convert to ts pt.2
This commit is contained in:
		
							
								
								
									
										3
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| { | ||||
|   "recommendations": ["svelte.svelte-vscode"] | ||||
| } | ||||
							
								
								
									
										319
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										319
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -17,7 +17,9 @@ | ||||
|         "@rollup/plugin-image": "^3.0.3", | ||||
|         "@rollup/plugin-node-resolve": "^15.2.3", | ||||
|         "@rollup/plugin-terser": "^0.4.4", | ||||
|         "@rollup/plugin-typescript": "^11.1.5", | ||||
|         "@sveltejs/vite-plugin-svelte": "^3.0.1", | ||||
|         "@tsconfig/svelte": "^5.0.2", | ||||
|         "autoprefixer": "^10.4.16", | ||||
|         "concurrently": "^8.2.2", | ||||
|         "electron": "^21.2.0", | ||||
| @@ -33,7 +35,11 @@ | ||||
|         "rollup-plugin-svelte": "^7.1.6", | ||||
|         "sirv-cli": "^2.0.2", | ||||
|         "svelte": "^4.2.8", | ||||
|         "svelte-check": "^3.6.2", | ||||
|         "svelte-preprocess": "^5.1.3", | ||||
|         "tailwindcss": "^3.3.6", | ||||
|         "tslib": "^2.6.2", | ||||
|         "typescript": "^5.3.3", | ||||
|         "wait-on": "^7.2.0" | ||||
|       } | ||||
|     }, | ||||
| @@ -978,6 +984,32 @@ | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@rollup/plugin-typescript": { | ||||
|       "version": "11.1.5", | ||||
|       "resolved": "https://registry.npmjs.org/@rollup/plugin-typescript/-/plugin-typescript-11.1.5.tgz", | ||||
|       "integrity": "sha512-rnMHrGBB0IUEv69Q8/JGRD/n4/n6b3nfpufUu26axhUcboUzv/twfZU8fIBbTOphRAe0v8EyxzeDpKXqGHfyDA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@rollup/pluginutils": "^5.0.1", | ||||
|         "resolve": "^1.22.1" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=14.0.0" | ||||
|       }, | ||||
|       "peerDependencies": { | ||||
|         "rollup": "^2.14.0||^3.0.0||^4.0.0", | ||||
|         "tslib": "*", | ||||
|         "typescript": ">=3.7.0" | ||||
|       }, | ||||
|       "peerDependenciesMeta": { | ||||
|         "rollup": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "tslib": { | ||||
|           "optional": true | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@rollup/pluginutils": { | ||||
|       "version": "5.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.1.0.tgz", | ||||
| @@ -1266,6 +1298,12 @@ | ||||
|         "node": ">=10.13.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@tsconfig/svelte": { | ||||
|       "version": "5.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/@tsconfig/svelte/-/svelte-5.0.2.tgz", | ||||
|       "integrity": "sha512-BRbo1fOtyVbhfLyuCWw6wAWp+U8UQle+ZXu84MYYWzYSEB28dyfnRBIE99eoG+qdAC0po6L2ScIEivcT07UaMA==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/@types/debug": { | ||||
|       "version": "4.1.12", | ||||
|       "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.12.tgz", | ||||
| @@ -1334,6 +1372,12 @@ | ||||
|         "xmlbuilder": ">=11.0.1" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@types/pug": { | ||||
|       "version": "2.0.10", | ||||
|       "resolved": "https://registry.npmjs.org/@types/pug/-/pug-2.0.10.tgz", | ||||
|       "integrity": "sha512-Sk/uYFOBAB7mb74XcpizmH0KOR2Pv3D2Hmrh1Dmy5BmK3MpdSa5kqZcg6EKBdklU0bFXX9gCfzvpnyUehrPIuA==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/@types/resolve": { | ||||
|       "version": "1.20.2", | ||||
|       "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.20.2.tgz", | ||||
| @@ -2058,6 +2102,15 @@ | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/callsites": { | ||||
|       "version": "3.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", | ||||
|       "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", | ||||
|       "dev": true, | ||||
|       "engines": { | ||||
|         "node": ">=6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/camelcase-css": { | ||||
|       "version": "2.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", | ||||
| @@ -2713,6 +2766,15 @@ | ||||
|         "node": ">=6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/detect-indent": { | ||||
|       "version": "6.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-6.1.0.tgz", | ||||
|       "integrity": "sha512-reYkTUJAZb9gUuZ2RvVCNhVHdg62RHnJ7WJl8ftMi4diZ6NWlciOzQN88pUhSELEwflJht4oQDv0F0BMlwaYtA==", | ||||
|       "dev": true, | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/detect-node": { | ||||
|       "version": "2.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.1.0.tgz", | ||||
| @@ -3190,6 +3252,12 @@ | ||||
|       "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", | ||||
|       "optional": true | ||||
|     }, | ||||
|     "node_modules/es6-promise": { | ||||
|       "version": "3.3.1", | ||||
|       "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz", | ||||
|       "integrity": "sha512-SOp9Phqvqn7jtEUxPWdWfWoLmyt2VaJ6MpvP9Comy1MceMXqE6bxvaTu4iaxpYYPzhny28Lc+M87/c2cPK6lDg==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/esbuild": { | ||||
|       "version": "0.19.11", | ||||
|       "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.11.tgz", | ||||
| @@ -3942,6 +4010,31 @@ | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/import-fresh": { | ||||
|       "version": "3.3.0", | ||||
|       "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", | ||||
|       "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "parent-module": "^1.0.0", | ||||
|         "resolve-from": "^4.0.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=6" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/sindresorhus" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/import-fresh/node_modules/resolve-from": { | ||||
|       "version": "4.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", | ||||
|       "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", | ||||
|       "dev": true, | ||||
|       "engines": { | ||||
|         "node": ">=4" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/import-from": { | ||||
|       "version": "3.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/import-from/-/import-from-3.0.0.tgz", | ||||
| @@ -4429,6 +4522,15 @@ | ||||
|         "node": ">=4" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/min-indent": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", | ||||
|       "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==", | ||||
|       "dev": true, | ||||
|       "engines": { | ||||
|         "node": ">=4" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/mini-svg-data-uri": { | ||||
|       "version": "1.4.4", | ||||
|       "resolved": "https://registry.npmjs.org/mini-svg-data-uri/-/mini-svg-data-uri-1.4.4.tgz", | ||||
| @@ -4494,15 +4596,15 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/mkdirp": { | ||||
|       "version": "1.0.4", | ||||
|       "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", | ||||
|       "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", | ||||
|       "version": "0.5.6", | ||||
|       "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", | ||||
|       "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "minimist": "^1.2.6" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "mkdirp": "bin/cmd.js" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=10" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/mri": { | ||||
| @@ -4707,6 +4809,18 @@ | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/parent-module": { | ||||
|       "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, | ||||
|       "dependencies": { | ||||
|         "callsites": "^3.0.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/path-is-absolute": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", | ||||
| @@ -5671,18 +5785,15 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/rimraf": { | ||||
|       "version": "3.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", | ||||
|       "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", | ||||
|       "version": "2.7.1", | ||||
|       "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", | ||||
|       "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "glob": "^7.1.3" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "rimraf": "bin.js" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/rimraf/node_modules/glob": { | ||||
| @@ -5988,6 +6099,18 @@ | ||||
|       "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/sander": { | ||||
|       "version": "0.5.1", | ||||
|       "resolved": "https://registry.npmjs.org/sander/-/sander-0.5.1.tgz", | ||||
|       "integrity": "sha512-3lVqBir7WuKDHGrKRDn/1Ye3kwpXaDOMsiRP1wd6wpZW56gJhsbp5RqQpA6JG/P+pkXizygnr1dKR8vzWaVsfA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "es6-promise": "^3.1.2", | ||||
|         "graceful-fs": "^4.1.3", | ||||
|         "mkdirp": "^0.5.1", | ||||
|         "rimraf": "^2.5.2" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/sanitize-filename": { | ||||
|       "version": "1.6.3", | ||||
|       "resolved": "https://registry.npmjs.org/sanitize-filename/-/sanitize-filename-1.6.3.tgz", | ||||
| @@ -6181,6 +6304,21 @@ | ||||
|       "integrity": "sha512-9LK+E7Hv5R9u4g4C3p+jjLstaLe11MDsL21UpYaCNmapvMkYhqCV4A/f/3gyH8QjMyh6l68q9xC85vihY9ahMQ==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "node_modules/sorcery": { | ||||
|       "version": "0.11.0", | ||||
|       "resolved": "https://registry.npmjs.org/sorcery/-/sorcery-0.11.0.tgz", | ||||
|       "integrity": "sha512-J69LQ22xrQB1cIFJhPfgtLuI6BpWRiWu1Y3vSsIwK/eAScqJxd/+CJlUuHQRdX2C9NGFamq+KqNywGgaThwfHw==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@jridgewell/sourcemap-codec": "^1.4.14", | ||||
|         "buffer-crc32": "^0.2.5", | ||||
|         "minimist": "^1.2.0", | ||||
|         "sander": "^0.5.0" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "sorcery": "bin/sorcery" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/source-map": { | ||||
|       "version": "0.6.1", | ||||
|       "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", | ||||
| @@ -6297,6 +6435,18 @@ | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/strip-indent": { | ||||
|       "version": "3.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz", | ||||
|       "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "min-indent": "^1.0.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/style-inject": { | ||||
|       "version": "0.3.0", | ||||
|       "resolved": "https://registry.npmjs.org/style-inject/-/style-inject-0.3.0.tgz", | ||||
| @@ -6458,6 +6608,28 @@ | ||||
|         "node": ">=16" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/svelte-check": { | ||||
|       "version": "3.6.2", | ||||
|       "resolved": "https://registry.npmjs.org/svelte-check/-/svelte-check-3.6.2.tgz", | ||||
|       "integrity": "sha512-E6iFh4aUCGJLRz6QZXH3gcN/VFfkzwtruWSRmlKrLWQTiO6VzLsivR6q02WYLGNAGecV3EocqZuCDrC2uttZ0g==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "@jridgewell/trace-mapping": "^0.3.17", | ||||
|         "chokidar": "^3.4.1", | ||||
|         "fast-glob": "^3.2.7", | ||||
|         "import-fresh": "^3.2.1", | ||||
|         "picocolors": "^1.0.0", | ||||
|         "sade": "^1.7.4", | ||||
|         "svelte-preprocess": "^5.1.0", | ||||
|         "typescript": "^5.0.3" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "svelte-check": "bin/svelte-check" | ||||
|       }, | ||||
|       "peerDependencies": { | ||||
|         "svelte": "^3.55.0 || ^4.0.0-next.0 || ^4.0.0 || ^5.0.0-next.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/svelte-hmr": { | ||||
|       "version": "0.15.3", | ||||
|       "resolved": "https://registry.npmjs.org/svelte-hmr/-/svelte-hmr-0.15.3.tgz", | ||||
| @@ -6470,6 +6642,69 @@ | ||||
|         "svelte": "^3.19.0 || ^4.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/svelte-preprocess": { | ||||
|       "version": "5.1.3", | ||||
|       "resolved": "https://registry.npmjs.org/svelte-preprocess/-/svelte-preprocess-5.1.3.tgz", | ||||
|       "integrity": "sha512-xxAkmxGHT+J/GourS5mVJeOXZzne1FR5ljeOUAMXUkfEhkLEllRreXpbl3dIYJlcJRfL1LO1uIAPpBpBfiqGPw==", | ||||
|       "dev": true, | ||||
|       "hasInstallScript": true, | ||||
|       "dependencies": { | ||||
|         "@types/pug": "^2.0.6", | ||||
|         "detect-indent": "^6.1.0", | ||||
|         "magic-string": "^0.30.5", | ||||
|         "sorcery": "^0.11.0", | ||||
|         "strip-indent": "^3.0.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">= 16.0.0", | ||||
|         "pnpm": "^8.0.0" | ||||
|       }, | ||||
|       "peerDependencies": { | ||||
|         "@babel/core": "^7.10.2", | ||||
|         "coffeescript": "^2.5.1", | ||||
|         "less": "^3.11.3 || ^4.0.0", | ||||
|         "postcss": "^7 || ^8", | ||||
|         "postcss-load-config": "^2.1.0 || ^3.0.0 || ^4.0.0 || ^5.0.0", | ||||
|         "pug": "^3.0.0", | ||||
|         "sass": "^1.26.8", | ||||
|         "stylus": "^0.55.0", | ||||
|         "sugarss": "^2.0.0 || ^3.0.0 || ^4.0.0", | ||||
|         "svelte": "^3.23.0 || ^4.0.0-next.0 || ^4.0.0 || ^5.0.0-next.0", | ||||
|         "typescript": ">=3.9.5 || ^4.0.0 || ^5.0.0" | ||||
|       }, | ||||
|       "peerDependenciesMeta": { | ||||
|         "@babel/core": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "coffeescript": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "less": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "postcss": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "postcss-load-config": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "pug": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "sass": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "stylus": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "sugarss": { | ||||
|           "optional": true | ||||
|         }, | ||||
|         "typescript": { | ||||
|           "optional": true | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/svelte/node_modules/estree-walker": { | ||||
|       "version": "3.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-3.0.3.tgz", | ||||
| @@ -6760,6 +6995,18 @@ | ||||
|         "node": ">=10" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/tar/node_modules/mkdirp": { | ||||
|       "version": "1.0.4", | ||||
|       "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", | ||||
|       "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", | ||||
|       "dev": true, | ||||
|       "bin": { | ||||
|         "mkdirp": "bin/cmd.js" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=10" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/temp-file": { | ||||
|       "version": "3.4.0", | ||||
|       "resolved": "https://registry.npmjs.org/temp-file/-/temp-file-3.4.0.tgz", | ||||
| @@ -6880,6 +7127,41 @@ | ||||
|         "tmp": "^0.2.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/tmp/node_modules/glob": { | ||||
|       "version": "7.2.3", | ||||
|       "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", | ||||
|       "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "fs.realpath": "^1.0.0", | ||||
|         "inflight": "^1.0.4", | ||||
|         "inherits": "2", | ||||
|         "minimatch": "^3.1.1", | ||||
|         "once": "^1.3.0", | ||||
|         "path-is-absolute": "^1.0.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": "*" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/tmp/node_modules/rimraf": { | ||||
|       "version": "3.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", | ||||
|       "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", | ||||
|       "dev": true, | ||||
|       "dependencies": { | ||||
|         "glob": "^7.1.3" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "rimraf": "bin.js" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/to-readable-stream": { | ||||
|       "version": "1.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", | ||||
| @@ -6960,6 +7242,19 @@ | ||||
|         "url": "https://github.com/sponsors/sindresorhus" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/typescript": { | ||||
|       "version": "5.3.3", | ||||
|       "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz", | ||||
|       "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==", | ||||
|       "dev": true, | ||||
|       "bin": { | ||||
|         "tsc": "bin/tsc", | ||||
|         "tsserver": "bin/tsserver" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=14.17" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/undici-types": { | ||||
|       "version": "5.26.5", | ||||
|       "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", | ||||
|   | ||||
							
								
								
									
										11
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								package.json
									
									
									
									
									
								
							| @@ -29,7 +29,8 @@ | ||||
|     "electron": "wait-on http://localhost:8080 && electron .", | ||||
|     "electron-dev": "concurrently \"yarn run dev\" \"yarn run electron\"", | ||||
|     "preelectron-pack": "yarn run build", | ||||
|     "electron-pack": "electron-builder" | ||||
|     "electron-pack": "electron-builder", | ||||
|     "check": "svelte-check --tsconfig ./tsconfig.json" | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "custom-electron-titlebar": "^4.2.7", | ||||
| @@ -40,7 +41,9 @@ | ||||
|     "@rollup/plugin-image": "^3.0.3", | ||||
|     "@rollup/plugin-node-resolve": "^15.2.3", | ||||
|     "@rollup/plugin-terser": "^0.4.4", | ||||
|     "@rollup/plugin-typescript": "^11.1.5", | ||||
|     "@sveltejs/vite-plugin-svelte": "^3.0.1", | ||||
|     "@tsconfig/svelte": "^5.0.2", | ||||
|     "autoprefixer": "^10.4.16", | ||||
|     "concurrently": "^8.2.2", | ||||
|     "electron": "^21.2.0", | ||||
| @@ -56,7 +59,11 @@ | ||||
|     "rollup-plugin-svelte": "^7.1.6", | ||||
|     "sirv-cli": "^2.0.2", | ||||
|     "svelte": "^4.2.8", | ||||
|     "svelte-check": "^3.6.2", | ||||
|     "svelte-preprocess": "^5.1.3", | ||||
|     "tailwindcss": "^3.3.6", | ||||
|     "tslib": "^2.6.2", | ||||
|     "typescript": "^5.3.3", | ||||
|     "wait-on": "^7.2.0" | ||||
|   } | ||||
| } | ||||
| } | ||||
							
								
								
									
										143
									
								
								rollup.config.js
									
									
									
									
									
								
							
							
						
						
									
										143
									
								
								rollup.config.js
									
									
									
									
									
								
							| @@ -1,82 +1,93 @@ | ||||
| import svelte from 'rollup-plugin-svelte'; | ||||
| import commonjs from '@rollup/plugin-commonjs'; | ||||
| import resolve from '@rollup/plugin-node-resolve'; | ||||
| import livereload from 'rollup-plugin-livereload'; | ||||
| import terser from '@rollup/plugin-terser'; | ||||
| import css from 'rollup-plugin-css-only'; | ||||
| import postcss from 'rollup-plugin-postcss'; | ||||
| import image from '@rollup/plugin-image'; | ||||
| import svelte from "rollup-plugin-svelte"; | ||||
| import commonjs from "@rollup/plugin-commonjs"; | ||||
| import resolve from "@rollup/plugin-node-resolve"; | ||||
| import livereload from "rollup-plugin-livereload"; | ||||
| import terser from "@rollup/plugin-terser"; | ||||
| import css from "rollup-plugin-css-only"; | ||||
| import postcss from "rollup-plugin-postcss"; | ||||
| import image from "@rollup/plugin-image"; | ||||
| import sveltePreprocess from "svelte-preprocess"; | ||||
| import typescript from "@rollup/plugin-typescript"; | ||||
|  | ||||
| const production = !process.env.ROLLUP_WATCH; | ||||
|  | ||||
| function serve() { | ||||
| 	let server; | ||||
|   let server; | ||||
|  | ||||
| 	function toExit() { | ||||
| 		if (server) server.kill(0); | ||||
| 	} | ||||
|   function toExit() { | ||||
|     if (server) server.kill(0); | ||||
|   } | ||||
|  | ||||
| 	return { | ||||
| 		writeBundle() { | ||||
| 			if (server) return; | ||||
| 			server = require('child_process').spawn('npm', ['run', 'start', '--', '--dev'], { | ||||
| 				stdio: ['ignore', 'inherit', 'inherit'], | ||||
| 				shell: true | ||||
| 			}); | ||||
|   return { | ||||
|     writeBundle() { | ||||
|       if (server) return; | ||||
|       server = require("child_process").spawn("npm", [ | ||||
|         "run", | ||||
|         "start", | ||||
|         "--", | ||||
|         "--dev", | ||||
|       ], { | ||||
|         stdio: ["ignore", "inherit", "inherit"], | ||||
|         shell: true, | ||||
|       }); | ||||
|  | ||||
| 			process.on('SIGTERM', toExit); | ||||
| 			process.on('exit', toExit); | ||||
| 		} | ||||
| 	}; | ||||
|       process.on("SIGTERM", toExit); | ||||
|       process.on("exit", toExit); | ||||
|     }, | ||||
|   }; | ||||
| } | ||||
|  | ||||
| export default { | ||||
| 	input: 'src/main.js', | ||||
| 	output: { | ||||
| 		sourcemap: true, | ||||
| 		format: 'iife', | ||||
| 		name: 'app', | ||||
| 		file: 'public/build/bundle.js' | ||||
| 	}, | ||||
| 	plugins: [ | ||||
| 		svelte({ | ||||
| 			compilerOptions: { | ||||
| 				// enable run-time checks when not in production | ||||
| 				dev: !production | ||||
| 			} | ||||
| 		}), | ||||
|   input: "src/main.ts", | ||||
|   output: { | ||||
|     sourcemap: true, | ||||
|     format: "iife", | ||||
|     name: "app", | ||||
|     file: "public/build/bundle.js", | ||||
|   }, | ||||
|   plugins: [ | ||||
|     svelte({ | ||||
|       preprocess: sveltePreprocess({ sourceMap: !production }), | ||||
|       compilerOptions: { | ||||
|         // enable run-time checks when not in production | ||||
|         dev: !production, | ||||
|       }, | ||||
|     }), | ||||
|  | ||||
| 		// we'll extract any component CSS out into | ||||
| 		// a separate file - better for performance | ||||
| 		css({ output: 'bundle.css' }), | ||||
| 		postcss(), | ||||
|     // we'll extract any component CSS out into | ||||
|     // a separate file - better for performance | ||||
|     css({ output: "bundle.css" }), | ||||
|     postcss(), | ||||
|  | ||||
| 		// If you have external dependencies installed from | ||||
| 		// npm, you'll most likely need these plugins. In | ||||
| 		// some cases you'll need additional configuration - | ||||
| 		// consult the documentation for details: | ||||
| 		// https://github.com/rollup/plugins/tree/master/packages/commonjs | ||||
| 		resolve({ | ||||
| 			browser: true, | ||||
| 			dedupe: ['svelte'] | ||||
| 		}), | ||||
| 		commonjs(), | ||||
| 		image(), | ||||
|     // If you have external dependencies installed from | ||||
|     // npm, you'll most likely need these plugins. In | ||||
|     // some cases you'll need additional configuration - | ||||
|     // consult the documentation for details: | ||||
|     // https://github.com/rollup/plugins/tree/master/packages/commonjs | ||||
|     resolve({ | ||||
|       browser: true, | ||||
|       dedupe: ["svelte"], | ||||
|     }), | ||||
|     commonjs(), | ||||
|     typescript({ | ||||
|       sourceMap: !production, | ||||
|       inlineSources: !production, | ||||
|     }), | ||||
|     image(), | ||||
|  | ||||
| 		// In dev mode, call `npm run start` once | ||||
| 		// the bundle has been generated | ||||
| 		!production && serve(), | ||||
|     // In dev mode, call `npm run start` once | ||||
|     // the bundle has been generated | ||||
|     !production && serve(), | ||||
|  | ||||
| 		// Watch the `public` directory and refresh the | ||||
| 		// browser on changes when not in production | ||||
| 		!production && livereload('public'), | ||||
|     // Watch the `public` directory and refresh the | ||||
|     // browser on changes when not in production | ||||
|     !production && livereload("public"), | ||||
|  | ||||
| 		// If we're building for production (npm run build | ||||
| 		// instead of npm run dev), minify | ||||
| 		production && terser(), | ||||
|  | ||||
| 	], | ||||
| 	watch: { | ||||
| 		clearScreen: false | ||||
| 	} | ||||
|     // If we're building for production (npm run build | ||||
|     // instead of npm run dev), minify | ||||
|     production && terser(), | ||||
|   ], | ||||
|   watch: { | ||||
|     clearScreen: false, | ||||
|   }, | ||||
| }; | ||||
|   | ||||
| @@ -1,121 +0,0 @@ | ||||
| // @ts-check | ||||
|  | ||||
| /** This script modifies the project to support TS code in .svelte files like: | ||||
|  | ||||
|   <script lang="ts"> | ||||
|   	export let name: string; | ||||
|   </script> | ||||
|   | ||||
|   As well as validating the code for CI. | ||||
|   */ | ||||
|  | ||||
| /**  To work on this script: | ||||
|   rm -rf test-template template && git clone sveltejs/template test-template && node scripts/setupTypeScript.js test-template | ||||
| */ | ||||
|  | ||||
| const fs = require("fs") | ||||
| const path = require("path") | ||||
| const { argv } = require("process") | ||||
|  | ||||
| const projectRoot = argv[2] || path.join(__dirname, "..") | ||||
|  | ||||
| // Add deps to pkg.json | ||||
| const packageJSON = JSON.parse(fs.readFileSync(path.join(projectRoot, "package.json"), "utf8")) | ||||
| packageJSON.devDependencies = Object.assign(packageJSON.devDependencies, { | ||||
|   "svelte-check": "^2.0.0", | ||||
|   "svelte-preprocess": "^4.0.0", | ||||
|   "@rollup/plugin-typescript": "^8.0.0", | ||||
|   "typescript": "^4.0.0", | ||||
|   "tslib": "^2.0.0", | ||||
|   "@tsconfig/svelte": "^2.0.0" | ||||
| }) | ||||
|  | ||||
| // Add script for checking | ||||
| packageJSON.scripts = Object.assign(packageJSON.scripts, { | ||||
|   "check": "svelte-check --tsconfig ./tsconfig.json" | ||||
| }) | ||||
|  | ||||
| // Write the package JSON | ||||
| fs.writeFileSync(path.join(projectRoot, "package.json"), JSON.stringify(packageJSON, null, "  ")) | ||||
|  | ||||
| // mv src/main.js to main.ts - note, we need to edit rollup.config.js for this too | ||||
| const beforeMainJSPath = path.join(projectRoot, "src", "main.js") | ||||
| const afterMainTSPath = path.join(projectRoot, "src", "main.ts") | ||||
| fs.renameSync(beforeMainJSPath, afterMainTSPath) | ||||
|  | ||||
| // Switch the app.svelte file to use TS | ||||
| const appSveltePath = path.join(projectRoot, "src", "App.svelte") | ||||
| let appFile = fs.readFileSync(appSveltePath, "utf8") | ||||
| appFile = appFile.replace("<script>", '<script lang="ts">') | ||||
| appFile = appFile.replace("export let name;", 'export let name: string;') | ||||
| fs.writeFileSync(appSveltePath, appFile) | ||||
|  | ||||
| // Edit rollup config | ||||
| const rollupConfigPath = path.join(projectRoot, "rollup.config.js") | ||||
| let rollupConfig = fs.readFileSync(rollupConfigPath, "utf8") | ||||
|  | ||||
| // Edit imports | ||||
| rollupConfig = rollupConfig.replace(`'@rollup/plugin-terser';`, `'@rollup/plugin-terser'; | ||||
| import sveltePreprocess from 'svelte-preprocess'; | ||||
| import typescript from '@rollup/plugin-typescript';`) | ||||
|  | ||||
| // Replace name of entry point | ||||
| rollupConfig = rollupConfig.replace(`'src/main.js'`, `'src/main.ts'`) | ||||
|  | ||||
| // Add preprocessor | ||||
| rollupConfig = rollupConfig.replace( | ||||
|   'compilerOptions:', | ||||
|   'preprocess: sveltePreprocess({ sourceMap: !production }),\n\t\t\tcompilerOptions:' | ||||
| ); | ||||
|  | ||||
| // Add TypeScript | ||||
| rollupConfig = rollupConfig.replace( | ||||
|   'commonjs(),', | ||||
|   'commonjs(),\n\t\ttypescript({\n\t\t\tsourceMap: !production,\n\t\t\tinlineSources: !production\n\t\t}),' | ||||
| ); | ||||
| fs.writeFileSync(rollupConfigPath, rollupConfig) | ||||
|  | ||||
| // Add TSConfig | ||||
| const tsconfig = `{ | ||||
|   "extends": "@tsconfig/svelte/tsconfig.json", | ||||
|  | ||||
|   "include": ["src/**/*"], | ||||
|   "exclude": ["node_modules/*", "__sapper__/*", "public/*"] | ||||
| }` | ||||
| const tsconfigPath =  path.join(projectRoot, "tsconfig.json") | ||||
| fs.writeFileSync(tsconfigPath, tsconfig) | ||||
|  | ||||
| // Add global.d.ts | ||||
| const dtsPath =  path.join(projectRoot, "src", "global.d.ts") | ||||
| fs.writeFileSync(dtsPath, `/// <reference types="svelte" />`) | ||||
|  | ||||
| // Delete this script, but not during testing | ||||
| if (!argv[2]) { | ||||
|   // Remove the script | ||||
|   fs.unlinkSync(path.join(__filename)) | ||||
|  | ||||
|   // Check for Mac's DS_store file, and if it's the only one left remove it | ||||
|   const remainingFiles = fs.readdirSync(path.join(__dirname)) | ||||
|   if (remainingFiles.length === 1 && remainingFiles[0] === '.DS_store') { | ||||
|     fs.unlinkSync(path.join(__dirname, '.DS_store')) | ||||
|   } | ||||
|  | ||||
|   // Check if the scripts folder is empty | ||||
|   if (fs.readdirSync(path.join(__dirname)).length === 0) { | ||||
|     // Remove the scripts folder | ||||
|     fs.rmdirSync(path.join(__dirname)) | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Adds the extension recommendation | ||||
| fs.mkdirSync(path.join(projectRoot, ".vscode"), { recursive: true }) | ||||
| fs.writeFileSync(path.join(projectRoot, ".vscode", "extensions.json"), `{ | ||||
|   "recommendations": ["svelte.svelte-vscode"] | ||||
| } | ||||
| `) | ||||
|  | ||||
| console.log("Converted to TypeScript.") | ||||
|  | ||||
| if (fs.existsSync(path.join(projectRoot, "node_modules"))) { | ||||
|   console.log("\nYou will need to re-run your dependency manager to get started.") | ||||
| } | ||||
| @@ -1,4 +1,4 @@ | ||||
| <script> | ||||
| <script lang="ts"> | ||||
|   import { | ||||
|     Avatar, | ||||
|     Dropdown, | ||||
|   | ||||
							
								
								
									
										1
									
								
								src/global.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								src/global.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| /// <reference types="svelte" /> | ||||
| @@ -1,6 +1,6 @@ | ||||
| import "./app.pcss"; | ||||
| import App from "./App.svelte"; | ||||
| import '@fontsource/prompt'; | ||||
| import "@fontsource/prompt"; | ||||
| 
 | ||||
| const app = new App({ | ||||
|   target: document.body, | ||||
							
								
								
									
										4
									
								
								src/types/images.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								src/types/images.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| declare module "*.jpg"; | ||||
| declare module "*.jpeg"; | ||||
| declare module "*.png"; | ||||
| declare module "*.svg"; | ||||
							
								
								
									
										9
									
								
								tsconfig.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								tsconfig.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| { | ||||
|   "extends": "@tsconfig/svelte/tsconfig.json", | ||||
|  | ||||
|   "include": ["src/**/*"], | ||||
|   "exclude": ["node_modules/*", "__sapper__/*", "public/*"], | ||||
|   "compilerOptions": { | ||||
|     "typeRoots": ["node_modules/@types", "src/types"] | ||||
|   } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user