Socket
Socket
Sign inDemoInstall

@uiw/react-color-compact

Package Overview
Dependencies
Maintainers
1
Versions
73
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

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

Comparing version 0.0.11 to 0.0.12

4

lib/cjs/index.js

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

}),
value: hex
value: hex.toLocaleUpperCase()
}), /*#__PURE__*/_react.default.createElement(EditableInputRGB, {

@@ -209,2 +209,2 @@ label: "R",

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"],"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}\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","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"]}

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

}),
value: hex
value: hex.toLocaleUpperCase()
}), /*#__PURE__*/React.createElement(EditableInputRGB, {

@@ -191,2 +191,2 @@ label: "R",

});
//# 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"],"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}\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","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"]}
{
"name": "@uiw/react-color-compact",
"version": "0.0.11",
"version": "0.0.12",
"description": "Color Compact component for React.",

@@ -32,5 +32,5 @@ "author": "Kenny Wong <wowohoo@qq.com>",

"@babel/runtime": "7.14.6",
"@uiw/color-convert": "^0.0.11",
"@uiw/react-color-alpha": "^0.0.11",
"@uiw/react-color-editable-input": "^0.0.11"
"@uiw/color-convert": "^0.0.12",
"@uiw/react-color-alpha": "^0.0.12",
"@uiw/react-color-editable-input": "^0.0.12"
},

@@ -37,0 +37,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