diff --git a/.eslintrc.cjs b/.eslintrc.cjs
index 73a97f64..c711e9dc 100644
--- a/.eslintrc.cjs
+++ b/.eslintrc.cjs
@@ -33,7 +33,6 @@ module.exports = {
defineExpose: 'readonly',
withDefaults: 'readonly',
defineOptions: 'readonly',
- defineModel: 'readonly',
},
rules: {
'no-undefined': ['error'],
diff --git a/CHANGELOG.md b/CHANGELOG.md
index ca0af1ca..9e2e347d 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,5 +1,46 @@
# CHANGE LOG
+## 4.5.0
+
+破坏性更新。
+
+更新 `vue` 版本至 `3.4.0`,请查看相关变更:[Vue 3.4.0](https://github.com/vuejs/core/blob/main/CHANGELOG.md)。该版本破坏性更新了一些东西,例如:
+
+- `JSX` 命名空间默认移除
+- `ReactiveTransform` 移除
+- `v-is` 指令移除
+
+更新 `@vitejs/plugin-vue` 版本至 `5.0.0`,请查看相关变更:[vite-plugin-vue](https://github.com/vitejs/vite-plugin-vue/blob/main/packages/plugin-vue/CHANGELOG.md)。该版本破坏性更新了一些东西,例如:
+
+- 放弃 `ReactivityTransform` 支持
+- 放弃 `node14, 16` 版本支持
+- 放弃 `vite4.x` 版本支持
+- 弃用 `defineModel` 方法
+
+主要是解决 `sameLevel` 问题与核心包 `store/men` 的一些问题。提高了性能,避免了潜在的空引用问题。
+
+然后就是统一 `types` 包的导入导出行为。
+
+## Feats
+
+- 统一 `types` 包下的导出方式,现在统一为 `import type { xxx } from '@/types'` 导入
+- `RQRCode` 组件
+ - 在 `loading` 状态下会模糊显示二维码,并且展示 `loading` 状态
+ - 优化显示 `error` 状态下默认按钮样式
+- 更新 `README.md`, `README-ZH.md` 文档
+- 取消 `changeModelValue` 节流锁
+- 优化 `changeModelValue`, `updateMenuKeyWhenRouteUpdate` 方法,避免潜在的空引用问题
+- 插件相关
+ - 更新 `vue` 版本至 `3.4.0`
+ - 更新 `@vitejs/plugin-vue-jsx` 版本至 `3.1.0`
+- `RModal` 组件相关
+ - 新增 `memoryPosition` 配置项,用于配置是否记忆上一次的位置
+
+## Fixes
+
+- 修复初始化的时候面包屑为空的问题
+- 修复 `sameLevel` 平级模式面包屑追加问题
+
## 4.4.7
## Feats
diff --git a/README-ZH.md b/README-ZH.md
index 5d3051e7..8f8c485f 100644
--- a/README-ZH.md
+++ b/README-ZH.md
@@ -1,6 +1,22 @@
@@ -9,32 +25,40 @@
简体中文 | [English](https://github.com/XiaoDaiGua-Ray/ray-template/blob/main/README.md)
-一个 `免费`、`高效`、`特性完整` 并且基于 vite5.x & ts(x) & pinia & vue3.x 等最新技术的中后台模板。
+一个 `完全免费`、`高效`、`特性完整` 并且基于 vite5.x & ts(x) & pinia & vue3.x 等最新技术的中后台模板。
+## 🌻 简介
+
+`Ray Template`采用前沿前端技术,摒弃繁杂与臃肿,采用模块化设计,解耦数据、方法和视图,专注业务开发。提供丰富配置和丰富的模板 `Hooks`,支持个性化定制,满足你的项目需求。
+
## ✨ 特性
-- **靠爱发电**:几乎包含市面常见的模板特性并且全部免费使用
-- **最新技术栈**:使用 vue3.x/vite5.x/pinia 等前端前沿技术开发
-- **TypeScript**:应用程序级 JavaScript 的语言
-- **主题**:可配置的主题
-- **国际化**:内置完善的国际化方案
-- **Mock 数据**:内置 Mock 数据方案
-- **权限**:内置完善的动态路由权限生成方案
-- **组件**:二次封装了多个常用的组件
-- **Axios 请求**:二次封装 axios 库,支持:取消、防抖、自动重复取消等功能
-- **缓存**:任意深度页面缓存
-- **SVG**:内置 svg icon 解决方案
-- **独立的 Data Methods Views**:解耦管理的数据、方法、视图,放心二次开发
-- **模板专属 hooks**:基于模板特性封装的 hooks 让你更加方便的使用模板一些功能
+- `全新技术栈:`使用 ts(x), vite5.x, vue3.x, pinia 等前端前沿技术开发
+- `主题:`可配置的主题
+- `国际化:`内置完善的国际化方案
+- `权限:`内置完善的动态路由权限生成方案
+- `组件:`二次封装了多个常用的组件
+- `工具包:`常用的工具函数封装
+- `缓存:`任意深度页面缓存
+- `模块化设计:`解耦管理的数据、方法、视图,放心二次开发
+- `配置化:`支持丰富的配置项
+- `代码风格:`内置 prettier, eslint 等代码风格工具
+- `多端适配:`支持 pc, phone, pad
+- `文档:`完善的文档
+- `Mock 数据:`内置 Mock 数据方案
+- `Axios 请求:`二次封装 axios 库,支持:取消、防抖、自动重复取消等功能
+- `SVG:`内置 svg icon 解决方案
+- `Hooks:`基于模板特性封装的 hooks 让你更加方便的使用模板一些功能
+- `TypeScript:`提供完整的类型
-## 🪄 预览地址
+## 👀 预览地址
- [点击预览](https://xiaodaigua-ray.github.io/ray-template/#/)
- [点击预览(加速地址)](https://ray-template.yunkuangao.com/#/)
-## 🦾 文档地址
+## 📌 文档地址
- [文档](https://xiaodaigua-ray.github.io/ray-template-doc/)
- [文档(加速地址)](https://ray-template.yunkuangao.com/ray-template-doc/)
@@ -50,8 +74,9 @@
- [Vue3](https://v3.vuejs.org/) - 熟悉 Vue 基础语法
- [TypeScript](https://www.typescriptlang.org/) - 熟悉 TypeScript 基本语法
- [Es6+](http://es6.ruanyifeng.com/) - 熟悉 es6 基本语法
+- [Vue-Hooks-Plus] - 熟悉 vue-hooks-plus useRequest 方法的基本使用
- [Vue-Router-Next](https://next.router.vuejs.org/) - 熟悉 vue-router4.x 基本使用
-- [Naive-UI](https://www.naiveui.com) - ui 基本使用
+- [Naive-UI](https://www.naiveui.com) - naive ui 基本使用
- [Mock.js](https://github.com/nuysoft/Mock) - mockjs 基本语法
- [Pinia](https://pinia.vuejs.org/zh/introduction.html) - 状态管理器 pinia 使用
- [TSX](https://github.com/vuejs/babel-plugin-jsx/blob/main/packages/babel-plugin-jsx/README-zh_CN.md) - tsx 基本语法
@@ -98,9 +123,9 @@ pnpm preview
pnpm report
```
-### 开发
+### 快速开发
-简介、易上手是该模板的核心思路。所以你可以放心的直接删除 `views/demo` `router/moduels/demo` 下的所有文件,这样就是一个干净的项目了。
+只需要删除 `views/demo`, `router/modules/demo` 下的文件即可得到一个干净的项目模板。
## 🪴 项目活动
diff --git a/README.md b/README.md
index 5681e392..6fde26a0 100644
--- a/README.md
+++ b/README.md
@@ -1,6 +1,22 @@
@@ -9,35 +25,43 @@
English | [简体中文](https://github.com/XiaoDaiGua-Ray/ray-template/blob/main/README-ZH.md)
-A `free`, `efficient`, `complete with features` middle and backend template based on the latest technologies such as vite5.x & ts(x) & pinia & vue3.x.
+A `completely free`, `efficient`, `feature complete` and based on vite5. x & ts(x) & pinia & vue3. x and other latest technology in the background template.
-## ✨ Feature
+## 🌻 Intro
-- **Power by love**: Contains almost all common template features on the market and all are free to use.
-- **Latest Technology Stack**:Developed using front-end cutting-edge technologies such as vue3.x/vite5.x/pinia.
-- **TypeScript**:The language for application-level JavaScript.
-- **App Theme**:Configurable themes.
-- **Globalization**:Built-in complete internationalization solution.
-- **Mock Data**:Built-in Mock data scheme.
-- **Permissions**:Built-in complete dynamic routing permission generation solution.
-- **Components**:Secondary encapsulation of multiple commonly used components.
-- **Axios Request**:Secondary encapsulation of the axios library, supporting functions such as cancellation, anti-shake, automatic repeat cancellation, etc.
-- **Page Cache**:Arbitrarily deep page cache.
-- **SVG**:Built-in svg icon solution.
-- **Standalone Data Methods Views**:Decoupled management of data, methods, and views allows for secondary development with confidence.
-- **Template Specific Hooks** : Hooks based on the template feature package make it easier to use some of the features of the template.
+`Ray Template` uses cutting-edge front-end technology, abandoning complexity and bloat, using modular design, decoupling data, methods and views, focusing on business development. Provide rich configuration and rich template `Hooks`, support personalized customization, to meet your project needs.
-## 🪄 Preview
+## ✨ Features
-- [Click to preview](https://xiaodaigua-ray.github.io/ray-template/#/)
-- [Click to preview(Acceleration address)](https://ray-template.yunkuangao.com/#/)
+- `New technology stack:` using ts(x), vite5. x, vue3. x, pinia and other front-end cutting-edge technology development
+- `Theme:` configurable theme
+- `Internationalization:` built-in perfect internationalization solution
+- `Permissions:` built-in perfect dynamic routing permission generation solution
+- `Components:` secondary encapsulation of multiple common components
+- `Toolkit:` common tool function packaging
+- `Cache:` arbitrary depth page caching
+- `Modular design:` decoupling management data, methods, views, rest assured secondary development
+- `Configurable:` support rich configuration items
+- `Code style:` built-in prettier, eslint and other code style tools
+- `Multi-terminal adaptation:` support pc, phone, pad
+- `Documentation:` complete documentation
+- `Mock data:` built-in Mock data solution
+- `Axios request:` secondary encapsulation of axios library, support: cancel, jitter, automatic repeat cancellation and other functions
+- `SVG:` built-in svg icon solution
+- `Hooks:` based on the template characteristics of the encapsulated hooks to make it easier to use some functions of the template
+- `TypeScript:` provide a complete type
-## 🦾 Document
+## 👀 Preview
-- [Document](https://xiaodaigua-ray.github.io/ray-template-doc/)
-- [Document(Acceleration address)](https://ray-template.yunkuangao.com/ray-template-doc/)
+- [Preview](https://xiaodaigua-ray.github.io/ray-template/#/)
+- [Preview(Acceleration address)](https://ray-template.yunkuangao.com/#/)
+
+## 📌 Documentation
+
+- [Documentation](https://xiaodaigua-ray.github.io/ray-template-doc/)
+- [Documentation(Acceleration address)](https://ray-template.yunkuangao.com/ray-template-doc/)
## 🔋 Change Log
@@ -45,16 +69,17 @@ A `free`, `efficient`, `complete with features` middle and backend template base
## 🪴 Prepare
-- [Node](http://nodejs.org/) and [git](https://git-scm.com/) - Project development environment
-- [Vite](https://vitejs.dev/) - Familiar with vite features
-- [Vue3](https://v3.vuejs.org/) - Familiar with Vue3.x basic syntax
-- [TypeScript](https://www.typescriptlang.org/) - Familiar with TypeScript basic syntax
-- [Es6+](http://es6.ruanyifeng.com/) - Familiar with es6 basic syntax
-- [Vue-Router-Next](https://next.router.vuejs.org/) - Familiar with the basic use of vue-router4.x
-- [Naive-UI](https://www.naiveui.com) - UI basic usage
-- [Mock.js](https://github.com/nuysoft/Mock) - Mockjs basic syntax
-- [Pinia](https://pinia.vuejs.org/zh/introduction.html) - State manager pinia uses
-- [TSX](https://github.com/vuejs/babel-plugin-jsx/blob/main/packages/babel-plugin-jsx/README-zh_CN.md) - TSX basic syntax
+- [Node](http://nodejs.org/) and [git](https://git-scm.com/) - project development environment
+- [Vite](https://vitejs.dev/) - familiar with vite features
+- [Vue3](https://v3.vuejs.org/) - familiar with Vue basic syntax
+- [TypeScript](https://www.typescriptlang.org/) - familiar with TypeScript basic syntax
+- [Es6+](http://es6.ruanyifeng.com/) - familiar with es6 basic syntax
+- [Vue-Hooks-Plus] - familiar with vue-hooks-plus useRequest method basic use
+- [Vue-Router-Next](https://next.router.vuejs.org/) - familiar with vue-router4.x basic use
+- [Naive-UI](https://www.naiveui.com) - naive ui basic use
+- [Mock.js](https://github.com/nuysoft/Mock) - mockjs basic syntax
+- [Pinia](https://pinia.vuejs.org/zh/introduction.html) - state manager pinia usage
+- [TSX](https://github.com/vuejs/babel-plugin-jsx/blob/main/packages/babel-plugin-jsx/README-zh_CN.md) - tsx basic syntax
## 📦 Setup
@@ -80,7 +105,7 @@ pnpm i
pnpm dev
```
-### Project packaging
+### Build project
```sh
pnpm build
@@ -92,23 +117,23 @@ pnpm build
pnpm preview
```
-### Volumetric analysis
+### Report project
```sh
pnpm report
```
-### Develop
+### Development
-Introduction and ease of use are the core ideas of this template. So you can safely delete all files under `views/demo` and `router/moduels/demo`, and you will have a clean project.
+Just delete the files under `views/demo`, `router/modules/demo` to get a clean project template.
## 🪴 Project Activities

-### Contributor
+### Contributors
-Thanks for all their contributions 🐝!
+Thanks for all their contributions 🐝 !
diff --git a/cfg.ts b/cfg.ts
index 35ddd233..5dee5ebb 100644
--- a/cfg.ts
+++ b/cfg.ts
@@ -42,7 +42,7 @@ import { htmlTitlePlugin, mixinCSSPlugin } from './vite-plugins/index'
import { APP_THEME } from './src/app-config/designConfig'
import { PRE_LOADING_CONFIG, SIDE_BAR_LOGO } from './src/app-config/appConfig'
-import type { AppConfigExport } from '@/types/modules/cfg'
+import type { AppConfigExport } from '@/types'
import type { BuildOptions } from 'vite'
const config: AppConfigExport = {
diff --git a/package.json b/package.json
index 04364668..82542875 100755
--- a/package.json
+++ b/package.json
@@ -1,7 +1,7 @@
{
"name": "ray-template",
"private": false,
- "version": "4.4.7",
+ "version": "4.5.0",
"type": "module",
"engines": {
"node": "^18.0.0 || >=20.0.0",
@@ -48,7 +48,7 @@
"pinia": "^2.1.7",
"pinia-plugin-persistedstate": "^3.2.0",
"print-js": "^1.6.0",
- "vue": "^3.3.13",
+ "vue": "^3.4.0",
"vue-hooks-plus": "1.8.5",
"vue-i18n": "^9.8.0",
"vue-router": "^4.2.5",
@@ -67,8 +67,8 @@
"@types/mockjs": "1.0.7",
"@typescript-eslint/eslint-plugin": "^6.5.0",
"@typescript-eslint/parser": "^6.5.0",
- "@vitejs/plugin-vue": "^4.4.1",
- "@vitejs/plugin-vue-jsx": "^3.0.2",
+ "@vitejs/plugin-vue": "^5.0.0",
+ "@vitejs/plugin-vue-jsx": "^3.1.0",
"@vue-hooks-plus/resolvers": "1.2.4",
"@vue/eslint-config-prettier": "^8.0.0",
"@vue/eslint-config-typescript": "^11.0.3",
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 6607bfd0..fbaed425 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.3.13)
+ version: 10.6.1(vue@3.4.0)
awesome-qr:
specifier: 2.1.5-rc.0
version: 2.1.5-rc.0
@@ -43,10 +43,10 @@ dependencies:
version: 1.1.0
naive-ui:
specifier: ^2.36.0
- version: 2.36.0(vue@3.3.13)
+ version: 2.36.0(vue@3.4.0)
pinia:
specifier: ^2.1.7
- version: 2.1.7(typescript@5.2.2)(vue@3.3.13)
+ version: 2.1.7(typescript@5.2.2)(vue@3.4.0)
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.3.13
- version: 3.3.13(typescript@5.2.2)
+ specifier: ^3.4.0
+ version: 3.4.0(typescript@5.2.2)
vue-hooks-plus:
specifier: 1.8.5
- version: 1.8.5(vue@3.3.13)
+ version: 1.8.5(vue@3.4.0)
vue-i18n:
specifier: ^9.8.0
- version: 9.8.0(vue@3.3.13)
+ version: 9.8.0(vue@3.4.0)
vue-router:
specifier: ^4.2.5
- version: 4.2.5(vue@3.3.13)
+ version: 4.2.5(vue@3.4.0)
xlsx:
specifier: ^0.18.5
version: 0.18.5
@@ -107,11 +107,11 @@ devDependencies:
specifier: ^6.5.0
version: 6.5.0(eslint@8.52.0)(typescript@5.2.2)
'@vitejs/plugin-vue':
- specifier: ^4.4.1
- version: 4.4.1(vite@5.0.10)(vue@3.3.13)
+ specifier: ^5.0.0
+ version: 5.0.0(vite@5.0.10)(vue@3.4.0)
'@vitejs/plugin-vue-jsx':
- specifier: ^3.0.2
- version: 3.0.2(vite@5.0.10)(vue@3.3.13)
+ specifier: ^3.1.0
+ version: 3.1.0(vite@5.0.10)(vue@3.4.0)
'@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.3.13)
+ version: 0.25.2(vue@3.4.0)
vite:
specifier: ^5.0.10
version: 5.0.10(@types/node@20.4.7)(sass@1.69.5)
@@ -245,11 +245,24 @@ packages:
chalk: 2.4.2
dev: true
+ /@babel/code-frame@7.23.5:
+ resolution: {integrity: sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==}
+ engines: {node: '>=6.9.0'}
+ dependencies:
+ '@babel/highlight': 7.23.4
+ chalk: 2.4.2
+ dev: true
+
/@babel/compat-data@7.22.9:
resolution: {integrity: sha512-5UamI7xkUcJ3i9qVDS+KFDEK8/7oJ55/sJMB1Ge7IEapr7KfdfV/HErR+koZwOfd+SgtFKOKRhRakdg++DcJpQ==}
engines: {node: '>=6.9.0'}
dev: true
+ /@babel/compat-data@7.23.5:
+ resolution: {integrity: sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==}
+ engines: {node: '>=6.9.0'}
+ dev: true
+
/@babel/core@7.23.2:
resolution: {integrity: sha512-n7s51eWdaWZ3vGT2tD4T7J6eJs3QoBXydv7vkUM06Bf1cbVD2Kc2UrkzhiQwobfV7NwOnQXYL7UBJ5VPU+RGoQ==}
engines: {node: '>=6.9.0'}
@@ -273,6 +286,29 @@ packages:
- supports-color
dev: true
+ /@babel/core@7.23.6:
+ resolution: {integrity: sha512-FxpRyGjrMJXh7X3wGLGhNDCRiwpWEF74sKjTLDJSG5Kyvow3QZaG0Adbqzi9ZrVjTWpsX+2cxWXD71NMg93kdw==}
+ engines: {node: '>=6.9.0'}
+ dependencies:
+ '@ampproject/remapping': 2.2.1
+ '@babel/code-frame': 7.23.5
+ '@babel/generator': 7.23.6
+ '@babel/helper-compilation-targets': 7.23.6
+ '@babel/helper-module-transforms': 7.23.3(@babel/core@7.23.6)
+ '@babel/helpers': 7.23.6
+ '@babel/parser': 7.23.6
+ '@babel/template': 7.22.15
+ '@babel/traverse': 7.23.6
+ '@babel/types': 7.23.6
+ convert-source-map: 2.0.0
+ debug: 4.3.4
+ gensync: 1.0.0-beta.2
+ json5: 2.2.3
+ semver: 6.3.1
+ transitivePeerDependencies:
+ - supports-color
+ dev: true
+
/@babel/eslint-parser@7.22.11(@babel/core@7.23.2)(eslint@8.52.0):
resolution: {integrity: sha512-YjOYZ3j7TjV8OhLW6NCtyg8G04uStATEUe5eiLuCZaXz2VSDQ3dsAtm2D+TuQyAqNMUK2WacGo0/uma9Pein1w==}
engines: {node: ^10.13.0 || ^12.13.0 || >=14.0.0}
@@ -307,6 +343,16 @@ packages:
jsesc: 2.5.2
dev: true
+ /@babel/generator@7.23.6:
+ resolution: {integrity: sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==}
+ engines: {node: '>=6.9.0'}
+ dependencies:
+ '@babel/types': 7.23.6
+ '@jridgewell/gen-mapping': 0.3.3
+ '@jridgewell/trace-mapping': 0.3.20
+ jsesc: 2.5.2
+ dev: true
+
/@babel/helper-annotate-as-pure@7.22.5:
resolution: {integrity: sha512-LvBTxu8bQSQkcyKOU+a1btnNFQ1dMAd0R6PyW3arXes06F6QLWLIrd681bxRPIXlrMGR3XYnW9JyML7dP3qgxg==}
engines: {node: '>=6.9.0'}
@@ -325,19 +371,33 @@ packages:
semver: 6.3.1
dev: true
- /@babel/helper-create-class-features-plugin@7.22.15(@babel/core@7.23.2):
- resolution: {integrity: sha512-jKkwA59IXcvSaiK2UN45kKwSC9o+KuoXsBDvHvU/7BecYIp8GQ2UwrVvFgJASUT+hBnwJx6MhvMCuMzwZZ7jlg==}
+ /@babel/helper-compilation-targets@7.23.6:
+ resolution: {integrity: sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==}
+ engines: {node: '>=6.9.0'}
+ dependencies:
+ '@babel/compat-data': 7.23.5
+ '@babel/helper-validator-option': 7.23.5
+ browserslist: 4.22.2
+ lru-cache: 5.1.1
+ semver: 6.3.1
+ dev: true
+
+ /@babel/helper-create-class-features-plugin@7.23.6(@babel/core@7.23.6):
+ resolution: {integrity: sha512-cBXU1vZni/CpGF29iTu4YRbOZt3Wat6zCoMDxRF1MayiEc4URxOj31tT65HUM0CRpMowA3HCJaAOVOUnMf96cw==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0
+ peerDependenciesMeta:
+ '@babel/core':
+ optional: true
dependencies:
- '@babel/core': 7.23.2
+ '@babel/core': 7.23.6
'@babel/helper-annotate-as-pure': 7.22.5
- '@babel/helper-environment-visitor': 7.22.5
- '@babel/helper-function-name': 7.22.5
- '@babel/helper-member-expression-to-functions': 7.22.15
+ '@babel/helper-environment-visitor': 7.22.20
+ '@babel/helper-function-name': 7.23.0
+ '@babel/helper-member-expression-to-functions': 7.23.0
'@babel/helper-optimise-call-expression': 7.22.5
- '@babel/helper-replace-supers': 7.22.9(@babel/core@7.23.2)
+ '@babel/helper-replace-supers': 7.22.20(@babel/core@7.23.6)
'@babel/helper-skip-transparent-expression-wrappers': 7.22.5
'@babel/helper-split-export-declaration': 7.22.6
semver: 6.3.1
@@ -376,8 +436,8 @@ packages:
'@babel/types': 7.23.3
dev: true
- /@babel/helper-member-expression-to-functions@7.22.15:
- resolution: {integrity: sha512-qLNsZbgrNh0fDQBCPocSL8guki1hcPvltGDv/NxvUoABwFq7GkKSu1nRXeJkVZc+wJvne2E0RKQz+2SQrz6eAA==}
+ /@babel/helper-member-expression-to-functions@7.23.0:
+ resolution: {integrity: sha512-6gfrPwh7OuT6gZyJZvd6WbTfrqAo7vm4xCzAXOusKqq/vWdKXphTpj5klHKNmRUU6/QRGlBsyU9mAIPaWHlqJA==}
engines: {node: '>=6.9.0'}
dependencies:
'@babel/types': 7.23.6
@@ -404,6 +464,20 @@ packages:
'@babel/helper-validator-identifier': 7.22.20
dev: true
+ /@babel/helper-module-transforms@7.23.3(@babel/core@7.23.6):
+ resolution: {integrity: sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0
+ dependencies:
+ '@babel/core': 7.23.6
+ '@babel/helper-environment-visitor': 7.22.20
+ '@babel/helper-module-imports': 7.22.15
+ '@babel/helper-simple-access': 7.22.5
+ '@babel/helper-split-export-declaration': 7.22.6
+ '@babel/helper-validator-identifier': 7.22.20
+ dev: true
+
/@babel/helper-optimise-call-expression@7.22.5:
resolution: {integrity: sha512-HBwaojN0xFRx4yIvpwGqxiV2tUfl7401jlok564NgB9EHS1y6QT17FmKWm4ztqjeVdXLuC4fSvHc5ePpQjoTbw==}
engines: {node: '>=6.9.0'}
@@ -416,15 +490,18 @@ packages:
engines: {node: '>=6.9.0'}
dev: true
- /@babel/helper-replace-supers@7.22.9(@babel/core@7.23.2):
- resolution: {integrity: sha512-LJIKvvpgPOPUThdYqcX6IXRuIcTkcAub0IaDRGCZH0p5GPUp7PhRU9QVgFcDDd51BaPkk77ZjqFwh6DZTAEmGg==}
+ /@babel/helper-replace-supers@7.22.20(@babel/core@7.23.6):
+ resolution: {integrity: sha512-qsW0In3dbwQUbK8kejJ4R7IHVGwHJlV6lpG6UA7a9hSa2YEiAib+N1T2kr6PEeUT+Fl7najmSOS6SmAwCHK6Tw==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0
+ peerDependenciesMeta:
+ '@babel/core':
+ optional: true
dependencies:
- '@babel/core': 7.23.2
- '@babel/helper-environment-visitor': 7.22.5
- '@babel/helper-member-expression-to-functions': 7.22.15
+ '@babel/core': 7.23.6
+ '@babel/helper-environment-visitor': 7.22.20
+ '@babel/helper-member-expression-to-functions': 7.23.0
'@babel/helper-optimise-call-expression': 7.22.5
dev: true
@@ -467,6 +544,11 @@ packages:
engines: {node: '>=6.9.0'}
dev: true
+ /@babel/helper-validator-option@7.23.5:
+ resolution: {integrity: sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==}
+ engines: {node: '>=6.9.0'}
+ dev: true
+
/@babel/helpers@7.23.2:
resolution: {integrity: sha512-lzchcp8SjTSVe/fPmLwtWVBFC7+Tbn8LGHDVfDp9JGxpAY5opSaEFgt8UQvrnECWOTdji2mOWMz1rOhkHscmGQ==}
engines: {node: '>=6.9.0'}
@@ -478,6 +560,17 @@ packages:
- supports-color
dev: true
+ /@babel/helpers@7.23.6:
+ resolution: {integrity: sha512-wCfsbN4nBidDRhpDhvcKlzHWCTlgJYUUdSJfzXb2NuBssDSIjc3xcb+znA7l+zYsFljAcGM0aFkN40cR3lXiGA==}
+ engines: {node: '>=6.9.0'}
+ dependencies:
+ '@babel/template': 7.22.15
+ '@babel/traverse': 7.23.6
+ '@babel/types': 7.23.6
+ transitivePeerDependencies:
+ - supports-color
+ dev: true
+
/@babel/highlight@7.22.13:
resolution: {integrity: sha512-C/BaXcnnvBCmHTpz/VGZ8jgtE2aYlW4hxDhseJAWZb7gqGM/qtCK6iZUb0TyKFf7BOUsBH7Q7fkRsDRhg1XklQ==}
engines: {node: '>=6.9.0'}
@@ -487,6 +580,15 @@ packages:
js-tokens: 4.0.0
dev: true
+ /@babel/highlight@7.23.4:
+ resolution: {integrity: sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==}
+ engines: {node: '>=6.9.0'}
+ dependencies:
+ '@babel/helper-validator-identifier': 7.22.20
+ chalk: 2.4.2
+ js-tokens: 4.0.0
+ dev: true
+
/@babel/parser@7.22.5:
resolution: {integrity: sha512-DFZMC9LJUG9PLOclRC32G63UXwzqS2koQC8dkx+PLdmt1xSePYpbT/NbsrJy8Q/muXz7o/h/d4A7Fuyixm559Q==}
engines: {node: '>=6.0.0'}
@@ -510,37 +612,37 @@ packages:
dependencies:
'@babel/types': 7.23.6
- /@babel/plugin-syntax-jsx@7.22.5(@babel/core@7.23.2):
- resolution: {integrity: sha512-gvyP4hZrgrs/wWMaocvxZ44Hw0b3W8Pe+cMxc8V1ULQ07oh8VNbIRaoD1LRZVTvD+0nieDKjfgKg89sD7rrKrg==}
+ /@babel/plugin-syntax-jsx@7.23.3(@babel/core@7.23.6):
+ resolution: {integrity: sha512-EB2MELswq55OHUoRZLGg/zC7QWUKfNLpE57m/S2yr1uEneIgsTgrSzXP3NXEsMkVn76OlaVVnzN+ugObuYGwhg==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0-0
dependencies:
- '@babel/core': 7.23.2
+ '@babel/core': 7.23.6
'@babel/helper-plugin-utils': 7.22.5
dev: true
- /@babel/plugin-syntax-typescript@7.22.5(@babel/core@7.23.2):
- resolution: {integrity: sha512-1mS2o03i7t1c6VzH6fdQ3OA8tcEIxwG18zIPRp+UY1Ihv6W+XZzBCVxExF9upussPXJ0xE9XRHwMoNs1ep/nRQ==}
+ /@babel/plugin-syntax-typescript@7.23.3(@babel/core@7.23.6):
+ resolution: {integrity: sha512-9EiNjVJOMwCO+43TqoTrgQ8jMwcAd0sWyXi9RPfIsLTj4R2MADDDQXELhffaUx/uJv2AYcxBgPwH6j4TIA4ytQ==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0-0
dependencies:
- '@babel/core': 7.23.2
+ '@babel/core': 7.23.6
'@babel/helper-plugin-utils': 7.22.5
dev: true
- /@babel/plugin-transform-typescript@7.22.15(@babel/core@7.23.2):
- resolution: {integrity: sha512-1uirS0TnijxvQLnlv5wQBwOX3E1wCFX7ITv+9pBV2wKEk4K+M5tqDaoNXnTH8tjEIYHLO98MwiTWO04Ggz4XuA==}
+ /@babel/plugin-transform-typescript@7.23.6(@babel/core@7.23.6):
+ resolution: {integrity: sha512-6cBG5mBvUu4VUD04OHKnYzbuHNP8huDsD3EDqqpIpsswTDoqHCjLoHb6+QgsV1WsT2nipRqCPgxD3LXnEO7XfA==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0-0
dependencies:
- '@babel/core': 7.23.2
+ '@babel/core': 7.23.6
'@babel/helper-annotate-as-pure': 7.22.5
- '@babel/helper-create-class-features-plugin': 7.22.15(@babel/core@7.23.2)
+ '@babel/helper-create-class-features-plugin': 7.23.6(@babel/core@7.23.6)
'@babel/helper-plugin-utils': 7.22.5
- '@babel/plugin-syntax-typescript': 7.22.5(@babel/core@7.23.2)
+ '@babel/plugin-syntax-typescript': 7.23.3(@babel/core@7.23.6)
dev: true
/@babel/runtime@7.23.6:
@@ -613,6 +715,24 @@ packages:
- supports-color
dev: true
+ /@babel/traverse@7.23.6:
+ resolution: {integrity: sha512-czastdK1e8YByZqezMPFiZ8ahwVMh/ESl9vPgvgdB9AmFMGP5jfpFax74AQgl5zj4XHzqeYAg2l8PuUeRS1MgQ==}
+ engines: {node: '>=6.9.0'}
+ dependencies:
+ '@babel/code-frame': 7.23.5
+ '@babel/generator': 7.23.6
+ '@babel/helper-environment-visitor': 7.22.20
+ '@babel/helper-function-name': 7.23.0
+ '@babel/helper-hoist-variables': 7.22.5
+ '@babel/helper-split-export-declaration': 7.22.6
+ '@babel/parser': 7.23.6
+ '@babel/types': 7.23.6
+ debug: 4.3.4
+ globals: 11.12.0
+ transitivePeerDependencies:
+ - supports-color
+ dev: true
+
/@babel/types@7.23.3:
resolution: {integrity: sha512-OZnvoH2l8PK5eUvEcUyCt/sXgr/h+UWpVuBbOljwcrAgUl6lpchoQ++PHGyQy1AtYnVA6CEq3y5xeEI10brpXw==}
engines: {node: '>=6.9.0'}
@@ -813,12 +933,12 @@ packages:
css-render: 0.15.12
dev: false
- /@css-render/vue3-ssr@0.15.12(vue@3.3.13):
+ /@css-render/vue3-ssr@0.15.12(vue@3.4.0):
resolution: {integrity: sha512-AQLGhhaE0F+rwybRCkKUdzBdTEM/5PZBYy+fSYe1T9z9+yxMuV/k7ZRqa4M69X+EI1W8pa4kc9Iq2VjQkZx4rg==}
peerDependencies:
vue: ^3.0.11
dependencies:
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
dev: false
/@emotion/hash@0.8.0:
@@ -1316,7 +1436,7 @@ packages:
magic-string: 0.30.5
mlly: 1.4.1
source-map-js: 1.0.2
- vue-i18n: 9.8.0(vue@3.3.13)
+ vue-i18n: 9.8.0(vue@3.4.0)
yaml-eslint-parser: 1.2.2
dev: true
@@ -1378,7 +1498,7 @@ packages:
picocolors: 1.0.0
source-map-js: 1.0.2
unplugin: 1.4.0
- vue-i18n: 9.8.0(vue@3.3.13)
+ vue-i18n: 9.8.0(vue@3.4.0)
transitivePeerDependencies:
- rollup
- supports-color
@@ -1413,6 +1533,13 @@ packages:
'@jridgewell/sourcemap-codec': 1.4.15
dev: true
+ /@jridgewell/trace-mapping@0.3.20:
+ resolution: {integrity: sha512-R8LcPeWZol2zR8mmH3JeKQ6QRCFb7XgUhV9ZlGhHLGyg4wpPiPZNQOOWhFZhxKw8u//yTbNGI42Bx/3paXEQ+Q==}
+ dependencies:
+ '@jridgewell/resolve-uri': 3.1.1
+ '@jridgewell/sourcemap-codec': 1.4.15
+ dev: true
+
/@jridgewell/trace-mapping@0.3.9:
resolution: {integrity: sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==}
dependencies:
@@ -1990,31 +2117,31 @@ packages:
resolution: {integrity: sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==}
dev: true
- /@vitejs/plugin-vue-jsx@3.0.2(vite@5.0.10)(vue@3.3.13):
- resolution: {integrity: sha512-obF26P2Z4Ogy3cPp07B4VaW6rpiu0ue4OT2Y15UxT5BZZ76haUY9guOsZV3uWh/I6xc+VeiW+ZVabRE82FyzWw==}
+ /@vitejs/plugin-vue-jsx@3.1.0(vite@5.0.10)(vue@3.4.0):
+ resolution: {integrity: sha512-w9M6F3LSEU5kszVb9An2/MmXNxocAnUb3WhRr8bHlimhDrXNt6n6D2nJQR3UXpGlZHh/EsgouOHCsM8V3Ln+WA==}
engines: {node: ^14.18.0 || >=16.0.0}
peerDependencies:
- vite: ^4.0.0
+ vite: ^4.0.0 || ^5.0.0
vue: ^3.0.0
dependencies:
- '@babel/core': 7.23.2
- '@babel/plugin-transform-typescript': 7.22.15(@babel/core@7.23.2)
- '@vue/babel-plugin-jsx': 1.1.5(@babel/core@7.23.2)
+ '@babel/core': 7.23.6
+ '@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.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
transitivePeerDependencies:
- supports-color
dev: true
- /@vitejs/plugin-vue@4.4.1(vite@5.0.10)(vue@3.3.13):
- resolution: {integrity: sha512-HCQG8VDFDM7YDAdcj5QI5DvUi+r6xvo9LgvYdk7LSkUNwdpempdB5horkMSZsbdey9Ywsf5aaU8kEPw9M5kREA==}
- engines: {node: ^14.18.0 || >=16.0.0}
+ /@vitejs/plugin-vue@5.0.0(vite@5.0.10)(vue@3.4.0):
+ resolution: {integrity: sha512-7x5e8X4J1Wi4NxudGjJBd2OFerAi/0nzF80ojCzvfj347WVr0YSn82C8BSsgwSHzlk9Kw5xnZfj0/7RLnNwP5w==}
+ engines: {node: ^18.0.0 || >=20.0.0}
peerDependencies:
- vite: ^4.0.0
+ vite: ^5.0.0
vue: ^3.2.25
dependencies:
vite: 5.0.10(@types/node@20.4.7)(sass@1.69.5)
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
dev: true
/@volar/language-core@1.10.1:
@@ -2042,24 +2169,24 @@ packages:
vue-hooks-plus: ^1.5.2
dependencies:
local-pkg: 0.4.3
- vue-hooks-plus: 1.8.5(vue@3.3.13)
+ vue-hooks-plus: 1.8.5(vue@3.4.0)
dev: true
/@vue/babel-helper-vue-transform-on@1.1.5:
resolution: {integrity: sha512-SgUymFpMoAyWeYWLAY+MkCK3QEROsiUnfaw5zxOVD/M64KQs8D/4oK6Q5omVA2hnvEOE0SCkH2TZxs/jnnUj7w==}
dev: true
- /@vue/babel-plugin-jsx@1.1.5(@babel/core@7.23.2):
+ /@vue/babel-plugin-jsx@1.1.5(@babel/core@7.23.6):
resolution: {integrity: sha512-nKs1/Bg9U1n3qSWnsHhCVQtAzI6aQXqua8j/bZrau8ywT1ilXQbK4FwEJGmU8fV7tcpuFvWmmN7TMmV1OBma1g==}
peerDependencies:
'@babel/core': ^7.0.0-0
dependencies:
- '@babel/core': 7.23.2
+ '@babel/core': 7.23.6
'@babel/helper-module-imports': 7.22.15
- '@babel/plugin-syntax-jsx': 7.22.5(@babel/core@7.23.2)
+ '@babel/plugin-syntax-jsx': 7.23.3(@babel/core@7.23.6)
'@babel/template': 7.22.15
- '@babel/traverse': 7.22.19
- '@babel/types': 7.23.3
+ '@babel/traverse': 7.23.6
+ '@babel/types': 7.23.6
'@vue/babel-helper-vue-transform-on': 1.1.5
camelcase: 6.3.0
html-tags: 3.3.1
@@ -2075,6 +2202,7 @@ packages:
'@vue/shared': 3.3.13
estree-walker: 2.0.2
source-map-js: 1.0.2
+ dev: true
/@vue/compiler-core@3.3.8:
resolution: {integrity: sha512-hN/NNBUECw8SusQvDSqqcVv6gWq8L6iAktUR0UF3vGu2OhzRqcOiAno0FmBJWwxhYEXRlQJT5XnoKsVq1WZx4g==}
@@ -2085,11 +2213,21 @@ packages:
source-map-js: 1.0.2
dev: true
+ /@vue/compiler-core@3.4.0:
+ resolution: {integrity: sha512-cw4S15PkNGTKkP9OFFl4wnQoJJk+HqaYBafgrpDnSukiQGpcYJeRpzmqnCVCIkl6V6Eqsv58E0OAdl6b592vuA==}
+ dependencies:
+ '@babel/parser': 7.23.6
+ '@vue/shared': 3.4.0
+ entities: 4.5.0
+ estree-walker: 2.0.2
+ source-map-js: 1.0.2
+
/@vue/compiler-dom@3.3.13:
resolution: {integrity: sha512-EYRDpbLadGtNL0Gph+HoKiYqXLqZ0xSSpR5Dvnu/Ep7ggaCbjRDIus1MMxTS2Qm0koXED4xSlvTZaTnI8cYAsw==}
dependencies:
'@vue/compiler-core': 3.3.13
'@vue/shared': 3.3.13
+ dev: true
/@vue/compiler-dom@3.3.8:
resolution: {integrity: sha512-+PPtv+p/nWDd0AvJu3w8HS0RIm/C6VGBIRe24b9hSyNWOAPEUosFZ5diwawwP8ip5sJ8n0Pe87TNNNHnvjs0FQ==}
@@ -2098,19 +2236,11 @@ packages:
'@vue/shared': 3.3.8
dev: true
- /@vue/compiler-sfc@3.3.13:
- resolution: {integrity: sha512-DQVmHEy/EKIgggvnGRLx21hSqnr1smUS9Aq8tfxiiot8UR0/pXKHN9k78/qQ7etyQTFj5em5nruODON7dBeumw==}
+ /@vue/compiler-dom@3.4.0:
+ resolution: {integrity: sha512-E957uOhpoE48YjZGWeAoLmNYd3UeU4oIP8kJi8Rcsb9l2tV8Z48Jn07Zgq1aW0v3vuhlmydEKkKKbhLpADHXEA==}
dependencies:
- '@babel/parser': 7.23.6
- '@vue/compiler-core': 3.3.13
- '@vue/compiler-dom': 3.3.13
- '@vue/compiler-ssr': 3.3.13
- '@vue/reactivity-transform': 3.3.13
- '@vue/shared': 3.3.13
- estree-walker: 2.0.2
- magic-string: 0.30.5
- postcss: 8.4.32
- source-map-js: 1.0.2
+ '@vue/compiler-core': 3.4.0
+ '@vue/shared': 3.4.0
/@vue/compiler-sfc@3.3.8:
resolution: {integrity: sha512-WMzbUrlTjfYF8joyT84HfwwXo+8WPALuPxhy+BZ6R4Aafls+jDBnSz8PDz60uFhuqFbl3HxRfxvDzrUf3THwpA==}
@@ -2127,11 +2257,18 @@ packages:
source-map-js: 1.0.2
dev: true
- /@vue/compiler-ssr@3.3.13:
- resolution: {integrity: sha512-d/P3bCeUGmkJNS1QUZSAvoCIW4fkOKK3l2deE7zrp0ypJEy+En2AcypIkqvcFQOcw3F0zt2VfMvNsA9JmExTaw==}
+ /@vue/compiler-sfc@3.4.0:
+ resolution: {integrity: sha512-PWE0mE2yW7bJS7PmaCrVDEG6KPaDJo0pb4AKnCxJ5lRRDO4IwL/fswBGhCpov+v/c+N/e+hQHpXNwvqU9BtUXg==}
dependencies:
- '@vue/compiler-dom': 3.3.13
- '@vue/shared': 3.3.13
+ '@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
+ estree-walker: 2.0.2
+ magic-string: 0.30.5
+ postcss: 8.4.32
+ source-map-js: 1.0.2
/@vue/compiler-ssr@3.3.8:
resolution: {integrity: sha512-hXCqQL/15kMVDBuoBYpUnSYT8doDNwsjvm3jTefnXr+ytn294ySnT8NlsFHmTgKNjwpuFy7XVV8yTeLtNl/P6w==}
@@ -2140,6 +2277,12 @@ packages:
'@vue/shared': 3.3.8
dev: true
+ /@vue/compiler-ssr@3.4.0:
+ resolution: {integrity: sha512-+oXKy105g9DIYQKDi3Gwung0xqQX5gJHr0GR+Vf7yK/WkNDM6q61ummcKmKAB85EIst8y3vj2PA9z9YU5Oc4DQ==}
+ dependencies:
+ '@vue/compiler-dom': 3.4.0
+ '@vue/shared': 3.4.0
+
/@vue/devtools-api@6.5.1:
resolution: {integrity: sha512-+KpckaAQyfbvshdDW5xQylLni1asvNSGme1JFs8I1+/H5pHEhqUKMEQD/qn3Nx5+/nycBq11qAEi8lk+LXI2dA==}
@@ -2197,15 +2340,6 @@ packages:
vue-template-compiler: 2.7.14
dev: true
- /@vue/reactivity-transform@3.3.13:
- resolution: {integrity: sha512-oWnydGH0bBauhXvh5KXUy61xr9gKaMbtsMHk40IK9M4gMuKPJ342tKFarY0eQ6jef8906m35q37wwA8DMZOm5Q==}
- dependencies:
- '@babel/parser': 7.23.6
- '@vue/compiler-core': 3.3.13
- '@vue/shared': 3.3.13
- estree-walker: 2.0.2
- magic-string: 0.30.5
-
/@vue/reactivity-transform@3.3.8:
resolution: {integrity: sha512-49CvBzmZNtcHua0XJ7GdGifM8GOXoUMOX4dD40Y5DxI3R8OUhMlvf2nvgUAcPxaXiV5MQQ1Nwy09ADpnLQUqRw==}
dependencies:
@@ -2216,46 +2350,50 @@ packages:
magic-string: 0.30.5
dev: true
- /@vue/reactivity@3.3.13:
- resolution: {integrity: sha512-fjzCxceMahHhi4AxUBzQqqVhuA21RJ0COaWTbIBl1PruGW1CeY97louZzLi4smpYx+CHfFPPU/CS8NybbGvPKQ==}
- dependencies:
- '@vue/shared': 3.3.13
-
/@vue/reactivity@3.3.8:
resolution: {integrity: sha512-ctLWitmFBu6mtddPyOKpHg8+5ahouoTCRtmAHZAXmolDtuZXfjL2T3OJ6DL6ezBPQB1SmMnpzjiWjCiMYmpIuw==}
dependencies:
'@vue/shared': 3.3.8
dev: true
- /@vue/runtime-core@3.3.13:
- resolution: {integrity: sha512-1TzA5TvGuh2zUwMJgdfvrBABWZ7y8kBwBhm7BXk8rvdx2SsgcGfz2ruv2GzuGZNvL1aKnK8CQMV/jFOrxNQUMA==}
+ /@vue/reactivity@3.4.0:
+ resolution: {integrity: sha512-X6BvQjNcgKKHWPQzlRJjZvIu72Kkn8xJSv6VNptqWh8dToMknD0Hch1l4N7llKgVt6Diq4lMeUnErbZFvuGlAA==}
dependencies:
- '@vue/reactivity': 3.3.13
- '@vue/shared': 3.3.13
+ '@vue/shared': 3.4.0
- /@vue/runtime-dom@3.3.13:
- resolution: {integrity: sha512-JJkpE8R/hJKXqVTgUoODwS5wqKtOsmJPEqmp90PDVGygtJ4C0PtOkcEYXwhiVEmef6xeXcIlrT3Yo5aQ4qkHhQ==}
+ /@vue/runtime-core@3.4.0:
+ resolution: {integrity: sha512-NYrj/JgMMqnSWcIud8lLzDQrBLu+EVEeQ56QE9DYJeKG2eFrnQy8o/h57R9nCprafHs0uImKL3xsdXjHseYVxw==}
dependencies:
- '@vue/runtime-core': 3.3.13
- '@vue/shared': 3.3.13
+ '@vue/reactivity': 3.4.0
+ '@vue/shared': 3.4.0
+
+ /@vue/runtime-dom@3.4.0:
+ resolution: {integrity: sha512-1ZoHEsA5l77qbx2F+SWo/hQdBksPuOmww1t/jznidDG+xMB/iidafEFvo2ZTtZii0JfTIrlDhjshfYUvQC17wQ==}
+ dependencies:
+ '@vue/runtime-core': 3.4.0
+ '@vue/shared': 3.4.0
csstype: 3.1.3
- /@vue/server-renderer@3.3.13(vue@3.3.13):
- resolution: {integrity: sha512-vSnN+nuf6iSqTL3Qgx/9A+BT+0Zf/VJOgF5uMZrKjYPs38GMYyAU1coDyBNHauehXDaP+zl73VhwWv0vBRBHcg==}
+ /@vue/server-renderer@3.4.0(vue@3.4.0):
+ resolution: {integrity: sha512-GuOVCyLDlWPu8nKo5AUxb8B+iB/Ik4I1WwqAlBqf5+y48z6D6rvKshp7KR3cJea+pte1tdTsb0+Ja82KizMZOw==}
peerDependencies:
- vue: 3.3.13
+ vue: 3.4.0
dependencies:
- '@vue/compiler-ssr': 3.3.13
- '@vue/shared': 3.3.13
- vue: 3.3.13(typescript@5.2.2)
+ '@vue/compiler-ssr': 3.4.0
+ '@vue/shared': 3.4.0
+ vue: 3.4.0(typescript@5.2.2)
/@vue/shared@3.3.13:
resolution: {integrity: sha512-/zYUwiHD8j7gKx2argXEMCUXVST6q/21DFU0sTfNX0URJroCe3b1UF6vLJ3lQDfLNIiiRl2ONp7Nh5UVWS6QnA==}
+ dev: true
/@vue/shared@3.3.8:
resolution: {integrity: sha512-8PGwybFwM4x8pcfgqEQFy70NaQxASvOC5DJwLQfpArw1UDfUXrJkdxD3BhVTMS+0Lef/TU7YO0Jvr0jJY8T+mw==}
dev: true
+ /@vue/shared@3.4.0:
+ resolution: {integrity: sha512-Nhh3ed3G1R6HDAWiG6YYFt0Zmq/To6u5vjzwa9TIquGheCXPY6nEdIAO8ZdlwXsWqC2yNLj700FOvShpYt5CEA==}
+
/@vue/typescript@1.8.8(typescript@5.2.2):
resolution: {integrity: sha512-jUnmMB6egu5wl342eaUH236v8tdcEPXXkPgj+eI/F6JwW/lb+yAU6U07ZbQ3MVabZRlupIlPESB7ajgAGixhow==}
dependencies:
@@ -2265,13 +2403,13 @@ packages:
- typescript
dev: true
- /@vueuse/core@10.6.1(vue@3.3.13):
+ /@vueuse/core@10.6.1(vue@3.4.0):
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.3.13)
- vue-demi: 0.14.6(vue@3.3.13)
+ '@vueuse/shared': 10.6.1(vue@3.4.0)
+ vue-demi: 0.14.6(vue@3.4.0)
transitivePeerDependencies:
- '@vue/composition-api'
- vue
@@ -2279,10 +2417,10 @@ packages:
/@vueuse/metadata@10.6.1:
resolution: {integrity: sha512-qhdwPI65Bgcj23e5lpGfQsxcy0bMjCAsUGoXkJ7DsoeDUdasbZ2DBa4dinFCOER3lF4gwUv+UD2AlA11zdzMFw==}
- /@vueuse/shared@10.6.1(vue@3.3.13):
+ /@vueuse/shared@10.6.1(vue@3.4.0):
resolution: {integrity: sha512-TECVDTIedFlL0NUfHWncf3zF9Gc4VfdxfQc8JFwoVZQmxpONhLxFrlm0eHQeidHj4rdTPL3KXJa0TZCk1wnc5Q==}
dependencies:
- vue-demi: 0.14.6(vue@3.3.13)
+ vue-demi: 0.14.6(vue@3.4.0)
transitivePeerDependencies:
- '@vue/composition-api'
- vue
@@ -2785,6 +2923,17 @@ packages:
update-browserslist-db: 1.0.11(browserslist@4.21.10)
dev: true
+ /browserslist@4.22.2:
+ resolution: {integrity: sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A==}
+ engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7}
+ hasBin: true
+ dependencies:
+ caniuse-lite: 1.0.30001571
+ electron-to-chromium: 1.4.616
+ node-releases: 2.0.14
+ update-browserslist-db: 1.0.13(browserslist@4.22.2)
+ dev: true
+
/buffer@6.0.3:
resolution: {integrity: sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==}
dependencies:
@@ -2863,6 +3012,10 @@ packages:
resolution: {integrity: sha512-vlPVrhsCS7XaSh2VvWluIQEzVhefrUQcEsQWSS5A5V+dM07uv1qHeQzAOTGIMy9i3e9bH15+muvI/UHojVgS/Q==}
dev: true
+ /caniuse-lite@1.0.30001571:
+ resolution: {integrity: sha512-tYq/6MoXhdezDLFZuCO/TKboTzuQ/xR5cFdgXPfDtM7/kchBO3b4VWghE/OAi/DV7tTdhmLjZiZBZi1fA/GheQ==}
+ dev: true
+
/canvas@2.11.2:
resolution: {integrity: sha512-ItanGBMrmRV7Py2Z+Xhs7cT+FNt5K0vPL4p9EZ/UX/Mu7hFbkxSjKF2KVtPwX7UYWp7dRKnrTvReflgrItJbdw==}
engines: {node: '>=6'}
@@ -3644,6 +3797,10 @@ packages:
resolution: {integrity: sha512-KGKjcafTpOxda0kqwQ72M0tDmX6RsGhUJTy0Hr7slt0+CgHh9Oex8JdjY9Og68dUkTLUlBOJC0A5W5Mw3QSGCg==}
dev: true
+ /electron-to-chromium@1.4.616:
+ resolution: {integrity: sha512-1n7zWYh8eS0L9Uy+GskE0lkBUNK83cXTVJI0pU3mGprFsbfSdAc15VTFbo+A+Bq4pwstmL30AVcEU3Fo463lNg==}
+ dev: true
+
/emoji-regex@8.0.0:
resolution: {integrity: sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==}
@@ -3667,7 +3824,6 @@ packages:
/entities@4.5.0:
resolution: {integrity: sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==}
engines: {node: '>=0.12'}
- dev: true
/error-ex@1.3.2:
resolution: {integrity: sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==}
@@ -5828,13 +5984,13 @@ packages:
minimatch: 3.1.2
dev: true
- /naive-ui@2.36.0(vue@3.3.13):
+ /naive-ui@2.36.0(vue@3.4.0):
resolution: {integrity: sha512-r1ydtEm1Ryf/aWpbLCf32mQAGK99jd1eXgpkCtIomcBRZeAtusfy6zCtIpCppoCuIKM3BW5DMafhVxilubk/lQ==}
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.3.13)
+ '@css-render/vue3-ssr': 0.15.12(vue@3.4.0)
'@types/katex': 0.16.7
'@types/lodash': 4.14.202
'@types/lodash-es': 4.17.11
@@ -5848,10 +6004,10 @@ packages:
lodash-es: 4.17.21
seemly: 0.3.8
treemate: 0.3.11
- vdirs: 0.1.8(vue@3.3.13)
- vooks: 0.2.12(vue@3.3.13)
- vue: 3.3.13(typescript@5.2.2)
- vueuc: 0.4.54(vue@3.3.13)
+ 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)
dev: false
/nan@2.17.0:
@@ -5913,6 +6069,10 @@ packages:
resolution: {integrity: sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==}
dev: true
+ /node-releases@2.0.14:
+ resolution: {integrity: sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==}
+ dev: true
+
/nopt@5.0.0:
resolution: {integrity: sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==}
engines: {node: '>=6'}
@@ -6234,10 +6394,10 @@ packages:
peerDependencies:
pinia: ^2.0.0
dependencies:
- pinia: 2.1.7(typescript@5.2.2)(vue@3.3.13)
+ pinia: 2.1.7(typescript@5.2.2)(vue@3.4.0)
dev: false
- /pinia@2.1.7(typescript@5.2.2)(vue@3.3.13):
+ /pinia@2.1.7(typescript@5.2.2)(vue@3.4.0):
resolution: {integrity: sha512-+C2AHFtcFqjPih0zpYuvof37SFxMQ7OEG2zV9jRI12i9BOy3YQVAHwdKtyyc8pDcDyIc33WCIsZaCFWU7WWxGQ==}
peerDependencies:
'@vue/composition-api': ^1.4.0
@@ -6251,8 +6411,8 @@ packages:
dependencies:
'@vue/devtools-api': 6.5.1
typescript: 5.2.2
- vue: 3.3.13(typescript@5.2.2)
- vue-demi: 0.14.6(vue@3.3.13)
+ vue: 3.4.0(typescript@5.2.2)
+ vue-demi: 0.14.6(vue@3.4.0)
dev: false
/pkg-types@1.0.3:
@@ -7525,7 +7685,7 @@ packages:
dependencies:
'@antfu/utils': 0.7.6
'@rollup/pluginutils': 5.0.4
- '@vueuse/core': 10.6.1(vue@3.3.13)
+ '@vueuse/core': 10.6.1(vue@3.4.0)
fast-glob: 3.3.1
local-pkg: 0.4.3
magic-string: 0.30.5
@@ -7536,7 +7696,7 @@ packages:
- rollup
dev: true
- /unplugin-vue-components@0.25.2(vue@3.3.13):
+ /unplugin-vue-components@0.25.2(vue@3.4.0):
resolution: {integrity: sha512-OVmLFqILH6w+eM8fyt/d/eoJT9A6WO51NZLf1vC5c1FZ4rmq2bbGxTy8WP2Jm7xwFdukaIdv819+UI7RClPyCA==}
engines: {node: '>=14'}
peerDependencies:
@@ -7559,7 +7719,7 @@ packages:
minimatch: 9.0.3
resolve: 1.22.5
unplugin: 1.4.0
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
transitivePeerDependencies:
- rollup
- supports-color
@@ -7598,6 +7758,17 @@ packages:
picocolors: 1.0.0
dev: true
+ /update-browserslist-db@1.0.13(browserslist@4.22.2):
+ resolution: {integrity: sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==}
+ hasBin: true
+ peerDependencies:
+ browserslist: '>= 4.21.0'
+ dependencies:
+ browserslist: 4.22.2
+ escalade: 3.1.1
+ picocolors: 1.0.0
+ dev: true
+
/uri-js@4.4.1:
resolution: {integrity: sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==}
dependencies:
@@ -7639,13 +7810,13 @@ packages:
engines: {node: '>= 0.8'}
dev: true
- /vdirs@0.1.8(vue@3.3.13):
+ /vdirs@0.1.8(vue@3.4.0):
resolution: {integrity: sha512-H9V1zGRLQZg9b+GdMk8MXDN2Lva0zx72MPahDKc30v+DtwKjfyOSXWRIX4t2mhDubM1H09gPhWeth/BJWPHGUw==}
peerDependencies:
vue: ^3.0.11
dependencies:
evtd: 0.2.4
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
dev: false
/vite-plugin-cdn2@0.15.2:
@@ -7828,16 +7999,16 @@ packages:
fsevents: 2.3.3
dev: true
- /vooks@0.2.12(vue@3.3.13):
+ /vooks@0.2.12(vue@3.4.0):
resolution: {integrity: sha512-iox0I3RZzxtKlcgYaStQYKEzWWGAduMmq+jS7OrNdQo1FgGfPMubGL3uGHOU9n97NIvfFDBGnpSvkWyb/NSn/Q==}
peerDependencies:
vue: ^3.0.0
dependencies:
evtd: 0.2.4
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
dev: false
- /vue-demi@0.14.6(vue@3.3.13):
+ /vue-demi@0.14.6(vue@3.4.0):
resolution: {integrity: sha512-8QA7wrYSHKaYgUxDA5ZC24w+eHm3sYCbp0EzcDwKqN3p6HqtTCGR/GVsPyZW92unff4UlcSh++lmqDWN3ZIq4w==}
engines: {node: '>=12'}
hasBin: true
@@ -7849,7 +8020,7 @@ packages:
'@vue/composition-api':
optional: true
dependencies:
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
/vue-eslint-parser@9.3.1(eslint@8.52.0):
resolution: {integrity: sha512-Clr85iD2XFZ3lJ52/ppmUDG/spxQu6+MAeHXjjyI4I1NUYZ9xmenQp4N0oaHJhrA8OOxltCVxMRfANGa70vU0g==}
@@ -7869,7 +8040,7 @@ packages:
- supports-color
dev: true
- /vue-hooks-plus@1.8.5(vue@3.3.13):
+ /vue-hooks-plus@1.8.5(vue@3.4.0):
resolution: {integrity: sha512-cIatTWz6QQcoSCDn7jadQ3zMr799FmNiHyb59yUvR7Ws5KDJ/KdIMHHx/b0XDKzbGhQ61kcJ78zJKAKhOV0pWw==}
peerDependencies:
vue: ^3.2.25
@@ -7881,9 +8052,9 @@ packages:
qs: 6.11.2
query-string: 7.1.3
screenfull: 5.2.0
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
- /vue-i18n@9.8.0(vue@3.3.13):
+ /vue-i18n@9.8.0(vue@3.4.0):
resolution: {integrity: sha512-Izho+6PYjejsTq2mzjcRdBZ5VLRQoSuuexvR8029h5CpN03FYqiqBrShMyf2I1DKkN6kw/xmujcbvC+4QybpsQ==}
engines: {node: '>= 16'}
peerDependencies:
@@ -7892,15 +8063,15 @@ packages:
'@intlify/core-base': 9.8.0
'@intlify/shared': 9.8.0
'@vue/devtools-api': 6.5.1
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
- /vue-router@4.2.5(vue@3.3.13):
+ /vue-router@4.2.5(vue@3.4.0):
resolution: {integrity: sha512-DIUpKcyg4+PTQKfFPX88UWhlagBEBEfJ5A8XDXRJLUnZOvcpMF8o/dnL90vpVkGaPbjvXazV/rC1qBKrZlFugw==}
peerDependencies:
vue: ^3.2.0
dependencies:
'@vue/devtools-api': 6.5.1
- vue: 3.3.13(typescript@5.2.2)
+ vue: 3.4.0(typescript@5.2.2)
dev: false
/vue-template-compiler@2.7.14:
@@ -7922,34 +8093,34 @@ packages:
typescript: 5.2.2
dev: true
- /vue@3.3.13(typescript@5.2.2):
- resolution: {integrity: sha512-LDnUpQvDgsfc0u/YgtAgTMXJlJQqjkxW1PVcOnJA5cshPleULDjHi7U45pl2VJYazSSvLH8UKcid/kzH8I0a0Q==}
+ /vue@3.4.0(typescript@5.2.2):
+ resolution: {integrity: sha512-iTE9Ve/7DO/H39+gXHrNkRdnh1jDwPe/fap4brbPKkp1APMkS03OiZ+UY0dwpqtRX0iPWQTkh8Fu3hKgLtaxfA==}
peerDependencies:
typescript: '*'
peerDependenciesMeta:
typescript:
optional: true
dependencies:
- '@vue/compiler-dom': 3.3.13
- '@vue/compiler-sfc': 3.3.13
- '@vue/runtime-dom': 3.3.13
- '@vue/server-renderer': 3.3.13(vue@3.3.13)
- '@vue/shared': 3.3.13
+ '@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
typescript: 5.2.2
- /vueuc@0.4.54(vue@3.3.13):
+ /vueuc@0.4.54(vue@3.4.0):
resolution: {integrity: sha512-2LED7h1BSnCRPBI6AlSIf+1Yte1shN+Vb2gpspO5wHI7zWzbcq4bAu2f9nFh5yXIUKdzqmLvzRsOXDl4TrDyCw==}
peerDependencies:
vue: ^3.0.11
dependencies:
- '@css-render/vue3-ssr': 0.15.12(vue@3.3.13)
+ '@css-render/vue3-ssr': 0.15.12(vue@3.4.0)
'@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.3.13)
- vooks: 0.2.12(vue@3.3.13)
- vue: 3.3.13(typescript@5.2.2)
+ vdirs: 0.1.8(vue@3.4.0)
+ vooks: 0.2.12(vue@3.4.0)
+ vue: 3.4.0(typescript@5.2.2)
dev: false
/webidl-conversions@3.0.1:
diff --git a/src/api/demo/mock/person.ts b/src/api/demo/mock/person.ts
index d8767b63..2ac2a6cc 100644
--- a/src/api/demo/mock/person.ts
+++ b/src/api/demo/mock/person.ts
@@ -1,6 +1,6 @@
import { request } from '@/axios'
-import type { BasicResponse, PaginationResponse } from '@/types/modules/axios'
+import type { PaginationResponse } from '@/types'
export interface MockListParams {
page: number
diff --git a/src/api/demo/test.ts b/src/api/demo/test.ts
index 0124197a..1b611ad0 100644
--- a/src/api/demo/test.ts
+++ b/src/api/demo/test.ts
@@ -21,7 +21,7 @@
import { request } from '@/axios'
-import type { BasicResponse } from '@/types/modules/axios'
+import type { BasicResponse } from '@/types'
interface AxiosTestResponse extends UnknownObjectKey {
data: UnknownObjectKey[]
diff --git a/src/app-config/appConfig.ts b/src/app-config/appConfig.ts
index ce7fc51c..8411abaa 100644
--- a/src/app-config/appConfig.ts
+++ b/src/app-config/appConfig.ts
@@ -11,8 +11,8 @@
/** 系统配置 */
-import type { LayoutSideBarLogo, PreloadingConfig } from '@/types/modules/cfg'
-import type { AppMenuConfig, AppKeepAlive } from '@/types/modules/appConfig'
+import type { LayoutSideBarLogo, PreloadingConfig } from '@/types'
+import type { AppMenuConfig, AppKeepAlive } from '@/types'
/**
*
diff --git a/src/app-config/designConfig.ts b/src/app-config/designConfig.ts
index 845ed7b2..45dd4447 100644
--- a/src/app-config/designConfig.ts
+++ b/src/app-config/designConfig.ts
@@ -11,7 +11,7 @@
/** 系统颜色风格配置入口 */
-import type { AppTheme } from '@/types/modules/cfg'
+import type { AppTheme } from '@/types'
export const APP_THEME: AppTheme = {
/**
diff --git a/src/app-config/localConfig.ts b/src/app-config/localConfig.ts
index 79fa9415..9834f3ef 100644
--- a/src/app-config/localConfig.ts
+++ b/src/app-config/localConfig.ts
@@ -11,12 +11,8 @@
/** 国际化相关配置 */
-import type {
- TemplateLocale,
- LocalOptions,
- DayjsLocalMap,
-} from '@/types/modules/appConfig'
-import type { ValueOf } from '@/types/modules/helper'
+import type { TemplateLocale, LocalOptions, DayjsLocalMap } from '@/types'
+import type { ValueOf } from '@/types'
/**
*
diff --git a/src/app-config/requestConfig.ts b/src/app-config/requestConfig.ts
index 7e9e1fb5..c8bc8e31 100644
--- a/src/app-config/requestConfig.ts
+++ b/src/app-config/requestConfig.ts
@@ -9,7 +9,7 @@
* @remark 今天也是元气满满撸代码的一天
*/
-import type { AxiosConfig } from '@/types/modules/appConfig'
+import type { AxiosConfig } from '@/types'
/** axios 相关配置 */
export const AXIOS_CONFIG: AxiosConfig = {
diff --git a/src/axios/helper/interceptor.ts b/src/axios/helper/interceptor.ts
index 2b9e0f17..9f0588b2 100644
--- a/src/axios/helper/interceptor.ts
+++ b/src/axios/helper/interceptor.ts
@@ -32,7 +32,7 @@ import type {
AxiosFetchInstance,
AxiosFetchError,
} from '@/axios/type'
-import type { AnyFC } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
/** 当前请求的实例 */
const axiosFetchInstance: AxiosFetchInstance = {
diff --git a/src/axios/inject/request/provider.ts b/src/axios/inject/request/provider.ts
index 9decae3a..11f37547 100644
--- a/src/axios/inject/request/provider.ts
+++ b/src/axios/inject/request/provider.ts
@@ -30,7 +30,7 @@ import type {
BeforeFetchFunction,
FetchErrorFunction,
} from '@/axios/type'
-import type { Recordable } from '@/types/modules/helper'
+import type { Recordable } from '@/types'
/**
*
diff --git a/src/axios/inject/response/provider.ts b/src/axios/inject/response/provider.ts
index 3fbcb5e1..137fb587 100644
--- a/src/axios/inject/response/provider.ts
+++ b/src/axios/inject/response/provider.ts
@@ -27,7 +27,7 @@ import type {
BeforeFetchFunction,
FetchErrorFunction,
} from '@/axios/type'
-import type { Recordable } from '@/types/modules/helper'
+import type { Recordable } from '@/types'
/**
*
diff --git a/src/axios/type.ts b/src/axios/type.ts
index 191c486a..4dcdb019 100644
--- a/src/axios/type.ts
+++ b/src/axios/type.ts
@@ -7,7 +7,7 @@ import type {
Axios,
AxiosResponse,
} from 'axios'
-import type { AnyFC } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
export type AxiosHeaderValue =
| AxiosHeaders
diff --git a/src/components/RChart/src/index.tsx b/src/components/RChart/src/index.tsx
index 30b06bf4..b4688d60 100644
--- a/src/components/RChart/src/index.tsx
+++ b/src/components/RChart/src/index.tsx
@@ -49,7 +49,7 @@ import { RMoreDropdown } from '@/components'
import { useSettingGetters } from '@/store'
import type { WatchStopHandle } from 'vue'
-import type { AnyFC } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
import type { DebouncedFunc } from 'lodash-es'
import type { UseResizeObserverReturn } from '@vueuse/core'
import type { ECharts, EChartsCoreOption } from 'echarts/core'
@@ -124,9 +124,7 @@ export default defineComponent({
try {
echarts.use(props.use?.filter(Boolean))
} catch (e) {
- console.error(
- 'register chart Core error: wrong property and method passed in extend attribute',
- )
+ console.error('RChart register error: ', e)
}
}
diff --git a/src/components/RChart/src/props.ts b/src/components/RChart/src/props.ts
index a7535180..67155ad4 100644
--- a/src/components/RChart/src/props.ts
+++ b/src/components/RChart/src/props.ts
@@ -1,6 +1,6 @@
import type * as echarts from 'echarts/core' // `echarts` 核心模块
import type { PropType, VNode } from 'vue'
-import type { MaybeArray } from '@/types/modules/utils'
+import type { MaybeArray } from '@/types'
import type {
LoadingOptions,
AutoResize,
diff --git a/src/components/RCollapseGrid/src/props.ts b/src/components/RCollapseGrid/src/props.ts
index c9e97dda..aa3202ef 100644
--- a/src/components/RCollapseGrid/src/props.ts
+++ b/src/components/RCollapseGrid/src/props.ts
@@ -2,7 +2,7 @@ import { gridProps } from 'naive-ui'
import type { PropType } from 'vue'
import type { CollapseToggleText } from './type'
-import type { AnyFC, MaybeArray } from '@/types/modules/utils'
+import type { AnyFC, MaybeArray } from '@/types'
const props = {
open: {
diff --git a/src/components/RIcon/src/props.ts b/src/components/RIcon/src/props.ts
index bce58a2e..f071751c 100644
--- a/src/components/RIcon/src/props.ts
+++ b/src/components/RIcon/src/props.ts
@@ -10,7 +10,7 @@
*/
import type { PropType } from 'vue'
-import type { MaybeArray } from '@/types/modules/utils'
+import type { MaybeArray } from '@/types'
const props = {
color: {
diff --git a/src/components/RIframe/src/props.ts b/src/components/RIframe/src/props.ts
index d5b0d5d9..9f37c49c 100644
--- a/src/components/RIframe/src/props.ts
+++ b/src/components/RIframe/src/props.ts
@@ -10,7 +10,7 @@
*/
import type { PropType } from 'vue'
-import type { MaybeArray } from '@/types/modules/utils'
+import type { MaybeArray } from '@/types'
import type { SpinProps } from 'naive-ui'
const props = {
diff --git a/src/components/RModal/src/Modal.tsx b/src/components/RModal/src/Modal.tsx
index ccec2433..35067d81 100644
--- a/src/components/RModal/src/Modal.tsx
+++ b/src/components/RModal/src/Modal.tsx
@@ -32,6 +32,11 @@ export default defineComponent({
}))
const uuidEl = uuid()
let intractable: null | ReturnType
+ // 记录拖拽的位置
+ const position = {
+ x: 0,
+ y: 0,
+ }
/**
*
@@ -44,7 +49,16 @@ export default defineComponent({
const target = document.getElementById(uuidEl)
if (target) {
- setupDraggable(target, props.preset).then((res) => {
+ setupDraggable(target, props.preset, {
+ scheduler: (event) => {
+ const target = event.target
+
+ position.x += event.dx
+ position.y += event.dy
+
+ target.style.transform = `translate(${position.x}px, ${position.y}px)`
+ },
+ }).then((res) => {
intractable = res
})
}
@@ -60,6 +74,12 @@ export default defineComponent({
) {
nextTick(() => {
setupInteract()
+
+ const target = document.getElementById(uuidEl)
+
+ if (props.memoryPosition && target) {
+ target.style.transform = `translate(${position.x}px, ${position.y}px)`
+ }
})
} else {
intractable?.unset()
diff --git a/src/components/RModal/src/props.ts b/src/components/RModal/src/props.ts
index 0e922828..1e63b2d7 100644
--- a/src/components/RModal/src/props.ts
+++ b/src/components/RModal/src/props.ts
@@ -13,6 +13,16 @@ import { modalProps } from 'naive-ui'
const props = {
...modalProps,
+ memoryPosition: {
+ /**
+ *
+ * 是否记住上一次的位置
+ *
+ * @default true
+ */
+ type: Boolean,
+ default: true,
+ },
/**
*
* 是否全屏
diff --git a/src/components/RModal/src/utils.ts b/src/components/RModal/src/utils.ts
index 9fc51871..af85d9ee 100644
--- a/src/components/RModal/src/utils.ts
+++ b/src/components/RModal/src/utils.ts
@@ -1,6 +1,11 @@
import interact from 'interactjs'
import type { ModalProps } from 'naive-ui'
+import type { AnyFC } from '@/types'
+
+interface SetupDraggableOptions {
+ scheduler?: AnyFC
+}
/**
*
@@ -15,7 +20,10 @@ import type { ModalProps } from 'naive-ui'
export const setupDraggable = (
bindModal: HTMLElement,
preset: ModalProps['preset'],
+ options?: SetupDraggableOptions,
): Promise> => {
+ const { scheduler } = options ?? {}
+
return new Promise((resolve) => {
setTimeout(() => {
const allowFromStr =
@@ -35,16 +43,7 @@ export const setupDraggable = (
],
listeners: {
move: (event) => {
- const target = event.target
- const x =
- (parseFloat(target.getAttribute('data-x')) || 0) + event.dx
- const y =
- (parseFloat(target.getAttribute('data-y')) || 0) + event.dy
-
- target.style.transform = 'translate(' + x + 'px, ' + y + 'px)'
-
- target.setAttribute('data-x', x)
- target.setAttribute('data-y', y)
+ scheduler?.(event)
},
},
})
diff --git a/src/components/RQRCode/src/index.scss b/src/components/RQRCode/src/index.scss
index e447cce8..4c97667a 100644
--- a/src/components/RQRCode/src/index.scss
+++ b/src/components/RQRCode/src/index.scss
@@ -23,4 +23,8 @@
color: #ffffff;
}
}
+
+ & .n-spin-content--spinning img {
+ filter: blur(6px);
+ }
}
diff --git a/src/components/RQRCode/src/index.tsx b/src/components/RQRCode/src/index.tsx
index 3b94d228..fce8c31e 100644
--- a/src/components/RQRCode/src/index.tsx
+++ b/src/components/RQRCode/src/index.tsx
@@ -59,9 +59,6 @@ export default defineComponent({
const { expose } = ctx
const qrcodeURL = ref()
- const spinOverrides = {
- opacitySpinning: '0.01',
- }
let gifBuffer: GIFBuffer
let watchCallback!: WatchStopHandle
@@ -153,7 +150,6 @@ export default defineComponent({
return {
qrcodeURL,
- spinOverrides,
errorActionClick,
}
},
@@ -162,7 +158,6 @@ export default defineComponent({
@@ -182,7 +177,7 @@ export default defineComponent({
this.$slots.errorAction()
) : (
<>
-
+
{{
default: () => this.errorActionDescription,
icon: () => (
diff --git a/src/components/RQRCode/src/props.ts b/src/components/RQRCode/src/props.ts
index 2bf05073..b07e3a21 100644
--- a/src/components/RQRCode/src/props.ts
+++ b/src/components/RQRCode/src/props.ts
@@ -11,7 +11,7 @@
import type { QRCodeStatus, QRCodeLevel } from './type'
import type { PropType, VNode } from 'vue'
-import type { MaybeArray } from '@/types/modules/utils'
+import type { MaybeArray } from '@/types'
import type { Options } from 'awesome-qr'
const props = {
diff --git a/src/components/RTable/src/Table.tsx b/src/components/RTable/src/Table.tsx
index 7b241be9..9ab3366a 100644
--- a/src/components/RTable/src/Table.tsx
+++ b/src/components/RTable/src/Table.tsx
@@ -22,7 +22,7 @@ import { call, renderNode, uuid } from '@/utils'
import config from './config'
import type { DropdownOption, DataTableInst } from 'naive-ui'
-import type { ComponentSize } from '@/types/modules/component'
+import type { ComponentSize } from '@/types'
import type { C as CType } from './type'
export default defineComponent({
diff --git a/src/components/RTable/src/components/C.tsx b/src/components/RTable/src/components/C.tsx
index 411f56e4..c5be73f2 100644
--- a/src/components/RTable/src/components/C.tsx
+++ b/src/components/RTable/src/components/C.tsx
@@ -27,8 +27,8 @@ import { call } from '@/utils'
import type { TreeOption, TreeDropInfo } from 'naive-ui'
import type { C } from '../type'
-import type { AnyFC } from '@/types/modules/utils'
-import type { MaybeArray } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
+import type { MaybeArray } from '@/types'
type FixedClick = (type: 'left' | 'right', option: C, index: number) => void
diff --git a/src/components/RTable/src/components/Size.tsx b/src/components/RTable/src/components/Size.tsx
index e5eb820f..96e929ca 100644
--- a/src/components/RTable/src/components/Size.tsx
+++ b/src/components/RTable/src/components/Size.tsx
@@ -16,8 +16,8 @@ import { call } from '@/utils'
import props from '../props'
import config from '../config'
-import type { ComponentSize } from '@/types/modules/component'
-import type { MaybeArray } from '@/types/modules/utils'
+import type { ComponentSize } from '@/types'
+import type { MaybeArray } from '@/types'
export default defineComponent({
name: 'TableSizeSelect',
diff --git a/src/components/RTable/src/props.ts b/src/components/RTable/src/props.ts
index 246efbcb..01c670f7 100644
--- a/src/components/RTable/src/props.ts
+++ b/src/components/RTable/src/props.ts
@@ -12,10 +12,10 @@
import { dataTableProps } from 'naive-ui'
import type { PropType, VNode, VNodeChild } from 'vue'
-import type { MaybeArray } from '@/types/modules/utils'
+import type { MaybeArray } from '@/types'
import type { DropdownOption, DataTableColumn } from 'naive-ui'
import type { DownloadTableOptions, PrintTableOptions } from './type'
-import type { Recordable } from '@/types/modules/helper'
+import type { Recordable } from '@/types'
const props = {
...dataTableProps,
diff --git a/src/components/RTable/src/type.ts b/src/components/RTable/src/type.ts
index 6c290f93..aad5a7de 100644
--- a/src/components/RTable/src/type.ts
+++ b/src/components/RTable/src/type.ts
@@ -8,7 +8,7 @@ import type {
DataTableBaseColumn,
} from 'naive-ui'
import type { VNode } from 'vue'
-import type { Recordable } from '@/types/modules/helper'
+import type { Recordable } from '@/types'
import type { PrintDomOptions } from '@/utils'
export type TableActionIcon = string | (() => VNode)
diff --git a/src/directives/modules/debounce/index.ts b/src/directives/modules/debounce/index.ts
index 0ed01513..537dbf10 100644
--- a/src/directives/modules/debounce/index.ts
+++ b/src/directives/modules/debounce/index.ts
@@ -18,7 +18,7 @@ import { debounce } from 'lodash-es'
import { useEventListener } from '@vueuse/core'
import type { DebounceBindingOptions } from './type'
-import type { AnyFC } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
import type { DebouncedFunc } from 'lodash-es'
import type { CustomDirectiveFC } from '@/directives/type'
diff --git a/src/directives/modules/debounce/type.ts b/src/directives/modules/debounce/type.ts
index 40a214c6..204b8234 100644
--- a/src/directives/modules/debounce/type.ts
+++ b/src/directives/modules/debounce/type.ts
@@ -1,5 +1,5 @@
import type { DebounceSettings } from 'lodash-es'
-import type { AnyFC } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
export interface DebounceBindingOptions {
func: AnyFC
diff --git a/src/directives/modules/throttle/index.ts b/src/directives/modules/throttle/index.ts
index 86479a36..d10599ca 100644
--- a/src/directives/modules/throttle/index.ts
+++ b/src/directives/modules/throttle/index.ts
@@ -18,7 +18,7 @@ import { throttle } from 'lodash-es'
import { useEventListener } from '@vueuse/core'
import type { ThrottleBindingOptions } from './type'
-import type { AnyFC } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
import type { DebouncedFunc } from 'lodash-es'
import type { CustomDirectiveFC } from '@/directives/type'
diff --git a/src/directives/modules/throttle/type.ts b/src/directives/modules/throttle/type.ts
index 77487d0d..134595b9 100644
--- a/src/directives/modules/throttle/type.ts
+++ b/src/directives/modules/throttle/type.ts
@@ -1,5 +1,5 @@
import type { ThrottleSettings } from 'lodash-es'
-import type { AnyFC } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
export interface ThrottleBindingOptions {
func: AnyFC
diff --git a/src/global-variable/variable.ts b/src/global-variable/variable.ts
index 8adc9aa3..d3d1b756 100644
--- a/src/global-variable/variable.ts
+++ b/src/global-variable/variable.ts
@@ -27,7 +27,7 @@
* createVariableState({ your state })
*/
-import type { AnyFC } from '@/types/modules/utils'
+import type { AnyFC } from '@/types'
/**
*
diff --git a/src/hooks/components/useContextmenuCoordinate.ts b/src/hooks/components/useContextmenuCoordinate.ts
index d9ceba21..2713dfcc 100644
--- a/src/hooks/components/useContextmenuCoordinate.ts
+++ b/src/hooks/components/useContextmenuCoordinate.ts
@@ -11,11 +11,10 @@
import { useEventListener, onClickOutside } from '@vueuse/core'
-import type { BasicTarget } from '@/types/modules/vue'
+import type { BasicTarget } from '@/types'
import type {
MaybeElementRef,
MaybeElement,
- UseEventSourceOptions,
MaybeRefOrGetter,
} from '@vueuse/core'
diff --git a/src/hooks/template/useAppNavigation.ts b/src/hooks/template/useAppNavigation.ts
index 413762cc..afbc318f 100644
--- a/src/hooks/template/useAppNavigation.ts
+++ b/src/hooks/template/useAppNavigation.ts
@@ -11,7 +11,7 @@
import { useMenuGetters, useMenuActions } from '@/store'
-import type { AppMenuOption } from '@/types/modules/app'
+import type { AppMenuOption } from '@/types'
export type Target = number | AppMenuOption
diff --git a/src/hooks/template/useSiderBar.ts b/src/hooks/template/useSiderBar.ts
index 37e2e3b1..111916da 100644
--- a/src/hooks/template/useSiderBar.ts
+++ b/src/hooks/template/useSiderBar.ts
@@ -12,7 +12,7 @@
import { useMenuGetters, useMenuActions } from '@/store'
import { redirectRouterToDashboard } from '@/router/helper/routerCopilot'
-import type { MenuTagOptions, Key } from '@/types/modules/app'
+import type { MenuTagOptions, Key } from '@/types'
export type CloseMenuTag = Key | MenuTagOptions
diff --git a/src/hooks/web/useDomToImage.ts b/src/hooks/web/useDomToImage.ts
index 5c656459..c496a05b 100644
--- a/src/hooks/web/useDomToImage.ts
+++ b/src/hooks/web/useDomToImage.ts
@@ -13,7 +13,7 @@ import domToImage from 'dom-to-image'
import { unrefElement } from '@/utils'
import type { Options as ReDomToImageOptions } from 'dom-to-image'
-import type { BasicTarget, TargetType } from '@/types/modules/vue'
+import type { BasicTarget, TargetType } from '@/types'
export type ImageType = keyof typeof domToImageMethods
diff --git a/src/hooks/web/useElementFullscreen.ts b/src/hooks/web/useElementFullscreen.ts
index 03b54b81..207fe441 100644
--- a/src/hooks/web/useElementFullscreen.ts
+++ b/src/hooks/web/useElementFullscreen.ts
@@ -12,7 +12,7 @@
import { unrefElement, effectDispose, isValueType } from '@/utils'
import { useWindowSize } from '@vueuse/core'
-import type { BasicTarget } from '@/types/modules/vue'
+import type { BasicTarget } from '@/types'
export interface UseElementFullscreenOptions {
beforeEnter?: () => void
@@ -159,3 +159,7 @@ export const useElementFullscreen = (
toggleFullscreen,
}
}
+
+export type UseElementFullscreenReturnTypes = ReturnType<
+ typeof useElementFullscreen
+>
diff --git a/src/hooks/web/useI18n.ts b/src/hooks/web/useI18n.ts
index 31adab74..98193a17 100644
--- a/src/hooks/web/useI18n.ts
+++ b/src/hooks/web/useI18n.ts
@@ -18,7 +18,7 @@ const getI18nKey = (namespace: string | undefined, key: string) => {
return key
}
- if (key.startsWith(namespace)) {
+ if (key[0] === namespace) {
return key
}
diff --git a/src/hooks/web/usePrint.ts b/src/hooks/web/usePrint.ts
index 0949c670..342af3be 100644
--- a/src/hooks/web/usePrint.ts
+++ b/src/hooks/web/usePrint.ts
@@ -2,7 +2,7 @@
import print from 'print-js'
import { unrefElement } from '@/utils'
-import type { BasicTarget } from '@/types/modules/vue'
+import type { BasicTarget } from '@/types'
export interface UsePrintOptions
extends Omit {}
diff --git a/src/layout/components/Menu/index.tsx b/src/layout/components/Menu/index.tsx
index 71449cda..b363aca1 100644
--- a/src/layout/components/Menu/index.tsx
+++ b/src/layout/components/Menu/index.tsx
@@ -20,8 +20,8 @@ import { getVariableToRefs, setVariable } from '@/global-variable'
import { useMenuGetters, useMenuActions } from '@/store'
import type { MenuInst } from 'naive-ui'
-import type { NaiveMenuOptions } from '@/types/modules/component'
-import type { AppMenuOption } from '@/types/modules/app'
+import type { NaiveMenuOptions } from '@/types'
+import type { AppMenuOption } from '@/types'
export default defineComponent({
name: 'AppMenu',
diff --git a/src/layout/components/MenuTag/index.tsx b/src/layout/components/MenuTag/index.tsx
index 81050eed..c62fbaaf 100644
--- a/src/layout/components/MenuTag/index.tsx
+++ b/src/layout/components/MenuTag/index.tsx
@@ -52,7 +52,7 @@ import { throttle } from 'lodash-es'
import { useAppRoot } from '@/hooks/template'
import type { ScrollbarInst } from 'naive-ui'
-import type { MenuTagOptions, AppMenuOption } from '@/types/modules/app'
+import type { MenuTagOptions, AppMenuOption } from '@/types'
export default defineComponent({
name: 'AppMenuTag',
@@ -423,7 +423,7 @@ export default defineComponent({
}
},
render() {
- const { iconConfig, getRootPath, uuidScrollBar } = this
+ const { iconConfig, getRootPath, uuidScrollBar, getMenuTagOptions } = this
const { maximize, closeCurrentMenuTag, scrollX, $t } = this
return (
@@ -472,7 +472,7 @@ export default defineComponent({
align="center"
justify="start"
>
- {this.getMenuTagOptions.map((curr, idx) => (
+ {getMenuTagOptions.map((curr, idx) => (