Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mishig25/mishig25.github.io
https://github.com/mishig25/mishig25.github.io
Last synced: 20 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/mishig25/mishig25.github.io
- Owner: mishig25
- Created: 2024-06-19T22:02:19.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-14T13:04:23.000Z (6 months ago)
- Last Synced: 2024-12-03T15:48:43.809Z (about 1 month ago)
- Language: Svelte
- Size: 196 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# sveltekit-gh-pages
> Minimal static [SvelteKit](https://kit.svelte.dev/) set-up made deployable to [GitHub Pages](https://metonym.github.io/sveltekit-gh-pages/).
## 1) Use the static adapter
Install the [SvelteKit static adapter](https://github.com/sveltejs/kit/tree/master/packages/adapter-static) to prerender the app.
**package.json**
```diff
"devDependencies": {
+ "@sveltejs/adapter-static": "^3.0.1",
"@sveltejs/kit": "^2.5.4",
"@sveltejs/vite-plugin-svelte": "^3.0.2",
"gh-pages": "^6.1.1",
"svelte": "^4.2.12",
"vite": "^5.1.6"
}
```**svelte.config.js**
```diff
+ import adapter from "@sveltejs/adapter-static";/** @type {import('@sveltejs/kit').Config} */
const config = {
kit: {
+ adapter: adapter(),
},
};export default config;
```
Ensure your top-level `+layout.js` exports `prerender = true`. Note that for SvelteKit version 2, [trailingSlash](https://kit.svelte.dev/docs/page-options#trailingslash) should be set to "always" so that the app does not redirect the URL to `/about`.
```js
// src/routes/+layout.js
export const prerender = true;export const trailingSlash = "always";
```## 2) Modify `paths.base` in the config
`kit.paths.base` should be your repo URL subpath (see the [Vite docs](https://vitejs.dev/guide/static-deploy.html#github-pages)). In the example below, replace `/sveltekit-gh-pages` with your repository name.
```diff
import adapter from "@sveltejs/adapter-static";/** @type {import('@sveltejs/kit').Config} */
const config = {
kit: {
adapter: adapter(),
+ paths: {
+ base: process.env.NODE_ENV === "production" ? "/sveltekit-gh-pages" : "",
+ },
},
};export default config;
```
**Note:** You will also need to prepend relative paths with the [SvelteKit `base` path](https://kit.svelte.dev/docs/modules#$app-paths) so that your app can build successfully for production.
```svelte
import { base } from "$app/paths";
About
```## 3) Add a `.nojekyll` file to the `/static` folder
The last step is to add an empty `.nojekyll` file to the static folder to [bypass Jekyll on GitHub Pages](https://github.blog/2009-12-29-bypassing-jekyll-on-github-pages/). SvelteKit will copy `static` assets to the final build folder.
**package.json**
```json
{
"scripts": {
"dev": "vite dev",
"build": "vite build",
"deploy": "gh-pages -d build -t true"
}
}
```**The `deploy` script**
The deploy script instructs `gh-pages` to do the following:
- `-d build`: Publish the `build` folder
- `-t true`: Include dotfiles (e.g., `.nojekyll`)---
## Quick start
Use [degit](https://github.com/Rich-Harris/degit) to quickly scaffold a new project from this repository:
```sh
npx degit metonym/sveltekit-gh-pages my-app
cd my-app && npm install
```## Deploying to GitHub Pages
First, build the app by running `npm run build`.
Then, run `npm run deploy` to deploy the app to GitHub Pages.