0
owncast/web/stories/Color.tsx

69 lines
1.4 KiB
TypeScript
Raw Normal View History

2022-04-18 15:32:19 -07:00
import PropTypes from 'prop-types';
export function Color(props) {
const { color } = props;
const resolvedColor = getComputedStyle(document.documentElement).getPropertyValue(`--${color}`);
const containerStyle = {
borderRadius: '20px',
width: '12vw',
height: '12vw',
minWidth: '100px',
minHeight: '100px',
borderWidth: '1.5px',
borderStyle: 'solid',
borderColor: 'lightgray',
overflow: 'hidden',
2022-05-06 23:27:29 -07:00
margin: '0.3vw',
2022-04-18 15:32:19 -07:00
};
const colorBlockStyle = {
height: '70%',
width: '100%',
backgroundColor: resolvedColor,
};
const colorDescriptionStyle = {
margin: '5px',
2022-05-06 23:27:29 -07:00
color: 'gray',
fontSize: '0.8em',
2022-04-18 15:32:19 -07:00
};
return (
<figure style={containerStyle}>
<div style={colorBlockStyle} />
2022-05-11 23:31:31 -07:00
<figcaption>
<span style={colorDescriptionStyle}>{color}</span>
</figcaption>
2022-04-18 15:32:19 -07:00
</figure>
);
}
Color.propTypes = {
color: PropTypes.string.isRequired,
};
const rowStyle = {
display: 'flex',
2022-05-11 23:31:31 -07:00
flexDirection: 'row' as 'row',
flexWrap: 'wrap' as 'wrap',
2022-04-18 15:32:19 -07:00
// justifyContent: 'space-around',
alignItems: 'center',
};
export function ColorRow(props) {
const { colors } = props;
return (
<div style={rowStyle}>
{colors.map(color => (
<Color key={color} color={color} />
))}
</div>
);
}
ColorRow.propTypes = {
colors: PropTypes.arrayOf(PropTypes.string).isRequired,
};