2022-10-25 14:56:25 -07:00
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import { HStack } from 'soapbox/components/ui';
|
2022-12-16 17:22:59 -08:00
|
|
|
import { compareId } from 'soapbox/utils/comparators';
|
2022-10-25 15:47:24 -07:00
|
|
|
|
|
|
|
import Color from './color';
|
2022-10-25 14:56:25 -07:00
|
|
|
|
|
|
|
interface ColorGroup {
|
|
|
|
[tint: string]: string,
|
|
|
|
}
|
|
|
|
|
|
|
|
interface IPalette {
|
|
|
|
palette: ColorGroup,
|
2022-10-25 15:47:24 -07:00
|
|
|
onChange: (palette: ColorGroup) => void,
|
2022-10-25 14:56:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Editable color palette. */
|
2022-10-25 15:47:24 -07:00
|
|
|
const Palette: React.FC<IPalette> = ({ palette, onChange }) => {
|
2022-10-25 14:56:25 -07:00
|
|
|
const tints = Object.keys(palette).sort(compareId);
|
|
|
|
|
2022-10-25 15:47:24 -07:00
|
|
|
const handleChange = (tint: string) => {
|
|
|
|
return (color: string) => {
|
|
|
|
onChange({
|
|
|
|
...palette,
|
|
|
|
[tint]: color,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
2022-10-25 14:56:25 -07:00
|
|
|
|
|
|
|
return (
|
|
|
|
<HStack className='w-full h-8 rounded-md overflow-hidden'>
|
2022-10-25 15:47:24 -07:00
|
|
|
{tints.map(tint => (
|
|
|
|
<Color color={palette[tint]} onChange={handleChange(tint)} />
|
|
|
|
))}
|
2022-10-25 14:56:25 -07:00
|
|
|
</HStack>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export {
|
|
|
|
Palette as default,
|
|
|
|
ColorGroup,
|
|
|
|
};
|