From b6415fad2d7d22c8a54fe48b4b45abc0b4769bde Mon Sep 17 00:00:00 2001 From: Vben Date: Sun, 4 Aug 2024 05:42:59 +0800 Subject: [PATCH] perf: optimize for some details and comments (#4030) * perf: optimize for some details and comments * fix: test case * chore: update ci --- .github/workflows/build.yml | 2 +- .github/workflows/ci.yml | 5 +- .github/workflows/semantic-pull-request.yml | 3 +- deploy/nginx.conf | 87 ------------------- docs/src/guide/in-depth/loading.md | 2 +- .../lint-configs/commitlint-config/index.mjs | 3 +- .../vite-config/src/config/application.ts | 8 +- internal/vite-config/src/config/library.ts | 6 +- internal/vite-config/src/options.ts | 4 +- .../src/plugins/inject-app-loading/README.md | 2 +- .../inject-app-loading/default-loading.html | 2 +- .../src/plugins/inject-app-loading/index.ts | 14 ++- internal/vite-config/src/typing.ts | 6 +- .../@core/preferences/src/preferences.test.ts | 3 +- packages/@core/preferences/src/preferences.ts | 14 +-- .../preferences/src/update-css-variables.ts | 2 +- .../@core/preferences/src/use-preferences.ts | 3 +- .../effects/hooks/src/use-design-tokens.ts | 2 +- .../src/helpers/unmount-global-loading.ts | 1 + scripts/turbo-run/src/run.ts | 2 +- 20 files changed, 37 insertions(+), 134 deletions(-) delete mode 100644 deploy/nginx.conf diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 86dc629a..d66a8556 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -44,6 +44,6 @@ jobs: - name: Install dependencies run: pnpm install --frozen-lockfile - - name: Test and Build + - name: Build run: | pnpm run build diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index e308ec57..428626da 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -5,7 +5,6 @@ on: push: branches: - main - - master - "releases/*" permissions: @@ -25,8 +24,8 @@ jobs: node-version: [20] os: - ubuntu-latest - # - macos-latest - # - windows-latest + - macos-latest + - windows-latest timeout-minutes: 20 steps: - name: Checkout code diff --git a/.github/workflows/semantic-pull-request.yml b/.github/workflows/semantic-pull-request.yml index e154da65..51df9ac6 100644 --- a/.github/workflows/semantic-pull-request.yml +++ b/.github/workflows/semantic-pull-request.yml @@ -9,17 +9,18 @@ on: jobs: main: - if: github.repository == 'vitejs/vite' runs-on: ubuntu-latest name: Semantic Pull Request steps: - name: Validate PR title uses: amannn/action-semantic-pull-request@v5 with: + wip: true subjectPattern: ^(?![A-Z]).+$ subjectPatternError: | The subject "{subject}" found in the pull request title "{title}" didn't match the configured pattern. Please ensure that the subject doesn't start with an uppercase character. + requireScope: false env: GITHUB_TOKEN: ${{ secrets.ACCESS_TOKEN }} diff --git a/deploy/nginx.conf b/deploy/nginx.conf deleted file mode 100644 index a36247d0..00000000 --- a/deploy/nginx.conf +++ /dev/null @@ -1,87 +0,0 @@ - -#user nobody; -worker_processes 1; - -#error_log logs/error.log; -#error_log logs/error.log notice; -#error_log logs/error.log info; - -#pid logs/nginx.pid; - - -events { - worker_connections 1024; -} - - -http { - include mime.types; - default_type application/octet-stream; - - types { - application/javascript js mjs; - text/css css; - text/html html; - } - - sendfile on; - # tcp_nopush on; - - #keepalive_timeout 0; - # keepalive_timeout 65; - - # gzip on; - # gzip_buffers 32 16k; - # gzip_comp_level 6; - # gzip_min_length 1k; - # gzip_static on; - # gzip_types text/plain - # text/css - # application/javascript - # application/json - # application/x-javascript - # text/xml - # application/xml - # application/xml+rss - # text/javascript; #设置压缩的文件类型 - # gzip_vary on; - - server { - listen 8080; - server_name localhost; - - location / { - root /usr/share/nginx/html; - try_files $uri $uri/ /index.html; - index index.html; - # Enable CORS - add_header 'Access-Control-Allow-Origin' '*'; - add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; - add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type'; - if ($request_method = 'OPTIONS') { - add_header 'Access-Control-Max-Age' 1728000; - add_header 'Content-Type' 'text/plain charset=UTF-8'; - add_header 'Content-Length' 0; - return 204; - } - } - - error_page 500 502 503 504 /50x.html; - - location = /50x.html { - root /usr/share/nginx/html; - } - } -} - -# stream { # stream 模块配置和 http 模块在相同级别 -# upstream redis { -# server 127.0.0.1:6379 max_fails=3 fail_timeout=30s; -# } -# server { -# listen 16379; -# proxy_connect_timeout 1s; -# proxy_timeout 3s; -# proxy_pass redis; -# } -# } diff --git a/docs/src/guide/in-depth/loading.md b/docs/src/guide/in-depth/loading.md index 99b895fe..663cb59d 100644 --- a/docs/src/guide/in-depth/loading.md +++ b/docs/src/guide/in-depth/loading.md @@ -6,7 +6,7 @@ ## 原理 -由 `vite-plugin-inject-app-loading` 插件实现,插件会在每个页面的注入一个全局的 loading html。 +由 `vite-plugin-inject-app-loading` 插件实现,插件会在每个应用的注入一个全局的 `loading html`。 ## 关闭 diff --git a/internal/lint-configs/commitlint-config/index.mjs b/internal/lint-configs/commitlint-config/index.mjs index 552a94c6..8f8092d1 100644 --- a/internal/lint-configs/commitlint-config/index.mjs +++ b/internal/lint-configs/commitlint-config/index.mjs @@ -47,7 +47,6 @@ const userConfig = { defaultScope: scopeComplete, // English typesAppend: [ - { name: 'wip: work in process', value: 'wip' }, { name: 'workflow: workflow improvements', value: 'workflow' }, { name: 'types: type definition file changes', value: 'types' }, ], @@ -122,7 +121,7 @@ const userConfig = { 'header-max-length': [2, 'always', 108], 'scope-enum': [0], - 'subject-case': [0], + 'subject-case': [2, 'always', 'lower-case'], 'subject-empty': [2, 'never'], 'type-empty': [2, 'never'], /** diff --git a/internal/vite-config/src/config/application.ts b/internal/vite-config/src/config/application.ts index 78743a86..317d69ad 100644 --- a/internal/vite-config/src/config/application.ts +++ b/internal/vite-config/src/config/application.ts @@ -15,8 +15,8 @@ import { getCommonConfig } from './common'; function defineApplicationConfig(userConfigPromise?: DefineApplicationOptions) { return defineConfig(async (config) => { - const { appTitle, base, port, ...envConfig } = await loadAndConvertEnv(); const options = await userConfigPromise?.(config); + const { appTitle, base, port, ...envConfig } = await loadAndConvertEnv(); const { command, mode } = config; const { application = {}, vite = {} } = options || {}; const root = process.cwd(); @@ -78,16 +78,16 @@ function defineApplicationConfig(userConfigPromise?: DefineApplicationOptions) { port, warmup: { // 预热文件 - clientFiles: ['./index.html', './src/{views,layouts}/*'], + clientFiles: ['./index.html', './src/{views,layouts,router,store}/*'], }, }, }; - const mergedConfig = mergeConfig( + const mergedCommonConfig = mergeConfig( await getCommonConfig(), applicationConfig, ); - return mergeConfig(mergedConfig, vite); + return mergeConfig(mergedCommonConfig, vite); }); } diff --git a/internal/vite-config/src/config/library.ts b/internal/vite-config/src/config/library.ts index 931babdb..759fc7bc 100644 --- a/internal/vite-config/src/config/library.ts +++ b/internal/vite-config/src/config/library.ts @@ -13,8 +13,8 @@ function defineLibraryConfig(userConfigPromise?: DefineLibraryOptions) { return defineConfig(async (config: ConfigEnv) => { const options = await userConfigPromise?.(config); const { command, mode } = config; - const root = process.cwd(); const { library = {}, vite = {} } = options || {}; + const root = process.cwd(); const isBuild = command === 'build'; const plugins = await loadLibraryPlugins({ @@ -52,8 +52,8 @@ function defineLibraryConfig(userConfigPromise?: DefineLibraryOptions) { plugins, }; const commonConfig = await getCommonConfig(); - const mergedConfig = mergeConfig(commonConfig, packageConfig); - return mergeConfig(mergedConfig, vite); + const mergedConmonConfig = mergeConfig(commonConfig, packageConfig); + return mergeConfig(mergedConmonConfig, vite); }); } diff --git a/internal/vite-config/src/options.ts b/internal/vite-config/src/options.ts index 2c3bd59e..b3d44624 100644 --- a/internal/vite-config/src/options.ts +++ b/internal/vite-config/src/options.ts @@ -28,12 +28,12 @@ const getDefaultPwaOptions = (name: string): Partial => ({ const defaultImportmapOptions: ImportmapPluginOptions = { // 通过 Importmap CDN 方式引入, // 目前只有esm.sh源兼容性好一点,jspm.io对于 esm 入口要求高 - defaultProvider: 'jspm.io', + defaultProvider: 'esm.sh', importmap: [ { name: 'vue' }, { name: 'pinia' }, { name: 'vue-router' }, - { name: 'vue-i18n' }, + // { name: 'vue-i18n' }, { name: 'dayjs' }, { name: 'vue-demi' }, ], diff --git a/internal/vite-config/src/plugins/inject-app-loading/README.md b/internal/vite-config/src/plugins/inject-app-loading/README.md index 504fcd54..8d2358f7 100644 --- a/internal/vite-config/src/plugins/inject-app-loading/README.md +++ b/internal/vite-config/src/plugins/inject-app-loading/README.md @@ -1,3 +1,3 @@ # inject-app-loading -用于在应用加载时显示加载动画的插件。可自行选择加载动画的样式。 +用于在应用加载时显示加载动画的插件,可自行选择加载动画的样式。 diff --git a/internal/vite-config/src/plugins/inject-app-loading/default-loading.html b/internal/vite-config/src/plugins/inject-app-loading/default-loading.html index 725a4c31..26ed4c99 100644 --- a/internal/vite-config/src/plugins/inject-app-loading/default-loading.html +++ b/internal/vite-config/src/plugins/inject-app-loading/default-loading.html @@ -25,7 +25,7 @@ pointer-events: none; visibility: hidden; opacity: 0; - transition: all 0.6s ease-out; + transition: all 1s ease-out; } .dark .loading { diff --git a/internal/vite-config/src/plugins/inject-app-loading/index.ts b/internal/vite-config/src/plugins/inject-app-loading/index.ts index d3e4f0f1..9f6e2a5c 100644 --- a/internal/vite-config/src/plugins/inject-app-loading/index.ts +++ b/internal/vite-config/src/plugins/inject-app-loading/index.ts @@ -52,19 +52,15 @@ async function viteInjectAppLoadingPlugin( * 用于获取loading的html模板 */ async function getLoadingRawByHtmlTemplate(loadingTemplate: string) { - const __dirname = fileURLToPath(new URL('.', import.meta.url)); - const defaultLoadingPath = join(__dirname, './default-loading.html'); // 支持在app内自定义loading模板,模版参考default-loading.html即可 - const appLoadingPath = join(process.cwd(), loadingTemplate); - let loadingPath = defaultLoadingPath; + let appLoadingPath = join(process.cwd(), loadingTemplate); - if (fs.existsSync(appLoadingPath)) { - loadingPath = appLoadingPath; - return; + if (!fs.existsSync(appLoadingPath)) { + const __dirname = fileURLToPath(new URL('.', import.meta.url)); + appLoadingPath = join(__dirname, './default-loading.html'); } - const htmlRaw = await fsp.readFile(loadingPath, 'utf8'); - return htmlRaw; + return await fsp.readFile(appLoadingPath, 'utf8'); } export { viteInjectAppLoadingPlugin }; diff --git a/internal/vite-config/src/typing.ts b/internal/vite-config/src/typing.ts index afa970d9..86609c62 100644 --- a/internal/vite-config/src/typing.ts +++ b/internal/vite-config/src/typing.ts @@ -74,13 +74,13 @@ interface CommonPluginOptions { } interface ApplicationPluginOptions extends CommonPluginOptions { - /** 开启 gzip 压缩 */ + /** 开启 gzip|brotli 压缩 */ compress?: boolean; /** 压缩类型 */ compressTypes?: ('brotli' | 'gzip')[]; /** 在构建的时候抽离配置文件 */ extraAppConfig?: boolean; - /** html 插件配置 */ + /** 是否开启html插件 */ html?: boolean; /** 是否开启i18n */ i18n?: boolean; @@ -98,7 +98,7 @@ interface ApplicationPluginOptions extends CommonPluginOptions { nitroMock?: boolean; /** nitro mock 插件配置 */ nitroMockOptions?: NitroMockPluginOptions; - /** dev是否开启mock服务 */ + /** 开启控制台自定义打印 */ print?: boolean; /** 打印插件配置 */ printInfoMap?: PrintPluginOptions['infoMap']; diff --git a/packages/@core/preferences/src/preferences.test.ts b/packages/@core/preferences/src/preferences.test.ts index 786de946..169358ec 100644 --- a/packages/@core/preferences/src/preferences.test.ts +++ b/packages/@core/preferences/src/preferences.test.ts @@ -1,7 +1,8 @@ import { beforeEach, describe, expect, it, vi } from 'vitest'; import { defaultPreferences } from './config'; -import { isDarkTheme, PreferenceManager } from './preferences'; +import { PreferenceManager } from './preferences'; +import { isDarkTheme } from './update-css-variables'; describe('preferences', () => { let preferenceManager: PreferenceManager; diff --git a/packages/@core/preferences/src/preferences.ts b/packages/@core/preferences/src/preferences.ts index 18ceaac2..f164a6b9 100644 --- a/packages/@core/preferences/src/preferences.ts +++ b/packages/@core/preferences/src/preferences.ts @@ -19,14 +19,6 @@ const STORAGE_KEY = 'preferences'; const STORAGE_KEY_LOCALE = `${STORAGE_KEY}-locale`; const STORAGE_KEY_THEME = `${STORAGE_KEY}-theme`; -function isDarkTheme(theme: string) { - let dark = theme === 'dark'; - if (theme === 'auto') { - dark = window.matchMedia('(prefers-color-scheme: dark)').matches; - } - return dark; -} - class PreferenceManager { private cache: null | StorageManager = null; // private flattenedState: Flatten; @@ -39,6 +31,7 @@ class PreferenceManager { constructor() { this.cache = new StorageManager(); + // 避免频繁的操作缓存 this.savePreferences = useDebounceFn( (preference: Preferences) => this._savePreferences(preference), 150, @@ -58,7 +51,6 @@ class PreferenceManager { /** * 处理更新的键值 * 根据更新的键值执行相应的操作。 - * * @param {DeepPartial} updates - 部分更新的偏好设置 */ private handleUpdates(updates: DeepPartial) { @@ -124,7 +116,7 @@ class PreferenceManager { this.updatePreferences({ theme: { mode: isDark ? 'dark' : 'light' }, }); - updateCSSVariables(this.state); + // updateCSSVariables(this.state); }); } @@ -232,4 +224,4 @@ class PreferenceManager { } const preferencesManager = new PreferenceManager(); -export { isDarkTheme, PreferenceManager, preferencesManager }; +export { PreferenceManager, preferencesManager }; diff --git a/packages/@core/preferences/src/update-css-variables.ts b/packages/@core/preferences/src/update-css-variables.ts index 1a2289bc..35d89d75 100644 --- a/packages/@core/preferences/src/update-css-variables.ts +++ b/packages/@core/preferences/src/update-css-variables.ts @@ -115,4 +115,4 @@ function isDarkTheme(theme: string) { return dark; } -export { updateCSSVariables }; +export { isDarkTheme, updateCSSVariables }; diff --git a/packages/@core/preferences/src/use-preferences.ts b/packages/@core/preferences/src/use-preferences.ts index 02526d64..b13b327b 100644 --- a/packages/@core/preferences/src/use-preferences.ts +++ b/packages/@core/preferences/src/use-preferences.ts @@ -2,7 +2,8 @@ import { computed } from 'vue'; import { diff } from '@vben-core/shared'; -import { isDarkTheme, preferencesManager } from './preferences'; +import { preferencesManager } from './preferences'; +import { isDarkTheme } from './update-css-variables'; function usePreferences() { const preferences = preferencesManager.getPreferences(); diff --git a/packages/effects/hooks/src/use-design-tokens.ts b/packages/effects/hooks/src/use-design-tokens.ts index a00f9690..9839aa34 100644 --- a/packages/effects/hooks/src/use-design-tokens.ts +++ b/packages/effects/hooks/src/use-design-tokens.ts @@ -209,7 +209,7 @@ export function useElementPlusDesignTokens() { '--el-text-color-primary': getCssVariableValue('--foreground'), '--el-text-color-regular': getCssVariableValue('--foreground'), }; - updateCSSVariables(variables, `__vben_ele_styles__`); + updateCSSVariables(variables, `__vben_design_styles__`); }, { immediate: true }, ); diff --git a/packages/utils/src/helpers/unmount-global-loading.ts b/packages/utils/src/helpers/unmount-global-loading.ts index daa5454b..10b88eae 100644 --- a/packages/utils/src/helpers/unmount-global-loading.ts +++ b/packages/utils/src/helpers/unmount-global-loading.ts @@ -3,6 +3,7 @@ * 放在这里是而不是放在 index.html 的app标签内,是因为这样比较不会生硬,渲染过快可能会有闪烁 * 通过先添加css动画隐藏,在动画结束后在移除loading节点来改善体验 * 不好的地方是会增加一些代码量 + * 自定义loading可以见:https://doc.vben.pro/guide/in-depth/loading.html */ export function unmountGlobalLoading() { // 查找全局 loading 元素 diff --git a/scripts/turbo-run/src/run.ts b/scripts/turbo-run/src/run.ts index 9475cd07..9371c646 100644 --- a/scripts/turbo-run/src/run.ts +++ b/scripts/turbo-run/src/run.ts @@ -20,7 +20,7 @@ export async function run(options: RunOptions) { // 只显示有对应命令的包 const selectPkgs = packages.filter((pkg) => { - return (pkg?.packageJson as Record).scripts?.[command]; + return (pkg?.packageJson as Record)?.scripts?.[command]; }); const selectPkg = await select({