diff --git a/CONTRIBUTING.md b/.github/contributing.md similarity index 83% rename from CONTRIBUTING.md rename to .github/contributing.md index 205721d43bf8..a01eee800627 100644 --- a/CONTRIBUTING.md +++ b/.github/contributing.md @@ -1,4 +1,4 @@ -# Contributing +# VitePress Contributing Guide This is a guide to help those who are interested in contributing to VitePress! @@ -11,11 +11,11 @@ This is a guide to help those who are interested in contributing to VitePress! ### Setup VitePress dev environment 1. Clone the VitePress repo -1. Install dependencies +2. Install dependencies ``` yarn ``` -1. Create symlink to allow projects to link to local VitePress dev environment +3. Create symlink to allow projects to link to local VitePress dev environment ```bash yarn link ``` @@ -25,13 +25,11 @@ This is a guide to help those who are interested in contributing to VitePress! info You can now run `yarn link "vitepress"` in the projects where you want to use this package and it will be used instead. ✨ Done in 0.05s. ``` -1. Start VitePress local dev environment +4. Start VitePress local dev environment ```bash yarn dev ``` - - ### Setup local VitePress project 1. Open up terminal @@ -65,7 +63,3 @@ This is a guide to help those who are interested in contributing to VitePress! ``` And with that, you are now ready to contribute to the VitePress project! πŸŽ‰ - -## Releasing - -After making sure tests are passing, run `yarn run release` (to be tested in non-unix environments like Windows) to run the bash script `scripts/release.sh`. diff --git a/.gitignore b/.gitignore index 6e9dbd352bc1..d66ddeade70e 100644 --- a/.gitignore +++ b/.gitignore @@ -1,6 +1,7 @@ -/dist -/node_modules +node_modules +dist /src/client/shared /src/node/shared *.log .DS_Store +TODOs.md diff --git a/README.md b/README.md index 62f6d9526dcf..3542d62d2042 100644 --- a/README.md +++ b/README.md @@ -4,96 +4,18 @@ > [VuePress](http://vuepress.vuejs.org/)' little brother, built on top of [vite](https://github.com/vuejs/vite) -**Note this is early WIP! Currently the focus is on making Vite stable and feature complete first. It is not recommended to use this for anything serious yet.** +**:fire: Note this is early WIP! Currently the focus is on making Vite stable and feature complete first. It is not recommended to use this for anything serious yet.** -``` bash -npm install -D vitepress -echo '# Hello VitePress' > index.md +## Documentation -# starts dev server -npx vitepress - -# build > .vitepress/dist -npx vitepress build -``` - -## Customization - -Configuration can be done via `.vitepress/config.js` (see `src/node/config.ts`) - -You can develop your custom theme by adding the following files: - -`.vitepress/theme/Layout.vue` - -```vue - -``` - -`.vitepress/theme/index.js` - -```js -import Layout from './Layout.vue' - -export default { - Layout, - NotFound: () => 'custom 404', // <- this is a Vue 3 functional component - enhanceApp({ app, router, siteData }) { - // app is the Vue 3 app instance from createApp() - // router is VitePress' custom router (see `lib/app/router.js`) - // siteData is a ref of current site-level metadata. - } -} -``` - -Unlike VuePress, the only file with a fixed location in a theme is `index.js` - everything else is imported and exported there like in a normal application. - -## Motivation - -I love VuePress, but being built on top of webpack, the time it takes to spin up the dev server for a simple doc site with a few pages is just becoming unbearable. Even HMR updates can take up to seconds to reflect in the browser! - -As a reference, the [Composition API RFC repo](https://github.com/vuejs/composition-api-rfc) is just two pages, but it takes 4 seconds to spin up the server, and almost 2 seconds for any edit to reflect in the browser. - -Fundamentally, this is because VuePress is a webpack app under the hood. Even with just two pages, it's a full on webpack project (including all the theme source files) being compiled. It gets even worse when the project has many pages - every page must first be fully compiled before the server can even display anything! - -Incidentally, [vite](https://github.com/vuejs/vite) solves these problems really well: nearly instant server start, on-demand compilation that only compiles the page being served, and lightning fast HMR. Plus, there are a few additional design issues I have noted in VuePress over time, but never had the time to fix due to the amount of refactoring it would require. - -Now, with `vite` and Vue 3, it is time to rethink what a "Vue-powered static site generator" can really be. - -## Improvements over VuePress - -- Uses Vue 3. - - Leverages Vue 3's improved template static analysis to stringify static content as much as possible. Static content is sent as string literals instead of JavaScript render function code - the JS payload is therefore *much* cheaper to parse, and hydration also becomes faster. - - Note the optimization is applied while still allowing the user to freely mix Vue components inside markdown content - the compiler does the static/dynamic separation for you automatically and you never need to think about it. - -- Uses `vite` under the hood: - - Faster dev server start - - Faster hot updates - - Faster build (uses Rollup internally) - -- Lighter page weight. - - Vue 3 tree-shaking + Rollup code splitting - - Does not ship metadata for every page on every request. This decouples page weight from total number of pages. Only the current page's metadata is sent. Client side navigation fetches the new page's component and metadata together. - - Does not use `vue-router` because the need of VitePress is very simple and specific - a simple custom router (under 200 LOC) is used instead. - - (WIP) i18n locale data should also be fetched on demand. - -## Other Differences - -- More opinionated and less configurable: VitePress aims to scale back the complexity in the current VuePress and restart from its minimalist roots. - -- Future oriented: VitePress only targets browsers that support native ES module imports. It encourages the use of native JavaScript without transpilation, and CSS variables for theming. - -## Will this become the next VuePress in the future? - -Maybe! It's currently under a different name so that we don't over commit to the compatibility with the current VuePress ecosystem (mostly themes and plugins). We'll see how close we can get without compromising the design goals listed above. But the overall idea is that VitePress will have a drastically more minimal theming API (preferring JavaScript APIs instead of file layout conventions) and likely no plugins (all customization is done in themes). +To check out docs, visit [vitepress.vuejs.org](https://vitepress.vuejs.org). ## Want to contribute? -Check out our [contributing guide](https://github.com/vuejs/vitepress/blob/master/CONTRIBUTING.md) for more information! +Please make sure to read the [Contributing Guide](./.github/contributing.md) before making a pull request. ## License -MIT +[MIT](https://opensource.org/licenses/MIT) + +Copyright (c) 2019-present, Yuxi (Evan) You diff --git a/docs/.vitepress/config.js b/docs/.vitepress/config.js new file mode 100644 index 000000000000..3a3c70951b51 --- /dev/null +++ b/docs/.vitepress/config.js @@ -0,0 +1,35 @@ +module.exports = { + lang: 'en-US', + title: 'VitePress', + description: 'Vite & Vue powered static site generator.', + + themeConfig: { + repo: 'vuejs/vitepress', + docsDir: 'docs', + editLinkText: 'Edit this page on GitHub', + + nav: [ + { text: 'Guide', link: '/' }, + { text: 'Config Reference', link: '/config/' }, + { + text: 'Release Notes', + link: 'https://github.com/vuejs/vitepress/releases' + } + ], + + sidebar: { + '/guide/': [ + { + text: 'Introduction', + children: [ + { text: 'What is VitePress?', link: '/' }, + { text: 'Getting Started', link: '/guide/getting-started' }, + { text: 'Configuration', link: '/guide/configuration' }, + { text: 'Customization', link: '/guide/customization' } + ] + } + ], + '/config/': [{ text: 'Config Reference', link: '/config/' }] + } + } +} diff --git a/docs/config/index.md b/docs/config/index.md new file mode 100644 index 000000000000..17e6b8814a0b --- /dev/null +++ b/docs/config/index.md @@ -0,0 +1,3 @@ +# Config Reference + +Coming soon... diff --git a/docs/guide/configuration.md b/docs/guide/configuration.md new file mode 100644 index 000000000000..17a894291d83 --- /dev/null +++ b/docs/guide/configuration.md @@ -0,0 +1,23 @@ +# Configuration + +Without any configuration, the page is pretty minimal, and the user has no way to navigate around the site. To customize your site, let’s first create a `.vitepress` directory inside your docs directory. This is where all VitePress-specific files will be placed. Your project structure is probably like this: + +```bash +. +β”œβ”€ docs +β”‚ β”œβ”€ .vitepress +β”‚ β”‚ └─ config.js +β”‚ └─ index.md +└─ package.json +```` + +The essential file for configuring a VitePress site is `.vuepress/config.js`, which should export a JavaScript object: + +```js +module.exports = { + title: 'Hello VitePress', + description: 'Just playing around.' +} +``` + +Check out the [Config Reference](/config/) for a full list of options. diff --git a/docs/guide/customization.md b/docs/guide/customization.md new file mode 100644 index 000000000000..6406d6be0e3d --- /dev/null +++ b/docs/guide/customization.md @@ -0,0 +1,51 @@ +# Customization + +You can develop your custom theme by adding the `.vitepress/theme/index.js` file. + +```bash +. +β”œβ”€ docs +β”‚ β”œβ”€ .vitepress +β”‚ β”‚ β”œβ”€ theme +β”‚ β”‚ β”‚ └─ index.js +β”‚ β”‚ └─ config.js +β”‚ └─ index.md +└─ package.json +```` + +In `.vitepress/theme/index.js`, you must export theme object and register your own theme layout. Let's say you have your own `Layout` component like this. + +```vue + + +``` + +Then include it in `.vitepress/theme/index.js`. + +```js +// .vitepress/theme/index.js +import Layout from './Layout.vue' + +export default { + Layout, + NotFound: () => 'custom 404', // <- this is a Vue 3 functional component + enhanceApp({ app, router, siteData }) { + // app is the Vue 3 app instance from `createApp()`. router is VitePress' + // custom router. `siteData`` is a `ref`` of current site-level metadata. + } +} +``` + +If you want to extend the default theme, you can import it from `vitepress/dist/client/theme-default`. + +```js +// .vitepress/theme/index.js +import DefaultTheme from 'vitepress/dist/client/theme-default' + +export default { + ...DefaultTheme +} +``` diff --git a/docs/guide/getting-started.md b/docs/guide/getting-started.md new file mode 100644 index 000000000000..ea9603378d98 --- /dev/null +++ b/docs/guide/getting-started.md @@ -0,0 +1,46 @@ +# Getting Started + +This section will help you build a basic VuePress documentation site from ground up. If you already have an existing project and would like to keep documentation inside the project, start from Step 3. + +- **Step. 1:** Create and change into a new directory. + + ```bash + $ mkdir vitepress-starter && cd vitepress-starter + ``` + +- **Step. 2:** Initialize with your preferred package manager. + + ```bash + $ yarn init + ``` + +- **Step. 3:** Install VuePress locally. + + ```bash + $ yarn add --dev vitepress + ``` + +- **Step. 4:** Create your first document. + + ```bash + $ mkdir docs && echo '# Hello VitePress' > docs/index.md + ``` + +- **Step. 5:** Add some scripts to `package.json`. + + ```json + { + "scripts": { + "docs:dev": "vitepress dev docs", + "docs:build": "vitepress build docs" + } + } + ``` + +- **Step. 6:** Serve the documentation site in the local server. + + ```bash + $ yarn docs:dev + ``` + + VitePress will start a hot-reloading development server at http://localhost:3000. diff --git a/docs/index.md b/docs/index.md new file mode 100644 index 000000000000..1b4330fa565a --- /dev/null +++ b/docs/index.md @@ -0,0 +1,52 @@ +# What is VitePress? + +::: warning WARNING +VitePress is early WIP! Currently the focus is on making Vite stable and feature complete first. It is not recommended to use this for anything serious yet. +::: + +VitePress is [VuePress](https://vuepress.vuejs.org/)' little brother, built on top of [Vite](https://github.com/vitejs/vite). + +## Motivation + +We love VuePress, but being built on top of Webpack, the time it takes to spin up the dev server for a simple doc site with a few pages is just becoming unbearable. Even HMR updates can take up to seconds to reflect in the browser! + +As a reference, the [Composition API RFC repo](https://github.com/vuejs/composition-api-rfc) is just two pages, but it takes 4 seconds to spin up the server and almost 2 seconds for any edit to reflect in the browser. + +Fundamentally, this is because VuePress is a Webpack app under the hood. Even with just two pages, it's a full on Webpack project (including all the theme source files) being compiled. It gets even worse when the project has many pages – every page must first be fully compiled before the server can even display anything! + +Incidentally, Vite solves these problems really well: nearly instant server start, an on-demand compilation that only compiles the page being served, and lightning-fast HMR. Plus, there are a few additional design issues I have noted in VuePress over time but never had the time to fix due to the amount of refactoring it would require. + +Now, with Vite and Vue 3, it is time to rethink what a "Vue-powered static site generator" can really be. + +## Improvements Over VuePress + +There're couple of things that are improved from VuePress. + +### It Uses Vue 3 + +Leverages Vue 3's improved template static analysis to stringify static content as much as possible. Static content is sent as string literals instead of JavaScript render function code – the JS payload is therefore *much* cheaper to parse, and hydration also becomes faster. + +Note the optimization is applied while still allowing the user to freely mix Vue components inside markdown content – the compiler does the static/dynamic separation for you automatically and you never need to think about it. + +### It Uses Vite Under The Hood + +- Faster dev server start +- Faster hot updates +- Faster build (uses Rollup internally) + +### Lighter Page Weight + +- Vue 3 tree-shaking + Rollup code splitting +- Does not ship metadata for every page on every request. This decouples page weight from total number of pages. Only the current page's metadata is sent. Client side navigation fetches the new page's component and metadata together. +- Does not use `vue-router` because the need of VitePress is very simple and specific - a simple custom router (under 200 LOC) is used instead. +- (WIP) i18n locale data should also be fetched on demand. + +## Other Differences + +VitePress is more opinionated and less configurable: VitePress aims to scale back the complexity in the current VuePress and restart from its minimalist roots. + +VitePress is future oriented: VitePress only targets browsers that support native ES module imports. It encourages the use of native JavaScript without transpilation, and CSS variables for theming. + +## Will this become the next VuePress in the future? + +Probably not. It's currently under a different name so that we don't over commit to the compatibility with the current VuePress ecosystem (mostly themes and plugins). We'll see how close we can get without compromising the design goals listed above. But the overall idea is that VitePress will have a drastically more minimal theming API (preferring JavaScript APIs instead of file layout conventions) and likely no plugins (all customization is done in themes). diff --git a/docs/package.json b/docs/package.json new file mode 100644 index 000000000000..b73384dc3734 --- /dev/null +++ b/docs/package.json @@ -0,0 +1,4 @@ +{ + "name": "vitepress-docs", + "private": true +} diff --git a/package.json b/package.json index 348b12b8525d..fcd62064ef11 100644 --- a/package.json +++ b/package.json @@ -25,7 +25,10 @@ "lint:js": "prettier --check --write \"{bin,scripts,src}/**/*.js\"", "lint:ts": "prettier --check --write --parser typescript \"{src,types}/**/*.ts\"", "changelog": "conventional-changelog -p angular -i CHANGELOG.md -s", - "release": "bash scripts/release.sh" + "release": "bash scripts/release.sh", + "docs": "run-p dev docs-dev", + "docs-dev": "node ./bin/vitepress dev docs", + "docs-build": "yarn build && node ./bin/vitepress build docs" }, "engines": { "node": ">=10.0.0"