Socket
Socket
Sign inDemoInstall

@uiw/react-color-sketch

Package Overview
Dependencies
Maintainers
1
Versions
78
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@uiw/react-color-sketch - npm Package Compare versions

Comparing version 0.0.24 to 0.0.25

4

lib/cjs/index.d.ts

@@ -12,3 +12,3 @@ import React from 'react';

}
declare const _default: React.ForwardRefExoticComponent<SketchProps & React.RefAttributes<HTMLDivElement>>;
export default _default;
declare const Sketch: React.ForwardRefExoticComponent<SketchProps & React.RefAttributes<HTMLDivElement>>;
export default Sketch;

@@ -56,3 +56,3 @@ "use strict";

var _default = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
var Sketch = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
var _props$prefixCls = props.prefixCls,

@@ -238,4 +238,6 @@ prefixCls = _props$prefixCls === void 0 ? 'w-color-sketch' : _props$prefixCls,

Sketch.displayName = 'Sketch';
var _default = Sketch;
exports.default = _default;
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","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"]}
//# 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","Sketch","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","displayName"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AASA;;;AAGA,IAAMA,aAAa,GAAG,CACpB,SADoB,EAEpB,SAFoB,EAGpB,SAHoB,EAIpB,SAJoB,EAKpB,SALoB,EAMpB,SANoB,EAOpB,SAPoB,EAQpB,SARoB,EASpB,SAToB,EAUpB,SAVoB,EAWpB,SAXoB,EAYpB,SAZoB,EAapB,SAboB,EAcpB,SAdoB,EAepB,SAfoB,CAAtB;;AA2BA,IAAMC,GAAG,GAAG,SAANA,GAAM,CAACC,KAAD;AAAA,sBACV;AACE,IAAA,KAAK,EAAE;AACLC,MAAAA,SAAS,EAAE,8BADN;AAELC,MAAAA,KAAK,EAAE,CAFF;AAGLC,MAAAA,GAAG,EAAE,CAHA;AAILC,MAAAA,MAAM,EAAE,CAJH;AAKLC,MAAAA,IAAI,EAAEL,KAAK,CAACK,IALP;AAMLC,MAAAA,YAAY,EAAE,CANT;AAOLC,MAAAA,QAAQ,EAAE,UAPL;AAQLC,MAAAA,eAAe,EAAE;AARZ;AADT,IADU;AAAA,CAAZ;;AAeA,IAAMC,MAAM,gBAAGC,eAAMC,UAAN,CAA8C,UAACX,KAAD,EAAQY,GAAR,EAAgB;AAC3E,yBAUIZ,KAVJ,CACEa,SADF;AAAA,MACEA,SADF,iCACc,gBADd;AAAA,MAEEC,SAFF,GAUId,KAVJ,CAEEc,SAFF;AAAA,MAGEC,QAHF,GAUIf,KAVJ,CAGEe,QAHF;AAAA,qBAUIf,KAVJ,CAIEE,KAJF;AAAA,MAIEA,KAJF,6BAIU,GAJV;AAAA,4BAUIF,KAVJ,CAKEgB,YALF;AAAA,MAKEA,YALF,oCAKiBlB,aALjB;AAAA,MAMEmB,KANF,GAUIjB,KAVJ,CAMEiB,KANF;AAAA,8BAUIjB,KAVJ,CAOEkB,eAPF;AAAA,MAOEA,eAPF,sCAOoB,IAPpB;AAAA,MAQEC,KARF,GAUInB,KAVJ,CAQEmB,KARF;AAAA,MASKC,KATL,0CAUIpB,KAVJ;;AAWA,kBAAwB,qBAAS;AAAEqB,IAAAA,CAAC,EAAE,GAAL;AAAUC,IAAAA,CAAC,EAAE,EAAb;AAAiBC,IAAAA,CAAC,EAAE,EAApB;AAAwBC,IAAAA,CAAC,EAAE;AAA3B,GAAT,CAAxB;AAAA;AAAA,MAAOC,IAAP;AAAA,MAAaC,OAAb;;AACA,wBAAU,YAAM;AACd,QAAI,OAAOT,KAAP,KAAiB,QAAjB,IAA6B,4BAASA,KAAT,CAAjC,EAAkD;AAChDS,MAAAA,OAAO,CAAC,6BAAUT,KAAV,CAAD,CAAP;AACD;;AACD,QAAI,sBAAOA,KAAP,MAAiB,QAArB,EAA+B;AAC7BS,MAAAA,OAAO,CAACT,KAAD,CAAP;AACD;AACF,GAPD,EAOG,CAACA,KAAD,CAPH;AASA,MAAMU,YAAY,GAAG,wBACnB,UAACC,GAAD,EAAoB;AAClBF,IAAAA,OAAO,CAACE,GAAD,CAAP;AACAb,IAAAA,QAAQ,IAAIA,QAAQ,CAAC,yBAAYa,GAAZ,CAAD,CAApB;AACD,GAJkB,EAKnB,CAACH,IAAD,CALmB,CAArB;;AAQA,MAAMI,SAAS,GAAG,SAAZA,SAAY,CAACC,KAAD,EAAyBC,GAAzB,EAAsE;AACtF,QAAI,OAAOD,KAAP,KAAiB,QAAjB,IAA6B,4BAASA,KAAT,CAA7B,IAAgD,QAAQE,IAAR,CAAaC,MAAM,CAACH,KAAK,CAACI,MAAP,CAAnB,CAApD,EAAwF;AACtFP,MAAAA,YAAY,CAAC,6BAAUG,KAAV,CAAD,CAAZ;AACD;AACF,GAJD;;AAKA,sBACE,+DACMV,KADN;AAEE,IAAA,SAAS,YAAKP,SAAL,cAAkBC,SAAS,IAAI,EAA/B,CAFX;AAGE,IAAA,GAAG,EAAEF,GAHP;AAIE,IAAA,KAAK;AACHuB,MAAAA,UAAU,EAAE,oBADT;AAEH7B,MAAAA,YAAY,EAAE,CAFX;AAGHL,MAAAA,SAAS,EAAE,iEAHR;AAIHC,MAAAA,KAAK,EAALA;AAJG,OAKAiB,KALA;AAJP,mBAYE;AAAK,IAAA,KAAK,EAAE;AAAEiB,MAAAA,OAAO,EAAE;AAAX;AAAZ,kBACE,6BAAC,6BAAD;AACE,IAAA,IAAI,EAAEX,IADR;AAEE,IAAA,KAAK,EAAE;AAAEvB,MAAAA,KAAK,EAAE,MAAT;AAAiBmC,MAAAA,MAAM,EAAE;AAAzB,KAFT;AAGE,IAAA,QAAQ,EAAE,kBAACC,QAAD;AAAA,aAAcX,YAAY,yFAAMF,IAAN,GAAea,QAAf;AAAyBd,QAAAA,CAAC,EAAEC,IAAI,CAACD;AAAjC,SAA1B;AAAA;AAHZ,IADF,eAME;AAAK,IAAA,KAAK,EAAE;AAAEe,MAAAA,OAAO,EAAE,MAAX;AAAmBC,MAAAA,SAAS,EAAE;AAA9B;AAAZ,kBACE;AAAK,IAAA,KAAK,EAAE;AAAEC,MAAAA,IAAI,EAAE;AAAR;AAAZ,kBACE,6BAAC,sBAAD;AACE,IAAA,KAAK,EAAC,MADR;AAEE,IAAA,MAAM,EAAE,EAFV;AAGE,IAAA,GAAG,EAAEhB,IAAI,CAACJ,CAHZ;AAIE,IAAA,OAAO,EAAEtB,GAJX;AAKE,IAAA,UAAU,EAAE;AACVoB,MAAAA,KAAK,EAAE;AAAEuB,QAAAA,UAAU,EAAE,CAAd;AAAiBC,QAAAA,WAAW,EAAE;AAA9B;AADG,KALd;AAQE,IAAA,QAAQ,EAAE,kBAACC,MAAD;AAAA,aAAYjB,YAAY,6DAAMF,IAAN,GAAemB,MAAf,EAAxB;AAAA;AARZ,IADF,eAWE,6BAAC,wBAAD;AACE,IAAA,KAAK,EAAC,MADR;AAEE,IAAA,MAAM,EAAE,EAFV;AAGE,IAAA,IAAI,EAAEnB,IAHR;AAIE,IAAA,OAAO,EAAE1B,GAJX;AAKE,IAAA,KAAK,EAAE;AAAEyC,MAAAA,SAAS,EAAE;AAAb,KALT;AAME,IAAA,UAAU,EAAE;AACVrB,MAAAA,KAAK,EAAE;AAAEuB,QAAAA,UAAU,EAAE,CAAd;AAAiBC,QAAAA,WAAW,EAAE;AAA9B;AADG,KANd;AASE,IAAA,QAAQ,EAAE,kBAACE,QAAD,EAAc;AACtBlB,MAAAA,YAAY,6DAAMF,IAAN,GAAe;AAAED,QAAAA,CAAC,EAAEqB,QAAQ,CAACrB;AAAd,OAAf,EAAZ;AACD;AAXH,IAXF,CADF,eA0BE,6BAAC,wBAAD;AACE,IAAA,KAAK,EAAE,EADT;AAEE,IAAA,MAAM,EAAE,EAFV;AAGE,IAAA,IAAI,EAAEC,IAHR;AAIE,IAAA,MAAM,EAAE,CAJV;AAKE,IAAA,KAAK,EAAE;AACLiB,MAAAA,UAAU,EAAE;AADP,KALT;AAQE,IAAA,OAAO,EAAE;AAAEvB,MAAAA,KAAK,EAAE;AAAEgB,QAAAA,UAAU,EAAE;AAAd;AAAT,KARX;AASE,IAAA,UAAU,EAAE;AACVhB,MAAAA,KAAK,EAAE;AACLb,QAAAA,YAAY,EAAE,CADT;AAEL6B,QAAAA,UAAU,EAAE,oCAAiBV,IAAjB,CAFP;AAGLxB,QAAAA,SAAS,EAAE;AAHN;AADG,KATd;AAgBE,IAAA,OAAO,EAAE;AAAA,0BAAM,6BAAC,eAAD,OAAN;AAAA;AAhBX,IA1BF,CANF,CAZF,EAgEGiB,eAAe,iBACd;AAAK,IAAA,KAAK,EAAE;AAAEqB,MAAAA,OAAO,EAAE,MAAX;AAAmBO,MAAAA,MAAM,EAAE;AAA3B;AAAZ,kBACE,6BAAC,gCAAD;AACE,IAAA,KAAK,EAAC,KADR;AAEE,IAAA,KAAK,EAAE,6BAAUrB,IAAV,EAAgBsB,OAAhB,CAAwB,IAAxB,EAA8B,EAA9B,EAAkCC,iBAAlC,EAFT;AAGE,IAAA,QAAQ,EAAE,kBAACjB,GAAD,EAAMkB,GAAN;AAAA,aAAcpB,SAAS,CAACoB,GAAD,EAAMlB,GAAN,CAAvB;AAAA,KAHZ;AAIE,IAAA,KAAK,EAAE;AAAEmB,MAAAA,QAAQ,EAAE;AAAZ;AAJT,IADF,eAOE,6BAAC,oCAAD;AAAM,IAAA,IAAI,EAAEzB,IAAZ;AAAkB,IAAA,KAAK,EAAE;AAAEiB,MAAAA,UAAU,EAAE;AAAd,KAAzB;AAA4C,IAAA,QAAQ,EAAE,kBAACS,MAAD;AAAA,aAAYxB,YAAY,CAACwB,MAAM,CAAC1B,IAAR,CAAxB;AAAA;AAAtD,IAPF,CAjEJ,EA2EGT,YAAY,IAAIA,YAAY,CAACkB,MAAb,GAAsB,CAAtC,iBACC,6BAAC,yBAAD;AACE,IAAA,KAAK,EAAE;AACLkB,MAAAA,SAAS,EAAE,8BADN;AAELC,MAAAA,UAAU,EAAE,EAFP;AAGLC,MAAAA,WAAW,EAAE;AAHR,KADT;AAME,IAAA,MAAM,EAAEtC,YANV;AAOE,IAAA,KAAK,EAAE,6BAAUS,IAAV,CAPT;AAQE,IAAA,QAAQ,EAAE,kBAAC8B,QAAD;AAAA,aAAc5B,YAAY,CAAC4B,QAAD,CAA1B;AAAA,KARZ;AASE,IAAA,SAAS,EAAE;AACTpC,MAAAA,KAAK,EAAE;AACLwB,QAAAA,WAAW,EAAE,EADR;AAELa,QAAAA,YAAY,EAAE,EAFT;AAGLlD,QAAAA,YAAY,EAAE,CAHT;AAILL,QAAAA,SAAS,EAAE,wCAJN,CAKL;AACA;AACA;;AAPK;AADE;AATb,IA5EJ,CADF;AAqGD,CAxIc,CAAf;;AA0IAQ,MAAM,CAACgD,WAAP,GAAqB,QAArB;eAEehD,M","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\nconst Sketch = 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\nSketch.displayName = 'Sketch';\n\nexport default Sketch;\n"]}

@@ -12,3 +12,3 @@ import React from 'react';

}
declare const _default: React.ForwardRefExoticComponent<SketchProps & React.RefAttributes<HTMLDivElement>>;
export default _default;
declare const Sketch: React.ForwardRefExoticComponent<SketchProps & React.RefAttributes<HTMLDivElement>>;
export default Sketch;

@@ -33,3 +33,3 @@ import _extends from "@babel/runtime/helpers/extends";

export default /*#__PURE__*/React.forwardRef(function (props, ref) {
var Sketch = /*#__PURE__*/React.forwardRef(function (props, ref) {
var _props$prefixCls = props.prefixCls,

@@ -214,2 +214,4 @@ prefixCls = _props$prefixCls === void 0 ? 'w-color-sketch' : _props$prefixCls,

});
//# 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"]}
Sketch.displayName = 'Sketch';
export default Sketch;
//# 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","Sketch","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","displayName"],"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\nconst Sketch = 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\nSketch.displayName = 'Sketch';\n\nexport default Sketch;\n"]}
{
"name": "@uiw/react-color-sketch",
"version": "0.0.24",
"version": "0.0.25",
"description": "Color Sketch component for React.",

@@ -33,9 +33,9 @@ "homepage": "https://uiwjs.github.io/react-color/#react-color-sketch",

"@babel/runtime": "7.14.6",
"@uiw/color-convert": "^0.0.24",
"@uiw/react-color-alpha": "^0.0.24",
"@uiw/react-color-editable-input": "^0.0.24",
"@uiw/react-color-editable-input-rgba": "^0.0.24",
"@uiw/react-color-hue": "^0.0.24",
"@uiw/react-color-saturation": "^0.0.24",
"@uiw/react-color-swatch": "^0.0.24"
"@uiw/color-convert": "^0.0.25",
"@uiw/react-color-alpha": "^0.0.25",
"@uiw/react-color-editable-input": "^0.0.25",
"@uiw/react-color-editable-input-rgba": "^0.0.25",
"@uiw/react-color-hue": "^0.0.25",
"@uiw/react-color-saturation": "^0.0.25",
"@uiw/react-color-swatch": "^0.0.25"
},

@@ -42,0 +42,0 @@ "devDependencies": {

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc