@uiw/react-color-compact
Advanced tools
Comparing version 0.0.14 to 0.0.15
@@ -24,2 +24,4 @@ "use strict"; | ||
var _reactColorEditableInputRgba = _interopRequireDefault(require("@uiw/react-color-editable-input-rgba")); | ||
var _excluded = ["style"], | ||
@@ -29,3 +31,3 @@ _excluded2 = ["prefixCls", "className", "style", "onChange", "color", "colors"]; | ||
var EditableInputRGB = function EditableInputRGB(_ref) { | ||
var EditableInputHex = function EditableInputHex(_ref) { | ||
var style = _ref.style, | ||
@@ -66,40 +68,9 @@ props = (0, _objectWithoutProperties2.default)(_ref, _excluded); | ||
var rgba = color ? (0, _colorConvert.hsvaToRgba)(hsva) : {}; | ||
var hex = color ? (0, _colorConvert.hsvaToHex)(hsva).replace(/^#/, '') : ''; | ||
var handleChangeCallback = (0, _react.useCallback)(function (hsv) { | ||
return onChange && onChange((0, _colorConvert.color)(hsv)); | ||
}, [hsva]); | ||
}, []); | ||
var handleChange = function handleChange(value, type, evn) { | ||
if (typeof value === 'number') { | ||
if (value > 255) { | ||
value = 255; | ||
evn.target.value = '255'; | ||
} | ||
if (value < 0) { | ||
value = 0; | ||
evn.target.value = '0'; | ||
} | ||
if (type === 'r') { | ||
handleChangeCallback((0, _colorConvert.rgbaToHsva)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, rgba), {}, { | ||
r: value | ||
}))); | ||
} | ||
if (type === 'g') { | ||
handleChangeCallback((0, _colorConvert.rgbaToHsva)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, rgba), {}, { | ||
g: value | ||
}))); | ||
} | ||
if (type === 'b') { | ||
handleChangeCallback((0, _colorConvert.rgbaToHsva)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, rgba), {}, { | ||
b: value | ||
}))); | ||
} | ||
} | ||
if (typeof value === 'string' && type === 'hex' && (0, _colorConvert.validHex)(value) && /(3|6)/.test(String(value.length))) { | ||
var handleHex = function handleHex(value, evn) { | ||
if (typeof value === 'string' && (0, _colorConvert.validHex)(value) && /(3|6)/.test(String(value.length))) { | ||
handleChangeCallback((0, _colorConvert.hexToHsva)(value)); | ||
@@ -109,14 +80,12 @@ } | ||
function handleBlur(evn) { | ||
var value = Number(evn.target.value); | ||
if (value && value > 255) { | ||
evn.target.value = '255'; | ||
var rgbProps = { | ||
style: { | ||
alignItems: 'baseline' | ||
}, | ||
inputStyle: { | ||
boxShadow: 'none', | ||
backgroundColor: 'transparent', | ||
outline: 0 | ||
} | ||
if (value && value < 0) { | ||
evn.target.value = '0'; | ||
} | ||
} | ||
}; | ||
return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({ | ||
@@ -171,3 +140,3 @@ ref: ref, | ||
} | ||
}, /*#__PURE__*/_react.default.createElement(EditableInputRGB, { | ||
}, /*#__PURE__*/_react.default.createElement(EditableInputHex, { | ||
style: { | ||
@@ -177,3 +146,3 @@ minWidth: 80 | ||
onChange: function onChange(evn, val) { | ||
return handleChange(val, 'hex', evn); | ||
return handleHex(val, evn); | ||
}, | ||
@@ -188,23 +157,12 @@ label: /*#__PURE__*/_react.default.createElement("div", { | ||
value: hex.toLocaleUpperCase() | ||
}), /*#__PURE__*/_react.default.createElement(EditableInputRGB, { | ||
label: "R", | ||
value: rgba.r || 0, | ||
onBlur: handleBlur, | ||
onChange: function onChange(evn, val) { | ||
return handleChange(val, 'r', evn); | ||
} | ||
}), /*#__PURE__*/_react.default.createElement(EditableInputRGB, { | ||
label: "G", | ||
value: rgba.g || 0, | ||
onBlur: handleBlur, | ||
onChange: function onChange(evn, val) { | ||
return handleChange(val, 'g', evn); | ||
} | ||
}), /*#__PURE__*/_react.default.createElement(EditableInputRGB, { | ||
label: "B", | ||
value: rgba.b || 0, | ||
onBlur: handleBlur, | ||
onChange: function onChange(evn, val) { | ||
return handleChange(val, 'b', evn); | ||
} | ||
}), /*#__PURE__*/_react.default.createElement(_reactColorEditableInputRgba.default, { | ||
hsva: hsva, | ||
placement: "left", | ||
onChange: function onChange(result) { | ||
return handleChangeCallback(result.hsva); | ||
}, | ||
aProps: false, | ||
rProps: rgbProps, | ||
gProps: rgbProps, | ||
bProps: rgbProps | ||
}))); | ||
@@ -215,2 +173,2 @@ }); | ||
module.exports = exports.default; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["COLORS","EditableInputRGB","style","props","paddingRight","marginTop","outline","boxShadow","background","flexDirection","flex","React","forwardRef","ref","prefixCls","className","onChange","color","colors","other","hsva","handleClick","hexStr","evn","rgba","hex","replace","handleChangeCallback","hsv","handleChange","value","type","target","r","g","b","test","String","length","handleBlur","Number","borderRadius","display","width","flexWrap","paddingTop","paddingLeft","filter","Boolean","join","map","idx","checked","toLocaleLowerCase","boxSizing","backgroundColor","height","marginRight","marginBottom","cursor","alignItems","justifyContent","margin","minWidth","val","toLocaleUpperCase"],"mappings":"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","sourcesContent":["import React, { useCallback } from 'react';\nimport {\n  ColorResult,\n  color as handleColor,\n  hexToHsva,\n  validHex,\n  HsvaColor,\n  hsvaToHex,\n  getContrastingColor,\n  hsvaToRgba,\n  RgbaColor,\n  rgbaToHsva,\n} from '@uiw/color-convert';\nimport EditableInput, { EditableInputProps } from '@uiw/react-color-editable-input';\n\nexport interface CompactProps<T> extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> {\n  prefixCls?: string;\n  color?: string | HsvaColor;\n  colors?: string[];\n  onChange?: (color: ColorResult, evn?: T) => void;\n}\n\nconst COLORS = [\n  '#4D4D4D',\n  '#999999',\n  '#FFFFFF',\n  '#F44E3B',\n  '#FE9200',\n  '#FCDC00',\n  '#DBDF00',\n  '#A4DD00',\n  '#68CCCA',\n  '#73D8FF',\n  '#AEA1FF',\n  '#FDA1FF',\n  '#333333',\n  '#808080',\n  '#cccccc',\n  '#D33115',\n  '#E27300',\n  '#FCC400',\n  '#B0BC00',\n  '#68BC00',\n  '#16A5A5',\n  '#009CE0',\n  '#7B64FF',\n  '#FA28FF',\n  '#000000',\n  '#666666',\n  '#B3B3B3',\n  '#9F0500',\n  '#C45100',\n  '#FB9E00',\n  '#808900',\n  '#194D33',\n  '#0C797D',\n  '#0062B1',\n  '#653294',\n  '#AB149E',\n];\n\nconst EditableInputRGB = ({ style, ...props }: EditableInputProps) => (\n  <EditableInput\n    labelStyle={{ paddingRight: 5, marginTop: -1 }}\n    inputStyle={{\n      outline: 'none',\n      boxShadow: 'initial',\n      background: 'transparent',\n    }}\n    style={{\n      flexDirection: 'row-reverse',\n      flex: '1 1 0%',\n      ...style,\n    }}\n    {...props}\n  />\n);\n\nexport default React.forwardRef<HTMLDivElement, CompactProps<React.MouseEvent<HTMLDivElement, MouseEvent>>>((props, ref) => {\n  const { prefixCls = 'w-color-compact', className, style, onChange, color, colors = COLORS, ...other } = props;\n  const hsva = (typeof color === 'string' && validHex(color) ? hexToHsva(color) : color) as HsvaColor;\n  const handleClick = (hexStr: string, evn: React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n    onChange && onChange(handleColor(hexToHsva(hexStr)), evn);\n  };\n  const rgba = (color ? hsvaToRgba(hsva) : {}) as RgbaColor;\n  const hex = color ? hsvaToHex(hsva).replace(/^#/, '') : '';\n  const handleChangeCallback = useCallback((hsv: HsvaColor) => onChange && onChange(handleColor(hsv)), [hsva]);\n  const handleChange = (value: string | number, type: 'hex' | 'r' | 'g' | 'b', evn: React.ChangeEvent<HTMLInputElement>) => {\n    if (typeof value === 'number') {\n      if (value > 255) {\n        value = 255;\n        evn.target.value = '255';\n      }\n      if (value < 0) {\n        value = 0;\n        evn.target.value = '0';\n      }\n      if (type === 'r') {\n        handleChangeCallback(rgbaToHsva({ ...rgba, r: value }));\n      }\n      if (type === 'g') {\n        handleChangeCallback(rgbaToHsva({ ...rgba, g: value }));\n      }\n      if (type === 'b') {\n        handleChangeCallback(rgbaToHsva({ ...rgba, b: value }));\n      }\n    }\n    if (typeof value === 'string' && type === 'hex' && validHex(value) && /(3|6)/.test(String(value.length))) {\n      handleChangeCallback(hexToHsva(value));\n    }\n  };\n  function handleBlur(evn: React.FocusEvent<HTMLInputElement>) {\n    const value = Number(evn.target.value);\n    if (value && value > 255) {\n      evn.target.value = '255';\n    }\n    if (value && value < 0) {\n      evn.target.value = '0';\n    }\n  }\n  return (\n    <div\n      ref={ref}\n      style={{\n        background: '#f6f6f6',\n        borderRadius: 3,\n        display: 'flex',\n        width: 240,\n        flexWrap: 'wrap',\n        paddingTop: 5,\n        paddingLeft: 5,\n        ...style,\n      }}\n      className={[prefixCls, className || ''].filter(Boolean).join(' ')}\n      {...other}\n    >\n      {colors.map((hex, idx) => {\n        const checked = hsva && hsvaToHex(hsva).toLocaleLowerCase() === hex.toLocaleLowerCase();\n        return (\n          <div\n            key={hex}\n            style={{\n              boxSizing: 'border-box',\n            }}\n          >\n            <div\n              onClick={(evn) => handleClick(hex, evn)}\n              title={hex}\n              style={{\n                backgroundColor: hex,\n                height: 15,\n                width: 15,\n                marginRight: 5,\n                marginBottom: 5,\n                cursor: 'pointer',\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center',\n                borderRadius: 2,\n              }}\n            >\n              {checked && (\n                <div\n                  style={{\n                    height: 5,\n                    width: 5,\n                    borderRadius: '50%',\n                    backgroundColor: getContrastingColor(hex),\n                  }}\n                />\n              )}\n            </div>\n          </div>\n        );\n      })}\n      <div style={{ display: 'flex', margin: '0 4px 3px 0' }}>\n        <EditableInputRGB\n          style={{ minWidth: 80 }}\n          onChange={(evn, val) => handleChange(val, 'hex', evn)}\n          label={<div style={{ width: 8, height: 8, backgroundColor: `#${hex}` }} />}\n          value={hex.toLocaleUpperCase()}\n        />\n        <EditableInputRGB\n          label=\"R\"\n          value={rgba.r || 0}\n          onBlur={handleBlur}\n          onChange={(evn, val) => handleChange(val, 'r', evn)}\n        />\n        <EditableInputRGB\n          label=\"G\"\n          value={rgba.g || 0}\n          onBlur={handleBlur}\n          onChange={(evn, val) => handleChange(val, 'g', evn)}\n        />\n        <EditableInputRGB\n          label=\"B\"\n          value={rgba.b || 0}\n          onBlur={handleBlur}\n          onChange={(evn, val) => handleChange(val, 'b', evn)}\n        />\n      </div>\n    </div>\n  );\n});\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["COLORS","EditableInputHex","style","props","paddingRight","marginTop","outline","boxShadow","background","flexDirection","flex","React","forwardRef","ref","prefixCls","className","onChange","color","colors","other","hsva","handleClick","hexStr","evn","hex","replace","handleChangeCallback","hsv","handleHex","value","test","String","length","rgbProps","alignItems","inputStyle","backgroundColor","borderRadius","display","width","flexWrap","paddingTop","paddingLeft","filter","Boolean","join","map","idx","checked","toLocaleLowerCase","boxSizing","height","marginRight","marginBottom","cursor","justifyContent","margin","minWidth","val","toLocaleUpperCase","result"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;AACA;;AASA;;AACA;;;;AASA,IAAMA,MAAM,GAAG,CACb,SADa,EAEb,SAFa,EAGb,SAHa,EAIb,SAJa,EAKb,SALa,EAMb,SANa,EAOb,SAPa,EAQb,SARa,EASb,SATa,EAUb,SAVa,EAWb,SAXa,EAYb,SAZa,EAab,SAba,EAcb,SAda,EAeb,SAfa,EAgBb,SAhBa,EAiBb,SAjBa,EAkBb,SAlBa,EAmBb,SAnBa,EAoBb,SApBa,EAqBb,SArBa,EAsBb,SAtBa,EAuBb,SAvBa,EAwBb,SAxBa,EAyBb,SAzBa,EA0Bb,SA1Ba,EA2Bb,SA3Ba,EA4Bb,SA5Ba,EA6Bb,SA7Ba,EA8Bb,SA9Ba,EA+Bb,SA/Ba,EAgCb,SAhCa,EAiCb,SAjCa,EAkCb,SAlCa,EAmCb,SAnCa,EAoCb,SApCa,CAAf;;AAuCA,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB;AAAA,MAAGC,KAAH,QAAGA,KAAH;AAAA,MAAaC,KAAb;AAAA,sBACvB,6BAAC,gCAAD;AACE,IAAA,UAAU,EAAE;AAAEC,MAAAA,YAAY,EAAE,CAAhB;AAAmBC,MAAAA,SAAS,EAAE,CAAC;AAA/B,KADd;AAEE,IAAA,UAAU,EAAE;AACVC,MAAAA,OAAO,EAAE,MADC;AAEVC,MAAAA,SAAS,EAAE,SAFD;AAGVC,MAAAA,UAAU,EAAE;AAHF,KAFd;AAOE,IAAA,KAAK;AACHC,MAAAA,aAAa,EAAE,aADZ;AAEHC,MAAAA,IAAI,EAAE;AAFH,OAGAR,KAHA;AAPP,KAYMC,KAZN,EADuB;AAAA,CAAzB;;4BAiBeQ,eAAMC,UAAN,CAA6F,UAACT,KAAD,EAAQU,GAAR,EAAgB;AAC1H,yBAAwGV,KAAxG,CAAQW,SAAR;AAAA,MAAQA,SAAR,iCAAoB,iBAApB;AAAA,MAAuCC,SAAvC,GAAwGZ,KAAxG,CAAuCY,SAAvC;AAAA,MAAkDb,KAAlD,GAAwGC,KAAxG,CAAkDD,KAAlD;AAAA,MAAyDc,QAAzD,GAAwGb,KAAxG,CAAyDa,QAAzD;AAAA,MAAmEC,KAAnE,GAAwGd,KAAxG,CAAmEc,KAAnE;AAAA,sBAAwGd,KAAxG,CAA0Ee,MAA1E;AAAA,MAA0EA,MAA1E,8BAAmFlB,MAAnF;AAAA,MAA8FmB,KAA9F,0CAAwGhB,KAAxG;AACA,MAAMiB,IAAI,GAAI,OAAOH,KAAP,KAAiB,QAAjB,IAA6B,4BAASA,KAAT,CAA7B,GAA+C,6BAAUA,KAAV,CAA/C,GAAkEA,KAAhF;;AACA,MAAMI,WAAW,GAAG,SAAdA,WAAc,CAACC,MAAD,EAAiBC,GAAjB,EAAuE;AACzFP,IAAAA,QAAQ,IAAIA,QAAQ,CAAC,yBAAY,6BAAUM,MAAV,CAAZ,CAAD,EAAiCC,GAAjC,CAApB;AACD,GAFD;;AAGA,MAAMC,GAAG,GAAGP,KAAK,GAAG,6BAAUG,IAAV,EAAgBK,OAAhB,CAAwB,IAAxB,EAA8B,EAA9B,CAAH,GAAuC,EAAxD;AACA,MAAMC,oBAAoB,GAAG,wBAAY,UAACC,GAAD;AAAA,WAAoBX,QAAQ,IAAIA,QAAQ,CAAC,yBAAYW,GAAZ,CAAD,CAAxC;AAAA,GAAZ,EAAwE,EAAxE,CAA7B;;AACA,MAAMC,SAAS,GAAG,SAAZA,SAAY,CAACC,KAAD,EAAyBN,GAAzB,EAAsE;AACtF,QAAI,OAAOM,KAAP,KAAiB,QAAjB,IAA6B,4BAASA,KAAT,CAA7B,IAAgD,QAAQC,IAAR,CAAaC,MAAM,CAACF,KAAK,CAACG,MAAP,CAAnB,CAApD,EAAwF;AACtFN,MAAAA,oBAAoB,CAAC,6BAAUG,KAAV,CAAD,CAApB;AACD;AACF,GAJD;;AAKA,MAAMI,QAAQ,GAAG;AACf/B,IAAAA,KAAK,EAAE;AACLgC,MAAAA,UAAU,EAAE;AADP,KADQ;AAIfC,IAAAA,UAAU,EAAE;AAAE5B,MAAAA,SAAS,EAAE,MAAb;AAAqB6B,MAAAA,eAAe,EAAE,aAAtC;AAAqD9B,MAAAA,OAAO,EAAE;AAA9D;AAJG,GAAjB;AAMA,sBACE;AACE,IAAA,GAAG,EAAEO,GADP;AAEE,IAAA,KAAK;AACHL,MAAAA,UAAU,EAAE,SADT;AAEH6B,MAAAA,YAAY,EAAE,CAFX;AAGHC,MAAAA,OAAO,EAAE,MAHN;AAIHC,MAAAA,KAAK,EAAE,GAJJ;AAKHC,MAAAA,QAAQ,EAAE,MALP;AAMHC,MAAAA,UAAU,EAAE,CANT;AAOHC,MAAAA,WAAW,EAAE;AAPV,OAQAxC,KARA,CAFP;AAYE,IAAA,SAAS,EAAE,CAACY,SAAD,EAAYC,SAAS,IAAI,EAAzB,EAA6B4B,MAA7B,CAAoCC,OAApC,EAA6CC,IAA7C,CAAkD,GAAlD;AAZb,KAaM1B,KAbN,GAeGD,MAAM,CAAC4B,GAAP,CAAW,UAACtB,GAAD,EAAMuB,GAAN,EAAc;AACxB,QAAMC,OAAO,GAAG5B,IAAI,IAAI,6BAAUA,IAAV,EAAgB6B,iBAAhB,OAAwCzB,GAAG,CAACyB,iBAAJ,EAAhE;AACA,wBACE;AACE,MAAA,GAAG,EAAEzB,GADP;AAEE,MAAA,KAAK,EAAE;AACL0B,QAAAA,SAAS,EAAE;AADN;AAFT,oBAME;AACE,MAAA,OAAO,EAAE,iBAAC3B,GAAD;AAAA,eAASF,WAAW,CAACG,GAAD,EAAMD,GAAN,CAApB;AAAA,OADX;AAEE,MAAA,KAAK,EAAEC,GAFT;AAGE,MAAA,KAAK,EAAE;AACLY,QAAAA,eAAe,EAAEZ,GADZ;AAEL2B,QAAAA,MAAM,EAAE,EAFH;AAGLZ,QAAAA,KAAK,EAAE,EAHF;AAILa,QAAAA,WAAW,EAAE,CAJR;AAKLC,QAAAA,YAAY,EAAE,CALT;AAMLC,QAAAA,MAAM,EAAE,SANH;AAOLhB,QAAAA,OAAO,EAAE,MAPJ;AAQLJ,QAAAA,UAAU,EAAE,QARP;AASLqB,QAAAA,cAAc,EAAE,QATX;AAULlB,QAAAA,YAAY,EAAE;AAVT;AAHT,OAgBGW,OAAO,iBACN;AACE,MAAA,KAAK,EAAE;AACLG,QAAAA,MAAM,EAAE,CADH;AAELZ,QAAAA,KAAK,EAAE,CAFF;AAGLF,QAAAA,YAAY,EAAE,KAHT;AAILD,QAAAA,eAAe,EAAE,uCAAoBZ,GAApB;AAJZ;AADT,MAjBJ,CANF,CADF;AAoCD,GAtCA,CAfH,eAsDE;AAAK,IAAA,KAAK,EAAE;AAAEc,MAAAA,OAAO,EAAE,MAAX;AAAmBkB,MAAAA,MAAM,EAAE;AAA3B;AAAZ,kBACE,6BAAC,gBAAD;AACE,IAAA,KAAK,EAAE;AAAEC,MAAAA,QAAQ,EAAE;AAAZ,KADT;AAEE,IAAA,QAAQ,EAAE,kBAAClC,GAAD,EAAMmC,GAAN;AAAA,aAAc9B,SAAS,CAAC8B,GAAD,EAAMnC,GAAN,CAAvB;AAAA,KAFZ;AAGE,IAAA,KAAK,eAAE;AAAK,MAAA,KAAK,EAAE;AAAEgB,QAAAA,KAAK,EAAE,CAAT;AAAYY,QAAAA,MAAM,EAAE,CAApB;AAAuBf,QAAAA,eAAe,aAAMZ,GAAN;AAAtC;AAAZ,MAHT;AAIE,IAAA,KAAK,EAAEA,GAAG,CAACmC,iBAAJ;AAJT,IADF,eAOE,6BAAC,oCAAD;AACE,IAAA,IAAI,EAAEvC,IADR;AAEE,IAAA,SAAS,EAAC,MAFZ;AAGE,IAAA,QAAQ,EAAE,kBAACwC,MAAD;AAAA,aAAYlC,oBAAoB,CAACkC,MAAM,CAACxC,IAAR,CAAhC;AAAA,KAHZ;AAIE,IAAA,MAAM,EAAE,KAJV;AAKE,IAAA,MAAM,EAAEa,QALV;AAME,IAAA,MAAM,EAAEA,QANV;AAOE,IAAA,MAAM,EAAEA;AAPV,IAPF,CAtDF,CADF;AA0ED,CA7Fc,C","sourcesContent":["import React, { useCallback } from 'react';\nimport {\n  ColorResult,\n  color as handleColor,\n  hexToHsva,\n  validHex,\n  HsvaColor,\n  hsvaToHex,\n  getContrastingColor,\n} from '@uiw/color-convert';\nimport EditableInput, { EditableInputProps } from '@uiw/react-color-editable-input';\nimport RGBA from '@uiw/react-color-editable-input-rgba';\n\nexport interface CompactProps<T> extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> {\n  prefixCls?: string;\n  color?: string | HsvaColor;\n  colors?: string[];\n  onChange?: (color: ColorResult, evn?: T) => void;\n}\n\nconst COLORS = [\n  '#4D4D4D',\n  '#999999',\n  '#FFFFFF',\n  '#F44E3B',\n  '#FE9200',\n  '#FCDC00',\n  '#DBDF00',\n  '#A4DD00',\n  '#68CCCA',\n  '#73D8FF',\n  '#AEA1FF',\n  '#FDA1FF',\n  '#333333',\n  '#808080',\n  '#cccccc',\n  '#D33115',\n  '#E27300',\n  '#FCC400',\n  '#B0BC00',\n  '#68BC00',\n  '#16A5A5',\n  '#009CE0',\n  '#7B64FF',\n  '#FA28FF',\n  '#000000',\n  '#666666',\n  '#B3B3B3',\n  '#9F0500',\n  '#C45100',\n  '#FB9E00',\n  '#808900',\n  '#194D33',\n  '#0C797D',\n  '#0062B1',\n  '#653294',\n  '#AB149E',\n];\n\nconst EditableInputHex = ({ style, ...props }: EditableInputProps) => (\n  <EditableInput\n    labelStyle={{ paddingRight: 5, marginTop: -1 }}\n    inputStyle={{\n      outline: 'none',\n      boxShadow: 'initial',\n      background: 'transparent',\n    }}\n    style={{\n      flexDirection: 'row-reverse',\n      flex: '1 1 0%',\n      ...style,\n    }}\n    {...props}\n  />\n);\n\nexport default React.forwardRef<HTMLDivElement, CompactProps<React.MouseEvent<HTMLDivElement, MouseEvent>>>((props, ref) => {\n  const { prefixCls = 'w-color-compact', className, style, onChange, color, colors = COLORS, ...other } = props;\n  const hsva = (typeof color === 'string' && validHex(color) ? hexToHsva(color) : color) as HsvaColor;\n  const handleClick = (hexStr: string, evn: React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n    onChange && onChange(handleColor(hexToHsva(hexStr)), evn);\n  };\n  const hex = color ? hsvaToHex(hsva).replace(/^#/, '') : '';\n  const handleChangeCallback = useCallback((hsv: HsvaColor) => onChange && onChange(handleColor(hsv)), []);\n  const handleHex = (value: string | number, evn: React.ChangeEvent<HTMLInputElement>) => {\n    if (typeof value === 'string' && validHex(value) && /(3|6)/.test(String(value.length))) {\n      handleChangeCallback(hexToHsva(value));\n    }\n  };\n  const rgbProps = {\n    style: {\n      alignItems: 'baseline',\n    },\n    inputStyle: { boxShadow: 'none', backgroundColor: 'transparent', outline: 0 },\n  };\n  return (\n    <div\n      ref={ref}\n      style={{\n        background: '#f6f6f6',\n        borderRadius: 3,\n        display: 'flex',\n        width: 240,\n        flexWrap: 'wrap',\n        paddingTop: 5,\n        paddingLeft: 5,\n        ...style,\n      }}\n      className={[prefixCls, className || ''].filter(Boolean).join(' ')}\n      {...other}\n    >\n      {colors.map((hex, idx) => {\n        const checked = hsva && hsvaToHex(hsva).toLocaleLowerCase() === hex.toLocaleLowerCase();\n        return (\n          <div\n            key={hex}\n            style={{\n              boxSizing: 'border-box',\n            }}\n          >\n            <div\n              onClick={(evn) => handleClick(hex, evn)}\n              title={hex}\n              style={{\n                backgroundColor: hex,\n                height: 15,\n                width: 15,\n                marginRight: 5,\n                marginBottom: 5,\n                cursor: 'pointer',\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center',\n                borderRadius: 2,\n              }}\n            >\n              {checked && (\n                <div\n                  style={{\n                    height: 5,\n                    width: 5,\n                    borderRadius: '50%',\n                    backgroundColor: getContrastingColor(hex),\n                  }}\n                />\n              )}\n            </div>\n          </div>\n        );\n      })}\n      <div style={{ display: 'flex', margin: '0 4px 3px 0' }}>\n        <EditableInputHex\n          style={{ minWidth: 80 }}\n          onChange={(evn, val) => handleHex(val, evn)}\n          label={<div style={{ width: 8, height: 8, backgroundColor: `#${hex}` }} />}\n          value={hex.toLocaleUpperCase()}\n        />\n        <RGBA\n          hsva={hsva}\n          placement=\"left\"\n          onChange={(result) => handleChangeCallback(result.hsva)}\n          aProps={false}\n          rProps={rgbProps}\n          gProps={rgbProps}\n          bProps={rgbProps}\n        />\n      </div>\n    </div>\n  );\n});\n"]} |
@@ -7,7 +7,8 @@ import _extends from "@babel/runtime/helpers/extends"; | ||
import React, { useCallback } from 'react'; | ||
import { color as handleColor, hexToHsva, validHex, hsvaToHex, getContrastingColor, hsvaToRgba, rgbaToHsva } from '@uiw/color-convert'; | ||
import { color as handleColor, hexToHsva, validHex, hsvaToHex, getContrastingColor } from '@uiw/color-convert'; | ||
import EditableInput from '@uiw/react-color-editable-input'; | ||
import RGBA from '@uiw/react-color-editable-input-rgba'; | ||
var COLORS = ['#4D4D4D', '#999999', '#FFFFFF', '#F44E3B', '#FE9200', '#FCDC00', '#DBDF00', '#A4DD00', '#68CCCA', '#73D8FF', '#AEA1FF', '#FDA1FF', '#333333', '#808080', '#cccccc', '#D33115', '#E27300', '#FCC400', '#B0BC00', '#68BC00', '#16A5A5', '#009CE0', '#7B64FF', '#FA28FF', '#000000', '#666666', '#B3B3B3', '#9F0500', '#C45100', '#FB9E00', '#808900', '#194D33', '#0C797D', '#0062B1', '#653294', '#AB149E']; | ||
var EditableInputRGB = function EditableInputRGB(_ref) { | ||
var EditableInputHex = function EditableInputHex(_ref) { | ||
var style = _ref.style, | ||
@@ -50,40 +51,9 @@ props = _objectWithoutProperties(_ref, _excluded); | ||
var rgba = color ? hsvaToRgba(hsva) : {}; | ||
var hex = color ? hsvaToHex(hsva).replace(/^#/, '') : ''; | ||
var handleChangeCallback = useCallback(function (hsv) { | ||
return onChange && onChange(handleColor(hsv)); | ||
}, [hsva]); | ||
}, []); | ||
var handleChange = function handleChange(value, type, evn) { | ||
if (typeof value === 'number') { | ||
if (value > 255) { | ||
value = 255; | ||
evn.target.value = '255'; | ||
} | ||
if (value < 0) { | ||
value = 0; | ||
evn.target.value = '0'; | ||
} | ||
if (type === 'r') { | ||
handleChangeCallback(rgbaToHsva(_objectSpread(_objectSpread({}, rgba), {}, { | ||
r: value | ||
}))); | ||
} | ||
if (type === 'g') { | ||
handleChangeCallback(rgbaToHsva(_objectSpread(_objectSpread({}, rgba), {}, { | ||
g: value | ||
}))); | ||
} | ||
if (type === 'b') { | ||
handleChangeCallback(rgbaToHsva(_objectSpread(_objectSpread({}, rgba), {}, { | ||
b: value | ||
}))); | ||
} | ||
} | ||
if (typeof value === 'string' && type === 'hex' && validHex(value) && /(3|6)/.test(String(value.length))) { | ||
var handleHex = function handleHex(value, evn) { | ||
if (typeof value === 'string' && validHex(value) && /(3|6)/.test(String(value.length))) { | ||
handleChangeCallback(hexToHsva(value)); | ||
@@ -93,14 +63,12 @@ } | ||
function handleBlur(evn) { | ||
var value = Number(evn.target.value); | ||
if (value && value > 255) { | ||
evn.target.value = '255'; | ||
var rgbProps = { | ||
style: { | ||
alignItems: 'baseline' | ||
}, | ||
inputStyle: { | ||
boxShadow: 'none', | ||
backgroundColor: 'transparent', | ||
outline: 0 | ||
} | ||
if (value && value < 0) { | ||
evn.target.value = '0'; | ||
} | ||
} | ||
}; | ||
return /*#__PURE__*/React.createElement("div", _extends({ | ||
@@ -155,3 +123,3 @@ ref: ref, | ||
} | ||
}, /*#__PURE__*/React.createElement(EditableInputRGB, { | ||
}, /*#__PURE__*/React.createElement(EditableInputHex, { | ||
style: { | ||
@@ -161,3 +129,3 @@ minWidth: 80 | ||
onChange: function onChange(evn, val) { | ||
return handleChange(val, 'hex', evn); | ||
return handleHex(val, evn); | ||
}, | ||
@@ -172,25 +140,14 @@ label: /*#__PURE__*/React.createElement("div", { | ||
value: hex.toLocaleUpperCase() | ||
}), /*#__PURE__*/React.createElement(EditableInputRGB, { | ||
label: "R", | ||
value: rgba.r || 0, | ||
onBlur: handleBlur, | ||
onChange: function onChange(evn, val) { | ||
return handleChange(val, 'r', evn); | ||
} | ||
}), /*#__PURE__*/React.createElement(EditableInputRGB, { | ||
label: "G", | ||
value: rgba.g || 0, | ||
onBlur: handleBlur, | ||
onChange: function onChange(evn, val) { | ||
return handleChange(val, 'g', evn); | ||
} | ||
}), /*#__PURE__*/React.createElement(EditableInputRGB, { | ||
label: "B", | ||
value: rgba.b || 0, | ||
onBlur: handleBlur, | ||
onChange: function onChange(evn, val) { | ||
return handleChange(val, 'b', evn); | ||
} | ||
}), /*#__PURE__*/React.createElement(RGBA, { | ||
hsva: hsva, | ||
placement: "left", | ||
onChange: function onChange(result) { | ||
return handleChangeCallback(result.hsva); | ||
}, | ||
aProps: false, | ||
rProps: rgbProps, | ||
gProps: rgbProps, | ||
bProps: rgbProps | ||
}))); | ||
}); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","useCallback","color","handleColor","hexToHsva","validHex","hsvaToHex","getContrastingColor","hsvaToRgba","rgbaToHsva","EditableInput","COLORS","EditableInputRGB","style","props","paddingRight","marginTop","outline","boxShadow","background","flexDirection","flex","forwardRef","ref","prefixCls","className","onChange","colors","other","hsva","handleClick","hexStr","evn","rgba","hex","replace","handleChangeCallback","hsv","handleChange","value","type","target","r","g","b","test","String","length","handleBlur","Number","borderRadius","display","width","flexWrap","paddingTop","paddingLeft","filter","Boolean","join","map","idx","checked","toLocaleLowerCase","boxSizing","backgroundColor","height","marginRight","marginBottom","cursor","alignItems","justifyContent","margin","minWidth","val","toLocaleUpperCase"],"mappings":"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","sourcesContent":["import React, { useCallback } from 'react';\nimport {\n  ColorResult,\n  color as handleColor,\n  hexToHsva,\n  validHex,\n  HsvaColor,\n  hsvaToHex,\n  getContrastingColor,\n  hsvaToRgba,\n  RgbaColor,\n  rgbaToHsva,\n} from '@uiw/color-convert';\nimport EditableInput, { EditableInputProps } from '@uiw/react-color-editable-input';\n\nexport interface CompactProps<T> extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> {\n  prefixCls?: string;\n  color?: string | HsvaColor;\n  colors?: string[];\n  onChange?: (color: ColorResult, evn?: T) => void;\n}\n\nconst COLORS = [\n  '#4D4D4D',\n  '#999999',\n  '#FFFFFF',\n  '#F44E3B',\n  '#FE9200',\n  '#FCDC00',\n  '#DBDF00',\n  '#A4DD00',\n  '#68CCCA',\n  '#73D8FF',\n  '#AEA1FF',\n  '#FDA1FF',\n  '#333333',\n  '#808080',\n  '#cccccc',\n  '#D33115',\n  '#E27300',\n  '#FCC400',\n  '#B0BC00',\n  '#68BC00',\n  '#16A5A5',\n  '#009CE0',\n  '#7B64FF',\n  '#FA28FF',\n  '#000000',\n  '#666666',\n  '#B3B3B3',\n  '#9F0500',\n  '#C45100',\n  '#FB9E00',\n  '#808900',\n  '#194D33',\n  '#0C797D',\n  '#0062B1',\n  '#653294',\n  '#AB149E',\n];\n\nconst EditableInputRGB = ({ style, ...props }: EditableInputProps) => (\n  <EditableInput\n    labelStyle={{ paddingRight: 5, marginTop: -1 }}\n    inputStyle={{\n      outline: 'none',\n      boxShadow: 'initial',\n      background: 'transparent',\n    }}\n    style={{\n      flexDirection: 'row-reverse',\n      flex: '1 1 0%',\n      ...style,\n    }}\n    {...props}\n  />\n);\n\nexport default React.forwardRef<HTMLDivElement, CompactProps<React.MouseEvent<HTMLDivElement, MouseEvent>>>((props, ref) => {\n  const { prefixCls = 'w-color-compact', className, style, onChange, color, colors = COLORS, ...other } = props;\n  const hsva = (typeof color === 'string' && validHex(color) ? hexToHsva(color) : color) as HsvaColor;\n  const handleClick = (hexStr: string, evn: React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n    onChange && onChange(handleColor(hexToHsva(hexStr)), evn);\n  };\n  const rgba = (color ? hsvaToRgba(hsva) : {}) as RgbaColor;\n  const hex = color ? hsvaToHex(hsva).replace(/^#/, '') : '';\n  const handleChangeCallback = useCallback((hsv: HsvaColor) => onChange && onChange(handleColor(hsv)), [hsva]);\n  const handleChange = (value: string | number, type: 'hex' | 'r' | 'g' | 'b', evn: React.ChangeEvent<HTMLInputElement>) => {\n    if (typeof value === 'number') {\n      if (value > 255) {\n        value = 255;\n        evn.target.value = '255';\n      }\n      if (value < 0) {\n        value = 0;\n        evn.target.value = '0';\n      }\n      if (type === 'r') {\n        handleChangeCallback(rgbaToHsva({ ...rgba, r: value }));\n      }\n      if (type === 'g') {\n        handleChangeCallback(rgbaToHsva({ ...rgba, g: value }));\n      }\n      if (type === 'b') {\n        handleChangeCallback(rgbaToHsva({ ...rgba, b: value }));\n      }\n    }\n    if (typeof value === 'string' && type === 'hex' && validHex(value) && /(3|6)/.test(String(value.length))) {\n      handleChangeCallback(hexToHsva(value));\n    }\n  };\n  function handleBlur(evn: React.FocusEvent<HTMLInputElement>) {\n    const value = Number(evn.target.value);\n    if (value && value > 255) {\n      evn.target.value = '255';\n    }\n    if (value && value < 0) {\n      evn.target.value = '0';\n    }\n  }\n  return (\n    <div\n      ref={ref}\n      style={{\n        background: '#f6f6f6',\n        borderRadius: 3,\n        display: 'flex',\n        width: 240,\n        flexWrap: 'wrap',\n        paddingTop: 5,\n        paddingLeft: 5,\n        ...style,\n      }}\n      className={[prefixCls, className || ''].filter(Boolean).join(' ')}\n      {...other}\n    >\n      {colors.map((hex, idx) => {\n        const checked = hsva && hsvaToHex(hsva).toLocaleLowerCase() === hex.toLocaleLowerCase();\n        return (\n          <div\n            key={hex}\n            style={{\n              boxSizing: 'border-box',\n            }}\n          >\n            <div\n              onClick={(evn) => handleClick(hex, evn)}\n              title={hex}\n              style={{\n                backgroundColor: hex,\n                height: 15,\n                width: 15,\n                marginRight: 5,\n                marginBottom: 5,\n                cursor: 'pointer',\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center',\n                borderRadius: 2,\n              }}\n            >\n              {checked && (\n                <div\n                  style={{\n                    height: 5,\n                    width: 5,\n                    borderRadius: '50%',\n                    backgroundColor: getContrastingColor(hex),\n                  }}\n                />\n              )}\n            </div>\n          </div>\n        );\n      })}\n      <div style={{ display: 'flex', margin: '0 4px 3px 0' }}>\n        <EditableInputRGB\n          style={{ minWidth: 80 }}\n          onChange={(evn, val) => handleChange(val, 'hex', evn)}\n          label={<div style={{ width: 8, height: 8, backgroundColor: `#${hex}` }} />}\n          value={hex.toLocaleUpperCase()}\n        />\n        <EditableInputRGB\n          label=\"R\"\n          value={rgba.r || 0}\n          onBlur={handleBlur}\n          onChange={(evn, val) => handleChange(val, 'r', evn)}\n        />\n        <EditableInputRGB\n          label=\"G\"\n          value={rgba.g || 0}\n          onBlur={handleBlur}\n          onChange={(evn, val) => handleChange(val, 'g', evn)}\n        />\n        <EditableInputRGB\n          label=\"B\"\n          value={rgba.b || 0}\n          onBlur={handleBlur}\n          onChange={(evn, val) => handleChange(val, 'b', evn)}\n        />\n      </div>\n    </div>\n  );\n});\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","useCallback","color","handleColor","hexToHsva","validHex","hsvaToHex","getContrastingColor","EditableInput","RGBA","COLORS","EditableInputHex","style","props","paddingRight","marginTop","outline","boxShadow","background","flexDirection","flex","forwardRef","ref","prefixCls","className","onChange","colors","other","hsva","handleClick","hexStr","evn","hex","replace","handleChangeCallback","hsv","handleHex","value","test","String","length","rgbProps","alignItems","inputStyle","backgroundColor","borderRadius","display","width","flexWrap","paddingTop","paddingLeft","filter","Boolean","join","map","idx","checked","toLocaleLowerCase","boxSizing","height","marginRight","marginBottom","cursor","justifyContent","margin","minWidth","val","toLocaleUpperCase","result"],"mappings":"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","sourcesContent":["import React, { useCallback } from 'react';\nimport {\n  ColorResult,\n  color as handleColor,\n  hexToHsva,\n  validHex,\n  HsvaColor,\n  hsvaToHex,\n  getContrastingColor,\n} from '@uiw/color-convert';\nimport EditableInput, { EditableInputProps } from '@uiw/react-color-editable-input';\nimport RGBA from '@uiw/react-color-editable-input-rgba';\n\nexport interface CompactProps<T> extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'color'> {\n  prefixCls?: string;\n  color?: string | HsvaColor;\n  colors?: string[];\n  onChange?: (color: ColorResult, evn?: T) => void;\n}\n\nconst COLORS = [\n  '#4D4D4D',\n  '#999999',\n  '#FFFFFF',\n  '#F44E3B',\n  '#FE9200',\n  '#FCDC00',\n  '#DBDF00',\n  '#A4DD00',\n  '#68CCCA',\n  '#73D8FF',\n  '#AEA1FF',\n  '#FDA1FF',\n  '#333333',\n  '#808080',\n  '#cccccc',\n  '#D33115',\n  '#E27300',\n  '#FCC400',\n  '#B0BC00',\n  '#68BC00',\n  '#16A5A5',\n  '#009CE0',\n  '#7B64FF',\n  '#FA28FF',\n  '#000000',\n  '#666666',\n  '#B3B3B3',\n  '#9F0500',\n  '#C45100',\n  '#FB9E00',\n  '#808900',\n  '#194D33',\n  '#0C797D',\n  '#0062B1',\n  '#653294',\n  '#AB149E',\n];\n\nconst EditableInputHex = ({ style, ...props }: EditableInputProps) => (\n  <EditableInput\n    labelStyle={{ paddingRight: 5, marginTop: -1 }}\n    inputStyle={{\n      outline: 'none',\n      boxShadow: 'initial',\n      background: 'transparent',\n    }}\n    style={{\n      flexDirection: 'row-reverse',\n      flex: '1 1 0%',\n      ...style,\n    }}\n    {...props}\n  />\n);\n\nexport default React.forwardRef<HTMLDivElement, CompactProps<React.MouseEvent<HTMLDivElement, MouseEvent>>>((props, ref) => {\n  const { prefixCls = 'w-color-compact', className, style, onChange, color, colors = COLORS, ...other } = props;\n  const hsva = (typeof color === 'string' && validHex(color) ? hexToHsva(color) : color) as HsvaColor;\n  const handleClick = (hexStr: string, evn: React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n    onChange && onChange(handleColor(hexToHsva(hexStr)), evn);\n  };\n  const hex = color ? hsvaToHex(hsva).replace(/^#/, '') : '';\n  const handleChangeCallback = useCallback((hsv: HsvaColor) => onChange && onChange(handleColor(hsv)), []);\n  const handleHex = (value: string | number, evn: React.ChangeEvent<HTMLInputElement>) => {\n    if (typeof value === 'string' && validHex(value) && /(3|6)/.test(String(value.length))) {\n      handleChangeCallback(hexToHsva(value));\n    }\n  };\n  const rgbProps = {\n    style: {\n      alignItems: 'baseline',\n    },\n    inputStyle: { boxShadow: 'none', backgroundColor: 'transparent', outline: 0 },\n  };\n  return (\n    <div\n      ref={ref}\n      style={{\n        background: '#f6f6f6',\n        borderRadius: 3,\n        display: 'flex',\n        width: 240,\n        flexWrap: 'wrap',\n        paddingTop: 5,\n        paddingLeft: 5,\n        ...style,\n      }}\n      className={[prefixCls, className || ''].filter(Boolean).join(' ')}\n      {...other}\n    >\n      {colors.map((hex, idx) => {\n        const checked = hsva && hsvaToHex(hsva).toLocaleLowerCase() === hex.toLocaleLowerCase();\n        return (\n          <div\n            key={hex}\n            style={{\n              boxSizing: 'border-box',\n            }}\n          >\n            <div\n              onClick={(evn) => handleClick(hex, evn)}\n              title={hex}\n              style={{\n                backgroundColor: hex,\n                height: 15,\n                width: 15,\n                marginRight: 5,\n                marginBottom: 5,\n                cursor: 'pointer',\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center',\n                borderRadius: 2,\n              }}\n            >\n              {checked && (\n                <div\n                  style={{\n                    height: 5,\n                    width: 5,\n                    borderRadius: '50%',\n                    backgroundColor: getContrastingColor(hex),\n                  }}\n                />\n              )}\n            </div>\n          </div>\n        );\n      })}\n      <div style={{ display: 'flex', margin: '0 4px 3px 0' }}>\n        <EditableInputHex\n          style={{ minWidth: 80 }}\n          onChange={(evn, val) => handleHex(val, evn)}\n          label={<div style={{ width: 8, height: 8, backgroundColor: `#${hex}` }} />}\n          value={hex.toLocaleUpperCase()}\n        />\n        <RGBA\n          hsva={hsva}\n          placement=\"left\"\n          onChange={(result) => handleChangeCallback(result.hsva)}\n          aProps={false}\n          rProps={rgbProps}\n          gProps={rgbProps}\n          bProps={rgbProps}\n        />\n      </div>\n    </div>\n  );\n});\n"]} |
{ | ||
"name": "@uiw/react-color-compact", | ||
"version": "0.0.14", | ||
"version": "0.0.15", | ||
"description": "Color Compact component for React.", | ||
@@ -33,9 +33,10 @@ "homepage": "https://uiwjs.github.io/react-color/#react-color-compact", | ||
"@babel/runtime": "7.14.6", | ||
"@uiw/color-convert": "^0.0.14", | ||
"@uiw/react-color-alpha": "^0.0.14", | ||
"@uiw/react-color-editable-input": "^0.0.14" | ||
"@uiw/color-convert": "^0.0.15", | ||
"@uiw/react-color-alpha": "^0.0.15", | ||
"@uiw/react-color-editable-input": "^0.0.15", | ||
"@uiw/react-color-editable-input-rgba": "^0.0.15" | ||
}, | ||
"devDependencies": { | ||
"@types/react": "17.0.13", | ||
"@types/react-dom": "17.0.8", | ||
"@types/react": "17.0.14", | ||
"@types/react-dom": "17.0.9", | ||
"@types/react-test-renderer": "17.0.1", | ||
@@ -42,0 +43,0 @@ "react": "17.0.2", |
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
44977
7
473
+ Added@uiw/color-convert@0.0.15(transitive)
+ Added@uiw/react-color-alpha@0.0.15(transitive)
+ Added@uiw/react-color-editable-input@0.0.15(transitive)
+ Added@uiw/react-color-editable-input-rgba@0.0.15(transitive)
+ Added@uiw/react-drag-event-interactive@0.0.15(transitive)
- Removed@uiw/color-convert@0.0.14(transitive)
- Removed@uiw/react-color-alpha@0.0.14(transitive)
- Removed@uiw/react-color-editable-input@0.0.14(transitive)
- Removed@uiw/react-drag-event-interactive@0.0.14(transitive)
Updated@uiw/color-convert@^0.0.15