From 3a8ccbdc3d689cfd8355420201c629acfdd170c1 Mon Sep 17 00:00:00 2001 From: Y Date: Mon, 15 Jan 2024 10:24:06 +0800 Subject: [PATCH] chore: update CONTRIBUTING.md (#1196) * chore: update CONTRIBUTING.md * Update CONTRIBUTING.md --- CONTRIBUTING.md | 190 +++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 163 insertions(+), 27 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index ad9b58411..e75328a2a 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,39 +1,175 @@ ---- -title: 贡献指南 -# description: -spline: explain ---- +# CONTRIBUTING -非常感谢你对 TDesign 的关注,如果你想为组件库或其他产品贡献一份力量,请先了解下以下内容。 +`tdesign-mobile-vue` 包含 `Mobile Vue` 代码和一个子仓库,子仓库指向 `tdesign-common` 仓库 -## 开启 issue +## 开发 -如果你想要贡献一个新特性,请在实际写代码前先开一个 issue 与社区里的小伙伴一起讨论必要性及实现方案。 +建议使用 node 18 版本进行开发 -## Github flow 贡献流程 +### 1.初始化子仓库 -- 请将本项目 clone 至本地 -- 创建 feature/fix 分支 -- 开发过程中可以使用 `git fetch` 或 `git rebase` 来同步上游分支代码 -- 提交代码到 forked 仓库,commit message 撰写请参照 [Angular Commits 规范](https://github.com/angular/angular.js/blob/master/DEVELOPERS.md#commits) -- 发起 pr -- 会有 PMC 同学来 CR 本次提交的代码,请及时关注 CR 评论通知信息 -- CR 通过后会合并进入 develop 分支,等待周迭代或紧急 patch 版本发布 npm +```bash +npm run init +``` -## 开发 +### 2.安装依赖 -⚠️ `npm` 版本要求至少为 `npm7`,执行 `npm install npm@latest -g` 更新至最新版本。 +```bash +npm i +``` + +### 3.本地开发 ```bash -git clone https://github.com/Tencent/tdesign-mobile-vue.git -cd tdesign-mobile-vue -git submodule init -git submodule update +npm run start +``` -# 开发预览 -cd .. -npm i -npm run dev +完成以上 3 个步骤,浏览器访问 即可调该框架的任何内容 + +## 目录结构 + +```text +├── scripts // 构建代码 +├── site // 站点代码 +├── src // 组件代码 + └─ componentA + ├── demos // 组件示例文档 + └─ __test__ // 组件测试用例 +└─ test // 测试配置文件 +``` + +### 组件页路由配置 + +每一个组件都有自己的路由,页面配置都是一个 `Markdown` 文件,如`button.md`,具体路径可参考 `/site/docs.config.js`。如果有新增组件,直接按照模板添加即可 + +```js +{ + title: '基础组件', + type: 'component', // 组件文档 + children: [ + { + title: 'Button 按钮', + name: 'button', + component: () => import(`tdesign-mobile-vue/button/button.md`), + }, + { + title: 'Icon 图标', + name: 'icon', + component: () => import(`tdesign-mobile-vue/icon/icon.md`), + }, + ... + ], +}, +``` -# 打开浏览器访问 http://127.0.0.1:18000 +### Markdown 文件的 demo 引用 + +文档 `demo` 排列与 `common` 子仓库中的 `UI demo` 展示一致,如 `button` 组件页面的展示顺序,由子仓库的 `docs/mobile/api/button.md` 内的顺序决定。 + +```markdown +{{ base }} +[demo 描述(可不填)] ``` + +### Demo 调试 + +我们可以通过打开组件的路由页进行开发调试,如 `button`,则打开 进行开发调试; + +如果仅想聚焦于对某个 `demo` 单独调试,如 `button`, 则可以打开 进行开发调试。 + + +## 子仓库 tdesign-common + +TDesign 的项目都会以子仓库的形式引入 `tdesign-common` 公共仓库,对应 `src/\_common` 文件夹, +公共仓库中包含 + +- 部分组件的一些框架无关的公共的工具函数 +- `组件库UI`,既 `html` 结构和 `css` 样式(多框架共用) + +大部分的功能和改动都只需要调整主仓库的代码即可,但涉及部分公共函数、样式或者部分文档的调整,需要改动子仓库的代码。 + +### 初始化子仓库 + +- 如开发部分提到的,初次克隆代码后需要初始化子仓库: `git submodule init && git submodule update` +- `git submodule update` 之后子仓库不指向任何分支,只是一个指向某一个提交的游离状态 + +### 子仓库开发 + +子仓库组件分支从 `develop checkout` 示例:`feature/button`,提交代码时先进入子仓库完成提交,然在回到主仓库完成提交 + +- 先进入 `src/\_common` 文件夹,正常将样式修改添加提交 +- 回到主仓库,此时应该会看到 `src/\_common` 文件夹是修改状态,按照正常步骤添加提交即可 + + +### 组件库 UI + +`UI` 是多个框架共用的,比如 `PC` 端的 `react/vue/vue-next` 都是复用子仓库的 `UI` 代码。 +各个框架组件实现应该要复用 `UI` 开发的 `html` 结构,引用其组件 `CSS` 与 `Demo CSS`(本仓库已在入口处引用了),`UI` 开发一般可由单独的 UI 开发同学认领完成或各框架组件开发同学的其中一名同学完成 + +- 如果开发前已有某个组件的 `UI` 开发内容,直接在主仓库使用即可 +- 如果没有,且你也负责 `UI` 开发:参考 `UI` 开发规范完成 `UI` 开发内容、然后再开发主仓库组件 +- 如果没有,且 `UI` 开发工作已有其他同学负责或认领:可以先在主仓库开发组件功能,待 `UI` 开发输出之后对齐即可 + +如果 `UI` 内容和样式(其他同学负责开发)还未完成,而你开发组件功能时需要写一些样式,可以直接在组件文件夹先写一个临时的 `less` 文件,在 `js` 中引入即可,如: + +```bash +├── button.less +├── button.tsx +``` + +```js +// button.tsx + +// 先引入临时的样式文件用于开发功能,待 UI 开发完成之后需要与 UI 样式对齐并删除 less 文件 +import './button.less'; +``` + +## 分支规范 + +### 分支 + +遵循使用 `git flow` 规范,新组件分支从 `develop checkout`:[https://nvie.com/posts/a-successful-git-branching-model/](https://nvie.com/posts/a-successful-git-branching-model/) + +如果是贡献组件,则从 `develop checkout` 分支如:`feature/button`,记得如果同时要在子仓库开发 `UI`,子仓库也要 `checkout` 同名分支 + +> 关于 fork + +以下内容处理 `fork` 仓库后,远端仓库的更新如何同步到 `fork` 仓库 + +```bash +# 建立 upstream remote +git remote add upstream git@github.com:Tencent/tdesign-mobile-vue.git + +# 更新 upstream +git fetch upstream develop + +# 合并 upstream develop 到本地 +git checkout develop + +git merge upstream/develop +``` + +### 提交说明 + +项目使用基于 angular 提交规范:[https://github.com/conventional-changelog/commitlint/tree/master/@commitlint/config-conventional](https://github.com/conventional-changelog/commitlint/tree/master/@commitlint/config-conventional) + +每次提交会自动触发提交验证 + +- 使用工具 `commitizen` 协助规范 `git commit` 信息 +- `fix` & `feat` 的提交会被用来生成 `changelog` +- 提交会触发 `git pre-commit` 检查,修复提示的 `eslint` 错误, + +## 开发规范 + +### API 规范 + +`API` 由 `API` 平台统一管理生成,如果涉及组件文档的改动(如`src/button/type.ts`的内容),都需要同时在 `API` 平台提交 `PR`,进行统一维护管理 https://github.com/tdesignoteam/tdesign-api + +### 前缀规范 + +组件和 `CSS` 前缀以 `t-` 开头,无论 `js` 还是 `css` 都使用变量定义前缀,方便后续替换 + +### CSS 规范 + + +组件样式在 `common` 子仓库开发,遵循 [tdesign-common 仓库 UI 开发规范](https://github.com/Tencent/tdesign-common/blob/main/style/mobile/README.md)