index.tsx 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. import React, { useCallback, useEffect, useState } from "react"
  2. import { SketchPicker } from 'react-color'
  3. import style from './index.less'
  4. type props = {
  5. onColor: (color: string) => void,
  6. defaultColor?: string,
  7. value?: string,
  8. }
  9. const ColorPicker = (props: props) => {
  10. let { onColor, defaultColor = "#000000", value } = props
  11. const [displayColorPicker, setDisplayColorPicker] = useState<boolean>(false)
  12. const [color, setColor] = useState<any>(defaultColor)
  13. const handleClick = useCallback(() => {
  14. setDisplayColorPicker(!displayColorPicker)
  15. }, [])
  16. const handleClose = useCallback(() => {
  17. setDisplayColorPicker(false)
  18. }, [])
  19. const handleChange = useCallback((e: any) => {
  20. setColor(e.hex)
  21. onColor(e.hex)
  22. }, [color])
  23. useEffect(() => {
  24. onColor(color)
  25. }, [])
  26. useEffect(() => {
  27. if (value) {
  28. setColor(value)
  29. onColor(value)
  30. }
  31. }, [value])
  32. return <>
  33. <div className={style.colorPicker}>
  34. <div className={style.swatch} onClick={handleClick}>
  35. <div className={style.color} style={{ backgroundColor: color }} />
  36. </div>
  37. {
  38. displayColorPicker ? <div className={style.popover}>
  39. <div className={style.cover} onClick={handleClose} />
  40. <SketchPicker color={color} onChange={handleChange} className={style.sketchPicker} />
  41. </div> : null
  42. }
  43. </div>
  44. </>
  45. }
  46. export default React.memo(ColorPicker)