JFIFxxC      C  " }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3Rbr{ gilour

File "color-picker.tsx"

Full Path: /home/markqprx/iniasli.pro/client/ui/color-picker/color-picker.tsx
File size: 1.96 KB
MIME-type: text/plain
Charset: utf-8

import {HexColorInput, HexColorPicker} from 'react-colorful';
import React, {useState} from 'react';
import {parseColor} from '@react-stately/color';
import {ColorSwatch} from './color-swatch';
import {getInputFieldClassNames} from '../forms/input-field/get-input-field-class-names';
import {ColorPresets} from '@common/ui/color-picker/color-presets';

const DefaultPresets = ColorPresets.map(({color}) => color).slice(0, 14);

type Props = {
  defaultValue?: string;
  onChange?: (e: string) => void;
  colorPresets?: string[];
  showInput?: boolean;
};
export function ColorPicker({
  defaultValue,
  onChange,
  colorPresets,
  showInput,
}: Props) {
  const [color, setColor] = useState<string | undefined>(defaultValue);

  const presets: string[] = colorPresets || DefaultPresets;

  const style = getInputFieldClassNames({size: 'sm'});

  return (
    <div>
      <HexColorPicker
        className="!w-auto"
        color={color}
        onChange={newColor => {
          onChange?.(newColor);
          setColor(newColor);
        }}
      />
      <div className="py-20 px-12">
        {presets && (
          <ColorSwatch
            colors={presets}
            onChange={newColor => {
              if (newColor) {
                const hex = parseColor(newColor).toString('hex');
                onChange?.(hex);
                setColor(hex);
              }
            }}
            value={color}
          />
        )}
        {showInput && (
          <div className="pt-20">
            <HexColorInput
              autoComplete="off"
              role="textbox"
              autoCorrect="off"
              spellCheck="false"
              required
              aria-label="Hex color"
              prefixed
              className={style.input}
              color={color}
              onChange={newColor => {
                onChange?.(newColor);
                setColor(newColor);
              }}
            />
          </div>
        )}
      </div>
    </div>
  );
}