Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | import React, { FC, useEffect, useMemo, useState } from "react"; import { SingleValue } from "react-select"; import l10n from "shared/lib/lang/l10n"; import { Select } from "ui/form/Select"; interface ParallaxSpeedSelectProps { name: string; value?: number; disabled?: boolean; onChange?: (newValue: number) => void; } interface ParallaxSpeedOption { value: number; label: string; } export const ParallaxSpeedSelect: FC<ParallaxSpeedSelectProps> = ({ name, value = 1, disabled, onChange, }) => { const options: ParallaxSpeedOption[] = useMemo( () => [ { value: 128, label: `${l10n("FIELD_FIXED_POSITION")}` }, { value: 0, label: `${l10n("FIELD_SPEED")} 1` }, { value: 1, label: `${l10n("FIELD_SPEED")} ½` }, { value: 2, label: `${l10n("FIELD_SPEED")} ¼` }, { value: 3, label: `${l10n("FIELD_SPEED")} ⅛` }, { value: 4, label: `${l10n("FIELD_SPEED")} ¹⁄₁₆` }, { value: 5, label: `${l10n("FIELD_SPEED")} ¹⁄₃₂` }, { value: 6, label: `${l10n("FIELD_SPEED")} ¹⁄₆₄` }, { value: 7, label: `${l10n("FIELD_SPEED")} ¹⁄₁₂₈` }, { value: 8, label: `${l10n("FIELD_SPEED")} ¹⁄₂₅₆` }, ], [] ); const [currentValue, setCurrentValue] = useState<ParallaxSpeedOption | undefined>(); useEffect(() => { const current = options.find((o) => o.value === value); setCurrentValue(current); }, [options, value]); return ( <Select name={name} value={currentValue} options={options} isDisabled={disabled} onChange={(newValue: SingleValue<ParallaxSpeedOption>) => { Iif (newValue) { onChange?.(newValue.value); } }} /> ); }; |