# 贡献指南 ## 概览 项目仓库借助于 [pnpm 工作空间](https://pnpm.io/zh/workspaces) 来实现 [Monorepo](https://en.wikipedia.org/wiki/Monorepo) ,存放了多个互相关联的独立 Package 。 - 主题于 `theme` 目录中进行开发维护。 - 插件于 `plugins` 目录中进行开发维护。 - 文档于 `docs` 目录中进行开发维护。 在 `plugins` 目录中: - `plugin-search`: 为主题提供 全文模糊搜索 功能 - `plugin-shikiji`: 代码高亮插件,支持 highlight、diff、focus、error level - `plugin-md-power`: 提供 markdown 增强功能 ## 开发配置 开发要求: - [Node.js](http://nodejs.org/) version 20.6.0+ - [pnpm](https://pnpm.io/zh/) version 9+ 克隆代码仓库,并安装依赖: ```sh pnpm install ``` 在首次启动开发服务前,先构建源代码: ```sh pnpm build ``` ### 主要工具 - [TypeScript](https://www.typescriptlang.org/) 作为开发语言 - [ESLint](https://eslint.org/) 用于代码检查和格式化 - [StyleLint](https://stylelint.io/) 用于代码检查和格式化 ### 脚本 #### `pnpm build` `build` 命令使用 `tsc` 将源代码编译成 `lib` 目录下的 `.js` 文件。 同时复制 不需要编译的资源到对应的`lib` 目录下。 你在克隆代码仓库后,需要先执行该命令来确保项目代码可以顺利运行,因为编译后的输出目录被 `.gitignore` 排除在仓库以外了。 #### `pnpm dev` `dev` 命令会在本地开启两个服务,一个是运行 主题 `theme` 目录的 `tsup:watch & copy:watch`, 一个是运行 示例 `docs` 目录的 `vuepress` 开发服务。 `plugins` 目录下的所有插件,默认都没有 `dev` 命令,因此,你对 `plugins` 下的改动,可能需要执行 `pnpm build` 命令 进行重新构建,部分对 `plugins/**/node` 目录下的改动,需要重新执行 `pnpm dev` 才能生效。 #### `pnpm lint` `lint` 命令使用 ESLint 来检查所有源文件。 当 `lint` 给出了错误时,你可以手动修改源码以修复 eslint 的报错。 也可以执行 `pnpm lint:fix` 来自动修复。 #### `pnpm test` `test` 命令使用 Vitest 来运行所有测试。 ### IDE 支持 推荐使用 `vs code` 进行开发。本仓库配置了开发本主题时,推荐的 `vs code` 扩展, 当你导入本仓库时,`vs code` 可能会推荐你安装一些扩展。