Getting started
Installation
Install @nolebase/vitepress-plugin-git-changelog
to your project dependencies by running the following command:
ni @nolebase/vitepress-plugin-git-changelog -D
pnpm add @nolebase/vitepress-plugin-git-changelog -D
npm install @nolebase/vitepress-plugin-git-changelog -D
yarn add @nolebase/vitepress-plugin-git-changelog -D
Usage
This is roughly the most complex one to configure with!
Please pay attentions to the following configurations and steps to get started with the Git-based page histories plugin. It is not quite simple as other plugins.
It consists two major steps to integrate the Inline Links Previewing plugin into your VitePress project:
- Configure Vite plugin (data fetching, logs aggregation)
- Integrate with VitePress (UI and components)
Configure Vite plugin
Ensure vite.config.ts
is created
If you understand what vite.config.ts
is already and have created it, you can skip this preparation step and jump to the next step Configure plugin in vite.config.ts
.
New to vite.config.ts
is?
First of all, vite.config.ts
is a configuration file for Vite, the build tool that VitePress is built on. It allows developers to build and transform the assets, content and data in the project.
Even though VitePress itself contains entire set of Vite options in its primary configuration file (not this is not a theme configuration file, it's usually located at docs/.vitepress/config.ts
, file paths and extensions may be vary), these options, and yet, the vite.config.ts
are identical in terms of configurations.
However, due to the order of plugins it registered, it's not enough to transform the needed data and logs if we install the Git-based page histories plugin in this way.
Therefore, please create a separated vite.config.ts
file in the root directory of your VitePress project:
touch vite.config.ts
Configure plugin in vite.config.ts
In the standalone Vite configuration file (e.g. vite.config.ts
) file we have under our root directory, we need to import both GitChangelog
(data fetcher), and GitChangelogMarkdownSection
(widget embedder) the plugins and configure it properly:
If you've never seen a colored diff before
This is a markup rule for displaying diff in the user interface (UI).
Red parts usually represents the lines you are going to remove, commonly appeared with a Minus sign -, or you could simply understand it as: this line will be removed.
Green parts usually represents the lines you are going to add, commonly appeared with a Plus sign +, or you could simply understand it as: this line will be added.
To learn more about diff, you can check out this answer about the history of diffutils and Git's documentation
import { join } from 'node:path'
import { defineConfig } from 'vite'
import {
GitChangelog,
GitChangelogMarkdownSection,
} from '@nolebase/vitepress-plugin-git-changelog/vite'
export default defineConfig(() => {
return {
plugins: [
GitChangelog({
// Fill in your repository URL here
repoURL: () => 'https://github.com/nolebase/integrations',
}),
GitChangelogMarkdownSection(),
]
// other vite configurations...
}
})
Integrate with VitePress
Now, let's integrate the Git-based page histories UI widgets into your VitePress project.
In VitePress's theme configuration file (note that it's not a configuration file, it's usually located at docs/.vitepress/theme/index.ts
, file paths and extensions may be vary), install the Vue plugin and use the components:
If you've never seen a colored diff before
This is a markup rule for displaying diff in the user interface (UI).
Red parts usually represents the lines you are going to remove, commonly appeared with a Minus sign -, or you could simply understand it as: this line will be removed.
Green parts usually represents the lines you are going to add, commonly appeared with a Plus sign +, or you could simply understand it as: this line will be added.
To learn more about diff, you can check out this answer about the history of diffutils and Git's documentation
import { h } from 'vue'
import DefaultTheme from 'vitepress/theme'
import type { Theme as ThemeConfig } from 'vitepress'
import {
NolebaseGitChangelogPlugin
} from '@nolebase/vitepress-plugin-git-changelog/client'
import '@nolebase/vitepress-plugin-git-changelog/client/styles.css'
export const Theme: ThemeConfig = {
extends: DefaultTheme,
Layout: () => {
// other configurations...
},
enhanceApp({ app }) {
app.use(NolebaseGitChangelogPlugin)
},
}
export default Theme