@opengis/partsmap 0.1.0 → 0.1.2
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/index.js +1653 -1606
- package/index.umd.cjs +1 -1
- package/package.json +1 -1
package/index.js
CHANGED
@@ -1,13 +1,13 @@
|
|
1
|
-
import { defineComponent as
|
2
|
-
const
|
1
|
+
import { defineComponent as Y, ref as V, watch as A, createBlock as z, openBlock as p, resolveDynamicComponent as oe, mergeProps as Z, withCtx as re, renderSlot as ee, computed as E, useSlots as we, createElementBlock as w, createCommentVNode as S, Fragment as F, renderList as q, unref as e, createElementVNode as o, normalizeClass as j, toDisplayString as K, createVNode as P, createTextVNode as W, toRaw as fe, cloneVNode as Ge, nextTick as ke, onMounted as ue, onBeforeUnmount as he, Teleport as Ue, withDirectives as I, normalizeStyle as _e, vShow as X, vModelText as te, withModifiers as Oe, isRef as Qe, createStaticVNode as Pe, resolveDirective as Ze } from "vue";
|
2
|
+
const Je = { class: "flex items-center justify-between w-full text-sm" }, Xe = { class: "flex items-center cursor-pointer w-full" }, et = {
|
3
3
|
key: 0,
|
4
4
|
width: "16",
|
5
5
|
height: "auto",
|
6
6
|
src: "data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTYgMTYnIGZpbGw9J3doaXRlJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnPjxwYXRoIGQ9J00xMi4yMDcgNC43OTNhMSAxIDAgMDEwIDEuNDE0bC01IDVhMSAxIDAgMDEtMS40MTQgMGwtMi0yYTEgMSAwIDAxMS40MTQtMS40MTRMNi41IDkuMDg2bDQuMjkzLTQuMjkzYTEgMSAwIDAxMS40MTQgMHonLz48L3N2Zz4="
|
7
|
-
},
|
7
|
+
}, tt = ["value"], lt = { class: "w-[calc(100%-18px)] flex flex-row items-center justify-between pl-[10px]" }, at = { class: "flex flex-row items-center font-normal text-gray-800 gap-x-1" }, ot = {
|
8
8
|
key: 0,
|
9
9
|
class: "text-xs text-gray-500 dark:text-neutral-500 pr-1"
|
10
|
-
}, Ce = /* @__PURE__ */
|
10
|
+
}, Ce = /* @__PURE__ */ Y({
|
11
11
|
__name: "list-item",
|
12
12
|
props: {
|
13
13
|
layout: {},
|
@@ -20,44 +20,44 @@ const Ne = { class: "flex items-center justify-between w-full text-sm" }, Ge = {
|
|
20
20
|
highlighted: { type: Boolean }
|
21
21
|
},
|
22
22
|
emits: ["itemClick"],
|
23
|
-
setup(
|
24
|
-
const l =
|
23
|
+
setup(i, { expose: r, emit: d }) {
|
24
|
+
const l = i, a = d;
|
25
25
|
function n() {
|
26
|
-
|
26
|
+
a("itemClick", l.value);
|
27
27
|
}
|
28
|
-
const
|
29
|
-
return r({ el:
|
28
|
+
const m = V(null);
|
29
|
+
return r({ el: m }), (h, g) => (p(), w("div", {
|
30
30
|
class: "flex items-center w-full rounded-lg group hover:bg-gray-100",
|
31
31
|
ref_key: "el",
|
32
|
-
ref:
|
32
|
+
ref: m
|
33
33
|
}, [
|
34
|
-
|
35
|
-
|
36
|
-
|
34
|
+
o("div", Je, [
|
35
|
+
o("div", Xe, [
|
36
|
+
o("label", {
|
37
37
|
for: "radio-9740",
|
38
|
-
class:
|
39
|
-
["inline", "popover"].includes(
|
40
|
-
{ "bg-blue-100":
|
38
|
+
class: j([
|
39
|
+
["inline", "popover"].includes(h.layout) ? "text-sm text-gray-500 px-2 w-full py-2 cursor-pointer !flex flex-row items-center" : "flex flex-row items-center w-full px-2 py-2 text-sm text-gray-500 cursor-pointer",
|
40
|
+
{ "bg-blue-100": h.highlighted }
|
41
41
|
]),
|
42
|
-
onClick:
|
42
|
+
onClick: Oe(n, ["stop", "prevent"])
|
43
43
|
}, [
|
44
|
-
|
45
|
-
class:
|
46
|
-
|
47
|
-
|
44
|
+
o("div", {
|
45
|
+
class: j(["w-[18px] h-[18px] border flex items-center justify-center", [
|
46
|
+
h.type == "checkbox" ? "rounded-[4px]" : "rounded-full",
|
47
|
+
h.color ? `bg-[${h.color}] border-[#ffffff]` : h.isSelected ? "bg-[#2563eb] border-[#ffffff]" : "bg-[#ffffff] border-[#d9d9d9]"
|
48
48
|
]])
|
49
49
|
}, [
|
50
|
-
|
50
|
+
h.isSelected ? (p(), w("img", et)) : S("", !0)
|
51
51
|
], 2),
|
52
|
-
|
52
|
+
o("input", {
|
53
53
|
type: "checkbox",
|
54
54
|
class: "hidden",
|
55
55
|
id: "radio-9740",
|
56
|
-
value:
|
57
|
-
}, null, 8,
|
58
|
-
|
59
|
-
|
60
|
-
|
56
|
+
value: h.value
|
57
|
+
}, null, 8, tt),
|
58
|
+
o("div", lt, [
|
59
|
+
o("span", at, K(h.label ?? "Відсутні данні"), 1),
|
60
|
+
h.count ? (p(), w("div", ot, " (" + K(h.count) + ") ", 1)) : S("", !0)
|
61
61
|
])
|
62
62
|
], 2)
|
63
63
|
])
|
@@ -65,75 +65,75 @@ const Ne = { class: "flex items-center justify-between w-full text-sm" }, Ge = {
|
|
65
65
|
], 512));
|
66
66
|
}
|
67
67
|
});
|
68
|
-
function
|
68
|
+
function Ie(i, r) {
|
69
69
|
const {
|
70
|
-
options:
|
70
|
+
options: d = [],
|
71
71
|
limit: l = 20
|
72
|
-
} =
|
73
|
-
function
|
74
|
-
return Array.isArray(
|
75
|
-
}
|
76
|
-
const n = V(
|
77
|
-
function C(
|
78
|
-
const _ =
|
79
|
-
return { autoValueKey:
|
80
|
-
}
|
81
|
-
if (
|
82
|
-
const
|
83
|
-
k.value =
|
84
|
-
}
|
85
|
-
const
|
86
|
-
const
|
87
|
-
return
|
72
|
+
} = i;
|
73
|
+
function a(u) {
|
74
|
+
return Array.isArray(u) ? u[0] : u;
|
75
|
+
}
|
76
|
+
const n = V(a(i.modelValue)), m = V(""), h = V(!1), g = V([]), k = V("id"), b = V("text"), f = V(!1), y = V(i.layout !== "popover" && d.length > l);
|
77
|
+
function C(u) {
|
78
|
+
const _ = u.find(Boolean) ?? {}, B = ["id", "value", "code", "key"].find((L) => L in _) ?? "id", M = ["text", "label", "name", "title"].find((L) => L in _) ?? "text";
|
79
|
+
return { autoValueKey: B, autoLabelKey: M };
|
80
|
+
}
|
81
|
+
if (d.length > 0) {
|
82
|
+
const u = C(d);
|
83
|
+
k.value = u.autoValueKey, b.value = u.autoLabelKey;
|
84
|
+
}
|
85
|
+
const c = E(() => {
|
86
|
+
const u = g.value;
|
87
|
+
return i.layout === "popover" || f.value ? u : u.slice(0, l);
|
88
88
|
});
|
89
|
-
|
90
|
-
n.value =
|
91
|
-
}, { immediate: !0 }),
|
92
|
-
function
|
93
|
-
return n.value ===
|
89
|
+
A(() => i.modelValue, (u) => {
|
90
|
+
n.value = a(u);
|
91
|
+
}, { immediate: !0 }), g.value = [...d].sort((u, _) => i.sort === "count" ? _.count && u.count ? _.count - u.count : 0 : i.sort === "name" ? String(u[b.value] ?? "").localeCompare(String(_[b.value] ?? "")) : 0);
|
92
|
+
function s(u) {
|
93
|
+
return n.value === u[k.value];
|
94
94
|
}
|
95
|
-
function t(
|
96
|
-
n.value =
|
95
|
+
function t(u) {
|
96
|
+
n.value = u[k.value], r("update:modelValue", n.value), r("change", { name: i.name, value: n.value });
|
97
97
|
}
|
98
|
-
function
|
99
|
-
n.value = void 0, r("update:modelValue", n.value), r("clear",
|
98
|
+
function x() {
|
99
|
+
n.value = void 0, r("update:modelValue", n.value), r("clear", i.name);
|
100
100
|
}
|
101
|
-
function
|
102
|
-
|
101
|
+
function v() {
|
102
|
+
f.value = !f.value;
|
103
103
|
}
|
104
104
|
return {
|
105
105
|
innerValue: n,
|
106
|
-
searchTerm:
|
107
|
-
filteredOptions:
|
108
|
-
isSelected:
|
106
|
+
searchTerm: m,
|
107
|
+
filteredOptions: c,
|
108
|
+
isSelected: s,
|
109
109
|
selectItem: t,
|
110
|
-
clear:
|
111
|
-
toggleShowAll:
|
112
|
-
isReqProc:
|
113
|
-
showAll:
|
114
|
-
isEnableShowAll:
|
115
|
-
labelKey:
|
110
|
+
clear: x,
|
111
|
+
toggleShowAll: v,
|
112
|
+
isReqProc: h,
|
113
|
+
showAll: f,
|
114
|
+
isEnableShowAll: y,
|
115
|
+
labelKey: b,
|
116
116
|
valueKey: k,
|
117
|
-
allOptions:
|
117
|
+
allOptions: g
|
118
118
|
};
|
119
119
|
}
|
120
|
-
const le = (
|
121
|
-
const
|
122
|
-
for (const [l,
|
123
|
-
|
124
|
-
return
|
125
|
-
},
|
120
|
+
const le = (i, r) => {
|
121
|
+
const d = i.__vccOpts || i;
|
122
|
+
for (const [l, a] of r)
|
123
|
+
d[l] = a;
|
124
|
+
return d;
|
125
|
+
}, rt = {}, nt = {
|
126
126
|
class: "w-48 mx-auto",
|
127
127
|
viewBox: "0 0 178 90",
|
128
128
|
fill: "none",
|
129
129
|
xmlns: "http://www.w3.org/2000/svg"
|
130
130
|
};
|
131
|
-
function
|
132
|
-
return
|
133
|
-
|
131
|
+
function it(i, r) {
|
132
|
+
return p(), w("svg", nt, r[0] || (r[0] = [
|
133
|
+
Pe('<rect x="27" y="50.5" width="124" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="27" y="50.5" width="124" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-50 dark:stroke-neutral-700/10"></rect><rect x="34.5" y="58" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="61" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="73" width="77" height="6" rx="3" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-100 dark:stroke-neutral-700/30"></rect><rect x="27" y="36" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><rect x="59" y="39" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><rect x="59" y="51" width="92" height="6" rx="3" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><g filter="url(#filter1)"><rect x="12" y="6" width="154" height="40" rx="8" fill="currentColor" class="fill-white dark:fill-neutral-800" shape-rendering="crispEdges"></rect><rect x="12.5" y="6.5" width="153" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-100 dark:stroke-neutral-700/60" shape-rendering="crispEdges"></rect><rect x="20" y="14" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect><rect x="52" y="17" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect><rect x="52" y="29" width="106" height="6" rx="3" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect></g><defs><filter id="filter1" x="0" y="0" width="178" height="64" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB"><feFlood flood-opacity="0" result="BackgroundImageFix"></feFlood><feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"></feColorMatrix><feOffset dy="6"></feOffset><feGaussianBlur stdDeviation="6"></feGaussianBlur><feComposite in2="hardAlpha" operator="out"></feComposite><feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.03 0"></feColorMatrix><feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_1187_14810"></feBlend><feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_1187_14810" result="shape"></feBlend></filter></defs>', 12)
|
134
134
|
]));
|
135
135
|
}
|
136
|
-
const Ve = /* @__PURE__ */ le(
|
136
|
+
const Ve = /* @__PURE__ */ le(rt, [["render", it]]), st = {}, ut = {
|
137
137
|
xmlns: "http://www.w3.org/2000/svg",
|
138
138
|
width: "24",
|
139
139
|
height: "24",
|
@@ -145,17 +145,17 @@ const Ve = /* @__PURE__ */ le(tt, [["render", at]]), ot = {}, rt = {
|
|
145
145
|
"stroke-linejoin": "round",
|
146
146
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-chevron-down w-[14px] rotate"
|
147
147
|
};
|
148
|
-
function
|
149
|
-
return
|
150
|
-
|
148
|
+
function dt(i, r) {
|
149
|
+
return p(), w("svg", ut, r[0] || (r[0] = [
|
150
|
+
o("path", {
|
151
151
|
stroke: "none",
|
152
152
|
d: "M0 0h24v24H0z",
|
153
153
|
fill: "none"
|
154
154
|
}, null, -1),
|
155
|
-
|
155
|
+
o("path", { d: "M6 9l6 6l6 -6" }, null, -1)
|
156
156
|
]));
|
157
157
|
}
|
158
|
-
const be = /* @__PURE__ */ le(
|
158
|
+
const be = /* @__PURE__ */ le(st, [["render", dt]]), ct = {}, pt = {
|
159
159
|
xmlns: "http://www.w3.org/2000/svg",
|
160
160
|
width: "24",
|
161
161
|
height: "24",
|
@@ -167,26 +167,26 @@ const be = /* @__PURE__ */ le(ot, [["render", nt]]), it = {}, st = {
|
|
167
167
|
"stroke-linejoin": "round",
|
168
168
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-chevron-down w-[14px] rotate-[180deg]"
|
169
169
|
};
|
170
|
-
function
|
171
|
-
return
|
172
|
-
|
170
|
+
function ft(i, r) {
|
171
|
+
return p(), w("svg", pt, r[0] || (r[0] = [
|
172
|
+
o("path", {
|
173
173
|
stroke: "none",
|
174
174
|
d: "M0 0h24v24H0z",
|
175
175
|
fill: "none"
|
176
176
|
}, null, -1),
|
177
|
-
|
177
|
+
o("path", { d: "M6 9l6 6l6 -6" }, null, -1)
|
178
178
|
]));
|
179
179
|
}
|
180
|
-
const Se = /* @__PURE__ */ le(
|
180
|
+
const Se = /* @__PURE__ */ le(ct, [["render", ft]]), vt = {
|
181
181
|
key: 0,
|
182
182
|
class: "w-full"
|
183
|
-
},
|
183
|
+
}, mt = { class: "flex flex-col items-center justify-center p-5 text-center" }, gt = {
|
184
184
|
key: 0,
|
185
185
|
class: "flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"
|
186
|
-
},
|
186
|
+
}, ht = {
|
187
187
|
key: 1,
|
188
188
|
class: "flex justify-between items-center text-xs text-gray-500 p-1 border-t"
|
189
|
-
},
|
189
|
+
}, bt = /* @__PURE__ */ Y({
|
190
190
|
__name: "radio",
|
191
191
|
props: {
|
192
192
|
id: {},
|
@@ -212,170 +212,170 @@ const Se = /* @__PURE__ */ le(it, [["render", ut]]), dt = {
|
|
212
212
|
sort: {}
|
213
213
|
},
|
214
214
|
emits: ["update:modelValue", "change", "clear"],
|
215
|
-
setup(
|
216
|
-
const l =
|
217
|
-
innerValue:
|
218
|
-
filteredOptions:
|
219
|
-
isSelected:
|
215
|
+
setup(i, { expose: r, emit: d }) {
|
216
|
+
const l = i, a = V(null), n = d, {
|
217
|
+
innerValue: m,
|
218
|
+
filteredOptions: h,
|
219
|
+
isSelected: g,
|
220
220
|
selectItem: k,
|
221
|
-
clear:
|
222
|
-
toggleShowAll:
|
223
|
-
isReqProc:
|
221
|
+
clear: b,
|
222
|
+
toggleShowAll: f,
|
223
|
+
isReqProc: y,
|
224
224
|
showAll: C,
|
225
|
-
isEnableShowAll:
|
226
|
-
labelKey:
|
225
|
+
isEnableShowAll: c,
|
226
|
+
labelKey: s,
|
227
227
|
valueKey: t,
|
228
|
-
allOptions:
|
229
|
-
} =
|
228
|
+
allOptions: x
|
229
|
+
} = Ie({
|
230
230
|
...l,
|
231
231
|
modelValue: l.modelValue ?? l.default ?? ""
|
232
232
|
}, n);
|
233
233
|
return r({
|
234
|
-
clear:
|
235
|
-
inputTextRef:
|
236
|
-
}),
|
234
|
+
clear: b,
|
235
|
+
inputTextRef: a
|
236
|
+
}), A(
|
237
237
|
() => l.modelValue,
|
238
|
-
(
|
239
|
-
|
238
|
+
(v) => {
|
239
|
+
v === void 0 && (m.value = void 0);
|
240
240
|
}
|
241
|
-
), (
|
242
|
-
class:
|
241
|
+
), (v, u) => (p(), w("div", {
|
242
|
+
class: j([v.layout === "popover" ? "flex flex-col h-full" : "flex flex-col vs-filter-checkbox"])
|
243
243
|
}, [
|
244
|
-
|
245
|
-
class:
|
246
|
-
|
247
|
-
|
244
|
+
o("div", {
|
245
|
+
class: j([
|
246
|
+
v.layout === "popover" ? "flex-1 overflow-y-auto max-h-64 p-2" : "",
|
247
|
+
v.layout === "inline" ? "flex-1 overflow-y-auto max-h-80" : ""
|
248
248
|
])
|
249
249
|
}, [
|
250
|
-
(
|
251
|
-
layout:
|
250
|
+
(p(!0), w(F, null, q(e(h), (_) => (p(), z(Ce, {
|
251
|
+
layout: v.layout,
|
252
252
|
key: _[e(t)],
|
253
253
|
count: _.count,
|
254
|
-
label: _[e(
|
254
|
+
label: _[e(s)],
|
255
255
|
color: _.color,
|
256
256
|
type: "radio",
|
257
257
|
value: _[e(t)],
|
258
|
-
"is-selected": e(
|
259
|
-
onItemClick: (
|
258
|
+
"is-selected": e(g)(_),
|
259
|
+
onItemClick: (B) => e(k)(_)
|
260
260
|
}, null, 8, ["layout", "count", "label", "color", "value", "is-selected", "onItemClick"]))), 128))
|
261
261
|
], 2),
|
262
|
-
|
263
|
-
|
262
|
+
v.type === "select" && e(h).length === 0 && !e(y) ? (p(), w("div", vt, [
|
263
|
+
o("div", mt, [
|
264
264
|
P(Ve),
|
265
|
-
|
266
|
-
|
267
|
-
|
265
|
+
u[4] || (u[4] = o("div", { class: "max-w-sm mx-auto mt-6" }, [
|
266
|
+
o("p", { class: "font-medium text-gray-800 dark:text-neutral-200" }, "За вашим запитом нічого не знайдено"),
|
267
|
+
o("p", { class: "mt-2 text-sm text-gray-500 dark:text-neutral-500" })
|
268
268
|
], -1))
|
269
269
|
])
|
270
270
|
])) : S("", !0),
|
271
|
-
|
272
|
-
!e(C) && e(
|
271
|
+
v.layout !== "popover" && v.type !== "select" ? (p(), w(F, { key: 1 }, [
|
272
|
+
!e(C) && e(c) ? (p(), w("div", {
|
273
273
|
key: 0,
|
274
|
-
onClick:
|
275
|
-
(..._) => e(
|
274
|
+
onClick: u[0] || (u[0] = //@ts-ignore
|
275
|
+
(..._) => e(f) && e(f)(..._)),
|
276
276
|
class: "inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"
|
277
277
|
}, [
|
278
|
-
|
278
|
+
u[5] || (u[5] = W(" Показати більше ", -1)),
|
279
279
|
P(be)
|
280
280
|
])) : S("", !0),
|
281
|
-
e(C) ? (
|
281
|
+
e(C) ? (p(), w("div", {
|
282
282
|
key: 1,
|
283
|
-
onClick:
|
284
|
-
(..._) => e(
|
283
|
+
onClick: u[1] || (u[1] = //@ts-ignore
|
284
|
+
(..._) => e(f) && e(f)(..._)),
|
285
285
|
class: "inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"
|
286
286
|
}, [
|
287
|
-
|
287
|
+
u[6] || (u[6] = W(" Показати менше ", -1)),
|
288
288
|
P(Se)
|
289
289
|
])) : S("", !0)
|
290
290
|
], 64)) : S("", !0),
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
291
|
+
v.cleanable ? (p(), w(F, { key: 2 }, [
|
292
|
+
v.layout === "inline" ? (p(), w("div", gt, [
|
293
|
+
W(K(e(m) || e(m) === null ? 1 : 0) + " з " + K(e(x).length) + " обрано ", 1),
|
294
|
+
I(o("button", {
|
295
295
|
class: "text-gray-600 hover:text-gray-800",
|
296
|
-
onClick:
|
297
|
-
(..._) => e(
|
296
|
+
onClick: u[2] || (u[2] = //@ts-ignore
|
297
|
+
(..._) => e(b) && e(b)(..._))
|
298
298
|
}, " Очистити ", 512), [
|
299
|
-
[X, e(
|
299
|
+
[X, e(m) !== "" && e(m) !== void 0]
|
300
300
|
])
|
301
301
|
])) : S("", !0),
|
302
|
-
|
303
|
-
|
304
|
-
|
302
|
+
v.layout === "popover" ? (p(), w("div", ht, [
|
303
|
+
o("span", null, K(e(m) || e(m) === null ? 1 : 0) + " з " + K(e(x).length) + " обрано", 1),
|
304
|
+
I(o("button", {
|
305
305
|
class: "text-gray-600 hover:text-gray-800",
|
306
|
-
onClick:
|
307
|
-
(..._) => e(
|
306
|
+
onClick: u[3] || (u[3] = //@ts-ignore
|
307
|
+
(..._) => e(b) && e(b)(..._))
|
308
308
|
}, " Очистити ", 512), [
|
309
|
-
[X, e(
|
309
|
+
[X, e(m) !== "" && e(m) !== void 0]
|
310
310
|
])
|
311
311
|
])) : S("", !0)
|
312
312
|
], 64)) : S("", !0)
|
313
313
|
], 2));
|
314
314
|
}
|
315
315
|
});
|
316
|
-
function
|
316
|
+
function Te(i, r) {
|
317
317
|
const {
|
318
|
-
options:
|
318
|
+
options: d = [],
|
319
319
|
limit: l = 20
|
320
|
-
} =
|
321
|
-
function
|
322
|
-
return Array.isArray(
|
323
|
-
}
|
324
|
-
const n = V(
|
325
|
-
function C(
|
326
|
-
const _ =
|
327
|
-
return { autoValueKey:
|
328
|
-
}
|
329
|
-
if (
|
330
|
-
const
|
331
|
-
k.value =
|
332
|
-
}
|
333
|
-
const
|
334
|
-
const
|
335
|
-
return
|
320
|
+
} = i;
|
321
|
+
function a(u) {
|
322
|
+
return Array.isArray(u) ? u : u ? [u] : [];
|
323
|
+
}
|
324
|
+
const n = V(a(i.modelValue)), m = V(""), h = V(!1), g = V([]), k = V("id"), b = V("text"), f = V(!1), y = V(i.layout !== "popover" && d.length > l);
|
325
|
+
function C(u) {
|
326
|
+
const _ = u.find(Boolean) ?? {}, B = ["id", "value", "code", "key"].find((L) => L in _) ?? "id", M = ["text", "label", "name", "title"].find((L) => L in _) ?? "text";
|
327
|
+
return { autoValueKey: B, autoLabelKey: M };
|
328
|
+
}
|
329
|
+
if (d.length > 0) {
|
330
|
+
const u = C(d);
|
331
|
+
k.value = u.autoValueKey, b.value = u.autoLabelKey;
|
332
|
+
}
|
333
|
+
const c = E(() => {
|
334
|
+
const u = g.value;
|
335
|
+
return i.layout === "popover" || f.value ? u : u.slice(0, l);
|
336
336
|
});
|
337
|
-
|
338
|
-
n.value =
|
339
|
-
}, { immediate: !0 }),
|
340
|
-
function
|
341
|
-
return n.value && n.value.includes(
|
337
|
+
A(() => i.modelValue, (u) => {
|
338
|
+
n.value = a(u);
|
339
|
+
}, { immediate: !0 }), g.value = [...d].sort((u, _) => i.sort === "count" ? _.count && u.count ? _.count - u.count : 0 : i.sort === "name" ? String(u[b.value]).localeCompare(String(_[b.value])) : 0);
|
340
|
+
function s(u) {
|
341
|
+
return n.value && n.value.includes(u[k.value]);
|
342
342
|
}
|
343
|
-
function t(
|
344
|
-
const _ = n.value.includes(
|
345
|
-
n.value = _ ? n.value.filter((
|
343
|
+
function t(u) {
|
344
|
+
const _ = n.value.includes(u[k.value]);
|
345
|
+
n.value = _ ? n.value.filter((B) => B !== u[k.value]) : [...n.value, u[k.value]], r("update:modelValue", n.value), r("change", { name: i.name, value: n.value });
|
346
346
|
}
|
347
|
-
function
|
348
|
-
n.value = [], r("update:modelValue", n.value), r("clear",
|
347
|
+
function x() {
|
348
|
+
n.value = [], r("update:modelValue", n.value), r("clear", i.name);
|
349
349
|
}
|
350
|
-
function
|
351
|
-
|
350
|
+
function v() {
|
351
|
+
f.value = !f.value;
|
352
352
|
}
|
353
353
|
return {
|
354
354
|
innerValue: n,
|
355
|
-
searchTerm:
|
356
|
-
filteredOptions:
|
357
|
-
isSelected:
|
355
|
+
searchTerm: m,
|
356
|
+
filteredOptions: c,
|
357
|
+
isSelected: s,
|
358
358
|
selectItem: t,
|
359
|
-
clear:
|
360
|
-
toggleShowAll:
|
361
|
-
isReqProc:
|
362
|
-
showAll:
|
363
|
-
isEnableShowAll:
|
364
|
-
labelKey:
|
359
|
+
clear: x,
|
360
|
+
toggleShowAll: v,
|
361
|
+
isReqProc: h,
|
362
|
+
showAll: f,
|
363
|
+
isEnableShowAll: y,
|
364
|
+
labelKey: b,
|
365
365
|
valueKey: k,
|
366
|
-
allOptions:
|
366
|
+
allOptions: g
|
367
367
|
};
|
368
368
|
}
|
369
|
-
const
|
369
|
+
const yt = {
|
370
370
|
key: 0,
|
371
371
|
class: "w-full"
|
372
|
-
},
|
372
|
+
}, xt = { class: "flex flex-col items-center justify-center p-5 text-center" }, wt = {
|
373
373
|
key: 0,
|
374
374
|
class: "flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"
|
375
|
-
},
|
375
|
+
}, kt = {
|
376
376
|
key: 1,
|
377
377
|
class: "flex justify-between items-center text-xs text-gray-500 p-1 border-t"
|
378
|
-
},
|
378
|
+
}, ze = /* @__PURE__ */ Y({
|
379
379
|
__name: "checkbox",
|
380
380
|
props: {
|
381
381
|
id: {},
|
@@ -401,97 +401,97 @@ const mt = {
|
|
401
401
|
sort: {}
|
402
402
|
},
|
403
403
|
emits: ["update:modelValue", "change", "clear"],
|
404
|
-
setup(
|
405
|
-
const l =
|
404
|
+
setup(i, { expose: r, emit: d }) {
|
405
|
+
const l = i, a = d, {
|
406
406
|
innerValue: n,
|
407
|
-
filteredOptions:
|
408
|
-
isSelected:
|
409
|
-
selectItem:
|
407
|
+
filteredOptions: m,
|
408
|
+
isSelected: h,
|
409
|
+
selectItem: g,
|
410
410
|
clear: k,
|
411
|
-
toggleShowAll:
|
412
|
-
isReqProc:
|
413
|
-
showAll:
|
411
|
+
toggleShowAll: b,
|
412
|
+
isReqProc: f,
|
413
|
+
showAll: y,
|
414
414
|
isEnableShowAll: C,
|
415
|
-
labelKey:
|
416
|
-
valueKey:
|
415
|
+
labelKey: c,
|
416
|
+
valueKey: s,
|
417
417
|
allOptions: t
|
418
|
-
} =
|
418
|
+
} = Te({
|
419
419
|
...l,
|
420
420
|
modelValue: l.modelValue
|
421
|
-
},
|
422
|
-
return
|
421
|
+
}, a);
|
422
|
+
return A(
|
423
423
|
() => l.modelValue,
|
424
|
-
(
|
425
|
-
|
424
|
+
(x) => {
|
425
|
+
x === void 0 && (n.value = []);
|
426
426
|
}
|
427
427
|
), r({
|
428
428
|
clear: k
|
429
|
-
}), (
|
430
|
-
class:
|
429
|
+
}), (x, v) => (p(), w("div", {
|
430
|
+
class: j([x.layout === "popover" ? "flex flex-col h-full" : "flex flex-col vs-filter-checkbox space-y-0.5"])
|
431
431
|
}, [
|
432
|
-
|
433
|
-
class:
|
434
|
-
|
435
|
-
|
432
|
+
o("div", {
|
433
|
+
class: j([
|
434
|
+
x.layout === "popover" ? "flex-1 overflow-y-auto max-h-64 p-2" : "",
|
435
|
+
x.layout === "inline" ? "flex-1 overflow-y-auto max-h-80" : ""
|
436
436
|
])
|
437
437
|
}, [
|
438
|
-
(
|
439
|
-
layout:
|
440
|
-
count:
|
441
|
-
label:
|
442
|
-
color:
|
438
|
+
(p(!0), w(F, null, q(e(m), (u) => (p(), z(Ce, {
|
439
|
+
layout: x.layout,
|
440
|
+
count: u.count,
|
441
|
+
label: u[e(c)],
|
442
|
+
color: u.color,
|
443
443
|
type: "checkbox",
|
444
|
-
value:
|
445
|
-
"is-selected": e(
|
446
|
-
onItemClick: (_) => e(
|
444
|
+
value: u[e(s)],
|
445
|
+
"is-selected": e(h)(u),
|
446
|
+
onItemClick: (_) => e(g)(u)
|
447
447
|
}, null, 8, ["layout", "count", "label", "color", "value", "is-selected", "onItemClick"]))), 256))
|
448
448
|
], 2),
|
449
|
-
|
450
|
-
|
449
|
+
x.type === "select" && e(m).length === 0 && !e(f) ? (p(), w("div", yt, [
|
450
|
+
o("div", xt, [
|
451
451
|
P(Ve),
|
452
|
-
|
453
|
-
|
454
|
-
|
452
|
+
v[4] || (v[4] = o("div", { class: "max-w-sm mx-auto mt-6" }, [
|
453
|
+
o("p", { class: "font-medium text-gray-800 dark:text-neutral-200" }, "За вашим запитом нічого не знайдено"),
|
454
|
+
o("p", { class: "mt-2 text-sm text-gray-500 dark:text-neutral-500" })
|
455
455
|
], -1))
|
456
456
|
])
|
457
457
|
])) : S("", !0),
|
458
|
-
|
459
|
-
!e(
|
458
|
+
x.layout !== "popover" && x.type !== "select" ? (p(), w(F, { key: 1 }, [
|
459
|
+
!e(y) && e(C) ? (p(), w("div", {
|
460
460
|
key: 0,
|
461
|
-
onClick:
|
462
|
-
(...
|
461
|
+
onClick: v[0] || (v[0] = //@ts-ignore
|
462
|
+
(...u) => e(b) && e(b)(...u)),
|
463
463
|
class: "inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"
|
464
464
|
}, [
|
465
|
-
|
465
|
+
v[5] || (v[5] = W(" Показати більше ", -1)),
|
466
466
|
P(be)
|
467
467
|
])) : S("", !0),
|
468
|
-
e(
|
468
|
+
e(y) ? (p(), w("div", {
|
469
469
|
key: 1,
|
470
|
-
onClick:
|
471
|
-
(...
|
470
|
+
onClick: v[1] || (v[1] = //@ts-ignore
|
471
|
+
(...u) => e(b) && e(b)(...u)),
|
472
472
|
class: "inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"
|
473
473
|
}, [
|
474
|
-
|
474
|
+
v[6] || (v[6] = W(" Показати менше ", -1)),
|
475
475
|
P(Se)
|
476
476
|
])) : S("", !0)
|
477
477
|
], 64)) : S("", !0),
|
478
|
-
|
479
|
-
|
480
|
-
|
481
|
-
|
478
|
+
x.cleanable ? (p(), w(F, { key: 2 }, [
|
479
|
+
x.layout === "inline" ? (p(), w("div", wt, [
|
480
|
+
W(K(e(n).length) + " з " + K(e(t).length) + " обрано ", 1),
|
481
|
+
I(o("button", {
|
482
482
|
class: "text-gray-600 hover:text-gray-800",
|
483
|
-
onClick:
|
484
|
-
(...
|
483
|
+
onClick: v[2] || (v[2] = //@ts-ignore
|
484
|
+
(...u) => e(k) && e(k)(...u))
|
485
485
|
}, " Очистити ", 512), [
|
486
486
|
[X, e(n).length !== 0]
|
487
487
|
])
|
488
488
|
])) : S("", !0),
|
489
|
-
|
490
|
-
|
491
|
-
|
489
|
+
x.layout === "popover" ? (p(), w("div", kt, [
|
490
|
+
o("span", null, K(e(n).length) + " з " + K(e(t).length) + " обрано", 1),
|
491
|
+
I(o("button", {
|
492
492
|
class: "text-gray-600 hover:text-gray-800",
|
493
|
-
onClick:
|
494
|
-
(...
|
493
|
+
onClick: v[3] || (v[3] = //@ts-ignore
|
494
|
+
(...u) => e(k) && e(k)(...u))
|
495
495
|
}, " Очистити ", 512), [
|
496
496
|
[X, e(n).length !== 0]
|
497
497
|
])
|
@@ -499,7 +499,7 @@ const mt = {
|
|
499
499
|
], 64)) : S("", !0)
|
500
500
|
], 2));
|
501
501
|
}
|
502
|
-
}),
|
502
|
+
}), _t = {}, Ct = {
|
503
503
|
xmlns: "http://www.w3.org/2000/svg",
|
504
504
|
width: "15px",
|
505
505
|
height: "15px",
|
@@ -511,18 +511,18 @@ const mt = {
|
|
511
511
|
"stroke-linejoin": "round",
|
512
512
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-search stroke-gray-500 transition-all"
|
513
513
|
};
|
514
|
-
function
|
515
|
-
return
|
516
|
-
|
514
|
+
function Vt(i, r) {
|
515
|
+
return p(), w("svg", Ct, r[0] || (r[0] = [
|
516
|
+
o("path", {
|
517
517
|
stroke: "none",
|
518
518
|
d: "M0 0h24v24H0z",
|
519
519
|
fill: "none"
|
520
520
|
}, null, -1),
|
521
|
-
|
522
|
-
|
521
|
+
o("path", { d: "M10 10m-7 0a7 7 0 1 0 14 0a7 7 0 1 0 -14 0" }, null, -1),
|
522
|
+
o("path", { d: "M21 21l-6 -6" }, null, -1)
|
523
523
|
]));
|
524
524
|
}
|
525
|
-
const
|
525
|
+
const He = /* @__PURE__ */ le(_t, [["render", Vt]]), St = {}, Mt = {
|
526
526
|
xmlns: "http://www.w3.org/2000/svg",
|
527
527
|
viewBox: "0 0 24 24",
|
528
528
|
fill: "none",
|
@@ -534,24 +534,24 @@ const Pe = /* @__PURE__ */ le(yt, [["render", wt]]), kt = {}, _t = {
|
|
534
534
|
width: "15px",
|
535
535
|
height: "15px"
|
536
536
|
};
|
537
|
-
function
|
538
|
-
return
|
539
|
-
|
537
|
+
function Bt(i, r) {
|
538
|
+
return p(), w("svg", Mt, r[0] || (r[0] = [
|
539
|
+
o("path", {
|
540
540
|
stroke: "none",
|
541
541
|
d: "M0 0h24v24H0z",
|
542
542
|
fill: "none"
|
543
543
|
}, null, -1),
|
544
|
-
|
545
|
-
|
544
|
+
o("path", { d: "M18 6l-12 12" }, null, -1),
|
545
|
+
o("path", { d: "M6 6l12 12" }, null, -1)
|
546
546
|
]));
|
547
547
|
}
|
548
|
-
const
|
548
|
+
const Ee = /* @__PURE__ */ le(St, [["render", Bt]]);
|
549
549
|
class ye {
|
550
550
|
static getWidthClass(r) {
|
551
551
|
return typeof r == "number" ? `max-w-[${r}px]` : typeof r == "string" ? r.endsWith("%") || r.endsWith("px") ? `max-w-[${r}]` : `max-w-${r}` : "w-full";
|
552
552
|
}
|
553
553
|
}
|
554
|
-
const
|
554
|
+
const $t = { class: "absolute bottom-2/4 translate-y-2/4 cursor-pointer left-3" }, At = ["placeholder"], Rt = /* @__PURE__ */ Y({
|
555
555
|
__name: "text-input",
|
556
556
|
props: {
|
557
557
|
id: {},
|
@@ -577,73 +577,73 @@ const Vt = { class: "absolute bottom-2/4 translate-y-2/4 cursor-pointer left-3"
|
|
577
577
|
sort: {}
|
578
578
|
},
|
579
579
|
emits: ["update:modelValue", "change", "clear"],
|
580
|
-
setup(
|
581
|
-
const
|
582
|
-
|
583
|
-
() =>
|
584
|
-
(
|
585
|
-
|
580
|
+
setup(i, { emit: r }) {
|
581
|
+
const d = i, l = V((d.placeHolder || d.label || d.name || "search").toString()), a = r, n = V(d.modelValue ?? "");
|
582
|
+
A(
|
583
|
+
() => d.modelValue,
|
584
|
+
(g) => {
|
585
|
+
g !== n.value && (n.value = g ?? "");
|
586
586
|
}
|
587
587
|
);
|
588
|
-
function
|
589
|
-
|
588
|
+
function m() {
|
589
|
+
a("update:modelValue", n.value), a("change", { name: d.name, value: n.value });
|
590
590
|
}
|
591
|
-
function
|
592
|
-
n.value = "",
|
591
|
+
function h() {
|
592
|
+
n.value = "", a("update:modelValue", ""), a("clear", d.name), a("change", { name: d.name, value: null });
|
593
593
|
}
|
594
|
-
return (
|
595
|
-
class:
|
594
|
+
return (g, k) => (p(), w("div", {
|
595
|
+
class: j([
|
596
596
|
"vs-form-text relative bg-white rounded-lg [&>input]:py-[7px] [&>input]:max-h-[38px] [&>input]:ps-10 [&>input]:pe-8 [&>input]:block [&>input]:w-full [&>input]:bg-gray-100 [&>input]:border-transparent [&>input]:rounded-lg [&>input]:text-sm [&>input]:focus:bg-white [&>input]:focus:border-blue-500 [&>input]:focus:ring-blue-500 [&>input]:disabled:opacity-50 [&>input]:disabled:pointer-events-none [&>input]:dark:bg-neutral-700 [&>input]:dark:border-transparent [&>input]:dark:text-neutral-400 [&>input]:dark:placeholder:text-neutral-400 dark:focus:bg-neutral-800 dark:focus:ring-neutral-600",
|
597
|
-
|
597
|
+
g.layout === "inline" ? e(ye).getWidthClass(g.width) : "mb-2" + (g.layout === "popover" ? " m-2" : "")
|
598
598
|
])
|
599
599
|
}, [
|
600
|
-
|
601
|
-
P(
|
600
|
+
o("div", $t, [
|
601
|
+
P(He)
|
602
602
|
]),
|
603
|
-
n.value !== "" ? (
|
603
|
+
n.value !== "" ? (p(), w("div", {
|
604
604
|
key: 0,
|
605
|
-
onClick:
|
605
|
+
onClick: h,
|
606
606
|
class: "absolute bottom-2/4 translate-y-2/4 right-3 cursor-pointer"
|
607
607
|
}, [
|
608
|
-
P(
|
608
|
+
P(Ee)
|
609
609
|
])) : S("", !0),
|
610
|
-
|
610
|
+
I(o("input", {
|
611
611
|
type: "text",
|
612
|
-
"onUpdate:modelValue": k[0] || (k[0] = (
|
613
|
-
onInput:
|
612
|
+
"onUpdate:modelValue": k[0] || (k[0] = (b) => n.value = b),
|
613
|
+
onInput: m,
|
614
614
|
placeholder: l.value,
|
615
615
|
class: "!pr-7 !pl-8 bg-white h-[38px] min-w-[100px] text-sm py-2 px-3 block w-full border border-solid placeholder:text-nowrap border-stone-200 rounded-lg text-sm text-stone-800 placeholder:text-stone-400 focus:border-2 focus:z-10 focus:border-blue-500 focus:ring-blue-500 focus:outline-blue-500"
|
616
|
-
}, null, 40,
|
616
|
+
}, null, 40, At), [
|
617
617
|
[te, n.value]
|
618
618
|
])
|
619
619
|
], 2));
|
620
620
|
}
|
621
621
|
});
|
622
|
-
function
|
622
|
+
function Ye(i = { color: "blue" }) {
|
623
623
|
return E(() => {
|
624
|
-
const r = `w-full px-3 py-2 border-solid border border-gray-300 text-sm rounded focus:outline-none focus:ring-2 focus:ring-${
|
625
|
-
return (
|
624
|
+
const r = `w-full px-3 py-2 border-solid border border-gray-300 text-sm rounded focus:outline-none focus:ring-2 focus:ring-${i.color}-500 focus:border-transparent`;
|
625
|
+
return (i == null ? void 0 : i.size) === "sm" ? `${r}h-[32px]` : `${r}h-[38px]`;
|
626
626
|
});
|
627
627
|
}
|
628
|
-
function
|
628
|
+
function Dt() {
|
629
629
|
return "rounded-md font-medium border-gray-200 border-solid disabled:pointer-events-none disabled:opacity-50 px-4 py-2 w-full bg-transparent border text-black text-sm h-[38px]";
|
630
630
|
}
|
631
|
-
function
|
631
|
+
function zt() {
|
632
632
|
return "font-medium border-gray-200 border-solid disabled:pointer-events-none disabled:opacity-50 border h-7 rounded-md text-xs px-2 py-1 hover:bg-gray-100";
|
633
633
|
}
|
634
|
-
function
|
635
|
-
return
|
634
|
+
function We(i) {
|
635
|
+
return i === "ghost" ? "inline-flex relative py-2 px-4 items-center gap-x-2 text-sm font-medium rounded-lg border border-transparent text-gray-600 hover:bg-blue-100 hover:text-gray-800 focus:outline-hidden focus:bg-gray-100 focus:text-gray-800 disabled:opacity-50 disabled:pointer-events-none dark:text-gray-500 dark:hover:bg-blue-800/30 dark:hover:text-blue-400 dark:focus:bg-blue-800/30 dark:focus:text-blue-400" : i === "soft" ? "inline-flex relative py-2 px-4 items-center gap-x-2 text-sm font-medium rounded-lg border border-transparent bg-gray-100 text-gray-800 hover:bg-gray-200 hover:bg-gray-200 focus:outline-hidden focus:bg-gray-200 disabled:opacity-50 disabled:pointer-events-none dark:text-blue-400 dark:hover:bg-blue-900 dark:focus:bg-blue-900" : "relative border-solid border-gray-200 focus-visible:outline-hidden focus-visible:ring-ring inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 border-input hover:bg-gray-100 border px-4 py-2 gap-2 bg-transparent h-[38px]";
|
636
636
|
}
|
637
|
-
const
|
637
|
+
const jt = {
|
638
638
|
key: 0,
|
639
639
|
class: "block text-xs font-medium text-gray-600 mb-1"
|
640
|
-
},
|
640
|
+
}, Ft = ["placeholder", "disabled"], Kt = {
|
641
641
|
key: 0,
|
642
642
|
class: "block text-xs font-medium text-gray-600 mb-1"
|
643
|
-
},
|
643
|
+
}, Lt = {
|
644
644
|
key: 0,
|
645
645
|
class: "block text-xs font-medium text-gray-600 mb-1"
|
646
|
-
},
|
646
|
+
}, Ut = ["placeholder", "disabled"], Ot = ["disabled"], Pt = /* @__PURE__ */ Y({
|
647
647
|
__name: "range-input",
|
648
648
|
props: {
|
649
649
|
id: {},
|
@@ -669,85 +669,85 @@ const $t = {
|
|
669
669
|
sort: {}
|
670
670
|
},
|
671
671
|
emits: ["update:modelValue", "change", "clear"],
|
672
|
-
setup(
|
673
|
-
const l =
|
672
|
+
setup(i, { expose: r, emit: d }) {
|
673
|
+
const l = Ye(), a = Dt(), n = i, m = V(
|
674
674
|
n.modelValue ?? n.default ?? []
|
675
|
-
),
|
676
|
-
get: () => n.modelValue ??
|
677
|
-
set: (
|
678
|
-
n.modelValue !== void 0 ?
|
675
|
+
), h = d, g = E({
|
676
|
+
get: () => n.modelValue ?? m.value,
|
677
|
+
set: (f) => {
|
678
|
+
n.modelValue !== void 0 ? h("update:modelValue", f) : m.value = f;
|
679
679
|
}
|
680
680
|
});
|
681
681
|
function k() {
|
682
|
-
|
682
|
+
h("change", { name: n.name, value: g.value || m.value });
|
683
683
|
}
|
684
|
-
function
|
685
|
-
|
684
|
+
function b() {
|
685
|
+
m.value = [], g.value = m.value, h("clear", n.name);
|
686
686
|
}
|
687
|
-
return
|
688
|
-
|
687
|
+
return A(() => n.modelValue, (f) => {
|
688
|
+
f !== void 0 && n.layout !== "popover" ? (m.value = f, h("update:modelValue", f)) : m.value = [];
|
689
689
|
}), r({
|
690
|
-
clear:
|
691
|
-
currentValue:
|
692
|
-
}), (
|
693
|
-
var C,
|
694
|
-
return
|
695
|
-
|
696
|
-
|
697
|
-
class:
|
690
|
+
clear: b,
|
691
|
+
currentValue: g
|
692
|
+
}), (f, y) => {
|
693
|
+
var C, c;
|
694
|
+
return p(), w(F, null, [
|
695
|
+
o("div", null, [
|
696
|
+
o("div", {
|
697
|
+
class: j(f.layout === "vertical" ? "inline-flex items-center gap-2" : "space-y-3 p-2")
|
698
698
|
}, [
|
699
|
-
|
700
|
-
|
701
|
-
|
699
|
+
o("div", null, [
|
700
|
+
f.layout !== "vertical" ? (p(), w("label", jt, "Від")) : S("", !0),
|
701
|
+
I(o("input", {
|
702
702
|
type: "number",
|
703
|
-
class:
|
704
|
-
placeholder: ((C =
|
703
|
+
class: j(e(l)),
|
704
|
+
placeholder: ((C = f.placeHolder) == null ? void 0 : C[0]) ?? "min",
|
705
705
|
step: "1",
|
706
706
|
style: { outline: "none" },
|
707
|
-
"onUpdate:modelValue":
|
708
|
-
disabled:
|
709
|
-
}, null, 10,
|
710
|
-
[te,
|
707
|
+
"onUpdate:modelValue": y[0] || (y[0] = (s) => g.value[0] = s),
|
708
|
+
disabled: f.disabled
|
709
|
+
}, null, 10, Ft), [
|
710
|
+
[te, g.value[0]]
|
711
711
|
])
|
712
712
|
]),
|
713
|
-
|
714
|
-
|
715
|
-
|
716
|
-
|
713
|
+
f.layout === "vertical" ? (p(), w("label", Kt, " - ")) : S("", !0),
|
714
|
+
o("div", null, [
|
715
|
+
f.layout !== "vertical" ? (p(), w("label", Lt, "До")) : S("", !0),
|
716
|
+
I(o("input", {
|
717
717
|
type: "number",
|
718
|
-
class:
|
719
|
-
placeholder: ((
|
718
|
+
class: j(e(l)),
|
719
|
+
placeholder: ((c = f.placeHolder) == null ? void 0 : c[1]) ?? "max",
|
720
720
|
min: "0",
|
721
721
|
max: "1000000000000000",
|
722
722
|
step: "1",
|
723
723
|
style: { outline: "none" },
|
724
|
-
"onUpdate:modelValue":
|
725
|
-
disabled:
|
726
|
-
}, null, 10,
|
727
|
-
[te,
|
724
|
+
"onUpdate:modelValue": y[1] || (y[1] = (s) => g.value[1] = s),
|
725
|
+
disabled: f.disabled
|
726
|
+
}, null, 10, Ut), [
|
727
|
+
[te, g.value[1]]
|
728
728
|
])
|
729
729
|
]),
|
730
|
-
["popover", "inline", "vertical"].includes(
|
730
|
+
["popover", "inline", "vertical"].includes(f.layout) ? (p(), w("button", {
|
731
731
|
key: 1,
|
732
732
|
onClick: k,
|
733
|
-
class:
|
734
|
-
}, K(
|
735
|
-
["popover", "inline"].includes(
|
733
|
+
class: j(e(a) + (f.layout === "vertical" ? " w-[50px]" : " bg-blue-100 hover:bg-blue-200"))
|
734
|
+
}, K(f.layout === "vertical" ? "Ok" : "Застосувати"), 3)) : S("", !0),
|
735
|
+
["popover", "inline"].includes(f.layout) ? (p(), w("button", {
|
736
736
|
key: 2,
|
737
|
-
disabled: !(
|
738
|
-
onClick:
|
739
|
-
class:
|
740
|
-
}, "Очистити", 10,
|
737
|
+
disabled: !(g.value[0] || g.value[1]),
|
738
|
+
onClick: b,
|
739
|
+
class: j(e(a) + " hover:bg-gray-100")
|
740
|
+
}, "Очистити", 10, Ot)) : S("", !0)
|
741
741
|
], 2)
|
742
742
|
]),
|
743
|
-
(
|
743
|
+
(f.cleanable && m.value.length, S("", !0))
|
744
744
|
], 64);
|
745
745
|
};
|
746
746
|
}
|
747
|
-
}),
|
747
|
+
}), It = ["disabled", "title"], Tt = {
|
748
748
|
key: 0,
|
749
749
|
class: "absolute top-0 end-0 inline-flex min-h-[10px] min-w-[10px] z-10 items-center py-0.5 rounded-full text-xs font-medium transform -translate-y-1/2 translate-x-1/2 bg-blue-600 text-white px-1"
|
750
|
-
},
|
750
|
+
}, Ht = { class: "w-full text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-lg focus:outline-none focus:bg-stone-100 after:h-4 after:absolute after:-bottom-4 after:start-0 after:w-full before:h-4 before:absolute before:-top-4 before:start-0 before:w-full" }, Et = { class: "w-[360px] max-h-[500px] overflow-auto [&::-webkit-scrollbar]:h-2 [&::-webkit-scrollbar]:w-1 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-stone-100 [&::-webkit-scrollbar-thumb]:bg-stone-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500 before:w-full p-2" }, Me = /* @__PURE__ */ Y({
|
751
751
|
__name: "popover-field",
|
752
752
|
props: {
|
753
753
|
disabled: { type: Boolean, default: !1 },
|
@@ -758,147 +758,147 @@ const $t = {
|
|
758
758
|
mode: {},
|
759
759
|
layout: {}
|
760
760
|
},
|
761
|
-
setup(
|
762
|
-
const
|
761
|
+
setup(i, { expose: r }) {
|
762
|
+
const d = i, l = E(() => We(d.mode)), a = V(!1), n = V({ top: 0, left: 0 }), m = V(null), h = V(null), g = V(null);
|
763
763
|
function k() {
|
764
|
-
const t =
|
765
|
-
if (!t || !
|
766
|
-
const
|
767
|
-
let { left:
|
768
|
-
|
764
|
+
const t = h.value, x = g.value;
|
765
|
+
if (!t || !x) return;
|
766
|
+
const v = t.getBoundingClientRect(), u = x.offsetWidth, _ = window.innerWidth, B = v.bottom + 8;
|
767
|
+
let { left: M } = v;
|
768
|
+
M + u > _ && (M = Math.max(_ - u - 10, 10)), n.value = { top: B, left: M };
|
769
769
|
}
|
770
|
-
function
|
771
|
-
|
772
|
-
var t,
|
773
|
-
k(), (t =
|
770
|
+
function b() {
|
771
|
+
a.value = !a.value, a.value && ke(() => {
|
772
|
+
var t, x;
|
773
|
+
k(), (t = d.fieldRef) != null && t.inputTextRef && ((x = d.fieldRef) == null || x.inputTextRef.focus());
|
774
774
|
});
|
775
775
|
}
|
776
|
-
function
|
777
|
-
var
|
778
|
-
!((
|
776
|
+
function f(t) {
|
777
|
+
var x, v;
|
778
|
+
!((x = m.value) != null && x.contains(t.target)) && !((v = g.value) != null && v.contains(t.target)) && (a.value = !1);
|
779
779
|
}
|
780
|
-
function
|
781
|
-
t.key === "Escape" && (
|
780
|
+
function y(t) {
|
781
|
+
t.key === "Escape" && (a.value = !1);
|
782
782
|
}
|
783
783
|
const C = V(!1);
|
784
784
|
ue(() => {
|
785
785
|
C.value = !0;
|
786
786
|
}), ue(() => {
|
787
|
-
document.addEventListener("click",
|
787
|
+
document.addEventListener("click", f, !0), document.addEventListener("keydown", y), window.addEventListener("scroll", k, !0);
|
788
788
|
}), he(() => {
|
789
|
-
document.removeEventListener("click",
|
789
|
+
document.removeEventListener("click", f, !0), document.removeEventListener("keydown", y), window.removeEventListener("scroll", k, !0);
|
790
790
|
});
|
791
|
-
function
|
792
|
-
|
791
|
+
function c() {
|
792
|
+
a.value = !1;
|
793
793
|
}
|
794
|
-
r({ close:
|
795
|
-
const
|
796
|
-
var
|
797
|
-
const t = (
|
798
|
-
return t ? Array.isArray(t) ? t.length > 0 ? t.join(", ") :
|
794
|
+
r({ close: c });
|
795
|
+
const s = E(() => {
|
796
|
+
var x;
|
797
|
+
const t = (x = d.fieldRef) == null ? void 0 : x.selectedLabels;
|
798
|
+
return t ? Array.isArray(t) ? t.length > 0 ? t.join(", ") : d.label ?? "" : String(t) : d.label ?? "";
|
799
799
|
});
|
800
|
-
return (t,
|
801
|
-
|
802
|
-
onClick:
|
800
|
+
return (t, x) => (p(), w("div", null, [
|
801
|
+
o("button", {
|
802
|
+
onClick: b,
|
803
803
|
disabled: t.disabled,
|
804
804
|
ref_key: "triggerRef",
|
805
|
-
ref:
|
805
|
+
ref: h,
|
806
806
|
title: t.label,
|
807
|
-
class:
|
807
|
+
class: j(l.value + " " + (t.width ? e(ye).getWidthClass(t.width) : "w-full"))
|
808
808
|
}, [
|
809
|
-
|
810
|
-
class:
|
811
|
-
}, K(
|
809
|
+
o("span", {
|
810
|
+
class: j(["truncate text-ellipsis block", t.width ? e(ye).getWidthClass(t.width - 50) : "w-full"])
|
811
|
+
}, K(s.value), 3),
|
812
812
|
P(be, { class: "h-4 w-4" }),
|
813
|
-
(Array.isArray(t.currentValue) ? t.currentValue === null || t.currentValue.length > 0 : t.currentValue === null || t.currentValue) && t.layout === "inline" ? (
|
814
|
-
], 10,
|
815
|
-
C.value ? (
|
813
|
+
(Array.isArray(t.currentValue) ? t.currentValue === null || t.currentValue.length > 0 : t.currentValue === null || t.currentValue) && t.layout === "inline" ? (p(), w("span", Tt)) : S("", !0)
|
814
|
+
], 10, It),
|
815
|
+
C.value ? (p(), z(Ue, {
|
816
816
|
key: 0,
|
817
817
|
to: "body"
|
818
818
|
}, [
|
819
|
-
|
819
|
+
I(o("div", {
|
820
820
|
ref_key: "popperRef",
|
821
|
-
ref:
|
821
|
+
ref: g,
|
822
822
|
class: "vsTailwind vs-popover__content bottom-right w-fit fixed z-[1000]",
|
823
823
|
style: _e({ top: `${n.value.top}px`, left: `${n.value.left}px` }),
|
824
824
|
"data-inside-popover": ""
|
825
825
|
}, [
|
826
|
-
|
827
|
-
|
826
|
+
o("div", Ht, [
|
827
|
+
o("div", Et, [
|
828
828
|
ee(t.$slots, "default")
|
829
829
|
])
|
830
830
|
])
|
831
831
|
], 4), [
|
832
|
-
[X,
|
832
|
+
[X, a.value]
|
833
833
|
])
|
834
834
|
])) : S("", !0)
|
835
835
|
]));
|
836
836
|
}
|
837
837
|
});
|
838
|
-
function
|
839
|
-
return String(
|
838
|
+
function Yt(i) {
|
839
|
+
return String(i).charAt(0).toUpperCase() + String(i).slice(1);
|
840
840
|
}
|
841
841
|
class N {
|
842
842
|
static format(r) {
|
843
|
-
const
|
844
|
-
return `${
|
843
|
+
const d = r.getFullYear(), l = (r.getMonth() + 1).toString().padStart(2, "0"), a = r.getDate().toString().padStart(2, "0");
|
844
|
+
return `${d}-${l}-${a}`;
|
845
845
|
}
|
846
|
-
static getShiftedDay(r,
|
846
|
+
static getShiftedDay(r, d = 0) {
|
847
847
|
const l = r ? new Date(r) : /* @__PURE__ */ new Date();
|
848
|
-
return l.setDate(l.getDate() +
|
848
|
+
return l.setDate(l.getDate() + d), this.format(l);
|
849
849
|
}
|
850
|
-
static getLastWeekRange(r,
|
851
|
-
if (r &&
|
852
|
-
const k = new Date(r),
|
853
|
-
return k.setDate(k.getDate() + l * 7),
|
850
|
+
static getLastWeekRange(r, d, l = 0) {
|
851
|
+
if (r && d) {
|
852
|
+
const k = new Date(r), b = new Date(d);
|
853
|
+
return k.setDate(k.getDate() + l * 7), b.setDate(b.getDate() + l * 7), [this.format(k), this.format(b)];
|
854
854
|
}
|
855
|
-
const
|
856
|
-
|
857
|
-
const
|
858
|
-
return
|
859
|
-
}
|
860
|
-
static getMonthRange(r,
|
861
|
-
let
|
862
|
-
r ?
|
863
|
-
const n =
|
864
|
-
return [this.format(n), this.format(
|
865
|
-
}
|
866
|
-
static getQuarterRange(r,
|
867
|
-
const
|
868
|
-
let
|
869
|
-
|
870
|
-
const
|
871
|
-
return [this.format(k), this.format(
|
872
|
-
}
|
873
|
-
static getYear(r,
|
855
|
+
const a = /* @__PURE__ */ new Date(), n = a.getDay(), m = n === 0 ? 13 : n - 1 + 7, h = new Date(a);
|
856
|
+
h.setDate(a.getDate() - m + l * 7);
|
857
|
+
const g = new Date(h);
|
858
|
+
return g.setDate(h.getDate() + 6), [this.format(h), this.format(g)];
|
859
|
+
}
|
860
|
+
static getMonthRange(r, d, l = 0) {
|
861
|
+
let a;
|
862
|
+
r ? a = new Date(r) : a = /* @__PURE__ */ new Date(), a = new Date(a.getFullYear(), a.getMonth() + l, 1);
|
863
|
+
const n = a, m = new Date(a.getFullYear(), a.getMonth() + 1, 0);
|
864
|
+
return [this.format(n), this.format(m)];
|
865
|
+
}
|
866
|
+
static getQuarterRange(r, d, l = 0) {
|
867
|
+
const a = r || d, n = a ? new Date(a) : /* @__PURE__ */ new Date();
|
868
|
+
let m = Math.floor(n.getMonth() / 3);
|
869
|
+
m += l;
|
870
|
+
const h = (m % 4 + 4) % 4 * 3, g = n.getFullYear() + Math.floor(m / 4), k = new Date(g, h, 1), b = new Date(g, h + 3, 0);
|
871
|
+
return [this.format(k), this.format(b)];
|
872
|
+
}
|
873
|
+
static getYear(r, d = 0) {
|
874
874
|
let l;
|
875
|
-
return r && /^\d{4}$/.test(r) ? l = parseInt(r, 10) : r ? l = new Date(r).getFullYear() : l = (/* @__PURE__ */ new Date()).getFullYear(), String(l +
|
875
|
+
return r && /^\d{4}$/.test(r) ? l = parseInt(r, 10) : r ? l = new Date(r).getFullYear() : l = (/* @__PURE__ */ new Date()).getFullYear(), String(l + d);
|
876
876
|
}
|
877
|
-
static getYearRange(r,
|
877
|
+
static getYearRange(r, d = 0) {
|
878
878
|
let l;
|
879
879
|
return r && /^\d{4}$/.test(r) ? l = parseInt(r, 10) : r ? l = new Date(r).getFullYear() : l = (/* @__PURE__ */ new Date()).getFullYear(), [
|
880
|
-
this.format(new Date(l +
|
881
|
-
this.format(new Date(l +
|
880
|
+
this.format(new Date(l + d, 0, 1)),
|
881
|
+
this.format(new Date(l + d + 1, 0, 0))
|
882
882
|
];
|
883
883
|
}
|
884
884
|
static getRangeFromDaysBefore(r) {
|
885
|
-
const
|
886
|
-
return l.setDate(
|
885
|
+
const d = /* @__PURE__ */ new Date(), l = new Date(d.getTime());
|
886
|
+
return l.setDate(d.getDate() - r), [this.format(l), this.format(d)];
|
887
887
|
}
|
888
888
|
}
|
889
|
-
function
|
889
|
+
function qe(i, r) {
|
890
890
|
const {
|
891
|
-
popoverRef:
|
892
|
-
} =
|
893
|
-
|
891
|
+
popoverRef: d
|
892
|
+
} = i, l = V(""), a = V(
|
893
|
+
i.modelValue ?? i.default ?? []
|
894
894
|
), n = V(0);
|
895
|
-
function
|
896
|
-
const
|
897
|
-
return
|
895
|
+
function m() {
|
896
|
+
const s = N.getRangeFromDaysBefore(n.value);
|
897
|
+
return a.value = [...s], r("change", { name: i.name, value: a.value }), r("update:modelValue", a.value), s;
|
898
898
|
}
|
899
|
-
function
|
900
|
-
var
|
901
|
-
l.value =
|
899
|
+
function h(s) {
|
900
|
+
var x;
|
901
|
+
l.value = s, (x = d.value) == null || x.close();
|
902
902
|
const t = [];
|
903
903
|
switch (l.value) {
|
904
904
|
case "today":
|
@@ -917,57 +917,57 @@ function Ee(u, r) {
|
|
917
917
|
t.push(...N.getYearRange());
|
918
918
|
break;
|
919
919
|
case "last_7_days":
|
920
|
-
n.value = 7,
|
920
|
+
n.value = 7, m();
|
921
921
|
break;
|
922
922
|
case "range":
|
923
|
-
n.value = 7, t.push(...
|
923
|
+
n.value = 7, t.push(...m());
|
924
924
|
break;
|
925
925
|
}
|
926
|
-
|
926
|
+
a.value = [...t], r("change", { name: i.name, value: a.value }), r("update:modelValue", a.value);
|
927
927
|
}
|
928
|
-
function
|
929
|
-
const
|
928
|
+
function g() {
|
929
|
+
const s = [];
|
930
930
|
switch (l.value) {
|
931
931
|
case "today":
|
932
|
-
|
932
|
+
s.push(N.getShiftedDay(a.value[0], 1));
|
933
933
|
break;
|
934
934
|
case "week":
|
935
|
-
|
935
|
+
s.push(...N.getLastWeekRange(a.value[0], a.value[1], 1));
|
936
936
|
break;
|
937
937
|
case "month":
|
938
|
-
|
938
|
+
s.push(...N.getMonthRange(a.value[0], a.value[1], 1));
|
939
939
|
break;
|
940
940
|
case "quarter":
|
941
|
-
|
941
|
+
s.push(...N.getQuarterRange(a.value[0], a.value[1], 1));
|
942
942
|
break;
|
943
943
|
case "year":
|
944
|
-
|
944
|
+
s.push(...N.getYearRange(a.value[0], 1));
|
945
945
|
break;
|
946
946
|
}
|
947
|
-
|
947
|
+
a.value = [...s], r("change", { name: i.name, value: a.value }), r("update:modelValue", a.value);
|
948
948
|
}
|
949
949
|
function k() {
|
950
|
-
const
|
950
|
+
const s = [];
|
951
951
|
switch (l.value) {
|
952
952
|
case "today":
|
953
|
-
|
953
|
+
s.push(N.getShiftedDay(a.value[0], -1));
|
954
954
|
break;
|
955
955
|
case "week":
|
956
|
-
|
956
|
+
s.push(...N.getLastWeekRange(a.value[0], a.value[1], -1));
|
957
957
|
break;
|
958
958
|
case "month":
|
959
|
-
|
959
|
+
s.push(...N.getMonthRange(a.value[0], a.value[1], -1));
|
960
960
|
break;
|
961
961
|
case "quarter":
|
962
|
-
|
962
|
+
s.push(...N.getQuarterRange(a.value[0], a.value[1], -1));
|
963
963
|
break;
|
964
964
|
case "year":
|
965
|
-
|
965
|
+
s.push(...N.getYearRange(a.value[0], -1));
|
966
966
|
break;
|
967
967
|
}
|
968
|
-
|
968
|
+
a.value = [...s], r("change", { name: i.name, value: a.value }), r("update:modelValue", a.value);
|
969
969
|
}
|
970
|
-
const
|
970
|
+
const b = [
|
971
971
|
"Січень",
|
972
972
|
"Лютий",
|
973
973
|
"Березень",
|
@@ -981,29 +981,29 @@ function Ee(u, r) {
|
|
981
981
|
"Листопад",
|
982
982
|
"Грудень"
|
983
983
|
];
|
984
|
-
function
|
985
|
-
const [t,
|
986
|
-
return `${
|
984
|
+
function f(s) {
|
985
|
+
const [t, x, v] = s.split("-");
|
986
|
+
return `${v}.${x}.${t}`;
|
987
987
|
}
|
988
|
-
function
|
989
|
-
const { value: t } =
|
990
|
-
switch (
|
988
|
+
function y(s) {
|
989
|
+
const { value: t } = a;
|
990
|
+
switch (s) {
|
991
991
|
case "today":
|
992
|
-
return
|
992
|
+
return f(t[0]);
|
993
993
|
case "range":
|
994
994
|
return "Період";
|
995
995
|
case "week":
|
996
|
-
return t[0] && t[1] ? `${
|
996
|
+
return t[0] && t[1] ? `${f(t[0])} – ${f(t[1])}` : "";
|
997
997
|
case "quarter":
|
998
998
|
if (t[0]) {
|
999
|
-
const
|
1000
|
-
return `${Math.floor(
|
999
|
+
const x = new Date(t[0]), v = x.getFullYear(), u = x.getMonth();
|
1000
|
+
return `${Math.floor(u / 3) + 1} квартал ${v}`;
|
1001
1001
|
}
|
1002
1002
|
return "";
|
1003
1003
|
case "month":
|
1004
1004
|
if (t[0]) {
|
1005
|
-
const [
|
1006
|
-
return `${
|
1005
|
+
const [x, v] = t[0].split("-");
|
1006
|
+
return `${b[parseInt(v, 10) - 1]} ${x}`;
|
1007
1007
|
}
|
1008
1008
|
return "";
|
1009
1009
|
case "year":
|
@@ -1011,44 +1011,44 @@ function Ee(u, r) {
|
|
1011
1011
|
case "last_7_days":
|
1012
1012
|
return "За останні дні";
|
1013
1013
|
default:
|
1014
|
-
return
|
1014
|
+
return i.label ?? "";
|
1015
1015
|
}
|
1016
1016
|
}
|
1017
|
-
const C = E(() => l.value ?
|
1018
|
-
function
|
1019
|
-
l.value = "",
|
1017
|
+
const C = E(() => l.value ? y(l.value) : i.label ?? "");
|
1018
|
+
function c() {
|
1019
|
+
l.value = "", a.value = [], r("update:modelValue", []), r("clear", i.name);
|
1020
1020
|
}
|
1021
1021
|
return {
|
1022
1022
|
activeMode: l,
|
1023
|
-
innerValue:
|
1023
|
+
innerValue: a,
|
1024
1024
|
daysBefore: n,
|
1025
|
-
onDaysBeforeChange:
|
1026
|
-
onSelectChange:
|
1027
|
-
nextClick:
|
1025
|
+
onDaysBeforeChange: m,
|
1026
|
+
onSelectChange: h,
|
1027
|
+
nextClick: g,
|
1028
1028
|
prevClick: k,
|
1029
|
-
ukMonths:
|
1030
|
-
formatDisplayDate:
|
1031
|
-
getModeLabel:
|
1029
|
+
ukMonths: b,
|
1030
|
+
formatDisplayDate: f,
|
1031
|
+
getModeLabel: y,
|
1032
1032
|
currentLabel: C,
|
1033
|
-
clear:
|
1033
|
+
clear: c
|
1034
1034
|
};
|
1035
1035
|
}
|
1036
|
-
const
|
1036
|
+
const Wt = {
|
1037
1037
|
key: 0,
|
1038
1038
|
class: "relative flex w-full h-auto gap-2 filter-date m-2 flex-wrap"
|
1039
|
-
},
|
1039
|
+
}, qt = {
|
1040
1040
|
key: 0,
|
1041
1041
|
class: "flex gap-1 !w-[75%] rounded-lg"
|
1042
|
-
},
|
1042
|
+
}, Nt = ["max", "disabled"], Gt = ["min", "disabled"], Qt = {
|
1043
1043
|
key: 0,
|
1044
1044
|
class: "block text-xs font-medium text-gray-600 mb-1"
|
1045
|
-
},
|
1045
|
+
}, Zt = ["max", "disabled"], Jt = {
|
1046
1046
|
key: 0,
|
1047
1047
|
class: "block text-xs font-medium text-gray-600 mb-1"
|
1048
|
-
},
|
1048
|
+
}, Xt = {
|
1049
1049
|
key: 0,
|
1050
1050
|
class: "block text-xs font-medium text-gray-600 mb-1"
|
1051
|
-
},
|
1051
|
+
}, el = ["min", "disabled"], tl = { class: "flex gap-1 pt-2" }, ll = ["onClick"], al = /* @__PURE__ */ Y({
|
1052
1052
|
__name: "date-input",
|
1053
1053
|
props: {
|
1054
1054
|
id: {},
|
@@ -1074,231 +1074,231 @@ const Tt = {
|
|
1074
1074
|
sort: {}
|
1075
1075
|
},
|
1076
1076
|
emits: ["update:modelValue", "change", "clear"],
|
1077
|
-
setup(
|
1078
|
-
const l =
|
1079
|
-
activeMode:
|
1077
|
+
setup(i, { expose: r, emit: d }) {
|
1078
|
+
const l = i, a = Ye(), n = zt(), m = d, h = V(null), {
|
1079
|
+
activeMode: g,
|
1080
1080
|
innerValue: k,
|
1081
|
-
onSelectChange:
|
1082
|
-
nextClick:
|
1083
|
-
prevClick:
|
1081
|
+
onSelectChange: b,
|
1082
|
+
nextClick: f,
|
1083
|
+
prevClick: y,
|
1084
1084
|
clear: C
|
1085
|
-
} =
|
1085
|
+
} = qe({
|
1086
1086
|
...l,
|
1087
|
-
popoverRef:
|
1088
|
-
},
|
1089
|
-
return
|
1090
|
-
|
1087
|
+
popoverRef: h
|
1088
|
+
}, m);
|
1089
|
+
return A(() => l.modelValue, (c) => {
|
1090
|
+
c !== void 0 ? (k.value = c, m("update:modelValue", c)) : (g.value = "", k.value = []);
|
1091
1091
|
}), r({
|
1092
1092
|
clear: C,
|
1093
|
-
popoverRef:
|
1094
|
-
}), (
|
1095
|
-
|
1096
|
-
e(
|
1097
|
-
|
1093
|
+
popoverRef: h
|
1094
|
+
}), (c, s) => (p(), w(F, null, [
|
1095
|
+
c.layout === "inline" ? (p(), w("div", Wt, [
|
1096
|
+
e(g) !== "" && e(g) === "range" ? (p(), w("div", qt, [
|
1097
|
+
I(o("input", {
|
1098
1098
|
type: "date",
|
1099
1099
|
max: e(k)[1],
|
1100
1100
|
locale: "uk-UA",
|
1101
|
-
"onUpdate:modelValue":
|
1101
|
+
"onUpdate:modelValue": s[0] || (s[0] = (t) => e(k)[0] = t),
|
1102
1102
|
class: "px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-lg focus:outline-blue-600",
|
1103
|
-
disabled:
|
1104
|
-
}, null, 8,
|
1103
|
+
disabled: c.disabled
|
1104
|
+
}, null, 8, Nt), [
|
1105
1105
|
[te, e(k)[0]]
|
1106
1106
|
]),
|
1107
|
-
|
1107
|
+
I(o("input", {
|
1108
1108
|
type: "date",
|
1109
1109
|
min: e(k)[0],
|
1110
1110
|
locale: "uk-UA",
|
1111
|
-
"onUpdate:modelValue":
|
1111
|
+
"onUpdate:modelValue": s[1] || (s[1] = (t) => e(k)[1] = t),
|
1112
1112
|
class: "px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-lg focus:outline-blue-600 appearance-auto",
|
1113
|
-
disabled:
|
1114
|
-
}, null, 8,
|
1113
|
+
disabled: c.disabled
|
1114
|
+
}, null, 8, Gt), [
|
1115
1115
|
[te, e(k)[1]]
|
1116
1116
|
])
|
1117
1117
|
])) : S("", !0)
|
1118
1118
|
])) : S("", !0),
|
1119
|
-
|
1120
|
-
class:
|
1119
|
+
o("div", {
|
1120
|
+
class: j(c.layout === "popover" ? "space-y-3 p-2" : "flex items-center gap-2")
|
1121
1121
|
}, [
|
1122
|
-
|
1123
|
-
class:
|
1122
|
+
o("div", {
|
1123
|
+
class: j(c.layout !== "popover" ? "w-[48%]" : "")
|
1124
1124
|
}, [
|
1125
|
-
|
1126
|
-
|
1125
|
+
c.layout === "popover" ? (p(), w("label", Qt, "Від")) : S("", !0),
|
1126
|
+
I(o("input", {
|
1127
1127
|
type: "date",
|
1128
1128
|
max: e(k)[1],
|
1129
1129
|
locale: "uk-UA",
|
1130
|
-
"onUpdate:modelValue":
|
1131
|
-
class:
|
1132
|
-
disabled:
|
1133
|
-
}, null, 10,
|
1130
|
+
"onUpdate:modelValue": s[2] || (s[2] = (t) => e(k)[0] = t),
|
1131
|
+
class: j(e(a)),
|
1132
|
+
disabled: c.disabled
|
1133
|
+
}, null, 10, Zt), [
|
1134
1134
|
[te, e(k)[0]]
|
1135
1135
|
])
|
1136
1136
|
], 2),
|
1137
|
-
|
1138
|
-
|
1139
|
-
class:
|
1137
|
+
c.layout !== "popover" ? (p(), w("label", Jt, " - ")) : S("", !0),
|
1138
|
+
o("div", {
|
1139
|
+
class: j(c.layout !== "popover" ? "w-[48%]" : "")
|
1140
1140
|
}, [
|
1141
|
-
|
1142
|
-
|
1141
|
+
c.layout === "popover" ? (p(), w("label", Xt, "До")) : S("", !0),
|
1142
|
+
I(o("input", {
|
1143
1143
|
type: "date",
|
1144
1144
|
min: e(k)[0],
|
1145
1145
|
locale: "uk-UA",
|
1146
|
-
"onUpdate:modelValue":
|
1147
|
-
class:
|
1148
|
-
disabled:
|
1149
|
-
}, null, 10,
|
1146
|
+
"onUpdate:modelValue": s[3] || (s[3] = (t) => e(k)[1] = t),
|
1147
|
+
class: j(e(a)),
|
1148
|
+
disabled: c.disabled
|
1149
|
+
}, null, 10, el), [
|
1150
1150
|
[te, e(k)[1]]
|
1151
1151
|
])
|
1152
1152
|
], 2)
|
1153
1153
|
], 2),
|
1154
|
-
|
1155
|
-
(
|
1154
|
+
o("div", tl, [
|
1155
|
+
(p(), w(F, null, q(["today", "week", "month", "quarter", "year"], (t) => o("button", {
|
1156
1156
|
key: t,
|
1157
|
-
class:
|
1158
|
-
onClick: (
|
1159
|
-
}, K(e(
|
1160
|
-
|
1161
|
-
class:
|
1162
|
-
onClick:
|
1163
|
-
(...t) => e(
|
1157
|
+
class: j(e(n) + (e(g) === t ? " bg-blue-100" : "")),
|
1158
|
+
onClick: (x) => e(b)(t)
|
1159
|
+
}, K(e(Yt)(t)), 11, ll)), 64)),
|
1160
|
+
o("button", {
|
1161
|
+
class: j(e(n)),
|
1162
|
+
onClick: s[4] || (s[4] = //@ts-ignore
|
1163
|
+
(...t) => e(y) && e(y)(...t))
|
1164
1164
|
}, " <", 2),
|
1165
|
-
|
1166
|
-
class:
|
1167
|
-
onClick:
|
1168
|
-
(...t) => e(
|
1165
|
+
o("button", {
|
1166
|
+
class: j(e(n)),
|
1167
|
+
onClick: s[5] || (s[5] = //@ts-ignore
|
1168
|
+
(...t) => e(f) && e(f)(...t))
|
1169
1169
|
}, " >", 2)
|
1170
1170
|
]),
|
1171
|
-
(
|
1171
|
+
(c.cleanable, S("", !0))
|
1172
1172
|
], 64));
|
1173
1173
|
}
|
1174
1174
|
});
|
1175
|
-
function
|
1175
|
+
function ol(i, r) {
|
1176
1176
|
const {
|
1177
|
-
api:
|
1177
|
+
api: d,
|
1178
1178
|
options: l = [],
|
1179
|
-
limit:
|
1179
|
+
limit: a = 20,
|
1180
1180
|
dataKey: n = "data"
|
1181
|
-
} =
|
1182
|
-
function
|
1183
|
-
return
|
1181
|
+
} = i, m = i.multi;
|
1182
|
+
function h($) {
|
1183
|
+
return m ? Array.isArray($) ? $ : $ ? [$] : [] : Array.isArray($) ? $[0] : $;
|
1184
1184
|
}
|
1185
|
-
const
|
1186
|
-
function
|
1187
|
-
const O =
|
1185
|
+
const g = V(h(i.modelValue)), k = V(""), b = V(!1), f = V([]), y = V("id"), C = V("text"), c = V(!1), s = V(i.layout !== "popover" && l.length > a), t = V([]), x = V(0);
|
1186
|
+
function v($) {
|
1187
|
+
const O = $.find(Boolean) ?? {}, G = ["id", "value", "code", "key"].find((ae) => ae in O) ?? "id", ie = ["text", "label", "name", "title"].find((ae) => ae in O) ?? "text";
|
1188
1188
|
return { autoValueKey: G, autoLabelKey: ie };
|
1189
1189
|
}
|
1190
1190
|
if (l.length > 0) {
|
1191
|
-
const
|
1192
|
-
|
1191
|
+
const $ = v(l);
|
1192
|
+
y.value = $.autoValueKey, C.value = $.autoLabelKey;
|
1193
1193
|
}
|
1194
|
-
const
|
1195
|
-
if (
|
1196
|
-
const
|
1197
|
-
if (
|
1194
|
+
const u = E(() => {
|
1195
|
+
if (d) return f.value;
|
1196
|
+
const $ = f.value;
|
1197
|
+
if (i.layout === "popover") return $;
|
1198
1198
|
if (!k.value)
|
1199
|
-
return
|
1199
|
+
return c.value ? $ : $.slice(0, a);
|
1200
1200
|
const O = k.value.toLowerCase();
|
1201
|
-
return
|
1201
|
+
return $.filter((G) => G[C.value].toLowerCase().includes(O));
|
1202
1202
|
});
|
1203
1203
|
let _ = null;
|
1204
|
-
async function
|
1205
|
-
if (
|
1206
|
-
|
1204
|
+
async function B($) {
|
1205
|
+
if (d) {
|
1206
|
+
b.value = !0;
|
1207
1207
|
try {
|
1208
|
-
const O = new URL(
|
1209
|
-
O.searchParams.set("json", "1"), O.searchParams.set("key",
|
1208
|
+
const O = new URL(d, window.location.origin);
|
1209
|
+
O.searchParams.set("json", "1"), O.searchParams.set("key", $), O.searchParams.set("limit", a.toString());
|
1210
1210
|
const G = await fetch(O.toString());
|
1211
1211
|
if (!G.ok)
|
1212
1212
|
throw new Error(`HTTP error! status: ${G.status}`);
|
1213
1213
|
const ie = await G.json();
|
1214
|
-
if (
|
1215
|
-
const ae =
|
1216
|
-
|
1214
|
+
if (f.value = ie[n], f.value.length > 0) {
|
1215
|
+
const ae = v(f.value);
|
1216
|
+
y.value = ae.autoValueKey, C.value = ae.autoLabelKey;
|
1217
1217
|
}
|
1218
|
-
|
1218
|
+
x.value = ie.total;
|
1219
1219
|
} catch (O) {
|
1220
1220
|
console.error("Failed to fetch remote options:", O);
|
1221
1221
|
} finally {
|
1222
|
-
|
1222
|
+
b.value = !1;
|
1223
1223
|
}
|
1224
1224
|
}
|
1225
1225
|
}
|
1226
|
-
|
1227
|
-
|
1228
|
-
|
1226
|
+
A(k, ($) => {
|
1227
|
+
d && (_ && clearTimeout(_), _ = setTimeout(() => {
|
1228
|
+
B($);
|
1229
1229
|
}, 200));
|
1230
|
-
}),
|
1231
|
-
|
1232
|
-
}, { immediate: !0 }),
|
1233
|
-
function
|
1234
|
-
return
|
1235
|
-
}
|
1236
|
-
function
|
1237
|
-
if (
|
1238
|
-
const O =
|
1239
|
-
|
1230
|
+
}), A(() => i.modelValue, ($) => {
|
1231
|
+
g.value = h($);
|
1232
|
+
}, { immediate: !0 }), d ? B("") : f.value = l;
|
1233
|
+
function M($) {
|
1234
|
+
return m && Array.isArray(g.value) ? g.value.includes($[y.value]) : g.value && g.value === $[y.value];
|
1235
|
+
}
|
1236
|
+
function L($) {
|
1237
|
+
if (m && !Array.isArray(g.value) && (g.value = []), m && Array.isArray(g.value)) {
|
1238
|
+
const O = g.value.includes($[y.value]);
|
1239
|
+
g.value = O ? g.value.filter((G) => G !== $[y.value]) : [...g.value, $[y.value]], t.value = O ? t.value.filter((G) => G !== $[C.value]) : [...t.value, $[C.value]];
|
1240
1240
|
} else
|
1241
|
-
|
1242
|
-
r("update:modelValue",
|
1241
|
+
g.value = $[y.value], t.value = $[C.value];
|
1242
|
+
r("update:modelValue", g.value), r("change", { name: i.name, value: g.value });
|
1243
1243
|
}
|
1244
|
-
function
|
1245
|
-
|
1244
|
+
function T() {
|
1245
|
+
m ? (g.value = [], t.value = []) : (g.value = void 0, t.value = []), r("update:modelValue", g.value), r("clear", i.name);
|
1246
1246
|
}
|
1247
|
-
function
|
1248
|
-
_ && clearTimeout(_), k.value = "",
|
1247
|
+
function U() {
|
1248
|
+
_ && clearTimeout(_), k.value = "", c.value = !1;
|
1249
1249
|
}
|
1250
1250
|
function de() {
|
1251
|
-
|
1251
|
+
c.value = !c.value;
|
1252
1252
|
}
|
1253
1253
|
he(() => {
|
1254
1254
|
_ && clearTimeout(_);
|
1255
1255
|
});
|
1256
1256
|
const J = V(-1);
|
1257
|
-
|
1258
|
-
J.value =
|
1257
|
+
A(u, () => {
|
1258
|
+
J.value = u.value.length > 0 ? 0 : -1;
|
1259
1259
|
});
|
1260
|
-
function
|
1261
|
-
const O =
|
1262
|
-
if (
|
1263
|
-
|
1264
|
-
else if (
|
1265
|
-
|
1266
|
-
else if (
|
1267
|
-
const G =
|
1268
|
-
|
1260
|
+
function H($) {
|
1261
|
+
const O = u.value.length;
|
1262
|
+
if ($.key === "ArrowDown")
|
1263
|
+
$.preventDefault(), J.value = (J.value + 1) % O;
|
1264
|
+
else if ($.key === "ArrowUp")
|
1265
|
+
$.preventDefault(), J.value = (J.value - 1 + O) % O;
|
1266
|
+
else if ($.key === "Enter" && ($.preventDefault(), J.value >= 0 && J.value < u.value.length)) {
|
1267
|
+
const G = u.value[J.value];
|
1268
|
+
L(G);
|
1269
1269
|
}
|
1270
1270
|
}
|
1271
1271
|
return {
|
1272
|
-
innerValue:
|
1272
|
+
innerValue: g,
|
1273
1273
|
searchTerm: k,
|
1274
|
-
filteredOptions:
|
1275
|
-
isSelected:
|
1276
|
-
selectItem:
|
1277
|
-
clear:
|
1278
|
-
resetSearch:
|
1274
|
+
filteredOptions: u,
|
1275
|
+
isSelected: M,
|
1276
|
+
selectItem: L,
|
1277
|
+
clear: T,
|
1278
|
+
resetSearch: U,
|
1279
1279
|
toggleShowAll: de,
|
1280
|
-
isReqProc:
|
1281
|
-
showAll:
|
1282
|
-
isEnableShowAll:
|
1280
|
+
isReqProc: b,
|
1281
|
+
showAll: c,
|
1282
|
+
isEnableShowAll: s,
|
1283
1283
|
labelKey: C,
|
1284
|
-
valueKey:
|
1285
|
-
allOptions:
|
1284
|
+
valueKey: y,
|
1285
|
+
allOptions: f,
|
1286
1286
|
highlightedIndex: J,
|
1287
|
-
onKeyDown:
|
1287
|
+
onKeyDown: H,
|
1288
1288
|
selectedLabels: t,
|
1289
|
-
totalCount:
|
1289
|
+
totalCount: x
|
1290
1290
|
};
|
1291
1291
|
}
|
1292
|
-
const
|
1292
|
+
const rl = { class: "h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relative justify-center" }, nl = {
|
1293
1293
|
key: 0,
|
1294
1294
|
class: "w-full"
|
1295
|
-
},
|
1295
|
+
}, il = { class: "flex flex-col items-center justify-center p-5 text-center" }, sl = {
|
1296
1296
|
key: 0,
|
1297
1297
|
class: "flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"
|
1298
|
-
},
|
1298
|
+
}, ul = {
|
1299
1299
|
key: 1,
|
1300
1300
|
class: "flex justify-between items-center text-xs text-gray-500 p-1 border-t"
|
1301
|
-
},
|
1301
|
+
}, dl = /* @__PURE__ */ Y({
|
1302
1302
|
__name: "select",
|
1303
1303
|
props: {
|
1304
1304
|
id: {},
|
@@ -1324,60 +1324,60 @@ const tl = { class: "h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relat
|
|
1324
1324
|
sort: {}
|
1325
1325
|
},
|
1326
1326
|
emits: ["update:modelValue", "change", "clear"],
|
1327
|
-
setup(
|
1328
|
-
const l =
|
1329
|
-
innerValue:
|
1330
|
-
filteredOptions:
|
1331
|
-
isSelected:
|
1327
|
+
setup(i, { expose: r, emit: d }) {
|
1328
|
+
const l = i, a = d, n = V(null), {
|
1329
|
+
innerValue: m,
|
1330
|
+
filteredOptions: h,
|
1331
|
+
isSelected: g,
|
1332
1332
|
selectItem: k,
|
1333
|
-
clear:
|
1334
|
-
resetSearch:
|
1335
|
-
toggleShowAll:
|
1333
|
+
clear: b,
|
1334
|
+
resetSearch: f,
|
1335
|
+
toggleShowAll: y,
|
1336
1336
|
isReqProc: C,
|
1337
|
-
showAll:
|
1338
|
-
isEnableShowAll:
|
1337
|
+
showAll: c,
|
1338
|
+
isEnableShowAll: s,
|
1339
1339
|
searchTerm: t,
|
1340
|
-
labelKey:
|
1341
|
-
valueKey:
|
1342
|
-
highlightedIndex:
|
1340
|
+
labelKey: x,
|
1341
|
+
valueKey: v,
|
1342
|
+
highlightedIndex: u,
|
1343
1343
|
onKeyDown: _,
|
1344
|
-
selectedLabels:
|
1345
|
-
totalCount:
|
1346
|
-
} =
|
1344
|
+
selectedLabels: B,
|
1345
|
+
totalCount: M
|
1346
|
+
} = ol({
|
1347
1347
|
...l,
|
1348
1348
|
modelValue: l.modelValue
|
1349
|
-
},
|
1349
|
+
}, a);
|
1350
1350
|
ue(() => {
|
1351
|
-
|
1352
|
-
}),
|
1351
|
+
f();
|
1352
|
+
}), A(
|
1353
1353
|
() => l.modelValue,
|
1354
|
-
(
|
1355
|
-
|
1354
|
+
(T) => {
|
1355
|
+
T === void 0 && (l.multi ? m.value = [] : m.value = void 0);
|
1356
1356
|
}
|
1357
1357
|
);
|
1358
|
-
const
|
1359
|
-
return
|
1360
|
-
var
|
1361
|
-
|
1358
|
+
const L = V([]);
|
1359
|
+
return A(u, (T) => {
|
1360
|
+
var U;
|
1361
|
+
T >= 0 && L.value[T] && ((U = L.value[T]) == null || U.scrollIntoView({
|
1362
1362
|
block: "nearest",
|
1363
1363
|
behavior: "smooth"
|
1364
1364
|
}));
|
1365
|
-
}),
|
1366
|
-
|
1365
|
+
}), A(h, () => {
|
1366
|
+
L.value = [];
|
1367
1367
|
}), r({
|
1368
|
-
clear:
|
1368
|
+
clear: b,
|
1369
1369
|
inputTextRef: n,
|
1370
|
-
selectedLabels:
|
1371
|
-
}), (
|
1370
|
+
selectedLabels: B
|
1371
|
+
}), (T, U) => {
|
1372
1372
|
var de, J;
|
1373
|
-
return
|
1374
|
-
class:
|
1373
|
+
return p(), w("div", {
|
1374
|
+
class: j([T.layout === "popover" ? "flex flex-col h-full" : "flex flex-col vs-filter-checkbox space-y-0.5"])
|
1375
1375
|
}, [
|
1376
|
-
|
1377
|
-
|
1378
|
-
"onUpdate:modelValue":
|
1379
|
-
onKeydown:
|
1380
|
-
(...
|
1376
|
+
o("div", rl, [
|
1377
|
+
I(o("input", {
|
1378
|
+
"onUpdate:modelValue": U[0] || (U[0] = (H) => Qe(t) ? t.value = H : null),
|
1379
|
+
onKeydown: U[1] || (U[1] = //@ts-ignore
|
1380
|
+
(...H) => e(_) && e(_)(...H)),
|
1381
1381
|
class: "w-full h-full text-[13px] px-4 border rounded-sm pl-9 focus:outline-none focus:ring-ring focus:ring-1 focus:ring-blue-500",
|
1382
1382
|
placeholder: "Пошук",
|
1383
1383
|
type: "text",
|
@@ -1386,93 +1386,93 @@ const tl = { class: "h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relat
|
|
1386
1386
|
}, null, 544), [
|
1387
1387
|
[te, e(t)]
|
1388
1388
|
]),
|
1389
|
-
P(
|
1390
|
-
P(
|
1391
|
-
onClick:
|
1389
|
+
P(He, { class: "absolute text-gray-400 -translate-y-1/2 left-4 top-1/2" }),
|
1390
|
+
P(Ee, {
|
1391
|
+
onClick: U[2] || (U[2] = (H) => t.value = ""),
|
1392
1392
|
class: "absolute text-gray-400 -translate-y-1/2 cursor-pointer hover:text-red-500 right-4 top-1/2"
|
1393
1393
|
})
|
1394
1394
|
]),
|
1395
|
-
|
1396
|
-
class:
|
1397
|
-
|
1398
|
-
|
1395
|
+
o("div", {
|
1396
|
+
class: j([
|
1397
|
+
T.layout === "popover" ? "flex-1 overflow-y-auto max-h-64 p-2" : "",
|
1398
|
+
T.layout === "inline" ? "flex-1 overflow-y-auto max-h-80" : ""
|
1399
1399
|
])
|
1400
1400
|
}, [
|
1401
|
-
(
|
1402
|
-
layout:
|
1403
|
-
count:
|
1404
|
-
label:
|
1405
|
-
color:
|
1406
|
-
type:
|
1407
|
-
value:
|
1408
|
-
"is-selected": e(
|
1409
|
-
highlighted:
|
1410
|
-
onItemClick: (O) => e(k)(
|
1401
|
+
(p(!0), w(F, null, q(e(h), (H, $) => (p(), z(Ce, {
|
1402
|
+
layout: T.layout,
|
1403
|
+
count: H.count,
|
1404
|
+
label: H[e(x)],
|
1405
|
+
color: H.color,
|
1406
|
+
type: T.multi ? "checkbox" : "radio",
|
1407
|
+
value: H[e(v)],
|
1408
|
+
"is-selected": e(g)(H),
|
1409
|
+
highlighted: $ === e(u),
|
1410
|
+
onItemClick: (O) => e(k)(H),
|
1411
1411
|
ref_for: !0,
|
1412
|
-
ref: (O) =>
|
1412
|
+
ref: (O) => L.value[$] = O == null ? void 0 : O.el
|
1413
1413
|
}, null, 8, ["layout", "count", "label", "color", "type", "value", "is-selected", "highlighted", "onItemClick"]))), 256))
|
1414
1414
|
], 2),
|
1415
|
-
|
1416
|
-
|
1415
|
+
T.type === "select" && e(h).length === 0 && !e(C) ? (p(), w("div", nl, [
|
1416
|
+
o("div", il, [
|
1417
1417
|
P(Ve),
|
1418
|
-
|
1419
|
-
|
1420
|
-
|
1418
|
+
U[7] || (U[7] = o("div", { class: "max-w-sm mx-auto mt-6" }, [
|
1419
|
+
o("p", { class: "font-medium text-gray-800 dark:text-neutral-200" }, "За вашим запитом нічого не знайдено"),
|
1420
|
+
o("p", { class: "mt-2 text-sm text-gray-500 dark:text-neutral-500" })
|
1421
1421
|
], -1))
|
1422
1422
|
])
|
1423
1423
|
])) : S("", !0),
|
1424
|
-
|
1425
|
-
!e(
|
1424
|
+
T.layout !== "popover" && T.type !== "select" ? (p(), w(F, { key: 1 }, [
|
1425
|
+
!e(c) && e(s) ? (p(), w("div", {
|
1426
1426
|
key: 0,
|
1427
|
-
onClick:
|
1428
|
-
(...
|
1427
|
+
onClick: U[3] || (U[3] = //@ts-ignore
|
1428
|
+
(...H) => e(y) && e(y)(...H)),
|
1429
1429
|
class: "inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"
|
1430
1430
|
}, [
|
1431
|
-
|
1431
|
+
U[8] || (U[8] = W(" Показати більше ", -1)),
|
1432
1432
|
P(be)
|
1433
1433
|
])) : S("", !0),
|
1434
|
-
e(
|
1434
|
+
e(c) ? (p(), w("div", {
|
1435
1435
|
key: 1,
|
1436
|
-
onClick:
|
1437
|
-
(...
|
1436
|
+
onClick: U[4] || (U[4] = //@ts-ignore
|
1437
|
+
(...H) => e(y) && e(y)(...H)),
|
1438
1438
|
class: "inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"
|
1439
1439
|
}, [
|
1440
|
-
|
1440
|
+
U[9] || (U[9] = W(" Показати менше ", -1)),
|
1441
1441
|
P(Se)
|
1442
1442
|
])) : S("", !0)
|
1443
1443
|
], 64)) : S("", !0),
|
1444
|
-
|
1445
|
-
|
1446
|
-
|
1447
|
-
|
1444
|
+
T.cleanable ? (p(), w(F, { key: 2 }, [
|
1445
|
+
T.layout === "inline" ? (p(), w("div", sl, [
|
1446
|
+
W(K(T.multi && Array.isArray(e(m)) ? (de = e(m)) == null ? void 0 : de.length : e(m) !== void 0 && (e(m) || e(m) === null) ? 1 : 0) + " з " + K(e(M)) + " обрано ", 1),
|
1447
|
+
I(o("button", {
|
1448
1448
|
class: "text-gray-600 hover:text-gray-800",
|
1449
|
-
onClick:
|
1450
|
-
(...
|
1449
|
+
onClick: U[5] || (U[5] = //@ts-ignore
|
1450
|
+
(...H) => e(b) && e(b)(...H))
|
1451
1451
|
}, " Очистити ", 512), [
|
1452
|
-
[X, e(
|
1452
|
+
[X, e(m) !== "" && e(m) !== void 0 || e(m)]
|
1453
1453
|
])
|
1454
1454
|
])) : S("", !0),
|
1455
|
-
|
1456
|
-
|
1457
|
-
|
1455
|
+
T.layout === "popover" ? (p(), w("div", ul, [
|
1456
|
+
o("span", null, K(T.multi && Array.isArray(e(m)) ? (J = e(m)) == null ? void 0 : J.length : e(m) !== void 0 && (e(m) || e(m) === null) ? 1 : 0) + " з " + K(e(M)) + " обрано", 1),
|
1457
|
+
I(o("button", {
|
1458
1458
|
class: "text-gray-600 hover:text-gray-800",
|
1459
|
-
onClick:
|
1460
|
-
(...
|
1459
|
+
onClick: U[6] || (U[6] = //@ts-ignore
|
1460
|
+
(...H) => e(b) && e(b)(...H))
|
1461
1461
|
}, " Очистити ", 512), [
|
1462
|
-
[X, e(
|
1462
|
+
[X, e(m) !== "" && e(m) !== void 0 || e(m)]
|
1463
1463
|
])
|
1464
1464
|
])) : S("", !0)
|
1465
1465
|
], 64)) : S("", !0)
|
1466
1466
|
], 2);
|
1467
1467
|
};
|
1468
1468
|
}
|
1469
|
-
}),
|
1469
|
+
}), cl = ["for", "onClick"], pl = ["id", "name", "value"], fl = { class: "block" }, vl = {
|
1470
1470
|
key: 0,
|
1471
1471
|
class: "flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"
|
1472
|
-
},
|
1472
|
+
}, ml = {
|
1473
1473
|
key: 1,
|
1474
1474
|
class: "flex justify-between items-center text-xs text-gray-500 p-1 border-t"
|
1475
|
-
},
|
1475
|
+
}, gl = /* @__PURE__ */ Y({
|
1476
1476
|
__name: "tag-field",
|
1477
1477
|
props: {
|
1478
1478
|
id: {},
|
@@ -1498,68 +1498,68 @@ const tl = { class: "h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relat
|
|
1498
1498
|
sort: {}
|
1499
1499
|
},
|
1500
1500
|
emits: ["update:modelValue", "change", "clear"],
|
1501
|
-
setup(
|
1502
|
-
const l =
|
1501
|
+
setup(i, { expose: r, emit: d }) {
|
1502
|
+
const l = i, a = d, {
|
1503
1503
|
innerValue: n,
|
1504
|
-
isSelected:
|
1505
|
-
selectItem:
|
1506
|
-
clear:
|
1504
|
+
isSelected: m,
|
1505
|
+
selectItem: h,
|
1506
|
+
clear: g,
|
1507
1507
|
labelKey: k,
|
1508
|
-
valueKey:
|
1509
|
-
allOptions:
|
1510
|
-
} = l.multi ?
|
1508
|
+
valueKey: b,
|
1509
|
+
allOptions: f
|
1510
|
+
} = l.multi ? Te({
|
1511
1511
|
...l,
|
1512
1512
|
modelValue: l.modelValue ?? l.default ?? []
|
1513
|
-
},
|
1513
|
+
}, a) : Ie({
|
1514
1514
|
...l,
|
1515
1515
|
modelValue: l.modelValue !== void 0 ? l.modelValue : l.default ?? ""
|
1516
|
-
},
|
1516
|
+
}, a);
|
1517
1517
|
return r({
|
1518
|
-
clear:
|
1519
|
-
}),
|
1518
|
+
clear: g
|
1519
|
+
}), A(
|
1520
1520
|
() => l.modelValue,
|
1521
|
-
(
|
1522
|
-
|
1521
|
+
(y) => {
|
1522
|
+
y === void 0 && (l.multi ? n.value = [] : n.value = void 0);
|
1523
1523
|
}
|
1524
|
-
), (
|
1525
|
-
var
|
1526
|
-
return
|
1527
|
-
|
1528
|
-
class:
|
1524
|
+
), (y, C) => {
|
1525
|
+
var c, s;
|
1526
|
+
return p(), w(F, null, [
|
1527
|
+
o("div", {
|
1528
|
+
class: j(["grid grid-cols-3 gap-2 mx-[1px]", y.layout === "popover" ? "m-1" : "mb-1"])
|
1529
1529
|
}, [
|
1530
|
-
(
|
1531
|
-
key: `item-${t[e(
|
1532
|
-
for: `item-${t[e(
|
1533
|
-
onClick:
|
1534
|
-
class:
|
1530
|
+
(p(!0), w(F, null, q(e(f), (t) => (p(), w("label", {
|
1531
|
+
key: `item-${t[e(b)]}`,
|
1532
|
+
for: `item-${t[e(b)]}`,
|
1533
|
+
onClick: Oe((x) => e(h)(t), ["stop", "prevent"]),
|
1534
|
+
class: j([e(m)(t) ? "ring-2 ring-indigo-600" : "", "p-2.5 group relative flex justify-center items-center gap-x-12 text-center text-xs bg-white text-gray-800 border border-gray-200 cursor-pointer rounded-lg dark:bg-neutral-900 dark:border-neutral-700 dark:text-neutral-200 peer-checked:text-indigo-600 dark:has-checked:text-indigo-500 peer-checked:border-indigo-600 dark:has-checked:border-indigo-500 peer-checked:ring peer-checked:shadow focus:ring dark:has-checked:ring-indigo-500 has-disabled:pointer-events-none has-disabled:text-gray-200 dark:has-disabled:text-neutral-700 has-disabled:after:absolute has-disabled:after:inset-0 has-disabled:after:bg-[linear-gradient(to_right_bottom,transparent_calc(50%-1px),var(--color-gray-200)_calc(50%-1px),var(--color-gray-200)_50%,transparent_50%)] dark:has-disabled:after:bg-[linear-gradient(to_right_bottom,transparent_calc(50%-1px),var(--color-neutral-700)_calc(50%-1px),var(--color-neutral-700)_50%,transparent_50%)]"])
|
1535
1535
|
}, [
|
1536
|
-
|
1536
|
+
o("input", {
|
1537
1537
|
type: "checkbox",
|
1538
|
-
id: `item-${t[e(
|
1538
|
+
id: `item-${t[e(b)]}`,
|
1539
1539
|
class: "hidden w4poy border-gray-200 g41z1 g22e3 axcnw dark:text-indigo-500 dark:border-neutral-700 dark:focus:ring-neutral-900",
|
1540
|
-
name: `item-${t[e(
|
1541
|
-
value: t[e(
|
1542
|
-
}, null, 8,
|
1543
|
-
|
1544
|
-
], 10,
|
1540
|
+
name: `item-${t[e(b)]}`,
|
1541
|
+
value: t[e(b)]
|
1542
|
+
}, null, 8, pl),
|
1543
|
+
o("span", fl, K(t[e(k)]), 1)
|
1544
|
+
], 10, cl))), 128))
|
1545
1545
|
], 2),
|
1546
|
-
|
1547
|
-
|
1548
|
-
|
1549
|
-
|
1546
|
+
y.cleanable ? (p(), w(F, { key: 0 }, [
|
1547
|
+
y.layout === "inline" ? (p(), w("div", vl, [
|
1548
|
+
W(K(y.multi && Array.isArray(e(n)) ? (c = e(n)) == null ? void 0 : c.length : e(n) !== void 0 && (e(n) || e(n) === null) ? 1 : 0) + " з " + K(e(f).length) + " обрано ", 1),
|
1549
|
+
I(o("button", {
|
1550
1550
|
class: "text-gray-600 hover:text-gray-800",
|
1551
1551
|
onClick: C[0] || (C[0] = //@ts-ignore
|
1552
|
-
(...t) => e(
|
1552
|
+
(...t) => e(g) && e(g)(...t))
|
1553
1553
|
}, " Очистити ", 512), [
|
1554
1554
|
[X, e(n) !== "" && e(n) !== void 0 || e(n)]
|
1555
1555
|
])
|
1556
1556
|
])) : S("", !0),
|
1557
|
-
|
1558
|
-
|
1559
|
-
|
1557
|
+
y.layout === "popover" ? (p(), w("div", ml, [
|
1558
|
+
o("span", null, K(y.multi && Array.isArray(e(n)) ? (s = e(n)) == null ? void 0 : s.length : e(n) !== void 0 && (e(n) || e(n) === null) ? 1 : 0) + " з " + K(e(f).length) + " обрано", 1),
|
1559
|
+
I(o("button", {
|
1560
1560
|
class: "text-gray-600 hover:text-gray-800",
|
1561
1561
|
onClick: C[1] || (C[1] = //@ts-ignore
|
1562
|
-
(...t) => e(
|
1562
|
+
(...t) => e(g) && e(g)(...t))
|
1563
1563
|
}, " Очистити ", 512), [
|
1564
1564
|
[X, e(n) !== void 0 && e(n) !== "" || e(n)]
|
1565
1565
|
])
|
@@ -1568,7 +1568,7 @@ const tl = { class: "h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relat
|
|
1568
1568
|
], 64);
|
1569
1569
|
};
|
1570
1570
|
}
|
1571
|
-
}),
|
1571
|
+
}), hl = {}, bl = {
|
1572
1572
|
xmlns: "http://www.w3.org/2000/svg",
|
1573
1573
|
width: "24",
|
1574
1574
|
height: "24",
|
@@ -1580,12 +1580,12 @@ const tl = { class: "h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relat
|
|
1580
1580
|
"stroke-linejoin": "round",
|
1581
1581
|
class: "text-blue-600 w-[16px] h-[16px]"
|
1582
1582
|
};
|
1583
|
-
function
|
1584
|
-
return
|
1585
|
-
|
1583
|
+
function yl(i, r) {
|
1584
|
+
return p(), w("svg", bl, r[0] || (r[0] = [
|
1585
|
+
o("path", { d: "M20 6 9 17l-5-5" }, null, -1)
|
1586
1586
|
]));
|
1587
1587
|
}
|
1588
|
-
const se = /* @__PURE__ */ le(
|
1588
|
+
const se = /* @__PURE__ */ le(hl, [["render", yl]]), xl = {}, wl = {
|
1589
1589
|
xmlns: "http://www.w3.org/2000/svg",
|
1590
1590
|
width: "15px",
|
1591
1591
|
height: "24",
|
@@ -1597,17 +1597,17 @@ const se = /* @__PURE__ */ le(fl, [["render", ml]]), gl = {}, hl = {
|
|
1597
1597
|
"stroke-linejoin": "round",
|
1598
1598
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-chevron-down text-gray-800 rotate-[90deg]"
|
1599
1599
|
};
|
1600
|
-
function
|
1601
|
-
return
|
1602
|
-
|
1600
|
+
function kl(i, r) {
|
1601
|
+
return p(), w("svg", wl, r[0] || (r[0] = [
|
1602
|
+
o("path", {
|
1603
1603
|
stroke: "none",
|
1604
1604
|
d: "M0 0h24v24H0z",
|
1605
1605
|
fill: "none"
|
1606
1606
|
}, null, -1),
|
1607
|
-
|
1607
|
+
o("path", { d: "M6 9l6 6l6 -6" }, null, -1)
|
1608
1608
|
]));
|
1609
1609
|
}
|
1610
|
-
const
|
1610
|
+
const _l = /* @__PURE__ */ le(xl, [["render", kl]]), Cl = {}, Vl = {
|
1611
1611
|
xmlns: "http://www.w3.org/2000/svg",
|
1612
1612
|
width: "15px",
|
1613
1613
|
height: "24",
|
@@ -1619,20 +1619,20 @@ const yl = /* @__PURE__ */ le(gl, [["render", bl]]), xl = {}, wl = {
|
|
1619
1619
|
"stroke-linejoin": "round",
|
1620
1620
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-chevron-down text-gray-800 rotate-[270deg]"
|
1621
1621
|
};
|
1622
|
-
function
|
1623
|
-
return
|
1624
|
-
|
1622
|
+
function Sl(i, r) {
|
1623
|
+
return p(), w("svg", Vl, r[0] || (r[0] = [
|
1624
|
+
o("path", {
|
1625
1625
|
stroke: "none",
|
1626
1626
|
d: "M0 0h24v24H0z",
|
1627
1627
|
fill: "none"
|
1628
1628
|
}, null, -1),
|
1629
|
-
|
1629
|
+
o("path", { d: "M6 9l6 6l6 -6" }, null, -1)
|
1630
1630
|
]));
|
1631
1631
|
}
|
1632
|
-
const
|
1632
|
+
const Ml = /* @__PURE__ */ le(Cl, [["render", Sl]]), Bl = { class: "flex" }, $l = { class: "mb-1" }, Al = { class: "mb-1" }, Rl = { class: "inline-flex rounded-lg shrink-0 pl-1" }, Dl = { class: "inline-flex rounded-lg shrink-0 pl-1" }, zl = {
|
1633
1633
|
key: 1,
|
1634
1634
|
class: "flex gap-1 !w-[75%] rounded-lg"
|
1635
|
-
},
|
1635
|
+
}, jl = ["max", "disabled"], Fl = ["min", "disabled"], Kl = /* @__PURE__ */ Y({
|
1636
1636
|
__name: "date-input-inline",
|
1637
1637
|
props: {
|
1638
1638
|
id: {},
|
@@ -1658,192 +1658,192 @@ const _l = /* @__PURE__ */ le(xl, [["render", kl]]), Cl = { class: "flex" }, Vl
|
|
1658
1658
|
sort: {}
|
1659
1659
|
},
|
1660
1660
|
emits: ["update:modelValue", "change", "clear"],
|
1661
|
-
setup(
|
1662
|
-
const l =
|
1663
|
-
activeMode:
|
1664
|
-
innerValue:
|
1665
|
-
onSelectChange:
|
1661
|
+
setup(i, { expose: r, emit: d }) {
|
1662
|
+
const l = i, a = d, n = V(null), {
|
1663
|
+
activeMode: m,
|
1664
|
+
innerValue: h,
|
1665
|
+
onSelectChange: g,
|
1666
1666
|
nextClick: k,
|
1667
|
-
prevClick:
|
1668
|
-
currentLabel:
|
1669
|
-
clear:
|
1670
|
-
} =
|
1667
|
+
prevClick: b,
|
1668
|
+
currentLabel: f,
|
1669
|
+
clear: y
|
1670
|
+
} = qe({
|
1671
1671
|
...l,
|
1672
1672
|
popoverRef: n
|
1673
|
-
},
|
1674
|
-
return
|
1675
|
-
C !== void 0 ? (
|
1673
|
+
}, a);
|
1674
|
+
return A(() => l.modelValue, (C) => {
|
1675
|
+
C !== void 0 ? (h.value = C, a("update:modelValue", C)) : (m.value = "", h.value = []);
|
1676
1676
|
}), r({
|
1677
|
-
clear:
|
1677
|
+
clear: y,
|
1678
1678
|
popoverRef: n
|
1679
|
-
}), (C,
|
1680
|
-
|
1679
|
+
}), (C, c) => (p(), w(F, null, [
|
1680
|
+
o("div", Bl, [
|
1681
1681
|
P(Me, {
|
1682
1682
|
ref_key: "popoverRef",
|
1683
1683
|
ref: n,
|
1684
|
-
label: e(
|
1685
|
-
"current-value": e(
|
1684
|
+
label: e(f),
|
1685
|
+
"current-value": e(h),
|
1686
1686
|
mode: C.mode,
|
1687
|
-
onClear: e(
|
1687
|
+
onClear: e(y),
|
1688
1688
|
layout: C.layout
|
1689
1689
|
}, {
|
1690
1690
|
default: re(() => [
|
1691
|
-
|
1692
|
-
|
1691
|
+
o("div", null, [
|
1692
|
+
o("button", {
|
1693
1693
|
type: "button",
|
1694
|
-
onClick:
|
1694
|
+
onClick: c[0] || (c[0] = (s) => e(g)("range")),
|
1695
1695
|
class: "flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-lg cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"
|
1696
1696
|
}, [
|
1697
|
-
|
1698
|
-
e(
|
1697
|
+
c[12] || (c[12] = W(" Період ", -1)),
|
1698
|
+
e(m) === "range" ? (p(), z(se, { key: 0 })) : S("", !0)
|
1699
1699
|
])
|
1700
1700
|
]),
|
1701
|
-
|
1702
|
-
|
1701
|
+
c[19] || (c[19] = o("div", null, [
|
1702
|
+
o("div", { class: "pt-1 mt-1 border-t" })
|
1703
1703
|
], -1)),
|
1704
|
-
|
1705
|
-
|
1704
|
+
o("div", null, [
|
1705
|
+
o("button", {
|
1706
1706
|
type: "button",
|
1707
|
-
onClick:
|
1707
|
+
onClick: c[1] || (c[1] = (s) => e(g)("today")),
|
1708
1708
|
class: "flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-lg cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"
|
1709
1709
|
}, [
|
1710
|
-
|
1711
|
-
e(
|
1710
|
+
c[13] || (c[13] = W(" Сьогодні ", -1)),
|
1711
|
+
e(m) === "today" ? (p(), z(se, { key: 0 })) : S("", !0)
|
1712
1712
|
])
|
1713
1713
|
]),
|
1714
|
-
|
1715
|
-
|
1714
|
+
o("div", null, [
|
1715
|
+
o("button", {
|
1716
1716
|
type: "button",
|
1717
|
-
onClick:
|
1717
|
+
onClick: c[2] || (c[2] = (s) => e(g)("week")),
|
1718
1718
|
class: "flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-lg cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"
|
1719
1719
|
}, [
|
1720
|
-
|
1721
|
-
e(
|
1720
|
+
c[14] || (c[14] = W(" Тиждень ", -1)),
|
1721
|
+
e(m) === "week" ? (p(), z(se, { key: 0 })) : S("", !0)
|
1722
1722
|
])
|
1723
1723
|
]),
|
1724
|
-
|
1725
|
-
|
1724
|
+
o("div", null, [
|
1725
|
+
o("button", {
|
1726
1726
|
type: "button",
|
1727
|
-
onClick:
|
1727
|
+
onClick: c[3] || (c[3] = (s) => e(g)("month")),
|
1728
1728
|
class: "flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-lg cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"
|
1729
1729
|
}, [
|
1730
|
-
|
1731
|
-
e(
|
1730
|
+
c[15] || (c[15] = W(" Місяць ", -1)),
|
1731
|
+
e(m) === "month" ? (p(), z(se, { key: 0 })) : S("", !0)
|
1732
1732
|
])
|
1733
1733
|
]),
|
1734
|
-
|
1735
|
-
|
1734
|
+
o("div", null, [
|
1735
|
+
o("button", {
|
1736
1736
|
type: "button",
|
1737
|
-
onClick:
|
1737
|
+
onClick: c[4] || (c[4] = (s) => e(g)("quarter")),
|
1738
1738
|
class: "flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-lg cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"
|
1739
1739
|
}, [
|
1740
|
-
|
1741
|
-
e(
|
1740
|
+
c[16] || (c[16] = W(" Квартал ", -1)),
|
1741
|
+
e(m) === "quarter" ? (p(), z(se, { key: 0 })) : S("", !0)
|
1742
1742
|
])
|
1743
1743
|
]),
|
1744
|
-
|
1745
|
-
|
1744
|
+
o("div", $l, [
|
1745
|
+
o("button", {
|
1746
1746
|
type: "button",
|
1747
|
-
onClick:
|
1747
|
+
onClick: c[5] || (c[5] = (s) => e(g)("year")),
|
1748
1748
|
class: "flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-lg cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"
|
1749
1749
|
}, [
|
1750
|
-
|
1751
|
-
e(
|
1750
|
+
c[17] || (c[17] = W(" Рік ", -1)),
|
1751
|
+
e(m) === "year" ? (p(), z(se, { key: 0 })) : S("", !0)
|
1752
1752
|
])
|
1753
1753
|
]),
|
1754
|
-
|
1755
|
-
|
1754
|
+
o("div", Al, [
|
1755
|
+
o("button", {
|
1756
1756
|
type: "button",
|
1757
|
-
onClick:
|
1757
|
+
onClick: c[6] || (c[6] = (s) => e(y)()),
|
1758
1758
|
class: "flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-lg cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"
|
1759
1759
|
}, [
|
1760
|
-
|
1761
|
-
e(
|
1760
|
+
c[18] || (c[18] = W(" Весь час ", -1)),
|
1761
|
+
e(h)[0] ? S("", !0) : (p(), z(se, { key: 0 }))
|
1762
1762
|
])
|
1763
1763
|
])
|
1764
1764
|
]),
|
1765
1765
|
_: 1,
|
1766
1766
|
__: [19]
|
1767
1767
|
}, 8, ["label", "current-value", "mode", "onClear", "layout"]),
|
1768
|
-
e(
|
1769
|
-
|
1770
|
-
|
1768
|
+
e(m) !== "" && e(m) !== "range" && e(m) !== "last_7_days" ? (p(), w(F, { key: 0 }, [
|
1769
|
+
o("div", Rl, [
|
1770
|
+
o("button", {
|
1771
1771
|
type: "button",
|
1772
1772
|
title: "Попередній період",
|
1773
1773
|
class: "inline-flex h-[38px] items-center px-2 text-sm text-gray-800 bg-gray-100 gap-x-2 -ms-px first:rounded-s-lg first:ms-0 last:rounded-e-lg focus:z-10 hover:bg-gray-200 focus:bg-gray-200 duration-300",
|
1774
|
-
onClick:
|
1775
|
-
(...
|
1774
|
+
onClick: c[7] || (c[7] = //@ts-ignore
|
1775
|
+
(...s) => e(b) && e(b)(...s))
|
1776
1776
|
}, [
|
1777
|
-
P(
|
1777
|
+
P(_l)
|
1778
1778
|
])
|
1779
1779
|
]),
|
1780
|
-
|
1781
|
-
|
1780
|
+
o("div", Dl, [
|
1781
|
+
o("button", {
|
1782
1782
|
type: "button",
|
1783
1783
|
title: "Наступний період",
|
1784
1784
|
class: "inline-flex h-[38px] items-center px-2 text-sm text-gray-800 gap-x-2 bg-gray-100 -ms-px first:rounded-s-lg first:ms-0 last:rounded-e-lg focus:z-10 hover:bg-gray-200 focus:bg-gray-200 duration-300",
|
1785
|
-
onClick:
|
1786
|
-
(...
|
1785
|
+
onClick: c[8] || (c[8] = //@ts-ignore
|
1786
|
+
(...s) => e(k) && e(k)(...s))
|
1787
1787
|
}, [
|
1788
|
-
P(
|
1788
|
+
P(Ml)
|
1789
1789
|
])
|
1790
1790
|
])
|
1791
1791
|
], 64)) : S("", !0),
|
1792
|
-
e(
|
1793
|
-
|
1792
|
+
e(m) !== "" && e(m) === "range" ? (p(), w("div", zl, [
|
1793
|
+
I(o("input", {
|
1794
1794
|
type: "date",
|
1795
|
-
max: e(
|
1795
|
+
max: e(h)[1],
|
1796
1796
|
locale: "uk-UA",
|
1797
|
-
"onUpdate:modelValue":
|
1797
|
+
"onUpdate:modelValue": c[9] || (c[9] = (s) => e(h)[0] = s),
|
1798
1798
|
class: "px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-lg focus:outline-blue-600",
|
1799
1799
|
disabled: C.disabled
|
1800
|
-
}, null, 8,
|
1801
|
-
[te, e(
|
1800
|
+
}, null, 8, jl), [
|
1801
|
+
[te, e(h)[0]]
|
1802
1802
|
]),
|
1803
|
-
|
1803
|
+
I(o("input", {
|
1804
1804
|
type: "date",
|
1805
|
-
min: e(
|
1805
|
+
min: e(h)[0],
|
1806
1806
|
locale: "uk-UA",
|
1807
|
-
"onUpdate:modelValue":
|
1807
|
+
"onUpdate:modelValue": c[10] || (c[10] = (s) => e(h)[1] = s),
|
1808
1808
|
class: "px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-lg focus:outline-blue-600 appearance-auto",
|
1809
1809
|
disabled: C.disabled
|
1810
|
-
}, null, 8,
|
1811
|
-
[te, e(
|
1810
|
+
}, null, 8, Fl), [
|
1811
|
+
[te, e(h)[1]]
|
1812
1812
|
])
|
1813
1813
|
])) : S("", !0)
|
1814
1814
|
]),
|
1815
1815
|
(C.cleanable, S("", !0))
|
1816
1816
|
], 64));
|
1817
1817
|
}
|
1818
|
-
}),
|
1819
|
-
radio:
|
1820
|
-
checkbox:
|
1821
|
-
check:
|
1822
|
-
text:
|
1823
|
-
range:
|
1824
|
-
date:
|
1825
|
-
select:
|
1826
|
-
tag:
|
1827
|
-
"date:inline":
|
1818
|
+
}), je = {
|
1819
|
+
radio: bt,
|
1820
|
+
checkbox: ze,
|
1821
|
+
check: ze,
|
1822
|
+
text: Rt,
|
1823
|
+
range: Pt,
|
1824
|
+
date: al,
|
1825
|
+
select: dl,
|
1826
|
+
tag: gl,
|
1827
|
+
"date:inline": Kl
|
1828
1828
|
};
|
1829
|
-
function Be(
|
1830
|
-
let
|
1831
|
-
switch (
|
1829
|
+
function Be(i, r) {
|
1830
|
+
let d;
|
1831
|
+
switch (i.toLowerCase()) {
|
1832
1832
|
case "autocomplete":
|
1833
|
-
|
1833
|
+
d = "select";
|
1834
1834
|
break;
|
1835
1835
|
case "check":
|
1836
|
-
|
1836
|
+
d = "checkbox";
|
1837
1837
|
break;
|
1838
1838
|
default:
|
1839
|
-
|
1839
|
+
d = i == null ? void 0 : i.toString().toLowerCase();
|
1840
1840
|
}
|
1841
|
-
return
|
1842
|
-
component:
|
1843
|
-
type:
|
1841
|
+
return d === "date" && r && r === "inline" && (d = "date:inline"), {
|
1842
|
+
component: je[d] || je.text,
|
1843
|
+
type: d
|
1844
1844
|
};
|
1845
1845
|
}
|
1846
|
-
const
|
1846
|
+
const Ll = {}, Ul = {
|
1847
1847
|
xmlns: "http://www.w3.org/2000/svg",
|
1848
1848
|
width: "15px",
|
1849
1849
|
height: "24",
|
@@ -1855,18 +1855,18 @@ const jl = {}, zl = {
|
|
1855
1855
|
"stroke-linejoin": "round",
|
1856
1856
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-reload absolute inline mr-1 text-gray-800 transition-all cursor-pointer active:rotate-90 right-1 top-1 hover:text-blue-500"
|
1857
1857
|
};
|
1858
|
-
function
|
1859
|
-
return
|
1860
|
-
|
1858
|
+
function Ol(i, r) {
|
1859
|
+
return p(), w("svg", Ul, r[0] || (r[0] = [
|
1860
|
+
o("path", {
|
1861
1861
|
stroke: "none",
|
1862
1862
|
d: "M0 0h24v24H0z",
|
1863
1863
|
fill: "none"
|
1864
1864
|
}, null, -1),
|
1865
|
-
|
1866
|
-
|
1865
|
+
o("path", { d: "M19.933 13.041a8 8 0 1 1 -9.925 -8.788c3.899 -1 7.935 1.007 9.425 4.747" }, null, -1),
|
1866
|
+
o("path", { d: "M20 4v5h-5" }, null, -1)
|
1867
1867
|
]));
|
1868
1868
|
}
|
1869
|
-
const
|
1869
|
+
const Pl = /* @__PURE__ */ le(Ll, [["render", Ol]]), Il = { style: { display: "inline-flex", margin: "0px", width: "100%" } }, Tl = { class: "relative w-full mb-2 p-4 bg-white rounded-lg shadow-sm" }, Hl = { class: "block mb-3 text-sm font-medium text-gray-800 dark:text-neutral-200" }, El = { class: "flex items-center" }, Yl = { class: "text-sm font-medium max-w-[80%] text-gray-800 flex items-center gap-x-1" }, Wl = { class: "filter-layout__body" }, ql = /* @__PURE__ */ Y({
|
1870
1870
|
__name: "vertical-layout",
|
1871
1871
|
props: {
|
1872
1872
|
id: {},
|
@@ -1892,73 +1892,73 @@ const Kl = /* @__PURE__ */ le(jl, [["render", Fl]]), Ul = { style: { display: "i
|
|
1892
1892
|
sort: {}
|
1893
1893
|
},
|
1894
1894
|
emits: ["update:modelValue", "change", "clear"],
|
1895
|
-
setup(
|
1896
|
-
const l =
|
1895
|
+
setup(i, { expose: r, emit: d }) {
|
1896
|
+
const l = i, a = d, n = V(), m = Be(l.type, l.layout), h = E({
|
1897
1897
|
get: () => l.modelValue,
|
1898
|
-
set: (
|
1898
|
+
set: (f) => a("update:modelValue", f)
|
1899
1899
|
});
|
1900
|
-
function
|
1901
|
-
|
1900
|
+
function g(f) {
|
1901
|
+
a("clear", f);
|
1902
1902
|
}
|
1903
|
-
function k(
|
1904
|
-
|
1903
|
+
function k(f, y) {
|
1904
|
+
a("change", { name: f, value: y }), l.modelValue !== void 0 && a("update:modelValue", y);
|
1905
1905
|
}
|
1906
|
-
function
|
1907
|
-
n.value && n.value.clear(),
|
1906
|
+
function b() {
|
1907
|
+
n.value && n.value.clear(), a("clear", l.name);
|
1908
1908
|
}
|
1909
|
-
return
|
1909
|
+
return A(
|
1910
1910
|
() => l.default,
|
1911
|
-
(
|
1912
|
-
|
1911
|
+
(f) => {
|
1912
|
+
h.value = f;
|
1913
1913
|
}
|
1914
|
-
),
|
1914
|
+
), A(
|
1915
1915
|
() => l.modelValue,
|
1916
|
-
(
|
1917
|
-
|
1916
|
+
(f) => {
|
1917
|
+
h.value = f;
|
1918
1918
|
}
|
1919
1919
|
), r({
|
1920
1920
|
filterRef: n
|
1921
|
-
}), (
|
1922
|
-
var C,
|
1923
|
-
return
|
1924
|
-
|
1925
|
-
|
1926
|
-
|
1927
|
-
|
1921
|
+
}), (f, y) => {
|
1922
|
+
var C, c, s;
|
1923
|
+
return p(), w("div", Il, [
|
1924
|
+
o("div", Tl, [
|
1925
|
+
o("div", Hl, [
|
1926
|
+
o("div", El, [
|
1927
|
+
o("span", Yl, K(f.label), 1)
|
1928
1928
|
]),
|
1929
|
-
typeof
|
1929
|
+
typeof h.value == "string" && h.value.trim() !== "" || Array.isArray(h.value) && h.value.length > 0 && h.value.some((t) => t !== void 0) || h.value === null ? (p(), z(Pl, {
|
1930
1930
|
key: 0,
|
1931
|
-
onClick:
|
1931
|
+
onClick: b
|
1932
1932
|
})) : S("", !0)
|
1933
1933
|
]),
|
1934
|
-
|
1935
|
-
((C = e(
|
1936
|
-
type: (
|
1937
|
-
onChange:
|
1938
|
-
onClear:
|
1934
|
+
o("div", Wl, [
|
1935
|
+
((C = e(m)) == null ? void 0 : C.type) !== "select" ? (p(), z(oe((c = e(m)) == null ? void 0 : c.component), Z({ key: 0 }, l, {
|
1936
|
+
type: (s = e(m)) == null ? void 0 : s.type,
|
1937
|
+
onChange: y[0] || (y[0] = (t) => k(t.name, t.value)),
|
1938
|
+
onClear: y[1] || (y[1] = (t) => g(t)),
|
1939
1939
|
ref_key: "filterRef",
|
1940
1940
|
ref: n
|
1941
|
-
}), null, 16, ["type"])) : (
|
1941
|
+
}), null, 16, ["type"])) : (p(), z(Me, {
|
1942
1942
|
key: 1,
|
1943
|
-
"current-value":
|
1944
|
-
label:
|
1945
|
-
mode:
|
1946
|
-
onClear:
|
1943
|
+
"current-value": h.value,
|
1944
|
+
label: f.label,
|
1945
|
+
mode: f.mode,
|
1946
|
+
onClear: b,
|
1947
1947
|
fieldRef: n.value,
|
1948
1948
|
width: void 0,
|
1949
|
-
disabled:
|
1949
|
+
disabled: f.disabled,
|
1950
1950
|
layout: "vertical"
|
1951
1951
|
}, {
|
1952
1952
|
default: re(() => {
|
1953
|
-
var t,
|
1953
|
+
var t, x;
|
1954
1954
|
return [
|
1955
|
-
(
|
1955
|
+
(p(), z(oe((t = e(m)) == null ? void 0 : t.component), Z({
|
1956
1956
|
ref_key: "filterRef",
|
1957
1957
|
ref: n
|
1958
1958
|
}, l, {
|
1959
|
-
type: (
|
1960
|
-
onChange:
|
1961
|
-
onClear:
|
1959
|
+
type: (x = e(m)) == null ? void 0 : x.type,
|
1960
|
+
onChange: y[2] || (y[2] = (v) => k(v.name, v.value)),
|
1961
|
+
onClear: y[3] || (y[3] = (v) => g(v))
|
1962
1962
|
}), null, 16, ["type"]))
|
1963
1963
|
];
|
1964
1964
|
}),
|
@@ -1969,7 +1969,7 @@ const Kl = /* @__PURE__ */ le(jl, [["render", Fl]]), Ul = { style: { display: "i
|
|
1969
1969
|
]);
|
1970
1970
|
};
|
1971
1971
|
}
|
1972
|
-
}),
|
1972
|
+
}), Fe = /* @__PURE__ */ Y({
|
1973
1973
|
__name: "inline-layout",
|
1974
1974
|
props: {
|
1975
1975
|
id: {},
|
@@ -1995,61 +1995,61 @@ const Kl = /* @__PURE__ */ le(jl, [["render", Fl]]), Ul = { style: { display: "i
|
|
1995
1995
|
sort: {}
|
1996
1996
|
},
|
1997
1997
|
emits: ["update:modelValue", "change", "clear"],
|
1998
|
-
setup(
|
1999
|
-
const l =
|
1998
|
+
setup(i, { expose: r, emit: d }) {
|
1999
|
+
const l = i, a = d, n = V(), m = Be(l.type, l.layout), h = E({
|
2000
2000
|
get: () => l.modelValue,
|
2001
|
-
set: (
|
2001
|
+
set: (b) => a("update:modelValue", b)
|
2002
2002
|
});
|
2003
|
-
function
|
2004
|
-
|
2003
|
+
function g(b = l.name) {
|
2004
|
+
a("clear", b);
|
2005
2005
|
}
|
2006
|
-
function k(
|
2007
|
-
|
2006
|
+
function k(b, f) {
|
2007
|
+
a("change", { name: b, value: f }), l.modelValue !== void 0 && a("update:modelValue", f);
|
2008
2008
|
}
|
2009
|
-
return
|
2009
|
+
return A(
|
2010
2010
|
() => l.default,
|
2011
|
-
(
|
2012
|
-
|
2011
|
+
(b) => {
|
2012
|
+
h.value = b;
|
2013
2013
|
}
|
2014
|
-
),
|
2014
|
+
), A(
|
2015
2015
|
() => l.modelValue,
|
2016
|
-
(
|
2017
|
-
|
2016
|
+
(b) => {
|
2017
|
+
h.value = b;
|
2018
2018
|
}
|
2019
2019
|
), r({
|
2020
2020
|
filterRef: n
|
2021
|
-
}), (
|
2022
|
-
var
|
2023
|
-
return ["text", "date"].includes(
|
2024
|
-
type: (C = e(
|
2025
|
-
onChange:
|
2026
|
-
onClear:
|
2027
|
-
disabled:
|
2028
|
-
modelValue:
|
2029
|
-
"onUpdate:modelValue":
|
2030
|
-
}), null, 16, ["type", "disabled", "modelValue"])) : (
|
2021
|
+
}), (b, f) => {
|
2022
|
+
var y, C;
|
2023
|
+
return ["text", "date"].includes(b.type.toLocaleLowerCase()) ? (p(), z(oe((y = e(m)) == null ? void 0 : y.component), Z({ key: 0 }, l, {
|
2024
|
+
type: (C = e(m)) == null ? void 0 : C.type,
|
2025
|
+
onChange: f[0] || (f[0] = (c) => k(c.name, c.value)),
|
2026
|
+
onClear: f[1] || (f[1] = (c) => g(c)),
|
2027
|
+
disabled: b.disabled,
|
2028
|
+
modelValue: h.value,
|
2029
|
+
"onUpdate:modelValue": f[2] || (f[2] = (c) => h.value = c)
|
2030
|
+
}), null, 16, ["type", "disabled", "modelValue"])) : (p(), z(Me, {
|
2031
2031
|
key: 1,
|
2032
|
-
"current-value":
|
2033
|
-
label:
|
2034
|
-
mode:
|
2035
|
-
onClear:
|
2032
|
+
"current-value": h.value,
|
2033
|
+
label: b.label,
|
2034
|
+
mode: b.mode,
|
2035
|
+
onClear: g,
|
2036
2036
|
fieldRef: n.value,
|
2037
2037
|
width: l.width,
|
2038
|
-
disabled:
|
2038
|
+
disabled: b.disabled,
|
2039
2039
|
layout: "inline"
|
2040
2040
|
}, {
|
2041
2041
|
default: re(() => {
|
2042
|
-
var
|
2042
|
+
var c, s;
|
2043
2043
|
return [
|
2044
|
-
(
|
2044
|
+
(p(), z(oe((c = e(m)) == null ? void 0 : c.component), Z({
|
2045
2045
|
ref_key: "filterRef",
|
2046
2046
|
ref: n
|
2047
2047
|
}, l, {
|
2048
|
-
modelValue:
|
2049
|
-
"onUpdate:modelValue":
|
2050
|
-
type: (
|
2051
|
-
onChange:
|
2052
|
-
onClear:
|
2048
|
+
modelValue: h.value,
|
2049
|
+
"onUpdate:modelValue": f[3] || (f[3] = (t) => h.value = t),
|
2050
|
+
type: (s = e(m)) == null ? void 0 : s.type,
|
2051
|
+
onChange: f[4] || (f[4] = (t) => k(t.name, t.value)),
|
2052
|
+
onClear: f[5] || (f[5] = (t) => g(t))
|
2053
2053
|
}), null, 16, ["modelValue", "type"]))
|
2054
2054
|
];
|
2055
2055
|
}),
|
@@ -2057,7 +2057,7 @@ const Kl = /* @__PURE__ */ le(jl, [["render", Fl]]), Ul = { style: { display: "i
|
|
2057
2057
|
}, 8, ["current-value", "label", "mode", "fieldRef", "width", "disabled"]));
|
2058
2058
|
};
|
2059
2059
|
}
|
2060
|
-
}),
|
2060
|
+
}), Nl = /* @__PURE__ */ Y({
|
2061
2061
|
__name: "popover-layout",
|
2062
2062
|
props: {
|
2063
2063
|
id: {},
|
@@ -2083,48 +2083,48 @@ const Kl = /* @__PURE__ */ le(jl, [["render", Fl]]), Ul = { style: { display: "i
|
|
2083
2083
|
sort: {}
|
2084
2084
|
},
|
2085
2085
|
emits: ["update:modelValue", "change", "clear"],
|
2086
|
-
setup(
|
2087
|
-
const l =
|
2086
|
+
setup(i, { expose: r, emit: d }) {
|
2087
|
+
const l = i, a = d, n = V(), m = V(Be(l.type, l.layout)), h = E({
|
2088
2088
|
get: () => l.modelValue,
|
2089
|
-
set: (
|
2089
|
+
set: (b) => a("update:modelValue", b)
|
2090
2090
|
});
|
2091
|
-
function
|
2092
|
-
|
2091
|
+
function g(b) {
|
2092
|
+
a("clear", b);
|
2093
2093
|
}
|
2094
|
-
function k(
|
2095
|
-
|
2094
|
+
function k(b, f) {
|
2095
|
+
a("change", { name: b, value: f }), l.modelValue !== void 0 && a("update:modelValue", f);
|
2096
2096
|
}
|
2097
|
-
return
|
2097
|
+
return A(
|
2098
2098
|
() => l.default,
|
2099
|
-
(
|
2100
|
-
|
2099
|
+
(b) => {
|
2100
|
+
h.value = b;
|
2101
2101
|
}
|
2102
|
-
),
|
2102
|
+
), A(
|
2103
2103
|
() => l.modelValue,
|
2104
|
-
(
|
2105
|
-
|
2104
|
+
(b) => {
|
2105
|
+
h.value = b;
|
2106
2106
|
}
|
2107
|
-
),
|
2107
|
+
), A(
|
2108
2108
|
() => l,
|
2109
|
-
(
|
2110
|
-
|
2109
|
+
(b) => {
|
2110
|
+
h.value = b;
|
2111
2111
|
}
|
2112
2112
|
), r({
|
2113
2113
|
filterRef: n
|
2114
|
-
}), (
|
2115
|
-
var
|
2116
|
-
return
|
2117
|
-
type: (C =
|
2118
|
-
modelValue:
|
2119
|
-
"onUpdate:modelValue":
|
2120
|
-
onChange:
|
2121
|
-
onClear:
|
2114
|
+
}), (b, f) => {
|
2115
|
+
var y, C;
|
2116
|
+
return p(), z(oe((y = m.value) == null ? void 0 : y.component), Z(l, {
|
2117
|
+
type: (C = m.value) == null ? void 0 : C.type,
|
2118
|
+
modelValue: h.value,
|
2119
|
+
"onUpdate:modelValue": f[0] || (f[0] = (c) => h.value = c),
|
2120
|
+
onChange: f[1] || (f[1] = (c) => k(c.name, c.value)),
|
2121
|
+
onClear: f[2] || (f[2] = (c) => g(c)),
|
2122
2122
|
ref_key: "filterRef",
|
2123
2123
|
ref: n
|
2124
2124
|
}), null, 16, ["type", "modelValue"]);
|
2125
2125
|
};
|
2126
2126
|
}
|
2127
|
-
}), ne = /* @__PURE__ */
|
2127
|
+
}), ne = /* @__PURE__ */ Y({
|
2128
2128
|
__name: "filter-field",
|
2129
2129
|
props: {
|
2130
2130
|
id: {},
|
@@ -2150,26 +2150,26 @@ const Kl = /* @__PURE__ */ le(jl, [["render", Fl]]), Ul = { style: { display: "i
|
|
2150
2150
|
sort: { default: "name" }
|
2151
2151
|
},
|
2152
2152
|
emits: ["update:modelValue", "change", "clear"],
|
2153
|
-
setup(
|
2154
|
-
const l =
|
2153
|
+
setup(i, { expose: r, emit: d }) {
|
2154
|
+
const l = i, a = d, n = V(), m = E({
|
2155
2155
|
get: () => l.modelValue,
|
2156
|
-
set: (
|
2156
|
+
set: (b) => a("update:modelValue", b)
|
2157
2157
|
});
|
2158
|
-
function
|
2159
|
-
|
2158
|
+
function h(b) {
|
2159
|
+
a("clear", b);
|
2160
2160
|
}
|
2161
|
-
function
|
2162
|
-
|
2161
|
+
function g(b, f) {
|
2162
|
+
a("change", { name: b, value: f }), l.modelValue !== void 0 && a("update:modelValue", f);
|
2163
2163
|
}
|
2164
|
-
|
2164
|
+
A(
|
2165
2165
|
() => l.default,
|
2166
|
-
(
|
2167
|
-
|
2166
|
+
(b) => {
|
2167
|
+
m.value = b;
|
2168
2168
|
}
|
2169
|
-
),
|
2169
|
+
), A(
|
2170
2170
|
() => l.modelValue,
|
2171
|
-
(
|
2172
|
-
|
2171
|
+
(b) => {
|
2172
|
+
m.value = b;
|
2173
2173
|
}
|
2174
2174
|
), r({
|
2175
2175
|
filterRef: n
|
@@ -2177,181 +2177,181 @@ const Kl = /* @__PURE__ */ le(jl, [["render", Fl]]), Ul = { style: { display: "i
|
|
2177
2177
|
function k() {
|
2178
2178
|
switch (l.layout) {
|
2179
2179
|
case "inline":
|
2180
|
-
return
|
2180
|
+
return Fe;
|
2181
2181
|
case "vertical":
|
2182
|
-
return
|
2182
|
+
return ql;
|
2183
2183
|
case "popover":
|
2184
|
-
return
|
2184
|
+
return Nl;
|
2185
2185
|
default:
|
2186
|
-
return
|
2186
|
+
return Fe;
|
2187
2187
|
}
|
2188
2188
|
}
|
2189
|
-
return (
|
2190
|
-
onChange:
|
2191
|
-
onClear:
|
2192
|
-
modelValue:
|
2193
|
-
"onUpdate:modelValue":
|
2189
|
+
return (b, f) => (p(), z(oe(k()), Z(l, {
|
2190
|
+
onChange: f[0] || (f[0] = (y) => g(y.name, y.value)),
|
2191
|
+
onClear: f[1] || (f[1] = (y) => h(y)),
|
2192
|
+
modelValue: m.value,
|
2193
|
+
"onUpdate:modelValue": f[2] || (f[2] = (y) => m.value = y)
|
2194
2194
|
}), null, 16, ["modelValue"]));
|
2195
2195
|
}
|
2196
2196
|
});
|
2197
|
-
function
|
2197
|
+
function $e(i, r) {
|
2198
2198
|
const {
|
2199
|
-
slots:
|
2200
|
-
} =
|
2201
|
-
var
|
2202
|
-
return (fe((
|
2199
|
+
slots: d
|
2200
|
+
} = i, l = V(i.value ?? {}), a = E(() => {
|
2201
|
+
var v;
|
2202
|
+
return (fe((v = d == null ? void 0 : d.default) == null ? void 0 : v.call(d)) ?? []).flatMap((u) => Array.isArray(u.children) ? u.children : [u]);
|
2203
2203
|
});
|
2204
|
-
function n(
|
2205
|
-
delete l.value[
|
2204
|
+
function n(v) {
|
2205
|
+
delete l.value[v], r("clear", {
|
2206
2206
|
data: fe(l.value),
|
2207
|
-
name:
|
2207
|
+
name: v
|
2208
2208
|
});
|
2209
2209
|
}
|
2210
|
-
function
|
2211
|
-
|
2210
|
+
function m(v, u) {
|
2211
|
+
u === void 0 ? n(v) : l.value = {
|
2212
2212
|
...l.value,
|
2213
|
-
[
|
2213
|
+
[v]: u
|
2214
2214
|
}, r("change", {
|
2215
2215
|
data: fe(l.value),
|
2216
|
-
name:
|
2217
|
-
value:
|
2216
|
+
name: v,
|
2217
|
+
value: u
|
2218
2218
|
});
|
2219
2219
|
}
|
2220
|
-
const
|
2220
|
+
const h = E(() => a.value.map((v) => {
|
2221
2221
|
var _;
|
2222
|
-
const
|
2223
|
-
return
|
2224
|
-
...
|
2225
|
-
layout:
|
2222
|
+
const u = (_ = v.props) == null ? void 0 : _.name;
|
2223
|
+
return Ge(v, {
|
2224
|
+
...v.props,
|
2225
|
+
layout: i.view,
|
2226
2226
|
showClean: !0,
|
2227
|
-
modelValue: l[
|
2228
|
-
"onUpdate:modelValue": (
|
2229
|
-
|
2227
|
+
modelValue: l[u],
|
2228
|
+
"onUpdate:modelValue": (B) => {
|
2229
|
+
m(u, B);
|
2230
2230
|
},
|
2231
|
-
onClear: () => n(
|
2231
|
+
onClear: () => n(u)
|
2232
2232
|
});
|
2233
|
-
})),
|
2233
|
+
})), g = E(
|
2234
2234
|
() => new Map(
|
2235
|
-
|
2235
|
+
h.value.map((v) => {
|
2236
2236
|
var _;
|
2237
|
-
const
|
2238
|
-
return
|
2239
|
-
}).filter((
|
2237
|
+
const u = (_ = v.props) == null ? void 0 : _.name;
|
2238
|
+
return u ? [u, v] : null;
|
2239
|
+
}).filter((v) => v !== null)
|
2240
2240
|
)
|
2241
2241
|
);
|
2242
|
-
function k(
|
2243
|
-
l.value = {},
|
2242
|
+
function k(v = !1) {
|
2243
|
+
l.value = {}, v || r("clearAll", {
|
2244
2244
|
data: fe(l.value),
|
2245
2245
|
name: "ALL"
|
2246
2246
|
});
|
2247
2247
|
}
|
2248
|
-
const
|
2249
|
-
var
|
2250
|
-
return (
|
2251
|
-
}),
|
2252
|
-
|
2253
|
-
var
|
2254
|
-
await ke(), (
|
2248
|
+
const b = V(""), f = E(() => {
|
2249
|
+
var v;
|
2250
|
+
return (v = i.schema) != null && v.value ? Object.entries(l.value).filter(([u, _]) => i.schema && !(u in i.schema.value) ? !1 : Array.isArray(_) ? _.some((B) => B !== "" && B !== void 0) : _ !== "" && _ !== void 0).length : 0;
|
2251
|
+
}), y = V();
|
2252
|
+
A(b, async () => {
|
2253
|
+
var v, u;
|
2254
|
+
await ke(), (u = (v = y == null ? void 0 : y.value) == null ? void 0 : v.filterRef) != null && u.inputTextRef && y.value.filterRef.inputTextRef.focus();
|
2255
2255
|
});
|
2256
2256
|
const C = E(() => {
|
2257
|
-
var
|
2258
|
-
return (
|
2259
|
-
}),
|
2260
|
-
var
|
2261
|
-
return (
|
2262
|
-
}),
|
2263
|
-
var
|
2264
|
-
if (
|
2265
|
-
let
|
2266
|
-
if ((
|
2267
|
-
const _ = Object.entries(
|
2268
|
-
_ <
|
2257
|
+
var v, u;
|
2258
|
+
return (v = i.schema) != null && v.value ? Object.fromEntries(Object.entries((u = i.schema) == null ? void 0 : u.value).slice(0, i.limit)) : {};
|
2259
|
+
}), c = E(() => {
|
2260
|
+
var v, u, _;
|
2261
|
+
return (v = i.schema) != null && v.value ? i.view !== "inline" ? (u = i.schema) == null ? void 0 : u.value : Object.fromEntries(Object.entries((_ = i.schema) == null ? void 0 : _.value).slice(i.limit)) : {};
|
2262
|
+
}), s = E(() => {
|
2263
|
+
var u;
|
2264
|
+
if (h.value.length === 0) return [];
|
2265
|
+
let v = 0;
|
2266
|
+
if ((u = i.schema) != null && u.value) {
|
2267
|
+
const _ = Object.entries(i.schema.value).length;
|
2268
|
+
_ < i.limit ? v = i.limit - _ : v = 0;
|
2269
2269
|
}
|
2270
|
-
return
|
2271
|
-
}), t = E(() =>
|
2272
|
-
function
|
2273
|
-
if (
|
2274
|
-
const [
|
2275
|
-
|
2276
|
-
} else t.value.length > 0 ?
|
2270
|
+
return h.value.slice(0, v);
|
2271
|
+
}), t = E(() => h.value.length === 0 ? [] : i.view !== "inline" ? h.value : h.value.slice(s.value.length));
|
2272
|
+
function x() {
|
2273
|
+
if (c.value) {
|
2274
|
+
const [v] = Object.keys(c.value);
|
2275
|
+
b.value = v;
|
2276
|
+
} else t.value.length > 0 ? b.value = t.value[0].props.name : b.value = "";
|
2277
2277
|
}
|
2278
2278
|
return {
|
2279
2279
|
activeFilter: l,
|
2280
|
-
activeFilterCount:
|
2281
|
-
onFilterChange:
|
2280
|
+
activeFilterCount: f,
|
2281
|
+
onFilterChange: m,
|
2282
2282
|
clearFilter: n,
|
2283
2283
|
clearAllFilters: k,
|
2284
2284
|
limitedSchema: C,
|
2285
|
-
popoverSchema:
|
2286
|
-
filtersSlot:
|
2287
|
-
limitedFiltersSlot:
|
2285
|
+
popoverSchema: c,
|
2286
|
+
filtersSlot: h,
|
2287
|
+
limitedFiltersSlot: s,
|
2288
2288
|
popoverFiltersSlot: t,
|
2289
|
-
vnodeMap:
|
2290
|
-
onPopoverOpen:
|
2291
|
-
selectedFilter:
|
2292
|
-
filterRef:
|
2289
|
+
vnodeMap: g,
|
2290
|
+
onPopoverOpen: x,
|
2291
|
+
selectedFilter: b,
|
2292
|
+
filterRef: y
|
2293
2293
|
};
|
2294
2294
|
}
|
2295
|
-
const
|
2295
|
+
const Gl = /* @__PURE__ */ Y({
|
2296
2296
|
__name: "popover",
|
2297
2297
|
emits: ["open", "close"],
|
2298
|
-
setup(
|
2299
|
-
const
|
2300
|
-
function
|
2301
|
-
|
2298
|
+
setup(i, { emit: r }) {
|
2299
|
+
const d = V(!1), l = V(null), a = V(null), n = V(null), m = V({ top: "0px", left: "0px", position: "absolute" });
|
2300
|
+
function h() {
|
2301
|
+
d.value = !d.value;
|
2302
2302
|
}
|
2303
|
-
function
|
2304
|
-
const
|
2305
|
-
if (!
|
2306
|
-
const
|
2307
|
-
let
|
2308
|
-
|
2303
|
+
function g() {
|
2304
|
+
const y = n.value, C = l.value;
|
2305
|
+
if (!y || !C) return;
|
2306
|
+
const c = y.getBoundingClientRect(), s = C.offsetWidth, t = window.innerWidth - c.left;
|
2307
|
+
let x = c.left + window.scrollX;
|
2308
|
+
s > t && (x = window.innerWidth - s - 8, x < 8 && (x = 8)), m.value = {
|
2309
2309
|
position: "absolute",
|
2310
|
-
top: `${
|
2311
|
-
left: `${
|
2310
|
+
top: `${c.bottom + window.scrollY + 8}px`,
|
2311
|
+
left: `${x}px`
|
2312
2312
|
};
|
2313
2313
|
}
|
2314
|
-
function k(
|
2315
|
-
var
|
2316
|
-
const C =
|
2317
|
-
!((
|
2314
|
+
function k(y) {
|
2315
|
+
var c, s;
|
2316
|
+
const C = y.target;
|
2317
|
+
!((c = n.value) != null && c.contains(y.target)) && !((s = l.value) != null && s.contains(y.target)) && !C.closest("[data-inside-popover]") && (d.value = !1);
|
2318
2318
|
}
|
2319
|
-
const
|
2319
|
+
const b = V(!1);
|
2320
2320
|
ue(() => {
|
2321
|
-
|
2321
|
+
b.value = !0;
|
2322
2322
|
}), ue(() => {
|
2323
|
-
var
|
2324
|
-
n.value = ((
|
2323
|
+
var y, C;
|
2324
|
+
n.value = ((y = a.value) == null ? void 0 : y.querySelector("[data-popover-trigger]")) || null, (C = n.value) == null || C.addEventListener("click", h), document.addEventListener("click", k), window.addEventListener("resize", g), window.addEventListener("scroll", g, !0);
|
2325
2325
|
}), he(() => {
|
2326
|
-
var
|
2327
|
-
(
|
2326
|
+
var y;
|
2327
|
+
(y = n.value) == null || y.removeEventListener("click", h), document.removeEventListener("click", k), window.removeEventListener("resize", g), window.removeEventListener("scroll", g, !0);
|
2328
2328
|
});
|
2329
|
-
const
|
2330
|
-
return
|
2331
|
-
|
2332
|
-
}), (
|
2329
|
+
const f = r;
|
2330
|
+
return A(d, async (y) => {
|
2331
|
+
y ? (f("open"), await ke(), g()) : f("close");
|
2332
|
+
}), (y, C) => (p(), w("div", {
|
2333
2333
|
ref_key: "wrapperRef",
|
2334
|
-
ref:
|
2334
|
+
ref: a
|
2335
2335
|
}, [
|
2336
|
-
ee(
|
2337
|
-
|
2336
|
+
ee(y.$slots, "trigger"),
|
2337
|
+
b.value ? (p(), z(Ue, {
|
2338
2338
|
key: 0,
|
2339
2339
|
to: "body"
|
2340
2340
|
}, [
|
2341
|
-
|
2341
|
+
I(o("div", {
|
2342
2342
|
ref_key: "popoverRef",
|
2343
2343
|
ref: l,
|
2344
2344
|
class: "absolute z-[50] w-[600px] rounded-md border bg-white shadow-md",
|
2345
|
-
style: _e(
|
2345
|
+
style: _e(m.value)
|
2346
2346
|
}, [
|
2347
|
-
ee(
|
2347
|
+
ee(y.$slots, "default")
|
2348
2348
|
], 4), [
|
2349
|
-
[X,
|
2349
|
+
[X, d.value]
|
2350
2350
|
])
|
2351
2351
|
])) : S("", !0)
|
2352
2352
|
], 512));
|
2353
2353
|
}
|
2354
|
-
}),
|
2354
|
+
}), Ql = {}, Zl = {
|
2355
2355
|
xmlns: "http://www.w3.org/2000/svg",
|
2356
2356
|
width: "24",
|
2357
2357
|
height: "24",
|
@@ -2363,27 +2363,27 @@ const Wl = /* @__PURE__ */ W({
|
|
2363
2363
|
"stroke-linejoin": "round",
|
2364
2364
|
class: "lucide lucide-filter h-4 w-4"
|
2365
2365
|
};
|
2366
|
-
function
|
2367
|
-
return
|
2368
|
-
|
2366
|
+
function Jl(i, r) {
|
2367
|
+
return p(), w("svg", Zl, r[0] || (r[0] = [
|
2368
|
+
o("polygon", { points: "22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3" }, null, -1)
|
2369
2369
|
]));
|
2370
2370
|
}
|
2371
|
-
const
|
2371
|
+
const Xl = /* @__PURE__ */ le(Ql, [["render", Jl]]), ea = {
|
2372
2372
|
key: 0,
|
2373
2373
|
class: "inline-flex rounded-sm items-center border font-semibold border-transparent hover:bg-secondary/80 bg-blue-500 text-white text-xs px-1.5"
|
2374
|
-
},
|
2374
|
+
}, ta = { class: "flex" }, la = { class: "w-64 border-r border-gray-200" }, aa = { class: "p-2" }, oa = ["onClick"], ra = { class: "flex items-center gap-2" }, na = { class: "text-sm font-medium" }, ia = {
|
2375
2375
|
key: 0,
|
2376
2376
|
class: "inline-flex items-center rounded-full border font-semibold transition-colors focus:outline-hidden focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent hover:bg-secondary/80 bg-blue-100 text-blue-700 text-xs p-2"
|
2377
|
-
},
|
2377
|
+
}, sa = ["onClick"], ua = { class: "flex items-center gap-2" }, da = { class: "text-sm font-medium" }, ca = {
|
2378
2378
|
key: 0,
|
2379
2379
|
class: "inline-flex items-center rounded-full border font-semibold transition-colors focus:outline-hidden focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent hover:bg-secondary/80 bg-blue-100 text-blue-700 text-xs p-2"
|
2380
|
-
},
|
2380
|
+
}, pa = {
|
2381
2381
|
key: 0,
|
2382
2382
|
class: "p-2 border-t"
|
2383
|
-
},
|
2383
|
+
}, fa = { class: "flex-1 min-h-[300px] overflow-y-auto" }, va = {
|
2384
2384
|
key: 0,
|
2385
2385
|
class: "flex items-center justify-center h-full text-gray-500"
|
2386
|
-
},
|
2386
|
+
}, Ne = /* @__PURE__ */ Y({
|
2387
2387
|
__name: "popover-filter-layout",
|
2388
2388
|
props: {
|
2389
2389
|
schema: {},
|
@@ -2394,140 +2394,140 @@ const Gl = /* @__PURE__ */ le(Yl, [["render", Nl]]), Ql = {
|
|
2394
2394
|
limit: { default: 3 }
|
2395
2395
|
},
|
2396
2396
|
emits: ["change", "clear", "clearAll"],
|
2397
|
-
setup(
|
2398
|
-
const l =
|
2399
|
-
activeFilter:
|
2397
|
+
setup(i, { expose: r, emit: d }) {
|
2398
|
+
const l = i, a = We(l.mode), n = we(), m = d, h = V({}), {
|
2399
|
+
activeFilter: g,
|
2400
2400
|
activeFilterCount: k,
|
2401
|
-
onFilterChange:
|
2402
|
-
clearFilter:
|
2403
|
-
clearAllFilters:
|
2401
|
+
onFilterChange: b,
|
2402
|
+
clearFilter: f,
|
2403
|
+
clearAllFilters: y,
|
2404
2404
|
popoverSchema: C,
|
2405
|
-
popoverFiltersSlot:
|
2406
|
-
onPopoverOpen:
|
2405
|
+
popoverFiltersSlot: c,
|
2406
|
+
onPopoverOpen: s,
|
2407
2407
|
selectedFilter: t,
|
2408
|
-
filterRef:
|
2409
|
-
} =
|
2408
|
+
filterRef: x
|
2409
|
+
} = $e({
|
2410
2410
|
...l,
|
2411
|
-
schema:
|
2411
|
+
schema: h,
|
2412
2412
|
slots: n
|
2413
|
-
},
|
2414
|
-
return
|
2413
|
+
}, m);
|
2414
|
+
return A(
|
2415
2415
|
() => l.schema,
|
2416
|
-
(
|
2417
|
-
|
2416
|
+
(v) => {
|
2417
|
+
h.value = v;
|
2418
2418
|
},
|
2419
2419
|
{ deep: !0, immediate: !0 }
|
2420
2420
|
), r({
|
2421
|
-
clearFilter:
|
2422
|
-
clearAllFilters:
|
2423
|
-
}), (
|
2424
|
-
onOpen: e(
|
2425
|
-
onClose:
|
2421
|
+
clearFilter: f,
|
2422
|
+
clearAllFilters: y
|
2423
|
+
}), (v, u) => (p(), z(Gl, {
|
2424
|
+
onOpen: e(s),
|
2425
|
+
onClose: u[5] || (u[5] = (_) => t.value = "")
|
2426
2426
|
}, {
|
2427
2427
|
trigger: re(() => [
|
2428
|
-
|
2428
|
+
o("button", {
|
2429
2429
|
"data-popover-trigger": "",
|
2430
2430
|
"aria-haspopup": "dialog",
|
2431
2431
|
"aria-expanded": "false",
|
2432
|
-
class:
|
2433
|
-
e(
|
2432
|
+
class: j(
|
2433
|
+
e(a) + (e(k) > 0 ? "bg-blue-50 border-blue-200 text-blue-700 hover:bg-blue-100" : "text-gray-800 hover:bg-gray-200 focus:bg-gray-200")
|
2434
2434
|
),
|
2435
2435
|
type: "button"
|
2436
2436
|
}, [
|
2437
|
-
P(
|
2438
|
-
|
2439
|
-
e(k) > 0 ? (
|
2437
|
+
P(Xl),
|
2438
|
+
u[6] || (u[6] = W(" Фільтр ", -1)),
|
2439
|
+
e(k) > 0 ? (p(), w("div", ea, K(e(k)), 1)) : S("", !0)
|
2440
2440
|
], 2)
|
2441
2441
|
]),
|
2442
2442
|
default: re(() => [
|
2443
|
-
|
2444
|
-
|
2445
|
-
|
2446
|
-
|
2443
|
+
o("div", ta, [
|
2444
|
+
o("div", la, [
|
2445
|
+
u[7] || (u[7] = o("div", { class: "p-4 border-b" }, [
|
2446
|
+
o("p", { class: "text-sm text-gray-600" }, "Select a field to start creating a filter.")
|
2447
2447
|
], -1)),
|
2448
|
-
|
2449
|
-
|
2450
|
-
var
|
2451
|
-
return
|
2448
|
+
o("div", aa, [
|
2449
|
+
v.schema ? (p(!0), w(F, { key: 0 }, q(Object.entries(e(C)), ([_, B]) => {
|
2450
|
+
var M;
|
2451
|
+
return p(), w("button", {
|
2452
2452
|
key: _,
|
2453
2453
|
onClick: () => {
|
2454
2454
|
t.value = _;
|
2455
2455
|
},
|
2456
|
-
class:
|
2456
|
+
class: j([
|
2457
2457
|
"w-full flex items-center justify-between px-3 py-2 text-left hover:bg-gray-50 transition-colors",
|
2458
2458
|
e(t) === _ ? "bg-blue-50 text-blue-700 border-l-2 border-blue-500" : ""
|
2459
2459
|
])
|
2460
2460
|
}, [
|
2461
|
-
|
2462
|
-
|
2461
|
+
o("div", ra, [
|
2462
|
+
o("span", na, K(B.label), 1)
|
2463
2463
|
]),
|
2464
|
-
(Array.isArray(e(
|
2465
|
-
], 10,
|
2464
|
+
(Array.isArray(e(g)[_]) ? ((M = e(g)[_]) == null ? void 0 : M.length) > 0 : e(g)[_] || e(g)[_] === null) ? (p(), w("div", ia)) : S("", !0)
|
2465
|
+
], 10, oa);
|
2466
2466
|
}), 128)) : S("", !0),
|
2467
|
-
(
|
2468
|
-
var
|
2469
|
-
return
|
2470
|
-
key: "slot-" +
|
2471
|
-
onClick: (
|
2472
|
-
class:
|
2467
|
+
(p(!0), w(F, null, q(e(c), (_, B) => {
|
2468
|
+
var M;
|
2469
|
+
return p(), w("button", {
|
2470
|
+
key: "slot-" + B,
|
2471
|
+
onClick: (L) => t.value = _.props.name,
|
2472
|
+
class: j([
|
2473
2473
|
"w-full flex items-center justify-between px-3 py-2 text-left hover:bg-gray-50 transition-colors",
|
2474
2474
|
e(t) === _.props.name ? "bg-blue-50 text-blue-700 border-l-2 border-blue-500" : ""
|
2475
2475
|
])
|
2476
2476
|
}, [
|
2477
|
-
|
2478
|
-
|
2477
|
+
o("div", ua, [
|
2478
|
+
o("span", da, K(_.props.label), 1)
|
2479
2479
|
]),
|
2480
|
-
((
|
2481
|
-
], 10,
|
2480
|
+
((M = e(g)[_.props.name]) == null ? void 0 : M.length) > 0 ? (p(), w("div", ca)) : S("", !0)
|
2481
|
+
], 10, sa);
|
2482
2482
|
}), 128))
|
2483
2483
|
]),
|
2484
|
-
e(k) > 0 ? (
|
2485
|
-
|
2484
|
+
e(k) > 0 ? (p(), w("div", pa, [
|
2485
|
+
o("button", {
|
2486
2486
|
class: "w-full px-3 py-2 text-left text-sm text-gray-600 hover:bg-gray-50 transition-colors",
|
2487
|
-
onClick:
|
2487
|
+
onClick: u[0] || (u[0] = (_) => e(y)()),
|
2488
2488
|
"data-inside-popover": ""
|
2489
2489
|
}, " Очистити всі ")
|
2490
2490
|
])) : S("", !0)
|
2491
2491
|
]),
|
2492
|
-
|
2493
|
-
e(t) === "" ? (
|
2494
|
-
|
2492
|
+
o("div", fa, [
|
2493
|
+
e(t) === "" ? (p(), w("div", va, u[8] || (u[8] = [
|
2494
|
+
o("p", { class: "text-sm" }, "Select a field to start creating a filter.", -1)
|
2495
2495
|
]))) : S("", !0),
|
2496
|
-
e(t) ? (
|
2497
|
-
e(C) ? (
|
2498
|
-
e(t) === _ ? (
|
2496
|
+
e(t) ? (p(), w(F, { key: 1 }, [
|
2497
|
+
e(C) ? (p(!0), w(F, { key: 0 }, q(Object.entries(e(C)), ([_, B]) => (p(), w(F, null, [
|
2498
|
+
e(t) === _ ? (p(), z(ne, Z({
|
2499
2499
|
name: _,
|
2500
2500
|
key: _,
|
2501
2501
|
layout: "popover",
|
2502
2502
|
ref_for: !0,
|
2503
2503
|
ref_key: "filterRef",
|
2504
|
-
ref:
|
2505
|
-
}, { ref_for: !0 },
|
2506
|
-
onChange:
|
2507
|
-
onClear:
|
2508
|
-
e(
|
2504
|
+
ref: x
|
2505
|
+
}, { ref_for: !0 }, B, {
|
2506
|
+
onChange: u[1] || (u[1] = (M) => e(b)(M.name, M.value)),
|
2507
|
+
onClear: u[2] || (u[2] = (M) => {
|
2508
|
+
e(f)(M), e(b)(M, void 0);
|
2509
2509
|
}),
|
2510
|
-
modelValue: e(
|
2511
|
-
"onUpdate:modelValue": (
|
2510
|
+
modelValue: e(g)[_],
|
2511
|
+
"onUpdate:modelValue": (M) => e(g)[_] = M,
|
2512
2512
|
cleanable: !0
|
2513
2513
|
}), null, 16, ["name", "modelValue", "onUpdate:modelValue"])) : S("", !0)
|
2514
2514
|
], 64))), 256)) : S("", !0),
|
2515
|
-
(
|
2516
|
-
key: "slot-" +
|
2515
|
+
(p(!0), w(F, null, q(e(c), (_, B) => (p(), w(F, {
|
2516
|
+
key: "slot-" + B
|
2517
2517
|
}, [
|
2518
|
-
e(t) === _.props.name ? (
|
2518
|
+
e(t) === _.props.name ? (p(), z(ne, Z({
|
2519
2519
|
key: 0,
|
2520
2520
|
layout: "popover"
|
2521
2521
|
}, { ref_for: !0 }, _.props, {
|
2522
2522
|
ref_for: !0,
|
2523
2523
|
ref_key: "filterRef",
|
2524
|
-
ref:
|
2525
|
-
onChange:
|
2526
|
-
onClear:
|
2527
|
-
e(
|
2524
|
+
ref: x,
|
2525
|
+
onChange: u[3] || (u[3] = (M) => e(b)(M.name, M.value)),
|
2526
|
+
onClear: u[4] || (u[4] = (M) => {
|
2527
|
+
e(f)(M), e(b)(M, void 0);
|
2528
2528
|
}),
|
2529
|
-
modelValue: e(
|
2530
|
-
"onUpdate:modelValue": (
|
2529
|
+
modelValue: e(g)[_.props.name],
|
2530
|
+
"onUpdate:modelValue": (M) => e(g)[_.props.name] = M,
|
2531
2531
|
cleanable: !0
|
2532
2532
|
}), null, 16, ["modelValue", "onUpdate:modelValue"])) : S("", !0)
|
2533
2533
|
], 64))), 128))
|
@@ -2538,7 +2538,7 @@ const Gl = /* @__PURE__ */ le(Yl, [["render", Nl]]), Ql = {
|
|
2538
2538
|
_: 1
|
2539
2539
|
}, 8, ["onOpen"]));
|
2540
2540
|
}
|
2541
|
-
}),
|
2541
|
+
}), ma = { class: "flex gap-1 items-center flex-wrap" }, Ke = /* @__PURE__ */ Y({
|
2542
2542
|
__name: "inline-filter-layout",
|
2543
2543
|
props: {
|
2544
2544
|
schema: {},
|
@@ -2549,93 +2549,93 @@ const Gl = /* @__PURE__ */ le(Yl, [["render", Nl]]), Ql = {
|
|
2549
2549
|
limit: { default: 3 }
|
2550
2550
|
},
|
2551
2551
|
emits: ["change", "clear", "clearAll"],
|
2552
|
-
setup(
|
2553
|
-
const l =
|
2554
|
-
activeFilter:
|
2555
|
-
activeFilterCount:
|
2552
|
+
setup(i, { expose: r, emit: d }) {
|
2553
|
+
const l = i, a = d, n = we(), m = V({}), {
|
2554
|
+
activeFilter: h,
|
2555
|
+
activeFilterCount: g,
|
2556
2556
|
onFilterChange: k,
|
2557
|
-
clearFilter:
|
2558
|
-
clearAllFilters:
|
2559
|
-
limitedSchema:
|
2557
|
+
clearFilter: b,
|
2558
|
+
clearAllFilters: f,
|
2559
|
+
limitedSchema: y,
|
2560
2560
|
popoverSchema: C,
|
2561
|
-
filtersSlot:
|
2562
|
-
limitedFiltersSlot:
|
2561
|
+
filtersSlot: c,
|
2562
|
+
limitedFiltersSlot: s,
|
2563
2563
|
popoverFiltersSlot: t
|
2564
|
-
} =
|
2564
|
+
} = $e(
|
2565
2565
|
{
|
2566
2566
|
...l,
|
2567
|
-
schema:
|
2567
|
+
schema: m,
|
2568
2568
|
slots: n
|
2569
2569
|
},
|
2570
|
-
|
2571
|
-
),
|
2572
|
-
function
|
2573
|
-
|
2570
|
+
a
|
2571
|
+
), x = V();
|
2572
|
+
function v() {
|
2573
|
+
x.value && x.value.clearAllFilters(!0), f();
|
2574
2574
|
}
|
2575
|
-
return
|
2575
|
+
return A(
|
2576
2576
|
() => l.schema,
|
2577
|
-
(
|
2578
|
-
|
2577
|
+
(u) => {
|
2578
|
+
m.value = u;
|
2579
2579
|
},
|
2580
2580
|
{ deep: !0, immediate: !0 }
|
2581
2581
|
), r({
|
2582
|
-
clearFilter:
|
2583
|
-
clearAllFilters:
|
2584
|
-
}), (
|
2585
|
-
|
2586
|
-
key:
|
2587
|
-
name:
|
2588
|
-
mode:
|
2589
|
-
}, { ref_for: !0 },
|
2590
|
-
onChange: _[0] || (_[0] = (
|
2591
|
-
onClear: e(
|
2582
|
+
clearFilter: b,
|
2583
|
+
clearAllFilters: f
|
2584
|
+
}), (u, _) => (p(), w("div", ma, [
|
2585
|
+
u.schema ? (p(!0), w(F, { key: 0 }, q(Object.entries(e(y)), ([B, M]) => (p(), z(ne, Z({
|
2586
|
+
key: B,
|
2587
|
+
name: B,
|
2588
|
+
mode: u.mode
|
2589
|
+
}, { ref_for: !0 }, M, {
|
2590
|
+
onChange: _[0] || (_[0] = (L) => e(k)(L.name, L.value)),
|
2591
|
+
onClear: e(b),
|
2592
2592
|
layout: "inline",
|
2593
2593
|
cleanable: !0,
|
2594
|
-
modelValue: e(
|
2595
|
-
"onUpdate:modelValue": (
|
2594
|
+
modelValue: e(h)[B],
|
2595
|
+
"onUpdate:modelValue": (L) => e(h)[B] = L
|
2596
2596
|
}), null, 16, ["name", "mode", "onClear", "modelValue", "onUpdate:modelValue"]))), 128)) : S("", !0),
|
2597
|
-
(
|
2598
|
-
key: "slot-" +
|
2597
|
+
(p(!0), w(F, null, q(e(s), (B, M) => (p(), z(ne, Z({
|
2598
|
+
key: "slot-" + M,
|
2599
2599
|
layout: "inline"
|
2600
|
-
}, { ref_for: !0 },
|
2601
|
-
onChange: _[1] || (_[1] = (
|
2602
|
-
onClear: _[2] || (_[2] = (
|
2603
|
-
e(
|
2600
|
+
}, { ref_for: !0 }, B.props, {
|
2601
|
+
onChange: _[1] || (_[1] = (L) => e(k)(L.name, L.value)),
|
2602
|
+
onClear: _[2] || (_[2] = (L) => {
|
2603
|
+
e(b)(L), e(k)(L, void 0);
|
2604
2604
|
}),
|
2605
2605
|
cleanable: !0,
|
2606
|
-
modelValue: e(
|
2607
|
-
"onUpdate:modelValue": (
|
2606
|
+
modelValue: e(h)[B.props.name],
|
2607
|
+
"onUpdate:modelValue": (L) => e(h)[B.props.name] = L
|
2608
2608
|
}), null, 16, ["modelValue", "onUpdate:modelValue"]))), 128)),
|
2609
|
-
Object.entries(e(C)).length > 0 || e(t).length > 0 ? (
|
2609
|
+
Object.entries(e(C)).length > 0 || e(t).length > 0 ? (p(), z(Ne, Z({ key: 1 }, l, {
|
2610
2610
|
schema: e(C),
|
2611
2611
|
limit: 0,
|
2612
|
-
onChange: _[3] || (_[3] = (
|
2613
|
-
onClearAll: _[4] || (_[4] = (
|
2614
|
-
onClear: _[5] || (_[5] = (
|
2615
|
-
mode:
|
2612
|
+
onChange: _[3] || (_[3] = (B) => e(k)(B.name, B.value)),
|
2613
|
+
onClearAll: _[4] || (_[4] = (B) => e(f)()),
|
2614
|
+
onClear: _[5] || (_[5] = (B) => e(b)(B.name)),
|
2615
|
+
mode: u.mode,
|
2616
2616
|
ref_key: "popoverRef",
|
2617
|
-
ref:
|
2617
|
+
ref: x,
|
2618
2618
|
cleanable: !0
|
2619
2619
|
}), {
|
2620
2620
|
default: re(() => [
|
2621
|
-
(
|
2622
|
-
key: "slot-" +
|
2621
|
+
(p(!0), w(F, null, q(e(c), (B, M) => (p(), z(oe(B), Z({
|
2622
|
+
key: "slot-" + M,
|
2623
2623
|
layout: "popover"
|
2624
|
-
}, { ref_for: !0 },
|
2624
|
+
}, { ref_for: !0 }, B.props, { cleanable: !0 }), null, 16))), 128))
|
2625
2625
|
]),
|
2626
2626
|
_: 1
|
2627
2627
|
}, 16, ["schema", "mode"])) : S("", !0),
|
2628
|
-
e(
|
2628
|
+
e(g) > 0 ? (p(), w("button", {
|
2629
2629
|
key: 2,
|
2630
|
-
onClick:
|
2630
|
+
onClick: v,
|
2631
2631
|
class: "relative py-2 px-3 inline-flex justify-center items-center gap-x-2 text-sm font-medium rounded-lg bg-gray-100 border border-transparent text-gray-800 hover:bg-gray-200 focus:bg-gray-200"
|
2632
2632
|
}, " Очистити ")) : S("", !0)
|
2633
2633
|
]));
|
2634
2634
|
}
|
2635
|
-
}),
|
2635
|
+
}), ga = {
|
2636
2636
|
key: 0,
|
2637
2637
|
class: "p-2 overflow-y-auto overflow-hidden [&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-gray-100 [&::-webkit-scrollbar-thumb]:bg-gray-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500 dark:bg-neutral-800 max-h-[calc(100%-142px)] h-full bg-gray-100"
|
2638
|
-
},
|
2638
|
+
}, ha = { class: "flex items-center vst-filters vsTailwind flex-col w-full" }, ba = /* @__PURE__ */ Y({
|
2639
2639
|
__name: "vertical-filter-layout",
|
2640
2640
|
props: {
|
2641
2641
|
schema: {},
|
@@ -2646,60 +2646,60 @@ const Gl = /* @__PURE__ */ le(Yl, [["render", Nl]]), Ql = {
|
|
2646
2646
|
limit: { default: 3 }
|
2647
2647
|
},
|
2648
2648
|
emits: ["change", "clear", "clearAll"],
|
2649
|
-
setup(
|
2650
|
-
const l =
|
2651
|
-
activeFilter:
|
2652
|
-
activeFilterCount:
|
2653
|
-
onFilterChange:
|
2649
|
+
setup(i, { expose: r, emit: d }) {
|
2650
|
+
const l = i, a = d, n = we(), {
|
2651
|
+
activeFilter: m,
|
2652
|
+
activeFilterCount: h,
|
2653
|
+
onFilterChange: g,
|
2654
2654
|
clearFilter: k,
|
2655
|
-
clearAllFilters:
|
2656
|
-
filtersSlot:
|
2657
|
-
} =
|
2655
|
+
clearAllFilters: b,
|
2656
|
+
filtersSlot: f
|
2657
|
+
} = $e({
|
2658
2658
|
...l,
|
2659
2659
|
slots: n
|
2660
|
-
},
|
2660
|
+
}, a);
|
2661
2661
|
return r({
|
2662
2662
|
clearFilter: k,
|
2663
|
-
clearAllFilters:
|
2664
|
-
}), (
|
2665
|
-
|
2666
|
-
e(
|
2663
|
+
clearAllFilters: b
|
2664
|
+
}), (y, C) => y.view === "vertical" ? (p(), w("div", ga, [
|
2665
|
+
o("div", ha, [
|
2666
|
+
e(h) > 0 ? (p(), w("button", {
|
2667
2667
|
key: 0,
|
2668
|
-
onClick: C[0] || (C[0] = (
|
2668
|
+
onClick: C[0] || (C[0] = (c) => e(b)()),
|
2669
2669
|
"data-popover-trigger": "",
|
2670
2670
|
"aria-haspopup": "dialog",
|
2671
2671
|
"aria-expanded": "false",
|
2672
2672
|
class: "w-full ring-offset-background focus-visible:outline-hidden focus-visible:ring-ring inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 hover:text-accent-foreground border h-10 px-4 py-2 gap-2 m-2 bg-white text-gray-800 hover:bg-gray-200 focus:bg-gray-200",
|
2673
2673
|
type: "button"
|
2674
2674
|
}, " Очистити ")) : S("", !0),
|
2675
|
-
|
2676
|
-
name:
|
2675
|
+
y.schema ? (p(!0), w(F, { key: 1 }, q(Object.entries(y.schema), ([c, s]) => (p(), z(ne, Z({
|
2676
|
+
name: c,
|
2677
2677
|
layout: "vertical"
|
2678
|
-
}, { ref_for: !0 },
|
2679
|
-
onChange: C[1] || (C[1] = (t) => e(
|
2678
|
+
}, { ref_for: !0 }, s, {
|
2679
|
+
onChange: C[1] || (C[1] = (t) => e(g)(t.name, t.value)),
|
2680
2680
|
onClear: C[2] || (C[2] = (t) => {
|
2681
|
-
e(k)(t), e(
|
2681
|
+
e(k)(t), e(g)(t, void 0);
|
2682
2682
|
}),
|
2683
|
-
modelValue: e(
|
2684
|
-
"onUpdate:modelValue": (t) => e(
|
2683
|
+
modelValue: e(m)[c],
|
2684
|
+
"onUpdate:modelValue": (t) => e(m)[c] = t,
|
2685
2685
|
showClean: !0
|
2686
2686
|
}), null, 16, ["name", "modelValue", "onUpdate:modelValue"]))), 256)) : S("", !0),
|
2687
|
-
(
|
2688
|
-
key: "slot-" +
|
2687
|
+
(p(!0), w(F, null, q(e(f), (c, s) => (p(), z(ne, Z({
|
2688
|
+
key: "slot-" + s,
|
2689
2689
|
layout: "vertical"
|
2690
|
-
}, { ref_for: !0 },
|
2691
|
-
onChange: C[3] || (C[3] = (t) => e(
|
2690
|
+
}, { ref_for: !0 }, c.props, {
|
2691
|
+
onChange: C[3] || (C[3] = (t) => e(g)(t.name, t.value)),
|
2692
2692
|
onClear: C[4] || (C[4] = (t) => {
|
2693
|
-
e(k)(t), e(
|
2693
|
+
e(k)(t), e(g)(t, void 0);
|
2694
2694
|
}),
|
2695
|
-
modelValue: e(
|
2696
|
-
"onUpdate:modelValue": (t) => e(
|
2695
|
+
modelValue: e(m)[c.props.name],
|
2696
|
+
"onUpdate:modelValue": (t) => e(m)[c.props.name] = t,
|
2697
2697
|
showClean: !0
|
2698
2698
|
}), null, 16, ["modelValue", "onUpdate:modelValue"]))), 128))
|
2699
2699
|
])
|
2700
2700
|
])) : S("", !0);
|
2701
2701
|
}
|
2702
|
-
}), xe = /* @__PURE__ */
|
2702
|
+
}), xe = /* @__PURE__ */ Y({
|
2703
2703
|
__name: "filter",
|
2704
2704
|
props: {
|
2705
2705
|
schema: {},
|
@@ -2710,116 +2710,116 @@ const Gl = /* @__PURE__ */ le(Yl, [["render", Nl]]), Ql = {
|
|
2710
2710
|
limit: { default: 3 }
|
2711
2711
|
},
|
2712
2712
|
emits: ["change", "clear", "clearAll"],
|
2713
|
-
setup(
|
2714
|
-
const l =
|
2715
|
-
function
|
2716
|
-
if (Array.isArray(
|
2717
|
-
return
|
2718
|
-
if (
|
2719
|
-
const t = fe(
|
2720
|
-
for (const
|
2721
|
-
|
2722
|
-
return
|
2713
|
+
setup(i, { expose: r, emit: d }) {
|
2714
|
+
const l = i, a = V(l.value ?? {}), n = d, m = V();
|
2715
|
+
function h(s) {
|
2716
|
+
if (Array.isArray(s))
|
2717
|
+
return s.map((t) => h(t));
|
2718
|
+
if (s !== null && typeof s == "object") {
|
2719
|
+
const t = fe(s), x = {};
|
2720
|
+
for (const v in t)
|
2721
|
+
x[v] = h(t[v]);
|
2722
|
+
return x;
|
2723
2723
|
}
|
2724
|
-
return
|
2724
|
+
return s;
|
2725
2725
|
}
|
2726
|
-
function
|
2727
|
-
t !== void 0 ?
|
2728
|
-
...
|
2729
|
-
[
|
2730
|
-
} : delete
|
2731
|
-
data:
|
2732
|
-
name:
|
2733
|
-
value:
|
2726
|
+
function g(s, t) {
|
2727
|
+
t !== void 0 ? a.value = {
|
2728
|
+
...a.value,
|
2729
|
+
[s]: t
|
2730
|
+
} : delete a.value[s], n("change", {
|
2731
|
+
data: h(a.value),
|
2732
|
+
name: s,
|
2733
|
+
value: h(t)
|
2734
2734
|
});
|
2735
2735
|
}
|
2736
|
-
function k(
|
2737
|
-
delete
|
2738
|
-
data:
|
2739
|
-
name:
|
2736
|
+
function k(s) {
|
2737
|
+
delete a.value[s], n("clear", {
|
2738
|
+
data: h(a.value),
|
2739
|
+
name: s
|
2740
2740
|
}), n("change", {
|
2741
|
-
data:
|
2742
|
-
name:
|
2741
|
+
data: h(a.value),
|
2742
|
+
name: s,
|
2743
2743
|
value: null
|
2744
2744
|
});
|
2745
2745
|
}
|
2746
|
-
function
|
2747
|
-
|
2748
|
-
data:
|
2746
|
+
function b() {
|
2747
|
+
a.value = {}, n("clear", {
|
2748
|
+
data: h(a.value),
|
2749
2749
|
name: "ALL"
|
2750
2750
|
}), n("change", {
|
2751
|
-
data:
|
2751
|
+
data: h(a.value),
|
2752
2752
|
name: "ALL",
|
2753
2753
|
value: null
|
2754
2754
|
});
|
2755
2755
|
}
|
2756
|
-
const
|
2757
|
-
function
|
2756
|
+
const f = V({});
|
2757
|
+
function y() {
|
2758
2758
|
switch (l.view) {
|
2759
2759
|
case "inline":
|
2760
|
-
return
|
2760
|
+
return Ke;
|
2761
2761
|
case "vertical":
|
2762
|
-
return
|
2762
|
+
return ba;
|
2763
2763
|
case "popover":
|
2764
|
-
return
|
2764
|
+
return Ne;
|
2765
2765
|
default:
|
2766
|
-
return
|
2766
|
+
return Ke;
|
2767
2767
|
}
|
2768
2768
|
}
|
2769
|
-
|
2769
|
+
A(
|
2770
2770
|
() => l.schema,
|
2771
|
-
(
|
2772
|
-
if (!
|
2773
|
-
|
2771
|
+
(s) => {
|
2772
|
+
if (!s) {
|
2773
|
+
f.value = {};
|
2774
2774
|
return;
|
2775
2775
|
}
|
2776
|
-
if (Array.isArray(
|
2777
|
-
|
2776
|
+
if (Array.isArray(s) && !s.length) {
|
2777
|
+
f.value = {};
|
2778
2778
|
return;
|
2779
2779
|
}
|
2780
|
-
Array.isArray(
|
2781
|
-
Object.assign(
|
2782
|
-
}),
|
2780
|
+
Array.isArray(s) ? f.value = s.filter((t) => t.type).reduce((t, x) => (Object.assign(x, { name: x.id || x.name, type: x.type.toLowerCase() }), t[x.name] = x, x.data && !x.api && !x.options && Object.assign(x, { api: `/api/suggest/${x.data}` }), t), {}) : (Object.entries(s).forEach(([t, x]) => {
|
2781
|
+
Object.assign(x, { name: t || x.name || x.id, type: x.type.toLowerCase() });
|
2782
|
+
}), f.value = { ...s });
|
2783
2783
|
},
|
2784
2784
|
{ immediate: !0, deep: !0 }
|
2785
2785
|
);
|
2786
|
-
function C(
|
2787
|
-
|
2786
|
+
function C(s) {
|
2787
|
+
m.value.clearFilter(s), k(s);
|
2788
2788
|
}
|
2789
|
-
function
|
2790
|
-
|
2789
|
+
function c() {
|
2790
|
+
m.value.clearAllFilters(), b();
|
2791
2791
|
}
|
2792
2792
|
return r({
|
2793
|
-
clearAllFilters:
|
2793
|
+
clearAllFilters: c,
|
2794
2794
|
clearFilter: C
|
2795
|
-
}), (
|
2796
|
-
schema:
|
2797
|
-
onChange: t[0] || (t[0] = (
|
2798
|
-
onClear: t[1] || (t[1] = (
|
2799
|
-
onClearAll:
|
2795
|
+
}), (s, t) => (p(), z(oe(y()), Z(l, {
|
2796
|
+
schema: f.value,
|
2797
|
+
onChange: t[0] || (t[0] = (x) => g(x.name, x.value)),
|
2798
|
+
onClear: t[1] || (t[1] = (x) => k(x.name)),
|
2799
|
+
onClearAll: b,
|
2800
2800
|
ref_key: "filterRef",
|
2801
|
-
ref:
|
2801
|
+
ref: m
|
2802
2802
|
}), {
|
2803
2803
|
default: re(() => [
|
2804
|
-
ee(
|
2804
|
+
ee(s.$slots, "default")
|
2805
2805
|
]),
|
2806
2806
|
_: 3
|
2807
2807
|
}, 16, ["schema"]));
|
2808
2808
|
}
|
2809
2809
|
});
|
2810
|
-
xe.install = function(
|
2811
|
-
|
2810
|
+
xe.install = function(i) {
|
2811
|
+
i.component("Filter", xe), i.component("FilterField", ne);
|
2812
2812
|
};
|
2813
|
-
function
|
2814
|
-
const { page: r, id:
|
2815
|
-
r ? n.set("page", r.toString()) : n.delete("page"),
|
2813
|
+
function ya(i) {
|
2814
|
+
const { page: r, id: d, filter: l } = i, a = new URL(window.location.href), n = new URLSearchParams(window.location.search);
|
2815
|
+
r ? n.set("page", r.toString()) : n.delete("page"), d ? n.set("id", d.toString()) : n.delete("id"), l ? n.set("filter", l) : n.delete("filter"), a.search = decodeURI(n.toString()), window.history.pushState({}, "", a);
|
2816
2816
|
}
|
2817
|
-
const
|
2817
|
+
const xa = { class: "flex items-center justify-between w-full gap-x-1" }, wa = { class: "flex items-center" }, ka = ["disabled"], _a = { class: "flex items-center gap-x-1" }, Ca = ["onClick"], Va = ["disabled"], Sa = { class: "flex justify-center items-center gap-x-5 ml-3" }, Ma = { class: "relative" }, Ba = {
|
2818
2818
|
class: "hs-dropdown-menu z-50 bg-white shadow-md rounded-lg p-1 space-y-0.5 dark:bg-neutral-800 dark:border dark:border-neutral-700 right-0 dark:divide-neutral-700 absolute bottom-[100%]",
|
2819
2819
|
role: "menu",
|
2820
2820
|
"aria-orientation": "vertical",
|
2821
2821
|
"aria-labelledby": "dropdown-button"
|
2822
|
-
},
|
2822
|
+
}, $a = ["onClick"], Aa = {
|
2823
2823
|
key: 0,
|
2824
2824
|
xmlns: "http://www.w3.org/2000/svg",
|
2825
2825
|
viewBox: "0 0 24 24",
|
@@ -2831,7 +2831,7 @@ const ga = { class: "flex items-center justify-between w-full gap-x-1" }, ha = {
|
|
2831
2831
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-check text-blue-600",
|
2832
2832
|
width: "14",
|
2833
2833
|
height: "14"
|
2834
|
-
},
|
2834
|
+
}, Ra = /* @__PURE__ */ Y({
|
2835
2835
|
__name: "pagination",
|
2836
2836
|
props: {
|
2837
2837
|
total: {},
|
@@ -2839,38 +2839,38 @@ const ga = { class: "flex items-center justify-between w-full gap-x-1" }, ha = {
|
|
2839
2839
|
pageSize: {}
|
2840
2840
|
},
|
2841
2841
|
emits: ["update:currentPage", "update:pageSize", "pageChange", "pageSizeChange"],
|
2842
|
-
setup(
|
2843
|
-
const
|
2844
|
-
|
2842
|
+
setup(i, { emit: r }) {
|
2843
|
+
const d = i, l = r, a = V(d.currentPage), n = V(d.pageSize), m = V(!1);
|
2844
|
+
A(() => d.pageSize, (C) => {
|
2845
2845
|
n.value = C;
|
2846
2846
|
});
|
2847
|
-
const
|
2848
|
-
const
|
2849
|
-
let
|
2850
|
-
|
2851
|
-
const
|
2852
|
-
for (let
|
2853
|
-
|
2854
|
-
return
|
2847
|
+
const h = E(() => Math.ceil(d.total / d.pageSize)), g = E(() => {
|
2848
|
+
const c = Math.floor(3.5);
|
2849
|
+
let s = a.value - c, t = a.value + c;
|
2850
|
+
s < 1 && (t += 1 - s, s = 1), t > h.value && (s -= t - h.value, t = h.value), s = Math.max(1, s);
|
2851
|
+
const x = [];
|
2852
|
+
for (let v = s; v <= t; v += 1)
|
2853
|
+
x.push(v);
|
2854
|
+
return x;
|
2855
2855
|
}), k = () => {
|
2856
|
-
|
2857
|
-
},
|
2858
|
-
|
2859
|
-
},
|
2860
|
-
|
2861
|
-
},
|
2862
|
-
n.value = C,
|
2856
|
+
a.value > 1 && (a.value -= 1, l("update:currentPage", a.value));
|
2857
|
+
}, b = () => {
|
2858
|
+
a.value < h.value && (a.value += 1, l("update:currentPage", a.value));
|
2859
|
+
}, f = (C) => {
|
2860
|
+
a.value = C, l("update:currentPage", C), l("pageChange", C);
|
2861
|
+
}, y = (C = n.value) => {
|
2862
|
+
n.value = C, m.value = !1, l("update:pageSize", n.value), l("update:currentPage", 1), l("pageSizeChange", n.value);
|
2863
2863
|
};
|
2864
|
-
return (C,
|
2865
|
-
|
2866
|
-
|
2864
|
+
return (C, c) => (p(), w("nav", xa, [
|
2865
|
+
o("div", wa, [
|
2866
|
+
o("button", {
|
2867
2867
|
type: "button",
|
2868
2868
|
"aria-label": "Previous",
|
2869
2869
|
onClick: k,
|
2870
|
-
disabled:
|
2870
|
+
disabled: a.value === 1,
|
2871
2871
|
class: "border-white last:rounded-e-lg text-base h-[38px] min-w-[38px] py-2 px-2.5 inline-flex justify-center items-center gap-x-2 border text-sm rounded-lg bg-white text-gray-800 hover:shadow-sm hover:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-50 dark:bg-neutral-700 dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-800 py-2"
|
2872
|
-
},
|
2873
|
-
|
2872
|
+
}, c[1] || (c[1] = [
|
2873
|
+
o("svg", {
|
2874
2874
|
xmlns: "http://www.w3.org/2000/svg",
|
2875
2875
|
viewBox: "0 0 24 24",
|
2876
2876
|
fill: "none",
|
@@ -2882,38 +2882,38 @@ const ga = { class: "flex items-center justify-between w-full gap-x-1" }, ha = {
|
|
2882
2882
|
height: "16",
|
2883
2883
|
width: "16"
|
2884
2884
|
}, [
|
2885
|
-
|
2885
|
+
o("path", {
|
2886
2886
|
stroke: "none",
|
2887
2887
|
d: "M0 0h24v24H0z",
|
2888
2888
|
fill: "none"
|
2889
2889
|
}),
|
2890
|
-
|
2890
|
+
o("path", { d: "M6 9l6 6l6 -6" })
|
2891
2891
|
], -1),
|
2892
|
-
|
2892
|
+
o("span", {
|
2893
2893
|
"aria-hidden": "true",
|
2894
2894
|
class: "sr-only"
|
2895
2895
|
}, "Previous", -1)
|
2896
|
-
]), 8,
|
2897
|
-
|
2898
|
-
(
|
2896
|
+
]), 8, ka),
|
2897
|
+
o("div", _a, [
|
2898
|
+
(p(!0), w(F, null, q(g.value, (s) => (p(), w("button", {
|
2899
2899
|
type: "button",
|
2900
|
-
key:
|
2901
|
-
onClick: (t) =>
|
2902
|
-
class:
|
2903
|
-
}, K(
|
2900
|
+
key: s,
|
2901
|
+
onClick: (t) => f(s),
|
2902
|
+
class: j(a.value === s ? "flex justify-center items-center rounded-lg text-sm dark:text-neutral-300 py-2 px-3 focus:outline-none disabled:opacity-50 disabled:pointer-events-none bg-[#e5e7eb] dark:bg-[#242424] border border-gray-200 text-base h-[38px] min-w-[38px]" : "flex justify-center items-center rounded-lg text-sm dark:text-neutral-400 hover:bg-gray-100 py-2 px-3 focus:outline-none focus:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none dark:hover:bg-neutral-800 dark:focus:bg-neutral-800 text-base h-[38px] min-w-[38px]")
|
2903
|
+
}, K(s), 11, Ca))), 128))
|
2904
2904
|
]),
|
2905
|
-
|
2905
|
+
o("button", {
|
2906
2906
|
type: "button",
|
2907
2907
|
"aria-label": "Next",
|
2908
|
-
onClick:
|
2909
|
-
disabled:
|
2908
|
+
onClick: b,
|
2909
|
+
disabled: a.value === h.value,
|
2910
2910
|
class: "border-white last:rounded-e-lg text-base h-[38px] min-w-[38px] py-2 px-2.5 inline-flex justify-center items-center gap-x-2 border text-sm rounded-lg bg-white text-gray-800 hover:shadow-sm hover:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-50 dark:bg-neutral-700 dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-800 py-2"
|
2911
|
-
},
|
2912
|
-
|
2911
|
+
}, c[2] || (c[2] = [
|
2912
|
+
o("span", {
|
2913
2913
|
"aria-hidden": "true",
|
2914
2914
|
class: "sr-only"
|
2915
2915
|
}, "Next", -1),
|
2916
|
-
|
2916
|
+
o("svg", {
|
2917
2917
|
xmlns: "http://www.w3.org/2000/svg",
|
2918
2918
|
viewBox: "0 0 24 24",
|
2919
2919
|
fill: "none",
|
@@ -2925,47 +2925,47 @@ const ga = { class: "flex items-center justify-between w-full gap-x-1" }, ha = {
|
|
2925
2925
|
height: "16",
|
2926
2926
|
width: "16"
|
2927
2927
|
}, [
|
2928
|
-
|
2928
|
+
o("path", {
|
2929
2929
|
stroke: "none",
|
2930
2930
|
d: "M0 0h24v24H0z",
|
2931
2931
|
fill: "none"
|
2932
2932
|
}),
|
2933
|
-
|
2933
|
+
o("path", { d: "M6 9l6 6l6 -6" })
|
2934
2934
|
], -1)
|
2935
|
-
]), 8,
|
2935
|
+
]), 8, Va)
|
2936
2936
|
]),
|
2937
|
-
|
2938
|
-
|
2939
|
-
|
2940
|
-
(
|
2937
|
+
o("div", Sa, [
|
2938
|
+
o("div", Ma, [
|
2939
|
+
I(o("div", Ba, [
|
2940
|
+
(p(), w(F, null, q([10, 20, 30], (s) => o("button", {
|
2941
2941
|
type: "button",
|
2942
|
-
key:
|
2943
|
-
onClick: (t) =>
|
2942
|
+
key: s,
|
2943
|
+
onClick: (t) => y(s),
|
2944
2944
|
class: "w-full flex items-center gap-x-3.5 py-2 px-3 rounded-lg text-sm text-gray-800 hover:bg-gray-100 focus:outline-none focus:bg-gray-100 dark:text-neutral-400 dark:hover:bg-neutral-700 dark:hover:text-neutral-300 dark:focus:bg-neutral-700"
|
2945
2945
|
}, [
|
2946
|
-
|
2947
|
-
n.value ===
|
2948
|
-
|
2946
|
+
W(K(s) + " ", 1),
|
2947
|
+
n.value === s ? (p(), w("svg", Aa, c[3] || (c[3] = [
|
2948
|
+
o("path", {
|
2949
2949
|
stroke: "none",
|
2950
2950
|
d: "M0 0h24v24H0z",
|
2951
2951
|
fill: "none"
|
2952
2952
|
}, null, -1),
|
2953
|
-
|
2953
|
+
o("path", { d: "M5 12l5 5l10 -10" }, null, -1)
|
2954
2954
|
]))) : S("", !0)
|
2955
|
-
], 8,
|
2955
|
+
], 8, $a)), 64))
|
2956
2956
|
], 512), [
|
2957
|
-
[X,
|
2957
|
+
[X, m.value]
|
2958
2958
|
]),
|
2959
|
-
|
2959
|
+
o("button", {
|
2960
2960
|
type: "button",
|
2961
2961
|
class: "py-3 px-3.5 inline-flex items-center gap-x-1 text-sm rounded-lg border border-gray-200 text-gray-800 shadow-sm hover:bg-gray-50 focus:outline-none focus:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-700 dark:focus:bg-neutral-700 text-base h-[38px] min-w-[38px]",
|
2962
2962
|
"aria-haspopup": "menu",
|
2963
2963
|
"aria-expanded": "false",
|
2964
2964
|
"aria-label": "Dropdown",
|
2965
|
-
onClick:
|
2965
|
+
onClick: c[0] || (c[0] = (s) => m.value = !m.value)
|
2966
2966
|
}, [
|
2967
|
-
|
2968
|
-
|
2967
|
+
W(K(n.value) + " ", 1),
|
2968
|
+
c[4] || (c[4] = o("svg", {
|
2969
2969
|
xmlns: "http://www.w3.org/2000/svg",
|
2970
2970
|
viewBox: "0 0 24 24",
|
2971
2971
|
fill: "none",
|
@@ -2977,24 +2977,24 @@ const ga = { class: "flex items-center justify-between w-full gap-x-1" }, ha = {
|
|
2977
2977
|
height: "16",
|
2978
2978
|
width: "16"
|
2979
2979
|
}, [
|
2980
|
-
|
2980
|
+
o("path", {
|
2981
2981
|
stroke: "none",
|
2982
2982
|
d: "M0 0h24v24H0z",
|
2983
2983
|
fill: "none"
|
2984
2984
|
}),
|
2985
|
-
|
2985
|
+
o("path", { d: "M6 9l6 6l6 -6" })
|
2986
2986
|
], -1))
|
2987
2987
|
])
|
2988
2988
|
])
|
2989
2989
|
])
|
2990
2990
|
]));
|
2991
2991
|
}
|
2992
|
-
}), ve = (
|
2993
|
-
const
|
2994
|
-
for (const [l,
|
2995
|
-
|
2996
|
-
return
|
2997
|
-
},
|
2992
|
+
}), ve = (i, r) => {
|
2993
|
+
const d = i.__vccOpts || i;
|
2994
|
+
for (const [l, a] of r)
|
2995
|
+
d[l] = a;
|
2996
|
+
return d;
|
2997
|
+
}, Da = {}, za = {
|
2998
2998
|
class: "w-48 mx-auto mb-4",
|
2999
2999
|
width: "178",
|
3000
3000
|
height: "90",
|
@@ -3002,12 +3002,12 @@ const ga = { class: "flex items-center justify-between w-full gap-x-1" }, ha = {
|
|
3002
3002
|
fill: "none",
|
3003
3003
|
xmlns: "http://www.w3.org/2000/svg"
|
3004
3004
|
};
|
3005
|
-
function
|
3006
|
-
return
|
3007
|
-
|
3005
|
+
function ja(i, r) {
|
3006
|
+
return p(), w("svg", za, r[0] || (r[0] = [
|
3007
|
+
Pe('<rect x="27" y="50.5" width="124" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="27" y="50.5" width="124" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-50 dark:stroke-neutral-700/10"></rect><rect x="34.5" y="58" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="61" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="73" width="77" height="6" rx="3" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-100 dark:stroke-neutral-700/30"></rect><rect x="27" y="36" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><rect x="59" y="39" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><rect x="59" y="51" width="92" height="6" rx="3" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><g filter="url(#filter2)"><rect x="12" y="6" width="154" height="40" rx="8" fill="currentColor" class="fill-white dark:fill-neutral-800" shape-rendering="crispEdges"></rect><rect x="12.5" y="6.5" width="153" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-100 dark:stroke-neutral-700/60" shape-rendering="crispEdges"></rect><rect x="20" y="14" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect><rect x="52" y="17" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect><rect x="52" y="29" width="106" height="6" rx="3" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect></g><defs><filter id="filter2" x="0" y="0" width="178" height="64" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB"><feFlood flood-opacity="0" result="BackgroundImageFix"></feFlood><feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"></feColorMatrix><feOffset dy="6"></feOffset><feGaussianBlur stdDeviation="6"></feGaussianBlur><feComposite in2="hardAlpha" operator="out"></feComposite><feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.03 0"></feColorMatrix><feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_1187_14810"></feBlend><feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_1187_14810" result="shape"></feBlend></filter></defs>', 12)
|
3008
3008
|
]));
|
3009
3009
|
}
|
3010
|
-
const
|
3010
|
+
const Fa = /* @__PURE__ */ ve(Da, [["render", ja]]), Ka = {}, La = {
|
3011
3011
|
xmlns: "http://www.w3.org/2000/svg",
|
3012
3012
|
width: "21",
|
3013
3013
|
height: "20",
|
@@ -3019,19 +3019,19 @@ const Ra = /* @__PURE__ */ ve(Ba, [["render", $a]]), Da = {}, ja = {
|
|
3019
3019
|
"stroke-linejoin": "round",
|
3020
3020
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-layout-sidebar-right-collapse"
|
3021
3021
|
};
|
3022
|
-
function
|
3023
|
-
return
|
3024
|
-
|
3022
|
+
function Ua(i, r) {
|
3023
|
+
return p(), w("svg", La, r[0] || (r[0] = [
|
3024
|
+
o("path", {
|
3025
3025
|
stroke: "none",
|
3026
3026
|
d: "M0 0h24v24H0z",
|
3027
3027
|
fill: "none"
|
3028
3028
|
}, null, -1),
|
3029
|
-
|
3030
|
-
|
3031
|
-
|
3029
|
+
o("path", { d: "M4 4m0 2a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2z" }, null, -1),
|
3030
|
+
o("path", { d: "M15 4v16" }, null, -1),
|
3031
|
+
o("path", { d: "M9 10l2 2l-2 2" }, null, -1)
|
3032
3032
|
]));
|
3033
3033
|
}
|
3034
|
-
const
|
3034
|
+
const Oa = /* @__PURE__ */ ve(Ka, [["render", Ua]]), Pa = {}, Ia = {
|
3035
3035
|
xmlns: "http://www.w3.org/2000/svg",
|
3036
3036
|
width: "21",
|
3037
3037
|
height: "20",
|
@@ -3043,19 +3043,19 @@ const Fa = /* @__PURE__ */ ve(Da, [["render", za]]), Ka = {}, Ua = {
|
|
3043
3043
|
"stroke-linejoin": "round",
|
3044
3044
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-layout-sidebar-right-expand"
|
3045
3045
|
};
|
3046
|
-
function
|
3047
|
-
return
|
3048
|
-
|
3046
|
+
function Ta(i, r) {
|
3047
|
+
return p(), w("svg", Ia, r[0] || (r[0] = [
|
3048
|
+
o("path", {
|
3049
3049
|
stroke: "none",
|
3050
3050
|
d: "M0 0h24v24H0z",
|
3051
3051
|
fill: "none"
|
3052
3052
|
}, null, -1),
|
3053
|
-
|
3054
|
-
|
3055
|
-
|
3053
|
+
o("path", { d: "M4 4m0 2a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2z" }, null, -1),
|
3054
|
+
o("path", { d: "M15 4v16" }, null, -1),
|
3055
|
+
o("path", { d: "M10 10l-2 2l2 2" }, null, -1)
|
3056
3056
|
]));
|
3057
3057
|
}
|
3058
|
-
const
|
3058
|
+
const Ha = /* @__PURE__ */ ve(Pa, [["render", Ta]]), Ea = {}, Ya = {
|
3059
3059
|
xmlns: "http://www.w3.org/2000/svg",
|
3060
3060
|
width: "24",
|
3061
3061
|
height: "24",
|
@@ -3067,19 +3067,19 @@ const Oa = /* @__PURE__ */ ve(Ka, [["render", La]]), Pa = {}, Ia = {
|
|
3067
3067
|
"stroke-linejoin": "round",
|
3068
3068
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-map"
|
3069
3069
|
};
|
3070
|
-
function
|
3071
|
-
return
|
3072
|
-
|
3070
|
+
function Wa(i, r) {
|
3071
|
+
return p(), w("svg", Ya, r[0] || (r[0] = [
|
3072
|
+
o("path", {
|
3073
3073
|
stroke: "none",
|
3074
3074
|
d: "M0 0h24v24H0z",
|
3075
3075
|
fill: "none"
|
3076
3076
|
}, null, -1),
|
3077
|
-
|
3078
|
-
|
3079
|
-
|
3077
|
+
o("path", { d: "M3 7l6 -3l6 3l6 -3v13l-6 3l-6 -3l-6 3v-13" }, null, -1),
|
3078
|
+
o("path", { d: "M9 4v13" }, null, -1),
|
3079
|
+
o("path", { d: "M15 7v13" }, null, -1)
|
3080
3080
|
]));
|
3081
3081
|
}
|
3082
|
-
const
|
3082
|
+
const qa = /* @__PURE__ */ ve(Ea, [["render", Wa]]), Na = {}, Ga = {
|
3083
3083
|
xmlns: "http://www.w3.org/2000/svg",
|
3084
3084
|
width: "24",
|
3085
3085
|
height: "24",
|
@@ -3091,30 +3091,30 @@ const Ha = /* @__PURE__ */ ve(Pa, [["render", Ta]]), Ea = {}, Wa = {
|
|
3091
3091
|
"stroke-linejoin": "round",
|
3092
3092
|
class: "icon icon-tabler icons-tabler-outline icon-tabler-table"
|
3093
3093
|
};
|
3094
|
-
function
|
3095
|
-
return
|
3096
|
-
|
3094
|
+
function Qa(i, r) {
|
3095
|
+
return p(), w("svg", Ga, r[0] || (r[0] = [
|
3096
|
+
o("path", {
|
3097
3097
|
stroke: "none",
|
3098
3098
|
d: "M0 0h24v24H0z",
|
3099
3099
|
fill: "none"
|
3100
3100
|
}, null, -1),
|
3101
|
-
|
3102
|
-
|
3103
|
-
|
3101
|
+
o("path", { d: "M3 5a2 2 0 0 1 2 -2h14a2 2 0 0 1 2 2v14a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-14z" }, null, -1),
|
3102
|
+
o("path", { d: "M3 10h18" }, null, -1),
|
3103
|
+
o("path", { d: "M10 3v18" }, null, -1)
|
3104
3104
|
]));
|
3105
3105
|
}
|
3106
|
-
const
|
3107
|
-
function
|
3108
|
-
let
|
3106
|
+
const Za = /* @__PURE__ */ ve(Na, [["render", Qa]]);
|
3107
|
+
function Ja(i, r) {
|
3108
|
+
let d;
|
3109
3109
|
return function(...l) {
|
3110
|
-
clearTimeout(
|
3110
|
+
clearTimeout(d), d = setTimeout(() => i(...l), r);
|
3111
3111
|
};
|
3112
3112
|
}
|
3113
|
-
function
|
3113
|
+
function Xa(i, r, d) {
|
3114
3114
|
r && (r.addSource("vector", {
|
3115
3115
|
type: "vector",
|
3116
3116
|
tiles: [
|
3117
|
-
`http://${window.location.host}/api/vtile/${
|
3117
|
+
`http://${window.location.host}/api/vtile/${i}/ua/{z}/{x}/{y}.vmt?pointZoom=12`
|
3118
3118
|
],
|
3119
3119
|
minzoom: 0,
|
3120
3120
|
maxzoom: 12
|
@@ -3123,10 +3123,10 @@ function Ga(u, r, v) {
|
|
3123
3123
|
type: "circle",
|
3124
3124
|
maxzoom: 12,
|
3125
3125
|
source: "vector",
|
3126
|
-
"source-layer":
|
3126
|
+
"source-layer": i,
|
3127
3127
|
// must match the layer name in the vector tile source
|
3128
3128
|
paint: {
|
3129
|
-
"circle-color":
|
3129
|
+
"circle-color": d,
|
3130
3130
|
"circle-stroke-color": "#eee",
|
3131
3131
|
"circle-stroke-width": 1,
|
3132
3132
|
"circle-radius": ["interpolate", ["linear"], ["zoom"], 10, 5, 15, 12]
|
@@ -3136,10 +3136,10 @@ function Ga(u, r, v) {
|
|
3136
3136
|
type: "fill",
|
3137
3137
|
minzoom: 12,
|
3138
3138
|
source: "vector",
|
3139
|
-
"source-layer":
|
3139
|
+
"source-layer": i,
|
3140
3140
|
// must match the layer name in the vector tile source
|
3141
3141
|
paint: {
|
3142
|
-
"fill-color":
|
3142
|
+
"fill-color": d,
|
3143
3143
|
"fill-opacity": 0.6
|
3144
3144
|
}
|
3145
3145
|
}));
|
@@ -3169,7 +3169,10 @@ const ge = [
|
|
3169
3169
|
url: "https://mt1.google.com/vt/lyrs=s&x={x}&y={y}&z={z}",
|
3170
3170
|
preview: "https://mt1.google.com/vt/lyrs=s&x=2422&y=1400&z=12"
|
3171
3171
|
}
|
3172
|
-
],
|
3172
|
+
], eo = { class: "relative w-auto h-full" }, to = { class: "absolute left-[20px] bottom-[74px] bg-white max-w-[250px] p-[10px] rounded-lg z-10 border" }, lo = { class: "flex justify-start items-center gap-2" }, ao = { class: "ml-1 text-[0.875rem]" }, oo = {
|
3173
|
+
class: "vs-map-slot-layers z-10 select-none",
|
3174
|
+
style: { display: "flex" }
|
3175
|
+
}, ro = ["title", "onClick"], no = ["src"], io = { class: "absolute py-2 px-4 text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-lg top-[-46px] hidden whitespace-nowrap left-1/2 -translate-x-1/2" }, so = /* @__PURE__ */ Y({
|
3173
3176
|
__name: "map",
|
3174
3177
|
props: {
|
3175
3178
|
table: {},
|
@@ -3181,10 +3184,10 @@ const ge = [
|
|
3181
3184
|
map: {}
|
3182
3185
|
},
|
3183
3186
|
emits: ["update:modelValue", "update:map"],
|
3184
|
-
setup(
|
3185
|
-
const
|
3186
|
-
let
|
3187
|
-
const
|
3187
|
+
setup(i, { emit: r }) {
|
3188
|
+
const d = i, l = r;
|
3189
|
+
let a, n;
|
3190
|
+
const m = V(null), h = V(!1), g = V(ge[0].name), k = ge[0], b = V(null), f = V(null), y = [
|
3188
3191
|
"#2563EB",
|
3189
3192
|
// Primary Blue
|
3190
3193
|
"#60A5FA",
|
@@ -3207,15 +3210,15 @@ const ge = [
|
|
3207
3210
|
// Light Gray
|
3208
3211
|
];
|
3209
3212
|
let C;
|
3210
|
-
const
|
3213
|
+
const c = [30, 48];
|
3211
3214
|
return ue(async () => {
|
3212
|
-
C = (await fetch(`/api/data/${
|
3213
|
-
t.color || Object.assign(t, { color: x
|
3215
|
+
C = (await fetch(`/api/data/${d.table}/${d.colorAttr}`).then((t) => t.json())).rows, C.forEach((t, x) => {
|
3216
|
+
t.color || Object.assign(t, { color: y[x % 10] });
|
3214
3217
|
}), n = new maplibregl.Popup({
|
3215
3218
|
closeButton: !1,
|
3216
3219
|
closeOnClick: !1
|
3217
|
-
}),
|
3218
|
-
container:
|
3220
|
+
}), a = new maplibregl.Map({
|
3221
|
+
container: m.value,
|
3219
3222
|
style: {
|
3220
3223
|
version: 8,
|
3221
3224
|
sources: {
|
@@ -3229,109 +3232,121 @@ const ge = [
|
|
3229
3232
|
maxzoom: 19
|
3230
3233
|
}]
|
3231
3234
|
},
|
3232
|
-
center:
|
3235
|
+
center: d.center || c,
|
3233
3236
|
// [lng, lat] → Paris
|
3234
|
-
zoom:
|
3237
|
+
zoom: d.zoom || 5,
|
3235
3238
|
minZoom: 3,
|
3236
3239
|
maxZoom: 18,
|
3237
3240
|
attributionControl: !1
|
3238
|
-
}), l("update:map",
|
3239
|
-
|
3240
|
-
|
3241
|
-
|
3242
|
-
|
3243
|
-
|
3244
|
-
|
3245
|
-
|
3246
|
-
|
3247
|
-
|
3248
|
-
|
3249
|
-
|
3241
|
+
}), l("update:map", a), a.addControl(new maplibregl.NavigationControl(), "top-right"), a.on("zoom", () => {
|
3242
|
+
console.log("Zoom is changing:", a.getZoom());
|
3243
|
+
}), a.on("load", () => {
|
3244
|
+
a == null || a.resize(), h.value = !0;
|
3245
|
+
const t = C.filter((v) => v.id).reduce((v, u) => [u.id, u.color].concat(v), []), x = ["match", ["get", d.colorAttr], ...t, "#808080"];
|
3246
|
+
Xa(d.table, a, x);
|
3247
|
+
}), a.on("click", (t) => {
|
3248
|
+
const x = a.queryRenderedFeatures(t.point);
|
3249
|
+
x.length && l("update:modelValue", x[0].properties.id);
|
3250
|
+
}), a.on("mousemove", (t) => {
|
3251
|
+
var B;
|
3252
|
+
const x = a.queryRenderedFeatures(t.point);
|
3253
|
+
if (!x || !x.length) {
|
3254
|
+
n.remove(), a.getCanvas().style.cursor = "";
|
3250
3255
|
return;
|
3251
3256
|
}
|
3252
|
-
|
3253
|
-
const
|
3254
|
-
|
3257
|
+
a.getCanvas().style.cursor = "pointer";
|
3258
|
+
const v = x[0], { coordinates: u } = v.geometry, _ = v.geometry.type === "Point" ? u : u[0][0];
|
3259
|
+
f.value = v.properties, n.setLngLat(_).setHTML((B = b.value) == null ? void 0 : B.innerHTML).addTo(a);
|
3255
3260
|
});
|
3256
|
-
}),
|
3257
|
-
|
3258
|
-
}),
|
3259
|
-
|
3260
|
-
|
3261
|
-
|
3262
|
-
|
3263
|
-
|
3264
|
-
|
3261
|
+
}), A(() => d.center, (s) => {
|
3262
|
+
a && a.setCenter(s || c);
|
3263
|
+
}), A(() => d.zoom, (s) => {
|
3264
|
+
a && a.setZoom(s);
|
3265
|
+
}), A(() => d.filter, (s) => {
|
3266
|
+
const t = `http://${window.location.host}/api/vtile/${d.table}/ua/{z}/{x}/{y}.vmt?pointZoom=12&filter=${s}`;
|
3267
|
+
a.getSource("vector").setTiles([t]);
|
3268
|
+
}), A(g, (s, t) => {
|
3269
|
+
const x = ge.find((v) => v.name === s);
|
3270
|
+
x && (a.removeLayer(t), a.removeSource(t), a.addSource(s, { type: "raster", tiles: [x.url], tileSize: 256 }), a.addLayer({
|
3271
|
+
id: x.name,
|
3265
3272
|
type: "raster",
|
3266
|
-
source:
|
3273
|
+
source: x.name,
|
3267
3274
|
minzoom: 0,
|
3268
3275
|
maxzoom: 19
|
3269
3276
|
}, "vector-circle"));
|
3270
3277
|
}), he(() => {
|
3271
|
-
|
3272
|
-
}), (
|
3273
|
-
|
3274
|
-
|
3275
|
-
|
3276
|
-
|
3277
|
-
|
3278
|
-
|
3279
|
-
|
3280
|
-
|
3281
|
-
|
3282
|
-
|
3283
|
-
|
3284
|
-
|
3285
|
-
|
3286
|
-
|
3287
|
-
|
3288
|
-
|
3289
|
-
|
3290
|
-
|
3291
|
-
|
3292
|
-
|
3293
|
-
|
3294
|
-
|
3295
|
-
|
3296
|
-
|
3297
|
-
|
3298
|
-
], 512),
|
3299
|
-
a("div", eo, [
|
3300
|
-
(c(!0), w(F, null, q(e(ge), (y) => (c(), w("div", {
|
3301
|
-
key: y.name,
|
3302
|
-
class: z(["vs-map-slot-layers__layer relative", { focused: m.value === y.name }]),
|
3303
|
-
onClick: (b) => m.value = y.name
|
3278
|
+
a && a.remove();
|
3279
|
+
}), (s, t) => {
|
3280
|
+
const x = Ze("tooltip");
|
3281
|
+
return I((p(), w("div", eo, [
|
3282
|
+
o("div", {
|
3283
|
+
ref_key: "mapContainer",
|
3284
|
+
ref: m,
|
3285
|
+
class: "map-container w-auto relative"
|
3286
|
+
}, null, 512),
|
3287
|
+
o("div", to, [
|
3288
|
+
(p(!0), w(F, null, q(e(C), (v) => (p(), w("div", {
|
3289
|
+
class: "legend-item",
|
3290
|
+
key: v.id
|
3291
|
+
}, [
|
3292
|
+
o("div", lo, [
|
3293
|
+
o("div", {
|
3294
|
+
class: "w-[15px] h-[15px] rounded-[50%] min-w-[15px]",
|
3295
|
+
style: _e("background-color:" + v.color)
|
3296
|
+
}, null, 4),
|
3297
|
+
o("div", ao, K(v.text), 1)
|
3298
|
+
])
|
3299
|
+
]))), 128))
|
3300
|
+
]),
|
3301
|
+
o("div", {
|
3302
|
+
ref_key: "popupDiv",
|
3303
|
+
ref: b,
|
3304
|
+
style: { display: "none" }
|
3304
3305
|
}, [
|
3305
|
-
|
3306
|
-
|
3307
|
-
|
3308
|
-
|
3309
|
-
|
3310
|
-
|
3311
|
-
|
3312
|
-
|
3313
|
-
|
3314
|
-
|
3306
|
+
ee(s.$slots, "default", { hoverData: f.value })
|
3307
|
+
], 512),
|
3308
|
+
o("div", oo, [
|
3309
|
+
(p(!0), w(F, null, q(e(ge), (v) => I((p(), w("div", {
|
3310
|
+
key: v.name,
|
3311
|
+
title: v.label || v.name,
|
3312
|
+
class: j(["vs-map-slot-layers__layer relative", { focused: g.value === v.name }]),
|
3313
|
+
onClick: (u) => g.value = v.name
|
3314
|
+
}, [
|
3315
|
+
o("img", {
|
3316
|
+
src: v.preview,
|
3317
|
+
class: "vs-map-slot-layers__image"
|
3318
|
+
}, null, 8, no),
|
3319
|
+
o("div", io, K(v.label), 1)
|
3320
|
+
], 10, ro)), [
|
3321
|
+
[x, v.label || v.name]
|
3322
|
+
])), 128))
|
3323
|
+
])
|
3324
|
+
], 512)), [
|
3325
|
+
[X, h.value]
|
3326
|
+
]);
|
3327
|
+
};
|
3315
3328
|
}
|
3316
|
-
}),
|
3329
|
+
}), uo = { class: "pt-[20px]" }, co = { class: "w-full gap-5 inline-flex mb-[6px] pr-3" }, po = { class: "flex items-center" }, fo = ["title"], vo = { class: "max-[1000px]:flex gap-2 min-[1001px]:hidden" }, mo = { class: "flex" }, go = {
|
3317
3330
|
key: 0,
|
3318
3331
|
class: "py-[15px] pb-[24px] pl-2"
|
3319
|
-
},
|
3332
|
+
}, ho = { class: "font-bold text-2xl mr-[10px]" }, bo = { class: "text-sm text-stone-500 font-medium" }, yo = {
|
3320
3333
|
class: "wrapperTable flex flex-col",
|
3321
3334
|
style: { height: "calc(100vh - 302px)" }
|
3322
|
-
},
|
3335
|
+
}, xo = {
|
3323
3336
|
key: 1,
|
3324
3337
|
class: "text-center py-28"
|
3325
|
-
},
|
3338
|
+
}, wo = { key: 1 }, ko = {
|
3326
3339
|
key: 2,
|
3327
3340
|
class: "my-5 pr-2"
|
3328
|
-
},
|
3341
|
+
}, _o = { class: "flex justify-between" }, Co = { class: "w-full lg:w-1/2 relative" }, Le = /* @__PURE__ */ Y({
|
3329
3342
|
__name: "vs-parts-map",
|
3330
3343
|
props: {
|
3331
3344
|
title: {},
|
3332
3345
|
table: {},
|
3333
3346
|
map: {},
|
3334
3347
|
rows: {},
|
3348
|
+
zoom: {},
|
3349
|
+
center: {},
|
3335
3350
|
initTotal: {},
|
3336
3351
|
colorAttr: {},
|
3337
3352
|
id: {},
|
@@ -3339,207 +3354,239 @@ const ge = [
|
|
3339
3354
|
history: { type: Boolean }
|
3340
3355
|
},
|
3341
3356
|
emits: ["change:filter", "update:map"],
|
3342
|
-
setup(
|
3343
|
-
var
|
3344
|
-
function
|
3345
|
-
return (
|
3357
|
+
setup(i, { emit: r }) {
|
3358
|
+
var G, ie, ae, Ae, Re, De;
|
3359
|
+
function d(R) {
|
3360
|
+
return (R.type === "Point" ? R.coordinates : null) || (R.type.includes("Multi") ? R.coordinates[0][0][0] : R.coordinates[0][0]);
|
3346
3361
|
}
|
3347
|
-
const l =
|
3348
|
-
n.value = l.initTotal ?? ((
|
3349
|
-
const
|
3350
|
-
function
|
3351
|
-
return Object.entries(
|
3362
|
+
const l = i, a = r, n = V(0);
|
3363
|
+
n.value = l.initTotal ?? ((G = l.rows) == null ? void 0 : G.length) ?? 0;
|
3364
|
+
const m = V(""), h = V(null), g = V(!0), k = V(((ie = l.rows) == null ? void 0 : ie.length) === 1), b = V(0), f = V(l.rows), y = V(1), C = V(20), c = V(l.filters || []), s = V(""), t = V({}), x = V(((ae = l.rows) == null ? void 0 : ae.length) === 1 ? l.rows[0] : {}), v = V(((Ae = l.rows) == null ? void 0 : Ae.length) === 1 ? l.rows[0].id : ""), u = V(((Re = l.rows) == null ? void 0 : Re.length) === 1 ? d(l.rows[0].geom) : l.center || null), _ = V(((De = l.rows) == null ? void 0 : De.length) === 1 ? 14 : l.zoom || 5);
|
3365
|
+
function B(R) {
|
3366
|
+
return Object.entries(R).filter(([, D]) => D).map(([D, ce]) => `${D}=${ce}`).join("|");
|
3352
3367
|
}
|
3353
3368
|
async function M() {
|
3354
|
-
const
|
3355
|
-
|
3369
|
+
const R = B(t.value);
|
3370
|
+
s.value = R;
|
3356
3371
|
try {
|
3357
3372
|
const D = {
|
3358
|
-
search:
|
3373
|
+
search: m.value,
|
3359
3374
|
limit: C.value.toString(),
|
3360
|
-
page:
|
3361
|
-
filter:
|
3362
|
-
}, ce = new URL(`/api/data/${l.table}`, window.location.origin) + (
|
3363
|
-
if (
|
3375
|
+
page: y.value.toString(),
|
3376
|
+
filter: R
|
3377
|
+
}, ce = new URL(`/api/data/${l.table}`, window.location.origin) + (v.value ? `/${v.value}` : ""), Q = new URLSearchParams(D).toString(), pe = await fetch(`${ce.toString()}?${Q}`).then((me) => me.json());
|
3378
|
+
if (v.value) {
|
3364
3379
|
const [me] = pe.rows;
|
3365
|
-
|
3380
|
+
x.value = me, u.value = d(me.geom), _.value = 14, k.value = !0;
|
3366
3381
|
} else
|
3367
|
-
|
3368
|
-
n.value = pe.filtered,
|
3382
|
+
k.value = !1, _.value = l.zoom || 5, f.value = pe == null ? void 0 : pe.rows;
|
3383
|
+
n.value = pe.filtered, ya({ page: y.value, filter: R, id: v.value });
|
3369
3384
|
} catch (D) {
|
3370
3385
|
console.error(D.message);
|
3371
3386
|
}
|
3372
3387
|
}
|
3373
|
-
const
|
3374
|
-
function
|
3375
|
-
C.value =
|
3388
|
+
const L = Ja(M, 300);
|
3389
|
+
function T(R) {
|
3390
|
+
C.value = R, y.value = 1, M();
|
3376
3391
|
}
|
3377
|
-
function
|
3378
|
-
|
3392
|
+
function U(R) {
|
3393
|
+
y.value = R, M();
|
3379
3394
|
}
|
3380
|
-
function
|
3381
|
-
t.value =
|
3395
|
+
function de(R) {
|
3396
|
+
t.value = R.data, y.value = 1, v.value ? v.value = "" : M(), a("change:filter", R);
|
3382
3397
|
}
|
3383
|
-
async function
|
3398
|
+
async function J() {
|
3384
3399
|
if (l.filters) return;
|
3385
3400
|
const D = await (await fetch(`/api/filter/${l.table}`)).json();
|
3386
|
-
|
3401
|
+
c.value = D.list;
|
3387
3402
|
}
|
3388
|
-
function
|
3389
|
-
t.value = {},
|
3403
|
+
function H() {
|
3404
|
+
t.value = {}, m.value = "", M();
|
3390
3405
|
}
|
3391
3406
|
ue(async () => {
|
3392
|
-
|
3393
|
-
const
|
3394
|
-
|
3407
|
+
b.value = window.innerWidth, b.value < 1e3 && (g.value = !1);
|
3408
|
+
const R = new URLSearchParams(window.location.search);
|
3409
|
+
y.value = Number(R.get("page")) || 1, C.value = Number(R.get("limit")) || C.value, v.value = R.get("id") || "", k.value = !!v.value, J(), !f.value && !v.value && M();
|
3395
3410
|
});
|
3396
|
-
function
|
3397
|
-
k.value = !1,
|
3411
|
+
function $() {
|
3412
|
+
k.value = !1, x.value = null, v.value = "", M();
|
3398
3413
|
}
|
3399
|
-
function
|
3400
|
-
|
3414
|
+
function O(R) {
|
3415
|
+
v.value = R.id;
|
3401
3416
|
}
|
3402
|
-
return
|
3403
|
-
|
3404
|
-
}),
|
3405
|
-
|
3406
|
-
}),
|
3417
|
+
return A(h, (R) => {
|
3418
|
+
a("update:map", R);
|
3419
|
+
}), A(m, (R) => {
|
3420
|
+
R || M();
|
3421
|
+
}), A(v, () => {
|
3407
3422
|
M();
|
3408
|
-
}), (
|
3423
|
+
}), (R, D) => {
|
3409
3424
|
var ce;
|
3410
|
-
return
|
3411
|
-
ee(
|
3425
|
+
return p(), w("section", uo, [
|
3426
|
+
ee(R.$slots, "header", {
|
3412
3427
|
title: l.title,
|
3413
3428
|
total: n.value
|
3414
3429
|
}),
|
3415
|
-
|
3430
|
+
o("div", co, [
|
3416
3431
|
P(e(ne), {
|
3417
3432
|
type: "text",
|
3418
|
-
modelValue:
|
3419
|
-
"onUpdate:modelValue": D[0] || (D[0] = (Q) =>
|
3433
|
+
modelValue: m.value,
|
3434
|
+
"onUpdate:modelValue": D[0] || (D[0] = (Q) => m.value = Q),
|
3420
3435
|
name: "search",
|
3421
3436
|
label: "Пошук",
|
3422
|
-
onChange: e(
|
3437
|
+
onChange: e(L)
|
3423
3438
|
}, null, 8, ["modelValue", "onChange"]),
|
3424
|
-
|
3439
|
+
c.value.length ? (p(), z(e(xe), {
|
3425
3440
|
key: 0,
|
3426
|
-
schema:
|
3441
|
+
schema: c.value,
|
3427
3442
|
view: "inline",
|
3428
|
-
onChange:
|
3443
|
+
onChange: de,
|
3429
3444
|
limit: 5,
|
3430
3445
|
value: t.value,
|
3431
3446
|
ref: "filterRef"
|
3432
3447
|
}, null, 8, ["schema", "value"])) : S("", !0),
|
3433
|
-
|
3434
|
-
|
3448
|
+
o("div", po, [
|
3449
|
+
o("button", {
|
3435
3450
|
type: "button",
|
3436
3451
|
class: "map-visible-button py-2 px-2 hidden min-[1001px]:inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",
|
3437
|
-
title:
|
3438
|
-
onClick: D[1] || (D[1] = (Q) =>
|
3452
|
+
title: g.value ? "Приховати карту" : "Показати карту",
|
3453
|
+
onClick: D[1] || (D[1] = (Q) => g.value = !g.value)
|
3439
3454
|
}, [
|
3440
|
-
|
3441
|
-
D[8] || (D[8] =
|
3442
|
-
], 8,
|
3443
|
-
|
3444
|
-
|
3445
|
-
onClick: D[2] || (D[2] = (Q) =>
|
3455
|
+
g.value ? (p(), z(Oa, { key: 0 })) : (p(), z(Ha, { key: 1 })),
|
3456
|
+
D[8] || (D[8] = o("span", { class: "sr-only" }, "Відкрити мапу", -1))
|
3457
|
+
], 8, fo),
|
3458
|
+
o("div", vo, [
|
3459
|
+
o("button", {
|
3460
|
+
onClick: D[2] || (D[2] = (Q) => g.value = !1),
|
3446
3461
|
class: "py-2 px-2 h-[38px] inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100"
|
3447
3462
|
}, [
|
3448
|
-
P(
|
3463
|
+
P(Za)
|
3449
3464
|
]),
|
3450
|
-
|
3451
|
-
onClick: D[3] || (D[3] = (Q) =>
|
3465
|
+
o("button", {
|
3466
|
+
onClick: D[3] || (D[3] = (Q) => g.value = !0),
|
3452
3467
|
class: "py-2 px-2 h-[38px] inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100"
|
3453
3468
|
}, [
|
3454
|
-
P(
|
3469
|
+
P(qa)
|
3455
3470
|
])
|
3456
3471
|
])
|
3457
3472
|
])
|
3458
3473
|
]),
|
3459
|
-
|
3460
|
-
|
3461
|
-
class:
|
3474
|
+
o("div", mo, [
|
3475
|
+
o("div", {
|
3476
|
+
class: j([
|
3462
3477
|
"relative overflow-hidden shrink-0",
|
3463
|
-
|
3478
|
+
g.value ? "w-2/4 mr-0" : "w-full mr-3",
|
3464
3479
|
k.value ? "hidden" : ""
|
3465
3480
|
])
|
3466
3481
|
}, [
|
3467
|
-
(ce =
|
3468
|
-
|
3469
|
-
|
3470
|
-
D[9] || (D[9] =
|
3482
|
+
(ce = R.$slots) != null && ce.header ? S("", !0) : (p(), w("h1", go, [
|
3483
|
+
o("span", ho, K(l.title), 1),
|
3484
|
+
o("span", bo, K(n.value), 1),
|
3485
|
+
D[9] || (D[9] = o("span", { class: "text-sm text-stone-500 font-medium" }, " об'єктів", -1))
|
3471
3486
|
])),
|
3472
|
-
|
3473
|
-
n.value >= 1 ? ee(
|
3487
|
+
o("div", yo, [
|
3488
|
+
n.value >= 1 ? ee(R.$slots, "table", {
|
3474
3489
|
key: 0,
|
3475
|
-
rows:
|
3476
|
-
selectRow:
|
3477
|
-
}) : (
|
3478
|
-
P(
|
3479
|
-
D[10] || (D[10] =
|
3480
|
-
D[11] || (D[11] =
|
3481
|
-
|
3490
|
+
rows: f.value,
|
3491
|
+
selectRow: O
|
3492
|
+
}) : (p(), w("div", xo, [
|
3493
|
+
P(Fa),
|
3494
|
+
D[10] || (D[10] = o("h2", { class: "font-medium text-base text-gray-500 rounded-xl" }, " За вашим запитом даних не знайдено! ", -1)),
|
3495
|
+
D[11] || (D[11] = o("p", { class: "font-normal text-sm text-gray-500 rounded-xl" }, " Введіть, будь ласка, інші значення для пошуку. ", -1)),
|
3496
|
+
o("button", {
|
3482
3497
|
type: "button",
|
3483
3498
|
class: "mt-[10px] py-2 px-2.5 inline-flex items-center gap-x-1.5 text-xs rounded-lg border border-stone-200 bg-white text-stone-800 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100",
|
3484
|
-
onClick:
|
3499
|
+
onClick: H
|
3485
3500
|
}, " Очистити дані пошуку ")
|
3486
3501
|
]))
|
3487
3502
|
]),
|
3488
|
-
n.value >= 1 ? (
|
3489
|
-
n.value >= 1 ? (
|
3490
|
-
|
3491
|
-
P(
|
3503
|
+
n.value >= 1 ? (p(), w("hr", wo)) : S("", !0),
|
3504
|
+
n.value >= 1 ? (p(), w("div", ko, [
|
3505
|
+
o("div", _o, [
|
3506
|
+
P(Ra, {
|
3492
3507
|
total: n.value,
|
3493
|
-
currentPage:
|
3508
|
+
currentPage: y.value ?? 1,
|
3494
3509
|
pageSize: C.value,
|
3495
|
-
onPageChange: D[4] || (D[4] = (Q) =>
|
3496
|
-
onPageSizeChange: D[5] || (D[5] = (Q) =>
|
3510
|
+
onPageChange: D[4] || (D[4] = (Q) => U(Q)),
|
3511
|
+
onPageSizeChange: D[5] || (D[5] = (Q) => T(Q))
|
3497
3512
|
}, null, 8, ["total", "currentPage", "pageSize"])
|
3498
3513
|
])
|
3499
3514
|
])) : S("", !0)
|
3500
3515
|
], 2),
|
3501
|
-
k.value ? (
|
3516
|
+
k.value ? (p(), w("div", {
|
3502
3517
|
key: 0,
|
3503
|
-
class:
|
3504
|
-
|
3518
|
+
class: j(
|
3519
|
+
g.value ? "lg:static lg:w-1/2 mr-0 pb-5" : "pb-5 mr-3"
|
3505
3520
|
),
|
3506
3521
|
style: { height: "calc(100vh - 152px)" }
|
3507
3522
|
}, [
|
3508
|
-
ee(
|
3523
|
+
ee(R.$slots, "details", {
|
3509
3524
|
table: l.table,
|
3510
|
-
selectedRow:
|
3511
|
-
closeObjCard:
|
3525
|
+
selectedRow: x.value,
|
3526
|
+
closeObjCard: $
|
3512
3527
|
})
|
3513
3528
|
], 2)) : S("", !0),
|
3514
|
-
|
3515
|
-
P(
|
3529
|
+
I(o("div", Co, [
|
3530
|
+
P(so, {
|
3516
3531
|
table: l.table,
|
3517
|
-
map:
|
3518
|
-
"onUpdate:map": D[6] || (D[6] = (Q) =>
|
3532
|
+
map: h.value,
|
3533
|
+
"onUpdate:map": D[6] || (D[6] = (Q) => h.value = Q),
|
3534
|
+
zoom: _.value,
|
3519
3535
|
colorAttr: l.colorAttr,
|
3520
|
-
filter:
|
3521
|
-
center:
|
3522
|
-
modelValue:
|
3523
|
-
"onUpdate:modelValue": D[7] || (D[7] = (Q) =>
|
3536
|
+
filter: s.value,
|
3537
|
+
center: u.value,
|
3538
|
+
modelValue: v.value,
|
3539
|
+
"onUpdate:modelValue": D[7] || (D[7] = (Q) => v.value = Q)
|
3524
3540
|
}, {
|
3525
3541
|
default: re(({ hoverData: Q }) => [
|
3526
|
-
ee(
|
3542
|
+
ee(R.$slots, "popup", { data: Q })
|
3527
3543
|
]),
|
3528
3544
|
_: 3
|
3529
|
-
}, 8, ["table", "map", "colorAttr", "filter", "center", "modelValue"]),
|
3530
|
-
ee(
|
3545
|
+
}, 8, ["table", "map", "zoom", "colorAttr", "filter", "center", "modelValue"]),
|
3546
|
+
ee(R.$slots, "default", {
|
3531
3547
|
table: l.table,
|
3532
|
-
map:
|
3533
|
-
selectedRow:
|
3548
|
+
map: h.value,
|
3549
|
+
selectedRow: x.value
|
3534
3550
|
})
|
3535
3551
|
], 512), [
|
3536
|
-
[X,
|
3552
|
+
[X, g.value]
|
3537
3553
|
])
|
3538
3554
|
])
|
3539
3555
|
]);
|
3540
3556
|
};
|
3541
3557
|
}
|
3542
|
-
})
|
3558
|
+
}), Vo = {
|
3559
|
+
mounted(i, r) {
|
3560
|
+
if (typeof document > "u") return;
|
3561
|
+
let d = null;
|
3562
|
+
const l = () => {
|
3563
|
+
d = document.createElement("div"), d.textContent = r.value, Object.assign(d.style, {
|
3564
|
+
position: "absolute",
|
3565
|
+
background: "#333",
|
3566
|
+
color: "#fff",
|
3567
|
+
padding: "4px 8px",
|
3568
|
+
borderRadius: "4px",
|
3569
|
+
fontSize: "12px",
|
3570
|
+
whiteSpace: "nowrap",
|
3571
|
+
pointerEvents: "none",
|
3572
|
+
zIndex: "9999"
|
3573
|
+
}), document.body.appendChild(d);
|
3574
|
+
const n = i.getBoundingClientRect();
|
3575
|
+
d.style.left = `${n.left + window.scrollX}px`, d.style.top = `${n.top + window.scrollY - d.offsetHeight - 5}px`;
|
3576
|
+
}, a = () => {
|
3577
|
+
d && d.parentNode && (d.parentNode.removeChild(d), d = null);
|
3578
|
+
};
|
3579
|
+
i.addEventListener("mouseenter", l), i.addEventListener("mouseleave", a), Object.assign(i, { tooltipHandlers: { showTooltip: l, hideTooltip: a } });
|
3580
|
+
},
|
3581
|
+
unmounted(i) {
|
3582
|
+
if (typeof document > "u") return;
|
3583
|
+
const r = i.tooltipHandlers;
|
3584
|
+
r && (i.removeEventListener("mouseenter", r.showTooltip), i.removeEventListener("mouseleave", r.hideTooltip));
|
3585
|
+
}
|
3586
|
+
};
|
3587
|
+
Le.install = (i) => {
|
3588
|
+
i.component("VsPartsMap", Le), i._context.directives.tooltip || i.directive("tooltip", Vo);
|
3589
|
+
};
|
3543
3590
|
export {
|
3544
|
-
|
3591
|
+
Le as default
|
3545
3592
|
};
|