@vuu-ui/vuu-table-extras 1.0.3 → 2.0.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 (181) hide show
  1. package/cjs/{column-expression-panel/ColumnExpressionPanel.js → calculated-column/CalculatedColumnPanel.js} +13 -13
  2. package/cjs/calculated-column/CalculatedColumnPanel.js.map +1 -0
  3. package/cjs/{column-expression-panel/useColumnExpression.js → calculated-column/useCalculatedColumnPanel.js} +12 -10
  4. package/cjs/calculated-column/useCalculatedColumnPanel.js.map +1 -0
  5. package/cjs/calculated-column/useEditCalculatedColumn.js +138 -0
  6. package/cjs/calculated-column/useEditCalculatedColumn.js.map +1 -0
  7. package/cjs/column-formatting-settings/BaseNumericFormattingSettings.js +1 -0
  8. package/cjs/column-formatting-settings/BaseNumericFormattingSettings.js.map +1 -1
  9. package/cjs/column-formatting-settings/ColumnFormattingPanel.js +1 -0
  10. package/cjs/column-formatting-settings/ColumnFormattingPanel.js.map +1 -1
  11. package/cjs/column-menu/ColumnMenu.js +3 -15
  12. package/cjs/column-menu/ColumnMenu.js.map +1 -1
  13. package/cjs/column-menu/column-menu-utils.js +1 -38
  14. package/cjs/column-menu/column-menu-utils.js.map +1 -1
  15. package/cjs/column-menu/useColumnActions.js +0 -2
  16. package/cjs/column-menu/useColumnActions.js.map +1 -1
  17. package/cjs/column-picker/ColumnModel.js +58 -0
  18. package/cjs/column-picker/ColumnModel.js.map +1 -1
  19. package/cjs/column-picker/ColumnPicker.css.js +1 -1
  20. package/cjs/column-picker/ColumnPicker.js +37 -14
  21. package/cjs/column-picker/ColumnPicker.js.map +1 -1
  22. package/cjs/column-picker/ColumnPickerAction.js +34 -0
  23. package/cjs/column-picker/ColumnPickerAction.js.map +1 -0
  24. package/cjs/column-picker/useColumnPicker.js.map +1 -1
  25. package/cjs/column-picker/useTableColumnPicker.js +35 -0
  26. package/cjs/column-picker/useTableColumnPicker.js.map +1 -0
  27. package/cjs/column-settings-panel/ColumnNameLabel.js.map +1 -0
  28. package/cjs/{table-column-settings → column-settings-panel}/ColumnSettingsPanel.css.js +1 -1
  29. package/cjs/column-settings-panel/ColumnSettingsPanel.js +161 -0
  30. package/cjs/column-settings-panel/ColumnSettingsPanel.js.map +1 -0
  31. package/cjs/{table-column-settings → column-settings-panel}/useColumnSettings.js +42 -79
  32. package/cjs/column-settings-panel/useColumnSettings.js.map +1 -0
  33. package/cjs/datasource-stats/DatasourceStats.css.js +1 -1
  34. package/cjs/index.js +20 -19
  35. package/cjs/index.js.map +1 -1
  36. package/cjs/tabbed-table-config-panel/TabbedTableConfigPanel.css.js +6 -0
  37. package/cjs/tabbed-table-config-panel/TabbedTableConfigPanel.css.js.map +1 -0
  38. package/cjs/tabbed-table-config-panel/TabbedTableConfigPanel.js +90 -0
  39. package/cjs/tabbed-table-config-panel/TabbedTableConfigPanel.js.map +1 -0
  40. package/cjs/tabbed-table-config-panel/TabbedTableSettingsAction.js +44 -0
  41. package/cjs/tabbed-table-config-panel/TabbedTableSettingsAction.js.map +1 -0
  42. package/cjs/tabbed-table-config-panel/useTabbedTableConfigPanel.js +49 -0
  43. package/cjs/tabbed-table-config-panel/useTabbedTableConfigPanel.js.map +1 -0
  44. package/cjs/table-footer/TableFooter.css.js +6 -0
  45. package/cjs/table-footer/TableFooter.css.js.map +1 -0
  46. package/cjs/table-footer/TableFooter.js +34 -0
  47. package/cjs/table-footer/TableFooter.js.map +1 -0
  48. package/cjs/{table-column-settings → table-settings-panel}/TableSettingsPanel.css.js +1 -1
  49. package/cjs/{table-column-settings → table-settings-panel}/TableSettingsPanel.js +12 -47
  50. package/cjs/table-settings-panel/TableSettingsPanel.js.map +1 -0
  51. package/cjs/table-settings-panel/useTableSettings.js +60 -0
  52. package/cjs/table-settings-panel/useTableSettings.js.map +1 -0
  53. package/esm/{column-expression-panel/ColumnExpressionPanel.js → calculated-column/CalculatedColumnPanel.js} +13 -13
  54. package/esm/calculated-column/CalculatedColumnPanel.js.map +1 -0
  55. package/esm/{column-expression-panel/useColumnExpression.js → calculated-column/useCalculatedColumnPanel.js} +12 -10
  56. package/esm/calculated-column/useCalculatedColumnPanel.js.map +1 -0
  57. package/esm/calculated-column/useEditCalculatedColumn.js +136 -0
  58. package/esm/calculated-column/useEditCalculatedColumn.js.map +1 -0
  59. package/esm/column-formatting-settings/BaseNumericFormattingSettings.js +1 -0
  60. package/esm/column-formatting-settings/BaseNumericFormattingSettings.js.map +1 -1
  61. package/esm/column-formatting-settings/ColumnFormattingPanel.js +1 -0
  62. package/esm/column-formatting-settings/ColumnFormattingPanel.js.map +1 -1
  63. package/esm/column-menu/ColumnMenu.js +4 -16
  64. package/esm/column-menu/ColumnMenu.js.map +1 -1
  65. package/esm/column-menu/column-menu-utils.js +2 -38
  66. package/esm/column-menu/column-menu-utils.js.map +1 -1
  67. package/esm/column-menu/useColumnActions.js +0 -2
  68. package/esm/column-menu/useColumnActions.js.map +1 -1
  69. package/esm/column-picker/ColumnModel.js +58 -0
  70. package/esm/column-picker/ColumnModel.js.map +1 -1
  71. package/esm/column-picker/ColumnPicker.css.js +1 -1
  72. package/esm/column-picker/ColumnPicker.js +39 -16
  73. package/esm/column-picker/ColumnPicker.js.map +1 -1
  74. package/esm/column-picker/ColumnPickerAction.js +32 -0
  75. package/esm/column-picker/ColumnPickerAction.js.map +1 -0
  76. package/esm/column-picker/useColumnPicker.js.map +1 -1
  77. package/esm/column-picker/useTableColumnPicker.js +33 -0
  78. package/esm/column-picker/useTableColumnPicker.js.map +1 -0
  79. package/esm/column-settings-panel/ColumnNameLabel.js.map +1 -0
  80. package/esm/{table-column-settings → column-settings-panel}/ColumnSettingsPanel.css.js +1 -1
  81. package/esm/column-settings-panel/ColumnSettingsPanel.js +159 -0
  82. package/esm/column-settings-panel/ColumnSettingsPanel.js.map +1 -0
  83. package/esm/{table-column-settings → column-settings-panel}/useColumnSettings.js +44 -81
  84. package/esm/column-settings-panel/useColumnSettings.js.map +1 -0
  85. package/esm/datasource-stats/DatasourceStats.css.js +1 -1
  86. package/esm/index.js +9 -7
  87. package/esm/index.js.map +1 -1
  88. package/esm/tabbed-table-config-panel/TabbedTableConfigPanel.css.js +4 -0
  89. package/esm/tabbed-table-config-panel/TabbedTableConfigPanel.css.js.map +1 -0
  90. package/esm/tabbed-table-config-panel/TabbedTableConfigPanel.js +88 -0
  91. package/esm/tabbed-table-config-panel/TabbedTableConfigPanel.js.map +1 -0
  92. package/esm/tabbed-table-config-panel/TabbedTableSettingsAction.js +42 -0
  93. package/esm/tabbed-table-config-panel/TabbedTableSettingsAction.js.map +1 -0
  94. package/esm/tabbed-table-config-panel/useTabbedTableConfigPanel.js +47 -0
  95. package/esm/tabbed-table-config-panel/useTabbedTableConfigPanel.js.map +1 -0
  96. package/esm/table-footer/TableFooter.css.js +4 -0
  97. package/esm/table-footer/TableFooter.css.js.map +1 -0
  98. package/esm/table-footer/TableFooter.js +31 -0
  99. package/esm/table-footer/TableFooter.js.map +1 -0
  100. package/esm/{table-column-settings → table-settings-panel}/TableSettingsPanel.css.js +1 -1
  101. package/esm/{table-column-settings → table-settings-panel}/TableSettingsPanel.js +13 -48
  102. package/esm/table-settings-panel/TableSettingsPanel.js.map +1 -0
  103. package/esm/table-settings-panel/useTableSettings.js +58 -0
  104. package/esm/table-settings-panel/useTableSettings.js.map +1 -0
  105. package/package.json +12 -11
  106. package/types/calculated-column/CalculatedColumnPanel.d.ts +12 -0
  107. package/types/calculated-column/useCalculatedColumnPanel.d.ts +10 -0
  108. package/types/calculated-column/useEditCalculatedColumn.d.ts +13 -0
  109. package/types/column-menu/ColumnMenu.d.ts +1 -1
  110. package/types/column-menu/column-action-types.d.ts +1 -4
  111. package/types/column-menu/column-menu-utils.d.ts +3 -4
  112. package/types/column-picker/ColumnModel.d.ts +26 -3
  113. package/types/column-picker/ColumnPicker.d.ts +7 -3
  114. package/types/column-picker/ColumnPickerAction.d.ts +5 -0
  115. package/types/column-picker/useColumnPicker.d.ts +4 -4
  116. package/types/column-picker/useTableColumnPicker.d.ts +7 -0
  117. package/types/column-picker/useTableColumnPickerDeprecated.d.ts +14 -0
  118. package/types/{table-column-settings → column-settings-panel}/ColumnNameLabel.d.ts +1 -1
  119. package/types/column-settings-panel/ColumnSettingsPanel.d.ts +5 -0
  120. package/types/{table-column-settings → column-settings-panel}/useColumnSettings.d.ts +14 -7
  121. package/types/index.d.ts +10 -9
  122. package/types/tabbed-table-config-panel/TabbedTableConfigPanel.d.ts +17 -0
  123. package/types/tabbed-table-config-panel/TabbedTableSettingsAction.d.ts +7 -0
  124. package/types/tabbed-table-config-panel/useTabbedTableConfigPanel.d.ts +13 -0
  125. package/types/table-footer/TableFooter.d.ts +9 -0
  126. package/types/table-settings-panel/TableSettingsPanel.d.ts +22 -0
  127. package/types/table-settings-panel/useTableSettings.d.ts +14 -0
  128. package/cjs/column-expression-panel/ColumnExpressionPanel.js.map +0 -1
  129. package/cjs/column-expression-panel/useColumnExpression.js.map +0 -1
  130. package/cjs/column-list/ColumnList.css.js +0 -6
  131. package/cjs/column-list/ColumnList.css.js.map +0 -1
  132. package/cjs/column-list/ColumnList.js +0 -218
  133. package/cjs/column-list/ColumnList.js.map +0 -1
  134. package/cjs/column-list/useColumnList.js +0 -66
  135. package/cjs/column-list/useColumnList.js.map +0 -1
  136. package/cjs/table-column-settings/ColumnNameLabel.js.map +0 -1
  137. package/cjs/table-column-settings/ColumnSettingsPanel.js +0 -202
  138. package/cjs/table-column-settings/ColumnSettingsPanel.js.map +0 -1
  139. package/cjs/table-column-settings/TableSettingsPanel.js.map +0 -1
  140. package/cjs/table-column-settings/useColumnSettings.js.map +0 -1
  141. package/cjs/table-column-settings/useTableAndColumnSettings.js +0 -129
  142. package/cjs/table-column-settings/useTableAndColumnSettings.js.map +0 -1
  143. package/cjs/table-column-settings/useTableSettings.js +0 -176
  144. package/cjs/table-column-settings/useTableSettings.js.map +0 -1
  145. package/esm/column-expression-panel/ColumnExpressionPanel.js.map +0 -1
  146. package/esm/column-expression-panel/useColumnExpression.js.map +0 -1
  147. package/esm/column-list/ColumnList.css.js +0 -4
  148. package/esm/column-list/ColumnList.css.js.map +0 -1
  149. package/esm/column-list/ColumnList.js +0 -214
  150. package/esm/column-list/ColumnList.js.map +0 -1
  151. package/esm/column-list/useColumnList.js +0 -64
  152. package/esm/column-list/useColumnList.js.map +0 -1
  153. package/esm/table-column-settings/ColumnNameLabel.js.map +0 -1
  154. package/esm/table-column-settings/ColumnSettingsPanel.js +0 -200
  155. package/esm/table-column-settings/ColumnSettingsPanel.js.map +0 -1
  156. package/esm/table-column-settings/TableSettingsPanel.js.map +0 -1
  157. package/esm/table-column-settings/useColumnSettings.js.map +0 -1
  158. package/esm/table-column-settings/useTableAndColumnSettings.js +0 -125
  159. package/esm/table-column-settings/useTableAndColumnSettings.js.map +0 -1
  160. package/esm/table-column-settings/useTableSettings.js +0 -174
  161. package/esm/table-column-settings/useTableSettings.js.map +0 -1
  162. package/types/column-expression-panel/ColumnExpressionPanel.d.ts +0 -13
  163. package/types/column-expression-panel/index.d.ts +0 -1
  164. package/types/column-expression-panel/useColumnExpression.d.ts +0 -10
  165. package/types/column-list/ColumnList.d.ts +0 -11
  166. package/types/column-list/index.d.ts +0 -2
  167. package/types/column-list/useColumnList.d.ts +0 -22
  168. package/types/table-column-settings/ColumnSettingsPanel.d.ts +0 -2
  169. package/types/table-column-settings/TableSettingsPanel.d.ts +0 -9
  170. package/types/table-column-settings/useTableAndColumnSettings.d.ts +0 -18
  171. package/types/table-column-settings/useTableSettings.d.ts +0 -18
  172. /package/cjs/{table-column-settings → column-settings-panel}/ColumnNameLabel.css.js +0 -0
  173. /package/cjs/{table-column-settings → column-settings-panel}/ColumnNameLabel.css.js.map +0 -0
  174. /package/cjs/{table-column-settings → column-settings-panel}/ColumnNameLabel.js +0 -0
  175. /package/cjs/{table-column-settings → column-settings-panel}/ColumnSettingsPanel.css.js.map +0 -0
  176. /package/cjs/{table-column-settings → table-settings-panel}/TableSettingsPanel.css.js.map +0 -0
  177. /package/esm/{table-column-settings → column-settings-panel}/ColumnNameLabel.css.js +0 -0
  178. /package/esm/{table-column-settings → column-settings-panel}/ColumnNameLabel.css.js.map +0 -0
  179. /package/esm/{table-column-settings → column-settings-panel}/ColumnNameLabel.js +0 -0
  180. /package/esm/{table-column-settings → column-settings-panel}/ColumnSettingsPanel.css.js.map +0 -0
  181. /package/esm/{table-column-settings → table-settings-panel}/TableSettingsPanel.css.js.map +0 -0
@@ -0,0 +1,90 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var lab = require('@salt-ds/lab');
5
+ var styles = require('@salt-ds/styles');
6
+ var window = require('@salt-ds/window');
7
+ var cx = require('clsx');
8
+ var react = require('react');
9
+ var useEditCalculatedColumn = require('../calculated-column/useEditCalculatedColumn.js');
10
+ var ColumnPicker = require('../column-picker/ColumnPicker.js');
11
+ var ColumnSettingsPanel = require('../column-settings-panel/ColumnSettingsPanel.js');
12
+ var TableSettingsPanel = require('../table-settings-panel/TableSettingsPanel.js');
13
+ var TabbedTableConfigPanel$1 = require('./TabbedTableConfigPanel.css.js');
14
+
15
+ const classBase = "vuuTabbedTableConfigPanel";
16
+ const TabbedTableConfigPanel = ({
17
+ allowCreateCalculatedColumn = false,
18
+ className,
19
+ columnModel,
20
+ config,
21
+ onDisplayAttributeChange,
22
+ selectedTab = "table-settings",
23
+ vuuTable,
24
+ ...htmlAttributes
25
+ }) => {
26
+ const targetWindow = window.useWindow();
27
+ styles.useComponentCssInjection({
28
+ testId: "vuu-tabbed-table-config-panel",
29
+ css: TabbedTableConfigPanel$1,
30
+ window: targetWindow
31
+ });
32
+ const [columns, setColumns] = react.useState([]);
33
+ const [value, setValue] = react.useState(selectedTab);
34
+ const handleChange = react.useCallback(
35
+ (_e, value2) => {
36
+ setValue(value2);
37
+ },
38
+ []
39
+ );
40
+ const handleSelectionChange = react.useCallback(
41
+ (_e, selectedItems) => {
42
+ setColumns(selectedItems);
43
+ },
44
+ []
45
+ );
46
+ const handleSaveCalculatedColumn = react.useCallback((column) => {
47
+ setColumns([column]);
48
+ }, []);
49
+ const { onCreateCalculatedColumn, onEditCalculatedColumn } = useEditCalculatedColumn.useEditCalculatedColumn({
50
+ columnModel,
51
+ calculatedColumn: columns[0],
52
+ onSaveColumn: handleSaveCalculatedColumn,
53
+ vuuTable
54
+ });
55
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { ...htmlAttributes, className: cx(classBase, className), children: /* @__PURE__ */ jsxRuntime.jsxs(lab.TabsNext, { onChange: handleChange, value, children: [
56
+ /* @__PURE__ */ jsxRuntime.jsxs(lab.TabListNext, { appearance: "transparent", children: [
57
+ /* @__PURE__ */ jsxRuntime.jsx(lab.TabNext, { value: "table-settings", children: /* @__PURE__ */ jsxRuntime.jsx(lab.TabNextTrigger, { children: "Table settings" }) }),
58
+ /* @__PURE__ */ jsxRuntime.jsx(lab.TabNext, { value: "table-columns", children: /* @__PURE__ */ jsxRuntime.jsx(lab.TabNextTrigger, { children: "Table columns" }) }),
59
+ /* @__PURE__ */ jsxRuntime.jsx(lab.TabNext, { disabled: columns.length === 0, value: "column-settings", children: /* @__PURE__ */ jsxRuntime.jsx(lab.TabNextTrigger, { children: "Column settings" }) })
60
+ ] }),
61
+ /* @__PURE__ */ jsxRuntime.jsx(lab.TabNextPanel, { value: "table-settings", children: /* @__PURE__ */ jsxRuntime.jsx(
62
+ TableSettingsPanel.TableSettingsPanel,
63
+ {
64
+ onDisplayAttributeChange,
65
+ tableDisplayAttributes: config
66
+ }
67
+ ) }),
68
+ /* @__PURE__ */ jsxRuntime.jsx(lab.TabNextPanel, { value: "table-columns", children: /* @__PURE__ */ jsxRuntime.jsx(
69
+ ColumnPicker.ColumnPicker,
70
+ {
71
+ allowCreateCalculatedColumn,
72
+ columnModel,
73
+ onClickCreateCalculatedColumn: onCreateCalculatedColumn,
74
+ onSelectionChange: handleSelectionChange,
75
+ selected: columns
76
+ }
77
+ ) }),
78
+ /* @__PURE__ */ jsxRuntime.jsx(lab.TabNextPanel, { value: "column-settings", children: columns.length > 0 ? /* @__PURE__ */ jsxRuntime.jsx(
79
+ ColumnSettingsPanel.ColumnSettingsPanel,
80
+ {
81
+ column: columns[0],
82
+ columnModel,
83
+ onClickEditCalculatedColumn: onEditCalculatedColumn
84
+ }
85
+ ) : null })
86
+ ] }) });
87
+ };
88
+
89
+ exports.TabbedTableConfigPanel = TabbedTableConfigPanel;
90
+ //# sourceMappingURL=TabbedTableConfigPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabbedTableConfigPanel.js","sources":["../../../../packages/vuu-table-extras/src/tabbed-table-config-panel/TabbedTableConfigPanel.tsx"],"sourcesContent":["import {\n TabListNext,\n TabNext,\n TabNextPanel,\n TabNextTrigger,\n TabsNext,\n} from \"@salt-ds/lab\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { VuuTable } from \"@vuu-ui/vuu-protocol-types\";\nimport type { TableProps } from \"@vuu-ui/vuu-table\";\nimport { ColumnDescriptor } from \"@vuu-ui/vuu-table-types\";\nimport cx from \"clsx\";\nimport { HTMLAttributes, SyntheticEvent, useCallback, useState } from \"react\";\nimport { useEditCalculatedColumn } from \"../calculated-column/useEditCalculatedColumn\";\nimport { ColumnPicker, ColumnPickerProps } from \"../column-picker/ColumnPicker\";\nimport { ColumnSettingsPanel } from \"../column-settings-panel/ColumnSettingsPanel\";\nimport {\n TableSettingsPanel,\n TableSettingsPanelProps,\n} from \"../table-settings-panel/TableSettingsPanel\";\n\nimport css from \"./TabbedTableConfigPanel.css\";\n\nconst TabLabels = {\n \"table-settings\": \"Table\",\n \"table-columns\": \"Columns\",\n} as const;\n\ntype TabName = keyof typeof TabLabels;\n\nconst classBase = \"vuuTabbedTableConfigPanel\";\nexport interface TabbedTableConfigPanelProps\n extends ColumnPickerProps,\n Pick<TableSettingsPanelProps, \"onDisplayAttributeChange\">,\n Pick<TableProps, \"config\">,\n HTMLAttributes<HTMLDivElement> {\n allowCreateCalculatedColumn?: boolean;\n selectedTab?: TabName;\n vuuTable?: VuuTable;\n}\n\nexport const TabbedTableConfigPanel = ({\n allowCreateCalculatedColumn = false,\n className,\n columnModel,\n config,\n onDisplayAttributeChange,\n selectedTab = \"table-settings\",\n vuuTable,\n ...htmlAttributes\n}: TabbedTableConfigPanelProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-tabbed-table-config-panel\",\n css,\n window: targetWindow,\n });\n\n const [columns, setColumns] = useState<ColumnDescriptor[]>([]);\n\n const [value, setValue] = useState<string>(selectedTab);\n const handleChange = useCallback(\n (_e: SyntheticEvent | null, value: string) => {\n setValue(value);\n },\n [],\n );\n\n const handleSelectionChange = useCallback(\n (_e: SyntheticEvent, selectedItems: ColumnDescriptor[]) => {\n setColumns(selectedItems);\n },\n [],\n );\n\n const handleSaveCalculatedColumn = useCallback((column: ColumnDescriptor) => {\n setColumns([column]);\n }, []);\n\n const { onCreateCalculatedColumn, onEditCalculatedColumn } =\n useEditCalculatedColumn({\n columnModel,\n calculatedColumn: columns[0],\n onSaveColumn: handleSaveCalculatedColumn,\n vuuTable,\n });\n\n return (\n <div {...htmlAttributes} className={cx(classBase, className)}>\n <TabsNext onChange={handleChange} value={value}>\n <TabListNext appearance=\"transparent\">\n <TabNext value=\"table-settings\">\n <TabNextTrigger>Table settings</TabNextTrigger>\n </TabNext>\n <TabNext value=\"table-columns\">\n <TabNextTrigger>Table columns</TabNextTrigger>\n </TabNext>\n <TabNext disabled={columns.length === 0} value=\"column-settings\">\n <TabNextTrigger>Column settings</TabNextTrigger>\n </TabNext>\n </TabListNext>\n <TabNextPanel value=\"table-settings\">\n <TableSettingsPanel\n onDisplayAttributeChange={onDisplayAttributeChange}\n tableDisplayAttributes={config}\n />\n </TabNextPanel>\n <TabNextPanel value=\"table-columns\">\n <ColumnPicker\n allowCreateCalculatedColumn={allowCreateCalculatedColumn}\n columnModel={columnModel}\n onClickCreateCalculatedColumn={onCreateCalculatedColumn}\n onSelectionChange={handleSelectionChange}\n selected={columns}\n />\n </TabNextPanel>\n <TabNextPanel value=\"column-settings\">\n {columns.length > 0 ? (\n <ColumnSettingsPanel\n column={columns[0]}\n columnModel={columnModel}\n onClickEditCalculatedColumn={onEditCalculatedColumn}\n />\n ) : null}\n </TabNextPanel>\n </TabsNext>\n </div>\n );\n};\n"],"names":["useWindow","useComponentCssInjection","css","useState","useCallback","value","useEditCalculatedColumn","jsx","jsxs","TabsNext","TabListNext","TabNext","TabNextTrigger","TabNextPanel","TableSettingsPanel","ColumnPicker","ColumnSettingsPanel"],"mappings":"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"}
@@ -0,0 +1,44 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var vuuUiControls = require('@vuu-ui/vuu-ui-controls');
5
+ var react = require('react');
6
+ var useTabbedTableConfigPanel = require('./useTabbedTableConfigPanel.js');
7
+
8
+ const TabbedTableSettingsAction = ({
9
+ allowCreateCalculatedColumn,
10
+ appearance = "transparent",
11
+ columnModel,
12
+ config,
13
+ icon = "settings",
14
+ onDisplayAttributeChange,
15
+ sentiment = "neutral",
16
+ vuuTable,
17
+ ...IconButtonProps2
18
+ }) => {
19
+ const { showTabbedTableConfigPanel } = useTabbedTableConfigPanel.useTabbedTableConfigPanel({
20
+ allowCreateCalculatedColumn,
21
+ columnModel,
22
+ config,
23
+ onDisplayAttributeChange,
24
+ vuuTable
25
+ });
26
+ const handleClick = react.useCallback(() => {
27
+ showTabbedTableConfigPanel();
28
+ }, [showTabbedTableConfigPanel]);
29
+ return /* @__PURE__ */ jsxRuntime.jsx(
30
+ vuuUiControls.IconButton,
31
+ {
32
+ ...IconButtonProps2,
33
+ appearance,
34
+ "data-action": "table-settings",
35
+ icon,
36
+ onClick: handleClick,
37
+ sentiment,
38
+ size: 20
39
+ }
40
+ );
41
+ };
42
+
43
+ exports.TabbedTableSettingsAction = TabbedTableSettingsAction;
44
+ //# sourceMappingURL=TabbedTableSettingsAction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabbedTableSettingsAction.js","sources":["../../../../packages/vuu-table-extras/src/tabbed-table-config-panel/TabbedTableSettingsAction.tsx"],"sourcesContent":["import { IconButton, IconButtonProps } from \"@vuu-ui/vuu-ui-controls\";\nimport { useCallback } from \"react\";\nimport {\n TabbedTableConfigPanelHookProps,\n useTabbedTableConfigPanel,\n} from \"./useTabbedTableConfigPanel\";\nimport { TableDisplayAttributeChangeHandler } from \"../table-settings-panel/TableSettingsPanel\";\n\nexport interface TabbedTableSettingsActionProps\n extends Partial<IconButtonProps>,\n TabbedTableConfigPanelHookProps {\n onDisplayAttributeChange: TableDisplayAttributeChangeHandler;\n}\n\nexport const TabbedTableSettingsAction = ({\n allowCreateCalculatedColumn,\n appearance = \"transparent\",\n columnModel,\n config,\n icon = \"settings\",\n onDisplayAttributeChange,\n sentiment = \"neutral\",\n vuuTable,\n ...IconButtonProps\n}: TabbedTableSettingsActionProps) => {\n const { showTabbedTableConfigPanel } = useTabbedTableConfigPanel({\n allowCreateCalculatedColumn,\n columnModel,\n config,\n onDisplayAttributeChange,\n vuuTable,\n });\n\n const handleClick = useCallback(() => {\n showTabbedTableConfigPanel();\n }, [showTabbedTableConfigPanel]);\n\n return (\n <IconButton\n {...IconButtonProps}\n appearance={appearance}\n data-action=\"table-settings\"\n icon={icon}\n onClick={handleClick}\n sentiment={sentiment}\n size={20}\n />\n );\n};\n"],"names":["IconButtonProps","useTabbedTableConfigPanel","useCallback","jsx","IconButton"],"mappings":";;;;;;;AAcO,MAAM,4BAA4B,CAAC;AAAA,EACxC,2BAAA;AAAA,EACA,UAAa,GAAA,aAAA;AAAA,EACb,WAAA;AAAA,EACA,MAAA;AAAA,EACA,IAAO,GAAA,UAAA;AAAA,EACP,wBAAA;AAAA,EACA,SAAY,GAAA,SAAA;AAAA,EACZ,QAAA;AAAA,EACA,GAAGA;AACL,CAAsC,KAAA;AACpC,EAAM,MAAA,EAAE,0BAA2B,EAAA,GAAIC,mDAA0B,CAAA;AAAA,IAC/D,2BAAA;AAAA,IACA,WAAA;AAAA,IACA,MAAA;AAAA,IACA,wBAAA;AAAA,IACA;AAAA,GACD,CAAA;AAED,EAAM,MAAA,WAAA,GAAcC,kBAAY,MAAM;AACpC,IAA2B,0BAAA,EAAA;AAAA,GAC7B,EAAG,CAAC,0BAA0B,CAAC,CAAA;AAE/B,EACE,uBAAAC,cAAA;AAAA,IAACC,wBAAA;AAAA,IAAA;AAAA,MACE,GAAGJ,gBAAAA;AAAA,MACJ,UAAA;AAAA,MACA,aAAY,EAAA,gBAAA;AAAA,MACZ,IAAA;AAAA,MACA,OAAS,EAAA,WAAA;AAAA,MACT,SAAA;AAAA,MACA,IAAM,EAAA;AAAA;AAAA,GACR;AAEJ;;;;"}
@@ -0,0 +1,49 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var react = require('react');
5
+ var vuuUiControls = require('@vuu-ui/vuu-ui-controls');
6
+ var TabbedTableConfigPanel = require('./TabbedTableConfigPanel.js');
7
+
8
+ const useTabbedTableConfigPanel = ({
9
+ allowCreateCalculatedColumn,
10
+ columnModel,
11
+ config,
12
+ onDisplayAttributeChange,
13
+ vuuTable
14
+ }) => {
15
+ const showContextPanel = vuuUiControls.useContextPanel();
16
+ const contextPanelShowing = react.useRef(false);
17
+ const showTabbedTableConfigPanel = react.useCallback(
18
+ (title = "Table settings") => {
19
+ contextPanelShowing.current = true;
20
+ showContextPanel(
21
+ /* @__PURE__ */ jsxRuntime.jsx(
22
+ TabbedTableConfigPanel.TabbedTableConfigPanel,
23
+ {
24
+ allowCreateCalculatedColumn,
25
+ columnModel,
26
+ config,
27
+ onDisplayAttributeChange,
28
+ vuuTable
29
+ }
30
+ ),
31
+ title
32
+ );
33
+ },
34
+ [
35
+ allowCreateCalculatedColumn,
36
+ columnModel,
37
+ config,
38
+ onDisplayAttributeChange,
39
+ showContextPanel,
40
+ vuuTable
41
+ ]
42
+ );
43
+ return {
44
+ showTabbedTableConfigPanel
45
+ };
46
+ };
47
+
48
+ exports.useTabbedTableConfigPanel = useTabbedTableConfigPanel;
49
+ //# sourceMappingURL=useTabbedTableConfigPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTabbedTableConfigPanel.js","sources":["../../../../packages/vuu-table-extras/src/tabbed-table-config-panel/useTabbedTableConfigPanel.tsx"],"sourcesContent":["import { useCallback, useRef } from \"react\";\nimport { useContextPanel } from \"@vuu-ui/vuu-ui-controls\";\nimport { TabbedTableConfigPanel } from \"./TabbedTableConfigPanel\";\nimport { TableSettingsPanelProps } from \"../table-settings-panel/TableSettingsPanel\";\nimport { TableProps } from \"@vuu-ui/vuu-table\";\nimport { ColumnPickerProps } from \"../column-picker/ColumnPicker\";\nimport { VuuTable } from \"@vuu-ui/vuu-protocol-types\";\n\nexport interface TabbedTableConfigPanelHookProps\n extends Pick<\n ColumnPickerProps,\n \"allowCreateCalculatedColumn\" | \"columnModel\"\n >,\n Pick<TableSettingsPanelProps, \"onDisplayAttributeChange\">,\n Pick<TableProps, \"config\"> {\n /**\n * only required for calculated columns\n */\n vuuTable?: VuuTable;\n}\n\nexport const useTabbedTableConfigPanel = ({\n allowCreateCalculatedColumn,\n columnModel,\n config,\n onDisplayAttributeChange,\n vuuTable,\n}: TabbedTableConfigPanelHookProps) => {\n const showContextPanel = useContextPanel();\n // const hideContextPanel = useHideContextPanel();\n const contextPanelShowing = useRef(false);\n\n const showTabbedTableConfigPanel = useCallback(\n (title = \"Table settings\") => {\n contextPanelShowing.current = true;\n showContextPanel(\n <TabbedTableConfigPanel\n allowCreateCalculatedColumn={allowCreateCalculatedColumn}\n columnModel={columnModel}\n config={config}\n onDisplayAttributeChange={onDisplayAttributeChange}\n vuuTable={vuuTable}\n />,\n title,\n );\n },\n [\n allowCreateCalculatedColumn,\n columnModel,\n config,\n onDisplayAttributeChange,\n showContextPanel,\n vuuTable,\n ],\n );\n\n return {\n showTabbedTableConfigPanel,\n };\n};\n"],"names":["useContextPanel","useRef","useCallback","jsx","TabbedTableConfigPanel"],"mappings":";;;;;;;AAqBO,MAAM,4BAA4B,CAAC;AAAA,EACxC,2BAAA;AAAA,EACA,WAAA;AAAA,EACA,MAAA;AAAA,EACA,wBAAA;AAAA,EACA;AACF,CAAuC,KAAA;AACrC,EAAA,MAAM,mBAAmBA,6BAAgB,EAAA;AAEzC,EAAM,MAAA,mBAAA,GAAsBC,aAAO,KAAK,CAAA;AAExC,EAAA,MAAM,0BAA6B,GAAAC,iBAAA;AAAA,IACjC,CAAC,QAAQ,gBAAqB,KAAA;AAC5B,MAAA,mBAAA,CAAoB,OAAU,GAAA,IAAA;AAC9B,MAAA,gBAAA;AAAA,wBACEC,cAAA;AAAA,UAACC,6CAAA;AAAA,UAAA;AAAA,YACC,2BAAA;AAAA,YACA,WAAA;AAAA,YACA,MAAA;AAAA,YACA,wBAAA;AAAA,YACA;AAAA;AAAA,SACF;AAAA,QACA;AAAA,OACF;AAAA,KACF;AAAA,IACA;AAAA,MACE,2BAAA;AAAA,MACA,WAAA;AAAA,MACA,MAAA;AAAA,MACA,wBAAA;AAAA,MACA,gBAAA;AAAA,MACA;AAAA;AACF,GACF;AAEA,EAAO,OAAA;AAAA,IACL;AAAA,GACF;AACF;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var tableFooterCss = ".vuuTableFooter {\n background-color: var(--salt-container-secondary-background);\n display: grid;\n --table-footer-height: var(--vuuTableFooter-height, 32px);\n flex: 0 0 var(--table-footer-height);\n grid-template-areas: \"panel-start panel-center panel-end\";\n grid-template-columns: 1fr 1fr 1fr;\n grid-template-rows: auto;\n\n height: var(--table-footer-height);\n\n .vuuTableFooterTray {\n align-items: center;\n display: flex;\n justify-self: end;;\n margin: 0 var(--salt-spacing-200);\n grid-area: panel-end;\n }\n\n}\n";
4
+
5
+ module.exports = tableFooterCss;
6
+ //# sourceMappingURL=TableFooter.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableFooter.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,34 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var cx = require('clsx');
5
+ var styles = require('@salt-ds/styles');
6
+ var window = require('@salt-ds/window');
7
+ var TableFooter$1 = require('./TableFooter.css.js');
8
+
9
+ const classBase = "vuuTableFooter";
10
+ const TableFooterTray = ({ children }) => {
11
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { className: `${classBase}Tray`, children });
12
+ };
13
+ const TableFooter = ({
14
+ children,
15
+ className,
16
+ onInvokeAction,
17
+ tooltrayActions,
18
+ ...htmlAttributes
19
+ }) => {
20
+ const targetWindow = window.useWindow();
21
+ styles.useComponentCssInjection({
22
+ testId: "vuu-table-footer",
23
+ css: TableFooter$1,
24
+ window: targetWindow
25
+ });
26
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { ...htmlAttributes, className: cx(classBase, className), children: [
27
+ children,
28
+ tooltrayActions ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: `${classBase}-tooltray`, children: tooltrayActions }) : null
29
+ ] });
30
+ };
31
+
32
+ exports.TableFooter = TableFooter;
33
+ exports.TableFooterTray = TableFooterTray;
34
+ //# sourceMappingURL=TableFooter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableFooter.js","sources":["../../../../packages/vuu-table-extras/src/table-footer/TableFooter.tsx"],"sourcesContent":["import cx from \"clsx\";\nimport { HTMLAttributes, ReactNode } from \"react\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport tableFooterCss from \"./TableFooter.css\";\n\nexport interface TableFooterProps extends HTMLAttributes<HTMLDivElement> {\n onInvokeAction?: (action: string) => void;\n tooltrayActions?: ReactNode;\n}\n\nconst classBase = \"vuuTableFooter\";\n\nexport const TableFooterTray = ({ children }: { children: ReactNode }) => {\n return <div className={`${classBase}Tray`}>{children}</div>;\n};\n\nexport const TableFooter = ({\n children,\n className,\n onInvokeAction,\n tooltrayActions,\n ...htmlAttributes\n}: TableFooterProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-table-footer\",\n css: tableFooterCss,\n window: targetWindow,\n });\n\n return (\n <div {...htmlAttributes} className={cx(classBase, className)}>\n {children}\n {tooltrayActions ? (\n <div className={`${classBase}-tooltray`}>{tooltrayActions}</div>\n ) : null}\n </div>\n );\n};\n"],"names":["useWindow","useComponentCssInjection","tableFooterCss","jsxs"],"mappings":";;;;;;;;AAYA,MAAM,SAAY,GAAA,gBAAA;AAEX,MAAM,eAAkB,GAAA,CAAC,EAAE,QAAA,EAAwC,KAAA;AACxE,EAAA,sCAAQ,KAAI,EAAA,EAAA,SAAA,EAAW,CAAG,EAAA,SAAS,QAAS,QAAS,EAAA,CAAA;AACvD;AAEO,MAAM,cAAc,CAAC;AAAA,EAC1B,QAAA;AAAA,EACA,SAAA;AAAA,EACA,cAAA;AAAA,EACA,eAAA;AAAA,EACA,GAAG;AACL,CAAwB,KAAA;AACtB,EAAA,MAAM,eAAeA,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,kBAAA;AAAA,IACR,GAAK,EAAAC,aAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EACE,uBAAAC,eAAA,CAAC,SAAK,GAAG,cAAA,EAAgB,WAAW,EAAG,CAAA,SAAA,EAAW,SAAS,CACxD,EAAA,QAAA,EAAA;AAAA,IAAA,QAAA;AAAA,IACA,eAAA,kCACE,KAAI,EAAA,EAAA,SAAA,EAAW,GAAG,SAAS,CAAA,SAAA,CAAA,EAAc,2BAAgB,CACxD,GAAA;AAAA,GACN,EAAA,CAAA;AAEJ;;;;;"}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var tableSettingsPanelCss = ".vuuTableSettingsPanel {\n --vuuScrollable-size: 6px;\n --vuu-svg-text-strikethrough: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 48 24\"><path d=\"M28.3333 9.33334C28.8867 9.33334 29.3333 8.88668 29.3333 8.33334C29.3333 7.78001 28.8867 7.33334 28.3333 7.33334H20.26L22.26 9.33334H23.48L23.1133 10.1867L24.5067 11.58L25.4733 9.33334H28.3333ZM27.6267 16.5867L18.7467 7.70668C18.4867 7.44668 18.0667 7.44668 17.8067 7.70668C17.5467 7.96668 17.5467 8.38668 17.8067 8.64668L21.98 12.82L20.88 15.38C20.62 15.9933 21.0667 16.6667 21.7267 16.6667C22.0933 16.6667 22.4267 16.4467 22.5733 16.1067L23.38 14.22L26.68 17.52C26.94 17.78 27.36 17.78 27.62 17.52C27.8867 17.2667 27.8867 16.8467 27.6267 16.5867Z\"/></svg>');\n --vuu-svg-text-Tt: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 48 24\"><path d=\"M17.6667 7.66666C17.6667 8.21999 18.1133 8.66666 18.6667 8.66666H21V15.6667C21 16.22 21.4467 16.6667 22 16.6667C22.5533 16.6667 23 16.22 23 15.6667V8.66666H25.3333C25.8867 8.66666 26.3333 8.21999 26.3333 7.66666C26.3333 7.11332 25.8867 6.66666 25.3333 6.66666H18.6667C18.1133 6.66666 17.6667 7.11332 17.6667 7.66666ZM29.3333 9.99999H25.3333C24.78 9.99999 24.3333 10.4467 24.3333 11C24.3333 11.5533 24.78 12 25.3333 12H26.3333V15.6667C26.3333 16.22 26.78 16.6667 27.3333 16.6667C27.8867 16.6667 28.3333 16.22 28.3333 15.6667V12H29.3333C29.8867 12 30.3333 11.5533 30.3333 11C30.3333 10.4467 29.8867 9.99999 29.3333 9.99999Z\" /></svg>');\n --vuu-svg-text-T: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 48 24\"><path d=\"M19.3333 7.66666C19.3333 8.21999 19.78 8.66666 20.3333 8.66666H23V15.6667C23 16.22 23.4467 16.6667 24 16.6667C24.5533 16.6667 25 16.22 25 15.6667V8.66666H27.6667C28.22 8.66666 28.6667 8.21999 28.6667 7.66666C28.6667 7.11332 28.22 6.66666 27.6667 6.66666H20.3333C19.78 6.66666 19.3333 7.11332 19.3333 7.66666Z\"/></svg>');\n --vuu-svg-stripes: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\"><rect x=\"2\" y=\"2\" width=\"12\" height=\"2\" rx=\"0.3\"/><rect x=\"2\" y=\"5\" width=\"12\" height=\"2\" rx=\"0.3\"/><rect x=\"2\" y=\"8\" width=\"12\" height=\"2\" rx=\"0.3\"/><rect x=\"2\" y=\"11\" width=\"12\" height=\"2\" rx=\"0.3\"/></svg>');\n --vuu-svg-row-lines: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\"><rect x=\"2\" y=\"3\" width=\"12\" height=\"1\" rx=\"0.3\" /><rect x=\"2\" y=\"6\" width=\"12\" height=\"1\" rx=\"0.3\" /><rect x=\"2\" y=\"9\" width=\"12\" height=\"1\" rx=\"0.3\" /><rect x=\"2\" y=\"12\" width=\"12\" height=\"1\" rx=\"0.3\"/></svg>');\n --vuu-svg-col-lines: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\"><rect x=\"3\" y=\"14\" width=\"12\" height=\"1\" rx=\"0.3\" transform=\"rotate(-90 3 14)\"/><rect x=\"6\" y=\"14\" width=\"12\" height=\"1\" rx=\"0.3\" transform=\"rotate(-90 6 14)\"/><rect x=\"9\" y=\"14\" width=\"12\" height=\"1\" rx=\"0.3\" transform=\"rotate(-90 9 14)\"/><rect x=\"12\" y=\"14\" width=\"12\" height=\"1\" rx=\"0.3\" transform=\"rotate(-90 12 14)\"/></svg>');\n\n display: flex;\n flex-direction: column;\n gap: 24px;\n height: 100%;\n max-width: 254px;\n padding: 12px 2px var(--salt-spacing-200) 2px;\n}\n\n\n.vuuTableSettingsPanel [data-icon=\"text-strikethrough\"]{\n --vuu-icon-svg: var(--vuu-svg-text-strikethrough);\n}\n.vuuTableSettingsPanel [data-icon=\"text-Tt\"]{\n --vuu-icon-svg: var(--vuu-svg-text-Tt);\n}\n.vuuTableSettingsPanel [data-icon=\"text-T\"]{\n --vuu-icon-svg: var(--vuu-svg-text-T);\n}\n.vuuTableSettingsPanel [data-icon=\"col-lines\"]{\n --vuu-icon-svg: var(--vuu-svg-col-lines);\n}\n.vuuTableSettingsPanel [data-icon=\"row-lines\"]{\n --vuu-icon-svg: var(--vuu-svg-row-lines);\n}\n.vuuTableSettingsPanel [data-icon=\"row-striping\"]{\n --vuu-icon-svg: var(--vuu-svg-stripes);\n}\n\n.vuuTableSettingsPanel-header {\n border-top: solid 2px var(--vuu-color-gray-30);\n font-size: 14px;\n font-weight: 600;\n padding-top: 24px;\n}\n\n.vuuTableSettingsPanel-columnListContainer {\n\n flex-grow: 1;\n flex-shrink: 1;\n flex-basis: 0;\n position: relative;\n overflow: auto;\n .vuuColumnList {\n height: 100%;\n }\n}\n\n.vuuTableSettingsPanel-calculatedButtonbar {\n --vuu-icon-size: 16px;\n --saltButton-height: 24px;\n --saltButton-width: 24px;\n align-items: center;\n display: flex;\n flex: 0 0 32px;\n gap: 12px;\n}\n\n\n\n\n\n\n";
3
+ var tableSettingsPanelCss = ".vuuTableSettingsPanel {\n --vuuScrollable-size: 6px;\n --vuu-svg-text-strikethrough: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 48 24\"><path d=\"M28.3333 9.33334C28.8867 9.33334 29.3333 8.88668 29.3333 8.33334C29.3333 7.78001 28.8867 7.33334 28.3333 7.33334H20.26L22.26 9.33334H23.48L23.1133 10.1867L24.5067 11.58L25.4733 9.33334H28.3333ZM27.6267 16.5867L18.7467 7.70668C18.4867 7.44668 18.0667 7.44668 17.8067 7.70668C17.5467 7.96668 17.5467 8.38668 17.8067 8.64668L21.98 12.82L20.88 15.38C20.62 15.9933 21.0667 16.6667 21.7267 16.6667C22.0933 16.6667 22.4267 16.4467 22.5733 16.1067L23.38 14.22L26.68 17.52C26.94 17.78 27.36 17.78 27.62 17.52C27.8867 17.2667 27.8867 16.8467 27.6267 16.5867Z\"/></svg>');\n --vuu-svg-text-Tt: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 48 24\"><path d=\"M17.6667 7.66666C17.6667 8.21999 18.1133 8.66666 18.6667 8.66666H21V15.6667C21 16.22 21.4467 16.6667 22 16.6667C22.5533 16.6667 23 16.22 23 15.6667V8.66666H25.3333C25.8867 8.66666 26.3333 8.21999 26.3333 7.66666C26.3333 7.11332 25.8867 6.66666 25.3333 6.66666H18.6667C18.1133 6.66666 17.6667 7.11332 17.6667 7.66666ZM29.3333 9.99999H25.3333C24.78 9.99999 24.3333 10.4467 24.3333 11C24.3333 11.5533 24.78 12 25.3333 12H26.3333V15.6667C26.3333 16.22 26.78 16.6667 27.3333 16.6667C27.8867 16.6667 28.3333 16.22 28.3333 15.6667V12H29.3333C29.8867 12 30.3333 11.5533 30.3333 11C30.3333 10.4467 29.8867 9.99999 29.3333 9.99999Z\" /></svg>');\n --vuu-svg-text-T: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 48 24\"><path d=\"M19.3333 7.66666C19.3333 8.21999 19.78 8.66666 20.3333 8.66666H23V15.6667C23 16.22 23.4467 16.6667 24 16.6667C24.5533 16.6667 25 16.22 25 15.6667V8.66666H27.6667C28.22 8.66666 28.6667 8.21999 28.6667 7.66666C28.6667 7.11332 28.22 6.66666 27.6667 6.66666H20.3333C19.78 6.66666 19.3333 7.11332 19.3333 7.66666Z\"/></svg>');\n --vuu-svg-stripes: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\"><rect x=\"2\" y=\"2\" width=\"12\" height=\"2\" rx=\"0.3\"/><rect x=\"2\" y=\"5\" width=\"12\" height=\"2\" rx=\"0.3\"/><rect x=\"2\" y=\"8\" width=\"12\" height=\"2\" rx=\"0.3\"/><rect x=\"2\" y=\"11\" width=\"12\" height=\"2\" rx=\"0.3\"/></svg>');\n --vuu-svg-row-lines: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\"><rect x=\"2\" y=\"3\" width=\"12\" height=\"1\" rx=\"0.3\" /><rect x=\"2\" y=\"6\" width=\"12\" height=\"1\" rx=\"0.3\" /><rect x=\"2\" y=\"9\" width=\"12\" height=\"1\" rx=\"0.3\" /><rect x=\"2\" y=\"12\" width=\"12\" height=\"1\" rx=\"0.3\"/></svg>');\n --vuu-svg-col-lines: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\"><rect x=\"3\" y=\"14\" width=\"12\" height=\"1\" rx=\"0.3\" transform=\"rotate(-90 3 14)\"/><rect x=\"6\" y=\"14\" width=\"12\" height=\"1\" rx=\"0.3\" transform=\"rotate(-90 6 14)\"/><rect x=\"9\" y=\"14\" width=\"12\" height=\"1\" rx=\"0.3\" transform=\"rotate(-90 9 14)\"/><rect x=\"12\" y=\"14\" width=\"12\" height=\"1\" rx=\"0.3\" transform=\"rotate(-90 12 14)\"/></svg>');\n\n display: flex;\n flex-direction: column;\n gap: 24px;\n height: 100%;\n max-width: 254px;\n padding: 12px 2px var(--salt-spacing-200) 2px;\n}\n\n\n.vuuTableSettingsPanel [data-icon=\"text-strikethrough\"]{\n --vuu-icon-svg: var(--vuu-svg-text-strikethrough);\n}\n.vuuTableSettingsPanel [data-icon=\"text-Tt\"]{\n --vuu-icon-svg: var(--vuu-svg-text-Tt);\n}\n.vuuTableSettingsPanel [data-icon=\"text-T\"]{\n --vuu-icon-svg: var(--vuu-svg-text-T);\n}\n.vuuTableSettingsPanel [data-icon=\"col-lines\"]{\n --vuu-icon-svg: var(--vuu-svg-col-lines);\n}\n.vuuTableSettingsPanel [data-icon=\"row-lines\"]{\n --vuu-icon-svg: var(--vuu-svg-row-lines);\n}\n.vuuTableSettingsPanel [data-icon=\"row-striping\"]{\n --vuu-icon-svg: var(--vuu-svg-stripes);\n}\n\n.vuuTableSettingsPanel-header {\n font-size: 14px;\n font-weight: 600;\n padding-top: 24px;\n}\n\n.vuuTableSettingsPanel-columnListContainer {\n\n flex-grow: 1;\n flex-shrink: 1;\n flex-basis: 0;\n position: relative;\n overflow: auto;\n .vuuColumnList {\n height: 100%;\n }\n}\n\n.vuuTableSettingsPanel-calculatedButtonbar {\n --vuu-icon-size: 16px;\n --saltButton-height: 24px;\n --saltButton-width: 24px;\n align-items: center;\n display: flex;\n flex: 0 0 32px;\n gap: 12px;\n}\n\n\n\n\n\n\n";
4
4
 
5
5
  module.exports = tableSettingsPanelCss;
6
6
  //# sourceMappingURL=TableSettingsPanel.css.js.map
@@ -4,38 +4,24 @@ var jsxRuntime = require('react/jsx-runtime');
4
4
  var core = require('@salt-ds/core');
5
5
  var styles = require('@salt-ds/styles');
6
6
  var window = require('@salt-ds/window');
7
- var ColumnList = require('../column-list/ColumnList.js');
8
7
  var useTableSettings = require('./useTableSettings.js');
9
8
  var vuuUiControls = require('@vuu-ui/vuu-ui-controls');
10
- var cx = require('clsx');
11
9
  var TableSettingsPanel$1 = require('./TableSettingsPanel.css.js');
12
10
 
13
11
  const classBase = "vuuTableSettingsPanel";
14
12
  const defaultTableSettingsPermissions = {
15
13
  allowColumnLabelCase: true,
16
14
  allowColumnDefaultWidth: true,
17
- allowGridSeparators: true,
18
- allowReorderColumns: true,
19
- allowRemoveColumns: true,
20
- allowHideColumns: true,
21
- allowCalculatedColumns: true
15
+ allowGridSeparators: true
22
16
  };
23
17
  const noTableSettingsPermissions = {
24
18
  allowColumnLabelCase: false,
25
19
  allowColumnDefaultWidth: false,
26
- allowGridSeparators: false,
27
- allowReorderColumns: false,
28
- allowRemoveColumns: false,
29
- allowHideColumns: false,
30
- allowCalculatedColumns: false
20
+ allowGridSeparators: false
31
21
  };
32
22
  const TableSettingsPanel = ({
33
- availableColumns,
34
- onAddCalculatedColumn,
35
- onConfigChange,
36
- onDataSourceConfigChange,
37
- onNavigateToColumn,
38
- tableConfig: tableConfigProp,
23
+ onDisplayAttributeChange,
24
+ tableDisplayAttributes: tableDisplayAttributesProp,
39
25
  permissions: permissionsProp
40
26
  }) => {
41
27
  const targetWindow = window.useWindow();
@@ -46,34 +32,27 @@ const TableSettingsPanel = ({
46
32
  });
47
33
  const permissions = permissionsProp === void 0 || permissionsProp === true ? defaultTableSettingsPermissions : permissionsProp === false ? noTableSettingsPermissions : permissionsProp;
48
34
  const {
49
- columnItems,
50
35
  columnLabelsValue,
51
36
  onChangeColumnLabels,
52
37
  onChangeTableAttribute,
53
- onReorderColumnItems,
54
- onColumnChange,
55
38
  onCommitColumnWidth,
56
- tableConfig
39
+ tableDisplayAttributes
57
40
  } = useTableSettings.useTableSettings({
58
- availableColumns,
59
- onConfigChange,
60
- onDataSourceConfigChange,
61
- tableConfig: tableConfigProp
41
+ onDisplayAttributeChange,
42
+ tableDisplayAttributes: tableDisplayAttributesProp
62
43
  });
63
44
  const {
64
45
  allowColumnLabelCase = true,
65
46
  allowColumnDefaultWidth = true,
66
- allowGridSeparators = true,
67
- allowCalculatedColumns = true,
68
- ...columnListPermissions
47
+ allowGridSeparators = true
69
48
  } = permissions;
70
49
  return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: classBase, children: [
71
- allowColumnLabelCase || allowColumnDefaultWidth || allowGridSeparators ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: `${classBase}-header`, children: /* @__PURE__ */ jsxRuntime.jsx("span", { children: "Column Settings" }) }) : null,
72
50
  allowColumnDefaultWidth ? /* @__PURE__ */ jsxRuntime.jsxs(core.FormField, { children: [
73
51
  /* @__PURE__ */ jsxRuntime.jsx(core.FormFieldLabel, { children: "Column Width" }),
74
52
  /* @__PURE__ */ jsxRuntime.jsx(
75
53
  vuuUiControls.VuuInput,
76
54
  {
55
+ bordered: true,
77
56
  className: "vuuInput",
78
57
  "data-embedded": true,
79
58
  onCommit: onCommitColumnWidth
@@ -102,7 +81,7 @@ const TableSettingsPanel = ({
102
81
  /* @__PURE__ */ jsxRuntime.jsx(
103
82
  core.ToggleButton,
104
83
  {
105
- selected: tableConfig.zebraStripes ?? false,
84
+ selected: tableDisplayAttributes.zebraStripes ?? false,
106
85
  onChange: onChangeTableAttribute,
107
86
  value: "zebraStripes",
108
87
  children: /* @__PURE__ */ jsxRuntime.jsx(vuuUiControls.Icon, { name: "row-striping", size: 16 })
@@ -111,7 +90,7 @@ const TableSettingsPanel = ({
111
90
  /* @__PURE__ */ jsxRuntime.jsx(
112
91
  core.ToggleButton,
113
92
  {
114
- selected: tableConfig.rowSeparators ?? false,
93
+ selected: tableDisplayAttributes.rowSeparators ?? false,
115
94
  onChange: onChangeTableAttribute,
116
95
  value: "rowSeparators",
117
96
  children: /* @__PURE__ */ jsxRuntime.jsx(vuuUiControls.Icon, { name: "row-lines", size: 16 })
@@ -120,27 +99,13 @@ const TableSettingsPanel = ({
120
99
  /* @__PURE__ */ jsxRuntime.jsx(
121
100
  core.ToggleButton,
122
101
  {
123
- selected: tableConfig.columnSeparators ?? false,
102
+ selected: tableDisplayAttributes.columnSeparators ?? false,
124
103
  onChange: onChangeTableAttribute,
125
104
  value: "columnSeparators",
126
105
  children: /* @__PURE__ */ jsxRuntime.jsx(vuuUiControls.Icon, { name: "col-lines", size: 16 })
127
106
  }
128
107
  )
129
108
  ] })
130
- ] }) : null,
131
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: cx(`${classBase}-columnListContainer`, "vuuScrollable"), children: /* @__PURE__ */ jsxRuntime.jsx(
132
- ColumnList.ColumnList,
133
- {
134
- columnItems,
135
- permissions: columnListPermissions,
136
- onChange: onColumnChange,
137
- onNavigateToColumn,
138
- onReorderColumnItems
139
- }
140
- ) }),
141
- allowCalculatedColumns ? /* @__PURE__ */ jsxRuntime.jsxs("div", { className: `${classBase}-calculatedButtonbar`, children: [
142
- /* @__PURE__ */ jsxRuntime.jsx(core.Button, { "data-icon": "plus", onClick: onAddCalculatedColumn }),
143
- /* @__PURE__ */ jsxRuntime.jsx("span", { className: `${classBase}-calculatedLabel`, children: "Add calculated column" })
144
109
  ] }) : null
145
110
  ] });
146
111
  };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableSettingsPanel.js","sources":["../../../../packages/vuu-table-extras/src/table-settings-panel/TableSettingsPanel.tsx"],"sourcesContent":["import {\n FormField,\n FormFieldLabel,\n ToggleButton,\n ToggleButtonGroup,\n} from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport {\n TableDisplayAttributes,\n TableSettingsPermissions,\n} from \"@vuu-ui/vuu-table-types\";\nimport { useTableSettings } from \"./useTableSettings\";\nimport { Icon } from \"@vuu-ui/vuu-ui-controls\";\nimport { VuuInput } from \"@vuu-ui/vuu-ui-controls\";\n\nimport tableSettingsPanelCss from \"./TableSettingsPanel.css\";\n\nconst classBase = \"vuuTableSettingsPanel\";\n\nexport const defaultTableSettingsPermissions: Readonly<TableSettingsPermissions> =\n {\n allowColumnLabelCase: true,\n allowColumnDefaultWidth: true,\n allowGridSeparators: true,\n };\nexport const noTableSettingsPermissions: Readonly<TableSettingsPermissions> = {\n allowColumnLabelCase: false,\n allowColumnDefaultWidth: false,\n allowGridSeparators: false,\n};\n\nexport type TableDisplayAttributeChangeHandler = (\n displayAttributes: TableDisplayAttributes,\n) => void;\n\n/**\n * Describes the props for a Table Configuration Editor, for which\n * an implementation is provided in vuu-table-extras\n */\nexport interface TableSettingsPanelProps {\n allowColumnLabelCase?: boolean;\n allowColumnDefaultWidth?: boolean;\n allowGridRowStyling?: boolean;\n onDisplayAttributeChange: TableDisplayAttributeChangeHandler;\n tableDisplayAttributes: TableDisplayAttributes;\n permissions?: TableSettingsPermissions | boolean;\n}\n\n/**\n The TableSettingsPanel assumes 'ownership' of the tableSettings.\n It updates the settings in state locally and notifies caller of\n every change via onChange callback\n */\nexport const TableSettingsPanel = ({\n onDisplayAttributeChange,\n tableDisplayAttributes: tableDisplayAttributesProp,\n permissions: permissionsProp,\n}: TableSettingsPanelProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-table-settings-panel\",\n css: tableSettingsPanelCss,\n window: targetWindow,\n });\n\n const permissions =\n permissionsProp === undefined || permissionsProp === true\n ? defaultTableSettingsPermissions\n : permissionsProp === false\n ? noTableSettingsPermissions\n : permissionsProp;\n\n const {\n columnLabelsValue,\n onChangeColumnLabels,\n onChangeTableAttribute,\n onCommitColumnWidth,\n tableDisplayAttributes,\n } = useTableSettings({\n onDisplayAttributeChange,\n tableDisplayAttributes: tableDisplayAttributesProp,\n });\n\n const {\n allowColumnLabelCase = true,\n allowColumnDefaultWidth = true,\n allowGridSeparators = true,\n } = permissions;\n\n return (\n <div className={classBase}>\n {allowColumnDefaultWidth ? (\n <FormField>\n <FormFieldLabel>Column Width</FormFieldLabel>\n <VuuInput\n bordered\n className=\"vuuInput\"\n data-embedded\n onCommit={onCommitColumnWidth}\n />\n </FormField>\n ) : null}\n\n {allowColumnLabelCase ? (\n <FormField>\n <FormFieldLabel>Column Labels</FormFieldLabel>\n <ToggleButtonGroup\n className=\"vuuToggleButtonGroup\"\n onChange={onChangeColumnLabels}\n value={columnLabelsValue}\n >\n <ToggleButton className=\"vuuIconToggleButton\" value={0}>\n <Icon name=\"text-strikethrough\" size={48} />\n </ToggleButton>\n <ToggleButton className=\"vuuIconToggleButton\" value={1}>\n <Icon name=\"text-Tt\" size={48} />\n </ToggleButton>\n <ToggleButton className=\"vuuIconToggleButton\" value={2}>\n <Icon name=\"text-T\" size={48} />\n </ToggleButton>\n </ToggleButtonGroup>\n </FormField>\n ) : null}\n\n {allowGridSeparators ? (\n <FormField>\n <FormFieldLabel>Grid separators</FormFieldLabel>\n <div className=\"saltToggleButtonGroup vuuStateButtonGroup saltToggleButtonGroup-horizontal\">\n <ToggleButton\n selected={tableDisplayAttributes.zebraStripes ?? false}\n onChange={onChangeTableAttribute}\n value=\"zebraStripes\"\n >\n <Icon name=\"row-striping\" size={16} />\n </ToggleButton>\n <ToggleButton\n selected={tableDisplayAttributes.rowSeparators ?? false}\n onChange={onChangeTableAttribute}\n value=\"rowSeparators\"\n >\n <Icon name=\"row-lines\" size={16} />\n </ToggleButton>\n <ToggleButton\n selected={tableDisplayAttributes.columnSeparators ?? false}\n onChange={onChangeTableAttribute}\n value=\"columnSeparators\"\n >\n <Icon name=\"col-lines\" size={16} />\n </ToggleButton>\n </div>\n </FormField>\n ) : null}\n </div>\n );\n};\n"],"names":["useWindow","useComponentCssInjection","tableSettingsPanelCss","useTableSettings","jsxs","FormField","jsx","FormFieldLabel","VuuInput","ToggleButtonGroup","ToggleButton","Icon"],"mappings":"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"}
@@ -0,0 +1,60 @@
1
+ 'use strict';
2
+
3
+ var vuuUtils = require('@vuu-ui/vuu-utils');
4
+ var react = require('react');
5
+
6
+ const useTableSettings = ({
7
+ onDisplayAttributeChange,
8
+ tableDisplayAttributes: tableDisplayAttributesProp
9
+ }) => {
10
+ const [tableDisplayAttributes, setDisplayTableAttributes] = react.useState(tableDisplayAttributesProp);
11
+ const handleChangeColumnLabels = react.useCallback((evt) => {
12
+ const button = vuuUtils.queryClosest(evt.target, "button");
13
+ if (button) {
14
+ const value = parseInt(button.value);
15
+ const columnFormatHeader = value === 0 ? void 0 : value === 1 ? "capitalize" : "uppercase";
16
+ setDisplayTableAttributes((state) => ({
17
+ ...state,
18
+ columnFormatHeader
19
+ }));
20
+ }
21
+ }, []);
22
+ const handleChangeTableAttribute = react.useCallback(
23
+ (evt) => {
24
+ const button = vuuUtils.queryClosest(evt.target, "button");
25
+ if (button) {
26
+ const { ariaPressed, value } = button;
27
+ setDisplayTableAttributes((state) => ({
28
+ ...state,
29
+ [value]: ariaPressed !== "true"
30
+ }));
31
+ }
32
+ },
33
+ []
34
+ );
35
+ const handleCommitColumnWidth = react.useCallback((_, value) => {
36
+ if (typeof value === "string") {
37
+ const columnDefaultWidth = parseInt(value);
38
+ if (!isNaN(columnDefaultWidth)) {
39
+ setDisplayTableAttributes((state) => ({
40
+ ...state,
41
+ columnDefaultWidth
42
+ }));
43
+ }
44
+ }
45
+ }, []);
46
+ vuuUtils.useLayoutEffectSkipFirst(() => {
47
+ onDisplayAttributeChange?.(tableDisplayAttributes);
48
+ }, [onDisplayAttributeChange, tableDisplayAttributes]);
49
+ const columnLabelsValue = tableDisplayAttributes.columnFormatHeader === void 0 ? 0 : tableDisplayAttributes.columnFormatHeader === "capitalize" ? 1 : 2;
50
+ return {
51
+ columnLabelsValue,
52
+ onChangeColumnLabels: handleChangeColumnLabels,
53
+ onChangeTableAttribute: handleChangeTableAttribute,
54
+ onCommitColumnWidth: handleCommitColumnWidth,
55
+ tableDisplayAttributes
56
+ };
57
+ };
58
+
59
+ exports.useTableSettings = useTableSettings;
60
+ //# sourceMappingURL=useTableSettings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTableSettings.js","sources":["../../../../packages/vuu-table-extras/src/table-settings-panel/useTableSettings.ts"],"sourcesContent":["import { TableDisplayAttributes } from \"@vuu-ui/vuu-table-types\";\nimport {\n queryClosest,\n useLayoutEffectSkipFirst,\n CommitHandler,\n} from \"@vuu-ui/vuu-utils\";\nimport { MouseEvent, SyntheticEvent, useCallback, useState } from \"react\";\nimport { TableSettingsPanelProps } from \"./TableSettingsPanel\";\n\nexport type ColumnLike = {\n name: string;\n};\n\nexport const useTableSettings = ({\n onDisplayAttributeChange,\n tableDisplayAttributes: tableDisplayAttributesProp,\n}: TableSettingsPanelProps) => {\n const [tableDisplayAttributes, setDisplayTableAttributes] =\n useState<TableDisplayAttributes>(tableDisplayAttributesProp);\n\n const handleChangeColumnLabels = useCallback((evt: SyntheticEvent) => {\n const button = queryClosest<HTMLButtonElement>(evt.target, \"button\");\n if (button) {\n const value = parseInt(button.value);\n const columnFormatHeader =\n value === 0 ? undefined : value === 1 ? \"capitalize\" : \"uppercase\";\n setDisplayTableAttributes((state) => ({\n ...state,\n columnFormatHeader,\n }));\n }\n }, []);\n\n const handleChangeTableAttribute = useCallback(\n (evt: MouseEvent<HTMLButtonElement>) => {\n const button = queryClosest<HTMLButtonElement>(evt.target, \"button\");\n if (button) {\n const { ariaPressed, value } = button;\n setDisplayTableAttributes((state) => ({\n ...state,\n [value]: ariaPressed !== \"true\",\n }));\n }\n },\n [],\n );\n\n const handleCommitColumnWidth = useCallback<CommitHandler>((_, value) => {\n if (typeof value === \"string\") {\n const columnDefaultWidth = parseInt(value);\n if (!isNaN(columnDefaultWidth)) {\n setDisplayTableAttributes((state) => ({\n ...state,\n columnDefaultWidth,\n }));\n }\n }\n }, []);\n\n useLayoutEffectSkipFirst(() => {\n onDisplayAttributeChange?.(tableDisplayAttributes);\n }, [onDisplayAttributeChange, tableDisplayAttributes]);\n\n const columnLabelsValue =\n tableDisplayAttributes.columnFormatHeader === undefined\n ? 0\n : tableDisplayAttributes.columnFormatHeader === \"capitalize\"\n ? 1\n : 2;\n\n return {\n columnLabelsValue,\n onChangeColumnLabels: handleChangeColumnLabels,\n onChangeTableAttribute: handleChangeTableAttribute,\n onCommitColumnWidth: handleCommitColumnWidth,\n tableDisplayAttributes,\n };\n};\n"],"names":["useState","useCallback","queryClosest","useLayoutEffectSkipFirst"],"mappings":";;;;;AAaO,MAAM,mBAAmB,CAAC;AAAA,EAC/B,wBAAA;AAAA,EACA,sBAAwB,EAAA;AAC1B,CAA+B,KAAA;AAC7B,EAAA,MAAM,CAAC,sBAAA,EAAwB,yBAAyB,CAAA,GACtDA,eAAiC,0BAA0B,CAAA;AAE7D,EAAM,MAAA,wBAAA,GAA2BC,iBAAY,CAAA,CAAC,GAAwB,KAAA;AACpE,IAAA,MAAM,MAAS,GAAAC,qBAAA,CAAgC,GAAI,CAAA,MAAA,EAAQ,QAAQ,CAAA;AACnE,IAAA,IAAI,MAAQ,EAAA;AACV,MAAM,MAAA,KAAA,GAAQ,QAAS,CAAA,MAAA,CAAO,KAAK,CAAA;AACnC,MAAA,MAAM,qBACJ,KAAU,KAAA,CAAA,GAAI,KAAY,CAAA,GAAA,KAAA,KAAU,IAAI,YAAe,GAAA,WAAA;AACzD,MAAA,yBAAA,CAA0B,CAAC,KAAW,MAAA;AAAA,QACpC,GAAG,KAAA;AAAA,QACH;AAAA,OACA,CAAA,CAAA;AAAA;AACJ,GACF,EAAG,EAAE,CAAA;AAEL,EAAA,MAAM,0BAA6B,GAAAD,iBAAA;AAAA,IACjC,CAAC,GAAuC,KAAA;AACtC,MAAA,MAAM,MAAS,GAAAC,qBAAA,CAAgC,GAAI,CAAA,MAAA,EAAQ,QAAQ,CAAA;AACnE,MAAA,IAAI,MAAQ,EAAA;AACV,QAAM,MAAA,EAAE,WAAa,EAAA,KAAA,EAAU,GAAA,MAAA;AAC/B,QAAA,yBAAA,CAA0B,CAAC,KAAW,MAAA;AAAA,UACpC,GAAG,KAAA;AAAA,UACH,CAAC,KAAK,GAAG,WAAgB,KAAA;AAAA,SACzB,CAAA,CAAA;AAAA;AACJ,KACF;AAAA,IACA;AAAC,GACH;AAEA,EAAA,MAAM,uBAA0B,GAAAD,iBAAA,CAA2B,CAAC,CAAA,EAAG,KAAU,KAAA;AACvE,IAAI,IAAA,OAAO,UAAU,QAAU,EAAA;AAC7B,MAAM,MAAA,kBAAA,GAAqB,SAAS,KAAK,CAAA;AACzC,MAAI,IAAA,CAAC,KAAM,CAAA,kBAAkB,CAAG,EAAA;AAC9B,QAAA,yBAAA,CAA0B,CAAC,KAAW,MAAA;AAAA,UACpC,GAAG,KAAA;AAAA,UACH;AAAA,SACA,CAAA,CAAA;AAAA;AACJ;AACF,GACF,EAAG,EAAE,CAAA;AAEL,EAAAE,iCAAA,CAAyB,MAAM;AAC7B,IAAA,wBAAA,GAA2B,sBAAsB,CAAA;AAAA,GAChD,EAAA,CAAC,wBAA0B,EAAA,sBAAsB,CAAC,CAAA;AAErD,EAAM,MAAA,iBAAA,GACJ,uBAAuB,kBAAuB,KAAA,KAAA,CAAA,GAC1C,IACA,sBAAuB,CAAA,kBAAA,KAAuB,eAC5C,CACA,GAAA,CAAA;AAER,EAAO,OAAA;AAAA,IACL,iBAAA;AAAA,IACA,oBAAsB,EAAA,wBAAA;AAAA,IACtB,sBAAwB,EAAA,0BAAA;AAAA,IACxB,mBAAqB,EAAA,uBAAA;AAAA,IACrB;AAAA,GACF;AACF;;;;"}
@@ -1,7 +1,8 @@
1
1
  import { jsxs, jsx } from 'react/jsx-runtime';
2
- import { getCalculatedColumnDetails } from '@vuu-ui/vuu-utils';
3
2
  import { FormField, FormFieldLabel, Input, Dropdown, Option } from '@salt-ds/core';
3
+ import { useCalculatedColumnPanel } from './useCalculatedColumnPanel.js';
4
4
  import { useRef, useCallback } from 'react';
5
+ import { getCalculatedColumnDetails } from '@vuu-ui/vuu-utils';
5
6
  import { ColumnExpressionInput } from '../column-expression-input/ColumnExpressionInput.js';
6
7
  import '../column-expression-input/column-language-parser/ColumnExpressionLanguage.js';
7
8
  import '../column-expression-input/column-language-parser/ColumnExpressionTreeWalker.js';
@@ -10,27 +11,26 @@ import '@vuu-ui/vuu-codemirror';
10
11
  import '../column-expression-input/highlighting.js';
11
12
  import '../column-expression-input/theme.js';
12
13
  import { useColumnExpressionSuggestionProvider } from '../column-expression-input/useColumnExpressionSuggestionProvider.js';
13
- import { useColumnExpression } from './useColumnExpression.js';
14
14
 
15
- const classBase = "vuuColumnExpressionPanel";
16
- const ColumnExpressionPanel = ({
15
+ const classBase = "vuuCalculatedColumnPanel";
16
+ const CalculatedColumnPanel = ({
17
17
  column: columnProp,
18
- onChangeName: onChangeNameProp,
18
+ columnModel,
19
+ onChangeColumn,
19
20
  onChangeServerDataType: onChangeServerDataTypeProp,
20
- tableConfig,
21
21
  vuuTable
22
22
  }) => {
23
23
  const typeRef = useRef(null);
24
- const { column, onChangeExpression, onChangeName, onChangeServerDataType } = useColumnExpression({
24
+ const { column, onChangeExpression, onChangeName, onChangeServerDataType } = useCalculatedColumnPanel({
25
25
  column: columnProp,
26
- onChangeName: onChangeNameProp,
26
+ onChangeColumn,
27
27
  onChangeServerDataType: onChangeServerDataTypeProp
28
28
  });
29
29
  const initialExpressionRef = useRef(
30
30
  getCalculatedColumnDetails(column).expression ?? ""
31
31
  );
32
32
  const suggestionProvider = useColumnExpressionSuggestionProvider({
33
- columns: tableConfig.columns,
33
+ columns: columnModel.selectedColumns,
34
34
  table: vuuTable
35
35
  });
36
36
  const handleSubmitExpression = useCallback(() => {
@@ -40,9 +40,9 @@ const ColumnExpressionPanel = ({
40
40
  }, []);
41
41
  const { name, serverDataType } = getCalculatedColumnDetails(column);
42
42
  return /* @__PURE__ */ jsxs("div", { className: classBase, children: [
43
- /* @__PURE__ */ jsx("div", { className: "vuuColumnSettingsPanel-header", children: /* @__PURE__ */ jsx("span", { children: "Calculation" }) }),
43
+ /* @__PURE__ */ jsx("div", { children: column.name }),
44
44
  /* @__PURE__ */ jsxs(FormField, { "data-field": "column-name", children: [
45
- /* @__PURE__ */ jsx(FormFieldLabel, { children: "Column Name" }),
45
+ /* @__PURE__ */ jsx(FormFieldLabel, { children: "Column Label" }),
46
46
  /* @__PURE__ */ jsx(Input, { className: "vuuInput", onChange: onChangeName, value: name })
47
47
  ] }),
48
48
  /* @__PURE__ */ jsxs(FormField, { "data-field": "column-expression", children: [
@@ -79,5 +79,5 @@ const ColumnExpressionPanel = ({
79
79
  ] });
80
80
  };
81
81
 
82
- export { ColumnExpressionPanel };
83
- //# sourceMappingURL=ColumnExpressionPanel.js.map
82
+ export { CalculatedColumnPanel };
83
+ //# sourceMappingURL=CalculatedColumnPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CalculatedColumnPanel.js","sources":["../../../../packages/vuu-table-extras/src/calculated-column/CalculatedColumnPanel.tsx"],"sourcesContent":["import {\n Dropdown,\n FormField,\n FormFieldLabel,\n Input,\n Option,\n} from \"@salt-ds/core\";\nimport { useCalculatedColumnPanel } from \"./useCalculatedColumnPanel\";\nimport { HTMLAttributes, useCallback, useRef } from \"react\";\nimport { ColumnDescriptor } from \"@vuu-ui/vuu-table-types\";\nimport { VuuColumnDataType, VuuTable } from \"@vuu-ui/vuu-protocol-types\";\nimport { getCalculatedColumnDetails } from \"@vuu-ui/vuu-utils\";\nimport {\n ColumnExpressionInput,\n ColumnExpressionSubmitHandler,\n useColumnExpressionSuggestionProvider,\n} from \"../column-expression-input\";\nimport { ColumnModel } from \"../column-picker/ColumnModel\";\n\nconst classBase = \"vuuCalculatedColumnPanel\";\n\nexport interface CalculatedColumnPanelProps\n extends HTMLAttributes<HTMLDivElement> {\n column: ColumnDescriptor;\n columnModel: ColumnModel;\n onChangeColumn: (column: ColumnDescriptor) => void;\n onChangeServerDataType?: (name: VuuColumnDataType) => void;\n vuuTable: VuuTable;\n}\n\nexport const CalculatedColumnPanel = ({\n column: columnProp,\n columnModel,\n onChangeColumn,\n onChangeServerDataType: onChangeServerDataTypeProp,\n vuuTable,\n}: CalculatedColumnPanelProps) => {\n const typeRef = useRef<HTMLButtonElement>(null);\n\n const { column, onChangeExpression, onChangeName, onChangeServerDataType } =\n useCalculatedColumnPanel({\n column: columnProp,\n onChangeColumn,\n onChangeServerDataType: onChangeServerDataTypeProp,\n });\n // The initial value to pass into the Expression Input. That is a\n // CodeMirror editor and will manage its own state once initialised.\n const initialExpressionRef = useRef<string>(\n getCalculatedColumnDetails(column).expression ?? \"\",\n );\n\n const suggestionProvider = useColumnExpressionSuggestionProvider({\n columns: columnModel.selectedColumns,\n table: vuuTable,\n });\n\n const handleSubmitExpression =\n useCallback<ColumnExpressionSubmitHandler>(() => {\n if (typeRef.current) {\n (\n typeRef.current?.querySelector(\"button\") as HTMLButtonElement\n )?.focus();\n }\n }, []);\n\n const { name, serverDataType } = getCalculatedColumnDetails(column);\n\n return (\n <div className={classBase}>\n <div>{column.name}</div>\n\n <FormField data-field=\"column-name\">\n <FormFieldLabel>Column Label</FormFieldLabel>\n <Input className=\"vuuInput\" onChange={onChangeName} value={name} />\n </FormField>\n\n <FormField data-field=\"column-expression\">\n <FormFieldLabel>Expression</FormFieldLabel>\n <ColumnExpressionInput\n onChange={onChangeExpression}\n onSubmitExpression={handleSubmitExpression}\n source={initialExpressionRef.current}\n suggestionProvider={suggestionProvider}\n />\n </FormField>\n <FormField data-field=\"type\">\n <FormFieldLabel>Column type</FormFieldLabel>\n <Dropdown\n className={`${classBase}-type`}\n onSelectionChange={onChangeServerDataType}\n ref={typeRef}\n selected={serverDataType ? [serverDataType] : []}\n value={serverDataType}\n >\n <Option value=\"boolean\">Boolean</Option>\n <Option value=\"double\">Double</Option>\n <Option value=\"long\">Long</Option>\n <Option value=\"string\">String</Option>\n </Dropdown>\n </FormField>\n </div>\n );\n};\n"],"names":[],"mappings":"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"}