@adaas/are-html 0.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 (365) hide show
  1. package/.conf/tsconfig.base.json +87 -0
  2. package/.conf/tsconfig.browser.json +34 -0
  3. package/.conf/tsconfig.node.json +35 -0
  4. package/.nvmrc +1 -0
  5. package/LICENSE +13 -0
  6. package/README.md +678 -0
  7. package/dist/browser/index.d.mts +521 -0
  8. package/dist/browser/index.mjs +1782 -0
  9. package/dist/browser/index.mjs.map +1 -0
  10. package/dist/node/AreBinding.attribute-C6JasbJL.d.ts +110 -0
  11. package/dist/node/AreBinding.attribute-C6qrxN8K.d.mts +110 -0
  12. package/dist/node/attributes/AreBinding.attribute.d.mts +4 -0
  13. package/dist/node/attributes/AreBinding.attribute.d.ts +4 -0
  14. package/dist/node/attributes/AreBinding.attribute.js +15 -0
  15. package/dist/node/attributes/AreBinding.attribute.js.map +1 -0
  16. package/dist/node/attributes/AreBinding.attribute.mjs +14 -0
  17. package/dist/node/attributes/AreBinding.attribute.mjs.map +1 -0
  18. package/dist/node/attributes/AreDirective.attribute.d.mts +4 -0
  19. package/dist/node/attributes/AreDirective.attribute.d.ts +4 -0
  20. package/dist/node/attributes/AreDirective.attribute.js +20 -0
  21. package/dist/node/attributes/AreDirective.attribute.js.map +1 -0
  22. package/dist/node/attributes/AreDirective.attribute.mjs +19 -0
  23. package/dist/node/attributes/AreDirective.attribute.mjs.map +1 -0
  24. package/dist/node/attributes/AreEvent.attribute.d.mts +4 -0
  25. package/dist/node/attributes/AreEvent.attribute.d.ts +4 -0
  26. package/dist/node/attributes/AreEvent.attribute.js +10 -0
  27. package/dist/node/attributes/AreEvent.attribute.js.map +1 -0
  28. package/dist/node/attributes/AreEvent.attribute.mjs +9 -0
  29. package/dist/node/attributes/AreEvent.attribute.mjs.map +1 -0
  30. package/dist/node/attributes/AreStatic.attribute.d.mts +4 -0
  31. package/dist/node/attributes/AreStatic.attribute.d.ts +4 -0
  32. package/dist/node/attributes/AreStatic.attribute.js +10 -0
  33. package/dist/node/attributes/AreStatic.attribute.js.map +1 -0
  34. package/dist/node/attributes/AreStatic.attribute.mjs +9 -0
  35. package/dist/node/attributes/AreStatic.attribute.mjs.map +1 -0
  36. package/dist/node/chunk-EQQGB2QZ.mjs +15 -0
  37. package/dist/node/chunk-EQQGB2QZ.mjs.map +1 -0
  38. package/dist/node/directives/AreComponent.directive.d.mts +2 -0
  39. package/dist/node/directives/AreComponent.directive.d.ts +2 -0
  40. package/dist/node/directives/AreComponent.directive.js +4 -0
  41. package/dist/node/directives/AreComponent.directive.js.map +1 -0
  42. package/dist/node/directives/AreComponent.directive.mjs +3 -0
  43. package/dist/node/directives/AreComponent.directive.mjs.map +1 -0
  44. package/dist/node/directives/AreDirectiveFor.directive.d.mts +41 -0
  45. package/dist/node/directives/AreDirectiveFor.directive.d.ts +41 -0
  46. package/dist/node/directives/AreDirectiveFor.directive.js +206 -0
  47. package/dist/node/directives/AreDirectiveFor.directive.js.map +1 -0
  48. package/dist/node/directives/AreDirectiveFor.directive.mjs +196 -0
  49. package/dist/node/directives/AreDirectiveFor.directive.mjs.map +1 -0
  50. package/dist/node/directives/AreDirectiveIf.directive.d.mts +15 -0
  51. package/dist/node/directives/AreDirectiveIf.directive.d.ts +15 -0
  52. package/dist/node/directives/AreDirectiveIf.directive.js +91 -0
  53. package/dist/node/directives/AreDirectiveIf.directive.js.map +1 -0
  54. package/dist/node/directives/AreDirectiveIf.directive.mjs +81 -0
  55. package/dist/node/directives/AreDirectiveIf.directive.mjs.map +1 -0
  56. package/dist/node/engine/AreHTML.compiler.d.mts +27 -0
  57. package/dist/node/engine/AreHTML.compiler.d.ts +27 -0
  58. package/dist/node/engine/AreHTML.compiler.js +150 -0
  59. package/dist/node/engine/AreHTML.compiler.js.map +1 -0
  60. package/dist/node/engine/AreHTML.compiler.mjs +140 -0
  61. package/dist/node/engine/AreHTML.compiler.mjs.map +1 -0
  62. package/dist/node/engine/AreHTML.constants.d.mts +2 -0
  63. package/dist/node/engine/AreHTML.constants.d.ts +2 -0
  64. package/dist/node/engine/AreHTML.constants.js +4 -0
  65. package/dist/node/engine/AreHTML.constants.js.map +1 -0
  66. package/dist/node/engine/AreHTML.constants.mjs +3 -0
  67. package/dist/node/engine/AreHTML.constants.mjs.map +1 -0
  68. package/dist/node/engine/AreHTML.context.d.mts +108 -0
  69. package/dist/node/engine/AreHTML.context.d.ts +108 -0
  70. package/dist/node/engine/AreHTML.context.js +155 -0
  71. package/dist/node/engine/AreHTML.context.js.map +1 -0
  72. package/dist/node/engine/AreHTML.context.mjs +154 -0
  73. package/dist/node/engine/AreHTML.context.mjs.map +1 -0
  74. package/dist/node/engine/AreHTML.engine.d.mts +21 -0
  75. package/dist/node/engine/AreHTML.engine.d.ts +21 -0
  76. package/dist/node/engine/AreHTML.engine.js +191 -0
  77. package/dist/node/engine/AreHTML.engine.js.map +1 -0
  78. package/dist/node/engine/AreHTML.engine.mjs +181 -0
  79. package/dist/node/engine/AreHTML.engine.mjs.map +1 -0
  80. package/dist/node/engine/AreHTML.interpreter.d.mts +28 -0
  81. package/dist/node/engine/AreHTML.interpreter.d.ts +28 -0
  82. package/dist/node/engine/AreHTML.interpreter.js +340 -0
  83. package/dist/node/engine/AreHTML.interpreter.js.map +1 -0
  84. package/dist/node/engine/AreHTML.interpreter.mjs +330 -0
  85. package/dist/node/engine/AreHTML.interpreter.mjs.map +1 -0
  86. package/dist/node/engine/AreHTML.lifecycle.d.mts +17 -0
  87. package/dist/node/engine/AreHTML.lifecycle.d.ts +17 -0
  88. package/dist/node/engine/AreHTML.lifecycle.js +91 -0
  89. package/dist/node/engine/AreHTML.lifecycle.js.map +1 -0
  90. package/dist/node/engine/AreHTML.lifecycle.mjs +79 -0
  91. package/dist/node/engine/AreHTML.lifecycle.mjs.map +1 -0
  92. package/dist/node/engine/AreHTML.tokenizer.d.mts +13 -0
  93. package/dist/node/engine/AreHTML.tokenizer.d.ts +13 -0
  94. package/dist/node/engine/AreHTML.tokenizer.js +83 -0
  95. package/dist/node/engine/AreHTML.tokenizer.js.map +1 -0
  96. package/dist/node/engine/AreHTML.tokenizer.mjs +71 -0
  97. package/dist/node/engine/AreHTML.tokenizer.mjs.map +1 -0
  98. package/dist/node/engine/AreHTML.transformer.d.mts +11 -0
  99. package/dist/node/engine/AreHTML.transformer.d.ts +11 -0
  100. package/dist/node/engine/AreHTML.transformer.js +44 -0
  101. package/dist/node/engine/AreHTML.transformer.js.map +1 -0
  102. package/dist/node/engine/AreHTML.transformer.mjs +32 -0
  103. package/dist/node/engine/AreHTML.transformer.mjs.map +1 -0
  104. package/dist/node/engine/AreHTML.types.d.mts +6 -0
  105. package/dist/node/engine/AreHTML.types.d.ts +6 -0
  106. package/dist/node/engine/AreHTML.types.js +4 -0
  107. package/dist/node/engine/AreHTML.types.js.map +1 -0
  108. package/dist/node/engine/AreHTML.types.mjs +3 -0
  109. package/dist/node/engine/AreHTML.types.mjs.map +1 -0
  110. package/dist/node/index.d.mts +39 -0
  111. package/dist/node/index.d.ts +39 -0
  112. package/dist/node/index.js +294 -0
  113. package/dist/node/index.js.map +1 -0
  114. package/dist/node/index.mjs +43 -0
  115. package/dist/node/index.mjs.map +1 -0
  116. package/dist/node/instructions/AddAttribute.instruction.d.mts +9 -0
  117. package/dist/node/instructions/AddAttribute.instruction.d.ts +9 -0
  118. package/dist/node/instructions/AddAttribute.instruction.js +32 -0
  119. package/dist/node/instructions/AddAttribute.instruction.js.map +1 -0
  120. package/dist/node/instructions/AddAttribute.instruction.mjs +25 -0
  121. package/dist/node/instructions/AddAttribute.instruction.mjs.map +1 -0
  122. package/dist/node/instructions/AddComment.instruction.d.mts +9 -0
  123. package/dist/node/instructions/AddComment.instruction.d.ts +9 -0
  124. package/dist/node/instructions/AddComment.instruction.js +35 -0
  125. package/dist/node/instructions/AddComment.instruction.js.map +1 -0
  126. package/dist/node/instructions/AddComment.instruction.mjs +28 -0
  127. package/dist/node/instructions/AddComment.instruction.mjs.map +1 -0
  128. package/dist/node/instructions/AddElement.instruction.d.mts +8 -0
  129. package/dist/node/instructions/AddElement.instruction.d.ts +8 -0
  130. package/dist/node/instructions/AddElement.instruction.js +32 -0
  131. package/dist/node/instructions/AddElement.instruction.js.map +1 -0
  132. package/dist/node/instructions/AddElement.instruction.mjs +25 -0
  133. package/dist/node/instructions/AddElement.instruction.mjs.map +1 -0
  134. package/dist/node/instructions/AddInterpolation.instruction.d.mts +8 -0
  135. package/dist/node/instructions/AddInterpolation.instruction.d.ts +8 -0
  136. package/dist/node/instructions/AddInterpolation.instruction.js +32 -0
  137. package/dist/node/instructions/AddInterpolation.instruction.js.map +1 -0
  138. package/dist/node/instructions/AddInterpolation.instruction.mjs +25 -0
  139. package/dist/node/instructions/AddInterpolation.instruction.mjs.map +1 -0
  140. package/dist/node/instructions/AddListener.instruction.d.mts +8 -0
  141. package/dist/node/instructions/AddListener.instruction.d.ts +8 -0
  142. package/dist/node/instructions/AddListener.instruction.js +32 -0
  143. package/dist/node/instructions/AddListener.instruction.js.map +1 -0
  144. package/dist/node/instructions/AddListener.instruction.mjs +25 -0
  145. package/dist/node/instructions/AddListener.instruction.mjs.map +1 -0
  146. package/dist/node/instructions/AddStyle.instruction.d.mts +8 -0
  147. package/dist/node/instructions/AddStyle.instruction.d.ts +8 -0
  148. package/dist/node/instructions/AddStyle.instruction.js +32 -0
  149. package/dist/node/instructions/AddStyle.instruction.js.map +1 -0
  150. package/dist/node/instructions/AddStyle.instruction.mjs +25 -0
  151. package/dist/node/instructions/AddStyle.instruction.mjs.map +1 -0
  152. package/dist/node/instructions/AddText.instruction.d.mts +8 -0
  153. package/dist/node/instructions/AddText.instruction.d.ts +8 -0
  154. package/dist/node/instructions/AddText.instruction.js +32 -0
  155. package/dist/node/instructions/AddText.instruction.js.map +1 -0
  156. package/dist/node/instructions/AddText.instruction.mjs +25 -0
  157. package/dist/node/instructions/AddText.instruction.mjs.map +1 -0
  158. package/dist/node/instructions/AreHTML.instructions.constants.d.mts +11 -0
  159. package/dist/node/instructions/AreHTML.instructions.constants.d.ts +11 -0
  160. package/dist/node/instructions/AreHTML.instructions.constants.js +15 -0
  161. package/dist/node/instructions/AreHTML.instructions.constants.js.map +1 -0
  162. package/dist/node/instructions/AreHTML.instructions.constants.mjs +15 -0
  163. package/dist/node/instructions/AreHTML.instructions.constants.mjs.map +1 -0
  164. package/dist/node/instructions/AreHTML.instructions.types.d.mts +46 -0
  165. package/dist/node/instructions/AreHTML.instructions.types.d.ts +46 -0
  166. package/dist/node/instructions/AreHTML.instructions.types.js +4 -0
  167. package/dist/node/instructions/AreHTML.instructions.types.js.map +1 -0
  168. package/dist/node/instructions/AreHTML.instructions.types.mjs +3 -0
  169. package/dist/node/instructions/AreHTML.instructions.types.mjs.map +1 -0
  170. package/dist/node/lib/AreDirective/AreDirective.component.d.mts +4 -0
  171. package/dist/node/lib/AreDirective/AreDirective.component.d.ts +4 -0
  172. package/dist/node/lib/AreDirective/AreDirective.component.js +117 -0
  173. package/dist/node/lib/AreDirective/AreDirective.component.js.map +1 -0
  174. package/dist/node/lib/AreDirective/AreDirective.component.mjs +107 -0
  175. package/dist/node/lib/AreDirective/AreDirective.component.mjs.map +1 -0
  176. package/dist/node/lib/AreDirective/AreDirective.constants.d.mts +16 -0
  177. package/dist/node/lib/AreDirective/AreDirective.constants.d.ts +16 -0
  178. package/dist/node/lib/AreDirective/AreDirective.constants.js +20 -0
  179. package/dist/node/lib/AreDirective/AreDirective.constants.js.map +1 -0
  180. package/dist/node/lib/AreDirective/AreDirective.constants.mjs +20 -0
  181. package/dist/node/lib/AreDirective/AreDirective.constants.mjs.map +1 -0
  182. package/dist/node/lib/AreDirective/AreDirective.context.d.mts +9 -0
  183. package/dist/node/lib/AreDirective/AreDirective.context.d.ts +9 -0
  184. package/dist/node/lib/AreDirective/AreDirective.context.js +14 -0
  185. package/dist/node/lib/AreDirective/AreDirective.context.js.map +1 -0
  186. package/dist/node/lib/AreDirective/AreDirective.context.mjs +13 -0
  187. package/dist/node/lib/AreDirective/AreDirective.context.mjs.map +1 -0
  188. package/dist/node/lib/AreDirective/AreDirective.meta.d.mts +7 -0
  189. package/dist/node/lib/AreDirective/AreDirective.meta.d.ts +7 -0
  190. package/dist/node/lib/AreDirective/AreDirective.meta.js +14 -0
  191. package/dist/node/lib/AreDirective/AreDirective.meta.js.map +1 -0
  192. package/dist/node/lib/AreDirective/AreDirective.meta.mjs +13 -0
  193. package/dist/node/lib/AreDirective/AreDirective.meta.mjs.map +1 -0
  194. package/dist/node/lib/AreDirective/AreDirective.types.d.mts +17 -0
  195. package/dist/node/lib/AreDirective/AreDirective.types.d.ts +17 -0
  196. package/dist/node/lib/AreDirective/AreDirective.types.js +4 -0
  197. package/dist/node/lib/AreDirective/AreDirective.types.js.map +1 -0
  198. package/dist/node/lib/AreDirective/AreDirective.types.mjs +3 -0
  199. package/dist/node/lib/AreDirective/AreDirective.types.mjs.map +1 -0
  200. package/dist/node/lib/AreHTML/AreHTML.tokenizer.d.mts +13 -0
  201. package/dist/node/lib/AreHTML/AreHTML.tokenizer.d.ts +13 -0
  202. package/dist/node/lib/AreHTML/AreHTML.tokenizer.js +82 -0
  203. package/dist/node/lib/AreHTML/AreHTML.tokenizer.js.map +1 -0
  204. package/dist/node/lib/AreHTML/AreHTML.tokenizer.mjs +70 -0
  205. package/dist/node/lib/AreHTML/AreHTML.tokenizer.mjs.map +1 -0
  206. package/dist/node/lib/AreHTMLAttribute/AreHTML.attribute.d.mts +4 -0
  207. package/dist/node/lib/AreHTMLAttribute/AreHTML.attribute.d.ts +4 -0
  208. package/dist/node/lib/AreHTMLAttribute/AreHTML.attribute.js +13 -0
  209. package/dist/node/lib/AreHTMLAttribute/AreHTML.attribute.js.map +1 -0
  210. package/dist/node/lib/AreHTMLAttribute/AreHTML.attribute.mjs +12 -0
  211. package/dist/node/lib/AreHTMLAttribute/AreHTML.attribute.mjs.map +1 -0
  212. package/dist/node/lib/AreHTMLNode/AreHTMLNode.d.mts +4 -0
  213. package/dist/node/lib/AreHTMLNode/AreHTMLNode.d.ts +4 -0
  214. package/dist/node/lib/AreHTMLNode/AreHTMLNode.js +82 -0
  215. package/dist/node/lib/AreHTMLNode/AreHTMLNode.js.map +1 -0
  216. package/dist/node/lib/AreHTMLNode/AreHTMLNode.mjs +75 -0
  217. package/dist/node/lib/AreHTMLNode/AreHTMLNode.mjs.map +1 -0
  218. package/dist/node/lib/AreRoot/AreRoot.component.d.mts +13 -0
  219. package/dist/node/lib/AreRoot/AreRoot.component.d.ts +13 -0
  220. package/dist/node/lib/AreRoot/AreRoot.component.js +117 -0
  221. package/dist/node/lib/AreRoot/AreRoot.component.js.map +1 -0
  222. package/dist/node/lib/AreRoot/AreRoot.component.mjs +107 -0
  223. package/dist/node/lib/AreRoot/AreRoot.component.mjs.map +1 -0
  224. package/dist/node/lib/AreStyle/AreStyle.context.d.mts +8 -0
  225. package/dist/node/lib/AreStyle/AreStyle.context.d.ts +8 -0
  226. package/dist/node/lib/AreStyle/AreStyle.context.js +16 -0
  227. package/dist/node/lib/AreStyle/AreStyle.context.js.map +1 -0
  228. package/dist/node/lib/AreStyle/AreStyle.context.mjs +15 -0
  229. package/dist/node/lib/AreStyle/AreStyle.context.mjs.map +1 -0
  230. package/dist/node/lib/AreStyle/AreStyle.types.d.mts +2 -0
  231. package/dist/node/lib/AreStyle/AreStyle.types.d.ts +2 -0
  232. package/dist/node/lib/AreStyle/AreStyle.types.js +4 -0
  233. package/dist/node/lib/AreStyle/AreStyle.types.js.map +1 -0
  234. package/dist/node/lib/AreStyle/AreStyle.types.mjs +3 -0
  235. package/dist/node/lib/AreStyle/AreStyle.types.mjs.map +1 -0
  236. package/dist/node/lib/AreWatcher/AreWatcher.component.d.mts +18 -0
  237. package/dist/node/lib/AreWatcher/AreWatcher.component.d.ts +18 -0
  238. package/dist/node/lib/AreWatcher/AreWatcher.component.js +78 -0
  239. package/dist/node/lib/AreWatcher/AreWatcher.component.js.map +1 -0
  240. package/dist/node/lib/AreWatcher/AreWatcher.component.mjs +71 -0
  241. package/dist/node/lib/AreWatcher/AreWatcher.component.mjs.map +1 -0
  242. package/dist/node/nodes/AreComment.d.mts +10 -0
  243. package/dist/node/nodes/AreComment.d.ts +10 -0
  244. package/dist/node/nodes/AreComment.js +19 -0
  245. package/dist/node/nodes/AreComment.js.map +1 -0
  246. package/dist/node/nodes/AreComment.mjs +18 -0
  247. package/dist/node/nodes/AreComment.mjs.map +1 -0
  248. package/dist/node/nodes/AreComponent.d.mts +17 -0
  249. package/dist/node/nodes/AreComponent.d.ts +17 -0
  250. package/dist/node/nodes/AreComponent.js +35 -0
  251. package/dist/node/nodes/AreComponent.js.map +1 -0
  252. package/dist/node/nodes/AreComponent.mjs +28 -0
  253. package/dist/node/nodes/AreComponent.mjs.map +1 -0
  254. package/dist/node/nodes/AreInterpolation.d.mts +10 -0
  255. package/dist/node/nodes/AreInterpolation.d.ts +10 -0
  256. package/dist/node/nodes/AreInterpolation.js +19 -0
  257. package/dist/node/nodes/AreInterpolation.js.map +1 -0
  258. package/dist/node/nodes/AreInterpolation.mjs +18 -0
  259. package/dist/node/nodes/AreInterpolation.mjs.map +1 -0
  260. package/dist/node/nodes/AreRoot.d.mts +21 -0
  261. package/dist/node/nodes/AreRoot.d.ts +21 -0
  262. package/dist/node/nodes/AreRoot.js +41 -0
  263. package/dist/node/nodes/AreRoot.js.map +1 -0
  264. package/dist/node/nodes/AreRoot.mjs +34 -0
  265. package/dist/node/nodes/AreRoot.mjs.map +1 -0
  266. package/dist/node/nodes/AreText.d.mts +10 -0
  267. package/dist/node/nodes/AreText.d.ts +10 -0
  268. package/dist/node/nodes/AreText.js +19 -0
  269. package/dist/node/nodes/AreText.js.map +1 -0
  270. package/dist/node/nodes/AreText.mjs +18 -0
  271. package/dist/node/nodes/AreText.mjs.map +1 -0
  272. package/dist/node/signals/AreRoute.signal.d.mts +12 -0
  273. package/dist/node/signals/AreRoute.signal.d.ts +12 -0
  274. package/dist/node/signals/AreRoute.signal.js +25 -0
  275. package/dist/node/signals/AreRoute.signal.js.map +1 -0
  276. package/dist/node/signals/AreRoute.signal.mjs +24 -0
  277. package/dist/node/signals/AreRoute.signal.mjs.map +1 -0
  278. package/docs/a-logo-docs.png +0 -0
  279. package/examples/dashboard/concept.ts +60 -0
  280. package/examples/dashboard/containers/UI.container.ts +233 -0
  281. package/examples/dashboard/dist/index.html +22 -0
  282. package/examples/dashboard/dist/mnzfypsd-6zjt7w.js +11454 -0
  283. package/examples/dashboard/dist/styles.css +792 -0
  284. package/examples/dashboard/public/index.html +22 -0
  285. package/examples/dashboard/public/styles.css +792 -0
  286. package/examples/dashboard/src/components/DashboardApp.component.ts +31 -0
  287. package/examples/dashboard/src/components/DashboardHeader.component.ts +40 -0
  288. package/examples/dashboard/src/components/DashboardLogo.component.ts +29 -0
  289. package/examples/dashboard/src/components/DashboardMain.component.ts +57 -0
  290. package/examples/dashboard/src/components/DashboardMenu.component.ts +94 -0
  291. package/examples/dashboard/src/components/DashboardNav.component.ts +28 -0
  292. package/examples/dashboard/src/components/DashboardNavItem.component.ts +32 -0
  293. package/examples/dashboard/src/components/DashboardSidebar.component.ts +43 -0
  294. package/examples/dashboard/src/components/DashboardStatCard.component.ts +71 -0
  295. package/examples/dashboard/src/components/DashboardStats.component.ts +28 -0
  296. package/examples/dashboard/src/components/DashboardTable.component.ts +138 -0
  297. package/examples/dashboard/src/components/DashboardUserCard.component.ts +39 -0
  298. package/examples/dashboard/src/concept.ts +93 -0
  299. package/examples/jumpstart/concept.ts +60 -0
  300. package/examples/jumpstart/containers/UI.container.ts +233 -0
  301. package/examples/jumpstart/dist/index.html +104 -0
  302. package/examples/jumpstart/dist/mnpl1g4i-nobz9g.js +10882 -0
  303. package/examples/jumpstart/dist/static/css/main.css +40 -0
  304. package/examples/jumpstart/dist/static/img/test.png +0 -0
  305. package/examples/jumpstart/public/index.html +104 -0
  306. package/examples/jumpstart/public/static/css/main.css +40 -0
  307. package/examples/jumpstart/public/static/img/test.png +0 -0
  308. package/examples/jumpstart/src/components/A-Btn.component.ts +150 -0
  309. package/examples/jumpstart/src/components/A-Input.component.ts +78 -0
  310. package/examples/jumpstart/src/components/A-Navigation.component.ts +167 -0
  311. package/examples/jumpstart/src/components/List.component.ts +138 -0
  312. package/examples/jumpstart/src/components/PromptTextArea.component.ts +359 -0
  313. package/examples/jumpstart/src/components/SignInComponent.component.ts +127 -0
  314. package/examples/jumpstart/src/concept.ts +105 -0
  315. package/jest.config.ts +61 -0
  316. package/package.json +110 -0
  317. package/src/attributes/AreBinding.attribute.ts +19 -0
  318. package/src/attributes/AreDirective.attribute.ts +26 -0
  319. package/src/attributes/AreEvent.attribute.ts +5 -0
  320. package/src/attributes/AreStatic.attribute.ts +6 -0
  321. package/src/directives/AreComponent.directive.ts +0 -0
  322. package/src/directives/AreDirectiveFor.directive.ts +322 -0
  323. package/src/directives/AreDirectiveIf.directive.ts +130 -0
  324. package/src/engine/AreHTML.compiler.ts +226 -0
  325. package/src/engine/AreHTML.constants.ts +2 -0
  326. package/src/engine/AreHTML.context.ts +196 -0
  327. package/src/engine/AreHTML.engine.ts +210 -0
  328. package/src/engine/AreHTML.interpreter.ts +466 -0
  329. package/src/engine/AreHTML.lifecycle.ts +96 -0
  330. package/src/engine/AreHTML.tokenizer.ts +90 -0
  331. package/src/engine/AreHTML.transformer.ts +37 -0
  332. package/src/engine/AreHTML.types.ts +6 -0
  333. package/src/index.ts +80 -0
  334. package/src/instructions/AddAttribute.instruction.ts +25 -0
  335. package/src/instructions/AddComment.instruction.ts +27 -0
  336. package/src/instructions/AddElement.instruction.ts +22 -0
  337. package/src/instructions/AddInterpolation.instruction.ts +24 -0
  338. package/src/instructions/AddListener.instruction.ts +24 -0
  339. package/src/instructions/AddStyle.instruction.ts +24 -0
  340. package/src/instructions/AddText.instruction.ts +21 -0
  341. package/src/instructions/AreHTML.instructions.constants.ts +11 -0
  342. package/src/instructions/AreHTML.instructions.types.ts +51 -0
  343. package/src/lib/AreDirective/AreDirective.component.ts +124 -0
  344. package/src/lib/AreDirective/AreDirective.constants.ts +16 -0
  345. package/src/lib/AreDirective/AreDirective.context.ts +16 -0
  346. package/src/lib/AreDirective/AreDirective.meta.ts +9 -0
  347. package/src/lib/AreDirective/AreDirective.types.ts +14 -0
  348. package/src/lib/AreHTML/AreHTML.tokenizer.ts +86 -0
  349. package/src/lib/AreHTMLAttribute/AreHTML.attribute.ts +13 -0
  350. package/src/lib/AreHTMLNode/AreHTMLNode.ts +84 -0
  351. package/src/lib/AreRoot/AreRoot.component.ts +134 -0
  352. package/src/lib/AreStyle/AreStyle.context.ts +20 -0
  353. package/src/lib/AreStyle/AreStyle.types.ts +0 -0
  354. package/src/lib/AreWatcher/AreWatcher.component.ts +84 -0
  355. package/src/nodes/AreComment.ts +17 -0
  356. package/src/nodes/AreComponent.ts +25 -0
  357. package/src/nodes/AreInterpolation.ts +16 -0
  358. package/src/nodes/AreRoot.ts +29 -0
  359. package/src/nodes/AreText.ts +17 -0
  360. package/src/signals/AreRoute.signal.ts +27 -0
  361. package/tests/AreTokenizer.test.ts +260 -0
  362. package/tests/jest.setup.ts +30 -0
  363. package/tsconfig.json +60 -0
  364. package/tslint.json +98 -0
  365. package/tsup.config.ts +108 -0
@@ -0,0 +1,138 @@
1
+ import { A_Caller, A_Inject } from "@adaas/a-concept";
2
+ import { A_Logger } from "@adaas/a-utils/a-logger";
3
+ import { Are } from "@adaas/are";
4
+ import { AreContext } from "@adaas/are";
5
+ import { AreEvent } from "@adaas/are";
6
+ import { AreNode } from "@adaas/are";
7
+ import { AreStore } from "@adaas/are";
8
+
9
+
10
+ export class ListComponent extends Are {
11
+
12
+ @Are.Template
13
+ async template(
14
+ @A_Inject(A_Caller) node: AreNode,
15
+ ) {
16
+
17
+
18
+ node.setContent(`
19
+ <div class="menu-section">Main</div>
20
+ <ul class="menu">
21
+ <li @click="$handleClick('Dashboard')" :class="active==='Dashboard' ? 'menu-item-active' : ''" class="menu-item "><span class="menu-icon">⊞</span> <span class="menu-text">{{item1}}</span></li>
22
+ <li $if="active=='Dashboard'" @click="$handleClick('Users')" :class="active==='Users' ? 'menu-item-active' : ''" class="menu-item"><span class="menu-icon">⊡</span> <span class="menu-text">{{item2}}</span> <span class="menu-badge">{{usersBadge}}</span></li>
23
+ <li @click="$handleClick('Products')" :class="active==='Products' ? 'menu-item-active' : ''" class="menu-item"><span class="menu-icon">⊠</span> <span class="menu-text">{{item3}}</span></li>
24
+ <li @click="$handleClick('Orders')" :class="active==='Orders' ? 'menu-item-active' : ''" class="menu-item"><span class="menu-icon">⊟</span> <span class="menu-text">{{item4}}</span></li>
25
+ </ul>
26
+ <div class="menu-section">System</div>
27
+ <button @click="$add">Add +</button>
28
+ <ul class="menu">
29
+ <li
30
+ $for="item in items" @click="$handleClick(item.name)"
31
+ $if="active=='Dashboard'"
32
+ :class="active===item.name ? 'menu-item-active' : ''"
33
+ class="menu-item">
34
+ <span class="menu-icon">⊙</span>
35
+ <span class="menu-text">{{item.name}}</span>
36
+ <span $if="item.badge > 0" class="menu-badge">{{item.badge}}</span>
37
+ <button @click="$remove(item)">+</button>
38
+ </li>
39
+ </ul>
40
+ `);
41
+ }
42
+
43
+ @Are.Data
44
+ async data(
45
+ @A_Inject(AreStore) store: AreStore,
46
+ ) {
47
+ store.set({
48
+ active: 'Dashboard',
49
+ item1: 'Dashboard',
50
+ item2: 'Users',
51
+ item3: 'Products',
52
+ item4: 'Orders',
53
+ item5: 'Messages',
54
+ item6: 'Settings',
55
+ usersBadge: '24',
56
+ msgBadge: '3',
57
+ items: [
58
+ { name: 'Messages', badge: 3 },
59
+ { name: 'Settings', badge: 0 },
60
+ ]
61
+ });
62
+ }
63
+ @Are.EventHandler
64
+ add(
65
+ @A_Inject(A_Caller) node: AreNode,
66
+ @A_Inject(AreEvent) event: AreEvent,
67
+ @A_Inject(AreContext) context: AreContext,
68
+ @A_Inject(AreStore) store: AreStore,
69
+ @A_Inject(A_Logger) logger: A_Logger,
70
+ ) {
71
+ const currentItems = store.get('items') || [];
72
+
73
+ currentItems.push({
74
+ name: `Item ${currentItems.length + 1}`,
75
+ badge: 0
76
+ });
77
+
78
+ store.set('items', currentItems);
79
+ }
80
+
81
+
82
+ @Are.EventHandler
83
+ remove(
84
+ @A_Inject(A_Caller) node: AreNode,
85
+ @A_Inject(AreEvent) event: AreEvent,
86
+ @A_Inject(AreContext) context: AreContext,
87
+ @A_Inject(AreStore) store: AreStore,
88
+ @A_Inject(A_Logger) logger: A_Logger,
89
+ ) {
90
+ const itemToRemove = event.get('args')?.[0];
91
+
92
+ console.log('Removing item:', itemToRemove, 'from store:', store);
93
+
94
+ if (!itemToRemove) {
95
+ logger.warning('No item specified for removal');
96
+ return;
97
+ }
98
+
99
+ const currentItems = store.get('items') || [];
100
+ const updatedItems = currentItems.filter((item: any) => item.name !== itemToRemove.name);
101
+
102
+ store.set('items', updatedItems);
103
+ }
104
+
105
+ @Are.EventHandler
106
+ async handleClick(
107
+ @A_Inject(A_Caller) node: AreNode,
108
+ @A_Inject(AreEvent) event: AreEvent,
109
+ @A_Inject(AreContext) context: AreContext,
110
+ @A_Inject(AreStore) store: AreStore,
111
+ @A_Inject(A_Logger) logger: A_Logger,
112
+ ) {
113
+ try {
114
+ console.log('Menu item clicked!', event.get('args'), store);
115
+
116
+ const item = event.get('args')?.[0] || 'Dashboard';
117
+
118
+
119
+ store.set('active', item);
120
+
121
+ // for (const root of context.roots) {
122
+ // root.update();
123
+ // }
124
+
125
+ // node.parent!.update();
126
+ context.endPerformance('Click');
127
+ logger.info(`Menu item clicked: ${item}`, ...context.performance);
128
+
129
+ // store.owner.parent?.emit(new AreEvent('menuItemClicked').set('section', item));
130
+
131
+ } catch (error) {
132
+ logger.error(error);
133
+ }
134
+
135
+
136
+ // store.set('active', store.get('active') === 'menu-item-active' ? '' : 'menu-item-active');
137
+ }
138
+ }
@@ -0,0 +1,359 @@
1
+ import { A_Caller, A_Feature, A_Inject, A_Scope } from "@adaas/a-concept";
2
+ import { A_Logger } from "@adaas/a-utils/a-logger";
3
+ import { Are, AreEvent, AreNode, AreScene, AreStore } from "@adaas/are";
4
+
5
+
6
+ export class PromptTextArea extends Are {
7
+
8
+ @Are.Template
9
+ async template(
10
+ @A_Inject(A_Caller) node: AreNode,
11
+ @A_Inject(A_Logger) logger: A_Logger
12
+ ) {
13
+ logger.info('blue', `PromptTextArea template called... : <${node.aseid.entity}> : `, node.aseid.toString());
14
+
15
+ node.setTemplate(`
16
+ <div class="prompt-textarea-container">
17
+ <div class="textarea-wrapper">
18
+ <textarea
19
+ $no-update
20
+ @input="onChange"
21
+ :value="textValue"
22
+ :placeholder="placeholder"
23
+ :rows="rows"
24
+ :maxlength="maxLength"
25
+ class="prompt-textarea"
26
+ ></textarea>
27
+ <div class="character-count">
28
+ <span class="count">{{textValue.length}}</span>
29
+ <span class="max-count">/ {{maxLength}}</span>
30
+ </div>
31
+ </div>
32
+
33
+ <div class="textarea-actions">
34
+ <button
35
+ @click="onClear"
36
+ class="clear-btn"
37
+ :disabled="textValue.length === 0"
38
+ >
39
+ Clear
40
+ </button>
41
+ <button
42
+ @click="onSubmit"
43
+ class="submit-btn"
44
+ :disabled="textValue.trim().length === 0"
45
+ >
46
+ Submit
47
+ </button>
48
+ </div>
49
+
50
+ <div class="preview-section" v-if="showPreview && textValue.trim().length > 0">
51
+ <h4 class="preview-title">Preview:</h4>
52
+ <div class="preview-content">{{textValue}}</div>
53
+ </div>
54
+ </div>
55
+ `);
56
+ }
57
+
58
+ @Are.Styles
59
+ async styles(
60
+ @A_Inject(A_Caller) node: AreNode,
61
+ @A_Inject(A_Logger) logger: A_Logger
62
+ ) {
63
+ logger.info('blue', `PromptTextArea styles applied... : <${node.aseid.entity}> : `, node.aseid.toString());
64
+
65
+ node.setStyles(`
66
+ .prompt-textarea-container {
67
+ width: 100%;
68
+ max-width: 600px;
69
+ margin: 0 auto;
70
+ padding: 20px;
71
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
72
+ border-radius: 16px;
73
+ box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
74
+ font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
75
+ }
76
+
77
+ .textarea-wrapper {
78
+ position: relative;
79
+ margin-bottom: 16px;
80
+ }
81
+
82
+ .prompt-textarea {
83
+ width: 100%;
84
+ min-height: 120px;
85
+ padding: 16px;
86
+ border: 2px solid rgba(255, 255, 255, 0.2);
87
+ border-radius: 12px;
88
+ background: rgba(255, 255, 255, 0.95);
89
+ color: #333;
90
+ font-size: 16px;
91
+ line-height: 1.5;
92
+ resize: vertical;
93
+ outline: none;
94
+ transition: all 0.3s ease;
95
+ box-sizing: border-box;
96
+ }
97
+
98
+ .prompt-textarea:focus {
99
+ border-color: #4f46e5;
100
+ box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.1);
101
+ background: rgba(255, 255, 255, 1);
102
+ }
103
+
104
+ .prompt-textarea::placeholder {
105
+ color: #888;
106
+ font-style: italic;
107
+ }
108
+
109
+ .character-count {
110
+ position: absolute;
111
+ bottom: 8px;
112
+ right: 12px;
113
+ font-size: 12px;
114
+ color: #666;
115
+ background: rgba(255, 255, 255, 0.9);
116
+ padding: 2px 6px;
117
+ border-radius: 4px;
118
+ pointer-events: none;
119
+ }
120
+
121
+ .count {
122
+ font-weight: 600;
123
+ color: #4f46e5;
124
+ }
125
+
126
+ .max-count {
127
+ color: #888;
128
+ }
129
+
130
+ .textarea-actions {
131
+ display: flex;
132
+ gap: 12px;
133
+ justify-content: flex-end;
134
+ margin-bottom: 16px;
135
+ }
136
+
137
+ .clear-btn,
138
+ .submit-btn {
139
+ padding: 12px 24px;
140
+ border: none;
141
+ border-radius: 8px;
142
+ font-size: 14px;
143
+ font-weight: 600;
144
+ cursor: pointer;
145
+ transition: all 0.3s ease;
146
+ position: relative;
147
+ overflow: hidden;
148
+ }
149
+
150
+ .clear-btn {
151
+ background: linear-gradient(135deg, #ff6b6b 0%, #ee5a52 100%);
152
+ color: white;
153
+ box-shadow: 0 4px 15px rgba(255, 107, 107, 0.3);
154
+ }
155
+
156
+ .clear-btn:hover:not(:disabled) {
157
+ transform: translateY(-2px);
158
+ box-shadow: 0 6px 20px rgba(255, 107, 107, 0.4);
159
+ }
160
+
161
+ .clear-btn:active:not(:disabled) {
162
+ transform: translateY(0);
163
+ }
164
+
165
+ .submit-btn {
166
+ background: linear-gradient(135deg, #4ade80 0%, #22c55e 100%);
167
+ color: white;
168
+ box-shadow: 0 4px 15px rgba(74, 222, 128, 0.3);
169
+ }
170
+
171
+ .submit-btn:hover:not(:disabled) {
172
+ transform: translateY(-2px);
173
+ box-shadow: 0 6px 20px rgba(74, 222, 128, 0.4);
174
+ }
175
+
176
+ .submit-btn:active:not(:disabled) {
177
+ transform: translateY(0);
178
+ }
179
+
180
+ .clear-btn:disabled,
181
+ .submit-btn:disabled {
182
+ background: #d1d5db;
183
+ color: #9ca3af;
184
+ cursor: not-allowed;
185
+ box-shadow: none;
186
+ transform: none;
187
+ }
188
+
189
+ .preview-section {
190
+ background: rgba(255, 255, 255, 0.95);
191
+ border-radius: 12px;
192
+ padding: 16px;
193
+ border: 2px solid rgba(255, 255, 255, 0.2);
194
+ }
195
+
196
+ .preview-title {
197
+ margin: 0 0 12px 0;
198
+ color: #4f46e5;
199
+ font-size: 14px;
200
+ font-weight: 600;
201
+ text-transform: uppercase;
202
+ letter-spacing: 0.5px;
203
+ }
204
+
205
+ .preview-content {
206
+ color: #333;
207
+ line-height: 1.6;
208
+ white-space: pre-wrap;
209
+ word-wrap: break-word;
210
+ background: #f8fafc;
211
+ padding: 12px;
212
+ border-radius: 8px;
213
+ border-left: 4px solid #4f46e5;
214
+ max-height: 200px;
215
+ overflow-y: auto;
216
+ }
217
+
218
+ /* Responsive Design */
219
+ @media (max-width: 768px) {
220
+ .prompt-textarea-container {
221
+ padding: 16px;
222
+ margin: 0 16px;
223
+ max-width: none;
224
+ }
225
+
226
+ .textarea-actions {
227
+ flex-direction: column;
228
+ }
229
+
230
+ .clear-btn,
231
+ .submit-btn {
232
+ width: 100%;
233
+ }
234
+ }
235
+
236
+ /* Animation for submit button */
237
+ .submit-btn::before {
238
+ content: '';
239
+ position: absolute;
240
+ top: 0;
241
+ left: -100%;
242
+ width: 100%;
243
+ height: 100%;
244
+ background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
245
+ transition: left 0.5s;
246
+ }
247
+
248
+ .submit-btn:hover::before {
249
+ left: 100%;
250
+ }
251
+ `);
252
+ }
253
+
254
+ @Are.Data
255
+ async data(
256
+ @A_Inject(AreStore) store: AreStore,
257
+ ) {
258
+ store.set({
259
+ placeholder: 'Enter your message here...',
260
+ textValue: '',
261
+ rows: 5,
262
+ maxLength: 500,
263
+ showPreview: true,
264
+ lastSubmittedValue: ''
265
+ });
266
+ }
267
+
268
+ @Are.EventHandler
269
+ async A_UI_NODE_onBeforeLoad(
270
+ @A_Inject(AreNode) node: AreNode,
271
+ @A_Inject(A_Scope) scope: A_Scope,
272
+ @A_Inject(AreStore) store: AreStore,
273
+ @A_Inject(A_Logger) logger: A_Logger,
274
+ ): Promise<void> {
275
+ logger.log('green', `PromptTextArea is initializing... : <${node.aseid.entity}> : `, node.aseid.toString());
276
+ }
277
+
278
+ @Are.EventHandler
279
+ async onChange(
280
+ @A_Inject(A_Scope) scope: A_Scope,
281
+ @A_Inject(A_Caller) node: AreNode,
282
+ @A_Inject(AreStore) store: AreStore,
283
+ @A_Inject(A_Logger) logger: A_Logger,
284
+ @A_Inject(AreEvent) event: AreEvent<InputEvent>,
285
+ @A_Inject(AreScene) scene: AreScene,
286
+ ) {
287
+ if (event.data.target === null
288
+ ||
289
+ store.get('textValue') === (event.data.target as HTMLTextAreaElement).value
290
+ ) return;
291
+
292
+ const newValue = (event.data.target as HTMLTextAreaElement).value;
293
+ const maxLength = store.get('maxLength');
294
+
295
+ // Enforce character limit
296
+ if (newValue.length > maxLength) {
297
+ (event.data.target as HTMLTextAreaElement).value = newValue.substring(0, maxLength);
298
+ return;
299
+ }
300
+
301
+ logger.log('green', `PromptTextArea onChange event triggered... : <${node.aseid.entity}> : `, node.aseid.toString(), newValue);
302
+
303
+ store.set('textValue', newValue);
304
+ await node.update();
305
+ }
306
+
307
+ @Are.EventHandler
308
+ async onSubmit(
309
+ @A_Inject(A_Scope) scope: A_Scope,
310
+ @A_Inject(A_Caller) node: AreNode,
311
+ @A_Inject(AreStore) store: AreStore,
312
+ @A_Inject(A_Logger) logger: A_Logger,
313
+ @A_Inject(AreEvent) event: AreEvent<MouseEvent>,
314
+ @A_Inject(AreScene) scene: AreScene,
315
+ ) {
316
+ const textValue = store.get('textValue');
317
+
318
+ if (textValue.trim().length === 0) {
319
+ logger.warning('yellow', 'Cannot submit empty text');
320
+ return;
321
+ }
322
+
323
+ logger.log('green', `PromptTextArea onSubmit event triggered... : <${node.aseid.entity}> : `, node.aseid.toString(), textValue);
324
+
325
+ // Store the submitted value for potential future reference
326
+ store.set('lastSubmittedValue', textValue);
327
+
328
+ // Here you could emit a custom event or call a service
329
+ // For now, we'll just log the submission
330
+ console.log('Text submitted:', textValue);
331
+
332
+ // Optionally clear after submit
333
+ // store.set('textValue', '');
334
+ // await node.update();
335
+ }
336
+
337
+ @Are.EventHandler
338
+ async onClear(
339
+ @A_Inject(A_Scope) scope: A_Scope,
340
+ @A_Inject(A_Caller) node: AreNode,
341
+ @A_Inject(AreStore) store: AreStore,
342
+ @A_Inject(A_Logger) logger: A_Logger,
343
+ @A_Inject(AreEvent) event: AreEvent<MouseEvent>,
344
+ @A_Inject(AreScene) scene: AreScene,
345
+ ) {
346
+ logger.log('green', `PromptTextArea onClear event triggered... : <${node.aseid.entity}> : `, node.aseid.toString());
347
+
348
+ store.set('textValue', '');
349
+ await node.update();
350
+
351
+ // Focus back to textarea after clearing
352
+ setTimeout(() => {
353
+ const textarea = (event.data.target as HTMLElement)?.closest('.prompt-textarea-container')?.querySelector('.prompt-textarea') as HTMLTextAreaElement;
354
+ if (textarea) {
355
+ textarea.focus();
356
+ }
357
+ }, 100);
358
+ }
359
+ }
@@ -0,0 +1,127 @@
1
+ import { A_Caller, A_Concept, A_Context, A_Feature, A_Inject, A_Scope } from "@adaas/a-concept";
2
+ import { A_Logger } from "@adaas/a-utils/a-logger";
3
+ import { Are, AreNode, AreStore } from "@adaas/are";
4
+
5
+ export function validateEmail(email: string): boolean {
6
+ return /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email);
7
+ }
8
+
9
+ export function showAlert(message: string): void {
10
+ alert(message);
11
+ }
12
+
13
+ export class SignInComponent extends Are {
14
+
15
+
16
+ @Are.Data
17
+ async data(
18
+ @A_Inject(AreStore) store: AreStore,
19
+ @A_Inject(A_Logger) logger: A_Logger,
20
+ ) {
21
+
22
+ store.set({
23
+ btnName: 'Sign In'
24
+ });
25
+ }
26
+
27
+ @Are.Styles
28
+ async styles(
29
+ @A_Inject(A_Caller) node: AreNode,
30
+ ): Promise<void> {
31
+ node.setStyles(`
32
+ .card {
33
+ background-color: #f9f9f9;
34
+ border: 1px solid #ddd;
35
+ border-radius: 8px;
36
+ padding: 20px;
37
+ max-width: 300px;
38
+ margin: 0 auto;
39
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
40
+ position:absolute;
41
+ top:50%;
42
+ left:50%;
43
+ transform: translate(-50%, -50%);
44
+ }
45
+ ` );
46
+ }
47
+
48
+ @Are.Template
49
+ async template(
50
+ @A_Inject(A_Caller) node: AreNode,
51
+ @A_Inject(A_Logger) logger: A_Logger,
52
+ ): Promise<void> {
53
+ logger.info('blue', `SignInComponent template called... : <${node.aseid.entity}> : `, node.aseid.toString());
54
+
55
+ node.setTemplate(`
56
+ <div class="card">
57
+ <h2>Sign In</h2>
58
+ <input type="email" id="email" placeholder="Email" />
59
+ <input type="password" id="password" placeholder="Password" />
60
+ <a-btn :name="btnName" :style="{ color: 'red' }"></a-btn>
61
+ </div>
62
+ `);
63
+ }
64
+
65
+
66
+ // @A_Feature.Extend({
67
+ // scope: [SignInComponent]
68
+ // })
69
+ // async A_UI_NODE_onBeforeLoad(
70
+ // @A_Inject(AreNode) node: AreNode,
71
+ // @A_Inject(A_Scope) scope: A_Scope,
72
+ // @A_Inject(A_UI_NodeStore) store: A_UI_NodeStore,
73
+ // @A_Inject(A_Logger) logger: A_Logger,
74
+ // ): Promise<void> {
75
+
76
+ // logger.log('green', `SignInComponent is initializing... : <${node.aseid.entity}> : `, node.aseid.toString());
77
+
78
+
79
+ // store.data.set('btnName', 'Custom Sign In Button');
80
+ // }
81
+
82
+
83
+ // private addListeners(): void {
84
+ // const btn = document.getElementById("signInBtn") as HTMLButtonElement;
85
+ // btn.addEventListener("click", () => this.signIn());
86
+ // }
87
+
88
+ // private async signIn(): Promise<void> {
89
+ // const email = (document.getElementById("email") as HTMLInputElement).value;
90
+ // const password = (document.getElementById("password") as HTMLInputElement).value;
91
+
92
+ // const signInCommand = new SignInCommand({
93
+ // username: email,
94
+ // password
95
+ // });
96
+
97
+
98
+ // A_Context.scope(this).register(signInCommand);
99
+
100
+ // await signInCommand.execute();
101
+
102
+ // console.log("SignIn Command Result:", signInCommand.toJSON());
103
+ // }
104
+
105
+
106
+ // @A_Feature.Extend({
107
+ // name: A_CommandFeatures.onComplete,
108
+ // scope: {
109
+ // include: [SignInCommand]
110
+ // }
111
+ // })
112
+ // async handleSuccessSignIn(
113
+ // @A_Inject(A_Memory) memory: A_Memory<{ token: SerializedToken }>,
114
+ // @A_Inject(A_Caller) command: SignInCommand,
115
+ // ) {
116
+
117
+ // console.log("Sign-in completed with result:", command.result);
118
+
119
+ // alert(command.result)
120
+
121
+ // const resultToken = await memory.get('token')
122
+
123
+ // const token = new Token(resultToken);
124
+
125
+ // memory.set('token', token as any);
126
+ // }
127
+ }