All files / src/components/forms ColorModeSelect.tsx

0% Statements 0/20
0% Branches 0/8
0% Functions 0/7
0% Lines 0/18

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 83 84 85 86 87 88 89 90 91                                                                                                                                                                                     
import React, { FC, useCallback, useEffect, useMemo, useState } from "react";
import { ColorModeSetting } from "store/features/settings/settingsState";
import {
  Option,
  OptionLabelWithInfo,
  Select,
  SelectCommonProps,
} from "ui/form/Select";
import l10n from "shared/lib/lang/l10n";
import { SingleValue } from "react-select";
 
interface ColorModeSelectProps extends SelectCommonProps {
  name: string;
  value?: ColorModeSetting;
  onChange?: (newId: ColorModeSetting) => void;
}
 
export interface ColorModeOption {
  value: ColorModeSetting;
  label: string;
}
 
export const ColorModeSelect: FC<ColorModeSelectProps> = ({
  value,
  onChange,
}) => {
  const [currentValue, setCurrentValue] = useState<ColorModeOption>();
  const colorModeOptionsInfo: { [key: string]: string } = useMemo(
    () => ({
      mono: l10n("FIELD_COLOR_MODE_MONO_INFO"),
      mixed: l10n("FIELD_COLOR_MODE_COLOR_MONO_INFO"),
      color: l10n("FIELD_COLOR_MODE_COLOR_ONLY_INFO"),
    }),
    []
  );
 
  const colorModeOptions: ColorModeOption[] = useMemo(
    () => [
      {
        value: "mono",
        label: l10n("FIELD_COLOR_MODE_MONO"),
      },
      {
        value: "mixed",
        label: l10n("FIELD_COLOR_MODE_COLOR_MONO"),
      },
      {
        value: "color",
        label: l10n("FIELD_COLOR_MODE_COLOR_ONLY"),
      },
    ],
    []
  );
 
  useEffect(() => {
    const currentColorMode = colorModeOptions.find((e) => e.value === value);
    Iif (currentColorMode) {
      setCurrentValue(currentColorMode);
    }
  }, [colorModeOptions, value]);
 
  const onSelectChange = useCallback(
    (newValue: SingleValue<ColorModeOption>) => {
      Iif (newValue) {
        onChange?.(newValue.value);
      }
    },
    [onChange]
  );
 
  return (
    <Select
      value={currentValue}
      options={colorModeOptions}
      onChange={onSelectChange}
      formatOptionLabel={(
        option: Option,
        { context }: { context: "menu" | "value" }
      ) => {
        return (
          <OptionLabelWithInfo
            info={context === "menu" ? colorModeOptionsInfo[option.value] : ""}
          >
            {option.label}
          </OptionLabelWithInfo>
        );
      }}
    />
  );
};