@platforma-sdk/ui-vue 1.42.18 → 1.42.19
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/.turbo/turbo-build.log +11 -7
- package/.turbo/turbo-type-check.log +1 -1
- package/CHANGELOG.md +6 -0
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue2.js +38 -38
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue.d.ts.map +1 -1
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue.js +7 -86
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue.js.map +1 -1
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js +103 -2
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js.map +1 -1
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue3.js +9 -0
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue3.js.map +1 -0
- package/dist/components/PlAgGridColumnManager/useFilteredItems.d.ts +15 -0
- package/dist/components/PlAgGridColumnManager/useFilteredItems.d.ts.map +1 -0
- package/dist/components/PlAgGridColumnManager/useFilteredItems.js +35 -0
- package/dist/components/PlAgGridColumnManager/useFilteredItems.js.map +1 -0
- package/package.json +4 -4
- package/src/components/PlAgGridColumnManager/PlAgGridColumnManager.vue +28 -4
- package/src/components/PlAgGridColumnManager/useFilteredItems.ts +68 -0
package/.turbo/turbo-build.log
CHANGED
|
@@ -1,16 +1,18 @@
|
|
|
1
1
|
WARN Issue while reading "/home/runner/_work/platforma/platforma/.npmrc". Failed to replace env in config: ${NPMJS_TOKEN}
|
|
2
2
|
|
|
3
|
-
> @platforma-sdk/ui-vue@1.42.
|
|
3
|
+
> @platforma-sdk/ui-vue@1.42.19 build /home/runner/_work/platforma/platforma/sdk/ui-vue
|
|
4
4
|
> vite build
|
|
5
5
|
|
|
6
6
|
[36mvite v6.3.5 [32mbuilding for production...[36m[39m
|
|
7
7
|
transforming...
|
|
8
|
-
[32m✓[39m
|
|
8
|
+
[32m✓[39m 903 modules transformed.
|
|
9
|
+
[33mExport "default" of module "src/components/PlAgGridColumnManager/PlAgGridColumnManager.vue" was reexported through module "src/components/PlAgGridColumnManager/index.ts" while both modules are dependencies of each other and will end up in different chunks by current Rollup settings. This scenario is not well supported at the moment as it will produce a circular dependency between chunks and will likely lead to broken execution order.
|
|
10
|
+
Either change the import in "src/components/PlAgDataTable/PlAgDataTableV2.vue?vue&type=script&setup=true&lang.ts" to point directly to the exporting module or do not use "output.preserveModules" to ensure these modules end up in the same chunk.[39m
|
|
9
11
|
rendering chunks...
|
|
10
12
|
|
|
11
13
|
[vite:dts] Start generate declaration files...
|
|
12
14
|
computing gzip size...
|
|
13
|
-
[vite:dts] Declaration files built in
|
|
15
|
+
[vite:dts] Declaration files built in 5734ms.
|
|
14
16
|
|
|
15
17
|
[2mdist/[22m[36m_virtual/re.js [39m[1m[2m 0.08 kB[22m[1m[22m[2m │ gzip: 0.10 kB[22m[2m │ map: 0.09 kB[22m
|
|
16
18
|
[2mdist/[22m[36mlib/ui/uikit/dist/node_modules/.pnpm/d3-interpolate@3.0.1/node_modules/d3-interpolate/src/constant.js [39m[1m[2m 0.09 kB[22m[1m[22m[2m │ gzip: 0.10 kB[22m[2m │ map: 0.32 kB[22m
|
|
@@ -48,7 +50,6 @@ computing gzip size...
|
|
|
48
50
|
[2mdist/[22m[36mcomponents/PlTableFilters/PlTableAddFilterV2.vue2.js [39m[1m[2m 0.12 kB[22m[1m[22m[2m │ gzip: 0.12 kB[22m[2m │ map: 0.11 kB[22m
|
|
49
51
|
[2mdist/[22m[36mplugins/Monetization/MonetizationSidebar.vue2.js [39m[1m[2m 0.13 kB[22m[1m[22m[2m │ gzip: 0.12 kB[22m[2m │ map: 0.11 kB[22m
|
|
50
52
|
[2mdist/[22m[36mcomponents/PlTableFilters/PlTableFilterEntryV2.vue2.js [39m[1m[2m 0.13 kB[22m[1m[22m[2m │ gzip: 0.12 kB[22m[2m │ map: 0.11 kB[22m
|
|
51
|
-
[2mdist/[22m[36mcomponents/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js [39m[1m[2m 0.13 kB[22m[1m[22m[2m │ gzip: 0.12 kB[22m[2m │ map: 0.11 kB[22m
|
|
52
53
|
[2mdist/[22m[36mcomponents/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue2.js [39m[1m[2m 0.13 kB[22m[1m[22m[2m │ gzip: 0.12 kB[22m[2m │ map: 0.11 kB[22m
|
|
53
54
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/PlRadio/keys.js [39m[1m[2m 0.13 kB[22m[1m[22m[2m │ gzip: 0.13 kB[22m[2m │ map: 0.46 kB[22m
|
|
54
55
|
[2mdist/[22m[36mlib/ui/uikit/dist/node_modules/.pnpm/d3-selection@3.0.0/node_modules/d3-selection/src/selection/size.js [39m[1m[2m 0.13 kB[22m[1m[22m[2m │ gzip: 0.13 kB[22m[2m │ map: 0.49 kB[22m
|
|
@@ -238,13 +239,14 @@ computing gzip size...
|
|
|
238
239
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/16_arrow-right.svg.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.25 kB[22m[2m │ map: 0.52 kB[22m
|
|
239
240
|
[2mdist/[22m[36m_virtual/stringify.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.22 kB[22m[2m │ map: 0.10 kB[22m
|
|
240
241
|
[2mdist/[22m[36mcomponents/PlAnnotations/components/PlAnnotationsModal.vue.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.22 kB[22m[2m │ map: 0.11 kB[22m
|
|
241
|
-
[2mdist/[22m[36mcomponents/PlAgDataTable/PlAgDataTableSheets.vue.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.22 kB[22m[2m │ map: 0.11 kB[22m
|
|
242
242
|
[2mdist/[22m[36mcomponents/PlAnnotations/components/AnnotationsSidebar.vue.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.22 kB[22m[2m │ map: 0.11 kB[22m
|
|
243
|
+
[2mdist/[22m[36mcomponents/PlAgDataTable/PlAgDataTableSheets.vue.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.22 kB[22m[2m │ map: 0.11 kB[22m
|
|
243
244
|
[2mdist/[22m[36mnode_modules/.pnpm/semver@7.7.2/node_modules/semver/ranges/valid.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.22 kB[22m[2m │ map: 0.76 kB[22m
|
|
244
245
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_chevron-first.svg.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.25 kB[22m[2m │ map: 0.53 kB[22m
|
|
245
246
|
[2mdist/[22m[36mlib/ui/uikit/dist/node_modules/.pnpm/d3-selection@3.0.0/node_modules/d3-selection/src/namespaces.js [39m[1m[2m 0.31 kB[22m[1m[22m[2m │ gzip: 0.19 kB[22m[2m │ map: 0.65 kB[22m
|
|
246
247
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/16_chevron-last.svg.js [39m[1m[2m 0.32 kB[22m[1m[22m[2m │ gzip: 0.25 kB[22m[2m │ map: 0.53 kB[22m
|
|
247
248
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_radio-button-checked.svg.js [39m[1m[2m 0.32 kB[22m[1m[22m[2m │ gzip: 0.25 kB[22m[2m │ map: 0.57 kB[22m
|
|
249
|
+
[2mdist/[22m[36mcomponents/PlAgGridColumnManager/PlAgGridColumnManager.vue.js [39m[1m[2m 0.32 kB[22m[1m[22m[2m │ gzip: 0.23 kB[22m[2m │ map: 0.12 kB[22m
|
|
248
250
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_chevron-last.svg.js [39m[1m[2m 0.32 kB[22m[1m[22m[2m │ gzip: 0.26 kB[22m[2m │ map: 0.53 kB[22m
|
|
249
251
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_sort.svg.js [39m[1m[2m 0.32 kB[22m[1m[22m[2m │ gzip: 0.25 kB[22m[2m │ map: 0.51 kB[22m
|
|
250
252
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/PlChartHistogram/drawThreshold.js [39m[1m[2m 0.32 kB[22m[1m[22m[2m │ gzip: 0.23 kB[22m[2m │ map: 1.03 kB[22m
|
|
@@ -370,6 +372,7 @@ computing gzip size...
|
|
|
370
372
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/16_y-axis.svg.js [39m[1m[2m 0.45 kB[22m[1m[22m[2m │ gzip: 0.30 kB[22m[2m │ map: 0.68 kB[22m
|
|
371
373
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_delete-circle.svg.js [39m[1m[2m 0.45 kB[22m[1m[22m[2m │ gzip: 0.31 kB[22m[2m │ map: 0.68 kB[22m
|
|
372
374
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_zoom-in.svg.js [39m[1m[2m 0.45 kB[22m[1m[22m[2m │ gzip: 0.30 kB[22m[2m │ map: 0.68 kB[22m
|
|
375
|
+
[2mdist/[22m[36mcomponents/PlAgGridColumnManager/PlAgGridColumnManager.vue3.js [39m[1m[2m 0.45 kB[22m[1m[22m[2m │ gzip: 0.33 kB[22m[2m │ map: 0.11 kB[22m
|
|
373
376
|
[2mdist/[22m[36mcomputedResult.js [39m[1m[2m 0.45 kB[22m[1m[22m[2m │ gzip: 0.27 kB[22m[2m │ map: 2.41 kB[22m
|
|
374
377
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/images/24_checkbox-light-enabled-checked.svg.js [39m[1m[2m 0.45 kB[22m[1m[22m[2m │ gzip: 0.33 kB[22m[2m │ map: 0.74 kB[22m
|
|
375
378
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_frame-type-all.svg.js [39m[1m[2m 0.46 kB[22m[1m[22m[2m │ gzip: 0.31 kB[22m[2m │ map: 0.68 kB[22m
|
|
@@ -634,6 +637,7 @@ computing gzip size...
|
|
|
634
637
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_dna-import.svg.js [39m[1m[2m 1.11 kB[22m[1m[22m[2m │ gzip: 0.67 kB[22m[2m │ map: 1.34 kB[22m
|
|
635
638
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_progress.svg.js [39m[1m[2m 1.11 kB[22m[1m[22m[2m │ gzip: 0.64 kB[22m[2m │ map: 1.32 kB[22m
|
|
636
639
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_settings.svg.js [39m[1m[2m 1.13 kB[22m[1m[22m[2m │ gzip: 0.60 kB[22m[2m │ map: 1.35 kB[22m
|
|
640
|
+
[2mdist/[22m[36mcomponents/PlAgGridColumnManager/useFilteredItems.js [39m[1m[2m 1.13 kB[22m[1m[22m[2m │ gzip: 0.58 kB[22m[2m │ map: 3.94 kB[22m
|
|
637
641
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/PlTabs/Tab.vue.js [39m[1m[2m 1.13 kB[22m[1m[22m[2m │ gzip: 0.62 kB[22m[2m │ map: 1.58 kB[22m
|
|
638
642
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/PlSplash/PlSplash.vue.js [39m[1m[2m 1.14 kB[22m[1m[22m[2m │ gzip: 0.56 kB[22m[2m │ map: 0.13 kB[22m
|
|
639
643
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/PlChartStackedBar/PlChartStackedBar.vue2.js [39m[1m[2m 1.14 kB[22m[1m[22m[2m │ gzip: 0.58 kB[22m[2m │ map: 1.64 kB[22m
|
|
@@ -784,7 +788,6 @@ computing gzip size...
|
|
|
784
788
|
[2mdist/[22m[36mcomponents/PlAgColumnHeader/PlAgColumnHeader.vue.js [39m[1m[2m 3.32 kB[22m[1m[22m[2m │ gzip: 1.34 kB[22m[2m │ map: 4.05 kB[22m
|
|
785
789
|
[2mdist/[22m[36mcomponents/PlAgDataTable/sources/table-state-v2.js [39m[1m[2m 3.33 kB[22m[1m[22m[2m │ gzip: 1.16 kB[22m[2m │ map: 9.95 kB[22m
|
|
786
790
|
[2mdist/[22m[36mnode_modules/.pnpm/fast-json-patch@3.1.1/node_modules/fast-json-patch/module/duplex.js [39m[1m[2m 3.33 kB[22m[1m[22m[2m │ gzip: 1.22 kB[22m[2m │ map: 10.70 kB[22m
|
|
787
|
-
[2mdist/[22m[36mcomponents/PlAgGridColumnManager/PlAgGridColumnManager.vue.js [39m[1m[2m 3.34 kB[22m[1m[22m[2m │ gzip: 1.30 kB[22m[2m │ map: 4.05 kB[22m
|
|
788
791
|
[2mdist/[22m[36mcomponents/PlTableFilters/PlTableAddFilterV2.vue.js [39m[1m[2m 3.42 kB[22m[1m[22m[2m │ gzip: 1.28 kB[22m[2m │ map: 3.95 kB[22m
|
|
789
792
|
[2mdist/[22m[36mlib/ui/uikit/dist/generated/icons-24.js [39m[1m[2m 3.43 kB[22m[1m[22m[2m │ gzip: 1.10 kB[22m[2m │ map: 5.86 kB[22m
|
|
790
793
|
[2mdist/[22m[36mlib/ui/uikit/dist/node_modules/.pnpm/d3-axis@3.0.0/node_modules/d3-axis/src/axis.js [39m[1m[2m 3.49 kB[22m[1m[22m[2m │ gzip: 1.30 kB[22m[2m │ map: 10.47 kB[22m
|
|
@@ -809,6 +812,7 @@ computing gzip size...
|
|
|
809
812
|
[2mdist/[22m[36mnode_modules/.pnpm/semver@7.7.2/node_modules/semver/internal/re.js [39m[1m[2m 4.03 kB[22m[1m[22m[2m │ gzip: 1.23 kB[22m[2m │ map: 12.96 kB[22m
|
|
810
813
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/PlChip/PlChip.vue.js [39m[1m[2m 4.05 kB[22m[1m[22m[2m │ gzip: 1.61 kB[22m[2m │ map: 1.36 kB[22m
|
|
811
814
|
[2mdist/[22m[36mcomponents/PlAnnotations/components/PlAnnotationsModal.vue2.js [39m[1m[2m 4.10 kB[22m[1m[22m[2m │ gzip: 1.41 kB[22m[2m │ map: 5.48 kB[22m
|
|
815
|
+
[2mdist/[22m[36mcomponents/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js [39m[1m[2m 4.20 kB[22m[1m[22m[2m │ gzip: 1.57 kB[22m[2m │ map: 5.00 kB[22m
|
|
812
816
|
[2mdist/[22m[36mlib/ui/uikit/dist/assets/icons/icon-assets-min/24_heatmap.svg.js [39m[1m[2m 4.38 kB[22m[1m[22m[2m │ gzip: 0.99 kB[22m[2m │ map: 4.71 kB[22m
|
|
813
817
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/PlBtnGhost/PlBtnGhost.vue.js [39m[1m[2m 4.39 kB[22m[1m[22m[2m │ gzip: 1.66 kB[22m[2m │ map: 2.39 kB[22m
|
|
814
818
|
[2mdist/[22m[36mlib/ui/uikit/dist/composition/useSortable2.js [39m[1m[2m 4.41 kB[22m[1m[22m[2m │ gzip: 1.51 kB[22m[2m │ map: 13.13 kB[22m
|
|
@@ -880,4 +884,4 @@ computing gzip size...
|
|
|
880
884
|
[2mdist/[22m[36mlib/ui/uikit/dist/index.js [39m[1m[2m497.77 kB[22m[1m[22m[2m │ gzip: 191.75 kB[22m[2m │ map: 0.18 kB[22m
|
|
881
885
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/PlSlideModal/PlPureSlideModal.vue.js [39m[1m[33m600.06 kB[39m[22m[2m │ gzip: 204.69 kB[22m[2m │ map: 0.21 kB[22m
|
|
882
886
|
[2mdist/[22m[36mlib/ui/uikit/dist/components/DataTable/TableComponent.vue.js [39m[1m[33m601.95 kB[39m[22m[2m │ gzip: 205.54 kB[22m[2m │ map: 0.27 kB[22m
|
|
883
|
-
[32m✓ built in
|
|
887
|
+
[32m✓ built in 9.81s[39m
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
WARN Issue while reading "/home/runner/_work/platforma/platforma/.npmrc". Failed to replace env in config: ${NPMJS_TOKEN}
|
|
2
2
|
|
|
3
|
-
> @platforma-sdk/ui-vue@1.42.
|
|
3
|
+
> @platforma-sdk/ui-vue@1.42.19 type-check /home/runner/_work/platforma/platforma/sdk/ui-vue
|
|
4
4
|
> vue-tsc --noEmit --project ./tsconfig.json
|
|
5
5
|
|
package/CHANGELOG.md
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
(function(){"use strict";try{if(typeof document<"u"){var E=document.createElement("style");E.appendChild(document.createTextNode(".grid-overlay-container{height:calc(100% - 1px);margin-top:1px;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--bg-base-light)}.grid-icon-sad-cat{background-image:url();background-repeat:no-repeat}.grid-overlay-container>div{height:300px;width:300px;background-size:contain;background-position:center}.grid-overlay-container>span{color:var(--txt-mask)}")),document.head.appendChild(E)}}catch(h){console.error("vite-plugin-css-injected-by-js",h)}})();
|
|
2
|
-
import { defineComponent as ue, mergeModels as U, useModel as q, toRefs as de, computed as
|
|
2
|
+
import { defineComponent as ue, mergeModels as U, useModel as q, toRefs as de, computed as M, ref as F, shallowRef as H, watch as R, effectScope as ce, createElementBlock as me, openBlock as I, normalizeClass as Q, createBlock as T, createCommentVNode as z, createVNode as fe, unref as b, isRef as W, withCtx as j, renderSlot as X } from "vue";
|
|
3
3
|
import { isJsonEqual as i, promiseTimeout as ve } from "../../lib/util/helpers/dist/index.js";
|
|
4
|
-
import { createPlSelectionModel as
|
|
4
|
+
import { createPlSelectionModel as $, getRawPlatformaInstance as pe } from "../../sdk/model/dist/index.js";
|
|
5
5
|
import { AgGridVue as Se } from "ag-grid-vue3";
|
|
6
6
|
import { AgGridTheme as ye } from "../../aggrid.js";
|
|
7
7
|
import ge from "../PlAgCsvExporter/PlAgCsvExporter.vue.js";
|
|
@@ -13,13 +13,13 @@ import De from "./PlAgOverlayNoRows.vue.js";
|
|
|
13
13
|
|
|
14
14
|
import Oe from "./PlAgRowCount.vue.js";
|
|
15
15
|
import { DeferredCircular as xe, ensureNodeVisible as Ie } from "./sources/focus-row.js";
|
|
16
|
-
import { PlAgDataTableRowNumberColId as
|
|
16
|
+
import { PlAgDataTableRowNumberColId as Y, autoSizeRowNumberColumn as be } from "./sources/row-number.js";
|
|
17
17
|
import { calculateGridOptions as Pe } from "./sources/table-source-v2.js";
|
|
18
18
|
import { useTableState as ke } from "./sources/table-state-v2.js";
|
|
19
19
|
import "../../lib/ui/uikit/dist/index.js";
|
|
20
20
|
import { watchCached as Te } from "../../lib/ui/uikit/dist/composition/watchCached.js";
|
|
21
|
-
import { parseJson as
|
|
22
|
-
const
|
|
21
|
+
import { parseJson as Z, getAxisId as _, matchAxisId as ee, canonicalizeJson as te } from "../../lib/model/common/dist/index.js";
|
|
22
|
+
const Ye = /* @__PURE__ */ ue({
|
|
23
23
|
__name: "PlAgDataTableV2",
|
|
24
24
|
props: /* @__PURE__ */ U({
|
|
25
25
|
settings: {},
|
|
@@ -41,8 +41,8 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
41
41
|
selectionModifiers: {}
|
|
42
42
|
}),
|
|
43
43
|
emits: /* @__PURE__ */ U(["rowDoubleClicked", "cellButtonClicked", "newDataRendered"], ["update:modelValue", "update:selection"]),
|
|
44
|
-
setup(
|
|
45
|
-
const ae = q(
|
|
44
|
+
setup(G, { expose: le, emit: oe }) {
|
|
45
|
+
const ae = q(G, "modelValue"), o = q(G, "selection"), d = G, { settings: D } = de(d), B = oe, { gridState: O, sheetsState: P, filtersState: k } = ke(ae, D), se = M(() => {
|
|
46
46
|
const e = { ...D.value };
|
|
47
47
|
return e.sourceId !== null ? {
|
|
48
48
|
sheets: e.sheets ?? [],
|
|
@@ -51,7 +51,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
51
51
|
sheets: [],
|
|
52
52
|
cachedState: []
|
|
53
53
|
};
|
|
54
|
-
}), V =
|
|
54
|
+
}), V = F([]), ne = M(() => {
|
|
55
55
|
const e = { ...D.value }, t = V.value;
|
|
56
56
|
return e.sourceId !== null && t.length > 0 ? {
|
|
57
57
|
columns: t,
|
|
@@ -62,7 +62,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
62
62
|
config: () => ({}),
|
|
63
63
|
cachedState: []
|
|
64
64
|
};
|
|
65
|
-
}), c =
|
|
65
|
+
}), c = H(null), x = new xe(), r = H({
|
|
66
66
|
animateRows: !1,
|
|
67
67
|
suppressColumnMoveAnimation: !0,
|
|
68
68
|
cellSelection: !o.value,
|
|
@@ -79,12 +79,12 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
79
79
|
onSelectionChanged: (e) => {
|
|
80
80
|
var t;
|
|
81
81
|
if (o.value) {
|
|
82
|
-
const l = e.api.getServerSideSelectionState(), a = ((t = l == null ? void 0 : l.toggledNodes) == null ? void 0 : t.map((s) =>
|
|
82
|
+
const l = e.api.getServerSideSelectionState(), a = ((t = l == null ? void 0 : l.toggledNodes) == null ? void 0 : t.map((s) => Z(s))) ?? [];
|
|
83
83
|
i(o.value.selectedKeys, a) || (o.value = { ...o.value, selectedKeys: a });
|
|
84
84
|
}
|
|
85
85
|
},
|
|
86
86
|
onRowDoubleClicked: (e) => {
|
|
87
|
-
e.data && e.data.axesKey &&
|
|
87
|
+
e.data && e.data.axesKey && B("rowDoubleClicked", e.data.axesKey);
|
|
88
88
|
},
|
|
89
89
|
defaultColDef: {
|
|
90
90
|
suppressHeaderMenuButton: !0,
|
|
@@ -155,7 +155,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
155
155
|
e.state
|
|
156
156
|
), e.api.autoSizeColumns(
|
|
157
157
|
e.api.getAllDisplayedColumns().filter(
|
|
158
|
-
(t) => t.getColId() !==
|
|
158
|
+
(t) => t.getColId() !== Y
|
|
159
159
|
)
|
|
160
160
|
);
|
|
161
161
|
},
|
|
@@ -172,7 +172,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
172
172
|
columnVisibility: e.columnVisibility
|
|
173
173
|
};
|
|
174
174
|
}
|
|
175
|
-
const E =
|
|
175
|
+
const E = F(0);
|
|
176
176
|
R(
|
|
177
177
|
() => [c.value, O.value],
|
|
178
178
|
([e, t]) => {
|
|
@@ -192,7 +192,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
192
192
|
},
|
|
193
193
|
{ immediate: !0 }
|
|
194
194
|
);
|
|
195
|
-
const re =
|
|
195
|
+
const re = M(() => d.cellRendererSelector ?? null);
|
|
196
196
|
R(
|
|
197
197
|
() => [c.value, re.value],
|
|
198
198
|
([e, t]) => {
|
|
@@ -216,7 +216,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
216
216
|
const a = (h = o.value) == null ? void 0 : h.axesSpec;
|
|
217
217
|
if (!a || a.length !== e.length) return !1;
|
|
218
218
|
const s = e.map((p) => {
|
|
219
|
-
const S =
|
|
219
|
+
const S = _(p);
|
|
220
220
|
return a.findIndex((w) => ee(w, S));
|
|
221
221
|
}), u = new Set(s);
|
|
222
222
|
if (u.has(-1) || u.size !== e.length) return !1;
|
|
@@ -241,7 +241,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
241
241
|
});
|
|
242
242
|
function ie(e) {
|
|
243
243
|
const t = (l) => !("children" in l);
|
|
244
|
-
return e ? e.filter(t).filter((l) => l.colId && l.colId !==
|
|
244
|
+
return e ? e.filter(t).filter((l) => l.colId && l.colId !== Y) : [];
|
|
245
245
|
}
|
|
246
246
|
Te(
|
|
247
247
|
() => r.value.columnDefs,
|
|
@@ -250,14 +250,14 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
250
250
|
V.value = [];
|
|
251
251
|
else {
|
|
252
252
|
const l = ie(e);
|
|
253
|
-
V.value = l.map((a) =>
|
|
253
|
+
V.value = l.map((a) => Z(a.colId).labeled);
|
|
254
254
|
}
|
|
255
255
|
},
|
|
256
256
|
{ immediate: !0 }
|
|
257
257
|
);
|
|
258
|
-
const
|
|
258
|
+
const A = $();
|
|
259
259
|
let v = null;
|
|
260
|
-
const C =
|
|
260
|
+
const C = F(0);
|
|
261
261
|
return R(
|
|
262
262
|
() => [c.value, D.value],
|
|
263
263
|
([e, t]) => {
|
|
@@ -274,7 +274,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
274
274
|
},
|
|
275
275
|
columnDefs: void 0,
|
|
276
276
|
serverSideDatasource: void 0
|
|
277
|
-
}), o.value && (o.value && !i(o.value,
|
|
277
|
+
}), o.value && (o.value && !i(o.value, A) && (o.value = $()), e.setServerSideSelectionState({
|
|
278
278
|
selectAll: !1,
|
|
279
279
|
toggledNodes: []
|
|
280
280
|
}));
|
|
@@ -286,7 +286,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
286
286
|
...r.value.loadingOverlayComponentParams,
|
|
287
287
|
notReady: !1
|
|
288
288
|
}
|
|
289
|
-
}), o.value && (v != null && v.sourceId) && (o.value && !i(o.value,
|
|
289
|
+
}), o.value && (v != null && v.sourceId) && (o.value && !i(o.value, A) && (o.value = $()), e.setServerSideSelectionState({
|
|
290
290
|
selectAll: !1,
|
|
291
291
|
toggledNodes: []
|
|
292
292
|
})));
|
|
@@ -312,7 +312,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
312
312
|
cellButtonAxisParams: {
|
|
313
313
|
showCellButtonForAxisId: d.showCellButtonForAxisId,
|
|
314
314
|
cellButtonInvokeRowsOnDoubleClick: d.cellButtonInvokeRowsOnDoubleClick,
|
|
315
|
-
trigger: (n) =>
|
|
315
|
+
trigger: (n) => B("cellButtonClicked", n)
|
|
316
316
|
}
|
|
317
317
|
}).then((n) => {
|
|
318
318
|
if (e.isDestroyed() || u !== C.value) return;
|
|
@@ -329,7 +329,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
329
329
|
toggledNodes: []
|
|
330
330
|
});
|
|
331
331
|
}
|
|
332
|
-
const S = g.map(
|
|
332
|
+
const S = g.map(_).map((f) => m.findIndex((K) => ee(K, f))), w = new Set(S);
|
|
333
333
|
if (w.has(-1) || w.size !== m.length) {
|
|
334
334
|
const f = { axesSpec: m, selectedKeys: [] };
|
|
335
335
|
return i(o.value, f) || (o.value = f), e.setServerSideSelectionState({
|
|
@@ -337,10 +337,10 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
337
337
|
toggledNodes: []
|
|
338
338
|
});
|
|
339
339
|
}
|
|
340
|
-
const
|
|
340
|
+
const L = p.map((f) => S.map((K) => f[K])), J = { axesSpec: m, selectedKeys: L };
|
|
341
341
|
return i(o.value, J) || (o.value = J), e.setServerSideSelectionState({
|
|
342
342
|
selectAll: !1,
|
|
343
|
-
toggledNodes:
|
|
343
|
+
toggledNodes: L.map((f) => te(f))
|
|
344
344
|
});
|
|
345
345
|
}
|
|
346
346
|
}
|
|
@@ -350,7 +350,7 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
350
350
|
e.isDestroyed() || u !== C.value || e.updateGridOptions({
|
|
351
351
|
loading: !1
|
|
352
352
|
});
|
|
353
|
-
}), x.promise.then(() =>
|
|
353
|
+
}), x.promise.then(() => B("newDataRendered"));
|
|
354
354
|
} catch (s) {
|
|
355
355
|
console.trace(s);
|
|
356
356
|
} finally {
|
|
@@ -379,45 +379,45 @@ const Xe = /* @__PURE__ */ ue({
|
|
|
379
379
|
});
|
|
380
380
|
}
|
|
381
381
|
), (e, t) => (I(), me("div", {
|
|
382
|
-
class:
|
|
382
|
+
class: Q(e.$style.container)
|
|
383
383
|
}, [
|
|
384
384
|
c.value && !e.disableColumnsPanel ? (I(), T(b(Ce), {
|
|
385
385
|
key: 0,
|
|
386
386
|
api: c.value
|
|
387
|
-
}, null, 8, ["api"])) :
|
|
388
|
-
e.disableFiltersPanel ?
|
|
387
|
+
}, null, 8, ["api"])) : z("", !0),
|
|
388
|
+
e.disableFiltersPanel ? z("", !0) : (I(), T(he, {
|
|
389
389
|
key: 1,
|
|
390
390
|
modelValue: b(k),
|
|
391
|
-
"onUpdate:modelValue": t[0] || (t[0] = (l) =>
|
|
391
|
+
"onUpdate:modelValue": t[0] || (t[0] = (l) => W(k) ? k.value = l : null),
|
|
392
392
|
settings: ne.value
|
|
393
393
|
}, null, 8, ["modelValue", "settings"])),
|
|
394
394
|
c.value && e.showExportButton ? (I(), T(ge, {
|
|
395
395
|
key: 2,
|
|
396
396
|
api: c.value
|
|
397
|
-
}, null, 8, ["api"])) :
|
|
397
|
+
}, null, 8, ["api"])) : z("", !0),
|
|
398
398
|
fe(we, {
|
|
399
399
|
modelValue: b(P),
|
|
400
|
-
"onUpdate:modelValue": t[1] || (t[1] = (l) =>
|
|
400
|
+
"onUpdate:modelValue": t[1] || (t[1] = (l) => W(P) ? P.value = l : null),
|
|
401
401
|
settings: se.value
|
|
402
402
|
}, {
|
|
403
|
-
before:
|
|
404
|
-
|
|
403
|
+
before: j(() => [
|
|
404
|
+
X(e.$slots, "before-sheets")
|
|
405
405
|
]),
|
|
406
|
-
after:
|
|
407
|
-
|
|
406
|
+
after: j(() => [
|
|
407
|
+
X(e.$slots, "after-sheets")
|
|
408
408
|
]),
|
|
409
409
|
_: 3
|
|
410
410
|
}, 8, ["modelValue", "settings"]),
|
|
411
411
|
(I(), T(b(Se), {
|
|
412
412
|
key: E.value,
|
|
413
413
|
theme: b(ye),
|
|
414
|
-
class:
|
|
414
|
+
class: Q(e.$style.grid),
|
|
415
415
|
"grid-options": r.value
|
|
416
416
|
}, null, 8, ["theme", "class", "grid-options"]))
|
|
417
417
|
], 2));
|
|
418
418
|
}
|
|
419
419
|
});
|
|
420
420
|
export {
|
|
421
|
-
|
|
421
|
+
Ye as default
|
|
422
422
|
};
|
|
423
423
|
//# sourceMappingURL=PlAgDataTableV2.vue2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PlAgGridColumnManager.vue.d.ts","sourceRoot":"","sources":["../../../src/components/PlAgGridColumnManager/PlAgGridColumnManager.vue"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PlAgGridColumnManager.vue.d.ts","sourceRoot":"","sources":["../../../src/components/PlAgGridColumnManager/PlAgGridColumnManager.vue"],"names":[],"mappings":"AAsHA,OAAO,EAAkD,KAAK,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAKlG,KAAK,WAAW,GAAG;IACjB;;;;;OAKG;IACH,GAAG,EAAE,OAAO,CAAC;IACb;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;;AA+NF,wBAOG"}
|
|
@@ -1,89 +1,10 @@
|
|
|
1
|
-
import
|
|
2
|
-
import "
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
import A from "../../lib/ui/uikit/dist/components/PlElementList/PlElementList.vue.js";
|
|
8
|
-
const j = /* @__PURE__ */ b({
|
|
9
|
-
__name: "PlAgGridColumnManager",
|
|
10
|
-
props: {
|
|
11
|
-
api: {},
|
|
12
|
-
width: {}
|
|
13
|
-
},
|
|
14
|
-
setup(p) {
|
|
15
|
-
const f = p, { api: n } = k(f), i = d([]);
|
|
16
|
-
V(
|
|
17
|
-
() => n.value,
|
|
18
|
-
(o) => {
|
|
19
|
-
o.isDestroyed() || (o.addEventListener("displayedColumnsChanged", (t) => {
|
|
20
|
-
i.value = t.api.getAllGridColumns();
|
|
21
|
-
}), i.value = o.getAllGridColumns(), i.value.length > 0 && o.moveColumns(i.value, 0));
|
|
22
|
-
},
|
|
23
|
-
{ immediate: !0 }
|
|
24
|
-
);
|
|
25
|
-
const c = w(() => i.value.map((o) => ({
|
|
26
|
-
column: o,
|
|
27
|
-
id: o.getId(),
|
|
28
|
-
label: o.getColDef().headerName
|
|
29
|
-
}))), s = d(!1), u = G("PlAgGridColumnManager");
|
|
30
|
-
return (o, t) => (g(), y("div", null, [
|
|
31
|
-
l(u) ? (g(), D(P, {
|
|
32
|
-
key: 0,
|
|
33
|
-
to: l(u)
|
|
34
|
-
}, [
|
|
35
|
-
r(l(h), {
|
|
36
|
-
icon: "columns",
|
|
37
|
-
onClick: t[0] || (t[0] = M((e) => s.value = !s.value, ["stop"]))
|
|
38
|
-
}, {
|
|
39
|
-
default: a(() => t[2] || (t[2] = [
|
|
40
|
-
m(" Columns ")
|
|
41
|
-
])),
|
|
42
|
-
_: 1
|
|
43
|
-
})
|
|
44
|
-
], 8, ["to"])) : T("", !0),
|
|
45
|
-
r(l(x), {
|
|
46
|
-
modelValue: s.value,
|
|
47
|
-
"onUpdate:modelValue": t[1] || (t[1] = (e) => s.value = e),
|
|
48
|
-
width: o.width,
|
|
49
|
-
"close-on-outside-click": ""
|
|
50
|
-
}, {
|
|
51
|
-
title: a(() => t[3] || (t[3] = [
|
|
52
|
-
m("Manage Columns")
|
|
53
|
-
])),
|
|
54
|
-
default: a(() => [
|
|
55
|
-
r(l(A), {
|
|
56
|
-
items: c.value,
|
|
57
|
-
"get-item-key": (e) => e.id,
|
|
58
|
-
"is-draggable": (e) => !e.column.getColDef().lockPosition,
|
|
59
|
-
"on-sort": (e, v) => {
|
|
60
|
-
if (!l(n).isDestroyed()) {
|
|
61
|
-
const C = i.value[e];
|
|
62
|
-
l(n).moveColumns([C], v);
|
|
63
|
-
}
|
|
64
|
-
return !0;
|
|
65
|
-
},
|
|
66
|
-
"on-toggle": (e) => {
|
|
67
|
-
l(n).isDestroyed() || l(n).setColumnsVisible([e.column], !e.column.isVisible());
|
|
68
|
-
},
|
|
69
|
-
"is-toggled": (e) => !e.column.isVisible(),
|
|
70
|
-
"is-toggable": (e) => e.id !== l(B),
|
|
71
|
-
"is-pinned": (e) => !!e.column.getColDef().lockPosition,
|
|
72
|
-
"is-pinnable": () => !1,
|
|
73
|
-
"disable-removing": ""
|
|
74
|
-
}, {
|
|
75
|
-
"item-title": a(({ item: e }) => [
|
|
76
|
-
m(N(e.label), 1)
|
|
77
|
-
]),
|
|
78
|
-
_: 1
|
|
79
|
-
}, 8, ["items", "get-item-key", "is-draggable", "on-sort", "on-toggle", "is-toggled", "is-toggable", "is-pinned"])
|
|
80
|
-
]),
|
|
81
|
-
_: 1
|
|
82
|
-
}, 8, ["modelValue", "width"])
|
|
83
|
-
]));
|
|
84
|
-
}
|
|
85
|
-
});
|
|
1
|
+
import o from "./PlAgGridColumnManager.vue2.js";
|
|
2
|
+
import s from "./PlAgGridColumnManager.vue3.js";
|
|
3
|
+
import r from "../../_virtual/_plugin-vue_export-helper.js";
|
|
4
|
+
const t = {
|
|
5
|
+
$style: s
|
|
6
|
+
}, c = /* @__PURE__ */ r(o, [["__cssModules", t]]);
|
|
86
7
|
export {
|
|
87
|
-
|
|
8
|
+
c as default
|
|
88
9
|
};
|
|
89
10
|
//# sourceMappingURL=PlAgGridColumnManager.vue.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PlAgGridColumnManager.vue.js","sources":[
|
|
1
|
+
{"version":3,"file":"PlAgGridColumnManager.vue.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
|
|
@@ -1,5 +1,106 @@
|
|
|
1
|
-
import f from "
|
|
1
|
+
import { defineComponent as w, toRefs as D, ref as p, watch as T, computed as P, createElementBlock as f, openBlock as m, createBlock as M, createCommentVNode as N, createVNode as u, unref as t, Teleport as h, withModifiers as B, withCtx as d, createTextVNode as v, createElementVNode as G, Fragment as I, renderList as A, normalizeClass as E, toDisplayString as R } from "vue";
|
|
2
|
+
import "../../lib/ui/uikit/dist/index.js";
|
|
3
|
+
import { PlAgDataTableRowNumberColId as $ } from "../PlAgDataTable/sources/row-number.js";
|
|
4
|
+
import { useFilteredItems as q } from "./useFilteredItems.js";
|
|
5
|
+
import { usePlBlockPageTitleTeleportTarget as x } from "../../lib/ui/uikit/dist/layout/PlBlockPage/usePlBlockPageTitleTeleportTarget.js";
|
|
6
|
+
import F from "../../lib/ui/uikit/dist/components/PlBtnGhost/PlBtnGhost.vue.js";
|
|
7
|
+
import L from "../../lib/ui/uikit/dist/components/PlSlideModal/PlSlideModal.vue.js";
|
|
8
|
+
import S from "../../lib/ui/uikit/dist/components/PlSearchField/PlSearchField.vue.js";
|
|
9
|
+
import U from "../../lib/ui/uikit/dist/components/PlElementList/PlElementList.vue.js";
|
|
10
|
+
const Y = /* @__PURE__ */ w({
|
|
11
|
+
__name: "PlAgGridColumnManager",
|
|
12
|
+
props: {
|
|
13
|
+
api: {},
|
|
14
|
+
width: {}
|
|
15
|
+
},
|
|
16
|
+
setup(C) {
|
|
17
|
+
const b = C, { api: n } = D(b), i = p([]);
|
|
18
|
+
T(
|
|
19
|
+
() => n.value,
|
|
20
|
+
(l) => {
|
|
21
|
+
l.isDestroyed() || (l.addEventListener("displayedColumnsChanged", (o) => {
|
|
22
|
+
i.value = o.api.getAllGridColumns();
|
|
23
|
+
}), i.value = l.getAllGridColumns(), i.value.length > 0 && l.moveColumns(i.value, 0));
|
|
24
|
+
},
|
|
25
|
+
{ immediate: !0 }
|
|
26
|
+
);
|
|
27
|
+
const V = P(() => i.value.map((l) => ({
|
|
28
|
+
column: l,
|
|
29
|
+
id: l.getId(),
|
|
30
|
+
label: l.getColDef().headerName
|
|
31
|
+
}))), s = p(""), a = p(!1), c = x("PlAgGridColumnManager"), { filteredItems: k, segments: y } = q(() => ({
|
|
32
|
+
items: V.value,
|
|
33
|
+
query: s.value,
|
|
34
|
+
getStrings: (l) => [l.label]
|
|
35
|
+
}));
|
|
36
|
+
return (l, o) => (m(), f("div", null, [
|
|
37
|
+
t(c) ? (m(), M(h, {
|
|
38
|
+
key: 0,
|
|
39
|
+
to: t(c)
|
|
40
|
+
}, [
|
|
41
|
+
u(t(F), {
|
|
42
|
+
icon: "columns",
|
|
43
|
+
onClick: o[0] || (o[0] = B((e) => a.value = !a.value, ["stop"]))
|
|
44
|
+
}, {
|
|
45
|
+
default: d(() => o[3] || (o[3] = [
|
|
46
|
+
v(" Columns ")
|
|
47
|
+
])),
|
|
48
|
+
_: 1
|
|
49
|
+
})
|
|
50
|
+
], 8, ["to"])) : N("", !0),
|
|
51
|
+
u(t(L), {
|
|
52
|
+
modelValue: a.value,
|
|
53
|
+
"onUpdate:modelValue": o[2] || (o[2] = (e) => a.value = e),
|
|
54
|
+
width: l.width,
|
|
55
|
+
"close-on-outside-click": ""
|
|
56
|
+
}, {
|
|
57
|
+
title: d(() => o[4] || (o[4] = [
|
|
58
|
+
v("Manage Columns")
|
|
59
|
+
])),
|
|
60
|
+
default: d(() => [
|
|
61
|
+
u(t(S), {
|
|
62
|
+
modelValue: s.value,
|
|
63
|
+
"onUpdate:modelValue": o[1] || (o[1] = (e) => s.value = e),
|
|
64
|
+
clearable: ""
|
|
65
|
+
}, null, 8, ["modelValue"]),
|
|
66
|
+
u(t(U), {
|
|
67
|
+
items: t(k),
|
|
68
|
+
"get-item-key": (e) => e.id,
|
|
69
|
+
"is-draggable": (e) => !e.column.getColDef().lockPosition,
|
|
70
|
+
"on-sort": (e, r) => {
|
|
71
|
+
if (!t(n).isDestroyed()) {
|
|
72
|
+
const g = i.value[e];
|
|
73
|
+
t(n).moveColumns([g], r);
|
|
74
|
+
}
|
|
75
|
+
return !0;
|
|
76
|
+
},
|
|
77
|
+
"on-toggle": (e) => {
|
|
78
|
+
t(n).isDestroyed() || t(n).setColumnsVisible([e.column], !e.column.isVisible());
|
|
79
|
+
},
|
|
80
|
+
"is-toggled": (e) => !e.column.isVisible(),
|
|
81
|
+
"is-toggable": (e) => e.id !== t($),
|
|
82
|
+
"is-pinned": (e) => !!e.column.getColDef().lockPosition,
|
|
83
|
+
"is-pinnable": () => !1,
|
|
84
|
+
"disable-dragging": s.value.length > 0,
|
|
85
|
+
"disable-removing": ""
|
|
86
|
+
}, {
|
|
87
|
+
"item-title": d(({ item: e }) => [
|
|
88
|
+
G("span", null, [
|
|
89
|
+
(m(!0), f(I, null, A(t(y).get(e.label), (r, g) => (m(), f("span", {
|
|
90
|
+
key: g,
|
|
91
|
+
class: E({ [l.$style.match]: r.match })
|
|
92
|
+
}, R(r.value), 3))), 128))
|
|
93
|
+
])
|
|
94
|
+
]),
|
|
95
|
+
_: 1
|
|
96
|
+
}, 8, ["items", "get-item-key", "is-draggable", "on-sort", "on-toggle", "is-toggled", "is-toggable", "is-pinned", "disable-dragging"])
|
|
97
|
+
]),
|
|
98
|
+
_: 1
|
|
99
|
+
}, 8, ["modelValue", "width"])
|
|
100
|
+
]));
|
|
101
|
+
}
|
|
102
|
+
});
|
|
2
103
|
export {
|
|
3
|
-
|
|
104
|
+
Y as default
|
|
4
105
|
};
|
|
5
106
|
//# sourceMappingURL=PlAgGridColumnManager.vue2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PlAgGridColumnManager.vue2.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
1
|
+
{"version":3,"file":"PlAgGridColumnManager.vue2.js","sources":["../../../src/components/PlAgGridColumnManager/PlAgGridColumnManager.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { PlBtnGhost, PlElementList, PlSearchField, PlSlideModal, usePlBlockPageTitleTeleportTarget } from '@milaboratories/uikit';\nimport { type Column, type DisplayedColumnsChangedEvent, type GridApi } from 'ag-grid-enterprise';\nimport { computed, ref, toRefs, watch } from 'vue';\nimport { PlAgDataTableRowNumberColId } from '../PlAgDataTable/sources/row-number';\nimport { useFilteredItems } from './useFilteredItems';\n\nconst props = defineProps<{\n /**\n * The GridApi is an API interface provided by the table/grid component\n * for interacting programmatically with the grid's features and functionality.\n * It allows you to control and manipulate grid behavior, access data, and\n * trigger specific actions.\n */\n api: GridApi;\n /**\n * Css Column Manager (Panel) modal width (default value is `368px`)\n */\n width?: string;\n}>();\n\nconst { api: gridApi } = toRefs(props);\n\nconst columns = ref<Column[]>([]);\nwatch(\n () => gridApi.value,\n (gridApi) => {\n if (gridApi.isDestroyed()) return;\n\n gridApi.addEventListener('displayedColumnsChanged', (event: DisplayedColumnsChangedEvent) => {\n columns.value = event.api.getAllGridColumns();\n });\n\n columns.value = gridApi.getAllGridColumns();\n if (columns.value.length > 0) {\n gridApi.moveColumns(columns.value, 0);\n }\n },\n { immediate: true },\n);\n\nconst items = computed(() => {\n return columns.value.map((col) => ({\n column: col,\n id: col.getId(),\n label: col.getColDef().headerName!,\n }));\n});\n\nconst query = ref('');\n\nconst slideModal = ref(false);\nconst teleportTarget = usePlBlockPageTitleTeleportTarget('PlAgGridColumnManager');\n\nconst { filteredItems, segments } = useFilteredItems(() => ({\n items: items.value,\n query: query.value,\n getStrings: (item) => [item.label],\n}));\n</script>\n\n<template>\n <div>\n <Teleport v-if=\"teleportTarget\" :to=\"teleportTarget\">\n <PlBtnGhost icon=\"columns\" @click.stop=\"slideModal = !slideModal\">\n Columns\n </PlBtnGhost>\n </Teleport>\n\n <PlSlideModal v-model=\"slideModal\" :width=\"width\" close-on-outside-click>\n <template #title>Manage Columns</template>\n <PlSearchField v-model=\"query\" clearable />\n <PlElementList\n :items=\"filteredItems\"\n :get-item-key=\"(item) => item.id\"\n :is-draggable=\"(item) => !item.column.getColDef().lockPosition\"\n :on-sort=\"(fromIndex, toIndex) => {\n if (!gridApi.isDestroyed()) {\n const columnToMove = columns[fromIndex];\n gridApi.moveColumns([columnToMove], toIndex);\n }\n return true; // Let PlElementList handle the visual update\n }\"\n :on-toggle=\"(item) => {\n if (!gridApi.isDestroyed()) {\n gridApi.setColumnsVisible([item.column], !item.column.isVisible());\n }\n }\"\n :is-toggled=\"(item) => !item.column.isVisible()\"\n :is-toggable=\"(item) => item.id !== PlAgDataTableRowNumberColId\"\n :is-pinned=\"(item) => !!item.column.getColDef().lockPosition\"\n :is-pinnable=\"() => false\"\n :disable-dragging=\"query.length > 0\"\n disable-removing\n >\n <template #item-title=\"{ item }\">\n <span>\n <span\n v-for=\"(segment, i) of segments.get(item.label)\"\n :key=\"i\"\n :class=\"{ [$style.match]: segment.match }\"\n >{{ segment.value }}</span>\n </span>\n </template>\n </PlElementList>\n </PlSlideModal>\n </div>\n</template>\n\n<style module>\n.match {\n background-color: var(--color-active-select);\n border-radius: 2px;\n}\n</style>\n"],"names":["props","__props","gridApi","toRefs","columns","ref","watch","event","items","computed","col","query","slideModal","teleportTarget","usePlBlockPageTitleTeleportTarget","filteredItems","segments","useFilteredItems","item"],"mappings":";;;;;;;;;;;;;;;;AAOA,UAAMA,IAAQC,GAcR,EAAE,KAAKC,MAAYC,EAAOH,CAAK,GAE/BI,IAAUC,EAAc,EAAE;AAChC,IAAAC;AAAA,MACE,MAAMJ,EAAQ;AAAA,MACd,CAACA,MAAY;AACPA,QAAAA,EAAQ,kBAEZA,EAAQ,iBAAiB,2BAA2B,CAACK,MAAwC;AACnF,UAAAH,EAAA,QAAQG,EAAM,IAAI,kBAAkB;AAAA,QAAA,CAC7C,GAEOH,EAAA,QAAQF,EAAQ,kBAAkB,GACtCE,EAAQ,MAAM,SAAS,KACzBF,EAAQ,YAAYE,EAAQ,OAAO,CAAC;AAAA,MAExC;AAAA,MACA,EAAE,WAAW,GAAK;AAAA,IACpB;AAEM,UAAAI,IAAQC,EAAS,MACdL,EAAQ,MAAM,IAAI,CAACM,OAAS;AAAA,MACjC,QAAQA;AAAA,MACR,IAAIA,EAAI,MAAM;AAAA,MACd,OAAOA,EAAI,YAAY;AAAA,IAAA,EACvB,CACH,GAEKC,IAAQN,EAAI,EAAE,GAEdO,IAAaP,EAAI,EAAK,GACtBQ,IAAiBC,EAAkC,uBAAuB,GAE1E,EAAE,eAAAC,GAAe,UAAAC,EAAS,IAAIC,EAAiB,OAAO;AAAA,MAC1D,OAAOT,EAAM;AAAA,MACb,OAAOG,EAAM;AAAA,MACb,YAAY,CAACO,MAAS,CAACA,EAAK,KAAK;AAAA,IAAA,EACjC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
(function(){"use strict";try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode("._match_pckgk_2{background-color:var(--color-active-select);border-radius:2px}")),document.head.appendChild(e)}}catch(c){console.error("vite-plugin-css-injected-by-js",c)}})();
|
|
2
|
+
const t = "_match_pckgk_2", c = {
|
|
3
|
+
match: t
|
|
4
|
+
};
|
|
5
|
+
export {
|
|
6
|
+
c as default,
|
|
7
|
+
t as match
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=PlAgGridColumnManager.vue3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PlAgGridColumnManager.vue3.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { MaybeRefOrGetter } from 'vue';
|
|
2
|
+
export declare function useFilteredItems<T>(props: MaybeRefOrGetter<{
|
|
3
|
+
items: T[];
|
|
4
|
+
query: string;
|
|
5
|
+
getStrings: (item: T) => Iterable<string>;
|
|
6
|
+
}>): {
|
|
7
|
+
filteredItems: import('vue').ComputedRef<T[]>;
|
|
8
|
+
segments: import('vue').ComputedRef<Map<string, StringSegment[]>>;
|
|
9
|
+
};
|
|
10
|
+
type StringSegment = {
|
|
11
|
+
value: string;
|
|
12
|
+
match: boolean;
|
|
13
|
+
};
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=useFilteredItems.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useFilteredItems.d.ts","sourceRoot":"","sources":["../../../src/components/PlAgGridColumnManager/useFilteredItems.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,gBAAgB,EAAW,MAAM,KAAK,CAAC;AAE/D,wBAAgB,gBAAgB,CAAC,CAAC,EAChC,KAAK,EAAE,gBAAgB,CAAC;IACtB,KAAK,EAAE,CAAC,EAAE,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,QAAQ,CAAC,MAAM,CAAC,CAAC;CAC3C,CAAC;;;EA0BH;AA+BD,KAAK,aAAa,GAAG;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,OAAO,CAAC;CAChB,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { computed as m, toValue as g } from "vue";
|
|
2
|
+
function d(t) {
|
|
3
|
+
const o = m(() => {
|
|
4
|
+
const { items: f, query: u, getStrings: r } = g(t), s = [], e = /* @__PURE__ */ new Map();
|
|
5
|
+
for (const l of f) {
|
|
6
|
+
let n = !1;
|
|
7
|
+
for (const c of r(l)) {
|
|
8
|
+
let i = e.get(c);
|
|
9
|
+
i || (i = p(c, u), e.set(c, i)), !n && (!u || i.some(({ match: a }) => a)) && (s.push(l), n = !0);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
return { filteredItems: s, segments: e };
|
|
13
|
+
});
|
|
14
|
+
return {
|
|
15
|
+
filteredItems: m(() => o.value.filteredItems),
|
|
16
|
+
segments: m(() => o.value.segments)
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
function p(t, o) {
|
|
20
|
+
if (!o) return [{ value: t, match: !1 }];
|
|
21
|
+
const f = t.toLowerCase(), u = o.toLowerCase(), r = [];
|
|
22
|
+
let s = 0;
|
|
23
|
+
for (; ; ) {
|
|
24
|
+
const e = f.indexOf(u, s), l = e + o.length;
|
|
25
|
+
if (e < 0) break;
|
|
26
|
+
s !== e && r.push({ value: t.slice(s, e), match: !1 });
|
|
27
|
+
const n = r.at(-1);
|
|
28
|
+
n != null && n.match ? n.value += t.slice(e, l) : r.push({ value: t.slice(e, l), match: !0 }), s = l;
|
|
29
|
+
}
|
|
30
|
+
return s < t.length && r.push({ value: t.slice(s), match: !1 }), r;
|
|
31
|
+
}
|
|
32
|
+
export {
|
|
33
|
+
d as useFilteredItems
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=useFilteredItems.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useFilteredItems.js","sources":["../../../src/components/PlAgGridColumnManager/useFilteredItems.ts"],"sourcesContent":["import { computed, type MaybeRefOrGetter, toValue } from 'vue';\n\nexport function useFilteredItems<T>(\n props: MaybeRefOrGetter<{\n items: T[];\n query: string;\n getStrings: (item: T) => Iterable<string>;\n }>,\n) {\n const result = computed(() => {\n const { items, query, getStrings } = toValue(props);\n const filteredItems: T[] = [];\n const segments = new Map<string, StringSegment[]>();\n for (const item of items) {\n let kept = false;\n for (const string of getStrings(item)) {\n let stringSegments = segments.get(string);\n if (!stringSegments) {\n stringSegments = matchSubstrings(string, query);\n segments.set(string, stringSegments);\n }\n if (!kept && (!query || stringSegments.some(({ match }) => match))) {\n filteredItems.push(item);\n kept = true;\n }\n }\n }\n return { filteredItems, segments };\n });\n return {\n filteredItems: computed(() => result.value.filteredItems),\n segments: computed(() => result.value.segments),\n };\n}\n\n// Very naïve implementation of substring matching, doesn't handle Unicode well\n// Maybe one day we'll have nice things: https://github.com/tc39/ecma402/issues/506\nfunction matchSubstrings(haystack: string, needle: string): StringSegment[] {\n if (!needle) return [{ value: haystack, match: false }];\n const haystackLower = haystack.toLowerCase();\n const needleLower = needle.toLowerCase();\n const result: StringSegment[] = [];\n let prevEnd = 0;\n while (true) {\n const start = haystackLower.indexOf(needleLower, prevEnd);\n const end = start + needle.length;\n if (start < 0) break;\n if (prevEnd !== start) {\n result.push({ value: haystack.slice(prevEnd, start), match: false });\n }\n const prevSegment = result.at(-1);\n if (prevSegment?.match) {\n prevSegment.value += haystack.slice(start, end);\n } else {\n result.push({ value: haystack.slice(start, end), match: true });\n }\n prevEnd = end;\n }\n if (prevEnd < haystack.length) {\n result.push({ value: haystack.slice(prevEnd), match: false });\n }\n return result;\n}\n\ntype StringSegment = {\n value: string;\n match: boolean;\n};\n"],"names":["useFilteredItems","props","result","computed","items","query","getStrings","toValue","filteredItems","segments","item","kept","string","stringSegments","matchSubstrings","match","haystack","needle","haystackLower","needleLower","prevEnd","start","end","prevSegment"],"mappings":";AAEO,SAASA,EACdC,GAKA;AACM,QAAAC,IAASC,EAAS,MAAM;AAC5B,UAAM,EAAE,OAAAC,GAAO,OAAAC,GAAO,YAAAC,EAAW,IAAIC,EAAQN,CAAK,GAC5CO,IAAqB,CAAC,GACtBC,wBAAe,IAA6B;AAClD,eAAWC,KAAQN,GAAO;AACxB,UAAIO,IAAO;AACA,iBAAAC,KAAUN,EAAWI,CAAI,GAAG;AACjC,YAAAG,IAAiBJ,EAAS,IAAIG,CAAM;AACxC,QAAKC,MACcA,IAAAC,EAAgBF,GAAQP,CAAK,GACrCI,EAAA,IAAIG,GAAQC,CAAc,IAEjC,CAACF,MAAS,CAACN,KAASQ,EAAe,KAAK,CAAC,EAAE,OAAAE,EAAA,MAAYA,CAAK,OAC9DP,EAAc,KAAKE,CAAI,GAChBC,IAAA;AAAA,MACT;AAAA,IACF;AAEK,WAAA,EAAE,eAAAH,GAAe,UAAAC,EAAS;AAAA,EAAA,CAClC;AACM,SAAA;AAAA,IACL,eAAeN,EAAS,MAAMD,EAAO,MAAM,aAAa;AAAA,IACxD,UAAUC,EAAS,MAAMD,EAAO,MAAM,QAAQ;AAAA,EAChD;AACF;AAIA,SAASY,EAAgBE,GAAkBC,GAAiC;AACtE,MAAA,CAACA,EAAe,QAAA,CAAC,EAAE,OAAOD,GAAU,OAAO,IAAO;AAChD,QAAAE,IAAgBF,EAAS,YAAY,GACrCG,IAAcF,EAAO,YAAY,GACjCf,IAA0B,CAAC;AACjC,MAAIkB,IAAU;AACd,aAAa;AACX,UAAMC,IAAQH,EAAc,QAAQC,GAAaC,CAAO,GAClDE,IAAMD,IAAQJ,EAAO;AAC3B,QAAII,IAAQ,EAAG;AACf,IAAID,MAAYC,KACPnB,EAAA,KAAK,EAAE,OAAOc,EAAS,MAAMI,GAASC,CAAK,GAAG,OAAO,IAAO;AAE/D,UAAAE,IAAcrB,EAAO,GAAG,EAAE;AAChC,IAAIqB,KAAA,QAAAA,EAAa,QACfA,EAAY,SAASP,EAAS,MAAMK,GAAOC,CAAG,IAEvCpB,EAAA,KAAK,EAAE,OAAOc,EAAS,MAAMK,GAAOC,CAAG,GAAG,OAAO,IAAM,GAEtDF,IAAAE;AAAA,EAAA;AAER,SAAAF,IAAUJ,EAAS,UACdd,EAAA,KAAK,EAAE,OAAOc,EAAS,MAAMI,CAAO,GAAG,OAAO,IAAO,GAEvDlB;AACT;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@platforma-sdk/ui-vue",
|
|
3
|
-
"version": "1.42.
|
|
3
|
+
"version": "1.42.19",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "dist/lib.js",
|
|
6
6
|
"styles": "dist/lib.js",
|
|
@@ -43,10 +43,10 @@
|
|
|
43
43
|
"yarpm": "^1.2.0",
|
|
44
44
|
"fast-json-patch": "^3.1.1",
|
|
45
45
|
"@faker-js/faker": "^9.2.0",
|
|
46
|
-
"@milaboratories/ts-configs": "1.0.5",
|
|
47
|
-
"@milaboratories/eslint-config": "^1.0.4",
|
|
48
46
|
"@milaboratories/build-configs": "1.0.5",
|
|
49
|
-
"@milaboratories/
|
|
47
|
+
"@milaboratories/ts-configs": "1.0.5",
|
|
48
|
+
"@milaboratories/helpers": "^1.6.19",
|
|
49
|
+
"@milaboratories/eslint-config": "^1.0.4"
|
|
50
50
|
},
|
|
51
51
|
"scripts": {
|
|
52
52
|
"test": "vitest run --passWithNoTests",
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
<script setup lang="ts">
|
|
2
|
+
import { PlBtnGhost, PlElementList, PlSearchField, PlSlideModal, usePlBlockPageTitleTeleportTarget } from '@milaboratories/uikit';
|
|
2
3
|
import { type Column, type DisplayedColumnsChangedEvent, type GridApi } from 'ag-grid-enterprise';
|
|
3
|
-
import {
|
|
4
|
-
import { ref, toRefs, watch, computed } from 'vue';
|
|
4
|
+
import { computed, ref, toRefs, watch } from 'vue';
|
|
5
5
|
import { PlAgDataTableRowNumberColId } from '../PlAgDataTable/sources/row-number';
|
|
6
|
+
import { useFilteredItems } from './useFilteredItems';
|
|
6
7
|
|
|
7
8
|
const props = defineProps<{
|
|
8
9
|
/**
|
|
@@ -46,8 +47,16 @@ const items = computed(() => {
|
|
|
46
47
|
}));
|
|
47
48
|
});
|
|
48
49
|
|
|
50
|
+
const query = ref('');
|
|
51
|
+
|
|
49
52
|
const slideModal = ref(false);
|
|
50
53
|
const teleportTarget = usePlBlockPageTitleTeleportTarget('PlAgGridColumnManager');
|
|
54
|
+
|
|
55
|
+
const { filteredItems, segments } = useFilteredItems(() => ({
|
|
56
|
+
items: items.value,
|
|
57
|
+
query: query.value,
|
|
58
|
+
getStrings: (item) => [item.label],
|
|
59
|
+
}));
|
|
51
60
|
</script>
|
|
52
61
|
|
|
53
62
|
<template>
|
|
@@ -60,8 +69,9 @@ const teleportTarget = usePlBlockPageTitleTeleportTarget('PlAgGridColumnManager'
|
|
|
60
69
|
|
|
61
70
|
<PlSlideModal v-model="slideModal" :width="width" close-on-outside-click>
|
|
62
71
|
<template #title>Manage Columns</template>
|
|
72
|
+
<PlSearchField v-model="query" clearable />
|
|
63
73
|
<PlElementList
|
|
64
|
-
:items="
|
|
74
|
+
:items="filteredItems"
|
|
65
75
|
:get-item-key="(item) => item.id"
|
|
66
76
|
:is-draggable="(item) => !item.column.getColDef().lockPosition"
|
|
67
77
|
:on-sort="(fromIndex, toIndex) => {
|
|
@@ -80,12 +90,26 @@ const teleportTarget = usePlBlockPageTitleTeleportTarget('PlAgGridColumnManager'
|
|
|
80
90
|
:is-toggable="(item) => item.id !== PlAgDataTableRowNumberColId"
|
|
81
91
|
:is-pinned="(item) => !!item.column.getColDef().lockPosition"
|
|
82
92
|
:is-pinnable="() => false"
|
|
93
|
+
:disable-dragging="query.length > 0"
|
|
83
94
|
disable-removing
|
|
84
95
|
>
|
|
85
96
|
<template #item-title="{ item }">
|
|
86
|
-
|
|
97
|
+
<span>
|
|
98
|
+
<span
|
|
99
|
+
v-for="(segment, i) of segments.get(item.label)"
|
|
100
|
+
:key="i"
|
|
101
|
+
:class="{ [$style.match]: segment.match }"
|
|
102
|
+
>{{ segment.value }}</span>
|
|
103
|
+
</span>
|
|
87
104
|
</template>
|
|
88
105
|
</PlElementList>
|
|
89
106
|
</PlSlideModal>
|
|
90
107
|
</div>
|
|
91
108
|
</template>
|
|
109
|
+
|
|
110
|
+
<style module>
|
|
111
|
+
.match {
|
|
112
|
+
background-color: var(--color-active-select);
|
|
113
|
+
border-radius: 2px;
|
|
114
|
+
}
|
|
115
|
+
</style>
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { computed, type MaybeRefOrGetter, toValue } from 'vue';
|
|
2
|
+
|
|
3
|
+
export function useFilteredItems<T>(
|
|
4
|
+
props: MaybeRefOrGetter<{
|
|
5
|
+
items: T[];
|
|
6
|
+
query: string;
|
|
7
|
+
getStrings: (item: T) => Iterable<string>;
|
|
8
|
+
}>,
|
|
9
|
+
) {
|
|
10
|
+
const result = computed(() => {
|
|
11
|
+
const { items, query, getStrings } = toValue(props);
|
|
12
|
+
const filteredItems: T[] = [];
|
|
13
|
+
const segments = new Map<string, StringSegment[]>();
|
|
14
|
+
for (const item of items) {
|
|
15
|
+
let kept = false;
|
|
16
|
+
for (const string of getStrings(item)) {
|
|
17
|
+
let stringSegments = segments.get(string);
|
|
18
|
+
if (!stringSegments) {
|
|
19
|
+
stringSegments = matchSubstrings(string, query);
|
|
20
|
+
segments.set(string, stringSegments);
|
|
21
|
+
}
|
|
22
|
+
if (!kept && (!query || stringSegments.some(({ match }) => match))) {
|
|
23
|
+
filteredItems.push(item);
|
|
24
|
+
kept = true;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return { filteredItems, segments };
|
|
29
|
+
});
|
|
30
|
+
return {
|
|
31
|
+
filteredItems: computed(() => result.value.filteredItems),
|
|
32
|
+
segments: computed(() => result.value.segments),
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// Very naïve implementation of substring matching, doesn't handle Unicode well
|
|
37
|
+
// Maybe one day we'll have nice things: https://github.com/tc39/ecma402/issues/506
|
|
38
|
+
function matchSubstrings(haystack: string, needle: string): StringSegment[] {
|
|
39
|
+
if (!needle) return [{ value: haystack, match: false }];
|
|
40
|
+
const haystackLower = haystack.toLowerCase();
|
|
41
|
+
const needleLower = needle.toLowerCase();
|
|
42
|
+
const result: StringSegment[] = [];
|
|
43
|
+
let prevEnd = 0;
|
|
44
|
+
while (true) {
|
|
45
|
+
const start = haystackLower.indexOf(needleLower, prevEnd);
|
|
46
|
+
const end = start + needle.length;
|
|
47
|
+
if (start < 0) break;
|
|
48
|
+
if (prevEnd !== start) {
|
|
49
|
+
result.push({ value: haystack.slice(prevEnd, start), match: false });
|
|
50
|
+
}
|
|
51
|
+
const prevSegment = result.at(-1);
|
|
52
|
+
if (prevSegment?.match) {
|
|
53
|
+
prevSegment.value += haystack.slice(start, end);
|
|
54
|
+
} else {
|
|
55
|
+
result.push({ value: haystack.slice(start, end), match: true });
|
|
56
|
+
}
|
|
57
|
+
prevEnd = end;
|
|
58
|
+
}
|
|
59
|
+
if (prevEnd < haystack.length) {
|
|
60
|
+
result.push({ value: haystack.slice(prevEnd), match: false });
|
|
61
|
+
}
|
|
62
|
+
return result;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
type StringSegment = {
|
|
66
|
+
value: string;
|
|
67
|
+
match: boolean;
|
|
68
|
+
};
|