@ultraviolet/ui 1.51.3 → 1.51.4

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 (149) hide show
  1. package/dist/components/ActionBar/index.cjs +32 -0
  2. package/dist/components/Alert/index.cjs +117 -0
  3. package/dist/components/Avatar/index.cjs +59 -0
  4. package/dist/components/Badge/index.cjs +101 -0
  5. package/dist/components/Banner/assets/default-image-small.svg.cjs +3 -0
  6. package/dist/components/Banner/assets/default-image.svg.cjs +3 -0
  7. package/dist/components/Banner/index.cjs +118 -0
  8. package/dist/components/BarChart/Tooltip.cjs +42 -0
  9. package/dist/components/BarChart/index.cjs +69 -0
  10. package/dist/components/BarStack/index.cjs +116 -0
  11. package/dist/components/Breadcrumbs/index.cjs +75 -0
  12. package/dist/components/Bullet/index.cjs +86 -0
  13. package/dist/components/Button/index.cjs +251 -0
  14. package/dist/components/Card/index.cjs +54 -0
  15. package/dist/components/Carousel/index.cjs +125 -0
  16. package/dist/components/Checkbox/index.cjs +264 -0
  17. package/dist/components/CheckboxGroup/index.cjs +118 -0
  18. package/dist/components/CopyButton/index.cjs +25 -0
  19. package/dist/components/DateInput/datepicker.css.cjs +3 -0
  20. package/dist/components/DateInput/index.cjs +185 -0
  21. package/dist/components/Dialog/Context.cjs +13 -0
  22. package/dist/components/Dialog/index.cjs +68 -0
  23. package/dist/components/Dialog/subComponents/Button.cjs +15 -0
  24. package/dist/components/Dialog/subComponents/Buttons.cjs +12 -0
  25. package/dist/components/Dialog/subComponents/CancelButton.cjs +9 -0
  26. package/dist/components/Dialog/subComponents/Stack.cjs +8 -0
  27. package/dist/components/Dialog/subComponents/Text.cjs +8 -0
  28. package/dist/components/EmptyState/index.cjs +92 -0
  29. package/dist/components/Expandable/index.cjs +77 -0
  30. package/dist/components/GlobalAlert/GlobalAlertLink.cjs +23 -0
  31. package/dist/components/GlobalAlert/index.cjs +61 -0
  32. package/dist/components/LineChart/CustomLegend.cjs +115 -0
  33. package/dist/components/LineChart/Tooltip.cjs +37 -0
  34. package/dist/components/LineChart/helpers.cjs +52 -0
  35. package/dist/components/LineChart/index.cjs +101 -0
  36. package/dist/components/Link/index.cjs +130 -0
  37. package/dist/components/List/Body.cjs +18 -0
  38. package/dist/components/List/Cell.cjs +43 -0
  39. package/dist/components/List/HeaderCell.cjs +84 -0
  40. package/dist/components/List/HeaderRow.cjs +38 -0
  41. package/dist/components/List/ListContext.cjs +136 -0
  42. package/dist/components/List/Row.cjs +163 -0
  43. package/dist/components/List/SelectBar.cjs +54 -0
  44. package/dist/components/List/SkeletonRows.cjs +57 -0
  45. package/dist/components/List/constants.cjs +6 -0
  46. package/dist/components/List/index.cjs +62 -0
  47. package/dist/components/Loader/index.cjs +79 -0
  48. package/dist/components/Menu/Item.cjs +92 -0
  49. package/dist/components/Menu/index.cjs +118 -0
  50. package/dist/components/MenuV2/Group.cjs +23 -0
  51. package/dist/components/MenuV2/Item.cjs +114 -0
  52. package/dist/components/MenuV2/index.cjs +92 -0
  53. package/dist/components/Meter/index.cjs +65 -0
  54. package/dist/components/Modal/Dialog.cjs +143 -0
  55. package/dist/components/Modal/Disclosure.cjs +44 -0
  56. package/dist/components/Modal/constants.cjs +52 -0
  57. package/dist/components/Modal/index.cjs +81 -0
  58. package/dist/components/Notice/index.cjs +25 -0
  59. package/dist/components/Notification/index.cjs +49 -0
  60. package/dist/components/Notification/react-toastify.css.cjs +3 -0
  61. package/dist/components/NumberInput/helpers.cjs +10 -0
  62. package/dist/components/NumberInput/index.cjs +264 -0
  63. package/dist/components/NumberInputV2/index.cjs +223 -0
  64. package/dist/components/Pagination/getPageNumbers.cjs +23 -0
  65. package/dist/components/Pagination/index.cjs +90 -0
  66. package/dist/components/PasswordCheck/index.cjs +26 -0
  67. package/dist/components/PasswordStrengthMeter/index.cjs +98 -0
  68. package/dist/components/PieChart/Legends.cjs +143 -0
  69. package/dist/components/PieChart/Tooltip.cjs +50 -0
  70. package/dist/components/PieChart/index.cjs +103 -0
  71. package/dist/components/Popover/index.cjs +102 -0
  72. package/dist/components/Popup/animations.cjs +25 -0
  73. package/dist/components/Popup/helpers.cjs +216 -0
  74. package/dist/components/Popup/index.cjs +299 -0
  75. package/dist/components/ProgressBar/index.cjs +55 -0
  76. package/dist/components/Radio/index.cjs +135 -0
  77. package/dist/components/RadioGroup/index.cjs +101 -0
  78. package/dist/components/Row/index.cjs +36 -0
  79. package/dist/components/SelectInput/index.cjs +520 -0
  80. package/dist/components/SelectInputV2/Dropdown.cjs +431 -0
  81. package/dist/components/SelectInputV2/DropdownOption.cjs +64 -0
  82. package/dist/components/SelectInputV2/SearchBarDropdown.cjs +109 -0
  83. package/dist/components/SelectInputV2/SelectBar.cjs +226 -0
  84. package/dist/components/SelectInputV2/SelectInputProvider.cjs +171 -0
  85. package/dist/components/SelectInputV2/findOptionInOptions.cjs +12 -0
  86. package/dist/components/SelectInputV2/index.cjs +89 -0
  87. package/dist/components/SelectInputV2/types.cjs +13 -0
  88. package/dist/components/SelectableCard/index.cjs +139 -0
  89. package/dist/components/SelectableCardGroup/index.cjs +109 -0
  90. package/dist/components/Separator/index.cjs +58 -0
  91. package/dist/components/Skeleton/Block.cjs +40 -0
  92. package/dist/components/Skeleton/Blocks.cjs +40 -0
  93. package/dist/components/Skeleton/BoxWithIcon.cjs +38 -0
  94. package/dist/components/Skeleton/Donut.cjs +63 -0
  95. package/dist/components/Skeleton/IconSkeleton.cjs +24 -0
  96. package/dist/components/Skeleton/Line.cjs +18 -0
  97. package/dist/components/Skeleton/List.cjs +58 -0
  98. package/dist/components/Skeleton/Slider.cjs +42 -0
  99. package/dist/components/Skeleton/Square.cjs +14 -0
  100. package/dist/components/Skeleton/index.cjs +81 -0
  101. package/dist/components/Snippet/index.cjs +184 -0
  102. package/dist/components/Stack/index.cjs +31 -0
  103. package/dist/components/Status/index.cjs +74 -0
  104. package/dist/components/StepList/index.cjs +60 -0
  105. package/dist/components/Stepper/index.cjs +147 -0
  106. package/dist/components/SwitchButton/FocusOverlay.cjs +40 -0
  107. package/dist/components/SwitchButton/index.cjs +78 -0
  108. package/dist/components/Table/Body.cjs +7 -0
  109. package/dist/components/Table/Cell.cjs +21 -0
  110. package/dist/components/Table/Header.cjs +18 -0
  111. package/dist/components/Table/HeaderCell.cjs +82 -0
  112. package/dist/components/Table/HeaderRow.cjs +23 -0
  113. package/dist/components/Table/Row.cjs +82 -0
  114. package/dist/components/Table/SelectBar.cjs +54 -0
  115. package/dist/components/Table/SkeletonRows.cjs +56 -0
  116. package/dist/components/Table/TableContext.cjs +88 -0
  117. package/dist/components/Table/index.cjs +69 -0
  118. package/dist/components/Tabs/Tab.cjs +122 -0
  119. package/dist/components/Tabs/TabMenu.cjs +64 -0
  120. package/dist/components/Tabs/TabMenuItem.cjs +36 -0
  121. package/dist/components/Tabs/TabsContext.cjs +7 -0
  122. package/dist/components/Tabs/index.cjs +104 -0
  123. package/dist/components/Tag/index.cjs +147 -0
  124. package/dist/components/TagInput/index.cjs +255 -0
  125. package/dist/components/TagList/index.cjs +100 -0
  126. package/dist/components/Text/index.cjs +84 -0
  127. package/dist/components/TextArea/index.cjs +160 -0
  128. package/dist/components/TextInput/index.cjs +390 -0
  129. package/dist/components/TextInputV2/index.cjs +192 -0
  130. package/dist/components/TimeInput/index.cjs +28 -0
  131. package/dist/components/Toaster/index.cjs +85 -0
  132. package/dist/components/Toaster/react-toastify.css.cjs +3 -0
  133. package/dist/components/Toggle/index.cjs +138 -0
  134. package/dist/components/ToggleGroup/index.cjs +98 -0
  135. package/dist/components/Tooltip/index.cjs +42 -0
  136. package/dist/components/VerificationCode/index.cjs +219 -0
  137. package/dist/helpers/isJSON.cjs +10 -0
  138. package/dist/helpers/legend.cjs +14 -0
  139. package/dist/helpers/recursivelyGetChildrenString.cjs +14 -0
  140. package/dist/hooks/useIsOverflowing.cjs +23 -0
  141. package/dist/index.cjs +196 -0
  142. package/dist/theme/index.cjs +34 -0
  143. package/dist/utils/animations.cjs +276 -0
  144. package/dist/utils/capitalize.cjs +3 -0
  145. package/dist/utils/ids.cjs +8 -0
  146. package/dist/utils/normalize.cjs +36 -0
  147. package/dist/utils/responsive/Breakpoint.cjs +16 -0
  148. package/dist/utils/responsive/utilities.cjs +15 -0
  149. package/package.json +22 -6
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const React = require("react");
5
+ const ListContext = React.createContext(void 0);
6
+ const ListProvider = ({
7
+ children,
8
+ autoCollapse,
9
+ selectable,
10
+ expandButton,
11
+ onSelectedChange
12
+ }) => {
13
+ const [expandedRowIds, setExpandedRowIds] = React.useState({});
14
+ const [selectedRowIds, setSelectedRowIds] = React.useState({});
15
+ const registerExpandableRow = React.useCallback((rowId) => {
16
+ setExpandedRowIds((current) => ({
17
+ ...current,
18
+ [rowId]: false
19
+ }));
20
+ return () => {
21
+ setExpandedRowIds((current) => {
22
+ const {
23
+ [rowId]: relatedId,
24
+ ...otherIds
25
+ } = current;
26
+ return otherIds;
27
+ });
28
+ };
29
+ }, []);
30
+ const registerSelectableRow = React.useCallback((rowId) => {
31
+ setSelectedRowIds((current) => ({
32
+ ...current,
33
+ [rowId]: false
34
+ }));
35
+ return () => {
36
+ setSelectedRowIds((current) => {
37
+ const {
38
+ [rowId]: relatedId,
39
+ ...otherIds
40
+ } = current;
41
+ return otherIds;
42
+ });
43
+ };
44
+ }, []);
45
+ const expandRow = React.useCallback((rowId) => {
46
+ setExpandedRowIds((current) => ({
47
+ ...autoCollapse ? {} : current,
48
+ [rowId]: true
49
+ }));
50
+ }, [autoCollapse]);
51
+ const collapseRow = React.useCallback((rowId) => {
52
+ setExpandedRowIds((current) => ({
53
+ ...current,
54
+ [rowId]: false
55
+ }));
56
+ }, []);
57
+ const allRowSelectValue = React.useMemo(() => {
58
+ const selectableRowCount = Object.keys(selectedRowIds).length;
59
+ if (!selectableRowCount) {
60
+ return false;
61
+ }
62
+ const selectedRowCount = Object.values(selectedRowIds).reduce((acc, isSelected) => acc + (isSelected ? 1 : 0), 0);
63
+ if (selectedRowCount === 0) {
64
+ return false;
65
+ }
66
+ if (selectableRowCount === selectedRowCount) {
67
+ return true;
68
+ }
69
+ return "indeterminate";
70
+ }, [selectedRowIds]);
71
+ const selectAll = React.useCallback(() => {
72
+ const newSelectedRowIds = Object.keys(selectedRowIds).reduce((acc, rowId) => ({
73
+ ...acc,
74
+ [rowId]: true
75
+ }), {});
76
+ setSelectedRowIds(newSelectedRowIds);
77
+ if (onSelectedChange) {
78
+ onSelectedChange(Object.keys(newSelectedRowIds).filter((row) => newSelectedRowIds[row]));
79
+ }
80
+ }, [onSelectedChange, selectedRowIds]);
81
+ const unselectAll = React.useCallback(() => {
82
+ const newSelectedRowIds = Object.keys(selectedRowIds).reduce((acc, rowId) => ({
83
+ ...acc,
84
+ [rowId]: false
85
+ }), {});
86
+ setSelectedRowIds(newSelectedRowIds);
87
+ if (onSelectedChange) {
88
+ onSelectedChange(Object.keys(newSelectedRowIds).filter((row) => newSelectedRowIds[row]));
89
+ }
90
+ }, [onSelectedChange, selectedRowIds]);
91
+ const selectRow = React.useCallback((rowId) => {
92
+ const newSelectedRowIds = {
93
+ ...selectedRowIds,
94
+ [rowId]: true
95
+ };
96
+ setSelectedRowIds(newSelectedRowIds);
97
+ if (onSelectedChange) {
98
+ onSelectedChange(Object.keys(newSelectedRowIds).filter((row) => newSelectedRowIds[row]));
99
+ }
100
+ }, [onSelectedChange, selectedRowIds]);
101
+ const unselectRow = React.useCallback((rowId) => {
102
+ const newSelectedRowIds = {
103
+ ...selectedRowIds,
104
+ [rowId]: false
105
+ };
106
+ setSelectedRowIds(newSelectedRowIds);
107
+ if (onSelectedChange) {
108
+ onSelectedChange(Object.keys(newSelectedRowIds).filter((row) => newSelectedRowIds[row]));
109
+ }
110
+ }, [onSelectedChange, selectedRowIds]);
111
+ const value = React.useMemo(() => ({
112
+ registerExpandableRow,
113
+ expandedRowIds,
114
+ expandRow,
115
+ collapseRow,
116
+ registerSelectableRow,
117
+ selectedRowIds,
118
+ selectRow,
119
+ unselectRow,
120
+ selectable,
121
+ selectAll,
122
+ unselectAll,
123
+ allRowSelectValue,
124
+ expandButton
125
+ }), [registerExpandableRow, expandedRowIds, expandRow, collapseRow, registerSelectableRow, selectedRowIds, selectRow, unselectRow, selectable, selectAll, unselectAll, allRowSelectValue, expandButton]);
126
+ return /* @__PURE__ */ jsxRuntime.jsx(ListContext.Provider, { value, children });
127
+ };
128
+ const useListContext = () => {
129
+ const context = React.useContext(ListContext);
130
+ if (!context) {
131
+ throw new Error("useListContext should be used inside a List component");
132
+ }
133
+ return context;
134
+ };
135
+ exports.ListProvider = ListProvider;
136
+ exports.useListContext = useListContext;
@@ -0,0 +1,163 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const React = require("react");
6
+ const index$2 = require("../Button/index.cjs");
7
+ const index$1 = require("../Checkbox/index.cjs");
8
+ const index = require("../Tooltip/index.cjs");
9
+ const Cell = require("./Cell.cjs");
10
+ const ListContext = require("./ListContext.cjs");
11
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
12
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
13
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
14
+ return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
15
+ }
16
+ const ExpandableWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
17
+ target: "ei4uyz12"
18
+ } : {
19
+ target: "ei4uyz12",
20
+ label: "ExpandableWrapper"
21
+ })("grid-column:1/-1;grid-column-start:1;border-top:1px solid ", ({
22
+ theme
23
+ }) => theme.colors.neutral.border, ";margin:0 -", ({
24
+ theme
25
+ }) => theme.space["2"], ";padding:", ({
26
+ theme
27
+ }) => theme.space["2"], ";cursor:auto;background:", ({
28
+ theme
29
+ }) => theme.colors.neutral.backgroundWeak, ";border-radius:0 0 ", ({
30
+ theme
31
+ }) => theme.radii.default, " ", ({
32
+ theme
33
+ }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AAUoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  className?: string\n  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = () => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n        onKeyDown={\n          canClickRowToExpand\n            ? event => {\n                if (event.key === ' ') {\n                  toggleRowExpand()\n                  event.preventDefault()\n                }\n              }\n            : undefined\n        }\n        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell preventClick>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
34
+ const StyledRow = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
35
+ shouldForwardProp: (prop) => !["sentiment"].includes(prop),
36
+ target: "ei4uyz11"
37
+ } : {
38
+ shouldForwardProp: (prop) => !["sentiment"].includes(prop),
39
+ target: "ei4uyz11",
40
+ label: "StyledRow"
41
+ })("position:relative;border:1px solid ", ({
42
+ theme
43
+ }) => theme.colors.neutral.border, ";border-radius:", ({
44
+ theme
45
+ }) => theme.radii.default, ";transition:box-shadow 200ms ease,border-color 200ms ease;box-shadow:none;background-color:", ({
46
+ theme
47
+ }) => theme.colors.neutral.background, ";font-size:", ({
48
+ theme
49
+ }) => theme.typography.bodySmall.fontSize, ";column-gap:", ({
50
+ theme
51
+ }) => theme.space["2"], ";padding:0 ", ({
52
+ theme
53
+ }) => theme.space["2"], ";&[role='button row']{cursor:pointer;}", ({
54
+ theme,
55
+ sentiment
56
+ }) => `
57
+ color: ${theme.colors[sentiment].text};
58
+ border-color: ${theme.colors[sentiment].border};
59
+ background-color: ${theme.colors[sentiment].background};
60
+ & [data-expandable-content] {
61
+ border-color: ${theme.colors[sentiment].border};
62
+ }
63
+
64
+ ${sentiment === "neutral" ? `&:hover {
65
+ border-color: ${theme.colors.primary.border};
66
+ box-shadow: ${theme.shadows.hoverPrimary};
67
+ }
68
+ ` : ""}
69
+ `, " &[data-highlight='true']{border-color:", ({
70
+ theme
71
+ }) => theme.colors.primary.border, ";box-shadow:", ({
72
+ theme
73
+ }) => theme.shadows.hoverPrimary, ";}&[aria-disabled='true']{border:1px solid ", ({
74
+ theme
75
+ }) => theme.colors.neutral.borderDisabled, ";background-color:", ({
76
+ theme
77
+ }) => theme.colors.neutral.backgroundDisabled, ";color:", ({
78
+ theme
79
+ }) => theme.colors.neutral.textDisabled, ";cursor:not-allowed;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AA0BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  className?: string\n  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = () => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n        onKeyDown={\n          canClickRowToExpand\n            ? event => {\n                if (event.key === ' ') {\n                  toggleRowExpand()\n                  event.preventDefault()\n                }\n              }\n            : undefined\n        }\n        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell preventClick>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
80
+ const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
81
+ target: "ei4uyz10"
82
+ } : {
83
+ target: "ei4uyz10",
84
+ label: "StyledCheckboxContainer"
85
+ })(process.env.NODE_ENV === "production" ? {
86
+ name: "zjik7",
87
+ styles: "display:flex"
88
+ } : {
89
+ name: "zjik7",
90
+ styles: "display:flex",
91
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AA8E0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  className?: string\n  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = () => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n        onKeyDown={\n          canClickRowToExpand\n            ? event => {\n                if (event.key === ' ') {\n                  toggleRowExpand()\n                  event.preventDefault()\n                }\n              }\n            : undefined\n        }\n        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell preventClick>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */",
92
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
+ });
94
+ const Row = React.forwardRef(({
95
+ children,
96
+ id,
97
+ expandable,
98
+ disabled,
99
+ selectDisabled,
100
+ sentiment = "neutral",
101
+ className,
102
+ "data-testid": dataTestid
103
+ }, ref) => {
104
+ const {
105
+ selectable,
106
+ registerExpandableRow,
107
+ expandedRowIds,
108
+ expandRow,
109
+ collapseRow,
110
+ registerSelectableRow,
111
+ selectedRowIds,
112
+ selectRow,
113
+ unselectRow,
114
+ expandButton
115
+ } = ListContext.useListContext();
116
+ const isSelectDisabled = disabled || selectDisabled !== void 0 && selectDisabled !== false;
117
+ const hasExpandable = !!expandable;
118
+ React.useEffect(() => {
119
+ if (hasExpandable) {
120
+ const unregisterCallback = registerExpandableRow(id);
121
+ return unregisterCallback;
122
+ }
123
+ return void 0;
124
+ }, [id, hasExpandable, registerExpandableRow]);
125
+ React.useEffect(() => {
126
+ if (!isSelectDisabled) {
127
+ const unregisterCallback = registerSelectableRow(id);
128
+ return unregisterCallback;
129
+ }
130
+ return void 0;
131
+ }, [id, registerSelectableRow, isSelectDisabled]);
132
+ const toggleRowExpand = () => {
133
+ if (expandedRowIds[id]) {
134
+ collapseRow(id);
135
+ } else {
136
+ expandRow(id);
137
+ }
138
+ };
139
+ const canClickRowToExpand = !disabled && !!expandable && !expandButton;
140
+ return /* @__PURE__ */ jsxRuntime.jsxs(StyledRow, { className, ref, role: canClickRowToExpand ? "button row" : "row", onClick: canClickRowToExpand ? toggleRowExpand : void 0, onKeyDown: canClickRowToExpand ? (event) => {
141
+ if (event.key === " ") {
142
+ toggleRowExpand();
143
+ event.preventDefault();
144
+ }
145
+ } : void 0, tabIndex: canClickRowToExpand ? 0 : -1, sentiment, "aria-disabled": disabled, "aria-expanded": expandable ? expandedRowIds[id] : void 0, "data-highlight": !!selectedRowIds[id], "data-testid": dataTestid, children: [
146
+ selectable ? /* @__PURE__ */ jsxRuntime.jsx(Cell.Cell, { preventClick: canClickRowToExpand, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckboxContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Checkbox, { name: "list-select-checkbox", "aria-label": "select", checked: selectedRowIds[id], value: id, onChange: () => {
147
+ if (selectedRowIds[id]) {
148
+ unselectRow(id);
149
+ } else {
150
+ selectRow(id);
151
+ }
152
+ }, disabled: isSelectDisabled }) }) }) }) : null,
153
+ expandButton ? /* @__PURE__ */ jsxRuntime.jsx(Cell.Cell, { preventClick: true, children: /* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { disabled: disabled || !expandable, icon: expandedRowIds[id] ? "arrow-up" : "arrow-down", onClick: toggleRowExpand, size: "small", sentiment: "neutral", variant: "ghost" }) }) : null,
154
+ children,
155
+ expandable && expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(ExpandableWrapper, { "data-expandable-content": true, onClick: canClickRowToExpand ? (e) => {
156
+ e.stopPropagation();
157
+ } : void 0, onKeyDown: canClickRowToExpand ? (e) => {
158
+ e.stopPropagation();
159
+ } : void 0, children: expandable }) : null
160
+ ] });
161
+ });
162
+ exports.Row = Row;
163
+ exports.StyledRow = StyledRow;
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const React = require("react");
6
+ const index = require("../ActionBar/index.cjs");
7
+ const ListContext = require("./ListContext.cjs");
8
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
9
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
10
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
11
+ return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
12
+ }
13
+ const StyledActionBar = /* @__PURE__ */ _styled__default.default(index.ActionBar, process.env.NODE_ENV === "production" ? {
14
+ target: "eo69e461"
15
+ } : {
16
+ target: "eo69e461",
17
+ label: "StyledActionBar"
18
+ })("display:flex;align-items:center;padding:0 ", ({
19
+ theme
20
+ }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvU2VsZWN0QmFyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNeUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9TZWxlY3RCYXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQWN0aW9uQmFyIH0gZnJvbSAnLi4vQWN0aW9uQmFyJ1xuaW1wb3J0IHsgdXNlTGlzdENvbnRleHQgfSBmcm9tICcuL0xpc3RDb250ZXh0J1xuXG5jb25zdCBTdHlsZWRBY3Rpb25CYXIgPSBzdHlsZWQoQWN0aW9uQmFyKWBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuYFxuXG5jb25zdCBGbGV4RGl2ID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMTtcbmBcblxudHlwZSBTZWxlY3RCYXJQcm9wczxUPiA9IHtcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGNoaWxkcmVuOiAocDogeyBzZWxlY3RlZEl0ZW1zOiBUW107IHVuc2VsZWN0QWxsOiAoKSA9PiB2b2lkIH0pID0+IFJlYWN0Tm9kZVxuICBkYXRhOiBUW11cbiAgLyoqXG4gICAqIFRoZSBpZEtleSBvZiBlYWNoIGRhdGEgZW50cnlcbiAgICogKi9cbiAgaWRLZXk6IGtleW9mIFRcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIFNlbGVjdEJhcjxUPih7XG4gIGNoaWxkcmVuLFxuICBkYXRhLFxuICBpZEtleSxcbiAgY2xhc3NOYW1lLFxufTogU2VsZWN0QmFyUHJvcHM8VD4pIHtcbiAgY29uc3QgeyBzZWxlY3RlZFJvd0lkcywgdW5zZWxlY3RBbGwgfSA9IHVzZUxpc3RDb250ZXh0KClcblxuICBjb25zdCBzZWxlY3RlZEl0ZW1zID0gdXNlTWVtbyhcbiAgICAoKSA9PiBkYXRhLmZpbHRlcihpdGVtID0+IHNlbGVjdGVkUm93SWRzW2l0ZW1baWRLZXldIGFzIHN0cmluZ10pLFxuICAgIFtkYXRhLCBpZEtleSwgc2VsZWN0ZWRSb3dJZHNdLFxuICApXG5cbiAgaWYgKHNlbGVjdGVkSXRlbXMubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuIG51bGxcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFjdGlvbkJhciBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICA8RmxleERpdj5cbiAgICAgICAge2NoaWxkcmVuKHtcbiAgICAgICAgICBzZWxlY3RlZEl0ZW1zLFxuICAgICAgICAgIHVuc2VsZWN0QWxsLFxuICAgICAgICB9KX1cbiAgICAgIDwvRmxleERpdj5cbiAgICA8L1N0eWxlZEFjdGlvbkJhcj5cbiAgKVxufVxuIl19 */"));
21
+ const FlexDiv = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
22
+ target: "eo69e460"
23
+ } : {
24
+ target: "eo69e460",
25
+ label: "FlexDiv"
26
+ })(process.env.NODE_ENV === "production" ? {
27
+ name: "82a6rk",
28
+ styles: "flex:1"
29
+ } : {
30
+ name: "82a6rk",
31
+ styles: "flex:1",
32
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvU2VsZWN0QmFyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZMEIiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9TZWxlY3RCYXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQWN0aW9uQmFyIH0gZnJvbSAnLi4vQWN0aW9uQmFyJ1xuaW1wb3J0IHsgdXNlTGlzdENvbnRleHQgfSBmcm9tICcuL0xpc3RDb250ZXh0J1xuXG5jb25zdCBTdHlsZWRBY3Rpb25CYXIgPSBzdHlsZWQoQWN0aW9uQmFyKWBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuYFxuXG5jb25zdCBGbGV4RGl2ID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMTtcbmBcblxudHlwZSBTZWxlY3RCYXJQcm9wczxUPiA9IHtcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGNoaWxkcmVuOiAocDogeyBzZWxlY3RlZEl0ZW1zOiBUW107IHVuc2VsZWN0QWxsOiAoKSA9PiB2b2lkIH0pID0+IFJlYWN0Tm9kZVxuICBkYXRhOiBUW11cbiAgLyoqXG4gICAqIFRoZSBpZEtleSBvZiBlYWNoIGRhdGEgZW50cnlcbiAgICogKi9cbiAgaWRLZXk6IGtleW9mIFRcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIFNlbGVjdEJhcjxUPih7XG4gIGNoaWxkcmVuLFxuICBkYXRhLFxuICBpZEtleSxcbiAgY2xhc3NOYW1lLFxufTogU2VsZWN0QmFyUHJvcHM8VD4pIHtcbiAgY29uc3QgeyBzZWxlY3RlZFJvd0lkcywgdW5zZWxlY3RBbGwgfSA9IHVzZUxpc3RDb250ZXh0KClcblxuICBjb25zdCBzZWxlY3RlZEl0ZW1zID0gdXNlTWVtbyhcbiAgICAoKSA9PiBkYXRhLmZpbHRlcihpdGVtID0+IHNlbGVjdGVkUm93SWRzW2l0ZW1baWRLZXldIGFzIHN0cmluZ10pLFxuICAgIFtkYXRhLCBpZEtleSwgc2VsZWN0ZWRSb3dJZHNdLFxuICApXG5cbiAgaWYgKHNlbGVjdGVkSXRlbXMubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuIG51bGxcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFjdGlvbkJhciBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICA8RmxleERpdj5cbiAgICAgICAge2NoaWxkcmVuKHtcbiAgICAgICAgICBzZWxlY3RlZEl0ZW1zLFxuICAgICAgICAgIHVuc2VsZWN0QWxsLFxuICAgICAgICB9KX1cbiAgICAgIDwvRmxleERpdj5cbiAgICA8L1N0eWxlZEFjdGlvbkJhcj5cbiAgKVxufVxuIl19 */",
33
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
34
+ });
35
+ function SelectBar({
36
+ children,
37
+ data,
38
+ idKey,
39
+ className
40
+ }) {
41
+ const {
42
+ selectedRowIds,
43
+ unselectAll
44
+ } = ListContext.useListContext();
45
+ const selectedItems = React.useMemo(() => data.filter((item) => selectedRowIds[item[idKey]]), [data, idKey, selectedRowIds]);
46
+ if (selectedItems.length === 0) {
47
+ return null;
48
+ }
49
+ return /* @__PURE__ */ jsxRuntime.jsx(StyledActionBar, { className, children: /* @__PURE__ */ jsxRuntime.jsx(FlexDiv, { children: children({
50
+ selectedItems,
51
+ unselectAll
52
+ }) }) });
53
+ }
54
+ exports.SelectBar = SelectBar;
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const index = require("../Skeleton/index.cjs");
6
+ const Cell = require("./Cell.cjs");
7
+ const Row = require("./Row.cjs");
8
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
9
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
10
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
11
+ return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
12
+ }
13
+ const StyledLoadingRow = /* @__PURE__ */ _styled__default.default(Row.StyledRow, process.env.NODE_ENV === "production" ? {
14
+ target: "efawmbb1"
15
+ } : {
16
+ target: "efawmbb1",
17
+ label: "StyledLoadingRow"
18
+ })(process.env.NODE_ENV === "production" ? {
19
+ name: "g8zzui",
20
+ styles: "cursor:progress"
21
+ } : {
22
+ name: "g8zzui",
23
+ styles: "cursor:progress",
24
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvU2tlbGV0b25Sb3dzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLMEMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9Ta2VsZXRvblJvd3MudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTa2VsZXRvbiB9IGZyb20gJy4uL1NrZWxldG9uJ1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vQ2VsbCdcbmltcG9ydCB7IFN0eWxlZFJvdyB9IGZyb20gJy4vUm93J1xuXG5jb25zdCBTdHlsZWRMb2FkaW5nUm93ID0gc3R5bGVkKFN0eWxlZFJvdylgXG4gIGN1cnNvcjogcHJvZ3Jlc3M7XG5gXG5cbmNvbnN0IFN0eWxlZFNrZWxldG9uID0gc3R5bGVkKFNrZWxldG9uKWBcbiAgd2lkdGg6IDgwJTtcbiAgbWF4LXdpZHRoOiAxMDAlO1xuYFxuXG50eXBlIExpc3RMb2FkaW5nU2tlbGV0b25Qcm9wcyA9IHtcbiAgc2VsZWN0YWJsZTogYm9vbGVhblxuICByb3dzOiBudW1iZXJcbiAgY29sczogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBTa2VsZXRvblJvd3MgPSAoe1xuICBzZWxlY3RhYmxlLFxuICByb3dzLFxuICBjb2xzLFxufTogTGlzdExvYWRpbmdTa2VsZXRvblByb3BzKSA9PiB7XG4gIGNvbnN0IHJvd0FycmF5ID0gQXJyYXkuZnJvbSh7IGxlbmd0aDogcm93cyB9LCAoXywgaW5kZXgpID0+IGluZGV4KVxuICBjb25zdCBjb2xBcnJheSA9IEFycmF5LmZyb20oeyBsZW5ndGg6IGNvbHMgfSwgKF8sIGluZGV4KSA9PiBpbmRleClcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7cm93QXJyYXkubWFwKGluZGV4ID0+IChcbiAgICAgICAgPFN0eWxlZExvYWRpbmdSb3dcbiAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICByb2xlPVwicm93XCJcbiAgICAgICAgICBpZD17YHNrZWxldG9uLSR7aW5kZXh9YH1cbiAgICAgICAgICBrZXk9e2luZGV4fVxuICAgICAgICA+XG4gICAgICAgICAge3NlbGVjdGFibGUgPyA8ZGl2IC8+IDogbnVsbH1cbiAgICAgICAgICB7Y29sQXJyYXkubWFwKGNvbHVtbkluZGV4ID0+IChcbiAgICAgICAgICAgIDxDZWxsIGtleT17Y29sdW1uSW5kZXh9PlxuICAgICAgICAgICAgICA8U3R5bGVkU2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgICAgICAgPC9DZWxsPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L1N0eWxlZExvYWRpbmdSb3c+XG4gICAgICApKX1cbiAgICA8Lz5cbiAgKVxufVxuIl19 */",
25
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
26
+ });
27
+ const StyledSkeleton = /* @__PURE__ */ _styled__default.default(index.Skeleton, process.env.NODE_ENV === "production" ? {
28
+ target: "efawmbb0"
29
+ } : {
30
+ target: "efawmbb0",
31
+ label: "StyledSkeleton"
32
+ })(process.env.NODE_ENV === "production" ? {
33
+ name: "bet25o",
34
+ styles: "width:80%;max-width:100%"
35
+ } : {
36
+ name: "bet25o",
37
+ styles: "width:80%;max-width:100%",
38
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvU2tlbGV0b25Sb3dzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9Ta2VsZXRvblJvd3MudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTa2VsZXRvbiB9IGZyb20gJy4uL1NrZWxldG9uJ1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vQ2VsbCdcbmltcG9ydCB7IFN0eWxlZFJvdyB9IGZyb20gJy4vUm93J1xuXG5jb25zdCBTdHlsZWRMb2FkaW5nUm93ID0gc3R5bGVkKFN0eWxlZFJvdylgXG4gIGN1cnNvcjogcHJvZ3Jlc3M7XG5gXG5cbmNvbnN0IFN0eWxlZFNrZWxldG9uID0gc3R5bGVkKFNrZWxldG9uKWBcbiAgd2lkdGg6IDgwJTtcbiAgbWF4LXdpZHRoOiAxMDAlO1xuYFxuXG50eXBlIExpc3RMb2FkaW5nU2tlbGV0b25Qcm9wcyA9IHtcbiAgc2VsZWN0YWJsZTogYm9vbGVhblxuICByb3dzOiBudW1iZXJcbiAgY29sczogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBTa2VsZXRvblJvd3MgPSAoe1xuICBzZWxlY3RhYmxlLFxuICByb3dzLFxuICBjb2xzLFxufTogTGlzdExvYWRpbmdTa2VsZXRvblByb3BzKSA9PiB7XG4gIGNvbnN0IHJvd0FycmF5ID0gQXJyYXkuZnJvbSh7IGxlbmd0aDogcm93cyB9LCAoXywgaW5kZXgpID0+IGluZGV4KVxuICBjb25zdCBjb2xBcnJheSA9IEFycmF5LmZyb20oeyBsZW5ndGg6IGNvbHMgfSwgKF8sIGluZGV4KSA9PiBpbmRleClcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7cm93QXJyYXkubWFwKGluZGV4ID0+IChcbiAgICAgICAgPFN0eWxlZExvYWRpbmdSb3dcbiAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICByb2xlPVwicm93XCJcbiAgICAgICAgICBpZD17YHNrZWxldG9uLSR7aW5kZXh9YH1cbiAgICAgICAgICBrZXk9e2luZGV4fVxuICAgICAgICA+XG4gICAgICAgICAge3NlbGVjdGFibGUgPyA8ZGl2IC8+IDogbnVsbH1cbiAgICAgICAgICB7Y29sQXJyYXkubWFwKGNvbHVtbkluZGV4ID0+IChcbiAgICAgICAgICAgIDxDZWxsIGtleT17Y29sdW1uSW5kZXh9PlxuICAgICAgICAgICAgICA8U3R5bGVkU2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgICAgICAgPC9DZWxsPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L1N0eWxlZExvYWRpbmdSb3c+XG4gICAgICApKX1cbiAgICA8Lz5cbiAgKVxufVxuIl19 */",
39
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
40
+ });
41
+ const SkeletonRows = ({
42
+ selectable,
43
+ rows,
44
+ cols
45
+ }) => {
46
+ const rowArray = Array.from({
47
+ length: rows
48
+ }, (_, index2) => index2);
49
+ const colArray = Array.from({
50
+ length: cols
51
+ }, (_, index2) => index2);
52
+ return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: rowArray.map((index2) => /* @__PURE__ */ jsxRuntime.jsxs(StyledLoadingRow, { sentiment: "neutral", role: "row", id: `skeleton-${index2}`, children: [
53
+ selectable ? /* @__PURE__ */ jsxRuntime.jsx("div", {}) : null,
54
+ colArray.map((columnIndex) => /* @__PURE__ */ jsxRuntime.jsx(Cell.Cell, { children: /* @__PURE__ */ jsxRuntime.jsx(StyledSkeleton, { variant: "line" }) }, columnIndex))
55
+ ] }, index2)) });
56
+ };
57
+ exports.SkeletonRows = SkeletonRows;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const SELECTABLE_CHECKBOX_SIZE = 24;
4
+ const EXPANDABLE_COLUMN_SIZE = 24;
5
+ exports.EXPANDABLE_COLUMN_SIZE = EXPANDABLE_COLUMN_SIZE;
6
+ exports.SELECTABLE_CHECKBOX_SIZE = SELECTABLE_CHECKBOX_SIZE;
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const React = require("react");
6
+ const Body = require("./Body.cjs");
7
+ const Cell = require("./Cell.cjs");
8
+ const HeaderCell = require("./HeaderCell.cjs");
9
+ const HeaderRow = require("./HeaderRow.cjs");
10
+ const ListContext = require("./ListContext.cjs");
11
+ const Row = require("./Row.cjs");
12
+ const SelectBar = require("./SelectBar.cjs");
13
+ const SkeletonRows = require("./SkeletonRows.cjs");
14
+ const constants = require("./constants.cjs");
15
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
16
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
17
+ const StyledList = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
18
+ shouldForwardProp: (prop) => !["template"].includes(prop),
19
+ target: "ef5qi0"
20
+ } : {
21
+ shouldForwardProp: (prop) => !["template"].includes(prop),
22
+ target: "ef5qi0",
23
+ label: "StyledList"
24
+ })("display:flex;flex-flow:column nowrap;width:100%;gap:", ({
25
+ theme
26
+ }) => theme.space["1"], ";[role='row'],[role='button row']{display:grid;width:100%;grid-template-columns:", ({
27
+ template
28
+ }) => template, ";align-items:center;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCd0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHtcbiAgQ29tcG9uZW50UHJvcHMsXG4gIERpc3BhdGNoLFxuICBGb3J3YXJkZWRSZWYsXG4gIFJlYWN0Tm9kZSxcbiAgU2V0U3RhdGVBY3Rpb24sXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQm9keSB9IGZyb20gJy4vQm9keSdcbmltcG9ydCB7IENlbGwgfSBmcm9tICcuL0NlbGwnXG5pbXBvcnQgeyBIZWFkZXJDZWxsIH0gZnJvbSAnLi9IZWFkZXJDZWxsJ1xuaW1wb3J0IHsgSGVhZGVyUm93IH0gZnJvbSAnLi9IZWFkZXJSb3cnXG5pbXBvcnQgeyBMaXN0UHJvdmlkZXIsIHVzZUxpc3RDb250ZXh0IH0gZnJvbSAnLi9MaXN0Q29udGV4dCdcbmltcG9ydCB7IFJvdyB9IGZyb20gJy4vUm93J1xuaW1wb3J0IHsgU2VsZWN0QmFyIH0gZnJvbSAnLi9TZWxlY3RCYXInXG5pbXBvcnQgeyBTa2VsZXRvblJvd3MgfSBmcm9tICcuL1NrZWxldG9uUm93cydcbmltcG9ydCB7IEVYUEFOREFCTEVfQ09MVU1OX1NJWkUsIFNFTEVDVEFCTEVfQ0hFQ0tCT1hfU0laRSB9IGZyb20gJy4vY29uc3RhbnRzJ1xuXG5jb25zdCBTdHlsZWRMaXN0ID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3RlbXBsYXRlJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHRlbXBsYXRlOiBzdHJpbmcgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZmxvdzogY29sdW1uIG5vd3JhcDtcbiAgd2lkdGg6IDEwMCU7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICBbcm9sZT0ncm93J10sXG4gIFtyb2xlPSdidXR0b24gcm93J10ge1xuICAgIGRpc3BsYXk6IGdyaWQ7XG4gICAgd2lkdGg6IDEwMCU7XG4gICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyh7IHRlbXBsYXRlIH0pID0+IHRlbXBsYXRlfTtcbiAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB9XG5gXG5cbnR5cGUgQ29sdW1uUHJvcHMgPSBQaWNrPFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgSGVhZGVyQ2VsbD4sXG4gICdpc09yZGVyZWQnIHwgJ29uT3JkZXInIHwgJ29yZGVyRGlyZWN0aW9uJ1xuPiAmIHtcbiAgbGFiZWw/OiBzdHJpbmdcbiAgd2lkdGg/OiBzdHJpbmdcbiAgaW5mbz86IHN0cmluZ1xufVxuXG50eXBlIExpc3RQcm9wcyA9IHtcbiAgZXhwYW5kYWJsZT86IGJvb2xlYW5cbiAgc2VsZWN0YWJsZT86IGJvb2xlYW5cbiAgY29sdW1uczogQ29sdW1uUHJvcHNbXVxuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIC8qKlxuICAgKiBTZXQgaXQgdG8gdHJ1ZSBpZiB5b3Ugd2FudCB0byBkaXNwbGF5IGEgcGxhY2Vob2xkZXIgZHVyaW5nIGxvYWRpbmdcbiAgICogKi9cbiAgbG9hZGluZz86IGJvb2xlYW5cbiAgLyoqXG4gICAqIEF1dG8gY29sbGFwc2UgaXMgY29sbGFwc2luZyBleHBhbmRhYmxlIHJvdyB3aGVuIGFub3RoZXIgaXMgZXhwYW5kaW5nXG4gICAqICovXG4gIGF1dG9Db2xsYXBzZT86IGJvb2xlYW5cbiAgLyoqXG4gICAqIEFjdGlvbiB3aGVuIHNlbGVjdGlvbiBjaGFuZ2VzIChnZXQgdGhlIGxpc3Qgb2Ygc2VsZWN0ZWQgcm93cylcbiAgICovXG4gIG9uU2VsZWN0ZWRDaGFuZ2U/OiBEaXNwYXRjaDxTZXRTdGF0ZUFjdGlvbjxzdHJpbmdbXT4+XG59XG5cbmNvbnN0IEJhc2VMaXN0ID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGV4cGFuZGFibGUgPSBmYWxzZSxcbiAgICAgIHNlbGVjdGFibGUgPSBmYWxzZSxcbiAgICAgIGNvbHVtbnMsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGxvYWRpbmcsXG4gICAgICBhdXRvQ29sbGFwc2UgPSBmYWxzZSxcbiAgICAgIG9uU2VsZWN0ZWRDaGFuZ2UsXG4gICAgfTogTGlzdFByb3BzLFxuICAgIHJlZjogRm9yd2FyZGVkUmVmPEhUTUxEaXZFbGVtZW50PixcbiAgKSA9PiB7XG4gICAgY29uc3QgY29tcHV0ZVRlbXBsYXRlID0gYCR7XG4gICAgICBzZWxlY3RhYmxlID8gYCR7U0VMRUNUQUJMRV9DSEVDS0JPWF9TSVpFfXB4IGAgOiAnJ1xuICAgIH0ke1xuICAgICAgZXhwYW5kYWJsZSA/IGAke0VYUEFOREFCTEVfQ09MVU1OX1NJWkV9cHggYCA6ICcnXG4gICAgfSR7Y29sdW1ucy5tYXAoKHsgd2lkdGggfSkgPT4gd2lkdGggPz8gJ21pbm1heCgwLCAxZnIpJykuam9pbignICcpfWBcblxuICAgIHJldHVybiAoXG4gICAgICA8TGlzdFByb3ZpZGVyXG4gICAgICAgIHNlbGVjdGFibGU9e3NlbGVjdGFibGV9XG4gICAgICAgIGV4cGFuZEJ1dHRvbj17ZXhwYW5kYWJsZX1cbiAgICAgICAgYXV0b0NvbGxhcHNlPXthdXRvQ29sbGFwc2V9XG4gICAgICAgIG9uU2VsZWN0ZWRDaGFuZ2U9e29uU2VsZWN0ZWRDaGFuZ2V9XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRMaXN0IHJlZj17cmVmfSByb2xlPVwiZ3JpZFwiIHRlbXBsYXRlPXtjb21wdXRlVGVtcGxhdGV9PlxuICAgICAgICAgIDxIZWFkZXJSb3cgaGFzU2VsZWN0QWxsQ29sdW1uPXtzZWxlY3RhYmxlfT5cbiAgICAgICAgICAgIHtjb2x1bW5zLm1hcCgoY29sdW1uLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgICA8SGVhZGVyQ2VsbFxuICAgICAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9uby1hcnJheS1pbmRleC1rZXlcbiAgICAgICAgICAgICAgICBrZXk9e2BoZWFkZXItY29sdW1uLSR7aW5kZXh9YH1cbiAgICAgICAgICAgICAgICBpc09yZGVyZWQ9e2NvbHVtbi5pc09yZGVyZWR9XG4gICAgICAgICAgICAgICAgb3JkZXJEaXJlY3Rpb249e2NvbHVtbi5vcmRlckRpcmVjdGlvbn1cbiAgICAgICAgICAgICAgICBvbk9yZGVyPXtjb2x1bW4ub25PcmRlcn1cbiAgICAgICAgICAgICAgICBpbmZvPXtjb2x1bW4uaW5mb31cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtjb2x1bW4ubGFiZWx9XG4gICAgICAgICAgICAgIDwvSGVhZGVyQ2VsbD5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvSGVhZGVyUm93PlxuICAgICAgICAgIDxCb2R5PlxuICAgICAgICAgICAge2xvYWRpbmcgPyAoXG4gICAgICAgICAgICAgIDxTa2VsZXRvblJvd3NcbiAgICAgICAgICAgICAgICBzZWxlY3RhYmxlPXtzZWxlY3RhYmxlfVxuICAgICAgICAgICAgICAgIHJvd3M9ezV9XG4gICAgICAgICAgICAgICAgY29scz17Y29sdW1ucy5sZW5ndGh9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApIDogKFxuICAgICAgICAgICAgICBjaGlsZHJlblxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0JvZHk+XG4gICAgICAgIDwvU3R5bGVkTGlzdD5cbiAgICAgIDwvTGlzdFByb3ZpZGVyPlxuICAgIClcbiAgfSxcbilcblxuLyoqXG4gKiBMaXN0IGlzIGEgY29tcG9uZW50IHRoYXQgZGlzcGxheXMgYSBsaXN0IG9mIGl0ZW1zIGJhc2VkIG9uIHRoZSBjb2x1bW5zIHlvdSBwcm92aWRlIGFuZCB0aGUgZGF0YSB5b3UgcGFzcy5cbiAqL1xuZXhwb3J0IGNvbnN0IExpc3QgPSBPYmplY3QuYXNzaWduKEJhc2VMaXN0LCB7XG4gIFJvdyxcbiAgQ2VsbCxcbiAgU2VsZWN0QmFyLFxuICB1c2VMaXN0Q29udGV4dCxcbn0pXG4iXX0= */"));
29
+ const BaseList = React.forwardRef(({
30
+ expandable = false,
31
+ selectable = false,
32
+ columns,
33
+ children,
34
+ loading,
35
+ autoCollapse = false,
36
+ onSelectedChange
37
+ }, ref) => {
38
+ const computeTemplate = `${selectable ? `${constants.SELECTABLE_CHECKBOX_SIZE}px ` : ""}${expandable ? `${constants.EXPANDABLE_COLUMN_SIZE}px ` : ""}${columns.map(({
39
+ width
40
+ }) => width ?? "minmax(0, 1fr)").join(" ")}`;
41
+ return /* @__PURE__ */ jsxRuntime.jsx(ListContext.ListProvider, { selectable, expandButton: expandable, autoCollapse, onSelectedChange, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledList, { ref, role: "grid", template: computeTemplate, children: [
42
+ /* @__PURE__ */ jsxRuntime.jsx(HeaderRow.HeaderRow, { hasSelectAllColumn: selectable, children: columns.map((column, index) => /* @__PURE__ */ jsxRuntime.jsx(
43
+ HeaderCell.HeaderCell,
44
+ {
45
+ isOrdered: column.isOrdered,
46
+ orderDirection: column.orderDirection,
47
+ onOrder: column.onOrder,
48
+ info: column.info,
49
+ children: column.label
50
+ },
51
+ `header-column-${index}`
52
+ )) }),
53
+ /* @__PURE__ */ jsxRuntime.jsx(Body.Body, { children: loading ? /* @__PURE__ */ jsxRuntime.jsx(SkeletonRows.SkeletonRows, { selectable, rows: 5, cols: columns.length }) : children })
54
+ ] }) });
55
+ });
56
+ const List = Object.assign(BaseList, {
57
+ Row: Row.Row,
58
+ Cell: Cell.Cell,
59
+ SelectBar: SelectBar.SelectBar,
60
+ useListContext: ListContext.useListContext
61
+ });
62
+ exports.List = List;