@flux-ui/components 3.0.0-next.67 → 3.0.0-next.69
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 +1 -1
- package/dist/component/FluxLayerPane.vue.d.ts +5 -1
- package/dist/index.css +81 -19
- package/dist/index.d.ts +1 -1
- package/dist/index.js +576 -358
- package/dist/index.js.map +1 -1
- package/dist/vite.js.map +1 -1
- package/package.json +11 -11
- package/src/component/FluxLayerPane.vue +17 -1
- package/src/css/component/Flyout.module.scss +1 -1
- package/src/css/component/LayerPane.module.scss +69 -7
- package/src/css/component/Overlay.module.scss +8 -7
- package/src/css/component/Transition.module.scss +4 -4
- package/src/css/component/base/Button.module.scss +21 -0
- package/src/index.ts +1 -0
package/dist/index.js
CHANGED
|
@@ -2369,7 +2369,7 @@ function useTooltipInjection_default() {
|
|
|
2369
2369
|
return inject(FluxTooltipInjectionKey, { calculate: () => void 0 });
|
|
2370
2370
|
}
|
|
2371
2371
|
//#endregion
|
|
2372
|
-
//#region ../../node_modules/.bun/@basmilius+utils@3.
|
|
2372
|
+
//#region ../../node_modules/.bun/@basmilius+utils@3.33.0/node_modules/@basmilius/utils/dist/index.mjs
|
|
2373
2373
|
function t$1(e, t) {
|
|
2374
2374
|
return Math.round(e / t) * t;
|
|
2375
2375
|
}
|
|
@@ -2379,21 +2379,21 @@ function n$1(e, n, r, i) {
|
|
|
2379
2379
|
function r$1(e) {
|
|
2380
2380
|
return e.toString().split(`.`)[1]?.length ?? 0;
|
|
2381
2381
|
}
|
|
2382
|
-
function p$
|
|
2382
|
+
function p$4(e, t = 0) {
|
|
2383
2383
|
let n = typeof navigator < `u` ? navigator.language : `nl-NL`;
|
|
2384
2384
|
return new Intl.NumberFormat(n, {
|
|
2385
2385
|
maximumFractionDigits: t,
|
|
2386
2386
|
minimumFractionDigits: t
|
|
2387
2387
|
}).format(e);
|
|
2388
2388
|
}
|
|
2389
|
-
function m$
|
|
2389
|
+
function m$2(e) {
|
|
2390
2390
|
return new Intl.NumberFormat(navigator.language, {
|
|
2391
2391
|
maximumFractionDigits: 1,
|
|
2392
2392
|
minimumFractionDigits: 0,
|
|
2393
2393
|
style: `percent`
|
|
2394
2394
|
}).format(e);
|
|
2395
2395
|
}
|
|
2396
|
-
function g$
|
|
2396
|
+
function g$1(e, t, n = 5, r) {
|
|
2397
2397
|
let i = [
|
|
2398
2398
|
1,
|
|
2399
2399
|
5,
|
|
@@ -2424,7 +2424,7 @@ function g$2(e, t, n = 5, r) {
|
|
|
2424
2424
|
for (let t = 0; t < o; t += c) l.push(t + e);
|
|
2425
2425
|
return l;
|
|
2426
2426
|
}
|
|
2427
|
-
function x$
|
|
2427
|
+
function x$3(e) {
|
|
2428
2428
|
let t = {};
|
|
2429
2429
|
do {
|
|
2430
2430
|
if (e.name === ``) break;
|
|
@@ -2436,7 +2436,7 @@ function x$4(e) {
|
|
|
2436
2436
|
} while (e = Object.getPrototypeOf(e));
|
|
2437
2437
|
return t;
|
|
2438
2438
|
}
|
|
2439
|
-
function j$
|
|
2439
|
+
function j$2(e) {
|
|
2440
2440
|
let t = parseInt(e.startsWith(`#`) ? e.substring(1) : e, 16);
|
|
2441
2441
|
return [
|
|
2442
2442
|
t >> 16 & 255,
|
|
@@ -2515,7 +2515,7 @@ function L$2(e, t, n) {
|
|
|
2515
2515
|
function R$2(e) {
|
|
2516
2516
|
return globalThis.document ? e instanceof HTMLElement : !1;
|
|
2517
2517
|
}
|
|
2518
|
-
function V$
|
|
2518
|
+
function V$1(e) {
|
|
2519
2519
|
let t = new Uint32Array(1);
|
|
2520
2520
|
t[0] = e;
|
|
2521
2521
|
function n() {
|
|
@@ -2526,7 +2526,7 @@ function V$2(e) {
|
|
|
2526
2526
|
return n() * (t - e) + e;
|
|
2527
2527
|
}
|
|
2528
2528
|
function i() {
|
|
2529
|
-
return V$
|
|
2529
|
+
return V$1(n() * 2 ** 32);
|
|
2530
2530
|
}
|
|
2531
2531
|
return {
|
|
2532
2532
|
fork: i,
|
|
@@ -2534,13 +2534,13 @@ function V$2(e) {
|
|
|
2534
2534
|
nextBetween: r
|
|
2535
2535
|
};
|
|
2536
2536
|
}
|
|
2537
|
-
function W$
|
|
2537
|
+
function W$1(e, t, n) {
|
|
2538
2538
|
return `#${e.toString(16).padStart(2, `0`)}${t.toString(16).padStart(2, `0`)}${n.toString(16).padStart(2, `0`)}`;
|
|
2539
2539
|
}
|
|
2540
|
-
function G$
|
|
2540
|
+
function G$2(e, t, n) {
|
|
2541
2541
|
e.prototype[t] = n;
|
|
2542
2542
|
}
|
|
2543
|
-
function K$
|
|
2543
|
+
function K$2(e, t, n) {
|
|
2544
2544
|
Object.defineProperty(e, t, { value: n });
|
|
2545
2545
|
}
|
|
2546
2546
|
var Z$1 = `—`;
|
|
@@ -3369,15 +3369,15 @@ var o$2 = [
|
|
|
3369
3369
|
function s$1(e) {
|
|
3370
3370
|
return Array.from(e.querySelectorAll(o$2)).filter(R$2).filter((e) => e.offsetWidth > 0 || e.offsetHeight > 0 || e === document.activeElement);
|
|
3371
3371
|
}
|
|
3372
|
-
function c$
|
|
3372
|
+
function c$2(e, t, n) {
|
|
3373
3373
|
let r = s$1(e), i = r.indexOf(t);
|
|
3374
3374
|
if (i === -1) return null;
|
|
3375
|
-
let a = d$
|
|
3376
|
-
l$
|
|
3377
|
-
let o = u$
|
|
3375
|
+
let a = d$1(r);
|
|
3376
|
+
l$1(a, i, n);
|
|
3377
|
+
let o = u$1(i, n, a, r);
|
|
3378
3378
|
return o || ((n === `up` || n === `left`) && (o = r[i - 1]), (n === `down` || n === `right`) && (o = r[i + 1])), o;
|
|
3379
3379
|
}
|
|
3380
|
-
function l$
|
|
3380
|
+
function l$1(e, t, n) {
|
|
3381
3381
|
let r = e[t];
|
|
3382
3382
|
e.forEach((e) => {
|
|
3383
3383
|
let t = e.center;
|
|
@@ -3410,7 +3410,7 @@ function l$2(e, t, n) {
|
|
|
3410
3410
|
e.distance = Math.sqrt((r.center.x - t.x) ** 2 + (r.center.y - t.y) ** 2);
|
|
3411
3411
|
});
|
|
3412
3412
|
}
|
|
3413
|
-
function u$
|
|
3413
|
+
function u$1(e, t, n, r) {
|
|
3414
3414
|
let i = n[e], a = [];
|
|
3415
3415
|
switch (t) {
|
|
3416
3416
|
case `up`:
|
|
@@ -3429,7 +3429,7 @@ function u$2(e, t, n, r) {
|
|
|
3429
3429
|
let o = a.indexOf(Math.min(...a));
|
|
3430
3430
|
return a[o] === 2 ** 53 - 1 ? null : r[o];
|
|
3431
3431
|
}
|
|
3432
|
-
function d$
|
|
3432
|
+
function d$1(e) {
|
|
3433
3433
|
return e.map((e) => e.getBoundingClientRect()).map((e) => ({
|
|
3434
3434
|
height: e.height,
|
|
3435
3435
|
width: e.width,
|
|
@@ -3444,36 +3444,36 @@ function d$2(e) {
|
|
|
3444
3444
|
distance: 0
|
|
3445
3445
|
}));
|
|
3446
3446
|
}
|
|
3447
|
-
function f$
|
|
3447
|
+
function f$3(e) {
|
|
3448
3448
|
let t = `UnknownComponent`;
|
|
3449
3449
|
return e.type && e.type.__name && (t = e.type.__name), t;
|
|
3450
3450
|
}
|
|
3451
|
-
function p$
|
|
3451
|
+
function p$3(e) {
|
|
3452
3452
|
return Object.fromEntries(Object.entries(e.props ?? {}).map(([e, t]) => [camelCase(e), t]));
|
|
3453
3453
|
}
|
|
3454
|
-
function m$
|
|
3454
|
+
function m$1(e, t) {
|
|
3455
3455
|
if (!e.exposed || !(t in e.exposed)) throw Error(`'${t}' was not exposed by the component.`);
|
|
3456
3456
|
return e.exposed[t];
|
|
3457
3457
|
}
|
|
3458
|
-
function h$
|
|
3458
|
+
function h$2(e, t, r = void 0) {
|
|
3459
3459
|
let i = s$1(e), a = r || document.activeElement;
|
|
3460
3460
|
return !a || !R$2(a) ? i[0] || void 0 : i[i.indexOf(a) + t] || void 0;
|
|
3461
3461
|
}
|
|
3462
|
-
function _$
|
|
3462
|
+
function _$2(e) {
|
|
3463
3463
|
let r = unref(e);
|
|
3464
3464
|
return R$2(r) ? r : r?.$el;
|
|
3465
3465
|
}
|
|
3466
|
-
function v$
|
|
3466
|
+
function v$2(...e) {
|
|
3467
3467
|
console.warn(`[Flux]`, ...e);
|
|
3468
3468
|
}
|
|
3469
|
-
function y$
|
|
3470
|
-
let r = b$
|
|
3469
|
+
function y$2(e, t, n = !1) {
|
|
3470
|
+
let r = b$2(e), i = t.compareDocumentPosition(e), a;
|
|
3471
3471
|
a = i && Node.DOCUMENT_POSITION_PRECEDING || n ? r.firstChild() : r.lastChild(), (a === null ? e : a).focus();
|
|
3472
3472
|
}
|
|
3473
|
-
function b$
|
|
3473
|
+
function b$2(e) {
|
|
3474
3474
|
return document.createTreeWalker(e, NodeFilter.SHOW_ELEMENT, { acceptNode: (e) => e.tabIndex >= 0 && !e.disabled ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP });
|
|
3475
3475
|
}
|
|
3476
|
-
var x$
|
|
3476
|
+
var x$2 = new class {
|
|
3477
3477
|
get active() {
|
|
3478
3478
|
return this.current?.isEnabled ?? !1;
|
|
3479
3479
|
}
|
|
@@ -3505,7 +3505,7 @@ var x$3 = new class {
|
|
|
3505
3505
|
toggle(e, t) {
|
|
3506
3506
|
e.setEnabled(t), e.isEnabled = t;
|
|
3507
3507
|
}
|
|
3508
|
-
}(), S$
|
|
3508
|
+
}(), S$2 = !globalThis.document;
|
|
3509
3509
|
//#endregion
|
|
3510
3510
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/rgb/parseNumber.js
|
|
3511
3511
|
var parseNumber = (color, len) => {
|
|
@@ -3711,12 +3711,12 @@ var num_per = `(?:${num$1}%|${num$1})`;
|
|
|
3711
3711
|
var num_per_none = `(?:${num$1}%|${num$1}|none)`;
|
|
3712
3712
|
var hue$1 = `(?:${num$1}(deg|grad|rad|turn)|${num$1})`;
|
|
3713
3713
|
`${num$1}${num$1}`;
|
|
3714
|
-
var c$
|
|
3714
|
+
var c$1 = `\\s*,\\s*`;
|
|
3715
3715
|
new RegExp("^" + num_per_none + "$");
|
|
3716
3716
|
//#endregion
|
|
3717
3717
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/rgb/parseRgbLegacy.js
|
|
3718
|
-
var rgb_num_old = new RegExp(`^rgba?\\(\\s*${num$1}${c$
|
|
3719
|
-
var rgb_per_old = new RegExp(`^rgba?\\(\\s*${per}${c$
|
|
3718
|
+
var rgb_num_old = new RegExp(`^rgba?\\(\\s*${num$1}${c$1}${num$1}${c$1}${num$1}\\s*(?:,\\s*${num_per}\\s*)?\\)$`);
|
|
3719
|
+
var rgb_per_old = new RegExp(`^rgba?\\(\\s*${per}${c$1}${per}${c$1}${per}\\s*(?:,\\s*${num_per}\\s*)?\\)$`);
|
|
3720
3720
|
var parseRgbLegacy = (color) => {
|
|
3721
3721
|
let res = { mode: "rgb" };
|
|
3722
3722
|
let match;
|
|
@@ -4418,7 +4418,7 @@ var convertLchToLab = ({ l, c, h, alpha }, mode = "lab") => {
|
|
|
4418
4418
|
};
|
|
4419
4419
|
//#endregion
|
|
4420
4420
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/xyz65/constants.js
|
|
4421
|
-
var k$
|
|
4421
|
+
var k$5 = Math.pow(29, 3) / Math.pow(3, 3);
|
|
4422
4422
|
var e$3 = Math.pow(6, 3) / Math.pow(29, 3);
|
|
4423
4423
|
//#endregion
|
|
4424
4424
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/constants.js
|
|
@@ -4436,7 +4436,7 @@ Math.pow(29, 3) / Math.pow(3, 3);
|
|
|
4436
4436
|
Math.pow(6, 3) / Math.pow(29, 3);
|
|
4437
4437
|
//#endregion
|
|
4438
4438
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/lab65/convertLab65ToXyz65.js
|
|
4439
|
-
var fn$2 = (v) => Math.pow(v, 3) > e$3 ? Math.pow(v, 3) : (116 * v - 16) / k$
|
|
4439
|
+
var fn$2 = (v) => Math.pow(v, 3) > e$3 ? Math.pow(v, 3) : (116 * v - 16) / k$5;
|
|
4440
4440
|
var convertLab65ToXyz65 = ({ l, a, b, alpha }) => {
|
|
4441
4441
|
if (l === void 0) l = 0;
|
|
4442
4442
|
if (a === void 0) a = 0;
|
|
@@ -4458,14 +4458,14 @@ var convertLab65ToXyz65 = ({ l, a, b, alpha }) => {
|
|
|
4458
4458
|
var convertLab65ToRgb = (lab) => convertXyz65ToRgb(convertLab65ToXyz65(lab));
|
|
4459
4459
|
//#endregion
|
|
4460
4460
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/lab65/convertXyz65ToLab65.js
|
|
4461
|
-
var f$
|
|
4461
|
+
var f$2 = (value) => value > e$3 ? Math.cbrt(value) : (k$5 * value + 16) / 116;
|
|
4462
4462
|
var convertXyz65ToLab65 = ({ x, y, z, alpha }) => {
|
|
4463
4463
|
if (x === void 0) x = 0;
|
|
4464
4464
|
if (y === void 0) y = 0;
|
|
4465
4465
|
if (z === void 0) z = 0;
|
|
4466
|
-
let f0 = f$
|
|
4467
|
-
let f1 = f$
|
|
4468
|
-
let f2 = f$
|
|
4466
|
+
let f0 = f$2(x / D65.X);
|
|
4467
|
+
let f1 = f$2(y / D65.Y);
|
|
4468
|
+
let f2 = f$2(z / D65.Z);
|
|
4469
4469
|
let res = {
|
|
4470
4470
|
mode: "lab65",
|
|
4471
4471
|
l: 116 * f1 - 16,
|
|
@@ -4801,7 +4801,7 @@ var hueToDeg = (val, unit) => {
|
|
|
4801
4801
|
};
|
|
4802
4802
|
//#endregion
|
|
4803
4803
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/hsl/parseHslLegacy.js
|
|
4804
|
-
var hsl_old = new RegExp(`^hsla?\\(\\s*${hue$1}${c$
|
|
4804
|
+
var hsl_old = new RegExp(`^hsla?\\(\\s*${hue$1}${c$1}${per}${c$1}${per}\\s*(?:,\\s*${num_per}\\s*)?\\)$`);
|
|
4805
4805
|
var parseHslLegacy = (color) => {
|
|
4806
4806
|
let match = color.match(hsl_old);
|
|
4807
4807
|
if (!match) return;
|
|
@@ -5151,12 +5151,12 @@ var definition$18 = {
|
|
|
5151
5151
|
};
|
|
5152
5152
|
//#endregion
|
|
5153
5153
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/jab/convertXyz65ToJab.js
|
|
5154
|
-
var p$
|
|
5154
|
+
var p$2 = 134.03437499999998;
|
|
5155
5155
|
var d0$1 = 16295499532821565e-27;
|
|
5156
5156
|
var jabPqEncode = (v) => {
|
|
5157
5157
|
if (v < 0) return 0;
|
|
5158
5158
|
let vn = Math.pow(v / 1e4, M1);
|
|
5159
|
-
return Math.pow((C1 + C2 * vn) / (1 + C3 * vn), p$
|
|
5159
|
+
return Math.pow((C1 + C2 * vn) / (1 + C3 * vn), p$2);
|
|
5160
5160
|
};
|
|
5161
5161
|
var abs = (v = 0) => Math.max(v * 203, 0);
|
|
5162
5162
|
var convertXyz65ToJab = ({ x, y, z, alpha }) => {
|
|
@@ -5180,11 +5180,11 @@ var convertXyz65ToJab = ({ x, y, z, alpha }) => {
|
|
|
5180
5180
|
};
|
|
5181
5181
|
//#endregion
|
|
5182
5182
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/jab/convertJabToXyz65.js
|
|
5183
|
-
var p$
|
|
5183
|
+
var p$1 = 134.03437499999998;
|
|
5184
5184
|
var d0 = 16295499532821565e-27;
|
|
5185
5185
|
var jabPqDecode = (v) => {
|
|
5186
5186
|
if (v < 0) return 0;
|
|
5187
|
-
let vp = Math.pow(v, 1 / p$
|
|
5187
|
+
let vp = Math.pow(v, 1 / p$1);
|
|
5188
5188
|
return 1e4 * Math.pow((C1 - vp) / (C3 * vp - C2), 1 / M1);
|
|
5189
5189
|
};
|
|
5190
5190
|
var rel = (v) => v / 203;
|
|
@@ -5320,11 +5320,11 @@ var definition$16 = {
|
|
|
5320
5320
|
};
|
|
5321
5321
|
//#endregion
|
|
5322
5322
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/xyz50/constants.js
|
|
5323
|
-
var k$
|
|
5323
|
+
var k$3 = Math.pow(29, 3) / Math.pow(3, 3);
|
|
5324
5324
|
var e$1 = Math.pow(6, 3) / Math.pow(29, 3);
|
|
5325
5325
|
//#endregion
|
|
5326
5326
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/lab/convertLabToXyz50.js
|
|
5327
|
-
var fn$1 = (v) => Math.pow(v, 3) > e$1 ? Math.pow(v, 3) : (116 * v - 16) / k$
|
|
5327
|
+
var fn$1 = (v) => Math.pow(v, 3) > e$1 ? Math.pow(v, 3) : (116 * v - 16) / k$3;
|
|
5328
5328
|
var convertLabToXyz50 = ({ l, a, b, alpha }) => {
|
|
5329
5329
|
if (l === void 0) l = 0;
|
|
5330
5330
|
if (a === void 0) a = 0;
|
|
@@ -5373,14 +5373,14 @@ var convertRgbToXyz50 = (rgb) => {
|
|
|
5373
5373
|
};
|
|
5374
5374
|
//#endregion
|
|
5375
5375
|
//#region ../../node_modules/.bun/culori@4.0.2/node_modules/culori/src/lab/convertXyz50ToLab.js
|
|
5376
|
-
var f$
|
|
5376
|
+
var f$1 = (value) => value > e$1 ? Math.cbrt(value) : (k$3 * value + 16) / 116;
|
|
5377
5377
|
var convertXyz50ToLab = ({ x, y, z, alpha }) => {
|
|
5378
5378
|
if (x === void 0) x = 0;
|
|
5379
5379
|
if (y === void 0) y = 0;
|
|
5380
5380
|
if (z === void 0) z = 0;
|
|
5381
|
-
let f0 = f$
|
|
5382
|
-
let f1 = f$
|
|
5383
|
-
let f2 = f$
|
|
5381
|
+
let f0 = f$1(x / D50.X);
|
|
5382
|
+
let f1 = f$1(y / D50.Y);
|
|
5383
|
+
let f2 = f$1(z / D50.Z);
|
|
5384
5384
|
let res = {
|
|
5385
5385
|
mode: "lab",
|
|
5386
5386
|
l: 116 * f1 - 16,
|
|
@@ -5579,7 +5579,7 @@ var u_fn$1 = (x, y, z) => 4 * x / (x + 15 * y + 3 * z);
|
|
|
5579
5579
|
var v_fn$1 = (x, y, z) => 9 * y / (x + 15 * y + 3 * z);
|
|
5580
5580
|
var un$2 = u_fn$1(D50.X, D50.Y, D50.Z);
|
|
5581
5581
|
var vn$2 = v_fn$1(D50.X, D50.Y, D50.Z);
|
|
5582
|
-
var l_fn = (value) => value <= e$1 ? k$
|
|
5582
|
+
var l_fn = (value) => value <= e$1 ? k$3 * value : 116 * Math.cbrt(value) - 16;
|
|
5583
5583
|
var convertXyz50ToLuv = ({ x, y, z, alpha }) => {
|
|
5584
5584
|
if (x === void 0) x = 0;
|
|
5585
5585
|
if (y === void 0) y = 0;
|
|
@@ -5619,7 +5619,7 @@ var convertLuvToXyz50 = ({ l, u, v, alpha }) => {
|
|
|
5619
5619
|
if (v === void 0) v = 0;
|
|
5620
5620
|
let up = u / (13 * l) + un$1;
|
|
5621
5621
|
let vp = v / (13 * l) + vn$1;
|
|
5622
|
-
let y = D50.Y * (l <= 8 ? l / k$
|
|
5622
|
+
let y = D50.Y * (l <= 8 ? l / k$3 : Math.pow((l + 16) / 116, 3));
|
|
5623
5623
|
let res = {
|
|
5624
5624
|
mode: "xyz50",
|
|
5625
5625
|
x: y * (9 * up) / (4 * vp),
|
|
@@ -6588,304 +6588,514 @@ useMode(definition$2);
|
|
|
6588
6588
|
useMode(definition$1);
|
|
6589
6589
|
useMode(definition);
|
|
6590
6590
|
//#endregion
|
|
6591
|
-
//#region ../../node_modules/.bun/@basmilius+http-client@3.
|
|
6592
|
-
function
|
|
6593
|
-
return class extends
|
|
6594
|
-
constructor(...
|
|
6595
|
-
throw Error(
|
|
6591
|
+
//#region ../../node_modules/.bun/@basmilius+http-client@3.33.0+644299353f754fd6/node_modules/@basmilius/http-client/dist/index.mjs
|
|
6592
|
+
function adapter_default(Parent) {
|
|
6593
|
+
return class extends Parent {
|
|
6594
|
+
constructor(...args) {
|
|
6595
|
+
throw new Error("@adapter: cannot create instance of class.");
|
|
6596
6596
|
}
|
|
6597
6597
|
};
|
|
6598
6598
|
}
|
|
6599
|
-
|
|
6600
|
-
|
|
6599
|
+
/**
|
|
6600
|
+
* Checks if the two given values are equal. When both values are a
|
|
6601
|
+
* dto, the check is done by firstly converthing them to JSON.
|
|
6602
|
+
*/
|
|
6603
|
+
function areEqual_default(a, b) {
|
|
6604
|
+
if (a === b) return true;
|
|
6605
|
+
return a === b;
|
|
6601
6606
|
}
|
|
6602
|
-
var
|
|
6603
|
-
|
|
6604
|
-
|
|
6607
|
+
var ARGS = Symbol();
|
|
6608
|
+
var CHILDREN = Symbol();
|
|
6609
|
+
var DESCRIPTORS = Symbol();
|
|
6610
|
+
var DIRTY = Symbol();
|
|
6611
|
+
var NAME = Symbol();
|
|
6612
|
+
var PARENT = Symbol();
|
|
6613
|
+
var PARENT_KEY = Symbol();
|
|
6614
|
+
var PROPERTIES = Symbol();
|
|
6615
|
+
var PROXY = Symbol();
|
|
6616
|
+
var TRACK = Symbol();
|
|
6617
|
+
var TRIGGER = Symbol();
|
|
6618
|
+
/**
|
|
6619
|
+
* Checks if the given object is a dto.
|
|
6620
|
+
*/
|
|
6621
|
+
function isDto_default(obj) {
|
|
6622
|
+
return obj && typeof obj === "object" && !!obj[NAME];
|
|
6605
6623
|
}
|
|
6606
|
-
|
|
6607
|
-
|
|
6624
|
+
/**
|
|
6625
|
+
* Asserts that the given object is a dto.
|
|
6626
|
+
*/
|
|
6627
|
+
function assertDto_default(obj) {
|
|
6628
|
+
if (!isDto_default(obj)) throw new Error("@dto assert given object is not a class decorated with @Dto.");
|
|
6608
6629
|
}
|
|
6609
|
-
var
|
|
6610
|
-
function
|
|
6611
|
-
return function(...
|
|
6612
|
-
|
|
6613
|
-
|
|
6614
|
-
|
|
6615
|
-
|
|
6616
|
-
if (!
|
|
6617
|
-
|
|
6618
|
-
|
|
6619
|
-
|
|
6620
|
-
|
|
6621
|
-
|
|
6622
|
-
|
|
6623
|
-
|
|
6630
|
+
var CIRCULAR_MAP = Symbol();
|
|
6631
|
+
function circularProtect_default(fn, arg1 = 0, arg2) {
|
|
6632
|
+
return function(...args) {
|
|
6633
|
+
const map = fn[CIRCULAR_MAP] ??= /* @__PURE__ */ new WeakMap();
|
|
6634
|
+
const primary = args[arg1];
|
|
6635
|
+
const secondary = arg2 !== void 0 ? args[arg2] : "self";
|
|
6636
|
+
if (typeof primary !== "object" || primary === null) return fn.call(this, ...args);
|
|
6637
|
+
if (!map.has(primary)) map.set(primary, []);
|
|
6638
|
+
const visited = map.get(primary);
|
|
6639
|
+
if (visited.includes(secondary)) return;
|
|
6640
|
+
visited.push(secondary);
|
|
6641
|
+
try {
|
|
6642
|
+
return fn.call(this, ...args);
|
|
6643
|
+
} finally {
|
|
6644
|
+
const index = visited.lastIndexOf(secondary);
|
|
6645
|
+
if (index !== -1) visited.splice(index, 1);
|
|
6646
|
+
if (visited.length === 0) map.delete(primary);
|
|
6624
6647
|
}
|
|
6625
6648
|
};
|
|
6626
6649
|
}
|
|
6627
|
-
|
|
6628
|
-
|
|
6650
|
+
/**
|
|
6651
|
+
* Checks if the given dto is dirty.
|
|
6652
|
+
*/
|
|
6653
|
+
function isDtoDirty_default(obj) {
|
|
6654
|
+
assertDto_default(obj);
|
|
6655
|
+
return obj[DIRTY];
|
|
6629
6656
|
}
|
|
6630
|
-
|
|
6631
|
-
|
|
6632
|
-
|
|
6633
|
-
|
|
6634
|
-
|
|
6657
|
+
/**
|
|
6658
|
+
* Trigger for when a dto property is being updated.
|
|
6659
|
+
*/
|
|
6660
|
+
var triggerDto = circularProtect_default(function(dto, key, value, oldValue) {
|
|
6661
|
+
const trigger = dto[TRIGGER];
|
|
6662
|
+
trigger(dto, key, value, oldValue);
|
|
6663
|
+
dto[PARENT] && triggerDto(dto[PARENT], dto[PARENT_KEY], dto[PARENT][dto[PARENT_KEY]]);
|
|
6664
|
+
}, 0, 1);
|
|
6665
|
+
/**
|
|
6666
|
+
* Marks the given dto clean.
|
|
6667
|
+
*/
|
|
6668
|
+
var markDtoClean = circularProtect_default(function(obj) {
|
|
6669
|
+
assertDto_default(obj);
|
|
6670
|
+
if (obj[DIRTY]) {
|
|
6671
|
+
obj[DIRTY] = false;
|
|
6672
|
+
triggerDto(obj, DIRTY, false, true);
|
|
6673
|
+
}
|
|
6674
|
+
if (!obj[CHILDREN] || obj[CHILDREN].length === 0) return;
|
|
6675
|
+
obj[CHILDREN].filter(isDtoDirty_default).forEach(markDtoClean);
|
|
6635
6676
|
});
|
|
6636
|
-
|
|
6637
|
-
|
|
6677
|
+
/**
|
|
6678
|
+
* Marks the given dto dirty.
|
|
6679
|
+
*/
|
|
6680
|
+
var markDtoDirty = circularProtect_default(function(obj, key) {
|
|
6681
|
+
assertDto_default(obj);
|
|
6682
|
+
if (!obj[DIRTY]) {
|
|
6683
|
+
obj[DIRTY] = true;
|
|
6684
|
+
triggerDto(obj, DIRTY, true, false);
|
|
6685
|
+
}
|
|
6686
|
+
if (!obj[PARENT]) return;
|
|
6687
|
+
markDtoDirty(obj[PARENT], obj[PARENT_KEY]);
|
|
6638
6688
|
});
|
|
6639
|
-
|
|
6640
|
-
|
|
6689
|
+
/**
|
|
6690
|
+
* Creates a parent-child relationship between the given two dtos.
|
|
6691
|
+
*/
|
|
6692
|
+
function relateDtoTo_default(dto, parent, key) {
|
|
6693
|
+
parent[CHILDREN] ??= [];
|
|
6694
|
+
!parent[CHILDREN].includes(dto) && parent[CHILDREN].push(dto);
|
|
6695
|
+
dto[PARENT] !== parent && (dto[PARENT] = parent);
|
|
6696
|
+
dto[PARENT_KEY] !== key && (dto[PARENT_KEY] = key);
|
|
6641
6697
|
}
|
|
6642
|
-
|
|
6643
|
-
|
|
6644
|
-
|
|
6645
|
-
|
|
6646
|
-
|
|
6698
|
+
/**
|
|
6699
|
+
* Creates relationships between the given value and dto.
|
|
6700
|
+
*/
|
|
6701
|
+
function relateValueTo_default(dto, key, value) {
|
|
6702
|
+
if (isDto_default(value)) relateDtoTo_default(value, dto, key);
|
|
6703
|
+
else if (Array.isArray(value)) {
|
|
6704
|
+
for (const item of value) {
|
|
6705
|
+
if (!isDto_default(item)) continue;
|
|
6706
|
+
relateDtoTo_default(item, dto, key);
|
|
6707
|
+
}
|
|
6708
|
+
value[PARENT] = dto;
|
|
6709
|
+
value[PARENT_KEY] = key;
|
|
6647
6710
|
}
|
|
6648
6711
|
}
|
|
6649
|
-
|
|
6650
|
-
|
|
6651
|
-
|
|
6712
|
+
/**
|
|
6713
|
+
* Tracking for when a dto property is being accessed.
|
|
6714
|
+
*/
|
|
6715
|
+
function trackDto(dto, key) {
|
|
6716
|
+
const track = dto[TRACK];
|
|
6717
|
+
track(dto, key);
|
|
6652
6718
|
}
|
|
6653
|
-
|
|
6654
|
-
|
|
6655
|
-
|
|
6656
|
-
|
|
6719
|
+
/**
|
|
6720
|
+
* Removes a parent-child relationship between the given two dtos.
|
|
6721
|
+
*/
|
|
6722
|
+
function unrelateDtoFrom_default(dto, parent) {
|
|
6723
|
+
if (CHILDREN in parent) {
|
|
6724
|
+
const index = parent[CHILDREN].indexOf(dto);
|
|
6725
|
+
if (index !== -1) parent[CHILDREN].splice(index, 1);
|
|
6657
6726
|
}
|
|
6658
|
-
|
|
6727
|
+
dto[PARENT] = void 0;
|
|
6728
|
+
dto[PARENT_KEY] = void 0;
|
|
6659
6729
|
}
|
|
6660
|
-
|
|
6661
|
-
|
|
6662
|
-
|
|
6663
|
-
|
|
6664
|
-
|
|
6730
|
+
/**
|
|
6731
|
+
* Removes relationships between the given value and dto.
|
|
6732
|
+
*/
|
|
6733
|
+
function unrelateValueFrom_default(dto, value) {
|
|
6734
|
+
if (isDto_default(value)) unrelateDtoFrom_default(value, dto);
|
|
6735
|
+
else if (Array.isArray(value)) {
|
|
6736
|
+
for (const item of value) if (isDto_default(item)) unrelateDtoFrom_default(item, dto);
|
|
6737
|
+
value[PARENT] = void 0;
|
|
6738
|
+
value[PARENT_KEY] = void 0;
|
|
6665
6739
|
}
|
|
6666
6740
|
}
|
|
6667
|
-
var
|
|
6668
|
-
var
|
|
6669
|
-
|
|
6670
|
-
|
|
6671
|
-
|
|
6672
|
-
|
|
6741
|
+
var DTO_CLASS_MAP = {};
|
|
6742
|
+
var arrayProxy_default = {
|
|
6743
|
+
/**
|
|
6744
|
+
* Trap for when a property is deleted from the target. This
|
|
6745
|
+
* will mark the parent dto as dirty and trigger an update.
|
|
6746
|
+
*/
|
|
6747
|
+
deleteProperty(target, key) {
|
|
6748
|
+
Reflect.deleteProperty(target, key);
|
|
6749
|
+
if (ignored(target, key)) return true;
|
|
6750
|
+
const dto = target[PARENT];
|
|
6751
|
+
dto && triggerDto(dto, target[PARENT_KEY], dto[target[PARENT_KEY]]);
|
|
6752
|
+
dto && markDtoDirty(dto, target[PARENT_KEY]);
|
|
6753
|
+
return true;
|
|
6673
6754
|
},
|
|
6674
|
-
|
|
6675
|
-
|
|
6676
|
-
|
|
6677
|
-
|
|
6678
|
-
|
|
6755
|
+
/**
|
|
6756
|
+
* Trap for when a property of the target is being accessed. The
|
|
6757
|
+
* property access is being tracked for further updates.
|
|
6758
|
+
*/
|
|
6759
|
+
get(target, key, receiver) {
|
|
6760
|
+
if (key === PROXY) return true;
|
|
6761
|
+
if (ignored(target, key)) return Reflect.get(target, key, receiver);
|
|
6762
|
+
const dto = target[PARENT];
|
|
6763
|
+
dto && trackDto(dto, target[PARENT_KEY]);
|
|
6764
|
+
return Reflect.get(target, key);
|
|
6679
6765
|
},
|
|
6680
|
-
|
|
6681
|
-
|
|
6682
|
-
|
|
6683
|
-
|
|
6766
|
+
/**
|
|
6767
|
+
* Trap for when a property of the target is being updated. This
|
|
6768
|
+
* will mark the parent dto as dirty and trigger an update.
|
|
6769
|
+
*/
|
|
6770
|
+
set(target, key, value, receiver) {
|
|
6771
|
+
if (ignored(target, key)) return Reflect.set(target, key, value, receiver);
|
|
6772
|
+
const dto = target[PARENT];
|
|
6773
|
+
dto && triggerDto(dto, target[PARENT_KEY], dto[target[PARENT_KEY]]);
|
|
6774
|
+
dto && markDtoDirty(dto, target[PARENT_KEY]);
|
|
6775
|
+
return Reflect.set(target, key, value);
|
|
6684
6776
|
}
|
|
6685
6777
|
};
|
|
6686
|
-
|
|
6687
|
-
|
|
6778
|
+
/**
|
|
6779
|
+
* Checks if the given key should be ignored by the proxy.
|
|
6780
|
+
*/
|
|
6781
|
+
function ignored(target, key) {
|
|
6782
|
+
return typeof key === "symbol" || typeof target[key] === "function" || key === "length";
|
|
6688
6783
|
}
|
|
6689
|
-
var
|
|
6690
|
-
|
|
6691
|
-
|
|
6692
|
-
|
|
6693
|
-
|
|
6694
|
-
|
|
6695
|
-
|
|
6696
|
-
|
|
6784
|
+
var instanceProxy_default = {
|
|
6785
|
+
/**
|
|
6786
|
+
* Trap for when a dto property is being accessed. The property
|
|
6787
|
+
* access is being tracked for further updates. If the dto has
|
|
6788
|
+
* any child dtos, a relationship will be added between them.
|
|
6789
|
+
*/
|
|
6790
|
+
get(target, key, receiver) {
|
|
6791
|
+
if (key === PROXY) return true;
|
|
6792
|
+
if (typeof key === "symbol") return Reflect.get(target, key, receiver);
|
|
6793
|
+
const descriptor = target[DESCRIPTORS][key];
|
|
6794
|
+
if (!descriptor || !descriptor.get) return Reflect.get(target, key, receiver);
|
|
6795
|
+
const value = descriptor.get.call(target);
|
|
6796
|
+
trackDto(target, key);
|
|
6797
|
+
relateValueTo_default(target, key, value);
|
|
6798
|
+
return value;
|
|
6697
6799
|
},
|
|
6698
|
-
|
|
6699
|
-
|
|
6800
|
+
/**
|
|
6801
|
+
* Trap for when a descriptor of a dto property is requested.
|
|
6802
|
+
*/
|
|
6803
|
+
getOwnPropertyDescriptor(target, key) {
|
|
6804
|
+
return target[DESCRIPTORS][key];
|
|
6700
6805
|
},
|
|
6701
|
-
|
|
6702
|
-
|
|
6806
|
+
/**
|
|
6807
|
+
* Trap for when the keys of a dto are requested.
|
|
6808
|
+
*/
|
|
6809
|
+
ownKeys(target) {
|
|
6810
|
+
return target[PROPERTIES];
|
|
6703
6811
|
},
|
|
6704
|
-
|
|
6705
|
-
|
|
6706
|
-
|
|
6707
|
-
|
|
6708
|
-
|
|
6709
|
-
|
|
6710
|
-
|
|
6711
|
-
|
|
6712
|
-
|
|
6713
|
-
|
|
6812
|
+
/**
|
|
6813
|
+
* Trap for when a dto property is being updated. This will
|
|
6814
|
+
* mark the dto dirty and trigger an update. If an array is
|
|
6815
|
+
* passed, that array will be made reactive as well.
|
|
6816
|
+
*/
|
|
6817
|
+
set(target, key, value, receiver) {
|
|
6818
|
+
if (typeof key === "symbol") return Reflect.set(target, key, value, receiver);
|
|
6819
|
+
const descriptor = target[DESCRIPTORS][key];
|
|
6820
|
+
if (!descriptor || !descriptor.set) return Reflect.set(target, key, value, receiver);
|
|
6821
|
+
const oldValue = descriptor.get?.call(target) ?? void 0;
|
|
6822
|
+
if (areEqual_default(value, oldValue)) return true;
|
|
6823
|
+
unrelateValueFrom_default(target, oldValue);
|
|
6824
|
+
if (Array.isArray(value) && !value[PROXY]) value = new Proxy(value, arrayProxy_default);
|
|
6825
|
+
descriptor.set.call(target, value);
|
|
6826
|
+
relateValueTo_default(target, key, value);
|
|
6827
|
+
markDtoDirty(target, key);
|
|
6828
|
+
triggerDto(target, key, value, oldValue);
|
|
6829
|
+
return true;
|
|
6830
|
+
}
|
|
6831
|
+
};
|
|
6832
|
+
var refProxy_default = {
|
|
6833
|
+
/**
|
|
6834
|
+
* Trap for when a ref property is being accessed. The property
|
|
6835
|
+
* access is being tracked for further updates. If the requested
|
|
6836
|
+
* property is not a part of {Ref}, the get is proxied to the
|
|
6837
|
+
* underlying dto instance.
|
|
6838
|
+
*
|
|
6839
|
+
* A little trick with __v_isRef is done here, all the features
|
|
6840
|
+
* of refs are used by our dto, but we don't want Vue to treat
|
|
6841
|
+
* it as a ref. We return false here to trick Vue.
|
|
6842
|
+
*/
|
|
6843
|
+
get(target, key, receiver) {
|
|
6844
|
+
if (key === "__v_isRef") return false;
|
|
6845
|
+
if (key === PROXY) return true;
|
|
6846
|
+
if (key in target) return Reflect.get(target, key, receiver);
|
|
6847
|
+
return Reflect.get(target.value, key);
|
|
6714
6848
|
},
|
|
6715
|
-
|
|
6716
|
-
|
|
6849
|
+
/**
|
|
6850
|
+
* Trap for when a descriptor of a property is requested, that
|
|
6851
|
+
* request is proxied to the underlying dto.
|
|
6852
|
+
*/
|
|
6853
|
+
getOwnPropertyDescriptor(target, key) {
|
|
6854
|
+
return Reflect.getOwnPropertyDescriptor(target.value, key);
|
|
6717
6855
|
},
|
|
6718
|
-
|
|
6719
|
-
|
|
6856
|
+
/**
|
|
6857
|
+
* Trap for when the keys of the ref are requested, that request
|
|
6858
|
+
* is proxied to the underlying dto.
|
|
6859
|
+
*/
|
|
6860
|
+
ownKeys(target) {
|
|
6861
|
+
return Reflect.ownKeys(target.value);
|
|
6720
6862
|
},
|
|
6721
|
-
|
|
6722
|
-
|
|
6723
|
-
}
|
|
6724
|
-
|
|
6725
|
-
|
|
6726
|
-
|
|
6727
|
-
|
|
6728
|
-
|
|
6729
|
-
|
|
6863
|
+
/**
|
|
6864
|
+
* Trap for when a ref property is being updated. If the property
|
|
6865
|
+
* is not part of {Ref}, the set is proxied to the underlying dto
|
|
6866
|
+
* instance. In that proxy, the dto will be marked dirty and an
|
|
6867
|
+
* update is triggered.
|
|
6868
|
+
*/
|
|
6869
|
+
set(target, key, value, receiver) {
|
|
6870
|
+
if (key in target) return Reflect.set(target, key, value, receiver);
|
|
6871
|
+
return Reflect.set(target.value, key, value);
|
|
6872
|
+
}
|
|
6873
|
+
};
|
|
6874
|
+
var classProxy_default = {
|
|
6875
|
+
/**
|
|
6876
|
+
* Trap for when a dto is being constructed. Reactivity is provided
|
|
6877
|
+
* to all arguments and a proxied custom ref is returned that references
|
|
6878
|
+
* the actual dto instance.
|
|
6879
|
+
*/
|
|
6880
|
+
construct(target, argsArray, newTarget) {
|
|
6881
|
+
argsArray = argsArray.map((arg) => {
|
|
6882
|
+
if (!Array.isArray(arg)) return arg;
|
|
6883
|
+
return new Proxy(arg, arrayProxy_default);
|
|
6884
|
+
});
|
|
6885
|
+
const ref = customRef((track, trigger) => {
|
|
6886
|
+
const instance = markRaw(Reflect.construct(target, argsArray, newTarget));
|
|
6887
|
+
instance[ARGS] = argsArray;
|
|
6888
|
+
instance[DIRTY] = false;
|
|
6889
|
+
instance[TRACK] = track;
|
|
6890
|
+
instance[TRIGGER] = trigger;
|
|
6891
|
+
const proxied = new Proxy(instance, instanceProxy_default);
|
|
6730
6892
|
return {
|
|
6731
|
-
get: () =>
|
|
6893
|
+
get: () => {
|
|
6894
|
+
track();
|
|
6895
|
+
return proxied;
|
|
6896
|
+
},
|
|
6732
6897
|
set: () => void 0
|
|
6733
6898
|
};
|
|
6734
6899
|
});
|
|
6735
|
-
return new Proxy(
|
|
6900
|
+
return new Proxy(ref, refProxy_default);
|
|
6736
6901
|
} };
|
|
6737
|
-
|
|
6738
|
-
|
|
6739
|
-
|
|
6740
|
-
|
|
6741
|
-
|
|
6742
|
-
|
|
6902
|
+
/**
|
|
6903
|
+
* Returns a clone of the dto.
|
|
6904
|
+
*/
|
|
6905
|
+
function clone_default() {
|
|
6906
|
+
const instance = this;
|
|
6907
|
+
assertDto_default(instance);
|
|
6908
|
+
const clazz = DTO_CLASS_MAP[instance[NAME]];
|
|
6909
|
+
const clone = new clazz(...instance[ARGS]);
|
|
6910
|
+
for (const [key, descriptor] of Object.entries(this[DESCRIPTORS])) {
|
|
6911
|
+
if (!descriptor.set) continue;
|
|
6912
|
+
clone[key] = isDto_default(this[key]) ? this[key].clone() : this[key];
|
|
6913
|
+
}
|
|
6914
|
+
return clone;
|
|
6743
6915
|
}
|
|
6744
|
-
|
|
6745
|
-
|
|
6746
|
-
|
|
6747
|
-
|
|
6916
|
+
/**
|
|
6917
|
+
* Fills the dto with the given data.
|
|
6918
|
+
*/
|
|
6919
|
+
function fill_default(data) {
|
|
6920
|
+
for (let key in data) {
|
|
6921
|
+
const descriptor = this[DESCRIPTORS][key];
|
|
6922
|
+
if (isDto_default(this[key]) && typeof data[key] === "object") this[key].fill(data[key]);
|
|
6923
|
+
else if (descriptor && descriptor.set) this[key] = data[key];
|
|
6748
6924
|
}
|
|
6749
6925
|
}
|
|
6750
|
-
|
|
6751
|
-
|
|
6752
|
-
|
|
6753
|
-
|
|
6754
|
-
|
|
6926
|
+
/**
|
|
6927
|
+
* Returns the json object representation of the dto.
|
|
6928
|
+
*/
|
|
6929
|
+
function toJSON_default() {
|
|
6930
|
+
const result = {};
|
|
6931
|
+
for (const property of this[PROPERTIES]) {
|
|
6932
|
+
let value = this[property];
|
|
6933
|
+
if (isDto_default(value)) value = value.toJSON();
|
|
6934
|
+
result[property] = value;
|
|
6755
6935
|
}
|
|
6756
|
-
return
|
|
6936
|
+
return result;
|
|
6757
6937
|
}
|
|
6758
|
-
|
|
6759
|
-
|
|
6760
|
-
|
|
6761
|
-
|
|
6938
|
+
/**
|
|
6939
|
+
* Provides reactivity to the decorated class.
|
|
6940
|
+
*/
|
|
6941
|
+
function dto_default(clazz) {
|
|
6942
|
+
validate(clazz);
|
|
6943
|
+
const descriptors = Object.freeze(x$3(clazz));
|
|
6944
|
+
const properties = Object.keys(descriptors);
|
|
6945
|
+
K$2(clazz.prototype, DESCRIPTORS, descriptors);
|
|
6946
|
+
K$2(clazz.prototype, NAME, clazz.name);
|
|
6947
|
+
K$2(clazz.prototype, PROPERTIES, properties);
|
|
6948
|
+
K$2(clazz, Symbol.hasInstance, (instance) => typeof instance === "object" && instance?.[NAME] === clazz.name);
|
|
6949
|
+
G$2(clazz, "clone", clone_default);
|
|
6950
|
+
G$2(clazz, "fill", fill_default);
|
|
6951
|
+
G$2(clazz, "toJSON", toJSON_default);
|
|
6952
|
+
return proxy(clazz);
|
|
6762
6953
|
}
|
|
6763
|
-
function
|
|
6764
|
-
|
|
6765
|
-
|
|
6954
|
+
function proxy(clazz) {
|
|
6955
|
+
const proxied = new Proxy(clazz, classProxy_default);
|
|
6956
|
+
DTO_CLASS_MAP[clazz.name] = proxied;
|
|
6957
|
+
return proxied;
|
|
6766
6958
|
}
|
|
6767
|
-
function
|
|
6768
|
-
|
|
6769
|
-
if (
|
|
6959
|
+
function validate(clazz) {
|
|
6960
|
+
const parent = Object.getPrototypeOf(clazz.prototype);
|
|
6961
|
+
if (NAME in parent) throw new Error(`⛔️ @dto ${clazz.name} cannot extend parent class which is also decorated with @dto ${parent[NAME]}.`);
|
|
6770
6962
|
}
|
|
6771
|
-
function
|
|
6772
|
-
var
|
|
6773
|
-
if (typeof Reflect
|
|
6774
|
-
else for (var
|
|
6775
|
-
return
|
|
6963
|
+
function __decorate(decorators, target, key, desc) {
|
|
6964
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
6965
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
6966
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6967
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6776
6968
|
}
|
|
6777
|
-
var
|
|
6969
|
+
var BlobResponse = class BlobResponse {
|
|
6778
6970
|
get blob() {
|
|
6779
|
-
return this.#
|
|
6971
|
+
return this.#blob;
|
|
6780
6972
|
}
|
|
6781
6973
|
get name() {
|
|
6782
|
-
return this.#
|
|
6974
|
+
return this.#name;
|
|
6783
6975
|
}
|
|
6784
|
-
#
|
|
6785
|
-
#
|
|
6786
|
-
constructor(
|
|
6787
|
-
this.#
|
|
6976
|
+
#blob;
|
|
6977
|
+
#name;
|
|
6978
|
+
constructor(blob, name) {
|
|
6979
|
+
this.#blob = blob;
|
|
6980
|
+
this.#name = name;
|
|
6788
6981
|
}
|
|
6789
6982
|
};
|
|
6790
|
-
|
|
6791
|
-
var
|
|
6983
|
+
BlobResponse = __decorate([dto_default], BlobResponse);
|
|
6984
|
+
var Paginated = class Paginated {
|
|
6792
6985
|
get items() {
|
|
6793
|
-
return this.#
|
|
6986
|
+
return this.#items;
|
|
6794
6987
|
}
|
|
6795
6988
|
get page() {
|
|
6796
|
-
return this.#
|
|
6989
|
+
return this.#page;
|
|
6797
6990
|
}
|
|
6798
6991
|
get pageSize() {
|
|
6799
|
-
return this.#
|
|
6992
|
+
return this.#pageSize;
|
|
6800
6993
|
}
|
|
6801
6994
|
get pages() {
|
|
6802
|
-
return this.#
|
|
6995
|
+
return this.#pages;
|
|
6803
6996
|
}
|
|
6804
6997
|
get total() {
|
|
6805
|
-
return this.#
|
|
6806
|
-
}
|
|
6807
|
-
#
|
|
6808
|
-
#
|
|
6809
|
-
#
|
|
6810
|
-
#
|
|
6811
|
-
#
|
|
6812
|
-
constructor(
|
|
6813
|
-
this.#
|
|
6998
|
+
return this.#total;
|
|
6999
|
+
}
|
|
7000
|
+
#items;
|
|
7001
|
+
#page;
|
|
7002
|
+
#pageSize;
|
|
7003
|
+
#pages;
|
|
7004
|
+
#total;
|
|
7005
|
+
constructor(items, page, pageSize, pages, total) {
|
|
7006
|
+
this.#items = items;
|
|
7007
|
+
this.#page = page;
|
|
7008
|
+
this.#pageSize = pageSize;
|
|
7009
|
+
this.#pages = pages;
|
|
7010
|
+
this.#total = total;
|
|
6814
7011
|
}
|
|
6815
7012
|
};
|
|
6816
|
-
|
|
6817
|
-
var
|
|
6818
|
-
var
|
|
7013
|
+
Paginated = __decorate([dto_default], Paginated);
|
|
7014
|
+
var Paginated_default = Paginated;
|
|
7015
|
+
var RequestError = class RequestError {
|
|
6819
7016
|
get code() {
|
|
6820
|
-
return this.#
|
|
7017
|
+
return this.#code;
|
|
6821
7018
|
}
|
|
6822
7019
|
get error() {
|
|
6823
|
-
return this.#
|
|
7020
|
+
return this.#error;
|
|
6824
7021
|
}
|
|
6825
7022
|
get errorDescription() {
|
|
6826
|
-
return this.#
|
|
7023
|
+
return this.#errorDescription;
|
|
6827
7024
|
}
|
|
6828
7025
|
get statusCode() {
|
|
6829
|
-
return this.#
|
|
6830
|
-
}
|
|
6831
|
-
#
|
|
6832
|
-
#
|
|
6833
|
-
#
|
|
6834
|
-
#
|
|
6835
|
-
constructor(
|
|
6836
|
-
this.#
|
|
7026
|
+
return this.#statusCode;
|
|
7027
|
+
}
|
|
7028
|
+
#code;
|
|
7029
|
+
#error;
|
|
7030
|
+
#errorDescription;
|
|
7031
|
+
#statusCode;
|
|
7032
|
+
constructor(code, error, errorDescription, statusCode) {
|
|
7033
|
+
this.#code = code;
|
|
7034
|
+
this.#error = error;
|
|
7035
|
+
this.#errorDescription = errorDescription;
|
|
7036
|
+
this.#statusCode = statusCode;
|
|
6837
7037
|
}
|
|
6838
7038
|
};
|
|
6839
|
-
|
|
6840
|
-
var
|
|
6841
|
-
var
|
|
7039
|
+
RequestError = __decorate([dto_default], RequestError);
|
|
7040
|
+
var RequestError_default = RequestError;
|
|
7041
|
+
var ValidationError = class ValidationError {
|
|
6842
7042
|
get code() {
|
|
6843
|
-
return this.#
|
|
7043
|
+
return this.#code;
|
|
6844
7044
|
}
|
|
6845
7045
|
get error() {
|
|
6846
|
-
return this.#
|
|
7046
|
+
return this.#error;
|
|
6847
7047
|
}
|
|
6848
7048
|
get errorDescription() {
|
|
6849
|
-
return this.#
|
|
7049
|
+
return this.#errorDescription;
|
|
6850
7050
|
}
|
|
6851
7051
|
get errors() {
|
|
6852
|
-
return this.#
|
|
7052
|
+
return this.#errors;
|
|
6853
7053
|
}
|
|
6854
7054
|
get params() {
|
|
6855
|
-
return this.#
|
|
6856
|
-
}
|
|
6857
|
-
#
|
|
6858
|
-
#
|
|
6859
|
-
#
|
|
6860
|
-
#
|
|
6861
|
-
#
|
|
6862
|
-
constructor(
|
|
6863
|
-
this.#
|
|
7055
|
+
return this.#params;
|
|
7056
|
+
}
|
|
7057
|
+
#code;
|
|
7058
|
+
#error;
|
|
7059
|
+
#errorDescription;
|
|
7060
|
+
#errors;
|
|
7061
|
+
#params;
|
|
7062
|
+
constructor(code, error, errorDescription, errors, params) {
|
|
7063
|
+
this.#code = code;
|
|
7064
|
+
this.#error = error;
|
|
7065
|
+
this.#errorDescription = errorDescription;
|
|
7066
|
+
this.#errors = errors;
|
|
7067
|
+
this.#params = params;
|
|
6864
7068
|
}
|
|
6865
7069
|
};
|
|
6866
|
-
|
|
6867
|
-
var
|
|
6868
|
-
var
|
|
6869
|
-
|
|
6870
|
-
|
|
6871
|
-
|
|
6872
|
-
|
|
6873
|
-
|
|
6874
|
-
|
|
6875
|
-
|
|
6876
|
-
|
|
6877
|
-
|
|
6878
|
-
|
|
6879
|
-
|
|
6880
|
-
|
|
6881
|
-
|
|
6882
|
-
|
|
6883
|
-
|
|
6884
|
-
|
|
6885
|
-
|
|
7070
|
+
ValidationError = __decorate([dto_default], ValidationError);
|
|
7071
|
+
var ValidationError_default = ValidationError;
|
|
7072
|
+
var _HttpAdapter;
|
|
7073
|
+
var HttpAdapter = _HttpAdapter = class HttpAdapter {
|
|
7074
|
+
static parsePaginatedAdapter(data, adapterMethod) {
|
|
7075
|
+
return new Paginated_default(data.items.map(adapterMethod), data.page, data.page_size, data.pages, data.total);
|
|
7076
|
+
}
|
|
7077
|
+
static parseFileNameFromContentDispositionHeader(header) {
|
|
7078
|
+
const defaultFilename = `download-${DateTime.now().toFormat("yyyy-MM-dd HH-mm-ss")}`;
|
|
7079
|
+
if (!header.startsWith("attachment")) return defaultFilename;
|
|
7080
|
+
const matches = /filename[^;=\n]*=((['"]).*?\2|[^;\n]*)/.exec(header);
|
|
7081
|
+
if ((matches?.length || 0) < 2) return defaultFilename;
|
|
7082
|
+
return matches[1].replaceAll("'", "").replaceAll("\"", "").replaceAll("/", "-").replaceAll(":", "-");
|
|
7083
|
+
}
|
|
7084
|
+
static parseRequestError(data, statusCode) {
|
|
7085
|
+
return new RequestError_default(data.code, data.error, data.error_description, statusCode);
|
|
7086
|
+
}
|
|
7087
|
+
static parseValidationError(data) {
|
|
7088
|
+
let errors;
|
|
7089
|
+
if (data.errors) {
|
|
7090
|
+
errors = {};
|
|
7091
|
+
Object.entries(data.errors).forEach(([key, value]) => {
|
|
7092
|
+
errors[key] = _HttpAdapter.parseValidationError(value);
|
|
7093
|
+
});
|
|
7094
|
+
}
|
|
7095
|
+
return new ValidationError_default(data.code, data.error, data.error_description, errors, data.params);
|
|
6886
7096
|
}
|
|
6887
7097
|
};
|
|
6888
|
-
|
|
7098
|
+
HttpAdapter = _HttpAdapter = __decorate([adapter_default], HttpAdapter);
|
|
6889
7099
|
function G$1(e) {
|
|
6890
7100
|
let t = unref(e);
|
|
6891
7101
|
return t ? R$2(t) ? t : t.$el ?? null : null;
|
|
@@ -7185,7 +7395,7 @@ function D$1(e, t, n, r = { passive: !0 }) {
|
|
|
7185
7395
|
function O$1(t, n = {}) {
|
|
7186
7396
|
let r = ref(n.initial ?? !1);
|
|
7187
7397
|
return watch(t, (i, a, o) => {
|
|
7188
|
-
let s = _$
|
|
7398
|
+
let s = _$2(t);
|
|
7189
7399
|
if (!s) return;
|
|
7190
7400
|
let c = new IntersectionObserver((e) => r.value = e[0]?.isIntersecting ?? !1, n);
|
|
7191
7401
|
c.observe(s), o(() => c.disconnect());
|
|
@@ -7211,7 +7421,7 @@ function k$1(e, t) {
|
|
|
7211
7421
|
function A$1(t) {
|
|
7212
7422
|
let n = ref(!0), r = ref(!0), i = ref(!0), a = ref(!0);
|
|
7213
7423
|
return watch(t, (o, s, c) => {
|
|
7214
|
-
let l = _$
|
|
7424
|
+
let l = _$2(t);
|
|
7215
7425
|
if (!l) return;
|
|
7216
7426
|
let u = () => {
|
|
7217
7427
|
let { scrollTop: e, scrollHeight: t, clientHeight: o, scrollLeft: s, scrollWidth: c, clientWidth: u } = l;
|
|
@@ -7249,11 +7459,11 @@ function j$1(e) {
|
|
|
7249
7459
|
var M$1 = 0;
|
|
7250
7460
|
function N$1(e = !1) {
|
|
7251
7461
|
let t = ref(`focus-trap-${++M$1}`), n = ref(!1);
|
|
7252
|
-
return onMounted(() => x$
|
|
7462
|
+
return onMounted(() => x$2.add(unref(t), (e) => n.value = e, e)), onUnmounted(() => x$2.remove(unref(t))), n;
|
|
7253
7463
|
}
|
|
7254
7464
|
function P$1(t, n) {
|
|
7255
7465
|
watch(t, (r, i, a) => {
|
|
7256
|
-
if (!_$
|
|
7466
|
+
if (!_$2(t) || unref(n)) return;
|
|
7257
7467
|
let o = document.activeElement;
|
|
7258
7468
|
a(() => {
|
|
7259
7469
|
requestAnimationFrame(() => o?.focus());
|
|
@@ -7261,21 +7471,21 @@ function P$1(t, n) {
|
|
|
7261
7471
|
});
|
|
7262
7472
|
}
|
|
7263
7473
|
function F$1(t, r = {}) {
|
|
7264
|
-
if (S$
|
|
7474
|
+
if (S$2) return;
|
|
7265
7475
|
let { disable: a = ref(!1), disableReturn: s = ref(!1), attachTo: c = null } = r, l = N$1(!a);
|
|
7266
7476
|
P$1(t, s), watch(t, (r, a, o) => {
|
|
7267
|
-
let s = _$
|
|
7268
|
-
l.value && s && document.activeElement && !s.contains(document.activeElement) && !s.querySelector(`[autofocus]`) && y$
|
|
7477
|
+
let s = _$2(t), u = c || document;
|
|
7478
|
+
l.value && s && document.activeElement && !s.contains(document.activeElement) && !s.querySelector(`[autofocus]`) && y$2(s, document.activeElement, !0);
|
|
7269
7479
|
function d(e) {
|
|
7270
7480
|
if (!l.value || !s) return;
|
|
7271
7481
|
let t = e.target || document.body;
|
|
7272
|
-
s.contains(t) || (e.preventDefault(), e.stopImmediatePropagation(), y$
|
|
7482
|
+
s.contains(t) || (e.preventDefault(), e.stopImmediatePropagation(), y$2(s, t));
|
|
7273
7483
|
}
|
|
7274
7484
|
function f(e) {
|
|
7275
7485
|
if (!l.value || !s) return;
|
|
7276
7486
|
(!e.relatedTarget || e.relatedTarget === document.body) && (e.preventDefault(), s.focus());
|
|
7277
7487
|
let t = e.target || document.body;
|
|
7278
|
-
s.contains(t) || y$
|
|
7488
|
+
s.contains(t) || y$2(s, t);
|
|
7279
7489
|
}
|
|
7280
7490
|
if (u.addEventListener(`focusin`, d, { capture: !0 }), u.addEventListener(`focusout`, f, { capture: !0 }), s) {
|
|
7281
7491
|
let e = s.querySelector(`[autofocus]`);
|
|
@@ -7289,7 +7499,7 @@ function F$1(t, r = {}) {
|
|
|
7289
7499
|
u.removeEventListener(`focusin`, d), u.removeEventListener(`focusout`, f);
|
|
7290
7500
|
});
|
|
7291
7501
|
}, { immediate: !0 }), watch(() => a, () => {
|
|
7292
|
-
let r = _$
|
|
7502
|
+
let r = _$2(t);
|
|
7293
7503
|
if (l.value = !a, a || !r) return;
|
|
7294
7504
|
let i = s$1(r);
|
|
7295
7505
|
i.includes(document.activeElement) || i[0]?.focus();
|
|
@@ -7339,7 +7549,7 @@ function R$1(e, n, r, i) {
|
|
|
7339
7549
|
break;
|
|
7340
7550
|
default: return;
|
|
7341
7551
|
}
|
|
7342
|
-
let o = c$
|
|
7552
|
+
let o = c$2(n, document.activeElement, a);
|
|
7343
7553
|
o && i(r.indexOf(o)), e.preventDefault();
|
|
7344
7554
|
}
|
|
7345
7555
|
function z$1(e, t, n, r, i, o) {
|
|
@@ -7347,7 +7557,7 @@ function z$1(e, t, n, r, i, o) {
|
|
|
7347
7557
|
if (e.key === (r === `horizontal` ? `ArrowLeft` : `ArrowUp`)) s = -1;
|
|
7348
7558
|
else if (e.key === (r === `horizontal` ? `ArrowRight` : `ArrowDown`)) s = 1;
|
|
7349
7559
|
else return;
|
|
7350
|
-
let c = h$
|
|
7560
|
+
let c = h$2(t, s);
|
|
7351
7561
|
c ? o(i.indexOf(c)) : n && o(s === 1 ? 0 : i.length - 1), e.preventDefault();
|
|
7352
7562
|
}
|
|
7353
7563
|
//#endregion
|
|
@@ -7438,7 +7648,7 @@ var FluxIcon_default = /* @__PURE__ */ defineComponent({
|
|
|
7438
7648
|
if (!__props.name) return null;
|
|
7439
7649
|
const icon = iconRegistry[__props.name];
|
|
7440
7650
|
if (!icon) {
|
|
7441
|
-
v$
|
|
7651
|
+
v$2(`Unknown icon: ${__props.name}`);
|
|
7442
7652
|
return null;
|
|
7443
7653
|
}
|
|
7444
7654
|
return {
|
|
@@ -7709,11 +7919,11 @@ var FluxButton_default = /* @__PURE__ */ defineComponent({
|
|
|
7709
7919
|
});
|
|
7710
7920
|
//#endregion
|
|
7711
7921
|
//#region src/css/component/Action.module.scss
|
|
7712
|
-
var { "
|
|
7922
|
+
var { "buttonIcon": _0$15, "button": _1$6, "buttonLabel": _2$5 } = Button_module_default$1;
|
|
7713
7923
|
var Action_module_default = {
|
|
7714
|
-
action: `action ${
|
|
7924
|
+
action: `action ${_1$6}`,
|
|
7715
7925
|
spinner: `spinner`,
|
|
7716
|
-
actionIcon: `action-icon ${
|
|
7926
|
+
actionIcon: `action-icon ${_0$15}`,
|
|
7717
7927
|
isDestructive: `is-destructive`,
|
|
7718
7928
|
actionLabel: `action-label ${_2$5}`,
|
|
7719
7929
|
actionBar: `action-bar`,
|
|
@@ -7999,7 +8209,7 @@ function useDropdownPopup(options) {
|
|
|
7999
8209
|
isOpen.value = !unref(isOpen);
|
|
8000
8210
|
}
|
|
8001
8211
|
function focusAnchor() {
|
|
8002
|
-
nextTick(() => _$
|
|
8212
|
+
nextTick(() => _$2(options.anchorRef)?.focus());
|
|
8003
8213
|
}
|
|
8004
8214
|
function onKeyDownBase(evt) {
|
|
8005
8215
|
if (evt.key === "Escape" && unref(isOpen)) {
|
|
@@ -9080,32 +9290,32 @@ function useTreeView(params) {
|
|
|
9080
9290
|
}
|
|
9081
9291
|
//#endregion
|
|
9082
9292
|
//#region src/css/component/Button.module.scss
|
|
9083
|
-
var { "
|
|
9293
|
+
var { "buttonIcon": _0$14, "button": _1$5, "buttonLabel": _2$4 } = Button_module_default$1;
|
|
9084
9294
|
var Button_module_default = {
|
|
9085
|
-
primaryButton: `primary-button ${
|
|
9295
|
+
primaryButton: `primary-button ${_1$5}`,
|
|
9086
9296
|
spinner: `spinner`,
|
|
9087
|
-
primaryButtonIcon: `primary-button-icon ${
|
|
9088
|
-
primaryButtonLabel: `primary-button-label ${
|
|
9089
|
-
secondaryButton: `secondary-button ${
|
|
9090
|
-
secondaryButtonIcon: `secondary-button-icon ${
|
|
9091
|
-
secondaryButtonLabel: `secondary-button-label ${
|
|
9092
|
-
destructiveButton: `destructive-button ${
|
|
9093
|
-
destructiveButtonIcon: `destructive-button-icon ${
|
|
9094
|
-
destructiveButtonLabel: `destructive-button-label ${
|
|
9095
|
-
baseLinkButton: `base-link-button ${
|
|
9096
|
-
primaryLinkButton: `primary-link-button base-link-button ${
|
|
9097
|
-
primaryLinkButtonIcon: `primary-link-button-icon ${
|
|
9098
|
-
primaryLinkButtonLabel: `primary-link-button-label ${
|
|
9099
|
-
secondaryLinkButton: `secondary-link-button base-link-button ${
|
|
9100
|
-
secondaryLinkButtonIcon: `secondary-link-button-icon ${
|
|
9101
|
-
secondaryLinkButtonLabel: `secondary-link-button-label ${
|
|
9102
|
-
linkButton: `link-button ${
|
|
9103
|
-
linkButtonIcon: `link-button-icon ${
|
|
9297
|
+
primaryButtonIcon: `primary-button-icon ${_0$14}`,
|
|
9298
|
+
primaryButtonLabel: `primary-button-label ${_2$4}`,
|
|
9299
|
+
secondaryButton: `secondary-button ${_1$5}`,
|
|
9300
|
+
secondaryButtonIcon: `secondary-button-icon ${_0$14}`,
|
|
9301
|
+
secondaryButtonLabel: `secondary-button-label ${_2$4}`,
|
|
9302
|
+
destructiveButton: `destructive-button ${_1$5}`,
|
|
9303
|
+
destructiveButtonIcon: `destructive-button-icon ${_0$14}`,
|
|
9304
|
+
destructiveButtonLabel: `destructive-button-label ${_2$4}`,
|
|
9305
|
+
baseLinkButton: `base-link-button ${_1$5}`,
|
|
9306
|
+
primaryLinkButton: `primary-link-button base-link-button ${_1$5}`,
|
|
9307
|
+
primaryLinkButtonIcon: `primary-link-button-icon ${_0$14}`,
|
|
9308
|
+
primaryLinkButtonLabel: `primary-link-button-label ${_2$4}`,
|
|
9309
|
+
secondaryLinkButton: `secondary-link-button base-link-button ${_1$5}`,
|
|
9310
|
+
secondaryLinkButtonIcon: `secondary-link-button-icon ${_0$14}`,
|
|
9311
|
+
secondaryLinkButtonLabel: `secondary-link-button-label ${_2$4}`,
|
|
9312
|
+
linkButton: `link-button ${_1$5}`,
|
|
9313
|
+
linkButtonIcon: `link-button-icon ${_0$14}`,
|
|
9104
9314
|
icon: `icon`,
|
|
9105
|
-
linkButtonLabel: `link-button-label ${
|
|
9106
|
-
publishButton: `publish-button primary-button ${
|
|
9107
|
-
publishButtonIcon: `publish-button-icon primary-button-icon ${
|
|
9108
|
-
publishButtonLabel: `publish-button-label primary-button-label ${
|
|
9315
|
+
linkButtonLabel: `link-button-label ${_2$4}`,
|
|
9316
|
+
publishButton: `publish-button primary-button ${_1$5}`,
|
|
9317
|
+
publishButtonIcon: `publish-button-icon primary-button-icon ${_0$14}`,
|
|
9318
|
+
publishButtonLabel: `publish-button-label primary-button-label ${_2$4}`,
|
|
9109
9319
|
publishButtonAnimation: `publish-button-animation`,
|
|
9110
9320
|
isDone: `is-done`,
|
|
9111
9321
|
publishButtonAnimationArrow: `publish-button-animation-arrow`,
|
|
@@ -9687,10 +9897,10 @@ var FluxFlyout_default = /* @__PURE__ */ defineComponent({
|
|
|
9687
9897
|
const paneY = ref(0);
|
|
9688
9898
|
const paneMarginX = ref(0);
|
|
9689
9899
|
const paneMarginY = ref(0);
|
|
9690
|
-
!S$
|
|
9900
|
+
!S$2 && D$1(ref(window), "resize", () => unref(isOpen) && reposition());
|
|
9691
9901
|
F$1(paneRef);
|
|
9692
9902
|
function close() {
|
|
9693
|
-
const pane = _$
|
|
9903
|
+
const pane = _$2(paneRef);
|
|
9694
9904
|
if (!pane) return;
|
|
9695
9905
|
pane.addEventListener("animationend", () => {
|
|
9696
9906
|
isClosing.value = false;
|
|
@@ -9704,7 +9914,7 @@ var FluxFlyout_default = /* @__PURE__ */ defineComponent({
|
|
|
9704
9914
|
openerWidth.value = width;
|
|
9705
9915
|
openerHeight.value = height;
|
|
9706
9916
|
requestAnimationFrame(() => {
|
|
9707
|
-
_$
|
|
9917
|
+
_$2(paneRef).addEventListener("animationend", () => {
|
|
9708
9918
|
isOpening.value = false;
|
|
9709
9919
|
}, { once: true });
|
|
9710
9920
|
isOpening.value = true;
|
|
@@ -9713,7 +9923,7 @@ var FluxFlyout_default = /* @__PURE__ */ defineComponent({
|
|
|
9713
9923
|
}
|
|
9714
9924
|
function reposition() {
|
|
9715
9925
|
const mount = unref(mountRef);
|
|
9716
|
-
const pane = _$
|
|
9926
|
+
const pane = _$2(paneRef);
|
|
9717
9927
|
const { top, left, width, height } = mount.children[0].getBoundingClientRect();
|
|
9718
9928
|
const { width: paneWidth, height: paneHeight } = pane.getBoundingClientRect();
|
|
9719
9929
|
let x, y, mx = 0, my = 0;
|
|
@@ -10079,7 +10289,7 @@ var FluxAdaptiveGroup_default = /* @__PURE__ */ defineComponent({
|
|
|
10079
10289
|
const elementRef = useTemplateRef("element");
|
|
10080
10290
|
const children = shallowReactive(/* @__PURE__ */ new Map());
|
|
10081
10291
|
const reflow = i$2(() => {
|
|
10082
|
-
const element = _$
|
|
10292
|
+
const element = _$2(elementRef);
|
|
10083
10293
|
if (!element) return;
|
|
10084
10294
|
const available = element.clientWidth;
|
|
10085
10295
|
const entries = Array.from(children.entries());
|
|
@@ -10183,7 +10393,7 @@ var FluxAdaptiveSlot_default = /* @__PURE__ */ defineComponent({
|
|
|
10183
10393
|
} else {
|
|
10184
10394
|
let lastFailedParentWidth = -1;
|
|
10185
10395
|
const reflow = i$2(() => {
|
|
10186
|
-
const element = _$
|
|
10396
|
+
const element = _$2(elementRef);
|
|
10187
10397
|
if (!element || !isDefaultVisible.value) return;
|
|
10188
10398
|
if (desiredDefaultWidth.value > element.clientWidth) {
|
|
10189
10399
|
lastFailedParentWidth = element.parentElement?.clientWidth ?? -1;
|
|
@@ -10260,7 +10470,7 @@ var FluxAnimatedColors_default = /* @__PURE__ */ defineComponent({
|
|
|
10260
10470
|
const tick = ref(0);
|
|
10261
10471
|
const polygons = computed(() => {
|
|
10262
10472
|
if (!__props.colors || __props.colors.length === 0) return [];
|
|
10263
|
-
const mulberry = V$
|
|
10473
|
+
const mulberry = V$1(__props.seed ?? componentId.value);
|
|
10264
10474
|
const polygons = [];
|
|
10265
10475
|
for (const color of __props.colors) {
|
|
10266
10476
|
const localMulberry = mulberry.fork();
|
|
@@ -11547,6 +11757,13 @@ var FluxDatePicker_default = /* @__PURE__ */ defineComponent({
|
|
|
11547
11757
|
var LayerPane_module_default = {
|
|
11548
11758
|
layerPane: `layer-pane`,
|
|
11549
11759
|
basePaneStructure: `base-pane-structure`,
|
|
11760
|
+
layerPaneGray: `layer-pane-gray layer-pane`,
|
|
11761
|
+
layerPanePrimary: `layer-pane-primary layer-pane`,
|
|
11762
|
+
layerPaneDanger: `layer-pane-danger layer-pane`,
|
|
11763
|
+
paneHeaderIcon: `pane-header-icon`,
|
|
11764
|
+
layerPaneInfo: `layer-pane-info layer-pane`,
|
|
11765
|
+
layerPaneSuccess: `layer-pane-success layer-pane`,
|
|
11766
|
+
layerPaneWarning: `layer-pane-warning layer-pane`,
|
|
11550
11767
|
paneFooter: `pane-footer`,
|
|
11551
11768
|
paneHeader: `pane-header`,
|
|
11552
11769
|
button: `button`,
|
|
@@ -11556,9 +11773,10 @@ var LayerPane_module_default = {
|
|
|
11556
11773
|
//#region src/component/FluxLayerPane.vue
|
|
11557
11774
|
var FluxLayerPane_default = /* @__PURE__ */ defineComponent({
|
|
11558
11775
|
__name: "FluxLayerPane",
|
|
11776
|
+
props: { color: { default: "gray" } },
|
|
11559
11777
|
setup(__props) {
|
|
11560
11778
|
return (_ctx, _cache) => {
|
|
11561
|
-
return openBlock(), createElementBlock("div", { class: normalizeClass(unref(LayerPane_module_default).
|
|
11779
|
+
return openBlock(), createElementBlock("div", { class: normalizeClass(unref(clsx)(__props.color === "gray" && unref(LayerPane_module_default).layerPaneGray, __props.color === "primary" && unref(LayerPane_module_default).layerPanePrimary, __props.color === "danger" && unref(LayerPane_module_default).layerPaneDanger, __props.color === "info" && unref(LayerPane_module_default).layerPaneInfo, __props.color === "success" && unref(LayerPane_module_default).layerPaneSuccess, __props.color === "warning" && unref(LayerPane_module_default).layerPaneWarning)) }, [renderSlot(_ctx.$slots, "default")], 2);
|
|
11562
11780
|
};
|
|
11563
11781
|
}
|
|
11564
11782
|
});
|
|
@@ -12618,7 +12836,7 @@ var FluxCommandPalette_default = /* @__PURE__ */ defineComponent({
|
|
|
12618
12836
|
else open();
|
|
12619
12837
|
}
|
|
12620
12838
|
}
|
|
12621
|
-
if (!S$
|
|
12839
|
+
if (!S$2 && props.hasKeyboardShortcut) {
|
|
12622
12840
|
onMounted(() => {
|
|
12623
12841
|
window.addEventListener("keydown", onGlobalKeyDown);
|
|
12624
12842
|
});
|
|
@@ -12968,7 +13186,7 @@ var CoordinatePicker_default = /* @__PURE__ */ defineComponent({
|
|
|
12968
13186
|
requestAnimationFrame(() => onPointerMove(evt));
|
|
12969
13187
|
}
|
|
12970
13188
|
function onPointerMove(evt) {
|
|
12971
|
-
const root = _$
|
|
13189
|
+
const root = _$2(rootRef);
|
|
12972
13190
|
if (!unref(isDragging) || !root) return;
|
|
12973
13191
|
const [maxX, maxY] = unref(max);
|
|
12974
13192
|
const [minX, minY] = unref(min);
|
|
@@ -13181,10 +13399,10 @@ var FluxFormInput_default = /* @__PURE__ */ defineComponent({
|
|
|
13181
13399
|
const localValue = ref(null);
|
|
13182
13400
|
const nativeType = ref(__props.type);
|
|
13183
13401
|
function blur() {
|
|
13184
|
-
_$
|
|
13402
|
+
_$2(inputRef)?.blur();
|
|
13185
13403
|
}
|
|
13186
13404
|
function focus() {
|
|
13187
|
-
_$
|
|
13405
|
+
_$2(inputRef)?.focus();
|
|
13188
13406
|
}
|
|
13189
13407
|
function passwordTypeToggle() {
|
|
13190
13408
|
if (__props.type !== "password") return;
|
|
@@ -13937,7 +14155,7 @@ var SelectBase_default = /* @__PURE__ */ defineComponent({
|
|
|
13937
14155
|
const searchInputElementRef = useTemplateRef("searchInputElement");
|
|
13938
14156
|
const highlightedIndex = ref(INITIAL_HIGHLIGHTED_INDEX);
|
|
13939
14157
|
const isKeyboardAction = ref(false);
|
|
13940
|
-
const focusElement = computed(() => _$
|
|
14158
|
+
const focusElement = computed(() => _$2(searchInputElementRef) ?? _$2(anchorRef));
|
|
13941
14159
|
const highlightedId = computed(() => unref(rawOptions)[unref(highlightedIndex)]?.value);
|
|
13942
14160
|
const rawOptions = computed(() => __props.options.map((group) => group[1]).flat());
|
|
13943
14161
|
const { isOpen: isPopupOpen, toggle, onKeyDownBase } = useDropdownPopup({
|
|
@@ -14173,8 +14391,8 @@ var FluxTicks_default = /* @__PURE__ */ defineComponent({
|
|
|
14173
14391
|
upper: {}
|
|
14174
14392
|
},
|
|
14175
14393
|
setup(__props) {
|
|
14176
|
-
const smallTicks = computed(() => g$
|
|
14177
|
-
const ticks = computed(() => g$
|
|
14394
|
+
const smallTicks = computed(() => g$1(__props.lower, __props.upper, 50, true).filter((s) => !ticks.value.includes(s)));
|
|
14395
|
+
const ticks = computed(() => g$1(__props.lower, __props.upper, 5));
|
|
14178
14396
|
return (_ctx, _cache) => {
|
|
14179
14397
|
return openBlock(), createElementBlock("div", { class: normalizeClass(unref(Slider_module_default).ticks) }, [(openBlock(true), createElementBlock(Fragment, null, renderList(ticks.value, (tick) => {
|
|
14180
14398
|
return openBlock(), createElementBlock("div", {
|
|
@@ -14220,7 +14438,7 @@ var SliderBase_default = /* @__PURE__ */ defineComponent({
|
|
|
14220
14438
|
requestAnimationFrame(() => onPointerMove(evt));
|
|
14221
14439
|
}
|
|
14222
14440
|
function onPointerMove(evt) {
|
|
14223
|
-
const root = _$
|
|
14441
|
+
const root = _$2(rootRef);
|
|
14224
14442
|
if (!__props.isDragging || !root) return;
|
|
14225
14443
|
let { left, width } = root.getBoundingClientRect();
|
|
14226
14444
|
left += 6;
|
|
@@ -14547,7 +14765,7 @@ var FluxFormSlider_default = /* @__PURE__ */ defineComponent({
|
|
|
14547
14765
|
name: {},
|
|
14548
14766
|
formatter: {
|
|
14549
14767
|
type: Function,
|
|
14550
|
-
default: p$
|
|
14768
|
+
default: p$4
|
|
14551
14769
|
},
|
|
14552
14770
|
ariaLabel: {},
|
|
14553
14771
|
isTicksVisible: { type: Boolean },
|
|
@@ -14781,7 +14999,7 @@ var FluxColorPicker_default = /* @__PURE__ */ defineComponent({
|
|
|
14781
14999
|
];
|
|
14782
15000
|
switch (__props.type) {
|
|
14783
15001
|
case "hex":
|
|
14784
|
-
hsv.value = P$2(...j$
|
|
15002
|
+
hsv.value = P$2(...j$2(hex));
|
|
14785
15003
|
break;
|
|
14786
15004
|
case "rgb":
|
|
14787
15005
|
hsv.value = P$2(...values);
|
|
@@ -14797,7 +15015,7 @@ var FluxColorPicker_default = /* @__PURE__ */ defineComponent({
|
|
|
14797
15015
|
watch(hsv, (hsv) => {
|
|
14798
15016
|
switch (__props.type) {
|
|
14799
15017
|
case "hex":
|
|
14800
|
-
modelValue.value = W$
|
|
15018
|
+
modelValue.value = W$1(...F$2(...hsv));
|
|
14801
15019
|
break;
|
|
14802
15020
|
case "rgb":
|
|
14803
15021
|
modelValue.value = F$2(...hsv);
|
|
@@ -15237,16 +15455,16 @@ var FluxFormSelect_default = /* @__PURE__ */ defineComponent({
|
|
|
15237
15455
|
});
|
|
15238
15456
|
//#endregion
|
|
15239
15457
|
//#region src/css/component/Pagination.module.scss
|
|
15240
|
-
var { "
|
|
15458
|
+
var { "secondaryButton": _0$8, "secondaryButtonIcon": _1$2, "secondaryButtonLabel": _2$1 } = Button_module_default;
|
|
15241
15459
|
var Pagination_module_default = {
|
|
15242
15460
|
pagination: `pagination`,
|
|
15243
|
-
paginationButton: `pagination-button ${
|
|
15461
|
+
paginationButton: `pagination-button ${_0$8}`,
|
|
15244
15462
|
secondaryButton: `secondary-button`,
|
|
15245
15463
|
paginationButtonArrow: `pagination-button-arrow`,
|
|
15246
15464
|
paginationButtonCurrent: `pagination-button-current`,
|
|
15247
15465
|
paginationButtonSpacer: `pagination-button-spacer`,
|
|
15248
|
-
paginationButtonIcon: `pagination-button-icon ${
|
|
15249
|
-
paginationButtonLabel: `pagination-button-label ${
|
|
15466
|
+
paginationButtonIcon: `pagination-button-icon ${_1$2}`,
|
|
15467
|
+
paginationButtonLabel: `pagination-button-label ${_2$1}`,
|
|
15250
15468
|
paginationBar: `pagination-bar`,
|
|
15251
15469
|
paginationBarLimit: `pagination-bar-limit`,
|
|
15252
15470
|
paginationBarLimitDisplayingOf: `pagination-bar-limit-displaying-of`,
|
|
@@ -15508,13 +15726,13 @@ var FluxPaginationBar_default = /* @__PURE__ */ defineComponent({
|
|
|
15508
15726
|
});
|
|
15509
15727
|
//#endregion
|
|
15510
15728
|
//#region src/css/component/Table.module.scss
|
|
15511
|
-
var { "
|
|
15729
|
+
var { "basePaneElement": _0$7, "basePaneLoader": _1$1 } = Pane_module_default$1;
|
|
15512
15730
|
var Table_module_default = {
|
|
15513
|
-
table: `table ${
|
|
15731
|
+
table: `table ${_0$7}`,
|
|
15514
15732
|
tableBase: `table-base`,
|
|
15515
15733
|
tableFill: `table-fill`,
|
|
15516
15734
|
tablePagination: `table-pagination`,
|
|
15517
|
-
tableLoader: `table-loader ${
|
|
15735
|
+
tableLoader: `table-loader ${_1$1}`,
|
|
15518
15736
|
tableRow: `table-row`,
|
|
15519
15737
|
isSelectableRow: `is-selectable-row`,
|
|
15520
15738
|
tableCell: `table-cell`,
|
|
@@ -16373,14 +16591,14 @@ var FluxExpandableGroup_default = /* @__PURE__ */ defineComponent({
|
|
|
16373
16591
|
const expandables = {};
|
|
16374
16592
|
function closeAll() {
|
|
16375
16593
|
Object.values(expandables).forEach((expandable) => {
|
|
16376
|
-
const isOpenRef = m$
|
|
16594
|
+
const isOpenRef = m$1(expandable, "isOpen");
|
|
16377
16595
|
isOpenRef.value = false;
|
|
16378
16596
|
});
|
|
16379
16597
|
}
|
|
16380
16598
|
function register(uid, expandable) {
|
|
16381
16599
|
expandables[uid] = expandable;
|
|
16382
16600
|
if (!__props.isControlled && Object.values(expandables).length === 1) {
|
|
16383
|
-
const isOpenRef = m$
|
|
16601
|
+
const isOpenRef = m$1(expandable, "isOpen");
|
|
16384
16602
|
isOpenRef.value = true;
|
|
16385
16603
|
}
|
|
16386
16604
|
}
|
|
@@ -16415,7 +16633,7 @@ var FluxFader_default = /* @__PURE__ */ defineComponent({
|
|
|
16415
16633
|
de$1(__props.interval, () => next());
|
|
16416
16634
|
const current = ref(-1);
|
|
16417
16635
|
const count = computed(() => {
|
|
16418
|
-
return _$
|
|
16636
|
+
return _$2(faderRef)?.children.length ?? 0;
|
|
16419
16637
|
});
|
|
16420
16638
|
function next() {
|
|
16421
16639
|
current.value = unref(current) + 1 >= unref(count) ? 0 : unref(current) + 1;
|
|
@@ -16424,7 +16642,7 @@ var FluxFader_default = /* @__PURE__ */ defineComponent({
|
|
|
16424
16642
|
current.value = unref(current) - 1 <= -1 ? unref(count) - 1 : unref(current) - 1;
|
|
16425
16643
|
}
|
|
16426
16644
|
watch(current, (current) => {
|
|
16427
|
-
const fader = _$
|
|
16645
|
+
const fader = _$2(faderRef);
|
|
16428
16646
|
if (!fader || fader.children.length === 0 || current < 0) return;
|
|
16429
16647
|
Array.from(fader.children).forEach((item) => item.classList.remove(Fader_module_default.isCurrent));
|
|
16430
16648
|
fader.children[current].classList.add(Fader_module_default.isCurrent);
|
|
@@ -16471,7 +16689,7 @@ var FluxFilterBase_default = /* @__PURE__ */ defineComponent({
|
|
|
16471
16689
|
const slots = useSlots();
|
|
16472
16690
|
function resolveDefinition(vnode) {
|
|
16473
16691
|
const factory = vnode.type?.__filterDefinitionFactory;
|
|
16474
|
-
return typeof factory === "function" ? factory(p$
|
|
16692
|
+
return typeof factory === "function" ? factory(p$3(vnode)) : null;
|
|
16475
16693
|
}
|
|
16476
16694
|
const flattenedFilters = computed(() => a$2(slots.filters?.() ?? []));
|
|
16477
16695
|
const buttons = computed(() => {
|
|
@@ -16498,7 +16716,7 @@ var FluxFilterBase_default = /* @__PURE__ */ defineComponent({
|
|
|
16498
16716
|
const menuItems = [[]];
|
|
16499
16717
|
const items = unref(flattenedFilters);
|
|
16500
16718
|
for (const item of items) {
|
|
16501
|
-
if (f$
|
|
16719
|
+
if (f$3(item) === "FluxSeparator") {
|
|
16502
16720
|
menuItems.push([]);
|
|
16503
16721
|
continue;
|
|
16504
16722
|
}
|
|
@@ -16746,7 +16964,7 @@ var FluxOverflowBar_default = /* @__PURE__ */ defineComponent({
|
|
|
16746
16964
|
const reflow = i$2(() => {
|
|
16747
16965
|
const bar = unref(barRef);
|
|
16748
16966
|
const measurer = unref(measurerRef);
|
|
16749
|
-
const overflow = _$
|
|
16967
|
+
const overflow = _$2(overflowRef);
|
|
16750
16968
|
availableSize.value = __props.direction === "horizontal" ? bar.offsetWidth : bar.offsetHeight;
|
|
16751
16969
|
itemSizes.value = Array.from(measurer.children).filter((item) => item instanceof HTMLElement).map((item) => {
|
|
16752
16970
|
const { display } = getComputedStyle(item);
|
|
@@ -17353,7 +17571,7 @@ var FluxFilterRange_default = /* @__PURE__ */ defineComponent({
|
|
|
17353
17571
|
async getValueLabel(value) {
|
|
17354
17572
|
if (!value || !Array.isArray(value) || value.length !== 2) return null;
|
|
17355
17573
|
const [lower, upper] = value;
|
|
17356
|
-
const format = p.formatter ?? p$
|
|
17574
|
+
const format = p.formatter ?? p$4;
|
|
17357
17575
|
return `${format(lower)} – ${format(upper)}`;
|
|
17358
17576
|
}
|
|
17359
17577
|
})),
|
|
@@ -17375,7 +17593,7 @@ var FluxFilterRange_default = /* @__PURE__ */ defineComponent({
|
|
|
17375
17593
|
onClear: { type: Function },
|
|
17376
17594
|
formatter: {
|
|
17377
17595
|
type: Function,
|
|
17378
|
-
default: p$
|
|
17596
|
+
default: p$4
|
|
17379
17597
|
},
|
|
17380
17598
|
isTicksVisible: { type: Boolean },
|
|
17381
17599
|
max: {},
|
|
@@ -17491,7 +17709,7 @@ var FluxFlickeringGrid_default = /* @__PURE__ */ defineComponent({
|
|
|
17491
17709
|
setup(__props) {
|
|
17492
17710
|
const canvasRef = useTemplateRef("canvas");
|
|
17493
17711
|
const inView = O$1(canvasRef);
|
|
17494
|
-
const mulberry = V$
|
|
17712
|
+
const mulberry = V$1(13);
|
|
17495
17713
|
const rgb = computed(() => {
|
|
17496
17714
|
const canvas = document.createElement("canvas");
|
|
17497
17715
|
canvas.width = canvas.height = 1;
|
|
@@ -18220,7 +18438,7 @@ var FluxFormRangeSlider_default = /* @__PURE__ */ defineComponent({
|
|
|
18220
18438
|
name: {},
|
|
18221
18439
|
formatter: {
|
|
18222
18440
|
type: Function,
|
|
18223
|
-
default: p$
|
|
18441
|
+
default: p$4
|
|
18224
18442
|
},
|
|
18225
18443
|
isTicksVisible: { type: Boolean },
|
|
18226
18444
|
isTooltipDisabled: { type: Boolean },
|
|
@@ -19208,7 +19426,7 @@ var FluxFormTimeZonePicker_default = /* @__PURE__ */ defineComponent({
|
|
|
19208
19426
|
const disabled = useDisabled_default(toRef(() => __props.disabled));
|
|
19209
19427
|
const translate = useTranslate_default();
|
|
19210
19428
|
const options = computed(() => {
|
|
19211
|
-
if (S$
|
|
19429
|
+
if (S$2) return [];
|
|
19212
19430
|
const groups = {};
|
|
19213
19431
|
const options = [];
|
|
19214
19432
|
for (const timeZone of TIME_ZONES) {
|
|
@@ -19334,7 +19552,7 @@ var FluxFormTreeViewSelect_default = /* @__PURE__ */ defineComponent({
|
|
|
19334
19552
|
const { isOpen: isPopupOpen, toggle, focusAnchor, onKeyDownBase } = useDropdownPopup({
|
|
19335
19553
|
anchorRef,
|
|
19336
19554
|
popupRef: anchorPopupRef,
|
|
19337
|
-
focusElement: computed(() => _$
|
|
19555
|
+
focusElement: computed(() => _$2(searchInputRef) ?? _$2(anchorRef)),
|
|
19338
19556
|
disabled,
|
|
19339
19557
|
readonly: toRef(() => !!__props.isReadonly)
|
|
19340
19558
|
});
|
|
@@ -20948,7 +21166,7 @@ var FluxPaneIllustration_default = /* @__PURE__ */ defineComponent({
|
|
|
20948
21166
|
const slots = useSlots();
|
|
20949
21167
|
const borderColor = computed(() => {
|
|
20950
21168
|
if (!__props.animatedColors || __props.animatedColors.length === 0) return "transparent";
|
|
20951
|
-
const [r, g, b] = j$
|
|
21169
|
+
const [r, g, b] = j$2(__props.animatedColors[0]);
|
|
20952
21170
|
return `rgb(${r} ${g} ${b} / .15)`;
|
|
20953
21171
|
});
|
|
20954
21172
|
return (_ctx, _cache) => {
|
|
@@ -21033,7 +21251,7 @@ var FluxPercentageBar_default = /* @__PURE__ */ defineComponent({
|
|
|
21033
21251
|
key: 0,
|
|
21034
21252
|
name: item.icon,
|
|
21035
21253
|
size: 16
|
|
21036
|
-
}, null, 8, ["name"])) : createCommentVNode("", true), createElementVNode("span", null, toDisplayString(unref(m$
|
|
21254
|
+
}, null, 8, ["name"])) : createCommentVNode("", true), createElementVNode("span", null, toDisplayString(unref(m$2)(item.value)) + " " + toDisplayString(item.label), 1)], 2)]),
|
|
21037
21255
|
default: withCtx(() => [createElementVNode("div", {
|
|
21038
21256
|
class: normalizeClass(unref(PercentageBar_module_default).percentageBarSegment),
|
|
21039
21257
|
style: normalizeStyle({
|
|
@@ -21388,7 +21606,7 @@ var FluxQuantitySelector_default = /* @__PURE__ */ defineComponent({
|
|
|
21388
21606
|
modelValue.value = Math.min(__props.max, unref(modelValue) + __props.step);
|
|
21389
21607
|
}
|
|
21390
21608
|
function sizeToContent() {
|
|
21391
|
-
const input = _$
|
|
21609
|
+
const input = _$2(inputRef);
|
|
21392
21610
|
if (!input || isNaN(input.valueAsNumber)) return;
|
|
21393
21611
|
width.value = 0;
|
|
21394
21612
|
requestAnimationFrame(() => {
|
|
@@ -21658,7 +21876,7 @@ var FluxTooltipProvider_vue_vue_type_script_lang_default = defineComponent(() =>
|
|
|
21658
21876
|
const content = computed(() => unref(tooltip) ? unref(tooltip).contentSlot?.() ?? [unref(tooltip).content] : null);
|
|
21659
21877
|
const has = computed(() => !!unref(tooltip));
|
|
21660
21878
|
function calculate() {
|
|
21661
|
-
const element = _$
|
|
21879
|
+
const element = _$2(elementRef);
|
|
21662
21880
|
const spec = unref(tooltip);
|
|
21663
21881
|
if (!spec || !element || !unref(content)) {
|
|
21664
21882
|
position.value = null;
|
|
@@ -21685,7 +21903,7 @@ var FluxTooltipProvider_vue_vue_type_script_lang_default = defineComponent(() =>
|
|
|
21685
21903
|
watch(content, () => requestAnimationFrame(calculate));
|
|
21686
21904
|
watch(has, (isVisible) => {
|
|
21687
21905
|
if (!isVisible) return;
|
|
21688
|
-
const host = _$
|
|
21906
|
+
const host = _$2(hostRef);
|
|
21689
21907
|
if (host && !host.matches(":popover-open")) host.showPopover();
|
|
21690
21908
|
});
|
|
21691
21909
|
return () => h("div", {
|
|
@@ -21694,7 +21912,7 @@ var FluxTooltipProvider_vue_vue_type_script_lang_default = defineComponent(() =>
|
|
|
21694
21912
|
class: Tooltip_module_default.tooltipHost
|
|
21695
21913
|
}, [h(FluxTooltipTransition_default, { onAfterLeave: () => {
|
|
21696
21914
|
if (unref(has)) return;
|
|
21697
|
-
const host = _$
|
|
21915
|
+
const host = _$2(hostRef);
|
|
21698
21916
|
if (host && host.matches(":popover-open")) host.hidePopover();
|
|
21699
21917
|
} }, { default: () => {
|
|
21700
21918
|
if (!unref(has)) return;
|
|
@@ -22594,7 +22812,7 @@ var FluxTabBar_default = /* @__PURE__ */ defineComponent({
|
|
|
22594
22812
|
}
|
|
22595
22813
|
});
|
|
22596
22814
|
function checkScroll() {
|
|
22597
|
-
const tabBar = _$
|
|
22815
|
+
const tabBar = _$2(tabBarRef);
|
|
22598
22816
|
if (tabBar.scrollWidth <= tabBar.offsetWidth) {
|
|
22599
22817
|
isEndArrowVisible.value = false;
|
|
22600
22818
|
isStartArrowVisible.value = false;
|
|
@@ -22604,7 +22822,7 @@ var FluxTabBar_default = /* @__PURE__ */ defineComponent({
|
|
|
22604
22822
|
isStartArrowVisible.value = tabBar.scrollLeft > 0;
|
|
22605
22823
|
}
|
|
22606
22824
|
function updateHighlight() {
|
|
22607
|
-
if (!_$
|
|
22825
|
+
if (!_$2(tabBarRef)) return;
|
|
22608
22826
|
let activeElement = null;
|
|
22609
22827
|
for (const [element, isActive] of items) if (isActive.value) {
|
|
22610
22828
|
activeElement = element;
|
|
@@ -22620,14 +22838,14 @@ var FluxTabBar_default = /* @__PURE__ */ defineComponent({
|
|
|
22620
22838
|
activeItemWidth.value = width;
|
|
22621
22839
|
}
|
|
22622
22840
|
function scrollToEnd() {
|
|
22623
|
-
const tabBar = _$
|
|
22841
|
+
const tabBar = _$2(tabBarRef);
|
|
22624
22842
|
tabBar.scrollBy({
|
|
22625
22843
|
behavior: "smooth",
|
|
22626
22844
|
left: tabBar.offsetWidth / 1.5
|
|
22627
22845
|
});
|
|
22628
22846
|
}
|
|
22629
22847
|
function scrollToStart() {
|
|
22630
|
-
const tabBar = _$
|
|
22848
|
+
const tabBar = _$2(tabBarRef);
|
|
22631
22849
|
tabBar.scrollBy({
|
|
22632
22850
|
behavior: "smooth",
|
|
22633
22851
|
left: tabBar.offsetWidth / -1.5
|
|
@@ -22804,9 +23022,9 @@ var FluxTabs_default = /* @__PURE__ */ defineComponent({
|
|
|
22804
23022
|
id: `${baseId}-panel-${index}`,
|
|
22805
23023
|
"aria-labelledby": `${baseId}-tab-${index}`
|
|
22806
23024
|
})));
|
|
22807
|
-
const tabs = computed(() => unref(rawChildren).filter((child) => p$
|
|
22808
|
-
icon: p$
|
|
22809
|
-
label: p$
|
|
23025
|
+
const tabs = computed(() => unref(rawChildren).filter((child) => p$3(child).icon || p$3(child).label).map((child) => ({
|
|
23026
|
+
icon: p$3(child).icon,
|
|
23027
|
+
label: p$3(child).label
|
|
22810
23028
|
})));
|
|
22811
23029
|
function activate(index) {
|
|
22812
23030
|
modelValue.value = index;
|
|
@@ -23196,6 +23414,6 @@ var FluxTreeView_default = /* @__PURE__ */ defineComponent({
|
|
|
23196
23414
|
}
|
|
23197
23415
|
});
|
|
23198
23416
|
//#endregion
|
|
23199
|
-
export { FluxAction_default as FluxAction, FluxActionBar_default as FluxActionBar, FluxActionPane_default as FluxActionPane, FluxActionStack_default as FluxActionStack, FluxAdaptiveGroup_default as FluxAdaptiveGroup, FluxAdaptiveSlot_default as FluxAdaptiveSlot, FluxAnimatedColors_default as FluxAnimatedColors, FluxAspectRatio_default as FluxAspectRatio, FluxAutoHeightTransition_default as FluxAutoHeightTransition, FluxAutoWidthTransition_default as FluxAutoWidthTransition, FluxAvatar_default as FluxAvatar, FluxBadge_default as FluxBadge, FluxBadgeStack_default as FluxBadgeStack, FluxBorderShine_default as FluxBorderShine, FluxBoxedIcon_default as FluxBoxedIcon, FluxBreakthroughTransition_default as FluxBreakthroughTransition, FluxButton_default as FluxButton, FluxButtonGroup_default as FluxButtonGroup, FluxButtonStack_default as FluxButtonStack, FluxCalendar_default as FluxCalendar, FluxCalendarItem_default as FluxCalendarItem, FluxCheckbox_default as FluxCheckbox, FluxChip_default as FluxChip, FluxClickablePane_default as FluxClickablePane, FluxColorPicker_default as FluxColorPicker, FluxColorSelect_default as FluxColorSelect, FluxCommandPalette_default as FluxCommandPalette, FluxCommandPaletteGroup_default as FluxCommandPaletteGroup, FluxCommandPaletteItem_default as FluxCommandPaletteItem, FluxComment_default as FluxComment, FluxContainer_default as FluxContainer, FluxDataTable_default as FluxDataTable, FluxDatePicker_default as FluxDatePicker, FluxDestructiveButton_default as FluxDestructiveButton, FluxDisabled_default as FluxDisabled, FluxDivider_default as FluxDivider, FluxDotPattern_default as FluxDotPattern, FluxDropZone_default as FluxDropZone, FluxDynamicView_default as FluxDynamicView, FluxExpandable_default as FluxExpandable, FluxExpandableGroup_default as FluxExpandableGroup, FluxFadeTransition_default as FluxFadeTransition, FluxFader_default as FluxFader, FluxFaderItem_default as FluxFaderItem, FluxFilter_default as FluxFilter, FluxFilterBar_default as FluxFilterBar, FluxFilterDate_default as FluxFilterDate, FluxFilterDateRange_default as FluxFilterDateRange, FluxFilterOption_default as FluxFilterOption, FluxFilterOptionAsync_default as FluxFilterOptionAsync, FluxFilterOptions_default as FluxFilterOptions, FluxFilterOptionsAsync_default as FluxFilterOptionsAsync, FluxFilterRange_default as FluxFilterRange, FluxFlex_default as FluxFlex, FluxFlexItem_default as FluxFlexItem, FluxFlickeringGrid_default as FluxFlickeringGrid, FluxFlyout_default as FluxFlyout, FluxFocalPointEditor_default as FluxFocalPointEditor, FluxFocalPointImage_default as FluxFocalPointImage, FluxForm_default as FluxForm, FluxFormColumn_default as FluxFormColumn, FluxFormDateInput_default as FluxFormDateInput, FluxFormDateRangeInput_default as FluxFormDateRangeInput, FluxFormDateTimeInput_default as FluxFormDateTimeInput, FluxFormField_default as FluxFormField, FluxFormFieldAddition_default as FluxFormFieldAddition, FluxFormGrid_default as FluxFormGrid, FluxFormInput_default as FluxFormInput, FluxFormInputAddition_default as FluxFormInputAddition, FluxFormInputGroup_default as FluxFormInputGroup, FluxFormPinInput_default as FluxFormPinInput, FluxFormRangeSlider_default as FluxFormRangeSlider, FluxFormRow_default as FluxFormRow, FluxFormSection_default as FluxFormSection, FluxFormSelect_default as FluxFormSelect, FluxFormSelectAsync_default as FluxFormSelectAsync, FluxFormSlider_default as FluxFormSlider, FluxFormTextArea_default as FluxFormTextArea, FluxFormTimeZonePicker_default as FluxFormTimeZonePicker, FluxFormTreeViewSelect_default as FluxFormTreeViewSelect, FluxGallery_default as FluxGallery, FluxGalleryItem_default as FluxGalleryItem, FluxGrid_default as FluxGrid, FluxGridColumn_default as FluxGridColumn, FluxGridPattern_default as FluxGridPattern, FluxIcon_default as FluxIcon, FluxInfo_default as FluxInfo, FluxInfoStack_default as FluxInfoStack, FluxItem_default as FluxItem, FluxItemActions_default as FluxItemActions, FluxItemContent_default as FluxItemContent, FluxItemMedia_default as FluxItemMedia, FluxItemStack_default as FluxItemStack, FluxKanban_default as FluxKanban, FluxKanbanColumn_default as FluxKanbanColumn, FluxKanbanItem_default as FluxKanbanItem, FluxLayerPane_default as FluxLayerPane, FluxLayerPaneSecondary_default as FluxLayerPaneSecondary, FluxLegend_default as FluxLegend, FluxLink_default as FluxLink, FluxMenu_default as FluxMenu, FluxMenuCollapsible_default as FluxMenuCollapsible, FluxMenuGroup_default as FluxMenuGroup, FluxMenuItem_default as FluxMenuItem, FluxMenuOptions_default as FluxMenuOptions, FluxMenuSubHeader_default as FluxMenuSubHeader, FluxMenuTitle_default as FluxMenuTitle, FluxNotice_default as FluxNotice, FluxNoticeStack_default as FluxNoticeStack, FluxOverflowBar_default as FluxOverflowBar, FluxOverlay_default as FluxOverlay, FluxOverlayProvider_default as FluxOverlayProvider, FluxOverlayTransition_default as FluxOverlayTransition, FluxPagination_default as FluxPagination, FluxPaginationBar_default as FluxPaginationBar, FluxPane_default as FluxPane, FluxPaneBody_default as FluxPaneBody, FluxPaneFooter_default as FluxPaneFooter, FluxPaneGroup_default as FluxPaneGroup, FluxPaneHeader_default as FluxPaneHeader, FluxPaneIllustration_default as FluxPaneIllustration, FluxPaneMedia_default as FluxPaneMedia, FluxPercentageBar_default as FluxPercentageBar, FluxPersona_default as FluxPersona, FluxPlaceholder_default as FluxPlaceholder, FluxPressable_default as FluxPressable, FluxPrimaryButton_default as FluxPrimaryButton, FluxPrimaryLinkButton_default as FluxPrimaryLinkButton, FluxProgressBar_default as FluxProgressBar, FluxPublishButton_default as FluxPublishButton, FluxQuantitySelector_default as FluxQuantitySelector, FluxRemove_default as FluxRemove, FluxRoot_default as FluxRoot, FluxRouteTransition_default as FluxRouteTransition, FluxScroller_default as FluxScroller, FluxSecondaryButton_default as FluxSecondaryButton, FluxSecondaryLinkButton_default as FluxSecondaryLinkButton, FluxSegmentedControl_default as FluxSegmentedControl, FluxSegmentedView_default as FluxSegmentedView, FluxSeparator_default as FluxSeparator, FluxSlideOver_default as FluxSlideOver, FluxSlideOverTransition_default as FluxSlideOverTransition, FluxSnackbar_default as FluxSnackbar, FluxSnackbarProvider_default as FluxSnackbarProvider, FluxSpacer_default as FluxSpacer, FluxSpacing_default as FluxSpacing, FluxSpinner_default as FluxSpinner, FluxSplitButton_default as FluxSplitButton, FluxSplitView_default as FluxSplitView, FluxSplitViewPane_default as FluxSplitViewPane, FluxStatistic_default as FluxStatistic, FluxStepper_default as FluxStepper, FluxStepperStep_default as FluxStepperStep, FluxStepperSteps_default as FluxStepperSteps, FluxSticky_default as FluxSticky, FluxTab_default as FluxTab, FluxTabBar_default as FluxTabBar, FluxTabBarItem_default as FluxTabBarItem, FluxTable_default as FluxTable, FluxTableActions_default as FluxTableActions, FluxTableBar_default as FluxTableBar, FluxTableCell_default as FluxTableCell, FluxTableHeader_default as FluxTableHeader, FluxTableRow_default as FluxTableRow, FluxTabs_default as FluxTabs, FluxTag_default as FluxTag, FluxTagStack_default as FluxTagStack, FluxTicks_default as FluxTicks, FluxTimeline_default as FluxTimeline, FluxTimelineItem_default as FluxTimelineItem, FluxToggle_default as FluxToggle, FluxToolbar_default as FluxToolbar, FluxToolbarGroup_default as FluxToolbarGroup, FluxTooltip_default as FluxTooltip, FluxTooltipProvider_default as FluxTooltipProvider, FluxTooltipTransition_default as FluxTooltipTransition, FluxTreeView_default as FluxTreeView, FluxVerticalWindowTransition_default as FluxVerticalWindowTransition, FluxWindow_default as FluxWindow, FluxWindowTransition_default as FluxWindowTransition, defineFilter, fluxRegisterIcons, isFluxFilterOptionHeader, isFluxFilterOptionItem, isFluxFormSelectGroup, isFluxFormSelectOption, pickFilterCommon, showAlert, showConfirm, showPrompt, showSnackbar, useAdaptiveGroupInjection_default as useAdaptiveGroupInjection, useBreakpoints_default as useBreakpoints, useCalendarInjection_default as useCalendarInjection, useDisabled_default as useDisabled, useDisabledInjection_default as useDisabledInjection, useExpandableGroupInjection_default as useExpandableGroupInjection, useFilterInjection_default as useFilterInjection, useFluxStore, useFlyoutInjection_default as useFlyoutInjection, useFormFieldInjection_default as useFormFieldInjection, useKanbanInjection_default as useKanbanInjection, useTabBarInjection_default as useTabBarInjection, useTableInjection_default as useTableInjection, useTooltipInjection_default as useTooltipInjection };
|
|
23417
|
+
export { FluxAction_default as FluxAction, FluxActionBar_default as FluxActionBar, FluxActionPane_default as FluxActionPane, FluxActionStack_default as FluxActionStack, FluxAdaptiveGroup_default as FluxAdaptiveGroup, FluxAdaptiveSlot_default as FluxAdaptiveSlot, FluxAnimatedColors_default as FluxAnimatedColors, FluxAspectRatio_default as FluxAspectRatio, FluxAutoHeightTransition_default as FluxAutoHeightTransition, FluxAutoWidthTransition_default as FluxAutoWidthTransition, FluxAvatar_default as FluxAvatar, FluxBadge_default as FluxBadge, FluxBadgeStack_default as FluxBadgeStack, FluxBorderShine_default as FluxBorderShine, FluxBoxedIcon_default as FluxBoxedIcon, FluxBreakthroughTransition_default as FluxBreakthroughTransition, FluxButton_default as FluxButton, FluxButtonGroup_default as FluxButtonGroup, FluxButtonStack_default as FluxButtonStack, FluxCalendar_default as FluxCalendar, FluxCalendarItem_default as FluxCalendarItem, FluxCheckbox_default as FluxCheckbox, FluxChip_default as FluxChip, FluxClickablePane_default as FluxClickablePane, FluxColorPicker_default as FluxColorPicker, FluxColorSelect_default as FluxColorSelect, FluxCommandPalette_default as FluxCommandPalette, FluxCommandPaletteGroup_default as FluxCommandPaletteGroup, FluxCommandPaletteItem_default as FluxCommandPaletteItem, FluxComment_default as FluxComment, FluxContainer_default as FluxContainer, FluxDataTable_default as FluxDataTable, FluxDatePicker_default as FluxDatePicker, FluxDestructiveButton_default as FluxDestructiveButton, FluxDisabled_default as FluxDisabled, FluxDivider_default as FluxDivider, FluxDotPattern_default as FluxDotPattern, FluxDropZone_default as FluxDropZone, FluxDynamicView_default as FluxDynamicView, FluxExpandable_default as FluxExpandable, FluxExpandableGroup_default as FluxExpandableGroup, FluxFadeTransition_default as FluxFadeTransition, FluxFader_default as FluxFader, FluxFaderItem_default as FluxFaderItem, FluxFilter_default as FluxFilter, FluxFilterBar_default as FluxFilterBar, FluxFilterDate_default as FluxFilterDate, FluxFilterDateRange_default as FluxFilterDateRange, FluxFilterOption_default as FluxFilterOption, FluxFilterOptionAsync_default as FluxFilterOptionAsync, FluxFilterOptions_default as FluxFilterOptions, FluxFilterOptionsAsync_default as FluxFilterOptionsAsync, FluxFilterRange_default as FluxFilterRange, FluxFlex_default as FluxFlex, FluxFlexItem_default as FluxFlexItem, FluxFlickeringGrid_default as FluxFlickeringGrid, FluxFlyout_default as FluxFlyout, FluxFocalPointEditor_default as FluxFocalPointEditor, FluxFocalPointImage_default as FluxFocalPointImage, FluxForm_default as FluxForm, FluxFormColumn_default as FluxFormColumn, FluxFormDateInput_default as FluxFormDateInput, FluxFormDateRangeInput_default as FluxFormDateRangeInput, FluxFormDateTimeInput_default as FluxFormDateTimeInput, FluxFormField_default as FluxFormField, FluxFormFieldAddition_default as FluxFormFieldAddition, FluxFormGrid_default as FluxFormGrid, FluxFormInput_default as FluxFormInput, FluxFormInputAddition_default as FluxFormInputAddition, FluxFormInputGroup_default as FluxFormInputGroup, FluxFormPinInput_default as FluxFormPinInput, FluxFormRangeSlider_default as FluxFormRangeSlider, FluxFormRow_default as FluxFormRow, FluxFormSection_default as FluxFormSection, FluxFormSelect_default as FluxFormSelect, FluxFormSelectAsync_default as FluxFormSelectAsync, FluxFormSlider_default as FluxFormSlider, FluxFormTextArea_default as FluxFormTextArea, FluxFormTimeZonePicker_default as FluxFormTimeZonePicker, FluxFormTreeViewSelect_default as FluxFormTreeViewSelect, FluxGallery_default as FluxGallery, FluxGalleryItem_default as FluxGalleryItem, FluxGrid_default as FluxGrid, FluxGridColumn_default as FluxGridColumn, FluxGridPattern_default as FluxGridPattern, FluxIcon_default as FluxIcon, FluxInfo_default as FluxInfo, FluxInfoStack_default as FluxInfoStack, FluxItem_default as FluxItem, FluxItemActions_default as FluxItemActions, FluxItemContent_default as FluxItemContent, FluxItemMedia_default as FluxItemMedia, FluxItemStack_default as FluxItemStack, FluxKanban_default as FluxKanban, FluxKanbanColumn_default as FluxKanbanColumn, FluxKanbanItem_default as FluxKanbanItem, FluxLayerPane_default as FluxLayerPane, FluxLayerPaneSecondary_default as FluxLayerPaneSecondary, FluxLegend_default as FluxLegend, FluxLink_default as FluxLink, FluxMenu_default as FluxMenu, FluxMenuCollapsible_default as FluxMenuCollapsible, FluxMenuGroup_default as FluxMenuGroup, FluxMenuItem_default as FluxMenuItem, FluxMenuOptions_default as FluxMenuOptions, FluxMenuSubHeader_default as FluxMenuSubHeader, FluxMenuTitle_default as FluxMenuTitle, FluxNotice_default as FluxNotice, FluxNoticeStack_default as FluxNoticeStack, FluxOverflowBar_default as FluxOverflowBar, FluxOverlay_default as FluxOverlay, FluxOverlayProvider_default as FluxOverlayProvider, FluxOverlayTransition_default as FluxOverlayTransition, FluxPagination_default as FluxPagination, FluxPaginationBar_default as FluxPaginationBar, FluxPane_default as FluxPane, FluxPaneBody_default as FluxPaneBody, FluxPaneFooter_default as FluxPaneFooter, FluxPaneGroup_default as FluxPaneGroup, FluxPaneHeader_default as FluxPaneHeader, FluxPaneIllustration_default as FluxPaneIllustration, FluxPaneMedia_default as FluxPaneMedia, FluxPercentageBar_default as FluxPercentageBar, FluxPersona_default as FluxPersona, FluxPlaceholder_default as FluxPlaceholder, FluxPressable_default as FluxPressable, FluxPrimaryButton_default as FluxPrimaryButton, FluxPrimaryLinkButton_default as FluxPrimaryLinkButton, FluxProgressBar_default as FluxProgressBar, FluxPublishButton_default as FluxPublishButton, FluxQuantitySelector_default as FluxQuantitySelector, FluxRemove_default as FluxRemove, FluxRoot_default as FluxRoot, FluxRouteTransition_default as FluxRouteTransition, FluxScroller_default as FluxScroller, FluxSecondaryButton_default as FluxSecondaryButton, FluxSecondaryLinkButton_default as FluxSecondaryLinkButton, FluxSegmentedControl_default as FluxSegmentedControl, FluxSegmentedView_default as FluxSegmentedView, FluxSeparator_default as FluxSeparator, FluxSlideOver_default as FluxSlideOver, FluxSlideOverTransition_default as FluxSlideOverTransition, FluxSnackbar_default as FluxSnackbar, FluxSnackbarProvider_default as FluxSnackbarProvider, FluxSpacer_default as FluxSpacer, FluxSpacing_default as FluxSpacing, FluxSpinner_default as FluxSpinner, FluxSplitButton_default as FluxSplitButton, FluxSplitView_default as FluxSplitView, FluxSplitViewPane_default as FluxSplitViewPane, FluxStatistic_default as FluxStatistic, FluxStepper_default as FluxStepper, FluxStepperStep_default as FluxStepperStep, FluxStepperSteps_default as FluxStepperSteps, FluxSticky_default as FluxSticky, FluxTab_default as FluxTab, FluxTabBar_default as FluxTabBar, FluxTabBarItem_default as FluxTabBarItem, FluxTable_default as FluxTable, FluxTableActions_default as FluxTableActions, FluxTableBar_default as FluxTableBar, FluxTableCell_default as FluxTableCell, FluxTableHeader_default as FluxTableHeader, FluxTableRow_default as FluxTableRow, FluxTabs_default as FluxTabs, FluxTag_default as FluxTag, FluxTagStack_default as FluxTagStack, FluxTicks_default as FluxTicks, FluxTimeline_default as FluxTimeline, FluxTimelineItem_default as FluxTimelineItem, FluxToggle_default as FluxToggle, FluxToolbar_default as FluxToolbar, FluxToolbarGroup_default as FluxToolbarGroup, FluxTooltip_default as FluxTooltip, FluxTooltipProvider_default as FluxTooltipProvider, FluxTooltipTransition_default as FluxTooltipTransition, FluxTreeView_default as FluxTreeView, FluxVerticalWindowTransition_default as FluxVerticalWindowTransition, FluxWindow_default as FluxWindow, FluxWindowTransition_default as FluxWindowTransition, defineFilter, fluxRegisterIcons, iconRegistry, isFluxFilterOptionHeader, isFluxFilterOptionItem, isFluxFormSelectGroup, isFluxFormSelectOption, pickFilterCommon, showAlert, showConfirm, showPrompt, showSnackbar, useAdaptiveGroupInjection_default as useAdaptiveGroupInjection, useBreakpoints_default as useBreakpoints, useCalendarInjection_default as useCalendarInjection, useDisabled_default as useDisabled, useDisabledInjection_default as useDisabledInjection, useExpandableGroupInjection_default as useExpandableGroupInjection, useFilterInjection_default as useFilterInjection, useFluxStore, useFlyoutInjection_default as useFlyoutInjection, useFormFieldInjection_default as useFormFieldInjection, useKanbanInjection_default as useKanbanInjection, useTabBarInjection_default as useTabBarInjection, useTableInjection_default as useTableInjection, useTooltipInjection_default as useTooltipInjection };
|
|
23200
23418
|
|
|
23201
23419
|
//# sourceMappingURL=index.js.map
|