@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,792 @@
1
+ /* ── ARE custom element wrappers ────────── */
2
+ are-root,
3
+ dashboard-app {
4
+ display: block;
5
+ min-height: 100vh;
6
+ }
7
+
8
+ dashboard-header,
9
+ dashboard-sidebar,
10
+ dashboard-main,
11
+ dashboard-logo,
12
+ dashboard-nav,
13
+ dashboard-nav-item,
14
+ dashboard-user-card,
15
+ dashboard-menu,
16
+ dashboard-stats,
17
+ dashboard-stat-card,
18
+ dashboard-table {
19
+ display: contents;
20
+ }
21
+
22
+ /* ── Reset & Base ────────────────────────── */
23
+ *,
24
+ *::before,
25
+ *::after {
26
+ margin: 0;
27
+ padding: 0;
28
+ box-sizing: border-box;
29
+ }
30
+
31
+ :root {
32
+ --clr-bg: #f0f2f5;
33
+ --clr-surface: #ffffff;
34
+ --clr-primary: #16213e;
35
+ --clr-primary-d: #0f3460;
36
+ --clr-accent: #e94560;
37
+ --clr-accent-l: #ff6b81;
38
+ --clr-sidebar: #1a1a2e;
39
+ --clr-text: #1a1a2e;
40
+ --clr-text-sec: #8892b0;
41
+ --clr-text-mute: #a8b2d1;
42
+ --clr-border: #e8ecf1;
43
+ --clr-green: #00b894;
44
+ --clr-green-bg: #d4edda;
45
+ --clr-green-fg: #155724;
46
+ --clr-yellow-bg: #fff3cd;
47
+ --clr-yellow-fg: #856404;
48
+ --clr-red-bg: #f8d7da;
49
+ --clr-red-fg: #721c24;
50
+ --radius-sm: 6px;
51
+ --radius-md: 10px;
52
+ --radius-lg: 16px;
53
+ --shadow-sm: 0 1px 3px rgba(0,0,0,.06);
54
+ --shadow-md: 0 4px 12px rgba(0,0,0,.08);
55
+ --shadow-lg: 0 8px 24px rgba(0,0,0,.12);
56
+ --transition: .2s cubic-bezier(.4,0,.2,1);
57
+ }
58
+
59
+ body {
60
+ font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
61
+ background: var(--clr-bg);
62
+ color: var(--clr-text);
63
+ min-height: 100vh;
64
+ -webkit-font-smoothing: antialiased;
65
+ -moz-osx-font-smoothing: grayscale;
66
+ }
67
+
68
+ /* ── Animations ──────────────────────────── */
69
+ @keyframes fadeInUp {
70
+ from { opacity: 0; transform: translateY(12px); }
71
+ to { opacity: 1; transform: translateY(0); }
72
+ }
73
+
74
+ @keyframes pulse {
75
+ 0%, 100% { transform: scale(1); }
76
+ 50% { transform: scale(1.04); }
77
+ }
78
+
79
+ @keyframes shimmer {
80
+ 0% { background-position: -200% 0; }
81
+ 100% { background-position: 200% 0; }
82
+ }
83
+
84
+ /* ── Layout ──────────────────────────────── */
85
+ .dashboard {
86
+ display: grid;
87
+ grid-template-columns: 260px 1fr;
88
+ grid-template-rows: 60px 1fr;
89
+ grid-template-areas:
90
+ "header header"
91
+ "sidebar main";
92
+ min-height: 100vh;
93
+ }
94
+
95
+ /* ── Header ──────────────────────────────── */
96
+ .header {
97
+ grid-area: header;
98
+ display: flex;
99
+ align-items: center;
100
+ justify-content: space-between;
101
+ padding: 0 28px;
102
+ background: linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-primary-d) 100%);
103
+ color: #fff;
104
+ box-shadow: var(--shadow-md);
105
+ z-index: 100;
106
+ }
107
+
108
+ .logo {
109
+ display: flex;
110
+ align-items: center;
111
+ gap: 12px;
112
+ font-size: 18px;
113
+ font-weight: 700;
114
+ letter-spacing: .5px;
115
+ }
116
+
117
+ .logo-icon {
118
+ width: 32px;
119
+ height: 32px;
120
+ background: linear-gradient(135deg, var(--clr-accent) 0%, var(--clr-accent-l) 100%);
121
+ border-radius: var(--radius-sm);
122
+ display: flex;
123
+ align-items: center;
124
+ justify-content: center;
125
+ font-size: 15px;
126
+ font-weight: 800;
127
+ color: #fff;
128
+ box-shadow: 0 2px 8px rgba(233,69,96,.35);
129
+ transition: transform var(--transition);
130
+ }
131
+
132
+ .logo-icon:hover {
133
+ transform: rotate(-8deg) scale(1.1);
134
+ }
135
+
136
+ .logo-text {
137
+ font-weight: 700;
138
+ letter-spacing: .3px;
139
+ }
140
+
141
+ .header-actions {
142
+ display: flex;
143
+ align-items: center;
144
+ gap: 16px;
145
+ }
146
+
147
+ .header-search {
148
+ display: flex;
149
+ align-items: center;
150
+ background: rgba(255,255,255,.1);
151
+ border-radius: 20px;
152
+ padding: 6px 14px;
153
+ gap: 8px;
154
+ transition: background var(--transition);
155
+ }
156
+
157
+ .header-search:hover {
158
+ background: rgba(255,255,255,.16);
159
+ }
160
+
161
+ .header-search-icon {
162
+ font-size: 14px;
163
+ opacity: .7;
164
+ }
165
+
166
+ .header-search-text {
167
+ font-size: 13px;
168
+ color: var(--clr-text-mute);
169
+ }
170
+
171
+ .header-notification {
172
+ position: relative;
173
+ width: 34px;
174
+ height: 34px;
175
+ border-radius: 50%;
176
+ background: rgba(255,255,255,.08);
177
+ display: flex;
178
+ align-items: center;
179
+ justify-content: center;
180
+ font-size: 16px;
181
+ cursor: pointer;
182
+ transition: background var(--transition);
183
+ }
184
+
185
+ .header-notification:hover {
186
+ background: rgba(255,255,255,.16);
187
+ }
188
+
189
+ .header-notification-badge {
190
+ position: absolute;
191
+ top: 2px;
192
+ right: 2px;
193
+ width: 8px;
194
+ height: 8px;
195
+ background: var(--clr-accent);
196
+ border-radius: 50%;
197
+ border: 2px solid var(--clr-primary);
198
+ }
199
+
200
+ .nav {
201
+ display: flex;
202
+ gap: 4px;
203
+ }
204
+
205
+ .nav-item {
206
+ padding: 8px 16px;
207
+ border-radius: 20px;
208
+ font-size: 13px;
209
+ font-weight: 500;
210
+ cursor: pointer;
211
+ transition: all var(--transition);
212
+ color: var(--clr-text-mute);
213
+ position: relative;
214
+ }
215
+
216
+ .nav-item:hover {
217
+ background: rgba(255,255,255,.1);
218
+ color: #fff;
219
+ }
220
+
221
+ .nav-item-active {
222
+ background: rgba(233,69,96,.15);
223
+ color: var(--clr-accent-l);
224
+ font-weight: 600;
225
+ }
226
+
227
+ .nav-item-active::after {
228
+ content: '';
229
+ position: absolute;
230
+ bottom: -2px;
231
+ left: 50%;
232
+ transform: translateX(-50%);
233
+ width: 16px;
234
+ height: 2px;
235
+ background: var(--clr-accent);
236
+ border-radius: 1px;
237
+ }
238
+
239
+ /* ── Sidebar ─────────────────────────────── */
240
+ .sidebar {
241
+ grid-area: sidebar;
242
+ background: var(--clr-sidebar);
243
+ padding: 0;
244
+ color: var(--clr-text-mute);
245
+ overflow-y: auto;
246
+ border-right: 1px solid rgba(255,255,255,.04);
247
+ }
248
+
249
+ .sidebar::-webkit-scrollbar {
250
+ width: 4px;
251
+ }
252
+
253
+ .sidebar::-webkit-scrollbar-thumb {
254
+ background: rgba(255,255,255,.1);
255
+ border-radius: 2px;
256
+ }
257
+
258
+ .user-card {
259
+ display: flex;
260
+ flex-direction: column;
261
+ align-items: center;
262
+ padding: 28px 20px 24px;
263
+ border-bottom: 1px solid rgba(255,255,255,.06);
264
+ margin-bottom: 8px;
265
+ background: linear-gradient(180deg, rgba(15,52,96,.3) 0%, transparent 100%);
266
+ }
267
+
268
+ .user-avatar {
269
+ width: 72px;
270
+ height: 72px;
271
+ border-radius: 50%;
272
+ background: linear-gradient(135deg, var(--clr-primary-d) 0%, var(--clr-accent) 100%);
273
+ display: flex;
274
+ align-items: center;
275
+ justify-content: center;
276
+ font-size: 24px;
277
+ font-weight: 800;
278
+ color: #fff;
279
+ margin-bottom: 14px;
280
+ box-shadow: 0 4px 16px rgba(233,69,96,.25);
281
+ border: 3px solid rgba(255,255,255,.1);
282
+ transition: transform var(--transition), box-shadow var(--transition);
283
+ }
284
+
285
+ .user-avatar:hover {
286
+ transform: scale(1.05);
287
+ box-shadow: 0 6px 20px rgba(233,69,96,.35);
288
+ }
289
+
290
+ .user-info {
291
+ text-align: center;
292
+ }
293
+
294
+ .user-name {
295
+ font-size: 15px;
296
+ font-weight: 600;
297
+ color: #fff;
298
+ margin-bottom: 4px;
299
+ }
300
+
301
+ .user-role {
302
+ font-size: 12px;
303
+ color: var(--clr-text-mute);
304
+ }
305
+
306
+ .user-status {
307
+ display: inline-flex;
308
+ align-items: center;
309
+ gap: 6px;
310
+ margin-top: 10px;
311
+ padding: 4px 12px;
312
+ border-radius: 12px;
313
+ background: rgba(0,184,148,.12);
314
+ color: var(--clr-green);
315
+ font-size: 11px;
316
+ font-weight: 600;
317
+ }
318
+
319
+ .user-status-dot {
320
+ width: 6px;
321
+ height: 6px;
322
+ background: var(--clr-green);
323
+ border-radius: 50%;
324
+ animation: pulse 2s ease-in-out infinite;
325
+ }
326
+
327
+ .menu-section {
328
+ padding: 12px 20px 8px;
329
+ font-size: 10px;
330
+ font-weight: 700;
331
+ text-transform: uppercase;
332
+ letter-spacing: 1.2px;
333
+ color: rgba(168,178,209,.5);
334
+ }
335
+
336
+ .menu {
337
+ list-style: none;
338
+ padding: 0 8px;
339
+ }
340
+
341
+ .menu-item {
342
+ padding: 10px 16px;
343
+ font-size: 13px;
344
+ cursor: pointer;
345
+ transition: all var(--transition);
346
+ display: flex;
347
+ align-items: center;
348
+ gap: 12px;
349
+ border-radius: var(--radius-sm);
350
+ margin-bottom: 2px;
351
+ position: relative;
352
+ }
353
+
354
+ .menu-item:hover {
355
+ background: rgba(255,255,255,.06);
356
+ color: #fff;
357
+ }
358
+
359
+ .menu-item-active {
360
+ background: rgba(233,69,96,.1);
361
+ color: var(--clr-accent-l);
362
+ }
363
+
364
+ .menu-item-active::before {
365
+ content: '';
366
+ position: absolute;
367
+ left: 0;
368
+ top: 50%;
369
+ transform: translateY(-50%);
370
+ width: 3px;
371
+ height: 20px;
372
+ background: var(--clr-accent);
373
+ border-radius: 0 2px 2px 0;
374
+ }
375
+
376
+ .menu-icon {
377
+ width: 20px;
378
+ height: 20px;
379
+ display: flex;
380
+ align-items: center;
381
+ justify-content: center;
382
+ font-size: 15px;
383
+ opacity: .7;
384
+ }
385
+
386
+ .menu-text {
387
+ flex: 1;
388
+ }
389
+
390
+ .menu-badge {
391
+ padding: 2px 8px;
392
+ border-radius: 10px;
393
+ font-size: 10px;
394
+ font-weight: 700;
395
+ background: var(--clr-accent);
396
+ color: #fff;
397
+ }
398
+
399
+ /* ── Main ────────────────────────────────── */
400
+ .main {
401
+ grid-area: main;
402
+ padding: 28px 32px;
403
+ overflow-y: auto;
404
+ background: var(--clr-bg);
405
+ }
406
+
407
+ .main::-webkit-scrollbar {
408
+ width: 6px;
409
+ }
410
+
411
+ .main::-webkit-scrollbar-thumb {
412
+ background: rgba(0,0,0,.12);
413
+ border-radius: 3px;
414
+ }
415
+
416
+ .main-header {
417
+ display: flex;
418
+ align-items: center;
419
+ justify-content: space-between;
420
+ margin-bottom: 24px;
421
+ }
422
+
423
+ .main-title {
424
+ font-size: 24px;
425
+ font-weight: 800;
426
+ color: var(--clr-primary);
427
+ }
428
+
429
+ .main-subtitle {
430
+ font-size: 13px;
431
+ color: var(--clr-text-sec);
432
+ margin-top: 4px;
433
+ }
434
+
435
+ .main-actions {
436
+ display: flex;
437
+ gap: 10px;
438
+ }
439
+
440
+ .btn {
441
+ display: inline-flex;
442
+ align-items: center;
443
+ gap: 8px;
444
+ padding: 9px 18px;
445
+ border-radius: var(--radius-sm);
446
+ font-size: 13px;
447
+ font-weight: 600;
448
+ cursor: pointer;
449
+ border: none;
450
+ transition: all var(--transition);
451
+ font-family: inherit;
452
+ }
453
+
454
+ .btn-primary {
455
+ background: linear-gradient(135deg, var(--clr-accent) 0%, var(--clr-accent-l) 100%);
456
+ color: #fff;
457
+ box-shadow: 0 2px 8px rgba(233,69,96,.3);
458
+ }
459
+
460
+ .btn-primary:hover {
461
+ box-shadow: 0 4px 14px rgba(233,69,96,.4);
462
+ transform: translateY(-1px);
463
+ }
464
+
465
+ .btn-outline {
466
+ background: var(--clr-surface);
467
+ color: var(--clr-text);
468
+ border: 1px solid var(--clr-border);
469
+ }
470
+
471
+ .btn-outline:hover {
472
+ border-color: var(--clr-text-sec);
473
+ box-shadow: var(--shadow-sm);
474
+ }
475
+
476
+ .btn-icon {
477
+ font-size: 14px;
478
+ }
479
+
480
+ /* ── Stats ────────────────────────────────── */
481
+ .stats {
482
+ display: grid;
483
+ grid-template-columns: repeat(4, 1fr);
484
+ gap: 20px;
485
+ margin-bottom: 28px;
486
+ }
487
+
488
+ .stat-card {
489
+ background: var(--clr-surface);
490
+ border-radius: var(--radius-md);
491
+ padding: 22px 24px;
492
+ box-shadow: var(--shadow-sm);
493
+ border: 1px solid rgba(0,0,0,.03);
494
+ transition: all var(--transition);
495
+ animation: fadeInUp .4s ease-out both;
496
+ position: relative;
497
+ overflow: hidden;
498
+ }
499
+
500
+ .stat-card:nth-child(1) { animation-delay: .05s; }
501
+ .stat-card:nth-child(2) { animation-delay: .1s; }
502
+ .stat-card:nth-child(3) { animation-delay: .15s; }
503
+ .stat-card:nth-child(4) { animation-delay: .2s; }
504
+
505
+ .stat-card:hover {
506
+ transform: translateY(-3px);
507
+ box-shadow: var(--shadow-md);
508
+ }
509
+
510
+ .stat-card::after {
511
+ content: '';
512
+ position: absolute;
513
+ top: 0;
514
+ left: 0;
515
+ right: 0;
516
+ height: 3px;
517
+ border-radius: var(--radius-md) var(--radius-md) 0 0;
518
+ }
519
+
520
+ .stat-card:nth-child(1)::after { background: linear-gradient(90deg, #6c5ce7, #a29bfe); }
521
+ .stat-card:nth-child(2)::after { background: linear-gradient(90deg, var(--clr-green), #55efc4); }
522
+ .stat-card:nth-child(3)::after { background: linear-gradient(90deg, var(--clr-accent), var(--clr-accent-l)); }
523
+ .stat-card:nth-child(4)::after { background: linear-gradient(90deg, #0984e3, #74b9ff); }
524
+
525
+ .stat-card-header {
526
+ display: flex;
527
+ align-items: center;
528
+ justify-content: space-between;
529
+ margin-bottom: 12px;
530
+ }
531
+
532
+ .stat-label {
533
+ font-size: 12px;
534
+ text-transform: uppercase;
535
+ letter-spacing: .8px;
536
+ color: var(--clr-text-sec);
537
+ font-weight: 600;
538
+ }
539
+
540
+ .stat-icon {
541
+ width: 36px;
542
+ height: 36px;
543
+ border-radius: var(--radius-sm);
544
+ display: flex;
545
+ align-items: center;
546
+ justify-content: center;
547
+ font-size: 16px;
548
+ }
549
+
550
+ .stat-icon-purple { background: rgba(108,92,231,.1); color: #6c5ce7; }
551
+ .stat-icon-green { background: rgba(0,184,148,.1); color: var(--clr-green); }
552
+ .stat-icon-red { background: rgba(233,69,96,.1); color: var(--clr-accent); }
553
+ .stat-icon-blue { background: rgba(9,132,227,.1); color: #0984e3; }
554
+
555
+ .stat-value {
556
+ font-size: 30px;
557
+ font-weight: 800;
558
+ color: var(--clr-primary);
559
+ line-height: 1.1;
560
+ margin-bottom: 8px;
561
+ }
562
+
563
+ .stat-change {
564
+ display: inline-flex;
565
+ align-items: center;
566
+ gap: 4px;
567
+ font-size: 12px;
568
+ font-weight: 600;
569
+ padding: 3px 8px;
570
+ border-radius: 12px;
571
+ background: rgba(0,184,148,.1);
572
+ color: var(--clr-green);
573
+ }
574
+
575
+ .stat-change-icon {
576
+ font-size: 10px;
577
+ }
578
+
579
+ .stat-change-down {
580
+ background: rgba(233,69,96,.1);
581
+ color: var(--clr-accent);
582
+ }
583
+
584
+ /* ── Table ───────────────────────────────── */
585
+ .table-container {
586
+ background: var(--clr-surface);
587
+ border-radius: var(--radius-md);
588
+ box-shadow: var(--shadow-sm);
589
+ border: 1px solid rgba(0,0,0,.03);
590
+ overflow: hidden;
591
+ animation: fadeInUp .4s ease-out .25s both;
592
+ }
593
+
594
+ .table-header {
595
+ display: flex;
596
+ justify-content: space-between;
597
+ align-items: center;
598
+ padding: 20px 24px;
599
+ border-bottom: 1px solid var(--clr-border);
600
+ }
601
+
602
+ .table-title {
603
+ font-size: 16px;
604
+ font-weight: 700;
605
+ color: var(--clr-primary);
606
+ }
607
+
608
+ .table-subtitle {
609
+ font-size: 12px;
610
+ color: var(--clr-text-sec);
611
+ margin-top: 2px;
612
+ }
613
+
614
+ .table-filter {
615
+ display: flex;
616
+ gap: 6px;
617
+ }
618
+
619
+ .table-filter-btn {
620
+ padding: 5px 14px;
621
+ border-radius: 16px;
622
+ font-size: 12px;
623
+ font-weight: 500;
624
+ cursor: pointer;
625
+ border: 1px solid var(--clr-border);
626
+ background: transparent;
627
+ color: var(--clr-text-sec);
628
+ transition: all var(--transition);
629
+ font-family: inherit;
630
+ }
631
+
632
+ .table-filter-btn:hover {
633
+ border-color: var(--clr-text-sec);
634
+ color: var(--clr-text);
635
+ }
636
+
637
+ .table-filter-btn-active {
638
+ background: var(--clr-primary);
639
+ color: #fff;
640
+ border-color: var(--clr-primary);
641
+ }
642
+
643
+ .table {
644
+ width: 100%;
645
+ border-collapse: collapse;
646
+ }
647
+
648
+ .table th {
649
+ text-align: left;
650
+ padding: 12px 24px;
651
+ font-size: 11px;
652
+ text-transform: uppercase;
653
+ letter-spacing: .8px;
654
+ color: var(--clr-text-sec);
655
+ font-weight: 600;
656
+ background: rgba(0,0,0,.015);
657
+ border-bottom: 1px solid var(--clr-border);
658
+ }
659
+
660
+ .table td {
661
+ padding: 14px 24px;
662
+ font-size: 13px;
663
+ border-bottom: 1px solid #f5f6f8;
664
+ color: var(--clr-text);
665
+ }
666
+
667
+ .table tbody tr {
668
+ transition: background var(--transition);
669
+ }
670
+
671
+ .table tbody tr:hover {
672
+ background: rgba(15,52,96,.02);
673
+ }
674
+
675
+ .table tbody tr:last-child td {
676
+ border-bottom: none;
677
+ }
678
+
679
+ .table-cell-primary {
680
+ font-weight: 600;
681
+ color: var(--clr-primary);
682
+ }
683
+
684
+ .table-cell-secondary {
685
+ color: var(--clr-text-sec);
686
+ font-size: 12px;
687
+ }
688
+
689
+ .status-badge {
690
+ display: inline-flex;
691
+ align-items: center;
692
+ gap: 5px;
693
+ padding: 4px 12px;
694
+ border-radius: 16px;
695
+ font-size: 11px;
696
+ font-weight: 600;
697
+ }
698
+
699
+ .status-dot {
700
+ width: 6px;
701
+ height: 6px;
702
+ border-radius: 50%;
703
+ }
704
+
705
+ .status-active {
706
+ background: var(--clr-green-bg);
707
+ color: var(--clr-green-fg);
708
+ }
709
+
710
+ .status-active .status-dot {
711
+ background: var(--clr-green-fg);
712
+ }
713
+
714
+ .status-pending {
715
+ background: var(--clr-yellow-bg);
716
+ color: var(--clr-yellow-fg);
717
+ }
718
+
719
+ .status-pending .status-dot {
720
+ background: var(--clr-yellow-fg);
721
+ }
722
+
723
+ .status-inactive {
724
+ background: var(--clr-red-bg);
725
+ color: var(--clr-red-fg);
726
+ }
727
+
728
+ .status-inactive .status-dot {
729
+ background: var(--clr-red-fg);
730
+ }
731
+
732
+ .table-footer {
733
+ display: flex;
734
+ align-items: center;
735
+ justify-content: space-between;
736
+ padding: 14px 24px;
737
+ border-top: 1px solid var(--clr-border);
738
+ font-size: 12px;
739
+ color: var(--clr-text-sec);
740
+ }
741
+
742
+ .table-pagination {
743
+ display: flex;
744
+ gap: 4px;
745
+ }
746
+
747
+ .table-page-btn {
748
+ width: 30px;
749
+ height: 30px;
750
+ border-radius: var(--radius-sm);
751
+ border: 1px solid var(--clr-border);
752
+ background: transparent;
753
+ color: var(--clr-text-sec);
754
+ font-size: 12px;
755
+ font-weight: 600;
756
+ cursor: pointer;
757
+ display: flex;
758
+ align-items: center;
759
+ justify-content: center;
760
+ transition: all var(--transition);
761
+ font-family: inherit;
762
+ }
763
+
764
+ .table-page-btn:hover {
765
+ border-color: var(--clr-primary);
766
+ color: var(--clr-primary);
767
+ }
768
+
769
+ .table-page-btn-active {
770
+ background: var(--clr-primary);
771
+ color: #fff;
772
+ border-color: var(--clr-primary);
773
+ }
774
+
775
+ /* ── Responsive ──────────────────────────── */
776
+ @media (max-width: 1200px) {
777
+ .stats { grid-template-columns: repeat(2, 1fr); }
778
+ }
779
+
780
+ @media (max-width: 768px) {
781
+ .dashboard {
782
+ grid-template-columns: 1fr;
783
+ grid-template-rows: 60px auto 1fr;
784
+ grid-template-areas:
785
+ "header"
786
+ "sidebar"
787
+ "main";
788
+ }
789
+ .sidebar { max-height: 200px; }
790
+ .stats { grid-template-columns: 1fr; }
791
+ .header-search { display: none; }
792
+ }