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.16 to 0.0.17

103

lib/cjs/index.js

@@ -26,25 +26,18 @@ "use strict";

var _excluded = ["style"],
_excluded2 = ["prefixCls", "className", "style", "onChange", "color", "colors"];
var _reactColorSwatch = _interopRequireDefault(require("@uiw/react-color-swatch"));
var _excluded = ["prefixCls", "className", "style", "onChange", "color", "colors"];
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 EditableInputHex = function EditableInputHex(_ref) {
var style = _ref.style,
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
return /*#__PURE__*/_react.default.createElement(_reactColorEditableInput.default, (0, _extends2.default)({
labelStyle: {
paddingRight: 5,
marginTop: -1
},
inputStyle: {
outline: 'none',
boxShadow: 'initial',
background: 'transparent'
},
style: (0, _objectSpread2.default)({
flexDirection: 'row-reverse',
flex: '1 1 0%'
}, style)
}, props));
};
function Point(props) {
if (!props.checked) return null;
return /*#__PURE__*/_react.default.createElement("div", {
style: {
height: 5,
width: 5,
borderRadius: '50%',
backgroundColor: (0, _colorConvert.getContrastingColor)(props.color)
}
});
}

@@ -60,9 +53,4 @@ var _default = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {

colors = _props$colors === void 0 ? COLORS : _props$colors,
other = (0, _objectWithoutProperties2.default)(props, _excluded2);
other = (0, _objectWithoutProperties2.default)(props, _excluded);
var hsva = typeof color === 'string' && (0, _colorConvert.validHex)(color) ? (0, _colorConvert.hexToHsva)(color) : color;
var handleClick = function handleClick(hexStr, evn) {
onChange && onChange((0, _colorConvert.color)((0, _colorConvert.hexToHsva)(hexStr)), evn);
};
var hex = color ? (0, _colorConvert.hsvaToHex)(hsva).replace(/^#/, '') : '';

@@ -101,34 +89,16 @@ var handleChangeCallback = (0, _react.useCallback)(function (hsv) {

className: [prefixCls, className || ''].filter(Boolean).join(' ')
}, other), colors.map(function (hex, idx) {
var checked = hsva && (0, _colorConvert.hsvaToHex)(hsva).toLocaleLowerCase() === hex.toLocaleLowerCase();
return /*#__PURE__*/_react.default.createElement("div", {
key: hex,
}, other), /*#__PURE__*/_react.default.createElement(_reactColorSwatch.default, {
colors: colors,
color: color ? (0, _colorConvert.hsvaToHex)(hsva) : undefined,
rectProps: {
children: /*#__PURE__*/_react.default.createElement(Point, null),
style: {
boxSizing: 'border-box'
}
}, /*#__PURE__*/_react.default.createElement("div", {
onClick: function onClick(evn) {
return handleClick(hex, evn);
},
title: hex,
style: {
backgroundColor: hex,
height: 15,
width: 15,
marginRight: 5,
marginBottom: 5,
cursor: 'pointer',
display: 'flex',
alignItems: 'center',
justifyContent: 'center',
borderRadius: 2
justifyContent: 'center'
}
}, checked && /*#__PURE__*/_react.default.createElement("div", {
style: {
height: 5,
width: 5,
borderRadius: '50%',
backgroundColor: (0, _colorConvert.getContrastingColor)(hex)
}
})));
},
onChange: function onChange(hsvColor) {
return handleChangeCallback(hsvColor);
}
}), /*#__PURE__*/_react.default.createElement("div", {

@@ -139,9 +109,11 @@ style: {

}
}, /*#__PURE__*/_react.default.createElement(EditableInputHex, {
style: {
minWidth: 80
},
}, /*#__PURE__*/_react.default.createElement(_reactColorEditableInput.default, {
onChange: function onChange(evn, val) {
return handleHex(val, evn);
},
labelStyle: {
paddingRight: 5,
marginTop: -1
},
value: hex.toLocaleUpperCase(),
label: /*#__PURE__*/_react.default.createElement("div", {

@@ -154,3 +126,12 @@ style: {

}),
value: hex.toLocaleUpperCase()
inputStyle: {
outline: 'none',
boxShadow: 'initial',
background: 'transparent'
},
style: {
flexDirection: 'row-reverse',
flex: '1 1 0%',
minWidth: 80
}
}), /*#__PURE__*/_react.default.createElement(_reactColorEditableInputRgba.default, {

@@ -171,2 +152,2 @@ hsva: hsva,

module.exports = exports.default;
//# 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":"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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"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["COLORS","Point","props","checked","height","width","borderRadius","backgroundColor","color","React","forwardRef","ref","prefixCls","className","style","onChange","colors","other","hsva","hex","replace","handleChangeCallback","hsv","handleHex","value","evn","test","String","length","rgbProps","alignItems","inputStyle","boxShadow","outline","background","display","flexWrap","paddingTop","paddingLeft","filter","Boolean","join","undefined","children","justifyContent","hsvColor","margin","val","paddingRight","marginTop","toLocaleUpperCase","flexDirection","flex","minWidth","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 from '@uiw/react-color-editable-input';\nimport RGBA from '@uiw/react-color-editable-input-rgba';\nimport Swatch from '@uiw/react-color-swatch';\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\nfunction Point(props: { color?: string; checked?: boolean }) {\n  if (!props.checked) return null;\n  return (\n    <div\n      style={{\n        height: 5,\n        width: 5,\n        borderRadius: '50%',\n        backgroundColor: getContrastingColor(props.color!),\n      }}\n    />\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 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      <Swatch\n        colors={colors}\n        color={color ? hsvaToHex(hsva) : undefined}\n        rectProps={{\n          children: <Point />,\n          style: {\n            display: 'flex',\n            alignItems: 'center',\n            justifyContent: 'center',\n          },\n        }}\n        onChange={(hsvColor) => handleChangeCallback(hsvColor)}\n      />\n      <div style={{ display: 'flex', margin: '0 4px 3px 0' }}>\n        <EditableInput\n          onChange={(evn, val) => handleHex(val, evn)}\n          labelStyle={{ paddingRight: 5, marginTop: -1 }}\n          value={hex.toLocaleUpperCase()}\n          label={<div style={{ width: 8, height: 8, backgroundColor: `#${hex}` }} />}\n          inputStyle={{\n            outline: 'none',\n            boxShadow: 'initial',\n            background: 'transparent',\n          }}\n          style={{\n            flexDirection: 'row-reverse',\n            flex: '1 1 0%',\n            minWidth: 80,\n          }}\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"]}
import _extends from "@babel/runtime/helpers/extends";
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
var _excluded = ["style"],
_excluded2 = ["prefixCls", "className", "style", "onChange", "color", "colors"];
var _excluded = ["prefixCls", "className", "style", "onChange", "color", "colors"];
import React, { useCallback } from 'react';

@@ -10,25 +9,17 @@ import { color as handleColor, hexToHsva, validHex, hsvaToHex, getContrastingColor } from '@uiw/color-convert';

import RGBA from '@uiw/react-color-editable-input-rgba';
import Swatch from '@uiw/react-color-swatch';
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 EditableInputHex = function EditableInputHex(_ref) {
var style = _ref.style,
props = _objectWithoutProperties(_ref, _excluded);
function Point(props) {
if (!props.checked) return null;
return /*#__PURE__*/React.createElement("div", {
style: {
height: 5,
width: 5,
borderRadius: '50%',
backgroundColor: getContrastingColor(props.color)
}
});
}
return /*#__PURE__*/React.createElement(EditableInput, _extends({
labelStyle: {
paddingRight: 5,
marginTop: -1
},
inputStyle: {
outline: 'none',
boxShadow: 'initial',
background: 'transparent'
},
style: _objectSpread({
flexDirection: 'row-reverse',
flex: '1 1 0%'
}, style)
}, props));
};
export default /*#__PURE__*/React.forwardRef(function (props, ref) {

@@ -43,10 +34,5 @@ var _props$prefixCls = props.prefixCls,

colors = _props$colors === void 0 ? COLORS : _props$colors,
other = _objectWithoutProperties(props, _excluded2);
other = _objectWithoutProperties(props, _excluded);
var hsva = typeof color === 'string' && validHex(color) ? hexToHsva(color) : color;
var handleClick = function handleClick(hexStr, evn) {
onChange && onChange(handleColor(hexToHsva(hexStr)), evn);
};
var hex = color ? hsvaToHex(hsva).replace(/^#/, '') : '';

@@ -85,34 +71,16 @@ var handleChangeCallback = useCallback(function (hsv) {

className: [prefixCls, className || ''].filter(Boolean).join(' ')
}, other), colors.map(function (hex, idx) {
var checked = hsva && hsvaToHex(hsva).toLocaleLowerCase() === hex.toLocaleLowerCase();
return /*#__PURE__*/React.createElement("div", {
key: hex,
}, other), /*#__PURE__*/React.createElement(Swatch, {
colors: colors,
color: color ? hsvaToHex(hsva) : undefined,
rectProps: {
children: /*#__PURE__*/React.createElement(Point, null),
style: {
boxSizing: 'border-box'
}
}, /*#__PURE__*/React.createElement("div", {
onClick: function onClick(evn) {
return handleClick(hex, evn);
},
title: hex,
style: {
backgroundColor: hex,
height: 15,
width: 15,
marginRight: 5,
marginBottom: 5,
cursor: 'pointer',
display: 'flex',
alignItems: 'center',
justifyContent: 'center',
borderRadius: 2
justifyContent: 'center'
}
}, checked && /*#__PURE__*/React.createElement("div", {
style: {
height: 5,
width: 5,
borderRadius: '50%',
backgroundColor: getContrastingColor(hex)
}
})));
},
onChange: function onChange(hsvColor) {
return handleChangeCallback(hsvColor);
}
}), /*#__PURE__*/React.createElement("div", {

@@ -123,9 +91,11 @@ style: {

}
}, /*#__PURE__*/React.createElement(EditableInputHex, {
style: {
minWidth: 80
},
}, /*#__PURE__*/React.createElement(EditableInput, {
onChange: function onChange(evn, val) {
return handleHex(val, evn);
},
labelStyle: {
paddingRight: 5,
marginTop: -1
},
value: hex.toLocaleUpperCase(),
label: /*#__PURE__*/React.createElement("div", {

@@ -138,3 +108,12 @@ style: {

}),
value: hex.toLocaleUpperCase()
inputStyle: {
outline: 'none',
boxShadow: 'initial',
background: 'transparent'
},
style: {
flexDirection: 'row-reverse',
flex: '1 1 0%',
minWidth: 80
}
}), /*#__PURE__*/React.createElement(RGBA, {

@@ -152,2 +131,2 @@ hsva: hsva,

});
//# 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"]}
//# 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","Swatch","COLORS","Point","props","checked","height","width","borderRadius","backgroundColor","forwardRef","ref","prefixCls","className","style","onChange","colors","other","hsva","hex","replace","handleChangeCallback","hsv","handleHex","value","evn","test","String","length","rgbProps","alignItems","inputStyle","boxShadow","outline","background","display","flexWrap","paddingTop","paddingLeft","filter","Boolean","join","undefined","children","justifyContent","hsvColor","margin","val","paddingRight","marginTop","toLocaleUpperCase","flexDirection","flex","minWidth","result"],"mappings":";;;;AAAA,OAAOA,KAAP,IAAgBC,WAAhB,QAAmC,OAAnC;AACA,SAEEC,KAAK,IAAIC,WAFX,EAGEC,SAHF,EAIEC,QAJF,EAMEC,SANF,EAOEC,mBAPF,QAQO,oBARP;AASA,OAAOC,aAAP,MAA0B,iCAA1B;AACA,OAAOC,IAAP,MAAiB,sCAAjB;AACA,OAAOC,MAAP,MAAmB,yBAAnB;AASA,IAAMC,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,SAASC,KAAT,CAAeC,KAAf,EAA6D;AAC3D,MAAI,CAACA,KAAK,CAACC,OAAX,EAAoB,OAAO,IAAP;AACpB,sBACE;AACE,IAAA,KAAK,EAAE;AACLC,MAAAA,MAAM,EAAE,CADH;AAELC,MAAAA,KAAK,EAAE,CAFF;AAGLC,MAAAA,YAAY,EAAE,KAHT;AAILC,MAAAA,eAAe,EAAEX,mBAAmB,CAACM,KAAK,CAACX,KAAP;AAJ/B;AADT,IADF;AAUD;;AAED,4BAAeF,KAAK,CAACmB,UAAN,CAA6F,UAACN,KAAD,EAAQO,GAAR,EAAgB;AAC1H,yBAAwGP,KAAxG,CAAQQ,SAAR;AAAA,MAAQA,SAAR,iCAAoB,iBAApB;AAAA,MAAuCC,SAAvC,GAAwGT,KAAxG,CAAuCS,SAAvC;AAAA,MAAkDC,KAAlD,GAAwGV,KAAxG,CAAkDU,KAAlD;AAAA,MAAyDC,QAAzD,GAAwGX,KAAxG,CAAyDW,QAAzD;AAAA,MAAmEtB,KAAnE,GAAwGW,KAAxG,CAAmEX,KAAnE;AAAA,sBAAwGW,KAAxG,CAA0EY,MAA1E;AAAA,MAA0EA,MAA1E,8BAAmFd,MAAnF;AAAA,MAA8Fe,KAA9F,4BAAwGb,KAAxG;;AACA,MAAMc,IAAI,GAAI,OAAOzB,KAAP,KAAiB,QAAjB,IAA6BG,QAAQ,CAACH,KAAD,CAArC,GAA+CE,SAAS,CAACF,KAAD,CAAxD,GAAkEA,KAAhF;AACA,MAAM0B,GAAG,GAAG1B,KAAK,GAAGI,SAAS,CAACqB,IAAD,CAAT,CAAgBE,OAAhB,CAAwB,IAAxB,EAA8B,EAA9B,CAAH,GAAuC,EAAxD;AACA,MAAMC,oBAAoB,GAAG7B,WAAW,CAAC,UAAC8B,GAAD;AAAA,WAAoBP,QAAQ,IAAIA,QAAQ,CAACrB,WAAW,CAAC4B,GAAD,CAAZ,CAAxC;AAAA,GAAD,EAA6D,EAA7D,CAAxC;;AACA,MAAMC,SAAS,GAAG,SAAZA,SAAY,CAACC,KAAD,EAAyBC,GAAzB,EAAsE;AACtF,QAAI,OAAOD,KAAP,KAAiB,QAAjB,IAA6B5B,QAAQ,CAAC4B,KAAD,CAArC,IAAgD,QAAQE,IAAR,CAAaC,MAAM,CAACH,KAAK,CAACI,MAAP,CAAnB,CAApD,EAAwF;AACtFP,MAAAA,oBAAoB,CAAC1B,SAAS,CAAC6B,KAAD,CAAV,CAApB;AACD;AACF,GAJD;;AAKA,MAAMK,QAAQ,GAAG;AACff,IAAAA,KAAK,EAAE;AACLgB,MAAAA,UAAU,EAAE;AADP,KADQ;AAIfC,IAAAA,UAAU,EAAE;AAAEC,MAAAA,SAAS,EAAE,MAAb;AAAqBvB,MAAAA,eAAe,EAAE,aAAtC;AAAqDwB,MAAAA,OAAO,EAAE;AAA9D;AAJG,GAAjB;AAMA,sBACE;AACE,IAAA,GAAG,EAAEtB,GADP;AAEE,IAAA,KAAK;AACHuB,MAAAA,UAAU,EAAE,SADT;AAEH1B,MAAAA,YAAY,EAAE,CAFX;AAGH2B,MAAAA,OAAO,EAAE,MAHN;AAIH5B,MAAAA,KAAK,EAAE,GAJJ;AAKH6B,MAAAA,QAAQ,EAAE,MALP;AAMHC,MAAAA,UAAU,EAAE,CANT;AAOHC,MAAAA,WAAW,EAAE;AAPV,OAQAxB,KARA,CAFP;AAYE,IAAA,SAAS,EAAE,CAACF,SAAD,EAAYC,SAAS,IAAI,EAAzB,EAA6B0B,MAA7B,CAAoCC,OAApC,EAA6CC,IAA7C,CAAkD,GAAlD;AAZb,KAaMxB,KAbN,gBAeE,oBAAC,MAAD;AACE,IAAA,MAAM,EAAED,MADV;AAEE,IAAA,KAAK,EAAEvB,KAAK,GAAGI,SAAS,CAACqB,IAAD,CAAZ,GAAqBwB,SAFnC;AAGE,IAAA,SAAS,EAAE;AACTC,MAAAA,QAAQ,eAAE,oBAAC,KAAD,OADD;AAET7B,MAAAA,KAAK,EAAE;AACLqB,QAAAA,OAAO,EAAE,MADJ;AAELL,QAAAA,UAAU,EAAE,QAFP;AAGLc,QAAAA,cAAc,EAAE;AAHX;AAFE,KAHb;AAWE,IAAA,QAAQ,EAAE,kBAACC,QAAD;AAAA,aAAcxB,oBAAoB,CAACwB,QAAD,CAAlC;AAAA;AAXZ,IAfF,eA4BE;AAAK,IAAA,KAAK,EAAE;AAAEV,MAAAA,OAAO,EAAE,MAAX;AAAmBW,MAAAA,MAAM,EAAE;AAA3B;AAAZ,kBACE,oBAAC,aAAD;AACE,IAAA,QAAQ,EAAE,kBAACrB,GAAD,EAAMsB,GAAN;AAAA,aAAcxB,SAAS,CAACwB,GAAD,EAAMtB,GAAN,CAAvB;AAAA,KADZ;AAEE,IAAA,UAAU,EAAE;AAAEuB,MAAAA,YAAY,EAAE,CAAhB;AAAmBC,MAAAA,SAAS,EAAE,CAAC;AAA/B,KAFd;AAGE,IAAA,KAAK,EAAE9B,GAAG,CAAC+B,iBAAJ,EAHT;AAIE,IAAA,KAAK,eAAE;AAAK,MAAA,KAAK,EAAE;AAAE3C,QAAAA,KAAK,EAAE,CAAT;AAAYD,QAAAA,MAAM,EAAE,CAApB;AAAuBG,QAAAA,eAAe,aAAMU,GAAN;AAAtC;AAAZ,MAJT;AAKE,IAAA,UAAU,EAAE;AACVc,MAAAA,OAAO,EAAE,MADC;AAEVD,MAAAA,SAAS,EAAE,SAFD;AAGVE,MAAAA,UAAU,EAAE;AAHF,KALd;AAUE,IAAA,KAAK,EAAE;AACLiB,MAAAA,aAAa,EAAE,aADV;AAELC,MAAAA,IAAI,EAAE,QAFD;AAGLC,MAAAA,QAAQ,EAAE;AAHL;AAVT,IADF,eAiBE,oBAAC,IAAD;AACE,IAAA,IAAI,EAAEnC,IADR;AAEE,IAAA,SAAS,EAAC,MAFZ;AAGE,IAAA,QAAQ,EAAE,kBAACoC,MAAD;AAAA,aAAYjC,oBAAoB,CAACiC,MAAM,CAACpC,IAAR,CAAhC;AAAA,KAHZ;AAIE,IAAA,MAAM,EAAE,KAJV;AAKE,IAAA,MAAM,EAAEW,QALV;AAME,IAAA,MAAM,EAAEA,QANV;AAOE,IAAA,MAAM,EAAEA;AAPV,IAjBF,CA5BF,CADF;AA0DD,CA1Ec,CAAf","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 from '@uiw/react-color-editable-input';\nimport RGBA from '@uiw/react-color-editable-input-rgba';\nimport Swatch from '@uiw/react-color-swatch';\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\nfunction Point(props: { color?: string; checked?: boolean }) {\n  if (!props.checked) return null;\n  return (\n    <div\n      style={{\n        height: 5,\n        width: 5,\n        borderRadius: '50%',\n        backgroundColor: getContrastingColor(props.color!),\n      }}\n    />\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 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      <Swatch\n        colors={colors}\n        color={color ? hsvaToHex(hsva) : undefined}\n        rectProps={{\n          children: <Point />,\n          style: {\n            display: 'flex',\n            alignItems: 'center',\n            justifyContent: 'center',\n          },\n        }}\n        onChange={(hsvColor) => handleChangeCallback(hsvColor)}\n      />\n      <div style={{ display: 'flex', margin: '0 4px 3px 0' }}>\n        <EditableInput\n          onChange={(evn, val) => handleHex(val, evn)}\n          labelStyle={{ paddingRight: 5, marginTop: -1 }}\n          value={hex.toLocaleUpperCase()}\n          label={<div style={{ width: 8, height: 8, backgroundColor: `#${hex}` }} />}\n          inputStyle={{\n            outline: 'none',\n            boxShadow: 'initial',\n            background: 'transparent',\n          }}\n          style={{\n            flexDirection: 'row-reverse',\n            flex: '1 1 0%',\n            minWidth: 80,\n          }}\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.16",
"version": "0.0.17",
"description": "Color Compact component for React.",

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

"@babel/runtime": "7.14.6",
"@uiw/color-convert": "^0.0.16",
"@uiw/react-color-alpha": "^0.0.16",
"@uiw/react-color-editable-input": "^0.0.16",
"@uiw/react-color-editable-input-rgba": "^0.0.16"
"@uiw/color-convert": "^0.0.17",
"@uiw/react-color-editable-input": "^0.0.17",
"@uiw/react-color-editable-input-rgba": "^0.0.17",
"@uiw/react-color-swatch": "^0.0.17"
},

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