@angelscmf/front 1.0.29 → 1.0.31

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 (103) hide show
  1. package/dist/AngelsFrontAnimationLibrary.d.ts +1 -1
  2. package/dist/AngelsFrontAnimationLibrary.js +81 -33
  3. package/dist/AngelsFrontAnimationLibrary.js.map +1 -1
  4. package/dist/{AngelsFrontLoader.cjs → AngelsFrontAnimationLibrary.mjs} +57 -64
  5. package/dist/AngelsFrontAnimationLibrary.mjs.map +1 -0
  6. package/dist/AngelsFrontApplication.d.mts +11 -0
  7. package/dist/AngelsFrontApplication.d.ts +3 -2
  8. package/dist/AngelsFrontApplication.js +283 -28
  9. package/dist/AngelsFrontApplication.js.map +1 -1
  10. package/dist/AngelsFrontApplication.mjs +365 -0
  11. package/dist/AngelsFrontApplication.mjs.map +1 -0
  12. package/dist/AngelsFrontDOMLibrary.d.mts +13 -0
  13. package/dist/AngelsFrontDOMLibrary.d.ts +11 -7
  14. package/dist/AngelsFrontDOMLibrary.js +345 -21
  15. package/dist/AngelsFrontDOMLibrary.js.map +1 -1
  16. package/dist/AngelsFrontDOMLibrary.mjs +391 -0
  17. package/dist/AngelsFrontDOMLibrary.mjs.map +1 -0
  18. package/dist/AngelsFrontElement.d.mts +15 -0
  19. package/dist/AngelsFrontElement.d.ts +15 -0
  20. package/dist/{AngelsFrontAnimationLibrary.cjs → AngelsFrontElement.js} +80 -68
  21. package/dist/AngelsFrontElement.js.map +1 -0
  22. package/dist/AngelsFrontElement.mjs +195 -0
  23. package/dist/AngelsFrontElement.mjs.map +1 -0
  24. package/dist/AngelsFrontLoader.js +613 -32
  25. package/dist/AngelsFrontLoader.js.map +1 -1
  26. package/dist/AngelsFrontLoader.mjs +789 -0
  27. package/dist/AngelsFrontLoader.mjs.map +1 -0
  28. package/dist/{AngelsFrontMod.d.cts → AngelsFrontMod.d.mts} +4 -3
  29. package/dist/AngelsFrontMod.d.ts +4 -3
  30. package/dist/AngelsFrontMod.js +40 -17
  31. package/dist/AngelsFrontMod.js.map +1 -1
  32. package/dist/{AngelsFrontComponent.js → AngelsFrontMod.mjs} +18 -37
  33. package/dist/AngelsFrontMod.mjs.map +1 -0
  34. package/dist/AngelsFrontPage.d.mts +11 -0
  35. package/dist/AngelsFrontPage.d.ts +3 -2
  36. package/dist/AngelsFrontPage.js +283 -28
  37. package/dist/AngelsFrontPage.js.map +1 -1
  38. package/dist/AngelsFrontPage.mjs +365 -0
  39. package/dist/AngelsFrontPage.mjs.map +1 -0
  40. package/dist/AngelsFrontWidgetClass.d.mts +15 -0
  41. package/dist/AngelsFrontWidgetClass.d.ts +15 -0
  42. package/dist/AngelsFrontWidgetClass.js +383 -0
  43. package/dist/AngelsFrontWidgetClass.js.map +1 -0
  44. package/dist/AngelsFrontWidgetClass.mjs +361 -0
  45. package/dist/AngelsFrontWidgetClass.mjs.map +1 -0
  46. package/dist/index.js +1 -0
  47. package/dist/index.mjs +1 -0
  48. package/package.json +13 -2
  49. package/sass/AngelsDesign.scss +5 -0
  50. package/sass/_AngelsHTMLElements.scss +244 -244
  51. package/sass/_AngelsPageLayout.scss +0 -4
  52. package/sass/_AngelsTheme.scss +47 -15
  53. package/sass/_AngelsVariables.scss +1 -4
  54. package/sass/angelsMessages/_AngelsAlert.scss +3 -2
  55. package/sass/angelsMessages/_AngelsDebug.scss +3 -2
  56. package/sass/angelsMessages/_AngelsDone.scss +3 -2
  57. package/sass/angelsMessages/_AngelsError.scss +3 -2
  58. package/sass/angelsMessages/_AngelsInfo.scss +3 -2
  59. package/sass/angelsMessages/_AngelsTip.scss +3 -2
  60. package/sass/angelsMessages/_AngelsWarn.scss +3 -2
  61. package/sass/angelsTags/_a-alpha.scss +29 -0
  62. package/sass/angelsTags/_a-center.scss +15 -0
  63. package/sass/angelsTags/_a-float.scss +42 -0
  64. package/sass/angelsTags/_a-icenter.scss +15 -0
  65. package/sass/angelsTags/_a-page.scss +13 -4
  66. package/sass/angelsTags/_a-state.scss +2 -1
  67. package/sass/angelsTags/_a-table.scss +9 -35
  68. package/sass/angelsTags/_a-text-transform.scss +29 -0
  69. package/dist/AngelsCore.cjs +0 -246
  70. package/dist/AngelsCore.cjs.map +0 -1
  71. package/dist/AngelsCore.js +0 -245
  72. package/dist/AngelsCore.js.map +0 -1
  73. package/dist/AngelsElement.cjs +0 -67
  74. package/dist/AngelsElement.cjs.map +0 -1
  75. package/dist/AngelsElement.d.cts +0 -11
  76. package/dist/AngelsElement.d.ts +0 -11
  77. package/dist/AngelsElement.js +0 -42
  78. package/dist/AngelsElement.js.map +0 -1
  79. package/dist/AngelsFrontAnimationLibrary.cjs.map +0 -1
  80. package/dist/AngelsFrontApplication.cjs +0 -155
  81. package/dist/AngelsFrontApplication.cjs.map +0 -1
  82. package/dist/AngelsFrontApplication.d.cts +0 -10
  83. package/dist/AngelsFrontComponent.cjs +0 -151
  84. package/dist/AngelsFrontComponent.cjs.map +0 -1
  85. package/dist/AngelsFrontComponent.d.cts +0 -11
  86. package/dist/AngelsFrontComponent.d.ts +0 -11
  87. package/dist/AngelsFrontComponent.js.map +0 -1
  88. package/dist/AngelsFrontDOMLibrary.cjs +0 -130
  89. package/dist/AngelsFrontDOMLibrary.cjs.map +0 -1
  90. package/dist/AngelsFrontDOMLibrary.d.cts +0 -9
  91. package/dist/AngelsFrontLoader.cjs.map +0 -1
  92. package/dist/AngelsFrontLoader.d.cts +0 -2
  93. package/dist/AngelsFrontMod.cjs +0 -128
  94. package/dist/AngelsFrontMod.cjs.map +0 -1
  95. package/dist/AngelsFrontPage.cjs +0 -155
  96. package/dist/AngelsFrontPage.cjs.map +0 -1
  97. package/dist/AngelsFrontPage.d.cts +0 -10
  98. package/dist/index.cjs +0 -2
  99. package/dist/index.d.cts +0 -2
  100. package/dist/{AngelsFrontAnimationLibrary.d.cts → AngelsFrontAnimationLibrary.d.mts} +1 -1
  101. /package/dist/{AngelsCore.d.cts → AngelsFrontLoader.d.mts} +0 -0
  102. /package/dist/{AngelsCore.d.ts → index.d.mts} +0 -0
  103. /package/dist/{index.cjs.map → index.mjs.map} +0 -0
@@ -0,0 +1,789 @@
1
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
2
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
3
+ }) : x)(function(x) {
4
+ if (typeof require !== "undefined") return require.apply(this, arguments);
5
+ throw Error('Dynamic require of "' + x + '" is not supported');
6
+ });
7
+ var __async = (__this, __arguments, generator) => {
8
+ return new Promise((resolve, reject) => {
9
+ var fulfilled = (value) => {
10
+ try {
11
+ step(generator.next(value));
12
+ } catch (e) {
13
+ reject(e);
14
+ }
15
+ };
16
+ var rejected = (value) => {
17
+ try {
18
+ step(generator.throw(value));
19
+ } catch (e) {
20
+ reject(e);
21
+ }
22
+ };
23
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
24
+ step((generator = generator.apply(__this, __arguments)).next());
25
+ });
26
+ };
27
+
28
+ // src/AngelsFrontElement.ts
29
+ var AngelsFrontElementClass = class _AngelsFrontElementClass {
30
+ constructor(element) {
31
+ this.aProxyBaseClass = _AngelsFrontElementClass;
32
+ this.elementBase = element;
33
+ return new Proxy(this, {
34
+ get(target, prop, receiver) {
35
+ if (prop in target) {
36
+ return Reflect.get(target, prop);
37
+ }
38
+ const valueOfProperty = Reflect.get(target.elementBase, prop);
39
+ if (typeof valueOfProperty === "function") {
40
+ return valueOfProperty.bind(target.elementBase);
41
+ }
42
+ return valueOfProperty;
43
+ },
44
+ set(target, prop, newValue, receiver) {
45
+ if (prop in target.elementBase) {
46
+ target.elementBase[prop] = newValue;
47
+ } else {
48
+ target[prop] = newValue;
49
+ }
50
+ return true;
51
+ }
52
+ });
53
+ }
54
+ aConcealElement() {
55
+ aLibConcealElement(this.elementBase);
56
+ return this;
57
+ }
58
+ aEngageElement(switcher = void 0) {
59
+ aLibEngageElement(this.elementBase, switcher);
60
+ return this;
61
+ }
62
+ aHideElement() {
63
+ this.elementBase.hidden = true;
64
+ return this;
65
+ }
66
+ aRevealElement() {
67
+ aLibRevealElement(this.elementBase);
68
+ return this;
69
+ }
70
+ aShowElement() {
71
+ this.elementBase.hidden = false;
72
+ return this;
73
+ }
74
+ aSetTextContent(content) {
75
+ const contentToSet = content.toString();
76
+ this.elementBase.textContent = contentToSet;
77
+ return this;
78
+ }
79
+ aTextContent() {
80
+ if (this.elementBase.textContent === null) {
81
+ return ``;
82
+ }
83
+ return this.elementBase.textContent;
84
+ }
85
+ };
86
+
87
+ // src/AngelsFrontMod.ts
88
+ var AngelsFrontMod = class {
89
+ constructor() {
90
+ this.modWaitStartTimeout = 1e3;
91
+ this.modSubMods = new Array();
92
+ }
93
+ /**
94
+ * Starts AngelsFrontMod.
95
+ */
96
+ modStart() {
97
+ this.modInit();
98
+ this.modBind();
99
+ this.modLink();
100
+ this.modRun();
101
+ setTimeout(() => {
102
+ this.modWait();
103
+ }, this.modWaitStartTimeout);
104
+ }
105
+ /**
106
+ * Finishes AngelsFrontMod.
107
+ */
108
+ modFinish() {
109
+ this.modDeWait();
110
+ this.modDeRun();
111
+ this.modDeLink();
112
+ this.modDeBind();
113
+ this.modDeInit();
114
+ }
115
+ /**
116
+ * Inits AngelsFrontMod and its sub-modules AngelsFrontMod.
117
+ */
118
+ modInit() {
119
+ this.modSubMods.forEach((mod) => mod.modInit());
120
+ }
121
+ /**
122
+ * Binds AngelsFrontMod and its sub-modules AngelsFrontMod.
123
+ */
124
+ modBind() {
125
+ this.modSubMods.forEach((mod) => mod.modBind());
126
+ }
127
+ /**
128
+ * Links AngelsFrontMod and its sub-modules AngelsFrontMod.
129
+ */
130
+ modLink() {
131
+ this.modSubMods.forEach((mod) => mod.modLink());
132
+ }
133
+ /**
134
+ * Runs AngelsFrontMod and its sub-modules AngelsFrontMod.
135
+ */
136
+ modRun() {
137
+ this.modSubMods.forEach((mod) => mod.modRun());
138
+ }
139
+ /**
140
+ * Waits AngelsFrontMod and its sub-modules AngelsFrontMod.
141
+ */
142
+ modWait() {
143
+ this.modSubMods.forEach((mod) => mod.modWait());
144
+ }
145
+ /**
146
+ * DeInits AngelsFrontMod and its sub-modules AngelsFrontMod.
147
+ */
148
+ modDeInit() {
149
+ this.modSubMods.forEach((mod) => mod.modDeInit());
150
+ }
151
+ /**
152
+ * DeBinds AngelsFrontMod and its sub-modules AngelsFrontMod.
153
+ */
154
+ modDeBind() {
155
+ this.modSubMods.forEach((mod) => mod.modDeBind());
156
+ }
157
+ /**
158
+ * DeLinks AngelsFrontMod and its sub-modules AngelsFrontMod.
159
+ */
160
+ modDeLink() {
161
+ this.modSubMods.forEach((mod) => mod.modDeLink());
162
+ }
163
+ /**
164
+ * DeRuns AngelsFrontMod and its sub-modules AngelsFrontMod.
165
+ */
166
+ modDeRun() {
167
+ this.modSubMods.forEach((mod) => mod.modDeRun());
168
+ }
169
+ /**
170
+ * DeWaits AngelsFrontMod and its sub-modules AngelsFrontMod.
171
+ */
172
+ modDeWait() {
173
+ this.modSubMods.forEach((mod) => mod.modDeWait());
174
+ }
175
+ modDestructor() {
176
+ this.modSubMods.forEach((mod) => mod.modDestructor());
177
+ }
178
+ modAddSubMod(mod) {
179
+ if (mod) {
180
+ this.modSubMods.push(mod);
181
+ mod.modInit();
182
+ return mod;
183
+ }
184
+ return null;
185
+ }
186
+ modRequireSubMod(mod) {
187
+ this.modSubMods.push(mod);
188
+ mod.modInit();
189
+ return mod;
190
+ }
191
+ };
192
+
193
+ // src/AngelsFrontWidgetClass.ts
194
+ var AngelsFrontWidgetClass = class extends AngelsFrontMod {
195
+ constructor(element) {
196
+ super();
197
+ this.widElement = aLibPrepareElement(element);
198
+ return new Proxy(this, {
199
+ get(target, prop, receiver) {
200
+ if (prop in target) {
201
+ const valueOfProperty2 = target[prop];
202
+ if (typeof valueOfProperty2 === "function") {
203
+ return Reflect.get(target, prop);
204
+ }
205
+ return valueOfProperty2;
206
+ }
207
+ const valueOfProperty = target.widElement[prop];
208
+ if (typeof valueOfProperty === "function") {
209
+ return valueOfProperty.bind(target.widElement);
210
+ }
211
+ return valueOfProperty;
212
+ },
213
+ set(target, prop, newValue, receiver) {
214
+ if (prop in target) {
215
+ target[prop] = newValue;
216
+ } else {
217
+ target.widElement[prop] = newValue;
218
+ }
219
+ return true;
220
+ }
221
+ });
222
+ }
223
+ widFindElement(selector) {
224
+ const findElement = this.widElement.querySelector(selector);
225
+ if (findElement) {
226
+ return aFindElement(findElement);
227
+ }
228
+ return null;
229
+ }
230
+ widFindElements(selector) {
231
+ return Array.from(this.widElement.querySelectorAll(selector)).map(aFindElement);
232
+ }
233
+ widRequireElement(selector) {
234
+ const element = this.widElement.querySelector(selector);
235
+ if (element) {
236
+ return aFindElement(element);
237
+ }
238
+ throw Error(`Element '${selector}' is not found.`);
239
+ }
240
+ };
241
+
242
+ // src/AngelsFrontDOMLibrary.ts
243
+ function aLibCreateWidget(element) {
244
+ return new AngelsFrontWidgetClass(element);
245
+ }
246
+ function aLibFindElement(selector) {
247
+ let element;
248
+ if (typeof selector === "undefined") {
249
+ return null;
250
+ } else if (selector === null) {
251
+ return null;
252
+ } else if (typeof selector === "string") {
253
+ const findElement = document.querySelector(selector);
254
+ if (!findElement) {
255
+ return null;
256
+ }
257
+ element = findElement;
258
+ } else if (selector instanceof HTMLElement) {
259
+ element = selector;
260
+ } else if (selector instanceof Element) {
261
+ element = selector;
262
+ } else if (selector instanceof AngelsFrontElementClass) {
263
+ return selector;
264
+ } else {
265
+ element = selector;
266
+ }
267
+ return new AngelsFrontElementClass(element);
268
+ }
269
+ function aLibRequireElement(selector) {
270
+ const element = aLibFindElement(selector);
271
+ if (element) {
272
+ return element;
273
+ }
274
+ throw Error(`Element not found by '${selector}' selector.`);
275
+ }
276
+ function aLibHideElement(selector) {
277
+ const element = aLibRequireElement(selector);
278
+ element.hidden = true;
279
+ return element;
280
+ }
281
+ function aLibPrepareElement(element) {
282
+ let angelsFrontElement;
283
+ if ("aProxyBaseClass" in element && element.aProxyBaseClass === AngelsFrontElementClass) {
284
+ angelsFrontElement = element;
285
+ } else if (element instanceof HTMLElement) {
286
+ angelsFrontElement = new AngelsFrontElementClass(element);
287
+ } else {
288
+ throw Error("Cannot prepare element: invalid element type.");
289
+ }
290
+ return angelsFrontElement;
291
+ }
292
+ function aLibShowElement(selector) {
293
+ const element = aLibRequireElement(selector);
294
+ element.hidden = false;
295
+ return element;
296
+ }
297
+ function aLibToggleElement(originalElement, switcher = void 0) {
298
+ const innerElement = aLibRequireElement(originalElement);
299
+ if (switcher === void 0) {
300
+ switcher = innerElement.hidden;
301
+ }
302
+ if (switcher) {
303
+ return aLibShowElement(innerElement);
304
+ } else {
305
+ return aLibHideElement(innerElement);
306
+ }
307
+ }
308
+
309
+ // src/AngelsFrontAnimationLibrary.ts
310
+ function aLibConcealElement(originalElement) {
311
+ return __async(this, null, function* () {
312
+ const innerElement = aLibRequireElement(originalElement);
313
+ const promise = new Promise((resolve) => {
314
+ if (innerElement.hidden) {
315
+ resolve();
316
+ return;
317
+ }
318
+ let timeout;
319
+ const animationHandler = () => {
320
+ clearTimeout(timeout);
321
+ innerElement.removeEventListener("animationend", animationHandler);
322
+ innerElement.hidden = true;
323
+ innerElement.classList.remove("a-out-animation");
324
+ resolve();
325
+ };
326
+ innerElement.classList.add("a-out-animation");
327
+ const animations = innerElement.getAnimations();
328
+ if (animations.length > 0) {
329
+ timeout = setTimeout(() => {
330
+ innerElement.removeEventListener("animationend", animationHandler);
331
+ innerElement.hidden = true;
332
+ innerElement.classList.remove("a-out-animation");
333
+ console.warn("Animation timeout");
334
+ resolve();
335
+ }, 5e3);
336
+ innerElement.addEventListener("animationend", animationHandler);
337
+ } else {
338
+ innerElement.hidden = true;
339
+ resolve();
340
+ }
341
+ });
342
+ return promise;
343
+ });
344
+ }
345
+ function aLibEngageElement(originalElement, switcher = void 0) {
346
+ return __async(this, null, function* () {
347
+ const innerElement = aLibRequireElement(originalElement);
348
+ if (switcher === void 0) {
349
+ switcher = innerElement.hidden;
350
+ }
351
+ if (switcher) {
352
+ return yield aLibRevealElement(innerElement);
353
+ } else {
354
+ return yield aLibConcealElement(innerElement);
355
+ }
356
+ });
357
+ }
358
+ function aLibRevealElement(originalElement) {
359
+ return __async(this, null, function* () {
360
+ const innerElement = aLibRequireElement(originalElement);
361
+ const promise = new Promise((resolve) => {
362
+ if (!innerElement.hidden) {
363
+ resolve();
364
+ return;
365
+ }
366
+ let timeout;
367
+ const animationHandler = () => {
368
+ clearTimeout(timeout);
369
+ innerElement.removeEventListener("animationend", animationHandler);
370
+ resolve();
371
+ };
372
+ innerElement.hidden = false;
373
+ const animations = innerElement.getAnimations();
374
+ if (animations.length > 0) {
375
+ timeout = setTimeout(() => {
376
+ innerElement.removeEventListener("animationend", animationHandler);
377
+ console.warn("Animation timeout");
378
+ resolve();
379
+ }, 5e3);
380
+ innerElement.addEventListener("animationend", animationHandler);
381
+ } else {
382
+ resolve();
383
+ }
384
+ });
385
+ return promise;
386
+ });
387
+ }
388
+
389
+ // src/AngelsFrontWebComponents/AngelsFrontBoardWebComponent.ts
390
+ var AngelsFrontBoardWebComponent = class _AngelsFrontBoardWebComponent extends HTMLElement {
391
+ /**
392
+ * Use the global displayHandler if set
393
+ */
394
+ get displayHandler() {
395
+ return _AngelsFrontBoardWebComponent.globalDisplayHandler;
396
+ }
397
+ /**
398
+ * Switch the visible child by key
399
+ */
400
+ aBoardSwitch(aBoardItemKey) {
401
+ this.setAttribute("a-board-show", aBoardItemKey);
402
+ }
403
+ /**
404
+ * Update visibility based on children/text
405
+ */
406
+ aBoardUpdateDisplaying() {
407
+ const children = Array.from(this.children);
408
+ const hasVisibleChildren = children.some((el) => !el.hidden);
409
+ const hasNonWhitespaceText = Array.from(this.childNodes).some(
410
+ (node) => node.nodeType === Node.TEXT_NODE && node.textContent.trim() !== ""
411
+ );
412
+ this.hidden = !hasVisibleChildren && !hasNonWhitespaceText;
413
+ this.toggleAttribute("a-board-auto-hidden", this.hidden);
414
+ }
415
+ aBoardShowKey() {
416
+ return this.getAttribute("a-board-show") || "";
417
+ }
418
+ connectedCallback() {
419
+ this.initContent();
420
+ this.observeMutations();
421
+ }
422
+ disconnectedCallback() {
423
+ var _a;
424
+ (_a = this.mutationObserver) == null ? void 0 : _a.disconnect();
425
+ }
426
+ static get observedAttributes() {
427
+ return ["a-board-show"];
428
+ }
429
+ attributeChangedCallback(name, oldValue, newValue) {
430
+ switch (name) {
431
+ case "a-board-show":
432
+ if (oldValue !== newValue) {
433
+ this.updateContent();
434
+ }
435
+ }
436
+ }
437
+ /**
438
+ * Update which child is visible
439
+ */
440
+ initContent() {
441
+ return __async(this, null, function* () {
442
+ const key = this.aBoardShowKey();
443
+ const items = Array.from(this.querySelectorAll(`:scope > [a-board-key]`));
444
+ const activeItem = items.find((el) => el.getAttribute("a-board-key") === key);
445
+ items.filter((el) => el !== activeItem).forEach((el) => {
446
+ const show = el === activeItem;
447
+ el.hidden = true;
448
+ });
449
+ if (activeItem) {
450
+ activeItem.hidden = false;
451
+ }
452
+ this.aBoardUpdateDisplaying();
453
+ });
454
+ }
455
+ /**
456
+ * Update which child is visible
457
+ */
458
+ updateContent() {
459
+ return __async(this, null, function* () {
460
+ var _a;
461
+ (_a = this.mutationObserver) == null ? void 0 : _a.disconnect();
462
+ const key = this.aBoardShowKey();
463
+ const items = Array.from(this.querySelectorAll(`:scope > [a-board-key]`));
464
+ const activeItem = items.find((el) => el.getAttribute("a-board-key") === key);
465
+ const rect = this.getBoundingClientRect();
466
+ const prevWidth = this.style.width;
467
+ const prevHeight = this.style.height;
468
+ const prevOverflow = this.style.overflow;
469
+ this.style.width = rect.width + "px";
470
+ this.style.height = rect.height + "px";
471
+ this.style.overflow = "hidden";
472
+ if (this.displayHandler) {
473
+ const promises = [];
474
+ items.filter((el) => el !== activeItem).forEach((el) => {
475
+ const displayHandlerResult = this.displayHandler(el, false);
476
+ if (displayHandlerResult instanceof Promise) {
477
+ promises.push(displayHandlerResult);
478
+ }
479
+ });
480
+ yield Promise.all(promises);
481
+ let targetHeight = 0;
482
+ console.log("targetHeight", targetHeight);
483
+ if (activeItem) {
484
+ activeItem.classList.add("a-technical-transparent");
485
+ targetHeight = activeItem.scrollHeight;
486
+ activeItem.classList.remove("a-technical-transparent");
487
+ }
488
+ console.log("targetHeight", targetHeight);
489
+ const heightAnimation = this.animate([
490
+ { height: rect.height + "px" },
491
+ { height: targetHeight + "px" }
492
+ ], {
493
+ duration: 300,
494
+ easing: "ease-in-out"
495
+ });
496
+ yield new Promise((resolve) => {
497
+ heightAnimation.addEventListener("finish", resolve);
498
+ });
499
+ this.style.height = targetHeight + "px";
500
+ if (activeItem) {
501
+ yield this.displayHandler(activeItem, true);
502
+ }
503
+ } else {
504
+ items.filter((el) => el !== activeItem).forEach((el) => {
505
+ const show = el === activeItem;
506
+ el.hidden = true;
507
+ });
508
+ let targetHeight = 0;
509
+ if (activeItem) {
510
+ activeItem.classList.add("a-technical-transparent");
511
+ targetHeight = activeItem.scrollHeight;
512
+ ;
513
+ activeItem.classList.remove("a-technical-transparent");
514
+ }
515
+ this.style.height = targetHeight + "px";
516
+ if (activeItem) {
517
+ activeItem.hidden = false;
518
+ }
519
+ }
520
+ this.style.height = "";
521
+ this.style.width = prevWidth;
522
+ this.style.overflow = prevOverflow;
523
+ this.aBoardUpdateDisplaying();
524
+ this.observeMutations();
525
+ });
526
+ }
527
+ /**
528
+ * Observe direct children and text nodes only, with debounce
529
+ */
530
+ observeMutations() {
531
+ if (this.mutationObserver) this.mutationObserver.disconnect();
532
+ this.mutationObserver = new MutationObserver(() => {
533
+ clearTimeout(this.mutationTimeout);
534
+ this.mutationTimeout = window.setTimeout(() => {
535
+ this.aBoardUpdateDisplaying();
536
+ }, 50);
537
+ });
538
+ this.mutationObserver.observe(this, {
539
+ childList: true,
540
+ characterData: true,
541
+ attributes: true,
542
+ subtree: false,
543
+ attributeFilter: ["hidden", "style", "class"]
544
+ });
545
+ }
546
+ /**
547
+ * Set global display handler for all <a-board> instances
548
+ */
549
+ static setGlobalDisplayHandler(handler) {
550
+ _AngelsFrontBoardWebComponent.globalDisplayHandler = handler;
551
+ }
552
+ };
553
+ function angelsBoardDefine(options) {
554
+ if (!customElements.get("a-board")) {
555
+ if (options == null ? void 0 : options.displayHandler) {
556
+ AngelsFrontBoardWebComponent.setGlobalDisplayHandler(options.displayHandler);
557
+ }
558
+ customElements.define("a-board", AngelsFrontBoardWebComponent);
559
+ } else if (options == null ? void 0 : options.displayHandler) {
560
+ AngelsFrontBoardWebComponent.setGlobalDisplayHandler(options.displayHandler);
561
+ }
562
+ return customElements.get("a-board");
563
+ }
564
+
565
+ // src/AngelsFrontWebComponents/AngelsFrontStateWebComponent.ts
566
+ var _AngelsFrontStateWebComponent = class _AngelsFrontStateWebComponent extends HTMLElement {
567
+ connectedCallback() {
568
+ this.hidden = this.textContent.trim().length === 0;
569
+ }
570
+ aStateAlert(message) {
571
+ this.aStateSet("a-alert" /* ALERT */, message);
572
+ }
573
+ aStateClear() {
574
+ this.classList.remove(..._AngelsFrontStateWebComponent.aStateClasses);
575
+ this.aStateSetMessage("");
576
+ }
577
+ aStateDebug(message) {
578
+ this.aStateSet("a-debug" /* DEBUG */, message);
579
+ }
580
+ aStateDone(message) {
581
+ this.aStateSet("a-done" /* DONE */, message);
582
+ }
583
+ aStateError(message) {
584
+ this.aStateSet("a-error" /* ERROR */, message);
585
+ }
586
+ aStateInfo(message) {
587
+ this.aStateSet("a-info" /* INFO */, message);
588
+ }
589
+ aStateSet(className, message) {
590
+ this.aStateSetType(className);
591
+ this.aStateSetMessage(message);
592
+ }
593
+ aStateSetMessage(message) {
594
+ this.textContent = message;
595
+ this.hidden = this.textContent.trim().length === 0;
596
+ }
597
+ aStateSetType(className) {
598
+ const classesToRemove = _AngelsFrontStateWebComponent.aStateClasses.filter((c) => c !== className);
599
+ this.classList.remove(...classesToRemove);
600
+ this.classList.add(className);
601
+ }
602
+ aStateTip(message) {
603
+ this.aStateSet("a-tip" /* TIP */, message);
604
+ }
605
+ aStateWarn(message) {
606
+ this.aStateSet("a-warn" /* WARN */, message);
607
+ }
608
+ };
609
+ _AngelsFrontStateWebComponent.aStateClasses = [
610
+ "a-alert" /* ALERT */,
611
+ "a-debug" /* DEBUG */,
612
+ "a-done" /* DONE */,
613
+ "a-error" /* ERROR */,
614
+ "a-info" /* INFO */,
615
+ "a-tip" /* TIP */,
616
+ "a-warn" /* WARN */
617
+ ];
618
+ var AngelsFrontStateWebComponent = _AngelsFrontStateWebComponent;
619
+ function angelsStateDefine() {
620
+ if (!customElements.get("a-state")) {
621
+ customElements.define("a-state", AngelsFrontStateWebComponent);
622
+ }
623
+ return customElements.get("a-state");
624
+ }
625
+
626
+ // src/AngelsFrontWebComponents/AngelsFrontDemoWebComponent.ts
627
+ var pretty = __require("pretty");
628
+ var AngelsFrontDemoWebComponent = class extends HTMLElement {
629
+ constructor() {
630
+ super();
631
+ this.awcRoot = this.attachShadow({ mode: "open" });
632
+ this.awcRoot.innerHTML = this.awcTemplate() + this.awcStyles();
633
+ this.awcReDraw();
634
+ }
635
+ connectedCallback() {
636
+ this.addEventListener("slotchange", this.awcReDraw.bind(this));
637
+ }
638
+ awcReDraw() {
639
+ const headerPart = this.awcRoot.querySelector('[part="a-demo-header"]');
640
+ const headerSlot = headerPart.querySelector("slot");
641
+ headerPart.hidden = !headerSlot.assignedNodes({ flatten: true }).length;
642
+ const resultSlot = this.awcRoot.querySelector('[part="a-demo-result"] slot');
643
+ const codePart = this.awcRoot.querySelector('[part="a-demo-code"]');
644
+ let code = resultSlot.assignedNodes({ flatten: true }).map((n) => n.outerHTML || n.textContent).join("");
645
+ code = pretty(code, { ocd: true });
646
+ console.log("code", code);
647
+ codePart.textContent = code.trim();
648
+ }
649
+ awcTemplate() {
650
+ return `
651
+ <div part="a-demo-header"><slot name="a-demo-header"></slot></div>
652
+ <div part="a-demo-result"><slot></slot></div>
653
+ <pre part="a-demo-code"></pre>
654
+ `;
655
+ }
656
+ awcStyles() {
657
+ return `
658
+ <style>
659
+ :host {
660
+ --a-demo-borderColor: darkmagenta;
661
+ --a-demo-borderRadius: var(--a-borderRadius, 4px);
662
+ --a-demo-backgroundColor: #fffbf3;
663
+ }
664
+ :host {
665
+ background: var(--a-demo-borderColor);
666
+ border: 1px solid var(--a-demo-borderColor);
667
+ border-radius: var(--a-demo-borderRadius);
668
+ display: grid;
669
+ gap: 1px;
670
+ font-family: Arial, sans-serif;
671
+ overflow: hidden;
672
+ }
673
+ :host > * {
674
+ background: var(--a-demo-backgroundColor);
675
+ padding: .5em;
676
+ }
677
+ [part="a-demo-header"] {
678
+ }
679
+ [part="a-demo-result"] slot {
680
+ }
681
+ [part="a-demo-code"] {
682
+ margin: 0;
683
+ overflow: auto;
684
+ }
685
+ </style>
686
+ `;
687
+ }
688
+ };
689
+ function angelsDemoDefine() {
690
+ if (!customElements.get("a-demo")) {
691
+ customElements.define("a-demo", AngelsFrontDemoWebComponent);
692
+ }
693
+ return customElements.get("a-demo");
694
+ }
695
+
696
+ // src/AngelsFrontWebComponents/AngelsFrontListWebComponent.ts
697
+ var _AngelsFrontListWebComponent = class _AngelsFrontListWebComponent extends HTMLElement {
698
+ constructor() {
699
+ super();
700
+ this.awcAppendStyles();
701
+ }
702
+ connectedCallback() {
703
+ this.awcRender();
704
+ }
705
+ attributeChangedCallback(name, oldValue, newValue) {
706
+ this.awcRender();
707
+ }
708
+ awcAppendStyles() {
709
+ if (_AngelsFrontListWebComponent.awcStylesAppended) {
710
+ return;
711
+ }
712
+ _AngelsFrontListWebComponent.awcStylesAppended = true;
713
+ const style = document.createElement("style");
714
+ style.textContent = `
715
+ a-list {
716
+ --a-list-space: var(--a-halfSize, 0.5em);
717
+ display: inline;
718
+ }
719
+ a-list::before {
720
+ content: attr(a-list-prefix);
721
+ display: inline;
722
+ }
723
+ a-list::after {
724
+ content: attr(a-list-suffix);
725
+ display: inline;
726
+ }
727
+ a-list .a-list-item:not(:last-child)::after {
728
+ content: attr(a-list-separator);
729
+ display: inline;
730
+ margin-right: var(--a-list-space);
731
+ }
732
+ `;
733
+ document.head.appendChild(style);
734
+ }
735
+ awcRender() {
736
+ const itemsAttr = this.getAttribute("a-list");
737
+ const separator = this.getAttribute("a-list-separator") || " ";
738
+ if (itemsAttr) {
739
+ try {
740
+ const items = JSON.parse(itemsAttr);
741
+ const children = [];
742
+ if (Array.isArray(items)) {
743
+ items.forEach((item, index) => {
744
+ const span = document.createElement("a-list-item");
745
+ span.textContent = item;
746
+ span.classList.add("a-list-item");
747
+ span.setAttribute("a-list-separator", this.getAttribute("a-list-separator") || " ");
748
+ children.push(span);
749
+ });
750
+ } else {
751
+ console.error('Attribute "a-list" must be an array of strings.');
752
+ }
753
+ this.replaceChildren(...children);
754
+ } catch (error) {
755
+ console.error(`Error parsing "a-list" attribute of "${itemsAttr}"`, error);
756
+ this.replaceChildren();
757
+ }
758
+ } else {
759
+ this.replaceChildren();
760
+ }
761
+ }
762
+ };
763
+ _AngelsFrontListWebComponent.awcStylesAppended = false;
764
+ _AngelsFrontListWebComponent.observedAttributes = ["a-list", "a-list-separator"];
765
+ var AngelsFrontListWebComponent = _AngelsFrontListWebComponent;
766
+ function angelsListDefine() {
767
+ if (!customElements.get("a-list")) {
768
+ customElements.define("a-list", AngelsFrontListWebComponent);
769
+ }
770
+ return customElements.get("a-list");
771
+ }
772
+
773
+ // src/AngelsFrontLoader.ts
774
+ window.aEngageElement = aLibEngageElement;
775
+ window.aConcealElement = aLibConcealElement;
776
+ window.aRevealElement = aLibRevealElement;
777
+ window.aCreateWidget = aLibCreateWidget;
778
+ window.aFindElement = aLibFindElement;
779
+ window.aHideElement = aLibHideElement;
780
+ window.aRequireElement = aLibRequireElement;
781
+ window.aShowElement = aLibShowElement;
782
+ window.aToggleElement = aLibToggleElement;
783
+ angelsBoardDefine({
784
+ displayHandler: aEngageElement
785
+ });
786
+ angelsStateDefine();
787
+ angelsDemoDefine();
788
+ angelsListDefine();
789
+ //# sourceMappingURL=AngelsFrontLoader.mjs.map