@platforma-sdk/ui-vue 1.45.35 → 1.45.37

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (180) hide show
  1. package/.turbo/turbo-build.log +204 -235
  2. package/.turbo/turbo-type-check.log +1 -1
  3. package/CHANGELOG.md +13 -0
  4. package/dist/AgGridVue/useAgGridOptions.js +2 -3
  5. package/dist/AgGridVue/useAgGridOptions.js.map +1 -1
  6. package/dist/components/BlockLayout.vue2.js +3 -3
  7. package/dist/components/BlockLayout.vue2.js.map +1 -1
  8. package/dist/components/BlockLoader.vue.js.map +1 -1
  9. package/dist/components/LoaderPage.vue.js +2 -2
  10. package/dist/components/LoaderPage.vue.js.map +1 -1
  11. package/dist/components/NotFound.vue.js +3 -3
  12. package/dist/components/NotFound.vue.js.map +1 -1
  13. package/dist/components/PlAdvancedFilter/OperandButton.vue2.js.map +1 -1
  14. package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue2.js +73 -73
  15. package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue2.js.map +1 -1
  16. package/dist/components/PlAdvancedFilter/SingleFilter.vue2.js +100 -100
  17. package/dist/components/PlAdvancedFilter/SingleFilter.vue2.js.map +1 -1
  18. package/dist/components/PlAgCellFile/PlAgCellFile.vue.js.map +1 -1
  19. package/dist/components/PlAgCellProgress/PlAgCellProgress.vue.js.map +1 -1
  20. package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue.js +6 -6
  21. package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue.js.map +1 -1
  22. package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue.js.map +1 -1
  23. package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue.js.map +1 -1
  24. package/dist/components/PlAgColumnHeader/PlAgColumnHeader.vue.js +22 -22
  25. package/dist/components/PlAgColumnHeader/PlAgColumnHeader.vue.js.map +1 -1
  26. package/dist/components/PlAgCsvExporter/PlAgCsvExporter.vue.js +3 -3
  27. package/dist/components/PlAgCsvExporter/PlAgCsvExporter.vue.js.map +1 -1
  28. package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue2.js.map +1 -1
  29. package/dist/components/PlAgDataTable/PlAgDataTableV2.vue2.js +50 -50
  30. package/dist/components/PlAgDataTable/PlAgDataTableV2.vue2.js.map +1 -1
  31. package/dist/components/PlAgDataTable/PlAgOverlayLoading.vue.js.map +1 -1
  32. package/dist/components/PlAgDataTable/PlAgOverlayNoRows.vue.js.map +1 -1
  33. package/dist/components/PlAgDataTable/PlAgRowCount.vue.js +7 -8
  34. package/dist/components/PlAgDataTable/PlAgRowCount.vue.js.map +1 -1
  35. package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js +35 -35
  36. package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js.map +1 -1
  37. package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue.js +16 -17
  38. package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue.js.map +1 -1
  39. package/dist/components/PlAgRowNumHeader.vue.js +14 -15
  40. package/dist/components/PlAgRowNumHeader.vue.js.map +1 -1
  41. package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue.js +16 -16
  42. package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue.js.map +1 -1
  43. package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue2.js +6 -6
  44. package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue2.js.map +1 -1
  45. package/dist/components/PlAnnotations/components/DynamicForm.vue2.js +57 -57
  46. package/dist/components/PlAnnotations/components/DynamicForm.vue2.js.map +1 -1
  47. package/dist/components/PlAnnotations/components/FilterSidebar.vue2.js +6 -6
  48. package/dist/components/PlAnnotations/components/FilterSidebar.vue2.js.map +1 -1
  49. package/dist/components/PlAnnotations/components/PlAnnotations.vue2.js.map +1 -1
  50. package/dist/components/PlAnnotations/components/PlAnnotationsModal.vue2.js.map +1 -1
  51. package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.vue.js +7 -7
  52. package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.vue.js.map +1 -1
  53. package/dist/components/PlBtnExportArchive/Item.vue2.js +23 -23
  54. package/dist/components/PlBtnExportArchive/Item.vue2.js.map +1 -1
  55. package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue2.js.map +1 -1
  56. package/dist/components/PlBtnExportArchive/Summary.vue2.js +22 -22
  57. package/dist/components/PlBtnExportArchive/Summary.vue2.js.map +1 -1
  58. package/dist/components/PlTableFilters/PlTableAddFilterV2.vue.js +9 -9
  59. package/dist/components/PlTableFilters/PlTableAddFilterV2.vue.js.map +1 -1
  60. package/dist/components/PlTableFilters/PlTableFilterEntryV2.vue.js +3 -3
  61. package/dist/components/PlTableFilters/PlTableFilterEntryV2.vue.js.map +1 -1
  62. package/dist/components/PlTableFilters/PlTableFiltersV2.vue2.js +9 -9
  63. package/dist/components/PlTableFilters/PlTableFiltersV2.vue2.js.map +1 -1
  64. package/dist/components/ValueOrErrorsComponent.vue.js.map +1 -1
  65. package/dist/index.js +48 -50
  66. package/dist/index.js.map +1 -1
  67. package/dist/lib.d.ts +0 -1
  68. package/dist/plugins/Monetization/EndOfPeriod.vue2.js +9 -9
  69. package/dist/plugins/Monetization/EndOfPeriod.vue2.js.map +1 -1
  70. package/dist/plugins/Monetization/LimitCard.vue2.js +40 -40
  71. package/dist/plugins/Monetization/LimitCard.vue2.js.map +1 -1
  72. package/dist/plugins/Monetization/MonetizationSidebar.vue.js +3 -3
  73. package/dist/plugins/Monetization/MonetizationSidebar.vue.js.map +1 -1
  74. package/dist/plugins/Monetization/RunStatus.vue2.js +12 -12
  75. package/dist/plugins/Monetization/RunStatus.vue2.js.map +1 -1
  76. package/dist/plugins/Monetization/UserCabinetCard.vue2.js +22 -22
  77. package/dist/plugins/Monetization/UserCabinetCard.vue2.js.map +1 -1
  78. package/package.json +7 -8
  79. package/src/lib.ts +0 -2
  80. package/dist/assets/multi-sequence-alignment.worker-Cm0gZp19.js +0 -6
  81. package/dist/assets/multi-sequence-alignment.worker-Cm0gZp19.js.map +0 -1
  82. package/dist/assets/phylogenetic-tree.worker-4CrExYEo.js +0 -5
  83. package/dist/assets/phylogenetic-tree.worker-4CrExYEo.js.map +0 -1
  84. package/dist/components/PlMultiSequenceAlignment/Consensus.vue.d.ts +0 -9
  85. package/dist/components/PlMultiSequenceAlignment/Consensus.vue.js +0 -10
  86. package/dist/components/PlMultiSequenceAlignment/Consensus.vue.js.map +0 -1
  87. package/dist/components/PlMultiSequenceAlignment/Consensus.vue2.js +0 -122
  88. package/dist/components/PlMultiSequenceAlignment/Consensus.vue2.js.map +0 -1
  89. package/dist/components/PlMultiSequenceAlignment/Consensus.vue3.js +0 -9
  90. package/dist/components/PlMultiSequenceAlignment/Consensus.vue3.js.map +0 -1
  91. package/dist/components/PlMultiSequenceAlignment/Legend.vue.d.ts +0 -6
  92. package/dist/components/PlMultiSequenceAlignment/Legend.vue.js +0 -10
  93. package/dist/components/PlMultiSequenceAlignment/Legend.vue.js.map +0 -1
  94. package/dist/components/PlMultiSequenceAlignment/Legend.vue2.js +0 -28
  95. package/dist/components/PlMultiSequenceAlignment/Legend.vue2.js.map +0 -1
  96. package/dist/components/PlMultiSequenceAlignment/Legend.vue3.js +0 -13
  97. package/dist/components/PlMultiSequenceAlignment/Legend.vue3.js.map +0 -1
  98. package/dist/components/PlMultiSequenceAlignment/MultiSequenceAlignmentView.vue.d.ts +0 -25
  99. package/dist/components/PlMultiSequenceAlignment/MultiSequenceAlignmentView.vue.js +0 -10
  100. package/dist/components/PlMultiSequenceAlignment/MultiSequenceAlignmentView.vue.js.map +0 -1
  101. package/dist/components/PlMultiSequenceAlignment/MultiSequenceAlignmentView.vue2.js +0 -138
  102. package/dist/components/PlMultiSequenceAlignment/MultiSequenceAlignmentView.vue2.js.map +0 -1
  103. package/dist/components/PlMultiSequenceAlignment/MultiSequenceAlignmentView.vue3.js +0 -31
  104. package/dist/components/PlMultiSequenceAlignment/MultiSequenceAlignmentView.vue3.js.map +0 -1
  105. package/dist/components/PlMultiSequenceAlignment/PhylogeneticTree.vue.d.ts +0 -8
  106. package/dist/components/PlMultiSequenceAlignment/PhylogeneticTree.vue.js +0 -10
  107. package/dist/components/PlMultiSequenceAlignment/PhylogeneticTree.vue.js.map +0 -1
  108. package/dist/components/PlMultiSequenceAlignment/PhylogeneticTree.vue2.js +0 -77
  109. package/dist/components/PlMultiSequenceAlignment/PhylogeneticTree.vue2.js.map +0 -1
  110. package/dist/components/PlMultiSequenceAlignment/PhylogeneticTree.vue3.js +0 -9
  111. package/dist/components/PlMultiSequenceAlignment/PhylogeneticTree.vue3.js.map +0 -1
  112. package/dist/components/PlMultiSequenceAlignment/PlMultiSequenceAlignment.vue.d.ts +0 -71
  113. package/dist/components/PlMultiSequenceAlignment/PlMultiSequenceAlignment.vue.js +0 -10
  114. package/dist/components/PlMultiSequenceAlignment/PlMultiSequenceAlignment.vue.js.map +0 -1
  115. package/dist/components/PlMultiSequenceAlignment/PlMultiSequenceAlignment.vue2.js +0 -224
  116. package/dist/components/PlMultiSequenceAlignment/PlMultiSequenceAlignment.vue2.js.map +0 -1
  117. package/dist/components/PlMultiSequenceAlignment/PlMultiSequenceAlignment.vue3.js +0 -9
  118. package/dist/components/PlMultiSequenceAlignment/PlMultiSequenceAlignment.vue3.js.map +0 -1
  119. package/dist/components/PlMultiSequenceAlignment/SeqLogo.vue.d.ts +0 -8
  120. package/dist/components/PlMultiSequenceAlignment/SeqLogo.vue.js +0 -10
  121. package/dist/components/PlMultiSequenceAlignment/SeqLogo.vue.js.map +0 -1
  122. package/dist/components/PlMultiSequenceAlignment/SeqLogo.vue2.js +0 -127
  123. package/dist/components/PlMultiSequenceAlignment/SeqLogo.vue2.js.map +0 -1
  124. package/dist/components/PlMultiSequenceAlignment/SeqLogo.vue3.js +0 -9
  125. package/dist/components/PlMultiSequenceAlignment/SeqLogo.vue3.js.map +0 -1
  126. package/dist/components/PlMultiSequenceAlignment/Toolbar.vue.d.ts +0 -16
  127. package/dist/components/PlMultiSequenceAlignment/Toolbar.vue.js +0 -10
  128. package/dist/components/PlMultiSequenceAlignment/Toolbar.vue.js.map +0 -1
  129. package/dist/components/PlMultiSequenceAlignment/Toolbar.vue2.js +0 -228
  130. package/dist/components/PlMultiSequenceAlignment/Toolbar.vue2.js.map +0 -1
  131. package/dist/components/PlMultiSequenceAlignment/Toolbar.vue3.js +0 -19
  132. package/dist/components/PlMultiSequenceAlignment/Toolbar.vue3.js.map +0 -1
  133. package/dist/components/PlMultiSequenceAlignment/cell-size.d.ts +0 -4
  134. package/dist/components/PlMultiSequenceAlignment/cell-size.js +0 -8
  135. package/dist/components/PlMultiSequenceAlignment/cell-size.js.map +0 -1
  136. package/dist/components/PlMultiSequenceAlignment/chemical-properties.d.ts +0 -44
  137. package/dist/components/PlMultiSequenceAlignment/chemical-properties.js +0 -132
  138. package/dist/components/PlMultiSequenceAlignment/chemical-properties.js.map +0 -1
  139. package/dist/components/PlMultiSequenceAlignment/data.d.ts +0 -61
  140. package/dist/components/PlMultiSequenceAlignment/data.js +0 -370
  141. package/dist/components/PlMultiSequenceAlignment/data.js.map +0 -1
  142. package/dist/components/PlMultiSequenceAlignment/index.d.ts +0 -1
  143. package/dist/components/PlMultiSequenceAlignment/markup.d.ts +0 -16
  144. package/dist/components/PlMultiSequenceAlignment/markup.js +0 -84
  145. package/dist/components/PlMultiSequenceAlignment/markup.js.map +0 -1
  146. package/dist/components/PlMultiSequenceAlignment/migrations.d.ts +0 -3
  147. package/dist/components/PlMultiSequenceAlignment/migrations.js +0 -24
  148. package/dist/components/PlMultiSequenceAlignment/migrations.js.map +0 -1
  149. package/dist/components/PlMultiSequenceAlignment/multi-sequence-alignment.worker.d.ts +0 -6
  150. package/dist/components/PlMultiSequenceAlignment/phylogenetic-tree.worker.d.ts +0 -7
  151. package/dist/components/PlMultiSequenceAlignment/residue-counts.d.ts +0 -2
  152. package/dist/components/PlMultiSequenceAlignment/residue-counts.js +0 -13
  153. package/dist/components/PlMultiSequenceAlignment/residue-counts.js.map +0 -1
  154. package/dist/components/PlMultiSequenceAlignment/settings.d.ts +0 -2
  155. package/dist/components/PlMultiSequenceAlignment/settings.js +0 -9
  156. package/dist/components/PlMultiSequenceAlignment/settings.js.map +0 -1
  157. package/dist/components/PlMultiSequenceAlignment/types.d.ts +0 -5
  158. package/dist/components/PlMultiSequenceAlignment/useMiPlots.d.ts +0 -4
  159. package/dist/components/PlMultiSequenceAlignment/useMiPlots.js +0 -19
  160. package/dist/components/PlMultiSequenceAlignment/useMiPlots.js.map +0 -1
  161. package/src/components/PlMultiSequenceAlignment/Consensus.vue +0 -165
  162. package/src/components/PlMultiSequenceAlignment/Legend.vue +0 -44
  163. package/src/components/PlMultiSequenceAlignment/MultiSequenceAlignmentView.vue +0 -299
  164. package/src/components/PlMultiSequenceAlignment/PhylogeneticTree.vue +0 -110
  165. package/src/components/PlMultiSequenceAlignment/PlMultiSequenceAlignment.vue +0 -314
  166. package/src/components/PlMultiSequenceAlignment/README.md +0 -216
  167. package/src/components/PlMultiSequenceAlignment/SeqLogo.vue +0 -166
  168. package/src/components/PlMultiSequenceAlignment/Toolbar.vue +0 -228
  169. package/src/components/PlMultiSequenceAlignment/cell-size.ts +0 -4
  170. package/src/components/PlMultiSequenceAlignment/chemical-properties.ts +0 -199
  171. package/src/components/PlMultiSequenceAlignment/data.ts +0 -661
  172. package/src/components/PlMultiSequenceAlignment/index.ts +0 -1
  173. package/src/components/PlMultiSequenceAlignment/markup.ts +0 -141
  174. package/src/components/PlMultiSequenceAlignment/migrations.ts +0 -46
  175. package/src/components/PlMultiSequenceAlignment/multi-sequence-alignment.worker.ts +0 -54
  176. package/src/components/PlMultiSequenceAlignment/phylogenetic-tree.worker.ts +0 -89
  177. package/src/components/PlMultiSequenceAlignment/residue-counts.ts +0 -124
  178. package/src/components/PlMultiSequenceAlignment/settings.ts +0 -7
  179. package/src/components/PlMultiSequenceAlignment/types.ts +0 -3
  180. package/src/components/PlMultiSequenceAlignment/useMiPlots.ts +0 -23
@@ -1,15 +1,15 @@
1
1
  (function(){"use strict";try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode(".pl-ag-column-header{cursor:pointer;width:100%;overflow:hidden}.pl-ag-column-header .mask-16{min-width:16px}.pl-ag-column-header span{word-break:break-word;overflow:hidden;text-overflow:ellipsis}.pl-ag-column-header__title{overflow:hidden}.pl-ag-column-header__type-icon{--icon-color: var(--txt-03)}.pl-ag-column-header__menu-icon{transform:rotate(90deg);position:relative;line-height:0}")),document.head.appendChild(e)}}catch(o){console.error("vite-plugin-css-injected-by-js",o)}})();
2
- import { defineComponent as C, computed as m, ref as i, onMounted as k, createElementBlock as p, openBlock as r, createVNode as n, createCommentVNode as d, unref as a, createSlots as S, withCtx as f, createElementVNode as g, createBlock as B, toDisplayString as h, createTextVNode as M, withModifiers as N } from "vue";
3
- import { PlTooltip as x, PlMaskIcon16 as o } from "@milaboratories/uikit";
2
+ import { defineComponent as C, computed as m, ref as i, onMounted as k, createElementBlock as d, openBlock as n, createVNode as r, createCommentVNode as p, unref as a, createSlots as x, withCtx as f, createElementVNode as g, createBlock as S, toDisplayString as h, createTextVNode as B, withModifiers as M } from "vue";
3
+ import { PlTooltip as N, PlMaskIcon16 as o } from "@milaboratories/uikit";
4
4
 
5
5
  const A = { class: "pl-ag-column-header__title d-flex align-center gap-6 flex-grow-1" }, I = /* @__PURE__ */ C({
6
6
  __name: "PlAgColumnHeader",
7
7
  props: {
8
8
  params: {}
9
9
  },
10
- setup(t) {
10
+ setup(e) {
11
11
  const v = m(() => {
12
- switch (t.params.type) {
12
+ switch (e.params.type) {
13
13
  case void 0:
14
14
  case "Text":
15
15
  return "cell-type-txt";
@@ -24,16 +24,16 @@ const A = { class: "pl-ag-column-header__title d-flex align-center gap-6 flex-gr
24
24
  case "Progress":
25
25
  return "progress";
26
26
  default:
27
- throw Error(`unsupported data type: ${t.params.type} for PlAgColumnHeader component. Column ${t.params.column.getColId()}`);
27
+ throw Error(`unsupported data type: ${e.params.type} for PlAgColumnHeader component. Column ${e.params.column.getColId()}`);
28
28
  }
29
- }), l = i(null), c = () => l.value = t.params.column.getSort() ?? null;
29
+ }), l = i(null), c = () => l.value = e.params.column.getSort() ?? null;
30
30
  k(() => c());
31
31
  function w() {
32
- t.params.column.isSortable() && (t.params.progressSort(), c());
32
+ e.params.column.isSortable() && (e.params.progressSort(), c());
33
33
  }
34
34
  const u = m(() => {
35
- const e = l.value;
36
- switch (e) {
35
+ const t = l.value;
36
+ switch (t) {
37
37
  case "asc":
38
38
  return "arrow-up";
39
39
  case "desc":
@@ -41,29 +41,29 @@ const A = { class: "pl-ag-column-header__title d-flex align-center gap-6 flex-gr
41
41
  case null:
42
42
  return null;
43
43
  default:
44
- throw Error(`unsupported sort direction: ${e}. Column ${t.params.column.getColId()}`);
44
+ throw Error(`unsupported sort direction: ${t}. Column ${e.params.column.getColId()}`);
45
45
  }
46
46
  }), s = i();
47
47
  function y() {
48
- const e = s.value;
49
- e && t.params.showColumnMenu(e);
48
+ const t = s.value;
49
+ t && e.params.showColumnMenu(t);
50
50
  }
51
- return (e, D) => (r(), p("div", {
51
+ return (t, D) => (n(), d("div", {
52
52
  class: "pl-ag-column-header d-flex align-center gap-6",
53
53
  onClick: w
54
54
  }, [
55
- n(a(x), null, S({
55
+ r(a(N), null, x({
56
56
  default: f(() => [
57
57
  g("div", A, [
58
- n(a(o), {
58
+ r(a(o), {
59
59
  name: v.value,
60
60
  class: "pl-ag-column-header__type-icon"
61
61
  }, null, 8, ["name"]),
62
62
  g("span", null, h(e.params.displayName), 1),
63
- u.value ? (r(), B(a(o), {
63
+ u.value ? (n(), S(a(o), {
64
64
  key: 0,
65
65
  name: u.value
66
- }, null, 8, ["name"])) : d("", !0)
66
+ }, null, 8, ["name"])) : p("", !0)
67
67
  ])
68
68
  ]),
69
69
  _: 2
@@ -71,20 +71,20 @@ const A = { class: "pl-ag-column-header__title d-flex align-center gap-6 flex-gr
71
71
  e.params.tooltip ? {
72
72
  name: "tooltip",
73
73
  fn: f(() => [
74
- M(h(e.params.tooltip), 1)
74
+ B(h(e.params.tooltip), 1)
75
75
  ]),
76
76
  key: "0"
77
77
  } : void 0
78
78
  ]), 1024),
79
- e.params.enableMenu ? (r(), p("div", {
79
+ e.params.enableMenu ? (n(), d("div", {
80
80
  key: 0,
81
81
  ref_key: "menuActivatorBtn",
82
82
  ref: s,
83
83
  class: "pl-ag-column-header__menu-icon",
84
- onClick: N(y, ["stop"])
84
+ onClick: M(y, ["stop"])
85
85
  }, [
86
- n(a(o), { name: "more" })
87
- ], 512)) : d("", !0)
86
+ r(a(o), { name: "more" })
87
+ ], 512)) : p("", !0)
88
88
  ]));
89
89
  }
90
90
  });
@@ -1 +1 @@
1
- {"version":3,"file":"PlAgColumnHeader.vue.js","sources":["../../../src/components/PlAgColumnHeader/PlAgColumnHeader.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { IHeaderParams, SortDirection } from 'ag-grid-enterprise';\nimport type { MaskIconName16 } from '@milaboratories/uikit';\nimport { PlMaskIcon16, PlTooltip } from '@milaboratories/uikit';\nimport { computed, onMounted, ref } from 'vue';\nimport './pl-ag-column-header.scss';\nimport type { PlAgHeaderComponentParams } from './types';\n\nconst { params } = defineProps<{ params: IHeaderParams & PlAgHeaderComponentParams }>();\n\nconst icon = computed<MaskIconName16>(() => {\n switch (params.type) {\n case undefined:\n case 'Text':\n return 'cell-type-txt';\n case 'Number':\n return 'cell-type-num';\n case 'File':\n return 'paper-clip';\n case 'Date':\n return 'calendar';\n case 'Duration':\n return 'time';\n case 'Progress':\n return 'progress';\n default:\n throw Error(`unsupported data type: ${params.type satisfies never} for PlAgColumnHeader component. Column ${params.column.getColId()}`);\n }\n});\n\nconst sortDirection = ref<SortDirection>(null);\nconst refreshSortDirection = () => (sortDirection.value = params.column.getSort() ?? null);\nonMounted(() => refreshSortDirection());\nfunction onSortRequested() {\n if (params.column.isSortable()) {\n params.progressSort();\n refreshSortDirection();\n }\n}\nconst sortIcon = computed<MaskIconName16 | null>(() => {\n const direction = sortDirection.value;\n switch (direction) {\n case 'asc':\n return 'arrow-up';\n case 'desc':\n return 'arrow-down';\n case null:\n return null;\n default:\n throw Error(`unsupported sort direction: ${direction satisfies never}. Column ${params.column.getColId()}`);\n }\n});\n\nconst menuActivatorBtn = ref<HTMLElement>();\nfunction showMenu() {\n const menuActivatorBtnValue = menuActivatorBtn.value;\n if (menuActivatorBtnValue) params.showColumnMenu(menuActivatorBtnValue);\n}\n</script>\n\n<template>\n <div class=\"pl-ag-column-header d-flex align-center gap-6\" @click=\"onSortRequested\">\n <PlTooltip>\n <template v-if=\"params.tooltip\" #tooltip>{{ params.tooltip }}</template>\n <div class=\"pl-ag-column-header__title d-flex align-center gap-6 flex-grow-1\">\n <PlMaskIcon16 :name=\"icon\" class=\"pl-ag-column-header__type-icon\" />\n <span>{{ params.displayName }}</span>\n <PlMaskIcon16 v-if=\"sortIcon\" :name=\"sortIcon\" />\n </div>\n </PlTooltip>\n <div v-if=\"params.enableMenu\" ref=\"menuActivatorBtn\" class=\"pl-ag-column-header__menu-icon\" @click.stop=\"showMenu\">\n <PlMaskIcon16 name=\"more\" />\n </div>\n </div>\n</template>\n"],"names":["icon","computed","__props","sortDirection","ref","refreshSortDirection","onMounted","onSortRequested","sortIcon","direction","menuActivatorBtn","showMenu","menuActivatorBtnValue"],"mappings":";;;;;;;;;AAUA,UAAMA,IAAOC,EAAyB,MAAM;AAC1C,cAAQC,EAAA,OAAO,MAAA;AAAA,QACb,KAAK;AAAA,QACL,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT;AACE,gBAAM,MAAM,0BAA0BA,EAAA,OAAO,IAAoB,2CAA2CA,EAAA,OAAO,OAAO,SAAA,CAAU,EAAE;AAAA,MAAA;AAAA,IAE5I,CAAC,GAEKC,IAAgBC,EAAmB,IAAI,GACvCC,IAAuB,MAAOF,EAAc,QAAQD,SAAO,OAAO,aAAa;AACrF,IAAAI,EAAU,MAAMD,GAAsB;AACtC,aAASE,IAAkB;AACzB,MAAIL,EAAA,OAAO,OAAO,WAAA,MAChBA,SAAO,aAAA,GACPG,EAAA;AAAA,IAEJ;AACA,UAAMG,IAAWP,EAAgC,MAAM;AACrD,YAAMQ,IAAYN,EAAc;AAChC,cAAQM,GAAA;AAAA,QACN,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT;AACE,gBAAM,MAAM,+BAA+BA,CAAyB,YAAYP,EAAA,OAAO,OAAO,SAAA,CAAU,EAAE;AAAA,MAAA;AAAA,IAEhH,CAAC,GAEKQ,IAAmBN,EAAA;AACzB,aAASO,IAAW;AAClB,YAAMC,IAAwBF,EAAiB;AAC/C,MAAIE,KAAuBV,EAAA,OAAO,eAAeU,CAAqB;AAAA,IACxE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"PlAgColumnHeader.vue.js","sources":["../../../src/components/PlAgColumnHeader/PlAgColumnHeader.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { IHeaderParams, SortDirection } from 'ag-grid-enterprise';\nimport type { MaskIconName16 } from '@milaboratories/uikit';\nimport { PlMaskIcon16, PlTooltip } from '@milaboratories/uikit';\nimport { computed, onMounted, ref } from 'vue';\nimport './pl-ag-column-header.scss';\nimport type { PlAgHeaderComponentParams } from './types';\n\nconst { params } = defineProps<{ params: IHeaderParams & PlAgHeaderComponentParams }>();\n\nconst icon = computed<MaskIconName16>(() => {\n switch (params.type) {\n case undefined:\n case 'Text':\n return 'cell-type-txt';\n case 'Number':\n return 'cell-type-num';\n case 'File':\n return 'paper-clip';\n case 'Date':\n return 'calendar';\n case 'Duration':\n return 'time';\n case 'Progress':\n return 'progress';\n default:\n throw Error(`unsupported data type: ${params.type satisfies never} for PlAgColumnHeader component. Column ${params.column.getColId()}`);\n }\n});\n\nconst sortDirection = ref<SortDirection>(null);\nconst refreshSortDirection = () => (sortDirection.value = params.column.getSort() ?? null);\nonMounted(() => refreshSortDirection());\nfunction onSortRequested() {\n if (params.column.isSortable()) {\n params.progressSort();\n refreshSortDirection();\n }\n}\nconst sortIcon = computed<MaskIconName16 | null>(() => {\n const direction = sortDirection.value;\n switch (direction) {\n case 'asc':\n return 'arrow-up';\n case 'desc':\n return 'arrow-down';\n case null:\n return null;\n default:\n throw Error(`unsupported sort direction: ${direction satisfies never}. Column ${params.column.getColId()}`);\n }\n});\n\nconst menuActivatorBtn = ref<HTMLElement>();\nfunction showMenu() {\n const menuActivatorBtnValue = menuActivatorBtn.value;\n if (menuActivatorBtnValue) params.showColumnMenu(menuActivatorBtnValue);\n}\n</script>\n\n<template>\n <div class=\"pl-ag-column-header d-flex align-center gap-6\" @click=\"onSortRequested\">\n <PlTooltip>\n <template v-if=\"params.tooltip\" #tooltip>{{ params.tooltip }}</template>\n <div class=\"pl-ag-column-header__title d-flex align-center gap-6 flex-grow-1\">\n <PlMaskIcon16 :name=\"icon\" class=\"pl-ag-column-header__type-icon\" />\n <span>{{ params.displayName }}</span>\n <PlMaskIcon16 v-if=\"sortIcon\" :name=\"sortIcon\" />\n </div>\n </PlTooltip>\n <div v-if=\"params.enableMenu\" ref=\"menuActivatorBtn\" class=\"pl-ag-column-header__menu-icon\" @click.stop=\"showMenu\">\n <PlMaskIcon16 name=\"more\" />\n </div>\n </div>\n</template>\n"],"names":["icon","computed","__props","sortDirection","ref","refreshSortDirection","onMounted","onSortRequested","sortIcon","direction","menuActivatorBtn","showMenu","menuActivatorBtnValue","_createElementBlock","_createVNode","_unref","PlTooltip","_createSlots","_createElementVNode","_hoisted_1","PlMaskIcon16","_toDisplayString","_createBlock","_createTextVNode"],"mappings":";;;;;;;;;AAUA,UAAMA,IAAOC,EAAyB,MAAM;AAC1C,cAAQC,EAAA,OAAO,MAAA;AAAA,QACb,KAAK;AAAA,QACL,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT;AACE,gBAAM,MAAM,0BAA0BA,EAAA,OAAO,IAAoB,2CAA2CA,EAAA,OAAO,OAAO,SAAA,CAAU,EAAE;AAAA,MAAA;AAAA,IAE5I,CAAC,GAEKC,IAAgBC,EAAmB,IAAI,GACvCC,IAAuB,MAAOF,EAAc,QAAQD,SAAO,OAAO,aAAa;AACrF,IAAAI,EAAU,MAAMD,GAAsB;AACtC,aAASE,IAAkB;AACzB,MAAIL,EAAA,OAAO,OAAO,WAAA,MAChBA,SAAO,aAAA,GACPG,EAAA;AAAA,IAEJ;AACA,UAAMG,IAAWP,EAAgC,MAAM;AACrD,YAAMQ,IAAYN,EAAc;AAChC,cAAQM,GAAA;AAAA,QACN,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT;AACE,gBAAM,MAAM,+BAA+BA,CAAyB,YAAYP,EAAA,OAAO,OAAO,SAAA,CAAU,EAAE;AAAA,MAAA;AAAA,IAEhH,CAAC,GAEKQ,IAAmBN,EAAA;AACzB,aAASO,IAAW;AAClB,YAAMC,IAAwBF,EAAiB;AAC/C,MAAIE,KAAuBV,EAAA,OAAO,eAAeU,CAAqB;AAAA,IACxE;2BAIEC,EAYM,OAAA;AAAA,MAZD,OAAM;AAAA,MAAiD,SAAON;AAAA,IAAA;MACjEO,EAOYC,EAAAC,CAAA,GAAA,MAAAC,EAAA;AAAA,mBALV,MAIM;AAAA,UAJNC,EAIM,OAJNC,GAIM;AAAA,YAHJL,EAAoEC,EAAAK,CAAA,GAAA;AAAA,cAArD,MAAMpB,EAAA;AAAA,cAAM,OAAM;AAAA,YAAA;YACjCkB,EAAqC,QAAA,MAAAG,EAA5BnB,EAAA,OAAO,WAAW,GAAA,CAAA;AAAA,YACPM,EAAA,cAApBc,EAAiDP,EAAAK,CAAA,GAAA;AAAA;cAAlB,MAAMZ,EAAA;AAAA,YAAA;;;;;QAJvBN,EAAA,OAAO;gBAAU;AAAA,gBAAQ,MAAoB;AAAA,YAAjBqB,EAAAF,EAAAnB,EAAA,OAAO,OAAO,GAAA,CAAA;AAAA,UAAA;;;;MAOjDA,EAAA,OAAO,mBAAlBW,EAEM,OAAA;AAAA;iBAF4B;AAAA,QAAJ,KAAIH;AAAA,QAAmB,OAAM;AAAA,QAAkC,WAAYC,GAAQ,CAAA,MAAA,CAAA;AAAA,MAAA;QAC/GG,EAA4BC,EAAAK,CAAA,GAAA,EAAd,MAAK,QAAM;AAAA,MAAA;;;;"}
@@ -20,9 +20,9 @@ const A = /* @__PURE__ */ s({
20
20
  icon: "export",
21
21
  onClick: v(i, ["stop"])
22
22
  }, {
23
- default: C(() => r[0] || (r[0] = [
24
- k(" Export ")
25
- ])),
23
+ default: C(() => [...r[0] || (r[0] = [
24
+ k(" Export ", -1)
25
+ ])]),
26
26
  _: 1
27
27
  }, 8, ["loading"])
28
28
  ], 8, ["to"])) : d("", !0)
@@ -1 +1 @@
1
- {"version":3,"file":"PlAgCsvExporter.vue.js","sources":["../../../src/components/PlAgCsvExporter/PlAgCsvExporter.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { GridApi } from 'ag-grid-enterprise';\nimport { PlBtnGhost, usePlBlockPageTitleTeleportTarget } from '@milaboratories/uikit';\nimport { shallowRef, toRefs } from 'vue';\nimport { exportCsv } from './export-csv';\n\nconst props = defineProps<{\n api: GridApi;\n}>();\nconst { api: gridApi } = toRefs(props);\n\nconst exporting = shallowRef(false);\nconst initiateExport = () => {\n exporting.value = true;\n exportCsv(gridApi.value, () => exporting.value = false);\n};\n\nconst teleportTarget = usePlBlockPageTitleTeleportTarget('PlAgCsvExporter');\n</script>\n\n<template>\n <div>\n <Teleport v-if=\"teleportTarget\" :to=\"teleportTarget\">\n <PlBtnGhost :loading=\"exporting\" icon=\"export\" @click.stop=\"initiateExport\">\n Export\n </PlBtnGhost>\n </Teleport>\n </div>\n</template>\n"],"names":["props","__props","gridApi","toRefs","exporting","shallowRef","initiateExport","exportCsv","teleportTarget","usePlBlockPageTitleTeleportTarget"],"mappings":";;;;;;;;;AAMA,UAAMA,IAAQC,GAGR,EAAE,KAAKC,MAAYC,EAAOH,CAAK,GAE/BI,IAAYC,EAAW,EAAK,GAC5BC,IAAiB,MAAM;AAC3B,MAAAF,EAAU,QAAQ,IAClBG,EAAUL,EAAQ,OAAO,MAAME,EAAU,QAAQ,EAAK;AAAA,IACxD,GAEMI,IAAiBC,EAAkC,iBAAiB;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"PlAgCsvExporter.vue.js","sources":["../../../src/components/PlAgCsvExporter/PlAgCsvExporter.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { GridApi } from 'ag-grid-enterprise';\nimport { PlBtnGhost, usePlBlockPageTitleTeleportTarget } from '@milaboratories/uikit';\nimport { shallowRef, toRefs } from 'vue';\nimport { exportCsv } from './export-csv';\n\nconst props = defineProps<{\n api: GridApi;\n}>();\nconst { api: gridApi } = toRefs(props);\n\nconst exporting = shallowRef(false);\nconst initiateExport = () => {\n exporting.value = true;\n exportCsv(gridApi.value, () => exporting.value = false);\n};\n\nconst teleportTarget = usePlBlockPageTitleTeleportTarget('PlAgCsvExporter');\n</script>\n\n<template>\n <div>\n <Teleport v-if=\"teleportTarget\" :to=\"teleportTarget\">\n <PlBtnGhost :loading=\"exporting\" icon=\"export\" @click.stop=\"initiateExport\">\n Export\n </PlBtnGhost>\n </Teleport>\n </div>\n</template>\n"],"names":["props","__props","gridApi","toRefs","exporting","shallowRef","initiateExport","exportCsv","teleportTarget","usePlBlockPageTitleTeleportTarget","_createElementBlock","_unref","_createBlock","_Teleport","_createVNode","PlBtnGhost","_cache"],"mappings":";;;;;;;;;AAMA,UAAMA,IAAQC,GAGR,EAAE,KAAKC,MAAYC,EAAOH,CAAK,GAE/BI,IAAYC,EAAW,EAAK,GAC5BC,IAAiB,MAAM;AAC3B,MAAAF,EAAU,QAAQ,IAClBG,EAAUL,EAAQ,OAAO,MAAME,EAAU,QAAQ,EAAK;AAAA,IACxD,GAEMI,IAAiBC,EAAkC,iBAAiB;2BAIxEC,EAMM,OAAA,MAAA;AAAA,MALYC,EAAAH,CAAA,UAAhBI,EAIWC,GAAA;AAAA;QAJsB,IAAIF,EAAAH,CAAA;AAAA,MAAA;QACnCM,EAEaH,EAAAI,CAAA,GAAA;AAAA,UAFA,SAASX,EAAA;AAAA,UAAW,MAAK;AAAA,UAAU,WAAYE,GAAc,CAAA,MAAA,CAAA;AAAA,QAAA;qBAAE,MAE5E,CAAA,GAAAU,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA;AAAA,cAF4E,YAE5E,EAAA;AAAA,UAAA;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"PlAgDataTableSheets.vue2.js","sources":["../../../src/components/PlAgDataTable/PlAgDataTableSheets.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport {\n PlDropdownLine,\n} from '@milaboratories/uikit';\nimport type {\n PlDataTableSheet,\n PlDataTableSheetState,\n} from '@platforma-sdk/model';\nimport {\n getAxisId,\n} from '@platforma-sdk/model';\nimport {\n computed,\n watchEffect,\n} from 'vue';\nimport type {\n PlDataTableSheetsSettings,\n PlDataTableSheetNormalized,\n} from './types';\nimport {\n isJsonEqual,\n} from '@milaboratories/helpers';\n\nconst state = defineModel<PlDataTableSheetState[]>({\n default: [],\n});\nconst props = defineProps<{\n settings: Readonly<PlDataTableSheetsSettings>;\n}>();\n\n// Normalize sheets: skip sheets with no options, set default values\nconst sheets = computed<PlDataTableSheetNormalized[]>(() => {\n return props.settings.sheets\n .filter((sheet) => sheet.options.length > 0)\n .map((sheet, i) => {\n const axisId = getAxisId(sheet.axis);\n\n const getDefaultValue = (): string | number => {\n const cachedState = props.settings.cachedState.find((s) => {\n return isJsonEqual(s.axisId, axisId);\n });\n if (cachedState && isValidOption(sheet, cachedState.value)) {\n return cachedState.value;\n }\n if (sheet.defaultValue && isValidOption(sheet, sheet.defaultValue)) {\n return sheet.defaultValue;\n }\n return sheet.options[0].value;\n };\n\n const makePrefix = (): string => {\n return (sheet.axis.annotations?.['pl7.app/label']?.trim()\n ?? `Unlabeled axis ${i}`) + ':';\n };\n\n return {\n axisId,\n prefix: makePrefix(),\n options: sheet.options,\n defaultValue: getDefaultValue(),\n } satisfies PlDataTableSheetNormalized;\n });\n});\n\nfunction isValidOption(sheet: PlDataTableSheet, value: string | number): boolean {\n return sheet.options.some((option) => option.value === value);\n}\n\n// Restore state from settings\nwatchEffect(() => {\n const oldState = [...state.value];\n const newState = sheets.value.map((sheet, i) => makeStateEntry(i, sheet.defaultValue));\n if (!isJsonEqual(oldState, newState)) {\n state.value = newState;\n }\n});\n\nfunction makeStateEntry(i: number, value: string | number): PlDataTableSheetState {\n const axisId = sheets.value[i].axisId;\n return {\n axisId,\n value,\n };\n}\n\nfunction onSheetChanged(i: number, newValue: string | number): void {\n const oldState = [...state.value];\n const stateEntry = makeStateEntry(i, newValue);\n if (!isJsonEqual(oldState[i], stateEntry)) {\n const newState = [...oldState];\n newState[i] = stateEntry;\n state.value = newState;\n }\n}\n</script>\n\n<template>\n <div\n v-if=\"$slots['before'] || sheets.length > 0 || $slots['after']\"\n :class=\"$style.container\"\n >\n <slot name=\"before\" />\n <template v-for=\"(sheet, i) in sheets\" :key=\"i\">\n <!-- For some reason state[i] is undefined when the sheet initially loads, so v-if to suppress the error -->\n <PlDropdownLine\n v-if=\"state[i]\"\n :model-value=\"state[i].value\"\n :options=\"sheet.options\"\n :prefix=\"sheet.prefix\"\n @update:model-value=\"(newValue: string | number) => onSheetChanged(i, newValue)\"\n />\n </template>\n <slot name=\"after\" />\n </div>\n</template>\n\n<style lang=\"css\" module>\n.container {\n display: flex;\n flex-direction: row;\n gap: 12px;\n flex-wrap: wrap;\n z-index: 3;\n}\n</style>\n"],"names":["state","_useModel","props","__props","sheets","computed","sheet","i","axisId","getAxisId","getDefaultValue","cachedState","s","isJsonEqual","isValidOption","_b","_a","value","option","watchEffect","oldState","newState","makeStateEntry","onSheetChanged","newValue","stateEntry"],"mappings":";;;;;;;;;;;;;;;;AAuBA,UAAMA,IAAQC,iBAEb,GACKC,IAAQC,GAKRC,IAASC,EAAuC,MAC7CH,EAAM,SAAS,OACnB,OAAO,CAACI,MAAUA,EAAM,QAAQ,SAAS,CAAC,EAC1C,IAAI,CAACA,GAAOC,MAAM;AACjB,YAAMC,IAASC,EAAUH,EAAM,IAAI,GAE7BI,IAAkB,MAAuB;AAC7C,cAAMC,IAAcT,EAAM,SAAS,YAAY,KAAK,CAACU,MAC5CC,EAAYD,EAAE,QAAQJ,CAAM,CACpC;AACD,eAAIG,KAAeG,EAAcR,GAAOK,EAAY,KAAK,IAChDA,EAAY,QAEjBL,EAAM,gBAAgBQ,EAAcR,GAAOA,EAAM,YAAY,IACxDA,EAAM,eAERA,EAAM,QAAQ,CAAC,EAAE;AAAA,MAC1B;AAOA,aAAO;AAAA,QACL,QAAAE;AAAA,QACA,SAPiB,MAAc;;AAC/B,oBAAQO,KAAAC,IAAAV,EAAM,KAAK,gBAAX,gBAAAU,EAAyB,qBAAzB,gBAAAD,EAA2C,WAC9C,kBAAkBR,CAAC,MAAM;AAAA,QAChC,GAIU;AAAA,QACR,SAASD,EAAM;AAAA,QACf,cAAcI,EAAA;AAAA,MAAgB;AAAA,IAElC,CAAC,CACJ;AAED,aAASI,EAAcR,GAAyBW,GAAiC;AAC/E,aAAOX,EAAM,QAAQ,KAAK,CAACY,MAAWA,EAAO,UAAUD,CAAK;AAAA,IAC9D;AAGA,IAAAE,EAAY,MAAM;AAChB,YAAMC,IAAW,CAAC,GAAGpB,EAAM,KAAK,GAC1BqB,IAAWjB,EAAO,MAAM,IAAI,CAACE,GAAOC,MAAMe,EAAef,GAAGD,EAAM,YAAY,CAAC;AACrF,MAAKO,EAAYO,GAAUC,CAAQ,MACjCrB,EAAM,QAAQqB;AAAA,IAElB,CAAC;AAED,aAASC,EAAef,GAAWU,GAA+C;AAEhF,aAAO;AAAA,QACL,QAFab,EAAO,MAAMG,CAAC,EAAE;AAAA,QAG7B,OAAAU;AAAA,MAAA;AAAA,IAEJ;AAEA,aAASM,EAAehB,GAAWiB,GAAiC;AAClE,YAAMJ,IAAW,CAAC,GAAGpB,EAAM,KAAK,GAC1ByB,IAAaH,EAAef,GAAGiB,CAAQ;AAC7C,UAAI,CAACX,EAAYO,EAASb,CAAC,GAAGkB,CAAU,GAAG;AACzC,cAAMJ,IAAW,CAAC,GAAGD,CAAQ;AAC7B,QAAAC,EAASd,CAAC,IAAIkB,GACdzB,EAAM,QAAQqB;AAAA,MAChB;AAAA,IACF;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"PlAgDataTableSheets.vue2.js","sources":["../../../src/components/PlAgDataTable/PlAgDataTableSheets.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport {\n PlDropdownLine,\n} from '@milaboratories/uikit';\nimport type {\n PlDataTableSheet,\n PlDataTableSheetState,\n} from '@platforma-sdk/model';\nimport {\n getAxisId,\n} from '@platforma-sdk/model';\nimport {\n computed,\n watchEffect,\n} from 'vue';\nimport type {\n PlDataTableSheetsSettings,\n PlDataTableSheetNormalized,\n} from './types';\nimport {\n isJsonEqual,\n} from '@milaboratories/helpers';\n\nconst state = defineModel<PlDataTableSheetState[]>({\n default: [],\n});\nconst props = defineProps<{\n settings: Readonly<PlDataTableSheetsSettings>;\n}>();\n\n// Normalize sheets: skip sheets with no options, set default values\nconst sheets = computed<PlDataTableSheetNormalized[]>(() => {\n return props.settings.sheets\n .filter((sheet) => sheet.options.length > 0)\n .map((sheet, i) => {\n const axisId = getAxisId(sheet.axis);\n\n const getDefaultValue = (): string | number => {\n const cachedState = props.settings.cachedState.find((s) => {\n return isJsonEqual(s.axisId, axisId);\n });\n if (cachedState && isValidOption(sheet, cachedState.value)) {\n return cachedState.value;\n }\n if (sheet.defaultValue && isValidOption(sheet, sheet.defaultValue)) {\n return sheet.defaultValue;\n }\n return sheet.options[0].value;\n };\n\n const makePrefix = (): string => {\n return (sheet.axis.annotations?.['pl7.app/label']?.trim()\n ?? `Unlabeled axis ${i}`) + ':';\n };\n\n return {\n axisId,\n prefix: makePrefix(),\n options: sheet.options,\n defaultValue: getDefaultValue(),\n } satisfies PlDataTableSheetNormalized;\n });\n});\n\nfunction isValidOption(sheet: PlDataTableSheet, value: string | number): boolean {\n return sheet.options.some((option) => option.value === value);\n}\n\n// Restore state from settings\nwatchEffect(() => {\n const oldState = [...state.value];\n const newState = sheets.value.map((sheet, i) => makeStateEntry(i, sheet.defaultValue));\n if (!isJsonEqual(oldState, newState)) {\n state.value = newState;\n }\n});\n\nfunction makeStateEntry(i: number, value: string | number): PlDataTableSheetState {\n const axisId = sheets.value[i].axisId;\n return {\n axisId,\n value,\n };\n}\n\nfunction onSheetChanged(i: number, newValue: string | number): void {\n const oldState = [...state.value];\n const stateEntry = makeStateEntry(i, newValue);\n if (!isJsonEqual(oldState[i], stateEntry)) {\n const newState = [...oldState];\n newState[i] = stateEntry;\n state.value = newState;\n }\n}\n</script>\n\n<template>\n <div\n v-if=\"$slots['before'] || sheets.length > 0 || $slots['after']\"\n :class=\"$style.container\"\n >\n <slot name=\"before\" />\n <template v-for=\"(sheet, i) in sheets\" :key=\"i\">\n <!-- For some reason state[i] is undefined when the sheet initially loads, so v-if to suppress the error -->\n <PlDropdownLine\n v-if=\"state[i]\"\n :model-value=\"state[i].value\"\n :options=\"sheet.options\"\n :prefix=\"sheet.prefix\"\n @update:model-value=\"(newValue: string | number) => onSheetChanged(i, newValue)\"\n />\n </template>\n <slot name=\"after\" />\n </div>\n</template>\n\n<style lang=\"css\" module>\n.container {\n display: flex;\n flex-direction: row;\n gap: 12px;\n flex-wrap: wrap;\n z-index: 3;\n}\n</style>\n"],"names":["state","_useModel","props","__props","sheets","computed","sheet","i","axisId","getAxisId","getDefaultValue","cachedState","s","isJsonEqual","isValidOption","_b","_a","value","option","watchEffect","oldState","newState","makeStateEntry","onSheetChanged","newValue","stateEntry","$slots","_createElementBlock","_normalizeClass","$style","_renderSlot","_ctx","_openBlock","_Fragment","_renderList","_createBlock","_unref","PlDropdownLine"],"mappings":";;;;;;;;;;;;;;;;AAuBA,UAAMA,IAAQC,iBAEb,GACKC,IAAQC,GAKRC,IAASC,EAAuC,MAC7CH,EAAM,SAAS,OACnB,OAAO,CAACI,MAAUA,EAAM,QAAQ,SAAS,CAAC,EAC1C,IAAI,CAACA,GAAOC,MAAM;AACjB,YAAMC,IAASC,EAAUH,EAAM,IAAI,GAE7BI,IAAkB,MAAuB;AAC7C,cAAMC,IAAcT,EAAM,SAAS,YAAY,KAAK,CAACU,MAC5CC,EAAYD,EAAE,QAAQJ,CAAM,CACpC;AACD,eAAIG,KAAeG,EAAcR,GAAOK,EAAY,KAAK,IAChDA,EAAY,QAEjBL,EAAM,gBAAgBQ,EAAcR,GAAOA,EAAM,YAAY,IACxDA,EAAM,eAERA,EAAM,QAAQ,CAAC,EAAE;AAAA,MAC1B;AAOA,aAAO;AAAA,QACL,QAAAE;AAAA,QACA,SAPiB,MAAc;;AAC/B,oBAAQO,KAAAC,IAAAV,EAAM,KAAK,gBAAX,gBAAAU,EAAyB,qBAAzB,gBAAAD,EAA2C,WAC9C,kBAAkBR,CAAC,MAAM;AAAA,QAChC,GAIU;AAAA,QACR,SAASD,EAAM;AAAA,QACf,cAAcI,EAAA;AAAA,MAAgB;AAAA,IAElC,CAAC,CACJ;AAED,aAASI,EAAcR,GAAyBW,GAAiC;AAC/E,aAAOX,EAAM,QAAQ,KAAK,CAACY,MAAWA,EAAO,UAAUD,CAAK;AAAA,IAC9D;AAGA,IAAAE,EAAY,MAAM;AAChB,YAAMC,IAAW,CAAC,GAAGpB,EAAM,KAAK,GAC1BqB,IAAWjB,EAAO,MAAM,IAAI,CAACE,GAAOC,MAAMe,EAAef,GAAGD,EAAM,YAAY,CAAC;AACrF,MAAKO,EAAYO,GAAUC,CAAQ,MACjCrB,EAAM,QAAQqB;AAAA,IAElB,CAAC;AAED,aAASC,EAAef,GAAWU,GAA+C;AAEhF,aAAO;AAAA,QACL,QAFab,EAAO,MAAMG,CAAC,EAAE;AAAA,QAG7B,OAAAU;AAAA,MAAA;AAAA,IAEJ;AAEA,aAASM,EAAehB,GAAWiB,GAAiC;AAClE,YAAMJ,IAAW,CAAC,GAAGpB,EAAM,KAAK,GAC1ByB,IAAaH,EAAef,GAAGiB,CAAQ;AAC7C,UAAI,CAACX,EAAYO,EAASb,CAAC,GAAGkB,CAAU,GAAG;AACzC,cAAMJ,IAAW,CAAC,GAAGD,CAAQ;AAC7B,QAAAC,EAASd,CAAC,IAAIkB,GACdzB,EAAM,QAAQqB;AAAA,MAChB;AAAA,IACF;qBAKUK,EAAAA,OAAM,UAActB,EAAA,MAAO,cAAcsB,EAAAA,OAAM,cADvDC,EAgBM,OAAA;AAAA;MAdH,OAAKC,EAAEC,EAAAA,OAAO,SAAS;AAAA,IAAA;MAExBC,EAAsBC,EAAA,QAAA,QAAA;AAAA,OACtBC,EAAA,EAAA,GAAAL,EASWM,GAAA,MAAAC,EAToB9B,EAAA,OAAM,CAAnBE,GAAOC,wBAAoBA,KAAC;AAAA,QAGpCP,EAAA,MAAMO,CAAC,UADf4B,EAMEC,EAAAC,CAAA,GAAA;AAAA;UAJC,eAAarC,EAAA,MAAMO,CAAC,EAAE;AAAA,UACtB,SAASD,EAAM;AAAA,UACf,QAAQA,EAAM;AAAA,UACd,wBAAqBkB,MAA8BD,EAAehB,GAAGiB,CAAQ;AAAA,QAAA;;MAGlFM,EAAqBC,EAAA,QAAA,OAAA;AAAA,IAAA;;;"}
@@ -1,5 +1,5 @@
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 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";
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 x, effectScope as ce, createElementBlock as me, openBlock as b, normalizeClass as Q, createBlock as G, createCommentVNode as z, createVNode as fe, unref as P, isRef as W, withCtx as j, renderSlot as X } from "vue";
3
3
  import { isJsonEqual as i } from "../../lib/util/helpers/dist/objects.js";
4
4
  import { promiseTimeout as ve } from "../../lib/util/helpers/dist/functions.js";
5
5
  import { parseJson as Y, getAxisId as Z, matchAxisId as _, canonicalizeJson as ee, createPlSelectionModel as $, getRawPlatformaInstance as pe } from "@platforma-sdk/model";
@@ -10,10 +10,10 @@ import Ce from "../PlAgGridColumnManager/PlAgGridColumnManager.vue.js";
10
10
  import he from "../PlTableFilters/PlTableFiltersV2.vue.js";
11
11
  import we from "./PlAgDataTableSheets.vue.js";
12
12
  import Re from "./PlAgOverlayLoading.vue.js";
13
- import De from "./PlAgOverlayNoRows.vue.js";
13
+ import xe from "./PlAgOverlayNoRows.vue.js";
14
14
 
15
- import Oe from "./PlAgRowCount.vue.js";
16
- import { DeferredCircular as xe, ensureNodeVisible as Ie } from "./sources/focus-row.js";
15
+ import De from "./PlAgRowCount.vue.js";
16
+ import { DeferredCircular as Oe, ensureNodeVisible as Ie } from "./sources/focus-row.js";
17
17
  import { PlAgDataTableRowNumberColId as te, autoSizeRowNumberColumn as be } from "./sources/row-number.js";
18
18
  import { calculateGridOptions as Pe } from "./sources/table-source-v2.js";
19
19
  import { useTableState as ke } from "./sources/table-state-v2.js";
@@ -40,12 +40,12 @@ const Xe = /* @__PURE__ */ ue({
40
40
  selectionModifiers: {}
41
41
  }),
42
42
  emits: /* @__PURE__ */ U(["rowDoubleClicked", "cellButtonClicked", "newDataRendered"], ["update:modelValue", "update:selection"]),
43
- setup(G, { expose: le, emit: oe }) {
44
- 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), ne = M(() => {
43
+ setup(C, { expose: le, emit: oe }) {
44
+ const ae = q(C, "modelValue"), o = q(C, "selection"), d = C, { settings: D } = de(d), B = oe, { gridState: O, sheetsState: k, filtersState: T } = ke(ae, D), ne = M(() => {
45
45
  const e = { ...D.value };
46
46
  return e.sourceId !== null ? {
47
47
  sheets: e.sheets ?? [],
48
- cachedState: [...P.value]
48
+ cachedState: [...k.value]
49
49
  } : {
50
50
  sheets: [],
51
51
  cachedState: []
@@ -55,13 +55,13 @@ const Xe = /* @__PURE__ */ ue({
55
55
  return e.sourceId !== null && t.length > 0 ? {
56
56
  columns: t,
57
57
  config: (a) => e.filtersConfig({ sourceId: e.sourceId, column: a }),
58
- cachedState: [...k.value]
58
+ cachedState: [...T.value]
59
59
  } : {
60
60
  columns: [],
61
61
  config: () => ({}),
62
62
  cachedState: []
63
63
  };
64
- }), c = H(null), x = new xe(), r = H({
64
+ }), c = H(null), I = new Oe(), r = H({
65
65
  animateRows: !1,
66
66
  suppressColumnMoveAnimation: !0,
67
67
  cellSelection: !o.value,
@@ -110,7 +110,7 @@ const Xe = /* @__PURE__ */ ue({
110
110
  notReadyText: d.notReadyText
111
111
  },
112
112
  loadingOverlayComponent: Re,
113
- noRowsOverlayComponent: De,
113
+ noRowsOverlayComponent: xe,
114
114
  noRowsOverlayComponentParams: {
115
115
  text: d.noRowsText
116
116
  },
@@ -121,7 +121,7 @@ const Xe = /* @__PURE__ */ ue({
121
121
  },
122
122
  statusBar: {
123
123
  statusPanels: [
124
- { statusPanel: Oe, align: "left" }
124
+ { statusPanel: De, align: "left" }
125
125
  ]
126
126
  },
127
127
  onGridReady: (e) => {
@@ -172,7 +172,7 @@ const Xe = /* @__PURE__ */ ue({
172
172
  };
173
173
  }
174
174
  const E = F(0);
175
- R(
175
+ x(
176
176
  () => [c.value, O.value],
177
177
  ([e, t]) => {
178
178
  if (!e || e.isDestroyed()) return;
@@ -181,7 +181,7 @@ const Xe = /* @__PURE__ */ ue({
181
181
  }
182
182
  );
183
183
  let y = null;
184
- R(
184
+ x(
185
185
  () => [c.value, r.value],
186
186
  ([e, t]) => {
187
187
  !e || e.isDestroyed() || (t.loading && (y != null && y.loading) && !i(
@@ -192,7 +192,7 @@ const Xe = /* @__PURE__ */ ue({
192
192
  { immediate: !0 }
193
193
  );
194
194
  const re = M(() => d.cellRendererSelector ?? null);
195
- R(
195
+ x(
196
196
  () => [c.value, re.value],
197
197
  ([e, t]) => {
198
198
  !e || e.isDestroyed() || e.setGridOption("defaultColDef", {
@@ -202,21 +202,21 @@ const Xe = /* @__PURE__ */ ue({
202
202
  }
203
203
  ), le({
204
204
  focusRow: async (e) => {
205
- const t = await x.promise;
205
+ const t = await I.promise;
206
206
  return t.isDestroyed() ? !1 : Ie(t, (l) => {
207
207
  var a;
208
208
  return i((a = l.data) == null ? void 0 : a.axesKey, e);
209
209
  });
210
210
  },
211
211
  updateSelection: async ({ axesSpec: e, selectedKeys: t }) => {
212
- var h, g;
213
- const l = await x.promise;
212
+ var w, g;
213
+ const l = await I.promise;
214
214
  if (l.isDestroyed()) return !1;
215
- const a = (h = o.value) == null ? void 0 : h.axesSpec;
215
+ const a = (w = o.value) == null ? void 0 : w.axesSpec;
216
216
  if (!a || a.length !== e.length) return !1;
217
217
  const n = e.map((p) => {
218
218
  const S = Z(p);
219
- return a.findIndex((w) => _(w, S));
219
+ return a.findIndex((R) => _(R, S));
220
220
  }), u = new Set(n);
221
221
  if (u.has(-1) || u.size !== e.length) return !1;
222
222
  const s = t.map((p) => ee(n.map((S) => p[S]))), m = ((g = l.getServerSideSelectionState()) == null ? void 0 : g.toggledNodes) ?? [];
@@ -225,10 +225,10 @@ const Xe = /* @__PURE__ */ ue({
225
225
  selectAll: !1,
226
226
  toggledNodes: s
227
227
  });
228
- const p = ce(), { resolve: S, promise: w } = Promise.withResolvers();
229
- p.run(() => R(o, S, { once: !0 }));
228
+ const p = ce(), { resolve: S, promise: R } = Promise.withResolvers();
229
+ p.run(() => x(o, S, { once: !0 }));
230
230
  try {
231
- await ve(w, 500);
231
+ await ve(R, 500);
232
232
  } catch {
233
233
  return !1;
234
234
  } finally {
@@ -256,15 +256,15 @@ const Xe = /* @__PURE__ */ ue({
256
256
  );
257
257
  const L = $();
258
258
  let v = null;
259
- const C = F(0);
260
- return R(
259
+ const h = F(0);
260
+ return x(
261
261
  () => [c.value, D.value],
262
262
  ([e, t]) => {
263
263
  var l, a;
264
264
  if (!(!e || e.isDestroyed()) && !i(t, v)) {
265
- ++C.value;
265
+ ++h.value;
266
266
  try {
267
- if (e.hideOverlay(), x.reset(), !t.sourceId) {
267
+ if (e.hideOverlay(), I.reset(), !t.sourceId) {
268
268
  e.updateGridOptions({
269
269
  loading: !0,
270
270
  loadingOverlayComponentParams: {
@@ -294,19 +294,19 @@ const Xe = /* @__PURE__ */ ue({
294
294
  const s = e.getServerSideGroupLevelState(), m = !n && s.length > 0 ? s[0].rowCount : 1;
295
295
  return e.updateGridOptions({
296
296
  serverSideDatasource: {
297
- getRows: (h) => {
298
- h.success({ rowData: [], rowCount: m });
297
+ getRows: (w) => {
298
+ w.success({ rowData: [], rowCount: m });
299
299
  }
300
300
  }
301
301
  });
302
302
  }
303
- const u = C.value;
303
+ const u = h.value;
304
304
  Pe({
305
- generation: C,
305
+ generation: h,
306
306
  pfDriver: pe().pFrameDriver,
307
307
  model: t.model,
308
308
  sheets: t.sheets ?? [],
309
- dataRenderedTracker: x,
309
+ dataRenderedTracker: I,
310
310
  hiddenColIds: (a = O.value.columnVisibility) == null ? void 0 : a.hiddenColIds,
311
311
  cellButtonAxisParams: {
312
312
  showCellButtonForAxisId: d.showCellButtonForAxisId,
@@ -314,10 +314,10 @@ const Xe = /* @__PURE__ */ ue({
314
314
  trigger: (s) => B("cellButtonClicked", s)
315
315
  }
316
316
  }).then((s) => {
317
- if (e.isDestroyed() || u !== C.value) return;
318
- const { axesSpec: m, ...h } = s;
317
+ if (e.isDestroyed() || u !== h.value) return;
318
+ const { axesSpec: m, ...w } = s;
319
319
  if (e.updateGridOptions({
320
- ...h
320
+ ...w
321
321
  }), o.value) {
322
322
  const { axesSpec: g, selectedKeys: p } = o.value;
323
323
  if (!i(g, m)) {
@@ -328,8 +328,8 @@ const Xe = /* @__PURE__ */ ue({
328
328
  toggledNodes: []
329
329
  });
330
330
  }
331
- const S = g.map(Z).map((f) => m.findIndex((K) => _(K, f))), w = new Set(S);
332
- if (w.has(-1) || w.size !== m.length) {
331
+ const S = g.map(Z).map((f) => m.findIndex((K) => _(K, f))), R = new Set(S);
332
+ if (R.has(-1) || R.size !== m.length) {
333
333
  const f = { axesSpec: m, selectedKeys: [] };
334
334
  return i(o.value, f) || (o.value = f), e.setServerSideSelectionState({
335
335
  selectAll: !1,
@@ -344,12 +344,12 @@ const Xe = /* @__PURE__ */ ue({
344
344
  }
345
345
  }
346
346
  }).catch((s) => {
347
- e.isDestroyed() || u !== C.value || console.trace(s);
347
+ e.isDestroyed() || u !== h.value || console.trace(s);
348
348
  }).finally(() => {
349
- e.isDestroyed() || u !== C.value || e.updateGridOptions({
349
+ e.isDestroyed() || u !== h.value || e.updateGridOptions({
350
350
  loading: !1
351
351
  });
352
- }), x.promise.then(() => B("newDataRendered"));
352
+ }), I.promise.then(() => B("newDataRendered"));
353
353
  } catch (n) {
354
354
  console.trace(n);
355
355
  } finally {
@@ -357,7 +357,7 @@ const Xe = /* @__PURE__ */ ue({
357
357
  }
358
358
  }
359
359
  }
360
- ), R(
360
+ ), x(
361
361
  () => ({
362
362
  gridApi: c.value,
363
363
  loadingText: d.loadingText,
@@ -377,26 +377,26 @@ const Xe = /* @__PURE__ */ ue({
377
377
  }
378
378
  });
379
379
  }
380
- ), (e, t) => (I(), me("div", {
380
+ ), (e, t) => (b(), me("div", {
381
381
  class: Q(e.$style.container)
382
382
  }, [
383
- c.value && !e.disableColumnsPanel ? (I(), T(b(Ce), {
383
+ c.value && !C.disableColumnsPanel ? (b(), G(P(Ce), {
384
384
  key: 0,
385
385
  api: c.value
386
386
  }, null, 8, ["api"])) : z("", !0),
387
- e.disableFiltersPanel ? z("", !0) : (I(), T(he, {
387
+ C.disableFiltersPanel ? z("", !0) : (b(), G(he, {
388
388
  key: 1,
389
- modelValue: b(k),
390
- "onUpdate:modelValue": t[0] || (t[0] = (l) => W(k) ? k.value = l : null),
389
+ modelValue: P(T),
390
+ "onUpdate:modelValue": t[0] || (t[0] = (l) => W(T) ? T.value = l : null),
391
391
  settings: se.value
392
392
  }, null, 8, ["modelValue", "settings"])),
393
- c.value && e.showExportButton ? (I(), T(ge, {
393
+ c.value && C.showExportButton ? (b(), G(ge, {
394
394
  key: 2,
395
395
  api: c.value
396
396
  }, null, 8, ["api"])) : z("", !0),
397
397
  fe(we, {
398
- modelValue: b(P),
399
- "onUpdate:modelValue": t[1] || (t[1] = (l) => W(P) ? P.value = l : null),
398
+ modelValue: P(k),
399
+ "onUpdate:modelValue": t[1] || (t[1] = (l) => W(k) ? k.value = l : null),
400
400
  settings: ne.value
401
401
  }, {
402
402
  before: j(() => [
@@ -407,9 +407,9 @@ const Xe = /* @__PURE__ */ ue({
407
407
  ]),
408
408
  _: 3
409
409
  }, 8, ["modelValue", "settings"]),
410
- (I(), T(b(Se), {
410
+ (b(), G(P(Se), {
411
411
  key: E.value,
412
- theme: b(ye),
412
+ theme: P(ye),
413
413
  class: Q(e.$style.grid),
414
414
  "grid-options": r.value
415
415
  }, null, 8, ["theme", "class", "grid-options"]))