mirror of
https://github.com/Stremio/stremio-web.git
synced 2026-03-11 21:27:05 +00:00
Dropped forwardRef. Minor formatting changes
This commit is contained in:
parent
51b607e7b4
commit
d9c3743400
1 changed files with 13 additions and 11 deletions
|
|
@ -8,11 +8,15 @@ const useBinaryState = require('stremio/common/useBinaryState');
|
|||
const Icon = require('stremio-icons/dom/Icon');
|
||||
const styles = require('./styles');
|
||||
|
||||
const ColorInput = React.forwardRef((props, ref) => {
|
||||
const ColorInput = ({ className, defaultValue, onChange }) => {
|
||||
const [menuOpen, openMenu, closeMenu, toggleMenu] = useBinaryState(false);
|
||||
const [color, setColor] = React.useState(props.defaultValue);
|
||||
const [chosenColor, setChosenColor] = React.useState(props.defaultValue);
|
||||
const updateColorsAndCloseMenu = () => { setChosenColor(color); props.onChange(color); closeMenu(); };
|
||||
const [color, setColor] = React.useState(defaultValue);
|
||||
const [selectedColor, setSelectedColor] = React.useState(defaultValue);
|
||||
const updateColorsAndCloseMenu = React.useCallback(() => {
|
||||
setSelectedColor(color);
|
||||
onChange(color);
|
||||
closeMenu();
|
||||
}, [color, onChange]);
|
||||
return (
|
||||
<Popup
|
||||
open={menuOpen}
|
||||
|
|
@ -20,25 +24,23 @@ const ColorInput = React.forwardRef((props, ref) => {
|
|||
onCloseRequest={closeMenu}
|
||||
// onCloseRequest={(event) => event.type === 'scroll' || closeMenu()}
|
||||
renderLabel={(ref) => (
|
||||
<Button ref={ref} title={name} onClick={toggleMenu} style={{ backgroundColor: chosenColor }} className={props.className}></Button>
|
||||
<Button className={className} ref={ref} title={selectedColor} onClick={toggleMenu} style={{ backgroundColor: selectedColor }}></Button>
|
||||
)}
|
||||
renderMenu={() => (
|
||||
<div className={classnames(styles['color-input-container'] )}>
|
||||
<div className={classnames(styles['color-input-container'])}>
|
||||
<Button onClick={closeMenu}>
|
||||
<Icon className={classnames(styles['x-icon'])} icon={'ic_x'} />
|
||||
</Button>
|
||||
<h1>Choose a color:</h1>
|
||||
<ColorPicker value={color} onChange={setColor} className={classnames(styles['color-input'])}/>
|
||||
<Button className={classnames(styles['button'])} onClick={updateColorsAndCloseMenu}>Select</Button>
|
||||
<ColorPicker className={classnames(styles['color-input'])} value={color} onChange={setColor} />
|
||||
<Button className={classnames(styles['button'])} onClick={updateColorsAndCloseMenu}>Select</Button>
|
||||
</div>
|
||||
)}
|
||||
/>
|
||||
);
|
||||
});
|
||||
};
|
||||
|
||||
|
||||
ColorInput.displayName = 'ColorInput';
|
||||
|
||||
ColorInput.propTypes = {
|
||||
className: PropTypes.string,
|
||||
defaultValue: PropTypes.string,
|
||||
|
|
|
|||
Loading…
Reference in a new issue