@milaboratories/graph-maker 1.2.2 → 1.2.4
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/dist/components/AesSettings/AesDataMappingDiscrete.vue.d.ts.map +1 -1
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue2.js +106 -94
- package/dist/components/AesSettings/AesDataMappingDiscrete.vue2.js.map +1 -1
- package/dist/dataBindAes.d.ts +1 -0
- package/dist/dataBindAes.d.ts.map +1 -1
- package/dist/dataBindAes.js +114 -99
- package/dist/dataBindAes.js.map +1 -1
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue.d.ts.map +1 -1
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue.js +61 -61
- package/dist/forms/AxesSettingsForm/DiscreteAxesSettingsForm.vue.js.map +1 -1
- package/package.json +3 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AesDataMappingDiscrete.vue.d.ts","sourceRoot":"","sources":["../../../src/components/AesSettings/AesDataMappingDiscrete.vue"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AesDataMappingDiscrete.vue.d.ts","sourceRoot":"","sources":["../../../src/components/AesSettings/AesDataMappingDiscrete.vue"],"names":[],"mappings":"AA2SA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,KAAK,EACV,2BAA2B,EAC5B,MAAM,mBAAmB,CAAC;AAW3B,KAAK,WAAW,GAAG;IACjB,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC1C,gBAAgB,EAAE,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAC3C,UAAU,EAAE,2BAA2B,CAAC;IACxC,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B,CAAC;;;;;;AAuaF,wBAQG"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { defineComponent as j, ref as
|
|
1
|
+
import { defineComponent as j, ref as p, computed as g, watch as w, createElementBlock as _, openBlock as C, createElementVNode as v, createCommentVNode as O, createBlock as q, toDisplayString as z, createVNode as V, unref as k, withCtx as E } from "vue";
|
|
2
2
|
import { scaleLinear as G } from "d3-scale";
|
|
3
|
-
import { isCategorical as J, PALETTE_MAP as
|
|
4
|
-
import {
|
|
3
|
+
import { isCategorical as J, PALETTE_MAP as b, UNKNOWN_COLOR as T } from "../../constantsAesthetic.js";
|
|
4
|
+
import { changePaletteInExistingCategoricalMapping as Q } from "../../dataBindAes.js";
|
|
5
5
|
import X from "./FormWrapper.vue.js";
|
|
6
6
|
import Y from "./PalettesForm.vue.js";
|
|
7
7
|
import Z from "../MultiselectButton.vue.js";
|
|
@@ -11,10 +11,10 @@ import { PlElementList as ae } from "@platforma-sdk/ui-vue";
|
|
|
11
11
|
const oe = { class: "aes-mapping-block" }, te = { style: { margin: "0 24px" } }, ne = { class: "section-title" }, ie = { style: { margin: "24px 0" } }, ue = {
|
|
12
12
|
key: 0,
|
|
13
13
|
style: { margin: "24px 0" }
|
|
14
|
-
},
|
|
14
|
+
}, re = {
|
|
15
15
|
key: 0,
|
|
16
16
|
class: "aes-settings-hint"
|
|
17
|
-
},
|
|
17
|
+
}, se = { class: "column-values-list" }, we = /* @__PURE__ */ j({
|
|
18
18
|
__name: "AesDataMappingDiscrete",
|
|
19
19
|
props: {
|
|
20
20
|
dataColumnLabel: {},
|
|
@@ -26,74 +26,74 @@ const oe = { class: "aes-mapping-block" }, te = { style: { margin: "0 24px" } },
|
|
|
26
26
|
allowNullOption: { type: Boolean }
|
|
27
27
|
},
|
|
28
28
|
emits: ["update:modelValue"],
|
|
29
|
-
setup(
|
|
30
|
-
const
|
|
31
|
-
function
|
|
29
|
+
setup(d, { emit: $ }) {
|
|
30
|
+
const a = d, m = $, f = p(!1), i = p(a.modelValue.palette), I = g(() => J(i.value)), c = p(null), B = g(() => c.value === null ? null : a.modelValue.order.indexOf(c.value)), h = p(null);
|
|
31
|
+
function D(e) {
|
|
32
32
|
i.value = e, f.value = !1, m(
|
|
33
33
|
"update:modelValue",
|
|
34
|
-
Q(e,
|
|
34
|
+
Q(e, a.modelValue)
|
|
35
35
|
);
|
|
36
36
|
}
|
|
37
|
-
function
|
|
37
|
+
function F(e, l, o) {
|
|
38
38
|
m("update:modelValue", {
|
|
39
|
-
...
|
|
39
|
+
...a.modelValue,
|
|
40
40
|
mapping: {
|
|
41
|
-
...
|
|
41
|
+
...a.modelValue.mapping,
|
|
42
42
|
[e]: {
|
|
43
|
-
...
|
|
43
|
+
...a.modelValue.mapping[e],
|
|
44
44
|
aes: {
|
|
45
|
-
...
|
|
46
|
-
[
|
|
45
|
+
...a.modelValue.mapping[e].aes,
|
|
46
|
+
[l]: o
|
|
47
47
|
}
|
|
48
48
|
}
|
|
49
49
|
}
|
|
50
50
|
});
|
|
51
51
|
}
|
|
52
52
|
function N() {
|
|
53
|
-
|
|
53
|
+
c.value = null, h.value = null;
|
|
54
54
|
}
|
|
55
|
-
function
|
|
56
|
-
var
|
|
55
|
+
function M(e) {
|
|
56
|
+
var l;
|
|
57
57
|
m("update:modelValue", {
|
|
58
|
-
...
|
|
58
|
+
...a.modelValue,
|
|
59
59
|
hidden: {
|
|
60
|
-
...
|
|
61
|
-
[e.value]: !((
|
|
60
|
+
...a.modelValue.hidden,
|
|
61
|
+
[e.value]: !((l = a.modelValue.hidden) != null && l[e.value])
|
|
62
62
|
}
|
|
63
63
|
});
|
|
64
64
|
}
|
|
65
|
-
function
|
|
66
|
-
const n = 1 / (e.length - 1),
|
|
67
|
-
return (u) => u > t || u < o ?
|
|
65
|
+
function L(e, l, o = 0, t = 1) {
|
|
66
|
+
const n = 1 / (e.length - 1), r = G().domain(e.map((u, s) => o + s * n * (t - o))).range(e);
|
|
67
|
+
return (u) => u > t || u < o ? l : r(u);
|
|
68
68
|
}
|
|
69
|
-
const U =
|
|
70
|
-
() =>
|
|
71
|
-
), H =
|
|
72
|
-
() =>
|
|
73
|
-
),
|
|
74
|
-
|
|
75
|
-
(e) =>
|
|
69
|
+
const U = g(
|
|
70
|
+
() => L(b[i.value].colors, T)
|
|
71
|
+
), H = g(
|
|
72
|
+
() => L(b[i.value].colors, T, 0, 100)
|
|
73
|
+
), x = p(
|
|
74
|
+
a.modelValue.order.map(
|
|
75
|
+
(e) => a.modelValue.mapping[e].colorIdx * 100
|
|
76
76
|
)
|
|
77
77
|
);
|
|
78
|
-
|
|
79
|
-
() =>
|
|
78
|
+
w(
|
|
79
|
+
() => a.modelValue,
|
|
80
80
|
(e) => {
|
|
81
|
-
|
|
82
|
-
(
|
|
81
|
+
x.value = e.order.map(
|
|
82
|
+
(l) => e.mapping[l].colorIdx * 100
|
|
83
83
|
);
|
|
84
84
|
}
|
|
85
85
|
);
|
|
86
86
|
function K(e) {
|
|
87
|
-
e.forEach((
|
|
88
|
-
const t =
|
|
89
|
-
|
|
90
|
-
...
|
|
87
|
+
e.forEach((l, o) => {
|
|
88
|
+
const t = a.modelValue.order[o], n = l / 100;
|
|
89
|
+
a.modelValue.mapping[t].colorIdx !== n && m("update:modelValue", {
|
|
90
|
+
...a.modelValue,
|
|
91
91
|
mapping: {
|
|
92
|
-
...
|
|
92
|
+
...a.modelValue.mapping,
|
|
93
93
|
[t]: {
|
|
94
94
|
colorIdx: n,
|
|
95
95
|
aes: {
|
|
96
|
-
...
|
|
96
|
+
...a.modelValue.mapping[t].aes,
|
|
97
97
|
color: U.value(n)
|
|
98
98
|
}
|
|
99
99
|
}
|
|
@@ -102,107 +102,119 @@ const oe = { class: "aes-mapping-block" }, te = { style: { margin: "0 24px" } },
|
|
|
102
102
|
});
|
|
103
103
|
}
|
|
104
104
|
function W(e) {
|
|
105
|
-
|
|
105
|
+
h.value = "color", c.value = e.status ? a.modelValue.order[e.index] : null;
|
|
106
106
|
}
|
|
107
|
-
function
|
|
107
|
+
function A(e, l) {
|
|
108
108
|
const o = e.order.map((t) => {
|
|
109
|
-
var n,
|
|
109
|
+
var n, r, u, s, P, R;
|
|
110
110
|
return {
|
|
111
|
-
text:
|
|
111
|
+
text: a.columnValueLabels[t],
|
|
112
112
|
value: t,
|
|
113
|
-
dotShape: (
|
|
114
|
-
color: (
|
|
113
|
+
dotShape: (r = (n = e.mapping[t]) == null ? void 0 : n.aes) == null ? void 0 : r.dotShape,
|
|
114
|
+
color: (s = (u = e.mapping[t]) == null ? void 0 : u.aes) == null ? void 0 : s.color,
|
|
115
115
|
lineType: (R = (P = e.mapping[t]) == null ? void 0 : P.aes) == null ? void 0 : R.lineShape
|
|
116
116
|
};
|
|
117
117
|
});
|
|
118
|
-
return
|
|
118
|
+
return l ? o : o.filter((t) => t.value !== "null");
|
|
119
119
|
}
|
|
120
|
-
const
|
|
121
|
-
return
|
|
122
|
-
[() => i.value, () =>
|
|
120
|
+
const y = p(A(a.modelValue, a.allowNullOption)), S = g(() => y.value);
|
|
121
|
+
return w(
|
|
122
|
+
[() => i.value, () => a.allowNullOption],
|
|
123
123
|
() => {
|
|
124
|
-
|
|
124
|
+
y.value = A(a.modelValue, a.allowNullOption);
|
|
125
125
|
},
|
|
126
126
|
{ deep: !0 }
|
|
127
|
-
),
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
127
|
+
), w(
|
|
128
|
+
() => a.modelValue,
|
|
129
|
+
(e) => {
|
|
130
|
+
y.value = y.value.map((l) => {
|
|
131
|
+
var o, t, n, r, u, s;
|
|
132
|
+
return {
|
|
133
|
+
...l,
|
|
134
|
+
dotShape: ((t = (o = e.mapping[l.value]) == null ? void 0 : o.aes) == null ? void 0 : t.dotShape) ?? l.dotShape,
|
|
135
|
+
color: ((r = (n = e.mapping[l.value]) == null ? void 0 : n.aes) == null ? void 0 : r.color) ?? l.color,
|
|
136
|
+
lineType: ((s = (u = e.mapping[l.value]) == null ? void 0 : u.aes) == null ? void 0 : s.lineShape) ?? l.lineType
|
|
137
|
+
};
|
|
138
|
+
});
|
|
139
|
+
},
|
|
140
|
+
{ deep: !0 }
|
|
141
|
+
), w(() => S.value, (e) => {
|
|
142
|
+
const l = e.map((t) => t.value);
|
|
143
|
+
!a.allowNullOption && a.modelValue.order.length > e.length && l.push("null"), (l.length !== a.modelValue.order.length || l.some((t, n) => t !== a.modelValue.order[n])) && m("update:modelValue", { ...a.modelValue, order: l });
|
|
144
|
+
}, { deep: !0 }), (e, l) => (C(), _("div", oe, [
|
|
133
145
|
v("div", te, [
|
|
134
146
|
v("div", ne, [
|
|
135
|
-
v("span", null, z(
|
|
147
|
+
v("span", null, z(d.dataColumnLabel), 1)
|
|
136
148
|
]),
|
|
137
149
|
v("div", ie, [
|
|
138
|
-
|
|
150
|
+
V(Z, {
|
|
139
151
|
label: "Color Palette ",
|
|
140
152
|
icon: "chevron-right",
|
|
141
|
-
title:
|
|
153
|
+
title: k(b)[i.value].title,
|
|
142
154
|
palette: i.value,
|
|
143
|
-
onButtonClick:
|
|
155
|
+
onButtonClick: l[0] || (l[0] = (o) => {
|
|
144
156
|
f.value = !0, N();
|
|
145
157
|
})
|
|
146
158
|
}, null, 8, ["title", "palette"])
|
|
147
159
|
]),
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
modelValue:
|
|
160
|
+
I.value ? O("", !0) : (C(), _("div", ue, [
|
|
161
|
+
V(ee, {
|
|
162
|
+
modelValue: x.value,
|
|
151
163
|
"onUpdate:modelValue": [
|
|
152
|
-
|
|
164
|
+
l[1] || (l[1] = (o) => x.value = o),
|
|
153
165
|
K
|
|
154
166
|
],
|
|
155
|
-
colors:
|
|
167
|
+
colors: k(b)[i.value].colors,
|
|
156
168
|
"get-color-for-percent": H.value,
|
|
157
|
-
active:
|
|
169
|
+
active: B.value,
|
|
158
170
|
onActive: W
|
|
159
171
|
}, null, 8, ["modelValue", "colors", "get-color-for-percent", "active"])
|
|
160
172
|
])),
|
|
161
|
-
f.value ? (
|
|
173
|
+
f.value ? (C(), q(X, {
|
|
162
174
|
key: 1,
|
|
163
175
|
title: "Color Palette",
|
|
164
176
|
"back-title": "Color mapping",
|
|
165
|
-
"onForm:close":
|
|
177
|
+
"onForm:close": l[2] || (l[2] = (o) => f.value = !1)
|
|
166
178
|
}, {
|
|
167
|
-
default:
|
|
168
|
-
|
|
179
|
+
default: E(() => [
|
|
180
|
+
V(Y, {
|
|
169
181
|
selected: i.value,
|
|
170
|
-
onSelect:
|
|
182
|
+
onSelect: D
|
|
171
183
|
}, null, 8, ["selected"])
|
|
172
184
|
]),
|
|
173
185
|
_: 1
|
|
174
|
-
})) :
|
|
186
|
+
})) : O("", !0)
|
|
175
187
|
]),
|
|
176
|
-
|
|
177
|
-
v("div",
|
|
178
|
-
|
|
179
|
-
items:
|
|
180
|
-
"onUpdate:items":
|
|
188
|
+
d.allowReordering ? (C(), _("div", re, " Drag the rows to reorder ")) : O("", !0),
|
|
189
|
+
v("div", se, [
|
|
190
|
+
V(k(ae), {
|
|
191
|
+
items: S.value,
|
|
192
|
+
"onUpdate:items": l[3] || (l[3] = (o) => S.value = o),
|
|
181
193
|
"get-item-key": (o) => o.value,
|
|
182
194
|
"item-class": e.$style.discreteRow,
|
|
183
195
|
"item-class-title": e.$style.discreteRowTitle,
|
|
184
|
-
disableDragging: !
|
|
196
|
+
disableDragging: !d.allowReordering,
|
|
185
197
|
disableRemoving: !0,
|
|
186
198
|
disableToggling: !0,
|
|
187
199
|
disablePinning: !0
|
|
188
200
|
}, {
|
|
189
|
-
"item-title":
|
|
201
|
+
"item-title": E(({ item: o }) => {
|
|
190
202
|
var t;
|
|
191
203
|
return [
|
|
192
|
-
|
|
204
|
+
V(le, {
|
|
193
205
|
item: o,
|
|
194
|
-
"active-value":
|
|
195
|
-
"active-aes-type":
|
|
196
|
-
"used-aes-in-mapping":
|
|
197
|
-
"allow-hiding":
|
|
198
|
-
"allow-reordering":
|
|
199
|
-
hidden: ((t =
|
|
206
|
+
"active-value": c.value,
|
|
207
|
+
"active-aes-type": h.value,
|
|
208
|
+
"used-aes-in-mapping": a.usedAesInMapping,
|
|
209
|
+
"allow-hiding": d.allowHiding ?? !1,
|
|
210
|
+
"allow-reordering": d.allowReordering ?? !1,
|
|
211
|
+
hidden: ((t = a.modelValue.hidden) == null ? void 0 : t[o.value]) ?? !1,
|
|
200
212
|
palette: i.value,
|
|
201
|
-
"is-categorical":
|
|
202
|
-
"on-aes-value-update": (n,
|
|
203
|
-
"on-switch-visibility": () =>
|
|
204
|
-
"on-active-value-change": (n) =>
|
|
205
|
-
"on-active-aes-type-change": (n) =>
|
|
213
|
+
"is-categorical": I.value,
|
|
214
|
+
"on-aes-value-update": (n, r) => F(o.value, n, r),
|
|
215
|
+
"on-switch-visibility": () => M(o),
|
|
216
|
+
"on-active-value-change": (n) => c.value = n,
|
|
217
|
+
"on-active-aes-type-change": (n) => h.value = n,
|
|
206
218
|
"on-close-form": N
|
|
207
219
|
}, null, 8, ["item", "active-value", "active-aes-type", "used-aes-in-mapping", "allow-hiding", "allow-reordering", "hidden", "palette", "is-categorical", "on-aes-value-update", "on-switch-visibility", "on-active-value-change", "on-active-aes-type-change"])
|
|
208
220
|
];
|
|
@@ -214,6 +226,6 @@ const oe = { class: "aes-mapping-block" }, te = { style: { margin: "0 24px" } },
|
|
|
214
226
|
}
|
|
215
227
|
});
|
|
216
228
|
export {
|
|
217
|
-
|
|
229
|
+
we as default
|
|
218
230
|
};
|
|
219
231
|
//# sourceMappingURL=AesDataMappingDiscrete.vue2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AesDataMappingDiscrete.vue2.js","sources":["../../../src/components/AesSettings/AesDataMappingDiscrete.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { scaleLinear } from 'd3-scale';\nimport { computed, ref, watch } from 'vue';\nimport type {\n DotShape,\n LineType,\n Palette,\n} from './types';\nimport {\n isCategorical,\n PALETTE_MAP, UNKNOWN_COLOR,\n} from '../../constantsAesthetic';\nimport type { AesType } from '../../constantsCommon';\nimport type {\n AestheticMappingCategorical,\n} from '../../dataBindAes';\nimport {\n createCategoricalMappingFromPalette,\n} from '../../dataBindAes';\nimport FormWrapper from './FormWrapper.vue';\nimport PalettesForm from './PalettesForm.vue';\nimport MultiselectButton from '../MultiselectButton.vue';\nimport PlColorSlider from '../PlColorSlider.vue';\nimport DiscreteRow from './DiscreteRow.vue';\nimport { PlElementList } from '@platforma-sdk/ui-vue';\n\nconst props = defineProps<{\n dataColumnLabel: string;\n columnValueLabels: Record<string, string>;\n usedAesInMapping: Record<AesType, boolean>;\n modelValue: AestheticMappingCategorical;\n allowReordering?: boolean;\n allowHiding?: boolean;\n allowNullOption?: boolean;\n}>();\n\nconst emit = defineEmits(['update:modelValue']);\n\nconst palettesOpen = ref(false);\nconst palette = ref<Palette>(props.modelValue.palette);\nconst categorical = computed(() => isCategorical(palette.value));\n\ntype EditableAesType = 'color' | 'dotShape' | 'lineType';\n\nconst activeValue = ref<string | null>(null);\nconst activeValueIndex = computed(() => {\n if (activeValue.value === null) {\n return null;\n }\n return props.modelValue.order.indexOf(activeValue.value);\n});\nconst activeAesType = ref<EditableAesType | null>(null);\n\nfunction onPaletteSelect(value: Palette) {\n palette.value = value;\n palettesOpen.value = false;\n emit(\n 'update:modelValue',\n createCategoricalMappingFromPalette(value, props.modelValue.order),\n );\n}\n\nfunction onAesValueUpdate(\n value: string | number,\n aesField: string,\n aesValue: string | DotShape | LineType,\n) {\n emit('update:modelValue', {\n ...props.modelValue,\n mapping: {\n ...props.modelValue.mapping,\n [value]: {\n ...props.modelValue.mapping[value],\n aes: {\n ...props.modelValue.mapping[value].aes,\n [aesField]: aesValue,\n },\n },\n },\n });\n}\n\nfunction closeForm() {\n activeValue.value = null;\n activeAesType.value = null;\n}\n\nfunction switchVisibility(option: { value: string }) {\n emit('update:modelValue', {\n ...props.modelValue,\n hidden: {\n ...props.modelValue.hidden,\n [option.value]: props.modelValue.hidden?.[option.value] ? false : true,\n },\n });\n}\n\nfunction getColorScale(colors: string[], unknownColor: string, from = 0, to = 1) {\n const colorStep = 1 / (colors.length - 1);\n const scale = scaleLinear<string, string>()\n .domain(colors.map((_c, idx) => from + idx * colorStep * (to - from)))\n .range(colors);\n return (v: number) => {\n if (v > to || v < from) {\n return unknownColor;\n }\n return scale(v);\n };\n}\n\nconst continuousColorScale = computed(() =>\n getColorScale(PALETTE_MAP[palette.value].colors, UNKNOWN_COLOR),\n);\n\nconst colorForPercent = computed(() =>\n getColorScale(PALETTE_MAP[palette.value].colors, UNKNOWN_COLOR, 0, 100),\n);\nconst continuousMappingItems = ref(\n props.modelValue.order.map(\n (item) => props.modelValue.mapping[item].colorIdx * 100,\n ),\n);\nwatch(\n () => props.modelValue,\n (v) => {\n continuousMappingItems.value = v.order.map(\n (item) => v.mapping[item].colorIdx * 100,\n );\n },\n);\nfunction updateContinuousColors(v: number[]) {\n v.forEach((value, idx) => {\n const item = props.modelValue.order[idx];\n const newColorIdx = value / 100;\n if (props.modelValue.mapping[item].colorIdx !== newColorIdx) {\n emit('update:modelValue', {\n ...props.modelValue,\n mapping: {\n ...props.modelValue.mapping,\n [item]: {\n colorIdx: newColorIdx,\n aes: {\n ...props.modelValue.mapping[item].aes,\n color: continuousColorScale.value(newColorIdx),\n },\n },\n },\n });\n }\n });\n}\n\nfunction setActiveElementFromColorSlider(e: { index: number; status: boolean }) {\n activeAesType.value = 'color';\n activeValue.value = e.status ? props.modelValue.order[e.index] : null;\n}\n\nfunction getOptionsList(data: AestheticMappingCategorical, allowNullOption: boolean) {\n const options = data.order.map((value: string) => {\n return {\n text: props.columnValueLabels[value],\n value,\n dotShape: data.mapping[value]?.aes?.dotShape,\n color: data.mapping[value]?.aes?.color,\n lineType: data.mapping[value]?.aes?.lineShape,\n };\n });\n return allowNullOption ? options : options.filter((op) => op.value !== 'null');\n}\n\nconst optionsList = ref(getOptionsList(props.modelValue, props.allowNullOption));\nconst reordarableItems = computed(() => optionsList.value);\n\nwatch(\n [() => palette.value, () => props.allowNullOption],\n () => {\n optionsList.value = getOptionsList(props.modelValue, props.allowNullOption);\n },\n { deep: true },\n);\nwatch(() => reordarableItems.value, (v) => {\n emit('update:modelValue', {\n ...props.modelValue,\n order: v.map((item) => item.value),\n });\n}, { deep: true });\n</script>\n\n<template>\n <div class=\"aes-mapping-block\">\n <div style=\"margin: 0 24px\">\n <div class=\"section-title\">\n <span>{{ dataColumnLabel }}</span>\n </div>\n <div style=\"margin: 24px 0\">\n <MultiselectButton\n label=\"Color Palette \" icon=\"chevron-right\" :title=\"PALETTE_MAP[palette].title\"\n :palette=\"palette\" @button-click=\"\n palettesOpen = true;\n closeForm();\n \"\n />\n </div>\n <div v-if=\"!categorical\" style=\"margin: 24px 0\">\n <PlColorSlider\n v-model=\"continuousMappingItems\" :colors=\"PALETTE_MAP[palette].colors\"\n :get-color-for-percent=\"colorForPercent\" :active=\"activeValueIndex\" @active=\"setActiveElementFromColorSlider\"\n @update:model-value=\"updateContinuousColors\"\n />\n </div>\n <FormWrapper\n v-if=\"palettesOpen\" title=\"Color Palette\" back-title=\"Color mapping\"\n @form:close=\"palettesOpen = false\"\n >\n <PalettesForm :selected=\"palette\" @select=\"onPaletteSelect\" />\n </FormWrapper>\n </div>\n <div v-if=\"allowReordering\" class=\"aes-settings-hint\">\n Drag the rows to reorder\n </div>\n <div class=\"column-values-list\">\n <PlElementList\n v-model:items=\"reordarableItems\"\n :get-item-key=\"(item) => item.value\"\n :item-class=\"$style.discreteRow\"\n :item-class-title=\"$style.discreteRowTitle\"\n :disableDragging=\"!allowReordering\"\n :disableRemoving=\"true\"\n :disableToggling=\"true\"\n :disablePinning=\"true\"\n >\n <template #item-title=\"{ item }\">\n <DiscreteRow\n :item=\"item\"\n :active-value=\"activeValue\"\n :active-aes-type=\"activeAesType\"\n :used-aes-in-mapping=\"props.usedAesInMapping\"\n :allow-hiding=\"allowHiding ?? false\"\n :allow-reordering=\"allowReordering ?? false\"\n :hidden=\"props.modelValue.hidden?.[item.value] ?? false\"\n :palette=\"palette\"\n :is-categorical=\"categorical\"\n :on-aes-value-update=\"(field: string, value: string | DotShape | LineType) => onAesValueUpdate(item.value, field, value)\"\n :on-switch-visibility=\"() => switchVisibility(item)\" :on-active-value-change=\"(v) => activeValue = v\"\n :on-active-aes-type-change=\"(v) => activeAesType = v\" :on-close-form=\"closeForm\"\n />\n </template>\n </PlElementList>\n </div>\n </div>\n</template>\n<style module>\n:global(.graph-maker) .discreteRow {\n background-color: var(--color-ic-00);\n border-color: var(--color-div-grey);\n}\n:global(.graph-maker) .discreteRow:hover {\n --head-background: var(--color-ic-00);\n}\n:global(.graph-maker) .discreteRowTitle,\n:global(.sortable-chosen) .discreteRowTitle {\n padding-top: 0;\n padding-bottom: 0;\n background-color: var(--color-ic-00);\n}\n:global(.graph-maker) .discreteRow:hover .discreteRowTitle {\n background-color: var(--color-ic-00);\n}\n</style>\n"],"names":["props","__props","emit","__emit","palettesOpen","ref","palette","categorical","computed","isCategorical","activeValue","activeValueIndex","activeAesType","onPaletteSelect","value","createCategoricalMappingFromPalette","onAesValueUpdate","aesField","aesValue","closeForm","switchVisibility","option","_a","getColorScale","colors","unknownColor","from","to","colorStep","scale","scaleLinear","_c","idx","v","continuousColorScale","PALETTE_MAP","UNKNOWN_COLOR","colorForPercent","continuousMappingItems","item","watch","updateContinuousColors","newColorIdx","setActiveElementFromColorSlider","getOptionsList","data","allowNullOption","options","_b","_d","_f","_e","op","optionsList","reordarableItems","_openBlock","_createElementBlock","_hoisted_1","_createElementVNode","_hoisted_2","_hoisted_3","_hoisted_4","_createVNode","MultiselectButton","_unref","_cache","$event","_hoisted_5","PlColorSlider","_createBlock","FormWrapper","PalettesForm","_hoisted_6","_hoisted_7","PlElementList","$style","_withCtx","DiscreteRow","field"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"AesDataMappingDiscrete.vue2.js","sources":["../../../src/components/AesSettings/AesDataMappingDiscrete.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { scaleLinear } from 'd3-scale';\nimport { computed, ref, watch } from 'vue';\nimport type {\n DotShape,\n LineType,\n Palette,\n} from './types';\nimport {\n isCategorical,\n PALETTE_MAP, UNKNOWN_COLOR,\n} from '../../constantsAesthetic';\nimport type { AesType } from '../../constantsCommon';\nimport type {\n AestheticMappingCategorical,\n} from '../../dataBindAes';\nimport {\n changePaletteInExistingCategoricalMapping,\n} from '../../dataBindAes';\nimport FormWrapper from './FormWrapper.vue';\nimport PalettesForm from './PalettesForm.vue';\nimport MultiselectButton from '../MultiselectButton.vue';\nimport PlColorSlider from '../PlColorSlider.vue';\nimport DiscreteRow from './DiscreteRow.vue';\nimport { PlElementList } from '@platforma-sdk/ui-vue';\n\nconst props = defineProps<{\n dataColumnLabel: string;\n columnValueLabels: Record<string, string>;\n usedAesInMapping: Record<AesType, boolean>;\n modelValue: AestheticMappingCategorical;\n allowReordering?: boolean;\n allowHiding?: boolean;\n allowNullOption?: boolean;\n}>();\n\nconst emit = defineEmits(['update:modelValue']);\n\nconst palettesOpen = ref(false);\nconst palette = ref<Palette>(props.modelValue.palette);\nconst categorical = computed(() => isCategorical(palette.value));\n\ntype EditableAesType = 'color' | 'dotShape' | 'lineType';\n\nconst activeValue = ref<string | null>(null);\nconst activeValueIndex = computed(() => {\n if (activeValue.value === null) {\n return null;\n }\n return props.modelValue.order.indexOf(activeValue.value);\n});\nconst activeAesType = ref<EditableAesType | null>(null);\n\nfunction onPaletteSelect(value: Palette) {\n palette.value = value;\n palettesOpen.value = false;\n emit(\n 'update:modelValue',\n changePaletteInExistingCategoricalMapping(value, props.modelValue),\n );\n}\n\nfunction onAesValueUpdate(\n value: string | number,\n aesField: string,\n aesValue: string | DotShape | LineType,\n) {\n emit('update:modelValue', {\n ...props.modelValue,\n mapping: {\n ...props.modelValue.mapping,\n [value]: {\n ...props.modelValue.mapping[value],\n aes: {\n ...props.modelValue.mapping[value].aes,\n [aesField]: aesValue,\n },\n },\n },\n });\n}\n\nfunction closeForm() {\n activeValue.value = null;\n activeAesType.value = null;\n}\n\nfunction switchVisibility(option: { value: string }) {\n emit('update:modelValue', {\n ...props.modelValue,\n hidden: {\n ...props.modelValue.hidden,\n [option.value]: props.modelValue.hidden?.[option.value] ? false : true,\n },\n });\n}\n\nfunction getColorScale(colors: string[], unknownColor: string, from = 0, to = 1) {\n const colorStep = 1 / (colors.length - 1);\n const scale = scaleLinear<string, string>()\n .domain(colors.map((_c, idx) => from + idx * colorStep * (to - from)))\n .range(colors);\n return (v: number) => {\n if (v > to || v < from) {\n return unknownColor;\n }\n return scale(v);\n };\n}\n\nconst continuousColorScale = computed(() =>\n getColorScale(PALETTE_MAP[palette.value].colors, UNKNOWN_COLOR),\n);\n\nconst colorForPercent = computed(() =>\n getColorScale(PALETTE_MAP[palette.value].colors, UNKNOWN_COLOR, 0, 100),\n);\nconst continuousMappingItems = ref(\n props.modelValue.order.map(\n (item) => props.modelValue.mapping[item].colorIdx * 100,\n ),\n);\nwatch(\n () => props.modelValue,\n (v) => {\n continuousMappingItems.value = v.order.map(\n (item) => v.mapping[item].colorIdx * 100,\n );\n },\n);\nfunction updateContinuousColors(v: number[]) {\n v.forEach((value, idx) => {\n const item = props.modelValue.order[idx];\n const newColorIdx = value / 100;\n if (props.modelValue.mapping[item].colorIdx !== newColorIdx) {\n emit('update:modelValue', {\n ...props.modelValue,\n mapping: {\n ...props.modelValue.mapping,\n [item]: {\n colorIdx: newColorIdx,\n aes: {\n ...props.modelValue.mapping[item].aes,\n color: continuousColorScale.value(newColorIdx),\n },\n },\n },\n });\n }\n });\n}\n\nfunction setActiveElementFromColorSlider(e: { index: number; status: boolean }) {\n activeAesType.value = 'color';\n activeValue.value = e.status ? props.modelValue.order[e.index] : null;\n}\n\nfunction getOptionsList(data: AestheticMappingCategorical, allowNullOption: boolean) {\n const options = data.order.map((value: string) => {\n return {\n text: props.columnValueLabels[value],\n value,\n dotShape: data.mapping[value]?.aes?.dotShape,\n color: data.mapping[value]?.aes?.color,\n lineType: data.mapping[value]?.aes?.lineShape,\n };\n });\n return allowNullOption ? options : options.filter((op) => op.value !== 'null');\n}\n\nconst optionsList = ref(getOptionsList(props.modelValue, props.allowNullOption));\nconst reordarableItems = computed(() => optionsList.value);\n\nwatch(\n [() => palette.value, () => props.allowNullOption],\n () => {\n optionsList.value = getOptionsList(props.modelValue, props.allowNullOption);\n },\n { deep: true },\n);\nwatch(\n () => props.modelValue,\n (newModel) => {\n optionsList.value = optionsList.value.map((item) => ({\n ...item,\n dotShape: newModel.mapping[item.value]?.aes?.dotShape ?? item.dotShape,\n color: newModel.mapping[item.value]?.aes?.color ?? item.color,\n lineType: newModel.mapping[item.value]?.aes?.lineShape ?? item.lineType,\n }));\n },\n { deep: true },\n);\nwatch(() => reordarableItems.value, (v) => {\n const newOrder = v.map((item) => item.value);\n if (!props.allowNullOption && props.modelValue.order.length > v.length) {\n newOrder.push('null');\n }\n const orderChanged\n = newOrder.length !== props.modelValue.order.length\n || newOrder.some((val, idx) => val !== props.modelValue.order[idx]);\n if (!orderChanged) return;\n emit('update:modelValue', { ...props.modelValue, order: newOrder });\n}, { deep: true });\n</script>\n\n<template>\n <div class=\"aes-mapping-block\">\n <div style=\"margin: 0 24px\">\n <div class=\"section-title\">\n <span>{{ dataColumnLabel }}</span>\n </div>\n <div style=\"margin: 24px 0\">\n <MultiselectButton\n label=\"Color Palette \" icon=\"chevron-right\" :title=\"PALETTE_MAP[palette].title\"\n :palette=\"palette\" @button-click=\"\n palettesOpen = true;\n closeForm();\n \"\n />\n </div>\n <div v-if=\"!categorical\" style=\"margin: 24px 0\">\n <PlColorSlider\n v-model=\"continuousMappingItems\" :colors=\"PALETTE_MAP[palette].colors\"\n :get-color-for-percent=\"colorForPercent\" :active=\"activeValueIndex\" @active=\"setActiveElementFromColorSlider\"\n @update:model-value=\"updateContinuousColors\"\n />\n </div>\n <FormWrapper\n v-if=\"palettesOpen\" title=\"Color Palette\" back-title=\"Color mapping\"\n @form:close=\"palettesOpen = false\"\n >\n <PalettesForm :selected=\"palette\" @select=\"onPaletteSelect\" />\n </FormWrapper>\n </div>\n <div v-if=\"allowReordering\" class=\"aes-settings-hint\">\n Drag the rows to reorder\n </div>\n <div class=\"column-values-list\">\n <PlElementList\n v-model:items=\"reordarableItems\"\n :get-item-key=\"(item) => item.value\"\n :item-class=\"$style.discreteRow\"\n :item-class-title=\"$style.discreteRowTitle\"\n :disableDragging=\"!allowReordering\"\n :disableRemoving=\"true\"\n :disableToggling=\"true\"\n :disablePinning=\"true\"\n >\n <template #item-title=\"{ item }\">\n <DiscreteRow\n :item=\"item\"\n :active-value=\"activeValue\"\n :active-aes-type=\"activeAesType\"\n :used-aes-in-mapping=\"props.usedAesInMapping\"\n :allow-hiding=\"allowHiding ?? false\"\n :allow-reordering=\"allowReordering ?? false\"\n :hidden=\"props.modelValue.hidden?.[item.value] ?? false\"\n :palette=\"palette\"\n :is-categorical=\"categorical\"\n :on-aes-value-update=\"(field: string, value: string | DotShape | LineType) => onAesValueUpdate(item.value, field, value)\"\n :on-switch-visibility=\"() => switchVisibility(item)\" :on-active-value-change=\"(v) => activeValue = v\"\n :on-active-aes-type-change=\"(v) => activeAesType = v\" :on-close-form=\"closeForm\"\n />\n </template>\n </PlElementList>\n </div>\n </div>\n</template>\n<style module>\n:global(.graph-maker) .discreteRow {\n background-color: var(--color-ic-00);\n border-color: var(--color-div-grey);\n}\n:global(.graph-maker) .discreteRow:hover {\n --head-background: var(--color-ic-00);\n}\n:global(.graph-maker) .discreteRowTitle,\n:global(.sortable-chosen) .discreteRowTitle {\n padding-top: 0;\n padding-bottom: 0;\n background-color: var(--color-ic-00);\n}\n:global(.graph-maker) .discreteRow:hover .discreteRowTitle {\n background-color: var(--color-ic-00);\n}\n</style>\n"],"names":["props","__props","emit","__emit","palettesOpen","ref","palette","categorical","computed","isCategorical","activeValue","activeValueIndex","activeAesType","onPaletteSelect","value","changePaletteInExistingCategoricalMapping","onAesValueUpdate","aesField","aesValue","closeForm","switchVisibility","option","_a","getColorScale","colors","unknownColor","from","to","colorStep","scale","scaleLinear","_c","idx","v","continuousColorScale","PALETTE_MAP","UNKNOWN_COLOR","colorForPercent","continuousMappingItems","item","watch","updateContinuousColors","newColorIdx","setActiveElementFromColorSlider","getOptionsList","data","allowNullOption","options","_b","_d","_f","_e","op","optionsList","reordarableItems","newModel","newOrder","val","_openBlock","_createElementBlock","_hoisted_1","_createElementVNode","_hoisted_2","_hoisted_3","_hoisted_4","_createVNode","MultiselectButton","_unref","_cache","$event","_hoisted_5","PlColorSlider","_createBlock","FormWrapper","PalettesForm","_hoisted_6","_hoisted_7","PlElementList","$style","_withCtx","DiscreteRow","field"],"mappings":"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"}
|
package/dist/dataBindAes.d.ts
CHANGED
|
@@ -52,6 +52,7 @@ export declare const DEFAULT_NA_AES: {
|
|
|
52
52
|
dotShape: DotShape;
|
|
53
53
|
};
|
|
54
54
|
export declare function createCategoricalMappingFromPalette(palette: Palette, values: string[]): AestheticMappingCategorical;
|
|
55
|
+
export declare function changePaletteInExistingCategoricalMapping(newPalette: Palette, currentMapping: AestheticMappingCategorical): AestheticMappingCategorical;
|
|
55
56
|
export declare function updateDataBindAes(optionsState: InputState, dataBindAes: Record<string, AestheticMapping>, uniqueValuesMap: UniqueValuesBySourceMap): void;
|
|
56
57
|
export declare function updateCategoricalMapping(newUniqueValues: string[], currentMapping: AestheticMappingCategorical): AestheticMappingCategorical;
|
|
57
58
|
export declare function createContinuousMappingFromPalette(palette: ContinuousPalette): AestheticMappingContinuous;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dataBindAes.d.ts","sourceRoot":"","sources":["../src/dataBindAes.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"dataBindAes.d.ts","sourceRoot":"","sources":["../src/dataBindAes.ts"],"names":[],"mappings":"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"}
|