td-stylekit 28.40.4 → 28.41.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.
Files changed (40) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/dist/es/BarChart/BarChart.js +1 -7
  3. package/dist/es/Checkbox/Checkbox.js +7 -7
  4. package/dist/es/CheckboxField/CheckboxField.d.ts +0 -4
  5. package/dist/es/CheckboxField/CheckboxField.js +2 -6
  6. package/dist/es/DataGrid/DataGrid.d.ts +0 -4
  7. package/dist/es/DataGrid/DataGrid.js +2 -7
  8. package/dist/es/DataGrid/elements.d.ts +1 -1
  9. package/dist/es/DateControl/DateControl.js +0 -2
  10. package/dist/es/DateField/DateField.d.ts +2 -6
  11. package/dist/es/DateField/DateField.js +1 -8
  12. package/dist/es/DropdownButton/DropdownButton.d.ts +0 -4
  13. package/dist/es/DropdownButton/DropdownButton.js +1 -6
  14. package/dist/es/FormControl/FormControl.d.ts +0 -4
  15. package/dist/es/FormControl/FormControl.js +1 -6
  16. package/dist/es/FormField/FormField.d.ts +0 -4
  17. package/dist/es/FormField/FormField.js +1 -6
  18. package/dist/es/FormModal/FormModal.js +56 -59
  19. package/dist/es/Input/Input.d.ts +1 -1
  20. package/dist/es/Input/Input.js +36 -14
  21. package/dist/es/Overlay/OverlayHeader.js +5 -7
  22. package/dist/es/Select/Select.d.ts +1 -1
  23. package/dist/es/Select/variantProps.d.ts +1 -1
  24. package/dist/es/Select/variantProps.js +26 -4
  25. package/dist/es/SimpleModal/SimpleModal.js +37 -40
  26. package/dist/es/Slider/elements.d.ts +1 -1
  27. package/dist/es/Slider/elements.js +3 -4
  28. package/dist/es/Tagger/Tagger.d.ts +8 -2
  29. package/dist/es/Tagger/components/PopupSelectorElements.d.ts +1 -1
  30. package/dist/es/Tagger/variantProps.d.ts +9 -3
  31. package/dist/es/Tagger/variantProps.js +44 -23
  32. package/dist/es/ThemeProvider/v4/CollapsibleToggle.d.ts +4 -1
  33. package/dist/es/TimeControl/TimeControl.js +0 -1
  34. package/dist/es/TimeControl/elements.js +3 -4
  35. package/dist/es/TimeControl/utils.js +0 -1
  36. package/dist/es/TimePicker/TimePicker.js +0 -1
  37. package/dist/es/TimePicker/components/PeriodSelector.js +5 -6
  38. package/dist/es/TimePicker/components/Spinner.js +1 -2
  39. package/dist/es/TimePicker/utils.js +0 -1
  40. package/package.json +3 -3
package/CHANGELOG.md CHANGED
@@ -1,3 +1,17 @@
1
+ # [28.41.0](https://github.com/treasure-data/td-stylekit/compare/v28.40.5...v28.41.0) (2024-06-19)
2
+
3
+
4
+ ### Features
5
+
6
+ * **CON-14995:** Add custom styling support to the Tagger component ([#1568](https://github.com/treasure-data/td-stylekit/issues/1568)) ([72d1472](https://github.com/treasure-data/td-stylekit/commit/72d1472093e443a1ecdea8131bb0df2a26570998))
7
+
8
+ ## [28.40.5](https://github.com/treasure-data/td-stylekit/compare/v28.40.4...v28.40.5) (2024-06-17)
9
+
10
+
11
+ ### Bug Fixes
12
+
13
+ * **CON-16172:** Fix checkbox colors ([#1576](https://github.com/treasure-data/td-stylekit/issues/1576)) ([1fd95bc](https://github.com/treasure-data/td-stylekit/commit/1fd95bc835f8f31af07f0332545f5443e736e18e))
14
+
1
15
  ## [28.40.4](https://github.com/treasure-data/td-stylekit/compare/v28.40.3...v28.40.4) (2024-06-14)
2
16
 
3
17
 
@@ -24,10 +24,6 @@ if (typeof window !== "undefined" && !window.gs) window.gs = function () {};
24
24
  if (typeof window !== "undefined" && !window.gsC) window.gsC = function () {};
25
25
  function BarChart(props) {
26
26
  var _chartTheme$axis, _chartTheme$axis$styl;
27
- /**
28
- * @typescript-eslint/no-unused-vars is added because even though the props are not used in this component
29
- * they are getting destructured into ...props and passed further down the tree
30
- */
31
27
  var _props$animate = props.animate,
32
28
  animate = _props$animate === void 0 ? _ChartPrimitives.chartUtils.ANIMATE : _props$animate,
33
29
  _props$barColor = props.barColor,
@@ -177,9 +173,7 @@ function BarChart(props) {
177
173
  "data-gs": gs("src", "barchart", "barchart.tsx", "bar-chart", "container", "victory-chart"),
178
174
  animate: animate,
179
175
  width: width,
180
- height: height
181
- // @ts-ignore: ignoring for now resolve in CON-6725
182
- ,
176
+ height: height,
183
177
  domain: domain,
184
178
  domainPadding: domainPadding || _domainPadding,
185
179
  padding: padding,
@@ -63,7 +63,7 @@ var Wrapper = /*#__PURE__*/(0, _base["default"])('label', process.env.NODE_ENV =
63
63
  return disabled ? {
64
64
  cursor: 'not-allowed'
65
65
  } : {};
66
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AAagB","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[4]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[4] : theme.palette.neutral[4],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
66
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AAagB","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[5]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[5] : theme.palette.neutral[6],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
67
67
  Wrapper.displayName = 'Label';
68
68
  var VisualCheckbox = /*#__PURE__*/(0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
69
69
  shouldForwardProp: function shouldForwardProp(prop) {
@@ -86,8 +86,8 @@ var VisualCheckbox = /*#__PURE__*/(0, _base["default"])('div', process.env.NODE_
86
86
  checked = _ref3.checked;
87
87
  return {
88
88
  alignItems: 'center',
89
- backgroundColor: checked ? theme.palette.primary[4] : theme.palette.neutral[0],
90
- borderColor: checked ? theme.palette.primary[4] : theme.palette.neutral[4],
89
+ backgroundColor: checked ? theme.palette.primary[5] : theme.palette.neutral[0],
90
+ borderColor: checked ? theme.palette.primary[5] : theme.palette.neutral[6],
91
91
  borderRadius: theme.radius[0],
92
92
  borderStyle: 'solid',
93
93
  borderWidth: theme.borderWidth[1],
@@ -121,7 +121,7 @@ var VisualCheckbox = /*#__PURE__*/(0, _base["default"])('div', process.env.NODE_
121
121
  backgroundColor: theme.palette.neutral[0],
122
122
  borderColor: theme.palette.neutral[checked ? 0 : 5]
123
123
  } : {};
124
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Checkbox.VisualCheckbox), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AA8CuB","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[4]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[4] : theme.palette.neutral[4],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
124
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Checkbox.VisualCheckbox), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AA8CuB","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[5]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[5] : theme.palette.neutral[6],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
125
125
  var Input = /*#__PURE__*/(0, _base["default"])('input', process.env.NODE_ENV === "production" ? {
126
126
  target: "engvdl52"
127
127
  } : {
@@ -160,7 +160,7 @@ var Input = /*#__PURE__*/(0, _base["default"])('input', process.env.NODE_ENV ===
160
160
  return disabled || readOnly ? {
161
161
  cursor: 'not-allowed'
162
162
  } : {};
163
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Checkbox.Input), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AA8Fc","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[4]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[4] : theme.palette.neutral[4],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
163
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Checkbox.Input), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AA8Fc","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[5]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[5] : theme.palette.neutral[6],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
164
164
  var Label = /*#__PURE__*/(0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
165
165
  target: "engvdl51"
166
166
  } : {
@@ -185,7 +185,7 @@ var Label = /*#__PURE__*/(0, _base["default"])('span', process.env.NODE_ENV ===
185
185
  return disabled ? {
186
186
  color: theme.palette.neutral[9]
187
187
  } : {};
188
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Checkbox.Label), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AA6Ic","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[4]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[4] : theme.palette.neutral[4],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
188
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Checkbox.Label), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AA6Ic","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[5]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[5] : theme.palette.neutral[6],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
189
189
  var CheckIcon = /*#__PURE__*/(0, _base["default"])(_Icon["default"].Small.SymbolThickCheck, process.env.NODE_ENV === "production" ? {
190
190
  target: "engvdl50"
191
191
  } : {
@@ -219,7 +219,7 @@ var CheckIcon = /*#__PURE__*/(0, _base["default"])(_Icon["default"].Small.Symbol
219
219
  bottom: '2px',
220
220
  color: theme.palette.primary[4]
221
221
  } : {};
222
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Checkbox.CheckIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AAyKkB","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[4]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[4] : theme.palette.neutral[4],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
222
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Checkbox.CheckIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Checkbox/Checkbox.tsx"],"names":[],"mappings":"AAyKkB","file":"../../../src/Checkbox/Checkbox.tsx","sourcesContent":["import { ReactNode, PureComponent } from 'react'\nimport styled from '@emotion/styled'\nimport { isPropValid } from '../utils'\nimport Icon from '../Icon'\nimport { getOverrides, Overridable } from '../ThemeProvider'\n\ntype WrapperProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n  checked?: boolean\n}\n\nconst Wrapper = styled('label')<WrapperProps>(\n  ({ theme, wrapLabel, disabled, readOnly }) => ({\n    alignItems: wrapLabel ? 'flex-start' : 'center',\n    cursor: disabled || readOnly ? 'not-allowed' : 'pointer',\n    display: 'flex',\n    flexDirection: 'row',\n    fontSize: theme.fontSize[1],\n    height: wrapLabel ? 'auto' : theme.space[5],\n    lineHeight: theme.lineHeight[5],\n    overflow: 'hidden',\n    position: 'relative',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    ':focus-within': {\n      overflow: 'visible'\n    }\n  }),\n  ({ disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {}\n)\nWrapper.displayName = 'Label'\n\ntype VisualCheckboxProps = {\n  label: boolean\n  disabled?: boolean\n  checked?: boolean\n  readOnly?: boolean\n}\n\nconst VisualCheckbox = styled('div', {\n  shouldForwardProp: (prop: string) => isPropValid(prop, { exclude: ['label'] })\n})<VisualCheckboxProps>(\n  ({ theme, label, checked }) => ({\n    alignItems: 'center',\n    backgroundColor: checked\n      ? theme.palette.primary[5]\n      : theme.palette.neutral[0],\n    borderColor: checked ? theme.palette.primary[5] : theme.palette.neutral[6],\n    borderRadius: theme.radius[0],\n    borderStyle: 'solid',\n    borderWidth: theme.borderWidth[1],\n    display: 'flex',\n    flex: '0 0 auto',\n    height: theme.space[4],\n    justifyContent: 'center',\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: label ? theme.space[2] : 0,\n    marginTop: theme.space[1],\n    position: 'relative',\n    width: theme.space[4],\n    cursor: 'pointer'\n  }),\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[3],\n          borderColor: theme.palette.neutral[5]\n        }\n      : {},\n  ({ theme, readOnly, disabled, checked }) =>\n    readOnly && !disabled\n      ? {\n          cursor: 'not-allowed',\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: theme.palette.neutral[checked ? 0 : 5]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.VisualCheckbox)\n)\n\ntype InputProps = {\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst Input = styled('input')<InputProps>(\n  ({ theme, readOnly }) => ({\n    borderRadius: theme.radius[0],\n    height: theme.space[3],\n    left: 0,\n    marginBottom: theme.space[1],\n    marginLeft: 0,\n    marginRight: theme.space[2],\n    marginTop: theme.space[1],\n    opacity: 0,\n    position: 'absolute',\n    top: 0,\n    width: theme.space[3],\n    zIndex: theme.zIndex.FormControl,\n    cursor: 'pointer',\n    ':disabled': {\n      cursor: 'not-allowed'\n    },\n    ':focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            boxShadow: `0px 0px 0px 3px ${theme.palette.primary[2]}`\n          }\n        : {}\n    },\n    ':not(:checked):focus +': {\n      [VisualCheckbox as any]: !readOnly\n        ? {\n            borderColor: theme.palette.neutral[6]\n          }\n        : {}\n    }\n  }),\n  ({ disabled, readOnly }) =>\n    disabled || readOnly\n      ? {\n          cursor: 'not-allowed'\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Input)\n)\n\ntype LabelProps = {\n  wrapLabel?: boolean\n  disabled?: boolean\n}\n\nconst Label = styled('span')<LabelProps>(\n  () => ({\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    textOverflow: 'ellipsis'\n  }),\n  ({ theme, wrapLabel }) =>\n    wrapLabel\n      ? {\n          whiteSpace: 'normal',\n          marginTop: theme.space[1]\n        }\n      : {},\n  ({ theme, disabled }) =>\n    disabled\n      ? {\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.Label)\n)\n\ntype CheckIconTypes = {\n  checked?: boolean\n  disabled?: boolean\n  readOnly?: boolean\n}\n\nconst CheckIcon = styled(Icon.Small.SymbolThickCheck)<CheckIconTypes>(\n  {\n    left: '1px',\n    bottom: '1px',\n    position: 'absolute',\n    opacity: 0,\n    cursor: 'pointer'\n  },\n  ({ theme }) => ({\n    height: theme.space[3],\n    width: theme.space[3],\n    color: theme.palette.neutral[0]\n  }),\n  ({ checked }) =>\n    checked\n      ? {\n          opacity: 1\n        }\n      : {},\n  ({ disabled, theme }) =>\n    disabled\n      ? {\n          cursor: 'not-allowed',\n          color: theme.palette.neutral[9]\n        }\n      : {},\n  ({ theme, readOnly }) =>\n    readOnly\n      ? {\n          cursor: 'not-allowed',\n          left: '2px',\n          bottom: '2px',\n          color: theme.palette.primary[4]\n        }\n      : {},\n  getOverrides(Overridable.Checkbox.CheckIcon)\n)\nCheckIcon.displayName = 'CheckIcon'\n\nexport type CheckboxProps = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  /** Text to display next to checkbox */\n  label: ReactNode\n  /** Name of input element */\n  name: string\n  title?: string\n  onChange: (arg0: { name: string; value: boolean }) => void\n  readOnly?: boolean\n  value: boolean\n  /**\n   * Wrap the label\n   */\n  wrapLabel?: boolean\n}\n\n/**\n * Renders a styled checkbox\n */\nclass Checkbox extends PureComponent<CheckboxProps> {\n  static defaultProps = {\n    disabled: false,\n    'data-instrumentation': 'checkbox'\n  }\n\n  _onChange = () => {\n    const { name, onChange, value } = this.props\n    onChange({ name, value: !value })\n  }\n\n  render() {\n    const {\n      className,\n      disabled,\n      label,\n      name,\n      readOnly,\n      title,\n      'data-instrumentation': dataInstrumentation,\n      value,\n      wrapLabel,\n      ...props\n    } = this.props\n\n    const getTitle = () => {\n      if (title) {\n        return title\n      }\n      if (typeof label === 'string') {\n        return label\n      }\n      return ''\n    }\n\n    return (\n      <Wrapper\n        className={className}\n        readOnly={readOnly}\n        disabled={disabled}\n        checked={value}\n        title={getTitle()}\n        wrapLabel={wrapLabel}\n      >\n        <Input\n          {...props}\n          checked={value}\n          disabled={!readOnly && disabled}\n          id={name}\n          name={name}\n          data-instrumentation={dataInstrumentation}\n          onChange={!readOnly ? this._onChange : undefined}\n          readOnly={readOnly}\n          type=\"checkbox\"\n        />\n        <VisualCheckbox\n          checked={!!value}\n          disabled={!readOnly && disabled}\n          label={!!label}\n          readOnly={readOnly}\n        >\n          <CheckIcon\n            checked={!!value}\n            disabled={!readOnly && disabled}\n            readOnly={readOnly}\n          />\n        </VisualCheckbox>\n        <Label disabled={!readOnly && disabled} wrapLabel={wrapLabel}>\n          {label}\n        </Label>\n      </Wrapper>\n    )\n  }\n}\n\nexport default Checkbox\n"]} */");
223
223
  CheckIcon.displayName = 'CheckIcon';
224
224
  /**
225
225
  * Renders a styled checkbox
@@ -8,10 +8,6 @@ export type CheckboxFieldProps = {
8
8
  hint?: string;
9
9
  hintNode?: React.ReactNode;
10
10
  } & CheckboxProps;
11
- /**
12
- * @typescript-eslint/no-unused-vars is added because even though the props are not used in this component
13
- * they are getting destructured into ...props and passed further down the tree
14
- */
15
11
  export declare const CheckboxField: React.FunctionComponent<React.PropsWithChildren<CheckboxFieldProps>>;
16
12
  export default CheckboxField;
17
13
  //# sourceMappingURL=CheckboxField.d.ts.map
@@ -33,7 +33,7 @@ var Container = /*#__PURE__*/(0, _base["default"])('div', process.env.NODE_ENV =
33
33
  } : {
34
34
  name: "1saxkct",
35
35
  styles: "align-items:stretch;display:flex;flex-flow:column nowrap;min-width:0;position:relative",
36
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9DaGVja2JveEZpZWxkL0NoZWNrYm94RmllbGQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1rQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQ2hlY2tib3hGaWVsZC9DaGVja2JveEZpZWxkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgZ2V0RXJyb3JMaXN0IH0gZnJvbSAnLi4vdXRpbHMnXG5pbXBvcnQgQ2hlY2tib3ggZnJvbSAnLi4vQ2hlY2tib3gnXG5pbXBvcnQgdHlwZSB7IENoZWNrYm94UHJvcHMgfSBmcm9tICcuLi9DaGVja2JveCdcbmltcG9ydCBGb3JtRmllbGRBZGRvbiBmcm9tICcuLi9Gb3JtRmllbGRBZGRvbidcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnKSh7XG4gIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBmbGV4RmxvdzogJ2NvbHVtbiBub3dyYXAnLFxuICBtaW5XaWR0aDogMCxcbiAgcG9zaXRpb246ICdyZWxhdGl2ZSdcbn0pXG5cbmNvbnN0IEFkZG9uID0gc3R5bGVkKEZvcm1GaWVsZEFkZG9uKTx7IG5vTGFiZWw6IGJvb2xlYW4gfT4oXG4gICh7IHRoZW1lLCBub0xhYmVsIH0pID0+ICh7XG4gICAgbWFyZ2luOiAwLFxuICAgIG1hcmdpbkxlZnQ6IG5vTGFiZWwgPyAwIDogdGhlbWUuc3BhY2VbNl1cbiAgfSlcbilcblxuZXhwb3J0IHR5cGUgQ2hlY2tib3hGaWVsZFByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtaW5zdHJ1bWVudGF0aW9uJz86IHN0cmluZ1xuICBlcnJvcj86IEFycmF5PHN0cmluZz4gfCBzdHJpbmdcbiAgaGlkZUFkZE9uPzogYm9vbGVhblxuICBoaW50Pzogc3RyaW5nXG4gIGhpbnROb2RlPzogUmVhY3QuUmVhY3ROb2RlXG59ICYgQ2hlY2tib3hQcm9wc1xuXG4vKipcbiAqICBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnMgaXMgYWRkZWQgYmVjYXVzZSBldmVuIHRob3VnaCB0aGUgcHJvcHMgYXJlIG5vdCB1c2VkIGluIHRoaXMgY29tcG9uZW50XG4gKiB0aGV5IGFyZSBnZXR0aW5nIGRlc3RydWN0dXJlZCBpbnRvIC4uLnByb3BzIGFuZCBwYXNzZWQgZnVydGhlciBkb3duIHRoZSB0cmVlXG4gKi9cbmV4cG9ydCBjb25zdCBDaGVja2JveEZpZWxkOiBSZWFjdC5GdW5jdGlvbkNvbXBvbmVudDxcbiAgUmVhY3QuUHJvcHNXaXRoQ2hpbGRyZW48Q2hlY2tib3hGaWVsZFByb3BzPlxuPiA9ICh7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgY2xhc3NOYW1lLFxuICBlcnJvcixcbiAgaGlkZUFkZE9uLFxuICBoaW50Tm9kZSxcbiAgaGludCxcbiAgLi4ucHJvcHNcbn06IENoZWNrYm94RmllbGRQcm9wcykgPT4ge1xuICBjb25zdCBlcnJvckxpc3QgPSBnZXRFcnJvckxpc3QoZXJyb3IpXG4gIHJldHVybiAoXG4gICAgPENvbnRhaW5lcj5cbiAgICAgIDxDaGVja2JveCB7Li4ucHJvcHN9IC8+XG4gICAgICB7aGlkZUFkZE9uIHx8IChcbiAgICAgICAgPEFkZG9uXG4gICAgICAgICAgZXJyb3JMaXN0PXtlcnJvckxpc3R9XG4gICAgICAgICAgaGludD17aGludH1cbiAgICAgICAgICBoaW50Tm9kZT17aGludE5vZGV9XG4gICAgICAgICAgbm9MYWJlbD17IXByb3BzLmxhYmVsfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L0NvbnRhaW5lcj5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBDaGVja2JveEZpZWxkXG4iXX0= */",
36
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9DaGVja2JveEZpZWxkL0NoZWNrYm94RmllbGQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1rQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQ2hlY2tib3hGaWVsZC9DaGVja2JveEZpZWxkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgZ2V0RXJyb3JMaXN0IH0gZnJvbSAnLi4vdXRpbHMnXG5pbXBvcnQgQ2hlY2tib3ggZnJvbSAnLi4vQ2hlY2tib3gnXG5pbXBvcnQgdHlwZSB7IENoZWNrYm94UHJvcHMgfSBmcm9tICcuLi9DaGVja2JveCdcbmltcG9ydCBGb3JtRmllbGRBZGRvbiBmcm9tICcuLi9Gb3JtRmllbGRBZGRvbidcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnKSh7XG4gIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBmbGV4RmxvdzogJ2NvbHVtbiBub3dyYXAnLFxuICBtaW5XaWR0aDogMCxcbiAgcG9zaXRpb246ICdyZWxhdGl2ZSdcbn0pXG5cbmNvbnN0IEFkZG9uID0gc3R5bGVkKEZvcm1GaWVsZEFkZG9uKTx7IG5vTGFiZWw6IGJvb2xlYW4gfT4oXG4gICh7IHRoZW1lLCBub0xhYmVsIH0pID0+ICh7XG4gICAgbWFyZ2luOiAwLFxuICAgIG1hcmdpbkxlZnQ6IG5vTGFiZWwgPyAwIDogdGhlbWUuc3BhY2VbNl1cbiAgfSlcbilcblxuZXhwb3J0IHR5cGUgQ2hlY2tib3hGaWVsZFByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtaW5zdHJ1bWVudGF0aW9uJz86IHN0cmluZ1xuICBlcnJvcj86IEFycmF5PHN0cmluZz4gfCBzdHJpbmdcbiAgaGlkZUFkZE9uPzogYm9vbGVhblxuICBoaW50Pzogc3RyaW5nXG4gIGhpbnROb2RlPzogUmVhY3QuUmVhY3ROb2RlXG59ICYgQ2hlY2tib3hQcm9wc1xuXG5leHBvcnQgY29uc3QgQ2hlY2tib3hGaWVsZDogUmVhY3QuRnVuY3Rpb25Db21wb25lbnQ8XG4gIFJlYWN0LlByb3BzV2l0aENoaWxkcmVuPENoZWNrYm94RmllbGRQcm9wcz5cbj4gPSAoe1xuICBjbGFzc05hbWUsXG4gIGVycm9yLFxuICBoaWRlQWRkT24sXG4gIGhpbnROb2RlLFxuICBoaW50LFxuICAuLi5wcm9wc1xufTogQ2hlY2tib3hGaWVsZFByb3BzKSA9PiB7XG4gIGNvbnN0IGVycm9yTGlzdCA9IGdldEVycm9yTGlzdChlcnJvcilcbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyPlxuICAgICAgPENoZWNrYm94IHsuLi5wcm9wc30gLz5cbiAgICAgIHtoaWRlQWRkT24gfHwgKFxuICAgICAgICA8QWRkb25cbiAgICAgICAgICBlcnJvckxpc3Q9e2Vycm9yTGlzdH1cbiAgICAgICAgICBoaW50PXtoaW50fVxuICAgICAgICAgIGhpbnROb2RlPXtoaW50Tm9kZX1cbiAgICAgICAgICBub0xhYmVsPXshcHJvcHMubGFiZWx9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvQ29udGFpbmVyPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IENoZWNrYm94RmllbGRcbiJdfQ== */",
37
37
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
38
38
  });
39
39
  var Addon = /*#__PURE__*/(0, _base["default"])(_FormFieldAddon["default"], process.env.NODE_ENV === "production" ? {
@@ -48,11 +48,7 @@ var Addon = /*#__PURE__*/(0, _base["default"])(_FormFieldAddon["default"], proce
48
48
  margin: 0,
49
49
  marginLeft: noLabel ? 0 : theme.space[6]
50
50
  };
51
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9DaGVja2JveEZpZWxkL0NoZWNrYm94RmllbGQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNjIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9DaGVja2JveEZpZWxkL0NoZWNrYm94RmllbGQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBnZXRFcnJvckxpc3QgfSBmcm9tICcuLi91dGlscydcbmltcG9ydCBDaGVja2JveCBmcm9tICcuLi9DaGVja2JveCdcbmltcG9ydCB0eXBlIHsgQ2hlY2tib3hQcm9wcyB9IGZyb20gJy4uL0NoZWNrYm94J1xuaW1wb3J0IEZvcm1GaWVsZEFkZG9uIGZyb20gJy4uL0Zvcm1GaWVsZEFkZG9uJ1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQoJ2RpdicpKHtcbiAgYWxpZ25JdGVtczogJ3N0cmV0Y2gnLFxuICBkaXNwbGF5OiAnZmxleCcsXG4gIGZsZXhGbG93OiAnY29sdW1uIG5vd3JhcCcsXG4gIG1pbldpZHRoOiAwLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJ1xufSlcblxuY29uc3QgQWRkb24gPSBzdHlsZWQoRm9ybUZpZWxkQWRkb24pPHsgbm9MYWJlbDogYm9vbGVhbiB9PihcbiAgKHsgdGhlbWUsIG5vTGFiZWwgfSkgPT4gKHtcbiAgICBtYXJnaW46IDAsXG4gICAgbWFyZ2luTGVmdDogbm9MYWJlbCA/IDAgOiB0aGVtZS5zcGFjZVs2XVxuICB9KVxuKVxuXG5leHBvcnQgdHlwZSBDaGVja2JveEZpZWxkUHJvcHMgPSB7XG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS1pbnN0cnVtZW50YXRpb24nPzogc3RyaW5nXG4gIGVycm9yPzogQXJyYXk8c3RyaW5nPiB8IHN0cmluZ1xuICBoaWRlQWRkT24/OiBib29sZWFuXG4gIGhpbnQ/OiBzdHJpbmdcbiAgaGludE5vZGU/OiBSZWFjdC5SZWFjdE5vZGVcbn0gJiBDaGVja2JveFByb3BzXG5cbi8qKlxuICogIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFycyBpcyBhZGRlZCBiZWNhdXNlIGV2ZW4gdGhvdWdoIHRoZSBwcm9wcyBhcmUgbm90IHVzZWQgaW4gdGhpcyBjb21wb25lbnRcbiAqIHRoZXkgYXJlIGdldHRpbmcgZGVzdHJ1Y3R1cmVkIGludG8gLi4ucHJvcHMgYW5kIHBhc3NlZCBmdXJ0aGVyIGRvd24gdGhlIHRyZWVcbiAqL1xuZXhwb3J0IGNvbnN0IENoZWNrYm94RmllbGQ6IFJlYWN0LkZ1bmN0aW9uQ29tcG9uZW50PFxuICBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxDaGVja2JveEZpZWxkUHJvcHM+XG4+ID0gKHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICBjbGFzc05hbWUsXG4gIGVycm9yLFxuICBoaWRlQWRkT24sXG4gIGhpbnROb2RlLFxuICBoaW50LFxuICAuLi5wcm9wc1xufTogQ2hlY2tib3hGaWVsZFByb3BzKSA9PiB7XG4gIGNvbnN0IGVycm9yTGlzdCA9IGdldEVycm9yTGlzdChlcnJvcilcbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyPlxuICAgICAgPENoZWNrYm94IHsuLi5wcm9wc30gLz5cbiAgICAgIHtoaWRlQWRkT24gfHwgKFxuICAgICAgICA8QWRkb25cbiAgICAgICAgICBlcnJvckxpc3Q9e2Vycm9yTGlzdH1cbiAgICAgICAgICBoaW50PXtoaW50fVxuICAgICAgICAgIGhpbnROb2RlPXtoaW50Tm9kZX1cbiAgICAgICAgICBub0xhYmVsPXshcHJvcHMubGFiZWx9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvQ29udGFpbmVyPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IENoZWNrYm94RmllbGRcbiJdfQ== */");
52
- /**
53
- * @typescript-eslint/no-unused-vars is added because even though the props are not used in this component
54
- * they are getting destructured into ...props and passed further down the tree
55
- */
51
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9DaGVja2JveEZpZWxkL0NoZWNrYm94RmllbGQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNjIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9DaGVja2JveEZpZWxkL0NoZWNrYm94RmllbGQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBnZXRFcnJvckxpc3QgfSBmcm9tICcuLi91dGlscydcbmltcG9ydCBDaGVja2JveCBmcm9tICcuLi9DaGVja2JveCdcbmltcG9ydCB0eXBlIHsgQ2hlY2tib3hQcm9wcyB9IGZyb20gJy4uL0NoZWNrYm94J1xuaW1wb3J0IEZvcm1GaWVsZEFkZG9uIGZyb20gJy4uL0Zvcm1GaWVsZEFkZG9uJ1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQoJ2RpdicpKHtcbiAgYWxpZ25JdGVtczogJ3N0cmV0Y2gnLFxuICBkaXNwbGF5OiAnZmxleCcsXG4gIGZsZXhGbG93OiAnY29sdW1uIG5vd3JhcCcsXG4gIG1pbldpZHRoOiAwLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJ1xufSlcblxuY29uc3QgQWRkb24gPSBzdHlsZWQoRm9ybUZpZWxkQWRkb24pPHsgbm9MYWJlbDogYm9vbGVhbiB9PihcbiAgKHsgdGhlbWUsIG5vTGFiZWwgfSkgPT4gKHtcbiAgICBtYXJnaW46IDAsXG4gICAgbWFyZ2luTGVmdDogbm9MYWJlbCA/IDAgOiB0aGVtZS5zcGFjZVs2XVxuICB9KVxuKVxuXG5leHBvcnQgdHlwZSBDaGVja2JveEZpZWxkUHJvcHMgPSB7XG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS1pbnN0cnVtZW50YXRpb24nPzogc3RyaW5nXG4gIGVycm9yPzogQXJyYXk8c3RyaW5nPiB8IHN0cmluZ1xuICBoaWRlQWRkT24/OiBib29sZWFuXG4gIGhpbnQ/OiBzdHJpbmdcbiAgaGludE5vZGU/OiBSZWFjdC5SZWFjdE5vZGVcbn0gJiBDaGVja2JveFByb3BzXG5cbmV4cG9ydCBjb25zdCBDaGVja2JveEZpZWxkOiBSZWFjdC5GdW5jdGlvbkNvbXBvbmVudDxcbiAgUmVhY3QuUHJvcHNXaXRoQ2hpbGRyZW48Q2hlY2tib3hGaWVsZFByb3BzPlxuPiA9ICh7XG4gIGNsYXNzTmFtZSxcbiAgZXJyb3IsXG4gIGhpZGVBZGRPbixcbiAgaGludE5vZGUsXG4gIGhpbnQsXG4gIC4uLnByb3BzXG59OiBDaGVja2JveEZpZWxkUHJvcHMpID0+IHtcbiAgY29uc3QgZXJyb3JMaXN0ID0gZ2V0RXJyb3JMaXN0KGVycm9yKVxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXI+XG4gICAgICA8Q2hlY2tib3ggey4uLnByb3BzfSAvPlxuICAgICAge2hpZGVBZGRPbiB8fCAoXG4gICAgICAgIDxBZGRvblxuICAgICAgICAgIGVycm9yTGlzdD17ZXJyb3JMaXN0fVxuICAgICAgICAgIGhpbnQ9e2hpbnR9XG4gICAgICAgICAgaGludE5vZGU9e2hpbnROb2RlfVxuICAgICAgICAgIG5vTGFiZWw9eyFwcm9wcy5sYWJlbH1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9Db250YWluZXI+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgQ2hlY2tib3hGaWVsZFxuIl19 */");
56
52
  var CheckboxField = exports.CheckboxField = function CheckboxField(_ref2) {
57
53
  var className = _ref2.className,
58
54
  error = _ref2.error,
@@ -165,10 +165,6 @@ declare class DataGrid extends Component<DataGridProps, DataGridState> {
165
165
  style: {};
166
166
  }) => import("@emotion/react/jsx-runtime").JSX.Element;
167
167
  rowRenderer: ({ key, style, index, rowData, columns, className, onRowMouseOver, onRowMouseOut }: TableRowProps) => import("@emotion/react/jsx-runtime").JSX.Element;
168
- /**
169
- * @typescript-eslint/no-unused-vars is added because even though the props are not used in this component
170
- * they are getting destructured into ...props and passed further down the tree
171
- */
172
168
  render(): import("@emotion/react/jsx-runtime").JSX.Element;
173
169
  }
174
170
  export default DataGrid;
@@ -463,12 +463,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
463
463
  _inherits(DataGrid, _Component);
464
464
  return _createClass(DataGrid, [{
465
465
  key: "render",
466
- value:
467
- /**
468
- * @typescript-eslint/no-unused-vars is added because even though the props are not used in this component
469
- * they are getting destructured into ...props and passed further down the tree
470
- */
471
- function render() {
466
+ value: function render() {
472
467
  var _this2 = this;
473
468
  var _this$props3 = this.props,
474
469
  children = _this$props3.children,
@@ -555,7 +550,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
555
550
  css: /*#__PURE__*/(0, _react.css)({
556
551
  width: width,
557
552
  height: height
558
- }, process.env.NODE_ENV === "production" ? "" : ";label:render;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/DataGrid.tsx"],"names":[],"mappings":"AAkrBQ","file":"../../../src/DataGrid/DataGrid.tsx","sourcesContent":["import {\n  ReactNode,\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  createRef,\n  cloneElement,\n  Component\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport {\n  InfiniteLoader,\n  Table,\n  SortDirection,\n  TableRowProps\n} from 'react-virtualized'\nimport type {\n  SortDirectionType,\n  TableProps,\n  IndexRange,\n  Index,\n  RowMouseEventHandlerParams\n} from 'react-virtualized'\nimport * as Elements from './elements'\nimport * as Renderers from './renderers'\nimport {\n  BasicColumn,\n  FocusableRow,\n  InputCell,\n  CollapsibleCell,\n  ScrollableTable\n} from './components'\nimport { CloseWrapper } from '../utils'\nimport curry from 'lodash.curry'\nimport includes from 'lodash.includes'\nimport noop from 'lodash.noop'\nimport range from 'lodash.range'\nimport throttle from 'lodash.throttle'\nimport uniq from 'lodash.uniq'\nimport * as dataGridUtils from './utils'\nimport type {\n  BasicColumnMappedProps,\n  BasicColumnProps\n} from './components/BasicColumn'\nimport type { LocaleStrings } from './constants'\n\nexport type onFilterArguments = {\n  filters: { [dataKey: string]: any }\n  sortBy?: string\n  sortDirection?: SortDirectionType\n}\n\ntype activeContextMenuState = {\n  top: number\n  left: number\n  index: number\n  rowData: any\n}\n\ntype contextMenuRendererArguments = {\n  top?: number\n  left?: number\n  index?: number\n  rowData?: any\n  selectedRows: Array<number>\n  onClose: () => void\n}\n\nexport type SelectableType = 'single' | 'multi'\n\nexport type ColumnFunction = (args: BasicColumnMappedProps) => ReactNode\n\nexport type DataGridProps = {\n  /** Functions that create react virtualized Columns. Default column is exposed as DataGrid.Column. */\n  // Can take a single column or an array of columns\n  children: ColumnFunction | (ColumnFunction | ColumnFunction[])[]\n  /** Instrumentation */\n  'data-instrumentation'?: string\n  /** Called during the onContextMenu event of each row. */\n  contextMenuRenderer?: (\n    contextMenuRendererArguments: contextMenuRendererArguments\n  ) => ReactNode\n  /** Called when a column is filtered or sorted. */\n  onFilter: (onFilterArguments: onFilterArguments) => void\n  /** Called when a column is resized by the user. Passing this in enables\n   * resize handles on the right edge of the header cells. */\n  onResize?: (newSizes: number[]) => void\n  /** Called when the row selection changes. Receives array of indices. */\n  onSelect: (indexes: number[]) => void\n  /** Called when the row is double clicked. Receives index. */\n  onRowDoubleClick?: (info: RowMouseEventHandlerParams) => void\n  /** Infinite loading: Indicates more rows need to be loaded. */\n  hasMoreRows?: boolean\n  /** Infinite loading: Called when more rows need to be loaded. */\n  loadMoreRows?: (props: IndexRange) => Promise<any>\n  /** Count of rows that have already been loaded. */\n  rowCount: number\n  /** Required by react-virtualized table. */\n  rowGetter: (props: { index: number }) => any\n  /** Whether rows can be selected (and how many). */\n  selectable?: SelectableType | false\n  /** Array of indices that should be selected. Only used if `selectable` is set. */\n  selectedRows: Array<number>\n  /** The column you want to sort */\n  sortBy?: string\n  /** The direction sorting should be done */\n  sortDirection?: SortDirectionType\n  /** A map of columns to filter data */\n  filters?: { [dataKey: string]: any }\n  /** Set the width of scrollable content */\n  scrollWidth?: number\n  width: number\n  height: number\n  /** Locale string: ja, de, es, ko, en, etc. */\n  locale?: string\n  /** Locale strings to override en for language in locale */\n  localeStrings?: LocaleStrings\n  /** allow events to propagate to a cell on row select */\n  allowRowEventPassthrough?: boolean\n} & Partial<TableProps>\n\ntype DataGridState = {\n  activeContextMenu: activeContextMenuState | null\n  disableKeyboardShortcuts: boolean\n  focusedRow: number | null\n  selecting: boolean\n  lastSelectedRow: number | null\n}\n\ntype HandleFilterArguments = {\n  sortBy?: string\n  sortDirection?: SortDirectionType\n  filters?: any\n}\n\n/**\n * Component for displaying data in a grid with support for things like\n * filtering, sorting, and context menus.\n *\n * Depends on react-virtualized/styles.css.\n *\n * For react-virtualized Table docs see: https://github.com/bvaughn/react-virtualized/blob/master/docs/Table.md\n *\n */\nclass DataGrid extends Component<DataGridProps, DataGridState> {\n  // expose sub-components\n  static Column = curry(BasicColumn)\n  static SortDirection = SortDirection\n  static Elements = Elements\n  static InputCell = InputCell\n  static CollapsibleCell = CollapsibleCell\n  static Renderers = Renderers\n\n  static SINGLE_SELECT: SelectableType = 'single'\n  static MULTI_SELECT: SelectableType = 'multi'\n  static MIN_COL_WIDTH = 50\n\n  static utils = dataGridUtils\n\n  static defaultProps = {\n    loadMoreRows: noop,\n    onSelect: noop,\n    onFilter: noop,\n    'data-instrumentation': 'datagrid',\n    sortBy: '',\n    sortDirection: SortDirection.ASC,\n    filters: {},\n    selectedRows: [],\n    allowRowEventPassthrough: false\n  }\n\n  static displayName = 'DataGrid'\n\n  state: DataGridState = {\n    activeContextMenu: null,\n    disableKeyboardShortcuts: false,\n    focusedRow: null,\n    lastSelectedRow: null,\n    selecting: false\n  }\n\n  infiniteTable = createRef<InfiniteLoader>()\n\n  totalWidth = 0\n  columnWidthPercents: number[] = []\n\n  columnTransformer: (\n    columns: ReactElement<any>[],\n    rowData: any,\n    rowIndex: number\n  ) => ReactNode[] | null | undefined\n\n  select = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = [...selectedRows, index]\n      if (this.props.selectable === DataGrid.SINGLE_SELECT) {\n        selected = [index]\n      } else if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        selected = uniq([...selectedRows, ...range(start, end + 1)])\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  selectAll = () => {\n    const { rowCount } = this.props\n    this.setSelectedRows(Array.from({ length: rowCount }).map((_, idx) => idx))\n  }\n\n  deselect = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = selectedRows.filter(idx => idx !== index)\n      if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        const toDeselect = range(start, end + 1)\n        selected = selectedRows.filter(idx => !includes(toDeselect, idx))\n      }\n      if (\n        this.props.selectable === DataGrid.SINGLE_SELECT &&\n        !selected.length\n      ) {\n        return null\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  deselectAll = () => {\n    this.setSelectedRows([])\n    this.setState({\n      lastSelectedRow: null\n    })\n  }\n\n  toggleSelect = ({\n    index,\n    contiguous\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    if (!this.props.selectedRows.includes(index)) {\n      this.select({ index, contiguous })\n    } else {\n      this.deselect({ index, contiguous })\n    }\n  }\n\n  setSelectedRows = (rows: Array<number>) => {\n    this.props.onSelect(rows)\n  }\n\n  handleFilter = ({\n    sortBy,\n    sortDirection,\n    filters\n  }: HandleFilterArguments) => {\n    const {\n      sortBy: oldSortBy,\n      sortDirection: oldSortDirection,\n      filters: oldFilters\n    } = this.props\n    const newData = {\n      sortBy: sortBy || oldSortBy,\n      sortDirection: sortDirection || oldSortDirection,\n      filters: {\n        ...oldFilters,\n        ...filters\n      }\n    }\n    this.props.onFilter(newData)\n  }\n\n  handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'a':\n        if (\n          (event.metaKey || event.ctrlKey) &&\n          this.props.selectable === DataGrid.MULTI_SELECT\n        ) {\n          event.preventDefault()\n          if (this.props.rowCount === this.props.selectedRows.length) {\n            this.deselectAll()\n          } else {\n            this.selectAll()\n          }\n        }\n        break\n      case 'ArrowUp':\n        this.setState(state => ({\n          focusedRow: Math.max((state.focusedRow || 0) - 1, 0)\n        }))\n        event.preventDefault()\n        break\n      case 'ArrowDown':\n        this.setState(state => ({\n          focusedRow:\n            state.focusedRow != null\n              ? Math.min(state.focusedRow + 1, this.props.rowCount - 1)\n              : 0\n        }))\n        event.preventDefault()\n        break\n      case 'Enter':\n      case ' ':\n        if (this.props.selectable) {\n          this.toggleSelect({\n            index: this.state.focusedRow || 0,\n            contiguous: event.shiftKey\n          })\n        }\n        event.preventDefault()\n        break\n      case 'Shift':\n        this.setState({\n          selecting: true\n        })\n        break\n    }\n  }\n\n  handleKeyUp = (event: KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'Shift':\n        this.setState({\n          selecting: false\n        })\n        break\n    }\n  }\n\n  // throttling this so a double click behaves like a single click\n  handleRowClick = throttle(\n    ({ event, index }: { event: MouseEvent<any>; index: number }) => {\n      if (!this.props.allowRowEventPassthrough) {\n        event.stopPropagation()\n      }\n\n      this.toggleSelect({ index, contiguous: event.shiftKey })\n    },\n    250,\n    { leading: true, trailing: false }\n  )\n\n  handleResize = ({ x, index }: { x: number; index: number }) => {\n    if (this.columnWidthPercents.length > 0 && this.totalWidth) {\n      const prevWidths = this.columnWidthPercents\n      const newWidths = [...prevWidths]\n      const parentWidth = this.props.scrollWidth ?? this.props.width\n      // limit next index from going beyond bounds\n      const nextIndex = Math.min(index + 1, prevWidths.length - 1)\n      const percentChange = x / this.totalWidth\n\n      if (this.props.scrollWidth) {\n        // if table is scrollable, we can grow the column without\n        // shrinking the others\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n          DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n      } else {\n        // if the table is not scrollable, ensure all columns fit by\n        // adjusting the current column and the one after it\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH ||\n          (prevWidths[nextIndex] - percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n        newWidths[nextIndex] = prevWidths[nextIndex] - safePercentChange\n      }\n\n      if (this.props.onResize) {\n        this.props.onResize(\n          // multiply by width prop to get correct percentage\n          newWidths.map(width => Math.round(width * parentWidth))\n        )\n      }\n    }\n  }\n\n  mapChildren = () => {\n    const IsArray = (\n      children\n    ): children is (ColumnFunction | ColumnFunction[])[] =>\n      Array.isArray(children)\n\n    const children: (ColumnFunction | ColumnFunction[])[] = IsArray(\n      this.props.children\n    )\n      ? this.props.children\n      : [this.props.children]\n\n    const validChildren = children\n      .flat()\n      .filter(child => typeof child === 'function')\n\n    return validChildren.map((child, index) =>\n      child({\n        locale: this.props.locale || 'en',\n        localeStrings: this.props.localeStrings || {},\n        columnIndex: index,\n        columnCount: validChildren.length,\n        getFilterValue: dataKey =>\n          this.props.filters && this.props.filters[dataKey],\n        onHeaderPopoverOpen: open =>\n          this.setState({ disableKeyboardShortcuts: open }),\n        onSort: sortArgs => {\n          this.setSelectedRows([])\n          this.handleFilter({ ...sortArgs })\n        },\n        onFilter: ({ dataKey, value, operator }) => {\n          this.setSelectedRows([])\n          this.handleFilter({\n            filters: {\n              [dataKey]: operator\n                ? {\n                    value,\n                    operator\n                  }\n                : value\n            }\n          })\n        },\n        onResize:\n          // the presence of `onResize` will show drag handles so don't set it\n          // if no prop is passed in or for the last column if the table isn't\n          // scrollable\n          this.props.onResize &&\n          ((!this.props.scrollWidth && index !== validChildren.length - 1) ||\n            this.props.scrollWidth)\n            ? ({ x }) => {\n                this.handleResize({ x, index })\n              }\n            : undefined\n      })\n    )\n  }\n\n  isRowLoaded = ({ index }: Index) => {\n    const { hasMoreRows, rowCount } = this.props\n    return !hasMoreRows || index < rowCount\n  }\n\n  isContextMenuVisible = (index: number) =>\n    this.state.activeContextMenu && this.state.activeContextMenu.index === index\n\n  closeContextMenu = () => {\n    this.setState({\n      activeContextMenu: null\n    })\n  }\n\n  contextMenuRenderer = (index: number) => {\n    if (\n      this.props.contextMenuRenderer &&\n      this.isContextMenuVisible(index) &&\n      document.body !== null\n    ) {\n      const contextMenuCloseWrapper = (\n        <CloseWrapper onClose={this.closeContextMenu}>\n          {this.props.contextMenuRenderer({\n            ...this.state.activeContextMenu,\n            selectedRows: this.props.selectedRows,\n            onClose: this.closeContextMenu\n          })}\n        </CloseWrapper>\n      )\n      return ReactDOM.createPortal(contextMenuCloseWrapper, document.body)\n    }\n    return null\n  }\n\n  headerRowRenderer = ({\n    columns,\n    style\n  }: {\n    columns: ReactNode[]\n    style: {}\n  }) => (\n    <Elements.Row role=\"row\" header zebra style={style}>\n      {columns}\n    </Elements.Row>\n  )\n\n  rowRenderer = ({\n    key,\n    style,\n    index,\n    rowData,\n    columns,\n    className,\n    onRowMouseOver,\n    onRowMouseOut\n  }: TableRowProps) => (\n    <FocusableRow\n      className={className}\n      aria-rowindex={index + 1}\n      zebra={index % 2 === 1}\n      selected={this.props.selectedRows.includes(index)}\n      selecting={this.state.selecting}\n      focused={index === this.state.focusedRow}\n      key={key}\n      style={style}\n      onMouseLeave={event => {\n        onRowMouseOut && onRowMouseOut({ rowData, index, event })\n      }}\n      onMouseEnter={event => {\n        onRowMouseOver && onRowMouseOver({ rowData, index, event })\n      }}\n      onFocus={() => this.setState({ focusedRow: index })}\n      data-instrumentation={`${this.props['data-instrumentation']}-row${\n        index + 1\n      }`}\n      onClick={\n        this.props.selectable && !this.state.activeContextMenu\n          ? event => this.handleRowClick({ event, index })\n          : undefined\n      }\n      onContextMenu={\n        this.props.contextMenuRenderer\n          ? event => {\n              this.setState({\n                activeContextMenu: {\n                  left: event.clientX,\n                  top: event.clientY,\n                  index,\n                  rowData\n                }\n              })\n              if (\n                !this.props.selectedRows.includes(index) &&\n                this.props.selectable\n              ) {\n                this.handleRowClick({ event, index })\n              }\n              event.preventDefault()\n            }\n          : undefined\n      }\n      onDoubleClick={event =>\n        this.props.onRowDoubleClick &&\n        this.props.onRowDoubleClick({ index, event, rowData })\n      }\n    >\n      {this.columnTransformer\n        ? this.columnTransformer(columns, rowData, index)\n        : columns}\n      {this.contextMenuRenderer(index)}\n    </FocusableRow>\n  )\n\n  /**\n   *  @typescript-eslint/no-unused-vars is added because even though the props are not used in this component\n   * they are getting destructured into ...props and passed further down the tree\n   */\n  render() {\n    const {\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      children,\n      hasMoreRows,\n      height,\n      loadMoreRows,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      onFilter,\n      rowCount,\n      sortBy = '',\n      sortDirection,\n      width,\n      ...props\n    } = this.props\n\n    // This fixes an issue where the header of the DataGrid doesn't render on page load in Safari\n    const safariStyle = {\n      transform: `translateZ(0)`\n    }\n\n    const mappedChildren = this.mapChildren().filter(child => child !== null)\n    // TODO: Better type signature when accessing children props?\n    const spanData = mappedChildren.map((child: ReactElement) => ({\n      colspan: child.props.colspan ? child.props.colspan : () => 1,\n      width: child.props.width,\n      flexGrow: child.props.flexGrow\n    }))\n    // Get the actual width of all the columns. This is independent from the\n    // width prop.\n    this.totalWidth = mappedChildren.reduce<number>(\n      (total: number, child: ReactElement<BasicColumnProps>) =>\n        total + child.props.width,\n      0\n    )\n    // Convert the widths to percents so we can map them back to the real table\n    // width later.\n    this.columnWidthPercents = mappedChildren.map(\n      ({ props }: ReactElement) => props.width / this.totalWidth\n    )\n\n    this.columnTransformer = (\n      columns: ReactElement<any>[],\n      rowData,\n      rowIndex\n    ) => {\n      const spans = spanData.map(item => item.colspan(rowData))\n      const spannedColumns: ReactElement[] = []\n      let index = 0\n      while (index < columns.length) {\n        const span = spans[index]\n        const column = columns[index]\n        if (span > 1) {\n          const followingColumns = spanData.slice(index, span)\n          // find new width by adding current column width plus columns that are spanned over\n\n          const width = followingColumns.reduce(\n            (accumulator, { width }: { width: number }) => accumulator + width,\n            0\n          )\n\n          const flexGrow = followingColumns.reduce(\n            (accumulator, { flexGrow }: { flexGrow: number }) =>\n              accumulator + flexGrow,\n            0\n          )\n          spannedColumns.push(\n            cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`,\n              style: {\n                ...Elements.cellResetStyle,\n                flex: `0 1 ${width}px`,\n                flexGrow\n              }\n            })\n          )\n          index += span // skip columns that have been spanned over\n        } else {\n          spannedColumns.push(\n            cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`\n            })\n          )\n          index++\n        }\n      }\n      return spannedColumns\n    }\n\n    const TableComponent =\n      this.props.scrollWidth !== undefined ? ScrollableTable : Table\n\n    return (\n      <Elements.TableContainer\n        css={{ width, height }}\n        onKeyDown={this.handleKeyDown}\n        onKeyUp={this.handleKeyUp}\n        data-instrumentation={`${this.props['data-instrumentation']}-grid`}\n      >\n        <InfiniteLoader\n          isRowLoaded={this.isRowLoaded}\n          loadMoreRows={loadMoreRows || (() => Promise.resolve(false))}\n          rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n          threshold={5}\n          ref={this.infiniteTable}\n        >\n          {({ onRowsRendered, registerChild }) => (\n            <TableComponent\n              style={safariStyle}\n              gridStyle={{ outline: 'none' }}\n              headerHeight={36}\n              rowHeight={30}\n              sortBy={sortBy}\n              sortDirection={sortDirection}\n              ref={registerChild}\n              noRowsRendered={() => <div>No results</div>}\n              onRowsRendered={onRowsRendered}\n              onScroll={\n                this.state.activeContextMenu\n                  ? () => this.closeContextMenu()\n                  : undefined\n              }\n              rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n              headerRowRenderer={this.headerRowRenderer}\n              rowRenderer={this.rowRenderer}\n              // account for border width of container\n              width={width - 2}\n              height={height - 2}\n              {...props}\n            >\n              {mappedChildren}\n            </TableComponent>\n          )}\n        </InfiniteLoader>\n      </Elements.TableContainer>\n    )\n  }\n}\n\nexport default DataGrid\n"]} */"),
553
+ }, process.env.NODE_ENV === "production" ? "" : ";label:render;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/DataGrid.tsx"],"names":[],"mappings":"AA4qBQ","file":"../../../src/DataGrid/DataGrid.tsx","sourcesContent":["import {\n  ReactNode,\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  createRef,\n  cloneElement,\n  Component\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport {\n  InfiniteLoader,\n  Table,\n  SortDirection,\n  TableRowProps\n} from 'react-virtualized'\nimport type {\n  SortDirectionType,\n  TableProps,\n  IndexRange,\n  Index,\n  RowMouseEventHandlerParams\n} from 'react-virtualized'\nimport * as Elements from './elements'\nimport * as Renderers from './renderers'\nimport {\n  BasicColumn,\n  FocusableRow,\n  InputCell,\n  CollapsibleCell,\n  ScrollableTable\n} from './components'\nimport { CloseWrapper } from '../utils'\nimport curry from 'lodash.curry'\nimport includes from 'lodash.includes'\nimport noop from 'lodash.noop'\nimport range from 'lodash.range'\nimport throttle from 'lodash.throttle'\nimport uniq from 'lodash.uniq'\nimport * as dataGridUtils from './utils'\nimport type {\n  BasicColumnMappedProps,\n  BasicColumnProps\n} from './components/BasicColumn'\nimport type { LocaleStrings } from './constants'\n\nexport type onFilterArguments = {\n  filters: { [dataKey: string]: any }\n  sortBy?: string\n  sortDirection?: SortDirectionType\n}\n\ntype activeContextMenuState = {\n  top: number\n  left: number\n  index: number\n  rowData: any\n}\n\ntype contextMenuRendererArguments = {\n  top?: number\n  left?: number\n  index?: number\n  rowData?: any\n  selectedRows: Array<number>\n  onClose: () => void\n}\n\nexport type SelectableType = 'single' | 'multi'\n\nexport type ColumnFunction = (args: BasicColumnMappedProps) => ReactNode\n\nexport type DataGridProps = {\n  /** Functions that create react virtualized Columns. Default column is exposed as DataGrid.Column. */\n  // Can take a single column or an array of columns\n  children: ColumnFunction | (ColumnFunction | ColumnFunction[])[]\n  /** Instrumentation */\n  'data-instrumentation'?: string\n  /** Called during the onContextMenu event of each row. */\n  contextMenuRenderer?: (\n    contextMenuRendererArguments: contextMenuRendererArguments\n  ) => ReactNode\n  /** Called when a column is filtered or sorted. */\n  onFilter: (onFilterArguments: onFilterArguments) => void\n  /** Called when a column is resized by the user. Passing this in enables\n   * resize handles on the right edge of the header cells. */\n  onResize?: (newSizes: number[]) => void\n  /** Called when the row selection changes. Receives array of indices. */\n  onSelect: (indexes: number[]) => void\n  /** Called when the row is double clicked. Receives index. */\n  onRowDoubleClick?: (info: RowMouseEventHandlerParams) => void\n  /** Infinite loading: Indicates more rows need to be loaded. */\n  hasMoreRows?: boolean\n  /** Infinite loading: Called when more rows need to be loaded. */\n  loadMoreRows?: (props: IndexRange) => Promise<any>\n  /** Count of rows that have already been loaded. */\n  rowCount: number\n  /** Required by react-virtualized table. */\n  rowGetter: (props: { index: number }) => any\n  /** Whether rows can be selected (and how many). */\n  selectable?: SelectableType | false\n  /** Array of indices that should be selected. Only used if `selectable` is set. */\n  selectedRows: Array<number>\n  /** The column you want to sort */\n  sortBy?: string\n  /** The direction sorting should be done */\n  sortDirection?: SortDirectionType\n  /** A map of columns to filter data */\n  filters?: { [dataKey: string]: any }\n  /** Set the width of scrollable content */\n  scrollWidth?: number\n  width: number\n  height: number\n  /** Locale string: ja, de, es, ko, en, etc. */\n  locale?: string\n  /** Locale strings to override en for language in locale */\n  localeStrings?: LocaleStrings\n  /** allow events to propagate to a cell on row select */\n  allowRowEventPassthrough?: boolean\n} & Partial<TableProps>\n\ntype DataGridState = {\n  activeContextMenu: activeContextMenuState | null\n  disableKeyboardShortcuts: boolean\n  focusedRow: number | null\n  selecting: boolean\n  lastSelectedRow: number | null\n}\n\ntype HandleFilterArguments = {\n  sortBy?: string\n  sortDirection?: SortDirectionType\n  filters?: any\n}\n\n/**\n * Component for displaying data in a grid with support for things like\n * filtering, sorting, and context menus.\n *\n * Depends on react-virtualized/styles.css.\n *\n * For react-virtualized Table docs see: https://github.com/bvaughn/react-virtualized/blob/master/docs/Table.md\n *\n */\nclass DataGrid extends Component<DataGridProps, DataGridState> {\n  // expose sub-components\n  static Column = curry(BasicColumn)\n  static SortDirection = SortDirection\n  static Elements = Elements\n  static InputCell = InputCell\n  static CollapsibleCell = CollapsibleCell\n  static Renderers = Renderers\n\n  static SINGLE_SELECT: SelectableType = 'single'\n  static MULTI_SELECT: SelectableType = 'multi'\n  static MIN_COL_WIDTH = 50\n\n  static utils = dataGridUtils\n\n  static defaultProps = {\n    loadMoreRows: noop,\n    onSelect: noop,\n    onFilter: noop,\n    'data-instrumentation': 'datagrid',\n    sortBy: '',\n    sortDirection: SortDirection.ASC,\n    filters: {},\n    selectedRows: [],\n    allowRowEventPassthrough: false\n  }\n\n  static displayName = 'DataGrid'\n\n  state: DataGridState = {\n    activeContextMenu: null,\n    disableKeyboardShortcuts: false,\n    focusedRow: null,\n    lastSelectedRow: null,\n    selecting: false\n  }\n\n  infiniteTable = createRef<InfiniteLoader>()\n\n  totalWidth = 0\n  columnWidthPercents: number[] = []\n\n  columnTransformer: (\n    columns: ReactElement<any>[],\n    rowData: any,\n    rowIndex: number\n  ) => ReactNode[] | null | undefined\n\n  select = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = [...selectedRows, index]\n      if (this.props.selectable === DataGrid.SINGLE_SELECT) {\n        selected = [index]\n      } else if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        selected = uniq([...selectedRows, ...range(start, end + 1)])\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  selectAll = () => {\n    const { rowCount } = this.props\n    this.setSelectedRows(Array.from({ length: rowCount }).map((_, idx) => idx))\n  }\n\n  deselect = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = selectedRows.filter(idx => idx !== index)\n      if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        const toDeselect = range(start, end + 1)\n        selected = selectedRows.filter(idx => !includes(toDeselect, idx))\n      }\n      if (\n        this.props.selectable === DataGrid.SINGLE_SELECT &&\n        !selected.length\n      ) {\n        return null\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  deselectAll = () => {\n    this.setSelectedRows([])\n    this.setState({\n      lastSelectedRow: null\n    })\n  }\n\n  toggleSelect = ({\n    index,\n    contiguous\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    if (!this.props.selectedRows.includes(index)) {\n      this.select({ index, contiguous })\n    } else {\n      this.deselect({ index, contiguous })\n    }\n  }\n\n  setSelectedRows = (rows: Array<number>) => {\n    this.props.onSelect(rows)\n  }\n\n  handleFilter = ({\n    sortBy,\n    sortDirection,\n    filters\n  }: HandleFilterArguments) => {\n    const {\n      sortBy: oldSortBy,\n      sortDirection: oldSortDirection,\n      filters: oldFilters\n    } = this.props\n    const newData = {\n      sortBy: sortBy || oldSortBy,\n      sortDirection: sortDirection || oldSortDirection,\n      filters: {\n        ...oldFilters,\n        ...filters\n      }\n    }\n    this.props.onFilter(newData)\n  }\n\n  handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'a':\n        if (\n          (event.metaKey || event.ctrlKey) &&\n          this.props.selectable === DataGrid.MULTI_SELECT\n        ) {\n          event.preventDefault()\n          if (this.props.rowCount === this.props.selectedRows.length) {\n            this.deselectAll()\n          } else {\n            this.selectAll()\n          }\n        }\n        break\n      case 'ArrowUp':\n        this.setState(state => ({\n          focusedRow: Math.max((state.focusedRow || 0) - 1, 0)\n        }))\n        event.preventDefault()\n        break\n      case 'ArrowDown':\n        this.setState(state => ({\n          focusedRow:\n            state.focusedRow != null\n              ? Math.min(state.focusedRow + 1, this.props.rowCount - 1)\n              : 0\n        }))\n        event.preventDefault()\n        break\n      case 'Enter':\n      case ' ':\n        if (this.props.selectable) {\n          this.toggleSelect({\n            index: this.state.focusedRow || 0,\n            contiguous: event.shiftKey\n          })\n        }\n        event.preventDefault()\n        break\n      case 'Shift':\n        this.setState({\n          selecting: true\n        })\n        break\n    }\n  }\n\n  handleKeyUp = (event: KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'Shift':\n        this.setState({\n          selecting: false\n        })\n        break\n    }\n  }\n\n  // throttling this so a double click behaves like a single click\n  handleRowClick = throttle(\n    ({ event, index }: { event: MouseEvent<any>; index: number }) => {\n      if (!this.props.allowRowEventPassthrough) {\n        event.stopPropagation()\n      }\n\n      this.toggleSelect({ index, contiguous: event.shiftKey })\n    },\n    250,\n    { leading: true, trailing: false }\n  )\n\n  handleResize = ({ x, index }: { x: number; index: number }) => {\n    if (this.columnWidthPercents.length > 0 && this.totalWidth) {\n      const prevWidths = this.columnWidthPercents\n      const newWidths = [...prevWidths]\n      const parentWidth = this.props.scrollWidth ?? this.props.width\n      // limit next index from going beyond bounds\n      const nextIndex = Math.min(index + 1, prevWidths.length - 1)\n      const percentChange = x / this.totalWidth\n\n      if (this.props.scrollWidth) {\n        // if table is scrollable, we can grow the column without\n        // shrinking the others\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n          DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n      } else {\n        // if the table is not scrollable, ensure all columns fit by\n        // adjusting the current column and the one after it\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH ||\n          (prevWidths[nextIndex] - percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n        newWidths[nextIndex] = prevWidths[nextIndex] - safePercentChange\n      }\n\n      if (this.props.onResize) {\n        this.props.onResize(\n          // multiply by width prop to get correct percentage\n          newWidths.map(width => Math.round(width * parentWidth))\n        )\n      }\n    }\n  }\n\n  mapChildren = () => {\n    const IsArray = (\n      children\n    ): children is (ColumnFunction | ColumnFunction[])[] =>\n      Array.isArray(children)\n\n    const children: (ColumnFunction | ColumnFunction[])[] = IsArray(\n      this.props.children\n    )\n      ? this.props.children\n      : [this.props.children]\n\n    const validChildren = children\n      .flat()\n      .filter(child => typeof child === 'function')\n\n    return validChildren.map((child, index) =>\n      child({\n        locale: this.props.locale || 'en',\n        localeStrings: this.props.localeStrings || {},\n        columnIndex: index,\n        columnCount: validChildren.length,\n        getFilterValue: dataKey =>\n          this.props.filters && this.props.filters[dataKey],\n        onHeaderPopoverOpen: open =>\n          this.setState({ disableKeyboardShortcuts: open }),\n        onSort: sortArgs => {\n          this.setSelectedRows([])\n          this.handleFilter({ ...sortArgs })\n        },\n        onFilter: ({ dataKey, value, operator }) => {\n          this.setSelectedRows([])\n          this.handleFilter({\n            filters: {\n              [dataKey]: operator\n                ? {\n                    value,\n                    operator\n                  }\n                : value\n            }\n          })\n        },\n        onResize:\n          // the presence of `onResize` will show drag handles so don't set it\n          // if no prop is passed in or for the last column if the table isn't\n          // scrollable\n          this.props.onResize &&\n          ((!this.props.scrollWidth && index !== validChildren.length - 1) ||\n            this.props.scrollWidth)\n            ? ({ x }) => {\n                this.handleResize({ x, index })\n              }\n            : undefined\n      })\n    )\n  }\n\n  isRowLoaded = ({ index }: Index) => {\n    const { hasMoreRows, rowCount } = this.props\n    return !hasMoreRows || index < rowCount\n  }\n\n  isContextMenuVisible = (index: number) =>\n    this.state.activeContextMenu && this.state.activeContextMenu.index === index\n\n  closeContextMenu = () => {\n    this.setState({\n      activeContextMenu: null\n    })\n  }\n\n  contextMenuRenderer = (index: number) => {\n    if (\n      this.props.contextMenuRenderer &&\n      this.isContextMenuVisible(index) &&\n      document.body !== null\n    ) {\n      const contextMenuCloseWrapper = (\n        <CloseWrapper onClose={this.closeContextMenu}>\n          {this.props.contextMenuRenderer({\n            ...this.state.activeContextMenu,\n            selectedRows: this.props.selectedRows,\n            onClose: this.closeContextMenu\n          })}\n        </CloseWrapper>\n      )\n      return ReactDOM.createPortal(contextMenuCloseWrapper, document.body)\n    }\n    return null\n  }\n\n  headerRowRenderer = ({\n    columns,\n    style\n  }: {\n    columns: ReactNode[]\n    style: {}\n  }) => (\n    <Elements.Row role=\"row\" header zebra style={style}>\n      {columns}\n    </Elements.Row>\n  )\n\n  rowRenderer = ({\n    key,\n    style,\n    index,\n    rowData,\n    columns,\n    className,\n    onRowMouseOver,\n    onRowMouseOut\n  }: TableRowProps) => (\n    <FocusableRow\n      className={className}\n      aria-rowindex={index + 1}\n      zebra={index % 2 === 1}\n      selected={this.props.selectedRows.includes(index)}\n      selecting={this.state.selecting}\n      focused={index === this.state.focusedRow}\n      key={key}\n      style={style}\n      onMouseLeave={event => {\n        onRowMouseOut && onRowMouseOut({ rowData, index, event })\n      }}\n      onMouseEnter={event => {\n        onRowMouseOver && onRowMouseOver({ rowData, index, event })\n      }}\n      onFocus={() => this.setState({ focusedRow: index })}\n      data-instrumentation={`${this.props['data-instrumentation']}-row${\n        index + 1\n      }`}\n      onClick={\n        this.props.selectable && !this.state.activeContextMenu\n          ? event => this.handleRowClick({ event, index })\n          : undefined\n      }\n      onContextMenu={\n        this.props.contextMenuRenderer\n          ? event => {\n              this.setState({\n                activeContextMenu: {\n                  left: event.clientX,\n                  top: event.clientY,\n                  index,\n                  rowData\n                }\n              })\n              if (\n                !this.props.selectedRows.includes(index) &&\n                this.props.selectable\n              ) {\n                this.handleRowClick({ event, index })\n              }\n              event.preventDefault()\n            }\n          : undefined\n      }\n      onDoubleClick={event =>\n        this.props.onRowDoubleClick &&\n        this.props.onRowDoubleClick({ index, event, rowData })\n      }\n    >\n      {this.columnTransformer\n        ? this.columnTransformer(columns, rowData, index)\n        : columns}\n      {this.contextMenuRenderer(index)}\n    </FocusableRow>\n  )\n\n  render() {\n    const {\n      children,\n      hasMoreRows,\n      height,\n      loadMoreRows,\n      onFilter,\n      rowCount,\n      sortBy = '',\n      sortDirection,\n      width,\n      ...props\n    } = this.props\n\n    // This fixes an issue where the header of the DataGrid doesn't render on page load in Safari\n    const safariStyle = {\n      transform: `translateZ(0)`\n    }\n\n    const mappedChildren = this.mapChildren().filter(child => child !== null)\n    // TODO: Better type signature when accessing children props?\n    const spanData = mappedChildren.map((child: ReactElement) => ({\n      colspan: child.props.colspan ? child.props.colspan : () => 1,\n      width: child.props.width,\n      flexGrow: child.props.flexGrow\n    }))\n    // Get the actual width of all the columns. This is independent from the\n    // width prop.\n    this.totalWidth = mappedChildren.reduce<number>(\n      (total: number, child: ReactElement<BasicColumnProps>) =>\n        total + child.props.width,\n      0\n    )\n    // Convert the widths to percents so we can map them back to the real table\n    // width later.\n    this.columnWidthPercents = mappedChildren.map(\n      ({ props }: ReactElement) => props.width / this.totalWidth\n    )\n\n    this.columnTransformer = (\n      columns: ReactElement<any>[],\n      rowData,\n      rowIndex\n    ) => {\n      const spans = spanData.map(item => item.colspan(rowData))\n      const spannedColumns: ReactElement[] = []\n      let index = 0\n      while (index < columns.length) {\n        const span = spans[index]\n        const column = columns[index]\n        if (span > 1) {\n          const followingColumns = spanData.slice(index, span)\n          // find new width by adding current column width plus columns that are spanned over\n\n          const width = followingColumns.reduce(\n            (accumulator, { width }: { width: number }) => accumulator + width,\n            0\n          )\n\n          const flexGrow = followingColumns.reduce(\n            (accumulator, { flexGrow }: { flexGrow: number }) =>\n              accumulator + flexGrow,\n            0\n          )\n          spannedColumns.push(\n            cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`,\n              style: {\n                ...Elements.cellResetStyle,\n                flex: `0 1 ${width}px`,\n                flexGrow\n              }\n            })\n          )\n          index += span // skip columns that have been spanned over\n        } else {\n          spannedColumns.push(\n            cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`\n            })\n          )\n          index++\n        }\n      }\n      return spannedColumns\n    }\n\n    const TableComponent =\n      this.props.scrollWidth !== undefined ? ScrollableTable : Table\n\n    return (\n      <Elements.TableContainer\n        css={{ width, height }}\n        onKeyDown={this.handleKeyDown}\n        onKeyUp={this.handleKeyUp}\n        data-instrumentation={`${this.props['data-instrumentation']}-grid`}\n      >\n        <InfiniteLoader\n          isRowLoaded={this.isRowLoaded}\n          loadMoreRows={loadMoreRows || (() => Promise.resolve(false))}\n          rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n          threshold={5}\n          ref={this.infiniteTable}\n        >\n          {({ onRowsRendered, registerChild }) => (\n            <TableComponent\n              style={safariStyle}\n              gridStyle={{ outline: 'none' }}\n              headerHeight={36}\n              rowHeight={30}\n              sortBy={sortBy}\n              sortDirection={sortDirection}\n              ref={registerChild}\n              noRowsRendered={() => <div>No results</div>}\n              onRowsRendered={onRowsRendered}\n              onScroll={\n                this.state.activeContextMenu\n                  ? () => this.closeContextMenu()\n                  : undefined\n              }\n              rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n              headerRowRenderer={this.headerRowRenderer}\n              rowRenderer={this.rowRenderer}\n              // account for border width of container\n              width={width - 2}\n              height={height - 2}\n              {...props}\n            >\n              {mappedChildren}\n            </TableComponent>\n          )}\n        </InfiniteLoader>\n      </Elements.TableContainer>\n    )\n  }\n}\n\nexport default DataGrid\n"]} */"),
559
554
  onKeyDown: this.handleKeyDown,
560
555
  onKeyUp: this.handleKeyUp,
561
556
  "data-instrumentation": "".concat(this.props['data-instrumentation'], "-grid"),
@@ -115,7 +115,7 @@ export declare const InlineInput: StyledComponent<{
115
115
  color: string;
116
116
  focusBorderColor: string;
117
117
  placeholderColor: string;
118
- }) | undefined;
118
+ } | "neutral") | undefined;
119
119
  } & Omit<import("react").InputHTMLAttributes<HTMLInputElement>, "onChange"> & Omit<import("react").TextareaHTMLAttributes<HTMLTextAreaElement>, "onChange"> & {
120
120
  theme?: import("@emotion/react").Theme | undefined;
121
121
  } & InlineInputProps, {}, {
@@ -270,8 +270,6 @@ var UnstyledDateControl = exports.UnstyledDateControl = function UnstyledDateCon
270
270
  if (!dateIsValid || !onChange) {
271
271
  return;
272
272
  }
273
-
274
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
275
273
  var newDate = (0, _dateFns.setSeconds)((0, _dateFns.setMinutes)((0, _dateFns.setHours)(value || new Date(), valueParts.hours), valueParts.minutes), valueParts.seconds);
276
274
  onChange({
277
275
  name: name,
@@ -4,7 +4,7 @@ import type { PLACEMENT } from '../TooltipPopover';
4
4
  export declare const CLOSE_KEYS: string[];
5
5
  export declare const FORMAT_DATE_ERROR_MESSAGE = "Format M/d/yyyy";
6
6
  export declare const DATE_FORMAT = "yyyy-M-d HH:mm:ss";
7
- export declare const FORMAT_ERROR_MESSAGE: string;
7
+ export declare const FORMAT_ERROR_MESSAGE = "Format yyyy-M-d HH:mm:ss";
8
8
  export declare const DISABLED_DAY_ERROR_MESSAGE = "That date is disabled";
9
9
  export type DateFieldProps = Omit<FormFieldProps<'text'>, 'value' | 'onChange' | 'type'> & {
10
10
  clearable?: boolean;
@@ -54,7 +54,7 @@ export declare class UnstyledDateField extends Component<DateFieldProps, DateFie
54
54
  };
55
55
  inputRef: import("react").RefObject<HTMLInputElement>;
56
56
  datePickerRef: import("react").RefObject<HTMLDivElement>;
57
- constructor(props: DateFieldProps, context: any);
57
+ constructor(props: DateFieldProps, context?: any);
58
58
  componentDidUpdate(prevProps: DateFieldProps): void;
59
59
  show: () => void;
60
60
  hide: () => void;
@@ -67,10 +67,6 @@ export declare class UnstyledDateField extends Component<DateFieldProps, DateFie
67
67
  value: any;
68
68
  }) => void;
69
69
  getErrors: () => string[] | undefined;
70
- /**
71
- * @typescript-eslint/no-unused-vars is added because even though the props are not used in this component
72
- * they are getting destructured into ...props and passed further down the tree
73
- */
74
70
  render(): import("@emotion/react/jsx-runtime").JSX.Element;
75
71
  }
76
72
  export default function DateField(props: any): import("@emotion/react/jsx-runtime").JSX.Element;