@platforma-sdk/ui-vue 1.45.36 → 1.45.42
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +45 -45
- package/.turbo/turbo-type-check.log +1 -1
- package/CHANGELOG.md +16 -0
- package/dist/components/BlockLayout.vue2.js +3 -3
- package/dist/components/BlockLayout.vue2.js.map +1 -1
- package/dist/components/BlockLoader.vue.js.map +1 -1
- package/dist/components/LoaderPage.vue.js +2 -2
- package/dist/components/LoaderPage.vue.js.map +1 -1
- package/dist/components/NotFound.vue.js +3 -3
- package/dist/components/NotFound.vue.js.map +1 -1
- package/dist/components/PlAdvancedFilter/OperandButton.vue2.js.map +1 -1
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue2.js +73 -73
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue2.js.map +1 -1
- package/dist/components/PlAdvancedFilter/SingleFilter.vue2.js +100 -100
- package/dist/components/PlAdvancedFilter/SingleFilter.vue2.js.map +1 -1
- package/dist/components/PlAgCellFile/PlAgCellFile.vue.js.map +1 -1
- package/dist/components/PlAgCellProgress/PlAgCellProgress.vue.js.map +1 -1
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue.js +6 -6
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue.js.map +1 -1
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue.js.map +1 -1
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue.js.map +1 -1
- package/dist/components/PlAgColumnHeader/PlAgColumnHeader.vue.js +22 -22
- package/dist/components/PlAgColumnHeader/PlAgColumnHeader.vue.js.map +1 -1
- package/dist/components/PlAgCsvExporter/PlAgCsvExporter.vue.js +3 -3
- package/dist/components/PlAgCsvExporter/PlAgCsvExporter.vue.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue2.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue2.js +50 -50
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue2.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgOverlayLoading.vue.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.vue.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgRowCount.vue.js.map +1 -1
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js +35 -35
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js.map +1 -1
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue.js +15 -15
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue.js.map +1 -1
- package/dist/components/PlAgRowNumHeader.vue.js +13 -13
- package/dist/components/PlAgRowNumHeader.vue.js.map +1 -1
- package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue.js +16 -16
- package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue.js.map +1 -1
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue2.js +6 -6
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue2.js.map +1 -1
- package/dist/components/PlAnnotations/components/DynamicForm.vue2.js +57 -57
- package/dist/components/PlAnnotations/components/DynamicForm.vue2.js.map +1 -1
- package/dist/components/PlAnnotations/components/FilterSidebar.vue2.js +6 -6
- package/dist/components/PlAnnotations/components/FilterSidebar.vue2.js.map +1 -1
- package/dist/components/PlAnnotations/components/PlAnnotations.vue2.js.map +1 -1
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.vue2.js.map +1 -1
- package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.vue.js +7 -7
- package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.vue.js.map +1 -1
- package/dist/components/PlBtnExportArchive/Item.vue2.js +23 -23
- package/dist/components/PlBtnExportArchive/Item.vue2.js.map +1 -1
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue2.js.map +1 -1
- package/dist/components/PlBtnExportArchive/Summary.vue2.js +22 -22
- package/dist/components/PlBtnExportArchive/Summary.vue2.js.map +1 -1
- package/dist/components/PlTableFilters/PlTableAddFilterV2.vue.js +9 -9
- package/dist/components/PlTableFilters/PlTableAddFilterV2.vue.js.map +1 -1
- package/dist/components/PlTableFilters/PlTableFilterEntryV2.vue.js +3 -3
- package/dist/components/PlTableFilters/PlTableFilterEntryV2.vue.js.map +1 -1
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue2.js +9 -9
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue2.js.map +1 -1
- package/dist/components/ValueOrErrorsComponent.vue.js.map +1 -1
- package/dist/plugins/Monetization/EndOfPeriod.vue2.js +9 -9
- package/dist/plugins/Monetization/EndOfPeriod.vue2.js.map +1 -1
- package/dist/plugins/Monetization/LimitCard.vue2.js +40 -40
- package/dist/plugins/Monetization/LimitCard.vue2.js.map +1 -1
- package/dist/plugins/Monetization/MonetizationSidebar.vue.js +3 -3
- package/dist/plugins/Monetization/MonetizationSidebar.vue.js.map +1 -1
- package/dist/plugins/Monetization/RunStatus.vue2.js +12 -12
- package/dist/plugins/Monetization/RunStatus.vue2.js.map +1 -1
- package/dist/plugins/Monetization/UserCabinetCard.vue2.js +22 -22
- package/dist/plugins/Monetization/UserCabinetCard.vue2.js.map +1 -1
- package/package.json +8 -8
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PlAgCellStatusTag.vue.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PlAgCellStatusTag.vue.js","sources":["../../../src/components/PlAgCellStatusTag/PlAgCellStatusTag.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport type { ICellRendererParams } from 'ag-grid-enterprise';\nimport { PlStatusTag } from '@milaboratories/uikit';\nimport type { PlStatusTagType } from '@milaboratories/uikit';\n\ndefineProps<{ params?: ICellRendererParams & { type: PlStatusTagType } }>();\n</script>\n\n<template>\n <div class=\"pl-ag-cell-status-tag d-flex align-center\">\n <PlStatusTag :type=\"params?.type\"/>\n </div>\n</template>\n\n<style lang=\"scss\">\n.pl-ag-cell-status-tag{\n height: 100%;\n padding: 0 12px;\n}\n</style>\n"],"names":["_openBlock","_createElementBlock","_hoisted_1","_createVNode","_unref","PlStatusTag","_a","__props"],"mappings":";;;;;;;;;;AASE,aAAAA,EAAA,GAAAC,EAEM,OAFNC,GAEM;AAAA,QADJC,EAAmCC,EAAAC,CAAA,GAAA;AAAA,UAArB,OAAMC,IAAAC,EAAA,WAAA,gBAAAD,EAAQ;AAAA,QAAA;;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PlAgChartHistogramCell.vue.js","sources":["../../../src/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { ICellRendererParams } from 'ag-grid-enterprise';\nimport {\n type InferComponentProps,\n PlChartHistogram,\n} from '@milaboratories/uikit';\nimport { computed, ref } from 'vue';\nimport { useElementBounding } from '@vueuse/core';\n\ntype PlChartHistogramSettings = InferComponentProps<typeof PlChartHistogram>['settings'];\n\nconst props = defineProps<{\n params: ICellRendererParams<unknown, PlChartHistogramSettings | undefined>;\n}>();\n\nconst root = ref<HTMLElement>();\n\nconst { width } = useElementBounding(root);\n\nconst settings = computed<PlChartHistogramSettings | undefined>(() => {\n if (!props.params.value) {\n return undefined;\n }\n\n if (!width.value) {\n return undefined;\n }\n\n return { ...props.params.value, compact: true, totalHeight: 24, totalWidth: width.value };\n});\n</script>\n\n<template>\n <div ref=\"root\" class=\"pl-ag-chart-histogram-cell\">\n <PlChartHistogram v-if=\"settings\" :settings=\"settings\" />\n <div v-else class=\"pl-ag-chart-histogram-cell__not-ready \">Not ready</div>\n </div>\n</template>\n\n<style>\n.pl-ag-chart-histogram-cell {\n height: 100%;\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.pl-ag-chart-histogram-cell__not-ready {\n color: var(--txt-03) !important;\n}\n</style>\n"],"names":["props","__props","root","ref","width","useElementBounding","settings","computed"],"mappings":";;;;;;;;;;;;AAWA,UAAMA,IAAQC,GAIRC,IAAOC,EAAA,GAEP,EAAE,OAAAC,EAAA,IAAUC,EAAmBH,CAAI,GAEnCI,IAAWC,EAA+C,MAAM;AACpE,UAAKP,EAAM,OAAO,SAIbI,EAAM;AAIX,eAAO,EAAE,GAAGJ,EAAM,OAAO,OAAO,SAAS,IAAM,aAAa,IAAI,YAAYI,EAAM,MAAA;AAAA,IACpF,CAAC
|
|
1
|
+
{"version":3,"file":"PlAgChartHistogramCell.vue.js","sources":["../../../src/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { ICellRendererParams } from 'ag-grid-enterprise';\nimport {\n type InferComponentProps,\n PlChartHistogram,\n} from '@milaboratories/uikit';\nimport { computed, ref } from 'vue';\nimport { useElementBounding } from '@vueuse/core';\n\ntype PlChartHistogramSettings = InferComponentProps<typeof PlChartHistogram>['settings'];\n\nconst props = defineProps<{\n params: ICellRendererParams<unknown, PlChartHistogramSettings | undefined>;\n}>();\n\nconst root = ref<HTMLElement>();\n\nconst { width } = useElementBounding(root);\n\nconst settings = computed<PlChartHistogramSettings | undefined>(() => {\n if (!props.params.value) {\n return undefined;\n }\n\n if (!width.value) {\n return undefined;\n }\n\n return { ...props.params.value, compact: true, totalHeight: 24, totalWidth: width.value };\n});\n</script>\n\n<template>\n <div ref=\"root\" class=\"pl-ag-chart-histogram-cell\">\n <PlChartHistogram v-if=\"settings\" :settings=\"settings\" />\n <div v-else class=\"pl-ag-chart-histogram-cell__not-ready \">Not ready</div>\n </div>\n</template>\n\n<style>\n.pl-ag-chart-histogram-cell {\n height: 100%;\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.pl-ag-chart-histogram-cell__not-ready {\n color: var(--txt-03) !important;\n}\n</style>\n"],"names":["props","__props","root","ref","width","useElementBounding","settings","computed","_createElementBlock","_createBlock","_unref","PlChartHistogram","_hoisted_1"],"mappings":";;;;;;;;;;;;AAWA,UAAMA,IAAQC,GAIRC,IAAOC,EAAA,GAEP,EAAE,OAAAC,EAAA,IAAUC,EAAmBH,CAAI,GAEnCI,IAAWC,EAA+C,MAAM;AACpE,UAAKP,EAAM,OAAO,SAIbI,EAAM;AAIX,eAAO,EAAE,GAAGJ,EAAM,OAAO,OAAO,SAAS,IAAM,aAAa,IAAI,YAAYI,EAAM,MAAA;AAAA,IACpF,CAAC;2BAICI,EAGM,OAAA;AAAA,eAHG;AAAA,MAAJ,KAAIN;AAAA,MAAO,OAAM;AAAA,IAAA;MACII,EAAA,cAAxBG,EAAyDC,EAAAC,CAAA,GAAA;AAAA;QAAtB,UAAUL,EAAA;AAAA,MAAA,mCAC7CE,EAA0E,OAA1EI,GAA2D,WAAS;AAAA,IAAA;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PlAgChartStackedBarCell.vue.js","sources":["../../../src/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { ICellRendererParams } from 'ag-grid-enterprise';\nimport type {\n PlChartStackedBarSettings,\n} from '@milaboratories/uikit';\nimport {\n PlChartStackedBarCompact,\n} from '@milaboratories/uikit';\nimport { computed } from 'vue';\n\nconst props = defineProps<{\n params: ICellRendererParams<unknown, PlChartStackedBarSettings | undefined>;\n}>();\n\nconst settings = computed(() => props.params.value || undefined);\n</script>\n\n<template>\n <div class=\"pl-ag-chart-stacked-bar-cell\">\n <PlChartStackedBarCompact v-if=\"settings\" :settings=\"settings\" />\n <div v-else class=\"pl-ag-chart-stacked-bar-cell__not-ready\">Not ready</div>\n </div>\n</template>\n\n<style>\n.pl-ag-chart-stacked-bar-cell {\n height: 100%;\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.pl-ag-chart-stacked-bar-cell__not-ready {\n color: var(--txt-03) !important;\n}\n</style>\n"],"names":["props","__props","settings","computed"],"mappings":";;;;;;;;;;;AAUA,UAAMA,IAAQC,GAIRC,IAAWC,EAAS,MAAMH,EAAM,OAAO,SAAS,MAAS
|
|
1
|
+
{"version":3,"file":"PlAgChartStackedBarCell.vue.js","sources":["../../../src/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { ICellRendererParams } from 'ag-grid-enterprise';\nimport type {\n PlChartStackedBarSettings,\n} from '@milaboratories/uikit';\nimport {\n PlChartStackedBarCompact,\n} from '@milaboratories/uikit';\nimport { computed } from 'vue';\n\nconst props = defineProps<{\n params: ICellRendererParams<unknown, PlChartStackedBarSettings | undefined>;\n}>();\n\nconst settings = computed(() => props.params.value || undefined);\n</script>\n\n<template>\n <div class=\"pl-ag-chart-stacked-bar-cell\">\n <PlChartStackedBarCompact v-if=\"settings\" :settings=\"settings\" />\n <div v-else class=\"pl-ag-chart-stacked-bar-cell__not-ready\">Not ready</div>\n </div>\n</template>\n\n<style>\n.pl-ag-chart-stacked-bar-cell {\n height: 100%;\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.pl-ag-chart-stacked-bar-cell__not-ready {\n color: var(--txt-03) !important;\n}\n</style>\n"],"names":["props","__props","settings","computed","_openBlock","_createElementBlock","_hoisted_1","_createBlock","_unref","PlChartStackedBarCompact","_hoisted_2"],"mappings":";;;;;;;;;;;AAUA,UAAMA,IAAQC,GAIRC,IAAWC,EAAS,MAAMH,EAAM,OAAO,SAAS,MAAS;sBAI7DI,EAAA,GAAAC,EAGM,OAHNC,GAGM;AAAA,MAF4BJ,EAAA,cAAhCK,EAAiEC,EAAAC,CAAA,GAAA;AAAA;QAAtB,UAAUP,EAAA;AAAA,MAAA,mCACrDG,EAA2E,OAA3EK,GAA4D,WAAS;AAAA,IAAA;;;"}
|
|
@@ -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
|
|
3
|
-
import { PlTooltip as
|
|
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(
|
|
10
|
+
setup(e) {
|
|
11
11
|
const v = m(() => {
|
|
12
|
-
switch (
|
|
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: ${
|
|
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 =
|
|
29
|
+
}), l = i(null), c = () => l.value = e.params.column.getSort() ?? null;
|
|
30
30
|
k(() => c());
|
|
31
31
|
function w() {
|
|
32
|
-
|
|
32
|
+
e.params.column.isSortable() && (e.params.progressSort(), c());
|
|
33
33
|
}
|
|
34
34
|
const u = m(() => {
|
|
35
|
-
const
|
|
36
|
-
switch (
|
|
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: ${
|
|
44
|
+
throw Error(`unsupported sort direction: ${t}. Column ${e.params.column.getColId()}`);
|
|
45
45
|
}
|
|
46
46
|
}), s = i();
|
|
47
47
|
function y() {
|
|
48
|
-
const
|
|
49
|
-
|
|
48
|
+
const t = s.value;
|
|
49
|
+
t && e.params.showColumnMenu(t);
|
|
50
50
|
}
|
|
51
|
-
return (
|
|
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
|
-
|
|
55
|
+
r(a(N), null, x({
|
|
56
56
|
default: f(() => [
|
|
57
57
|
g("div", A, [
|
|
58
|
-
|
|
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 ? (
|
|
63
|
+
u.value ? (n(), S(a(o), {
|
|
64
64
|
key: 0,
|
|
65
65
|
name: u.value
|
|
66
|
-
}, null, 8, ["name"])) :
|
|
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
|
-
|
|
74
|
+
B(h(e.params.tooltip), 1)
|
|
75
75
|
]),
|
|
76
76
|
key: "0"
|
|
77
77
|
} : void 0
|
|
78
78
|
]), 1024),
|
|
79
|
-
e.params.enableMenu ? (
|
|
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:
|
|
84
|
+
onClick: M(y, ["stop"])
|
|
85
85
|
}, [
|
|
86
|
-
|
|
87
|
-
], 512)) :
|
|
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
|
|
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
|
|
13
|
+
import xe from "./PlAgOverlayNoRows.vue.js";
|
|
14
14
|
|
|
15
|
-
import
|
|
16
|
-
import { DeferredCircular as
|
|
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(
|
|
44
|
-
const ae = q(
|
|
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: [...
|
|
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: [...
|
|
58
|
+
cachedState: [...T.value]
|
|
59
59
|
} : {
|
|
60
60
|
columns: [],
|
|
61
61
|
config: () => ({}),
|
|
62
62
|
cachedState: []
|
|
63
63
|
};
|
|
64
|
-
}), c = H(null),
|
|
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:
|
|
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:
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
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
|
|
213
|
-
const l = await
|
|
212
|
+
var w, g;
|
|
213
|
+
const l = await I.promise;
|
|
214
214
|
if (l.isDestroyed()) return !1;
|
|
215
|
-
const a = (
|
|
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((
|
|
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:
|
|
229
|
-
p.run(() =>
|
|
228
|
+
const p = ce(), { resolve: S, promise: R } = Promise.withResolvers();
|
|
229
|
+
p.run(() => x(o, S, { once: !0 }));
|
|
230
230
|
try {
|
|
231
|
-
await ve(
|
|
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
|
|
260
|
-
return
|
|
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
|
-
++
|
|
265
|
+
++h.value;
|
|
266
266
|
try {
|
|
267
|
-
if (e.hideOverlay(),
|
|
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: (
|
|
298
|
-
|
|
297
|
+
getRows: (w) => {
|
|
298
|
+
w.success({ rowData: [], rowCount: m });
|
|
299
299
|
}
|
|
300
300
|
}
|
|
301
301
|
});
|
|
302
302
|
}
|
|
303
|
-
const u =
|
|
303
|
+
const u = h.value;
|
|
304
304
|
Pe({
|
|
305
|
-
generation:
|
|
305
|
+
generation: h,
|
|
306
306
|
pfDriver: pe().pFrameDriver,
|
|
307
307
|
model: t.model,
|
|
308
308
|
sheets: t.sheets ?? [],
|
|
309
|
-
dataRenderedTracker:
|
|
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 !==
|
|
318
|
-
const { axesSpec: m, ...
|
|
317
|
+
if (e.isDestroyed() || u !== h.value) return;
|
|
318
|
+
const { axesSpec: m, ...w } = s;
|
|
319
319
|
if (e.updateGridOptions({
|
|
320
|
-
...
|
|
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))),
|
|
332
|
-
if (
|
|
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 !==
|
|
347
|
+
e.isDestroyed() || u !== h.value || console.trace(s);
|
|
348
348
|
}).finally(() => {
|
|
349
|
-
e.isDestroyed() || u !==
|
|
349
|
+
e.isDestroyed() || u !== h.value || e.updateGridOptions({
|
|
350
350
|
loading: !1
|
|
351
351
|
});
|
|
352
|
-
}),
|
|
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
|
-
),
|
|
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) => (
|
|
380
|
+
), (e, t) => (b(), me("div", {
|
|
381
381
|
class: Q(e.$style.container)
|
|
382
382
|
}, [
|
|
383
|
-
c.value && !
|
|
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
|
-
|
|
387
|
+
C.disableFiltersPanel ? z("", !0) : (b(), G(he, {
|
|
388
388
|
key: 1,
|
|
389
|
-
modelValue:
|
|
390
|
-
"onUpdate:modelValue": t[0] || (t[0] = (l) => W(
|
|
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 &&
|
|
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:
|
|
399
|
-
"onUpdate:modelValue": t[1] || (t[1] = (l) => W(
|
|
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
|
-
(
|
|
410
|
+
(b(), G(P(Se), {
|
|
411
411
|
key: E.value,
|
|
412
|
-
theme:
|
|
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"]))
|