@vuu-ui/vuu-utils 0.13.8 → 0.13.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/node_modules/@dnd-kit/abstract/index.js +625 -0
- package/cjs/node_modules/@dnd-kit/abstract/index.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/abstract/modifiers.js +85 -0
- package/cjs/node_modules/@dnd-kit/abstract/modifiers.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/collision/dist/index.js +91 -0
- package/cjs/node_modules/@dnd-kit/collision/dist/index.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/dom/index.js +1649 -0
- package/cjs/node_modules/@dnd-kit/dom/index.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/dom/sortable.js +833 -0
- package/cjs/node_modules/@dnd-kit/dom/sortable.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/dom/utilities.js +1389 -0
- package/cjs/node_modules/@dnd-kit/dom/utilities.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/geometry/dist/index.js +310 -0
- package/cjs/node_modules/@dnd-kit/geometry/dist/index.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/react/hooks.js +86 -0
- package/cjs/node_modules/@dnd-kit/react/hooks.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/react/sortable.js +177 -0
- package/cjs/node_modules/@dnd-kit/react/sortable.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/react/utilities.js +19 -0
- package/cjs/node_modules/@dnd-kit/react/utilities.js.map +1 -0
- package/cjs/node_modules/@dnd-kit/state/dist/index.js +272 -0
- package/cjs/node_modules/@dnd-kit/state/dist/index.js.map +1 -0
- package/cjs/node_modules/@preact/signals-core/dist/signals-core.js +11 -0
- package/cjs/node_modules/@preact/signals-core/dist/signals-core.js.map +1 -0
- package/cjs/packages/vuu-utils/src/DataWindow.js +76 -0
- package/cjs/packages/vuu-utils/src/DataWindow.js.map +1 -0
- package/cjs/packages/vuu-utils/src/ShellContext.js +13 -0
- package/cjs/packages/vuu-utils/src/ShellContext.js.map +1 -0
- package/cjs/packages/vuu-utils/src/ThemeProvider.js +85 -0
- package/cjs/packages/vuu-utils/src/ThemeProvider.js.map +1 -0
- package/cjs/packages/vuu-utils/src/array-utils.js +87 -0
- package/cjs/packages/vuu-utils/src/array-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/box-utils.js +53 -0
- package/cjs/packages/vuu-utils/src/box-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/column-utils.js +891 -0
- package/cjs/packages/vuu-utils/src/column-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/common-types.js +15 -0
- package/cjs/packages/vuu-utils/src/common-types.js.map +1 -0
- package/cjs/packages/vuu-utils/src/component-registry.js +140 -0
- package/cjs/packages/vuu-utils/src/component-registry.js.map +1 -0
- package/cjs/packages/vuu-utils/src/context-definitions/DataContext.js +20 -0
- package/cjs/packages/vuu-utils/src/context-definitions/DataContext.js.map +1 -0
- package/cjs/packages/vuu-utils/src/context-definitions/DataProvider.js +24 -0
- package/cjs/packages/vuu-utils/src/context-definitions/DataProvider.js.map +1 -0
- package/cjs/packages/vuu-utils/src/context-definitions/DataSourceProvider.js +33 -0
- package/cjs/packages/vuu-utils/src/context-definitions/DataSourceProvider.js.map +1 -0
- package/cjs/packages/vuu-utils/src/context-definitions/WorkspaceContext.js +20 -0
- package/cjs/packages/vuu-utils/src/context-definitions/WorkspaceContext.js.map +1 -0
- package/cjs/packages/vuu-utils/src/cookie-utils.js +10 -0
- package/cjs/packages/vuu-utils/src/cookie-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/css-utils.js +9 -0
- package/cjs/packages/vuu-utils/src/css-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/data-utils.js +81 -0
- package/cjs/packages/vuu-utils/src/data-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/datasource/BaseDataSource.js +248 -0
- package/cjs/packages/vuu-utils/src/datasource/BaseDataSource.js.map +1 -0
- package/cjs/packages/vuu-utils/src/datasource/datasource-action-utils.js +14 -0
- package/cjs/packages/vuu-utils/src/datasource/datasource-action-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/datasource/datasource-filter-utils.js +23 -0
- package/cjs/packages/vuu-utils/src/datasource/datasource-filter-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/datasource/datasource-utils.js +207 -0
- package/cjs/packages/vuu-utils/src/datasource/datasource-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/date/date-utils.js +10 -0
- package/cjs/packages/vuu-utils/src/date/date-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/date/dateTimePattern.js +25 -0
- package/cjs/packages/vuu-utils/src/date/dateTimePattern.js.map +1 -0
- package/cjs/packages/vuu-utils/src/date/formatter.js +66 -0
- package/cjs/packages/vuu-utils/src/date/formatter.js.map +1 -0
- package/cjs/packages/vuu-utils/src/date/types.js +27 -0
- package/cjs/packages/vuu-utils/src/date/types.js.map +1 -0
- package/cjs/packages/vuu-utils/src/debug-utils.js +34 -0
- package/cjs/packages/vuu-utils/src/debug-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/event-emitter.js +113 -0
- package/cjs/packages/vuu-utils/src/event-emitter.js.map +1 -0
- package/cjs/packages/vuu-utils/src/feature-utils.js +139 -0
- package/cjs/packages/vuu-utils/src/feature-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/filters/filter-utils.js +136 -0
- package/cjs/packages/vuu-utils/src/filters/filter-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/filters/filterAsQuery.js +76 -0
- package/cjs/packages/vuu-utils/src/filters/filterAsQuery.js.map +1 -0
- package/cjs/packages/vuu-utils/src/form-utils.js +48 -0
- package/cjs/packages/vuu-utils/src/form-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/formatting-utils.js +68 -0
- package/cjs/packages/vuu-utils/src/formatting-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/getUniqueId.js +6 -0
- package/cjs/packages/vuu-utils/src/getUniqueId.js.map +1 -0
- package/cjs/packages/vuu-utils/src/group-utils.js +27 -0
- package/cjs/packages/vuu-utils/src/group-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/html-utils.js +162 -0
- package/cjs/packages/vuu-utils/src/html-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/index.js +414 -0
- package/cjs/packages/vuu-utils/src/index.js.map +1 -0
- package/cjs/packages/vuu-utils/src/input-utils.js +10 -0
- package/cjs/packages/vuu-utils/src/input-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/invariant.js +13 -0
- package/cjs/packages/vuu-utils/src/invariant.js.map +1 -0
- package/cjs/packages/vuu-utils/src/itemToString.js +23 -0
- package/cjs/packages/vuu-utils/src/itemToString.js.map +1 -0
- package/cjs/packages/vuu-utils/src/json-utils.js +103 -0
- package/cjs/packages/vuu-utils/src/json-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/keyboard-utils.js +30 -0
- package/cjs/packages/vuu-utils/src/keyboard-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/keyset.js +72 -0
- package/cjs/packages/vuu-utils/src/keyset.js.map +1 -0
- package/cjs/packages/vuu-utils/src/list-utils.js +11 -0
- package/cjs/packages/vuu-utils/src/list-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/local-storage-utils.js +20 -0
- package/cjs/packages/vuu-utils/src/local-storage-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/logging-utils.js +65 -0
- package/cjs/packages/vuu-utils/src/logging-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/menu-utils.js +10 -0
- package/cjs/packages/vuu-utils/src/menu-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/module-utils.js +6 -0
- package/cjs/packages/vuu-utils/src/module-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/moving-window.js +103 -0
- package/cjs/packages/vuu-utils/src/moving-window.js.map +1 -0
- package/cjs/packages/vuu-utils/src/nanoid/index.js +22 -0
- package/cjs/packages/vuu-utils/src/nanoid/index.js.map +1 -0
- package/cjs/packages/vuu-utils/src/perf-utils.js +35 -0
- package/cjs/packages/vuu-utils/src/perf-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/promise-utils.js +42 -0
- package/cjs/packages/vuu-utils/src/promise-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/protocol-message-utils.js +86 -0
- package/cjs/packages/vuu-utils/src/protocol-message-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/range-utils.js +152 -0
- package/cjs/packages/vuu-utils/src/range-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/react-utils.js +36 -0
- package/cjs/packages/vuu-utils/src/react-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/round-decimal.js +86 -0
- package/cjs/packages/vuu-utils/src/round-decimal.js.map +1 -0
- package/cjs/packages/vuu-utils/src/row-utils.js +44 -0
- package/cjs/packages/vuu-utils/src/row-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/selection-utils.js +246 -0
- package/cjs/packages/vuu-utils/src/selection-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/shell-layout-types.js +13 -0
- package/cjs/packages/vuu-utils/src/shell-layout-types.js.map +1 -0
- package/cjs/packages/vuu-utils/src/sort-utils.js +78 -0
- package/cjs/packages/vuu-utils/src/sort-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/table-schema-utils.js +13 -0
- package/cjs/packages/vuu-utils/src/table-schema-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/text-utils.js +21 -0
- package/cjs/packages/vuu-utils/src/text-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/tree-utils.js +106 -0
- package/cjs/packages/vuu-utils/src/tree-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/ts-utils.js +12 -0
- package/cjs/packages/vuu-utils/src/ts-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/typeahead-utils.js +6 -0
- package/cjs/packages/vuu-utils/src/typeahead-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/url-utils.js +21 -0
- package/cjs/packages/vuu-utils/src/url-utils.js.map +1 -0
- package/cjs/packages/vuu-utils/src/useId.js +9 -0
- package/cjs/packages/vuu-utils/src/useId.js.map +1 -0
- package/cjs/packages/vuu-utils/src/useLayoutEffectSkipFirst.js +17 -0
- package/cjs/packages/vuu-utils/src/useLayoutEffectSkipFirst.js.map +1 -0
- package/cjs/packages/vuu-utils/src/useStateRef.js +23 -0
- package/cjs/packages/vuu-utils/src/useStateRef.js.map +1 -0
- package/esm/node_modules/@dnd-kit/abstract/index.js +612 -0
- package/esm/node_modules/@dnd-kit/abstract/index.js.map +1 -0
- package/esm/node_modules/@dnd-kit/abstract/modifiers.js +82 -0
- package/esm/node_modules/@dnd-kit/abstract/modifiers.js.map +1 -0
- package/esm/node_modules/@dnd-kit/collision/dist/index.js +86 -0
- package/esm/node_modules/@dnd-kit/collision/dist/index.js.map +1 -0
- package/esm/node_modules/@dnd-kit/dom/index.js +1642 -0
- package/esm/node_modules/@dnd-kit/dom/index.js.map +1 -0
- package/esm/node_modules/@dnd-kit/dom/sortable.js +827 -0
- package/esm/node_modules/@dnd-kit/dom/sortable.js.map +1 -0
- package/esm/node_modules/@dnd-kit/dom/utilities.js +1344 -0
- package/esm/node_modules/@dnd-kit/dom/utilities.js.map +1 -0
- package/esm/node_modules/@dnd-kit/geometry/dist/index.js +303 -0
- package/esm/node_modules/@dnd-kit/geometry/dist/index.js.map +1 -0
- package/esm/node_modules/@dnd-kit/react/hooks.js +80 -0
- package/esm/node_modules/@dnd-kit/react/hooks.js.map +1 -0
- package/esm/node_modules/@dnd-kit/react/sortable.js +175 -0
- package/esm/node_modules/@dnd-kit/react/sortable.js.map +1 -0
- package/esm/node_modules/@dnd-kit/react/utilities.js +17 -0
- package/esm/node_modules/@dnd-kit/react/utilities.js.map +1 -0
- package/esm/node_modules/@dnd-kit/state/dist/index.js +259 -0
- package/esm/node_modules/@dnd-kit/state/dist/index.js.map +1 -0
- package/esm/node_modules/@preact/signals-core/dist/signals-core.js +4 -0
- package/esm/node_modules/@preact/signals-core/dist/signals-core.js.map +1 -0
- package/esm/packages/vuu-utils/src/DataWindow.js +74 -0
- package/esm/packages/vuu-utils/src/DataWindow.js.map +1 -0
- package/esm/packages/vuu-utils/src/ShellContext.js +10 -0
- package/esm/packages/vuu-utils/src/ShellContext.js.map +1 -0
- package/esm/packages/vuu-utils/src/ThemeProvider.js +78 -0
- package/esm/packages/vuu-utils/src/ThemeProvider.js.map +1 -0
- package/esm/packages/vuu-utils/src/array-utils.js +79 -0
- package/esm/packages/vuu-utils/src/array-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/box-utils.js +47 -0
- package/esm/packages/vuu-utils/src/box-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/column-utils.js +815 -0
- package/esm/packages/vuu-utils/src/column-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/common-types.js +13 -0
- package/esm/packages/vuu-utils/src/common-types.js.map +1 -0
- package/esm/packages/vuu-utils/src/component-registry.js +124 -0
- package/esm/packages/vuu-utils/src/component-registry.js.map +1 -0
- package/esm/packages/vuu-utils/src/context-definitions/DataContext.js +18 -0
- package/esm/packages/vuu-utils/src/context-definitions/DataContext.js.map +1 -0
- package/esm/packages/vuu-utils/src/context-definitions/DataProvider.js +20 -0
- package/esm/packages/vuu-utils/src/context-definitions/DataProvider.js.map +1 -0
- package/esm/packages/vuu-utils/src/context-definitions/DataSourceProvider.js +29 -0
- package/esm/packages/vuu-utils/src/context-definitions/DataSourceProvider.js.map +1 -0
- package/esm/packages/vuu-utils/src/context-definitions/WorkspaceContext.js +17 -0
- package/esm/packages/vuu-utils/src/context-definitions/WorkspaceContext.js.map +1 -0
- package/esm/packages/vuu-utils/src/cookie-utils.js +8 -0
- package/esm/packages/vuu-utils/src/cookie-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/css-utils.js +7 -0
- package/esm/packages/vuu-utils/src/css-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/data-utils.js +68 -0
- package/esm/packages/vuu-utils/src/data-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/datasource/BaseDataSource.js +246 -0
- package/esm/packages/vuu-utils/src/datasource/BaseDataSource.js.map +1 -0
- package/esm/packages/vuu-utils/src/datasource/datasource-action-utils.js +8 -0
- package/esm/packages/vuu-utils/src/datasource/datasource-action-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/datasource/datasource-filter-utils.js +21 -0
- package/esm/packages/vuu-utils/src/datasource/datasource-filter-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/datasource/datasource-utils.js +184 -0
- package/esm/packages/vuu-utils/src/datasource/datasource-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/date/date-utils.js +8 -0
- package/esm/packages/vuu-utils/src/date/date-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/date/dateTimePattern.js +21 -0
- package/esm/packages/vuu-utils/src/date/dateTimePattern.js.map +1 -0
- package/esm/packages/vuu-utils/src/date/formatter.js +63 -0
- package/esm/packages/vuu-utils/src/date/formatter.js.map +1 -0
- package/esm/packages/vuu-utils/src/date/types.js +21 -0
- package/esm/packages/vuu-utils/src/date/types.js.map +1 -0
- package/esm/packages/vuu-utils/src/debug-utils.js +32 -0
- package/esm/packages/vuu-utils/src/debug-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/event-emitter.js +111 -0
- package/esm/packages/vuu-utils/src/event-emitter.js.map +1 -0
- package/esm/packages/vuu-utils/src/feature-utils.js +125 -0
- package/esm/packages/vuu-utils/src/feature-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/filters/filter-utils.js +120 -0
- package/esm/packages/vuu-utils/src/filters/filter-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/filters/filterAsQuery.js +72 -0
- package/esm/packages/vuu-utils/src/filters/filterAsQuery.js.map +1 -0
- package/esm/packages/vuu-utils/src/form-utils.js +44 -0
- package/esm/packages/vuu-utils/src/form-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/formatting-utils.js +63 -0
- package/esm/packages/vuu-utils/src/formatting-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/getUniqueId.js +4 -0
- package/esm/packages/vuu-utils/src/getUniqueId.js.map +1 -0
- package/esm/packages/vuu-utils/src/group-utils.js +23 -0
- package/esm/packages/vuu-utils/src/group-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/html-utils.js +145 -0
- package/esm/packages/vuu-utils/src/html-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/index.js +70 -0
- package/esm/packages/vuu-utils/src/index.js.map +1 -0
- package/esm/packages/vuu-utils/src/input-utils.js +7 -0
- package/esm/packages/vuu-utils/src/input-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/invariant.js +11 -0
- package/esm/packages/vuu-utils/src/invariant.js.map +1 -0
- package/esm/packages/vuu-utils/src/itemToString.js +21 -0
- package/esm/packages/vuu-utils/src/itemToString.js.map +1 -0
- package/esm/packages/vuu-utils/src/json-utils.js +101 -0
- package/esm/packages/vuu-utils/src/json-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/keyboard-utils.js +16 -0
- package/esm/packages/vuu-utils/src/keyboard-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/keyset.js +70 -0
- package/esm/packages/vuu-utils/src/keyset.js.map +1 -0
- package/esm/packages/vuu-utils/src/list-utils.js +9 -0
- package/esm/packages/vuu-utils/src/list-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/local-storage-utils.js +16 -0
- package/esm/packages/vuu-utils/src/local-storage-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/logging-utils.js +61 -0
- package/esm/packages/vuu-utils/src/logging-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/menu-utils.js +6 -0
- package/esm/packages/vuu-utils/src/menu-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/module-utils.js +4 -0
- package/esm/packages/vuu-utils/src/module-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/moving-window.js +101 -0
- package/esm/packages/vuu-utils/src/moving-window.js.map +1 -0
- package/esm/packages/vuu-utils/src/nanoid/index.js +20 -0
- package/esm/packages/vuu-utils/src/nanoid/index.js.map +1 -0
- package/esm/packages/vuu-utils/src/perf-utils.js +32 -0
- package/esm/packages/vuu-utils/src/perf-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/promise-utils.js +40 -0
- package/esm/packages/vuu-utils/src/promise-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/protocol-message-utils.js +71 -0
- package/esm/packages/vuu-utils/src/protocol-message-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/range-utils.js +145 -0
- package/esm/packages/vuu-utils/src/range-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/react-utils.js +32 -0
- package/esm/packages/vuu-utils/src/react-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/round-decimal.js +84 -0
- package/esm/packages/vuu-utils/src/round-decimal.js.map +1 -0
- package/esm/packages/vuu-utils/src/row-utils.js +40 -0
- package/esm/packages/vuu-utils/src/row-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/selection-utils.js +236 -0
- package/esm/packages/vuu-utils/src/selection-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/shell-layout-types.js +11 -0
- package/esm/packages/vuu-utils/src/shell-layout-types.js.map +1 -0
- package/esm/packages/vuu-utils/src/sort-utils.js +73 -0
- package/esm/packages/vuu-utils/src/sort-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/table-schema-utils.js +11 -0
- package/esm/packages/vuu-utils/src/table-schema-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/text-utils.js +18 -0
- package/esm/packages/vuu-utils/src/text-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/tree-utils.js +100 -0
- package/esm/packages/vuu-utils/src/tree-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/ts-utils.js +8 -0
- package/esm/packages/vuu-utils/src/ts-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/typeahead-utils.js +4 -0
- package/esm/packages/vuu-utils/src/typeahead-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/url-utils.js +18 -0
- package/esm/packages/vuu-utils/src/url-utils.js.map +1 -0
- package/esm/packages/vuu-utils/src/useId.js +7 -0
- package/esm/packages/vuu-utils/src/useId.js.map +1 -0
- package/esm/packages/vuu-utils/src/useLayoutEffectSkipFirst.js +15 -0
- package/esm/packages/vuu-utils/src/useLayoutEffectSkipFirst.js.map +1 -0
- package/esm/packages/vuu-utils/src/useStateRef.js +21 -0
- package/esm/packages/vuu-utils/src/useStateRef.js.map +1 -0
- package/package.json +9 -9
- package/cjs/index.js +0 -9622
- package/cjs/index.js.map +0 -1
- package/esm/index.js +0 -9283
- package/esm/index.js.map +0 -1
|
@@ -0,0 +1,815 @@
|
|
|
1
|
+
import { moveItem } from './array-utils.js';
|
|
2
|
+
|
|
3
|
+
const SORT_ASC = "asc";
|
|
4
|
+
const NO_HEADINGS = [];
|
|
5
|
+
const DEFAULT_COL_WIDTH = 100;
|
|
6
|
+
const DEFAULT_MAX_WIDTH = 250;
|
|
7
|
+
const DEFAULT_MIN_WIDTH = 50;
|
|
8
|
+
const AggregationType = {
|
|
9
|
+
Average: 2,
|
|
10
|
+
Count: 3,
|
|
11
|
+
Distinct: 6,
|
|
12
|
+
Sum: 1,
|
|
13
|
+
High: 4,
|
|
14
|
+
Low: 5
|
|
15
|
+
};
|
|
16
|
+
function mapSortCriteria(sortCriteria, columnMap, metadataOffset = 0) {
|
|
17
|
+
return sortCriteria.map((s) => {
|
|
18
|
+
if (typeof s === "string") {
|
|
19
|
+
return [columnMap[s] + metadataOffset, "asc"];
|
|
20
|
+
} else if (Array.isArray(s)) {
|
|
21
|
+
const [columnName, sortDir] = s;
|
|
22
|
+
return [columnMap[columnName] + metadataOffset, sortDir || SORT_ASC];
|
|
23
|
+
} else {
|
|
24
|
+
throw Error("columnUtils.mapSortCriteria invalid input");
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
const numericTypes = ["int", "long", "double"];
|
|
29
|
+
const getDefaultAlignment = (serverDataType) => serverDataType === void 0 ? "left" : numericTypes.includes(serverDataType) ? "right" : "left";
|
|
30
|
+
const getRuntimeColumnWidth = (col, runtimeColumns) => {
|
|
31
|
+
const runtimeColumn = runtimeColumns.find(({ name }) => name === col.name);
|
|
32
|
+
if (runtimeColumn) {
|
|
33
|
+
return runtimeColumn.width;
|
|
34
|
+
} else {
|
|
35
|
+
return DEFAULT_COL_WIDTH;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
const applyRuntimeColumnWidthsToConfig = (tableConfig, columns) => {
|
|
39
|
+
return {
|
|
40
|
+
...tableConfig,
|
|
41
|
+
columns: columns.map((column) => ({
|
|
42
|
+
...column,
|
|
43
|
+
width: column.width ?? getRuntimeColumnWidth(column, columns)
|
|
44
|
+
})),
|
|
45
|
+
columnLayout: "manual"
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
const isValidColumnAlignment = (v) => v === "left" || v === "right";
|
|
49
|
+
const isValidPinLocation = (v) => isValidColumnAlignment(v) || v === "floating" || v === "";
|
|
50
|
+
const VUU_COLUMN_DATA_TYPES = [
|
|
51
|
+
"long",
|
|
52
|
+
"double",
|
|
53
|
+
"int",
|
|
54
|
+
"string",
|
|
55
|
+
"char",
|
|
56
|
+
"boolean"
|
|
57
|
+
];
|
|
58
|
+
const isVuuColumnDataType = (value) => VUU_COLUMN_DATA_TYPES.includes(value);
|
|
59
|
+
const fromServerDataType = (serverDataType) => {
|
|
60
|
+
switch (serverDataType) {
|
|
61
|
+
case "double":
|
|
62
|
+
case "int":
|
|
63
|
+
case "long":
|
|
64
|
+
return "number";
|
|
65
|
+
case "boolean":
|
|
66
|
+
return "boolean";
|
|
67
|
+
default:
|
|
68
|
+
return "string";
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
const isNumericColumn = ({ serverDataType, type }) => {
|
|
72
|
+
if (serverDataType === "int" || serverDataType === "long" || serverDataType === "double") {
|
|
73
|
+
return true;
|
|
74
|
+
}
|
|
75
|
+
if (typeof type === "string") {
|
|
76
|
+
return type === "number";
|
|
77
|
+
}
|
|
78
|
+
if (typeof type?.name === "string") {
|
|
79
|
+
return type?.name === "number";
|
|
80
|
+
}
|
|
81
|
+
return false;
|
|
82
|
+
};
|
|
83
|
+
const isDateTimeDataValue = (column) => (isTypeDescriptor(column.type) ? column.type.name : column.type) === "date/time";
|
|
84
|
+
const isPinned = (column) => typeof column.pin === "string";
|
|
85
|
+
const hasHeadings = (column) => Array.isArray(column.heading) && column.heading.length > 0;
|
|
86
|
+
const isResizing = (column) => column.resizing;
|
|
87
|
+
const isTextColumn = ({ serverDataType }) => serverDataType === void 0 ? false : serverDataType === "char" || serverDataType === "string";
|
|
88
|
+
const toColumnDescriptor = (name) => ({
|
|
89
|
+
name
|
|
90
|
+
});
|
|
91
|
+
const isTypeDescriptor = (type) => typeof type !== "undefined" && typeof type !== "string";
|
|
92
|
+
const EMPTY_COLUMN_MAP = {};
|
|
93
|
+
const isColumnTypeRenderer = (renderer) => typeof renderer?.name !== "undefined";
|
|
94
|
+
const hasCustomRenderer = (type) => isTypeDescriptor(type) && isColumnTypeRenderer(type.renderer);
|
|
95
|
+
const isLookupRenderer = (renderer) => typeof renderer?.name !== "undefined" && "lookup" in renderer;
|
|
96
|
+
const isValueListRenderer = (renderer) => typeof renderer?.name !== "undefined" && Array.isArray(renderer.values);
|
|
97
|
+
const hasValidationRules = (type) => isTypeDescriptor(type) && Array.isArray(type.rules) && type.rules.length > 0;
|
|
98
|
+
const isMappedValueTypeRenderer = (renderer) => renderer !== void 0 && typeof renderer?.map !== "undefined";
|
|
99
|
+
function buildColumnMap(columns) {
|
|
100
|
+
const start = metadataKeys.count;
|
|
101
|
+
if (columns) {
|
|
102
|
+
return columns.reduce((map, column, i) => {
|
|
103
|
+
if (typeof column === "string") {
|
|
104
|
+
map[column] = start + i;
|
|
105
|
+
} else {
|
|
106
|
+
map[column.name] = start + i;
|
|
107
|
+
}
|
|
108
|
+
return map;
|
|
109
|
+
}, {});
|
|
110
|
+
} else {
|
|
111
|
+
return EMPTY_COLUMN_MAP;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
function projectUpdates(updates) {
|
|
115
|
+
const results = [];
|
|
116
|
+
const metadataOffset = metadataKeys.count - 2;
|
|
117
|
+
for (let i = 0; i < updates.length; i += 3) {
|
|
118
|
+
results[i] = updates[i] + metadataOffset;
|
|
119
|
+
results[i + 1] = updates[i + 1];
|
|
120
|
+
results[i + 2] = updates[i + 2];
|
|
121
|
+
}
|
|
122
|
+
return results;
|
|
123
|
+
}
|
|
124
|
+
const KEY = 6;
|
|
125
|
+
const metadataKeys = {
|
|
126
|
+
IDX: 0,
|
|
127
|
+
RENDER_IDX: 1,
|
|
128
|
+
IS_LEAF: 2,
|
|
129
|
+
IS_EXPANDED: 3,
|
|
130
|
+
DEPTH: 4,
|
|
131
|
+
COUNT: 5,
|
|
132
|
+
KEY,
|
|
133
|
+
SELECTED: 7,
|
|
134
|
+
count: 8,
|
|
135
|
+
// TODO following only used in datamodel
|
|
136
|
+
PARENT_IDX: "parent_idx",
|
|
137
|
+
IDX_POINTER: "idx_pointer",
|
|
138
|
+
FILTER_COUNT: "filter_count",
|
|
139
|
+
NEXT_FILTER_IDX: "next_filter_idx"
|
|
140
|
+
};
|
|
141
|
+
const insertColumn = (columns, column) => {
|
|
142
|
+
const { originalIdx } = column;
|
|
143
|
+
if (typeof originalIdx === "number") {
|
|
144
|
+
for (let i = 0; i < columns.length; i++) {
|
|
145
|
+
const { originalIdx: colIdx = -1 } = columns[i];
|
|
146
|
+
if (colIdx > originalIdx) {
|
|
147
|
+
columns.splice(i, 0, column);
|
|
148
|
+
return columns;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
columns.push(column);
|
|
153
|
+
return columns;
|
|
154
|
+
};
|
|
155
|
+
const flattenColumnGroup = (columns) => {
|
|
156
|
+
if (columns[0]?.isGroup) {
|
|
157
|
+
const [groupColumn, ...nonGroupedColumns] = columns;
|
|
158
|
+
groupColumn.columns.forEach((groupColumn2) => {
|
|
159
|
+
insertColumn(nonGroupedColumns, groupColumn2);
|
|
160
|
+
});
|
|
161
|
+
return nonGroupedColumns;
|
|
162
|
+
} else {
|
|
163
|
+
return columns;
|
|
164
|
+
}
|
|
165
|
+
};
|
|
166
|
+
function extractGroupColumn({
|
|
167
|
+
availableWidth,
|
|
168
|
+
columns,
|
|
169
|
+
groupBy,
|
|
170
|
+
confirmed = true
|
|
171
|
+
}) {
|
|
172
|
+
if (groupBy && groupBy.length > 0) {
|
|
173
|
+
const flattenedColumns = flattenColumnGroup(columns);
|
|
174
|
+
const [groupedColumns, rest] = flattenedColumns.reduce(
|
|
175
|
+
(result, column, i) => {
|
|
176
|
+
const [g, r] = result;
|
|
177
|
+
if (groupBy.includes(column.name)) {
|
|
178
|
+
g.push({
|
|
179
|
+
...column,
|
|
180
|
+
originalIdx: i
|
|
181
|
+
});
|
|
182
|
+
} else {
|
|
183
|
+
r.push(column);
|
|
184
|
+
}
|
|
185
|
+
return result;
|
|
186
|
+
},
|
|
187
|
+
[[], []]
|
|
188
|
+
);
|
|
189
|
+
if (groupedColumns.length !== groupBy.length) {
|
|
190
|
+
throw Error(
|
|
191
|
+
`extractGroupColumn: no column definition found for all groupBy cols ${JSON.stringify(
|
|
192
|
+
groupBy
|
|
193
|
+
)} `
|
|
194
|
+
);
|
|
195
|
+
}
|
|
196
|
+
const groupOnly = rest.length === 0;
|
|
197
|
+
const groupCount = groupBy.length;
|
|
198
|
+
const groupCols = groupBy.map((name, idx) => {
|
|
199
|
+
const column = groupedColumns.find(
|
|
200
|
+
(col) => col.name === name
|
|
201
|
+
);
|
|
202
|
+
return {
|
|
203
|
+
...column,
|
|
204
|
+
groupLevel: groupCount - idx
|
|
205
|
+
};
|
|
206
|
+
});
|
|
207
|
+
const width = groupOnly ? availableWidth : Math.min(
|
|
208
|
+
availableWidth,
|
|
209
|
+
groupCols.map((c) => c.width).reduce((a, b) => a + b) + 100
|
|
210
|
+
);
|
|
211
|
+
const groupCol = {
|
|
212
|
+
ariaColIndex: 1,
|
|
213
|
+
columns: groupCols,
|
|
214
|
+
heading: ["group-col"],
|
|
215
|
+
isGroup: true,
|
|
216
|
+
groupConfirmed: confirmed,
|
|
217
|
+
name: "group-col",
|
|
218
|
+
width
|
|
219
|
+
};
|
|
220
|
+
const withAdjustedAriaIndex = [];
|
|
221
|
+
let colIndex = 2;
|
|
222
|
+
for (const column of rest) {
|
|
223
|
+
withAdjustedAriaIndex.push({
|
|
224
|
+
...column,
|
|
225
|
+
ariaColIndex: column.hidden ? -1 : colIndex
|
|
226
|
+
});
|
|
227
|
+
if (!column.hidden) {
|
|
228
|
+
colIndex += 1;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
return [groupCol, withAdjustedAriaIndex];
|
|
232
|
+
}
|
|
233
|
+
return [null, flattenColumnGroup(columns)];
|
|
234
|
+
}
|
|
235
|
+
const isGroupColumn = (column) => column.isGroup === true;
|
|
236
|
+
const checkConfirmationPending = (previousConfig) => {
|
|
237
|
+
if (previousConfig) {
|
|
238
|
+
const [column] = previousConfig.columns;
|
|
239
|
+
if (isGroupColumn(column)) {
|
|
240
|
+
return column.groupConfirmed;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
};
|
|
244
|
+
const isJsonAttribute = (value) => typeof value === "string" && (value.endsWith("{") || value.endsWith("["));
|
|
245
|
+
const isJsonGroup = (column, row, columnMap) => column.type?.name === "json" && isJsonAttribute(row[columnMap[column.name]]);
|
|
246
|
+
const isJsonColumn = (column) => column.type?.name === "json";
|
|
247
|
+
const sortPinnedColumns = (columns) => {
|
|
248
|
+
const leftPinnedColumns = [];
|
|
249
|
+
const rightPinnedColumns = [];
|
|
250
|
+
const restColumns = [];
|
|
251
|
+
let pinnedWidthLeft = 4;
|
|
252
|
+
for (const column of columns) {
|
|
253
|
+
switch (column.pin) {
|
|
254
|
+
case "left":
|
|
255
|
+
{
|
|
256
|
+
leftPinnedColumns.push({
|
|
257
|
+
...column,
|
|
258
|
+
endPin: void 0,
|
|
259
|
+
pinnedOffset: pinnedWidthLeft
|
|
260
|
+
});
|
|
261
|
+
pinnedWidthLeft += column.width;
|
|
262
|
+
}
|
|
263
|
+
break;
|
|
264
|
+
// store right pinned columns initially in reverse order
|
|
265
|
+
case "right":
|
|
266
|
+
rightPinnedColumns.unshift(column);
|
|
267
|
+
break;
|
|
268
|
+
default:
|
|
269
|
+
restColumns.push(column);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
if (leftPinnedColumns.length) {
|
|
273
|
+
leftPinnedColumns.push({
|
|
274
|
+
...leftPinnedColumns.pop(),
|
|
275
|
+
endPin: true
|
|
276
|
+
});
|
|
277
|
+
}
|
|
278
|
+
const allColumns = leftPinnedColumns.length ? leftPinnedColumns.concat(restColumns) : restColumns;
|
|
279
|
+
if (rightPinnedColumns.length) {
|
|
280
|
+
const measuredRightPinnedColumns = [];
|
|
281
|
+
let pinnedWidthRight = 0;
|
|
282
|
+
for (const column of rightPinnedColumns) {
|
|
283
|
+
measuredRightPinnedColumns.unshift({
|
|
284
|
+
...column,
|
|
285
|
+
pinnedOffset: pinnedWidthRight
|
|
286
|
+
});
|
|
287
|
+
pinnedWidthRight += column.width;
|
|
288
|
+
}
|
|
289
|
+
measuredRightPinnedColumns[0].endPin = true;
|
|
290
|
+
return allColumns.concat(measuredRightPinnedColumns);
|
|
291
|
+
} else {
|
|
292
|
+
return allColumns;
|
|
293
|
+
}
|
|
294
|
+
};
|
|
295
|
+
const measurePinnedColumns = (columns, selectionEndSize) => {
|
|
296
|
+
let pinnedWidthLeft = 0;
|
|
297
|
+
let pinnedWidthRight = 0;
|
|
298
|
+
let unpinnedWidth = 0;
|
|
299
|
+
for (const column of columns) {
|
|
300
|
+
const { hidden, pin, width } = column;
|
|
301
|
+
const visibleWidth = hidden ? 0 : width;
|
|
302
|
+
if (pin === "left") {
|
|
303
|
+
pinnedWidthLeft += visibleWidth;
|
|
304
|
+
} else if (pin === "right") {
|
|
305
|
+
pinnedWidthRight += visibleWidth;
|
|
306
|
+
} else {
|
|
307
|
+
unpinnedWidth += visibleWidth;
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
return {
|
|
311
|
+
pinnedWidthLeft: pinnedWidthLeft + selectionEndSize,
|
|
312
|
+
pinnedWidthRight: pinnedWidthRight + selectionEndSize,
|
|
313
|
+
unpinnedWidth
|
|
314
|
+
};
|
|
315
|
+
};
|
|
316
|
+
const getTableHeadings = (columns) => {
|
|
317
|
+
if (columns.some(hasHeadings)) {
|
|
318
|
+
const maxHeadingDepth = columns.reduce(
|
|
319
|
+
(max, { heading: heading2 }) => Math.max(max, heading2?.length ?? 0),
|
|
320
|
+
0
|
|
321
|
+
);
|
|
322
|
+
let heading = void 0;
|
|
323
|
+
const tableHeadings = [];
|
|
324
|
+
let tableHeadingsRow;
|
|
325
|
+
for (let level = 0; level < maxHeadingDepth; level++) {
|
|
326
|
+
tableHeadingsRow = [];
|
|
327
|
+
columns.forEach(({ heading: columnHeading = NO_HEADINGS, width }) => {
|
|
328
|
+
const label = columnHeading[level] ?? "";
|
|
329
|
+
if (heading && heading.label === label) {
|
|
330
|
+
heading.width += width;
|
|
331
|
+
} else {
|
|
332
|
+
heading = { label, width };
|
|
333
|
+
tableHeadingsRow.push(heading);
|
|
334
|
+
}
|
|
335
|
+
});
|
|
336
|
+
tableHeadings.push(tableHeadingsRow);
|
|
337
|
+
}
|
|
338
|
+
return tableHeadings;
|
|
339
|
+
}
|
|
340
|
+
return NO_HEADINGS;
|
|
341
|
+
};
|
|
342
|
+
const getColumnStyle = ({
|
|
343
|
+
pin,
|
|
344
|
+
// the 4 is `selectionEndSize`, unfortunate if we need to be passed it from cell
|
|
345
|
+
// need to think about how to make this available
|
|
346
|
+
pinnedOffset = pin === "left" ? 0 : 4,
|
|
347
|
+
width
|
|
348
|
+
}) => pin === "left" ? {
|
|
349
|
+
left: pinnedOffset,
|
|
350
|
+
width,
|
|
351
|
+
"--pin-width": `${pinnedOffset + width - 3}px`
|
|
352
|
+
} : pin === "right" ? {
|
|
353
|
+
right: pinnedOffset,
|
|
354
|
+
width,
|
|
355
|
+
"--pin-width": `${pinnedOffset + width}px`
|
|
356
|
+
} : { width };
|
|
357
|
+
const setAggregations = (aggregations, column, aggType) => {
|
|
358
|
+
return aggregations.filter((agg) => agg.column !== column.name).concat({ column: column.name, aggType });
|
|
359
|
+
};
|
|
360
|
+
const applyGroupByToColumns = (props) => {
|
|
361
|
+
if (props.groupBy.length) {
|
|
362
|
+
const [groupColumn, nonGroupedColumns] = extractGroupColumn(props);
|
|
363
|
+
if (groupColumn) {
|
|
364
|
+
return [groupColumn].concat(nonGroupedColumns);
|
|
365
|
+
}
|
|
366
|
+
} else if (props.columns[0]?.isGroup) {
|
|
367
|
+
return flattenColumnGroup(props.columns);
|
|
368
|
+
}
|
|
369
|
+
return props.columns;
|
|
370
|
+
};
|
|
371
|
+
const applySortToColumns = (columns, sort) => columns.map((column) => {
|
|
372
|
+
const sorted = getSortType(column, sort);
|
|
373
|
+
if (sorted !== void 0) {
|
|
374
|
+
return {
|
|
375
|
+
...column,
|
|
376
|
+
sorted
|
|
377
|
+
};
|
|
378
|
+
} else if (column.sorted) {
|
|
379
|
+
return {
|
|
380
|
+
...column,
|
|
381
|
+
sorted: void 0
|
|
382
|
+
};
|
|
383
|
+
} else {
|
|
384
|
+
return column;
|
|
385
|
+
}
|
|
386
|
+
});
|
|
387
|
+
const removeSort = (columns) => columns.map((col) => col.sorted ? { ...col, sorted: void 0 } : col);
|
|
388
|
+
const existingSort = (columns) => columns.some((col) => col.sorted);
|
|
389
|
+
const getSortType = (column, { sortDefs }) => {
|
|
390
|
+
const sortDef = sortDefs.find((sortCol) => sortCol.column === column.name);
|
|
391
|
+
if (sortDef) {
|
|
392
|
+
return sortDefs.length > 1 ? (sortDefs.indexOf(sortDef) + 1) * (sortDef.sortType === "A" ? 1 : -1) : sortDef.sortType;
|
|
393
|
+
}
|
|
394
|
+
};
|
|
395
|
+
const getColumnName = (name) => {
|
|
396
|
+
const pos = name.indexOf(":");
|
|
397
|
+
if (pos === -1) {
|
|
398
|
+
return name;
|
|
399
|
+
} else {
|
|
400
|
+
return name.slice(0, pos);
|
|
401
|
+
}
|
|
402
|
+
};
|
|
403
|
+
const getColumnLabel = (column) => {
|
|
404
|
+
if (column.label) {
|
|
405
|
+
return column.label;
|
|
406
|
+
} else if (isCalculatedColumn(column.name)) {
|
|
407
|
+
const { name } = getCalculatedColumnDetails(column);
|
|
408
|
+
return name ?? column.name;
|
|
409
|
+
} else {
|
|
410
|
+
return column.name;
|
|
411
|
+
}
|
|
412
|
+
};
|
|
413
|
+
const findColumn = (columns, columnName) => {
|
|
414
|
+
const column = columns.find((col) => col.name === columnName);
|
|
415
|
+
if (column) {
|
|
416
|
+
return column;
|
|
417
|
+
} else {
|
|
418
|
+
const groupColumn = columns.find(
|
|
419
|
+
(col) => col.isGroup
|
|
420
|
+
);
|
|
421
|
+
if (groupColumn) {
|
|
422
|
+
return findColumn(groupColumn.columns, columnName);
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
};
|
|
426
|
+
function updateColumn(columns, column, options) {
|
|
427
|
+
const targetColumn = typeof column === "string" ? columns.find((col) => col.name === column) : column;
|
|
428
|
+
if (targetColumn) {
|
|
429
|
+
const replacementColumn = options ? { ...targetColumn, ...options } : targetColumn;
|
|
430
|
+
return columns.map(
|
|
431
|
+
(col) => col.name === replacementColumn.name ? replacementColumn : col
|
|
432
|
+
);
|
|
433
|
+
} else {
|
|
434
|
+
throw Error("column-utils.replaceColun, column not found");
|
|
435
|
+
}
|
|
436
|
+
}
|
|
437
|
+
const toDataSourceColumns = (column) => column.name;
|
|
438
|
+
const dataSourceRowToDataRowDto = (row, columnMap) => {
|
|
439
|
+
return Object.entries(columnMap).reduce(
|
|
440
|
+
(map, [colName, key]) => {
|
|
441
|
+
map[colName] = row[key];
|
|
442
|
+
return map;
|
|
443
|
+
},
|
|
444
|
+
{}
|
|
445
|
+
);
|
|
446
|
+
};
|
|
447
|
+
const isDataLoading = (columns) => {
|
|
448
|
+
return isGroupColumn(columns[0]) && columns[0].groupConfirmed === false;
|
|
449
|
+
};
|
|
450
|
+
const getColumnsInViewport = (columns, vpStart, vpEnd) => {
|
|
451
|
+
const visibleColumns = [];
|
|
452
|
+
let preSpan = 0;
|
|
453
|
+
let rightPinnedOnly = false;
|
|
454
|
+
for (let columnOffset = 0, i = 0; i < columns.length; i++) {
|
|
455
|
+
const column = columns[i];
|
|
456
|
+
if (column.hidden) {
|
|
457
|
+
continue;
|
|
458
|
+
} else if (rightPinnedOnly) {
|
|
459
|
+
if (column.pin === "right") {
|
|
460
|
+
visibleColumns.push(column);
|
|
461
|
+
}
|
|
462
|
+
} else if (columnOffset + column.width < vpStart) {
|
|
463
|
+
if (column.pin === "left") {
|
|
464
|
+
visibleColumns.push(column);
|
|
465
|
+
} else if (columnOffset + column.width + columns[i + 1]?.width > vpStart) {
|
|
466
|
+
visibleColumns.push(column);
|
|
467
|
+
} else {
|
|
468
|
+
preSpan += column.width;
|
|
469
|
+
}
|
|
470
|
+
} else if (columnOffset > vpEnd) {
|
|
471
|
+
rightPinnedOnly = true;
|
|
472
|
+
} else {
|
|
473
|
+
visibleColumns.push(column);
|
|
474
|
+
}
|
|
475
|
+
columnOffset += column.width;
|
|
476
|
+
}
|
|
477
|
+
return [visibleColumns, preSpan];
|
|
478
|
+
};
|
|
479
|
+
const isNotHidden = (column) => column.hidden !== true;
|
|
480
|
+
const visibleColumnAtIndex = (columns, index) => {
|
|
481
|
+
if (columns.every(isNotHidden)) {
|
|
482
|
+
return columns[index];
|
|
483
|
+
} else {
|
|
484
|
+
return columns.filter(isNotHidden).at(index);
|
|
485
|
+
}
|
|
486
|
+
};
|
|
487
|
+
const { DEPTH, IS_LEAF } = metadataKeys;
|
|
488
|
+
const getGroupIcon = (columns, row) => {
|
|
489
|
+
const { [DEPTH]: depth, [IS_LEAF]: isLeaf } = row;
|
|
490
|
+
if (isLeaf || depth > columns.length) {
|
|
491
|
+
return void 0;
|
|
492
|
+
} else if (depth === 0) {
|
|
493
|
+
return void 0;
|
|
494
|
+
} else {
|
|
495
|
+
const { getIcon } = columns[depth - 1];
|
|
496
|
+
return getIcon?.(row);
|
|
497
|
+
}
|
|
498
|
+
};
|
|
499
|
+
const getGroupValue = (columns, row, columnMap) => {
|
|
500
|
+
const { [DEPTH]: depth, [IS_LEAF]: isLeaf } = row;
|
|
501
|
+
if (isLeaf || depth > columns.length) {
|
|
502
|
+
return null;
|
|
503
|
+
} else if (depth === 0) {
|
|
504
|
+
return "$root";
|
|
505
|
+
} else {
|
|
506
|
+
const { name, valueFormatter } = columns[depth - 1];
|
|
507
|
+
const value = valueFormatter(row[columnMap[name]]);
|
|
508
|
+
return value;
|
|
509
|
+
}
|
|
510
|
+
};
|
|
511
|
+
const getDefaultColumnType = (serverDataType) => {
|
|
512
|
+
switch (serverDataType) {
|
|
513
|
+
case "int":
|
|
514
|
+
case "long":
|
|
515
|
+
case "double":
|
|
516
|
+
return "number";
|
|
517
|
+
case "boolean":
|
|
518
|
+
return "boolean";
|
|
519
|
+
default:
|
|
520
|
+
return "string";
|
|
521
|
+
}
|
|
522
|
+
};
|
|
523
|
+
const updateColumnFormatting = (column, formatting) => {
|
|
524
|
+
const { serverDataType, type = getDefaultColumnType(serverDataType) } = column;
|
|
525
|
+
if (isTypeDescriptor(type)) {
|
|
526
|
+
return { ...column, type: { ...type, formatting } };
|
|
527
|
+
} else {
|
|
528
|
+
return { ...column, type: { name: type, formatting } };
|
|
529
|
+
}
|
|
530
|
+
};
|
|
531
|
+
function updateColumnType(column, type) {
|
|
532
|
+
return isTypeDescriptor(column.type) ? { ...column, type: { ...column.type, name: type } } : { ...column, type };
|
|
533
|
+
}
|
|
534
|
+
const updateColumnRenderProps = (column, renderer) => {
|
|
535
|
+
const { serverDataType, type = getDefaultColumnType(serverDataType) } = column;
|
|
536
|
+
if (isTypeDescriptor(type)) {
|
|
537
|
+
return {
|
|
538
|
+
...column,
|
|
539
|
+
type: {
|
|
540
|
+
...type,
|
|
541
|
+
// TODO do we need to preserve any existing attributes from renderer ?
|
|
542
|
+
renderer
|
|
543
|
+
}
|
|
544
|
+
};
|
|
545
|
+
} else {
|
|
546
|
+
return { ...column, type: { name: type, renderer } };
|
|
547
|
+
}
|
|
548
|
+
};
|
|
549
|
+
const NO_TYPE_SETTINGS = {};
|
|
550
|
+
const getTypeFormattingFromColumn = (column) => {
|
|
551
|
+
if (isTypeDescriptor(column.type)) {
|
|
552
|
+
return column.type.formatting ?? NO_TYPE_SETTINGS;
|
|
553
|
+
} else {
|
|
554
|
+
return NO_TYPE_SETTINGS;
|
|
555
|
+
}
|
|
556
|
+
};
|
|
557
|
+
const subscribedOnly = (columnNames) => (column) => column.source === "client" || columnNames?.includes(column.name);
|
|
558
|
+
const addColumnToSubscribedColumns = (subscribedColumns, availableColumns, columnName) => {
|
|
559
|
+
const byColName = (n = columnName) => (column) => column.name === n;
|
|
560
|
+
if (subscribedColumns.findIndex(byColName()) !== -1) {
|
|
561
|
+
throw Error(
|
|
562
|
+
`column-utils, addColumnToSubscribedColumns column ${columnName} is already subscribed`
|
|
563
|
+
);
|
|
564
|
+
}
|
|
565
|
+
const indexOfAvailableColumn = availableColumns.findIndex(byColName());
|
|
566
|
+
if (indexOfAvailableColumn === -1) {
|
|
567
|
+
throw Error(
|
|
568
|
+
`column-utils, addColumnToSubscribedColumns column ${columnName} is not available`
|
|
569
|
+
);
|
|
570
|
+
}
|
|
571
|
+
const newColumn = {
|
|
572
|
+
...availableColumns[indexOfAvailableColumn]
|
|
573
|
+
};
|
|
574
|
+
let index = -1;
|
|
575
|
+
for (let i = indexOfAvailableColumn - 1; i >= 0; i--) {
|
|
576
|
+
const { name } = availableColumns[i];
|
|
577
|
+
index = subscribedColumns.findIndex(byColName(name));
|
|
578
|
+
if (index !== -1) {
|
|
579
|
+
break;
|
|
580
|
+
}
|
|
581
|
+
}
|
|
582
|
+
if (index === -1) {
|
|
583
|
+
return [newColumn].concat(subscribedColumns);
|
|
584
|
+
} else {
|
|
585
|
+
const results = [];
|
|
586
|
+
for (let i = 0; i < subscribedColumns.length; i++) {
|
|
587
|
+
results.push(subscribedColumns[i]);
|
|
588
|
+
if (i === index) {
|
|
589
|
+
results.push(newColumn);
|
|
590
|
+
index = Number.MAX_SAFE_INTEGER;
|
|
591
|
+
}
|
|
592
|
+
}
|
|
593
|
+
return results;
|
|
594
|
+
}
|
|
595
|
+
};
|
|
596
|
+
const CalculatedColumnPattern = /.*:.*:.*/;
|
|
597
|
+
const isCalculatedColumn = (columnName) => columnName !== void 0 && CalculatedColumnPattern.test(columnName);
|
|
598
|
+
const getCalculatedColumnDetails = (column) => {
|
|
599
|
+
if (isCalculatedColumn(column.name)) {
|
|
600
|
+
const [name, serverDataType, expression] = column.name.split(/:=?/);
|
|
601
|
+
if (serverDataType && !isVuuColumnDataType(serverDataType)) {
|
|
602
|
+
throw Error(
|
|
603
|
+
`column-utils, getCalculatedColumnDetails ${serverDataType} is not valid type for column ${column.name}`
|
|
604
|
+
);
|
|
605
|
+
}
|
|
606
|
+
return {
|
|
607
|
+
name: name ?? "",
|
|
608
|
+
expression: expression ?? "",
|
|
609
|
+
serverDataType: isVuuColumnDataType(serverDataType) ? serverDataType : void 0
|
|
610
|
+
};
|
|
611
|
+
} else {
|
|
612
|
+
throw Error(`column.name is nor a calculated column`);
|
|
613
|
+
}
|
|
614
|
+
};
|
|
615
|
+
const setCalculatedColumnName = (column, name) => {
|
|
616
|
+
const [, type, expression] = column.name.split(":");
|
|
617
|
+
return {
|
|
618
|
+
...column,
|
|
619
|
+
name: `${name}:${type}:${expression}`
|
|
620
|
+
};
|
|
621
|
+
};
|
|
622
|
+
const setCalculatedColumnType = (column, type) => {
|
|
623
|
+
const [name, , expression] = column.name.split(":");
|
|
624
|
+
return {
|
|
625
|
+
...column,
|
|
626
|
+
name: `${name}:${type}:${expression}`
|
|
627
|
+
};
|
|
628
|
+
};
|
|
629
|
+
const setCalculatedColumnExpression = (column, expression) => {
|
|
630
|
+
const [name, type] = column.name.split(":");
|
|
631
|
+
return {
|
|
632
|
+
...column,
|
|
633
|
+
name: `${name}:${type}:=${expression}`
|
|
634
|
+
};
|
|
635
|
+
};
|
|
636
|
+
const moveColumnTo = (columns, column, newIndex) => {
|
|
637
|
+
const index = columns.findIndex((col) => col.name === column.name);
|
|
638
|
+
return moveItem(columns, index, newIndex);
|
|
639
|
+
};
|
|
640
|
+
function replaceColumn(columns, column) {
|
|
641
|
+
return columns.map((col) => col.name === column.name ? column : col);
|
|
642
|
+
}
|
|
643
|
+
const applyDefaultColumnConfig = ({ columns, table }, getDefaultColumnConfig) => {
|
|
644
|
+
if (typeof getDefaultColumnConfig === "function") {
|
|
645
|
+
return columns.map((column) => {
|
|
646
|
+
const config = getDefaultColumnConfig(table.table, column.name);
|
|
647
|
+
if (config) {
|
|
648
|
+
return {
|
|
649
|
+
...column,
|
|
650
|
+
...config
|
|
651
|
+
};
|
|
652
|
+
} else {
|
|
653
|
+
return column;
|
|
654
|
+
}
|
|
655
|
+
});
|
|
656
|
+
} else {
|
|
657
|
+
return columns;
|
|
658
|
+
}
|
|
659
|
+
};
|
|
660
|
+
const measureColumns = (columns, defaultMaxWidth, defaultMinWidth) => columns.reduce(
|
|
661
|
+
(aggregated, column) => {
|
|
662
|
+
if (column.hidden !== true) {
|
|
663
|
+
aggregated.totalMinWidth += column.minWidth ?? defaultMinWidth;
|
|
664
|
+
aggregated.totalMaxWidth += column.maxWidth ?? defaultMaxWidth;
|
|
665
|
+
aggregated.totalWidth += column.width;
|
|
666
|
+
aggregated.flexCount += column.flex ?? 0;
|
|
667
|
+
}
|
|
668
|
+
return aggregated;
|
|
669
|
+
},
|
|
670
|
+
{ totalMinWidth: 0, totalMaxWidth: 0, totalWidth: 0, flexCount: 0 }
|
|
671
|
+
);
|
|
672
|
+
function applyWidthToColumns(columns, {
|
|
673
|
+
availableWidth = 0,
|
|
674
|
+
columnLayout = "static",
|
|
675
|
+
defaultWidth = DEFAULT_COL_WIDTH,
|
|
676
|
+
defaultMinWidth = DEFAULT_MIN_WIDTH,
|
|
677
|
+
defaultMaxWidth = DEFAULT_MAX_WIDTH
|
|
678
|
+
}) {
|
|
679
|
+
if (columnLayout === "fit") {
|
|
680
|
+
const { totalMinWidth, totalMaxWidth, totalWidth, flexCount } = measureColumns(columns, defaultMaxWidth, defaultMinWidth);
|
|
681
|
+
if (totalMaxWidth < availableWidth) {
|
|
682
|
+
return assignMaxWidthToAll(columns, defaultMaxWidth);
|
|
683
|
+
} else if (totalMinWidth > availableWidth) {
|
|
684
|
+
return columns;
|
|
685
|
+
} else if (totalWidth > availableWidth) {
|
|
686
|
+
return shrinkColumnsToFitAvailableSpace(
|
|
687
|
+
columns,
|
|
688
|
+
availableWidth,
|
|
689
|
+
totalWidth,
|
|
690
|
+
defaultMinWidth,
|
|
691
|
+
defaultWidth,
|
|
692
|
+
flexCount
|
|
693
|
+
);
|
|
694
|
+
} else if (totalWidth < availableWidth) {
|
|
695
|
+
return stretchColumnsToFillAvailableSpace(
|
|
696
|
+
columns,
|
|
697
|
+
availableWidth,
|
|
698
|
+
totalWidth,
|
|
699
|
+
defaultMaxWidth,
|
|
700
|
+
defaultWidth
|
|
701
|
+
);
|
|
702
|
+
}
|
|
703
|
+
}
|
|
704
|
+
return columns;
|
|
705
|
+
}
|
|
706
|
+
const assignMaxWidthToAll = (columns, defaultMaxWidth) => {
|
|
707
|
+
return columns.map((column) => {
|
|
708
|
+
const { maxWidth = defaultMaxWidth } = column;
|
|
709
|
+
if (column.width === maxWidth) {
|
|
710
|
+
return column;
|
|
711
|
+
} else {
|
|
712
|
+
return {
|
|
713
|
+
...column,
|
|
714
|
+
width: maxWidth
|
|
715
|
+
};
|
|
716
|
+
}
|
|
717
|
+
});
|
|
718
|
+
};
|
|
719
|
+
const shrinkColumnsToFitAvailableSpace = (columns, availableWidth, totalWidth, defaultMinWidth, defaultWidth, flexCount) => {
|
|
720
|
+
const excessWidth = totalWidth - availableWidth;
|
|
721
|
+
const inFlexMode = flexCount > 0;
|
|
722
|
+
let excessWidthPerColumn = excessWidth / (flexCount || columns.length);
|
|
723
|
+
let columnsNotYetAtMinWidth = columns.length;
|
|
724
|
+
let unassignedExcess = 0;
|
|
725
|
+
let newColumns = columns.map((column) => {
|
|
726
|
+
const {
|
|
727
|
+
minWidth = defaultMinWidth,
|
|
728
|
+
width = defaultWidth,
|
|
729
|
+
flex = 0
|
|
730
|
+
} = column;
|
|
731
|
+
if (inFlexMode && flex === 0) {
|
|
732
|
+
return column;
|
|
733
|
+
}
|
|
734
|
+
const adjustedWidth = width - excessWidthPerColumn;
|
|
735
|
+
if (adjustedWidth < minWidth) {
|
|
736
|
+
columnsNotYetAtMinWidth -= 1;
|
|
737
|
+
unassignedExcess += minWidth - adjustedWidth;
|
|
738
|
+
return { ...column, width: minWidth };
|
|
739
|
+
} else {
|
|
740
|
+
return { ...column, width: adjustedWidth };
|
|
741
|
+
}
|
|
742
|
+
});
|
|
743
|
+
if (unassignedExcess === 0) {
|
|
744
|
+
return newColumns;
|
|
745
|
+
} else {
|
|
746
|
+
excessWidthPerColumn = unassignedExcess / columnsNotYetAtMinWidth;
|
|
747
|
+
newColumns = newColumns.map((column) => {
|
|
748
|
+
const adjustedWidth = column.width - excessWidthPerColumn;
|
|
749
|
+
if (column.width !== column.minWidth) {
|
|
750
|
+
return { ...column, width: adjustedWidth };
|
|
751
|
+
} else {
|
|
752
|
+
return column;
|
|
753
|
+
}
|
|
754
|
+
});
|
|
755
|
+
return newColumns;
|
|
756
|
+
}
|
|
757
|
+
};
|
|
758
|
+
const hasFlex = ({ flex }) => typeof flex === "number";
|
|
759
|
+
const stretchColumnsToFillAvailableSpace = (columns, availableWidth, totalWidth, defaultMaxWidth, defaultWidth) => {
|
|
760
|
+
let freeSpaceToBeFilled = availableWidth - totalWidth;
|
|
761
|
+
let adjustedColumns = columns;
|
|
762
|
+
const canGrow = ({
|
|
763
|
+
width = defaultWidth,
|
|
764
|
+
maxWidth = defaultMaxWidth
|
|
765
|
+
}) => width < maxWidth;
|
|
766
|
+
while (freeSpaceToBeFilled > 0) {
|
|
767
|
+
const flexCols = adjustedColumns.filter(
|
|
768
|
+
(col) => hasFlex(col) && canGrow(col)
|
|
769
|
+
);
|
|
770
|
+
const columnsNotYetAtMaxWidth = flexCols.length || adjustedColumns.filter(canGrow).length;
|
|
771
|
+
const additionalWidthPerColumn = Math.ceil(
|
|
772
|
+
freeSpaceToBeFilled / columnsNotYetAtMaxWidth
|
|
773
|
+
);
|
|
774
|
+
adjustedColumns = columns.map((column) => {
|
|
775
|
+
const {
|
|
776
|
+
maxWidth = defaultMaxWidth,
|
|
777
|
+
width = defaultWidth,
|
|
778
|
+
flex = 0
|
|
779
|
+
} = column;
|
|
780
|
+
if (flexCols.length > 0 && flex === 0) {
|
|
781
|
+
return column;
|
|
782
|
+
}
|
|
783
|
+
const adjustmentAmount = Math.min(
|
|
784
|
+
additionalWidthPerColumn,
|
|
785
|
+
freeSpaceToBeFilled
|
|
786
|
+
);
|
|
787
|
+
const adjustedWidth = width + adjustmentAmount;
|
|
788
|
+
if (adjustedWidth > maxWidth) {
|
|
789
|
+
freeSpaceToBeFilled -= adjustedWidth - maxWidth;
|
|
790
|
+
return { ...column, width: maxWidth };
|
|
791
|
+
} else {
|
|
792
|
+
freeSpaceToBeFilled -= adjustmentAmount;
|
|
793
|
+
return { ...column, width: adjustedWidth };
|
|
794
|
+
}
|
|
795
|
+
});
|
|
796
|
+
}
|
|
797
|
+
return adjustedColumns;
|
|
798
|
+
};
|
|
799
|
+
const dataAndColumnUnchanged = (p, p1) => p.column === p1.column && p.column.valueFormatter(p.row[p.columnMap[p.column.name]]) === p1.column.valueFormatter(p1.row[p1.columnMap[p1.column.name]]);
|
|
800
|
+
const dataColumnAndKeyUnchanged = (p, p1) => p.column === p1.column && p.row[KEY] === p1.row[KEY] && p.column.valueFormatter(p.row[p.columnMap[p.column.name]]) === p1.column.valueFormatter(p1.row[p1.columnMap[p1.column.name]]);
|
|
801
|
+
const toColumnName = (column) => column.name;
|
|
802
|
+
const isStringColumn = (column) => column.serverDataType === "string";
|
|
803
|
+
const reorderColumnItems = (columnItems, orderedNames) => {
|
|
804
|
+
const columns = [];
|
|
805
|
+
for (const name of orderedNames) {
|
|
806
|
+
const columnItem = columnItems.find((c) => c.name === name);
|
|
807
|
+
if (columnItem) {
|
|
808
|
+
columns.push(columnItem);
|
|
809
|
+
}
|
|
810
|
+
}
|
|
811
|
+
return columns;
|
|
812
|
+
};
|
|
813
|
+
|
|
814
|
+
export { AggregationType, addColumnToSubscribedColumns, applyDefaultColumnConfig, applyGroupByToColumns, applyRuntimeColumnWidthsToConfig, applySortToColumns, applyWidthToColumns, buildColumnMap, checkConfirmationPending, dataAndColumnUnchanged, dataColumnAndKeyUnchanged, dataSourceRowToDataRowDto, existingSort, extractGroupColumn, findColumn, flattenColumnGroup, fromServerDataType, getCalculatedColumnDetails, getColumnLabel, getColumnName, getColumnStyle, getColumnsInViewport, getDefaultAlignment, getDefaultColumnType, getGroupIcon, getGroupValue, getRuntimeColumnWidth, getTableHeadings, getTypeFormattingFromColumn, hasCustomRenderer, hasHeadings, hasValidationRules, isCalculatedColumn, isColumnTypeRenderer, isDataLoading, isDateTimeDataValue, isGroupColumn, isJsonAttribute, isJsonColumn, isJsonGroup, isLookupRenderer, isMappedValueTypeRenderer, isNotHidden, isNumericColumn, isPinned, isResizing, isStringColumn, isTextColumn, isTypeDescriptor, isValidColumnAlignment, isValidPinLocation, isValueListRenderer, isVuuColumnDataType, mapSortCriteria, measurePinnedColumns, metadataKeys, moveColumnTo, projectUpdates, removeSort, reorderColumnItems, replaceColumn, setAggregations, setCalculatedColumnExpression, setCalculatedColumnName, setCalculatedColumnType, sortPinnedColumns, subscribedOnly, toColumnDescriptor, toColumnName, toDataSourceColumns, updateColumn, updateColumnFormatting, updateColumnRenderProps, updateColumnType, visibleColumnAtIndex };
|
|
815
|
+
//# sourceMappingURL=column-utils.js.map
|