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 | import React, { FC, useMemo } from "react"; import { SingleValue } from "react-select"; import l10n from "shared/lib/lang/l10n"; import { Select } from "ui/form/Select"; interface CameraSpeedSelectProps { name: string; value?: number | null; allowNone?: boolean; allowDefault?: boolean; onChange?: (newValue: number | null) => void; } interface CameraSpeedOption { value: number; label: string; } export const CameraSpeedSelect: FC<CameraSpeedSelectProps> = ({ name, value = 2, allowNone, allowDefault, onChange, }) => { const options = useMemo( () => [ ...(allowDefault ? [{ value: -1, label: `${l10n("FIELD_DEFAULT")}` }] : []), ...(allowNone ? [{ value: 0, label: `${l10n("FIELD_INSTANT")}` }] : []), { value: 1, label: `${l10n("FIELD_SPEED")} 1 (${l10n("FIELD_FASTER")})` }, { 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 (${l10n("FIELD_SLOWER")})` }, ], [allowDefault, allowNone] ); const currentValue = options.find((o) => o.value === value); return ( <Select name={name} value={currentValue} options={options} onChange={(newValue: SingleValue<CameraSpeedOption>) => { Iif (newValue) { onChange?.(newValue.value); } }} /> ); }; |