-
Notifications
You must be signed in to change notification settings - Fork 1.7k
/
single-color-palette.tsx
87 lines (77 loc) · 2.97 KB
/
single-color-palette.tsx
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
// Copyright (c) 2023 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
import React, {MouseEvent} from 'react';
import {range} from 'd3-array';
import styled from 'styled-components';
import {hexToRgb} from '@kepler.gl/utils';
import {ColorsByTheme, Themes, ColorRange} from '@kepler.gl/constants';
import {RGBColor} from '@kepler.gl/types';
export type SingleColorPaletteProps = {
onSelectColor: (color: RGBColor | ColorRange, e: MouseEvent) => void;
// hex value
selectedColor: string;
};
const PALETTE_HEIGHT = '8px';
const ROWS = 22;
const StyledColorPalette = styled.div`
display: flex;
flex-direction: row;
justify-content: space-between;
padding: 12px;
:hover {
cursor: pointer;
}
`;
const StyledColorColumn = styled.div`
display: flex;
flex-grow: 1;
flex-direction: column;
justify-content: space-between;
`;
const StyledColorBlock = styled.div<{selected: boolean}>`
flex-grow: 1;
height: ${PALETTE_HEIGHT};
border-width: 1px;
border-style: solid;
`;
const SingleColorPalette: React.FC<SingleColorPaletteProps> = ({selectedColor, onSelectColor}) => (
<StyledColorPalette className="single-color-palette">
{Themes.map((theme, col) => (
<StyledColorColumn key={theme} className="single-color-palette__column">
{range(1, ROWS + 1, 1).map((key, i) => (
<StyledColorBlock
className="single-color-palette__block"
style={{
backgroundColor: ColorsByTheme[theme][key],
borderColor:
selectedColor === ColorsByTheme[theme][key].toUpperCase()
? 'white'
: ColorsByTheme[theme][key]
}}
key={`${theme}_${key}`}
selected={selectedColor === ColorsByTheme[theme][key].toUpperCase()}
onClick={e => onSelectColor(hexToRgb(ColorsByTheme[theme][key]), e)}
/>
))}
</StyledColorColumn>
))}
</StyledColorPalette>
);
export default SingleColorPalette;