nicklabs-ui 1.0.71 → 1.0.74
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/README.md +219 -1
- package/dist/index.mjs +1735 -859
- package/dist/nicklabs-ui.css +1 -1
- package/dist/src/components/NAudioSelect.vue.d.ts +27 -0
- package/dist/src/components/NImageSelect.vue.d.ts +27 -0
- package/dist/src/components/NVideoSelect.vue.d.ts +27 -0
- package/dist/src/index.d.ts +10 -1
- package/dist/src/types/components/audioselect.d.ts +13 -0
- package/dist/src/types/components/imageselect.d.ts +14 -0
- package/dist/src/types/components/videoselect.d.ts +15 -0
- package/package.json +1 -1
package/dist/index.mjs
CHANGED
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { Fragment as e, Teleport as t, Transition as n, TransitionGroup as r, computed as i, createBlock as a, createCommentVNode as o, createElementBlock as s, createElementVNode as c, createSlots as l, createStaticVNode as u, createTextVNode as d, createVNode as f, defineComponent as p,
|
|
1
|
+
import { Fragment as e, Teleport as t, Transition as n, TransitionGroup as r, computed as i, createBlock as a, createCommentVNode as o, createElementBlock as s, createElementVNode as c, createSlots as l, createStaticVNode as u, createTextVNode as d, createVNode as f, defineComponent as p, mergeProps as m, nextTick as h, normalizeClass as g, normalizeStyle as _, onBeforeUnmount as v, onMounted as y, onUnmounted as b, openBlock as x, reactive as S, ref as C, renderList as w, renderSlot as T, toDisplayString as E, unref as D, useCssVars as O, vModelText as k, watch as A, withCtx as j, withDirectives as M, withModifiers as N } from "vue";
|
|
2
2
|
//#region src/composables/sharedRouter.ts
|
|
3
|
-
var
|
|
4
|
-
function
|
|
5
|
-
|
|
3
|
+
var P = null;
|
|
4
|
+
function ee(e) {
|
|
5
|
+
P = e;
|
|
6
6
|
}
|
|
7
|
-
function
|
|
8
|
-
return
|
|
7
|
+
function F() {
|
|
8
|
+
return P;
|
|
9
9
|
}
|
|
10
10
|
//#endregion
|
|
11
11
|
//#region src/components/NButton.vue?vue&type=script&setup=true&lang.ts
|
|
12
|
-
var
|
|
12
|
+
var I = ["type", "disabled"], L = {
|
|
13
13
|
key: 0,
|
|
14
14
|
class: "spinner",
|
|
15
15
|
viewBox: "0 0 24 24",
|
|
16
16
|
fill: "none",
|
|
17
17
|
xmlns: "http://www.w3.org/2000/svg"
|
|
18
|
-
},
|
|
18
|
+
}, te = /* @__PURE__ */ p({
|
|
19
19
|
__name: "NButton",
|
|
20
20
|
props: {
|
|
21
21
|
variant: { default: "none" },
|
|
@@ -40,7 +40,7 @@ var ae = ["type", "disabled"], oe = {
|
|
|
40
40
|
}
|
|
41
41
|
},
|
|
42
42
|
setup(e) {
|
|
43
|
-
|
|
43
|
+
O((e) => ({
|
|
44
44
|
v3887cfe2: n.value,
|
|
45
45
|
e00c4f48: e.width,
|
|
46
46
|
v55723951: e.height
|
|
@@ -50,8 +50,8 @@ var ae = ["type", "disabled"], oe = {
|
|
|
50
50
|
md: "6px 14px",
|
|
51
51
|
lg: "8px 18px"
|
|
52
52
|
}, n = i(() => e.padding ?? t[e.size]);
|
|
53
|
-
return (t, n) => (
|
|
54
|
-
class:
|
|
53
|
+
return (t, n) => (x(), s("button", {
|
|
54
|
+
class: g([
|
|
55
55
|
`variant-${e.variant}`,
|
|
56
56
|
`intent-${e.intent}`,
|
|
57
57
|
`radiusSize-${e.radiusSize}`,
|
|
@@ -63,7 +63,7 @@ var ae = ["type", "disabled"], oe = {
|
|
|
63
63
|
]),
|
|
64
64
|
type: e.type,
|
|
65
65
|
disabled: e.disabled || e.loading
|
|
66
|
-
}, [e.loading ? (
|
|
66
|
+
}, [e.loading ? (x(), s("svg", L, [...n[0] ||= [c("circle", {
|
|
67
67
|
cx: "12",
|
|
68
68
|
cy: "12",
|
|
69
69
|
r: "10",
|
|
@@ -72,39 +72,39 @@ var ae = ["type", "disabled"], oe = {
|
|
|
72
72
|
"stroke-linecap": "round",
|
|
73
73
|
"stroke-dasharray": "32",
|
|
74
74
|
"stroke-dashoffset": "12"
|
|
75
|
-
}, null, -1)]])) : o("", !0),
|
|
75
|
+
}, null, -1)]])) : o("", !0), T(t.$slots, "default", {}, void 0, !0)], 10, I));
|
|
76
76
|
}
|
|
77
|
-
}),
|
|
77
|
+
}), R = (e, t) => {
|
|
78
78
|
let n = e.__vccOpts || e;
|
|
79
79
|
for (let [e, r] of t) n[e] = r;
|
|
80
80
|
return n;
|
|
81
|
-
},
|
|
82
|
-
function
|
|
81
|
+
}, z = /* @__PURE__ */ R(te, [["__scopeId", "data-v-285afe14"]]), B = (e) => e.meta?.breadcrumb ?? "", V = C((e) => e);
|
|
82
|
+
function H() {
|
|
83
83
|
function e(e) {
|
|
84
|
-
|
|
84
|
+
B = e;
|
|
85
85
|
}
|
|
86
86
|
function t(e) {
|
|
87
|
-
|
|
87
|
+
V.value = e;
|
|
88
88
|
}
|
|
89
89
|
let n = i(() => {
|
|
90
|
-
let e =
|
|
90
|
+
let e = F();
|
|
91
91
|
if (!e) return [];
|
|
92
92
|
let t = e.currentRoute.value.matched, n = [];
|
|
93
93
|
return t.forEach((e, r) => {
|
|
94
|
-
let i =
|
|
94
|
+
let i = B(e);
|
|
95
95
|
if (!i) return;
|
|
96
96
|
let a = r === t.length - 1;
|
|
97
97
|
n.push({
|
|
98
|
-
label: a ?
|
|
98
|
+
label: a ? V.value(i) : i,
|
|
99
99
|
path: a ? void 0 : e.path
|
|
100
100
|
});
|
|
101
101
|
}), n;
|
|
102
102
|
});
|
|
103
103
|
function r(e) {
|
|
104
|
-
|
|
104
|
+
F()?.push(e);
|
|
105
105
|
}
|
|
106
106
|
function a() {
|
|
107
|
-
|
|
107
|
+
V.value = (e) => e;
|
|
108
108
|
}
|
|
109
109
|
return {
|
|
110
110
|
breadcrumbs: n,
|
|
@@ -116,23 +116,23 @@ function F() {
|
|
|
116
116
|
}
|
|
117
117
|
//#endregion
|
|
118
118
|
//#region src/components/NBreadcrumb.vue?vue&type=script&setup=true&lang.ts
|
|
119
|
-
var
|
|
119
|
+
var U = { class: "breadcrumbs" }, W = ["onClick"], ne = {
|
|
120
120
|
key: 1,
|
|
121
121
|
class: "active"
|
|
122
|
-
},
|
|
122
|
+
}, re = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
123
123
|
__name: "NBreadcrumb",
|
|
124
124
|
setup(t) {
|
|
125
|
-
let { breadcrumbs: n, navigate: r } =
|
|
126
|
-
return (t, i) => (
|
|
125
|
+
let { breadcrumbs: n, navigate: r } = H();
|
|
126
|
+
return (t, i) => (x(), s("nav", U, [(x(!0), s(e, null, w(D(n), (t, n) => (x(), s(e, { key: n }, [t.path ? (x(), s("span", {
|
|
127
127
|
key: 0,
|
|
128
128
|
class: "crumb-link",
|
|
129
|
-
onClick: (e) =>
|
|
130
|
-
},
|
|
129
|
+
onClick: (e) => D(r)(t.path)
|
|
130
|
+
}, E(t.label), 9, W)) : (x(), s("span", ne, E(t.label), 1))], 64))), 128))]));
|
|
131
131
|
}
|
|
132
|
-
}), [["__scopeId", "data-v-46f3b63f"]]),
|
|
132
|
+
}), [["__scopeId", "data-v-46f3b63f"]]), G = {
|
|
133
133
|
key: 0,
|
|
134
134
|
class: "label"
|
|
135
|
-
},
|
|
135
|
+
}, ie = ["disabled"], ae = [
|
|
136
136
|
"type",
|
|
137
137
|
"placeholder",
|
|
138
138
|
"disabled",
|
|
@@ -140,10 +140,10 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
140
140
|
"value",
|
|
141
141
|
"maxlength",
|
|
142
142
|
"autocomplete"
|
|
143
|
-
],
|
|
143
|
+
], oe = ["disabled"], se = {
|
|
144
144
|
key: 2,
|
|
145
145
|
class: "actions"
|
|
146
|
-
},
|
|
146
|
+
}, ce = {
|
|
147
147
|
key: 0,
|
|
148
148
|
xmlns: "http://www.w3.org/2000/svg",
|
|
149
149
|
width: "16",
|
|
@@ -154,7 +154,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
154
154
|
"stroke-width": "2",
|
|
155
155
|
"stroke-linecap": "round",
|
|
156
156
|
"stroke-linejoin": "round"
|
|
157
|
-
},
|
|
157
|
+
}, le = {
|
|
158
158
|
key: 1,
|
|
159
159
|
xmlns: "http://www.w3.org/2000/svg",
|
|
160
160
|
width: "16",
|
|
@@ -165,7 +165,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
165
165
|
"stroke-width": "2",
|
|
166
166
|
"stroke-linecap": "round",
|
|
167
167
|
"stroke-linejoin": "round"
|
|
168
|
-
},
|
|
168
|
+
}, ue = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
169
169
|
__name: "NInput",
|
|
170
170
|
props: {
|
|
171
171
|
modelValue: { default: "" },
|
|
@@ -203,8 +203,8 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
203
203
|
"clear"
|
|
204
204
|
],
|
|
205
205
|
setup(e, { emit: t }) {
|
|
206
|
-
|
|
207
|
-
let n = t, r = i(() => e.type === "password"), a = i(() => e.type === "number"), l =
|
|
206
|
+
O((e) => ({ v446bddee: d.value }));
|
|
207
|
+
let n = t, r = i(() => e.type === "password"), a = i(() => e.type === "number"), l = C(!1), u = i(() => a.value ? "text" : r.value ? l.value ? "text" : "password" : e.type), d = i(() => {
|
|
208
208
|
let t = 12;
|
|
209
209
|
return r.value && (t += 24), e.clearable && (t += 24), `${t}px`;
|
|
210
210
|
}), f = (t) => {
|
|
@@ -220,10 +220,10 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
220
220
|
"Tab",
|
|
221
221
|
"Home",
|
|
222
222
|
"End"
|
|
223
|
-
].includes(e.key) || e.ctrlKey || e.metaKey || /^[0-9]$/.test(e.key)),
|
|
223
|
+
].includes(e.key) || e.ctrlKey || e.metaKey || /^[0-9]$/.test(e.key)), h = (e) => {
|
|
224
224
|
if (n("keydown", e), a.value) {
|
|
225
225
|
if (e.key === "ArrowUp") {
|
|
226
|
-
e.preventDefault(),
|
|
226
|
+
e.preventDefault(), w();
|
|
227
227
|
return;
|
|
228
228
|
}
|
|
229
229
|
if (e.key === "ArrowDown") {
|
|
@@ -235,12 +235,12 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
235
235
|
return;
|
|
236
236
|
}
|
|
237
237
|
}
|
|
238
|
-
},
|
|
238
|
+
}, _ = (e) => {
|
|
239
239
|
if (a.value) {
|
|
240
240
|
let t = e.target, r = f(t.value);
|
|
241
241
|
t.value !== r && (t.value = r), n("update:modelValue", p(r));
|
|
242
242
|
}
|
|
243
|
-
},
|
|
243
|
+
}, v = (e) => {
|
|
244
244
|
n("input", e);
|
|
245
245
|
let t = e.target;
|
|
246
246
|
if (a.value) {
|
|
@@ -249,7 +249,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
249
249
|
return;
|
|
250
250
|
}
|
|
251
251
|
n("update:modelValue", t.value);
|
|
252
|
-
},
|
|
252
|
+
}, y = (t) => {
|
|
253
253
|
n("blur", t), a.value && e.modelValue === "" && n("update:modelValue", e.min === -Infinity ? 0 : e.min);
|
|
254
254
|
}, b = () => {
|
|
255
255
|
e.disabled || e.readonly || (n("update:modelValue", ""), n("clear"));
|
|
@@ -261,7 +261,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
261
261
|
return;
|
|
262
262
|
}
|
|
263
263
|
n("update:modelValue", e.min);
|
|
264
|
-
},
|
|
264
|
+
}, w = () => {
|
|
265
265
|
if (e.disabled) return;
|
|
266
266
|
let t = e.modelValue === "" ? e.min : Number(e.modelValue), r = Math.min(t + 1, e.max);
|
|
267
267
|
if (e.min <= r && r <= e.max) {
|
|
@@ -270,13 +270,13 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
270
270
|
}
|
|
271
271
|
n("update:modelValue", e.min);
|
|
272
272
|
}, T = () => l.value = !l.value;
|
|
273
|
-
return (t, i) => (
|
|
273
|
+
return (t, i) => (x(), s("div", { class: g(["input", { inline: e.inline }]) }, [e.title ? (x(), s("label", G, E(e.title), 1)) : o("", !0), c("div", { class: g({
|
|
274
274
|
common: !a.value,
|
|
275
275
|
number: a.value,
|
|
276
276
|
disabled: e.disabled,
|
|
277
277
|
readonly: e.readonly
|
|
278
278
|
}) }, [
|
|
279
|
-
a.value ? (
|
|
279
|
+
a.value ? (x(), s("button", {
|
|
280
280
|
key: 0,
|
|
281
281
|
class: "tool-button",
|
|
282
282
|
type: "button",
|
|
@@ -292,7 +292,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
292
292
|
"stroke-width": "2",
|
|
293
293
|
"stroke-linecap": "round",
|
|
294
294
|
"stroke-linejoin": "round"
|
|
295
|
-
}, [c("path", { d: "M5 12h14" })], -1)]], 8,
|
|
295
|
+
}, [c("path", { d: "M5 12h14" })], -1)]], 8, ie)) : o("", !0),
|
|
296
296
|
c("input", {
|
|
297
297
|
type: u.value,
|
|
298
298
|
placeholder: e.placeholder,
|
|
@@ -302,18 +302,18 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
302
302
|
maxlength: e.maxlength,
|
|
303
303
|
autocomplete: e.autocomplete,
|
|
304
304
|
onFocus: i[0] ||= (e) => n("focus", e),
|
|
305
|
-
onBlur:
|
|
306
|
-
onInput:
|
|
305
|
+
onBlur: y,
|
|
306
|
+
onInput: v,
|
|
307
307
|
onChange: i[1] ||= (e) => n("change", e),
|
|
308
|
-
onKeydown:
|
|
309
|
-
onCompositionend:
|
|
310
|
-
}, null, 40,
|
|
311
|
-
a.value ? (
|
|
308
|
+
onKeydown: h,
|
|
309
|
+
onCompositionend: _
|
|
310
|
+
}, null, 40, ae),
|
|
311
|
+
a.value ? (x(), s("button", {
|
|
312
312
|
key: 1,
|
|
313
313
|
class: "tool-button",
|
|
314
314
|
type: "button",
|
|
315
315
|
disabled: e.disabled || Number(e.modelValue) >= e.max,
|
|
316
|
-
onClick:
|
|
316
|
+
onClick: w
|
|
317
317
|
}, [...i[3] ||= [c("svg", {
|
|
318
318
|
xmlns: "http://www.w3.org/2000/svg",
|
|
319
319
|
width: "16",
|
|
@@ -324,22 +324,22 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
324
324
|
"stroke-width": "2",
|
|
325
325
|
"stroke-linecap": "round",
|
|
326
326
|
"stroke-linejoin": "round"
|
|
327
|
-
}, [c("path", { d: "M5 12h14" }), c("path", { d: "M12 5v14" })], -1)]], 8,
|
|
328
|
-
a.value ? o("", !0) : (
|
|
327
|
+
}, [c("path", { d: "M5 12h14" }), c("path", { d: "M12 5v14" })], -1)]], 8, oe)) : o("", !0),
|
|
328
|
+
a.value ? o("", !0) : (x(), s("div", se, [r.value && !e.disabled ? (x(), s("button", {
|
|
329
329
|
key: 0,
|
|
330
330
|
type: "button",
|
|
331
331
|
onClick: T,
|
|
332
332
|
"aria-label": "Toggle password visibility"
|
|
333
|
-
}, [l.value ? (
|
|
333
|
+
}, [l.value ? (x(), s("svg", le, [...i[5] ||= [
|
|
334
334
|
c("path", { d: "M10.733 5.076a10.744 10.744 0 0 1 11.205 6.575 1 1 0 0 1 0 .696 10.747 10.747 0 0 1-1.444 2.49" }, null, -1),
|
|
335
335
|
c("path", { d: "M14.084 14.158a3 3 0 0 1-4.242-4.242" }, null, -1),
|
|
336
336
|
c("path", { d: "M17.479 17.499a10.75 10.75 0 0 1-15.417-5.151 1 1 0 0 1 0-.696 10.75 10.75 0 0 1 4.446-5.143" }, null, -1),
|
|
337
337
|
c("path", { d: "m2 2 20 20" }, null, -1)
|
|
338
|
-
]])) : (
|
|
338
|
+
]])) : (x(), s("svg", ce, [...i[4] ||= [c("path", { d: "M2.062 12.348a1 1 0 0 1 0-.696 10.75 10.75 0 0 1 19.876 0 1 1 0 0 1 0 .696 10.75 10.75 0 0 1-19.876 0" }, null, -1), c("circle", {
|
|
339
339
|
cx: "12",
|
|
340
340
|
cy: "12",
|
|
341
341
|
r: "3"
|
|
342
|
-
}, null, -1)]]))])) : o("", !0), e.clearable && `${e.modelValue}`.length > 0 && !e.disabled ? (
|
|
342
|
+
}, null, -1)]]))])) : o("", !0), e.clearable && `${e.modelValue}`.length > 0 && !e.disabled ? (x(), s("button", {
|
|
343
343
|
key: 1,
|
|
344
344
|
type: "button",
|
|
345
345
|
"aria-label": "Clear input",
|
|
@@ -357,7 +357,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
357
357
|
}, [c("path", { d: "M18 6 6 18" }), c("path", { d: "m6 6 12 12" })], -1)]])) : o("", !0)]))
|
|
358
358
|
], 2)], 2));
|
|
359
359
|
}
|
|
360
|
-
}), [["__scopeId", "data-v-91e7a17e"]]),
|
|
360
|
+
}), [["__scopeId", "data-v-91e7a17e"]]), de = { class: "textarea" }, fe = ["textContent"], pe = [
|
|
361
361
|
"rows",
|
|
362
362
|
"placeholder",
|
|
363
363
|
"disabled",
|
|
@@ -366,10 +366,10 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
366
366
|
"maxlength",
|
|
367
367
|
"autocomplete",
|
|
368
368
|
"wrap"
|
|
369
|
-
],
|
|
369
|
+
], me = {
|
|
370
370
|
key: 1,
|
|
371
371
|
class: "char-count"
|
|
372
|
-
},
|
|
372
|
+
}, he = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
373
373
|
__name: "NTextarea",
|
|
374
374
|
props: {
|
|
375
375
|
modelValue: { default: "" },
|
|
@@ -406,7 +406,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
406
406
|
"paste"
|
|
407
407
|
],
|
|
408
408
|
setup(e, { emit: t }) {
|
|
409
|
-
let n = t, r =
|
|
409
|
+
let n = t, r = C(null), a = i(() => {
|
|
410
410
|
let t = Number(e.maxLength);
|
|
411
411
|
return Number.isFinite(t) && t > 0 ? t : void 0;
|
|
412
412
|
}), l = i(() => a.value !== void 0), u = i(() => {
|
|
@@ -417,14 +417,14 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
417
417
|
let t = e.target;
|
|
418
418
|
n("update:modelValue", t.value);
|
|
419
419
|
};
|
|
420
|
-
return
|
|
420
|
+
return y(() => {
|
|
421
421
|
e.autofocus && r.value?.focus();
|
|
422
|
-
}), (t, i) => (
|
|
423
|
-
e.title ? (
|
|
422
|
+
}), (t, i) => (x(), s("div", de, [
|
|
423
|
+
e.title ? (x(), s("label", {
|
|
424
424
|
key: 0,
|
|
425
425
|
class: "label",
|
|
426
|
-
textContent:
|
|
427
|
-
}, null, 8,
|
|
426
|
+
textContent: E(e.title)
|
|
427
|
+
}, null, 8, fe)) : o("", !0),
|
|
428
428
|
c("textarea", {
|
|
429
429
|
ref_key: "textareaRef",
|
|
430
430
|
ref: r,
|
|
@@ -443,17 +443,17 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
443
443
|
onChange: i[2] ||= (e) => n("change", e),
|
|
444
444
|
onKeydown: i[3] ||= (e) => n("keydown", e),
|
|
445
445
|
onPaste: i[4] ||= (e) => n("paste", e)
|
|
446
|
-
}, null, 40,
|
|
447
|
-
e.showCount ? (
|
|
446
|
+
}, null, 40, pe),
|
|
447
|
+
e.showCount ? (x(), s("div", me, E(u.value), 1)) : o("", !0)
|
|
448
448
|
]));
|
|
449
449
|
}
|
|
450
|
-
}), [["__scopeId", "data-v-03ad19c3"]]),
|
|
450
|
+
}), [["__scopeId", "data-v-03ad19c3"]]), ge = {
|
|
451
451
|
key: 0,
|
|
452
452
|
class: "label"
|
|
453
|
-
},
|
|
453
|
+
}, _e = ["onClick"], ve = ["checked", "disabled"], ye = { class: "text" }, be = ["checked", "disabled"], K = {
|
|
454
454
|
key: 0,
|
|
455
455
|
class: "text"
|
|
456
|
-
},
|
|
456
|
+
}, xe = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
457
457
|
__name: "NCheckbox",
|
|
458
458
|
props: {
|
|
459
459
|
modelValue: { default: !1 },
|
|
@@ -498,7 +498,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
498
498
|
"change:values"
|
|
499
499
|
],
|
|
500
500
|
setup(t, { emit: n }) {
|
|
501
|
-
let r = n, a =
|
|
501
|
+
let r = n, a = C(null), l = i(() => !t.options || t.options.length === 0), u = i(() => !!t.multiple), f = i(() => Array.isArray(t.options) && t.options.length > 0), p = i(() => f.value ? Array.isArray(t.modelValue) ? t.modelValue : [t.modelValue] : []), m = (e) => p.value.some((t) => t === e), h = (e) => {
|
|
502
502
|
if (t.disabled) return;
|
|
503
503
|
if (l.value && !f.value) {
|
|
504
504
|
if (!t.allowDeselect && t.modelValue) return;
|
|
@@ -515,18 +515,18 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
515
515
|
} else n = t.formatValue(e);
|
|
516
516
|
r("update:modelValue", n), r("change", n), r("change:item", e), r("change:value", n), r("change:values", n);
|
|
517
517
|
};
|
|
518
|
-
return
|
|
518
|
+
return y(() => {
|
|
519
519
|
t.autofocus || a.value?.focus();
|
|
520
|
-
}), (n, r) => (
|
|
520
|
+
}), (n, r) => (x(), s("div", { class: g(["checkbox", { inline: t.inline }]) }, [t.title ? (x(), s("h3", ge, E(t.title), 1)) : o("", !0), c("div", { class: g(["group", [t.direction]]) }, [l.value ? (x(), s("label", {
|
|
521
521
|
key: 1,
|
|
522
522
|
class: "item",
|
|
523
|
-
onClick: r[0] ||=
|
|
523
|
+
onClick: r[0] ||= N((e) => h(), ["prevent"])
|
|
524
524
|
}, [
|
|
525
525
|
c("input", {
|
|
526
526
|
type: "checkbox",
|
|
527
527
|
checked: !!t.modelValue,
|
|
528
528
|
disabled: t.disabled
|
|
529
|
-
}, null, 8,
|
|
529
|
+
}, null, 8, be),
|
|
530
530
|
r[2] ||= c("span", { class: "icon" }, [c("svg", {
|
|
531
531
|
xmlns: "http://www.w3.org/2000/svg",
|
|
532
532
|
width: "24",
|
|
@@ -538,18 +538,18 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
538
538
|
"stroke-linecap": "round",
|
|
539
539
|
"stroke-linejoin": "round"
|
|
540
540
|
}, [c("path", { d: "M20 6 9 17l-5-5" })])], -1),
|
|
541
|
-
n.$slots.default || t.label ? (
|
|
542
|
-
])) : (
|
|
541
|
+
n.$slots.default || t.label ? (x(), s("span", K, [T(n.$slots, "default", {}, () => [d(E(t.label), 1)], !0)])) : o("", !0)
|
|
542
|
+
])) : (x(!0), s(e, { key: 0 }, w(t.options, (e, n) => (x(), s("label", {
|
|
543
543
|
key: `${t.formatLabel(e)}${n}`,
|
|
544
544
|
class: "item",
|
|
545
|
-
onClick:
|
|
545
|
+
onClick: N((t) => h(e), ["prevent"])
|
|
546
546
|
}, [
|
|
547
547
|
c("input", {
|
|
548
548
|
type: "checkbox",
|
|
549
549
|
checked: m(t.formatValue(e)),
|
|
550
550
|
disabled: t.disabled
|
|
551
|
-
}, null, 8,
|
|
552
|
-
c("span", { class:
|
|
551
|
+
}, null, 8, ve),
|
|
552
|
+
c("span", { class: g(["icon", { radio: !t.multiple }]) }, [...r[1] ||= [c("svg", {
|
|
553
553
|
xmlns: "http://www.w3.org/2000/svg",
|
|
554
554
|
width: "24",
|
|
555
555
|
height: "24",
|
|
@@ -560,16 +560,16 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
560
560
|
"stroke-linecap": "round",
|
|
561
561
|
"stroke-linejoin": "round"
|
|
562
562
|
}, [c("path", { d: "M20 6 9 17l-5-5" })], -1)]], 2),
|
|
563
|
-
c("span",
|
|
564
|
-
], 8,
|
|
563
|
+
c("span", ye, E(t.formatLabel(e)), 1)
|
|
564
|
+
], 8, _e))), 128))], 2)], 2));
|
|
565
565
|
}
|
|
566
|
-
}), [["__scopeId", "data-v-1f6a325a"]]),
|
|
566
|
+
}), [["__scopeId", "data-v-1f6a325a"]]), Se = { class: "select" }, q = {
|
|
567
567
|
key: 0,
|
|
568
568
|
class: "label"
|
|
569
|
-
},
|
|
569
|
+
}, J = { class: "select-chips-container" }, Y = ["textContent"], X = ["onClick"], Z = {
|
|
570
570
|
key: 0,
|
|
571
571
|
class: "search-box"
|
|
572
|
-
},
|
|
572
|
+
}, Ce = { class: "options" }, we = ["onClick"], Te = {
|
|
573
573
|
key: 0,
|
|
574
574
|
xmlns: "http://www.w3.org/2000/svg",
|
|
575
575
|
width: "14",
|
|
@@ -580,10 +580,10 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
580
580
|
"stroke-width": "2.5",
|
|
581
581
|
"stroke-linecap": "round",
|
|
582
582
|
"stroke-linejoin": "round"
|
|
583
|
-
},
|
|
583
|
+
}, Ee = {
|
|
584
584
|
key: 0,
|
|
585
585
|
class: "empty"
|
|
586
|
-
},
|
|
586
|
+
}, De = 240, Oe = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
587
587
|
__name: "NSelect",
|
|
588
588
|
props: {
|
|
589
589
|
modelValue: { default: () => void 0 },
|
|
@@ -624,67 +624,67 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
624
624
|
"change:values"
|
|
625
625
|
],
|
|
626
626
|
setup(t, { emit: n }) {
|
|
627
|
-
let r = n, a =
|
|
627
|
+
let r = n, a = C(!1), l = C(""), u = C(!1), d = C(null), f = C(null), p = i(() => {
|
|
628
628
|
let e = {};
|
|
629
629
|
return t.multiple ? Array.isArray(t.modelValue) && t.modelValue.forEach((n) => {
|
|
630
630
|
e[n] = t.options.find((e) => t.formatValue(e) === n);
|
|
631
631
|
}) : t.modelValue !== void 0 && t.modelValue !== null && !Array.isArray(t.modelValue) && (e[t.modelValue] = t.options.find((e) => t.formatValue(e) === t.modelValue)), e;
|
|
632
|
-
}),
|
|
632
|
+
}), m = i(() => Object.keys(p.value).length > 0), _ = async () => {
|
|
633
633
|
if (!t.disabled && (a.value = !a.value, a.value)) {
|
|
634
|
-
if (await
|
|
634
|
+
if (await h(), d.value) {
|
|
635
635
|
let e = d.value.getBoundingClientRect();
|
|
636
|
-
u.value = window.innerHeight - e.bottom <
|
|
636
|
+
u.value = window.innerHeight - e.bottom < De;
|
|
637
637
|
}
|
|
638
638
|
t.searchable && f.value?.focus();
|
|
639
639
|
}
|
|
640
640
|
}, b = () => {
|
|
641
641
|
a.value = !1, l.value = "";
|
|
642
|
-
},
|
|
642
|
+
}, S = (e) => {
|
|
643
643
|
if (!a.value) return;
|
|
644
644
|
let t = e.target;
|
|
645
645
|
d.value && !d.value.contains(t) && b();
|
|
646
|
-
}, T = (e) => p.value.hasOwnProperty(e),
|
|
646
|
+
}, T = (e) => p.value.hasOwnProperty(e), D = (e) => {
|
|
647
647
|
if (t.disabled) return;
|
|
648
648
|
let n;
|
|
649
649
|
t.multiple ? (T(t.formatValue(e)) ? delete p.value[t.formatValue(e)] : p.value[t.formatValue(e)] = e, n = Object.keys(p.value), r("update:modelValue", n), r("change", n), r("change:item", e), r("change:value", n), r("change:values", n)) : (n = t.formatValue(e), r("update:modelValue", n), r("change", n), r("change:item", e), r("change:value", n), b());
|
|
650
|
-
},
|
|
650
|
+
}, O = () => {
|
|
651
651
|
if (t.disabled) return;
|
|
652
652
|
let e = t.multiple ? [] : void 0;
|
|
653
653
|
r("update:modelValue", e), r("change", e), r("change:value", e), r("change:values", []);
|
|
654
|
-
},
|
|
654
|
+
}, A = i(() => {
|
|
655
655
|
let e = l.value.trim().toLowerCase();
|
|
656
656
|
return e ? t.options.filter((n) => String(t.formatLabel(n)).toLowerCase().includes(e)) : t.options;
|
|
657
657
|
});
|
|
658
|
-
|
|
659
|
-
document.addEventListener("pointerdown",
|
|
660
|
-
}),
|
|
661
|
-
document.removeEventListener("pointerdown",
|
|
658
|
+
y(() => {
|
|
659
|
+
document.addEventListener("pointerdown", S);
|
|
660
|
+
}), v(() => {
|
|
661
|
+
document.removeEventListener("pointerdown", S);
|
|
662
662
|
});
|
|
663
|
-
let
|
|
663
|
+
let j = i(() => {
|
|
664
664
|
let e = Object.keys(p.value), n = e.length;
|
|
665
665
|
return n === 0 ? "" : t.multiple ? `已選 ${n} 項` : t.formatLabel(p.value[e[0]]) ?? "";
|
|
666
666
|
});
|
|
667
|
-
return (n, r) => (
|
|
667
|
+
return (n, r) => (x(), s("div", Se, [t.title ? (x(), s("label", q, E(t.title), 1)) : o("", !0), c("div", {
|
|
668
668
|
ref_key: "selectGroupRef",
|
|
669
669
|
ref: d,
|
|
670
|
-
class:
|
|
670
|
+
class: g(["group", {
|
|
671
671
|
open: a.value,
|
|
672
672
|
multiple: t.multiple
|
|
673
673
|
}])
|
|
674
674
|
}, [c("div", {
|
|
675
|
-
class:
|
|
676
|
-
onClick:
|
|
675
|
+
class: g(["trigger", { disabled: t.disabled }]),
|
|
676
|
+
onClick: _
|
|
677
677
|
}, [
|
|
678
|
-
c("div",
|
|
678
|
+
c("div", J, [!m.value || !t.multiple || t.multiple && t.multipleDisplay === "count" ? (x(), s("span", {
|
|
679
679
|
key: 0,
|
|
680
|
-
class:
|
|
681
|
-
textContent:
|
|
682
|
-
}, null, 10,
|
|
680
|
+
class: g(["trigger-text", { placeholder: !m.value }]),
|
|
681
|
+
textContent: E(m.value ? j.value : t.placeholder)
|
|
682
|
+
}, null, 10, Y)) : o("", !0), t.multiple && t.multipleDisplay === "tags" ? (x(!0), s(e, { key: 1 }, w(p.value, (e, n) => (x(), s("div", {
|
|
683
683
|
key: `${t.formatLabel(e)}${n}`,
|
|
684
684
|
class: "select-chip"
|
|
685
|
-
}, [c("span", null,
|
|
685
|
+
}, [c("span", null, E(t.formatLabel(e)), 1), c("span", {
|
|
686
686
|
class: "remove-chip",
|
|
687
|
-
onClick:
|
|
687
|
+
onClick: N((t) => D(e), ["stop"])
|
|
688
688
|
}, [...r[1] ||= [c("svg", {
|
|
689
689
|
xmlns: "http://www.w3.org/2000/svg",
|
|
690
690
|
width: "14",
|
|
@@ -695,12 +695,12 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
695
695
|
"stroke-width": "2",
|
|
696
696
|
"stroke-linecap": "round",
|
|
697
697
|
"stroke-linejoin": "round"
|
|
698
|
-
}, [c("path", { d: "M18 6 6 18" }), c("path", { d: "m6 6 12 12" })], -1)]], 8,
|
|
699
|
-
t.clearable &&
|
|
698
|
+
}, [c("path", { d: "M18 6 6 18" }), c("path", { d: "m6 6 12 12" })], -1)]], 8, X)]))), 128)) : o("", !0)]),
|
|
699
|
+
t.clearable && m.value && !t.disabled ? (x(), s("button", {
|
|
700
700
|
key: 0,
|
|
701
701
|
class: "clear-btn",
|
|
702
702
|
type: "button",
|
|
703
|
-
onClick: O
|
|
703
|
+
onClick: N(O, ["stop"])
|
|
704
704
|
}, [...r[2] ||= [c("svg", {
|
|
705
705
|
xmlns: "http://www.w3.org/2000/svg",
|
|
706
706
|
width: "14",
|
|
@@ -724,7 +724,7 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
724
724
|
"stroke-linejoin": "round",
|
|
725
725
|
class: "arrow-icon"
|
|
726
726
|
}, [c("path", { d: "m6 10 6 6 6-6" })], -1)
|
|
727
|
-
], 2), c("div", { class:
|
|
727
|
+
], 2), c("div", { class: g(["dropdown", { upward: u.value }]) }, [t.searchable ? (x(), s("div", Z, [r[4] ||= c("svg", {
|
|
728
728
|
xmlns: "http://www.w3.org/2000/svg",
|
|
729
729
|
width: "14",
|
|
730
730
|
height: "14",
|
|
@@ -739,59 +739,59 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
739
739
|
cx: "11",
|
|
740
740
|
cy: "11",
|
|
741
741
|
r: "8"
|
|
742
|
-
})], -1),
|
|
742
|
+
})], -1), M(c("input", {
|
|
743
743
|
ref_key: "searchInputRef",
|
|
744
744
|
ref: f,
|
|
745
745
|
type: "text",
|
|
746
746
|
class: "search-input",
|
|
747
747
|
placeholder: "Search...",
|
|
748
748
|
"onUpdate:modelValue": r[0] ||= (e) => l.value = e
|
|
749
|
-
}, null, 512), [[
|
|
749
|
+
}, null, 512), [[k, l.value]])])) : o("", !0), c("div", Ce, [(x(!0), s(e, null, w(A.value, (e, n) => (x(), s("div", {
|
|
750
750
|
key: `${t.formatLabel(e)}${n}`,
|
|
751
|
-
class:
|
|
752
|
-
onClick: (t) =>
|
|
753
|
-
}, [c("span", null,
|
|
751
|
+
class: g(["option", { selected: T(t.formatValue(e)) }]),
|
|
752
|
+
onClick: (t) => D(e)
|
|
753
|
+
}, [c("span", null, E(t.formatLabel(e)), 1), T(t.formatValue(e)) ? (x(), s("svg", Te, [...r[5] ||= [c("path", { d: "M20 6 9 17l-5-5" }, null, -1)]])) : o("", !0)], 10, we))), 128)), A.value.length === 0 ? (x(), s("div", Ee, " 無符合選項 ")) : o("", !0)])], 2)], 2)]));
|
|
754
754
|
}
|
|
755
|
-
}), [["__scopeId", "data-v-a8a2abbc"]]),
|
|
755
|
+
}), [["__scopeId", "data-v-a8a2abbc"]]), ke = typeof Buffer == "function", Ae = typeof TextDecoder == "function" ? new TextDecoder() : void 0, je = typeof TextEncoder == "function" ? new TextEncoder() : void 0, Me = Array.prototype.slice.call("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="), Ne = ((e) => {
|
|
756
756
|
let t = {};
|
|
757
757
|
return e.forEach((e, n) => t[e] = n), t;
|
|
758
|
-
})(
|
|
758
|
+
})(Me), Pe = /^(?:[A-Za-z\d+\/]{4})*?(?:[A-Za-z\d+\/]{2}(?:==)?|[A-Za-z\d+\/]{3}=?)?$/, Q = String.fromCharCode.bind(String), Fe = typeof Uint8Array.from == "function" ? Uint8Array.from.bind(Uint8Array) : (e) => new Uint8Array(Array.prototype.slice.call(e, 0)), Ie = (e) => e.replace(/=/g, "").replace(/[+\/]/g, (e) => e == "+" ? "-" : "_"), Le = (e) => e.replace(/[^A-Za-z0-9\+\/]/g, ""), Re = typeof btoa == "function" ? (e) => btoa(e) : ke ? (e) => Buffer.from(e, "binary").toString("base64") : (e) => {
|
|
759
759
|
let t, n, r, i, a = "", o = e.length % 3;
|
|
760
760
|
for (let o = 0; o < e.length;) {
|
|
761
761
|
if ((n = e.charCodeAt(o++)) > 255 || (r = e.charCodeAt(o++)) > 255 || (i = e.charCodeAt(o++)) > 255) throw TypeError("invalid character found");
|
|
762
|
-
t = n << 16 | r << 8 | i, a +=
|
|
762
|
+
t = n << 16 | r << 8 | i, a += Me[t >> 18 & 63] + Me[t >> 12 & 63] + Me[t >> 6 & 63] + Me[t & 63];
|
|
763
763
|
}
|
|
764
764
|
return o ? a.slice(0, o - 3) + "===".substring(o) : a;
|
|
765
|
-
}, ze =
|
|
765
|
+
}, ze = ke ? (e) => Buffer.from(e).toString("base64") : (e) => {
|
|
766
766
|
let t = 4096, n = [];
|
|
767
|
-
for (let r = 0, i = e.length; r < i; r += t) n.push(
|
|
767
|
+
for (let r = 0, i = e.length; r < i; r += t) n.push(Q.apply(null, e.subarray(r, r + t)));
|
|
768
768
|
return Re(n.join(""));
|
|
769
769
|
}, Be = (e) => {
|
|
770
770
|
if (e.length < 2) {
|
|
771
771
|
var t = e.charCodeAt(0);
|
|
772
|
-
return t < 128 ? e : t < 2048 ?
|
|
772
|
+
return t < 128 ? e : t < 2048 ? Q(192 | t >>> 6) + Q(128 | t & 63) : Q(224 | t >>> 12 & 15) + Q(128 | t >>> 6 & 63) + Q(128 | t & 63);
|
|
773
773
|
} else {
|
|
774
774
|
var t = 65536 + (e.charCodeAt(0) - 55296) * 1024 + (e.charCodeAt(1) - 56320);
|
|
775
|
-
return
|
|
775
|
+
return Q(240 | t >>> 18 & 7) + Q(128 | t >>> 12 & 63) + Q(128 | t >>> 6 & 63) + Q(128 | t & 63);
|
|
776
776
|
}
|
|
777
|
-
}, Ve = /[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g, He = (e) => e.replace(Ve, Be), Ue =
|
|
777
|
+
}, Ve = /[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g, He = (e) => e.replace(Ve, Be), Ue = ke ? (e) => Buffer.from(e, "utf8").toString("base64") : je ? (e) => ze(je.encode(e)) : (e) => Re(He(e)), We = (e, t = !1) => t ? Ie(Ue(e)) : Ue(e), Ge = /[\xC0-\xDF][\x80-\xBF]|[\xE0-\xEF][\x80-\xBF]{2}|[\xF0-\xF7][\x80-\xBF]{3}/g, Ke = (e) => {
|
|
778
778
|
switch (e.length) {
|
|
779
779
|
case 4:
|
|
780
780
|
var t = ((7 & e.charCodeAt(0)) << 18 | (63 & e.charCodeAt(1)) << 12 | (63 & e.charCodeAt(2)) << 6 | 63 & e.charCodeAt(3)) - 65536;
|
|
781
|
-
return
|
|
782
|
-
case 3: return
|
|
783
|
-
default: return
|
|
781
|
+
return Q((t >>> 10) + 55296) + Q((t & 1023) + 56320);
|
|
782
|
+
case 3: return Q((15 & e.charCodeAt(0)) << 12 | (63 & e.charCodeAt(1)) << 6 | 63 & e.charCodeAt(2));
|
|
783
|
+
default: return Q((31 & e.charCodeAt(0)) << 6 | 63 & e.charCodeAt(1));
|
|
784
784
|
}
|
|
785
|
-
}, qe = (e) => e.replace(Ge, Ke), Je = typeof atob == "function" ? (e) => atob(Le(e)) :
|
|
785
|
+
}, qe = (e) => e.replace(Ge, Ke), Je = typeof atob == "function" ? (e) => atob(Le(e)) : ke ? (e) => Buffer.from(e, "base64").toString("binary") : (e) => {
|
|
786
786
|
if (e = e.replace(/\s+/g, ""), !Pe.test(e)) throw TypeError("malformed base64.");
|
|
787
787
|
e += "==".slice(2 - (e.length & 3));
|
|
788
788
|
let t, n, r, i = [];
|
|
789
|
-
for (let a = 0; a < e.length;) t =
|
|
789
|
+
for (let a = 0; a < e.length;) t = Ne[e.charAt(a++)] << 18 | Ne[e.charAt(a++)] << 12 | (n = Ne[e.charAt(a++)]) << 6 | (r = Ne[e.charAt(a++)]), n === 64 ? i.push(Q(t >> 16 & 255)) : r === 64 ? i.push(Q(t >> 16 & 255, t >> 8 & 255)) : i.push(Q(t >> 16 & 255, t >> 8 & 255, t & 255));
|
|
790
790
|
return i.join("");
|
|
791
|
-
}, Ye =
|
|
792
|
-
let e = We(JSON.stringify(
|
|
791
|
+
}, Ye = ke ? (e) => Fe(Buffer.from(e, "base64")) : (e) => Fe(Je(e).split("").map((e) => e.charCodeAt(0))), Xe = (e) => Ye(Qe(e)), Ze = ke ? (e) => Buffer.from(e, "base64").toString("utf8") : Ae ? (e) => Ae.decode(Ye(e)) : (e) => qe(Je(e)), Qe = (e) => Le(e.replace(/[-_]/g, (e) => e == "-" ? "+" : "/")), $e = (e) => Ze(Qe(e)), et = "N_UTILS_KEY", tt = [], nt = () => {
|
|
792
|
+
let e = We(JSON.stringify(tt));
|
|
793
793
|
localStorage.setItem(et, e);
|
|
794
|
-
},
|
|
794
|
+
}, rt = () => {
|
|
795
795
|
let e = localStorage.getItem(et) ?? "";
|
|
796
796
|
if (e.length == 0) return [];
|
|
797
797
|
try {
|
|
@@ -799,42 +799,42 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
799
799
|
} catch {
|
|
800
800
|
return [];
|
|
801
801
|
}
|
|
802
|
-
},
|
|
803
|
-
|
|
804
|
-
let e =
|
|
802
|
+
}, it = () => {
|
|
803
|
+
tt.clear();
|
|
804
|
+
let e = rt(), t = (/* @__PURE__ */ new Date()).getTime();
|
|
805
805
|
e.forEach((e) => {
|
|
806
|
-
e.expireTime && e.expireTime < t ||
|
|
806
|
+
e.expireTime && e.expireTime < t || tt.push({
|
|
807
807
|
key: e.key,
|
|
808
808
|
value: e.value,
|
|
809
809
|
expireTime: e.expireTime
|
|
810
810
|
});
|
|
811
|
-
}),
|
|
812
|
-
},
|
|
813
|
-
|
|
811
|
+
}), tt.length > 0 && nt();
|
|
812
|
+
}, at = (e) => (it(), tt.some((t) => t.key == e)), ot = (e, t, n) => {
|
|
813
|
+
ct(e);
|
|
814
814
|
let r = {
|
|
815
815
|
key: e,
|
|
816
816
|
value: t
|
|
817
817
|
};
|
|
818
|
-
n && (r.expireTime = (/* @__PURE__ */ new Date()).getTime() + n * 1e3),
|
|
819
|
-
},
|
|
820
|
-
|
|
821
|
-
let n =
|
|
818
|
+
n && (r.expireTime = (/* @__PURE__ */ new Date()).getTime() + n * 1e3), tt.push(r), nt();
|
|
819
|
+
}, st = (e, t) => {
|
|
820
|
+
it();
|
|
821
|
+
let n = tt.find((t) => t.key == e);
|
|
822
822
|
return n ? n.value : t;
|
|
823
|
-
},
|
|
824
|
-
|
|
825
|
-
let t =
|
|
826
|
-
t != -1 && (
|
|
827
|
-
},
|
|
828
|
-
set:
|
|
829
|
-
get:
|
|
830
|
-
has:
|
|
831
|
-
forget:
|
|
832
|
-
},
|
|
823
|
+
}, ct = (e) => {
|
|
824
|
+
it();
|
|
825
|
+
let t = tt.findIndex((t) => t.key == e);
|
|
826
|
+
t != -1 && (tt.splice(t, 1), nt());
|
|
827
|
+
}, lt = {
|
|
828
|
+
set: ot,
|
|
829
|
+
get: st,
|
|
830
|
+
has: at,
|
|
831
|
+
forget: ct
|
|
832
|
+
}, ut = { fullScreenToggle: (() => {
|
|
833
833
|
let e = !1;
|
|
834
834
|
return () => {
|
|
835
835
|
e ? document.exitFullscreen() : document.documentElement.requestFullscreen(), e = !e;
|
|
836
836
|
};
|
|
837
|
-
})() },
|
|
837
|
+
})() }, dt = {
|
|
838
838
|
random: (e = 5) => Array(e).fill(null).map(() => {
|
|
839
839
|
let e = Math.random() * 62;
|
|
840
840
|
return "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789".charAt(e);
|
|
@@ -842,11 +842,11 @@ var I = { class: "breadcrumbs" }, L = ["onClick"], R = {
|
|
|
842
842
|
copy: (e) => {
|
|
843
843
|
navigator.clipboard.writeText(e);
|
|
844
844
|
}
|
|
845
|
-
},
|
|
846
|
-
function
|
|
847
|
-
return
|
|
845
|
+
}, ft = [];
|
|
846
|
+
function pt(e = "", t = !1, n = !1) {
|
|
847
|
+
return ft.clear(), new Promise((r, i) => {
|
|
848
848
|
let a = document.createElement("input");
|
|
849
|
-
|
|
849
|
+
ft.push(a), a.hidden = !0, a.type = "file", a.accept = e, a.multiple = t, a.onchange = async () => {
|
|
850
850
|
let e = [];
|
|
851
851
|
if (!a.files || a.files.length === 0) {
|
|
852
852
|
r(t ? [] : void 0);
|
|
@@ -869,11 +869,11 @@ function ft(e = "", t = !1, n = !1) {
|
|
|
869
869
|
}, a.click();
|
|
870
870
|
});
|
|
871
871
|
}
|
|
872
|
-
function pt(e = !1, t = !1) {
|
|
873
|
-
return ft("", e, t);
|
|
874
|
-
}
|
|
875
872
|
function mt(e = !1, t = !1) {
|
|
876
|
-
return
|
|
873
|
+
return pt("", e, t);
|
|
874
|
+
}
|
|
875
|
+
function ht(e = !1, t = !1) {
|
|
876
|
+
return pt([
|
|
877
877
|
"image/jpg",
|
|
878
878
|
"image/jpeg",
|
|
879
879
|
"image/png",
|
|
@@ -881,8 +881,8 @@ function mt(e = !1, t = !1) {
|
|
|
881
881
|
"image/bmp"
|
|
882
882
|
].join(","), e, t);
|
|
883
883
|
}
|
|
884
|
-
function
|
|
885
|
-
return
|
|
884
|
+
function gt(e = !1, t = !1) {
|
|
885
|
+
return pt([
|
|
886
886
|
".pdf",
|
|
887
887
|
"application/pdf",
|
|
888
888
|
".doc",
|
|
@@ -894,16 +894,16 @@ function ht(e = !1, t = !1) {
|
|
|
894
894
|
".md"
|
|
895
895
|
].join(","), e, t);
|
|
896
896
|
}
|
|
897
|
-
function
|
|
898
|
-
return
|
|
897
|
+
function _t(e = !1, t = !1) {
|
|
898
|
+
return pt([
|
|
899
899
|
"video/mp4",
|
|
900
900
|
"video/quicktime",
|
|
901
901
|
"video/webm",
|
|
902
902
|
"video/ogg"
|
|
903
903
|
].join(","), e, t);
|
|
904
904
|
}
|
|
905
|
-
function
|
|
906
|
-
return
|
|
905
|
+
function vt(e = !1, t = !1) {
|
|
906
|
+
return pt([
|
|
907
907
|
"audio/mp3",
|
|
908
908
|
"audio/wav",
|
|
909
909
|
"audio/ogg",
|
|
@@ -911,48 +911,48 @@ function _t(e = !1, t = !1) {
|
|
|
911
911
|
"audio/flac"
|
|
912
912
|
].join(","), e, t);
|
|
913
913
|
}
|
|
914
|
-
function
|
|
915
|
-
return
|
|
914
|
+
function yt(e = "", t = !1, n = !1) {
|
|
915
|
+
return pt(e, t, n);
|
|
916
916
|
}
|
|
917
|
-
var
|
|
918
|
-
all:
|
|
919
|
-
image:
|
|
920
|
-
documentFile:
|
|
921
|
-
video:
|
|
922
|
-
audio:
|
|
923
|
-
custom:
|
|
924
|
-
},
|
|
917
|
+
var bt = {
|
|
918
|
+
all: mt,
|
|
919
|
+
image: ht,
|
|
920
|
+
documentFile: gt,
|
|
921
|
+
video: _t,
|
|
922
|
+
audio: vt,
|
|
923
|
+
custom: yt
|
|
924
|
+
}, xt = (e) => new Promise((t, n) => {
|
|
925
925
|
let r = new FileReader();
|
|
926
926
|
r.readAsDataURL(e), r.onload = () => {
|
|
927
927
|
let e = r.result.split(";base64,");
|
|
928
928
|
e.length > 1 ? t(e[1]) : n(/* @__PURE__ */ Error("Failed to convert file to base64 string."));
|
|
929
929
|
}, r.onerror = n;
|
|
930
|
-
}),
|
|
931
|
-
convertBase64:
|
|
932
|
-
createImageUrlFromFile:
|
|
933
|
-
createImageUrlFromBlob:
|
|
930
|
+
}), St = (e) => Ct(new Blob([e], { type: "xxxx" })), Ct = (e) => (window.URL || window.webkitURL).createObjectURL(e), wt = {
|
|
931
|
+
convertBase64: xt,
|
|
932
|
+
createImageUrlFromFile: St,
|
|
933
|
+
createImageUrlFromBlob: Ct,
|
|
934
934
|
revokeObjectUrl: (e) => {
|
|
935
935
|
(window.URL || window.webkitURL).revokeObjectURL(e);
|
|
936
936
|
}
|
|
937
|
-
},
|
|
937
|
+
}, Tt = (e, t) => {
|
|
938
938
|
let n = document.createElement("a");
|
|
939
939
|
n.target = "_blank", t && (n.download = t), n.href = e, n.click(), n.remove();
|
|
940
|
-
},
|
|
941
|
-
download:
|
|
940
|
+
}, Et = {
|
|
941
|
+
download: Tt,
|
|
942
942
|
downloadFromBase64: (e, t, n) => {
|
|
943
943
|
let r = Xe(e), i = new Blob([r.buffer], { type: t }), a = URL.createObjectURL(i);
|
|
944
|
-
|
|
944
|
+
Tt(a, n), URL.revokeObjectURL(a);
|
|
945
945
|
},
|
|
946
946
|
openExternalLink: (e, t) => {
|
|
947
947
|
let n = document.createElement("a");
|
|
948
948
|
n.target = "_blank", t && (n.download = t), n.href = e, n.click(), n.remove();
|
|
949
949
|
}
|
|
950
|
-
},
|
|
950
|
+
}, Dt = async (e) => {
|
|
951
951
|
let t = e.includes("data:image/") ? e : `data:image/jpeg;base64,${e}`;
|
|
952
952
|
return (await fetch(t)).blob();
|
|
953
|
-
},
|
|
953
|
+
}, Ot = (e) => new Promise(async (t, n) => {
|
|
954
954
|
try {
|
|
955
|
-
let r = typeof e == "string" ? await
|
|
955
|
+
let r = typeof e == "string" ? await Dt(e) : e, i = window.URL || window.webkitURL, a = i.createObjectURL(r), o = document.createElement("img");
|
|
956
956
|
o.src = a, o.onload = () => {
|
|
957
957
|
i.revokeObjectURL(a), t(o);
|
|
958
958
|
}, o.onerror = (e) => {
|
|
@@ -961,39 +961,39 @@ var yt = {
|
|
|
961
961
|
} catch (e) {
|
|
962
962
|
n(e);
|
|
963
963
|
}
|
|
964
|
-
}),
|
|
964
|
+
}), kt = (e, t) => {
|
|
965
965
|
let n = Math.min(t / e.width, t / e.height, 1), r = n * e.width, i = n * e.height, a = document.createElement("canvas"), o = a.getContext("2d");
|
|
966
966
|
return a.width = r, a.height = i, o.drawImage(e, 0, 0, r, i), a;
|
|
967
|
-
},
|
|
967
|
+
}, At = (e) => {
|
|
968
968
|
let t = e.toDataURL("image/jpeg", .8).split(";base64,");
|
|
969
969
|
return t.length > 1 ? t[1] : "";
|
|
970
|
-
},
|
|
970
|
+
}, jt = (e) => new Promise((t, n) => {
|
|
971
971
|
e.toBlob((e) => {
|
|
972
972
|
e ? t(e) : n(/* @__PURE__ */ Error("Failed to create Blob from canvas."));
|
|
973
973
|
}, "image/jpeg", .8);
|
|
974
|
-
}),
|
|
975
|
-
thumbnailFromBlobToBase64: async (e, t) =>
|
|
976
|
-
thumbnailFromBlobToBlob: async (e, t) =>
|
|
977
|
-
thumbnailFromBase64ToBase64: async (e, t) =>
|
|
978
|
-
thumbnailFromBase64ToBlob: async (e, t) =>
|
|
979
|
-
},
|
|
974
|
+
}), Mt = async (e, t) => kt(await Ot(e), t), Nt = {
|
|
975
|
+
thumbnailFromBlobToBase64: async (e, t) => At(await Mt(e, t)),
|
|
976
|
+
thumbnailFromBlobToBlob: async (e, t) => jt(await Mt(e, t)),
|
|
977
|
+
thumbnailFromBase64ToBase64: async (e, t) => At(await Mt(e, t)),
|
|
978
|
+
thumbnailFromBase64ToBlob: async (e, t) => jt(await Mt(e, t))
|
|
979
|
+
}, Pt = () => {
|
|
980
980
|
let e = navigator.userAgent;
|
|
981
981
|
return !!/Mobile|Android|iP(hone|od)|IEMobile|BlackBerry|Kindle|Silk-Accelerated|(hpw|web)OS|Opera M(obi|ini)/.test(e);
|
|
982
|
-
},
|
|
982
|
+
}, Ft = () => {
|
|
983
983
|
let e = navigator.userAgent;
|
|
984
984
|
return !!/(tablet|ipad|playbook|silk)|(android(?!.*mobi))/i.test(e);
|
|
985
985
|
}, $ = {
|
|
986
|
-
store:
|
|
987
|
-
screen:
|
|
988
|
-
str:
|
|
989
|
-
input:
|
|
990
|
-
file:
|
|
991
|
-
link:
|
|
992
|
-
image:
|
|
986
|
+
store: lt,
|
|
987
|
+
screen: ut,
|
|
988
|
+
str: dt,
|
|
989
|
+
input: bt,
|
|
990
|
+
file: wt,
|
|
991
|
+
link: Et,
|
|
992
|
+
image: Nt,
|
|
993
993
|
device: {
|
|
994
|
-
isMobile:
|
|
995
|
-
isTablet:
|
|
996
|
-
isDesktop: () =>
|
|
994
|
+
isMobile: Pt,
|
|
995
|
+
isTablet: Ft,
|
|
996
|
+
isDesktop: () => Pt() == 0 && Ft() == 0
|
|
997
997
|
},
|
|
998
998
|
date: { getCalendarByDate: (e) => {
|
|
999
999
|
e.setDate(1);
|
|
@@ -1017,7 +1017,7 @@ var yt = {
|
|
|
1017
1017
|
e > 0 && window.clearTimeout(e), e = window.setTimeout(t, n);
|
|
1018
1018
|
};
|
|
1019
1019
|
})() }
|
|
1020
|
-
},
|
|
1020
|
+
}, It = { class: "file-select" }, Lt = ["textContent"], Rt = ["aria-disabled"], zt = { class: "inner" }, Bt = { class: "text" }, Vt = ["textContent"], Ht = ["textContent"], Ut = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1021
1021
|
__name: "NFileSelect",
|
|
1022
1022
|
props: {
|
|
1023
1023
|
multiple: {
|
|
@@ -1050,19 +1050,19 @@ var yt = {
|
|
|
1050
1050
|
console.log(e);
|
|
1051
1051
|
}
|
|
1052
1052
|
};
|
|
1053
|
-
return (t, n) => (
|
|
1053
|
+
return (t, n) => (x(), s("div", It, [e.title ? (x(), s("div", {
|
|
1054
1054
|
key: 0,
|
|
1055
1055
|
class: "label",
|
|
1056
|
-
textContent:
|
|
1057
|
-
}, null, 8,
|
|
1058
|
-
class:
|
|
1056
|
+
textContent: E(e.title)
|
|
1057
|
+
}, null, 8, Lt)) : o("", !0), c("div", {
|
|
1058
|
+
class: g(["select", {
|
|
1059
1059
|
multiple: e.multiple,
|
|
1060
1060
|
disabled: e.disabled
|
|
1061
1061
|
}]),
|
|
1062
1062
|
tabindex: "0",
|
|
1063
1063
|
"aria-disabled": e.disabled ? "true" : void 0,
|
|
1064
1064
|
onClick: r
|
|
1065
|
-
}, [c("div",
|
|
1065
|
+
}, [c("div", zt, [n[0] ||= c("span", {
|
|
1066
1066
|
class: "icon",
|
|
1067
1067
|
"aria-hidden": "true"
|
|
1068
1068
|
}, [c("svg", {
|
|
@@ -1075,47 +1075,47 @@ var yt = {
|
|
|
1075
1075
|
"stroke-linejoin": "round",
|
|
1076
1076
|
"stroke-width": "2",
|
|
1077
1077
|
d: "M4 16v1a3 3 0 003 3h10a3 3 0 003-3v-1m-4-8l-4-4m0 0L8 8m4-4v12"
|
|
1078
|
-
})])], -1), c("div",
|
|
1078
|
+
})])], -1), c("div", Bt, [c("p", {
|
|
1079
1079
|
class: "label",
|
|
1080
|
-
textContent:
|
|
1081
|
-
}, null, 8,
|
|
1080
|
+
textContent: E(e.label)
|
|
1081
|
+
}, null, 8, Vt), c("p", {
|
|
1082
1082
|
class: "hint",
|
|
1083
|
-
textContent:
|
|
1084
|
-
}, null, 8,
|
|
1083
|
+
textContent: E(e.hint)
|
|
1084
|
+
}, null, 8, Ht)])])], 10, Rt)]));
|
|
1085
1085
|
}
|
|
1086
|
-
}), [["__scopeId", "data-v-ef36f4d5"]]),
|
|
1087
|
-
function
|
|
1088
|
-
let t = `NSidebar:${e}:expanded`, n =
|
|
1089
|
-
|
|
1086
|
+
}), [["__scopeId", "data-v-ef36f4d5"]]), Wt = C(!1), Gt = (e, t) => e.children?.some((e) => e.route === t) ?? !1, Kt = (e, t) => e.route === t;
|
|
1087
|
+
function qt(e = "default") {
|
|
1088
|
+
let t = `NSidebar:${e}:expanded`, n = S($.store.get(t, {}));
|
|
1089
|
+
Wt.value = $.store.get("NSidebar:expanded", !1);
|
|
1090
1090
|
let r = (e) => !!n[e];
|
|
1091
1091
|
return {
|
|
1092
1092
|
isMenuExpanded: r,
|
|
1093
1093
|
toggleMenu: (e) => {
|
|
1094
1094
|
n[e] = !r(e), $.store.set(t, n);
|
|
1095
1095
|
},
|
|
1096
|
-
isSidebarExpanded: () =>
|
|
1096
|
+
isSidebarExpanded: () => Wt.value,
|
|
1097
1097
|
toggleSidebar: () => {
|
|
1098
|
-
|
|
1098
|
+
Wt.value = !Wt.value, $.store.set("NSidebar:expanded", Wt.value);
|
|
1099
1099
|
},
|
|
1100
1100
|
setMenuActiveResolver: (e) => {
|
|
1101
|
-
|
|
1101
|
+
Gt = e;
|
|
1102
1102
|
},
|
|
1103
1103
|
setItemActiveResolver: (e) => {
|
|
1104
|
-
|
|
1104
|
+
Kt = e;
|
|
1105
1105
|
},
|
|
1106
|
-
resolveMenuActive:
|
|
1107
|
-
resolveItemActive:
|
|
1106
|
+
resolveMenuActive: Gt,
|
|
1107
|
+
resolveItemActive: Kt
|
|
1108
1108
|
};
|
|
1109
1109
|
}
|
|
1110
1110
|
//#endregion
|
|
1111
1111
|
//#region src/layouts/NHeroSection.vue?vue&type=script&setup=true&lang.ts
|
|
1112
|
-
var
|
|
1112
|
+
var Jt = { class: "hero-section-container" }, Yt = { class: "hero-section" }, Xt = { class: "header" }, Zt = ["innerHTML"], Qt = { class: "body" }, $t = { class: "title-section" }, en = { class: "title" }, tn = { key: 0 }, nn = {
|
|
1113
1113
|
key: 1,
|
|
1114
1114
|
class: "description"
|
|
1115
|
-
},
|
|
1115
|
+
}, rn = {
|
|
1116
1116
|
key: 0,
|
|
1117
1117
|
class: "toolbar"
|
|
1118
|
-
},
|
|
1118
|
+
}, an = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1119
1119
|
__name: "NHeroSection",
|
|
1120
1120
|
props: {
|
|
1121
1121
|
icon: { default: "" },
|
|
@@ -1123,18 +1123,18 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1123
1123
|
description: { default: "" }
|
|
1124
1124
|
},
|
|
1125
1125
|
setup(e) {
|
|
1126
|
-
let t =
|
|
1127
|
-
return (n, r) => (
|
|
1126
|
+
let t = qt();
|
|
1127
|
+
return (n, r) => (x(), s("div", Jt, [c("div", Yt, [
|
|
1128
1128
|
r[2] ||= c("div", { class: "effect-background-left" }, null, -1),
|
|
1129
1129
|
r[3] ||= c("div", { class: "effect-background-right" }, null, -1),
|
|
1130
|
-
c("div",
|
|
1130
|
+
c("div", Xt, [f(z, {
|
|
1131
1131
|
class: "sidebar-toggle-button",
|
|
1132
1132
|
padding: "8px",
|
|
1133
1133
|
intent: "none",
|
|
1134
1134
|
variant: "ghost",
|
|
1135
|
-
onClick: r[0] ||= (e) =>
|
|
1135
|
+
onClick: r[0] ||= (e) => D(t).toggleSidebar()
|
|
1136
1136
|
}, {
|
|
1137
|
-
default:
|
|
1137
|
+
default: j(() => [...r[1] ||= [c("svg", {
|
|
1138
1138
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1139
1139
|
width: "24",
|
|
1140
1140
|
height: "24",
|
|
@@ -1150,19 +1150,19 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1150
1150
|
c("path", { d: "M4 19h16" })
|
|
1151
1151
|
], -1)]]),
|
|
1152
1152
|
_: 1
|
|
1153
|
-
}), f(
|
|
1154
|
-
e.icon ? (
|
|
1153
|
+
}), f(re)]),
|
|
1154
|
+
e.icon ? (x(), s("div", {
|
|
1155
1155
|
key: 0,
|
|
1156
1156
|
class: "icon-bg",
|
|
1157
1157
|
innerHTML: e.icon
|
|
1158
|
-
}, null, 8,
|
|
1159
|
-
c("div",
|
|
1158
|
+
}, null, 8, Zt)) : o("", !0),
|
|
1159
|
+
c("div", Qt, [c("div", $t, [c("div", en, [e.title ? (x(), s("h1", tn, E(e.title), 1)) : o("", !0), n.$slots.description || e.description ? (x(), s("div", nn, [T(n.$slots, "description", {}, () => [d(E(e.description), 1)], !0)])) : o("", !0)])]), n.$slots.toolbar ? (x(), s("div", rn, [T(n.$slots, "toolbar", {}, void 0, !0)])) : o("", !0)])
|
|
1160
1160
|
])]));
|
|
1161
1161
|
}
|
|
1162
|
-
}), [["__scopeId", "data-v-6fef1cae"]]),
|
|
1162
|
+
}), [["__scopeId", "data-v-6fef1cae"]]), on = { class: "content-container" }, sn = {
|
|
1163
1163
|
key: 0,
|
|
1164
1164
|
class: "nav-tabs"
|
|
1165
|
-
},
|
|
1165
|
+
}, cn = ["textContent", "onClick"], ln = { class: "tab-content" }, un = { class: "footer" }, dn = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1166
1166
|
__name: "NForm",
|
|
1167
1167
|
props: {
|
|
1168
1168
|
model: { default: () => ({}) },
|
|
@@ -1182,61 +1182,61 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1182
1182
|
"update:modelValue"
|
|
1183
1183
|
],
|
|
1184
1184
|
setup(t, { emit: n }) {
|
|
1185
|
-
let r = n, a = `NForm:${t.title}@${t.tabs.length}:tab`, u =
|
|
1185
|
+
let r = n, a = `NForm:${t.title}@${t.tabs.length}:tab`, u = C(t.tabs.length > 0 ? $.store.get(a, 0) : 0), d = i(() => t.modelValue ?? u.value), p = () => {
|
|
1186
1186
|
t.disabled || r("submit", t.model);
|
|
1187
1187
|
}, m = () => {
|
|
1188
1188
|
t.disabled || r("reset");
|
|
1189
1189
|
};
|
|
1190
|
-
return (n, i) => (
|
|
1190
|
+
return (n, i) => (x(), s("div", on, [T(n.$slots, "heroSection", {}, () => [f(an, {
|
|
1191
1191
|
icon: t.icon,
|
|
1192
1192
|
title: t.title,
|
|
1193
1193
|
description: t.description
|
|
1194
1194
|
}, l({
|
|
1195
|
-
toolbar:
|
|
1195
|
+
toolbar: j(() => [T(n.$slots, "toolbar", {}, void 0, !0)]),
|
|
1196
1196
|
_: 2
|
|
1197
1197
|
}, [n.$slots.description ? {
|
|
1198
1198
|
name: "description",
|
|
1199
|
-
fn:
|
|
1199
|
+
fn: j(() => [T(n.$slots, "description", {}, void 0, !0)]),
|
|
1200
1200
|
key: "0"
|
|
1201
1201
|
} : void 0]), 1032, [
|
|
1202
1202
|
"icon",
|
|
1203
1203
|
"title",
|
|
1204
1204
|
"description"
|
|
1205
1205
|
])], !0), c("form", {
|
|
1206
|
-
onSubmit:
|
|
1207
|
-
onReset:
|
|
1206
|
+
onSubmit: N(p, ["prevent"]),
|
|
1207
|
+
onReset: N(m, ["prevent"])
|
|
1208
1208
|
}, [
|
|
1209
|
-
t.tabs.length > 0 ? (
|
|
1209
|
+
t.tabs.length > 0 ? (x(), s("div", sn, [(x(!0), s(e, null, w(t.tabs, (e, t) => (x(), s("button", {
|
|
1210
1210
|
key: `${e}${t}`,
|
|
1211
|
-
class:
|
|
1212
|
-
textContent:
|
|
1211
|
+
class: g(["nav-link", { active: d.value === t }]),
|
|
1212
|
+
textContent: E(e),
|
|
1213
1213
|
onClick: () => {
|
|
1214
|
-
u.value = t,
|
|
1214
|
+
u.value = t, D($).store.set(a, t), r("update:modelValue", t);
|
|
1215
1215
|
}
|
|
1216
|
-
}, null, 10,
|
|
1217
|
-
c("div",
|
|
1218
|
-
c("div",
|
|
1216
|
+
}, null, 10, cn))), 128))])) : o("", !0),
|
|
1217
|
+
c("div", ln, [t.tabs.length > 0 ? (x(!0), s(e, { key: 0 }, w(t.tabs, (t, r) => (x(), s(e, null, [d.value === r ? T(n.$slots, `tab${r}`, { key: 0 }, void 0, !0) : o("", !0)], 64))), 256)) : o("", !0), t.tabs.length == 0 && n.$slots.tab0 ? T(n.$slots, "tab0", { key: 1 }, void 0, !0) : o("", !0)]),
|
|
1218
|
+
c("div", un, [T(n.$slots, "footer", {}, void 0, !0)])
|
|
1219
1219
|
], 32)]));
|
|
1220
1220
|
}
|
|
1221
|
-
}), [["__scopeId", "data-v-fc11e625"]]),
|
|
1221
|
+
}), [["__scopeId", "data-v-fc11e625"]]), fn = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1222
1222
|
__name: "NCard",
|
|
1223
1223
|
props: {
|
|
1224
1224
|
size: { default: "md" },
|
|
1225
1225
|
radius: { default: "md" }
|
|
1226
1226
|
},
|
|
1227
1227
|
setup(e) {
|
|
1228
|
-
return (t, n) => (
|
|
1228
|
+
return (t, n) => (x(), s("div", { class: g(["card", {
|
|
1229
1229
|
[`size-${e.size}`]: !0,
|
|
1230
1230
|
[`radius-${e.radius}`]: !0
|
|
1231
|
-
}]) }, [
|
|
1231
|
+
}]) }, [T(t.$slots, "default", {}, void 0, !0)], 2));
|
|
1232
1232
|
}
|
|
1233
|
-
}), [["__scopeId", "data-v-56a18223"]]),
|
|
1233
|
+
}), [["__scopeId", "data-v-56a18223"]]), pn = {
|
|
1234
1234
|
key: 0,
|
|
1235
1235
|
class: "paginate"
|
|
1236
|
-
},
|
|
1236
|
+
}, mn = { class: "summary" }, hn = { class: "pages" }, gn = {
|
|
1237
1237
|
key: 1,
|
|
1238
1238
|
class: "separator"
|
|
1239
|
-
},
|
|
1239
|
+
}, _n = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1240
1240
|
__name: "NPaginate",
|
|
1241
1241
|
props: {
|
|
1242
1242
|
totalItems: {},
|
|
@@ -1246,8 +1246,8 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1246
1246
|
},
|
|
1247
1247
|
emits: ["onPageChange"],
|
|
1248
1248
|
setup(t, { emit: n }) {
|
|
1249
|
-
let r = n, l =
|
|
1250
|
-
|
|
1249
|
+
let r = n, l = C(1);
|
|
1250
|
+
A(() => t.currentPage, (e) => {
|
|
1251
1251
|
l.value = e;
|
|
1252
1252
|
}, { immediate: !0 });
|
|
1253
1253
|
let u = i(() => Math.max(1, Math.ceil(t.totalItems / t.pageSize))), p = i(() => {
|
|
@@ -1272,8 +1272,8 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1272
1272
|
let t = Math.min(Math.max(1, e), u.value);
|
|
1273
1273
|
l.value !== t && (l.value = t, r("onPageChange", l.value));
|
|
1274
1274
|
}
|
|
1275
|
-
return (n, r) => t.totalItems > 0 ? (
|
|
1276
|
-
f(
|
|
1275
|
+
return (n, r) => t.totalItems > 0 ? (x(), s("div", pn, [c("span", mn, "第 " + E(l.value) + " / " + E(u.value) + " 頁,共 " + E(t.totalItems) + " 筆", 1), c("div", hn, [
|
|
1276
|
+
f(z, {
|
|
1277
1277
|
variant: "outline",
|
|
1278
1278
|
padding: "",
|
|
1279
1279
|
width: "35px",
|
|
@@ -1281,7 +1281,7 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1281
1281
|
disabled: t.currentPage <= 1,
|
|
1282
1282
|
onClick: m
|
|
1283
1283
|
}, {
|
|
1284
|
-
default:
|
|
1284
|
+
default: j(() => [...r[0] ||= [c("svg", {
|
|
1285
1285
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1286
1286
|
width: "16",
|
|
1287
1287
|
height: "16",
|
|
@@ -1294,7 +1294,7 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1294
1294
|
}, [c("path", { d: "M15 18l-6-6 6-6" })], -1)]]),
|
|
1295
1295
|
_: 1
|
|
1296
1296
|
}, 8, ["disabled"]),
|
|
1297
|
-
(
|
|
1297
|
+
(x(!0), s(e, null, w(p.value, (n) => (x(), s(e, { key: "p-" + n }, [typeof n == "number" ? (x(), a(z, {
|
|
1298
1298
|
key: 0,
|
|
1299
1299
|
variant: t.currentPage === n ? "solid" : "outline",
|
|
1300
1300
|
intent: t.currentPage === n ? "primary" : "none",
|
|
@@ -1303,14 +1303,14 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1303
1303
|
height: "35px",
|
|
1304
1304
|
onClick: (e) => g(n)
|
|
1305
1305
|
}, {
|
|
1306
|
-
default:
|
|
1306
|
+
default: j(() => [d(E(n), 1)]),
|
|
1307
1307
|
_: 2
|
|
1308
1308
|
}, 1032, [
|
|
1309
1309
|
"variant",
|
|
1310
1310
|
"intent",
|
|
1311
1311
|
"onClick"
|
|
1312
|
-
])) : (
|
|
1313
|
-
f(
|
|
1312
|
+
])) : (x(), s("span", gn, "…"))], 64))), 128)),
|
|
1313
|
+
f(z, {
|
|
1314
1314
|
variant: "outline",
|
|
1315
1315
|
padding: "",
|
|
1316
1316
|
width: "35px",
|
|
@@ -1318,7 +1318,7 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1318
1318
|
disabled: t.currentPage >= u.value,
|
|
1319
1319
|
onClick: h
|
|
1320
1320
|
}, {
|
|
1321
|
-
default:
|
|
1321
|
+
default: j(() => [...r[1] ||= [c("svg", {
|
|
1322
1322
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1323
1323
|
width: "16",
|
|
1324
1324
|
height: "16",
|
|
@@ -1333,13 +1333,13 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1333
1333
|
}, 8, ["disabled"])
|
|
1334
1334
|
])])) : o("", !0);
|
|
1335
1335
|
}
|
|
1336
|
-
}), [["__scopeId", "data-v-a191a116"]]),
|
|
1336
|
+
}), [["__scopeId", "data-v-a191a116"]]), vn = ["innerHTML"], yn = { class: "title" }, bn = {
|
|
1337
1337
|
key: 1,
|
|
1338
1338
|
class: "description"
|
|
1339
|
-
},
|
|
1339
|
+
}, xn = {
|
|
1340
1340
|
key: 2,
|
|
1341
1341
|
class: "action"
|
|
1342
|
-
},
|
|
1342
|
+
}, Sn = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1343
1343
|
__name: "NEmpty",
|
|
1344
1344
|
props: {
|
|
1345
1345
|
title: { default: "目前沒有資料" },
|
|
@@ -1348,42 +1348,42 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1348
1348
|
icon: { default: "<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <polyline points=\"22 12 16 12 14 15 10 15 8 12 2 12\"/>\n <path d=\"M5.45 5.11 2 12v6a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-6l-3.45-6.89A2 2 0 0 0 16.76 4H7.24a2 2 0 0 0-1.79 1.11z\"/>\n</svg>" }
|
|
1349
1349
|
},
|
|
1350
1350
|
setup(e) {
|
|
1351
|
-
return (t, n) => (
|
|
1352
|
-
e.icon ? (
|
|
1351
|
+
return (t, n) => (x(), s("div", { class: g(["empty", [`size-${e.size}`]]) }, [
|
|
1352
|
+
e.icon ? (x(), s("div", {
|
|
1353
1353
|
key: 0,
|
|
1354
1354
|
class: "icon",
|
|
1355
1355
|
innerHTML: e.icon
|
|
1356
|
-
}, null, 8,
|
|
1357
|
-
c("p",
|
|
1358
|
-
e.description ? (
|
|
1359
|
-
t.$slots.default ? (
|
|
1356
|
+
}, null, 8, vn)) : o("", !0),
|
|
1357
|
+
c("p", yn, E(e.title), 1),
|
|
1358
|
+
e.description ? (x(), s("p", bn, E(e.description), 1)) : o("", !0),
|
|
1359
|
+
t.$slots.default ? (x(), s("div", xn, [T(t.$slots, "default", {}, void 0, !0)])) : o("", !0)
|
|
1360
1360
|
], 2));
|
|
1361
1361
|
}
|
|
1362
|
-
}), [["__scopeId", "data-v-b9482c23"]]),
|
|
1362
|
+
}), [["__scopeId", "data-v-b9482c23"]]), Cn = {
|
|
1363
1363
|
key: 0,
|
|
1364
1364
|
class: "loading-fullscreen"
|
|
1365
|
-
},
|
|
1365
|
+
}, wn = { class: "content" }, Tn = {
|
|
1366
1366
|
key: 0,
|
|
1367
1367
|
class: "title"
|
|
1368
|
-
},
|
|
1368
|
+
}, En = {
|
|
1369
1369
|
key: 1,
|
|
1370
1370
|
class: "loading-wrapper"
|
|
1371
|
-
},
|
|
1371
|
+
}, Dn = {
|
|
1372
1372
|
key: 0,
|
|
1373
1373
|
class: "overlay"
|
|
1374
|
-
},
|
|
1374
|
+
}, On = { class: "content" }, kn = {
|
|
1375
1375
|
key: 0,
|
|
1376
1376
|
class: "title"
|
|
1377
|
-
},
|
|
1377
|
+
}, An = {
|
|
1378
1378
|
key: 0,
|
|
1379
1379
|
class: "loading-inline"
|
|
1380
|
-
},
|
|
1380
|
+
}, jn = {
|
|
1381
1381
|
key: 0,
|
|
1382
1382
|
class: "title"
|
|
1383
|
-
},
|
|
1383
|
+
}, Mn = {
|
|
1384
1384
|
key: 0,
|
|
1385
1385
|
class: "title"
|
|
1386
|
-
},
|
|
1386
|
+
}, Nn = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1387
1387
|
__name: "NLoading",
|
|
1388
1388
|
props: {
|
|
1389
1389
|
loading: {
|
|
@@ -1402,46 +1402,46 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1402
1402
|
}
|
|
1403
1403
|
},
|
|
1404
1404
|
setup(r) {
|
|
1405
|
-
return (i, l) => r.fullscreen ? (
|
|
1405
|
+
return (i, l) => r.fullscreen ? (x(), a(t, {
|
|
1406
1406
|
key: 0,
|
|
1407
1407
|
to: "body"
|
|
1408
1408
|
}, [f(n, { name: "fade" }, {
|
|
1409
|
-
default:
|
|
1409
|
+
default: j(() => [r.loading ? (x(), s("div", Cn, [c("div", wn, [l[0] ||= c("div", { class: "spinner" }, [c("svg", { viewBox: "0 0 50 50" }, [c("circle", {
|
|
1410
1410
|
cx: "25",
|
|
1411
1411
|
cy: "25",
|
|
1412
1412
|
r: "20",
|
|
1413
1413
|
fill: "none",
|
|
1414
1414
|
"stroke-width": "4"
|
|
1415
|
-
})])], -1), r.title ? (
|
|
1415
|
+
})])], -1), r.title ? (x(), s("p", Tn, E(r.title), 1)) : o("", !0)])])) : o("", !0)]),
|
|
1416
1416
|
_: 1
|
|
1417
|
-
})])) : r.overlay ? (
|
|
1418
|
-
default:
|
|
1417
|
+
})])) : r.overlay ? (x(), s("div", En, [T(i.$slots, "default", {}, void 0, !0), f(n, { name: "fade" }, {
|
|
1418
|
+
default: j(() => [r.loading ? (x(), s("div", Dn, [c("div", On, [l[1] ||= c("div", { class: "spinner" }, [c("svg", { viewBox: "0 0 50 50" }, [c("circle", {
|
|
1419
1419
|
cx: "25",
|
|
1420
1420
|
cy: "25",
|
|
1421
1421
|
r: "20",
|
|
1422
1422
|
fill: "none",
|
|
1423
1423
|
"stroke-width": "4"
|
|
1424
|
-
})])], -1), r.title ? (
|
|
1424
|
+
})])], -1), r.title ? (x(), s("p", kn, E(r.title), 1)) : o("", !0)])])) : o("", !0)]),
|
|
1425
1425
|
_: 1
|
|
1426
|
-
})])) : (
|
|
1426
|
+
})])) : (x(), s(e, { key: 2 }, [r.loading ? (x(), s("div", An, [r.variant === "spinner" ? (x(), s(e, { key: 0 }, [l[2] ||= c("div", { class: "spinner" }, [c("svg", { viewBox: "0 0 50 50" }, [c("circle", {
|
|
1427
1427
|
cx: "25",
|
|
1428
1428
|
cy: "25",
|
|
1429
1429
|
r: "20",
|
|
1430
1430
|
fill: "none",
|
|
1431
1431
|
"stroke-width": "4"
|
|
1432
|
-
})])], -1), r.title ? (
|
|
1432
|
+
})])], -1), r.title ? (x(), s("p", jn, E(r.title), 1)) : o("", !0)], 64)) : o("", !0), r.variant === "dots" ? (x(), s(e, { key: 1 }, [l[3] ||= c("div", { class: "dots" }, [
|
|
1433
1433
|
c("span"),
|
|
1434
1434
|
c("span"),
|
|
1435
1435
|
c("span")
|
|
1436
|
-
], -1), r.title ? (
|
|
1436
|
+
], -1), r.title ? (x(), s("p", Mn, E(r.title), 1)) : o("", !0)], 64)) : o("", !0)])) : T(i.$slots, "default", { key: 1 }, void 0, !0)], 64));
|
|
1437
1437
|
}
|
|
1438
|
-
}), [["__scopeId", "data-v-f3aa02fe"]]),
|
|
1438
|
+
}), [["__scopeId", "data-v-f3aa02fe"]]), Pn = { class: "table-scroll" }, Fn = {
|
|
1439
1439
|
key: 0,
|
|
1440
1440
|
class: "batch"
|
|
1441
|
-
},
|
|
1441
|
+
}, In = ["onClick"], Ln = { class: "th-content" }, Rn = {
|
|
1442
1442
|
key: 0,
|
|
1443
1443
|
class: "sort-icon"
|
|
1444
|
-
},
|
|
1444
|
+
}, zn = {
|
|
1445
1445
|
key: 0,
|
|
1446
1446
|
viewBox: "0 0 24 24",
|
|
1447
1447
|
fill: "none",
|
|
@@ -1449,7 +1449,7 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1449
1449
|
"stroke-width": "2",
|
|
1450
1450
|
"stroke-linecap": "round",
|
|
1451
1451
|
"stroke-linejoin": "round"
|
|
1452
|
-
},
|
|
1452
|
+
}, Bn = {
|
|
1453
1453
|
key: 1,
|
|
1454
1454
|
viewBox: "0 0 24 24",
|
|
1455
1455
|
fill: "none",
|
|
@@ -1457,7 +1457,7 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1457
1457
|
"stroke-width": "2",
|
|
1458
1458
|
"stroke-linecap": "round",
|
|
1459
1459
|
"stroke-linejoin": "round"
|
|
1460
|
-
},
|
|
1460
|
+
}, Vn = {
|
|
1461
1461
|
key: 2,
|
|
1462
1462
|
viewBox: "0 0 24 24",
|
|
1463
1463
|
fill: "none",
|
|
@@ -1465,13 +1465,13 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1465
1465
|
"stroke-width": "2",
|
|
1466
1466
|
"stroke-linecap": "round",
|
|
1467
1467
|
"stroke-linejoin": "round"
|
|
1468
|
-
},
|
|
1468
|
+
}, Hn = {
|
|
1469
1469
|
key: 1,
|
|
1470
1470
|
class: "actions"
|
|
1471
|
-
},
|
|
1471
|
+
}, Un = { key: 0 }, Wn = ["onClick"], Gn = {
|
|
1472
1472
|
key: 0,
|
|
1473
1473
|
class: "actions"
|
|
1474
|
-
},
|
|
1474
|
+
}, Kn = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1475
1475
|
__name: "NTable",
|
|
1476
1476
|
props: {
|
|
1477
1477
|
columns: { default: () => [] },
|
|
@@ -1494,43 +1494,43 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1494
1494
|
},
|
|
1495
1495
|
emits: ["sort", "click"],
|
|
1496
1496
|
setup(t, { emit: n }) {
|
|
1497
|
-
let r = n, i =
|
|
1497
|
+
let r = n, i = C({
|
|
1498
1498
|
key: "",
|
|
1499
1499
|
order: null
|
|
1500
1500
|
}), a = (e) => {
|
|
1501
1501
|
e.sortable && (i.value.key === e.key ? i.value.order = i.value.order === "asc" ? "desc" : "asc" : (i.value.key = e.key, i.value.order = "asc"), r("sort", { ...i.value }));
|
|
1502
1502
|
};
|
|
1503
|
-
return (n, l) => (
|
|
1503
|
+
return (n, l) => (x(), s("div", { class: g(["table", [{ bordered: t.bordered }, { hoverable: t.hoverable }]]) }, [f(Nn, {
|
|
1504
1504
|
loading: t.loading,
|
|
1505
1505
|
overlay: ""
|
|
1506
1506
|
}, {
|
|
1507
|
-
default:
|
|
1508
|
-
n.$slots.batch ? (
|
|
1509
|
-
(
|
|
1507
|
+
default: j(() => [c("div", Pn, [c("table", null, [c("thead", null, [c("tr", null, [
|
|
1508
|
+
n.$slots.batch ? (x(), s("th", Fn, [T(n.$slots, "batch", {}, void 0, !0)])) : o("", !0),
|
|
1509
|
+
(x(!0), s(e, null, w(t.columns, (e) => (x(), s("th", {
|
|
1510
1510
|
key: e.key,
|
|
1511
|
-
class:
|
|
1511
|
+
class: g({ sortable: e.sortable }),
|
|
1512
1512
|
onClick: (t) => a(e)
|
|
1513
|
-
}, [c("span",
|
|
1514
|
-
n.$slots.actions ? (
|
|
1515
|
-
])]), !t.loading && t.items.length > 0 ? (
|
|
1513
|
+
}, [c("span", Ln, [d(E(e.label) + " ", 1), e.sortable ? (x(), s("span", Rn, [i.value.key !== e.key || i.value.order === null ? (x(), s("svg", zn, [...l[0] ||= [c("path", { d: "M8 9l4-4 4 4" }, null, -1), c("path", { d: "M16 15l-4 4-4-4" }, null, -1)]])) : i.value.order === "asc" ? (x(), s("svg", Bn, [...l[1] ||= [c("path", { d: "M8 15l4-6 4 6" }, null, -1)]])) : (x(), s("svg", Vn, [...l[2] ||= [c("path", { d: "M8 9l4 6 4-6" }, null, -1)]]))])) : o("", !0)])], 10, In))), 128)),
|
|
1514
|
+
n.$slots.actions ? (x(), s("th", Hn, [T(n.$slots, "actions-header", {}, () => [l[3] ||= d("操作", -1)], !0)])) : o("", !0)
|
|
1515
|
+
])]), !t.loading && t.items.length > 0 ? (x(), s("tbody", Un, [(x(!0), s(e, null, w(t.items, (e, i) => (x(), s("tr", {
|
|
1516
1516
|
key: e[t.itemKey] ?? i,
|
|
1517
1517
|
onClick: (t) => r("click", e)
|
|
1518
|
-
}, [
|
|
1518
|
+
}, [T(n.$slots, "item", {
|
|
1519
1519
|
index: i,
|
|
1520
1520
|
item: e,
|
|
1521
1521
|
column: t.columns[i]
|
|
1522
|
-
}, void 0, !0), n.$slots.actions ? (
|
|
1522
|
+
}, void 0, !0), n.$slots.actions ? (x(), s("td", Gn, [T(n.$slots, "actions", {
|
|
1523
1523
|
index: i,
|
|
1524
1524
|
item: e,
|
|
1525
1525
|
column: t.columns[i]
|
|
1526
|
-
}, void 0, !0)])) : o("", !0)], 8,
|
|
1526
|
+
}, void 0, !0)])) : o("", !0)], 8, Wn))), 128))])) : o("", !0)])])]),
|
|
1527
1527
|
_: 3
|
|
1528
|
-
}, 8, ["loading"]), t.items.length === 0 ?
|
|
1528
|
+
}, 8, ["loading"]), t.items.length === 0 ? T(n.$slots, "empty", { key: 0 }, () => [f(Sn, {
|
|
1529
1529
|
title: t.emptyTitle,
|
|
1530
1530
|
description: t.emptyDescription
|
|
1531
1531
|
}, null, 8, ["title", "description"])], !0) : o("", !0)], 2));
|
|
1532
1532
|
}
|
|
1533
|
-
}), [["__scopeId", "data-v-77619033"]]),
|
|
1533
|
+
}), [["__scopeId", "data-v-77619033"]]), qn = { class: "content-container" }, Jn = { key: 0 }, Yn = { class: "actions" }, Xn = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1534
1534
|
__name: "NList",
|
|
1535
1535
|
props: {
|
|
1536
1536
|
title: { default: "" },
|
|
@@ -1588,7 +1588,7 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1588
1588
|
"sort"
|
|
1589
1589
|
],
|
|
1590
1590
|
setup(e, { emit: t }) {
|
|
1591
|
-
let n = t, r =
|
|
1591
|
+
let n = t, r = C(/* @__PURE__ */ new Set()), u = i(() => Array.from(r.value)), p = (e) => r.value.has(`${e}`), m = i(() => e.items.length > 0 && e.items.length === r.value.size);
|
|
1592
1592
|
function h(t) {
|
|
1593
1593
|
if (!e.batchDeletable || !["string", "number"].includes(typeof t[e.itemKey])) return;
|
|
1594
1594
|
let n = `${t[e.itemKey]}`;
|
|
@@ -1597,23 +1597,23 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1597
1597
|
function g() {
|
|
1598
1598
|
e.batchDeletable && (m.value ? e.items.forEach((e) => r.value.delete(e.id)) : e.items.forEach((e) => r.value.add(e.id)), r.value = new Set(r.value));
|
|
1599
1599
|
}
|
|
1600
|
-
function
|
|
1600
|
+
function _() {
|
|
1601
1601
|
r.value.clear();
|
|
1602
1602
|
}
|
|
1603
|
-
return (t, r) => (
|
|
1603
|
+
return (t, r) => (x(), s("div", qn, [T(t.$slots, "heroSection", {}, () => [f(an, {
|
|
1604
1604
|
icon: "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"28\" height=\"28\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2\"></path>\n <circle cx=\"12\" cy=\"7\" r=\"4\"></circle>\n </svg>",
|
|
1605
1605
|
title: e.title,
|
|
1606
1606
|
description: e.description
|
|
1607
1607
|
}, l({ _: 2 }, [t.$slots.toolbar || e.refreshable || e.creatable || e.batchDeletable ? {
|
|
1608
1608
|
name: "toolbar",
|
|
1609
|
-
fn:
|
|
1610
|
-
|
|
1611
|
-
e.refreshable ? (
|
|
1609
|
+
fn: j(() => [
|
|
1610
|
+
T(t.$slots, "toolbar", {}, void 0, !0),
|
|
1611
|
+
e.refreshable ? (x(), a(z, {
|
|
1612
1612
|
key: 0,
|
|
1613
1613
|
variant: "outline",
|
|
1614
1614
|
onClick: r[0] ||= (e) => n("refresh")
|
|
1615
1615
|
}, {
|
|
1616
|
-
default:
|
|
1616
|
+
default: j(() => [r[8] ||= c("svg", {
|
|
1617
1617
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1618
1618
|
width: "16",
|
|
1619
1619
|
height: "16",
|
|
@@ -1628,15 +1628,15 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1628
1628
|
c("path", { d: "M21 3v5h-5" }),
|
|
1629
1629
|
c("path", { d: "M21 12a9 9 0 0 1-9 9 9.75 9.75 0 0 1-6.74-2.74L3 16" }),
|
|
1630
1630
|
c("path", { d: "M8 16H3v5" })
|
|
1631
|
-
], -1), d(" " +
|
|
1631
|
+
], -1), d(" " + E(e.refreshLabel), 1)]),
|
|
1632
1632
|
_: 1
|
|
1633
1633
|
})) : o("", !0),
|
|
1634
|
-
e.filterable ? (
|
|
1634
|
+
e.filterable ? (x(), a(z, {
|
|
1635
1635
|
key: 1,
|
|
1636
1636
|
variant: "outline",
|
|
1637
1637
|
onClick: r[1] ||= (e) => n("filter")
|
|
1638
1638
|
}, {
|
|
1639
|
-
default:
|
|
1639
|
+
default: j(() => [r[9] ||= c("svg", {
|
|
1640
1640
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1641
1641
|
width: "16",
|
|
1642
1642
|
height: "16",
|
|
@@ -1646,17 +1646,17 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1646
1646
|
"stroke-width": "2",
|
|
1647
1647
|
"stroke-linecap": "round",
|
|
1648
1648
|
"stroke-linejoin": "round"
|
|
1649
|
-
}, [c("path", { d: "M10 20a1 1 0 0 0 .553.895l2 1A1 1 0 0 0 14 21v-7a2 2 0 0 1 .517-1.341L21.74 4.67A1 1 0 0 0 21 3H3a1 1 0 0 0-.742 1.67l7.225 7.989A2 2 0 0 1 10 14z" })], -1), d(" " +
|
|
1649
|
+
}, [c("path", { d: "M10 20a1 1 0 0 0 .553.895l2 1A1 1 0 0 0 14 21v-7a2 2 0 0 1 .517-1.341L21.74 4.67A1 1 0 0 0 21 3H3a1 1 0 0 0-.742 1.67l7.225 7.989A2 2 0 0 1 10 14z" })], -1), d(" " + E(e.filterLabel), 1)]),
|
|
1650
1650
|
_: 1
|
|
1651
1651
|
})) : o("", !0),
|
|
1652
|
-
e.batchDeletable ? (
|
|
1652
|
+
e.batchDeletable ? (x(), a(z, {
|
|
1653
1653
|
key: 2,
|
|
1654
1654
|
variant: "solid",
|
|
1655
1655
|
intent: "error",
|
|
1656
1656
|
disabled: u.value.length == 0,
|
|
1657
|
-
onClick: r[2] ||= (e) => n("batchDelete", u.value,
|
|
1657
|
+
onClick: r[2] ||= (e) => n("batchDelete", u.value, _)
|
|
1658
1658
|
}, {
|
|
1659
|
-
default:
|
|
1659
|
+
default: j(() => [r[10] ||= c("svg", {
|
|
1660
1660
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1661
1661
|
width: "16",
|
|
1662
1662
|
height: "16",
|
|
@@ -1672,16 +1672,16 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1672
1672
|
c("path", { d: "M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6" }),
|
|
1673
1673
|
c("path", { d: "M3 6h18" }),
|
|
1674
1674
|
c("path", { d: "M8 6V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2" })
|
|
1675
|
-
], -1), d(" " +
|
|
1675
|
+
], -1), d(" " + E(e.batchDeleteLabel), 1)]),
|
|
1676
1676
|
_: 1
|
|
1677
1677
|
}, 8, ["disabled"])) : o("", !0),
|
|
1678
|
-
e.creatable ? (
|
|
1678
|
+
e.creatable ? (x(), a(z, {
|
|
1679
1679
|
key: 3,
|
|
1680
1680
|
variant: "solid",
|
|
1681
1681
|
intent: "primary",
|
|
1682
1682
|
onClick: r[3] ||= (e) => n("create")
|
|
1683
1683
|
}, {
|
|
1684
|
-
default:
|
|
1684
|
+
default: j(() => [r[11] ||= c("svg", {
|
|
1685
1685
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1686
1686
|
width: "16",
|
|
1687
1687
|
height: "16",
|
|
@@ -1691,16 +1691,16 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1691
1691
|
"stroke-width": "2",
|
|
1692
1692
|
"stroke-linecap": "round",
|
|
1693
1693
|
"stroke-linejoin": "round"
|
|
1694
|
-
}, [c("path", { d: "M5 12h14" }), c("path", { d: "M12 5v14" })], -1), d(" " +
|
|
1694
|
+
}, [c("path", { d: "M5 12h14" }), c("path", { d: "M12 5v14" })], -1), d(" " + E(e.createLabel), 1)]),
|
|
1695
1695
|
_: 1
|
|
1696
1696
|
})) : o("", !0)
|
|
1697
1697
|
]),
|
|
1698
1698
|
key: "0"
|
|
1699
|
-
} : void 0]), 1032, ["title", "description"])], !0), f(
|
|
1699
|
+
} : void 0]), 1032, ["title", "description"])], !0), f(fn, {
|
|
1700
1700
|
size: "none",
|
|
1701
1701
|
radius: "xl"
|
|
1702
1702
|
}, {
|
|
1703
|
-
default:
|
|
1703
|
+
default: j(() => [f(Kn, {
|
|
1704
1704
|
columns: e.columns,
|
|
1705
1705
|
items: e.items,
|
|
1706
1706
|
hoverable: "",
|
|
@@ -1715,7 +1715,7 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1715
1715
|
}, l({ _: 2 }, [
|
|
1716
1716
|
e.batchDeletable ? {
|
|
1717
1717
|
name: "batch",
|
|
1718
|
-
fn:
|
|
1718
|
+
fn: j(() => [f(xe, {
|
|
1719
1719
|
"model-value": m.value,
|
|
1720
1720
|
"onUpdate:modelValue": r[4] ||= () => g()
|
|
1721
1721
|
}, null, 8, ["model-value"])]),
|
|
@@ -1723,10 +1723,10 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1723
1723
|
} : void 0,
|
|
1724
1724
|
t.$slots.item ? {
|
|
1725
1725
|
name: "item",
|
|
1726
|
-
fn:
|
|
1727
|
-
onClick:
|
|
1726
|
+
fn: j(({ item: n, column: r, index: i }) => [e.batchDeletable ? (x(), s("td", Jn, [f(xe, {
|
|
1727
|
+
onClick: N((e) => h(n), ["stop"]),
|
|
1728
1728
|
"model-value": p(n.id)
|
|
1729
|
-
}, null, 8, ["onClick", "model-value"])])) : o("", !0),
|
|
1729
|
+
}, null, 8, ["onClick", "model-value"])])) : o("", !0), T(t.$slots, "item", {
|
|
1730
1730
|
index: i,
|
|
1731
1731
|
item: n,
|
|
1732
1732
|
column: r
|
|
@@ -1735,30 +1735,30 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1735
1735
|
} : void 0,
|
|
1736
1736
|
e.updatable || e.deletable || t.$slots.actions ? {
|
|
1737
1737
|
name: "actions",
|
|
1738
|
-
fn:
|
|
1738
|
+
fn: j(({ item: r, index: i }) => [T(t.$slots, "actions", {
|
|
1739
1739
|
item: r,
|
|
1740
1740
|
index: i
|
|
1741
|
-
}, () => [c("div",
|
|
1741
|
+
}, () => [c("div", Yn, [e.updatable ? (x(), a(z, {
|
|
1742
1742
|
key: 0,
|
|
1743
1743
|
variant: "outline",
|
|
1744
|
-
onClick:
|
|
1744
|
+
onClick: N(() => n("update", r), ["stop"])
|
|
1745
1745
|
}, {
|
|
1746
|
-
default:
|
|
1746
|
+
default: j(() => [d(E(e.updateLabel), 1)]),
|
|
1747
1747
|
_: 1
|
|
1748
|
-
}, 8, ["onClick"])) : o("", !0), e.deletable ? (
|
|
1748
|
+
}, 8, ["onClick"])) : o("", !0), e.deletable ? (x(), a(z, {
|
|
1749
1749
|
key: 1,
|
|
1750
1750
|
variant: "solid",
|
|
1751
1751
|
intent: "error",
|
|
1752
|
-
onClick:
|
|
1752
|
+
onClick: N(() => n("delete", r), ["stop"])
|
|
1753
1753
|
}, {
|
|
1754
|
-
default:
|
|
1754
|
+
default: j(() => [d(E(e.deleteLabel), 1)]),
|
|
1755
1755
|
_: 1
|
|
1756
1756
|
}, 8, ["onClick"])) : o("", !0)])], !0)]),
|
|
1757
1757
|
key: "2"
|
|
1758
1758
|
} : void 0,
|
|
1759
1759
|
t.$slots["actions-header"] ? {
|
|
1760
1760
|
name: "actions-header",
|
|
1761
|
-
fn:
|
|
1761
|
+
fn: j(() => [T(t.$slots, "actions-header", {}, void 0, !0)]),
|
|
1762
1762
|
key: "3"
|
|
1763
1763
|
} : void 0
|
|
1764
1764
|
]), 1032, [
|
|
@@ -1768,7 +1768,7 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1768
1768
|
"empty-icon",
|
|
1769
1769
|
"empty-title",
|
|
1770
1770
|
"empty-description"
|
|
1771
|
-
]), e.items.length > 0 ? (
|
|
1771
|
+
]), e.items.length > 0 ? (x(), a(_n, {
|
|
1772
1772
|
key: 0,
|
|
1773
1773
|
"total-items": e.totalItems,
|
|
1774
1774
|
"current-page": e.currentPage,
|
|
@@ -1784,11 +1784,11 @@ var qt = { class: "hero-section-container" }, Jt = { class: "hero-section" }, Yt
|
|
|
1784
1784
|
_: 3
|
|
1785
1785
|
})]));
|
|
1786
1786
|
}
|
|
1787
|
-
}), [["__scopeId", "data-v-66c8acf7"]]),
|
|
1788
|
-
function
|
|
1787
|
+
}), [["__scopeId", "data-v-66c8acf7"]]), Zn = 0, Qn = S([]);
|
|
1788
|
+
function $n() {
|
|
1789
1789
|
let e = function(e, n = {}) {
|
|
1790
|
-
let r = ++
|
|
1791
|
-
|
|
1790
|
+
let r = ++Zn, i = n.duration ?? 4e3;
|
|
1791
|
+
Qn.push({
|
|
1792
1792
|
id: r,
|
|
1793
1793
|
description: e,
|
|
1794
1794
|
status: n.status ?? "info",
|
|
@@ -1810,48 +1810,48 @@ function Qn() {
|
|
|
1810
1810
|
status: "info"
|
|
1811
1811
|
});
|
|
1812
1812
|
function t(e) {
|
|
1813
|
-
let t =
|
|
1814
|
-
t !== -1 &&
|
|
1813
|
+
let t = Qn.findIndex((t) => t.id === e);
|
|
1814
|
+
t !== -1 && Qn.splice(t, 1);
|
|
1815
1815
|
}
|
|
1816
1816
|
return {
|
|
1817
|
-
toasts:
|
|
1817
|
+
toasts: Qn,
|
|
1818
1818
|
toast: e,
|
|
1819
1819
|
removeToast: t
|
|
1820
1820
|
};
|
|
1821
1821
|
}
|
|
1822
1822
|
//#endregion
|
|
1823
1823
|
//#region src/components/NToast.vue?vue&type=script&setup=true&lang.ts
|
|
1824
|
-
var
|
|
1824
|
+
var er = { class: "icon-wrap" }, tr = ["innerHTML"], nr = {
|
|
1825
1825
|
key: 0,
|
|
1826
1826
|
class: "arc-timer",
|
|
1827
1827
|
viewBox: "0 0 36 36",
|
|
1828
1828
|
width: "36",
|
|
1829
1829
|
height: "36",
|
|
1830
1830
|
"shape-rendering": "geometricPrecision"
|
|
1831
|
-
},
|
|
1831
|
+
}, rr = { class: "body" }, ir = {
|
|
1832
1832
|
key: 0,
|
|
1833
1833
|
class: "title"
|
|
1834
|
-
},
|
|
1834
|
+
}, ar = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1835
1835
|
__name: "NToast",
|
|
1836
1836
|
setup(n) {
|
|
1837
|
-
let { toasts: i } =
|
|
1837
|
+
let { toasts: i } = $n(), l = {
|
|
1838
1838
|
success: "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M20 6 9 17l-5-5\"/>\n </svg>",
|
|
1839
1839
|
danger: "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <circle cx=\"12\" cy=\"12\" r=\"10\"/>\n <path d=\"m15 9-6 6\"/>\n <path d=\"m9 9 6 6\"/>\n </svg>",
|
|
1840
1840
|
warning: "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3\"/>\n <path d=\"M12 9v4\"/>\n <path d=\"M12 17h.01\"/>\n </svg>",
|
|
1841
1841
|
info: "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <circle cx=\"12\" cy=\"12\" r=\"10\"/>\n <path d=\"M12 16v-4\"/>\n <path d=\"M12 8h.01\"/>\n </svg>"
|
|
1842
1842
|
};
|
|
1843
|
-
return (n, u) => (
|
|
1843
|
+
return (n, u) => (x(), a(t, { to: "body" }, [f(r, {
|
|
1844
1844
|
name: "toast",
|
|
1845
1845
|
tag: "div",
|
|
1846
1846
|
class: "toast-wrapper"
|
|
1847
1847
|
}, {
|
|
1848
|
-
default:
|
|
1848
|
+
default: j(() => [(x(!0), s(e, null, w(D(i), (e) => (x(), s("div", {
|
|
1849
1849
|
key: e.id,
|
|
1850
|
-
class:
|
|
1851
|
-
}, [c("div",
|
|
1850
|
+
class: g(["toast", [`${e.status}`]])
|
|
1851
|
+
}, [c("div", er, [c("div", {
|
|
1852
1852
|
class: "icon",
|
|
1853
1853
|
innerHTML: l[e.status]
|
|
1854
|
-
}, null, 8,
|
|
1854
|
+
}, null, 8, tr), e.duration > 0 ? (x(), s("svg", nr, [u[0] ||= c("circle", {
|
|
1855
1855
|
class: "arc-track",
|
|
1856
1856
|
cx: "18",
|
|
1857
1857
|
cy: "18",
|
|
@@ -1862,18 +1862,18 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
1862
1862
|
cy: "18",
|
|
1863
1863
|
r: "16",
|
|
1864
1864
|
transform: "rotate(-90 18 18)",
|
|
1865
|
-
style:
|
|
1866
|
-
}, null, 4)])) : o("", !0)]), c("div",
|
|
1865
|
+
style: _({ animationDuration: `${e.duration}ms` })
|
|
1866
|
+
}, null, 4)])) : o("", !0)]), c("div", rr, [e.title ? (x(), s("p", ir, E(e.title), 1)) : o("", !0), e.description ? (x(), s("p", {
|
|
1867
1867
|
key: 1,
|
|
1868
|
-
class:
|
|
1869
|
-
},
|
|
1868
|
+
class: g(e.title ? "description" : "title")
|
|
1869
|
+
}, E(e.description), 3)) : o("", !0)])], 2))), 128))]),
|
|
1870
1870
|
_: 1
|
|
1871
1871
|
})]));
|
|
1872
1872
|
}
|
|
1873
|
-
}), [["__scopeId", "data-v-53892c5f"]]),
|
|
1873
|
+
}), [["__scopeId", "data-v-53892c5f"]]), or = { class: "code" }, sr = {
|
|
1874
1874
|
key: 0,
|
|
1875
1875
|
class: "header"
|
|
1876
|
-
},
|
|
1876
|
+
}, cr = { class: "language-label" }, lr = {
|
|
1877
1877
|
key: 0,
|
|
1878
1878
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1879
1879
|
width: "14",
|
|
@@ -1884,7 +1884,7 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
1884
1884
|
"stroke-width": "2",
|
|
1885
1885
|
"stroke-linecap": "round",
|
|
1886
1886
|
"stroke-linejoin": "round"
|
|
1887
|
-
},
|
|
1887
|
+
}, ur = {
|
|
1888
1888
|
key: 1,
|
|
1889
1889
|
xmlns: "http://www.w3.org/2000/svg",
|
|
1890
1890
|
width: "14",
|
|
@@ -1895,10 +1895,10 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
1895
1895
|
"stroke-width": "2",
|
|
1896
1896
|
"stroke-linecap": "round",
|
|
1897
1897
|
"stroke-linejoin": "round"
|
|
1898
|
-
},
|
|
1898
|
+
}, dr = { class: "code-body" }, fr = {
|
|
1899
1899
|
key: 0,
|
|
1900
1900
|
class: "gutter"
|
|
1901
|
-
},
|
|
1901
|
+
}, pr = ["textContent"], mr = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1902
1902
|
__name: "NCode",
|
|
1903
1903
|
props: {
|
|
1904
1904
|
code: {},
|
|
@@ -1909,7 +1909,7 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
1909
1909
|
}
|
|
1910
1910
|
},
|
|
1911
1911
|
setup(t) {
|
|
1912
|
-
let n =
|
|
1912
|
+
let n = C(!1), r = i(() => t.code.trim().split("\n"));
|
|
1913
1913
|
async function a() {
|
|
1914
1914
|
try {
|
|
1915
1915
|
await navigator.clipboard.writeText(t.code), n.value = !0, setTimeout(() => {
|
|
@@ -1917,28 +1917,28 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
1917
1917
|
}, 2e3);
|
|
1918
1918
|
} catch {}
|
|
1919
1919
|
}
|
|
1920
|
-
return (i, l) => (
|
|
1921
|
-
class:
|
|
1920
|
+
return (i, l) => (x(), s("div", or, [(t.language, x(), s("div", sr, [c("span", cr, E(t.language || "code"), 1), c("button", {
|
|
1921
|
+
class: g(["copy-btn", { copied: n.value }]),
|
|
1922
1922
|
onClick: a
|
|
1923
|
-
}, [n.value ? (
|
|
1923
|
+
}, [n.value ? (x(), s("svg", ur, [...l[1] ||= [c("polyline", { points: "20 6 9 17 4 12" }, null, -1)]])) : (x(), s("svg", lr, [...l[0] ||= [c("rect", {
|
|
1924
1924
|
x: "9",
|
|
1925
1925
|
y: "9",
|
|
1926
1926
|
width: "13",
|
|
1927
1927
|
height: "13",
|
|
1928
1928
|
rx: "2",
|
|
1929
1929
|
ry: "2"
|
|
1930
|
-
}, null, -1), c("path", { d: "M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1" }, null, -1)]])), c("span", null,
|
|
1930
|
+
}, null, -1), c("path", { d: "M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1" }, null, -1)]])), c("span", null, E(n.value ? "Copied!" : "Copy"), 1)], 2)])), c("div", dr, [t.showLineNumbers ? (x(), s("div", fr, [(x(!0), s(e, null, w(r.value, (e, t) => (x(), s("span", {
|
|
1931
1931
|
key: t,
|
|
1932
1932
|
class: "line-number"
|
|
1933
|
-
},
|
|
1933
|
+
}, E(t + 1), 1))), 128))])) : o("", !0), c("pre", {
|
|
1934
1934
|
class: "code-content",
|
|
1935
|
-
textContent:
|
|
1936
|
-
}, null, 8,
|
|
1935
|
+
textContent: E(t.code.trim())
|
|
1936
|
+
}, null, 8, pr)])]));
|
|
1937
1937
|
}
|
|
1938
|
-
}), [["__scopeId", "data-v-6fed5425"]]),
|
|
1938
|
+
}), [["__scopeId", "data-v-6fed5425"]]), hr = {
|
|
1939
1939
|
key: 0,
|
|
1940
1940
|
class: "label"
|
|
1941
|
-
},
|
|
1941
|
+
}, gr = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1942
1942
|
__name: "NSwitch",
|
|
1943
1943
|
props: {
|
|
1944
1944
|
modelValue: {
|
|
@@ -1963,8 +1963,8 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
1963
1963
|
let e = !n.modelValue;
|
|
1964
1964
|
r("update:modelValue", e), r("change", e);
|
|
1965
1965
|
};
|
|
1966
|
-
return (t, n) => (
|
|
1967
|
-
class:
|
|
1966
|
+
return (t, n) => (x(), s("div", { class: g(["switch-wrapper", { inline: e.inline }]) }, [e.title ? (x(), s("label", hr, E(e.title), 1)) : o("", !0), c("div", {
|
|
1967
|
+
class: g(["switch", [
|
|
1968
1968
|
`size-${e.size}`,
|
|
1969
1969
|
{ checked: a.value },
|
|
1970
1970
|
{ disabled: e.disabled }
|
|
@@ -1972,7 +1972,7 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
1972
1972
|
onClick: l
|
|
1973
1973
|
}, [...n[0] ||= [c("div", { class: "inner" }, [c("div", { class: "handle" })], -1)]], 2)], 2));
|
|
1974
1974
|
}
|
|
1975
|
-
}), [["__scopeId", "data-v-efa08615"]]),
|
|
1975
|
+
}), [["__scopeId", "data-v-efa08615"]]), _r = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
1976
1976
|
__name: "NTag",
|
|
1977
1977
|
props: {
|
|
1978
1978
|
intent: { default: "none" },
|
|
@@ -1992,12 +1992,12 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
1992
1992
|
let n = t, r = (e) => {
|
|
1993
1993
|
e.stopPropagation(), n("close");
|
|
1994
1994
|
};
|
|
1995
|
-
return (t, n) => (
|
|
1995
|
+
return (t, n) => (x(), s("span", { class: g(["tag", [
|
|
1996
1996
|
`intent-${e.intent}`,
|
|
1997
1997
|
`variant-${e.variant}`,
|
|
1998
1998
|
`size-${e.size}`,
|
|
1999
1999
|
{ round: e.round }
|
|
2000
|
-
]]) }, [
|
|
2000
|
+
]]) }, [T(t.$slots, "default", {}, void 0, !0), e.closable ? (x(), s("button", {
|
|
2001
2001
|
key: 0,
|
|
2002
2002
|
type: "button",
|
|
2003
2003
|
class: "close",
|
|
@@ -2021,49 +2021,49 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2021
2021
|
y2: "18"
|
|
2022
2022
|
})], -1)]])) : o("", !0)], 2));
|
|
2023
2023
|
}
|
|
2024
|
-
}), [["__scopeId", "data-v-55e5be0f"]]),
|
|
2024
|
+
}), [["__scopeId", "data-v-55e5be0f"]]), vr = {
|
|
2025
2025
|
key: 0,
|
|
2026
2026
|
class: "label"
|
|
2027
|
-
},
|
|
2027
|
+
}, yr = {
|
|
2028
2028
|
key: 0,
|
|
2029
2029
|
class: "picker-dropdown"
|
|
2030
|
-
},
|
|
2030
|
+
}, br = { class: "picker-header" }, xr = { class: "header-nav" }, Sr = { class: "header-nav" }, Cr = { class: "picker-body" }, wr = { class: "weekday-grid" }, Tr = { class: "day-grid" }, Er = {
|
|
2031
2031
|
key: 1,
|
|
2032
2032
|
class: "year-grid"
|
|
2033
|
-
},
|
|
2033
|
+
}, Dr = {
|
|
2034
2034
|
key: 0,
|
|
2035
2035
|
class: "time-section"
|
|
2036
|
-
},
|
|
2036
|
+
}, Or = { class: "time-sliders" }, kr = {
|
|
2037
2037
|
key: 0,
|
|
2038
2038
|
class: "time-row"
|
|
2039
|
-
},
|
|
2039
|
+
}, Ar = ["value"], jr = { class: "time-val" }, Mr = {
|
|
2040
2040
|
key: 1,
|
|
2041
2041
|
class: "time-row"
|
|
2042
|
-
},
|
|
2042
|
+
}, Nr = ["value"], Pr = { class: "time-val" }, Fr = { class: "mobile-sheet" }, Ir = { class: "picker-header" }, Lr = { class: "header-nav" }, Rr = { class: "header-nav" }, zr = { class: "picker-body" }, Br = { class: "weekday-grid" }, Vr = { class: "day-grid" }, Hr = {
|
|
2043
2043
|
key: 1,
|
|
2044
2044
|
class: "year-grid"
|
|
2045
|
-
},
|
|
2045
|
+
}, Ur = {
|
|
2046
2046
|
key: 0,
|
|
2047
2047
|
class: "time-section"
|
|
2048
|
-
},
|
|
2048
|
+
}, Wr = { class: "time-sliders" }, Gr = {
|
|
2049
2049
|
key: 0,
|
|
2050
2050
|
class: "time-row"
|
|
2051
|
-
},
|
|
2051
|
+
}, Kr = ["value"], qr = { class: "time-val" }, Jr = {
|
|
2052
2052
|
key: 1,
|
|
2053
2053
|
class: "time-row"
|
|
2054
|
-
},
|
|
2054
|
+
}, Yr = ["value"], Xr = { class: "time-val" }, Zr = { class: "range-modal" }, Qr = { class: "range-body" }, $r = {
|
|
2055
2055
|
key: 0,
|
|
2056
2056
|
class: "range-sep"
|
|
2057
|
-
},
|
|
2057
|
+
}, ei = { class: "range-cal" }, ti = { class: "picker-header" }, ni = { class: "header-nav" }, ri = {
|
|
2058
2058
|
key: 1,
|
|
2059
2059
|
class: "header-nav-placeholder"
|
|
2060
|
-
},
|
|
2060
|
+
}, ii = { class: "header-title no-click" }, ai = { class: "header-nav" }, oi = {
|
|
2061
2061
|
key: 1,
|
|
2062
2062
|
class: "header-nav-placeholder"
|
|
2063
|
-
},
|
|
2063
|
+
}, si = { class: "weekday-grid" }, ci = { class: "day-grid range-day-grid" }, li = ["onClick", "onMouseenter"], ui = { class: "range-footer" }, di = { class: "range-display" }, fi = { class: "mobile-sheet" }, pi = {
|
|
2064
2064
|
class: "picker-header",
|
|
2065
2065
|
style: { "margin-top": "8px" }
|
|
2066
|
-
},
|
|
2066
|
+
}, mi = { class: "header-nav" }, hi = { class: "header-title no-click" }, gi = { class: "header-nav" }, _i = { class: "weekday-grid" }, vi = { class: "day-grid range-day-grid" }, yi = ["onClick"], bi = { class: "range-footer" }, xi = { class: "range-display" }, Si = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
2067
2067
|
__name: "NDatePicker",
|
|
2068
2068
|
props: {
|
|
2069
2069
|
modelValue: { default: "" },
|
|
@@ -2113,13 +2113,13 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2113
2113
|
e === "month" ? a[e] = n - 1 : a[e] = n;
|
|
2114
2114
|
}), a;
|
|
2115
2115
|
}
|
|
2116
|
-
let m = i(() => t.format.includes("HH")),
|
|
2117
|
-
function
|
|
2118
|
-
|
|
2116
|
+
let m = i(() => t.format.includes("HH")), h = i(() => t.format.includes("mm")), _ = i(() => m.value || h.value), b = C(!1), S = C(null), T = C(typeof window < "u" && window.innerWidth < 768), D = null;
|
|
2117
|
+
function O() {
|
|
2118
|
+
D && clearTimeout(D), D = setTimeout(() => {
|
|
2119
2119
|
T.value = window.innerWidth < 768;
|
|
2120
2120
|
}, 150);
|
|
2121
2121
|
}
|
|
2122
|
-
let
|
|
2122
|
+
let k = [
|
|
2123
2123
|
"一月",
|
|
2124
2124
|
"二月",
|
|
2125
2125
|
"三月",
|
|
@@ -2132,7 +2132,7 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2132
2132
|
"十月",
|
|
2133
2133
|
"十一月",
|
|
2134
2134
|
"十二月"
|
|
2135
|
-
],
|
|
2135
|
+
], M = [
|
|
2136
2136
|
"日",
|
|
2137
2137
|
"一",
|
|
2138
2138
|
"二",
|
|
@@ -2140,8 +2140,8 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2140
2140
|
"四",
|
|
2141
2141
|
"五",
|
|
2142
2142
|
"六"
|
|
2143
|
-
],
|
|
2144
|
-
function
|
|
2143
|
+
], P = /* @__PURE__ */ new Date(), ee = P.getFullYear(), F = P.getMonth(), I = P.getDate();
|
|
2144
|
+
function L(e, t) {
|
|
2145
2145
|
let n = new Date(e, t, 1).getDay(), r = new Date(e, t + 1, 0).getDate(), i = new Date(e, t, 0).getDate(), a = [];
|
|
2146
2146
|
for (let r = n - 1; r >= 0; r--) {
|
|
2147
2147
|
let n = t === 0 ? 11 : t - 1, o = t === 0 ? e - 1 : e;
|
|
@@ -2167,96 +2167,96 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2167
2167
|
});
|
|
2168
2168
|
return a;
|
|
2169
2169
|
}
|
|
2170
|
-
function
|
|
2170
|
+
function te(e, t) {
|
|
2171
2171
|
return e.year === t.year ? e.month === t.month ? e.day - t.day : e.month - t.month : e.year - t.year;
|
|
2172
2172
|
}
|
|
2173
|
-
function
|
|
2173
|
+
function R(e) {
|
|
2174
2174
|
return String(e).padStart(2, "0");
|
|
2175
2175
|
}
|
|
2176
|
-
let
|
|
2176
|
+
let B = C("date"), V = C(/* @__PURE__ */ new Date()), H = C(null), U = C(0), W = C(0), ne = null, re = null, G = i(() => V.value.getFullYear()), ie = i(() => V.value.getMonth()), ae = C(Math.floor((/* @__PURE__ */ new Date()).getFullYear() / 12) * 12), oe = i(() => {
|
|
2177
2177
|
let e = [];
|
|
2178
|
-
for (let t = 0; t < 12; t++) e.push(
|
|
2178
|
+
for (let t = 0; t < 12; t++) e.push(ae.value + t);
|
|
2179
2179
|
return e;
|
|
2180
2180
|
});
|
|
2181
|
-
|
|
2182
|
-
|
|
2183
|
-
}, { immediate: !0 }),
|
|
2181
|
+
A(G, (e) => {
|
|
2182
|
+
ae.value = Math.floor(e / 12) * 12;
|
|
2183
|
+
}, { immediate: !0 }), A(() => t.modelValue, (e) => {
|
|
2184
2184
|
if (!e) return;
|
|
2185
2185
|
let t = p(String(e));
|
|
2186
|
-
t && (
|
|
2186
|
+
t && (V.value = new Date(t.year, t.month, 1));
|
|
2187
2187
|
}, { immediate: !0 });
|
|
2188
|
-
let
|
|
2188
|
+
let se = i(() => L(G.value, ie.value)), ce = i(() => {
|
|
2189
2189
|
if (!t.modelValue) return "";
|
|
2190
2190
|
let e = p(String(t.modelValue));
|
|
2191
2191
|
return e ? u(e.year, e.month, e.day, e.hour, e.min) : "";
|
|
2192
|
-
}),
|
|
2193
|
-
function
|
|
2192
|
+
}), le = i(() => t.range ? t.start && t.end ? `${t.start} → ${t.end}` : t.start ? `${t.start} → ...` : "" : ce.value);
|
|
2193
|
+
function ue() {
|
|
2194
2194
|
let e = p(String(t.modelValue));
|
|
2195
|
-
e ? (
|
|
2195
|
+
e ? (V.value = new Date(e.year, e.month, 1), U.value = e.hour, W.value = e.min, H.value = _.value ? {
|
|
2196
2196
|
year: e.year,
|
|
2197
2197
|
month: e.month,
|
|
2198
2198
|
day: e.day,
|
|
2199
2199
|
isCurrentMonth: !0
|
|
2200
|
-
} : null) : (
|
|
2200
|
+
} : null) : (U.value = 0, W.value = 0, H.value = null), B.value = "date";
|
|
2201
2201
|
}
|
|
2202
|
-
function
|
|
2202
|
+
function de(e) {
|
|
2203
2203
|
if (!t.modelValue) return !1;
|
|
2204
2204
|
let n = p(String(t.modelValue));
|
|
2205
2205
|
return n ? n.year === e.year && n.month === e.month && n.day === e.day : !1;
|
|
2206
2206
|
}
|
|
2207
|
-
function
|
|
2208
|
-
return
|
|
2207
|
+
function fe(e) {
|
|
2208
|
+
return ee === e.year && F === e.month && I === e.day;
|
|
2209
2209
|
}
|
|
2210
|
-
function
|
|
2211
|
-
return
|
|
2210
|
+
function pe(e) {
|
|
2211
|
+
return _.value ? H.value !== null && H.value.year === e.year && H.value.month === e.month && H.value.day === e.day : de(e);
|
|
2212
2212
|
}
|
|
2213
|
-
function
|
|
2214
|
-
let t = u(e.year, e.month, e.day,
|
|
2213
|
+
function me(e) {
|
|
2214
|
+
let t = u(e.year, e.month, e.day, U.value, W.value);
|
|
2215
2215
|
l("update:modelValue", t), l("change", t);
|
|
2216
2216
|
}
|
|
2217
|
-
function
|
|
2218
|
-
if (
|
|
2217
|
+
function he(e) {
|
|
2218
|
+
if (_.value) H.value = { ...e }, V.value = new Date(e.year, e.month, 1), me(e);
|
|
2219
2219
|
else {
|
|
2220
2220
|
let t = u(e.year, e.month, e.day, 0, 0);
|
|
2221
|
-
l("update:modelValue", t), l("change", t),
|
|
2221
|
+
l("update:modelValue", t), l("change", t), Be();
|
|
2222
2222
|
}
|
|
2223
2223
|
}
|
|
2224
|
-
function
|
|
2225
|
-
|
|
2224
|
+
function ge(e) {
|
|
2225
|
+
V.value = new Date(e, ie.value, 1), B.value = "date";
|
|
2226
2226
|
}
|
|
2227
|
-
function
|
|
2228
|
-
|
|
2227
|
+
function _e(e) {
|
|
2228
|
+
V.value = new Date(G.value, ie.value + e, 1);
|
|
2229
2229
|
}
|
|
2230
|
-
function
|
|
2231
|
-
|
|
2230
|
+
function ve(e) {
|
|
2231
|
+
B.value === "year" ? ae.value += e * 12 : V.value = new Date(G.value + e, ie.value, 1);
|
|
2232
2232
|
}
|
|
2233
|
-
function
|
|
2234
|
-
e === "H" ?
|
|
2233
|
+
function ye(e, t) {
|
|
2234
|
+
e === "H" ? U.value = Math.max(0, Math.min(23, U.value + t)) : W.value = Math.max(0, Math.min(59, W.value + t)), H.value && me(H.value);
|
|
2235
2235
|
}
|
|
2236
|
-
function
|
|
2237
|
-
|
|
2238
|
-
|
|
2236
|
+
function be(e, t) {
|
|
2237
|
+
ye(e, t), ne = setTimeout(() => {
|
|
2238
|
+
re = setInterval(() => ye(e, t), 100);
|
|
2239
2239
|
}, 300);
|
|
2240
2240
|
}
|
|
2241
|
-
function
|
|
2242
|
-
|
|
2241
|
+
function K() {
|
|
2242
|
+
ne &&= (clearTimeout(ne), null), re &&= (clearInterval(re), null);
|
|
2243
2243
|
}
|
|
2244
|
-
function
|
|
2244
|
+
function xe(e, t) {
|
|
2245
2245
|
let n = parseInt(e.target.value);
|
|
2246
|
-
t === "H" ?
|
|
2246
|
+
t === "H" ? U.value = n : W.value = n, H.value && me(H.value);
|
|
2247
2247
|
}
|
|
2248
|
-
let
|
|
2249
|
-
year:
|
|
2250
|
-
month:
|
|
2251
|
-
days:
|
|
2248
|
+
let Se = C(ee), q = C(F), J = C(null), Y = C(null), X = C(null), Z = C(null), Ce = i(() => !!Y.value && !!X.value), we = i(() => q.value === 11 ? Se.value + 1 : Se.value), Te = i(() => q.value === 11 ? 0 : q.value + 1), Ee = i(() => L(Se.value, q.value)), De = i(() => L(we.value, Te.value)), Oe = i(() => [{
|
|
2249
|
+
year: Se.value,
|
|
2250
|
+
month: q.value,
|
|
2251
|
+
days: Ee.value,
|
|
2252
2252
|
isLeft: !0
|
|
2253
2253
|
}, {
|
|
2254
|
-
year:
|
|
2255
|
-
month:
|
|
2256
|
-
days:
|
|
2254
|
+
year: we.value,
|
|
2255
|
+
month: Te.value,
|
|
2256
|
+
days: De.value,
|
|
2257
2257
|
isLeft: !1
|
|
2258
2258
|
}]);
|
|
2259
|
-
function
|
|
2259
|
+
function ke(e) {
|
|
2260
2260
|
let t = p(e);
|
|
2261
2261
|
return t ? {
|
|
2262
2262
|
year: t.year,
|
|
@@ -2265,49 +2265,49 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2265
2265
|
isCurrentMonth: !0
|
|
2266
2266
|
} : null;
|
|
2267
2267
|
}
|
|
2268
|
-
let
|
|
2269
|
-
if (
|
|
2270
|
-
let e =
|
|
2271
|
-
return `${e.year}-${
|
|
2268
|
+
let Ae = i(() => J.value && Z.value ? te(J.value, Z.value) <= 0 ? J.value : Z.value : Y.value ?? ke(t.start)), je = i(() => J.value && Z.value ? te(J.value, Z.value) <= 0 ? Z.value : J.value : X.value ?? ke(t.end)), Me = i(() => {
|
|
2269
|
+
if (J.value) {
|
|
2270
|
+
let e = J.value;
|
|
2271
|
+
return `${e.year}-${R(e.month + 1)}-${R(e.day)}`;
|
|
2272
2272
|
}
|
|
2273
|
-
if (
|
|
2274
|
-
let e =
|
|
2275
|
-
return `${e.year}-${
|
|
2273
|
+
if (Y.value) {
|
|
2274
|
+
let e = Y.value;
|
|
2275
|
+
return `${e.year}-${R(e.month + 1)}-${R(e.day)}`;
|
|
2276
2276
|
}
|
|
2277
2277
|
return t.start;
|
|
2278
|
-
}),
|
|
2279
|
-
if (
|
|
2280
|
-
if (
|
|
2281
|
-
let e =
|
|
2282
|
-
return `${e.year}-${
|
|
2278
|
+
}), Ne = i(() => {
|
|
2279
|
+
if (J.value) return "";
|
|
2280
|
+
if (X.value) {
|
|
2281
|
+
let e = X.value;
|
|
2282
|
+
return `${e.year}-${R(e.month + 1)}-${R(e.day)}`;
|
|
2283
2283
|
}
|
|
2284
2284
|
return t.end;
|
|
2285
2285
|
});
|
|
2286
|
-
function
|
|
2286
|
+
function Pe() {
|
|
2287
2287
|
let e = p(t.start) ?? {
|
|
2288
|
-
year:
|
|
2289
|
-
month:
|
|
2288
|
+
year: ee,
|
|
2289
|
+
month: F,
|
|
2290
2290
|
day: 1,
|
|
2291
2291
|
hour: 0,
|
|
2292
2292
|
min: 0
|
|
2293
2293
|
};
|
|
2294
|
-
|
|
2294
|
+
Se.value = e.year, q.value = e.month, Y.value = ke(t.start), X.value = ke(t.end), J.value = null, Z.value = null;
|
|
2295
2295
|
}
|
|
2296
|
-
function
|
|
2297
|
-
|
|
2296
|
+
function Q() {
|
|
2297
|
+
q.value === 0 ? (Se.value--, q.value = 11) : q.value--;
|
|
2298
2298
|
}
|
|
2299
|
-
function
|
|
2300
|
-
|
|
2299
|
+
function Fe() {
|
|
2300
|
+
q.value === 11 ? (Se.value++, q.value = 0) : q.value++;
|
|
2301
2301
|
}
|
|
2302
|
-
function
|
|
2303
|
-
if (!
|
|
2302
|
+
function Ie(e) {
|
|
2303
|
+
if (!J.value) J.value = { ...e }, Y.value = null, X.value = null;
|
|
2304
2304
|
else {
|
|
2305
|
-
let t =
|
|
2306
|
-
|
|
2305
|
+
let t = J.value, [n, r] = te(t, e) <= 0 ? [t, e] : [e, t];
|
|
2306
|
+
Y.value = n, X.value = r, J.value = null, Z.value = null;
|
|
2307
2307
|
}
|
|
2308
2308
|
}
|
|
2309
|
-
function
|
|
2310
|
-
let t = e.year ===
|
|
2309
|
+
function Le(e) {
|
|
2310
|
+
let t = e.year === ee && e.month === F && e.day === I, n = J.value && e.year === J.value.year && e.month === J.value.month && e.day === J.value.day, r = Ae.value, i = je.value, a = r && e.year === r.year && e.month === r.month && e.day === r.day, o = i && e.year === i.year && e.month === i.month && e.day === i.day, s = r && i && te(e, r) > 0 && te(e, i) < 0;
|
|
2311
2311
|
return {
|
|
2312
2312
|
"is-other-month": !e.isCurrentMonth,
|
|
2313
2313
|
"is-today": t && !a && !o,
|
|
@@ -2317,57 +2317,57 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2317
2317
|
"is-pending": !!n && !a
|
|
2318
2318
|
};
|
|
2319
2319
|
}
|
|
2320
|
+
function Re() {
|
|
2321
|
+
if (!Y.value || !X.value) return;
|
|
2322
|
+
let e = Y.value, t = X.value, n = `${e.year}-${R(e.month + 1)}-${R(e.day)}`, r = `${t.year}-${R(t.month + 1)}-${R(t.day)}`;
|
|
2323
|
+
l("update:start", n), l("update:end", r), l("change", n, r), Be();
|
|
2324
|
+
}
|
|
2320
2325
|
function ze() {
|
|
2321
|
-
|
|
2322
|
-
let e = q.value, t = J.value, n = `${e.year}-${N(e.month + 1)}-${N(e.day)}`, r = `${t.year}-${N(t.month + 1)}-${N(t.day)}`;
|
|
2323
|
-
l("update:start", n), l("update:end", r), l("change", n, r), Ve();
|
|
2326
|
+
t.disabled || (b.value || (t.range ? Pe() : ue()), b.value = !b.value);
|
|
2324
2327
|
}
|
|
2325
2328
|
function Be() {
|
|
2326
|
-
|
|
2329
|
+
b.value = !1, J.value = null, Z.value = null;
|
|
2327
2330
|
}
|
|
2328
2331
|
function Ve() {
|
|
2329
|
-
|
|
2330
|
-
}
|
|
2331
|
-
function He() {
|
|
2332
|
-
P.value = P.value === "date" ? "year" : "date";
|
|
2332
|
+
B.value = B.value === "date" ? "year" : "date";
|
|
2333
2333
|
}
|
|
2334
|
-
let
|
|
2334
|
+
let He = (e) => {
|
|
2335
2335
|
let t = e.target;
|
|
2336
|
-
|
|
2336
|
+
S.value?.contains(t) || T.value || Be();
|
|
2337
2337
|
};
|
|
2338
|
-
|
|
2339
|
-
document.addEventListener("mousedown",
|
|
2340
|
-
}),
|
|
2341
|
-
document.removeEventListener("mousedown",
|
|
2338
|
+
y(() => {
|
|
2339
|
+
document.addEventListener("mousedown", He), window.addEventListener("resize", O);
|
|
2340
|
+
}), v(() => {
|
|
2341
|
+
document.removeEventListener("mousedown", He), window.removeEventListener("resize", O), D && clearTimeout(D), K();
|
|
2342
2342
|
});
|
|
2343
|
-
let
|
|
2343
|
+
let Ue = (e) => {
|
|
2344
2344
|
if (e.stopPropagation(), t.range) {
|
|
2345
|
-
|
|
2345
|
+
Y.value = null, X.value = null, J.value = null, Z.value = null, l("update:start", ""), l("update:end", ""), l("change", "", ""), l("clear");
|
|
2346
2346
|
return;
|
|
2347
2347
|
}
|
|
2348
2348
|
l("update:modelValue", ""), l("change", ""), l("clear");
|
|
2349
2349
|
};
|
|
2350
|
-
return (r, i) => (
|
|
2350
|
+
return (r, i) => (x(), s("div", {
|
|
2351
2351
|
ref_key: "containerRef",
|
|
2352
|
-
ref:
|
|
2352
|
+
ref: S,
|
|
2353
2353
|
class: "datepicker"
|
|
2354
2354
|
}, [
|
|
2355
|
-
t.title ? (
|
|
2356
|
-
c("div", { class:
|
|
2355
|
+
t.title ? (x(), s("label", vr, E(t.title), 1)) : o("", !0),
|
|
2356
|
+
c("div", { class: g(["date-picker", {
|
|
2357
2357
|
open: b.value && !t.range && !T.value,
|
|
2358
2358
|
disabled: t.disabled
|
|
2359
2359
|
}]) }, [c("div", {
|
|
2360
2360
|
class: "picker-trigger",
|
|
2361
|
-
onClick:
|
|
2362
|
-
}, [c("span", { class:
|
|
2361
|
+
onClick: ze
|
|
2362
|
+
}, [c("span", { class: g(["text", { placeholder: !le.value }]) }, E(le.value || t.placeholder), 3), t.clearable && le.value ? (x(), a(z, {
|
|
2363
2363
|
key: 0,
|
|
2364
2364
|
variant: "none",
|
|
2365
2365
|
square: "",
|
|
2366
2366
|
class: "clear",
|
|
2367
2367
|
size: "sm",
|
|
2368
|
-
onClick:
|
|
2368
|
+
onClick: Ue
|
|
2369
2369
|
}, {
|
|
2370
|
-
default:
|
|
2370
|
+
default: j(() => [...i[20] ||= [c("svg", {
|
|
2371
2371
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2372
2372
|
width: "16",
|
|
2373
2373
|
height: "16",
|
|
@@ -2380,14 +2380,14 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2380
2380
|
}, [c("path", { d: "M18 6 6 18" }), c("path", { d: "m6 6 12 12" })], -1)]]),
|
|
2381
2381
|
_: 1
|
|
2382
2382
|
})) : o("", !0)]), f(n, { name: "fade" }, {
|
|
2383
|
-
default:
|
|
2384
|
-
c("div",
|
|
2385
|
-
c("div",
|
|
2383
|
+
default: j(() => [b.value && !t.range && !T.value ? (x(), s("div", yr, [
|
|
2384
|
+
c("div", br, [
|
|
2385
|
+
c("div", xr, [f(z, {
|
|
2386
2386
|
variant: "ghost",
|
|
2387
2387
|
square: "",
|
|
2388
|
-
onClick: i[0] ||= (e) =>
|
|
2388
|
+
onClick: i[0] ||= (e) => ve(-1)
|
|
2389
2389
|
}, {
|
|
2390
|
-
default:
|
|
2390
|
+
default: j(() => [...i[21] ||= [c("svg", {
|
|
2391
2391
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2392
2392
|
width: "16",
|
|
2393
2393
|
height: "16",
|
|
@@ -2399,13 +2399,13 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2399
2399
|
"stroke-linejoin": "round"
|
|
2400
2400
|
}, [c("path", { d: "m11 17-5-5 5-5" }), c("path", { d: "m18 17-5-5 5-5" })], -1)]]),
|
|
2401
2401
|
_: 1
|
|
2402
|
-
}),
|
|
2402
|
+
}), B.value === "date" ? (x(), a(z, {
|
|
2403
2403
|
key: 0,
|
|
2404
2404
|
variant: "ghost",
|
|
2405
2405
|
square: "",
|
|
2406
|
-
onClick: i[1] ||= (e) =>
|
|
2406
|
+
onClick: i[1] ||= (e) => _e(-1)
|
|
2407
2407
|
}, {
|
|
2408
|
-
default:
|
|
2408
|
+
default: j(() => [...i[22] ||= [c("svg", {
|
|
2409
2409
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2410
2410
|
width: "16",
|
|
2411
2411
|
height: "16",
|
|
@@ -2420,15 +2420,15 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2420
2420
|
})) : o("", !0)]),
|
|
2421
2421
|
c("div", {
|
|
2422
2422
|
class: "header-title",
|
|
2423
|
-
onClick:
|
|
2424
|
-
}, [
|
|
2425
|
-
c("div",
|
|
2423
|
+
onClick: Ve
|
|
2424
|
+
}, [B.value === "date" ? (x(), s(e, { key: 0 }, [d(E(k[ie.value]) + " " + E(G.value), 1)], 64)) : (x(), s(e, { key: 1 }, [d(E(oe.value[0]) + " - " + E(oe.value[oe.value.length - 1]), 1)], 64))]),
|
|
2425
|
+
c("div", Sr, [B.value === "date" ? (x(), a(z, {
|
|
2426
2426
|
key: 0,
|
|
2427
2427
|
variant: "ghost",
|
|
2428
2428
|
square: "",
|
|
2429
|
-
onClick: i[2] ||= (e) =>
|
|
2429
|
+
onClick: i[2] ||= (e) => _e(1)
|
|
2430
2430
|
}, {
|
|
2431
|
-
default:
|
|
2431
|
+
default: j(() => [...i[23] ||= [c("svg", {
|
|
2432
2432
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2433
2433
|
width: "16",
|
|
2434
2434
|
height: "16",
|
|
@@ -2440,12 +2440,12 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2440
2440
|
"stroke-linejoin": "round"
|
|
2441
2441
|
}, [c("path", { d: "m9 18 6-6-6-6" })], -1)]]),
|
|
2442
2442
|
_: 1
|
|
2443
|
-
})) : o("", !0), f(
|
|
2443
|
+
})) : o("", !0), f(z, {
|
|
2444
2444
|
variant: "ghost",
|
|
2445
2445
|
square: "",
|
|
2446
|
-
onClick: i[3] ||= (e) =>
|
|
2446
|
+
onClick: i[3] ||= (e) => ve(1)
|
|
2447
2447
|
}, {
|
|
2448
|
-
default:
|
|
2448
|
+
default: j(() => [...i[24] ||= [c("svg", {
|
|
2449
2449
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2450
2450
|
width: "16",
|
|
2451
2451
|
height: "16",
|
|
@@ -2459,50 +2459,50 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2459
2459
|
_: 1
|
|
2460
2460
|
})])
|
|
2461
2461
|
]),
|
|
2462
|
-
c("div",
|
|
2462
|
+
c("div", Cr, [B.value === "date" ? (x(), s(e, { key: 0 }, [c("div", wr, [(x(), s(e, null, w(M, (e) => c("span", {
|
|
2463
2463
|
key: e,
|
|
2464
2464
|
class: "weekday"
|
|
2465
|
-
},
|
|
2465
|
+
}, E(e), 1)), 64))]), c("div", Tr, [(x(!0), s(e, null, w(se.value, (e, t) => (x(), a(z, {
|
|
2466
2466
|
key: t,
|
|
2467
|
-
variant:
|
|
2468
|
-
intent:
|
|
2469
|
-
class:
|
|
2467
|
+
variant: pe(e) ? "solid" : fe(e) ? "mute" : "ghost",
|
|
2468
|
+
intent: pe(e) || fe(e) ? "primary" : "none",
|
|
2469
|
+
class: g(["day-cell", { "is-not-current": !e.isCurrentMonth }]),
|
|
2470
2470
|
padding: "0",
|
|
2471
|
-
onClick: (t) =>
|
|
2471
|
+
onClick: (t) => he(e)
|
|
2472
2472
|
}, {
|
|
2473
|
-
default:
|
|
2473
|
+
default: j(() => [d(E(e.day), 1)]),
|
|
2474
2474
|
_: 2
|
|
2475
2475
|
}, 1032, [
|
|
2476
2476
|
"variant",
|
|
2477
2477
|
"intent",
|
|
2478
2478
|
"class",
|
|
2479
2479
|
"onClick"
|
|
2480
|
-
]))), 128))])], 64)) : (
|
|
2480
|
+
]))), 128))])], 64)) : (x(), s("div", Er, [(x(!0), s(e, null, w(oe.value, (e) => (x(), a(z, {
|
|
2481
2481
|
key: e,
|
|
2482
|
-
variant: e ===
|
|
2483
|
-
intent: e ===
|
|
2482
|
+
variant: e === G.value ? "solid" : "ghost",
|
|
2483
|
+
intent: e === G.value ? "primary" : "none",
|
|
2484
2484
|
class: "year-cell",
|
|
2485
|
-
onClick: (t) =>
|
|
2485
|
+
onClick: (t) => ge(e)
|
|
2486
2486
|
}, {
|
|
2487
|
-
default:
|
|
2487
|
+
default: j(() => [d(E(e), 1)]),
|
|
2488
2488
|
_: 2
|
|
2489
2489
|
}, 1032, [
|
|
2490
2490
|
"variant",
|
|
2491
2491
|
"intent",
|
|
2492
2492
|
"onClick"
|
|
2493
2493
|
]))), 128))]))]),
|
|
2494
|
-
|
|
2494
|
+
_.value && B.value === "date" ? (x(), s("div", Dr, [c("div", Or, [m.value ? (x(), s("div", kr, [
|
|
2495
2495
|
i[27] ||= c("span", { class: "time-label" }, "時", -1),
|
|
2496
|
-
f(
|
|
2496
|
+
f(z, {
|
|
2497
2497
|
variant: "ghost",
|
|
2498
2498
|
square: "",
|
|
2499
2499
|
size: "sm",
|
|
2500
2500
|
class: "time-step",
|
|
2501
|
-
onMousedown: i[4] ||=
|
|
2502
|
-
onMouseup:
|
|
2503
|
-
onMouseleave:
|
|
2501
|
+
onMousedown: i[4] ||= N((e) => be("H", -1), ["prevent"]),
|
|
2502
|
+
onMouseup: K,
|
|
2503
|
+
onMouseleave: K
|
|
2504
2504
|
}, {
|
|
2505
|
-
default:
|
|
2505
|
+
default: j(() => [...i[25] ||= [c("svg", {
|
|
2506
2506
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2507
2507
|
width: "16",
|
|
2508
2508
|
height: "16",
|
|
@@ -2520,19 +2520,19 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2520
2520
|
type: "range",
|
|
2521
2521
|
min: "0",
|
|
2522
2522
|
max: "23",
|
|
2523
|
-
value:
|
|
2524
|
-
onInput: i[5] ||= (e) =>
|
|
2525
|
-
}, null, 40,
|
|
2526
|
-
f(
|
|
2523
|
+
value: U.value,
|
|
2524
|
+
onInput: i[5] ||= (e) => xe(e, "H")
|
|
2525
|
+
}, null, 40, Ar),
|
|
2526
|
+
f(z, {
|
|
2527
2527
|
variant: "ghost",
|
|
2528
2528
|
square: "",
|
|
2529
2529
|
size: "sm",
|
|
2530
2530
|
class: "time-step",
|
|
2531
|
-
onMousedown: i[6] ||=
|
|
2532
|
-
onMouseup:
|
|
2533
|
-
onMouseleave:
|
|
2531
|
+
onMousedown: i[6] ||= N((e) => be("H", 1), ["prevent"]),
|
|
2532
|
+
onMouseup: K,
|
|
2533
|
+
onMouseleave: K
|
|
2534
2534
|
}, {
|
|
2535
|
-
default:
|
|
2535
|
+
default: j(() => [...i[26] ||= [c("svg", {
|
|
2536
2536
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2537
2537
|
width: "16",
|
|
2538
2538
|
height: "16",
|
|
@@ -2545,19 +2545,19 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2545
2545
|
}, [c("path", { d: "m9 18 6-6-6-6" })], -1)]]),
|
|
2546
2546
|
_: 1
|
|
2547
2547
|
}),
|
|
2548
|
-
c("span",
|
|
2549
|
-
])) : o("", !0),
|
|
2548
|
+
c("span", jr, E(R(U.value)), 1)
|
|
2549
|
+
])) : o("", !0), h.value ? (x(), s("div", Mr, [
|
|
2550
2550
|
i[30] ||= c("span", { class: "time-label" }, "分", -1),
|
|
2551
|
-
f(
|
|
2551
|
+
f(z, {
|
|
2552
2552
|
variant: "ghost",
|
|
2553
2553
|
square: "",
|
|
2554
2554
|
size: "sm",
|
|
2555
2555
|
class: "time-step",
|
|
2556
|
-
onMousedown: i[7] ||=
|
|
2557
|
-
onMouseup:
|
|
2558
|
-
onMouseleave:
|
|
2556
|
+
onMousedown: i[7] ||= N((e) => be("m", -1), ["prevent"]),
|
|
2557
|
+
onMouseup: K,
|
|
2558
|
+
onMouseleave: K
|
|
2559
2559
|
}, {
|
|
2560
|
-
default:
|
|
2560
|
+
default: j(() => [...i[28] ||= [c("svg", {
|
|
2561
2561
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2562
2562
|
width: "16",
|
|
2563
2563
|
height: "16",
|
|
@@ -2575,19 +2575,19 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2575
2575
|
type: "range",
|
|
2576
2576
|
min: "0",
|
|
2577
2577
|
max: "59",
|
|
2578
|
-
value:
|
|
2579
|
-
onInput: i[8] ||= (e) =>
|
|
2580
|
-
}, null, 40,
|
|
2581
|
-
f(
|
|
2578
|
+
value: W.value,
|
|
2579
|
+
onInput: i[8] ||= (e) => xe(e, "m")
|
|
2580
|
+
}, null, 40, Nr),
|
|
2581
|
+
f(z, {
|
|
2582
2582
|
variant: "ghost",
|
|
2583
2583
|
square: "",
|
|
2584
2584
|
size: "sm",
|
|
2585
2585
|
class: "time-step",
|
|
2586
|
-
onMousedown: i[9] ||=
|
|
2587
|
-
onMouseup:
|
|
2588
|
-
onMouseleave:
|
|
2586
|
+
onMousedown: i[9] ||= N((e) => be("m", 1), ["prevent"]),
|
|
2587
|
+
onMouseup: K,
|
|
2588
|
+
onMouseleave: K
|
|
2589
2589
|
}, {
|
|
2590
|
-
default:
|
|
2590
|
+
default: j(() => [...i[29] ||= [c("svg", {
|
|
2591
2591
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2592
2592
|
width: "16",
|
|
2593
2593
|
height: "16",
|
|
@@ -2600,25 +2600,25 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2600
2600
|
}, [c("path", { d: "m9 18 6-6-6-6" })], -1)]]),
|
|
2601
2601
|
_: 1
|
|
2602
2602
|
}),
|
|
2603
|
-
c("span",
|
|
2603
|
+
c("span", Pr, E(R(W.value)), 1)
|
|
2604
2604
|
])) : o("", !0)])])) : o("", !0)
|
|
2605
2605
|
])) : o("", !0)]),
|
|
2606
2606
|
_: 1
|
|
2607
2607
|
})], 2),
|
|
2608
2608
|
f(n, { name: "sheet-slide" }, {
|
|
2609
|
-
default:
|
|
2609
|
+
default: j(() => [b.value && !t.range && T.value ? (x(), s("div", {
|
|
2610
2610
|
key: 0,
|
|
2611
2611
|
class: "mobile-overlay",
|
|
2612
|
-
onClick:
|
|
2613
|
-
}, [c("div",
|
|
2612
|
+
onClick: N(Be, ["self"])
|
|
2613
|
+
}, [c("div", Fr, [
|
|
2614
2614
|
i[41] ||= c("div", { class: "sheet-handle" }, null, -1),
|
|
2615
|
-
c("div",
|
|
2616
|
-
c("div",
|
|
2615
|
+
c("div", Ir, [
|
|
2616
|
+
c("div", Lr, [f(z, {
|
|
2617
2617
|
variant: "ghost",
|
|
2618
2618
|
square: "",
|
|
2619
|
-
onClick: i[10] ||= (e) =>
|
|
2619
|
+
onClick: i[10] ||= (e) => ve(-1)
|
|
2620
2620
|
}, {
|
|
2621
|
-
default:
|
|
2621
|
+
default: j(() => [...i[31] ||= [c("svg", {
|
|
2622
2622
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2623
2623
|
width: "16",
|
|
2624
2624
|
height: "16",
|
|
@@ -2630,13 +2630,13 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2630
2630
|
"stroke-linejoin": "round"
|
|
2631
2631
|
}, [c("path", { d: "m11 17-5-5 5-5" }), c("path", { d: "m18 17-5-5 5-5" })], -1)]]),
|
|
2632
2632
|
_: 1
|
|
2633
|
-
}),
|
|
2633
|
+
}), B.value === "date" ? (x(), a(z, {
|
|
2634
2634
|
key: 0,
|
|
2635
2635
|
variant: "ghost",
|
|
2636
2636
|
square: "",
|
|
2637
|
-
onClick: i[11] ||= (e) =>
|
|
2637
|
+
onClick: i[11] ||= (e) => _e(-1)
|
|
2638
2638
|
}, {
|
|
2639
|
-
default:
|
|
2639
|
+
default: j(() => [...i[32] ||= [c("svg", {
|
|
2640
2640
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2641
2641
|
width: "16",
|
|
2642
2642
|
height: "16",
|
|
@@ -2651,15 +2651,15 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2651
2651
|
})) : o("", !0)]),
|
|
2652
2652
|
c("div", {
|
|
2653
2653
|
class: "header-title",
|
|
2654
|
-
onClick:
|
|
2655
|
-
}, [
|
|
2656
|
-
c("div",
|
|
2654
|
+
onClick: Ve
|
|
2655
|
+
}, [B.value === "date" ? (x(), s(e, { key: 0 }, [d(E(k[ie.value]) + " " + E(G.value), 1)], 64)) : (x(), s(e, { key: 1 }, [d(E(oe.value[0]) + " - " + E(oe.value[oe.value.length - 1]), 1)], 64))]),
|
|
2656
|
+
c("div", Rr, [B.value === "date" ? (x(), a(z, {
|
|
2657
2657
|
key: 0,
|
|
2658
2658
|
variant: "ghost",
|
|
2659
2659
|
square: "",
|
|
2660
|
-
onClick: i[12] ||= (e) =>
|
|
2660
|
+
onClick: i[12] ||= (e) => _e(1)
|
|
2661
2661
|
}, {
|
|
2662
|
-
default:
|
|
2662
|
+
default: j(() => [...i[33] ||= [c("svg", {
|
|
2663
2663
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2664
2664
|
width: "16",
|
|
2665
2665
|
height: "16",
|
|
@@ -2671,12 +2671,12 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2671
2671
|
"stroke-linejoin": "round"
|
|
2672
2672
|
}, [c("path", { d: "m9 18 6-6-6-6" })], -1)]]),
|
|
2673
2673
|
_: 1
|
|
2674
|
-
})) : o("", !0), f(
|
|
2674
|
+
})) : o("", !0), f(z, {
|
|
2675
2675
|
variant: "ghost",
|
|
2676
2676
|
square: "",
|
|
2677
|
-
onClick: i[13] ||= (e) =>
|
|
2677
|
+
onClick: i[13] ||= (e) => ve(1)
|
|
2678
2678
|
}, {
|
|
2679
|
-
default:
|
|
2679
|
+
default: j(() => [...i[34] ||= [c("svg", {
|
|
2680
2680
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2681
2681
|
width: "16",
|
|
2682
2682
|
height: "16",
|
|
@@ -2690,50 +2690,50 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2690
2690
|
_: 1
|
|
2691
2691
|
})])
|
|
2692
2692
|
]),
|
|
2693
|
-
c("div",
|
|
2693
|
+
c("div", zr, [B.value === "date" ? (x(), s(e, { key: 0 }, [c("div", Br, [(x(), s(e, null, w(M, (e) => c("span", {
|
|
2694
2694
|
key: e,
|
|
2695
2695
|
class: "weekday"
|
|
2696
|
-
},
|
|
2696
|
+
}, E(e), 1)), 64))]), c("div", Vr, [(x(!0), s(e, null, w(se.value, (e, t) => (x(), a(z, {
|
|
2697
2697
|
key: t,
|
|
2698
|
-
variant:
|
|
2699
|
-
intent:
|
|
2700
|
-
class:
|
|
2698
|
+
variant: pe(e) ? "solid" : fe(e) ? "mute" : "ghost",
|
|
2699
|
+
intent: pe(e) || fe(e) ? "primary" : "none",
|
|
2700
|
+
class: g(["day-cell", { "is-not-current": !e.isCurrentMonth }]),
|
|
2701
2701
|
padding: "0",
|
|
2702
|
-
onClick: (t) =>
|
|
2702
|
+
onClick: (t) => he(e)
|
|
2703
2703
|
}, {
|
|
2704
|
-
default:
|
|
2704
|
+
default: j(() => [d(E(e.day), 1)]),
|
|
2705
2705
|
_: 2
|
|
2706
2706
|
}, 1032, [
|
|
2707
2707
|
"variant",
|
|
2708
2708
|
"intent",
|
|
2709
2709
|
"class",
|
|
2710
2710
|
"onClick"
|
|
2711
|
-
]))), 128))])], 64)) : (
|
|
2711
|
+
]))), 128))])], 64)) : (x(), s("div", Hr, [(x(!0), s(e, null, w(oe.value, (e) => (x(), a(z, {
|
|
2712
2712
|
key: e,
|
|
2713
|
-
variant: e ===
|
|
2714
|
-
intent: e ===
|
|
2713
|
+
variant: e === G.value ? "solid" : "ghost",
|
|
2714
|
+
intent: e === G.value ? "primary" : "none",
|
|
2715
2715
|
class: "year-cell",
|
|
2716
|
-
onClick: (t) =>
|
|
2716
|
+
onClick: (t) => ge(e)
|
|
2717
2717
|
}, {
|
|
2718
|
-
default:
|
|
2718
|
+
default: j(() => [d(E(e), 1)]),
|
|
2719
2719
|
_: 2
|
|
2720
2720
|
}, 1032, [
|
|
2721
2721
|
"variant",
|
|
2722
2722
|
"intent",
|
|
2723
2723
|
"onClick"
|
|
2724
2724
|
]))), 128))]))]),
|
|
2725
|
-
|
|
2725
|
+
_.value && B.value === "date" ? (x(), s("div", Ur, [c("div", Wr, [m.value ? (x(), s("div", Gr, [
|
|
2726
2726
|
i[37] ||= c("span", { class: "time-label" }, "時", -1),
|
|
2727
|
-
f(
|
|
2727
|
+
f(z, {
|
|
2728
2728
|
variant: "ghost",
|
|
2729
2729
|
square: "",
|
|
2730
2730
|
size: "sm",
|
|
2731
2731
|
class: "time-step",
|
|
2732
|
-
onMousedown: i[14] ||=
|
|
2733
|
-
onMouseup:
|
|
2734
|
-
onMouseleave:
|
|
2732
|
+
onMousedown: i[14] ||= N((e) => be("H", -1), ["prevent"]),
|
|
2733
|
+
onMouseup: K,
|
|
2734
|
+
onMouseleave: K
|
|
2735
2735
|
}, {
|
|
2736
|
-
default:
|
|
2736
|
+
default: j(() => [...i[35] ||= [c("svg", {
|
|
2737
2737
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2738
2738
|
width: "16",
|
|
2739
2739
|
height: "16",
|
|
@@ -2751,19 +2751,19 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2751
2751
|
type: "range",
|
|
2752
2752
|
min: "0",
|
|
2753
2753
|
max: "23",
|
|
2754
|
-
value:
|
|
2755
|
-
onInput: i[15] ||= (e) =>
|
|
2756
|
-
}, null, 40,
|
|
2757
|
-
f(
|
|
2754
|
+
value: U.value,
|
|
2755
|
+
onInput: i[15] ||= (e) => xe(e, "H")
|
|
2756
|
+
}, null, 40, Kr),
|
|
2757
|
+
f(z, {
|
|
2758
2758
|
variant: "ghost",
|
|
2759
2759
|
square: "",
|
|
2760
2760
|
size: "sm",
|
|
2761
2761
|
class: "time-step",
|
|
2762
|
-
onMousedown: i[16] ||=
|
|
2763
|
-
onMouseup:
|
|
2764
|
-
onMouseleave:
|
|
2762
|
+
onMousedown: i[16] ||= N((e) => be("H", 1), ["prevent"]),
|
|
2763
|
+
onMouseup: K,
|
|
2764
|
+
onMouseleave: K
|
|
2765
2765
|
}, {
|
|
2766
|
-
default:
|
|
2766
|
+
default: j(() => [...i[36] ||= [c("svg", {
|
|
2767
2767
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2768
2768
|
width: "16",
|
|
2769
2769
|
height: "16",
|
|
@@ -2776,19 +2776,19 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2776
2776
|
}, [c("path", { d: "m9 18 6-6-6-6" })], -1)]]),
|
|
2777
2777
|
_: 1
|
|
2778
2778
|
}),
|
|
2779
|
-
c("span",
|
|
2780
|
-
])) : o("", !0),
|
|
2779
|
+
c("span", qr, E(R(U.value)), 1)
|
|
2780
|
+
])) : o("", !0), h.value ? (x(), s("div", Jr, [
|
|
2781
2781
|
i[40] ||= c("span", { class: "time-label" }, "分", -1),
|
|
2782
|
-
f(
|
|
2782
|
+
f(z, {
|
|
2783
2783
|
variant: "ghost",
|
|
2784
2784
|
square: "",
|
|
2785
2785
|
size: "sm",
|
|
2786
2786
|
class: "time-step",
|
|
2787
|
-
onMousedown: i[17] ||=
|
|
2788
|
-
onMouseup:
|
|
2789
|
-
onMouseleave:
|
|
2787
|
+
onMousedown: i[17] ||= N((e) => be("m", -1), ["prevent"]),
|
|
2788
|
+
onMouseup: K,
|
|
2789
|
+
onMouseleave: K
|
|
2790
2790
|
}, {
|
|
2791
|
-
default:
|
|
2791
|
+
default: j(() => [...i[38] ||= [c("svg", {
|
|
2792
2792
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2793
2793
|
width: "16",
|
|
2794
2794
|
height: "16",
|
|
@@ -2806,19 +2806,19 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2806
2806
|
type: "range",
|
|
2807
2807
|
min: "0",
|
|
2808
2808
|
max: "59",
|
|
2809
|
-
value:
|
|
2810
|
-
onInput: i[18] ||= (e) =>
|
|
2811
|
-
}, null, 40,
|
|
2812
|
-
f(
|
|
2809
|
+
value: W.value,
|
|
2810
|
+
onInput: i[18] ||= (e) => xe(e, "m")
|
|
2811
|
+
}, null, 40, Yr),
|
|
2812
|
+
f(z, {
|
|
2813
2813
|
variant: "ghost",
|
|
2814
2814
|
square: "",
|
|
2815
2815
|
size: "sm",
|
|
2816
2816
|
class: "time-step",
|
|
2817
|
-
onMousedown: i[19] ||=
|
|
2818
|
-
onMouseup:
|
|
2819
|
-
onMouseleave:
|
|
2817
|
+
onMousedown: i[19] ||= N((e) => be("m", 1), ["prevent"]),
|
|
2818
|
+
onMouseup: K,
|
|
2819
|
+
onMouseleave: K
|
|
2820
2820
|
}, {
|
|
2821
|
-
default:
|
|
2821
|
+
default: j(() => [...i[39] ||= [c("svg", {
|
|
2822
2822
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2823
2823
|
width: "16",
|
|
2824
2824
|
height: "16",
|
|
@@ -2831,27 +2831,27 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2831
2831
|
}, [c("path", { d: "m9 18 6-6-6-6" })], -1)]]),
|
|
2832
2832
|
_: 1
|
|
2833
2833
|
}),
|
|
2834
|
-
c("span",
|
|
2834
|
+
c("span", Xr, E(R(W.value)), 1)
|
|
2835
2835
|
])) : o("", !0)])])) : o("", !0)
|
|
2836
2836
|
])])) : o("", !0)]),
|
|
2837
2837
|
_: 1
|
|
2838
2838
|
}),
|
|
2839
2839
|
f(n, { name: "overlay-fade" }, {
|
|
2840
|
-
default:
|
|
2840
|
+
default: j(() => [b.value && t.range && !T.value ? (x(), s("div", {
|
|
2841
2841
|
key: 0,
|
|
2842
2842
|
class: "range-overlay",
|
|
2843
|
-
onClick:
|
|
2844
|
-
}, [c("div",
|
|
2843
|
+
onClick: N(Be, ["self"])
|
|
2844
|
+
}, [c("div", Zr, [
|
|
2845
2845
|
i[46] ||= c("p", { class: "range-modal-title" }, "選擇日期範圍", -1),
|
|
2846
|
-
c("div",
|
|
2847
|
-
c("div",
|
|
2848
|
-
c("div",
|
|
2846
|
+
c("div", Qr, [(x(!0), s(e, null, w(Oe.value, (t) => (x(), s(e, { key: t.isLeft ? "left" : "right" }, [t.isLeft ? o("", !0) : (x(), s("div", $r)), c("div", ei, [
|
|
2847
|
+
c("div", ti, [
|
|
2848
|
+
c("div", ni, [t.isLeft ? (x(), a(z, {
|
|
2849
2849
|
key: 0,
|
|
2850
2850
|
variant: "ghost",
|
|
2851
2851
|
square: "",
|
|
2852
|
-
onClick:
|
|
2852
|
+
onClick: Q
|
|
2853
2853
|
}, {
|
|
2854
|
-
default:
|
|
2854
|
+
default: j(() => [...i[42] ||= [c("svg", {
|
|
2855
2855
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2856
2856
|
width: "16",
|
|
2857
2857
|
height: "16",
|
|
@@ -2863,15 +2863,15 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2863
2863
|
"stroke-linejoin": "round"
|
|
2864
2864
|
}, [c("path", { d: "m15 18-6-6 6-6" })], -1)]]),
|
|
2865
2865
|
_: 1
|
|
2866
|
-
})) : (
|
|
2867
|
-
c("div",
|
|
2868
|
-
c("div",
|
|
2866
|
+
})) : (x(), s("div", ri))]),
|
|
2867
|
+
c("div", ii, E(k[t.month]) + " " + E(t.year), 1),
|
|
2868
|
+
c("div", ai, [t.isLeft ? (x(), s("div", oi)) : (x(), a(z, {
|
|
2869
2869
|
key: 0,
|
|
2870
2870
|
variant: "ghost",
|
|
2871
2871
|
square: "",
|
|
2872
|
-
onClick:
|
|
2872
|
+
onClick: Fe
|
|
2873
2873
|
}, {
|
|
2874
|
-
default:
|
|
2874
|
+
default: j(() => [...i[43] ||= [c("svg", {
|
|
2875
2875
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2876
2876
|
width: "16",
|
|
2877
2877
|
height: "16",
|
|
@@ -2885,49 +2885,49 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2885
2885
|
_: 1
|
|
2886
2886
|
}))])
|
|
2887
2887
|
]),
|
|
2888
|
-
c("div",
|
|
2888
|
+
c("div", si, [(x(), s(e, null, w(M, (e) => c("span", {
|
|
2889
2889
|
key: e,
|
|
2890
2890
|
class: "weekday"
|
|
2891
|
-
},
|
|
2892
|
-
c("div",
|
|
2891
|
+
}, E(e), 1)), 64))]),
|
|
2892
|
+
c("div", ci, [(x(!0), s(e, null, w(t.days, (e, t) => (x(), s("div", {
|
|
2893
2893
|
key: t,
|
|
2894
|
-
class:
|
|
2895
|
-
onClick: (t) =>
|
|
2896
|
-
onMouseenter: (t) =>
|
|
2897
|
-
},
|
|
2894
|
+
class: g(["range-day", Le(e)]),
|
|
2895
|
+
onClick: (t) => Ie(e),
|
|
2896
|
+
onMouseenter: (t) => Z.value = e
|
|
2897
|
+
}, E(e.day), 43, li))), 128))])
|
|
2898
2898
|
])], 64))), 128))]),
|
|
2899
|
-
c("div",
|
|
2900
|
-
c("span", { class:
|
|
2899
|
+
c("div", ui, [c("div", di, [
|
|
2900
|
+
c("span", { class: g(["range-val", { "is-empty": !Me.value }]) }, E(Me.value || "開始日期"), 3),
|
|
2901
2901
|
i[44] ||= c("span", { class: "range-arrow" }, "→", -1),
|
|
2902
|
-
c("span", { class:
|
|
2903
|
-
]), f(
|
|
2902
|
+
c("span", { class: g(["range-val", { "is-empty": !Ne.value }]) }, E(Ne.value || "結束日期"), 3)
|
|
2903
|
+
]), f(z, {
|
|
2904
2904
|
variant: "solid",
|
|
2905
2905
|
intent: "primary",
|
|
2906
2906
|
class: "confirm-btn",
|
|
2907
|
-
disabled: !
|
|
2908
|
-
onClick:
|
|
2907
|
+
disabled: !Ce.value,
|
|
2908
|
+
onClick: N(Re, ["stop"])
|
|
2909
2909
|
}, {
|
|
2910
|
-
default:
|
|
2910
|
+
default: j(() => [...i[45] ||= [d(" 確認 ", -1)]]),
|
|
2911
2911
|
_: 1
|
|
2912
2912
|
}, 8, ["disabled"])])
|
|
2913
2913
|
])])) : o("", !0)]),
|
|
2914
2914
|
_: 1
|
|
2915
2915
|
}),
|
|
2916
2916
|
f(n, { name: "sheet-slide" }, {
|
|
2917
|
-
default:
|
|
2917
|
+
default: j(() => [b.value && t.range && T.value ? (x(), s("div", {
|
|
2918
2918
|
key: 0,
|
|
2919
2919
|
class: "mobile-overlay",
|
|
2920
|
-
onClick:
|
|
2921
|
-
}, [c("div",
|
|
2920
|
+
onClick: N(Be, ["self"])
|
|
2921
|
+
}, [c("div", fi, [
|
|
2922
2922
|
i[51] ||= c("div", { class: "sheet-handle" }, null, -1),
|
|
2923
2923
|
i[52] ||= c("p", { class: "range-modal-title" }, "選擇日期範圍", -1),
|
|
2924
|
-
c("div",
|
|
2925
|
-
c("div",
|
|
2924
|
+
c("div", pi, [
|
|
2925
|
+
c("div", mi, [f(z, {
|
|
2926
2926
|
variant: "ghost",
|
|
2927
2927
|
square: "",
|
|
2928
|
-
onClick:
|
|
2928
|
+
onClick: Q
|
|
2929
2929
|
}, {
|
|
2930
|
-
default:
|
|
2930
|
+
default: j(() => [...i[47] ||= [c("svg", {
|
|
2931
2931
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2932
2932
|
width: "16",
|
|
2933
2933
|
height: "16",
|
|
@@ -2940,13 +2940,13 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2940
2940
|
}, [c("path", { d: "m15 18-6-6 6-6" })], -1)]]),
|
|
2941
2941
|
_: 1
|
|
2942
2942
|
})]),
|
|
2943
|
-
c("div",
|
|
2944
|
-
c("div",
|
|
2943
|
+
c("div", hi, E(k[q.value]) + " " + E(Se.value), 1),
|
|
2944
|
+
c("div", gi, [f(z, {
|
|
2945
2945
|
variant: "ghost",
|
|
2946
2946
|
square: "",
|
|
2947
|
-
onClick:
|
|
2947
|
+
onClick: Fe
|
|
2948
2948
|
}, {
|
|
2949
|
-
default:
|
|
2949
|
+
default: j(() => [...i[48] ||= [c("svg", {
|
|
2950
2950
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2951
2951
|
width: "16",
|
|
2952
2952
|
height: "16",
|
|
@@ -2960,27 +2960,27 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2960
2960
|
_: 1
|
|
2961
2961
|
})])
|
|
2962
2962
|
]),
|
|
2963
|
-
c("div",
|
|
2963
|
+
c("div", _i, [(x(), s(e, null, w(M, (e) => c("span", {
|
|
2964
2964
|
key: e,
|
|
2965
2965
|
class: "weekday"
|
|
2966
|
-
},
|
|
2967
|
-
c("div",
|
|
2966
|
+
}, E(e), 1)), 64))]),
|
|
2967
|
+
c("div", vi, [(x(!0), s(e, null, w(Ee.value, (e, t) => (x(), s("div", {
|
|
2968
2968
|
key: t,
|
|
2969
|
-
class:
|
|
2970
|
-
onClick: (t) =>
|
|
2971
|
-
},
|
|
2972
|
-
c("div",
|
|
2973
|
-
c("span", { class:
|
|
2969
|
+
class: g(["range-day", Le(e)]),
|
|
2970
|
+
onClick: (t) => Ie(e)
|
|
2971
|
+
}, E(e.day), 11, yi))), 128))]),
|
|
2972
|
+
c("div", bi, [c("div", xi, [
|
|
2973
|
+
c("span", { class: g(["range-val", { "is-empty": !Me.value }]) }, E(Me.value || "開始日期"), 3),
|
|
2974
2974
|
i[49] ||= c("span", { class: "range-arrow" }, "→", -1),
|
|
2975
|
-
c("span", { class:
|
|
2976
|
-
]), f(
|
|
2975
|
+
c("span", { class: g(["range-val", { "is-empty": !Ne.value }]) }, E(Ne.value || "結束日期"), 3)
|
|
2976
|
+
]), f(z, {
|
|
2977
2977
|
variant: "solid",
|
|
2978
2978
|
intent: "primary",
|
|
2979
2979
|
class: "confirm-btn",
|
|
2980
|
-
disabled: !
|
|
2981
|
-
onClick:
|
|
2980
|
+
disabled: !Ce.value,
|
|
2981
|
+
onClick: N(Re, ["stop"])
|
|
2982
2982
|
}, {
|
|
2983
|
-
default:
|
|
2983
|
+
default: j(() => [...i[50] ||= [d(" 確認 ", -1)]]),
|
|
2984
2984
|
_: 1
|
|
2985
2985
|
}, 8, ["disabled"])])
|
|
2986
2986
|
])])) : o("", !0)]),
|
|
@@ -2988,7 +2988,7 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2988
2988
|
})
|
|
2989
2989
|
], 512));
|
|
2990
2990
|
}
|
|
2991
|
-
}), [["__scopeId", "data-v-a16fe255"]]),
|
|
2991
|
+
}), [["__scopeId", "data-v-a16fe255"]]), Ci = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
2992
2992
|
__name: "NTooltip",
|
|
2993
2993
|
props: {
|
|
2994
2994
|
content: { default: "" },
|
|
@@ -2999,34 +2999,34 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
2999
2999
|
}
|
|
3000
3000
|
},
|
|
3001
3001
|
setup(e) {
|
|
3002
|
-
let t =
|
|
3002
|
+
let t = C(!1), r = null, i = () => {
|
|
3003
3003
|
e.disabled || (r &&= (clearTimeout(r), null), t.value = !0);
|
|
3004
3004
|
}, a = () => {
|
|
3005
3005
|
e.disabled || (r = setTimeout(() => {
|
|
3006
3006
|
t.value = !1;
|
|
3007
3007
|
}, 100));
|
|
3008
3008
|
};
|
|
3009
|
-
return (r, l) => (
|
|
3009
|
+
return (r, l) => (x(), s("div", {
|
|
3010
3010
|
class: "tooltip",
|
|
3011
3011
|
onMouseenter: i,
|
|
3012
3012
|
onMouseleave: a,
|
|
3013
3013
|
onFocusin: i,
|
|
3014
3014
|
onFocusout: a
|
|
3015
|
-
}, [
|
|
3016
|
-
default:
|
|
3015
|
+
}, [T(r.$slots, "default", {}, void 0, !0), f(n, { name: "fade" }, {
|
|
3016
|
+
default: j(() => [t.value ? (x(), s("div", {
|
|
3017
3017
|
key: 0,
|
|
3018
|
-
class:
|
|
3018
|
+
class: g(["content", [e.position]]),
|
|
3019
3019
|
role: "tooltip",
|
|
3020
3020
|
onMouseenter: i,
|
|
3021
3021
|
onMouseleave: a
|
|
3022
|
-
}, [
|
|
3022
|
+
}, [T(r.$slots, "content", {}, () => [d(E(e.content), 1)], !0), c("div", { class: g(["arrow", [e.position]]) }, null, 2)], 34)) : o("", !0)]),
|
|
3023
3023
|
_: 3
|
|
3024
3024
|
})], 32));
|
|
3025
3025
|
}
|
|
3026
|
-
}), [["__scopeId", "data-v-7a53ca0a"]]),
|
|
3026
|
+
}), [["__scopeId", "data-v-7a53ca0a"]]), wi = { class: "modal-header" }, Ti = { class: "modal-title" }, Ei = { class: "modal-content" }, Di = {
|
|
3027
3027
|
key: 0,
|
|
3028
3028
|
class: "modal-footer"
|
|
3029
|
-
},
|
|
3029
|
+
}, Oi = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3030
3030
|
__name: "NModal",
|
|
3031
3031
|
props: {
|
|
3032
3032
|
show: {
|
|
@@ -3055,22 +3055,22 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
3055
3055
|
i("update:show", !1), i("close");
|
|
3056
3056
|
}, u = () => {
|
|
3057
3057
|
e.closeOnClickOverlay && l();
|
|
3058
|
-
}, d =
|
|
3059
|
-
return
|
|
3058
|
+
}, d = C("");
|
|
3059
|
+
return A(() => e.show, (e) => {
|
|
3060
3060
|
e ? (d.value = document.body.style.overflow, document.body.style.overflow = "hidden", i("open")) : document.body.style.overflow = d.value;
|
|
3061
|
-
}, { immediate: !0 }),
|
|
3061
|
+
}, { immediate: !0 }), b(() => {
|
|
3062
3062
|
e.show && (document.body.style.overflow = d.value);
|
|
3063
|
-
}), (r, i) => (
|
|
3064
|
-
default:
|
|
3063
|
+
}), (r, i) => (x(), a(t, { to: "body" }, [f(n, { name: "modal-fade" }, {
|
|
3064
|
+
default: j(() => [e.show ? (x(), s("div", {
|
|
3065
3065
|
key: 0,
|
|
3066
3066
|
class: "modal-overlay",
|
|
3067
|
-
style:
|
|
3068
|
-
onClick:
|
|
3067
|
+
style: _({ zIndex: e.zIndex }),
|
|
3068
|
+
onClick: N(u, ["self"])
|
|
3069
3069
|
}, [c("div", {
|
|
3070
3070
|
class: "modal-container",
|
|
3071
|
-
style:
|
|
3071
|
+
style: _({ width: e.width })
|
|
3072
3072
|
}, [
|
|
3073
|
-
c("header",
|
|
3073
|
+
c("header", wi, [c("h3", Ti, E(e.title), 1), e.showClose ? (x(), s("button", {
|
|
3074
3074
|
key: 0,
|
|
3075
3075
|
class: "close-btn",
|
|
3076
3076
|
onClick: l
|
|
@@ -3082,16 +3082,16 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
3082
3082
|
fill: "currentColor",
|
|
3083
3083
|
d: "M19 6.41L17.59 5L12 10.59L6.41 5L5 6.41L10.59 12L5 17.59L6.41 19L12 13.41L17.59 19L19 17.59L13.41 12L19 6.41Z"
|
|
3084
3084
|
})], -1)]])) : o("", !0)]),
|
|
3085
|
-
c("main",
|
|
3086
|
-
r.$slots.footer ? (
|
|
3085
|
+
c("main", Ei, [T(r.$slots, "default", {}, void 0, !0)]),
|
|
3086
|
+
r.$slots.footer ? (x(), s("footer", Di, [T(r.$slots, "footer", {}, void 0, !0)])) : o("", !0)
|
|
3087
3087
|
], 4)], 4)) : o("", !0)]),
|
|
3088
3088
|
_: 3
|
|
3089
3089
|
})]));
|
|
3090
3090
|
}
|
|
3091
|
-
}), [["__scopeId", "data-v-ee2fac3c"]]),
|
|
3091
|
+
}), [["__scopeId", "data-v-ee2fac3c"]]), ki = { class: "drawer-header" }, Ai = { class: "drawer-title" }, ji = { class: "drawer-body" }, Mi = {
|
|
3092
3092
|
key: 0,
|
|
3093
3093
|
class: "drawer-footer"
|
|
3094
|
-
},
|
|
3094
|
+
}, Ni = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3095
3095
|
__name: "NDrawer",
|
|
3096
3096
|
props: {
|
|
3097
3097
|
show: {
|
|
@@ -3121,22 +3121,22 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
3121
3121
|
i("update:show", !1), i("close");
|
|
3122
3122
|
}, u = () => {
|
|
3123
3123
|
e.closeOnClickOverlay && l();
|
|
3124
|
-
}, p =
|
|
3125
|
-
return
|
|
3124
|
+
}, p = C("");
|
|
3125
|
+
return A(() => e.show, (e) => {
|
|
3126
3126
|
e ? (p.value = document.body.style.overflow, document.body.style.overflow = "hidden", i("open")) : document.body.style.overflow = p.value;
|
|
3127
|
-
}, { immediate: !0 }),
|
|
3127
|
+
}, { immediate: !0 }), b(() => {
|
|
3128
3128
|
e.show && (document.body.style.overflow = p.value);
|
|
3129
|
-
}), (r, i) => (
|
|
3130
|
-
default:
|
|
3129
|
+
}), (r, i) => (x(), a(t, { to: "body" }, [f(n, { name: "drawer-fade" }, {
|
|
3130
|
+
default: j(() => [e.show ? (x(), s("div", {
|
|
3131
3131
|
key: 0,
|
|
3132
3132
|
class: "drawer-overlay",
|
|
3133
|
-
style:
|
|
3134
|
-
onClick:
|
|
3133
|
+
style: _({ zIndex: e.zIndex }),
|
|
3134
|
+
onClick: N(u, ["self"])
|
|
3135
3135
|
}, [c("div", {
|
|
3136
|
-
class:
|
|
3137
|
-
style:
|
|
3136
|
+
class: g(["drawer-container", [`placement-${e.placement}`]]),
|
|
3137
|
+
style: _({ width: e.width })
|
|
3138
3138
|
}, [
|
|
3139
|
-
c("header",
|
|
3139
|
+
c("header", ki, [c("h3", Ai, [T(r.$slots, "title", {}, () => [d(E(e.title), 1)], !0)]), e.showClose ? (x(), s("button", {
|
|
3140
3140
|
key: 0,
|
|
3141
3141
|
class: "close-btn",
|
|
3142
3142
|
onClick: l
|
|
@@ -3148,18 +3148,18 @@ var $n = { class: "icon-wrap" }, er = ["innerHTML"], tr = {
|
|
|
3148
3148
|
fill: "currentColor",
|
|
3149
3149
|
d: "M19 6.41L17.59 5L12 10.59L6.41 5L5 6.41L10.59 12L5 17.59L6.41 19L12 13.41L17.59 19L19 17.59L13.41 12L19 6.41Z"
|
|
3150
3150
|
})], -1)]])) : o("", !0)]),
|
|
3151
|
-
c("main",
|
|
3152
|
-
r.$slots.footer ? (
|
|
3151
|
+
c("main", ji, [T(r.$slots, "default", {}, void 0, !0)]),
|
|
3152
|
+
r.$slots.footer ? (x(), s("footer", Mi, [T(r.$slots, "footer", {}, void 0, !0)])) : o("", !0)
|
|
3153
3153
|
], 6)], 4)) : o("", !0)]),
|
|
3154
3154
|
_: 3
|
|
3155
3155
|
})]));
|
|
3156
3156
|
}
|
|
3157
|
-
}), [["__scopeId", "data-v-f8c0a0bb"]]),
|
|
3158
|
-
function
|
|
3157
|
+
}), [["__scopeId", "data-v-f8c0a0bb"]]), Pi = 0, Fi = S([]);
|
|
3158
|
+
function Ii() {
|
|
3159
3159
|
let e = function(e, t = {}) {
|
|
3160
|
-
let n = ++
|
|
3160
|
+
let n = ++Pi;
|
|
3161
3161
|
return new Promise((r) => {
|
|
3162
|
-
|
|
3162
|
+
Fi.push({
|
|
3163
3163
|
id: n,
|
|
3164
3164
|
type: "alert",
|
|
3165
3165
|
message: e,
|
|
@@ -3185,8 +3185,8 @@ function Fi() {
|
|
|
3185
3185
|
});
|
|
3186
3186
|
function t(e, t = {}) {
|
|
3187
3187
|
return new Promise((n) => {
|
|
3188
|
-
let r = ++
|
|
3189
|
-
|
|
3188
|
+
let r = ++Pi;
|
|
3189
|
+
Fi.push({
|
|
3190
3190
|
id: r,
|
|
3191
3191
|
type: "confirm",
|
|
3192
3192
|
message: e,
|
|
@@ -3199,10 +3199,10 @@ function Fi() {
|
|
|
3199
3199
|
});
|
|
3200
3200
|
}
|
|
3201
3201
|
function n() {
|
|
3202
|
-
for (;
|
|
3202
|
+
for (; Fi.length > 0;) Fi.shift().resolve(!1);
|
|
3203
3203
|
}
|
|
3204
3204
|
return {
|
|
3205
|
-
alerts:
|
|
3205
|
+
alerts: Fi,
|
|
3206
3206
|
alert: e,
|
|
3207
3207
|
confirm: t,
|
|
3208
3208
|
clearAlerts: n
|
|
@@ -3210,13 +3210,13 @@ function Fi() {
|
|
|
3210
3210
|
}
|
|
3211
3211
|
//#endregion
|
|
3212
3212
|
//#region src/components/NAlert.vue?vue&type=script&setup=true&lang.ts
|
|
3213
|
-
var
|
|
3213
|
+
var Li = { class: "cards-wrapper" }, Ri = ["innerHTML"], zi = { class: "card-body" }, Bi = {
|
|
3214
3214
|
key: 0,
|
|
3215
3215
|
class: "card-title"
|
|
3216
|
-
},
|
|
3216
|
+
}, Vi = { class: "card-message" }, Hi = { class: "card-footer" }, Ui = ["onClick"], Wi = ["onClick"], Gi = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3217
3217
|
__name: "NAlert",
|
|
3218
3218
|
setup(n) {
|
|
3219
|
-
let { alerts: r, clearAlerts: i } =
|
|
3219
|
+
let { alerts: r, clearAlerts: i } = Ii(), l = {
|
|
3220
3220
|
success: "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"72\" height=\"72\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><circle cx=\"12\" cy=\"12\" r=\"10\"/><path d=\"M8 12l3 3 5-6\"/></svg>",
|
|
3221
3221
|
warning: "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"72\" height=\"72\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3\"/><path d=\"M12 9v4\"/><path d=\"M12 17h.01\"/></svg>",
|
|
3222
3222
|
danger: "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"72\" height=\"72\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><circle cx=\"12\" cy=\"12\" r=\"10\"/><path d=\"m15 9-6 6\"/><path d=\"m9 9 6 6\"/></svg>",
|
|
@@ -3251,35 +3251,924 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3251
3251
|
let t = r[r.length - 1];
|
|
3252
3252
|
t && (e.key === "Enter" ? (e.preventDefault(), f(t)) : e.key === "Escape" && (e.preventDefault(), t.type === "confirm" ? p(t) : f(t)));
|
|
3253
3253
|
}
|
|
3254
|
-
return
|
|
3254
|
+
return y(() => document.addEventListener("keydown", m)), b(() => {
|
|
3255
3255
|
document.removeEventListener("keydown", m), i();
|
|
3256
|
-
}), (n, i) => (
|
|
3256
|
+
}), (n, i) => (x(), a(t, { to: "body" }, [c("div", { class: g(["backdrop", { open: D(r).length > 0 }]) }, null, 2), c("div", { class: g(["alert-stack", { open: D(r).length > 0 }]) }, [c("div", Li, [(x(!0), s(e, null, w(D(r), (e, t) => (x(), s("div", {
|
|
3257
3257
|
key: e.id,
|
|
3258
|
-
class:
|
|
3259
|
-
style:
|
|
3258
|
+
class: g(["alert-card", `status-${e.status}`]),
|
|
3259
|
+
style: _(d(t))
|
|
3260
3260
|
}, [
|
|
3261
3261
|
c("div", {
|
|
3262
3262
|
class: "card-icon",
|
|
3263
3263
|
innerHTML: u(e)
|
|
3264
|
-
}, null, 8,
|
|
3265
|
-
c("div",
|
|
3266
|
-
c("div",
|
|
3264
|
+
}, null, 8, Ri),
|
|
3265
|
+
c("div", zi, [e.title ? (x(), s("p", Bi, E(e.title), 1)) : o("", !0), c("p", Vi, E(e.message), 1)]),
|
|
3266
|
+
c("div", Hi, [e.type === "confirm" ? (x(), s("button", {
|
|
3267
3267
|
key: 0,
|
|
3268
3268
|
class: "btn btn-cancel",
|
|
3269
3269
|
onClick: (t) => p(e)
|
|
3270
|
-
},
|
|
3271
|
-
class:
|
|
3270
|
+
}, E(e.cancelText), 9, Ui)) : o("", !0), c("button", {
|
|
3271
|
+
class: g(["btn btn-confirm", `btn-${e.status}`]),
|
|
3272
3272
|
onClick: (t) => f(e)
|
|
3273
|
-
},
|
|
3273
|
+
}, E(e.confirmText), 11, Wi)])
|
|
3274
3274
|
], 6))), 128))])], 2)]));
|
|
3275
3275
|
}
|
|
3276
|
-
}), [["__scopeId", "data-v-20105bbb"]])
|
|
3276
|
+
}), [["__scopeId", "data-v-20105bbb"]]);
|
|
3277
|
+
//#endregion
|
|
3278
|
+
//#region src/composables/useDisclosure.ts
|
|
3279
|
+
function Ki() {
|
|
3280
|
+
let e = C(!1);
|
|
3281
|
+
function t() {
|
|
3282
|
+
e.value = !0;
|
|
3283
|
+
}
|
|
3284
|
+
function n() {
|
|
3285
|
+
e.value = !1;
|
|
3286
|
+
}
|
|
3287
|
+
return [
|
|
3288
|
+
e,
|
|
3289
|
+
t,
|
|
3290
|
+
n
|
|
3291
|
+
];
|
|
3292
|
+
}
|
|
3293
|
+
//#endregion
|
|
3294
|
+
//#region src/components/NVideoSelect.vue?vue&type=script&setup=true&lang.ts
|
|
3295
|
+
var qi = {
|
|
3296
|
+
key: 0,
|
|
3297
|
+
class: "head"
|
|
3298
|
+
}, Ji = ["textContent"], Yi = {
|
|
3299
|
+
key: 1,
|
|
3300
|
+
class: "count-chip"
|
|
3301
|
+
}, Xi = { class: "grid" }, Zi = ["textContent"], Qi = ["textContent"], $i = ["onClick"], ea = ["src"], ta = {
|
|
3302
|
+
key: 1,
|
|
3303
|
+
class: "placeholder-label"
|
|
3304
|
+
}, na = { class: "duration" }, ra = { class: "card-body" }, ia = ["title"], aa = { class: "file-meta" }, oa = { class: "card-actions" }, sa = ["onClick"], ca = ["disabled", "onClick"], la = { class: "vi-modal-card" }, ua = { class: "vi-modal-media" }, da = ["src"], fa = {
|
|
3305
|
+
key: 1,
|
|
3306
|
+
class: "vi-modal-placeholder"
|
|
3307
|
+
}, pa = { class: "vi-modal-bar" }, ma = { class: "vi-modal-info" }, ha = { class: "modal-name" }, ga = { class: "modal-meta" }, _a = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3308
|
+
__name: "NVideoSelect",
|
|
3309
|
+
props: {
|
|
3310
|
+
modelValue: { default: () => [] },
|
|
3311
|
+
accept: { default: "video/*" },
|
|
3312
|
+
multiple: {
|
|
3313
|
+
type: Boolean,
|
|
3314
|
+
default: !1
|
|
3315
|
+
},
|
|
3316
|
+
maxSize: { default: 0 },
|
|
3317
|
+
disabled: {
|
|
3318
|
+
type: Boolean,
|
|
3319
|
+
default: !1
|
|
3320
|
+
},
|
|
3321
|
+
title: { default: "" },
|
|
3322
|
+
showCount: {
|
|
3323
|
+
type: Boolean,
|
|
3324
|
+
default: !1
|
|
3325
|
+
},
|
|
3326
|
+
emptyTitle: { default: "將影片拖放到這裡" },
|
|
3327
|
+
emptyHint: { default: "或點擊以選擇檔案 · 支援 MP4 / MOV / WebM,可一次多支" }
|
|
3328
|
+
},
|
|
3329
|
+
emits: [
|
|
3330
|
+
"update:modelValue",
|
|
3331
|
+
"change",
|
|
3332
|
+
"add",
|
|
3333
|
+
"remove",
|
|
3334
|
+
"error"
|
|
3335
|
+
],
|
|
3336
|
+
setup(r, { emit: l }) {
|
|
3337
|
+
let p = l, h = C(!1), _ = C(null), [y, b, S] = Ki(), { confirm: T } = Ii(), O = i(() => r.modelValue.length), k = (e) => e == null ? "—" : e < 1024 ? e + " B" : e < 1048576 ? (e / 1024).toFixed(0) + " KB" : e < 1073741824 ? (e / 1048576).toFixed(1) + " MB" : (e / 1073741824).toFixed(2) + " GB", M = (e) => {
|
|
3338
|
+
if (e == null || isNaN(e)) return "0:00";
|
|
3339
|
+
let t = Math.round(e), n = Math.floor(t / 60), r = t % 60;
|
|
3340
|
+
return n + ":" + (r < 10 ? "0" : "") + r;
|
|
3341
|
+
}, P = (e) => e.width && e.height ? e.width + "×" + e.height : "—", ee = () => typeof crypto < "u" && "randomUUID" in crypto ? crypto.randomUUID() : "v" + Math.random().toString(36).slice(2, 9), F = (e) => {
|
|
3342
|
+
let t = r.accept.split(",").map((e) => e.trim().toLowerCase()).filter(Boolean);
|
|
3343
|
+
if (t.length === 0) return e.type.startsWith("video/");
|
|
3344
|
+
let n = e.type.toLowerCase(), i = e.name.toLowerCase();
|
|
3345
|
+
return t.some((e) => e.startsWith(".") ? i.endsWith(e) : e.endsWith("/*") ? n.startsWith(e.slice(0, -1)) : n === e);
|
|
3346
|
+
}, I = (e) => {
|
|
3347
|
+
if (!e.url) return;
|
|
3348
|
+
let t = document.createElement("video");
|
|
3349
|
+
t.preload = "metadata";
|
|
3350
|
+
let n = () => {
|
|
3351
|
+
if (r.modelValue.some((t) => t.id === e.id)) {
|
|
3352
|
+
let n = r.modelValue.map((n) => n.id === e.id ? {
|
|
3353
|
+
...n,
|
|
3354
|
+
duration: t.duration,
|
|
3355
|
+
width: t.videoWidth,
|
|
3356
|
+
height: t.videoHeight
|
|
3357
|
+
} : n);
|
|
3358
|
+
p("update:modelValue", n), p("change", n);
|
|
3359
|
+
}
|
|
3360
|
+
t.removeEventListener("loadedmetadata", n), t.removeAttribute("src"), t.load();
|
|
3361
|
+
};
|
|
3362
|
+
t.addEventListener("loadedmetadata", n), t.src = e.url;
|
|
3363
|
+
}, L = (e) => {
|
|
3364
|
+
if (r.disabled) return;
|
|
3365
|
+
let t = [], n = !1;
|
|
3366
|
+
if (Array.prototype.forEach.call(e, (e) => {
|
|
3367
|
+
if (!F(e)) {
|
|
3368
|
+
p("error", {
|
|
3369
|
+
type: "type",
|
|
3370
|
+
file: e
|
|
3371
|
+
});
|
|
3372
|
+
return;
|
|
3373
|
+
}
|
|
3374
|
+
if (r.maxSize > 0 && e.size > r.maxSize * 1024 * 1024) {
|
|
3375
|
+
p("error", {
|
|
3376
|
+
type: "size",
|
|
3377
|
+
file: e
|
|
3378
|
+
});
|
|
3379
|
+
return;
|
|
3380
|
+
}
|
|
3381
|
+
if (!r.multiple && r.modelValue.length + t.length >= 1) {
|
|
3382
|
+
n ||= (p("error", {
|
|
3383
|
+
type: "count",
|
|
3384
|
+
file: e
|
|
3385
|
+
}), !0);
|
|
3386
|
+
return;
|
|
3387
|
+
}
|
|
3388
|
+
t.push({
|
|
3389
|
+
id: ee(),
|
|
3390
|
+
file: e,
|
|
3391
|
+
name: e.name,
|
|
3392
|
+
size: e.size,
|
|
3393
|
+
duration: null,
|
|
3394
|
+
width: null,
|
|
3395
|
+
height: null,
|
|
3396
|
+
url: URL.createObjectURL(e)
|
|
3397
|
+
});
|
|
3398
|
+
}), t.length === 0) return;
|
|
3399
|
+
let i = [...r.modelValue, ...t];
|
|
3400
|
+
p("update:modelValue", i), p("change", i), p("add", t), t.forEach(I);
|
|
3401
|
+
}, te = async () => {
|
|
3402
|
+
if (!r.disabled) if (r.multiple) {
|
|
3403
|
+
let e = await $.input.custom(r.accept, !0);
|
|
3404
|
+
if (e.length === 0) return;
|
|
3405
|
+
L(e.map((e) => e.file));
|
|
3406
|
+
} else {
|
|
3407
|
+
let e = await $.input.custom(r.accept, !1);
|
|
3408
|
+
if (!e) return;
|
|
3409
|
+
L([e.file]);
|
|
3410
|
+
}
|
|
3411
|
+
}, R = async (e) => {
|
|
3412
|
+
if (r.disabled) return;
|
|
3413
|
+
let t = r.modelValue.find((t) => t.id === e);
|
|
3414
|
+
if (!t || !await T(`確定要移除「${t.name}」嗎?`, {
|
|
3415
|
+
title: "移除影片",
|
|
3416
|
+
status: "danger",
|
|
3417
|
+
confirmText: "移除",
|
|
3418
|
+
cancelText: "取消"
|
|
3419
|
+
})) return;
|
|
3420
|
+
t.url && URL.revokeObjectURL(t.url);
|
|
3421
|
+
let n = r.modelValue.filter((t) => t.id !== e);
|
|
3422
|
+
p("update:modelValue", n), p("change", n), p("remove", t);
|
|
3423
|
+
}, z = (e) => {
|
|
3424
|
+
_.value = e, b();
|
|
3425
|
+
}, B = () => {
|
|
3426
|
+
S();
|
|
3427
|
+
}, V = i(() => {
|
|
3428
|
+
let e = _.value;
|
|
3429
|
+
return e ? [
|
|
3430
|
+
k(e.size),
|
|
3431
|
+
P(e),
|
|
3432
|
+
M(e.duration)
|
|
3433
|
+
].join(" · ") : "";
|
|
3434
|
+
}), H = (e) => {
|
|
3435
|
+
e.key === "Escape" && B();
|
|
3436
|
+
}, U = "";
|
|
3437
|
+
A(y, (e) => {
|
|
3438
|
+
e ? (U = document.body.style.overflow, document.body.style.overflow = "hidden", document.addEventListener("keydown", H)) : (document.body.style.overflow = U, document.removeEventListener("keydown", H));
|
|
3439
|
+
}), v(() => {
|
|
3440
|
+
document.body.style.overflow = U, document.removeEventListener("keydown", H), r.modelValue.forEach((e) => {
|
|
3441
|
+
e.url && URL.revokeObjectURL(e.url);
|
|
3442
|
+
});
|
|
3443
|
+
});
|
|
3444
|
+
let W = {
|
|
3445
|
+
onClick: te,
|
|
3446
|
+
onDragenter: (e) => {
|
|
3447
|
+
r.disabled || (e.preventDefault(), h.value = !0);
|
|
3448
|
+
},
|
|
3449
|
+
onDragover: (e) => e.preventDefault(),
|
|
3450
|
+
onDragleave: (e) => {
|
|
3451
|
+
e.preventDefault(), h.value = !1;
|
|
3452
|
+
},
|
|
3453
|
+
onDrop: (e) => {
|
|
3454
|
+
r.disabled || (e.preventDefault(), h.value = !1, e.dataTransfer?.files?.length && L(e.dataTransfer.files));
|
|
3455
|
+
}
|
|
3456
|
+
};
|
|
3457
|
+
return (i, l) => (x(), s("div", { class: g(["video-input", { "is-disabled": r.disabled }]) }, [
|
|
3458
|
+
r.title || r.showCount ? (x(), s("div", qi, [r.title ? (x(), s("span", {
|
|
3459
|
+
key: 0,
|
|
3460
|
+
class: "title",
|
|
3461
|
+
textContent: E(r.title)
|
|
3462
|
+
}, null, 8, Ji)) : o("", !0), r.showCount ? (x(), s("span", Yi, E(O.value) + " 支", 1)) : o("", !0)])) : o("", !0),
|
|
3463
|
+
c("div", Xi, [O.value === 0 ? (x(), s("div", m({
|
|
3464
|
+
key: 0,
|
|
3465
|
+
class: ["empty", { "is-drag": h.value }]
|
|
3466
|
+
}, W), [
|
|
3467
|
+
l[0] ||= u("<span class=\"icon\" aria-hidden=\"true\" data-v-409ed1e3><svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.7\" stroke-linecap=\"round\" stroke-linejoin=\"round\" data-v-409ed1e3><path d=\"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4\" data-v-409ed1e3></path><path d=\"M7 9l5-5 5 5\" data-v-409ed1e3></path><path d=\"M12 4v12\" data-v-409ed1e3></path></svg></span>", 1),
|
|
3468
|
+
c("h3", { textContent: E(r.emptyTitle) }, null, 8, Zi),
|
|
3469
|
+
c("p", { textContent: E(r.emptyHint) }, null, 8, Qi)
|
|
3470
|
+
], 16)) : (x(), s(e, { key: 1 }, [(x(!0), s(e, null, w(r.modelValue, (e) => (x(), s("div", {
|
|
3471
|
+
key: e.id,
|
|
3472
|
+
class: "card"
|
|
3473
|
+
}, [c("div", {
|
|
3474
|
+
class: g(["thumb", { placeholder: !e.url }]),
|
|
3475
|
+
onClick: (t) => z(e)
|
|
3476
|
+
}, [
|
|
3477
|
+
e.url ? (x(), s("video", {
|
|
3478
|
+
key: 0,
|
|
3479
|
+
src: e.url + "#t=0.5",
|
|
3480
|
+
muted: "",
|
|
3481
|
+
preload: "metadata"
|
|
3482
|
+
}, null, 8, ea)) : (x(), s("div", ta, "縮圖預覽")),
|
|
3483
|
+
l[1] ||= c("div", {
|
|
3484
|
+
class: "play",
|
|
3485
|
+
"aria-hidden": "true"
|
|
3486
|
+
}, [c("svg", {
|
|
3487
|
+
viewBox: "0 0 24 24",
|
|
3488
|
+
fill: "currentColor"
|
|
3489
|
+
}, [c("path", { d: "M8 5v14l11-7z" })])], -1),
|
|
3490
|
+
c("div", na, E(M(e.duration)), 1)
|
|
3491
|
+
], 10, $i), c("div", ra, [
|
|
3492
|
+
c("div", {
|
|
3493
|
+
class: "file-name",
|
|
3494
|
+
title: e.name
|
|
3495
|
+
}, E(e.name), 9, ia),
|
|
3496
|
+
c("div", aa, [
|
|
3497
|
+
c("span", null, E(k(e.size)), 1),
|
|
3498
|
+
l[2] ||= c("span", { class: "dot-separator" }, null, -1),
|
|
3499
|
+
c("span", null, E(P(e)), 1)
|
|
3500
|
+
]),
|
|
3501
|
+
c("div", oa, [c("button", {
|
|
3502
|
+
class: "action preview",
|
|
3503
|
+
onClick: (t) => z(e)
|
|
3504
|
+
}, [...l[3] ||= [c("svg", {
|
|
3505
|
+
viewBox: "0 0 24 24",
|
|
3506
|
+
fill: "none",
|
|
3507
|
+
stroke: "currentColor",
|
|
3508
|
+
"stroke-width": "2",
|
|
3509
|
+
"stroke-linecap": "round",
|
|
3510
|
+
"stroke-linejoin": "round"
|
|
3511
|
+
}, [c("path", { d: "M2 12s3.5-7 10-7 10 7 10 7-3.5 7-10 7-10-7-10-7z" }), c("circle", {
|
|
3512
|
+
cx: "12",
|
|
3513
|
+
cy: "12",
|
|
3514
|
+
r: "3"
|
|
3515
|
+
})], -1), d(" 預覽 ", -1)]], 8, sa), c("button", {
|
|
3516
|
+
class: "action delete",
|
|
3517
|
+
"aria-label": "刪除",
|
|
3518
|
+
disabled: r.disabled,
|
|
3519
|
+
onClick: N((t) => R(e.id), ["stop"])
|
|
3520
|
+
}, [...l[4] ||= [c("svg", {
|
|
3521
|
+
viewBox: "0 0 24 24",
|
|
3522
|
+
fill: "none",
|
|
3523
|
+
stroke: "currentColor",
|
|
3524
|
+
"stroke-width": "2",
|
|
3525
|
+
"stroke-linecap": "round",
|
|
3526
|
+
"stroke-linejoin": "round"
|
|
3527
|
+
}, [c("path", { d: "M3 6h18M8 6V4a1 1 0 0 1 1-1h6a1 1 0 0 1 1 1v2m2 0v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6" }), c("path", { d: "M10 11v6M14 11v6" })], -1)]], 8, ca)])
|
|
3528
|
+
])]))), 128)), c("div", m({ class: ["add-card", { "is-drag": h.value }] }, W), [...l[5] ||= [
|
|
3529
|
+
c("span", {
|
|
3530
|
+
class: "plus",
|
|
3531
|
+
"aria-hidden": "true"
|
|
3532
|
+
}, [c("svg", {
|
|
3533
|
+
viewBox: "0 0 24 24",
|
|
3534
|
+
fill: "none",
|
|
3535
|
+
stroke: "currentColor",
|
|
3536
|
+
"stroke-width": "2.2",
|
|
3537
|
+
"stroke-linecap": "round",
|
|
3538
|
+
"stroke-linejoin": "round"
|
|
3539
|
+
}, [c("path", { d: "M12 5v14M5 12h14" })])], -1),
|
|
3540
|
+
c("strong", null, "新增影片", -1),
|
|
3541
|
+
c("span", { class: "hint" }, "點擊或拖放檔案 · MP4 / MOV / WebM", -1)
|
|
3542
|
+
]], 16)], 64))]),
|
|
3543
|
+
(x(), a(t, { to: "body" }, [f(n, { name: "vi-modal" }, {
|
|
3544
|
+
default: j(() => [D(y) ? (x(), s("div", {
|
|
3545
|
+
key: 0,
|
|
3546
|
+
class: "vi-modal",
|
|
3547
|
+
onClick: N(B, ["self"])
|
|
3548
|
+
}, [c("div", la, [c("div", ua, [_.value?.url ? (x(), s("video", {
|
|
3549
|
+
key: 0,
|
|
3550
|
+
src: _.value.url,
|
|
3551
|
+
controls: "",
|
|
3552
|
+
autoplay: "",
|
|
3553
|
+
playsinline: "",
|
|
3554
|
+
controlslist: "nofullscreen nodownload noremoteplayback noplaybackrate",
|
|
3555
|
+
disablepictureinpicture: ""
|
|
3556
|
+
}, null, 8, da)) : (x(), s("div", fa, " 示範影片 · 上傳真實檔案即可在此播放 "))]), c("div", pa, [c("div", ma, [c("div", ha, E(_.value?.name), 1), c("div", ga, E(V.value), 1)]), c("button", {
|
|
3557
|
+
class: "vi-modal-close",
|
|
3558
|
+
"aria-label": "關閉",
|
|
3559
|
+
onClick: B
|
|
3560
|
+
}, [...l[6] ||= [c("svg", {
|
|
3561
|
+
viewBox: "0 0 24 24",
|
|
3562
|
+
fill: "none",
|
|
3563
|
+
stroke: "currentColor",
|
|
3564
|
+
"stroke-width": "2.2",
|
|
3565
|
+
"stroke-linecap": "round",
|
|
3566
|
+
"stroke-linejoin": "round"
|
|
3567
|
+
}, [c("path", { d: "M18 6 6 18M6 6l12 12" })], -1)]])])])])) : o("", !0)]),
|
|
3568
|
+
_: 1
|
|
3569
|
+
})]))
|
|
3570
|
+
], 2));
|
|
3571
|
+
}
|
|
3572
|
+
}), [["__scopeId", "data-v-409ed1e3"]]), va = {
|
|
3573
|
+
key: 0,
|
|
3574
|
+
class: "head"
|
|
3575
|
+
}, ya = ["textContent"], ba = {
|
|
3576
|
+
key: 1,
|
|
3577
|
+
class: "count-chip"
|
|
3578
|
+
}, xa = { class: "grid" }, Sa = ["textContent"], Ca = ["textContent"], wa = ["onClick"], Ta = ["src", "alt"], Ea = {
|
|
3579
|
+
key: 1,
|
|
3580
|
+
class: "placeholder-label"
|
|
3581
|
+
}, Da = { class: "card-body" }, Oa = ["title"], ka = { class: "file-meta" }, Aa = { class: "card-actions" }, ja = ["onClick"], Ma = ["disabled", "onClick"], Na = { class: "ii-modal-card" }, Pa = { class: "ii-modal-media" }, Fa = ["src", "alt"], Ia = {
|
|
3582
|
+
key: 1,
|
|
3583
|
+
class: "ii-modal-ph"
|
|
3584
|
+
}, La = { class: "ii-modal-bar" }, Ra = { class: "ii-modal-info" }, za = { class: "modal-name" }, Ba = { class: "modal-meta" }, Va = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3585
|
+
__name: "NImageSelect",
|
|
3586
|
+
props: {
|
|
3587
|
+
modelValue: { default: () => [] },
|
|
3588
|
+
accept: { default: "image/*" },
|
|
3589
|
+
multiple: {
|
|
3590
|
+
type: Boolean,
|
|
3591
|
+
default: !1
|
|
3592
|
+
},
|
|
3593
|
+
maxSize: { default: 0 },
|
|
3594
|
+
disabled: {
|
|
3595
|
+
type: Boolean,
|
|
3596
|
+
default: !1
|
|
3597
|
+
},
|
|
3598
|
+
title: { default: "" },
|
|
3599
|
+
showCount: {
|
|
3600
|
+
type: Boolean,
|
|
3601
|
+
default: !1
|
|
3602
|
+
},
|
|
3603
|
+
emptyTitle: { default: "將圖片拖放到這裡" },
|
|
3604
|
+
emptyHint: { default: "或點擊以選擇檔案 · 支援 JPG / PNG / WebP / GIF,可一次多張" }
|
|
3605
|
+
},
|
|
3606
|
+
emits: [
|
|
3607
|
+
"update:modelValue",
|
|
3608
|
+
"change",
|
|
3609
|
+
"add",
|
|
3610
|
+
"remove",
|
|
3611
|
+
"error"
|
|
3612
|
+
],
|
|
3613
|
+
setup(r, { emit: l }) {
|
|
3614
|
+
let p = l, h = C(!1), _ = C(null), [y, b, S] = Ki(), { confirm: T } = Ii(), O = i(() => r.modelValue.length), k = (e) => e == null ? "—" : e < 1024 ? e + " B" : e < 1048576 ? (e / 1024).toFixed(0) + " KB" : e < 1073741824 ? (e / 1048576).toFixed(1) + " MB" : (e / 1073741824).toFixed(2) + " GB", M = (e) => e.width && e.height ? e.width + "×" + e.height : "—", P = () => typeof crypto < "u" && "randomUUID" in crypto ? crypto.randomUUID() : "i" + Math.random().toString(36).slice(2, 9), ee = (e) => {
|
|
3615
|
+
let t = r.accept.split(",").map((e) => e.trim().toLowerCase()).filter(Boolean);
|
|
3616
|
+
if (t.length === 0) return e.type.startsWith("image/");
|
|
3617
|
+
let n = e.type.toLowerCase(), i = e.name.toLowerCase();
|
|
3618
|
+
return t.some((e) => e.startsWith(".") ? i.endsWith(e) : e.endsWith("/*") ? n.startsWith(e.slice(0, -1)) : n === e);
|
|
3619
|
+
}, F = (e) => {
|
|
3620
|
+
if (!e.url) return;
|
|
3621
|
+
let t = new Image(), n = () => {
|
|
3622
|
+
if (r.modelValue.some((t) => t.id === e.id)) {
|
|
3623
|
+
let n = r.modelValue.map((n) => n.id === e.id ? {
|
|
3624
|
+
...n,
|
|
3625
|
+
width: t.naturalWidth,
|
|
3626
|
+
height: t.naturalHeight
|
|
3627
|
+
} : n);
|
|
3628
|
+
p("update:modelValue", n), p("change", n);
|
|
3629
|
+
}
|
|
3630
|
+
t.removeEventListener("load", n), t.removeAttribute("src");
|
|
3631
|
+
};
|
|
3632
|
+
t.addEventListener("load", n), t.src = e.url;
|
|
3633
|
+
}, I = (e) => {
|
|
3634
|
+
if (r.disabled) return;
|
|
3635
|
+
let t = [], n = !1;
|
|
3636
|
+
if (Array.prototype.forEach.call(e, (e) => {
|
|
3637
|
+
if (!ee(e)) {
|
|
3638
|
+
p("error", {
|
|
3639
|
+
type: "type",
|
|
3640
|
+
file: e
|
|
3641
|
+
});
|
|
3642
|
+
return;
|
|
3643
|
+
}
|
|
3644
|
+
if (r.maxSize > 0 && e.size > r.maxSize * 1024 * 1024) {
|
|
3645
|
+
p("error", {
|
|
3646
|
+
type: "size",
|
|
3647
|
+
file: e
|
|
3648
|
+
});
|
|
3649
|
+
return;
|
|
3650
|
+
}
|
|
3651
|
+
if (!r.multiple && r.modelValue.length + t.length >= 1) {
|
|
3652
|
+
n ||= (p("error", {
|
|
3653
|
+
type: "count",
|
|
3654
|
+
file: e
|
|
3655
|
+
}), !0);
|
|
3656
|
+
return;
|
|
3657
|
+
}
|
|
3658
|
+
t.push({
|
|
3659
|
+
id: P(),
|
|
3660
|
+
file: e,
|
|
3661
|
+
name: e.name,
|
|
3662
|
+
size: e.size,
|
|
3663
|
+
width: null,
|
|
3664
|
+
height: null,
|
|
3665
|
+
url: URL.createObjectURL(e)
|
|
3666
|
+
});
|
|
3667
|
+
}), t.length === 0) return;
|
|
3668
|
+
let i = [...r.modelValue, ...t];
|
|
3669
|
+
p("update:modelValue", i), p("change", i), p("add", t), t.forEach(F);
|
|
3670
|
+
}, L = async () => {
|
|
3671
|
+
if (!r.disabled) if (r.multiple) {
|
|
3672
|
+
let e = await $.input.custom(r.accept, !0);
|
|
3673
|
+
if (e.length === 0) return;
|
|
3674
|
+
I(e.map((e) => e.file));
|
|
3675
|
+
} else {
|
|
3676
|
+
let e = await $.input.custom(r.accept, !1);
|
|
3677
|
+
if (!e) return;
|
|
3678
|
+
I([e.file]);
|
|
3679
|
+
}
|
|
3680
|
+
}, te = async (e) => {
|
|
3681
|
+
if (r.disabled) return;
|
|
3682
|
+
let t = r.modelValue.find((t) => t.id === e);
|
|
3683
|
+
if (!t || !await T(`確定要移除「${t.name}」嗎?`, {
|
|
3684
|
+
title: "移除圖片",
|
|
3685
|
+
status: "danger",
|
|
3686
|
+
confirmText: "移除",
|
|
3687
|
+
cancelText: "取消"
|
|
3688
|
+
})) return;
|
|
3689
|
+
t.url && URL.revokeObjectURL(t.url);
|
|
3690
|
+
let n = r.modelValue.filter((t) => t.id !== e);
|
|
3691
|
+
p("update:modelValue", n), p("change", n), p("remove", t);
|
|
3692
|
+
}, R = (e) => {
|
|
3693
|
+
_.value = e, b();
|
|
3694
|
+
}, z = () => {
|
|
3695
|
+
S();
|
|
3696
|
+
}, B = i(() => {
|
|
3697
|
+
let e = _.value;
|
|
3698
|
+
return e ? [k(e.size), M(e)].join(" · ") : "";
|
|
3699
|
+
}), V = (e) => {
|
|
3700
|
+
e.key === "Escape" && z();
|
|
3701
|
+
}, H = "";
|
|
3702
|
+
A(y, (e) => {
|
|
3703
|
+
e ? (H = document.body.style.overflow, document.body.style.overflow = "hidden", document.addEventListener("keydown", V)) : (document.body.style.overflow = H, document.removeEventListener("keydown", V));
|
|
3704
|
+
}), v(() => {
|
|
3705
|
+
document.body.style.overflow = H, document.removeEventListener("keydown", V), r.modelValue.forEach((e) => {
|
|
3706
|
+
e.url && URL.revokeObjectURL(e.url);
|
|
3707
|
+
});
|
|
3708
|
+
});
|
|
3709
|
+
let U = {
|
|
3710
|
+
onClick: L,
|
|
3711
|
+
onDragenter: (e) => {
|
|
3712
|
+
r.disabled || (e.preventDefault(), h.value = !0);
|
|
3713
|
+
},
|
|
3714
|
+
onDragover: (e) => e.preventDefault(),
|
|
3715
|
+
onDragleave: (e) => {
|
|
3716
|
+
e.preventDefault(), h.value = !1;
|
|
3717
|
+
},
|
|
3718
|
+
onDrop: (e) => {
|
|
3719
|
+
r.disabled || (e.preventDefault(), h.value = !1, e.dataTransfer?.files?.length && I(e.dataTransfer.files));
|
|
3720
|
+
}
|
|
3721
|
+
};
|
|
3722
|
+
return (i, l) => (x(), s("div", { class: g(["image-input", { "is-disabled": r.disabled }]) }, [
|
|
3723
|
+
r.title || r.showCount ? (x(), s("div", va, [r.title ? (x(), s("span", {
|
|
3724
|
+
key: 0,
|
|
3725
|
+
class: "title",
|
|
3726
|
+
textContent: E(r.title)
|
|
3727
|
+
}, null, 8, ya)) : o("", !0), r.showCount ? (x(), s("span", ba, E(O.value) + " 張", 1)) : o("", !0)])) : o("", !0),
|
|
3728
|
+
c("div", xa, [O.value === 0 ? (x(), s("div", m({
|
|
3729
|
+
key: 0,
|
|
3730
|
+
class: ["empty", { "is-drag": h.value }]
|
|
3731
|
+
}, U), [
|
|
3732
|
+
l[0] ||= u("<span class=\"icon\" aria-hidden=\"true\" data-v-a1750a96><svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.7\" stroke-linecap=\"round\" stroke-linejoin=\"round\" data-v-a1750a96><rect x=\"3\" y=\"3\" width=\"18\" height=\"18\" rx=\"2\" data-v-a1750a96></rect><circle cx=\"9\" cy=\"9\" r=\"2\" data-v-a1750a96></circle><path d=\"m21 15-3.5-3.5a2 2 0 0 0-2.83 0L4 22\" data-v-a1750a96></path></svg></span>", 1),
|
|
3733
|
+
c("h3", { textContent: E(r.emptyTitle) }, null, 8, Sa),
|
|
3734
|
+
c("p", { textContent: E(r.emptyHint) }, null, 8, Ca)
|
|
3735
|
+
], 16)) : (x(), s(e, { key: 1 }, [(x(!0), s(e, null, w(r.modelValue, (e) => (x(), s("div", {
|
|
3736
|
+
key: e.id,
|
|
3737
|
+
class: "card"
|
|
3738
|
+
}, [c("div", {
|
|
3739
|
+
class: g(["thumb", { placeholder: !e.url }]),
|
|
3740
|
+
onClick: (t) => R(e)
|
|
3741
|
+
}, [e.url ? (x(), s("img", {
|
|
3742
|
+
key: 0,
|
|
3743
|
+
src: e.url,
|
|
3744
|
+
alt: e.name,
|
|
3745
|
+
loading: "lazy"
|
|
3746
|
+
}, null, 8, Ta)) : (x(), s("div", Ea, "縮圖預覽")), l[1] ||= c("div", {
|
|
3747
|
+
class: "zoom",
|
|
3748
|
+
"aria-hidden": "true"
|
|
3749
|
+
}, [c("svg", {
|
|
3750
|
+
viewBox: "0 0 24 24",
|
|
3751
|
+
fill: "none",
|
|
3752
|
+
stroke: "currentColor",
|
|
3753
|
+
"stroke-width": "2",
|
|
3754
|
+
"stroke-linecap": "round",
|
|
3755
|
+
"stroke-linejoin": "round"
|
|
3756
|
+
}, [c("circle", {
|
|
3757
|
+
cx: "11",
|
|
3758
|
+
cy: "11",
|
|
3759
|
+
r: "7"
|
|
3760
|
+
}), c("path", { d: "m21 21-4.3-4.3M11 8v6M8 11h6" })])], -1)], 10, wa), c("div", Da, [
|
|
3761
|
+
c("div", {
|
|
3762
|
+
class: "file-name",
|
|
3763
|
+
title: e.name
|
|
3764
|
+
}, E(e.name), 9, Oa),
|
|
3765
|
+
c("div", ka, [
|
|
3766
|
+
c("span", null, E(k(e.size)), 1),
|
|
3767
|
+
l[2] ||= c("span", { class: "dot-separator" }, null, -1),
|
|
3768
|
+
c("span", null, E(M(e)), 1)
|
|
3769
|
+
]),
|
|
3770
|
+
c("div", Aa, [c("button", {
|
|
3771
|
+
class: "action preview",
|
|
3772
|
+
onClick: (t) => R(e)
|
|
3773
|
+
}, [...l[3] ||= [c("svg", {
|
|
3774
|
+
viewBox: "0 0 24 24",
|
|
3775
|
+
fill: "none",
|
|
3776
|
+
stroke: "currentColor",
|
|
3777
|
+
"stroke-width": "2",
|
|
3778
|
+
"stroke-linecap": "round",
|
|
3779
|
+
"stroke-linejoin": "round"
|
|
3780
|
+
}, [c("path", { d: "M2 12s3.5-7 10-7 10 7 10 7-3.5 7-10 7-10-7-10-7z" }), c("circle", {
|
|
3781
|
+
cx: "12",
|
|
3782
|
+
cy: "12",
|
|
3783
|
+
r: "3"
|
|
3784
|
+
})], -1), d(" 預覽 ", -1)]], 8, ja), c("button", {
|
|
3785
|
+
class: "action delete",
|
|
3786
|
+
"aria-label": "刪除",
|
|
3787
|
+
disabled: r.disabled,
|
|
3788
|
+
onClick: N((t) => te(e.id), ["stop"])
|
|
3789
|
+
}, [...l[4] ||= [c("svg", {
|
|
3790
|
+
viewBox: "0 0 24 24",
|
|
3791
|
+
fill: "none",
|
|
3792
|
+
stroke: "currentColor",
|
|
3793
|
+
"stroke-width": "2",
|
|
3794
|
+
"stroke-linecap": "round",
|
|
3795
|
+
"stroke-linejoin": "round"
|
|
3796
|
+
}, [c("path", { d: "M3 6h18M8 6V4a1 1 0 0 1 1-1h6a1 1 0 0 1 1 1v2m2 0v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6" }), c("path", { d: "M10 11v6M14 11v6" })], -1)]], 8, Ma)])
|
|
3797
|
+
])]))), 128)), c("div", m({ class: ["add-card", { "is-drag": h.value }] }, U), [...l[5] ||= [
|
|
3798
|
+
c("span", {
|
|
3799
|
+
class: "plus",
|
|
3800
|
+
"aria-hidden": "true"
|
|
3801
|
+
}, [c("svg", {
|
|
3802
|
+
viewBox: "0 0 24 24",
|
|
3803
|
+
fill: "none",
|
|
3804
|
+
stroke: "currentColor",
|
|
3805
|
+
"stroke-width": "2.2",
|
|
3806
|
+
"stroke-linecap": "round",
|
|
3807
|
+
"stroke-linejoin": "round"
|
|
3808
|
+
}, [c("path", { d: "M12 5v14M5 12h14" })])], -1),
|
|
3809
|
+
c("strong", null, "新增圖片", -1),
|
|
3810
|
+
c("span", { class: "hint" }, "點擊或拖放檔案 · JPG / PNG / WebP / GIF", -1)
|
|
3811
|
+
]], 16)], 64))]),
|
|
3812
|
+
(x(), a(t, { to: "body" }, [f(n, { name: "ii-modal" }, {
|
|
3813
|
+
default: j(() => [D(y) ? (x(), s("div", {
|
|
3814
|
+
key: 0,
|
|
3815
|
+
class: "ii-modal",
|
|
3816
|
+
onClick: N(z, ["self"])
|
|
3817
|
+
}, [c("div", Na, [c("div", Pa, [_.value?.url ? (x(), s("img", {
|
|
3818
|
+
key: 0,
|
|
3819
|
+
src: _.value.url,
|
|
3820
|
+
alt: _.value.name
|
|
3821
|
+
}, null, 8, Fa)) : (x(), s("div", Ia, " 示範圖片 · 上傳真實檔案即可在此檢視 "))]), c("div", La, [c("div", Ra, [c("div", za, E(_.value?.name), 1), c("div", Ba, E(B.value), 1)]), c("button", {
|
|
3822
|
+
class: "ii-modal-close",
|
|
3823
|
+
"aria-label": "關閉",
|
|
3824
|
+
onClick: z
|
|
3825
|
+
}, [...l[6] ||= [c("svg", {
|
|
3826
|
+
viewBox: "0 0 24 24",
|
|
3827
|
+
fill: "none",
|
|
3828
|
+
stroke: "currentColor",
|
|
3829
|
+
"stroke-width": "2.2",
|
|
3830
|
+
"stroke-linecap": "round",
|
|
3831
|
+
"stroke-linejoin": "round"
|
|
3832
|
+
}, [c("path", { d: "M18 6 6 18M6 6l12 12" })], -1)]])])])])) : o("", !0)]),
|
|
3833
|
+
_: 1
|
|
3834
|
+
})]))
|
|
3835
|
+
], 2));
|
|
3836
|
+
}
|
|
3837
|
+
}), [["__scopeId", "data-v-a1750a96"]]), Ha = {
|
|
3838
|
+
key: 0,
|
|
3839
|
+
class: "head"
|
|
3840
|
+
}, Ua = ["textContent"], Wa = {
|
|
3841
|
+
key: 1,
|
|
3842
|
+
class: "count-chip"
|
|
3843
|
+
}, Ga = ["textContent"], Ka = ["textContent"], qa = {
|
|
3844
|
+
key: 2,
|
|
3845
|
+
class: "list"
|
|
3846
|
+
}, Ja = [
|
|
3847
|
+
"src",
|
|
3848
|
+
"onTimeupdate",
|
|
3849
|
+
"onEnded"
|
|
3850
|
+
], Ya = [
|
|
3851
|
+
"aria-label",
|
|
3852
|
+
"disabled",
|
|
3853
|
+
"onClick"
|
|
3854
|
+
], Xa = {
|
|
3855
|
+
key: 0,
|
|
3856
|
+
viewBox: "0 0 24 24",
|
|
3857
|
+
fill: "currentColor"
|
|
3858
|
+
}, Za = {
|
|
3859
|
+
key: 1,
|
|
3860
|
+
viewBox: "0 0 24 24",
|
|
3861
|
+
fill: "currentColor"
|
|
3862
|
+
}, Qa = { class: "meta" }, $a = ["title"], eo = { class: "sub" }, to = ["onMousedown", "onTouchstart"], no = { class: "time" }, ro = ["disabled", "onClick"], io = { class: "meta" }, ao = { class: "name" }, oo = 256, so = 5, co = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3863
|
+
__name: "NAudioSelect",
|
|
3864
|
+
props: {
|
|
3865
|
+
modelValue: { default: () => [] },
|
|
3866
|
+
accept: { default: ".mp3,.wav,.ogg,.m4a,.aac,.flac,audio/mpeg,audio/wav,audio/ogg,audio/aac,audio/flac" },
|
|
3867
|
+
multiple: {
|
|
3868
|
+
type: Boolean,
|
|
3869
|
+
default: !1
|
|
3870
|
+
},
|
|
3871
|
+
maxSize: { default: 0 },
|
|
3872
|
+
disabled: {
|
|
3873
|
+
type: Boolean,
|
|
3874
|
+
default: !1
|
|
3875
|
+
},
|
|
3876
|
+
title: { default: "" },
|
|
3877
|
+
showCount: {
|
|
3878
|
+
type: Boolean,
|
|
3879
|
+
default: !1
|
|
3880
|
+
},
|
|
3881
|
+
emptyTitle: { default: "將音訊拖放到這裡" },
|
|
3882
|
+
emptyHint: { default: "或點擊以選擇檔案 · 支援 MP3 / WAV / OGG / M4A,可一次多首" }
|
|
3883
|
+
},
|
|
3884
|
+
emits: [
|
|
3885
|
+
"update:modelValue",
|
|
3886
|
+
"change",
|
|
3887
|
+
"add",
|
|
3888
|
+
"remove",
|
|
3889
|
+
"error"
|
|
3890
|
+
],
|
|
3891
|
+
setup(t, { emit: n }) {
|
|
3892
|
+
let r = n, { confirm: a } = Ii(), l = C(!1), d = C([]), f = C(null), p = S({}), h = S({}), y = S({}), b = /* @__PURE__ */ new Map(), T = /* @__PURE__ */ new Map(), D = (e, t) => {
|
|
3893
|
+
t ? b.set(e, t) : b.delete(e);
|
|
3894
|
+
}, O = i(() => t.modelValue.length), k = (e) => e == null ? "—" : e < 1024 ? e + " B" : e < 1048576 ? (e / 1024).toFixed(0) + " KB" : e < 1073741824 ? (e / 1048576).toFixed(1) + " MB" : (e / 1073741824).toFixed(2) + " GB", A = (e) => {
|
|
3895
|
+
if (e == null || isNaN(e)) return "0:00";
|
|
3896
|
+
let t = Math.floor(e), n = Math.floor(t / 60), r = t % 60;
|
|
3897
|
+
return n + ":" + (r < 10 ? "0" : "") + r;
|
|
3898
|
+
}, j = () => typeof crypto < "u" && "randomUUID" in crypto ? crypto.randomUUID() : "a" + Math.random().toString(36).slice(2, 9), M = (e) => {
|
|
3899
|
+
let n = t.accept.split(",").map((e) => e.trim().toLowerCase()).filter(Boolean);
|
|
3900
|
+
if (n.length === 0) return e.type.startsWith("audio/");
|
|
3901
|
+
let r = e.type.toLowerCase(), i = e.name.toLowerCase();
|
|
3902
|
+
return n.some((e) => e.startsWith(".") ? i.endsWith(e) : e.endsWith("/*") ? r.startsWith(e.slice(0, -1)) : r === e);
|
|
3903
|
+
}, P = null, ee = () => (P ||= new (window.AudioContext || window.webkitAudioContext)(), P), F = async (e) => {
|
|
3904
|
+
let t = await e.arrayBuffer(), n = await ee().decodeAudioData(t.slice(0)), r = n.getChannelData(0), i = Math.floor(r.length / oo) || 1, a = Array(oo), o = 0;
|
|
3905
|
+
for (let e = 0; e < oo; e++) {
|
|
3906
|
+
let t = 0, n = e * i, s = Math.min(r.length, n + i);
|
|
3907
|
+
for (let e = n; e < s; e++) {
|
|
3908
|
+
let n = Math.abs(r[e]);
|
|
3909
|
+
n > t && (t = n);
|
|
3910
|
+
}
|
|
3911
|
+
a[e] = t, t > o && (o = t);
|
|
3912
|
+
}
|
|
3913
|
+
let s = o > 0 ? 1 / o : 1;
|
|
3914
|
+
for (let e = 0; e < oo; e++) a[e] = Math.max(.06, a[e] * s);
|
|
3915
|
+
return {
|
|
3916
|
+
peaks: a,
|
|
3917
|
+
duration: n.duration
|
|
3918
|
+
};
|
|
3919
|
+
}, I = (e) => {
|
|
3920
|
+
let t = T.get(e), n = p[e];
|
|
3921
|
+
if (!t || !n) return;
|
|
3922
|
+
let r = t.clientWidth;
|
|
3923
|
+
if (r <= 0) {
|
|
3924
|
+
requestAnimationFrame(() => I(e));
|
|
3925
|
+
return;
|
|
3926
|
+
}
|
|
3927
|
+
let i = Math.max(8, Math.min(n.length, Math.floor((r + 2) / so)));
|
|
3928
|
+
if (h[e] && h[e].length === i) return;
|
|
3929
|
+
let a = Array(i);
|
|
3930
|
+
for (let e = 0; e < i; e++) {
|
|
3931
|
+
let t = Math.floor(e * n.length / i), r = Math.max(t + 1, Math.floor((e + 1) * n.length / i)), o = 0;
|
|
3932
|
+
for (let e = t; e < r; e++) n[e] > o && (o = n[e]);
|
|
3933
|
+
a[e] = o;
|
|
3934
|
+
}
|
|
3935
|
+
h[e] = a;
|
|
3936
|
+
}, L = typeof ResizeObserver < "u" ? new ResizeObserver((e) => {
|
|
3937
|
+
e.forEach((e) => {
|
|
3938
|
+
let t = e.target.dataset.waveId;
|
|
3939
|
+
t && I(t);
|
|
3940
|
+
});
|
|
3941
|
+
}) : null, te = (e, t) => {
|
|
3942
|
+
let n = T.get(e);
|
|
3943
|
+
if (n && L && L.unobserve(n), t) {
|
|
3944
|
+
let n = t;
|
|
3945
|
+
n.dataset.waveId = e, T.set(e, n), L ? L.observe(n) : I(e);
|
|
3946
|
+
} else T.delete(e);
|
|
3947
|
+
}, R = (e) => {
|
|
3948
|
+
if (t.disabled) return;
|
|
3949
|
+
let n = [], i = !1;
|
|
3950
|
+
Array.prototype.forEach.call(e, (e) => {
|
|
3951
|
+
if (!M(e)) {
|
|
3952
|
+
r("error", {
|
|
3953
|
+
type: "type",
|
|
3954
|
+
file: e
|
|
3955
|
+
});
|
|
3956
|
+
return;
|
|
3957
|
+
}
|
|
3958
|
+
if (t.maxSize > 0 && e.size > t.maxSize * 1024 * 1024) {
|
|
3959
|
+
r("error", {
|
|
3960
|
+
type: "size",
|
|
3961
|
+
file: e
|
|
3962
|
+
});
|
|
3963
|
+
return;
|
|
3964
|
+
}
|
|
3965
|
+
if (!t.multiple && t.modelValue.length + n.length + d.value.length >= 1) {
|
|
3966
|
+
i ||= (r("error", {
|
|
3967
|
+
type: "count",
|
|
3968
|
+
file: e
|
|
3969
|
+
}), !0);
|
|
3970
|
+
return;
|
|
3971
|
+
}
|
|
3972
|
+
n.push(e);
|
|
3973
|
+
}), n.length !== 0 && n.forEach((e) => {
|
|
3974
|
+
let n = "p" + j();
|
|
3975
|
+
d.value.push({
|
|
3976
|
+
tag: n,
|
|
3977
|
+
name: e.name
|
|
3978
|
+
}), F(e).then(({ peaks: n, duration: i }) => {
|
|
3979
|
+
let a = {
|
|
3980
|
+
id: j(),
|
|
3981
|
+
file: e,
|
|
3982
|
+
name: e.name,
|
|
3983
|
+
size: e.size,
|
|
3984
|
+
duration: i,
|
|
3985
|
+
url: URL.createObjectURL(e)
|
|
3986
|
+
};
|
|
3987
|
+
p[a.id] = n, y[a.id] = 0;
|
|
3988
|
+
let o = [...t.modelValue, a];
|
|
3989
|
+
r("update:modelValue", o), r("change", o), r("add", [a]);
|
|
3990
|
+
}).catch(() => {
|
|
3991
|
+
r("error", {
|
|
3992
|
+
type: "type",
|
|
3993
|
+
file: e
|
|
3994
|
+
});
|
|
3995
|
+
}).finally(() => {
|
|
3996
|
+
d.value = d.value.filter((e) => e.tag !== n);
|
|
3997
|
+
});
|
|
3998
|
+
});
|
|
3999
|
+
}, z = async () => {
|
|
4000
|
+
if (!t.disabled) if (t.multiple) {
|
|
4001
|
+
let e = await $.input.custom(t.accept, !0);
|
|
4002
|
+
if (e.length === 0) return;
|
|
4003
|
+
R(e.map((e) => e.file));
|
|
4004
|
+
} else {
|
|
4005
|
+
let e = await $.input.custom(t.accept, !1);
|
|
4006
|
+
if (!e) return;
|
|
4007
|
+
R([e.file]);
|
|
4008
|
+
}
|
|
4009
|
+
}, B = async (e) => {
|
|
4010
|
+
if (t.disabled) return;
|
|
4011
|
+
let n = t.modelValue.find((t) => t.id === e);
|
|
4012
|
+
if (!n || !await a(`確定要移除「${n.name}」嗎?`, {
|
|
4013
|
+
title: "移除音訊",
|
|
4014
|
+
status: "danger",
|
|
4015
|
+
confirmText: "移除",
|
|
4016
|
+
cancelText: "取消"
|
|
4017
|
+
})) return;
|
|
4018
|
+
f.value === e && V(), n.url && URL.revokeObjectURL(n.url), delete p[e], delete h[e], delete y[e];
|
|
4019
|
+
let i = t.modelValue.filter((t) => t.id !== e);
|
|
4020
|
+
r("update:modelValue", i), r("change", i), r("remove", n);
|
|
4021
|
+
}, V = () => {
|
|
4022
|
+
let e = f.value;
|
|
4023
|
+
e && b.get(e)?.pause(), f.value = null;
|
|
4024
|
+
}, H = (e) => {
|
|
4025
|
+
let n = b.get(e);
|
|
4026
|
+
if (!n) return;
|
|
4027
|
+
if (f.value === e) {
|
|
4028
|
+
n.pause(), f.value = null;
|
|
4029
|
+
return;
|
|
4030
|
+
}
|
|
4031
|
+
f.value && b.get(f.value)?.pause();
|
|
4032
|
+
let r = t.modelValue.find((t) => t.id === e);
|
|
4033
|
+
(n.ended || r?.duration && n.currentTime >= r.duration) && (n.currentTime = 0), f.value = e, n.play();
|
|
4034
|
+
}, U = (e, t) => {
|
|
4035
|
+
y[e] = t.target.currentTime;
|
|
4036
|
+
}, W = (e) => {
|
|
4037
|
+
f.value === e && (f.value = null), y[e] = 0;
|
|
4038
|
+
}, ne = (e, t) => {
|
|
4039
|
+
let n = b.get(e), r = T.get(e);
|
|
4040
|
+
if (!n || !r || !n.duration || isNaN(n.duration)) return;
|
|
4041
|
+
let i = r.getBoundingClientRect();
|
|
4042
|
+
n.currentTime = Math.min(Math.max((t - i.left) / i.width, 0), 1) * n.duration, y[e] = n.currentTime;
|
|
4043
|
+
}, re = (e, n) => {
|
|
4044
|
+
if (t.disabled) return;
|
|
4045
|
+
n.preventDefault(), ne(e, ("touches" in n ? n.touches[0] : n).clientX);
|
|
4046
|
+
let r = (t) => {
|
|
4047
|
+
ne(e, ("touches" in t ? t.touches[0] : t).clientX);
|
|
4048
|
+
}, i = () => {
|
|
4049
|
+
window.removeEventListener("mousemove", r), window.removeEventListener("mouseup", i), window.removeEventListener("touchmove", r), window.removeEventListener("touchend", i);
|
|
4050
|
+
};
|
|
4051
|
+
window.addEventListener("mousemove", r), window.addEventListener("mouseup", i), window.addEventListener("touchmove", r, { passive: !1 }), window.addEventListener("touchend", i);
|
|
4052
|
+
}, G = (e, t) => {
|
|
4053
|
+
if (!e.duration || isNaN(e.duration)) return !1;
|
|
4054
|
+
let n = h[e.id]?.length || 0;
|
|
4055
|
+
if (n === 0) return !1;
|
|
4056
|
+
let r = (y[e.id] || 0) / e.duration;
|
|
4057
|
+
return (t + .5) / n <= r;
|
|
4058
|
+
};
|
|
4059
|
+
v(() => {
|
|
4060
|
+
t.modelValue.forEach((e) => {
|
|
4061
|
+
e.url && URL.revokeObjectURL(e.url);
|
|
4062
|
+
}), L?.disconnect(), P &&= (P.close(), null);
|
|
4063
|
+
});
|
|
4064
|
+
let ie = {
|
|
4065
|
+
onClick: z,
|
|
4066
|
+
onDragenter: (e) => {
|
|
4067
|
+
t.disabled || (e.preventDefault(), l.value = !0);
|
|
4068
|
+
},
|
|
4069
|
+
onDragover: (e) => e.preventDefault(),
|
|
4070
|
+
onDragleave: (e) => {
|
|
4071
|
+
e.preventDefault(), l.value = !1;
|
|
4072
|
+
},
|
|
4073
|
+
onDrop: (e) => {
|
|
4074
|
+
t.disabled || (e.preventDefault(), l.value = !1, e.dataTransfer?.files?.length && R(e.dataTransfer.files));
|
|
4075
|
+
}
|
|
4076
|
+
};
|
|
4077
|
+
return (n, r) => (x(), s("div", { class: g(["audio-input", { "is-disabled": t.disabled }]) }, [t.title || t.showCount ? (x(), s("div", Ha, [t.title ? (x(), s("span", {
|
|
4078
|
+
key: 0,
|
|
4079
|
+
class: "title",
|
|
4080
|
+
textContent: E(t.title)
|
|
4081
|
+
}, null, 8, Ua)) : o("", !0), t.showCount ? (x(), s("span", Wa, E(O.value) + " 首", 1)) : o("", !0)])) : o("", !0), O.value === 0 && d.value.length === 0 ? (x(), s("div", m({
|
|
4082
|
+
key: 1,
|
|
4083
|
+
class: ["empty", { "is-drag": l.value }]
|
|
4084
|
+
}, ie), [
|
|
4085
|
+
r[0] ||= u("<span class=\"icon\" aria-hidden=\"true\" data-v-c2c7a167><svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.7\" stroke-linecap=\"round\" stroke-linejoin=\"round\" data-v-c2c7a167><path d=\"M9 18V5l12-2v13\" data-v-c2c7a167></path><circle cx=\"6\" cy=\"18\" r=\"3\" data-v-c2c7a167></circle><circle cx=\"18\" cy=\"16\" r=\"3\" data-v-c2c7a167></circle></svg></span>", 1),
|
|
4086
|
+
c("h3", { textContent: E(t.emptyTitle) }, null, 8, Ga),
|
|
4087
|
+
c("p", { textContent: E(t.emptyHint) }, null, 8, Ka)
|
|
4088
|
+
], 16)) : (x(), s("div", qa, [
|
|
4089
|
+
(x(!0), s(e, null, w(t.modelValue, (n) => (x(), s("div", {
|
|
4090
|
+
key: n.id,
|
|
4091
|
+
class: g(["row", { "is-playing": f.value === n.id }])
|
|
4092
|
+
}, [
|
|
4093
|
+
c("audio", {
|
|
4094
|
+
ref_for: !0,
|
|
4095
|
+
ref: (e) => D(n.id, e),
|
|
4096
|
+
src: n.url,
|
|
4097
|
+
preload: "metadata",
|
|
4098
|
+
onTimeupdate: (e) => U(n.id, e),
|
|
4099
|
+
onEnded: (e) => W(n.id)
|
|
4100
|
+
}, null, 40, Ja),
|
|
4101
|
+
c("button", {
|
|
4102
|
+
class: "play-btn",
|
|
4103
|
+
"aria-label": f.value === n.id ? "暫停" : "播放",
|
|
4104
|
+
disabled: !n.url,
|
|
4105
|
+
onClick: (e) => H(n.id)
|
|
4106
|
+
}, [f.value === n.id ? (x(), s("svg", Xa, [...r[1] ||= [c("rect", {
|
|
4107
|
+
x: "6",
|
|
4108
|
+
y: "5",
|
|
4109
|
+
width: "4",
|
|
4110
|
+
height: "14",
|
|
4111
|
+
rx: "1"
|
|
4112
|
+
}, null, -1), c("rect", {
|
|
4113
|
+
x: "14",
|
|
4114
|
+
y: "5",
|
|
4115
|
+
width: "4",
|
|
4116
|
+
height: "14",
|
|
4117
|
+
rx: "1"
|
|
4118
|
+
}, null, -1)]])) : (x(), s("svg", Za, [...r[2] ||= [c("path", { d: "M8 5v14l11-7z" }, null, -1)]]))], 8, Ya),
|
|
4119
|
+
c("div", Qa, [c("div", {
|
|
4120
|
+
class: "name",
|
|
4121
|
+
title: n.name
|
|
4122
|
+
}, E(n.name), 9, $a), c("div", eo, E(k(n.size)) + " · " + E(A(n.duration)), 1)]),
|
|
4123
|
+
c("div", {
|
|
4124
|
+
class: "wave",
|
|
4125
|
+
ref_for: !0,
|
|
4126
|
+
ref: (e) => te(n.id, e),
|
|
4127
|
+
onMousedown: (e) => re(n.id, e),
|
|
4128
|
+
onTouchstart: (e) => re(n.id, e)
|
|
4129
|
+
}, [(x(!0), s(e, null, w(h[n.id] || [], (e, t) => (x(), s("span", {
|
|
4130
|
+
key: t,
|
|
4131
|
+
class: g(["bar", { "is-played": G(n, t) }]),
|
|
4132
|
+
style: _({ height: Math.max(2, Math.round(e * 34)) + "px" })
|
|
4133
|
+
}, null, 6))), 128))], 40, to),
|
|
4134
|
+
c("div", no, E(A(y[n.id] || 0)) + " / " + E(A(n.duration)), 1),
|
|
4135
|
+
c("button", {
|
|
4136
|
+
class: "del-btn",
|
|
4137
|
+
"aria-label": "刪除",
|
|
4138
|
+
disabled: t.disabled,
|
|
4139
|
+
onClick: N((e) => B(n.id), ["stop"])
|
|
4140
|
+
}, [...r[3] ||= [c("svg", {
|
|
4141
|
+
viewBox: "0 0 24 24",
|
|
4142
|
+
fill: "none",
|
|
4143
|
+
stroke: "currentColor",
|
|
4144
|
+
"stroke-width": "1.8",
|
|
4145
|
+
"stroke-linecap": "round",
|
|
4146
|
+
"stroke-linejoin": "round"
|
|
4147
|
+
}, [c("path", { d: "M3 6h18M8 6V4h8v2M6 6l1 14h10l1-14" })], -1)]], 8, ro)
|
|
4148
|
+
], 2))), 128)),
|
|
4149
|
+
(x(!0), s(e, null, w(d.value, (e) => (x(), s("div", {
|
|
4150
|
+
key: e.tag,
|
|
4151
|
+
class: "row is-pending"
|
|
4152
|
+
}, [r[5] ||= c("span", {
|
|
4153
|
+
class: "spin",
|
|
4154
|
+
"aria-hidden": "true"
|
|
4155
|
+
}, [c("svg", {
|
|
4156
|
+
viewBox: "0 0 24 24",
|
|
4157
|
+
fill: "none",
|
|
4158
|
+
stroke: "currentColor",
|
|
4159
|
+
"stroke-width": "2",
|
|
4160
|
+
"stroke-linecap": "round"
|
|
4161
|
+
}, [c("path", { d: "M12 3a9 9 0 1 0 9 9" })])], -1), c("div", io, [c("div", ao, E(e.name), 1), r[4] ||= c("div", { class: "sub" }, "解析波形中…", -1)])]))), 128)),
|
|
4162
|
+
c("div", m({ class: ["add", { "is-drag": l.value }] }, ie), [...r[6] ||= [u("<span class=\"plus\" aria-hidden=\"true\" data-v-c2c7a167><svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\" data-v-c2c7a167><path d=\"M12 5v14M5 12h14\" data-v-c2c7a167></path></svg></span><div class=\"add-text\" data-v-c2c7a167><div class=\"t\" data-v-c2c7a167>新增音訊</div><div class=\"d\" data-v-c2c7a167>點擊或拖放檔案 · MP3 / WAV / OGG / M4A</div></div>", 2)]], 16)
|
|
4163
|
+
]))], 2));
|
|
4164
|
+
}
|
|
4165
|
+
}), [["__scopeId", "data-v-c2c7a167"]]), lo = { class: "header" }, uo = { class: "brand-logo" }, fo = { class: "logo-text" }, po = { class: "logo-icon" }, mo = { class: "nav" }, ho = ["onClick"], go = ["innerHTML"], _o = { class: "nav-list" }, vo = ["href", "onClick"], yo = ["innerHTML"], bo = { class: "nav-text" }, xo = ["href", "onClick"], So = { class: "title no-children" }, Co = ["innerHTML"], wo = { class: "user-capsule" }, To = { class: "user-avatar" }, Eo = ["src"], Do = {
|
|
3277
4166
|
key: 1,
|
|
3278
4167
|
xmlns: "http://www.w3.org/2000/svg",
|
|
3279
4168
|
width: "36",
|
|
3280
4169
|
height: "36",
|
|
3281
4170
|
viewBox: "0 0 36 36"
|
|
3282
|
-
},
|
|
4171
|
+
}, Oo = { class: "user-info" }, ko = { class: "user-name-row" }, Ao = { class: "user-name" }, jo = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3283
4172
|
__name: "NSidebar",
|
|
3284
4173
|
props: {
|
|
3285
4174
|
title: { default: "" },
|
|
@@ -3298,26 +4187,26 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3298
4187
|
"navigate"
|
|
3299
4188
|
],
|
|
3300
4189
|
setup(n, { emit: r }) {
|
|
3301
|
-
let { isMenuExpanded: i, toggleMenu: o, resolveMenuActive: l, resolveItemActive: d } =
|
|
4190
|
+
let { isMenuExpanded: i, toggleMenu: o, resolveMenuActive: l, resolveItemActive: d } = qt(), p = C(!1), m = r, h = (e) => {
|
|
3302
4191
|
n.currentPath !== e.route && m("navigate", e);
|
|
3303
|
-
},
|
|
4192
|
+
}, _ = (e) => {
|
|
3304
4193
|
!e.route || n.currentPath === e.route || m("navigate", {
|
|
3305
4194
|
icon: e.icon,
|
|
3306
4195
|
title: e.title,
|
|
3307
4196
|
route: e.route
|
|
3308
4197
|
});
|
|
3309
4198
|
};
|
|
3310
|
-
return (r,
|
|
3311
|
-
class:
|
|
4199
|
+
return (r, v) => (x(), s("nav", {
|
|
4200
|
+
class: g(["sidebar", {
|
|
3312
4201
|
open: n.isOpen,
|
|
3313
4202
|
"hover-expanded": p.value
|
|
3314
4203
|
}]),
|
|
3315
|
-
onMouseleave:
|
|
4204
|
+
onMouseleave: v[4] ||= (e) => p.value = !1
|
|
3316
4205
|
}, [
|
|
3317
4206
|
c("div", {
|
|
3318
4207
|
class: "arrow",
|
|
3319
|
-
onClick:
|
|
3320
|
-
}, [...
|
|
4208
|
+
onClick: v[0] ||= (e) => m("update:isOpen", !n.isOpen)
|
|
4209
|
+
}, [...v[5] ||= [c("div", { class: "icon" }, [c("svg", {
|
|
3321
4210
|
xmlns: "http://www.w3.org/2000/svg",
|
|
3322
4211
|
width: "18",
|
|
3323
4212
|
height: "18",
|
|
@@ -3330,19 +4219,19 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3330
4219
|
}, [c("path", { d: "m9 18 6-6-6-6" })])], -1)]]),
|
|
3331
4220
|
c("div", {
|
|
3332
4221
|
class: "content",
|
|
3333
|
-
onMouseenter:
|
|
4222
|
+
onMouseenter: v[2] ||= (e) => p.value = !0
|
|
3334
4223
|
}, [
|
|
3335
|
-
|
|
3336
|
-
c("div",
|
|
4224
|
+
T(r.$slots, "header", {}, () => [c("div", lo, [c("div", uo, [c("span", fo, E(n.title), 1), c("span", po, E(n.title.substring(0, 1).toUpperCase()), 1)])])], !0),
|
|
4225
|
+
c("div", mo, [(x(!0), s(e, null, w(n.menus, (t) => (x(), s(e, null, [t.children?.length ? (x(), s("div", {
|
|
3337
4226
|
key: 0,
|
|
3338
|
-
class:
|
|
3339
|
-
open:
|
|
3340
|
-
active:
|
|
4227
|
+
class: g(["menu", {
|
|
4228
|
+
open: D(i)(t.title),
|
|
4229
|
+
active: D(l)(t, n.currentPath)
|
|
3341
4230
|
}])
|
|
3342
4231
|
}, [c("div", {
|
|
3343
4232
|
class: "title",
|
|
3344
|
-
onClick: (e) =>
|
|
3345
|
-
}, [c("div", null, [c("div", { innerHTML: t.icon }, null, 8,
|
|
4233
|
+
onClick: (e) => D(o)(t.title)
|
|
4234
|
+
}, [c("div", null, [c("div", { innerHTML: t.icon }, null, 8, go), c("span", null, E(t.title), 1)]), v[6] ||= c("svg", {
|
|
3346
4235
|
xmlns: "http://www.w3.org/2000/svg",
|
|
3347
4236
|
width: "14",
|
|
3348
4237
|
height: "14",
|
|
@@ -3353,32 +4242,32 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3353
4242
|
"stroke-linecap": "round",
|
|
3354
4243
|
"stroke-linejoin": "round",
|
|
3355
4244
|
class: "icon"
|
|
3356
|
-
}, [c("path", { d: "m9 18 6-6-6-6" })], -1)], 8,
|
|
4245
|
+
}, [c("path", { d: "m9 18 6-6-6-6" })], -1)], 8, ho), c("div", _o, [c("div", null, [(x(!0), s(e, null, w(t.children, (e) => (x(), s("a", {
|
|
3357
4246
|
href: e.route,
|
|
3358
|
-
onClick:
|
|
3359
|
-
}, [c("div", { class:
|
|
4247
|
+
onClick: N((t) => h(e), ["prevent"])
|
|
4248
|
+
}, [c("div", { class: g(["nav-item", { active: D(d)(e, n.currentPath) }]) }, [c("div", { innerHTML: e.icon }, null, 8, yo), c("span", bo, E(e.title), 1)], 2)], 8, vo))), 256))])])], 2)) : (x(), s("div", {
|
|
3360
4249
|
key: 1,
|
|
3361
|
-
class:
|
|
4250
|
+
class: g(["menu", { active: t.route === n.currentPath }])
|
|
3362
4251
|
}, [c("a", {
|
|
3363
4252
|
href: t.route,
|
|
3364
|
-
onClick:
|
|
3365
|
-
}, [c("div",
|
|
3366
|
-
c("div",
|
|
3367
|
-
c("div",
|
|
4253
|
+
onClick: N((e) => _(t), ["prevent"])
|
|
4254
|
+
}, [c("div", So, [c("div", null, [c("div", { innerHTML: t.icon }, null, 8, Co), c("span", null, E(t.title), 1)])])], 8, xo)], 2))], 64))), 256))]),
|
|
4255
|
+
c("div", wo, [T(r.$slots, "user", {}, () => [
|
|
4256
|
+
c("div", To, [n.userAvatarUrl ? (x(), s("img", {
|
|
3368
4257
|
key: 0,
|
|
3369
4258
|
src: n.userAvatarUrl,
|
|
3370
4259
|
alt: "User Avatar"
|
|
3371
|
-
}, null, 8,
|
|
3372
|
-
c("div",
|
|
3373
|
-
f(
|
|
4260
|
+
}, null, 8, Eo)) : (x(), s("svg", Do, [...v[7] ||= [u("<defs data-v-2c73c218><clipPath id=\"avatarClip\" data-v-2c73c218><circle cx=\"18\" cy=\"18\" r=\"18\" data-v-2c73c218></circle></clipPath></defs><circle cx=\"18\" cy=\"18\" r=\"18\" fill=\"#dbeafe\" data-v-2c73c218></circle><g clip-path=\"url(#avatarClip)\" data-v-2c73c218><circle cx=\"18\" cy=\"14\" r=\"6\" fill=\"#2563eb\" data-v-2c73c218></circle><path d=\"M6,34 Q6,24 18,24 Q30,24 30,34\" fill=\"#2563eb\" data-v-2c73c218></path></g>", 3)]]))]),
|
|
4261
|
+
c("div", Oo, [c("div", ko, [c("span", Ao, E(n.userName), 1)])]),
|
|
4262
|
+
f(z, {
|
|
3374
4263
|
class: "logout-btn",
|
|
3375
4264
|
intent: "error",
|
|
3376
4265
|
variant: "ghost",
|
|
3377
4266
|
"radius-size": "full",
|
|
3378
4267
|
padding: "12px",
|
|
3379
|
-
onClick:
|
|
4268
|
+
onClick: v[1] ||= (e) => m("logout")
|
|
3380
4269
|
}, {
|
|
3381
|
-
default:
|
|
4270
|
+
default: j(() => [...v[8] ||= [c("svg", {
|
|
3382
4271
|
xmlns: "http://www.w3.org/2000/svg",
|
|
3383
4272
|
width: "18",
|
|
3384
4273
|
height: "18",
|
|
@@ -3402,13 +4291,13 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3402
4291
|
})
|
|
3403
4292
|
], !0)])
|
|
3404
4293
|
], 32),
|
|
3405
|
-
(
|
|
3406
|
-
class:
|
|
3407
|
-
onClick:
|
|
4294
|
+
(x(), a(t, { to: "body" }, [c("div", {
|
|
4295
|
+
class: g(["overlay", { active: n.isOpen }]),
|
|
4296
|
+
onClick: v[3] ||= (e) => m("update:isOpen", !n.isOpen)
|
|
3408
4297
|
}, null, 2)]))
|
|
3409
4298
|
], 34));
|
|
3410
4299
|
}
|
|
3411
|
-
}), [["__scopeId", "data-v-2c73c218"]]),
|
|
4300
|
+
}), [["__scopeId", "data-v-2c73c218"]]), Mo = { class: "layout" }, No = { class: "main-content" }, Po = { class: "copyright" }, Fo = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3412
4301
|
__name: "NLayout",
|
|
3413
4302
|
props: {
|
|
3414
4303
|
title: { default: "NICKLABS" },
|
|
@@ -3423,13 +4312,13 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3423
4312
|
},
|
|
3424
4313
|
emits: ["logout", "navigate"],
|
|
3425
4314
|
setup(e, { emit: t }) {
|
|
3426
|
-
let n =
|
|
3427
|
-
return (t, i) => (
|
|
4315
|
+
let n = qt(), r = t;
|
|
4316
|
+
return (t, i) => (x(), s("div", Mo, [e.isShowSidebar ? (x(), a(jo, {
|
|
3428
4317
|
key: 0,
|
|
3429
4318
|
title: e.title,
|
|
3430
4319
|
userName: e.userName,
|
|
3431
|
-
isOpen:
|
|
3432
|
-
"onUpdate:isOpen": i[0] ||= (e) =>
|
|
4320
|
+
isOpen: D(n).isSidebarExpanded(),
|
|
4321
|
+
"onUpdate:isOpen": i[0] ||= (e) => D(n).toggleSidebar(),
|
|
3433
4322
|
menus: e.menus,
|
|
3434
4323
|
currentPath: e.currentPath,
|
|
3435
4324
|
onLogout: i[1] ||= (e) => r("logout"),
|
|
@@ -3440,18 +4329,18 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3440
4329
|
"isOpen",
|
|
3441
4330
|
"menus",
|
|
3442
4331
|
"currentPath"
|
|
3443
|
-
])) : o("", !0), c("main",
|
|
4332
|
+
])) : o("", !0), c("main", No, [T(t.$slots, "default", {}, void 0, !0), c("div", Po, E(e.copyright), 1)])]));
|
|
3444
4333
|
}
|
|
3445
|
-
}), [["__scopeId", "data-v-41b1eb44"]]),
|
|
4334
|
+
}), [["__scopeId", "data-v-41b1eb44"]]), Io = { class: "topbar" }, Lo = { class: "topbar-left" }, Ro = { class: "topbar-right" }, zo = {
|
|
3446
4335
|
key: 0,
|
|
3447
4336
|
class: "pill"
|
|
3448
|
-
},
|
|
4337
|
+
}, Bo = {
|
|
3449
4338
|
key: 0,
|
|
3450
4339
|
class: "name"
|
|
3451
|
-
},
|
|
4340
|
+
}, Vo = {
|
|
3452
4341
|
key: 1,
|
|
3453
4342
|
class: "separator"
|
|
3454
|
-
},
|
|
4343
|
+
}, Ho = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3455
4344
|
__name: "NNavigation",
|
|
3456
4345
|
props: {
|
|
3457
4346
|
isShowSidebar: {
|
|
@@ -3476,12 +4365,12 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3476
4365
|
let n = t, r = () => {
|
|
3477
4366
|
document.fullscreenElement ? document.exitFullscreen?.() : document.documentElement.requestFullscreen();
|
|
3478
4367
|
};
|
|
3479
|
-
return (t, i) => (
|
|
4368
|
+
return (t, i) => (x(), s("header", Io, [c("div", Lo, [e.isShowSidebar ? (x(), a(z, {
|
|
3480
4369
|
key: 0,
|
|
3481
4370
|
onClick: i[0] ||= (e) => n("toggleSidebar"),
|
|
3482
4371
|
padding: "8px"
|
|
3483
4372
|
}, {
|
|
3484
|
-
default:
|
|
4373
|
+
default: j(() => [...i[2] ||= [c("svg", {
|
|
3485
4374
|
xmlns: "http://www.w3.org/2000/svg",
|
|
3486
4375
|
width: "24",
|
|
3487
4376
|
height: "24",
|
|
@@ -3497,12 +4386,12 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3497
4386
|
c("path", { d: "M4 19h16" })
|
|
3498
4387
|
], -1)]]),
|
|
3499
4388
|
_: 1
|
|
3500
|
-
})) : o("", !0), e.isShowFullscreen ? (
|
|
4389
|
+
})) : o("", !0), e.isShowFullscreen ? (x(), a(z, {
|
|
3501
4390
|
key: 1,
|
|
3502
4391
|
padding: "8px",
|
|
3503
|
-
onClick:
|
|
4392
|
+
onClick: N(r, ["prevent"])
|
|
3504
4393
|
}, {
|
|
3505
|
-
default:
|
|
4394
|
+
default: j(() => [...i[3] ||= [c("svg", {
|
|
3506
4395
|
xmlns: "http://www.w3.org/2000/svg",
|
|
3507
4396
|
width: "24",
|
|
3508
4397
|
height: "24",
|
|
@@ -3519,16 +4408,16 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3519
4408
|
c("path", { d: "M16 21h3a2 2 0 0 0 2-2v-3" })
|
|
3520
4409
|
], -1)]]),
|
|
3521
4410
|
_: 1
|
|
3522
|
-
})) : o("", !0)]), c("div",
|
|
3523
|
-
e.isShowUser ? (
|
|
3524
|
-
e.isShowUser && e.isShowLogoutButton ? (
|
|
3525
|
-
e.isShowLogoutButton ? (
|
|
4411
|
+
})) : o("", !0)]), c("div", Ro, [e.isShowUser || e.isShowLogoutButton ? (x(), s("div", zo, [
|
|
4412
|
+
e.isShowUser ? (x(), s("span", Bo, "Nick")) : o("", !0),
|
|
4413
|
+
e.isShowUser && e.isShowLogoutButton ? (x(), s("div", Vo)) : o("", !0),
|
|
4414
|
+
e.isShowLogoutButton ? (x(), a(z, {
|
|
3526
4415
|
key: 2,
|
|
3527
4416
|
variant: "mute",
|
|
3528
4417
|
intent: "error",
|
|
3529
|
-
onClick: i[1] ||=
|
|
4418
|
+
onClick: i[1] ||= N((e) => n("logout"), ["prevent"])
|
|
3530
4419
|
}, {
|
|
3531
|
-
default:
|
|
4420
|
+
default: j(() => [...i[4] ||= [c("svg", {
|
|
3532
4421
|
xmlns: "http://www.w3.org/2000/svg",
|
|
3533
4422
|
width: "14",
|
|
3534
4423
|
height: "14",
|
|
@@ -3547,10 +4436,10 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3547
4436
|
})) : o("", !0)
|
|
3548
4437
|
])) : o("", !0)])]));
|
|
3549
4438
|
}
|
|
3550
|
-
}), [["__scopeId", "data-v-f38a4beb"]]),
|
|
4439
|
+
}), [["__scopeId", "data-v-f38a4beb"]]), Uo = { class: "brand" }, Wo = ["src", "alt"], Go = {
|
|
3551
4440
|
key: 1,
|
|
3552
4441
|
class: "icon"
|
|
3553
|
-
},
|
|
4442
|
+
}, Ko = { key: 2 }, qo = { key: 3 }, Jo = /* @__PURE__ */ R(/* @__PURE__ */ p({
|
|
3554
4443
|
__name: "NLoginLayout",
|
|
3555
4444
|
props: {
|
|
3556
4445
|
backgroundImage: { default: "" },
|
|
@@ -3560,43 +4449,43 @@ var Ii = { class: "cards-wrapper" }, Li = ["innerHTML"], Ri = { class: "card-bod
|
|
|
3560
4449
|
},
|
|
3561
4450
|
setup(e) {
|
|
3562
4451
|
let t = i(() => !!e.logo && (e.logo.startsWith("http") || e.logo.startsWith("/")));
|
|
3563
|
-
return (n, r) => (
|
|
4452
|
+
return (n, r) => (x(), s("div", {
|
|
3564
4453
|
class: "login-wrapper",
|
|
3565
|
-
style:
|
|
3566
|
-
}, [f(
|
|
4454
|
+
style: _({ "--login-bg": e.backgroundImage ? `url('${e.backgroundImage}')` : "var(--bg-gradient)" })
|
|
4455
|
+
}, [f(fn, {
|
|
3567
4456
|
size: "lg",
|
|
3568
4457
|
radius: "xl",
|
|
3569
4458
|
class: "card"
|
|
3570
4459
|
}, {
|
|
3571
|
-
default:
|
|
3572
|
-
t.value ? (
|
|
4460
|
+
default: j(() => [c("div", Uo, [
|
|
4461
|
+
t.value ? (x(), s("img", {
|
|
3573
4462
|
key: 0,
|
|
3574
4463
|
class: "logo-img",
|
|
3575
4464
|
src: e.logo,
|
|
3576
4465
|
alt: e.title
|
|
3577
|
-
}, null, 8,
|
|
3578
|
-
e.title ? (
|
|
3579
|
-
e.description ? (
|
|
3580
|
-
]),
|
|
4466
|
+
}, null, 8, Wo)) : (x(), s("div", Go, E(e.logo), 1)),
|
|
4467
|
+
e.title ? (x(), s("h1", Ko, E(e.title), 1)) : o("", !0),
|
|
4468
|
+
e.description ? (x(), s("p", qo, E(e.description), 1)) : o("", !0)
|
|
4469
|
+
]), T(n.$slots, "default", {}, void 0, !0)]),
|
|
3581
4470
|
_: 3
|
|
3582
4471
|
})], 4));
|
|
3583
4472
|
}
|
|
3584
4473
|
}), [["__scopeId", "data-v-f0866bc5"]]);
|
|
3585
4474
|
//#endregion
|
|
3586
4475
|
//#region src/composables/useRouteModal.ts
|
|
3587
|
-
function
|
|
4476
|
+
function Yo(e) {
|
|
3588
4477
|
let t = i(() => {
|
|
3589
|
-
let t =
|
|
4478
|
+
let t = F();
|
|
3590
4479
|
return t ? t.currentRoute.value.matched.some((t) => t.name === e.routeName) : !1;
|
|
3591
|
-
}), n = i(() =>
|
|
4480
|
+
}), n = i(() => F()?.currentRoute.value.params ?? {});
|
|
3592
4481
|
function r(t = {}) {
|
|
3593
|
-
|
|
4482
|
+
F()?.push({
|
|
3594
4483
|
name: e.routeName,
|
|
3595
4484
|
params: t
|
|
3596
4485
|
});
|
|
3597
4486
|
}
|
|
3598
4487
|
function a() {
|
|
3599
|
-
let t =
|
|
4488
|
+
let t = F();
|
|
3600
4489
|
t && (window.history.state?.back ? t.back() : e.parentRouteName ? t.push({ name: e.parentRouteName }) : t.back());
|
|
3601
4490
|
}
|
|
3602
4491
|
return {
|
|
@@ -3607,54 +4496,41 @@ function Aa(e) {
|
|
|
3607
4496
|
};
|
|
3608
4497
|
}
|
|
3609
4498
|
//#endregion
|
|
3610
|
-
//#region src/composables/useDisclosure.ts
|
|
3611
|
-
function ja() {
|
|
3612
|
-
let e = x(!1);
|
|
3613
|
-
function t() {
|
|
3614
|
-
e.value = !0;
|
|
3615
|
-
}
|
|
3616
|
-
function n() {
|
|
3617
|
-
e.value = !1;
|
|
3618
|
-
}
|
|
3619
|
-
return [
|
|
3620
|
-
e,
|
|
3621
|
-
t,
|
|
3622
|
-
n
|
|
3623
|
-
];
|
|
3624
|
-
}
|
|
3625
|
-
//#endregion
|
|
3626
4499
|
//#region src/index.ts
|
|
3627
|
-
var
|
|
3628
|
-
NButton:
|
|
3629
|
-
NBreadcrumb:
|
|
3630
|
-
NInput:
|
|
3631
|
-
NTextarea:
|
|
3632
|
-
NCheckbox:
|
|
3633
|
-
NSelect:
|
|
3634
|
-
NFileSelect:
|
|
3635
|
-
NForm:
|
|
3636
|
-
NList:
|
|
3637
|
-
NEmpty:
|
|
3638
|
-
NToast:
|
|
3639
|
-
NLoading:
|
|
3640
|
-
NCode:
|
|
3641
|
-
NSwitch:
|
|
3642
|
-
NTag:
|
|
3643
|
-
NDatePicker:
|
|
3644
|
-
NTooltip:
|
|
3645
|
-
NModal:
|
|
3646
|
-
NDrawer:
|
|
3647
|
-
NAlert:
|
|
3648
|
-
NTable:
|
|
3649
|
-
|
|
3650
|
-
|
|
3651
|
-
|
|
3652
|
-
|
|
3653
|
-
|
|
3654
|
-
|
|
3655
|
-
|
|
4500
|
+
var Xo = {
|
|
4501
|
+
NButton: z,
|
|
4502
|
+
NBreadcrumb: re,
|
|
4503
|
+
NInput: ue,
|
|
4504
|
+
NTextarea: he,
|
|
4505
|
+
NCheckbox: xe,
|
|
4506
|
+
NSelect: Oe,
|
|
4507
|
+
NFileSelect: Ut,
|
|
4508
|
+
NForm: dn,
|
|
4509
|
+
NList: Xn,
|
|
4510
|
+
NEmpty: Sn,
|
|
4511
|
+
NToast: ar,
|
|
4512
|
+
NLoading: Nn,
|
|
4513
|
+
NCode: mr,
|
|
4514
|
+
NSwitch: gr,
|
|
4515
|
+
NTag: _r,
|
|
4516
|
+
NDatePicker: Si,
|
|
4517
|
+
NTooltip: Ci,
|
|
4518
|
+
NModal: Oi,
|
|
4519
|
+
NDrawer: Ni,
|
|
4520
|
+
NAlert: Gi,
|
|
4521
|
+
NTable: Kn,
|
|
4522
|
+
NVideoSelect: _a,
|
|
4523
|
+
NImageSelect: Va,
|
|
4524
|
+
NAudioSelect: co,
|
|
4525
|
+
NLayout: Fo,
|
|
4526
|
+
NNavigation: Ho,
|
|
4527
|
+
NSidebar: jo,
|
|
4528
|
+
NCard: fn,
|
|
4529
|
+
NLoginLayout: Jo
|
|
4530
|
+
}, Zo = { install(e, t = {}) {
|
|
4531
|
+
Object.entries(Xo).forEach(([t, n]) => {
|
|
3656
4532
|
e.component(t, n);
|
|
3657
|
-
}), t.router &&
|
|
4533
|
+
}), t.router && ee(t.router);
|
|
3658
4534
|
} };
|
|
3659
4535
|
//#endregion
|
|
3660
|
-
export {
|
|
4536
|
+
export { Gi as NAlert, co as NAudioSelect, z as NButton, fn as NCard, xe as NCheckbox, mr as NCode, Si as NDatePicker, Ni as NDrawer, Sn as NEmpty, Ut as NFileSelect, dn as NForm, Va as NImageSelect, ue as NInput, Fo as NLayout, Xn as NList, Nn as NLoading, Jo as NLoginLayout, Oi as NModal, Ho as NNavigation, Oe as NSelect, jo as NSidebar, gr as NSwitch, Kn as NTable, _r as NTag, he as NTextarea, ar as NToast, Ci as NTooltip, _a as NVideoSelect, Zo as NickLabsUI, Ii as useAlert, H as useBreadcrumb, Ki as useDisclosure, Yo as useRouteModal, qt as useSidebarManager, $n as useToast };
|