@miurajs/miura-render 0.0.0 → 0.1.1

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 (262) hide show
  1. package/dist/index.d.ts +14 -0
  2. package/dist/index.d.ts.map +1 -0
  3. package/dist/index.js +13 -0
  4. package/dist/index.js.map +1 -0
  5. package/dist/src/binding-manager/binding-manager.d.ts +30 -0
  6. package/dist/src/binding-manager/binding-manager.d.ts.map +1 -0
  7. package/dist/src/binding-manager/binding-manager.js +245 -0
  8. package/dist/src/binding-manager/binding-manager.js.map +1 -0
  9. package/dist/src/binding-manager/binding-type.d.ts +24 -0
  10. package/dist/src/binding-manager/binding-type.d.ts.map +1 -0
  11. package/dist/src/binding-manager/binding-type.js +25 -0
  12. package/dist/src/binding-manager/binding-type.js.map +1 -0
  13. package/dist/src/binding-manager/bindings/async-binding.d.ts +23 -0
  14. package/dist/src/binding-manager/bindings/async-binding.d.ts.map +1 -0
  15. package/dist/src/binding-manager/bindings/async-binding.js +67 -0
  16. package/dist/src/binding-manager/bindings/async-binding.js.map +1 -0
  17. package/dist/src/binding-manager/bindings/attribute-binding.d.ts +41 -0
  18. package/dist/src/binding-manager/bindings/attribute-binding.d.ts.map +1 -0
  19. package/dist/src/binding-manager/bindings/attribute-binding.js +79 -0
  20. package/dist/src/binding-manager/bindings/attribute-binding.js.map +1 -0
  21. package/dist/src/binding-manager/bindings/bind-binding.d.ts +30 -0
  22. package/dist/src/binding-manager/bindings/bind-binding.d.ts.map +1 -0
  23. package/dist/src/binding-manager/bindings/bind-binding.js +81 -0
  24. package/dist/src/binding-manager/bindings/bind-binding.js.map +1 -0
  25. package/dist/src/binding-manager/bindings/binding.d.ts +6 -0
  26. package/dist/src/binding-manager/bindings/binding.d.ts.map +1 -0
  27. package/dist/src/binding-manager/bindings/binding.js +2 -0
  28. package/dist/src/binding-manager/bindings/binding.js.map +1 -0
  29. package/dist/src/binding-manager/bindings/boolean-binding.d.ts +18 -0
  30. package/dist/src/binding-manager/bindings/boolean-binding.d.ts.map +1 -0
  31. package/dist/src/binding-manager/bindings/boolean-binding.js +65 -0
  32. package/dist/src/binding-manager/bindings/boolean-binding.js.map +1 -0
  33. package/dist/src/binding-manager/bindings/class-binding.d.ts +10 -0
  34. package/dist/src/binding-manager/bindings/class-binding.d.ts.map +1 -0
  35. package/dist/src/binding-manager/bindings/class-binding.js +68 -0
  36. package/dist/src/binding-manager/bindings/class-binding.js.map +1 -0
  37. package/dist/src/binding-manager/bindings/directive-binding.d.ts +15 -0
  38. package/dist/src/binding-manager/bindings/directive-binding.d.ts.map +1 -0
  39. package/dist/src/binding-manager/bindings/directive-binding.js +70 -0
  40. package/dist/src/binding-manager/bindings/directive-binding.js.map +1 -0
  41. package/dist/src/binding-manager/bindings/event-binding.d.ts +14 -0
  42. package/dist/src/binding-manager/bindings/event-binding.d.ts.map +1 -0
  43. package/dist/src/binding-manager/bindings/event-binding.js +73 -0
  44. package/dist/src/binding-manager/bindings/event-binding.js.map +1 -0
  45. package/dist/src/binding-manager/bindings/node-binding.d.ts +36 -0
  46. package/dist/src/binding-manager/bindings/node-binding.d.ts.map +1 -0
  47. package/dist/src/binding-manager/bindings/node-binding.js +235 -0
  48. package/dist/src/binding-manager/bindings/node-binding.js.map +1 -0
  49. package/dist/src/binding-manager/bindings/object-class-binding.d.ts +16 -0
  50. package/dist/src/binding-manager/bindings/object-class-binding.d.ts.map +1 -0
  51. package/dist/src/binding-manager/bindings/object-class-binding.js +42 -0
  52. package/dist/src/binding-manager/bindings/object-class-binding.js.map +1 -0
  53. package/dist/src/binding-manager/bindings/object-style-binding.d.ts +16 -0
  54. package/dist/src/binding-manager/bindings/object-style-binding.d.ts.map +1 -0
  55. package/dist/src/binding-manager/bindings/object-style-binding.js +38 -0
  56. package/dist/src/binding-manager/bindings/object-style-binding.js.map +1 -0
  57. package/dist/src/binding-manager/bindings/property-binding.d.ts +12 -0
  58. package/dist/src/binding-manager/bindings/property-binding.d.ts.map +1 -0
  59. package/dist/src/binding-manager/bindings/property-binding.js +44 -0
  60. package/dist/src/binding-manager/bindings/property-binding.js.map +1 -0
  61. package/dist/src/binding-manager/bindings/reference-binding.d.ts +14 -0
  62. package/dist/src/binding-manager/bindings/reference-binding.d.ts.map +1 -0
  63. package/dist/src/binding-manager/bindings/reference-binding.js +44 -0
  64. package/dist/src/binding-manager/bindings/reference-binding.js.map +1 -0
  65. package/dist/src/binding-manager/bindings/spread-binding.d.ts +16 -0
  66. package/dist/src/binding-manager/bindings/spread-binding.d.ts.map +1 -0
  67. package/dist/src/binding-manager/bindings/spread-binding.js +40 -0
  68. package/dist/src/binding-manager/bindings/spread-binding.js.map +1 -0
  69. package/dist/src/binding-manager/bindings/style-binding.d.ts +10 -0
  70. package/dist/src/binding-manager/bindings/style-binding.d.ts.map +1 -0
  71. package/dist/src/binding-manager/bindings/style-binding.js +44 -0
  72. package/dist/src/binding-manager/bindings/style-binding.js.map +1 -0
  73. package/dist/src/compiler/code-factory.d.ts +45 -0
  74. package/dist/src/compiler/code-factory.d.ts.map +1 -0
  75. package/dist/src/compiler/code-factory.js +211 -0
  76. package/dist/src/compiler/code-factory.js.map +1 -0
  77. package/dist/src/compiler/compiler.d.ts +77 -0
  78. package/dist/src/compiler/compiler.d.ts.map +1 -0
  79. package/dist/src/compiler/compiler.js +77 -0
  80. package/dist/src/compiler/compiler.js.map +1 -0
  81. package/dist/src/compiler/constants.d.ts +5 -0
  82. package/dist/src/compiler/constants.d.ts.map +1 -0
  83. package/dist/src/compiler/constants.js +9 -0
  84. package/dist/src/compiler/constants.js.map +1 -0
  85. package/dist/src/css-result.d.ts +27 -0
  86. package/dist/src/css-result.d.ts.map +1 -0
  87. package/dist/src/css-result.js +56 -0
  88. package/dist/src/css-result.js.map +1 -0
  89. package/dist/src/css.d.ts +26 -0
  90. package/dist/src/css.d.ts.map +1 -0
  91. package/dist/src/css.js +62 -0
  92. package/dist/src/css.js.map +1 -0
  93. package/dist/src/directives/animate.directive.d.ts +42 -0
  94. package/dist/src/directives/animate.directive.d.ts.map +1 -0
  95. package/dist/src/directives/animate.directive.js +349 -0
  96. package/dist/src/directives/animate.directive.js.map +1 -0
  97. package/dist/src/directives/await.d.ts +68 -0
  98. package/dist/src/directives/await.d.ts.map +1 -0
  99. package/dist/src/directives/await.js +70 -0
  100. package/dist/src/directives/await.js.map +1 -0
  101. package/dist/src/directives/choose.d.ts +28 -0
  102. package/dist/src/directives/choose.d.ts.map +1 -0
  103. package/dist/src/directives/choose.js +30 -0
  104. package/dist/src/directives/choose.js.map +1 -0
  105. package/dist/src/directives/decorator-example.d.ts +8 -0
  106. package/dist/src/directives/decorator-example.d.ts.map +1 -0
  107. package/dist/src/directives/decorator-example.js +32 -0
  108. package/dist/src/directives/decorator-example.js.map +1 -0
  109. package/dist/src/directives/decorators.d.ts +3 -0
  110. package/dist/src/directives/decorators.d.ts.map +1 -0
  111. package/dist/src/directives/decorators.js +17 -0
  112. package/dist/src/directives/decorators.js.map +1 -0
  113. package/dist/src/directives/directive-manager.d.ts +26 -0
  114. package/dist/src/directives/directive-manager.d.ts.map +1 -0
  115. package/dist/src/directives/directive-manager.js +114 -0
  116. package/dist/src/directives/directive-manager.js.map +1 -0
  117. package/dist/src/directives/directive.d.ts +38 -0
  118. package/dist/src/directives/directive.d.ts.map +1 -0
  119. package/dist/src/directives/directive.js +18 -0
  120. package/dist/src/directives/directive.js.map +1 -0
  121. package/dist/src/directives/focus.directive.d.ts +16 -0
  122. package/dist/src/directives/focus.directive.d.ts.map +1 -0
  123. package/dist/src/directives/focus.directive.js +29 -0
  124. package/dist/src/directives/focus.directive.js.map +1 -0
  125. package/dist/src/directives/gesture.directive.d.ts +58 -0
  126. package/dist/src/directives/gesture.directive.d.ts.map +1 -0
  127. package/dist/src/directives/gesture.directive.js +331 -0
  128. package/dist/src/directives/gesture.directive.js.map +1 -0
  129. package/dist/src/directives/index.d.ts +34 -0
  130. package/dist/src/directives/index.d.ts.map +1 -0
  131. package/dist/src/directives/index.js +35 -0
  132. package/dist/src/directives/index.js.map +1 -0
  133. package/dist/src/directives/intersection.directive.d.ts +18 -0
  134. package/dist/src/directives/intersection.directive.d.ts.map +1 -0
  135. package/dist/src/directives/intersection.directive.js +50 -0
  136. package/dist/src/directives/intersection.directive.js.map +1 -0
  137. package/dist/src/directives/keyed-diff.d.ts +30 -0
  138. package/dist/src/directives/keyed-diff.d.ts.map +1 -0
  139. package/dist/src/directives/keyed-diff.js +185 -0
  140. package/dist/src/directives/keyed-diff.js.map +1 -0
  141. package/dist/src/directives/lazy-setup.d.ts +3 -0
  142. package/dist/src/directives/lazy-setup.d.ts.map +1 -0
  143. package/dist/src/directives/lazy-setup.js +55 -0
  144. package/dist/src/directives/lazy-setup.js.map +1 -0
  145. package/dist/src/directives/lazy.directive.d.ts +19 -0
  146. package/dist/src/directives/lazy.directive.d.ts.map +1 -0
  147. package/dist/src/directives/lazy.directive.js +73 -0
  148. package/dist/src/directives/lazy.directive.js.map +1 -0
  149. package/dist/src/directives/media.directive.d.ts +31 -0
  150. package/dist/src/directives/media.directive.d.ts.map +1 -0
  151. package/dist/src/directives/media.directive.js +105 -0
  152. package/dist/src/directives/media.directive.js.map +1 -0
  153. package/dist/src/directives/mutation.directive.d.ts +11 -0
  154. package/dist/src/directives/mutation.directive.d.ts.map +1 -0
  155. package/dist/src/directives/mutation.directive.js +56 -0
  156. package/dist/src/directives/mutation.directive.js.map +1 -0
  157. package/dist/src/directives/repeat.d.ts +50 -0
  158. package/dist/src/directives/repeat.d.ts.map +1 -0
  159. package/dist/src/directives/repeat.js +47 -0
  160. package/dist/src/directives/repeat.js.map +1 -0
  161. package/dist/src/directives/resize.directive.d.ts +14 -0
  162. package/dist/src/directives/resize.directive.d.ts.map +1 -0
  163. package/dist/src/directives/resize.directive.js +81 -0
  164. package/dist/src/directives/resize.directive.js.map +1 -0
  165. package/dist/src/directives/setup.d.ts +9 -0
  166. package/dist/src/directives/setup.d.ts.map +1 -0
  167. package/dist/src/directives/setup.js +9 -0
  168. package/dist/src/directives/setup.js.map +1 -0
  169. package/dist/src/directives/structural/async.directive.d.ts +39 -0
  170. package/dist/src/directives/structural/async.directive.d.ts.map +1 -0
  171. package/dist/src/directives/structural/async.directive.js +115 -0
  172. package/dist/src/directives/structural/async.directive.js.map +1 -0
  173. package/dist/src/directives/structural/for.directive.d.ts +37 -0
  174. package/dist/src/directives/structural/for.directive.d.ts.map +1 -0
  175. package/dist/src/directives/structural/for.directive.js +209 -0
  176. package/dist/src/directives/structural/for.directive.js.map +1 -0
  177. package/dist/src/directives/structural/if.directive.d.ts +54 -0
  178. package/dist/src/directives/structural/if.directive.d.ts.map +1 -0
  179. package/dist/src/directives/structural/if.directive.js +210 -0
  180. package/dist/src/directives/structural/if.directive.js.map +1 -0
  181. package/dist/src/directives/structural/structural.directive.d.ts +11 -0
  182. package/dist/src/directives/structural/structural.directive.d.ts.map +1 -0
  183. package/dist/src/directives/structural/structural.directive.js +29 -0
  184. package/dist/src/directives/structural/structural.directive.js.map +1 -0
  185. package/dist/src/directives/structural/switch.directive.d.ts +12 -0
  186. package/dist/src/directives/structural/switch.directive.d.ts.map +1 -0
  187. package/dist/src/directives/structural/switch.directive.js +69 -0
  188. package/dist/src/directives/structural/switch.directive.js.map +1 -0
  189. package/dist/src/directives/structural/virtual-scroll.directive.d.ts +50 -0
  190. package/dist/src/directives/structural/virtual-scroll.directive.d.ts.map +1 -0
  191. package/dist/src/directives/structural/virtual-scroll.directive.js +165 -0
  192. package/dist/src/directives/structural/virtual-scroll.directive.js.map +1 -0
  193. package/dist/src/directives/utils.d.ts +61 -0
  194. package/dist/src/directives/utils.d.ts.map +1 -0
  195. package/dist/src/directives/utils.js +121 -0
  196. package/dist/src/directives/utils.js.map +1 -0
  197. package/dist/src/directives/validate.directive.d.ts +41 -0
  198. package/dist/src/directives/validate.directive.d.ts.map +1 -0
  199. package/dist/src/directives/validate.directive.js +161 -0
  200. package/dist/src/directives/validate.directive.js.map +1 -0
  201. package/dist/src/directives/virtual-scroll.d.ts +91 -0
  202. package/dist/src/directives/virtual-scroll.d.ts.map +1 -0
  203. package/dist/src/directives/virtual-scroll.js +78 -0
  204. package/dist/src/directives/virtual-scroll.js.map +1 -0
  205. package/dist/src/directives/when.d.ts +24 -0
  206. package/dist/src/directives/when.d.ts.map +1 -0
  207. package/dist/src/directives/when.js +25 -0
  208. package/dist/src/directives/when.js.map +1 -0
  209. package/dist/src/html.d.ts +23 -0
  210. package/dist/src/html.d.ts.map +1 -0
  211. package/dist/src/html.js +37 -0
  212. package/dist/src/html.js.map +1 -0
  213. package/dist/src/modifiers/capture-modifier.d.ts +6 -0
  214. package/dist/src/modifiers/capture-modifier.d.ts.map +1 -0
  215. package/dist/src/modifiers/capture-modifier.js +14 -0
  216. package/dist/src/modifiers/capture-modifier.js.map +1 -0
  217. package/dist/src/modifiers/event-modifiers.d.ts +38 -0
  218. package/dist/src/modifiers/event-modifiers.d.ts.map +1 -0
  219. package/dist/src/modifiers/event-modifiers.js +90 -0
  220. package/dist/src/modifiers/event-modifiers.js.map +1 -0
  221. package/dist/src/modifiers/key-modifiers.d.ts +8 -0
  222. package/dist/src/modifiers/key-modifiers.d.ts.map +1 -0
  223. package/dist/src/modifiers/key-modifiers.js +29 -0
  224. package/dist/src/modifiers/key-modifiers.js.map +1 -0
  225. package/dist/src/modifiers/mouse-modifiers.d.ts +8 -0
  226. package/dist/src/modifiers/mouse-modifiers.d.ts.map +1 -0
  227. package/dist/src/modifiers/mouse-modifiers.js +15 -0
  228. package/dist/src/modifiers/mouse-modifiers.js.map +1 -0
  229. package/dist/src/modifiers/once-modifier.d.ts +6 -0
  230. package/dist/src/modifiers/once-modifier.d.ts.map +1 -0
  231. package/dist/src/modifiers/once-modifier.js +11 -0
  232. package/dist/src/modifiers/once-modifier.js.map +1 -0
  233. package/dist/src/modifiers/passive-modifier.d.ts +6 -0
  234. package/dist/src/modifiers/passive-modifier.d.ts.map +1 -0
  235. package/dist/src/modifiers/passive-modifier.js +14 -0
  236. package/dist/src/modifiers/passive-modifier.js.map +1 -0
  237. package/dist/src/processor/parser.d.ts +74 -0
  238. package/dist/src/processor/parser.d.ts.map +1 -0
  239. package/dist/src/processor/parser.js +345 -0
  240. package/dist/src/processor/parser.js.map +1 -0
  241. package/dist/src/processor/processor.d.ts +68 -0
  242. package/dist/src/processor/processor.d.ts.map +1 -0
  243. package/dist/src/processor/processor.js +138 -0
  244. package/dist/src/processor/processor.js.map +1 -0
  245. package/dist/src/processor/template-result.d.ts +74 -0
  246. package/dist/src/processor/template-result.d.ts.map +1 -0
  247. package/dist/src/processor/template-result.js +53 -0
  248. package/dist/src/processor/template-result.js.map +1 -0
  249. package/dist/src/processor/types.d.ts +16 -0
  250. package/dist/src/processor/types.d.ts.map +1 -0
  251. package/dist/src/processor/types.js +13 -0
  252. package/dist/src/processor/types.js.map +1 -0
  253. package/dist/src/utils/debug.d.ts +7 -0
  254. package/dist/src/utils/debug.d.ts.map +1 -0
  255. package/dist/src/utils/debug.js +7 -0
  256. package/dist/src/utils/debug.js.map +1 -0
  257. package/dist/src/utils/performance.d.ts +50 -0
  258. package/dist/src/utils/performance.d.ts.map +1 -0
  259. package/dist/src/utils/performance.js +51 -0
  260. package/dist/src/utils/performance.js.map +1 -0
  261. package/dist/tsconfig.tsbuildinfo +1 -0
  262. package/package.json +8 -10
@@ -0,0 +1,30 @@
1
+ import { Binding } from './binding';
2
+ /**
3
+ * Value passed to a two-way binding. Either:
4
+ * - A tuple: [currentValue, setter]
5
+ * - A binder object: { value, set }
6
+ */
7
+ export interface BinderObject {
8
+ value: unknown;
9
+ set: (value: unknown) => void;
10
+ }
11
+ /**
12
+ * Two-way binding: sets a DOM property and listens for the corresponding
13
+ * DOM event to push changes back to the host component.
14
+ *
15
+ * Template syntax:
16
+ * <input ~value=${[this.name, (v) => this.name = v]}>
17
+ * <input ~value=${this.bind('name')}>
18
+ */
19
+ export declare class BindBinding implements Binding {
20
+ private element;
21
+ private propertyName;
22
+ private handler;
23
+ private eventName;
24
+ private setter;
25
+ constructor(element: Element, propertyName: string);
26
+ setValue(value: unknown): void;
27
+ clear(): void;
28
+ disconnect(): void;
29
+ }
30
+ //# sourceMappingURL=bind-binding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bind-binding.d.ts","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/bind-binding.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC;;;;GAIG;AACH,MAAM,WAAW,YAAY;IACzB,KAAK,EAAE,OAAO,CAAC;IACf,GAAG,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;CACjC;AAgBD;;;;;;;GAOG;AACH,qBAAa,WAAY,YAAW,OAAO;IAMnC,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,YAAY;IANxB,OAAO,CAAC,OAAO,CAA8B;IAC7C,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,MAAM,CAAuC;gBAGzC,OAAO,EAAE,OAAO,EAChB,YAAY,EAAE,MAAM;IAKhC,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IA2C9B,KAAK,IAAI,IAAI;IAQb,UAAU,IAAI,IAAI;CAGrB"}
@@ -0,0 +1,81 @@
1
+ /**
2
+ * Default event names for common DOM properties.
3
+ * Maps property name → DOM event that fires when the property changes.
4
+ */
5
+ const PROPERTY_EVENT_MAP = {
6
+ value: 'input',
7
+ checked: 'change',
8
+ selected: 'change',
9
+ selectedIndex: 'change',
10
+ files: 'change',
11
+ };
12
+ /**
13
+ * Two-way binding: sets a DOM property and listens for the corresponding
14
+ * DOM event to push changes back to the host component.
15
+ *
16
+ * Template syntax:
17
+ * <input ~value=${[this.name, (v) => this.name = v]}>
18
+ * <input ~value=${this.bind('name')}>
19
+ */
20
+ export class BindBinding {
21
+ element;
22
+ propertyName;
23
+ handler = null;
24
+ eventName;
25
+ setter = null;
26
+ constructor(element, propertyName) {
27
+ this.element = element;
28
+ this.propertyName = propertyName;
29
+ this.eventName = PROPERTY_EVENT_MAP[propertyName] || 'input';
30
+ }
31
+ setValue(value) {
32
+ // Extract current value and setter from the bind value
33
+ let currentValue;
34
+ let setter = null;
35
+ if (Array.isArray(value) && value.length === 2 && typeof value[1] === 'function') {
36
+ // Tuple form: [value, setter]
37
+ currentValue = value[0];
38
+ setter = value[1];
39
+ }
40
+ else if (value && typeof value === 'object' && 'set' in value && 'value' in value) {
41
+ // Binder object form: { value, set }
42
+ const binder = value;
43
+ currentValue = binder.value;
44
+ setter = binder.set;
45
+ }
46
+ else {
47
+ // Fallback: treat as one-way (just set the property)
48
+ this.element[this.propertyName] = value;
49
+ return;
50
+ }
51
+ // Set the DOM property
52
+ this.element[this.propertyName] = currentValue;
53
+ // Update event listener if setter changed
54
+ if (setter !== this.setter) {
55
+ // Remove old listener
56
+ if (this.handler) {
57
+ this.element.removeEventListener(this.eventName, this.handler);
58
+ this.handler = null;
59
+ }
60
+ this.setter = setter;
61
+ if (setter) {
62
+ this.handler = () => {
63
+ const newValue = this.element[this.propertyName];
64
+ setter(newValue);
65
+ };
66
+ this.element.addEventListener(this.eventName, this.handler);
67
+ }
68
+ }
69
+ }
70
+ clear() {
71
+ if (this.handler) {
72
+ this.element.removeEventListener(this.eventName, this.handler);
73
+ this.handler = null;
74
+ }
75
+ this.setter = null;
76
+ }
77
+ disconnect() {
78
+ this.clear();
79
+ }
80
+ }
81
+ //# sourceMappingURL=bind-binding.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bind-binding.js","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/bind-binding.ts"],"names":[],"mappings":"AAcA;;;GAGG;AACH,MAAM,kBAAkB,GAA2B;IAC/C,KAAK,EAAE,OAAO;IACd,OAAO,EAAE,QAAQ;IACjB,QAAQ,EAAE,QAAQ;IAClB,aAAa,EAAE,QAAQ;IACvB,KAAK,EAAE,QAAQ;CAClB,CAAC;AAEF;;;;;;;GAOG;AACH,MAAM,OAAO,WAAW;IAMR;IACA;IANJ,OAAO,GAAyB,IAAI,CAAC;IACrC,SAAS,CAAS;IAClB,MAAM,GAAkC,IAAI,CAAC;IAErD,YACY,OAAgB,EAChB,YAAoB;QADpB,YAAO,GAAP,OAAO,CAAS;QAChB,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,SAAS,GAAG,kBAAkB,CAAC,YAAY,CAAC,IAAI,OAAO,CAAC;IACjE,CAAC;IAED,QAAQ,CAAC,KAAc;QACnB,uDAAuD;QACvD,IAAI,YAAqB,CAAC;QAC1B,IAAI,MAAM,GAAkC,IAAI,CAAC;QAEjD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,UAAU,EAAE,CAAC;YAC/E,8BAA8B;YAC9B,YAAY,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YACxB,MAAM,GAAG,KAAK,CAAC,CAAC,CAAyB,CAAC;QAC9C,CAAC;aAAM,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,IAAI,KAAK,IAAI,OAAO,IAAI,KAAK,EAAE,CAAC;YAClF,qCAAqC;YACrC,MAAM,MAAM,GAAG,KAAqB,CAAC;YACrC,YAAY,GAAG,MAAM,CAAC,KAAK,CAAC;YAC5B,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC;QACxB,CAAC;aAAM,CAAC;YACJ,qDAAqD;YACpD,IAAI,CAAC,OAAe,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC;YACjD,OAAO;QACX,CAAC;QAED,uBAAuB;QACtB,IAAI,CAAC,OAAe,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,YAAY,CAAC;QAExD,0CAA0C;QAC1C,IAAI,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,CAAC;YACzB,sBAAsB;YACtB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACf,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;gBAC/D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACxB,CAAC;YAED,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;YAErB,IAAI,MAAM,EAAE,CAAC;gBACT,IAAI,CAAC,OAAO,GAAG,GAAG,EAAE;oBAChB,MAAM,QAAQ,GAAI,IAAI,CAAC,OAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;oBAC1D,MAAO,CAAC,QAAQ,CAAC,CAAC;gBACtB,CAAC,CAAC;gBACF,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YAChE,CAAC;QACL,CAAC;IACL,CAAC;IAED,KAAK;QACD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YAC/D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACvB,CAAC;IAED,UAAU;QACN,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;CACJ"}
@@ -0,0 +1,6 @@
1
+ export interface Binding {
2
+ setValue(value: unknown, context?: unknown): void | Promise<void>;
3
+ clear(): void;
4
+ disconnect?(): void;
5
+ }
6
+ //# sourceMappingURL=binding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"binding.d.ts","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/binding.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,OAAO;IACpB,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAClE,KAAK,IAAI,IAAI,CAAC;IACd,UAAU,CAAC,IAAI,IAAI,CAAC;CACvB"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=binding.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"binding.js","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/binding.ts"],"names":[],"mappings":""}
@@ -0,0 +1,18 @@
1
+ import { Binding } from './binding';
2
+ /**
3
+ * Handles boolean attribute bindings (?attribute=${value})
4
+ * Examples:
5
+ * - ?disabled=${isDisabled}
6
+ * - ?readonly=${isReadOnly}
7
+ * - ?checked=${isChecked}
8
+ */
9
+ export declare class BooleanBinding implements Binding {
10
+ private element;
11
+ private attributeName;
12
+ private previousValue;
13
+ constructor(element: Element, attributeName: string);
14
+ setValue(value: unknown): void;
15
+ clear(): void;
16
+ disconnect(): void;
17
+ }
18
+ //# sourceMappingURL=boolean-binding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"boolean-binding.d.ts","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/boolean-binding.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC;;;;;;GAMG;AACH,qBAAa,cAAe,YAAW,OAAO;IAItC,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,aAAa;IAJzB,OAAO,CAAC,aAAa,CAAwB;gBAGjC,OAAO,EAAE,OAAO,EAChB,aAAa,EAAE,MAAM;IAQjC,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAiC9B,KAAK,IAAI,IAAI;IAab,UAAU,IAAI,IAAI;CAGrB"}
@@ -0,0 +1,65 @@
1
+ import { debugLog } from '../../utils/debug';
2
+ /**
3
+ * Handles boolean attribute bindings (?attribute=${value})
4
+ * Examples:
5
+ * - ?disabled=${isDisabled}
6
+ * - ?readonly=${isReadOnly}
7
+ * - ?checked=${isChecked}
8
+ */
9
+ export class BooleanBinding {
10
+ element;
11
+ attributeName;
12
+ previousValue = null;
13
+ constructor(element, attributeName) {
14
+ this.element = element;
15
+ this.attributeName = attributeName;
16
+ debugLog('booleanBinding', 'Created boolean binding', {
17
+ element: element.tagName,
18
+ attributeName,
19
+ });
20
+ }
21
+ setValue(value) {
22
+ const newValue = Boolean(value);
23
+ // Skip if value hasn't changed
24
+ if (newValue === this.previousValue) {
25
+ return;
26
+ }
27
+ debugLog('booleanBinding', 'Setting value', {
28
+ element: this.element.tagName,
29
+ attributeName: this.attributeName,
30
+ value: newValue,
31
+ previousValue: this.previousValue
32
+ });
33
+ if (newValue) {
34
+ // Set both attribute and property
35
+ this.element.setAttribute(this.attributeName, '');
36
+ // Only set property if it exists on element
37
+ if (this.attributeName in this.element) {
38
+ this.element[this.attributeName] = true;
39
+ }
40
+ }
41
+ else {
42
+ // Remove both attribute and property
43
+ this.element.removeAttribute(this.attributeName);
44
+ if (this.attributeName in this.element) {
45
+ this.element[this.attributeName] = false;
46
+ }
47
+ }
48
+ this.previousValue = newValue;
49
+ }
50
+ clear() {
51
+ debugLog('booleanBinding', 'Clearing binding', {
52
+ element: this.element.tagName,
53
+ attributeName: this.attributeName
54
+ });
55
+ this.element.removeAttribute(this.attributeName);
56
+ if (this.attributeName in this.element) {
57
+ this.element[this.attributeName] = false;
58
+ }
59
+ this.previousValue = null;
60
+ }
61
+ disconnect() {
62
+ this.clear();
63
+ }
64
+ }
65
+ //# sourceMappingURL=boolean-binding.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"boolean-binding.js","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/boolean-binding.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C;;;;;;GAMG;AACH,MAAM,OAAO,cAAc;IAIX;IACA;IAJJ,aAAa,GAAmB,IAAI,CAAC;IAE7C,YACY,OAAgB,EAChB,aAAqB;QADrB,YAAO,GAAP,OAAO,CAAS;QAChB,kBAAa,GAAb,aAAa,CAAQ;QAE7B,QAAQ,CAAC,gBAAgB,EAAE,yBAAyB,EAAE;YAClD,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,aAAa;SAChB,CAAC,CAAC;IACP,CAAC;IAED,QAAQ,CAAC,KAAc;QACnB,MAAM,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;QAEhC,+BAA+B;QAC/B,IAAI,QAAQ,KAAK,IAAI,CAAC,aAAa,EAAE,CAAC;YAClC,OAAO;QACX,CAAC;QAED,QAAQ,CAAC,gBAAgB,EAAE,eAAe,EAAE;YACxC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,KAAK,EAAE,QAAQ;YACf,aAAa,EAAE,IAAI,CAAC,aAAa;SACpC,CAAC,CAAC;QAEH,IAAI,QAAQ,EAAE,CAAC;YACX,kCAAkC;YAClC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;YAClD,4CAA4C;YAC5C,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACpC,IAAI,CAAC,OAAe,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;YACrD,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,qCAAqC;YACrC,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACjD,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACpC,IAAI,CAAC,OAAe,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC;YACtD,CAAC;QACL,CAAC;QAED,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;IAClC,CAAC;IAED,KAAK;QACD,QAAQ,CAAC,gBAAgB,EAAE,kBAAkB,EAAE;YAC3C,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;SACpC,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACjD,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACpC,IAAI,CAAC,OAAe,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC;QACtD,CAAC;QACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;IAC9B,CAAC;IAED,UAAU;QACN,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;CACJ"}
@@ -0,0 +1,10 @@
1
+ import { Binding } from './binding';
2
+ export declare class ClassBinding implements Binding {
3
+ private element;
4
+ private previousClasses;
5
+ constructor(element: Element);
6
+ setValue(value: unknown): void;
7
+ clear(): void;
8
+ disconnect(): void;
9
+ }
10
+ //# sourceMappingURL=class-binding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"class-binding.d.ts","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/class-binding.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,qBAAa,YAAa,YAAW,OAAO;IAIpC,OAAO,CAAC,OAAO;IAHnB,OAAO,CAAC,eAAe,CAA0B;gBAGrC,OAAO,EAAE,OAAO;IAO5B,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAqD9B,KAAK,IAAI,IAAI;IAOb,UAAU,IAAI,IAAI;CAGrB"}
@@ -0,0 +1,68 @@
1
+ import { debugLog } from '../../utils/debug';
2
+ export class ClassBinding {
3
+ element;
4
+ previousClasses = new Set();
5
+ constructor(element) {
6
+ this.element = element;
7
+ debugLog('classBinding', 'Created class binding', {
8
+ element: element.tagName
9
+ });
10
+ }
11
+ setValue(value) {
12
+ debugLog('classBinding', 'Setting value', {
13
+ element: this.element.tagName,
14
+ value,
15
+ previousClasses: Array.from(this.previousClasses),
16
+ currentClassList: Array.from(this.element.classList),
17
+ valueType: typeof value,
18
+ valueIsObject: typeof value === 'object'
19
+ });
20
+ // Convert value to array of class names
21
+ const newClasses = new Set();
22
+ if (typeof value === 'string') {
23
+ // Handle string value
24
+ value.split(/\s+/).filter(Boolean).forEach(c => newClasses.add(c));
25
+ debugLog('classBinding', 'String value processed', {
26
+ value,
27
+ newClasses: Array.from(newClasses)
28
+ });
29
+ }
30
+ else if (typeof value === 'object' && value !== null) {
31
+ // Handle object value { class: boolean }
32
+ const entries = Object.entries(value);
33
+ debugLog('classBinding', 'Object value processing', {
34
+ entries
35
+ });
36
+ entries
37
+ .filter(([_, active]) => active)
38
+ .forEach(([className]) => newClasses.add(className));
39
+ }
40
+ debugLog('classBinding', 'Classes to apply', {
41
+ newClasses: Array.from(newClasses),
42
+ previousClasses: Array.from(this.previousClasses)
43
+ });
44
+ // Remove old classes that aren't in new set
45
+ this.previousClasses.forEach(className => {
46
+ if (!newClasses.has(className)) {
47
+ this.element.classList.remove(className);
48
+ }
49
+ });
50
+ // Add new classes
51
+ newClasses.forEach(className => {
52
+ if (!this.previousClasses.has(className)) {
53
+ this.element.classList.add(className);
54
+ }
55
+ });
56
+ this.previousClasses = newClasses;
57
+ }
58
+ clear() {
59
+ this.previousClasses.forEach(className => {
60
+ this.element.classList.remove(className);
61
+ });
62
+ this.previousClasses.clear();
63
+ }
64
+ disconnect() {
65
+ this.clear();
66
+ }
67
+ }
68
+ //# sourceMappingURL=class-binding.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"class-binding.js","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/class-binding.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,MAAM,OAAO,YAAY;IAIT;IAHJ,eAAe,GAAgB,IAAI,GAAG,EAAE,CAAC;IAEjD,YACY,OAAgB;QAAhB,YAAO,GAAP,OAAO,CAAS;QAExB,QAAQ,CAAC,cAAc,EAAE,uBAAuB,EAAE;YAC9C,OAAO,EAAE,OAAO,CAAC,OAAO;SAC3B,CAAC,CAAC;IACP,CAAC;IAED,QAAQ,CAAC,KAAc;QACnB,QAAQ,CAAC,cAAc,EAAE,eAAe,EAAE;YACtC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;YAC7B,KAAK;YACL,eAAe,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC;YACjD,gBAAgB,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;YACpD,SAAS,EAAE,OAAO,KAAK;YACvB,aAAa,EAAE,OAAO,KAAK,KAAK,QAAQ;SAC3C,CAAC,CAAC;QAEH,wCAAwC;QACxC,MAAM,UAAU,GAAG,IAAI,GAAG,EAAU,CAAC;QAErC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC5B,sBAAsB;YACtB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YACnE,QAAQ,CAAC,cAAc,EAAE,wBAAwB,EAAE;gBAC/C,KAAK;gBACL,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC;aACrC,CAAC,CAAC;QACP,CAAC;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACrD,yCAAyC;YACzC,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,KAAgC,CAAC,CAAC;YACjE,QAAQ,CAAC,cAAc,EAAE,yBAAyB,EAAE;gBAChD,OAAO;aACV,CAAC,CAAC;YACH,OAAO;iBACF,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC;iBAC/B,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;QAC7D,CAAC;QAED,QAAQ,CAAC,cAAc,EAAE,kBAAkB,EAAE;YACzC,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC;YAClC,eAAe,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC;SACpD,CAAC,CAAC;QAEH,4CAA4C;QAC5C,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YACrC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC7B,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YAC7C,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,kBAAkB;QAClB,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC3B,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;gBACvC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YAC1C,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC;IACtC,CAAC;IAED,KAAK;QACD,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YACrC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;IACjC,CAAC;IAED,UAAU;QACN,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;CACJ"}
@@ -0,0 +1,15 @@
1
+ import { Binding } from './binding';
2
+ export declare class DirectiveBinding implements Binding {
3
+ private element;
4
+ private directiveName;
5
+ private directive;
6
+ private isLoading;
7
+ private loadingPromise;
8
+ constructor(element: Element, directiveName: string);
9
+ setValue(value: unknown): Promise<void>;
10
+ clear(): void;
11
+ disconnect(): void;
12
+ isLoaded(): boolean;
13
+ getLoadingState(): boolean;
14
+ }
15
+ //# sourceMappingURL=directive-binding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"directive-binding.d.ts","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/directive-binding.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAKpC,qBAAa,gBAAiB,YAAW,OAAO;IAMxC,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,aAAa;IANzB,OAAO,CAAC,SAAS,CAA0B;IAC3C,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,cAAc,CAA8B;gBAGxC,OAAO,EAAE,OAAO,EAChB,aAAa,EAAE,MAAM;IAS3B,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAmC7C,KAAK,IAAI,IAAI;IAUb,UAAU,IAAI,IAAI;IAKlB,QAAQ,IAAI,OAAO;IAKnB,eAAe,IAAI,OAAO;CAG7B"}
@@ -0,0 +1,70 @@
1
+ import { DirectiveManager } from '../../directives/directive-manager';
2
+ import { debugLog } from '../../utils/debug';
3
+ export class DirectiveBinding {
4
+ element;
5
+ directiveName;
6
+ directive = null;
7
+ isLoading = false;
8
+ loadingPromise = null;
9
+ constructor(element, directiveName) {
10
+ this.element = element;
11
+ this.directiveName = directiveName;
12
+ debugLog('directiveBinding', ' 🔴 Creating directive binding', {
13
+ element,
14
+ directiveName,
15
+ hasDirective: DirectiveManager.has(directiveName)
16
+ });
17
+ }
18
+ async setValue(value) {
19
+ debugLog('directiveBinding', 'setValue', {
20
+ value,
21
+ hasDirective: this.directive !== null,
22
+ isLoading: this.isLoading
23
+ });
24
+ if (!this.directive && !this.isLoading) {
25
+ this.isLoading = true;
26
+ // Add loading indicator to element
27
+ this.element.setAttribute('data-directive-loading', this.directiveName);
28
+ try {
29
+ this.directive = await DirectiveManager.create(this.directiveName, this.element);
30
+ debugLog('directiveBinding', 'Created directive', {
31
+ directive: this.directive
32
+ });
33
+ if (this.directive) {
34
+ this.directive.mount(this.element);
35
+ }
36
+ }
37
+ catch (error) {
38
+ console.error(`Failed to create directive ${this.directiveName}:`, error);
39
+ }
40
+ finally {
41
+ this.isLoading = false;
42
+ this.element.removeAttribute('data-directive-loading');
43
+ }
44
+ }
45
+ if (this.directive?.update) {
46
+ this.directive.update(value);
47
+ }
48
+ }
49
+ clear() {
50
+ if (this.directive?.unmount) {
51
+ this.directive.unmount();
52
+ }
53
+ this.directive = null;
54
+ this.isLoading = false;
55
+ this.loadingPromise = null;
56
+ this.element.removeAttribute('data-directive-loading');
57
+ }
58
+ disconnect() {
59
+ this.clear();
60
+ }
61
+ // Helper method to check if directive is loaded
62
+ isLoaded() {
63
+ return this.directive !== null;
64
+ }
65
+ // Helper method to check if directive is loading
66
+ getLoadingState() {
67
+ return this.isLoading;
68
+ }
69
+ }
70
+ //# sourceMappingURL=directive-binding.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"directive-binding.js","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/directive-binding.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AAEtE,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,MAAM,OAAO,gBAAgB;IAMb;IACA;IANJ,SAAS,GAAqB,IAAI,CAAC;IACnC,SAAS,GAAG,KAAK,CAAC;IAClB,cAAc,GAAyB,IAAI,CAAC;IAEpD,YACY,OAAgB,EAChB,aAAqB;QADrB,YAAO,GAAP,OAAO,CAAS;QAChB,kBAAa,GAAb,aAAa,CAAQ;QAE7B,QAAQ,CAAC,kBAAkB,EAAE,gCAAgC,EAAE;YAC3D,OAAO;YACP,aAAa;YACb,YAAY,EAAE,gBAAgB,CAAC,GAAG,CAAC,aAAa,CAAC;SACpD,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,KAAc;QACzB,QAAQ,CAAC,kBAAkB,EAAE,UAAU,EAAE;YACrC,KAAK;YACL,YAAY,EAAE,IAAI,CAAC,SAAS,KAAK,IAAI;YACrC,SAAS,EAAE,IAAI,CAAC,SAAS;SAC5B,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACrC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YAEtB,mCAAmC;YACnC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,wBAAwB,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;YAExE,IAAI,CAAC;gBACD,IAAI,CAAC,SAAS,GAAG,MAAM,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;gBACjF,QAAQ,CAAC,kBAAkB,EAAE,mBAAmB,EAAE;oBAC9C,SAAS,EAAE,IAAI,CAAC,SAAS;iBAC5B,CAAC,CAAC;gBAEH,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;oBACjB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACvC,CAAC;YACL,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC,8BAA8B,IAAI,CAAC,aAAa,GAAG,EAAE,KAAK,CAAC,CAAC;YAC9E,CAAC;oBAAS,CAAC;gBACP,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACvB,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,wBAAwB,CAAC,CAAC;YAC3D,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,CAAC;YACzB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;IACL,CAAC;IAED,KAAK;QACD,IAAI,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;QAC7B,CAAC;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,wBAAwB,CAAC,CAAC;IAC3D,CAAC;IAED,UAAU;QACN,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAED,gDAAgD;IAChD,QAAQ;QACJ,OAAO,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC;IACnC,CAAC;IAED,iDAAiD;IACjD,eAAe;QACX,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;CACJ"}
@@ -0,0 +1,14 @@
1
+ import { Binding } from './binding';
2
+ export declare class EventBinding implements Binding {
3
+ private element;
4
+ private eventName;
5
+ private handler;
6
+ private modifiers;
7
+ constructor(element: Element, eventName: string, modifiers?: string[]);
8
+ private parseModifiers;
9
+ private createHandler;
10
+ setValue(value: unknown, context?: unknown): void;
11
+ clear(): void;
12
+ disconnect(): void;
13
+ }
14
+ //# sourceMappingURL=event-binding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-binding.d.ts","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/event-binding.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,qBAAa,YAAa,YAAW,OAAO;IAKpC,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,SAAS;IALrB,OAAO,CAAC,OAAO,CAA8B;IAC7C,OAAO,CAAC,SAAS,CAAuB;gBAG5B,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,MAAM,EACzB,SAAS,GAAE,MAAM,EAAO;IAM5B,OAAO,CAAC,cAAc;IAkBtB,OAAO,CAAC,aAAa;IAuBrB,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,IAAI;IAejD,KAAK,IAAI,IAAI;IAOb,UAAU,IAAI,IAAI;CAGrB"}
@@ -0,0 +1,73 @@
1
+ import { EVENT_MODIFIERS } from '../../modifiers/event-modifiers';
2
+ import { debugLog } from '../../utils/debug';
3
+ export class EventBinding {
4
+ element;
5
+ eventName;
6
+ handler = null;
7
+ modifiers = [];
8
+ constructor(element, eventName, modifiers = []) {
9
+ this.element = element;
10
+ this.eventName = eventName;
11
+ // Parse modifiers from event name (e.g., "click.prevent.stop")
12
+ this.parseModifiers(modifiers);
13
+ }
14
+ parseModifiers(modifiers) {
15
+ modifiers.forEach(mod => {
16
+ const [name, value] = mod.split(':');
17
+ debugLog('eventBinding', 'Parsing modifier', { name, value });
18
+ const modifier = EVENT_MODIFIERS[name];
19
+ if (modifier) {
20
+ const modifierInstance = modifier(value);
21
+ debugLog('eventBinding', 'Created modifier', {
22
+ name,
23
+ value,
24
+ instance: modifierInstance
25
+ });
26
+ this.modifiers.push(modifierInstance);
27
+ }
28
+ });
29
+ }
30
+ createHandler(originalHandler) {
31
+ let handler = originalHandler;
32
+ // Apply modifiers in reverse order
33
+ for (const modifier of this.modifiers) {
34
+ if ('wrap' in modifier && typeof modifier.wrap === 'function') {
35
+ handler = modifier.wrap(handler);
36
+ }
37
+ }
38
+ return (event) => {
39
+ // Apply non-wrapping modifiers
40
+ for (const modifier of this.modifiers) {
41
+ if (!('wrap' in modifier)) {
42
+ const shouldContinue = modifier.apply(event);
43
+ if (!shouldContinue)
44
+ return;
45
+ }
46
+ }
47
+ handler(event);
48
+ };
49
+ }
50
+ setValue(value, context) {
51
+ // Remove old handler
52
+ if (this.handler) {
53
+ this.element.removeEventListener(this.eventName, this.handler);
54
+ this.handler = null;
55
+ }
56
+ // Add new handler with modifiers
57
+ if (typeof value === 'function') {
58
+ const boundHandler = value.bind(context);
59
+ this.handler = this.createHandler(boundHandler);
60
+ this.element.addEventListener(this.eventName, this.handler);
61
+ }
62
+ }
63
+ clear() {
64
+ if (this.handler) {
65
+ this.element.removeEventListener(this.eventName, this.handler);
66
+ this.handler = null;
67
+ }
68
+ }
69
+ disconnect() {
70
+ this.clear();
71
+ }
72
+ }
73
+ //# sourceMappingURL=event-binding.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-binding.js","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/event-binding.ts"],"names":[],"mappings":"AACA,OAAO,EAAiB,eAAe,EAAE,MAAM,iCAAiC,CAAC;AACjF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,MAAM,OAAO,YAAY;IAKT;IACA;IALJ,OAAO,GAAyB,IAAI,CAAC;IACrC,SAAS,GAAoB,EAAE,CAAC;IAExC,YACY,OAAgB,EAChB,SAAiB,EACzB,YAAsB,EAAE;QAFhB,YAAO,GAAP,OAAO,CAAS;QAChB,cAAS,GAAT,SAAS,CAAQ;QAGzB,+DAA+D;QAC/D,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAEO,cAAc,CAAC,SAAmB;QACtC,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACpB,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACrC,QAAQ,CAAC,cAAc,EAAE,kBAAkB,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;YAE9D,MAAM,QAAQ,GAAG,eAAe,CAAC,IAAoC,CAAC,CAAC;YACvE,IAAI,QAAQ,EAAE,CAAC;gBACX,MAAM,gBAAgB,GAAG,QAAQ,CAAC,KAAc,CAAC,CAAC;gBAClD,QAAQ,CAAC,cAAc,EAAE,kBAAkB,EAAE;oBACzC,IAAI;oBACJ,KAAK;oBACL,QAAQ,EAAE,gBAAgB;iBAC7B,CAAC,CAAC;gBACH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAC1C,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,aAAa,CAAC,eAA8B;QAChD,IAAI,OAAO,GAAG,eAAe,CAAC;QAE9B,mCAAmC;QACnC,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACpC,IAAI,MAAM,IAAI,QAAQ,IAAI,OAAO,QAAQ,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;gBAC5D,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACrC,CAAC;QACL,CAAC;QAED,OAAO,CAAC,KAAY,EAAE,EAAE;YACpB,+BAA+B;YAC/B,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;gBACpC,IAAI,CAAC,CAAC,MAAM,IAAI,QAAQ,CAAC,EAAE,CAAC;oBACxB,MAAM,cAAc,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;oBAC7C,IAAI,CAAC,cAAc;wBAAE,OAAO;gBAChC,CAAC;YACL,CAAC;YAED,OAAO,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC,CAAC;IACN,CAAC;IAED,QAAQ,CAAC,KAAc,EAAE,OAAiB;QACtC,qBAAqB;QACrB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YAC/D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,CAAC;QAED,iCAAiC;QACjC,IAAI,OAAO,KAAK,KAAK,UAAU,EAAE,CAAC;YAC9B,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACzC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;YAChD,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAChE,CAAC;IACL,CAAC;IAED,KAAK;QACD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YAC/D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,CAAC;IACL,CAAC;IAED,UAAU;QACN,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;CACJ"}
@@ -0,0 +1,36 @@
1
+ import { Binding } from './binding';
2
+ import { ITemplateProcessor } from '../../processor/types';
3
+ export declare class NodeBinding implements Binding {
4
+ private element;
5
+ private startMarker;
6
+ private endMarker;
7
+ private processor?;
8
+ private previousValue;
9
+ /** What kind of content we last rendered */
10
+ private prevKind;
11
+ /** Cached instance for a single TemplateResult */
12
+ private templateInstance;
13
+ /** strings identity of the current templateInstance */
14
+ private templateStrings;
15
+ /** Cached instances when rendering an array */
16
+ private arrayInstances;
17
+ /** Per-index strings identity for each array item */
18
+ private arrayStrings;
19
+ private textNode;
20
+ private keyedState;
21
+ constructor(element: Element, startMarker: Comment, endMarker: Comment, processor?: ITemplateProcessor | undefined);
22
+ setValue(value: unknown): Promise<void>;
23
+ private setArrayValue;
24
+ /**
25
+ * Remove DOM nodes that belong to array items from index `fromIndex` onwards.
26
+ */
27
+ private removeTrailingNodes;
28
+ private insert;
29
+ /**
30
+ * Full teardown: disconnect instances, remove DOM nodes, reset state.
31
+ */
32
+ private teardown;
33
+ clear(): void;
34
+ disconnect(): void;
35
+ }
36
+ //# sourceMappingURL=node-binding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node-binding.d.ts","sourceRoot":"","sources":["../../../../src/binding-manager/bindings/node-binding.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAiB3D,qBAAa,WAAY,YAAW,OAAO;IAyBnC,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,SAAS,CAAC;IA3BtB,OAAO,CAAC,aAAa,CAAsB;IAE3C,4CAA4C;IAC5C,OAAO,CAAC,QAAQ,CAA2B;IAG3C,kDAAkD;IAClD,OAAO,CAAC,gBAAgB,CAAa;IACrC,uDAAuD;IACvD,OAAO,CAAC,eAAe,CAAqC;IAG5D,+CAA+C;IAC/C,OAAO,CAAC,cAAc,CAAa;IACnC,qDAAqD;IACrD,OAAO,CAAC,YAAY,CAAuC;IAG3D,OAAO,CAAC,QAAQ,CAAqB;IAGrC,OAAO,CAAC,UAAU,CAA+B;gBAGrC,OAAO,EAAE,OAAO,EAChB,WAAW,EAAE,OAAO,EACpB,SAAS,EAAE,OAAO,EAClB,SAAS,CAAC,EAAE,kBAAkB,YAAA;IAGpC,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;YAyF/B,aAAa;IAmE3B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAwB3B,OAAO,CAAC,MAAM;IAId;;OAEG;IACH,OAAO,CAAC,QAAQ;IA6BhB,KAAK,IAAI,IAAI;IAIb,UAAU,IAAI,IAAI;CAOrB"}