@microsoft/fast-element 2.10.4 → 3.0.0-rc.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (349) hide show
  1. package/ARCHITECTURE_HTML_TAGGED_TEMPLATE_LITERAL.md +1 -1
  2. package/ARCHITECTURE_OVERVIEW.md +2 -2
  3. package/CHANGELOG.json +1 -1
  4. package/CHANGELOG.md +2 -2
  5. package/DECLARATIVE_DESIGN.md +806 -0
  6. package/DECLARATIVE_HTML.md +470 -0
  7. package/DECLARATIVE_MIGRATION.md +215 -0
  8. package/DECLARATIVE_RENDERING.md +530 -0
  9. package/DECLARATIVE_RENDERING_LIFECYCLE.md +288 -0
  10. package/DECLARATIVE_SCHEMA_OBSERVER_MAP.md +489 -0
  11. package/DESIGN.md +138 -33
  12. package/MIGRATION.md +387 -0
  13. package/README.md +208 -1
  14. package/SIZES.md +25 -0
  15. package/api-extractor.arrays.json +15 -0
  16. package/api-extractor.context.json +1 -0
  17. package/api-extractor.declarative.json +15 -0
  18. package/api-extractor.di.json +1 -0
  19. package/api-extractor.hydration.json +15 -0
  20. package/api-extractor.styles.json +15 -0
  21. package/dist/arrays/arrays.api.json +2621 -0
  22. package/dist/declarative/declarative.api.json +7844 -0
  23. package/dist/di/di.api.json +1 -1
  24. package/dist/dts/array-observer.d.ts +2 -0
  25. package/dist/dts/arrays.d.ts +2 -0
  26. package/dist/dts/attr.d.ts +1 -0
  27. package/dist/dts/binding/signal.d.ts +6 -6
  28. package/dist/dts/binding/two-way.d.ts +1 -0
  29. package/dist/dts/binding.d.ts +7 -0
  30. package/dist/dts/components/attributes.d.ts +2 -5
  31. package/dist/dts/components/definition-schema-transforms.d.ts +9 -0
  32. package/dist/dts/components/element-controller.d.ts +80 -114
  33. package/dist/dts/components/element-hydration.d.ts +1 -1
  34. package/dist/dts/components/enable-hydration.d.ts +34 -0
  35. package/dist/dts/components/fast-definitions.d.ts +91 -42
  36. package/dist/dts/components/fast-element.d.ts +5 -8
  37. package/dist/dts/components/hydration-tracker.d.ts +40 -0
  38. package/dist/dts/components/hydration.d.ts +18 -53
  39. package/dist/dts/components/schema.d.ts +205 -0
  40. package/dist/dts/context.d.ts +6 -6
  41. package/dist/dts/css.d.ts +3 -0
  42. package/dist/dts/debug.d.ts +5 -1
  43. package/dist/dts/declarative/attribute-map.d.ts +58 -0
  44. package/dist/dts/declarative/debug.d.ts +5 -0
  45. package/dist/dts/declarative/index.d.ts +13 -0
  46. package/dist/dts/declarative/interfaces.d.ts +9 -0
  47. package/dist/dts/declarative/observer-map-utilities.d.ts +58 -0
  48. package/dist/dts/declarative/observer-map.d.ts +89 -0
  49. package/dist/dts/declarative/runtime.d.ts +5 -0
  50. package/dist/dts/declarative/syntax.d.ts +21 -0
  51. package/dist/dts/declarative/template-bridge.d.ts +33 -0
  52. package/dist/dts/declarative/template-parser.d.ts +98 -0
  53. package/dist/dts/declarative/template.d.ts +9 -0
  54. package/dist/dts/declarative/utilities.d.ts +312 -0
  55. package/dist/dts/di/di.d.ts +1 -1
  56. package/dist/dts/directives/children.d.ts +2 -0
  57. package/dist/dts/directives/node-observation.d.ts +2 -0
  58. package/dist/dts/directives/ref.d.ts +2 -0
  59. package/dist/dts/directives/repeat.d.ts +4 -0
  60. package/dist/dts/directives/slotted.d.ts +2 -0
  61. package/dist/dts/directives/when.d.ts +3 -0
  62. package/dist/dts/dom-policy.d.ts +1 -1
  63. package/dist/dts/html.d.ts +5 -0
  64. package/dist/dts/hydration/runtime.d.ts +7 -0
  65. package/dist/dts/hydration/target-builder.d.ts +15 -12
  66. package/dist/dts/hydration.d.ts +14 -0
  67. package/dist/dts/index.d.ts +38 -42
  68. package/dist/dts/index.debug.d.ts +0 -1
  69. package/dist/dts/index.rollup.debug.d.ts +0 -1
  70. package/dist/dts/interfaces.d.ts +1 -49
  71. package/dist/dts/observable.d.ts +3 -6
  72. package/dist/dts/observation/arrays.d.ts +1 -1
  73. package/dist/dts/observation/update-queue.d.ts +1 -1
  74. package/dist/dts/platform.d.ts +25 -4
  75. package/dist/dts/render.d.ts +7 -0
  76. package/dist/dts/schema.d.ts +1 -0
  77. package/dist/dts/state/exports.d.ts +1 -1
  78. package/dist/dts/state/state.d.ts +2 -2
  79. package/dist/dts/styles/css-directive.d.ts +5 -12
  80. package/dist/dts/styles/css.d.ts +5 -7
  81. package/dist/dts/styles/element-styles.d.ts +0 -10
  82. package/dist/dts/styles.d.ts +6 -0
  83. package/dist/dts/templating/children.d.ts +1 -1
  84. package/dist/dts/templating/html-binding-directive.d.ts +4 -0
  85. package/dist/dts/templating/html-directive.d.ts +17 -0
  86. package/dist/dts/templating/hydration-view.d.ts +109 -0
  87. package/dist/dts/templating/ref.d.ts +1 -1
  88. package/dist/dts/templating/render.d.ts +1 -1
  89. package/dist/dts/templating/repeat.d.ts +2 -2
  90. package/dist/dts/templating/slotted.d.ts +1 -1
  91. package/dist/dts/templating/template.d.ts +17 -9
  92. package/dist/dts/templating/view.d.ts +25 -102
  93. package/dist/dts/templating/when.d.ts +1 -1
  94. package/dist/dts/templating.d.ts +10 -0
  95. package/dist/dts/testing/exports.d.ts +2 -2
  96. package/dist/dts/updates.d.ts +1 -0
  97. package/dist/dts/volatile.d.ts +2 -0
  98. package/dist/esm/array-observer.js +1 -0
  99. package/dist/esm/arrays.js +1 -0
  100. package/dist/esm/attr.js +1 -0
  101. package/dist/esm/binding/normalize.js +1 -1
  102. package/dist/esm/binding/signal.js +4 -4
  103. package/dist/esm/binding/two-way.js +2 -1
  104. package/dist/esm/binding.js +4 -0
  105. package/dist/esm/components/attributes.js +8 -5
  106. package/dist/esm/components/definition-schema-transforms.js +23 -0
  107. package/dist/esm/components/element-controller.js +200 -269
  108. package/dist/esm/components/element-hydration.js +1 -1
  109. package/dist/esm/components/enable-hydration.js +100 -0
  110. package/dist/esm/components/fast-definitions.js +211 -49
  111. package/dist/esm/components/fast-element.js +18 -27
  112. package/dist/esm/components/hydration-tracker.js +93 -0
  113. package/dist/esm/components/hydration.js +62 -144
  114. package/dist/esm/components/schema.js +253 -0
  115. package/dist/esm/context.js +6 -6
  116. package/dist/esm/css.js +3 -0
  117. package/dist/esm/debug.js +26 -26
  118. package/dist/esm/declarative/attribute-map.js +121 -0
  119. package/dist/esm/declarative/debug.js +5 -0
  120. package/dist/esm/declarative/index.js +3 -0
  121. package/dist/esm/declarative/interfaces.js +10 -0
  122. package/dist/esm/declarative/observer-map-utilities.js +562 -0
  123. package/dist/esm/declarative/observer-map.js +216 -0
  124. package/dist/esm/declarative/runtime.js +14 -0
  125. package/dist/esm/declarative/syntax.js +36 -0
  126. package/dist/esm/declarative/template-bridge.js +170 -0
  127. package/dist/esm/declarative/template-parser.js +306 -0
  128. package/dist/esm/declarative/template.js +142 -0
  129. package/dist/esm/declarative/utilities.js +834 -0
  130. package/dist/esm/di/di.js +6 -8
  131. package/dist/esm/directives/children.js +1 -0
  132. package/dist/esm/directives/node-observation.js +1 -0
  133. package/dist/esm/directives/ref.js +1 -0
  134. package/dist/esm/directives/repeat.js +1 -0
  135. package/dist/esm/directives/slotted.js +1 -0
  136. package/dist/esm/directives/when.js +1 -0
  137. package/dist/esm/dom-policy.js +2 -2
  138. package/dist/esm/dom.js +1 -1
  139. package/dist/esm/html.js +2 -0
  140. package/dist/esm/hydration/runtime.js +33 -0
  141. package/dist/esm/hydration/target-builder.js +97 -90
  142. package/dist/esm/hydration.js +4 -0
  143. package/dist/esm/index.debug.js +2 -1
  144. package/dist/esm/index.js +34 -29
  145. package/dist/esm/index.rollup.debug.js +3 -2
  146. package/dist/esm/index.rollup.js +1 -1
  147. package/dist/esm/interfaces.js +1 -45
  148. package/dist/esm/observable.js +1 -4
  149. package/dist/esm/observation/arrays.js +1 -1
  150. package/dist/esm/observation/observable.js +5 -5
  151. package/dist/esm/observation/update-queue.js +47 -58
  152. package/dist/esm/platform.js +31 -30
  153. package/dist/esm/render.js +1 -0
  154. package/dist/esm/schema.js +1 -0
  155. package/dist/esm/state/exports.js +1 -1
  156. package/dist/esm/styles/css-directive.js +1 -2
  157. package/dist/esm/styles/css.js +15 -56
  158. package/dist/esm/styles/element-styles.js +69 -15
  159. package/dist/esm/styles.js +2 -0
  160. package/dist/esm/templating/html-binding-directive.js +10 -8
  161. package/dist/esm/templating/hydration-view.js +235 -0
  162. package/dist/esm/templating/render.js +1 -1
  163. package/dist/esm/templating/repeat.js +36 -34
  164. package/dist/esm/templating/template.js +7 -7
  165. package/dist/esm/templating/view.js +24 -233
  166. package/dist/esm/templating.js +7 -0
  167. package/dist/esm/testing/exports.js +2 -2
  168. package/dist/esm/updates.js +1 -0
  169. package/dist/esm/volatile.js +1 -0
  170. package/dist/fast-element.api.json +9016 -6995
  171. package/dist/fast-element.d.ts +3557 -796
  172. package/dist/fast-element.debug.js +5088 -4437
  173. package/dist/fast-element.debug.min.js +2 -2
  174. package/dist/fast-element.js +5369 -4649
  175. package/dist/fast-element.min.js +2 -2
  176. package/dist/fast-element.untrimmed.d.ts +863 -475
  177. package/dist/hydration/hydration.api.json +5237 -0
  178. package/dist/styles/styles.api.json +2672 -0
  179. package/docs/api-report.api.md +343 -166
  180. package/docs/arrays/api-report.api.md +114 -0
  181. package/docs/declarative/api-report.api.md +397 -0
  182. package/docs/hydration/api-report.api.md +285 -0
  183. package/docs/styles/api-report.api.md +135 -0
  184. package/package.json +149 -41
  185. package/playwright.declarative.config.ts +26 -0
  186. package/playwright.declarative.webui.config.ts +20 -0
  187. package/scripts/declarative/build-fixtures-with-webui.js +135 -0
  188. package/scripts/declarative/build-fixtures.js +49 -0
  189. package/scripts/declarative/build-fixtures.utilities.js +101 -0
  190. package/scripts/measure-sizes.js +219 -0
  191. package/scripts/run-api-extractor.js +39 -20
  192. package/test/declarative/fixtures/README.md +72 -0
  193. package/test/declarative/fixtures/WRITING_FIXTURES.md +330 -0
  194. package/test/declarative/fixtures/bindings/README.md +12 -0
  195. package/test/declarative/fixtures/bindings/attribute/entry.html +13 -0
  196. package/test/declarative/fixtures/bindings/attribute/fast-build.config.json +6 -0
  197. package/test/declarative/fixtures/bindings/attribute/index.html +25 -0
  198. package/test/declarative/fixtures/bindings/attribute/main.ts +41 -0
  199. package/test/declarative/fixtures/bindings/attribute/state.json +8 -0
  200. package/test/declarative/fixtures/bindings/attribute/templates.html +11 -0
  201. package/test/declarative/fixtures/bindings/content/entry.html +12 -0
  202. package/test/declarative/fixtures/bindings/content/fast-build.config.json +6 -0
  203. package/test/declarative/fixtures/bindings/content/index.html +19 -0
  204. package/test/declarative/fixtures/bindings/content/main.ts +27 -0
  205. package/test/declarative/fixtures/bindings/content/state.json +4 -0
  206. package/test/declarative/fixtures/bindings/content/templates.html +6 -0
  207. package/test/declarative/fixtures/bindings/dot-syntax/entry.html +11 -0
  208. package/test/declarative/fixtures/bindings/dot-syntax/fast-build.config.json +6 -0
  209. package/test/declarative/fixtures/bindings/dot-syntax/index.html +47 -0
  210. package/test/declarative/fixtures/bindings/dot-syntax/main.ts +59 -0
  211. package/test/declarative/fixtures/bindings/dot-syntax/state.json +16 -0
  212. package/test/declarative/fixtures/bindings/dot-syntax/templates.html +17 -0
  213. package/test/declarative/fixtures/bindings/event/entry.html +11 -0
  214. package/test/declarative/fixtures/bindings/event/fast-build.config.json +6 -0
  215. package/test/declarative/fixtures/bindings/event/index.html +43 -0
  216. package/test/declarative/fixtures/bindings/event/main.ts +43 -0
  217. package/test/declarative/fixtures/bindings/event/state.json +3 -0
  218. package/test/declarative/fixtures/bindings/event/templates.html +18 -0
  219. package/test/declarative/fixtures/bindings/host/entry.html +40 -0
  220. package/test/declarative/fixtures/bindings/host/fast-build.config.json +6 -0
  221. package/test/declarative/fixtures/bindings/host/index.html +96 -0
  222. package/test/declarative/fixtures/bindings/host/main.ts +222 -0
  223. package/test/declarative/fixtures/bindings/host/state.json +9 -0
  224. package/test/declarative/fixtures/bindings/host/templates.html +55 -0
  225. package/test/declarative/fixtures/directives/README.md +12 -0
  226. package/test/declarative/fixtures/directives/children/entry.html +11 -0
  227. package/test/declarative/fixtures/directives/children/fast-build.config.json +6 -0
  228. package/test/declarative/fixtures/directives/children/index.html +15 -0
  229. package/test/declarative/fixtures/directives/children/main.ts +22 -0
  230. package/test/declarative/fixtures/directives/children/state.json +3 -0
  231. package/test/declarative/fixtures/directives/children/templates.html +3 -0
  232. package/test/declarative/fixtures/directives/ref/entry.html +11 -0
  233. package/test/declarative/fixtures/directives/ref/fast-build.config.json +6 -0
  234. package/test/declarative/fixtures/directives/ref/index.html +15 -0
  235. package/test/declarative/fixtures/directives/ref/main.ts +17 -0
  236. package/test/declarative/fixtures/directives/ref/state.json +1 -0
  237. package/test/declarative/fixtures/directives/ref/templates.html +3 -0
  238. package/test/declarative/fixtures/directives/repeat/entry.html +21 -0
  239. package/test/declarative/fixtures/directives/repeat/fast-build.config.json +6 -0
  240. package/test/declarative/fixtures/directives/repeat/index.html +133 -0
  241. package/test/declarative/fixtures/directives/repeat/main.ts +110 -0
  242. package/test/declarative/fixtures/directives/repeat/sprites.svg +8 -0
  243. package/test/declarative/fixtures/directives/repeat/state.json +10 -0
  244. package/test/declarative/fixtures/directives/repeat/templates.html +75 -0
  245. package/test/declarative/fixtures/directives/slotted/entry.html +17 -0
  246. package/test/declarative/fixtures/directives/slotted/fast-build.config.json +6 -0
  247. package/test/declarative/fixtures/directives/slotted/index.html +27 -0
  248. package/test/declarative/fixtures/directives/slotted/main.ts +29 -0
  249. package/test/declarative/fixtures/directives/slotted/state.json +1 -0
  250. package/test/declarative/fixtures/directives/slotted/templates.html +7 -0
  251. package/test/declarative/fixtures/directives/when/entry.html +51 -0
  252. package/test/declarative/fixtures/directives/when/fast-build.config.json +6 -0
  253. package/test/declarative/fixtures/directives/when/index.html +136 -0
  254. package/test/declarative/fixtures/directives/when/main.ts +172 -0
  255. package/test/declarative/fixtures/directives/when/state.json +12 -0
  256. package/test/declarative/fixtures/directives/when/templates.html +75 -0
  257. package/test/declarative/fixtures/ecosystem/README.md +11 -0
  258. package/test/declarative/fixtures/ecosystem/declarative-no-hydration/entry.html +12 -0
  259. package/test/declarative/fixtures/ecosystem/declarative-no-hydration/fast-build.config.json +6 -0
  260. package/test/declarative/fixtures/ecosystem/declarative-no-hydration/index.html +20 -0
  261. package/test/declarative/fixtures/ecosystem/declarative-no-hydration/main.ts +68 -0
  262. package/test/declarative/fixtures/ecosystem/declarative-no-hydration/state.json +4 -0
  263. package/test/declarative/fixtures/ecosystem/declarative-no-hydration/templates.html +7 -0
  264. package/test/declarative/fixtures/ecosystem/errors/entry.html +12 -0
  265. package/test/declarative/fixtures/ecosystem/errors/fast-build.config.json +6 -0
  266. package/test/declarative/fixtures/ecosystem/errors/index.html +20 -0
  267. package/test/declarative/fixtures/ecosystem/errors/main.ts +17 -0
  268. package/test/declarative/fixtures/ecosystem/errors/state.json +1 -0
  269. package/test/declarative/fixtures/ecosystem/errors/templates.html +7 -0
  270. package/test/declarative/fixtures/ecosystem/lifecycle-callbacks/entry.html +17 -0
  271. package/test/declarative/fixtures/ecosystem/lifecycle-callbacks/fast-build.config.json +6 -0
  272. package/test/declarative/fixtures/ecosystem/lifecycle-callbacks/index.html +56 -0
  273. package/test/declarative/fixtures/ecosystem/lifecycle-callbacks/main.ts +134 -0
  274. package/test/declarative/fixtures/ecosystem/lifecycle-callbacks/state.json +12 -0
  275. package/test/declarative/fixtures/ecosystem/lifecycle-callbacks/templates.html +34 -0
  276. package/test/declarative/fixtures/ecosystem/performance-metrics/entry.html +25 -0
  277. package/test/declarative/fixtures/ecosystem/performance-metrics/fast-build.config.json +6 -0
  278. package/test/declarative/fixtures/ecosystem/performance-metrics/fast-card.css +10 -0
  279. package/test/declarative/fixtures/ecosystem/performance-metrics/index.html +181 -0
  280. package/test/declarative/fixtures/ecosystem/performance-metrics/main.ts +58 -0
  281. package/test/declarative/fixtures/ecosystem/performance-metrics/state.json +6 -0
  282. package/test/declarative/fixtures/ecosystem/performance-metrics/templates.html +15 -0
  283. package/test/declarative/fixtures/extensions/README.md +15 -0
  284. package/test/declarative/fixtures/extensions/attribute-map/entry.html +14 -0
  285. package/test/declarative/fixtures/extensions/attribute-map/fast-build.config.json +6 -0
  286. package/test/declarative/fixtures/extensions/attribute-map/index.html +31 -0
  287. package/test/declarative/fixtures/extensions/attribute-map/main.ts +40 -0
  288. package/test/declarative/fixtures/extensions/attribute-map/state.json +4 -0
  289. package/test/declarative/fixtures/extensions/attribute-map/templates.html +14 -0
  290. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy/entry.html +12 -0
  291. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy/fast-build.config.json +7 -0
  292. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy/index.html +25 -0
  293. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy/main.ts +31 -0
  294. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy/state.json +5 -0
  295. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy/templates.html +11 -0
  296. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy-camel-case/entry.html +13 -0
  297. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy-camel-case/fast-build.config.json +7 -0
  298. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy-camel-case/index.html +23 -0
  299. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy-camel-case/main.ts +37 -0
  300. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy-camel-case/state.json +1 -0
  301. package/test/declarative/fixtures/extensions/attribute-map-naming-strategy-camel-case/templates.html +9 -0
  302. package/test/declarative/fixtures/extensions/observer-map/entry.html +15 -0
  303. package/test/declarative/fixtures/extensions/observer-map/fast-build.config.json +6 -0
  304. package/test/declarative/fixtures/extensions/observer-map/index.html +442 -0
  305. package/test/declarative/fixtures/extensions/observer-map/main.ts +482 -0
  306. package/test/declarative/fixtures/extensions/observer-map/state.json +158 -0
  307. package/test/declarative/fixtures/extensions/observer-map/templates.html +172 -0
  308. package/test/declarative/fixtures/extensions/observer-map-config-object/entry.html +16 -0
  309. package/test/declarative/fixtures/extensions/observer-map-config-object/fast-build.config.json +6 -0
  310. package/test/declarative/fixtures/extensions/observer-map-config-object/index.html +27 -0
  311. package/test/declarative/fixtures/extensions/observer-map-config-object/main.ts +53 -0
  312. package/test/declarative/fixtures/extensions/observer-map-config-object/state.json +9 -0
  313. package/test/declarative/fixtures/extensions/observer-map-config-object/templates.html +12 -0
  314. package/test/declarative/fixtures/extensions/observer-map-deep-merge/README.md +98 -0
  315. package/test/declarative/fixtures/extensions/observer-map-deep-merge/entry.html +156 -0
  316. package/test/declarative/fixtures/extensions/observer-map-deep-merge/fast-build.config.json +6 -0
  317. package/test/declarative/fixtures/extensions/observer-map-deep-merge/index.html +376 -0
  318. package/test/declarative/fixtures/extensions/observer-map-deep-merge/main.ts +366 -0
  319. package/test/declarative/fixtures/extensions/observer-map-deep-merge/state.json +69 -0
  320. package/test/declarative/fixtures/extensions/observer-map-deep-merge/templates.html +91 -0
  321. package/test/declarative/fixtures/extensions/observer-map-properties/entry.html +14 -0
  322. package/test/declarative/fixtures/extensions/observer-map-properties/fast-build.config.json +6 -0
  323. package/test/declarative/fixtures/extensions/observer-map-properties/index.html +110 -0
  324. package/test/declarative/fixtures/extensions/observer-map-properties/main.ts +175 -0
  325. package/test/declarative/fixtures/extensions/observer-map-properties/state.json +29 -0
  326. package/test/declarative/fixtures/extensions/observer-map-properties/templates.html +55 -0
  327. package/test/declarative/fixtures/scenarios/README.md +7 -0
  328. package/test/declarative/fixtures/scenarios/nested-elements/entry.html +16 -0
  329. package/test/declarative/fixtures/scenarios/nested-elements/fast-build.config.json +6 -0
  330. package/test/declarative/fixtures/scenarios/nested-elements/index.html +126 -0
  331. package/test/declarative/fixtures/scenarios/nested-elements/main.ts +214 -0
  332. package/test/declarative/fixtures/scenarios/nested-elements/state.json +10 -0
  333. package/test/declarative/fixtures/scenarios/nested-elements/templates.html +54 -0
  334. package/test/declarative/index.html +12 -0
  335. package/test/declarative/vite.config.ts +55 -0
  336. package/test/declarative-main.ts +6 -0
  337. package/test/extension-subpaths-main.ts +9 -0
  338. package/test/main.ts +38 -33
  339. package/test/pure-declarative-main.ts +1 -0
  340. package/dist/dts/components/install-hydration.d.ts +0 -1
  341. package/dist/dts/pending-task.d.ts +0 -32
  342. package/dist/dts/polyfills.d.ts +0 -0
  343. package/dist/dts/styles/css-binding-directive.d.ts +0 -60
  344. package/dist/dts/templating/install-hydratable-view-templates.d.ts +0 -1
  345. package/dist/esm/components/install-hydration.js +0 -3
  346. package/dist/esm/pending-task.js +0 -28
  347. package/dist/esm/polyfills.js +0 -60
  348. package/dist/esm/styles/css-binding-directive.js +0 -76
  349. package/dist/esm/templating/install-hydratable-view-templates.js +0 -23
@@ -0,0 +1,22 @@
1
+ import { declarativeTemplate } from "@microsoft/fast-element/declarative.js";
2
+ import { FASTElement } from "@microsoft/fast-element/fast-element.js";
3
+ import { enableHydration } from "@microsoft/fast-element/hydration.js";
4
+ import { observable } from "@microsoft/fast-element/observable.js";
5
+
6
+ class TestElement extends FASTElement {
7
+ @observable
8
+ listItems: Node[] = [];
9
+
10
+ @observable
11
+ list: Array<string> = ["Foo", "Bar"];
12
+ }
13
+ TestElement.define({
14
+ name: "test-element",
15
+ template: declarativeTemplate(),
16
+ });
17
+
18
+ enableHydration({
19
+ hydrationComplete() {
20
+ (window as any).hydrationCompleted = true;
21
+ },
22
+ });
@@ -0,0 +1,3 @@
1
+ {
2
+ "list": ["Foo", "Bar"]
3
+ }
@@ -0,0 +1,3 @@
1
+ <f-template name="test-element">
2
+ <template><ul f-children="{listItems}"><f-repeat value="{{item in list}}"><li>{{item}}</li></f-repeat></ul></template>
3
+ </f-template>
@@ -0,0 +1,11 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en-US">
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title></title>
6
+ </head>
7
+ <body>
8
+ <test-element></test-element>
9
+ <script type="module" src="./main.ts"></script>
10
+ </body>
11
+ </html>
@@ -0,0 +1,6 @@
1
+ {
2
+ "entry": "entry.html",
3
+ "state": "state.json",
4
+ "output": "index.html",
5
+ "templates": "templates.html"
6
+ }
@@ -0,0 +1,15 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en-US">
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title></title>
6
+ </head>
7
+ <body>
8
+ <test-element><template shadowrootmode="open" shadowroot="open"><video data-fe="1"></video></template></test-element>
9
+ <f-template name="test-element">
10
+ <template><video f-ref="{video}"></video></template>
11
+ </f-template>
12
+
13
+ <script type="module" src="./main.ts"></script>
14
+ </body>
15
+ </html>
@@ -0,0 +1,17 @@
1
+ import { declarativeTemplate } from "@microsoft/fast-element/declarative.js";
2
+ import { FASTElement } from "@microsoft/fast-element/fast-element.js";
3
+ import { enableHydration } from "@microsoft/fast-element/hydration.js";
4
+
5
+ class TestElement extends FASTElement {
6
+ public video: HTMLVideoElement | null = null;
7
+ }
8
+ TestElement.define({
9
+ name: "test-element",
10
+ template: declarativeTemplate(),
11
+ });
12
+
13
+ enableHydration({
14
+ hydrationComplete() {
15
+ (window as any).hydrationCompleted = true;
16
+ },
17
+ });
@@ -0,0 +1,3 @@
1
+ <f-template name="test-element">
2
+ <template><video f-ref="{video}"></video></template>
3
+ </f-template>
@@ -0,0 +1,21 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en-US">
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title></title>
6
+ </head>
7
+ <body>
8
+ <test-element item_parent="{{item_parent}}"></test-element>
9
+ <test-element-with-observer-map
10
+ item_parent="{{item_parent}}"
11
+ ></test-element-with-observer-map>
12
+ <test-element-inner-when></test-element-inner-when>
13
+ <test-element-interval-updates></test-element-interval-updates>
14
+ <test-element-no-item-repeat-binding
15
+ list="{{emptyList}}"
16
+ ></test-element-no-item-repeat-binding>
17
+ <test-element-empty-array :list="{{emptyList}}"></test-element-empty-array>
18
+ <test-element-event :list="{{eventList}}"></test-element-event>
19
+ <script type="module" src="./main.ts"></script>
20
+ </body>
21
+ </html>
@@ -0,0 +1,6 @@
1
+ {
2
+ "entry": "entry.html",
3
+ "state": "state.json",
4
+ "output": "index.html",
5
+ "templates": "templates.html"
6
+ }
@@ -0,0 +1,133 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en-US">
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title></title>
6
+ </head>
7
+ <body>
8
+ <test-element item_parent="Bat"><template shadowrootmode="open" shadowroot="open"><ul>
9
+ <!--fe:b--><!--fe:r-->
10
+ <li><!--fe:b-->Foo<!--fe:/b--> - <!--fe:b-->Bat<!--fe:/b--></li>
11
+ <!--fe:/r--><!--fe:r-->
12
+ <li><!--fe:b-->Bar<!--fe:/b--> - <!--fe:b-->Bat<!--fe:/b--></li>
13
+ <!--fe:/r--><!--fe:/b-->
14
+ </ul></template></test-element>
15
+ <test-element-with-observer-map item_parent="Bat"><template shadowrootmode="open" shadowroot="open"><ul>
16
+ <!--fe:b--><!--fe:r-->
17
+ <li><!--fe:b-->Foo<!--fe:/b--> - <!--fe:b-->Bat<!--fe:/b--></li>
18
+ <!--fe:/r--><!--fe:r-->
19
+ <li><!--fe:b-->Bar<!--fe:/b--> - <!--fe:b-->Bat<!--fe:/b--></li>
20
+ <!--fe:/r--><!--fe:/b-->
21
+ </ul></template></test-element-with-observer-map>
22
+ <test-element-inner-when><template shadowrootmode="open" shadowroot="open"><ul>
23
+ <!--fe:b--><!--fe:r-->
24
+ <!--fe:b--><!--fe:/b-->
25
+ <!--fe:/r--><!--fe:r-->
26
+ <!--fe:b--><!--fe:/b-->
27
+ <!--fe:/r--><!--fe:/b-->
28
+ </ul></template></test-element-inner-when>
29
+ <test-element-interval-updates><template shadowrootmode="open" shadowroot="open"><ul>
30
+ <!--fe:b--><!--fe:r-->
31
+ <li>
32
+ <svg width="20px" height="20px">
33
+ <use href="sprites.svg#repeat-icon" data-fe="1"></use>
34
+ </svg>
35
+ </li>
36
+ <!--fe:/r--><!--fe:/b-->
37
+
38
+ <!--fe:b--><!--fe:r-->
39
+ <li>
40
+ <svg width="20px" height="20px">
41
+ <use href="sprites.svg#repeat-icon" data-fe="1"></use>
42
+ </svg>
43
+ </li>
44
+ <!--fe:/r--><!--fe:/b-->
45
+ </ul></template></test-element-interval-updates>
46
+ <test-element-no-item-repeat-binding><template shadowrootmode="open" shadowroot="open"><ul>
47
+ <!--fe:b--><!--fe:/b-->
48
+ </ul></template></test-element-no-item-repeat-binding>
49
+ <test-element-empty-array><template shadowrootmode="open" shadowroot="open"><ul>
50
+ <!--fe:b--><!--fe:/b-->
51
+ </ul></template></test-element-empty-array>
52
+ <test-element-event><template shadowrootmode="open" shadowroot="open"><!--fe:b--><!--fe:r-->
53
+ <button data-fe="1">Click</button>
54
+ <!--fe:/r--><!--fe:/b--></template></test-element-event>
55
+ <f-template name="test-element">
56
+ <template>
57
+ <ul>
58
+ <f-repeat value="{{item in list}}">
59
+ <li>{{item}} - {{item_parent}}</li>
60
+ </f-repeat>
61
+ </ul>
62
+ </template>
63
+ </f-template>
64
+ <f-template name="test-element-inner-when">
65
+ <template>
66
+ <ul>
67
+ <f-repeat value="{{item in list}}">
68
+ <f-when value="{{item.show}}">
69
+ <li>{{item.text}}</li>
70
+ </f-when>
71
+ </f-repeat>
72
+ </ul>
73
+ </template>
74
+ </f-template>
75
+ <f-template name="test-element-with-observer-map">
76
+ <template>
77
+ <ul>
78
+ <f-repeat value="{{item in list}}">
79
+ <li>{{item}} - {{item_parent}}</li>
80
+ </f-repeat>
81
+ </ul>
82
+ </template>
83
+ </f-template>
84
+ <f-template name="test-element-no-item-repeat-binding">
85
+ <template>
86
+ <ul>
87
+ <f-repeat value="{{item in list}}">
88
+ <li>{{item}}</li>
89
+ </f-repeat>
90
+ </ul>
91
+ </template>
92
+ </f-template>
93
+ <f-template name="test-element-event">
94
+ <template>
95
+ <f-repeat value="{{item in list}}">
96
+ <button @click="{handleClick()}">Click</button>
97
+ </f-repeat>
98
+ </template>
99
+ </f-template>
100
+ <f-template name="test-element-empty-array">
101
+ <template>
102
+ <ul>
103
+ <f-repeat value="{{item in list}}">
104
+ <li>{{item}}</li>
105
+ </f-repeat>
106
+ </ul>
107
+ </template>
108
+ </f-template>
109
+ <f-template name="test-element-interval-updates">
110
+ <template>
111
+ <ul>
112
+ <f-repeat value="{{item in someData.list1}}">
113
+ <li>
114
+ <svg width="20px" height="20px">
115
+ <use href="sprites.svg#{{item.icon}}-icon"></use>
116
+ </svg>
117
+ </li>
118
+ </f-repeat>
119
+
120
+ <f-repeat value="{{item in someData.list2}}">
121
+ <li>
122
+ <svg width="20px" height="20px">
123
+ <use href="sprites.svg#{{item.icon}}-icon"></use>
124
+ </svg>
125
+ </li>
126
+ </f-repeat>
127
+ </ul>
128
+ </template>
129
+ </f-template>
130
+
131
+ <script type="module" src="./main.ts"></script>
132
+ </body>
133
+ </html>
@@ -0,0 +1,110 @@
1
+ import { attr } from "@microsoft/fast-element/attr.js";
2
+ import { declarativeTemplate } from "@microsoft/fast-element/declarative.js";
3
+ import { deepMerge } from "@microsoft/fast-element/declarative-utilities.js";
4
+ import { FASTElement } from "@microsoft/fast-element/fast-element.js";
5
+ import { enableHydration } from "@microsoft/fast-element/hydration.js";
6
+ import { observable } from "@microsoft/fast-element/observable.js";
7
+ import { observerMap } from "@microsoft/fast-element/observer-map.js";
8
+
9
+ export class TestElement extends FASTElement {
10
+ @observable
11
+ list: Array<string> = ["Foo", "Bar"];
12
+
13
+ @attr
14
+ item_parent: string = "Bat";
15
+ }
16
+ TestElement.define({
17
+ name: "test-element",
18
+ template: declarativeTemplate(),
19
+ });
20
+
21
+ export class TestElementInnerWhen extends FASTElement {
22
+ @observable
23
+ list: Array<any> = [
24
+ {
25
+ show: true,
26
+ text: "Foo",
27
+ },
28
+ {
29
+ show: false,
30
+ text: "Bar",
31
+ },
32
+ ];
33
+ }
34
+ TestElementInnerWhen.define({
35
+ name: "test-element-inner-when",
36
+ template: declarativeTemplate(),
37
+ });
38
+
39
+ export class TestElementIntervalUpdates extends FASTElement {
40
+ someData = { list1: [{ icon: "repeat" }], list2: [{ icon: "repeat" }] };
41
+
42
+ updateData() {
43
+ deepMerge(this.someData, {
44
+ list1: [{ icon: "repeat" }],
45
+ list2: [{ icon: "repeat" }],
46
+ });
47
+ }
48
+ }
49
+
50
+ TestElementIntervalUpdates.define(
51
+ {
52
+ name: "test-element-interval-updates",
53
+ template: declarativeTemplate(),
54
+ },
55
+ [observerMap()],
56
+ );
57
+
58
+ export class TestElementNoItemRepeatBinding extends FASTElement {
59
+ @observable
60
+ list: Array<string> = [];
61
+ }
62
+ TestElementNoItemRepeatBinding.define({
63
+ name: "test-element-no-item-repeat-binding",
64
+ template: declarativeTemplate(),
65
+ });
66
+
67
+ export class TestElementEmptyArray extends FASTElement {
68
+ @observable
69
+ list: Array<string> = [];
70
+ }
71
+ TestElementEmptyArray.define({
72
+ name: "test-element-empty-array",
73
+ template: declarativeTemplate(),
74
+ });
75
+
76
+ export class TestElementEvent extends FASTElement {
77
+ @observable
78
+ list: Array<string> = ["A"];
79
+
80
+ @observable
81
+ clickCount: number = 0;
82
+
83
+ public handleClick = (): void => {
84
+ this.clickCount++;
85
+ };
86
+ }
87
+ TestElementEvent.define({
88
+ name: "test-element-event",
89
+ template: declarativeTemplate(),
90
+ });
91
+
92
+ export class TestElementWithObserverMap extends FASTElement {
93
+ list: Array<string> = ["Foo", "Bar"];
94
+
95
+ @attr
96
+ item_parent: string = "Bat";
97
+ }
98
+ TestElementWithObserverMap.define(
99
+ {
100
+ name: "test-element-with-observer-map",
101
+ template: declarativeTemplate(),
102
+ },
103
+ [observerMap()],
104
+ );
105
+
106
+ enableHydration({
107
+ hydrationComplete() {
108
+ (window as any).hydrationCompleted = true;
109
+ },
110
+ });
@@ -0,0 +1,8 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" style="display: none" aria-hidden="true">
2
+ <symbol id="repeat-icon" viewBox="0 0 20 20" preserveAspectRatio="xMidYMid meet">
3
+ <path
4
+ fill="currentColor"
5
+ d="M14.69 11.503c1 0 1.81.81 1.81 1.81v.689h-.005c-.034.78-.248 1.757-1.123 2.555C14.416 17.43 12.765 18 10 18c-2.766 0-4.416-.57-5.372-1.443c-.875-.798-1.089-1.776-1.123-2.555H3.5v-.69c0-.999.81-1.809 1.81-1.809h9.38ZM6.5 3A1.5 1.5 0 0 0 5 4.5v4A1.5 1.5 0 0 0 6.5 10h7A1.5 1.5 0 0 0 15 8.5v-4A1.5 1.5 0 0 0 13.5 3h-3v-.5A.48.48 0 0 0 10 2c-.276 0-.5.23-.5.5V3h-3ZM7 6.5a1 1 0 1 1 2 0a1 1 0 0 1-2 0Zm4 0a1 1 0 1 1 2 0a1 1 0 0 1-2 0Z"
6
+ />
7
+ </symbol>
8
+ </svg>
@@ -0,0 +1,10 @@
1
+ {
2
+ "list": ["Foo", "Bar"],
3
+ "item_parent": "Bat",
4
+ "emptyList": [],
5
+ "eventList": ["A"],
6
+ "someData": {
7
+ "list1": [{ "icon": "repeat" }],
8
+ "list2": [{ "icon": "repeat" }]
9
+ }
10
+ }
@@ -0,0 +1,75 @@
1
+ <f-template name="test-element">
2
+ <template>
3
+ <ul>
4
+ <f-repeat value="{{item in list}}">
5
+ <li>{{item}} - {{item_parent}}</li>
6
+ </f-repeat>
7
+ </ul>
8
+ </template>
9
+ </f-template>
10
+ <f-template name="test-element-inner-when">
11
+ <template>
12
+ <ul>
13
+ <f-repeat value="{{item in list}}">
14
+ <f-when value="{{item.show}}">
15
+ <li>{{item.text}}</li>
16
+ </f-when>
17
+ </f-repeat>
18
+ </ul>
19
+ </template>
20
+ </f-template>
21
+ <f-template name="test-element-with-observer-map">
22
+ <template>
23
+ <ul>
24
+ <f-repeat value="{{item in list}}">
25
+ <li>{{item}} - {{item_parent}}</li>
26
+ </f-repeat>
27
+ </ul>
28
+ </template>
29
+ </f-template>
30
+ <f-template name="test-element-no-item-repeat-binding">
31
+ <template>
32
+ <ul>
33
+ <f-repeat value="{{item in list}}">
34
+ <li>{{item}}</li>
35
+ </f-repeat>
36
+ </ul>
37
+ </template>
38
+ </f-template>
39
+ <f-template name="test-element-event">
40
+ <template>
41
+ <f-repeat value="{{item in list}}">
42
+ <button @click="{handleClick()}">Click</button>
43
+ </f-repeat>
44
+ </template>
45
+ </f-template>
46
+ <f-template name="test-element-empty-array">
47
+ <template>
48
+ <ul>
49
+ <f-repeat value="{{item in list}}">
50
+ <li>{{item}}</li>
51
+ </f-repeat>
52
+ </ul>
53
+ </template>
54
+ </f-template>
55
+ <f-template name="test-element-interval-updates">
56
+ <template>
57
+ <ul>
58
+ <f-repeat value="{{item in someData.list1}}">
59
+ <li>
60
+ <svg width="20px" height="20px">
61
+ <use href="sprites.svg#{{item.icon}}-icon"></use>
62
+ </svg>
63
+ </li>
64
+ </f-repeat>
65
+
66
+ <f-repeat value="{{item in someData.list2}}">
67
+ <li>
68
+ <svg width="20px" height="20px">
69
+ <use href="sprites.svg#{{item.icon}}-icon"></use>
70
+ </svg>
71
+ </li>
72
+ </f-repeat>
73
+ </ul>
74
+ </template>
75
+ </f-template>
@@ -0,0 +1,17 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en-US">
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title></title>
6
+ </head>
7
+ <body>
8
+ <test-element>
9
+ <div>Slotted</div>
10
+ Not slotted
11
+ <ul slot="foo"><li>Item 1</li><li>Item 2</li></ul>
12
+ <div slot="bar"></div>
13
+ <p slot="bar"></p>
14
+ </test-element>
15
+ <script type="module" src="./main.ts"></script>
16
+ </body>
17
+ </html>
@@ -0,0 +1,6 @@
1
+ {
2
+ "entry": "entry.html",
3
+ "state": "state.json",
4
+ "output": "index.html",
5
+ "templates": "templates.html"
6
+ }
@@ -0,0 +1,27 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en-US">
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title></title>
6
+ </head>
7
+ <body>
8
+ <test-element><template shadowrootmode="open" shadowroot="open"><slot data-fe="1"></slot>
9
+ <slot name="foo" data-fe="1"></slot>
10
+ <slot name="bar" data-fe="1"></slot></template>
11
+ <div>Slotted</div>
12
+ Not slotted
13
+ <ul slot="foo"><li>Item 1</li><li>Item 2</li></ul>
14
+ <div slot="bar"></div>
15
+ <p slot="bar"></p>
16
+ </test-element>
17
+ <f-template name="test-element">
18
+ <template>
19
+ <slot f-slotted="{slottedNodes filter elements()}"></slot>
20
+ <slot name="foo" f-slotted="{slottedFooNodes}"></slot>
21
+ <slot name="bar" f-slotted="{slottedBarNodes filter elements(p, ol)}"></slot>
22
+ </template>
23
+ </f-template>
24
+
25
+ <script type="module" src="./main.ts"></script>
26
+ </body>
27
+ </html>
@@ -0,0 +1,29 @@
1
+ import { declarativeTemplate } from "@microsoft/fast-element/declarative.js";
2
+ import { FASTElement } from "@microsoft/fast-element/fast-element.js";
3
+ import { enableHydration } from "@microsoft/fast-element/hydration.js";
4
+ import { observable } from "@microsoft/fast-element/observable.js";
5
+
6
+ class TestElement extends FASTElement {
7
+ @observable
8
+ slottedNodes: Node[] = [];
9
+
10
+ @observable
11
+ slottedFooNodes: Node[] = [];
12
+
13
+ slottedFooNodesChanged() {
14
+ this.classList.add(`class-${this.slottedFooNodes.length}`);
15
+ }
16
+
17
+ @observable
18
+ slottedBarNodes: Node[] = [];
19
+ }
20
+ TestElement.define({
21
+ name: "test-element",
22
+ template: declarativeTemplate(),
23
+ });
24
+
25
+ enableHydration({
26
+ hydrationComplete() {
27
+ (window as any).hydrationCompleted = true;
28
+ },
29
+ });
@@ -0,0 +1,7 @@
1
+ <f-template name="test-element">
2
+ <template>
3
+ <slot f-slotted="{slottedNodes filter elements()}"></slot>
4
+ <slot name="foo" f-slotted="{slottedFooNodes}"></slot>
5
+ <slot name="bar" f-slotted="{slottedBarNodes filter elements(p, ol)}"></slot>
6
+ </template>
7
+ </f-template>
@@ -0,0 +1,51 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en-US">
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title></title>
6
+ </head>
7
+ <body>
8
+ <!-- multiple -->
9
+ <test-element-multiple id="multiple1" planet="earth"></test-element-multiple>
10
+ <test-element-multiple id="multiple2" planet="pluto"></test-element-multiple>
11
+ <test-element-multiple id="multiple3" planet="mars"></test-element-multiple>
12
+ <!-- boolean -->
13
+ <test-element id="show" show></test-element>
14
+ <test-element id="hide"></test-element>
15
+ <!-- not -->
16
+ <test-element-not id="show-not"></test-element-not>
17
+ <test-element-not id="hide-not" hide></test-element-not>
18
+ <!-- equals -->
19
+ <test-element-equals id="equals-true" vara="3"></test-element-equals>
20
+ <test-element-equals id="equals-false" vara="4"></test-element-equals>
21
+ <!-- not equals -->
22
+ <test-element-not-equals id="not-equals-true" vara="4"></test-element-not-equals>
23
+ <test-element-not-equals id="not-equals-false" vara="3"></test-element-not-equals>
24
+ <!-- greater than or equals -->
25
+ <test-element-ge id="ge-true" vara="3"></test-element-ge>
26
+ <test-element-ge id="ge-false" vara="0"></test-element-ge>
27
+ <!-- greater than -->
28
+ <test-element-gt id="gt-true" vara="3"></test-element-gt>
29
+ <test-element-gt id="gt-false" vara="0"></test-element-gt>
30
+ <!-- less than or equals -->
31
+ <test-element-le id="le-true" vara="2"></test-element-le>
32
+ <test-element-le id="le-false" vara="4"></test-element-le>
33
+ <!-- less than -->
34
+ <test-element-lt id="lt-true" vara="1"></test-element-lt>
35
+ <test-element-lt id="lt-false" vara="3"></test-element-lt>
36
+ <!-- or -->
37
+ <test-element-or id="or-true" thisvar="3"></test-element-or>
38
+ <test-element-or id="or-false"></test-element-or>
39
+ <!-- and -->
40
+ <test-element-and id="and-true" thisvar thatvar></test-element-and>
41
+ <test-element-and id="and-false" thisvar></test-element-and>
42
+ <!-- nested when -->
43
+ <nested-when id="nested-when" error="{{error}}"></nested-when>
44
+ <!-- when false with repeat -->
45
+ <test-element-when-false-repeat id="when-false-repeat"></test-element-when-false-repeat>
46
+ <!-- event -->
47
+ <test-element-event id="event-show" show></test-element-event>
48
+ <test-element-event id="event-hide"></test-element-event>
49
+ <script type="module" src="./main.ts"></script>
50
+ </body>
51
+ </html>
@@ -0,0 +1,6 @@
1
+ {
2
+ "entry": "entry.html",
3
+ "state": "state.json",
4
+ "output": "index.html",
5
+ "templates": "templates.html"
6
+ }