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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | import React, { FC, useCallback, useEffect, useMemo, useState } from "react"; import { Select, SelectCommonProps } from "ui/form/Select"; import l10n from "shared/lib/lang/l10n"; import { SingleValue } from "react-select"; type AutoTileFlipSelectProps = | ({ allowDefault: true; value?: boolean; onChange?: (newId: boolean | undefined) => void; } & SelectCommonProps) | ({ allowDefault?: false | undefined; value?: boolean; onChange?: (newId: boolean) => void; } & SelectCommonProps); interface AutoTileFlipOption { value: boolean | undefined; label: string; } export const AutoTileFlipSelect: FC<AutoTileFlipSelectProps> = ({ value, allowDefault, onChange, }) => { const [currentValue, setCurrentValue] = useState<AutoTileFlipOption>(); const autoTileFlipOptions: AutoTileFlipOption[] = useMemo(() => { const options = allowDefault ? [ { value: undefined, label: l10n("FIELD_NONE"), }, ] : ([] as AutoTileFlipOption[]); return options.concat([ { value: true, label: l10n(allowDefault ? "FIELD_ENABLED" : "FIELD_ENABLED_DEFAULT"), }, { value: false, label: l10n("FIELD_DISABLED"), }, ]); }, [allowDefault]); useEffect(() => { const currentAutoTileFlip = autoTileFlipOptions.find( (e) => e.value === value, ); Iif (currentAutoTileFlip) { setCurrentValue(currentAutoTileFlip); } }, [autoTileFlipOptions, value]); const onSelectChange = useCallback( (newValue: SingleValue<AutoTileFlipOption>) => { Iif (newValue) { if (allowDefault) { onChange?.(newValue.value); } else { onChange?.(!!newValue.value); } } }, [allowDefault, onChange], ); return ( <Select value={currentValue} options={autoTileFlipOptions} onChange={onSelectChange} /> ); }; |