@dooboostore/simple-web-component 1.0.0 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (100) hide show
  1. package/README.md +70 -78
  2. package/dist/cjs/decorators/addEventListener.js +42 -0
  3. package/dist/cjs/decorators/addEventListener.js.map +7 -0
  4. package/dist/cjs/decorators/attributeChanged.js +24 -4
  5. package/dist/cjs/decorators/attributeChanged.js.map +2 -2
  6. package/dist/cjs/decorators/{element.js → elementDefind.js} +91 -13
  7. package/dist/cjs/decorators/elementDefind.js.map +7 -0
  8. package/dist/cjs/decorators/query.js +53 -0
  9. package/dist/cjs/decorators/query.js.map +7 -0
  10. package/dist/cjs/decorators/queryAll.js +53 -0
  11. package/dist/cjs/decorators/queryAll.js.map +7 -0
  12. package/dist/cjs/elements/SwcChoose.js +117 -0
  13. package/dist/cjs/elements/SwcChoose.js.map +7 -0
  14. package/dist/cjs/elements/SwcForOf.js +126 -0
  15. package/dist/cjs/elements/SwcForOf.js.map +7 -0
  16. package/dist/cjs/elements/SwcHTMLElementBase.js +102 -0
  17. package/dist/cjs/elements/SwcHTMLElementBase.js.map +7 -0
  18. package/dist/cjs/elements/SwcIf.js +127 -0
  19. package/dist/cjs/elements/SwcIf.js.map +7 -0
  20. package/dist/cjs/elements/SwcObject.js +115 -0
  21. package/dist/cjs/elements/SwcObject.js.map +7 -0
  22. package/dist/cjs/elements/SwcOther.js +56 -0
  23. package/dist/cjs/elements/SwcOther.js.map +7 -0
  24. package/dist/cjs/elements/SwcWhen.js +56 -0
  25. package/dist/cjs/elements/SwcWhen.js.map +7 -0
  26. package/dist/cjs/index.js +11 -1
  27. package/dist/cjs/index.js.map +2 -2
  28. package/dist/esm/decorators/addEventListener.js +23 -0
  29. package/dist/esm/decorators/addEventListener.js.map +7 -0
  30. package/dist/esm/decorators/attributeChanged.js +24 -4
  31. package/dist/esm/decorators/attributeChanged.js.map +2 -2
  32. package/dist/esm/decorators/{element.js → elementDefind.js} +89 -11
  33. package/dist/esm/decorators/elementDefind.js.map +7 -0
  34. package/dist/esm/decorators/query.js +34 -0
  35. package/dist/esm/decorators/query.js.map +7 -0
  36. package/dist/esm/decorators/queryAll.js +34 -0
  37. package/dist/esm/decorators/queryAll.js.map +7 -0
  38. package/dist/esm/elements/SwcChoose.js +98 -0
  39. package/dist/esm/elements/SwcChoose.js.map +7 -0
  40. package/dist/esm/elements/SwcForOf.js +107 -0
  41. package/dist/esm/elements/SwcForOf.js.map +7 -0
  42. package/dist/esm/elements/SwcHTMLElementBase.js +83 -0
  43. package/dist/esm/elements/SwcHTMLElementBase.js.map +7 -0
  44. package/dist/esm/elements/SwcIf.js +108 -0
  45. package/dist/esm/elements/SwcIf.js.map +7 -0
  46. package/dist/esm/elements/SwcObject.js +96 -0
  47. package/dist/esm/elements/SwcObject.js.map +7 -0
  48. package/dist/esm/elements/SwcOther.js +37 -0
  49. package/dist/esm/elements/SwcOther.js.map +7 -0
  50. package/dist/esm/elements/SwcWhen.js +37 -0
  51. package/dist/esm/elements/SwcWhen.js.map +7 -0
  52. package/dist/esm/index.js +11 -1
  53. package/dist/esm/index.js.map +2 -2
  54. package/dist/esm-bundle/dooboostore-simple-web-component.esm.js +744 -14
  55. package/dist/esm-bundle/dooboostore-simple-web-component.esm.js.map +4 -4
  56. package/dist/types/decorators/addEventListener.d.ts +16 -0
  57. package/dist/types/decorators/addEventListener.d.ts.map +1 -0
  58. package/dist/types/decorators/attributeChanged.d.ts +3 -1
  59. package/dist/types/decorators/attributeChanged.d.ts.map +1 -1
  60. package/dist/types/decorators/{element.d.ts → elementDefind.d.ts} +2 -2
  61. package/dist/types/decorators/elementDefind.d.ts.map +1 -0
  62. package/dist/types/decorators/query.d.ts +13 -0
  63. package/dist/types/decorators/query.d.ts.map +1 -0
  64. package/dist/types/decorators/queryAll.d.ts +13 -0
  65. package/dist/types/decorators/queryAll.d.ts.map +1 -0
  66. package/dist/types/elements/SwcChoose.d.ts +12 -0
  67. package/dist/types/elements/SwcChoose.d.ts.map +1 -0
  68. package/dist/types/elements/SwcForOf.d.ts +14 -0
  69. package/dist/types/elements/SwcForOf.d.ts.map +1 -0
  70. package/dist/types/elements/SwcHTMLElementBase.d.ts +14 -0
  71. package/dist/types/elements/SwcHTMLElementBase.d.ts.map +1 -0
  72. package/dist/types/elements/SwcIf.d.ts +14 -0
  73. package/dist/types/elements/SwcIf.d.ts.map +1 -0
  74. package/dist/types/elements/SwcObject.d.ts +14 -0
  75. package/dist/types/elements/SwcObject.d.ts.map +1 -0
  76. package/dist/types/elements/SwcOther.d.ts +5 -0
  77. package/dist/types/elements/SwcOther.d.ts.map +1 -0
  78. package/dist/types/elements/SwcWhen.d.ts +5 -0
  79. package/dist/types/elements/SwcWhen.d.ts.map +1 -0
  80. package/dist/types/index.d.ts +11 -1
  81. package/dist/types/index.d.ts.map +1 -1
  82. package/dist/umd-bundle/dooboostore-simple-web-component.umd.js +744 -14
  83. package/dist/umd-bundle/dooboostore-simple-web-component.umd.js.map +4 -4
  84. package/package.json +1 -1
  85. package/src/decorators/addEventListener.ts +35 -0
  86. package/src/decorators/attributeChanged.ts +29 -6
  87. package/src/decorators/{element.ts → elementDefind.ts} +121 -11
  88. package/src/decorators/query.ts +46 -0
  89. package/src/decorators/queryAll.ts +46 -0
  90. package/src/elements/SwcChoose.ts +83 -0
  91. package/src/elements/SwcForOf.ts +95 -0
  92. package/src/elements/SwcHTMLElementBase.ts +93 -0
  93. package/src/elements/SwcIf.ts +92 -0
  94. package/src/elements/SwcObject.ts +78 -0
  95. package/src/elements/SwcOther.ts +14 -0
  96. package/src/elements/SwcWhen.ts +14 -0
  97. package/src/index.ts +12 -2
  98. package/dist/cjs/decorators/element.js.map +0 -7
  99. package/dist/esm/decorators/element.js.map +0 -7
  100. package/dist/types/decorators/element.d.ts.map +0 -1
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../src/bundle-entry.ts", "../../../core/src/reflect/ReflectUtils.ts", "../../src/decorators/attributeChanged.ts", "../../src/decorators/template.ts", "../../src/decorators/style.ts", "../../src/decorators/element.ts"],
4
- "sourcesContent": ["export * from './index';\n", "import { ConstructorType } from '../types';\nexport namespace ReflectUtils {\n export const getParameterTypes = (target: any, propertyKey?: string | symbol): ConstructorType<any>[] => {\n // console.log('---------param')\n if (propertyKey) {\n return Reflect.getMetadata('design:paramtypes', target, propertyKey) || [];\n } else {\n return Reflect.getMetadata('design:paramtypes', target) || [];\n }\n }\n\n\n export const getReturnType = (target: any, propertyKey: string | symbol): any => {\n return Reflect.getMetadata('design:returntype', target, propertyKey);\n }\n\n // @Reflect.metadata(\"design:type\", Point)\n export const getType = (target: any, propertyKey?: string | symbol): any => {\n if (propertyKey) {\n return Reflect.getMetadata('design:type', target, propertyKey);\n } else {\n return Reflect.getMetadata('design:type', target);\n }\n }\n\n export const getMetadata = <T = any>(metadataKey: any, target: any, propertyKey?: string | symbol): T | undefined => {\n if (propertyKey) {\n return Reflect.getMetadata(metadataKey, target, propertyKey);\n } else {\n return Reflect.getMetadata(metadataKey, target);\n }\n\n\n //\n // let tt = target;\n // // proxy \uAC78\uB9B0\uAC70\uB294 \uC624\uB9AC\uC9C0\uB110 constructor\uC5D0 \uB4E4\uC5B4\uAC00\uC788\uC744\uACBD\uC6B0\uB3C4\uC788\uC5B4\uC11C reflect\uAC00 proxy\uC758 constructor\uC5D0\uC11C \uCC3E\uB294\uACBD\uC6B0\uB3C4\uC788\uB2E4,\n // // \uC11C\uBC84\uB791 \uD504\uB860\uD2B8\uB791 \uB2E4\uB978\uB4EF.. \uADF8\uB798\uC11C \uC704\uB85C \uCC3E\uC544\uAC00\uBA74\uC11C\n // while (tt) {\n // let meta: any = undefined;\n // if (propertyKey) {\n // meta = Reflect.getMetadata(metadataKey, tt, propertyKey);\n // } else {\n // meta = Reflect.getMetadata(metadataKey, tt);\n // }\n // if (meta) {\n // return meta;\n // }\n // tt = Reflect.getPrototypeOf(tt);\n // }\n }\n\n export const getMetadataKeys = (target: any) => {\n return Reflect.getMetadataKeys(target);\n }\n\n export const getOwnMetadata = (metadataKey: any, target: any, propertyKey?: string): number[] | any => {\n if (propertyKey) {\n return Reflect.getOwnMetadata(metadataKey, target, propertyKey);\n } else {\n return Reflect.getOwnMetadata(metadataKey, target);\n }\n }\n\n export const getMetadatas = (target: any) => {\n return ReflectUtils.getMetadataKeys(target).map(it => ReflectUtils.getMetadata(it, target));\n }\n\n export const metadata = (metadataKey: any, data: any) => {\n return Reflect.metadata(metadataKey, data);\n }\n\n export const defineMetadata = (metadataKey: any, value: any, target: any, propertyKey?: string | symbol) => {\n // console.log(\"Reflect:\",Reflect)\n if (propertyKey && Reflect.defineMetadata) {\n Reflect.defineMetadata(metadataKey, value, target, propertyKey);\n } else if (Reflect.defineMetadata) {\n Reflect.defineMetadata(metadataKey, value, target);\n // Reflect.defineMetadata(\"design:paramtypes\", value, target);\n }\n // console.log(\"Reflect:\",Reflect.getMetadata(metadataKey, target))\n // console.log(\"Reflect:\",Reflect.getMetadata('design:paramtypes', target))\n }\n}\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport const ATTRIBUTE_CHANGED_METADATA_KEY = Symbol('simple-web-component:attribute-changed');\n\nexport const attributeChanged = (attributeName: string): MethodDecorator => {\n return (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {\n const constructor = target.constructor;\n let meta = ReflectUtils.getMetadata<Map<string, string | symbol>>(ATTRIBUTE_CHANGED_METADATA_KEY, constructor);\n if (!meta) {\n meta = new Map<string, string | symbol>();\n ReflectUtils.defineMetadata(ATTRIBUTE_CHANGED_METADATA_KEY, meta, constructor);\n }\n meta.set(attributeName, propertyKey);\n };\n};\n\nexport const getAttributeChangedMap = (target: any): Map<string, string | symbol> | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(ATTRIBUTE_CHANGED_METADATA_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport const TEMPLATE_METHOD_KEY = Symbol('simple-web-component:template-method');\n\nexport const template: MethodDecorator = (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {\n // console.log('setTemplateMethod target.constructor', target.constructor)\n ReflectUtils.defineMetadata(TEMPLATE_METHOD_KEY, propertyKey, target.constructor);\n};\n\nexport const getTemplateMethod = (target: any): string | symbol | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n // console.log('getTemplateMethod constructor', constructor)\n return ReflectUtils.getMetadata(TEMPLATE_METHOD_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport const STYLE_METHOD_KEY = Symbol('simple-web-component:style-method');\n\nexport const style: MethodDecorator = (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {\n ReflectUtils.defineMetadata(STYLE_METHOD_KEY, propertyKey, target.constructor);\n};\n\nexport const getStyleMethod = (target: any): string | symbol | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(STYLE_METHOD_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\nimport { getAttributeChangedMap } from './attributeChanged';\nimport { getTemplateMethod } from './template';\nimport { getStyleMethod } from './style';\n\nexport interface ElementConfig {\n tagName: string;\n useShadow?: boolean;\n extends?: string;\n observedAttributes?: string[];\n customElementRegistry?: CustomElementRegistry;\n}\n\nexport const ELEMENT_CONFIG_KEY = Symbol('simple-web-component:element-config');\n\nconst BUILT_IN_TAG_MAP = new Map<any, string>();\n\nconst registerTag = (className: string, tagName: string) => {\n if (typeof globalThis !== 'undefined' && (globalThis as any)[className]) {\n BUILT_IN_TAG_MAP.set((globalThis as any)[className], tagName);\n }\n};\n\n// Register comprehensive list of supported tags for automatic extends inference\n[\n ['HTMLAnchorElement', 'a'],\n ['HTMLAreaElement', 'area'],\n ['HTMLAudioElement', 'audio'],\n ['HTMLBaseElement', 'base'],\n ['HTMLButtonElement', 'button'],\n ['HTMLCanvasElement', 'canvas'],\n ['HTMLDataElement', 'data'],\n ['HTMLDataListElement', 'datalist'],\n ['HTMLDetailsElement', 'details'],\n ['HTMLDialogElement', 'dialog'],\n ['HTMLDivElement', 'div'],\n ['HTMLDListElement', 'dl'],\n ['HTMLEmbedElement', 'embed'],\n ['HTMLFieldSetElement', 'fieldset'],\n ['HTMLFormElement', 'form'],\n ['HTMLHRElement', 'hr'],\n ['HTMLIFrameElement', 'iframe'],\n ['HTMLImageElement', 'img'],\n ['HTMLInputElement', 'input'],\n ['HTMLLabelElement', 'label'],\n ['HTMLLegendElement', 'legend'],\n ['HTMLLIElement', 'li'],\n ['HTMLLinkElement', 'link'],\n ['HTMLMapElement', 'map'],\n ['HTMLMetaElement', 'meta'],\n ['HTMLMeterElement', 'meter'],\n ['HTMLModElement', 'del'],\n ['HTMLObjectElement', 'object'],\n ['HTMLOListElement', 'ol'],\n ['HTMLOptGroupElement', 'optgroup'],\n ['HTMLOptionElement', 'option'],\n ['HTMLOutputElement', 'output'],\n ['HTMLParagraphElement', 'p'],\n ['HTMLParamElement', 'param'],\n ['HTMLPictureElement', 'picture'],\n ['HTMLPreElement', 'pre'],\n ['HTMLProgressElement', 'progress'],\n ['HTMLQuoteElement', 'blockquote'],\n ['HTMLScriptElement', 'script'],\n ['HTMLSelectElement', 'select'],\n ['HTMLSlotElement', 'slot'],\n ['HTMLSourceElement', 'source'],\n ['HTMLSpanElement', 'span'],\n ['HTMLStyleElement', 'style'],\n ['HTMLTableElement', 'table'],\n ['HTMLTableSectionElement', 'tbody'],\n ['HTMLTableCellElement', 'td'],\n ['HTMLTemplateElement', 'template'],\n ['HTMLTextAreaElement', 'textarea'],\n ['HTMLTimeElement', 'time'],\n ['HTMLTitleElement', 'title'],\n ['HTMLTableRowElement', 'tr'],\n ['HTMLTrackElement', 'track'],\n ['HTMLUListElement', 'ul'],\n ['HTMLVideoElement', 'video'],\n ['HTMLHeadingElement', 'h1']\n].forEach(([cls, tag]) => registerTag(cls, tag));\n\nexport const element =\n (inConfig: ElementConfig | string): ClassDecorator =>\n (constructor: any) => {\n const config: ElementConfig = typeof inConfig === 'string' ? { tagName: inConfig } : inConfig;\n\n // 1. Automatically derive extendsTagName from prototype chain if not provided\n let extendsTagName = config.extends;\n if (!extendsTagName) {\n let proto = Object.getPrototypeOf(constructor);\n while (proto && proto !== HTMLElement && proto !== Function.prototype) {\n extendsTagName = BUILT_IN_TAG_MAP.get(proto);\n if (extendsTagName) break;\n proto = Object.getPrototypeOf(proto);\n }\n }\n\n // 2. Automatically collect observed attributes from @attributeChanged decorators\n const attributeChangedMap = getAttributeChangedMap(constructor);\n const observedFromDecorators = attributeChangedMap ? Array.from(attributeChangedMap.keys()) : [];\n const mergedObservedAttributes = [...new Set([...(config.observedAttributes ?? []), ...observedFromDecorators])];\n\n // 3. Create a new anonymous class that extends the original constructor\n const NewClass = class extends (constructor as any) {\n static get observedAttributes() {\n return mergedObservedAttributes;\n }\n\n constructor(...args: any[]) {\n super(...args);\n if (config.useShadow === true && !this.shadowRoot) {\n this.attachShadow({ mode: 'open' });\n }\n }\n\n disconnectedCallback() {\n if (super.disconnectedCallback) {\n super.disconnectedCallback();\n }\n }\n\n connectedMoveCallback() {\n if (super.connectedMoveCallback) {\n super.connectedMoveCallback();\n }\n }\n\n adoptedCallback() {\n if (super.adoptedCallback) {\n super.adoptedCallback();\n }\n }\n\n async connectedCallback() {\n if (super.connectedCallback) {\n await super.connectedCallback();\n }\n\n const templateMethod = getTemplateMethod(this);\n const styleMethod = getStyleMethod(this);\n\n const template = templateMethod ? await (this as any)[templateMethod]() : undefined;\n const style = styleMethod ? await (this as any)[styleMethod]() : undefined;\n\n // If not using shadow DOM and no decorators are present, do nothing\n if (!this.shadowRoot && template === undefined && style === undefined) {\n return;\n }\n\n let content = '';\n if (style !== undefined && style.trim().length > 0) {\n content += `<style>${style}</style>`;\n }\n\n if (template !== undefined) {\n content += template;\n } else if (!this.shadowRoot) {\n content += this.innerHTML;\n }\n\n if (this.shadowRoot) {\n this.shadowRoot.innerHTML = content;\n } else {\n this.innerHTML = content;\n }\n }\n\n // 4. Handle attribute changes and route to decorated methods\n attributeChangedCallback(name: string, oldValue: string | null, newValue: string | null) {\n // Call the original callback if it exists\n if (super.attributeChangedCallback) {\n super.attributeChangedCallback(name, oldValue, newValue);\n }\n\n // Call the method associated with @attributeChanged\n const methodKey = attributeChangedMap?.get(name);\n if (methodKey && typeof (this as any)[methodKey] === 'function') {\n (this as any)[methodKey](newValue, oldValue);\n }\n }\n };\n\n // 5. Register Custom Element using specified or default registry\n const registry = config.customElementRegistry || (typeof customElements !== 'undefined' ? customElements : undefined);\n if (registry && !registry.get(config.tagName)) {\n const options = extendsTagName ? { extends: extendsTagName } : undefined;\n registry.define(config.tagName, NewClass as any, options);\n }\n\n // 6. Save metadata\n ReflectUtils.defineMetadata(ELEMENT_CONFIG_KEY, config, NewClass);\n\n return NewClass as any;\n };\n\nexport const getElementConfig = (target: any): ElementConfig | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(ELEMENT_CONFIG_KEY, constructor);\n};\n"],
5
- "mappings": "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",
6
- "names": ["ReflectUtils", "template", "style"]
3
+ "sources": ["../../src/bundle-entry.ts", "../../../core/src/reflect/ReflectUtils.ts", "../../src/decorators/attributeChanged.ts", "../../src/decorators/template.ts", "../../src/decorators/style.ts", "../../src/decorators/query.ts", "../../src/decorators/queryAll.ts", "../../src/decorators/addEventListener.ts", "../../src/decorators/elementDefind.ts", "../../src/elements/SwcHTMLElementBase.ts", "../../src/elements/SwcForOf.ts", "../../src/elements/SwcIf.ts", "../../src/elements/SwcChoose.ts", "../../src/elements/SwcWhen.ts", "../../src/elements/SwcOther.ts", "../../src/elements/SwcObject.ts"],
4
+ "sourcesContent": ["export * from './index';\n", "import { ConstructorType } from '../types';\nexport namespace ReflectUtils {\n export const getParameterTypes = (target: any, propertyKey?: string | symbol): ConstructorType<any>[] => {\n // console.log('---------param')\n if (propertyKey) {\n return Reflect.getMetadata('design:paramtypes', target, propertyKey) || [];\n } else {\n return Reflect.getMetadata('design:paramtypes', target) || [];\n }\n }\n\n\n export const getReturnType = (target: any, propertyKey: string | symbol): any => {\n return Reflect.getMetadata('design:returntype', target, propertyKey);\n }\n\n // @Reflect.metadata(\"design:type\", Point)\n export const getType = (target: any, propertyKey?: string | symbol): any => {\n if (propertyKey) {\n return Reflect.getMetadata('design:type', target, propertyKey);\n } else {\n return Reflect.getMetadata('design:type', target);\n }\n }\n\n export const getMetadata = <T = any>(metadataKey: any, target: any, propertyKey?: string | symbol): T | undefined => {\n if (propertyKey) {\n return Reflect.getMetadata(metadataKey, target, propertyKey);\n } else {\n return Reflect.getMetadata(metadataKey, target);\n }\n\n\n //\n // let tt = target;\n // // proxy \uAC78\uB9B0\uAC70\uB294 \uC624\uB9AC\uC9C0\uB110 constructor\uC5D0 \uB4E4\uC5B4\uAC00\uC788\uC744\uACBD\uC6B0\uB3C4\uC788\uC5B4\uC11C reflect\uAC00 proxy\uC758 constructor\uC5D0\uC11C \uCC3E\uB294\uACBD\uC6B0\uB3C4\uC788\uB2E4,\n // // \uC11C\uBC84\uB791 \uD504\uB860\uD2B8\uB791 \uB2E4\uB978\uB4EF.. \uADF8\uB798\uC11C \uC704\uB85C \uCC3E\uC544\uAC00\uBA74\uC11C\n // while (tt) {\n // let meta: any = undefined;\n // if (propertyKey) {\n // meta = Reflect.getMetadata(metadataKey, tt, propertyKey);\n // } else {\n // meta = Reflect.getMetadata(metadataKey, tt);\n // }\n // if (meta) {\n // return meta;\n // }\n // tt = Reflect.getPrototypeOf(tt);\n // }\n }\n\n export const getMetadataKeys = (target: any) => {\n return Reflect.getMetadataKeys(target);\n }\n\n export const getOwnMetadata = (metadataKey: any, target: any, propertyKey?: string): number[] | any => {\n if (propertyKey) {\n return Reflect.getOwnMetadata(metadataKey, target, propertyKey);\n } else {\n return Reflect.getOwnMetadata(metadataKey, target);\n }\n }\n\n export const getMetadatas = (target: any) => {\n return ReflectUtils.getMetadataKeys(target).map(it => ReflectUtils.getMetadata(it, target));\n }\n\n export const metadata = (metadataKey: any, data: any) => {\n return Reflect.metadata(metadataKey, data);\n }\n\n export const defineMetadata = (metadataKey: any, value: any, target: any, propertyKey?: string | symbol) => {\n // console.log(\"Reflect:\",Reflect)\n if (propertyKey && Reflect.defineMetadata) {\n Reflect.defineMetadata(metadataKey, value, target, propertyKey);\n } else if (Reflect.defineMetadata) {\n Reflect.defineMetadata(metadataKey, value, target);\n // Reflect.defineMetadata(\"design:paramtypes\", value, target);\n }\n // console.log(\"Reflect:\",Reflect.getMetadata(metadataKey, target))\n // console.log(\"Reflect:\",Reflect.getMetadata('design:paramtypes', target))\n }\n}\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport const ATTRIBUTE_CHANGED_METADATA_KEY = Symbol('simple-web-component:attribute-changed');\nexport const ATTRIBUTE_CHANGED_WILDCARD = '*';\n\nexport function attributeChanged(attributeName: string | string[]): MethodDecorator;\nexport function attributeChanged(target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor): void;\nexport function attributeChanged(arg1: string | string[] | Object, arg2?: string | symbol, arg3?: PropertyDescriptor): MethodDecorator | void {\n const decorator = (attributeName: string, target: Object, propertyKey: string | symbol) => {\n const constructor = target.constructor;\n let meta = ReflectUtils.getMetadata<Map<string, (string | symbol)[]>>(ATTRIBUTE_CHANGED_METADATA_KEY, constructor);\n if (!meta) {\n meta = new Map<string, (string | symbol)[]>();\n ReflectUtils.defineMetadata(ATTRIBUTE_CHANGED_METADATA_KEY, meta, constructor);\n }\n\n let methods = meta.get(attributeName);\n if (!methods) {\n methods = [];\n meta.set(attributeName, methods);\n }\n if (!methods.includes(propertyKey)) {\n methods.push(propertyKey);\n }\n };\n\n if (typeof arg1 === 'string') {\n return (target: Object, propertyKey: string | symbol) => {\n decorator(arg1, target, propertyKey);\n };\n } else if (Array.isArray(arg1)) {\n return (target: Object, propertyKey: string | symbol) => {\n arg1.forEach(name => decorator(name, target, propertyKey));\n };\n } else if (arg1 && arg2) {\n decorator(ATTRIBUTE_CHANGED_WILDCARD, arg1, arg2);\n }\n}\n\nexport const getAttributeChangedMap = (target: any): Map<string, string | symbol> | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(ATTRIBUTE_CHANGED_METADATA_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport const TEMPLATE_METHOD_KEY = Symbol('simple-web-component:template-method');\n\nexport const template: MethodDecorator = (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {\n // console.log('setTemplateMethod target.constructor', target.constructor)\n ReflectUtils.defineMetadata(TEMPLATE_METHOD_KEY, propertyKey, target.constructor);\n};\n\nexport const getTemplateMethod = (target: any): string | symbol | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n // console.log('getTemplateMethod constructor', constructor)\n return ReflectUtils.getMetadata(TEMPLATE_METHOD_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport const STYLE_METHOD_KEY = Symbol('simple-web-component:style-method');\n\nexport const style: MethodDecorator = (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {\n ReflectUtils.defineMetadata(STYLE_METHOD_KEY, propertyKey, target.constructor);\n};\n\nexport const getStyleMethod = (target: any): string | symbol | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(STYLE_METHOD_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport interface QueryOptions {\n useShadow?: boolean;\n}\n\nexport interface QueryMetadata {\n selector: string;\n options: QueryOptions;\n propertyKey: string | symbol;\n isMethod: boolean;\n}\n\nexport const QUERY_METADATA_KEY = Symbol('simple-web-component:query');\n\nexport const query = (selector: string, options: QueryOptions = { useShadow: true }): any => {\n return (target: Object, propertyKey: string | symbol, descriptor?: PropertyDescriptor) => {\n const isMethod = !!descriptor;\n const constructor = target.constructor;\n\n // \uBA54\uD0C0\uB370\uC774\uD130 \uC800\uC7A5 (\uB098\uC911\uC5D0 elementDefind\uC5D0\uC11C \uC0AC\uC6A9)\n let queries = ReflectUtils.getMetadata<QueryMetadata[]>(QUERY_METADATA_KEY, constructor);\n if (!queries) {\n queries = [];\n ReflectUtils.defineMetadata(QUERY_METADATA_KEY, queries, constructor);\n }\n queries.push({ selector, options, propertyKey, isMethod });\n\n if (!isMethod) {\n // \uC18D\uC131 \uB370\uCF54\uB808\uC774\uD130\uC778 \uACBD\uC6B0: \uAE30\uC874\uCC98\uB7FC Lazy Getter \uC124\uC815\n Object.defineProperty(target, propertyKey, {\n get(this: HTMLElement) {\n const root = options.useShadow !== false && this.shadowRoot ? this.shadowRoot : this;\n return root.querySelector(selector);\n },\n enumerable: true,\n configurable: true\n });\n }\n };\n};\n\nexport const getQueryMetadata = (target: any): QueryMetadata[] | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(QUERY_METADATA_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport interface QueryAllOptions {\n useShadow?: boolean;\n}\n\nexport interface QueryAllMetadata {\n selector: string;\n options: QueryAllOptions;\n propertyKey: string | symbol;\n isMethod: boolean;\n}\n\nexport const QUERY_ALL_METADATA_KEY = Symbol('simple-web-component:query-all');\n\nexport const queryAll = (selector: string, options: QueryAllOptions = { useShadow: true }): any => {\n return (target: Object, propertyKey: string | symbol, descriptor?: PropertyDescriptor) => {\n const isMethod = !!descriptor;\n const constructor = target.constructor;\n\n // \uBA54\uD0C0\uB370\uC774\uD130 \uC800\uC7A5 (\uB098\uC911\uC5D0 elementDefind\uC5D0\uC11C \uC0AC\uC6A9)\n let queries = ReflectUtils.getMetadata<QueryAllMetadata[]>(QUERY_ALL_METADATA_KEY, constructor);\n if (!queries) {\n queries = [];\n ReflectUtils.defineMetadata(QUERY_ALL_METADATA_KEY, queries, constructor);\n }\n queries.push({ selector, options, propertyKey, isMethod });\n\n if (!isMethod) {\n // \uC18D\uC131 \uB370\uCF54\uB808\uC774\uD130\uC778 \uACBD\uC6B0: \uAE30\uC874\uCC98\uB7FC Lazy Getter \uC124\uC815\n Object.defineProperty(target, propertyKey, {\n get(this: HTMLElement) {\n const root = options.useShadow !== false && this.shadowRoot ? this.shadowRoot : this;\n return root.querySelectorAll(selector);\n },\n enumerable: true,\n configurable: true\n });\n }\n };\n};\n\nexport const getQueryAllMetadata = (target: any): QueryAllMetadata[] | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(QUERY_ALL_METADATA_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\n\nexport interface AddEventListenerOptions extends EventListenerOptions {\n selector?: string;\n eventName: string;\n useShadow?: boolean;\n capture?: boolean;\n once?: boolean;\n passive?: boolean;\n}\n\nexport interface AddEventListenerMetadata {\n options: AddEventListenerOptions;\n propertyKey: string | symbol;\n}\n\nexport const ADD_EVENT_LISTENER_METADATA_KEY = Symbol('simple-web-component:add-event-listener');\n\nexport const addEventListener = (options: AddEventListenerOptions): MethodDecorator => {\n return (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {\n const constructor = target.constructor;\n\n let listeners = ReflectUtils.getMetadata<AddEventListenerMetadata[]>(ADD_EVENT_LISTENER_METADATA_KEY, constructor);\n if (!listeners) {\n listeners = [];\n ReflectUtils.defineMetadata(ADD_EVENT_LISTENER_METADATA_KEY, listeners, constructor);\n }\n listeners.push({ options, propertyKey });\n };\n};\n\nexport const getAddEventListenerMetadata = (target: any): AddEventListenerMetadata[] | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(ADD_EVENT_LISTENER_METADATA_KEY, constructor);\n};\n", "import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';\nimport { getAttributeChangedMap, ATTRIBUTE_CHANGED_WILDCARD } from './attributeChanged';\nimport { getTemplateMethod } from './template';\nimport { getStyleMethod } from './style';\nimport { getQueryMetadata } from './query';\nimport { getQueryAllMetadata } from './queryAll';\nimport { getAddEventListenerMetadata } from './addEventListener';\n\nexport interface ElementConfig {\n tagName: string;\n useShadow?: boolean;\n extends?: string;\n observedAttributes?: string[];\n customElementRegistry?: CustomElementRegistry;\n}\n\nexport const ELEMENT_CONFIG_KEY = Symbol('simple-web-component:element-config');\n\nconst BUILT_IN_TAG_MAP = new Map<any, string>();\n\nconst registerTag = (className: string, tagName: string) => {\n if (typeof globalThis !== 'undefined' && (globalThis as any)[className]) {\n BUILT_IN_TAG_MAP.set((globalThis as any)[className], tagName);\n }\n};\n\n// Register comprehensive list of supported tags for automatic extends inference\n[\n ['HTMLAnchorElement', 'a'],\n ['HTMLAreaElement', 'area'],\n ['HTMLAudioElement', 'audio'],\n ['HTMLBaseElement', 'base'],\n ['HTMLButtonElement', 'button'],\n ['HTMLCanvasElement', 'canvas'],\n ['HTMLDataElement', 'data'],\n ['HTMLDataListElement', 'datalist'],\n ['HTMLDetailsElement', 'details'],\n ['HTMLDialogElement', 'dialog'],\n ['HTMLDivElement', 'div'],\n ['HTMLDListElement', 'dl'],\n ['HTMLEmbedElement', 'embed'],\n ['HTMLFieldSetElement', 'fieldset'],\n ['HTMLFormElement', 'form'],\n ['HTMLHRElement', 'hr'],\n ['HTMLIFrameElement', 'iframe'],\n ['HTMLImageElement', 'img'],\n ['HTMLInputElement', 'input'],\n ['HTMLLabelElement', 'label'],\n ['HTMLLegendElement', 'legend'],\n ['HTMLLIElement', 'li'],\n ['HTMLLinkElement', 'link'],\n ['HTMLMapElement', 'map'],\n ['HTMLMetaElement', 'meta'],\n ['HTMLMeterElement', 'meter'],\n ['HTMLModElement', 'del'],\n ['HTMLObjectElement', 'object'],\n ['HTMLOListElement', 'ol'],\n ['HTMLOptGroupElement', 'optgroup'],\n ['HTMLOptionElement', 'option'],\n ['HTMLOutputElement', 'output'],\n ['HTMLParagraphElement', 'p'],\n ['HTMLParamElement', 'param'],\n ['HTMLPictureElement', 'picture'],\n ['HTMLPreElement', 'pre'],\n ['HTMLProgressElement', 'progress'],\n ['HTMLQuoteElement', 'blockquote'],\n ['HTMLScriptElement', 'script'],\n ['HTMLSelectElement', 'select'],\n ['HTMLSlotElement', 'slot'],\n ['HTMLSourceElement', 'source'],\n ['HTMLSpanElement', 'span'],\n ['HTMLStyleElement', 'style'],\n ['HTMLTableElement', 'table'],\n ['HTMLTableSectionElement', 'tbody'],\n ['HTMLTableCellElement', 'td'],\n ['HTMLTemplateElement', 'template'],\n ['HTMLTextAreaElement', 'textarea'],\n ['HTMLTimeElement', 'time'],\n ['HTMLTitleElement', 'title'],\n ['HTMLTableRowElement', 'tr'],\n ['HTMLTrackElement', 'track'],\n ['HTMLUListElement', 'ul'],\n ['HTMLVideoElement', 'video'],\n ['HTMLHeadingElement', 'h1']\n].forEach(([cls, tag]) => registerTag(cls, tag));\n\nexport const elementDefind =\n (inConfig: ElementConfig | string): ClassDecorator =>\n (constructor: any) => {\n const config: ElementConfig = typeof inConfig === 'string' ? { tagName: inConfig } : inConfig;\n\n // 1. Automatically derive extendsTagName from prototype chain if not provided\n let extendsTagName = config.extends;\n if (!extendsTagName) {\n let proto = Object.getPrototypeOf(constructor);\n while (proto && proto !== HTMLElement && proto !== Function.prototype) {\n extendsTagName = BUILT_IN_TAG_MAP.get(proto);\n if (extendsTagName) break;\n proto = Object.getPrototypeOf(proto);\n }\n }\n\n // 2. Automatically collect observed attributes from @attributeChanged decorators\n const attributeChangedMap = getAttributeChangedMap(constructor);\n const observedFromDecorators = attributeChangedMap ? Array.from(attributeChangedMap.keys()).filter(it => it !== ATTRIBUTE_CHANGED_WILDCARD) : [];\n const mergedObservedAttributes = [...new Set([...(config.observedAttributes ?? []), ...observedFromDecorators])];\n\n // 3. Create a new anonymous class that extends the original constructor\n const NewClass = class extends (constructor as any) {\n private _observer: MutationObserver | null = null;\n private _boundElements = new WeakMap<Element, Set<string | symbol>>();\n\n static get observedAttributes() {\n return mergedObservedAttributes;\n }\n\n constructor(...args: any[]) {\n super(...args);\n if (config.useShadow === true && !this.shadowRoot) {\n this.attachShadow({ mode: 'open' });\n }\n }\n\n private _syncDecorators() {\n // 5. Execute @query and @queryAll methods\n const queryMetadata = getQueryMetadata(this);\n if (queryMetadata) {\n queryMetadata\n .filter(it => it.isMethod)\n .forEach(it => {\n const root = it.options.useShadow !== false && this.shadowRoot ? this.shadowRoot : this;\n const element = root.querySelector(it.selector);\n\n // 중복 호출 방지: 해당 selector로 찾은 요소가 이전과 다를 때만 호출하거나,\n // 또는 매번 호출할지 결정해야 함. 여기서는 새로운 요소가 발견되면 호출하는 방식으로 처리.\n if (element) {\n let bound = this._boundElements.get(element);\n if (!bound) {\n bound = new Set();\n this._boundElements.set(element, bound);\n }\n if (!bound.has(it.propertyKey)) {\n (this as any)[it.propertyKey](element);\n bound.add(it.propertyKey);\n }\n }\n });\n }\n\n const queryAllMetadata = getQueryAllMetadata(this);\n if (queryAllMetadata) {\n queryAllMetadata\n .filter(it => it.isMethod)\n .forEach(it => {\n const root = it.options.useShadow !== false && this.shadowRoot ? this.shadowRoot : this;\n const elements = root.querySelectorAll(it.selector);\n\n // queryAll은 목록이 바뀔 수 있으므로 일단 호출하되,\n // 내부 로직은 사용자에게 맡기거나 좀 더 정교한 비교가 필요할 수 있음.\n // 여기서는 단순하게 호출만 다시 함. (사용자가 요청한 '다시 호출' 반영)\n (this as any)[it.propertyKey](elements);\n });\n }\n\n // 6. Register @addEventListener methods\n const eventListeners = getAddEventListenerMetadata(this);\n if (eventListeners) {\n eventListeners.forEach(it => {\n const { selector, eventName, useShadow, ...options } = it.options;\n const root = useShadow !== false && this.shadowRoot ? this.shadowRoot : this;\n const targetElements = selector ? root.querySelectorAll(selector) : [this as any as Element];\n\n targetElements.forEach(targetElement => {\n if (targetElement) {\n let bound = this._boundElements.get(targetElement);\n if (!bound) {\n bound = new Set();\n this._boundElements.set(targetElement, bound);\n }\n\n // 중복 바인딩 방지: (요소, 이벤트, 메서드) 조합 확인\n const eventKey = `event:${String(it.propertyKey)}:${eventName}`;\n if (!bound.has(eventKey)) {\n targetElement.addEventListener(\n eventName,\n event => {\n (this as any)[it.propertyKey](event);\n },\n options\n );\n bound.add(eventKey);\n }\n }\n });\n });\n }\n }\n\n disconnectedCallback() {\n if (this._observer) {\n this._observer.disconnect();\n }\n if (super.disconnectedCallback) {\n super.disconnectedCallback();\n }\n }\n\n connectedMoveCallback() {\n //default logic...\n if (super.connectedMoveCallback) {\n super.connectedMoveCallback();\n }\n }\n\n adoptedCallback() {\n //default logic...\n if (super.adoptedCallback) {\n super.adoptedCallback();\n }\n }\n\n async connectedCallback() {\n const templateMethod = getTemplateMethod(this);\n const styleMethod = getStyleMethod(this);\n\n const template = templateMethod ? await (this as any)[templateMethod]() : undefined;\n const style = styleMethod ? await (this as any)[styleMethod]() : undefined;\n\n // If not using shadow DOM and no decorators are present, do nothing\n if (!this.shadowRoot && template === undefined && style === undefined) {\n return;\n }\n\n let content = '';\n if (style !== undefined && style.trim().length > 0) {\n content += `<style>${style}</style>`;\n }\n\n if (template !== undefined) {\n content += template;\n } else if (!this.shadowRoot) {\n content += this.innerHTML;\n }\n\n if (this.shadowRoot) {\n this.shadowRoot.innerHTML = content;\n } else {\n this.innerHTML = content;\n }\n\n // 초기 동기화\n (this as any)._syncDecorators();\n\n // 7. Watch for DOM changes (MutationObserver)\n this._observer = new MutationObserver(() => {\n (this as any)._syncDecorators();\n });\n const target = this.shadowRoot || this;\n this._observer.observe(target, { childList: true, subtree: true });\n\n if (super.connectedCallback) {\n await super.connectedCallback();\n }\n }\n\n // 4. Handle attribute changes and route to decorated methods\n attributeChangedCallback(name: string, oldValue: string | null, newValue: string | null) {\n // Call the original callback if it exists\n if (super.attributeChangedCallback) {\n super.attributeChangedCallback(name, oldValue, newValue);\n }\n\n // Call all methods associated with @attributeChanged\n const methodKeys = attributeChangedMap?.get(name);\n if (methodKeys && Array.isArray(methodKeys)) {\n methodKeys.forEach(key => {\n if (typeof (this as any)[key] === 'function') {\n (this as any)[key](newValue, oldValue, name);\n }\n });\n }\n\n // Call the wildcard methods if they exist\n const wildcardMethodKeys = attributeChangedMap?.get(ATTRIBUTE_CHANGED_WILDCARD);\n if (wildcardMethodKeys && Array.isArray(wildcardMethodKeys)) {\n wildcardMethodKeys.forEach(key => {\n if (typeof (this as any)[key] === 'function') {\n (this as any)[key](newValue, oldValue, name);\n }\n });\n }\n }\n };\n\n // 5. Register Custom Element using specified or default registry\n const registry = config.customElementRegistry || (typeof customElements !== 'undefined' ? customElements : undefined);\n if (registry && !registry.get(config.tagName)) {\n const options = extendsTagName ? { extends: extendsTagName } : undefined;\n registry.define(config.tagName, NewClass as any, options);\n }\n\n // 6. Save metadata\n ReflectUtils.defineMetadata(ELEMENT_CONFIG_KEY, config, NewClass);\n\n return NewClass as any;\n };\n\nexport const getElementConfig = (target: any): ElementConfig | undefined => {\n const constructor = target instanceof Function ? target : target.constructor;\n return ReflectUtils.getMetadata(ELEMENT_CONFIG_KEY, constructor);\n};\n", "import { getTemplateMethod } from '../decorators/template';\nimport { getStyleMethod } from '../decorators/style';\n\nexport abstract class SwcHTMLElementBase extends HTMLElement {\n protected _masterTplNodes: Node[] = [];\n protected _asKey: string = 'value';\n protected _asIndexKey: string = 'index';\n\n constructor() {\n super();\n }\n\n protected initCore() {\n this._asKey = this.getAttribute('as') || 'value';\n this._asIndexKey = this.getAttribute('as-index') || 'index';\n const tplSlot = this.shadowRoot?.getElementById('tpl-slot') as HTMLSlotElement;\n if (tplSlot) {\n this._masterTplNodes = tplSlot.assignedNodes().map(n => n.cloneNode(true));\n }\n }\n\n protected getValueByPath(obj: any, path: string) {\n if (path === this._asKey) return obj;\n if (path.startsWith(`${this._asKey}.`)) {\n return path\n .split('.')\n .slice(1)\n .reduce((acc, part) => acc && acc[part], obj);\n }\n return undefined;\n }\n\n protected applyData(node: Node, data: any, index?: number) {\n const context: Record<string, any> = {};\n if (index !== undefined) {\n context[this._asIndexKey] = index.toString();\n }\n\n const walk = (n: Node) => {\n if (n.nodeType === Node.TEXT_NODE) {\n if (!(n as any)._original) (n as any)._original = n.textContent;\n let text = (n as any)._original;\n\n text = text.replace(/{{(.*?)}}/g, (match: string, path: string) => {\n path = path.trim();\n if (context[path] !== undefined) return context[path];\n const val = this.getValueByPath(data, path);\n return val !== undefined ? val : match;\n });\n if (n.textContent !== text) n.textContent = text;\n } else if (n.nodeType === Node.ELEMENT_NODE) {\n const el = n as Element;\n Array.from(el.attributes).forEach(a => {\n if (!(a as any)._original) (a as any)._original = a.value;\n let val = (a as any)._original;\n\n val = val.replace(/{{(.*?)}}/g, (match: string, path: string) => {\n path = path.trim();\n if (context[path] !== undefined) return context[path];\n const v = this.getValueByPath(data, path);\n return v !== undefined ? v : match;\n });\n if (a.value !== val) a.value = val;\n });\n el.childNodes.forEach(walk);\n }\n };\n walk(node);\n }\n\n /**\n * \uAC1D\uCCB4/\uBC30\uC5F4\uC758 \uBCC0\uACBD\uC744 \uAC10\uC9C0\uD558\uB294 Proxy \uC0DD\uC131 \uC720\uD2F8\uB9AC\uD2F0\n */\n protected createReactiveProxy(target: any, onChange: () => void, onIndexChange?: (index: number, val: any) => void) {\n return new Proxy(target, {\n set: (t, prop, val) => {\n const isIndex = !isNaN(Number(prop));\n t[prop] = val;\n if (isIndex && onIndexChange) {\n onIndexChange(Number(prop), val);\n } else {\n onChange();\n }\n return true;\n },\n deleteProperty: (t, prop) => {\n delete t[prop];\n onChange();\n return true;\n }\n });\n }\n}\n", "import { elementDefind, template, style } from '../index';\nimport { SwcHTMLElementBase } from './SwcHTMLElementBase';\n\n@elementDefind({ tagName: 'swc-for-of', useShadow: true })\nexport class SwcForOf extends SwcHTMLElementBase {\n private _value: any[] = [];\n\n constructor() {\n super();\n }\n\n set value(val: any[]) {\n if (!Array.isArray(val)) val = [];\n this._value = this.createReactiveProxy(\n val,\n () => this.renderAll(),\n (idx, v) => this.updateSingleRow(idx, v)\n );\n this.renderAll();\n }\n\n get value(): any[] {\n return this._value;\n }\n\n @style\n styles() {\n return `:host { display: contents; }`;\n }\n\n @template\n renderTemplate() {\n return `<slot id=\"tpl-slot\" style=\"display:none;\"></slot>`;\n }\n\n connectedCallback() {\n this.initCore();\n this.renderAll();\n }\n\n public updateSingleRow(index: number, newValue: any) {\n const targets = this.querySelectorAll(`[slot=\"row-${index}\"]`);\n if (targets.length > 0) {\n targets.forEach(target => this.applyData(target, newValue, index));\n } else {\n this.renderRow(newValue, index);\n }\n }\n\n private renderRow(item: any, index: number) {\n if (!this.shadowRoot || this._masterTplNodes.length === 0) return;\n\n const slotName = `row-${index}`;\n if (!this.shadowRoot.querySelector(`slot[name=\"${slotName}\"]`)) {\n const slot = document.createElement('slot');\n slot.name = slotName;\n this.shadowRoot.appendChild(slot);\n }\n\n this._masterTplNodes.forEach(tplNode => {\n const clone = tplNode.cloneNode(true);\n if (clone.nodeType === Node.ELEMENT_NODE) {\n (clone as HTMLElement).setAttribute('slot', slotName);\n (clone as HTMLElement).style.display = '';\n } else if (clone.nodeType === Node.TEXT_NODE) {\n if (clone.textContent?.trim().length === 0) return;\n const span = document.createElement('span');\n span.setAttribute('slot', slotName);\n span.appendChild(clone);\n this.appendChild(span);\n this.applyData(span, item, index);\n return;\n }\n this.appendChild(clone);\n this.applyData(clone, item, index);\n });\n }\n\n private renderAll() {\n if (this._masterTplNodes.length === 0 || !this.shadowRoot) return;\n\n Array.from(this.children).forEach(c => {\n const slot = c.getAttribute('slot');\n if (slot && slot.startsWith('row-')) {\n c.remove();\n }\n });\n\n Array.from(this.shadowRoot.querySelectorAll('slot')).forEach(s => {\n if (s.id !== 'tpl-slot') s.remove();\n });\n\n this._value.forEach((item, index) => this.renderRow(item, index));\n }\n}\n", "import { elementDefind, template, style } from '../index';\nimport { SwcHTMLElementBase } from './SwcHTMLElementBase';\n\n@elementDefind({ tagName: 'swc-if', useShadow: true })\nexport class SwcIf extends SwcHTMLElementBase {\n private _value: any = false;\n private _observer: MutationObserver | null = null;\n\n constructor() {\n super();\n }\n\n set value(val: any) {\n this._value = val;\n this.render();\n }\n\n get value(): any {\n return this._value;\n }\n\n @style\n styles() {\n return `:host { display: contents; }`;\n }\n\n @template\n renderTemplate() {\n return `<slot id=\"tpl-slot\" style=\"display:none;\"></slot>`;\n }\n\n connectedCallback() {\n this.initCore();\n this._observer = new MutationObserver(() => this.render());\n this._observer.observe(this, { attributes: true });\n this.render();\n }\n\n disconnectedCallback() {\n this._observer?.disconnect();\n }\n\n private render() {\n if (!this.shadowRoot) return;\n\n const attrValue = this.getAttribute('value');\n if (attrValue !== null && attrValue.includes('{{')) return;\n\n let displayValue = attrValue !== null ? attrValue : this._value;\n let isTruthy = !!displayValue;\n if (typeof displayValue === 'string') {\n if (displayValue === 'false' || displayValue === '0' || displayValue === '') isTruthy = false;\n else {\n try {\n isTruthy = !!new Function(`return ${displayValue}`)();\n } catch (e) {\n isTruthy = true;\n }\n }\n }\n\n Array.from(this.children).forEach(c => {\n if (c.getAttribute('slot') === 'if-content') {\n c.remove();\n }\n });\n\n const existingSlot = this.shadowRoot.querySelector('slot[name=\"if-content\"]');\n if (existingSlot) existingSlot.remove();\n\n if (isTruthy && this._masterTplNodes.length > 0) {\n const contentSlot = document.createElement('slot');\n contentSlot.name = 'if-content';\n this.shadowRoot.appendChild(contentSlot);\n\n this._masterTplNodes.forEach(tplNode => {\n const clone = tplNode.cloneNode(true);\n if (clone.nodeType === Node.ELEMENT_NODE) {\n (clone as HTMLElement).setAttribute('slot', 'if-content');\n } else if (clone.nodeType === Node.TEXT_NODE) {\n if (clone.textContent?.trim().length === 0) return;\n const span = document.createElement('span');\n span.setAttribute('slot', 'if-content');\n span.appendChild(clone);\n this.appendChild(span);\n return;\n }\n this.appendChild(clone);\n });\n }\n }\n}\n", "import { elementDefind, template, style } from '../index';\n\n@elementDefind({ tagName: 'swc-choose', useShadow: true })\nexport class SwcChoose extends HTMLElement {\n private _observer: MutationObserver | null = null;\n private _value: any = undefined;\n\n set value(val: any) {\n this._value = val;\n this.evaluate();\n }\n\n get value() {\n return this._value;\n }\n\n @style\n styles() {\n return `:host { display: contents; }`;\n }\n\n @template\n render() {\n return `<slot id=\"choose-slot\"></slot>`;\n }\n\n connectedCallback() {\n this._observer = new MutationObserver(() => this.evaluate());\n this._observer.observe(this, { attributes: true, subtree: true, childList: true });\n this.evaluate();\n }\n\n disconnectedCallback() {\n this._observer?.disconnect();\n }\n\n private evaluate() {\n const whens = Array.from(this.querySelectorAll('swc-when'));\n const other = this.querySelector('swc-other');\n let matched = false;\n\n // 현재 choose에 설정된 value (문자열인 경우 \"null\", \"undefined\" 등 처리)\n const chooseValue = this.getAttribute('value') ?? this._value;\n\n whens.forEach(when => {\n if (matched) {\n (when as HTMLElement).style.display = 'none';\n return;\n }\n\n const testAttr = when.getAttribute('test');\n if (testAttr === null) return;\n if (testAttr.includes('{{')) return; // 아직 치환 전이면 스킵\n\n let isConditionMet = false;\n\n if (chooseValue !== undefined && chooseValue !== null) {\n // 1. 매칭 모드: choose의 value와 when의 test값이 같은지 비교\n isConditionMet = String(chooseValue) === String(testAttr);\n } else {\n // 2. 표현식 모드: testAttr 자체가 실행 가능한 코드인 경우\n try {\n if (testAttr === 'true') isConditionMet = true;\n else if (testAttr === 'false') isConditionMet = false;\n else isConditionMet = !!new Function(`return ${testAttr}`)();\n } catch (e) {\n isConditionMet = false;\n }\n }\n\n if (isConditionMet) {\n (when as HTMLElement).style.display = '';\n matched = true;\n } else {\n (when as HTMLElement).style.display = 'none';\n }\n });\n\n if (other) {\n (other as HTMLElement).style.display = matched ? 'none' : '';\n }\n }\n}\n", "import { elementDefind, template, style } from '../index';\n\n@elementDefind({ tagName: 'swc-when', useShadow: true })\nexport class SwcWhen extends HTMLElement {\n @style\n styles() {\n return `:host { display: contents; }`;\n }\n\n @template\n render() {\n return `<slot></slot>`;\n }\n}\n", "import { elementDefind, template, style } from '../index';\n\n@elementDefind({ tagName: 'swc-other', useShadow: true })\nexport class SwcOther extends HTMLElement {\n @style\n styles() {\n return `:host { display: contents; }`;\n }\n\n @template\n render() {\n return `<slot></slot>`;\n }\n}\n", "import { elementDefind, template, style } from '../index';\nimport { SwcHTMLElementBase } from './SwcHTMLElementBase';\n\n@elementDefind({ tagName: 'swc-object', useShadow: true })\nexport class SwcObject extends SwcHTMLElementBase {\n private _value: any = {};\n private _renderedNodes: Node[] = [];\n\n constructor() {\n super();\n }\n\n set value(val: any) {\n if (typeof val !== 'object' || val === null) val = {};\n this._value = this.createReactiveProxy(val, () => this.updateUI());\n this.render();\n }\n\n get value(): any {\n return this._value;\n }\n\n @style\n styles() {\n return `:host { display: contents; }`;\n }\n\n @template\n renderTemplate() {\n return `<slot id=\"tpl-slot\" style=\"display:none;\"></slot>`;\n }\n\n connectedCallback() {\n this.initCore();\n this.render();\n }\n\n private updateUI() {\n this._renderedNodes.forEach(node => {\n this.applyData(node, this._value);\n });\n }\n\n private render() {\n if (!this.shadowRoot || this._masterTplNodes.length === 0) return;\n\n this._renderedNodes.forEach(n => {\n if (n.parentElement === this) this.removeChild(n);\n });\n this._renderedNodes = [];\n\n let slot = this.shadowRoot.querySelector('slot[name=\"obj-content\"]');\n if (!slot) {\n slot = document.createElement('slot');\n (slot as HTMLSlotElement).name = 'obj-content';\n this.shadowRoot.appendChild(slot);\n }\n\n this._masterTplNodes.forEach(tplNode => {\n const clone = tplNode.cloneNode(true);\n if (clone.nodeType === Node.ELEMENT_NODE) {\n (clone as HTMLElement).setAttribute('slot', 'obj-content');\n } else if (clone.nodeType === Node.TEXT_NODE) {\n if (clone.textContent?.trim().length === 0) return;\n const span = document.createElement('span');\n span.setAttribute('slot', 'obj-content');\n span.appendChild(clone);\n this.appendChild(span);\n this._renderedNodes.push(span);\n this.applyData(span, this._value);\n return;\n }\n this.appendChild(clone);\n this._renderedNodes.push(clone);\n this.applyData(clone, this._value);\n });\n }\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACCO,MAAW;AAAA,GAAX,CAAWA,kBAAX;AACUA,kBAAA,oBAAoB,CAAC,QAAa,gBAA0D;AAErG,UAAI,aAAa;AACb,eAAO,QAAQ,YAAY,qBAAqB,QAAQ,WAAW,KAAK,CAAC;MAC7E,OAAO;AACH,eAAO,QAAQ,YAAY,qBAAqB,MAAM,KAAK,CAAC;MAChE;IACJ;AAGaA,kBAAA,gBAAgB,CAAC,QAAa,gBAAuC;AAC9E,aAAO,QAAQ,YAAY,qBAAqB,QAAQ,WAAW;IACvE;AAGaA,kBAAA,UAAU,CAAC,QAAa,gBAAuC;AACxE,UAAI,aAAa;AACb,eAAO,QAAQ,YAAY,eAAe,QAAQ,WAAW;MACjE,OAAO;AACH,eAAO,QAAQ,YAAY,eAAe,MAAM;MACpD;IACJ;AAEaA,kBAAA,cAAc,CAAU,aAAkB,QAAa,gBAAiD;AACjH,UAAI,aAAa;AACb,eAAO,QAAQ,YAAY,aAAa,QAAQ,WAAW;MAC/D,OAAO;AACH,eAAO,QAAQ,YAAY,aAAa,MAAM;MAClD;IAmBJ;AAEaA,kBAAA,kBAAkB,CAAC,WAAgB;AAC5C,aAAO,QAAQ,gBAAgB,MAAM;IACzC;AAEaA,kBAAA,iBAAiB,CAAC,aAAkB,QAAa,gBAAyC;AACnG,UAAI,aAAa;AACb,eAAO,QAAQ,eAAe,aAAa,QAAQ,WAAW;MAClE,OAAO;AACH,eAAO,QAAQ,eAAe,aAAa,MAAM;MACrD;IACJ;AAEaA,kBAAA,eAAe,CAAC,WAAgB;AACzC,aAAOA,cAAa,gBAAgB,MAAM,EAAE,IAAI,CAAA,OAAMA,cAAa,YAAY,IAAI,MAAM,CAAC;IAC9F;AAEaA,kBAAA,WAAW,CAAC,aAAkB,SAAc;AACrD,aAAO,QAAQ,SAAS,aAAa,IAAI;IAC7C;AAEaA,kBAAA,iBAAiB,CAAC,aAAkB,OAAY,QAAa,gBAAkC;AAExG,UAAI,eAAe,QAAQ,gBAAgB;AACvC,gBAAQ,eAAe,aAAa,OAAO,QAAQ,WAAW;MAClE,WAAW,QAAQ,gBAAgB;AAC/B,gBAAQ,eAAe,aAAa,OAAO,MAAM;MAErD;IAGJ;EAAA,GAhFc,iBAAA,eAAA,CAAA,EAAA;;;ACCX,MAAM,iCAAiC,OAAO,wCAAwC;AACtF,MAAM,6BAA6B;AAInC,WAAS,iBAAiB,MAAkC,MAAwB,MAAmD;AAC5I,UAAM,YAAY,CAAC,eAAuB,QAAgB,gBAAiC;AACzF,YAAM,cAAc,OAAO;AAC3B,UAAI,OAAO,aAAa,YAA8C,gCAAgC,WAAW;AACjH,UAAI,CAAC,MAAM;AACT,eAAO,oBAAI,IAAiC;AAC5C,qBAAa,eAAe,gCAAgC,MAAM,WAAW;AAAA,MAC/E;AAEA,UAAI,UAAU,KAAK,IAAI,aAAa;AACpC,UAAI,CAAC,SAAS;AACZ,kBAAU,CAAC;AACX,aAAK,IAAI,eAAe,OAAO;AAAA,MACjC;AACA,UAAI,CAAC,QAAQ,SAAS,WAAW,GAAG;AAClC,gBAAQ,KAAK,WAAW;AAAA,MAC1B;AAAA,IACF;AAEA,QAAI,OAAO,SAAS,UAAU;AAC5B,aAAO,CAAC,QAAgB,gBAAiC;AACvD,kBAAU,MAAM,QAAQ,WAAW;AAAA,MACrC;AAAA,IACF,WAAW,MAAM,QAAQ,IAAI,GAAG;AAC9B,aAAO,CAAC,QAAgB,gBAAiC;AACvD,aAAK,QAAQ,UAAQ,UAAU,MAAM,QAAQ,WAAW,CAAC;AAAA,MAC3D;AAAA,IACF,WAAW,QAAQ,MAAM;AACvB,gBAAU,4BAA4B,MAAM,IAAI;AAAA,IAClD;AAAA,EACF;AAEO,MAAM,yBAAyB,CAAC,WAA0D;AAC/F,UAAM,cAAc,kBAAkB,WAAW,SAAS,OAAO;AACjE,WAAO,aAAa,YAAY,gCAAgC,WAAW;AAAA,EAC7E;;;ACxCO,MAAM,sBAAsB,OAAO,sCAAsC;AAEzE,MAAM,WAA4B,CAAC,QAAgB,aAA8B,eAAmC;AAEzH,iBAAa,eAAe,qBAAqB,aAAa,OAAO,WAAW;AAAA,EAClF;AAEO,MAAM,oBAAoB,CAAC,WAA6C;AAC7E,UAAM,cAAc,kBAAkB,WAAW,SAAS,OAAO;AAEjE,WAAO,aAAa,YAAY,qBAAqB,WAAW;AAAA,EAClE;;;ACXO,MAAM,mBAAmB,OAAO,mCAAmC;AAEnE,MAAM,QAAyB,CAAC,QAAgB,aAA8B,eAAmC;AACtH,iBAAa,eAAe,kBAAkB,aAAa,OAAO,WAAW;AAAA,EAC/E;AAEO,MAAM,iBAAiB,CAAC,WAA6C;AAC1E,UAAM,cAAc,kBAAkB,WAAW,SAAS,OAAO;AACjE,WAAO,aAAa,YAAY,kBAAkB,WAAW;AAAA,EAC/D;;;ACEO,MAAM,qBAAqB,OAAO,4BAA4B;AAE9D,MAAM,QAAQ,CAAC,UAAkB,UAAwB,EAAE,WAAW,KAAK,MAAW;AAC3F,WAAO,CAAC,QAAgB,aAA8B,eAAoC;AACxF,YAAM,WAAW,CAAC,CAAC;AACnB,YAAM,cAAc,OAAO;AAG3B,UAAI,UAAU,aAAa,YAA6B,oBAAoB,WAAW;AACvF,UAAI,CAAC,SAAS;AACZ,kBAAU,CAAC;AACX,qBAAa,eAAe,oBAAoB,SAAS,WAAW;AAAA,MACtE;AACA,cAAQ,KAAK,EAAE,UAAU,SAAS,aAAa,SAAS,CAAC;AAEzD,UAAI,CAAC,UAAU;AAEb,eAAO,eAAe,QAAQ,aAAa;AAAA,UACzC,MAAuB;AACrB,kBAAM,OAAO,QAAQ,cAAc,SAAS,KAAK,aAAa,KAAK,aAAa;AAChF,mBAAO,KAAK,cAAc,QAAQ;AAAA,UACpC;AAAA,UACA,YAAY;AAAA,UACZ,cAAc;AAAA,QAChB,CAAC;AAAA,MACH;AAAA,IACF;AAAA,EACF;AAEO,MAAM,mBAAmB,CAAC,WAA6C;AAC5E,UAAM,cAAc,kBAAkB,WAAW,SAAS,OAAO;AACjE,WAAO,aAAa,YAAY,oBAAoB,WAAW;AAAA,EACjE;;;AChCO,MAAM,yBAAyB,OAAO,gCAAgC;AAEtE,MAAM,WAAW,CAAC,UAAkB,UAA2B,EAAE,WAAW,KAAK,MAAW;AACjG,WAAO,CAAC,QAAgB,aAA8B,eAAoC;AACxF,YAAM,WAAW,CAAC,CAAC;AACnB,YAAM,cAAc,OAAO;AAG3B,UAAI,UAAU,aAAa,YAAgC,wBAAwB,WAAW;AAC9F,UAAI,CAAC,SAAS;AACZ,kBAAU,CAAC;AACX,qBAAa,eAAe,wBAAwB,SAAS,WAAW;AAAA,MAC1E;AACA,cAAQ,KAAK,EAAE,UAAU,SAAS,aAAa,SAAS,CAAC;AAEzD,UAAI,CAAC,UAAU;AAEb,eAAO,eAAe,QAAQ,aAAa;AAAA,UACzC,MAAuB;AACrB,kBAAM,OAAO,QAAQ,cAAc,SAAS,KAAK,aAAa,KAAK,aAAa;AAChF,mBAAO,KAAK,iBAAiB,QAAQ;AAAA,UACvC;AAAA,UACA,YAAY;AAAA,UACZ,cAAc;AAAA,QAChB,CAAC;AAAA,MACH;AAAA,IACF;AAAA,EACF;AAEO,MAAM,sBAAsB,CAAC,WAAgD;AAClF,UAAM,cAAc,kBAAkB,WAAW,SAAS,OAAO;AACjE,WAAO,aAAa,YAAY,wBAAwB,WAAW;AAAA,EACrE;;;AC7BO,MAAM,kCAAkC,OAAO,yCAAyC;AAExF,MAAM,mBAAmB,CAAC,YAAsD;AACrF,WAAO,CAAC,QAAgB,aAA8B,eAAmC;AACvF,YAAM,cAAc,OAAO;AAE3B,UAAI,YAAY,aAAa,YAAwC,iCAAiC,WAAW;AACjH,UAAI,CAAC,WAAW;AACd,oBAAY,CAAC;AACb,qBAAa,eAAe,iCAAiC,WAAW,WAAW;AAAA,MACrF;AACA,gBAAU,KAAK,EAAE,SAAS,YAAY,CAAC;AAAA,IACzC;AAAA,EACF;AAEO,MAAM,8BAA8B,CAAC,WAAwD;AAClG,UAAM,cAAc,kBAAkB,WAAW,SAAS,OAAO;AACjE,WAAO,aAAa,YAAY,iCAAiC,WAAW;AAAA,EAC9E;;;AClBO,MAAM,qBAAqB,OAAO,qCAAqC;AAE9E,MAAM,mBAAmB,oBAAI,IAAG;AAEhC,MAAM,cAAc,CAAC,WAAmB,YAAmB;AACzD,QAAI,OAAO,eAAe,eAAgB,WAAmB,SAAS,GAAG;AACvE,uBAAiB,IAAK,WAAmB,SAAS,GAAG,OAAO;IAC9D;EACF;AAGA;IACE,CAAC,qBAAqB,GAAG;IACzB,CAAC,mBAAmB,MAAM;IAC1B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,mBAAmB,MAAM;IAC1B,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,mBAAmB,MAAM;IAC1B,CAAC,uBAAuB,UAAU;IAClC,CAAC,sBAAsB,SAAS;IAChC,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,kBAAkB,KAAK;IACxB,CAAC,oBAAoB,IAAI;IACzB,CAAC,oBAAoB,OAAO;IAC5B,CAAC,uBAAuB,UAAU;IAClC,CAAC,mBAAmB,MAAM;IAC1B,CAAC,iBAAiB,IAAI;IACtB,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,oBAAoB,KAAK;IAC1B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,iBAAiB,IAAI;IACtB,CAAC,mBAAmB,MAAM;IAC1B,CAAC,kBAAkB,KAAK;IACxB,CAAC,mBAAmB,MAAM;IAC1B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,kBAAkB,KAAK;IACxB,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,oBAAoB,IAAI;IACzB,CAAC,uBAAuB,UAAU;IAClC,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,wBAAwB,GAAG;IAC5B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,sBAAsB,SAAS;IAChC,CAAC,kBAAkB,KAAK;IACxB,CAAC,uBAAuB,UAAU;IAClC,CAAC,oBAAoB,YAAY;IACjC,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,mBAAmB,MAAM;IAC1B,CAAC,qBAAqB,QAAQ;IAC9B,CAAC,mBAAmB,MAAM;IAC1B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,2BAA2B,OAAO;IACnC,CAAC,wBAAwB,IAAI;IAC7B,CAAC,uBAAuB,UAAU;IAClC,CAAC,uBAAuB,UAAU;IAClC,CAAC,mBAAmB,MAAM;IAC1B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,uBAAuB,IAAI;IAC5B,CAAC,oBAAoB,OAAO;IAC5B,CAAC,oBAAoB,IAAI;IACzB,CAAC,oBAAoB,OAAO;IAC5B,CAAC,sBAAsB,IAAI;IAC3B,QAAQ,CAAC,CAAC,KAAK,GAAG,MAAM,YAAY,KAAK,GAAG,CAAC;AAExC,MAAM,gBACX,CAAC,aACD,CAAC,gBAAoB;AACnB,UAAM,SAAwB,OAAO,aAAa,WAAW,EAAE,SAAS,SAAQ,IAAK;AAGrF,QAAI,iBAAiB,OAAO;AAC5B,QAAI,CAAC,gBAAgB;AACnB,UAAI,QAAQ,OAAO,eAAe,WAAW;AAC7C,aAAO,SAAS,UAAU,eAAe,UAAU,SAAS,WAAW;AACrE,yBAAiB,iBAAiB,IAAI,KAAK;AAC3C,YAAI;AAAgB;AACpB,gBAAQ,OAAO,eAAe,KAAK;MACrC;IACF;AAGA,UAAM,sBAAsB,uBAAuB,WAAW;AAC9D,UAAM,yBAAyB,sBAAsB,MAAM,KAAK,oBAAoB,KAAI,CAAE,EAAE,OAAO,QAAM,OAAO,0BAA0B,IAAI,CAAA;AAC9I,UAAM,2BAA2B,CAAC,GAAG,oBAAI,IAAI,CAAC,GAAI,OAAO,sBAAsB,CAAA,GAAK,GAAG,sBAAsB,CAAC,CAAC;AAG/G,UAAM,WAAW,cAAe,YAAmB;MAIjD,WAAW,qBAAkB;AAC3B,eAAO;MACT;MAEA,eAAe,MAAW;AACxB,cAAM,GAAG,IAAI;AARP,aAAA,YAAqC;AACrC,aAAA,iBAAiB,oBAAI,QAAO;AAQlC,YAAI,OAAO,cAAc,QAAQ,CAAC,KAAK,YAAY;AACjD,eAAK,aAAa,EAAE,MAAM,OAAM,CAAE;QACpC;MACF;MAEQ,kBAAe;AAErB,cAAM,gBAAgB,iBAAiB,IAAI;AAC3C,YAAI,eAAe;AACjB,wBACG,OAAO,QAAM,GAAG,QAAQ,EACxB,QAAQ,QAAK;AACZ,kBAAM,OAAO,GAAG,QAAQ,cAAc,SAAS,KAAK,aAAa,KAAK,aAAa;AACnF,kBAAM,UAAU,KAAK,cAAc,GAAG,QAAQ;AAI9C,gBAAI,SAAS;AACX,kBAAI,QAAQ,KAAK,eAAe,IAAI,OAAO;AAC3C,kBAAI,CAAC,OAAO;AACV,wBAAQ,oBAAI,IAAG;AACf,qBAAK,eAAe,IAAI,SAAS,KAAK;cACxC;AACA,kBAAI,CAAC,MAAM,IAAI,GAAG,WAAW,GAAG;AAC7B,qBAAa,GAAG,WAAW,EAAE,OAAO;AACrC,sBAAM,IAAI,GAAG,WAAW;cAC1B;YACF;UACF,CAAC;QACL;AAEA,cAAM,mBAAmB,oBAAoB,IAAI;AACjD,YAAI,kBAAkB;AACpB,2BACG,OAAO,QAAM,GAAG,QAAQ,EACxB,QAAQ,QAAK;AACZ,kBAAM,OAAO,GAAG,QAAQ,cAAc,SAAS,KAAK,aAAa,KAAK,aAAa;AACnF,kBAAM,WAAW,KAAK,iBAAiB,GAAG,QAAQ;AAKjD,iBAAa,GAAG,WAAW,EAAE,QAAQ;UACxC,CAAC;QACL;AAGA,cAAM,iBAAiB,4BAA4B,IAAI;AACvD,YAAI,gBAAgB;AAClB,yBAAe,QAAQ,QAAK;AAC1B,kBAAM,EAAE,UAAU,WAAW,WAAW,GAAG,QAAO,IAAK,GAAG;AAC1D,kBAAM,OAAO,cAAc,SAAS,KAAK,aAAa,KAAK,aAAa;AACxE,kBAAM,iBAAiB,WAAW,KAAK,iBAAiB,QAAQ,IAAI,CAAC,IAAsB;AAE3F,2BAAe,QAAQ,mBAAgB;AACrC,kBAAI,eAAe;AACjB,oBAAI,QAAQ,KAAK,eAAe,IAAI,aAAa;AACjD,oBAAI,CAAC,OAAO;AACV,0BAAQ,oBAAI,IAAG;AACf,uBAAK,eAAe,IAAI,eAAe,KAAK;gBAC9C;AAGA,sBAAM,WAAW,SAAS,OAAO,GAAG,WAAW,CAAC,IAAI,SAAS;AAC7D,oBAAI,CAAC,MAAM,IAAI,QAAQ,GAAG;AACxB,gCAAc,iBACZ,WACA,WAAQ;AACL,yBAAa,GAAG,WAAW,EAAE,KAAK;kBACrC,GACA,OAAO;AAET,wBAAM,IAAI,QAAQ;gBACpB;cACF;YACF,CAAC;UACH,CAAC;QACH;MACF;MAEA,uBAAoB;AAClB,YAAI,KAAK,WAAW;AAClB,eAAK,UAAU,WAAU;QAC3B;AACA,YAAI,MAAM,sBAAsB;AAC9B,gBAAM,qBAAoB;QAC5B;MACF;MAEA,wBAAqB;AAEnB,YAAI,MAAM,uBAAuB;AAC/B,gBAAM,sBAAqB;QAC7B;MACF;MAEA,kBAAe;AAEb,YAAI,MAAM,iBAAiB;AACzB,gBAAM,gBAAe;QACvB;MACF;MAEA,MAAM,oBAAiB;AACrB,cAAM,iBAAiB,kBAAkB,IAAI;AAC7C,cAAM,cAAc,eAAe,IAAI;AAEvC,cAAMC,YAAW,iBAAiB,MAAO,KAAa,cAAc,EAAC,IAAK;AAC1E,cAAMC,SAAQ,cAAc,MAAO,KAAa,WAAW,EAAC,IAAK;AAGjE,YAAI,CAAC,KAAK,cAAcD,cAAa,UAAaC,WAAU,QAAW;AACrE;QACF;AAEA,YAAI,UAAU;AACd,YAAIA,WAAU,UAAaA,OAAM,KAAI,EAAG,SAAS,GAAG;AAClD,qBAAW,UAAUA,MAAK;QAC5B;AAEA,YAAID,cAAa,QAAW;AAC1B,qBAAWA;QACb,WAAW,CAAC,KAAK,YAAY;AAC3B,qBAAW,KAAK;QAClB;AAEA,YAAI,KAAK,YAAY;AACnB,eAAK,WAAW,YAAY;QAC9B,OAAO;AACL,eAAK,YAAY;QACnB;AAGC,aAAa,gBAAe;AAG7B,aAAK,YAAY,IAAI,iBAAiB,MAAK;AACxC,eAAa,gBAAe;QAC/B,CAAC;AACD,cAAM,SAAS,KAAK,cAAc;AAClC,aAAK,UAAU,QAAQ,QAAQ,EAAE,WAAW,MAAM,SAAS,KAAI,CAAE;AAEjE,YAAI,MAAM,mBAAmB;AAC3B,gBAAM,MAAM,kBAAiB;QAC/B;MACF;;MAGA,yBAAyB,MAAc,UAAyB,UAAuB;AAErF,YAAI,MAAM,0BAA0B;AAClC,gBAAM,yBAAyB,MAAM,UAAU,QAAQ;QACzD;AAGA,cAAM,aAAa,qBAAqB,IAAI,IAAI;AAChD,YAAI,cAAc,MAAM,QAAQ,UAAU,GAAG;AAC3C,qBAAW,QAAQ,SAAM;AACvB,gBAAI,OAAQ,KAAa,GAAG,MAAM,YAAY;AAC3C,mBAAa,GAAG,EAAE,UAAU,UAAU,IAAI;YAC7C;UACF,CAAC;QACH;AAGA,cAAM,qBAAqB,qBAAqB,IAAI,0BAA0B;AAC9E,YAAI,sBAAsB,MAAM,QAAQ,kBAAkB,GAAG;AAC3D,6BAAmB,QAAQ,SAAM;AAC/B,gBAAI,OAAQ,KAAa,GAAG,MAAM,YAAY;AAC3C,mBAAa,GAAG,EAAE,UAAU,UAAU,IAAI;YAC7C;UACF,CAAC;QACH;MACF;;AAIF,UAAM,WAAW,OAAO,0BAA0B,OAAO,mBAAmB,cAAc,iBAAiB;AAC3G,QAAI,YAAY,CAAC,SAAS,IAAI,OAAO,OAAO,GAAG;AAC7C,YAAM,UAAU,iBAAiB,EAAE,SAAS,eAAc,IAAK;AAC/D,eAAS,OAAO,OAAO,SAAS,UAAiB,OAAO;IAC1D;AAGA,iBAAa,eAAe,oBAAoB,QAAQ,QAAQ;AAEhE,WAAO;EACT;AAEK,MAAM,mBAAmB,CAAC,WAA0C;AACzE,UAAM,cAAc,kBAAkB,WAAW,SAAS,OAAO;AACjE,WAAO,aAAa,YAAY,oBAAoB,WAAW;EACjE;;;ACnTO,MAAe,qBAAf,cAA0C,YAAY;AAAA,IAK3D,cAAc;AACZ,YAAM;AALR,WAAU,kBAA0B,CAAC;AACrC,WAAU,SAAiB;AAC3B,WAAU,cAAsB;AAAA,IAIhC;AAAA,IAEU,WAAW;AACnB,WAAK,SAAS,KAAK,aAAa,IAAI,KAAK;AACzC,WAAK,cAAc,KAAK,aAAa,UAAU,KAAK;AACpD,YAAM,UAAU,KAAK,YAAY,eAAe,UAAU;AAC1D,UAAI,SAAS;AACX,aAAK,kBAAkB,QAAQ,cAAc,EAAE,IAAI,OAAK,EAAE,UAAU,IAAI,CAAC;AAAA,MAC3E;AAAA,IACF;AAAA,IAEU,eAAe,KAAU,MAAc;AAC/C,UAAI,SAAS,KAAK,OAAQ,QAAO;AACjC,UAAI,KAAK,WAAW,GAAG,KAAK,MAAM,GAAG,GAAG;AACtC,eAAO,KACJ,MAAM,GAAG,EACT,MAAM,CAAC,EACP,OAAO,CAAC,KAAK,SAAS,OAAO,IAAI,IAAI,GAAG,GAAG;AAAA,MAChD;AACA,aAAO;AAAA,IACT;AAAA,IAEU,UAAU,MAAY,MAAW,OAAgB;AACzD,YAAM,UAA+B,CAAC;AACtC,UAAI,UAAU,QAAW;AACvB,gBAAQ,KAAK,WAAW,IAAI,MAAM,SAAS;AAAA,MAC7C;AAEA,YAAM,OAAO,CAAC,MAAY;AACxB,YAAI,EAAE,aAAa,KAAK,WAAW;AACjC,cAAI,CAAE,EAAU,UAAW,CAAC,EAAU,YAAY,EAAE;AACpD,cAAI,OAAQ,EAAU;AAEtB,iBAAO,KAAK,QAAQ,cAAc,CAAC,OAAe,SAAiB;AACjE,mBAAO,KAAK,KAAK;AACjB,gBAAI,QAAQ,IAAI,MAAM,OAAW,QAAO,QAAQ,IAAI;AACpD,kBAAM,MAAM,KAAK,eAAe,MAAM,IAAI;AAC1C,mBAAO,QAAQ,SAAY,MAAM;AAAA,UACnC,CAAC;AACD,cAAI,EAAE,gBAAgB,KAAM,GAAE,cAAc;AAAA,QAC9C,WAAW,EAAE,aAAa,KAAK,cAAc;AAC3C,gBAAM,KAAK;AACX,gBAAM,KAAK,GAAG,UAAU,EAAE,QAAQ,OAAK;AACrC,gBAAI,CAAE,EAAU,UAAW,CAAC,EAAU,YAAY,EAAE;AACpD,gBAAI,MAAO,EAAU;AAErB,kBAAM,IAAI,QAAQ,cAAc,CAAC,OAAe,SAAiB;AAC/D,qBAAO,KAAK,KAAK;AACjB,kBAAI,QAAQ,IAAI,MAAM,OAAW,QAAO,QAAQ,IAAI;AACpD,oBAAM,IAAI,KAAK,eAAe,MAAM,IAAI;AACxC,qBAAO,MAAM,SAAY,IAAI;AAAA,YAC/B,CAAC;AACD,gBAAI,EAAE,UAAU,IAAK,GAAE,QAAQ;AAAA,UACjC,CAAC;AACD,aAAG,WAAW,QAAQ,IAAI;AAAA,QAC5B;AAAA,MACF;AACA,WAAK,IAAI;AAAA,IACX;AAAA;AAAA;AAAA;AAAA,IAKU,oBAAoB,QAAa,UAAsB,eAAmD;AAClH,aAAO,IAAI,MAAM,QAAQ;AAAA,QACvB,KAAK,CAAC,GAAG,MAAM,QAAQ;AACrB,gBAAM,UAAU,CAAC,MAAM,OAAO,IAAI,CAAC;AACnC,YAAE,IAAI,IAAI;AACV,cAAI,WAAW,eAAe;AAC5B,0BAAc,OAAO,IAAI,GAAG,GAAG;AAAA,UACjC,OAAO;AACL,qBAAS;AAAA,UACX;AACA,iBAAO;AAAA,QACT;AAAA,QACA,gBAAgB,CAAC,GAAG,SAAS;AAC3B,iBAAO,EAAE,IAAI;AACb,mBAAS;AACT,iBAAO;AAAA,QACT;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;;;;;;;;;;;;ACxFO,MAAM,WAAN,MAAME,kBAAiB,mBAAkB;IAG9C,cAAA;AACE,YAAK;AAHC,WAAA,SAAgB,CAAA;IAIxB;IAEA,IAAI,MAAM,KAAU;AAClB,UAAI,CAAC,MAAM,QAAQ,GAAG;AAAG,cAAM,CAAA;AAC/B,WAAK,SAAS,KAAK,oBACjB,KACA,MAAM,KAAK,UAAS,GACpB,CAAC,KAAK,MAAM,KAAK,gBAAgB,KAAK,CAAC,CAAC;AAE1C,WAAK,UAAS;IAChB;IAEA,IAAI,QAAK;AACP,aAAO,KAAK;IACd;IAGA,SAAM;AACJ,aAAO;IACT;IAGA,iBAAc;AACZ,aAAO;IACT;IAEA,oBAAiB;AACf,WAAK,SAAQ;AACb,WAAK,UAAS;IAChB;IAEO,gBAAgB,OAAe,UAAa;AACjD,YAAM,UAAU,KAAK,iBAAiB,cAAc,KAAK,IAAI;AAC7D,UAAI,QAAQ,SAAS,GAAG;AACtB,gBAAQ,QAAQ,YAAU,KAAK,UAAU,QAAQ,UAAU,KAAK,CAAC;MACnE,OAAO;AACL,aAAK,UAAU,UAAU,KAAK;MAChC;IACF;IAEQ,UAAU,MAAW,OAAa;AACxC,UAAI,CAAC,KAAK,cAAc,KAAK,gBAAgB,WAAW;AAAG;AAE3D,YAAM,WAAW,OAAO,KAAK;AAC7B,UAAI,CAAC,KAAK,WAAW,cAAc,cAAc,QAAQ,IAAI,GAAG;AAC9D,cAAM,OAAO,SAAS,cAAc,MAAM;AAC1C,aAAK,OAAO;AACZ,aAAK,WAAW,YAAY,IAAI;MAClC;AAEA,WAAK,gBAAgB,QAAQ,aAAU;AACrC,cAAM,QAAQ,QAAQ,UAAU,IAAI;AACpC,YAAI,MAAM,aAAa,KAAK,cAAc;AACvC,gBAAsB,aAAa,QAAQ,QAAQ;AACnD,gBAAsB,MAAM,UAAU;QACzC,WAAW,MAAM,aAAa,KAAK,WAAW;AAC5C,cAAI,MAAM,aAAa,KAAI,EAAG,WAAW;AAAG;AAC5C,gBAAM,OAAO,SAAS,cAAc,MAAM;AAC1C,eAAK,aAAa,QAAQ,QAAQ;AAClC,eAAK,YAAY,KAAK;AACtB,eAAK,YAAY,IAAI;AACrB,eAAK,UAAU,MAAM,MAAM,KAAK;AAChC;QACF;AACA,aAAK,YAAY,KAAK;AACtB,aAAK,UAAU,OAAO,MAAM,KAAK;MACnC,CAAC;IACH;IAEQ,YAAS;AACf,UAAI,KAAK,gBAAgB,WAAW,KAAK,CAAC,KAAK;AAAY;AAE3D,YAAM,KAAK,KAAK,QAAQ,EAAE,QAAQ,OAAI;AACpC,cAAM,OAAO,EAAE,aAAa,MAAM;AAClC,YAAI,QAAQ,KAAK,WAAW,MAAM,GAAG;AACnC,YAAE,OAAM;QACV;MACF,CAAC;AAED,YAAM,KAAK,KAAK,WAAW,iBAAiB,MAAM,CAAC,EAAE,QAAQ,OAAI;AAC/D,YAAI,EAAE,OAAO;AAAY,YAAE,OAAM;MACnC,CAAC;AAED,WAAK,OAAO,QAAQ,CAAC,MAAM,UAAU,KAAK,UAAU,MAAM,KAAK,CAAC;IAClE;;AAnEA,aAAA;IADC;;;;;AAMD,aAAA;IADC;;;;;AA1BU,aAAQ,WAAA;IADpB,cAAc,EAAE,SAAS,cAAc,WAAW,KAAI,CAAE;;KAC5C,QAAQ;;;;;;;;;;;;ACAd,MAAM,QAAN,MAAMC,eAAc,mBAAkB;IAI3C,cAAA;AACE,YAAK;AAJC,WAAA,SAAc;AACd,WAAA,YAAqC;IAI7C;IAEA,IAAI,MAAM,KAAQ;AAChB,WAAK,SAAS;AACd,WAAK,OAAM;IACb;IAEA,IAAI,QAAK;AACP,aAAO,KAAK;IACd;IAGA,SAAM;AACJ,aAAO;IACT;IAGA,iBAAc;AACZ,aAAO;IACT;IAEA,oBAAiB;AACf,WAAK,SAAQ;AACb,WAAK,YAAY,IAAI,iBAAiB,MAAM,KAAK,OAAM,CAAE;AACzD,WAAK,UAAU,QAAQ,MAAM,EAAE,YAAY,KAAI,CAAE;AACjD,WAAK,OAAM;IACb;IAEA,uBAAoB;AAClB,WAAK,WAAW,WAAU;IAC5B;IAEQ,SAAM;AACZ,UAAI,CAAC,KAAK;AAAY;AAEtB,YAAM,YAAY,KAAK,aAAa,OAAO;AAC3C,UAAI,cAAc,QAAQ,UAAU,SAAS,IAAI;AAAG;AAEpD,UAAI,eAAe,cAAc,OAAO,YAAY,KAAK;AACzD,UAAI,WAAW,CAAC,CAAC;AACjB,UAAI,OAAO,iBAAiB,UAAU;AACpC,YAAI,iBAAiB,WAAW,iBAAiB,OAAO,iBAAiB;AAAI,qBAAW;aACnF;AACH,cAAI;AACF,uBAAW,CAAC,CAAC,IAAI,SAAS,UAAU,YAAY,EAAE,EAAC;UACrD,SAAS,GAAG;AACV,uBAAW;UACb;QACF;MACF;AAEA,YAAM,KAAK,KAAK,QAAQ,EAAE,QAAQ,OAAI;AACpC,YAAI,EAAE,aAAa,MAAM,MAAM,cAAc;AAC3C,YAAE,OAAM;QACV;MACF,CAAC;AAED,YAAM,eAAe,KAAK,WAAW,cAAc,yBAAyB;AAC5E,UAAI;AAAc,qBAAa,OAAM;AAErC,UAAI,YAAY,KAAK,gBAAgB,SAAS,GAAG;AAC/C,cAAM,cAAc,SAAS,cAAc,MAAM;AACjD,oBAAY,OAAO;AACnB,aAAK,WAAW,YAAY,WAAW;AAEvC,aAAK,gBAAgB,QAAQ,aAAU;AACrC,gBAAM,QAAQ,QAAQ,UAAU,IAAI;AACpC,cAAI,MAAM,aAAa,KAAK,cAAc;AACvC,kBAAsB,aAAa,QAAQ,YAAY;UAC1D,WAAW,MAAM,aAAa,KAAK,WAAW;AAC5C,gBAAI,MAAM,aAAa,KAAI,EAAG,WAAW;AAAG;AAC5C,kBAAM,OAAO,SAAS,cAAc,MAAM;AAC1C,iBAAK,aAAa,QAAQ,YAAY;AACtC,iBAAK,YAAY,KAAK;AACtB,iBAAK,YAAY,IAAI;AACrB;UACF;AACA,eAAK,YAAY,KAAK;QACxB,CAAC;MACH;IACF;;AApEA,EAAAC,YAAA;IADC;;;;;AAMD,EAAAA,YAAA;IADC;;;;;AAtBU,UAAKA,YAAA;IADjB,cAAc,EAAE,SAAS,UAAU,WAAW,KAAI,CAAE;;KACxC,KAAK;;;;;;;;;;;;ACDX,MAAM,YAAN,MAAMC,mBAAkB,YAAW;IAAnC,cAAA;;AACG,WAAA,YAAqC;AACrC,WAAA,SAAc;IA6ExB;IA3EE,IAAI,MAAM,KAAQ;AAChB,WAAK,SAAS;AACd,WAAK,SAAQ;IACf;IAEA,IAAI,QAAK;AACP,aAAO,KAAK;IACd;IAGA,SAAM;AACJ,aAAO;IACT;IAGA,SAAM;AACJ,aAAO;IACT;IAEA,oBAAiB;AACf,WAAK,YAAY,IAAI,iBAAiB,MAAM,KAAK,SAAQ,CAAE;AAC3D,WAAK,UAAU,QAAQ,MAAM,EAAE,YAAY,MAAM,SAAS,MAAM,WAAW,KAAI,CAAE;AACjF,WAAK,SAAQ;IACf;IAEA,uBAAoB;AAClB,WAAK,WAAW,WAAU;IAC5B;IAEQ,WAAQ;AACd,YAAM,QAAQ,MAAM,KAAK,KAAK,iBAAiB,UAAU,CAAC;AAC1D,YAAM,QAAQ,KAAK,cAAc,WAAW;AAC5C,UAAI,UAAU;AAGd,YAAM,cAAc,KAAK,aAAa,OAAO,KAAK,KAAK;AAEvD,YAAM,QAAQ,UAAO;AACnB,YAAI,SAAS;AACV,eAAqB,MAAM,UAAU;AACtC;QACF;AAEA,cAAM,WAAW,KAAK,aAAa,MAAM;AACzC,YAAI,aAAa;AAAM;AACvB,YAAI,SAAS,SAAS,IAAI;AAAG;AAE7B,YAAI,iBAAiB;AAErB,YAAI,gBAAgB,UAAa,gBAAgB,MAAM;AAErD,2BAAiB,OAAO,WAAW,MAAM,OAAO,QAAQ;QAC1D,OAAO;AAEL,cAAI;AACF,gBAAI,aAAa;AAAQ,+BAAiB;qBACjC,aAAa;AAAS,+BAAiB;;AAC3C,+BAAiB,CAAC,CAAC,IAAI,SAAS,UAAU,QAAQ,EAAE,EAAC;UAC5D,SAAS,GAAG;AACV,6BAAiB;UACnB;QACF;AAEA,YAAI,gBAAgB;AACjB,eAAqB,MAAM,UAAU;AACtC,oBAAU;QACZ,OAAO;AACJ,eAAqB,MAAM,UAAU;QACxC;MACF,CAAC;AAED,UAAI,OAAO;AACR,cAAsB,MAAM,UAAU,UAAU,SAAS;MAC5D;IACF;;AAhEA,EAAAC,YAAA;IADC;;;;;AAMD,EAAAA,YAAA;IADC;;;;;AAlBU,cAASA,YAAA;IADrB,cAAc,EAAE,SAAS,cAAc,WAAW,KAAI,CAAE;KAC5C,SAAS;;;;;;;;;;;;ACAf,MAAM,UAAN,MAAMC,iBAAgB,YAAW;IAEtC,SAAM;AACJ,aAAO;IACT;IAGA,SAAM;AACJ,aAAO;IACT;;AAPA,EAAAC,YAAA;IADC;;;;;AAMD,EAAAA,YAAA;IADC;;;;;AANU,YAAOA,YAAA;IADnB,cAAc,EAAE,SAAS,YAAY,WAAW,KAAI,CAAE;KAC1C,OAAO;;;;;;;;;;;;ACAb,MAAM,WAAN,MAAMC,kBAAiB,YAAW;IAEvC,SAAM;AACJ,aAAO;IACT;IAGA,SAAM;AACJ,aAAO;IACT;;AAPA,EAAAC,YAAA;IADC;;;;;AAMD,EAAAA,YAAA;IADC;;;;;AANU,aAAQA,YAAA;IADpB,cAAc,EAAE,SAAS,aAAa,WAAW,KAAI,CAAE;KAC3C,QAAQ;;;;;;;;;;;;ACCd,MAAM,YAAN,MAAMC,mBAAkB,mBAAkB;IAI/C,cAAA;AACE,YAAK;AAJC,WAAA,SAAc,CAAA;AACd,WAAA,iBAAyB,CAAA;IAIjC;IAEA,IAAI,MAAM,KAAQ;AAChB,UAAI,OAAO,QAAQ,YAAY,QAAQ;AAAM,cAAM,CAAA;AACnD,WAAK,SAAS,KAAK,oBAAoB,KAAK,MAAM,KAAK,SAAQ,CAAE;AACjE,WAAK,OAAM;IACb;IAEA,IAAI,QAAK;AACP,aAAO,KAAK;IACd;IAGA,SAAM;AACJ,aAAO;IACT;IAGA,iBAAc;AACZ,aAAO;IACT;IAEA,oBAAiB;AACf,WAAK,SAAQ;AACb,WAAK,OAAM;IACb;IAEQ,WAAQ;AACd,WAAK,eAAe,QAAQ,UAAO;AACjC,aAAK,UAAU,MAAM,KAAK,MAAM;MAClC,CAAC;IACH;IAEQ,SAAM;AACZ,UAAI,CAAC,KAAK,cAAc,KAAK,gBAAgB,WAAW;AAAG;AAE3D,WAAK,eAAe,QAAQ,OAAI;AAC9B,YAAI,EAAE,kBAAkB;AAAM,eAAK,YAAY,CAAC;MAClD,CAAC;AACD,WAAK,iBAAiB,CAAA;AAEtB,UAAI,OAAO,KAAK,WAAW,cAAc,0BAA0B;AACnE,UAAI,CAAC,MAAM;AACT,eAAO,SAAS,cAAc,MAAM;AACnC,aAAyB,OAAO;AACjC,aAAK,WAAW,YAAY,IAAI;MAClC;AAEA,WAAK,gBAAgB,QAAQ,aAAU;AACrC,cAAM,QAAQ,QAAQ,UAAU,IAAI;AACpC,YAAI,MAAM,aAAa,KAAK,cAAc;AACvC,gBAAsB,aAAa,QAAQ,aAAa;QAC3D,WAAW,MAAM,aAAa,KAAK,WAAW;AAC5C,cAAI,MAAM,aAAa,KAAI,EAAG,WAAW;AAAG;AAC5C,gBAAM,OAAO,SAAS,cAAc,MAAM;AAC1C,eAAK,aAAa,QAAQ,aAAa;AACvC,eAAK,YAAY,KAAK;AACtB,eAAK,YAAY,IAAI;AACrB,eAAK,eAAe,KAAK,IAAI;AAC7B,eAAK,UAAU,MAAM,KAAK,MAAM;AAChC;QACF;AACA,aAAK,YAAY,KAAK;AACtB,aAAK,eAAe,KAAK,KAAK;AAC9B,aAAK,UAAU,OAAO,KAAK,MAAM;MACnC,CAAC;IACH;;AArDA,EAAAC,YAAA;IADC;;;;;AAMD,EAAAA,YAAA;IADC;;;;;AAvBU,cAASA,YAAA;IADrB,cAAc,EAAE,SAAS,cAAc,WAAW,KAAI,CAAE;;KAC5C,SAAS;",
6
+ "names": ["ReflectUtils", "template", "style", "SwcForOf", "SwcIf", "__decorate", "SwcChoose", "__decorate", "SwcWhen", "__decorate", "SwcOther", "__decorate", "SwcObject", "__decorate"]
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dooboostore/simple-web-component",
3
- "version": "1.0.0",
3
+ "version": "1.0.2",
4
4
  "license": "MIT",
5
5
  "type": "module",
6
6
  "main": "./dist/cjs/index.js",
@@ -0,0 +1,35 @@
1
+ import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';
2
+
3
+ export interface AddEventListenerOptions extends EventListenerOptions {
4
+ selector?: string;
5
+ eventName: string;
6
+ useShadow?: boolean;
7
+ capture?: boolean;
8
+ once?: boolean;
9
+ passive?: boolean;
10
+ }
11
+
12
+ export interface AddEventListenerMetadata {
13
+ options: AddEventListenerOptions;
14
+ propertyKey: string | symbol;
15
+ }
16
+
17
+ export const ADD_EVENT_LISTENER_METADATA_KEY = Symbol('simple-web-component:add-event-listener');
18
+
19
+ export const addEventListener = (options: AddEventListenerOptions): MethodDecorator => {
20
+ return (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {
21
+ const constructor = target.constructor;
22
+
23
+ let listeners = ReflectUtils.getMetadata<AddEventListenerMetadata[]>(ADD_EVENT_LISTENER_METADATA_KEY, constructor);
24
+ if (!listeners) {
25
+ listeners = [];
26
+ ReflectUtils.defineMetadata(ADD_EVENT_LISTENER_METADATA_KEY, listeners, constructor);
27
+ }
28
+ listeners.push({ options, propertyKey });
29
+ };
30
+ };
31
+
32
+ export const getAddEventListenerMetadata = (target: any): AddEventListenerMetadata[] | undefined => {
33
+ const constructor = target instanceof Function ? target : target.constructor;
34
+ return ReflectUtils.getMetadata(ADD_EVENT_LISTENER_METADATA_KEY, constructor);
35
+ };
@@ -1,18 +1,41 @@
1
1
  import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';
2
2
 
3
3
  export const ATTRIBUTE_CHANGED_METADATA_KEY = Symbol('simple-web-component:attribute-changed');
4
+ export const ATTRIBUTE_CHANGED_WILDCARD = '*';
4
5
 
5
- export const attributeChanged = (attributeName: string): MethodDecorator => {
6
- return (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {
6
+ export function attributeChanged(attributeName: string | string[]): MethodDecorator;
7
+ export function attributeChanged(target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor): void;
8
+ export function attributeChanged(arg1: string | string[] | Object, arg2?: string | symbol, arg3?: PropertyDescriptor): MethodDecorator | void {
9
+ const decorator = (attributeName: string, target: Object, propertyKey: string | symbol) => {
7
10
  const constructor = target.constructor;
8
- let meta = ReflectUtils.getMetadata<Map<string, string | symbol>>(ATTRIBUTE_CHANGED_METADATA_KEY, constructor);
11
+ let meta = ReflectUtils.getMetadata<Map<string, (string | symbol)[]>>(ATTRIBUTE_CHANGED_METADATA_KEY, constructor);
9
12
  if (!meta) {
10
- meta = new Map<string, string | symbol>();
13
+ meta = new Map<string, (string | symbol)[]>();
11
14
  ReflectUtils.defineMetadata(ATTRIBUTE_CHANGED_METADATA_KEY, meta, constructor);
12
15
  }
13
- meta.set(attributeName, propertyKey);
16
+
17
+ let methods = meta.get(attributeName);
18
+ if (!methods) {
19
+ methods = [];
20
+ meta.set(attributeName, methods);
21
+ }
22
+ if (!methods.includes(propertyKey)) {
23
+ methods.push(propertyKey);
24
+ }
14
25
  };
15
- };
26
+
27
+ if (typeof arg1 === 'string') {
28
+ return (target: Object, propertyKey: string | symbol) => {
29
+ decorator(arg1, target, propertyKey);
30
+ };
31
+ } else if (Array.isArray(arg1)) {
32
+ return (target: Object, propertyKey: string | symbol) => {
33
+ arg1.forEach(name => decorator(name, target, propertyKey));
34
+ };
35
+ } else if (arg1 && arg2) {
36
+ decorator(ATTRIBUTE_CHANGED_WILDCARD, arg1, arg2);
37
+ }
38
+ }
16
39
 
17
40
  export const getAttributeChangedMap = (target: any): Map<string, string | symbol> | undefined => {
18
41
  const constructor = target instanceof Function ? target : target.constructor;
@@ -1,7 +1,10 @@
1
1
  import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';
2
- import { getAttributeChangedMap } from './attributeChanged';
2
+ import { getAttributeChangedMap, ATTRIBUTE_CHANGED_WILDCARD } from './attributeChanged';
3
3
  import { getTemplateMethod } from './template';
4
4
  import { getStyleMethod } from './style';
5
+ import { getQueryMetadata } from './query';
6
+ import { getQueryAllMetadata } from './queryAll';
7
+ import { getAddEventListenerMetadata } from './addEventListener';
5
8
 
6
9
  export interface ElementConfig {
7
10
  tagName: string;
@@ -81,7 +84,7 @@ const registerTag = (className: string, tagName: string) => {
81
84
  ['HTMLHeadingElement', 'h1']
82
85
  ].forEach(([cls, tag]) => registerTag(cls, tag));
83
86
 
84
- export const element =
87
+ export const elementDefind =
85
88
  (inConfig: ElementConfig | string): ClassDecorator =>
86
89
  (constructor: any) => {
87
90
  const config: ElementConfig = typeof inConfig === 'string' ? { tagName: inConfig } : inConfig;
@@ -99,11 +102,14 @@ export const element =
99
102
 
100
103
  // 2. Automatically collect observed attributes from @attributeChanged decorators
101
104
  const attributeChangedMap = getAttributeChangedMap(constructor);
102
- const observedFromDecorators = attributeChangedMap ? Array.from(attributeChangedMap.keys()) : [];
105
+ const observedFromDecorators = attributeChangedMap ? Array.from(attributeChangedMap.keys()).filter(it => it !== ATTRIBUTE_CHANGED_WILDCARD) : [];
103
106
  const mergedObservedAttributes = [...new Set([...(config.observedAttributes ?? []), ...observedFromDecorators])];
104
107
 
105
108
  // 3. Create a new anonymous class that extends the original constructor
106
109
  const NewClass = class extends (constructor as any) {
110
+ private _observer: MutationObserver | null = null;
111
+ private _boundElements = new WeakMap<Element, Set<string | symbol>>();
112
+
107
113
  static get observedAttributes() {
108
114
  return mergedObservedAttributes;
109
115
  }
@@ -115,29 +121,105 @@ export const element =
115
121
  }
116
122
  }
117
123
 
124
+ private _syncDecorators() {
125
+ // 5. Execute @query and @queryAll methods
126
+ const queryMetadata = getQueryMetadata(this);
127
+ if (queryMetadata) {
128
+ queryMetadata
129
+ .filter(it => it.isMethod)
130
+ .forEach(it => {
131
+ const root = it.options.useShadow !== false && this.shadowRoot ? this.shadowRoot : this;
132
+ const element = root.querySelector(it.selector);
133
+
134
+ // 중복 호출 방지: 해당 selector로 찾은 요소가 이전과 다를 때만 호출하거나,
135
+ // 또는 매번 호출할지 결정해야 함. 여기서는 새로운 요소가 발견되면 호출하는 방식으로 처리.
136
+ if (element) {
137
+ let bound = this._boundElements.get(element);
138
+ if (!bound) {
139
+ bound = new Set();
140
+ this._boundElements.set(element, bound);
141
+ }
142
+ if (!bound.has(it.propertyKey)) {
143
+ (this as any)[it.propertyKey](element);
144
+ bound.add(it.propertyKey);
145
+ }
146
+ }
147
+ });
148
+ }
149
+
150
+ const queryAllMetadata = getQueryAllMetadata(this);
151
+ if (queryAllMetadata) {
152
+ queryAllMetadata
153
+ .filter(it => it.isMethod)
154
+ .forEach(it => {
155
+ const root = it.options.useShadow !== false && this.shadowRoot ? this.shadowRoot : this;
156
+ const elements = root.querySelectorAll(it.selector);
157
+
158
+ // queryAll은 목록이 바뀔 수 있으므로 일단 호출하되,
159
+ // 내부 로직은 사용자에게 맡기거나 좀 더 정교한 비교가 필요할 수 있음.
160
+ // 여기서는 단순하게 호출만 다시 함. (사용자가 요청한 '다시 호출' 반영)
161
+ (this as any)[it.propertyKey](elements);
162
+ });
163
+ }
164
+
165
+ // 6. Register @addEventListener methods
166
+ const eventListeners = getAddEventListenerMetadata(this);
167
+ if (eventListeners) {
168
+ eventListeners.forEach(it => {
169
+ const { selector, eventName, useShadow, ...options } = it.options;
170
+ const root = useShadow !== false && this.shadowRoot ? this.shadowRoot : this;
171
+ const targetElements = selector ? root.querySelectorAll(selector) : [this as any as Element];
172
+
173
+ targetElements.forEach(targetElement => {
174
+ if (targetElement) {
175
+ let bound = this._boundElements.get(targetElement);
176
+ if (!bound) {
177
+ bound = new Set();
178
+ this._boundElements.set(targetElement, bound);
179
+ }
180
+
181
+ // 중복 바인딩 방지: (요소, 이벤트, 메서드) 조합 확인
182
+ const eventKey = `event:${String(it.propertyKey)}:${eventName}`;
183
+ if (!bound.has(eventKey)) {
184
+ targetElement.addEventListener(
185
+ eventName,
186
+ event => {
187
+ (this as any)[it.propertyKey](event);
188
+ },
189
+ options
190
+ );
191
+ bound.add(eventKey);
192
+ }
193
+ }
194
+ });
195
+ });
196
+ }
197
+ }
198
+
118
199
  disconnectedCallback() {
200
+ if (this._observer) {
201
+ this._observer.disconnect();
202
+ }
119
203
  if (super.disconnectedCallback) {
120
204
  super.disconnectedCallback();
121
205
  }
122
206
  }
123
207
 
124
208
  connectedMoveCallback() {
209
+ //default logic...
125
210
  if (super.connectedMoveCallback) {
126
211
  super.connectedMoveCallback();
127
212
  }
128
213
  }
129
214
 
130
215
  adoptedCallback() {
216
+ //default logic...
131
217
  if (super.adoptedCallback) {
132
218
  super.adoptedCallback();
133
219
  }
134
220
  }
135
221
 
136
222
  async connectedCallback() {
137
- if (super.connectedCallback) {
138
- await super.connectedCallback();
139
- }
140
-
141
223
  const templateMethod = getTemplateMethod(this);
142
224
  const styleMethod = getStyleMethod(this);
143
225
 
@@ -165,6 +247,20 @@ export const element =
165
247
  } else {
166
248
  this.innerHTML = content;
167
249
  }
250
+
251
+ // 초기 동기화
252
+ (this as any)._syncDecorators();
253
+
254
+ // 7. Watch for DOM changes (MutationObserver)
255
+ this._observer = new MutationObserver(() => {
256
+ (this as any)._syncDecorators();
257
+ });
258
+ const target = this.shadowRoot || this;
259
+ this._observer.observe(target, { childList: true, subtree: true });
260
+
261
+ if (super.connectedCallback) {
262
+ await super.connectedCallback();
263
+ }
168
264
  }
169
265
 
170
266
  // 4. Handle attribute changes and route to decorated methods
@@ -174,10 +270,24 @@ export const element =
174
270
  super.attributeChangedCallback(name, oldValue, newValue);
175
271
  }
176
272
 
177
- // Call the method associated with @attributeChanged
178
- const methodKey = attributeChangedMap?.get(name);
179
- if (methodKey && typeof (this as any)[methodKey] === 'function') {
180
- (this as any)[methodKey](newValue, oldValue);
273
+ // Call all methods associated with @attributeChanged
274
+ const methodKeys = attributeChangedMap?.get(name);
275
+ if (methodKeys && Array.isArray(methodKeys)) {
276
+ methodKeys.forEach(key => {
277
+ if (typeof (this as any)[key] === 'function') {
278
+ (this as any)[key](newValue, oldValue, name);
279
+ }
280
+ });
281
+ }
282
+
283
+ // Call the wildcard methods if they exist
284
+ const wildcardMethodKeys = attributeChangedMap?.get(ATTRIBUTE_CHANGED_WILDCARD);
285
+ if (wildcardMethodKeys && Array.isArray(wildcardMethodKeys)) {
286
+ wildcardMethodKeys.forEach(key => {
287
+ if (typeof (this as any)[key] === 'function') {
288
+ (this as any)[key](newValue, oldValue, name);
289
+ }
290
+ });
181
291
  }
182
292
  }
183
293
  };
@@ -0,0 +1,46 @@
1
+ import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';
2
+
3
+ export interface QueryOptions {
4
+ useShadow?: boolean;
5
+ }
6
+
7
+ export interface QueryMetadata {
8
+ selector: string;
9
+ options: QueryOptions;
10
+ propertyKey: string | symbol;
11
+ isMethod: boolean;
12
+ }
13
+
14
+ export const QUERY_METADATA_KEY = Symbol('simple-web-component:query');
15
+
16
+ export const query = (selector: string, options: QueryOptions = { useShadow: true }): any => {
17
+ return (target: Object, propertyKey: string | symbol, descriptor?: PropertyDescriptor) => {
18
+ const isMethod = !!descriptor;
19
+ const constructor = target.constructor;
20
+
21
+ // 메타데이터 저장 (나중에 elementDefind에서 사용)
22
+ let queries = ReflectUtils.getMetadata<QueryMetadata[]>(QUERY_METADATA_KEY, constructor);
23
+ if (!queries) {
24
+ queries = [];
25
+ ReflectUtils.defineMetadata(QUERY_METADATA_KEY, queries, constructor);
26
+ }
27
+ queries.push({ selector, options, propertyKey, isMethod });
28
+
29
+ if (!isMethod) {
30
+ // 속성 데코레이터인 경우: 기존처럼 Lazy Getter 설정
31
+ Object.defineProperty(target, propertyKey, {
32
+ get(this: HTMLElement) {
33
+ const root = options.useShadow !== false && this.shadowRoot ? this.shadowRoot : this;
34
+ return root.querySelector(selector);
35
+ },
36
+ enumerable: true,
37
+ configurable: true
38
+ });
39
+ }
40
+ };
41
+ };
42
+
43
+ export const getQueryMetadata = (target: any): QueryMetadata[] | undefined => {
44
+ const constructor = target instanceof Function ? target : target.constructor;
45
+ return ReflectUtils.getMetadata(QUERY_METADATA_KEY, constructor);
46
+ };
@@ -0,0 +1,46 @@
1
+ import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';
2
+
3
+ export interface QueryAllOptions {
4
+ useShadow?: boolean;
5
+ }
6
+
7
+ export interface QueryAllMetadata {
8
+ selector: string;
9
+ options: QueryAllOptions;
10
+ propertyKey: string | symbol;
11
+ isMethod: boolean;
12
+ }
13
+
14
+ export const QUERY_ALL_METADATA_KEY = Symbol('simple-web-component:query-all');
15
+
16
+ export const queryAll = (selector: string, options: QueryAllOptions = { useShadow: true }): any => {
17
+ return (target: Object, propertyKey: string | symbol, descriptor?: PropertyDescriptor) => {
18
+ const isMethod = !!descriptor;
19
+ const constructor = target.constructor;
20
+
21
+ // 메타데이터 저장 (나중에 elementDefind에서 사용)
22
+ let queries = ReflectUtils.getMetadata<QueryAllMetadata[]>(QUERY_ALL_METADATA_KEY, constructor);
23
+ if (!queries) {
24
+ queries = [];
25
+ ReflectUtils.defineMetadata(QUERY_ALL_METADATA_KEY, queries, constructor);
26
+ }
27
+ queries.push({ selector, options, propertyKey, isMethod });
28
+
29
+ if (!isMethod) {
30
+ // 속성 데코레이터인 경우: 기존처럼 Lazy Getter 설정
31
+ Object.defineProperty(target, propertyKey, {
32
+ get(this: HTMLElement) {
33
+ const root = options.useShadow !== false && this.shadowRoot ? this.shadowRoot : this;
34
+ return root.querySelectorAll(selector);
35
+ },
36
+ enumerable: true,
37
+ configurable: true
38
+ });
39
+ }
40
+ };
41
+ };
42
+
43
+ export const getQueryAllMetadata = (target: any): QueryAllMetadata[] | undefined => {
44
+ const constructor = target instanceof Function ? target : target.constructor;
45
+ return ReflectUtils.getMetadata(QUERY_ALL_METADATA_KEY, constructor);
46
+ };