|  | hai 5 meses | |
|---|---|---|
| .github | hai 1 ano | |
| @ | hai 9 meses | |
| build | hai 1 ano | |
| js | %!s(int64=2) %!d(string=hai) anos | |
| mock | hai 1 ano | |
| public | hai 6 meses | |
| src | hai 5 meses | |
| tests | %!s(int64=3) %!d(string=hai) anos | |
| types | hai 7 meses | |
| .babelrc | hai 1 ano | |
| .editorconfig | %!s(int64=4) %!d(string=hai) anos | |
| .env | hai 5 meses | |
| .env.development | hai 5 meses | |
| .env.production | hai 5 meses | |
| .eslintignore | %!s(int64=4) %!d(string=hai) anos | |
| .eslintrc.js | %!s(int64=3) %!d(string=hai) anos | |
| .gitignore | hai 9 meses | |
| .gitpod.yml | %!s(int64=4) %!d(string=hai) anos | |
| .prettierignore | %!s(int64=4) %!d(string=hai) anos | |
| .stylelintignore | %!s(int64=4) %!d(string=hai) anos | |
| Dockerfile | %!s(int64=2) %!d(string=hai) anos | |
| LICENSE | hai 1 ano | |
| README.md | hai 7 meses | |
| commitlint.config.js | hai 1 ano | |
| index.html | hai 10 meses | |
| jest.config.mjs | %!s(int64=4) %!d(string=hai) anos | |
| npm | %!s(int64=4) %!d(string=hai) anos | |
| npminstall-debug.log | hai 10 meses | |
| package-lock.json | hai 5 meses | |
| package.json | hai 6 meses | |
| pnpm-lock.yaml | hai 6 meses | |
| postcss.config.js | %!s(int64=4) %!d(string=hai) anos | |
| prettier.config.js | %!s(int64=3) %!d(string=hai) anos | |
| stylelint.config.js | hai 1 ano | |
| tsconfig.json | hai 1 ano | |
| vite.config.ts | hai 5 meses | 
系统v2.0前端代码仓库
本项目以jeecgboot为模板,请先阅读此文档后继续!
建议:安装 nvm 或其他 nodejs 版本管理器,使用 VSCode 作为 IDE,使用 Chrome/Edge 浏览器;
在项目目录下执行 pnpm install
在项目目录下执行 git config commit.template .github/COMMIT_TEMPLATE
开发的基本流程,部分内容可忽略
git pull # 可以rebase
git checkout [branch] # 可选
nvm use 20 # 建议,高版本node自带pnpm包管理器
pnpm dev # 必选,dddd
git add .
git commit # 公用模板见.github/COMMIT_TEMPLATE
git push origin [branch] # 目前master分支无保护,可直接推
pnpm build
主题可以在 /views/vent/sys/setting/index.vue 中找到设置入口
常规的颜色、变量在 /design/color.less 或 /design/themify/ 下添加,图片资源应在 /assets/images/themify/ 下添加
一般来说,主题化开发可以参考以下代码
// import theme variables
@import '/@/design/theme.less';
// scope the selector
@{theme-deepblue} {
  .your-component-root-class-name {
    --image-a: url('/@/assets/images/themify/deepblue/a.png');
    --bg-a: #ffffff;
  }
}
// scope the selector
@{theme-dark} {
  .your-component-root-class-name {
    --image-a: url('/@/assets/images/themify/dark/a.png');
    --bg-a: #000000;
  }
}
// default css
.your-component-root-class-name {
  --image-a: url('/@/assets/images/a.png');
  --bg-a: #888888;
  .class-name-a {
    background-image: var(--image-a);
    background-color: var(--bg-a);
  }
}
更加详细的页面主题化标准模板可以参考登录页 /views/sys/login/Login.vue
如果已经写了css代码,想要支持主题化,则下面是配合主题化使用的工具,用于将已有样式代码输出为主题化代码。输入页面的 css 样式,即可输出标准模板所需的资源(返回的数据第一项为变量集合,第二项为css代码文本)
// Take note of requires below before using this function:
// 1. replace all url patterns to patterns like `url(/@/xxx/xxx.xxx)`.
// 2. remove all the in-line comments(//) or replace them to block comments(/** */).
// 3. replace all rbg/rgba/hsa or any other css color functions to hex colors(#xxxxxx).
function themifyScript(
  str,
  options = {
    color: false,
    gradient: false,
    url: true,
  }
) {
  const keySet = new Set();
  let strcopy = str;
  let varstr = '';
  // process url, extract all css url and replace them to css var and record them.
  {
    keySet.clear();
    const regexp = /url\('?(\/[@|0-9|a-z|A-Z|\-|_]+)+.(png|svg)'?\)/g;
    let res = regexp.exec(str);
    while (res) {
      const [url, image] = res;
      const varname = `--image-${image.replace('/', '')}`;
      if (!keySet.has(image)) {
        keySet.add(image);
        varstr += `${varname}: ${url};`;
      }
      if (options.url) {
        strcopy = strcopy.replace(url, `var(${varname})`);
      }
      res = regexp.exec(str);
    }
  }
  // process gradient, extract all css gradient and replace them to css var and record them.
  {
    keySet.clear();
    let key = 0;
    const regexp = /linear-gradient\([0-9|a-z|A-Z|#|,|\s|%|.]+\)/g;
    let res = regexp.exec(str);
    while (res) {
      const [gradient] = res;
      const varname = `--gradient-${key}`;
      if (!keySet.has(gradient)) {
        keySet.add(gradient);
        varstr += `${varname}: ${gradient};`;
      }
      if (options.gradient) {
        strcopy = strcopy.replace(gradient, `var(${varname})`);
      }
      res = regexp.exec(str);
      key += 1;
    }
  }
  {
    keySet.clear();
    let key = 0;
    const regexp = /radial-gradient\([0-9|a-z|A-Z|#|,|\s|%|.]+\)/g;
    let res = regexp.exec(str);
    while (res) {
      const [gradient] = res;
      const varname = `--gradient-${key}`;
      if (!keySet.has(gradient)) {
        keySet.add(gradient);
        varstr += `${varname}: ${gradient};`;
      }
      if (options.gradient) {
        strcopy = strcopy.replace(gradient, `var(${varname})`);
      }
      res = regexp.exec(str);
      key += 1;
    }
  }
  // process color, extract all css colors and replace them to css var and record them.
  {
    keySet.clear();
    let key = 0;
    const regexp = /#[0-9|a-z|A-Z]{3,8}/g;
    let res = regexp.exec(str);
    while (res) {
      const [color] = res;
      const varname = `--color-${key}`;
      if (!keySet.has(color)) {
        keySet.add(color);
        varstr += `${varname}: ${color};`;
      }
      if (options.color) {
        strcopy = strcopy.replace(color, `var(${varname})`);
      }
      res = regexp.exec(str);
      key += 1;
    }
  }
  return [varstr, strcopy];
}