From ec1d011a7788184e45740e7f2453aa68be4580c9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E4=BD=9A=E5=90=8D=E7=A8=8B=E5=BA=8F=E5=91=98?= <1968115437@qq.com> Date: Wed, 15 Mar 2023 09:20:03 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E5=A2=9E=E5=8A=A0commitlint=E6=8F=90?= =?UTF-8?q?=E4=BA=A4=E6=96=B9=E5=BC=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .husky/commit-msg | 4 ++++ .husky/lintstagedrc.cjs | 9 ++++++++ .husky/pre-commit | 5 ++++- commitlint.config.cjs | 37 +++++++++++++++++++++++++++++++++ package.json | 21 +++++++------------ src/components/Navbar/index.vue | 14 +++++++++++-- src/utils/http/index.ts | 4 ++-- tsconfig.json | 2 +- 8 files changed, 76 insertions(+), 20 deletions(-) create mode 100644 .husky/commit-msg create mode 100644 .husky/lintstagedrc.cjs create mode 100644 commitlint.config.cjs diff --git a/.husky/commit-msg b/.husky/commit-msg new file mode 100644 index 0000000..10cb551 --- /dev/null +++ b/.husky/commit-msg @@ -0,0 +1,4 @@ +#!/bin/sh +. "$(dirname "$0")/_/husky.sh" + +pnpm commitlint --edit "$1" diff --git a/.husky/lintstagedrc.cjs b/.husky/lintstagedrc.cjs new file mode 100644 index 0000000..b1cec8e --- /dev/null +++ b/.husky/lintstagedrc.cjs @@ -0,0 +1,9 @@ +module.exports = { + '*.{js,jsx,ts,tsx}': ['eslint --fix', 'prettier --write'], + '{!(package)*.json,*.code-snippets,.!(browserslist)*rc}': ['prettier --write--parser json'], + 'package.json': ['prettier --write'], + '*.vue': ['prettier --write'], + '*.{scss,less,styl,css,html}': ['prettier --write'], + '*.md': ['prettier --write'], + '*.hbs': ['prettier --write'], +}; diff --git a/.husky/pre-commit b/.husky/pre-commit index 36af219..29b6b29 100644 --- a/.husky/pre-commit +++ b/.husky/pre-commit @@ -1,4 +1,7 @@ #!/bin/sh . "$(dirname "$0")/_/husky.sh" -npx lint-staged +[ -n "$CI" ] && exit 0 + +# 根据./lintsstagedrc.cjs配置格式化并提交代码 +npm run lint:lint-staged diff --git a/commitlint.config.cjs b/commitlint.config.cjs new file mode 100644 index 0000000..13f4e39 --- /dev/null +++ b/commitlint.config.cjs @@ -0,0 +1,37 @@ +// https://github.com/conventional-changelog/commitlint/#what-is-commitlint + +// 例:feat: 增加功能 + +module.exports = { + extends: ['@commitlint/config-conventional'], + rules: { + 'type-enum': [ + 2, + 'always', + [ + 'feat', // 新功能(feature) + 'fix', // 修补bug + 'docs', // 文档(documentation) + 'style', // 格式、样式(不影响代码运行的变动) + 'refactor', // 代码重构 + 'perf', // 性能改进 + 'test', // 添加测试 + 'ci', // 持续集成 + 'chore', // 构建过程或辅助工具的变动 + 'revert', // 回滚到上一个版本 + 'workflow', // 工作流改进 + 'mod', // 不确定分类的修改 + 'wip', // 开发中 + 'types', // 类型修改 + 'release', // 版本发布 + 'resolve a conflict', // 解决冲突 + 'merge branch', // 合并分支 + 'dependencies', // 依赖项修改 + 'devDependencies', // 开发依赖修改 + 'strengthen', // 加强,巩固 + ], + ], + 'subject-full-stop': [0, 'never'], + 'subject-case': [0, 'never'], + }, +}; diff --git a/package.json b/package.json index 57df935..1d2b91c 100644 --- a/package.json +++ b/package.json @@ -30,7 +30,10 @@ "build:quickapp-webview": "uni build -p quickapp-webview", "build:quickapp-webview-huawei": "uni build -p quickapp-webview-huawei", "build:quickapp-webview-union": "uni build -p quickapp-webview-union", - "eslint": "eslint --max-warnings 0 \"src/**/*.{vue,js,jsx,cjs,mjs,ts,tsx,cts,mts}\" --fix", + "lint": "pnpm lint:format & pnpm lint:eslint", + "lint:eslint": "eslint --max-warnings 0 --fix --ext .js,.cjs,.mjs,.jsx,.ts,.cts,.mts,.tsx,.vue ./src", + "lint:format": "prettier --write --loglevel warn \"src/**/*.{js,ts,json,tsx,css,less,vue,html,md}\"", + "lint:lint-staged": "lint-staged -c ./.husky/lintstagedrc.cjs", "prepare": "husky install" }, "dependencies": { @@ -58,6 +61,8 @@ "vue": "^3.2.47" }, "devDependencies": { + "@commitlint/cli": "^17.4.4", + "@commitlint/config-conventional": "^17.4.4", "@dcloudio/types": "^3.2.11", "@dcloudio/uni-automator": "3.0.0-alpha-3070620230227001", "@dcloudio/uni-cli-shared": "3.0.0-alpha-3070620230227001", @@ -75,8 +80,7 @@ "eslint": "^8.35.0", "eslint-plugin-vue": "^9.9.0", "husky": "^8.0.3", - "lint-staged": "^13.1.2", - "mrm": "^4.1.13", + "lint-staged": "^13.2.0", "postcss": "^8.4.21", "prettier": "^2.8.4", "sass": "^1.58.3", @@ -84,16 +88,5 @@ "unocss": "^0.46.5", "unocss-preset-weapp": "^0.2.5", "vite": "^4.1.4" - }, - "husky": { - "hooks": { - "pre-commit": "lint-staged" - } - }, - "lint-staged": { - "*.{js,jsx,vue,ts,tsx}": [ - "eslint --max-warnings 0 --fix", - "git add" - ] } } diff --git a/src/components/Navbar/index.vue b/src/components/Navbar/index.vue index 73a7234..bfa0561 100644 --- a/src/components/Navbar/index.vue +++ b/src/components/Navbar/index.vue @@ -70,10 +70,20 @@ const onBackHome = () => { diff --git a/src/utils/http/index.ts b/src/utils/http/index.ts index c2b23ae..7ebfed5 100644 --- a/src/utils/http/index.ts +++ b/src/utils/http/index.ts @@ -40,7 +40,7 @@ request.interceptors.request.use( } return options; }, - (options) => Promise.reject(options), + (options) => Promise.reject(options) ); /** @@ -59,7 +59,7 @@ request.interceptors.response.use( (response) => // 请求错误做点什么。可以使用async await 做异步操作 // error('Request Error!'); - Promise.reject(response), + Promise.reject(response) ); export { request }; diff --git a/tsconfig.json b/tsconfig.json index bdd5425..6464fae 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,5 +1,5 @@ { - "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue", "vite.config.*", "vitest.config.*", "cypress.config.*"], // 指定要包含在编译中的文件匹配列表 + "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue", "vite.config.*"], // 指定要包含在编译中的文件匹配列表 "exclude": [], // 指定要从编译中排除的文件列表 "compilerOptions": { "baseUrl": "./", // 指定基目录以解析非相对模块名