diff --git a/.eslintignore b/.eslintignore
index 023e6d045b..e6f44fbdd8 100644
--- a/.eslintignore
+++ b/.eslintignore
@@ -1,11 +1,6 @@
-src/shared
-shared.js
-store.js
-test/test.js
-test/setup.js
**/_actual.js
**/expected.js
-
+test/*/samples/*/output.js
# output files
animate.js
diff --git a/.eslintrc.json b/.eslintrc.json
index 7e8c26382a..26b87eab68 100644
--- a/.eslintrc.json
+++ b/.eslintrc.json
@@ -1,44 +1,79 @@
{
- "root": true,
- "rules": {
- "indent": [2, "tab", { "SwitchCase": 1 }],
- "semi": [2, "always"],
- "keyword-spacing": [2, { "before": true, "after": true }],
- "space-before-blocks": [2, "always"],
- "no-mixed-spaces-and-tabs": [2, "smart-tabs"],
- "no-cond-assign": 0,
- "no-unused-vars": 2,
- "object-shorthand": [2, "always"],
- "no-const-assign": 2,
- "no-class-assign": 2,
- "no-this-before-super": 2,
- "no-var": 2,
- "no-unreachable": 2,
- "valid-typeof": 2,
- "quote-props": [2, "as-needed"],
- "one-var": [2, "never"],
- "prefer-arrow-callback": 2,
- "prefer-const": [2, { "destructuring": "all" }],
- "arrow-spacing": 2,
- "no-inner-declarations": 0
- },
- "env": {
- "es6": true,
- "browser": true,
- "node": true,
- "mocha": true
- },
- "extends": [
- "eslint:recommended",
- "plugin:import/errors",
- "plugin:import/warnings"
- ],
- "parserOptions": {
- "ecmaVersion": 9,
- "sourceType": "module"
- },
- "settings": {
- "import/core-modules": ["svelte"],
- "svelte3/extensions": ["html"]
- }
+ "root": true,
+ "rules": {
+ "indent": "off",
+ "no-unused-vars": "off",
+ "semi": [2, "always"],
+ "keyword-spacing": [2, { "before": true, "after": true }],
+ "space-before-blocks": [2, "always"],
+ "no-mixed-spaces-and-tabs": [2, "smart-tabs"],
+ "no-cond-assign": 0,
+ "object-shorthand": [2, "always"],
+ "no-const-assign": 2,
+ "no-class-assign": 2,
+ "no-this-before-super": 2,
+ "no-var": 2,
+ "no-unreachable": 2,
+ "valid-typeof": 2,
+ "quote-props": [2, "as-needed"],
+ "one-var": [2, "never"],
+ "prefer-arrow-callback": 2,
+ "prefer-const": [2, { "destructuring": "all" }],
+ "arrow-spacing": 2,
+ "no-inner-declarations": 0,
+ "@typescript-eslint/indent": ["error", "tab", {
+ "SwitchCase": 1,
+ "ignoredNodes": ["TemplateLiteral"]
+ }],
+ "@typescript-eslint/camelcase": "off",
+ "@typescript-eslint/no-use-before-define": "off",
+ "@typescript-eslint/array-type": ["error", "array-simple"],
+ "@typescript-eslint/explicit-function-return-type": "off",
+ "@typescript-eslint/no-explicit-any": "off",
+ "@typescript-eslint/explicit-member-accessibility": "off",
+ "@typescript-eslint/no-unused-vars": ["error", {
+ "argsIgnorePattern": "^_"
+ }],
+ "@typescript-eslint/no-object-literal-type-assertion": ["error", {
+ "allowAsParameter": true
+ }],
+ "@typescript-eslint/no-unused-vars": "off"
+ },
+ "globals": {
+ "globalThis": false
+ },
+ "env": {
+ "es6": true,
+ "browser": true,
+ "node": true,
+ "mocha": true
+ },
+ "extends": [
+ "eslint:recommended",
+ "plugin:import/errors",
+ "plugin:import/warnings",
+ "plugin:import/typescript",
+ "plugin:@typescript-eslint/recommended"
+ ],
+ "parserOptions": {
+ "ecmaVersion": 9,
+ "sourceType": "module"
+ },
+ "settings": {
+ "import/core-modules": [
+ "svelte",
+ "svelte/internal",
+ "svelte/store",
+ "svelte/easing",
+ "estree"
+ ]
+ },
+ "overrides": [
+ {
+ "files": ["*.js"],
+ "rules": {
+ "@typescript-eslint/no-var-requires": "off"
+ }
+ }
+ ]
}
diff --git a/.flowconfig b/.flowconfig
deleted file mode 100644
index 2ed2b0c713..0000000000
--- a/.flowconfig
+++ /dev/null
@@ -1,9 +0,0 @@
-[ignore]
-/dist/.*
-
-[include]
-
-[libs]
-
-[options]
-strip_root=true
diff --git a/.gitattributes b/.gitattributes
deleted file mode 100644
index eb49e78156..0000000000
--- a/.gitattributes
+++ /dev/null
@@ -1 +0,0 @@
-*.svelte linguist-language=HTML
diff --git a/.gitignore b/.gitignore
index 06671edc2b..590bd1d88e 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,16 +1,18 @@
+.idea
.DS_Store
.nyc_output
node_modules
*.map
-/src/compile/internal-exports.ts
-/compiler.js
-/index.js
-/internal.*
-/store.js
-/easing.js
-/motion.*
-/transition.js
-/animate.js
+/src/compiler/compile/internal_exports.ts
+/compiler.d.ts
+/compiler.*js
+/index.*js
+/internal
+/store
+/easing
+/motion
+/transition
+/animate
/scratch/
/coverage/
/coverage.lcov/
@@ -20,6 +22,7 @@ node_modules
/test/sourcemaps/samples/*/output.css.map
/yarn-error.log
_actual*.*
+/types
/site/cypress/screenshots/
/site/__sapper__/
@@ -27,5 +30,6 @@ _actual*.*
/site/.sessions
/site/static/svelte-app.json
/site/static/contributors.jpg
+/site/static/workers
/site/scripts/svelte-app
/site/src/routes/_contributors.js
diff --git a/.travis.yml b/.travis.yml
index aeadd48f8d..a4603a26e2 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -1,7 +1,8 @@
language: node_js
node_js:
- - "node"
-
+ - "8"
+ - "10"
+ - "12"
env:
global:
- BUILD_TIMEOUT=20000
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 1d6a7b34dd..fff5821319 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,5 +1,103 @@
# Svelte changelog
+## 3.6.1
+
+* Fix escaping of `@` in dev mode debug filename ([#3114](https://github.com/sveltejs/svelte/pull/3114))
+
+## 3.6.0
+
+* Add `innerHTML` and `textContent` bindings for `contenteditable` elements ([#2996](https://github.com/sveltejs/svelte/pull/2996))
+* Fix destructuring assignments where targets are member expressions ([#3092](https://github.com/sveltejs/svelte/issues/3092))
+* Deconflict with used globals ([#2963](https://github.com/sveltejs/svelte/pull/2963))
+* Always run `onDestroy` functions, not just for detaching components ([#3058](https://github.com/sveltejs/svelte/issues/3058))
+* Fix scope analysis around catch clauses ([#3064](https://github.com/sveltejs/svelte/issues/3064))
+* Add error constructors to known globals ([#3064](https://github.com/sveltejs/svelte/issues/3064))
+* Always bail out of hoisting on encountering local state in function definition ([#3044](https://github.com/sveltejs/svelte/issues/3044))
+* Fix incorrect merging of top-level text nodes ([#3027](https://github.com/sveltejs/svelte/issues/3027))
+* Handle removal of components in each blocks without props ([#3035](https://github.com/sveltejs/svelte/issues/3035))
+* Only call subscriber once when resubscribing to a store ([#3022](https://github.com/sveltejs/svelte/issues/3022))
+* Check for existence of dynamic component before introing ([#3054](https://github.com/sveltejs/svelte/issues/3054))
+* Sanitize names of bubbled event handlers ([#2923](https://github.com/sveltejs/svelte/issues/2923))
+
+
+## 3.5.4
+
+* Preserve whitespace at the boundaries of `{#each}` blocks ([#713](https://github.com/sveltejs/svelte/issues/713))
+* Fix dynamic `bind:this` on components ([#2333](https://github.com/sveltejs/svelte/issues/2333))
+* Fix binding to values in a component when it uses `$$props` ([#2725](https://github.com/sveltejs/svelte/issues/2725))
+* Fix parsing ambiguous HTML entities ([#3071](https://github.com/sveltejs/svelte/pull/3071))
+
+## 3.5.3
+
+* Don't double-destroy keyed each blocks with outros ([#3055](https://github.com/sveltejs/svelte/issues/3055))
+
+## 3.5.2
+
+* Prevent duplicated outros causing errors ([#3001](https://github.com/sveltejs/svelte/issues/3001))
+* Fix automatic name generation ([#2843](https://github.com/sveltejs/svelte/issues/2843))
+* Fix .d.ts stubs ([#3009](https://github.com/sveltejs/svelte/pull/3009))
+* Don't strip non-breaking spaces ([#3014](https://github.com/sveltejs/svelte/issues/3014))
+* Fix `requestAnimationFrame` context ([#2933](https://github.com/sveltejs/svelte/issues/2933))
+* Allow space before attribute value ([#3026](https://github.com/sveltejs/svelte/issues/3026))
+* Remove null/undefined attributes ([#1434](https://github.com/sveltejs/svelte/issues/1434))
+* Fix whitespace in static markup ([#3030](https://github.com/sveltejs/svelte/pull/3030))
+
+## 3.5.1
+
+* Accommodate webpack idiosyncracies
+
+## 3.5.0
+
+* Update package folder structure ([#2887](https://github.com/sveltejs/svelte/pull/2887))
+* Support `once` modifier on component events ([#2654](https://github.com/sveltejs/svelte/issues/2654))
+* Allow empty `` tags ([#2980](https://github.com/sveltejs/svelte/issues/2980))
+* Render textarea binding values inside element ([#2975](https://github.com/sveltejs/svelte/pull/2975))
+* Fix delayed animation glitch ([#2871](https://github.com/sveltejs/svelte/issues/2871))
+* Solve diamond dependencies problem with stores ([#2660](https://github.com/sveltejs/svelte/issues/2660))
+* Fix missing outros inside each blocks ([#2689](https://github.com/sveltejs/svelte/issues/2689))
+* Support animations without transitions ([#2908](https://github.com/sveltejs/svelte/issues/2908))
+* Add missing transition events ([#2912](https://github.com/sveltejs/svelte/pull/2912))
+
+
+## 3.4.4
+
+* Publish type declaration files ([#2874](https://github.com/sveltejs/svelte/issues/2874))
+* Don't trigger updates for unreferenced values ([#2865](https://github.com/sveltejs/svelte/pull/2865))
+* Omit readonly bindings from SSR output ([#2339](https://github.com/sveltejs/svelte/issues/2339))
+* Prevent outdated animation CSS ([#2871](https://github.com/sveltejs/svelte/issues/2871))
+* Repair dynamic `{@html ...}` in head ([#2880](https://github.com/sveltejs/svelte/pull/2880))
+* Don't create unknown prop warnings for internal props, or if component has `$$props` ([#2881](https://github.com/sveltejs/svelte/pull/2881))
+
+
+## 3.4.3
+
+* Add type declaration files for everything ([#2842](https://github.com/sveltejs/svelte/pull/2842))
+* Prevent `svelte/store` being bundled ([#2786](https://github.com/sveltejs/svelte/issues/2786))
+* Warn on unknown props in dev mode ([#2840](https://github.com/sveltejs/svelte/pull/2840))
+* Treat `requestAnimationFrame` as a no-op on the server ([#2856](https://github.com/sveltejs/svelte/pull/2856))
+* Add `raw` property to AST's `Text` nodes ([#2714](https://github.com/sveltejs/svelte/issues/2714))
+* Add `` ([#2854](https://github.com/sveltejs/svelte/issues/2854))
+
+## 3.4.2
+
+* Use empty string for empty data attributes ([#2804](https://github.com/sveltejs/svelte/pull/2804))
+* Support `customElement: true` with no `` ([#2821](https://github.com/sveltejs/svelte/issues/2821))
+* Add docstrings to `svelte/store` ([#2795](https://github.com/sveltejs/svelte/pull/2795))
+
+## 3.4.1
+
+* Handle non-falsy non-function return values from derivers ([#2780](https://github.com/sveltejs/svelte/issues/2780))
+* Allow `spring` to work server-side ([#2773](https://github.com/sveltejs/svelte/issues/2773))
+
+## 3.4.0
+
+* Allow custom element to be defined without a `tag` ([#2417](https://github.com/sveltejs/svelte/issues/2417))
+* Fix parsing of quote marks inside attribute values ([#2715](https://github.com/sveltejs/svelte/pull/2754))
+* Convert `svelte/store` to TypeScript ([#2733](https://github.com/sveltejs/svelte/pull/2733))
+* Allow `debug` tags to include hoisted values ([#2764](https://github.com/sveltejs/svelte/issues/2764))
+* Parse error if attribute name is missing `=` ([#1513](https://github.com/sveltejs/svelte/pull/2770))
+* Allow reactive declarations to depend on mutated `const` values ([#2728](https://github.com/sveltejs/svelte/issues/2728))
+
## 3.3.0
* Allow multiple event listeners on a single node ([#2688](https://github.com/sveltejs/svelte/issues/2688))
diff --git a/README.md b/README.md
index ac0e4ff366..dc747668b0 100644
--- a/README.md
+++ b/README.md
@@ -2,7 +2,7 @@
-
+
@@ -16,7 +16,7 @@
alt="build status">
-
+
@@ -36,11 +36,16 @@ Pull requests are encouraged and always welcome. [Pick an issue](https://github.
To install and work on Svelte locally:
```bash
-git clone git@github.com:sveltejs/svelte.git
+git clone https://github.com/sveltejs/svelte.git
cd svelte
npm install
```
+> Many tests depend on newlines being preserved as ``. On Windows, you can ensure this by cloning with:
+> ```bash
+> git -c core.autocrlf=false clone https://github.com/sveltejs/svelte.git
+> ```
+
To build the compiler, and all the other modules included in the package:
```bash
diff --git a/animate.mjs b/animate.mjs
deleted file mode 100644
index f22fabe401..0000000000
--- a/animate.mjs
+++ /dev/null
@@ -1,25 +0,0 @@
-import { cubicOut } from './easing';
-import { is_function } from './internal';
-
-export function flip(node, animation, params) {
- const style = getComputedStyle(node);
- const transform = style.transform === 'none' ? '' : style.transform;
-
- const dx = animation.from.left - animation.to.left;
- const dy = animation.from.top - animation.to.top;
-
- const d = Math.sqrt(dx * dx + dy * dy);
-
- const {
- delay = 0,
- duration = d => Math.sqrt(d) * 120,
- easing = cubicOut
- } = params;
-
- return {
- delay,
- duration: is_function(duration) ? duration(d) : duration,
- easing,
- css: (t, u) => `transform: ${transform} translate(${u * dx}px, ${u * dy}px);`
- };
-}
\ No newline at end of file
diff --git a/appveyor.yml b/appveyor.yml
index 249f61abf4..23a3ac3505 100644
--- a/appveyor.yml
+++ b/appveyor.yml
@@ -9,12 +9,13 @@ init:
environment:
matrix:
- # node.js
+ - nodejs_version: 8
- nodejs_version: 10
+ - nodejs_version: 12
install:
- - ps: Install-Product node $env:nodejs_version
- - npm install
+ - ps: Update-NodeJsInstallation (Get-NodeJsLatestBuild $env:nodejs_version)
+ - npm ci || npm install
build: off
diff --git a/package-lock.json b/package-lock.json
index 7c7363db2e..9afa2356d2 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1,6 +1,6 @@
{
"name": "svelte",
- "version": "3.1.0",
+ "version": "3.6.1",
"lockfileVersion": 1,
"requires": true,
"dependencies": {
@@ -30,16 +30,6 @@
"integrity": "sha512-UdVB1rSL7H8TS8674fH02p5lRbhfIqQ18YKLxLKEnHFztHUH6bhMqjebMxgSTmWVrs5raS5JSLJIKKHFT4WfPg==",
"dev": true
},
- "@sveltejs/svelte-repl": {
- "version": "0.0.5",
- "resolved": "https://registry.npmjs.org/@sveltejs/svelte-repl/-/svelte-repl-0.0.5.tgz",
- "integrity": "sha512-SKSX4xkqwH0XcUHQozwTNm3OCqatk66CXYZnqOW9Jf4E1B6opyQUb9f96KwAxh7ghZMbeePRv51oOWsw6n0Yww==",
- "dev": true,
- "requires": {
- "codemirror": "^5.45.0",
- "yootils": "0.0.15"
- }
- },
"@types/estree": {
"version": "0.0.39",
"resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz",
@@ -59,11 +49,65 @@
"dev": true
},
"@types/node": {
- "version": "10.12.18",
- "resolved": "https://registry.npmjs.org/@types/node/-/node-10.12.18.tgz",
- "integrity": "sha512-fh+pAqt4xRzPfqA6eh3Z2y6fyZavRIumvjhaCL753+TVkGKGhpPeyrJG2JftD0T9q4GF00KjefsQ+PQNDdWQaQ==",
+ "version": "8.10.49",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-8.10.49.tgz",
+ "integrity": "sha512-YX30JVx0PvSmJ3Eqr74fYLGeBxD+C7vIL20ek+GGGLJeUbVYRUW3EzyAXpIRA0K8c8o0UWqR/GwEFYiFoz1T8w==",
"dev": true
},
+ "@typescript-eslint/eslint-plugin": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-1.9.0.tgz",
+ "integrity": "sha512-FOgfBorxjlBGpDIw+0LaZIXRX6GEEUfzj8LXwaQIUCp+gDOvkI+1WgugJ7SmWiISqK9Vj5r8S7NDKO/LB+6X9A==",
+ "dev": true,
+ "requires": {
+ "@typescript-eslint/experimental-utils": "1.9.0",
+ "@typescript-eslint/parser": "1.9.0",
+ "eslint-utils": "^1.3.1",
+ "functional-red-black-tree": "^1.0.1",
+ "regexpp": "^2.0.1",
+ "requireindex": "^1.2.0",
+ "tsutils": "^3.7.0"
+ }
+ },
+ "@typescript-eslint/experimental-utils": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-1.9.0.tgz",
+ "integrity": "sha512-1s2dY9XxBwtS9IlSnRIlzqILPyeMly5tz1bfAmQ84Ul687xBBve5YsH5A5EKeIcGurYYqY2w6RkHETXIwnwV0A==",
+ "dev": true,
+ "requires": {
+ "@typescript-eslint/typescript-estree": "1.9.0"
+ }
+ },
+ "@typescript-eslint/parser": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-1.9.0.tgz",
+ "integrity": "sha512-CWgC1XrQ34H/+LwAU7vY5xteZDkNqeAkeidEpJnJgkKu0yqQ3ZhQ7S+dI6MX4vmmM1TKRbOrKuXc6W0fIHhdbA==",
+ "dev": true,
+ "requires": {
+ "@typescript-eslint/experimental-utils": "1.9.0",
+ "@typescript-eslint/typescript-estree": "1.9.0",
+ "eslint-scope": "^4.0.0",
+ "eslint-visitor-keys": "^1.0.0"
+ }
+ },
+ "@typescript-eslint/typescript-estree": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-1.9.0.tgz",
+ "integrity": "sha512-7Eg0TEQpCkTsEwsl1lIzd6i7L3pJLQFWesV08dS87bNz0NeSjbL78gNAP1xCKaCejkds4PhpLnZkaAjx9SU8OA==",
+ "dev": true,
+ "requires": {
+ "lodash.unescape": "4.0.1",
+ "semver": "5.5.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz",
+ "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==",
+ "dev": true
+ }
+ }
+ },
"abab": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/abab/-/abab-2.0.0.tgz",
@@ -148,9 +192,9 @@
}
},
"ansi-escapes": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz",
- "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==",
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz",
+ "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==",
"dev": true
},
"ansi-regex": {
@@ -213,6 +257,16 @@
"integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=",
"dev": true
},
+ "array-includes": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz",
+ "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=",
+ "dev": true,
+ "requires": {
+ "define-properties": "^1.1.2",
+ "es-abstract": "^1.7.0"
+ }
+ },
"arrify": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz",
@@ -246,15 +300,6 @@
"integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==",
"dev": true
},
- "async": {
- "version": "2.6.2",
- "resolved": "https://registry.npmjs.org/async/-/async-2.6.2.tgz",
- "integrity": "sha512-H1qVYh1MYhEEFLsP97cVKqCGo7KfCyTt6uEWqsTBr9SO84oK9Uwbyd/yCW+6rKJLHksBNUVWZDAjfS+Ccx0Bbg==",
- "dev": true,
- "requires": {
- "lodash": "^4.17.11"
- }
- },
"async-limiter": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz",
@@ -493,9 +538,9 @@
}
},
"callsites": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.0.0.tgz",
- "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==",
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
"dev": true
},
"caseless": {
@@ -521,12 +566,6 @@
"integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==",
"dev": true
},
- "circular-json": {
- "version": "0.3.3",
- "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz",
- "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==",
- "dev": true
- },
"class-utils": {
"version": "0.3.6",
"resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz",
@@ -601,12 +640,6 @@
"urlgrey": "^0.4.4"
}
},
- "codemirror": {
- "version": "5.45.0",
- "resolved": "https://registry.npmjs.org/codemirror/-/codemirror-5.45.0.tgz",
- "integrity": "sha512-c19j644usCE8gQaXa0jqn2B/HN9MnB2u6qPIrrhrMkB+QAP42y8G4QnTwuwbVSoUS1jEl7JU9HZMGhCDL0nsAw==",
- "dev": true
- },
"collection-visit": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz",
@@ -808,6 +841,15 @@
"integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=",
"dev": true
},
+ "define-properties": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz",
+ "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==",
+ "dev": true,
+ "requires": {
+ "object-keys": "^1.0.12"
+ }
+ },
"define-property": {
"version": "2.0.2",
"resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz",
@@ -874,38 +916,14 @@
"dev": true
},
"doctrine": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz",
- "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==",
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
+ "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==",
"dev": true,
"requires": {
"esutils": "^2.0.2"
}
},
- "dom-serializer": {
- "version": "0.1.0",
- "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.1.0.tgz",
- "integrity": "sha1-BzxpdUbOB4DOI75KKOKT5AvDDII=",
- "dev": true,
- "requires": {
- "domelementtype": "~1.1.1",
- "entities": "~1.1.1"
- },
- "dependencies": {
- "domelementtype": {
- "version": "1.1.3",
- "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.1.3.tgz",
- "integrity": "sha1-vSh3PiZCiBrsUVRJJCmcXNgiGFs=",
- "dev": true
- }
- }
- },
- "domelementtype": {
- "version": "1.3.1",
- "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz",
- "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==",
- "dev": true
- },
"domexception": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/domexception/-/domexception-1.0.1.tgz",
@@ -915,25 +933,6 @@
"webidl-conversions": "^4.0.2"
}
},
- "domhandler": {
- "version": "2.4.2",
- "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.4.2.tgz",
- "integrity": "sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA==",
- "dev": true,
- "requires": {
- "domelementtype": "1"
- }
- },
- "domutils": {
- "version": "1.7.0",
- "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz",
- "integrity": "sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==",
- "dev": true,
- "requires": {
- "dom-serializer": "0",
- "domelementtype": "1"
- }
- },
"ecc-jsbn": {
"version": "0.1.2",
"resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz",
@@ -944,6 +943,12 @@
"safer-buffer": "^2.1.0"
}
},
+ "emoji-regex": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz",
+ "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==",
+ "dev": true
+ },
"end-of-stream": {
"version": "1.4.1",
"resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz",
@@ -953,12 +958,6 @@
"once": "^1.4.0"
}
},
- "entities": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz",
- "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==",
- "dev": true
- },
"error-ex": {
"version": "1.3.2",
"resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
@@ -968,6 +967,31 @@
"is-arrayish": "^0.2.1"
}
},
+ "es-abstract": {
+ "version": "1.13.0",
+ "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz",
+ "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==",
+ "dev": true,
+ "requires": {
+ "es-to-primitive": "^1.2.0",
+ "function-bind": "^1.1.1",
+ "has": "^1.0.3",
+ "is-callable": "^1.1.4",
+ "is-regex": "^1.0.4",
+ "object-keys": "^1.0.12"
+ }
+ },
+ "es-to-primitive": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz",
+ "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==",
+ "dev": true,
+ "requires": {
+ "is-callable": "^1.1.4",
+ "is-date-object": "^1.0.1",
+ "is-symbol": "^1.0.2"
+ }
+ },
"es6-promise": {
"version": "4.2.6",
"resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.6.tgz",
@@ -1011,48 +1035,61 @@
}
},
"eslint": {
- "version": "5.12.1",
- "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.12.1.tgz",
- "integrity": "sha512-54NV+JkTpTu0d8+UYSA8mMKAG4XAsaOrozA9rCW7tgneg1mevcL7wIotPC+fZ0SkWwdhNqoXoxnQCTBp7UvTsg==",
+ "version": "5.16.0",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.16.0.tgz",
+ "integrity": "sha512-S3Rz11i7c8AA5JPv7xAH+dOyq/Cu/VXHiHXBPOU1k/JAM5dXqQPt3qcrhpHSorXmrpu2g0gkIBVXAqCpzfoZIg==",
"dev": true,
"requires": {
"@babel/code-frame": "^7.0.0",
- "ajv": "^6.5.3",
+ "ajv": "^6.9.1",
"chalk": "^2.1.0",
"cross-spawn": "^6.0.5",
"debug": "^4.0.1",
- "doctrine": "^2.1.0",
- "eslint-scope": "^4.0.0",
+ "doctrine": "^3.0.0",
+ "eslint-scope": "^4.0.3",
"eslint-utils": "^1.3.1",
"eslint-visitor-keys": "^1.0.0",
- "espree": "^5.0.0",
+ "espree": "^5.0.1",
"esquery": "^1.0.1",
"esutils": "^2.0.2",
- "file-entry-cache": "^2.0.0",
+ "file-entry-cache": "^5.0.1",
"functional-red-black-tree": "^1.0.1",
"glob": "^7.1.2",
"globals": "^11.7.0",
"ignore": "^4.0.6",
"import-fresh": "^3.0.0",
"imurmurhash": "^0.1.4",
- "inquirer": "^6.1.0",
- "js-yaml": "^3.12.0",
+ "inquirer": "^6.2.2",
+ "js-yaml": "^3.13.0",
"json-stable-stringify-without-jsonify": "^1.0.1",
"levn": "^0.3.0",
- "lodash": "^4.17.5",
+ "lodash": "^4.17.11",
"minimatch": "^3.0.4",
"mkdirp": "^0.5.1",
"natural-compare": "^1.4.0",
"optionator": "^0.8.2",
"path-is-inside": "^1.0.2",
- "pluralize": "^7.0.0",
"progress": "^2.0.0",
"regexpp": "^2.0.1",
"semver": "^5.5.1",
"strip-ansi": "^4.0.0",
"strip-json-comments": "^2.0.1",
- "table": "^5.0.2",
+ "table": "^5.2.3",
"text-table": "^0.2.0"
+ },
+ "dependencies": {
+ "ajv": {
+ "version": "6.10.0",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz",
+ "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==",
+ "dev": true,
+ "requires": {
+ "fast-deep-equal": "^2.0.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ }
+ }
}
},
"eslint-import-resolver-node": {
@@ -1083,9 +1120,9 @@
}
},
"eslint-module-utils": {
- "version": "2.3.0",
- "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.3.0.tgz",
- "integrity": "sha512-lmDJgeOOjk8hObTysjqH7wyMi+nsHwwvfBykwfhjR1LNdd7C2uFJBvx4OpWYpXOw4df1yE1cDEVd1yLHitk34w==",
+ "version": "2.4.0",
+ "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.4.0.tgz",
+ "integrity": "sha512-14tltLm38Eu3zS+mt0KvILC3q8jyIAH518MlG+HO0p+yK885Lb1UHTY/UgR91eOyGdmxAPb+OLoW4znqIT6Ndw==",
"dev": true,
"requires": {
"debug": "^2.6.8",
@@ -1109,31 +1146,23 @@
}
}
},
- "eslint-plugin-html": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/eslint-plugin-html/-/eslint-plugin-html-5.0.0.tgz",
- "integrity": "sha512-f7p/7YQdgQUFVAX3nB4dnMQbrDeTalcA01PDhuvTLk0ZadCwM4Pb+639SRuqEf1zMkIxckLY+ckCr0hVP5zl6A==",
- "dev": true,
- "requires": {
- "htmlparser2": "^3.10.0"
- }
- },
"eslint-plugin-import": {
- "version": "2.15.0",
- "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.15.0.tgz",
- "integrity": "sha512-LEHqgR+RcnpGqYW7h9WMkPb/tP+ekKxWdQDztfTtZeV43IHF+X8lXU+1HOCcR4oXD24qRgEwNSxIweD5uNKGVg==",
+ "version": "2.17.3",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.17.3.tgz",
+ "integrity": "sha512-qeVf/UwXFJbeyLbxuY8RgqDyEKCkqV7YC+E5S5uOjAp4tOc8zj01JP3ucoBM8JcEqd1qRasJSg6LLlisirfy0Q==",
"dev": true,
"requires": {
+ "array-includes": "^3.0.3",
"contains-path": "^0.1.0",
"debug": "^2.6.9",
"doctrine": "1.5.0",
"eslint-import-resolver-node": "^0.3.2",
- "eslint-module-utils": "^2.3.0",
+ "eslint-module-utils": "^2.4.0",
"has": "^1.0.3",
"lodash": "^4.17.11",
"minimatch": "^3.0.4",
"read-pkg-up": "^2.0.0",
- "resolve": "^1.9.0"
+ "resolve": "^1.11.0"
},
"dependencies": {
"debug": {
@@ -1160,13 +1189,22 @@
"resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
"integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=",
"dev": true
+ },
+ "resolve": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.11.1.tgz",
+ "integrity": "sha512-vIpgF6wfuJOZI7KKKSP+HmiKggadPQAdsp5HiC1mvqnfp0gF1vdwgBWZIdrVft9pgqoMFQN+R7BSWZiBxx+BBw==",
+ "dev": true,
+ "requires": {
+ "path-parse": "^1.0.6"
+ }
}
}
},
"eslint-scope": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz",
- "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==",
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz",
+ "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==",
"dev": true,
"requires": {
"esrecurse": "^4.1.0",
@@ -1186,12 +1224,12 @@
"dev": true
},
"espree": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.0.tgz",
- "integrity": "sha512-1MpUfwsdS9MMoN7ZXqAr9e9UKdVHDcvrJpyx7mm1WuQlx/ygErEQBzgi5Nh5qBHIoYweprhtMkTCb9GhcAIcsA==",
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz",
+ "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==",
"dev": true,
"requires": {
- "acorn": "^6.0.2",
+ "acorn": "^6.0.7",
"acorn-jsx": "^5.0.0",
"eslint-visitor-keys": "^1.0.0"
}
@@ -1227,9 +1265,9 @@
"dev": true
},
"estree-walker": {
- "version": "0.6.0",
- "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.0.tgz",
- "integrity": "sha512-peq1RfVAVzr3PU/jL31RaOjUKLoZJpObQWJJ+LgfcxDUifyLZ1RjPQZTl0pzj2uJ45b7A7XpyppXvxdEqzo4rw==",
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz",
+ "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==",
"dev": true
},
"esutils": {
@@ -1363,13 +1401,12 @@
}
},
"file-entry-cache": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz",
- "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=",
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz",
+ "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==",
"dev": true,
"requires": {
- "flat-cache": "^1.2.1",
- "object-assign": "^4.0.1"
+ "flat-cache": "^2.0.1"
}
},
"find-up": {
@@ -1382,17 +1419,22 @@
}
},
"flat-cache": {
- "version": "1.3.4",
- "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.4.tgz",
- "integrity": "sha512-VwyB3Lkgacfik2vhqR4uv2rvebqmDvFu4jlN/C1RzWoJEo8I7z4Q404oiqYCkq41mni8EzQnm95emU9seckwtg==",
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz",
+ "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==",
"dev": true,
"requires": {
- "circular-json": "^0.3.1",
- "graceful-fs": "^4.1.2",
- "rimraf": "~2.6.2",
- "write": "^0.2.1"
+ "flatted": "^2.0.0",
+ "rimraf": "2.6.3",
+ "write": "1.0.3"
}
},
+ "flatted": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz",
+ "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==",
+ "dev": true
+ },
"for-in": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz",
@@ -1520,9 +1562,9 @@
}
},
"globals": {
- "version": "11.10.0",
- "resolved": "https://registry.npmjs.org/globals/-/globals-11.10.0.tgz",
- "integrity": "sha512-0GZF1RiPKU97IHUO5TORo9w1PwrH/NBPl+fS7oMLdaTRiYmYbwK4NWoZWrAdd0/abG9R2BU+OiwyQpTpE6pdfQ==",
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
"dev": true
},
"globalyzer": {
@@ -1550,12 +1592,12 @@
"dev": true
},
"handlebars": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.1.0.tgz",
- "integrity": "sha512-l2jRuU1NAWK6AW5qqcTATWQJvNPEwkM7NEKSiv/gqOsoSQbVoWyqVEY5GS+XPQ88zLNmqASRpzfdm8d79hJS+w==",
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.1.2.tgz",
+ "integrity": "sha512-nvfrjqvt9xQ8Z/w0ijewdD/vvWDTOweBUm96NTr66Wfvo1mJenBLwcYmPs3TIBP5ruzYGD7Hx/DaM9RmhroGPw==",
"dev": true,
"requires": {
- "async": "^2.5.0",
+ "neo-async": "^2.6.0",
"optimist": "^0.6.1",
"source-map": "^0.6.1",
"uglify-js": "^3.1.4"
@@ -1592,6 +1634,12 @@
"integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
"dev": true
},
+ "has-symbols": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz",
+ "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=",
+ "dev": true
+ },
"has-value": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz",
@@ -1673,20 +1721,6 @@
"whatwg-encoding": "^1.0.1"
}
},
- "htmlparser2": {
- "version": "3.10.0",
- "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.10.0.tgz",
- "integrity": "sha512-J1nEUGv+MkXS0weHNWVKJJ+UrLfePxRWpN3C9bEi9fLxL2+ggW94DQvgYVXsaT30PGwYRIZKNZXuyMhp3Di4bQ==",
- "dev": true,
- "requires": {
- "domelementtype": "^1.3.0",
- "domhandler": "^2.3.0",
- "domutils": "^1.5.1",
- "entities": "^1.1.1",
- "inherits": "^2.0.1",
- "readable-stream": "^3.0.6"
- }
- },
"http-signature": {
"version": "1.2.0",
"resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz",
@@ -1776,39 +1810,39 @@
"dev": true
},
"inquirer": {
- "version": "6.2.1",
- "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.1.tgz",
- "integrity": "sha512-088kl3DRT2dLU5riVMKKr1DlImd6X7smDhpXUCkJDCKvTEJeRiXh0G132HG9u5a+6Ylw9plFRY7RuTnwohYSpg==",
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.3.1.tgz",
+ "integrity": "sha512-MmL624rfkFt4TG9y/Jvmt8vdmOo836U7Y0Hxr2aFk3RelZEGX4Igk0KabWrcaaZaTv9uzglOqWh1Vly+FAWAXA==",
"dev": true,
"requires": {
- "ansi-escapes": "^3.0.0",
- "chalk": "^2.0.0",
+ "ansi-escapes": "^3.2.0",
+ "chalk": "^2.4.2",
"cli-cursor": "^2.1.0",
"cli-width": "^2.0.0",
- "external-editor": "^3.0.0",
+ "external-editor": "^3.0.3",
"figures": "^2.0.0",
- "lodash": "^4.17.10",
+ "lodash": "^4.17.11",
"mute-stream": "0.0.7",
"run-async": "^2.2.0",
- "rxjs": "^6.1.0",
+ "rxjs": "^6.4.0",
"string-width": "^2.1.0",
- "strip-ansi": "^5.0.0",
+ "strip-ansi": "^5.1.0",
"through": "^2.3.6"
},
"dependencies": {
"ansi-regex": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz",
- "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==",
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
+ "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
"dev": true
},
"strip-ansi": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz",
- "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==",
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
+ "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
"dev": true,
"requires": {
- "ansi-regex": "^4.0.0"
+ "ansi-regex": "^4.1.0"
}
}
}
@@ -1849,6 +1883,12 @@
"builtin-modules": "^1.0.0"
}
},
+ "is-callable": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz",
+ "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==",
+ "dev": true
+ },
"is-data-descriptor": {
"version": "0.1.4",
"resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz",
@@ -1858,6 +1898,12 @@
"kind-of": "^3.0.2"
}
},
+ "is-date-object": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz",
+ "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=",
+ "dev": true
+ },
"is-descriptor": {
"version": "0.1.6",
"resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz",
@@ -1927,12 +1973,30 @@
"@types/estree": "0.0.39"
}
},
+ "is-regex": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz",
+ "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=",
+ "dev": true,
+ "requires": {
+ "has": "^1.0.1"
+ }
+ },
"is-stream": {
"version": "1.1.0",
"resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz",
"integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=",
"dev": true
},
+ "is-symbol": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz",
+ "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==",
+ "dev": true,
+ "requires": {
+ "has-symbols": "^1.0.0"
+ }
+ },
"is-typedarray": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
@@ -1996,9 +2060,9 @@
"dev": true
},
"js-yaml": {
- "version": "3.12.1",
- "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.1.tgz",
- "integrity": "sha512-um46hB9wNOKlwkHgiuyEVAybXBjwFUV0Z/RaHJblRd9DXltue9FTYvzCr9ErQrK9Adz5MU4gHWVaNUfdmrC8qA==",
+ "version": "3.13.1",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz",
+ "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==",
"dev": true,
"requires": {
"argparse": "^1.0.7",
@@ -2166,6 +2230,12 @@
"integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=",
"dev": true
},
+ "lodash.unescape": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/lodash.unescape/-/lodash.unescape-4.0.1.tgz",
+ "integrity": "sha1-vyJJiGzlFM2hEvrpIYzcBlIR/Jw=",
+ "dev": true
+ },
"lru-cache": {
"version": "4.1.5",
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz",
@@ -2448,6 +2518,12 @@
"integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=",
"dev": true
},
+ "neo-async": {
+ "version": "2.6.1",
+ "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.1.tgz",
+ "integrity": "sha512-iyam8fBuCUpWeKPGpaNMetEocMt364qkCsfL9JuhjXX6dRnguRVOfk2GZaDpPjcOKiiXCPINZC1GczQ7iTq3Zw==",
+ "dev": true
+ },
"nice-try": {
"version": "1.0.5",
"resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
@@ -2527,6 +2603,12 @@
}
}
},
+ "object-keys": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz",
+ "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==",
+ "dev": true
+ },
"object-visit": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz",
@@ -2671,9 +2753,9 @@
"dev": true
},
"parent-module": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.0.tgz",
- "integrity": "sha512-8Mf5juOMmiE4FcmzYc4IaiS9L3+9paz2KOiXzkRviCP6aDmN49Hz6EMWz0lGNp9pX80GvvAuLADtyGfW/Em3TA==",
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
"dev": true,
"requires": {
"callsites": "^3.0.0"
@@ -2775,12 +2857,6 @@
"find-up": "^2.1.0"
}
},
- "pluralize": {
- "version": "7.0.0",
- "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz",
- "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==",
- "dev": true
- },
"pn": {
"version": "1.1.0",
"resolved": "https://registry.npmjs.org/pn/-/pn-1.1.0.tgz",
@@ -2888,17 +2964,6 @@
"read-pkg": "^2.0.0"
}
},
- "readable-stream": {
- "version": "3.1.1",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.1.1.tgz",
- "integrity": "sha512-DkN66hPyqDhnIQ6Jcsvx9bFjhw214O4poMBcIMgPVpQvNy9a0e0Uhg5SqySyDKAmUlwt8LonTBz1ezOnM8pUdA==",
- "dev": true,
- "requires": {
- "inherits": "^2.0.3",
- "string_decoder": "^1.1.1",
- "util-deprecate": "^1.0.1"
- }
- },
"regex-not": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz",
@@ -2987,6 +3052,12 @@
"integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=",
"dev": true
},
+ "requireindex": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/requireindex/-/requireindex-1.2.0.tgz",
+ "integrity": "sha512-L9jEkOi3ASd9PYit2cwRfyppc9NoABujTP8/5gFcbERmo5jUoAKovIC3fsF17pkTnGsrByysqX+Kxd2OTNI1ww==",
+ "dev": true
+ },
"resolve": {
"version": "1.10.0",
"resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.0.tgz",
@@ -3440,9 +3511,9 @@
}
},
"rxjs": {
- "version": "6.3.3",
- "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.3.3.tgz",
- "integrity": "sha512-JTWmoY9tWCs7zvIk/CvRjhjGaOd+OVBM987mxFo+OW66cGpdKjZcpmc74ES1sB//7Kl/PAe8+wEakuhG4pcgOw==",
+ "version": "6.5.2",
+ "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz",
+ "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==",
"dev": true,
"requires": {
"tslib": "^1.9.0"
@@ -3535,9 +3606,9 @@
"dev": true
},
"slice-ansi": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.0.0.tgz",
- "integrity": "sha512-4j2WTWjp3GsZ+AOagyzVbzp4vWGtZ0hEZ/gDY/uTvm6MTxUfTUIsnMIFb1bn8o0RuXiqUw15H1bue8f22Vw2oQ==",
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz",
+ "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==",
"dev": true,
"requires": {
"ansi-styles": "^3.2.0",
@@ -3816,15 +3887,6 @@
"strip-ansi": "^4.0.0"
}
},
- "string_decoder": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.2.0.tgz",
- "integrity": "sha512-6YqyX6ZWEYguAxgZzHGL7SsCeGx3V2TtOTqZz1xSTSWnqsbWwbptafNyvf/ACquZUXV3DANr5BDIwNYe1mN42w==",
- "dev": true,
- "requires": {
- "safe-buffer": "~5.1.0"
- }
- },
"strip-ansi": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz",
@@ -3888,15 +3950,55 @@
"dev": true
},
"table": {
- "version": "5.2.1",
- "resolved": "https://registry.npmjs.org/table/-/table-5.2.1.tgz",
- "integrity": "sha512-qmhNs2GEHNqY5fd2Mo+8N1r2sw/rvTAAvBZTaTx+Y7PHLypqyrxr1MdIu0pLw6Xvl/Gi4ONu/sdceP8vvUjkyA==",
+ "version": "5.4.0",
+ "resolved": "https://registry.npmjs.org/table/-/table-5.4.0.tgz",
+ "integrity": "sha512-nHFDrxmbrkU7JAFKqKbDJXfzrX2UBsWmrieXFTGxiI5e4ncg3VqsZeI4EzNmX0ncp4XNGVeoxIWJXfCIXwrsvw==",
"dev": true,
"requires": {
- "ajv": "^6.6.1",
+ "ajv": "^6.9.1",
"lodash": "^4.17.11",
- "slice-ansi": "2.0.0",
- "string-width": "^2.1.1"
+ "slice-ansi": "^2.1.0",
+ "string-width": "^3.0.0"
+ },
+ "dependencies": {
+ "ajv": {
+ "version": "6.10.0",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz",
+ "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==",
+ "dev": true,
+ "requires": {
+ "fast-deep-equal": "^2.0.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ }
+ },
+ "ansi-regex": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
+ "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
+ "dev": true
+ },
+ "string-width": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz",
+ "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==",
+ "dev": true,
+ "requires": {
+ "emoji-regex": "^7.0.1",
+ "is-fullwidth-code-point": "^2.0.0",
+ "strip-ansi": "^5.1.0"
+ }
+ },
+ "strip-ansi": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
+ "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^4.1.0"
+ }
+ }
}
},
"test-exclude": {
@@ -4151,6 +4253,15 @@
"integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==",
"dev": true
},
+ "tsutils": {
+ "version": "3.14.0",
+ "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.14.0.tgz",
+ "integrity": "sha512-SmzGbB0l+8I0QwsPgjooFRaRvHLBLNYM8SeQ0k6rtNDru5sCGeLJcZdwilNndN+GysuFjF5EIYgN8GfFG6UeUw==",
+ "dev": true,
+ "requires": {
+ "tslib": "^1.8.1"
+ }
+ },
"tunnel-agent": {
"version": "0.6.0",
"resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz",
@@ -4182,26 +4293,26 @@
"dev": true
},
"typescript": {
- "version": "3.2.4",
- "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.2.4.tgz",
- "integrity": "sha512-0RNDbSdEokBeEAkgNbxJ+BLwSManFy9TeXz8uW+48j/xhEXv1ePME60olyzw2XzUqUBNAYFeJadIqAgNqIACwg==",
+ "version": "3.4.5",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.4.5.tgz",
+ "integrity": "sha512-YycBxUb49UUhdNMU5aJ7z5Ej2XGmaIBL0x34vZ82fn3hGvD+bgrMrVDpatgz2f7YxUMJxMkbWxJZeAvDxVe7Vw==",
"dev": true
},
"uglify-js": {
- "version": "3.4.9",
- "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.4.9.tgz",
- "integrity": "sha512-8CJsbKOtEbnJsTyv6LE6m6ZKniqMiFWmm9sRbopbkGs3gMPPfd3Fh8iIA4Ykv5MgaTbqHr4BaoGLJLZNhsrW1Q==",
+ "version": "3.5.12",
+ "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.5.12.tgz",
+ "integrity": "sha512-KeQesOpPiZNgVwJj8Ge3P4JYbQHUdZzpx6Fahy6eKAYRSV4zhVmLXoC+JtOeYxcHCHTve8RG1ZGdTvpeOUM26Q==",
"dev": true,
"optional": true,
"requires": {
- "commander": "~2.17.1",
+ "commander": "~2.20.0",
"source-map": "~0.6.1"
},
"dependencies": {
"commander": {
- "version": "2.17.1",
- "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz",
- "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==",
+ "version": "2.20.0",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.0.tgz",
+ "integrity": "sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ==",
"dev": true,
"optional": true
}
@@ -4470,9 +4581,9 @@
"dev": true
},
"write": {
- "version": "0.2.1",
- "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz",
- "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=",
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz",
+ "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==",
"dev": true,
"requires": {
"mkdirp": "^0.5.1"
@@ -4623,12 +4734,6 @@
"resolved": "https://registry.npmjs.org/yn/-/yn-3.0.0.tgz",
"integrity": "sha512-+Wo/p5VRfxUgBUGy2j/6KX2mj9AYJWOHuhMjMcbBFc3y54o9/4buK1ksBvuiK01C3kby8DH9lSmJdSxw+4G/2Q==",
"dev": true
- },
- "yootils": {
- "version": "0.0.15",
- "resolved": "https://registry.npmjs.org/yootils/-/yootils-0.0.15.tgz",
- "integrity": "sha512-GvGLuJ7XHJPGEUQ52vh8fh+vPjfikuGcu7yBswfrsNsHqnAoytOVuSb69eM0j8wQIjMz0U3kY3YsfwMhJgfG9w==",
- "dev": true
}
}
}
diff --git a/package.json b/package.json
index 437eef8d0e..35283d9069 100644
--- a/package.json
+++ b/package.json
@@ -1,37 +1,43 @@
{
"name": "svelte",
- "version": "3.3.0",
+ "version": "3.6.1",
"description": "Cybernetically enhanced web apps",
"module": "index.mjs",
"main": "index",
"files": [
- "compiler.js",
+ "types",
+ "compiler.*",
"register.js",
"index.*",
- "internal.*",
- "store.*",
- "animate.*",
- "transition.*",
- "easing.*",
- "motion.*",
+ "internal",
+ "store",
+ "animate",
+ "transition",
+ "easing",
+ "motion",
"svelte",
"README.md"
],
+ "engines": {
+ "node": ">= 8"
+ },
+ "types": "types/runtime/index.d.ts",
"scripts": {
"test": "mocha --opts mocha.opts",
- "test:unit": "mocha --require sucrase/register --recursive ./**/__test__.ts",
+ "test:unit": "mocha --require sucrase/register --recursive src/**/__test__.ts",
"quicktest": "mocha --opts mocha.opts",
"precoverage": "c8 mocha --opts mocha.coverage.opts",
"coverage": "c8 report --reporter=text-lcov > coverage.lcov && c8 report --reporter=html",
"codecov": "codecov",
"precodecov": "npm run coverage",
- "lint": "eslint src test/*.js",
- "build": "rollup -c",
+ "build": "rollup -c && npm run tsd",
"prepare": "npm run build",
"dev": "rollup -cw",
"pretest": "npm run build",
- "posttest": "agadoo src/internal/index.js",
- "prepublishOnly": "export PUBLISH=true && npm run lint && npm test"
+ "posttest": "agadoo internal/index.mjs",
+ "prepublishOnly": "npm run lint && PUBLISH=true npm test",
+ "tsd": "tsc -p src/compiler --emitDeclarationOnly && tsc -p src/runtime --emitDeclarationOnly",
+ "lint": "eslint \"{src,test}/**/*.{ts,js}\""
},
"repository": {
"type": "git",
@@ -50,19 +56,19 @@
},
"homepage": "https://github.com/sveltejs/svelte#README",
"devDependencies": {
- "@sveltejs/svelte-repl": "0.0.5",
"@types/mocha": "^5.2.0",
- "@types/node": "^10.5.5",
+ "@types/node": "=8",
+ "@typescript-eslint/eslint-plugin": "^1.9.0",
+ "@typescript-eslint/parser": "^1.9.0",
"acorn": "^6.1.1",
"acorn-dynamic-import": "^4.0.0",
"agadoo": "^1.0.1",
"c8": "^3.4.0",
"codecov": "^3.0.0",
"css-tree": "1.0.0-alpha22",
- "eslint": "^5.3.0",
- "eslint-plugin-html": "^5.0.0",
- "eslint-plugin-import": "^2.11.0",
- "estree-walker": "^0.6.0",
+ "eslint": "^5.16.0",
+ "eslint-plugin-import": "^2.17.3",
+ "estree-walker": "^0.6.1",
"is-reference": "^1.1.1",
"jsdom": "^12.2.0",
"kleur": "^3.0.0",
@@ -83,7 +89,7 @@
"tiny-glob": "^0.2.1",
"ts-node": "^8.0.2",
"tslib": "^1.8.0",
- "typescript": "^3.0.1"
+ "typescript": "^3.4.0"
},
"nyc": {
"include": [
diff --git a/register.js b/register.js
index f5cbeb5063..3278c1cbf5 100644
--- a/register.js
+++ b/register.js
@@ -25,8 +25,7 @@ function deregisterExtension(extension) {
function registerExtension(extension) {
require.extensions[extension] = function(module, filename) {
- const name = path.basename(filename)
- .slice(0, -path.extname(filename).length)
+ const name = path.parse(filename).name
.replace(/^\d/, '_$&')
.replace(/[^a-zA-Z0-9_$]/g, '');
@@ -46,4 +45,4 @@ function registerExtension(extension) {
registerExtension('.svelte');
registerExtension('.html');
-module.exports = register;
\ No newline at end of file
+module.exports = register;
diff --git a/rollup.config.js b/rollup.config.js
index f7b2d07d4b..8c3068dcbd 100644
--- a/rollup.config.js
+++ b/rollup.config.js
@@ -9,36 +9,82 @@ import pkg from './package.json';
const is_publish = !!process.env.PUBLISH;
+const ts_plugin = is_publish
+ ? typescript({
+ include: 'src/**',
+ typescript: require('typescript')
+ })
+ : sucrase({
+ transforms: ['typescript']
+ });
+
+const external = id => id.startsWith('svelte/');
+
+fs.writeFileSync(`./compiler.d.ts`, `export * from './types/compiler/index';`);
+
export default [
- /* internal.[m]js */
+ /* runtime */
{
- input: `src/internal/index.js`,
+ input: `src/runtime/index.ts`,
output: [
{
- file: `internal.mjs`,
+ file: `index.mjs`,
format: 'esm',
- paths: id => id.startsWith('svelte/') && id.replace('svelte', '.')
+ paths: id => id.startsWith('svelte/') && `${id.replace('svelte', '.')}`
},
{
- file: `internal.js`,
+ file: `index.js`,
format: 'cjs',
- paths: id => id.startsWith('svelte/') && id.replace('svelte', '.')
+ paths: id => id.startsWith('svelte/') && `${id.replace('svelte', '.')}`
}
],
- external: id => id.startsWith('svelte/'),
- plugins: [{
- generateBundle(options, bundle) {
- const mod = bundle['internal.mjs'];
- if (mod) {
- fs.writeFileSync('src/compile/internal-exports.ts', `// This file is automatically generated\nexport default new Set(${JSON.stringify(mod.exports)});`);
- }
- }
- }]
+ external,
+ plugins: [ts_plugin]
},
+ ...fs.readdirSync('src/runtime')
+ .filter(dir => fs.statSync(`src/runtime/${dir}`).isDirectory())
+ .map(dir => ({
+ input: `src/runtime/${dir}/index.ts`,
+ output: [
+ {
+ file: `${dir}/index.mjs`,
+ format: 'esm',
+ paths: id => id.startsWith('svelte/') && `${id.replace('svelte', '..')}`
+ },
+ {
+ file: `${dir}/index.js`,
+ format: 'cjs',
+ paths: id => id.startsWith('svelte/') && `${id.replace('svelte', '..')}`
+ }
+ ],
+ external,
+ plugins: [
+ ts_plugin,
+ {
+ writeBundle(bundle) {
+ if (dir === 'internal') {
+ const mod = bundle['index.mjs'];
+ if (mod) {
+ fs.writeFileSync('src/compiler/compile/internal_exports.ts', `// This file is automatically generated\nexport default new Set(${JSON.stringify(mod.exports)});`);
+ }
+ }
+
+ fs.writeFileSync(`${dir}/package.json`, JSON.stringify({
+ main: './index',
+ module: './index.mjs',
+ types: './index.d.ts'
+ }, null, ' '));
+
+ fs.writeFileSync(`${dir}/index.d.ts`, `export * from '../types/runtime/${dir}/index';`);
+ }
+ }
+ ]
+ })),
+
/* compiler.js */
{
- input: 'src/index.ts',
+ input: 'src/compiler/index.ts',
plugins: [
replace({
__VERSION__: pkg.version
@@ -48,15 +94,7 @@ export default [
include: ['node_modules/**']
}),
json(),
- is_publish
- ? typescript({
- include: 'src/**',
- exclude: 'src/internal/**',
- typescript: require('typescript')
- })
- : sucrase({
- transforms: ['typescript']
- })
+ ts_plugin
],
output: {
file: 'compiler.js',
@@ -67,34 +105,5 @@ export default [
external: is_publish
? []
: id => id === 'acorn' || id === 'magic-string' || id.startsWith('css-tree')
- },
-
- /* motion.mjs */
- {
- input: `src/motion/index.js`,
- output: [
- {
- file: `motion.mjs`,
- format: 'esm',
- paths: id => id.startsWith('svelte/') && id.replace('svelte', '.')
- },
- {
- file: `motion.js`,
- format: 'cjs',
- paths: id => id.startsWith('svelte/') && id.replace('svelte', '.')
- }
- ],
- external: id => id.startsWith('svelte/')
- },
-
- // everything else
- ...['index', 'store', 'easing', 'transition', 'animate'].map(name => ({
- input: `${name}.mjs`,
- output: {
- file: `${name}.js`,
- format: 'cjs',
- paths: id => id.startsWith('svelte/') && id.replace('svelte', '.')
- },
- external: id => id !== `${name}.mjs`
- }))
+ }
];
diff --git a/site/Dockerfile b/site/Dockerfile
index f53e6a0c4a..c2a65122d9 100644
--- a/site/Dockerfile
+++ b/site/Dockerfile
@@ -1,4 +1,4 @@
-FROM mhart/alpine-node:11.14
+FROM mhart/alpine-node:12
# install dependencies
WORKDIR /app
@@ -9,7 +9,7 @@ RUN npm ci --production
# Only copy over the Node pieces we need
# ~> Saves 35MB
###
-FROM mhart/alpine-node:base-11.14
+FROM mhart/alpine-node:slim-12
WORKDIR /app
COPY --from=0 /app .
diff --git a/site/README.md b/site/README.md
index c438bda5ca..259e956003 100644
--- a/site/README.md
+++ b/site/README.md
@@ -4,7 +4,10 @@ Set up the project:
```bash
git clone https://github.com/sveltejs/svelte.git
-cd svelte/site
+cd svelte
+npm ci
+PUBLISH=1 npm run build
+cd site
npm ci
npm run update
```
@@ -13,7 +16,11 @@ Start the server with `npm run dev`, and navigate to [localhost:3000](http://loc
## Using a local copy of Svelte
-By default, the REPL will fetch the most recent version of Svelte from https://unpkg.com/svelte. To use the local copy of the compiler and runtime from this repo, you can navigate to [localhost:3000/repl?version=local](http://localhost:3000/repl?version=local). To produce the proper browser-compatible UMD build, you will need to run `npm run build` with the `PUBLISH` environment variable set (to any non-empty string).
+By default, the REPL will fetch the most recent version of Svelte from https://unpkg.com/svelte. When running the site locally, you can also use your local copy of Svelte.
+
+To produce the proper browser-compatible UMD build of the compiler, you will need to run `npm run build` (or `npm run dev`) in the root of this repository with the `PUBLISH` environment variable set to any non-empty string.
+
+Then visit the REPL at [localhost:3000/repl?version=local](http://localhost:3000/repl?version=local). Please note that the local REPL only works with `npm run dev` and not when building the site for production usage.
## REPL GitHub integration
@@ -28,6 +35,13 @@ In order for the REPL's GitHub integration to work properly when running locally
GITHUB_CLIENT_SECRET=[your app's Client Secret]
BASEURL=http://localhost:3000
```
+## Building the site
+
+To build the website, run `npm run sapper`. The output can be found in `__sapper__/build`.
+
+## Testing
+
+Tests can be run using `npm run test`.
## Translating the API docs
diff --git a/site/content/blog/2017-08-07-the-easiest-way-to-get-started.md b/site/content/blog/2017-08-07-the-easiest-way-to-get-started.md
index 596c469433..9d4c661615 100644
--- a/site/content/blog/2017-08-07-the-easiest-way-to-get-started.md
+++ b/site/content/blog/2017-08-07-the-easiest-way-to-get-started.md
@@ -44,9 +44,11 @@ In the terminal, you can instantly create a new project like so:
npx degit sveltejs/template my-svelte-project
cd my-svelte-project
npm install
-npm run dev & open http://localhost:5000
+npm run dev
```
+This will create a new project in the `my-svelte-project` directory, install its dependencies, and start a server on http://localhost:5000.
+
Once you've tinkered a bit and understood how everything fits together, you can fork [sveltejs/template](https://github.com/sveltejs/template) and start doing this instead:
```bash
diff --git a/site/content/docs/01-component-format.md b/site/content/docs/01-component-format.md
index 1472ff3d6c..b60457d5af 100644
--- a/site/content/docs/01-component-format.md
+++ b/site/content/docs/01-component-format.md
@@ -28,38 +28,60 @@ A `
+```
+
+---
+
+You can specify a default value, which will be used if the component's consumer doesn't specify a prop.
+
+In development mode (see the [compiler options](docs#svelte_compile)), a warning will be printed if no default is provided and the consumer does not specify a value. To squelch this warning, ensure that a default is specified, even if it is `undefined`.
+
+```html
+
+```
- // you can use export { ... as ... } to have
- // props whose names are reserved keywords
- let clazz;
- export { clazz as class };
+---
- // this property is readonly externally
- export const buzz = 'buzz';
+If you export a `const`, `class` or `function`, it is readonly from outside the component. Function *expressions* are valid props, however.
- // Values that are passed in as props
- // are immediately available
- console.log(foo, bar);
+```html
+
+```
+
+---
+
+You can use reserved words as prop names.
+
+```html
+
```
@@ -78,8 +100,8 @@ Because Svelte's reactivity is based on assignments, using array methods like `.
let count = 0;
function handleClick () {
- // calling this function will trigger a re-render
- // if the markup references `count`
+ // calling this function will trigger an
+ // update if the markup references `count`
count = count + 1;
}
diff --git a/site/content/docs/02-template-syntax.md b/site/content/docs/02-template-syntax.md
index c6fd5c8b2d..981224fc14 100644
--- a/site/content/docs/02-template-syntax.md
+++ b/site/content/docs/02-template-syntax.md
@@ -20,7 +20,7 @@ A lowercase tag, like ``, denotes a regular HTML element. A capitalised tag
```
-### Attributes
+### Attributes and props
---
@@ -76,6 +76,16 @@ When the attribute name and value match (`name={name}`), they can be replaced wi
---
+By convention, values passed to components are referred to as *properties* or *props* rather than *attributes*, which are a feature of the DOM.
+
+As with elements, `name={name}` can be replaced with the `{name}` shorthand.
+
+```html
+
+```
+
+---
+
*Spread attributes* allow many attributes or properties to be passed to an element or component at once.
An element or component can have multiple spread attributes, interspersed with regular ones.
@@ -101,27 +111,7 @@ Text can also contain JavaScript expressions:
```
-### HTML expressions
-
-```sv
-{@html expression}
-```
-
----
-
-In a text expression, characters like `<` and `>` are escaped. With HTML expressions, they're not.
-
-> Svelte does not sanitize expressions before injecting HTML. If the data comes from an untrusted source, you must sanitize it, or you are exposing your users to an XSS vulnerability.
-
-```html
-
-
{post.title}
- {@html post.content}
-
-```
-
-
-### If blocks
+### {#if ...}
```sv
{#if expression}...{/if}
@@ -158,7 +148,7 @@ Additional conditions can be added with `{:else if expression}`, optionally endi
```
-### Each blocks
+### {#each ...}
```sv
{#each expression as name}...{/each}
@@ -208,12 +198,20 @@ If a *key* expression is provided — which must uniquely identify each list ite
---
-You can freely use destructuring patterns in each blocks.
+You can freely use destructuring and rest patterns in each blocks.
```html
{#each items as { id, name, qty }, i (id)}
{i + 1}: {name} x {qty}
{/each}
+
+{#each objects as { id, ...rest }}
+
{id}
+{/each}
+
+{#each items as [id, ...rest]}
+
{id}
+{/each}
```
---
@@ -229,7 +227,7 @@ An each block can also have an `{:else}` clause, which is rendered if the list i
```
-### Await blocks
+### {#await ...}
```sv
{#await expression}...{:then name}...{:catch name}...{/await}
@@ -283,7 +281,80 @@ If you don't care about the pending state, you can also omit the initial block.
```
-### DOM events
+### {@html ...}
+
+```sv
+{@html expression}
+```
+
+---
+
+In a text expression, characters like `<` and `>` are escaped. With HTML expressions, they're not.
+
+> Svelte does not sanitize expressions before injecting HTML. If the data comes from an untrusted source, you must sanitize it, or you are exposing your users to an XSS vulnerability.
+
+```html
+
+
{post.title}
+ {@html post.content}
+
+```
+
+
+### {@debug ...}
+
+```sv
+{@debug}
+```
+```sv
+{@debug var1, var2, ..., varN}
+```
+
+---
+
+The `{@debug ...}` tag offers an alternative to `console.log(...)`. It logs the values of specific variables whenever they change, and pauses code execution if you have devtools open.
+
+It accepts a comma-separated list of variable names (not arbitrary expressions).
+
+```html
+
+
+{@debug user}
+
+
Hello {user.firstname}!
+```
+
+---
+
+`{@debug ...}` accepts a comma-separated list of variable names (not arbitrary expressions).
+
+```html
+
+{@debug user}
+{@debug user1, user2, user3}
+
+
+{@debug user.firstname}
+{@debug myArray[0]}
+{@debug !isReady}
+{@debug typeof user === 'object'}
+```
+
+The `{@debug}` tag without any arguments will insert a `debugger` statement that gets triggered when *any* state changes, as opposed to the specified variables.
+
+
+
+### Element directives
+
+As well as attributes, elements can have *directives*, which control the element's behaviour in some way.
+
+
+#### [on:*eventname*](on_component_event)
```sv
on:eventname={handler}
@@ -324,6 +395,13 @@ Handlers can be declared inline with no performance penalty. As with attributes,
Add *modifiers* to DOM events with the `|` character.
+```html
+
+```
+
The following modifiers are available:
* `preventDefault` — calls `event.preventDefault()` before running the handler
@@ -334,13 +412,6 @@ The following modifiers are available:
Modifiers can be chained together, e.g. `on:click|once|capture={...}`.
-```html
-
-```
-
---
If the `on:` directive is used without a value, the component will *forward* the event, meaning that a consumer of the component can listen for it.
@@ -351,40 +422,30 @@ If the `on:` directive is used without a value, the component will *forward* the
```
-
-### Component events
-
-```sv
-on:eventname={handler}
-```
-
---
-Components can emit events using [createEventDispatcher](docs#createEventDispatcher), or by forwarding DOM events. Listening for component events looks the same as listening for DOM events:
+It's possible to have multiple event listeners for the same event:
```html
-
-```
-
----
+
-```html
-
+Click me!
```
-### Element bindings
+#### [bind:*property*](bind_element_property)
```sv
bind:property={variable}
```
-```sv
-bind:group={variable}
-```
-```sv
-bind:this={dom_node}
-```
---
@@ -418,31 +479,8 @@ Numeric input values are coerced; even though `input.value` is a string as far a
```
-#### Binding related elements
----
-
-Inputs that work together can use `bind:group`.
-
-```html
-
-
-
-
-
-
-
-
-
-
-
-
-```
-
-#### Binding `` value
+##### Binding `` value
---
@@ -482,7 +520,15 @@ When the value of an `` matches its text content, the attribute can be o
```
-#### Media element bindings
+---
+
+Elements with the `contenteditable` attribute support `innerHTML` and `textContent` bindings.
+
+```html
+
+```
+
+##### Media element bindings
---
@@ -512,7 +558,7 @@ Media elements (`` and ``) have their own set of bindings — four
>
```
-#### Block-level element bindings
+##### Block-level element bindings
---
@@ -532,61 +578,61 @@ Block-level elements have 4 readonly bindings, measured using a technique simila
```
-#### Binding a DOM node
+#### bind:group
+
+```sv
+bind:group={variable}
+```
---
-To get a reference to a DOM node, use `bind:this`.
+Inputs that work together can use `bind:group`.
```html
-
-```
+
+
+
+
+
+
+
+
+
+```
-### Component bindings
+#### [bind:this](bind_element)
```sv
-bind:property={variable}
-```
-```sv
-bind:this={component_instance}
+bind:this={dom_node}
```
---
-You can bind to component props using the same mechanism.
+To get a reference to a DOM node, use `bind:this`.
```html
-
-```
-
----
-
-Components also support `bind:this`, allowing you to interact with component instances programmatically.
+
-
- Empty shopping cart
-
+
```
-### Classes
+#### class:*name*
```sv
class:name={value}
@@ -612,7 +658,7 @@ A `class:` directive provides a shorter way of toggling a class on an element.
```
-### Actions
+#### use:*action*
```sv
use:action
@@ -677,43 +723,19 @@ An action can have parameters. If the returned value has an `update` method, it
```
-### Transitions
+#### transition:*fn*
```sv
-transition:name
-```
-```sv
-transition:name={params}
-```
-```sv
-transition:name|local
-```
-```sv
-transition:name|local={params}
-```
-```sv
-in:name
+transition:fn
```
```sv
-in:name={params}
+transition:fn={params}
```
```sv
-in:name|local
+transition:fn|local
```
```sv
-in:name|local={params}
-```
-```sv
-out:name
-```
-```sv
-out:name={params}
-```
-```sv
-out:name|local
-```
-```sv
-out:name|local={params}
+transition:fn|local={params}
```
@@ -729,7 +751,7 @@ transition = (node: HTMLElement, params: any) => {
---
-A transition is triggered by an element entering or leaving the DOM as a result of a state change. Transitions do not run when a component is first mounted, but only on subsequent updates.
+A transition is triggered by an element entering or leaving the DOM as a result of a state change.
Elements inside an *outroing* block are kept in the DOM until all current transitions have completed.
@@ -743,21 +765,9 @@ The `transition:` directive indicates a *bidirectional* transition, which means
{/if}
```
----
-
-The `in:` and `out:` directives are not bidirectional. An in transition will continue to 'play' alongside the out transition, if the block is outroed while the transition is in progress. If an out transition is aborted, transitions will restart from scratch.
-
-```html
-{#if visible}
-
- flies in, fades out
-
-{/if}
-```
-
> By default intro transitions will not play on first render. You can modify this behaviour by setting `intro: true` when you [create a component](docs#Client-side_component_API).
-#### Transition parameters
+##### Transition parameters
---
@@ -773,7 +783,7 @@ Like actions, transitions can have parameters.
{/if}
```
-#### Custom transition functions
+##### Custom transition functions
---
@@ -849,7 +859,7 @@ A custom transition function can also return a `tick` function, which is called
If a transition returns a function instead of a transition object, the function will be called in the next microtask. This allows multiple transitions to coordinate, making [crossfade effects](tutorial/deferred-transitions) possible.
-#### Transition events
+##### Transition events
---
@@ -893,7 +903,51 @@ Local transitions only play when the block they belong to is created or destroye
```
-### Animations
+#### in:*fn*/out:*fn*
+
+```sv
+in:fn
+```
+```sv
+in:fn={params}
+```
+```sv
+in:fn|local
+```
+```sv
+in:fn|local={params}
+```
+
+```sv
+out:fn
+```
+```sv
+out:fn={params}
+```
+```sv
+out:fn|local
+```
+```sv
+out:fn|local={params}
+```
+
+---
+
+Similar to `transition:`, but only applies to elements entering (`in:`) or leaving (`out:`) the DOM.
+
+Unlike with `transition:`, transitions applied with `in:` and `out:` are not bidirectional — an in transition will continue to 'play' alongside the out transition, rather than reversing, if the block is outroed while the transition is in progress. If an out transition is aborted, transitions will restart from scratch.
+
+```html
+{#if visible}
+
+ flies in, fades out
+
+{/if}
+```
+
+
+
+#### animate:
```sv
animate:name
@@ -939,7 +993,7 @@ Animations can be used with Svelte's [built-in animation functions](docs#svelte_
{/each}
```
-#### Animation Parameters
+##### Animation Parameters
---
@@ -953,7 +1007,7 @@ As with actions and transitions, animations can have parameters.
{/each}
```
-#### Custom animation functions
+##### Custom animation functions
---
@@ -1027,9 +1081,68 @@ A custom animation function can also return a `tick` function, which is called *
{/each}
```
+### Component directives
+
+#### [on:*eventname*](on_component_event)
+
+```sv
+on:eventname={handler}
+```
+
+---
+
+Components can emit events using [createEventDispatcher](docs#createEventDispatcher), or by forwarding DOM events. Listening for component events looks the same as listening for DOM events:
+
+```html
+
+```
+---
-### Slots
+As with DOM events, if the `on:` directive is used without a value, the component will *forward* the event, meaning that a consumer of the component can listen for it.
+
+```html
+
+```
+
+
+#### [bind:*property*](bind_component_property)
+
+```sv
+bind:property={variable}
+```
+
+---
+
+You can bind to component props using the same mechanism.
+
+```html
+
+```
+
+#### [bind:this](bind_component)
+
+```sv
+bind:this={component_instance}
+```
+
+---
+
+Components also support `bind:this`, allowing you to interact with component instances programmatically.
+
+> Note that we can't do `{cart.empty}` since `cart` is `undefined` when the button is first rendered and throws an error.
+
+```html
+
+
+ cart.empty()}>
+ Empty shopping cart
+
+```
+
+
+
+### ``
```sv
@@ -1061,6 +1174,8 @@ The content is exposed in the child component using the `` element, which
```
+#### [``](slot_name)
+
---
Named slots allow consumers to target specific areas. They can also have fallback content.
@@ -1080,6 +1195,8 @@ Named slots allow consumers to target specific areas. They can also have fallbac
```
+#### [``](slot_let)
+
---
Slots can be rendered zero or more times, and can pass values *back* to the parent using props. The parent exposes the values to the slot template using the `let:` directive.
@@ -1126,7 +1243,7 @@ Named slots can also expose values. The `let:` directive goes on the element wit
```
-### <svelte:self>
+### ``
---
@@ -1147,10 +1264,10 @@ It cannot appear at the top level of your markup; it must be inside an if or eac
{/if}
```
-### <svelte:component>
+### ``
```sv
-
+
```
---
@@ -1164,7 +1281,7 @@ If `this` is falsy, no component is rendered.
```
-### <svelte:window>
+### ``
```sv
@@ -1206,7 +1323,7 @@ All except `scrollX` and `scrollY` are readonly.
```
-### <svelte:body>
+### ``
```sv
@@ -1224,10 +1341,10 @@ As with ``, this element allows you to add listeners to events on
```
-### <svelte:head>
+### ``
```sv
-
+...
```
---
@@ -1241,10 +1358,10 @@ This element makes it possible to insert elements into `document.head`. During s
```
-### <svelte:options>
+### ``
```sv
-
+
```
---
diff --git a/site/content/docs/03-run-time.md b/site/content/docs/03-run-time.md
index 1beacc4169..bd5d4b40ce 100644
--- a/site/content/docs/03-run-time.md
+++ b/site/content/docs/03-run-time.md
@@ -359,17 +359,21 @@ const delayed = derived(a, ($a, set) => {
}, 'one moment...');
```
-If you return a function from the callback, it will be called when a) the callback runs again, or b) the last subscriber unsubscribes:
+---
+
+If you return a function from the callback, it will be called when a) the callback runs again, or b) the last subscriber unsubscribes.
```js
import { derived } from 'svelte/store';
const tick = derived(frequency, ($frequency, set) => {
- const interval = setInterval(() => set(Date.now()), 1000 / frequency);
+ const interval = setInterval(() => {
+ set(Date.now());
+ }, 1000 / $frequency);
return () => {
clearInterval(interval);
- }
+ };
}, 'one moment...');
```
@@ -618,13 +622,13 @@ Slides an element in and out.
```html
{#if condition}
-
- flies in and out
+
+ slides in and out
{/if}
```
diff --git a/site/content/docs/04-compile-time.md b/site/content/docs/04-compile-time.md
index b019b9437b..c219bae497 100644
--- a/site/content/docs/04-compile-time.md
+++ b/site/content/docs/04-compile-time.md
@@ -308,8 +308,8 @@ const { code } = svelte.preprocess(source, [
```js
walk(ast: Node, {
- enter(node: Node, parent: Node)?: void,
- leave(node: Node, parent: Node)?: void
+ enter(node: Node, parent: Node, prop: string, index: number)?: void,
+ leave(node: Node, parent: Node, prop: string, index: number)?: void
})
```
@@ -323,13 +323,13 @@ The walker takes an abstract syntax tree to walk and an object with two optional
```js
const svelte = require('svelte/compiler');
svelte.walk(ast, {
- enter(node, parent) {
+ enter(node, parent, prop, index) {
do_something(node);
if (should_skip_children(node)) {
this.skip();
}
},
- leave(node, parent) {
+ leave(node, parent, prop, index) {
do_something_else(node);
}
});
diff --git a/site/content/examples/06-lifecycle/02-update/App.svelte b/site/content/examples/06-lifecycle/02-update/App.svelte
index 373b6dcb6a..3eb2dceb52 100644
--- a/site/content/examples/06-lifecycle/02-update/App.svelte
+++ b/site/content/examples/06-lifecycle/02-update/App.svelte
@@ -1,5 +1,5 @@
-
+
todo
diff --git a/site/content/examples/19-7guis/05-7guis-crud/App.svelte b/site/content/examples/19-7guis/05-7guis-crud/App.svelte
index 1f39fe6642..f55aeb0d83 100644
--- a/site/content/examples/19-7guis/05-7guis-crud/App.svelte
+++ b/site/content/examples/19-7guis/05-7guis-crud/App.svelte
@@ -30,10 +30,7 @@
$: selected = filteredPeople[i];
- $: {
- first = selected ? selected.first : '';
- last = selected ? selected.last : '';
- }
+ $: reset_inputs(selected);
function create() {
people = people.concat({ first, last });
@@ -46,14 +43,17 @@
}
function remove() {
- people = [...people.slice(0, i), ...people.slice(i + 1)];
+ // Remove selected person from the source array (people), not the filtered array
+ const index = people.indexOf(selected);
+ people = [...people.slice(0, index), ...people.slice(index + 1)];
first = last = '';
- i = Math.min(i, people.length - 1);
+ i = Math.min(i, filteredPeople.length - 2);
}
function reset_inputs(person) {
- ({ first, last } = person);
+ first = person ? person.first : '';
+ last = person ? person.last : '';
}
diff --git a/site/content/examples/20-miscellaneous/02-immutable-data/flash.js b/site/content/examples/20-miscellaneous/02-immutable-data/flash.js
index 8dff9cbe2f..c788cc6d35 100644
--- a/site/content/examples/20-miscellaneous/02-immutable-data/flash.js
+++ b/site/content/examples/20-miscellaneous/02-immutable-data/flash.js
@@ -1,11 +1,13 @@
export default function flash(element) {
- element.style.transition = 'none';
- element.style.color = 'rgba(255,62,0,1)';
- element.style.backgroundColor = 'rgba(255,62,0,0.2)';
+ requestAnimationFrame(() => {
+ element.style.transition = 'none';
+ element.style.color = 'rgba(255,62,0,1)';
+ element.style.backgroundColor = 'rgba(255,62,0,0.2)';
- setTimeout(() => {
- element.style.transition = 'color 1s, background 1s';
- element.style.color = '';
- element.style.backgroundColor = '';
+ setTimeout(() => {
+ element.style.transition = 'color 1s, background 1s';
+ element.style.color = '';
+ element.style.backgroundColor = '';
+ });
});
}
\ No newline at end of file
diff --git a/site/content/examples/99-embeds/20181225-blog-svelte-css-in-js/App.svelte b/site/content/examples/99-embeds/20181225-blog-svelte-css-in-js/App.svelte
index c8487abefe..ccb1ad8834 100644
--- a/site/content/examples/99-embeds/20181225-blog-svelte-css-in-js/App.svelte
+++ b/site/content/examples/99-embeds/20181225-blog-svelte-css-in-js/App.svelte
@@ -1,6 +1,6 @@
diff --git a/site/content/examples/99-embeds/20181225-blog-svelte-css-in-js/styles.js b/site/content/examples/99-embeds/20181225-blog-svelte-css-in-js/styles.js
index faf91b13d4..c7e10606c5 100644
--- a/site/content/examples/99-embeds/20181225-blog-svelte-css-in-js/styles.js
+++ b/site/content/examples/99-embeds/20181225-blog-svelte-css-in-js/styles.js
@@ -1,4 +1,6 @@
-import { css } from 'emotion/dist/emotion.umd.min.js';
+import emotion from 'emotion/dist/emotion.umd.min.js';
+
+const { css } = emotion;
const brand = '#74D900';
@@ -30,4 +32,4 @@ export const link = css`
text-decoration: none;
background: ${brand};
}
-`;
\ No newline at end of file
+`;
diff --git a/site/content/tutorial/01-introduction/03-dynamic-attributes/app-b/App.svelte b/site/content/tutorial/01-introduction/03-dynamic-attributes/app-b/App.svelte
index 6a12752e1a..e61b4d48e0 100644
--- a/site/content/tutorial/01-introduction/03-dynamic-attributes/app-b/App.svelte
+++ b/site/content/tutorial/01-introduction/03-dynamic-attributes/app-b/App.svelte
@@ -3,4 +3,4 @@
let name = 'Rick Astley';
-
\ No newline at end of file
+
diff --git a/site/content/tutorial/01-introduction/03-dynamic-attributes/text.md b/site/content/tutorial/01-introduction/03-dynamic-attributes/text.md
index 1fd6774b8a..c503b4f548 100644
--- a/site/content/tutorial/01-introduction/03-dynamic-attributes/text.md
+++ b/site/content/tutorial/01-introduction/03-dynamic-attributes/text.md
@@ -19,10 +19,10 @@ When building web apps, it's important to make sure that they're *accessible* to
In this case, we're missing the `alt` attribute that describes the image for people using screenreaders, or people with slow or flaky internet connections that can't download the image. Let's add one:
```html
-
+
```
-We can use curly braces *inside* attributes. Try changing it to `"{name} dancing"` — remember to declare a `name` variable in the `
```
-If we now instantiate the component without an `answer` prop, it will fall back to the default:
+If we now add a second component *without* an `answer` prop, it will fall back to the default:
```html
-```
\ No newline at end of file
+```
diff --git a/site/content/tutorial/06-bindings/08-contenteditable-bindings/app-a/App.svelte b/site/content/tutorial/06-bindings/08-contenteditable-bindings/app-a/App.svelte
new file mode 100644
index 0000000000..55d699959c
--- /dev/null
+++ b/site/content/tutorial/06-bindings/08-contenteditable-bindings/app-a/App.svelte
@@ -0,0 +1,15 @@
+
+
+
+
+{html}
+
+
\ No newline at end of file
diff --git a/site/content/tutorial/06-bindings/08-contenteditable-bindings/app-b/App.svelte b/site/content/tutorial/06-bindings/08-contenteditable-bindings/app-b/App.svelte
new file mode 100644
index 0000000000..ee97cf19c0
--- /dev/null
+++ b/site/content/tutorial/06-bindings/08-contenteditable-bindings/app-b/App.svelte
@@ -0,0 +1,18 @@
+
+
+
+
+{html}
+
+
\ No newline at end of file
diff --git a/site/content/tutorial/06-bindings/08-contenteditable-bindings/text.md b/site/content/tutorial/06-bindings/08-contenteditable-bindings/text.md
new file mode 100644
index 0000000000..a73b07c0ba
--- /dev/null
+++ b/site/content/tutorial/06-bindings/08-contenteditable-bindings/text.md
@@ -0,0 +1,12 @@
+---
+title: Contenteditable bindings
+---
+
+Elements with a `contenteditable="true"` attribute support `textContent` and `innerHTML` bindings:
+
+```html
+
+```
\ No newline at end of file
diff --git a/site/content/tutorial/06-bindings/08-each-block-bindings/app-a/App.svelte b/site/content/tutorial/06-bindings/09-each-block-bindings/app-a/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/08-each-block-bindings/app-a/App.svelte
rename to site/content/tutorial/06-bindings/09-each-block-bindings/app-a/App.svelte
diff --git a/site/content/tutorial/06-bindings/08-each-block-bindings/app-b/App.svelte b/site/content/tutorial/06-bindings/09-each-block-bindings/app-b/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/08-each-block-bindings/app-b/App.svelte
rename to site/content/tutorial/06-bindings/09-each-block-bindings/app-b/App.svelte
diff --git a/site/content/tutorial/06-bindings/08-each-block-bindings/text.md b/site/content/tutorial/06-bindings/09-each-block-bindings/text.md
similarity index 100%
rename from site/content/tutorial/06-bindings/08-each-block-bindings/text.md
rename to site/content/tutorial/06-bindings/09-each-block-bindings/text.md
diff --git a/site/content/tutorial/06-bindings/09-media-elements/app-a/App.svelte b/site/content/tutorial/06-bindings/10-media-elements/app-a/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/09-media-elements/app-a/App.svelte
rename to site/content/tutorial/06-bindings/10-media-elements/app-a/App.svelte
diff --git a/site/content/tutorial/06-bindings/09-media-elements/app-b/App.svelte b/site/content/tutorial/06-bindings/10-media-elements/app-b/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/09-media-elements/app-b/App.svelte
rename to site/content/tutorial/06-bindings/10-media-elements/app-b/App.svelte
diff --git a/site/content/tutorial/06-bindings/09-media-elements/text.md b/site/content/tutorial/06-bindings/10-media-elements/text.md
similarity index 100%
rename from site/content/tutorial/06-bindings/09-media-elements/text.md
rename to site/content/tutorial/06-bindings/10-media-elements/text.md
diff --git a/site/content/tutorial/06-bindings/10-dimensions/app-a/App.svelte b/site/content/tutorial/06-bindings/11-dimensions/app-a/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/10-dimensions/app-a/App.svelte
rename to site/content/tutorial/06-bindings/11-dimensions/app-a/App.svelte
diff --git a/site/content/tutorial/06-bindings/10-dimensions/app-b/App.svelte b/site/content/tutorial/06-bindings/11-dimensions/app-b/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/10-dimensions/app-b/App.svelte
rename to site/content/tutorial/06-bindings/11-dimensions/app-b/App.svelte
diff --git a/site/content/tutorial/06-bindings/10-dimensions/text.md b/site/content/tutorial/06-bindings/11-dimensions/text.md
similarity index 100%
rename from site/content/tutorial/06-bindings/10-dimensions/text.md
rename to site/content/tutorial/06-bindings/11-dimensions/text.md
diff --git a/site/content/tutorial/06-bindings/11-bind-this/app-a/App.svelte b/site/content/tutorial/06-bindings/12-bind-this/app-a/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/11-bind-this/app-a/App.svelte
rename to site/content/tutorial/06-bindings/12-bind-this/app-a/App.svelte
diff --git a/site/content/tutorial/06-bindings/11-bind-this/app-b/App.svelte b/site/content/tutorial/06-bindings/12-bind-this/app-b/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/11-bind-this/app-b/App.svelte
rename to site/content/tutorial/06-bindings/12-bind-this/app-b/App.svelte
diff --git a/site/content/tutorial/06-bindings/11-bind-this/text.md b/site/content/tutorial/06-bindings/12-bind-this/text.md
similarity index 100%
rename from site/content/tutorial/06-bindings/11-bind-this/text.md
rename to site/content/tutorial/06-bindings/12-bind-this/text.md
diff --git a/site/content/tutorial/06-bindings/12-component-bindings/app-a/App.svelte b/site/content/tutorial/06-bindings/13-component-bindings/app-a/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/12-component-bindings/app-a/App.svelte
rename to site/content/tutorial/06-bindings/13-component-bindings/app-a/App.svelte
diff --git a/site/content/tutorial/06-bindings/12-component-bindings/app-a/Keypad.svelte b/site/content/tutorial/06-bindings/13-component-bindings/app-a/Keypad.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/12-component-bindings/app-a/Keypad.svelte
rename to site/content/tutorial/06-bindings/13-component-bindings/app-a/Keypad.svelte
diff --git a/site/content/tutorial/06-bindings/12-component-bindings/app-b/App.svelte b/site/content/tutorial/06-bindings/13-component-bindings/app-b/App.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/12-component-bindings/app-b/App.svelte
rename to site/content/tutorial/06-bindings/13-component-bindings/app-b/App.svelte
diff --git a/site/content/tutorial/06-bindings/12-component-bindings/app-b/Keypad.svelte b/site/content/tutorial/06-bindings/13-component-bindings/app-b/Keypad.svelte
similarity index 100%
rename from site/content/tutorial/06-bindings/12-component-bindings/app-b/Keypad.svelte
rename to site/content/tutorial/06-bindings/13-component-bindings/app-b/Keypad.svelte
diff --git a/site/content/tutorial/06-bindings/12-component-bindings/text.md b/site/content/tutorial/06-bindings/13-component-bindings/text.md
similarity index 100%
rename from site/content/tutorial/06-bindings/12-component-bindings/text.md
rename to site/content/tutorial/06-bindings/13-component-bindings/text.md
diff --git a/site/content/tutorial/07-lifecycle/03-update/app-a/App.svelte b/site/content/tutorial/07-lifecycle/03-update/app-a/App.svelte
index 2081b6ab8c..75fce63ca2 100644
--- a/site/content/tutorial/07-lifecycle/03-update/app-a/App.svelte
+++ b/site/content/tutorial/07-lifecycle/03-update/app-a/App.svelte
@@ -1,5 +1,5 @@
+
+Hello world
+
+
diff --git a/test/custom-elements/index.js b/test/custom-elements/index.js
index 32e95266ec..9255d33c0e 100644
--- a/test/custom-elements/index.js
+++ b/test/custom-elements/index.js
@@ -5,6 +5,7 @@ import { rollup } from 'rollup';
import * as virtual from 'rollup-plugin-virtual';
import * as puppeteer from 'puppeteer';
import { addLineNumbers, loadConfig, loadSvelte } from "../helpers.js";
+import { deepEqual } from 'assert';
const page = `
@@ -57,18 +58,20 @@ describe('custom-elements', function() {
const solo = /\.solo$/.test(dir);
const skip = /\.skip$/.test(dir);
- const internal = path.resolve('internal.mjs');
+ const internal = path.resolve('internal/index.mjs');
const index = path.resolve('index.mjs');
+ const warnings = [];
(solo ? it.only : skip ? it.skip : it)(dir, async () => {
const config = loadConfig(`./custom-elements/samples/${dir}/_config.js`);
+ const expected_warnings = config.warnings || [];
const bundle = await rollup({
input: `test/custom-elements/samples/${dir}/test.js`,
plugins: [
{
resolveId(importee) {
- if (importee === 'svelte/internal') {
+ if (importee === 'svelte/internal' || importee === './internal') {
return internal;
}
@@ -84,6 +87,8 @@ describe('custom-elements', function() {
dev: config.dev
});
+ compiled.warnings.forEach(w => warnings.push(w));
+
return compiled.js;
}
}
@@ -112,6 +117,16 @@ describe('custom-elements', function() {
} catch (err) {
console.log(addLineNumbers(code));
throw err;
+ } finally {
+ if (expected_warnings) {
+ deepEqual(warnings.map(w => ({
+ code: w.code,
+ message: w.message,
+ pos: w.pos,
+ start: w.start,
+ end: w.end
+ })), expected_warnings);
+ }
}
});
});
diff --git a/test/custom-elements/samples/no-svelte-options/_config.js b/test/custom-elements/samples/no-svelte-options/_config.js
new file mode 100644
index 0000000000..e45582a127
--- /dev/null
+++ b/test/custom-elements/samples/no-svelte-options/_config.js
@@ -0,0 +1,17 @@
+export default {
+ warnings: [{
+ code: "custom-element-no-tag",
+ message: "No custom element 'tag' option was specified. To automatically register a custom element, specify a name with a hyphen in it, e.g. . To hide this warning, use ",
+ pos: 0,
+ start: {
+ character: 0,
+ column: 0,
+ line: 1
+ },
+ end: {
+ character: 0,
+ column: 0,
+ line: 1
+ }
+ }]
+};
diff --git a/test/custom-elements/samples/no-svelte-options/main.svelte b/test/custom-elements/samples/no-svelte-options/main.svelte
new file mode 100644
index 0000000000..538dc970e9
--- /dev/null
+++ b/test/custom-elements/samples/no-svelte-options/main.svelte
@@ -0,0 +1,5 @@
+
+
+Hello {name}!
diff --git a/test/custom-elements/samples/no-svelte-options/test.js b/test/custom-elements/samples/no-svelte-options/test.js
new file mode 100644
index 0000000000..c77f035088
--- /dev/null
+++ b/test/custom-elements/samples/no-svelte-options/test.js
@@ -0,0 +1,12 @@
+import * as assert from 'assert';
+import CustomElement from './main.svelte';
+
+export default function (target) {
+ customElements.define('no-tag', CustomElement);
+ target.innerHTML = ` `;
+
+ const el = target.querySelector('no-tag');
+ const h1 = el.shadowRoot.querySelector('h1');
+
+ assert.equal(h1.textContent, 'Hello world!');
+}
diff --git a/test/custom-elements/samples/no-tag-warning/_config.js b/test/custom-elements/samples/no-tag-warning/_config.js
new file mode 100644
index 0000000000..7cdfdbaec6
--- /dev/null
+++ b/test/custom-elements/samples/no-tag-warning/_config.js
@@ -0,0 +1,17 @@
+export default {
+ warnings: [{
+ code: "custom-element-no-tag",
+ message: "No custom element 'tag' option was specified. To automatically register a custom element, specify a name with a hyphen in it, e.g. . To hide this warning, use ",
+ pos: 0,
+ start: {
+ character: 0,
+ column: 0,
+ line: 1
+ },
+ end: {
+ character: 18,
+ column: 18,
+ line: 1
+ }
+ }]
+};
diff --git a/test/custom-elements/samples/no-tag-warning/main.svelte b/test/custom-elements/samples/no-tag-warning/main.svelte
new file mode 100644
index 0000000000..4f7cdc52ca
--- /dev/null
+++ b/test/custom-elements/samples/no-tag-warning/main.svelte
@@ -0,0 +1,7 @@
+
+
+
+
+Hello {name}!
diff --git a/test/custom-elements/samples/no-tag-warning/test.js b/test/custom-elements/samples/no-tag-warning/test.js
new file mode 100644
index 0000000000..c77f035088
--- /dev/null
+++ b/test/custom-elements/samples/no-tag-warning/test.js
@@ -0,0 +1,12 @@
+import * as assert from 'assert';
+import CustomElement from './main.svelte';
+
+export default function (target) {
+ customElements.define('no-tag', CustomElement);
+ target.innerHTML = ` `;
+
+ const el = target.querySelector('no-tag');
+ const h1 = el.shadowRoot.querySelector('h1');
+
+ assert.equal(h1.textContent, 'Hello world!');
+}
diff --git a/test/custom-elements/samples/no-tag/_config.js b/test/custom-elements/samples/no-tag/_config.js
new file mode 100644
index 0000000000..c81f1a9f82
--- /dev/null
+++ b/test/custom-elements/samples/no-tag/_config.js
@@ -0,0 +1,3 @@
+export default {
+ warnings: []
+};
diff --git a/test/custom-elements/samples/no-tag/main.svelte b/test/custom-elements/samples/no-tag/main.svelte
new file mode 100644
index 0000000000..031bd93694
--- /dev/null
+++ b/test/custom-elements/samples/no-tag/main.svelte
@@ -0,0 +1,7 @@
+
+
+
+
+Hello {name}!
diff --git a/test/custom-elements/samples/no-tag/test.js b/test/custom-elements/samples/no-tag/test.js
new file mode 100644
index 0000000000..c77f035088
--- /dev/null
+++ b/test/custom-elements/samples/no-tag/test.js
@@ -0,0 +1,12 @@
+import * as assert from 'assert';
+import CustomElement from './main.svelte';
+
+export default function (target) {
+ customElements.define('no-tag', CustomElement);
+ target.innerHTML = ` `;
+
+ const el = target.querySelector('no-tag');
+ const h1 = el.shadowRoot.querySelector('h1');
+
+ assert.equal(h1.textContent, 'Hello world!');
+}
diff --git a/test/helpers.js b/test/helpers.js
index e07d7c9b06..514d084698 100644
--- a/test/helpers.js
+++ b/test/helpers.js
@@ -28,7 +28,7 @@ export function exists(path) {
export function tryToLoadJson(file) {
try {
- return JSON.parse(fs.readFileSync(file));
+ return JSON.parse(fs.readFileSync(file, 'utf-8'));
} catch (err) {
if (err.code !== 'ENOENT') throw err;
return null;
@@ -44,14 +44,21 @@ export function tryToReadFile(file) {
}
}
-export const virtualConsole = new jsdom.VirtualConsole();
-const { window } = new jsdom.JSDOM(' ', {virtualConsole});
+const virtualConsole = new jsdom.VirtualConsole();
+virtualConsole.sendTo(console);
+
+global.window = new jsdom.JSDOM(' ', {virtualConsole}).window;
global.document = window.document;
-global.getComputedStyle = window.getComputedStyle;
-global.navigator = {userAgent: 'fake'};
+global.requestAnimationFrame = null; // placeholder, filled in using set_raf
+
+// add missing ecmascript globals to window
+for (const key of Object.getOwnPropertyNames(global)) {
+ window[key] = window[key] || global[key];
+}
export function env() {
window._svelteTransitionManager = null;
+ window.document.title = '';
window.document.body.innerHTML = ' ';
return window;
@@ -120,7 +127,7 @@ export function normalizeHtml(window, html) {
.replace(//g, '')
.replace(/>[\s\r\n]+<')
.trim();
- cleanChildren(node, '');
+ cleanChildren(node);
return node.innerHTML.replace(/<\/?noscript\/?>/g, '');
} catch (err) {
throw new Error(`Failed to normalize HTML:\n${html}`);
diff --git a/test/js/samples/action/expected.js b/test/js/samples/action/expected.js
index cbbcb0d317..ed0a0a7430 100644
--- a/test/js/samples/action/expected.js
+++ b/test/js/samples/action/expected.js
@@ -1,6 +1,7 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ attr,
detach,
element,
init,
@@ -16,7 +17,7 @@ function create_fragment(ctx) {
c() {
a = element("a");
a.textContent = "Test";
- a.href = "#";
+ attr(a, "href", "#");
},
m(target, anchor) {
diff --git a/test/js/samples/bind-open/expected.js b/test/js/samples/bind-open/expected.js
new file mode 100644
index 0000000000..7f739aec8b
--- /dev/null
+++ b/test/js/samples/bind-open/expected.js
@@ -0,0 +1,69 @@
+/* generated by Svelte vX.Y.Z */
+import {
+ SvelteComponent,
+ detach,
+ element,
+ init,
+ insert,
+ listen,
+ noop,
+ safe_not_equal
+} from "svelte/internal";
+
+function create_fragment(ctx) {
+ var details, dispose;
+
+ return {
+ c() {
+ details = element("details");
+ details.innerHTML = `summary content
+ `;
+ dispose = listen(details, "toggle", ctx.details_toggle_handler);
+ },
+
+ m(target, anchor) {
+ insert(target, details, anchor);
+
+ details.open = ctx.open;
+ },
+
+ p(changed, ctx) {
+ if (changed.open) details.open = ctx.open;
+ },
+
+ i: noop,
+ o: noop,
+
+ d(detaching) {
+ if (detaching) {
+ detach(details);
+ }
+
+ dispose();
+ }
+ };
+}
+
+function instance($$self, $$props, $$invalidate) {
+ let { open } = $$props;
+
+ function details_toggle_handler() {
+ open = this.open;
+ $$invalidate('open', open);
+ }
+
+ $$self.$set = $$props => {
+ if ('open' in $$props) $$invalidate('open', open = $$props.open);
+ };
+
+ return { open, details_toggle_handler };
+}
+
+class Component extends SvelteComponent {
+ constructor(options) {
+ super();
+ init(this, options, instance, create_fragment, safe_not_equal, ["open"]);
+ }
+}
+
+export default Component;
\ No newline at end of file
diff --git a/test/js/samples/bind-open/input.svelte b/test/js/samples/bind-open/input.svelte
new file mode 100644
index 0000000000..3dd2b03a73
--- /dev/null
+++ b/test/js/samples/bind-open/input.svelte
@@ -0,0 +1,7 @@
+
+
+
+ summary content
+
diff --git a/test/js/samples/collapses-text-around-comments/expected.js b/test/js/samples/collapses-text-around-comments/expected.js
index 12164d0579..09b40a1e98 100644
--- a/test/js/samples/collapses-text-around-comments/expected.js
+++ b/test/js/samples/collapses-text-around-comments/expected.js
@@ -2,6 +2,7 @@
import {
SvelteComponent,
append,
+ attr,
detach,
element,
init,
@@ -26,7 +27,7 @@ function create_fragment(ctx) {
c() {
p = element("p");
t = text(ctx.foo);
- p.className = "svelte-1a7i8ec";
+ attr(p, "class", "svelte-1a7i8ec");
},
m(target, anchor) {
diff --git a/test/js/samples/component-static-array/expected.js b/test/js/samples/component-static-array/expected.js
index 875c741076..6997f431dd 100644
--- a/test/js/samples/component-static-array/expected.js
+++ b/test/js/samples/component-static-array/expected.js
@@ -1,10 +1,13 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ destroy_component,
init,
mount_component,
noop,
- safe_not_equal
+ safe_not_equal,
+ transition_in,
+ transition_out
} from "svelte/internal";
function create_fragment(ctx) {
@@ -26,18 +29,18 @@ function create_fragment(ctx) {
i(local) {
if (current) return;
- nested.$$.fragment.i(local);
+ transition_in(nested.$$.fragment, local);
current = true;
},
o(local) {
- nested.$$.fragment.o(local);
+ transition_out(nested.$$.fragment, local);
current = false;
},
d(detaching) {
- nested.$destroy(detaching);
+ destroy_component(nested, detaching);
}
};
}
diff --git a/test/js/samples/component-static-immutable/expected.js b/test/js/samples/component-static-immutable/expected.js
index 6612a7f1b6..4b33d537ca 100644
--- a/test/js/samples/component-static-immutable/expected.js
+++ b/test/js/samples/component-static-immutable/expected.js
@@ -1,10 +1,13 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ destroy_component,
init,
mount_component,
noop,
- not_equal
+ not_equal,
+ transition_in,
+ transition_out
} from "svelte/internal";
function create_fragment(ctx) {
@@ -26,18 +29,18 @@ function create_fragment(ctx) {
i(local) {
if (current) return;
- nested.$$.fragment.i(local);
+ transition_in(nested.$$.fragment, local);
current = true;
},
o(local) {
- nested.$$.fragment.o(local);
+ transition_out(nested.$$.fragment, local);
current = false;
},
d(detaching) {
- nested.$destroy(detaching);
+ destroy_component(nested, detaching);
}
};
}
diff --git a/test/js/samples/component-static-immutable2/expected.js b/test/js/samples/component-static-immutable2/expected.js
index 6612a7f1b6..4b33d537ca 100644
--- a/test/js/samples/component-static-immutable2/expected.js
+++ b/test/js/samples/component-static-immutable2/expected.js
@@ -1,10 +1,13 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ destroy_component,
init,
mount_component,
noop,
- not_equal
+ not_equal,
+ transition_in,
+ transition_out
} from "svelte/internal";
function create_fragment(ctx) {
@@ -26,18 +29,18 @@ function create_fragment(ctx) {
i(local) {
if (current) return;
- nested.$$.fragment.i(local);
+ transition_in(nested.$$.fragment, local);
current = true;
},
o(local) {
- nested.$$.fragment.o(local);
+ transition_out(nested.$$.fragment, local);
current = false;
},
d(detaching) {
- nested.$destroy(detaching);
+ destroy_component(nested, detaching);
}
};
}
diff --git a/test/js/samples/component-static/expected.js b/test/js/samples/component-static/expected.js
index 12ebeb28b7..5a031a32a4 100644
--- a/test/js/samples/component-static/expected.js
+++ b/test/js/samples/component-static/expected.js
@@ -1,10 +1,13 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ destroy_component,
init,
mount_component,
noop,
- safe_not_equal
+ safe_not_equal,
+ transition_in,
+ transition_out
} from "svelte/internal";
function create_fragment(ctx) {
@@ -26,18 +29,18 @@ function create_fragment(ctx) {
i(local) {
if (current) return;
- nested.$$.fragment.i(local);
+ transition_in(nested.$$.fragment, local);
current = true;
},
o(local) {
- nested.$$.fragment.o(local);
+ transition_out(nested.$$.fragment, local);
current = false;
},
d(detaching) {
- nested.$destroy(detaching);
+ destroy_component(nested, detaching);
}
};
}
diff --git a/test/js/samples/css-media-query/expected.js b/test/js/samples/css-media-query/expected.js
index d4be134376..82b7c5dfc8 100644
--- a/test/js/samples/css-media-query/expected.js
+++ b/test/js/samples/css-media-query/expected.js
@@ -2,6 +2,7 @@
import {
SvelteComponent,
append,
+ attr,
detach,
element,
init,
@@ -23,7 +24,7 @@ function create_fragment(ctx) {
return {
c() {
div = element("div");
- div.className = "svelte-1slhpfn";
+ attr(div, "class", "svelte-1slhpfn");
},
m(target, anchor) {
diff --git a/test/js/samples/debug-empty/expected.js b/test/js/samples/debug-empty/expected.js
index 98c2837ab7..6f07993590 100644
--- a/test/js/samples/debug-empty/expected.js
+++ b/test/js/samples/debug-empty/expected.js
@@ -65,6 +65,11 @@ function create_fragment(ctx) {
function instance($$self, $$props, $$invalidate) {
let { name } = $$props;
+ const writable_props = ['name'];
+ Object.keys($$props).forEach(key => {
+ if (!writable_props.includes(key) && !key.startsWith('$$')) console.warn(` was created with unknown prop '${key}'`);
+ });
+
$$self.$set = $$props => {
if ('name' in $$props) $$invalidate('name', name = $$props.name);
};
diff --git a/test/js/samples/debug-foo-bar-baz-things/expected.js b/test/js/samples/debug-foo-bar-baz-things/expected.js
index c1391475b2..eea35d5ba7 100644
--- a/test/js/samples/debug-foo-bar-baz-things/expected.js
+++ b/test/js/samples/debug-foo-bar-baz-things/expected.js
@@ -151,6 +151,11 @@ function create_fragment(ctx) {
function instance($$self, $$props, $$invalidate) {
let { things, foo, bar, baz } = $$props;
+ const writable_props = ['things', 'foo', 'bar', 'baz'];
+ Object.keys($$props).forEach(key => {
+ if (!writable_props.includes(key) && !key.startsWith('$$')) console.warn(` was created with unknown prop '${key}'`);
+ });
+
$$self.$set = $$props => {
if ('things' in $$props) $$invalidate('things', things = $$props.things);
if ('foo' in $$props) $$invalidate('foo', foo = $$props.foo);
diff --git a/test/js/samples/debug-foo/expected.js b/test/js/samples/debug-foo/expected.js
index f5daa7dad7..5b931d9464 100644
--- a/test/js/samples/debug-foo/expected.js
+++ b/test/js/samples/debug-foo/expected.js
@@ -151,6 +151,11 @@ function create_fragment(ctx) {
function instance($$self, $$props, $$invalidate) {
let { things, foo } = $$props;
+ const writable_props = ['things', 'foo'];
+ Object.keys($$props).forEach(key => {
+ if (!writable_props.includes(key) && !key.startsWith('$$')) console.warn(` was created with unknown prop '${key}'`);
+ });
+
$$self.$set = $$props => {
if ('things' in $$props) $$invalidate('things', things = $$props.things);
if ('foo' in $$props) $$invalidate('foo', foo = $$props.foo);
diff --git a/test/js/samples/debug-hoisted/_config.js b/test/js/samples/debug-hoisted/_config.js
new file mode 100644
index 0000000000..414b026a97
--- /dev/null
+++ b/test/js/samples/debug-hoisted/_config.js
@@ -0,0 +1,5 @@
+export default {
+ options: {
+ dev: true
+ }
+};
diff --git a/test/js/samples/debug-hoisted/expected.js b/test/js/samples/debug-hoisted/expected.js
new file mode 100644
index 0000000000..51d8bf63a3
--- /dev/null
+++ b/test/js/samples/debug-hoisted/expected.js
@@ -0,0 +1,56 @@
+/* generated by Svelte vX.Y.Z */
+import {
+ SvelteComponentDev,
+ init,
+ noop,
+ safe_not_equal
+} from "svelte/internal";
+
+const file = undefined;
+
+function create_fragment(ctx) {
+ return {
+ c: function create() {
+ {
+ const { obj } = ctx;
+ console.log({ obj, kobzol });
+ debugger;
+ }
+ },
+
+ l: function claim(nodes) {
+ throw new Error("options.hydrate only works if the component was compiled with the `hydratable: true` option");
+ },
+
+ m: noop,
+
+ p: function update(changed, ctx) {
+ if (changed.obj || changed.kobzol) {
+ const { obj } = ctx;
+ console.log({ obj, kobzol });
+ debugger;
+ }
+ },
+
+ i: noop,
+ o: noop,
+ d: noop
+ };
+}
+
+let kobzol = 5;
+
+function instance($$self) {
+ let obj = { x: 5 };
+
+ return { obj };
+}
+
+class Component extends SvelteComponentDev {
+ constructor(options) {
+ super(options);
+ init(this, options, instance, create_fragment, safe_not_equal, []);
+ }
+}
+
+export default Component;
\ No newline at end of file
diff --git a/test/js/samples/debug-hoisted/input.svelte b/test/js/samples/debug-hoisted/input.svelte
new file mode 100644
index 0000000000..94d584ccac
--- /dev/null
+++ b/test/js/samples/debug-hoisted/input.svelte
@@ -0,0 +1,6 @@
+
+
+{@debug obj, kobzol}
diff --git a/test/js/samples/dev-warning-missing-data-computed/expected.js b/test/js/samples/dev-warning-missing-data-computed/expected.js
index 12e8a983d0..5c4b2ece1b 100644
--- a/test/js/samples/dev-warning-missing-data-computed/expected.js
+++ b/test/js/samples/dev-warning-missing-data-computed/expected.js
@@ -65,6 +65,11 @@ function instance($$self, $$props, $$invalidate) {
let bar;
+ const writable_props = ['foo'];
+ Object.keys($$props).forEach(key => {
+ if (!writable_props.includes(key) && !key.startsWith('$$')) console.warn(` was created with unknown prop '${key}'`);
+ });
+
$$self.$set = $$props => {
if ('foo' in $$props) $$invalidate('foo', foo = $$props.foo);
};
diff --git a/test/js/samples/dynamic-import/expected.js b/test/js/samples/dynamic-import/expected.js
index 2d51bcf60d..9a6a67bcd9 100644
--- a/test/js/samples/dynamic-import/expected.js
+++ b/test/js/samples/dynamic-import/expected.js
@@ -1,10 +1,13 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ destroy_component,
init,
mount_component,
noop,
- safe_not_equal
+ safe_not_equal,
+ transition_in,
+ transition_out
} from "svelte/internal";
import LazyLoad from "./LazyLoad.svelte";
@@ -27,18 +30,18 @@ function create_fragment(ctx) {
i(local) {
if (current) return;
- lazyload.$$.fragment.i(local);
+ transition_in(lazyload.$$.fragment, local);
current = true;
},
o(local) {
- lazyload.$$.fragment.o(local);
+ transition_out(lazyload.$$.fragment, local);
current = false;
},
d(detaching) {
- lazyload.$destroy(detaching);
+ destroy_component(lazyload, detaching);
}
};
}
diff --git a/test/js/samples/each-block-changed-check/expected.js b/test/js/samples/each-block-changed-check/expected.js
index 951565bae4..b4d4577df3 100644
--- a/test/js/samples/each-block-changed-check/expected.js
+++ b/test/js/samples/each-block-changed-check/expected.js
@@ -2,6 +2,7 @@
import {
SvelteComponent,
append,
+ attr,
destroy_each,
detach,
detach_after,
@@ -39,8 +40,8 @@ function create_each_block(ctx) {
t5 = text(" ago:");
t6 = space();
raw_before = element('noscript');
- span.className = "meta";
- div.className = "comment";
+ attr(span, "class", "meta");
+ attr(div, "class", "comment");
},
m(target, anchor) {
diff --git a/test/js/samples/each-block-keyed-animated/expected.js b/test/js/samples/each-block-keyed-animated/expected.js
index d18c569fa1..ec28e60d5f 100644
--- a/test/js/samples/each-block-keyed-animated/expected.js
+++ b/test/js/samples/each-block-keyed-animated/expected.js
@@ -6,7 +6,7 @@ import {
detach,
element,
empty,
- fix_and_outro_and_destroy_block,
+ fix_and_destroy_block,
fix_position,
init,
insert,
@@ -100,7 +100,7 @@ function create_fragment(ctx) {
p(changed, ctx) {
const each_value = ctx.things;
for (let i = 0; i < each_blocks.length; i += 1) each_blocks[i].r();
- each_blocks = update_keyed_each(each_blocks, changed, get_key, 1, ctx, each_value, each_1_lookup, each_1_anchor.parentNode, fix_and_outro_and_destroy_block, create_each_block, each_1_anchor, get_each_context);
+ each_blocks = update_keyed_each(each_blocks, changed, get_key, 1, ctx, each_value, each_1_lookup, each_1_anchor.parentNode, fix_and_destroy_block, create_each_block, each_1_anchor, get_each_context);
for (let i = 0; i < each_blocks.length; i += 1) each_blocks[i].a();
},
diff --git a/test/js/samples/event-handler-no-passive/expected.js b/test/js/samples/event-handler-no-passive/expected.js
index 41fcbeeb2a..e8ca72c556 100644
--- a/test/js/samples/event-handler-no-passive/expected.js
+++ b/test/js/samples/event-handler-no-passive/expected.js
@@ -1,6 +1,7 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ attr,
detach,
element,
init,
@@ -17,7 +18,7 @@ function create_fragment(ctx) {
c() {
a = element("a");
a.textContent = "this should not navigate to example.com";
- a.href = "https://example.com";
+ attr(a, "href", "https://example.com");
dispose = listen(a, "touchstart", touchstart_handler);
},
diff --git a/test/js/samples/head-no-whitespace/expected.js b/test/js/samples/head-no-whitespace/expected.js
index b95177bba7..457df77dc8 100644
--- a/test/js/samples/head-no-whitespace/expected.js
+++ b/test/js/samples/head-no-whitespace/expected.js
@@ -2,6 +2,7 @@
import {
SvelteComponent,
append,
+ attr,
detach,
element,
init,
@@ -16,10 +17,10 @@ function create_fragment(ctx) {
c() {
meta0 = element("meta");
meta1 = element("meta");
- meta0.name = "twitter:creator";
- meta0.content = "@sveltejs";
- meta1.name = "twitter:title";
- meta1.content = "Svelte";
+ attr(meta0, "name", "twitter:creator");
+ attr(meta0, "content", "@sveltejs");
+ attr(meta1, "name", "twitter:title");
+ attr(meta1, "content", "Svelte");
},
m(target, anchor) {
diff --git a/test/js/samples/inline-style-unoptimized/expected.js b/test/js/samples/inline-style-unoptimized/expected.js
index 8f3b668827..9349ade12c 100644
--- a/test/js/samples/inline-style-unoptimized/expected.js
+++ b/test/js/samples/inline-style-unoptimized/expected.js
@@ -1,6 +1,7 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ attr,
detach,
element,
init,
@@ -18,8 +19,8 @@ function create_fragment(ctx) {
div0 = element("div");
t = space();
div1 = element("div");
- div0.style.cssText = ctx.style;
- div1.style.cssText = div1_style_value = "" + ctx.key + ": " + ctx.value;
+ attr(div0, "style", ctx.style);
+ attr(div1, "style", div1_style_value = "" + ctx.key + ": " + ctx.value);
},
m(target, anchor) {
@@ -30,11 +31,11 @@ function create_fragment(ctx) {
p(changed, ctx) {
if (changed.style) {
- div0.style.cssText = ctx.style;
+ attr(div0, "style", ctx.style);
}
if ((changed.key || changed.value) && div1_style_value !== (div1_style_value = "" + ctx.key + ": " + ctx.value)) {
- div1.style.cssText = div1_style_value;
+ attr(div1, "style", div1_style_value);
}
},
diff --git a/test/js/samples/media-bindings/expected.js b/test/js/samples/media-bindings/expected.js
index 8a193f698b..f45f9ce8db 100644
--- a/test/js/samples/media-bindings/expected.js
+++ b/test/js/samples/media-bindings/expected.js
@@ -8,6 +8,7 @@ import {
insert,
listen,
noop,
+ raf,
run_all,
safe_not_equal,
time_ranges_to_array
@@ -18,7 +19,7 @@ function create_fragment(ctx) {
function audio_timeupdate_handler() {
cancelAnimationFrame(audio_animationframe);
- if (!audio.paused) audio_animationframe = requestAnimationFrame(audio_timeupdate_handler);
+ if (!audio.paused) audio_animationframe = raf(audio_timeupdate_handler);
audio_updating = true;
ctx.audio_timeupdate_handler.call(audio);
}
diff --git a/test/js/samples/non-imported-component/expected.js b/test/js/samples/non-imported-component/expected.js
index 20ac461c76..42a21aa496 100644
--- a/test/js/samples/non-imported-component/expected.js
+++ b/test/js/samples/non-imported-component/expected.js
@@ -1,13 +1,16 @@
/* generated by Svelte vX.Y.Z */
import {
SvelteComponent,
+ destroy_component,
detach,
init,
insert,
mount_component,
noop,
safe_not_equal,
- space
+ space,
+ transition_in,
+ transition_out
} from "svelte/internal";
import Imported from "Imported.svelte";
@@ -36,27 +39,27 @@ function create_fragment(ctx) {
i(local) {
if (current) return;
- imported.$$.fragment.i(local);
+ transition_in(imported.$$.fragment, local);
- nonimported.$$.fragment.i(local);
+ transition_in(nonimported.$$.fragment, local);
current = true;
},
o(local) {
- imported.$$.fragment.o(local);
- nonimported.$$.fragment.o(local);
+ transition_out(imported.$$.fragment, local);
+ transition_out(nonimported.$$.fragment, local);
current = false;
},
d(detaching) {
- imported.$destroy(detaching);
+ destroy_component(imported, detaching);
if (detaching) {
detach(t);
}
- nonimported.$destroy(detaching);
+ destroy_component(nonimported, detaching);
}
};
}
diff --git a/test/js/samples/reactive-values-non-topologically-ordered/expected.js b/test/js/samples/reactive-values-non-topologically-ordered/expected.js
index 2f729362b0..b5e2b04f75 100644
--- a/test/js/samples/reactive-values-non-topologically-ordered/expected.js
+++ b/test/js/samples/reactive-values-non-topologically-ordered/expected.js
@@ -29,7 +29,7 @@ function instance($$self, $$props, $$invalidate) {
$$self.$$.update = ($$dirty = { x: 1, b: 1 }) => {
if ($$dirty.x) { $$invalidate('b', b = x); }
- if ($$dirty.b) { $$invalidate('a', a = b); }
+ if ($$dirty.b) { a = b; }
};
return { x };
diff --git a/test/js/samples/reactive-values-non-writable-dependencies/expected.js b/test/js/samples/reactive-values-non-writable-dependencies/expected.js
index 62057cc6f0..8958f1ffbc 100644
--- a/test/js/samples/reactive-values-non-writable-dependencies/expected.js
+++ b/test/js/samples/reactive-values-non-writable-dependencies/expected.js
@@ -17,26 +17,25 @@ function create_fragment(ctx) {
};
}
-let a = 1;
-
-let b = 2;
-
function instance($$self, $$props, $$invalidate) {
-
+ let { a = 1, b = 2 } = $$props;
- let max;
+ $$self.$set = $$props => {
+ if ('a' in $$props) $$invalidate('a', a = $$props.a);
+ if ('b' in $$props) $$invalidate('b', b = $$props.b);
+ };
$$self.$$.update = ($$dirty = { a: 1, b: 1 }) => {
- if ($$dirty.a || $$dirty.b) { $$invalidate('max', max = Math.max(a, b)); }
+ if ($$dirty.a || $$dirty.b) { console.log('max', Math.max(a, b)); }
};
- return {};
+ return { a, b };
}
class Component extends SvelteComponent {
constructor(options) {
super();
- init(this, options, instance, create_fragment, safe_not_equal, []);
+ init(this, options, instance, create_fragment, safe_not_equal, ["a", "b"]);
}
}
diff --git a/test/js/samples/reactive-values-non-writable-dependencies/input.svelte b/test/js/samples/reactive-values-non-writable-dependencies/input.svelte
index 8e3397e40d..3fb70d5e8f 100644
--- a/test/js/samples/reactive-values-non-writable-dependencies/input.svelte
+++ b/test/js/samples/reactive-values-non-writable-dependencies/input.svelte
@@ -1,7 +1,6 @@
\ No newline at end of file
diff --git a/test/js/samples/transition-local/expected.js b/test/js/samples/transition-local/expected.js
index 2df99a4c87..53bce5f5d0 100644
--- a/test/js/samples/transition-local/expected.js
+++ b/test/js/samples/transition-local/expected.js
@@ -9,7 +9,8 @@ import {
init,
insert,
noop,
- safe_not_equal
+ safe_not_equal,
+ transition_in
} from "svelte/internal";
// (8:0) {#if x}
@@ -34,10 +35,10 @@ function create_if_block(ctx) {
if (!if_block) {
if_block = create_if_block_1(ctx);
if_block.c();
- if_block.i(1);
+ transition_in(if_block, 1);
if_block.m(if_block_anchor.parentNode, if_block_anchor);
} else {
- if_block.i(1);
+ transition_in(if_block, 1);
}
} else if (if_block) {
if_block.d(1);
diff --git a/test/js/samples/transition-repeated-outro/expected.js b/test/js/samples/transition-repeated-outro/expected.js
new file mode 100644
index 0000000000..959bd47201
--- /dev/null
+++ b/test/js/samples/transition-repeated-outro/expected.js
@@ -0,0 +1,129 @@
+/* generated by Svelte vX.Y.Z */
+import {
+ SvelteComponent,
+ check_outros,
+ create_out_transition,
+ detach,
+ element,
+ empty,
+ group_outros,
+ init,
+ insert,
+ safe_not_equal,
+ transition_in,
+ transition_out
+} from "svelte/internal";
+import { fade } from "svelte/transition";
+
+// (7:0) {#if num < 5}
+function create_if_block(ctx) {
+ var div, div_outro, current;
+
+ return {
+ c() {
+ div = element("div");
+ div.innerHTML = `wheeee
`;
+ },
+
+ m(target, anchor) {
+ insert(target, div, anchor);
+ current = true;
+ },
+
+ i(local) {
+ if (current) return;
+ if (div_outro) div_outro.end(1);
+
+ current = true;
+ },
+
+ o(local) {
+ div_outro = create_out_transition(div, fade, {});
+
+ current = false;
+ },
+
+ d(detaching) {
+ if (detaching) {
+ detach(div);
+ if (div_outro) div_outro.end();
+ }
+ }
+ };
+}
+
+function create_fragment(ctx) {
+ var if_block_anchor, current;
+
+ var if_block = (ctx.num < 5) && create_if_block(ctx);
+
+ return {
+ c() {
+ if (if_block) if_block.c();
+ if_block_anchor = empty();
+ },
+
+ m(target, anchor) {
+ if (if_block) if_block.m(target, anchor);
+ insert(target, if_block_anchor, anchor);
+ current = true;
+ },
+
+ p(changed, ctx) {
+ if (ctx.num < 5) {
+ if (!if_block) {
+ if_block = create_if_block(ctx);
+ if_block.c();
+ transition_in(if_block, 1);
+ if_block.m(if_block_anchor.parentNode, if_block_anchor);
+ } else {
+ transition_in(if_block, 1);
+ }
+ } else if (if_block) {
+ group_outros();
+ transition_out(if_block, 1, () => {
+ if_block = null;
+ });
+ check_outros();
+ }
+ },
+
+ i(local) {
+ if (current) return;
+ transition_in(if_block);
+ current = true;
+ },
+
+ o(local) {
+ transition_out(if_block);
+ current = false;
+ },
+
+ d(detaching) {
+ if (if_block) if_block.d(detaching);
+
+ if (detaching) {
+ detach(if_block_anchor);
+ }
+ }
+ };
+}
+
+function instance($$self, $$props, $$invalidate) {
+ let { num = 1 } = $$props;
+
+ $$self.$set = $$props => {
+ if ('num' in $$props) $$invalidate('num', num = $$props.num);
+ };
+
+ return { num };
+}
+
+class Component extends SvelteComponent {
+ constructor(options) {
+ super();
+ init(this, options, instance, create_fragment, safe_not_equal, ["num"]);
+ }
+}
+
+export default Component;
\ No newline at end of file
diff --git a/test/js/samples/transition-repeated-outro/input.svelte b/test/js/samples/transition-repeated-outro/input.svelte
new file mode 100644
index 0000000000..d5114846b8
--- /dev/null
+++ b/test/js/samples/transition-repeated-outro/input.svelte
@@ -0,0 +1,11 @@
+
+
+{#if num < 5}
+
+{/if}
\ No newline at end of file
diff --git a/test/js/samples/unreferenced-state-not-invalidated/expected.js b/test/js/samples/unreferenced-state-not-invalidated/expected.js
new file mode 100644
index 0000000000..17b5638a84
--- /dev/null
+++ b/test/js/samples/unreferenced-state-not-invalidated/expected.js
@@ -0,0 +1,78 @@
+/* generated by Svelte vX.Y.Z */
+import {
+ SvelteComponent,
+ append,
+ detach,
+ element,
+ init,
+ insert,
+ noop,
+ safe_not_equal,
+ set_data,
+ text
+} from "svelte/internal";
+import { onMount } from "svelte";
+
+function create_fragment(ctx) {
+ var p, t;
+
+ return {
+ c() {
+ p = element("p");
+ t = text(ctx.y);
+ },
+
+ m(target, anchor) {
+ insert(target, p, anchor);
+ append(p, t);
+ },
+
+ p(changed, ctx) {
+ if (changed.y) {
+ set_data(t, ctx.y);
+ }
+ },
+
+ i: noop,
+ o: noop,
+
+ d(detaching) {
+ if (detaching) {
+ detach(p);
+ }
+ }
+ };
+}
+
+function instance($$self, $$props, $$invalidate) {
+ let a, b, c;
+
+ onMount(() => {
+ const interval = setInterval(() => {
+ $$invalidate('b', b += 1);
+ c += 1;
+
+ console.log(b, c);
+ }, 1000);
+
+ return () => clearInterval(interval);
+ });
+
+ let x, y;
+
+ $$self.$$.update = ($$dirty = { a: 1, b: 1 }) => {
+ if ($$dirty.a) { x = a * 2; }
+ if ($$dirty.b) { $$invalidate('y', y = b * 2); }
+ };
+
+ return { y };
+}
+
+class Component extends SvelteComponent {
+ constructor(options) {
+ super();
+ init(this, options, instance, create_fragment, safe_not_equal, []);
+ }
+}
+
+export default Component;
\ No newline at end of file
diff --git a/test/js/samples/unreferenced-state-not-invalidated/input.svelte b/test/js/samples/unreferenced-state-not-invalidated/input.svelte
new file mode 100644
index 0000000000..fff60f181d
--- /dev/null
+++ b/test/js/samples/unreferenced-state-not-invalidated/input.svelte
@@ -0,0 +1,21 @@
+
+
+{y}
\ No newline at end of file
diff --git a/test/js/samples/window-binding-scroll/expected.js b/test/js/samples/window-binding-scroll/expected.js
index 18f5210bea..fbe4596e2b 100644
--- a/test/js/samples/window-binding-scroll/expected.js
+++ b/test/js/samples/window-binding-scroll/expected.js
@@ -42,7 +42,7 @@ function create_fragment(ctx) {
if (changed.y && !scrolling) {
scrolling = true;
clearTimeout(scrolling_timeout);
- window.scrollTo(window.pageXOffset, ctx.y);
+ scrollTo(window.pageXOffset, ctx.y);
scrolling_timeout = setTimeout(clear_scrolling, 100);
}
diff --git a/test/parser/samples/action-with-call/output.json b/test/parser/samples/action-with-call/output.json
index d6aaa72892..e910f0b49f 100644
--- a/test/parser/samples/action-with-call/output.json
+++ b/test/parser/samples/action-with-call/output.json
@@ -41,8 +41,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/action-with-identifier/output.json b/test/parser/samples/action-with-identifier/output.json
index d58b9097b7..435aee4444 100644
--- a/test/parser/samples/action-with-identifier/output.json
+++ b/test/parser/samples/action-with-identifier/output.json
@@ -27,8 +27,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/action-with-literal/output.json b/test/parser/samples/action-with-literal/output.json
index 4a6f596d10..01a6b67549 100644
--- a/test/parser/samples/action-with-literal/output.json
+++ b/test/parser/samples/action-with-literal/output.json
@@ -28,8 +28,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/action/output.json b/test/parser/samples/action/output.json
index 2f553b5efa..9828e200dd 100644
--- a/test/parser/samples/action/output.json
+++ b/test/parser/samples/action/output.json
@@ -22,8 +22,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/animation/output.json b/test/parser/samples/animation/output.json
index 8332b3ad04..f4d183eb5c 100644
--- a/test/parser/samples/animation/output.json
+++ b/test/parser/samples/animation/output.json
@@ -35,6 +35,7 @@
"start": 51,
"end": 56,
"type": "Text",
+ "raw": "flips",
"data": "flips"
}
]
@@ -54,8 +55,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-containing-solidus/output.json b/test/parser/samples/attribute-containing-solidus/output.json
index 95372bd77d..f1158b4f50 100644
--- a/test/parser/samples/attribute-containing-solidus/output.json
+++ b/test/parser/samples/attribute-containing-solidus/output.json
@@ -20,6 +20,7 @@
"start": 8,
"end": 30,
"type": "Text",
+ "raw": "https://www.google.com",
"data": "https://www.google.com"
}
]
@@ -30,13 +31,11 @@
"start": 31,
"end": 37,
"type": "Text",
+ "raw": "Google",
"data": "Google"
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-dynamic-boolean/output.json b/test/parser/samples/attribute-dynamic-boolean/output.json
index 81a19f49b9..478144152a 100644
--- a/test/parser/samples/attribute-dynamic-boolean/output.json
+++ b/test/parser/samples/attribute-dynamic-boolean/output.json
@@ -33,8 +33,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-dynamic-reserved/output.json b/test/parser/samples/attribute-dynamic-reserved/output.json
index 3a830d448f..22be3c9087 100644
--- a/test/parser/samples/attribute-dynamic-reserved/output.json
+++ b/test/parser/samples/attribute-dynamic-reserved/output.json
@@ -33,8 +33,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-dynamic/output.json b/test/parser/samples/attribute-dynamic/output.json
index 50d8ec60a5..a48f376876 100644
--- a/test/parser/samples/attribute-dynamic/output.json
+++ b/test/parser/samples/attribute-dynamic/output.json
@@ -18,8 +18,9 @@
"value": [
{
"start": 12,
- "end": 19,
+ "end": 20,
"type": "Text",
+ "raw": "color: ",
"data": "color: "
},
{
@@ -37,6 +38,7 @@
"start": 26,
"end": 27,
"type": "Text",
+ "raw": ";",
"data": ";"
}
]
@@ -57,8 +59,5 @@
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-escaped/input.svelte b/test/parser/samples/attribute-escaped/input.svelte
index 82186dcee4..4c9cd5ff68 100644
--- a/test/parser/samples/attribute-escaped/input.svelte
+++ b/test/parser/samples/attribute-escaped/input.svelte
@@ -1 +1 @@
-
+
diff --git a/test/parser/samples/attribute-escaped/output.json b/test/parser/samples/attribute-escaped/output.json
index 6a4143e674..a8498bd574 100644
--- a/test/parser/samples/attribute-escaped/output.json
+++ b/test/parser/samples/attribute-escaped/output.json
@@ -1,26 +1,27 @@
{
"html": {
"start": 0,
- "end": 41,
+ "end": 83,
"type": "Fragment",
"children": [
{
"start": 0,
- "end": 41,
+ "end": 83,
"type": "Element",
"name": "div",
"attributes": [
{
"start": 5,
- "end": 34,
+ "end": 76,
"type": "Attribute",
"name": "data-foo",
"value": [
{
"start": 15,
- "end": 33,
+ "end": 75,
"type": "Text",
- "data": "\"quoted\""
+ "raw": "semi:"space:" letter:"e number:"1 end:"",
+ "data": "semi:\"space:\" letter:"e number:"1 end:\""
}
]
}
@@ -28,8 +29,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-multiple/output.json b/test/parser/samples/attribute-multiple/output.json
index 668409c0ef..c4be13e6ee 100644
--- a/test/parser/samples/attribute-multiple/output.json
+++ b/test/parser/samples/attribute-multiple/output.json
@@ -20,6 +20,7 @@
"start": 9,
"end": 10,
"type": "Text",
+ "raw": "x",
"data": "x"
}
]
@@ -34,6 +35,7 @@
"start": 19,
"end": 20,
"type": "Text",
+ "raw": "y",
"data": "y"
}
]
@@ -42,8 +44,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-shorthand/output.json b/test/parser/samples/attribute-shorthand/output.json
index 08ddf5eda9..f23e62b04e 100644
--- a/test/parser/samples/attribute-shorthand/output.json
+++ b/test/parser/samples/attribute-shorthand/output.json
@@ -33,8 +33,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-static-boolean/output.json b/test/parser/samples/attribute-static-boolean/output.json
index f63b5734e0..7d635004c1 100644
--- a/test/parser/samples/attribute-static-boolean/output.json
+++ b/test/parser/samples/attribute-static-boolean/output.json
@@ -21,8 +21,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-static/output.json b/test/parser/samples/attribute-static/output.json
index 3185e48736..37b41d9a89 100644
--- a/test/parser/samples/attribute-static/output.json
+++ b/test/parser/samples/attribute-static/output.json
@@ -20,6 +20,7 @@
"start": 12,
"end": 15,
"type": "Text",
+ "raw": "foo",
"data": "foo"
}
]
@@ -28,8 +29,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-unquoted/output.json b/test/parser/samples/attribute-unquoted/output.json
index c7556f2eba..11fa397819 100644
--- a/test/parser/samples/attribute-unquoted/output.json
+++ b/test/parser/samples/attribute-unquoted/output.json
@@ -20,6 +20,7 @@
"start": 11,
"end": 14,
"type": "Text",
+ "raw": "foo",
"data": "foo"
}
]
@@ -28,8 +29,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/attribute-with-whitespace/input.svelte b/test/parser/samples/attribute-with-whitespace/input.svelte
new file mode 100644
index 0000000000..2743a89ed0
--- /dev/null
+++ b/test/parser/samples/attribute-with-whitespace/input.svelte
@@ -0,0 +1 @@
+Click
diff --git a/test/parser/samples/attribute-with-whitespace/output.json b/test/parser/samples/attribute-with-whitespace/output.json
new file mode 100644
index 0000000000..eab6054f2a
--- /dev/null
+++ b/test/parser/samples/attribute-with-whitespace/output.json
@@ -0,0 +1,39 @@
+{
+ "html": {
+ "start": 0,
+ "end": 38,
+ "type": "Fragment",
+ "children": [
+ {
+ "start": 0,
+ "end": 38,
+ "type": "Element",
+ "name": "button",
+ "attributes": [
+ {
+ "start": 8,
+ "end": 23,
+ "type": "EventHandler",
+ "name": "click",
+ "modifiers": [],
+ "expression": {
+ "type": "Identifier",
+ "start": 19,
+ "end": 22,
+ "name": "foo"
+ }
+ }
+ ],
+ "children": [
+ {
+ "start": 24,
+ "end": 29,
+ "type": "Text",
+ "raw": "Click",
+ "data": "Click"
+ }
+ ]
+ }
+ ]
+ }
+}
diff --git a/test/parser/samples/await-then-catch/output.json b/test/parser/samples/await-then-catch/output.json
index f62ad16574..ac598a403a 100644
--- a/test/parser/samples/await-then-catch/output.json
+++ b/test/parser/samples/await-then-catch/output.json
@@ -19,13 +19,13 @@
"pending": {
"start": 19,
"end": 39,
- "skip": false,
"type": "PendingBlock",
"children": [
{
"start": 19,
"end": 21,
"type": "Text",
+ "raw": "\n\t",
"data": "\n\t"
},
{
@@ -39,6 +39,7 @@
"start": 24,
"end": 34,
"type": "Text",
+ "raw": "loading...",
"data": "loading..."
}
]
@@ -47,20 +48,22 @@
"start": 38,
"end": 39,
"type": "Text",
+ "raw": "\n",
"data": "\n"
}
- ]
+ ],
+ "skip": false
},
"then": {
"start": 39,
"end": 88,
- "skip": false,
"type": "ThenBlock",
"children": [
{
"start": 55,
"end": 57,
"type": "Text",
+ "raw": "\n\t",
"data": "\n\t"
},
{
@@ -74,6 +77,7 @@
"start": 60,
"end": 73,
"type": "Text",
+ "raw": "the value is ",
"data": "the value is "
},
{
@@ -93,20 +97,22 @@
"start": 87,
"end": 88,
"type": "Text",
+ "raw": "\n",
"data": "\n"
}
- ]
+ ],
+ "skip": false
},
"catch": {
"start": 88,
"end": 140,
- "skip": false,
"type": "CatchBlock",
"children": [
{
"start": 105,
"end": 107,
"type": "Text",
+ "raw": "\n\t",
"data": "\n\t"
},
{
@@ -120,6 +126,7 @@
"start": 110,
"end": 117,
"type": "Text",
+ "raw": "oh no! ",
"data": "oh no! "
},
{
@@ -151,14 +158,13 @@
"start": 139,
"end": 140,
"type": "Text",
+ "raw": "\n",
"data": "\n"
}
- ]
+ ],
+ "skip": false
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
-}
+ }
+}
\ No newline at end of file
diff --git a/test/parser/samples/binding-shorthand/output.json b/test/parser/samples/binding-shorthand/output.json
index 8f92101042..7fe7acb5b3 100644
--- a/test/parser/samples/binding-shorthand/output.json
+++ b/test/parser/samples/binding-shorthand/output.json
@@ -8,6 +8,7 @@
"start": 28,
"end": 30,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
},
{
diff --git a/test/parser/samples/binding/output.json b/test/parser/samples/binding/output.json
index d084050617..72ad60202c 100644
--- a/test/parser/samples/binding/output.json
+++ b/test/parser/samples/binding/output.json
@@ -8,6 +8,7 @@
"start": 29,
"end": 31,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
},
{
diff --git a/test/parser/samples/comment/output.json b/test/parser/samples/comment/output.json
index 89295c188a..2a57c4fa5d 100644
--- a/test/parser/samples/comment/output.json
+++ b/test/parser/samples/comment/output.json
@@ -11,8 +11,5 @@
"data": " a comment "
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/component-dynamic/output.json b/test/parser/samples/component-dynamic/output.json
index c2e4e3ee79..77837d1ca9 100644
--- a/test/parser/samples/component-dynamic/output.json
+++ b/test/parser/samples/component-dynamic/output.json
@@ -36,8 +36,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/convert-entities-in-element/output.json b/test/parser/samples/convert-entities-in-element/output.json
index fb0f5b288e..c830c276de 100644
--- a/test/parser/samples/convert-entities-in-element/output.json
+++ b/test/parser/samples/convert-entities-in-element/output.json
@@ -15,13 +15,11 @@
"start": 3,
"end": 20,
"type": "Text",
+ "raw": "Hello & World",
"data": "Hello & World"
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/convert-entities/output.json b/test/parser/samples/convert-entities/output.json
index ca1c1356f8..f4cc1a6662 100644
--- a/test/parser/samples/convert-entities/output.json
+++ b/test/parser/samples/convert-entities/output.json
@@ -8,11 +8,9 @@
"start": 0,
"end": 17,
"type": "Text",
+ "raw": "Hello & World",
"data": "Hello & World"
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/css/output.json b/test/parser/samples/css/output.json
index 3127e01c71..12d74ae7f8 100644
--- a/test/parser/samples/css/output.json
+++ b/test/parser/samples/css/output.json
@@ -15,6 +15,7 @@
"start": 5,
"end": 8,
"type": "Text",
+ "raw": "foo",
"data": "foo"
}
]
@@ -23,6 +24,7 @@
"start": 14,
"end": 16,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
}
]
@@ -90,7 +92,5 @@
"end": 48,
"styles": "\n\tdiv {\n\t\tcolor: red;\n\t}\n"
}
- },
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/dynamic-import/output.json b/test/parser/samples/dynamic-import/output.json
index c0d4a45e0d..fa1acf7d9b 100644
--- a/test/parser/samples/dynamic-import/output.json
+++ b/test/parser/samples/dynamic-import/output.json
@@ -5,7 +5,6 @@
"type": "Fragment",
"children": []
},
- "css": null,
"instance": {
"start": 0,
"end": 146,
@@ -66,8 +65,8 @@
"start": 54,
"end": 134,
"id": null,
- "generator": false,
"expression": false,
+ "generator": false,
"async": false,
"params": [],
"body": {
@@ -120,8 +119,8 @@
"start": 88,
"end": 129,
"id": null,
- "generator": false,
"expression": false,
+ "generator": false,
"async": false,
"params": [
{
diff --git a/test/parser/samples/each-block-destructured/output.json b/test/parser/samples/each-block-destructured/output.json
index 0c4b1a5c54..6368b445d6 100644
--- a/test/parser/samples/each-block-destructured/output.json
+++ b/test/parser/samples/each-block-destructured/output.json
@@ -37,6 +37,7 @@
"start": 50,
"end": 52,
"type": "Text",
+ "raw": ": ",
"data": ": "
},
{
@@ -80,8 +81,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
-}
+ }
+}
\ No newline at end of file
diff --git a/test/parser/samples/each-block-else/output.json b/test/parser/samples/each-block-else/output.json
index aefc8c2f39..1e8ac455e6 100644
--- a/test/parser/samples/each-block-else/output.json
+++ b/test/parser/samples/each-block-else/output.json
@@ -58,6 +58,7 @@
"start": 55,
"end": 65,
"type": "Text",
+ "raw": "no animals",
"data": "no animals"
}
]
@@ -66,8 +67,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/each-block-indexed/output.json b/test/parser/samples/each-block-indexed/output.json
index 7518652468..77417ba67a 100644
--- a/test/parser/samples/each-block-indexed/output.json
+++ b/test/parser/samples/each-block-indexed/output.json
@@ -37,6 +37,7 @@
"start": 36,
"end": 38,
"type": "Text",
+ "raw": ": ",
"data": ": "
},
{
@@ -62,8 +63,5 @@
"index": "i"
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/each-block-keyed/output.json b/test/parser/samples/each-block-keyed/output.json
index fe893bcdb9..11cdd45ff1 100644
--- a/test/parser/samples/each-block-keyed/output.json
+++ b/test/parser/samples/each-block-keyed/output.json
@@ -62,8 +62,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/each-block/output.json b/test/parser/samples/each-block/output.json
index c16a71ad5d..6a60823952 100644
--- a/test/parser/samples/each-block/output.json
+++ b/test/parser/samples/each-block/output.json
@@ -44,8 +44,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/element-with-mustache/output.json b/test/parser/samples/element-with-mustache/output.json
index c8a386d681..f7c2e9936b 100644
--- a/test/parser/samples/element-with-mustache/output.json
+++ b/test/parser/samples/element-with-mustache/output.json
@@ -15,6 +15,7 @@
"start": 4,
"end": 10,
"type": "Text",
+ "raw": "hello ",
"data": "hello "
},
{
@@ -32,13 +33,11 @@
"start": 16,
"end": 17,
"type": "Text",
+ "raw": "!",
"data": "!"
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/element-with-text/output.json b/test/parser/samples/element-with-text/output.json
index 70f6163c93..b0e0f5c6cc 100644
--- a/test/parser/samples/element-with-text/output.json
+++ b/test/parser/samples/element-with-text/output.json
@@ -15,13 +15,11 @@
"start": 6,
"end": 10,
"type": "Text",
+ "raw": "test",
"data": "test"
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/elements/output.json b/test/parser/samples/elements/output.json
index d216f7f5d8..75548c20f0 100644
--- a/test/parser/samples/elements/output.json
+++ b/test/parser/samples/elements/output.json
@@ -21,8 +21,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/event-handler/output.json b/test/parser/samples/event-handler/output.json
index b1fe89fc2a..f792ffadcc 100644
--- a/test/parser/samples/event-handler/output.json
+++ b/test/parser/samples/event-handler/output.json
@@ -21,8 +21,8 @@
"start": 19,
"end": 43,
"id": null,
- "generator": false,
"expression": true,
+ "generator": false,
"async": false,
"params": [],
"body": {
@@ -58,6 +58,7 @@
"start": 46,
"end": 52,
"type": "Text",
+ "raw": "toggle",
"data": "toggle"
}
]
@@ -66,6 +67,7 @@
"start": 61,
"end": 63,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
},
{
@@ -90,6 +92,7 @@
"start": 81,
"end": 87,
"type": "Text",
+ "raw": "hello!",
"data": "hello!"
}
]
@@ -97,8 +100,5 @@
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/if-block-else/output.json b/test/parser/samples/if-block-else/output.json
index dedf2797c4..8b22cfa26b 100644
--- a/test/parser/samples/if-block-else/output.json
+++ b/test/parser/samples/if-block-else/output.json
@@ -26,6 +26,7 @@
"start": 14,
"end": 17,
"type": "Text",
+ "raw": "foo",
"data": "foo"
}
]
@@ -47,6 +48,7 @@
"start": 34,
"end": 41,
"type": "Text",
+ "raw": "not foo",
"data": "not foo"
}
]
@@ -55,8 +57,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/if-block-elseif/output.json b/test/parser/samples/if-block-elseif/output.json
index 188b57aaad..54fb53dacb 100644
--- a/test/parser/samples/if-block-elseif/output.json
+++ b/test/parser/samples/if-block-elseif/output.json
@@ -39,6 +39,7 @@
"start": 17,
"end": 37,
"type": "Text",
+ "raw": "x is greater than 10",
"data": "x is greater than 10"
}
]
@@ -85,6 +86,7 @@
"start": 63,
"end": 79,
"type": "Text",
+ "raw": "x is less than 5",
"data": "x is less than 5"
}
]
diff --git a/test/parser/samples/if-block/output.json b/test/parser/samples/if-block/output.json
index d560824766..1714bb7141 100644
--- a/test/parser/samples/if-block/output.json
+++ b/test/parser/samples/if-block/output.json
@@ -19,13 +19,11 @@
"start": 9,
"end": 12,
"type": "Text",
+ "raw": "bar",
"data": "bar"
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/implicitly-closed-li/output.json b/test/parser/samples/implicitly-closed-li/output.json
index caf69d7109..f46a2b1a26 100644
--- a/test/parser/samples/implicitly-closed-li/output.json
+++ b/test/parser/samples/implicitly-closed-li/output.json
@@ -15,6 +15,7 @@
"start": 4,
"end": 6,
"type": "Text",
+ "raw": "\n\t",
"data": "\n\t"
},
{
@@ -28,6 +29,7 @@
"start": 10,
"end": 13,
"type": "Text",
+ "raw": "a\n\t",
"data": "a\n\t"
}
]
@@ -43,6 +45,7 @@
"start": 17,
"end": 20,
"type": "Text",
+ "raw": "b\n\t",
"data": "b\n\t"
}
]
@@ -58,6 +61,7 @@
"start": 24,
"end": 26,
"type": "Text",
+ "raw": "c\n",
"data": "c\n"
}
]
@@ -65,8 +69,5 @@
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/nbsp/output.json b/test/parser/samples/nbsp/output.json
index 4fa318ce48..044de64cba 100644
--- a/test/parser/samples/nbsp/output.json
+++ b/test/parser/samples/nbsp/output.json
@@ -15,13 +15,11 @@
"start": 6,
"end": 12,
"type": "Text",
+ "raw": " ",
"data": " "
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/raw-mustaches/output.json b/test/parser/samples/raw-mustaches/output.json
index 1d92b21c85..1b3d9b7a9c 100644
--- a/test/parser/samples/raw-mustaches/output.json
+++ b/test/parser/samples/raw-mustaches/output.json
@@ -15,6 +15,7 @@
"start": 3,
"end": 4,
"type": "Text",
+ "raw": " ",
"data": " "
},
{
@@ -32,6 +33,7 @@
"start": 16,
"end": 17,
"type": "Text",
+ "raw": " ",
"data": " "
},
{
@@ -49,13 +51,11 @@
"start": 29,
"end": 30,
"type": "Text",
+ "raw": " ",
"data": " "
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/refs/output.json b/test/parser/samples/refs/output.json
index d15753b0a2..e09383f9b6 100644
--- a/test/parser/samples/refs/output.json
+++ b/test/parser/samples/refs/output.json
@@ -8,6 +8,7 @@
"start": 28,
"end": 30,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
},
{
diff --git a/test/parser/samples/script-comment-only/output.json b/test/parser/samples/script-comment-only/output.json
index 95ca769b20..ba28434318 100644
--- a/test/parser/samples/script-comment-only/output.json
+++ b/test/parser/samples/script-comment-only/output.json
@@ -8,6 +8,7 @@
"start": 43,
"end": 45,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
},
{
diff --git a/test/parser/samples/script-comment-trailing-multiline/output.json b/test/parser/samples/script-comment-trailing-multiline/output.json
index d4a45911a1..7d01599efa 100644
--- a/test/parser/samples/script-comment-trailing-multiline/output.json
+++ b/test/parser/samples/script-comment-trailing-multiline/output.json
@@ -8,6 +8,7 @@
"start": 77,
"end": 79,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
},
{
@@ -21,6 +22,7 @@
"start": 83,
"end": 89,
"type": "Text",
+ "raw": "Hello ",
"data": "Hello "
},
{
@@ -38,6 +40,7 @@
"start": 95,
"end": 96,
"type": "Text",
+ "raw": "!",
"data": "!"
}
]
diff --git a/test/parser/samples/script-comment-trailing/output.json b/test/parser/samples/script-comment-trailing/output.json
index 92d431b558..bc8f3e4e67 100644
--- a/test/parser/samples/script-comment-trailing/output.json
+++ b/test/parser/samples/script-comment-trailing/output.json
@@ -8,6 +8,7 @@
"start": 66,
"end": 68,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
},
{
@@ -21,6 +22,7 @@
"start": 72,
"end": 78,
"type": "Text",
+ "raw": "Hello ",
"data": "Hello "
},
{
@@ -38,6 +40,7 @@
"start": 84,
"end": 85,
"type": "Text",
+ "raw": "!",
"data": "!"
}
]
diff --git a/test/parser/samples/script/output.json b/test/parser/samples/script/output.json
index 95966f5dc6..75aa0a7d2c 100644
--- a/test/parser/samples/script/output.json
+++ b/test/parser/samples/script/output.json
@@ -8,6 +8,7 @@
"start": 39,
"end": 41,
"type": "Text",
+ "raw": "\n\n",
"data": "\n\n"
},
{
@@ -21,6 +22,7 @@
"start": 45,
"end": 51,
"type": "Text",
+ "raw": "Hello ",
"data": "Hello "
},
{
@@ -38,6 +40,7 @@
"start": 57,
"end": 58,
"type": "Text",
+ "raw": "!",
"data": "!"
}
]
diff --git a/test/parser/samples/self-closing-element/output.json b/test/parser/samples/self-closing-element/output.json
index 47eea2f333..63ff17a466 100644
--- a/test/parser/samples/self-closing-element/output.json
+++ b/test/parser/samples/self-closing-element/output.json
@@ -13,8 +13,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/self-reference/output.json b/test/parser/samples/self-reference/output.json
index de5112a087..92dfdfe4d0 100644
--- a/test/parser/samples/self-reference/output.json
+++ b/test/parser/samples/self-reference/output.json
@@ -72,8 +72,5 @@
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/space-between-mustaches/output.json b/test/parser/samples/space-between-mustaches/output.json
index c89409daeb..9a367bd2c1 100644
--- a/test/parser/samples/space-between-mustaches/output.json
+++ b/test/parser/samples/space-between-mustaches/output.json
@@ -15,6 +15,7 @@
"start": 3,
"end": 4,
"type": "Text",
+ "raw": " ",
"data": " "
},
{
@@ -32,6 +33,7 @@
"start": 7,
"end": 8,
"type": "Text",
+ "raw": " ",
"data": " "
},
{
@@ -49,6 +51,7 @@
"start": 11,
"end": 14,
"type": "Text",
+ "raw": " : ",
"data": " : "
},
{
@@ -66,13 +69,11 @@
"start": 17,
"end": 20,
"type": "Text",
+ "raw": " : ",
"data": " : "
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/spread/output.json b/test/parser/samples/spread/output.json
index 3986da3578..73a0dc9777 100644
--- a/test/parser/samples/spread/output.json
+++ b/test/parser/samples/spread/output.json
@@ -25,8 +25,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/textarea-children/output.json b/test/parser/samples/textarea-children/output.json
index 3b403458fc..90f31f3caf 100644
--- a/test/parser/samples/textarea-children/output.json
+++ b/test/parser/samples/textarea-children/output.json
@@ -16,8 +16,9 @@
"value": [
{
"start": 10,
- "end": 40,
+ "end": 41,
"type": "Text",
+ "raw": "\n\tnot actually an element. ",
"data": "\n\t
not actually an element. "
},
{
@@ -35,6 +36,7 @@
"start": 45,
"end": 50,
"type": "Text",
+ "raw": "
\n",
"data": "\n"
}
]
@@ -43,8 +45,5 @@
"children": []
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/transition-intro-no-params/output.json b/test/parser/samples/transition-intro-no-params/output.json
index edb15457e6..91b50f3ec8 100644
--- a/test/parser/samples/transition-intro-no-params/output.json
+++ b/test/parser/samples/transition-intro-no-params/output.json
@@ -26,13 +26,11 @@
"start": 13,
"end": 21,
"type": "Text",
+ "raw": "fades in",
"data": "fades in"
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/transition-intro/output.json b/test/parser/samples/transition-intro/output.json
index 5583dd89bc..418bb97e16 100644
--- a/test/parser/samples/transition-intro/output.json
+++ b/test/parser/samples/transition-intro/output.json
@@ -54,13 +54,11 @@
"start": 31,
"end": 39,
"type": "Text",
+ "raw": "fades in",
"data": "fades in"
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/unusual-identifier/output.json b/test/parser/samples/unusual-identifier/output.json
index c0d4ecc3ff..e4a2a18619 100644
--- a/test/parser/samples/unusual-identifier/output.json
+++ b/test/parser/samples/unusual-identifier/output.json
@@ -44,8 +44,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/whitespace-leading-trailing/output.json b/test/parser/samples/whitespace-leading-trailing/output.json
index f164af01ba..e4f387856e 100644
--- a/test/parser/samples/whitespace-leading-trailing/output.json
+++ b/test/parser/samples/whitespace-leading-trailing/output.json
@@ -8,6 +8,7 @@
"start": 0,
"end": 6,
"type": "Text",
+ "raw": "\n\n\t\t\t\t",
"data": "\n\n\t\t\t\t"
},
{
@@ -21,13 +22,11 @@
"start": 9,
"end": 32,
"type": "Text",
+ "raw": "just chillin' over here",
"data": "just chillin' over here"
}
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/whitespace-normal/output.json b/test/parser/samples/whitespace-normal/output.json
index e4ce956331..acbae7ae17 100644
--- a/test/parser/samples/whitespace-normal/output.json
+++ b/test/parser/samples/whitespace-normal/output.json
@@ -15,6 +15,7 @@
"start": 4,
"end": 10,
"type": "Text",
+ "raw": "Hello ",
"data": "Hello "
},
{
@@ -39,6 +40,7 @@
"start": 24,
"end": 26,
"type": "Text",
+ "raw": "! ",
"data": "! "
}
]
@@ -54,6 +56,7 @@
"start": 41,
"end": 53,
"type": "Text",
+ "raw": "How are you?",
"data": "How are you?"
}
]
@@ -61,8 +64,5 @@
]
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/parser/samples/yield/output.json b/test/parser/samples/yield/output.json
index 16ea79d8e8..b2e4b9430f 100644
--- a/test/parser/samples/yield/output.json
+++ b/test/parser/samples/yield/output.json
@@ -16,8 +16,5 @@
}
}
]
- },
- "css": null,
- "instance": null,
- "module": null
+ }
}
\ No newline at end of file
diff --git a/test/runtime/index.js b/test/runtime/index.js
index 64d7f3ae51..87be528a61 100644
--- a/test/runtime/index.js
+++ b/test/runtime/index.js
@@ -3,7 +3,7 @@ import * as path from "path";
import * as fs from "fs";
import { rollup } from 'rollup';
import * as virtual from 'rollup-plugin-virtual';
-import { clear_loops } from "../../internal.js";
+import { clear_loops, flush, set_now, set_raf } from "../../internal";
import {
showOutput,
@@ -20,7 +20,6 @@ let compileOptions = null;
let compile = null;
const sveltePath = process.cwd().split('\\').join('/');
-const internal = `${sveltePath}/internal.js`;
describe("runtime", () => {
before(() => {
@@ -47,8 +46,6 @@ describe("runtime", () => {
function runTest(dir, hydrate) {
if (dir[0] === ".") return;
- const { flush } = require(internal);
-
const config = loadConfig(`./runtime/samples/${dir}/_config.js`);
if (hydrate && config.skip_if_hydrate) return;
@@ -66,7 +63,6 @@ describe("runtime", () => {
compile = (config.preserveIdentifiers ? svelte : svelte$).compile;
const cwd = path.resolve(`test/runtime/samples/${dir}`);
- global.document.title = '';
compileOptions = config.compileOptions || {};
compileOptions.sveltePath = sveltePath;
@@ -100,8 +96,8 @@ describe("runtime", () => {
if (raf.callback) raf.callback();
}
};
- window.performance.now = () => raf.time;
- global.requestAnimationFrame = cb => {
+ set_now(() => raf.time);
+ set_raf(cb => {
let called = false;
raf.callback = () => {
if (!called) {
@@ -109,7 +105,7 @@ describe("runtime", () => {
cb();
}
};
- };
+ });
try {
mod = require(`./samples/${dir}/main.svelte`);
@@ -119,8 +115,6 @@ describe("runtime", () => {
throw err;
}
- global.window = window;
-
if (config.before_test) config.before_test();
// Put things we need on window for testing
@@ -221,9 +215,10 @@ describe("runtime", () => {
'main.js': js.code
}),
{
+ name: 'svelte-packages',
resolveId: (importee, importer) => {
if (importee.startsWith('svelte/')) {
- return importee.replace('svelte', process.cwd()) + '.mjs';
+ return importee.replace('svelte', process.cwd()) + '/index.mjs';
}
}
}
diff --git a/test/runtime/samples/animation-css/_config.js b/test/runtime/samples/animation-css/_config.js
index 544c6378ff..201a282e58 100644
--- a/test/runtime/samples/animation-css/_config.js
+++ b/test/runtime/samples/animation-css/_config.js
@@ -29,9 +29,9 @@ export default {
right: 100,
top,
bottom: top + 20
- }
+ };
};
- })
+ });
component.things = [
{ id: 5, name: 'e' },
diff --git a/test/runtime/samples/animation-js-delay/_config.js b/test/runtime/samples/animation-js-delay/_config.js
index faed25ecaa..6bd02d17e6 100644
--- a/test/runtime/samples/animation-js-delay/_config.js
+++ b/test/runtime/samples/animation-js-delay/_config.js
@@ -29,9 +29,9 @@ export default {
right: 100,
top,
bottom: top + 20
- }
+ };
};
- })
+ });
component.things = [
{ id: 5, name: 'e' },
diff --git a/test/runtime/samples/animation-js-easing/_config.js b/test/runtime/samples/animation-js-easing/_config.js
index a31825c3f9..415af042a9 100644
--- a/test/runtime/samples/animation-js-easing/_config.js
+++ b/test/runtime/samples/animation-js-easing/_config.js
@@ -29,9 +29,9 @@ export default {
right: 100,
top,
bottom: top + 20
- }
+ };
};
- })
+ });
component.things = [
{ id: 5, name: 'e' },
diff --git a/test/runtime/samples/animation-js/_config.js b/test/runtime/samples/animation-js/_config.js
index d5991a915a..521753633d 100644
--- a/test/runtime/samples/animation-js/_config.js
+++ b/test/runtime/samples/animation-js/_config.js
@@ -29,7 +29,7 @@ export default {
right: 100,
top,
bottom: top + 20
- }
+ };
};
});
diff --git a/test/runtime/samples/attribute-dataset-without-value/_config.js b/test/runtime/samples/attribute-dataset-without-value/_config.js
new file mode 100644
index 0000000000..934f44eb06
--- /dev/null
+++ b/test/runtime/samples/attribute-dataset-without-value/_config.js
@@ -0,0 +1,3 @@
+export default {
+ html: '
',
+};
diff --git a/test/runtime/samples/attribute-dataset-without-value/main.svelte b/test/runtime/samples/attribute-dataset-without-value/main.svelte
new file mode 100644
index 0000000000..ed7d532652
--- /dev/null
+++ b/test/runtime/samples/attribute-dataset-without-value/main.svelte
@@ -0,0 +1 @@
+
diff --git a/test/runtime/samples/attribute-url/_config.js b/test/runtime/samples/attribute-url/_config.js
new file mode 100644
index 0000000000..28bc1bcb0c
--- /dev/null
+++ b/test/runtime/samples/attribute-url/_config.js
@@ -0,0 +1,8 @@
+export default {
+ test({ assert, target }) {
+ const div = target.querySelector( 'div' );
+
+ assert.equal( div.style.backgroundImage, 'url(https://example.com/foo.jpg)');
+ assert.equal( div.style.color, 'red' );
+ }
+};
diff --git a/test/runtime/samples/attribute-url/main.svelte b/test/runtime/samples/attribute-url/main.svelte
new file mode 100644
index 0000000000..357a352aaa
--- /dev/null
+++ b/test/runtime/samples/attribute-url/main.svelte
@@ -0,0 +1,6 @@
+
+
+{color}
diff --git a/test/runtime/samples/await-containing-if/_config.js b/test/runtime/samples/await-containing-if/_config.js
index 9e24e4f614..cd83585cc1 100644
--- a/test/runtime/samples/await-containing-if/_config.js
+++ b/test/runtime/samples/await-containing-if/_config.js
@@ -1,6 +1,6 @@
let fulfil;
-let thePromise = new Promise(f => {
+const thePromise = new Promise(f => {
fulfil = f;
});
diff --git a/test/runtime/samples/await-in-each/_config.js b/test/runtime/samples/await-in-each/_config.js
index b1a232e4bd..6c7da69ee3 100644
--- a/test/runtime/samples/await-in-each/_config.js
+++ b/test/runtime/samples/await-in-each/_config.js
@@ -1,6 +1,6 @@
let fulfil;
-let thePromise = new Promise(f => {
+const thePromise = new Promise(f => {
fulfil = f;
});
diff --git a/test/runtime/samples/await-then-catch-order/_config.js b/test/runtime/samples/await-then-catch-order/_config.js
index 5c4eb530e9..f972520904 100644
--- a/test/runtime/samples/await-then-catch-order/_config.js
+++ b/test/runtime/samples/await-then-catch-order/_config.js
@@ -1,6 +1,6 @@
let fulfil;
-let thePromise = new Promise(f => {
+const thePromise = new Promise(f => {
fulfil = f;
});
diff --git a/test/runtime/samples/await-with-components/_config.js b/test/runtime/samples/await-with-components/_config.js
index ffef7441ff..a0a558782a 100644
--- a/test/runtime/samples/await-with-components/_config.js
+++ b/test/runtime/samples/await-with-components/_config.js
@@ -1,6 +1,7 @@
export default {
async test({ assert, component, target }) {
- let resolve, reject;
+ let resolve;
+ let reject;
let promise = new Promise(ok => resolve = ok);
component.promise = promise;
diff --git a/test/runtime/samples/binding-contenteditable-html-initial/_config.js b/test/runtime/samples/binding-contenteditable-html-initial/_config.js
new file mode 100644
index 0000000000..9eac2c9b17
--- /dev/null
+++ b/test/runtime/samples/binding-contenteditable-html-initial/_config.js
@@ -0,0 +1,40 @@
+export default {
+ html: `
+ world
+ hello world
+ `,
+
+ ssrHtml: `
+ world
+ hello undefined
+ `,
+
+ async test({ assert, component, target, window }) {
+ assert.equal(component.name, 'world ');
+
+ const el = target.querySelector('editor');
+
+ el.innerHTML = 'everybody ';
+
+ // No updates to data yet
+ assert.htmlEqual(target.innerHTML, `
+ everybody
+ hello world
+ `);
+
+ // Handle user input
+ const event = new window.Event('input');
+ await el.dispatchEvent(event);
+ assert.htmlEqual(target.innerHTML, `
+ everybody
+ hello everybody
+ `);
+
+ component.name = 'goodbye ';
+ assert.equal(el.innerHTML, 'goodbye ');
+ assert.htmlEqual(target.innerHTML, `
+ goodbye
+ hello goodbye
+ `);
+ },
+};
diff --git a/test/runtime/samples/binding-contenteditable-html-initial/main.svelte b/test/runtime/samples/binding-contenteditable-html-initial/main.svelte
new file mode 100644
index 0000000000..119b41b52d
--- /dev/null
+++ b/test/runtime/samples/binding-contenteditable-html-initial/main.svelte
@@ -0,0 +1,8 @@
+
+
+
+ world
+
+hello {@html name}
\ No newline at end of file
diff --git a/test/runtime/samples/binding-contenteditable-html/_config.js b/test/runtime/samples/binding-contenteditable-html/_config.js
new file mode 100644
index 0000000000..ceb6a75c70
--- /dev/null
+++ b/test/runtime/samples/binding-contenteditable-html/_config.js
@@ -0,0 +1,38 @@
+export default {
+ props: {
+ name: 'world ',
+ },
+
+ html: `
+ world
+ hello world
+ `,
+
+ async test({ assert, component, target, window }) {
+ const el = target.querySelector('editor');
+ assert.equal(el.innerHTML, 'world ');
+
+ el.innerHTML = 'everybody ';
+
+ // No updates to data yet
+ assert.htmlEqual(target.innerHTML, `
+ everybody
+ hello world
+ `);
+
+ // Handle user input
+ const event = new window.Event('input');
+ await el.dispatchEvent(event);
+ assert.htmlEqual(target.innerHTML, `
+ everybody
+ hello everybody
+ `);
+
+ component.name = 'goodbye ';
+ assert.equal(el.innerHTML, 'goodbye ');
+ assert.htmlEqual(target.innerHTML, `
+ goodbye
+ hello goodbye
+ `);
+ },
+};
diff --git a/test/runtime/samples/binding-contenteditable-html/main.svelte b/test/runtime/samples/binding-contenteditable-html/main.svelte
new file mode 100644
index 0000000000..f576cf1868
--- /dev/null
+++ b/test/runtime/samples/binding-contenteditable-html/main.svelte
@@ -0,0 +1,6 @@
+
+
+
+hello {@html name}
\ No newline at end of file
diff --git a/test/runtime/samples/binding-contenteditable-text-initial/_config.js b/test/runtime/samples/binding-contenteditable-text-initial/_config.js
new file mode 100644
index 0000000000..4899f30f12
--- /dev/null
+++ b/test/runtime/samples/binding-contenteditable-text-initial/_config.js
@@ -0,0 +1,34 @@
+export default {
+ html: `
+ world
+ hello world
+ `,
+
+ ssrHtml: `
+ world
+ hello undefined
+ `,
+
+ async test({ assert, component, target, window }) {
+ assert.equal(component.name, 'world');
+
+ const el = target.querySelector('editor');
+
+ const event = new window.Event('input');
+
+ el.textContent = 'everybody';
+ await el.dispatchEvent(event);
+
+ assert.htmlEqual(target.innerHTML, `
+ everybody
+ hello everybody
+ `);
+
+ component.name = 'goodbye';
+ assert.equal(el.textContent, 'goodbye');
+ assert.htmlEqual(target.innerHTML, `
+ goodbye
+ hello goodbye
+ `);
+ },
+};
diff --git a/test/runtime/samples/binding-contenteditable-text-initial/main.svelte b/test/runtime/samples/binding-contenteditable-text-initial/main.svelte
new file mode 100644
index 0000000000..b0938d4d0b
--- /dev/null
+++ b/test/runtime/samples/binding-contenteditable-text-initial/main.svelte
@@ -0,0 +1,8 @@
+
+
+
+ world
+
+hello {name}
\ No newline at end of file
diff --git a/test/runtime/samples/binding-contenteditable-text/_config.js b/test/runtime/samples/binding-contenteditable-text/_config.js
new file mode 100644
index 0000000000..9f8645724d
--- /dev/null
+++ b/test/runtime/samples/binding-contenteditable-text/_config.js
@@ -0,0 +1,32 @@
+export default {
+ props: {
+ name: 'world',
+ },
+
+ html: `
+ world
+ hello world
+ `,
+
+ async test({ assert, component, target, window }) {
+ const el = target.querySelector('editor');
+ assert.equal(el.textContent, 'world');
+
+ const event = new window.Event('input');
+
+ el.textContent = 'everybody';
+ await el.dispatchEvent(event);
+
+ assert.htmlEqual(target.innerHTML, `
+ everybody
+ hello everybody
+ `);
+
+ component.name = 'goodbye';
+ assert.equal(el.textContent, 'goodbye');
+ assert.htmlEqual(target.innerHTML, `
+ goodbye
+ hello goodbye
+ `);
+ },
+};
diff --git a/test/runtime/samples/binding-contenteditable-text/main.svelte b/test/runtime/samples/binding-contenteditable-text/main.svelte
new file mode 100644
index 0000000000..70f65e8824
--- /dev/null
+++ b/test/runtime/samples/binding-contenteditable-text/main.svelte
@@ -0,0 +1,6 @@
+
+
+
+hello {name}
\ No newline at end of file
diff --git a/test/runtime/samples/binding-details-open/_config.js b/test/runtime/samples/binding-details-open/_config.js
new file mode 100644
index 0000000000..cf2459c3f1
--- /dev/null
+++ b/test/runtime/samples/binding-details-open/_config.js
@@ -0,0 +1,25 @@
+export default {
+ html: `
+ toggle
+ `,
+
+ async test({ assert, component, target, window }) {
+ const details = target.querySelector('details');
+ const event = new window.Event('toggle');
+
+ details.open = true;
+ await details.dispatchEvent(event);
+ assert.equal(component.visible, true);
+ assert.htmlEqual(target.innerHTML, `
+ toggle
+ hello!
+ `);
+
+ details.open = false;
+ await details.dispatchEvent(event);
+ assert.equal(component.visible, false);
+ assert.htmlEqual(target.innerHTML, `
+ toggle
+ `);
+ }
+};
diff --git a/test/runtime/samples/binding-details-open/main.svelte b/test/runtime/samples/binding-details-open/main.svelte
new file mode 100644
index 0000000000..3a7a08e121
--- /dev/null
+++ b/test/runtime/samples/binding-details-open/main.svelte
@@ -0,0 +1,9 @@
+
+
+toggle
+
+{#if visible}
+ hello!
+{/if}
diff --git a/test/runtime/samples/binding-textarea/_config.js b/test/runtime/samples/binding-textarea/_config.js
index c09256e059..ac092096e6 100644
--- a/test/runtime/samples/binding-textarea/_config.js
+++ b/test/runtime/samples/binding-textarea/_config.js
@@ -9,7 +9,7 @@ export default {
`,
ssrHtml: `
-
+
some text
`,
diff --git a/test/runtime/samples/binding-this-component-computed-key/Foo.svelte b/test/runtime/samples/binding-this-component-computed-key/Foo.svelte
new file mode 100644
index 0000000000..066a48b65e
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-computed-key/Foo.svelte
@@ -0,0 +1 @@
+foo
\ No newline at end of file
diff --git a/test/runtime/samples/binding-this-component-computed-key/_config.js b/test/runtime/samples/binding-this-component-computed-key/_config.js
new file mode 100644
index 0000000000..415d2e641c
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-computed-key/_config.js
@@ -0,0 +1,8 @@
+export default {
+ skip_if_ssr: true,
+
+ html: `
+ foo
+ has foo: true
+ `
+};
diff --git a/test/runtime/samples/binding-this-component-computed-key/main.svelte b/test/runtime/samples/binding-this-component-computed-key/main.svelte
new file mode 100644
index 0000000000..af450ea1fe
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-computed-key/main.svelte
@@ -0,0 +1,9 @@
+
+
+
+
+ has foo: {!!foo.computed}
+
diff --git a/test/runtime/samples/binding-this-component-each-block-value/Foo.svelte b/test/runtime/samples/binding-this-component-each-block-value/Foo.svelte
new file mode 100644
index 0000000000..066a48b65e
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-each-block-value/Foo.svelte
@@ -0,0 +1 @@
+foo
\ No newline at end of file
diff --git a/test/runtime/samples/binding-this-component-each-block-value/_config.js b/test/runtime/samples/binding-this-component-each-block-value/_config.js
new file mode 100644
index 0000000000..2b5df8c595
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-each-block-value/_config.js
@@ -0,0 +1,12 @@
+export default {
+ skip_if_ssr: true,
+
+ html: `
+ foo
+ first has foo: true
+ foo
+ second has foo: true
+ foo
+ third has foo: true
+ `
+};
diff --git a/test/runtime/samples/binding-this-component-each-block-value/main.svelte b/test/runtime/samples/binding-this-component-each-block-value/main.svelte
new file mode 100644
index 0000000000..5093eecd3f
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-each-block-value/main.svelte
@@ -0,0 +1,11 @@
+
+
+{#each ["first", "second", "third"] as value}
+
+
+ {value} has foo: {!!foo[value]}
+
+{/each}
diff --git a/test/runtime/samples/binding-this-component-each-block/Foo.svelte b/test/runtime/samples/binding-this-component-each-block/Foo.svelte
new file mode 100644
index 0000000000..066a48b65e
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-each-block/Foo.svelte
@@ -0,0 +1 @@
+foo
\ No newline at end of file
diff --git a/test/runtime/samples/binding-this-component-each-block/_config.js b/test/runtime/samples/binding-this-component-each-block/_config.js
new file mode 100644
index 0000000000..358c5b5afc
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-each-block/_config.js
@@ -0,0 +1,12 @@
+export default {
+ skip_if_ssr: true,
+
+ html: `
+ foo
+ 0 has foo: true
+ foo
+ 1 has foo: true
+ foo
+ 2 has foo: true
+ `
+};
diff --git a/test/runtime/samples/binding-this-component-each-block/main.svelte b/test/runtime/samples/binding-this-component-each-block/main.svelte
new file mode 100644
index 0000000000..49d1d76172
--- /dev/null
+++ b/test/runtime/samples/binding-this-component-each-block/main.svelte
@@ -0,0 +1,11 @@
+
+
+{#each Array(3) as _, i}
+
+
+ {i} has foo: {!!foo[i]}
+
+{/each}
diff --git a/test/runtime/samples/binding-using-props/TextInput.svelte b/test/runtime/samples/binding-using-props/TextInput.svelte
new file mode 100644
index 0000000000..da9e7e4a0e
--- /dev/null
+++ b/test/runtime/samples/binding-using-props/TextInput.svelte
@@ -0,0 +1,6 @@
+
+
+
\ No newline at end of file
diff --git a/test/runtime/samples/binding-using-props/_config.js b/test/runtime/samples/binding-using-props/_config.js
new file mode 100644
index 0000000000..dcb34c4357
--- /dev/null
+++ b/test/runtime/samples/binding-using-props/_config.js
@@ -0,0 +1,14 @@
+export default {
+ async test({ assert, target, window }) {
+ const input = target.querySelector('input');
+
+ const event = new window.Event('input');
+ input.value = 'changed';
+ await input.dispatchEvent(event);
+
+ assert.htmlEqual(target.innerHTML, `
+
+ changed
+ `);
+ }
+};
\ No newline at end of file
diff --git a/test/runtime/samples/binding-using-props/main.svelte b/test/runtime/samples/binding-using-props/main.svelte
new file mode 100644
index 0000000000..543bd28d49
--- /dev/null
+++ b/test/runtime/samples/binding-using-props/main.svelte
@@ -0,0 +1,7 @@
+
+
+
+{actualValue}
\ No newline at end of file
diff --git a/test/runtime/samples/component-event-handler-modifier-once/Button.svelte b/test/runtime/samples/component-event-handler-modifier-once/Button.svelte
new file mode 100644
index 0000000000..9b5b7a5f67
--- /dev/null
+++ b/test/runtime/samples/component-event-handler-modifier-once/Button.svelte
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/test/runtime/samples/component-event-handler-modifier-once/_config.js b/test/runtime/samples/component-event-handler-modifier-once/_config.js
new file mode 100644
index 0000000000..41daf374c8
--- /dev/null
+++ b/test/runtime/samples/component-event-handler-modifier-once/_config.js
@@ -0,0 +1,16 @@
+export default {
+ html: `
+ 0
+ `,
+
+ async test({ assert, component, target, window }) {
+ const button = target.querySelector('button');
+ const event = new window.MouseEvent('click');
+
+ await button.dispatchEvent(event);
+ assert.equal(component.count, 1);
+
+ await button.dispatchEvent(event);
+ assert.equal(component.count, 1);
+ }
+};
diff --git a/test/runtime/samples/component-event-handler-modifier-once/main.svelte b/test/runtime/samples/component-event-handler-modifier-once/main.svelte
new file mode 100644
index 0000000000..b9bca3b5eb
--- /dev/null
+++ b/test/runtime/samples/component-event-handler-modifier-once/main.svelte
@@ -0,0 +1,6 @@
+
+
+ count += 1}">{count}
\ No newline at end of file
diff --git a/test/runtime/samples/component-slot-named-inherits-default-lets/_config.js b/test/runtime/samples/component-slot-named-inherits-default-lets/_config.js
index 212c57308a..a07a1482bc 100644
--- a/test/runtime/samples/component-slot-named-inherits-default-lets/_config.js
+++ b/test/runtime/samples/component-slot-named-inherits-default-lets/_config.js
@@ -22,4 +22,4 @@ export default {
`);
}
-}
\ No newline at end of file
+};
\ No newline at end of file
diff --git a/test/runtime/samples/deconflict-globals/_config.js b/test/runtime/samples/deconflict-globals/_config.js
new file mode 100644
index 0000000000..c29f022a37
--- /dev/null
+++ b/test/runtime/samples/deconflict-globals/_config.js
@@ -0,0 +1,14 @@
+export default {
+ preserveIdentifiers: true,
+ compileOptions: {
+ name: 'window'
+ },
+
+ html: `
+
I hereby declare Svelte the bestest framework.
+
nintendo sixty four
+
Woops.
+
42
+
false
+ `
+};
diff --git a/test/runtime/samples/deconflict-globals/main.svelte b/test/runtime/samples/deconflict-globals/main.svelte
new file mode 100644
index 0000000000..d1928ea533
--- /dev/null
+++ b/test/runtime/samples/deconflict-globals/main.svelte
@@ -0,0 +1,20 @@
+
+
+
+ Cute test
+
+
+
+
+
+{#each everyone as someone (someone)}
+
{someone}
+{/each}
diff --git a/test/runtime/samples/destructuring-assignment-array/_config.js b/test/runtime/samples/destructuring-assignment-array/_config.js
new file mode 100644
index 0000000000..ede4552803
--- /dev/null
+++ b/test/runtime/samples/destructuring-assignment-array/_config.js
@@ -0,0 +1,23 @@
+export default {
+ html: `
+
+ Gruyere
+ Compté
+ Beaufort
+ Abondance
+
+ `,
+
+ async test({ assert, component, target }) {
+ await component.swap(0, 1);
+
+ assert.htmlEqual(target.innerHTML, `
+
+ Compté
+ Gruyere
+ Beaufort
+ Abondance
+
+ `);
+ }
+};
\ No newline at end of file
diff --git a/test/runtime/samples/destructuring-assignment-array/main.svelte b/test/runtime/samples/destructuring-assignment-array/main.svelte
new file mode 100644
index 0000000000..aebbfe204c
--- /dev/null
+++ b/test/runtime/samples/destructuring-assignment-array/main.svelte
@@ -0,0 +1,18 @@
+
+
+
+ {#each cheese as cheese}
+ {cheese}
+ {/each}
+
\ No newline at end of file
diff --git a/test/runtime/samples/dev-warning-unknown-props-with-$$props/Foo.svelte b/test/runtime/samples/dev-warning-unknown-props-with-$$props/Foo.svelte
new file mode 100644
index 0000000000..9e5c62339d
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props-with-$$props/Foo.svelte
@@ -0,0 +1,7 @@
+
+
+
{foo}
+
{JSON.stringify($$props)}
diff --git a/test/runtime/samples/dev-warning-unknown-props-with-$$props/_config.js b/test/runtime/samples/dev-warning-unknown-props-with-$$props/_config.js
new file mode 100644
index 0000000000..62ad08624d
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props-with-$$props/_config.js
@@ -0,0 +1,7 @@
+export default {
+ compileOptions: {
+ dev: true
+ },
+
+ warnings: []
+};
diff --git a/test/runtime/samples/dev-warning-unknown-props-with-$$props/main.svelte b/test/runtime/samples/dev-warning-unknown-props-with-$$props/main.svelte
new file mode 100644
index 0000000000..1566cf3e41
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props-with-$$props/main.svelte
@@ -0,0 +1,5 @@
+
+
+
diff --git a/test/runtime/samples/dev-warning-unknown-props-with-$$scope/Foo.svelte b/test/runtime/samples/dev-warning-unknown-props-with-$$scope/Foo.svelte
new file mode 100644
index 0000000000..b9f7feec24
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props-with-$$scope/Foo.svelte
@@ -0,0 +1,6 @@
+
+
+
{answer}
+
diff --git a/test/runtime/samples/dev-warning-unknown-props-with-$$scope/_config.js b/test/runtime/samples/dev-warning-unknown-props-with-$$scope/_config.js
new file mode 100644
index 0000000000..62ad08624d
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props-with-$$scope/_config.js
@@ -0,0 +1,7 @@
+export default {
+ compileOptions: {
+ dev: true
+ },
+
+ warnings: []
+};
diff --git a/test/runtime/samples/dev-warning-unknown-props-with-$$scope/main.svelte b/test/runtime/samples/dev-warning-unknown-props-with-$$scope/main.svelte
new file mode 100644
index 0000000000..a1656e86e0
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props-with-$$scope/main.svelte
@@ -0,0 +1,7 @@
+
+
+
+ bar
+
diff --git a/test/runtime/samples/dev-warning-unknown-props/Foo.svelte b/test/runtime/samples/dev-warning-unknown-props/Foo.svelte
new file mode 100644
index 0000000000..cebe5fd571
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props/Foo.svelte
@@ -0,0 +1,5 @@
+
+
+
{foo}
diff --git a/test/runtime/samples/dev-warning-unknown-props/_config.js b/test/runtime/samples/dev-warning-unknown-props/_config.js
new file mode 100644
index 0000000000..9bff4a2a74
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props/_config.js
@@ -0,0 +1,9 @@
+export default {
+ compileOptions: {
+ dev: true
+ },
+
+ warnings: [
+ `
was created with unknown prop 'fo'`
+ ]
+};
diff --git a/test/runtime/samples/dev-warning-unknown-props/main.svelte b/test/runtime/samples/dev-warning-unknown-props/main.svelte
new file mode 100644
index 0000000000..1566cf3e41
--- /dev/null
+++ b/test/runtime/samples/dev-warning-unknown-props/main.svelte
@@ -0,0 +1,5 @@
+
+
+
diff --git a/test/runtime/samples/dynamic-component-nulled-out-intro/_config.js b/test/runtime/samples/dynamic-component-nulled-out-intro/_config.js
new file mode 100644
index 0000000000..9759ada538
--- /dev/null
+++ b/test/runtime/samples/dynamic-component-nulled-out-intro/_config.js
@@ -0,0 +1,5 @@
+export default {
+ test({ component }) {
+ component.visible = true;
+ }
+};
\ No newline at end of file
diff --git a/test/runtime/samples/dynamic-component-nulled-out-intro/main.svelte b/test/runtime/samples/dynamic-component-nulled-out-intro/main.svelte
new file mode 100644
index 0000000000..eac72cf694
--- /dev/null
+++ b/test/runtime/samples/dynamic-component-nulled-out-intro/main.svelte
@@ -0,0 +1,7 @@
+
+
+{#if visible}
+
+{/if}
\ No newline at end of file
diff --git a/test/runtime/samples/each-block-component-no-props/Child.svelte b/test/runtime/samples/each-block-component-no-props/Child.svelte
new file mode 100644
index 0000000000..86ef4f3319
--- /dev/null
+++ b/test/runtime/samples/each-block-component-no-props/Child.svelte
@@ -0,0 +1 @@
+hello
\ No newline at end of file
diff --git a/test/runtime/samples/each-block-component-no-props/_config.js b/test/runtime/samples/each-block-component-no-props/_config.js
new file mode 100644
index 0000000000..e8344496ca
--- /dev/null
+++ b/test/runtime/samples/each-block-component-no-props/_config.js
@@ -0,0 +1,16 @@
+export default {
+ html: `
+ hello
+ `,
+
+ async test({ assert, component, target }) {
+ await component.remove();
+ assert.htmlEqual(target.innerHTML, ``);
+
+ await component.add();
+ assert.htmlEqual(target.innerHTML, `hello
`);
+
+ await component.remove();
+ assert.htmlEqual(target.innerHTML, ``);
+ }
+};
diff --git a/test/runtime/samples/each-block-component-no-props/main.svelte b/test/runtime/samples/each-block-component-no-props/main.svelte
new file mode 100644
index 0000000000..01299fe314
--- /dev/null
+++ b/test/runtime/samples/each-block-component-no-props/main.svelte
@@ -0,0 +1,17 @@
+
+
+{#each items as item}
+
+{/each}
diff --git a/test/runtime/samples/each-block-keyed-shift/Nested.svelte b/test/runtime/samples/each-block-keyed-shift/Nested.svelte
new file mode 100644
index 0000000000..82df711742
--- /dev/null
+++ b/test/runtime/samples/each-block-keyed-shift/Nested.svelte
@@ -0,0 +1,5 @@
+
+
+{title}
\ No newline at end of file
diff --git a/test/runtime/samples/each-block-keyed-shift/_config.js b/test/runtime/samples/each-block-keyed-shift/_config.js
new file mode 100644
index 0000000000..44ca8447f0
--- /dev/null
+++ b/test/runtime/samples/each-block-keyed-shift/_config.js
@@ -0,0 +1,27 @@
+export default {
+ props: {
+ titles: [{ name: 'a', }, { name: 'b' }, { name: 'c' }]
+ },
+
+ html: `
+ a
+ b
+ c
+ `,
+
+ test({ assert, component, target }) {
+ component.titles = [{ name: 'b' }, { name: 'c' }];
+
+ assert.htmlEqual(target.innerHTML, `
+ b
+ c
+ `);
+
+ component.titles = [{ name: 'c' }];
+
+ assert.htmlEqual(target.innerHTML, `
+ c
+ `);
+
+ }
+};
diff --git a/test/runtime/samples/each-block-keyed-shift/main.svelte b/test/runtime/samples/each-block-keyed-shift/main.svelte
new file mode 100644
index 0000000000..b8954e17fd
--- /dev/null
+++ b/test/runtime/samples/each-block-keyed-shift/main.svelte
@@ -0,0 +1,9 @@
+
+
+{#each titles as title (title.name)}
+
+{/each}
\ No newline at end of file
diff --git a/test/runtime/samples/element-invalid-name/_config.js b/test/runtime/samples/element-invalid-name/_config.js
index af6e4933ce..d70c920a19 100644
--- a/test/runtime/samples/element-invalid-name/_config.js
+++ b/test/runtime/samples/element-invalid-name/_config.js
@@ -2,4 +2,4 @@ export default {
html: `
Hello
`
-}
+};
diff --git a/test/runtime/samples/event-handler-shorthand-sanitized/_config.js b/test/runtime/samples/event-handler-shorthand-sanitized/_config.js
new file mode 100644
index 0000000000..030e27ad1a
--- /dev/null
+++ b/test/runtime/samples/event-handler-shorthand-sanitized/_config.js
@@ -0,0 +1,18 @@
+export default {
+ html: `
+ click me now
+ `,
+
+ test({ assert, component, target, window }) {
+ const button = target.querySelector('button');
+ const event = new window.Event('click-now');
+
+ let clicked;
+ component.$on('click-now', () => {
+ clicked = true;
+ });
+
+ button.dispatchEvent(event);
+ assert.ok(clicked);
+ }
+};
diff --git a/test/runtime/samples/event-handler-shorthand-sanitized/main.svelte b/test/runtime/samples/event-handler-shorthand-sanitized/main.svelte
new file mode 100644
index 0000000000..05de1316ef
--- /dev/null
+++ b/test/runtime/samples/event-handler-shorthand-sanitized/main.svelte
@@ -0,0 +1 @@
+click me now
\ No newline at end of file
diff --git a/test/runtime/samples/export-function-hoisting/_config.js b/test/runtime/samples/export-function-hoisting/_config.js
index c56851d065..f01c8b4841 100644
--- a/test/runtime/samples/export-function-hoisting/_config.js
+++ b/test/runtime/samples/export-function-hoisting/_config.js
@@ -1,3 +1,3 @@
export default {
- html: 'Compile plz'
-}
+ html: 'Compile plz'
+};
diff --git a/test/runtime/samples/fragment-trailing-whitespace/_config.js b/test/runtime/samples/fragment-trailing-whitespace/_config.js
new file mode 100644
index 0000000000..2251d6dae8
--- /dev/null
+++ b/test/runtime/samples/fragment-trailing-whitespace/_config.js
@@ -0,0 +1,16 @@
+const message = "the quick brown fox jumps over the lazy dog";
+const expected = [...message].map(c => `${c + " "} `).join("");
+
+export default {
+ props: {
+ message
+ },
+
+ async test({ assert, target }) {
+ const firstSpanList = target.children[0];
+ assert.equal(firstSpanList.innerHTML, expected);
+
+ const secondSpanList = target.children[1];
+ assert.equal(secondSpanList.innerHTML, expected);
+ }
+};
diff --git a/test/runtime/samples/fragment-trailing-whitespace/main.svelte b/test/runtime/samples/fragment-trailing-whitespace/main.svelte
new file mode 100644
index 0000000000..f36f2694a6
--- /dev/null
+++ b/test/runtime/samples/fragment-trailing-whitespace/main.svelte
@@ -0,0 +1,11 @@
+
+
+
+ {#each message as char}
+ {char}
+ {/each}
+
+
+{#each message as char}{char} {/each}
\ No newline at end of file
diff --git a/test/runtime/samples/function-hoisting/_config.js b/test/runtime/samples/function-hoisting/_config.js
index 5a22ffaf0b..91492d8c38 100644
--- a/test/runtime/samples/function-hoisting/_config.js
+++ b/test/runtime/samples/function-hoisting/_config.js
@@ -1,7 +1,7 @@
export default {
- props: {
- greeting: 'Good day'
- },
+ props: {
+ greeting: 'Good day'
+ },
- html: 'Good day, world '
-}
+ html: 'Good day, world '
+};
diff --git a/test/runtime/samples/get-after-destroy/_config.js b/test/runtime/samples/get-after-destroy/_config.js
index bf4d8e90ba..5d10bbe72a 100644
--- a/test/runtime/samples/get-after-destroy/_config.js
+++ b/test/runtime/samples/get-after-destroy/_config.js
@@ -10,4 +10,4 @@ export default {
const { foo } = component;
assert.equal(foo, undefined);
}
-}
\ No newline at end of file
+};
diff --git a/test/runtime/samples/head-if-block/_config.js b/test/runtime/samples/head-if-block/_config.js
index 26e1457be7..439ed2cb1b 100644
--- a/test/runtime/samples/head-if-block/_config.js
+++ b/test/runtime/samples/head-if-block/_config.js
@@ -9,4 +9,4 @@ export default {
component.condition = true;
assert.equal(window.document.title, 'woo!!!');
}
-};
\ No newline at end of file
+};
diff --git a/test/runtime/samples/head-if-block/main.svelte b/test/runtime/samples/head-if-block/main.svelte
index a6b115bf28..1656278b9e 100644
--- a/test/runtime/samples/head-if-block/main.svelte
+++ b/test/runtime/samples/head-if-block/main.svelte
@@ -6,4 +6,4 @@
{#if condition}
woo!!!
{/if}
-
\ No newline at end of file
+
diff --git a/test/runtime/samples/head-if-else-block/_config.js b/test/runtime/samples/head-if-else-block/_config.js
new file mode 100644
index 0000000000..7665bfe90b
--- /dev/null
+++ b/test/runtime/samples/head-if-else-block/_config.js
@@ -0,0 +1,14 @@
+export default {
+ props: {
+ condition: false
+ },
+
+ test({ assert, component, target, window }) {
+ assert.equal(window.document.title, '');
+ assert.equal(Boolean(window.document.getElementById('meta')), true);
+
+ component.condition = true;
+ assert.equal(window.document.title, 'woo!!!');
+ assert.equal(window.document.getElementById('meta'), null);
+ }
+};
diff --git a/test/runtime/samples/head-if-else-block/main.svelte b/test/runtime/samples/head-if-else-block/main.svelte
new file mode 100644
index 0000000000..a31bdf3330
--- /dev/null
+++ b/test/runtime/samples/head-if-else-block/main.svelte
@@ -0,0 +1,11 @@
+
+
+
+ {#if condition}
+ woo!!!
+ {:else}
+
+ {/if}
+
diff --git a/test/runtime/samples/head-if-else-raw-dynamic/_config.js b/test/runtime/samples/head-if-else-raw-dynamic/_config.js
new file mode 100644
index 0000000000..b6da617cb9
--- /dev/null
+++ b/test/runtime/samples/head-if-else-raw-dynamic/_config.js
@@ -0,0 +1,19 @@
+const foo = '';
+const bar = '';
+
+export default {
+ props: {
+ condition: false,
+ foo,
+ bar
+ },
+
+ test({ assert, component, window }) {
+ assert.equal(window.document.head.innerHTML.includes(foo), false);
+ assert.equal(window.document.head.innerHTML.includes(bar), true);
+
+ component.condition = true;
+ assert.equal(window.document.head.innerHTML.includes(foo), true);
+ assert.equal(window.document.head.innerHTML.includes(bar), false);
+ }
+};
diff --git a/test/runtime/samples/head-if-else-raw-dynamic/main.svelte b/test/runtime/samples/head-if-else-raw-dynamic/main.svelte
new file mode 100644
index 0000000000..ca322dad83
--- /dev/null
+++ b/test/runtime/samples/head-if-else-raw-dynamic/main.svelte
@@ -0,0 +1,11 @@
+
+
+
+ {#if condition}
+ {@html foo}
+ {:else}
+ {@html bar}
+ {/if}
+
diff --git a/test/runtime/samples/head-raw-dynamic/Bar.svelte b/test/runtime/samples/head-raw-dynamic/Bar.svelte
new file mode 100644
index 0000000000..11e5cb9ee8
--- /dev/null
+++ b/test/runtime/samples/head-raw-dynamic/Bar.svelte
@@ -0,0 +1,11 @@
+
+
+
+
+ {#if true}
+ {@html bar}
+ {/if}
+ bar!!!
+
diff --git a/test/runtime/samples/head-raw-dynamic/Foo.svelte b/test/runtime/samples/head-raw-dynamic/Foo.svelte
new file mode 100644
index 0000000000..f4fd5741ac
--- /dev/null
+++ b/test/runtime/samples/head-raw-dynamic/Foo.svelte
@@ -0,0 +1,7 @@
+
+
+
+ {@html foo}
+
diff --git a/test/runtime/samples/head-raw-dynamic/_config.js b/test/runtime/samples/head-raw-dynamic/_config.js
new file mode 100644
index 0000000000..61e86727ff
--- /dev/null
+++ b/test/runtime/samples/head-raw-dynamic/_config.js
@@ -0,0 +1,26 @@
+const foo = '';
+const bar = '';
+
+export default {
+ props: {
+ condition: 1,
+ foo,
+ bar
+ },
+
+ test({ assert, component, window }) {
+ assert.equal(window.document.head.innerHTML.includes(foo), true);
+
+ component.condition = false;
+ assert.equal(window.document.head.innerHTML.includes(foo), false);
+
+ component.condition = 2;
+ assert.equal(window.document.title, 'bar!!!');
+ assert.equal(window.document.head.innerHTML.includes(bar), true);
+ assert.equal(Boolean(window.document.getElementById('meta')), true);
+
+ component.condition = false;
+ assert.equal(window.document.head.innerHTML.includes(bar), false);
+ assert.equal(window.document.getElementById('meta'), null);
+ }
+};
diff --git a/test/runtime/samples/head-raw-dynamic/main.svelte b/test/runtime/samples/head-raw-dynamic/main.svelte
new file mode 100644
index 0000000000..69f341ae36
--- /dev/null
+++ b/test/runtime/samples/head-raw-dynamic/main.svelte
@@ -0,0 +1,12 @@
+
+
+{#if condition === 1}
+
+{:else if condition === 2}
+
+{/if}
diff --git a/test/runtime/samples/head-title-empty/_config.js b/test/runtime/samples/head-title-empty/_config.js
new file mode 100644
index 0000000000..497855156c
--- /dev/null
+++ b/test/runtime/samples/head-title-empty/_config.js
@@ -0,0 +1,5 @@
+export default {
+ test({ assert, window }) {
+ assert.equal(window.document.title, '');
+ }
+};
\ No newline at end of file
diff --git a/test/runtime/samples/head-title-empty/main.svelte b/test/runtime/samples/head-title-empty/main.svelte
new file mode 100644
index 0000000000..3f81715df5
--- /dev/null
+++ b/test/runtime/samples/head-title-empty/main.svelte
@@ -0,0 +1,3 @@
+
+
+
\ No newline at end of file
diff --git a/test/runtime/samples/html-entities/_config.js b/test/runtime/samples/html-entities/_config.js
index 1591f31a53..c8c2de8403 100644
--- a/test/runtime/samples/html-entities/_config.js
+++ b/test/runtime/samples/html-entities/_config.js
@@ -9,6 +9,6 @@ export default {
A
€
- ¬anentity;
+ ¬anentity;
`
};
\ No newline at end of file
diff --git a/test/runtime/samples/immutable-nested/Nested.svelte b/test/runtime/samples/immutable-nested/Nested.svelte
index 45385e9b0b..acb0b480a4 100644
--- a/test/runtime/samples/immutable-nested/Nested.svelte
+++ b/test/runtime/samples/immutable-nested/Nested.svelte
@@ -1,7 +1,7 @@
-Called {count} times.
\ No newline at end of file
+Called {count} times.
+{foo.bar} {mounted}
\ No newline at end of file
diff --git a/test/runtime/samples/immutable-nested/_config.js b/test/runtime/samples/immutable-nested/_config.js
index e5c515fc78..8b1dd7e68a 100644
--- a/test/runtime/samples/immutable-nested/_config.js
+++ b/test/runtime/samples/immutable-nested/_config.js
@@ -1,16 +1,36 @@
export default {
immutable: true,
- html: `
Called 1 times. `,
+ html: `
+
+
Called 1 times.
+
baz true
+
+ `,
- ssrHtml: `
Called 0 times. `,
+ ssrHtml: `
+
+
Called 0 times.
+
baz false
+
`,
- test({ assert, component, target, window }) {
- var nested = component.nested;
+ test({ assert, component, target }) {
+ const nested = component.nested;
- assert.htmlEqual(target.innerHTML, `
Called 1 times. `);
+ assert.htmlEqual(target.innerHTML, `
+
+
Called 1 times.
+
baz true
+
+ `);
+ // eslint-disable-next-line no-self-assign
nested.foo = nested.foo;
- assert.htmlEqual(target.innerHTML, `
Called 1 times. `);
+ assert.htmlEqual(target.innerHTML, `
+
+
Called 1 times.
+
baz true
+
+ `);
}
};
diff --git a/test/runtime/samples/immutable-nested/main.svelte b/test/runtime/samples/immutable-nested/main.svelte
index e50055be0c..4ccf7008cd 100644
--- a/test/runtime/samples/immutable-nested/main.svelte
+++ b/test/runtime/samples/immutable-nested/main.svelte
@@ -5,5 +5,5 @@
-
+
diff --git a/test/runtime/samples/immutable-option/_config.js b/test/runtime/samples/immutable-option/_config.js
index 0aaa742fbe..1224d0213a 100644
--- a/test/runtime/samples/immutable-option/_config.js
+++ b/test/runtime/samples/immutable-option/_config.js
@@ -4,6 +4,7 @@ export default {
html: `
Called 1 times. `,
test({ assert, component, target }) {
+ // eslint-disable-next-line no-self-assign
component.foo = component.foo;
assert.htmlEqual(target.innerHTML, `
Called 1 times. `);
}
diff --git a/test/runtime/samples/immutable-svelte-meta-false/_config.js b/test/runtime/samples/immutable-svelte-meta-false/_config.js
index 933c151d6b..664f99f087 100644
--- a/test/runtime/samples/immutable-svelte-meta-false/_config.js
+++ b/test/runtime/samples/immutable-svelte-meta-false/_config.js
@@ -4,6 +4,7 @@ export default {
html: `
Called 1 times. `,
test({ assert, component, target }) {
+ // eslint-disable-next-line no-self-assign
component.foo = component.foo;
assert.htmlEqual(target.innerHTML, `
Called 2 times. `);
}
diff --git a/test/runtime/samples/immutable-svelte-meta/_config.js b/test/runtime/samples/immutable-svelte-meta/_config.js
index 9bd32dbd11..4e39f36224 100644
--- a/test/runtime/samples/immutable-svelte-meta/_config.js
+++ b/test/runtime/samples/immutable-svelte-meta/_config.js
@@ -2,6 +2,7 @@ export default {
html: `
Called 1 times. `,
test({ assert, component, target }) {
+ // eslint-disable-next-line no-self-assign
component.foo = component.foo;
assert.htmlEqual(target.innerHTML, `
Called 1 times. `);
}
diff --git a/test/runtime/samples/internal-state/_config.js b/test/runtime/samples/internal-state/_config.js
index 09ea61a8eb..6b8440aaf3 100644
--- a/test/runtime/samples/internal-state/_config.js
+++ b/test/runtime/samples/internal-state/_config.js
@@ -1,18 +1,18 @@
export default {
- html: `
- internal: 1
- click me
- `,
+ html: `
+ internal: 1
+ click me
+ `,
- async test({ assert, target, window }) {
- const button = target.querySelector('button');
- const click = new window.MouseEvent('click');
+ async test({ assert, target, window }) {
+ const button = target.querySelector('button');
+ const click = new window.MouseEvent('click');
- await button.dispatchEvent(click);
+ await button.dispatchEvent(click);
- assert.htmlEqual(target.innerHTML, `
- internal: 1
- click me
- `);
- }
-};
\ No newline at end of file
+ assert.htmlEqual(target.innerHTML, `
+ internal: 1
+ click me
+ `);
+ }
+};
diff --git a/test/runtime/samples/isolated-text/_config.js b/test/runtime/samples/isolated-text/_config.js
new file mode 100644
index 0000000000..ec4332be5c
--- /dev/null
+++ b/test/runtime/samples/isolated-text/_config.js
@@ -0,0 +1,6 @@
+export default {
+ html: `
+ before
+ after
+ `
+};
\ No newline at end of file
diff --git a/test/runtime/samples/isolated-text/main.svelte b/test/runtime/samples/isolated-text/main.svelte
new file mode 100644
index 0000000000..fa48dea46e
--- /dev/null
+++ b/test/runtime/samples/isolated-text/main.svelte
@@ -0,0 +1,5 @@
+before
+
+
+
+after
\ No newline at end of file
diff --git a/test/runtime/samples/mixed-let-export/_config.js b/test/runtime/samples/mixed-let-export/_config.js
index 5ac8585742..f3da4215d9 100644
--- a/test/runtime/samples/mixed-let-export/_config.js
+++ b/test/runtime/samples/mixed-let-export/_config.js
@@ -1,9 +1,9 @@
export default {
- props: {
- a: 42
- },
+ props: {
+ a: 42
+ },
- html: `
- 42
- `
-}
+ html: `
+ 42
+ `
+};
diff --git a/test/runtime/samples/nbsp-div/_config.js b/test/runtime/samples/nbsp-div/_config.js
new file mode 100644
index 0000000000..5ab7a7f04b
--- /dev/null
+++ b/test/runtime/samples/nbsp-div/_config.js
@@ -0,0 +1,17 @@
+export default {
+ html: ` hello
+ hello
+ hello hello
`,
+
+ test({ assert, component, target }) {
+ const divList = target.querySelectorAll('div');
+ assert.equal( divList[0].textContent.charCodeAt( 0 ), 160 );
+ assert.equal( divList[1].textContent.charCodeAt( 0 ), 160 );
+ assert.equal( divList[1].textContent.charCodeAt( 6 ), 160 );
+ assert.equal( divList[1].textContent.charCodeAt( 7 ), 160 );
+ assert.equal( divList[2].textContent.charCodeAt( 0 ), 160 );
+ assert.equal( divList[2].textContent.charCodeAt( 6 ), 160 );
+ assert.equal( divList[2].textContent.charCodeAt( 7 ), 32 ); //normal space
+ assert.equal( divList[2].textContent.charCodeAt( 8 ), 160 );
+ }
+};
diff --git a/test/runtime/samples/nbsp-div/main.svelte b/test/runtime/samples/nbsp-div/main.svelte
new file mode 100644
index 0000000000..64557bfeb1
--- /dev/null
+++ b/test/runtime/samples/nbsp-div/main.svelte
@@ -0,0 +1,7 @@
+
+
+ {name}
+ {name}
+ {name} {name}
\ No newline at end of file
diff --git a/test/runtime/samples/ondestroy-deep/A.svelte b/test/runtime/samples/ondestroy-deep/A.svelte
new file mode 100644
index 0000000000..a1a740bc2e
--- /dev/null
+++ b/test/runtime/samples/ondestroy-deep/A.svelte
@@ -0,0 +1,15 @@
+
+
+
+ {#if yes}
+
+ {/if}
+
\ No newline at end of file
diff --git a/test/runtime/samples/ondestroy-deep/B.svelte b/test/runtime/samples/ondestroy-deep/B.svelte
new file mode 100644
index 0000000000..78b042f2d6
--- /dev/null
+++ b/test/runtime/samples/ondestroy-deep/B.svelte
@@ -0,0 +1,15 @@
+
+
+
+ {#if yes}
+
+ {/if}
+
\ No newline at end of file
diff --git a/test/runtime/samples/ondestroy-deep/C.svelte b/test/runtime/samples/ondestroy-deep/C.svelte
new file mode 100644
index 0000000000..27f33c93fc
--- /dev/null
+++ b/test/runtime/samples/ondestroy-deep/C.svelte
@@ -0,0 +1,8 @@
+
\ No newline at end of file
diff --git a/test/runtime/samples/ondestroy-deep/_config.js b/test/runtime/samples/ondestroy-deep/_config.js
new file mode 100644
index 0000000000..4431a2e163
--- /dev/null
+++ b/test/runtime/samples/ondestroy-deep/_config.js
@@ -0,0 +1,10 @@
+import { destroyed, reset } from './destroyed.js';
+
+export default {
+ test({ assert, component }) {
+ component.visible = false;
+ assert.deepEqual(destroyed, ['A', 'B', 'C']);
+
+ reset();
+ }
+};
\ No newline at end of file
diff --git a/test/runtime/samples/ondestroy-deep/destroyed.js b/test/runtime/samples/ondestroy-deep/destroyed.js
new file mode 100644
index 0000000000..fe05c1d241
--- /dev/null
+++ b/test/runtime/samples/ondestroy-deep/destroyed.js
@@ -0,0 +1,3 @@
+export const destroyed = [];
+
+export const reset = () => destroyed.length = 0;
\ No newline at end of file
diff --git a/test/runtime/samples/ondestroy-deep/main.svelte b/test/runtime/samples/ondestroy-deep/main.svelte
new file mode 100644
index 0000000000..d584dc1b85
--- /dev/null
+++ b/test/runtime/samples/ondestroy-deep/main.svelte
@@ -0,0 +1,9 @@
+
+
+{#if visible}
+
+{/if}
\ No newline at end of file
diff --git a/test/runtime/samples/prop-exports/_config.js b/test/runtime/samples/prop-exports/_config.js
index 631c9eb0ad..e1620c015f 100644
--- a/test/runtime/samples/prop-exports/_config.js
+++ b/test/runtime/samples/prop-exports/_config.js
@@ -2,29 +2,29 @@ import { writable } from '../../../../store';
export default {
props: {
- s1: writable(42),
- s2: writable(43),
- p1: 2,
- p3: 3,
- a1: writable(1),
- a2: 4,
- a6: writable(29),
- for: 'loop',
- continue: '...',
+ s1: writable(42),
+ s2: writable(43),
+ p1: 2,
+ p3: 3,
+ a1: writable(1),
+ a2: 4,
+ a6: writable(29),
+ for: 'loop',
+ continue: '...',
},
html: `
- $s1=42
- $s2=43
- p1=2
- p3=3
- $v1=1
- v2=4
- vi1=4
- $vs1=1
- vl0=hello
- vl1=test
- $s3=29
- loop...
- `
-}
+ $s1=42
+ $s2=43
+ p1=2
+ p3=3
+ $v1=1
+ v2=4
+ vi1=4
+ $vs1=1
+ vl0=hello
+ vl1=test
+ $s3=29
+ loop...
+ `
+};
diff --git a/test/runtime/samples/prop-subscribable/_config.js b/test/runtime/samples/prop-subscribable/_config.js
index 69f8104fab..84cde8c9af 100644
--- a/test/runtime/samples/prop-subscribable/_config.js
+++ b/test/runtime/samples/prop-subscribable/_config.js
@@ -1,4 +1,4 @@
-import { writable } from '../../../../store.js';
+import { writable } from '../../../../store';
export default {
props: {
diff --git a/test/runtime/samples/reactive-value-function-hoist-b/_config.js b/test/runtime/samples/reactive-value-function-hoist-b/_config.js
new file mode 100644
index 0000000000..04c4fd3f11
--- /dev/null
+++ b/test/runtime/samples/reactive-value-function-hoist-b/_config.js
@@ -0,0 +1,15 @@
+export default {
+ html: `
+ Click me
+ `,
+
+ async test({ assert, target, window }) {
+ const event = new window.MouseEvent('click');
+ const button = target.querySelector('button');
+
+ await button.dispatchEvent(event);
+ assert.htmlEqual(target.innerHTML, `
+ A,B,C
+ `);
+ }
+};
diff --git a/test/runtime/samples/reactive-value-function-hoist-b/main.svelte b/test/runtime/samples/reactive-value-function-hoist-b/main.svelte
new file mode 100644
index 0000000000..2e9ee6eefe
--- /dev/null
+++ b/test/runtime/samples/reactive-value-function-hoist-b/main.svelte
@@ -0,0 +1,10 @@
+
+
+Click me
diff --git a/test/runtime/samples/reactive-value-mutate-const/_config.js b/test/runtime/samples/reactive-value-mutate-const/_config.js
new file mode 100644
index 0000000000..da0a19dd28
--- /dev/null
+++ b/test/runtime/samples/reactive-value-mutate-const/_config.js
@@ -0,0 +1,17 @@
+export default {
+ html: `
+ Mutate a
+ {}
+ `,
+
+ async test({ assert, target }) {
+ const button = target.querySelector('button');
+ const click = new window.MouseEvent('click');
+
+ await button.dispatchEvent(click);
+ assert.htmlEqual(target.innerHTML, `
+ Mutate a
+ {"foo":42}
+ `);
+ }
+};
diff --git a/test/runtime/samples/reactive-value-mutate-const/main.svelte b/test/runtime/samples/reactive-value-mutate-const/main.svelte
new file mode 100644
index 0000000000..403544e5f1
--- /dev/null
+++ b/test/runtime/samples/reactive-value-mutate-const/main.svelte
@@ -0,0 +1,9 @@
+
+
+ a.foo = 42}>Mutate a
+{JSON.stringify(b)}
+
diff --git a/test/runtime/samples/script-style-non-top-level/_config.js b/test/runtime/samples/script-style-non-top-level/_config.js
index 1aade72239..86eddf4611 100644
--- a/test/runtime/samples/script-style-non-top-level/_config.js
+++ b/test/runtime/samples/script-style-non-top-level/_config.js
@@ -2,7 +2,7 @@ export default {
html: `
-
+
`
};
\ No newline at end of file
diff --git a/test/runtime/samples/script-style-non-top-level/main.svelte b/test/runtime/samples/script-style-non-top-level/main.svelte
index 94cf72e4bd..73b0dfcf38 100644
--- a/test/runtime/samples/script-style-non-top-level/main.svelte
+++ b/test/runtime/samples/script-style-non-top-level/main.svelte
@@ -1,4 +1,4 @@
-
+
\ No newline at end of file
diff --git a/test/runtime/samples/set-undefined-attr/_config.js b/test/runtime/samples/set-undefined-attr/_config.js
index e28bad8257..b23f51dfc9 100644
--- a/test/runtime/samples/set-undefined-attr/_config.js
+++ b/test/runtime/samples/set-undefined-attr/_config.js
@@ -1,5 +1,5 @@
export default {
- html: '
',
+ html: `
`,
- ssrHtml: '
'
+ ssrHtml: `
`,
};
diff --git a/test/runtime/samples/set-undefined-attr/main.svelte b/test/runtime/samples/set-undefined-attr/main.svelte
index 8191acbeff..77a1885415 100644
--- a/test/runtime/samples/set-undefined-attr/main.svelte
+++ b/test/runtime/samples/set-undefined-attr/main.svelte
@@ -3,10 +3,11 @@
export let foo = 1;
export let bar;
+ export let _class;
onMount(() => {
foo = undefined;
});
-
+
diff --git a/test/runtime/samples/spring/_config.js b/test/runtime/samples/spring/_config.js
new file mode 100644
index 0000000000..49367ce08b
--- /dev/null
+++ b/test/runtime/samples/spring/_config.js
@@ -0,0 +1,3 @@
+export default {
+ html: `0
`
+};
diff --git a/test/runtime/samples/spring/main.svelte b/test/runtime/samples/spring/main.svelte
new file mode 100644
index 0000000000..39c9afde1d
--- /dev/null
+++ b/test/runtime/samples/spring/main.svelte
@@ -0,0 +1,8 @@
+
+
+{$x}
\ No newline at end of file
diff --git a/test/runtime/samples/store-assignment-updates-reactive/_config.js b/test/runtime/samples/store-assignment-updates-reactive/_config.js
index a7439bde5c..e81b3bb180 100644
--- a/test/runtime/samples/store-assignment-updates-reactive/_config.js
+++ b/test/runtime/samples/store-assignment-updates-reactive/_config.js
@@ -1,4 +1,4 @@
-import { writable } from '../../../../store.js';
+import { writable } from '../../../../store';
const c = writable(0);
diff --git a/test/runtime/samples/store-assignment-updates-reactive/main.svelte b/test/runtime/samples/store-assignment-updates-reactive/main.svelte
index 18ec3bd7a7..9975ea87b8 100644
--- a/test/runtime/samples/store-assignment-updates-reactive/main.svelte
+++ b/test/runtime/samples/store-assignment-updates-reactive/main.svelte
@@ -1,5 +1,5 @@
+
+{status}
+
+{#each things as thing}
+ {#if visible}
+ {thing}
+ {/if}
+{/each}
\ No newline at end of file
diff --git a/test/server-side-rendering/index.js b/test/server-side-rendering/index.js
index 9f67ee06e9..cf6e5ad964 100644
--- a/test/server-side-rendering/index.js
+++ b/test/server-side-rendering/index.js
@@ -1,7 +1,6 @@
import * as assert from "assert";
import * as fs from "fs";
import * as path from "path";
-import * as glob from 'tiny-glob/sync.js';
import {
showOutput,
@@ -102,6 +101,8 @@ describe("ssr", () => {
delete require.cache[file];
});
+ delete global.window;
+
const compileOptions = Object.assign({ sveltePath }, config.compileOptions, {
generate: 'ssr'
});
diff --git a/test/server-side-rendering/samples/bindings-readonly/_expected.html b/test/server-side-rendering/samples/bindings-readonly/_expected.html
new file mode 100644
index 0000000000..af678acde0
--- /dev/null
+++ b/test/server-side-rendering/samples/bindings-readonly/_expected.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/test/server-side-rendering/samples/bindings-readonly/main.svelte b/test/server-side-rendering/samples/bindings-readonly/main.svelte
new file mode 100644
index 0000000000..3ff98a3ead
--- /dev/null
+++ b/test/server-side-rendering/samples/bindings-readonly/main.svelte
@@ -0,0 +1,44 @@
+
+
+
+
+
+
+
+
+
diff --git a/test/server-side-rendering/samples/styles-nested/_actual.css b/test/server-side-rendering/samples/styles-nested/_actual.css
deleted file mode 100644
index 775ae8a91c..0000000000
--- a/test/server-side-rendering/samples/styles-nested/_actual.css
+++ /dev/null
@@ -1,2 +0,0 @@
-div.svelte-bzh57p{color:red}
-div.svelte-4yw8vx{color:green}
\ No newline at end of file
diff --git a/test/server-side-rendering/samples/styles/_actual.css b/test/server-side-rendering/samples/styles/_actual.css
deleted file mode 100644
index 2025c64f84..0000000000
--- a/test/server-side-rendering/samples/styles/_actual.css
+++ /dev/null
@@ -1 +0,0 @@
-div.svelte-bzh57p{color:red}
\ No newline at end of file
diff --git a/test/server-side-rendering/samples/text-area-bind/_expected.html b/test/server-side-rendering/samples/text-area-bind/_expected.html
new file mode 100644
index 0000000000..c3c8441f56
--- /dev/null
+++ b/test/server-side-rendering/samples/text-area-bind/_expected.html
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/test/server-side-rendering/samples/text-area-bind/main.svelte b/test/server-side-rendering/samples/text-area-bind/main.svelte
new file mode 100644
index 0000000000..7126e09375
--- /dev/null
+++ b/test/server-side-rendering/samples/text-area-bind/main.svelte
@@ -0,0 +1,5 @@
+
+
+
\ No newline at end of file
diff --git a/test/setup.js b/test/setup.js
index 8bb73d81d0..7406a07dd9 100644
--- a/test/setup.js
+++ b/test/setup.js
@@ -7,7 +7,7 @@ process.env.TEST = true;
require.extensions['.js'] = function(module, filename) {
const exports = [];
- var code = fs.readFileSync(filename, 'utf-8')
+ let code = fs.readFileSync(filename, 'utf-8')
.replace(/^import \* as (\w+) from ['"]([^'"]+)['"];?/gm, 'var $1 = require("$2");')
.replace(/^import (\w+) from ['"]([^'"]+)['"];?/gm, 'var {default: $1} = require("$2");')
.replace(/^import {([^}]+)} from ['"](.+)['"];?/gm, 'var {$1} = require("$2");')
@@ -35,4 +35,4 @@ require.extensions['.js'] = function(module, filename) {
console.log(code); // eslint-disable-line no-console
throw err;
}
-};
\ No newline at end of file
+};
diff --git a/test/sourcemaps/index.js b/test/sourcemaps/index.js
index 79028719b9..ee169ebe1b 100644
--- a/test/sourcemaps/index.js
+++ b/test/sourcemaps/index.js
@@ -1,7 +1,7 @@
import * as fs from "fs";
import * as path from "path";
import * as assert from "assert";
-import { loadConfig, svelte } from "../helpers.js";
+import { svelte } from "../helpers.js";
import { SourceMapConsumer } from "source-map";
import { getLocator } from "locate-character";
@@ -18,8 +18,6 @@ describe("sourcemaps", () => {
}
(solo ? it.only : skip ? it.skip : it)(dir, () => {
- const config = loadConfig(`./sourcemaps/samples/${dir}/_config.js`);
-
const filename = path.resolve(
`test/sourcemaps/samples/${dir}/input.svelte`
);
diff --git a/test/store/index.js b/test/store/index.ts
similarity index 70%
rename from test/store/index.js
rename to test/store/index.ts
index 5f9176cffb..bbfe7099b4 100644
--- a/test/store/index.js
+++ b/test/store/index.ts
@@ -1,5 +1,5 @@
import * as assert from 'assert';
-import { readable, writable, derived, get } from '../../store.js';
+import { readable, writable, derived, get } from '../../store';
describe('store', () => {
describe('writable', () => {
@@ -30,10 +30,10 @@ describe('store', () => {
return () => called -= 1;
});
- const unsubscribe1 = store.subscribe(() => {});
+ const unsubscribe1 = store.subscribe(() => { });
assert.equal(called, 1);
- const unsubscribe2 = store.subscribe(() => {});
+ const unsubscribe2 = store.subscribe(() => { });
assert.equal(called, 1);
unsubscribe1();
@@ -49,7 +49,7 @@ describe('store', () => {
const store = writable(obj);
- store.subscribe(value => {
+ store.subscribe(() => {
called += 1;
});
@@ -59,6 +59,22 @@ describe('store', () => {
store.update(obj => obj);
assert.equal(called, 3);
});
+
+ it('only calls subscriber once initially, including on resubscriptions', () => {
+ let num = 0;
+ const store = writable(num, set => set(num += 1));
+
+ let count1 = 0;
+ let count2 = 0;
+
+ store.subscribe(() => count1 += 1)();
+ assert.equal(count1, 1);
+
+ const unsubscribe = store.subscribe(() => count2 += 1);
+ assert.equal(count2, 1);
+
+ unsubscribe();
+ });
});
describe('readable', () => {
@@ -73,7 +89,7 @@ describe('store', () => {
set(0);
return () => {
- tick = () => {};
+ tick = () => { };
running = false;
};
});
@@ -189,6 +205,34 @@ describe('store', () => {
unsubscribe();
});
+ it('prevents diamond dependency problem', () => {
+ const count = writable(0);
+ const values = [];
+
+ const a = derived(count, $count => {
+ return 'a' + $count;
+ });
+
+ const b = derived(count, $count => {
+ return 'b' + $count;
+ });
+
+ const combined = derived([a, b], ([a, b]) => {
+ return a + b;
+ });
+
+ const unsubscribe = combined.subscribe(v => {
+ values.push(v);
+ });
+
+ assert.deepEqual(values, ['a0b0']);
+
+ count.set(1);
+ assert.deepEqual(values, ['a0b0', 'a1b1']);
+
+ unsubscribe();
+ });
+
it('is updated with safe_not_equal logic', () => {
const arr = [0];
@@ -242,11 +286,47 @@ describe('store', () => {
assert.deepEqual(cleaned_up, [2, 3, 4]);
});
+
+ it('discards non-function return values', () => {
+ const num = writable(1);
+
+ const values = [];
+
+ const d = derived(num, ($num, set) => {
+ set($num * 2);
+ return {};
+ });
+
+ num.set(2);
+
+ const unsubscribe = d.subscribe(value => {
+ values.push(value);
+ });
+
+ num.set(3);
+ num.set(4);
+
+ assert.deepEqual(values, [4, 6, 8]);
+
+ unsubscribe();
+ });
+
+ it('allows derived with different types', () => {
+ const a = writable('one');
+ const b = writable(1);
+ const c = derived([a, b], ([a, b]) => `${a} ${b}`);
+
+ assert.deepEqual(get(c), 'one 1');
+
+ a.set('two');
+ b.set(2);
+ assert.deepEqual(get(c), 'two 2');
+ });
});
describe('get', () => {
it('gets the current value of a store', () => {
- const store = readable(42, () => {});
+ const store = readable(42, () => { });
assert.equal(get(store), 42);
});
});
diff --git a/test/test.js b/test/test.js
index 993b1f637c..cb89b3e9d1 100644
--- a/test/test.js
+++ b/test/test.js
@@ -2,6 +2,10 @@ const glob = require("tiny-glob/sync.js");
require("./setup");
-glob("*/index.js", { cwd: "test" }).forEach(function(file) {
+// bind internal to jsdom
+require("./helpers");
+require("../internal");
+
+glob("*/index.{js,ts}", { cwd: "test" }).forEach((file) => {
require("./" + file);
-});
\ No newline at end of file
+});
diff --git a/test/tsconfig.json b/test/tsconfig.json
new file mode 100644
index 0000000000..82eaf0245e
--- /dev/null
+++ b/test/tsconfig.json
@@ -0,0 +1,10 @@
+{
+ "extends": "../tsconfig.json",
+ "include": ["."],
+
+ "compilerOptions": {
+ "allowJs": true,
+ "checkJs": true,
+ "noEmit": true
+ }
+}
diff --git a/test/validator/index.js b/test/validator/index.js
index b26b087bb3..1e54cc20db 100644
--- a/test/validator/index.js
+++ b/test/validator/index.js
@@ -24,7 +24,7 @@ describe("validate", () => {
let error;
try {
- let { warnings } = svelte.compile(input, {
+ const { warnings } = svelte.compile(input, {
dev: config.dev,
legacy: config.legacy,
generate: false
@@ -59,7 +59,7 @@ describe("validate", () => {
assert.deepEqual(error.end, expected.end);
assert.equal(error.pos, expected.pos);
} catch (e) {
- console.error(error)
+ console.error(error); // eslint-disable-line no-console
throw e;
}
}
diff --git a/test/validator/samples/attribute-expected-equals/errors.json b/test/validator/samples/attribute-expected-equals/errors.json
new file mode 100644
index 0000000000..a3fa9d3cac
--- /dev/null
+++ b/test/validator/samples/attribute-expected-equals/errors.json
@@ -0,0 +1,15 @@
+[{
+ "code": "unexpected-token",
+ "message": "Expected =",
+ "start": {
+ "line": 5,
+ "column": 9,
+ "character": 50
+ },
+ "end": {
+ "line": 5,
+ "column": 9,
+ "character": 50
+ },
+ "pos": 50
+}]
diff --git a/test/validator/samples/attribute-expected-equals/input.svelte b/test/validator/samples/attribute-expected-equals/input.svelte
new file mode 100644
index 0000000000..91f4b0ca7b
--- /dev/null
+++ b/test/validator/samples/attribute-expected-equals/input.svelte
@@ -0,0 +1,5 @@
+
+
+Hello {name}!
diff --git a/test/validator/samples/catch-declares-error-variable/input.svelte b/test/validator/samples/catch-declares-error-variable/input.svelte
new file mode 100644
index 0000000000..b44e854cf5
--- /dev/null
+++ b/test/validator/samples/catch-declares-error-variable/input.svelte
@@ -0,0 +1,13 @@
+
+
+ {
+ try {
+ throw new Error('foo');
+ } catch (error) {
+ value = error;
+ }
+}}>Click to create error
+
+{String(value)}
diff --git a/test/validator/samples/catch-declares-error-variable/warnings.json b/test/validator/samples/catch-declares-error-variable/warnings.json
new file mode 100644
index 0000000000..0637a088a0
--- /dev/null
+++ b/test/validator/samples/catch-declares-error-variable/warnings.json
@@ -0,0 +1 @@
+[]
\ No newline at end of file
diff --git a/test/validator/samples/component-event-modifiers-invalid/errors.json b/test/validator/samples/component-event-modifiers-invalid/errors.json
new file mode 100644
index 0000000000..da608063fe
--- /dev/null
+++ b/test/validator/samples/component-event-modifiers-invalid/errors.json
@@ -0,0 +1,15 @@
+[{
+ "message": "Event modifiers other than 'once' can only be used on DOM elements",
+ "code": "invalid-event-modifier",
+ "start": {
+ "line": 6,
+ "column": 8,
+ "character": 93
+ },
+ "end": {
+ "line": 6,
+ "column": 40,
+ "character": 125
+ },
+ "pos": 93
+}]
diff --git a/test/validator/samples/component-event-modifiers-invalid/input.svelte b/test/validator/samples/component-event-modifiers-invalid/input.svelte
new file mode 100644
index 0000000000..8f7ce54d7a
--- /dev/null
+++ b/test/validator/samples/component-event-modifiers-invalid/input.svelte
@@ -0,0 +1,6 @@
+
+
+
\ No newline at end of file
diff --git a/test/validator/samples/contenteditable-dynamic/errors.json b/test/validator/samples/contenteditable-dynamic/errors.json
new file mode 100644
index 0000000000..0c4c5585a6
--- /dev/null
+++ b/test/validator/samples/contenteditable-dynamic/errors.json
@@ -0,0 +1,15 @@
+[{
+ "code": "dynamic-contenteditable-attribute",
+ "message": "'contenteditable' attribute cannot be dynamic if element uses two-way binding",
+ "start": {
+ "line": 6,
+ "column": 8,
+ "character": 73
+ },
+ "end": {
+ "line": 6,
+ "column": 32,
+ "character": 97
+ },
+ "pos": 73
+}]
\ No newline at end of file
diff --git a/test/validator/samples/contenteditable-dynamic/input.svelte b/test/validator/samples/contenteditable-dynamic/input.svelte
new file mode 100644
index 0000000000..8dfa91a354
--- /dev/null
+++ b/test/validator/samples/contenteditable-dynamic/input.svelte
@@ -0,0 +1,6 @@
+
+
diff --git a/test/validator/samples/contenteditable-missing/errors.json b/test/validator/samples/contenteditable-missing/errors.json
new file mode 100644
index 0000000000..53d5af4928
--- /dev/null
+++ b/test/validator/samples/contenteditable-missing/errors.json
@@ -0,0 +1,15 @@
+[{
+ "code": "missing-contenteditable-attribute",
+ "message": "'contenteditable' attribute is required for textContent and innerHTML two-way bindings",
+ "start": {
+ "line": 4,
+ "column": 8,
+ "character": 48
+ },
+ "end": {
+ "line": 4,
+ "column": 31,
+ "character": 71
+ },
+ "pos": 48
+}]
\ No newline at end of file
diff --git a/test/validator/samples/contenteditable-missing/input.svelte b/test/validator/samples/contenteditable-missing/input.svelte
new file mode 100644
index 0000000000..dae1088994
--- /dev/null
+++ b/test/validator/samples/contenteditable-missing/input.svelte
@@ -0,0 +1,4 @@
+
+
diff --git a/tsconfig.json b/tsconfig.json
index fdb7367e05..39476f3dd1 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -1,18 +1,30 @@
{
- "compilerOptions": {
- "target": "ES6",
- "diagnostics": true,
- "noImplicitThis": true,
- "noEmitOnError": true,
- "allowJs": true,
- "lib": ["es5", "es6", "dom"],
- "importHelpers": true,
- "moduleResolution": "node"
- },
- "include": [
- "src"
- ],
- "exclude": [
- "node_modules"
- ]
+ "include": [],
+
+ "compilerOptions": {
+ "rootDir": "src",
+
+ // target node v8+ (https://node.green/)
+ // the only missing feature is Array.prototype.values
+ "lib": ["es2017"],
+ "target": "es2017",
+
+ "declaration": true,
+ "declarationDir": "types",
+
+ "noEmitOnError": true,
+ "noErrorTruncation": true,
+
+ // rollup takes care of these
+ "module": "esnext",
+ "moduleResolution": "node",
+ "resolveJsonModule": true,
+ "allowSyntheticDefaultImports": true,
+
+ // TODO: error all the things
+ //"strict": true,
+ "noImplicitThis": true,
+ "noUnusedLocals": true,
+ "noUnusedParameters": true
+ }
}