@depup/svelte 5.53.3-depup.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 (386) hide show
  1. package/LICENSE.md +7 -0
  2. package/README.md +41 -0
  3. package/action.d.ts +1 -0
  4. package/animate.d.ts +1 -0
  5. package/compiler/index.js +1 -0
  6. package/compiler/package.json +3 -0
  7. package/compiler.d.ts +1 -0
  8. package/easing.d.ts +1 -0
  9. package/elements.d.ts +2078 -0
  10. package/index.d.ts +1 -0
  11. package/legacy.d.ts +1 -0
  12. package/motion.d.ts +1 -0
  13. package/package.json +185 -0
  14. package/src/animate/index.js +78 -0
  15. package/src/attachments/index.js +113 -0
  16. package/src/compiler/errors.js +1719 -0
  17. package/src/compiler/index.js +198 -0
  18. package/src/compiler/legacy.js +637 -0
  19. package/src/compiler/migrate/index.js +1996 -0
  20. package/src/compiler/phases/1-parse/acorn.js +198 -0
  21. package/src/compiler/phases/1-parse/index.js +326 -0
  22. package/src/compiler/phases/1-parse/read/context.js +116 -0
  23. package/src/compiler/phases/1-parse/read/expression.js +93 -0
  24. package/src/compiler/phases/1-parse/read/options.js +263 -0
  25. package/src/compiler/phases/1-parse/read/script.js +97 -0
  26. package/src/compiler/phases/1-parse/read/style.js +637 -0
  27. package/src/compiler/phases/1-parse/remove_typescript_nodes.js +180 -0
  28. package/src/compiler/phases/1-parse/state/element.js +937 -0
  29. package/src/compiler/phases/1-parse/state/fragment.js +17 -0
  30. package/src/compiler/phases/1-parse/state/tag.js +751 -0
  31. package/src/compiler/phases/1-parse/state/text.js +23 -0
  32. package/src/compiler/phases/1-parse/utils/bracket.js +213 -0
  33. package/src/compiler/phases/1-parse/utils/create.js +16 -0
  34. package/src/compiler/phases/1-parse/utils/entities.js +2234 -0
  35. package/src/compiler/phases/1-parse/utils/fuzzymatch.js +281 -0
  36. package/src/compiler/phases/1-parse/utils/html.js +127 -0
  37. package/src/compiler/phases/2-analyze/css/css-analyze.js +331 -0
  38. package/src/compiler/phases/2-analyze/css/css-prune.js +1206 -0
  39. package/src/compiler/phases/2-analyze/css/css-warn.js +47 -0
  40. package/src/compiler/phases/2-analyze/css/utils.js +177 -0
  41. package/src/compiler/phases/2-analyze/index.js +1300 -0
  42. package/src/compiler/phases/2-analyze/utils/check_graph_for_cycles.js +47 -0
  43. package/src/compiler/phases/2-analyze/visitors/AnimateDirective.js +15 -0
  44. package/src/compiler/phases/2-analyze/visitors/ArrowFunctionExpression.js +11 -0
  45. package/src/compiler/phases/2-analyze/visitors/AssignmentExpression.js +31 -0
  46. package/src/compiler/phases/2-analyze/visitors/AttachTag.js +17 -0
  47. package/src/compiler/phases/2-analyze/visitors/Attribute.js +66 -0
  48. package/src/compiler/phases/2-analyze/visitors/AwaitBlock.js +48 -0
  49. package/src/compiler/phases/2-analyze/visitors/AwaitExpression.js +150 -0
  50. package/src/compiler/phases/2-analyze/visitors/BindDirective.js +280 -0
  51. package/src/compiler/phases/2-analyze/visitors/CallExpression.js +339 -0
  52. package/src/compiler/phases/2-analyze/visitors/ClassBody.js +156 -0
  53. package/src/compiler/phases/2-analyze/visitors/ClassDeclaration.js +25 -0
  54. package/src/compiler/phases/2-analyze/visitors/ClassDirective.js +13 -0
  55. package/src/compiler/phases/2-analyze/visitors/Component.js +26 -0
  56. package/src/compiler/phases/2-analyze/visitors/ConstTag.js +45 -0
  57. package/src/compiler/phases/2-analyze/visitors/DebugTag.js +15 -0
  58. package/src/compiler/phases/2-analyze/visitors/EachBlock.js +97 -0
  59. package/src/compiler/phases/2-analyze/visitors/ExportDefaultDeclaration.js +20 -0
  60. package/src/compiler/phases/2-analyze/visitors/ExportNamedDeclaration.js +70 -0
  61. package/src/compiler/phases/2-analyze/visitors/ExportSpecifier.js +30 -0
  62. package/src/compiler/phases/2-analyze/visitors/ExpressionStatement.js +38 -0
  63. package/src/compiler/phases/2-analyze/visitors/ExpressionTag.js +26 -0
  64. package/src/compiler/phases/2-analyze/visitors/Fragment.js +10 -0
  65. package/src/compiler/phases/2-analyze/visitors/FunctionDeclaration.js +16 -0
  66. package/src/compiler/phases/2-analyze/visitors/FunctionExpression.js +11 -0
  67. package/src/compiler/phases/2-analyze/visitors/HtmlTag.js +19 -0
  68. package/src/compiler/phases/2-analyze/visitors/Identifier.js +194 -0
  69. package/src/compiler/phases/2-analyze/visitors/IfBlock.js +46 -0
  70. package/src/compiler/phases/2-analyze/visitors/ImportDeclaration.js +31 -0
  71. package/src/compiler/phases/2-analyze/visitors/KeyBlock.js +21 -0
  72. package/src/compiler/phases/2-analyze/visitors/LabeledStatement.js +95 -0
  73. package/src/compiler/phases/2-analyze/visitors/LetDirective.js +24 -0
  74. package/src/compiler/phases/2-analyze/visitors/Literal.js +14 -0
  75. package/src/compiler/phases/2-analyze/visitors/MemberExpression.js +28 -0
  76. package/src/compiler/phases/2-analyze/visitors/NewExpression.js +17 -0
  77. package/src/compiler/phases/2-analyze/visitors/OnDirective.js +28 -0
  78. package/src/compiler/phases/2-analyze/visitors/PropertyDefinition.js +21 -0
  79. package/src/compiler/phases/2-analyze/visitors/RegularElement.js +240 -0
  80. package/src/compiler/phases/2-analyze/visitors/RenderTag.js +68 -0
  81. package/src/compiler/phases/2-analyze/visitors/SlotElement.js +42 -0
  82. package/src/compiler/phases/2-analyze/visitors/SnippetBlock.js +113 -0
  83. package/src/compiler/phases/2-analyze/visitors/SpreadAttribute.js +13 -0
  84. package/src/compiler/phases/2-analyze/visitors/SpreadElement.js +16 -0
  85. package/src/compiler/phases/2-analyze/visitors/StyleDirective.js +39 -0
  86. package/src/compiler/phases/2-analyze/visitors/SvelteBody.js +22 -0
  87. package/src/compiler/phases/2-analyze/visitors/SvelteBoundary.js +30 -0
  88. package/src/compiler/phases/2-analyze/visitors/SvelteComponent.js +18 -0
  89. package/src/compiler/phases/2-analyze/visitors/SvelteDocument.js +24 -0
  90. package/src/compiler/phases/2-analyze/visitors/SvelteElement.js +78 -0
  91. package/src/compiler/phases/2-analyze/visitors/SvelteFragment.js +27 -0
  92. package/src/compiler/phases/2-analyze/visitors/SvelteHead.js +18 -0
  93. package/src/compiler/phases/2-analyze/visitors/SvelteSelf.js +36 -0
  94. package/src/compiler/phases/2-analyze/visitors/SvelteWindow.js +24 -0
  95. package/src/compiler/phases/2-analyze/visitors/TaggedTemplateExpression.js +16 -0
  96. package/src/compiler/phases/2-analyze/visitors/TemplateElement.js +12 -0
  97. package/src/compiler/phases/2-analyze/visitors/Text.js +52 -0
  98. package/src/compiler/phases/2-analyze/visitors/TitleElement.js +21 -0
  99. package/src/compiler/phases/2-analyze/visitors/TransitionDirective.js +19 -0
  100. package/src/compiler/phases/2-analyze/visitors/UpdateExpression.js +29 -0
  101. package/src/compiler/phases/2-analyze/visitors/UseDirective.js +18 -0
  102. package/src/compiler/phases/2-analyze/visitors/VariableDeclarator.js +160 -0
  103. package/src/compiler/phases/2-analyze/visitors/shared/a11y/constants.js +334 -0
  104. package/src/compiler/phases/2-analyze/visitors/shared/a11y/index.js +981 -0
  105. package/src/compiler/phases/2-analyze/visitors/shared/attribute.js +125 -0
  106. package/src/compiler/phases/2-analyze/visitors/shared/component.js +177 -0
  107. package/src/compiler/phases/2-analyze/visitors/shared/element.js +160 -0
  108. package/src/compiler/phases/2-analyze/visitors/shared/fragment.js +15 -0
  109. package/src/compiler/phases/2-analyze/visitors/shared/function.js +24 -0
  110. package/src/compiler/phases/2-analyze/visitors/shared/snippets.js +17 -0
  111. package/src/compiler/phases/2-analyze/visitors/shared/special-element.js +16 -0
  112. package/src/compiler/phases/2-analyze/visitors/shared/utils.js +301 -0
  113. package/src/compiler/phases/3-transform/client/transform-client.js +719 -0
  114. package/src/compiler/phases/3-transform/client/transform-template/fix-attribute-casing.js +18 -0
  115. package/src/compiler/phases/3-transform/client/transform-template/index.js +67 -0
  116. package/src/compiler/phases/3-transform/client/transform-template/template.js +164 -0
  117. package/src/compiler/phases/3-transform/client/utils.js +181 -0
  118. package/src/compiler/phases/3-transform/client/visitors/AnimateDirective.js +38 -0
  119. package/src/compiler/phases/3-transform/client/visitors/ArrowFunctionExpression.js +11 -0
  120. package/src/compiler/phases/3-transform/client/visitors/AssignmentExpression.js +247 -0
  121. package/src/compiler/phases/3-transform/client/visitors/AttachTag.js +26 -0
  122. package/src/compiler/phases/3-transform/client/visitors/Attribute.js +14 -0
  123. package/src/compiler/phases/3-transform/client/visitors/AwaitBlock.js +124 -0
  124. package/src/compiler/phases/3-transform/client/visitors/AwaitExpression.js +25 -0
  125. package/src/compiler/phases/3-transform/client/visitors/BinaryExpression.js +34 -0
  126. package/src/compiler/phases/3-transform/client/visitors/BindDirective.js +290 -0
  127. package/src/compiler/phases/3-transform/client/visitors/BlockStatement.js +32 -0
  128. package/src/compiler/phases/3-transform/client/visitors/BreakStatement.js +20 -0
  129. package/src/compiler/phases/3-transform/client/visitors/CallExpression.js +136 -0
  130. package/src/compiler/phases/3-transform/client/visitors/ClassBody.js +111 -0
  131. package/src/compiler/phases/3-transform/client/visitors/Comment.js +11 -0
  132. package/src/compiler/phases/3-transform/client/visitors/Component.js +12 -0
  133. package/src/compiler/phases/3-transform/client/visitors/ConstTag.js +134 -0
  134. package/src/compiler/phases/3-transform/client/visitors/DebugTag.js +28 -0
  135. package/src/compiler/phases/3-transform/client/visitors/EachBlock.js +362 -0
  136. package/src/compiler/phases/3-transform/client/visitors/ExportNamedDeclaration.js +19 -0
  137. package/src/compiler/phases/3-transform/client/visitors/ExpressionStatement.js +20 -0
  138. package/src/compiler/phases/3-transform/client/visitors/ForOfStatement.js +25 -0
  139. package/src/compiler/phases/3-transform/client/visitors/Fragment.js +186 -0
  140. package/src/compiler/phases/3-transform/client/visitors/FunctionDeclaration.js +12 -0
  141. package/src/compiler/phases/3-transform/client/visitors/FunctionExpression.js +11 -0
  142. package/src/compiler/phases/3-transform/client/visitors/HtmlTag.js +53 -0
  143. package/src/compiler/phases/3-transform/client/visitors/Identifier.js +45 -0
  144. package/src/compiler/phases/3-transform/client/visitors/IfBlock.js +131 -0
  145. package/src/compiler/phases/3-transform/client/visitors/KeyBlock.js +45 -0
  146. package/src/compiler/phases/3-transform/client/visitors/LabeledStatement.js +64 -0
  147. package/src/compiler/phases/3-transform/client/visitors/LetDirective.js +55 -0
  148. package/src/compiler/phases/3-transform/client/visitors/MemberExpression.js +23 -0
  149. package/src/compiler/phases/3-transform/client/visitors/OnDirective.js +38 -0
  150. package/src/compiler/phases/3-transform/client/visitors/Program.js +153 -0
  151. package/src/compiler/phases/3-transform/client/visitors/RegularElement.js +725 -0
  152. package/src/compiler/phases/3-transform/client/visitors/RenderTag.js +95 -0
  153. package/src/compiler/phases/3-transform/client/visitors/SlotElement.js +94 -0
  154. package/src/compiler/phases/3-transform/client/visitors/SnippetBlock.js +94 -0
  155. package/src/compiler/phases/3-transform/client/visitors/SpreadAttribute.js +10 -0
  156. package/src/compiler/phases/3-transform/client/visitors/SvelteBody.js +11 -0
  157. package/src/compiler/phases/3-transform/client/visitors/SvelteBoundary.js +126 -0
  158. package/src/compiler/phases/3-transform/client/visitors/SvelteComponent.js +13 -0
  159. package/src/compiler/phases/3-transform/client/visitors/SvelteDocument.js +11 -0
  160. package/src/compiler/phases/3-transform/client/visitors/SvelteElement.js +161 -0
  161. package/src/compiler/phases/3-transform/client/visitors/SvelteFragment.js +17 -0
  162. package/src/compiler/phases/3-transform/client/visitors/SvelteHead.js +23 -0
  163. package/src/compiler/phases/3-transform/client/visitors/SvelteSelf.js +13 -0
  164. package/src/compiler/phases/3-transform/client/visitors/SvelteWindow.js +11 -0
  165. package/src/compiler/phases/3-transform/client/visitors/TitleElement.js +48 -0
  166. package/src/compiler/phases/3-transform/client/visitors/TransitionDirective.js +41 -0
  167. package/src/compiler/phases/3-transform/client/visitors/UpdateExpression.js +55 -0
  168. package/src/compiler/phases/3-transform/client/visitors/UseDirective.js +49 -0
  169. package/src/compiler/phases/3-transform/client/visitors/VariableDeclaration.js +422 -0
  170. package/src/compiler/phases/3-transform/client/visitors/shared/component.js +536 -0
  171. package/src/compiler/phases/3-transform/client/visitors/shared/declarations.js +53 -0
  172. package/src/compiler/phases/3-transform/client/visitors/shared/element.js +263 -0
  173. package/src/compiler/phases/3-transform/client/visitors/shared/events.js +180 -0
  174. package/src/compiler/phases/3-transform/client/visitors/shared/fragment.js +185 -0
  175. package/src/compiler/phases/3-transform/client/visitors/shared/function.js +17 -0
  176. package/src/compiler/phases/3-transform/client/visitors/shared/special_element.js +22 -0
  177. package/src/compiler/phases/3-transform/client/visitors/shared/utils.js +513 -0
  178. package/src/compiler/phases/3-transform/css/index.js +479 -0
  179. package/src/compiler/phases/3-transform/index.js +118 -0
  180. package/src/compiler/phases/3-transform/server/transform-server.js +428 -0
  181. package/src/compiler/phases/3-transform/server/visitors/AssignmentExpression.js +124 -0
  182. package/src/compiler/phases/3-transform/server/visitors/AwaitBlock.js +36 -0
  183. package/src/compiler/phases/3-transform/server/visitors/AwaitExpression.js +40 -0
  184. package/src/compiler/phases/3-transform/server/visitors/CallExpression.js +71 -0
  185. package/src/compiler/phases/3-transform/server/visitors/ClassBody.js +81 -0
  186. package/src/compiler/phases/3-transform/server/visitors/Component.js +13 -0
  187. package/src/compiler/phases/3-transform/server/visitors/ConstTag.js +49 -0
  188. package/src/compiler/phases/3-transform/server/visitors/DebugTag.js +24 -0
  189. package/src/compiler/phases/3-transform/server/visitors/EachBlock.js +76 -0
  190. package/src/compiler/phases/3-transform/server/visitors/ExpressionStatement.js +23 -0
  191. package/src/compiler/phases/3-transform/server/visitors/Fragment.js +53 -0
  192. package/src/compiler/phases/3-transform/server/visitors/HtmlTag.js +25 -0
  193. package/src/compiler/phases/3-transform/server/visitors/Identifier.js +24 -0
  194. package/src/compiler/phases/3-transform/server/visitors/IfBlock.js +48 -0
  195. package/src/compiler/phases/3-transform/server/visitors/KeyBlock.js +22 -0
  196. package/src/compiler/phases/3-transform/server/visitors/LabeledStatement.js +24 -0
  197. package/src/compiler/phases/3-transform/server/visitors/MemberExpression.js +19 -0
  198. package/src/compiler/phases/3-transform/server/visitors/Program.js +25 -0
  199. package/src/compiler/phases/3-transform/server/visitors/PropertyDefinition.js +37 -0
  200. package/src/compiler/phases/3-transform/server/visitors/RegularElement.js +216 -0
  201. package/src/compiler/phases/3-transform/server/visitors/RenderTag.js +45 -0
  202. package/src/compiler/phases/3-transform/server/visitors/SlotElement.js +68 -0
  203. package/src/compiler/phases/3-transform/server/visitors/SnippetBlock.js +29 -0
  204. package/src/compiler/phases/3-transform/server/visitors/SpreadAttribute.js +10 -0
  205. package/src/compiler/phases/3-transform/server/visitors/SvelteBoundary.js +139 -0
  206. package/src/compiler/phases/3-transform/server/visitors/SvelteComponent.js +12 -0
  207. package/src/compiler/phases/3-transform/server/visitors/SvelteElement.js +89 -0
  208. package/src/compiler/phases/3-transform/server/visitors/SvelteFragment.js +11 -0
  209. package/src/compiler/phases/3-transform/server/visitors/SvelteHead.js +25 -0
  210. package/src/compiler/phases/3-transform/server/visitors/SvelteSelf.js +12 -0
  211. package/src/compiler/phases/3-transform/server/visitors/TitleElement.js +21 -0
  212. package/src/compiler/phases/3-transform/server/visitors/UpdateExpression.js +35 -0
  213. package/src/compiler/phases/3-transform/server/visitors/VariableDeclaration.js +247 -0
  214. package/src/compiler/phases/3-transform/server/visitors/shared/component.js +359 -0
  215. package/src/compiler/phases/3-transform/server/visitors/shared/element.js +557 -0
  216. package/src/compiler/phases/3-transform/server/visitors/shared/utils.js +408 -0
  217. package/src/compiler/phases/3-transform/shared/assignments.js +92 -0
  218. package/src/compiler/phases/3-transform/shared/transform-async.js +114 -0
  219. package/src/compiler/phases/3-transform/utils.js +451 -0
  220. package/src/compiler/phases/bindings.js +227 -0
  221. package/src/compiler/phases/css.js +14 -0
  222. package/src/compiler/phases/nodes.js +258 -0
  223. package/src/compiler/phases/patterns.js +27 -0
  224. package/src/compiler/phases/scope.js +1432 -0
  225. package/src/compiler/preprocess/decode_sourcemap.js +96 -0
  226. package/src/compiler/preprocess/index.js +368 -0
  227. package/src/compiler/preprocess/replace_in_code.js +72 -0
  228. package/src/compiler/print/index.js +911 -0
  229. package/src/compiler/state.js +144 -0
  230. package/src/compiler/utils/assert.js +9 -0
  231. package/src/compiler/utils/ast.js +639 -0
  232. package/src/compiler/utils/builders.js +698 -0
  233. package/src/compiler/utils/compile_diagnostic.js +107 -0
  234. package/src/compiler/utils/extract_svelte_ignore.js +104 -0
  235. package/src/compiler/utils/mapped_code.js +454 -0
  236. package/src/compiler/utils/push_array.js +13 -0
  237. package/src/compiler/utils/sanitize_template_string.js +7 -0
  238. package/src/compiler/utils/slot.js +20 -0
  239. package/src/compiler/utils/string.js +9 -0
  240. package/src/compiler/validate-options.js +324 -0
  241. package/src/compiler/warnings.js +845 -0
  242. package/src/constants.js +66 -0
  243. package/src/easing/index.js +286 -0
  244. package/src/escaping.js +26 -0
  245. package/src/events/index.js +1 -0
  246. package/src/html-tree-validation.js +238 -0
  247. package/src/index-client.js +255 -0
  248. package/src/index-server.js +56 -0
  249. package/src/internal/client/constants.js +77 -0
  250. package/src/internal/client/context.js +258 -0
  251. package/src/internal/client/dev/assign.js +79 -0
  252. package/src/internal/client/dev/console-log.js +37 -0
  253. package/src/internal/client/dev/css.js +31 -0
  254. package/src/internal/client/dev/debug.js +500 -0
  255. package/src/internal/client/dev/elements.js +63 -0
  256. package/src/internal/client/dev/equality.js +101 -0
  257. package/src/internal/client/dev/hmr.js +89 -0
  258. package/src/internal/client/dev/inspect.js +72 -0
  259. package/src/internal/client/dev/legacy.js +25 -0
  260. package/src/internal/client/dev/ownership.js +81 -0
  261. package/src/internal/client/dev/tracing.js +162 -0
  262. package/src/internal/client/dev/validation.js +16 -0
  263. package/src/internal/client/dom/blocks/async.js +71 -0
  264. package/src/internal/client/dom/blocks/await.js +142 -0
  265. package/src/internal/client/dom/blocks/boundary.js +534 -0
  266. package/src/internal/client/dom/blocks/branches.js +227 -0
  267. package/src/internal/client/dom/blocks/css-props.js +28 -0
  268. package/src/internal/client/dom/blocks/each.js +723 -0
  269. package/src/internal/client/dom/blocks/html.js +128 -0
  270. package/src/internal/client/dom/blocks/if.js +82 -0
  271. package/src/internal/client/dom/blocks/key.js +40 -0
  272. package/src/internal/client/dom/blocks/slot.js +44 -0
  273. package/src/internal/client/dom/blocks/snippet.js +103 -0
  274. package/src/internal/client/dom/blocks/svelte-component.js +61 -0
  275. package/src/internal/client/dom/blocks/svelte-element.js +152 -0
  276. package/src/internal/client/dom/blocks/svelte-head.js +61 -0
  277. package/src/internal/client/dom/css.js +33 -0
  278. package/src/internal/client/dom/elements/actions.js +43 -0
  279. package/src/internal/client/dom/elements/attachments.js +33 -0
  280. package/src/internal/client/dom/elements/attributes.js +657 -0
  281. package/src/internal/client/dom/elements/bindings/document.js +17 -0
  282. package/src/internal/client/dom/elements/bindings/input.js +312 -0
  283. package/src/internal/client/dom/elements/bindings/media.js +233 -0
  284. package/src/internal/client/dom/elements/bindings/navigator.js +11 -0
  285. package/src/internal/client/dom/elements/bindings/props.js +22 -0
  286. package/src/internal/client/dom/elements/bindings/select.js +159 -0
  287. package/src/internal/client/dom/elements/bindings/shared.js +76 -0
  288. package/src/internal/client/dom/elements/bindings/size.js +107 -0
  289. package/src/internal/client/dom/elements/bindings/this.js +61 -0
  290. package/src/internal/client/dom/elements/bindings/universal.js +75 -0
  291. package/src/internal/client/dom/elements/bindings/window.js +66 -0
  292. package/src/internal/client/dom/elements/class.js +51 -0
  293. package/src/internal/client/dom/elements/custom-element.js +344 -0
  294. package/src/internal/client/dom/elements/customizable-select.js +99 -0
  295. package/src/internal/client/dom/elements/events.js +355 -0
  296. package/src/internal/client/dom/elements/misc.js +58 -0
  297. package/src/internal/client/dom/elements/style.js +57 -0
  298. package/src/internal/client/dom/elements/transitions.js +471 -0
  299. package/src/internal/client/dom/hydration.js +125 -0
  300. package/src/internal/client/dom/legacy/event-modifiers.js +127 -0
  301. package/src/internal/client/dom/legacy/lifecycle.js +82 -0
  302. package/src/internal/client/dom/legacy/misc.js +68 -0
  303. package/src/internal/client/dom/operations.js +293 -0
  304. package/src/internal/client/dom/reconciler.js +25 -0
  305. package/src/internal/client/dom/task.js +42 -0
  306. package/src/internal/client/dom/template.js +401 -0
  307. package/src/internal/client/error-handling.js +118 -0
  308. package/src/internal/client/errors.js +510 -0
  309. package/src/internal/client/hydratable.js +33 -0
  310. package/src/internal/client/index.js +183 -0
  311. package/src/internal/client/legacy.js +46 -0
  312. package/src/internal/client/loop.js +48 -0
  313. package/src/internal/client/proxy.js +432 -0
  314. package/src/internal/client/reactivity/async.js +306 -0
  315. package/src/internal/client/reactivity/batch.js +1057 -0
  316. package/src/internal/client/reactivity/deriveds.js +426 -0
  317. package/src/internal/client/reactivity/effects.js +718 -0
  318. package/src/internal/client/reactivity/equality.js +31 -0
  319. package/src/internal/client/reactivity/props.js +430 -0
  320. package/src/internal/client/reactivity/sources.js +370 -0
  321. package/src/internal/client/reactivity/status.js +25 -0
  322. package/src/internal/client/reactivity/store.js +203 -0
  323. package/src/internal/client/reactivity/utils.js +40 -0
  324. package/src/internal/client/render.js +335 -0
  325. package/src/internal/client/runtime.js +827 -0
  326. package/src/internal/client/timing.js +16 -0
  327. package/src/internal/client/validate.js +54 -0
  328. package/src/internal/client/warnings.js +271 -0
  329. package/src/internal/disclose-version.js +6 -0
  330. package/src/internal/flags/async.js +3 -0
  331. package/src/internal/flags/index.js +23 -0
  332. package/src/internal/flags/legacy.js +3 -0
  333. package/src/internal/flags/tracing.js +3 -0
  334. package/src/internal/index.js +5 -0
  335. package/src/internal/server/abort-signal.js +13 -0
  336. package/src/internal/server/blocks/html.js +11 -0
  337. package/src/internal/server/blocks/snippet.js +24 -0
  338. package/src/internal/server/context.js +132 -0
  339. package/src/internal/server/crypto.js +45 -0
  340. package/src/internal/server/dev.js +115 -0
  341. package/src/internal/server/errors.js +131 -0
  342. package/src/internal/server/hydratable.js +142 -0
  343. package/src/internal/server/hydration.js +6 -0
  344. package/src/internal/server/index.js +544 -0
  345. package/src/internal/server/render-context.js +86 -0
  346. package/src/internal/server/renderer.js +923 -0
  347. package/src/internal/server/warnings.js +29 -0
  348. package/src/internal/shared/attributes.js +225 -0
  349. package/src/internal/shared/clone.js +137 -0
  350. package/src/internal/shared/dev.js +65 -0
  351. package/src/internal/shared/errors.js +134 -0
  352. package/src/internal/shared/utils.js +144 -0
  353. package/src/internal/shared/validate.js +47 -0
  354. package/src/internal/shared/warnings.js +40 -0
  355. package/src/legacy/legacy-client.js +281 -0
  356. package/src/legacy/legacy-server.js +112 -0
  357. package/src/motion/index.js +32 -0
  358. package/src/motion/spring.js +369 -0
  359. package/src/motion/tweened.js +306 -0
  360. package/src/motion/utils.js +7 -0
  361. package/src/reactivity/create-subscriber.js +95 -0
  362. package/src/reactivity/date.js +118 -0
  363. package/src/reactivity/index-client.js +7 -0
  364. package/src/reactivity/index-server.js +23 -0
  365. package/src/reactivity/map.js +273 -0
  366. package/src/reactivity/media-query.js +55 -0
  367. package/src/reactivity/reactive-value.js +24 -0
  368. package/src/reactivity/set.js +213 -0
  369. package/src/reactivity/url-search-params.js +174 -0
  370. package/src/reactivity/url.js +205 -0
  371. package/src/reactivity/window/index.js +161 -0
  372. package/src/server/index.js +1 -0
  373. package/src/store/index-client.js +169 -0
  374. package/src/store/index-server.js +101 -0
  375. package/src/store/shared/index.js +209 -0
  376. package/src/store/utils.js +36 -0
  377. package/src/transition/index.js +300 -0
  378. package/src/utils.js +504 -0
  379. package/src/version.js +8 -0
  380. package/store.d.ts +1 -0
  381. package/svelte-html.d.ts +245 -0
  382. package/transition.d.ts +1 -0
  383. package/types/compiler/interfaces.d.ts +1 -0
  384. package/types/compiler/preprocess.d.ts +1 -0
  385. package/types/index.d.ts +3744 -0
  386. package/types/index.d.ts.map +280 -0
@@ -0,0 +1,95 @@
1
+ /** @import { Expression, Statement } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { ComponentContext } from '../types' */
4
+ import { unwrap_optional } from '../../../../utils/ast.js';
5
+ import * as b from '#compiler/builders';
6
+ import { add_svelte_meta, build_expression, Memoizer } from './shared/utils.js';
7
+
8
+ /**
9
+ * @param {AST.RenderTag} node
10
+ * @param {ComponentContext} context
11
+ */
12
+ export function RenderTag(node, context) {
13
+ context.state.template.push_comment();
14
+
15
+ const call = unwrap_optional(node.expression);
16
+
17
+ /** @type {Expression[]} */
18
+ let args = [];
19
+
20
+ const memoizer = new Memoizer();
21
+
22
+ for (let i = 0; i < call.arguments.length; i++) {
23
+ const arg = /** @type {Expression} */ (call.arguments[i]);
24
+ const metadata = node.metadata.arguments[i];
25
+ let expression = build_expression(context, arg, metadata);
26
+ const memoized = memoizer.add(expression, metadata);
27
+
28
+ if (expression !== memoized) {
29
+ expression = b.call('$.get', memoized);
30
+ }
31
+
32
+ args.push(b.thunk(expression));
33
+ }
34
+
35
+ memoizer.apply();
36
+
37
+ /** @type {Statement[]} */
38
+ const statements = memoizer.deriveds(context.state.analysis.runes);
39
+
40
+ let snippet_function = build_expression(
41
+ context,
42
+ /** @type {Expression} */ (call.callee),
43
+ node.metadata.expression
44
+ );
45
+
46
+ if (node.metadata.dynamic) {
47
+ // If we have a chain expression then ensure a nullish snippet function gets turned into an empty one
48
+ if (node.expression.type === 'ChainExpression') {
49
+ snippet_function = b.logical('??', snippet_function, b.id('$.noop'));
50
+ }
51
+
52
+ statements.push(
53
+ add_svelte_meta(
54
+ b.call('$.snippet', context.state.node, b.thunk(snippet_function), ...args),
55
+ node,
56
+ 'render'
57
+ )
58
+ );
59
+ } else {
60
+ statements.push(
61
+ add_svelte_meta(
62
+ (node.expression.type === 'CallExpression' ? b.call : b.maybe_call)(
63
+ snippet_function,
64
+ context.state.node,
65
+ ...args
66
+ ),
67
+ node,
68
+ 'render'
69
+ )
70
+ );
71
+ }
72
+
73
+ const async_values = memoizer.async_values();
74
+ const blockers = memoizer.blockers();
75
+
76
+ if (async_values || blockers) {
77
+ context.state.init.push(
78
+ b.stmt(
79
+ b.call(
80
+ '$.async',
81
+ context.state.node,
82
+ blockers,
83
+ memoizer.async_values(),
84
+ b.arrow([context.state.node, ...memoizer.async_ids()], b.block(statements))
85
+ )
86
+ )
87
+ );
88
+
89
+ if (context.state.is_standalone) {
90
+ context.state.init.push(b.stmt(b.call('$.next')));
91
+ }
92
+ } else {
93
+ context.state.init.push(statements.length === 1 ? statements[0] : b.block(statements));
94
+ }
95
+ }
@@ -0,0 +1,94 @@
1
+ /** @import { BlockStatement, Expression, ExpressionStatement, Literal, Property, Statement } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { ComponentContext } from '../types' */
4
+ import * as b from '#compiler/builders';
5
+ import { build_attribute_value } from './shared/element.js';
6
+ import { Memoizer } from './shared/utils.js';
7
+
8
+ /**
9
+ * @param {AST.SlotElement} node
10
+ * @param {ComponentContext} context
11
+ */
12
+ export function SlotElement(node, context) {
13
+ // <slot {a}>fallback</slot> --> $.slot($$slots.default, { get a() { .. } }, () => ...fallback);
14
+ context.state.template.push_comment();
15
+
16
+ /** @type {Property[]} */
17
+ const props = [];
18
+
19
+ /** @type {Expression[]} */
20
+ const spreads = [];
21
+
22
+ /** @type {ExpressionStatement[]} */
23
+ const lets = [];
24
+
25
+ const memoizer = new Memoizer();
26
+
27
+ let name = b.literal('default');
28
+
29
+ for (const attribute of node.attributes) {
30
+ if (attribute.type === 'SpreadAttribute') {
31
+ spreads.push(b.thunk(/** @type {Expression} */ (context.visit(attribute))));
32
+ } else if (attribute.type === 'Attribute') {
33
+ const { value, has_state } = build_attribute_value(
34
+ attribute.value,
35
+ context,
36
+ (value, metadata) =>
37
+ metadata.has_call || metadata.has_await
38
+ ? b.call('$.get', memoizer.add(value, metadata))
39
+ : value
40
+ );
41
+
42
+ if (attribute.name === 'name') {
43
+ name = /** @type {Literal} */ (value);
44
+ } else if (attribute.name !== 'slot') {
45
+ if (has_state) {
46
+ props.push(b.get(attribute.name, [b.return(value)]));
47
+ } else {
48
+ props.push(b.init(attribute.name, value));
49
+ }
50
+ }
51
+ } else if (attribute.type === 'LetDirective') {
52
+ context.visit(attribute, { ...context.state, let_directives: lets });
53
+ }
54
+ }
55
+
56
+ memoizer.apply();
57
+
58
+ // Let bindings first, they can be used on attributes
59
+ context.state.init.push(...lets);
60
+
61
+ /** @type {Statement[]} */
62
+ const statements = memoizer.deriveds(context.state.analysis.runes);
63
+
64
+ const props_expression =
65
+ spreads.length === 0 ? b.object(props) : b.call('$.spread_props', b.object(props), ...spreads);
66
+
67
+ const fallback =
68
+ node.fragment.nodes.length === 0
69
+ ? b.null
70
+ : b.arrow([b.id('$$anchor')], /** @type {BlockStatement} */ (context.visit(node.fragment)));
71
+
72
+ statements.push(
73
+ b.stmt(b.call('$.slot', context.state.node, b.id('$$props'), name, props_expression, fallback))
74
+ );
75
+
76
+ const async_values = memoizer.async_values();
77
+ const blockers = memoizer.blockers();
78
+
79
+ if (async_values || blockers) {
80
+ context.state.init.push(
81
+ b.stmt(
82
+ b.call(
83
+ '$.async',
84
+ context.state.node,
85
+ blockers,
86
+ async_values,
87
+ b.arrow([context.state.node, ...memoizer.async_ids()], b.block(statements))
88
+ )
89
+ )
90
+ );
91
+ } else {
92
+ context.state.init.push(statements.length === 1 ? statements[0] : b.block(statements));
93
+ }
94
+ }
@@ -0,0 +1,94 @@
1
+ /** @import { AssignmentPattern, BlockStatement, Expression, Identifier, Statement } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { ComponentContext } from '../types' */
4
+ import { dev } from '../../../../state.js';
5
+ import { extract_paths } from '../../../../utils/ast.js';
6
+ import * as b from '#compiler/builders';
7
+ import { get_value } from './shared/declarations.js';
8
+
9
+ /**
10
+ * @param {AST.SnippetBlock} node
11
+ * @param {ComponentContext} context
12
+ */
13
+ export function SnippetBlock(node, context) {
14
+ // TODO hoist where possible
15
+ /** @type {(Identifier | AssignmentPattern)[]} */
16
+ const args = [b.id('$$anchor')];
17
+ /** @type {BlockStatement} */
18
+ let body;
19
+
20
+ /** @type {Statement[]} */
21
+ const declarations = [];
22
+
23
+ const transform = { ...context.state.transform };
24
+ const child_state = { ...context.state, transform };
25
+
26
+ for (let i = 0; i < node.parameters.length; i++) {
27
+ const argument = node.parameters[i];
28
+
29
+ if (!argument) continue;
30
+
31
+ if (argument.type === 'Identifier') {
32
+ args.push(b.assignment_pattern(argument, b.id('$.noop')));
33
+ transform[argument.name] = { read: b.call };
34
+
35
+ continue;
36
+ }
37
+
38
+ let arg_alias = `$$arg${i}`;
39
+ args.push(b.id(arg_alias));
40
+
41
+ const { inserts, paths } = extract_paths(argument, b.maybe_call(b.id(arg_alias)));
42
+
43
+ for (const { id, value } of inserts) {
44
+ id.name = context.state.scope.generate('$$array');
45
+ transform[id.name] = { read: get_value };
46
+
47
+ declarations.push(
48
+ b.var(id, b.call('$.derived', /** @type {Expression} */ (context.visit(b.thunk(value)))))
49
+ );
50
+ }
51
+
52
+ for (const path of paths) {
53
+ const name = /** @type {Identifier} */ (path.node).name;
54
+ const needs_derived = path.has_default_value; // to ensure that default value is only called once
55
+ const fn = b.thunk(/** @type {Expression} */ (context.visit(path.expression, child_state)));
56
+
57
+ declarations.push(b.let(path.node, needs_derived ? b.call('$.derived_safe_equal', fn) : fn));
58
+
59
+ transform[name] = {
60
+ read: needs_derived ? get_value : b.call
61
+ };
62
+
63
+ // we need to eagerly evaluate the expression in order to hit any
64
+ // 'Cannot access x before initialization' errors
65
+ if (dev) {
66
+ declarations.push(b.stmt(transform[name].read(b.id(name))));
67
+ }
68
+ }
69
+ }
70
+ const block = /** @type {BlockStatement} */ (context.visit(node.body, child_state)).body;
71
+ body = b.block([
72
+ dev ? b.stmt(b.call('$.validate_snippet_args', b.spread(b.id('arguments')))) : b.empty,
73
+ ...declarations,
74
+ ...block
75
+ ]);
76
+
77
+ // in dev we use a FunctionExpression (not arrow function) so we can use `arguments`
78
+ let snippet = dev
79
+ ? b.call('$.wrap_snippet', b.id(context.state.analysis.name), b.function(null, args, body))
80
+ : b.arrow(args, body);
81
+
82
+ const declaration = b.const(node.expression, snippet);
83
+
84
+ // Top-level snippets are hoisted so they can be referenced in the `<script>`
85
+ if (context.path.length === 1 && context.path[0].type === 'Fragment') {
86
+ if (node.metadata.can_hoist) {
87
+ context.state.module_level_snippets.push(declaration);
88
+ } else {
89
+ context.state.instance_level_snippets.push(declaration);
90
+ }
91
+ } else {
92
+ context.state.snippets.push(declaration);
93
+ }
94
+ }
@@ -0,0 +1,10 @@
1
+ /** @import { AST } from '#compiler' */
2
+ /** @import { ComponentContext } from '../types' */
3
+
4
+ /**
5
+ * @param {AST.SpreadAttribute} node
6
+ * @param {ComponentContext} context
7
+ */
8
+ export function SpreadAttribute(node, context) {
9
+ return context.visit(node.expression);
10
+ }
@@ -0,0 +1,11 @@
1
+ /** @import { AST } from '#compiler' */
2
+ /** @import { ComponentContext } from '../types' */
3
+ import { visit_special_element } from './shared/special_element.js';
4
+
5
+ /**
6
+ * @param {AST.SvelteBody} node
7
+ * @param {ComponentContext} context
8
+ */
9
+ export function SvelteBody(node, context) {
10
+ visit_special_element(node, '$.document.body', context);
11
+ }
@@ -0,0 +1,126 @@
1
+ /** @import { BlockStatement, Statement, Expression, VariableDeclaration } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { ComponentContext } from '../types' */
4
+ import { dev } from '../../../../state.js';
5
+ import * as b from '#compiler/builders';
6
+
7
+ /**
8
+ * @param {AST.SvelteBoundary} node
9
+ * @param {ComponentContext} context
10
+ */
11
+ export function SvelteBoundary(node, context) {
12
+ const props = b.object([]);
13
+
14
+ for (const attribute of node.attributes) {
15
+ if (attribute.type !== 'Attribute' || attribute.value === true) {
16
+ // these can't exist, because they would have caused validation
17
+ // to fail, but typescript doesn't know that
18
+ continue;
19
+ }
20
+
21
+ const chunk = Array.isArray(attribute.value)
22
+ ? /** @type {AST.ExpressionTag} */ (attribute.value[0])
23
+ : attribute.value;
24
+
25
+ const expression = /** @type {Expression} */ (context.visit(chunk.expression, context.state));
26
+
27
+ if (chunk.metadata.expression.has_state) {
28
+ props.properties.push(b.get(attribute.name, [b.return(expression)]));
29
+ } else {
30
+ props.properties.push(b.init(attribute.name, expression));
31
+ }
32
+ }
33
+
34
+ const nodes = [];
35
+
36
+ /** @type {Statement[]} */
37
+ const const_tags = [];
38
+
39
+ /** @type {Statement[]} */
40
+ const hoisted = [];
41
+
42
+ let has_const = false;
43
+
44
+ // const tags need to live inside the boundary, but might also be referenced in hoisted snippets.
45
+ // to resolve this we cheat: we duplicate const tags inside snippets
46
+ // We'll revert this behavior in the future, it was a mistake to allow this (Component snippets also don't do this).
47
+ for (const child of node.fragment.nodes) {
48
+ if (child.type === 'ConstTag') {
49
+ has_const = true;
50
+ if (!context.state.options.experimental.async) {
51
+ context.visit(child, {
52
+ ...context.state,
53
+ consts: const_tags,
54
+ scope: context.state.scopes.get(node.fragment) ?? context.state.scope
55
+ });
56
+ }
57
+ }
58
+ }
59
+
60
+ for (const child of node.fragment.nodes) {
61
+ if (child.type === 'ConstTag') {
62
+ if (context.state.options.experimental.async) {
63
+ nodes.push(child);
64
+ }
65
+ continue;
66
+ }
67
+
68
+ if (child.type === 'SnippetBlock') {
69
+ if (
70
+ context.state.options.experimental.async &&
71
+ has_const &&
72
+ !['failed', 'pending'].includes(child.expression.name)
73
+ ) {
74
+ // we can't hoist snippets as they may reference const tags, so we just keep them in the fragment
75
+ nodes.push(child);
76
+ } else {
77
+ /** @type {Statement[]} */
78
+ const statements = [];
79
+
80
+ context.visit(child, { ...context.state, snippets: statements });
81
+
82
+ const snippet = /** @type {VariableDeclaration} */ (statements[0]);
83
+
84
+ const snippet_fn = dev
85
+ ? // @ts-expect-error we know this shape is correct
86
+ snippet.declarations[0].init.arguments[1]
87
+ : snippet.declarations[0].init;
88
+
89
+ if (!context.state.options.experimental.async) {
90
+ snippet_fn.body.body.unshift(
91
+ ...const_tags.filter((node) => node.type === 'VariableDeclaration')
92
+ );
93
+ }
94
+
95
+ if (['failed', 'pending'].includes(child.expression.name)) {
96
+ props.properties.push(b.prop('init', child.expression, child.expression));
97
+ }
98
+
99
+ hoisted.push(snippet);
100
+ }
101
+
102
+ continue;
103
+ }
104
+
105
+ nodes.push(child);
106
+ }
107
+
108
+ const block = /** @type {BlockStatement} */ (
109
+ context.visit(
110
+ { ...node.fragment, nodes },
111
+ // Since we're creating a new fragment the reference in scopes can't match, so we gotta attach the right scope manually
112
+ { ...context.state, scope: context.state.scopes.get(node.fragment) ?? context.state.scope }
113
+ )
114
+ );
115
+
116
+ if (!context.state.options.experimental.async) {
117
+ block.body.unshift(...const_tags);
118
+ }
119
+
120
+ const boundary = b.stmt(
121
+ b.call('$.boundary', context.state.node, props, b.arrow([b.id('$$anchor')], block))
122
+ );
123
+
124
+ context.state.template.push_comment();
125
+ context.state.init.push(hoisted.length > 0 ? b.block([...hoisted, boundary]) : boundary);
126
+ }
@@ -0,0 +1,13 @@
1
+ /** @import { AST } from '#compiler' */
2
+ /** @import { ComponentContext } from '../types' */
3
+ import { build_component } from './shared/component.js';
4
+ import * as b from '#compiler/builders';
5
+
6
+ /**
7
+ * @param {AST.SvelteComponent} node
8
+ * @param {ComponentContext} context
9
+ */
10
+ export function SvelteComponent(node, context) {
11
+ const component = build_component(node, '$$component', null, context);
12
+ context.state.init.push(component);
13
+ }
@@ -0,0 +1,11 @@
1
+ /** @import { AST } from '#compiler' */
2
+ /** @import { ComponentContext } from '../types' */
3
+ import { visit_special_element } from './shared/special_element.js';
4
+
5
+ /**
6
+ * @param {AST.SvelteDocument} node
7
+ * @param {ComponentContext} context
8
+ */
9
+ export function SvelteDocument(node, context) {
10
+ visit_special_element(node, '$.document', context);
11
+ }
@@ -0,0 +1,161 @@
1
+ /** @import { BlockStatement, Expression, ExpressionStatement, Statement } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { ComponentContext } from '../types' */
4
+ import { dev, locator } from '../../../../state.js';
5
+ import { is_text_attribute } from '../../../../utils/ast.js';
6
+ import * as b from '#compiler/builders';
7
+ import { determine_namespace_for_children } from '../../utils.js';
8
+ import {
9
+ build_attribute_value,
10
+ build_attribute_effect,
11
+ build_set_class
12
+ } from './shared/element.js';
13
+ import { build_render_statement, Memoizer } from './shared/utils.js';
14
+
15
+ /**
16
+ * @param {AST.SvelteElement} node
17
+ * @param {ComponentContext} context
18
+ */
19
+ export function SvelteElement(node, context) {
20
+ context.state.template.push_comment();
21
+
22
+ /** @type {Array<AST.Attribute | AST.SpreadAttribute>} */
23
+ const attributes = [];
24
+
25
+ /** @type {AST.Attribute['value'] | undefined} */
26
+ let dynamic_namespace = undefined;
27
+
28
+ /** @type {AST.ClassDirective[]} */
29
+ const class_directives = [];
30
+
31
+ /** @type {AST.StyleDirective[]} */
32
+ const style_directives = [];
33
+
34
+ /** @type {ExpressionStatement[]} */
35
+ const statements = [];
36
+
37
+ // Create a temporary context which picks up the init/update statements.
38
+ // They'll then be added to the function parameter of $.element
39
+ const element_id = b.id(context.state.scope.generate('$$element'));
40
+
41
+ /** @type {ComponentContext} */
42
+ const inner_context = {
43
+ ...context,
44
+ state: {
45
+ ...context.state,
46
+ node: element_id,
47
+ init: [],
48
+ update: [],
49
+ after_update: [],
50
+ memoizer: new Memoizer()
51
+ }
52
+ };
53
+
54
+ for (const attribute of node.attributes) {
55
+ if (attribute.type === 'Attribute') {
56
+ if (attribute.name === 'xmlns' && !is_text_attribute(attribute)) {
57
+ dynamic_namespace = attribute.value;
58
+ }
59
+ attributes.push(attribute);
60
+ } else if (attribute.type === 'SpreadAttribute') {
61
+ attributes.push(attribute);
62
+ } else if (attribute.type === 'ClassDirective') {
63
+ class_directives.push(attribute);
64
+ } else if (attribute.type === 'StyleDirective') {
65
+ style_directives.push(attribute);
66
+ } else if (attribute.type === 'LetDirective') {
67
+ statements.push(/** @type {ExpressionStatement} */ (context.visit(attribute)));
68
+ } else if (attribute.type === 'OnDirective') {
69
+ const handler = /** @type {Expression} */ (context.visit(attribute, inner_context.state));
70
+ inner_context.state.after_update.push(b.stmt(handler));
71
+ } else {
72
+ context.visit(attribute, inner_context.state);
73
+ }
74
+ }
75
+
76
+ if (
77
+ attributes.length === 1 &&
78
+ attributes[0].type === 'Attribute' &&
79
+ attributes[0].name.toLowerCase() === 'class' &&
80
+ is_text_attribute(attributes[0])
81
+ ) {
82
+ build_set_class(node, element_id, attributes[0], class_directives, inner_context, false);
83
+ } else if (attributes.length) {
84
+ // Always use spread because we don't know whether the element is a custom element or not,
85
+ // therefore we need to do the "how to set an attribute" logic at runtime.
86
+ build_attribute_effect(
87
+ attributes,
88
+ class_directives,
89
+ style_directives,
90
+ inner_context,
91
+ node,
92
+ element_id
93
+ );
94
+ }
95
+
96
+ const has_await = node.metadata.expression.has_await;
97
+ const has_blockers = node.metadata.expression.has_blockers();
98
+
99
+ const expression = /** @type {Expression} */ (context.visit(node.tag));
100
+ const get_tag = b.thunk(has_await ? b.call('$.get', b.id('$$tag')) : expression);
101
+
102
+ /** @type {Statement[]} */
103
+ const inner = inner_context.state.init;
104
+ if (inner_context.state.update.length > 0) {
105
+ inner.push(build_render_statement(inner_context.state));
106
+ }
107
+ inner.push(...inner_context.state.after_update);
108
+ inner.push(
109
+ .../** @type {BlockStatement} */ (
110
+ context.visit(node.fragment, {
111
+ ...context.state,
112
+ metadata: {
113
+ ...context.state.metadata,
114
+ namespace: determine_namespace_for_children(node, context.state.metadata.namespace)
115
+ }
116
+ })
117
+ ).body
118
+ );
119
+
120
+ if (dev) {
121
+ statements.push(b.stmt(b.call('$.validate_dynamic_element_tag', get_tag)));
122
+ if (node.fragment.nodes.length > 0) {
123
+ statements.push(b.stmt(b.call('$.validate_void_dynamic_element', get_tag)));
124
+ }
125
+ }
126
+
127
+ const location = dev && locator(node.start);
128
+
129
+ statements.push(
130
+ b.stmt(
131
+ b.call(
132
+ '$.element',
133
+ context.state.node,
134
+ get_tag,
135
+ node.metadata.svg || node.metadata.mathml ? b.true : b.false,
136
+ inner.length > 0 && b.arrow([element_id, b.id('$$anchor')], b.block(inner)),
137
+ dynamic_namespace && b.thunk(build_attribute_value(dynamic_namespace, context).value),
138
+ location && b.array([b.literal(location.line), b.literal(location.column)])
139
+ )
140
+ )
141
+ );
142
+
143
+ if (has_await || has_blockers) {
144
+ context.state.init.push(
145
+ b.stmt(
146
+ b.call(
147
+ '$.async',
148
+ context.state.node,
149
+ node.metadata.expression.blockers(),
150
+ has_await ? b.array([b.thunk(expression, true)]) : b.void0,
151
+ b.arrow(
152
+ has_await ? [context.state.node, b.id('$$tag')] : [context.state.node],
153
+ b.block(statements)
154
+ )
155
+ )
156
+ )
157
+ );
158
+ } else {
159
+ context.state.init.push(statements.length === 1 ? statements[0] : b.block(statements));
160
+ }
161
+ }
@@ -0,0 +1,17 @@
1
+ /** @import { BlockStatement, ExpressionStatement } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { ComponentContext } from '../types' */
4
+
5
+ /**
6
+ * @param {AST.SvelteFragment} node
7
+ * @param {ComponentContext} context
8
+ */
9
+ export function SvelteFragment(node, context) {
10
+ for (const attribute of node.attributes) {
11
+ if (attribute.type === 'LetDirective') {
12
+ context.visit(attribute);
13
+ }
14
+ }
15
+
16
+ context.state.init.push(.../** @type {BlockStatement} */ (context.visit(node.fragment)).body);
17
+ }
@@ -0,0 +1,23 @@
1
+ /** @import { BlockStatement } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { ComponentContext } from '../types' */
4
+ import * as b from '#compiler/builders';
5
+ import { hash } from '../../../../../utils.js';
6
+ import { filename } from '../../../../state.js';
7
+
8
+ /**
9
+ * @param {AST.SvelteHead} node
10
+ * @param {ComponentContext} context
11
+ */
12
+ export function SvelteHead(node, context) {
13
+ // TODO attributes?
14
+ context.state.init.push(
15
+ b.stmt(
16
+ b.call(
17
+ b.id('$.head', node.name_loc),
18
+ b.literal(hash(filename)),
19
+ b.arrow([b.id('$$anchor')], /** @type {BlockStatement} */ (context.visit(node.fragment)))
20
+ )
21
+ )
22
+ );
23
+ }
@@ -0,0 +1,13 @@
1
+ /** @import { AST } from '#compiler' */
2
+ /** @import { ComponentContext } from '../types' */
3
+ import { component_name } from '../../../../state.js';
4
+ import { build_component } from './shared/component.js';
5
+
6
+ /**
7
+ * @param {AST.SvelteSelf} node
8
+ * @param {ComponentContext} context
9
+ */
10
+ export function SvelteSelf(node, context) {
11
+ const component = build_component(node, component_name, node.name_loc, context);
12
+ context.state.init.push(component);
13
+ }
@@ -0,0 +1,11 @@
1
+ /** @import { AST } from '#compiler' */
2
+ /** @import { ComponentContext } from '../types' */
3
+ import { visit_special_element } from './shared/special_element.js';
4
+
5
+ /**
6
+ * @param {AST.SvelteWindow} node
7
+ * @param {ComponentContext} context
8
+ */
9
+ export function SvelteWindow(node, context) {
10
+ visit_special_element(node, '$.window', context);
11
+ }