Skip to content

Commit

Permalink
docs: rewrite getting started + init tips
Browse files Browse the repository at this point in the history
  • Loading branch information
yyx990803 committed Mar 7, 2023
1 parent 5ebee75 commit 49bcc25
Show file tree
Hide file tree
Showing 6 changed files with 113 additions and 111 deletions.
3 changes: 2 additions & 1 deletion docs/.vitepress/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,8 @@ function sidebarReference() {
link: '/reference/default-theme-config'
},
{ text: 'Frontmatter Config', link: '/reference/frontmatter-config' },
{ text: 'Runtime API', link: '/reference/runtime-api' }
{ text: 'Runtime API', link: '/reference/runtime-api' },
{ text: 'CLI', link: '/reference/cli' }
]
}
]
Expand Down
167 changes: 74 additions & 93 deletions docs/guide/getting-started.md
Original file line number Diff line number Diff line change
@@ -1,63 +1,31 @@
# Getting Started

This section will help you build a basic VitePress documentation site from ground up. If you already have an existing project and would like to keep documentation inside the project, start from Step 2.
## Prerequisites

You can also try VitePress online on [StackBlitz](https://vitepress.new/). It runs the VitePress-based site directly in the browser, so it is almost identical to the local setup but doesn't require installing anything on your machine.
VitePress requires [Node.js](https://nodejs.org/) version 16 or higher.

::: warning
VitePress is currently in `alpha` status. It is already suitable for out-of-the-box documentation use, but the config and theming API may still change between minor releases.
:::

## Step 1: Create a new project

Create and change into a new directory.

```sh
$ mkdir vitepress-starter && cd vitepress-starter
```
## Installation

Then, initialize with your preferred package manager.
VitePress can be used on its own, or be installed into an existing project. Either way, you can install it with:

::: code-group

```sh [npm]
$ npm init
```

```sh [yarn]
$ yarn init
$ npm install -D vitepress
```

```sh [pnpm]
$ pnpm init
```

:::

## Step 2: Install VitePress

Add VitePress and Vue as dev dependencies for the project.

::: code-group

```sh [npm]
$ npm install -D vitepress vue
$ pnpm add -D vitepress
```

```sh [yarn]
$ yarn add -D vitepress vue
```

```sh [pnpm]
$ pnpm add -D vitepress vue
$ yarn add -D vitepress
```

:::

::: details Getting missing peer deps warnings?
`@docsearch/js` has certain issues with its peer dependencies. If you see some commands failing due to them, you can try this workaround for now:

If using PNPM, add this in your `package.json`:
If using PNPM, you will notice a missing peer warning for `@docsearch/js`. This does not prevent VitePress from working. If you wish to suppress this warning, add the following to your `package.json`:

```json
"pnpm": {
Expand All @@ -71,15 +39,69 @@ If using PNPM, add this in your `package.json`:

:::

Create your first document.
## Setup Wizard

VitePress ships with a command line setup wizard that will help you scaffold a basic project. Start the wizard by running:

```sh
$ mkdir docs && echo '# Hello VitePress' > docs/index.md
$ npx vitepress init
```

## Step 3: Boot up dev environment
You should be greeted with the following:

<p>
<img src="./vitepress-init.png" alt="vitepress init screenshot" style="border-radius:8px">
</p>

If you are installing VitePress in an existing project alongside the source code, it is recommended to scaffold the site in a nested directory so that it is separate from the rest of the project.

## File Structure

Assuming you chose to scaffold the VitePress project in `./docs`, the generated file structure should look like this:

Add some scripts to `package.json`.
```
.
├─ docs
│ ├─ .vitepress
│ │ └─ config.js
│ ├─ api-examples.md
│ ├─ markdown-examples.md
│ └─ index.md
└─ package.json
```

The `docs` directory is considered the **project root** of the VitePress site. The `.vitepress` directory contains the config file, dev server cache, build output, and optional theme customization code.

### The Config File

The config file allows you to customize various aspects of your VitePress site, with the most basic options being the title and description of the site:

```js
// .vitepress/config.js
export default {
// site-level options
title: 'VitePress',
description: 'Just playing around.',

themeConfig: {
// theme-level options
}
}
```

You can also configure the behavior of the theme via the `themeConfig` option. Consult the [Site Config Reference](/reference/site-config) for full details on all config options.

### Source Files

Markdown files outside the `.vitepress` directory are considered **source files**.

VitePress uses **file-based routing**: each `.md` file is compiled into a corresponding `.html` file with the same path. For example, `index.md` will be compiled into `index.html`, and can be visited at the root path `/` of the resulting VitePress site.

We will discuss more about [Routing](./routing) in the next chapter.

## Up and Running

The tool should have also injected the following npm scripts to your `package.json` if you allowed it to do so during the setup process:

```json
{
Expand All @@ -93,7 +115,7 @@ Add some scripts to `package.json`.
}
```

Serve the documentation site in the local server.
The `docs:dev` script will start a local dev server with instant hot updates. Run it with the following command:

::: code-group

Expand All @@ -110,58 +132,17 @@ $ pnpm run docs:dev
```

:::
VitePress will start a hot-reloading development server at `http://localhost:5173`.

## Step 4: Add more pages

Let's add another page to the site. Create a file name `getting-started.md` along with `index.md` you've created in Step 2. Now your directory structure should look like this.

```
.
├─ docs
│ ├─ getting-started.md
│ └─ index.md
└─ package.json
```

Then, try to access `http://localhost:5173/getting-started.html` and you should see the content of `getting-started.md` is shown.

This is how VitePress works basically. The directory structure corresponds with the URL path. You add files, and just try to access it.

## 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:

```
.
├─ docs
│ ├─ .vitepress
│ │ └─ config.js
│ └─ index.md
└─ package.json
```

The essential file for configuring a VitePress site is `.vitepress/config.js`, which should export a JavaScript object:

```js
export default {
title: 'VitePress',
description: 'Just playing around.'
}
```

In the above example, the site will have the title of `VitePress`, and `Just playing around.` as the description meta tag.

Learn everything about VitePress features at [Theme: Introduction](./custom-theme) to find how to configure specific features within this config file.
The dev server should be running at `http://localhost:5173`. Visit the URL in your browser to see your new site in action!

You may also find all configuration references at [Config Reference](/reference/site-config).
## What's Next?

## What's next?
- To better understand how markdown files are mapped to generated HTML, proceed to the [Routing Guide](./routing.md).

By now, you should have a basic but functional VitePress documentation site. But currently, the user has no way to navigate around the site because it's missing for example sidebar menu we have on this site.
- To discover more about what you can do on the page, such as writing markdown content or using Vue Component, refer to the "Writing" section of the guide. A great place to start would be to learn about [Markdown Extensions](/guide/markdown).

If you would like to know more about what you can do within the page, for example, writing markdown contents, or using Vue Component, check out the "Writing" section of the docs. [Markdown guide](./markdown) would be a great starting point.
- To explore the features provided by the default documentation theme, check out the [Default Theme Config Reference](/reference/default-theme-config).

If you want to know how to customize how the site looks (Theme), and find out the features VitePress's default theme provides, check out how to [extend the default theme](./extending-default-theme) or [build a custom theme](./custom-theme).
- If you want to further customize the appearance of your site, explore how to either [Extend the Default Theme](./extending-default-theme) or [Build a Custom Theme](./custom-theme).

When your documentation site starts to take shape, be sure to read the [deployment guide](./deploy).
- Once your documentation site takes shape, make sure to read the [Deployment Guide](./deploy).
8 changes: 4 additions & 4 deletions docs/guide/routing.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,10 @@ By default, VitePress assumes your page files are stored in project root. Here y
Then you can access the pages by the below URL.

```
index.md -> /
prologue.md -> /prologue.html
guide/index.md -> /guide/
guide/getting-started.md -> /guide/getting-started.html
index.md --> /
prologue.md --> /prologue.html
guide/index.md --> /guide/
guide/getting-started.md --> /guide/getting-started.html
```

As you can see, the directory structure corresponds to the final URL, as same as hosting plain HTML from a typical web server.
Expand Down
Binary file added docs/guide/vitepress-init.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions docs/reference/cli.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# CLI
45 changes: 32 additions & 13 deletions src/node/init/init.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import {
} from '@clack/prompts'
import fs from 'fs-extra'
import path from 'path'
import { black, cyan, bgCyan, bold } from 'picocolors'
import { black, cyan, bgCyan, bold, yellow } from 'picocolors'
import { fileURLToPath } from 'url'
// @ts-ignore
import template from 'lodash.template'
Expand Down Expand Up @@ -106,7 +106,7 @@ export function scaffold({
theme,
useTs,
injectNpmScripts
}: ScaffoldOptions) {
}: ScaffoldOptions): string {
const resolvedRoot = path.resolve(root)
const templateDir = path.resolve(
path.dirname(fileURLToPath(import.meta.url)),
Expand Down Expand Up @@ -158,25 +158,44 @@ export function scaffold({
}

const dir = root === './' ? `` : ` ${root.replace(/^\.\//, '')}`

const pkgPath = path.resolve('package.json')
const userPkg = fs.existsSync(pkgPath)
? JSON.parse(fs.readFileSync(pkgPath, 'utf-8'))
: {}

const tips = []
if (fs.existsSync('.git')) {
tips.push(
`Make sure to add ${cyan(`.vitepress/dist`)} and ` +
`${cyan(`.vitepress/cache`)} to your ${cyan(`.gitignore`)} file.`
)
}
if (
theme !== ScaffoldThemeType.Default &&
!userPkg.dependencies?.['vue'] &&
!userPkg.devDependencies?.['vue']
) {
tips.push(
`Since you've chosen to customize the theme, ` +
`you should also explicitly install ${cyan(`vue`)} as a dev dependency.`
)
}

const tip = tips.length ? yellow([`\n\nTips:`, ...tips].join('\n- ')) : ``

if (injectNpmScripts) {
const scripts = {
'docs:dev': `vitepress dev${dir}`,
'docs:build': `vitepress build${dir}`,
'docs:preview': `vitepress preview${dir}`
}
const pkgPath = path.resolve('package.json')
let pkg
if (!fs.existsSync(pkgPath)) {
pkg = { scripts }
} else {
pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'))
Object.assign(pkg.scripts || (pkg.scripts = {}), scripts)
}
fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2))
return `Done! Now run ${cyan(`npm run docs:dev`)} and start writing.`
Object.assign(userPkg.scripts || (userPkg.scripts = {}), scripts)
fs.writeFileSync(pkgPath, JSON.stringify(userPkg, null, 2))
return `Done! Now run ${cyan(`npm run docs:dev`)} and start writing.${tip}`
} else {
return `You're all set! Now run ${cyan(
`npx vitepress dev${dir}`
)} and start writing.`
)} and start writing.${tip}`
}
}

0 comments on commit 49bcc25

Please sign in to comment.