@rusticarcade/palette 0.4.0 → 0.7.0

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/dev/index.js CHANGED
@@ -170,271 +170,6 @@ class PaletteError extends Error {
170
170
  }
171
171
  }
172
172
 
173
- // src/util/attributes.ts
174
- function serializeAttribute(value) {
175
- if (typeof value === "string" || typeof value === "number") {
176
- return `${value}`;
177
- }
178
- if (value === true) {
179
- return "";
180
- }
181
- if (value === null || value === false || value === undefined) {
182
- return null;
183
- }
184
- return value.toString();
185
- }
186
- function createAttributeMap(source) {
187
- const map = new Map;
188
- if (source instanceof HTMLElement) {
189
- for (const name of source.getAttributeNames()) {
190
- map.set(name, serializeAttribute(source.getAttribute(name)));
191
- }
192
- return map;
193
- }
194
- if (source instanceof Map) {
195
- for (const [key, val] of source) {
196
- map.set(key, serializeAttribute(val));
197
- }
198
- return map;
199
- }
200
- if (typeof source === "object" && source !== null) {
201
- for (const [key, val] of Object.entries(source)) {
202
- map.set(key, serializeAttribute(val));
203
- }
204
- return map;
205
- }
206
- throw new PaletteError(0 /* INVARIANT */);
207
- }
208
- function applyAttributeMap(target, attrs) {
209
- const currentNames = new Set(target.getAttributeNames());
210
- const incomingNames = new Set(attrs.keys());
211
- const attributesToRemove = currentNames.difference(incomingNames);
212
- for (const attr of attributesToRemove) {
213
- target.removeAttribute(attr);
214
- }
215
- for (const [name, val] of attrs) {
216
- if (val === null) {
217
- target.removeAttribute(name);
218
- } else {
219
- target.setAttribute(name, val);
220
- }
221
- }
222
- }
223
- // src/util/element-match.ts
224
- function isTagName(str) {
225
- for (let i = 0;i < str.length; i++) {
226
- const char = str.charAt(i);
227
- if (!(char === "-" || char >= "A" && char <= "Z" || char >= "a" && char <= "z")) {
228
- return false;
229
- }
230
- }
231
- return true;
232
- }
233
- function elementMatches(element, query) {
234
- if (query[0] === "#" && query.indexOf(" ") === -1 && query.indexOf(".") === -1 && query.indexOf("[") === -1 && query.indexOf(":") === -1 && query.indexOf(">") === -1) {
235
- return element.id === query.slice(1);
236
- }
237
- if (query[0] === "." && query.indexOf(" ") === -1 && query.indexOf("#") === -1 && query.indexOf("[") === -1 && query.indexOf(":") === -1 && query.indexOf(">") === -1) {
238
- return element.classList.contains(query.slice(1));
239
- }
240
- if (isTagName(query)) {
241
- return element.tagName.toLowerCase() === query.toLowerCase();
242
- }
243
- if (query[0] === "[" && query[query.length - 1] === "]" && query.indexOf(" ") === -1 && query.indexOf(":") === -1) {
244
- const attr = query.slice(1, -1);
245
- const eqIndex = attr.indexOf("=");
246
- if (eqIndex === -1) {
247
- return element.hasAttribute(attr);
248
- }
249
- const attrName = attr.slice(0, eqIndex);
250
- const attrValue = attr.slice(eqIndex + 1).replace(/^["']|["']$/g, "");
251
- return element.getAttribute(attrName) === attrValue;
252
- }
253
- return element.matches(query);
254
- }
255
- // src/util/lru-cache.ts
256
- class LRUCache {
257
- _maxSize;
258
- _data;
259
- _metrics = { hits: 0, misses: 0 };
260
- constructor(maxSize = 500) {
261
- if (maxSize <= 0) {
262
- throw new Error("LRU Cache capacity must be >= 1");
263
- }
264
- if (true) {
265
- this._metrics = { hits: 0, misses: 0 };
266
- }
267
- this._maxSize = maxSize;
268
- this._data = new Map;
269
- }
270
- _trim = () => {
271
- while (this._data.size > this._maxSize) {
272
- const firstKey = this._data.keys().next().value;
273
- if (firstKey === undefined) {
274
- throw new Error("Absurd");
275
- }
276
- this._data.delete(firstKey);
277
- }
278
- };
279
- getMetrics() {
280
- if (true) {
281
- const { hits = 0, misses = 0 } = this._metrics ?? {};
282
- const lookups = hits + misses;
283
- const hitRate = lookups === 0 ? 0 : hits / lookups;
284
- return {
285
- lookups,
286
- hits,
287
- misses,
288
- capacity: this._maxSize,
289
- entries: this._data.size,
290
- hitRate
291
- };
292
- }
293
- }
294
- setCapacity = (maxSize) => {
295
- if (maxSize <= 0 && true) {
296
- console.warn("[Palette LRU Cache] Cache size is <= 0. Cache is disabled.");
297
- }
298
- this._maxSize = maxSize;
299
- this._trim();
300
- };
301
- get(key) {
302
- const value = this._data.get(key);
303
- if (value === undefined) {
304
- if (true) {
305
- this._metrics.misses += 1;
306
- }
307
- return;
308
- }
309
- this._data.delete(key);
310
- this._data.set(key, value);
311
- if (true) {
312
- this._metrics.hits += 1;
313
- }
314
- return value;
315
- }
316
- set(key, value) {
317
- if (this._data.has(key)) {
318
- this._data.delete(key);
319
- }
320
- this._data.set(key, value);
321
- if (this._data.size > this._maxSize) {
322
- this._trim();
323
- }
324
- }
325
- clear() {
326
- this._data.clear();
327
- }
328
- get size() {
329
- return this._data.size;
330
- }
331
- }
332
- var lru_cache_default = LRUCache;
333
-
334
- // src/util/fragments.ts
335
- var fragmentCache = new lru_cache_default;
336
- function htmlToFragment(html) {
337
- const lookup = fragmentCache.get(html);
338
- if (lookup !== undefined) {
339
- return lookup.cloneNode(true);
340
- }
341
- const temp = document.createElement("template");
342
- temp.innerHTML = html;
343
- fragmentCache.set(html, temp.content);
344
- return temp.content.cloneNode(true);
345
- }
346
- function saveFragment(html, fragment) {
347
- fragmentCache.set(html, fragment);
348
- }
349
- // src/helper/css.ts
350
- function parseCSSTemplateStringValue(val) {
351
- if (typeof val === "function") {
352
- const tagName = val.tagName;
353
- if (!isTagName(tagName)) {
354
- throw new PaletteError(203 /* TEMPLATE_INVALID_COMPONENT */, val.name, val.tagName);
355
- }
356
- return tagName;
357
- }
358
- if (typeof val === "string") {
359
- return val;
360
- }
361
- throw new PaletteError(200 /* TEMPLATE_INVALID_VALUE */, String(val));
362
- }
363
- function css(strings, ...values) {
364
- let result = strings[0] ?? "";
365
- for (let i = 0;i < values.length; i++) {
366
- const nextVal = values[i] ?? "";
367
- const nextStr = strings[i + 1] ?? "";
368
- result += parseCSSTemplateStringValue(nextVal);
369
- result += nextStr;
370
- }
371
- const sheet = new CSSStyleSheet;
372
- sheet.replaceSync(result);
373
- return sheet;
374
- }
375
- function classify(...args) {
376
- let resultString = "";
377
- for (let index = 0;index < args.length; index++) {
378
- const argument = args[index];
379
- if (!argument) {
380
- continue;
381
- }
382
- if (typeof argument === "string" || typeof argument === "number") {
383
- if (resultString) {
384
- resultString += " ";
385
- }
386
- resultString += argument;
387
- continue;
388
- }
389
- if (Array.isArray(argument)) {
390
- const nestedResult = classify(...argument);
391
- if (nestedResult) {
392
- if (resultString) {
393
- resultString += " ";
394
- }
395
- resultString += nestedResult;
396
- }
397
- continue;
398
- }
399
- if (typeof argument === "object") {
400
- for (const className in argument) {
401
- if (argument[className]) {
402
- if (resultString) {
403
- resultString += " ";
404
- }
405
- resultString += className;
406
- }
407
- }
408
- }
409
- }
410
- return resultString;
411
- }
412
- // src/helper/html.ts
413
- function parseTemplateStringValue(val) {
414
- if (val instanceof HTMLTemplateElement) {
415
- return val.innerHTML;
416
- }
417
- if (typeof val === "function" && (val.prototype instanceof Component || val === Component)) {
418
- const tagName = val.tagName;
419
- if (!isTagName(tagName)) {
420
- throw new PaletteError(203 /* TEMPLATE_INVALID_COMPONENT */, val.name, val.tagName);
421
- }
422
- return tagName;
423
- }
424
- if (typeof val === "string") {
425
- return `<span ::swap="${val}"></span>`;
426
- }
427
- throw new PaletteError(200 /* TEMPLATE_INVALID_VALUE */, String(val));
428
- }
429
- function html(strings, ...values) {
430
- const fullString = strings.reduce((acc, str, i) => {
431
- const parsedValue = values[i] ? `${parseTemplateStringValue(values[i])}` : "";
432
- return acc + str + parsedValue;
433
- }, "");
434
- const templateElement = document.createElement("template");
435
- templateElement.innerHTML = fullString;
436
- return templateElement;
437
- }
438
173
  // src/state/state.ts
439
174
  var ArrayMutatorFunctions = new Set([
440
175
  "push",
@@ -455,17 +190,18 @@ var DataStructureMutatorFunctions = new Set([
455
190
  ]);
456
191
 
457
192
  class State {
193
+ static isState(value) {
194
+ return value !== null && typeof value === "object" && value instanceof State;
195
+ }
458
196
  _data;
459
197
  _listeners = new Set;
460
198
  _proxy;
461
199
  _proxyCache = new WeakMap;
462
200
  _reverseProxyCache = new WeakMap;
463
- _isLocked = false;
464
- constructor(initialData, onChange) {
201
+ constructor(initialData, listener) {
465
202
  this._data = initialData;
466
- this.get = this.get.bind(this);
467
- if (onChange) {
468
- this._listeners.add(onChange);
203
+ if (listener) {
204
+ this._listeners.add(listener);
469
205
  }
470
206
  }
471
207
  _createProxy(target, path = []) {
@@ -493,9 +229,6 @@ class State {
493
229
  }
494
230
  const res = current[key](...args);
495
231
  if (isMutation) {
496
- if (this._isLocked) {
497
- throw new PaletteError(305 /* STATE_LOCKED */);
498
- }
499
232
  this._processIncomingState(snapshot);
500
233
  }
501
234
  return res;
@@ -507,9 +240,6 @@ class State {
507
240
  return value;
508
241
  },
509
242
  set: (_obj, key, value) => {
510
- if (this._isLocked) {
511
- throw new PaletteError(305 /* STATE_LOCKED */);
512
- }
513
243
  if (typeof key === "symbol") {
514
244
  return false;
515
245
  }
@@ -583,7 +313,7 @@ class State {
583
313
  }
584
314
  if (current[finalKey] !== value && !Object.is(current[finalKey], value)) {
585
315
  current[finalKey] = value;
586
- this._emit(this.current);
316
+ this._emit(this.raw);
587
317
  }
588
318
  }
589
319
  _processIncomingState = (incomingState) => {
@@ -601,13 +331,14 @@ class State {
601
331
  if (hasChanges) {
602
332
  this._emit(this._data);
603
333
  }
334
+ return this;
604
335
  };
605
336
  _emit = (data) => {
606
337
  for (const listener of this._listeners) {
607
338
  listener(data);
608
339
  }
609
340
  };
610
- get current() {
341
+ get raw() {
611
342
  return this._data;
612
343
  }
613
344
  get live() {
@@ -616,9 +347,6 @@ class State {
616
347
  }
617
348
  return this._proxy;
618
349
  }
619
- get isLocked() {
620
- return this._isLocked;
621
- }
622
350
  addListener = (listener) => {
623
351
  this._listeners.add(listener);
624
352
  };
@@ -632,101 +360,229 @@ class State {
632
360
  return structuredClone(this._data);
633
361
  };
634
362
  set = (key, value) => {
635
- if (this._isLocked) {
636
- throw new PaletteError(305 /* STATE_LOCKED */);
637
- }
638
363
  const partial = {};
639
364
  partial[key] = value;
640
- this._processIncomingState(partial);
365
+ return this._processIncomingState(partial);
641
366
  };
642
367
  patch = (patch) => {
643
- if (this._isLocked) {
644
- throw new PaletteError(305 /* STATE_LOCKED */);
645
- }
646
- this._processIncomingState(patch);
647
- return this;
368
+ return this._processIncomingState(patch);
648
369
  };
649
370
  replace = (state) => {
650
- if (this._isLocked) {
651
- throw new PaletteError(305 /* STATE_LOCKED */);
652
- }
653
371
  this._data = state;
654
372
  this._emit(this._data);
655
373
  return this;
656
374
  };
657
- lock = () => {
658
- if (this._isLocked) {
659
- throw new PaletteError(305 /* STATE_LOCKED */);
660
- }
661
- this._isLocked = true;
662
- return this;
663
- };
664
- unlock = () => {
665
- this._isLocked = false;
666
- return this;
667
- };
668
375
  mutate = (mutator) => {
669
- if (this._isLocked) {
670
- throw new PaletteError(305 /* STATE_LOCKED */);
671
- }
672
- this._processIncomingState(mutator(this.snapshot()));
673
- return this;
376
+ return this._processIncomingState(mutator(this.snapshot()));
674
377
  };
675
- mutateAsync = async (mutator, lock = false) => {
676
- if (this._isLocked) {
677
- throw new PaletteError(305 /* STATE_LOCKED */);
378
+ }
379
+ // src/util/lru-cache.ts
380
+ class LRUCache {
381
+ _maxSize;
382
+ _data;
383
+ _metrics = { hits: 0, misses: 0 };
384
+ constructor(maxSize = 500) {
385
+ if (maxSize <= 0) {
386
+ throw new Error("LRU Cache capacity must be >= 1");
678
387
  }
679
- if (lock) {
680
- this._isLocked = true;
388
+ if (true) {
389
+ this._metrics = { hits: 0, misses: 0 };
681
390
  }
682
- const mutationResult = await mutator(this.snapshot());
683
- this._processIncomingState(mutationResult);
684
- if (lock) {
685
- this._isLocked = false;
391
+ this._maxSize = maxSize;
392
+ this._data = new Map;
393
+ }
394
+ _trim = () => {
395
+ while (this._data.size > this._maxSize) {
396
+ const firstKey = this._data.keys().next().value;
397
+ if (firstKey === undefined) {
398
+ throw new Error("Absurd");
399
+ }
400
+ this._data.delete(firstKey);
686
401
  }
687
- return this;
688
402
  };
689
- transaction = (fn) => {
690
- if (this._isLocked) {
691
- throw new PaletteError(305 /* STATE_LOCKED */);
403
+ getMetrics() {
404
+ if (true) {
405
+ const { hits = 0, misses = 0 } = this._metrics ?? {};
406
+ const lookups = hits + misses;
407
+ const hitRate = lookups === 0 ? 0 : hits / lookups;
408
+ return {
409
+ lookups,
410
+ hits,
411
+ misses,
412
+ capacity: this._maxSize,
413
+ entries: this._data.size,
414
+ hitRate
415
+ };
692
416
  }
693
- this._isLocked = true;
694
- let success = true;
695
- try {
696
- const transactionState = new State(this.snapshot());
697
- fn(transactionState);
698
- this._processIncomingState(transactionState.current);
699
- } catch (error) {
417
+ }
418
+ setCapacity = (maxSize) => {
419
+ if (maxSize <= 0 && true) {
420
+ console.warn("[Palette LRU Cache] Cache size is <= 0. Cache is disabled.");
421
+ }
422
+ this._maxSize = maxSize;
423
+ this._trim();
424
+ };
425
+ get(key) {
426
+ const value = this._data.get(key);
427
+ if (value === undefined) {
700
428
  if (true) {
701
- console.warn("[State] Transaction failed due to caught error", error);
429
+ this._metrics.misses += 1;
702
430
  }
703
- success = false;
704
- } finally {
705
- this._isLocked = false;
431
+ return;
706
432
  }
707
- return success;
708
- };
709
- transactionAsync = async (fn) => {
710
- if (this._isLocked) {
711
- throw new PaletteError(305 /* STATE_LOCKED */);
433
+ this._data.delete(key);
434
+ this._data.set(key, value);
435
+ if (true) {
436
+ this._metrics.hits += 1;
437
+ }
438
+ return value;
439
+ }
440
+ set(key, value) {
441
+ if (this._data.has(key)) {
442
+ this._data.delete(key);
443
+ }
444
+ this._data.set(key, value);
445
+ if (this._data.size > this._maxSize) {
446
+ this._trim();
447
+ }
448
+ }
449
+ clear() {
450
+ this._data.clear();
451
+ }
452
+ get size() {
453
+ return this._data.size;
454
+ }
455
+ }
456
+ var lru_cache_default = LRUCache;
457
+
458
+ // src/util/fragments.ts
459
+ var fragmentCache = new lru_cache_default;
460
+ function htmlToFragment(html) {
461
+ const lookup = fragmentCache.get(html);
462
+ if (lookup !== undefined) {
463
+ return lookup.cloneNode(true);
464
+ }
465
+ const temp = document.createElement("template");
466
+ temp.innerHTML = html;
467
+ fragmentCache.set(html, temp.content);
468
+ return temp.content.cloneNode(true);
469
+ }
470
+ function saveFragment(html, fragment) {
471
+ fragmentCache.set(html, fragment);
472
+ }
473
+
474
+ // src/util/attributes.ts
475
+ function serializeAttribute(value) {
476
+ if (typeof value === "string" || typeof value === "number") {
477
+ return `${value}`;
478
+ }
479
+ if (value === true) {
480
+ return "";
481
+ }
482
+ if (value === null || value === false || value === undefined) {
483
+ return null;
484
+ }
485
+ return value.toString();
486
+ }
487
+ function applyAttribute(element, name, value) {
488
+ if (value === null) {
489
+ element.removeAttribute(name);
490
+ } else {
491
+ element.setAttribute(name, value);
492
+ }
493
+ }
494
+ function getElementAttributes(source) {
495
+ const attrs = {};
496
+ for (const name of source.getAttributeNames()) {
497
+ attrs[name] = serializeAttribute(source.getAttribute(name));
498
+ }
499
+ return attrs;
500
+ }
501
+ function applyElementAttributes(target, attrs) {
502
+ const currentNames = new Set(target.getAttributeNames());
503
+ const incomingNames = new Set(Object.keys(attrs));
504
+ const attributesToRemove = currentNames.difference(incomingNames);
505
+ for (const attr of attributesToRemove) {
506
+ target.removeAttribute(attr);
507
+ }
508
+ for (const [name, val] of Object.entries(attrs)) {
509
+ applyAttribute(target, name, serializeAttribute(val));
510
+ }
511
+ }
512
+ function formatAttributeRecord(record) {
513
+ const out = {};
514
+ for (const [key, val] of Object.entries(record)) {
515
+ out[key] = serializeAttribute(val);
516
+ }
517
+ return out;
518
+ }
519
+ // src/util/element-match.ts
520
+ function isTagName(str) {
521
+ for (let i = 0;i < str.length; i++) {
522
+ const char = str.charAt(i);
523
+ if (!(char === "-" || char >= "A" && char <= "Z" || char >= "a" && char <= "z")) {
524
+ return false;
525
+ }
526
+ }
527
+ return true;
528
+ }
529
+ function elementMatches(element, query) {
530
+ if (query[0] === "#" && query.indexOf(" ") === -1 && query.indexOf(".") === -1 && query.indexOf("[") === -1 && query.indexOf(":") === -1 && query.indexOf(">") === -1) {
531
+ return element.id === query.slice(1);
532
+ }
533
+ if (query[0] === "." && query.indexOf(" ") === -1 && query.indexOf("#") === -1 && query.indexOf("[") === -1 && query.indexOf(":") === -1 && query.indexOf(">") === -1) {
534
+ return element.classList.contains(query.slice(1));
535
+ }
536
+ if (isTagName(query)) {
537
+ return element.tagName.toLowerCase() === query.toLowerCase();
538
+ }
539
+ if (query[0] === "[" && query[query.length - 1] === "]" && query.indexOf(" ") === -1 && query.indexOf(":") === -1) {
540
+ const attr = query.slice(1, -1);
541
+ const eqIndex = attr.indexOf("=");
542
+ if (eqIndex === -1) {
543
+ return element.hasAttribute(attr);
712
544
  }
713
- this._isLocked = true;
714
- let success = true;
715
- try {
716
- const transactionState = new State(this.snapshot());
717
- await fn(transactionState);
718
- this._processIncomingState(transactionState.current);
719
- } catch (error) {
720
- if (true) {
721
- console.warn("[State] Transaction failed due to caught error", error);
722
- }
723
- success = false;
724
- } finally {
725
- this._isLocked = false;
545
+ const attrName = attr.slice(0, eqIndex);
546
+ const attrValue = attr.slice(eqIndex + 1).replace(/^["']|["']$/g, "");
547
+ return element.getAttribute(attrName) === attrValue;
548
+ }
549
+ return element.matches(query);
550
+ }
551
+ // src/util/dom.ts
552
+ function walkParents(target, fn) {
553
+ let current = target.parentNode;
554
+ while (current !== null) {
555
+ const result = fn(current);
556
+ if (result) {
557
+ return true;
558
+ }
559
+ if (isShadowRoot(current)) {
560
+ current = current.host;
561
+ } else {
562
+ current = current.parentNode;
726
563
  }
727
- return success;
728
- };
564
+ }
565
+ return false;
566
+ }
567
+ function isElement(value) {
568
+ return value !== null && typeof value === "object" && value instanceof Element;
569
+ }
570
+ function isHTMLElement(value) {
571
+ return value !== null && typeof value === "object" && value instanceof HTMLElement;
729
572
  }
573
+ function isHTMLTemplateElement(value) {
574
+ return value !== null && typeof value === "object" && value instanceof HTMLTemplateElement;
575
+ }
576
+ function isShadowRoot(value) {
577
+ return value !== null && typeof value === "object" && value instanceof ShadowRoot;
578
+ }
579
+ function isNode(value) {
580
+ return value !== null && typeof value === "object" && value instanceof Node;
581
+ }
582
+ function isComment(value) {
583
+ return value !== null && typeof value === "object" && value instanceof Comment;
584
+ }
585
+
730
586
  // src/template/constant.ts
731
587
  var REF_ATTR = "data-node-ref";
732
588
 
@@ -815,8 +671,8 @@ function buildValueAccessor(notation) {
815
671
  }
816
672
 
817
673
  // src/template/util.ts
818
- function htmlStringToTemplate(html2) {
819
- const fragment = htmlToFragment(html2);
674
+ function htmlStringToTemplate(html) {
675
+ const fragment = htmlToFragment(html);
820
676
  const templateElement = document.createElement("template");
821
677
  templateElement.content.appendChild(fragment);
822
678
  return new Template(templateElement);
@@ -827,14 +683,14 @@ function collectOperableNodes(fragment) {
827
683
  const nodes = [];
828
684
  let currentNode = walker.nextNode();
829
685
  while (currentNode) {
830
- if (!(currentNode instanceof HTMLElement)) {
686
+ if (!isHTMLElement(currentNode)) {
831
687
  currentNode = walker.nextNode();
832
688
  continue;
833
689
  }
834
690
  let parent = currentNode.parentNode;
835
691
  let isInoperable = false;
836
692
  while (parent && !isInoperable) {
837
- if (knownIgnores.has(parent) || parent instanceof HTMLElement && (parent.hasAttribute("::each" /* Each */) || parent.hasAttribute("::if" /* If */) || parent.hasAttribute("::else" /* Else */) || parent.hasAttribute("::else-if" /* ElseIf */))) {
693
+ if (knownIgnores.has(parent) || isHTMLElement(parent) && (parent.hasAttribute("::each" /* Each */) || parent.hasAttribute("::if" /* If */) || parent.hasAttribute("::else" /* Else */) || parent.hasAttribute("::else-if" /* ElseIf */))) {
838
694
  isInoperable = true;
839
695
  knownIgnores.add(currentNode);
840
696
  break;
@@ -878,23 +734,14 @@ function compileTemplate(source) {
878
734
  const clonedTemplateElement = source.content.cloneNode(true);
879
735
  const nodes = collectOperableNodes(clonedTemplateElement);
880
736
  for (const node of nodes) {
881
- const attributes2 = createAttributeMap(node);
882
- for (const [attributeName, attributeValue] of attributes2) {
737
+ const allAttributesForNode = node.getAttributeNames();
738
+ for (const attributeName of allAttributesForNode) {
739
+ const attributeValue = node.getAttribute(attributeName);
883
740
  if (attributeValue === null || attributeName[0] !== ":") {
884
741
  continue;
885
742
  }
886
- if (attributeName[1] !== ":") {
887
- const bindName = attributeName.slice(1);
888
- const scheme = {
889
- type: "attr",
890
- notation: parseNotation(attributeValue),
891
- attribute: bindName,
892
- nodeRef: ensureNodeRef(node)
893
- };
894
- compiledSchemes.push(scheme);
895
- }
896
743
  if (attributeName === "::key" /* Key */) {
897
- if (!attributes2.has("::each" /* Each */)) {
744
+ if (!allAttributesForNode.includes("::each" /* Each */)) {
898
745
  throw new PaletteError(208 /* TEMPLATE_INVALID_KEY_DIRECTIVE */);
899
746
  }
900
747
  continue;
@@ -908,9 +755,18 @@ function compileTemplate(source) {
908
755
  parsedNotations.set(attributeValue, notation);
909
756
  }
910
757
  node.removeAttribute(attributeName);
911
- if (attributeName === "::tag" /* Tag */) {
758
+ if (attributeName[1] !== ":") {
759
+ const bindName = attributeName.slice(1);
760
+ const scheme = {
761
+ type: "attr" /* Attribute */,
762
+ notation: parseNotation(attributeValue),
763
+ attribute: bindName,
764
+ nodeRef: ensureNodeRef(node)
765
+ };
766
+ compiledSchemes.push(scheme);
767
+ } else if (attributeName === "::tag" /* Tag */) {
912
768
  compiledSchemes.push({
913
- type: "tag",
769
+ type: "tag" /* Tag */,
914
770
  notation,
915
771
  nodeRef: ensureNodeRef(node)
916
772
  });
@@ -926,7 +782,7 @@ function compileTemplate(source) {
926
782
  node.removeChild(node.firstChild);
927
783
  }
928
784
  const scheme = {
929
- type: "each",
785
+ type: "list" /* List */,
930
786
  notation,
931
787
  keyNotation: parseNotation(keyNotation),
932
788
  nodeRef,
@@ -935,14 +791,14 @@ function compileTemplate(source) {
935
791
  compiledSchemes.push(scheme);
936
792
  } else if (attributeName === "::swap" /* Swap */) {
937
793
  const scheme = {
938
- type: "swap",
794
+ type: "swap" /* Swap */,
939
795
  notation,
940
796
  nodeRef: ensureNodeRef(node)
941
797
  };
942
798
  compiledSchemes.push(scheme);
943
799
  } else if (attributeName === "::if" /* If */) {
944
800
  const scheme = {
945
- type: "cond",
801
+ type: "cond" /* Conditional */,
946
802
  branches: []
947
803
  };
948
804
  node.removeAttribute("::if" /* If */);
@@ -955,7 +811,7 @@ function compileTemplate(source) {
955
811
  scheme.branches.push(ifBranch);
956
812
  let condNode = node.nextElementSibling;
957
813
  while (condNode?.hasAttribute("::else-if" /* ElseIf */)) {
958
- if (!(condNode instanceof HTMLElement)) {
814
+ if (!isHTMLElement(condNode)) {
959
815
  break;
960
816
  }
961
817
  const baseElseIfNotation = condNode.getAttribute("::else-if" /* ElseIf */);
@@ -977,7 +833,7 @@ function compileTemplate(source) {
977
833
  scheme.branches.push(elseIfBranch);
978
834
  condNode = condNode.nextElementSibling;
979
835
  }
980
- if (condNode && condNode instanceof HTMLElement && condNode?.hasAttribute("::else" /* Else */)) {
836
+ if (condNode && isHTMLElement(condNode) && condNode?.hasAttribute("::else" /* Else */)) {
981
837
  condNode.removeAttribute("::else" /* Else */);
982
838
  const elseBranch = {
983
839
  type: "::else" /* Else */,
@@ -1003,17 +859,106 @@ function compileTemplate(source) {
1003
859
  }
1004
860
  const temp = document.createElement("div");
1005
861
  temp.appendChild(clonedTemplateElement.cloneNode(true));
1006
- const html2 = temp.innerHTML;
862
+ const html = temp.innerHTML;
1007
863
  const compiled = {
1008
- html: html2,
864
+ html,
1009
865
  schemes: compiledSchemes,
1010
866
  notations
1011
867
  };
1012
868
  compiledTemplateCache.set(source, compiled);
1013
- saveFragment(html2, clonedTemplateElement);
869
+ saveFragment(html, clonedTemplateElement);
1014
870
  return compiled;
1015
871
  }
1016
872
 
873
+ // src/helper/css.ts
874
+ function parseCSSTemplateStringValue(val) {
875
+ if (typeof val === "function") {
876
+ const tagName = val.tagName;
877
+ if (!isTagName(tagName)) {
878
+ throw new PaletteError(203 /* TEMPLATE_INVALID_COMPONENT */, val.name, val.tagName);
879
+ }
880
+ return tagName;
881
+ }
882
+ if (typeof val === "string") {
883
+ return val;
884
+ }
885
+ throw new PaletteError(200 /* TEMPLATE_INVALID_VALUE */, String(val));
886
+ }
887
+ function css(strings, ...values) {
888
+ let result = strings[0] ?? "";
889
+ for (let i = 0;i < values.length; i++) {
890
+ const nextVal = values[i] ?? "";
891
+ const nextStr = strings[i + 1] ?? "";
892
+ result += parseCSSTemplateStringValue(nextVal);
893
+ result += nextStr;
894
+ }
895
+ const sheet = new CSSStyleSheet;
896
+ sheet.replaceSync(result);
897
+ return sheet;
898
+ }
899
+ function classify(...args) {
900
+ let resultString = "";
901
+ for (let index = 0;index < args.length; index++) {
902
+ const argument = args[index];
903
+ if (!argument) {
904
+ continue;
905
+ }
906
+ if (typeof argument === "string" || typeof argument === "number") {
907
+ if (resultString) {
908
+ resultString += " ";
909
+ }
910
+ resultString += argument;
911
+ continue;
912
+ }
913
+ if (Array.isArray(argument)) {
914
+ const nestedResult = classify(...argument);
915
+ if (nestedResult) {
916
+ if (resultString) {
917
+ resultString += " ";
918
+ }
919
+ resultString += nestedResult;
920
+ }
921
+ continue;
922
+ }
923
+ if (typeof argument === "object") {
924
+ for (const className in argument) {
925
+ if (argument[className]) {
926
+ if (resultString) {
927
+ resultString += " ";
928
+ }
929
+ resultString += className;
930
+ }
931
+ }
932
+ }
933
+ }
934
+ return resultString;
935
+ }
936
+ // src/helper/html.ts
937
+ function parseTemplateStringValue(val) {
938
+ if (isHTMLTemplateElement(val)) {
939
+ return val.innerHTML;
940
+ }
941
+ if (Component.isComponentClass(val)) {
942
+ const tagName = val.tagName;
943
+ if (!isTagName(tagName)) {
944
+ throw new PaletteError(203 /* TEMPLATE_INVALID_COMPONENT */, val.name, val.tagName);
945
+ }
946
+ return tagName;
947
+ }
948
+ if (typeof val === "string") {
949
+ return `<span ::swap="${val}"></span>`;
950
+ }
951
+ throw new PaletteError(200 /* TEMPLATE_INVALID_VALUE */, String(val));
952
+ }
953
+ function html(strings, ...values) {
954
+ const fullString = strings.reduce((acc, str, i) => {
955
+ const parsedValue = values[i] ? `${parseTemplateStringValue(values[i])}` : "";
956
+ return acc + str + parsedValue;
957
+ }, "");
958
+ const templateElement = document.createElement("template");
959
+ templateElement.innerHTML = fullString;
960
+ return templateElement;
961
+ }
1017
962
  // src/template/jobs/common.ts
1018
963
  var SKIPPED_JOB = Symbol("noop");
1019
964
 
@@ -1033,11 +978,7 @@ function prepareAttributeJob(plan, values) {
1033
978
  }
1034
979
  function runAttributeJobs(jobs) {
1035
980
  for (const [node, name, value] of jobs) {
1036
- if (value === null) {
1037
- node.removeAttribute(name);
1038
- } else {
1039
- node.setAttribute(name, value);
1040
- }
981
+ applyAttribute(node, name, value);
1041
982
  }
1042
983
  }
1043
984
 
@@ -1069,7 +1010,7 @@ function runConditionalRenderJobs(jobs) {
1069
1010
  const nodesToRemove = new Set;
1070
1011
  let node = plan.start;
1071
1012
  while (node && node !== plan.end) {
1072
- if (node instanceof HTMLElement) {
1013
+ if (isHTMLElement(node)) {
1073
1014
  nodesToRemove.add(node);
1074
1015
  }
1075
1016
  node = node.nextSibling;
@@ -1104,7 +1045,7 @@ function collectHTMLElements(start, end) {
1104
1045
  let node = start;
1105
1046
  const nodeSet = new Set;
1106
1047
  while (node && node !== end) {
1107
- if (node instanceof HTMLElement) {
1048
+ if (isHTMLElement(node)) {
1108
1049
  nodeSet.add(node);
1109
1050
  }
1110
1051
  node = node.nextSibling;
@@ -1145,7 +1086,7 @@ function prepareListRenderJob(plan, values) {
1145
1086
  context,
1146
1087
  root: rowRoot,
1147
1088
  template: rowTemplate,
1148
- attrMap: createAttributeMap(item)
1089
+ attrs: formatAttributeRecord(item)
1149
1090
  };
1150
1091
  listRenderContexts.set(key, jobItem);
1151
1092
  }
@@ -1171,9 +1112,9 @@ function runListRenderJobs(jobs) {
1171
1112
  const rootsToKeep = new Set;
1172
1113
  let existingDOMNodeIdx = 0;
1173
1114
  for (const renderItem of renderItems) {
1174
- const { root, attrMap, context, template } = renderItem;
1115
+ const { root, attrs: attrMap, context, template } = renderItem;
1175
1116
  const existingDOMNode = existingDOMNodes[existingDOMNodeIdx];
1176
- applyAttributeMap(root, attrMap);
1117
+ applyElementAttributes(root, attrMap);
1177
1118
  template.render(root, context);
1178
1119
  rootsToKeep.add(root);
1179
1120
  if (Object.is(existingDOMNode, root)) {
@@ -1206,11 +1147,11 @@ function prepareContentSwapJob(plan, values) {
1206
1147
  }
1207
1148
  return [plan, document.createTextNode(asStr)];
1208
1149
  } else if (value === null || value === undefined) {
1209
- if (plan.node instanceof Comment) {
1150
+ if (isComment(plan.node)) {
1210
1151
  return SKIPPED_JOB;
1211
1152
  }
1212
1153
  return [plan, document.createComment("empty")];
1213
- } else if (value instanceof HTMLElement) {
1154
+ } else if (isHTMLElement(value)) {
1214
1155
  if (Object.is(plan.node, value)) {
1215
1156
  return SKIPPED_JOB;
1216
1157
  }
@@ -1272,35 +1213,35 @@ function createJobsFromPlans(plans, newValues) {
1272
1213
  };
1273
1214
  for (const plan of plans) {
1274
1215
  switch (plan.type) {
1275
- case "cond": {
1216
+ case "cond" /* Conditional */: {
1276
1217
  const job = prepareConditionalRenderJob(plan, newValues);
1277
1218
  if (job !== SKIPPED_JOB) {
1278
1219
  jobs.conditionals.push(job);
1279
1220
  }
1280
1221
  break;
1281
1222
  }
1282
- case "attr": {
1223
+ case "attr" /* Attribute */: {
1283
1224
  const job = prepareAttributeJob(plan, newValues);
1284
1225
  if (job !== SKIPPED_JOB) {
1285
1226
  jobs.attributes.push(job);
1286
1227
  }
1287
1228
  break;
1288
1229
  }
1289
- case "each": {
1230
+ case "list" /* List */: {
1290
1231
  const job = prepareListRenderJob(plan, newValues);
1291
1232
  if (job !== SKIPPED_JOB) {
1292
1233
  jobs.lists.push(job);
1293
1234
  }
1294
1235
  break;
1295
1236
  }
1296
- case "swap": {
1237
+ case "swap" /* Swap */: {
1297
1238
  const job = prepareContentSwapJob(plan, newValues);
1298
1239
  if (job !== SKIPPED_JOB) {
1299
1240
  jobs.swaps.push(job);
1300
1241
  }
1301
1242
  break;
1302
1243
  }
1303
- case "tag": {
1244
+ case "tag" /* Tag */: {
1304
1245
  const job = prepareTagChangeJob(plan, newValues);
1305
1246
  if (job !== SKIPPED_JOB) {
1306
1247
  jobs.tags.push(job);
@@ -1356,7 +1297,7 @@ function prepareCompiledTemplate(compiled, prototypeFragment) {
1356
1297
  });
1357
1298
  let markNode = walker.nextNode();
1358
1299
  while (markNode) {
1359
- if (!(markNode instanceof HTMLElement)) {
1300
+ if (!isHTMLElement(markNode)) {
1360
1301
  continue;
1361
1302
  }
1362
1303
  const ref = markNode.getAttribute(REF_ATTR);
@@ -1383,7 +1324,7 @@ function prepareCompiledTemplate(compiled, prototypeFragment) {
1383
1324
  throw new PaletteError(3 /* MISSING_NODE_REF */);
1384
1325
  };
1385
1326
  for (const scheme of compiled.schemes) {
1386
- if (scheme.type === "each") {
1327
+ if (scheme.type === "list" /* List */) {
1387
1328
  const itemPrototype = getByNodeRef(scheme.nodeRef);
1388
1329
  const listParentNode = requireParentNode(itemPrototype);
1389
1330
  const rowRootPrototype = itemPrototype.cloneNode(false);
@@ -1394,7 +1335,7 @@ function prepareCompiledTemplate(compiled, prototypeFragment) {
1394
1335
  const rowTemplateElement = document.createElement("template");
1395
1336
  rowTemplateElement.content.appendChild(templateContentFragment);
1396
1337
  const plan = {
1397
- type: "each",
1338
+ type: "list" /* List */,
1398
1339
  notation: scheme.notation,
1399
1340
  keyNotation: scheme.keyNotation,
1400
1341
  listContainer: listParentNode,
@@ -1406,7 +1347,7 @@ function prepareCompiledTemplate(compiled, prototypeFragment) {
1406
1347
  rowRootsByKey: new Map
1407
1348
  };
1408
1349
  associatePlan(plan, scheme.notation.base);
1409
- } else if (scheme.type === "cond") {
1350
+ } else if (scheme.type === "cond" /* Conditional */) {
1410
1351
  const firstBranch = scheme.branches[0];
1411
1352
  if (!firstBranch) {
1412
1353
  throw new PaletteError(0 /* INVARIANT */);
@@ -1417,7 +1358,7 @@ function prepareCompiledTemplate(compiled, prototypeFragment) {
1417
1358
  const lastBranchRoot = getByNodeRef(lastBranch.branchRootRef);
1418
1359
  const endComment = createCommentAfter(lastBranchRoot);
1419
1360
  const plan = {
1420
- type: "cond",
1361
+ type: "cond" /* Conditional */,
1421
1362
  start: startComment,
1422
1363
  end: endComment,
1423
1364
  branches: []
@@ -1443,16 +1384,16 @@ function prepareCompiledTemplate(compiled, prototypeFragment) {
1443
1384
  });
1444
1385
  }
1445
1386
  }
1446
- } else if (scheme.type === "swap" || scheme.type === "tag") {
1387
+ } else if (scheme.type === "swap" /* Swap */ || scheme.type === "tag" /* Tag */) {
1447
1388
  const plan = {
1448
1389
  type: scheme.type,
1449
1390
  notation: scheme.notation,
1450
1391
  node: getByNodeRef(scheme.nodeRef)
1451
1392
  };
1452
1393
  associatePlan(plan, scheme.notation.base);
1453
- } else if (scheme.type === "attr") {
1394
+ } else if (scheme.type === "attr" /* Attribute */) {
1454
1395
  const plan = {
1455
- type: "attr",
1396
+ type: "attr" /* Attribute */,
1456
1397
  attribute: scheme.attribute,
1457
1398
  notation: scheme.notation,
1458
1399
  node: getByNodeRef(scheme.nodeRef)
@@ -1470,6 +1411,9 @@ function prepareCompiledTemplate(compiled, prototypeFragment) {
1470
1411
 
1471
1412
  // src/template/template.ts
1472
1413
  class Template {
1414
+ static isTemplate(value) {
1415
+ return value !== null && typeof value === "object" && value instanceof Template;
1416
+ }
1473
1417
  static cache = {
1474
1418
  clear: () => {
1475
1419
  fragmentCache.clear();
@@ -1572,28 +1516,67 @@ class Template {
1572
1516
  this._latestRenderedValues = resolvedValues;
1573
1517
  };
1574
1518
  }
1575
- // src/component/delegator.ts
1576
- class EventDelegator {
1577
- static nextListenerId = 0;
1578
- static processTargetDescriptor(targetDescriptor) {
1579
- if (targetDescriptor instanceof HTMLElement) {
1580
- if (targetDescriptor.id.length) {
1581
- return `#${targetDescriptor.id}`;
1519
+ // src/task-scheduler.ts
1520
+ class TaskScheduler {
1521
+ _queues = {
1522
+ tasks: [],
1523
+ frames: []
1524
+ };
1525
+ _promises = {};
1526
+ _resolvers = {};
1527
+ _onError;
1528
+ constructor(onError) {
1529
+ this._onError = onError;
1530
+ }
1531
+ _flushQueue = (queueType) => {
1532
+ const queue = this._queues[queueType];
1533
+ try {
1534
+ while (queue.length) {
1535
+ const task = queue.shift();
1536
+ task?.();
1537
+ }
1538
+ } catch (error) {
1539
+ if (this._onError) {
1540
+ this._onError(error);
1582
1541
  } else {
1583
- const generatedId = `listen-${EventDelegator.nextListenerId++}`;
1584
- targetDescriptor.setAttribute("data-listener-id", generatedId);
1585
- return `[data-listener-id="${generatedId}"]`;
1542
+ throw error;
1586
1543
  }
1587
- } else if (typeof targetDescriptor === "function") {
1588
- if (true) {
1589
- if (targetDescriptor.tagName.length === 0) {
1590
- console.warn(`[Component] Automatic listener setup failure: Component ${targetDescriptor.name} has no defined tagname`);
1591
- }
1544
+ } finally {
1545
+ this._resolvers[queueType]?.();
1546
+ this._resolvers[queueType] = undefined;
1547
+ this._promises[queueType] = undefined;
1548
+ }
1549
+ };
1550
+ _schedule = (type, task, prioritize = false) => {
1551
+ const queue = this._queues[type];
1552
+ if (prioritize) {
1553
+ queue.unshift(task);
1554
+ } else {
1555
+ queue.push(task);
1556
+ }
1557
+ if (!this._promises[type]) {
1558
+ this._promises[type] = new Promise((resolve) => {
1559
+ this._resolvers[type] = resolve;
1560
+ });
1561
+ if (type === "frames") {
1562
+ requestAnimationFrame(this._flushQueue.bind(this, "frames"));
1563
+ } else {
1564
+ queueMicrotask(this._flushQueue.bind(this, "tasks"));
1592
1565
  }
1593
- return targetDescriptor.tagName;
1594
1566
  }
1595
- return targetDescriptor;
1596
- }
1567
+ return this._promises[type];
1568
+ };
1569
+ scheduleMicrotask = (task, prioritize = false) => {
1570
+ return this._schedule("tasks", task, prioritize);
1571
+ };
1572
+ scheduleFrameTask = (task, prioritize = false) => {
1573
+ return this._schedule("frames", task, prioritize);
1574
+ };
1575
+ }
1576
+ var asyncTasks = new TaskScheduler;
1577
+
1578
+ // src/component/delegator.ts
1579
+ class EventDelegator {
1597
1580
  _root;
1598
1581
  _rootListeners = new Map;
1599
1582
  _events = new Map;
@@ -1624,7 +1607,7 @@ class EventDelegator {
1624
1607
  const listener = (event) => {
1625
1608
  const handlersForEvent = this._handlersForEvent(eventName);
1626
1609
  const { target } = event;
1627
- if (target === null || !(target instanceof Node)) {
1610
+ if (target === null || !isNode(target)) {
1628
1611
  return;
1629
1612
  }
1630
1613
  let node = target;
@@ -1638,7 +1621,7 @@ class EventDelegator {
1638
1621
  if (node === this._root) {
1639
1622
  break;
1640
1623
  }
1641
- if (!(node instanceof Element)) {
1624
+ if (!isElement(node)) {
1642
1625
  node = node.parentNode;
1643
1626
  continue;
1644
1627
  }
@@ -1656,7 +1639,7 @@ class EventDelegator {
1656
1639
  return;
1657
1640
  }
1658
1641
  node = node.parentNode;
1659
- if (node === this._root || node instanceof ShadowRoot) {
1642
+ if (node === this._root || isShadowRoot(node)) {
1660
1643
  break;
1661
1644
  }
1662
1645
  }
@@ -1687,6 +1670,7 @@ class EventDelegator {
1687
1670
  // src/component/component.ts
1688
1671
  var MAX_SEQUENTIAL_RENDERS = 1e4;
1689
1672
  var BLANK_TEMPLATE = document.createElement("template");
1673
+ var HOST_TARGET = ":host";
1690
1674
  var RootMode;
1691
1675
  ((RootMode2) => {
1692
1676
  RootMode2["Closed"] = "closed";
@@ -1694,212 +1678,161 @@ var RootMode;
1694
1678
  })(RootMode ||= {});
1695
1679
 
1696
1680
  class Component extends HTMLElement {
1681
+ static isComponent(value) {
1682
+ return typeof value === "object" && value !== null && value instanceof Component;
1683
+ }
1684
+ static isComponentClass(value) {
1685
+ return value !== null && typeof value === "function" && (value.prototype instanceof Component || value === Component);
1686
+ }
1687
+ static readComponentTagName(componentClass) {
1688
+ const { tagName } = componentClass;
1689
+ if (true) {
1690
+ if (tagName === "") {
1691
+ console.warn(`[Component] Empty tag name when reading from component ${componentClass.name}`);
1692
+ }
1693
+ }
1694
+ return tagName;
1695
+ }
1697
1696
  static tagName = "";
1698
1697
  static template = BLANK_TEMPLATE;
1699
- static styles = [];
1698
+ static style = [];
1700
1699
  static observedAttributes = [];
1701
1700
  static rootMode = "closed" /* Closed */;
1702
- initialState;
1703
- computedProperties;
1704
- liveAttributes;
1705
- _template;
1706
- _root;
1707
- _state;
1708
- _delegator;
1709
- _ownListeners = new Set;
1710
- _cleanupFn;
1711
- _renderInternals = {
1701
+ root;
1702
+ template;
1703
+ _cmp = {
1712
1704
  isFinalized: false,
1713
- initialRenderComplete: false,
1714
- willRender: false,
1705
+ isInitialRenderComplete: false,
1706
+ isRenderScheduled: false,
1715
1707
  isRendering: false,
1716
- sequentialRenders: 0,
1717
- postRenderCallbacks: [],
1718
- lastRenderedAttributeMap: new Map,
1719
- trackedAttributeChanges: new Map
1708
+ sequentialRenderCount: 0,
1709
+ lastRenderedAttributes: {},
1710
+ pendingAttributeChanges: {}
1720
1711
  };
1721
1712
  constructor() {
1722
1713
  super();
1723
- const { template: template2, styles, rootMode } = this.constructor;
1724
- const newStyles = Array.isArray(styles) ? styles : typeof styles === "object" ? [styles] : [css`${styles}`];
1725
- this._root = this.attachShadow({ mode: rootMode });
1726
- this._root.adoptedStyleSheets.push(...newStyles);
1727
- this._template = template2 instanceof Template ? template2 : new Template(template2);
1714
+ const {
1715
+ template: template2,
1716
+ style,
1717
+ rootMode: mode
1718
+ } = this.constructor;
1719
+ this.root = this.attachShadow({ mode });
1720
+ let adoptStyles = [];
1721
+ if (Array.isArray(style)) {
1722
+ adoptStyles = style;
1723
+ } else if (style instanceof CSSStyleSheet) {
1724
+ adoptStyles = [style];
1725
+ } else {
1726
+ const adoptSheet = new CSSStyleSheet;
1727
+ adoptSheet.replaceSync(style);
1728
+ adoptStyles = [adoptSheet];
1729
+ }
1730
+ this.root.adoptedStyleSheets.push(...adoptStyles);
1731
+ this.template = Template.isTemplate(template2) ? template2 : new Template(template2);
1728
1732
  }
1729
1733
  _getRenderContext(attr) {
1734
+ const state = this._cmp.state?.raw ?? {};
1735
+ const computed = this.computedProperties?.call(this, attr, state);
1730
1736
  return {
1731
- attr: Object.fromEntries(attr),
1732
- data: typeof this.computedProperties === "function" ? this.computedProperties() : this.computedProperties,
1733
- state: this._state ? this._state.current : undefined
1737
+ attr,
1738
+ data: computed,
1739
+ state
1734
1740
  };
1735
1741
  }
1736
1742
  _escalateError(error) {
1737
- let node = this.parentNode;
1738
- while (node) {
1739
- if (node instanceof Component && "onError" in node && typeof node.onError === "function") {
1743
+ const isErrorHandled = walkParents(this, (node) => {
1744
+ if (node instanceof Component && node.onError) {
1740
1745
  node.onError(error);
1741
- return;
1742
- } else if (node instanceof ShadowRoot) {
1743
- node = node.host;
1744
- } else {
1745
- node = node.parentNode;
1746
+ return true;
1746
1747
  }
1748
+ });
1749
+ if (!isErrorHandled) {
1750
+ throw error;
1747
1751
  }
1748
- throw error;
1749
1752
  }
1750
1753
  _reportError(error) {
1751
- if (!this.onError) {
1752
- this._escalateError(error);
1753
- } else {
1754
- this.onError(error);
1755
- }
1754
+ this.onError ? this.onError(error) : this._escalateError(error);
1756
1755
  }
1757
- _executeAttributeChangeHandlers = () => {
1758
- if (!this.liveAttributes) {
1759
- return;
1760
- }
1761
- const prevAttrs = this._renderInternals.lastRenderedAttributeMap;
1762
- const trackedChanges = new Map(this._renderInternals.trackedAttributeChanges);
1763
- this._renderInternals.trackedAttributeChanges.clear();
1764
- for (const [name, val] of trackedChanges) {
1765
- const config = this.liveAttributes[name];
1766
- if (!config) {
1767
- continue;
1768
- }
1769
- if ("onChange" in config) {
1770
- const previousValue = prevAttrs.get(name) ?? null;
1771
- if (config && previousValue !== val) {
1772
- config.onChange?.call(this, val, previousValue);
1773
- }
1774
- }
1775
- }
1776
- };
1777
- _reflectLiveAttributes = () => {
1778
- if (!this.liveAttributes) {
1779
- return;
1780
- }
1781
- const toSet = [];
1782
- for (const [name, config] of Object.entries(this.liveAttributes)) {
1783
- if ("reflect" in config) {
1784
- const val = serializeAttribute(config.reflect?.call(this));
1785
- const current = this.getAttribute(name);
1786
- if (val !== current) {
1787
- toSet.push([name, val]);
1788
- }
1789
- }
1790
- }
1791
- for (const [name, val] of toSet) {
1792
- this.reflectAttribute(name, val);
1793
- }
1794
- };
1795
- _performUpdate = () => {
1756
+ _render = () => {
1796
1757
  try {
1797
- this._renderInternals.isRendering = true;
1798
- this._renderInternals.willRender = false;
1799
- this._executeAttributeChangeHandlers();
1800
- const prevAttrs = this._renderInternals.lastRenderedAttributeMap;
1801
- this.beforeUpdate?.();
1802
- const newAttributes = createAttributeMap(this);
1803
- this._template.render(this.root, this._getRenderContext(newAttributes));
1804
- this._renderInternals.lastRenderedAttributeMap = newAttributes;
1758
+ this._cmp.isRendering = true;
1759
+ this._cmp.isRenderScheduled = false;
1760
+ const prevAttrs = this._cmp.lastRenderedAttributes;
1761
+ this.beforeUpdate?.(this._cmp.pendingAttributeChanges);
1762
+ const newAttributes = getElementAttributes(this);
1763
+ this.template.render(this.root, this._getRenderContext(newAttributes));
1764
+ this._cmp.lastRenderedAttributes = newAttributes;
1805
1765
  this.afterUpdate?.(prevAttrs);
1806
- this._reflectLiveAttributes();
1807
- if (this._renderInternals.postRenderCallbacks.length) {
1808
- const callbacks = this._renderInternals.postRenderCallbacks;
1809
- this._renderInternals.postRenderCallbacks = [];
1810
- for (const fn of callbacks) {
1811
- fn();
1812
- }
1813
- }
1814
- if (this._renderInternals.willRender) {
1815
- this._renderInternals.sequentialRenders += 1;
1816
- if (this._renderInternals.sequentialRenders >= MAX_SEQUENTIAL_RENDERS) {
1817
- throw new PaletteError(306 /* MAX_SEQUENTIAL_RENDERS */, `${this._renderInternals.sequentialRenders}`);
1766
+ if (this._cmp.isRenderScheduled) {
1767
+ this._cmp.sequentialRenderCount += 1;
1768
+ if (this._cmp.sequentialRenderCount >= MAX_SEQUENTIAL_RENDERS) {
1769
+ throw new PaletteError(306 /* MAX_SEQUENTIAL_RENDERS */, `${this._cmp.sequentialRenderCount}`);
1818
1770
  }
1819
- this._performUpdate();
1771
+ this._render();
1820
1772
  } else {
1821
- this._renderInternals.sequentialRenders = 0;
1773
+ this._cmp.sequentialRenderCount = 0;
1822
1774
  }
1823
1775
  } catch (error) {
1824
- this._renderInternals.willRender = false;
1776
+ this._cmp.isRenderScheduled = false;
1825
1777
  this._reportError(error);
1826
1778
  } finally {
1827
- this._renderInternals.isRendering = false;
1828
- }
1829
- };
1830
- _scheduleUpdate = () => {
1831
- if (this._renderInternals.willRender) {
1832
- return;
1779
+ this._cmp.isRendering = false;
1833
1780
  }
1834
- this._renderInternals.willRender = true;
1835
- if (this._renderInternals.isRendering) {
1836
- return;
1837
- }
1838
- requestAnimationFrame(this._performUpdate);
1839
1781
  };
1840
1782
  _adoptState(state) {
1841
- if (Object.is(this._state, state)) {
1783
+ if (Object.is(this._cmp.state, state)) {
1842
1784
  return;
1843
1785
  }
1844
- if (this._state) {
1845
- this._state.removeListener(this._scheduleUpdate);
1846
- this._scheduleUpdate();
1786
+ if (this._cmp.state) {
1787
+ this._cmp.state.removeListener(this.render);
1788
+ this.render();
1847
1789
  }
1848
- const incomingStateObj = state instanceof State ? state : new State(state);
1849
- this._state = incomingStateObj;
1850
- this._state.removeListener(this._scheduleUpdate);
1851
- this._state.addListener(this._scheduleUpdate);
1790
+ const incomingStateObj = State.isState(state) ? state : new State(state);
1791
+ this._cmp.state = incomingStateObj;
1792
+ this._cmp.state.removeListener(this.render);
1793
+ this._cmp.state.addListener(this.render);
1852
1794
  }
1853
1795
  connectedCallback() {
1854
- if (this._renderInternals.initialRenderComplete) {
1796
+ if (this._cmp.isInitialRenderComplete) {
1855
1797
  return;
1856
1798
  }
1857
- if (true) {
1858
- const liveAttributes = new Set(Object.keys(this.liveAttributes ?? {}));
1859
- const observedAttributes = new Set(this.constructor.observedAttributes);
1860
- if (!observedAttributes.isSupersetOf(liveAttributes)) {
1861
- const componentName = this.constructor.name;
1862
- console.warn(`[Component] Component ${componentName} has defined Live Attributes ` + `which are not listed in the Observed Attributes list. As such, ` + `they may not function properly. Be sure to set the static ` + `observedAttributes property on your Component, or use the ` + `define() helper to automatically ensure the correct configuration`);
1863
- }
1864
- }
1865
- queueMicrotask(() => {
1799
+ asyncTasks.scheduleMicrotask(() => {
1866
1800
  try {
1867
- this._renderInternals.isRendering = true;
1868
- this._renderInternals.willRender = false;
1869
- const attributes2 = createAttributeMap(this);
1801
+ this._cmp.isRendering = true;
1802
+ this._cmp.isRenderScheduled = false;
1803
+ const attributes2 = getElementAttributes(this);
1870
1804
  if (this.initialState) {
1871
- const init = typeof this.initialState === "object" ? this.initialState : this.initialState();
1872
- this._adoptState(init);
1805
+ this._adoptState(this.initialState());
1873
1806
  }
1874
- this._template.render(this.root, this._getRenderContext(attributes2));
1875
- this._reflectLiveAttributes();
1876
- this._renderInternals.lastRenderedAttributeMap = attributes2;
1877
- this._renderInternals.initialRenderComplete = true;
1878
- this._cleanupFn = this.script?.() ?? undefined;
1807
+ this.template.render(this.root, this._getRenderContext(attributes2));
1808
+ this._cmp.lastRenderedAttributes = attributes2;
1809
+ this._cmp.isInitialRenderComplete = true;
1810
+ this._cmp.cleanupFn = this.script?.() ?? undefined;
1879
1811
  } catch (error) {
1880
1812
  this._reportError(error);
1881
1813
  } finally {
1882
- this._renderInternals.isRendering = false;
1814
+ this._cmp.isRendering = false;
1883
1815
  }
1884
1816
  });
1885
1817
  }
1886
1818
  disconnectedCallback() {
1887
- if (this._renderInternals.isFinalized) {
1819
+ if (this._cmp.isFinalized) {
1888
1820
  return;
1889
1821
  }
1890
- queueMicrotask(() => {
1891
- if (this.isConnected || !this._renderInternals.initialRenderComplete) {
1822
+ asyncTasks.scheduleMicrotask(() => {
1823
+ if (this.isConnected || !this._cmp.isInitialRenderComplete) {
1892
1824
  return;
1893
1825
  }
1894
- this._renderInternals.isFinalized = true;
1826
+ this._cmp.isFinalized = true;
1895
1827
  try {
1896
- this._delegator?.cleanup();
1897
- if (this._ownListeners && this._ownListeners.size > 0) {
1898
- for (const listener of this._ownListeners) {
1828
+ const { delegator, cleanupFn, hostListeners } = this._cmp;
1829
+ delegator?.cleanup();
1830
+ if (hostListeners && hostListeners.size > 0) {
1831
+ for (const listener of hostListeners) {
1899
1832
  this.removeEventListener(listener.event, listener.handler);
1900
1833
  }
1901
1834
  }
1902
- this._cleanupFn?.();
1835
+ cleanupFn?.();
1903
1836
  } catch (error) {
1904
1837
  this._reportError(error);
1905
1838
  } finally {
@@ -1912,148 +1845,90 @@ class Component extends HTMLElement {
1912
1845
  });
1913
1846
  }
1914
1847
  attributeChangedCallback(name, _, newValue) {
1915
- if (this._renderInternals.isRendering) {
1916
- return;
1917
- }
1918
- if (newValue === this._renderInternals.lastRenderedAttributeMap?.get(name)) {
1848
+ if (this._cmp.isRendering) {
1919
1849
  return;
1920
1850
  }
1921
- this._renderInternals.trackedAttributeChanges.set(name, newValue);
1922
- if (!this._renderInternals.willRender) {
1923
- this._scheduleUpdate();
1851
+ this._cmp.pendingAttributeChanges[name] = newValue;
1852
+ if (!this._cmp.isRenderScheduled) {
1853
+ this.render();
1924
1854
  }
1925
1855
  }
1926
- get root() {
1927
- return this._root;
1928
- }
1929
1856
  get isMounted() {
1930
- return this.isConnected && this._renderInternals.initialRenderComplete;
1857
+ return this.isConnected && this._cmp.isInitialRenderComplete;
1931
1858
  }
1932
- get state() {
1933
- if (!this._state) {
1859
+ getState() {
1860
+ if (!this._cmp.state) {
1934
1861
  throw new PaletteError(301 /* MISSING_STATE */);
1935
1862
  }
1936
- return this._state.live;
1863
+ return this._cmp.state;
1864
+ }
1865
+ get state() {
1866
+ return this.getState().live;
1937
1867
  }
1938
1868
  set state(newState) {
1939
1869
  this._adoptState(newState);
1940
1870
  }
1941
- getState() {
1942
- if (!this._state) {
1943
- throw new PaletteError(301 /* MISSING_STATE */);
1871
+ render = () => {
1872
+ if (this._cmp.isRenderScheduled) {
1873
+ return;
1944
1874
  }
1945
- return this._state;
1946
- }
1947
- requestRender(callback) {
1948
- if (callback) {
1949
- this._renderInternals.postRenderCallbacks.push(callback);
1875
+ this._cmp.isRenderScheduled = true;
1876
+ if (this._cmp.isRendering) {
1877
+ return;
1950
1878
  }
1951
- this._scheduleUpdate();
1952
- }
1879
+ asyncTasks.scheduleFrameTask(this._render);
1880
+ };
1953
1881
  listen(targetDescriptor, eventName, eventHandler) {
1954
- const query = EventDelegator.processTargetDescriptor(targetDescriptor);
1955
- if (query === ":host" || query === ":HOST") {
1956
- if (this._ownListeners === undefined) {
1957
- this._ownListeners = new Set;
1958
- }
1882
+ if (targetDescriptor === HOST_TARGET || targetDescriptor === this) {
1883
+ if (!this._cmp.hostListeners) {
1884
+ this._cmp.hostListeners = new Set;
1885
+ }
1886
+ const hostListeners = this._cmp.hostListeners;
1887
+ const entry = {
1888
+ event: eventName,
1889
+ handler: eventHandler
1890
+ };
1891
+ hostListeners.add(entry);
1959
1892
  this.addEventListener(eventName, eventHandler);
1960
- this._ownListeners.add({
1961
- handler: eventHandler,
1962
- event: eventName
1963
- });
1964
- return;
1965
- }
1966
- if (!this._delegator) {
1967
- this._delegator = new EventDelegator(this.root);
1968
- }
1969
- this._delegator.addListener(eventName, eventHandler, query);
1970
- }
1971
- stopListening(targetDescriptor, eventName, eventHandler) {
1972
- const query = EventDelegator.processTargetDescriptor(targetDescriptor);
1973
- if (query === ":host" || query === ":HOST") {
1974
- if (this._ownListeners === undefined) {
1975
- this._ownListeners = new Set;
1976
- }
1977
- this.removeEventListener(eventName, eventHandler);
1978
- for (const listener of this._ownListeners) {
1979
- if (listener.event === eventName && listener.handler === eventHandler) {
1980
- this._ownListeners.delete(listener);
1981
- }
1982
- }
1983
- return;
1893
+ return () => {
1894
+ this.removeEventListener(eventName, eventHandler);
1895
+ hostListeners.delete(entry);
1896
+ };
1984
1897
  }
1985
- if (!this._delegator) {
1986
- return;
1898
+ if (typeof targetDescriptor === "object") {
1899
+ throw new PaletteError(2 /* INVALID_CALLSITE */);
1987
1900
  }
1988
- this._delegator.removeListener(eventName, eventHandler, query);
1989
- }
1990
- dispatchEvent(event, detail, options) {
1991
- if (event instanceof Event) {
1992
- return super.dispatchEvent(event);
1901
+ if (!this._cmp.delegator) {
1902
+ this._cmp.delegator = new EventDelegator(this.root);
1993
1903
  }
1994
- const opts = {
1995
- bubbles: true,
1996
- cancelable: true,
1997
- composed: true,
1998
- ...options ?? {}
1904
+ const delegator = this._cmp.delegator;
1905
+ const query = typeof targetDescriptor === "string" ? targetDescriptor : Component.readComponentTagName(targetDescriptor);
1906
+ delegator.addListener(eventName, eventHandler, query);
1907
+ return () => {
1908
+ delegator.removeListener(eventName, eventHandler, query);
1999
1909
  };
2000
- return super.dispatchEvent(new CustomEvent(event, {
2001
- detail,
2002
- ...opts
2003
- }));
2004
- }
2005
- querySelector(query) {
2006
- return this._root.querySelector(query);
2007
1910
  }
2008
- querySelectorAll(query) {
2009
- return this._root.querySelectorAll(query);
2010
- }
2011
- getElementById(id) {
2012
- if (this._root instanceof ShadowRoot) {
2013
- return this._root.getElementById(id);
1911
+ dispatchEvent(a, b) {
1912
+ if (typeof a === "object" && typeof b === "undefined") {
1913
+ return super.dispatchEvent(a);
1914
+ } else if (typeof a === "string") {
1915
+ return super.dispatchEvent(new CustomEvent(a, {
1916
+ bubbles: true,
1917
+ cancelable: true,
1918
+ composed: true,
1919
+ ...b
1920
+ }));
2014
1921
  } else {
2015
- return HTMLElement.prototype.querySelector.call(this, `#${id}`);
1922
+ throw new PaletteError(2 /* INVALID_CALLSITE */);
2016
1923
  }
2017
1924
  }
2018
- requireElementById(id) {
2019
- const lookup = this.getElementById(id);
1925
+ ref(id) {
1926
+ const lookup = this.root.getElementById(id);
2020
1927
  if (!lookup) {
2021
1928
  throw new PaletteError(300 /* MISSING_ELEMENT */);
2022
1929
  }
2023
1930
  return lookup;
2024
1931
  }
2025
- setAttribute(name, value) {
2026
- const serialized = serializeAttribute(value);
2027
- if (serialized === null) {
2028
- HTMLElement.prototype.removeAttribute.call(this, name);
2029
- } else {
2030
- HTMLElement.prototype.setAttribute.call(this, name, serialized);
2031
- }
2032
- }
2033
- getAttribute(name, defaultValue) {
2034
- const value = HTMLElement.prototype.getAttribute.call(this, name);
2035
- if (defaultValue === undefined) {
2036
- return value;
2037
- }
2038
- if (typeof defaultValue === "number") {
2039
- if (value === null) {
2040
- return defaultValue;
2041
- }
2042
- const parsed = Number(value);
2043
- if (Number.isNaN(parsed)) {
2044
- return defaultValue;
2045
- }
2046
- return parsed;
2047
- }
2048
- throw new PaletteError(2 /* INVALID_CALLSITE */);
2049
- }
2050
- reflectAttribute(name, value) {
2051
- const current = this.getAttribute(name);
2052
- const reflected = serializeAttribute(value);
2053
- if (current !== reflected) {
2054
- this.setAttribute(name, reflected);
2055
- }
2056
- }
2057
1932
  toString() {
2058
1933
  const { tagName, name } = this.constructor;
2059
1934
  const computedName = tagName === "" ? name : tagName;
@@ -2106,44 +1981,35 @@ function define(a, b) {
2106
1981
  }
2107
1982
  const {
2108
1983
  template: template2 = BLANK_TEMPLATE2,
2109
- styles = [],
2110
- shadowRootMode = "closed",
2111
- initialState,
2112
- computedProperties = {},
2113
- liveAttributes = {},
1984
+ style = [],
1985
+ rootMode = "closed" /* Closed */,
1986
+ initialState: stateInitializer,
1987
+ computedProperties,
1988
+ observedAttributes = [],
2114
1989
  script,
2115
1990
  beforeUpdate,
2116
1991
  afterUpdate,
2117
1992
  finalize,
2118
1993
  onError
2119
1994
  } = definition;
2120
- const fullObservedAttributes = Array.from(new Set([...Object.keys(liveAttributes)]));
1995
+ let getInitialState;
1996
+ if (stateInitializer) {
1997
+ getInitialState = typeof stateInitializer === "function" ? stateInitializer : () => stateInitializer;
1998
+ }
2121
1999
  const cls = class extends Component {
2122
2000
  static tagName = tagName;
2123
2001
  static template = template2;
2124
- static styles = styles;
2125
- static observedAttributes = [...fullObservedAttributes];
2126
- static shadowRootMode = shadowRootMode;
2127
- constructor() {
2128
- super();
2129
- this.initialState = typeof initialState === "function" ? initialState.bind(this) : initialState;
2130
- this.computedProperties = typeof computedProperties === "function" ? computedProperties.bind(this) : computedProperties;
2131
- this.liveAttributes = liveAttributes;
2132
- for (const def of Object.values(this.liveAttributes)) {
2133
- if (def.onChange) {
2134
- def.onChange = def.onChange.bind(this);
2135
- }
2136
- if (def.reflect) {
2137
- def.reflect = def.reflect.bind(this);
2138
- }
2139
- }
2140
- this.script = script?.bind(this) ?? undefined;
2141
- this.beforeUpdate = beforeUpdate?.bind(this) ?? undefined;
2142
- this.afterUpdate = afterUpdate?.bind(this) ?? undefined;
2143
- this.finalize = finalize?.bind(this) ?? undefined;
2144
- this.onError = onError?.bind(this) ?? undefined;
2145
- }
2002
+ static style = style;
2003
+ static observedAttributes = [...observedAttributes];
2004
+ static shadowRootMode = rootMode;
2146
2005
  };
2006
+ cls.prototype.initialState = getInitialState;
2007
+ cls.prototype.computedProperties = computedProperties;
2008
+ cls.prototype.script = script;
2009
+ cls.prototype.beforeUpdate = beforeUpdate;
2010
+ cls.prototype.afterUpdate = afterUpdate;
2011
+ cls.prototype.finalize = finalize;
2012
+ cls.prototype.onError = onError;
2147
2013
  customElements.define(tagName, cls);
2148
2014
  return cls;
2149
2015
  }
@@ -2151,10 +2017,10 @@ function define(a, b) {
2151
2017
  if (typeof window !== "undefined") {
2152
2018
  window.__PALETTE_DEVTOOLS__ = {
2153
2019
  dumpCacheMetrics: () => {
2154
- console.log("Compiled Templates Cache", compiledTemplateCache.getMetrics());
2155
- console.log("HTML Fragments Cache", fragmentCache.getMetrics());
2156
- console.log("Notation Accessor Cache", valueAccessorCache.getMetrics());
2157
- console.log("Parsed Notations Cache", parsedNotationCache.getMetrics());
2020
+ console.log("Compiled Templates", compiledTemplateCache.getMetrics());
2021
+ console.log("HTML Fragments", fragmentCache.getMetrics());
2022
+ console.log("Notation Accessor", valueAccessorCache.getMetrics());
2023
+ console.log("Parsed Notations", parsedNotationCache.getMetrics());
2158
2024
  }
2159
2025
  };
2160
2026
  }
@@ -2170,5 +2036,5 @@ export {
2170
2036
  Component
2171
2037
  };
2172
2038
 
2173
- //# debugId=86B5A91FBB0A820D64756E2164756E21
2174
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/errors.ts", "src/util/attributes.ts", "src/util/element-match.ts", "src/util/lru-cache.ts", "src/util/fragments.ts", "src/helper/css.ts", "src/helper/html.ts", "src/state/state.ts", "src/template/constant.ts", "src/template/syntax.ts", "src/template/util.ts", "src/template/compile.ts", "src/template/jobs/common.ts", "src/template/jobs/attribute.ts", "src/template/jobs/conditional.ts", "src/template/jobs/list.ts", "src/template/jobs/swap.ts", "src/template/jobs/tag.ts", "src/template/jobs/index.ts", "src/template/prepare.ts", "src/template/template.ts", "src/component/delegator.ts", "src/component/component.ts", "src/component/factory.ts", "src/devtools.ts"],
  "sourcesContent": [
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n/**\n * Possible error types for {@link PaletteError}\n *\n * Codes are categorized into groups by the 100's:\n *\n * - 0 - 99: Invariants\n * - 100 - 199: Custom Elements / Environment Errors\n * - 200 - 299: Templating Errors\n * - 300 - 399: Runtime Errors\n */\nexport const enum ErrorCode {\n  // 0 - 99: Invariants\n  INVARIANT = 0,\n  INVALID_ENV = 1,\n  INVALID_CALLSITE = 2,\n  MISSING_NODE_REF = 3,\n\n  // 100 - 199: Custom Elements Errors\n  INVALID_TAGNAME = 100,\n\n  // 200 - 299: Template Errors\n  TEMPLATE_INVALID_VALUE = 200,\n  TEMPLATE_INVALID_NOTATION_SYNTAX = 201,\n  TEMPLATE_MISSING_NOTATION = 202,\n  TEMPLATE_INVALID_COMPONENT = 203,\n  TEMPLATE_INVALID_LIST_DATA = 204,\n  TEMPLATE_MISSING_LIST_KEY = 205,\n  TEMPLATE_DUPLICATE_LIST_KEY = 206,\n  TEMPLATE_INVALID_CONDITIONAL = 207,\n  TEMPLATE_INVALID_KEY_DIRECTIVE = 208,\n  TEMPLATE_PARENT_REQUIRED = 209,\n\n  // 300 - 399: Runtime Errors\n  MISSING_ELEMENT = 300,\n  MISSING_STATE = 301,\n  INVALID_CONTENT = 302,\n  INVALID_STATE_KEY = 303,\n  INVALID_STATE_UPDATE = 304,\n  STATE_LOCKED = 305,\n  MAX_SEQUENTIAL_RENDERS = 306,\n}\n\nfunction getDevError(code: ErrorCode) {\n  const DEV_ERROR_INFO: Record<ErrorCode, string> = {\n    [ErrorCode.INVARIANT]: `\nINVARIANT\nA condition has occurred which should never happen, such as a code path that\nshouldn't be reachable when using correct types, or a disallowed state.\n`,\n\n    [ErrorCode.INVALID_ENV]: `\nINVALID_ENV\nFailed to find a custom elements registry in this environment. Is a window\nglobal available with a customElements property?\n`,\n    [ErrorCode.INVALID_CALLSITE]: `\nINVALID_CALLSITE\nA function was invoked with an invalid set of parameters.   \n`,\n\n    [ErrorCode.INVALID_TAGNAME]: `\nINVALID_TAGNAME\nFailed to determine a valid HTML Tag to use when registering a component as a\ncustom element. Specify a static readonly tagName property on your component\nclass or provide a tagName argument to Component.register.\n\nAlternatively, you can directly register your element as you would any other\nHTML custom element: customElements.define(\"my-tag\", MyComponentClass);\n`,\n\n    [ErrorCode.MISSING_ELEMENT]: `\nMISSING_ELEMENT\nAn element was expected to exist but was not found when the DOM was queried.\n`,\n\n    [ErrorCode.MISSING_STATE]: `\nMISSING_STATE\nA Component's reactive state was accessed, but no initialState is defined for\nthe Component's class. Initial state must be defined as an object or function.\n`,\n\n    [ErrorCode.INVALID_CONTENT]: `\nINVALID_CONTENT\nTried to set a value as content in a template, but the value was not a supported\ntype. Values must be a string, HTMLElement.\n\nInstead, got %s: %s.\n`,\n\n    [ErrorCode.TEMPLATE_INVALID_VALUE]: `\nTEMPLATE_INVALID\nThe value %s cannot be interpolated via the Template html string helper.\nValues may only be HTMLTemplateElements (template content is adopted) or\nstrings (shorthand for a ::swap directive on an element)\n`,\n\n    [ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX]: `\nTEMPLATE_INVALID_NOTATION\nA template value notation failed to parse. Notations must begin with one of\n@, $, *, or #, followed by a dot-separated path of accessor names. Optionally,\nnotations may have modifiers such as the ! modifier.\n\nThe notation that failed to parse was \"%s\"\n`,\n    [ErrorCode.TEMPLATE_INVALID_COMPONENT]: `\nTEMPLATE_INVALID_COMPONENT\nFailed to interpolate a Component in an html template string due to the\nComponent having an invalid tagName property.\n\nComponent \"%s\" has an invalid tagName property \"%s\"\n    `,\n\n    [ErrorCode.TEMPLATE_INVALID_LIST_DATA]: `\nTEMPLATE_INVALID_LIST\nA template failed to render because an ::each directive fetched a value which\nwas not an array of actionable data.\n`,\n\n    [ErrorCode.MISSING_NODE_REF]: `\nTEMPLATE_INVALID_NODE_REF\nA template failed to prepare a node from a compiled source. Typically, this\nmeans something is broken within the compiled template rather than an error with\nthe template content itself.\n`,\n\n    [ErrorCode.TEMPLATE_MISSING_LIST_KEY]: `\nTEMPLATE_MISSING_LIST_KEY\nA template failed to compile because an ::each directive was found on an element\nwithout a corresponding ::key directive. ::each directives must have a ::key\ndirective specified on the same element, whose notation evaluates to a unique\nvalue for each item in the list.\n\nExample: <li ::each=\"$items\" ::key=\"#id\"> ... </li>\n`,\n\n    [ErrorCode.TEMPLATE_DUPLICATE_LIST_KEY]: `\nTEMPLATE_DUPLICATE_LIST_KEY\nA list failed to render because item key %s appeared multiple times when\nresolving list item keys. Each ::key directive must reference a notation whose\nvalue is unique for each list item.\n`,\n\n    [ErrorCode.TEMPLATE_INVALID_CONDITIONAL]: `\nTEMPLATE_INVALID_CONDITIONAL\nA template failed to compile due to an invalid use of conditional directives.\n\nConditional elements must be siblings. The first conditional branch must use an\n::if directive, followed by zero or more ::else-if directives, and finally zero\nor one ::else directive.\n\n::if and ::else-if directives must specify a notation to evaluate. ::else does\nnot take any values and is just a binary attribute.\n`,\n\n    [ErrorCode.TEMPLATE_MISSING_NOTATION]: `\nTEMPLATE_MISSING_NOTATION\nA template failed to compile because a %s directive did not have an associated\nnotation despite requiring one.\n`,\n\n    [ErrorCode.INVALID_STATE_KEY]: `\nINVALID_STATE_KEY\nTried to access a state property which does not exist\n\nKey path: %s\n`,\n\n    [ErrorCode.INVALID_STATE_UPDATE]: `\nINVALID_STATE_UPDATE\nA Component's setState() was called with a value which could not be patched in\nto the existing component state.\n\nsetState() takes a partial object describing state keys to update.\n\nInstead, received: %s\n`,\n\n    [ErrorCode.STATE_LOCKED]: `\nSTATE_LOCKED\nA State received a request to update or lock while already locked.\nStates may be locked using the .lock() method and unlocked using the .unlock()\nmethod. States lock during async mutations done through the .mutateAsync()\nmethod if \"true\" is passed as the second parameter.\n\nYou can check the lock status of a State instance with .isLocked\n`,\n\n    [ErrorCode.MAX_SEQUENTIAL_RENDERS]: `\nMAX_SEQUENTIAL_RENDERS\nA component has errored after re-rendering more than %s times in the same frame.\n\nThis typically happens because state or live attributes are being modified\nduring a render lifecycle method such as beforeUpdate() or afterUpdate(). If\nstate changes unconditionally during a render, the render will infinitely loop.\nUpdating render source data during a render cycle is supported, but infinite\nupdate loops may occur if unchecked.\n`,\n\n    [ErrorCode.TEMPLATE_INVALID_KEY_DIRECTIVE]: `\nTEMPLATE_INVALID_KEY_DIRECTIVE\nA template failed to compile because a ::key directive was found on an element\nwith no associated ::each directive. ::key directives can only be used in\nassociation with list rendering via ::each.\n`,\n    [ErrorCode.TEMPLATE_PARENT_REQUIRED]: `\nTEMPLATE_PARENT_REQUIRED\nA template failed to compile due to an element which requires a parent having\nno available parent in the template.\n\n::each and ::if/::else-if/::else elements must have a parent node.\n`,\n  };\n\n  return DEV_ERROR_INFO[code];\n}\n\n/**\n * An error originating from within a Palette subsystem.\n *\n * In the `development` environment, the error will surface with extended info\n * about the error and any details which may be relevant to help with debugging.\n *\n * In the `production` environment, a minimal error only surfacing the numeric\n * error code is thrown instead.\n *\n * Codes are categorized into groups by the 100's:\n *\n * - 0 - 99: Invariants\n * - 100 - 199: Custom Elements / Environment Errors\n * - 200 - 299: Templating Errors\n * - 300 - 399: Runtime Errors\n */\nexport class PaletteError extends Error {\n  name = \"PaletteError\";\n  code: number;\n\n  constructor(code: number, ...values: string[]) {\n    let message = `Code: ${code}`;\n    if (__DEV__) {\n      message += getDevError(code);\n\n      for (const val of values) {\n        message = message.replace(`%s`, String(val));\n      }\n    }\n\n    super(message);\n    this.code = code;\n  }\n}\n",
    "/*\n * Copyright © Rustic Arcade, LLC 2026\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\n\n/** An attribute value as read from a DOM element */\ntype AttributeValue = string | null;\n\n/** A Map of string attribute names to {@link AttributeValue} */\ntype AttributeMap = Map<string, AttributeValue>;\n\nexport function serializeAttribute(value: unknown): AttributeValue {\n  if (typeof value === \"string\" || typeof value === \"number\") {\n    return `${value}`;\n  }\n\n  if (value === true) {\n    return \"\";\n  }\n\n  if (value === null || value === false || value === undefined) {\n    return null;\n  }\n\n  return value.toString();\n}\n\nexport function createAttributeMap(\n  source: object | Map<string, unknown> | HTMLElement,\n): AttributeMap {\n  const map = new Map<string, string | null>();\n\n  if (source instanceof HTMLElement) {\n    for (const name of source.getAttributeNames()) {\n      map.set(name, serializeAttribute(source.getAttribute(name)));\n    }\n    return map;\n  }\n\n  if (source instanceof Map) {\n    for (const [key, val] of source) {\n      map.set(key, serializeAttribute(val));\n    }\n    return map;\n  }\n\n  if (typeof source === \"object\" && source !== null) {\n    for (const [key, val] of Object.entries(source)) {\n      map.set(key, serializeAttribute(val));\n    }\n    return map;\n  }\n\n  throw new PaletteError(ErrorCode.INVARIANT);\n}\n\nexport function applyAttributeMap(\n  target: HTMLElement,\n  attrs: AttributeMap,\n): void {\n  const currentNames = new Set(target.getAttributeNames());\n  const incomingNames = new Set(attrs.keys());\n  const attributesToRemove = currentNames.difference(incomingNames);\n\n  for (const attr of attributesToRemove) {\n    target.removeAttribute(attr);\n  }\n\n  for (const [name, val] of attrs) {\n    if (val === null) {\n      target.removeAttribute(name);\n    } else {\n      target.setAttribute(name, val);\n    }\n  }\n}\n",
    "/*\n * Copyright © Rustic Arcade, LLC 2026\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\n/**\n * Check if a given string is a valid html tagname, optimized for hot paths.\n *\n * @remarks\n * This function avoids using the regex engine for performance\n */\nexport function isTagName(str: string): boolean {\n  for (let i = 0; i < str.length; i++) {\n    const char = str.charAt(i);\n\n    if (\n      !(\n        char === \"-\" ||\n        (char >= \"A\" && char <= \"Z\") ||\n        (char >= \"a\" && char <= \"z\")\n      )\n    ) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * A performance optimized version of `.matches()` which includes faster\n * matching strategies for common queries.\n *\n * @remarks\n * Optimized query types:\n *\n * - Single ID selector `\"#identifier\"`\n * - Single class selector `\".classname\"`\n * - Tagname selector `\"button\"`\n * - Simple attribute selector `\"[attr='value']\"`\n *\n * All other types of queries use the base .matches() for comparison\n */\nexport function elementMatches(element: Element, query: string) {\n  // If the query is a simple ID, check it directly\n  if (\n    query[0] === \"#\" &&\n    query.indexOf(\" \") === -1 &&\n    query.indexOf(\".\") === -1 &&\n    query.indexOf(\"[\") === -1 &&\n    query.indexOf(\":\") === -1 &&\n    query.indexOf(\">\") === -1\n  ) {\n    return element.id === query.slice(1);\n  }\n\n  // If the query is a simple classname, check it directly\n  if (\n    query[0] === \".\" &&\n    query.indexOf(\" \") === -1 &&\n    query.indexOf(\"#\") === -1 &&\n    query.indexOf(\"[\") === -1 &&\n    query.indexOf(\":\") === -1 &&\n    query.indexOf(\">\") === -1\n  ) {\n    return element.classList.contains(query.slice(1));\n  }\n\n  // If the query is for just a tagname, check it directly\n  if (isTagName(query)) {\n    return element.tagName.toLowerCase() === query.toLowerCase();\n  }\n\n  // If the query is for a single selector value, check it directly\n  if (\n    query[0] === \"[\" &&\n    query[query.length - 1] === \"]\" &&\n    query.indexOf(\" \") === -1 &&\n    query.indexOf(\":\") === -1\n  ) {\n    const attr = query.slice(1, -1);\n    const eqIndex = attr.indexOf(\"=\");\n    if (eqIndex === -1) {\n      return element.hasAttribute(attr);\n    }\n    const attrName = attr.slice(0, eqIndex);\n    const attrValue = attr.slice(eqIndex + 1).replace(/^[\"']|[\"']$/g, \"\");\n    return element.getAttribute(attrName) === attrValue;\n  }\n\n  // Otherwise, use native `.matches` for complex stuff\n  return element.matches(query);\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\ntype Metrics = {\n  hits: number;\n  misses: number;\n};\n\nexport type LRUCacheMetrics = {\n  lookups: number;\n  hits: number;\n  misses: number;\n  capacity: number;\n  entries: number;\n  hitRate: number;\n};\n\n/**\n * A simple in-memory LRU Cache using JavaScript maps.\n *\n * @example\n *\n * Cached network request\n *\n * ```typescript\n * // A cache of API URLs to their returned payloads\n * const cache = new LRUCache<string, APIPayload>();\n *\n * async function makeRequest(url: string) {\n *   let cached = cache.get(url);\n *   if (cached) {\n *     return cached;\n *   }\n *\n *   // ... Make the request and cache.set() the response\n * }\n * ```\n */\nexport class LRUCache<K, V> {\n  private _maxSize: number;\n  private _data: Map<K, V>;\n  private _metrics: Metrics = { hits: 0, misses: 0 };\n\n  constructor(maxSize: number = 500) {\n    if (maxSize <= 0) {\n      throw new Error(\"LRU Cache capacity must be >= 1\");\n    }\n\n    if (__DEV__) {\n      this._metrics = { hits: 0, misses: 0 };\n    }\n\n    this._maxSize = maxSize;\n    this._data = new Map<K, V>();\n  }\n\n  private _trim = () => {\n    while (this._data.size > this._maxSize) {\n      const firstKey = this._data.keys().next().value;\n      if (firstKey === undefined) {\n        throw new Error(\"Absurd\");\n      }\n      this._data.delete(firstKey);\n    }\n  };\n\n  /**\n   * Get cache performance metrics from this LRU Cache instance.\n   *\n   * In development mode, this returns insights into hits/misses of the cache,\n   * as well as the current configuration and entry count.\n   *\n   * In production mode, this returns a placeholder object, as metric collection\n   * is not active in production.\n   */\n  getMetrics(): LRUCacheMetrics | void {\n    if (__DEV__) {\n      const { hits = 0, misses = 0 } = this._metrics ?? {};\n      const lookups = hits + misses;\n      const hitRate = lookups === 0 ? 0 : hits / lookups;\n\n      return {\n        lookups,\n        hits: hits,\n        misses: misses,\n        capacity: this._maxSize,\n        entries: this._data.size,\n        hitRate,\n      };\n    }\n  }\n\n  /**\n   * Update the maximum cache size for this instance. Immediately triggers a\n   * purge of cached contents if the new capacity is less than the current\n   * number of cached entries.\n   */\n  setCapacity = (maxSize: number): void => {\n    if (maxSize <= 0 && __DEV__) {\n      console.warn(\n        \"[Palette LRU Cache] Cache size is <= 0. Cache is disabled.\",\n      );\n    }\n\n    this._maxSize = maxSize;\n    this._trim();\n  };\n\n  /**\n   * Fetch a value from the cache, returning `undefined` if no value was found\n   */\n  get(key: K): V | undefined {\n    const value = this._data.get(key);\n\n    if (value === undefined) {\n      if (__DEV__) {\n        this._metrics.misses += 1;\n      }\n      return undefined;\n    }\n\n    // Delete and re-set the value to move the key to the end of the key list\n    this._data.delete(key);\n    this._data.set(key, value);\n\n    if (__DEV__) {\n      this._metrics.hits += 1;\n    }\n\n    return value;\n  }\n\n  /**\n   * Set a value in the cache. This also moves the value to the back of the list\n   * of values to consider evicting when the cache is full.\n   */\n  set(key: K, value: V): void {\n    // Remove if exists to update position\n    if (this._data.has(key)) {\n      this._data.delete(key);\n    }\n\n    this._data.set(key, value);\n\n    if (this._data.size > this._maxSize) {\n      this._trim();\n    }\n  }\n\n  /**\n   * Clear all contents of this cache instance\n   */\n  clear(): void {\n    this._data.clear();\n  }\n\n  /**\n   * Get the number of entries in this cache instance\n   */\n  get size(): number {\n    return this._data.size;\n  }\n}\n\nexport default LRUCache;\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport LRUCache from \"./lru-cache\";\n\nexport const fragmentCache = new LRUCache<string, DocumentFragment>();\n\nexport function htmlToFragment(html: string): DocumentFragment {\n  const lookup = fragmentCache.get(html);\n\n  if (lookup !== undefined) {\n    return lookup.cloneNode(true) as DocumentFragment;\n  }\n\n  const temp = document.createElement(\"template\");\n  temp.innerHTML = html;\n  fragmentCache.set(html, temp.content);\n  return temp.content.cloneNode(true) as DocumentFragment;\n}\n\nexport function saveFragment(html: string, fragment: DocumentFragment): void {\n  fragmentCache.set(html, fragment);\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport type { Component } from \"#component\";\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { isTagName } from \"#util\";\n\nexport function parseCSSTemplateStringValue(\n  val: string | typeof Component,\n): string {\n  // Convert component refs to their tagnames\n  if (typeof val === \"function\") {\n    const tagName = val.tagName;\n    if (!isTagName(tagName)) {\n      throw new PaletteError(\n        ErrorCode.TEMPLATE_INVALID_COMPONENT,\n        val.name,\n        val.tagName,\n      );\n    }\n    return tagName;\n  }\n\n  if (typeof val === \"string\") {\n    return val;\n  }\n\n  throw new PaletteError(ErrorCode.TEMPLATE_INVALID_VALUE, String(val));\n}\n\n/**\n * @returns An array of {@link CSSStyleSheet}s containing the provided CSS\n */\nexport function css(\n  strings: TemplateStringsArray,\n  ...values: (string | typeof Component<any>)[]\n): CSSStyleSheet {\n  let result = strings[0] ?? \"\";\n\n  for (let i = 0; i < values.length; i++) {\n    const nextVal = values[i] ?? \"\";\n    const nextStr = strings[i + 1] ?? \"\";\n    result += parseCSSTemplateStringValue(nextVal);\n    result += nextStr;\n  }\n\n  const sheet = new CSSStyleSheet();\n  sheet.replaceSync(result);\n  return sheet;\n}\n\ntype ClassValue =\n  | string\n  | number\n  | boolean\n  | undefined\n  | null\n  | ClassArray\n  | ClassObject;\ntype ClassArray = ClassValue[];\ntype ClassObject = Record<string, any>;\n\n/**\n * Given flexible input, generate a string suitable for setting as an html class\n *\n * @example\n *\n * ```typescript\n * classify(\"my-class\", \"another-class\") // \"my-class another-class\"\n * classify([\"my-class\", \"another-class\"]) // \"my-class another-class\"\n * classify({ enabled: true, disabled: false }) // \"enabled\"\n * ```\n */\nexport function classify(...args: ClassValue[]): string {\n  let resultString = \"\";\n\n  for (let index = 0; index < args.length; index++) {\n    const argument = args[index];\n\n    if (!argument) {\n      continue;\n    }\n\n    // Strings/nums -> Direct append\n    if (typeof argument === \"string\" || typeof argument === \"number\") {\n      if (resultString) {\n        resultString += \" \";\n      }\n      resultString += argument;\n      continue;\n    }\n\n    // Handle arrays recursively\n    if (Array.isArray(argument)) {\n      const nestedResult = classify(...argument);\n      if (nestedResult) {\n        if (resultString) {\n          resultString += \" \";\n        }\n        resultString += nestedResult;\n      }\n      continue;\n    }\n\n    // Handle objects with conditional class names\n    if (typeof argument === \"object\") {\n      for (const className in argument) {\n        // Only include class name if its value is truthy\n        if (argument[className]) {\n          if (resultString) {\n            resultString += \" \";\n          }\n          resultString += className;\n        }\n      }\n    }\n  }\n\n  return resultString;\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { Component } from \"#component\";\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { isTagName } from \"#util\";\n\nexport function parseTemplateStringValue(\n  val: string | typeof Component | HTMLTemplateElement,\n): string {\n  if (val instanceof HTMLTemplateElement) {\n    return val.innerHTML;\n  }\n\n  if (\n    typeof val === \"function\" &&\n    (val.prototype instanceof Component || val === Component)\n  ) {\n    const tagName = val.tagName;\n    if (!isTagName(tagName)) {\n      throw new PaletteError(\n        ErrorCode.TEMPLATE_INVALID_COMPONENT,\n        val.name,\n        val.tagName,\n      );\n    }\n    return tagName;\n  }\n\n  if (typeof val === \"string\") {\n    return `<span ::swap=\"${val}\"></span>`;\n  }\n\n  throw new PaletteError(ErrorCode.TEMPLATE_INVALID_VALUE, String(val));\n}\n\n/**\n * Create an {@link HTMLTemplateElement} from the provided HTML string.\n *\n * These HTML Templates can be used as standard HTML Templates, or as the\n * foundation for a {@link Component} or standalone {@link Template}\n *\n * Interpolates values in the template string to provide helpers for composing\n * templates:\n *\n * - HTMLTemplateElement references are serialized to HTML and inlined\n * - Strings are modified to become <span> tags with the ::swap directive set\n *   to the string value. This is helpful shorthand for content placeholders.\n *\n * @example\n *\n * This template string\n *\n * ```typescript\n * const $template = html`\n * <div :class=\"*classnames\">\n *   ${\"@content\"}\n * </div>\n * `\n * ```\n *\n * Produces this template element (portrayed as HTML)\n *\n * ```html\n * <template>\n *   <div :class=\"*classnames\">\n *     <span ::swap=\"@content\"></span>\n *   </div>\n * </template>\n * ```\n */\nexport function html(\n  strings: TemplateStringsArray,\n  ...values: (\n    | `@${string}`\n    | `$${string}`\n    | `#${string}`\n    | `*${string}`\n    | HTMLTemplateElement\n    | typeof Component<any>\n  )[]\n): HTMLTemplateElement {\n  const fullString = strings.reduce((acc, str, i) => {\n    const parsedValue = values[i]\n      ? `${parseTemplateStringValue(values[i])}`\n      : \"\";\n    return acc + str + parsedValue;\n  }, \"\");\n\n  const templateElement = document.createElement(\"template\");\n  templateElement.innerHTML = fullString;\n  return templateElement;\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\n\nexport type StateListener<Shape> = (state: Shape) => void;\n\nconst ArrayMutatorFunctions = new Set([\n  \"push\",\n  \"pop\",\n  \"shift\",\n  \"unshift\",\n  \"splice\",\n  \"sort\",\n  \"reverse\",\n  \"fill\",\n  \"copyWithin\",\n]);\n\nconst DataStructureMutatorFunctions = new Set([\n  \"add\",\n  \"delete\",\n  \"clear\",\n  \"set\",\n]);\n\n/**\n * Powerful and flexible state management with deep reactivity, transaction, and\n * locking support.\n *\n * The State class wraps stateful data and provides an API for mutating the data\n * while listeners subscribe to meaningful updates.\n *\n * Modify state with setters, mutators, transactions, or proxied updates with\n * deep reactivity and array mutation support built in.\n *\n * @example\n *\n * ```typescript\n * const state = new State({count: 1});\n * state.addListener(data => console.log(data))\n *\n * state.set(\"count\", 2); // Prints \"2\"\n * state.set(\"count\", 2); // Nothing happens, no change\n * state.live.count = 3; // Prints \"3\"\n * ```\n */\nexport class State<Shape extends object> {\n  private _data: Shape;\n  private _listeners: Set<StateListener<Shape>> = new Set();\n  private _proxy?: Shape;\n  private _proxyCache = new WeakMap<object, any>();\n  private _reverseProxyCache = new WeakMap<object, object>();\n  private _isLocked = false;\n\n  constructor(initialData: Shape, onChange?: StateListener<Shape>) {\n    this._data = initialData;\n    this.get = this.get.bind(this);\n\n    if (onChange) {\n      this._listeners.add(onChange);\n    }\n  }\n\n  /**\n   * Lazily create and cache proxies into the state for reactive updates on\n   * nested values.\n   */\n  private _createProxy<T>(target: T, path: string[] = []): T {\n    // Return primitives immediately\n    if (typeof target !== \"object\" || target === null) {\n      return target;\n    }\n\n    // Check for a cached proxy for this object\n    const cached = this._proxyCache.get(target as object);\n    if (cached) {\n      return cached;\n    }\n\n    // Otherwise create a new proxy and cache it\n    const proxy = new Proxy(target as object, {\n      get: (obj, key: string | symbol) => {\n        // Symbols -> Direct return\n        if (typeof key === \"symbol\") {\n          return (obj as any)[key];\n        }\n\n        const value = (obj as any)[key];\n\n        // For Arrays, Maps, and Sets, handle mutator functions correctly\n        if (\n          (obj instanceof Set || obj instanceof Map || Array.isArray(obj)) &&\n          typeof value === \"function\"\n        ) {\n          const mutationFns = Array.isArray(obj)\n            ? ArrayMutatorFunctions\n            : DataStructureMutatorFunctions;\n          const isMutation = mutationFns.has(key);\n\n          return (...args: any[]) => {\n            const snapshot = this.snapshot();\n\n            let current: any = snapshot;\n\n            for (const p of path) {\n              current = current[p];\n            }\n\n            const res = (current as any)[key](...args);\n\n            if (isMutation) {\n              if (this._isLocked) {\n                throw new PaletteError(ErrorCode.STATE_LOCKED);\n              }\n              this._processIncomingState(snapshot);\n            }\n\n            return res;\n          };\n        }\n\n        // Objects -> recursively create a proxy\n        if (typeof value === \"object\" && value !== null) {\n          return this._createProxy(value, [...path, key]);\n        }\n\n        // Primitives -> Return value\n        return value;\n      },\n\n      set: (_obj, key: string | symbol, value: any) => {\n        // Reject if currently locked\n        if (this._isLocked) {\n          throw new PaletteError(ErrorCode.STATE_LOCKED);\n        }\n\n        // Disallow setting symbol properties on target data values\n        if (typeof key === \"symbol\") {\n          return false;\n        }\n\n        // Compute and update the path with the value\n        const newPath = [...path, key];\n        this._setNested(newPath, this._unwrapProxy(value));\n\n        return true;\n      },\n\n      has: (obj, key: string | symbol) => {\n        return key in obj;\n      },\n\n      ownKeys: (obj) => {\n        return Reflect.ownKeys(obj);\n      },\n\n      getOwnPropertyDescriptor: (obj, key: string | symbol) => {\n        const desc = Object.getOwnPropertyDescriptor(obj, key);\n\n        if (desc) {\n          desc.configurable = true;\n        }\n\n        return desc;\n      },\n\n      deleteProperty: (obj, key) => {\n        if (typeof key === \"symbol\" || !(key in obj)) {\n          return false;\n        }\n\n        // Compute and update the path with the value\n        const newPath = [...path, key];\n\n        this._setNested(newPath, undefined);\n\n        return true;\n      },\n    }) as T;\n\n    this._proxyCache.set(target as object, proxy);\n    this._reverseProxyCache.set(proxy as object, target as object);\n    return proxy;\n  }\n\n  private _unwrapProxy<T>(value: T): T {\n    // Don't do anything for primitives\n    if (typeof value !== \"object\" || value === null) {\n      return value;\n    }\n\n    // Check if this is one of our proxies\n    const rawTarget = this._reverseProxyCache.get(value as object);\n    if (rawTarget) {\n      return rawTarget as T;\n    }\n\n    // Handle arrays\n    if (Array.isArray(value)) {\n      return value.map((item) => this._unwrapProxy(item)) as T;\n    }\n\n    // Handle plain objects\n    if (Object.getPrototypeOf(value) === Object.prototype) {\n      const unwrapped: any = {};\n      for (const key in value) {\n        if (Object.hasOwn(value, key)) {\n          unwrapped[key] = this._unwrapProxy((value as any)[key]);\n        }\n      }\n      return unwrapped;\n    }\n\n    // Other objects (Date, Map, Set, etc.) pass through\n    return value;\n  }\n\n  /**\n   * Handle setting nested values and emitting updated data if the value changed\n   */\n  private _setNested(path: string[], value: any): void {\n    // Nothing to do with empty paths\n    if (!path.length) {\n      return;\n    }\n\n    // Start at the root and seek to the value being set\n    let current: any = this._data;\n\n    for (let i = 0; i < path.length - 1; i++) {\n      const key = path[i] ?? \"\";\n\n      if (current === undefined) {\n        throw new PaletteError(ErrorCode.INVALID_STATE_KEY, path.join(\".\"));\n      }\n\n      current = current[key];\n    }\n\n    const finalKey = path[path.length - 1] ?? \"\";\n\n    if (current === undefined) {\n      throw new PaletteError(ErrorCode.INVALID_STATE_KEY, path.join(\".\"));\n    }\n\n    // Set and emit only if the value is different. Otherwise no-op.\n    if (current[finalKey] !== value && !Object.is(current[finalKey], value)) {\n      current[finalKey] = value;\n      this._emit(this.current);\n    }\n  }\n\n  /**\n   * Process an incoming partial state and emit updates to listeners if there\n   * are any changes detected.\n   *\n   * @remarks\n   * Object.is() to check for differences. Does not attempt deep diffing.\n   */\n  private _processIncomingState = (incomingState: Partial<Shape>): void => {\n    if (\n      typeof incomingState !== \"object\" ||\n      incomingState === null ||\n      Array.isArray(incomingState)\n    ) {\n      throw new PaletteError(\n        ErrorCode.INVALID_STATE_UPDATE,\n        JSON.stringify(incomingState),\n      );\n    }\n    let hasChanges = false;\n\n    // Check if any key/value pair on the incoming state differs from the\n    // existing data\n    for (const [key, newValue] of Object.entries(incomingState)) {\n      const currentValue = this._data[key as keyof Shape];\n      if (!Object.is(currentValue, newValue)) {\n        hasChanges = true;\n        (this._data as any)[key] = newValue;\n      }\n    }\n\n    if (hasChanges) {\n      this._emit(this._data);\n    }\n  };\n\n  /**\n   * Emit the current state to all listeners\n   */\n  private _emit = (data: Shape): void => {\n    for (const listener of this._listeners) {\n      listener(data);\n    }\n  };\n\n  /**\n   * The current state\n   *\n   * @remarks\n   * This is a direct reference to the internal state. It is marked as Readonly\n   * to help prevent accidental changes. Never edit this value directly.\n   */\n  get current(): Readonly<Shape> {\n    return this._data;\n  }\n\n  /**\n   * Live reactive accessor for state data. Deeply nested changes trigger\n   * automatic updates, including array, Map, and Set mutations.\n   *\n   * @remarks\n   * For deeply nested values, the `.live` accessor may add performance overhead\n   * compared to directly accessing the value via `.current`\n   */\n  get live(): Shape {\n    if (!this._proxy) {\n      this._proxy = this._createProxy(this._data);\n    }\n    return this._proxy;\n  }\n\n  /**\n   * Indicates if this state is currently locked (true) or not (false)\n   */\n  get isLocked(): boolean {\n    return this._isLocked;\n  }\n\n  /**\n   * Add a handler function for when this state changes.\n   *\n   * Listeners are invoked in the order they are registered and are passed a\n   * reference to the internally managed state object as a readonly object.\n   *\n   * **Do not modify state values directly**. Instead, use {@link set} or\n   * {@link patch} to make immutable updates.\n   */\n  addListener = (listener: StateListener<Shape>): void => {\n    this._listeners.add(listener);\n  };\n\n  /**\n   * Remove a previously registered state handler\n   */\n  removeListener = (listener: StateListener<Shape>): void => {\n    this._listeners.delete(listener);\n  };\n\n  /**\n   * Get a single value from the state object\n   *\n   * The value is returned as Readonly to prevent accidental state mutations.\n   * To mutate stateful properties, use {@link set} or {@link patch} instead.\n   *\n   * @example\n   *\n   * ```typescript\n   * const state = new State({ count: 1 });\n   * console.log(state.get(\"count\")); // 1\n   * ```\n   *\n   */\n  get = <K extends keyof Shape>(key: K): Readonly<Shape[K]> => {\n    return this._data[key] as Readonly<Shape[K]>;\n  };\n\n  /**\n   * Returns a deep clone of the current state data using `structuredClone()` to\n   * make the copy.\n   *\n   * The object returned from this function can be edited without modifying the\n   * actual internal state.\n   *\n   * @example\n   *\n   * ```typescript\n   * const snap = state.snapshot();\n   * snap.count += 1;\n   * state.patch(snap);\n   * ```\n   */\n  snapshot = (): Shape => {\n    return structuredClone(this._data);\n  };\n\n  /**\n   * Set a single stateful property while leaving other properties unchanged.\n   *\n   * Triggers an update to all listeners if the value is different from before\n   * when compared using shallow equality.\n   *\n   * @example\n   *\n   * ```typescript\n   * const state = new State({ count: 1, color: \"red\" });\n   * state.set(\"count\", 2); // State is now { count: 2, color: \"red\" }\n   * ```\n   */\n  set = <K extends keyof Shape>(key: K, value: Shape[K]): void => {\n    // Reject if currently locked\n    if (this._isLocked) {\n      throw new PaletteError(ErrorCode.STATE_LOCKED);\n    }\n\n    const partial: Partial<Shape> = {};\n    partial[key] = value;\n\n    this._processIncomingState(partial);\n  };\n\n  /**\n   * Set multiple stateful properties at once, leaving omitted properties\n   * unchanged.\n   *\n   * @example\n   *\n   * Patch a partial state, updating all listed properties at once\n   *\n   * ```typescript\n   * const state = new State({\n   *   weather: \"sunny\",\n   *   temperature: 30,\n   *   humidity: 70,\n   * });\n   *\n   * // Leaves `temperature` unchanged\n   * state.patch({\n   *   weather: \"cloudy\",\n   *   humidity: 50,\n   * });\n   * ```\n   */\n  patch = (patch: Partial<Shape>): State<Shape> => {\n    // Reject if currently locked\n    if (this._isLocked) {\n      throw new PaletteError(ErrorCode.STATE_LOCKED);\n    }\n\n    this._processIncomingState(patch);\n    return this;\n  };\n\n  /**\n   * Fully replace the current state data and force listeners to receive the\n   * updated data immediately.\n   */\n  replace = (state: Shape): State<Shape> => {\n    // Reject if currently locked\n    if (this._isLocked) {\n      throw new PaletteError(ErrorCode.STATE_LOCKED);\n    }\n\n    this._data = state;\n    this._emit(this._data);\n    return this;\n  };\n\n  /**\n   * Lock this State instance, preventing further external changes\n   */\n  lock = (): State<Shape> => {\n    if (this._isLocked) {\n      throw new PaletteError(ErrorCode.STATE_LOCKED);\n    }\n\n    this._isLocked = true;\n    return this;\n  };\n\n  /**\n   * Unlock this State instance, allowing further external changes\n   */\n  unlock = (): State<Shape> => {\n    this._isLocked = false;\n    return this;\n  };\n\n  /**\n   * Apply complex updates to the state using a mutator function.\n   *\n   * The mutator function takes one parameter which is a structuredClone copy of\n   * the current state object. Whatever is returned by the mutator is then\n   * patched in to the state.\n   */\n  mutate = (mutator: (current: Shape) => Shape): State<Shape> => {\n    if (this._isLocked) {\n      throw new PaletteError(ErrorCode.STATE_LOCKED);\n    }\n\n    this._processIncomingState(mutator(this.snapshot()));\n    return this;\n  };\n\n  /**\n   * Perform an async mutation of the state, optionally locking the state during\n   * the process.\n   * @param mutator A function to mutate and return the new state\n   * @param lock If `true`, lock the state until the mutator completes\n   */\n  mutateAsync = async (\n    mutator: (current: Shape) => Promise<Shape>,\n    lock = false,\n  ): Promise<State<Shape>> => {\n    if (this._isLocked) {\n      throw new PaletteError(ErrorCode.STATE_LOCKED);\n    }\n\n    if (lock) {\n      this._isLocked = true;\n    }\n\n    const mutationResult = await mutator(this.snapshot());\n    this._processIncomingState(mutationResult);\n\n    if (lock) {\n      this._isLocked = false;\n    }\n\n    return this;\n  };\n\n  /**\n   * Perform a transaction-style set of actions defined within a function.\n   *\n   * The provided function can do anything, beyond just setting state. Any\n   * uncaught errors thrown from within the function will cause the transaction\n   * to fail and the state to automatically roll back to the last valid state.\n   *\n   * During a transaction, this state instance will be locked, preventing other\n   * changes.\n   *\n   * Transactions will always result in a state update when successful.\n   *\n   * @example\n   *\n   * Transactions with locking and rollback support\n   *\n   * ```typescript\n   * const state = new State({count: 1});\n   *\n   * state.transaction(async (s) => {\n   *   // `s` is a full State object you can safely manipulate\n   *   s.set(\"count\", 10);\n   * });\n   * state.get(\"count\"); // => 10;\n   *\n   * // Errors inside the transaction roll back the state\n   * state.transaction(async (s) => {\n   *   s.set(\"count\", 100);\n   *   throw new Error();\n   * });\n   * state.get(\"count\"); // => 10;\n   */\n  transaction = (fn: (state: State<Shape>) => void): boolean => {\n    if (this._isLocked) {\n      throw new PaletteError(ErrorCode.STATE_LOCKED);\n    }\n\n    // Lock outside of the try/catch to throw immediately, separating the\n    // transaction function error from the actual call site errors\n    this._isLocked = true;\n\n    let success = true;\n\n    try {\n      // Create a temporary state object to use within the transaction\n      const transactionState = new State<Shape>(this.snapshot());\n\n      // Run the transaction itself\n      fn(transactionState);\n\n      // Adopt the resulting state of the temporary object\n      this._processIncomingState(transactionState.current);\n    } catch (error) {\n      if (__DEV__) {\n        console.warn(\"[State] Transaction failed due to caught error\", error);\n      }\n      success = false;\n    } finally {\n      this._isLocked = false;\n    }\n\n    return success;\n  };\n\n  /**\n   * Perform a transaction-style set of actions defined within an async function\n   *\n   * The provided function can do anything, beyond just setting state. Any\n   * uncaught errors thrown from within the function will cause the transaction\n   * to fail and the state to automatically roll back to the last valid state.\n   *\n   * During a transaction, this state instance will be locked, preventing other\n   * changes.\n   *\n   * Transactions will always result in a state update when successful.\n   *\n   * @example\n   *\n   * Transactions with locking and rollback support\n   *\n   * ```typescript\n   * const state = new State({count: 1});\n   *\n   * // Awaiting the result of a transaction\n   * await state.transactionAsync(async (s) => {\n   *   // `s` is a full State object you can safely manipulate\n   *   s.set(\"count\", 10);\n   * });\n   * state.get(\"count\"); // => 10;\n   *\n   * // Errors inside the transaction roll back the state\n   * await state.transactionAsync(async (s) => {\n   *   s.set(\"count\", 100);\n   *   throw new Error();\n   * });\n   * state.get(\"count\"); // => 10;\n   *\n   * // If you forget to await the transaction, its still locked\n   * state.transactionAsync(async (s) => {\n   *   await waitSeconds(1);\n   * });\n   * state.set(\"count\", 1); // Error: State is locked!\n   * ```\n   */\n  transactionAsync = async (\n    fn: (state: State<Shape>) => Promise<void>,\n  ): Promise<boolean> => {\n    if (this._isLocked) {\n      throw new PaletteError(ErrorCode.STATE_LOCKED);\n    }\n\n    // Lock outside of the try/catch to throw immediately, separating the\n    // transaction function error from the actual call site errors\n    this._isLocked = true;\n\n    let success = true;\n\n    try {\n      // Create a temporary state object to use within the transaction\n      const transactionState = new State<Shape>(this.snapshot());\n\n      // Run the transaction itself\n      await fn(transactionState);\n\n      // Adopt the resulting state of the temporary object\n      this._processIncomingState(transactionState.current);\n    } catch (error) {\n      if (__DEV__) {\n        console.warn(\"[State] Transaction failed due to caught error\", error);\n      }\n      success = false;\n    } finally {\n      this._isLocked = false;\n    }\n\n    return success;\n  };\n}\n",
    "export const REF_ATTR = \"data-node-ref\";\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { LRUCache } from \"#util\";\n\nconst enum NotationPrefix {\n  Attributes = \"@\",\n  State = \"$\",\n  Data = \"*\",\n  Item = \"#\",\n}\n\nconst PREFIX_MAPPING: Record<NotationPrefix, string> = {\n  [NotationPrefix.Attributes]: \"attr\",\n  [NotationPrefix.State]: \"state\",\n  [NotationPrefix.Data]: \"data\",\n  [NotationPrefix.Item]: \"item\",\n};\n\nconst prefixMapping = new Map(Object.entries(PREFIX_MAPPING));\n\nexport type ParsedNotation = {\n  /** The raw string representation of the parsed notation */\n  base: string;\n\n  /** An array of property names forming a path to the notation value */\n  path: string[];\n\n  modifiers?: {\n    not?: boolean;\n  };\n};\n\nexport const parsedNotationCache = new LRUCache<string, ParsedNotation>();\n\n/**\n * Parse a notation into an object with runtime information\n *\n * @remarks\n * Four notations are supported:\n *\n * - `@attrname` -> Root element attributes\n * - `$statevalue` -> Stateful content\n * - `*property.or.whatever` -> Computed data properties\n * - `#color` -> List item properties\n */\nexport function parseNotation(notation: string): ParsedNotation {\n  const cached = parsedNotationCache.get(notation);\n  if (cached) {\n    return cached;\n  }\n\n  // Check for prefix modifiers\n  let notModifier = false;\n\n  let pathPart = \"\";\n  const computedPath: string[] = [];\n\n  let isFirst = true;\n  for (const char of notation) {\n    // ! at position 0 -> Enable NOT modifier, dont count towards idx\n    if (isFirst && char === \"!\") {\n      notModifier = true;\n    }\n\n    // Otherwise, position 0 must be a prefix\n    else if (isFirst) {\n      const prefix = prefixMapping.get(char);\n\n      if (!prefix) {\n        throw new PaletteError(\n          ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX,\n          notation,\n        );\n      }\n\n      computedPath.push(prefix);\n      isFirst = false;\n    }\n\n    // Collect characters and push when hitting a dot or end\n    else if (char === \".\") {\n      if (pathPart.length) {\n        computedPath.push(pathPart);\n        pathPart = \"\";\n      } else {\n        throw new PaletteError(\n          ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX,\n          notation,\n        );\n      }\n    } else {\n      pathPart += char;\n    }\n  }\n\n  // Add the final part which must exist (otherwise, it ended in a dot)\n  if (!pathPart.length) {\n    throw new PaletteError(\n      ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX,\n      notation,\n    );\n  }\n\n  computedPath.push(pathPart);\n\n  if (computedPath.length < 2) {\n    throw new PaletteError(\n      ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX,\n      notation,\n    );\n  }\n\n  const parsedNotation: ParsedNotation = {\n    base: notation,\n    path: computedPath,\n    modifiers: notModifier ? { not: true } : undefined,\n  };\n\n  parsedNotationCache.set(notation, parsedNotation);\n\n  return parsedNotation;\n}\n\nexport type NotationAccessor = (source: unknown) => unknown;\n\nexport const valueAccessorCache = new LRUCache<string, NotationAccessor>();\n\nexport function buildValueAccessor(notation: ParsedNotation): NotationAccessor {\n  const { path, modifiers, base } = notation;\n\n  const cached = valueAccessorCache.get(base);\n  if (cached) {\n    return cached;\n  }\n\n  if (path.length < 2) {\n    // Notations must always have at least 2 parts: the namespace, and at least\n    // one property name on the namespace (example: [\"state\", \"visible\"])\n    throw new PaletteError(ErrorCode.INVARIANT);\n  }\n\n  const accessor = (source: unknown) => {\n    let current = source;\n\n    for (const part of path) {\n      if (!current || typeof current !== \"object\") {\n        return null;\n      }\n\n      current = current[part as keyof typeof current];\n    }\n\n    if (modifiers?.not) {\n      if (path[0] === \"attr\") {\n        return current !== \"\" && !current;\n      }\n      return !current;\n    }\n\n    return current;\n  };\n\n  valueAccessorCache.set(base, accessor);\n\n  return accessor;\n}\n",
    "import { htmlToFragment } from \"#util\";\nimport { Directive } from \"./directive\";\nimport { Template } from \"./template\";\n\nexport function htmlStringToTemplate(html: string): Template {\n  const fragment = htmlToFragment(html);\n  const templateElement = document.createElement(\"template\");\n  templateElement.content.appendChild(fragment);\n  return new Template(templateElement);\n}\n\nexport function collectOperableNodes(\n  fragment: DocumentFragment,\n): HTMLElement[] {\n  const walker = document.createTreeWalker(fragment, NodeFilter.SHOW_ELEMENT);\n  const knownIgnores = new Set<Node>();\n  const nodes: HTMLElement[] = [];\n\n  let currentNode: Node | null = walker.nextNode();\n\n  while (currentNode) {\n    if (!(currentNode instanceof HTMLElement)) {\n      currentNode = walker.nextNode();\n      continue;\n    }\n\n    let parent = currentNode.parentNode;\n    let isInoperable = false;\n\n    while (parent && !isInoperable) {\n      if (\n        knownIgnores.has(parent) ||\n        (parent instanceof HTMLElement &&\n          (parent.hasAttribute(Directive.Each) ||\n            parent.hasAttribute(Directive.If) ||\n            parent.hasAttribute(Directive.Else) ||\n            parent.hasAttribute(Directive.ElseIf)))\n      ) {\n        isInoperable = true;\n        knownIgnores.add(currentNode);\n        break;\n      }\n\n      parent = parent.parentNode;\n    }\n\n    if (!isInoperable) {\n      nodes.push(currentNode);\n    }\n\n    currentNode = walker.nextNode();\n  }\n\n  return nodes;\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { createAttributeMap, LRUCache, saveFragment } from \"#util\";\nimport { REF_ATTR } from \"./constant\";\nimport { Directive } from \"./directive\";\nimport { type ParsedNotation, parseNotation } from \"./syntax\";\nimport type {\n  AnyScheme,\n  AttributeUpdateScheme,\n  ConditionalRenderScheme,\n  ConditionalRenderSchemeBranch,\n  ContentSwapScheme,\n  ListRenderScheme,\n} from \"./types\";\nimport { collectOperableNodes } from \"./util\";\n\nconst requiresNotation = new Set<string>([\n  Directive.Each,\n  Directive.If,\n  Directive.ElseIf,\n  Directive.Key,\n  Directive.Swap,\n  Directive.Tag,\n]);\n\n/**\n * A JSON-serializable representation of a {@link Template} instance, including\n * everything needed to recreate the template.\n */\nexport interface CompiledTemplate {\n  html: string;\n  schemes: AnyScheme[];\n  notations: Record<string, ParsedNotation>;\n}\n\nexport const compiledTemplateCache = new LRUCache<\n  HTMLTemplateElement,\n  CompiledTemplate\n>();\n\n/**\n * Compile an {@link HTMLTemplateElement} into a {@link CompiledTemplate} for\n * caching, cloning, or storage.\n *\n * Compiled template objects contain a JSON-serializable data representation of\n * a template and can be prepared using {@link prepareCompiledTemplate} to\n * create new Template instances.\n *\n * @example\n *\n * ```typescript\n * const compiled = compileTemplate($templateElement);\n * const stringified = JSON.stringify(compiled); // a JSON template bundle\n * ```\n */\nexport function compileTemplate(source: HTMLTemplateElement): CompiledTemplate {\n  // Check if the template is already cached\n  const cachedTemplate = compiledTemplateCache.get(source);\n  if (cachedTemplate) {\n    return cachedTemplate;\n  }\n\n  const parsedNotations = new Map<string, ParsedNotation>();\n  const compiledSchemes: AnyScheme[] = [];\n\n  let nextNodeRef = 0;\n  const ensureNodeRef = (el: HTMLElement): string => {\n    let ref = el.getAttribute(REF_ATTR);\n    if (!ref) {\n      ref = `el-${nextNodeRef++}`;\n      el.setAttribute(REF_ATTR, ref);\n    }\n    return ref;\n  };\n\n  const clonedTemplateElement = source.content.cloneNode(\n    true,\n  ) as DocumentFragment;\n\n  const nodes: HTMLElement[] = collectOperableNodes(clonedTemplateElement);\n\n  for (const node of nodes) {\n    const attributes = createAttributeMap(node);\n\n    for (const [attributeName, attributeValue] of attributes) {\n      // Bail quickly if this isn't a directive\n      if (attributeValue === null || attributeName[0] !== \":\") {\n        continue;\n      }\n\n      // If the second character is not a colon, it is a binding\n      if (attributeName[1] !== \":\") {\n        const bindName = attributeName.slice(1);\n\n        const scheme: AttributeUpdateScheme = {\n          type: \"attr\",\n          notation: parseNotation(attributeValue),\n          attribute: bindName,\n          nodeRef: ensureNodeRef(node),\n        };\n\n        compiledSchemes.push(scheme);\n      }\n\n      // Expect any ::key to have an ::each\n      if (attributeName === Directive.Key) {\n        if (!attributes.has(Directive.Each)) {\n          throw new PaletteError(ErrorCode.TEMPLATE_INVALID_KEY_DIRECTIVE);\n        }\n        continue;\n      }\n\n      // Ensure required notations exist\n      if (requiresNotation.has(attributeName) && attributeValue === \"\") {\n        throw new PaletteError(\n          ErrorCode.TEMPLATE_MISSING_NOTATION,\n          attributeName,\n        );\n      }\n\n      let notation = parsedNotations.get(attributeValue);\n\n      if (notation === undefined) {\n        notation = parseNotation(attributeValue);\n        parsedNotations.set(attributeValue, notation);\n      }\n\n      node.removeAttribute(attributeName);\n\n      // TAG CHANGE SCHEMES\n      if (attributeName === Directive.Tag) {\n        compiledSchemes.push({\n          type: \"tag\",\n          notation,\n          nodeRef: ensureNodeRef(node),\n        });\n      }\n\n      // LIST RENDER SCHEMES\n      else if (attributeName === Directive.Each) {\n        const nodeRef = ensureNodeRef(node);\n\n        // A ::key directive is required with any ::each\n        const keyNotation = node.getAttribute(Directive.Key);\n        if (keyNotation === null) {\n          throw new PaletteError(ErrorCode.TEMPLATE_MISSING_LIST_KEY);\n        }\n\n        node.removeAttribute(Directive.Key);\n\n        const listContentHtml = node.innerHTML;\n\n        while (node.firstChild) {\n          node.removeChild(node.firstChild);\n        }\n\n        const scheme: ListRenderScheme = {\n          type: \"each\",\n          notation,\n          keyNotation: parseNotation(keyNotation),\n          nodeRef,\n          listContentHtml,\n        };\n\n        compiledSchemes.push(scheme);\n      }\n\n      // CONTENT SWAP SCHEMES\n      else if (attributeName === Directive.Swap) {\n        const scheme: ContentSwapScheme = {\n          type: \"swap\",\n          notation,\n          nodeRef: ensureNodeRef(node),\n        };\n\n        compiledSchemes.push(scheme);\n      }\n\n      // CONDITIONAL RENDER SCHEMES\n      else if (attributeName === Directive.If) {\n        const scheme: ConditionalRenderScheme = {\n          type: \"cond\",\n          branches: [],\n        };\n\n        // First branch - this IF\n        node.removeAttribute(Directive.If);\n        const ifBranch: ConditionalRenderSchemeBranch = {\n          type: Directive.If,\n          notation,\n          branchRootRef: ensureNodeRef(node),\n          branchTemplateHTML: node.innerHTML,\n        };\n\n        scheme.branches.push(ifBranch);\n\n        let condNode = node.nextElementSibling;\n\n        // Check future nodes for else-if\n        while (condNode?.hasAttribute(Directive.ElseIf)) {\n          if (!(condNode instanceof HTMLElement)) {\n            break;\n          }\n\n          const baseElseIfNotation = condNode.getAttribute(Directive.ElseIf);\n\n          if (!baseElseIfNotation) {\n            throw new PaletteError(\n              ErrorCode.TEMPLATE_MISSING_NOTATION,\n              Directive.ElseIf,\n            );\n          }\n\n          // If the notation has been parsed before, reuse that\n          let parsedElseIfNotation = parsedNotations.get(baseElseIfNotation);\n\n          if (parsedElseIfNotation === undefined) {\n            parsedElseIfNotation = parseNotation(baseElseIfNotation);\n            parsedNotations.set(baseElseIfNotation, parsedElseIfNotation);\n          }\n\n          condNode.removeAttribute(Directive.ElseIf);\n\n          const elseIfBranch: ConditionalRenderSchemeBranch = {\n            type: Directive.ElseIf,\n            notation: parsedElseIfNotation,\n            branchRootRef: ensureNodeRef(condNode),\n            branchTemplateHTML: condNode.innerHTML,\n          };\n\n          scheme.branches.push(elseIfBranch);\n          condNode = condNode.nextElementSibling;\n        }\n\n        // Else\n        if (\n          condNode &&\n          condNode instanceof HTMLElement &&\n          condNode?.hasAttribute(Directive.Else)\n        ) {\n          condNode.removeAttribute(Directive.Else);\n\n          const elseBranch: ConditionalRenderSchemeBranch = {\n            type: Directive.Else,\n            branchRootRef: ensureNodeRef(condNode),\n            branchTemplateHTML: condNode.innerHTML,\n          };\n\n          scheme.branches.push(elseBranch);\n        }\n\n        compiledSchemes.push(scheme);\n      } else {\n        if (__DEV__) {\n          if (\n            attributeName === Directive.Else ||\n            attributeName === Directive.ElseIf\n          ) {\n            throw new PaletteError(ErrorCode.TEMPLATE_INVALID_CONDITIONAL);\n          }\n\n          console.warn(`Template: ${attributeName} is not a valid directive`);\n        }\n      }\n    }\n  }\n\n  const notations: Record<string, ParsedNotation> = {};\n\n  for (const [key, val] of parsedNotations) {\n    notations[key] = val;\n  }\n\n  const temp = document.createElement(\"div\");\n  temp.appendChild(clonedTemplateElement.cloneNode(true));\n  const html = temp.innerHTML;\n\n  const compiled: CompiledTemplate = {\n    html,\n    schemes: compiledSchemes,\n    notations,\n  };\n\n  // Cache the compiled template and html/fragment combo to prevent needing\n  // to re-create the fragment from HTML again when compiling at runtime\n  compiledTemplateCache.set(source, compiled);\n  saveFragment(html, clonedTemplateElement);\n\n  return compiled;\n}\n",
    "export const SKIPPED_JOB = Symbol(\"noop\");\nexport type SkippedJob = typeof SKIPPED_JOB;\n",
    "import { classify } from \"#helper\";\nimport { serializeAttribute } from \"#util\";\nimport type { AttributeUpdatePlan } from \"../types\";\nimport { SKIPPED_JOB, type SkippedJob } from \"./common\";\n\nexport type AttributeUpdateJob = [\n  node: HTMLElement,\n  name: string,\n  value: string | null,\n];\n\nexport function prepareAttributeJob(\n  plan: AttributeUpdatePlan,\n  values: Map<string, unknown>,\n): AttributeUpdateJob | SkippedJob {\n  const rawValue = values.get(plan.notation.base);\n  let value = typeof rawValue === \"function\" ? rawValue(plan.node) : rawValue;\n\n  // Parse the value with `classify` if setting the class attribute\n  if (plan.attribute === \"class\" && typeof value !== \"string\") {\n    value = classify(value);\n  }\n\n  const serializedValue = serializeAttribute(value);\n  const current = plan.node.getAttribute(plan.attribute);\n\n  if (serializedValue !== current) {\n    return [plan.node, plan.attribute, serializedValue];\n  }\n\n  return SKIPPED_JOB;\n}\n\nexport function runAttributeJobs(jobs: AttributeUpdateJob[]): void {\n  for (const [node, name, value] of jobs) {\n    if (value === null) {\n      node.removeAttribute(name);\n    } else {\n      node.setAttribute(name, value);\n    }\n  }\n}\n",
    "import { ErrorCode, PaletteError } from \"#error\";\nimport { Directive } from \"../directive\";\nimport type {\n  ConditionalRenderPlan,\n  ConditionalRenderPlanBranch,\n} from \"../types\";\nimport type { SkippedJob } from \"./common\";\n\nexport type ConditionalRenderJob = [\n  plan: ConditionalRenderPlan,\n  branch: ConditionalRenderPlanBranch | null,\n  values: Map<string, unknown>,\n];\n\nexport function prepareConditionalRenderJob(\n  plan: ConditionalRenderPlan,\n  values: Map<string, unknown>,\n): ConditionalRenderJob | SkippedJob {\n  // Determine which branch to dipslay\n  let displayedBranch: ConditionalRenderPlanBranch | null = null;\n\n  for (const branch of plan.branches) {\n    if (branch.type === Directive.Else) {\n      displayedBranch = branch;\n      break;\n    } else {\n      const rawValue = values.get(branch.notation.base);\n      const value =\n        typeof rawValue === \"function\" ? rawValue(plan.start) : rawValue;\n\n      if (value) {\n        displayedBranch = branch;\n        break;\n      }\n    }\n  }\n\n  return [plan, displayedBranch, values];\n}\n\nexport function runConditionalRenderJobs(jobs: ConditionalRenderJob[]): void {\n  for (const [plan, branch, values] of jobs) {\n    const parent = plan.start.parentNode;\n\n    if (!parent) {\n      throw new PaletteError(ErrorCode.TEMPLATE_PARENT_REQUIRED);\n    }\n\n    // If the current root and branch root differ, remove content\n    if (branch === null || !Object.is(plan.currentRoot, branch.branchRoot)) {\n      // Remove existing content if the branch has changed\n      const nodesToRemove = new Set<Node>();\n\n      let node: Node | null = plan.start;\n      while (node && node !== plan.end) {\n        if (node instanceof HTMLElement) {\n          nodesToRemove.add(node);\n        }\n        node = node.nextSibling;\n      }\n\n      for (const toRemove of nodesToRemove) {\n        parent.removeChild(toRemove);\n      }\n\n      // Then add the branch root if need be\n      if (branch) {\n        parent.insertBefore(branch.branchRoot, plan.end);\n      }\n    }\n\n    // Null branch -> Render nothing\n    if (branch === null) {\n      continue;\n    }\n\n    // Otherwise render branch template\n    branch.branchTemplate.renderWithValues(branch.branchRoot, values);\n  }\n}\n",
    "import type { AttributeMap } from \"#component\";\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { applyAttributeMap, createAttributeMap } from \"#util\";\nimport { buildValueAccessor } from \"../syntax\";\nimport { Template, type TemplateContext } from \"../template\";\nimport type { ListRenderPlan } from \"../types\";\nimport type { SkippedJob } from \"./common\";\n\nexport type ListRenderJobItem = {\n  context: TemplateContext;\n  attrMap: AttributeMap;\n  root: HTMLElement;\n  template: Template;\n};\n\nexport type ListRenderJob = [plan: ListRenderPlan, list: ListRenderJobItem[]];\n\nfunction fetchListData(\n  plan: ListRenderPlan,\n  values: Map<string, unknown>,\n): Record<string, unknown>[] {\n  const notationValue = values.get(plan.notation.base);\n  const evaluatedValue =\n    typeof notationValue === \"function\"\n      ? notationValue(plan.startMarker.parentNode)\n      : notationValue;\n\n  if (evaluatedValue === null || evaluatedValue === undefined) {\n    return [];\n  }\n\n  if (Array.isArray(evaluatedValue)) {\n    return evaluatedValue;\n  }\n\n  throw new PaletteError(ErrorCode.TEMPLATE_INVALID_LIST_DATA);\n}\n\nfunction collectHTMLElements(start: Node, end: Node): Set<HTMLElement> {\n  let node: Node | null = start;\n  const nodeSet = new Set<HTMLElement>();\n\n  while (node && node !== end) {\n    if (node instanceof HTMLElement) {\n      nodeSet.add(node);\n    }\n\n    node = node.nextSibling;\n  }\n\n  return nodeSet;\n}\n\nexport function prepareListRenderJob(\n  plan: ListRenderPlan,\n  values: Map<string, unknown>,\n): ListRenderJob | SkippedJob {\n  // Fetch the data for rendering the updated list items\n  const listData = fetchListData(plan, values);\n\n  // Empty -> Remove the list contents entirely and exit\n  if (listData.length === 0) {\n    return [plan, []];\n  }\n\n  // Collect existing elements from the DOM for assessment\n  const {\n    rowTemplatesByRoot,\n    rowTemplateElement,\n    rowRootPrototype: rowRootElement,\n  } = plan;\n  const keyAccessor = buildValueAccessor(plan.keyNotation);\n  const listRenderContexts: Map<unknown, ListRenderJobItem> = new Map();\n\n  for (const item of listData) {\n    const context: TemplateContext = {\n      item,\n    };\n\n    const key = keyAccessor(context);\n\n    if (listRenderContexts.has(key)) {\n      throw new PaletteError(\n        ErrorCode.TEMPLATE_DUPLICATE_LIST_KEY,\n        String(key),\n      );\n    }\n\n    // Get or create the HTML Element we expect to see here\n    let rowRoot = plan.rowRootsByKey.get(key);\n\n    if (rowRoot === undefined) {\n      rowRoot = rowRootElement.cloneNode(false) as HTMLElement;\n      plan.rowRootsByKey.set(key, rowRoot);\n    }\n\n    // Get or create the template associated with the row root\n    let rowTemplate = rowTemplatesByRoot.get(rowRoot);\n\n    if (rowTemplate === undefined) {\n      rowTemplate = new Template(rowTemplateElement);\n      rowTemplatesByRoot.set(rowRoot, rowTemplate);\n    }\n\n    const jobItem: ListRenderJobItem = {\n      context,\n      root: rowRoot,\n      template: rowTemplate,\n      attrMap: createAttributeMap(item),\n    };\n\n    listRenderContexts.set(key, jobItem);\n  }\n\n  // Clean up cached data\n  for (const [key, root] of plan.rowRootsByKey) {\n    if (!listRenderContexts.has(key)) {\n      plan.rowRootsByKey.delete(key);\n      plan.rowTemplatesByRoot.delete(root);\n    }\n  }\n\n  return [plan, Array.from(listRenderContexts.values())];\n}\n\nexport function runListRenderJobs(jobs: ListRenderJob[]): void {\n  for (const [plan, renderItems] of jobs) {\n    const { endMarker, listContainer: listContainerElement } = plan;\n\n    // Fast path for empty lists -> Remove everything and continue\n    if (renderItems.length === 0) {\n      for (const root of plan.rowRootsByKey.values()) {\n        root.remove();\n      }\n      plan.rowRootsByKey.clear();\n      continue;\n    }\n\n    // Otherwise, scan the current nodes and modify as needed\n    const existingDOMNodes = Array.from(\n      collectHTMLElements(plan.startMarker, plan.endMarker),\n    );\n\n    const rootsToKeep = new Set<HTMLElement>();\n\n    let existingDOMNodeIdx = 0;\n\n    for (const renderItem of renderItems) {\n      const { root, attrMap, context, template } = renderItem;\n      const existingDOMNode = existingDOMNodes[existingDOMNodeIdx];\n\n      // Spread item as attributes on the root and update the template\n      applyAttributeMap(root, attrMap);\n      template.render(root, context);\n\n      rootsToKeep.add(root);\n\n      // Node is the existing DOM Node, continue\n      if (Object.is(existingDOMNode, root)) {\n        existingDOMNodeIdx += 1;\n        continue;\n      }\n\n      // No existing node -> append item\n      if (!existingDOMNode) {\n        listContainerElement.insertBefore(root, endMarker);\n        continue;\n      }\n\n      // DOM node exists but isn't the one we're looking for. Insert before.\n      listContainerElement.insertBefore(root, existingDOMNode);\n    }\n\n    // Remove any remaining old elements\n    for (const root of existingDOMNodes) {\n      if (!rootsToKeep.has(root)) {\n        root.remove();\n        plan.rowTemplatesByRoot.delete(root);\n      }\n    }\n  }\n}\n",
    "import { ErrorCode, PaletteError } from \"#error\";\nimport type { ContentSwapPlan } from \"../types\";\nimport { SKIPPED_JOB, type SkippedJob } from \"./common\";\n\nexport type ContentSwapJob = [plan: ContentSwapPlan, swap: Node];\n\nexport function prepareContentSwapJob(\n  plan: ContentSwapPlan,\n  values: Map<string, unknown>,\n): ContentSwapJob | SkippedJob {\n  const rawValue = values.get(plan.notation.base);\n  const value = typeof rawValue === \"function\" ? rawValue(plan.node) : rawValue;\n\n  // String, Number, Boolean -> Text Node\n  if (\n    typeof value === \"string\" ||\n    typeof value === \"number\" ||\n    typeof value === \"boolean\"\n  ) {\n    const asStr = `${value}`;\n    if (plan.node.textContent === asStr) {\n      return SKIPPED_JOB;\n    }\n\n    return [plan, document.createTextNode(asStr)];\n  }\n\n  // Nullish values -> Comment\n  else if (value === null || value === undefined) {\n    if (plan.node instanceof Comment) {\n      return SKIPPED_JOB;\n    }\n\n    return [plan, document.createComment(\"empty\")];\n  }\n\n  // HTMLElement -> Swap nodes\n  else if (value instanceof HTMLElement) {\n    if (Object.is(plan.node, value)) {\n      return SKIPPED_JOB;\n    }\n\n    return [plan, value.cloneNode(true)];\n  }\n\n  // Anything else -> Unsupported\n  else {\n    throw new PaletteError(\n      ErrorCode.INVALID_CONTENT,\n      typeof value,\n      JSON.stringify(value),\n    );\n  }\n}\n\nexport function runContentSwapJobs(jobs: ContentSwapJob[]): void {\n  for (const [plan, replace] of jobs) {\n    const parent = plan.node.parentNode;\n\n    if (!parent) {\n      // Should never happen in practice\n      throw new PaletteError(ErrorCode.INVARIANT);\n    }\n\n    parent.replaceChild(replace, plan.node);\n    plan.node = replace;\n  }\n}\n",
    "import type { TagChangePlan } from \"../types\";\nimport { SKIPPED_JOB, type SkippedJob } from \"./common\";\n\nexport type TagChangeJob = [plan: TagChangePlan, newTag: string];\n\n/**\n * Given an element, replace it with a different tag, adopting all attributes\n * and child elements.\n * @param $target The element to swap out\n * @param newTag The new HTML tagName to use\n * @returns The newly swapped-in element\n */\nexport function changeTag($target: HTMLElement, newTag: string): HTMLElement {\n  const $newEl = document.createElement(newTag);\n\n  while ($target.firstChild !== null) {\n    $newEl.appendChild($target.firstChild);\n  }\n\n  for (const attrName of $target.getAttributeNames()) {\n    const val = $target.getAttribute(attrName);\n\n    if (val !== null) {\n      $newEl.setAttribute(attrName, val);\n    }\n  }\n\n  $target.replaceWith($newEl);\n  return $newEl;\n}\n\nexport function prepareTagChangeJob(\n  plan: TagChangePlan,\n  values: Map<string, unknown>,\n): TagChangeJob | SkippedJob {\n  const rawValue = values.get(plan.notation.base) ?? \"\";\n  const value = typeof rawValue === \"function\" ? rawValue(plan.node) : rawValue;\n  const nextTag = `${value}`.toLowerCase();\n  const currentTag = plan.node.tagName.toLowerCase();\n\n  if (!nextTag || nextTag === currentTag) {\n    return SKIPPED_JOB;\n  }\n\n  return [plan, nextTag];\n}\n\nexport function runTagChangeJobs(jobs: TagChangeJob[]): void {\n  for (const [plan, nextTag] of jobs) {\n    plan.node = changeTag(plan.node, nextTag);\n  }\n}\n",
    "import { ErrorCode, PaletteError } from \"#error\";\nimport type { AnyRenderPlan } from \"../types\";\nimport {\n  type AttributeUpdateJob,\n  prepareAttributeJob,\n  runAttributeJobs,\n} from \"./attribute\";\nimport { SKIPPED_JOB } from \"./common\";\nimport {\n  type ConditionalRenderJob,\n  prepareConditionalRenderJob,\n  runConditionalRenderJobs,\n} from \"./conditional\";\nimport {\n  type ListRenderJob,\n  prepareListRenderJob,\n  runListRenderJobs,\n} from \"./list\";\nimport {\n  type ContentSwapJob,\n  prepareContentSwapJob,\n  runContentSwapJobs,\n} from \"./swap\";\nimport {\n  prepareTagChangeJob,\n  runTagChangeJobs,\n  type TagChangeJob,\n} from \"./tag\";\n\nexport * from \"./attribute\";\nexport * from \"./common\";\nexport * from \"./conditional\";\nexport * from \"./list\";\nexport * from \"./swap\";\nexport * from \"./tag\";\n\ninterface RenderJobs {\n  conditionals: ConditionalRenderJob[];\n  attributes: AttributeUpdateJob[];\n  swaps: ContentSwapJob[];\n  tags: TagChangeJob[];\n  lists: ListRenderJob[];\n}\n\nexport function createJobsFromPlans(\n  plans: Set<AnyRenderPlan>,\n  newValues: Map<string, unknown>,\n): RenderJobs {\n  const jobs: RenderJobs = {\n    conditionals: [],\n    attributes: [],\n    swaps: [],\n    tags: [],\n    lists: [],\n  };\n\n  for (const plan of plans) {\n    switch (plan.type) {\n      case \"cond\": {\n        const job = prepareConditionalRenderJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.conditionals.push(job);\n        }\n        break;\n      }\n      case \"attr\": {\n        const job = prepareAttributeJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.attributes.push(job);\n        }\n        break;\n      }\n      case \"each\": {\n        const job = prepareListRenderJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.lists.push(job);\n        }\n        break;\n      }\n      case \"swap\": {\n        const job = prepareContentSwapJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.swaps.push(job);\n        }\n        break;\n      }\n      case \"tag\": {\n        const job = prepareTagChangeJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.tags.push(job);\n        }\n        break;\n      }\n      default:\n        // Should be impossible given an exhaustive switch case\n        throw new PaletteError(ErrorCode.INVARIANT);\n    }\n  }\n\n  return jobs;\n}\n\nexport function executeRenderJobs(jobs: RenderJobs): void {\n  runConditionalRenderJobs(jobs.conditionals);\n  runAttributeJobs(jobs.attributes);\n  runListRenderJobs(jobs.lists);\n  runContentSwapJobs(jobs.swaps);\n  runTagChangeJobs(jobs.tags);\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { htmlToFragment } from \"#util\";\nimport type { CompiledTemplate } from \"./compile\";\nimport { REF_ATTR } from \"./constant\";\nimport { Directive } from \"./directive\";\nimport { buildValueAccessor, type NotationAccessor } from \"./syntax\";\nimport type { Template } from \"./template\";\nimport type {\n  AnyRenderPlan,\n  AttributeUpdatePlan,\n  ConditionalRenderPlan,\n  ContentSwapPlan,\n  ListRenderPlan,\n  TagChangePlan,\n} from \"./types\";\nimport { htmlStringToTemplate } from \"./util\";\n\n/**\n * A pre-processed {@link CompiledTemplate} result containing the bulk of the\n * data necessary to create a template instance.\n */\nexport interface PreparedTemplate {\n  fragment: DocumentFragment;\n  plansByNotation: Map<string, Set<AnyRenderPlan>>;\n  notationAccessors: Map<string, NotationAccessor>;\n  subtemplates: Set<Template>;\n}\n\nconst requireParentNode = (node: Node): Node => {\n  if (!node.parentNode) {\n    throw new PaletteError(ErrorCode.TEMPLATE_PARENT_REQUIRED);\n  }\n\n  return node.parentNode;\n};\n\nconst createCommentBefore = (node: Node, text = \"\"): Comment => {\n  const parent = requireParentNode(node);\n  const comment = document.createComment(text);\n  parent.insertBefore(comment, node);\n  return comment;\n};\n\nconst createCommentAfter = (node: Node, text = \"\"): Comment => {\n  const parent = requireParentNode(node);\n  const comment = document.createComment(text);\n  parent.insertBefore(comment, node.nextSibling);\n  return comment;\n};\n\n/**\n * Given a {@link CompiledTemplate} structure, return an object containing the\n * data needed to create new Template instances.\n *\n * @example\n *\n * ```typescript\n * const compiledTemplate = getCompiledTemplateJSON();\n * const parsed = JSON.parse(compiledTemplate);\n * const prepared = prepareCompiledTemplate(parsed);\n *\n * // Elsewhere...\n *\n * const template = new Template(prepared);\n * ```\n */\nexport function prepareCompiledTemplate(\n  compiled: CompiledTemplate,\n  prototypeFragment?: DocumentFragment,\n): PreparedTemplate {\n  const plansByNotation: Map<string, Set<AnyRenderPlan>> = new Map();\n  const notationAccessors: Map<string, NotationAccessor> = new Map();\n  const subtemplates: Set<Template> = new Set();\n  const nodeRefs: Map<string, HTMLElement> = new Map();\n\n  for (const [notation, parsed] of Object.entries(compiled.notations)) {\n    notationAccessors.set(notation, buildValueAccessor(parsed));\n  }\n\n  const fragment = prototypeFragment ?? htmlToFragment(compiled.html);\n\n  const walker = document.createTreeWalker(fragment, NodeFilter.SHOW_ELEMENT, {\n    acceptNode(node: HTMLElement) {\n      return node.hasAttribute(REF_ATTR)\n        ? NodeFilter.FILTER_ACCEPT\n        : NodeFilter.FILTER_SKIP;\n    },\n  });\n\n  let markNode: Node | null = walker.nextNode();\n\n  while (markNode) {\n    if (!(markNode instanceof HTMLElement)) {\n      continue;\n    }\n\n    const ref = markNode.getAttribute(REF_ATTR);\n\n    if (ref === null) {\n      // Should never happen in practice, as the tree walker only surfaces\n      // elements with an extant node ref attribute\n      throw new PaletteError(ErrorCode.INVARIANT);\n    }\n\n    nodeRefs.set(ref, markNode);\n    markNode.removeAttribute(REF_ATTR);\n    markNode = walker.nextNode();\n  }\n\n  const associatePlan = (plan: AnyRenderPlan, notation: string) => {\n    let notationPlans = plansByNotation.get(notation);\n    if (!notationPlans) {\n      notationPlans = new Set();\n      plansByNotation.set(notation, notationPlans);\n    }\n    notationPlans.add(plan);\n  };\n\n  const getByNodeRef = (nodeRef: string): HTMLElement => {\n    const cached = nodeRefs.get(nodeRef);\n\n    if (cached) {\n      return cached;\n    }\n\n    throw new PaletteError(ErrorCode.MISSING_NODE_REF);\n  };\n\n  for (const scheme of compiled.schemes) {\n    // Hydrate List schemes into List plans\n    if (scheme.type === \"each\") {\n      // Use the prototype row root to create the plan\n      const itemPrototype = getByNodeRef(scheme.nodeRef);\n      const listParentNode = requireParentNode(itemPrototype);\n      const rowRootPrototype = itemPrototype.cloneNode(false) as HTMLElement;\n      const startMarker = createCommentBefore(itemPrototype);\n      const endMarker = createCommentAfter(itemPrototype);\n\n      // Remove the original root prototype since we will be rendering new items\n      itemPrototype.remove();\n\n      // Copy the contents of the row into a template\n      const templateContentFragment = htmlToFragment(scheme.listContentHtml);\n      const rowTemplateElement = document.createElement(\"template\");\n      rowTemplateElement.content.appendChild(templateContentFragment);\n\n      const plan: ListRenderPlan = {\n        type: \"each\",\n        notation: scheme.notation,\n        keyNotation: scheme.keyNotation,\n        listContainer: listParentNode,\n        rowTemplateElement,\n        rowRootPrototype,\n        startMarker,\n        endMarker,\n        rowTemplatesByRoot: new WeakMap(),\n        rowRootsByKey: new Map(),\n      };\n\n      associatePlan(plan, scheme.notation.base);\n    }\n\n    // Hydrate conditional render schemes into plans\n    else if (scheme.type === \"cond\") {\n      // Grab the first branch and insert the start comment before it\n      const firstBranch = scheme.branches[0];\n      if (!firstBranch) {\n        throw new PaletteError(ErrorCode.INVARIANT);\n      }\n\n      const firstBranchRoot = getByNodeRef(firstBranch.branchRootRef);\n      const startComment = createCommentBefore(firstBranchRoot);\n\n      // Grab the last branch and insert the end comment after it\n      // biome-ignore lint/style/noNonNullAssertion: Logically guaranteed\n      const lastBranch = scheme.branches[scheme.branches.length - 1]!;\n      const lastBranchRoot = getByNodeRef(lastBranch.branchRootRef);\n      const endComment = createCommentAfter(lastBranchRoot);\n\n      const plan: ConditionalRenderPlan = {\n        type: \"cond\",\n        start: startComment,\n        end: endComment,\n        branches: [],\n      };\n\n      // Hydrate the branches\n      for (const branch of scheme.branches) {\n        // If and Else-If have notations\n        if (branch.type === Directive.If || branch.type === Directive.ElseIf) {\n          const branchRoot = getByNodeRef(branch.branchRootRef);\n          const branchTemplate = htmlStringToTemplate(\n            branch.branchTemplateHTML,\n          );\n\n          // Add the child template\n          subtemplates.add(branchTemplate);\n\n          plan.branches.push({\n            type: branch.type,\n            notation: branch.notation,\n            branchRoot: getByNodeRef(branch.branchRootRef),\n            branchTemplate: htmlStringToTemplate(branch.branchTemplateHTML),\n          });\n          associatePlan(plan, branch.notation.base);\n          branchRoot.remove();\n        }\n\n        // Else is binary, no notation associated\n        else {\n          plan.branches.push({\n            type: branch.type,\n            branchRoot: getByNodeRef(branch.branchRootRef),\n            branchTemplate: htmlStringToTemplate(branch.branchTemplateHTML),\n          });\n        }\n      }\n    }\n\n    // Swap/Tag are the same signature\n    else if (scheme.type === \"swap\" || scheme.type === \"tag\") {\n      const plan: ContentSwapPlan | TagChangePlan = {\n        type: scheme.type,\n        notation: scheme.notation,\n        node: getByNodeRef(scheme.nodeRef),\n      };\n\n      associatePlan(plan, scheme.notation.base);\n    }\n\n    // Hydrate Attribute update plans\n    else if (scheme.type === \"attr\") {\n      const plan: AttributeUpdatePlan = {\n        type: \"attr\",\n        attribute: scheme.attribute,\n        notation: scheme.notation,\n        node: getByNodeRef(scheme.nodeRef),\n      };\n\n      associatePlan(plan, plan.notation.base);\n    }\n  }\n\n  return {\n    plansByNotation,\n    notationAccessors,\n    fragment,\n    subtemplates,\n  };\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { fragmentCache, htmlToFragment } from \"../util/fragments\";\nimport {\n  type CompiledTemplate,\n  compiledTemplateCache,\n  compileTemplate,\n} from \"./compile\";\nimport { createJobsFromPlans, executeRenderJobs } from \"./jobs\";\nimport { prepareCompiledTemplate } from \"./prepare\";\nimport {\n  type NotationAccessor,\n  parsedNotationCache,\n  valueAccessorCache,\n} from \"./syntax\";\nimport type { AnyRenderPlan } from \"./types\";\n\nexport type TemplateRoot = HTMLElement | ShadowRoot;\nexport type TemplateContext = {\n  attr?: Record<string, string | null>;\n  state?: Record<string, unknown>;\n  data?: Record<string, unknown>;\n  item?: Record<string, unknown>;\n  index?: number;\n};\n\n/**\n * A renderable template from an HTMLTemplateElement\n *\n * Leverages a simple syntax to provide accessors to template data from one of\n * four categories, based on use case:\n *\n * ```\n * `@` -> The `attr` namespace (the host element's attributes)\n * `$` -> The `state` namespace (the host element's reactive state)\n * `*` -> The `data` namespace (the host element's computed data)\n * `#` -> The `item` namespace (list item access with ::each)\n * ```\n *\n * Bind attributes to a value using the `:attribute` syntax:\n *\n * ```html\n * <div :id=\"$id\" :class=\"@classname\"></div>\n * ```\n */\nexport class Template {\n  /**\n   * Properties related to the global Template build cache.\n   *\n   * This is not something typically needed for general app development, but\n   * allows for advanced configuration to tune the caching system if need be.\n   *\n   * Cache sizes default to 500 HTML Template Fragments and compiled Palette\n   * templates (includes nested templates like lists) to cover most application\n   * needs without using much memory.\n   */\n  static cache = {\n    /**\n     * Wipe all cached templates and HTML fragments\n     */\n    clear: (): void => {\n      fragmentCache.clear();\n      compiledTemplateCache.clear();\n      valueAccessorCache.clear();\n      parsedNotationCache.clear();\n    },\n\n    /**\n     * the default cache capacity of 500 items per cache\n     *\n     * General caching guidance:\n     * - 95% of the time, 500 works fine\n     * - For very large applications, up to 1000 is reasonable\n     * - For smaller apps, dropping down to 100 - 250 may save memory\n     *\n     * Ultimately the impact will be minimal unless your app has very specific\n     * rendering needs.\n     */\n    setCapacity: (maxSize: number): void => {\n      fragmentCache.setCapacity(maxSize);\n      compiledTemplateCache.setCapacity(maxSize);\n      valueAccessorCache.setCapacity(maxSize);\n      parsedNotationCache.setCapacity(maxSize);\n    },\n  };\n\n  private _compiled: CompiledTemplate;\n\n  /**\n   * The original {@link HTMLTemplateElement} used to create this Template.\n   *\n   * @remarks\n   * Make sure to never operate directly on this element. Always clone.\n   */\n  private _templateElement?: HTMLTemplateElement;\n\n  /** The current known root element that this Template is rendered into */\n  private _mountedRoot?: TemplateRoot;\n\n  /** The most recent set value for each notation that has rendered */\n  private _latestRenderedValues: Map<string, unknown> = new Map();\n\n  /** The active HTMLElement which the template is updating on renders */\n  private _fragment: DocumentFragment;\n\n  /** Value Notations -> Set<Render Plans> */\n  private _plansByNotation: Map<string, Set<AnyRenderPlan>> = new Map();\n\n  /** Value Notations -> Accessor functions */\n  private _notationAccessors: Map<string, NotationAccessor> = new Map();\n\n  private _subtemplates: Set<Template> = new Set();\n\n  constructor(template: HTMLTemplateElement) {\n    this._templateElement = template;\n    this._compiled = compileTemplate(template);\n\n    // Prepare a fragment from the compiled HTML (cached)\n    const fragment = htmlToFragment(this._compiled.html);\n    const hydrated = prepareCompiledTemplate(this._compiled, fragment);\n\n    this._plansByNotation = hydrated.plansByNotation;\n    this._notationAccessors = hydrated.notationAccessors;\n    this._fragment = hydrated.fragment;\n    this._subtemplates = hydrated.subtemplates;\n\n    const allRelevantAccessors = new Map<string, NotationAccessor>(\n      this._notationAccessors,\n    );\n\n    for (const child of this._subtemplates) {\n      for (const [key, val] of child.notationMap) {\n        allRelevantAccessors.set(key, val);\n      }\n    }\n\n    this._notationAccessors = allRelevantAccessors;\n  }\n\n  get compiled(): CompiledTemplate {\n    return this._compiled;\n  }\n\n  get notationMap(): Map<string, NotationAccessor> {\n    return this._notationAccessors;\n  }\n\n  /**\n   * Create a full copy of this template for use in rendering to another root\n   */\n  clone = (): Template => {\n    return new Template(this.element());\n  };\n\n  /**\n   * @returns An {@link HTMLTemplateElement} representing this template\n   */\n  element = (): HTMLTemplateElement => {\n    if (this._templateElement) {\n      return this._templateElement;\n    }\n\n    const template = document.createElement(\"template\");\n    template.innerHTML = this._compiled.html;\n    return template;\n  };\n\n  private _collectUpdatedValues = (\n    context: TemplateContext,\n  ): [hasChanges: boolean, values: Map<string, unknown>] => {\n    const updatedValues = new Map<string, unknown>();\n    let hasChanges = false;\n\n    for (const [rawNotation, accessor] of this._notationAccessors) {\n      const previousValue = this._latestRenderedValues.get(rawNotation);\n      const newValue = accessor(context);\n      updatedValues.set(rawNotation, newValue);\n\n      if (previousValue !== newValue && !Object.is(previousValue, newValue)) {\n        hasChanges = true;\n      }\n    }\n\n    return [hasChanges, updatedValues];\n  };\n\n  private _update(newValues: Map<string, unknown>) {\n    // Collect affected plans\n    const allAffectedPlans: Set<AnyRenderPlan> = new Set();\n\n    for (const [notation] of newValues) {\n      const affectedPlans = this._plansByNotation.get(notation);\n\n      if (!affectedPlans) {\n        continue;\n      }\n\n      for (const plan of affectedPlans) {\n        allAffectedPlans.add(plan);\n      }\n    }\n\n    const jobs = createJobsFromPlans(allAffectedPlans, newValues);\n    executeRenderJobs(jobs);\n  }\n\n  renderWithValues = (\n    root: TemplateRoot,\n    values: Map<string, unknown>,\n  ): void => {\n    if (root !== this._mountedRoot) {\n      this._mountedRoot = root;\n      while (root.firstChild) {\n        root.removeChild(root.firstChild);\n      }\n\n      root.append(this._fragment);\n    }\n\n    this._update(values);\n  };\n\n  /**\n   * Render this template into a target host element.\n   */\n  render = (root: TemplateRoot, context: TemplateContext): void => {\n    const [hasChanges, resolvedValues] = this._collectUpdatedValues(context);\n\n    // If no values have changed, exit early\n    if (root === this._mountedRoot && !hasChanges) {\n      return;\n    }\n\n    this.renderWithValues(root, resolvedValues);\n    this._latestRenderedValues = resolvedValues;\n  };\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { elementMatches } from \"#util\";\nimport type { Component } from \"./component\";\n\nexport type EventName = keyof GlobalEventHandlersEventMap;\nexport type EventHandler<K extends EventName = EventName> = (\n  event: GlobalEventHandlersEventMap[K],\n) => void;\n\ntype EventHandlerMap = Map<string, EventHandler>;\n\n/**\n * Managed event delegation to coalesce event listeners for an entire tree into\n * single root-level listeners.\n *\n * @example\n * Listen for events from any child element of the delegated root\n *\n * ```typescript\n * const delegator = new EventDelegator($root);\n * delegator.addDelegatedListener(\"click\", handleClick);\n * ```\n *\n * @example\n * Listen for events from child elements matching `.action`\n *\n * ```typescript\n * const delegator = new EventDelegator($root);\n * delegator.addDelegatedListener(\"click\", handleClick, \".action\");\n * ```\n */\nexport class EventDelegator {\n  static nextListenerId = 0;\n\n  static processTargetDescriptor(\n    targetDescriptor: string | typeof Component<any> | HTMLElement,\n  ): string {\n    // Create a query filter from the target descriptor\n    if (targetDescriptor instanceof HTMLElement) {\n      // If the element has an ID, use that\n      if (targetDescriptor.id.length) {\n        return `#${targetDescriptor.id}`;\n      } else {\n        const generatedId = `listen-${EventDelegator.nextListenerId++}`;\n        targetDescriptor.setAttribute(\"data-listener-id\", generatedId);\n        return `[data-listener-id=\"${generatedId}\"]`;\n      }\n    } else if (typeof targetDescriptor === \"function\") {\n      if (__DEV__) {\n        if (targetDescriptor.tagName.length === 0) {\n          console.warn(\n            `[Component] Automatic listener setup failure: Component ${targetDescriptor.name} has no defined tagname`,\n          );\n        }\n      }\n\n      // If the target descriptor is a Component class, pull the tagname\n      return targetDescriptor.tagName;\n    }\n\n    return targetDescriptor;\n  }\n\n  private _root: HTMLElement | ShadowRoot | Document;\n  private _rootListeners: EventHandlerMap = new Map();\n  private _events: Map<string, Map<string, Set<EventHandler>>> = new Map();\n\n  constructor(root: HTMLElement | ShadowRoot | Document = document) {\n    this._root = root;\n  }\n\n  private _handlersForEvent(event: string): Map<string, Set<EventHandler>> {\n    let handlerMap = this._events.get(event);\n\n    if (handlerMap === undefined) {\n      handlerMap = new Map();\n      this._events.set(event, handlerMap);\n    }\n\n    return handlerMap;\n  }\n\n  private _handlersForEventAndQuery<E extends EventName>(\n    event: E,\n    query: string,\n  ): Set<EventHandler<E>> {\n    const handlerMap = this._handlersForEvent(event);\n    let handlerSet = handlerMap.get(query);\n\n    if (handlerSet === undefined) {\n      handlerSet = new Set();\n      handlerMap.set(query, handlerSet);\n    }\n\n    return handlerSet;\n  }\n\n  private _createRootListener(eventName: string): void {\n    if (this._rootListeners.has(eventName)) {\n      return;\n    }\n\n    const listener = (event: Event) => {\n      const handlersForEvent = this._handlersForEvent(eventName);\n      const { target } = event;\n\n      if (target === null || !(target instanceof Node)) {\n        return;\n      }\n\n      let node: Node | null = target;\n\n      let stopImmediateCalled = false;\n      const originalFn = event.stopImmediatePropagation;\n      event.stopImmediatePropagation = () => {\n        originalFn.call(event);\n        stopImmediateCalled = true;\n      };\n\n      while (node) {\n        if (node === this._root) {\n          break;\n        }\n\n        // Skip invalid elements\n        if (!(node instanceof Element)) {\n          node = node.parentNode;\n          continue;\n        }\n\n        // Invoke handlers\n        for (const [query, handlers] of handlersForEvent) {\n          if (query === \"*\" || elementMatches(node, query)) {\n            for (const handler of handlers) {\n              handler.call(node, event);\n\n              // Respect .stopImmediatePropagation() and .preventDefault()\n              if (stopImmediateCalled || event.defaultPrevented) {\n                return;\n              }\n            }\n          }\n        }\n\n        // Respect .stopPropagation()\n        if (event.cancelBubble) {\n          return;\n        }\n\n        node = node.parentNode;\n\n        if (node === this._root || node instanceof ShadowRoot) {\n          break;\n        }\n      }\n    };\n\n    this._rootListeners.set(eventName, listener);\n    this._root.addEventListener(eventName, listener);\n  }\n\n  addListener<E extends EventName>(\n    eventName: E,\n    handler: EventHandler<E>,\n    queryFilter: string = \"*\",\n  ): void {\n    this._handlersForEventAndQuery(eventName, queryFilter).add(handler);\n    this._createRootListener(eventName);\n  }\n\n  removeListener(\n    eventName: EventName,\n    handler: EventHandler,\n    queryFilter: string,\n  ): void {\n    const handlerSet = this._handlersForEventAndQuery(eventName, queryFilter);\n    handlerSet.delete(handler);\n\n    // If that was the last handler for that event/query combo, delete the set\n    if (handlerSet.size === 0) {\n      const eventHandlerSets = this._handlersForEvent(eventName);\n      eventHandlerSets.delete(queryFilter);\n    }\n  }\n\n  cleanup = (): void => {\n    for (const [event, handler] of this._rootListeners) {\n      this._root.removeEventListener(event, handler);\n    }\n\n    this._rootListeners.clear();\n  };\n}\n",
    "/*\n * Copyright © Rustic Arcade, LLC 2026\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { css } from \"#helper\";\nimport { State } from \"#state\";\nimport { Template, type TemplateContext } from \"#template\";\nimport { createAttributeMap, serializeAttribute } from \"#util\";\nimport { EventDelegator, type EventHandler, type EventName } from \"./delegator\";\nimport type {\n  AttributeMap,\n  ComponentStyles,\n  ComputedProperties,\n  LiveAttributes,\n  StateInitializer,\n} from \"./types\";\n\nconst MAX_SEQUENTIAL_RENDERS = 10000;\nconst BLANK_TEMPLATE = document.createElement(\"template\");\n\nexport enum RootMode {\n  Closed = \"closed\",\n  Open = \"open\",\n}\n\ntype InternalRenderStatus = {\n  isFinalized: boolean;\n  initialRenderComplete: boolean;\n  willRender: boolean;\n  isRendering: boolean;\n  sequentialRenders: number;\n  postRenderCallbacks: VoidFunction[];\n  lastRenderedAttributeMap: AttributeMap;\n  trackedAttributeChanges: AttributeMap;\n};\n\n/**\n * The **Component** class extends the base HTMLElement class to provide an\n * ergonomic way to design and develop Web Components with reactive state,\n * managed attributes, and dynamic templating.\n */\nexport abstract class Component<\n  StateShape extends object = {},\n> extends HTMLElement {\n  // ╭────────────────────────────────────────────────────────╮\n  // │       Static Component Configuration Properties        │\n  // ╰────────────────────────────────────────────────────────╯\n\n  /** The HTML tag name to use for this Component */\n  static tagName: string = \"\";\n\n  /** An HTML Template element for this element to use. */\n  static template: HTMLTemplateElement | Template = BLANK_TEMPLATE;\n\n  /**\n   * Styles for this Component\n   */\n  static styles: ComponentStyles = [];\n\n  /**\n   * A list of attribute names to track changes for\n   *\n   * @remarks\n   * If you use the {@link define} factory helper, this value will be\n   * automatically merged with a list of any defined {@link liveAttributes}.\n   */\n  static observedAttributes: string[] = [];\n\n  /**\n   * The mode for this Component's ShadowRoot. Must be a {@link RootMode}\n   */\n  static rootMode: RootMode = RootMode.Closed;\n\n  // ╭────────────────────────────────────────────────────────╮\n  // │                  Lifecycle Properties                  │\n  // ╰────────────────────────────────────────────────────────╯\n\n  /**\n   * Initialization lifecycle method. Main scripting and event listeners.\n   * @returns a function to handle cleanup tasks when the component unmounts\n   */\n  protected script?(): VoidFunction | void;\n\n  /** Called immediately before each template update */\n  protected beforeUpdate?(): void;\n\n  /** Called immediately after each template update */\n  protected afterUpdate?(previousAttributes: AttributeMap): void;\n\n  /** Final lifecycle method called at the end of the unmounting process. */\n  protected finalize?(): void;\n\n  /**\n   * When defined, catches any errors thrown during lifecycle mthods of this\n   * component as well as any uncaught errors from child components.\n   *\n   * @example\n   *\n   * Recovering from errors or displaying a fallback\n   *\n   * ```typescript\n   * onError(error) {\n   *   if (error.canRecover) {\n   *     this.recover();\n   *     return;\n   *   }\n   *\n   *   this.replaceWith(\"Oh dear, an error happened real bad\");\n   * }\n   * ```\n   */\n  protected onError?(error: unknown): void;\n\n  /**\n   * The initial value for this Component's reactive internal state, if any.\n   *\n   * @remarks\n   * If `initialState` is defined as a function, the function is evaluated at\n   * mounting time and the return value is used as the initial state.\n   */\n  protected initialState?: StateInitializer<StateShape>;\n\n  /**\n   * An object or function returning an object which populates the `data` values\n   * in the templating engine. Such values are accessed using the `*` notation.\n   *\n   * @example\n   *\n   * ```typescript\n   * host = {\n   *   avatarUrl: \"http://...\",\n   *   renderTime: () => new Date().toISOString(),\n   * }\n   * ```\n   *\n   * ```html\n   * <img :src=\"*avatarUrl\" />\n   * <span>Rendered at ${\"*renderTime\"}</span>\n   * ```\n   */\n  protected computedProperties?: ComputedProperties<StateShape>;\n\n  /**\n   * Define attribute update and reflection behaviors as a record of attribute\n   * name keys to objects with optionally defined behaviors.\n   *\n   * @example\n   *\n   * ```typescript\n   * liveAttributes = {\n   *   done: {\n   *     onChange(newValue) {\n   *       this.state.set(\"done\", !!newValue);\n   *     },\n   *     reflect() { return this.state.current.done }\n   *   }\n   * };\n   * ```\n   *\n   * @remarks\n   * The optional functions are:\n   *\n   * `onChange(newValue, oldValue): void`, a handler function for when the value\n   * of this attribute has changed. Runs once per update cycle, *before* the\n   * update occurs.\n   *\n   * `reflect(): unknown`, a function which returns a value to serialize and set\n   * as this attribute *after* an update completes.\n   *\n   * If using the {@link define} helper, the keys of this property are\n   * automatically merged with any defined {@link observedAttributes}.\n   */\n  protected liveAttributes?: LiveAttributes<StateShape>;\n\n  // ╭────────────────────────────────────────────────────────╮\n  // │               Internal State Management                │\n  // ╰────────────────────────────────────────────────────────╯\n\n  private _template: Template;\n  private _root: ShadowRoot;\n  private _state?: State<StateShape>;\n  private _delegator?: EventDelegator;\n  private _ownListeners?: Set<{\n    handler: EventHandler;\n    event: EventName;\n  }> = new Set();\n  private _cleanupFn?: VoidFunction;\n\n  private _renderInternals: InternalRenderStatus = {\n    isFinalized: false,\n    initialRenderComplete: false,\n    willRender: false,\n\n    /** When set to `true`, the render/update process is actively running */\n    isRendering: false,\n    sequentialRenders: 0,\n    postRenderCallbacks: [],\n    lastRenderedAttributeMap: new Map(),\n    trackedAttributeChanges: new Map(),\n  };\n\n  // ╭────────────────────────────────────────────────────────╮\n  // │             Internals and Private Methods              │\n  // ╰────────────────────────────────────────────────────────╯\n\n  constructor() {\n    super();\n\n    const { template, styles, rootMode } = this.constructor as typeof Component;\n\n    // Normalize styles to an array of CSSStyleSheet objects\n    const newStyles = Array.isArray(styles)\n      ? styles\n      : typeof styles === \"object\"\n        ? [styles]\n        : [css`${styles}`];\n\n    this._root = this.attachShadow({ mode: rootMode });\n    this._root.adoptedStyleSheets.push(...newStyles);\n    this._template =\n      template instanceof Template ? template : new Template(template);\n  }\n\n  /** Produce the data object to pass to the template's render function */\n  private _getRenderContext(attr: AttributeMap): TemplateContext {\n    return {\n      attr: Object.fromEntries(attr),\n      data:\n        typeof this.computedProperties === \"function\"\n          ? this.computedProperties()\n          : this.computedProperties,\n      state: this._state ? this._state.current : undefined,\n    };\n  }\n\n  private _escalateError(error: unknown): void {\n    let node: Node | null = this.parentNode;\n\n    while (node) {\n      if (\n        node instanceof Component &&\n        \"onError\" in node &&\n        typeof node.onError === \"function\"\n      ) {\n        node.onError(error);\n        return;\n      } else if (node instanceof ShadowRoot) {\n        node = node.host;\n      } else {\n        node = node.parentNode;\n      }\n    }\n\n    // If nothing was found to escalate to, throw the error\n    throw error;\n  }\n\n  private _reportError(error: unknown): void {\n    if (!this.onError) {\n      this._escalateError(error);\n    } else {\n      this.onError(error);\n    }\n  }\n\n  private _executeAttributeChangeHandlers = () => {\n    if (!this.liveAttributes) {\n      return;\n    }\n\n    const prevAttrs = this._renderInternals.lastRenderedAttributeMap;\n\n    // Copy the changes to a new map and clear the tracking map\n    const trackedChanges = new Map(\n      this._renderInternals.trackedAttributeChanges,\n    );\n    this._renderInternals.trackedAttributeChanges.clear();\n\n    for (const [name, val] of trackedChanges) {\n      const config = this.liveAttributes[name];\n      if (!config) {\n        continue;\n      }\n\n      if (\"onChange\" in config) {\n        const previousValue = prevAttrs.get(name) ?? null;\n\n        if (config && previousValue !== val) {\n          config.onChange?.call(this, val, previousValue);\n        }\n      }\n    }\n  };\n\n  private _reflectLiveAttributes = () => {\n    if (!this.liveAttributes) {\n      return;\n    }\n\n    const toSet: [name: string, val: string | null][] = [];\n\n    for (const [name, config] of Object.entries(this.liveAttributes)) {\n      if (\"reflect\" in config) {\n        const val = serializeAttribute(config.reflect?.call(this));\n        const current = this.getAttribute(name);\n\n        if (val !== current) {\n          toSet.push([name, val]);\n        }\n      }\n    }\n\n    for (const [name, val] of toSet) {\n      this.reflectAttribute(name, val);\n    }\n  };\n\n  /** The actual update behavior */\n  private _performUpdate = (): void => {\n    try {\n      // Immediately flip flags to denote a render is in progress and allow\n      // queueing another render request.\n      this._renderInternals.isRendering = true;\n      this._renderInternals.willRender = false;\n\n      // Attributes: Run any `read` hooks for changed attributes\n      this._executeAttributeChangeHandlers();\n\n      // Cache the attributes from the previous render\n      const prevAttrs = this._renderInternals.lastRenderedAttributeMap;\n\n      this.beforeUpdate?.();\n\n      // Update the current snapshot of attributes\n      const newAttributes = createAttributeMap(this);\n      this._template.render(this.root, this._getRenderContext(newAttributes));\n      this._renderInternals.lastRenderedAttributeMap = newAttributes;\n      this.afterUpdate?.(prevAttrs);\n\n      // Attributes: Run any `write` hooks for updated values\n      this._reflectLiveAttributes();\n\n      // Run any requested render callbacks\n      // These are considered lifecycle methods as well, and will report errors\n      // as any other lifecycle method would\n      if (this._renderInternals.postRenderCallbacks.length) {\n        const callbacks = this._renderInternals.postRenderCallbacks;\n        this._renderInternals.postRenderCallbacks = [];\n        for (const fn of callbacks) {\n          fn();\n        }\n      }\n\n      // If the `willRender` flag was flipped, immediately perform a render\n      if (this._renderInternals.willRender) {\n        this._renderInternals.sequentialRenders += 1;\n\n        if (this._renderInternals.sequentialRenders >= MAX_SEQUENTIAL_RENDERS) {\n          throw new PaletteError(\n            ErrorCode.MAX_SEQUENTIAL_RENDERS,\n            `${this._renderInternals.sequentialRenders}`,\n          );\n        }\n\n        this._performUpdate();\n      } else {\n        this._renderInternals.sequentialRenders = 0;\n      }\n    } catch (error) {\n      this._renderInternals.willRender = false;\n      this._reportError(error);\n    } finally {\n      this._renderInternals.isRendering = false;\n    }\n  };\n\n  /** Safely request for an update to run on the next frame */\n  private _scheduleUpdate = () => {\n    // Prevent scheduling multiple renders\n    if (this._renderInternals.willRender) {\n      return;\n    }\n\n    this._renderInternals.willRender = true;\n\n    // If currently rendering, don't request a render, it will auto-continue\n    // until there are no changes to render\n    if (this._renderInternals.isRendering) {\n      return;\n    }\n\n    // If a render is requested and we're not rendering, request a render frame\n    requestAnimationFrame(this._performUpdate);\n  };\n\n  private _adoptState(state: StateShape | State<StateShape>) {\n    // If this is exactly our own state object, do nothing\n    if (Object.is(this._state, state)) {\n      return;\n    }\n\n    // If state exists, remove the listener and schedule a render\n    if (this._state) {\n      this._state.removeListener(this._scheduleUpdate);\n      this._scheduleUpdate();\n    }\n\n    // Adopt the incoming state obj or wrap and adopt it\n    const incomingStateObj = state instanceof State ? state : new State(state);\n    this._state = incomingStateObj;\n\n    // Ensure there is not accidentally two of the same render listeners\n    this._state.removeListener(this._scheduleUpdate);\n    this._state.addListener(this._scheduleUpdate);\n  }\n\n  // ╭────────────────────────────────────────────────────────╮\n  // │           Custom Element Callback Overrides            │\n  // ╰────────────────────────────────────────────────────────╯\n\n  /**\n   * @deprecated Use {@link script} instead\n   */\n  protected connectedCallback(): void {\n    if (this._renderInternals.initialRenderComplete) {\n      return;\n    }\n\n    if (__DEV__) {\n      const liveAttributes = new Set(Object.keys(this.liveAttributes ?? {}));\n      const observedAttributes = new Set(\n        (this.constructor as typeof Component).observedAttributes,\n      );\n\n      if (!observedAttributes.isSupersetOf(liveAttributes)) {\n        const componentName = (this.constructor as typeof Component).name;\n        console.warn(\n          `[Component] Component ${componentName} has defined Live Attributes ` +\n            `which are not listed in the Observed Attributes list. As such, ` +\n            `they may not function properly. Be sure to set the static ` +\n            `observedAttributes property on your Component, or use the ` +\n            `define() helper to automatically ensure the correct configuration`,\n        );\n      }\n    }\n\n    queueMicrotask(() => {\n      try {\n        this._renderInternals.isRendering = true;\n        this._renderInternals.willRender = false;\n\n        const attributes = createAttributeMap(this);\n\n        // If this is a stateful component, set up that state\n        if (this.initialState) {\n          const init =\n            typeof this.initialState === \"object\"\n              ? this.initialState\n              : this.initialState();\n\n          this._adoptState(init);\n        }\n\n        this._template.render(this.root, this._getRenderContext(attributes));\n        this._reflectLiveAttributes();\n        this._renderInternals.lastRenderedAttributeMap = attributes;\n        this._renderInternals.initialRenderComplete = true;\n        this._cleanupFn = this.script?.() ?? undefined;\n      } catch (error) {\n        this._reportError(error);\n      } finally {\n        this._renderInternals.isRendering = false;\n      }\n    });\n  }\n\n  /**\n   * @deprecated use {@link finalize}\n   */\n  protected disconnectedCallback(): void {\n    if (this._renderInternals.isFinalized) {\n      return;\n    }\n\n    queueMicrotask(() => {\n      // If this task runs but the component is still connected, then do nothing\n      // because the component was just moved in the DOM.\n      if (this.isConnected || !this._renderInternals.initialRenderComplete) {\n        return;\n      }\n\n      this._renderInternals.isFinalized = true;\n\n      // Only run the disconnect if the element is actually unmounted and not\n      // just moved. Using this in place of connectedMoveCallback() for compat\n      try {\n        this._delegator?.cleanup();\n\n        // Clear any listeners set up on self\n        if (this._ownListeners && this._ownListeners.size > 0) {\n          for (const listener of this._ownListeners) {\n            this.removeEventListener(listener.event, listener.handler);\n          }\n        }\n\n        this._cleanupFn?.();\n      } catch (error) {\n        this._reportError(error);\n      } finally {\n        // Run the finalize call after everything, even if the cleanup fn failed\n        try {\n          this.finalize?.();\n        } catch (error) {\n          this._reportError(error);\n        }\n      }\n    });\n  }\n\n  /**\n   * @deprecated Use {@link liveAttributes} instead\n   */\n  protected attributeChangedCallback(\n    name: string,\n    _: string | null,\n    newValue: string | null,\n  ): void {\n    // Ignore attribute changes that occur during an update, as they are\n    // coming from inside the house\n    if (this._renderInternals.isRendering) {\n      return;\n    }\n\n    // Skip non-changes using the stored attributes as reference to compare\n    // to the render state rather than the dom\n    if (\n      newValue === this._renderInternals.lastRenderedAttributeMap?.get(name)\n    ) {\n      return;\n    }\n\n    // Cache the updated attribute value\n    this._renderInternals.trackedAttributeChanges.set(name, newValue);\n\n    // Schedule a render\n    if (!this._renderInternals.willRender) {\n      this._scheduleUpdate();\n    }\n  }\n\n  // ╭────────────────────────────────────────────────────────╮\n  // │                    Public Interface                    │\n  // ╰────────────────────────────────────────────────────────╯\n\n  /**\n   * The ShadowRoot node of this element\n   */\n  get root(): ShadowRoot {\n    return this._root;\n  }\n\n  get isMounted(): boolean {\n    return this.isConnected && this._renderInternals.initialRenderComplete;\n  }\n\n  /**\n   * Accessor for live reactive state.\n   *\n   * For the full state manipulation API, use {@link getState}\n   */\n  get state(): StateShape {\n    if (!this._state) {\n      throw new PaletteError(ErrorCode.MISSING_STATE);\n    }\n\n    return this._state.live;\n  }\n\n  /**\n   * Replace the current state with a new value or adopt a whole different State\n   * instance\n   */\n  set state(newState: StateShape | State<StateShape>) {\n    this._adoptState(newState);\n  }\n\n  /**\n   * Access the full {@link State} instance for this Component.\n   *\n   * @remarks\n   * Calling this method on a component which is not using reactive state\n   * will result in an error being thrown.\n   */\n  getState(): State<StateShape> {\n    if (!this._state) {\n      throw new PaletteError(ErrorCode.MISSING_STATE);\n    }\n\n    return this._state;\n  }\n\n  /**\n   * Manually schedule a render to occur, optionally providing a callback to\n   * invoke after the render completes.\n   *\n   * @remarks\n   * Calling {@link requestRender} multiple times in the same event loop won't\n   * schedule multiple renders. Renders are scheduled to occur on the next\n   * animation frame.\n   */\n  requestRender(callback?: VoidFunction): void {\n    if (callback) {\n      this._renderInternals.postRenderCallbacks.push(callback);\n    }\n\n    this._scheduleUpdate();\n  }\n\n  /**\n   * Listen for events from within this Component.\n   *\n   * Provide a query string to target specific element events, or use `:host`\n   * to create listeners on the host element itself.\n   *\n   * Event listeners created with this method are automatically cleaned up when\n   * the component unmounts.\n   */\n  listen<E extends EventName>(\n    targetDescriptor: string | typeof Component<any> | HTMLElement,\n    eventName: E,\n    eventHandler: EventHandler<E>,\n  ): void {\n    const query = EventDelegator.processTargetDescriptor(targetDescriptor);\n\n    // If the query filter is `\":host\"`, set up an ownListener\n    if (query === \":host\" || query === \":HOST\") {\n      if (this._ownListeners === undefined) {\n        this._ownListeners = new Set();\n      }\n\n      this.addEventListener(eventName, eventHandler);\n      this._ownListeners.add({\n        handler: eventHandler as EventHandler,\n        event: eventName,\n      });\n      return;\n    }\n\n    // Otherwise, set up a root listener\n    if (!this._delegator) {\n      this._delegator = new EventDelegator(this.root);\n    }\n\n    this._delegator.addListener(eventName, eventHandler, query);\n  }\n\n  stopListening<E extends EventName>(\n    targetDescriptor: string | typeof Component<any> | HTMLElement,\n    eventName: E,\n    eventHandler: EventHandler<E>,\n  ): void {\n    const query = EventDelegator.processTargetDescriptor(targetDescriptor);\n\n    // If the query filter is `\":host\"`, remove from the ownListener list\n    if (query === \":host\" || query === \":HOST\") {\n      if (this._ownListeners === undefined) {\n        this._ownListeners = new Set();\n      }\n      this.removeEventListener(eventName, eventHandler as EventHandler);\n      for (const listener of this._ownListeners) {\n        if (listener.event === eventName && listener.handler === eventHandler) {\n          this._ownListeners.delete(listener);\n        }\n      }\n      return;\n    }\n\n    // If the delegator is not set up, there's nothing to do\n    if (!this._delegator) {\n      return;\n    }\n\n    this._delegator.removeListener(\n      eventName,\n      eventHandler as EventHandler,\n      query,\n    );\n  }\n\n  dispatchEvent(event: Event): boolean;\n\n  /**\n   * Dispatch a {@link CustomEvent} with the specified name and detail\n   */\n  dispatchEvent<T>(\n    event: string,\n    detail?: T,\n    options?: {\n      bubbles: boolean;\n      cancelable: boolean;\n      composed: boolean;\n    },\n  ): boolean;\n  dispatchEvent<T>(\n    event: string | Event,\n    detail?: T,\n    options?: {\n      bubbles: boolean;\n      cancelable: boolean;\n      composed: boolean;\n    },\n  ): boolean {\n    if (event instanceof Event) {\n      return super.dispatchEvent(event);\n    }\n\n    const opts = {\n      bubbles: true,\n      cancelable: true,\n      composed: true,\n      ...(options ?? {}),\n    };\n\n    return super.dispatchEvent(\n      new CustomEvent<T>(event, {\n        detail,\n        ...opts,\n      }),\n    );\n  }\n\n  querySelector<E extends HTMLElement>(query: string): E | null {\n    return this._root.querySelector(query);\n  }\n\n  querySelectorAll<E extends HTMLElement>(query: string): NodeListOf<E> {\n    return this._root.querySelectorAll(query) as NodeListOf<E>;\n  }\n\n  getElementById<E extends HTMLElement>(id: string): E | null {\n    if (this._root instanceof ShadowRoot) {\n      return this._root.getElementById(id) as E | null;\n    } else {\n      return HTMLElement.prototype.querySelector.call(\n        this,\n        `#${id}`,\n      ) as E | null;\n    }\n  }\n\n  requireElementById<E extends HTMLElement>(id: string): E {\n    const lookup = this.getElementById<E>(id);\n    if (!lookup) {\n      throw new PaletteError(ErrorCode.MISSING_ELEMENT);\n    }\n    return lookup;\n  }\n\n  setAttribute(name: string, value: string): void;\n\n  /**\n   * Set a value as an attribute, serializing to a string or `null`.\n   *\n   * null values cause the attribute to be removed from this element\n   */\n  setAttribute(name: string, value: unknown): void;\n  setAttribute(name: string, value: unknown): void {\n    const serialized = serializeAttribute(value);\n    if (serialized === null) {\n      HTMLElement.prototype.removeAttribute.call(this, name);\n    } else {\n      HTMLElement.prototype.setAttribute.call(this, name, serialized);\n    }\n  }\n\n  getAttribute(name: string): string | null;\n\n  /**\n   * Get an attribute as a number, falling back to a specified default.\n   *\n   * `null` attributes are returned as `null`, while string attributes are\n   * parsed using the `Number()` constructor. NaN is coerced to `null`.\n   */\n  getAttribute(name: string, defaultValue: number): number;\n\n  /**\n   * Get an attribute as a string, falling back to a specified default\n   */\n  getAttribute(name: string, defaultValue: string): string;\n  getAttribute(\n    name: string,\n    defaultValue?: string | number,\n  ): string | number | null {\n    const value = HTMLElement.prototype.getAttribute.call(this, name);\n\n    if (defaultValue === undefined) {\n      return value;\n    }\n\n    if (typeof defaultValue === \"number\") {\n      if (value === null) {\n        return defaultValue;\n      }\n\n      const parsed = Number(value);\n\n      if (Number.isNaN(parsed)) {\n        return defaultValue;\n      }\n\n      return parsed;\n    }\n\n    // Invalid function invocation\n    throw new PaletteError(ErrorCode.INVALID_CALLSITE);\n  }\n\n  /**\n   * Set the value of an attribute on this element if the provided value\n   * differs from the attribute when serialized\n   */\n  reflectAttribute(name: string, value: unknown): void {\n    const current = this.getAttribute(name);\n    const reflected = serializeAttribute(value);\n\n    if (current !== reflected) {\n      this.setAttribute(name, reflected);\n    }\n  }\n\n  /**\n   * Serialize this element to a string\n   */\n  toString(): string {\n    const { tagName, name } = this.constructor as typeof Component;\n    const computedName = tagName === \"\" ? name : tagName;\n    const attrString = this.getAttributeNames()\n      .map((attrName) => {\n        const val = this.getAttribute(attrName);\n        return val ? `${attrName}=\"${val}\"` : \"\";\n      })\n      .join(\" \");\n    const attrs = attrString.length > 0 ? ` ${attrString}` : \"\";\n    return `<${computedName}${attrs}></${computedName}>`;\n  }\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { Component } from \"./component\";\nimport type {\n  AttributeMap,\n  ComponentStyles,\n  ComputedProperties,\n  LiveAttributes,\n  StateInitializer,\n} from \"./types\";\n\nconst BLANK_TEMPLATE = document.createElement(\"template\");\n\nexport interface ComponentShorthand<StateShape extends object = {}> {\n  /**\n   * An HTML Template element for this element to use.\n   */\n  template?: HTMLTemplateElement;\n\n  /**\n   * A {@link CSSStyleSheet} array to adopt to the element's shadow DOM\n   */\n  styles?: ComponentStyles;\n\n  /**\n   * The mode for this Component's ShadowRoot.\n   *\n   * - `\"open\"` allows JS access to the children of this component\n   * - `\"closed\"` (default) disallows internal JS access\n   */\n  shadowRootMode?: \"closed\" | \"open\";\n\n  /**\n   * The initial state for this Component's reactive internal state, if any.\n   */\n  initialState?: StateInitializer<StateShape>;\n\n  /**\n   * An object or function returning an object which populates the `data` values\n   * in the templating engine. Such values are accessed using the `*` notation.\n   */\n  computedProperties?: ComputedProperties<StateShape>;\n\n  /**\n   * Declaration of attribute behaviors during updates.\n   */\n  liveAttributes?: LiveAttributes<StateShape>;\n\n  /**\n   * Initialization scripting for this Component\n   */\n  script?: (this: Component<StateShape>) => VoidFunction | void;\n\n  /**\n   * Called immediately before each template update\n   */\n  beforeUpdate?: (this: Component<StateShape>) => void;\n\n  /**\n   * Called immediately after each template update\n   */\n  afterUpdate?: (\n    this: Component<StateShape>,\n    previousAttributes: AttributeMap,\n  ) => void;\n\n  /**\n   * Called as the final lifecycle method at the end of the unmounting process.\n   */\n  finalize?: (this: Component<StateShape>) => void;\n\n  /**\n   * If defined, receives errors caught during the lifecycle methods of this\n   * component and it's children. If not defined, this component will instead\n   * throw errors as they are found.\n   */\n  onError?: (this: Component<StateShape>, error: unknown) => void;\n}\n\nfunction defineFromClass<StateShape extends object = {}>(\n  cls: typeof Component<StateShape>,\n  tagName?: string,\n) {\n  // Set the tagName static if its not already set\n  if (tagName && cls.tagName === \"\") {\n    cls.tagName = tagName;\n  }\n\n  if (__DEV__) {\n    if (tagName && tagName !== cls.tagName) {\n      console.warn(\n        `[COMPONENT] Component ${cls.name} was defined with tagname ${tagName} ` +\n          `which does not match its static tagName property`,\n      );\n    }\n  }\n\n  window.customElements.define(\n    cls.tagName,\n    cls as unknown as CustomElementConstructor,\n  );\n}\n\n/**\n * Register a Palette Component as a custom element\n */\nexport function define<Cls extends typeof Component<any>>(definition: Cls): Cls;\n\n/**\n * Register a Palette Component as a custom element\n */\nexport function define<Cls extends typeof Component<any>>(\n  tagName: string,\n  definition: Cls,\n): Cls;\n\n/**\n * Define a Palette Component using the shorthand syntax\n *\n * @example\n *\n * ```typescript\n * define(\"my-component\", {\n *   template: html`...`,\n *   styles: css`...`,\n *   initialState: { ... },\n *   computedProperties() { ... },\n *   script() { ... },\n *   // and any other lifecycle methods\n * });\n * ```\n */\nexport function define<StateShape extends object = {}>(\n  tagName: string,\n  definition: ComponentShorthand<StateShape>,\n): typeof Component<StateShape>;\n\nexport function define<StateShape extends object = {}>(\n  a: string | typeof Component<StateShape>,\n  b?: ComponentShorthand<StateShape> | typeof Component<StateShape>,\n): typeof Component<StateShape> {\n  // Handle component class paths\n  if (typeof a === \"function\") {\n    defineFromClass(a);\n    return a;\n  }\n\n  if (typeof a === \"string\" && typeof b === \"function\") {\n    defineFromClass(b, a);\n    return b;\n  }\n\n  if (b === undefined) {\n    throw new PaletteError(ErrorCode.INVALID_CALLSITE);\n  }\n\n  // Handle shorthand\n  const tagName = a;\n  const definition = b;\n\n  // Component constructors are functions -> Define them with their tagname if present\n  if (typeof definition === \"function\") {\n    // Set the tagName static if its not already set\n    if (definition.tagName === \"\") {\n      definition.tagName = tagName;\n    }\n\n    if (__DEV__) {\n      if (tagName !== definition.tagName) {\n        console.warn(\n          `[COMPONENT] Component ${definition.name} was defined with tagname ${tagName} ` +\n            `which does not match its static tagName property`,\n        );\n      }\n    }\n\n    window.customElements.define(\n      tagName,\n      definition as unknown as CustomElementConstructor,\n    );\n    return definition;\n  }\n\n  const {\n    // Config\n    template = BLANK_TEMPLATE,\n    styles = [],\n    shadowRootMode = \"closed\",\n    initialState,\n    computedProperties = {},\n    liveAttributes = {},\n\n    // Lifecycle\n    script,\n    beforeUpdate,\n    afterUpdate,\n    finalize,\n    onError,\n  } = definition;\n\n  const fullObservedAttributes = Array.from(\n    new Set([...Object.keys(liveAttributes)]),\n  );\n\n  const cls = class extends Component<StateShape> {\n    static tagName = tagName;\n    static template = template;\n    static styles = styles;\n    static observedAttributes = [...fullObservedAttributes];\n    static shadowRootMode = shadowRootMode;\n\n    constructor() {\n      super();\n\n      this.initialState =\n        typeof initialState === \"function\"\n          ? initialState.bind(this)\n          : initialState;\n      this.computedProperties =\n        typeof computedProperties === \"function\"\n          ? computedProperties.bind(this)\n          : computedProperties;\n      this.liveAttributes = liveAttributes;\n\n      for (const def of Object.values(this.liveAttributes)) {\n        if (def.onChange) {\n          def.onChange = def.onChange.bind(this);\n        }\n\n        if (def.reflect) {\n          def.reflect = def.reflect.bind(this);\n        }\n      }\n\n      this.script = script?.bind(this) ?? undefined;\n      this.beforeUpdate = beforeUpdate?.bind(this) ?? undefined;\n      this.afterUpdate = afterUpdate?.bind(this) ?? undefined;\n      this.finalize = finalize?.bind(this) ?? undefined;\n      this.onError = onError?.bind(this) ?? undefined;\n    }\n  };\n\n  customElements.define(tagName, cls);\n  return cls;\n}\n",
    "import { fragmentCache } from \"#util\";\nimport { compiledTemplateCache } from \"./template/compile\";\nimport { parsedNotationCache, valueAccessorCache } from \"./template/syntax\";\n\nif (__DEV__ && typeof window !== \"undefined\") {\n  (window as any).__PALETTE_DEVTOOLS__ = {\n    dumpCacheMetrics: () => {\n      console.log(\n        \"Compiled Templates Cache\",\n        compiledTemplateCache.getMetrics(),\n      );\n      console.log(\"HTML Fragments Cache\", fragmentCache.getMetrics());\n      console.log(\"Notation Accessor Cache\", valueAccessorCache.getMetrics());\n      console.log(\"Parsed Notations Cache\", parsedNotationCache.getMetrics());\n    },\n  };\n}\n"
  ],
  "mappings": "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",
  "debugId": "86B5A91FBB0A820D64756E2164756E21",
  "names": []
}
2039
+ //# debugId=D9A90808356EA17464756E2164756E21
2040
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/errors.ts", "src/state/state.ts", "src/util/lru-cache.ts", "src/util/fragments.ts", "src/util/attributes.ts", "src/util/element-match.ts", "src/util/dom.ts", "src/template/constant.ts", "src/template/syntax.ts", "src/template/util.ts", "src/template/compile.ts", "src/helper/css.ts", "src/helper/html.ts", "src/template/jobs/common.ts", "src/template/jobs/attribute.ts", "src/template/jobs/conditional.ts", "src/template/jobs/list.ts", "src/template/jobs/swap.ts", "src/template/jobs/tag.ts", "src/template/jobs/index.ts", "src/template/prepare.ts", "src/template/template.ts", "src/task-scheduler.ts", "src/component/delegator.ts", "src/component/component.ts", "src/component/factory.ts", "src/devtools.ts"],
  "sourcesContent": [
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n/**\n * Possible error types for {@link PaletteError}\n *\n * Codes are categorized into groups by the 100's:\n *\n * - 0 - 99: Invariants\n * - 100 - 199: Custom Elements / Environment Errors\n * - 200 - 299: Templating Errors\n * - 300 - 399: Runtime Errors\n */\nexport const enum ErrorCode {\n  // 0 - 99: Invariants\n  INVARIANT = 0,\n  INVALID_ENV = 1,\n  INVALID_CALLSITE = 2,\n  MISSING_NODE_REF = 3,\n\n  // 100 - 199: Custom Elements Errors\n  INVALID_TAGNAME = 100,\n\n  // 200 - 299: Template Errors\n  TEMPLATE_INVALID_VALUE = 200,\n  TEMPLATE_INVALID_NOTATION_SYNTAX = 201,\n  TEMPLATE_MISSING_NOTATION = 202,\n  TEMPLATE_INVALID_COMPONENT = 203,\n  TEMPLATE_INVALID_LIST_DATA = 204,\n  TEMPLATE_MISSING_LIST_KEY = 205,\n  TEMPLATE_DUPLICATE_LIST_KEY = 206,\n  TEMPLATE_INVALID_CONDITIONAL = 207,\n  TEMPLATE_INVALID_KEY_DIRECTIVE = 208,\n  TEMPLATE_PARENT_REQUIRED = 209,\n\n  // 300 - 399: Runtime Errors\n  MISSING_ELEMENT = 300,\n  MISSING_STATE = 301,\n  INVALID_CONTENT = 302,\n  INVALID_STATE_KEY = 303,\n  INVALID_STATE_UPDATE = 304,\n  STATE_LOCKED = 305,\n  MAX_SEQUENTIAL_RENDERS = 306,\n}\n\nfunction getDevError(code: ErrorCode) {\n  const DEV_ERROR_INFO: Record<ErrorCode, string> = {\n    [ErrorCode.INVARIANT]: `\nINVARIANT\nA condition has occurred which should never happen, such as a code path that\nshouldn't be reachable when using correct types, or a disallowed state.\n`,\n\n    [ErrorCode.INVALID_ENV]: `\nINVALID_ENV\nFailed to find a custom elements registry in this environment. Is a window\nglobal available with a customElements property?\n`,\n    [ErrorCode.INVALID_CALLSITE]: `\nINVALID_CALLSITE\nA function was invoked with an invalid set of parameters.   \n`,\n\n    [ErrorCode.INVALID_TAGNAME]: `\nINVALID_TAGNAME\nFailed to determine a valid HTML Tag to use when registering a component as a\ncustom element. Specify a static readonly tagName property on your component\nclass or provide a tagName argument to Component.register.\n\nAlternatively, you can directly register your element as you would any other\nHTML custom element: customElements.define(\"my-tag\", MyComponentClass);\n`,\n\n    [ErrorCode.MISSING_ELEMENT]: `\nMISSING_ELEMENT\nAn element was expected to exist but was not found when the DOM was queried.\n`,\n\n    [ErrorCode.MISSING_STATE]: `\nMISSING_STATE\nA Component's reactive state was accessed, but no initialState is defined for\nthe Component's class. Initial state must be defined as an object or function.\n`,\n\n    [ErrorCode.INVALID_CONTENT]: `\nINVALID_CONTENT\nTried to set a value as content in a template, but the value was not a supported\ntype. Values must be a string, HTMLElement.\n\nInstead, got %s: %s.\n`,\n\n    [ErrorCode.TEMPLATE_INVALID_VALUE]: `\nTEMPLATE_INVALID\nThe value %s cannot be interpolated via the Template html string helper.\nValues may only be HTMLTemplateElements (template content is adopted) or\nstrings (shorthand for a ::swap directive on an element)\n`,\n\n    [ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX]: `\nTEMPLATE_INVALID_NOTATION\nA template value notation failed to parse. Notations must begin with one of\n@, $, *, or #, followed by a dot-separated path of accessor names. Optionally,\nnotations may have modifiers such as the ! modifier.\n\nThe notation that failed to parse was \"%s\"\n`,\n    [ErrorCode.TEMPLATE_INVALID_COMPONENT]: `\nTEMPLATE_INVALID_COMPONENT\nFailed to interpolate a Component in an html template string due to the\nComponent having an invalid tagName property.\n\nComponent \"%s\" has an invalid tagName property \"%s\"\n    `,\n\n    [ErrorCode.TEMPLATE_INVALID_LIST_DATA]: `\nTEMPLATE_INVALID_LIST\nA template failed to render because an ::each directive fetched a value which\nwas not an array of actionable data.\n`,\n\n    [ErrorCode.MISSING_NODE_REF]: `\nTEMPLATE_INVALID_NODE_REF\nA template failed to prepare a node from a compiled source. Typically, this\nmeans something is broken within the compiled template rather than an error with\nthe template content itself.\n`,\n\n    [ErrorCode.TEMPLATE_MISSING_LIST_KEY]: `\nTEMPLATE_MISSING_LIST_KEY\nA template failed to compile because an ::each directive was found on an element\nwithout a corresponding ::key directive. ::each directives must have a ::key\ndirective specified on the same element, whose notation evaluates to a unique\nvalue for each item in the list.\n\nExample: <li ::each=\"$items\" ::key=\"#id\"> ... </li>\n`,\n\n    [ErrorCode.TEMPLATE_DUPLICATE_LIST_KEY]: `\nTEMPLATE_DUPLICATE_LIST_KEY\nA list failed to render because item key %s appeared multiple times when\nresolving list item keys. Each ::key directive must reference a notation whose\nvalue is unique for each list item.\n`,\n\n    [ErrorCode.TEMPLATE_INVALID_CONDITIONAL]: `\nTEMPLATE_INVALID_CONDITIONAL\nA template failed to compile due to an invalid use of conditional directives.\n\nConditional elements must be siblings. The first conditional branch must use an\n::if directive, followed by zero or more ::else-if directives, and finally zero\nor one ::else directive.\n\n::if and ::else-if directives must specify a notation to evaluate. ::else does\nnot take any values and is just a binary attribute.\n`,\n\n    [ErrorCode.TEMPLATE_MISSING_NOTATION]: `\nTEMPLATE_MISSING_NOTATION\nA template failed to compile because a %s directive did not have an associated\nnotation despite requiring one.\n`,\n\n    [ErrorCode.INVALID_STATE_KEY]: `\nINVALID_STATE_KEY\nTried to access a state property which does not exist\n\nKey path: %s\n`,\n\n    [ErrorCode.INVALID_STATE_UPDATE]: `\nINVALID_STATE_UPDATE\nA Component's setState() was called with a value which could not be patched in\nto the existing component state.\n\nsetState() takes a partial object describing state keys to update.\n\nInstead, received: %s\n`,\n\n    [ErrorCode.STATE_LOCKED]: `\nSTATE_LOCKED\nA State received a request to update or lock while already locked.\nStates may be locked using the .lock() method and unlocked using the .unlock()\nmethod. States lock during async mutations done through the .mutateAsync()\nmethod if \"true\" is passed as the second parameter.\n\nYou can check the lock status of a State instance with .isLocked\n`,\n\n    [ErrorCode.MAX_SEQUENTIAL_RENDERS]: `\nMAX_SEQUENTIAL_RENDERS\nA component has errored after re-rendering more than %s times in the same frame.\n\nThis typically happens because state or live attributes are being modified\nduring a render lifecycle method such as beforeUpdate() or afterUpdate(). If\nstate changes unconditionally during a render, the render will infinitely loop.\nUpdating render source data during a render cycle is supported, but infinite\nupdate loops may occur if unchecked.\n`,\n\n    [ErrorCode.TEMPLATE_INVALID_KEY_DIRECTIVE]: `\nTEMPLATE_INVALID_KEY_DIRECTIVE\nA template failed to compile because a ::key directive was found on an element\nwith no associated ::each directive. ::key directives can only be used in\nassociation with list rendering via ::each.\n`,\n    [ErrorCode.TEMPLATE_PARENT_REQUIRED]: `\nTEMPLATE_PARENT_REQUIRED\nA template failed to compile due to an element which requires a parent having\nno available parent in the template.\n\n::each and ::if/::else-if/::else elements must have a parent node.\n`,\n  };\n\n  return DEV_ERROR_INFO[code];\n}\n\n/**\n * An error originating from within a Palette subsystem.\n *\n * In the `development` environment, the error will surface with extended info\n * about the error and any details which may be relevant to help with debugging.\n *\n * In the `production` environment, a minimal error only surfacing the numeric\n * error code is thrown instead.\n *\n * Codes are categorized into groups by the 100's:\n *\n * - 0 - 99: Invariants\n * - 100 - 199: Custom Elements / Environment Errors\n * - 200 - 299: Templating Errors\n * - 300 - 399: Runtime Errors\n */\nexport class PaletteError extends Error {\n  name = \"PaletteError\";\n  code: number;\n\n  constructor(code: number, ...values: string[]) {\n    let message = `Code: ${code}`;\n    if (__DEV__) {\n      message += getDevError(code);\n\n      for (const val of values) {\n        message = message.replace(`%s`, String(val));\n      }\n    }\n\n    super(message);\n    this.code = code;\n  }\n}\n",
    "/*\n * Copyright © Rustic Arcade, LLC 2026\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\n\nexport type StateListener<Shape> = (state: Shape) => void;\n\nconst ArrayMutatorFunctions = new Set([\n  \"push\",\n  \"pop\",\n  \"shift\",\n  \"unshift\",\n  \"splice\",\n  \"sort\",\n  \"reverse\",\n  \"fill\",\n  \"copyWithin\",\n]);\n\nconst DataStructureMutatorFunctions = new Set([\n  \"add\",\n  \"delete\",\n  \"clear\",\n  \"set\",\n]);\n\n/**\n * Powerful and flexible state management with deep reactivity, transaction, and\n * locking support.\n *\n * The State class wraps stateful data and provides an API for mutating the data\n * while listeners subscribe to meaningful updates.\n */\nexport class State<Shape extends object> {\n  static isState<T extends object>(value: unknown): value is State<T> {\n    return (\n      value !== null && typeof value === \"object\" && value instanceof State\n    );\n  }\n\n  private _data: Shape;\n  private _listeners: Set<StateListener<Shape>> = new Set();\n  private _proxy?: Shape;\n  private _proxyCache = new WeakMap<object, any>();\n  private _reverseProxyCache = new WeakMap<object, object>();\n\n  constructor(initialData: Shape, listener?: StateListener<Shape>) {\n    this._data = initialData;\n    if (listener) {\n      this._listeners.add(listener);\n    }\n  }\n\n  /**\n   * Lazily create and cache proxies into the state for reactive updates on\n   * nested values.\n   */\n  private _createProxy<T>(target: T, path: string[] = []): T {\n    // Return primitives immediately\n    if (typeof target !== \"object\" || target === null) {\n      return target;\n    }\n\n    // Check for a cached proxy for this object\n    const cached = this._proxyCache.get(target as object);\n    if (cached) {\n      return cached;\n    }\n\n    // Otherwise create a new proxy and cache it\n    const proxy = new Proxy(target as object, {\n      get: (obj, key: string | symbol) => {\n        // Symbols -> Direct return\n        if (typeof key === \"symbol\") {\n          return (obj as any)[key];\n        }\n\n        const value = (obj as any)[key];\n\n        // For Arrays, Maps, and Sets, handle mutator functions correctly\n        if (\n          (obj instanceof Set || obj instanceof Map || Array.isArray(obj)) &&\n          typeof value === \"function\"\n        ) {\n          const mutationFns = Array.isArray(obj)\n            ? ArrayMutatorFunctions\n            : DataStructureMutatorFunctions;\n          const isMutation = mutationFns.has(key);\n\n          return (...args: any[]) => {\n            const snapshot = this.snapshot();\n\n            let current: any = snapshot;\n\n            for (const p of path) {\n              current = current[p];\n            }\n\n            const res = (current as any)[key](...args);\n\n            if (isMutation) {\n              this._processIncomingState(snapshot);\n            }\n\n            return res;\n          };\n        }\n\n        // Objects -> recursively create a proxy\n        if (typeof value === \"object\" && value !== null) {\n          return this._createProxy(value, [...path, key]);\n        }\n\n        // Primitives -> Return value\n        return value;\n      },\n\n      set: (_obj, key: string | symbol, value: any) => {\n        // Disallow setting symbol properties on target data values\n        if (typeof key === \"symbol\") {\n          return false;\n        }\n\n        // Compute and update the path with the value\n        const newPath = [...path, key];\n        this._setNested(newPath, this._unwrapProxy(value));\n\n        return true;\n      },\n\n      has: (obj, key: string | symbol) => {\n        return key in obj;\n      },\n\n      ownKeys: (obj) => {\n        return Reflect.ownKeys(obj);\n      },\n\n      getOwnPropertyDescriptor: (obj, key: string | symbol) => {\n        const desc = Object.getOwnPropertyDescriptor(obj, key);\n\n        if (desc) {\n          desc.configurable = true;\n        }\n\n        return desc;\n      },\n\n      deleteProperty: (obj, key) => {\n        if (typeof key === \"symbol\" || !(key in obj)) {\n          return false;\n        }\n\n        // Compute and update the path with the value\n        const newPath = [...path, key];\n\n        this._setNested(newPath, undefined);\n\n        return true;\n      },\n    }) as T;\n\n    this._proxyCache.set(target as object, proxy);\n    this._reverseProxyCache.set(proxy as object, target as object);\n    return proxy;\n  }\n\n  private _unwrapProxy<T>(value: T): T {\n    // Don't do anything for primitives\n    if (typeof value !== \"object\" || value === null) {\n      return value;\n    }\n\n    // Check if this is one of our proxies\n    const rawTarget = this._reverseProxyCache.get(value as object);\n    if (rawTarget) {\n      return rawTarget as T;\n    }\n\n    // Handle arrays\n    if (Array.isArray(value)) {\n      return value.map((item) => this._unwrapProxy(item)) as T;\n    }\n\n    // Handle plain objects\n    if (Object.getPrototypeOf(value) === Object.prototype) {\n      const unwrapped: any = {};\n      for (const key in value) {\n        if (Object.hasOwn(value, key)) {\n          unwrapped[key] = this._unwrapProxy((value as any)[key]);\n        }\n      }\n      return unwrapped;\n    }\n\n    // Other objects (Date, Map, Set, etc.) pass through\n    return value;\n  }\n\n  /**\n   * Handle setting nested values and emitting updated data if the value changed\n   */\n  private _setNested(path: string[], value: any): void {\n    // Nothing to do with empty paths\n    if (!path.length) {\n      return;\n    }\n\n    // Start at the root and seek to the value being set\n    let current: any = this._data;\n\n    for (let i = 0; i < path.length - 1; i++) {\n      const key = path[i] ?? \"\";\n\n      if (current === undefined) {\n        throw new PaletteError(ErrorCode.INVALID_STATE_KEY, path.join(\".\"));\n      }\n\n      current = current[key];\n    }\n\n    const finalKey = path[path.length - 1] ?? \"\";\n\n    if (current === undefined) {\n      throw new PaletteError(ErrorCode.INVALID_STATE_KEY, path.join(\".\"));\n    }\n\n    // Set and emit only if the value is different. Otherwise no-op.\n    if (current[finalKey] !== value && !Object.is(current[finalKey], value)) {\n      current[finalKey] = value;\n      this._emit(this.raw);\n    }\n  }\n\n  /**\n   * Process an incoming partial state and emit updates to listeners if there\n   * are any changes detected.\n   *\n   * @remarks\n   * Object.is() to check for differences. Does not attempt deep diffing.\n   */\n  private _processIncomingState = (\n    incomingState: Partial<Shape>,\n  ): State<Shape> => {\n    if (\n      typeof incomingState !== \"object\" ||\n      incomingState === null ||\n      Array.isArray(incomingState)\n    ) {\n      throw new PaletteError(\n        ErrorCode.INVALID_STATE_UPDATE,\n        JSON.stringify(incomingState),\n      );\n    }\n    let hasChanges = false;\n\n    // Check if any key/value pair on the incoming state differs from the\n    // existing data\n    for (const [key, newValue] of Object.entries(incomingState)) {\n      const currentValue = this._data[key as keyof Shape];\n      if (!Object.is(currentValue, newValue)) {\n        hasChanges = true;\n        (this._data as any)[key] = newValue;\n      }\n    }\n\n    if (hasChanges) {\n      this._emit(this._data);\n    }\n\n    return this;\n  };\n\n  /**\n   * Emit the current state to all listeners\n   */\n  private _emit = (data: Shape): void => {\n    for (const listener of this._listeners) {\n      listener(data);\n    }\n  };\n\n  /**\n   * The current state\n   *\n   * @remarks\n   * This is a direct reference to the internal state. It is marked as Readonly\n   * to help prevent accidental changes. Never edit this value directly.\n   */\n  get raw(): Readonly<Shape> {\n    return this._data;\n  }\n\n  /**\n   * Live reactive accessor for state data. Deeply nested changes trigger\n   * automatic updates, including array, Map, and Set mutations.\n   *\n   * @remarks\n   * For deeply nested values, the `.live` accessor may add performance overhead\n   * compared to directly accessing the value via `.current`\n   */\n  get live(): Shape {\n    if (!this._proxy) {\n      this._proxy = this._createProxy(this._data);\n    }\n    return this._proxy;\n  }\n\n  /**\n   * Add a handler function for when this state changes.\n   *\n   * Listeners are invoked in the order they are registered and are passed a\n   * reference to the internally managed state object as a readonly object.\n   *\n   * **Do not modify state values directly**. Instead, use {@link set} or\n   * {@link patch} to make immutable updates.\n   */\n  addListener = (listener: StateListener<Shape>): void => {\n    this._listeners.add(listener);\n  };\n\n  /**\n   * Remove a previously registered state handler\n   */\n  removeListener = (listener: StateListener<Shape>): void => {\n    this._listeners.delete(listener);\n  };\n\n  /**\n   * Get a single value from the state object\n   *\n   * The value is returned as Readonly to prevent accidental state mutations.\n   * To mutate stateful properties, use {@link set} or {@link patch} instead.\n   */\n  get = <K extends keyof Shape>(key: K): Readonly<Shape[K]> => {\n    return this._data[key] as Readonly<Shape[K]>;\n  };\n\n  /**\n   * Returns a deep clone of the current state data using `structuredClone()` to\n   * make the copy.\n   *\n   * The object returned from this function can be edited without modifying the\n   * actual internal state.\n   * ```\n   */\n  snapshot = (): Shape => {\n    return structuredClone(this._data);\n  };\n\n  /**\n   * Set a single stateful property while leaving other properties unchanged.\n   *\n   * Triggers an update to all listeners if the value is different from before\n   * when compared using shallow equality.\n   *\n   * @example\n   *\n   * ```typescript\n   * const state = new State({ count: 1, color: \"red\" });\n   * state.set(\"count\", 2); // State is now { count: 2, color: \"red\" }\n   * ```\n   */\n  set = <K extends keyof Shape>(key: K, value: Shape[K]): State<Shape> => {\n    const partial: Partial<Shape> = {};\n    partial[key] = value;\n    return this._processIncomingState(partial);\n  };\n\n  /**\n   * Set multiple stateful properties at once, leaving omitted properties\n   * unchanged.\n   */\n  patch = (patch: Partial<Shape>): State<Shape> => {\n    return this._processIncomingState(patch);\n  };\n\n  /**\n   * Fully replace the current state data and force an update\n   */\n  replace = (state: Shape): State<Shape> => {\n    this._data = state;\n    this._emit(this._data);\n    return this;\n  };\n\n  /**\n   * Apply complex updates to the state using a mutator function.\n   *\n   * The mutator function takes one parameter which is a structuredClone copy of\n   * the current state object. Whatever is returned by the mutator is then\n   * patched in to the state.\n   */\n  mutate = (mutator: (current: Shape) => Shape): State<Shape> => {\n    return this._processIncomingState(mutator(this.snapshot()));\n  };\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\ntype Metrics = {\n  hits: number;\n  misses: number;\n};\n\nexport type LRUCacheMetrics = {\n  lookups: number;\n  hits: number;\n  misses: number;\n  capacity: number;\n  entries: number;\n  hitRate: number;\n};\n\n/**\n * A simple in-memory LRU Cache using JavaScript maps.\n *\n * @example\n *\n * Cached network request\n *\n * ```typescript\n * // A cache of API URLs to their returned payloads\n * const cache = new LRUCache<string, APIPayload>();\n *\n * async function makeRequest(url: string) {\n *   let cached = cache.get(url);\n *   if (cached) {\n *     return cached;\n *   }\n *\n *   // ... Make the request and cache.set() the response\n * }\n * ```\n */\nexport class LRUCache<K, V> {\n  private _maxSize: number;\n  private _data: Map<K, V>;\n  private _metrics: Metrics = { hits: 0, misses: 0 };\n\n  constructor(maxSize: number = 500) {\n    if (maxSize <= 0) {\n      throw new Error(\"LRU Cache capacity must be >= 1\");\n    }\n\n    if (__DEV__) {\n      this._metrics = { hits: 0, misses: 0 };\n    }\n\n    this._maxSize = maxSize;\n    this._data = new Map<K, V>();\n  }\n\n  private _trim = () => {\n    while (this._data.size > this._maxSize) {\n      const firstKey = this._data.keys().next().value;\n      if (firstKey === undefined) {\n        throw new Error(\"Absurd\");\n      }\n      this._data.delete(firstKey);\n    }\n  };\n\n  /**\n   * Get cache performance metrics from this LRU Cache instance.\n   *\n   * In development mode, this returns insights into hits/misses of the cache,\n   * as well as the current configuration and entry count.\n   *\n   * In production mode, this returns a placeholder object, as metric collection\n   * is not active in production.\n   */\n  getMetrics(): LRUCacheMetrics | void {\n    if (__DEV__) {\n      const { hits = 0, misses = 0 } = this._metrics ?? {};\n      const lookups = hits + misses;\n      const hitRate = lookups === 0 ? 0 : hits / lookups;\n\n      return {\n        lookups,\n        hits: hits,\n        misses: misses,\n        capacity: this._maxSize,\n        entries: this._data.size,\n        hitRate,\n      };\n    }\n  }\n\n  /**\n   * Update the maximum cache size for this instance. Immediately triggers a\n   * purge of cached contents if the new capacity is less than the current\n   * number of cached entries.\n   */\n  setCapacity = (maxSize: number): void => {\n    if (maxSize <= 0 && __DEV__) {\n      console.warn(\n        \"[Palette LRU Cache] Cache size is <= 0. Cache is disabled.\",\n      );\n    }\n\n    this._maxSize = maxSize;\n    this._trim();\n  };\n\n  /**\n   * Fetch a value from the cache, returning `undefined` if no value was found\n   */\n  get(key: K): V | undefined {\n    const value = this._data.get(key);\n\n    if (value === undefined) {\n      if (__DEV__) {\n        this._metrics.misses += 1;\n      }\n      return undefined;\n    }\n\n    // Delete and re-set the value to move the key to the end of the key list\n    this._data.delete(key);\n    this._data.set(key, value);\n\n    if (__DEV__) {\n      this._metrics.hits += 1;\n    }\n\n    return value;\n  }\n\n  /**\n   * Set a value in the cache. This also moves the value to the back of the list\n   * of values to consider evicting when the cache is full.\n   */\n  set(key: K, value: V): void {\n    // Remove if exists to update position\n    if (this._data.has(key)) {\n      this._data.delete(key);\n    }\n\n    this._data.set(key, value);\n\n    if (this._data.size > this._maxSize) {\n      this._trim();\n    }\n  }\n\n  /**\n   * Clear all contents of this cache instance\n   */\n  clear(): void {\n    this._data.clear();\n  }\n\n  /**\n   * Get the number of entries in this cache instance\n   */\n  get size(): number {\n    return this._data.size;\n  }\n}\n\nexport default LRUCache;\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport LRUCache from \"./lru-cache\";\n\nexport const fragmentCache = new LRUCache<string, DocumentFragment>();\n\nexport function htmlToFragment(html: string): DocumentFragment {\n  const lookup = fragmentCache.get(html);\n\n  if (lookup !== undefined) {\n    return lookup.cloneNode(true) as DocumentFragment;\n  }\n\n  const temp = document.createElement(\"template\");\n  temp.innerHTML = html;\n  fragmentCache.set(html, temp.content);\n  return temp.content.cloneNode(true) as DocumentFragment;\n}\n\nexport function saveFragment(html: string, fragment: DocumentFragment): void {\n  fragmentCache.set(html, fragment);\n}\n",
    "/*\n * Copyright © Rustic Arcade, LLC 2026\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nexport function serializeAttribute(value: unknown): string | null {\n  if (typeof value === \"string\" || typeof value === \"number\") {\n    return `${value}`;\n  }\n\n  if (value === true) {\n    return \"\";\n  }\n\n  if (value === null || value === false || value === undefined) {\n    return null;\n  }\n\n  return value.toString();\n}\n\nexport function applyAttribute(\n  element: HTMLElement,\n  name: string,\n  value: string | null,\n): void {\n  if (value === null) {\n    element.removeAttribute(name);\n  } else {\n    element.setAttribute(name, value);\n  }\n}\n\nexport function getElementAttributes(\n  source: HTMLElement,\n): Record<string, string | null> {\n  const attrs: Record<string, string | null> = {};\n\n  for (const name of source.getAttributeNames()) {\n    attrs[name] = serializeAttribute(source.getAttribute(name));\n  }\n\n  return attrs;\n}\n\nexport function applyElementAttributes(\n  target: HTMLElement,\n  attrs: Record<string, unknown>,\n): void {\n  const currentNames = new Set(target.getAttributeNames());\n  const incomingNames = new Set(Object.keys(attrs));\n  const attributesToRemove = currentNames.difference(incomingNames);\n\n  for (const attr of attributesToRemove) {\n    target.removeAttribute(attr);\n  }\n\n  for (const [name, val] of Object.entries(attrs)) {\n    applyAttribute(target, name, serializeAttribute(val));\n  }\n}\n\nexport function formatAttributeRecord(\n  record: Record<string, unknown>,\n): Record<string, string | null> {\n  const out: Record<string, string | null> = {};\n\n  for (const [key, val] of Object.entries(record)) {\n    out[key] = serializeAttribute(val);\n  }\n\n  return out;\n}\n",
    "/*\n * Copyright © Rustic Arcade, LLC 2026\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\n/**\n * Check if a given string is a valid html tagname, optimized for hot paths.\n *\n * @remarks\n * This function avoids using the regex engine for performance\n */\nexport function isTagName(str: string): boolean {\n  for (let i = 0; i < str.length; i++) {\n    const char = str.charAt(i);\n\n    if (\n      !(\n        char === \"-\" ||\n        (char >= \"A\" && char <= \"Z\") ||\n        (char >= \"a\" && char <= \"z\")\n      )\n    ) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * A performance optimized version of `.matches()` which includes faster\n * matching strategies for common queries.\n *\n * @remarks\n * Optimized query types:\n *\n * - Single ID selector `\"#identifier\"`\n * - Single class selector `\".classname\"`\n * - Tagname selector `\"button\"`\n * - Simple attribute selector `\"[attr='value']\"`\n *\n * All other types of queries use the base .matches() for comparison\n */\nexport function elementMatches(element: Element, query: string) {\n  // If the query is a simple ID, check it directly\n  if (\n    query[0] === \"#\" &&\n    query.indexOf(\" \") === -1 &&\n    query.indexOf(\".\") === -1 &&\n    query.indexOf(\"[\") === -1 &&\n    query.indexOf(\":\") === -1 &&\n    query.indexOf(\">\") === -1\n  ) {\n    return element.id === query.slice(1);\n  }\n\n  // If the query is a simple classname, check it directly\n  if (\n    query[0] === \".\" &&\n    query.indexOf(\" \") === -1 &&\n    query.indexOf(\"#\") === -1 &&\n    query.indexOf(\"[\") === -1 &&\n    query.indexOf(\":\") === -1 &&\n    query.indexOf(\">\") === -1\n  ) {\n    return element.classList.contains(query.slice(1));\n  }\n\n  // If the query is for just a tagname, check it directly\n  if (isTagName(query)) {\n    return element.tagName.toLowerCase() === query.toLowerCase();\n  }\n\n  // If the query is for a single selector value, check it directly\n  if (\n    query[0] === \"[\" &&\n    query[query.length - 1] === \"]\" &&\n    query.indexOf(\" \") === -1 &&\n    query.indexOf(\":\") === -1\n  ) {\n    const attr = query.slice(1, -1);\n    const eqIndex = attr.indexOf(\"=\");\n    if (eqIndex === -1) {\n      return element.hasAttribute(attr);\n    }\n    const attrName = attr.slice(0, eqIndex);\n    const attrValue = attr.slice(eqIndex + 1).replace(/^[\"']|[\"']$/g, \"\");\n    return element.getAttribute(attrName) === attrValue;\n  }\n\n  // Otherwise, use native `.matches` for complex stuff\n  return element.matches(query);\n}\n",
    "type WalkerFn = (node: Node) => boolean | void;\n\n/**\n * Walk up the parent nodes from a target child element and invoke a function\n * on each node. If the function returns `true` for a node, execution will\n * stop and this function will also return `true`. If the function does not\n * return true, it will continue walking up the parent nodes.\n */\nexport function walkParents(target: Node, fn: WalkerFn): boolean {\n  let current: Node | null = target.parentNode;\n\n  while (current !== null) {\n    const result = fn(current);\n\n    if (result) {\n      return true;\n    }\n\n    if (isShadowRoot(current)) {\n      current = current.host;\n    } else {\n      current = current.parentNode;\n    }\n  }\n\n  return false;\n}\n\nexport function isElement(value: unknown): value is Element {\n  return (\n    value !== null && typeof value === \"object\" && value instanceof Element\n  );\n}\n\nexport function isHTMLElement(value: unknown): value is HTMLElement {\n  return (\n    value !== null && typeof value === \"object\" && value instanceof HTMLElement\n  );\n}\n\nexport function isHTMLTemplateElement(\n  value: unknown,\n): value is HTMLTemplateElement {\n  return (\n    value !== null &&\n    typeof value === \"object\" &&\n    value instanceof HTMLTemplateElement\n  );\n}\nexport function isShadowRoot(value: unknown): value is ShadowRoot {\n  return (\n    value !== null && typeof value === \"object\" && value instanceof ShadowRoot\n  );\n}\n\nexport function isNode(value: unknown): value is Node {\n  return value !== null && typeof value === \"object\" && value instanceof Node;\n}\n\nexport function isComment(value: unknown): value is Comment {\n  return (\n    value !== null && typeof value === \"object\" && value instanceof Comment\n  );\n}\n",
    "export const REF_ATTR = \"data-node-ref\";\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { LRUCache } from \"#util\";\n\nconst enum NotationPrefix {\n  Attributes = \"@\",\n  State = \"$\",\n  Data = \"*\",\n  Item = \"#\",\n}\n\nconst PREFIX_MAPPING: Record<NotationPrefix, string> = {\n  [NotationPrefix.Attributes]: \"attr\",\n  [NotationPrefix.State]: \"state\",\n  [NotationPrefix.Data]: \"data\",\n  [NotationPrefix.Item]: \"item\",\n};\n\nconst prefixMapping = new Map(Object.entries(PREFIX_MAPPING));\n\nexport type ParsedNotation = {\n  /** The raw string representation of the parsed notation */\n  base: string;\n\n  /** An array of property names forming a path to the notation value */\n  path: string[];\n\n  modifiers?: {\n    not?: boolean;\n  };\n};\n\nexport const parsedNotationCache = new LRUCache<string, ParsedNotation>();\n\n/**\n * Parse a notation into an object with runtime information\n *\n * @remarks\n * Four notations are supported:\n *\n * - `@attrname` -> Root element attributes\n * - `$statevalue` -> Stateful content\n * - `*property.or.whatever` -> Computed data properties\n * - `#color` -> List item properties\n */\nexport function parseNotation(notation: string): ParsedNotation {\n  const cached = parsedNotationCache.get(notation);\n  if (cached) {\n    return cached;\n  }\n\n  // Check for prefix modifiers\n  let notModifier = false;\n\n  let pathPart = \"\";\n  const computedPath: string[] = [];\n\n  let isFirst = true;\n  for (const char of notation) {\n    // ! at position 0 -> Enable NOT modifier, dont count towards idx\n    if (isFirst && char === \"!\") {\n      notModifier = true;\n    }\n\n    // Otherwise, position 0 must be a prefix\n    else if (isFirst) {\n      const prefix = prefixMapping.get(char);\n\n      if (!prefix) {\n        throw new PaletteError(\n          ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX,\n          notation,\n        );\n      }\n\n      computedPath.push(prefix);\n      isFirst = false;\n    }\n\n    // Collect characters and push when hitting a dot or end\n    else if (char === \".\") {\n      if (pathPart.length) {\n        computedPath.push(pathPart);\n        pathPart = \"\";\n      } else {\n        throw new PaletteError(\n          ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX,\n          notation,\n        );\n      }\n    } else {\n      pathPart += char;\n    }\n  }\n\n  // Add the final part which must exist (otherwise, it ended in a dot)\n  if (!pathPart.length) {\n    throw new PaletteError(\n      ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX,\n      notation,\n    );\n  }\n\n  computedPath.push(pathPart);\n\n  if (computedPath.length < 2) {\n    throw new PaletteError(\n      ErrorCode.TEMPLATE_INVALID_NOTATION_SYNTAX,\n      notation,\n    );\n  }\n\n  const parsedNotation: ParsedNotation = {\n    base: notation,\n    path: computedPath,\n    modifiers: notModifier ? { not: true } : undefined,\n  };\n\n  parsedNotationCache.set(notation, parsedNotation);\n\n  return parsedNotation;\n}\n\nexport type NotationAccessor = (source: unknown) => unknown;\n\nexport const valueAccessorCache = new LRUCache<string, NotationAccessor>();\n\nexport function buildValueAccessor(notation: ParsedNotation): NotationAccessor {\n  const { path, modifiers, base } = notation;\n\n  const cached = valueAccessorCache.get(base);\n  if (cached) {\n    return cached;\n  }\n\n  if (path.length < 2) {\n    // Notations must always have at least 2 parts: the namespace, and at least\n    // one property name on the namespace (example: [\"state\", \"visible\"])\n    throw new PaletteError(ErrorCode.INVARIANT);\n  }\n\n  const accessor = (source: unknown) => {\n    let current = source;\n\n    for (const part of path) {\n      if (!current || typeof current !== \"object\") {\n        return null;\n      }\n\n      current = current[part as keyof typeof current];\n    }\n\n    if (modifiers?.not) {\n      if (path[0] === \"attr\") {\n        return current !== \"\" && !current;\n      }\n      return !current;\n    }\n\n    return current;\n  };\n\n  valueAccessorCache.set(base, accessor);\n\n  return accessor;\n}\n",
    "import { htmlToFragment } from \"#util\";\nimport { isHTMLElement } from \"../util/dom\";\nimport { Directive } from \"./directive\";\nimport { Template } from \"./template\";\n\nexport function htmlStringToTemplate(html: string): Template {\n  const fragment = htmlToFragment(html);\n  const templateElement = document.createElement(\"template\");\n  templateElement.content.appendChild(fragment);\n  return new Template(templateElement);\n}\n\nexport function collectOperableNodes(\n  fragment: DocumentFragment,\n): HTMLElement[] {\n  const walker = document.createTreeWalker(fragment, NodeFilter.SHOW_ELEMENT);\n  const knownIgnores = new Set<Node>();\n  const nodes: HTMLElement[] = [];\n\n  let currentNode: Node | null = walker.nextNode();\n\n  while (currentNode) {\n    if (!isHTMLElement(currentNode)) {\n      currentNode = walker.nextNode();\n      continue;\n    }\n\n    let parent = currentNode.parentNode;\n    let isInoperable = false;\n\n    while (parent && !isInoperable) {\n      if (\n        knownIgnores.has(parent) ||\n        (isHTMLElement(parent) &&\n          (parent.hasAttribute(Directive.Each) ||\n            parent.hasAttribute(Directive.If) ||\n            parent.hasAttribute(Directive.Else) ||\n            parent.hasAttribute(Directive.ElseIf)))\n      ) {\n        isInoperable = true;\n        knownIgnores.add(currentNode);\n        break;\n      }\n\n      parent = parent.parentNode;\n    }\n\n    if (!isInoperable) {\n      nodes.push(currentNode);\n    }\n\n    currentNode = walker.nextNode();\n  }\n\n  return nodes;\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { LRUCache, saveFragment } from \"#util\";\nimport { isHTMLElement } from \"../util/dom\";\nimport { REF_ATTR } from \"./constant\";\nimport { Directive } from \"./directive\";\nimport { type ParsedNotation, parseNotation } from \"./syntax\";\nimport {\n  type AnyScheme,\n  type AttributeUpdateScheme,\n  type ConditionalRenderScheme,\n  type ConditionalRenderSchemeBranch,\n  type ContentSwapScheme,\n  type ListRenderScheme,\n  UpdateType,\n} from \"./types\";\nimport { collectOperableNodes } from \"./util\";\n\nconst requiresNotation = new Set<string>([\n  Directive.Each,\n  Directive.If,\n  Directive.ElseIf,\n  Directive.Key,\n  Directive.Swap,\n  Directive.Tag,\n]);\n\n/**\n * A JSON-serializable representation of a {@link Template} instance, including\n * everything needed to recreate the template.\n */\nexport interface CompiledTemplate {\n  html: string;\n  schemes: AnyScheme[];\n  notations: Record<string, ParsedNotation>;\n}\n\nexport const compiledTemplateCache = new LRUCache<\n  HTMLTemplateElement,\n  CompiledTemplate\n>();\n\n/**\n * Compile an {@link HTMLTemplateElement} into a {@link CompiledTemplate} for\n * caching, cloning, or storage.\n *\n * Compiled template objects contain a JSON-serializable data representation of\n * a template and can be prepared using {@link prepareCompiledTemplate} to\n * create new Template instances.\n *\n * @example\n *\n * ```typescript\n * const compiled = compileTemplate($templateElement);\n * const stringified = JSON.stringify(compiled); // a JSON template bundle\n * ```\n */\nexport function compileTemplate(source: HTMLTemplateElement): CompiledTemplate {\n  // Check if the template is already cached\n  const cachedTemplate = compiledTemplateCache.get(source);\n  if (cachedTemplate) {\n    return cachedTemplate;\n  }\n\n  const parsedNotations = new Map<string, ParsedNotation>();\n  const compiledSchemes: AnyScheme[] = [];\n\n  let nextNodeRef = 0;\n  const ensureNodeRef = (el: HTMLElement): string => {\n    let ref = el.getAttribute(REF_ATTR);\n    if (!ref) {\n      ref = `el-${nextNodeRef++}`;\n      el.setAttribute(REF_ATTR, ref);\n    }\n    return ref;\n  };\n\n  const clonedTemplateElement = source.content.cloneNode(\n    true,\n  ) as DocumentFragment;\n\n  const nodes: HTMLElement[] = collectOperableNodes(clonedTemplateElement);\n\n  for (const node of nodes) {\n    const allAttributesForNode = node.getAttributeNames();\n\n    for (const attributeName of allAttributesForNode) {\n      const attributeValue = node.getAttribute(attributeName);\n\n      // Bail quickly if this isn't a directive\n      if (attributeValue === null || attributeName[0] !== \":\") {\n        continue;\n      }\n\n      // Expect any ::key to have an ::each\n      if (attributeName === Directive.Key) {\n        if (!allAttributesForNode.includes(Directive.Each)) {\n          throw new PaletteError(ErrorCode.TEMPLATE_INVALID_KEY_DIRECTIVE);\n        }\n        continue;\n      }\n\n      // Ensure required notations exist\n      if (requiresNotation.has(attributeName) && attributeValue === \"\") {\n        throw new PaletteError(\n          ErrorCode.TEMPLATE_MISSING_NOTATION,\n          attributeName,\n        );\n      }\n\n      let notation = parsedNotations.get(attributeValue);\n\n      if (notation === undefined) {\n        notation = parseNotation(attributeValue);\n        parsedNotations.set(attributeValue, notation);\n      }\n\n      node.removeAttribute(attributeName);\n\n      // If the second character is not a colon, it is a binding\n      if (attributeName[1] !== \":\") {\n        const bindName = attributeName.slice(1);\n\n        const scheme: AttributeUpdateScheme = {\n          type: UpdateType.Attribute,\n          notation: parseNotation(attributeValue),\n          attribute: bindName,\n          nodeRef: ensureNodeRef(node),\n        };\n\n        compiledSchemes.push(scheme);\n      }\n\n      // TAG CHANGE SCHEMES\n      else if (attributeName === Directive.Tag) {\n        compiledSchemes.push({\n          type: UpdateType.Tag,\n          notation,\n          nodeRef: ensureNodeRef(node),\n        });\n      }\n\n      // LIST RENDER SCHEMES\n      else if (attributeName === Directive.Each) {\n        const nodeRef = ensureNodeRef(node);\n\n        // A ::key directive is required with any ::each\n        const keyNotation = node.getAttribute(Directive.Key);\n        if (keyNotation === null) {\n          throw new PaletteError(ErrorCode.TEMPLATE_MISSING_LIST_KEY);\n        }\n\n        node.removeAttribute(Directive.Key);\n\n        const listContentHtml = node.innerHTML;\n\n        while (node.firstChild) {\n          node.removeChild(node.firstChild);\n        }\n\n        const scheme: ListRenderScheme = {\n          type: UpdateType.List,\n          notation,\n          keyNotation: parseNotation(keyNotation),\n          nodeRef,\n          listContentHtml,\n        };\n\n        compiledSchemes.push(scheme);\n      }\n\n      // CONTENT SWAP SCHEMES\n      else if (attributeName === Directive.Swap) {\n        const scheme: ContentSwapScheme = {\n          type: UpdateType.Swap,\n          notation,\n          nodeRef: ensureNodeRef(node),\n        };\n\n        compiledSchemes.push(scheme);\n      }\n\n      // CONDITIONAL RENDER SCHEMES\n      else if (attributeName === Directive.If) {\n        const scheme: ConditionalRenderScheme = {\n          type: UpdateType.Conditional,\n          branches: [],\n        };\n\n        // First branch - this IF\n        node.removeAttribute(Directive.If);\n        const ifBranch: ConditionalRenderSchemeBranch = {\n          type: Directive.If,\n          notation,\n          branchRootRef: ensureNodeRef(node),\n          branchTemplateHTML: node.innerHTML,\n        };\n\n        scheme.branches.push(ifBranch);\n\n        let condNode = node.nextElementSibling;\n\n        // Check future nodes for else-if\n        while (condNode?.hasAttribute(Directive.ElseIf)) {\n          if (!isHTMLElement(condNode)) {\n            break;\n          }\n\n          const baseElseIfNotation = condNode.getAttribute(Directive.ElseIf);\n\n          if (!baseElseIfNotation) {\n            throw new PaletteError(\n              ErrorCode.TEMPLATE_MISSING_NOTATION,\n              Directive.ElseIf,\n            );\n          }\n\n          // If the notation has been parsed before, reuse that\n          let parsedElseIfNotation = parsedNotations.get(baseElseIfNotation);\n\n          if (parsedElseIfNotation === undefined) {\n            parsedElseIfNotation = parseNotation(baseElseIfNotation);\n            parsedNotations.set(baseElseIfNotation, parsedElseIfNotation);\n          }\n\n          condNode.removeAttribute(Directive.ElseIf);\n\n          const elseIfBranch: ConditionalRenderSchemeBranch = {\n            type: Directive.ElseIf,\n            notation: parsedElseIfNotation,\n            branchRootRef: ensureNodeRef(condNode),\n            branchTemplateHTML: condNode.innerHTML,\n          };\n\n          scheme.branches.push(elseIfBranch);\n          condNode = condNode.nextElementSibling;\n        }\n\n        // Else\n        if (\n          condNode &&\n          isHTMLElement(condNode) &&\n          condNode?.hasAttribute(Directive.Else)\n        ) {\n          condNode.removeAttribute(Directive.Else);\n\n          const elseBranch: ConditionalRenderSchemeBranch = {\n            type: Directive.Else,\n            branchRootRef: ensureNodeRef(condNode),\n            branchTemplateHTML: condNode.innerHTML,\n          };\n\n          scheme.branches.push(elseBranch);\n        }\n\n        compiledSchemes.push(scheme);\n      } else {\n        if (__DEV__) {\n          if (\n            attributeName === Directive.Else ||\n            attributeName === Directive.ElseIf\n          ) {\n            throw new PaletteError(ErrorCode.TEMPLATE_INVALID_CONDITIONAL);\n          }\n\n          console.warn(`Template: ${attributeName} is not a valid directive`);\n        }\n      }\n    }\n  }\n\n  const notations: Record<string, ParsedNotation> = {};\n\n  for (const [key, val] of parsedNotations) {\n    notations[key] = val;\n  }\n\n  const temp = document.createElement(\"div\");\n  temp.appendChild(clonedTemplateElement.cloneNode(true));\n  const html = temp.innerHTML;\n\n  const compiled: CompiledTemplate = {\n    html,\n    schemes: compiledSchemes,\n    notations,\n  };\n\n  // Cache the compiled template and html/fragment combo to prevent needing\n  // to re-create the fragment from HTML again when compiling at runtime\n  compiledTemplateCache.set(source, compiled);\n  saveFragment(html, clonedTemplateElement);\n\n  return compiled;\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport type { Component } from \"#component\";\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { isTagName } from \"#util\";\n\nexport function parseCSSTemplateStringValue(\n  val: string | typeof Component,\n): string {\n  // Convert component refs to their tagnames\n  if (typeof val === \"function\") {\n    const tagName = val.tagName;\n    if (!isTagName(tagName)) {\n      throw new PaletteError(\n        ErrorCode.TEMPLATE_INVALID_COMPONENT,\n        val.name,\n        val.tagName,\n      );\n    }\n    return tagName;\n  }\n\n  if (typeof val === \"string\") {\n    return val;\n  }\n\n  throw new PaletteError(ErrorCode.TEMPLATE_INVALID_VALUE, String(val));\n}\n\n/**\n * @returns An array of {@link CSSStyleSheet}s containing the provided CSS\n */\nexport function css(\n  strings: TemplateStringsArray,\n  ...values: (string | typeof Component<any>)[]\n): CSSStyleSheet {\n  let result = strings[0] ?? \"\";\n\n  for (let i = 0; i < values.length; i++) {\n    const nextVal = values[i] ?? \"\";\n    const nextStr = strings[i + 1] ?? \"\";\n    result += parseCSSTemplateStringValue(nextVal);\n    result += nextStr;\n  }\n\n  const sheet = new CSSStyleSheet();\n  sheet.replaceSync(result);\n  return sheet;\n}\n\nexport type ClassifyInput =\n  | string\n  | number\n  | boolean\n  | undefined\n  | null\n  | Record<string, any>\n  | ClassifyInput[];\n\n/**\n * Given flexible input, generate a string suitable for setting as an html class\n *\n * @example\n *\n * ```typescript\n * classify(\"my-class\", \"another-class\") // \"my-class another-class\"\n * classify([\"my-class\", \"another-class\"]) // \"my-class another-class\"\n * classify({ enabled: true, disabled: false }) // \"enabled\"\n * ```\n */\nexport function classify(...args: ClassifyInput[]): string {\n  let resultString = \"\";\n\n  for (let index = 0; index < args.length; index++) {\n    const argument = args[index];\n\n    if (!argument) {\n      continue;\n    }\n\n    // Strings/nums -> Direct append\n    if (typeof argument === \"string\" || typeof argument === \"number\") {\n      if (resultString) {\n        resultString += \" \";\n      }\n      resultString += argument;\n      continue;\n    }\n\n    // Handle arrays recursively\n    if (Array.isArray(argument)) {\n      const nestedResult = classify(...argument);\n      if (nestedResult) {\n        if (resultString) {\n          resultString += \" \";\n        }\n        resultString += nestedResult;\n      }\n      continue;\n    }\n\n    // Handle objects with conditional class names\n    if (typeof argument === \"object\") {\n      for (const className in argument) {\n        // Only include class name if its value is truthy\n        if (argument[className]) {\n          if (resultString) {\n            resultString += \" \";\n          }\n          resultString += className;\n        }\n      }\n    }\n  }\n\n  return resultString;\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { Component } from \"#component\";\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { isTagName } from \"#util\";\nimport { isHTMLTemplateElement } from \"../util/dom\";\n\nexport function parseTemplateStringValue(\n  val: string | typeof Component | HTMLTemplateElement,\n): string {\n  if (isHTMLTemplateElement(val)) {\n    return val.innerHTML;\n  }\n\n  if (Component.isComponentClass(val)) {\n    const tagName = val.tagName;\n    if (!isTagName(tagName)) {\n      throw new PaletteError(\n        ErrorCode.TEMPLATE_INVALID_COMPONENT,\n        val.name,\n        val.tagName,\n      );\n    }\n    return tagName;\n  }\n\n  if (typeof val === \"string\") {\n    return `<span ::swap=\"${val}\"></span>`;\n  }\n\n  throw new PaletteError(ErrorCode.TEMPLATE_INVALID_VALUE, String(val));\n}\n\n/**\n * Create an {@link HTMLTemplateElement} from the provided HTML string.\n *\n * These HTML Templates can be used as standard HTML Templates, or as the\n * foundation for a {@link Component} or standalone {@link Template}\n *\n * Interpolates values in the template string to provide helpers for composing\n * templates:\n *\n * - HTMLTemplateElement references are serialized to HTML and inlined\n * - Strings are modified to become <span> tags with the ::swap directive set\n *   to the string value. This is helpful shorthand for content placeholders.\n *\n * @example\n *\n * This template string\n *\n * ```typescript\n * const $template = html`\n * <div :class=\"*classnames\">\n *   ${\"@content\"}\n * </div>\n * `\n * ```\n *\n * Produces this template element (portrayed as HTML)\n *\n * ```html\n * <template>\n *   <div :class=\"*classnames\">\n *     <span ::swap=\"@content\"></span>\n *   </div>\n * </template>\n * ```\n */\nexport function html(\n  strings: TemplateStringsArray,\n  ...values: (\n    | `@${string}`\n    | `$${string}`\n    | `#${string}`\n    | `*${string}`\n    | HTMLTemplateElement\n    | typeof Component<any>\n  )[]\n): HTMLTemplateElement {\n  const fullString = strings.reduce((acc, str, i) => {\n    const parsedValue = values[i]\n      ? `${parseTemplateStringValue(values[i])}`\n      : \"\";\n    return acc + str + parsedValue;\n  }, \"\");\n\n  const templateElement = document.createElement(\"template\");\n  templateElement.innerHTML = fullString;\n  return templateElement;\n}\n",
    "export const SKIPPED_JOB = Symbol(\"noop\");\nexport type SkippedJob = typeof SKIPPED_JOB;\n",
    "import { classify } from \"#helper\";\nimport { applyAttribute, serializeAttribute } from \"#util\";\nimport type { AttributeUpdatePlan } from \"../types\";\nimport { SKIPPED_JOB, type SkippedJob } from \"./common\";\n\nexport type AttributeUpdateJob = [\n  node: HTMLElement,\n  name: string,\n  value: string | null,\n];\n\nexport function prepareAttributeJob(\n  plan: AttributeUpdatePlan,\n  values: Map<string, unknown>,\n): AttributeUpdateJob | SkippedJob {\n  const rawValue = values.get(plan.notation.base);\n  let value = typeof rawValue === \"function\" ? rawValue(plan.node) : rawValue;\n\n  // Parse the value with `classify` if setting the class attribute\n  if (plan.attribute === \"class\" && typeof value !== \"string\") {\n    value = classify(value);\n  }\n\n  const serializedValue = serializeAttribute(value);\n  const current = plan.node.getAttribute(plan.attribute);\n\n  if (serializedValue !== current) {\n    return [plan.node, plan.attribute, serializedValue];\n  }\n\n  return SKIPPED_JOB;\n}\n\nexport function runAttributeJobs(jobs: AttributeUpdateJob[]): void {\n  for (const [node, name, value] of jobs) {\n    applyAttribute(node, name, value);\n  }\n}\n",
    "import { ErrorCode, PaletteError } from \"#error\";\nimport { isHTMLElement } from \"../../util/dom\";\nimport { Directive } from \"../directive\";\nimport type {\n  ConditionalRenderPlan,\n  ConditionalRenderPlanBranch,\n} from \"../types\";\nimport type { SkippedJob } from \"./common\";\n\nexport type ConditionalRenderJob = [\n  plan: ConditionalRenderPlan,\n  branch: ConditionalRenderPlanBranch | null,\n  values: Map<string, unknown>,\n];\n\nexport function prepareConditionalRenderJob(\n  plan: ConditionalRenderPlan,\n  values: Map<string, unknown>,\n): ConditionalRenderJob | SkippedJob {\n  // Determine which branch to dipslay\n  let displayedBranch: ConditionalRenderPlanBranch | null = null;\n\n  for (const branch of plan.branches) {\n    if (branch.type === Directive.Else) {\n      displayedBranch = branch;\n      break;\n    } else {\n      const rawValue = values.get(branch.notation.base);\n      const value =\n        typeof rawValue === \"function\" ? rawValue(plan.start) : rawValue;\n\n      if (value) {\n        displayedBranch = branch;\n        break;\n      }\n    }\n  }\n\n  return [plan, displayedBranch, values];\n}\n\nexport function runConditionalRenderJobs(jobs: ConditionalRenderJob[]): void {\n  for (const [plan, branch, values] of jobs) {\n    const parent = plan.start.parentNode;\n\n    if (!parent) {\n      throw new PaletteError(ErrorCode.TEMPLATE_PARENT_REQUIRED);\n    }\n\n    // If the current root and branch root differ, remove content\n    if (branch === null || !Object.is(plan.currentRoot, branch.branchRoot)) {\n      // Remove existing content if the branch has changed\n      const nodesToRemove = new Set<Node>();\n\n      let node: Node | null = plan.start;\n      while (node && node !== plan.end) {\n        if (isHTMLElement(node)) {\n          nodesToRemove.add(node);\n        }\n        node = node.nextSibling;\n      }\n\n      for (const toRemove of nodesToRemove) {\n        parent.removeChild(toRemove);\n      }\n\n      // Then add the branch root if need be\n      if (branch) {\n        parent.insertBefore(branch.branchRoot, plan.end);\n      }\n    }\n\n    // Null branch -> Render nothing\n    if (branch === null) {\n      continue;\n    }\n\n    // Otherwise render branch template\n    branch.branchTemplate.renderWithValues(branch.branchRoot, values);\n  }\n}\n",
    "import { ErrorCode, PaletteError } from \"#error\";\nimport { applyElementAttributes, formatAttributeRecord } from \"#util\";\nimport { isHTMLElement } from \"../../util/dom\";\nimport { buildValueAccessor } from \"../syntax\";\nimport { Template, type TemplateContext } from \"../template\";\nimport type { ListRenderPlan } from \"../types\";\nimport type { SkippedJob } from \"./common\";\n\nexport type ListRenderJobItem = {\n  context: TemplateContext;\n  attrs: Record<string, string | null>;\n  root: HTMLElement;\n  template: Template;\n};\n\nexport type ListRenderJob = [plan: ListRenderPlan, list: ListRenderJobItem[]];\n\nfunction fetchListData(\n  plan: ListRenderPlan,\n  values: Map<string, unknown>,\n): Record<string, unknown>[] {\n  const notationValue = values.get(plan.notation.base);\n  const evaluatedValue =\n    typeof notationValue === \"function\"\n      ? notationValue(plan.startMarker.parentNode)\n      : notationValue;\n\n  if (evaluatedValue === null || evaluatedValue === undefined) {\n    return [];\n  }\n\n  if (Array.isArray(evaluatedValue)) {\n    return evaluatedValue;\n  }\n\n  throw new PaletteError(ErrorCode.TEMPLATE_INVALID_LIST_DATA);\n}\n\nfunction collectHTMLElements(start: Node, end: Node): Set<HTMLElement> {\n  let node: Node | null = start;\n  const nodeSet = new Set<HTMLElement>();\n\n  while (node && node !== end) {\n    if (isHTMLElement(node)) {\n      nodeSet.add(node);\n    }\n\n    node = node.nextSibling;\n  }\n\n  return nodeSet;\n}\n\nexport function prepareListRenderJob(\n  plan: ListRenderPlan,\n  values: Map<string, unknown>,\n): ListRenderJob | SkippedJob {\n  // Fetch the data for rendering the updated list items\n  const listData = fetchListData(plan, values);\n\n  // Empty -> Remove the list contents entirely and exit\n  if (listData.length === 0) {\n    return [plan, []];\n  }\n\n  // Collect existing elements from the DOM for assessment\n  const {\n    rowTemplatesByRoot,\n    rowTemplateElement,\n    rowRootPrototype: rowRootElement,\n  } = plan;\n  const keyAccessor = buildValueAccessor(plan.keyNotation);\n  const listRenderContexts: Map<unknown, ListRenderJobItem> = new Map();\n\n  for (const item of listData) {\n    const context: TemplateContext = {\n      item,\n    };\n\n    const key = keyAccessor(context);\n\n    if (listRenderContexts.has(key)) {\n      throw new PaletteError(\n        ErrorCode.TEMPLATE_DUPLICATE_LIST_KEY,\n        String(key),\n      );\n    }\n\n    // Get or create the HTML Element we expect to see here\n    let rowRoot = plan.rowRootsByKey.get(key);\n\n    if (rowRoot === undefined) {\n      rowRoot = rowRootElement.cloneNode(false) as HTMLElement;\n      plan.rowRootsByKey.set(key, rowRoot);\n    }\n\n    // Get or create the template associated with the row root\n    let rowTemplate = rowTemplatesByRoot.get(rowRoot);\n\n    if (rowTemplate === undefined) {\n      rowTemplate = new Template(rowTemplateElement);\n      rowTemplatesByRoot.set(rowRoot, rowTemplate);\n    }\n\n    const jobItem: ListRenderJobItem = {\n      context,\n      root: rowRoot,\n      template: rowTemplate,\n      attrs: formatAttributeRecord(item),\n    };\n\n    listRenderContexts.set(key, jobItem);\n  }\n\n  // Clean up cached data\n  for (const [key, root] of plan.rowRootsByKey) {\n    if (!listRenderContexts.has(key)) {\n      plan.rowRootsByKey.delete(key);\n      plan.rowTemplatesByRoot.delete(root);\n    }\n  }\n\n  return [plan, Array.from(listRenderContexts.values())];\n}\n\nexport function runListRenderJobs(jobs: ListRenderJob[]): void {\n  for (const [plan, renderItems] of jobs) {\n    const { endMarker, listContainer: listContainerElement } = plan;\n\n    // Fast path for empty lists -> Remove everything and continue\n    if (renderItems.length === 0) {\n      for (const root of plan.rowRootsByKey.values()) {\n        root.remove();\n      }\n      plan.rowRootsByKey.clear();\n      continue;\n    }\n\n    // Otherwise, scan the current nodes and modify as needed\n    const existingDOMNodes = Array.from(\n      collectHTMLElements(plan.startMarker, plan.endMarker),\n    );\n\n    const rootsToKeep = new Set<HTMLElement>();\n\n    let existingDOMNodeIdx = 0;\n\n    for (const renderItem of renderItems) {\n      const { root, attrs: attrMap, context, template } = renderItem;\n      const existingDOMNode = existingDOMNodes[existingDOMNodeIdx];\n\n      // Spread item as attributes on the root and update the template\n      applyElementAttributes(root, attrMap);\n      template.render(root, context);\n\n      rootsToKeep.add(root);\n\n      // Node is the existing DOM Node, continue\n      if (Object.is(existingDOMNode, root)) {\n        existingDOMNodeIdx += 1;\n        continue;\n      }\n\n      // No existing node -> append item\n      if (!existingDOMNode) {\n        listContainerElement.insertBefore(root, endMarker);\n        continue;\n      }\n\n      // DOM node exists but isn't the one we're looking for. Insert before.\n      listContainerElement.insertBefore(root, existingDOMNode);\n    }\n\n    // Remove any remaining old elements\n    for (const root of existingDOMNodes) {\n      if (!rootsToKeep.has(root)) {\n        root.remove();\n        plan.rowTemplatesByRoot.delete(root);\n      }\n    }\n  }\n}\n",
    "import { ErrorCode, PaletteError } from \"#error\";\nimport { isComment, isHTMLElement } from \"../../util/dom\";\nimport type { ContentSwapPlan } from \"../types\";\nimport { SKIPPED_JOB, type SkippedJob } from \"./common\";\n\nexport type ContentSwapJob = [plan: ContentSwapPlan, swap: Node];\n\nexport function prepareContentSwapJob(\n  plan: ContentSwapPlan,\n  values: Map<string, unknown>,\n): ContentSwapJob | SkippedJob {\n  const rawValue = values.get(plan.notation.base);\n  const value = typeof rawValue === \"function\" ? rawValue(plan.node) : rawValue;\n\n  // String, Number, Boolean -> Text Node\n  if (\n    typeof value === \"string\" ||\n    typeof value === \"number\" ||\n    typeof value === \"boolean\"\n  ) {\n    const asStr = `${value}`;\n    if (plan.node.textContent === asStr) {\n      return SKIPPED_JOB;\n    }\n\n    return [plan, document.createTextNode(asStr)];\n  }\n\n  // Nullish values -> Comment\n  else if (value === null || value === undefined) {\n    if (isComment(plan.node)) {\n      return SKIPPED_JOB;\n    }\n\n    return [plan, document.createComment(\"empty\")];\n  }\n\n  // HTMLElement -> Swap nodes\n  else if (isHTMLElement(value)) {\n    if (Object.is(plan.node, value)) {\n      return SKIPPED_JOB;\n    }\n\n    return [plan, value.cloneNode(true)];\n  }\n\n  // Anything else -> Unsupported\n  else {\n    throw new PaletteError(\n      ErrorCode.INVALID_CONTENT,\n      typeof value,\n      JSON.stringify(value),\n    );\n  }\n}\n\nexport function runContentSwapJobs(jobs: ContentSwapJob[]): void {\n  for (const [plan, replace] of jobs) {\n    const parent = plan.node.parentNode;\n\n    if (!parent) {\n      // Should never happen in practice\n      throw new PaletteError(ErrorCode.INVARIANT);\n    }\n\n    parent.replaceChild(replace, plan.node);\n    plan.node = replace;\n  }\n}\n",
    "import type { TagChangePlan } from \"../types\";\nimport { SKIPPED_JOB, type SkippedJob } from \"./common\";\n\nexport type TagChangeJob = [plan: TagChangePlan, newTag: string];\n\n/**\n * Given an element, replace it with a different tag, adopting all attributes\n * and child elements.\n * @param $target The element to swap out\n * @param newTag The new HTML tagName to use\n * @returns The newly swapped-in element\n */\nexport function changeTag($target: HTMLElement, newTag: string): HTMLElement {\n  const $newEl = document.createElement(newTag);\n\n  while ($target.firstChild !== null) {\n    $newEl.appendChild($target.firstChild);\n  }\n\n  for (const attrName of $target.getAttributeNames()) {\n    const val = $target.getAttribute(attrName);\n\n    if (val !== null) {\n      $newEl.setAttribute(attrName, val);\n    }\n  }\n\n  $target.replaceWith($newEl);\n  return $newEl;\n}\n\nexport function prepareTagChangeJob(\n  plan: TagChangePlan,\n  values: Map<string, unknown>,\n): TagChangeJob | SkippedJob {\n  const rawValue = values.get(plan.notation.base) ?? \"\";\n  const value = typeof rawValue === \"function\" ? rawValue(plan.node) : rawValue;\n  const nextTag = `${value}`.toLowerCase();\n  const currentTag = plan.node.tagName.toLowerCase();\n\n  if (!nextTag || nextTag === currentTag) {\n    return SKIPPED_JOB;\n  }\n\n  return [plan, nextTag];\n}\n\nexport function runTagChangeJobs(jobs: TagChangeJob[]): void {\n  for (const [plan, nextTag] of jobs) {\n    plan.node = changeTag(plan.node, nextTag);\n  }\n}\n",
    "import { ErrorCode, PaletteError } from \"#error\";\nimport { type AnyRenderPlan, UpdateType } from \"../types\";\nimport {\n  type AttributeUpdateJob,\n  prepareAttributeJob,\n  runAttributeJobs,\n} from \"./attribute\";\nimport { SKIPPED_JOB } from \"./common\";\nimport {\n  type ConditionalRenderJob,\n  prepareConditionalRenderJob,\n  runConditionalRenderJobs,\n} from \"./conditional\";\nimport {\n  type ListRenderJob,\n  prepareListRenderJob,\n  runListRenderJobs,\n} from \"./list\";\nimport {\n  type ContentSwapJob,\n  prepareContentSwapJob,\n  runContentSwapJobs,\n} from \"./swap\";\nimport {\n  prepareTagChangeJob,\n  runTagChangeJobs,\n  type TagChangeJob,\n} from \"./tag\";\n\nexport * from \"./attribute\";\nexport * from \"./common\";\nexport * from \"./conditional\";\nexport * from \"./list\";\nexport * from \"./swap\";\nexport * from \"./tag\";\n\ninterface RenderJobs {\n  conditionals: ConditionalRenderJob[];\n  attributes: AttributeUpdateJob[];\n  swaps: ContentSwapJob[];\n  tags: TagChangeJob[];\n  lists: ListRenderJob[];\n}\n\nexport function createJobsFromPlans(\n  plans: Set<AnyRenderPlan>,\n  newValues: Map<string, unknown>,\n): RenderJobs {\n  const jobs: RenderJobs = {\n    conditionals: [],\n    attributes: [],\n    swaps: [],\n    tags: [],\n    lists: [],\n  };\n\n  for (const plan of plans) {\n    switch (plan.type) {\n      case UpdateType.Conditional: {\n        const job = prepareConditionalRenderJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.conditionals.push(job);\n        }\n        break;\n      }\n      case UpdateType.Attribute: {\n        const job = prepareAttributeJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.attributes.push(job);\n        }\n        break;\n      }\n      case UpdateType.List: {\n        const job = prepareListRenderJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.lists.push(job);\n        }\n        break;\n      }\n      case UpdateType.Swap: {\n        const job = prepareContentSwapJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.swaps.push(job);\n        }\n        break;\n      }\n      case UpdateType.Tag: {\n        const job = prepareTagChangeJob(plan, newValues);\n        if (job !== SKIPPED_JOB) {\n          jobs.tags.push(job);\n        }\n        break;\n      }\n      default:\n        // Should be impossible given an exhaustive switch case\n        throw new PaletteError(ErrorCode.INVARIANT);\n    }\n  }\n\n  return jobs;\n}\n\nexport function executeRenderJobs(jobs: RenderJobs): void {\n  runConditionalRenderJobs(jobs.conditionals);\n  runAttributeJobs(jobs.attributes);\n  runListRenderJobs(jobs.lists);\n  runContentSwapJobs(jobs.swaps);\n  runTagChangeJobs(jobs.tags);\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { htmlToFragment } from \"#util\";\nimport { isHTMLElement } from \"../util/dom\";\nimport type { CompiledTemplate } from \"./compile\";\nimport { REF_ATTR } from \"./constant\";\nimport { Directive } from \"./directive\";\nimport { buildValueAccessor, type NotationAccessor } from \"./syntax\";\nimport type { Template } from \"./template\";\nimport {\n  type AnyRenderPlan,\n  type AttributeUpdatePlan,\n  type ConditionalRenderPlan,\n  type ContentSwapPlan,\n  type ListRenderPlan,\n  type TagChangePlan,\n  UpdateType,\n} from \"./types\";\nimport { htmlStringToTemplate } from \"./util\";\n\n/**\n * A pre-processed {@link CompiledTemplate} result containing the bulk of the\n * data necessary to create a template instance.\n */\nexport interface PreparedTemplate {\n  fragment: DocumentFragment;\n  plansByNotation: Map<string, Set<AnyRenderPlan>>;\n  notationAccessors: Map<string, NotationAccessor>;\n  subtemplates: Set<Template>;\n}\n\nconst requireParentNode = (node: Node): Node => {\n  if (!node.parentNode) {\n    throw new PaletteError(ErrorCode.TEMPLATE_PARENT_REQUIRED);\n  }\n\n  return node.parentNode;\n};\n\nconst createCommentBefore = (node: Node, text = \"\"): Comment => {\n  const parent = requireParentNode(node);\n  const comment = document.createComment(text);\n  parent.insertBefore(comment, node);\n  return comment;\n};\n\nconst createCommentAfter = (node: Node, text = \"\"): Comment => {\n  const parent = requireParentNode(node);\n  const comment = document.createComment(text);\n  parent.insertBefore(comment, node.nextSibling);\n  return comment;\n};\n\n/**\n * Given a {@link CompiledTemplate} structure, return an object containing the\n * data needed to create new Template instances.\n *\n * @example\n *\n * ```typescript\n * const compiledTemplate = getCompiledTemplateJSON();\n * const parsed = JSON.parse(compiledTemplate);\n * const prepared = prepareCompiledTemplate(parsed);\n *\n * // Elsewhere...\n *\n * const template = new Template(prepared);\n * ```\n */\nexport function prepareCompiledTemplate(\n  compiled: CompiledTemplate,\n  prototypeFragment?: DocumentFragment,\n): PreparedTemplate {\n  const plansByNotation: Map<string, Set<AnyRenderPlan>> = new Map();\n  const notationAccessors: Map<string, NotationAccessor> = new Map();\n  const subtemplates: Set<Template> = new Set();\n  const nodeRefs: Map<string, HTMLElement> = new Map();\n\n  for (const [notation, parsed] of Object.entries(compiled.notations)) {\n    notationAccessors.set(notation, buildValueAccessor(parsed));\n  }\n\n  const fragment = prototypeFragment ?? htmlToFragment(compiled.html);\n\n  const walker = document.createTreeWalker(fragment, NodeFilter.SHOW_ELEMENT, {\n    acceptNode(node: HTMLElement) {\n      return node.hasAttribute(REF_ATTR)\n        ? NodeFilter.FILTER_ACCEPT\n        : NodeFilter.FILTER_SKIP;\n    },\n  });\n\n  let markNode: Node | null = walker.nextNode();\n\n  while (markNode) {\n    if (!isHTMLElement(markNode)) {\n      continue;\n    }\n\n    const ref = markNode.getAttribute(REF_ATTR);\n\n    if (ref === null) {\n      // Should never happen in practice, as the tree walker only surfaces\n      // elements with an extant node ref attribute\n      throw new PaletteError(ErrorCode.INVARIANT);\n    }\n\n    nodeRefs.set(ref, markNode);\n    markNode.removeAttribute(REF_ATTR);\n    markNode = walker.nextNode();\n  }\n\n  const associatePlan = (plan: AnyRenderPlan, notation: string) => {\n    let notationPlans = plansByNotation.get(notation);\n    if (!notationPlans) {\n      notationPlans = new Set();\n      plansByNotation.set(notation, notationPlans);\n    }\n    notationPlans.add(plan);\n  };\n\n  const getByNodeRef = (nodeRef: string): HTMLElement => {\n    const cached = nodeRefs.get(nodeRef);\n\n    if (cached) {\n      return cached;\n    }\n\n    throw new PaletteError(ErrorCode.MISSING_NODE_REF);\n  };\n\n  for (const scheme of compiled.schemes) {\n    // Hydrate List schemes into List plans\n    if (scheme.type === UpdateType.List) {\n      // Use the prototype row root to create the plan\n      const itemPrototype = getByNodeRef(scheme.nodeRef);\n      const listParentNode = requireParentNode(itemPrototype);\n      const rowRootPrototype = itemPrototype.cloneNode(false) as HTMLElement;\n      const startMarker = createCommentBefore(itemPrototype);\n      const endMarker = createCommentAfter(itemPrototype);\n\n      // Remove the original root prototype since we will be rendering new items\n      itemPrototype.remove();\n\n      // Copy the contents of the row into a template\n      const templateContentFragment = htmlToFragment(scheme.listContentHtml);\n      const rowTemplateElement = document.createElement(\"template\");\n      rowTemplateElement.content.appendChild(templateContentFragment);\n\n      const plan: ListRenderPlan = {\n        type: UpdateType.List,\n        notation: scheme.notation,\n        keyNotation: scheme.keyNotation,\n        listContainer: listParentNode,\n        rowTemplateElement,\n        rowRootPrototype,\n        startMarker,\n        endMarker,\n        rowTemplatesByRoot: new WeakMap(),\n        rowRootsByKey: new Map(),\n      };\n\n      associatePlan(plan, scheme.notation.base);\n    }\n\n    // Hydrate conditional render schemes into plans\n    else if (scheme.type === UpdateType.Conditional) {\n      // Grab the first branch and insert the start comment before it\n      const firstBranch = scheme.branches[0];\n      if (!firstBranch) {\n        throw new PaletteError(ErrorCode.INVARIANT);\n      }\n\n      const firstBranchRoot = getByNodeRef(firstBranch.branchRootRef);\n      const startComment = createCommentBefore(firstBranchRoot);\n\n      // Grab the last branch and insert the end comment after it\n      // biome-ignore lint/style/noNonNullAssertion: Logically guaranteed\n      const lastBranch = scheme.branches[scheme.branches.length - 1]!;\n      const lastBranchRoot = getByNodeRef(lastBranch.branchRootRef);\n      const endComment = createCommentAfter(lastBranchRoot);\n\n      const plan: ConditionalRenderPlan = {\n        type: UpdateType.Conditional,\n        start: startComment,\n        end: endComment,\n        branches: [],\n      };\n\n      // Hydrate the branches\n      for (const branch of scheme.branches) {\n        // If and Else-If have notations\n        if (branch.type === Directive.If || branch.type === Directive.ElseIf) {\n          const branchRoot = getByNodeRef(branch.branchRootRef);\n          const branchTemplate = htmlStringToTemplate(\n            branch.branchTemplateHTML,\n          );\n\n          // Add the child template\n          subtemplates.add(branchTemplate);\n\n          plan.branches.push({\n            type: branch.type,\n            notation: branch.notation,\n            branchRoot: getByNodeRef(branch.branchRootRef),\n            branchTemplate: htmlStringToTemplate(branch.branchTemplateHTML),\n          });\n          associatePlan(plan, branch.notation.base);\n          branchRoot.remove();\n        }\n\n        // Else is binary, no notation associated\n        else {\n          plan.branches.push({\n            type: branch.type,\n            branchRoot: getByNodeRef(branch.branchRootRef),\n            branchTemplate: htmlStringToTemplate(branch.branchTemplateHTML),\n          });\n        }\n      }\n    }\n\n    // Swap/Tag are the same signature\n    else if (\n      scheme.type === UpdateType.Swap ||\n      scheme.type === UpdateType.Tag\n    ) {\n      const plan: ContentSwapPlan | TagChangePlan = {\n        type: scheme.type,\n        notation: scheme.notation,\n        node: getByNodeRef(scheme.nodeRef),\n      };\n\n      associatePlan(plan, scheme.notation.base);\n    }\n\n    // Hydrate Attribute update plans\n    else if (scheme.type === UpdateType.Attribute) {\n      const plan: AttributeUpdatePlan = {\n        type: UpdateType.Attribute,\n        attribute: scheme.attribute,\n        notation: scheme.notation,\n        node: getByNodeRef(scheme.nodeRef),\n      };\n\n      associatePlan(plan, plan.notation.base);\n    }\n  }\n\n  return {\n    plansByNotation,\n    notationAccessors,\n    fragment,\n    subtemplates,\n  };\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { fragmentCache, htmlToFragment } from \"../util/fragments\";\nimport {\n  type CompiledTemplate,\n  compiledTemplateCache,\n  compileTemplate,\n} from \"./compile\";\nimport { createJobsFromPlans, executeRenderJobs } from \"./jobs\";\nimport { prepareCompiledTemplate } from \"./prepare\";\nimport {\n  type NotationAccessor,\n  parsedNotationCache,\n  valueAccessorCache,\n} from \"./syntax\";\nimport type { AnyRenderPlan } from \"./types\";\n\nexport type TemplateRoot = HTMLElement | ShadowRoot;\nexport type TemplateContext = {\n  attr?: Record<string, string | null>;\n  state?: Record<string, unknown>;\n  data?: Record<string, unknown>;\n  item?: Record<string, unknown>;\n  index?: number;\n};\n\n/**\n * A renderable template from an HTMLTemplateElement\n *\n * Leverages a simple syntax to provide accessors to template data from one of\n * four categories, based on use case:\n *\n * | Prefix | Namespace                                        |\n * | ------ | ------------------------------------------------ |\n * | `@`    | The `attr` namespace (host element attributes)   |\n * | `$`    | The `state` namespace (component reactive state) |\n * | `*`    | The `data` namespace (component computed props)  |\n * | `#`    | The `item` namespace (list item context)         |\n *\n * Bind attributes to a value using the `:attribute` syntax:\n *\n * ```html\n * <div :id=\"$id\" :class=\"@classname\"></div>\n * ```\n *\n * Or use directives with notations for advanced templating:\n *\n * ```html\n * <div ::if=\"*showList\">\n *   <ul>\n *     <li ::each=\"$items\" ::key=\"#id\">\n *       <span ::swap=\"#content\"></span>\n *     </li>\n *   </ul>\n * </div>\n * ```\n */\nexport class Template {\n  static isTemplate(value: unknown): value is Template {\n    return (\n      value !== null && typeof value === \"object\" && value instanceof Template\n    );\n  }\n\n  /**\n   * Properties related to the global Template build cache.\n   *\n   * This is not something typically needed for general app development, but\n   * allows for advanced configuration to tune the caching system if need be.\n   *\n   * Cache sizes default to 500 HTML Template Fragments and compiled Palette\n   * templates (includes nested templates like lists) to cover most application\n   * needs without using much memory.\n   */\n  static cache = {\n    /**\n     * Wipe all cached templates and HTML fragments\n     */\n    clear: (): void => {\n      fragmentCache.clear();\n      compiledTemplateCache.clear();\n      valueAccessorCache.clear();\n      parsedNotationCache.clear();\n    },\n\n    /**\n     * the default cache capacity of 500 items per cache\n     *\n     * General caching guidance:\n     * - 95% of the time, 500 works fine\n     * - For very large applications, up to 1000 is reasonable\n     * - For smaller apps, dropping down to 100 - 250 may save memory\n     *\n     * Ultimately the impact will be minimal unless your app has very specific\n     * rendering needs.\n     */\n    setCapacity: (maxSize: number): void => {\n      fragmentCache.setCapacity(maxSize);\n      compiledTemplateCache.setCapacity(maxSize);\n      valueAccessorCache.setCapacity(maxSize);\n      parsedNotationCache.setCapacity(maxSize);\n    },\n  };\n\n  private _compiled: CompiledTemplate;\n\n  /**\n   * The original {@link HTMLTemplateElement} used to create this Template.\n   *\n   * @remarks\n   * Make sure to never operate directly on this element. Always clone.\n   */\n  private _templateElement?: HTMLTemplateElement;\n\n  /** The current known root element that this Template is rendered into */\n  private _mountedRoot?: TemplateRoot;\n\n  /** The most recent set value for each notation that has rendered */\n  private _latestRenderedValues: Map<string, unknown> = new Map();\n\n  /** The active HTMLElement which the template is updating on renders */\n  private _fragment: DocumentFragment;\n\n  /** Value Notations -> Set<Render Plans> */\n  private _plansByNotation: Map<string, Set<AnyRenderPlan>> = new Map();\n\n  /** Value Notations -> Accessor functions */\n  private _notationAccessors: Map<string, NotationAccessor> = new Map();\n\n  private _subtemplates: Set<Template> = new Set();\n\n  constructor(template: HTMLTemplateElement) {\n    this._templateElement = template;\n    this._compiled = compileTemplate(template);\n\n    // Prepare a fragment from the compiled HTML (cached)\n    const fragment = htmlToFragment(this._compiled.html);\n    const hydrated = prepareCompiledTemplate(this._compiled, fragment);\n\n    this._plansByNotation = hydrated.plansByNotation;\n    this._notationAccessors = hydrated.notationAccessors;\n    this._fragment = hydrated.fragment;\n    this._subtemplates = hydrated.subtemplates;\n\n    const allRelevantAccessors = new Map<string, NotationAccessor>(\n      this._notationAccessors,\n    );\n\n    for (const child of this._subtemplates) {\n      for (const [key, val] of child.notationMap) {\n        allRelevantAccessors.set(key, val);\n      }\n    }\n\n    this._notationAccessors = allRelevantAccessors;\n  }\n\n  get compiled(): CompiledTemplate {\n    return this._compiled;\n  }\n\n  get notationMap(): Map<string, NotationAccessor> {\n    return this._notationAccessors;\n  }\n\n  /**\n   * Create a full copy of this template for use in rendering to another root\n   */\n  clone = (): Template => {\n    return new Template(this.element());\n  };\n\n  /**\n   * @returns An {@link HTMLTemplateElement} representing this template\n   */\n  element = (): HTMLTemplateElement => {\n    if (this._templateElement) {\n      return this._templateElement;\n    }\n\n    const template = document.createElement(\"template\");\n    template.innerHTML = this._compiled.html;\n    return template;\n  };\n\n  private _collectUpdatedValues = (\n    context: TemplateContext,\n  ): [hasChanges: boolean, values: Map<string, unknown>] => {\n    const updatedValues = new Map<string, unknown>();\n    let hasChanges = false;\n\n    for (const [rawNotation, accessor] of this._notationAccessors) {\n      const previousValue = this._latestRenderedValues.get(rawNotation);\n      const newValue = accessor(context);\n      updatedValues.set(rawNotation, newValue);\n\n      if (previousValue !== newValue && !Object.is(previousValue, newValue)) {\n        hasChanges = true;\n      }\n    }\n\n    return [hasChanges, updatedValues];\n  };\n\n  private _update(newValues: Map<string, unknown>) {\n    // Collect affected plans\n    const allAffectedPlans: Set<AnyRenderPlan> = new Set();\n\n    for (const [notation] of newValues) {\n      const affectedPlans = this._plansByNotation.get(notation);\n\n      if (!affectedPlans) {\n        continue;\n      }\n\n      for (const plan of affectedPlans) {\n        allAffectedPlans.add(plan);\n      }\n    }\n\n    const jobs = createJobsFromPlans(allAffectedPlans, newValues);\n    executeRenderJobs(jobs);\n  }\n\n  renderWithValues = (\n    root: TemplateRoot,\n    values: Map<string, unknown>,\n  ): void => {\n    if (root !== this._mountedRoot) {\n      this._mountedRoot = root;\n      while (root.firstChild) {\n        root.removeChild(root.firstChild);\n      }\n\n      root.append(this._fragment);\n    }\n\n    this._update(values);\n  };\n\n  /**\n   * Render this template into a target host element.\n   */\n  render = (root: TemplateRoot, context: TemplateContext): void => {\n    const [hasChanges, resolvedValues] = this._collectUpdatedValues(context);\n\n    // If no values have changed, exit early\n    if (root === this._mountedRoot && !hasChanges) {\n      return;\n    }\n\n    this.renderWithValues(root, resolvedValues);\n    this._latestRenderedValues = resolvedValues;\n  };\n}\n",
    "type TaskQueue = \"tasks\" | \"frames\";\ntype TaskQueues = Record<TaskQueue, VoidFunction[]>;\ntype TaskPromises = Partial<Record<TaskQueue, Promise<void>>>;\ntype TaskResolvers = Partial<Record<TaskQueue, VoidFunction>>;\n\nexport class TaskScheduler {\n  private _queues: TaskQueues = {\n    tasks: [],\n    frames: [],\n  };\n  private _promises: TaskPromises = {};\n  private _resolvers: TaskResolvers = {};\n  private _onError?: (error: unknown) => void;\n\n  constructor(onError?: (error: unknown) => void) {\n    this._onError = onError;\n  }\n\n  private _flushQueue = (queueType: TaskQueue) => {\n    const queue = this._queues[queueType];\n    try {\n      while (queue.length) {\n        const task = queue.shift();\n        task?.();\n      }\n    } catch (error) {\n      if (this._onError) {\n        this._onError(error);\n      } else {\n        throw error;\n      }\n    } finally {\n      // Resolve the task promise\n      this._resolvers[queueType]?.();\n      this._resolvers[queueType] = undefined;\n      this._promises[queueType] = undefined;\n    }\n  };\n\n  private _schedule = (\n    type: TaskQueue,\n    task: VoidFunction,\n    prioritize = false,\n  ): Promise<void> => {\n    const queue = this._queues[type];\n    if (prioritize) {\n      queue.unshift(task);\n    } else {\n      queue.push(task);\n    }\n\n    if (!this._promises[type]) {\n      this._promises[type] = new Promise((resolve) => {\n        this._resolvers[type] = resolve;\n      });\n\n      if (type === \"frames\") {\n        requestAnimationFrame(this._flushQueue.bind(this, \"frames\"));\n      } else {\n        queueMicrotask(this._flushQueue.bind(this, \"tasks\"));\n      }\n    }\n\n    return this._promises[type];\n  };\n\n  scheduleMicrotask = (\n    task: VoidFunction,\n    prioritize = false,\n  ): Promise<void> => {\n    return this._schedule(\"tasks\", task, prioritize);\n  };\n\n  scheduleFrameTask = (\n    task: VoidFunction,\n    prioritize = false,\n  ): Promise<void> => {\n    return this._schedule(\"frames\", task, prioritize);\n  };\n}\n\nexport const asyncTasks = new TaskScheduler();\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { elementMatches } from \"#util\";\nimport { isElement, isNode, isShadowRoot } from \"../util/dom\";\n\nexport type EventName = keyof GlobalEventHandlersEventMap;\nexport type EventHandler<K extends EventName = EventName> = (\n  event: GlobalEventHandlersEventMap[K],\n) => void;\n\ntype EventHandlerMap = Map<string, EventHandler>;\n\n/**\n * Managed event delegation to coalesce event listeners for an entire tree into\n * single root-level listeners.\n *\n * @example\n * Listen for events from any child element of the delegated root\n *\n * ```typescript\n * const delegator = new EventDelegator($root);\n * delegator.addDelegatedListener(\"click\", handleClick);\n * ```\n *\n * @example\n * Listen for events from child elements matching `.action`\n *\n * ```typescript\n * const delegator = new EventDelegator($root);\n * delegator.addDelegatedListener(\"click\", handleClick, \".action\");\n * ```\n */\nexport class EventDelegator {\n  private _root: HTMLElement | ShadowRoot | Document;\n  private _rootListeners: EventHandlerMap = new Map();\n  private _events: Map<string, Map<string, Set<EventHandler>>> = new Map();\n\n  constructor(root: HTMLElement | ShadowRoot | Document = document) {\n    this._root = root;\n  }\n\n  private _handlersForEvent(event: string): Map<string, Set<EventHandler>> {\n    let handlerMap = this._events.get(event);\n\n    if (handlerMap === undefined) {\n      handlerMap = new Map();\n      this._events.set(event, handlerMap);\n    }\n\n    return handlerMap;\n  }\n\n  private _handlersForEventAndQuery<E extends EventName>(\n    event: E,\n    query: string,\n  ): Set<EventHandler<E>> {\n    const handlerMap = this._handlersForEvent(event);\n    let handlerSet = handlerMap.get(query);\n\n    if (handlerSet === undefined) {\n      handlerSet = new Set();\n      handlerMap.set(query, handlerSet);\n    }\n\n    return handlerSet;\n  }\n\n  private _createRootListener(eventName: string): void {\n    if (this._rootListeners.has(eventName)) {\n      return;\n    }\n\n    const listener = (event: Event) => {\n      const handlersForEvent = this._handlersForEvent(eventName);\n      const { target } = event;\n\n      if (target === null || !isNode(target)) {\n        return;\n      }\n\n      let node: Node | null = target;\n\n      let stopImmediateCalled = false;\n      const originalFn = event.stopImmediatePropagation;\n      event.stopImmediatePropagation = () => {\n        originalFn.call(event);\n        stopImmediateCalled = true;\n      };\n\n      while (node) {\n        if (node === this._root) {\n          break;\n        }\n\n        // Skip invalid elements\n        if (!isElement(node)) {\n          node = node.parentNode;\n          continue;\n        }\n\n        // Invoke handlers\n        for (const [query, handlers] of handlersForEvent) {\n          if (query === \"*\" || elementMatches(node, query)) {\n            for (const handler of handlers) {\n              handler.call(node, event);\n\n              // Respect .stopImmediatePropagation() and .preventDefault()\n              if (stopImmediateCalled || event.defaultPrevented) {\n                return;\n              }\n            }\n          }\n        }\n\n        // Respect .stopPropagation()\n        if (event.cancelBubble) {\n          return;\n        }\n\n        node = node.parentNode;\n\n        if (node === this._root || isShadowRoot(node)) {\n          break;\n        }\n      }\n    };\n\n    this._rootListeners.set(eventName, listener);\n    this._root.addEventListener(eventName, listener);\n  }\n\n  addListener<E extends EventName>(\n    eventName: E,\n    handler: EventHandler<E>,\n    queryFilter: string = \"*\",\n  ): void {\n    this._handlersForEventAndQuery(eventName, queryFilter).add(handler);\n    this._createRootListener(eventName);\n  }\n\n  removeListener(\n    eventName: EventName,\n    handler: EventHandler,\n    queryFilter: string,\n  ): void {\n    const handlerSet = this._handlersForEventAndQuery(eventName, queryFilter);\n    handlerSet.delete(handler);\n\n    // If that was the last handler for that event/query combo, delete the set\n    if (handlerSet.size === 0) {\n      const eventHandlerSets = this._handlersForEvent(eventName);\n      eventHandlerSets.delete(queryFilter);\n    }\n  }\n\n  cleanup = (): void => {\n    for (const [event, handler] of this._rootListeners) {\n      this._root.removeEventListener(event, handler);\n    }\n\n    this._rootListeners.clear();\n  };\n}\n",
    "/*\n * Copyright © Rustic Arcade, LLC 2026\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { ErrorCode, PaletteError } from \"#error\";\nimport { State } from \"#state\";\nimport { Template, type TemplateContext } from \"#template\";\nimport { getElementAttributes } from \"#util\";\nimport { asyncTasks } from \"../task-scheduler\";\nimport { walkParents } from \"../util/dom\";\nimport { EventDelegator, type EventHandler, type EventName } from \"./delegator\";\n\nconst MAX_SEQUENTIAL_RENDERS = 10000;\nconst BLANK_TEMPLATE = document.createElement(\"template\");\nconst HOST_TARGET = \":host\";\n\nexport enum RootMode {\n  Closed = \"closed\",\n  Open = \"open\",\n}\n\ntype Internals<StateShape extends object = {}> = {\n  isFinalized: boolean;\n  isInitialRenderComplete: boolean;\n  isRenderScheduled: boolean;\n  isRendering: boolean;\n  sequentialRenderCount: number;\n  lastRenderedAttributes: Record<string, string | null>;\n  pendingAttributeChanges: Record<string, string | null>;\n\n  state?: State<StateShape>;\n  delegator?: EventDelegator;\n  hostListeners?: Set<ComponentHostListener>;\n  cleanupFn?: VoidFunction;\n};\n\ntype ComponentHostListener = {\n  handler: EventHandler;\n  event: EventName;\n};\n\n/**\n * The **Component** class extends the base HTMLElement class to provide an\n * ergonomic way to design and develop Web Components with reactive state,\n * managed attributes, and dynamic templating.\n */\nexport abstract class Component<\n  StateShape extends object = {},\n> extends HTMLElement {\n  /**\n   * Check if a value is a Component instance\n   */\n  static isComponent(value: unknown): value is Component {\n    return (\n      typeof value === \"object\" && value !== null && value instanceof Component\n    );\n  }\n\n  /**\n   * Check if a value is a Component class\n   */\n  static isComponentClass(value: unknown): value is typeof Component {\n    return (\n      value !== null &&\n      typeof value === \"function\" &&\n      (value.prototype instanceof Component || value === Component)\n    );\n  }\n\n  static readComponentTagName(componentClass: typeof Component): string {\n    const { tagName } = componentClass;\n\n    if (__DEV__) {\n      if (tagName === \"\") {\n        console.warn(\n          `[Component] Empty tag name when reading from component ${componentClass.name}`,\n        );\n      }\n    }\n\n    return tagName;\n  }\n\n  /** The HTML tag name to use for this Component */\n  static tagName: string = \"\";\n\n  /** An HTML Template element for this element to use. */\n  static template: HTMLTemplateElement | Template = BLANK_TEMPLATE;\n\n  /** Styles to encapsulate to this component's root. */\n  static style: CSSStyleSheet | CSSStyleSheet[] | string = [];\n\n  /** Attributes to watch for changes for updates. */\n  static observedAttributes: string[] = [];\n\n  /**\n   * The mode for this Component's ShadowRoot.\n   *\n   * MDN: https://developer.mozilla.org/en-US/docs/Web/API/ShadowRoot/mode\n   */\n  static rootMode: RootMode = RootMode.Closed;\n\n  /**\n   * Initialization lifecycle method. Main scripting and event listeners.\n   * @returns a function to handle cleanup tasks when the component unmounts\n   */\n  public script?(): VoidFunction | void;\n\n  /** Called immediately before each template update */\n  public beforeUpdate?(changedAttributes: Record<string, string | null>): void;\n\n  /** Called immediately after each template update */\n  public afterUpdate?(previousAttributes: Record<string, string | null>): void;\n\n  /** Final lifecycle method called at the end of the unmounting process. */\n  public finalize?(): void;\n\n  /**\n   * Handle errors thrown during lifecycle methods of this component or any\n   * unhandled errors from child components.\n   */\n  public onError?(error: unknown): void;\n\n  /** The initial state for this Component */\n  public initialState?(): State<StateShape> | StateShape;\n\n  /**\n   * An object or function returning an object which populates the `data` values\n   * in the templating engine. Such values are accessed using the `*` notation.\n   */\n  public computedProperties?(\n    this: Component<StateShape>,\n    attributes: Record<string, string | null>,\n    state: StateShape,\n  ): Record<string, unknown>;\n\n  public readonly root: ShadowRoot;\n  public readonly template: Template;\n\n  private _cmp: Internals<StateShape> = {\n    isFinalized: false,\n    isInitialRenderComplete: false,\n    isRenderScheduled: false,\n    isRendering: false,\n    sequentialRenderCount: 0,\n    lastRenderedAttributes: {},\n    pendingAttributeChanges: {},\n  };\n\n  // ╭────────────────────────────────────────────────────────╮\n  // │             Internals and Private Methods              │\n  // ╰────────────────────────────────────────────────────────╯\n\n  constructor() {\n    super();\n\n    const {\n      template,\n      style,\n      rootMode: mode,\n    } = this.constructor as typeof Component;\n\n    // Create the element's shadow dom\n    this.root = this.attachShadow({ mode });\n\n    // Coerce and adopt styles\n    let adoptStyles: CSSStyleSheet[] = [];\n\n    if (Array.isArray(style)) {\n      adoptStyles = style;\n    } else if (style instanceof CSSStyleSheet) {\n      adoptStyles = [style];\n    } else {\n      const adoptSheet = new CSSStyleSheet();\n      adoptSheet.replaceSync(style);\n      adoptStyles = [adoptSheet];\n    }\n\n    this.root.adoptedStyleSheets.push(...adoptStyles);\n\n    // Adopt template\n    this.template = Template.isTemplate(template)\n      ? template\n      : new Template(template);\n  }\n\n  /** Produce the data object to pass to the template's render function */\n  private _getRenderContext(\n    attr: Record<string, string | null>,\n  ): TemplateContext {\n    const state = (this._cmp.state?.raw ?? {}) as StateShape;\n    const computed = this.computedProperties?.call(this, attr, state);\n\n    return {\n      attr: attr,\n      data: computed,\n      state: state as Record<string, unknown>,\n    };\n  }\n\n  private _escalateError(error: unknown): void {\n    const isErrorHandled = walkParents(this, (node: Node) => {\n      if (node instanceof Component && node.onError) {\n        node.onError(error);\n        return true;\n      }\n    });\n\n    if (!isErrorHandled) {\n      throw error;\n    }\n  }\n\n  private _reportError(error: unknown): void {\n    this.onError ? this.onError(error) : this._escalateError(error);\n  }\n\n  /** The actual update behavior */\n  private _render = (): void => {\n    try {\n      // Immediately flip flags to denote a render is in progress and allow\n      // queueing another render request.\n      this._cmp.isRendering = true;\n      this._cmp.isRenderScheduled = false;\n\n      // Cache the attributes from the previous render\n      const prevAttrs = this._cmp.lastRenderedAttributes;\n\n      this.beforeUpdate?.(this._cmp.pendingAttributeChanges);\n\n      // Update the current snapshot of attributes\n      const newAttributes = getElementAttributes(this);\n      this.template.render(this.root, this._getRenderContext(newAttributes));\n      this._cmp.lastRenderedAttributes = newAttributes;\n\n      this.afterUpdate?.(prevAttrs);\n\n      // If the `willRender` flag was flipped, immediately perform a render\n      if (this._cmp.isRenderScheduled) {\n        this._cmp.sequentialRenderCount += 1;\n\n        if (this._cmp.sequentialRenderCount >= MAX_SEQUENTIAL_RENDERS) {\n          throw new PaletteError(\n            ErrorCode.MAX_SEQUENTIAL_RENDERS,\n            `${this._cmp.sequentialRenderCount}`,\n          );\n        }\n\n        this._render();\n      } else {\n        this._cmp.sequentialRenderCount = 0;\n      }\n    } catch (error) {\n      this._cmp.isRenderScheduled = false;\n      this._reportError(error);\n    } finally {\n      this._cmp.isRendering = false;\n    }\n  };\n\n  private _adoptState(state: StateShape | State<StateShape>) {\n    // If this is exactly our own state object, do nothing\n    if (Object.is(this._cmp.state, state)) {\n      return;\n    }\n\n    // If state exists, remove the listener and schedule a render\n    if (this._cmp.state) {\n      this._cmp.state.removeListener(this.render);\n      this.render();\n    }\n\n    // Adopt the incoming state obj or wrap and adopt it\n    const incomingStateObj = State.isState<StateShape>(state)\n      ? state\n      : new State(state);\n    this._cmp.state = incomingStateObj;\n\n    // Ensure there is not accidentally two of the same render listeners\n    this._cmp.state.removeListener(this.render);\n    this._cmp.state.addListener(this.render);\n  }\n\n  // ╭────────────────────────────────────────────────────────╮\n  // │           Custom Element Callback Overrides            │\n  // ╰────────────────────────────────────────────────────────╯\n\n  /**\n   * @deprecated Use {@link script} instead\n   */\n  protected connectedCallback(): void {\n    if (this._cmp.isInitialRenderComplete) {\n      return;\n    }\n\n    asyncTasks.scheduleMicrotask(() => {\n      try {\n        this._cmp.isRendering = true;\n        this._cmp.isRenderScheduled = false;\n\n        const attributes = getElementAttributes(this);\n\n        // If this is a stateful component, set up that state\n        if (this.initialState) {\n          this._adoptState(this.initialState());\n        }\n\n        this.template.render(this.root, this._getRenderContext(attributes));\n\n        this._cmp.lastRenderedAttributes = attributes;\n        this._cmp.isInitialRenderComplete = true;\n        this._cmp.cleanupFn = this.script?.() ?? undefined;\n      } catch (error) {\n        this._reportError(error);\n      } finally {\n        this._cmp.isRendering = false;\n      }\n    });\n  }\n\n  /**\n   * @deprecated use {@link finalize}\n   */\n  protected disconnectedCallback(): void {\n    if (this._cmp.isFinalized) {\n      return;\n    }\n\n    asyncTasks.scheduleMicrotask(() => {\n      // If this task runs but the component is still connected, then do nothing\n      // because the component was just moved in the DOM.\n      if (this.isConnected || !this._cmp.isInitialRenderComplete) {\n        return;\n      }\n\n      this._cmp.isFinalized = true;\n\n      // Only run the disconnect if the element is actually unmounted and not\n      // just moved. Using this in place of connectedMoveCallback() for compat\n      try {\n        const { delegator, cleanupFn, hostListeners } = this._cmp;\n        delegator?.cleanup();\n\n        // Clear any listeners set up on self\n        if (hostListeners && hostListeners.size > 0) {\n          for (const listener of hostListeners) {\n            this.removeEventListener(listener.event, listener.handler);\n          }\n        }\n\n        cleanupFn?.();\n      } catch (error) {\n        this._reportError(error);\n      } finally {\n        // Run the finalize call after everything, even if the cleanup fn failed\n        try {\n          this.finalize?.();\n        } catch (error) {\n          this._reportError(error);\n        }\n      }\n    });\n  }\n\n  /**\n   * @deprecated Use {@link beforeUpdate} and {@link afterUpdate} instead\n   */\n  protected attributeChangedCallback(\n    name: string,\n    _: string | null,\n    newValue: string | null,\n  ): void {\n    // Ignore attribute changes that occur during an update, as they are\n    // coming from inside the house\n    if (this._cmp.isRendering) {\n      return;\n    }\n\n    // Cache the updated attribute value\n    this._cmp.pendingAttributeChanges[name] = newValue;\n\n    // Schedule a render\n    if (!this._cmp.isRenderScheduled) {\n      this.render();\n    }\n  }\n\n  // ╭────────────────────────────────────────────────────────╮\n  // │                    Public Interface                    │\n  // ╰────────────────────────────────────────────────────────╯\n\n  get isMounted(): boolean {\n    return this.isConnected && this._cmp.isInitialRenderComplete;\n  }\n\n  /**\n   * Access the full {@link State} instance for this Component.\n   *\n   * @remarks\n   * Calling this method on a component which is not using reactive state\n   * will result in an error being thrown.\n   */\n  getState(): State<StateShape> {\n    if (!this._cmp.state) {\n      throw new PaletteError(ErrorCode.MISSING_STATE);\n    }\n\n    return this._cmp.state;\n  }\n\n  /**\n   * Accessor for live reactive state.\n   *\n   * For the full state manipulation API, use {@link getState}\n   */\n  get state(): StateShape {\n    return this.getState().live;\n  }\n\n  /**\n   * Replace the current state with a new value or adopt a whole different State\n   * instance\n   */\n  set state(newState: StateShape | State<StateShape>) {\n    this._adoptState(newState);\n  }\n\n  /**\n   * Manually schedule a render to occur, optionally providing a callback to\n   * invoke after the render completes.\n   *\n   * @remarks\n   * Calling {@link render} multiple times in the same event loop won't\n   * schedule multiple renders. Renders are scheduled to occur on the next\n   * animation frame.\n   */\n  render = (): void => {\n    // Prevent scheduling multiple renders\n    if (this._cmp.isRenderScheduled) {\n      return;\n    }\n\n    this._cmp.isRenderScheduled = true;\n\n    // If currently rendering, don't request a render, it will auto-continue\n    // until there are no changes to render\n    if (this._cmp.isRendering) {\n      return;\n    }\n\n    // If a render is requested and we're not rendering, request a render frame\n    asyncTasks.scheduleFrameTask(this._render);\n  };\n\n  /**\n   * Listen for events on a child element based on the provided query\n   *\n   * @returns A function which removes the listener when called\n   *\n   * @remarks\n   * Event listeners created with this method are automatically cleaned up when\n   * the component unmounts. You can manually remove the listener during the\n   * component's lifecycle by calling the returned function if need be.\n   */\n  listen<E extends EventName>(\n    target: string,\n    eventName: E,\n    eventHandler: EventHandler<E>,\n  ): VoidFunction;\n\n  /**\n   * Listen for events on a child element based on the provided component's tag\n   *\n   * @returns A function which removes the listener when called\n   *\n   * @remarks\n   * Event listeners created with this method are automatically cleaned up when\n   * the component unmounts. You can manually remove the listener during the\n   * component's lifecycle by calling the returned function if need be.\n   */\n  listen<E extends EventName>(\n    target: typeof Component<any>,\n    eventName: E,\n    eventHandler: EventHandler<E>,\n  ): VoidFunction;\n\n  /**\n   * Listen for events on the host element\n   *\n   * @returns A function which removes the listener when called\n   *\n   * @remarks\n   * Event listeners created with this method are automatically cleaned up when\n   * the component unmounts. You can manually remove the listener during the\n   * component's lifecycle by calling the returned function if need be.\n   */\n  listen<E extends EventName>(\n    target: typeof this,\n    eventName: E,\n    eventHandler: EventHandler<E>,\n  ): VoidFunction;\n\n  /**\n   * Listen for events on the host element\n   *\n   * @returns A function which removes the listener when called\n   *\n   * @remarks\n   * Event listeners created with this method are automatically cleaned up when\n   * the component unmounts. You can manually remove the listener during the\n   * component's lifecycle by calling the returned function if need be.\n   */\n  listen<E extends EventName>(\n    target: \":host\",\n    eventName: E,\n    eventHandler: EventHandler<E>,\n  ): VoidFunction;\n\n  listen<E extends EventName>(\n    targetDescriptor: string | typeof Component<any> | typeof this,\n    eventName: E,\n    eventHandler: EventHandler<E>,\n  ): VoidFunction {\n    // Host element events\n    if (targetDescriptor === HOST_TARGET || targetDescriptor === this) {\n      if (!this._cmp.hostListeners) {\n        this._cmp.hostListeners = new Set();\n      }\n\n      const hostListeners = this._cmp.hostListeners;\n\n      const entry: ComponentHostListener = {\n        event: eventName,\n        handler: eventHandler as EventHandler,\n      };\n\n      hostListeners.add(entry);\n      this.addEventListener(eventName, eventHandler);\n\n      return () => {\n        this.removeEventListener(eventName, eventHandler);\n        hostListeners.delete(entry);\n      };\n    }\n\n    // Other objects as a descriptor indicate an error\n    if (typeof targetDescriptor === \"object\") {\n      throw new PaletteError(ErrorCode.INVALID_CALLSITE);\n    }\n\n    // Child element events\n    if (!this._cmp.delegator) {\n      this._cmp.delegator = new EventDelegator(this.root);\n    }\n\n    const delegator = this._cmp.delegator;\n\n    const query =\n      typeof targetDescriptor === \"string\"\n        ? targetDescriptor\n        : Component.readComponentTagName(targetDescriptor);\n\n    delegator.addListener(eventName, eventHandler, query);\n\n    return () => {\n      delegator.removeListener(eventName, eventHandler as EventHandler, query);\n    };\n  }\n\n  /**\n   * Publish a {@link CustomEvent} with the provided name and options.\n   *\n   * Default options are:\n   *\n   * ```typescript\n   * {\n   *   bubbles: true,\n   *   cancelable: true,\n   *   composed: true,\n   *   detail: undefined,\n   * }\n   * ```\n   *\n   * @param name The name of the custom event to publish\n   * @param options Options to configure the custom event\n   */\n  dispatchEvent<T>(name: string, options: CustomEventInit<T>): boolean;\n  dispatchEvent(event: Event): boolean;\n  dispatchEvent<T>(a: Event | string, b?: CustomEventInit<T>): boolean {\n    if (typeof a === \"object\" && typeof b === \"undefined\") {\n      return super.dispatchEvent(a);\n    } else if (typeof a === \"string\") {\n      return super.dispatchEvent(\n        new CustomEvent(a, {\n          bubbles: true,\n          cancelable: true,\n          composed: true,\n          ...b,\n        }),\n      );\n    } else {\n      throw new PaletteError(ErrorCode.INVALID_CALLSITE);\n    }\n  }\n\n  /**\n   * Returns a reference to the HTML Element with the provided ID within the\n   * shadow root of this component.\n   *\n   * Throws an error if no element with the provided ID is found\n   */\n  ref<E extends HTMLElement>(id: string): E {\n    const lookup = this.root.getElementById(id);\n    if (!lookup) {\n      throw new PaletteError(ErrorCode.MISSING_ELEMENT);\n    }\n    return lookup as E;\n  }\n\n  /**\n   * Serialize this element to a string\n   */\n  toString(): string {\n    const { tagName, name } = this.constructor as typeof Component;\n    const computedName = tagName === \"\" ? name : tagName;\n    const attrString = this.getAttributeNames()\n      .map((attrName) => {\n        const val = this.getAttribute(attrName);\n        return val ? `${attrName}=\"${val}\"` : \"\";\n      })\n      .join(\" \");\n    const attrs = attrString.length > 0 ? ` ${attrString}` : \"\";\n    return `<${computedName}${attrs}></${computedName}>`;\n  }\n}\n",
    "/*\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n\nimport { ErrorCode, PaletteError } from \"#error\";\nimport type { State } from \"#state\";\nimport { Component, RootMode } from \"./component\";\n\nconst BLANK_TEMPLATE = document.createElement(\"template\");\n\nexport interface ComponentShorthand<StateShape extends object = {}> {\n  /** An HTML Template element for this element to use. */\n  template?: HTMLTemplateElement;\n\n  /** Styles to encapsulate to this component's root. */\n  style?: CSSStyleSheet | CSSStyleSheet[] | string;\n\n  /**\n   * The mode for this Component's ShadowRoot.\n   *\n   * MDN: https://developer.mozilla.org/en-US/docs/Web/API/ShadowRoot/mode\n   */\n  rootMode?: RootMode;\n\n  /** Attributes to watch for changes for updates. */\n  observedAttributes?: string[];\n\n  /** The initial state for this Component */\n  initialState?:\n    | State<StateShape>\n    | StateShape\n    | (() => State<StateShape>)\n    | (() => StateShape);\n\n  /**\n   * An object or function returning an object which populates the `data` values\n   * in the templating engine. Such values are accessed using the `*` notation.\n   */\n  computedProperties?(\n    this: Component<StateShape>,\n    attributes?: Record<string, string | null>,\n    state?: StateShape,\n  ): Record<string, unknown>;\n\n  /** Initialization scripting for this Component */\n  script?: (this: Component<StateShape>) => VoidFunction | void;\n\n  /** Called immediately before each template update */\n  beforeUpdate?: (\n    this: Component<StateShape>,\n    changedAttributes?: Record<string, string | null>,\n  ) => void;\n\n  /** Called immediately after each template update */\n  afterUpdate?: (\n    this: Component<StateShape>,\n    previousAttributes?: Record<string, string | null>,\n  ) => void;\n\n  /**\n   * Called as the final lifecycle method at the end of the unmounting process.\n   */\n  finalize?: (this: Component<StateShape>) => void;\n\n  /**\n   * If defined, receives errors caught during the lifecycle methods of this\n   * component and it's children. If not defined, this component will instead\n   * throw errors as they are found.\n   */\n  onError?: (this: Component<StateShape>, error: unknown) => void;\n}\n\nfunction defineFromClass<StateShape extends object = {}>(\n  cls: typeof Component<StateShape>,\n  tagName?: string,\n) {\n  // Set the tagName static if its not already set\n  if (tagName && cls.tagName === \"\") {\n    cls.tagName = tagName;\n  }\n\n  if (__DEV__) {\n    if (tagName && tagName !== cls.tagName) {\n      console.warn(\n        `[COMPONENT] Component ${cls.name} was defined with tagname ${tagName} ` +\n          `which does not match its static tagName property`,\n      );\n    }\n  }\n\n  window.customElements.define(\n    cls.tagName,\n    cls as unknown as CustomElementConstructor,\n  );\n}\n\n/**\n * Define a Palette Component using the shorthand syntax\n *\n * @example\n *\n * ```typescript\n * define(\"my-component\", {\n *   template: html`...`,\n *   style: css`...`,\n *   initialState: { ... },\n *   computedProperties() { ... },\n *   script() { ... },\n *   // and any other lifecycle methods\n * });\n * ```\n */\nexport function define<StateShape extends object = {}>(\n  tagName: string,\n  definition: ComponentShorthand<StateShape>,\n): typeof Component<StateShape>;\n\n/**\n * Register a Palette Component as a custom element\n */\nexport function define<Cls extends typeof Component<any>>(definition: Cls): Cls;\n\n/**\n * Register a Palette Component as a custom element\n */\nexport function define<Cls extends typeof Component<any>>(\n  tagName: string,\n  definition: Cls,\n): Cls;\n\nexport function define<StateShape extends object = {}>(\n  a: string | typeof Component<StateShape>,\n  b?: ComponentShorthand<StateShape> | typeof Component<StateShape>,\n): typeof Component<StateShape> {\n  // Handle component class paths\n  if (typeof a === \"function\") {\n    defineFromClass(a);\n    return a;\n  }\n\n  if (typeof a === \"string\" && typeof b === \"function\") {\n    defineFromClass(b, a);\n    return b;\n  }\n\n  if (b === undefined) {\n    throw new PaletteError(ErrorCode.INVALID_CALLSITE);\n  }\n\n  // Handle shorthand\n  const tagName = a;\n  const definition = b;\n\n  // Component constructors are functions -> Define them with their tagname if present\n  if (typeof definition === \"function\") {\n    // Set the tagName static if its not already set\n    if (definition.tagName === \"\") {\n      definition.tagName = tagName;\n    }\n\n    if (__DEV__) {\n      if (tagName !== definition.tagName) {\n        console.warn(\n          `[COMPONENT] Component ${definition.name} was defined with tagname ${tagName} ` +\n            `which does not match its static tagName property`,\n        );\n      }\n    }\n\n    window.customElements.define(\n      tagName,\n      definition as unknown as CustomElementConstructor,\n    );\n    return definition;\n  }\n\n  const {\n    // Config\n    template = BLANK_TEMPLATE,\n    style = [],\n    rootMode = RootMode.Closed,\n    initialState: stateInitializer,\n    computedProperties,\n    observedAttributes = [],\n\n    // Lifecycle\n    script,\n    beforeUpdate,\n    afterUpdate,\n    finalize,\n    onError,\n  } = definition;\n\n  let getInitialState: (() => State<StateShape> | StateShape) | undefined;\n\n  if (stateInitializer) {\n    getInitialState =\n      typeof stateInitializer === \"function\"\n        ? stateInitializer\n        : () => stateInitializer;\n  }\n\n  const cls = class extends Component<StateShape> {\n    static tagName = tagName;\n    static template = template;\n    static style = style;\n    static observedAttributes = [...observedAttributes];\n    static shadowRootMode = rootMode;\n  };\n\n  cls.prototype.initialState = getInitialState;\n  cls.prototype.computedProperties = computedProperties;\n\n  cls.prototype.script = script;\n  cls.prototype.beforeUpdate = beforeUpdate;\n  cls.prototype.afterUpdate = afterUpdate;\n  cls.prototype.finalize = finalize;\n  cls.prototype.onError = onError;\n\n  customElements.define(tagName, cls);\n  return cls;\n}\n",
    "import { fragmentCache } from \"#util\";\nimport { compiledTemplateCache } from \"./template/compile\";\nimport { parsedNotationCache, valueAccessorCache } from \"./template/syntax\";\n\nif (__DEV__ && typeof window !== \"undefined\") {\n  (window as any).__PALETTE_DEVTOOLS__ = {\n    dumpCacheMetrics: () => {\n      console.log(\"Compiled Templates\", compiledTemplateCache.getMetrics());\n      console.log(\"HTML Fragments\", fragmentCache.getMetrics());\n      console.log(\"Notation Accessor\", valueAccessorCache.getMetrics());\n      console.log(\"Parsed Notations\", parsedNotationCache.getMetrics());\n    },\n  };\n}\n"
  ],
  "mappings": "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",
  "debugId": "D9A90808356EA17464756E2164756E21",
  "names": []
}