@typed/template 0.13.0 → 1.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (453) hide show
  1. package/README.md +108 -2
  2. package/dist/EventHandler.d.ts +273 -0
  3. package/dist/EventHandler.d.ts.map +1 -0
  4. package/dist/EventHandler.js +261 -0
  5. package/dist/EventSource.d.ts +82 -0
  6. package/dist/EventSource.d.ts.map +1 -0
  7. package/dist/EventSource.js +127 -0
  8. package/dist/Html.d.ts +122 -0
  9. package/dist/Html.d.ts.map +1 -0
  10. package/dist/Html.js +250 -0
  11. package/dist/HtmlChunk.d.ts +118 -0
  12. package/dist/HtmlChunk.d.ts.map +1 -0
  13. package/dist/HtmlChunk.js +211 -0
  14. package/dist/HydrateContext.d.ts +28 -0
  15. package/dist/HydrateContext.d.ts.map +1 -0
  16. package/dist/HydrateContext.js +25 -0
  17. package/dist/Parser.d.ts +35 -0
  18. package/dist/Parser.d.ts.map +1 -0
  19. package/dist/Parser.js +437 -0
  20. package/dist/Render.d.ts +195 -0
  21. package/dist/Render.d.ts.map +1 -0
  22. package/dist/Render.js +609 -0
  23. package/dist/RenderEvent.d.ts +179 -0
  24. package/dist/RenderEvent.d.ts.map +1 -0
  25. package/dist/RenderEvent.js +102 -0
  26. package/dist/RenderQueue.d.ts +167 -0
  27. package/dist/RenderQueue.d.ts.map +1 -0
  28. package/dist/RenderQueue.js +297 -0
  29. package/dist/RenderTemplate.d.ts +90 -0
  30. package/dist/RenderTemplate.d.ts.map +1 -0
  31. package/dist/RenderTemplate.js +87 -0
  32. package/dist/Renderable.d.ts +88 -0
  33. package/dist/Renderable.d.ts.map +1 -0
  34. package/dist/Renderable.js +3 -0
  35. package/dist/{dts/Template.d.ts → Template.d.ts} +109 -74
  36. package/dist/Template.d.ts.map +1 -0
  37. package/dist/{esm/Template.js → Template.js} +96 -56
  38. package/dist/Wire.d.ts +169 -0
  39. package/dist/Wire.d.ts.map +1 -0
  40. package/dist/Wire.js +217 -0
  41. package/dist/errors.d.ts +145 -0
  42. package/dist/errors.d.ts.map +1 -0
  43. package/dist/errors.js +159 -0
  44. package/dist/index.d.ts +15 -0
  45. package/dist/index.d.ts.map +1 -0
  46. package/dist/index.js +14 -0
  47. package/dist/internal/IndexRefCounter.d.ts +11 -0
  48. package/dist/internal/IndexRefCounter.d.ts.map +1 -0
  49. package/dist/internal/IndexRefCounter.js +42 -0
  50. package/dist/internal/ParentChildNodes.d.ts +6 -0
  51. package/dist/internal/ParentChildNodes.d.ts.map +1 -0
  52. package/dist/internal/ParentChildNodes.js +1 -0
  53. package/dist/internal/PathStack.d.ts +9 -0
  54. package/dist/internal/PathStack.d.ts.map +1 -0
  55. package/dist/internal/PathStack.js +18 -0
  56. package/dist/internal/buildTemplateFragement.d.ts +3 -0
  57. package/dist/internal/buildTemplateFragement.d.ts.map +1 -0
  58. package/dist/internal/buildTemplateFragement.js +61 -0
  59. package/dist/internal/diff.d.ts +2 -0
  60. package/dist/internal/diff.d.ts.map +1 -0
  61. package/dist/internal/diff.js +119 -0
  62. package/dist/internal/dom.d.ts +45 -0
  63. package/dist/internal/dom.d.ts.map +1 -0
  64. package/dist/internal/dom.js +304 -0
  65. package/dist/internal/encoding.d.ts +7 -0
  66. package/dist/internal/encoding.d.ts.map +1 -0
  67. package/dist/internal/encoding.js +134 -0
  68. package/dist/{dts/internal/v2/hydration-template.d.ts → internal/hydration.d.ts} +10 -7
  69. package/dist/internal/hydration.d.ts.map +1 -0
  70. package/dist/{esm/internal/v2/hydration-template.js → internal/hydration.js} +80 -26
  71. package/dist/internal/keyToPartType.d.ts +2 -0
  72. package/dist/internal/keyToPartType.d.ts.map +1 -0
  73. package/dist/internal/keyToPartType.js +110 -0
  74. package/dist/internal/meta.d.ts +17 -0
  75. package/dist/internal/meta.d.ts.map +1 -0
  76. package/dist/internal/meta.js +14 -0
  77. package/dist/internal/takeOneIfNotRenderEvent.d.ts +4 -0
  78. package/dist/internal/takeOneIfNotRenderEvent.d.ts.map +1 -0
  79. package/dist/internal/takeOneIfNotRenderEvent.js +10 -0
  80. package/dist/internal/templateHash.d.ts +2 -0
  81. package/dist/internal/templateHash.d.ts.map +1 -0
  82. package/dist/internal/templateHash.js +14 -0
  83. package/dist/many.d.ts +68 -0
  84. package/dist/many.d.ts.map +1 -0
  85. package/dist/many.js +107 -0
  86. package/package.json +22 -223
  87. package/src/EventHandler.ts +318 -86
  88. package/src/EventSource.ts +202 -0
  89. package/src/Html.test.ts +490 -0
  90. package/src/Html.ts +292 -333
  91. package/src/HtmlChunk.ts +290 -332
  92. package/src/HydrateContext.ts +40 -0
  93. package/src/Hydration.test.ts +409 -0
  94. package/src/Parser.test.ts +924 -0
  95. package/src/Parser.ts +598 -10
  96. package/src/Render.test.ts +338 -0
  97. package/src/Render.ts +878 -63
  98. package/src/RenderEvent.ts +169 -40
  99. package/src/RenderQueue.ts +290 -383
  100. package/src/RenderTemplate.ts +98 -31
  101. package/src/Renderable.ts +122 -24
  102. package/src/Template.ts +246 -145
  103. package/src/Wire.ts +309 -0
  104. package/src/errors.ts +173 -0
  105. package/src/index.ts +14 -66
  106. package/src/internal/IndexRefCounter.ts +53 -0
  107. package/src/internal/ParentChildNodes.ts +7 -0
  108. package/src/internal/PathStack.ts +23 -0
  109. package/src/internal/buildTemplateFragement.ts +82 -0
  110. package/src/internal/diff.ts +127 -0
  111. package/src/internal/dom.ts +357 -0
  112. package/src/internal/encoding.ts +147 -0
  113. package/src/internal/hydration.ts +406 -0
  114. package/src/internal/keyToPartType.ts +113 -0
  115. package/src/internal/meta.ts +25 -0
  116. package/src/internal/takeOneIfNotRenderEvent.ts +19 -0
  117. package/src/internal/templateHash.ts +18 -0
  118. package/src/many.ts +148 -0
  119. package/tsconfig.json +6 -0
  120. package/Directive/package.json +0 -6
  121. package/ElementRef/package.json +0 -6
  122. package/ElementSource/package.json +0 -6
  123. package/Entry/package.json +0 -6
  124. package/EventHandler/package.json +0 -6
  125. package/Html/package.json +0 -6
  126. package/HtmlChunk/package.json +0 -6
  127. package/Hydrate/package.json +0 -6
  128. package/LICENSE +0 -21
  129. package/Many/package.json +0 -6
  130. package/Meta/package.json +0 -6
  131. package/Parser/package.json +0 -6
  132. package/Part/package.json +0 -6
  133. package/Placeholder/package.json +0 -6
  134. package/Platform/package.json +0 -6
  135. package/Render/package.json +0 -6
  136. package/RenderContext/package.json +0 -6
  137. package/RenderEvent/package.json +0 -6
  138. package/RenderQueue/package.json +0 -6
  139. package/RenderTemplate/package.json +0 -6
  140. package/Renderable/package.json +0 -6
  141. package/Template/package.json +0 -6
  142. package/Test/package.json +0 -6
  143. package/Vitest/package.json +0 -6
  144. package/compiler-tools/package.json +0 -6
  145. package/dist/cjs/Directive.js +0 -76
  146. package/dist/cjs/Directive.js.map +0 -1
  147. package/dist/cjs/ElementRef.js +0 -92
  148. package/dist/cjs/ElementRef.js.map +0 -1
  149. package/dist/cjs/ElementSource.js +0 -242
  150. package/dist/cjs/ElementSource.js.map +0 -1
  151. package/dist/cjs/Entry.js +0 -6
  152. package/dist/cjs/Entry.js.map +0 -1
  153. package/dist/cjs/EventHandler.js +0 -76
  154. package/dist/cjs/EventHandler.js.map +0 -1
  155. package/dist/cjs/Html.js +0 -224
  156. package/dist/cjs/Html.js.map +0 -1
  157. package/dist/cjs/HtmlChunk.js +0 -306
  158. package/dist/cjs/HtmlChunk.js.map +0 -1
  159. package/dist/cjs/Hydrate.js +0 -43
  160. package/dist/cjs/Hydrate.js.map +0 -1
  161. package/dist/cjs/Many.js +0 -66
  162. package/dist/cjs/Many.js.map +0 -1
  163. package/dist/cjs/Meta.js +0 -50
  164. package/dist/cjs/Meta.js.map +0 -1
  165. package/dist/cjs/Parser.js +0 -19
  166. package/dist/cjs/Parser.js.map +0 -1
  167. package/dist/cjs/Part.js +0 -6
  168. package/dist/cjs/Part.js.map +0 -1
  169. package/dist/cjs/Placeholder.js +0 -34
  170. package/dist/cjs/Placeholder.js.map +0 -1
  171. package/dist/cjs/Platform.js +0 -66
  172. package/dist/cjs/Platform.js.map +0 -1
  173. package/dist/cjs/Render.js +0 -50
  174. package/dist/cjs/Render.js.map +0 -1
  175. package/dist/cjs/RenderContext.js +0 -67
  176. package/dist/cjs/RenderContext.js.map +0 -1
  177. package/dist/cjs/RenderEvent.js +0 -52
  178. package/dist/cjs/RenderEvent.js.map +0 -1
  179. package/dist/cjs/RenderQueue.js +0 -341
  180. package/dist/cjs/RenderQueue.js.map +0 -1
  181. package/dist/cjs/RenderTemplate.js +0 -26
  182. package/dist/cjs/RenderTemplate.js.map +0 -1
  183. package/dist/cjs/Renderable.js +0 -6
  184. package/dist/cjs/Renderable.js.map +0 -1
  185. package/dist/cjs/Template.js +0 -305
  186. package/dist/cjs/Template.js.map +0 -1
  187. package/dist/cjs/Test.js +0 -184
  188. package/dist/cjs/Test.js.map +0 -1
  189. package/dist/cjs/Vitest.js +0 -52
  190. package/dist/cjs/Vitest.js.map +0 -1
  191. package/dist/cjs/compiler-tools.js +0 -100
  192. package/dist/cjs/compiler-tools.js.map +0 -1
  193. package/dist/cjs/index.js +0 -138
  194. package/dist/cjs/index.js.map +0 -1
  195. package/dist/cjs/internal/EventSource.js +0 -129
  196. package/dist/cjs/internal/EventSource.js.map +0 -1
  197. package/dist/cjs/internal/HydrateContext.js +0 -13
  198. package/dist/cjs/internal/HydrateContext.js.map +0 -1
  199. package/dist/cjs/internal/browser.js +0 -110
  200. package/dist/cjs/internal/browser.js.map +0 -1
  201. package/dist/cjs/internal/character-entities.js +0 -2141
  202. package/dist/cjs/internal/character-entities.js.map +0 -1
  203. package/dist/cjs/internal/chunks.js +0 -68
  204. package/dist/cjs/internal/chunks.js.map +0 -1
  205. package/dist/cjs/internal/errors.js +0 -52
  206. package/dist/cjs/internal/errors.js.map +0 -1
  207. package/dist/cjs/internal/indexRefCounter.js +0 -52
  208. package/dist/cjs/internal/indexRefCounter.js.map +0 -1
  209. package/dist/cjs/internal/module-augmentation.js +0 -6
  210. package/dist/cjs/internal/module-augmentation.js.map +0 -1
  211. package/dist/cjs/internal/parser.js +0 -568
  212. package/dist/cjs/internal/parser.js.map +0 -1
  213. package/dist/cjs/internal/parser2.js +0 -382
  214. package/dist/cjs/internal/parser2.js.map +0 -1
  215. package/dist/cjs/internal/server-parts.js +0 -124
  216. package/dist/cjs/internal/server-parts.js.map +0 -1
  217. package/dist/cjs/internal/server.js +0 -48
  218. package/dist/cjs/internal/server.js.map +0 -1
  219. package/dist/cjs/internal/utils.js +0 -136
  220. package/dist/cjs/internal/utils.js.map +0 -1
  221. package/dist/cjs/internal/v2/SyncPart.js +0 -6
  222. package/dist/cjs/internal/v2/SyncPart.js.map +0 -1
  223. package/dist/cjs/internal/v2/helpers.js +0 -15
  224. package/dist/cjs/internal/v2/helpers.js.map +0 -1
  225. package/dist/cjs/internal/v2/hydration-template.js +0 -269
  226. package/dist/cjs/internal/v2/hydration-template.js.map +0 -1
  227. package/dist/cjs/internal/v2/parts.js +0 -169
  228. package/dist/cjs/internal/v2/parts.js.map +0 -1
  229. package/dist/cjs/internal/v2/render-entry.js +0 -110
  230. package/dist/cjs/internal/v2/render-entry.js.map +0 -1
  231. package/dist/cjs/internal/v2/render-sync-parts.js +0 -318
  232. package/dist/cjs/internal/v2/render-sync-parts.js.map +0 -1
  233. package/dist/cjs/internal/v2/render.js +0 -592
  234. package/dist/cjs/internal/v2/render.js.map +0 -1
  235. package/dist/cjs/internal/v2/sync-parts.js +0 -115
  236. package/dist/cjs/internal/v2/sync-parts.js.map +0 -1
  237. package/dist/dts/Directive.d.ts +0 -70
  238. package/dist/dts/Directive.d.ts.map +0 -1
  239. package/dist/dts/ElementRef.d.ts +0 -42
  240. package/dist/dts/ElementRef.d.ts.map +0 -1
  241. package/dist/dts/ElementSource.d.ts +0 -77
  242. package/dist/dts/ElementSource.d.ts.map +0 -1
  243. package/dist/dts/Entry.d.ts +0 -26
  244. package/dist/dts/Entry.d.ts.map +0 -1
  245. package/dist/dts/EventHandler.d.ts +0 -73
  246. package/dist/dts/EventHandler.d.ts.map +0 -1
  247. package/dist/dts/Html.d.ts +0 -35
  248. package/dist/dts/Html.d.ts.map +0 -1
  249. package/dist/dts/HtmlChunk.d.ts +0 -56
  250. package/dist/dts/HtmlChunk.d.ts.map +0 -1
  251. package/dist/dts/Hydrate.d.ts +0 -19
  252. package/dist/dts/Hydrate.d.ts.map +0 -1
  253. package/dist/dts/Many.d.ts +0 -32
  254. package/dist/dts/Many.d.ts.map +0 -1
  255. package/dist/dts/Meta.d.ts +0 -33
  256. package/dist/dts/Meta.d.ts.map +0 -1
  257. package/dist/dts/Parser.d.ts +0 -13
  258. package/dist/dts/Parser.d.ts.map +0 -1
  259. package/dist/dts/Part.d.ts +0 -121
  260. package/dist/dts/Part.d.ts.map +0 -1
  261. package/dist/dts/Placeholder.d.ts +0 -48
  262. package/dist/dts/Placeholder.d.ts.map +0 -1
  263. package/dist/dts/Platform.d.ts +0 -21
  264. package/dist/dts/Platform.d.ts.map +0 -1
  265. package/dist/dts/Render.d.ts +0 -31
  266. package/dist/dts/Render.d.ts.map +0 -1
  267. package/dist/dts/RenderContext.d.ts +0 -70
  268. package/dist/dts/RenderContext.d.ts.map +0 -1
  269. package/dist/dts/RenderEvent.d.ts +0 -42
  270. package/dist/dts/RenderEvent.d.ts.map +0 -1
  271. package/dist/dts/RenderQueue.d.ts +0 -103
  272. package/dist/dts/RenderQueue.d.ts.map +0 -1
  273. package/dist/dts/RenderTemplate.d.ts +0 -25
  274. package/dist/dts/RenderTemplate.d.ts.map +0 -1
  275. package/dist/dts/Renderable.d.ts +0 -28
  276. package/dist/dts/Renderable.d.ts.map +0 -1
  277. package/dist/dts/Template.d.ts.map +0 -1
  278. package/dist/dts/Test.d.ts +0 -85
  279. package/dist/dts/Test.d.ts.map +0 -1
  280. package/dist/dts/Vitest.d.ts +0 -43
  281. package/dist/dts/Vitest.d.ts.map +0 -1
  282. package/dist/dts/compiler-tools.d.ts +0 -143
  283. package/dist/dts/compiler-tools.d.ts.map +0 -1
  284. package/dist/dts/index.d.ts +0 -65
  285. package/dist/dts/index.d.ts.map +0 -1
  286. package/dist/dts/internal/EventSource.d.ts +0 -13
  287. package/dist/dts/internal/EventSource.d.ts.map +0 -1
  288. package/dist/dts/internal/HydrateContext.d.ts +0 -2
  289. package/dist/dts/internal/HydrateContext.d.ts.map +0 -1
  290. package/dist/dts/internal/browser.d.ts +0 -8
  291. package/dist/dts/internal/browser.d.ts.map +0 -1
  292. package/dist/dts/internal/character-entities.d.ts +0 -2133
  293. package/dist/dts/internal/character-entities.d.ts.map +0 -1
  294. package/dist/dts/internal/chunks.d.ts +0 -23
  295. package/dist/dts/internal/chunks.d.ts.map +0 -1
  296. package/dist/dts/internal/errors.d.ts +0 -22
  297. package/dist/dts/internal/errors.d.ts.map +0 -1
  298. package/dist/dts/internal/indexRefCounter.d.ts +0 -7
  299. package/dist/dts/internal/indexRefCounter.d.ts.map +0 -1
  300. package/dist/dts/internal/module-augmentation.d.ts +0 -32
  301. package/dist/dts/internal/module-augmentation.d.ts.map +0 -1
  302. package/dist/dts/internal/parser.d.ts +0 -33
  303. package/dist/dts/internal/parser.d.ts.map +0 -1
  304. package/dist/dts/internal/parser2.d.ts +0 -12
  305. package/dist/dts/internal/parser2.d.ts.map +0 -1
  306. package/dist/dts/internal/server-parts.d.ts +0 -223
  307. package/dist/dts/internal/server-parts.d.ts.map +0 -1
  308. package/dist/dts/internal/server.d.ts +0 -5
  309. package/dist/dts/internal/server.d.ts.map +0 -1
  310. package/dist/dts/internal/utils.d.ts +0 -19
  311. package/dist/dts/internal/utils.d.ts.map +0 -1
  312. package/dist/dts/internal/v2/SyncPart.d.ts +0 -87
  313. package/dist/dts/internal/v2/SyncPart.d.ts.map +0 -1
  314. package/dist/dts/internal/v2/helpers.d.ts +0 -3
  315. package/dist/dts/internal/v2/helpers.d.ts.map +0 -1
  316. package/dist/dts/internal/v2/hydration-template.d.ts.map +0 -1
  317. package/dist/dts/internal/v2/parts.d.ts +0 -245
  318. package/dist/dts/internal/v2/parts.d.ts.map +0 -1
  319. package/dist/dts/internal/v2/render-entry.d.ts +0 -6
  320. package/dist/dts/internal/v2/render-entry.d.ts.map +0 -1
  321. package/dist/dts/internal/v2/render-sync-parts.d.ts +0 -22
  322. package/dist/dts/internal/v2/render-sync-parts.d.ts.map +0 -1
  323. package/dist/dts/internal/v2/render.d.ts +0 -83
  324. package/dist/dts/internal/v2/render.d.ts.map +0 -1
  325. package/dist/dts/internal/v2/sync-parts.d.ts +0 -129
  326. package/dist/dts/internal/v2/sync-parts.d.ts.map +0 -1
  327. package/dist/esm/Directive.js +0 -64
  328. package/dist/esm/Directive.js.map +0 -1
  329. package/dist/esm/ElementRef.js +0 -76
  330. package/dist/esm/ElementRef.js.map +0 -1
  331. package/dist/esm/ElementSource.js +0 -240
  332. package/dist/esm/ElementSource.js.map +0 -1
  333. package/dist/esm/Entry.js +0 -2
  334. package/dist/esm/Entry.js.map +0 -1
  335. package/dist/esm/EventHandler.js +0 -68
  336. package/dist/esm/EventHandler.js.map +0 -1
  337. package/dist/esm/Html.js +0 -230
  338. package/dist/esm/Html.js.map +0 -1
  339. package/dist/esm/HtmlChunk.js +0 -330
  340. package/dist/esm/HtmlChunk.js.map +0 -1
  341. package/dist/esm/Hydrate.js +0 -31
  342. package/dist/esm/Hydrate.js.map +0 -1
  343. package/dist/esm/Many.js +0 -54
  344. package/dist/esm/Many.js.map +0 -1
  345. package/dist/esm/Meta.js +0 -40
  346. package/dist/esm/Meta.js.map +0 -1
  347. package/dist/esm/Parser.js +0 -13
  348. package/dist/esm/Parser.js.map +0 -1
  349. package/dist/esm/Part.js +0 -5
  350. package/dist/esm/Part.js.map +0 -1
  351. package/dist/esm/Placeholder.js +0 -26
  352. package/dist/esm/Placeholder.js.map +0 -1
  353. package/dist/esm/Platform.js +0 -43
  354. package/dist/esm/Platform.js.map +0 -1
  355. package/dist/esm/Render.js +0 -36
  356. package/dist/esm/Render.js.map +0 -1
  357. package/dist/esm/RenderContext.js +0 -54
  358. package/dist/esm/RenderContext.js.map +0 -1
  359. package/dist/esm/RenderEvent.js +0 -43
  360. package/dist/esm/RenderEvent.js.map +0 -1
  361. package/dist/esm/RenderQueue.js +0 -336
  362. package/dist/esm/RenderQueue.js.map +0 -1
  363. package/dist/esm/RenderTemplate.js +0 -16
  364. package/dist/esm/RenderTemplate.js.map +0 -1
  365. package/dist/esm/Renderable.js +0 -2
  366. package/dist/esm/Renderable.js.map +0 -1
  367. package/dist/esm/Template.js.map +0 -1
  368. package/dist/esm/Test.js +0 -167
  369. package/dist/esm/Test.js.map +0 -1
  370. package/dist/esm/Vitest.js +0 -44
  371. package/dist/esm/Vitest.js.map +0 -1
  372. package/dist/esm/compiler-tools.js +0 -91
  373. package/dist/esm/compiler-tools.js.map +0 -1
  374. package/dist/esm/index.js +0 -65
  375. package/dist/esm/index.js.map +0 -1
  376. package/dist/esm/internal/EventSource.js +0 -126
  377. package/dist/esm/internal/EventSource.js.map +0 -1
  378. package/dist/esm/internal/HydrateContext.js +0 -7
  379. package/dist/esm/internal/HydrateContext.js.map +0 -1
  380. package/dist/esm/internal/browser.js +0 -103
  381. package/dist/esm/internal/browser.js.map +0 -1
  382. package/dist/esm/internal/character-entities.js +0 -2134
  383. package/dist/esm/internal/character-entities.js.map +0 -1
  384. package/dist/esm/internal/chunks.js +0 -60
  385. package/dist/esm/internal/chunks.js.map +0 -1
  386. package/dist/esm/internal/errors.js +0 -46
  387. package/dist/esm/internal/errors.js.map +0 -1
  388. package/dist/esm/internal/indexRefCounter.js +0 -47
  389. package/dist/esm/internal/indexRefCounter.js.map +0 -1
  390. package/dist/esm/internal/module-augmentation.js +0 -2
  391. package/dist/esm/internal/module-augmentation.js.map +0 -1
  392. package/dist/esm/internal/parser.js +0 -596
  393. package/dist/esm/internal/parser.js.map +0 -1
  394. package/dist/esm/internal/parser2.js +0 -393
  395. package/dist/esm/internal/parser2.js.map +0 -1
  396. package/dist/esm/internal/server-parts.js +0 -109
  397. package/dist/esm/internal/server-parts.js.map +0 -1
  398. package/dist/esm/internal/server.js +0 -22
  399. package/dist/esm/internal/server.js.map +0 -1
  400. package/dist/esm/internal/utils.js +0 -119
  401. package/dist/esm/internal/utils.js.map +0 -1
  402. package/dist/esm/internal/v2/SyncPart.js +0 -5
  403. package/dist/esm/internal/v2/SyncPart.js.map +0 -1
  404. package/dist/esm/internal/v2/helpers.js +0 -12
  405. package/dist/esm/internal/v2/helpers.js.map +0 -1
  406. package/dist/esm/internal/v2/hydration-template.js.map +0 -1
  407. package/dist/esm/internal/v2/parts.js +0 -150
  408. package/dist/esm/internal/v2/parts.js.map +0 -1
  409. package/dist/esm/internal/v2/render-entry.js +0 -102
  410. package/dist/esm/internal/v2/render-entry.js.map +0 -1
  411. package/dist/esm/internal/v2/render-sync-parts.js +0 -265
  412. package/dist/esm/internal/v2/render-sync-parts.js.map +0 -1
  413. package/dist/esm/internal/v2/render.js +0 -521
  414. package/dist/esm/internal/v2/render.js.map +0 -1
  415. package/dist/esm/internal/v2/sync-parts.js +0 -102
  416. package/dist/esm/internal/v2/sync-parts.js.map +0 -1
  417. package/dist/esm/package.json +0 -4
  418. package/src/Directive.ts +0 -114
  419. package/src/ElementRef.ts +0 -126
  420. package/src/ElementSource.ts +0 -432
  421. package/src/Entry.ts +0 -28
  422. package/src/Hydrate.ts +0 -51
  423. package/src/Many.ts +0 -161
  424. package/src/Meta.ts +0 -45
  425. package/src/Part.ts +0 -154
  426. package/src/Placeholder.ts +0 -78
  427. package/src/Platform.ts +0 -71
  428. package/src/RenderContext.ts +0 -121
  429. package/src/Test.ts +0 -354
  430. package/src/Vitest.ts +0 -141
  431. package/src/compiler-tools.ts +0 -250
  432. package/src/internal/EventSource.ts +0 -188
  433. package/src/internal/HydrateContext.ts +0 -22
  434. package/src/internal/browser.ts +0 -138
  435. package/src/internal/character-entities.ts +0 -2136
  436. package/src/internal/chunks.ts +0 -89
  437. package/src/internal/errors.ts +0 -49
  438. package/src/internal/external.d.ts +0 -11
  439. package/src/internal/indexRefCounter.ts +0 -54
  440. package/src/internal/module-augmentation.ts +0 -44
  441. package/src/internal/parser.ts +0 -757
  442. package/src/internal/parser2.ts +0 -468
  443. package/src/internal/server-parts.ts +0 -161
  444. package/src/internal/server.ts +0 -37
  445. package/src/internal/utils.ts +0 -153
  446. package/src/internal/v2/SyncPart.ts +0 -112
  447. package/src/internal/v2/helpers.ts +0 -13
  448. package/src/internal/v2/hydration-template.ts +0 -308
  449. package/src/internal/v2/parts.ts +0 -254
  450. package/src/internal/v2/render-entry.ts +0 -131
  451. package/src/internal/v2/render-sync-parts.ts +0 -440
  452. package/src/internal/v2/render.ts +0 -813
  453. package/src/internal/v2/sync-parts.ts +0 -133
@@ -0,0 +1,490 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import type { Scope } from "effect";
3
+ import { Effect } from "effect";
4
+ import { Fx } from "@typed/fx";
5
+ import type { RenderEvent, RenderTemplate } from "./index.js";
6
+ import {
7
+ html,
8
+ HtmlRenderEvent,
9
+ HtmlRenderTemplate,
10
+ many,
11
+ renderToHtml,
12
+ renderToHtmlString,
13
+ StaticHtmlRenderTemplate,
14
+ } from "./index.js";
15
+ import { escape } from "./internal/encoding.js";
16
+
17
+ describe("Html", () => {
18
+ it("static template", () =>
19
+ Effect.gen(function* () {
20
+ expect(
21
+ yield* getStaticHtml(
22
+ html`
23
+ <div>Hello, world!</div>
24
+ `,
25
+ ),
26
+ ).toMatchInlineSnapshot(`"<div>Hello, world!</div>"`);
27
+ }).pipe(Effect.scoped, Effect.runPromise));
28
+
29
+ it("dynamic template for text", () =>
30
+ Effect.gen(function* () {
31
+ expect(yield* getStaticHtml(html`<div>Hello, ${"Typed"}!</div>`)).toMatchInlineSnapshot(
32
+ `"<div>Hello, Typed!</div>"`,
33
+ );
34
+ }).pipe(Effect.scoped, Effect.runPromise));
35
+
36
+ it("dynamic template for effect", () =>
37
+ Effect.gen(function* () {
38
+ expect(
39
+ yield* getStaticHtml(html`<div>Hello, ${Effect.succeed("Typed")}!</div>`),
40
+ ).toMatchInlineSnapshot(`"<div>Hello, Typed!</div>"`);
41
+ }).pipe(Effect.scoped, Effect.runPromise));
42
+
43
+ it("dynamic template for fx only takes first value", () =>
44
+ Effect.gen(function* () {
45
+ expect(
46
+ yield* getStaticHtml(
47
+ html`<div>Hello, ${Fx.mergeAll(Fx.succeed("Typed"), Fx.succeed("Other"))}!</div>`,
48
+ ),
49
+ ).toMatchInlineSnapshot(`"<div>Hello, Typed!</div>"`);
50
+ }).pipe(Effect.scoped, Effect.runPromise));
51
+
52
+ it("streams render events in order", () =>
53
+ Effect.gen(function* () {
54
+ expect(
55
+ yield* getStaticHtml(
56
+ html`<div>Hello, ${Fx.mergeAll(
57
+ Fx.succeed(HtmlRenderEvent("Typ", false)),
58
+ Fx.succeed(HtmlRenderEvent("ed", true)),
59
+ )}!</div>`,
60
+ ),
61
+ ).toMatchInlineSnapshot(`"<div>Hello, Typed!</div>"`);
62
+ }).pipe(Effect.scoped, Effect.runPromise));
63
+
64
+ it("renders template with static attribute", () =>
65
+ Effect.gen(function* () {
66
+ expect(
67
+ yield* getStaticHtml(
68
+ html`
69
+ <div data-foo="Hello, world!"></div>
70
+ `,
71
+ ),
72
+ ).toMatchInlineSnapshot(`"<div data-foo="Hello, world!"></div>"`);
73
+ }).pipe(Effect.scoped, Effect.runPromise));
74
+
75
+ it("renders template with primitive attribute interpolation", () =>
76
+ Effect.gen(function* () {
77
+ expect(
78
+ yield* getStaticHtml(html`<div data-foo=${"Hello, world!"}></div>`),
79
+ ).toMatchInlineSnapshot(`"<div data-foo="Hello, world!"></div>"`);
80
+ }).pipe(Effect.scoped, Effect.runPromise));
81
+
82
+ it("renders template with Effect attribute", () =>
83
+ Effect.gen(function* () {
84
+ expect(
85
+ yield* getStaticHtml(html`<div data-foo=${Effect.succeed("Hello, world!")}></div>`),
86
+ ).toMatchInlineSnapshot(`"<div data-foo="Hello, world!"></div>"`);
87
+ }).pipe(Effect.scoped, Effect.runPromise));
88
+
89
+ it("renders template with reactive Fx attribute", () =>
90
+ Effect.gen(function* () {
91
+ expect(
92
+ yield* getStaticHtml(html`<div data-foo=${Fx.succeed("Hello, world!")}></div>`),
93
+ ).toMatchInlineSnapshot(`"<div data-foo="Hello, world!"></div>"`);
94
+ }).pipe(Effect.scoped, Effect.runPromise));
95
+
96
+ it("renders template with ?boolean attribute set to true", () =>
97
+ Effect.gen(function* () {
98
+ expect(yield* getStaticHtml(html`<div ?hidden=${true}></div>`)).toMatchInlineSnapshot(
99
+ `"<div hidden></div>"`,
100
+ );
101
+ }).pipe(Effect.scoped, Effect.runPromise));
102
+
103
+ it("renders template with ?boolean attribute set to false", () =>
104
+ Effect.gen(function* () {
105
+ expect(yield* getStaticHtml(html`<div ?hidden=${false}></div>`)).toMatchInlineSnapshot(
106
+ `"<div></div>"`,
107
+ );
108
+ }).pipe(Effect.scoped, Effect.runPromise));
109
+
110
+ it("renders template with ?boolean attribute set to Effect.succeed(true)", () =>
111
+ Effect.gen(function* () {
112
+ expect(
113
+ yield* getStaticHtml(html`<div ?hidden=${Effect.succeed(true)}></div>`),
114
+ ).toMatchInlineSnapshot(`"<div hidden></div>"`);
115
+ }).pipe(Effect.scoped, Effect.runPromise));
116
+
117
+ it("renders template with ?boolean attribute set to Effect.succeed(false)", () =>
118
+ Effect.gen(function* () {
119
+ expect(
120
+ yield* getStaticHtml(html`<div ?hidden=${Effect.succeed(false)}></div>`),
121
+ ).toMatchInlineSnapshot(`"<div></div>"`);
122
+ }).pipe(Effect.scoped, Effect.runPromise));
123
+
124
+ it("renders template with ?boolean attribute set to Fx.succeed(true)", () =>
125
+ Effect.gen(function* () {
126
+ expect(
127
+ yield* getStaticHtml(html`<div ?hidden=${Fx.succeed(true)}></div>`),
128
+ ).toMatchInlineSnapshot(`"<div hidden></div>"`);
129
+ }).pipe(Effect.scoped, Effect.runPromise));
130
+
131
+ it("renders template with ?boolean attribute set to Fx.succeed(false)", () =>
132
+ Effect.gen(function* () {
133
+ expect(
134
+ yield* getStaticHtml(html`<div ?hidden=${Fx.succeed(false)}></div>`),
135
+ ).toMatchInlineSnapshot(`"<div></div>"`);
136
+ }).pipe(Effect.scoped, Effect.runPromise));
137
+
138
+ it("renders template with a class name", () =>
139
+ Effect.gen(function* () {
140
+ expect(
141
+ yield* getStaticHtml(
142
+ html`
143
+ <div class="foo"></div>
144
+ `,
145
+ ),
146
+ ).toMatchInlineSnapshot(`"<div class="foo"></div>"`);
147
+ expect(yield* getStaticHtml(html`<div class=${"foo"}></div>`)).toMatchInlineSnapshot(
148
+ `"<div class="foo"></div>"`,
149
+ );
150
+ expect(
151
+ yield* getStaticHtml(html`<div class=${Effect.succeed("foo")}></div>`),
152
+ ).toMatchInlineSnapshot(`"<div class="foo"></div>"`);
153
+ expect(
154
+ yield* getStaticHtml(html`<div class=${Fx.succeed("foo")}></div>`),
155
+ ).toMatchInlineSnapshot(`"<div class="foo"></div>"`);
156
+ }).pipe(Effect.scoped, Effect.runPromise));
157
+
158
+ it("renders template with a class name interpolation", () =>
159
+ Effect.gen(function* () {
160
+ expect(yield* getStaticHtml(html`<div class=${"foo bar baz"}></div>`)).toMatchInlineSnapshot(
161
+ `"<div class="foo bar baz"></div>"`,
162
+ );
163
+ }).pipe(Effect.scoped, Effect.runPromise));
164
+
165
+ it("renders template with a class name interpolation with holes", () =>
166
+ Effect.gen(function* () {
167
+ expect(
168
+ yield* getStaticHtml(
169
+ html`<div class="${"foo"} ${Effect.succeed("bar")} ${Fx.succeed("baz")}"></div>`,
170
+ ),
171
+ ).toMatchInlineSnapshot(`"<div class="foo bar baz"></div>"`);
172
+ }).pipe(Effect.scoped, Effect.runPromise));
173
+
174
+ it("renders template with data attributes", () =>
175
+ Effect.gen(function* () {
176
+ expect(
177
+ yield* getStaticHtml(
178
+ html`<div .data=${{ a: "a", b: Effect.succeed("b"), c: Fx.succeed("c") }} />`,
179
+ ),
180
+ ).toMatchInlineSnapshot(`"<div data-a="a" data-b="b" data-c="c"></div>"`);
181
+ }).pipe(Effect.scoped, Effect.runPromise));
182
+
183
+ it("renders comments", () =>
184
+ Effect.gen(function* () {
185
+ expect(
186
+ yield* getStaticHtml(
187
+ html`
188
+ <!--Hello, world!-->
189
+ `,
190
+ ),
191
+ ).toMatchInlineSnapshot(`"<!--Hello, world!-->"`);
192
+ }).pipe(Effect.scoped, Effect.runPromise));
193
+
194
+ it("renders comments with holes", () =>
195
+ Effect.gen(function* () {
196
+ expect(yield* getStaticHtml(html`<!--${"Hello, world!"}-->`)).toMatchInlineSnapshot(
197
+ `"<!--Hello, world!-->"`,
198
+ );
199
+ }).pipe(Effect.scoped, Effect.runPromise));
200
+
201
+ it("renders comments with multiple holes", () =>
202
+ Effect.gen(function* () {
203
+ expect(
204
+ yield* getStaticHtml(html`<!--${"Hello"}, ${Effect.succeed("world")}${Fx.succeed("!")}-->`),
205
+ ).toMatchInlineSnapshot(`"<!--Hello, world!-->"`);
206
+ }).pipe(Effect.scoped, Effect.runPromise));
207
+
208
+ it("renders template with property syntax", () =>
209
+ Effect.gen(function* () {
210
+ const x = {};
211
+ expect(
212
+ yield* getStaticHtml(html`<div .foo=${Effect.succeed(x)}></div>`),
213
+ ).toMatchInlineSnapshot(`"<div foo="${escape(JSON.stringify(x))}"></div>"`);
214
+ }).pipe(Effect.scoped, Effect.runPromise));
215
+
216
+ it("supports sparse attributes", () =>
217
+ Effect.gen(function* () {
218
+ expect(
219
+ yield* getStaticHtml(html`<div attr="${"foo"} ${"bar"} ${"baz"}"></div>`),
220
+ ).toMatchInlineSnapshot(`"<div attr="foo bar baz"></div>"`);
221
+ }).pipe(Effect.scoped, Effect.runPromise));
222
+
223
+ it("supports text only elements", () =>
224
+ Effect.gen(function* () {
225
+ expect(
226
+ yield* getStaticHtml(html`<script>console.log("${"Hello, world!"}")</script>`),
227
+ ).toMatchInlineSnapshot(`"<script>console.log("Hello, world!")</script>"`);
228
+ }).pipe(Effect.scoped, Effect.runPromise));
229
+
230
+ it("supports text only elements with multiple holes", () =>
231
+ Effect.gen(function* () {
232
+ expect(
233
+ yield* getStaticHtml(
234
+ html`<script>console.log("${"Hello"}, ${Effect.succeed("world")}${Fx.succeed("!")}")</script>`,
235
+ ),
236
+ ).toMatchInlineSnapshot(`"<script>console.log("Hello, world!")</script>"`);
237
+ }).pipe(Effect.scoped, Effect.runPromise));
238
+
239
+ it("supports spread attributes", () =>
240
+ Effect.gen(function* () {
241
+ expect(
242
+ yield* getStaticHtml(html`<div ...${{ foo: "bar", baz: "qux" }}></div>`),
243
+ ).toMatchInlineSnapshot(`"<div foo="bar" baz="qux"></div>"`);
244
+ }).pipe(Effect.scoped, Effect.runPromise));
245
+
246
+ it("interpolates primitive children", () =>
247
+ Effect.gen(function* () {
248
+ expect(yield* getStaticHtml(html`<div>${1}</div>`)).toMatchInlineSnapshot(`"<div>1</div>"`);
249
+ expect(yield* getStaticHtml(html`<div>${"Hello, world!"}</div>`)).toMatchInlineSnapshot(
250
+ `"<div>Hello, world!</div>"`,
251
+ );
252
+ expect(yield* getStaticHtml(html`<div>${true}</div>`)).toMatchInlineSnapshot(
253
+ `"<div>true</div>"`,
254
+ );
255
+ expect(yield* getStaticHtml(html`<div>${BigInt(1)}</div>`)).toMatchInlineSnapshot(
256
+ `"<div>1</div>"`,
257
+ );
258
+ expect(yield* getStaticHtml(html`<div>${Symbol("foo")}</div>`)).toMatchInlineSnapshot(
259
+ `"<div>Symbol(foo)</div>"`,
260
+ );
261
+ expect(yield* getStaticHtml(html`<div>${undefined}</div>`)).toMatchInlineSnapshot(
262
+ `"<div></div>"`,
263
+ );
264
+ expect(yield* getStaticHtml(html`<div>${null}</div>`)).toMatchInlineSnapshot(`"<div></div>"`);
265
+ expect(
266
+ yield* getStaticHtml(html`<div>${[1, " ", "Hello", " ", true]}</div>`),
267
+ ).toMatchInlineSnapshot(`"<div>1 Hello true</div>"`);
268
+ }).pipe(Effect.scoped, Effect.runPromise));
269
+
270
+ it("interpolates html render events", () =>
271
+ Effect.gen(function* () {
272
+ expect(
273
+ yield* getStaticHtml(html`<div>${HtmlRenderEvent("<p>Hello, world!</p>", true)}</div>`),
274
+ ).toMatchInlineSnapshot(`"<div><p>Hello, world!</p></div>"`);
275
+ }).pipe(Effect.scoped, Effect.runPromise));
276
+
277
+ it("interpolates dom render events", () =>
278
+ Effect.gen(function* () {
279
+ expect(
280
+ yield* getStaticHtml(
281
+ html`<div>${html`
282
+ <p>Hello, world!</p>
283
+ `}</div>`,
284
+ ),
285
+ ).toMatchInlineSnapshot(`"<div><p>Hello, world!</p></div>"`);
286
+ }).pipe(Effect.scoped, Effect.runPromise));
287
+
288
+ it("interpolates array of render events", () =>
289
+ Effect.gen(function* () {
290
+ expect(
291
+ yield* getStaticHtml(
292
+ html`<div>${[
293
+ html`
294
+ <p>A</p>
295
+ `,
296
+ html`
297
+ <p>B</p>
298
+ `,
299
+ ]}</div>`,
300
+ ),
301
+ ).toMatchInlineSnapshot(`"<div><p>A</p><p>B</p></div>"`);
302
+ }).pipe(Effect.scoped, Effect.runPromise));
303
+
304
+ it("renders nested templates", () =>
305
+ Effect.gen(function* () {
306
+ expect(
307
+ yield* getStaticHtml(html`<div>${html`<span>${"nested"}</span>`}</div>`),
308
+ ).toMatchInlineSnapshot(`"<div><span>nested</span></div>"`);
309
+ }).pipe(Effect.scoped, Effect.runPromise));
310
+
311
+ it("renders complex nested structure", () =>
312
+ Effect.gen(function* () {
313
+ expect(
314
+ yield* getStaticHtml(
315
+ html`<div class="container">${html`<header>${html`<h1>${"Title"}</h1>`}</header>`}${html`<main>${html`<p>${"Content"}</p>`}</main>`}</div>`,
316
+ ),
317
+ ).toMatchInlineSnapshot(
318
+ `"<div class="container"><header><h1>Title</h1></header><main><p>Content</p></main></div>"`,
319
+ );
320
+ }).pipe(Effect.scoped, Effect.runPromise));
321
+
322
+ it("renders with mixed attribute types", () =>
323
+ Effect.gen(function* () {
324
+ expect(
325
+ yield* getStaticHtml(
326
+ html`<div id="test" class=${"dynamic"} ?hidden=${true} data-value=${Effect.succeed("effect")} ...${{
327
+ "aria-label": "accessible",
328
+ }}></div>`,
329
+ ),
330
+ ).toMatchInlineSnapshot(
331
+ `"<div id="test" class="dynamic" hidden data-value="effect" aria-label="accessible"></div>"`,
332
+ );
333
+ }).pipe(Effect.scoped, Effect.runPromise));
334
+
335
+ it("renders self-closing tags", () =>
336
+ Effect.gen(function* () {
337
+ expect(
338
+ yield* getStaticHtml(html`<img src=${"image.jpg"} alt=${"description"} />`),
339
+ ).toMatchInlineSnapshot(`"<img src="image.jpg" alt="description"/>"`);
340
+ }).pipe(Effect.scoped, Effect.runPromise));
341
+
342
+ it("renders void elements", () =>
343
+ Effect.gen(function* () {
344
+ expect(
345
+ yield* getStaticHtml(
346
+ html`
347
+ <br />
348
+ `,
349
+ ),
350
+ ).toMatchInlineSnapshot(`"<br/>"`);
351
+ expect(
352
+ yield* getStaticHtml(
353
+ html`
354
+ <hr class="separator" />
355
+ `,
356
+ ),
357
+ ).toMatchInlineSnapshot(`"<hr class="separator"/>"`);
358
+ }).pipe(Effect.scoped, Effect.runPromise));
359
+
360
+ it("renders with special characters in attributes", () =>
361
+ Effect.gen(function* () {
362
+ expect(
363
+ yield* getStaticHtml(html`<div title=${'Hello & "world" <test>'}></div>`),
364
+ ).toMatchInlineSnapshot(`"<div title="Hello &amp; &quot;world&quot; &lt;test&gt;"></div>"`);
365
+ }).pipe(Effect.scoped, Effect.runPromise));
366
+
367
+ it("renders with special characters in text content", () =>
368
+ Effect.gen(function* () {
369
+ expect(yield* getStaticHtml(html`<div>Hello & "world" <test></div>`)).toMatchInlineSnapshot(
370
+ `"<div>Hello & "world" <test></test></div>"`,
371
+ );
372
+ }).pipe(Effect.scoped, Effect.runPromise));
373
+ });
374
+
375
+ describe("Html Render Events", () => {
376
+ it("renders html render events", () =>
377
+ Effect.gen(function* () {
378
+ const events = yield* getHtmlRenderEvents(
379
+ html`<div>${html`
380
+ <p>Hello, world!</p>
381
+ `}</div>`,
382
+ );
383
+
384
+ expect(events).toMatchInlineSnapshot(`
385
+ [
386
+ "<!--t_fqNjm/UcUg8=--><div>",
387
+ "<!--n_0-->",
388
+ "<!--t_ay1Mjj9KxIY=--><p>Hello, world!</p><!--/t_ay1Mjj9KxIY=-->",
389
+ "<!--/n_0-->",
390
+ "</div><!--/t_fqNjm/UcUg8=-->",
391
+ ]
392
+ `);
393
+ }).pipe(Effect.scoped, Effect.runPromise));
394
+
395
+ it("renders with many comments", (ctx) =>
396
+ Effect.gen(function* () {
397
+ const para = (n: Fx.Fx<number, never, Scope.Scope>) => html`<p>${n}</p>`;
398
+
399
+ const events = yield* getHtmlRenderEvents(para(Fx.succeed(1)));
400
+
401
+ ctx.expect(events).toMatchInlineSnapshot(`
402
+ [
403
+ "<!--t_KwZ/fKKViAs=--><p>",
404
+ "<!--n_0-->",
405
+ "1",
406
+ "<!--/n_0-->",
407
+ "</p><!--/t_KwZ/fKKViAs=-->",
408
+ ]
409
+ `);
410
+ }).pipe(Effect.scoped, Effect.runPromise));
411
+
412
+ it("renders with array of templates", (ctx) =>
413
+ Effect.gen(function* () {
414
+ const para = (n: Fx.Fx<number, never, Scope.Scope>) => html`<p>${n}</p>`;
415
+ const events = yield* getHtmlRenderEvents(
416
+ html`<div>${[para(Fx.succeed(1)), para(Fx.succeed(2)), para(Fx.succeed(3))]}</div>`,
417
+ );
418
+
419
+ ctx.expect(events).toMatchInlineSnapshot(`
420
+ [
421
+ "<!--t_fqNjm/UcUg8=--><div>",
422
+ "<!--n_0-->",
423
+ "<!--t_KwZ/fKKViAs=--><p>",
424
+ "<!--n_0-->",
425
+ "1",
426
+ "<!--/n_0-->",
427
+ "</p><!--/t_KwZ/fKKViAs=-->",
428
+ "<!--t_KwZ/fKKViAs=--><p>",
429
+ "<!--n_0-->",
430
+ "2",
431
+ "<!--/n_0-->",
432
+ "</p><!--/t_KwZ/fKKViAs=-->",
433
+ "<!--t_KwZ/fKKViAs=--><p>",
434
+ "<!--n_0-->",
435
+ "3",
436
+ "<!--/n_0-->",
437
+ "</p><!--/t_KwZ/fKKViAs=-->",
438
+ "<!--/n_0-->",
439
+ "</div><!--/t_fqNjm/UcUg8=-->",
440
+ ]
441
+ `);
442
+ }).pipe(Effect.scoped, Effect.runPromise));
443
+
444
+ it("renders with many comments", (ctx) =>
445
+ Effect.gen(function* () {
446
+ const para = (n: Fx.Fx<number, never, Scope.Scope>) => html`<p>${n}</p>`;
447
+ const events = yield* getHtmlRenderEvents(
448
+ html`<div>${many(Fx.succeed([1, 2, 3]), (n) => n, para)}</div>`,
449
+ );
450
+
451
+ ctx.expect(events).toMatchInlineSnapshot(`
452
+ [
453
+ "<!--t_fqNjm/UcUg8=--><div>",
454
+ "<!--n_0-->",
455
+ "<!--t_KwZ/fKKViAs=--><p>",
456
+ "<!--n_0-->",
457
+ "1",
458
+ "<!--/n_0-->",
459
+ "</p><!--/t_KwZ/fKKViAs=-->",
460
+ "<!--/m_1-->",
461
+ "<!--t_KwZ/fKKViAs=--><p>",
462
+ "<!--n_0-->",
463
+ "2",
464
+ "<!--/n_0-->",
465
+ "</p><!--/t_KwZ/fKKViAs=-->",
466
+ "<!--/m_2-->",
467
+ "<!--t_KwZ/fKKViAs=--><p>",
468
+ "<!--n_0-->",
469
+ "3",
470
+ "<!--/n_0-->",
471
+ "</p><!--/t_KwZ/fKKViAs=-->",
472
+ "<!--/m_3-->",
473
+ "<!--/n_0-->",
474
+ "</div><!--/t_fqNjm/UcUg8=-->",
475
+ ]
476
+ `);
477
+ }).pipe(Effect.scoped, Effect.runPromise));
478
+ });
479
+
480
+ function getStaticHtml<E, R>(
481
+ renderable: Fx.Fx<RenderEvent, E, R>,
482
+ ): Effect.Effect<string, E, Exclude<R, RenderTemplate>> {
483
+ return renderToHtmlString(renderable).pipe(Effect.provide(StaticHtmlRenderTemplate));
484
+ }
485
+
486
+ function getHtmlRenderEvents<E, R>(
487
+ renderable: Fx.Fx<RenderEvent, E, R>,
488
+ ): Effect.Effect<ReadonlyArray<string>, E, Exclude<R, RenderTemplate>> {
489
+ return renderable.pipe(renderToHtml, Fx.collectAll, Effect.provide(HtmlRenderTemplate));
490
+ }