diff --git a/.vscode/settings.json b/.vscode/settings.json index 06350601..e5492073 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -21,6 +21,7 @@ "cSpell.words": [ "Clickoutside", "commitmsg", + "datetimerange", "domtoimage", "EDITMSG", "macarons", diff --git a/CHANGELOG.md b/CHANGELOG.md index 2ddb1baf..4e006ed6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,48 @@ # CHANGE LOG +## 4.6.0 + +破坏性更新,请谨慎更新。 + +提升了模板整体性能。 + +## Feats + +- 更新 `vue` 版本至 `3.4.7` +- 更新 `naive-ui` 版本至 `2.37.3` +- 更新最新版本 `vue` 后,更新 `createDiscreteApi` 方法注册上下文,改为函数包裹,避免 `slot default invoked outside of render` 警告 +- 使用 [`NFlex`](https://www.naiveui.com/zh-CN/dark/components/flex) 组件替换 `NSpace` 组件,根据官方建议,尽量使用该组件 +- `menu store` 相关 + - 优化 `setupAppMenu` 方法,初始化时会拼接完整的 `fullPath`,避免 `url`, `menu value` 更新路由时重复处理 `path`,提高性能 + - 优化 `updateMenuKeyWhenRouteUpdate` 方法,减少 `path` 处理操作 + - 优化 `changeMenuModelValue` 方法,减少 `path` 处理操作 + - 移除 `emptyMenuTagOptions` 方法,使用 `spliceMenTagOptions` 方法替代 +- 由于更新了 `path` 逻辑,所以 `menu store`, `AppMenu` 等相关也同步更新 + - `AppMenu` 更新 `key` 绑定字段为 `fullPath` + - `menu store` 更新 `menuKey` 绑定字段为 `fullPath` + - 更新 `parseAndFindMatchingNodes` 绑定字段为 `fullPath` +- `useAppNavigation` 相关 + - `navigationTo` 相关 + - 重构该方法 + - 支持传递完整路径跳转 + - 支持传递参数 `vue-router query` 对象 + - 支持配置项,详情请看 `NavigationToOptions` +- `useSiderBar` 相关 + - 同步更新所有方法,使用 `fullPath` 代替 `path` +- `useContextmenuCoordinate` 方法 + - 使用 `readonly` 方法包裹 `show` 属性 + - 补充一些注释 +- 统一 `app-config` 的导入导出方式,现在统一为 `import { xxx } from '@/app-config'` 导入 +- 统一 `hooks` 包的导入导出方式,现在统一为 `import { xxx } from '@/hooks'` 导入 +- `app-config` 相关 + - 开放 `APP_CATCH_KEY.appMenuKey` 属性,配置缓存读取字段 +- `useMaximize` 相关 + - 优化 `maximize` 方法,现在支持配置滚动位置 + +## Fixes + +- 修复 `RChart` 组件 `RChartInst` 类型不完整的问题 + ## 4.5.0 破坏性更新。 diff --git a/package.json b/package.json index 82542875..6f16bfce 100755 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "ray-template", "private": false, - "version": "4.5.0", + "version": "4.6.0", "type": "module", "engines": { "node": "^18.0.0 || >=20.0.0", @@ -44,13 +44,13 @@ "interactjs": "1.10.26", "lodash-es": "^4.17.21", "mockjs": "1.1.0", - "naive-ui": "^2.36.0", + "naive-ui": "^2.37.3", "pinia": "^2.1.7", "pinia-plugin-persistedstate": "^3.2.0", "print-js": "^1.6.0", - "vue": "^3.4.0", + "vue": "^3.4.7", "vue-hooks-plus": "1.8.5", - "vue-i18n": "^9.8.0", + "vue-i18n": "^9.9.0", "vue-router": "^4.2.5", "xlsx": "^0.18.5" }, diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index fbaed425..f5ffe192 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -7,7 +7,7 @@ settings: dependencies: '@vueuse/core': specifier: ^10.6.1 - version: 10.6.1(vue@3.4.0) + version: 10.6.1(vue@3.4.7) awesome-qr: specifier: 2.1.5-rc.0 version: 2.1.5-rc.0 @@ -42,11 +42,11 @@ dependencies: specifier: 1.1.0 version: 1.1.0 naive-ui: - specifier: ^2.36.0 - version: 2.36.0(vue@3.4.0) + specifier: ^2.37.3 + version: 2.37.3(vue@3.4.7) pinia: specifier: ^2.1.7 - version: 2.1.7(typescript@5.2.2)(vue@3.4.0) + version: 2.1.7(typescript@5.2.2)(vue@3.4.7) pinia-plugin-persistedstate: specifier: ^3.2.0 version: 3.2.0(pinia@2.1.7) @@ -54,17 +54,17 @@ dependencies: specifier: ^1.6.0 version: 1.6.0 vue: - specifier: ^3.4.0 - version: 3.4.0(typescript@5.2.2) + specifier: ^3.4.7 + version: 3.4.7(typescript@5.2.2) vue-hooks-plus: specifier: 1.8.5 - version: 1.8.5(vue@3.4.0) + version: 1.8.5(vue@3.4.7) vue-i18n: - specifier: ^9.8.0 - version: 9.8.0(vue@3.4.0) + specifier: ^9.9.0 + version: 9.9.0(vue@3.4.7) vue-router: specifier: ^4.2.5 - version: 4.2.5(vue@3.4.0) + version: 4.2.5(vue@3.4.7) xlsx: specifier: ^0.18.5 version: 0.18.5 @@ -87,7 +87,7 @@ devDependencies: version: 1.10.21 '@intlify/unplugin-vue-i18n': specifier: ^1.5.0 - version: 1.5.0(vue-i18n@9.8.0) + version: 1.5.0(vue-i18n@9.9.0) '@types/crypto-js': specifier: ^4.1.1 version: 4.1.1 @@ -108,10 +108,10 @@ devDependencies: version: 6.5.0(eslint@8.52.0)(typescript@5.2.2) '@vitejs/plugin-vue': specifier: ^5.0.0 - version: 5.0.0(vite@5.0.10)(vue@3.4.0) + version: 5.0.0(vite@5.0.10)(vue@3.4.7) '@vitejs/plugin-vue-jsx': specifier: ^3.1.0 - version: 3.1.0(vite@5.0.10)(vue@3.4.0) + version: 3.1.0(vite@5.0.10)(vue@3.4.7) '@vue-hooks-plus/resolvers': specifier: 1.2.4 version: 1.2.4(vue-hooks-plus@1.8.5) @@ -183,7 +183,7 @@ devDependencies: version: 0.16.6(@vueuse/core@10.6.1) unplugin-vue-components: specifier: ^0.25.2 - version: 0.25.2(vue@3.4.0) + version: 0.25.2(vue@3.4.7) vite: specifier: ^5.0.10 version: 5.0.10(@types/node@20.4.7)(sass@1.69.5) @@ -387,9 +387,6 @@ packages: engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - peerDependenciesMeta: - '@babel/core': - optional: true dependencies: '@babel/core': 7.23.6 '@babel/helper-annotate-as-pure': 7.22.5 @@ -495,9 +492,6 @@ packages: engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - peerDependenciesMeta: - '@babel/core': - optional: true dependencies: '@babel/core': 7.23.6 '@babel/helper-environment-visitor': 7.22.20 @@ -933,12 +927,12 @@ packages: css-render: 0.15.12 dev: false - /@css-render/vue3-ssr@0.15.12(vue@3.4.0): + /@css-render/vue3-ssr@0.15.12(vue@3.4.7): resolution: {integrity: sha512-AQLGhhaE0F+rwybRCkKUdzBdTEM/5PZBYy+fSYe1T9z9+yxMuV/k7ZRqa4M69X+EI1W8pa4kc9Iq2VjQkZx4rg==} peerDependencies: vue: ^3.0.11 dependencies: - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) dev: false /@emotion/hash@0.8.0: @@ -1415,7 +1409,7 @@ packages: resolution: {integrity: sha512-DekYpdkMV3XJVd/0k3f4pJluZAsCiG86yEtVXvGLK0lS/Fj0+OzYEv7HoMpcBZSkQ8s7//yaeEBgnxy2tV81lA==} dev: false - /@intlify/bundle-utils@7.4.0(vue-i18n@9.8.0): + /@intlify/bundle-utils@7.4.0(vue-i18n@9.9.0): resolution: {integrity: sha512-AQfjBe2HUxzyN8ignIk3WhhSuVcSuirgzOzkd17nb337rCbI4Gv/t1R60UUyIqFoFdviLb/wLcDUzTD/xXjv9w==} engines: {node: '>= 14.16'} peerDependencies: @@ -1436,16 +1430,16 @@ packages: magic-string: 0.30.5 mlly: 1.4.1 source-map-js: 1.0.2 - vue-i18n: 9.8.0(vue@3.4.0) + vue-i18n: 9.9.0(vue@3.4.7) yaml-eslint-parser: 1.2.2 dev: true - /@intlify/core-base@9.8.0: - resolution: {integrity: sha512-UxaSZVZ1DwqC/CltUZrWZNaWNhfmKtfyV4BJSt/Zt4Or/fZs1iFj0B+OekYk1+MRHfIOe3+x00uXGQI4PbO/9g==} + /@intlify/core-base@9.9.0: + resolution: {integrity: sha512-C7UXPymDIOlMGSNjAhNLtKgzITc/8BjINK5gNKXg8GiWCTwL6n3MWr55czksxn8RM5wTMz0qcLOFT+adtaVQaA==} engines: {node: '>= 16'} dependencies: - '@intlify/message-compiler': 9.8.0 - '@intlify/shared': 9.8.0 + '@intlify/message-compiler': 9.9.0 + '@intlify/shared': 9.9.0 /@intlify/message-compiler@9.7.0: resolution: {integrity: sha512-/YdZCio2L2tCM5bZ2eMHbSEIQNPh1QqvZIOLI/yCVKXLscis7O0SsR2nmuU/DfCJ3iSeI8juw82C2wLvfsAeww==} @@ -1455,11 +1449,11 @@ packages: source-map-js: 1.0.2 dev: true - /@intlify/message-compiler@9.8.0: - resolution: {integrity: sha512-McnYWhcoYmDJvssVu6QGR0shqlkJuL1HHdi5lK7fNqvQqRYaQ4lSLjYmZxwc8tRNMdIe9/KUKfyPxU9M6yCtNQ==} + /@intlify/message-compiler@9.9.0: + resolution: {integrity: sha512-yDU/jdUm9KuhEzYfS+wuyja209yXgdl1XFhMlKtXEgSFTxz4COZQCRXXbbH8JrAjMsaJ7bdoPSLsKlY6mXG2iA==} engines: {node: '>= 16'} dependencies: - '@intlify/shared': 9.8.0 + '@intlify/shared': 9.9.0 source-map-js: 1.0.2 /@intlify/shared@9.7.0: @@ -1467,11 +1461,11 @@ packages: engines: {node: '>= 16'} dev: true - /@intlify/shared@9.8.0: - resolution: {integrity: sha512-TmgR0RCLjzrSo+W3wT0ALf9851iFMlVI9EYNGeWvZFUQTAJx0bvfsMlPdgVtV1tDNRiAfhkFsMKu6jtUY1ZLKQ==} + /@intlify/shared@9.9.0: + resolution: {integrity: sha512-1ECUyAHRrzOJbOizyGufYP2yukqGrWXtkmTu4PcswVnWbkcjzk3YQGmJ0bLkM7JZ0ZYAaohLGdYvBYnTOGYJ9g==} engines: {node: '>= 16'} - /@intlify/unplugin-vue-i18n@1.5.0(vue-i18n@9.8.0): + /@intlify/unplugin-vue-i18n@1.5.0(vue-i18n@9.9.0): resolution: {integrity: sha512-jW0MCCdwxybxcwjEfCunAcKjVoxyO3i+cnLL6v+MNGRLUHqrpELF6zQAJUhgAK2afhY7mCliy8RxTFWKdXm26w==} engines: {node: '>= 14.16'} peerDependencies: @@ -1486,7 +1480,7 @@ packages: vue-i18n-bridge: optional: true dependencies: - '@intlify/bundle-utils': 7.4.0(vue-i18n@9.8.0) + '@intlify/bundle-utils': 7.4.0(vue-i18n@9.9.0) '@intlify/shared': 9.7.0 '@rollup/pluginutils': 5.0.4 '@vue/compiler-sfc': 3.3.8 @@ -1498,7 +1492,7 @@ packages: picocolors: 1.0.0 source-map-js: 1.0.2 unplugin: 1.4.0 - vue-i18n: 9.8.0(vue@3.4.0) + vue-i18n: 9.9.0(vue@3.4.7) transitivePeerDependencies: - rollup - supports-color @@ -2117,7 +2111,7 @@ packages: resolution: {integrity: sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==} dev: true - /@vitejs/plugin-vue-jsx@3.1.0(vite@5.0.10)(vue@3.4.0): + /@vitejs/plugin-vue-jsx@3.1.0(vite@5.0.10)(vue@3.4.7): resolution: {integrity: sha512-w9M6F3LSEU5kszVb9An2/MmXNxocAnUb3WhRr8bHlimhDrXNt6n6D2nJQR3UXpGlZHh/EsgouOHCsM8V3Ln+WA==} engines: {node: ^14.18.0 || >=16.0.0} peerDependencies: @@ -2128,12 +2122,12 @@ packages: '@babel/plugin-transform-typescript': 7.23.6(@babel/core@7.23.6) '@vue/babel-plugin-jsx': 1.1.5(@babel/core@7.23.6) vite: 5.0.10(@types/node@20.4.7)(sass@1.69.5) - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) transitivePeerDependencies: - supports-color dev: true - /@vitejs/plugin-vue@5.0.0(vite@5.0.10)(vue@3.4.0): + /@vitejs/plugin-vue@5.0.0(vite@5.0.10)(vue@3.4.7): resolution: {integrity: sha512-7x5e8X4J1Wi4NxudGjJBd2OFerAi/0nzF80ojCzvfj347WVr0YSn82C8BSsgwSHzlk9Kw5xnZfj0/7RLnNwP5w==} engines: {node: ^18.0.0 || >=20.0.0} peerDependencies: @@ -2141,7 +2135,7 @@ packages: vue: ^3.2.25 dependencies: vite: 5.0.10(@types/node@20.4.7)(sass@1.69.5) - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) dev: true /@volar/language-core@1.10.1: @@ -2169,7 +2163,7 @@ packages: vue-hooks-plus: ^1.5.2 dependencies: local-pkg: 0.4.3 - vue-hooks-plus: 1.8.5(vue@3.4.0) + vue-hooks-plus: 1.8.5(vue@3.4.7) dev: true /@vue/babel-helper-vue-transform-on@1.1.5: @@ -2213,11 +2207,11 @@ packages: source-map-js: 1.0.2 dev: true - /@vue/compiler-core@3.4.0: - resolution: {integrity: sha512-cw4S15PkNGTKkP9OFFl4wnQoJJk+HqaYBafgrpDnSukiQGpcYJeRpzmqnCVCIkl6V6Eqsv58E0OAdl6b592vuA==} + /@vue/compiler-core@3.4.7: + resolution: {integrity: sha512-hhCaE3pTMrlIJK7M/o3Xf7HV8+JoNTGOQ/coWS+V+pH6QFFyqtoXqQzpqsNp7UK17xYKua/MBiKj4e1vgZOBYw==} dependencies: '@babel/parser': 7.23.6 - '@vue/shared': 3.4.0 + '@vue/shared': 3.4.7 entities: 4.5.0 estree-walker: 2.0.2 source-map-js: 1.0.2 @@ -2236,11 +2230,11 @@ packages: '@vue/shared': 3.3.8 dev: true - /@vue/compiler-dom@3.4.0: - resolution: {integrity: sha512-E957uOhpoE48YjZGWeAoLmNYd3UeU4oIP8kJi8Rcsb9l2tV8Z48Jn07Zgq1aW0v3vuhlmydEKkKKbhLpADHXEA==} + /@vue/compiler-dom@3.4.7: + resolution: {integrity: sha512-qDKBAIurCTub4n/6jDYkXwgsFuriqqmmLrIq1N2QDfYJA/mwiwvxi09OGn28g+uDdERX9NaKDLji0oTjE3sScg==} dependencies: - '@vue/compiler-core': 3.4.0 - '@vue/shared': 3.4.0 + '@vue/compiler-core': 3.4.7 + '@vue/shared': 3.4.7 /@vue/compiler-sfc@3.3.8: resolution: {integrity: sha512-WMzbUrlTjfYF8joyT84HfwwXo+8WPALuPxhy+BZ6R4Aafls+jDBnSz8PDz60uFhuqFbl3HxRfxvDzrUf3THwpA==} @@ -2257,14 +2251,14 @@ packages: source-map-js: 1.0.2 dev: true - /@vue/compiler-sfc@3.4.0: - resolution: {integrity: sha512-PWE0mE2yW7bJS7PmaCrVDEG6KPaDJo0pb4AKnCxJ5lRRDO4IwL/fswBGhCpov+v/c+N/e+hQHpXNwvqU9BtUXg==} + /@vue/compiler-sfc@3.4.7: + resolution: {integrity: sha512-Gec6CLkReVswDYjQFq79O5rktri4R7TsD/VPCiUoJw40JhNNxaNJJa8mrQrWoJluW4ETy6QN0NUyC/JO77OCOw==} dependencies: '@babel/parser': 7.23.6 - '@vue/compiler-core': 3.4.0 - '@vue/compiler-dom': 3.4.0 - '@vue/compiler-ssr': 3.4.0 - '@vue/shared': 3.4.0 + '@vue/compiler-core': 3.4.7 + '@vue/compiler-dom': 3.4.7 + '@vue/compiler-ssr': 3.4.7 + '@vue/shared': 3.4.7 estree-walker: 2.0.2 magic-string: 0.30.5 postcss: 8.4.32 @@ -2277,11 +2271,11 @@ packages: '@vue/shared': 3.3.8 dev: true - /@vue/compiler-ssr@3.4.0: - resolution: {integrity: sha512-+oXKy105g9DIYQKDi3Gwung0xqQX5gJHr0GR+Vf7yK/WkNDM6q61ummcKmKAB85EIst8y3vj2PA9z9YU5Oc4DQ==} + /@vue/compiler-ssr@3.4.7: + resolution: {integrity: sha512-PvYeSOvnCkST5mGS0TLwEn5w+4GavtEn6adcq8AspbHaIr+mId5hp7cG3ASy3iy8b+LuXEG2/QaV/nj5BQ/Aww==} dependencies: - '@vue/compiler-dom': 3.4.0 - '@vue/shared': 3.4.0 + '@vue/compiler-dom': 3.4.7 + '@vue/shared': 3.4.7 /@vue/devtools-api@6.5.1: resolution: {integrity: sha512-+KpckaAQyfbvshdDW5xQylLni1asvNSGme1JFs8I1+/H5pHEhqUKMEQD/qn3Nx5+/nycBq11qAEi8lk+LXI2dA==} @@ -2356,32 +2350,32 @@ packages: '@vue/shared': 3.3.8 dev: true - /@vue/reactivity@3.4.0: - resolution: {integrity: sha512-X6BvQjNcgKKHWPQzlRJjZvIu72Kkn8xJSv6VNptqWh8dToMknD0Hch1l4N7llKgVt6Diq4lMeUnErbZFvuGlAA==} + /@vue/reactivity@3.4.7: + resolution: {integrity: sha512-F539DO0ogH0+L8F9Pnw7cjqibcmSOh5UTk16u5f4MKQ8fraqepI9zdh+sozPX6VmEHOcjo8qw3Or9ZcFFw4SZA==} dependencies: - '@vue/shared': 3.4.0 + '@vue/shared': 3.4.7 - /@vue/runtime-core@3.4.0: - resolution: {integrity: sha512-NYrj/JgMMqnSWcIud8lLzDQrBLu+EVEeQ56QE9DYJeKG2eFrnQy8o/h57R9nCprafHs0uImKL3xsdXjHseYVxw==} + /@vue/runtime-core@3.4.7: + resolution: {integrity: sha512-QMMsWRQaD3BpGyjjChthpl4Mji4Fjx1qfdufsXlDkKU3HV+hWNor2z+29F+E1MmVcP0ZfRZUfqYgtsQoL7IGwQ==} dependencies: - '@vue/reactivity': 3.4.0 - '@vue/shared': 3.4.0 + '@vue/reactivity': 3.4.7 + '@vue/shared': 3.4.7 - /@vue/runtime-dom@3.4.0: - resolution: {integrity: sha512-1ZoHEsA5l77qbx2F+SWo/hQdBksPuOmww1t/jznidDG+xMB/iidafEFvo2ZTtZii0JfTIrlDhjshfYUvQC17wQ==} + /@vue/runtime-dom@3.4.7: + resolution: {integrity: sha512-XwegyUY1rw8zxsX1Z36vwYcqo+uOgih5ti7y9vx+pPFhNdSQmN4LqK2RmSeAJG1oKV8NqSUmjpv92f/x6h0SeQ==} dependencies: - '@vue/runtime-core': 3.4.0 - '@vue/shared': 3.4.0 + '@vue/runtime-core': 3.4.7 + '@vue/shared': 3.4.7 csstype: 3.1.3 - /@vue/server-renderer@3.4.0(vue@3.4.0): - resolution: {integrity: sha512-GuOVCyLDlWPu8nKo5AUxb8B+iB/Ik4I1WwqAlBqf5+y48z6D6rvKshp7KR3cJea+pte1tdTsb0+Ja82KizMZOw==} + /@vue/server-renderer@3.4.7(vue@3.4.7): + resolution: {integrity: sha512-3bWnYLEkLLhkDWqvNk7IvbQD4UcxvFKxELBiOO2iG3m6AniFIsBWfHOO5tLVQnjdWkODu4rq0GipmfEenVAK5Q==} peerDependencies: - vue: 3.4.0 + vue: 3.4.7 dependencies: - '@vue/compiler-ssr': 3.4.0 - '@vue/shared': 3.4.0 - vue: 3.4.0(typescript@5.2.2) + '@vue/compiler-ssr': 3.4.7 + '@vue/shared': 3.4.7 + vue: 3.4.7(typescript@5.2.2) /@vue/shared@3.3.13: resolution: {integrity: sha512-/zYUwiHD8j7gKx2argXEMCUXVST6q/21DFU0sTfNX0URJroCe3b1UF6vLJ3lQDfLNIiiRl2ONp7Nh5UVWS6QnA==} @@ -2391,8 +2385,8 @@ packages: resolution: {integrity: sha512-8PGwybFwM4x8pcfgqEQFy70NaQxASvOC5DJwLQfpArw1UDfUXrJkdxD3BhVTMS+0Lef/TU7YO0Jvr0jJY8T+mw==} dev: true - /@vue/shared@3.4.0: - resolution: {integrity: sha512-Nhh3ed3G1R6HDAWiG6YYFt0Zmq/To6u5vjzwa9TIquGheCXPY6nEdIAO8ZdlwXsWqC2yNLj700FOvShpYt5CEA==} + /@vue/shared@3.4.7: + resolution: {integrity: sha512-G+i4glX1dMJk88sbJEcQEGWRQnVm9eIY7CcQbO5dpdsD9SF8jka3Mr5OqZYGjczGN1+D6EUwdu6phcmcx9iuPA==} /@vue/typescript@1.8.8(typescript@5.2.2): resolution: {integrity: sha512-jUnmMB6egu5wl342eaUH236v8tdcEPXXkPgj+eI/F6JwW/lb+yAU6U07ZbQ3MVabZRlupIlPESB7ajgAGixhow==} @@ -2403,13 +2397,13 @@ packages: - typescript dev: true - /@vueuse/core@10.6.1(vue@3.4.0): + /@vueuse/core@10.6.1(vue@3.4.7): resolution: {integrity: sha512-Pc26IJbqgC9VG1u6VY/xrXXfxD33hnvxBnKrLlA2LJlyHII+BSrRoTPJgGYq7qZOu61itITFUnm6QbacwZ4H8Q==} dependencies: '@types/web-bluetooth': 0.0.20 '@vueuse/metadata': 10.6.1 - '@vueuse/shared': 10.6.1(vue@3.4.0) - vue-demi: 0.14.6(vue@3.4.0) + '@vueuse/shared': 10.6.1(vue@3.4.7) + vue-demi: 0.14.6(vue@3.4.7) transitivePeerDependencies: - '@vue/composition-api' - vue @@ -2417,10 +2411,10 @@ packages: /@vueuse/metadata@10.6.1: resolution: {integrity: sha512-qhdwPI65Bgcj23e5lpGfQsxcy0bMjCAsUGoXkJ7DsoeDUdasbZ2DBa4dinFCOER3lF4gwUv+UD2AlA11zdzMFw==} - /@vueuse/shared@10.6.1(vue@3.4.0): + /@vueuse/shared@10.6.1(vue@3.4.7): resolution: {integrity: sha512-TECVDTIedFlL0NUfHWncf3zF9Gc4VfdxfQc8JFwoVZQmxpONhLxFrlm0eHQeidHj4rdTPL3KXJa0TZCk1wnc5Q==} dependencies: - vue-demi: 0.14.6(vue@3.4.0) + vue-demi: 0.14.6(vue@3.4.7) transitivePeerDependencies: - '@vue/composition-api' - vue @@ -5984,18 +5978,19 @@ packages: minimatch: 3.1.2 dev: true - /naive-ui@2.36.0(vue@3.4.0): - resolution: {integrity: sha512-r1ydtEm1Ryf/aWpbLCf32mQAGK99jd1eXgpkCtIomcBRZeAtusfy6zCtIpCppoCuIKM3BW5DMafhVxilubk/lQ==} + /naive-ui@2.37.3(vue@3.4.7): + resolution: {integrity: sha512-aUkHFXVIluSi8Me+npbcsdv1NYhVMj5t9YaruoCESlqmfqspj+R2QHEVXkTtUI1kQwVrABMCtAGq/wountqjZA==} peerDependencies: vue: ^3.0.0 dependencies: '@css-render/plugin-bem': 0.15.12(css-render@0.15.12) - '@css-render/vue3-ssr': 0.15.12(vue@3.4.0) + '@css-render/vue3-ssr': 0.15.12(vue@3.4.7) '@types/katex': 0.16.7 '@types/lodash': 4.14.202 '@types/lodash-es': 4.17.11 async-validator: 4.2.5 css-render: 0.15.12 + csstype: 3.1.3 date-fns: 2.30.0 date-fns-tz: 2.0.0(date-fns@2.30.0) evtd: 0.2.4 @@ -6004,10 +5999,10 @@ packages: lodash-es: 4.17.21 seemly: 0.3.8 treemate: 0.3.11 - vdirs: 0.1.8(vue@3.4.0) - vooks: 0.2.12(vue@3.4.0) - vue: 3.4.0(typescript@5.2.2) - vueuc: 0.4.54(vue@3.4.0) + vdirs: 0.1.8(vue@3.4.7) + vooks: 0.2.12(vue@3.4.7) + vue: 3.4.7(typescript@5.2.2) + vueuc: 0.4.58(vue@3.4.7) dev: false /nan@2.17.0: @@ -6394,10 +6389,10 @@ packages: peerDependencies: pinia: ^2.0.0 dependencies: - pinia: 2.1.7(typescript@5.2.2)(vue@3.4.0) + pinia: 2.1.7(typescript@5.2.2)(vue@3.4.7) dev: false - /pinia@2.1.7(typescript@5.2.2)(vue@3.4.0): + /pinia@2.1.7(typescript@5.2.2)(vue@3.4.7): resolution: {integrity: sha512-+C2AHFtcFqjPih0zpYuvof37SFxMQ7OEG2zV9jRI12i9BOy3YQVAHwdKtyyc8pDcDyIc33WCIsZaCFWU7WWxGQ==} peerDependencies: '@vue/composition-api': ^1.4.0 @@ -6411,8 +6406,8 @@ packages: dependencies: '@vue/devtools-api': 6.5.1 typescript: 5.2.2 - vue: 3.4.0(typescript@5.2.2) - vue-demi: 0.14.6(vue@3.4.0) + vue: 3.4.7(typescript@5.2.2) + vue-demi: 0.14.6(vue@3.4.7) dev: false /pkg-types@1.0.3: @@ -7685,7 +7680,7 @@ packages: dependencies: '@antfu/utils': 0.7.6 '@rollup/pluginutils': 5.0.4 - '@vueuse/core': 10.6.1(vue@3.4.0) + '@vueuse/core': 10.6.1(vue@3.4.7) fast-glob: 3.3.1 local-pkg: 0.4.3 magic-string: 0.30.5 @@ -7696,7 +7691,7 @@ packages: - rollup dev: true - /unplugin-vue-components@0.25.2(vue@3.4.0): + /unplugin-vue-components@0.25.2(vue@3.4.7): resolution: {integrity: sha512-OVmLFqILH6w+eM8fyt/d/eoJT9A6WO51NZLf1vC5c1FZ4rmq2bbGxTy8WP2Jm7xwFdukaIdv819+UI7RClPyCA==} engines: {node: '>=14'} peerDependencies: @@ -7719,7 +7714,7 @@ packages: minimatch: 9.0.3 resolve: 1.22.5 unplugin: 1.4.0 - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) transitivePeerDependencies: - rollup - supports-color @@ -7810,13 +7805,13 @@ packages: engines: {node: '>= 0.8'} dev: true - /vdirs@0.1.8(vue@3.4.0): + /vdirs@0.1.8(vue@3.4.7): resolution: {integrity: sha512-H9V1zGRLQZg9b+GdMk8MXDN2Lva0zx72MPahDKc30v+DtwKjfyOSXWRIX4t2mhDubM1H09gPhWeth/BJWPHGUw==} peerDependencies: vue: ^3.0.11 dependencies: evtd: 0.2.4 - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) dev: false /vite-plugin-cdn2@0.15.2: @@ -7999,16 +7994,16 @@ packages: fsevents: 2.3.3 dev: true - /vooks@0.2.12(vue@3.4.0): + /vooks@0.2.12(vue@3.4.7): resolution: {integrity: sha512-iox0I3RZzxtKlcgYaStQYKEzWWGAduMmq+jS7OrNdQo1FgGfPMubGL3uGHOU9n97NIvfFDBGnpSvkWyb/NSn/Q==} peerDependencies: vue: ^3.0.0 dependencies: evtd: 0.2.4 - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) dev: false - /vue-demi@0.14.6(vue@3.4.0): + /vue-demi@0.14.6(vue@3.4.7): resolution: {integrity: sha512-8QA7wrYSHKaYgUxDA5ZC24w+eHm3sYCbp0EzcDwKqN3p6HqtTCGR/GVsPyZW92unff4UlcSh++lmqDWN3ZIq4w==} engines: {node: '>=12'} hasBin: true @@ -8020,7 +8015,7 @@ packages: '@vue/composition-api': optional: true dependencies: - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) /vue-eslint-parser@9.3.1(eslint@8.52.0): resolution: {integrity: sha512-Clr85iD2XFZ3lJ52/ppmUDG/spxQu6+MAeHXjjyI4I1NUYZ9xmenQp4N0oaHJhrA8OOxltCVxMRfANGa70vU0g==} @@ -8040,7 +8035,7 @@ packages: - supports-color dev: true - /vue-hooks-plus@1.8.5(vue@3.4.0): + /vue-hooks-plus@1.8.5(vue@3.4.7): resolution: {integrity: sha512-cIatTWz6QQcoSCDn7jadQ3zMr799FmNiHyb59yUvR7Ws5KDJ/KdIMHHx/b0XDKzbGhQ61kcJ78zJKAKhOV0pWw==} peerDependencies: vue: ^3.2.25 @@ -8052,26 +8047,26 @@ packages: qs: 6.11.2 query-string: 7.1.3 screenfull: 5.2.0 - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) - /vue-i18n@9.8.0(vue@3.4.0): - resolution: {integrity: sha512-Izho+6PYjejsTq2mzjcRdBZ5VLRQoSuuexvR8029h5CpN03FYqiqBrShMyf2I1DKkN6kw/xmujcbvC+4QybpsQ==} + /vue-i18n@9.9.0(vue@3.4.7): + resolution: {integrity: sha512-xQ5SxszUAqK5n84N+uUyHH/PiQl9xZ24FOxyAaNonmOQgXeN+rD9z/6DStOpOxNFQn4Cgcquot05gZc+CdOujA==} engines: {node: '>= 16'} peerDependencies: vue: ^3.0.0 dependencies: - '@intlify/core-base': 9.8.0 - '@intlify/shared': 9.8.0 + '@intlify/core-base': 9.9.0 + '@intlify/shared': 9.9.0 '@vue/devtools-api': 6.5.1 - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) - /vue-router@4.2.5(vue@3.4.0): + /vue-router@4.2.5(vue@3.4.7): resolution: {integrity: sha512-DIUpKcyg4+PTQKfFPX88UWhlagBEBEfJ5A8XDXRJLUnZOvcpMF8o/dnL90vpVkGaPbjvXazV/rC1qBKrZlFugw==} peerDependencies: vue: ^3.2.0 dependencies: '@vue/devtools-api': 6.5.1 - vue: 3.4.0(typescript@5.2.2) + vue: 3.4.7(typescript@5.2.2) dev: false /vue-template-compiler@2.7.14: @@ -8093,34 +8088,34 @@ packages: typescript: 5.2.2 dev: true - /vue@3.4.0(typescript@5.2.2): - resolution: {integrity: sha512-iTE9Ve/7DO/H39+gXHrNkRdnh1jDwPe/fap4brbPKkp1APMkS03OiZ+UY0dwpqtRX0iPWQTkh8Fu3hKgLtaxfA==} + /vue@3.4.7(typescript@5.2.2): + resolution: {integrity: sha512-4urmkWpudekq0CPNMO7p6mBGa9qmTXwJMO2r6CT4EzIJVG7WoSReiysiNb7OSi/WI113oX0Srn9Rz1k/DCXKFQ==} peerDependencies: typescript: '*' peerDependenciesMeta: typescript: optional: true dependencies: - '@vue/compiler-dom': 3.4.0 - '@vue/compiler-sfc': 3.4.0 - '@vue/runtime-dom': 3.4.0 - '@vue/server-renderer': 3.4.0(vue@3.4.0) - '@vue/shared': 3.4.0 + '@vue/compiler-dom': 3.4.7 + '@vue/compiler-sfc': 3.4.7 + '@vue/runtime-dom': 3.4.7 + '@vue/server-renderer': 3.4.7(vue@3.4.7) + '@vue/shared': 3.4.7 typescript: 5.2.2 - /vueuc@0.4.54(vue@3.4.0): - resolution: {integrity: sha512-2LED7h1BSnCRPBI6AlSIf+1Yte1shN+Vb2gpspO5wHI7zWzbcq4bAu2f9nFh5yXIUKdzqmLvzRsOXDl4TrDyCw==} + /vueuc@0.4.58(vue@3.4.7): + resolution: {integrity: sha512-Wnj/N8WbPRSxSt+9ji1jtDHPzda5h2OH/0sFBhvdxDRuyCZbjGg3/cKMaKqEoe+dErTexG2R+i6Q8S/Toq1MYg==} peerDependencies: vue: ^3.0.11 dependencies: - '@css-render/vue3-ssr': 0.15.12(vue@3.4.0) + '@css-render/vue3-ssr': 0.15.12(vue@3.4.7) '@juggle/resize-observer': 3.4.0 css-render: 0.15.12 evtd: 0.2.4 seemly: 0.3.8 - vdirs: 0.1.8(vue@3.4.0) - vooks: 0.2.12(vue@3.4.0) - vue: 3.4.0(typescript@5.2.2) + vdirs: 0.1.8(vue@3.4.7) + vooks: 0.2.12(vue@3.4.7) + vue: 3.4.7(typescript@5.2.2) dev: false /webidl-conversions@3.0.1: diff --git a/src/app-components/app/AppAvatar/index.tsx b/src/app-components/app/AppAvatar/index.tsx index 75843752..b977b47f 100644 --- a/src/app-components/app/AppAvatar/index.tsx +++ b/src/app-components/app/AppAvatar/index.tsx @@ -19,10 +19,10 @@ import './index.scss' -import { NAvatar, NSpace } from 'naive-ui' +import { NAvatar, NFlex } from 'naive-ui' -import { avatarProps, spaceProps } from 'naive-ui' -import { APP_CATCH_KEY } from '@/app-config/appConfig' +import { avatarProps, flexProps } from 'naive-ui' +import { APP_CATCH_KEY } from '@/app-config' import { getStorage } from '@/utils' import type { PropType } from 'vue' @@ -33,7 +33,7 @@ const AppAvatar = defineComponent({ name: 'AppAvatar', props: { ...avatarProps, - ...spaceProps, + ...flexProps, cursor: { type: String, default: 'auto', @@ -64,10 +64,9 @@ const AppAvatar = defineComponent({ }, render() { return ( - @@ -80,7 +79,7 @@ const AppAvatar = defineComponent({ size={this.avatarSize} />
{this.signing?.name}
-
+ ) }, }) diff --git a/src/app-components/app/AppLockScreen/components/UnlockScreen/index.tsx b/src/app-components/app/AppLockScreen/components/UnlockScreen/index.tsx index cceb6f7a..67a739ab 100644 --- a/src/app-components/app/AppLockScreen/components/UnlockScreen/index.tsx +++ b/src/app-components/app/AppLockScreen/components/UnlockScreen/index.tsx @@ -11,14 +11,14 @@ /** 解锁界面 */ -import { NInput, NForm, NFormItem, NButton, NSpace } from 'naive-ui' +import { NInput, NForm, NFormItem, NButton, NFlex } from 'naive-ui' import AppAvatar from '@/app-components/app/AppAvatar' import dayjs from 'dayjs' import { useSigningActions, useSettingActions } from '@/store' import { rules, useCondition } from '@/app-components/app/AppLockScreen/shared' import useAppLockScreen from '@/app-components/app/AppLockScreen/appLockVar' -import { useDevice } from '@/hooks/web' +import { useDevice } from '@/hooks' import type { FormInst, InputInst } from 'naive-ui' @@ -137,14 +137,14 @@ export default defineComponent({ }} /> - + 返回登陆 进入系统 - +
diff --git a/src/app-components/app/RayLink/index.tsx b/src/app-components/app/RayLink/index.tsx index 0f7f6015..908e38ec 100644 --- a/src/app-components/app/RayLink/index.tsx +++ b/src/app-components/app/RayLink/index.tsx @@ -1,4 +1,9 @@ -import { NAvatar, NTooltip, NSpace } from 'naive-ui' +/** + * + * 友情链接组件,无实际项目意义 + */ + +import { NAvatar, NTooltip, NFlex } from 'naive-ui' interface AvatarOptions { key: string @@ -7,7 +12,7 @@ interface AvatarOptions { icon: string } -const RayLink = defineComponent({ +export default defineComponent({ name: 'RayLink', setup() { const avatarOptions: AvatarOptions[] = [ @@ -60,7 +65,7 @@ const RayLink = defineComponent({ }, render() { return ( - + {this.avatarOptions.map((curr) => ( {{ @@ -80,16 +85,7 @@ const RayLink = defineComponent({ }} ))} - + ) }, }) - -export default RayLink - -/** - * - * 友链组件 - * - * 这个组件用作初试模板中, 不喜欢自行删除 - */ diff --git a/src/app-components/provider/AppNaiveGlobalProvider/index.tsx b/src/app-components/provider/AppNaiveGlobalProvider/index.tsx index ca14fd54..f7e41203 100644 --- a/src/app-components/provider/AppNaiveGlobalProvider/index.tsx +++ b/src/app-components/provider/AppNaiveGlobalProvider/index.tsx @@ -43,20 +43,29 @@ export default defineComponent({ return naiveLocales(key) }) - const { message, notification, dialog, loadingBar } = createDiscreteApi( - ['message', 'dialog', 'notification', 'loadingBar'], - { - configProviderProps: computed(() => ({ - theme: getAppTheme.value ? darkTheme : null, - })), - notificationProviderProps: {}, - }, - ) + /** + * + * 使用 createDiscreteApi 脱离上下文 api 注入一些常用的组件 + * 通过 window.$message、window.$notification、window.$dialog、window.$loadingBar 访问 + * 但是,使用该组件注册后,使用 window.$notification 组件时不能更改 placement 位置(只能默认右上角弹出) + * + * 改为函数包裹,避免 `slot default invoked outside of render` 警告 + */ + const discreteApi = () => { + const { message, notification, dialog, loadingBar } = createDiscreteApi( + ['message', 'dialog', 'notification', 'loadingBar'], + { + configProviderProps: computed(() => ({ + theme: getAppTheme.value ? darkTheme : null, + })), + }, + ) - window.$dialog = dialog // 注入 `dialog` - window.$message = message // 注入 `message` - window.$loadingBar = loadingBar // 注入 `loadingBar` - window.$notification = notification // 注入 `notification` + window.$dialog = dialog // 注入 `dialog` + window.$message = message // 注入 `message` + window.$loadingBar = loadingBar // 注入 `loadingBar` + window.$notification = notification // 注入 `notification` + } expose() @@ -64,22 +73,30 @@ export default defineComponent({ getPrimaryColorOverride, localePackage, getAppTheme, + discreteApi, } }, render() { + const { + $slots: { default: slotDefault }, + discreteApi, + } = this + const { getPrimaryColorOverride, getAppTheme, localePackage } = this + return ( - {this.$slots.default?.()} + {slotDefault?.()} + {discreteApi()} diff --git a/src/app-config/appConfig.ts b/src/app-config/appConfig.ts index 8411abaa..7074a594 100644 --- a/src/app-config/appConfig.ts +++ b/src/app-config/appConfig.ts @@ -86,9 +86,11 @@ export const APP_MENU_CONFIG: Readonly = { * - signing: 登陆信息缓存 key * - localeLanguage: 国际化默认缓存 key * - token: token key + * - appMenuKey: 菜单缓存 key */ export const APP_CATCH_KEY = { signing: 'signing', localeLanguage: 'localeLanguage', token: 'token', + appMenuKey: 'menuKey', } as const diff --git a/src/app-config/index.ts b/src/app-config/index.ts new file mode 100644 index 00000000..33f42cdf --- /dev/null +++ b/src/app-config/index.ts @@ -0,0 +1,6 @@ +export * from './appConfig' +export * from './designConfig' +export * from './localConfig' +export * from './regexConfig' +export * from './requestConfig' +export * from './routerConfig' diff --git a/src/axios/inject/request/provider.ts b/src/axios/inject/request/provider.ts index 11f37547..1462795b 100644 --- a/src/axios/inject/request/provider.ts +++ b/src/axios/inject/request/provider.ts @@ -22,7 +22,7 @@ import { axiosCanceler } from '@/axios/helper/interceptor' import { appendRequestHeaders } from '@/axios/helper/axiosCopilot' -import { APP_CATCH_KEY } from '@/app-config/appConfig' +import { APP_CATCH_KEY } from '@/app-config' import { getStorage } from '@/utils' import type { diff --git a/src/axios/instance.ts b/src/axios/instance.ts index 54695935..795a6f31 100644 --- a/src/axios/instance.ts +++ b/src/axios/instance.ts @@ -17,7 +17,7 @@ */ import axios from 'axios' -import { AXIOS_CONFIG } from '@/app-config/requestConfig' +import { AXIOS_CONFIG } from '@/app-config' import { useAxiosInterceptor } from '@/axios/helper/interceptor' import { setupResponseInterceptor, diff --git a/src/components/RChart/src/index.tsx b/src/components/RChart/src/index.tsx index 99ee4044..5499c7f0 100644 --- a/src/components/RChart/src/index.tsx +++ b/src/components/RChart/src/index.tsx @@ -43,7 +43,7 @@ import props from './props' import { throttle } from 'lodash-es' import { completeSize, downloadBase64File, call, renderNode } from '@/utils' import { setupChartTheme } from './helper' -import { APP_THEME } from '@/app-config/designConfig' +import { APP_THEME } from '@/app-config' import { useResizeObserver } from '@vueuse/core' import { RMoreDropdown } from '@/components' import { useSettingGetters } from '@/store' diff --git a/src/components/RChart/src/type.ts b/src/components/RChart/src/type.ts index 682454b9..ad3117c1 100644 --- a/src/components/RChart/src/type.ts +++ b/src/components/RChart/src/type.ts @@ -75,6 +75,13 @@ export interface RChartInst { * @default () => void */ render: () => void + /** + * + * 判断图表是否已经卸载 + * + * @returns 图表是否已经卸载 + */ + isDispose: () => boolean } export type EChartsExtensionInstallRegisters = typeof CanvasRenderer diff --git a/src/components/RCollapseGrid/src/index.tsx b/src/components/RCollapseGrid/src/index.tsx index 9c4babe1..6b3f4244 100644 --- a/src/components/RCollapseGrid/src/index.tsx +++ b/src/components/RCollapseGrid/src/index.tsx @@ -21,7 +21,7 @@ import './index.scss' -import { NCard, NGrid, NGridItem, NSpace } from 'naive-ui' +import { NCard, NGrid, NGridItem, NFlex } from 'naive-ui' import { RIcon } from '@/components' import { call } from '@/utils' @@ -85,10 +85,10 @@ export default defineComponent({ > {this.$slots.default?.()} - + {this.$slots.action?.()} {this.CollapseIcon()} - + ), diff --git a/src/components/RTable/src/Table.tsx b/src/components/RTable/src/Table.tsx index 9ab3366a..6f947985 100644 --- a/src/components/RTable/src/Table.tsx +++ b/src/components/RTable/src/Table.tsx @@ -11,7 +11,7 @@ import './index.scss' -import { NCard, NDataTable, NDropdown, NSpace } from 'naive-ui' +import { NCard, NDataTable, NDropdown, NFlex } from 'naive-ui' import Size from './components/Size' import Fullscreen from './components/Fullscreen' import C from './components/C' @@ -238,10 +238,10 @@ export default defineComponent({ defaultElement:
, }), 'header-extra': () => ( - + {/* eslint-disable @typescript-eslint/no-explicit-any */} {tool(this.$props as any)} - + ), footer: () => this.$slots.tableFooter?.(), action: () => this.$slots.tableAction?.(), diff --git a/src/components/RTable/src/components/C.tsx b/src/components/RTable/src/components/C.tsx index c5be73f2..a2962afe 100644 --- a/src/components/RTable/src/components/C.tsx +++ b/src/components/RTable/src/components/C.tsx @@ -18,7 +18,7 @@ * 2. 大量数据的时候,可能会出现性能问题 */ -import { NPopover, NSpace, NTree } from 'naive-ui' +import { NPopover, NFlex, NTree } from 'naive-ui' import { RIcon } from '@/components' import config from '../config' @@ -65,6 +65,13 @@ const RowIconRender = ({ ) } +/** + * 查找节点的兄弟节点和索引 + * + * @param node 要查找的节点 + * @param nodes 节点列表 + * @returns 如果找到节点,则返回包含兄弟节点列表和索引的元组,否则返回 [null, null] + */ const findSiblingsAndIndex = ( node: TreeOption, nodes?: TreeOption[], @@ -122,7 +129,7 @@ export default defineComponent({ return { ...attr, suffix: () => ( - + - + ), } }) as C[] @@ -192,6 +199,7 @@ export default defineComponent({ event(treeDataSource.value) } + // 拖拽节点的处理函数 const treeDrop = ({ node, dragNode, dropPosition }: TreeDropInfo) => { const [dragNodeSiblings, dragNodeIndex] = findSiblingsAndIndex( dragNode, @@ -202,6 +210,7 @@ export default defineComponent({ return } + // 从兄弟节点中移除拖拽节点 dragNodeSiblings.splice(dragNodeIndex, 1) const [nodeSiblings, nodeIndex] = findSiblingsAndIndex( @@ -213,10 +222,12 @@ export default defineComponent({ return } + // 根据拖拽位置将拖拽节点插入到目标节点的前面或后面 dropPosition === 'before' ? nodeSiblings.splice(nodeIndex, 0, dragNode) : nodeSiblings.splice(nodeIndex + 1, 0, dragNode) + // 触发事件,更新树形数据源 event(nodeSiblings as C[]) } diff --git a/src/components/RTransitionComponent/src/index.vue b/src/components/RTransitionComponent/src/index.vue index 9f1c9b30..6fcb71ce 100644 --- a/src/components/RTransitionComponent/src/index.vue +++ b/src/components/RTransitionComponent/src/index.vue @@ -24,7 +24,7 @@