ys 5 ngày trước cách đây
mục cha
commit
8ec37d065d
100 tập tin đã thay đổi với 3298 bổ sung0 xóa
  1. 37 0
      .gitignore
  2. 254 0
      README.md
  3. 8 0
      yushu-uivue3/.env.development
  4. 11 0
      yushu-uivue3/.env.production
  5. 11 0
      yushu-uivue3/.env.staging
  6. 1 0
      yushu-uivue3/.github/FUNDING.yml
  7. 23 0
      yushu-uivue3/.gitignore
  8. 20 0
      yushu-uivue3/LICENSE
  9. 240 0
      yushu-uivue3/README.md
  10. 12 0
      yushu-uivue3/bin/build.bat
  11. 12 0
      yushu-uivue3/bin/package.bat
  12. 12 0
      yushu-uivue3/bin/run-web.bat
  13. 21 0
      yushu-uivue3/html/ie.html
  14. 247 0
      yushu-uivue3/index.html
  15. 53 0
      yushu-uivue3/package.json
  16. BIN
      yushu-uivue3/public/favicon.ico
  17. 46 0
      yushu-uivue3/src/App.vue
  18. 86 0
      yushu-uivue3/src/api/login.js
  19. 9 0
      yushu-uivue3/src/api/menu.js
  20. 57 0
      yushu-uivue3/src/api/monitor/cache.js
  21. 60 0
      yushu-uivue3/src/api/monitor/errorLog.js
  22. 71 0
      yushu-uivue3/src/api/monitor/job.js
  23. 26 0
      yushu-uivue3/src/api/monitor/jobLog.js
  24. 34 0
      yushu-uivue3/src/api/monitor/logininfor.js
  25. 18 0
      yushu-uivue3/src/api/monitor/online.js
  26. 26 0
      yushu-uivue3/src/api/monitor/operlog.js
  27. 9 0
      yushu-uivue3/src/api/monitor/server.js
  28. 63 0
      yushu-uivue3/src/api/system/ai/chat.js
  29. 44 0
      yushu-uivue3/src/api/system/ai/config.js
  30. 44 0
      yushu-uivue3/src/api/system/ai/model.js
  31. 44 0
      yushu-uivue3/src/api/system/ai/provider.js
  32. 91 0
      yushu-uivue3/src/api/system/ai/service.js
  33. 60 0
      yushu-uivue3/src/api/system/config.js
  34. 52 0
      yushu-uivue3/src/api/system/dept.js
  35. 52 0
      yushu-uivue3/src/api/system/dict/data.js
  36. 60 0
      yushu-uivue3/src/api/system/dict/type.js
  37. 250 0
      yushu-uivue3/src/api/system/file.js
  38. 13 0
      yushu-uivue3/src/api/system/icon.js
  39. 266 0
      yushu-uivue3/src/api/system/mail.js
  40. 60 0
      yushu-uivue3/src/api/system/menu.js
  41. 159 0
      yushu-uivue3/src/api/system/message.js
  42. 34 0
      yushu-uivue3/src/api/system/messageRemark.js
  43. 44 0
      yushu-uivue3/src/api/system/notice.js
  44. 68 0
      yushu-uivue3/src/api/system/notification.js
  45. 44 0
      yushu-uivue3/src/api/system/post.js
  46. 119 0
      yushu-uivue3/src/api/system/role.js
  47. 21 0
      yushu-uivue3/src/api/system/statistics.js
  48. 136 0
      yushu-uivue3/src/api/system/user.js
  49. 85 0
      yushu-uivue3/src/api/tool/gen.js
  50. BIN
      yushu-uivue3/src/assets/401_images/401.gif
  51. BIN
      yushu-uivue3/src/assets/404_images/404.png
  52. BIN
      yushu-uivue3/src/assets/404_images/404_cloud.png
  53. 1 0
      yushu-uivue3/src/assets/icons/svg/404.svg
  54. 9 0
      yushu-uivue3/src/assets/icons/svg/ai-assistant.svg
  55. 0 0
      yushu-uivue3/src/assets/icons/svg/aislogo.svg
  56. 10 0
      yushu-uivue3/src/assets/icons/svg/aliyun-email.svg
  57. 13 0
      yushu-uivue3/src/assets/icons/svg/api-service.svg
  58. 1 0
      yushu-uivue3/src/assets/icons/svg/bug.svg
  59. 1 0
      yushu-uivue3/src/assets/icons/svg/build.svg
  60. 0 0
      yushu-uivue3/src/assets/icons/svg/button.svg
  61. 0 0
      yushu-uivue3/src/assets/icons/svg/cascader.svg
  62. 1 0
      yushu-uivue3/src/assets/icons/svg/chart.svg
  63. 7 0
      yushu-uivue3/src/assets/icons/svg/chat-bubble.svg
  64. 1 0
      yushu-uivue3/src/assets/icons/svg/checkbox.svg
  65. 1 0
      yushu-uivue3/src/assets/icons/svg/clipboard.svg
  66. 5 0
      yushu-uivue3/src/assets/icons/svg/cloud-service.svg
  67. 1 0
      yushu-uivue3/src/assets/icons/svg/code.svg
  68. 0 0
      yushu-uivue3/src/assets/icons/svg/color.svg
  69. 0 0
      yushu-uivue3/src/assets/icons/svg/component.svg
  70. 0 0
      yushu-uivue3/src/assets/icons/svg/dashboard.svg
  71. 5 0
      yushu-uivue3/src/assets/icons/svg/data-analysis.svg
  72. 0 0
      yushu-uivue3/src/assets/icons/svg/date-range.svg
  73. 0 0
      yushu-uivue3/src/assets/icons/svg/date.svg
  74. 0 0
      yushu-uivue3/src/assets/icons/svg/dict.svg
  75. 1 0
      yushu-uivue3/src/assets/icons/svg/documentation.svg
  76. 1 0
      yushu-uivue3/src/assets/icons/svg/download.svg
  77. 1 0
      yushu-uivue3/src/assets/icons/svg/drag.svg
  78. 1 0
      yushu-uivue3/src/assets/icons/svg/druid.svg
  79. 1 0
      yushu-uivue3/src/assets/icons/svg/edit.svg
  80. 1 0
      yushu-uivue3/src/assets/icons/svg/education.svg
  81. 5 0
      yushu-uivue3/src/assets/icons/svg/email-service.svg
  82. 1 0
      yushu-uivue3/src/assets/icons/svg/email.svg
  83. 1 0
      yushu-uivue3/src/assets/icons/svg/enter.svg
  84. 1 0
      yushu-uivue3/src/assets/icons/svg/example.svg
  85. 1 0
      yushu-uivue3/src/assets/icons/svg/excel.svg
  86. 1 0
      yushu-uivue3/src/assets/icons/svg/exit-fullscreen.svg
  87. 1 0
      yushu-uivue3/src/assets/icons/svg/eye-open.svg
  88. 1 0
      yushu-uivue3/src/assets/icons/svg/eye.svg
  89. 0 0
      yushu-uivue3/src/assets/icons/svg/form.svg
  90. 1 0
      yushu-uivue3/src/assets/icons/svg/fullscreen.svg
  91. 1 0
      yushu-uivue3/src/assets/icons/svg/github.svg
  92. 1 0
      yushu-uivue3/src/assets/icons/svg/guide.svg
  93. 1 0
      yushu-uivue3/src/assets/icons/svg/icon.svg
  94. 1 0
      yushu-uivue3/src/assets/icons/svg/input.svg
  95. 1 0
      yushu-uivue3/src/assets/icons/svg/international.svg
  96. 1 0
      yushu-uivue3/src/assets/icons/svg/job.svg
  97. 1 0
      yushu-uivue3/src/assets/icons/svg/language.svg
  98. 1 0
      yushu-uivue3/src/assets/icons/svg/link.svg
  99. 1 0
      yushu-uivue3/src/assets/icons/svg/list.svg
  100. 1 0
      yushu-uivue3/src/assets/icons/svg/lock.svg

+ 37 - 0
.gitignore

@@ -0,0 +1,37 @@
+# IDE
+.idea/
+*.iml
+.vscode/
+.windsurf/
+*.suo
+*.ntvs*
+*.njsproj
+*.sln
+*.sw?
+
+# 编译输出
+target/
+dist/
+node_modules/
+
+# 日志文件
+*.log
+logs/
+
+# 临时文件
+*.tmp
+*.temp
+*.bak
+
+# 系统文件
+.DS_Store
+Thumbs.db
+
+# 环境配置(敏感信息)
+.env
+.env.local
+.env.*.local
+
+# 上传文件目录
+upload/
+uploadPath/

+ 254 - 0
README.md

@@ -0,0 +1,254 @@
+# 予书管理系统
+
+基于 Spring Boot + Vue3 前后端分离的企业级管理系统
+
+---
+
+## 项目简介
+
+予书管理系统是一套现代化的企业级后台管理解决方案,采用前后端分离架构,提供完整的权限管理、系统监控、开发工具等基础功能。系统界面采用玻璃拟态(Glassmorphism)设计风格,支持深色/浅色主题切换。
+
+---
+
+## 系统架构
+
+```
+yushu/
+├── yushu-backend/          # 后端服务(Spring Boot)
+│   ├── yushu-admin/        # 主应用模块
+│   ├── yushu-common/       # 通用模块
+│   ├── yushu-framework/    # 框架核心
+│   ├── yushu-generator/    # 代码生成器
+│   ├── yushu-quartz/       # 定时任务模块
+│   ├── yushu-system/       # 系统模块
+│   └── sql/                # 数据库脚本
+└── yushu-uivue3/           # 前端应用(Vue3)
+    ├── src/
+    │   ├── api/            # API 接口
+    │   ├── components/     # 公共组件
+    │   ├── views/          # 页面视图
+    │   └── ...
+    └── ...
+```
+
+---
+
+## 技术栈
+
+### 后端
+
+| 技术 | 说明 |
+|------|------|
+| Spring Boot 2.5 | 基础框架 |
+| Spring Security | 安全框架 |
+| MyBatis | ORM 框架 |
+| MySQL | 数据库 |
+| Redis | 缓存 |
+| JWT | 身份认证 |
+| Quartz | 定时任务 |
+
+### 前端
+
+| 技术 | 说明 |
+|------|------|
+| Vue 3 | 前端框架 |
+| Element Plus | UI 组件库 |
+| Vite | 构建工具 |
+| Pinia | 状态管理 |
+| Vue Router | 路由管理 |
+
+---
+
+## 环境要求
+
+### 后端环境
+- JDK 1.8+
+- Maven 3.6+
+- MySQL 5.7+
+- Redis 3.0+
+
+### 前端环境
+- Node.js 16.0+
+- npm 8.0+
+
+---
+
+## 快速部署
+
+### 1. 数据库初始化
+
+```sql
+-- 创建数据库
+CREATE DATABASE yushu DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
+```
+
+**必须导入**:
+```bash
+cd yushu-backend
+
+# 系统核心数据库
+mysql -u root -p yushu < sql/ys_20250522.sql
+
+# 定时任务模块
+mysql -u root -p yushu < sql/quartz.sql
+```
+
+**可选模块**:
+```bash
+# AI模块
+mysql -u root -p yushu < sql/ai.sql
+
+# 邮箱模块
+mysql -u root -p yushu < sql/mail.sql
+
+# 文件模块
+mysql -u root -p yushu < sql/file.sql
+
+# 消息模块
+mysql -u root -p yushu < sql/message.sql
+
+# 错误日志模块
+mysql -u root -p yushu < sql/error-log.sql
+```
+
+### 2. 后端部署
+
+```bash
+# 进入后端目录
+cd yushu-backend
+
+# 修改配置文件
+# yushu-admin/src/main/resources/application-druid.yml  (数据库配置)
+# yushu-admin/src/main/resources/application.yml        (Redis配置)
+
+# 编译打包
+mvn clean package -Dmaven.test.skip=true
+
+# 运行
+cd yushu-admin/target
+java -jar yushu-admin.jar
+```
+
+后端访问地址:http://localhost:8080
+
+### 3. 前端部署
+
+```bash
+# 进入前端目录
+cd yushu-uivue3
+
+# 安装依赖
+npm install
+
+# 开发环境运行
+npm run dev
+
+# 生产环境构建
+npm run build:prod
+```
+
+前端访问地址:http://localhost:80
+
+### 4. 默认账号
+
+- 用户名:admin
+- 密码:admin123
+
+---
+
+## 生产环境部署
+
+### 后端部署
+
+```bash
+# 打包
+mvn clean package -Dmaven.test.skip=true
+
+# 后台运行
+nohup java -jar yushu-admin.jar > yushu.log 2>&1 &
+```
+
+### 前端部署(Nginx)
+
+```nginx
+server {
+    listen       80;
+    server_name  your-domain.com;
+
+    location / {
+        root   /usr/share/nginx/html/dist;
+        index  index.html;
+        try_files $uri $uri/ /index.html;
+    }
+
+    location /prod-api/ {
+        proxy_pass http://localhost:8080/;
+        proxy_set_header Host $host;
+        proxy_set_header X-Real-IP $remote_addr;
+        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+    }
+}
+```
+
+### Docker 部署
+
+后端 Dockerfile:
+```dockerfile
+FROM openjdk:8-jdk-alpine
+VOLUME /tmp
+COPY yushu-admin.jar app.jar
+ENTRYPOINT ["java","-jar","/app.jar"]
+```
+
+```bash
+# 构建镜像
+docker build -t yushu-backend .
+
+# 运行容器
+docker run -d -p 8080:8080 --name yushu-backend yushu-backend
+```
+
+---
+
+## 内置功能
+
+### 系统管理
+- 用户管理:系统用户配置与权限分配
+- 角色管理:角色权限分配,支持数据权限
+- 菜单管理:配置系统菜单、操作权限、按钮权限
+- 部门管理:组织机构树形结构管理
+- 岗位管理:用户职务配置
+- 字典管理:系统常用固定数据维护
+- 参数管理:系统动态配置参数
+- 通知公告:系统通知信息发布
+- 文件管理:系统文件上传与管理
+- 图标管理:系统图标资源管理
+
+### 系统监控
+- 在线用户:当前活跃用户监控,支持强制下线
+- 定时任务:任务调度管理与执行日志
+- 操作日志:系统操作日志记录与查询
+- 登录日志:用户登录记录与异常查询
+- 服务监控:CPU、内存、磁盘、JVM 信息
+- 缓存监控:Redis 缓存信息与统计
+- 数据源监控:数据库连接池状态监控
+
+### 开发工具
+- 代码生成:根据数据库表生成前后端代码
+- 表单构建:可视化表单设计器
+- 系统接口:Swagger API 接口文档
+
+---
+
+## 目录说明
+
+| 目录 | 说明 |
+|------|------|
+| yushu-backend | 后端服务,详见 [后端说明](./yushu-backend/README.md) |
+| yushu-uivue3 | 前端应用,详见 [前端说明](./yushu-uivue3/README.md) |
+
+---
+
+## 致谢
+
+本项目基于 [RuoYi-Vue](https://gitee.com/y_project/RuoYi-Vue) 进行二次开发,感谢若依团队的开源贡献。

+ 8 - 0
yushu-uivue3/.env.development

@@ -0,0 +1,8 @@
+# 页面标题
+VITE_APP_TITLE = 予书管理系统
+
+# 开发环境配置
+VITE_APP_ENV = 'development'
+
+# 予书管理系统/开发环境
+VITE_APP_BASE_API = '/dev-api'

+ 11 - 0
yushu-uivue3/.env.production

@@ -0,0 +1,11 @@
+# 页面标题
+VITE_APP_TITLE = 予书管理系统
+
+# 生产环境配置
+VITE_APP_ENV = 'production'
+
+# 予书管理系统/生产环境
+VITE_APP_BASE_API = '/prod-api'
+
+# 是否在打包时开启压缩,支持 gzip 和 brotli
+VITE_BUILD_COMPRESS = gzip

+ 11 - 0
yushu-uivue3/.env.staging

@@ -0,0 +1,11 @@
+# 页面标题
+VITE_APP_TITLE = 予书管理系统
+
+# 生产环境配置
+VITE_APP_ENV = 'staging'
+
+# 予书管理系统/测试环境
+VITE_APP_BASE_API = '/stage-api'
+
+# 是否在打包时开启压缩,支持 gzip 和 brotli
+VITE_BUILD_COMPRESS = gzip

+ 1 - 0
yushu-uivue3/.github/FUNDING.yml

@@ -0,0 +1 @@
+custom: http://doc.ruoyi.vip/ruoyi-vue/other/donate.html

+ 23 - 0
yushu-uivue3/.gitignore

@@ -0,0 +1,23 @@
+.DS_Store
+node_modules/
+dist/
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+**/*.log
+
+tests/**/coverage/
+tests/e2e/reports
+selenium-debug.log
+
+# Editor directories and files
+.idea
+.vscode
+*.suo
+*.ntvs*
+*.njsproj
+*.sln
+*.local
+
+package-lock.json
+yarn.lock

+ 20 - 0
yushu-uivue3/LICENSE

@@ -0,0 +1,20 @@
+The MIT License (MIT)
+
+Copyright (c) 2018 RuoYi
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated documentation files (the "Software"), to deal in
+the Software without restriction, including without limitation the rights to
+use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
+the Software, and to permit persons to whom the Software is furnished to do so,
+subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
+FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
+COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
+IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

+ 240 - 0
yushu-uivue3/README.md

@@ -0,0 +1,240 @@
+# 予书管理系统 - 前端
+
+基于 Vue3 + Element Plus + Vite 的企业级管理系统前端
+
+---
+
+## 简介
+
+予书管理系统前端采用最新的 Vue3 技术栈,配合 Element Plus 组件库,实现现代化的企业级后台管理界面。
+
+---
+
+## 技术栈
+
+| 技术 | 说明 | 版本 |
+|------|------|------|
+| Vue | 渐进式 JavaScript 框架 | 3.x |
+| Element Plus | Vue3 组件库 | 2.x |
+| Vite | 下一代前端构建工具 | 4.x |
+| Pinia | Vue 状态管理 | 2.x |
+| Vue Router | 路由管理 | 4.x |
+| Axios | HTTP 请求库 | 0.27.x |
+| Sass | CSS 预处理器 | 1.x |
+
+---
+
+## UI 特性
+
+- 玻璃拟态(Glassmorphism)设计风格
+- 深色/浅色主题切换
+- 动态光效与流畅动画
+- 响应式布局适配
+- 自定义 Element Plus 组件样式
+
+---
+
+## 环境要求
+
+- Node.js 16.0+
+- npm 8.0+ 或 yarn 1.22+
+
+---
+
+## 安装部署
+
+### 开发环境
+
+```bash
+# 进入项目目录
+cd yushu-uivue3
+
+# 安装依赖
+npm install
+
+# 启动开发服务
+npm run dev
+
+# 访问地址
+http://localhost:80
+```
+
+### 生产环境
+
+```bash
+# 构建生产环境
+npm run build:prod
+
+# 构建测试环境
+npm run build:stage
+```
+
+### Nginx 部署
+
+将 `dist` 目录下的文件部署到 Nginx:
+
+```nginx
+server {
+    listen       80;
+    server_name  localhost;
+
+    location / {
+        root   /usr/share/nginx/html/dist;
+        index  index.html index.htm;
+        try_files $uri $uri/ /index.html;
+    }
+
+    location /prod-api/ {
+        proxy_pass http://localhost:8080/;
+        proxy_set_header Host $host;
+        proxy_set_header X-Real-IP $remote_addr;
+        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+    }
+}
+```
+
+---
+
+## 项目结构
+
+```
+yushu-uivue3/
+├── public/                     # 静态资源
+│   └── favicon.ico
+├── src/
+│   ├── api/                    # API 接口定义
+│   │   ├── system/             # 系统管理接口
+│   │   ├── monitor/            # 系统监控接口
+│   │   └── tool/               # 开发工具接口
+│   ├── assets/                 # 项目资源
+│   │   ├── icons/              # 图标资源
+│   │   ├── images/             # 图片资源
+│   │   └── styles/             # 全局样式
+│   │       ├── index.scss      # 样式入口
+│   │       ├── element-ui.scss # Element Plus 样式覆盖
+│   │       ├── sidebar.scss    # 侧边栏样式
+│   │       └── variables.module.scss
+│   ├── components/             # 公共组件
+│   │   ├── Breadcrumb/         # 面包屑
+│   │   ├── HeaderSearch/       # 头部搜索
+│   │   ├── IconSelect/         # 图标选择器
+│   │   ├── Pagination/         # 分页组件
+│   │   ├── RightToolbar/       # 右侧工具栏
+│   │   └── ...
+│   ├── directive/              # 自定义指令
+│   ├── layout/                 # 布局组件
+│   │   ├── components/         # 布局子组件
+│   │   └── index.vue           # 主布局
+│   ├── plugins/                # 插件配置
+│   ├── router/                 # 路由配置
+│   ├── store/                  # Pinia 状态管理
+│   │   └── modules/            # 状态模块
+│   ├── utils/                  # 工具函数
+│   │   ├── request.js          # Axios 封装
+│   │   ├── auth.js             # 认证相关
+│   │   └── validate.js         # 表单验证
+│   └── views/                  # 页面视图
+│       ├── dashboard/          # 首页仪表盘
+│       ├── system/             # 系统管理
+│       │   ├── user/           # 用户管理
+│       │   ├── role/           # 角色管理
+│       │   ├── menu/           # 菜单管理
+│       │   ├── dept/           # 部门管理
+│       │   ├── post/           # 岗位管理
+│       │   ├── dict/           # 字典管理
+│       │   ├── param/          # 参数管理
+│       │   ├── notice/         # 通知公告
+│       │   ├── file/           # 文件管理
+│       │   └── icon/           # 图标管理
+│       ├── monitor/            # 系统监控
+│       │   ├── online/         # 在线用户
+│       │   ├── job/            # 定时任务
+│       │   ├── operlog/        # 操作日志
+│       │   ├── logininfor/     # 登录日志
+│       │   ├── server/         # 服务监控
+│       │   ├── cache/          # 缓存监控
+│       │   └── druid/          # 数据源监控
+│       ├── tool/               # 开发工具
+│       │   ├── gen/            # 代码生成
+│       │   ├── build/          # 表单构建
+│       │   └── swagger/        # 接口文档
+│       └── error/              # 错误页面
+├── .env.development            # 开发环境配置
+├── .env.production             # 生产环境配置
+├── .env.staging                # 测试环境配置
+├── vite.config.js              # Vite 配置
+├── package.json                # 项目依赖
+└── README.md                   # 项目说明
+```
+
+---
+
+## 环境配置
+
+### 开发环境 (.env.development)
+
+```properties
+# 开发环境
+VITE_APP_ENV = 'development'
+
+# 接口地址
+VITE_APP_BASE_API = '/dev-api'
+
+# 代理目标地址
+VITE_APP_PROXY_TARGET = 'http://localhost:8080'
+```
+
+### 生产环境 (.env.production)
+
+```properties
+# 生产环境
+VITE_APP_ENV = 'production'
+
+# 接口地址
+VITE_APP_BASE_API = '/prod-api'
+```
+
+---
+
+## 内置功能
+
+### 系统管理
+
+| 功能 | 说明 |
+|------|------|
+| 用户管理 | 系统用户配置与权限分配 |
+| 角色管理 | 角色权限分配,支持数据权限范围划分 |
+| 菜单管理 | 配置系统菜单、操作权限、按钮权限 |
+| 部门管理 | 组织机构树形结构管理 |
+| 岗位管理 | 用户职务配置 |
+| 字典管理 | 系统常用固定数据维护 |
+| 参数管理 | 系统动态配置参数 |
+| 通知公告 | 系统通知信息发布 |
+| 文件管理 | 系统文件上传与管理 |
+| 图标管理 | 系统图标资源管理 |
+
+### 系统监控
+
+| 功能 | 说明 |
+|------|------|
+| 在线用户 | 当前活跃用户状态监控,支持强制下线 |
+| 定时任务 | 任务调度管理与执行日志 |
+| 操作日志 | 系统操作日志记录与查询 |
+| 登录日志 | 用户登录记录与异常查询 |
+| 服务监控 | CPU、内存、磁盘、JVM 等系统信息 |
+| 缓存监控 | Redis 缓存信息与命令统计 |
+| 数据源监控 | 数据库连接池状态监控 |
+
+### 开发工具
+
+| 功能 | 说明 |
+|------|------|
+| 代码生成 | 根据数据库表生成前后端代码 |
+| 表单构建 | 可视化表单设计器 |
+| 系统接口 | Swagger API 接口文档 |
+
+---
+
+## 致谢
+
+本项目基于 [RuoYi-Vue3](https://gitee.com/y_project/RuoYi-Vue) 进行二次开发,感谢若依团队的开源贡献。

+ 12 - 0
yushu-uivue3/bin/build.bat

@@ -0,0 +1,12 @@
+@echo off
+echo.
+echo [信息] 打包Web工程,生成dist文件。
+echo.
+
+%~d0
+cd %~dp0
+
+cd ..
+yarn build:prod
+
+pause

+ 12 - 0
yushu-uivue3/bin/package.bat

@@ -0,0 +1,12 @@
+@echo off
+echo.
+echo [信息] 安装Web工程,生成node_modules文件。
+echo.
+
+%~d0
+cd %~dp0
+
+cd ..
+yarn --registry=https://registry.npmmirror.com
+
+pause

+ 12 - 0
yushu-uivue3/bin/run-web.bat

@@ -0,0 +1,12 @@
+@echo off
+echo.
+echo [信息] 使用 Vite 命令运行 Web 工程。
+echo.
+
+%~d0
+cd %~dp0
+
+cd ..
+yarn dev
+
+pause

Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 21 - 0
yushu-uivue3/html/ie.html


+ 247 - 0
yushu-uivue3/index.html

@@ -0,0 +1,247 @@
+<!DOCTYPE html>
+<html>
+
+<head>
+  <meta charset="utf-8">
+  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
+  <meta name="renderer" content="webkit">
+  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
+  <link rel="icon" href="/favicon.ico">
+  <title>予书管理系统</title>
+  <!--[if lt IE 11]><script>window.location.href='/html/ie.html';</script><![endif]-->
+  <style>
+    html,
+    body,
+    #app {
+      height: 100%;
+      margin: 0px;
+      padding: 0px;
+      font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
+    }
+
+    /* 内容页淡入动画 */
+    #app {
+      opacity: 0;
+      transition: opacity 0.8s ease-in-out;
+    }
+    
+    #app.app-loaded {
+      opacity: 1;
+    }
+
+    /* 容器 - 自带背景色,不依赖body */
+    .app-loading {
+      position: fixed;
+      top: 0;
+      left: 0;
+      width: 100%;
+      height: 100%;
+      background: #090a0f; /* 深空黑 */
+      z-index: 99999;
+      display: flex;
+      justify-content: center;
+      align-items: center;
+      transition: opacity 1.2s ease-in-out, visibility 1.2s; /* 延长消失时间 */
+      overflow: hidden; /* 仅在Loading时隐藏滚动条 */
+    }
+
+    /* Canvas 粒子背景 */
+    #loading-canvas {
+      position: absolute;
+      top: 0;
+      left: 0;
+      width: 100%;
+      height: 100%;
+      z-index: 0;
+    }
+
+    /* 内容区域 */
+    .loading-content {
+      position: relative;
+      z-index: 1;
+      display: flex;
+      flex-direction: column;
+      align-items: center;
+      justify-content: center;
+    }
+
+    /* 极简标题 */
+    .app-loading-title {
+      color: #fff;
+      font-size: 24px;
+      /* 强制指定字体,防止被 Element Plus / Normalize.css 覆盖导致跳变 */
+      font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
+      letter-spacing: 8px;
+      font-weight: 200;
+      line-height: 1.5; /* 锁定行高 */
+      text-transform: uppercase;
+      opacity: 0.9;
+      animation: text-breathe 3s ease-in-out infinite;
+      text-shadow: 0 0 20px rgba(59, 130, 246, 0.5); /* 蓝色微光 */
+    }
+
+    /* 进度条容器 */
+    .loading-bar-container {
+      margin-top: 20px;
+      width: 200px;
+      height: 2px;
+      background: rgba(255, 255, 255, 0.1);
+      border-radius: 2px;
+      overflow: hidden;
+      position: relative;
+    }
+
+    /* 进度条流光 */
+    .loading-bar {
+      position: absolute;
+      top: 0;
+      left: 0;
+      width: 100%;
+      height: 100%;
+      background: linear-gradient(90deg, transparent, #3b82f6, transparent);
+      transform: translateX(-100%);
+      animation: loading-scan 2s cubic-bezier(0.4, 0, 0.2, 1) infinite;
+    }
+
+    @keyframes text-breathe {
+      0%, 100% { opacity: 0.8; text-shadow: 0 0 10px rgba(59, 130, 246, 0.3); }
+      50% { opacity: 1; text-shadow: 0 0 25px rgba(59, 130, 246, 0.8); }
+    }
+
+    @keyframes loading-scan {
+      0% { transform: translateX(-100%); }
+      50% { transform: translateX(0%); }
+      100% { transform: translateX(100%); }
+    }
+  </style>
+</head>
+
+<body>
+  <div id="app"></div>
+  
+  <!-- Vue 挂载前显示的 Loading (移出 #app 以免被 Vue 覆盖) -->
+  <div class="app-loading">
+    <canvas id="loading-canvas"></canvas>
+    <div class="loading-content">
+      <div class="app-loading-title">YUSHU SYSTEM</div>
+      <div class="loading-bar-container">
+        <div class="loading-bar"></div>
+      </div>
+    </div>
+  </div>
+
+  <script>
+    // 沉浸式星空背景
+    (function() {
+      const canvas = document.getElementById('loading-canvas');
+      const ctx = canvas.getContext('2d');
+      let width, height;
+      let stars = [];
+      
+      const starCount = 120; // 减少粒子数量优化性能
+      let speedMultiplier = 1; // 速度倍率
+
+      class Star {
+        constructor() {
+          this.reset();
+          // 初始化时随机进度
+          this.opacity = Math.random(); 
+          this.fadeDir = Math.random() > 0.5 ? 0.01 : -0.01;
+        }
+
+        reset() {
+          this.x = Math.random() * width;
+          this.y = Math.random() * height;
+          this.size = Math.random() * 1.5; 
+          if (Math.random() > 0.95) this.size = Math.random() * 2 + 1; // 减少大星星概率
+          
+          this.speedY = Math.random() * 0.2 + 0.05; 
+          this.speedX = (Math.random() - 0.5) * 0.1;
+        }
+
+        update() {
+          this.y -= this.speedY * speedMultiplier;
+          this.x += this.speedX * speedMultiplier;
+
+          this.opacity += this.fadeDir * (speedMultiplier > 1 ? speedMultiplier * 0.5 : 1);
+          if (this.opacity > 1) {
+            this.opacity = 1;
+            this.fadeDir = -0.01 - Math.random() * 0.02;
+          } else if (this.opacity < 0.2) {
+            this.opacity = 0.2;
+            this.fadeDir = 0.01 + Math.random() * 0.02;
+          }
+
+          if (this.y < 0) {
+            this.y = height;
+            this.x = Math.random() * width;
+          }
+        }
+
+        draw() {
+          ctx.fillStyle = `rgba(255, 255, 255, ${this.opacity})`;
+          ctx.beginPath();
+          ctx.arc(this.x, this.y, this.size, 0, Math.PI * 2);
+          ctx.fill();
+          
+          // 性能优化:移除 shadowBlur,改用绘制两层圆模拟光晕
+          if (this.size > 1.5) {
+             ctx.fillStyle = `rgba(255, 255, 255, ${this.opacity * 0.3})`;
+             ctx.beginPath();
+             ctx.arc(this.x, this.y, this.size * 2, 0, Math.PI * 2);
+             ctx.fill();
+          }
+        }
+      }
+
+      function init() {
+        resize();
+        for (let i = 0; i < starCount; i++) {
+          stars.push(new Star());
+        }
+        loop();
+        
+        // 模拟加速过程:1秒后开始加速,营造冲刺感
+        setTimeout(() => {
+          const accelerate = setInterval(() => {
+            speedMultiplier += 0.5; // 加速更快
+            if (speedMultiplier > 30) clearInterval(accelerate); // 最大加速到30倍,极速穿梭
+          }, 50);
+        }, 800);
+      }
+
+      function resize() {
+        width = canvas.width = window.innerWidth;
+        height = canvas.height = window.innerHeight;
+      }
+
+      function loop() {
+        if (window.loadingAnimationStopped) return; // 停止动画循环
+
+        // 创建拖尾效果 (background with opacity)
+        ctx.fillStyle = 'rgba(9, 10, 15, 0.2)'; // 深色背景,0.2透明度产生拖尾
+        ctx.fillRect(0, 0, width, height);
+        
+        // 偶尔绘制流星 (可选,暂不加,保持宁静)
+
+        for (let star of stars) {
+          star.update();
+          star.draw();
+        }
+        
+        requestAnimationFrame(loop);
+      }
+
+      window.addEventListener('resize', resize);
+      init();
+      
+      // 暴露停止函数给外部调用
+      window.stopLoadingAnimation = function() {
+        window.loadingAnimationStopped = true;
+      }
+    })();
+  </script>
+  <script type="module" src="/src/main.js"></script>
+</body>
+
+</html>

+ 53 - 0
yushu-uivue3/package.json

@@ -0,0 +1,53 @@
+{
+  "name": "yushu",
+  "version": "3.9.0",
+  "description": "予书管理系统",
+  "author": "予书",
+  "license": "MIT",
+  "type": "module",
+  "scripts": {
+    "dev": "vite",
+    "build:prod": "vite build",
+    "build:stage": "vite build --mode staging",
+    "preview": "vite preview"
+  },
+  "repository": {
+    "type": "git",
+    "url": "https://gitee.com/y_project/yushu-Vue.git"
+  },
+  "dependencies": {
+    "@element-plus/icons-vue": "2.3.1",
+    "@vueup/vue-quill": "1.2.0",
+    "@vueuse/core": "13.3.0",
+    "axios": "1.9.0",
+    "clipboard": "2.0.11",
+    "echarts": "5.6.0",
+    "element-plus": "2.10.7",
+    "file-saver": "2.0.5",
+    "fuse.js": "6.6.2",
+    "js-beautify": "1.14.11",
+    "js-cookie": "3.0.5",
+    "jsencrypt": "3.3.2",
+    "markdown-it": "^14.1.0",
+    "nprogress": "0.2.0",
+    "pinia": "3.0.2",
+    "splitpanes": "4.0.4",
+    "vue": "3.5.16",
+    "vue-count-to": "^1.0.13",
+    "vue-cropper": "1.1.1",
+    "vue-router": "4.5.1",
+    "vuedraggable": "4.1.0"
+  },
+  "devDependencies": {
+    "@vitejs/plugin-vue": "5.2.4",
+    "sass-embedded": "1.89.1",
+    "unplugin-auto-import": "0.18.6",
+    "unplugin-vue-setup-extend-plus": "1.0.1",
+    "vite": "6.3.5",
+    "vite-plugin-compression": "0.5.1",
+    "vite-plugin-svg-icons": "2.0.1"
+  },
+  "overrides": {
+    "quill": "2.0.2"
+  }
+}

BIN
yushu-uivue3/public/favicon.ico


+ 46 - 0
yushu-uivue3/src/App.vue

@@ -0,0 +1,46 @@
+<template>
+  <router-view />
+</template>
+
+<script setup>
+import useSettingsStore from '@/store/modules/settings'
+import { handleThemeStyle } from '@/utils/theme'
+
+onMounted(() => {
+  nextTick(() => {
+    // 初始化主题样式
+    handleThemeStyle(useSettingsStore().theme)
+    
+    // 移除 Loading 动画并显示 App
+    const loader = document.querySelector('.app-loading')
+    const app = document.getElementById('app')
+    
+    if (loader) {
+      // 强制延迟 1.5s 再开始淡出,让用户看清星空
+      setTimeout(() => {
+        loader.style.opacity = '0'
+        loader.style.visibility = 'hidden'
+        
+        // 停止星空动画,释放性能
+        if (window.stopLoadingAnimation) {
+          window.stopLoadingAnimation()
+        }
+        
+        // 动画结束后移除节点
+        setTimeout(() => {
+          loader.remove()
+        }, 1200) // 对应 CSS 中的 1.2s transition
+        
+        if (app) {
+          app.classList.add('app-loaded')
+        }
+      }, 1500)
+    } else {
+      // 如果没有 loader(比如热更新),直接显示 app
+      if (app) {
+        app.classList.add('app-loaded')
+      }
+    }
+  })
+})
+</script>

+ 86 - 0
yushu-uivue3/src/api/login.js

@@ -0,0 +1,86 @@
+import request from '@/utils/request'
+
+// 登录方法
+export function login(username, password, code, uuid) {
+  const data = {
+    username,
+    password,
+    code,
+    uuid
+  }
+  return request({
+    url: '/login',
+    headers: {
+      isToken: false,
+      repeatSubmit: false
+    },
+    method: 'post',
+    data: data
+  })
+}
+
+// 注册方法
+export function register(data) {
+  return request({
+    url: '/register',
+    headers: {
+      isToken: false
+    },
+    method: 'post',
+    data: data
+  })
+}
+
+// 获取用户详细信息
+export function getInfo() {
+  return request({
+    url: '/getInfo',
+    method: 'get'
+  })
+}
+
+// 退出方法
+export function logout() {
+  return request({
+    url: '/logout',
+    method: 'post'
+  })
+}
+
+// 获取验证码
+export function getCodeImg() {
+  return request({
+    url: '/captchaImage',
+    headers: {
+      isToken: false
+    },
+    method: 'get',
+    timeout: 20000
+  })
+}
+
+// 发送邮箱验证码
+export function sendEmailCode(email) {
+  return request({
+    url: '/sendEmailCode',
+    headers: {
+      isToken: false,
+      repeatSubmit: false
+    },
+    method: 'post',
+    data: { email }
+  })
+}
+
+// 邮箱登录方法
+export function emailLogin(email, emailCode) {
+  return request({
+    url: '/emailLogin',
+    headers: {
+      isToken: false,
+      repeatSubmit: false
+    },
+    method: 'post',
+    data: { email, emailCode }
+  })
+}

+ 9 - 0
yushu-uivue3/src/api/menu.js

@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+// 获取路由
+export const getRouters = () => {
+  return request({
+    url: '/getRouters',
+    method: 'get'
+  })
+}

+ 57 - 0
yushu-uivue3/src/api/monitor/cache.js

@@ -0,0 +1,57 @@
+import request from '@/utils/request'
+
+// 查询缓存详细
+export function getCache() {
+  return request({
+    url: '/monitor/cache',
+    method: 'get'
+  })
+}
+
+// 查询缓存名称列表
+export function listCacheName() {
+  return request({
+    url: '/monitor/cache/getNames',
+    method: 'get'
+  })
+}
+
+// 查询缓存键名列表
+export function listCacheKey(cacheName) {
+  return request({
+    url: '/monitor/cache/getKeys/' + cacheName,
+    method: 'get'
+  })
+}
+
+// 查询缓存内容
+export function getCacheValue(cacheName, cacheKey) {
+  return request({
+    url: '/monitor/cache/getValue/' + cacheName + '/' + cacheKey,
+    method: 'get'
+  })
+}
+
+// 清理指定名称缓存
+export function clearCacheName(cacheName) {
+  return request({
+    url: '/monitor/cache/clearCacheName/' + cacheName,
+    method: 'delete'
+  })
+}
+
+// 清理指定键名缓存
+export function clearCacheKey(cacheKey) {
+  return request({
+    url: '/monitor/cache/clearCacheKey/' + cacheKey,
+    method: 'delete'
+  })
+}
+
+// 清理全部缓存
+export function clearCacheAll() {
+  return request({
+    url: '/monitor/cache/clearCacheAll',
+    method: 'delete'
+  })
+}

+ 60 - 0
yushu-uivue3/src/api/monitor/errorLog.js

@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询错误日志列表
+export function listErrorLog(query) {
+  return request({
+    url: '/monitor/errorLog/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询错误日志详细
+export function getErrorLog(errorId) {
+  return request({
+    url: '/monitor/errorLog/' + errorId,
+    method: 'get'
+  })
+}
+
+// 处理错误
+export function resolveError(data) {
+  return request({
+    url: '/monitor/errorLog/resolve',
+    method: 'put',
+    data: data
+  })
+}
+
+// 批量处理错误
+export function batchResolve(data) {
+  return request({
+    url: '/monitor/errorLog/batchResolve',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除错误日志
+export function delErrorLog(errorIds) {
+  return request({
+    url: '/monitor/errorLog/' + errorIds,
+    method: 'delete'
+  })
+}
+
+// 清空错误日志
+export function cleanErrorLog() {
+  return request({
+    url: '/monitor/errorLog/clean',
+    method: 'delete'
+  })
+}
+
+// 获取未处理错误数量
+export function getUnresolvedCount() {
+  return request({
+    url: '/monitor/errorLog/unresolved/count',
+    method: 'get'
+  })
+}

+ 71 - 0
yushu-uivue3/src/api/monitor/job.js

@@ -0,0 +1,71 @@
+import request from '@/utils/request'
+
+// 查询定时任务调度列表
+export function listJob(query) {
+  return request({
+    url: '/monitor/job/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询定时任务调度详细
+export function getJob(jobId) {
+  return request({
+    url: '/monitor/job/' + jobId,
+    method: 'get'
+  })
+}
+
+// 新增定时任务调度
+export function addJob(data) {
+  return request({
+    url: '/monitor/job',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改定时任务调度
+export function updateJob(data) {
+  return request({
+    url: '/monitor/job',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除定时任务调度
+export function delJob(jobId) {
+  return request({
+    url: '/monitor/job/' + jobId,
+    method: 'delete'
+  })
+}
+
+// 任务状态修改
+export function changeJobStatus(jobId, status) {
+  const data = {
+    jobId,
+    status
+  }
+  return request({
+    url: '/monitor/job/changeStatus',
+    method: 'put',
+    data: data
+  })
+}
+
+
+// 定时任务立即执行一次
+export function runJob(jobId, jobGroup) {
+  const data = {
+    jobId,
+    jobGroup
+  }
+  return request({
+    url: '/monitor/job/run',
+    method: 'put',
+    data: data
+  })
+}

+ 26 - 0
yushu-uivue3/src/api/monitor/jobLog.js

@@ -0,0 +1,26 @@
+import request from '@/utils/request'
+
+// 查询调度日志列表
+export function listJobLog(query) {
+  return request({
+    url: '/monitor/jobLog/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 删除调度日志
+export function delJobLog(jobLogId) {
+  return request({
+    url: '/monitor/jobLog/' + jobLogId,
+    method: 'delete'
+  })
+}
+
+// 清空调度日志
+export function cleanJobLog() {
+  return request({
+    url: '/monitor/jobLog/clean',
+    method: 'delete'
+  })
+}

+ 34 - 0
yushu-uivue3/src/api/monitor/logininfor.js

@@ -0,0 +1,34 @@
+import request from '@/utils/request'
+
+// 查询登录日志列表
+export function list(query) {
+  return request({
+    url: '/monitor/logininfor/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 删除登录日志
+export function delLogininfor(infoId) {
+  return request({
+    url: '/monitor/logininfor/' + infoId,
+    method: 'delete'
+  })
+}
+
+// 解锁用户登录状态
+export function unlockLogininfor(userName) {
+  return request({
+    url: '/monitor/logininfor/unlock/' + userName,
+    method: 'get'
+  })
+}
+
+// 清空登录日志
+export function cleanLogininfor() {
+  return request({
+    url: '/monitor/logininfor/clean',
+    method: 'delete'
+  })
+}

+ 18 - 0
yushu-uivue3/src/api/monitor/online.js

@@ -0,0 +1,18 @@
+import request from '@/utils/request'
+
+// 查询在线用户列表
+export function list(query) {
+  return request({
+    url: '/monitor/online/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 强退用户
+export function forceLogout(tokenId) {
+  return request({
+    url: '/monitor/online/' + tokenId,
+    method: 'delete'
+  })
+}

+ 26 - 0
yushu-uivue3/src/api/monitor/operlog.js

@@ -0,0 +1,26 @@
+import request from '@/utils/request'
+
+// 查询操作日志列表
+export function list(query) {
+  return request({
+    url: '/monitor/operlog/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 删除操作日志
+export function delOperlog(operId) {
+  return request({
+    url: '/monitor/operlog/' + operId,
+    method: 'delete'
+  })
+}
+
+// 清空操作日志
+export function cleanOperlog() {
+  return request({
+    url: '/monitor/operlog/clean',
+    method: 'delete'
+  })
+}

+ 9 - 0
yushu-uivue3/src/api/monitor/server.js

@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+// 获取服务信息
+export function getServer() {
+  return request({
+    url: '/monitor/server',
+    method: 'get'
+  })
+}

+ 63 - 0
yushu-uivue3/src/api/system/ai/chat.js

@@ -0,0 +1,63 @@
+import request from '@/utils/request'
+
+/**
+ * AI对话API - 简化版
+ * 
+ * 使用 serviceId 替代 configId
+ * 向后兼容:后端同时支持 serviceId 和 configId
+ */
+
+// 发送聊天消息(非流式)
+export function sendMessage(data) {
+  return request({
+    url: '/system/ai/chat/send',
+    method: 'post',
+    data: data,
+    timeout: 60000 // 60秒超时
+  })
+}
+
+// 获取会话历史
+export function getHistory(conversationId) {
+  return request({
+    url: '/system/ai/chat/history/' + conversationId,
+    method: 'get'
+  })
+}
+
+// 创建新会话
+export function createConversation(data) {
+  return request({
+    url: '/system/ai/chat/conversation',
+    method: 'post',
+    data: data
+  })
+}
+
+// 获取用户的会话列表
+export function getConversations() {
+  return request({
+    url: '/system/ai/chat/conversations',
+    method: 'get'
+  })
+}
+
+// 删除会话
+export function deleteConversation(conversationId) {
+  return request({
+    url: '/system/ai/chat/conversation/' + conversationId,
+    method: 'delete'
+  })
+}
+
+// 流式发送消息(SSE)
+export function streamMessage(serviceId, message, conversationId) {
+  const params = new URLSearchParams()
+  params.append('serviceId', serviceId)
+  params.append('message', message)
+  if (conversationId) {
+    params.append('conversationId', conversationId)
+  }
+  
+  return `/system/ai/chat/stream?${params.toString()}`
+}

+ 44 - 0
yushu-uivue3/src/api/system/ai/config.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询AI配置列表
+export function listConfig(query) {
+  return request({
+    url: '/system/ai/config/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询AI配置详细
+export function getConfig(configId) {
+  return request({
+    url: '/system/ai/config/' + configId,
+    method: 'get'
+  })
+}
+
+// 新增AI配置
+export function addConfig(data) {
+  return request({
+    url: '/system/ai/config',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改AI配置
+export function updateConfig(data) {
+  return request({
+    url: '/system/ai/config',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除AI配置
+export function delConfig(configIds) {
+  return request({
+    url: '/system/ai/config/' + configIds,
+    method: 'delete'
+  })
+}

+ 44 - 0
yushu-uivue3/src/api/system/ai/model.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询AI模型列表
+export function listModel(query) {
+  return request({
+    url: '/system/ai/model/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询AI模型详细
+export function getModel(modelId) {
+  return request({
+    url: '/system/ai/model/' + modelId,
+    method: 'get'
+  })
+}
+
+// 新增AI模型
+export function addModel(data) {
+  return request({
+    url: '/system/ai/model',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改AI模型
+export function updateModel(data) {
+  return request({
+    url: '/system/ai/model',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除AI模型
+export function delModel(modelIds) {
+  return request({
+    url: '/system/ai/model/' + modelIds,
+    method: 'delete'
+  })
+}

+ 44 - 0
yushu-uivue3/src/api/system/ai/provider.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询AI厂商列表
+export function listProvider(query) {
+  return request({
+    url: '/system/ai/provider/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询AI厂商详细
+export function getProvider(providerId) {
+  return request({
+    url: '/system/ai/provider/' + providerId,
+    method: 'get'
+  })
+}
+
+// 新增AI厂商
+export function addProvider(data) {
+  return request({
+    url: '/system/ai/provider',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改AI厂商
+export function updateProvider(data) {
+  return request({
+    url: '/system/ai/provider',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除AI厂商
+export function delProvider(providerIds) {
+  return request({
+    url: '/system/ai/provider/' + providerIds,
+    method: 'delete'
+  })
+}

+ 91 - 0
yushu-uivue3/src/api/system/ai/service.js

@@ -0,0 +1,91 @@
+import request from '@/utils/request'
+
+/**
+ * AI服务管理API - 简化版
+ * 
+ * 核心理念:一个服务 = 一个可用的AI
+ * 新增AI只需在这里添加配置
+ */
+
+// 查询AI服务列表
+export function listService(query) {
+  return request({
+    url: '/system/ai/service/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询已启用的AI服务(下拉框使用)
+export function listEnabledService() {
+  return request({
+    url: '/system/ai/service/enabled',
+    method: 'get'
+  })
+}
+
+// 获取AI服务详情
+export function getService(serviceId) {
+  return request({
+    url: '/system/ai/service/' + serviceId,
+    method: 'get'
+  })
+}
+
+// 新增AI服务
+export function addService(data) {
+  return request({
+    url: '/system/ai/service',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改AI服务
+export function updateService(data) {
+  return request({
+    url: '/system/ai/service',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除AI服务
+export function delService(serviceIds) {
+  return request({
+    url: '/system/ai/service/' + serviceIds,
+    method: 'delete'
+  })
+}
+
+// 设置默认服务
+export function setDefaultService(serviceId) {
+  return request({
+    url: '/system/ai/service/default/' + serviceId,
+    method: 'put'
+  })
+}
+
+// 获取默认服务
+export function getDefaultService() {
+  return request({
+    url: '/system/ai/service/default',
+    method: 'get'
+  })
+}
+
+// 测试服务连接
+export function testService(serviceId) {
+  return request({
+    url: '/system/ai/service/test/' + serviceId,
+    method: 'post'
+  })
+}
+
+// 查看完整API Key(需要管理员权限)
+export function viewApiKey(serviceId) {
+  return request({
+    url: '/system/ai/service/viewkey/' + serviceId,
+    method: 'get'
+  })
+}

+ 60 - 0
yushu-uivue3/src/api/system/config.js

@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询参数列表
+export function listConfig(query) {
+  return request({
+    url: '/system/config/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询参数详细
+export function getConfig(configId) {
+  return request({
+    url: '/system/config/' + configId,
+    method: 'get'
+  })
+}
+
+// 根据参数键名查询参数值
+export function getConfigKey(configKey) {
+  return request({
+    url: '/system/config/configKey/' + configKey,
+    method: 'get'
+  })
+}
+
+// 新增参数配置
+export function addConfig(data) {
+  return request({
+    url: '/system/config',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改参数配置
+export function updateConfig(data) {
+  return request({
+    url: '/system/config',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除参数配置
+export function delConfig(configId) {
+  return request({
+    url: '/system/config/' + configId,
+    method: 'delete'
+  })
+}
+
+// 刷新参数缓存
+export function refreshCache() {
+  return request({
+    url: '/system/config/refreshCache',
+    method: 'delete'
+  })
+}

+ 52 - 0
yushu-uivue3/src/api/system/dept.js

@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询部门列表
+export function listDept(query) {
+  return request({
+    url: '/system/dept/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询部门列表(排除节点)
+export function listDeptExcludeChild(deptId) {
+  return request({
+    url: '/system/dept/list/exclude/' + deptId,
+    method: 'get'
+  })
+}
+
+// 查询部门详细
+export function getDept(deptId) {
+  return request({
+    url: '/system/dept/' + deptId,
+    method: 'get'
+  })
+}
+
+// 新增部门
+export function addDept(data) {
+  return request({
+    url: '/system/dept',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改部门
+export function updateDept(data) {
+  return request({
+    url: '/system/dept',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除部门
+export function delDept(deptId) {
+  return request({
+    url: '/system/dept/' + deptId,
+    method: 'delete'
+  })
+}

+ 52 - 0
yushu-uivue3/src/api/system/dict/data.js

@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+
+// 查询字典数据列表
+export function listData(query) {
+  return request({
+    url: '/system/dict/data/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询字典数据详细
+export function getData(dictCode) {
+  return request({
+    url: '/system/dict/data/' + dictCode,
+    method: 'get'
+  })
+}
+
+// 根据字典类型查询字典数据信息
+export function getDicts(dictType) {
+  return request({
+    url: '/system/dict/data/type/' + dictType,
+    method: 'get'
+  })
+}
+
+// 新增字典数据
+export function addData(data) {
+  return request({
+    url: '/system/dict/data',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改字典数据
+export function updateData(data) {
+  return request({
+    url: '/system/dict/data',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除字典数据
+export function delData(dictCode) {
+  return request({
+    url: '/system/dict/data/' + dictCode,
+    method: 'delete'
+  })
+}

+ 60 - 0
yushu-uivue3/src/api/system/dict/type.js

@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询字典类型列表
+export function listType(query) {
+  return request({
+    url: '/system/dict/type/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询字典类型详细
+export function getType(dictId) {
+  return request({
+    url: '/system/dict/type/' + dictId,
+    method: 'get'
+  })
+}
+
+// 新增字典类型
+export function addType(data) {
+  return request({
+    url: '/system/dict/type',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改字典类型
+export function updateType(data) {
+  return request({
+    url: '/system/dict/type',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除字典类型
+export function delType(dictId) {
+  return request({
+    url: '/system/dict/type/' + dictId,
+    method: 'delete'
+  })
+}
+
+// 刷新字典缓存
+export function refreshCache() {
+  return request({
+    url: '/system/dict/type/refreshCache',
+    method: 'delete'
+  })
+}
+
+// 获取字典选择框列表
+export function optionselect() {
+  return request({
+    url: '/system/dict/type/optionselect',
+    method: 'get'
+  })
+}

+ 250 - 0
yushu-uivue3/src/api/system/file.js

@@ -0,0 +1,250 @@
+import request from '@/utils/request'
+
+// 查询文件夹列表
+export function listFolder(query) {
+  return request({
+    url: '/system/folder/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询文件夹详细
+export function getFolder(folderId) {
+  return request({
+    url: '/system/folder/' + folderId,
+    method: 'get'
+  })
+}
+
+// 新增文件夹
+export function addFolder(data) {
+  return request({
+    url: '/system/folder',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改文件夹
+export function updateFolder(data) {
+  return request({
+    url: '/system/folder',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除文件夹
+export function delFolder(folderId) {
+  return request({
+    url: '/system/folder/' + folderId,
+    method: 'delete'
+  })
+}
+
+// 获取文件夹树
+export function getFolderTree(query) {
+  return request({
+    url: '/system/folder/tree',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询文件列表
+export function listFile(query) {
+  return request({
+    url: '/system/file/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询文件详细
+export function getFile(fileId) {
+  return request({
+    url: '/system/file/' + fileId,
+    method: 'get'
+  })
+}
+
+// 上传文件
+export function uploadFile(data) {
+  return request({
+    url: '/system/file/upload',
+    method: 'post',
+    data: data,
+    headers: {
+      'Content-Type': 'multipart/form-data',
+      'repeatSubmit': false
+    }
+  })
+}
+
+// 修改文件
+export function updateFile(data) {
+  return request({
+    url: '/system/file',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除文件
+export function delFile(fileId) {
+  return request({
+    url: '/system/file/' + fileId,
+    method: 'delete'
+  })
+}
+
+// 下载文件
+export function downloadFile(fileId) {
+  return request({
+    url: '/system/file/download/' + fileId,
+    method: 'get',
+    responseType: 'blob'
+  })
+}
+
+// 预览文件
+export function previewFile(fileId) {
+  return import.meta.env.VITE_APP_BASE_API + '/system/file/preview/' + fileId
+}
+
+// 获取文件访问URL
+export function getFileUrl(fileId) {
+  return request({
+    url: '/system/file/url/' + fileId,
+    method: 'get'
+  })
+}
+
+// 移动文件
+export function moveFile(fileId, targetFolderId) {
+  return request({
+    url: '/system/file/move',
+    method: 'post',
+    params: {
+      fileId: fileId,
+      targetFolderId: targetFolderId
+    }
+  })
+}
+
+// 复制文件
+export function copyFile(fileId, targetFolderId) {
+  return request({
+    url: '/system/file/copy',
+    method: 'post',
+    params: {
+      fileId: fileId,
+      targetFolderId: targetFolderId
+    },
+    headers: {
+      'repeatSubmit': false
+    }
+  })
+}
+
+// 复制文件夹
+export function copyFolder(folderId, targetFolderId) {
+  return request({
+    url: '/system/folder/copy',
+    method: 'post',
+    params: {
+      folderId: folderId,
+      targetFolderId: targetFolderId
+    },
+    headers: {
+      'repeatSubmit': false
+    }
+  })
+}
+
+// 查询文件分享列表
+export function listFileShare(query) {
+  return request({
+    url: '/system/file/share/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 获取文件的分享信息
+export function getFileShare(fileId) {
+  return request({
+    url: '/system/file/share/file/' + fileId,
+    method: 'get'
+  })
+}
+
+// 获取文件夹的分享信息
+export function getFolderShare(folderId) {
+  return request({
+    url: '/system/file/share/folder/' + folderId,
+    method: 'get'
+  })
+}
+
+// 创建文件分享
+export function createFileShare(fileId, expireDays, needPassword) {
+  return request({
+    url: '/system/file/share/create',
+    method: 'post',
+    params: {
+      fileId: fileId,
+      expireDays: expireDays,
+      needPassword: needPassword
+    }
+  })
+}
+
+// 创建文件夹分享
+export function createFolderShare(folderId, expireDays, needPassword) {
+  return request({
+    url: '/system/file/share/createFolder',
+    method: 'post',
+    params: {
+      folderId: folderId,
+      expireDays: expireDays,
+      needPassword: needPassword
+    }
+  })
+}
+
+// 删除文件分享
+export function delFileShare(shareId) {
+  return request({
+    url: '/system/file/share/' + shareId,
+    method: 'delete'
+  })
+}
+
+// 取消文件分享(通过文件ID)
+export function cancelFileShare(fileId) {
+  return request({
+    url: '/system/file/share/cancel/' + fileId,
+    method: 'delete'
+  })
+}
+
+// 验证文件分享
+export function verifyFileShare(shareCode, password) {
+  return request({
+    url: '/system/file/share/verify/' + shareCode,
+    method: 'get',
+    params: {
+      password: password
+    }
+  })
+}
+
+// 获取分享文件夹下的子文件夹内容
+export function getShareFolderFiles(shareCode, folderId) {
+  return request({
+    url: `/system/file/share/folder/${shareCode}/${folderId}`,
+    method: 'get'
+  })
+}

+ 13 - 0
yushu-uivue3/src/api/system/icon.js

@@ -0,0 +1,13 @@
+import request from '@/utils/request'
+
+// 上传图标(开发环境使用)
+export function uploadIcon(data) {
+  return request({
+    url: '/system/icon/upload',
+    method: 'post',
+    headers: {
+      'Content-Type': 'multipart/form-data'
+    },
+    data: data
+  })
+}

+ 266 - 0
yushu-uivue3/src/api/system/mail.js

@@ -0,0 +1,266 @@
+import request from '@/utils/request'
+
+// ==================== 邮箱配置 ====================
+
+// 查询邮箱配置列表
+export function listMailConfig(query) {
+  return request({
+    url: '/system/mail/config/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询邮箱配置详细
+export function getMailConfig(configId) {
+  return request({
+    url: '/system/mail/config/' + configId,
+    method: 'get'
+  })
+}
+
+// 新增邮箱配置
+export function addMailConfig(data) {
+  return request({
+    url: '/system/mail/config',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改邮箱配置
+export function updateMailConfig(data) {
+  return request({
+    url: '/system/mail/config',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除邮箱配置
+export function delMailConfig(configId) {
+  return request({
+    url: '/system/mail/config/' + configId,
+    method: 'delete'
+  })
+}
+
+// 获取已启用的邮箱配置列表
+export function getEnabledConfigList() {
+  return request({
+    url: '/system/mail/config/enabledList',
+    method: 'get'
+  })
+}
+
+// 测试邮箱连接
+export function testMailConfig(data) {
+  return request({
+    url: '/system/mail/config/test',
+    method: 'post',
+    data: data
+  })
+}
+
+// ==================== 邮件模板 ====================
+
+// 查询邮件模板列表
+export function listMailTemplate(query) {
+  return request({
+    url: '/system/mail/template/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询邮件模板详细
+export function getMailTemplate(templateId) {
+  return request({
+    url: '/system/mail/template/' + templateId,
+    method: 'get'
+  })
+}
+
+// 新增邮件模板
+export function addMailTemplate(data) {
+  return request({
+    url: '/system/mail/template',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改邮件模板
+export function updateMailTemplate(data) {
+  return request({
+    url: '/system/mail/template',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除邮件模板
+export function delMailTemplate(templateId) {
+  return request({
+    url: '/system/mail/template/' + templateId,
+    method: 'delete'
+  })
+}
+
+// 预览邮件模板
+export function previewMailTemplate(data) {
+  return request({
+    url: '/system/mail/template/preview',
+    method: 'post',
+    data: data
+  })
+}
+
+// 获取模板选择列表
+export function getTemplateSelectList() {
+  return request({
+    url: '/system/mail/template/selectList',
+    method: 'get'
+  })
+}
+
+// ==================== 邮件发送记录 ====================
+
+// 查询邮件发送记录列表
+export function listMailLog(query) {
+  return request({
+    url: '/system/mail/log/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询邮件发送记录详细
+export function getMailLog(logId) {
+  return request({
+    url: '/system/mail/log/' + logId,
+    method: 'get'
+  })
+}
+
+// 删除邮件发送记录
+export function delMailLog(logId) {
+  return request({
+    url: '/system/mail/log/' + logId,
+    method: 'delete'
+  })
+}
+
+// 清空邮件发送记录
+export function cleanMailLog() {
+  return request({
+    url: '/system/mail/log/clean',
+    method: 'delete'
+  })
+}
+
+// 重新发送邮件
+export function resendMail(logId) {
+  return request({
+    url: '/system/mail/log/resend/' + logId,
+    method: 'post'
+  })
+}
+
+// ==================== 邮件发送 ====================
+
+// 发送邮件
+export function sendMail(data) {
+  return request({
+    url: '/system/mail/send',
+    method: 'post',
+    data: data
+  })
+}
+
+// 使用模板发送邮件
+export function sendMailByTemplate(data) {
+  return request({
+    url: '/system/mail/send/template',
+    method: 'post',
+    data: data
+  })
+}
+
+// ==================== 收件箱 ====================
+
+// 查询收件列表
+export function listMailInbox(query) {
+  return request({
+    url: '/system/mail/inbox/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询收件详细
+export function getMailInbox(inboxId) {
+  return request({
+    url: '/system/mail/inbox/' + inboxId,
+    method: 'get'
+  })
+}
+
+// 获取未读数量
+export function getUnreadCount(configId) {
+  return request({
+    url: '/system/mail/inbox/unreadCount',
+    method: 'get',
+    params: { configId }
+  })
+}
+
+// 标记已读
+export function markAsRead(inboxId) {
+  return request({
+    url: '/system/mail/inbox/markRead/' + inboxId,
+    method: 'put'
+  })
+}
+
+// 批量标记已读
+export function batchMarkAsRead(inboxIds) {
+  return request({
+    url: '/system/mail/inbox/batchMarkRead',
+    method: 'put',
+    data: inboxIds
+  })
+}
+
+// 切换星标
+export function toggleStar(inboxId) {
+  return request({
+    url: '/system/mail/inbox/toggleStar/' + inboxId,
+    method: 'put'
+  })
+}
+
+// 删除收件
+export function delMailInbox(inboxId) {
+  return request({
+    url: '/system/mail/inbox/' + inboxId,
+    method: 'delete'
+  })
+}
+
+// 同步邮件(不设置超时限制)
+export function syncMails(configId) {
+  return request({
+    url: '/system/mail/inbox/sync/' + configId,
+    method: 'post',
+    timeout: 0 // 0表示不限制超时时间
+  })
+}
+
+// 标记指定账户的所有未读邮件为已读
+export function markAllAsReadByConfig(configId) {
+  return request({
+    url: '/system/mail/inbox/markAllAsRead/' + configId,
+    method: 'put'
+  })
+}

+ 60 - 0
yushu-uivue3/src/api/system/menu.js

@@ -0,0 +1,60 @@
+import request from '@/utils/request'
+
+// 查询菜单列表
+export function listMenu(query) {
+  return request({
+    url: '/system/menu/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询菜单详细
+export function getMenu(menuId) {
+  return request({
+    url: '/system/menu/' + menuId,
+    method: 'get'
+  })
+}
+
+// 查询菜单下拉树结构
+export function treeselect() {
+  return request({
+    url: '/system/menu/treeselect',
+    method: 'get'
+  })
+}
+
+// 根据角色ID查询菜单下拉树结构
+export function roleMenuTreeselect(roleId) {
+  return request({
+    url: '/system/menu/roleMenuTreeselect/' + roleId,
+    method: 'get'
+  })
+}
+
+// 新增菜单
+export function addMenu(data) {
+  return request({
+    url: '/system/menu',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改菜单
+export function updateMenu(data) {
+  return request({
+    url: '/system/menu',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除菜单
+export function delMenu(menuId) {
+  return request({
+    url: '/system/menu/' + menuId,
+    method: 'delete'
+  })
+}

+ 159 - 0
yushu-uivue3/src/api/system/message.js

@@ -0,0 +1,159 @@
+import request from '@/utils/request'
+
+// ========================================
+// 系统通知相关API(用于 /system/message 页面)
+// ========================================
+
+// 查询系统通知列表(管理员)
+export function listNotification(query) {
+  return request({
+    url: '/system/notification/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 获取系统通知详细信息
+export function getNotification(notificationId) {
+  return request({
+    url: '/system/notification/' + notificationId,
+    method: 'get'
+  })
+}
+
+// 新增系统通知
+export function addNotification(data) {
+  return request({
+    url: '/system/notification',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改系统通知
+export function updateNotification(data) {
+  return request({
+    url: '/system/notification',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除系统通知
+export function delNotification(notificationId) {
+  return request({
+    url: '/system/notification/' + notificationId,
+    method: 'delete'
+  })
+}
+
+// 发布通知
+export function publishNotification(notificationId) {
+  return request({
+    url: '/system/notification/' + notificationId + '/publish',
+    method: 'post'
+  })
+}
+
+// 获取用户通知列表
+export function getMyNotifications() {
+  return request({
+    url: '/system/notification/my',
+    method: 'get'
+  })
+}
+
+// 获取未读通知数量
+export function getUnreadNotificationCount() {
+  return request({
+    url: '/system/notification/unread/count',
+    method: 'get'
+  })
+}
+
+// 标记通知为已读
+export function markNotificationAsRead(notificationId) {
+  return request({
+    url: '/system/notification/' + notificationId + '/read',
+    method: 'put'
+  })
+}
+
+// 删除用户通知
+export function deleteMyNotification(notificationId) {
+  return request({
+    url: '/system/notification/' + notificationId + '/my',
+    method: 'delete'
+  })
+}
+
+// ========================================
+// 用户对话相关API(用于 /message 页面)
+// ========================================
+
+// 获取会话列表
+export function getConversationList() {
+  return request({
+    url: '/chat/conversations',
+    method: 'get'
+  })
+}
+
+// 创建或获取私聊会话
+export function createPrivateConversation(otherUserId) {
+  return request({
+    url: '/chat/conversation/private/' + otherUserId,
+    method: 'post'
+  })
+}
+
+// 获取会话消息列表
+export function getConversationMessages(conversationId, pageNum = 1, pageSize = 50) {
+  return request({
+    url: '/chat/conversation/' + conversationId + '/messages',
+    method: 'get',
+    params: { pageNum, pageSize }
+  })
+}
+
+// 发送消息
+export function sendMessage(conversationId, content) {
+  return request({
+    url: '/chat/conversation/' + conversationId + '/message',
+    method: 'post',
+    data: { content }
+  })
+}
+
+// 设置会话备注
+export function setConversationRemark(conversationId, remarkName) {
+  return request({
+    url: '/chat/conversation/' + conversationId + '/remark',
+    method: 'put',
+    data: { remarkName }
+  })
+}
+
+// 获取会话未读消息数
+export function getConversationUnreadCount(conversationId) {
+  return request({
+    url: '/chat/conversation/' + conversationId + '/unread',
+    method: 'get'
+  })
+}
+
+// 标记会话为已读
+export function markConversationAsRead(conversationId) {
+  return request({
+    url: '/chat/conversation/' + conversationId + '/read',
+    method: 'put'
+  })
+}
+
+// 删除会话
+export function deleteConversation(conversationId) {
+  return request({
+    url: '/chat/conversation/' + conversationId,
+    method: 'delete'
+  })
+}

+ 34 - 0
yushu-uivue3/src/api/system/messageRemark.js

@@ -0,0 +1,34 @@
+import request from '@/utils/request'
+
+// 查询当前用户的所有备注(Map格式)
+export function getRemarksMap() {
+  return request({
+    url: '/system/message/remark/map',
+    method: 'get'
+  })
+}
+
+// 查询备注详情
+export function getRemarkInfo(targetUserId) {
+  return request({
+    url: '/system/message/remark/' + targetUserId,
+    method: 'get'
+  })
+}
+
+// 设置备注
+export function setRemark(data) {
+  return request({
+    url: '/system/message/remark/set',
+    method: 'post',
+    data: data
+  })
+}
+
+// 删除备注
+export function delRemark(targetUserId) {
+  return request({
+    url: '/system/message/remark/' + targetUserId,
+    method: 'delete'
+  })
+}

+ 44 - 0
yushu-uivue3/src/api/system/notice.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询公告列表
+export function listNotice(query) {
+  return request({
+    url: '/system/notice/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询公告详细
+export function getNotice(noticeId) {
+  return request({
+    url: '/system/notice/' + noticeId,
+    method: 'get'
+  })
+}
+
+// 新增公告
+export function addNotice(data) {
+  return request({
+    url: '/system/notice',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改公告
+export function updateNotice(data) {
+  return request({
+    url: '/system/notice',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除公告
+export function delNotice(noticeId) {
+  return request({
+    url: '/system/notice/' + noticeId,
+    method: 'delete'
+  })
+}

+ 68 - 0
yushu-uivue3/src/api/system/notification.js

@@ -0,0 +1,68 @@
+import request from '@/utils/request'
+
+// 查询系统通知列表
+export function listNotification(query) {
+  return request({
+    url: '/system/notification/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 获取所有系统通知
+export function getAllNotifications() {
+  return request({
+    url: '/system/notification/public/list',
+    method: 'get'
+  })
+}
+
+// 获取未读通知数
+export function getUnreadCount() {
+  return request({
+    url: '/system/notification/unread-count',
+    method: 'get'
+  })
+}
+
+// 标记通知为已读
+export function markNotificationAsRead(notificationId) {
+  return request({
+    url: '/system/notification/mark-read/' + notificationId,
+    method: 'post'
+  })
+}
+
+// 查询系统通知详细
+export function getNotification(notificationId) {
+  return request({
+    url: '/system/notification/' + notificationId,
+    method: 'get'
+  })
+}
+
+// 新增系统通知
+export function addNotification(data) {
+  return request({
+    url: '/system/notification',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改系统通知
+export function updateNotification(data) {
+  return request({
+    url: '/system/notification',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除系统通知
+export function delNotification(notificationId) {
+  return request({
+    url: '/system/notification/' + notificationId,
+    method: 'delete'
+  })
+}

+ 44 - 0
yushu-uivue3/src/api/system/post.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询岗位列表
+export function listPost(query) {
+  return request({
+    url: '/system/post/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询岗位详细
+export function getPost(postId) {
+  return request({
+    url: '/system/post/' + postId,
+    method: 'get'
+  })
+}
+
+// 新增岗位
+export function addPost(data) {
+  return request({
+    url: '/system/post',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改岗位
+export function updatePost(data) {
+  return request({
+    url: '/system/post',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除岗位
+export function delPost(postId) {
+  return request({
+    url: '/system/post/' + postId,
+    method: 'delete'
+  })
+}

+ 119 - 0
yushu-uivue3/src/api/system/role.js

@@ -0,0 +1,119 @@
+import request from '@/utils/request'
+
+// 查询角色列表
+export function listRole(query) {
+  return request({
+    url: '/system/role/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询角色详细
+export function getRole(roleId) {
+  return request({
+    url: '/system/role/' + roleId,
+    method: 'get'
+  })
+}
+
+// 新增角色
+export function addRole(data) {
+  return request({
+    url: '/system/role',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改角色
+export function updateRole(data) {
+  return request({
+    url: '/system/role',
+    method: 'put',
+    data: data
+  })
+}
+
+// 角色数据权限
+export function dataScope(data) {
+  return request({
+    url: '/system/role/dataScope',
+    method: 'put',
+    data: data
+  })
+}
+
+// 角色状态修改
+export function changeRoleStatus(roleId, status) {
+  const data = {
+    roleId,
+    status
+  }
+  return request({
+    url: '/system/role/changeStatus',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除角色
+export function delRole(roleId) {
+  return request({
+    url: '/system/role/' + roleId,
+    method: 'delete'
+  })
+}
+
+// 查询角色已授权用户列表
+export function allocatedUserList(query) {
+  return request({
+    url: '/system/role/authUser/allocatedList',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询角色未授权用户列表
+export function unallocatedUserList(query) {
+  return request({
+    url: '/system/role/authUser/unallocatedList',
+    method: 'get',
+    params: query
+  })
+}
+
+// 取消用户授权角色
+export function authUserCancel(data) {
+  return request({
+    url: '/system/role/authUser/cancel',
+    method: 'put',
+    data: data
+  })
+}
+
+// 批量取消用户授权角色
+export function authUserCancelAll(data) {
+  return request({
+    url: '/system/role/authUser/cancelAll',
+    method: 'put',
+    params: data
+  })
+}
+
+// 授权用户选择
+export function authUserSelectAll(data) {
+  return request({
+    url: '/system/role/authUser/selectAll',
+    method: 'put',
+    params: data
+  })
+}
+
+// 根据角色ID查询部门树结构
+export function deptTreeSelect(roleId) {
+  return request({
+    url: '/system/role/deptTree/' + roleId,
+    method: 'get'
+  })
+}

+ 21 - 0
yushu-uivue3/src/api/system/statistics.js

@@ -0,0 +1,21 @@
+import request from '@/utils/request'
+
+/**
+ * 获取首页统计数据
+ */
+export function getDashboardStats() {
+  return request({
+    url: '/system/statistics/dashboard',
+    method: 'get'
+  })
+}
+
+/**
+ * 获取访问趋势数据
+ */
+export function getVisitsTrend() {
+  return request({
+    url: '/system/statistics/visits/trend',
+    method: 'get'
+  })
+}

+ 136 - 0
yushu-uivue3/src/api/system/user.js

@@ -0,0 +1,136 @@
+import request from '@/utils/request'
+import { parseStrEmpty } from "@/utils/yushu";
+
+// 查询用户列表
+export function listUser(query) {
+  return request({
+    url: '/system/user/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询用户详细
+export function getUser(userId) {
+  return request({
+    url: '/system/user/' + parseStrEmpty(userId),
+    method: 'get'
+  })
+}
+
+// 新增用户
+export function addUser(data) {
+  return request({
+    url: '/system/user',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改用户
+export function updateUser(data) {
+  return request({
+    url: '/system/user',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除用户
+export function delUser(userId) {
+  return request({
+    url: '/system/user/' + userId,
+    method: 'delete'
+  })
+}
+
+// 用户密码重置
+export function resetUserPwd(userId, password) {
+  const data = {
+    userId,
+    password
+  }
+  return request({
+    url: '/system/user/resetPwd',
+    method: 'put',
+    data: data
+  })
+}
+
+// 用户状态修改
+export function changeUserStatus(userId, status) {
+  const data = {
+    userId,
+    status
+  }
+  return request({
+    url: '/system/user/changeStatus',
+    method: 'put',
+    data: data
+  })
+}
+
+// 查询用户个人信息
+export function getUserProfile() {
+  return request({
+    url: '/system/user/profile',
+    method: 'get'
+  })
+}
+
+// 修改用户个人信息
+export function updateUserProfile(data) {
+  return request({
+    url: '/system/user/profile',
+    method: 'put',
+    data: data
+  })
+}
+
+// 用户密码重置
+export function updateUserPwd(oldPassword, newPassword) {
+  const data = {
+    oldPassword,
+    newPassword
+  }
+  return request({
+    url: '/system/user/profile/updatePwd',
+    method: 'put',
+    data: data
+  })
+}
+
+// 用户头像上传
+export function uploadAvatar(data) {
+  return request({
+    url: '/system/user/profile/avatar',
+    method: 'post',
+    headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
+    data: data
+  })
+}
+
+// 查询授权角色
+export function getAuthRole(userId) {
+  return request({
+    url: '/system/user/authRole/' + userId,
+    method: 'get'
+  })
+}
+
+// 保存授权角色
+export function updateAuthRole(data) {
+  return request({
+    url: '/system/user/authRole',
+    method: 'put',
+    params: data
+  })
+}
+
+// 查询部门下拉树结构
+export function deptTreeSelect() {
+  return request({
+    url: '/system/user/deptTree',
+    method: 'get'
+  })
+}

+ 85 - 0
yushu-uivue3/src/api/tool/gen.js

@@ -0,0 +1,85 @@
+import request from '@/utils/request'
+
+// 查询生成表数据
+export function listTable(query) {
+  return request({
+    url: '/tool/gen/list',
+    method: 'get',
+    params: query
+  })
+}
+// 查询db数据库列表
+export function listDbTable(query) {
+  return request({
+    url: '/tool/gen/db/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询表详细信息
+export function getGenTable(tableId) {
+  return request({
+    url: '/tool/gen/' + tableId,
+    method: 'get'
+  })
+}
+
+// 修改代码生成信息
+export function updateGenTable(data) {
+  return request({
+    url: '/tool/gen',
+    method: 'put',
+    data: data
+  })
+}
+
+// 导入表
+export function importTable(data) {
+  return request({
+    url: '/tool/gen/importTable',
+    method: 'post',
+    params: data
+  })
+}
+
+// 创建表
+export function createTable(data) {
+  return request({
+    url: '/tool/gen/createTable',
+    method: 'post',
+    params: data
+  })
+}
+
+// 预览生成代码
+export function previewTable(tableId) {
+  return request({
+    url: '/tool/gen/preview/' + tableId,
+    method: 'get'
+  })
+}
+
+// 删除表数据
+export function delTable(tableId) {
+  return request({
+    url: '/tool/gen/' + tableId,
+    method: 'delete'
+  })
+}
+
+// 生成代码(自定义路径)
+export function genCode(tableName) {
+  return request({
+    url: '/tool/gen/genCode/' + tableName,
+    method: 'get'
+  })
+}
+
+// 同步数据库
+export function synchDb(tableName) {
+  return request({
+    url: '/tool/gen/synchDb/' + tableName,
+    method: 'get'
+  })
+}

BIN
yushu-uivue3/src/assets/401_images/401.gif


BIN
yushu-uivue3/src/assets/404_images/404.png


BIN
yushu-uivue3/src/assets/404_images/404_cloud.png


+ 1 - 0
yushu-uivue3/src/assets/icons/svg/404.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M121.718 73.272v9.953c3.957-7.584 6.199-16.05 6.199-24.995C127.917 26.079 99.273 0 63.958 0 28.644 0 0 26.079 0 58.23c0 .403.028.806.028 1.21l22.97-25.953h13.34l-19.76 27.187h6.42V53.77l13.728-19.477v49.361H22.998V73.272H2.158c5.951 20.284 23.608 36.208 45.998 41.399-1.44 3.3-5.618 11.263-12.565 12.674-8.607 1.764 23.358.428 46.163-13.178 17.519-4.611 31.938-15.849 39.77-30.513h-13.506V73.272H85.02V59.464l22.998-25.977h13.008l-19.429 27.187h6.421v-7.433l13.727-19.402v39.433h-.027zm-78.24 2.822a10.516 10.516 0 0 1-.996-4.535V44.548c0-1.613.332-3.124.996-4.535a11.66 11.66 0 0 1 2.713-3.68c1.134-1.032 2.49-1.864 4.04-2.468 1.55-.605 3.21-.908 4.982-.908h11.292c1.77 0 3.431.303 4.981.908 1.522.604 2.85 1.41 3.986 2.418l-12.26 16.303v-2.898a1.96 1.96 0 0 0-.665-1.512c-.443-.403-.996-.604-1.66-.604-.665 0-1.218.201-1.661.604a1.96 1.96 0 0 0-.664 1.512v9.071L44.364 77.606a10.556 10.556 0 0 1-.886-1.512zm35.73-4.535c0 1.613-.332 3.124-.997 4.535a11.66 11.66 0 0 1-2.712 3.68c-1.134 1.032-2.49 1.864-4.04 2.469-1.55.604-3.21.907-4.982.907H55.185c-1.77 0-3.431-.303-4.981-.907-1.55-.605-2.906-1.437-4.041-2.47a12.49 12.49 0 0 1-1.384-1.512l13.727-18.217v6.375c0 .605.222 1.109.665 1.512.442.403.996.604 1.66.604.664 0 1.218-.201 1.66-.604a1.96 1.96 0 0 0 .665-1.512V53.87L75.97 36.838c.913.932 1.66 1.99 2.214 3.175.664 1.41.996 2.922.996 4.535v27.011h.028z"/></svg>

+ 9 - 0
yushu-uivue3/src/assets/icons/svg/ai-assistant.svg

@@ -0,0 +1,9 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
+  <path d="M12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM12 20C7.59 20 4 16.41 4 12C4 7.59 7.59 4 12 4C16.41 4 20 7.59 20 12C20 16.41 16.41 20 12 20Z" fill="currentColor"/>
+  <path d="M9 13.5C9.82843 13.5 10.5 12.8284 10.5 12C10.5 11.1716 9.82843 10.5 9 10.5C8.17157 10.5 7.5 11.1716 7.5 12C7.5 12.8284 8.17157 13.5 9 13.5Z" fill="currentColor"/>
+  <path d="M15 13.5C15.8284 13.5 16.5 12.8284 16.5 12C16.5 11.1716 15.8284 10.5 15 10.5C14.1716 10.5 13.5 11.1716 13.5 12C13.5 12.8284 14.1716 13.5 15 13.5Z" fill="currentColor"/>
+  <path d="M12 18C14.28 18 16.22 16.34 17 14H7C7.78 16.34 9.72 18 12 18Z" fill="currentColor"/>
+  <path d="M7 8L10 9.5L7 11V8Z" fill="currentColor"/>
+  <path d="M17 8L14 9.5L17 11V8Z" fill="currentColor"/>
+</svg>

Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/aislogo.svg


+ 10 - 0
yushu-uivue3/src/assets/icons/svg/aliyun-email.svg

@@ -0,0 +1,10 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
+  <!-- 信封基础形状 -->
+  <path d="M20 4H4C2.9 4 2.01 4.9 2.01 6L2 18C2 19.1 2.9 20 4 20H20C21.1 20 22 19.1 22 18V6C22 4.9 21.1 4 20 4ZM20 18H4V8L12 13L20 8V18ZM12 11L4 6H20L12 11Z" fill="currentColor"/>
+  
+  <!-- 阿里云标志 - 简化版 -->
+  <path d="M12 15.5C10.07 15.5 8.5 13.93 8.5 12C8.5 10.07 10.07 8.5 12 8.5C13.93 8.5 15.5 10.07 15.5 12C15.5 13.93 13.93 15.5 12 15.5Z" fill="currentColor"/>
+  <path d="M7 9L9 12L7 15" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
+  <path d="M17 9L15 12L17 15" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
+</svg>

+ 13 - 0
yushu-uivue3/src/assets/icons/svg/api-service.svg

@@ -0,0 +1,13 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
+  <!-- 代码符号 - API -->
+  <path d="M9.4 16.6L4.8 12L9.4 7.4L8 6L2 12L8 18L9.4 16.6Z" fill="currentColor"/>
+  <path d="M14.6 16.6L19.2 12L14.6 7.4L16 6L22 12L16 18L14.6 16.6Z" fill="currentColor"/>
+  
+  <!-- 中间连接点 - 服务 -->
+  <path d="M12 19.5C13.3807 19.5 14.5 18.3807 14.5 17C14.5 15.6193 13.3807 14.5 12 14.5C10.6193 14.5 9.5 15.6193 9.5 17C9.5 18.3807 10.6193 19.5 12 19.5Z" fill="currentColor"/>
+  <path d="M12 9.5C13.3807 9.5 14.5 8.38071 14.5 7C14.5 5.61929 13.3807 4.5 12 4.5C10.6193 4.5 9.5 5.61929 9.5 7C9.5 8.38071 10.6193 9.5 12 9.5Z" fill="currentColor"/>
+  
+  <!-- 连接线 -->
+  <path d="M12 10V14" stroke="currentColor" stroke-width="2" stroke-linecap="round"/>
+</svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/bug.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M127.88 73.143c0 1.412-.506 2.635-1.518 3.669-1.011 1.033-2.209 1.55-3.592 1.55h-17.887c0 9.296-1.783 17.178-5.35 23.645l16.609 17.044c1.011 1.034 1.517 2.257 1.517 3.67 0 1.412-.506 2.635-1.517 3.668-.958 1.033-2.155 1.55-3.593 1.55-1.438 0-2.635-.517-3.593-1.55l-15.811-16.063a15.49 15.49 0 0 1-1.196 1.06c-.532.434-1.65 1.208-3.353 2.322a50.104 50.104 0 0 1-5.192 2.974c-1.758.87-3.94 1.658-6.546 2.364-2.607.706-5.189 1.06-7.748 1.06V47.044H58.89v73.062c-2.716 0-5.417-.367-8.106-1.102-2.688-.734-5.003-1.631-6.945-2.692a66.769 66.769 0 0 1-5.268-3.179c-1.571-1.057-2.73-1.94-3.476-2.65L33.9 109.34l-14.611 16.877c-1.066 1.14-2.344 1.711-3.833 1.711-1.277 0-2.422-.434-3.434-1.304-1.012-.978-1.557-2.187-1.635-3.627-.079-1.44.333-2.705 1.236-3.794l16.129-18.51c-3.087-6.197-4.63-13.644-4.63-22.342H5.235c-1.383 0-2.58-.517-3.592-1.55S.125 74.545.125 73.132c0-1.412.506-2.635 1.518-3.668 1.012-1.034 2.21-1.55 3.592-1.55h17.887V43.939L9.308 29.833c-1.012-1.033-1.517-2.256-1.517-3.669 0-1.412.505-2.635 1.517-3.668 1.012-1.034 2.21-1.55 3.593-1.55s2.58.516 3.593 1.55l13.813 14.106h67.396l13.814-14.106c1.012-1.034 2.21-1.55 3.592-1.55 1.384 0 2.581.516 3.593 1.55 1.012 1.033 1.518 2.256 1.518 3.668 0 1.413-.506 2.636-1.518 3.67l-13.814 14.105v23.975h17.887c1.383 0 2.58.516 3.593 1.55 1.011 1.033 1.517 2.256 1.517 3.668l-.005.01zM89.552 26.175H38.448c0-7.23 2.489-13.386 7.466-18.469C50.892 2.623 56.92.082 64 .082c7.08 0 13.108 2.541 18.086 7.624 4.977 5.083 7.466 11.24 7.466 18.469z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/build.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1568899741379" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2054" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M960 591.424V368.96c0-0.288 0.16-0.512 0.16-0.768S960 367.68 960 367.424V192a32 32 0 0 0-32-32H96a32 32 0 0 0-32 32v175.424c0 0.288-0.16 0.512-0.16 0.768s0.16 0.48 0.16 0.768v222.464c0 0.288-0.16 0.512-0.16 0.768s0.16 0.48 0.16 0.768V864a32 32 0 0 0 32 32h832a32 32 0 0 0 32-32v-271.04c0-0.288 0.16-0.512 0.16-0.768S960 591.68 960 591.424z m-560-31.232v-160H608v160h-208z m208 64V832h-208v-207.808H608z m-480-224h208v160H128v-160z m544 0h224v160h-224v-160zM896 224v112.192H128V224h768zM128 624.192h208V832H128v-207.808zM672 832v-207.808h224V832h-224z" p-id="2055"></path></svg>

Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/button.svg


Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/cascader.svg


+ 1 - 0
yushu-uivue3/src/assets/icons/svg/chart.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M0 54.857h36.571V128H0V54.857zM91.429 27.43H128V128H91.429V27.429zM45.714 0h36.572v128H45.714V0z"/></svg>

+ 7 - 0
yushu-uivue3/src/assets/icons/svg/chat-bubble.svg

@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
+  <path d="M20 2H4C2.9 2 2.01 2.9 2.01 4L2 22L6 18H20C21.1 18 22 17.1 22 16V4C22 2.9 21.1 2 20 2ZM20 16H5.17L4.58 16.59L4 17.17V4H20V16Z" fill="currentColor"/>
+  <path d="M7 9H17V11H7V9Z" fill="currentColor"/>
+  <path d="M7 12H14V14H7V12Z" fill="currentColor"/>
+  <path d="M7 6H17V8H7V6Z" fill="currentColor"/>
+</svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/checkbox.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1575982282951" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="902" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M828.40625 90.125H195.59375C137.375 90.125 90.125 137.375 90.125 195.59375v632.8125c0 58.21875 47.25 105.46875 105.46875 105.46875h632.8125c58.21875 0 105.46875-47.25 105.46875-105.46875V195.59375c0-58.21875-47.25-105.46875-105.46875-105.46875z m52.734375 738.28125c0 29.16-23.57015625 52.734375-52.734375 52.734375H195.59375c-29.109375 0-52.734375-23.574375-52.734375-52.734375V195.59375c0-29.109375 23.625-52.734375 52.734375-52.734375h632.8125c29.16 0 52.734375 23.625 52.734375 52.734375v632.8125z" p-id="903"></path><path d="M421.52890625 709.55984375a36.28125 36.28125 0 0 1-27.55265625-12.66890625L205.17453125 476.613125a36.28546875 36.28546875 0 0 1 55.10109375-47.22890625l164.986875 192.4846875 342.16171875-298.48078125a36.2896875 36.2896875 0 0 1 47.70984375 54.68765625L445.3859375 700.6203125a36.3234375 36.3234375 0 0 1-23.85703125 8.93953125z" p-id="904"></path></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/clipboard.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M54.857 118.857h64V73.143H89.143c-1.902 0-3.52-.668-4.855-2.002-1.335-1.335-2.002-2.954-2.002-4.855V36.57H54.857v82.286zM73.143 16v-4.571a2.2 2.2 0 0 0-.677-1.61 2.198 2.198 0 0 0-1.609-.676H20.571c-.621 0-1.158.225-1.609.676a2.198 2.198 0 0 0-.676 1.61V16a2.2 2.2 0 0 0 .676 1.61c.451.45.988.676 1.61.676h50.285c.622 0 1.158-.226 1.61-.677.45-.45.676-.987.676-1.609zm18.286 48h21.357L91.43 42.642V64zM128 73.143v48c0 1.902-.667 3.52-2.002 4.855-1.335 1.335-2.953 2.002-4.855 2.002H52.57c-1.901 0-3.52-.667-4.854-2.002-1.335-1.335-2.003-2.953-2.003-4.855v-11.429H6.857c-1.902 0-3.52-.667-4.855-2.002C.667 106.377 0 104.759 0 102.857v-96c0-1.902.667-3.52 2.002-4.855C3.337.667 4.955 0 6.857 0h77.714c1.902 0 3.52.667 4.855 2.002 1.335 1.335 2.003 2.953 2.003 4.855V30.29c1 .622 1.856 1.29 2.569 2.003l29.147 29.147c1.335 1.335 2.478 3.145 3.429 5.43.95 2.287 1.426 4.383 1.426 6.291v-.018z"/></svg>

+ 5 - 0
yushu-uivue3/src/assets/icons/svg/cloud-service.svg

@@ -0,0 +1,5 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
+  <path d="M19.35 10.04C18.67 6.59 15.64 4 12 4C9.11 4 6.6 5.64 5.35 8.04C2.34 8.36 0 10.91 0 14C0 17.31 2.69 20 6 20H19C21.76 20 24 17.76 24 15C24 12.36 21.95 10.22 19.35 10.04ZM19 18H6C3.79 18 2 16.21 2 14C2 11.95 3.53 10.24 5.56 10.03L6.63 9.92L7.13 8.97C8.08 7.14 9.94 6 12 6C14.62 6 16.88 7.86 17.39 10.43L17.69 11.93L19.22 12.04C20.78 12.14 22 13.45 22 15C22 16.65 20.65 18 19 18Z" fill="currentColor"/>
+  <path d="M10 17L15 12L10 7V17Z" fill="currentColor"/>
+</svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/code.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1546567861908" class="icon" style="" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2422" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M318.577778 819.2L17.066667 512l301.511111-307.2 45.511111 45.511111L96.711111 512l267.377778 261.688889zM705.422222 819.2l-45.511111-45.511111L927.288889 512l-267.377778-261.688889 45.511111-45.511111L1006.933333 512zM540.785778 221.866667l55.751111 11.150222L483.157333 802.133333l-55.751111-11.093333z" p-id="2423"></path></svg>

Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/color.svg


Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/component.svg


Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/dashboard.svg


+ 5 - 0
yushu-uivue3/src/assets/icons/svg/data-analysis.svg

@@ -0,0 +1,5 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
+  <path d="M5 9.2H8V19H5V9.2ZM10.6 5H13.4V19H10.6V5ZM16.2 13H19V19H16.2V13Z" fill="currentColor"/>
+  <path d="M19 3H5C3.9 3 3 3.9 3 5V19C3 20.1 3.9 21 5 21H19C20.1 21 21 20.1 21 19V5C21 3.9 20.1 3 19 3ZM19 19H5V5H19V19Z" fill="currentColor"/>
+</svg>

Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/date-range.svg


Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/date.svg


Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/dict.svg


+ 1 - 0
yushu-uivue3/src/assets/icons/svg/documentation.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M71.984 44.815H115.9L71.984 9.642v35.173zM16.094.05h63.875l47.906 38.37v76.74c0 3.392-1.682 6.645-4.677 9.044-2.995 2.399-7.056 3.746-11.292 3.746H16.094c-4.236 0-8.297-1.347-11.292-3.746-2.995-2.399-4.677-5.652-4.677-9.044V12.84C.125 5.742 7.23.05 16.094.05zm71.86 102.32V89.58h-71.86v12.79h71.86zm23.952-25.58V64H16.094v12.79h95.812z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/download.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1569915748289" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="3062" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M768.35456 416a256 256 0 1 0-512 0 192 192 0 1 0 0 384v64a256 256 0 0 1-58.88-505.216 320.128 320.128 0 0 1 629.76 0A256.128 256.128 0 0 1 768.35456 864v-64a192 192 0 0 0 0-384z m-512 384h64v64H256.35456v-64z m448 0h64v64h-64v-64z" fill="#333333" p-id="3063"></path><path d="M539.04256 845.248V512.192a32.448 32.448 0 0 0-32-32.192c-17.664 0-32 14.912-32 32.192v333.056l-36.096-36.096a32.192 32.192 0 0 0-45.056 0.192 31.616 31.616 0 0 0-0.192 45.056l90.88 90.944a31.36 31.36 0 0 0 22.528 9.088 30.08 30.08 0 0 0 22.4-9.088l90.88-90.88a32.192 32.192 0 0 0-0.192-45.12 31.616 31.616 0 0 0-45.056-0.192l-36.096 36.096z" fill="#333333" p-id="3064"></path></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/drag.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M73.137 29.08h-9.209 29.7L63.886.093 34.373 29.08h20.49v27.035H27.238v17.948h27.625v27.133h18.274V74.063h27.41V56.115h-27.41V29.08zm-9.245 98.827l27.518-26.711H36.59l27.302 26.71zM.042 64.982l27.196 27.029V38.167L.042 64.982zm100.505-26.815V92.01l27.41-27.029-27.41-26.815z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/druid.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1566036347051" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5853" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M832 128H192a64.19 64.19 0 0 0-64 64v640a64.19 64.19 0 0 0 64 64h640a64.19 64.19 0 0 0 64-64V192a64.19 64.19 0 0 0-64-64z m0 703.89l-0.11 0.11H192.11l-0.11-0.11V768h640zM832 544H720L605.6 696.54 442.18 435.07 333.25 544H192v-64h114.75l147.07-147.07L610.4 583.46 688 480h144z m0-288H192v-63.89l0.11-0.11h639.78l0.11 0.11z" p-id="5854"></path></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/edit.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M106.133 67.2a4.797 4.797 0 0 0-4.8 4.8c0 .187.014.36.027.533h-.027V118.4H9.6V26.667h50.133c2.654 0 4.8-2.147 4.8-4.8 0-2.654-2.146-4.8-4.8-4.8H9.6a9.594 9.594 0 0 0-9.6 9.6V118.4c0 5.307 4.293 9.6 9.6 9.6h91.733c5.307 0 9.6-4.293 9.6-9.6V72.533h-.026c.013-.173.026-.346.026-.533 0-2.653-2.146-4.8-4.8-4.8z"/><path d="M125.16 13.373L114.587 2.8c-3.747-3.747-9.854-3.72-13.6.027l-52.96 52.96a4.264 4.264 0 0 0-.907 1.36L33.813 88.533c-.746 1.76-.226 3.534.907 4.68 1.133 1.147 2.92 1.667 4.693.92l31.4-13.293c.507-.213.96-.52 1.36-.907l52.96-52.96c3.747-3.746 3.774-9.853.027-13.6zM66.107 72.4l-18.32 7.76 7.76-18.32L92.72 24.667l10.56 10.56L66.107 72.4zm52.226-52.227l-8.266 8.267-10.56-10.56 8.266-8.267.027-.026 10.56 10.56-.027.026z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/education.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M88.883 119.565c-7.284 0-19.434 2.495-21.333 8.25v.127c-4.232.13-5.222 0-7.108 0-1.895-5.76-14.045-8.256-21.333-8.256H0V0h42.523c9.179 0 17.109 5.47 21.47 13.551C68.352 5.475 76.295 0 85.478 0H128v119.57l-39.113-.005h-.004zM60.442 24.763c0-9.651-8.978-16.507-17.777-16.507H7.108V111.43H39.11c7.054-.14 18.177.082 21.333 6.12v-4.628c-.134-5.722-.004-13.522 0-13.832V27.413l.004-2.655-.004.005zm60.442-16.517h-35.55c-8.802 0-17.78 6.856-17.78 16.493v74.259c.004.32.138 8.115 0 13.813v4.627c3.155-6.022 14.279-6.26 21.333-6.114h32V8.25l-.003-.005z"/></svg>

+ 5 - 0
yushu-uivue3/src/assets/icons/svg/email-service.svg

@@ -0,0 +1,5 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
+  <path d="M20 4H4C2.9 4 2.01 4.9 2.01 6L2 18C2 19.1 2.9 20 4 20H20C21.1 20 22 19.1 22 18V6C22 4.9 21.1 4 20 4ZM20 18H4V8L12 13L20 8V18ZM12 11L4 6H20L12 11Z" fill="currentColor"/>
+  <path d="M12 15L15 13L20 16V18H4V16L9 13L12 15Z" fill="currentColor"/>
+</svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/email.svg

@@ -0,0 +1 @@
+<svg width="128" height="96" xmlns="http://www.w3.org/2000/svg"><path d="M64.125 56.975L120.188.912A12.476 12.476 0 0 0 115.5 0h-103c-1.588 0-3.113.3-4.513.838l56.138 56.137z"/><path d="M64.125 68.287l-62.3-62.3A12.42 12.42 0 0 0 0 12.5v71C0 90.4 5.6 96 12.5 96h103c6.9 0 12.5-5.6 12.5-12.5v-71a12.47 12.47 0 0 0-1.737-6.35L64.125 68.287z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/enter.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1746590936918" class="icon" viewBox="0 0 1194 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5378" xmlns:xlink="http://www.w3.org/1999/xlink" width="233.203125" height="200"><path d="M1151.9144 325.11999969V89.12a57.04000031 57.04000031 0 0 0-28.8-49.44 58.15999969 58.15999969 0 0 0-57.76000031 0 57.04000031 57.04000031 0 0 0-28.8 49.44v235.99999969c0.24 84.31999969-33.6 152.56000031-94.08 212.00000062-60.07999969 59.83999969-141.84 80.64-227.04 80.4H225.91440031L388.07439969 457.11999969a56.80000031 56.80000031 0 0 0 12.40000031-62.16 57.76000031 57.76000031 0 0 0-94.00000031-18.63999938L48.8744 631.20000031a56.88 56.88 0 0 0 0 80.79999938l264.96 262.56a58.08 58.08 0 0 0 96.55999969-25.59999938 56.80000031 56.80000031 0 0 0-14.95999969-55.2L232.07439969 731.67999969h483.44000062c116.56000031 0 226.15999969-32.08000031 308.64-113.76 82.15999969-80.80000031 128.23999969-178.15999969 127.83999938-292.87999969" p-id="5379"></path></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/example.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M96.258 57.462h31.421C124.794 27.323 100.426 2.956 70.287.07v31.422a32.856 32.856 0 0 1 25.971 25.97zm-38.796-25.97V.07C27.323 2.956 2.956 27.323.07 57.462h31.422a32.856 32.856 0 0 1 25.97-25.97zm12.825 64.766v31.421c30.46-2.885 54.507-27.253 57.713-57.712H96.579c-2.886 13.466-13.146 23.726-26.292 26.291zM31.492 70.287H.07c2.886 30.46 27.253 54.507 57.713 57.713V96.579c-13.466-2.886-23.726-13.146-26.291-26.292z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/excel.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M78.208 16.576v8.384h38.72v5.376h-38.72v8.704h38.72v5.376h-38.72v8.576h38.72v5.376h-38.72v8.576h38.72v5.376h-38.72v8.576h38.72v5.376h-38.72v8.512h38.72v5.376h-38.72v11.136H128v-94.72H78.208zM0 114.368L72.128 128V0L0 13.632v100.736z"/><path d="M28.672 82.56h-11.2l14.784-23.488-14.08-22.592h11.52l8.192 14.976 8.448-14.976h11.136l-14.08 22.208L58.368 82.56H46.656l-8.768-15.68z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/exit-fullscreen.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M49.217 41.329l-.136-35.24c-.06-2.715-2.302-4.345-5.022-4.405h-3.65c-2.712-.06-4.866 2.303-4.806 5.016l.152 19.164-24.151-23.79a6.698 6.698 0 0 0-9.499 0 6.76 6.76 0 0 0 0 9.526l23.93 23.713-18.345.074c-2.712-.069-5.228 1.813-5.64 5.02v3.462c.069 2.721 2.31 4.97 5.022 5.03l35.028-.207c.052.005.087.025.133.025l2.457.054a4.626 4.626 0 0 0 3.436-1.38c.88-.874 1.205-2.096 1.169-3.462l-.262-2.465c0-.048.182-.081.182-.136h.002zm52.523 51.212l18.32-.073c2.713.06 5.224-1.609 5.64-4.815v-3.462c-.068-2.722-2.317-4.97-5.021-5.04l-34.58.21c-.053 0-.086-.021-.138-.021l-2.451-.06a4.64 4.64 0 0 0-3.445 1.381c-.885.868-1.201 2.094-1.174 3.46l.27 2.46c.005.06-.177.095-.177.141l.141 34.697c.069 2.713 2.31 4.338 5.022 4.397l3.45.006c2.705.062 4.867-2.31 4.8-5.026l-.153-18.752 24.151 23.946a6.69 6.69 0 0 0 9.494 0 6.747 6.747 0 0 0 0-9.523L101.74 92.54v.001zM48.125 80.662a4.636 4.636 0 0 0-3.437-1.382l-2.457.06c-.05 0-.082.022-.137.022l-35.025-.21c-2.712.07-4.957 2.318-5.022 5.04v3.462c.409 3.206 2.925 4.874 5.633 4.814l18.554.06-24.132 23.928c-2.62 2.626-2.62 6.89 0 9.524a6.694 6.694 0 0 0 9.496 0l24.155-23.79-.155 18.866c-.06 2.722 2.094 5.093 4.801 5.025h3.65c2.72-.069 4.962-1.685 5.022-4.406l.141-34.956c0-.05-.182-.082-.182-.136l.262-2.46c.03-1.366-.286-2.592-1.166-3.46h-.001zM80.08 47.397a4.62 4.62 0 0 0 3.443 1.374l2.45-.054c.055 0 .088-.02.143-.028l35.08.21c2.712-.062 4.953-2.312 5.021-5.033l.009-3.463c-.417-3.211-2.937-5.084-5.64-5.025l-18.615-.073 23.917-23.715c2.63-2.623 2.63-6.879.008-9.513a6.691 6.691 0 0 0-9.494 0L92.251 26.016l.155-19.312c.065-2.713-2.097-5.085-4.802-5.025h-3.45c-2.713.069-4.954 1.693-5.022 4.406l-.139 35.247c0 .054.18.088.18.136l-.267 2.465c-.028 1.366.288 2.588 1.174 3.463v.001z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/eye-open.svg

@@ -0,0 +1 @@
+<svg class="icon" viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="128" height="128"><defs><style/></defs><path d="M512 128q69.675 0 135.51 21.163t115.498 54.997 93.483 74.837 73.685 82.006 51.67 74.837 32.17 54.827L1024 512q-2.347 4.992-6.315 13.483T998.87 560.17t-31.658 51.669-44.331 59.99-56.832 64.34-69.504 60.16-82.347 51.5-94.848 34.687T512 896q-69.675 0-135.51-21.163t-115.498-54.826-93.483-74.326-73.685-81.493-51.67-74.496-32.17-54.997L0 513.707q2.347-4.992 6.315-13.483t18.816-34.816 31.658-51.84 44.331-60.33 56.832-64.683 69.504-60.331 82.347-51.84 94.848-34.816T512 128.085zm0 85.333q-46.677 0-91.648 12.331t-81.152 31.83-70.656 47.146-59.648 54.485-48.853 57.686-37.675 52.821-26.325 43.99q12.33 21.674 26.325 43.52t37.675 52.351 48.853 57.003 59.648 53.845T339.2 767.02t81.152 31.488T512 810.667t91.648-12.331 81.152-31.659 70.656-46.848 59.648-54.186 48.853-57.344 37.675-52.651T927.957 512q-12.33-21.675-26.325-43.648t-37.675-52.65-48.853-57.345-59.648-54.186-70.656-46.848-81.152-31.659T512 213.334zm0 128q70.656 0 120.661 50.006T682.667 512 632.66 632.661 512 682.667 391.339 632.66 341.333 512t50.006-120.661T512 341.333zm0 85.334q-35.328 0-60.33 25.002T426.666 512t25.002 60.33T512 597.334t60.33-25.002T597.334 512t-25.002-60.33T512 426.666z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/eye.svg

@@ -0,0 +1 @@
+<svg width="128" height="64" xmlns="http://www.w3.org/2000/svg"><path d="M127.072 7.994c1.37-2.208.914-5.152-.914-6.87-2.056-1.717-4.797-1.226-6.396.982-.229.245-25.586 32.382-55.74 32.382-29.24 0-55.74-32.382-55.968-32.627-1.6-1.963-4.57-2.208-6.397-.49C-.17 3.086-.399 6.275 1.2 8.238c.457.736 5.94 7.36 14.62 14.72L4.17 35.96c-1.828 1.963-1.6 5.152.228 6.87.457.98 1.6 1.471 2.742 1.471s2.284-.49 3.198-1.472l12.564-13.983c5.94 4.416 13.021 8.587 20.788 11.53l-4.797 17.418c-.685 2.699.686 5.397 3.198 6.133h1.37c2.057 0 3.884-1.472 4.341-3.68L52.6 42.83c3.655.736 7.538 1.227 11.422 1.227 3.883 0 7.767-.49 11.422-1.227l4.797 17.173c.457 2.208 2.513 3.68 4.34 3.68.457 0 .914 0 1.143-.246 2.513-.736 3.883-3.434 3.198-6.133l-4.797-17.172c7.767-2.944 14.848-7.114 20.788-11.53l12.336 13.738c.913.981 2.056 1.472 3.198 1.472s2.284-.49 3.198-1.472c1.828-1.963 1.828-4.906.228-6.87l-11.65-13.001c9.366-7.36 14.849-14.474 14.849-14.474z"/></svg>

Những thai đổi đã bị hủy bỏ vì nó quá lớn
+ 0 - 0
yushu-uivue3/src/assets/icons/svg/form.svg


+ 1 - 0
yushu-uivue3/src/assets/icons/svg/fullscreen.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M38.47 52L52 38.462l-23.648-23.67L43.209 0H.035L0 43.137l14.757-14.865L38.47 52zm74.773 47.726L89.526 76 76 89.536l23.648 23.672L84.795 128h43.174L128 84.863l-14.757 14.863zM89.538 52l23.668-23.648L128 43.207V.038L84.866 0 99.73 14.76 76 38.472 89.538 52zM38.46 76L14.792 99.651 0 84.794v43.173l43.137.033-14.865-14.757L52 89.53 38.46 76z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/github.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1581238998885" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4187" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M511.542857 14.057143C228.914286 13.942857 0 242.742857 0 525.142857 0 748.457143 143.2 938.285714 342.628571 1008c26.857143 6.742857 22.742857-12.342857 22.742858-25.371429v-88.571428c-155.085714 18.171429-161.371429-84.457143-171.771429-101.6C172.571429 756.571429 122.857143 747.428571 137.714286 730.285714c35.314286-18.171429 71.314286 4.571429 113.028571 66.171429 30.171429 44.685714 89.028571 37.142857 118.857143 29.714286 6.514286-26.857143 20.457143-50.857143 39.657143-69.485715-160.685714-28.8-227.657143-126.857143-227.657143-243.428571 0-56.571429 18.628571-108.571429 55.2-150.514286-23.314286-69.142857 2.171429-128.342857 5.6-137.142857 66.4-5.942857 135.428571 47.542857 140.8 51.771429 37.714286-10.171429 80.8-15.542857 129.028571-15.542858 48.457143 0 91.657143 5.6 129.714286 15.885715 12.914286-9.828571 76.914286-55.771429 138.628572-50.171429 3.314286 8.8 28.228571 66.628571 6.285714 134.857143 37.028571 42.057143 55.885714 94.514286 55.885714 151.2 0 116.8-67.428571 214.971429-228.571428 243.314286a145.714286 145.714286 0 0 1 43.542857 104v128.571428c0.914286 10.285714 0 20.457143 17.142857 20.457143 202.4-68.228571 348.114286-259.428571 348.114286-484.685714 0-282.514286-229.028571-511.2-511.428572-511.2z" p-id="4188"></path></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/guide.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M1.482 70.131l36.204 16.18 69.932-65.485-61.38 70.594 46.435 18.735c1.119.425 2.397-.17 2.797-1.363v-.085L127.998.047 1.322 65.874c-1.12.597-1.519 1.959-1.04 3.151.32.511.72.937 1.2 1.107zm44.676 57.821L64.22 107.26l-18.062-7.834v28.527z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/icon.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M115.147.062a13 13 0 0 1 4.94.945c1.55.63 2.907 1.526 4.069 2.688a13.148 13.148 0 0 1 2.761 4.069c.678 1.55 1.017 3.245 1.017 5.086v102.3c0 3.681-1.187 6.733-3.56 9.155-2.373 2.422-5.352 3.633-8.937 3.633H12.992c-3.875 0-7-1.26-9.373-3.779-2.373-2.518-3.56-5.667-3.56-9.445V12.704c0-3.39 1.163-6.345 3.488-8.863C5.872 1.32 8.972.062 12.847.062h102.3zM81.434 109.047c1.744 0 3.003-.412 3.778-1.235.775-.824 1.163-1.914 1.163-3.27 0-1.26-.388-2.325-1.163-3.197-.775-.872-2.034-1.307-3.778-1.307H72.57c.097-.194.145-.485.145-.872V27.09h9.01c1.743 0 2.954-.436 3.633-1.308.678-.872 1.017-1.938 1.017-3.197 0-1.26-.34-2.325-1.017-3.197-.679-.872-1.89-1.308-3.633-1.308H46.268c-1.743 0-2.954.436-3.632 1.308-.678.872-1.018 1.938-1.018 3.197 0 1.26.34 2.325 1.018 3.197.678.872 1.889 1.308 3.632 1.308h8.138v72.075c0 .193.024.339.073.436.048.096.072.242.072.436H46.56c-1.744 0-3.003.435-3.778 1.307-.775.872-1.163 1.938-1.163 3.197 0 1.356.388 2.446 1.163 3.27.775.823 2.034 1.235 3.778 1.235h34.875z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/input.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1575802859706" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="3102" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M896 224H128c-35.2 0-64 28.8-64 64v448c0 35.2 28.8 64 64 64h768c35.2 0 64-28.8 64-64V288c0-35.2-28.8-64-64-64z m0 480c0 19.2-12.8 32-32 32H160c-19.2 0-32-12.8-32-32V320c0-19.2 12.8-32 32-32h704c19.2 0 32 12.8 32 32v384z" p-id="3103"></path><path d="M224 352c-19.2 0-32 12.8-32 32v256c0 16 12.8 32 32 32s32-12.8 32-32V384c0-16-12.8-32-32-32z" p-id="3104"></path></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/international.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M83.287 103.01c-1.57-3.84-6.778-10.414-15.447-19.548-2.327-2.444-2.182-4.306-1.338-9.862v-.64c.553-3.81 1.513-6.05 14.313-8.087 6.516-1.018 8.203 1.57 10.589 5.178l.785 1.193a12.625 12.625 0 0 0 6.43 5.207c1.134.524 2.53 1.164 4.421 2.24 4.596 2.53 4.596 5.41 4.596 11.753v.727a26.91 26.91 0 0 1-5.178 17.454 59.055 59.055 0 0 1-19.025 11.026c3.49-6.546.814-14.313 0-16.553l-.146-.087zM64 5.12a58.502 58.502 0 0 1 25.484 5.818 54.313 54.313 0 0 0-12.859 10.327c-.93 1.28-1.716 2.473-2.472 3.579-2.444 3.694-3.637 5.352-5.818 5.614a25.105 25.105 0 0 1-4.219 0c-4.276-.29-10.094-.64-11.956 4.422-1.193 3.23-1.396 11.956 2.444 16.495.66 1.077.778 2.4.32 3.578a7.01 7.01 0 0 1-2.066 3.229 18.938 18.938 0 0 1-2.909-2.91 18.91 18.91 0 0 0-8.32-6.603c-1.25-.349-2.647-.64-3.985-.93-3.782-.786-8.03-1.688-9.019-3.812a14.895 14.895 0 0 1-.727-5.818 21.935 21.935 0 0 0-1.396-9.25 8.873 8.873 0 0 0-5.557-4.946A58.705 58.705 0 0 1 64 5.12zM0 64c0 35.346 28.654 64 64 64 35.346 0 64-28.654 64-64 0-35.346-28.654-64-64-64C28.654 0 0 28.654 0 64z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/job.svg

@@ -0,0 +1 @@
+<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1566036191400" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5472" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M934.912 1016.832H192c-14.336 0-25.6-11.264-25.6-25.6v-189.44c0-14.336 11.264-25.6 25.6-25.6s25.6 11.264 25.6 25.6v163.84h691.712V64H217.6v148.48c0 14.336-11.264 25.6-25.6 25.6s-25.6-11.264-25.6-25.6v-174.08c0-14.336 11.264-25.6 25.6-25.6h742.912c14.336 0 25.6 11.264 25.6 25.6v952.832c0 14.336-11.264 25.6-25.6 25.6z" p-id="5473"></path><path d="M232.96 371.2h-117.76c-14.336 0-25.6-11.264-25.6-25.6s11.264-25.6 25.6-25.6h117.76c14.336 0 25.6 11.264 25.6 25.6s-11.264 25.6-25.6 25.6zM232.96 540.16h-117.76c-14.336 0-25.6-11.264-25.6-25.6s11.264-25.6 25.6-25.6h117.76c14.336 0 25.6 11.264 25.6 25.6s-11.264 25.6-25.6 25.6zM232.96 698.88h-117.76c-14.336 0-25.6-11.264-25.6-25.6s11.264-25.6 25.6-25.6h117.76c14.336 0 25.6 11.264 25.6 25.6s-11.264 25.6-25.6 25.6zM574.464 762.88c-134.144 0-243.2-109.056-243.2-243.2S440.32 276.48 574.464 276.48s243.2 109.056 243.2 243.2-109.056 243.2-243.2 243.2z m0-435.2c-105.984 0-192 86.016-192 192S468.48 711.68 574.464 711.68s192-86.016 192-192S680.448 327.68 574.464 327.68z" p-id="5474"></path><path d="M663.04 545.28h-87.04c-14.336 0-25.6-11.264-25.6-25.6s11.264-25.6 25.6-25.6h87.04c14.336 0 25.6 11.264 25.6 25.6s-11.264 25.6-25.6 25.6z" p-id="5475"></path><path d="M576 545.28c-14.336 0-25.6-11.264-25.6-25.6v-87.04c0-14.336 11.264-25.6 25.6-25.6s25.6 11.264 25.6 25.6v87.04c0 14.336-11.264 25.6-25.6 25.6z" p-id="5476"></path></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/language.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M84.742 36.8c2.398 7.2 5.595 12.8 11.19 18.4 4.795-4.8 7.992-11.2 10.39-18.4h-21.58zm-52.748 40h20.78l-10.39-28-10.39 28z"/><path d="M111.916 0H16.009C7.218 0 .025 7.2.025 16v96c0 8.8 7.193 16 15.984 16h95.907c8.791 0 15.984-7.2 15.984-16V16c0-8.8-6.394-16-15.984-16zM72.754 103.2c-1.598 1.6-3.197 1.6-4.795 1.6-.8 0-2.398 0-3.197-.8-.8-.8-1.599 0-1.599-.8s-.799-1.6-1.598-3.2c-.8-1.6-.8-2.4-1.599-4l-3.196-8.8H28.797L25.6 96c-1.598 3.2-2.398 5.6-3.197 7.2-.8 1.6-2.398 1.6-4.795 1.6-1.599 0-3.197-.8-4.796-1.6-1.598-1.6-2.397-2.4-2.397-4 0-.8 0-1.6.799-3.2.8-1.6.8-2.4 1.598-4l17.583-44.8c.8-1.6.8-3.2 1.599-4.8.799-1.6 1.598-3.2 2.397-4 .8-.8 1.599-2.4 3.197-3.2 1.599-.8 3.197-.8 4.796-.8 1.598 0 3.196 0 4.795.8 1.598.8 2.398 1.6 3.197 3.2.799.8 1.598 2.4 2.397 4 .8 1.6 1.599 3.2 2.398 5.6l17.583 44c1.598 3.2 2.398 5.6 2.398 7.2-.8.8-1.599 2.4-2.398 4zM116.711 72c-8.791-3.2-15.185-7.2-20.78-12-5.594 5.6-12.787 9.6-21.579 12l-2.397-4c8.791-2.4 15.984-5.6 21.579-11.2C87.939 51.2 83.144 44 81.545 36h-7.992v-3.2h21.58c-1.6-2.4-3.198-5.6-4.796-8l2.397-.8c1.599 2.4 3.997 5.6 5.595 8.8h19.98v4h-7.992c-2.397 8-6.393 15.2-11.189 20 5.595 4.8 11.988 8.8 20.78 11.2l-3.197 4z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/link.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M115.625 127.937H.063V12.375h57.781v12.374H12.438v90.813h90.813V70.156h12.374z"/><path d="M116.426 2.821l8.753 8.753-56.734 56.734-8.753-8.745z"/><path d="M127.893 37.982h-12.375V12.375H88.706V0h39.187z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/list.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M1.585 12.087c0 6.616 3.974 11.98 8.877 11.98 4.902 0 8.877-5.364 8.877-11.98 0-6.616-3.975-11.98-8.877-11.98-4.903 0-8.877 5.364-8.877 11.98zM125.86.107H35.613c-1.268 0-2.114 1.426-2.114 2.852v18.255c0 1.712 1.057 2.853 2.114 2.853h90.247c1.268 0 2.114-1.426 2.114-2.853V2.96c0-1.711-1.057-2.852-2.114-2.852zM.106 62.86c0 6.615 3.974 11.979 8.876 11.979 4.903 0 8.877-5.364 8.877-11.98 0-6.616-3.974-11.98-8.877-11.98-4.902 0-8.876 5.364-8.876 11.98zM124.17 50.88H33.921c-1.268 0-2.114 1.425-2.114 2.851v18.256c0 1.711 1.057 2.852 2.114 2.852h90.247c1.268 0 2.114-1.426 2.114-2.852V53.73c0-1.426-.846-2.852-2.114-2.852zM.106 115.913c0 6.616 3.974 11.98 8.876 11.98 4.903 0 8.877-5.364 8.877-11.98 0-6.616-3.974-11.98-8.877-11.98-4.902 0-8.876 5.364-8.876 11.98zm124.064-11.98H33.921c-1.268 0-2.114 1.426-2.114 2.853v18.255c0 1.711 1.057 2.852 2.114 2.852h90.247c1.268 0 2.114-1.426 2.114-2.852v-18.255c0-1.427-.846-2.853-2.114-2.853z"/></svg>

+ 1 - 0
yushu-uivue3/src/assets/icons/svg/lock.svg

@@ -0,0 +1 @@
+<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M119.88 49.674h-7.987V39.52C111.893 17.738 90.45.08 63.996.08 37.543.08 16.1 17.738 16.1 39.52v10.154H8.113c-4.408 0-7.987 2.94-7.987 6.577v65.13c0 3.637 3.57 6.577 7.987 6.577H119.88c4.407 0 7.987-2.94 7.987-6.577v-65.13c-.008-3.636-3.58-6.577-7.987-6.577zm-23.953 0H32.065V39.52c0-14.524 14.301-26.295 31.931-26.295 17.63 0 31.932 11.777 31.932 26.295v10.153z"/></svg>

Một số tệp đã không được hiển thị bởi vì quá nhiều tập tin thay đổi trong này khác