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.
Files changed (40) hide show
  1. package/dist/dark.css +8 -0
  2. package/dist/light.css +17 -5
  3. package/dist/packages/utils/utils.d.ts +16 -0
  4. package/dist/packages/wje-chip/chip.element.d.ts +12 -0
  5. package/dist/packages/wje-chip/chip.test.d.ts +1 -0
  6. package/dist/packages/wje-dialog/dialog.element.d.ts +1 -0
  7. package/dist/packages/wje-element/element.d.ts +38 -3
  8. package/dist/packages/wje-file-upload/file-upload.element.d.ts +18 -6
  9. package/dist/packages/wje-file-upload/file-upload.test.d.ts +1 -0
  10. package/dist/packages/wje-file-upload/service/service.d.ts +0 -23
  11. package/dist/packages/wje-file-upload-item/file-upload-item.element.d.ts +25 -8
  12. package/dist/packages/wje-select/select.element.d.ts +2 -0
  13. package/dist/packages/wje-select/select.test.d.ts +1 -0
  14. package/dist/packages/wje-toggle/toggle.test.d.ts +1 -0
  15. package/dist/styles.css +2 -1
  16. package/dist/utils.js +18 -1
  17. package/dist/utils.js.map +1 -1
  18. package/dist/wje-animation.js +1 -1
  19. package/dist/wje-avatar.js +1 -1
  20. package/dist/wje-avatar.js.map +1 -1
  21. package/dist/wje-breadcrumb.js +12 -10
  22. package/dist/wje-breadcrumb.js.map +1 -1
  23. package/dist/wje-chip.js +20 -0
  24. package/dist/wje-chip.js.map +1 -1
  25. package/dist/wje-dialog.js +35 -0
  26. package/dist/wje-dialog.js.map +1 -1
  27. package/dist/wje-element.js +437 -22
  28. package/dist/wje-element.js.map +1 -1
  29. package/dist/wje-file-upload-item.js +30 -9
  30. package/dist/wje-file-upload-item.js.map +1 -1
  31. package/dist/wje-file-upload.js +85 -62
  32. package/dist/wje-file-upload.js.map +1 -1
  33. package/dist/wje-infinite-scroll.js +13 -3
  34. package/dist/wje-infinite-scroll.js.map +1 -1
  35. package/dist/wje-item.js +1 -1
  36. package/dist/wje-option.js +9 -5
  37. package/dist/wje-option.js.map +1 -1
  38. package/dist/wje-select.js +104 -42
  39. package/dist/wje-select.js.map +1 -1
  40. package/package.json +14 -10
@@ -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.context.adoptedStyleSheets = [sheet];
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
- if (force) {
390
- [...this.context.childNodes].forEach(this.context.removeChild.bind(this.context));
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
- return __privateMethod(this, _WJElement_instances, resolveRender_fn).call(this);
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 component's content.
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(this.context, this.store, WjElementUtils.getAttributes(this));
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
- this.context.appendChild(rendered);
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 __beforeDraw = this.beforeDraw(this.context, this.store, WjElementUtils.getAttributes(this));
536
- if (__beforeDraw instanceof Promise || (__beforeDraw == null ? void 0 : __beforeDraw.constructor.name) === "Promise") {
537
- await __beforeDraw;
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
- const __afterDraw = (_a = this.afterDraw) == null ? void 0 : _a.call(this, this.context, this.store, WjElementUtils.getAttributes(this));
541
- if (__afterDraw instanceof Promise || (__afterDraw == null ? void 0 : __afterDraw.constructor.name) === "Promise") {
542
- await __afterDraw;
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);