@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,719 @@
1
+ /** @import * as ESTree from 'estree' */
2
+ /** @import { AST, ValidatedCompileOptions, ValidatedModuleCompileOptions } from '#compiler' */
3
+ /** @import { ComponentAnalysis, Analysis } from '../../types' */
4
+ /** @import { Visitors, ComponentClientTransformState, ClientTransformState } from './types' */
5
+ import { walk } from 'zimmerframe';
6
+ import * as b from '#compiler/builders';
7
+ import { build_getter, is_state_source } from './utils.js';
8
+ import { render_stylesheet } from '../css/index.js';
9
+ import { dev, filename } from '../../../state.js';
10
+ import { AnimateDirective } from './visitors/AnimateDirective.js';
11
+ import { ArrowFunctionExpression } from './visitors/ArrowFunctionExpression.js';
12
+ import { AssignmentExpression } from './visitors/AssignmentExpression.js';
13
+ import { Attribute } from './visitors/Attribute.js';
14
+ import { AwaitBlock } from './visitors/AwaitBlock.js';
15
+ import { AwaitExpression } from './visitors/AwaitExpression.js';
16
+ import { BinaryExpression } from './visitors/BinaryExpression.js';
17
+ import { BindDirective } from './visitors/BindDirective.js';
18
+ import { BlockStatement } from './visitors/BlockStatement.js';
19
+ import { BreakStatement } from './visitors/BreakStatement.js';
20
+ import { CallExpression } from './visitors/CallExpression.js';
21
+ import { ClassBody } from './visitors/ClassBody.js';
22
+ import { Comment } from './visitors/Comment.js';
23
+ import { Component } from './visitors/Component.js';
24
+ import { ConstTag } from './visitors/ConstTag.js';
25
+ import { DebugTag } from './visitors/DebugTag.js';
26
+ import { EachBlock } from './visitors/EachBlock.js';
27
+ import { ExportNamedDeclaration } from './visitors/ExportNamedDeclaration.js';
28
+ import { ExpressionStatement } from './visitors/ExpressionStatement.js';
29
+ import { ForOfStatement } from './visitors/ForOfStatement.js';
30
+ import { Fragment } from './visitors/Fragment.js';
31
+ import { FunctionDeclaration } from './visitors/FunctionDeclaration.js';
32
+ import { FunctionExpression } from './visitors/FunctionExpression.js';
33
+ import { HtmlTag } from './visitors/HtmlTag.js';
34
+ import { Identifier } from './visitors/Identifier.js';
35
+ import { IfBlock } from './visitors/IfBlock.js';
36
+ import { KeyBlock } from './visitors/KeyBlock.js';
37
+ import { LabeledStatement } from './visitors/LabeledStatement.js';
38
+ import { LetDirective } from './visitors/LetDirective.js';
39
+ import { MemberExpression } from './visitors/MemberExpression.js';
40
+ import { OnDirective } from './visitors/OnDirective.js';
41
+ import { Program } from './visitors/Program.js';
42
+ import { RegularElement } from './visitors/RegularElement.js';
43
+ import { RenderTag } from './visitors/RenderTag.js';
44
+ import { SlotElement } from './visitors/SlotElement.js';
45
+ import { SnippetBlock } from './visitors/SnippetBlock.js';
46
+ import { SpreadAttribute } from './visitors/SpreadAttribute.js';
47
+ import { SvelteBody } from './visitors/SvelteBody.js';
48
+ import { SvelteComponent } from './visitors/SvelteComponent.js';
49
+ import { SvelteDocument } from './visitors/SvelteDocument.js';
50
+ import { SvelteElement } from './visitors/SvelteElement.js';
51
+ import { SvelteFragment } from './visitors/SvelteFragment.js';
52
+ import { SvelteBoundary } from './visitors/SvelteBoundary.js';
53
+ import { SvelteHead } from './visitors/SvelteHead.js';
54
+ import { SvelteSelf } from './visitors/SvelteSelf.js';
55
+ import { SvelteWindow } from './visitors/SvelteWindow.js';
56
+ import { TitleElement } from './visitors/TitleElement.js';
57
+ import { TransitionDirective } from './visitors/TransitionDirective.js';
58
+ import { UpdateExpression } from './visitors/UpdateExpression.js';
59
+ import { UseDirective } from './visitors/UseDirective.js';
60
+ import { AttachTag } from './visitors/AttachTag.js';
61
+ import { VariableDeclaration } from './visitors/VariableDeclaration.js';
62
+
63
+ /** @type {Visitors} */
64
+ const visitors = {
65
+ _: function set_scope(node, { next, state }) {
66
+ const scope = state.scopes.get(node);
67
+
68
+ if (scope && scope !== state.scope) {
69
+ const transform = { ...state.transform };
70
+
71
+ for (const [name, binding] of scope.declarations) {
72
+ if (
73
+ binding.kind === 'normal' ||
74
+ // Reads of `$state(...)` declarations are not
75
+ // transformed if they are never reassigned
76
+ (binding.kind === 'state' && !is_state_source(binding, state.analysis))
77
+ ) {
78
+ delete transform[name];
79
+ }
80
+ }
81
+
82
+ next({ ...state, transform, scope });
83
+ } else {
84
+ next();
85
+ }
86
+ },
87
+ AnimateDirective,
88
+ ArrowFunctionExpression,
89
+ AssignmentExpression,
90
+ Attribute,
91
+ AwaitBlock,
92
+ AwaitExpression,
93
+ BinaryExpression,
94
+ BindDirective,
95
+ BlockStatement,
96
+ BreakStatement,
97
+ CallExpression,
98
+ ClassBody,
99
+ Comment,
100
+ Component,
101
+ ConstTag,
102
+ DebugTag,
103
+ EachBlock,
104
+ ExportNamedDeclaration,
105
+ ExpressionStatement,
106
+ ForOfStatement,
107
+ Fragment,
108
+ FunctionDeclaration,
109
+ FunctionExpression,
110
+ HtmlTag,
111
+ Identifier,
112
+ IfBlock,
113
+ KeyBlock,
114
+ LabeledStatement,
115
+ LetDirective,
116
+ MemberExpression,
117
+ OnDirective,
118
+ Program,
119
+ RegularElement,
120
+ RenderTag,
121
+ SlotElement,
122
+ SnippetBlock,
123
+ SpreadAttribute,
124
+ SvelteBody,
125
+ SvelteComponent,
126
+ SvelteDocument,
127
+ SvelteElement,
128
+ SvelteFragment,
129
+ SvelteBoundary,
130
+ SvelteHead,
131
+ SvelteSelf,
132
+ SvelteWindow,
133
+ TitleElement,
134
+ TransitionDirective,
135
+ UpdateExpression,
136
+ UseDirective,
137
+ AttachTag,
138
+ VariableDeclaration
139
+ };
140
+
141
+ /**
142
+ * @param {ComponentAnalysis} analysis
143
+ * @param {ValidatedCompileOptions} options
144
+ * @returns {ESTree.Program}
145
+ */
146
+ export function client_component(analysis, options) {
147
+ /** @type {ComponentClientTransformState} */
148
+ const state = {
149
+ analysis,
150
+ options,
151
+ scope: analysis.module.scope,
152
+ scopes: analysis.module.scopes,
153
+ is_instance: false,
154
+ hoisted: [b.import_all('$', 'svelte/internal/client'), ...analysis.instance_body.hoisted],
155
+ node: /** @type {any} */ (null), // populated by the root node
156
+ legacy_reactive_imports: [],
157
+ legacy_reactive_statements: new Map(),
158
+ metadata: {
159
+ namespace: options.namespace,
160
+ bound_contenteditable: false
161
+ },
162
+ events: new Set(),
163
+ preserve_whitespace: options.preserveWhitespace,
164
+ state_fields: new Map(),
165
+ transform: {},
166
+ in_constructor: false,
167
+ instance_level_snippets: [],
168
+ module_level_snippets: [],
169
+ is_standalone: false,
170
+
171
+ // these are set inside the `Fragment` visitor, and cannot be used until then
172
+ init: /** @type {any} */ (null),
173
+ consts: /** @type {any} */ (null),
174
+ snippets: /** @type {any} */ (null),
175
+ let_directives: /** @type {any} */ (null),
176
+ update: /** @type {any} */ (null),
177
+ after_update: /** @type {any} */ (null),
178
+ template: /** @type {any} */ (null),
179
+ memoizer: /** @type {any} */ (null)
180
+ };
181
+
182
+ const module = /** @type {ESTree.Program} */ (
183
+ walk(/** @type {AST.SvelteNode} */ (analysis.module.ast), state, visitors)
184
+ );
185
+
186
+ const instance_state = {
187
+ ...state,
188
+ transform: { ...state.transform },
189
+ scope: analysis.instance.scope,
190
+ scopes: analysis.instance.scopes,
191
+ is_instance: true
192
+ };
193
+
194
+ const instance = /** @type {ESTree.Program} */ (
195
+ walk(/** @type {AST.SvelteNode} */ (analysis.instance.ast), instance_state, visitors)
196
+ );
197
+
198
+ const template = /** @type {ESTree.Program} */ (
199
+ walk(
200
+ /** @type {AST.SvelteNode} */ (analysis.template.ast),
201
+ {
202
+ ...state,
203
+ transform: instance_state.transform,
204
+ scope: analysis.instance.scope,
205
+ scopes: analysis.template.scopes
206
+ },
207
+ visitors
208
+ )
209
+ );
210
+
211
+ module.body.unshift(...state.legacy_reactive_imports);
212
+
213
+ /** @type {ESTree.Statement[]} */
214
+ const store_setup = [];
215
+ /** @type {ESTree.Statement} */
216
+ let store_init = b.empty;
217
+ /** @type {ESTree.VariableDeclaration[]} */
218
+ const legacy_reactive_declarations = [];
219
+
220
+ let needs_store_cleanup = false;
221
+
222
+ for (const [name, binding] of analysis.instance.scope.declarations) {
223
+ if (binding.kind === 'legacy_reactive') {
224
+ legacy_reactive_declarations.push(
225
+ b.const(
226
+ name,
227
+ b.call('$.mutable_source', undefined, analysis.immutable ? b.true : undefined)
228
+ )
229
+ );
230
+ }
231
+ if (binding.kind === 'store_sub') {
232
+ if (store_setup.length === 0) {
233
+ needs_store_cleanup = true;
234
+ store_init = b.const(
235
+ b.array_pattern([b.id('$$stores'), b.id('$$cleanup')]),
236
+ b.call('$.setup_stores')
237
+ );
238
+ }
239
+
240
+ // We're creating an arrow function that gets the store value which minifies better for two or more references
241
+ const store_reference = build_getter(b.id(name.slice(1)), instance_state);
242
+ const store_get = b.call('$.store_get', store_reference, b.literal(name), b.id('$$stores'));
243
+ store_setup.push(
244
+ b.const(
245
+ binding.node,
246
+ dev
247
+ ? b.thunk(
248
+ b.sequence([
249
+ b.call('$.validate_store', store_reference, b.literal(name.slice(1))),
250
+ store_get
251
+ ])
252
+ )
253
+ : b.thunk(store_get)
254
+ )
255
+ );
256
+ }
257
+ }
258
+
259
+ for (const [node] of analysis.reactive_statements) {
260
+ const statement = [...state.legacy_reactive_statements].find(([n]) => n === node);
261
+ if (statement === undefined) {
262
+ throw new Error('Could not find reactive statement');
263
+ }
264
+ instance.body.push(statement[1]);
265
+ }
266
+
267
+ if (analysis.reactive_statements.size > 0) {
268
+ instance.body.push(b.stmt(b.call('$.legacy_pre_effect_reset')));
269
+ }
270
+
271
+ /**
272
+ * Used to store the group nodes
273
+ * @type {ESTree.VariableDeclaration[]}
274
+ */
275
+ const group_binding_declarations = [];
276
+ for (const group of analysis.binding_groups.values()) {
277
+ group_binding_declarations.push(b.const(group.name, b.array([])));
278
+ }
279
+
280
+ /** @type {Array<ESTree.Property | ESTree.SpreadElement>} */
281
+ const component_returned_object = analysis.exports.flatMap(({ name, alias }) => {
282
+ const binding = instance_state.scope.get(name);
283
+ const expression = build_getter(b.id(name), instance_state);
284
+ const getter = b.get(alias ?? name, [b.return(expression)]);
285
+
286
+ if (expression.type === 'Identifier') {
287
+ if (binding?.declaration_kind === 'let' || binding?.declaration_kind === 'var') {
288
+ return [
289
+ getter,
290
+ b.set(alias ?? name, [b.stmt(b.assignment('=', expression, b.id('$$value')))])
291
+ ];
292
+ } else if (!dev) {
293
+ return b.init(alias ?? name, expression);
294
+ }
295
+ }
296
+
297
+ if (binding?.kind === 'prop' || binding?.kind === 'bindable_prop') {
298
+ return [getter, b.set(alias ?? name, [b.stmt(b.call(name, b.id('$$value')))])];
299
+ }
300
+
301
+ if (binding?.kind === 'state' || binding?.kind === 'raw_state') {
302
+ const value = binding.kind === 'state' ? b.call('$.proxy', b.id('$$value')) : b.id('$$value');
303
+ return [getter, b.set(alias ?? name, [b.stmt(b.call('$.set', b.id(name), value))])];
304
+ }
305
+
306
+ return getter;
307
+ });
308
+
309
+ const properties = [...analysis.instance.scope.declarations].filter(
310
+ ([name, binding]) =>
311
+ (binding.kind === 'prop' || binding.kind === 'bindable_prop') && !name.startsWith('$$')
312
+ );
313
+
314
+ if (analysis.accessors) {
315
+ for (const [name, binding] of properties) {
316
+ const key = binding.prop_alias ?? name;
317
+
318
+ const getter = b.get(key, [b.return(b.call(b.id(name)))]);
319
+
320
+ const setter = b.set(key, [
321
+ b.stmt(b.call(b.id(name), b.id('$$value'))),
322
+ b.stmt(b.call('$.flush'))
323
+ ]);
324
+
325
+ if (analysis.runes && binding.initial) {
326
+ // turn `set foo($$value)` into `set foo($$value = expression)`
327
+ setter.value.params[0] = {
328
+ type: 'AssignmentPattern',
329
+ left: b.id('$$value'),
330
+ right: /** @type {ESTree.Expression} */ (binding.initial)
331
+ };
332
+ }
333
+
334
+ component_returned_object.push(getter, setter);
335
+ }
336
+ }
337
+
338
+ if (options.compatibility.componentApi === 4) {
339
+ component_returned_object.push(
340
+ b.init('$set', b.id('$.update_legacy_props')),
341
+ b.init(
342
+ '$on',
343
+ b.arrow(
344
+ [b.id('$$event_name'), b.id('$$event_cb')],
345
+ b.call(
346
+ '$.add_legacy_event_listener',
347
+ b.id('$$props'),
348
+ b.id('$$event_name'),
349
+ b.id('$$event_cb')
350
+ )
351
+ )
352
+ )
353
+ );
354
+ } else if (dev) {
355
+ component_returned_object.push(b.spread(b.call(b.id('$.legacy_api'))));
356
+ }
357
+
358
+ const push_args = [b.id('$$props'), b.literal(analysis.runes)];
359
+ if (dev) push_args.push(b.id(analysis.name));
360
+
361
+ let component_block = b.block([
362
+ store_init,
363
+ ...legacy_reactive_declarations,
364
+ ...group_binding_declarations
365
+ ]);
366
+
367
+ const should_inject_context =
368
+ dev ||
369
+ analysis.needs_context ||
370
+ analysis.reactive_statements.size > 0 ||
371
+ component_returned_object.length > 0;
372
+
373
+ component_block.body.push(
374
+ ...state.instance_level_snippets,
375
+ .../** @type {ESTree.Statement[]} */ (instance.body)
376
+ );
377
+
378
+ if (should_inject_context && component_returned_object.length > 0) {
379
+ component_block.body.push(b.var('$$exports', b.object(component_returned_object)));
380
+ }
381
+ component_block.body.unshift(...store_setup);
382
+
383
+ if (!analysis.runes && analysis.needs_context) {
384
+ component_block.body.push(b.stmt(b.call('$.init', analysis.immutable ? b.true : undefined)));
385
+ }
386
+
387
+ component_block.body.push(.../** @type {ESTree.Statement[]} */ (template.body));
388
+
389
+ if (analysis.needs_mutation_validation) {
390
+ component_block.body.unshift(
391
+ b.var('$$ownership_validator', b.call('$.create_ownership_validator', b.id('$$props')))
392
+ );
393
+ }
394
+
395
+ let should_inject_props =
396
+ should_inject_context ||
397
+ analysis.needs_props ||
398
+ analysis.uses_props ||
399
+ analysis.uses_rest_props ||
400
+ analysis.uses_slots ||
401
+ analysis.slot_names.size > 0;
402
+
403
+ // trick esrap into including comments
404
+ component_block.loc = instance.loc;
405
+
406
+ if (!analysis.runes) {
407
+ // Bind static exports to props so that people can access them with bind:x
408
+ for (const { name, alias } of analysis.exports) {
409
+ component_block.body.push(
410
+ b.stmt(
411
+ b.call(
412
+ '$.bind_prop',
413
+ b.id('$$props'),
414
+ b.literal(alias ?? name),
415
+ build_getter(b.id(name), instance_state)
416
+ )
417
+ )
418
+ );
419
+ }
420
+ }
421
+
422
+ if (analysis.css.ast !== null && analysis.inject_styles) {
423
+ const hash = b.literal(analysis.css.hash);
424
+ const code = b.literal(render_stylesheet(analysis.source, analysis, options).code);
425
+
426
+ state.hoisted.push(b.const('$$css', b.object([b.init('hash', hash), b.init('code', code)])));
427
+
428
+ component_block.body.unshift(
429
+ b.stmt(b.call('$.append_styles', b.id('$$anchor'), b.id('$$css')))
430
+ );
431
+ }
432
+
433
+ // we want the cleanup function for the stores to run as the very last thing
434
+ // so that it can effectively clean up the store subscription even after the user effects runs
435
+ if (should_inject_context) {
436
+ component_block.body.unshift(b.stmt(b.call('$.push', ...push_args)));
437
+
438
+ let to_push;
439
+
440
+ if (component_returned_object.length > 0) {
441
+ let pop_call = b.call('$.pop', b.id('$$exports'));
442
+ to_push = needs_store_cleanup ? b.var('$$pop', pop_call) : b.return(pop_call);
443
+ } else {
444
+ to_push = b.stmt(b.call('$.pop'));
445
+ }
446
+
447
+ component_block.body.push(to_push);
448
+ }
449
+
450
+ if (needs_store_cleanup) {
451
+ component_block.body.push(b.stmt(b.call('$$cleanup')));
452
+
453
+ if (component_returned_object.length > 0) {
454
+ component_block.body.push(b.return(b.id('$$pop')));
455
+ }
456
+ }
457
+
458
+ if (analysis.uses_rest_props) {
459
+ const named_props = analysis.exports.map(({ name, alias }) => alias ?? name);
460
+ for (const [name, binding] of analysis.instance.scope.declarations) {
461
+ if (binding.kind === 'bindable_prop') named_props.push(binding.prop_alias ?? name);
462
+ }
463
+
464
+ component_block.body.unshift(
465
+ b.const(
466
+ '$$restProps',
467
+ b.call(
468
+ '$.legacy_rest_props',
469
+ b.id('$$sanitized_props'),
470
+ b.array(named_props.map((name) => b.literal(name)))
471
+ )
472
+ )
473
+ );
474
+ }
475
+
476
+ if (analysis.uses_props || analysis.uses_rest_props) {
477
+ const to_remove = [
478
+ b.literal('children'),
479
+ b.literal('$$slots'),
480
+ b.literal('$$events'),
481
+ b.literal('$$legacy')
482
+ ];
483
+ if (analysis.custom_element) {
484
+ to_remove.push(b.literal('$$host'));
485
+ }
486
+
487
+ component_block.body.unshift(
488
+ b.const(
489
+ '$$sanitized_props',
490
+ b.call('$.legacy_rest_props', b.id('$$props'), b.array(to_remove))
491
+ )
492
+ );
493
+ }
494
+
495
+ if (analysis.uses_slots) {
496
+ component_block.body.unshift(b.const('$$slots', b.call('$.sanitize_slots', b.id('$$props'))));
497
+ }
498
+
499
+ // Merge hoisted statements into module body.
500
+ // Ensure imports are on top, with the order preserved, then module body, then hoisted statements
501
+ /** @type {ESTree.ImportDeclaration[]} */
502
+ const imports = [];
503
+ /** @type {ESTree.Program['body']} */
504
+ let body = [];
505
+
506
+ for (const entry of [...module.body, ...state.hoisted]) {
507
+ if (entry.type === 'ImportDeclaration') {
508
+ imports.push(entry);
509
+ } else {
510
+ body.push(entry);
511
+ }
512
+ }
513
+
514
+ body = [...imports, ...state.module_level_snippets, ...body];
515
+
516
+ const component = b.function_declaration(
517
+ b.id(analysis.name),
518
+ should_inject_props ? [b.id('$$anchor'), b.id('$$props')] : [b.id('$$anchor')],
519
+ component_block
520
+ );
521
+
522
+ if (options.hmr) {
523
+ const id = b.id(analysis.name);
524
+
525
+ const accept_fn_body = [
526
+ b.stmt(b.call(b.member(b.member(id, b.id('$.HMR'), true), 'update'), b.id('module.default')))
527
+ ];
528
+
529
+ if (analysis.css.hash) {
530
+ // remove existing `<style>` element, in case CSS changed
531
+ accept_fn_body.unshift(b.stmt(b.call('$.cleanup_styles', b.literal(analysis.css.hash))));
532
+ }
533
+
534
+ const hmr = b.block([
535
+ b.stmt(b.assignment('=', id, b.call('$.hmr', id))),
536
+ b.stmt(b.call('import.meta.hot.accept', b.arrow([b.id('module')], b.block(accept_fn_body))))
537
+ ]);
538
+
539
+ body.push(component, b.if(b.id('import.meta.hot'), hmr), b.export_default(b.id(analysis.name)));
540
+ } else {
541
+ body.push(b.export_default(component));
542
+ }
543
+
544
+ if (dev) {
545
+ // add `App[$.FILENAME] = 'App.svelte'` so that we can print useful messages later
546
+ body.unshift(
547
+ b.stmt(
548
+ b.assignment('=', b.member(b.id(analysis.name), '$.FILENAME', true), b.literal(filename))
549
+ )
550
+ );
551
+ }
552
+
553
+ if (options.experimental.async) {
554
+ body.unshift(b.imports([], 'svelte/internal/flags/async'));
555
+ }
556
+
557
+ if (!analysis.runes) {
558
+ body.unshift(b.imports([], 'svelte/internal/flags/legacy'));
559
+ }
560
+
561
+ if (analysis.tracing) {
562
+ body.unshift(b.imports([], 'svelte/internal/flags/tracing'));
563
+ }
564
+
565
+ if (options.discloseVersion) {
566
+ body.unshift(b.imports([], 'svelte/internal/disclose-version'));
567
+ }
568
+
569
+ if (options.compatibility.componentApi === 4) {
570
+ body.unshift(b.imports([['createClassComponent', '$$_createClassComponent']], 'svelte/legacy'));
571
+ component_block.body.unshift(
572
+ b.if(
573
+ b.id('new.target'),
574
+ b.return(
575
+ b.call(
576
+ '$$_createClassComponent',
577
+ // When called with new, the first argument is the constructor options
578
+ b.object([b.init('component', b.id(analysis.name)), b.spread(b.id('$$anchor'))])
579
+ )
580
+ )
581
+ )
582
+ );
583
+ } else if (dev) {
584
+ component_block.body.unshift(b.stmt(b.call('$.check_target', b.id('new.target'))));
585
+ }
586
+
587
+ if (analysis.props_id) {
588
+ // need to be placed on first line of the component for hydration
589
+ component_block.body.unshift(b.const(analysis.props_id, b.call('$.props_id')));
590
+ }
591
+
592
+ if (state.events.size > 0) {
593
+ body.push(
594
+ b.stmt(b.call('$.delegate', b.array(Array.from(state.events).map((name) => b.literal(name)))))
595
+ );
596
+ }
597
+
598
+ const ce = options.customElementOptions ?? options.customElement;
599
+
600
+ if (ce) {
601
+ const ce_props = typeof ce === 'boolean' ? {} : ce.props || {};
602
+
603
+ /** @type {ESTree.Property[]} */
604
+ const props_str = [];
605
+
606
+ for (const [name, prop_def] of Object.entries(ce_props)) {
607
+ const binding = analysis.instance.scope.get(name);
608
+ const key = binding?.prop_alias ?? name;
609
+
610
+ if (
611
+ !prop_def.type &&
612
+ binding?.initial?.type === 'Literal' &&
613
+ typeof binding?.initial.value === 'boolean'
614
+ ) {
615
+ prop_def.type = 'Boolean';
616
+ }
617
+
618
+ const value = b.object(
619
+ /** @type {ESTree.Property[]} */ (
620
+ [
621
+ prop_def.attribute ? b.init('attribute', b.literal(prop_def.attribute)) : undefined,
622
+ prop_def.reflect ? b.init('reflect', b.true) : undefined,
623
+ prop_def.type ? b.init('type', b.literal(prop_def.type)) : undefined
624
+ ].filter(Boolean)
625
+ )
626
+ );
627
+
628
+ props_str.push(b.init(key, value));
629
+ }
630
+
631
+ for (const [name, binding] of properties) {
632
+ const key = binding.prop_alias ?? name;
633
+ if (ce_props[key]) continue;
634
+
635
+ props_str.push(b.init(key, b.object([])));
636
+ }
637
+
638
+ const slots_str = b.array([...analysis.slot_names.keys()].map((name) => b.literal(name)));
639
+ const accessors_str = b.array(
640
+ analysis.exports.map(({ name, alias }) => b.literal(alias ?? name))
641
+ );
642
+
643
+ /** @type {ESTree.ObjectExpression | undefined} */
644
+ let shadow_root_init;
645
+ if (typeof ce === 'boolean' || ce.shadow === 'open' || ce.shadow === undefined) {
646
+ shadow_root_init = b.object([b.init('mode', b.literal('open'))]);
647
+ } else if (ce.shadow === 'none') {
648
+ shadow_root_init = undefined;
649
+ } else {
650
+ shadow_root_init = ce.shadow;
651
+ }
652
+
653
+ const create_ce = b.call(
654
+ '$.create_custom_element',
655
+ b.id(analysis.name),
656
+ b.object(props_str),
657
+ slots_str,
658
+ accessors_str,
659
+ shadow_root_init,
660
+ /** @type {any} */ (typeof ce !== 'boolean' ? ce.extend : undefined)
661
+ );
662
+
663
+ // If a tag name is provided, call `customElements.define`, otherwise leave to the user
664
+ if (typeof ce !== 'boolean' && typeof ce.tag === 'string') {
665
+ const define = b.stmt(b.call('customElements.define', b.literal(ce.tag), create_ce));
666
+
667
+ if (options.hmr) {
668
+ body.push(
669
+ b.if(b.binary('==', b.call('customElements.get', b.literal(ce.tag)), b.null), define)
670
+ );
671
+ } else {
672
+ body.push(define);
673
+ }
674
+ } else {
675
+ body.push(b.stmt(create_ce));
676
+ }
677
+ }
678
+
679
+ return {
680
+ type: 'Program',
681
+ sourceType: 'module',
682
+ body
683
+ };
684
+ }
685
+
686
+ /**
687
+ * @param {Analysis} analysis
688
+ * @param {ValidatedModuleCompileOptions} options
689
+ * @returns {ESTree.Program}
690
+ */
691
+ export function client_module(analysis, options) {
692
+ /** @type {ClientTransformState} */
693
+ const state = {
694
+ analysis,
695
+ options,
696
+ scope: analysis.module.scope,
697
+ scopes: analysis.module.scopes,
698
+ state_fields: new Map(),
699
+ transform: {},
700
+ in_constructor: false,
701
+ is_instance: false
702
+ };
703
+
704
+ const module = /** @type {ESTree.Program} */ (
705
+ walk(/** @type {AST.SvelteNode} */ (analysis.module.ast), state, visitors)
706
+ );
707
+
708
+ const body = [b.import_all('$', 'svelte/internal/client')];
709
+
710
+ if (analysis.tracing) {
711
+ body.push(b.imports([], 'svelte/internal/flags/tracing'));
712
+ }
713
+
714
+ return {
715
+ type: 'Program',
716
+ sourceType: 'module',
717
+ body: [...body, ...module.body]
718
+ };
719
+ }