@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.
@@ -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.18 build /home/runner/_work/platforma/platforma/sdk/ui-vue
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
  vite v6.3.5 building for production...
7
7
  transforming...
8
- ✓ 901 modules transformed.
8
+ ✓ 903 modules transformed.
9
+ Export "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.
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 6391ms.
15
+ [vite:dts] Declaration files built in 5734ms.
14
16
 
15
17
  dist/_virtual/re.js  0.08 kB │ gzip: 0.10 kB │ map: 0.09 kB
16
18
  dist/lib/ui/uikit/dist/node_modules/.pnpm/d3-interpolate@3.0.1/node_modules/d3-interpolate/src/constant.js  0.09 kB │ gzip: 0.10 kB │ map: 0.32 kB
@@ -48,7 +50,6 @@ computing gzip size...
48
50
  dist/components/PlTableFilters/PlTableAddFilterV2.vue2.js  0.12 kB │ gzip: 0.12 kB │ map: 0.11 kB
49
51
  dist/plugins/Monetization/MonetizationSidebar.vue2.js  0.13 kB │ gzip: 0.12 kB │ map: 0.11 kB
50
52
  dist/components/PlTableFilters/PlTableFilterEntryV2.vue2.js  0.13 kB │ gzip: 0.12 kB │ map: 0.11 kB
51
- dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js  0.13 kB │ gzip: 0.12 kB │ map: 0.11 kB
52
53
  dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue2.js  0.13 kB │ gzip: 0.12 kB │ map: 0.11 kB
53
54
  dist/lib/ui/uikit/dist/components/PlRadio/keys.js  0.13 kB │ gzip: 0.13 kB │ map: 0.46 kB
54
55
  dist/lib/ui/uikit/dist/node_modules/.pnpm/d3-selection@3.0.0/node_modules/d3-selection/src/selection/size.js  0.13 kB │ gzip: 0.13 kB │ map: 0.49 kB
@@ -238,13 +239,14 @@ computing gzip size...
238
239
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/16_arrow-right.svg.js  0.31 kB │ gzip: 0.25 kB │ map: 0.52 kB
239
240
  dist/_virtual/stringify.js  0.31 kB │ gzip: 0.22 kB │ map: 0.10 kB
240
241
  dist/components/PlAnnotations/components/PlAnnotationsModal.vue.js  0.31 kB │ gzip: 0.22 kB │ map: 0.11 kB
241
- dist/components/PlAgDataTable/PlAgDataTableSheets.vue.js  0.31 kB │ gzip: 0.22 kB │ map: 0.11 kB
242
242
  dist/components/PlAnnotations/components/AnnotationsSidebar.vue.js  0.31 kB │ gzip: 0.22 kB │ map: 0.11 kB
243
+ dist/components/PlAgDataTable/PlAgDataTableSheets.vue.js  0.31 kB │ gzip: 0.22 kB │ map: 0.11 kB
243
244
  dist/node_modules/.pnpm/semver@7.7.2/node_modules/semver/ranges/valid.js  0.31 kB │ gzip: 0.22 kB │ map: 0.76 kB
244
245
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_chevron-first.svg.js  0.31 kB │ gzip: 0.25 kB │ map: 0.53 kB
245
246
  dist/lib/ui/uikit/dist/node_modules/.pnpm/d3-selection@3.0.0/node_modules/d3-selection/src/namespaces.js  0.31 kB │ gzip: 0.19 kB │ map: 0.65 kB
246
247
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/16_chevron-last.svg.js  0.32 kB │ gzip: 0.25 kB │ map: 0.53 kB
247
248
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_radio-button-checked.svg.js  0.32 kB │ gzip: 0.25 kB │ map: 0.57 kB
249
+ dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue.js  0.32 kB │ gzip: 0.23 kB │ map: 0.12 kB
248
250
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_chevron-last.svg.js  0.32 kB │ gzip: 0.26 kB │ map: 0.53 kB
249
251
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_sort.svg.js  0.32 kB │ gzip: 0.25 kB │ map: 0.51 kB
250
252
  dist/lib/ui/uikit/dist/components/PlChartHistogram/drawThreshold.js  0.32 kB │ gzip: 0.23 kB │ map: 1.03 kB
@@ -370,6 +372,7 @@ computing gzip size...
370
372
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/16_y-axis.svg.js  0.45 kB │ gzip: 0.30 kB │ map: 0.68 kB
371
373
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_delete-circle.svg.js  0.45 kB │ gzip: 0.31 kB │ map: 0.68 kB
372
374
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_zoom-in.svg.js  0.45 kB │ gzip: 0.30 kB │ map: 0.68 kB
375
+ dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue3.js  0.45 kB │ gzip: 0.33 kB │ map: 0.11 kB
373
376
  dist/computedResult.js  0.45 kB │ gzip: 0.27 kB │ map: 2.41 kB
374
377
  dist/lib/ui/uikit/dist/assets/images/24_checkbox-light-enabled-checked.svg.js  0.45 kB │ gzip: 0.33 kB │ map: 0.74 kB
375
378
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_frame-type-all.svg.js  0.46 kB │ gzip: 0.31 kB │ map: 0.68 kB
@@ -634,6 +637,7 @@ computing gzip size...
634
637
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_dna-import.svg.js  1.11 kB │ gzip: 0.67 kB │ map: 1.34 kB
635
638
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_progress.svg.js  1.11 kB │ gzip: 0.64 kB │ map: 1.32 kB
636
639
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_settings.svg.js  1.13 kB │ gzip: 0.60 kB │ map: 1.35 kB
640
+ dist/components/PlAgGridColumnManager/useFilteredItems.js  1.13 kB │ gzip: 0.58 kB │ map: 3.94 kB
637
641
  dist/lib/ui/uikit/dist/components/PlTabs/Tab.vue.js  1.13 kB │ gzip: 0.62 kB │ map: 1.58 kB
638
642
  dist/lib/ui/uikit/dist/components/PlSplash/PlSplash.vue.js  1.14 kB │ gzip: 0.56 kB │ map: 0.13 kB
639
643
  dist/lib/ui/uikit/dist/components/PlChartStackedBar/PlChartStackedBar.vue2.js  1.14 kB │ gzip: 0.58 kB │ map: 1.64 kB
@@ -784,7 +788,6 @@ computing gzip size...
784
788
  dist/components/PlAgColumnHeader/PlAgColumnHeader.vue.js  3.32 kB │ gzip: 1.34 kB │ map: 4.05 kB
785
789
  dist/components/PlAgDataTable/sources/table-state-v2.js  3.33 kB │ gzip: 1.16 kB │ map: 9.95 kB
786
790
  dist/node_modules/.pnpm/fast-json-patch@3.1.1/node_modules/fast-json-patch/module/duplex.js  3.33 kB │ gzip: 1.22 kB │ map: 10.70 kB
787
- dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue.js  3.34 kB │ gzip: 1.30 kB │ map: 4.05 kB
788
791
  dist/components/PlTableFilters/PlTableAddFilterV2.vue.js  3.42 kB │ gzip: 1.28 kB │ map: 3.95 kB
789
792
  dist/lib/ui/uikit/dist/generated/icons-24.js  3.43 kB │ gzip: 1.10 kB │ map: 5.86 kB
790
793
  dist/lib/ui/uikit/dist/node_modules/.pnpm/d3-axis@3.0.0/node_modules/d3-axis/src/axis.js  3.49 kB │ gzip: 1.30 kB │ map: 10.47 kB
@@ -809,6 +812,7 @@ computing gzip size...
809
812
  dist/node_modules/.pnpm/semver@7.7.2/node_modules/semver/internal/re.js  4.03 kB │ gzip: 1.23 kB │ map: 12.96 kB
810
813
  dist/lib/ui/uikit/dist/components/PlChip/PlChip.vue.js  4.05 kB │ gzip: 1.61 kB │ map: 1.36 kB
811
814
  dist/components/PlAnnotations/components/PlAnnotationsModal.vue2.js  4.10 kB │ gzip: 1.41 kB │ map: 5.48 kB
815
+ dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js  4.20 kB │ gzip: 1.57 kB │ map: 5.00 kB
812
816
  dist/lib/ui/uikit/dist/assets/icons/icon-assets-min/24_heatmap.svg.js  4.38 kB │ gzip: 0.99 kB │ map: 4.71 kB
813
817
  dist/lib/ui/uikit/dist/components/PlBtnGhost/PlBtnGhost.vue.js  4.39 kB │ gzip: 1.66 kB │ map: 2.39 kB
814
818
  dist/lib/ui/uikit/dist/composition/useSortable2.js  4.41 kB │ gzip: 1.51 kB │ map: 13.13 kB
@@ -880,4 +884,4 @@ computing gzip size...
880
884
  dist/lib/ui/uikit/dist/index.js 497.77 kB │ gzip: 191.75 kB │ map: 0.18 kB
881
885
  dist/lib/ui/uikit/dist/components/PlSlideModal/PlPureSlideModal.vue.js 600.06 kB │ gzip: 204.69 kB │ map: 0.21 kB
882
886
  dist/lib/ui/uikit/dist/components/DataTable/TableComponent.vue.js 601.95 kB │ gzip: 205.54 kB │ map: 0.27 kB
883
- ✓ built in 10.68s
887
+ ✓ built in 9.81s
@@ -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.18 type-check /home/runner/_work/platforma/platforma/sdk/ui-vue
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,5 +1,11 @@
1
1
  # @platforma-sdk/ui-vue
2
2
 
3
+ ## 1.42.19
4
+
5
+ ### Patch Changes
6
+
7
+ - 77103d0: PlAgDataTable: search field in columns manager
8
+
3
9
  ## 1.42.18
4
10
 
5
11
  ### Patch Changes
@@ -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 F, ref as M, shallowRef as _, watch as R, effectScope as ce, createElementBlock as me, openBlock as I, normalizeClass as H, createBlock as T, createCommentVNode as $, createVNode as fe, unref as b, isRef as Q, withCtx as W, renderSlot as j } from "vue";
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 z, getRawPlatformaInstance as pe } from "../../sdk/model/dist/index.js";
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 X, autoSizeRowNumberColumn as be } from "./sources/row-number.js";
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 Y, getAxisId as Z, matchAxisId as ee, canonicalizeJson as te } from "../../lib/model/common/dist/index.js";
22
- const Xe = /* @__PURE__ */ ue({
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(B, { expose: le, emit: oe }) {
45
- const ae = q(B, "modelValue"), o = q(B, "selection"), d = B, { settings: D } = de(d), G = oe, { gridState: O, sheetsState: P, filtersState: k } = ke(ae, D), se = F(() => {
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 = M([]), ne = F(() => {
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 = _(null), x = new xe(), r = _({
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) => Y(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 && G("rowDoubleClicked", 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() !== X
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 = M(0);
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 = F(() => d.cellRendererSelector ?? null);
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 = Z(p);
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 !== X) : [];
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) => Y(a.colId).labeled);
253
+ V.value = l.map((a) => Z(a.colId).labeled);
254
254
  }
255
255
  },
256
256
  { immediate: !0 }
257
257
  );
258
- const L = z();
258
+ const A = $();
259
259
  let v = null;
260
- const C = M(0);
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, L) && (o.value = z()), e.setServerSideSelectionState({
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, L) && (o.value = z()), e.setServerSideSelectionState({
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) => G("cellButtonClicked", 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(Z).map((f) => m.findIndex((K) => ee(K, f))), w = new Set(S);
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 A = p.map((f) => S.map((K) => f[K])), J = { axesSpec: m, selectedKeys: A };
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: A.map((f) => te(f))
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(() => G("newDataRendered"));
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: H(e.$style.container)
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"])) : $("", !0),
388
- e.disableFiltersPanel ? $("", !0) : (I(), T(he, {
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) => Q(k) ? k.value = l : null),
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"])) : $("", !0),
397
+ }, null, 8, ["api"])) : z("", !0),
398
398
  fe(we, {
399
399
  modelValue: b(P),
400
- "onUpdate:modelValue": t[1] || (t[1] = (l) => Q(P) ? P.value = l : null),
400
+ "onUpdate:modelValue": t[1] || (t[1] = (l) => W(P) ? P.value = l : null),
401
401
  settings: se.value
402
402
  }, {
403
- before: W(() => [
404
- j(e.$slots, "before-sheets")
403
+ before: j(() => [
404
+ X(e.$slots, "before-sheets")
405
405
  ]),
406
- after: W(() => [
407
- j(e.$slots, "after-sheets")
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: H(e.$style.grid),
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
- Xe as default
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":"AA6FA,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;;AA0LF,wBAOG"}
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 { defineComponent as b, toRefs as k, ref as d, watch as V, computed as w, createElementBlock as y, openBlock as g, createBlock as D, createCommentVNode as T, createVNode as r, unref as l, Teleport as P, withModifiers as M, withCtx as a, createTextVNode as m, toDisplayString as N } from "vue";
2
- import "../../lib/ui/uikit/dist/index.js";
3
- import { PlAgDataTableRowNumberColId as B } from "../PlAgDataTable/sources/row-number.js";
4
- import { usePlBlockPageTitleTeleportTarget as G } from "../../lib/ui/uikit/dist/layout/PlBlockPage/usePlBlockPageTitleTeleportTarget.js";
5
- import h from "../../lib/ui/uikit/dist/components/PlBtnGhost/PlBtnGhost.vue.js";
6
- import x from "../../lib/ui/uikit/dist/components/PlSlideModal/PlSlideModal.vue.js";
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
- j as default
8
+ c as default
88
9
  };
89
10
  //# sourceMappingURL=PlAgGridColumnManager.vue.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlAgGridColumnManager.vue.js","sources":["../../../src/components/PlAgGridColumnManager/PlAgGridColumnManager.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { type Column, type DisplayedColumnsChangedEvent, type GridApi } from 'ag-grid-enterprise';\nimport { PlBtnGhost, PlSlideModal, PlElementList, usePlBlockPageTitleTeleportTarget } from '@milaboratories/uikit';\nimport { ref, toRefs, watch, computed } from 'vue';\nimport { PlAgDataTableRowNumberColId } from '../PlAgDataTable/sources/row-number';\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 slideModal = ref(false);\nconst teleportTarget = usePlBlockPageTitleTeleportTarget('PlAgGridColumnManager');\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 <PlElementList\n :items=\"items\"\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-removing\n >\n <template #item-title=\"{ item }\">\n {{ item.label }}\n </template>\n </PlElementList>\n </PlSlideModal>\n </div>\n</template>\n"],"names":["props","__props","gridApi","toRefs","columns","ref","watch","event","items","computed","col","slideModal","teleportTarget","usePlBlockPageTitleTeleportTarget"],"mappings":";;;;;;;;;;;;;;AAMA,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,IAAaN,EAAI,EAAK,GACtBO,IAAiBC,EAAkC,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"PlAgGridColumnManager.vue.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -1,5 +1,106 @@
1
- import f from "./PlAgGridColumnManager.vue.js";
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
- f as default
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.18",
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/helpers": "^1.6.19"
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 { PlBtnGhost, PlSlideModal, PlElementList, usePlBlockPageTitleTeleportTarget } from '@milaboratories/uikit';
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="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
- {{ item.label }}
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
+ };