@milaboratories/graph-maker 1.1.194 → 1.1.196

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 (63) hide show
  1. package/dist/components/AesSettings/AesDataMappingDiscrete.vue2.js +127 -130
  2. package/dist/components/AesSettings/AesDataMappingDiscrete.vue2.js.map +1 -1
  3. package/dist/components/AesSettings/DiscreteRow.vue2.js +18 -18
  4. package/dist/components/AesSettings/DiscreteRow.vue2.js.map +1 -1
  5. package/dist/components/AesSettings/DiscreteRow.vue3.js +10 -8
  6. package/dist/components/AesSettings/DiscreteRow.vue3.js.map +1 -1
  7. package/dist/components/Chart.vue.js +118 -112
  8. package/dist/components/Chart.vue.js.map +1 -1
  9. package/dist/components/CollapsableBlock.vue.d.ts +1 -0
  10. package/dist/components/CollapsableBlock.vue.js +27 -21
  11. package/dist/components/CollapsableBlock.vue.js.map +1 -1
  12. package/dist/constantsCommon.d.ts +2 -0
  13. package/dist/constantsCommon.js +24 -16
  14. package/dist/constantsCommon.js.map +1 -1
  15. package/dist/forms/AxesSettingsForm/BubbleAxesSettingsForm.vue.js +156 -117
  16. package/dist/forms/AxesSettingsForm/BubbleAxesSettingsForm.vue.js.map +1 -1
  17. package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue.js +167 -138
  18. package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue.js.map +1 -1
  19. package/dist/forms/AxesSettingsForm/HeatmapAxesSettingsForm.vue.js +175 -153
  20. package/dist/forms/AxesSettingsForm/HeatmapAxesSettingsForm.vue.js.map +1 -1
  21. package/dist/forms/AxesSettingsForm/HistogramAxesSettingsForm.vue.js +177 -136
  22. package/dist/forms/AxesSettingsForm/HistogramAxesSettingsForm.vue.js.map +1 -1
  23. package/dist/forms/AxesSettingsForm/ScatterplotAxesSettingsForm.vue.js +243 -203
  24. package/dist/forms/AxesSettingsForm/ScatterplotAxesSettingsForm.vue.js.map +1 -1
  25. package/dist/forms/LayersForm/Layer/Bubble.vue.js +39 -43
  26. package/dist/forms/LayersForm/Layer/Bubble.vue.js.map +1 -1
  27. package/dist/forms/LayersForm/Layer/discrete/Bar.vue.js +30 -34
  28. package/dist/forms/LayersForm/Layer/discrete/Bar.vue.js.map +1 -1
  29. package/dist/forms/LayersForm/Layer/discrete/Errorbar.vue.js +24 -26
  30. package/dist/forms/LayersForm/Layer/discrete/Errorbar.vue.js.map +1 -1
  31. package/dist/forms/LayersForm/Layer/discrete/Line.vue.js +27 -29
  32. package/dist/forms/LayersForm/Layer/discrete/Line.vue.js.map +1 -1
  33. package/dist/forms/LayersForm/Layer/discrete/StackedArea.vue.js +38 -43
  34. package/dist/forms/LayersForm/Layer/discrete/StackedArea.vue.js.map +1 -1
  35. package/dist/forms/LayersForm/Layer/discrete/StackedBar.vue.js +31 -36
  36. package/dist/forms/LayersForm/Layer/discrete/StackedBar.vue.js.map +1 -1
  37. package/dist/forms/LayersForm/Layer/heatmap/Heatmap.vue.js +53 -57
  38. package/dist/forms/LayersForm/Layer/heatmap/Heatmap.vue.js.map +1 -1
  39. package/dist/forms/LayersForm/Layer/heatmap/HeatmapClustered.vue.js +70 -74
  40. package/dist/forms/LayersForm/Layer/heatmap/HeatmapClustered.vue.js.map +1 -1
  41. package/dist/index.js +1 -1
  42. package/dist/index.vue.js +1 -1
  43. package/dist/store.d.ts +3 -4
  44. package/dist/store.js +25 -26
  45. package/dist/store.js.map +1 -1
  46. package/dist/types.d.ts +4 -0
  47. package/dist/utils/createChartSettingsForRender/composeBubbleSettings.d.ts +1 -1
  48. package/dist/utils/createChartSettingsForRender/composeChartSettings.d.ts +4 -2
  49. package/dist/utils/createChartSettingsForRender/composeChartSettings.js +22 -22
  50. package/dist/utils/createChartSettingsForRender/composeChartSettings.js.map +1 -1
  51. package/dist/utils/createChartSettingsForRender/composeDiscreteSettings.d.ts +7 -5
  52. package/dist/utils/createChartSettingsForRender/composeHeatmapSettings.d.ts +1 -1
  53. package/dist/utils/createChartSettingsForRender/composeScatterplotSettings.d.ts +2 -1
  54. package/dist/utils/createChartSettingsForRender/composeScatterplotSettings.js +12 -12
  55. package/dist/utils/createChartSettingsForRender/composeScatterplotSettings.js.map +1 -1
  56. package/dist/utils/createChartSettingsForRender/composeScatterplotUmapSettings.js +11 -11
  57. package/dist/utils/createChartSettingsForRender/composeScatterplotUmapSettings.js.map +1 -1
  58. package/dist/utils/createChartSettingsForRender/getAxesDataFromForms.js +17 -17
  59. package/dist/utils/createChartSettingsForRender/getAxesDataFromForms.js.map +1 -1
  60. package/dist/utils/loadUniqueValuesToSave.d.ts +2 -3
  61. package/dist/utils/loadUniqueValuesToSave.js +2 -2
  62. package/dist/utils/loadUniqueValuesToSave.js.map +1 -1
  63. package/package.json +3 -3
@@ -1,184 +1,223 @@
1
- import { defineComponent as _, createElementBlock as a, openBlock as d, createElementVNode as s, createVNode as i, withCtx as p, createCommentVNode as x, unref as t } from "vue";
2
- import { PlBtnGroup as n, PlTextField as V, Slider as S } from "@platforma-sdk/ui-vue";
3
- import { useStore as O } from "../../store.js";
4
- import g from "../../components/CollapsableBlock.vue.js";
5
- import f from "../../icons/Right.vue.js";
6
- import v from "../../icons/Down.vue.js";
7
- import u from "../../components/BtnIconGroup.vue.js";
8
- import k from "../../icons/AlignLeft.vue.js";
9
- import w from "../../icons/AlignCenter.vue.js";
10
- import U from "../../icons/AlignRight.vue.js";
11
- import C from "../../icons/FrameFull.vue.js";
12
- import L from "../../icons/FrameEmpty.vue.js";
13
- import N from "../../icons/Rotation0.vue.js";
14
- import X from "../../icons/Rotation45.vue.js";
15
- import I from "../../icons/Rotation90.vue.js";
16
- const P = { class: "axes-settings-list" }, Y = { class: "axes-settings-options-row block" }, M = {
1
+ import { defineComponent as U, computed as k, createElementBlock as d, openBlock as u, createElementVNode as s, createVNode as i, withCtx as n, createCommentVNode as x, unref as o, createTextVNode as V } from "vue";
2
+ import { PlBtnGroup as a, PlTextField as g, PlCheckbox as v, Slider as O } from "@platforma-sdk/ui-vue";
3
+ import { useStore as _ } from "../../store.js";
4
+ import f from "../../components/CollapsableBlock.vue.js";
5
+ import b from "../../icons/Right.vue.js";
6
+ import T from "../../icons/Down.vue.js";
7
+ import m from "../../components/BtnIconGroup.vue.js";
8
+ import X from "../../icons/AlignLeft.vue.js";
9
+ import C from "../../icons/AlignCenter.vue.js";
10
+ import N from "../../icons/AlignRight.vue.js";
11
+ import P from "../../icons/FrameFull.vue.js";
12
+ import Y from "../../icons/FrameEmpty.vue.js";
13
+ import I from "../../icons/Rotation0.vue.js";
14
+ import M from "../../icons/Rotation45.vue.js";
15
+ import R from "../../icons/Rotation90.vue.js";
16
+ const E = { class: "axes-settings-list" }, F = { class: "axes-settings-options-row block" }, y = {
17
17
  key: 0,
18
18
  class: "axes-settings-input"
19
- }, R = { class: "axes-settings-options-row" }, E = { class: "axes-settings-options-row" }, F = { class: "axes-settings-options-row block" }, y = { key: 0 }, B = { class: "axes-settings-options-row block" }, G = { class: "axes-settings-options-row" }, H = { class: "axes-settings-options-row block" }, D = { key: 0 }, $ = { class: "axes-settings-options-row block" }, z = { class: "other" }, j = { class: "axes-settings-options-row" }, q = { class: "axes-settings-options-row" }, pe = /* @__PURE__ */ _({
19
+ }, B = { class: "axes-settings-options-row" }, H = { class: "axes-settings-options-row" }, G = { class: "axes-settings-options-row" }, D = { class: "axes-settings-options-row block" }, $ = { key: 0 }, z = { class: "axes-settings-options-row block" }, j = { class: "axes-settings-options-row" }, q = { class: "axes-settings-options-row" }, J = { class: "axes-settings-options-row block" }, K = { key: 0 }, Q = { class: "axes-settings-options-row block" }, W = { class: "other" }, Z = { class: "axes-settings-options-row" }, h = { class: "axes-settings-options-row" }, ee = { class: "axes-settings-options-row" }, be = /* @__PURE__ */ U({
20
20
  __name: "BubbleAxesSettingsForm",
21
- setup(J) {
22
- const o = O().value.reactive.axesSettings, m = {
21
+ setup(oe) {
22
+ const A = _(), t = A.value.reactive.axesSettings, r = {
23
23
  height: 40,
24
24
  horizontalPadding: 12,
25
- defaultState: "open"
26
- }, A = [
27
- { value: "left", icon: k },
28
- { value: "center", icon: w },
29
- { value: "right", icon: U }
30
- ], T = [
31
- { value: 0, icon: N },
32
- { value: 45, icon: X },
33
- { value: 90, icon: I }
34
- ], r = [
25
+ defaultState: "open",
26
+ contentPadding: "0 24px"
27
+ }, S = [
28
+ { value: "left", icon: X },
29
+ { value: "center", icon: C },
30
+ { value: "right", icon: N }
31
+ ], w = [
32
+ { value: 0, icon: I },
33
+ { value: 45, icon: M },
34
+ { value: 90, icon: R }
35
+ ], p = [
35
36
  { value: "auto", text: "Auto" },
36
37
  { value: "custom", text: "Custom" },
37
38
  { value: "hidden", text: "Hidden" }
38
39
  ], c = [
39
- { value: "none", icon: L },
40
- { value: "full", icon: C }
41
- ], b = [
40
+ { value: "none", icon: Y },
41
+ { value: "full", icon: P }
42
+ ], L = [
42
43
  { text: "ascending", value: "asc" },
43
44
  { text: "descending", value: "desc" }
44
45
  ];
45
- return (Q, e) => (d(), a("div", {
46
+ return k(() => A.value.reactive.optionsState.components), (te, e) => (u(), d("div", {
46
47
  class: "axes-form",
47
- onClick: e[13] || (e[13] = (l) => l.stopPropagation())
48
+ onClick: e[16] || (e[16] = (l) => l.stopPropagation())
48
49
  }, [
49
- e[18] || (e[18] = s("h3", { class: "axes-title" }, " Axes ", -1)),
50
- s("div", P, [
51
- i(g, {
50
+ e[24] || (e[24] = s("h3", { class: "axes-title" }, " Axes ", -1)),
51
+ s("div", E, [
52
+ i(f, {
52
53
  title: "Title",
53
- settings: m,
54
- icon: f,
55
- "icon-open": v
54
+ settings: r,
55
+ icon: b,
56
+ "icon-open": T
56
57
  }, {
57
- default: p(() => [
58
- s("div", Y, [
59
- i(t(n), {
60
- modelValue: t(o).title.mode,
61
- "onUpdate:modelValue": e[0] || (e[0] = (l) => t(o).title.mode = l),
58
+ default: n(() => [
59
+ s("div", F, [
60
+ i(o(a), {
61
+ modelValue: o(t).title.mode,
62
+ "onUpdate:modelValue": e[0] || (e[0] = (l) => o(t).title.mode = l),
62
63
  label: "Title",
63
- options: r
64
+ options: p,
65
+ compact: !0
64
66
  }, null, 8, ["modelValue"])
65
67
  ]),
66
- t(o).title.mode === "custom" ? (d(), a("div", M, [
67
- i(t(V), {
68
- modelValue: t(o).title.value,
69
- "onUpdate:modelValue": e[1] || (e[1] = (l) => t(o).title.value = l),
68
+ o(t).title.mode === "custom" ? (u(), d("div", y, [
69
+ i(o(g), {
70
+ modelValue: o(t).title.value,
71
+ "onUpdate:modelValue": e[1] || (e[1] = (l) => o(t).title.value = l),
70
72
  label: "Chart title",
71
73
  placeholder: "Chart title"
72
74
  }, null, 8, ["modelValue"])
73
75
  ])) : x("", !0),
74
- s("div", R, [
75
- e[14] || (e[14] = s("span", null, "Alignment", -1)),
76
- i(u, {
77
- modelValue: t(o).title.position,
78
- "onUpdate:modelValue": e[2] || (e[2] = (l) => t(o).title.position = l),
79
- options: A
76
+ s("div", B, [
77
+ e[17] || (e[17] = s("span", null, "Alignment", -1)),
78
+ i(m, {
79
+ modelValue: o(t).title.position,
80
+ "onUpdate:modelValue": e[2] || (e[2] = (l) => o(t).title.position = l),
81
+ options: S
80
82
  }, null, 8, ["modelValue"])
81
83
  ])
82
84
  ]),
83
85
  _: 1
84
86
  }),
85
- i(g, {
87
+ i(f, {
86
88
  title: "X-axis",
87
- settings: m,
88
- icon: f,
89
- "icon-open": v
89
+ settings: r,
90
+ icon: b,
91
+ "icon-open": T
90
92
  }, {
91
- default: p(() => [
92
- s("div", E, [
93
- e[15] || (e[15] = s("span", null, "Labels rotation", -1)),
94
- i(u, {
95
- modelValue: t(o).axisX.axisLabelsAngle,
96
- "onUpdate:modelValue": e[3] || (e[3] = (l) => t(o).axisX.axisLabelsAngle = l),
97
- options: T
93
+ default: n(() => [
94
+ s("div", H, [
95
+ i(o(v), {
96
+ modelValue: o(t).axisX.hideAxisLabels,
97
+ "onUpdate:modelValue": e[3] || (e[3] = (l) => o(t).axisX.hideAxisLabels = l)
98
+ }, {
99
+ default: n(() => [...e[18] || (e[18] = [
100
+ V("Hide axis labels", -1)
101
+ ])]),
102
+ _: 1
103
+ }, 8, ["modelValue"])
104
+ ]),
105
+ s("div", G, [
106
+ e[19] || (e[19] = s("span", null, "Labels rotation", -1)),
107
+ i(m, {
108
+ modelValue: o(t).axisX.axisLabelsAngle,
109
+ "onUpdate:modelValue": e[4] || (e[4] = (l) => o(t).axisX.axisLabelsAngle = l),
110
+ options: w
98
111
  }, null, 8, ["modelValue"])
99
112
  ]),
100
- s("div", F, [
101
- i(t(n), {
102
- modelValue: t(o).axisX.titleMode,
103
- "onUpdate:modelValue": e[4] || (e[4] = (l) => t(o).axisX.titleMode = l),
113
+ s("div", D, [
114
+ i(o(a), {
115
+ modelValue: o(t).axisX.titleMode,
116
+ "onUpdate:modelValue": e[5] || (e[5] = (l) => o(t).axisX.titleMode = l),
104
117
  label: "Title",
105
- options: r
118
+ options: p,
119
+ compact: !0
106
120
  }, null, 8, ["modelValue"])
107
121
  ]),
108
- t(o).axisX.titleMode === "custom" ? (d(), a("div", y, [
109
- i(t(V), {
110
- modelValue: t(o).axisX.customTitle,
111
- "onUpdate:modelValue": e[5] || (e[5] = (l) => t(o).axisX.customTitle = l),
122
+ o(t).axisX.titleMode === "custom" ? (u(), d("div", $, [
123
+ i(o(g), {
124
+ modelValue: o(t).axisX.customTitle,
125
+ "onUpdate:modelValue": e[6] || (e[6] = (l) => o(t).axisX.customTitle = l),
112
126
  label: "Text",
113
127
  placeholder: "Type"
114
128
  }, null, 8, ["modelValue"])
115
129
  ])) : x("", !0),
116
- s("div", B, [
117
- i(t(n), {
118
- modelValue: t(o).axisX.sorting,
119
- "onUpdate:modelValue": e[6] || (e[6] = (l) => t(o).axisX.sorting = l),
130
+ s("div", z, [
131
+ i(o(a), {
132
+ modelValue: o(t).axisX.sorting,
133
+ "onUpdate:modelValue": e[7] || (e[7] = (l) => o(t).axisX.sorting = l),
120
134
  label: "Sorting",
121
- options: b
135
+ options: L,
136
+ compact: !0
122
137
  }, null, 8, ["modelValue"])
123
138
  ])
124
139
  ]),
125
140
  _: 1
126
141
  }),
127
- i(g, {
142
+ i(f, {
128
143
  title: "Y-axis",
129
- settings: m,
130
- icon: f,
131
- "icon-open": v
144
+ settings: r,
145
+ icon: b,
146
+ "icon-open": T
132
147
  }, {
133
- default: p(() => [
134
- s("div", G, [
135
- e[16] || (e[16] = s("span", null, "Labels rotation", -1)),
136
- i(u, {
137
- modelValue: t(o).axisY.axisLabelsAngle,
138
- "onUpdate:modelValue": e[7] || (e[7] = (l) => t(o).axisY.axisLabelsAngle = l),
139
- options: T
148
+ default: n(() => [
149
+ s("div", j, [
150
+ i(o(v), {
151
+ modelValue: o(t).axisY.hideAxisLabels,
152
+ "onUpdate:modelValue": e[8] || (e[8] = (l) => o(t).axisY.hideAxisLabels = l)
153
+ }, {
154
+ default: n(() => [...e[20] || (e[20] = [
155
+ V("Hide axis labels", -1)
156
+ ])]),
157
+ _: 1
158
+ }, 8, ["modelValue"])
159
+ ]),
160
+ s("div", q, [
161
+ e[21] || (e[21] = s("span", null, "Labels rotation", -1)),
162
+ i(m, {
163
+ modelValue: o(t).axisY.axisLabelsAngle,
164
+ "onUpdate:modelValue": e[9] || (e[9] = (l) => o(t).axisY.axisLabelsAngle = l),
165
+ options: w
140
166
  }, null, 8, ["modelValue"])
141
167
  ]),
142
- s("div", H, [
143
- i(t(n), {
144
- modelValue: t(o).axisY.titleMode,
145
- "onUpdate:modelValue": e[8] || (e[8] = (l) => t(o).axisY.titleMode = l),
168
+ s("div", J, [
169
+ i(o(a), {
170
+ modelValue: o(t).axisY.titleMode,
171
+ "onUpdate:modelValue": e[10] || (e[10] = (l) => o(t).axisY.titleMode = l),
146
172
  label: "Title",
147
- options: r
173
+ options: p,
174
+ compact: !0
148
175
  }, null, 8, ["modelValue"])
149
176
  ]),
150
- t(o).axisY.titleMode === "custom" ? (d(), a("div", D, [
151
- i(t(V), {
152
- modelValue: t(o).axisY.customTitle,
153
- "onUpdate:modelValue": e[9] || (e[9] = (l) => t(o).axisY.customTitle = l),
177
+ o(t).axisY.titleMode === "custom" ? (u(), d("div", K, [
178
+ i(o(g), {
179
+ modelValue: o(t).axisY.customTitle,
180
+ "onUpdate:modelValue": e[11] || (e[11] = (l) => o(t).axisY.customTitle = l),
154
181
  label: "Text",
155
182
  placeholder: "Type"
156
183
  }, null, 8, ["modelValue"])
157
184
  ])) : x("", !0),
158
- s("div", $, [
159
- i(t(n), {
160
- modelValue: t(o).axisY.sorting,
161
- "onUpdate:modelValue": e[10] || (e[10] = (l) => t(o).axisY.sorting = l),
185
+ s("div", Q, [
186
+ i(o(a), {
187
+ modelValue: o(t).axisY.sorting,
188
+ "onUpdate:modelValue": e[12] || (e[12] = (l) => o(t).axisY.sorting = l),
162
189
  label: "Sorting",
163
- options: b
190
+ options: L,
191
+ compact: !0
164
192
  }, null, 8, ["modelValue"])
165
193
  ])
166
194
  ]),
167
195
  _: 1
168
196
  }),
169
- s("div", z, [
170
- s("div", j, [
171
- e[17] || (e[17] = s("span", null, "Frame", -1)),
172
- i(u, {
173
- modelValue: t(o).other.frame,
174
- "onUpdate:modelValue": e[11] || (e[11] = (l) => t(o).other.frame = l),
197
+ s("div", W, [
198
+ s("div", Z, [
199
+ i(o(v), {
200
+ modelValue: o(t).other.showLegend,
201
+ "onUpdate:modelValue": e[13] || (e[13] = (l) => o(t).other.showLegend = l)
202
+ }, {
203
+ default: n(() => [...e[22] || (e[22] = [
204
+ V("Show legend", -1)
205
+ ])]),
206
+ _: 1
207
+ }, 8, ["modelValue"])
208
+ ]),
209
+ s("div", h, [
210
+ e[23] || (e[23] = s("span", null, "Frame", -1)),
211
+ i(m, {
212
+ modelValue: o(t).other.frame,
213
+ "onUpdate:modelValue": e[14] || (e[14] = (l) => o(t).other.frame = l),
175
214
  options: c
176
215
  }, null, 8, ["modelValue"])
177
216
  ]),
178
- s("div", q, [
179
- i(t(S), {
180
- modelValue: t(o).other.facetColumns,
181
- "onUpdate:modelValue": e[12] || (e[12] = (l) => t(o).other.facetColumns = l),
217
+ s("div", ee, [
218
+ i(o(O), {
219
+ modelValue: o(t).other.facetColumns,
220
+ "onUpdate:modelValue": e[15] || (e[15] = (l) => o(t).other.facetColumns = l),
182
221
  style: { width: "100%" },
183
222
  label: "Facet column count",
184
223
  min: 1,
@@ -194,6 +233,6 @@ const P = { class: "axes-settings-list" }, Y = { class: "axes-settings-options-r
194
233
  }
195
234
  });
196
235
  export {
197
- pe as default
236
+ be as default
198
237
  };
199
238
  //# sourceMappingURL=BubbleAxesSettingsForm.vue.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"BubbleAxesSettingsForm.vue.js","sources":["../../../src/forms/AxesSettingsForm/BubbleAxesSettingsForm.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { Slider } from '@platforma-sdk/ui-vue';\nimport { useStore } from '../../store';\nimport CollapsableBlock from '../../components/CollapsableBlock.vue';\nimport Right from '../../icons/Right.vue';\nimport Down from '../../icons/Down.vue';\nimport { PlTextField, PlBtnGroup } from '@platforma-sdk/ui-vue';\nimport BtnIconGroup from '../../components/BtnIconGroup.vue';\nimport AlignLeft from '../../icons/AlignLeft.vue';\nimport AlignCenter from '../../icons/AlignCenter.vue';\nimport AlignRight from '../../icons/AlignRight.vue';\nimport FrameFull from '../../icons/FrameFull.vue';\nimport FrameEmpty from '../../icons/FrameEmpty.vue';\nimport Rotation0 from '../../icons/Rotation0.vue';\nimport Rotation45 from '../../icons/Rotation45.vue';\nimport Rotation90 from '../../icons/Rotation90.vue';\n\nconst store = useStore();\nconst settings = store.value.reactive.axesSettings;\nconst blockSettings = {\n height: 40,\n horizontalPadding: 12,\n defaultState: 'open' as 'open' | 'close',\n};\nconst OPTIONS_TITLE_ALIGN = [\n { value: 'left', icon: AlignLeft },\n { value: 'center', icon: AlignCenter },\n { value: 'right', icon: AlignRight },\n];\nconst OPTIONS_HEATMAP_ROTATION = [\n { value: 0, icon: Rotation0 },\n { value: 45, icon: Rotation45 },\n { value: 90, icon: Rotation90 },\n];\nconst OPTIONS_AXIS_LABEL_MODE = [\n { value: 'auto', text: 'Auto' },\n { value: 'custom', text: 'Custom' },\n { value: 'hidden', text: 'Hidden' },\n];\nconst OPTIONS_CHART_FRAME = [\n { value: 'none', icon: FrameEmpty },\n { value: 'full', icon: FrameFull },\n];\nconst OPTIONS_SORTING = [\n { text: 'ascending', value: 'asc' },\n { text: 'descending', value: 'desc' },\n];\n\n</script>\n\n<template>\n <div class=\"axes-form\" @click=\"(e) => e.stopPropagation()\">\n <h3 class=\"axes-title\">\n Axes\n </h3>\n <div class=\"axes-settings-list\">\n <!-- Chart title -->\n <CollapsableBlock title=\"Title\" :settings=\"blockSettings\" :icon=\"Right\" :icon-open=\"Down\">\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.title.mode\"\n label=\"Title\"\n :options=\"OPTIONS_AXIS_LABEL_MODE\"\n />\n </div>\n <div v-if=\"settings.title.mode === 'custom'\" class=\"axes-settings-input\">\n <PlTextField\n v-model=\"settings.title.value\"\n label=\"Chart title\"\n placeholder=\"Chart title\"\n />\n </div>\n <div class=\"axes-settings-options-row\">\n <span>Alignment</span>\n <BtnIconGroup v-model=\"settings.title.position\" :options=\"OPTIONS_TITLE_ALIGN\"/>\n </div>\n </CollapsableBlock>\n <!-- X axis settings-->\n <CollapsableBlock title=\"X-axis\" :settings=\"blockSettings\" :icon=\"Right\" :icon-open=\"Down\">\n <div class=\"axes-settings-options-row\">\n <span>Labels rotation</span>\n <BtnIconGroup v-model=\"settings.axisX.axisLabelsAngle\" :options=\"OPTIONS_HEATMAP_ROTATION\" />\n </div>\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.axisX.titleMode\"\n label=\"Title\"\n :options=\"OPTIONS_AXIS_LABEL_MODE\"\n />\n </div>\n <div v-if=\"settings.axisX.titleMode === 'custom'\">\n <PlTextField\n v-model=\"settings.axisX.customTitle\"\n label=\"Text\"\n placeholder=\"Type\"\n />\n </div>\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.axisX.sorting\"\n label=\"Sorting\"\n :options=\"OPTIONS_SORTING\"\n />\n </div>\n </CollapsableBlock>\n <!-- Y axis settings-->\n <CollapsableBlock title=\"Y-axis\" :settings=\"blockSettings\" :icon=\"Right\" :icon-open=\"Down\">\n <div class=\"axes-settings-options-row\">\n <span>Labels rotation</span>\n <BtnIconGroup v-model=\"settings.axisY.axisLabelsAngle\" :options=\"OPTIONS_HEATMAP_ROTATION\" />\n </div>\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.axisY.titleMode\"\n label=\"Title\"\n :options=\"OPTIONS_AXIS_LABEL_MODE\"\n />\n </div>\n <div v-if=\"settings.axisY.titleMode === 'custom'\">\n <PlTextField\n v-model=\"settings.axisY.customTitle\"\n label=\"Text\"\n placeholder=\"Type\"\n />\n </div>\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.axisY.sorting\"\n label=\"Sorting\"\n :options=\"OPTIONS_SORTING\"\n />\n </div>\n </CollapsableBlock>\n\n <div class=\"other\">\n <div class=\"axes-settings-options-row\">\n <span>Frame</span>\n <BtnIconGroup v-model=\"settings.other.frame\" :options=\"OPTIONS_CHART_FRAME\" />\n </div>\n <div class=\"axes-settings-options-row\">\n <Slider\n v-model=\"settings.other.facetColumns\"\n :style=\"{width: '100%'}\"\n label=\"Facet column count\"\n :min=\"1\"\n :max=\"6\"\n :step=\"1\"\n :breakpoints=\"true\"\n mode=\"input\"\n />\n </div>\n </div>\n </div>\n </div>\n</template>\n"],"names":["settings","useStore","blockSettings","OPTIONS_TITLE_ALIGN","AlignLeft","AlignCenter","AlignRight","OPTIONS_HEATMAP_ROTATION","Rotation0","Rotation45","Rotation90","OPTIONS_AXIS_LABEL_MODE","OPTIONS_CHART_FRAME","FrameEmpty","FrameFull","OPTIONS_SORTING","_createElementBlock","_cache","e","_createElementVNode","_hoisted_1","_createVNode","CollapsableBlock","Right","Down","_hoisted_2","_unref","PlBtnGroup","$event","_openBlock","_hoisted_3","PlTextField","_hoisted_4","BtnIconGroup","_hoisted_5","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_13","_hoisted_14","_hoisted_15","Slider"],"mappings":"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"}
1
+ {"version":3,"file":"BubbleAxesSettingsForm.vue.js","sources":["../../../src/forms/AxesSettingsForm/BubbleAxesSettingsForm.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { Slider, PlCheckbox } from '@platforma-sdk/ui-vue';\nimport { useStore } from '../../store';\nimport CollapsableBlock from '../../components/CollapsableBlock.vue';\nimport Right from '../../icons/Right.vue';\nimport Down from '../../icons/Down.vue';\nimport { PlTextField, PlBtnGroup } from '@platforma-sdk/ui-vue';\nimport BtnIconGroup from '../../components/BtnIconGroup.vue';\nimport AlignLeft from '../../icons/AlignLeft.vue';\nimport AlignCenter from '../../icons/AlignCenter.vue';\nimport AlignRight from '../../icons/AlignRight.vue';\nimport FrameFull from '../../icons/FrameFull.vue';\nimport FrameEmpty from '../../icons/FrameEmpty.vue';\nimport Rotation0 from '../../icons/Rotation0.vue';\nimport Rotation45 from '../../icons/Rotation45.vue';\nimport Rotation90 from '../../icons/Rotation90.vue';\nimport type { BubbleUIState } from '@milaboratories/pf-plots';\nimport { computed } from 'vue';\n\nconst store = useStore();\nconst settings = store.value.reactive.axesSettings;\nconst blockSettings = {\n height: 40,\n horizontalPadding: 12,\n defaultState: 'open' as 'open' | 'close',\n contentPadding: '0 24px',\n};\nconst OPTIONS_TITLE_ALIGN = [\n { value: 'left', icon: AlignLeft },\n { value: 'center', icon: AlignCenter },\n { value: 'right', icon: AlignRight },\n];\nconst OPTIONS_HEATMAP_ROTATION = [\n { value: 0, icon: Rotation0 },\n { value: 45, icon: Rotation45 },\n { value: 90, icon: Rotation90 },\n];\nconst OPTIONS_AXIS_LABEL_MODE = [\n { value: 'auto', text: 'Auto' },\n { value: 'custom', text: 'Custom' },\n { value: 'hidden', text: 'Hidden' },\n];\nconst OPTIONS_CHART_FRAME = [\n { value: 'none', icon: FrameEmpty },\n { value: 'full', icon: FrameFull },\n];\nconst OPTIONS_SORTING = [\n { text: 'ascending', value: 'asc' },\n { text: 'descending', value: 'desc' },\n];\n\nconst options = computed(() => (store.value.reactive.optionsState.components as BubbleUIState['components']));\n\n</script>\n\n<template>\n <div class=\"axes-form\" @click=\"(e) => e.stopPropagation()\">\n <h3 class=\"axes-title\">\n Axes\n </h3>\n <div class=\"axes-settings-list\">\n <!-- Chart title -->\n <CollapsableBlock title=\"Title\" :settings=\"blockSettings\" :icon=\"Right\" :icon-open=\"Down\">\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.title.mode\"\n label=\"Title\"\n :options=\"OPTIONS_AXIS_LABEL_MODE\"\n :compact=\"true\"\n />\n </div>\n <div v-if=\"settings.title.mode === 'custom'\" class=\"axes-settings-input\">\n <PlTextField\n v-model=\"settings.title.value\"\n label=\"Chart title\"\n placeholder=\"Chart title\"\n />\n </div>\n <div class=\"axes-settings-options-row\">\n <span>Alignment</span>\n <BtnIconGroup v-model=\"settings.title.position\" :options=\"OPTIONS_TITLE_ALIGN\"/>\n </div>\n </CollapsableBlock>\n <!-- X axis settings-->\n <CollapsableBlock title=\"X-axis\" :settings=\"blockSettings\" :icon=\"Right\" :icon-open=\"Down\">\n <div class=\"axes-settings-options-row\">\n <PlCheckbox v-model=\"settings.axisX.hideAxisLabels\">Hide axis labels</PlCheckbox>\n </div>\n <div class=\"axes-settings-options-row\">\n <span>Labels rotation</span>\n <BtnIconGroup v-model=\"settings.axisX.axisLabelsAngle\" :options=\"OPTIONS_HEATMAP_ROTATION\" />\n </div>\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.axisX.titleMode\"\n label=\"Title\"\n :options=\"OPTIONS_AXIS_LABEL_MODE\"\n :compact=\"true\"\n />\n </div>\n <div v-if=\"settings.axisX.titleMode === 'custom'\">\n <PlTextField\n v-model=\"settings.axisX.customTitle\"\n label=\"Text\"\n placeholder=\"Type\"\n />\n </div>\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.axisX.sorting\"\n label=\"Sorting\"\n :options=\"OPTIONS_SORTING\"\n :compact=\"true\"\n />\n </div>\n </CollapsableBlock>\n <!-- Y axis settings-->\n <CollapsableBlock title=\"Y-axis\" :settings=\"blockSettings\" :icon=\"Right\" :icon-open=\"Down\">\n <div class=\"axes-settings-options-row\">\n <PlCheckbox v-model=\"settings.axisY.hideAxisLabels\">Hide axis labels</PlCheckbox>\n </div>\n <div class=\"axes-settings-options-row\">\n <span>Labels rotation</span>\n <BtnIconGroup v-model=\"settings.axisY.axisLabelsAngle\" :options=\"OPTIONS_HEATMAP_ROTATION\" />\n </div>\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.axisY.titleMode\"\n label=\"Title\"\n :options=\"OPTIONS_AXIS_LABEL_MODE\"\n :compact=\"true\"\n />\n </div>\n <div v-if=\"settings.axisY.titleMode === 'custom'\">\n <PlTextField\n v-model=\"settings.axisY.customTitle\"\n label=\"Text\"\n placeholder=\"Type\"\n />\n </div>\n <div class=\"axes-settings-options-row block\">\n <PlBtnGroup\n v-model=\"settings.axisY.sorting\"\n label=\"Sorting\"\n :options=\"OPTIONS_SORTING\"\n :compact=\"true\"\n />\n </div>\n </CollapsableBlock>\n\n <div class=\"other\">\n <div class=\"axes-settings-options-row\">\n <PlCheckbox v-model=\"settings.other.showLegend\">Show legend</PlCheckbox>\n </div>\n <div class=\"axes-settings-options-row\">\n <span>Frame</span>\n <BtnIconGroup v-model=\"settings.other.frame\" :options=\"OPTIONS_CHART_FRAME\" />\n </div>\n <div class=\"axes-settings-options-row\">\n <Slider\n v-model=\"settings.other.facetColumns\"\n :style=\"{width: '100%'}\"\n label=\"Facet column count\"\n :min=\"1\"\n :max=\"6\"\n :step=\"1\"\n :breakpoints=\"true\"\n mode=\"input\"\n />\n </div>\n </div>\n </div>\n </div>\n</template>\n"],"names":["store","useStore","settings","blockSettings","OPTIONS_TITLE_ALIGN","AlignLeft","AlignCenter","AlignRight","OPTIONS_HEATMAP_ROTATION","Rotation0","Rotation45","Rotation90","OPTIONS_AXIS_LABEL_MODE","OPTIONS_CHART_FRAME","FrameEmpty","FrameFull","OPTIONS_SORTING","computed","_createElementBlock","_cache","e","_createElementVNode","_hoisted_1","_createVNode","CollapsableBlock","Right","Down","_hoisted_2","_unref","PlBtnGroup","$event","_openBlock","_hoisted_3","PlTextField","_hoisted_4","BtnIconGroup","_hoisted_5","PlCheckbox","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_13","_hoisted_14","_hoisted_15","_hoisted_16","_hoisted_17","_hoisted_18","Slider"],"mappings":"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"}