lumen-plus 0.0.5 → 0.0.6
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.
- package/dist/components/Alert/Alert.svelte +1 -1
- package/dist/components/Autocomplete/Autocomplete.svelte +1 -1
- package/dist/components/Backtop/Backtop.svelte +1 -1
- package/dist/components/Breadcrumb/Breadcrumb.svelte +1 -1
- package/dist/components/Button/Button.svelte +1 -1
- package/dist/components/Calendar/Calendar.svelte +1 -1
- package/dist/components/Carousel/Carousel.svelte +1 -1
- package/dist/components/Cascader/Cascader.svelte +1 -1
- package/dist/components/Checkbox/Checkbox.svelte +1 -1
- package/dist/components/Collapse/CollapseItem.svelte +1 -1
- package/dist/components/ColorPicker/ColorPicker.svelte +1 -1
- package/dist/components/DatePicker/DatePicker.svelte +1 -1
- package/dist/components/DateTimePicker/DateTimePicker.svelte +1 -1
- package/dist/components/Dialog/Dialog.svelte +1 -1
- package/dist/components/Drawer/Drawer.svelte +1 -1
- package/dist/components/Dropdown/Dropdown.svelte +1 -1
- package/dist/components/Image/Image.svelte +1 -1
- package/dist/components/Input/Input.svelte +1 -1
- package/dist/components/InputNumber/InputNumber.svelte +1 -1
- package/dist/components/InputTag/InputTag.svelte +1 -1
- package/dist/components/Loading/Loading.svelte +1 -1
- package/dist/components/Menu/Menu.svelte +1 -1
- package/dist/components/Message/MessageBox.svelte +1 -1
- package/dist/components/MessageBox/MessageBox.svelte +2 -2
- package/dist/components/Notification/Notification.svelte +1 -1
- package/dist/components/Pagination/Pagination.svelte +4 -4
- package/dist/components/Popconfirm/Popconfirm.svelte +2 -2
- package/dist/components/Result/Result.svelte +1 -1
- package/dist/components/Select/Select.svelte +1 -1
- package/dist/components/Slider/Slider.svelte +1 -1
- package/dist/components/Steps/Step.svelte +1 -1
- package/dist/components/Switch/Switch.svelte +1 -1
- package/dist/components/Table/Table.svelte +5 -5
- package/dist/components/Tabs/Tabs.svelte +1 -1
- package/dist/components/Tag/Tag.svelte +1 -1
- package/dist/components/Textarea/Textarea.svelte +1 -1
- package/dist/components/TimePicker/TimePicker.svelte +1 -1
- package/dist/components/Transfer/Transfer.svelte +2 -2
- package/dist/components/Tree/TreeNode.svelte +2 -2
- package/dist/components/TreeSelect/TreeSelect.svelte +3 -3
- package/dist/components/Upload/Upload.svelte +1 -1
- package/dist/utils/node_modules/.bin/tsc +2 -0
- package/dist/utils/node_modules/.bin/tsserver +2 -0
- package/dist/utils/node_modules/svelte/LICENSE.md +7 -0
- package/dist/utils/node_modules/svelte/README.md +41 -0
- package/dist/utils/node_modules/svelte/compiler/index.js +1 -0
- package/dist/utils/node_modules/svelte/compiler/package.json +3 -0
- package/dist/utils/node_modules/svelte/package.json +184 -0
- package/dist/utils/node_modules/svelte/src/animate/index.js +78 -0
- package/dist/utils/node_modules/svelte/src/attachments/index.js +113 -0
- package/dist/utils/node_modules/svelte/src/compiler/errors.js +1719 -0
- package/dist/utils/node_modules/svelte/src/compiler/index.js +198 -0
- package/dist/utils/node_modules/svelte/src/compiler/legacy.js +632 -0
- package/dist/utils/node_modules/svelte/src/compiler/migrate/index.js +1996 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/acorn.js +198 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/index.js +326 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/context.js +116 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/expression.js +93 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/options.js +261 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/script.js +97 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/style.js +633 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/remove_typescript_nodes.js +180 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/state/element.js +877 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/state/fragment.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/state/tag.js +751 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/state/text.js +23 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/bracket.js +213 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/create.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/entities.js +2234 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/fuzzymatch.js +280 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/html.js +127 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/css/css-analyze.js +331 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/css/css-prune.js +1160 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/css/css-warn.js +47 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/css/utils.js +177 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/index.js +1283 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/utils/check_graph_for_cycles.js +47 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AnimateDirective.js +15 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ArrowFunctionExpression.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AssignmentExpression.js +31 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AttachTag.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Attribute.js +66 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AwaitBlock.js +48 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AwaitExpression.js +150 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/BindDirective.js +280 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/CallExpression.js +339 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ClassBody.js +156 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ClassDeclaration.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ClassDirective.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Component.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ConstTag.js +45 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/DebugTag.js +15 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/EachBlock.js +97 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExportDefaultDeclaration.js +20 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExportNamedDeclaration.js +70 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExportSpecifier.js +30 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExpressionStatement.js +38 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExpressionTag.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Fragment.js +10 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/FunctionDeclaration.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/FunctionExpression.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/HtmlTag.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Identifier.js +193 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/IfBlock.js +27 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ImportDeclaration.js +31 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/KeyBlock.js +21 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/LabeledStatement.js +95 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/LetDirective.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Literal.js +14 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/MemberExpression.js +28 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/NewExpression.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/OnDirective.js +28 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/PropertyDefinition.js +21 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/RegularElement.js +210 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/RenderTag.js +68 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SlotElement.js +42 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SnippetBlock.js +113 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SpreadAttribute.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SpreadElement.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/StyleDirective.js +39 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteBody.js +22 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteBoundary.js +30 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteComponent.js +18 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteDocument.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteElement.js +78 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteFragment.js +27 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteHead.js +18 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteSelf.js +36 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteWindow.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/TaggedTemplateExpression.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/TemplateElement.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Text.js +52 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/TitleElement.js +21 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/TransitionDirective.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/UpdateExpression.js +29 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/UseDirective.js +18 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/VariableDeclarator.js +160 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/a11y/constants.js +319 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/a11y/index.js +977 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/attribute.js +125 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/component.js +177 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/element.js +160 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/fragment.js +15 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/function.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/snippets.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/special-element.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/utils.js +301 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/transform-client.js +709 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/transform-template/fix-attribute-casing.js +18 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/transform-template/index.js +67 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/transform-template/template.js +162 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/utils.js +181 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AnimateDirective.js +38 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ArrowFunctionExpression.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AssignmentExpression.js +225 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AttachTag.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Attribute.js +14 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AwaitBlock.js +124 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AwaitExpression.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/BinaryExpression.js +34 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/BindDirective.js +290 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/BlockStatement.js +32 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/BreakStatement.js +20 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/CallExpression.js +136 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ClassBody.js +111 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Comment.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Component.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ConstTag.js +134 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/DebugTag.js +28 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/EachBlock.js +367 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ExportNamedDeclaration.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ExpressionStatement.js +20 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ForOfStatement.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Fragment.js +181 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/FunctionDeclaration.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/FunctionExpression.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/HtmlTag.js +49 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Identifier.js +45 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/IfBlock.js +90 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/KeyBlock.js +39 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/LabeledStatement.js +64 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/LetDirective.js +55 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/MemberExpression.js +23 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/OnDirective.js +38 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Program.js +153 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/RegularElement.js +791 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/RenderTag.js +91 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SlotElement.js +94 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SnippetBlock.js +94 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SpreadAttribute.js +10 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteBody.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteBoundary.js +126 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteComponent.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteDocument.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteElement.js +157 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteFragment.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteHead.js +23 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteSelf.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteWindow.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/TitleElement.js +48 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/TransitionDirective.js +41 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/UpdateExpression.js +55 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/UseDirective.js +49 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/VariableDeclaration.js +422 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/component.js +530 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/declarations.js +53 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/element.js +263 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/events.js +176 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/fragment.js +185 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/function.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/special_element.js +22 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/utils.js +513 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/css/index.js +479 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/index.js +118 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/transform-server.js +423 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/AssignmentExpression.js +107 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/AwaitBlock.js +37 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/AwaitExpression.js +40 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/CallExpression.js +71 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/ClassBody.js +81 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/Component.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/ConstTag.js +49 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/DebugTag.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/EachBlock.js +80 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/ExpressionStatement.js +23 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/Fragment.js +53 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/HtmlTag.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/Identifier.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/IfBlock.js +39 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/KeyBlock.js +22 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/LabeledStatement.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/MemberExpression.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/Program.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/PropertyDefinition.js +37 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/RegularElement.js +255 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/RenderTag.js +51 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SlotElement.js +77 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SnippetBlock.js +29 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SpreadAttribute.js +10 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteBoundary.js +71 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteComponent.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteElement.js +102 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteFragment.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteHead.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteSelf.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/TitleElement.js +21 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/UpdateExpression.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/VariableDeclaration.js +212 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/shared/component.js +360 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/shared/element.js +563 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/shared/utils.js +407 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/shared/assignments.js +93 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/shared/transform-async.js +114 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/utils.js +451 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/bindings.js +227 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/css.js +14 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/nodes.js +245 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/patterns.js +27 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/scope.js +1412 -0
- package/dist/utils/node_modules/svelte/src/compiler/preprocess/decode_sourcemap.js +96 -0
- package/dist/utils/node_modules/svelte/src/compiler/preprocess/index.js +368 -0
- package/dist/utils/node_modules/svelte/src/compiler/preprocess/replace_in_code.js +72 -0
- package/dist/utils/node_modules/svelte/src/compiler/print/index.js +890 -0
- package/dist/utils/node_modules/svelte/src/compiler/state.js +144 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/assert.js +9 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/ast.js +639 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/builders.js +698 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/compile_diagnostic.js +107 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/extract_svelte_ignore.js +104 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/mapped_code.js +454 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/push_array.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/sanitize_template_string.js +7 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/slot.js +20 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/string.js +9 -0
- package/dist/utils/node_modules/svelte/src/compiler/validate-options.js +324 -0
- package/dist/utils/node_modules/svelte/src/compiler/warnings.js +845 -0
- package/dist/utils/node_modules/svelte/src/constants.js +64 -0
- package/dist/utils/node_modules/svelte/src/easing/index.js +286 -0
- package/dist/utils/node_modules/svelte/src/escaping.js +26 -0
- package/dist/utils/node_modules/svelte/src/events/index.js +1 -0
- package/dist/utils/node_modules/svelte/src/html-tree-validation.js +238 -0
- package/dist/utils/node_modules/svelte/src/index-client.js +255 -0
- package/dist/utils/node_modules/svelte/src/index-server.js +56 -0
- package/dist/utils/node_modules/svelte/src/internal/client/constants.js +73 -0
- package/dist/utils/node_modules/svelte/src/internal/client/context.js +258 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/assign.js +78 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/console-log.js +35 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/css.js +31 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/debug.js +500 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/elements.js +63 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/equality.js +101 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/hmr.js +89 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/inspect.js +72 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/legacy.js +25 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/ownership.js +81 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/tracing.js +162 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/validation.js +16 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/async.js +64 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/await.js +142 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/boundary.js +507 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/branches.js +227 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/css-props.js +28 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/each.js +666 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/html.js +121 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/if.js +70 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/key.js +33 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/slot.js +44 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/snippet.js +103 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/svelte-component.js +26 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/svelte-element.js +152 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/svelte-head.js +59 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/css.js +32 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/actions.js +43 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/attachments.js +33 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/attributes.js +657 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/document.js +17 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/input.js +312 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/media.js +232 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/navigator.js +11 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/props.js +22 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/select.js +159 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/shared.js +76 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/size.js +108 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/this.js +61 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/universal.js +75 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/window.js +66 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/class.js +51 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/custom-element.js +338 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/customizable-select.js +98 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/events.js +338 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/misc.js +58 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/style.js +57 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/transitions.js +472 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/hydration.js +120 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/legacy/event-modifiers.js +127 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/legacy/lifecycle.js +82 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/legacy/misc.js +68 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/operations.js +260 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/reconciler.js +6 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/task.js +42 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/template.js +388 -0
- package/dist/utils/node_modules/svelte/src/internal/client/error-handling.js +116 -0
- package/dist/utils/node_modules/svelte/src/internal/client/errors.js +491 -0
- package/dist/utils/node_modules/svelte/src/internal/client/hydratable.js +33 -0
- package/dist/utils/node_modules/svelte/src/internal/client/index.js +184 -0
- package/dist/utils/node_modules/svelte/src/internal/client/legacy.js +46 -0
- package/dist/utils/node_modules/svelte/src/internal/client/loop.js +48 -0
- package/dist/utils/node_modules/svelte/src/internal/client/proxy.js +432 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/async.js +302 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/batch.js +988 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/deriveds.js +394 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/effects.js +717 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/equality.js +31 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/props.js +430 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/sources.js +368 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/status.js +25 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/store.js +203 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/utils.js +40 -0
- package/dist/utils/node_modules/svelte/src/internal/client/render.js +319 -0
- package/dist/utils/node_modules/svelte/src/internal/client/runtime.js +831 -0
- package/dist/utils/node_modules/svelte/src/internal/client/timing.js +16 -0
- package/dist/utils/node_modules/svelte/src/internal/client/validate.js +88 -0
- package/dist/utils/node_modules/svelte/src/internal/client/warnings.js +271 -0
- package/dist/utils/node_modules/svelte/src/internal/disclose-version.js +6 -0
- package/dist/utils/node_modules/svelte/src/internal/flags/async.js +3 -0
- package/dist/utils/node_modules/svelte/src/internal/flags/index.js +23 -0
- package/dist/utils/node_modules/svelte/src/internal/flags/legacy.js +3 -0
- package/dist/utils/node_modules/svelte/src/internal/flags/tracing.js +3 -0
- package/dist/utils/node_modules/svelte/src/internal/index.js +5 -0
- package/dist/utils/node_modules/svelte/src/internal/server/abort-signal.js +13 -0
- package/dist/utils/node_modules/svelte/src/internal/server/blocks/html.js +11 -0
- package/dist/utils/node_modules/svelte/src/internal/server/blocks/snippet.js +24 -0
- package/dist/utils/node_modules/svelte/src/internal/server/context.js +122 -0
- package/dist/utils/node_modules/svelte/src/internal/server/crypto.js +41 -0
- package/dist/utils/node_modules/svelte/src/internal/server/dev.js +115 -0
- package/dist/utils/node_modules/svelte/src/internal/server/errors.js +118 -0
- package/dist/utils/node_modules/svelte/src/internal/server/hydratable.js +142 -0
- package/dist/utils/node_modules/svelte/src/internal/server/hydration.js +6 -0
- package/dist/utils/node_modules/svelte/src/internal/server/index.js +490 -0
- package/dist/utils/node_modules/svelte/src/internal/server/render-context.js +86 -0
- package/dist/utils/node_modules/svelte/src/internal/server/renderer.js +770 -0
- package/dist/utils/node_modules/svelte/src/internal/server/warnings.js +29 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/attributes.js +223 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/clone.js +137 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/dev.js +65 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/errors.js +134 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/utils.js +118 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/validate.js +47 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/warnings.js +40 -0
- package/dist/utils/node_modules/svelte/src/legacy/legacy-client.js +280 -0
- package/dist/utils/node_modules/svelte/src/legacy/legacy-server.js +112 -0
- package/dist/utils/node_modules/svelte/src/motion/index.js +32 -0
- package/dist/utils/node_modules/svelte/src/motion/spring.js +369 -0
- package/dist/utils/node_modules/svelte/src/motion/tweened.js +306 -0
- package/dist/utils/node_modules/svelte/src/motion/utils.js +7 -0
- package/dist/utils/node_modules/svelte/src/reactivity/create-subscriber.js +95 -0
- package/dist/utils/node_modules/svelte/src/reactivity/date.js +118 -0
- package/dist/utils/node_modules/svelte/src/reactivity/index-client.js +7 -0
- package/dist/utils/node_modules/svelte/src/reactivity/index-server.js +23 -0
- package/dist/utils/node_modules/svelte/src/reactivity/map.js +273 -0
- package/dist/utils/node_modules/svelte/src/reactivity/media-query.js +55 -0
- package/dist/utils/node_modules/svelte/src/reactivity/reactive-value.js +24 -0
- package/dist/utils/node_modules/svelte/src/reactivity/set.js +213 -0
- package/dist/utils/node_modules/svelte/src/reactivity/url-search-params.js +174 -0
- package/dist/utils/node_modules/svelte/src/reactivity/url.js +205 -0
- package/dist/utils/node_modules/svelte/src/reactivity/window/index.js +161 -0
- package/dist/utils/node_modules/svelte/src/server/index.js +1 -0
- package/dist/utils/node_modules/svelte/src/store/index-client.js +169 -0
- package/dist/utils/node_modules/svelte/src/store/index-server.js +101 -0
- package/dist/utils/node_modules/svelte/src/store/shared/index.js +209 -0
- package/dist/utils/node_modules/svelte/src/store/utils.js +36 -0
- package/dist/utils/node_modules/svelte/src/transition/index.js +300 -0
- package/dist/utils/node_modules/svelte/src/utils.js +491 -0
- package/dist/utils/node_modules/svelte/src/version.js +8 -0
- package/dist/utils/node_modules/typescript/LICENSE.txt +55 -0
- package/dist/utils/node_modules/typescript/README.md +50 -0
- package/dist/utils/node_modules/typescript/SECURITY.md +41 -0
- package/dist/utils/node_modules/typescript/ThirdPartyNoticeText.txt +193 -0
- package/dist/utils/node_modules/typescript/bin/tsc +2 -0
- package/dist/utils/node_modules/typescript/bin/tsserver +2 -0
- package/dist/utils/node_modules/typescript/lib/_tsc.js +133818 -0
- package/dist/utils/node_modules/typescript/lib/_tsserver.js +659 -0
- package/dist/utils/node_modules/typescript/lib/_typingsInstaller.js +222 -0
- package/dist/utils/node_modules/typescript/lib/cs/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/de/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/es/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/fr/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/it/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/ja/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/ko/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/pl/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/pt-br/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/ru/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/tr/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/tsc.js +8 -0
- package/dist/utils/node_modules/typescript/lib/tsserver.js +8 -0
- package/dist/utils/node_modules/typescript/lib/tsserverlibrary.js +21 -0
- package/dist/utils/node_modules/typescript/lib/typesMap.json +497 -0
- package/dist/utils/node_modules/typescript/lib/typescript.js +200276 -0
- package/dist/utils/node_modules/typescript/lib/typingsInstaller.js +8 -0
- package/dist/utils/node_modules/typescript/lib/watchGuard.js +53 -0
- package/dist/utils/node_modules/typescript/lib/zh-cn/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/zh-tw/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/package.json +120 -0
- package/dist/utils/package.json +27 -0
- package/package.json +1 -1
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/** @import { AST } from '#compiler' */
|
|
2
|
+
/** @import { ComponentContext } from '../types' */
|
|
3
|
+
import * as b from '#compiler/builders';
|
|
4
|
+
import { build_template_chunk, Memoizer } from './shared/utils.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* @param {AST.TitleElement} node
|
|
8
|
+
* @param {ComponentContext} context
|
|
9
|
+
*/
|
|
10
|
+
export function TitleElement(node, context) {
|
|
11
|
+
const memoizer = new Memoizer();
|
|
12
|
+
const { has_state, value } = build_template_chunk(
|
|
13
|
+
/** @type {any} */ (node.fragment.nodes),
|
|
14
|
+
context,
|
|
15
|
+
context.state,
|
|
16
|
+
(value, metadata) => memoizer.add(value, metadata)
|
|
17
|
+
);
|
|
18
|
+
const evaluated = context.state.scope.evaluate(value);
|
|
19
|
+
|
|
20
|
+
const statement = b.stmt(
|
|
21
|
+
b.assignment(
|
|
22
|
+
'=',
|
|
23
|
+
b.member(b.id('$.document'), b.id('title', node.name_loc)),
|
|
24
|
+
evaluated.is_known
|
|
25
|
+
? b.literal(evaluated.value)
|
|
26
|
+
: evaluated.is_defined
|
|
27
|
+
? value
|
|
28
|
+
: b.logical('??', value, b.literal(''))
|
|
29
|
+
)
|
|
30
|
+
);
|
|
31
|
+
|
|
32
|
+
// Make sure it only changes the title once async work is done
|
|
33
|
+
if (has_state) {
|
|
34
|
+
context.state.after_update.push(
|
|
35
|
+
b.stmt(
|
|
36
|
+
b.call(
|
|
37
|
+
'$.deferred_template_effect',
|
|
38
|
+
b.arrow(memoizer.apply(), b.block([statement])),
|
|
39
|
+
memoizer.sync_values(),
|
|
40
|
+
memoizer.async_values(),
|
|
41
|
+
memoizer.blockers()
|
|
42
|
+
)
|
|
43
|
+
)
|
|
44
|
+
);
|
|
45
|
+
} else {
|
|
46
|
+
context.state.after_update.push(b.stmt(b.call('$.effect', b.thunk(b.block([statement])))));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/** @import { Expression } from 'estree' */
|
|
2
|
+
/** @import { AST } from '#compiler' */
|
|
3
|
+
/** @import { ComponentContext } from '../types' */
|
|
4
|
+
import { TRANSITION_GLOBAL, TRANSITION_IN, TRANSITION_OUT } from '../../../../../constants.js';
|
|
5
|
+
import * as b from '#compiler/builders';
|
|
6
|
+
import { parse_directive_name } from './shared/utils.js';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* @param {AST.TransitionDirective} node
|
|
10
|
+
* @param {ComponentContext} context
|
|
11
|
+
*/
|
|
12
|
+
export function TransitionDirective(node, context) {
|
|
13
|
+
let flags = node.modifiers.includes('global') ? TRANSITION_GLOBAL : 0;
|
|
14
|
+
if (node.intro) flags |= TRANSITION_IN;
|
|
15
|
+
if (node.outro) flags |= TRANSITION_OUT;
|
|
16
|
+
|
|
17
|
+
const args = [
|
|
18
|
+
b.literal(flags),
|
|
19
|
+
context.state.node,
|
|
20
|
+
b.thunk(/** @type {Expression} */ (context.visit(parse_directive_name(node.name))))
|
|
21
|
+
];
|
|
22
|
+
|
|
23
|
+
if (node.expression) {
|
|
24
|
+
args.push(b.thunk(/** @type {Expression} */ (context.visit(node.expression))));
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// in after_update to ensure it always happens after bind:this
|
|
28
|
+
let statement = b.stmt(b.call('$.transition', ...args));
|
|
29
|
+
|
|
30
|
+
if (node.metadata.expression.is_async()) {
|
|
31
|
+
statement = b.stmt(
|
|
32
|
+
b.call(
|
|
33
|
+
'$.run_after_blockers',
|
|
34
|
+
node.metadata.expression.blockers(),
|
|
35
|
+
b.thunk(b.block([statement]))
|
|
36
|
+
)
|
|
37
|
+
);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
context.state.after_update.push(statement);
|
|
41
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/** @import { AssignmentExpression, Expression, UpdateExpression } from 'estree' */
|
|
2
|
+
/** @import { Context } from '../types' */
|
|
3
|
+
import { object } from '../../../../utils/ast.js';
|
|
4
|
+
import * as b from '#compiler/builders';
|
|
5
|
+
import { validate_mutation } from './shared/utils.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @param {UpdateExpression} node
|
|
9
|
+
* @param {Context} context
|
|
10
|
+
*/
|
|
11
|
+
export function UpdateExpression(node, context) {
|
|
12
|
+
const argument = node.argument;
|
|
13
|
+
|
|
14
|
+
if (
|
|
15
|
+
argument.type === 'MemberExpression' &&
|
|
16
|
+
argument.object.type === 'ThisExpression' &&
|
|
17
|
+
argument.property.type === 'PrivateIdentifier' &&
|
|
18
|
+
context.state.state_fields.has('#' + argument.property.name)
|
|
19
|
+
) {
|
|
20
|
+
let fn = '$.update';
|
|
21
|
+
if (node.prefix) fn += '_pre';
|
|
22
|
+
|
|
23
|
+
/** @type {Expression[]} */
|
|
24
|
+
const args = [argument];
|
|
25
|
+
if (node.operator === '--') {
|
|
26
|
+
args.push(b.literal(-1));
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return b.call(fn, ...args);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
if (argument.type !== 'Identifier' && argument.type !== 'MemberExpression') {
|
|
33
|
+
throw new Error('An impossible state was reached');
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const left = object(argument);
|
|
37
|
+
const transformers = left && context.state.transform[left.name];
|
|
38
|
+
|
|
39
|
+
if (left === argument && transformers?.update) {
|
|
40
|
+
// we don't need to worry about ownership_invalid_mutation here, because
|
|
41
|
+
// we're not mutating but reassigning
|
|
42
|
+
return transformers.update(node);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
let update = /** @type {Expression} */ (context.next());
|
|
46
|
+
|
|
47
|
+
if (left && transformers?.mutate) {
|
|
48
|
+
update = transformers.mutate(
|
|
49
|
+
left,
|
|
50
|
+
/** @type {AssignmentExpression | UpdateExpression} */ (update)
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return validate_mutation(node, context, update);
|
|
55
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/** @import { Expression } from 'estree' */
|
|
2
|
+
/** @import { AST } from '#compiler' */
|
|
3
|
+
/** @import { ComponentContext } from '../types' */
|
|
4
|
+
import * as b from '#compiler/builders';
|
|
5
|
+
import { parse_directive_name } from './shared/utils.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @param {AST.UseDirective} node
|
|
9
|
+
* @param {ComponentContext} context
|
|
10
|
+
*/
|
|
11
|
+
export function UseDirective(node, context) {
|
|
12
|
+
const params = [b.id('$$node')];
|
|
13
|
+
|
|
14
|
+
if (node.expression) {
|
|
15
|
+
params.push(b.id('$$action_arg'));
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/** @type {Expression[]} */
|
|
19
|
+
const args = [
|
|
20
|
+
context.state.node,
|
|
21
|
+
b.arrow(
|
|
22
|
+
params,
|
|
23
|
+
b.maybe_call(
|
|
24
|
+
/** @type {Expression} */ (context.visit(parse_directive_name(node.name))),
|
|
25
|
+
...params
|
|
26
|
+
)
|
|
27
|
+
)
|
|
28
|
+
];
|
|
29
|
+
|
|
30
|
+
if (node.expression) {
|
|
31
|
+
args.push(b.thunk(/** @type {Expression} */ (context.visit(node.expression))));
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// actions need to run after attribute updates in order with bindings/events
|
|
35
|
+
let statement = b.stmt(b.call('$.action', ...args));
|
|
36
|
+
|
|
37
|
+
if (node.metadata.expression.is_async()) {
|
|
38
|
+
statement = b.stmt(
|
|
39
|
+
b.call(
|
|
40
|
+
'$.run_after_blockers',
|
|
41
|
+
node.metadata.expression.blockers(),
|
|
42
|
+
b.thunk(b.block([statement]))
|
|
43
|
+
)
|
|
44
|
+
);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
context.state.init.push(statement);
|
|
48
|
+
context.next();
|
|
49
|
+
}
|
|
@@ -0,0 +1,422 @@
|
|
|
1
|
+
/** @import { CallExpression, Expression, Identifier, Literal, VariableDeclaration, VariableDeclarator } from 'estree' */
|
|
2
|
+
/** @import { Binding } from '#compiler' */
|
|
3
|
+
/** @import { ComponentContext } from '../types' */
|
|
4
|
+
import { dev, is_ignored, locate_node } from '../../../../state.js';
|
|
5
|
+
import { extract_paths, save } from '../../../../utils/ast.js';
|
|
6
|
+
import * as b from '#compiler/builders';
|
|
7
|
+
import * as assert from '../../../../utils/assert.js';
|
|
8
|
+
import { get_rune } from '../../../scope.js';
|
|
9
|
+
import { get_prop_source, is_prop_source, is_state_source, should_proxy } from '../utils.js';
|
|
10
|
+
import { get_value } from './shared/declarations.js';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* @param {VariableDeclaration} node
|
|
14
|
+
* @param {ComponentContext} context
|
|
15
|
+
*/
|
|
16
|
+
export function VariableDeclaration(node, context) {
|
|
17
|
+
/** @type {VariableDeclarator[]} */
|
|
18
|
+
const declarations = [];
|
|
19
|
+
|
|
20
|
+
if (context.state.analysis.runes) {
|
|
21
|
+
for (const declarator of node.declarations) {
|
|
22
|
+
const init = /** @type {Expression} */ (declarator.init);
|
|
23
|
+
const rune = get_rune(init, context.state.scope);
|
|
24
|
+
|
|
25
|
+
if (
|
|
26
|
+
!rune ||
|
|
27
|
+
rune === '$effect.tracking' ||
|
|
28
|
+
rune === '$effect.root' ||
|
|
29
|
+
rune === '$inspect' ||
|
|
30
|
+
rune === '$inspect.trace' ||
|
|
31
|
+
rune === '$state.snapshot' ||
|
|
32
|
+
rune === '$host'
|
|
33
|
+
) {
|
|
34
|
+
declarations.push(/** @type {VariableDeclarator} */ (context.visit(declarator)));
|
|
35
|
+
continue;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
if (rune === '$props.id') {
|
|
39
|
+
// skip
|
|
40
|
+
continue;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
if (rune === '$props') {
|
|
44
|
+
/** @type {string[]} */
|
|
45
|
+
const seen = ['$$slots', '$$events', '$$legacy'];
|
|
46
|
+
|
|
47
|
+
if (context.state.analysis.custom_element) {
|
|
48
|
+
seen.push('$$host');
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
if (declarator.id.type === 'Identifier') {
|
|
52
|
+
/** @type {Expression[]} */
|
|
53
|
+
const args = [b.id('$$props'), b.array(seen.map((name) => b.literal(name)))];
|
|
54
|
+
|
|
55
|
+
if (dev) {
|
|
56
|
+
// include rest name, so we can provide informative error messages
|
|
57
|
+
args.push(b.literal(declarator.id.name));
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
declarations.push(b.declarator(declarator.id, b.call('$.rest_props', ...args)));
|
|
61
|
+
} else {
|
|
62
|
+
assert.equal(declarator.id.type, 'ObjectPattern');
|
|
63
|
+
|
|
64
|
+
for (const property of declarator.id.properties) {
|
|
65
|
+
if (property.type === 'Property') {
|
|
66
|
+
const key = /** @type {Identifier | Literal} */ (property.key);
|
|
67
|
+
const name = key.type === 'Identifier' ? key.name : /** @type {string} */ (key.value);
|
|
68
|
+
|
|
69
|
+
seen.push(name);
|
|
70
|
+
|
|
71
|
+
let id =
|
|
72
|
+
property.value.type === 'AssignmentPattern' ? property.value.left : property.value;
|
|
73
|
+
assert.equal(id.type, 'Identifier');
|
|
74
|
+
const binding = /** @type {Binding} */ (context.state.scope.get(id.name));
|
|
75
|
+
let initial =
|
|
76
|
+
binding.initial && /** @type {Expression} */ (context.visit(binding.initial));
|
|
77
|
+
// We're adding proxy here on demand and not within the prop runtime function so that
|
|
78
|
+
// people not using proxied state anywhere in their code don't have to pay the additional bundle size cost
|
|
79
|
+
if (
|
|
80
|
+
initial &&
|
|
81
|
+
binding.kind === 'bindable_prop' &&
|
|
82
|
+
should_proxy(initial, context.state.scope)
|
|
83
|
+
) {
|
|
84
|
+
initial = b.call('$.proxy', initial);
|
|
85
|
+
|
|
86
|
+
if (dev) {
|
|
87
|
+
initial = b.call('$.tag_proxy', initial, b.literal(id.name));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
if (is_prop_source(binding, context.state)) {
|
|
92
|
+
declarations.push(
|
|
93
|
+
b.declarator(id, get_prop_source(binding, context.state, name, initial))
|
|
94
|
+
);
|
|
95
|
+
}
|
|
96
|
+
} else {
|
|
97
|
+
// RestElement
|
|
98
|
+
/** @type {Expression[]} */
|
|
99
|
+
const args = [b.id('$$props'), b.array(seen.map((name) => b.literal(name)))];
|
|
100
|
+
|
|
101
|
+
if (dev) {
|
|
102
|
+
// include rest name, so we can provide informative error messages
|
|
103
|
+
args.push(b.literal(/** @type {Identifier} */ (property.argument).name));
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
declarations.push(b.declarator(property.argument, b.call('$.rest_props', ...args)));
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
// TODO
|
|
112
|
+
continue;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
const args = /** @type {CallExpression} */ (init).arguments;
|
|
116
|
+
const value = /** @type {Expression} */ (args[0]) ?? b.void0; // TODO do we need the void 0? can we just omit it altogether?
|
|
117
|
+
|
|
118
|
+
if (rune === '$state' || rune === '$state.raw') {
|
|
119
|
+
/**
|
|
120
|
+
* @param {Identifier} id
|
|
121
|
+
* @param {Expression} value
|
|
122
|
+
*/
|
|
123
|
+
const create_state_declarator = (id, value) => {
|
|
124
|
+
const binding = /** @type {import('#compiler').Binding} */ (
|
|
125
|
+
context.state.scope.get(id.name)
|
|
126
|
+
);
|
|
127
|
+
const is_state = is_state_source(binding, context.state.analysis);
|
|
128
|
+
const is_proxy = should_proxy(value, context.state.scope);
|
|
129
|
+
|
|
130
|
+
if (rune === '$state' && is_proxy) {
|
|
131
|
+
value = b.call('$.proxy', value);
|
|
132
|
+
|
|
133
|
+
if (dev && !is_state) {
|
|
134
|
+
value = b.call('$.tag_proxy', value, b.literal(id.name));
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
if (is_state) {
|
|
139
|
+
const callee = b.id('$.state', /** @type {CallExpression} */ (init).callee.loc);
|
|
140
|
+
value = b.call(callee, value);
|
|
141
|
+
|
|
142
|
+
if (dev) {
|
|
143
|
+
value = b.call('$.tag', value, b.literal(id.name));
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
return value;
|
|
148
|
+
};
|
|
149
|
+
|
|
150
|
+
if (declarator.id.type === 'Identifier') {
|
|
151
|
+
const expression = /** @type {Expression} */ (context.visit(value));
|
|
152
|
+
|
|
153
|
+
declarations.push(
|
|
154
|
+
b.declarator(declarator.id, create_state_declarator(declarator.id, expression))
|
|
155
|
+
);
|
|
156
|
+
} else {
|
|
157
|
+
const tmp = b.id(context.state.scope.generate('tmp'));
|
|
158
|
+
const { inserts, paths } = extract_paths(declarator.id, tmp);
|
|
159
|
+
|
|
160
|
+
declarations.push(
|
|
161
|
+
b.declarator(tmp, /** @type {Expression} */ (context.visit(value))),
|
|
162
|
+
...inserts.map(({ id, value }) => {
|
|
163
|
+
id.name = context.state.scope.generate('$$array');
|
|
164
|
+
context.state.transform[id.name] = { read: get_value };
|
|
165
|
+
|
|
166
|
+
const expression = /** @type {Expression} */ (context.visit(b.thunk(value)));
|
|
167
|
+
let call = b.call('$.derived', expression);
|
|
168
|
+
|
|
169
|
+
if (dev) {
|
|
170
|
+
const label = `[$state ${declarator.id.type === 'ArrayPattern' ? 'iterable' : 'object'}]`;
|
|
171
|
+
call = b.call('$.tag', call, b.literal(label));
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
return b.declarator(id, call);
|
|
175
|
+
}),
|
|
176
|
+
...paths.map((path) => {
|
|
177
|
+
const value = /** @type {Expression} */ (context.visit(path.expression));
|
|
178
|
+
const binding = context.state.scope.get(/** @type {Identifier} */ (path.node).name);
|
|
179
|
+
return b.declarator(
|
|
180
|
+
path.node,
|
|
181
|
+
binding?.kind === 'state' || binding?.kind === 'raw_state'
|
|
182
|
+
? create_state_declarator(binding.node, value)
|
|
183
|
+
: value
|
|
184
|
+
);
|
|
185
|
+
})
|
|
186
|
+
);
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
continue;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
if (rune === '$derived' || rune === '$derived.by') {
|
|
193
|
+
const is_async = context.state.analysis.async_deriveds.has(
|
|
194
|
+
/** @type {CallExpression} */ (init)
|
|
195
|
+
);
|
|
196
|
+
|
|
197
|
+
// for now, only wrap async derived in $.save if it's not
|
|
198
|
+
// a top-level instance derived. TODO in future maybe we
|
|
199
|
+
// can dewaterfall all of them?
|
|
200
|
+
const should_save = context.state.is_instance && context.state.scope.function_depth > 1;
|
|
201
|
+
|
|
202
|
+
if (declarator.id.type === 'Identifier') {
|
|
203
|
+
let expression = /** @type {Expression} */ (context.visit(value));
|
|
204
|
+
|
|
205
|
+
if (is_async) {
|
|
206
|
+
const location = dev && !is_ignored(init, 'await_waterfall') && locate_node(init);
|
|
207
|
+
|
|
208
|
+
/** @type {Expression} */
|
|
209
|
+
let call = b.call(
|
|
210
|
+
'$.async_derived',
|
|
211
|
+
b.thunk(expression, true),
|
|
212
|
+
dev && b.literal(declarator.id.name),
|
|
213
|
+
location ? b.literal(location) : undefined
|
|
214
|
+
);
|
|
215
|
+
|
|
216
|
+
call = should_save ? save(call) : b.await(call);
|
|
217
|
+
|
|
218
|
+
declarations.push(b.declarator(declarator.id, call));
|
|
219
|
+
} else {
|
|
220
|
+
if (rune === '$derived') expression = b.thunk(expression);
|
|
221
|
+
|
|
222
|
+
let call = b.call('$.derived', expression);
|
|
223
|
+
if (dev) call = b.call('$.tag', call, b.literal(declarator.id.name));
|
|
224
|
+
|
|
225
|
+
declarations.push(b.declarator(declarator.id, call));
|
|
226
|
+
}
|
|
227
|
+
} else {
|
|
228
|
+
const init = /** @type {CallExpression} */ (declarator.init);
|
|
229
|
+
let expression = /** @type {Expression} */ (context.visit(value));
|
|
230
|
+
|
|
231
|
+
let rhs = value;
|
|
232
|
+
|
|
233
|
+
if (rune !== '$derived' || init.arguments[0].type !== 'Identifier') {
|
|
234
|
+
const id = b.id(context.state.scope.generate('$$d'));
|
|
235
|
+
|
|
236
|
+
/** @type {Expression} */
|
|
237
|
+
let call = b.call('$.derived', rune === '$derived' ? b.thunk(expression) : expression);
|
|
238
|
+
|
|
239
|
+
rhs = b.call('$.get', id);
|
|
240
|
+
|
|
241
|
+
if (is_async) {
|
|
242
|
+
const location = dev && !is_ignored(init, 'await_waterfall') && locate_node(init);
|
|
243
|
+
|
|
244
|
+
call = b.call(
|
|
245
|
+
'$.async_derived',
|
|
246
|
+
b.thunk(expression, true),
|
|
247
|
+
dev &&
|
|
248
|
+
b.literal(
|
|
249
|
+
`[$derived ${declarator.id.type === 'ArrayPattern' ? 'iterable' : 'object'}]`
|
|
250
|
+
),
|
|
251
|
+
location ? b.literal(location) : undefined
|
|
252
|
+
);
|
|
253
|
+
|
|
254
|
+
call = should_save ? save(call) : b.await(call);
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
declarations.push(b.declarator(id, call));
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
const { inserts, paths } = extract_paths(declarator.id, rhs);
|
|
261
|
+
|
|
262
|
+
for (const { id, value } of inserts) {
|
|
263
|
+
id.name = context.state.scope.generate('$$array');
|
|
264
|
+
context.state.transform[id.name] = { read: get_value };
|
|
265
|
+
|
|
266
|
+
const expression = /** @type {Expression} */ (context.visit(b.thunk(value)));
|
|
267
|
+
let call = b.call('$.derived', expression);
|
|
268
|
+
|
|
269
|
+
if (dev) {
|
|
270
|
+
const label = `[$derived ${declarator.id.type === 'ArrayPattern' ? 'iterable' : 'object'}]`;
|
|
271
|
+
call = b.call('$.tag', call, b.literal(label));
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
declarations.push(b.declarator(id, call));
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
for (const path of paths) {
|
|
278
|
+
const expression = /** @type {Expression} */ (context.visit(path.expression));
|
|
279
|
+
const call = b.call('$.derived', b.thunk(expression));
|
|
280
|
+
declarations.push(
|
|
281
|
+
b.declarator(
|
|
282
|
+
path.node,
|
|
283
|
+
dev
|
|
284
|
+
? b.call('$.tag', call, b.literal(/** @type {Identifier} */ (path.node).name))
|
|
285
|
+
: call
|
|
286
|
+
)
|
|
287
|
+
);
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
continue;
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
} else {
|
|
295
|
+
for (const declarator of node.declarations) {
|
|
296
|
+
const bindings = /** @type {Binding[]} */ (context.state.scope.get_bindings(declarator));
|
|
297
|
+
const has_state = bindings.some((binding) => binding.kind === 'state');
|
|
298
|
+
const has_props = bindings.some((binding) => binding.kind === 'bindable_prop');
|
|
299
|
+
|
|
300
|
+
if (!has_state && !has_props) {
|
|
301
|
+
declarations.push(/** @type {VariableDeclarator} */ (context.visit(declarator)));
|
|
302
|
+
continue;
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
if (has_props) {
|
|
306
|
+
if (declarator.id.type !== 'Identifier') {
|
|
307
|
+
// Turn export let into props. It's really really weird because export let { x: foo, z: [bar]} = ..
|
|
308
|
+
// means that foo and bar are the props (i.e. the leaves are the prop names), not x and z.
|
|
309
|
+
const tmp = b.id(context.state.scope.generate('tmp'));
|
|
310
|
+
const { inserts, paths } = extract_paths(declarator.id, tmp);
|
|
311
|
+
|
|
312
|
+
declarations.push(
|
|
313
|
+
b.declarator(
|
|
314
|
+
tmp,
|
|
315
|
+
/** @type {Expression} */ (context.visit(/** @type {Expression} */ (declarator.init)))
|
|
316
|
+
)
|
|
317
|
+
);
|
|
318
|
+
|
|
319
|
+
for (const { id, value } of inserts) {
|
|
320
|
+
id.name = context.state.scope.generate('$$array');
|
|
321
|
+
context.state.transform[id.name] = { read: get_value };
|
|
322
|
+
|
|
323
|
+
const expression = /** @type {Expression} */ (context.visit(b.thunk(value)));
|
|
324
|
+
declarations.push(b.declarator(id, b.call('$.derived', expression)));
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
for (const path of paths) {
|
|
328
|
+
const name = /** @type {Identifier} */ (path.node).name;
|
|
329
|
+
const binding = /** @type {Binding} */ (context.state.scope.get(name));
|
|
330
|
+
const value = /** @type {Expression} */ (context.visit(path.expression));
|
|
331
|
+
|
|
332
|
+
declarations.push(
|
|
333
|
+
b.declarator(
|
|
334
|
+
path.node,
|
|
335
|
+
binding.kind === 'bindable_prop'
|
|
336
|
+
? get_prop_source(binding, context.state, binding.prop_alias ?? name, value)
|
|
337
|
+
: value
|
|
338
|
+
)
|
|
339
|
+
);
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
continue;
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
const binding = /** @type {Binding} */ (context.state.scope.get(declarator.id.name));
|
|
346
|
+
|
|
347
|
+
declarations.push(
|
|
348
|
+
b.declarator(
|
|
349
|
+
declarator.id,
|
|
350
|
+
get_prop_source(
|
|
351
|
+
binding,
|
|
352
|
+
context.state,
|
|
353
|
+
binding.prop_alias ?? declarator.id.name,
|
|
354
|
+
declarator.init && /** @type {Expression} */ (context.visit(declarator.init))
|
|
355
|
+
)
|
|
356
|
+
)
|
|
357
|
+
);
|
|
358
|
+
|
|
359
|
+
continue;
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
declarations.push(
|
|
363
|
+
...create_state_declarators(
|
|
364
|
+
declarator,
|
|
365
|
+
context,
|
|
366
|
+
/** @type {Expression} */ (declarator.init && context.visit(declarator.init))
|
|
367
|
+
)
|
|
368
|
+
);
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
if (declarations.length === 0) {
|
|
373
|
+
return b.empty;
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
return {
|
|
377
|
+
...node,
|
|
378
|
+
declarations
|
|
379
|
+
};
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
/**
|
|
383
|
+
* Creates the output for a state declaration in legacy mode.
|
|
384
|
+
* @param {VariableDeclarator} declarator
|
|
385
|
+
* @param {ComponentContext} context
|
|
386
|
+
* @param {Expression} value
|
|
387
|
+
*/
|
|
388
|
+
function create_state_declarators(declarator, context, value) {
|
|
389
|
+
if (declarator.id.type === 'Identifier') {
|
|
390
|
+
return [
|
|
391
|
+
b.declarator(
|
|
392
|
+
declarator.id,
|
|
393
|
+
b.call('$.mutable_source', value, context.state.analysis.immutable ? b.true : undefined)
|
|
394
|
+
)
|
|
395
|
+
];
|
|
396
|
+
}
|
|
397
|
+
|
|
398
|
+
const tmp = b.id(context.state.scope.generate('tmp'));
|
|
399
|
+
const { inserts, paths } = extract_paths(declarator.id, tmp);
|
|
400
|
+
|
|
401
|
+
return [
|
|
402
|
+
b.declarator(tmp, value),
|
|
403
|
+
...inserts.map(({ id, value }) => {
|
|
404
|
+
id.name = context.state.scope.generate('$$array');
|
|
405
|
+
context.state.transform[id.name] = { read: get_value };
|
|
406
|
+
|
|
407
|
+
const expression = /** @type {Expression} */ (context.visit(b.thunk(value)));
|
|
408
|
+
return b.declarator(id, b.call('$.derived', expression));
|
|
409
|
+
}),
|
|
410
|
+
...paths.map((path) => {
|
|
411
|
+
const value = /** @type {Expression} */ (context.visit(path.expression));
|
|
412
|
+
const binding = context.state.scope.get(/** @type {Identifier} */ (path.node).name);
|
|
413
|
+
|
|
414
|
+
return b.declarator(
|
|
415
|
+
path.node,
|
|
416
|
+
binding?.kind === 'state'
|
|
417
|
+
? b.call('$.mutable_source', value, context.state.analysis.immutable ? b.true : undefined)
|
|
418
|
+
: value
|
|
419
|
+
);
|
|
420
|
+
})
|
|
421
|
+
];
|
|
422
|
+
}
|