wj-elements 0.1.255 → 0.2.0-alpha.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/dark.css +8 -0
- package/dist/light.css +17 -5
- package/dist/packages/utils/utils.d.ts +16 -0
- package/dist/packages/wje-chip/chip.element.d.ts +12 -0
- package/dist/packages/wje-chip/chip.test.d.ts +1 -0
- package/dist/packages/wje-dialog/dialog.element.d.ts +1 -0
- package/dist/packages/wje-element/element.d.ts +38 -3
- package/dist/packages/wje-file-upload/file-upload.element.d.ts +18 -6
- package/dist/packages/wje-file-upload/file-upload.test.d.ts +1 -0
- package/dist/packages/wje-file-upload/service/service.d.ts +0 -23
- package/dist/packages/wje-file-upload-item/file-upload-item.element.d.ts +25 -8
- package/dist/packages/wje-select/select.element.d.ts +2 -0
- package/dist/packages/wje-select/select.test.d.ts +1 -0
- package/dist/packages/wje-toggle/toggle.test.d.ts +1 -0
- package/dist/styles.css +2 -1
- package/dist/utils.js +18 -1
- package/dist/utils.js.map +1 -1
- package/dist/wje-animation.js +1 -1
- package/dist/wje-avatar.js +1 -1
- package/dist/wje-avatar.js.map +1 -1
- package/dist/wje-breadcrumb.js +12 -10
- package/dist/wje-breadcrumb.js.map +1 -1
- package/dist/wje-chip.js +20 -0
- package/dist/wje-chip.js.map +1 -1
- package/dist/wje-dialog.js +35 -0
- package/dist/wje-dialog.js.map +1 -1
- package/dist/wje-element.js +437 -22
- package/dist/wje-element.js.map +1 -1
- package/dist/wje-file-upload-item.js +30 -9
- package/dist/wje-file-upload-item.js.map +1 -1
- package/dist/wje-file-upload.js +85 -62
- package/dist/wje-file-upload.js.map +1 -1
- package/dist/wje-infinite-scroll.js +13 -3
- package/dist/wje-infinite-scroll.js.map +1 -1
- package/dist/wje-item.js +1 -1
- package/dist/wje-option.js +9 -5
- package/dist/wje-option.js.map +1 -1
- package/dist/wje-select.js +104 -42
- package/dist/wje-select.js.map +1 -1
- package/package.json +14 -10
package/dist/wje-element.js
CHANGED
|
@@ -15,8 +15,201 @@ import { Permissions } from "./permissions.js";
|
|
|
15
15
|
import { WjElementUtils } from "./element-utils.js";
|
|
16
16
|
import { event } from "./event.js";
|
|
17
17
|
import { store, defaultStoreActions } from "./wje-store.js";
|
|
18
|
+
const skeletonCss = `/*
|
|
19
|
+
[ Skeleton ]
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
@keyframes wje-skeleton-shimmer {
|
|
23
|
+
from {
|
|
24
|
+
transform: translateX(-100%);
|
|
25
|
+
}
|
|
26
|
+
to {
|
|
27
|
+
transform: translateX(100%);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.wje-skeleton {
|
|
32
|
+
cursor: progress;
|
|
33
|
+
user-select: none;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.wje-skeleton-overlay {
|
|
37
|
+
display: grid;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.wje-skeleton-overlay-content,
|
|
41
|
+
.wje-skeleton-overlay-skeleton {
|
|
42
|
+
grid-area: 1 / 1;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
.wje-skeleton-overlay-skeleton {
|
|
46
|
+
display: none; /* shown in loading state */
|
|
47
|
+
pointer-events: none; /* skeleton should not be interactive */
|
|
48
|
+
align-self: stretch;
|
|
49
|
+
justify-self: stretch;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.wje-skeleton-overlay-skeleton > .wje-skeleton {
|
|
53
|
+
width: 100%;
|
|
54
|
+
height: 100%;
|
|
55
|
+
box-sizing: border-box;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/* Base "shape" primitives */
|
|
59
|
+
.wje-skeleton-line,
|
|
60
|
+
.wje-skeleton-head,
|
|
61
|
+
.wje-skeleton-circle,
|
|
62
|
+
.wje-skeleton-square {
|
|
63
|
+
position: relative;
|
|
64
|
+
overflow: hidden;
|
|
65
|
+
background-color: var(--wje-skeleton-bg);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
.wje-skeleton-line {
|
|
69
|
+
display: block;
|
|
70
|
+
height: var(--wje-skeleton-height);
|
|
71
|
+
border-radius: var(--wje-skeleton-radius);
|
|
72
|
+
width: 100%;
|
|
73
|
+
flex: 0 0 auto;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
.wje-skeleton-flex-row {
|
|
77
|
+
display: flex;
|
|
78
|
+
flex-direction: row;
|
|
79
|
+
align-items: center;
|
|
80
|
+
gap: var(--wje-skeleton-gap);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
.wje-skeleton-flex-column {
|
|
84
|
+
display: flex;
|
|
85
|
+
flex-direction: column;
|
|
86
|
+
gap: var(--wje-skeleton-gap);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
.wje-skeleton-line + .wje-skeleton-line,
|
|
90
|
+
.wje-skeleton-line + .wje-skeleton-head,
|
|
91
|
+
.wje-skeleton-head + .wje-skeleton-line,
|
|
92
|
+
.wje-skeleton-head + .wje-skeleton-head,
|
|
93
|
+
.wje-skeleton-circle + .wje-skeleton-line,
|
|
94
|
+
.wje-skeleton-line + .wje-skeleton-circle {
|
|
95
|
+
/*margin-top: var(--wje-skeleton-gap);*/
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
.wje-skeleton-head {
|
|
99
|
+
display: block;
|
|
100
|
+
height: var(--wje-skeleton-head-height);
|
|
101
|
+
border-radius: var(--wje-skeleton-radius);
|
|
102
|
+
width: 100%;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.wje-skeleton-circle {
|
|
106
|
+
display: block;
|
|
107
|
+
/* Take remaining width in flex row (e.g. 40% if sibling is w-60) */
|
|
108
|
+
flex: 1 1 0;
|
|
109
|
+
max-width: 100%;
|
|
110
|
+
aspect-ratio: 1 / 1;
|
|
111
|
+
border-radius: 50%;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
.wje-skeleton-square {
|
|
115
|
+
display: block;
|
|
116
|
+
width: 100%;
|
|
117
|
+
height: 150px;
|
|
118
|
+
border-radius: 8px;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
/* Shimmer layer */
|
|
122
|
+
.wje-skeleton-line::after,
|
|
123
|
+
.wje-skeleton-head::after,
|
|
124
|
+
.wje-skeleton-circle::after,
|
|
125
|
+
.wje-skeleton-square::after {
|
|
126
|
+
content: '';
|
|
127
|
+
position: absolute;
|
|
128
|
+
inset: 0;
|
|
129
|
+
transform: translateX(-100%);
|
|
130
|
+
animation: wje-skeleton-shimmer var(--wje-skeleton-duration) infinite;
|
|
131
|
+
background: linear-gradient(90deg, transparent, var(--wje-skeleton-highlight), transparent);
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
/* "Stronger" variant */
|
|
135
|
+
.wje-skeleton-strong .wje-skeleton-line,
|
|
136
|
+
.wje-skeleton-strong .wje-skeleton-head,
|
|
137
|
+
.wje-skeleton-strong .wje-skeleton-circle,
|
|
138
|
+
.wje-skeleton-strong .wje-skeleton-square {
|
|
139
|
+
background-color: var(--wje-skeleton-bg-strong);
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/* Simple layout helpers (opt-in) */
|
|
143
|
+
.wje-skeleton .flex { display: flex; }
|
|
144
|
+
.wje-skeleton .inline-flex { display: inline-flex; }
|
|
145
|
+
.wje-skeleton .align-center { align-items: center; }
|
|
146
|
+
.wje-skeleton .align-start { align-items: flex-start; }
|
|
147
|
+
.wje-skeleton .align-end { align-items: flex-end; }
|
|
148
|
+
.wje-skeleton .justify-start { justify-content: flex-start; }
|
|
149
|
+
.wje-skeleton .justify-end { justify-content: flex-end; }
|
|
150
|
+
.wje-skeleton .justify-between { justify-content: space-between; }
|
|
151
|
+
.wje-skeleton .justify-center { justify-content: center; }
|
|
152
|
+
.wje-skeleton .justify-around { justify-content: space-around; }
|
|
153
|
+
|
|
154
|
+
.wje-skeleton .gap { gap: var(--wje-skeleton-gap); }
|
|
155
|
+
|
|
156
|
+
.wje-skeleton .w-5 { width: 5%; }
|
|
157
|
+
.wje-skeleton .w-10 { width: 10%; }
|
|
158
|
+
.wje-skeleton .w-15 { width: 15%; }
|
|
159
|
+
.wje-skeleton .w-20 { width: 20%; }
|
|
160
|
+
.wje-skeleton .w-25 { width: 25%; }
|
|
161
|
+
.wje-skeleton .w-30 { width: 30%; }
|
|
162
|
+
.wje-skeleton .w-35 { width: 35%; }
|
|
163
|
+
.wje-skeleton .w-40 { width: 40%; }
|
|
164
|
+
.wje-skeleton .w-45 { width: 45%; }
|
|
165
|
+
.wje-skeleton .w-50 { width: 50%; }
|
|
166
|
+
.wje-skeleton .w-55 { width: 55%; }
|
|
167
|
+
.wje-skeleton .w-60 { width: 60%; }
|
|
168
|
+
.wje-skeleton .w-65 { width: 65%; }
|
|
169
|
+
.wje-skeleton .w-70 { width: 70%; }
|
|
170
|
+
.wje-skeleton .w-75 { width: 75%; }
|
|
171
|
+
.wje-skeleton .w-80 { width: 80%; }
|
|
172
|
+
.wje-skeleton .w-85 { width: 85%; }
|
|
173
|
+
.wje-skeleton .w-90 { width: 90%; }
|
|
174
|
+
.wje-skeleton .w-95 { width: 95%; }
|
|
175
|
+
.wje-skeleton .w-100 { width: 100%; }
|
|
176
|
+
|
|
177
|
+
.wje-skeleton .mb { margin-bottom: 16px; }
|
|
178
|
+
.wje-skeleton .mt { margin-top: 16px; }
|
|
179
|
+
.wje-skeleton .mr { margin-right: 16px; }
|
|
180
|
+
.wje-skeleton .ml { margin-left: 16px; }
|
|
181
|
+
.wje-skeleton .mbs { margin-bottom: 8px; }
|
|
182
|
+
.wje-skeleton .mts { margin-top: 8px; }
|
|
183
|
+
.wje-skeleton .mrs { margin-right: 8px; }
|
|
184
|
+
.wje-skeleton .mls { margin-left: 8px; }
|
|
185
|
+
|
|
186
|
+
/* Optional state helpers */
|
|
187
|
+
.wje-skeleton-loading .wje-skeleton-overlay-content {
|
|
188
|
+
visibility: hidden;
|
|
189
|
+
pointer-events: none;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
.wje-skeleton-loading .wje-skeleton-overlay-skeleton {
|
|
193
|
+
display: block;
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
@media (prefers-reduced-motion: reduce) {
|
|
197
|
+
.wje-skeleton-line::after,
|
|
198
|
+
.wje-skeleton-head::after,
|
|
199
|
+
.wje-skeleton-circle::after,
|
|
200
|
+
.wje-skeleton-square::after {
|
|
201
|
+
animation: none;
|
|
202
|
+
transform: none;
|
|
203
|
+
opacity: 0.35;
|
|
204
|
+
}
|
|
205
|
+
}`;
|
|
18
206
|
const template = document.createElement("template");
|
|
19
207
|
template.innerHTML = ``;
|
|
208
|
+
const wjSkeletonSheet = new CSSStyleSheet();
|
|
209
|
+
try {
|
|
210
|
+
wjSkeletonSheet.replaceSync(skeletonCss);
|
|
211
|
+
} catch (e) {
|
|
212
|
+
}
|
|
20
213
|
const _WJElement = class _WJElement extends HTMLElement {
|
|
21
214
|
/**
|
|
22
215
|
* Initializes a new instance of the WJElement class.
|
|
@@ -44,10 +237,18 @@ const _WJElement = class _WJElement extends HTMLElement {
|
|
|
44
237
|
}
|
|
45
238
|
this.setUpAccessors();
|
|
46
239
|
__privateSet(this, _drawingStatus, this.drawingStatuses.START);
|
|
47
|
-
await this.display(force);
|
|
48
240
|
const sheet = new CSSStyleSheet();
|
|
49
241
|
sheet.replaceSync(this.constructor.cssStyleSheet);
|
|
50
|
-
this.
|
|
242
|
+
if (this.shadowRoot) {
|
|
243
|
+
const existing = this.shadowRoot.adoptedStyleSheets || [];
|
|
244
|
+
const next = [...existing];
|
|
245
|
+
if (!next.includes(wjSkeletonSheet) && wjSkeletonSheet.cssRules !== void 0) {
|
|
246
|
+
next.push(wjSkeletonSheet);
|
|
247
|
+
}
|
|
248
|
+
if (!next.includes(sheet)) next.push(sheet);
|
|
249
|
+
this.shadowRoot.adoptedStyleSheets = next;
|
|
250
|
+
}
|
|
251
|
+
await this.display(force);
|
|
51
252
|
resolve();
|
|
52
253
|
});
|
|
53
254
|
});
|
|
@@ -223,8 +424,9 @@ const _WJElement = class _WJElement extends HTMLElement {
|
|
|
223
424
|
* Defines component dependencies by registering custom elements.
|
|
224
425
|
*/
|
|
225
426
|
defineDependencies() {
|
|
226
|
-
if (this.dependencies)
|
|
227
|
-
Object.entries(this.dependencies).forEach((name, component) => _WJElement.define(name, component));
|
|
427
|
+
if (this.dependencies) {
|
|
428
|
+
Object.entries(this.dependencies).forEach(([name, component]) => _WJElement.define(name, component));
|
|
429
|
+
}
|
|
228
430
|
}
|
|
229
431
|
/**
|
|
230
432
|
* Hook for extending behavior before drawing the component.
|
|
@@ -263,6 +465,81 @@ const _WJElement = class _WJElement extends HTMLElement {
|
|
|
263
465
|
*/
|
|
264
466
|
afterDraw(context, appStoreObj, params) {
|
|
265
467
|
}
|
|
468
|
+
/**
|
|
469
|
+
* Optional hook: return skeleton markup used while async draw is in progress.
|
|
470
|
+
* Prefer declarative skeleton via `<div slot="skeleton">...</div>`.
|
|
471
|
+
* Return: string | Node | DocumentFragment | null | Promise of those.
|
|
472
|
+
*/
|
|
473
|
+
renderSkeleton(params) {
|
|
474
|
+
return null;
|
|
475
|
+
}
|
|
476
|
+
/**
|
|
477
|
+
* Retrieves the delay duration for the skeleton display, determining the value based on a hierarchy of overrides and defaults.
|
|
478
|
+
* The method prioritizes in the following order:
|
|
479
|
+
* 1. A finite number set as the `_wjSkeletonSlotClone` property.
|
|
480
|
+
* 2. A valid numeric value from the `skeleton-delay` attribute.
|
|
481
|
+
* 3. The `skeletonDelayMs` property, if defined with a finite number.
|
|
482
|
+
* 4. A default value of 150 if none of the above are set.
|
|
483
|
+
* @returns {number} The delay in milliseconds before the skeleton is displayed.
|
|
484
|
+
*/
|
|
485
|
+
get skeletonDelay() {
|
|
486
|
+
if (Number.isFinite(this._wjSkeletonSlotClone)) return this._wjSkeletonSlotClone;
|
|
487
|
+
const v = this.getAttribute("skeleton-delay");
|
|
488
|
+
const n = v == null ? NaN : Number(v);
|
|
489
|
+
if (Number.isFinite(n)) return n;
|
|
490
|
+
if (Number.isFinite(this.skeletonDelayMs)) return this.skeletonDelayMs;
|
|
491
|
+
return 150;
|
|
492
|
+
}
|
|
493
|
+
/**
|
|
494
|
+
* Retrieves the minimum duration for the skeleton animation.
|
|
495
|
+
* The method checks for an internally stored finite value. If unavailable,
|
|
496
|
+
* it retrieves the value from the 'skeleton-min-duration' attribute,
|
|
497
|
+
* converts it to a number if possible, and uses it. If neither is valid,
|
|
498
|
+
* a default duration of 300 is returned.
|
|
499
|
+
* @returns {number} The minimum duration for the skeleton animation in milliseconds.
|
|
500
|
+
*/
|
|
501
|
+
get skeletonMinDuration() {
|
|
502
|
+
if (Number.isFinite(this._wjSkeletonSlotClone)) return this._wjSkeletonSlotClone;
|
|
503
|
+
const v = this.getAttribute("skeleton-min-duration");
|
|
504
|
+
const n = v == null ? NaN : Number(v);
|
|
505
|
+
if (Number.isFinite(n)) return n;
|
|
506
|
+
return 300;
|
|
507
|
+
}
|
|
508
|
+
set skeletonMinDuration(value) {
|
|
509
|
+
if (value === null || value === void 0 || value === "") {
|
|
510
|
+
delete this._wjSkeletonSlotClone;
|
|
511
|
+
this.removeAttribute("skeleton-min-duration");
|
|
512
|
+
return;
|
|
513
|
+
}
|
|
514
|
+
const n = Number(value);
|
|
515
|
+
if (Number.isFinite(n)) {
|
|
516
|
+
this._wjSkeletonSlotClone = n;
|
|
517
|
+
this.setAttribute("skeleton-min-duration", String(n));
|
|
518
|
+
}
|
|
519
|
+
}
|
|
520
|
+
// Public API: property-based control
|
|
521
|
+
set skeleton(value) {
|
|
522
|
+
if (value) this.setAttribute("skeleton", "");
|
|
523
|
+
else this.removeAttribute("skeleton");
|
|
524
|
+
}
|
|
525
|
+
get skeleton() {
|
|
526
|
+
return this.hasAttribute("skeleton");
|
|
527
|
+
}
|
|
528
|
+
set skeletonDelay(value) {
|
|
529
|
+
if (value === null || value === void 0 || value === "") {
|
|
530
|
+
delete this._wjSkeletonSlotClone;
|
|
531
|
+
this.removeAttribute("skeleton-delay");
|
|
532
|
+
return;
|
|
533
|
+
}
|
|
534
|
+
const n = Number(value);
|
|
535
|
+
if (Number.isFinite(n)) {
|
|
536
|
+
this._wjSkeletonSlotClone = n;
|
|
537
|
+
this.setAttribute("skeleton-delay", String(n));
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
get skeletonDelayValue() {
|
|
541
|
+
return this.skeletonDelay;
|
|
542
|
+
}
|
|
266
543
|
/**
|
|
267
544
|
* Lifecycle method invoked when the component is connected to the DOM.
|
|
268
545
|
*/
|
|
@@ -386,22 +663,157 @@ const _WJElement = class _WJElement extends HTMLElement {
|
|
|
386
663
|
*/
|
|
387
664
|
display(force = false) {
|
|
388
665
|
this.template = this.constructor.customTemplate || document.createElement("template");
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
}
|
|
392
|
-
this.context.append(this.template.content.cloneNode(true));
|
|
666
|
+
const nextContext = document.createDocumentFragment();
|
|
667
|
+
nextContext.append(this.template.content.cloneNode(true));
|
|
393
668
|
if (this.noShow || this.isPermissionCheck && !Permissions.isPermissionFulfilled(this.permission)) {
|
|
394
669
|
this.remove();
|
|
395
670
|
return Promise.resolve();
|
|
396
671
|
}
|
|
397
|
-
|
|
672
|
+
let skeletonTimer = null;
|
|
673
|
+
let renderFinished = false;
|
|
674
|
+
let skeletonShownAt = null;
|
|
675
|
+
const clearSkeletonTimer = () => {
|
|
676
|
+
if (skeletonTimer) {
|
|
677
|
+
clearTimeout(skeletonTimer);
|
|
678
|
+
skeletonTimer = null;
|
|
679
|
+
}
|
|
680
|
+
};
|
|
681
|
+
const buildSkeletonFragment = async () => {
|
|
682
|
+
var _a, _b;
|
|
683
|
+
const slotted = this.querySelector('[slot="skeleton"]');
|
|
684
|
+
if (slotted) {
|
|
685
|
+
this._wjSkeletonSlotClone = slotted.cloneNode(true);
|
|
686
|
+
const frag2 = document.createDocumentFragment();
|
|
687
|
+
frag2.append(this._wjSkeletonSlotClone.cloneNode(true));
|
|
688
|
+
return frag2;
|
|
689
|
+
}
|
|
690
|
+
if (this._wjSkeletonSlotClone) {
|
|
691
|
+
const frag2 = document.createDocumentFragment();
|
|
692
|
+
frag2.append(this._wjSkeletonSlotClone.cloneNode(true));
|
|
693
|
+
return frag2;
|
|
694
|
+
}
|
|
695
|
+
const frag = document.createDocumentFragment();
|
|
696
|
+
let skel = (_a = this.renderSkeleton) == null ? void 0 : _a.call(this, WjElementUtils.getAttributes(this));
|
|
697
|
+
if (skel instanceof Promise || ((_b = skel == null ? void 0 : skel.constructor) == null ? void 0 : _b.name) === "Promise") {
|
|
698
|
+
skel = await skel;
|
|
699
|
+
}
|
|
700
|
+
if (skel == null) return null;
|
|
701
|
+
let node;
|
|
702
|
+
if (skel instanceof HTMLElement || skel instanceof DocumentFragment) {
|
|
703
|
+
node = skel;
|
|
704
|
+
} else {
|
|
705
|
+
const t = document.createElement("template");
|
|
706
|
+
t.innerHTML = skel;
|
|
707
|
+
node = t.content.cloneNode(true);
|
|
708
|
+
}
|
|
709
|
+
frag.append(node);
|
|
710
|
+
return frag;
|
|
711
|
+
};
|
|
712
|
+
const showSkeleton = async () => {
|
|
713
|
+
if (renderFinished) return;
|
|
714
|
+
if (!this.hasAttribute("skeleton")) return;
|
|
715
|
+
const frag = await buildSkeletonFragment();
|
|
716
|
+
if (!frag) return;
|
|
717
|
+
try {
|
|
718
|
+
const cs = getComputedStyle(this);
|
|
719
|
+
if (cs.display === "inline") this.style.display = "block";
|
|
720
|
+
if (cs.width === "0px") this.style.width = "100%";
|
|
721
|
+
} catch (e) {
|
|
722
|
+
}
|
|
723
|
+
if (this.hasShadowRoot) {
|
|
724
|
+
if (this.shadowRoot) {
|
|
725
|
+
const existing = this.shadowRoot.adoptedStyleSheets || [];
|
|
726
|
+
if (!existing.includes(wjSkeletonSheet) && wjSkeletonSheet.cssRules !== void 0) {
|
|
727
|
+
this.shadowRoot.adoptedStyleSheets = [...existing, wjSkeletonSheet];
|
|
728
|
+
}
|
|
729
|
+
}
|
|
730
|
+
this.shadowRoot.replaceChildren(frag);
|
|
731
|
+
} else {
|
|
732
|
+
this.replaceChildren(frag);
|
|
733
|
+
}
|
|
734
|
+
skeletonShownAt = performance.now();
|
|
735
|
+
this.dispatchEvent(new CustomEvent("wj:skeleton:show", {
|
|
736
|
+
detail: { delay: this.skeletonDelay },
|
|
737
|
+
bubbles: true,
|
|
738
|
+
composed: true
|
|
739
|
+
}));
|
|
740
|
+
if (this.hasAttribute("debug-skeleton")) {
|
|
741
|
+
debugger;
|
|
742
|
+
}
|
|
743
|
+
};
|
|
744
|
+
if (this.hasAttribute("skeleton") && this.style.visibility === "hidden") {
|
|
745
|
+
this.style.visibility = __privateGet(this, _originalVisibility) ?? "visible";
|
|
746
|
+
}
|
|
747
|
+
let skeletonPlannedAt;
|
|
748
|
+
if (this.hasAttribute("skeleton")) {
|
|
749
|
+
skeletonPlannedAt = performance.now();
|
|
750
|
+
skeletonTimer = setTimeout(() => {
|
|
751
|
+
showSkeleton();
|
|
752
|
+
}, this.skeletonDelay);
|
|
753
|
+
}
|
|
754
|
+
return __privateMethod(this, _WJElement_instances, resolveRender_fn).call(this, nextContext, { skipAfterDraw: true }).then(async () => {
|
|
755
|
+
var _a;
|
|
756
|
+
renderFinished = true;
|
|
757
|
+
clearSkeletonTimer();
|
|
758
|
+
if (skeletonShownAt === null) {
|
|
759
|
+
const elapsed = skeletonPlannedAt ? performance.now() - skeletonPlannedAt : 0;
|
|
760
|
+
this.dispatchEvent(new CustomEvent("wj:skeleton:skip", {
|
|
761
|
+
detail: { reason: "render-finished-fast", elapsedMs: elapsed, delay: this.skeletonDelay },
|
|
762
|
+
bubbles: true,
|
|
763
|
+
composed: true
|
|
764
|
+
}));
|
|
765
|
+
} else {
|
|
766
|
+
const now = performance.now();
|
|
767
|
+
const visibleFor = now - skeletonShownAt;
|
|
768
|
+
const remaining = this.skeletonMinDuration - visibleFor;
|
|
769
|
+
if (remaining > 0) {
|
|
770
|
+
await new Promise((r) => setTimeout(r, remaining));
|
|
771
|
+
}
|
|
772
|
+
}
|
|
773
|
+
if (this.hasShadowRoot) {
|
|
774
|
+
this.shadowRoot.replaceChildren(nextContext);
|
|
775
|
+
} else {
|
|
776
|
+
this.replaceChildren(nextContext);
|
|
777
|
+
}
|
|
778
|
+
if (skeletonShownAt !== null) {
|
|
779
|
+
this.dispatchEvent(new CustomEvent("wj:skeleton:hide", {
|
|
780
|
+
detail: {
|
|
781
|
+
reason: "render-finished",
|
|
782
|
+
visibleMs: Math.max(this.skeletonMinDuration, performance.now() - skeletonShownAt),
|
|
783
|
+
delay: this.skeletonDelay,
|
|
784
|
+
minDuration: this.skeletonMinDuration
|
|
785
|
+
},
|
|
786
|
+
bubbles: true,
|
|
787
|
+
composed: true
|
|
788
|
+
}));
|
|
789
|
+
}
|
|
790
|
+
const liveContext = this.hasShadowRoot ? this.shadowRoot : this;
|
|
791
|
+
const _afterDraw = (_a = this.afterDraw) == null ? void 0 : _a.call(this, liveContext, this.store, WjElementUtils.getAttributes(this));
|
|
792
|
+
if (_afterDraw instanceof Promise || (_afterDraw == null ? void 0 : _afterDraw.constructor.name) === "Promise") {
|
|
793
|
+
await _afterDraw;
|
|
794
|
+
}
|
|
795
|
+
}).finally(() => {
|
|
796
|
+
renderFinished = true;
|
|
797
|
+
clearSkeletonTimer();
|
|
798
|
+
if (!__privateGet(this, _isRendering)) {
|
|
799
|
+
this.dispatchEvent(new CustomEvent("wj:skeleton:hide", {
|
|
800
|
+
detail: { reason: "finally" },
|
|
801
|
+
bubbles: true,
|
|
802
|
+
composed: true
|
|
803
|
+
}));
|
|
804
|
+
}
|
|
805
|
+
});
|
|
398
806
|
}
|
|
399
807
|
/**
|
|
400
|
-
* Renders the
|
|
808
|
+
* Renders the content into the provided target context.
|
|
809
|
+
* This method handles asynchronous rendering, processes the output from the `draw` method,
|
|
810
|
+
* and appends the resulting content to the specified target context.
|
|
811
|
+
* @returns {Promise<void>} A promise that resolves once the render operation is complete and the content is appended to the target context.
|
|
812
|
+
* @param targetContext
|
|
401
813
|
*/
|
|
402
|
-
async render() {
|
|
814
|
+
async render(targetContext = this.context) {
|
|
403
815
|
__privateSet(this, _drawingStatus, this.drawingStatuses.DRAWING);
|
|
404
|
-
let _draw = this.draw(
|
|
816
|
+
let _draw = this.draw(targetContext, this.store, WjElementUtils.getAttributes(this));
|
|
405
817
|
if (_draw instanceof Promise || (_draw == null ? void 0 : _draw.constructor.name) === "Promise") {
|
|
406
818
|
_draw = await _draw;
|
|
407
819
|
}
|
|
@@ -415,7 +827,7 @@ const _WJElement = class _WJElement extends HTMLElement {
|
|
|
415
827
|
element = inputTemplate.content.cloneNode(true);
|
|
416
828
|
}
|
|
417
829
|
let rendered = element;
|
|
418
|
-
|
|
830
|
+
targetContext.appendChild(rendered);
|
|
419
831
|
}
|
|
420
832
|
/**
|
|
421
833
|
* Sanitizes a given name by converting it from kebab-case to camelCase.
|
|
@@ -524,22 +936,25 @@ refresh_fn = async function() {
|
|
|
524
936
|
}
|
|
525
937
|
};
|
|
526
938
|
/**
|
|
527
|
-
* Resolves the rendering process of the component.
|
|
939
|
+
* Resolves the rendering process of the component, using the given target context.
|
|
940
|
+
* @param {HTMLElement|ShadowRoot|DocumentFragment} targetContext Target for rendering (defaults to this.context)
|
|
528
941
|
* @returns A promise that resolves when rendering is complete.
|
|
529
942
|
* @private
|
|
530
943
|
*/
|
|
531
|
-
resolveRender_fn = function() {
|
|
944
|
+
resolveRender_fn = function(targetContext = this.context, { skipAfterDraw = false } = {}) {
|
|
532
945
|
this.params = WjElementUtils.getAttributes(this);
|
|
533
946
|
return new Promise(async (resolve, reject) => {
|
|
534
947
|
var _a;
|
|
535
|
-
const
|
|
536
|
-
if (
|
|
537
|
-
await
|
|
948
|
+
const _beforeDraw = this.beforeDraw(targetContext, this.store, WjElementUtils.getAttributes(this));
|
|
949
|
+
if (_beforeDraw instanceof Promise || (_beforeDraw == null ? void 0 : _beforeDraw.constructor.name) === "Promise") {
|
|
950
|
+
await _beforeDraw;
|
|
538
951
|
}
|
|
539
|
-
await this.render();
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
952
|
+
await this.render(targetContext);
|
|
953
|
+
if (!skipAfterDraw) {
|
|
954
|
+
const _afterDraw = (_a = this.afterDraw) == null ? void 0 : _a.call(this, targetContext, this.store, WjElementUtils.getAttributes(this));
|
|
955
|
+
if (_afterDraw instanceof Promise || (_afterDraw == null ? void 0 : _afterDraw.constructor.name) === "Promise") {
|
|
956
|
+
await _afterDraw;
|
|
957
|
+
}
|
|
543
958
|
}
|
|
544
959
|
__privateSet(this, _isRendering, false);
|
|
545
960
|
__privateSet(this, _isAttached, true);
|