All files / src/components/forms MusicDriverSelect.tsx

0% Statements 0/19
0% Branches 0/10
0% Functions 0/6
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                                                                                                                                                                                   
import l10n from "shared/lib/lang/l10n";
import React, { FC, useCallback, useEffect, useMemo, useState } from "react";
import { MusicDriverSetting } from "store/features/settings/settingsState";
import {
  Option,
  OptionLabelWithInfo,
  Select,
  SelectCommonProps,
} from "ui/form/Select";
import { SingleValue } from "react-select";
 
interface MusicDriverSelectProps extends SelectCommonProps {
  name: string;
  value?: MusicDriverSetting;
  onChange?: (newId: MusicDriverSetting) => void;
}
 
export interface MusicDriverOption {
  value: MusicDriverSetting;
  label: string;
}
 
const musicDriverOptions: MusicDriverOption[] = [
  {
    label: "UGE",
    value: "huge",
  },
  {
    label: "MOD",
    value: "gbt",
  },
];
 
export const MusicDriverSelect: FC<MusicDriverSelectProps> = ({
  value,
  onChange,
}) => {
  const [currentValue, setCurrentValue] = useState<MusicDriverOption>();
  const musicDriverOptionsInfo: { [key: string]: string } = useMemo(
    () => ({
      huge: l10n("FIELD_HUGE_DRIVER_INFO"),
      gbt: l10n("FIELD_GBT_PLAYER_INFO"),
    }),
    []
  );
 
  useEffect(() => {
    const currentMusicDriver = musicDriverOptions.find(
      (e) => e.value === value
    );
    Iif (currentMusicDriver) {
      setCurrentValue(currentMusicDriver);
    }
  }, [value]);
 
  const onSelectChange = useCallback(
    (newValue: SingleValue<MusicDriverOption>) => {
      Iif (newValue) {
        onChange?.(newValue.value);
      }
    },
    [onChange]
  );
 
  return (
    <Select
      value={currentValue}
      options={musicDriverOptions}
      onChange={onSelectChange}
      formatOptionLabel={(
        option: Option,
        { context }: { context: "menu" | "value" }
      ) => {
        return (
          <OptionLabelWithInfo
            info={
              context === "menu" ? musicDriverOptionsInfo[option.value] : ""
            }
          >
            {option.label}
            {context === "value"
              ? ` (${musicDriverOptionsInfo[option.value]})`
              : ""}
          </OptionLabelWithInfo>
        );
      }}
    />
  );
};