td-stylekit 26.1.3 → 26.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,24 @@
1
+ # [26.2.0](https://github.com/treasure-data/td-stylekit/compare/v26.1.5...v26.2.0) (2022-04-11)
2
+
3
+
4
+ ### Features
5
+
6
+ * **CON-9533:** Add ColorPicker component ([#1259](https://github.com/treasure-data/td-stylekit/issues/1259)) ([cee81d5](https://github.com/treasure-data/td-stylekit/commit/cee81d5))
7
+
8
+ ## [26.1.5](https://github.com/treasure-data/td-stylekit/compare/v26.1.4...v26.1.5) (2022-04-08)
9
+
10
+
11
+ ### Bug Fixes
12
+
13
+ * Fix date filtering ([#1262](https://github.com/treasure-data/td-stylekit/issues/1262)) ([46e9ce5](https://github.com/treasure-data/td-stylekit/commit/46e9ce5))
14
+
15
+ ## [26.1.4](https://github.com/treasure-data/td-stylekit/compare/v26.1.3...v26.1.4) (2022-04-06)
16
+
17
+
18
+ ### Bug Fixes
19
+
20
+ * **CON-9496:** Address issues in StyleKit ([#1260](https://github.com/treasure-data/td-stylekit/issues/1260)) ([5f1c4a0](https://github.com/treasure-data/td-stylekit/commit/5f1c4a0))
21
+
1
22
  ## [26.1.3](https://github.com/treasure-data/td-stylekit/compare/v26.1.2...v26.1.3) (2022-04-06)
2
23
 
3
24
 
@@ -0,0 +1,9 @@
1
+ declare type ColorPickerProps = {
2
+ ['data-instrumentation']: string;
3
+ onChange: (hex: string) => void;
4
+ value: string;
5
+ label: string;
6
+ };
7
+ export default function ColorPicker(props: ColorPickerProps): import("@emotion/react/jsx-runtime").JSX.Element;
8
+ export {};
9
+ //# sourceMappingURL=ColorPicker.d.ts.map
@@ -0,0 +1,331 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = ColorPicker;
9
+
10
+ var _base = _interopRequireDefault(require("@emotion/styled/base"));
11
+
12
+ var _react = require("react");
13
+
14
+ var _reactColorful = require("react-colorful");
15
+
16
+ var _lodash = _interopRequireDefault(require("lodash.debounce"));
17
+
18
+ var _Input = _interopRequireDefault(require("../Input"));
19
+
20
+ var _FormLabel = _interopRequireDefault(require("../FormLabel"));
21
+
22
+ var _Button = _interopRequireDefault(require("../Button"));
23
+
24
+ var _Grid = _interopRequireWildcard(require("../Grid"));
25
+
26
+ var _utils = require("./utils");
27
+
28
+ var _hooks = require("./hooks");
29
+
30
+ var _jsxRuntime = require("@emotion/react/jsx-runtime");
31
+
32
+ function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
33
+
34
+ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
35
+
36
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
37
+
38
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
39
+
40
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
41
+
42
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
43
+
44
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
45
+
46
+ function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
47
+
48
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
49
+
50
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
51
+
52
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
53
+
54
+ if (typeof window !== "undefined" && !window.gs) window.gs = function () {};
55
+ if (typeof window !== "undefined" && !window.gsC) window.gsC = function () {};
56
+ // Values from UX
57
+ var PICKER_WIDTH = 196;
58
+ var SATURATION_HEIGHT = 129;
59
+ var PickerWrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
60
+ target: "eu4c7ix5"
61
+ } : {
62
+ target: "eu4c7ix5",
63
+ label: "PickerWrapper"
64
+ })(function (_ref) {
65
+ var _ref2;
66
+
67
+ var theme = _ref.theme;
68
+ return _ref2 = {
69
+ background: theme.palette.neutral[0],
70
+ borderColor: theme.palette.neutral[4],
71
+ borderRadius: theme.radius[2],
72
+ borderStyle: 'solid',
73
+ borderWidth: theme.borderWidth[1],
74
+ paddingBottom: theme.space[5],
75
+ position: 'absolute',
76
+ right: -(PICKER_WIDTH + 9),
77
+ top: 0,
78
+ width: PICKER_WIDTH,
79
+ '& .react-colorful': {
80
+ height: 'auto',
81
+ width: '100%'
82
+ },
83
+ '& .react-colorful__saturation': {
84
+ border: 'none',
85
+ borderTopLeftRadius: theme.radius[2],
86
+ borderTopRightRadius: theme.radius[2],
87
+ height: SATURATION_HEIGHT
88
+ }
89
+ }, _defineProperty(_ref2, "& .react-colorful__hue,\n & .react-colorful__alpha", {
90
+ borderRadius: theme.space[3],
91
+ // Same as height
92
+ height: theme.space[3],
93
+ marginLeft: theme.space[4],
94
+ marginRight: theme.space[4]
95
+ }), _defineProperty(_ref2, '& .react-colorful__hue', {
96
+ marginBottom: theme.space[3],
97
+ marginTop: theme.space[4]
98
+ }), _defineProperty(_ref2, '& .react-colorful__alpha', {
99
+ marginBottom: theme.space[4]
100
+ }), _defineProperty(_ref2, "& .react-colorful__saturation-pointer,\n & .react-colorful__hue-pointer,\n & .react-colorful__alpha-pointer", {
101
+ width: theme.space[3],
102
+ height: theme.space[3],
103
+ borderRadius: '50%' // Make them round
104
+
105
+ }), _ref2;
106
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ColorPicker/ColorPicker.tsx"],"names":[],"mappings":"AAgBsB","file":"../../../src/ColorPicker/ColorPicker.tsx","sourcesContent":["import { useCallback, useMemo, useState } from 'react'\nimport { RgbaColorPicker } from 'react-colorful'\nimport styled from '@emotion/styled'\nimport debounce from 'lodash.debounce'\nimport SkInput from '../Input'\nimport FormLabel from '../FormLabel'\nimport SkButton from '../Button'\nimport Grid, { GridItem } from '../Grid'\nimport { rgbaToHexa, hexaToRgba, opacityFromHexa } from './utils'\nimport { useClickOutsideToggle, useOpacityValueSync } from './hooks'\nimport type { RGBA } from './types'\n\n// Values from UX\nconst PICKER_WIDTH = 196\nconst SATURATION_HEIGHT = 129\n\nconst PickerWrapper = styled('div')(({ theme }) => ({\n  background: theme.palette.neutral[0],\n  borderColor: theme.palette.neutral[4],\n  borderRadius: theme.radius[2],\n  borderStyle: 'solid',\n  borderWidth: theme.borderWidth[1],\n  paddingBottom: theme.space[5],\n  position: 'absolute',\n  right: -(PICKER_WIDTH + 9),\n  top: 0,\n  width: PICKER_WIDTH,\n  '& .react-colorful': {\n    height: 'auto',\n    width: '100%'\n  },\n  '& .react-colorful__saturation': {\n    border: 'none',\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    height: SATURATION_HEIGHT\n  },\n  [`& .react-colorful__hue,\n    & .react-colorful__alpha`]: {\n    borderRadius: theme.space[3], // Same as height\n    height: theme.space[3],\n    marginLeft: theme.space[4],\n    marginRight: theme.space[4]\n  },\n  '& .react-colorful__hue': {\n    marginBottom: theme.space[3],\n    marginTop: theme.space[4]\n  },\n  '& .react-colorful__alpha': {\n    marginBottom: theme.space[4]\n  },\n  [`& .react-colorful__saturation-pointer,\n    & .react-colorful__hue-pointer,\n    & .react-colorful__alpha-pointer`]: {\n    width: theme.space[3],\n    height: theme.space[3],\n    borderRadius: '50%' // Make them round\n  }\n}))\n\nconst Label = styled(FormLabel)(({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  marginLeft: theme.space[4],\n  flexShrink: 0,\n  height: theme.space[6],\n  lineHeight: theme.space[6]\n}))\n\nconst Input = styled(SkInput)(({ theme }) => ({\n  flexShrink: 1,\n  fontSize: theme.fontSize[1],\n  height: theme.space[6],\n  marginRight: theme.space[4],\n  textTransform: 'uppercase'\n}))\n\nconst Palette = styled('div')<{ color: string }>(({ theme, color }) => ({\n  height: theme.space[6],\n  width: theme.space[6],\n  borderRadius: theme.radius[0],\n  marginRight: theme.space[3],\n  backgroundColor: color\n}))\n\nconst Button = styled(SkButton)(({ theme }) => ({\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[4],\n  paddingRight: theme.space[4],\n  borderRadius: theme.radius[0]\n}))\n\nconst Item = styled(GridItem)({\n  display: 'flex'\n})\n\ntype ColorPickerProps = {\n  ['data-instrumentation']: string\n  onChange: (hex: string) => void\n  value: string\n  label: string\n}\n\nexport default function ColorPicker(props: ColorPickerProps) {\n  const { onChange, 'data-instrumentation': dataInstru, value, label } = props\n  const [opacity, setOpacity] = useState<string>(opacityFromHexa(value))\n\n  // Need to slightly delay the call to setState because moving the hue\n  // slider too fast can cause the picker internal state and our state\n  // to become unaligned and cause a render loop (for some reason).\n  // TODO: We may be able to replace this with useDeferredValue when we\n  // upgrade to React 18\n  const debouncedOnChange = useMemo(() => debounce(onChange, 1), [onChange])\n\n  const handleRgbaChange = useCallback(\n    (rgba: RGBA) => {\n      const hex = rgbaToHexa(rgba)\n      debouncedOnChange(hex)\n    },\n    [debouncedOnChange]\n  )\n\n  const handleHexaChange = useCallback(\n    ({ value: inString }) => {\n      let val = inString\n      if (typeof val === 'string') {\n        if (!val.startsWith('#') && val.length < 9) {\n          val = '#' + val\n        }\n        if (val !== value) {\n          onChange(val)\n        }\n      }\n    },\n    [onChange, value]\n  )\n\n  const handleOpacityChange = useCallback(({ value: inString }) => {\n    const val = inString\n    if (typeof val === 'string') {\n      setOpacity(val)\n    }\n  }, [])\n\n  // Contains logic to call onChange when opacity changes, update opacity\n  // when the value from props changes, and to reformat the opacity\n  // when the input is blurred. This is tricky because of the circular\n  // nature of opacity updates and the input color updates, especially\n  // when typing into the opacity field. You don't want to reformat the\n  // field while typing because it moves the cursor to the end.\n  const { handleOpacityBlur, handleOpacityFocus } = useOpacityValueSync(\n    value,\n    opacity,\n    onChange,\n    setOpacity\n  )\n\n  // Handle open/closed state of color picker popup\n  const [state, wrapperRef, handleToggle] = useClickOutsideToggle()\n\n  // Expands the input value if it is a condensed hex\n  const paletteColor = rgbaToHexa(hexaToRgba(value))\n\n  return (\n    <div\n      ref={wrapperRef}\n      css={{\n        position: 'relative',\n        display: 'inline-flex'\n      }}\n    >\n      <Button\n        data-instrumentation={`${dataInstru} colorpicker-button`}\n        onClick={handleToggle}\n        plain\n      >\n        <Palette title={paletteColor} color={paletteColor} />\n        {label}\n      </Button>\n      {state === 'open' ? (\n        <PickerWrapper>\n          <RgbaColorPicker\n            color={hexaToRgba(value)}\n            data-instrumentation={`${dataInstru} colorpicker-colorpicker`}\n            onChange={handleRgbaChange}\n          />\n          <Grid columns=\"auto auto\" gap=\".5rem .25rem\">\n            <Item>\n              <Label htmlFor=\"hex-color\">Hex</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-hexinput`}\n                maxLength={9} // #rrggbbaa\n                name=\"hex-color\"\n                onChange={handleHexaChange}\n                type=\"text\"\n                value={value}\n              />\n            </Item>\n\n            <Item>\n              <Label htmlFor=\"opacity\">Opacity</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-opacityinput`}\n                maxLength={5} // 99.9%\n                name=\"opacity\"\n                onChange={handleOpacityChange}\n                type=\"text\"\n                value={opacity}\n                onFocus={handleOpacityFocus}\n                onBlur={handleOpacityBlur}\n              />\n            </Item>\n          </Grid>\n        </PickerWrapper>\n      ) : null}\n    </div>\n  )\n}\n"]} */");
107
+ var Label = ( /*#__PURE__*/0, _base["default"])(_FormLabel["default"], process.env.NODE_ENV === "production" ? {
108
+ target: "eu4c7ix4"
109
+ } : {
110
+ target: "eu4c7ix4",
111
+ label: "Label"
112
+ })(function (_ref3) {
113
+ var theme = _ref3.theme;
114
+ return {
115
+ fontSize: theme.fontSize[1],
116
+ marginLeft: theme.space[4],
117
+ flexShrink: 0,
118
+ height: theme.space[6],
119
+ lineHeight: theme.space[6]
120
+ };
121
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ColorPicker/ColorPicker.tsx"],"names":[],"mappings":"AA4Dc","file":"../../../src/ColorPicker/ColorPicker.tsx","sourcesContent":["import { useCallback, useMemo, useState } from 'react'\nimport { RgbaColorPicker } from 'react-colorful'\nimport styled from '@emotion/styled'\nimport debounce from 'lodash.debounce'\nimport SkInput from '../Input'\nimport FormLabel from '../FormLabel'\nimport SkButton from '../Button'\nimport Grid, { GridItem } from '../Grid'\nimport { rgbaToHexa, hexaToRgba, opacityFromHexa } from './utils'\nimport { useClickOutsideToggle, useOpacityValueSync } from './hooks'\nimport type { RGBA } from './types'\n\n// Values from UX\nconst PICKER_WIDTH = 196\nconst SATURATION_HEIGHT = 129\n\nconst PickerWrapper = styled('div')(({ theme }) => ({\n  background: theme.palette.neutral[0],\n  borderColor: theme.palette.neutral[4],\n  borderRadius: theme.radius[2],\n  borderStyle: 'solid',\n  borderWidth: theme.borderWidth[1],\n  paddingBottom: theme.space[5],\n  position: 'absolute',\n  right: -(PICKER_WIDTH + 9),\n  top: 0,\n  width: PICKER_WIDTH,\n  '& .react-colorful': {\n    height: 'auto',\n    width: '100%'\n  },\n  '& .react-colorful__saturation': {\n    border: 'none',\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    height: SATURATION_HEIGHT\n  },\n  [`& .react-colorful__hue,\n    & .react-colorful__alpha`]: {\n    borderRadius: theme.space[3], // Same as height\n    height: theme.space[3],\n    marginLeft: theme.space[4],\n    marginRight: theme.space[4]\n  },\n  '& .react-colorful__hue': {\n    marginBottom: theme.space[3],\n    marginTop: theme.space[4]\n  },\n  '& .react-colorful__alpha': {\n    marginBottom: theme.space[4]\n  },\n  [`& .react-colorful__saturation-pointer,\n    & .react-colorful__hue-pointer,\n    & .react-colorful__alpha-pointer`]: {\n    width: theme.space[3],\n    height: theme.space[3],\n    borderRadius: '50%' // Make them round\n  }\n}))\n\nconst Label = styled(FormLabel)(({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  marginLeft: theme.space[4],\n  flexShrink: 0,\n  height: theme.space[6],\n  lineHeight: theme.space[6]\n}))\n\nconst Input = styled(SkInput)(({ theme }) => ({\n  flexShrink: 1,\n  fontSize: theme.fontSize[1],\n  height: theme.space[6],\n  marginRight: theme.space[4],\n  textTransform: 'uppercase'\n}))\n\nconst Palette = styled('div')<{ color: string }>(({ theme, color }) => ({\n  height: theme.space[6],\n  width: theme.space[6],\n  borderRadius: theme.radius[0],\n  marginRight: theme.space[3],\n  backgroundColor: color\n}))\n\nconst Button = styled(SkButton)(({ theme }) => ({\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[4],\n  paddingRight: theme.space[4],\n  borderRadius: theme.radius[0]\n}))\n\nconst Item = styled(GridItem)({\n  display: 'flex'\n})\n\ntype ColorPickerProps = {\n  ['data-instrumentation']: string\n  onChange: (hex: string) => void\n  value: string\n  label: string\n}\n\nexport default function ColorPicker(props: ColorPickerProps) {\n  const { onChange, 'data-instrumentation': dataInstru, value, label } = props\n  const [opacity, setOpacity] = useState<string>(opacityFromHexa(value))\n\n  // Need to slightly delay the call to setState because moving the hue\n  // slider too fast can cause the picker internal state and our state\n  // to become unaligned and cause a render loop (for some reason).\n  // TODO: We may be able to replace this with useDeferredValue when we\n  // upgrade to React 18\n  const debouncedOnChange = useMemo(() => debounce(onChange, 1), [onChange])\n\n  const handleRgbaChange = useCallback(\n    (rgba: RGBA) => {\n      const hex = rgbaToHexa(rgba)\n      debouncedOnChange(hex)\n    },\n    [debouncedOnChange]\n  )\n\n  const handleHexaChange = useCallback(\n    ({ value: inString }) => {\n      let val = inString\n      if (typeof val === 'string') {\n        if (!val.startsWith('#') && val.length < 9) {\n          val = '#' + val\n        }\n        if (val !== value) {\n          onChange(val)\n        }\n      }\n    },\n    [onChange, value]\n  )\n\n  const handleOpacityChange = useCallback(({ value: inString }) => {\n    const val = inString\n    if (typeof val === 'string') {\n      setOpacity(val)\n    }\n  }, [])\n\n  // Contains logic to call onChange when opacity changes, update opacity\n  // when the value from props changes, and to reformat the opacity\n  // when the input is blurred. This is tricky because of the circular\n  // nature of opacity updates and the input color updates, especially\n  // when typing into the opacity field. You don't want to reformat the\n  // field while typing because it moves the cursor to the end.\n  const { handleOpacityBlur, handleOpacityFocus } = useOpacityValueSync(\n    value,\n    opacity,\n    onChange,\n    setOpacity\n  )\n\n  // Handle open/closed state of color picker popup\n  const [state, wrapperRef, handleToggle] = useClickOutsideToggle()\n\n  // Expands the input value if it is a condensed hex\n  const paletteColor = rgbaToHexa(hexaToRgba(value))\n\n  return (\n    <div\n      ref={wrapperRef}\n      css={{\n        position: 'relative',\n        display: 'inline-flex'\n      }}\n    >\n      <Button\n        data-instrumentation={`${dataInstru} colorpicker-button`}\n        onClick={handleToggle}\n        plain\n      >\n        <Palette title={paletteColor} color={paletteColor} />\n        {label}\n      </Button>\n      {state === 'open' ? (\n        <PickerWrapper>\n          <RgbaColorPicker\n            color={hexaToRgba(value)}\n            data-instrumentation={`${dataInstru} colorpicker-colorpicker`}\n            onChange={handleRgbaChange}\n          />\n          <Grid columns=\"auto auto\" gap=\".5rem .25rem\">\n            <Item>\n              <Label htmlFor=\"hex-color\">Hex</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-hexinput`}\n                maxLength={9} // #rrggbbaa\n                name=\"hex-color\"\n                onChange={handleHexaChange}\n                type=\"text\"\n                value={value}\n              />\n            </Item>\n\n            <Item>\n              <Label htmlFor=\"opacity\">Opacity</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-opacityinput`}\n                maxLength={5} // 99.9%\n                name=\"opacity\"\n                onChange={handleOpacityChange}\n                type=\"text\"\n                value={opacity}\n                onFocus={handleOpacityFocus}\n                onBlur={handleOpacityBlur}\n              />\n            </Item>\n          </Grid>\n        </PickerWrapper>\n      ) : null}\n    </div>\n  )\n}\n"]} */");
122
+ var Input = ( /*#__PURE__*/0, _base["default"])(_Input["default"], process.env.NODE_ENV === "production" ? {
123
+ target: "eu4c7ix3"
124
+ } : {
125
+ target: "eu4c7ix3",
126
+ label: "Input"
127
+ })(function (_ref4) {
128
+ var theme = _ref4.theme;
129
+ return {
130
+ flexShrink: 1,
131
+ fontSize: theme.fontSize[1],
132
+ height: theme.space[6],
133
+ marginRight: theme.space[4],
134
+ textTransform: 'uppercase'
135
+ };
136
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ColorPicker/ColorPicker.tsx"],"names":[],"mappings":"AAoEc","file":"../../../src/ColorPicker/ColorPicker.tsx","sourcesContent":["import { useCallback, useMemo, useState } from 'react'\nimport { RgbaColorPicker } from 'react-colorful'\nimport styled from '@emotion/styled'\nimport debounce from 'lodash.debounce'\nimport SkInput from '../Input'\nimport FormLabel from '../FormLabel'\nimport SkButton from '../Button'\nimport Grid, { GridItem } from '../Grid'\nimport { rgbaToHexa, hexaToRgba, opacityFromHexa } from './utils'\nimport { useClickOutsideToggle, useOpacityValueSync } from './hooks'\nimport type { RGBA } from './types'\n\n// Values from UX\nconst PICKER_WIDTH = 196\nconst SATURATION_HEIGHT = 129\n\nconst PickerWrapper = styled('div')(({ theme }) => ({\n  background: theme.palette.neutral[0],\n  borderColor: theme.palette.neutral[4],\n  borderRadius: theme.radius[2],\n  borderStyle: 'solid',\n  borderWidth: theme.borderWidth[1],\n  paddingBottom: theme.space[5],\n  position: 'absolute',\n  right: -(PICKER_WIDTH + 9),\n  top: 0,\n  width: PICKER_WIDTH,\n  '& .react-colorful': {\n    height: 'auto',\n    width: '100%'\n  },\n  '& .react-colorful__saturation': {\n    border: 'none',\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    height: SATURATION_HEIGHT\n  },\n  [`& .react-colorful__hue,\n    & .react-colorful__alpha`]: {\n    borderRadius: theme.space[3], // Same as height\n    height: theme.space[3],\n    marginLeft: theme.space[4],\n    marginRight: theme.space[4]\n  },\n  '& .react-colorful__hue': {\n    marginBottom: theme.space[3],\n    marginTop: theme.space[4]\n  },\n  '& .react-colorful__alpha': {\n    marginBottom: theme.space[4]\n  },\n  [`& .react-colorful__saturation-pointer,\n    & .react-colorful__hue-pointer,\n    & .react-colorful__alpha-pointer`]: {\n    width: theme.space[3],\n    height: theme.space[3],\n    borderRadius: '50%' // Make them round\n  }\n}))\n\nconst Label = styled(FormLabel)(({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  marginLeft: theme.space[4],\n  flexShrink: 0,\n  height: theme.space[6],\n  lineHeight: theme.space[6]\n}))\n\nconst Input = styled(SkInput)(({ theme }) => ({\n  flexShrink: 1,\n  fontSize: theme.fontSize[1],\n  height: theme.space[6],\n  marginRight: theme.space[4],\n  textTransform: 'uppercase'\n}))\n\nconst Palette = styled('div')<{ color: string }>(({ theme, color }) => ({\n  height: theme.space[6],\n  width: theme.space[6],\n  borderRadius: theme.radius[0],\n  marginRight: theme.space[3],\n  backgroundColor: color\n}))\n\nconst Button = styled(SkButton)(({ theme }) => ({\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[4],\n  paddingRight: theme.space[4],\n  borderRadius: theme.radius[0]\n}))\n\nconst Item = styled(GridItem)({\n  display: 'flex'\n})\n\ntype ColorPickerProps = {\n  ['data-instrumentation']: string\n  onChange: (hex: string) => void\n  value: string\n  label: string\n}\n\nexport default function ColorPicker(props: ColorPickerProps) {\n  const { onChange, 'data-instrumentation': dataInstru, value, label } = props\n  const [opacity, setOpacity] = useState<string>(opacityFromHexa(value))\n\n  // Need to slightly delay the call to setState because moving the hue\n  // slider too fast can cause the picker internal state and our state\n  // to become unaligned and cause a render loop (for some reason).\n  // TODO: We may be able to replace this with useDeferredValue when we\n  // upgrade to React 18\n  const debouncedOnChange = useMemo(() => debounce(onChange, 1), [onChange])\n\n  const handleRgbaChange = useCallback(\n    (rgba: RGBA) => {\n      const hex = rgbaToHexa(rgba)\n      debouncedOnChange(hex)\n    },\n    [debouncedOnChange]\n  )\n\n  const handleHexaChange = useCallback(\n    ({ value: inString }) => {\n      let val = inString\n      if (typeof val === 'string') {\n        if (!val.startsWith('#') && val.length < 9) {\n          val = '#' + val\n        }\n        if (val !== value) {\n          onChange(val)\n        }\n      }\n    },\n    [onChange, value]\n  )\n\n  const handleOpacityChange = useCallback(({ value: inString }) => {\n    const val = inString\n    if (typeof val === 'string') {\n      setOpacity(val)\n    }\n  }, [])\n\n  // Contains logic to call onChange when opacity changes, update opacity\n  // when the value from props changes, and to reformat the opacity\n  // when the input is blurred. This is tricky because of the circular\n  // nature of opacity updates and the input color updates, especially\n  // when typing into the opacity field. You don't want to reformat the\n  // field while typing because it moves the cursor to the end.\n  const { handleOpacityBlur, handleOpacityFocus } = useOpacityValueSync(\n    value,\n    opacity,\n    onChange,\n    setOpacity\n  )\n\n  // Handle open/closed state of color picker popup\n  const [state, wrapperRef, handleToggle] = useClickOutsideToggle()\n\n  // Expands the input value if it is a condensed hex\n  const paletteColor = rgbaToHexa(hexaToRgba(value))\n\n  return (\n    <div\n      ref={wrapperRef}\n      css={{\n        position: 'relative',\n        display: 'inline-flex'\n      }}\n    >\n      <Button\n        data-instrumentation={`${dataInstru} colorpicker-button`}\n        onClick={handleToggle}\n        plain\n      >\n        <Palette title={paletteColor} color={paletteColor} />\n        {label}\n      </Button>\n      {state === 'open' ? (\n        <PickerWrapper>\n          <RgbaColorPicker\n            color={hexaToRgba(value)}\n            data-instrumentation={`${dataInstru} colorpicker-colorpicker`}\n            onChange={handleRgbaChange}\n          />\n          <Grid columns=\"auto auto\" gap=\".5rem .25rem\">\n            <Item>\n              <Label htmlFor=\"hex-color\">Hex</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-hexinput`}\n                maxLength={9} // #rrggbbaa\n                name=\"hex-color\"\n                onChange={handleHexaChange}\n                type=\"text\"\n                value={value}\n              />\n            </Item>\n\n            <Item>\n              <Label htmlFor=\"opacity\">Opacity</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-opacityinput`}\n                maxLength={5} // 99.9%\n                name=\"opacity\"\n                onChange={handleOpacityChange}\n                type=\"text\"\n                value={opacity}\n                onFocus={handleOpacityFocus}\n                onBlur={handleOpacityBlur}\n              />\n            </Item>\n          </Grid>\n        </PickerWrapper>\n      ) : null}\n    </div>\n  )\n}\n"]} */");
137
+ var Palette = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
138
+ target: "eu4c7ix2"
139
+ } : {
140
+ target: "eu4c7ix2",
141
+ label: "Palette"
142
+ })(function (_ref5) {
143
+ var theme = _ref5.theme,
144
+ color = _ref5.color;
145
+ return {
146
+ height: theme.space[6],
147
+ width: theme.space[6],
148
+ borderRadius: theme.radius[0],
149
+ marginRight: theme.space[3],
150
+ backgroundColor: color
151
+ };
152
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ColorPicker/ColorPicker.tsx"],"names":[],"mappings":"AA4EgB","file":"../../../src/ColorPicker/ColorPicker.tsx","sourcesContent":["import { useCallback, useMemo, useState } from 'react'\nimport { RgbaColorPicker } from 'react-colorful'\nimport styled from '@emotion/styled'\nimport debounce from 'lodash.debounce'\nimport SkInput from '../Input'\nimport FormLabel from '../FormLabel'\nimport SkButton from '../Button'\nimport Grid, { GridItem } from '../Grid'\nimport { rgbaToHexa, hexaToRgba, opacityFromHexa } from './utils'\nimport { useClickOutsideToggle, useOpacityValueSync } from './hooks'\nimport type { RGBA } from './types'\n\n// Values from UX\nconst PICKER_WIDTH = 196\nconst SATURATION_HEIGHT = 129\n\nconst PickerWrapper = styled('div')(({ theme }) => ({\n  background: theme.palette.neutral[0],\n  borderColor: theme.palette.neutral[4],\n  borderRadius: theme.radius[2],\n  borderStyle: 'solid',\n  borderWidth: theme.borderWidth[1],\n  paddingBottom: theme.space[5],\n  position: 'absolute',\n  right: -(PICKER_WIDTH + 9),\n  top: 0,\n  width: PICKER_WIDTH,\n  '& .react-colorful': {\n    height: 'auto',\n    width: '100%'\n  },\n  '& .react-colorful__saturation': {\n    border: 'none',\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    height: SATURATION_HEIGHT\n  },\n  [`& .react-colorful__hue,\n    & .react-colorful__alpha`]: {\n    borderRadius: theme.space[3], // Same as height\n    height: theme.space[3],\n    marginLeft: theme.space[4],\n    marginRight: theme.space[4]\n  },\n  '& .react-colorful__hue': {\n    marginBottom: theme.space[3],\n    marginTop: theme.space[4]\n  },\n  '& .react-colorful__alpha': {\n    marginBottom: theme.space[4]\n  },\n  [`& .react-colorful__saturation-pointer,\n    & .react-colorful__hue-pointer,\n    & .react-colorful__alpha-pointer`]: {\n    width: theme.space[3],\n    height: theme.space[3],\n    borderRadius: '50%' // Make them round\n  }\n}))\n\nconst Label = styled(FormLabel)(({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  marginLeft: theme.space[4],\n  flexShrink: 0,\n  height: theme.space[6],\n  lineHeight: theme.space[6]\n}))\n\nconst Input = styled(SkInput)(({ theme }) => ({\n  flexShrink: 1,\n  fontSize: theme.fontSize[1],\n  height: theme.space[6],\n  marginRight: theme.space[4],\n  textTransform: 'uppercase'\n}))\n\nconst Palette = styled('div')<{ color: string }>(({ theme, color }) => ({\n  height: theme.space[6],\n  width: theme.space[6],\n  borderRadius: theme.radius[0],\n  marginRight: theme.space[3],\n  backgroundColor: color\n}))\n\nconst Button = styled(SkButton)(({ theme }) => ({\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[4],\n  paddingRight: theme.space[4],\n  borderRadius: theme.radius[0]\n}))\n\nconst Item = styled(GridItem)({\n  display: 'flex'\n})\n\ntype ColorPickerProps = {\n  ['data-instrumentation']: string\n  onChange: (hex: string) => void\n  value: string\n  label: string\n}\n\nexport default function ColorPicker(props: ColorPickerProps) {\n  const { onChange, 'data-instrumentation': dataInstru, value, label } = props\n  const [opacity, setOpacity] = useState<string>(opacityFromHexa(value))\n\n  // Need to slightly delay the call to setState because moving the hue\n  // slider too fast can cause the picker internal state and our state\n  // to become unaligned and cause a render loop (for some reason).\n  // TODO: We may be able to replace this with useDeferredValue when we\n  // upgrade to React 18\n  const debouncedOnChange = useMemo(() => debounce(onChange, 1), [onChange])\n\n  const handleRgbaChange = useCallback(\n    (rgba: RGBA) => {\n      const hex = rgbaToHexa(rgba)\n      debouncedOnChange(hex)\n    },\n    [debouncedOnChange]\n  )\n\n  const handleHexaChange = useCallback(\n    ({ value: inString }) => {\n      let val = inString\n      if (typeof val === 'string') {\n        if (!val.startsWith('#') && val.length < 9) {\n          val = '#' + val\n        }\n        if (val !== value) {\n          onChange(val)\n        }\n      }\n    },\n    [onChange, value]\n  )\n\n  const handleOpacityChange = useCallback(({ value: inString }) => {\n    const val = inString\n    if (typeof val === 'string') {\n      setOpacity(val)\n    }\n  }, [])\n\n  // Contains logic to call onChange when opacity changes, update opacity\n  // when the value from props changes, and to reformat the opacity\n  // when the input is blurred. This is tricky because of the circular\n  // nature of opacity updates and the input color updates, especially\n  // when typing into the opacity field. You don't want to reformat the\n  // field while typing because it moves the cursor to the end.\n  const { handleOpacityBlur, handleOpacityFocus } = useOpacityValueSync(\n    value,\n    opacity,\n    onChange,\n    setOpacity\n  )\n\n  // Handle open/closed state of color picker popup\n  const [state, wrapperRef, handleToggle] = useClickOutsideToggle()\n\n  // Expands the input value if it is a condensed hex\n  const paletteColor = rgbaToHexa(hexaToRgba(value))\n\n  return (\n    <div\n      ref={wrapperRef}\n      css={{\n        position: 'relative',\n        display: 'inline-flex'\n      }}\n    >\n      <Button\n        data-instrumentation={`${dataInstru} colorpicker-button`}\n        onClick={handleToggle}\n        plain\n      >\n        <Palette title={paletteColor} color={paletteColor} />\n        {label}\n      </Button>\n      {state === 'open' ? (\n        <PickerWrapper>\n          <RgbaColorPicker\n            color={hexaToRgba(value)}\n            data-instrumentation={`${dataInstru} colorpicker-colorpicker`}\n            onChange={handleRgbaChange}\n          />\n          <Grid columns=\"auto auto\" gap=\".5rem .25rem\">\n            <Item>\n              <Label htmlFor=\"hex-color\">Hex</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-hexinput`}\n                maxLength={9} // #rrggbbaa\n                name=\"hex-color\"\n                onChange={handleHexaChange}\n                type=\"text\"\n                value={value}\n              />\n            </Item>\n\n            <Item>\n              <Label htmlFor=\"opacity\">Opacity</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-opacityinput`}\n                maxLength={5} // 99.9%\n                name=\"opacity\"\n                onChange={handleOpacityChange}\n                type=\"text\"\n                value={opacity}\n                onFocus={handleOpacityFocus}\n                onBlur={handleOpacityBlur}\n              />\n            </Item>\n          </Grid>\n        </PickerWrapper>\n      ) : null}\n    </div>\n  )\n}\n"]} */");
153
+ var Button = ( /*#__PURE__*/0, _base["default"])(_Button["default"], process.env.NODE_ENV === "production" ? {
154
+ target: "eu4c7ix1"
155
+ } : {
156
+ target: "eu4c7ix1",
157
+ label: "Button"
158
+ })(function (_ref6) {
159
+ var theme = _ref6.theme;
160
+ return {
161
+ paddingTop: theme.space[2],
162
+ paddingBottom: theme.space[2],
163
+ paddingLeft: theme.space[4],
164
+ paddingRight: theme.space[4],
165
+ borderRadius: theme.radius[0]
166
+ };
167
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ColorPicker/ColorPicker.tsx"],"names":[],"mappings":"AAoFe","file":"../../../src/ColorPicker/ColorPicker.tsx","sourcesContent":["import { useCallback, useMemo, useState } from 'react'\nimport { RgbaColorPicker } from 'react-colorful'\nimport styled from '@emotion/styled'\nimport debounce from 'lodash.debounce'\nimport SkInput from '../Input'\nimport FormLabel from '../FormLabel'\nimport SkButton from '../Button'\nimport Grid, { GridItem } from '../Grid'\nimport { rgbaToHexa, hexaToRgba, opacityFromHexa } from './utils'\nimport { useClickOutsideToggle, useOpacityValueSync } from './hooks'\nimport type { RGBA } from './types'\n\n// Values from UX\nconst PICKER_WIDTH = 196\nconst SATURATION_HEIGHT = 129\n\nconst PickerWrapper = styled('div')(({ theme }) => ({\n  background: theme.palette.neutral[0],\n  borderColor: theme.palette.neutral[4],\n  borderRadius: theme.radius[2],\n  borderStyle: 'solid',\n  borderWidth: theme.borderWidth[1],\n  paddingBottom: theme.space[5],\n  position: 'absolute',\n  right: -(PICKER_WIDTH + 9),\n  top: 0,\n  width: PICKER_WIDTH,\n  '& .react-colorful': {\n    height: 'auto',\n    width: '100%'\n  },\n  '& .react-colorful__saturation': {\n    border: 'none',\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    height: SATURATION_HEIGHT\n  },\n  [`& .react-colorful__hue,\n    & .react-colorful__alpha`]: {\n    borderRadius: theme.space[3], // Same as height\n    height: theme.space[3],\n    marginLeft: theme.space[4],\n    marginRight: theme.space[4]\n  },\n  '& .react-colorful__hue': {\n    marginBottom: theme.space[3],\n    marginTop: theme.space[4]\n  },\n  '& .react-colorful__alpha': {\n    marginBottom: theme.space[4]\n  },\n  [`& .react-colorful__saturation-pointer,\n    & .react-colorful__hue-pointer,\n    & .react-colorful__alpha-pointer`]: {\n    width: theme.space[3],\n    height: theme.space[3],\n    borderRadius: '50%' // Make them round\n  }\n}))\n\nconst Label = styled(FormLabel)(({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  marginLeft: theme.space[4],\n  flexShrink: 0,\n  height: theme.space[6],\n  lineHeight: theme.space[6]\n}))\n\nconst Input = styled(SkInput)(({ theme }) => ({\n  flexShrink: 1,\n  fontSize: theme.fontSize[1],\n  height: theme.space[6],\n  marginRight: theme.space[4],\n  textTransform: 'uppercase'\n}))\n\nconst Palette = styled('div')<{ color: string }>(({ theme, color }) => ({\n  height: theme.space[6],\n  width: theme.space[6],\n  borderRadius: theme.radius[0],\n  marginRight: theme.space[3],\n  backgroundColor: color\n}))\n\nconst Button = styled(SkButton)(({ theme }) => ({\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[4],\n  paddingRight: theme.space[4],\n  borderRadius: theme.radius[0]\n}))\n\nconst Item = styled(GridItem)({\n  display: 'flex'\n})\n\ntype ColorPickerProps = {\n  ['data-instrumentation']: string\n  onChange: (hex: string) => void\n  value: string\n  label: string\n}\n\nexport default function ColorPicker(props: ColorPickerProps) {\n  const { onChange, 'data-instrumentation': dataInstru, value, label } = props\n  const [opacity, setOpacity] = useState<string>(opacityFromHexa(value))\n\n  // Need to slightly delay the call to setState because moving the hue\n  // slider too fast can cause the picker internal state and our state\n  // to become unaligned and cause a render loop (for some reason).\n  // TODO: We may be able to replace this with useDeferredValue when we\n  // upgrade to React 18\n  const debouncedOnChange = useMemo(() => debounce(onChange, 1), [onChange])\n\n  const handleRgbaChange = useCallback(\n    (rgba: RGBA) => {\n      const hex = rgbaToHexa(rgba)\n      debouncedOnChange(hex)\n    },\n    [debouncedOnChange]\n  )\n\n  const handleHexaChange = useCallback(\n    ({ value: inString }) => {\n      let val = inString\n      if (typeof val === 'string') {\n        if (!val.startsWith('#') && val.length < 9) {\n          val = '#' + val\n        }\n        if (val !== value) {\n          onChange(val)\n        }\n      }\n    },\n    [onChange, value]\n  )\n\n  const handleOpacityChange = useCallback(({ value: inString }) => {\n    const val = inString\n    if (typeof val === 'string') {\n      setOpacity(val)\n    }\n  }, [])\n\n  // Contains logic to call onChange when opacity changes, update opacity\n  // when the value from props changes, and to reformat the opacity\n  // when the input is blurred. This is tricky because of the circular\n  // nature of opacity updates and the input color updates, especially\n  // when typing into the opacity field. You don't want to reformat the\n  // field while typing because it moves the cursor to the end.\n  const { handleOpacityBlur, handleOpacityFocus } = useOpacityValueSync(\n    value,\n    opacity,\n    onChange,\n    setOpacity\n  )\n\n  // Handle open/closed state of color picker popup\n  const [state, wrapperRef, handleToggle] = useClickOutsideToggle()\n\n  // Expands the input value if it is a condensed hex\n  const paletteColor = rgbaToHexa(hexaToRgba(value))\n\n  return (\n    <div\n      ref={wrapperRef}\n      css={{\n        position: 'relative',\n        display: 'inline-flex'\n      }}\n    >\n      <Button\n        data-instrumentation={`${dataInstru} colorpicker-button`}\n        onClick={handleToggle}\n        plain\n      >\n        <Palette title={paletteColor} color={paletteColor} />\n        {label}\n      </Button>\n      {state === 'open' ? (\n        <PickerWrapper>\n          <RgbaColorPicker\n            color={hexaToRgba(value)}\n            data-instrumentation={`${dataInstru} colorpicker-colorpicker`}\n            onChange={handleRgbaChange}\n          />\n          <Grid columns=\"auto auto\" gap=\".5rem .25rem\">\n            <Item>\n              <Label htmlFor=\"hex-color\">Hex</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-hexinput`}\n                maxLength={9} // #rrggbbaa\n                name=\"hex-color\"\n                onChange={handleHexaChange}\n                type=\"text\"\n                value={value}\n              />\n            </Item>\n\n            <Item>\n              <Label htmlFor=\"opacity\">Opacity</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-opacityinput`}\n                maxLength={5} // 99.9%\n                name=\"opacity\"\n                onChange={handleOpacityChange}\n                type=\"text\"\n                value={opacity}\n                onFocus={handleOpacityFocus}\n                onBlur={handleOpacityBlur}\n              />\n            </Item>\n          </Grid>\n        </PickerWrapper>\n      ) : null}\n    </div>\n  )\n}\n"]} */");
168
+ var Item = ( /*#__PURE__*/0, _base["default"])(_Grid.GridItem, process.env.NODE_ENV === "production" ? {
169
+ target: "eu4c7ix0"
170
+ } : {
171
+ target: "eu4c7ix0",
172
+ label: "Item"
173
+ })(process.env.NODE_ENV === "production" ? {
174
+ name: "zjik7",
175
+ styles: "display:flex"
176
+ } : {
177
+ name: "zjik7",
178
+ styles: "display:flex",
179
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ColorPicker/ColorPicker.tsx"],"names":[],"mappings":"AA4Fa","file":"../../../src/ColorPicker/ColorPicker.tsx","sourcesContent":["import { useCallback, useMemo, useState } from 'react'\nimport { RgbaColorPicker } from 'react-colorful'\nimport styled from '@emotion/styled'\nimport debounce from 'lodash.debounce'\nimport SkInput from '../Input'\nimport FormLabel from '../FormLabel'\nimport SkButton from '../Button'\nimport Grid, { GridItem } from '../Grid'\nimport { rgbaToHexa, hexaToRgba, opacityFromHexa } from './utils'\nimport { useClickOutsideToggle, useOpacityValueSync } from './hooks'\nimport type { RGBA } from './types'\n\n// Values from UX\nconst PICKER_WIDTH = 196\nconst SATURATION_HEIGHT = 129\n\nconst PickerWrapper = styled('div')(({ theme }) => ({\n  background: theme.palette.neutral[0],\n  borderColor: theme.palette.neutral[4],\n  borderRadius: theme.radius[2],\n  borderStyle: 'solid',\n  borderWidth: theme.borderWidth[1],\n  paddingBottom: theme.space[5],\n  position: 'absolute',\n  right: -(PICKER_WIDTH + 9),\n  top: 0,\n  width: PICKER_WIDTH,\n  '& .react-colorful': {\n    height: 'auto',\n    width: '100%'\n  },\n  '& .react-colorful__saturation': {\n    border: 'none',\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    height: SATURATION_HEIGHT\n  },\n  [`& .react-colorful__hue,\n    & .react-colorful__alpha`]: {\n    borderRadius: theme.space[3], // Same as height\n    height: theme.space[3],\n    marginLeft: theme.space[4],\n    marginRight: theme.space[4]\n  },\n  '& .react-colorful__hue': {\n    marginBottom: theme.space[3],\n    marginTop: theme.space[4]\n  },\n  '& .react-colorful__alpha': {\n    marginBottom: theme.space[4]\n  },\n  [`& .react-colorful__saturation-pointer,\n    & .react-colorful__hue-pointer,\n    & .react-colorful__alpha-pointer`]: {\n    width: theme.space[3],\n    height: theme.space[3],\n    borderRadius: '50%' // Make them round\n  }\n}))\n\nconst Label = styled(FormLabel)(({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  marginLeft: theme.space[4],\n  flexShrink: 0,\n  height: theme.space[6],\n  lineHeight: theme.space[6]\n}))\n\nconst Input = styled(SkInput)(({ theme }) => ({\n  flexShrink: 1,\n  fontSize: theme.fontSize[1],\n  height: theme.space[6],\n  marginRight: theme.space[4],\n  textTransform: 'uppercase'\n}))\n\nconst Palette = styled('div')<{ color: string }>(({ theme, color }) => ({\n  height: theme.space[6],\n  width: theme.space[6],\n  borderRadius: theme.radius[0],\n  marginRight: theme.space[3],\n  backgroundColor: color\n}))\n\nconst Button = styled(SkButton)(({ theme }) => ({\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[4],\n  paddingRight: theme.space[4],\n  borderRadius: theme.radius[0]\n}))\n\nconst Item = styled(GridItem)({\n  display: 'flex'\n})\n\ntype ColorPickerProps = {\n  ['data-instrumentation']: string\n  onChange: (hex: string) => void\n  value: string\n  label: string\n}\n\nexport default function ColorPicker(props: ColorPickerProps) {\n  const { onChange, 'data-instrumentation': dataInstru, value, label } = props\n  const [opacity, setOpacity] = useState<string>(opacityFromHexa(value))\n\n  // Need to slightly delay the call to setState because moving the hue\n  // slider too fast can cause the picker internal state and our state\n  // to become unaligned and cause a render loop (for some reason).\n  // TODO: We may be able to replace this with useDeferredValue when we\n  // upgrade to React 18\n  const debouncedOnChange = useMemo(() => debounce(onChange, 1), [onChange])\n\n  const handleRgbaChange = useCallback(\n    (rgba: RGBA) => {\n      const hex = rgbaToHexa(rgba)\n      debouncedOnChange(hex)\n    },\n    [debouncedOnChange]\n  )\n\n  const handleHexaChange = useCallback(\n    ({ value: inString }) => {\n      let val = inString\n      if (typeof val === 'string') {\n        if (!val.startsWith('#') && val.length < 9) {\n          val = '#' + val\n        }\n        if (val !== value) {\n          onChange(val)\n        }\n      }\n    },\n    [onChange, value]\n  )\n\n  const handleOpacityChange = useCallback(({ value: inString }) => {\n    const val = inString\n    if (typeof val === 'string') {\n      setOpacity(val)\n    }\n  }, [])\n\n  // Contains logic to call onChange when opacity changes, update opacity\n  // when the value from props changes, and to reformat the opacity\n  // when the input is blurred. This is tricky because of the circular\n  // nature of opacity updates and the input color updates, especially\n  // when typing into the opacity field. You don't want to reformat the\n  // field while typing because it moves the cursor to the end.\n  const { handleOpacityBlur, handleOpacityFocus } = useOpacityValueSync(\n    value,\n    opacity,\n    onChange,\n    setOpacity\n  )\n\n  // Handle open/closed state of color picker popup\n  const [state, wrapperRef, handleToggle] = useClickOutsideToggle()\n\n  // Expands the input value if it is a condensed hex\n  const paletteColor = rgbaToHexa(hexaToRgba(value))\n\n  return (\n    <div\n      ref={wrapperRef}\n      css={{\n        position: 'relative',\n        display: 'inline-flex'\n      }}\n    >\n      <Button\n        data-instrumentation={`${dataInstru} colorpicker-button`}\n        onClick={handleToggle}\n        plain\n      >\n        <Palette title={paletteColor} color={paletteColor} />\n        {label}\n      </Button>\n      {state === 'open' ? (\n        <PickerWrapper>\n          <RgbaColorPicker\n            color={hexaToRgba(value)}\n            data-instrumentation={`${dataInstru} colorpicker-colorpicker`}\n            onChange={handleRgbaChange}\n          />\n          <Grid columns=\"auto auto\" gap=\".5rem .25rem\">\n            <Item>\n              <Label htmlFor=\"hex-color\">Hex</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-hexinput`}\n                maxLength={9} // #rrggbbaa\n                name=\"hex-color\"\n                onChange={handleHexaChange}\n                type=\"text\"\n                value={value}\n              />\n            </Item>\n\n            <Item>\n              <Label htmlFor=\"opacity\">Opacity</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-opacityinput`}\n                maxLength={5} // 99.9%\n                name=\"opacity\"\n                onChange={handleOpacityChange}\n                type=\"text\"\n                value={opacity}\n                onFocus={handleOpacityFocus}\n                onBlur={handleOpacityBlur}\n              />\n            </Item>\n          </Grid>\n        </PickerWrapper>\n      ) : null}\n    </div>\n  )\n}\n"]} */",
180
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
181
+ });
182
+
183
+ var _ref9 = process.env.NODE_ENV === "production" ? {
184
+ name: "5tpiub",
185
+ styles: "position:relative;display:inline-flex"
186
+ } : {
187
+ name: "16f6a97-ColorPicker",
188
+ styles: "position:relative;display:inline-flex;label:ColorPicker;",
189
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ColorPicker/ColorPicker.tsx"],"names":[],"mappings":"AAsKM","file":"../../../src/ColorPicker/ColorPicker.tsx","sourcesContent":["import { useCallback, useMemo, useState } from 'react'\nimport { RgbaColorPicker } from 'react-colorful'\nimport styled from '@emotion/styled'\nimport debounce from 'lodash.debounce'\nimport SkInput from '../Input'\nimport FormLabel from '../FormLabel'\nimport SkButton from '../Button'\nimport Grid, { GridItem } from '../Grid'\nimport { rgbaToHexa, hexaToRgba, opacityFromHexa } from './utils'\nimport { useClickOutsideToggle, useOpacityValueSync } from './hooks'\nimport type { RGBA } from './types'\n\n// Values from UX\nconst PICKER_WIDTH = 196\nconst SATURATION_HEIGHT = 129\n\nconst PickerWrapper = styled('div')(({ theme }) => ({\n  background: theme.palette.neutral[0],\n  borderColor: theme.palette.neutral[4],\n  borderRadius: theme.radius[2],\n  borderStyle: 'solid',\n  borderWidth: theme.borderWidth[1],\n  paddingBottom: theme.space[5],\n  position: 'absolute',\n  right: -(PICKER_WIDTH + 9),\n  top: 0,\n  width: PICKER_WIDTH,\n  '& .react-colorful': {\n    height: 'auto',\n    width: '100%'\n  },\n  '& .react-colorful__saturation': {\n    border: 'none',\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    height: SATURATION_HEIGHT\n  },\n  [`& .react-colorful__hue,\n    & .react-colorful__alpha`]: {\n    borderRadius: theme.space[3], // Same as height\n    height: theme.space[3],\n    marginLeft: theme.space[4],\n    marginRight: theme.space[4]\n  },\n  '& .react-colorful__hue': {\n    marginBottom: theme.space[3],\n    marginTop: theme.space[4]\n  },\n  '& .react-colorful__alpha': {\n    marginBottom: theme.space[4]\n  },\n  [`& .react-colorful__saturation-pointer,\n    & .react-colorful__hue-pointer,\n    & .react-colorful__alpha-pointer`]: {\n    width: theme.space[3],\n    height: theme.space[3],\n    borderRadius: '50%' // Make them round\n  }\n}))\n\nconst Label = styled(FormLabel)(({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  marginLeft: theme.space[4],\n  flexShrink: 0,\n  height: theme.space[6],\n  lineHeight: theme.space[6]\n}))\n\nconst Input = styled(SkInput)(({ theme }) => ({\n  flexShrink: 1,\n  fontSize: theme.fontSize[1],\n  height: theme.space[6],\n  marginRight: theme.space[4],\n  textTransform: 'uppercase'\n}))\n\nconst Palette = styled('div')<{ color: string }>(({ theme, color }) => ({\n  height: theme.space[6],\n  width: theme.space[6],\n  borderRadius: theme.radius[0],\n  marginRight: theme.space[3],\n  backgroundColor: color\n}))\n\nconst Button = styled(SkButton)(({ theme }) => ({\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[4],\n  paddingRight: theme.space[4],\n  borderRadius: theme.radius[0]\n}))\n\nconst Item = styled(GridItem)({\n  display: 'flex'\n})\n\ntype ColorPickerProps = {\n  ['data-instrumentation']: string\n  onChange: (hex: string) => void\n  value: string\n  label: string\n}\n\nexport default function ColorPicker(props: ColorPickerProps) {\n  const { onChange, 'data-instrumentation': dataInstru, value, label } = props\n  const [opacity, setOpacity] = useState<string>(opacityFromHexa(value))\n\n  // Need to slightly delay the call to setState because moving the hue\n  // slider too fast can cause the picker internal state and our state\n  // to become unaligned and cause a render loop (for some reason).\n  // TODO: We may be able to replace this with useDeferredValue when we\n  // upgrade to React 18\n  const debouncedOnChange = useMemo(() => debounce(onChange, 1), [onChange])\n\n  const handleRgbaChange = useCallback(\n    (rgba: RGBA) => {\n      const hex = rgbaToHexa(rgba)\n      debouncedOnChange(hex)\n    },\n    [debouncedOnChange]\n  )\n\n  const handleHexaChange = useCallback(\n    ({ value: inString }) => {\n      let val = inString\n      if (typeof val === 'string') {\n        if (!val.startsWith('#') && val.length < 9) {\n          val = '#' + val\n        }\n        if (val !== value) {\n          onChange(val)\n        }\n      }\n    },\n    [onChange, value]\n  )\n\n  const handleOpacityChange = useCallback(({ value: inString }) => {\n    const val = inString\n    if (typeof val === 'string') {\n      setOpacity(val)\n    }\n  }, [])\n\n  // Contains logic to call onChange when opacity changes, update opacity\n  // when the value from props changes, and to reformat the opacity\n  // when the input is blurred. This is tricky because of the circular\n  // nature of opacity updates and the input color updates, especially\n  // when typing into the opacity field. You don't want to reformat the\n  // field while typing because it moves the cursor to the end.\n  const { handleOpacityBlur, handleOpacityFocus } = useOpacityValueSync(\n    value,\n    opacity,\n    onChange,\n    setOpacity\n  )\n\n  // Handle open/closed state of color picker popup\n  const [state, wrapperRef, handleToggle] = useClickOutsideToggle()\n\n  // Expands the input value if it is a condensed hex\n  const paletteColor = rgbaToHexa(hexaToRgba(value))\n\n  return (\n    <div\n      ref={wrapperRef}\n      css={{\n        position: 'relative',\n        display: 'inline-flex'\n      }}\n    >\n      <Button\n        data-instrumentation={`${dataInstru} colorpicker-button`}\n        onClick={handleToggle}\n        plain\n      >\n        <Palette title={paletteColor} color={paletteColor} />\n        {label}\n      </Button>\n      {state === 'open' ? (\n        <PickerWrapper>\n          <RgbaColorPicker\n            color={hexaToRgba(value)}\n            data-instrumentation={`${dataInstru} colorpicker-colorpicker`}\n            onChange={handleRgbaChange}\n          />\n          <Grid columns=\"auto auto\" gap=\".5rem .25rem\">\n            <Item>\n              <Label htmlFor=\"hex-color\">Hex</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-hexinput`}\n                maxLength={9} // #rrggbbaa\n                name=\"hex-color\"\n                onChange={handleHexaChange}\n                type=\"text\"\n                value={value}\n              />\n            </Item>\n\n            <Item>\n              <Label htmlFor=\"opacity\">Opacity</Label>\n            </Item>\n            <Item>\n              <Input\n                data-instrumentation={`${dataInstru} colorpicker-opacityinput`}\n                maxLength={5} // 99.9%\n                name=\"opacity\"\n                onChange={handleOpacityChange}\n                type=\"text\"\n                value={opacity}\n                onFocus={handleOpacityFocus}\n                onBlur={handleOpacityBlur}\n              />\n            </Item>\n          </Grid>\n        </PickerWrapper>\n      ) : null}\n    </div>\n  )\n}\n"]} */",
190
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
191
+ };
192
+
193
+ function ColorPicker(props) {
194
+ var onChange = props.onChange,
195
+ dataInstru = props['data-instrumentation'],
196
+ value = props.value,
197
+ label = props.label;
198
+
199
+ var _useState = (0, _react.useState)((0, _utils.opacityFromHexa)(value)),
200
+ _useState2 = _slicedToArray(_useState, 2),
201
+ opacity = _useState2[0],
202
+ setOpacity = _useState2[1]; // Need to slightly delay the call to setState because moving the hue
203
+ // slider too fast can cause the picker internal state and our state
204
+ // to become unaligned and cause a render loop (for some reason).
205
+ // TODO: We may be able to replace this with useDeferredValue when we
206
+ // upgrade to React 18
207
+
208
+
209
+ var debouncedOnChange = (0, _react.useMemo)(function () {
210
+ return (0, _lodash["default"])(onChange, 1);
211
+ }, [onChange]);
212
+ var handleRgbaChange = (0, _react.useCallback)(function (rgba) {
213
+ var hex = (0, _utils.rgbaToHexa)(rgba);
214
+ debouncedOnChange(hex);
215
+ }, [debouncedOnChange]);
216
+ var handleHexaChange = (0, _react.useCallback)(function (_ref7) {
217
+ var inString = _ref7.value;
218
+ var val = inString;
219
+
220
+ if (typeof val === 'string') {
221
+ if (!val.startsWith('#') && val.length < 9) {
222
+ val = '#' + val;
223
+ }
224
+
225
+ if (val !== value) {
226
+ onChange(val);
227
+ }
228
+ }
229
+ }, [onChange, value]);
230
+ var handleOpacityChange = (0, _react.useCallback)(function (_ref8) {
231
+ var inString = _ref8.value;
232
+ var val = inString;
233
+
234
+ if (typeof val === 'string') {
235
+ setOpacity(val);
236
+ }
237
+ }, []); // Contains logic to call onChange when opacity changes, update opacity
238
+ // when the value from props changes, and to reformat the opacity
239
+ // when the input is blurred. This is tricky because of the circular
240
+ // nature of opacity updates and the input color updates, especially
241
+ // when typing into the opacity field. You don't want to reformat the
242
+ // field while typing because it moves the cursor to the end.
243
+
244
+ var _useOpacityValueSync = (0, _hooks.useOpacityValueSync)(value, opacity, onChange, setOpacity),
245
+ handleOpacityBlur = _useOpacityValueSync.handleOpacityBlur,
246
+ handleOpacityFocus = _useOpacityValueSync.handleOpacityFocus; // Handle open/closed state of color picker popup
247
+
248
+
249
+ var _useClickOutsideToggl = (0, _hooks.useClickOutsideToggle)(),
250
+ _useClickOutsideToggl2 = _slicedToArray(_useClickOutsideToggl, 3),
251
+ state = _useClickOutsideToggl2[0],
252
+ wrapperRef = _useClickOutsideToggl2[1],
253
+ handleToggle = _useClickOutsideToggl2[2]; // Expands the input value if it is a condensed hex
254
+
255
+
256
+ var paletteColor = (0, _utils.rgbaToHexa)((0, _utils.hexaToRgba)(value));
257
+ return (0, _jsxRuntime.jsxs)("div", {
258
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div"),
259
+ ref: wrapperRef,
260
+ css: _ref9,
261
+ children: [(0, _jsxRuntime.jsxs)(Button, {
262
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "button"),
263
+ "data-instrumentation": "".concat(dataInstru, " colorpicker-button"),
264
+ onClick: handleToggle,
265
+ plain: true,
266
+ children: [(0, _jsxRuntime.jsx)(Palette, {
267
+ "data-gs-c": gsC(paletteColor),
268
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "button", "palette"),
269
+ title: paletteColor,
270
+ color: paletteColor
271
+ }), label]
272
+ }), state === 'open' ? (0, _jsxRuntime.jsxs)(PickerWrapper, {
273
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper"),
274
+ children: [(0, _jsxRuntime.jsx)(_reactColorful.RgbaColorPicker, {
275
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "rgba-color-picker"),
276
+ color: (0, _utils.hexaToRgba)(value),
277
+ "data-instrumentation": "".concat(dataInstru, " colorpicker-colorpicker"),
278
+ onChange: handleRgbaChange
279
+ }), (0, _jsxRuntime.jsxs)(_Grid["default"], {
280
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid"),
281
+ columns: "auto auto",
282
+ gap: ".5rem .25rem",
283
+ children: [(0, _jsxRuntime.jsx)(Item, {
284
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid", "item"),
285
+ children: (0, _jsxRuntime.jsx)(Label, {
286
+ "data-gs-c": gsC("Hex"),
287
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid", "item", "label"),
288
+ htmlFor: "hex-color",
289
+ children: "Hex"
290
+ })
291
+ }), (0, _jsxRuntime.jsx)(Item, {
292
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid", "item"),
293
+ children: (0, _jsxRuntime.jsx)(Input, {
294
+ "data-gs-c": gsC("hex-color", value),
295
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid", "item", "input"),
296
+ "data-instrumentation": "".concat(dataInstru, " colorpicker-hexinput"),
297
+ maxLength: 9 // #rrggbbaa
298
+ ,
299
+ name: "hex-color",
300
+ onChange: handleHexaChange,
301
+ type: "text",
302
+ value: value
303
+ })
304
+ }), (0, _jsxRuntime.jsx)(Item, {
305
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid", "item"),
306
+ children: (0, _jsxRuntime.jsx)(Label, {
307
+ "data-gs-c": gsC("Opacity"),
308
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid", "item", "label"),
309
+ htmlFor: "opacity",
310
+ children: "Opacity"
311
+ })
312
+ }), (0, _jsxRuntime.jsx)(Item, {
313
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid", "item"),
314
+ children: (0, _jsxRuntime.jsx)(Input, {
315
+ "data-gs-c": gsC("opacity", opacity),
316
+ "data-gs": gs("src", "colorpicker", "colorpicker.tsx", "color-picker", "div", "picker-wrapper", "grid", "item", "input"),
317
+ "data-instrumentation": "".concat(dataInstru, " colorpicker-opacityinput"),
318
+ maxLength: 5 // 99.9%
319
+ ,
320
+ name: "opacity",
321
+ onChange: handleOpacityChange,
322
+ type: "text",
323
+ value: opacity,
324
+ onFocus: handleOpacityFocus,
325
+ onBlur: handleOpacityBlur
326
+ })
327
+ })]
328
+ })]
329
+ }) : null]
330
+ });
331
+ }
@@ -0,0 +1,13 @@
1
+ import { RefObject } from 'react';
2
+ declare type State = 'open' | 'closed';
3
+ export declare function useClickOutsideToggle(): [
4
+ State,
5
+ RefObject<HTMLDivElement>,
6
+ () => void
7
+ ];
8
+ export declare function useOpacityValueSync(value: string, opacity: string, onChange: (value: string) => void, setOpacity: (opacity: string) => void): {
9
+ handleOpacityFocus: () => void;
10
+ handleOpacityBlur: () => void;
11
+ };
12
+ export {};
13
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.useClickOutsideToggle = useClickOutsideToggle;
7
+ exports.useOpacityValueSync = useOpacityValueSync;
8
+
9
+ var _react = require("react");
10
+
11
+ var _useOnclickoutside = _interopRequireDefault(require("use-onclickoutside"));
12
+
13
+ var _utils = require("./utils");
14
+
15
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
16
+
17
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
18
+
19
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
20
+
21
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
22
+
23
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
24
+
25
+ function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
26
+
27
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
28
+
29
+ if (typeof window !== "undefined" && !window.gs) window.gs = function () {};
30
+ if (typeof window !== "undefined" && !window.gsC) window.gsC = function () {};
31
+
32
+ // Returns an open/closed state, a ref to attach a clickoutide event to,
33
+ // and a function that toggles the state. Pass the function to a button,
34
+ // and the ref to a div above the button and the component you want to toggle
35
+ function useClickOutsideToggle() {
36
+ var wrapperRef = (0, _react.useRef)(null);
37
+
38
+ var _useState = (0, _react.useState)('closed'),
39
+ _useState2 = _slicedToArray(_useState, 2),
40
+ state = _useState2[0],
41
+ setState = _useState2[1];
42
+
43
+ var handleToggle = (0, _react.useCallback)(function () {
44
+ setState(state === 'open' ? 'closed' : 'open');
45
+ }, [state]);
46
+ (0, _useOnclickoutside["default"])(wrapperRef, function () {
47
+ return setState('closed');
48
+ });
49
+ return [state, wrapperRef, handleToggle];
50
+ }
51
+
52
+ function useOpacityValueSync(value, opacity, onChange, setOpacity) {
53
+ var oldValue = (0, _react.useRef)(value);
54
+ var oldOpacity = (0, _react.useRef)(opacity);
55
+ var opacityFocussed = (0, _react.useRef)(false);
56
+ (0, _react.useEffect)(function () {
57
+ var fl = (0, _utils.opacityToA)(opacity);
58
+ var rgba = (0, _utils.hexaToRgba)(value); // Editing the opacity field
59
+ // If the value has changed and it's different to the alpha you
60
+ // get from the color value passed in then call onChange
61
+
62
+ if (opacity !== oldOpacity.current) {
63
+ if (rgba.a !== fl) {
64
+ rgba.a = fl;
65
+ var hexa = (0, _utils.rgbaToHexa)(rgba);
66
+
67
+ if (hexa !== value) {
68
+ onChange(hexa);
69
+ oldValue.current = hexa;
70
+ oldOpacity.current = opacity;
71
+ }
72
+ }
73
+ } // Editing the value/recieving new props
74
+ // If the color has changed and we're not editing the opacity
75
+ // If the opacity from the new value is different to the opacity
76
+ // we already have then update it
77
+
78
+
79
+ if (value !== oldValue.current && !opacityFocussed.current) {
80
+ var newOpacity = (0, _utils.opacityFromHexa)(value);
81
+
82
+ if (opacity !== newOpacity) {
83
+ setOpacity(newOpacity);
84
+ oldValue.current = value;
85
+ oldOpacity.current = newOpacity;
86
+ }
87
+ }
88
+ }, [onChange, opacity, setOpacity, value]); // So we know when we're editing the opacity and can prevent
89
+ // updates to it from elsewhere
90
+
91
+ var handleOpacityFocus = (0, _react.useCallback)(function () {
92
+ opacityFocussed.current = true;
93
+ }, [opacityFocussed]); // On blur we can sync the color value back into the opacity field
94
+
95
+ var handleOpacityBlur = (0, _react.useCallback)(function () {
96
+ opacityFocussed.current = false;
97
+ setOpacity((0, _utils.opacityFromHexa)(value));
98
+ }, [setOpacity, value]);
99
+ return {
100
+ handleOpacityFocus: handleOpacityFocus,
101
+ handleOpacityBlur: handleOpacityBlur
102
+ };
103
+ }
@@ -0,0 +1,2 @@
1
+ export { default } from './ColorPicker';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "default", {
7
+ enumerable: true,
8
+ get: function get() {
9
+ return _ColorPicker["default"];
10
+ }
11
+ });
12
+
13
+ var _ColorPicker = _interopRequireDefault(require("./ColorPicker"));
14
+
15
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
16
+
17
+ if (typeof window !== "undefined" && !window.gs) window.gs = function () {};
18
+ if (typeof window !== "undefined" && !window.gsC) window.gsC = function () {};
@@ -0,0 +1,7 @@
1
+ export declare type RGBA = {
2
+ r: number;
3
+ g: number;
4
+ b: number;
5
+ a: number;
6
+ };
7
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ if (typeof window !== "undefined" && !window.gs) window.gs = function () {};
7
+ if (typeof window !== "undefined" && !window.gsC) window.gsC = function () {};
@@ -0,0 +1,6 @@
1
+ import type { RGBA } from './types';
2
+ export declare function opacityFromHexa(hexa: string): string;
3
+ export declare function opacityToA(opacity: string): number;
4
+ export declare function rgbaToHexa(rgba: RGBA): string;
5
+ export declare function hexaToRgba(hex: string): RGBA;
6
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1,148 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.hexaToRgba = hexaToRgba;
7
+ exports.opacityFromHexa = opacityFromHexa;
8
+ exports.opacityToA = opacityToA;
9
+ exports.rgbaToHexa = rgbaToHexa;
10
+
11
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
12
+
13
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
14
+
15
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
16
+
17
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }
18
+
19
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
20
+
21
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
22
+
23
+ if (typeof window !== "undefined" && !window.gs) window.gs = function () {};
24
+ if (typeof window !== "undefined" && !window.gsC) window.gsC = function () {};
25
+ // Opacity values fixed to three decimal places
26
+ var OPACITY_FIXED = 3; // Convert an 8bit number to a hex string
27
+ // 0-255 -> 00-ff
28
+
29
+ function itohex(number) {
30
+ return number.toString(16).padStart(2, '0');
31
+ } // Convert an rgba object to a #rrggbbaa string
32
+ // However, a is 0.0-1.0
33
+
34
+
35
+ function _rgbaToHexa(rgba) {
36
+ return "#".concat(itohex(rgba.r)).concat(itohex(rgba.g)).concat(itohex(rgba.b)).concat(itohex(Math.round(255 * rgba.a)));
37
+ } // Wraps parseInt but returns 0 instead of NaN
38
+
39
+
40
+ function safeParseHex(str) {
41
+ var num = parseInt(str, 16);
42
+
43
+ if (Number.isNaN(num)) {
44
+ return 0;
45
+ }
46
+
47
+ return num;
48
+ } // Converts a valid hex string to an RGBA object
49
+
50
+
51
+ function _hexaToRgba(hexa) {
52
+ if (hexa[0] === '#') {
53
+ hexa = hexa.substring(1);
54
+ } // rgb shorthand
55
+
56
+
57
+ if (hexa.length === 3) {
58
+ var _ref = _toConsumableArray(hexa),
59
+ r = _ref[0],
60
+ g = _ref[1],
61
+ b = _ref[2];
62
+
63
+ hexa = [r, r, g, g, b, b, 'f', 'f'].join('');
64
+ } // rrggbb without alpha
65
+
66
+
67
+ if (hexa.length === 6) {
68
+ hexa += 'ff';
69
+ }
70
+
71
+ return {
72
+ r: safeParseHex(hexa.substring(0, 2)),
73
+ g: safeParseHex(hexa.substring(2, 4)),
74
+ b: safeParseHex(hexa.substring(4, 6)),
75
+ a: parseFloat((safeParseHex(hexa.substring(6, 8)) / 255).toFixed(OPACITY_FIXED))
76
+ };
77
+ } // Converts #rrggbbaa into decimal between 0 and 100,
78
+ // Supporting up to 3 decimal places, but removing any trailing zeros
79
+ // and appends a percent sign
80
+ // e.g. 0% 25.5% 66.666%
81
+
82
+
83
+ function opacityFromHexa(hexa) {
84
+ return (hexaToRgba(hexa).a * 100).toFixed(OPACITY_FIXED).replace(/\.?0+%?$/, '') + '%';
85
+ } // Converts an opacity string, which is a decimal number between 0 and 100
86
+ // with a trailing percent sign, into a value between 0.0 and 1.0
87
+ // If the value is outside of those bounds it is clamped
88
+ // If the parsing fails it returns 1.0
89
+
90
+
91
+ function opacityToA(opacity) {
92
+ var str = opacity;
93
+ str = str.replace(/%/g, ''); // remove all % signs
94
+
95
+ var fl = parseFloat(str);
96
+ fl = fl / 100; // opacity input is 0-100, RGBA is 0.0 - 1.0
97
+
98
+ fl = parseFloat(fl.toFixed(OPACITY_FIXED)); // we only keep 3 decimal places
99
+
100
+ if (Number.isNaN(fl)) {
101
+ fl = 1.0;
102
+ }
103
+
104
+ if (fl < 0) {
105
+ fl = 0.0;
106
+ }
107
+
108
+ if (fl > 1) {
109
+ fl = 1.0;
110
+ }
111
+
112
+ return fl;
113
+ } // Converts an RGBA string to a hexa string but will remove
114
+ // the alpha if it is not used
115
+
116
+
117
+ function rgbaToHexa(rgba) {
118
+ var hexa = _rgbaToHexa(rgba); // If #rrggbbaa and fully opaque remove the alpha
119
+ // and just display #rrggbb
120
+
121
+
122
+ if (hexa.length === 9 && hexa.toLowerCase().endsWith('ff')) {
123
+ hexa = hexa.replace(/ff$/i, '');
124
+ }
125
+
126
+ return hexa;
127
+ } // Wraps _hexaToRgba but will return #000 in RGBA if the string doesn't
128
+ // seem to be a valid hex string: #rgb, #rrggbb, or #rrggbbaa
129
+
130
+
131
+ function hexaToRgba(hex) {
132
+ // Only if the value resembles a valid hex
133
+ if (hex.startsWith('#')) {
134
+ var val = hex.trim();
135
+ var len = val.length; // #rrggbbaa || #rrggbb || #rgb
136
+
137
+ if (len === 9 || len === 7 || len === 4) {
138
+ return _hexaToRgba(val);
139
+ }
140
+ }
141
+
142
+ return {
143
+ r: 0,
144
+ g: 0,
145
+ b: 0,
146
+ a: 1
147
+ };
148
+ }
@@ -48,7 +48,7 @@ var FILTER_OPERATOR_LOGIC = (_FILTER_OPERATOR_LOGI = {}, _defineProperty(_FILTER
48
48
  }), _defineProperty(_FILTER_OPERATOR_LOGI, _constants.OPERATORS.AFTER_DATE, function (_ref3) {
49
49
  var value = _ref3.value,
50
50
  filter = _ref3.filter;
51
- return value && (0, _dateFns.isAfter)(valueToDate(value), valueToDate(filter));
51
+ return value && !(0, _dateFns.isSameDay)(valueToDate(value), valueToDate(filter)) && (0, _dateFns.isAfter)(valueToDate(value), valueToDate(filter));
52
52
  }), _defineProperty(_FILTER_OPERATOR_LOGI, _constants.OPERATORS.ON_AFTER_DATE, function (_ref4) {
53
53
  var value = _ref4.value,
54
54
  filter = _ref4.filter;
@@ -62,7 +62,7 @@ var FILTER_OPERATOR_LOGIC = (_FILTER_OPERATOR_LOGI = {}, _defineProperty(_FILTER
62
62
  }), _defineProperty(_FILTER_OPERATOR_LOGI, _constants.OPERATORS.BEFORE_DATE, function (_ref5) {
63
63
  var value = _ref5.value,
64
64
  filter = _ref5.filter;
65
- return value && (0, _dateFns.isBefore)(valueToDate(value), valueToDate(filter));
65
+ return value && !(0, _dateFns.isSameDay)(valueToDate(value), valueToDate(filter)) && (0, _dateFns.isBefore)(valueToDate(value), valueToDate(filter));
66
66
  }), _defineProperty(_FILTER_OPERATOR_LOGI, _constants.OPERATORS.ON_BEFORE_DATE, function (_ref6) {
67
67
  var value = _ref6.value,
68
68
  filter = _ref6.filter;
@@ -114,7 +114,7 @@ export declare const DateFormControl: import("@emotion/styled").StyledComponent<
114
114
  labelWidth?: string | number | undefined;
115
115
  inputCss?: import("@emotion/serialize").Interpolation<any>;
116
116
  options?: any;
117
- } & import("../FormControl/components/CheckboxGroup").CheckboxGroupProps, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "options" | "isClearable" | "warning" | "showFullLabel" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>) | (Pick<{
117
+ } & import("../FormControl/components/CheckboxGroup").CheckboxGroupProps, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "showFullLabel" | "options" | "isClearable" | "warning" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>) | (Pick<{
118
118
  addOnClassName?: string | undefined;
119
119
  blockLabel?: boolean | undefined;
120
120
  'data-gs-c'?: Function | undefined;
@@ -170,7 +170,7 @@ export declare const DateFormControl: import("@emotion/styled").StyledComponent<
170
170
  labelWidth?: string | number | undefined;
171
171
  inputCss?: import("@emotion/serialize").Interpolation<any>;
172
172
  options?: any;
173
- } & import("../FormControl/components/RadioGroup").RadioGroupProps, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "options" | "isClearable" | "warning" | "showFullLabel" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>) | (Pick<{
173
+ } & import("../FormControl/components/RadioGroup").RadioGroupProps, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "showFullLabel" | "options" | "isClearable" | "warning" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>) | (Pick<{
174
174
  addOnClassName?: string | undefined;
175
175
  blockLabel?: boolean | undefined;
176
176
  'data-gs-c'?: Function | undefined;
@@ -198,7 +198,7 @@ export declare const DateFormControl: import("@emotion/styled").StyledComponent<
198
198
  labelWidth?: string | number | undefined;
199
199
  inputCss?: import("@emotion/serialize").Interpolation<any>;
200
200
  options?: any;
201
- } & Omit<import("../Input").InputProps<"number" | "textarea" | "text" | "url" | "email" | "datetime-local" | "password">, "label">, "form" | "style" | "title" | "pattern" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "lang" | "placeholder" | "slot" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "readOnly" | "checked" | "height" | "width" | "wrap" | "inline" | "rows" | "max" | "min" | "crossOrigin" | "autoFocus" | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "list" | "step" | "multiple" | "accept" | "alt" | "autoComplete" | "capture" | "maxLength" | "minLength" | "src" | "cols" | "dirName" | "variant" | "inputRef"> & Partial<Pick<{
201
+ } & Omit<import("../Input").InputProps<"number" | "textarea" | "text" | "url" | "email" | "datetime-local" | "password">, "label">, "form" | "style" | "title" | "pattern" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "lang" | "placeholder" | "slot" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "readOnly" | "checked" | "height" | "width" | "wrap" | "inline" | "rows" | "max" | "min" | "crossOrigin" | "autoFocus" | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "list" | "step" | "multiple" | "accept" | "alt" | "autoComplete" | "capture" | "maxLength" | "minLength" | "src" | "variant" | "cols" | "dirName" | "inputRef"> & Partial<Pick<{
202
202
  addOnClassName?: string | undefined;
203
203
  blockLabel?: boolean | undefined;
204
204
  'data-gs-c'?: Function | undefined;
@@ -226,7 +226,7 @@ export declare const DateFormControl: import("@emotion/styled").StyledComponent<
226
226
  labelWidth?: string | number | undefined;
227
227
  inputCss?: import("@emotion/serialize").Interpolation<any>;
228
228
  options?: any;
229
- } & Omit<import("../Input").InputProps<"number" | "textarea" | "text" | "url" | "email" | "datetime-local" | "password">, "label">, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "options" | "isClearable" | "warning" | "showFullLabel" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>)) & {
229
+ } & Omit<import("../Input").InputProps<"number" | "textarea" | "text" | "url" | "email" | "datetime-local" | "password">, "label">, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "showFullLabel" | "options" | "isClearable" | "warning" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>)) & {
230
230
  theme?: import("@emotion/react").Theme | undefined;
231
231
  }) & {
232
232
  variant: string;
@@ -93,7 +93,7 @@ export declare const TimeFormControl: import("@emotion/styled").StyledComponent<
93
93
  labelWidth?: string | number | undefined;
94
94
  inputCss?: import("@emotion/serialize").Interpolation<any>;
95
95
  options?: any;
96
- } & import("../FormControl/components/CheckboxGroup").CheckboxGroupProps, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "options" | "isClearable" | "warning" | "showFullLabel" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>) | (Pick<{
96
+ } & import("../FormControl/components/CheckboxGroup").CheckboxGroupProps, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "showFullLabel" | "options" | "isClearable" | "warning" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>) | (Pick<{
97
97
  addOnClassName?: string | undefined;
98
98
  blockLabel?: boolean | undefined;
99
99
  'data-gs-c'?: Function | undefined;
@@ -149,7 +149,7 @@ export declare const TimeFormControl: import("@emotion/styled").StyledComponent<
149
149
  labelWidth?: string | number | undefined;
150
150
  inputCss?: import("@emotion/serialize").Interpolation<any>;
151
151
  options?: any;
152
- } & import("../FormControl/components/RadioGroup").RadioGroupProps, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "options" | "isClearable" | "warning" | "showFullLabel" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>) | (Pick<{
152
+ } & import("../FormControl/components/RadioGroup").RadioGroupProps, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "showFullLabel" | "options" | "isClearable" | "warning" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>) | (Pick<{
153
153
  addOnClassName?: string | undefined;
154
154
  blockLabel?: boolean | undefined;
155
155
  'data-gs-c'?: Function | undefined;
@@ -177,7 +177,7 @@ export declare const TimeFormControl: import("@emotion/styled").StyledComponent<
177
177
  labelWidth?: string | number | undefined;
178
178
  inputCss?: import("@emotion/serialize").Interpolation<any>;
179
179
  options?: any;
180
- } & Omit<import("../Input").InputProps<"number" | "textarea" | "text" | "url" | "email" | "datetime-local" | "password">, "label">, "form" | "style" | "title" | "pattern" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "lang" | "placeholder" | "slot" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "readOnly" | "checked" | "height" | "width" | "wrap" | "inline" | "rows" | "max" | "min" | "crossOrigin" | "autoFocus" | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "list" | "step" | "multiple" | "accept" | "alt" | "autoComplete" | "capture" | "maxLength" | "minLength" | "src" | "cols" | "dirName" | "variant" | "inputRef"> & Partial<Pick<{
180
+ } & Omit<import("../Input").InputProps<"number" | "textarea" | "text" | "url" | "email" | "datetime-local" | "password">, "label">, "form" | "style" | "title" | "pattern" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "lang" | "placeholder" | "slot" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "readOnly" | "checked" | "height" | "width" | "wrap" | "inline" | "rows" | "max" | "min" | "crossOrigin" | "autoFocus" | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "list" | "step" | "multiple" | "accept" | "alt" | "autoComplete" | "capture" | "maxLength" | "minLength" | "src" | "variant" | "cols" | "dirName" | "inputRef"> & Partial<Pick<{
181
181
  addOnClassName?: string | undefined;
182
182
  blockLabel?: boolean | undefined;
183
183
  'data-gs-c'?: Function | undefined;
@@ -205,7 +205,7 @@ export declare const TimeFormControl: import("@emotion/styled").StyledComponent<
205
205
  labelWidth?: string | number | undefined;
206
206
  inputCss?: import("@emotion/serialize").Interpolation<any>;
207
207
  options?: any;
208
- } & Omit<import("../Input").InputProps<"number" | "textarea" | "text" | "url" | "email" | "datetime-local" | "password">, "label">, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "options" | "isClearable" | "warning" | "showFullLabel" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>)) & {
208
+ } & Omit<import("../Input").InputProps<"number" | "textarea" | "text" | "url" | "email" | "datetime-local" | "password">, "label">, "value" | "label" | "className" | "id" | "onChange" | "disabled" | "error" | "required" | "invalid" | "name" | "type" | "data-instrumentation" | "getRef" | "size" | "data-gs-c" | "labelWidth" | "showFullError" | "showFullHint" | "showFullInfo" | "showFullWarning" | "hint" | "info" | "hintNode" | "truncateErrors" | "truncateWarnings" | "showFullLabel" | "options" | "isClearable" | "warning" | "addOnClassName" | "valueCanBeNull" | "blockLabel" | "inputCss">> & Partial<Pick<Partial<import("../FormControl").FormControlProps<"text">>, never>>)) & {
209
209
  theme?: import("@emotion/react").Theme | undefined;
210
210
  }) & {
211
211
  variant?: "primary" | "secondary" | undefined;
@@ -8,7 +8,7 @@ export declare type TimeFieldProps = Omit<FormFieldProps<'text'>, 'type' | 'valu
8
8
  export declare const TimeField: ({ error, name, value, ...props }: TimeFieldProps) => import("@emotion/react/jsx-runtime").JSX.Element;
9
9
  declare const _default: import("react").FC<Pick<Omit<FormFieldProps<"text">, "value" | "type"> & {
10
10
  value: string;
11
- }, "value" | "form" | "label" | "style" | "title" | "pattern" | "className" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "id" | "lang" | "placeholder" | "slot" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "disabled" | "readOnly" | "checked" | "error" | "required" | "invalid" | "height" | "width" | "wrap" | "inline" | "name" | "data-instrumentation" | "getRef" | "rows" | "size" | "max" | "min" | "crossOrigin" | "autoFocus" | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "data-gs-c" | "list" | "step" | "tooltip" | "multiple" | "accept" | "alt" | "autoComplete" | "capture" | "maxLength" | "minLength" | "src" | "showAddOnInTooltip" | "showFullError" | "showFullHint" | "hint" | "hintNode" | "truncateErrors" | "hideAddOn" | "cols" | "dirName" | "variant" | "inputRef" | "isClearable" | "addOnClassName" | "tooltipClassName" | "valueCanBeNull"> & {
11
+ }, "value" | "form" | "label" | "style" | "title" | "pattern" | "className" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "id" | "lang" | "placeholder" | "slot" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "disabled" | "readOnly" | "checked" | "error" | "required" | "invalid" | "height" | "width" | "wrap" | "inline" | "name" | "data-instrumentation" | "getRef" | "rows" | "size" | "max" | "min" | "crossOrigin" | "autoFocus" | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "data-gs-c" | "list" | "step" | "tooltip" | "multiple" | "accept" | "alt" | "autoComplete" | "capture" | "maxLength" | "minLength" | "src" | "showAddOnInTooltip" | "showFullError" | "showFullHint" | "hint" | "hintNode" | "truncateErrors" | "hideAddOn" | "variant" | "cols" | "dirName" | "inputRef" | "isClearable" | "addOnClassName" | "tooltipClassName" | "valueCanBeNull"> & {
12
12
  theme?: import("@emotion/react").Theme | undefined;
13
13
  }>;
14
14
  export default _default;
@@ -11,6 +11,7 @@ import Checkbox from './Checkbox';
11
11
  import CheckboxField from './CheckboxField';
12
12
  import CollapsibleToggle from './CollapsibleToggle';
13
13
  import Column from './Column';
14
+ import ColorPicker from './ColorPicker';
14
15
  import ComparisonChart from './ComparisonChart';
15
16
  import ComponentGroup from './ComponentGroup';
16
17
  import DataGrid from './DataGrid';
@@ -97,5 +98,5 @@ export type { DatePickerProps };
97
98
  export type { SelectComponentStyles };
98
99
  export type { Theme, AccessibilityOptions };
99
100
  export { BADGE_TYPES } from './Badge';
100
- export { ActionBar, Badge, BarChart, Box, Button, Canvas, Card, ChartPrimitives, Checkbox, CheckboxField, CollapsibleToggle, Column, ComparisonChart, ComponentGroup, DataGrid, DateControl, DateField, DatePicker, DatePickerUtils, DetailPanel, DistributionChart, Drawer, DropdownButton, FileInput, FormControl, FormField, FormFieldAddon, FormLabel, FormModal, Grid, GridItem, GrowthRateChart, Heading, Highlighter, Histogram, Icon, IconBar, InfiniteList, Input, LeftTruncatedText, Link, Loader, Logo, Menu, MiddleTruncatedText, Modal, MultiSelect, NavigationBar, NavigationPopover, Overlay, Paragraph, Popover, Radio, RightTruncatedText, Row, SecondaryNavigation, Section, Select, Shuttle, SimpleModal, Slider, StatCard, TREE_UTILS, Tabs, Tagger, Text, ThemeProvider, TimeControl, TimeField, TimePicker, Toast, Toggle, TooltipPopover, Tree, UserAvatar, View, VisuallyHidden, VolumeChart, theme };
101
+ export { ActionBar, Badge, BarChart, Box, Button, Canvas, Card, ChartPrimitives, Checkbox, CheckboxField, CollapsibleToggle, Column, ColorPicker, ComparisonChart, ComponentGroup, DataGrid, DateControl, DateField, DatePicker, DatePickerUtils, DetailPanel, DistributionChart, Drawer, DropdownButton, FileInput, FormControl, FormField, FormFieldAddon, FormLabel, FormModal, Grid, GridItem, GrowthRateChart, Heading, Highlighter, Histogram, Icon, IconBar, InfiniteList, Input, LeftTruncatedText, Link, Loader, Logo, Menu, MiddleTruncatedText, Modal, MultiSelect, NavigationBar, NavigationPopover, Overlay, Paragraph, Popover, Radio, RightTruncatedText, Row, SecondaryNavigation, Section, Select, Shuttle, SimpleModal, Slider, StatCard, TREE_UTILS, Tabs, Tagger, Text, ThemeProvider, TimeControl, TimeField, TimePicker, Toast, Toggle, TooltipPopover, Tree, UserAvatar, View, VisuallyHidden, VolumeChart, theme };
101
102
  //# sourceMappingURL=index.d.ts.map
package/dist/es/index.js CHANGED
@@ -83,6 +83,12 @@ Object.defineProperty(exports, "CollapsibleToggle", {
83
83
  return _CollapsibleToggle["default"];
84
84
  }
85
85
  });
86
+ Object.defineProperty(exports, "ColorPicker", {
87
+ enumerable: true,
88
+ get: function get() {
89
+ return _ColorPicker["default"];
90
+ }
91
+ });
86
92
  Object.defineProperty(exports, "Column", {
87
93
  enumerable: true,
88
94
  get: function get() {
@@ -582,6 +588,8 @@ var _CollapsibleToggle = _interopRequireDefault(require("./CollapsibleToggle"));
582
588
 
583
589
  var _Column = _interopRequireDefault(require("./Column"));
584
590
 
591
+ var _ColorPicker = _interopRequireDefault(require("./ColorPicker"));
592
+
585
593
  var _ComparisonChart = _interopRequireDefault(require("./ComparisonChart"));
586
594
 
587
595
  var _ComponentGroup = _interopRequireDefault(require("./ComponentGroup"));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "td-stylekit",
3
- "version": "26.1.3",
3
+ "version": "26.2.0",
4
4
  "main": "dist/es/index.js",
5
5
  "module": "dist/es/index.js",
6
6
  "types": "dist/es/index.d.ts",
@@ -56,6 +56,7 @@
56
56
  "keymirror": "^0.1.1",
57
57
  "lodash.clamp": "^4.0.3",
58
58
  "lodash.curry": "^4.1.1",
59
+ "lodash.debounce": "^4.0.8",
59
60
  "lodash.has": "^4.5.2",
60
61
  "lodash.includes": "^4.3.0",
61
62
  "lodash.isempty": "^4.4.0",
@@ -73,6 +74,7 @@
73
74
  "parse-unit": "^1.0.1",
74
75
  "rc-slider": "^9.7.2",
75
76
  "react-click-outside": "^3.0.1",
77
+ "react-colorful": "^5.5.1",
76
78
  "react-day-picker": "7.3.2",
77
79
  "react-highlight-words": "^0.16.0",
78
80
  "react-middle-ellipsis": "^1.0.12",
@@ -119,6 +121,7 @@
119
121
  "@types/jest": "^25.1.3",
120
122
  "@types/lodash.clamp": "^4.0.6",
121
123
  "@types/lodash.curry": "^4.1.6",
124
+ "@types/lodash.debounce": "^4",
122
125
  "@types/lodash.has": "^4.5.6",
123
126
  "@types/lodash.includes": "^4.3.6",
124
127
  "@types/lodash.isempty": "^4.4.6",