@uiw/react-color-sketch
Advanced tools
Comparing version 0.0.16 to 0.0.17
import React from 'react'; | ||
import { HsvaColor, ColorResult } from '@uiw/color-convert'; | ||
import { PresetColor } from './Swatch'; | ||
import { SwatchPresetColor } from '@uiw/react-color-swatch'; | ||
export interface SketchProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> { | ||
@@ -8,3 +8,3 @@ prefixCls?: string; | ||
color?: string | HsvaColor; | ||
presetColors?: false | PresetColor[]; | ||
presetColors?: false | SwatchPresetColor[]; | ||
editableDisable?: boolean; | ||
@@ -11,0 +11,0 @@ onChange?: (newShade: ColorResult) => void; |
@@ -36,3 +36,3 @@ "use strict"; | ||
var _Swatch = _interopRequireDefault(require("./Swatch")); | ||
var _reactColorSwatch = _interopRequireDefault(require("@uiw/react-color-swatch")); | ||
@@ -213,7 +213,23 @@ var _excluded = ["prefixCls", "className", "onChange", "width", "presetColors", "color", "editableDisable", "style"]; | ||
} | ||
})), presetColors && presetColors.length > 0 && /*#__PURE__*/_react.default.createElement(_Swatch.default, { | ||
})), presetColors && presetColors.length > 0 && /*#__PURE__*/_react.default.createElement(_reactColorSwatch.default, { | ||
style: { | ||
borderTop: '1px solid rgb(238, 238, 238)', | ||
paddingTop: 10, | ||
paddingLeft: 10 | ||
}, | ||
colors: presetColors, | ||
color: (0, _colorConvert.hsvaToHex)(hsva), | ||
onClick: function onClick(hsva) { | ||
return handleChange(hsva); | ||
onChange: function onChange(hsvColor) { | ||
return handleChange(hsvColor); | ||
}, | ||
rectProps: { | ||
style: { | ||
marginRight: 10, | ||
marginBottom: 10, | ||
borderRadius: 3, | ||
boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px inset' // display: 'flex', | ||
// alignItems: 'center', | ||
// justifyContent: 'center', | ||
} | ||
} | ||
@@ -225,2 +241,2 @@ })); | ||
module.exports = exports.default; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["PRESET_COLORS","Bar","props","boxShadow","width","top","bottom","left","borderRadius","position","backgroundColor","React","forwardRef","ref","prefixCls","className","onChange","presetColors","color","editableDisable","style","other","h","s","v","a","hsva","setHsva","handleChange","hsv","handleHex","value","evn","test","String","length","background","padding","height","newColor","display","marginTop","flex","marginLeft","marginRight","newHue","newAlpha","margin","replace","toLocaleUpperCase","val","minWidth","result"],"mappings":"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","sourcesContent":["import React, { useState, useCallback, Fragment } from 'react';\nimport Saturation from '@uiw/react-color-saturation';\nimport Alpha from '@uiw/react-color-alpha';\nimport EditableInput from '@uiw/react-color-editable-input';\nimport RGBA from '@uiw/react-color-editable-input-rgba';\nimport { PointerProps } from '@uiw/react-color-alpha/lib/cjs/Pointer';\nimport Hue from '@uiw/react-color-hue';\nimport {\n  validHex,\n  HsvaColor,\n  hsvaToHex,\n  hsvaToRgbaString,\n  hexToHsva,\n  color as handleColor,\n  ColorResult,\n} from '@uiw/color-convert';\nimport Swatch, { PresetColor } from './Swatch';\nimport { useEffect } from 'react';\n\nconst PRESET_COLORS = [\n  '#D0021B',\n  '#F5A623',\n  '#f8e61b',\n  '#8B572A',\n  '#7ED321',\n  '#417505',\n  '#BD10E0',\n  '#9013FE',\n  '#4A90E2',\n  '#50E3C2',\n  '#B8E986',\n  '#000000',\n  '#4A4A4A',\n  '#9B9B9B',\n  '#FFFFFF',\n];\n\nexport interface SketchProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> {\n  prefixCls?: string;\n  width?: number;\n  color?: string | HsvaColor;\n  presetColors?: false | PresetColor[];\n  editableDisable?: boolean;\n  onChange?: (newShade: ColorResult) => void;\n}\n\nconst Bar = (props: PointerProps) => (\n  <div\n    style={{\n      boxShadow: 'rgb(0 0 0 / 60%) 0px 0px 2px',\n      width: 4,\n      top: 1,\n      bottom: 1,\n      left: props.left,\n      borderRadius: 1,\n      position: 'absolute',\n      backgroundColor: '#fff',\n    }}\n  />\n);\n\nexport default React.forwardRef<HTMLDivElement, SketchProps>((props, ref) => {\n  const {\n    prefixCls = 'w-color-sketch',\n    className,\n    onChange,\n    width = 218,\n    presetColors = PRESET_COLORS,\n    color,\n    editableDisable = true,\n    style,\n    ...other\n  } = props;\n  const [hsva, setHsva] = useState({ h: 209, s: 36, v: 90, a: 1 });\n  useEffect(() => {\n    if (typeof color === 'string' && validHex(color)) {\n      setHsva(hexToHsva(color));\n    }\n    if (typeof color === 'object') {\n      setHsva(color);\n    }\n  }, [color]);\n\n  const handleChange = useCallback(\n    (hsv: HsvaColor) => {\n      setHsva(hsv);\n      onChange && onChange(handleColor(hsv));\n    },\n    [hsva],\n  );\n\n  const handleHex = (value: string | number, evn: React.ChangeEvent<HTMLInputElement>) => {\n    if (typeof value === 'string' && validHex(value) && /(3|6)/.test(String(value.length))) {\n      handleChange(hexToHsva(value));\n    }\n  };\n  return (\n    <div\n      {...other}\n      className={`${prefixCls} ${className || ''}`}\n      ref={ref}\n      style={{\n        background: 'rgb(255, 255, 255)',\n        borderRadius: 4,\n        boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px, rgb(0 0 0 / 15%) 0px 8px 16px',\n        width,\n        ...style,\n      }}\n    >\n      <div style={{ padding: '10px 10px 8px' }}>\n        <Saturation\n          hsva={hsva}\n          style={{ width: 'auto', height: 150 }}\n          onChange={(newColor) => handleChange({ ...hsva, ...newColor, a: hsva.a })}\n        />\n        <div style={{ display: 'flex', marginTop: 4 }}>\n          <div style={{ flex: 1 }}>\n            <Hue\n              width=\"auto\"\n              height={10}\n              hue={hsva.h}\n              pointer={Bar}\n              innerProps={{\n                style: { marginLeft: 1, marginRight: 5 },\n              }}\n              onChange={(newHue) => handleChange({ ...hsva, ...newHue })}\n            />\n            <Alpha\n              width=\"auto\"\n              height={10}\n              hsva={hsva}\n              pointer={Bar}\n              style={{ marginTop: 4 }}\n              innerProps={{\n                style: { marginLeft: 1, marginRight: 5 },\n              }}\n              onChange={(newAlpha) => {\n                handleChange({ ...hsva, ...{ a: newAlpha.a } });\n              }}\n            />\n          </div>\n          <Alpha\n            width={24}\n            height={24}\n            hsva={hsva}\n            radius={2}\n            style={{\n              marginLeft: 4,\n            }}\n            bgProps={{ style: { background: 'transparent' } }}\n            innerProps={{\n              style: {\n                borderRadius: 2,\n                background: hsvaToRgbaString(hsva),\n                boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px inset, rgb(0 0 0 / 25%) 0px 0px 4px inset',\n              },\n            }}\n            pointer={() => <Fragment />}\n          />\n        </div>\n      </div>\n      {editableDisable && (\n        <div style={{ display: 'flex', margin: '0 10px 3px 10px' }}>\n          <EditableInput\n            label=\"Hex\"\n            value={hsvaToHex(hsva).replace(/^#/, '').toLocaleUpperCase()}\n            onChange={(evn, val) => handleHex(val, evn)}\n            style={{ minWidth: 58 }}\n          />\n          <RGBA hsva={hsva} style={{ marginLeft: 6 }} onChange={(result) => handleChange(result.hsva)} />\n        </div>\n      )}\n      {presetColors && presetColors.length > 0 && (\n        <Swatch colors={presetColors} color={hsvaToHex(hsva)} onClick={(hsva) => handleChange(hsva)} />\n      )}\n    </div>\n  );\n});\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["PRESET_COLORS","Bar","props","boxShadow","width","top","bottom","left","borderRadius","position","backgroundColor","React","forwardRef","ref","prefixCls","className","onChange","presetColors","color","editableDisable","style","other","h","s","v","a","hsva","setHsva","handleChange","hsv","handleHex","value","evn","test","String","length","background","padding","height","newColor","display","marginTop","flex","marginLeft","marginRight","newHue","newAlpha","margin","replace","toLocaleUpperCase","val","minWidth","result","borderTop","paddingTop","paddingLeft","hsvColor","marginBottom"],"mappings":"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","sourcesContent":["import React, { useState, useCallback, Fragment } from 'react';\nimport Saturation from '@uiw/react-color-saturation';\nimport Alpha from '@uiw/react-color-alpha';\nimport EditableInput from '@uiw/react-color-editable-input';\nimport RGBA from '@uiw/react-color-editable-input-rgba';\nimport { PointerProps } from '@uiw/react-color-alpha/lib/cjs/Pointer';\nimport Hue from '@uiw/react-color-hue';\nimport {\n  validHex,\n  HsvaColor,\n  hsvaToHex,\n  hsvaToRgbaString,\n  hexToHsva,\n  color as handleColor,\n  ColorResult,\n} from '@uiw/color-convert';\nimport Swatch, { SwatchPresetColor } from '@uiw/react-color-swatch';\nimport { useEffect } from 'react';\n\nconst PRESET_COLORS = [\n  '#D0021B',\n  '#F5A623',\n  '#f8e61b',\n  '#8B572A',\n  '#7ED321',\n  '#417505',\n  '#BD10E0',\n  '#9013FE',\n  '#4A90E2',\n  '#50E3C2',\n  '#B8E986',\n  '#000000',\n  '#4A4A4A',\n  '#9B9B9B',\n  '#FFFFFF',\n];\n\nexport interface SketchProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> {\n  prefixCls?: string;\n  width?: number;\n  color?: string | HsvaColor;\n  presetColors?: false | SwatchPresetColor[];\n  editableDisable?: boolean;\n  onChange?: (newShade: ColorResult) => void;\n}\n\nconst Bar = (props: PointerProps) => (\n  <div\n    style={{\n      boxShadow: 'rgb(0 0 0 / 60%) 0px 0px 2px',\n      width: 4,\n      top: 1,\n      bottom: 1,\n      left: props.left,\n      borderRadius: 1,\n      position: 'absolute',\n      backgroundColor: '#fff',\n    }}\n  />\n);\n\nexport default React.forwardRef<HTMLDivElement, SketchProps>((props, ref) => {\n  const {\n    prefixCls = 'w-color-sketch',\n    className,\n    onChange,\n    width = 218,\n    presetColors = PRESET_COLORS,\n    color,\n    editableDisable = true,\n    style,\n    ...other\n  } = props;\n  const [hsva, setHsva] = useState({ h: 209, s: 36, v: 90, a: 1 });\n  useEffect(() => {\n    if (typeof color === 'string' && validHex(color)) {\n      setHsva(hexToHsva(color));\n    }\n    if (typeof color === 'object') {\n      setHsva(color);\n    }\n  }, [color]);\n\n  const handleChange = useCallback(\n    (hsv: HsvaColor) => {\n      setHsva(hsv);\n      onChange && onChange(handleColor(hsv));\n    },\n    [hsva],\n  );\n\n  const handleHex = (value: string | number, evn: React.ChangeEvent<HTMLInputElement>) => {\n    if (typeof value === 'string' && validHex(value) && /(3|6)/.test(String(value.length))) {\n      handleChange(hexToHsva(value));\n    }\n  };\n  return (\n    <div\n      {...other}\n      className={`${prefixCls} ${className || ''}`}\n      ref={ref}\n      style={{\n        background: 'rgb(255, 255, 255)',\n        borderRadius: 4,\n        boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px, rgb(0 0 0 / 15%) 0px 8px 16px',\n        width,\n        ...style,\n      }}\n    >\n      <div style={{ padding: '10px 10px 8px' }}>\n        <Saturation\n          hsva={hsva}\n          style={{ width: 'auto', height: 150 }}\n          onChange={(newColor) => handleChange({ ...hsva, ...newColor, a: hsva.a })}\n        />\n        <div style={{ display: 'flex', marginTop: 4 }}>\n          <div style={{ flex: 1 }}>\n            <Hue\n              width=\"auto\"\n              height={10}\n              hue={hsva.h}\n              pointer={Bar}\n              innerProps={{\n                style: { marginLeft: 1, marginRight: 5 },\n              }}\n              onChange={(newHue) => handleChange({ ...hsva, ...newHue })}\n            />\n            <Alpha\n              width=\"auto\"\n              height={10}\n              hsva={hsva}\n              pointer={Bar}\n              style={{ marginTop: 4 }}\n              innerProps={{\n                style: { marginLeft: 1, marginRight: 5 },\n              }}\n              onChange={(newAlpha) => {\n                handleChange({ ...hsva, ...{ a: newAlpha.a } });\n              }}\n            />\n          </div>\n          <Alpha\n            width={24}\n            height={24}\n            hsva={hsva}\n            radius={2}\n            style={{\n              marginLeft: 4,\n            }}\n            bgProps={{ style: { background: 'transparent' } }}\n            innerProps={{\n              style: {\n                borderRadius: 2,\n                background: hsvaToRgbaString(hsva),\n                boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px inset, rgb(0 0 0 / 25%) 0px 0px 4px inset',\n              },\n            }}\n            pointer={() => <Fragment />}\n          />\n        </div>\n      </div>\n      {editableDisable && (\n        <div style={{ display: 'flex', margin: '0 10px 3px 10px' }}>\n          <EditableInput\n            label=\"Hex\"\n            value={hsvaToHex(hsva).replace(/^#/, '').toLocaleUpperCase()}\n            onChange={(evn, val) => handleHex(val, evn)}\n            style={{ minWidth: 58 }}\n          />\n          <RGBA hsva={hsva} style={{ marginLeft: 6 }} onChange={(result) => handleChange(result.hsva)} />\n        </div>\n      )}\n      {presetColors && presetColors.length > 0 && (\n        <Swatch\n          style={{\n            borderTop: '1px solid rgb(238, 238, 238)',\n            paddingTop: 10,\n            paddingLeft: 10,\n          }}\n          colors={presetColors}\n          color={hsvaToHex(hsva)}\n          onChange={(hsvColor) => handleChange(hsvColor)}\n          rectProps={{\n            style: {\n              marginRight: 10,\n              marginBottom: 10,\n              borderRadius: 3,\n              boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px inset',\n              // display: 'flex',\n              // alignItems: 'center',\n              // justifyContent: 'center',\n            },\n          }}\n        />\n      )}\n    </div>\n  );\n});\n"]} |
import React from 'react'; | ||
import { HsvaColor, ColorResult } from '@uiw/color-convert'; | ||
import { PresetColor } from './Swatch'; | ||
import { SwatchPresetColor } from '@uiw/react-color-swatch'; | ||
export interface SketchProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> { | ||
@@ -8,3 +8,3 @@ prefixCls?: string; | ||
color?: string | HsvaColor; | ||
presetColors?: false | PresetColor[]; | ||
presetColors?: false | SwatchPresetColor[]; | ||
editableDisable?: boolean; | ||
@@ -11,0 +11,0 @@ onChange?: (newShade: ColorResult) => void; |
@@ -14,3 +14,3 @@ import _extends from "@babel/runtime/helpers/extends"; | ||
import { validHex, hsvaToHex, hsvaToRgbaString, hexToHsva, color as handleColor } from '@uiw/color-convert'; | ||
import Swatch from './Swatch'; | ||
import Swatch from '@uiw/react-color-swatch'; | ||
import { useEffect } from 'react'; | ||
@@ -191,9 +191,25 @@ var PRESET_COLORS = ['#D0021B', '#F5A623', '#f8e61b', '#8B572A', '#7ED321', '#417505', '#BD10E0', '#9013FE', '#4A90E2', '#50E3C2', '#B8E986', '#000000', '#4A4A4A', '#9B9B9B', '#FFFFFF']; | ||
})), presetColors && presetColors.length > 0 && /*#__PURE__*/React.createElement(Swatch, { | ||
style: { | ||
borderTop: '1px solid rgb(238, 238, 238)', | ||
paddingTop: 10, | ||
paddingLeft: 10 | ||
}, | ||
colors: presetColors, | ||
color: hsvaToHex(hsva), | ||
onClick: function onClick(hsva) { | ||
return handleChange(hsva); | ||
onChange: function onChange(hsvColor) { | ||
return handleChange(hsvColor); | ||
}, | ||
rectProps: { | ||
style: { | ||
marginRight: 10, | ||
marginBottom: 10, | ||
borderRadius: 3, | ||
boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px inset' // display: 'flex', | ||
// alignItems: 'center', | ||
// justifyContent: 'center', | ||
} | ||
} | ||
})); | ||
}); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","useState","useCallback","Fragment","Saturation","Alpha","EditableInput","RGBA","Hue","validHex","hsvaToHex","hsvaToRgbaString","hexToHsva","color","handleColor","Swatch","useEffect","PRESET_COLORS","Bar","props","boxShadow","width","top","bottom","left","borderRadius","position","backgroundColor","forwardRef","ref","prefixCls","className","onChange","presetColors","editableDisable","style","other","h","s","v","a","hsva","setHsva","handleChange","hsv","handleHex","value","evn","test","String","length","background","padding","height","newColor","display","marginTop","flex","marginLeft","marginRight","newHue","newAlpha","margin","replace","toLocaleUpperCase","val","minWidth","result"],"mappings":"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","sourcesContent":["import React, { useState, useCallback, Fragment } from 'react';\nimport Saturation from '@uiw/react-color-saturation';\nimport Alpha from '@uiw/react-color-alpha';\nimport EditableInput from '@uiw/react-color-editable-input';\nimport RGBA from '@uiw/react-color-editable-input-rgba';\nimport { PointerProps } from '@uiw/react-color-alpha/lib/cjs/Pointer';\nimport Hue from '@uiw/react-color-hue';\nimport {\n  validHex,\n  HsvaColor,\n  hsvaToHex,\n  hsvaToRgbaString,\n  hexToHsva,\n  color as handleColor,\n  ColorResult,\n} from '@uiw/color-convert';\nimport Swatch, { PresetColor } from './Swatch';\nimport { useEffect } from 'react';\n\nconst PRESET_COLORS = [\n  '#D0021B',\n  '#F5A623',\n  '#f8e61b',\n  '#8B572A',\n  '#7ED321',\n  '#417505',\n  '#BD10E0',\n  '#9013FE',\n  '#4A90E2',\n  '#50E3C2',\n  '#B8E986',\n  '#000000',\n  '#4A4A4A',\n  '#9B9B9B',\n  '#FFFFFF',\n];\n\nexport interface SketchProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> {\n  prefixCls?: string;\n  width?: number;\n  color?: string | HsvaColor;\n  presetColors?: false | PresetColor[];\n  editableDisable?: boolean;\n  onChange?: (newShade: ColorResult) => void;\n}\n\nconst Bar = (props: PointerProps) => (\n  <div\n    style={{\n      boxShadow: 'rgb(0 0 0 / 60%) 0px 0px 2px',\n      width: 4,\n      top: 1,\n      bottom: 1,\n      left: props.left,\n      borderRadius: 1,\n      position: 'absolute',\n      backgroundColor: '#fff',\n    }}\n  />\n);\n\nexport default React.forwardRef<HTMLDivElement, SketchProps>((props, ref) => {\n  const {\n    prefixCls = 'w-color-sketch',\n    className,\n    onChange,\n    width = 218,\n    presetColors = PRESET_COLORS,\n    color,\n    editableDisable = true,\n    style,\n    ...other\n  } = props;\n  const [hsva, setHsva] = useState({ h: 209, s: 36, v: 90, a: 1 });\n  useEffect(() => {\n    if (typeof color === 'string' && validHex(color)) {\n      setHsva(hexToHsva(color));\n    }\n    if (typeof color === 'object') {\n      setHsva(color);\n    }\n  }, [color]);\n\n  const handleChange = useCallback(\n    (hsv: HsvaColor) => {\n      setHsva(hsv);\n      onChange && onChange(handleColor(hsv));\n    },\n    [hsva],\n  );\n\n  const handleHex = (value: string | number, evn: React.ChangeEvent<HTMLInputElement>) => {\n    if (typeof value === 'string' && validHex(value) && /(3|6)/.test(String(value.length))) {\n      handleChange(hexToHsva(value));\n    }\n  };\n  return (\n    <div\n      {...other}\n      className={`${prefixCls} ${className || ''}`}\n      ref={ref}\n      style={{\n        background: 'rgb(255, 255, 255)',\n        borderRadius: 4,\n        boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px, rgb(0 0 0 / 15%) 0px 8px 16px',\n        width,\n        ...style,\n      }}\n    >\n      <div style={{ padding: '10px 10px 8px' }}>\n        <Saturation\n          hsva={hsva}\n          style={{ width: 'auto', height: 150 }}\n          onChange={(newColor) => handleChange({ ...hsva, ...newColor, a: hsva.a })}\n        />\n        <div style={{ display: 'flex', marginTop: 4 }}>\n          <div style={{ flex: 1 }}>\n            <Hue\n              width=\"auto\"\n              height={10}\n              hue={hsva.h}\n              pointer={Bar}\n              innerProps={{\n                style: { marginLeft: 1, marginRight: 5 },\n              }}\n              onChange={(newHue) => handleChange({ ...hsva, ...newHue })}\n            />\n            <Alpha\n              width=\"auto\"\n              height={10}\n              hsva={hsva}\n              pointer={Bar}\n              style={{ marginTop: 4 }}\n              innerProps={{\n                style: { marginLeft: 1, marginRight: 5 },\n              }}\n              onChange={(newAlpha) => {\n                handleChange({ ...hsva, ...{ a: newAlpha.a } });\n              }}\n            />\n          </div>\n          <Alpha\n            width={24}\n            height={24}\n            hsva={hsva}\n            radius={2}\n            style={{\n              marginLeft: 4,\n            }}\n            bgProps={{ style: { background: 'transparent' } }}\n            innerProps={{\n              style: {\n                borderRadius: 2,\n                background: hsvaToRgbaString(hsva),\n                boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px inset, rgb(0 0 0 / 25%) 0px 0px 4px inset',\n              },\n            }}\n            pointer={() => <Fragment />}\n          />\n        </div>\n      </div>\n      {editableDisable && (\n        <div style={{ display: 'flex', margin: '0 10px 3px 10px' }}>\n          <EditableInput\n            label=\"Hex\"\n            value={hsvaToHex(hsva).replace(/^#/, '').toLocaleUpperCase()}\n            onChange={(evn, val) => handleHex(val, evn)}\n            style={{ minWidth: 58 }}\n          />\n          <RGBA hsva={hsva} style={{ marginLeft: 6 }} onChange={(result) => handleChange(result.hsva)} />\n        </div>\n      )}\n      {presetColors && presetColors.length > 0 && (\n        <Swatch colors={presetColors} color={hsvaToHex(hsva)} onClick={(hsva) => handleChange(hsva)} />\n      )}\n    </div>\n  );\n});\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","useState","useCallback","Fragment","Saturation","Alpha","EditableInput","RGBA","Hue","validHex","hsvaToHex","hsvaToRgbaString","hexToHsva","color","handleColor","Swatch","useEffect","PRESET_COLORS","Bar","props","boxShadow","width","top","bottom","left","borderRadius","position","backgroundColor","forwardRef","ref","prefixCls","className","onChange","presetColors","editableDisable","style","other","h","s","v","a","hsva","setHsva","handleChange","hsv","handleHex","value","evn","test","String","length","background","padding","height","newColor","display","marginTop","flex","marginLeft","marginRight","newHue","newAlpha","margin","replace","toLocaleUpperCase","val","minWidth","result","borderTop","paddingTop","paddingLeft","hsvColor","marginBottom"],"mappings":"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","sourcesContent":["import React, { useState, useCallback, Fragment } from 'react';\nimport Saturation from '@uiw/react-color-saturation';\nimport Alpha from '@uiw/react-color-alpha';\nimport EditableInput from '@uiw/react-color-editable-input';\nimport RGBA from '@uiw/react-color-editable-input-rgba';\nimport { PointerProps } from '@uiw/react-color-alpha/lib/cjs/Pointer';\nimport Hue from '@uiw/react-color-hue';\nimport {\n  validHex,\n  HsvaColor,\n  hsvaToHex,\n  hsvaToRgbaString,\n  hexToHsva,\n  color as handleColor,\n  ColorResult,\n} from '@uiw/color-convert';\nimport Swatch, { SwatchPresetColor } from '@uiw/react-color-swatch';\nimport { useEffect } from 'react';\n\nconst PRESET_COLORS = [\n  '#D0021B',\n  '#F5A623',\n  '#f8e61b',\n  '#8B572A',\n  '#7ED321',\n  '#417505',\n  '#BD10E0',\n  '#9013FE',\n  '#4A90E2',\n  '#50E3C2',\n  '#B8E986',\n  '#000000',\n  '#4A4A4A',\n  '#9B9B9B',\n  '#FFFFFF',\n];\n\nexport interface SketchProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> {\n  prefixCls?: string;\n  width?: number;\n  color?: string | HsvaColor;\n  presetColors?: false | SwatchPresetColor[];\n  editableDisable?: boolean;\n  onChange?: (newShade: ColorResult) => void;\n}\n\nconst Bar = (props: PointerProps) => (\n  <div\n    style={{\n      boxShadow: 'rgb(0 0 0 / 60%) 0px 0px 2px',\n      width: 4,\n      top: 1,\n      bottom: 1,\n      left: props.left,\n      borderRadius: 1,\n      position: 'absolute',\n      backgroundColor: '#fff',\n    }}\n  />\n);\n\nexport default React.forwardRef<HTMLDivElement, SketchProps>((props, ref) => {\n  const {\n    prefixCls = 'w-color-sketch',\n    className,\n    onChange,\n    width = 218,\n    presetColors = PRESET_COLORS,\n    color,\n    editableDisable = true,\n    style,\n    ...other\n  } = props;\n  const [hsva, setHsva] = useState({ h: 209, s: 36, v: 90, a: 1 });\n  useEffect(() => {\n    if (typeof color === 'string' && validHex(color)) {\n      setHsva(hexToHsva(color));\n    }\n    if (typeof color === 'object') {\n      setHsva(color);\n    }\n  }, [color]);\n\n  const handleChange = useCallback(\n    (hsv: HsvaColor) => {\n      setHsva(hsv);\n      onChange && onChange(handleColor(hsv));\n    },\n    [hsva],\n  );\n\n  const handleHex = (value: string | number, evn: React.ChangeEvent<HTMLInputElement>) => {\n    if (typeof value === 'string' && validHex(value) && /(3|6)/.test(String(value.length))) {\n      handleChange(hexToHsva(value));\n    }\n  };\n  return (\n    <div\n      {...other}\n      className={`${prefixCls} ${className || ''}`}\n      ref={ref}\n      style={{\n        background: 'rgb(255, 255, 255)',\n        borderRadius: 4,\n        boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px, rgb(0 0 0 / 15%) 0px 8px 16px',\n        width,\n        ...style,\n      }}\n    >\n      <div style={{ padding: '10px 10px 8px' }}>\n        <Saturation\n          hsva={hsva}\n          style={{ width: 'auto', height: 150 }}\n          onChange={(newColor) => handleChange({ ...hsva, ...newColor, a: hsva.a })}\n        />\n        <div style={{ display: 'flex', marginTop: 4 }}>\n          <div style={{ flex: 1 }}>\n            <Hue\n              width=\"auto\"\n              height={10}\n              hue={hsva.h}\n              pointer={Bar}\n              innerProps={{\n                style: { marginLeft: 1, marginRight: 5 },\n              }}\n              onChange={(newHue) => handleChange({ ...hsva, ...newHue })}\n            />\n            <Alpha\n              width=\"auto\"\n              height={10}\n              hsva={hsva}\n              pointer={Bar}\n              style={{ marginTop: 4 }}\n              innerProps={{\n                style: { marginLeft: 1, marginRight: 5 },\n              }}\n              onChange={(newAlpha) => {\n                handleChange({ ...hsva, ...{ a: newAlpha.a } });\n              }}\n            />\n          </div>\n          <Alpha\n            width={24}\n            height={24}\n            hsva={hsva}\n            radius={2}\n            style={{\n              marginLeft: 4,\n            }}\n            bgProps={{ style: { background: 'transparent' } }}\n            innerProps={{\n              style: {\n                borderRadius: 2,\n                background: hsvaToRgbaString(hsva),\n                boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px inset, rgb(0 0 0 / 25%) 0px 0px 4px inset',\n              },\n            }}\n            pointer={() => <Fragment />}\n          />\n        </div>\n      </div>\n      {editableDisable && (\n        <div style={{ display: 'flex', margin: '0 10px 3px 10px' }}>\n          <EditableInput\n            label=\"Hex\"\n            value={hsvaToHex(hsva).replace(/^#/, '').toLocaleUpperCase()}\n            onChange={(evn, val) => handleHex(val, evn)}\n            style={{ minWidth: 58 }}\n          />\n          <RGBA hsva={hsva} style={{ marginLeft: 6 }} onChange={(result) => handleChange(result.hsva)} />\n        </div>\n      )}\n      {presetColors && presetColors.length > 0 && (\n        <Swatch\n          style={{\n            borderTop: '1px solid rgb(238, 238, 238)',\n            paddingTop: 10,\n            paddingLeft: 10,\n          }}\n          colors={presetColors}\n          color={hsvaToHex(hsva)}\n          onChange={(hsvColor) => handleChange(hsvColor)}\n          rectProps={{\n            style: {\n              marginRight: 10,\n              marginBottom: 10,\n              borderRadius: 3,\n              boxShadow: 'rgb(0 0 0 / 15%) 0px 0px 0px 1px inset',\n              // display: 'flex',\n              // alignItems: 'center',\n              // justifyContent: 'center',\n            },\n          }}\n        />\n      )}\n    </div>\n  );\n});\n"]} |
{ | ||
"name": "@uiw/react-color-sketch", | ||
"version": "0.0.16", | ||
"version": "0.0.17", | ||
"description": "Color Sketch component for React.", | ||
@@ -33,8 +33,9 @@ "homepage": "https://uiwjs.github.io/react-color/#react-color-sketch", | ||
"@babel/runtime": "7.14.6", | ||
"@uiw/color-convert": "^0.0.16", | ||
"@uiw/react-color-alpha": "^0.0.16", | ||
"@uiw/react-color-editable-input": "^0.0.16", | ||
"@uiw/react-color-editable-input-rgba": "^0.0.16", | ||
"@uiw/react-color-hue": "^0.0.16", | ||
"@uiw/react-color-saturation": "^0.0.16" | ||
"@uiw/color-convert": "^0.0.17", | ||
"@uiw/react-color-alpha": "^0.0.17", | ||
"@uiw/react-color-editable-input": "^0.0.17", | ||
"@uiw/react-color-editable-input-rgba": "^0.0.17", | ||
"@uiw/react-color-hue": "^0.0.17", | ||
"@uiw/react-color-saturation": "^0.0.17", | ||
"@uiw/react-color-swatch": "^0.0.17" | ||
}, | ||
@@ -41,0 +42,0 @@ "devDependencies": { |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
54723
10
7
634
+ Added@uiw/color-convert@0.0.17(transitive)
+ Added@uiw/react-color-alpha@0.0.17(transitive)
+ Added@uiw/react-color-editable-input@0.0.17(transitive)
+ Added@uiw/react-color-editable-input-rgba@0.0.17(transitive)
+ Added@uiw/react-color-hue@0.0.17(transitive)
+ Added@uiw/react-color-saturation@0.0.17(transitive)
+ Added@uiw/react-color-swatch@0.0.17(transitive)
+ Added@uiw/react-drag-event-interactive@0.0.17(transitive)
- Removed@uiw/color-convert@0.0.16(transitive)
- Removed@uiw/react-color-alpha@0.0.16(transitive)
- Removed@uiw/react-color-editable-input@0.0.16(transitive)
- Removed@uiw/react-color-editable-input-rgba@0.0.16(transitive)
- Removed@uiw/react-color-hue@0.0.16(transitive)
- Removed@uiw/react-color-saturation@0.0.16(transitive)
- Removed@uiw/react-drag-event-interactive@0.0.16(transitive)
Updated@uiw/color-convert@^0.0.17
Updated@uiw/react-color-hue@^0.0.17