From aa346ddd86c71f19b8d024f5d8d9ee66e3dd957c Mon Sep 17 00:00:00 2001 From: Ben McCann <322311+benmccann@users.noreply.github.com> Date: Thu, 4 Aug 2022 15:12:03 -0700 Subject: [PATCH 1/3] Convert site to SvelteKit --- packages/site/.gitignore | 6 +- packages/site/package.json | 20 +- packages/site/rollup.config.js | 150 --- packages/site/src/{template.html => app.html} | 8 +- packages/site/src/client.js | 5 - packages/site/src/components/Nav.svelte | 4 +- .../Repl/Input/ComponentSelector.svelte | 2 +- .../routes/{_error.svelte => __error.svelte} | 10 +- .../{_layout.svelte => __layout.svelte} | 0 packages/site/src/routes/docs.svelte | 4 +- packages/site/src/server.js | 17 - packages/site/src/service-worker.js | 82 -- packages/site/svelte.config.js | 14 + packages/site/vite.config.js | 38 + pnpm-lock.yaml | 1183 +++++++++++++---- 15 files changed, 970 insertions(+), 573 deletions(-) delete mode 100644 packages/site/rollup.config.js rename packages/site/src/{template.html => app.html} (94%) delete mode 100644 packages/site/src/client.js rename packages/site/src/routes/{_error.svelte => __error.svelte} (70%) rename packages/site/src/routes/{_layout.svelte => __layout.svelte} (100%) delete mode 100644 packages/site/src/server.js delete mode 100644 packages/site/src/service-worker.js create mode 100644 packages/site/svelte.config.js create mode 100644 packages/site/vite.config.js diff --git a/packages/site/.gitignore b/packages/site/.gitignore index d076dd10..8c1592e4 100644 --- a/packages/site/.gitignore +++ b/packages/site/.gitignore @@ -1,6 +1,4 @@ .DS_Store -node_modules -yarn-error.log +/node_modules /cypress/screenshots/ -/__sapper__/ -dist +/.svelte-kit diff --git a/packages/site/package.json b/packages/site/package.json index 3c7c0f51..32c4d9e0 100644 --- a/packages/site/package.json +++ b/packages/site/package.json @@ -4,10 +4,9 @@ "version": "0.0.1", "type": "module", "scripts": { - "dev": "sapper dev --ext '.svelte .svx'", - "build:site": "sapper build --legacy --ext '.svelte .svx'", - "export": "sapper export --legacy --ext '.svelte .svx'", - "start": "node __sapper__/build", + "dev": "vite dev", + "build": "vite build", + "preview": "vite preview", "cy:run": "cypress run", "cy:open": "cypress open", "test": "run-p --race dev cy:run", @@ -15,11 +14,8 @@ }, "private": "true", "dependencies": { - "compression": "^1.7.1", "mdsvex": "^0.7.1-beta.3", - "polka": "^0.5.0", "refractor": "^2.10.0", - "sirv": "^0.4.0", "yootils": "^0.0.15" }, "devDependencies": { @@ -33,20 +29,22 @@ "@rollup/plugin-json": "^4.1.0", "@rollup/plugin-node-resolve": "^13.0.5", "@rollup/plugin-replace": "^3.0.0", + "@sveltejs/kit": "next", + "@sveltejs/adapter-auto": "next", "codemirror": "^5.49.2", "npm-run-all": "^4.1.5", - "prism-svelte": "^0.4.4", + "prism-svelte": "^0.5.0", "rehype-autolink-headings": "^2.0.5", "rehype-slug": "^2.0.3", "remark-syntax-highlight": "^0.1.3", "rollup": "^2.58.0", "rollup-plugin-svelte": "^7.1.0", "rollup-plugin-terser": "^7.0.2", - "sapper": "^0.29.3", - "svelte": "^3.7.1", + "svelte": "^3.49.0", "svelte-json-tree": "^0.0.7", "typeface-catamaran": "^0.0.72", "typeface-roboto": "^0.0.75", - "unist-util-visit": "^2.0.1" + "unist-util-visit": "^2.0.1", + "vite": "^3.0.4" } } diff --git a/packages/site/rollup.config.js b/packages/site/rollup.config.js deleted file mode 100644 index e1f2b9a0..00000000 --- a/packages/site/rollup.config.js +++ /dev/null @@ -1,150 +0,0 @@ -import 'prismjs'; -import "prism-svelte"; -import "./prism/svx.js"; - - - -import resolve from "@rollup/plugin-node-resolve"; -import replace from "@rollup/plugin-replace"; -import commonjs from "@rollup/plugin-commonjs"; -import svelte from "rollup-plugin-svelte"; -import babel from "@rollup/plugin-babel"; -import { terser } from "rollup-plugin-terser"; -import config from "sapper/config/rollup.js"; -import pkg from "./package.json"; - -import slug from "rehype-slug"; -import link from "rehype-autolink-headings"; - -import { highlight, highlighter } from "./prism/prism.js"; - -import { extname } from "path"; - -const mode = process.env.NODE_ENV; -const dev = mode === "development"; -const legacy = !!process.env.SAPPER_LEGACY_BUILD; - -import { mdsvex } from "mdsvex"; - -function mdsvex_transform() { - return { - async transform(code, id) { - if (extname(id) !== ".svtext") return; - - const c = ( - await mdsvex({ - highlight: { - alias: { - ts: "typescript", - mdx: "markdown", - svelte: "svelte", - svx: "svx", - mdsvex: "svx", - sig: "ts", - } - }, - extension: '.svtext', - rehypePlugins: [slug, link] - }).markup({ content: code, filename: id }) - ).code; - return `export default \`${c.replace(/`/g, "\\`").trim()}\`;`; - } - }; -} - -export default { - client: { - input: config.client.input(), - output: config.client.output(), - globals: { - global: "window" - }, - plugins: [ - replace({ - "process.browser": true, - "process.env.NODE_ENV": JSON.stringify(mode) - }), - mdsvex_transform(), - svelte({ - extensions: [".svelte", ".svx"], - compilerOptions: { - dev, - hydratable: true - }, - emitCss: true, - preprocess: mdsvex({ extension: '.svx' }) - }), - resolve({ preferBuiltins: false, browser: true }), - commonjs(), - - legacy && - babel({ - extensions: [".js", ".mjs", ".html", ".svelte"], - babelHelpers: "runtime", - exclude: ["node_modules/@babel/**"], - presets: [ - [ - "@babel/preset-env", - { - targets: "> 0.25%, not dead" - } - ] - ], - plugins: [ - "@babel/plugin-syntax-dynamic-import", - [ - "@babel/plugin-transform-runtime", - { - useESModules: true - } - ] - ] - }), - - !dev && - terser({ - module: true - }) - ] - }, - - server: { - input: config.server.input(), - output: config.server.output(), - plugins: [ - replace({ - "process.browser": false, - "process.env.NODE_ENV": JSON.stringify(mode) - }), - mdsvex_transform(), - svelte({ - extensions: [".svelte", ".svx"], - compilerOptions: { - generate: "ssr", - dev - }, - preprocess: mdsvex({ extension: '.svx' }) - }), - resolve({ browser: true }), - commonjs() - ], - external: Object.keys(pkg.dependencies).concat( - require("module").builtinModules || - Object.keys(process.binding("natives")) - ) - }, - - serviceworker: { - input: config.serviceworker.input(), - output: config.serviceworker.output(), - plugins: [ - resolve(), - replace({ - "process.browser": true, - "process.env.NODE_ENV": JSON.stringify(mode) - }), - commonjs(), - !dev && terser() - ] - } -}; diff --git a/packages/site/src/template.html b/packages/site/src/app.html similarity index 94% rename from packages/site/src/template.html rename to packages/site/src/app.html index 9221dd2f..a60712f0 100644 --- a/packages/site/src/template.html +++ b/packages/site/src/app.html @@ -4,8 +4,6 @@ - %sapper.base% - @@ -48,14 +46,12 @@ /> - %sapper.styles% %sapper.head% + %sveltekit.head%
-