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 | import React, { FC, useMemo } from "react"; import { SingleValue } from "react-select"; import l10n from "shared/lib/lang/l10n"; import { Select, SelectCommonProps } from "ui/form/Select"; interface TextSpeedSelectProps extends SelectCommonProps { name: string; value?: number | null; onChange?: (newValue: number | null) => void; } interface TextSpeedOption { value: number; label: string; } export const TextSpeedSelect: FC<TextSpeedSelectProps> = ({ name, value = 3, onChange, ...selectProps }) => { const options: TextSpeedOption[] = useMemo( () => [ { value: 0, label: `${l10n("FIELD_INSTANT")}` }, { value: 1, label: `${l10n("FIELD_SPEED")} 1` }, { value: 2, label: `${l10n("FIELD_SPEED")} 2` }, { value: 3, label: `${l10n("FIELD_SPEED")} 3` }, { value: 4, label: `${l10n("FIELD_SPEED")} 4` }, { value: 5, label: `${l10n("FIELD_SPEED")} 5` }, ], [] ); const currentValue = options.find((o) => o.value === value); return ( <Select name={name} value={currentValue} options={options} onChange={(newValue: SingleValue<TextSpeedOption>) => { Iif (newValue) { onChange?.(newValue.value); } }} {...selectProps} /> ); }; |