defaultScope
- Obtaining the project scopeautomatically. Good for when there are a lot of scope options (eg components lib, monorepo).- e.g TDesign-Vue-Next, which is a Vue3 component library with more than 60+ components stored in src
- Fortunately, the path structure is clear
- We can get the path of the modified file cache through git status
- Perform string matching interception to obtain scope
- passed to defaultScope. pin the top of scope list
 
- e.g TDesign-Vue-Next, which is a Vue3 component library with more than 60+ components stored in 
js
// commitlint.config.js
const { execSync } = require('child_process');
// precomputed scope
const scopeComplete = execSync('git status --porcelain || true')
  .toString()
  .trim()
  .split('\n')
  .find((r) => ~r.indexOf('M  src'))
  ?.replace(/(\/)/g, '%%')
  ?.match(/src%%((\w|-)*)/)?.[1];
/** @type {import('cz-git').UserConfig} */
module.exports = {
  prompt: {
    defaultScope: scopeComplete,
    customScopesAlign: !scopeComplete ? 'top-bottom' : 'bottom',
  },
};
// commitlint.config.js
const { execSync } = require('child_process');
// precomputed scope
const scopeComplete = execSync('git status --porcelain || true')
  .toString()
  .trim()
  .split('\n')
  .find((r) => ~r.indexOf('M  src'))
  ?.replace(/(\/)/g, '%%')
  ?.match(/src%%((\w|-)*)/)?.[1];
/** @type {import('cz-git').UserConfig} */
module.exports = {
  prompt: {
    defaultScope: scopeComplete,
    customScopesAlign: !scopeComplete ? 'top-bottom' : 'bottom',
  },
};

Using highly customizable
cz-gitmakes committing more convenient and more customary. Welcome to share.
 cz-git
cz-git