commit 728f59cc83dd94bc08a620320a1c0dd38fdcde98 Author: jlzhou <12020042@qq.com> Date: Tue Aug 13 15:12:12 2024 +0800 init diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..f94929f --- /dev/null +++ b/.editorconfig @@ -0,0 +1,18 @@ +# http://editorconfig.org +root = true + +# 空格替代Tab缩进在各种编辑工具下效果一致 +[*] +indent_style = space +indent_size = 2 +charset = utf-8 +end_of_line = lf +trim_trailing_whitespace = true +insert_final_newline = true + +[*.{json,yml,yaml}] +indent_size = 2 + +[*.md] +insert_final_newline = false +trim_trailing_whitespace = false diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..7607145 --- /dev/null +++ b/.gitignore @@ -0,0 +1,57 @@ +###################################################################### +# 本地环境配置 +/logs/* +*-local.* +*.local +**/temp/* +.temp +!*.template + +###################################################################### +# Build Tools + +.gradle +/build/ +!gradle/wrapper/gradle-wrapper.jar + +target/ +!.mvn/wrapper/maven-wrapper.jar + +###################################################################### +# IDE + +### STS ### +.apt_generated +.classpath +.factorypath +.project +.settings +.springBeans + +### IntelliJ IDEA ### +.idea +*.iws +*.iml +*.ipr + + +### JRebel ### +rebel.xml + +### NetBeans ### +nbproject/private/ +build/* +nbbuild/ +nbdist/ +.nb-gradle/ + +###################################################################### +# Others +*.log +*.xml.versionsBackup +*.swp + +!*/build/*.java +!*/build/*.html +!*/build/*.xml +/.metadata/ diff --git a/README.md b/README.md new file mode 100644 index 0000000..c3193b2 --- /dev/null +++ b/README.md @@ -0,0 +1,67 @@ +# 某某系统 + +> 全局文本替换: qanything,192.168.3.205 + + + +## Git Commit message 与自动构建与发布 + +- 如果需要SpringBoot工程的自动构建与发布,在Git Commit message的后面加`-buildboot` +- 如果需要管理端前端工程的自动构建与发布,在Git Commit message的后面加`-buildadmin` +- 如果需要用户端h5工程的自动构建与发布,在Git Commit message的后面加`-buildh5` + + + +## 项目预览地址 + +- 管理后端: [https://admin.xxx.xxx.cn/](https://admin.xxx.xxx.cn/) +- 用户移动web端: [https://h5.xxx.xxx.cn/](https://h5.xxx.evolvecloud.cn/) + + + +## 开发环境 + +- [OpenJDK-17+](https://mirrors.tuna.tsinghua.edu.cn/Adoptium/17/jdk/x64/) +- [MariaDB-10+](https://mirrors.tuna.tsinghua.edu.cn/mariadb/mariadb-10.11.6/) +- [Redis-7+](https://redis.io/download/) +- [MongoDB-7+](https://www.mongodb.com/zh-cn) + + + + +## 开发工具 + +- java开发工具: [IntelliJ IDEA](https://www.jetbrains.com.cn/idea/) + +- java开发工具: **[STS4](https://spring.io/tools/) Spring官方工具** + +- 前端开发工具: [VSCode](https://code.visualstudio.com/) + +- 数据库开发工具: [Navicat-16](https://www.navicat.com.cn/navicat-16-highlights) + +- Redis工具: [RedisFront](https://gitee.com/dromara/redisfront) + +- MongoDB工具: [NoSQLBooster for MongoDB](https://www.nosqlbooster.com/) + +- MQTT工具: [emqx](https://www.emqx.io/) + + + +## 参考网站 + +### 核心 +- [Dromara开源社区](https://dromara.org/zh/) +- [RuoYi-Vue-Plu](https://plus-doc.dromara.org/) +- [MyBatis-Plus](https://www.baomidou.com/) +- [HuTool工具类](https://doc.hutool.cn/pages/index/) +- [sa-token安全认证框架](https://sa-token.cc/) +- [xxl-job分布式任务调度平台](https://www.xuxueli.com/xxl-job/) +- [Redisson](https://redisson.org/) +- [WxJava微信开发工具包](https://gitee.com/binary/weixin-java-tools/) + +### 备选 +- [sms4j短信集成库](https://gitee.com/dromara/sms4j) +- [x-file-storage文件存储库](https://x-file-storage.xuyanwu.cn/) +- [payment-spring-boot集成支付](https://felord.gitee.io/payment-spring-boot) +- [JustAuth第三方登录集成库](https://www.justauth.cn/) + diff --git a/admin-ui/.env b/admin-ui/.env new file mode 100644 index 0000000..bc8256e --- /dev/null +++ b/admin-ui/.env @@ -0,0 +1,6 @@ +# 页面标题 +VITE_APP_TITLE = 某某系统 + +VITE_APP_COPY = Copyright © 2023 xxx.xxx.cn All Rights Reserved. + +VITE_APP_COLOR = #257fbd \ No newline at end of file diff --git a/admin-ui/.env.development b/admin-ui/.env.development new file mode 100644 index 0000000..9194ea6 --- /dev/null +++ b/admin-ui/.env.development @@ -0,0 +1,14 @@ +# 开发环境配置 +VITE_APP_ENV = 'development' + +# 若依管理系统/开发环境 +VITE_APP_BASE_API = '/dev-api' + +# 应用访问路径 例如使用前缀 /admin/ +VITE_APP_CONTEXT_PATH = '/' + +# 监控地址 +VITE_APP_MONITRO_ADMIN = 'http://localhost:9090/admin/login' + +# xxl-job 控制台地址 +VITE_APP_XXL_JOB_ADMIN = 'http://localhost:9100/xxl-job-admin' diff --git a/admin-ui/.env.production b/admin-ui/.env.production new file mode 100644 index 0000000..04ddb12 --- /dev/null +++ b/admin-ui/.env.production @@ -0,0 +1,17 @@ +# 生产环境配置 +VITE_APP_ENV = 'production' + +# 应用访问路径 例如使用前缀 /admin/ +VITE_APP_CONTEXT_PATH = '/admin/' + +# 监控地址 +VITE_APP_MONITRO_ADMIN = '/monitor/login' + +# 监控地址 +VITE_APP_XXL_JOB_ADMIN = '/xxljob/' + +# 若依管理系统/生产环境 +VITE_APP_BASE_API = '/api' + +# 是否在打包时开启压缩,支持 gzip 和 brotli +VITE_BUILD_COMPRESS = gzip \ No newline at end of file diff --git a/admin-ui/.gitignore b/admin-ui/.gitignore new file mode 100644 index 0000000..e92f34b --- /dev/null +++ b/admin-ui/.gitignore @@ -0,0 +1,25 @@ +.DS_Store +node_modules/ +dist/ +npm-debug.log* +yarn-debug.log* +yarn-error.log* +*.local + +**/*.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 diff --git a/admin-ui/README.md b/admin-ui/README.md new file mode 100644 index 0000000..16564cc --- /dev/null +++ b/admin-ui/README.md @@ -0,0 +1,87 @@ +## 平台简介 + + +* 本仓库为前端技术栈 [Vue3](https://v3.cn.vuejs.org) + [Element Plus](https://element-plus.org/zh-CN) + [Vite](https://cn.vitejs.dev) 版本。 +* 配套后端代码仓库地址[RuoYi-Vue-Plus 4.X(注意版本号)](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus) +* 5.X后端需要使用此项目 [plus-ui](https://gitee.com/JavaLionLi/plus-ui) + +## 前端运行 + +```bash +# 克隆项目 +git clone https://gitee.com/JavaLionLi/RuoYi-Vue-Plus-UI.git + +# 进入项目目录 +cd RuoYi-Vue-Plus-UI + +# 安装依赖 +npm install --registry=https://registry.npmmirror.com + +# 启动服务 +npm run dev + +# 构建测试环境 yarn build:stage +# 构建生产环境 yarn build:prod +# 前端访问地址 http://localhost:80 +``` + +## 后端改造 +参考后端代码内 `ruoyi-generator/resources/vm/vue/v3/readme.txt` 说明 + +## 内置功能 + +1. 用户管理:用户是系统操作者,该功能主要完成系统用户配置。 +2. 部门管理:配置系统组织机构(公司、部门、小组),树结构展现支持数据权限。 +3. 岗位管理:配置系统用户所属担任职务。 +4. 菜单管理:配置系统菜单,操作权限,按钮权限标识等。 +5. 角色管理:角色菜单权限分配、设置角色按机构进行数据范围权限划分。 +6. 字典管理:对系统中经常使用的一些较为固定的数据进行维护。 +7. 参数管理:对系统动态配置常用参数。 +8. 通知公告:系统通知公告信息发布维护。 +9. 操作日志:系统正常操作日志记录和查询;系统异常信息日志记录和查询。 +10. 登录日志:系统登录日志记录查询包含登录异常。 +11. 在线用户:当前系统中活跃用户状态监控。 +12. 定时任务:在线(添加、修改、删除)任务调度包含执行结果日志。 +13. 代码生成:前后端代码的生成(java、html、xml、sql)支持CRUD下载 。 +14. 系统接口:根据业务代码自动生成相关的api接口文档。 +15. 服务监控:监视当前系统CPU、内存、磁盘、堆栈等相关信息。 +16. 缓存监控:对系统的缓存信息查询,命令统计等。 +17. 在线构建器:拖动表单元素生成相应的HTML代码。 +18. 连接池监视:监视当前系统数据库连接池状态,可进行分析SQL找出系统性能瓶颈。 + +## 演示图 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
\ No newline at end of file diff --git a/admin-ui/bin/build.bat b/admin-ui/bin/build.bat new file mode 100644 index 0000000..ecbb454 --- /dev/null +++ b/admin-ui/bin/build.bat @@ -0,0 +1,12 @@ +@echo off +echo. +echo [Ϣ] Weḅdistļ +echo. + +%~d0 +cd %~dp0 + +cd .. +yarn build:prod + +pause \ No newline at end of file diff --git a/admin-ui/bin/package.bat b/admin-ui/bin/package.bat new file mode 100644 index 0000000..f5b24e0 --- /dev/null +++ b/admin-ui/bin/package.bat @@ -0,0 +1,12 @@ +@echo off +echo. +echo [Ϣ] װWeḅnode_modulesļ +echo. + +%~d0 +cd %~dp0 + +cd .. +yarn --registry=https://registry.npmmirror.com + +pause \ No newline at end of file diff --git a/admin-ui/bin/run-web.bat b/admin-ui/bin/run-web.bat new file mode 100644 index 0000000..d2fe397 --- /dev/null +++ b/admin-ui/bin/run-web.bat @@ -0,0 +1,12 @@ +@echo off +echo. +echo [Ϣ] ʹ Vite Web ̡ +echo. + +%~d0 +cd %~dp0 + +cd .. +yarn dev + +pause \ No newline at end of file diff --git a/admin-ui/db-ddl.html b/admin-ui/db-ddl.html new file mode 100644 index 0000000..498623c --- /dev/null +++ b/admin-ui/db-ddl.html @@ -0,0 +1,47 @@ + + + + + + Document + + + + + +
+
+  
+ + + \ No newline at end of file diff --git a/admin-ui/game.html b/admin-ui/game.html new file mode 100644 index 0000000..5117702 --- /dev/null +++ b/admin-ui/game.html @@ -0,0 +1,59 @@ + + + + + + game + + + + + +
+
+ + + \ No newline at end of file diff --git a/admin-ui/html/ie.html b/admin-ui/html/ie.html new file mode 100644 index 0000000..052ffcd --- /dev/null +++ b/admin-ui/html/ie.html @@ -0,0 +1,46 @@ + + + + + + 请升级您的浏览器 + + + + + + +

请升级您的浏览器,以便我们更好的为您提供服务!

+

您正在使用 Internet Explorer 的早期版本(IE11以下版本或使用该内核的浏览器)。这意味着在升级浏览器前,您将无法访问此网站。

+
+

请注意:微软公司对Windows XP 及 Internet Explorer 早期版本的支持已经结束

+

自 2016 年 1 月 12 日起,Microsoft 不再为 IE 11 以下版本提供相应支持和更新。没有关键的浏览器安全更新,您的电脑可能易受有害病毒、间谍软件和其他恶意软件的攻击,它们可以窃取或损害您的业务数据和信息。请参阅 微软对 Internet Explorer 早期版本的支持将于 2016 年 1 月 12 日结束的说明

+
+

您可以选择更先进的浏览器

+

推荐使用以下浏览器的最新版本。如果您的电脑已有以下浏览器的最新版本则直接使用该浏览器访问即可。

+ +
+ + \ No newline at end of file diff --git a/admin-ui/index.html b/admin-ui/index.html new file mode 100644 index 0000000..4716354 --- /dev/null +++ b/admin-ui/index.html @@ -0,0 +1,133 @@ + + + + + + + + + + + + + + + +
+
+
+
+
+
+
+
+
+ +
+
正在加载系统资源,请耐心等待...
+
+
+ + + + diff --git a/admin-ui/jsconfig.json b/admin-ui/jsconfig.json new file mode 100644 index 0000000..46678f9 --- /dev/null +++ b/admin-ui/jsconfig.json @@ -0,0 +1,15 @@ +{ + "compilerOptions": { + "baseUrl": ".", + "paths": { + // 解决项目中使用@作为路径别名,导致vscode无法跳转文件的问题 + "@/*": ["src/*"] + }, + // 解决prettier对于装饰器语法的警告 + "experimentalDecorators": true, + // 解决.jsx文件无法快速跳转的问题 + "jsx": "preserve" + }, + //提高 IDE 性能 + "exclude": ["node_modules", "dist", "build"] +} \ No newline at end of file diff --git a/admin-ui/package.json b/admin-ui/package.json new file mode 100644 index 0000000..b635f4e --- /dev/null +++ b/admin-ui/package.json @@ -0,0 +1,45 @@ +{ + "name": "ruoyi-vue-plus", + "version": "4.6.0", + "description": "RuoYi-Vue-Plus后台管理系统", + "author": "LionLi", + "license": "MIT", + "scripts": { + "dev": "vite", + "build:prod": "vite build", + "preview": "vite preview" + }, + "repository": { + "type": "git", + "url": "https://gitee.com/JavaLionLi/RuoYi-Vue-Plus-UI.git" + }, + "dependencies": { + "@element-plus/icons-vue": "^2.3.1", + "@vueup/vue-quill": "1.1.0", + "@vueuse/core": "9.5.0", + "axios": "0.27.2", + "echarts": "5.4.0", + "element-plus": "^2.7.3", + "file-saver": "2.0.5", + "fuse.js": "6.6.2", + "js-cookie": "3.0.1", + "jsencrypt": "3.3.1", + "mescroll.js": "^1.4.2", + "nprogress": "0.2.0", + "pinia": "2.0.22", + "pinia-plugin-persist": "^1.0.0", + "vue": "3.2.45", + "vue-cropper": "1.0.3", + "vue-router": "4.1.4" + }, + "devDependencies": { + "@vitejs/plugin-vue": "3.1.0", + "@vue/compiler-sfc": "3.2.45", + "sass": "1.56.1", + "unplugin-auto-import": "0.11.4", + "vite": "3.2.7", + "vite-plugin-compression": "0.5.1", + "vite-plugin-svg-icons": "2.0.1", + "vite-plugin-vue-setup-extend": "0.4.0" + } +} diff --git a/admin-ui/pnpm-lock.yaml b/admin-ui/pnpm-lock.yaml new file mode 100644 index 0000000..a0df74b --- /dev/null +++ b/admin-ui/pnpm-lock.yaml @@ -0,0 +1,3266 @@ +lockfileVersion: '9.0' + +settings: + autoInstallPeers: true + excludeLinksFromLockfile: false + +importers: + + .: + dependencies: + '@element-plus/icons-vue': + specifier: ^2.3.1 + version: 2.3.1(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + '@vueup/vue-quill': + specifier: 1.1.0 + version: https://registry.npmmirror.com/@vueup/vue-quill/-/vue-quill-1.1.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + '@vueuse/core': + specifier: 9.5.0 + version: https://registry.npmmirror.com/@vueuse/core/-/core-9.5.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + axios: + specifier: 0.27.2 + version: https://registry.npmmirror.com/axios/-/axios-0.27.2.tgz + echarts: + specifier: 5.4.0 + version: https://registry.npmmirror.com/echarts/-/echarts-5.4.0.tgz + element-plus: + specifier: ^2.7.3 + version: 2.7.3(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + file-saver: + specifier: 2.0.5 + version: https://registry.npmmirror.com/file-saver/-/file-saver-2.0.5.tgz + fuse.js: + specifier: 6.6.2 + version: https://registry.npmmirror.com/fuse.js/-/fuse.js-6.6.2.tgz + js-cookie: + specifier: 3.0.1 + version: https://registry.npmmirror.com/js-cookie/-/js-cookie-3.0.1.tgz + jsencrypt: + specifier: 3.3.1 + version: https://registry.npmmirror.com/jsencrypt/-/jsencrypt-3.3.1.tgz + mescroll.js: + specifier: ^1.4.2 + version: https://registry.npmmirror.com/mescroll.js/-/mescroll.js-1.4.2.tgz + nprogress: + specifier: 0.2.0 + version: https://registry.npmmirror.com/nprogress/-/nprogress-0.2.0.tgz + pinia: + specifier: 2.0.22 + version: https://registry.npmmirror.com/pinia/-/pinia-2.0.22.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + pinia-plugin-persist: + specifier: ^1.0.0 + version: https://registry.npmmirror.com/pinia-plugin-persist/-/pinia-plugin-persist-1.0.0.tgz(pinia@https://registry.npmmirror.com/pinia/-/pinia-2.0.22.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz))(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + vue: + specifier: 3.2.45 + version: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + vue-cropper: + specifier: 1.0.3 + version: https://registry.npmmirror.com/vue-cropper/-/vue-cropper-1.0.3.tgz + vue-router: + specifier: 4.1.4 + version: https://registry.npmmirror.com/vue-router/-/vue-router-4.1.4.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + devDependencies: + '@vitejs/plugin-vue': + specifier: 3.1.0 + version: https://registry.npmmirror.com/@vitejs/plugin-vue/-/plugin-vue-3.1.0.tgz(vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz))(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + '@vue/compiler-sfc': + specifier: 3.2.45 + version: https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.45.tgz + sass: + specifier: 1.56.1 + version: https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz + unplugin-auto-import: + specifier: 0.11.4 + version: https://registry.npmmirror.com/unplugin-auto-import/-/unplugin-auto-import-0.11.4.tgz(@vueuse/core@https://registry.npmmirror.com/@vueuse/core/-/core-9.5.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz))(rollup@2.79.1) + vite: + specifier: 3.2.7 + version: https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz) + vite-plugin-compression: + specifier: 0.5.1 + version: https://registry.npmmirror.com/vite-plugin-compression/-/vite-plugin-compression-0.5.1.tgz(vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz)) + vite-plugin-svg-icons: + specifier: 2.0.1 + version: https://registry.npmmirror.com/vite-plugin-svg-icons/-/vite-plugin-svg-icons-2.0.1.tgz(vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz)) + vite-plugin-vue-setup-extend: + specifier: 0.4.0 + version: https://registry.npmmirror.com/vite-plugin-vue-setup-extend/-/vite-plugin-vue-setup-extend-0.4.0.tgz(vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz)) + +packages: + + '@antfu/utils@https://registry.npmmirror.com/@antfu/utils/-/utils-0.6.3.tgz': + resolution: {integrity: sha512-sEYpyyKUPOew9QsXZ8feRVMzW6DWLviwOl+/ap06UQW02A8Srbc95CPHVm4eUbiBzBgD46eyIT+przv//KSSlQ==, tarball: https://registry.npmmirror.com/@antfu/utils/-/utils-0.6.3.tgz} + version: 0.6.3 + + '@babel/helper-string-parser@https://registry.npmmirror.com/@babel/helper-string-parser/-/helper-string-parser-7.21.5.tgz': + resolution: {integrity: sha512-5pTUx3hAJaZIdW99sJ6ZUUgWq/Y+Hja7TowEnLNMm1VivRgZQL3vpBY3qUACVsvw+yQU6+YgfBVmcbLaZtrA1w==, tarball: https://registry.npmmirror.com/@babel/helper-string-parser/-/helper-string-parser-7.21.5.tgz} + version: 7.21.5 + engines: {node: '>=6.9.0'} + + '@babel/helper-validator-identifier@https://registry.npmmirror.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz': + resolution: {integrity: sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==, tarball: https://registry.npmmirror.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz} + version: 7.19.1 + engines: {node: '>=6.9.0'} + + '@babel/parser@https://registry.npmmirror.com/@babel/parser/-/parser-7.21.9.tgz': + resolution: {integrity: sha512-q5PNg/Bi1OpGgx5jYlvWZwAorZepEudDMCLtj967aeS7WMont7dUZI46M2XwcIQqvUlMxWfdLFu4S/qSxeUu5g==, tarball: https://registry.npmmirror.com/@babel/parser/-/parser-7.21.9.tgz} + version: 7.21.9 + engines: {node: '>=6.0.0'} + hasBin: true + + '@babel/types@https://registry.npmmirror.com/@babel/types/-/types-7.21.5.tgz': + resolution: {integrity: sha512-m4AfNvVF2mVC/F7fDEdH2El3HzUg9It/XsCxZiOTTA3m3qYfcSVSbTfM6Q9xG+hYDniZssYhlXKKUMD5m8tF4Q==, tarball: https://registry.npmmirror.com/@babel/types/-/types-7.21.5.tgz} + version: 7.21.5 + engines: {node: '>=6.9.0'} + + '@ctrl/tinycolor@3.6.1': + resolution: {integrity: sha512-SITSV6aIXsuVNV3f3O0f2n/cgyEDWoSqtZMYiAmcsYHydcKrOz3gUxB/iXd/Qf08+IZX4KpgNbvUdMBmWz+kcA==} + engines: {node: '>=10'} + + '@element-plus/icons-vue@2.3.1': + resolution: {integrity: sha512-XxVUZv48RZAd87ucGS48jPf6pKu0yV5UCg9f4FFwtrYxXOwWuVJo6wOvSLKEoMQKjv8GsX/mhP6UsC1lRwbUWg==} + version: 2.3.1 + peerDependencies: + vue: ^3.2.0 + + '@esbuild/android-arm@0.15.18': + resolution: {integrity: sha512-5GT+kcs2WVGjVs7+boataCkO5Fg0y4kCjzkB5bAip7H4jfnOS3dA6KPiww9W1OEKTKeAcUVhdZGvgI65OXmUnw==} + engines: {node: '>=12'} + cpu: [arm] + os: [android] + + '@esbuild/linux-loong64@0.15.18': + resolution: {integrity: sha512-L4jVKS82XVhw2nvzLg/19ClLWg0y27ulRwuP7lcyL6AbUWB5aPglXY3M21mauDQMDfRLs8cQmeT03r/+X3cZYQ==} + engines: {node: '>=12'} + cpu: [loong64] + os: [linux] + + '@floating-ui/core@1.6.2': + resolution: {integrity: sha512-+2XpQV9LLZeanU4ZevzRnGFg2neDeKHgFLjP6YLW+tly0IvrhqT4u8enLGjLH3qeh85g19xY5rsAusfwTdn5lg==} + + '@floating-ui/dom@1.6.5': + resolution: {integrity: sha512-Nsdud2X65Dz+1RHjAIP0t8z5e2ff/IRbei6BqFrl1urT8sDVzM1HMQ+R0XcU5ceRfyO3I6ayeqIfh+6Wb8LGTw==} + + '@floating-ui/utils@0.2.2': + resolution: {integrity: sha512-J4yDIIthosAsRZ5CPYP/jQvUAQtlZTTD/4suA08/FEnlxqW3sKS9iAhgsa9VYLZ6vDHn/ixJgIqRQPotoBjxIw==} + + '@nodelib/fs.scandir@https://registry.npmmirror.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz': + resolution: {integrity: sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==, tarball: https://registry.npmmirror.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz} + version: 2.1.5 + engines: {node: '>= 8'} + + '@nodelib/fs.stat@https://registry.npmmirror.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz': + resolution: {integrity: sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==, tarball: https://registry.npmmirror.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz} + version: 2.0.5 + engines: {node: '>= 8'} + + '@nodelib/fs.walk@https://registry.npmmirror.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz': + resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==, tarball: https://registry.npmmirror.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz} + version: 1.2.8 + engines: {node: '>= 8'} + + '@rollup/pluginutils@https://registry.npmmirror.com/@rollup/pluginutils/-/pluginutils-5.0.2.tgz': + resolution: {integrity: sha512-pTd9rIsP92h+B6wWwFbW8RkZv4hiR/xKsqre4SIuAOaOEQRxi0lqLke9k2/7WegC85GgUs9pjmOjCUi3In4vwA==, tarball: https://registry.npmmirror.com/@rollup/pluginutils/-/pluginutils-5.0.2.tgz} + version: 5.0.2 + engines: {node: '>=14.0.0'} + peerDependencies: + rollup: ^1.20.0||^2.0.0||^3.0.0 + peerDependenciesMeta: + rollup: + optional: true + + '@sxzz/popperjs-es@2.11.7': + resolution: {integrity: sha512-Ccy0NlLkzr0Ex2FKvh2X+OyERHXJ88XJ1MXtsI9y9fGexlaXaVTPzBCRBwIxFkORuOb+uBqeu+RqnpgYTEZRUQ==} + + '@trysound/sax@https://registry.npmmirror.com/@trysound/sax/-/sax-0.2.0.tgz': + resolution: {integrity: sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA==, tarball: https://registry.npmmirror.com/@trysound/sax/-/sax-0.2.0.tgz} + version: 0.2.0 + engines: {node: '>=10.13.0'} + + '@types/estree@https://registry.npmmirror.com/@types/estree/-/estree-1.0.1.tgz': + resolution: {integrity: sha512-LG4opVs2ANWZ1TJoKc937iMmNstM/d0ae1vNbnBvBhqCSezgVUOzcLCqbI5elV8Vy6WKwKjaqR+zO9VKirBBCA==, tarball: https://registry.npmmirror.com/@types/estree/-/estree-1.0.1.tgz} + version: 1.0.1 + + '@types/lodash-es@4.17.12': + resolution: {integrity: sha512-0NgftHUcV4v34VhXm8QBSftKVXtbkBG3ViCjs6+eJ5a6y6Mi/jiFGPc1sC7QK+9BFhWrURE3EOggmWaSxL9OzQ==} + + '@types/lodash@4.17.4': + resolution: {integrity: sha512-wYCP26ZLxaT3R39kiN2+HcJ4kTd3U1waI/cY7ivWYqFP6pW3ZNpvi6Wd6PHZx7T/t8z0vlkXMg3QYLa7DZ/IJQ==} + + '@types/node@20.2.3': + resolution: {integrity: sha512-pg9d0yC4rVNWQzX8U7xb4olIOFuuVL9za3bzMT2pu2SU0SNEi66i2qrvhE2qt0HvkhuCaWJu7pLNOt/Pj8BIrw==} + + '@types/node@https://registry.npmmirror.com/@types/node/-/node-20.2.3.tgz': + resolution: {integrity: sha512-pg9d0yC4rVNWQzX8U7xb4olIOFuuVL9za3bzMT2pu2SU0SNEi66i2qrvhE2qt0HvkhuCaWJu7pLNOt/Pj8BIrw==, tarball: https://registry.npmmirror.com/@types/node/-/node-20.2.3.tgz} + version: 20.2.3 + + '@types/svgo@https://registry.npmmirror.com/@types/svgo/-/svgo-2.6.4.tgz': + resolution: {integrity: sha512-l4cmyPEckf8moNYHdJ+4wkHvFxjyW6ulm9l4YGaOxeyBWPhBOT0gvni1InpFPdzx1dKf/2s62qGITwxNWnPQng==, tarball: https://registry.npmmirror.com/@types/svgo/-/svgo-2.6.4.tgz} + version: 2.6.4 + + '@types/web-bluetooth@0.0.16': + resolution: {integrity: sha512-oh8q2Zc32S6gd/j50GowEjKLoOVOwHP/bWVjKJInBwQqdOYMdPrf1oVlelTlyfFK3CKxL1uahMDAr+vy8T7yMQ==} + + '@types/web-bluetooth@https://registry.npmmirror.com/@types/web-bluetooth/-/web-bluetooth-0.0.16.tgz': + resolution: {integrity: sha512-oh8q2Zc32S6gd/j50GowEjKLoOVOwHP/bWVjKJInBwQqdOYMdPrf1oVlelTlyfFK3CKxL1uahMDAr+vy8T7yMQ==, tarball: https://registry.npmmirror.com/@types/web-bluetooth/-/web-bluetooth-0.0.16.tgz} + version: 0.0.16 + + '@vitejs/plugin-vue@https://registry.npmmirror.com/@vitejs/plugin-vue/-/plugin-vue-3.1.0.tgz': + resolution: {integrity: sha512-fmxtHPjSOEIRg6vHYDaem+97iwCUg/uSIaTzp98lhELt2ISOQuDo2hbkBdXod0g15IhfPMQmAxh4heUks2zvDA==, tarball: https://registry.npmmirror.com/@vitejs/plugin-vue/-/plugin-vue-3.1.0.tgz} + version: 3.1.0 + engines: {node: ^14.18.0 || >=16.0.0} + peerDependencies: + vite: ^3.0.0 + vue: ^3.2.25 + + '@vue/compiler-core@https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.45.tgz': + resolution: {integrity: sha512-rcMj7H+PYe5wBV3iYeUgbCglC+pbpN8hBLTJvRiK2eKQiWqu+fG9F+8sW99JdL4LQi7Re178UOxn09puSXvn4A==, tarball: https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.45.tgz} + version: 3.2.45 + + '@vue/compiler-dom@https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.45.tgz': + resolution: {integrity: sha512-tyYeUEuKqqZO137WrZkpwfPCdiiIeXYCcJ8L4gWz9vqaxzIQRccTSwSWZ/Axx5YR2z+LvpUbmPNXxuBU45lyRw==, tarball: https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.45.tgz} + version: 3.2.45 + + '@vue/compiler-sfc@https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.45.tgz': + resolution: {integrity: sha512-1jXDuWah1ggsnSAOGsec8cFjT/K6TMZ0sPL3o3d84Ft2AYZi2jWJgRMjw4iaK0rBfA89L5gw427H4n1RZQBu6Q==, tarball: https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.45.tgz} + version: 3.2.45 + + '@vue/compiler-ssr@https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.45.tgz': + resolution: {integrity: sha512-6BRaggEGqhWht3lt24CrIbQSRD5O07MTmd+LjAn5fJj568+R9eUD2F7wMQJjX859seSlrYog7sUtrZSd7feqrQ==, tarball: https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.45.tgz} + version: 3.2.45 + + '@vue/devtools-api@https://registry.npmmirror.com/@vue/devtools-api/-/devtools-api-6.5.0.tgz': + resolution: {integrity: sha512-o9KfBeaBmCKl10usN4crU53fYtC1r7jJwdGKjPT24t348rHxgfpZ0xL3Xm/gLUYnc0oTp8LAmrxOeLyu6tbk2Q==, tarball: https://registry.npmmirror.com/@vue/devtools-api/-/devtools-api-6.5.0.tgz} + version: 6.5.0 + + '@vue/reactivity-transform@https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.2.45.tgz': + resolution: {integrity: sha512-BHVmzYAvM7vcU5WmuYqXpwaBHjsS8T63jlKGWVtHxAHIoMIlmaMyurUSEs1Zcg46M4AYT5MtB1U274/2aNzjJQ==, tarball: https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.2.45.tgz} + version: 3.2.45 + + '@vue/reactivity@https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.2.45.tgz': + resolution: {integrity: sha512-PRvhCcQcyEVohW0P8iQ7HDcIOXRjZfAsOds3N99X/Dzewy8TVhTCT4uXpAHfoKjVTJRA0O0K+6QNkDIZAxNi3A==, tarball: https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.2.45.tgz} + version: 3.2.45 + + '@vue/runtime-core@https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.2.45.tgz': + resolution: {integrity: sha512-gzJiTA3f74cgARptqzYswmoQx0fIA+gGYBfokYVhF8YSXjWTUA2SngRzZRku2HbGbjzB6LBYSbKGIaK8IW+s0A==, tarball: https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.2.45.tgz} + version: 3.2.45 + + '@vue/runtime-dom@https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.2.45.tgz': + resolution: {integrity: sha512-cy88YpfP5Ue2bDBbj75Cb4bIEZUMM/mAkDMfqDTpUYVgTf/kuQ2VQ8LebuZ8k6EudgH8pYhsGWHlY0lcxlvTwA==, tarball: https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.2.45.tgz} + version: 3.2.45 + + '@vue/server-renderer@https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.2.45.tgz': + resolution: {integrity: sha512-ebiMq7q24WBU1D6uhPK//2OTR1iRIyxjF5iVq/1a5I1SDMDyDu4Ts6fJaMnjrvD3MqnaiFkKQj+LKAgz5WIK3g==, tarball: https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.2.45.tgz} + version: 3.2.45 + peerDependencies: + vue: 3.2.45 + + '@vue/shared@https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz': + resolution: {integrity: sha512-Ewzq5Yhimg7pSztDV+RH1UDKBzmtqieXQlpTVm2AwraoRL/Rks96mvd8Vgi7Lj+h+TH8dv7mXD3FRZR3TUvbSg==, tarball: https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz} + version: 3.2.45 + + '@vueup/vue-quill@https://registry.npmmirror.com/@vueup/vue-quill/-/vue-quill-1.1.0.tgz': + resolution: {integrity: sha512-xr1mx2y+JZClPs/lz+qjvGOWgLqh9SWfm1V+ofsJtuvBnN/h9O/QqJBuVWmdAcB6JGFhIeQcjuA2JgzqX2STjg==, tarball: https://registry.npmmirror.com/@vueup/vue-quill/-/vue-quill-1.1.0.tgz} + version: 1.1.0 + peerDependencies: + vue: ^3.2.41 + + '@vueuse/core@9.5.0': + resolution: {integrity: sha512-6GsWBsJHEb3sYw15mbLrcbslAVY45pkzjJYTKYKCXv88z7srAF0VEW0q+oXKsl58tCbqooplInahXFg8Yo1m4w==} + version: 9.5.0 + + '@vueuse/core@https://registry.npmmirror.com/@vueuse/core/-/core-9.5.0.tgz': + resolution: {integrity: sha512-6GsWBsJHEb3sYw15mbLrcbslAVY45pkzjJYTKYKCXv88z7srAF0VEW0q+oXKsl58tCbqooplInahXFg8Yo1m4w==, tarball: https://registry.npmmirror.com/@vueuse/core/-/core-9.5.0.tgz} + version: 9.5.0 + + '@vueuse/metadata@9.5.0': + resolution: {integrity: sha512-4M1AyPZmIv41pym+K5+4wup3bKuYebbH8w8BROY1hmT7rIwcyS4tEL+UsGz0Hiu1FCOxcoBrwtAizc0YmBJjyQ==} + + '@vueuse/metadata@https://registry.npmmirror.com/@vueuse/metadata/-/metadata-9.5.0.tgz': + resolution: {integrity: sha512-4M1AyPZmIv41pym+K5+4wup3bKuYebbH8w8BROY1hmT7rIwcyS4tEL+UsGz0Hiu1FCOxcoBrwtAizc0YmBJjyQ==, tarball: https://registry.npmmirror.com/@vueuse/metadata/-/metadata-9.5.0.tgz} + version: 9.5.0 + + '@vueuse/shared@9.5.0': + resolution: {integrity: sha512-HnnCWU1Vg9CVWRCcI8ohDKDRB2Sc4bTgT1XAIaoLSfVHHn+TKbrox6pd3klCSw4UDxkhDfOk8cAdcK+Z5KleCA==} + version: 9.5.0 + + '@vueuse/shared@https://registry.npmmirror.com/@vueuse/shared/-/shared-9.5.0.tgz': + resolution: {integrity: sha512-HnnCWU1Vg9CVWRCcI8ohDKDRB2Sc4bTgT1XAIaoLSfVHHn+TKbrox6pd3klCSw4UDxkhDfOk8cAdcK+Z5KleCA==, tarball: https://registry.npmmirror.com/@vueuse/shared/-/shared-9.5.0.tgz} + version: 9.5.0 + + acorn@https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz: + resolution: {integrity: sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==, tarball: https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz} + version: 8.8.2 + engines: {node: '>=0.4.0'} + hasBin: true + + ansi-regex@https://registry.npmmirror.com/ansi-regex/-/ansi-regex-2.1.1.tgz: + resolution: {integrity: sha512-TIGnTpdo+E3+pCyAluZvtED5p5wCqLdezCyhPZzKPcxvFplEt4i+W7OONCKgeZFT3+y5NZZfOOS/Bdcanm1MYA==, tarball: https://registry.npmmirror.com/ansi-regex/-/ansi-regex-2.1.1.tgz} + version: 2.1.1 + engines: {node: '>=0.10.0'} + + ansi-styles@https://registry.npmmirror.com/ansi-styles/-/ansi-styles-2.2.1.tgz: + resolution: {integrity: sha512-kmCevFghRiWM7HB5zTPULl4r9bVFSWjz62MhqizDGUrq2NWuNMQyuv4tHHoKJHs69M/MF64lEcHdYIocrdWQYA==, tarball: https://registry.npmmirror.com/ansi-styles/-/ansi-styles-2.2.1.tgz} + version: 2.2.1 + engines: {node: '>=0.10.0'} + + ansi-styles@https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz: + resolution: {integrity: sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==, tarball: https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz} + version: 4.3.0 + engines: {node: '>=8'} + + anymatch@https://registry.npmmirror.com/anymatch/-/anymatch-3.1.3.tgz: + resolution: {integrity: sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==, tarball: https://registry.npmmirror.com/anymatch/-/anymatch-3.1.3.tgz} + version: 3.1.3 + engines: {node: '>= 8'} + + arr-diff@https://registry.npmmirror.com/arr-diff/-/arr-diff-4.0.0.tgz: + resolution: {integrity: sha512-YVIQ82gZPGBebQV/a8dar4AitzCQs0jjXwMPZllpXMaGjXPYVUawSxQrRsjhjupyVxEvbHgUmIhKVlND+j02kA==, tarball: https://registry.npmmirror.com/arr-diff/-/arr-diff-4.0.0.tgz} + version: 4.0.0 + engines: {node: '>=0.10.0'} + + arr-flatten@https://registry.npmmirror.com/arr-flatten/-/arr-flatten-1.1.0.tgz: + resolution: {integrity: sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==, tarball: https://registry.npmmirror.com/arr-flatten/-/arr-flatten-1.1.0.tgz} + version: 1.1.0 + engines: {node: '>=0.10.0'} + + arr-union@https://registry.npmmirror.com/arr-union/-/arr-union-3.1.0.tgz: + resolution: {integrity: sha512-sKpyeERZ02v1FeCZT8lrfJq5u6goHCtpTAzPwJYe7c8SPFOboNjNg1vz2L4VTn9T4PQxEx13TbXLmYUcS6Ug7Q==, tarball: https://registry.npmmirror.com/arr-union/-/arr-union-3.1.0.tgz} + version: 3.1.0 + engines: {node: '>=0.10.0'} + + array-unique@https://registry.npmmirror.com/array-unique/-/array-unique-0.3.2.tgz: + resolution: {integrity: sha512-SleRWjh9JUud2wH1hPs9rZBZ33H6T9HOiL0uwGnGx9FpE6wKGyfWugmbkEOIs6qWrZhg0LWeLziLrEwQJhs5mQ==, tarball: https://registry.npmmirror.com/array-unique/-/array-unique-0.3.2.tgz} + version: 0.3.2 + engines: {node: '>=0.10.0'} + + assign-symbols@https://registry.npmmirror.com/assign-symbols/-/assign-symbols-1.0.0.tgz: + resolution: {integrity: sha512-Q+JC7Whu8HhmTdBph/Tq59IoRtoy6KAm5zzPv00WdujX82lbAL8K7WVjne7vdCsAmbF4AYaDOPyO3k0kl8qIrw==, tarball: https://registry.npmmirror.com/assign-symbols/-/assign-symbols-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + async-validator@4.2.5: + resolution: {integrity: sha512-7HhHjtERjqlNbZtqNqy2rckN/SpOOlmDliet+lP7k+eKZEjPk3DgyeU9lIXLdeLz0uBbbVp+9Qdow9wJWgwwfg==} + + asynckit@https://registry.npmmirror.com/asynckit/-/asynckit-0.4.0.tgz: + resolution: {integrity: sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==, tarball: https://registry.npmmirror.com/asynckit/-/asynckit-0.4.0.tgz} + version: 0.4.0 + + atob@https://registry.npmmirror.com/atob/-/atob-2.1.2.tgz: + resolution: {integrity: sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==, tarball: https://registry.npmmirror.com/atob/-/atob-2.1.2.tgz} + version: 2.1.2 + engines: {node: '>= 4.5.0'} + hasBin: true + + axios@https://registry.npmmirror.com/axios/-/axios-0.27.2.tgz: + resolution: {integrity: sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ==, tarball: https://registry.npmmirror.com/axios/-/axios-0.27.2.tgz} + version: 0.27.2 + + base@https://registry.npmmirror.com/base/-/base-0.11.2.tgz: + resolution: {integrity: sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==, tarball: https://registry.npmmirror.com/base/-/base-0.11.2.tgz} + version: 0.11.2 + engines: {node: '>=0.10.0'} + + big.js@https://registry.npmmirror.com/big.js/-/big.js-5.2.2.tgz: + resolution: {integrity: sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==, tarball: https://registry.npmmirror.com/big.js/-/big.js-5.2.2.tgz} + version: 5.2.2 + + binary-extensions@https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.2.0.tgz: + resolution: {integrity: sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==, tarball: https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.2.0.tgz} + version: 2.2.0 + engines: {node: '>=8'} + + bluebird@https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz: + resolution: {integrity: sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==, tarball: https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz} + version: 3.7.2 + + boolbase@https://registry.npmmirror.com/boolbase/-/boolbase-1.0.0.tgz: + resolution: {integrity: sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==, tarball: https://registry.npmmirror.com/boolbase/-/boolbase-1.0.0.tgz} + version: 1.0.0 + + braces@https://registry.npmmirror.com/braces/-/braces-2.3.2.tgz: + resolution: {integrity: sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==, tarball: https://registry.npmmirror.com/braces/-/braces-2.3.2.tgz} + version: 2.3.2 + engines: {node: '>=0.10.0'} + + braces@https://registry.npmmirror.com/braces/-/braces-3.0.2.tgz: + resolution: {integrity: sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==, tarball: https://registry.npmmirror.com/braces/-/braces-3.0.2.tgz} + version: 3.0.2 + engines: {node: '>=8'} + + cache-base@https://registry.npmmirror.com/cache-base/-/cache-base-1.0.1.tgz: + resolution: {integrity: sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==, tarball: https://registry.npmmirror.com/cache-base/-/cache-base-1.0.1.tgz} + version: 1.0.1 + engines: {node: '>=0.10.0'} + + call-bind@https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz: + resolution: {integrity: sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==, tarball: https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz} + version: 1.0.2 + + chalk@https://registry.npmmirror.com/chalk/-/chalk-1.1.3.tgz: + resolution: {integrity: sha512-U3lRVLMSlsCfjqYPbLyVv11M9CPW4I728d6TCKMAOJueEeB9/8o+eSsMnxPJD+Q+K909sdESg7C+tIkoH6on1A==, tarball: https://registry.npmmirror.com/chalk/-/chalk-1.1.3.tgz} + version: 1.1.3 + engines: {node: '>=0.10.0'} + + chalk@https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz: + resolution: {integrity: sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==, tarball: https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz} + version: 4.1.2 + engines: {node: '>=10'} + + chokidar@https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz: + resolution: {integrity: sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==, tarball: https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz} + version: 3.5.3 + engines: {node: '>= 8.10.0'} + + class-utils@https://registry.npmmirror.com/class-utils/-/class-utils-0.3.6.tgz: + resolution: {integrity: sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==, tarball: https://registry.npmmirror.com/class-utils/-/class-utils-0.3.6.tgz} + version: 0.3.6 + engines: {node: '>=0.10.0'} + + clone@https://registry.npmmirror.com/clone/-/clone-2.1.2.tgz: + resolution: {integrity: sha512-3Pe/CF1Nn94hyhIYpjtiLhdCoEoz0DqQ+988E9gmeEdQZlojxnOb74wctFyuwWQHzqyf9X7C7MG8juUpqBJT8w==, tarball: https://registry.npmmirror.com/clone/-/clone-2.1.2.tgz} + version: 2.1.2 + engines: {node: '>=0.8'} + + collection-visit@https://registry.npmmirror.com/collection-visit/-/collection-visit-1.0.0.tgz: + resolution: {integrity: sha512-lNkKvzEeMBBjUGHZ+q6z9pSJla0KWAQPvtzhEV9+iGyQYG+pBpl7xKDhxoNSOZH2hhv0v5k0y2yAM4o4SjoSkw==, tarball: https://registry.npmmirror.com/collection-visit/-/collection-visit-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + color-convert@https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz: + resolution: {integrity: sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==, tarball: https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz} + version: 2.0.1 + engines: {node: '>=7.0.0'} + + color-name@https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz: + resolution: {integrity: sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==, tarball: https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz} + version: 1.1.4 + + combined-stream@https://registry.npmmirror.com/combined-stream/-/combined-stream-1.0.8.tgz: + resolution: {integrity: sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==, tarball: https://registry.npmmirror.com/combined-stream/-/combined-stream-1.0.8.tgz} + version: 1.0.8 + engines: {node: '>= 0.8'} + + commander@https://registry.npmmirror.com/commander/-/commander-7.2.0.tgz: + resolution: {integrity: sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==, tarball: https://registry.npmmirror.com/commander/-/commander-7.2.0.tgz} + version: 7.2.0 + engines: {node: '>= 10'} + + component-emitter@https://registry.npmmirror.com/component-emitter/-/component-emitter-1.3.0.tgz: + resolution: {integrity: sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==, tarball: https://registry.npmmirror.com/component-emitter/-/component-emitter-1.3.0.tgz} + version: 1.3.0 + + copy-descriptor@https://registry.npmmirror.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz: + resolution: {integrity: sha512-XgZ0pFcakEUlbwQEVNg3+QAis1FyTL3Qel9FYy8pSkQqoG3PNoT0bOCQtOXcOkur21r2Eq2kI+IE+gsmAEVlYw==, tarball: https://registry.npmmirror.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz} + version: 0.1.1 + engines: {node: '>=0.10.0'} + + cors@https://registry.npmmirror.com/cors/-/cors-2.8.5.tgz: + resolution: {integrity: sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==, tarball: https://registry.npmmirror.com/cors/-/cors-2.8.5.tgz} + version: 2.8.5 + engines: {node: '>= 0.10'} + + css-select@https://registry.npmmirror.com/css-select/-/css-select-4.3.0.tgz: + resolution: {integrity: sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==, tarball: https://registry.npmmirror.com/css-select/-/css-select-4.3.0.tgz} + version: 4.3.0 + + css-tree@https://registry.npmmirror.com/css-tree/-/css-tree-1.1.3.tgz: + resolution: {integrity: sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==, tarball: https://registry.npmmirror.com/css-tree/-/css-tree-1.1.3.tgz} + version: 1.1.3 + engines: {node: '>=8.0.0'} + + css-what@https://registry.npmmirror.com/css-what/-/css-what-6.1.0.tgz: + resolution: {integrity: sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==, tarball: https://registry.npmmirror.com/css-what/-/css-what-6.1.0.tgz} + version: 6.1.0 + engines: {node: '>= 6'} + + csso@https://registry.npmmirror.com/csso/-/csso-4.2.0.tgz: + resolution: {integrity: sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA==, tarball: https://registry.npmmirror.com/csso/-/csso-4.2.0.tgz} + version: 4.2.0 + engines: {node: '>=8.0.0'} + + csstype@https://registry.npmmirror.com/csstype/-/csstype-2.6.21.tgz: + resolution: {integrity: sha512-Z1PhmomIfypOpoMjRQB70jfvy/wxT50qW08YXO5lMIJkrdq4yOTR+AW7FqutScmB9NkLwxo+jU+kZLbofZZq/w==, tarball: https://registry.npmmirror.com/csstype/-/csstype-2.6.21.tgz} + version: 2.6.21 + + dayjs@1.11.11: + resolution: {integrity: sha512-okzr3f11N6WuqYtZSvm+F776mB41wRZMhKP+hc34YdW+KmtYYK9iqvHSwo2k9FEH3fhGXvOPV6yz2IcSrfRUDg==} + + debug@https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz: + resolution: {integrity: sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==, tarball: https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz} + version: 2.6.9 + peerDependencies: + supports-color: '*' + peerDependenciesMeta: + supports-color: + optional: true + + debug@https://registry.npmmirror.com/debug/-/debug-4.3.4.tgz: + resolution: {integrity: sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==, tarball: https://registry.npmmirror.com/debug/-/debug-4.3.4.tgz} + version: 4.3.4 + engines: {node: '>=6.0'} + peerDependencies: + supports-color: '*' + peerDependenciesMeta: + supports-color: + optional: true + + decode-uri-component@https://registry.npmmirror.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz: + resolution: {integrity: sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ==, tarball: https://registry.npmmirror.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz} + version: 0.2.2 + engines: {node: '>=0.10'} + + deep-equal@https://registry.npmmirror.com/deep-equal/-/deep-equal-1.1.1.tgz: + resolution: {integrity: sha512-yd9c5AdiqVcR+JjcwUQb9DkhJc8ngNr0MahEBGvDiJw8puWab2yZlh+nkasOnZP+EGTAP6rRp2JzJhJZzvNF8g==, tarball: https://registry.npmmirror.com/deep-equal/-/deep-equal-1.1.1.tgz} + version: 1.1.1 + + define-properties@https://registry.npmmirror.com/define-properties/-/define-properties-1.2.0.tgz: + resolution: {integrity: sha512-xvqAVKGfT1+UAvPwKTVw/njhdQ8ZhXK4lI0bCIuCMrp2up9nPnaDftrLtmpTazqd1o+UY4zgzU+avtMbDP+ldA==, tarball: https://registry.npmmirror.com/define-properties/-/define-properties-1.2.0.tgz} + version: 1.2.0 + engines: {node: '>= 0.4'} + + define-property@https://registry.npmmirror.com/define-property/-/define-property-0.2.5.tgz: + resolution: {integrity: sha512-Rr7ADjQZenceVOAKop6ALkkRAmH1A4Gx9hV/7ZujPUN2rkATqFO0JZLZInbAjpZYoJ1gUx8MRMQVkYemcbMSTA==, tarball: https://registry.npmmirror.com/define-property/-/define-property-0.2.5.tgz} + version: 0.2.5 + engines: {node: '>=0.10.0'} + + define-property@https://registry.npmmirror.com/define-property/-/define-property-1.0.0.tgz: + resolution: {integrity: sha512-cZTYKFWspt9jZsMscWo8sc/5lbPC9Q0N5nBLgb+Yd915iL3udB1uFgS3B8YCx66UVHq018DAVFoee7x+gxggeA==, tarball: https://registry.npmmirror.com/define-property/-/define-property-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + define-property@https://registry.npmmirror.com/define-property/-/define-property-2.0.2.tgz: + resolution: {integrity: sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==, tarball: https://registry.npmmirror.com/define-property/-/define-property-2.0.2.tgz} + version: 2.0.2 + engines: {node: '>=0.10.0'} + + delayed-stream@https://registry.npmmirror.com/delayed-stream/-/delayed-stream-1.0.0.tgz: + resolution: {integrity: sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==, tarball: https://registry.npmmirror.com/delayed-stream/-/delayed-stream-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.4.0'} + + dom-serializer@https://registry.npmmirror.com/dom-serializer/-/dom-serializer-0.2.2.tgz: + resolution: {integrity: sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g==, tarball: https://registry.npmmirror.com/dom-serializer/-/dom-serializer-0.2.2.tgz} + version: 0.2.2 + + dom-serializer@https://registry.npmmirror.com/dom-serializer/-/dom-serializer-1.4.1.tgz: + resolution: {integrity: sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==, tarball: https://registry.npmmirror.com/dom-serializer/-/dom-serializer-1.4.1.tgz} + version: 1.4.1 + + domelementtype@https://registry.npmmirror.com/domelementtype/-/domelementtype-1.3.1.tgz: + resolution: {integrity: sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==, tarball: https://registry.npmmirror.com/domelementtype/-/domelementtype-1.3.1.tgz} + version: 1.3.1 + + domelementtype@https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz: + resolution: {integrity: sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==, tarball: https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz} + version: 2.3.0 + + domhandler@https://registry.npmmirror.com/domhandler/-/domhandler-2.4.2.tgz: + resolution: {integrity: sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA==, tarball: https://registry.npmmirror.com/domhandler/-/domhandler-2.4.2.tgz} + version: 2.4.2 + + domhandler@https://registry.npmmirror.com/domhandler/-/domhandler-4.3.1.tgz: + resolution: {integrity: sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==, tarball: https://registry.npmmirror.com/domhandler/-/domhandler-4.3.1.tgz} + version: 4.3.1 + engines: {node: '>= 4'} + + domutils@https://registry.npmmirror.com/domutils/-/domutils-1.7.0.tgz: + resolution: {integrity: sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==, tarball: https://registry.npmmirror.com/domutils/-/domutils-1.7.0.tgz} + version: 1.7.0 + + domutils@https://registry.npmmirror.com/domutils/-/domutils-2.8.0.tgz: + resolution: {integrity: sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==, tarball: https://registry.npmmirror.com/domutils/-/domutils-2.8.0.tgz} + version: 2.8.0 + + echarts@https://registry.npmmirror.com/echarts/-/echarts-5.4.0.tgz: + resolution: {integrity: sha512-uPsO9VRUIKAdFOoH3B0aNg7NRVdN7aM39/OjovjO9MwmWsAkfGyeXJhK+dbRi51iDrQWliXV60/XwLA7kg3z0w==, tarball: https://registry.npmmirror.com/echarts/-/echarts-5.4.0.tgz} + version: 5.4.0 + + element-plus@2.7.3: + resolution: {integrity: sha512-OaqY1kQ2xzNyRFyge3fzM7jqMwux+464RBEqd+ybRV9xPiGxtgnj/sVK4iEbnKnzQIa9XK03DOIFzoToUhu1DA==} + version: 2.7.3 + peerDependencies: + vue: ^3.2.0 + + emojis-list@https://registry.npmmirror.com/emojis-list/-/emojis-list-3.0.0.tgz: + resolution: {integrity: sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==, tarball: https://registry.npmmirror.com/emojis-list/-/emojis-list-3.0.0.tgz} + version: 3.0.0 + engines: {node: '>= 4'} + + entities@https://registry.npmmirror.com/entities/-/entities-1.1.2.tgz: + resolution: {integrity: sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==, tarball: https://registry.npmmirror.com/entities/-/entities-1.1.2.tgz} + version: 1.1.2 + + entities@https://registry.npmmirror.com/entities/-/entities-2.2.0.tgz: + resolution: {integrity: sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==, tarball: https://registry.npmmirror.com/entities/-/entities-2.2.0.tgz} + version: 2.2.0 + + esbuild-android-64@0.15.18: + resolution: {integrity: sha512-wnpt3OXRhcjfIDSZu9bnzT4/TNTDsOUvip0foZOUBG7QbSt//w3QV4FInVJxNhKc/ErhUxc5z4QjHtMi7/TbgA==} + engines: {node: '>=12'} + cpu: [x64] + os: [android] + + esbuild-android-arm64@0.15.18: + resolution: {integrity: sha512-G4xu89B8FCzav9XU8EjsXacCKSG2FT7wW9J6hOc18soEHJdtWu03L3TQDGf0geNxfLTtxENKBzMSq9LlbjS8OQ==} + engines: {node: '>=12'} + cpu: [arm64] + os: [android] + + esbuild-darwin-64@0.15.18: + resolution: {integrity: sha512-2WAvs95uPnVJPuYKP0Eqx+Dl/jaYseZEUUT1sjg97TJa4oBtbAKnPnl3b5M9l51/nbx7+QAEtuummJZW0sBEmg==} + engines: {node: '>=12'} + cpu: [x64] + os: [darwin] + + esbuild-darwin-arm64@0.15.18: + resolution: {integrity: sha512-tKPSxcTJ5OmNb1btVikATJ8NftlyNlc8BVNtyT/UAr62JFOhwHlnoPrhYWz09akBLHI9nElFVfWSTSRsrZiDUA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [darwin] + + esbuild-freebsd-64@0.15.18: + resolution: {integrity: sha512-TT3uBUxkteAjR1QbsmvSsjpKjOX6UkCstr8nMr+q7zi3NuZ1oIpa8U41Y8I8dJH2fJgdC3Dj3CXO5biLQpfdZA==} + engines: {node: '>=12'} + cpu: [x64] + os: [freebsd] + + esbuild-freebsd-arm64@0.15.18: + resolution: {integrity: sha512-R/oVr+X3Tkh+S0+tL41wRMbdWtpWB8hEAMsOXDumSSa6qJR89U0S/PpLXrGF7Wk/JykfpWNokERUpCeHDl47wA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [freebsd] + + esbuild-linux-32@0.15.18: + resolution: {integrity: sha512-lphF3HiCSYtaa9p1DtXndiQEeQDKPl9eN/XNoBf2amEghugNuqXNZA/ZovthNE2aa4EN43WroO0B85xVSjYkbg==} + engines: {node: '>=12'} + cpu: [ia32] + os: [linux] + + esbuild-linux-64@0.15.18: + resolution: {integrity: sha512-hNSeP97IviD7oxLKFuii5sDPJ+QHeiFTFLoLm7NZQligur8poNOWGIgpQ7Qf8Balb69hptMZzyOBIPtY09GZYw==} + engines: {node: '>=12'} + cpu: [x64] + os: [linux] + + esbuild-linux-arm64@0.15.18: + resolution: {integrity: sha512-54qr8kg/6ilcxd+0V3h9rjT4qmjc0CccMVWrjOEM/pEcUzt8X62HfBSeZfT2ECpM7104mk4yfQXkosY8Quptug==} + engines: {node: '>=12'} + cpu: [arm64] + os: [linux] + + esbuild-linux-arm@0.15.18: + resolution: {integrity: sha512-UH779gstRblS4aoS2qpMl3wjg7U0j+ygu3GjIeTonCcN79ZvpPee12Qun3vcdxX+37O5LFxz39XeW2I9bybMVA==} + engines: {node: '>=12'} + cpu: [arm] + os: [linux] + + esbuild-linux-mips64le@0.15.18: + resolution: {integrity: sha512-Mk6Ppwzzz3YbMl/ZZL2P0q1tnYqh/trYZ1VfNP47C31yT0K8t9s7Z077QrDA/guU60tGNp2GOwCQnp+DYv7bxQ==} + engines: {node: '>=12'} + cpu: [mips64el] + os: [linux] + + esbuild-linux-ppc64le@0.15.18: + resolution: {integrity: sha512-b0XkN4pL9WUulPTa/VKHx2wLCgvIAbgwABGnKMY19WhKZPT+8BxhZdqz6EgkqCLld7X5qiCY2F/bfpUUlnFZ9w==} + engines: {node: '>=12'} + cpu: [ppc64] + os: [linux] + + esbuild-linux-riscv64@0.15.18: + resolution: {integrity: sha512-ba2COaoF5wL6VLZWn04k+ACZjZ6NYniMSQStodFKH/Pu6RxzQqzsmjR1t9QC89VYJxBeyVPTaHuBMCejl3O/xg==} + engines: {node: '>=12'} + cpu: [riscv64] + os: [linux] + + esbuild-linux-s390x@0.15.18: + resolution: {integrity: sha512-VbpGuXEl5FCs1wDVp93O8UIzl3ZrglgnSQ+Hu79g7hZu6te6/YHgVJxCM2SqfIila0J3k0csfnf8VD2W7u2kzQ==} + engines: {node: '>=12'} + cpu: [s390x] + os: [linux] + + esbuild-netbsd-64@0.15.18: + resolution: {integrity: sha512-98ukeCdvdX7wr1vUYQzKo4kQ0N2p27H7I11maINv73fVEXt2kyh4K4m9f35U1K43Xc2QGXlzAw0K9yoU7JUjOg==} + engines: {node: '>=12'} + cpu: [x64] + os: [netbsd] + + esbuild-openbsd-64@0.15.18: + resolution: {integrity: sha512-yK5NCcH31Uae076AyQAXeJzt/vxIo9+omZRKj1pauhk3ITuADzuOx5N2fdHrAKPxN+zH3w96uFKlY7yIn490xQ==} + engines: {node: '>=12'} + cpu: [x64] + os: [openbsd] + + esbuild-sunos-64@0.15.18: + resolution: {integrity: sha512-On22LLFlBeLNj/YF3FT+cXcyKPEI263nflYlAhz5crxtp3yRG1Ugfr7ITyxmCmjm4vbN/dGrb/B7w7U8yJR9yw==} + engines: {node: '>=12'} + cpu: [x64] + os: [sunos] + + esbuild-windows-32@0.15.18: + resolution: {integrity: sha512-o+eyLu2MjVny/nt+E0uPnBxYuJHBvho8vWsC2lV61A7wwTWC3jkN2w36jtA+yv1UgYkHRihPuQsL23hsCYGcOQ==} + engines: {node: '>=12'} + cpu: [ia32] + os: [win32] + + esbuild-windows-64@0.15.18: + resolution: {integrity: sha512-qinug1iTTaIIrCorAUjR0fcBk24fjzEedFYhhispP8Oc7SFvs+XeW3YpAKiKp8dRpizl4YYAhxMjlftAMJiaUw==} + engines: {node: '>=12'} + cpu: [x64] + os: [win32] + + esbuild-windows-arm64@0.15.18: + resolution: {integrity: sha512-q9bsYzegpZcLziq0zgUi5KqGVtfhjxGbnksaBFYmWLxeV/S1fK4OLdq2DFYnXcLMjlZw2L0jLsk1eGoB522WXQ==} + engines: {node: '>=12'} + cpu: [arm64] + os: [win32] + + esbuild@https://registry.npmmirror.com/esbuild/-/esbuild-0.15.18.tgz: + resolution: {integrity: sha512-x/R72SmW3sSFRm5zrrIjAhCeQSAWoni3CmHEqfQrZIQTM3lVCdehdwuIqaOtfC2slvpdlLa62GYoN8SxT23m6Q==, tarball: https://registry.npmmirror.com/esbuild/-/esbuild-0.15.18.tgz} + version: 0.15.18 + engines: {node: '>=12'} + hasBin: true + + escape-html@1.0.3: + resolution: {integrity: sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==} + + escape-string-regexp@https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz: + resolution: {integrity: sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==, tarball: https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz} + version: 1.0.5 + engines: {node: '>=0.8.0'} + + escape-string-regexp@https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz: + resolution: {integrity: sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==, tarball: https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz} + version: 5.0.0 + engines: {node: '>=12'} + + estree-walker@https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz: + resolution: {integrity: sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==, tarball: https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz} + version: 2.0.2 + + etag@https://registry.npmmirror.com/etag/-/etag-1.8.1.tgz: + resolution: {integrity: sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==, tarball: https://registry.npmmirror.com/etag/-/etag-1.8.1.tgz} + version: 1.8.1 + engines: {node: '>= 0.6'} + + eventemitter3@https://registry.npmmirror.com/eventemitter3/-/eventemitter3-2.0.3.tgz: + resolution: {integrity: sha512-jLN68Dx5kyFHaePoXWPsCGW5qdyZQtLYHkxkg02/Mz6g0kYpDx4FyP6XfArhQdlOC4b8Mv+EMxPo/8La7Tzghg==, tarball: https://registry.npmmirror.com/eventemitter3/-/eventemitter3-2.0.3.tgz} + version: 2.0.3 + + expand-brackets@https://registry.npmmirror.com/expand-brackets/-/expand-brackets-2.1.4.tgz: + resolution: {integrity: sha512-w/ozOKR9Obk3qoWeY/WDi6MFta9AoMR+zud60mdnbniMcBxRuFJyDt2LdX/14A1UABeqk+Uk+LDfUpvoGKppZA==, tarball: https://registry.npmmirror.com/expand-brackets/-/expand-brackets-2.1.4.tgz} + version: 2.1.4 + engines: {node: '>=0.10.0'} + + extend-shallow@https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz: + resolution: {integrity: sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==, tarball: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz} + version: 2.0.1 + engines: {node: '>=0.10.0'} + + extend-shallow@https://registry.npmmirror.com/extend-shallow/-/extend-shallow-3.0.2.tgz: + resolution: {integrity: sha512-BwY5b5Ql4+qZoefgMj2NUmx+tehVTH/Kf4k1ZEtOHNFcm2wSxMRo992l6X3TIgni2eZVTZ85xMOjF31fwZAj6Q==, tarball: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-3.0.2.tgz} + version: 3.0.2 + engines: {node: '>=0.10.0'} + + extend@https://registry.npmmirror.com/extend/-/extend-3.0.2.tgz: + resolution: {integrity: sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==, tarball: https://registry.npmmirror.com/extend/-/extend-3.0.2.tgz} + version: 3.0.2 + + extglob@https://registry.npmmirror.com/extglob/-/extglob-2.0.4.tgz: + resolution: {integrity: sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==, tarball: https://registry.npmmirror.com/extglob/-/extglob-2.0.4.tgz} + version: 2.0.4 + engines: {node: '>=0.10.0'} + + fast-diff@https://registry.npmmirror.com/fast-diff/-/fast-diff-1.1.2.tgz: + resolution: {integrity: sha512-KaJUt+M9t1qaIteSvjc6P3RbMdXsNhK61GRftR6SNxqmhthcd9MGIi4T+o0jD8LUSpSnSKXE20nLtJ3fOHxQig==, tarball: https://registry.npmmirror.com/fast-diff/-/fast-diff-1.1.2.tgz} + version: 1.1.2 + + fast-diff@https://registry.npmmirror.com/fast-diff/-/fast-diff-1.2.0.tgz: + resolution: {integrity: sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==, tarball: https://registry.npmmirror.com/fast-diff/-/fast-diff-1.2.0.tgz} + version: 1.2.0 + + fast-glob@https://registry.npmmirror.com/fast-glob/-/fast-glob-3.2.12.tgz: + resolution: {integrity: sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==, tarball: https://registry.npmmirror.com/fast-glob/-/fast-glob-3.2.12.tgz} + version: 3.2.12 + engines: {node: '>=8.6.0'} + + fastq@https://registry.npmmirror.com/fastq/-/fastq-1.15.0.tgz: + resolution: {integrity: sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==, tarball: https://registry.npmmirror.com/fastq/-/fastq-1.15.0.tgz} + version: 1.15.0 + + file-saver@https://registry.npmmirror.com/file-saver/-/file-saver-2.0.5.tgz: + resolution: {integrity: sha512-P9bmyZ3h/PRG+Nzga+rbdI4OEpNDzAVyy74uVO9ATgzLK6VtAsYybF/+TOCvrc0MO793d6+42lLyZTw7/ArVzA==, tarball: https://registry.npmmirror.com/file-saver/-/file-saver-2.0.5.tgz} + version: 2.0.5 + + fill-range@https://registry.npmmirror.com/fill-range/-/fill-range-4.0.0.tgz: + resolution: {integrity: sha512-VcpLTWqWDiTerugjj8e3+esbg+skS3M9e54UuR3iCeIDMXCLTsAH8hTSzDQU/X6/6t3eYkOKoZSef2PlU6U1XQ==, tarball: https://registry.npmmirror.com/fill-range/-/fill-range-4.0.0.tgz} + version: 4.0.0 + engines: {node: '>=0.10.0'} + + fill-range@https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz: + resolution: {integrity: sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==, tarball: https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz} + version: 7.0.1 + engines: {node: '>=8'} + + follow-redirects@https://registry.npmmirror.com/follow-redirects/-/follow-redirects-1.15.2.tgz: + resolution: {integrity: sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==, tarball: https://registry.npmmirror.com/follow-redirects/-/follow-redirects-1.15.2.tgz} + version: 1.15.2 + engines: {node: '>=4.0'} + peerDependencies: + debug: '*' + peerDependenciesMeta: + debug: + optional: true + + for-in@https://registry.npmmirror.com/for-in/-/for-in-1.0.2.tgz: + resolution: {integrity: sha512-7EwmXrOjyL+ChxMhmG5lnW9MPt1aIeZEwKhQzoBUdTV0N3zuwWDZYVJatDvZ2OyzPUvdIAZDsCetk3coyMfcnQ==, tarball: https://registry.npmmirror.com/for-in/-/for-in-1.0.2.tgz} + version: 1.0.2 + engines: {node: '>=0.10.0'} + + form-data@https://registry.npmmirror.com/form-data/-/form-data-4.0.0.tgz: + resolution: {integrity: sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==, tarball: https://registry.npmmirror.com/form-data/-/form-data-4.0.0.tgz} + version: 4.0.0 + engines: {node: '>= 6'} + + fragment-cache@https://registry.npmmirror.com/fragment-cache/-/fragment-cache-0.2.1.tgz: + resolution: {integrity: sha512-GMBAbW9antB8iZRHLoGw0b3HANt57diZYFO/HL1JGIC1MjKrdmhxvrJbupnVvpys0zsz7yBApXdQyfepKly2kA==, tarball: https://registry.npmmirror.com/fragment-cache/-/fragment-cache-0.2.1.tgz} + version: 0.2.1 + engines: {node: '>=0.10.0'} + + fs-extra@https://registry.npmmirror.com/fs-extra/-/fs-extra-10.1.0.tgz: + resolution: {integrity: sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==, tarball: https://registry.npmmirror.com/fs-extra/-/fs-extra-10.1.0.tgz} + version: 10.1.0 + engines: {node: '>=12'} + + fsevents@2.3.3: + resolution: {integrity: sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==} + engines: {node: ^8.16.0 || ^10.6.0 || >=11.0.0} + os: [darwin] + + function-bind@https://registry.npmmirror.com/function-bind/-/function-bind-1.1.1.tgz: + resolution: {integrity: sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==, tarball: https://registry.npmmirror.com/function-bind/-/function-bind-1.1.1.tgz} + version: 1.1.1 + + functions-have-names@https://registry.npmmirror.com/functions-have-names/-/functions-have-names-1.2.3.tgz: + resolution: {integrity: sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==, tarball: https://registry.npmmirror.com/functions-have-names/-/functions-have-names-1.2.3.tgz} + version: 1.2.3 + + fuse.js@https://registry.npmmirror.com/fuse.js/-/fuse.js-6.6.2.tgz: + resolution: {integrity: sha512-cJaJkxCCxC8qIIcPBF9yGxY0W/tVZS3uEISDxhYIdtk8OL93pe+6Zj7LjCqVV4dzbqcriOZ+kQ/NE4RXZHsIGA==, tarball: https://registry.npmmirror.com/fuse.js/-/fuse.js-6.6.2.tgz} + version: 6.6.2 + engines: {node: '>=10'} + + get-intrinsic@https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.2.1.tgz: + resolution: {integrity: sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==, tarball: https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.2.1.tgz} + version: 1.2.1 + + get-value@https://registry.npmmirror.com/get-value/-/get-value-2.0.6.tgz: + resolution: {integrity: sha512-Ln0UQDlxH1BapMu3GPtf7CuYNwRZf2gwCuPqbyG6pB8WfmFpzqcy4xtAaAMUhnNqjMKTiCPZG2oMT3YSx8U2NA==, tarball: https://registry.npmmirror.com/get-value/-/get-value-2.0.6.tgz} + version: 2.0.6 + engines: {node: '>=0.10.0'} + + glob-parent@https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz: + resolution: {integrity: sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==, tarball: https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz} + version: 5.1.2 + engines: {node: '>= 6'} + + graceful-fs@4.2.11: + resolution: {integrity: sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==} + + graceful-fs@https://registry.npmmirror.com/graceful-fs/-/graceful-fs-4.2.11.tgz: + resolution: {integrity: sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==, tarball: https://registry.npmmirror.com/graceful-fs/-/graceful-fs-4.2.11.tgz} + version: 4.2.11 + + has-ansi@https://registry.npmmirror.com/has-ansi/-/has-ansi-2.0.0.tgz: + resolution: {integrity: sha512-C8vBJ8DwUCx19vhm7urhTuUsr4/IyP6l4VzNQDv+ryHQObW3TTTp9yB68WpYgRe2bbaGuZ/se74IqFeVnMnLZg==, tarball: https://registry.npmmirror.com/has-ansi/-/has-ansi-2.0.0.tgz} + version: 2.0.0 + engines: {node: '>=0.10.0'} + + has-flag@https://registry.npmmirror.com/has-flag/-/has-flag-1.0.0.tgz: + resolution: {integrity: sha512-DyYHfIYwAJmjAjSSPKANxI8bFY9YtFrgkAfinBojQ8YJTOuOuav64tMUJv584SES4xl74PmuaevIyaLESHdTAA==, tarball: https://registry.npmmirror.com/has-flag/-/has-flag-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + has-flag@https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz: + resolution: {integrity: sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==, tarball: https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz} + version: 4.0.0 + engines: {node: '>=8'} + + has-property-descriptors@https://registry.npmmirror.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz: + resolution: {integrity: sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==, tarball: https://registry.npmmirror.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz} + version: 1.0.0 + + has-proto@https://registry.npmmirror.com/has-proto/-/has-proto-1.0.1.tgz: + resolution: {integrity: sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==, tarball: https://registry.npmmirror.com/has-proto/-/has-proto-1.0.1.tgz} + version: 1.0.1 + engines: {node: '>= 0.4'} + + has-symbols@https://registry.npmmirror.com/has-symbols/-/has-symbols-1.0.3.tgz: + resolution: {integrity: sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==, tarball: https://registry.npmmirror.com/has-symbols/-/has-symbols-1.0.3.tgz} + version: 1.0.3 + engines: {node: '>= 0.4'} + + has-tostringtag@https://registry.npmmirror.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz: + resolution: {integrity: sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==, tarball: https://registry.npmmirror.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>= 0.4'} + + has-value@https://registry.npmmirror.com/has-value/-/has-value-0.3.1.tgz: + resolution: {integrity: sha512-gpG936j8/MzaeID5Yif+577c17TxaDmhuyVgSwtnL/q8UUTySg8Mecb+8Cf1otgLoD7DDH75axp86ER7LFsf3Q==, tarball: https://registry.npmmirror.com/has-value/-/has-value-0.3.1.tgz} + version: 0.3.1 + engines: {node: '>=0.10.0'} + + has-value@https://registry.npmmirror.com/has-value/-/has-value-1.0.0.tgz: + resolution: {integrity: sha512-IBXk4GTsLYdQ7Rvt+GRBrFSVEkmuOUy4re0Xjd9kJSUQpnTrWR4/y9RpfexN9vkAPMFuQoeWKwqzPozRTlasGw==, tarball: https://registry.npmmirror.com/has-value/-/has-value-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + has-values@https://registry.npmmirror.com/has-values/-/has-values-0.1.4.tgz: + resolution: {integrity: sha512-J8S0cEdWuQbqD9//tlZxiMuMNmxB8PlEwvYwuxsTmR1G5RXUePEX/SJn7aD0GMLieuZYSwNH0cQuJGwnYunXRQ==, tarball: https://registry.npmmirror.com/has-values/-/has-values-0.1.4.tgz} + version: 0.1.4 + engines: {node: '>=0.10.0'} + + has-values@https://registry.npmmirror.com/has-values/-/has-values-1.0.0.tgz: + resolution: {integrity: sha512-ODYZC64uqzmtfGMEAX/FvZiRyWLpAC3vYnNunURUnkGVTS+mI0smVsWaPydRBsE3g+ok7h960jChO8mFcWlHaQ==, tarball: https://registry.npmmirror.com/has-values/-/has-values-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + has@https://registry.npmmirror.com/has/-/has-1.0.3.tgz: + resolution: {integrity: sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==, tarball: https://registry.npmmirror.com/has/-/has-1.0.3.tgz} + version: 1.0.3 + engines: {node: '>= 0.4.0'} + + he@https://registry.npmmirror.com/he/-/he-1.2.0.tgz: + resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==, tarball: https://registry.npmmirror.com/he/-/he-1.2.0.tgz} + version: 1.2.0 + hasBin: true + + htmlparser2@https://registry.npmmirror.com/htmlparser2/-/htmlparser2-3.10.1.tgz: + resolution: {integrity: sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ==, tarball: https://registry.npmmirror.com/htmlparser2/-/htmlparser2-3.10.1.tgz} + version: 3.10.1 + + image-size@https://registry.npmmirror.com/image-size/-/image-size-0.5.5.tgz: + resolution: {integrity: sha512-6TDAlDPZxUFCv+fuOkIoXT/V/f3Qbq8e37p+YOiYrUv3v9cc3/6x78VdfPgFVaB9dZYeLUfKgHRebpkm/oP2VQ==, tarball: https://registry.npmmirror.com/image-size/-/image-size-0.5.5.tgz} + version: 0.5.5 + engines: {node: '>=0.10.0'} + hasBin: true + + immutable@https://registry.npmmirror.com/immutable/-/immutable-4.3.0.tgz: + resolution: {integrity: sha512-0AOCmOip+xgJwEVTQj1EfiDDOkPmuyllDuTuEX+DDXUgapLAsBIfkg3sxCYyCEA8mQqZrrxPUGjcOQ2JS3WLkg==, tarball: https://registry.npmmirror.com/immutable/-/immutable-4.3.0.tgz} + version: 4.3.0 + + inherits@https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz: + resolution: {integrity: sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==, tarball: https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz} + version: 2.0.4 + + is-accessor-descriptor@https://registry.npmmirror.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz: + resolution: {integrity: sha512-e1BM1qnDbMRG3ll2U9dSK0UMHuWOs3pY3AtcFsmvwPtKL3MML/Q86i+GilLfvqEs4GW+ExB91tQ3Ig9noDIZ+A==, tarball: https://registry.npmmirror.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz} + version: 0.1.6 + engines: {node: '>=0.10.0'} + + is-accessor-descriptor@https://registry.npmmirror.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz: + resolution: {integrity: sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==, tarball: https://registry.npmmirror.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + is-arguments@https://registry.npmmirror.com/is-arguments/-/is-arguments-1.1.1.tgz: + resolution: {integrity: sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA==, tarball: https://registry.npmmirror.com/is-arguments/-/is-arguments-1.1.1.tgz} + version: 1.1.1 + engines: {node: '>= 0.4'} + + is-binary-path@https://registry.npmmirror.com/is-binary-path/-/is-binary-path-2.1.0.tgz: + resolution: {integrity: sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==, tarball: https://registry.npmmirror.com/is-binary-path/-/is-binary-path-2.1.0.tgz} + version: 2.1.0 + engines: {node: '>=8'} + + is-buffer@https://registry.npmmirror.com/is-buffer/-/is-buffer-1.1.6.tgz: + resolution: {integrity: sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==, tarball: https://registry.npmmirror.com/is-buffer/-/is-buffer-1.1.6.tgz} + version: 1.1.6 + + is-core-module@https://registry.npmmirror.com/is-core-module/-/is-core-module-2.12.1.tgz: + resolution: {integrity: sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==, tarball: https://registry.npmmirror.com/is-core-module/-/is-core-module-2.12.1.tgz} + version: 2.12.1 + + is-data-descriptor@https://registry.npmmirror.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz: + resolution: {integrity: sha512-+w9D5ulSoBNlmw9OHn3U2v51SyoCd0he+bB3xMl62oijhrspxowjU+AIcDY0N3iEJbUEkB15IlMASQsxYigvXg==, tarball: https://registry.npmmirror.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz} + version: 0.1.4 + engines: {node: '>=0.10.0'} + + is-data-descriptor@https://registry.npmmirror.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz: + resolution: {integrity: sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==, tarball: https://registry.npmmirror.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + is-date-object@https://registry.npmmirror.com/is-date-object/-/is-date-object-1.0.5.tgz: + resolution: {integrity: sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==, tarball: https://registry.npmmirror.com/is-date-object/-/is-date-object-1.0.5.tgz} + version: 1.0.5 + engines: {node: '>= 0.4'} + + is-descriptor@https://registry.npmmirror.com/is-descriptor/-/is-descriptor-0.1.6.tgz: + resolution: {integrity: sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==, tarball: https://registry.npmmirror.com/is-descriptor/-/is-descriptor-0.1.6.tgz} + version: 0.1.6 + engines: {node: '>=0.10.0'} + + is-descriptor@https://registry.npmmirror.com/is-descriptor/-/is-descriptor-1.0.2.tgz: + resolution: {integrity: sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==, tarball: https://registry.npmmirror.com/is-descriptor/-/is-descriptor-1.0.2.tgz} + version: 1.0.2 + engines: {node: '>=0.10.0'} + + is-extendable@https://registry.npmmirror.com/is-extendable/-/is-extendable-0.1.1.tgz: + resolution: {integrity: sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==, tarball: https://registry.npmmirror.com/is-extendable/-/is-extendable-0.1.1.tgz} + version: 0.1.1 + engines: {node: '>=0.10.0'} + + is-extendable@https://registry.npmmirror.com/is-extendable/-/is-extendable-1.0.1.tgz: + resolution: {integrity: sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==, tarball: https://registry.npmmirror.com/is-extendable/-/is-extendable-1.0.1.tgz} + version: 1.0.1 + engines: {node: '>=0.10.0'} + + is-extglob@https://registry.npmmirror.com/is-extglob/-/is-extglob-2.1.1.tgz: + resolution: {integrity: sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==, tarball: https://registry.npmmirror.com/is-extglob/-/is-extglob-2.1.1.tgz} + version: 2.1.1 + engines: {node: '>=0.10.0'} + + is-glob@https://registry.npmmirror.com/is-glob/-/is-glob-4.0.3.tgz: + resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==, tarball: https://registry.npmmirror.com/is-glob/-/is-glob-4.0.3.tgz} + version: 4.0.3 + engines: {node: '>=0.10.0'} + + is-number@https://registry.npmmirror.com/is-number/-/is-number-3.0.0.tgz: + resolution: {integrity: sha512-4cboCqIpliH+mAvFNegjZQ4kgKc3ZUhQVr3HvWbSh5q3WH2v82ct+T2Y1hdU5Gdtorx/cLifQjqCbL7bpznLTg==, tarball: https://registry.npmmirror.com/is-number/-/is-number-3.0.0.tgz} + version: 3.0.0 + engines: {node: '>=0.10.0'} + + is-number@https://registry.npmmirror.com/is-number/-/is-number-7.0.0.tgz: + resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==, tarball: https://registry.npmmirror.com/is-number/-/is-number-7.0.0.tgz} + version: 7.0.0 + engines: {node: '>=0.12.0'} + + is-plain-obj@https://registry.npmmirror.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz: + resolution: {integrity: sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg==, tarball: https://registry.npmmirror.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz} + version: 1.1.0 + engines: {node: '>=0.10.0'} + + is-plain-object@https://registry.npmmirror.com/is-plain-object/-/is-plain-object-2.0.4.tgz: + resolution: {integrity: sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==, tarball: https://registry.npmmirror.com/is-plain-object/-/is-plain-object-2.0.4.tgz} + version: 2.0.4 + engines: {node: '>=0.10.0'} + + is-regex@https://registry.npmmirror.com/is-regex/-/is-regex-1.1.4.tgz: + resolution: {integrity: sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==, tarball: https://registry.npmmirror.com/is-regex/-/is-regex-1.1.4.tgz} + version: 1.1.4 + engines: {node: '>= 0.4'} + + is-windows@https://registry.npmmirror.com/is-windows/-/is-windows-1.0.2.tgz: + resolution: {integrity: sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==, tarball: https://registry.npmmirror.com/is-windows/-/is-windows-1.0.2.tgz} + version: 1.0.2 + engines: {node: '>=0.10.0'} + + isarray@https://registry.npmmirror.com/isarray/-/isarray-1.0.0.tgz: + resolution: {integrity: sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==, tarball: https://registry.npmmirror.com/isarray/-/isarray-1.0.0.tgz} + version: 1.0.0 + + isobject@https://registry.npmmirror.com/isobject/-/isobject-2.1.0.tgz: + resolution: {integrity: sha512-+OUdGJlgjOBZDfxnDjYYG6zp487z0JGNQq3cYQYg5f5hKR+syHMsaztzGeml/4kGG55CSpKSpWTY+jYGgsHLgA==, tarball: https://registry.npmmirror.com/isobject/-/isobject-2.1.0.tgz} + version: 2.1.0 + engines: {node: '>=0.10.0'} + + isobject@https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz: + resolution: {integrity: sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==, tarball: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz} + version: 3.0.1 + engines: {node: '>=0.10.0'} + + js-base64@https://registry.npmmirror.com/js-base64/-/js-base64-2.6.4.tgz: + resolution: {integrity: sha512-pZe//GGmwJndub7ZghVHz7vjb2LgC1m8B07Au3eYqeqv9emhESByMXxaEgkUkEqJe87oBbSniGYoQNIBklc7IQ==, tarball: https://registry.npmmirror.com/js-base64/-/js-base64-2.6.4.tgz} + version: 2.6.4 + + js-cookie@https://registry.npmmirror.com/js-cookie/-/js-cookie-3.0.1.tgz: + resolution: {integrity: sha512-+0rgsUXZu4ncpPxRL+lNEptWMOWl9etvPHc/koSRp6MPwpRYAhmk0dUG00J4bxVV3r9uUzfo24wW0knS07SKSw==, tarball: https://registry.npmmirror.com/js-cookie/-/js-cookie-3.0.1.tgz} + version: 3.0.1 + engines: {node: '>=12'} + + jsencrypt@https://registry.npmmirror.com/jsencrypt/-/jsencrypt-3.3.1.tgz: + resolution: {integrity: sha512-dVvV54GdFuJgmEKn+oBiaifDMen4p6o6j/lJh0OVMcouME8sST0bJ7bldIgKBQk4za0zyGn0/pm4vOznR25mLw==, tarball: https://registry.npmmirror.com/jsencrypt/-/jsencrypt-3.3.1.tgz} + version: 3.3.1 + + json5@https://registry.npmmirror.com/json5/-/json5-1.0.2.tgz: + resolution: {integrity: sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==, tarball: https://registry.npmmirror.com/json5/-/json5-1.0.2.tgz} + version: 1.0.2 + hasBin: true + + jsonc-parser@https://registry.npmmirror.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz: + resolution: {integrity: sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==, tarball: https://registry.npmmirror.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz} + version: 3.2.0 + + jsonfile@https://registry.npmmirror.com/jsonfile/-/jsonfile-6.1.0.tgz: + resolution: {integrity: sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==, tarball: https://registry.npmmirror.com/jsonfile/-/jsonfile-6.1.0.tgz} + version: 6.1.0 + + kind-of@https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz: + resolution: {integrity: sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ==, tarball: https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz} + version: 3.2.2 + engines: {node: '>=0.10.0'} + + kind-of@https://registry.npmmirror.com/kind-of/-/kind-of-4.0.0.tgz: + resolution: {integrity: sha512-24XsCxmEbRwEDbz/qz3stgin8TTzZ1ESR56OMCN0ujYg+vRutNSiOj9bHH9u85DKgXguraugV5sFuvbD4FW/hw==, tarball: https://registry.npmmirror.com/kind-of/-/kind-of-4.0.0.tgz} + version: 4.0.0 + engines: {node: '>=0.10.0'} + + kind-of@https://registry.npmmirror.com/kind-of/-/kind-of-5.1.0.tgz: + resolution: {integrity: sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==, tarball: https://registry.npmmirror.com/kind-of/-/kind-of-5.1.0.tgz} + version: 5.1.0 + engines: {node: '>=0.10.0'} + + kind-of@https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz: + resolution: {integrity: sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==, tarball: https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz} + version: 6.0.3 + engines: {node: '>=0.10.0'} + + loader-utils@https://registry.npmmirror.com/loader-utils/-/loader-utils-1.4.2.tgz: + resolution: {integrity: sha512-I5d00Pd/jwMD2QCduo657+YM/6L3KZu++pmX9VFncxaxvHcru9jx1lBaFft+r4Mt2jK0Yhp41XlRAihzPxHNCg==, tarball: https://registry.npmmirror.com/loader-utils/-/loader-utils-1.4.2.tgz} + version: 1.4.2 + engines: {node: '>=4.0.0'} + + local-pkg@https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz: + resolution: {integrity: sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==, tarball: https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz} + version: 0.4.3 + engines: {node: '>=14'} + + lodash-es@4.17.21: + resolution: {integrity: sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==} + + lodash-unified@1.0.3: + resolution: {integrity: sha512-WK9qSozxXOD7ZJQlpSqOT+om2ZfcT4yO+03FuzAHD0wF6S0l0090LRPDx3vhTTLZ8cFKpBn+IOcVXK6qOcIlfQ==} + peerDependencies: + '@types/lodash-es': '*' + lodash: '*' + lodash-es: '*' + + lodash.clonedeep@https://registry.npmmirror.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz: + resolution: {integrity: sha512-H5ZhCF25riFd9uB5UCkVKo61m3S/xZk1x4wA6yp/L3RFP6Z/eHH1ymQcGLo7J3GMPfm0V/7m1tryHuGVxpqEBQ==, tarball: https://registry.npmmirror.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz} + version: 4.5.0 + + lodash.isequal@https://registry.npmmirror.com/lodash.isequal/-/lodash.isequal-4.5.0.tgz: + resolution: {integrity: sha512-pDo3lu8Jhfjqls6GkMgpahsF9kCyayhgykjyLMNFTKWrpVdAQtYyB4muAMWozBB4ig/dtWAmsMxLEI8wuz+DYQ==, tarball: https://registry.npmmirror.com/lodash.isequal/-/lodash.isequal-4.5.0.tgz} + version: 4.5.0 + + lodash@4.17.21: + resolution: {integrity: sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==} + + magic-string@https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz: + resolution: {integrity: sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==, tarball: https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz} + version: 0.25.9 + + magic-string@https://registry.npmmirror.com/magic-string/-/magic-string-0.26.7.tgz: + resolution: {integrity: sha512-hX9XH3ziStPoPhJxLq1syWuZMxbDvGNbVchfrdCtanC7D13888bMFow61x8axrx+GfHLtVeAx2kxL7tTGRl+Ow==, tarball: https://registry.npmmirror.com/magic-string/-/magic-string-0.26.7.tgz} + version: 0.26.7 + engines: {node: '>=12'} + + map-cache@https://registry.npmmirror.com/map-cache/-/map-cache-0.2.2.tgz: + resolution: {integrity: sha512-8y/eV9QQZCiyn1SprXSrCmqJN0yNRATe+PO8ztwqrvrbdRLA3eYJF0yaR0YayLWkMbsQSKWS9N2gPcGEc4UsZg==, tarball: https://registry.npmmirror.com/map-cache/-/map-cache-0.2.2.tgz} + version: 0.2.2 + engines: {node: '>=0.10.0'} + + map-visit@https://registry.npmmirror.com/map-visit/-/map-visit-1.0.0.tgz: + resolution: {integrity: sha512-4y7uGv8bd2WdM9vpQsiQNo41Ln1NvhvDRuVt0k2JZQ+ezN2uaQes7lZeZ+QQUHOLQAtDaBJ+7wCbi+ab/KFs+w==, tarball: https://registry.npmmirror.com/map-visit/-/map-visit-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + mdn-data@https://registry.npmmirror.com/mdn-data/-/mdn-data-2.0.14.tgz: + resolution: {integrity: sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow==, tarball: https://registry.npmmirror.com/mdn-data/-/mdn-data-2.0.14.tgz} + version: 2.0.14 + + memoize-one@6.0.0: + resolution: {integrity: sha512-rkpe71W0N0c0Xz6QD0eJETuWAJGnJ9afsl1srmwPrI+yBCkge5EycXXbYRyvL29zZVUWQCY7InPRCv3GDXuZNw==} + + merge-options@https://registry.npmmirror.com/merge-options/-/merge-options-1.0.1.tgz: + resolution: {integrity: sha512-iuPV41VWKWBIOpBsjoxjDZw8/GbSfZ2mk7N1453bwMrfzdrIk7EzBd+8UVR6rkw67th7xnk9Dytl3J+lHPdxvg==, tarball: https://registry.npmmirror.com/merge-options/-/merge-options-1.0.1.tgz} + version: 1.0.1 + engines: {node: '>=4'} + + merge2@https://registry.npmmirror.com/merge2/-/merge2-1.4.1.tgz: + resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==, tarball: https://registry.npmmirror.com/merge2/-/merge2-1.4.1.tgz} + version: 1.4.1 + engines: {node: '>= 8'} + + mescroll.js@https://registry.npmmirror.com/mescroll.js/-/mescroll.js-1.4.2.tgz: + resolution: {integrity: sha512-tZDucS9DXUrIfTGXTY2L7e4mGLIQ8uMqY2GOaQAGrCHQssUADOIM0kcQlRCA6U6ffFPxXV4D+IbhzOy3zVQ1wA==, tarball: https://registry.npmmirror.com/mescroll.js/-/mescroll.js-1.4.2.tgz} + version: 1.4.2 + + micromatch@https://registry.npmmirror.com/micromatch/-/micromatch-3.1.0.tgz: + resolution: {integrity: sha512-3StSelAE+hnRvMs8IdVW7Uhk8CVed5tp+kLLGlBP6WiRAXS21GPGu/Nat4WNPXj2Eoc24B02SaeoyozPMfj0/g==, tarball: https://registry.npmmirror.com/micromatch/-/micromatch-3.1.0.tgz} + version: 3.1.0 + engines: {node: '>=0.10.0'} + + micromatch@https://registry.npmmirror.com/micromatch/-/micromatch-4.0.5.tgz: + resolution: {integrity: sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==, tarball: https://registry.npmmirror.com/micromatch/-/micromatch-4.0.5.tgz} + version: 4.0.5 + engines: {node: '>=8.6'} + + mime-db@https://registry.npmmirror.com/mime-db/-/mime-db-1.52.0.tgz: + resolution: {integrity: sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==, tarball: https://registry.npmmirror.com/mime-db/-/mime-db-1.52.0.tgz} + version: 1.52.0 + engines: {node: '>= 0.6'} + + mime-types@https://registry.npmmirror.com/mime-types/-/mime-types-2.1.35.tgz: + resolution: {integrity: sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==, tarball: https://registry.npmmirror.com/mime-types/-/mime-types-2.1.35.tgz} + version: 2.1.35 + engines: {node: '>= 0.6'} + + minimist@https://registry.npmmirror.com/minimist/-/minimist-1.2.8.tgz: + resolution: {integrity: sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==, tarball: https://registry.npmmirror.com/minimist/-/minimist-1.2.8.tgz} + version: 1.2.8 + + mixin-deep@https://registry.npmmirror.com/mixin-deep/-/mixin-deep-1.3.2.tgz: + resolution: {integrity: sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==, tarball: https://registry.npmmirror.com/mixin-deep/-/mixin-deep-1.3.2.tgz} + version: 1.3.2 + engines: {node: '>=0.10.0'} + + mlly@https://registry.npmmirror.com/mlly/-/mlly-1.3.0.tgz: + resolution: {integrity: sha512-HT5mcgIQKkOrZecOjOX3DJorTikWXwsBfpcr/MGBkhfWcjiqvnaL/9ppxvIUXfjT6xt4DVIAsN9fMUz1ev4bIw==, tarball: https://registry.npmmirror.com/mlly/-/mlly-1.3.0.tgz} + version: 1.3.0 + + ms@https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz: + resolution: {integrity: sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==, tarball: https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz} + version: 2.0.0 + + ms@https://registry.npmmirror.com/ms/-/ms-2.1.2.tgz: + resolution: {integrity: sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==, tarball: https://registry.npmmirror.com/ms/-/ms-2.1.2.tgz} + version: 2.1.2 + + nanoid@https://registry.npmmirror.com/nanoid/-/nanoid-3.3.6.tgz: + resolution: {integrity: sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==, tarball: https://registry.npmmirror.com/nanoid/-/nanoid-3.3.6.tgz} + version: 3.3.6 + engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} + hasBin: true + + nanomatch@https://registry.npmmirror.com/nanomatch/-/nanomatch-1.2.13.tgz: + resolution: {integrity: sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==, tarball: https://registry.npmmirror.com/nanomatch/-/nanomatch-1.2.13.tgz} + version: 1.2.13 + engines: {node: '>=0.10.0'} + + normalize-path@https://registry.npmmirror.com/normalize-path/-/normalize-path-3.0.0.tgz: + resolution: {integrity: sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==, tarball: https://registry.npmmirror.com/normalize-path/-/normalize-path-3.0.0.tgz} + version: 3.0.0 + engines: {node: '>=0.10.0'} + + normalize-wheel-es@1.2.0: + resolution: {integrity: sha512-Wj7+EJQ8mSuXr2iWfnujrimU35R2W4FAErEyTmJoJ7ucwTn2hOUSsRehMb5RSYkxXGTM7Y9QpvPmp++w5ftoJw==} + + nprogress@https://registry.npmmirror.com/nprogress/-/nprogress-0.2.0.tgz: + resolution: {integrity: sha512-I19aIingLgR1fmhftnbWWO3dXc0hSxqHQHQb3H8m+K3TnEn/iSeTZZOyvKXWqQESMwuUVnatlCnZdLBZZt2VSA==, tarball: https://registry.npmmirror.com/nprogress/-/nprogress-0.2.0.tgz} + version: 0.2.0 + + nth-check@https://registry.npmmirror.com/nth-check/-/nth-check-2.1.1.tgz: + resolution: {integrity: sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==, tarball: https://registry.npmmirror.com/nth-check/-/nth-check-2.1.1.tgz} + version: 2.1.1 + + object-assign@https://registry.npmmirror.com/object-assign/-/object-assign-4.1.1.tgz: + resolution: {integrity: sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==, tarball: https://registry.npmmirror.com/object-assign/-/object-assign-4.1.1.tgz} + version: 4.1.1 + engines: {node: '>=0.10.0'} + + object-copy@https://registry.npmmirror.com/object-copy/-/object-copy-0.1.0.tgz: + resolution: {integrity: sha512-79LYn6VAb63zgtmAteVOWo9Vdj71ZVBy3Pbse+VqxDpEP83XuujMrGqHIwAXJ5I/aM0zU7dIyIAhifVTPrNItQ==, tarball: https://registry.npmmirror.com/object-copy/-/object-copy-0.1.0.tgz} + version: 0.1.0 + engines: {node: '>=0.10.0'} + + object-is@https://registry.npmmirror.com/object-is/-/object-is-1.1.5.tgz: + resolution: {integrity: sha512-3cyDsyHgtmi7I7DfSSI2LDp6SK2lwvtbg0p0R1e0RvTqF5ceGx+K2dfSjm1bKDMVCFEDAQvy+o8c6a7VujOddw==, tarball: https://registry.npmmirror.com/object-is/-/object-is-1.1.5.tgz} + version: 1.1.5 + engines: {node: '>= 0.4'} + + object-keys@https://registry.npmmirror.com/object-keys/-/object-keys-1.1.1.tgz: + resolution: {integrity: sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==, tarball: https://registry.npmmirror.com/object-keys/-/object-keys-1.1.1.tgz} + version: 1.1.1 + engines: {node: '>= 0.4'} + + object-visit@https://registry.npmmirror.com/object-visit/-/object-visit-1.0.1.tgz: + resolution: {integrity: sha512-GBaMwwAVK9qbQN3Scdo0OyvgPW7l3lnaVMj84uTOZlswkX0KpF6fyDBJhtTthf7pymztoN36/KEr1DyhF96zEA==, tarball: https://registry.npmmirror.com/object-visit/-/object-visit-1.0.1.tgz} + version: 1.0.1 + engines: {node: '>=0.10.0'} + + object.pick@https://registry.npmmirror.com/object.pick/-/object.pick-1.3.0.tgz: + resolution: {integrity: sha512-tqa/UMy/CCoYmj+H5qc07qvSL9dqcs/WZENZ1JbtWBlATP+iVOe778gE6MSijnyCnORzDuX6hU+LA4SZ09YjFQ==, tarball: https://registry.npmmirror.com/object.pick/-/object.pick-1.3.0.tgz} + version: 1.3.0 + engines: {node: '>=0.10.0'} + + parchment@https://registry.npmmirror.com/parchment/-/parchment-1.1.4.tgz: + resolution: {integrity: sha512-J5FBQt/pM2inLzg4hEWmzQx/8h8D0CiDxaG3vyp9rKrQRSDgBlhjdP5jQGgosEajXPSQouXGHOmVdgo7QmJuOg==, tarball: https://registry.npmmirror.com/parchment/-/parchment-1.1.4.tgz} + version: 1.1.4 + + pascalcase@https://registry.npmmirror.com/pascalcase/-/pascalcase-0.1.1.tgz: + resolution: {integrity: sha512-XHXfu/yOQRy9vYOtUDVMN60OEJjW013GoObG1o+xwQTpB9eYJX/BjXMsdW13ZDPruFhYYn0AG22w0xgQMwl3Nw==, tarball: https://registry.npmmirror.com/pascalcase/-/pascalcase-0.1.1.tgz} + version: 0.1.1 + engines: {node: '>=0.10.0'} + + path-parse@https://registry.npmmirror.com/path-parse/-/path-parse-1.0.7.tgz: + resolution: {integrity: sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==, tarball: https://registry.npmmirror.com/path-parse/-/path-parse-1.0.7.tgz} + version: 1.0.7 + + pathe@https://registry.npmmirror.com/pathe/-/pathe-0.2.0.tgz: + resolution: {integrity: sha512-sTitTPYnn23esFR3RlqYBWn4c45WGeLcsKzQiUpXJAyfcWkolvlYpV8FLo7JishK946oQwMFUCHXQ9AjGPKExw==, tarball: https://registry.npmmirror.com/pathe/-/pathe-0.2.0.tgz} + version: 0.2.0 + + pathe@https://registry.npmmirror.com/pathe/-/pathe-1.1.0.tgz: + resolution: {integrity: sha512-ODbEPR0KKHqECXW1GoxdDb+AZvULmXjVPy4rt+pGo2+TnjJTIPJQSVS6N63n8T2Ip+syHhbn52OewKicV0373w==, tarball: https://registry.npmmirror.com/pathe/-/pathe-1.1.0.tgz} + version: 1.1.0 + + picocolors@https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz: + resolution: {integrity: sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==, tarball: https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz} + version: 1.0.0 + + picomatch@https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz: + resolution: {integrity: sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==, tarball: https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz} + version: 2.3.1 + engines: {node: '>=8.6'} + + pinia-plugin-persist@https://registry.npmmirror.com/pinia-plugin-persist/-/pinia-plugin-persist-1.0.0.tgz: + resolution: {integrity: sha512-M4hBBd8fz/GgNmUPaaUsC29y1M09lqbXrMAHcusVoU8xlQi1TqgkWnnhvMikZwr7Le/hVyMx8KUcumGGrR6GVw==, tarball: https://registry.npmmirror.com/pinia-plugin-persist/-/pinia-plugin-persist-1.0.0.tgz} + version: 1.0.0 + peerDependencies: + '@vue/composition-api': ^1.0.0 + pinia: ^2.0.0 + vue: ^2.0.0 || >=3.0.0 + peerDependenciesMeta: + '@vue/composition-api': + optional: true + + pinia@https://registry.npmmirror.com/pinia/-/pinia-2.0.22.tgz: + resolution: {integrity: sha512-u+b8/BC+tmvo3ACbYO2w5NfxHWFOjvvw9DQnyT0dW8aUMCPRQT5QnfZ5R5W2MzZBMTeZRMQI7V/QFbafmM9QHw==, tarball: https://registry.npmmirror.com/pinia/-/pinia-2.0.22.tgz} + version: 2.0.22 + peerDependencies: + '@vue/composition-api': ^1.4.0 + typescript: '>=4.4.4' + vue: ^2.6.14 || ^3.2.0 + peerDependenciesMeta: + '@vue/composition-api': + optional: true + typescript: + optional: true + + pkg-types@https://registry.npmmirror.com/pkg-types/-/pkg-types-1.0.3.tgz: + resolution: {integrity: sha512-nN7pYi0AQqJnoLPC9eHFQ8AcyaixBUOwvqc5TDnIKCMEE6I0y8P7OKA7fPexsXGCGxQDl/cmrLAp26LhcwxZ4A==, tarball: https://registry.npmmirror.com/pkg-types/-/pkg-types-1.0.3.tgz} + version: 1.0.3 + + posix-character-classes@https://registry.npmmirror.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz: + resolution: {integrity: sha512-xTgYBc3fuo7Yt7JbiuFxSYGToMoz8fLoE6TC9Wx1P/u+LfeThMOAqmuyECnlBaaJb+u1m9hHiXUEtwW4OzfUJg==, tarball: https://registry.npmmirror.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz} + version: 0.1.1 + engines: {node: '>=0.10.0'} + + postcss-prefix-selector@https://registry.npmmirror.com/postcss-prefix-selector/-/postcss-prefix-selector-1.16.0.tgz: + resolution: {integrity: sha512-rdVMIi7Q4B0XbXqNUEI+Z4E+pueiu/CS5E6vRCQommzdQ/sgsS4dK42U7GX8oJR+TJOtT+Qv3GkNo6iijUMp3Q==, tarball: https://registry.npmmirror.com/postcss-prefix-selector/-/postcss-prefix-selector-1.16.0.tgz} + version: 1.16.0 + peerDependencies: + postcss: '>4 <9' + + postcss@https://registry.npmmirror.com/postcss/-/postcss-5.2.18.tgz: + resolution: {integrity: sha512-zrUjRRe1bpXKsX1qAJNJjqZViErVuyEkMTRrwu4ud4sbTtIBRmtaYDrHmcGgmrbsW3MHfmtIf+vJumgQn+PrXg==, tarball: https://registry.npmmirror.com/postcss/-/postcss-5.2.18.tgz} + version: 5.2.18 + engines: {node: '>=0.12'} + + postcss@https://registry.npmmirror.com/postcss/-/postcss-8.4.23.tgz: + resolution: {integrity: sha512-bQ3qMcpF6A/YjR55xtoTr0jGOlnPOKAIMdOWiv0EIT6HVPEaJiJB4NLljSbiHoC2RX7DN5Uvjtpbg1NPdwv1oA==, tarball: https://registry.npmmirror.com/postcss/-/postcss-8.4.23.tgz} + version: 8.4.23 + engines: {node: ^10 || ^12 || >=14} + + posthtml-parser@https://registry.npmmirror.com/posthtml-parser/-/posthtml-parser-0.2.1.tgz: + resolution: {integrity: sha512-nPC53YMqJnc/+1x4fRYFfm81KV2V+G9NZY+hTohpYg64Ay7NemWWcV4UWuy/SgMupqQ3kJ88M/iRfZmSnxT+pw==, tarball: https://registry.npmmirror.com/posthtml-parser/-/posthtml-parser-0.2.1.tgz} + version: 0.2.1 + + posthtml-rename-id@https://registry.npmmirror.com/posthtml-rename-id/-/posthtml-rename-id-1.0.12.tgz: + resolution: {integrity: sha512-UKXf9OF/no8WZo9edRzvuMenb6AD5hDLzIepJW+a4oJT+T/Lx7vfMYWT4aWlGNQh0WMhnUx1ipN9OkZ9q+ddEw==, tarball: https://registry.npmmirror.com/posthtml-rename-id/-/posthtml-rename-id-1.0.12.tgz} + version: 1.0.12 + + posthtml-render@https://registry.npmmirror.com/posthtml-render/-/posthtml-render-1.4.0.tgz: + resolution: {integrity: sha512-W1779iVHGfq0Fvh2PROhCe2QhB8mEErgqzo1wpIt36tCgChafP+hbXIhLDOM8ePJrZcFs0vkNEtdibEWVqChqw==, tarball: https://registry.npmmirror.com/posthtml-render/-/posthtml-render-1.4.0.tgz} + version: 1.4.0 + engines: {node: '>=10'} + + posthtml-svg-mode@https://registry.npmmirror.com/posthtml-svg-mode/-/posthtml-svg-mode-1.0.3.tgz: + resolution: {integrity: sha512-hEqw9NHZ9YgJ2/0G7CECOeuLQKZi8HjWLkBaSVtOWjygQ9ZD8P7tqeowYs7WrFdKsWEKG7o+IlsPY8jrr0CJpQ==, tarball: https://registry.npmmirror.com/posthtml-svg-mode/-/posthtml-svg-mode-1.0.3.tgz} + version: 1.0.3 + + posthtml@https://registry.npmmirror.com/posthtml/-/posthtml-0.9.2.tgz: + resolution: {integrity: sha512-spBB5sgC4cv2YcW03f/IAUN1pgDJWNWD8FzkyY4mArLUMJW+KlQhlmUdKAHQuPfb00Jl5xIfImeOsf6YL8QK7Q==, tarball: https://registry.npmmirror.com/posthtml/-/posthtml-0.9.2.tgz} + version: 0.9.2 + engines: {node: '>=0.10.0'} + + query-string@https://registry.npmmirror.com/query-string/-/query-string-4.3.4.tgz: + resolution: {integrity: sha512-O2XLNDBIg1DnTOa+2XrIwSiXEV8h2KImXUnjhhn2+UsvZ+Es2uyd5CCRTNQlDGbzUQOW3aYCBx9rVA6dzsiY7Q==, tarball: https://registry.npmmirror.com/query-string/-/query-string-4.3.4.tgz} + version: 4.3.4 + engines: {node: '>=0.10.0'} + + queue-microtask@https://registry.npmmirror.com/queue-microtask/-/queue-microtask-1.2.3.tgz: + resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==, tarball: https://registry.npmmirror.com/queue-microtask/-/queue-microtask-1.2.3.tgz} + version: 1.2.3 + + quill-delta@https://registry.npmmirror.com/quill-delta/-/quill-delta-3.6.3.tgz: + resolution: {integrity: sha512-wdIGBlcX13tCHOXGMVnnTVFtGRLoP0imqxM696fIPwIf5ODIYUHIvHbZcyvGlZFiFhK5XzDC2lpjbxRhnM05Tg==, tarball: https://registry.npmmirror.com/quill-delta/-/quill-delta-3.6.3.tgz} + version: 3.6.3 + engines: {node: '>=0.10'} + + quill-delta@https://registry.npmmirror.com/quill-delta/-/quill-delta-4.2.2.tgz: + resolution: {integrity: sha512-qjbn82b/yJzOjstBgkhtBjN2TNK+ZHP/BgUQO+j6bRhWQQdmj2lH6hXG7+nwwLF41Xgn//7/83lxs9n2BkTtTg==, tarball: https://registry.npmmirror.com/quill-delta/-/quill-delta-4.2.2.tgz} + version: 4.2.2 + + quill@https://registry.npmmirror.com/quill/-/quill-1.3.7.tgz: + resolution: {integrity: sha512-hG/DVzh/TiknWtE6QmWAF/pxoZKYxfe3J/d/+ShUWkDvvkZQVTPeVmUJVu1uE6DDooC4fWTiCLh84ul89oNz5g==, tarball: https://registry.npmmirror.com/quill/-/quill-1.3.7.tgz} + version: 1.3.7 + + readable-stream@https://registry.npmmirror.com/readable-stream/-/readable-stream-3.6.2.tgz: + resolution: {integrity: sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==, tarball: https://registry.npmmirror.com/readable-stream/-/readable-stream-3.6.2.tgz} + version: 3.6.2 + engines: {node: '>= 6'} + + readdirp@https://registry.npmmirror.com/readdirp/-/readdirp-3.6.0.tgz: + resolution: {integrity: sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==, tarball: https://registry.npmmirror.com/readdirp/-/readdirp-3.6.0.tgz} + version: 3.6.0 + engines: {node: '>=8.10.0'} + + regex-not@https://registry.npmmirror.com/regex-not/-/regex-not-1.0.2.tgz: + resolution: {integrity: sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==, tarball: https://registry.npmmirror.com/regex-not/-/regex-not-1.0.2.tgz} + version: 1.0.2 + engines: {node: '>=0.10.0'} + + regexp.prototype.flags@https://registry.npmmirror.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz: + resolution: {integrity: sha512-0SutC3pNudRKgquxGoRGIz946MZVHqbNfPjBdxeOhBrdgDKlRoXmYLQN9xRbrR09ZXWeGAdPuif7egofn6v5LA==, tarball: https://registry.npmmirror.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz} + version: 1.5.0 + engines: {node: '>= 0.4'} + + repeat-element@https://registry.npmmirror.com/repeat-element/-/repeat-element-1.1.4.tgz: + resolution: {integrity: sha512-LFiNfRcSu7KK3evMyYOuCzv3L10TW7yC1G2/+StMjK8Y6Vqd2MG7r/Qjw4ghtuCOjFvlnms/iMmLqpvW/ES/WQ==, tarball: https://registry.npmmirror.com/repeat-element/-/repeat-element-1.1.4.tgz} + version: 1.1.4 + engines: {node: '>=0.10.0'} + + repeat-string@https://registry.npmmirror.com/repeat-string/-/repeat-string-1.6.1.tgz: + resolution: {integrity: sha512-PV0dzCYDNfRi1jCDbJzpW7jNNDRuCOG/jI5ctQcGKt/clZD+YcPS3yIlWuTJMmESC8aevCFmWJy5wjAFgNqN6w==, tarball: https://registry.npmmirror.com/repeat-string/-/repeat-string-1.6.1.tgz} + version: 1.6.1 + engines: {node: '>=0.10'} + + resolve-url@https://registry.npmmirror.com/resolve-url/-/resolve-url-0.2.1.tgz: + resolution: {integrity: sha512-ZuF55hVUQaaczgOIwqWzkEcEidmlD/xl44x1UZnhOXcYuFN2S6+rcxpG+C1N3So0wvNI3DmJICUFfu2SxhBmvg==, tarball: https://registry.npmmirror.com/resolve-url/-/resolve-url-0.2.1.tgz} + version: 0.2.1 + deprecated: https://github.com/lydell/resolve-url#deprecated + + resolve@https://registry.npmmirror.com/resolve/-/resolve-1.22.2.tgz: + resolution: {integrity: sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==, tarball: https://registry.npmmirror.com/resolve/-/resolve-1.22.2.tgz} + version: 1.22.2 + hasBin: true + + ret@https://registry.npmmirror.com/ret/-/ret-0.1.15.tgz: + resolution: {integrity: sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==, tarball: https://registry.npmmirror.com/ret/-/ret-0.1.15.tgz} + version: 0.1.15 + engines: {node: '>=0.12'} + + reusify@https://registry.npmmirror.com/reusify/-/reusify-1.0.4.tgz: + resolution: {integrity: sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==, tarball: https://registry.npmmirror.com/reusify/-/reusify-1.0.4.tgz} + version: 1.0.4 + engines: {iojs: '>=1.0.0', node: '>=0.10.0'} + + rollup@2.79.1: + resolution: {integrity: sha512-uKxbd0IhMZOhjAiD5oAFp7BqvkA4Dv47qpOCtaNvng4HBwdbWtdOh8f5nZNuk2rp51PMGk3bzfWu5oayNEuYnw==} + engines: {node: '>=10.0.0'} + hasBin: true + + rollup@https://registry.npmmirror.com/rollup/-/rollup-2.79.1.tgz: + resolution: {integrity: sha512-uKxbd0IhMZOhjAiD5oAFp7BqvkA4Dv47qpOCtaNvng4HBwdbWtdOh8f5nZNuk2rp51PMGk3bzfWu5oayNEuYnw==, tarball: https://registry.npmmirror.com/rollup/-/rollup-2.79.1.tgz} + version: 2.79.1 + engines: {node: '>=10.0.0'} + hasBin: true + + run-parallel@https://registry.npmmirror.com/run-parallel/-/run-parallel-1.2.0.tgz: + resolution: {integrity: sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==, tarball: https://registry.npmmirror.com/run-parallel/-/run-parallel-1.2.0.tgz} + version: 1.2.0 + + safe-buffer@https://registry.npmmirror.com/safe-buffer/-/safe-buffer-5.2.1.tgz: + resolution: {integrity: sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==, tarball: https://registry.npmmirror.com/safe-buffer/-/safe-buffer-5.2.1.tgz} + version: 5.2.1 + + safe-regex@https://registry.npmmirror.com/safe-regex/-/safe-regex-1.1.0.tgz: + resolution: {integrity: sha512-aJXcif4xnaNUzvUuC5gcb46oTS7zvg4jpMTnuqtrEPlR3vFr4pxtdTwaF1Qs3Enjn9HK+ZlwQui+a7z0SywIzg==, tarball: https://registry.npmmirror.com/safe-regex/-/safe-regex-1.1.0.tgz} + version: 1.1.0 + + sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz: + resolution: {integrity: sha512-VpEyKpyBPCxE7qGDtOcdJ6fFbcpOM+Emu7uZLxVrkX8KVU/Dp5UF7WLvzqRuUhB6mqqQt1xffLoG+AndxTZrCQ==, tarball: https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz} + version: 1.56.1 + engines: {node: '>=12.0.0'} + hasBin: true + + scule@https://registry.npmmirror.com/scule/-/scule-1.0.0.tgz: + resolution: {integrity: sha512-4AsO/FrViE/iDNEPaAQlb77tf0csuq27EsVpy6ett584EcRTp6pTDLoGWVxCD77y5iU5FauOvhsI4o1APwPoSQ==, tarball: https://registry.npmmirror.com/scule/-/scule-1.0.0.tgz} + version: 1.0.0 + + set-value@https://registry.npmmirror.com/set-value/-/set-value-2.0.1.tgz: + resolution: {integrity: sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==, tarball: https://registry.npmmirror.com/set-value/-/set-value-2.0.1.tgz} + version: 2.0.1 + engines: {node: '>=0.10.0'} + + snapdragon-node@https://registry.npmmirror.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz: + resolution: {integrity: sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==, tarball: https://registry.npmmirror.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz} + version: 2.1.1 + engines: {node: '>=0.10.0'} + + snapdragon-util@https://registry.npmmirror.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz: + resolution: {integrity: sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==, tarball: https://registry.npmmirror.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz} + version: 3.0.1 + engines: {node: '>=0.10.0'} + + snapdragon@https://registry.npmmirror.com/snapdragon/-/snapdragon-0.8.2.tgz: + resolution: {integrity: sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==, tarball: https://registry.npmmirror.com/snapdragon/-/snapdragon-0.8.2.tgz} + version: 0.8.2 + engines: {node: '>=0.10.0'} + + source-map-js@https://registry.npmmirror.com/source-map-js/-/source-map-js-1.0.2.tgz: + resolution: {integrity: sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==, tarball: https://registry.npmmirror.com/source-map-js/-/source-map-js-1.0.2.tgz} + version: 1.0.2 + engines: {node: '>=0.10.0'} + + source-map-resolve@https://registry.npmmirror.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz: + resolution: {integrity: sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw==, tarball: https://registry.npmmirror.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz} + version: 0.5.3 + deprecated: See https://github.com/lydell/source-map-resolve#deprecated + + source-map-url@https://registry.npmmirror.com/source-map-url/-/source-map-url-0.4.1.tgz: + resolution: {integrity: sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw==, tarball: https://registry.npmmirror.com/source-map-url/-/source-map-url-0.4.1.tgz} + version: 0.4.1 + deprecated: See https://github.com/lydell/source-map-url#deprecated + + source-map@https://registry.npmmirror.com/source-map/-/source-map-0.5.7.tgz: + resolution: {integrity: sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==, tarball: https://registry.npmmirror.com/source-map/-/source-map-0.5.7.tgz} + version: 0.5.7 + engines: {node: '>=0.10.0'} + + source-map@https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz: + resolution: {integrity: sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==, tarball: https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz} + version: 0.6.1 + engines: {node: '>=0.10.0'} + + sourcemap-codec@https://registry.npmmirror.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz: + resolution: {integrity: sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==, tarball: https://registry.npmmirror.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz} + version: 1.4.8 + deprecated: Please use @jridgewell/sourcemap-codec instead + + split-string@https://registry.npmmirror.com/split-string/-/split-string-3.1.0.tgz: + resolution: {integrity: sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==, tarball: https://registry.npmmirror.com/split-string/-/split-string-3.1.0.tgz} + version: 3.1.0 + engines: {node: '>=0.10.0'} + + stable@https://registry.npmmirror.com/stable/-/stable-0.1.8.tgz: + resolution: {integrity: sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==, tarball: https://registry.npmmirror.com/stable/-/stable-0.1.8.tgz} + version: 0.1.8 + deprecated: 'Modern JS already guarantees Array#sort() is a stable sort, so this library is deprecated. See the compatibility table on MDN: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#browser_compatibility' + + static-extend@https://registry.npmmirror.com/static-extend/-/static-extend-0.1.2.tgz: + resolution: {integrity: sha512-72E9+uLc27Mt718pMHt9VMNiAL4LMsmDbBva8mxWUCkT07fSzEGMYUCk0XWY6lp0j6RBAG4cJ3mWuZv2OE3s0g==, tarball: https://registry.npmmirror.com/static-extend/-/static-extend-0.1.2.tgz} + version: 0.1.2 + engines: {node: '>=0.10.0'} + + strict-uri-encode@https://registry.npmmirror.com/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz: + resolution: {integrity: sha512-R3f198pcvnB+5IpnBlRkphuE9n46WyVl8I39W/ZUTZLz4nqSP/oLYUrcnJrw462Ds8he4YKMov2efsTIw1BDGQ==, tarball: https://registry.npmmirror.com/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz} + version: 1.1.0 + engines: {node: '>=0.10.0'} + + string_decoder@https://registry.npmmirror.com/string_decoder/-/string_decoder-1.3.0.tgz: + resolution: {integrity: sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==, tarball: https://registry.npmmirror.com/string_decoder/-/string_decoder-1.3.0.tgz} + version: 1.3.0 + + strip-ansi@https://registry.npmmirror.com/strip-ansi/-/strip-ansi-3.0.1.tgz: + resolution: {integrity: sha512-VhumSSbBqDTP8p2ZLKj40UjBCV4+v8bUSEpUb4KjRgWk9pbqGF4REFj6KEagidb2f/M6AzC0EmFyDNGaw9OCzg==, tarball: https://registry.npmmirror.com/strip-ansi/-/strip-ansi-3.0.1.tgz} + version: 3.0.1 + engines: {node: '>=0.10.0'} + + strip-literal@https://registry.npmmirror.com/strip-literal/-/strip-literal-1.0.1.tgz: + resolution: {integrity: sha512-QZTsipNpa2Ppr6v1AmJHESqJ3Uz247MUS0OjrnnZjFAvEoWqxuyFuXn2xLgMtRnijJShAa1HL0gtJyUs7u7n3Q==, tarball: https://registry.npmmirror.com/strip-literal/-/strip-literal-1.0.1.tgz} + version: 1.0.1 + + supports-color@https://registry.npmmirror.com/supports-color/-/supports-color-2.0.0.tgz: + resolution: {integrity: sha512-KKNVtd6pCYgPIKU4cp2733HWYCpplQhddZLBUryaAHou723x+FRzQ5Df824Fj+IyyuiQTRoub4SnIFfIcrp70g==, tarball: https://registry.npmmirror.com/supports-color/-/supports-color-2.0.0.tgz} + version: 2.0.0 + engines: {node: '>=0.8.0'} + + supports-color@https://registry.npmmirror.com/supports-color/-/supports-color-3.2.3.tgz: + resolution: {integrity: sha512-Jds2VIYDrlp5ui7t8abHN2bjAu4LV/q4N2KivFPpGH0lrka0BMq/33AmECUXlKPcHigkNaqfXRENFju+rlcy+A==, tarball: https://registry.npmmirror.com/supports-color/-/supports-color-3.2.3.tgz} + version: 3.2.3 + engines: {node: '>=0.8.0'} + + supports-color@https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz: + resolution: {integrity: sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==, tarball: https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz} + version: 7.2.0 + engines: {node: '>=8'} + + supports-preserve-symlinks-flag@https://registry.npmmirror.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz: + resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==, tarball: https://registry.npmmirror.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>= 0.4'} + + svg-baker@https://registry.npmmirror.com/svg-baker/-/svg-baker-1.7.0.tgz: + resolution: {integrity: sha512-nibslMbkXOIkqKVrfcncwha45f97fGuAOn1G99YwnwTj8kF9YiM6XexPcUso97NxOm6GsP0SIvYVIosBis1xLg==, tarball: https://registry.npmmirror.com/svg-baker/-/svg-baker-1.7.0.tgz} + version: 1.7.0 + + svgo@https://registry.npmmirror.com/svgo/-/svgo-2.8.0.tgz: + resolution: {integrity: sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg==, tarball: https://registry.npmmirror.com/svgo/-/svgo-2.8.0.tgz} + version: 2.8.0 + engines: {node: '>=10.13.0'} + hasBin: true + + to-fast-properties@https://registry.npmmirror.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz: + resolution: {integrity: sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==, tarball: https://registry.npmmirror.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz} + version: 2.0.0 + engines: {node: '>=4'} + + to-object-path@https://registry.npmmirror.com/to-object-path/-/to-object-path-0.3.0.tgz: + resolution: {integrity: sha512-9mWHdnGRuh3onocaHzukyvCZhzvr6tiflAy/JRFXcJX0TjgfWA9pk9t8CMbzmBE4Jfw58pXbkngtBtqYxzNEyg==, tarball: https://registry.npmmirror.com/to-object-path/-/to-object-path-0.3.0.tgz} + version: 0.3.0 + engines: {node: '>=0.10.0'} + + to-regex-range@https://registry.npmmirror.com/to-regex-range/-/to-regex-range-2.1.1.tgz: + resolution: {integrity: sha512-ZZWNfCjUokXXDGXFpZehJIkZqq91BcULFq/Pi7M5i4JnxXdhMKAK682z8bCW3o8Hj1wuuzoKcW3DfVzaP6VuNg==, tarball: https://registry.npmmirror.com/to-regex-range/-/to-regex-range-2.1.1.tgz} + version: 2.1.1 + engines: {node: '>=0.10.0'} + + to-regex-range@https://registry.npmmirror.com/to-regex-range/-/to-regex-range-5.0.1.tgz: + resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==, tarball: https://registry.npmmirror.com/to-regex-range/-/to-regex-range-5.0.1.tgz} + version: 5.0.1 + engines: {node: '>=8.0'} + + to-regex@https://registry.npmmirror.com/to-regex/-/to-regex-3.0.2.tgz: + resolution: {integrity: sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==, tarball: https://registry.npmmirror.com/to-regex/-/to-regex-3.0.2.tgz} + version: 3.0.2 + engines: {node: '>=0.10.0'} + + traverse@https://registry.npmmirror.com/traverse/-/traverse-0.6.7.tgz: + resolution: {integrity: sha512-/y956gpUo9ZNCb99YjxG7OaslxZWHfCHAUUfshwqOXmxUIvqLjVO581BT+gM59+QV9tFe6/CGG53tsA1Y7RSdg==, tarball: https://registry.npmmirror.com/traverse/-/traverse-0.6.7.tgz} + version: 0.6.7 + + tslib@https://registry.npmmirror.com/tslib/-/tslib-2.3.0.tgz: + resolution: {integrity: sha512-N82ooyxVNm6h1riLCoyS9e3fuJ3AMG2zIZs2Gd1ATcSFjSA23Q0fzjjZeh0jbJvWVDZ0cJT8yaNNaaXHzueNjg==, tarball: https://registry.npmmirror.com/tslib/-/tslib-2.3.0.tgz} + version: 2.3.0 + + ufo@https://registry.npmmirror.com/ufo/-/ufo-1.1.2.tgz: + resolution: {integrity: sha512-TrY6DsjTQQgyS3E3dBaOXf0TpPD8u9FVrVYmKVegJuFw51n/YB9XPt+U6ydzFG5ZIN7+DIjPbNmXoBj9esYhgQ==, tarball: https://registry.npmmirror.com/ufo/-/ufo-1.1.2.tgz} + version: 1.1.2 + + unimport@https://registry.npmmirror.com/unimport/-/unimport-0.7.1.tgz: + resolution: {integrity: sha512-rn/hRpCtFxVVT3T8a6sG738xiA6yp8eFzzMLVr+ebp2FBU1gF0Qo6SfOGrrXATDmKruskhYAvPN7djhydgHU8A==, tarball: https://registry.npmmirror.com/unimport/-/unimport-0.7.1.tgz} + version: 0.7.1 + + union-value@https://registry.npmmirror.com/union-value/-/union-value-1.0.1.tgz: + resolution: {integrity: sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==, tarball: https://registry.npmmirror.com/union-value/-/union-value-1.0.1.tgz} + version: 1.0.1 + engines: {node: '>=0.10.0'} + + universalify@https://registry.npmmirror.com/universalify/-/universalify-2.0.0.tgz: + resolution: {integrity: sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ==, tarball: https://registry.npmmirror.com/universalify/-/universalify-2.0.0.tgz} + version: 2.0.0 + engines: {node: '>= 10.0.0'} + + unplugin-auto-import@https://registry.npmmirror.com/unplugin-auto-import/-/unplugin-auto-import-0.11.4.tgz: + resolution: {integrity: sha512-lh/bRDRYwgnb9Cm5ur8TlTMGxA1GRZvgzCvBIf0vyuVRy7ebWcWefFElpUDpr8vLl+ZRGsPVCOGiYJ8TCR625Q==, tarball: https://registry.npmmirror.com/unplugin-auto-import/-/unplugin-auto-import-0.11.4.tgz} + version: 0.11.4 + engines: {node: '>=14'} + peerDependencies: + '@vueuse/core': '*' + peerDependenciesMeta: + '@vueuse/core': + optional: true + + unplugin@https://registry.npmmirror.com/unplugin/-/unplugin-0.10.2.tgz: + resolution: {integrity: sha512-6rk7GUa4ICYjae5PrAllvcDeuT8pA9+j5J5EkxbMFaV+SalHhxZ7X2dohMzu6C3XzsMT+6jwR/+pwPNR3uK9MA==, tarball: https://registry.npmmirror.com/unplugin/-/unplugin-0.10.2.tgz} + version: 0.10.2 + + unplugin@https://registry.npmmirror.com/unplugin/-/unplugin-1.3.1.tgz: + resolution: {integrity: sha512-h4uUTIvFBQRxUKS2Wjys6ivoeofGhxzTe2sRWlooyjHXVttcVfV/JiavNd3d4+jty0SVV0dxGw9AkY9MwiaCEw==, tarball: https://registry.npmmirror.com/unplugin/-/unplugin-1.3.1.tgz} + version: 1.3.1 + + unset-value@https://registry.npmmirror.com/unset-value/-/unset-value-1.0.0.tgz: + resolution: {integrity: sha512-PcA2tsuGSF9cnySLHTLSh2qrQiJ70mn+r+Glzxv2TWZblxsxCC52BDlZoPCsz7STd9pN7EZetkWZBAvk4cgZdQ==, tarball: https://registry.npmmirror.com/unset-value/-/unset-value-1.0.0.tgz} + version: 1.0.0 + engines: {node: '>=0.10.0'} + + urix@https://registry.npmmirror.com/urix/-/urix-0.1.0.tgz: + resolution: {integrity: sha512-Am1ousAhSLBeB9cG/7k7r2R0zj50uDRlZHPGbazid5s9rlF1F/QKYObEKSIunSjIOkJZqwRRLpvewjEkM7pSqg==, tarball: https://registry.npmmirror.com/urix/-/urix-0.1.0.tgz} + version: 0.1.0 + deprecated: Please see https://github.com/lydell/urix#deprecated + + use@https://registry.npmmirror.com/use/-/use-3.1.1.tgz: + resolution: {integrity: sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==, tarball: https://registry.npmmirror.com/use/-/use-3.1.1.tgz} + version: 3.1.1 + engines: {node: '>=0.10.0'} + + util-deprecate@https://registry.npmmirror.com/util-deprecate/-/util-deprecate-1.0.2.tgz: + resolution: {integrity: sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==, tarball: https://registry.npmmirror.com/util-deprecate/-/util-deprecate-1.0.2.tgz} + version: 1.0.2 + + vary@https://registry.npmmirror.com/vary/-/vary-1.1.2.tgz: + resolution: {integrity: sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==, tarball: https://registry.npmmirror.com/vary/-/vary-1.1.2.tgz} + version: 1.1.2 + engines: {node: '>= 0.8'} + + vite-plugin-compression@https://registry.npmmirror.com/vite-plugin-compression/-/vite-plugin-compression-0.5.1.tgz: + resolution: {integrity: sha512-5QJKBDc+gNYVqL/skgFAP81Yuzo9R+EAf19d+EtsMF/i8kFUpNi3J/H01QD3Oo8zBQn+NzoCIFkpPLynoOzaJg==, tarball: https://registry.npmmirror.com/vite-plugin-compression/-/vite-plugin-compression-0.5.1.tgz} + version: 0.5.1 + peerDependencies: + vite: '>=2.0.0' + + vite-plugin-svg-icons@https://registry.npmmirror.com/vite-plugin-svg-icons/-/vite-plugin-svg-icons-2.0.1.tgz: + resolution: {integrity: sha512-6ktD+DhV6Rz3VtedYvBKKVA2eXF+sAQVaKkKLDSqGUfnhqXl3bj5PPkVTl3VexfTuZy66PmINi8Q6eFnVfRUmA==, tarball: https://registry.npmmirror.com/vite-plugin-svg-icons/-/vite-plugin-svg-icons-2.0.1.tgz} + version: 2.0.1 + peerDependencies: + vite: '>=2.0.0' + + vite-plugin-vue-setup-extend@https://registry.npmmirror.com/vite-plugin-vue-setup-extend/-/vite-plugin-vue-setup-extend-0.4.0.tgz: + resolution: {integrity: sha512-WMbjPCui75fboFoUTHhdbXzu4Y/bJMv5N9QT9a7do3wNMNHHqrk+Tn2jrSJU0LS5fGl/EG+FEDBYVUeWIkDqXQ==, tarball: https://registry.npmmirror.com/vite-plugin-vue-setup-extend/-/vite-plugin-vue-setup-extend-0.4.0.tgz} + version: 0.4.0 + peerDependencies: + vite: '>=2.0.0' + + vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz: + resolution: {integrity: sha512-29pdXjk49xAP0QBr0xXqu2s5jiQIXNvE/xwd0vUizYT2Hzqe4BksNNoWllFVXJf4eLZ+UlVQmXfB4lWrc+t18g==, tarball: https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz} + version: 3.2.7 + engines: {node: ^14.18.0 || >=16.0.0} + hasBin: true + peerDependencies: + '@types/node': '>= 14' + less: '*' + sass: '*' + stylus: '*' + sugarss: '*' + terser: ^5.4.0 + peerDependenciesMeta: + '@types/node': + optional: true + less: + optional: true + sass: + optional: true + stylus: + optional: true + sugarss: + optional: true + terser: + optional: true + + vue-cropper@https://registry.npmmirror.com/vue-cropper/-/vue-cropper-1.0.3.tgz: + resolution: {integrity: sha512-yDrZkE4H5vOiMA9WQHE+6rmXrZ1S9TMZasEPAZPKg/2I/nySHL4ECD1lNxt7+ofTPKT+9+2sQkCwagPqEqiqJg==, tarball: https://registry.npmmirror.com/vue-cropper/-/vue-cropper-1.0.3.tgz} + version: 1.0.3 + + vue-demi@0.14.5: + resolution: {integrity: sha512-o9NUVpl/YlsGJ7t+xuqJKx8EBGf1quRhCiT6D/J0pfwmk9zUwYkC7yrF4SZCe6fETvSM3UNL2edcbYrSyc4QHA==} + version: 0.14.5 + engines: {node: '>=12'} + hasBin: true + peerDependencies: + '@vue/composition-api': ^1.0.0-rc.1 + vue: ^3.0.0-0 || ^2.6.0 + peerDependenciesMeta: + '@vue/composition-api': + optional: true + + vue-demi@https://registry.npmmirror.com/vue-demi/-/vue-demi-0.12.5.tgz: + resolution: {integrity: sha512-BREuTgTYlUr0zw0EZn3hnhC3I6gPWv+Kwh4MCih6QcAeaTlaIX0DwOVN0wHej7hSvDPecz4jygy/idsgKfW58Q==, tarball: https://registry.npmmirror.com/vue-demi/-/vue-demi-0.12.5.tgz} + version: 0.12.5 + engines: {node: '>=12'} + hasBin: true + peerDependencies: + '@vue/composition-api': ^1.0.0-rc.1 + vue: ^3.0.0-0 || ^2.6.0 + peerDependenciesMeta: + '@vue/composition-api': + optional: true + + vue-demi@https://registry.npmmirror.com/vue-demi/-/vue-demi-0.14.5.tgz: + resolution: {integrity: sha512-o9NUVpl/YlsGJ7t+xuqJKx8EBGf1quRhCiT6D/J0pfwmk9zUwYkC7yrF4SZCe6fETvSM3UNL2edcbYrSyc4QHA==, tarball: https://registry.npmmirror.com/vue-demi/-/vue-demi-0.14.5.tgz} + version: 0.14.5 + engines: {node: '>=12'} + hasBin: true + peerDependencies: + '@vue/composition-api': ^1.0.0-rc.1 + vue: ^3.0.0-0 || ^2.6.0 + peerDependenciesMeta: + '@vue/composition-api': + optional: true + + vue-router@https://registry.npmmirror.com/vue-router/-/vue-router-4.1.4.tgz: + resolution: {integrity: sha512-UgYen33gOtwT3cOG1+yRen+Brk9py8CSlC9LEa3UjvKZ4EAoSo8NjZPDeDnmNerfazorHIJG1NC7qdi1SuQJnQ==, tarball: https://registry.npmmirror.com/vue-router/-/vue-router-4.1.4.tgz} + version: 4.1.4 + peerDependencies: + vue: ^3.2.0 + + vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz: + resolution: {integrity: sha512-9Nx/Mg2b2xWlXykmCwiTUCWHbWIj53bnkizBxKai1g61f2Xit700A1ljowpTIM11e3uipOeiPcSqnmBg6gyiaA==, tarball: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz} + version: 3.2.45 + + webpack-sources@https://registry.npmmirror.com/webpack-sources/-/webpack-sources-3.2.3.tgz: + resolution: {integrity: sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==, tarball: https://registry.npmmirror.com/webpack-sources/-/webpack-sources-3.2.3.tgz} + version: 3.2.3 + engines: {node: '>=10.13.0'} + + webpack-virtual-modules@https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.4.6.tgz: + resolution: {integrity: sha512-5tyDlKLqPfMqjT3Q9TAqf2YqjwmnUleZwzJi1A5qXnlBCdj2AtOJ6wAWdglTIDOPgOiOrXeBeFcsQ8+aGQ6QbA==, tarball: https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.4.6.tgz} + version: 0.4.6 + + webpack-virtual-modules@https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.5.0.tgz: + resolution: {integrity: sha512-kyDivFZ7ZM0BVOUteVbDFhlRt7Ah/CSPwJdi8hBpkK7QLumUqdLtVfm/PX/hkcnrvr0i77fO5+TjZ94Pe+C9iw==, tarball: https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.5.0.tgz} + version: 0.5.0 + + zrender@https://registry.npmmirror.com/zrender/-/zrender-5.4.0.tgz: + resolution: {integrity: sha512-rOS09Z2HSVGFs2dn/TuYk5BlCaZcVe8UDLLjj1ySYF828LATKKdxuakSZMvrDz54yiKPDYVfjdKqcX8Jky3BIA==, tarball: https://registry.npmmirror.com/zrender/-/zrender-5.4.0.tgz} + version: 5.4.0 + +snapshots: + + '@antfu/utils@https://registry.npmmirror.com/@antfu/utils/-/utils-0.6.3.tgz': {} + + '@babel/helper-string-parser@https://registry.npmmirror.com/@babel/helper-string-parser/-/helper-string-parser-7.21.5.tgz': {} + + '@babel/helper-validator-identifier@https://registry.npmmirror.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz': {} + + '@babel/parser@https://registry.npmmirror.com/@babel/parser/-/parser-7.21.9.tgz': + dependencies: + '@babel/types': https://registry.npmmirror.com/@babel/types/-/types-7.21.5.tgz + + '@babel/types@https://registry.npmmirror.com/@babel/types/-/types-7.21.5.tgz': + dependencies: + '@babel/helper-string-parser': https://registry.npmmirror.com/@babel/helper-string-parser/-/helper-string-parser-7.21.5.tgz + '@babel/helper-validator-identifier': https://registry.npmmirror.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz + to-fast-properties: https://registry.npmmirror.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz + + '@ctrl/tinycolor@3.6.1': {} + + '@element-plus/icons-vue@2.3.1(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz)': + dependencies: + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + + '@esbuild/android-arm@0.15.18': + optional: true + + '@esbuild/linux-loong64@0.15.18': + optional: true + + '@floating-ui/core@1.6.2': + dependencies: + '@floating-ui/utils': 0.2.2 + + '@floating-ui/dom@1.6.5': + dependencies: + '@floating-ui/core': 1.6.2 + '@floating-ui/utils': 0.2.2 + + '@floating-ui/utils@0.2.2': {} + + '@nodelib/fs.scandir@https://registry.npmmirror.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz': + dependencies: + '@nodelib/fs.stat': https://registry.npmmirror.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz + run-parallel: https://registry.npmmirror.com/run-parallel/-/run-parallel-1.2.0.tgz + + '@nodelib/fs.stat@https://registry.npmmirror.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz': {} + + '@nodelib/fs.walk@https://registry.npmmirror.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz': + dependencies: + '@nodelib/fs.scandir': https://registry.npmmirror.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz + fastq: https://registry.npmmirror.com/fastq/-/fastq-1.15.0.tgz + + '@rollup/pluginutils@https://registry.npmmirror.com/@rollup/pluginutils/-/pluginutils-5.0.2.tgz(rollup@2.79.1)': + dependencies: + '@types/estree': https://registry.npmmirror.com/@types/estree/-/estree-1.0.1.tgz + estree-walker: https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz + picomatch: https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz + optionalDependencies: + rollup: 2.79.1 + + '@sxzz/popperjs-es@2.11.7': {} + + '@trysound/sax@https://registry.npmmirror.com/@trysound/sax/-/sax-0.2.0.tgz': {} + + '@types/estree@https://registry.npmmirror.com/@types/estree/-/estree-1.0.1.tgz': {} + + '@types/lodash-es@4.17.12': + dependencies: + '@types/lodash': 4.17.4 + + '@types/lodash@4.17.4': {} + + '@types/node@20.2.3': + optional: true + + '@types/node@https://registry.npmmirror.com/@types/node/-/node-20.2.3.tgz': {} + + '@types/svgo@https://registry.npmmirror.com/@types/svgo/-/svgo-2.6.4.tgz': + dependencies: + '@types/node': https://registry.npmmirror.com/@types/node/-/node-20.2.3.tgz + + '@types/web-bluetooth@0.0.16': {} + + '@types/web-bluetooth@https://registry.npmmirror.com/@types/web-bluetooth/-/web-bluetooth-0.0.16.tgz': {} + + '@vitejs/plugin-vue@https://registry.npmmirror.com/@vitejs/plugin-vue/-/plugin-vue-3.1.0.tgz(vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz))(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz)': + dependencies: + vite: https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz) + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + + '@vue/compiler-core@https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.45.tgz': + dependencies: + '@babel/parser': https://registry.npmmirror.com/@babel/parser/-/parser-7.21.9.tgz + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + estree-walker: https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz + source-map: https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz + + '@vue/compiler-dom@https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.45.tgz': + dependencies: + '@vue/compiler-core': https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.45.tgz + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + + '@vue/compiler-sfc@https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.45.tgz': + dependencies: + '@babel/parser': https://registry.npmmirror.com/@babel/parser/-/parser-7.21.9.tgz + '@vue/compiler-core': https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.45.tgz + '@vue/compiler-dom': https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.45.tgz + '@vue/compiler-ssr': https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.45.tgz + '@vue/reactivity-transform': https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.2.45.tgz + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + estree-walker: https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz + magic-string: https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz + postcss: https://registry.npmmirror.com/postcss/-/postcss-8.4.23.tgz + source-map: https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz + + '@vue/compiler-ssr@https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.45.tgz': + dependencies: + '@vue/compiler-dom': https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.45.tgz + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + + '@vue/devtools-api@https://registry.npmmirror.com/@vue/devtools-api/-/devtools-api-6.5.0.tgz': {} + + '@vue/reactivity-transform@https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.2.45.tgz': + dependencies: + '@babel/parser': https://registry.npmmirror.com/@babel/parser/-/parser-7.21.9.tgz + '@vue/compiler-core': https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.2.45.tgz + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + estree-walker: https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz + magic-string: https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz + + '@vue/reactivity@https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.2.45.tgz': + dependencies: + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + + '@vue/runtime-core@https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.2.45.tgz': + dependencies: + '@vue/reactivity': https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.2.45.tgz + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + + '@vue/runtime-dom@https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.2.45.tgz': + dependencies: + '@vue/runtime-core': https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.2.45.tgz + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + csstype: https://registry.npmmirror.com/csstype/-/csstype-2.6.21.tgz + + '@vue/server-renderer@https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.2.45.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz)': + dependencies: + '@vue/compiler-ssr': https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.2.45.tgz + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + + '@vue/shared@https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz': {} + + '@vueup/vue-quill@https://registry.npmmirror.com/@vueup/vue-quill/-/vue-quill-1.1.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz)': + dependencies: + quill: https://registry.npmmirror.com/quill/-/quill-1.3.7.tgz + quill-delta: https://registry.npmmirror.com/quill-delta/-/quill-delta-4.2.2.tgz + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + + '@vueuse/core@9.5.0(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz)': + dependencies: + '@types/web-bluetooth': 0.0.16 + '@vueuse/metadata': 9.5.0 + '@vueuse/shared': 9.5.0(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + vue-demi: 0.14.5(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + transitivePeerDependencies: + - '@vue/composition-api' + - vue + + '@vueuse/core@https://registry.npmmirror.com/@vueuse/core/-/core-9.5.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz)': + dependencies: + '@types/web-bluetooth': https://registry.npmmirror.com/@types/web-bluetooth/-/web-bluetooth-0.0.16.tgz + '@vueuse/metadata': https://registry.npmmirror.com/@vueuse/metadata/-/metadata-9.5.0.tgz + '@vueuse/shared': https://registry.npmmirror.com/@vueuse/shared/-/shared-9.5.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + vue-demi: https://registry.npmmirror.com/vue-demi/-/vue-demi-0.14.5.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + transitivePeerDependencies: + - '@vue/composition-api' + - vue + + '@vueuse/metadata@9.5.0': {} + + '@vueuse/metadata@https://registry.npmmirror.com/@vueuse/metadata/-/metadata-9.5.0.tgz': {} + + '@vueuse/shared@9.5.0(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz)': + dependencies: + vue-demi: 0.14.5(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + transitivePeerDependencies: + - '@vue/composition-api' + - vue + + '@vueuse/shared@https://registry.npmmirror.com/@vueuse/shared/-/shared-9.5.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz)': + dependencies: + vue-demi: https://registry.npmmirror.com/vue-demi/-/vue-demi-0.14.5.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + transitivePeerDependencies: + - '@vue/composition-api' + - vue + + acorn@https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz: {} + + ansi-regex@https://registry.npmmirror.com/ansi-regex/-/ansi-regex-2.1.1.tgz: {} + + ansi-styles@https://registry.npmmirror.com/ansi-styles/-/ansi-styles-2.2.1.tgz: {} + + ansi-styles@https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz: + dependencies: + color-convert: https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz + + anymatch@https://registry.npmmirror.com/anymatch/-/anymatch-3.1.3.tgz: + dependencies: + normalize-path: https://registry.npmmirror.com/normalize-path/-/normalize-path-3.0.0.tgz + picomatch: https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz + + arr-diff@https://registry.npmmirror.com/arr-diff/-/arr-diff-4.0.0.tgz: {} + + arr-flatten@https://registry.npmmirror.com/arr-flatten/-/arr-flatten-1.1.0.tgz: {} + + arr-union@https://registry.npmmirror.com/arr-union/-/arr-union-3.1.0.tgz: {} + + array-unique@https://registry.npmmirror.com/array-unique/-/array-unique-0.3.2.tgz: {} + + assign-symbols@https://registry.npmmirror.com/assign-symbols/-/assign-symbols-1.0.0.tgz: {} + + async-validator@4.2.5: {} + + asynckit@https://registry.npmmirror.com/asynckit/-/asynckit-0.4.0.tgz: {} + + atob@https://registry.npmmirror.com/atob/-/atob-2.1.2.tgz: {} + + axios@https://registry.npmmirror.com/axios/-/axios-0.27.2.tgz: + dependencies: + follow-redirects: https://registry.npmmirror.com/follow-redirects/-/follow-redirects-1.15.2.tgz + form-data: https://registry.npmmirror.com/form-data/-/form-data-4.0.0.tgz + transitivePeerDependencies: + - debug + + base@https://registry.npmmirror.com/base/-/base-0.11.2.tgz: + dependencies: + cache-base: https://registry.npmmirror.com/cache-base/-/cache-base-1.0.1.tgz + class-utils: https://registry.npmmirror.com/class-utils/-/class-utils-0.3.6.tgz + component-emitter: https://registry.npmmirror.com/component-emitter/-/component-emitter-1.3.0.tgz + define-property: https://registry.npmmirror.com/define-property/-/define-property-1.0.0.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + mixin-deep: https://registry.npmmirror.com/mixin-deep/-/mixin-deep-1.3.2.tgz + pascalcase: https://registry.npmmirror.com/pascalcase/-/pascalcase-0.1.1.tgz + + big.js@https://registry.npmmirror.com/big.js/-/big.js-5.2.2.tgz: {} + + binary-extensions@https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.2.0.tgz: {} + + bluebird@https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz: {} + + boolbase@https://registry.npmmirror.com/boolbase/-/boolbase-1.0.0.tgz: {} + + braces@https://registry.npmmirror.com/braces/-/braces-2.3.2.tgz: + dependencies: + arr-flatten: https://registry.npmmirror.com/arr-flatten/-/arr-flatten-1.1.0.tgz + array-unique: https://registry.npmmirror.com/array-unique/-/array-unique-0.3.2.tgz + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz + fill-range: https://registry.npmmirror.com/fill-range/-/fill-range-4.0.0.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + repeat-element: https://registry.npmmirror.com/repeat-element/-/repeat-element-1.1.4.tgz + snapdragon: https://registry.npmmirror.com/snapdragon/-/snapdragon-0.8.2.tgz + snapdragon-node: https://registry.npmmirror.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz + split-string: https://registry.npmmirror.com/split-string/-/split-string-3.1.0.tgz + to-regex: https://registry.npmmirror.com/to-regex/-/to-regex-3.0.2.tgz + transitivePeerDependencies: + - supports-color + + braces@https://registry.npmmirror.com/braces/-/braces-3.0.2.tgz: + dependencies: + fill-range: https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz + + cache-base@https://registry.npmmirror.com/cache-base/-/cache-base-1.0.1.tgz: + dependencies: + collection-visit: https://registry.npmmirror.com/collection-visit/-/collection-visit-1.0.0.tgz + component-emitter: https://registry.npmmirror.com/component-emitter/-/component-emitter-1.3.0.tgz + get-value: https://registry.npmmirror.com/get-value/-/get-value-2.0.6.tgz + has-value: https://registry.npmmirror.com/has-value/-/has-value-1.0.0.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + set-value: https://registry.npmmirror.com/set-value/-/set-value-2.0.1.tgz + to-object-path: https://registry.npmmirror.com/to-object-path/-/to-object-path-0.3.0.tgz + union-value: https://registry.npmmirror.com/union-value/-/union-value-1.0.1.tgz + unset-value: https://registry.npmmirror.com/unset-value/-/unset-value-1.0.0.tgz + + call-bind@https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz: + dependencies: + function-bind: https://registry.npmmirror.com/function-bind/-/function-bind-1.1.1.tgz + get-intrinsic: https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.2.1.tgz + + chalk@https://registry.npmmirror.com/chalk/-/chalk-1.1.3.tgz: + dependencies: + ansi-styles: https://registry.npmmirror.com/ansi-styles/-/ansi-styles-2.2.1.tgz + escape-string-regexp: https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz + has-ansi: https://registry.npmmirror.com/has-ansi/-/has-ansi-2.0.0.tgz + strip-ansi: https://registry.npmmirror.com/strip-ansi/-/strip-ansi-3.0.1.tgz + supports-color: https://registry.npmmirror.com/supports-color/-/supports-color-2.0.0.tgz + + chalk@https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz: + dependencies: + ansi-styles: https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz + supports-color: https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz + + chokidar@https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz: + dependencies: + anymatch: https://registry.npmmirror.com/anymatch/-/anymatch-3.1.3.tgz + braces: https://registry.npmmirror.com/braces/-/braces-3.0.2.tgz + glob-parent: https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz + is-binary-path: https://registry.npmmirror.com/is-binary-path/-/is-binary-path-2.1.0.tgz + is-glob: https://registry.npmmirror.com/is-glob/-/is-glob-4.0.3.tgz + normalize-path: https://registry.npmmirror.com/normalize-path/-/normalize-path-3.0.0.tgz + readdirp: https://registry.npmmirror.com/readdirp/-/readdirp-3.6.0.tgz + optionalDependencies: + fsevents: 2.3.3 + + class-utils@https://registry.npmmirror.com/class-utils/-/class-utils-0.3.6.tgz: + dependencies: + arr-union: https://registry.npmmirror.com/arr-union/-/arr-union-3.1.0.tgz + define-property: https://registry.npmmirror.com/define-property/-/define-property-0.2.5.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + static-extend: https://registry.npmmirror.com/static-extend/-/static-extend-0.1.2.tgz + + clone@https://registry.npmmirror.com/clone/-/clone-2.1.2.tgz: {} + + collection-visit@https://registry.npmmirror.com/collection-visit/-/collection-visit-1.0.0.tgz: + dependencies: + map-visit: https://registry.npmmirror.com/map-visit/-/map-visit-1.0.0.tgz + object-visit: https://registry.npmmirror.com/object-visit/-/object-visit-1.0.1.tgz + + color-convert@https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz: + dependencies: + color-name: https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz + + color-name@https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz: {} + + combined-stream@https://registry.npmmirror.com/combined-stream/-/combined-stream-1.0.8.tgz: + dependencies: + delayed-stream: https://registry.npmmirror.com/delayed-stream/-/delayed-stream-1.0.0.tgz + + commander@https://registry.npmmirror.com/commander/-/commander-7.2.0.tgz: {} + + component-emitter@https://registry.npmmirror.com/component-emitter/-/component-emitter-1.3.0.tgz: {} + + copy-descriptor@https://registry.npmmirror.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz: {} + + cors@https://registry.npmmirror.com/cors/-/cors-2.8.5.tgz: + dependencies: + object-assign: https://registry.npmmirror.com/object-assign/-/object-assign-4.1.1.tgz + vary: https://registry.npmmirror.com/vary/-/vary-1.1.2.tgz + + css-select@https://registry.npmmirror.com/css-select/-/css-select-4.3.0.tgz: + dependencies: + boolbase: https://registry.npmmirror.com/boolbase/-/boolbase-1.0.0.tgz + css-what: https://registry.npmmirror.com/css-what/-/css-what-6.1.0.tgz + domhandler: https://registry.npmmirror.com/domhandler/-/domhandler-4.3.1.tgz + domutils: https://registry.npmmirror.com/domutils/-/domutils-2.8.0.tgz + nth-check: https://registry.npmmirror.com/nth-check/-/nth-check-2.1.1.tgz + + css-tree@https://registry.npmmirror.com/css-tree/-/css-tree-1.1.3.tgz: + dependencies: + mdn-data: https://registry.npmmirror.com/mdn-data/-/mdn-data-2.0.14.tgz + source-map: https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz + + css-what@https://registry.npmmirror.com/css-what/-/css-what-6.1.0.tgz: {} + + csso@https://registry.npmmirror.com/csso/-/csso-4.2.0.tgz: + dependencies: + css-tree: https://registry.npmmirror.com/css-tree/-/css-tree-1.1.3.tgz + + csstype@https://registry.npmmirror.com/csstype/-/csstype-2.6.21.tgz: {} + + dayjs@1.11.11: {} + + debug@https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz: + dependencies: + ms: https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz + + debug@https://registry.npmmirror.com/debug/-/debug-4.3.4.tgz: + dependencies: + ms: https://registry.npmmirror.com/ms/-/ms-2.1.2.tgz + + decode-uri-component@https://registry.npmmirror.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz: {} + + deep-equal@https://registry.npmmirror.com/deep-equal/-/deep-equal-1.1.1.tgz: + dependencies: + is-arguments: https://registry.npmmirror.com/is-arguments/-/is-arguments-1.1.1.tgz + is-date-object: https://registry.npmmirror.com/is-date-object/-/is-date-object-1.0.5.tgz + is-regex: https://registry.npmmirror.com/is-regex/-/is-regex-1.1.4.tgz + object-is: https://registry.npmmirror.com/object-is/-/object-is-1.1.5.tgz + object-keys: https://registry.npmmirror.com/object-keys/-/object-keys-1.1.1.tgz + regexp.prototype.flags: https://registry.npmmirror.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz + + define-properties@https://registry.npmmirror.com/define-properties/-/define-properties-1.2.0.tgz: + dependencies: + has-property-descriptors: https://registry.npmmirror.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz + object-keys: https://registry.npmmirror.com/object-keys/-/object-keys-1.1.1.tgz + + define-property@https://registry.npmmirror.com/define-property/-/define-property-0.2.5.tgz: + dependencies: + is-descriptor: https://registry.npmmirror.com/is-descriptor/-/is-descriptor-0.1.6.tgz + + define-property@https://registry.npmmirror.com/define-property/-/define-property-1.0.0.tgz: + dependencies: + is-descriptor: https://registry.npmmirror.com/is-descriptor/-/is-descriptor-1.0.2.tgz + + define-property@https://registry.npmmirror.com/define-property/-/define-property-2.0.2.tgz: + dependencies: + is-descriptor: https://registry.npmmirror.com/is-descriptor/-/is-descriptor-1.0.2.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + + delayed-stream@https://registry.npmmirror.com/delayed-stream/-/delayed-stream-1.0.0.tgz: {} + + dom-serializer@https://registry.npmmirror.com/dom-serializer/-/dom-serializer-0.2.2.tgz: + dependencies: + domelementtype: https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz + entities: https://registry.npmmirror.com/entities/-/entities-2.2.0.tgz + + dom-serializer@https://registry.npmmirror.com/dom-serializer/-/dom-serializer-1.4.1.tgz: + dependencies: + domelementtype: https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz + domhandler: https://registry.npmmirror.com/domhandler/-/domhandler-4.3.1.tgz + entities: https://registry.npmmirror.com/entities/-/entities-2.2.0.tgz + + domelementtype@https://registry.npmmirror.com/domelementtype/-/domelementtype-1.3.1.tgz: {} + + domelementtype@https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz: {} + + domhandler@https://registry.npmmirror.com/domhandler/-/domhandler-2.4.2.tgz: + dependencies: + domelementtype: https://registry.npmmirror.com/domelementtype/-/domelementtype-1.3.1.tgz + + domhandler@https://registry.npmmirror.com/domhandler/-/domhandler-4.3.1.tgz: + dependencies: + domelementtype: https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz + + domutils@https://registry.npmmirror.com/domutils/-/domutils-1.7.0.tgz: + dependencies: + dom-serializer: https://registry.npmmirror.com/dom-serializer/-/dom-serializer-0.2.2.tgz + domelementtype: https://registry.npmmirror.com/domelementtype/-/domelementtype-1.3.1.tgz + + domutils@https://registry.npmmirror.com/domutils/-/domutils-2.8.0.tgz: + dependencies: + dom-serializer: https://registry.npmmirror.com/dom-serializer/-/dom-serializer-1.4.1.tgz + domelementtype: https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz + domhandler: https://registry.npmmirror.com/domhandler/-/domhandler-4.3.1.tgz + + echarts@https://registry.npmmirror.com/echarts/-/echarts-5.4.0.tgz: + dependencies: + tslib: https://registry.npmmirror.com/tslib/-/tslib-2.3.0.tgz + zrender: https://registry.npmmirror.com/zrender/-/zrender-5.4.0.tgz + + element-plus@2.7.3(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz): + dependencies: + '@ctrl/tinycolor': 3.6.1 + '@element-plus/icons-vue': 2.3.1(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + '@floating-ui/dom': 1.6.5 + '@popperjs/core': '@sxzz/popperjs-es@2.11.7' + '@types/lodash': 4.17.4 + '@types/lodash-es': 4.17.12 + '@vueuse/core': 9.5.0(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + async-validator: 4.2.5 + dayjs: 1.11.11 + escape-html: 1.0.3 + lodash: 4.17.21 + lodash-es: 4.17.21 + lodash-unified: 1.0.3(@types/lodash-es@4.17.12)(lodash-es@4.17.21)(lodash@4.17.21) + memoize-one: 6.0.0 + normalize-wheel-es: 1.2.0 + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + transitivePeerDependencies: + - '@vue/composition-api' + + emojis-list@https://registry.npmmirror.com/emojis-list/-/emojis-list-3.0.0.tgz: {} + + entities@https://registry.npmmirror.com/entities/-/entities-1.1.2.tgz: {} + + entities@https://registry.npmmirror.com/entities/-/entities-2.2.0.tgz: {} + + esbuild-android-64@0.15.18: + optional: true + + esbuild-android-arm64@0.15.18: + optional: true + + esbuild-darwin-64@0.15.18: + optional: true + + esbuild-darwin-arm64@0.15.18: + optional: true + + esbuild-freebsd-64@0.15.18: + optional: true + + esbuild-freebsd-arm64@0.15.18: + optional: true + + esbuild-linux-32@0.15.18: + optional: true + + esbuild-linux-64@0.15.18: + optional: true + + esbuild-linux-arm64@0.15.18: + optional: true + + esbuild-linux-arm@0.15.18: + optional: true + + esbuild-linux-mips64le@0.15.18: + optional: true + + esbuild-linux-ppc64le@0.15.18: + optional: true + + esbuild-linux-riscv64@0.15.18: + optional: true + + esbuild-linux-s390x@0.15.18: + optional: true + + esbuild-netbsd-64@0.15.18: + optional: true + + esbuild-openbsd-64@0.15.18: + optional: true + + esbuild-sunos-64@0.15.18: + optional: true + + esbuild-windows-32@0.15.18: + optional: true + + esbuild-windows-64@0.15.18: + optional: true + + esbuild-windows-arm64@0.15.18: + optional: true + + esbuild@https://registry.npmmirror.com/esbuild/-/esbuild-0.15.18.tgz: + optionalDependencies: + '@esbuild/android-arm': 0.15.18 + '@esbuild/linux-loong64': 0.15.18 + esbuild-android-64: 0.15.18 + esbuild-android-arm64: 0.15.18 + esbuild-darwin-64: 0.15.18 + esbuild-darwin-arm64: 0.15.18 + esbuild-freebsd-64: 0.15.18 + esbuild-freebsd-arm64: 0.15.18 + esbuild-linux-32: 0.15.18 + esbuild-linux-64: 0.15.18 + esbuild-linux-arm: 0.15.18 + esbuild-linux-arm64: 0.15.18 + esbuild-linux-mips64le: 0.15.18 + esbuild-linux-ppc64le: 0.15.18 + esbuild-linux-riscv64: 0.15.18 + esbuild-linux-s390x: 0.15.18 + esbuild-netbsd-64: 0.15.18 + esbuild-openbsd-64: 0.15.18 + esbuild-sunos-64: 0.15.18 + esbuild-windows-32: 0.15.18 + esbuild-windows-64: 0.15.18 + esbuild-windows-arm64: 0.15.18 + + escape-html@1.0.3: {} + + escape-string-regexp@https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz: {} + + escape-string-regexp@https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz: {} + + estree-walker@https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz: {} + + etag@https://registry.npmmirror.com/etag/-/etag-1.8.1.tgz: {} + + eventemitter3@https://registry.npmmirror.com/eventemitter3/-/eventemitter3-2.0.3.tgz: {} + + expand-brackets@https://registry.npmmirror.com/expand-brackets/-/expand-brackets-2.1.4.tgz: + dependencies: + debug: https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz + define-property: https://registry.npmmirror.com/define-property/-/define-property-0.2.5.tgz + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz + posix-character-classes: https://registry.npmmirror.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz + regex-not: https://registry.npmmirror.com/regex-not/-/regex-not-1.0.2.tgz + snapdragon: https://registry.npmmirror.com/snapdragon/-/snapdragon-0.8.2.tgz + to-regex: https://registry.npmmirror.com/to-regex/-/to-regex-3.0.2.tgz + transitivePeerDependencies: + - supports-color + + extend-shallow@https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz: + dependencies: + is-extendable: https://registry.npmmirror.com/is-extendable/-/is-extendable-0.1.1.tgz + + extend-shallow@https://registry.npmmirror.com/extend-shallow/-/extend-shallow-3.0.2.tgz: + dependencies: + assign-symbols: https://registry.npmmirror.com/assign-symbols/-/assign-symbols-1.0.0.tgz + is-extendable: https://registry.npmmirror.com/is-extendable/-/is-extendable-1.0.1.tgz + + extend@https://registry.npmmirror.com/extend/-/extend-3.0.2.tgz: {} + + extglob@https://registry.npmmirror.com/extglob/-/extglob-2.0.4.tgz: + dependencies: + array-unique: https://registry.npmmirror.com/array-unique/-/array-unique-0.3.2.tgz + define-property: https://registry.npmmirror.com/define-property/-/define-property-1.0.0.tgz + expand-brackets: https://registry.npmmirror.com/expand-brackets/-/expand-brackets-2.1.4.tgz + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz + fragment-cache: https://registry.npmmirror.com/fragment-cache/-/fragment-cache-0.2.1.tgz + regex-not: https://registry.npmmirror.com/regex-not/-/regex-not-1.0.2.tgz + snapdragon: https://registry.npmmirror.com/snapdragon/-/snapdragon-0.8.2.tgz + to-regex: https://registry.npmmirror.com/to-regex/-/to-regex-3.0.2.tgz + transitivePeerDependencies: + - supports-color + + fast-diff@https://registry.npmmirror.com/fast-diff/-/fast-diff-1.1.2.tgz: {} + + fast-diff@https://registry.npmmirror.com/fast-diff/-/fast-diff-1.2.0.tgz: {} + + fast-glob@https://registry.npmmirror.com/fast-glob/-/fast-glob-3.2.12.tgz: + dependencies: + '@nodelib/fs.stat': https://registry.npmmirror.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz + '@nodelib/fs.walk': https://registry.npmmirror.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz + glob-parent: https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz + merge2: https://registry.npmmirror.com/merge2/-/merge2-1.4.1.tgz + micromatch: https://registry.npmmirror.com/micromatch/-/micromatch-4.0.5.tgz + + fastq@https://registry.npmmirror.com/fastq/-/fastq-1.15.0.tgz: + dependencies: + reusify: https://registry.npmmirror.com/reusify/-/reusify-1.0.4.tgz + + file-saver@https://registry.npmmirror.com/file-saver/-/file-saver-2.0.5.tgz: {} + + fill-range@https://registry.npmmirror.com/fill-range/-/fill-range-4.0.0.tgz: + dependencies: + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz + is-number: https://registry.npmmirror.com/is-number/-/is-number-3.0.0.tgz + repeat-string: https://registry.npmmirror.com/repeat-string/-/repeat-string-1.6.1.tgz + to-regex-range: https://registry.npmmirror.com/to-regex-range/-/to-regex-range-2.1.1.tgz + + fill-range@https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz: + dependencies: + to-regex-range: https://registry.npmmirror.com/to-regex-range/-/to-regex-range-5.0.1.tgz + + follow-redirects@https://registry.npmmirror.com/follow-redirects/-/follow-redirects-1.15.2.tgz: {} + + for-in@https://registry.npmmirror.com/for-in/-/for-in-1.0.2.tgz: {} + + form-data@https://registry.npmmirror.com/form-data/-/form-data-4.0.0.tgz: + dependencies: + asynckit: https://registry.npmmirror.com/asynckit/-/asynckit-0.4.0.tgz + combined-stream: https://registry.npmmirror.com/combined-stream/-/combined-stream-1.0.8.tgz + mime-types: https://registry.npmmirror.com/mime-types/-/mime-types-2.1.35.tgz + + fragment-cache@https://registry.npmmirror.com/fragment-cache/-/fragment-cache-0.2.1.tgz: + dependencies: + map-cache: https://registry.npmmirror.com/map-cache/-/map-cache-0.2.2.tgz + + fs-extra@https://registry.npmmirror.com/fs-extra/-/fs-extra-10.1.0.tgz: + dependencies: + graceful-fs: https://registry.npmmirror.com/graceful-fs/-/graceful-fs-4.2.11.tgz + jsonfile: https://registry.npmmirror.com/jsonfile/-/jsonfile-6.1.0.tgz + universalify: https://registry.npmmirror.com/universalify/-/universalify-2.0.0.tgz + + fsevents@2.3.3: + optional: true + + function-bind@https://registry.npmmirror.com/function-bind/-/function-bind-1.1.1.tgz: {} + + functions-have-names@https://registry.npmmirror.com/functions-have-names/-/functions-have-names-1.2.3.tgz: {} + + fuse.js@https://registry.npmmirror.com/fuse.js/-/fuse.js-6.6.2.tgz: {} + + get-intrinsic@https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.2.1.tgz: + dependencies: + function-bind: https://registry.npmmirror.com/function-bind/-/function-bind-1.1.1.tgz + has: https://registry.npmmirror.com/has/-/has-1.0.3.tgz + has-proto: https://registry.npmmirror.com/has-proto/-/has-proto-1.0.1.tgz + has-symbols: https://registry.npmmirror.com/has-symbols/-/has-symbols-1.0.3.tgz + + get-value@https://registry.npmmirror.com/get-value/-/get-value-2.0.6.tgz: {} + + glob-parent@https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz: + dependencies: + is-glob: https://registry.npmmirror.com/is-glob/-/is-glob-4.0.3.tgz + + graceful-fs@4.2.11: + optional: true + + graceful-fs@https://registry.npmmirror.com/graceful-fs/-/graceful-fs-4.2.11.tgz: {} + + has-ansi@https://registry.npmmirror.com/has-ansi/-/has-ansi-2.0.0.tgz: + dependencies: + ansi-regex: https://registry.npmmirror.com/ansi-regex/-/ansi-regex-2.1.1.tgz + + has-flag@https://registry.npmmirror.com/has-flag/-/has-flag-1.0.0.tgz: {} + + has-flag@https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz: {} + + has-property-descriptors@https://registry.npmmirror.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz: + dependencies: + get-intrinsic: https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.2.1.tgz + + has-proto@https://registry.npmmirror.com/has-proto/-/has-proto-1.0.1.tgz: {} + + has-symbols@https://registry.npmmirror.com/has-symbols/-/has-symbols-1.0.3.tgz: {} + + has-tostringtag@https://registry.npmmirror.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz: + dependencies: + has-symbols: https://registry.npmmirror.com/has-symbols/-/has-symbols-1.0.3.tgz + + has-value@https://registry.npmmirror.com/has-value/-/has-value-0.3.1.tgz: + dependencies: + get-value: https://registry.npmmirror.com/get-value/-/get-value-2.0.6.tgz + has-values: https://registry.npmmirror.com/has-values/-/has-values-0.1.4.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-2.1.0.tgz + + has-value@https://registry.npmmirror.com/has-value/-/has-value-1.0.0.tgz: + dependencies: + get-value: https://registry.npmmirror.com/get-value/-/get-value-2.0.6.tgz + has-values: https://registry.npmmirror.com/has-values/-/has-values-1.0.0.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + + has-values@https://registry.npmmirror.com/has-values/-/has-values-0.1.4.tgz: {} + + has-values@https://registry.npmmirror.com/has-values/-/has-values-1.0.0.tgz: + dependencies: + is-number: https://registry.npmmirror.com/is-number/-/is-number-3.0.0.tgz + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-4.0.0.tgz + + has@https://registry.npmmirror.com/has/-/has-1.0.3.tgz: + dependencies: + function-bind: https://registry.npmmirror.com/function-bind/-/function-bind-1.1.1.tgz + + he@https://registry.npmmirror.com/he/-/he-1.2.0.tgz: {} + + htmlparser2@https://registry.npmmirror.com/htmlparser2/-/htmlparser2-3.10.1.tgz: + dependencies: + domelementtype: https://registry.npmmirror.com/domelementtype/-/domelementtype-1.3.1.tgz + domhandler: https://registry.npmmirror.com/domhandler/-/domhandler-2.4.2.tgz + domutils: https://registry.npmmirror.com/domutils/-/domutils-1.7.0.tgz + entities: https://registry.npmmirror.com/entities/-/entities-1.1.2.tgz + inherits: https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz + readable-stream: https://registry.npmmirror.com/readable-stream/-/readable-stream-3.6.2.tgz + + image-size@https://registry.npmmirror.com/image-size/-/image-size-0.5.5.tgz: {} + + immutable@https://registry.npmmirror.com/immutable/-/immutable-4.3.0.tgz: {} + + inherits@https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz: {} + + is-accessor-descriptor@https://registry.npmmirror.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz: + dependencies: + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz + + is-accessor-descriptor@https://registry.npmmirror.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz: + dependencies: + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz + + is-arguments@https://registry.npmmirror.com/is-arguments/-/is-arguments-1.1.1.tgz: + dependencies: + call-bind: https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz + has-tostringtag: https://registry.npmmirror.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz + + is-binary-path@https://registry.npmmirror.com/is-binary-path/-/is-binary-path-2.1.0.tgz: + dependencies: + binary-extensions: https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.2.0.tgz + + is-buffer@https://registry.npmmirror.com/is-buffer/-/is-buffer-1.1.6.tgz: {} + + is-core-module@https://registry.npmmirror.com/is-core-module/-/is-core-module-2.12.1.tgz: + dependencies: + has: https://registry.npmmirror.com/has/-/has-1.0.3.tgz + + is-data-descriptor@https://registry.npmmirror.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz: + dependencies: + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz + + is-data-descriptor@https://registry.npmmirror.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz: + dependencies: + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz + + is-date-object@https://registry.npmmirror.com/is-date-object/-/is-date-object-1.0.5.tgz: + dependencies: + has-tostringtag: https://registry.npmmirror.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz + + is-descriptor@https://registry.npmmirror.com/is-descriptor/-/is-descriptor-0.1.6.tgz: + dependencies: + is-accessor-descriptor: https://registry.npmmirror.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz + is-data-descriptor: https://registry.npmmirror.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-5.1.0.tgz + + is-descriptor@https://registry.npmmirror.com/is-descriptor/-/is-descriptor-1.0.2.tgz: + dependencies: + is-accessor-descriptor: https://registry.npmmirror.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz + is-data-descriptor: https://registry.npmmirror.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz + + is-extendable@https://registry.npmmirror.com/is-extendable/-/is-extendable-0.1.1.tgz: {} + + is-extendable@https://registry.npmmirror.com/is-extendable/-/is-extendable-1.0.1.tgz: + dependencies: + is-plain-object: https://registry.npmmirror.com/is-plain-object/-/is-plain-object-2.0.4.tgz + + is-extglob@https://registry.npmmirror.com/is-extglob/-/is-extglob-2.1.1.tgz: {} + + is-glob@https://registry.npmmirror.com/is-glob/-/is-glob-4.0.3.tgz: + dependencies: + is-extglob: https://registry.npmmirror.com/is-extglob/-/is-extglob-2.1.1.tgz + + is-number@https://registry.npmmirror.com/is-number/-/is-number-3.0.0.tgz: + dependencies: + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz + + is-number@https://registry.npmmirror.com/is-number/-/is-number-7.0.0.tgz: {} + + is-plain-obj@https://registry.npmmirror.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz: {} + + is-plain-object@https://registry.npmmirror.com/is-plain-object/-/is-plain-object-2.0.4.tgz: + dependencies: + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + + is-regex@https://registry.npmmirror.com/is-regex/-/is-regex-1.1.4.tgz: + dependencies: + call-bind: https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz + has-tostringtag: https://registry.npmmirror.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz + + is-windows@https://registry.npmmirror.com/is-windows/-/is-windows-1.0.2.tgz: {} + + isarray@https://registry.npmmirror.com/isarray/-/isarray-1.0.0.tgz: {} + + isobject@https://registry.npmmirror.com/isobject/-/isobject-2.1.0.tgz: + dependencies: + isarray: https://registry.npmmirror.com/isarray/-/isarray-1.0.0.tgz + + isobject@https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz: {} + + js-base64@https://registry.npmmirror.com/js-base64/-/js-base64-2.6.4.tgz: {} + + js-cookie@https://registry.npmmirror.com/js-cookie/-/js-cookie-3.0.1.tgz: {} + + jsencrypt@https://registry.npmmirror.com/jsencrypt/-/jsencrypt-3.3.1.tgz: {} + + json5@https://registry.npmmirror.com/json5/-/json5-1.0.2.tgz: + dependencies: + minimist: https://registry.npmmirror.com/minimist/-/minimist-1.2.8.tgz + + jsonc-parser@https://registry.npmmirror.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz: {} + + jsonfile@https://registry.npmmirror.com/jsonfile/-/jsonfile-6.1.0.tgz: + dependencies: + universalify: https://registry.npmmirror.com/universalify/-/universalify-2.0.0.tgz + optionalDependencies: + graceful-fs: 4.2.11 + + kind-of@https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz: + dependencies: + is-buffer: https://registry.npmmirror.com/is-buffer/-/is-buffer-1.1.6.tgz + + kind-of@https://registry.npmmirror.com/kind-of/-/kind-of-4.0.0.tgz: + dependencies: + is-buffer: https://registry.npmmirror.com/is-buffer/-/is-buffer-1.1.6.tgz + + kind-of@https://registry.npmmirror.com/kind-of/-/kind-of-5.1.0.tgz: {} + + kind-of@https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz: {} + + loader-utils@https://registry.npmmirror.com/loader-utils/-/loader-utils-1.4.2.tgz: + dependencies: + big.js: https://registry.npmmirror.com/big.js/-/big.js-5.2.2.tgz + emojis-list: https://registry.npmmirror.com/emojis-list/-/emojis-list-3.0.0.tgz + json5: https://registry.npmmirror.com/json5/-/json5-1.0.2.tgz + + local-pkg@https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz: {} + + lodash-es@4.17.21: {} + + lodash-unified@1.0.3(@types/lodash-es@4.17.12)(lodash-es@4.17.21)(lodash@4.17.21): + dependencies: + '@types/lodash-es': 4.17.12 + lodash: 4.17.21 + lodash-es: 4.17.21 + + lodash.clonedeep@https://registry.npmmirror.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz: {} + + lodash.isequal@https://registry.npmmirror.com/lodash.isequal/-/lodash.isequal-4.5.0.tgz: {} + + lodash@4.17.21: {} + + magic-string@https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz: + dependencies: + sourcemap-codec: https://registry.npmmirror.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz + + magic-string@https://registry.npmmirror.com/magic-string/-/magic-string-0.26.7.tgz: + dependencies: + sourcemap-codec: https://registry.npmmirror.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz + + map-cache@https://registry.npmmirror.com/map-cache/-/map-cache-0.2.2.tgz: {} + + map-visit@https://registry.npmmirror.com/map-visit/-/map-visit-1.0.0.tgz: + dependencies: + object-visit: https://registry.npmmirror.com/object-visit/-/object-visit-1.0.1.tgz + + mdn-data@https://registry.npmmirror.com/mdn-data/-/mdn-data-2.0.14.tgz: {} + + memoize-one@6.0.0: {} + + merge-options@https://registry.npmmirror.com/merge-options/-/merge-options-1.0.1.tgz: + dependencies: + is-plain-obj: https://registry.npmmirror.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz + + merge2@https://registry.npmmirror.com/merge2/-/merge2-1.4.1.tgz: {} + + mescroll.js@https://registry.npmmirror.com/mescroll.js/-/mescroll.js-1.4.2.tgz: {} + + micromatch@https://registry.npmmirror.com/micromatch/-/micromatch-3.1.0.tgz: + dependencies: + arr-diff: https://registry.npmmirror.com/arr-diff/-/arr-diff-4.0.0.tgz + array-unique: https://registry.npmmirror.com/array-unique/-/array-unique-0.3.2.tgz + braces: https://registry.npmmirror.com/braces/-/braces-2.3.2.tgz + define-property: https://registry.npmmirror.com/define-property/-/define-property-1.0.0.tgz + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz + extglob: https://registry.npmmirror.com/extglob/-/extglob-2.0.4.tgz + fragment-cache: https://registry.npmmirror.com/fragment-cache/-/fragment-cache-0.2.1.tgz + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-5.1.0.tgz + nanomatch: https://registry.npmmirror.com/nanomatch/-/nanomatch-1.2.13.tgz + object.pick: https://registry.npmmirror.com/object.pick/-/object.pick-1.3.0.tgz + regex-not: https://registry.npmmirror.com/regex-not/-/regex-not-1.0.2.tgz + snapdragon: https://registry.npmmirror.com/snapdragon/-/snapdragon-0.8.2.tgz + to-regex: https://registry.npmmirror.com/to-regex/-/to-regex-3.0.2.tgz + transitivePeerDependencies: + - supports-color + + micromatch@https://registry.npmmirror.com/micromatch/-/micromatch-4.0.5.tgz: + dependencies: + braces: https://registry.npmmirror.com/braces/-/braces-3.0.2.tgz + picomatch: https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz + + mime-db@https://registry.npmmirror.com/mime-db/-/mime-db-1.52.0.tgz: {} + + mime-types@https://registry.npmmirror.com/mime-types/-/mime-types-2.1.35.tgz: + dependencies: + mime-db: https://registry.npmmirror.com/mime-db/-/mime-db-1.52.0.tgz + + minimist@https://registry.npmmirror.com/minimist/-/minimist-1.2.8.tgz: {} + + mixin-deep@https://registry.npmmirror.com/mixin-deep/-/mixin-deep-1.3.2.tgz: + dependencies: + for-in: https://registry.npmmirror.com/for-in/-/for-in-1.0.2.tgz + is-extendable: https://registry.npmmirror.com/is-extendable/-/is-extendable-1.0.1.tgz + + mlly@https://registry.npmmirror.com/mlly/-/mlly-1.3.0.tgz: + dependencies: + acorn: https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz + pathe: https://registry.npmmirror.com/pathe/-/pathe-1.1.0.tgz + pkg-types: https://registry.npmmirror.com/pkg-types/-/pkg-types-1.0.3.tgz + ufo: https://registry.npmmirror.com/ufo/-/ufo-1.1.2.tgz + + ms@https://registry.npmmirror.com/ms/-/ms-2.0.0.tgz: {} + + ms@https://registry.npmmirror.com/ms/-/ms-2.1.2.tgz: {} + + nanoid@https://registry.npmmirror.com/nanoid/-/nanoid-3.3.6.tgz: {} + + nanomatch@https://registry.npmmirror.com/nanomatch/-/nanomatch-1.2.13.tgz: + dependencies: + arr-diff: https://registry.npmmirror.com/arr-diff/-/arr-diff-4.0.0.tgz + array-unique: https://registry.npmmirror.com/array-unique/-/array-unique-0.3.2.tgz + define-property: https://registry.npmmirror.com/define-property/-/define-property-2.0.2.tgz + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-3.0.2.tgz + fragment-cache: https://registry.npmmirror.com/fragment-cache/-/fragment-cache-0.2.1.tgz + is-windows: https://registry.npmmirror.com/is-windows/-/is-windows-1.0.2.tgz + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-6.0.3.tgz + object.pick: https://registry.npmmirror.com/object.pick/-/object.pick-1.3.0.tgz + regex-not: https://registry.npmmirror.com/regex-not/-/regex-not-1.0.2.tgz + snapdragon: https://registry.npmmirror.com/snapdragon/-/snapdragon-0.8.2.tgz + to-regex: https://registry.npmmirror.com/to-regex/-/to-regex-3.0.2.tgz + transitivePeerDependencies: + - supports-color + + normalize-path@https://registry.npmmirror.com/normalize-path/-/normalize-path-3.0.0.tgz: {} + + normalize-wheel-es@1.2.0: {} + + nprogress@https://registry.npmmirror.com/nprogress/-/nprogress-0.2.0.tgz: {} + + nth-check@https://registry.npmmirror.com/nth-check/-/nth-check-2.1.1.tgz: + dependencies: + boolbase: https://registry.npmmirror.com/boolbase/-/boolbase-1.0.0.tgz + + object-assign@https://registry.npmmirror.com/object-assign/-/object-assign-4.1.1.tgz: {} + + object-copy@https://registry.npmmirror.com/object-copy/-/object-copy-0.1.0.tgz: + dependencies: + copy-descriptor: https://registry.npmmirror.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz + define-property: https://registry.npmmirror.com/define-property/-/define-property-0.2.5.tgz + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz + + object-is@https://registry.npmmirror.com/object-is/-/object-is-1.1.5.tgz: + dependencies: + call-bind: https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz + define-properties: https://registry.npmmirror.com/define-properties/-/define-properties-1.2.0.tgz + + object-keys@https://registry.npmmirror.com/object-keys/-/object-keys-1.1.1.tgz: {} + + object-visit@https://registry.npmmirror.com/object-visit/-/object-visit-1.0.1.tgz: + dependencies: + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + + object.pick@https://registry.npmmirror.com/object.pick/-/object.pick-1.3.0.tgz: + dependencies: + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + + parchment@https://registry.npmmirror.com/parchment/-/parchment-1.1.4.tgz: {} + + pascalcase@https://registry.npmmirror.com/pascalcase/-/pascalcase-0.1.1.tgz: {} + + path-parse@https://registry.npmmirror.com/path-parse/-/path-parse-1.0.7.tgz: {} + + pathe@https://registry.npmmirror.com/pathe/-/pathe-0.2.0.tgz: {} + + pathe@https://registry.npmmirror.com/pathe/-/pathe-1.1.0.tgz: {} + + picocolors@https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz: {} + + picomatch@https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz: {} + + pinia-plugin-persist@https://registry.npmmirror.com/pinia-plugin-persist/-/pinia-plugin-persist-1.0.0.tgz(pinia@https://registry.npmmirror.com/pinia/-/pinia-2.0.22.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz))(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz): + dependencies: + pinia: https://registry.npmmirror.com/pinia/-/pinia-2.0.22.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + vue-demi: https://registry.npmmirror.com/vue-demi/-/vue-demi-0.12.5.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + + pinia@https://registry.npmmirror.com/pinia/-/pinia-2.0.22.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz): + dependencies: + '@vue/devtools-api': https://registry.npmmirror.com/@vue/devtools-api/-/devtools-api-6.5.0.tgz + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + vue-demi: https://registry.npmmirror.com/vue-demi/-/vue-demi-0.14.5.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + + pkg-types@https://registry.npmmirror.com/pkg-types/-/pkg-types-1.0.3.tgz: + dependencies: + jsonc-parser: https://registry.npmmirror.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz + mlly: https://registry.npmmirror.com/mlly/-/mlly-1.3.0.tgz + pathe: https://registry.npmmirror.com/pathe/-/pathe-1.1.0.tgz + + posix-character-classes@https://registry.npmmirror.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz: {} + + postcss-prefix-selector@https://registry.npmmirror.com/postcss-prefix-selector/-/postcss-prefix-selector-1.16.0.tgz(postcss@https://registry.npmmirror.com/postcss/-/postcss-5.2.18.tgz): + dependencies: + postcss: https://registry.npmmirror.com/postcss/-/postcss-5.2.18.tgz + + postcss@https://registry.npmmirror.com/postcss/-/postcss-5.2.18.tgz: + dependencies: + chalk: https://registry.npmmirror.com/chalk/-/chalk-1.1.3.tgz + js-base64: https://registry.npmmirror.com/js-base64/-/js-base64-2.6.4.tgz + source-map: https://registry.npmmirror.com/source-map/-/source-map-0.5.7.tgz + supports-color: https://registry.npmmirror.com/supports-color/-/supports-color-3.2.3.tgz + + postcss@https://registry.npmmirror.com/postcss/-/postcss-8.4.23.tgz: + dependencies: + nanoid: https://registry.npmmirror.com/nanoid/-/nanoid-3.3.6.tgz + picocolors: https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz + source-map-js: https://registry.npmmirror.com/source-map-js/-/source-map-js-1.0.2.tgz + + posthtml-parser@https://registry.npmmirror.com/posthtml-parser/-/posthtml-parser-0.2.1.tgz: + dependencies: + htmlparser2: https://registry.npmmirror.com/htmlparser2/-/htmlparser2-3.10.1.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-2.1.0.tgz + + posthtml-rename-id@https://registry.npmmirror.com/posthtml-rename-id/-/posthtml-rename-id-1.0.12.tgz: + dependencies: + escape-string-regexp: https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz + + posthtml-render@https://registry.npmmirror.com/posthtml-render/-/posthtml-render-1.4.0.tgz: {} + + posthtml-svg-mode@https://registry.npmmirror.com/posthtml-svg-mode/-/posthtml-svg-mode-1.0.3.tgz: + dependencies: + merge-options: https://registry.npmmirror.com/merge-options/-/merge-options-1.0.1.tgz + posthtml: https://registry.npmmirror.com/posthtml/-/posthtml-0.9.2.tgz + posthtml-parser: https://registry.npmmirror.com/posthtml-parser/-/posthtml-parser-0.2.1.tgz + posthtml-render: https://registry.npmmirror.com/posthtml-render/-/posthtml-render-1.4.0.tgz + + posthtml@https://registry.npmmirror.com/posthtml/-/posthtml-0.9.2.tgz: + dependencies: + posthtml-parser: https://registry.npmmirror.com/posthtml-parser/-/posthtml-parser-0.2.1.tgz + posthtml-render: https://registry.npmmirror.com/posthtml-render/-/posthtml-render-1.4.0.tgz + + query-string@https://registry.npmmirror.com/query-string/-/query-string-4.3.4.tgz: + dependencies: + object-assign: https://registry.npmmirror.com/object-assign/-/object-assign-4.1.1.tgz + strict-uri-encode: https://registry.npmmirror.com/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz + + queue-microtask@https://registry.npmmirror.com/queue-microtask/-/queue-microtask-1.2.3.tgz: {} + + quill-delta@https://registry.npmmirror.com/quill-delta/-/quill-delta-3.6.3.tgz: + dependencies: + deep-equal: https://registry.npmmirror.com/deep-equal/-/deep-equal-1.1.1.tgz + extend: https://registry.npmmirror.com/extend/-/extend-3.0.2.tgz + fast-diff: https://registry.npmmirror.com/fast-diff/-/fast-diff-1.1.2.tgz + + quill-delta@https://registry.npmmirror.com/quill-delta/-/quill-delta-4.2.2.tgz: + dependencies: + fast-diff: https://registry.npmmirror.com/fast-diff/-/fast-diff-1.2.0.tgz + lodash.clonedeep: https://registry.npmmirror.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz + lodash.isequal: https://registry.npmmirror.com/lodash.isequal/-/lodash.isequal-4.5.0.tgz + + quill@https://registry.npmmirror.com/quill/-/quill-1.3.7.tgz: + dependencies: + clone: https://registry.npmmirror.com/clone/-/clone-2.1.2.tgz + deep-equal: https://registry.npmmirror.com/deep-equal/-/deep-equal-1.1.1.tgz + eventemitter3: https://registry.npmmirror.com/eventemitter3/-/eventemitter3-2.0.3.tgz + extend: https://registry.npmmirror.com/extend/-/extend-3.0.2.tgz + parchment: https://registry.npmmirror.com/parchment/-/parchment-1.1.4.tgz + quill-delta: https://registry.npmmirror.com/quill-delta/-/quill-delta-3.6.3.tgz + + readable-stream@https://registry.npmmirror.com/readable-stream/-/readable-stream-3.6.2.tgz: + dependencies: + inherits: https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz + string_decoder: https://registry.npmmirror.com/string_decoder/-/string_decoder-1.3.0.tgz + util-deprecate: https://registry.npmmirror.com/util-deprecate/-/util-deprecate-1.0.2.tgz + + readdirp@https://registry.npmmirror.com/readdirp/-/readdirp-3.6.0.tgz: + dependencies: + picomatch: https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz + + regex-not@https://registry.npmmirror.com/regex-not/-/regex-not-1.0.2.tgz: + dependencies: + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-3.0.2.tgz + safe-regex: https://registry.npmmirror.com/safe-regex/-/safe-regex-1.1.0.tgz + + regexp.prototype.flags@https://registry.npmmirror.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz: + dependencies: + call-bind: https://registry.npmmirror.com/call-bind/-/call-bind-1.0.2.tgz + define-properties: https://registry.npmmirror.com/define-properties/-/define-properties-1.2.0.tgz + functions-have-names: https://registry.npmmirror.com/functions-have-names/-/functions-have-names-1.2.3.tgz + + repeat-element@https://registry.npmmirror.com/repeat-element/-/repeat-element-1.1.4.tgz: {} + + repeat-string@https://registry.npmmirror.com/repeat-string/-/repeat-string-1.6.1.tgz: {} + + resolve-url@https://registry.npmmirror.com/resolve-url/-/resolve-url-0.2.1.tgz: {} + + resolve@https://registry.npmmirror.com/resolve/-/resolve-1.22.2.tgz: + dependencies: + is-core-module: https://registry.npmmirror.com/is-core-module/-/is-core-module-2.12.1.tgz + path-parse: https://registry.npmmirror.com/path-parse/-/path-parse-1.0.7.tgz + supports-preserve-symlinks-flag: https://registry.npmmirror.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz + + ret@https://registry.npmmirror.com/ret/-/ret-0.1.15.tgz: {} + + reusify@https://registry.npmmirror.com/reusify/-/reusify-1.0.4.tgz: {} + + rollup@2.79.1: + optionalDependencies: + fsevents: 2.3.3 + optional: true + + rollup@https://registry.npmmirror.com/rollup/-/rollup-2.79.1.tgz: + optionalDependencies: + fsevents: 2.3.3 + + run-parallel@https://registry.npmmirror.com/run-parallel/-/run-parallel-1.2.0.tgz: + dependencies: + queue-microtask: https://registry.npmmirror.com/queue-microtask/-/queue-microtask-1.2.3.tgz + + safe-buffer@https://registry.npmmirror.com/safe-buffer/-/safe-buffer-5.2.1.tgz: {} + + safe-regex@https://registry.npmmirror.com/safe-regex/-/safe-regex-1.1.0.tgz: + dependencies: + ret: https://registry.npmmirror.com/ret/-/ret-0.1.15.tgz + + sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz: + dependencies: + chokidar: https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz + immutable: https://registry.npmmirror.com/immutable/-/immutable-4.3.0.tgz + source-map-js: https://registry.npmmirror.com/source-map-js/-/source-map-js-1.0.2.tgz + + scule@https://registry.npmmirror.com/scule/-/scule-1.0.0.tgz: {} + + set-value@https://registry.npmmirror.com/set-value/-/set-value-2.0.1.tgz: + dependencies: + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz + is-extendable: https://registry.npmmirror.com/is-extendable/-/is-extendable-0.1.1.tgz + is-plain-object: https://registry.npmmirror.com/is-plain-object/-/is-plain-object-2.0.4.tgz + split-string: https://registry.npmmirror.com/split-string/-/split-string-3.1.0.tgz + + snapdragon-node@https://registry.npmmirror.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz: + dependencies: + define-property: https://registry.npmmirror.com/define-property/-/define-property-1.0.0.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + snapdragon-util: https://registry.npmmirror.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz + + snapdragon-util@https://registry.npmmirror.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz: + dependencies: + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz + + snapdragon@https://registry.npmmirror.com/snapdragon/-/snapdragon-0.8.2.tgz: + dependencies: + base: https://registry.npmmirror.com/base/-/base-0.11.2.tgz + debug: https://registry.npmmirror.com/debug/-/debug-2.6.9.tgz + define-property: https://registry.npmmirror.com/define-property/-/define-property-0.2.5.tgz + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-2.0.1.tgz + map-cache: https://registry.npmmirror.com/map-cache/-/map-cache-0.2.2.tgz + source-map: https://registry.npmmirror.com/source-map/-/source-map-0.5.7.tgz + source-map-resolve: https://registry.npmmirror.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz + use: https://registry.npmmirror.com/use/-/use-3.1.1.tgz + transitivePeerDependencies: + - supports-color + + source-map-js@https://registry.npmmirror.com/source-map-js/-/source-map-js-1.0.2.tgz: {} + + source-map-resolve@https://registry.npmmirror.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz: + dependencies: + atob: https://registry.npmmirror.com/atob/-/atob-2.1.2.tgz + decode-uri-component: https://registry.npmmirror.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz + resolve-url: https://registry.npmmirror.com/resolve-url/-/resolve-url-0.2.1.tgz + source-map-url: https://registry.npmmirror.com/source-map-url/-/source-map-url-0.4.1.tgz + urix: https://registry.npmmirror.com/urix/-/urix-0.1.0.tgz + + source-map-url@https://registry.npmmirror.com/source-map-url/-/source-map-url-0.4.1.tgz: {} + + source-map@https://registry.npmmirror.com/source-map/-/source-map-0.5.7.tgz: {} + + source-map@https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz: {} + + sourcemap-codec@https://registry.npmmirror.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz: {} + + split-string@https://registry.npmmirror.com/split-string/-/split-string-3.1.0.tgz: + dependencies: + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-3.0.2.tgz + + stable@https://registry.npmmirror.com/stable/-/stable-0.1.8.tgz: {} + + static-extend@https://registry.npmmirror.com/static-extend/-/static-extend-0.1.2.tgz: + dependencies: + define-property: https://registry.npmmirror.com/define-property/-/define-property-0.2.5.tgz + object-copy: https://registry.npmmirror.com/object-copy/-/object-copy-0.1.0.tgz + + strict-uri-encode@https://registry.npmmirror.com/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz: {} + + string_decoder@https://registry.npmmirror.com/string_decoder/-/string_decoder-1.3.0.tgz: + dependencies: + safe-buffer: https://registry.npmmirror.com/safe-buffer/-/safe-buffer-5.2.1.tgz + + strip-ansi@https://registry.npmmirror.com/strip-ansi/-/strip-ansi-3.0.1.tgz: + dependencies: + ansi-regex: https://registry.npmmirror.com/ansi-regex/-/ansi-regex-2.1.1.tgz + + strip-literal@https://registry.npmmirror.com/strip-literal/-/strip-literal-1.0.1.tgz: + dependencies: + acorn: https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz + + supports-color@https://registry.npmmirror.com/supports-color/-/supports-color-2.0.0.tgz: {} + + supports-color@https://registry.npmmirror.com/supports-color/-/supports-color-3.2.3.tgz: + dependencies: + has-flag: https://registry.npmmirror.com/has-flag/-/has-flag-1.0.0.tgz + + supports-color@https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz: + dependencies: + has-flag: https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz + + supports-preserve-symlinks-flag@https://registry.npmmirror.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz: {} + + svg-baker@https://registry.npmmirror.com/svg-baker/-/svg-baker-1.7.0.tgz: + dependencies: + bluebird: https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz + clone: https://registry.npmmirror.com/clone/-/clone-2.1.2.tgz + he: https://registry.npmmirror.com/he/-/he-1.2.0.tgz + image-size: https://registry.npmmirror.com/image-size/-/image-size-0.5.5.tgz + loader-utils: https://registry.npmmirror.com/loader-utils/-/loader-utils-1.4.2.tgz + merge-options: https://registry.npmmirror.com/merge-options/-/merge-options-1.0.1.tgz + micromatch: https://registry.npmmirror.com/micromatch/-/micromatch-3.1.0.tgz + postcss: https://registry.npmmirror.com/postcss/-/postcss-5.2.18.tgz + postcss-prefix-selector: https://registry.npmmirror.com/postcss-prefix-selector/-/postcss-prefix-selector-1.16.0.tgz(postcss@https://registry.npmmirror.com/postcss/-/postcss-5.2.18.tgz) + posthtml-rename-id: https://registry.npmmirror.com/posthtml-rename-id/-/posthtml-rename-id-1.0.12.tgz + posthtml-svg-mode: https://registry.npmmirror.com/posthtml-svg-mode/-/posthtml-svg-mode-1.0.3.tgz + query-string: https://registry.npmmirror.com/query-string/-/query-string-4.3.4.tgz + traverse: https://registry.npmmirror.com/traverse/-/traverse-0.6.7.tgz + transitivePeerDependencies: + - supports-color + + svgo@https://registry.npmmirror.com/svgo/-/svgo-2.8.0.tgz: + dependencies: + '@trysound/sax': https://registry.npmmirror.com/@trysound/sax/-/sax-0.2.0.tgz + commander: https://registry.npmmirror.com/commander/-/commander-7.2.0.tgz + css-select: https://registry.npmmirror.com/css-select/-/css-select-4.3.0.tgz + css-tree: https://registry.npmmirror.com/css-tree/-/css-tree-1.1.3.tgz + csso: https://registry.npmmirror.com/csso/-/csso-4.2.0.tgz + picocolors: https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz + stable: https://registry.npmmirror.com/stable/-/stable-0.1.8.tgz + + to-fast-properties@https://registry.npmmirror.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz: {} + + to-object-path@https://registry.npmmirror.com/to-object-path/-/to-object-path-0.3.0.tgz: + dependencies: + kind-of: https://registry.npmmirror.com/kind-of/-/kind-of-3.2.2.tgz + + to-regex-range@https://registry.npmmirror.com/to-regex-range/-/to-regex-range-2.1.1.tgz: + dependencies: + is-number: https://registry.npmmirror.com/is-number/-/is-number-3.0.0.tgz + repeat-string: https://registry.npmmirror.com/repeat-string/-/repeat-string-1.6.1.tgz + + to-regex-range@https://registry.npmmirror.com/to-regex-range/-/to-regex-range-5.0.1.tgz: + dependencies: + is-number: https://registry.npmmirror.com/is-number/-/is-number-7.0.0.tgz + + to-regex@https://registry.npmmirror.com/to-regex/-/to-regex-3.0.2.tgz: + dependencies: + define-property: https://registry.npmmirror.com/define-property/-/define-property-2.0.2.tgz + extend-shallow: https://registry.npmmirror.com/extend-shallow/-/extend-shallow-3.0.2.tgz + regex-not: https://registry.npmmirror.com/regex-not/-/regex-not-1.0.2.tgz + safe-regex: https://registry.npmmirror.com/safe-regex/-/safe-regex-1.1.0.tgz + + traverse@https://registry.npmmirror.com/traverse/-/traverse-0.6.7.tgz: {} + + tslib@https://registry.npmmirror.com/tslib/-/tslib-2.3.0.tgz: {} + + ufo@https://registry.npmmirror.com/ufo/-/ufo-1.1.2.tgz: {} + + unimport@https://registry.npmmirror.com/unimport/-/unimport-0.7.1.tgz(rollup@2.79.1): + dependencies: + '@rollup/pluginutils': https://registry.npmmirror.com/@rollup/pluginutils/-/pluginutils-5.0.2.tgz(rollup@2.79.1) + escape-string-regexp: https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz + fast-glob: https://registry.npmmirror.com/fast-glob/-/fast-glob-3.2.12.tgz + local-pkg: https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz + magic-string: https://registry.npmmirror.com/magic-string/-/magic-string-0.26.7.tgz + mlly: https://registry.npmmirror.com/mlly/-/mlly-1.3.0.tgz + pathe: https://registry.npmmirror.com/pathe/-/pathe-1.1.0.tgz + pkg-types: https://registry.npmmirror.com/pkg-types/-/pkg-types-1.0.3.tgz + scule: https://registry.npmmirror.com/scule/-/scule-1.0.0.tgz + strip-literal: https://registry.npmmirror.com/strip-literal/-/strip-literal-1.0.1.tgz + unplugin: https://registry.npmmirror.com/unplugin/-/unplugin-1.3.1.tgz + transitivePeerDependencies: + - rollup + + union-value@https://registry.npmmirror.com/union-value/-/union-value-1.0.1.tgz: + dependencies: + arr-union: https://registry.npmmirror.com/arr-union/-/arr-union-3.1.0.tgz + get-value: https://registry.npmmirror.com/get-value/-/get-value-2.0.6.tgz + is-extendable: https://registry.npmmirror.com/is-extendable/-/is-extendable-0.1.1.tgz + set-value: https://registry.npmmirror.com/set-value/-/set-value-2.0.1.tgz + + universalify@https://registry.npmmirror.com/universalify/-/universalify-2.0.0.tgz: {} + + unplugin-auto-import@https://registry.npmmirror.com/unplugin-auto-import/-/unplugin-auto-import-0.11.4.tgz(@vueuse/core@https://registry.npmmirror.com/@vueuse/core/-/core-9.5.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz))(rollup@2.79.1): + dependencies: + '@antfu/utils': https://registry.npmmirror.com/@antfu/utils/-/utils-0.6.3.tgz + '@rollup/pluginutils': https://registry.npmmirror.com/@rollup/pluginutils/-/pluginutils-5.0.2.tgz(rollup@2.79.1) + local-pkg: https://registry.npmmirror.com/local-pkg/-/local-pkg-0.4.3.tgz + magic-string: https://registry.npmmirror.com/magic-string/-/magic-string-0.26.7.tgz + unimport: https://registry.npmmirror.com/unimport/-/unimport-0.7.1.tgz(rollup@2.79.1) + unplugin: https://registry.npmmirror.com/unplugin/-/unplugin-0.10.2.tgz + optionalDependencies: + '@vueuse/core': https://registry.npmmirror.com/@vueuse/core/-/core-9.5.0.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + transitivePeerDependencies: + - rollup + + unplugin@https://registry.npmmirror.com/unplugin/-/unplugin-0.10.2.tgz: + dependencies: + acorn: https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz + chokidar: https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz + webpack-sources: https://registry.npmmirror.com/webpack-sources/-/webpack-sources-3.2.3.tgz + webpack-virtual-modules: https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.4.6.tgz + + unplugin@https://registry.npmmirror.com/unplugin/-/unplugin-1.3.1.tgz: + dependencies: + acorn: https://registry.npmmirror.com/acorn/-/acorn-8.8.2.tgz + chokidar: https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz + webpack-sources: https://registry.npmmirror.com/webpack-sources/-/webpack-sources-3.2.3.tgz + webpack-virtual-modules: https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.5.0.tgz + + unset-value@https://registry.npmmirror.com/unset-value/-/unset-value-1.0.0.tgz: + dependencies: + has-value: https://registry.npmmirror.com/has-value/-/has-value-0.3.1.tgz + isobject: https://registry.npmmirror.com/isobject/-/isobject-3.0.1.tgz + + urix@https://registry.npmmirror.com/urix/-/urix-0.1.0.tgz: {} + + use@https://registry.npmmirror.com/use/-/use-3.1.1.tgz: {} + + util-deprecate@https://registry.npmmirror.com/util-deprecate/-/util-deprecate-1.0.2.tgz: {} + + vary@https://registry.npmmirror.com/vary/-/vary-1.1.2.tgz: {} + + vite-plugin-compression@https://registry.npmmirror.com/vite-plugin-compression/-/vite-plugin-compression-0.5.1.tgz(vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz)): + dependencies: + chalk: https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz + debug: https://registry.npmmirror.com/debug/-/debug-4.3.4.tgz + fs-extra: https://registry.npmmirror.com/fs-extra/-/fs-extra-10.1.0.tgz + vite: https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz) + transitivePeerDependencies: + - supports-color + + vite-plugin-svg-icons@https://registry.npmmirror.com/vite-plugin-svg-icons/-/vite-plugin-svg-icons-2.0.1.tgz(vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz)): + dependencies: + '@types/svgo': https://registry.npmmirror.com/@types/svgo/-/svgo-2.6.4.tgz + cors: https://registry.npmmirror.com/cors/-/cors-2.8.5.tgz + debug: https://registry.npmmirror.com/debug/-/debug-4.3.4.tgz + etag: https://registry.npmmirror.com/etag/-/etag-1.8.1.tgz + fs-extra: https://registry.npmmirror.com/fs-extra/-/fs-extra-10.1.0.tgz + pathe: https://registry.npmmirror.com/pathe/-/pathe-0.2.0.tgz + svg-baker: https://registry.npmmirror.com/svg-baker/-/svg-baker-1.7.0.tgz + svgo: https://registry.npmmirror.com/svgo/-/svgo-2.8.0.tgz + vite: https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz) + transitivePeerDependencies: + - supports-color + + vite-plugin-vue-setup-extend@https://registry.npmmirror.com/vite-plugin-vue-setup-extend/-/vite-plugin-vue-setup-extend-0.4.0.tgz(vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz)): + dependencies: + '@vue/compiler-sfc': https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.45.tgz + magic-string: https://registry.npmmirror.com/magic-string/-/magic-string-0.25.9.tgz + vite: https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz) + + vite@https://registry.npmmirror.com/vite/-/vite-3.2.7.tgz(@types/node@20.2.3)(sass@https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz): + dependencies: + esbuild: https://registry.npmmirror.com/esbuild/-/esbuild-0.15.18.tgz + postcss: https://registry.npmmirror.com/postcss/-/postcss-8.4.23.tgz + resolve: https://registry.npmmirror.com/resolve/-/resolve-1.22.2.tgz + rollup: https://registry.npmmirror.com/rollup/-/rollup-2.79.1.tgz + optionalDependencies: + '@types/node': 20.2.3 + fsevents: 2.3.3 + sass: https://registry.npmmirror.com/sass/-/sass-1.56.1.tgz + + vue-cropper@https://registry.npmmirror.com/vue-cropper/-/vue-cropper-1.0.3.tgz: {} + + vue-demi@0.14.5(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz): + dependencies: + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + + vue-demi@https://registry.npmmirror.com/vue-demi/-/vue-demi-0.12.5.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz): + dependencies: + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + + vue-demi@https://registry.npmmirror.com/vue-demi/-/vue-demi-0.14.5.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz): + dependencies: + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + + vue-router@https://registry.npmmirror.com/vue-router/-/vue-router-4.1.4.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz): + dependencies: + '@vue/devtools-api': https://registry.npmmirror.com/@vue/devtools-api/-/devtools-api-6.5.0.tgz + vue: https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz + + vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz: + dependencies: + '@vue/compiler-dom': https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.2.45.tgz + '@vue/compiler-sfc': https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.2.45.tgz + '@vue/runtime-dom': https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.2.45.tgz + '@vue/server-renderer': https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.2.45.tgz(vue@https://registry.npmmirror.com/vue/-/vue-3.2.45.tgz) + '@vue/shared': https://registry.npmmirror.com/@vue/shared/-/shared-3.2.45.tgz + + webpack-sources@https://registry.npmmirror.com/webpack-sources/-/webpack-sources-3.2.3.tgz: {} + + webpack-virtual-modules@https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.4.6.tgz: {} + + webpack-virtual-modules@https://registry.npmmirror.com/webpack-virtual-modules/-/webpack-virtual-modules-0.5.0.tgz: {} + + zrender@https://registry.npmmirror.com/zrender/-/zrender-5.4.0.tgz: + dependencies: + tslib: https://registry.npmmirror.com/tslib/-/tslib-2.3.0.tgz diff --git a/admin-ui/public/favicon.ico b/admin-ui/public/favicon.ico new file mode 100644 index 0000000..86d7bc6 Binary files /dev/null and b/admin-ui/public/favicon.ico differ diff --git a/admin-ui/public/logo.png b/admin-ui/public/logo.png new file mode 100644 index 0000000..bbea6dd Binary files /dev/null and b/admin-ui/public/logo.png differ diff --git a/admin-ui/src/App.vue b/admin-ui/src/App.vue new file mode 100644 index 0000000..31839f2 --- /dev/null +++ b/admin-ui/src/App.vue @@ -0,0 +1,15 @@ + + + diff --git a/admin-ui/src/api/demo/demo.js b/admin-ui/src/api/demo/demo.js new file mode 100644 index 0000000..04d4025 --- /dev/null +++ b/admin-ui/src/api/demo/demo.js @@ -0,0 +1,54 @@ +import request from '@/utils/request' + +// 查询测试单表列表 +export function listDemo(query) { + return request({ + url: '/demo/demo/list', + method: 'get', + params: query + }) +} + +// 自定义分页接口 +export function pageDemo(query) { + return request({ + url: '/demo/demo/page', + method: 'get', + params: query + }) +} + +// 查询测试单表详细 +export function getDemo(id) { + return request({ + url: '/demo/demo/' + id, + method: 'get' + }) +} + +// 新增测试单表 +export function addDemo(data) { + return request({ + url: '/demo/demo', + method: 'post', + data: data + }) +} + +// 修改测试单表 +export function updateDemo(data) { + return request({ + url: '/demo/demo', + method: 'put', + data: data + }) +} + +// 删除测试单表 +export function delDemo(id) { + return request({ + url: '/demo/demo/' + id, + method: 'delete' + }) +} + diff --git a/admin-ui/src/api/demo/tree.js b/admin-ui/src/api/demo/tree.js new file mode 100644 index 0000000..4c7ebc0 --- /dev/null +++ b/admin-ui/src/api/demo/tree.js @@ -0,0 +1,44 @@ +import request from '@/utils/request' + +// 查询测试树表列表 +export function listTree(query) { + return request({ + url: '/demo/tree/list', + method: 'get', + params: query + }) +} + +// 查询测试树表详细 +export function getTree(id) { + return request({ + url: '/demo/tree/' + id, + method: 'get' + }) +} + +// 新增测试树表 +export function addTree(data) { + return request({ + url: '/demo/tree', + method: 'post', + data: data + }) +} + +// 修改测试树表 +export function updateTree(data) { + return request({ + url: '/demo/tree', + method: 'put', + data: data + }) +} + +// 删除测试树表 +export function delTree(id) { + return request({ + url: '/demo/tree/' + id, + method: 'delete' + }) +} diff --git a/admin-ui/src/api/login.js b/admin-ui/src/api/login.js new file mode 100644 index 0000000..649f59c --- /dev/null +++ b/admin-ui/src/api/login.js @@ -0,0 +1,59 @@ +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 + }, + 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 + }) +} \ No newline at end of file diff --git a/admin-ui/src/api/menu.js b/admin-ui/src/api/menu.js new file mode 100644 index 0000000..faef101 --- /dev/null +++ b/admin-ui/src/api/menu.js @@ -0,0 +1,9 @@ +import request from '@/utils/request' + +// 获取路由 +export const getRouters = () => { + return request({ + url: '/getRouters', + method: 'get' + }) +} \ No newline at end of file diff --git a/admin-ui/src/api/monitor/cache.js b/admin-ui/src/api/monitor/cache.js new file mode 100644 index 0000000..45a9003 --- /dev/null +++ b/admin-ui/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(cacheName, cacheKey) { + return request({ + url: '/monitor/cache/clearCacheKey/' + cacheName + '/' + cacheKey, + method: 'delete' + }) +} + +// 清理全部缓存 +export function clearCacheAll() { + return request({ + url: '/monitor/cache/clearCacheAll', + method: 'delete' + }) +} diff --git a/admin-ui/src/api/monitor/logininfor.js b/admin-ui/src/api/monitor/logininfor.js new file mode 100644 index 0000000..4d112b7 --- /dev/null +++ b/admin-ui/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' + }) +} diff --git a/admin-ui/src/api/monitor/online.js b/admin-ui/src/api/monitor/online.js new file mode 100644 index 0000000..bd22137 --- /dev/null +++ b/admin-ui/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' + }) +} diff --git a/admin-ui/src/api/monitor/operlog.js b/admin-ui/src/api/monitor/operlog.js new file mode 100644 index 0000000..a04bca8 --- /dev/null +++ b/admin-ui/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' + }) +} diff --git a/admin-ui/src/api/system/config.js b/admin-ui/src/api/system/config.js new file mode 100644 index 0000000..9b93886 --- /dev/null +++ b/admin-ui/src/api/system/config.js @@ -0,0 +1,72 @@ +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 updateConfigByKey(key, value) { + return request({ + url: '/system/config/updateByKey', + method: 'put', + data: { + configKey: key, + configValue: value + } + }) +} + +// 删除参数配置 +export function delConfig(configId) { + return request({ + url: '/system/config/' + configId, + method: 'delete' + }) +} + +// 刷新参数缓存 +export function refreshCache() { + return request({ + url: '/system/config/refreshCache', + method: 'delete' + }) +} diff --git a/admin-ui/src/api/system/dept.js b/admin-ui/src/api/system/dept.js new file mode 100644 index 0000000..fc943cd --- /dev/null +++ b/admin-ui/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' + }) +} \ No newline at end of file diff --git a/admin-ui/src/api/system/dict/data.js b/admin-ui/src/api/system/dict/data.js new file mode 100644 index 0000000..6c9eb79 --- /dev/null +++ b/admin-ui/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' + }) +} diff --git a/admin-ui/src/api/system/dict/type.js b/admin-ui/src/api/system/dict/type.js new file mode 100644 index 0000000..a0254ba --- /dev/null +++ b/admin-ui/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' + }) +} diff --git a/admin-ui/src/api/system/links.js b/admin-ui/src/api/system/links.js new file mode 100644 index 0000000..0f14b5f --- /dev/null +++ b/admin-ui/src/api/system/links.js @@ -0,0 +1,12 @@ +import request from '@/utils/request' +const base = "/system/links/"; + +export const doAdd = (data)=>request.post(base,data); + +export const doUpdate=(data)=>request.put(base,data); + +export const doPage= (params)=>request.get(base+"page",{params}); + +export const doGet=(id)=>request.get(base+id); + +export const doDelete=(id)=>request.delete(base+id); \ No newline at end of file diff --git a/admin-ui/src/api/system/menu.js b/admin-ui/src/api/system/menu.js new file mode 100644 index 0000000..f6415c6 --- /dev/null +++ b/admin-ui/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' + }) +} \ No newline at end of file diff --git a/admin-ui/src/api/system/notice.js b/admin-ui/src/api/system/notice.js new file mode 100644 index 0000000..c274ea5 --- /dev/null +++ b/admin-ui/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' + }) +} \ No newline at end of file diff --git a/admin-ui/src/api/system/oss.js b/admin-ui/src/api/system/oss.js new file mode 100644 index 0000000..7d80026 --- /dev/null +++ b/admin-ui/src/api/system/oss.js @@ -0,0 +1,27 @@ +import request from '@/utils/request' + +// 查询OSS对象存储列表 +export function listOss(query) { + return request({ + url: '/system/oss/list', + method: 'get', + params: query + }) +} + +// 查询OSS对象基于id串 +export function listByIds(ossId) { + return request({ + url: '/system/oss/listByIds/' + ossId, + method: 'get' + }) +} + +// 删除OSS对象存储 +export function delOss(ossId) { + return request({ + url: '/system/oss/' + ossId, + method: 'delete' + }) +} + diff --git a/admin-ui/src/api/system/ossConfig.js b/admin-ui/src/api/system/ossConfig.js new file mode 100644 index 0000000..f290762 --- /dev/null +++ b/admin-ui/src/api/system/ossConfig.js @@ -0,0 +1,58 @@ +import request from '@/utils/request' + +// 查询对象存储配置列表 +export function listOssConfig(query) { + return request({ + url: '/system/oss/config/list', + method: 'get', + params: query + }) +} + +// 查询对象存储配置详细 +export function getOssConfig(ossConfigId) { + return request({ + url: '/system/oss/config/' + ossConfigId, + method: 'get' + }) +} + +// 新增对象存储配置 +export function addOssConfig(data) { + return request({ + url: '/system/oss/config', + method: 'post', + data: data + }) +} + +// 修改对象存储配置 +export function updateOssConfig(data) { + return request({ + url: '/system/oss/config', + method: 'put', + data: data + }) +} + +// 删除对象存储配置 +export function delOssConfig(ossConfigId) { + return request({ + url: '/system/oss/config/' + ossConfigId, + method: 'delete' + }) +} + +// 对象存储状态修改 +export function changeOssConfigStatus(ossConfigId, status, configKey) { + const data = { + ossConfigId, + status, + configKey + } + return request({ + url: '/system/oss/config/changeStatus', + method: 'put', + data: data + }) +} diff --git a/admin-ui/src/api/system/post.js b/admin-ui/src/api/system/post.js new file mode 100644 index 0000000..1a8e9ca --- /dev/null +++ b/admin-ui/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' + }) +} diff --git a/admin-ui/src/api/system/role.js b/admin-ui/src/api/system/role.js new file mode 100644 index 0000000..f13e6f4 --- /dev/null +++ b/admin-ui/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' + }) +} diff --git a/admin-ui/src/api/system/user.js b/admin-ui/src/api/system/user.js new file mode 100644 index 0000000..5a25294 --- /dev/null +++ b/admin-ui/src/api/system/user.js @@ -0,0 +1,160 @@ +import request from '@/utils/request' +import { parseStrEmpty } from "@/utils/ruoyi"; + +// 查询用户列表 +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 unbindUser(userId) { + return request({ + url: '/system/user/unbind-' + userId, + method: 'put' + }) +} + +// 删除用户 +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', + params: data + }) +} + +// 用户头像上传 +export function uploadAvatar(data) { + return request({ + url: '/system/user/profile/avatar', + method: 'post', + 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' + }) +} + + +export function searchUsers(query) { + return request({ + url: '/system/user/search', + method: 'get', + params: query + }) +} + + +export function searchUser(id) { + return request({ + url: '/system/user/search/' + id, + method: 'get' + }) +} diff --git a/admin-ui/src/api/tool/gen.js b/admin-ui/src/api/tool/gen.js new file mode 100644 index 0000000..441791c --- /dev/null +++ b/admin-ui/src/api/tool/gen.js @@ -0,0 +1,85 @@ +import request from '@/utils/request' + +// 查询生成表数据 +export function listTable(query) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen/list', + method: 'get', + params: query + }) +} +// 查询db数据库列表 +export function listDbTable(query) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen/db/list', + method: 'get', + params: query + }) +} + +// 查询表详细信息 +export function getGenTable(tableId) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen/' + tableId, + method: 'get' + }) +} + +// 修改代码生成信息 +export function updateGenTable(data) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen', + method: 'put', + data: data + }) +} + +// 导入表 +export function importTable(data) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen/importTable', + method: 'post', + params: data + }) +} + +// 预览生成代码 +export function previewTable(tableId) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen/preview/' + tableId, + method: 'get' + }) +} + +// 删除表数据 +export function delTable(tableId) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen/' + tableId, + method: 'delete' + }) +} + +// 生成代码(自定义路径) +export function genCode(tableName) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen/genCode/' + tableName, + method: 'get' + }) +} + +// 同步数据库 +export function synchDb(tableName) { + return request({ + headers: { 'datasource': localStorage.getItem("dataName") }, + url: '/tool/gen/synchDb/' + tableName, + method: 'get' + }) +} diff --git a/admin-ui/src/api/upload.js b/admin-ui/src/api/upload.js new file mode 100644 index 0000000..0823381 --- /dev/null +++ b/admin-ui/src/api/upload.js @@ -0,0 +1,11 @@ +import request from '@/utils/request' + +/** + * 上传单个文件 + * @param {FormData} formData 文件项file + * @param {Funmction} onUploadProgress 进度处理函数 + * @param {Boolean} showLoading 是否打开loading,true + * @param {Number} timeout 上传超时时间,60000 + * @returns + */ +export const upload = (url,formData, onUploadProgress,showLoading=true,timeout=600000)=> request.post(url,formData,{onUploadProgress,timeout,showLoading}); \ No newline at end of file diff --git a/admin-ui/src/assets/401_images/401.gif b/admin-ui/src/assets/401_images/401.gif new file mode 100644 index 0000000..cd6e0d9 Binary files /dev/null and b/admin-ui/src/assets/401_images/401.gif differ diff --git a/admin-ui/src/assets/404_images/404.png b/admin-ui/src/assets/404_images/404.png new file mode 100644 index 0000000..3d8e230 Binary files /dev/null and b/admin-ui/src/assets/404_images/404.png differ diff --git a/admin-ui/src/assets/404_images/404_cloud.png b/admin-ui/src/assets/404_images/404_cloud.png new file mode 100644 index 0000000..c6281d0 Binary files /dev/null and b/admin-ui/src/assets/404_images/404_cloud.png differ diff --git a/admin-ui/src/assets/css/login.scss b/admin-ui/src/assets/css/login.scss new file mode 100644 index 0000000..e4b178f --- /dev/null +++ b/admin-ui/src/assets/css/login.scss @@ -0,0 +1,212 @@ +html, +body { + padding: 0; + margin: 0; +} + +.w-login-content { + --size: 16px; + --bg: #606060; + --primary-color: var(--el-color-primary); + --left-img: url(../images/login.png); + + + background-color: var(--bg); + width: 100%; + height: 100%; + font-size: var(--size); + display: flex; + justify-content: center; + align-items: center; + overflow: hidden; + + &>.w-login-outer { + position: relative; + z-index: 2; + background-color: #fff; + width: calc(900 / 16 * var(--size)); + height: calc(500 / 16 * var(--size)); + display: grid; + gap: 0; + grid-template-columns: repeat(2, 1fr); + border-radius: .2em; + overflow: hidden; + box-shadow: 0 0 1em #0003; + + &> :first-child { + background-image: var(--left-img), linear-gradient(to bottom,var(--el-color-primary-light-9) 15%, var(--el-color-primary-light-8) 50%, var(--el-color-primary-light-3)); + background-size: 70% auto, 100% 100%; + background-position: center center; + background-repeat: no-repeat; + position: relative; + box-shadow: -.3em 0 .6em #0001 inset; + overflow: hidden; + + &::before { + position: absolute; + background-color: #FFF; + right: -2.5em; + top: calc(50% - 2em); + box-shadow: -.3em .3em .6em #0001; + transform: scaleX(.8) rotate(45deg); + + width: 4em; + height: 4em; + content: ''; + } + + } + + .w-login-form { + background-color: #FFF; + display: flex; + justify-content: center; + align-items: center; + flex-direction: column; + position: relative; + padding-bottom: 1.5em; + + & * { + box-sizing: border-box; + margin: 0; + padding: 0; + border: none; + outline: none; + font-size: var(--size); + line-height: 1; + transition: all .5s; + } + + &>*:not(:first-child) { + width: 70%; + margin-top: 1.2em; + } + + &> :nth-child(1) { + width: 65%; + font-size: 1.2em; + letter-spacing: .1em; + font-weight: bold; + color: #333; + line-height: 1.5; + } + + & input:not([type="checkbox"]) { + background-color: #f3f3f3; + box-shadow: -.2em -.2em 2em #0001 inset; + outline: none; + border: none; + display: block; + width: 100%; + height: 2.5em; + border-radius: 0.3em; + padding: 0 1em; + } + + & input:not([type="checkbox"])::placeholder { + color: #8d8d8d; + } + + &>.verify { + display: grid; + gap: 1em; + grid-template-columns: repeat(2, 1fr); + + & img { + display: block; + height: 2.5em; + cursor: pointer; + } + } + + & .btn { + background-color: var(--primary-color); + text-align: center; + color: #fff; + font-size: 1.2em; + font-weight: bold; + line-height: 2; + border-radius: 0.2em; + + &:hover { + filter: brightness(0.9); + } + } + + &>.h2 { + margin-top: 0.6em; + display: flex; + justify-content: space-between; + align-items: center; + + & label:has(input[type="checkbox"]) { + margin-top: .3em; + font-size: .9em; + --color: #aaa; + color: var(--color); + display: flex; + justify-content: flex-start; + align-items: center; + cursor: pointer; + font-weight: normal; + + &::before { + content: ""; + background-color: var(--color); + border: .13em solid var(--color); + box-sizing: border-box; + padding: .17em; + background-clip: content-box; + height: 1em; + width: 1em; + margin-right: .3em; + border-radius: 2em; + } + + &>input[type="checkbox"] { + display: none; + } + } + + & label:has(input[type="checkbox"]:checked) { + --color: var(--primary-color); + } + + & label:hover { + filter: brightness(0.8); + } + + & a { + color: var(--primary-color); + text-decoration: none; + + &:hover { + filter: brightness(0.7); + } + } + } + + & .copy { + position: absolute; + color: #818181; + bottom: 1em; + left: 0; + font-size: 0.75em; + width: 100%; + text-align: center; + } + } + } +} + +@media screen and (max-width:900px) { + .w-login-content>.w-login-outer { + width: 100%; + height: 100%; + grid-template-columns: 1fr; + + &>:first-child { + display: none; + } + } +} \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/404.svg b/admin-ui/src/assets/icons/svg/404.svg new file mode 100644 index 0000000..6df5019 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/404.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/bug.svg b/admin-ui/src/assets/icons/svg/bug.svg new file mode 100644 index 0000000..05a150d --- /dev/null +++ b/admin-ui/src/assets/icons/svg/bug.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/build.svg b/admin-ui/src/assets/icons/svg/build.svg new file mode 100644 index 0000000..97c4688 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/build.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/button.svg b/admin-ui/src/assets/icons/svg/button.svg new file mode 100644 index 0000000..904fddc --- /dev/null +++ b/admin-ui/src/assets/icons/svg/button.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/cascader.svg b/admin-ui/src/assets/icons/svg/cascader.svg new file mode 100644 index 0000000..e256024 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/cascader.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/chart.svg b/admin-ui/src/assets/icons/svg/chart.svg new file mode 100644 index 0000000..27728fb --- /dev/null +++ b/admin-ui/src/assets/icons/svg/chart.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/checkbox.svg b/admin-ui/src/assets/icons/svg/checkbox.svg new file mode 100644 index 0000000..013fd3a --- /dev/null +++ b/admin-ui/src/assets/icons/svg/checkbox.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/clipboard.svg b/admin-ui/src/assets/icons/svg/clipboard.svg new file mode 100644 index 0000000..90923ff --- /dev/null +++ b/admin-ui/src/assets/icons/svg/clipboard.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/code.svg b/admin-ui/src/assets/icons/svg/code.svg new file mode 100644 index 0000000..5f9c5ab --- /dev/null +++ b/admin-ui/src/assets/icons/svg/code.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/color.svg b/admin-ui/src/assets/icons/svg/color.svg new file mode 100644 index 0000000..44a81aa --- /dev/null +++ b/admin-ui/src/assets/icons/svg/color.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/component.svg b/admin-ui/src/assets/icons/svg/component.svg new file mode 100644 index 0000000..29c3458 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/component.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/dashboard.svg b/admin-ui/src/assets/icons/svg/dashboard.svg new file mode 100644 index 0000000..5317d37 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/dashboard.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/date-range.svg b/admin-ui/src/assets/icons/svg/date-range.svg new file mode 100644 index 0000000..fda571e --- /dev/null +++ b/admin-ui/src/assets/icons/svg/date-range.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/date.svg b/admin-ui/src/assets/icons/svg/date.svg new file mode 100644 index 0000000..52dc73e --- /dev/null +++ b/admin-ui/src/assets/icons/svg/date.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/dict.svg b/admin-ui/src/assets/icons/svg/dict.svg new file mode 100644 index 0000000..4849377 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/dict.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/documentation.svg b/admin-ui/src/assets/icons/svg/documentation.svg new file mode 100644 index 0000000..7043122 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/documentation.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/download.svg b/admin-ui/src/assets/icons/svg/download.svg new file mode 100644 index 0000000..c896951 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/download.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/drag.svg b/admin-ui/src/assets/icons/svg/drag.svg new file mode 100644 index 0000000..4185d3c --- /dev/null +++ b/admin-ui/src/assets/icons/svg/drag.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/druid.svg b/admin-ui/src/assets/icons/svg/druid.svg new file mode 100644 index 0000000..a2b4b4e --- /dev/null +++ b/admin-ui/src/assets/icons/svg/druid.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/edit.svg b/admin-ui/src/assets/icons/svg/edit.svg new file mode 100644 index 0000000..d26101f --- /dev/null +++ b/admin-ui/src/assets/icons/svg/edit.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/education.svg b/admin-ui/src/assets/icons/svg/education.svg new file mode 100644 index 0000000..7bfb01d --- /dev/null +++ b/admin-ui/src/assets/icons/svg/education.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/email.svg b/admin-ui/src/assets/icons/svg/email.svg new file mode 100644 index 0000000..74d25e2 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/email.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/example.svg b/admin-ui/src/assets/icons/svg/example.svg new file mode 100644 index 0000000..46f42b5 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/example.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/excel.svg b/admin-ui/src/assets/icons/svg/excel.svg new file mode 100644 index 0000000..74d97b8 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/excel.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/exit-fullscreen.svg b/admin-ui/src/assets/icons/svg/exit-fullscreen.svg new file mode 100644 index 0000000..485c128 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/exit-fullscreen.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/eye-open.svg b/admin-ui/src/assets/icons/svg/eye-open.svg new file mode 100644 index 0000000..88dcc98 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/eye-open.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/eye.svg b/admin-ui/src/assets/icons/svg/eye.svg new file mode 100644 index 0000000..16ed2d8 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/eye.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/form.svg b/admin-ui/src/assets/icons/svg/form.svg new file mode 100644 index 0000000..dcbaa18 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/form.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/fullscreen.svg b/admin-ui/src/assets/icons/svg/fullscreen.svg new file mode 100644 index 0000000..0e86b6f --- /dev/null +++ b/admin-ui/src/assets/icons/svg/fullscreen.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/github.svg b/admin-ui/src/assets/icons/svg/github.svg new file mode 100644 index 0000000..db0a0d4 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/github.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/guide.svg b/admin-ui/src/assets/icons/svg/guide.svg new file mode 100644 index 0000000..b271001 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/guide.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/icon.svg b/admin-ui/src/assets/icons/svg/icon.svg new file mode 100644 index 0000000..82be8ee --- /dev/null +++ b/admin-ui/src/assets/icons/svg/icon.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/input.svg b/admin-ui/src/assets/icons/svg/input.svg new file mode 100644 index 0000000..ab91381 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/input.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/international.svg b/admin-ui/src/assets/icons/svg/international.svg new file mode 100644 index 0000000..e9b56ee --- /dev/null +++ b/admin-ui/src/assets/icons/svg/international.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/job.svg b/admin-ui/src/assets/icons/svg/job.svg new file mode 100644 index 0000000..2a93a25 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/job.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/language.svg b/admin-ui/src/assets/icons/svg/language.svg new file mode 100644 index 0000000..0082b57 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/language.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/link.svg b/admin-ui/src/assets/icons/svg/link.svg new file mode 100644 index 0000000..48197ba --- /dev/null +++ b/admin-ui/src/assets/icons/svg/link.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/list.svg b/admin-ui/src/assets/icons/svg/list.svg new file mode 100644 index 0000000..20259ed --- /dev/null +++ b/admin-ui/src/assets/icons/svg/list.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/lock.svg b/admin-ui/src/assets/icons/svg/lock.svg new file mode 100644 index 0000000..74fee54 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/lock.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/log.svg b/admin-ui/src/assets/icons/svg/log.svg new file mode 100644 index 0000000..d879d33 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/log.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/logininfor.svg b/admin-ui/src/assets/icons/svg/logininfor.svg new file mode 100644 index 0000000..267f844 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/logininfor.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/message.svg b/admin-ui/src/assets/icons/svg/message.svg new file mode 100644 index 0000000..14ca817 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/message.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/money.svg b/admin-ui/src/assets/icons/svg/money.svg new file mode 100644 index 0000000..c1580de --- /dev/null +++ b/admin-ui/src/assets/icons/svg/money.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/monitor.svg b/admin-ui/src/assets/icons/svg/monitor.svg new file mode 100644 index 0000000..bc308cb --- /dev/null +++ b/admin-ui/src/assets/icons/svg/monitor.svg @@ -0,0 +1,2 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/nested.svg b/admin-ui/src/assets/icons/svg/nested.svg new file mode 100644 index 0000000..06713a8 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/nested.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/number.svg b/admin-ui/src/assets/icons/svg/number.svg new file mode 100644 index 0000000..ad5ce9a --- /dev/null +++ b/admin-ui/src/assets/icons/svg/number.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/online.svg b/admin-ui/src/assets/icons/svg/online.svg new file mode 100644 index 0000000..330a202 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/online.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/password.svg b/admin-ui/src/assets/icons/svg/password.svg new file mode 100644 index 0000000..6c64def --- /dev/null +++ b/admin-ui/src/assets/icons/svg/password.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/pdf.svg b/admin-ui/src/assets/icons/svg/pdf.svg new file mode 100644 index 0000000..957aa0c --- /dev/null +++ b/admin-ui/src/assets/icons/svg/pdf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/people.svg b/admin-ui/src/assets/icons/svg/people.svg new file mode 100644 index 0000000..2bd54ae --- /dev/null +++ b/admin-ui/src/assets/icons/svg/people.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/peoples.svg b/admin-ui/src/assets/icons/svg/peoples.svg new file mode 100644 index 0000000..aab852e --- /dev/null +++ b/admin-ui/src/assets/icons/svg/peoples.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/phone.svg b/admin-ui/src/assets/icons/svg/phone.svg new file mode 100644 index 0000000..ab8e8c4 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/phone.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/post.svg b/admin-ui/src/assets/icons/svg/post.svg new file mode 100644 index 0000000..2922c61 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/post.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/qq.svg b/admin-ui/src/assets/icons/svg/qq.svg new file mode 100644 index 0000000..ee13d4e --- /dev/null +++ b/admin-ui/src/assets/icons/svg/qq.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/question.svg b/admin-ui/src/assets/icons/svg/question.svg new file mode 100644 index 0000000..cf75bd4 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/question.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/radio.svg b/admin-ui/src/assets/icons/svg/radio.svg new file mode 100644 index 0000000..0cde345 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/radio.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/rate.svg b/admin-ui/src/assets/icons/svg/rate.svg new file mode 100644 index 0000000..aa3b14d --- /dev/null +++ b/admin-ui/src/assets/icons/svg/rate.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/redis-list.svg b/admin-ui/src/assets/icons/svg/redis-list.svg new file mode 100644 index 0000000..98a15b2 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/redis-list.svg @@ -0,0 +1,2 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/redis.svg b/admin-ui/src/assets/icons/svg/redis.svg new file mode 100644 index 0000000..2f1d62d --- /dev/null +++ b/admin-ui/src/assets/icons/svg/redis.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/row.svg b/admin-ui/src/assets/icons/svg/row.svg new file mode 100644 index 0000000..0780992 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/row.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/search.svg b/admin-ui/src/assets/icons/svg/search.svg new file mode 100644 index 0000000..84233dd --- /dev/null +++ b/admin-ui/src/assets/icons/svg/search.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/select.svg b/admin-ui/src/assets/icons/svg/select.svg new file mode 100644 index 0000000..d628382 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/select.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/server.svg b/admin-ui/src/assets/icons/svg/server.svg new file mode 100644 index 0000000..eb287e3 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/server.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/shopping.svg b/admin-ui/src/assets/icons/svg/shopping.svg new file mode 100644 index 0000000..87513e7 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/shopping.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/size.svg b/admin-ui/src/assets/icons/svg/size.svg new file mode 100644 index 0000000..ddb25b8 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/size.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/skill.svg b/admin-ui/src/assets/icons/svg/skill.svg new file mode 100644 index 0000000..a3b7312 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/skill.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/slider.svg b/admin-ui/src/assets/icons/svg/slider.svg new file mode 100644 index 0000000..fbe4f39 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/slider.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/star.svg b/admin-ui/src/assets/icons/svg/star.svg new file mode 100644 index 0000000..6cf86e6 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/star.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/swagger.svg b/admin-ui/src/assets/icons/svg/swagger.svg new file mode 100644 index 0000000..05d4e7b --- /dev/null +++ b/admin-ui/src/assets/icons/svg/swagger.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/switch.svg b/admin-ui/src/assets/icons/svg/switch.svg new file mode 100644 index 0000000..0ba61e3 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/switch.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/system.svg b/admin-ui/src/assets/icons/svg/system.svg new file mode 100644 index 0000000..5992593 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/system.svg @@ -0,0 +1,2 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/tab.svg b/admin-ui/src/assets/icons/svg/tab.svg new file mode 100644 index 0000000..b4b48e4 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/tab.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/table.svg b/admin-ui/src/assets/icons/svg/table.svg new file mode 100644 index 0000000..0e3dc9d --- /dev/null +++ b/admin-ui/src/assets/icons/svg/table.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/textarea.svg b/admin-ui/src/assets/icons/svg/textarea.svg new file mode 100644 index 0000000..2709f29 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/textarea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/theme.svg b/admin-ui/src/assets/icons/svg/theme.svg new file mode 100644 index 0000000..5982a2f --- /dev/null +++ b/admin-ui/src/assets/icons/svg/theme.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/time-range.svg b/admin-ui/src/assets/icons/svg/time-range.svg new file mode 100644 index 0000000..13c1202 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/time-range.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/time.svg b/admin-ui/src/assets/icons/svg/time.svg new file mode 100644 index 0000000..b376e32 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/time.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/tool.svg b/admin-ui/src/assets/icons/svg/tool.svg new file mode 100644 index 0000000..48e0e35 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/tool.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/tree-table.svg b/admin-ui/src/assets/icons/svg/tree-table.svg new file mode 100644 index 0000000..8aafdb8 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/tree-table.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/tree.svg b/admin-ui/src/assets/icons/svg/tree.svg new file mode 100644 index 0000000..dd4b7dd --- /dev/null +++ b/admin-ui/src/assets/icons/svg/tree.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/upload.svg b/admin-ui/src/assets/icons/svg/upload.svg new file mode 100644 index 0000000..bae49c0 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/upload.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/user.svg b/admin-ui/src/assets/icons/svg/user.svg new file mode 100644 index 0000000..0ba0716 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/user.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/validCode.svg b/admin-ui/src/assets/icons/svg/validCode.svg new file mode 100644 index 0000000..cfb1021 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/validCode.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/wechat.svg b/admin-ui/src/assets/icons/svg/wechat.svg new file mode 100644 index 0000000..c586e55 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/wechat.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/icons/svg/zip.svg b/admin-ui/src/assets/icons/svg/zip.svg new file mode 100644 index 0000000..f806fc4 --- /dev/null +++ b/admin-ui/src/assets/icons/svg/zip.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/admin-ui/src/assets/images/avatar.png b/admin-ui/src/assets/images/avatar.png new file mode 100644 index 0000000..194a3f5 Binary files /dev/null and b/admin-ui/src/assets/images/avatar.png differ diff --git a/admin-ui/src/assets/images/dark.svg b/admin-ui/src/assets/images/dark.svg new file mode 100644 index 0000000..f646bd7 --- /dev/null +++ b/admin-ui/src/assets/images/dark.svg @@ -0,0 +1,39 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/admin-ui/src/assets/images/light.svg b/admin-ui/src/assets/images/light.svg new file mode 100644 index 0000000..ab7cc08 --- /dev/null +++ b/admin-ui/src/assets/images/light.svg @@ -0,0 +1,39 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/admin-ui/src/assets/images/login-background.jpg b/admin-ui/src/assets/images/login-background.jpg new file mode 100644 index 0000000..fa6408b Binary files /dev/null and b/admin-ui/src/assets/images/login-background.jpg differ diff --git a/admin-ui/src/assets/images/login.png b/admin-ui/src/assets/images/login.png new file mode 100644 index 0000000..2e35f16 Binary files /dev/null and b/admin-ui/src/assets/images/login.png differ diff --git a/admin-ui/src/assets/images/profile.jpg b/admin-ui/src/assets/images/profile.jpg new file mode 100644 index 0000000..b3a940b Binary files /dev/null and b/admin-ui/src/assets/images/profile.jpg differ diff --git a/admin-ui/src/assets/styles/btn.scss b/admin-ui/src/assets/styles/btn.scss new file mode 100644 index 0000000..3590d8d --- /dev/null +++ b/admin-ui/src/assets/styles/btn.scss @@ -0,0 +1,99 @@ +@import './variables.module.scss'; + +@mixin colorBtn($color) { + background: $color; + + &:hover { + color: $color; + + &:before, + &:after { + background: $color; + } + } +} + +.blue-btn { + @include colorBtn($blue) +} + +.light-blue-btn { + @include colorBtn($light-blue) +} + +.red-btn { + @include colorBtn($red) +} + +.pink-btn { + @include colorBtn($pink) +} + +.green-btn { + @include colorBtn($green) +} + +.tiffany-btn { + @include colorBtn($tiffany) +} + +.yellow-btn { + @include colorBtn($yellow) +} + +.pan-btn { + font-size: 14px; + color: #fff; + padding: 14px 36px; + border-radius: 8px; + border: none; + outline: none; + transition: 600ms ease all; + position: relative; + display: inline-block; + + &:hover { + background: #fff; + + &:before, + &:after { + width: 100%; + transition: 600ms ease all; + } + } + + &:before, + &:after { + content: ''; + position: absolute; + top: 0; + right: 0; + height: 2px; + width: 0; + transition: 400ms ease all; + } + + &::after { + right: inherit; + top: inherit; + left: 0; + bottom: 0; + } +} + +.custom-button { + display: inline-block; + line-height: 1; + white-space: nowrap; + cursor: pointer; + background: #fff; + color: #fff; + -webkit-appearance: none; + text-align: center; + box-sizing: border-box; + outline: 0; + margin: 0; + padding: 10px 15px; + font-size: 14px; + border-radius: 4px; +} diff --git a/admin-ui/src/assets/styles/element-ui.scss b/admin-ui/src/assets/styles/element-ui.scss new file mode 100644 index 0000000..0f175f2 --- /dev/null +++ b/admin-ui/src/assets/styles/element-ui.scss @@ -0,0 +1,96 @@ +// cover some element-ui styles + +.el-breadcrumb__inner, +.el-breadcrumb__inner a { + font-weight: 400 !important; +} + +.el-upload { + input[type="file"] { + display: none !important; + } +} + +.el-upload__input { + display: none; +} + +.cell { + .el-tag { + margin-right: 0px; + } +} + +.small-padding { + .cell { + padding-left: 5px; + padding-right: 5px; + } +} + +.fixed-width { + .el-button--mini { + padding: 7px 10px; + width: 60px; + } +} + +.status-col { + .cell { + padding: 0 10px; + text-align: center; + + .el-tag { + margin-right: 0px; + } + } +} + +// to fixed https://github.com/ElemeFE/element/issues/2461 +.el-dialog { + transform: none; + left: 0; + position: relative; + margin: 0 auto; +} + +// refine element ui upload +.upload-container { + .el-upload { + width: 100%; + + .el-upload-dragger { + width: 100%; + height: 200px; + } + } +} + +// dropdown +.el-dropdown-menu { + a { + display: block + } +} + +// fix date-picker ui bug in filter-item +.el-range-editor.el-input__inner { + display: inline-flex !important; +} + +// to fix el-date-picker css style +.el-range-separator { + box-sizing: content-box; +} + +.el-menu--collapse + > div + > .el-submenu + > .el-submenu__title + .el-submenu__icon-arrow { + display: none; +} + +.el-dropdown .el-dropdown-link{ + color: var(--el-color-primary) !important; +} \ No newline at end of file diff --git a/admin-ui/src/assets/styles/index.scss b/admin-ui/src/assets/styles/index.scss new file mode 100644 index 0000000..33e2c93 --- /dev/null +++ b/admin-ui/src/assets/styles/index.scss @@ -0,0 +1,224 @@ +@import './variables.module.scss'; +@import './mixin.scss'; +@import './transition.scss'; +@import './element-ui.scss'; +@import './sidebar.scss'; +@import './btn.scss'; +@import './ruoyi.scss'; + +body { + height: 100%; + margin: 0; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + text-rendering: optimizeLegibility; + font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif; +} + +label { + font-weight: 700; +} + +html { + height: 100%; + box-sizing: border-box; +} + +#app { + height: 100%; +} + +*, +*:before, +*:after { + box-sizing: inherit; +} + +.no-padding { + padding: 0px !important; +} + +.padding-content { + padding: 4px 0; +} + +a:focus, +a:active { + outline: none; +} + +a, +a:focus, +a:hover { + cursor: pointer; + color: inherit; + text-decoration: none; +} + +div:focus { + outline: none; +} + +.fr { + float: right; +} + +.fl { + float: left; +} + +.pr-5 { + padding-right: 5px; +} + +.pl-5 { + padding-left: 5px; +} + +.block { + display: block; +} + +.pointer { + cursor: pointer; +} + +.inlineBlock { + display: block; +} + +.clearfix { + &:after { + visibility: hidden; + display: block; + font-size: 0; + content: " "; + clear: both; + height: 0; + } +} + +aside { + background: #eef1f6; + padding: 8px 24px; + margin-bottom: 20px; + border-radius: 2px; + display: block; + line-height: 32px; + font-size: 16px; + font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif; + color: #2c3e50; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + + a { + color: #337ab7; + cursor: pointer; + + &:hover { + color: rgb(32, 160, 255); + } + } +} + +//main-container全局样式 +.app-container { + padding: 20px; +} + +.components-container { + margin: 30px 50px; + position: relative; +} + +.pagination-container { + margin-top: 30px; +} + +.text-center { + text-align: center +} + +.sub-navbar { + height: 50px; + line-height: 50px; + position: relative; + width: 100%; + text-align: right; + padding-right: 20px; + transition: 600ms ease position; + background: linear-gradient(90deg, rgba(32, 182, 249, 1) 0%, rgba(32, 182, 249, 1) 0%, rgba(33, 120, 241, 1) 100%, rgba(33, 120, 241, 1) 100%); + + .subtitle { + font-size: 20px; + color: #fff; + } + + &.draft { + background: #d0d0d0; + } + + &.deleted { + background: #d0d0d0; + } +} + +.link-type, +.link-type:focus { + color: #337ab7; + cursor: pointer; + + &:hover { + color: rgb(32, 160, 255); + } +} + +.filter-container { + padding-bottom: 10px; + + .filter-item { + display: inline-block; + vertical-align: middle; + margin-bottom: 10px; + } +} + +//refine vue-multiselect plugin +.multiselect { + line-height: 16px; +} + +.multiselect--active { + z-index: 1000 !important; +} + + +.col-padding { + padding: 0 !important; +} + +fieldset { + border-radius: .3rem; + border: var(--el-border-color) 1px solid; +} + + +.w-lines { + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; +} +.w-flex { + display: flex; + justify-content: center; + align-items: center; + flex-direction: row; + position: relative; +} +.w-flex-column { + position: relative; + display: flex; + justify-content: center; + align-items: center; + flex-direction: column; +} \ No newline at end of file diff --git a/admin-ui/src/assets/styles/mixin.scss b/admin-ui/src/assets/styles/mixin.scss new file mode 100644 index 0000000..06fa061 --- /dev/null +++ b/admin-ui/src/assets/styles/mixin.scss @@ -0,0 +1,66 @@ +@mixin clearfix { + &:after { + content: ""; + display: table; + clear: both; + } +} + +@mixin scrollBar { + &::-webkit-scrollbar-track-piece { + background: #d3dce6; + } + + &::-webkit-scrollbar { + width: 6px; + } + + &::-webkit-scrollbar-thumb { + background: #99a9bf; + border-radius: 20px; + } +} + +@mixin relative { + position: relative; + width: 100%; + height: 100%; +} + +@mixin pct($pct) { + width: #{$pct}; + position: relative; + margin: 0 auto; +} + +@mixin triangle($width, $height, $color, $direction) { + $width: $width/2; + $color-border-style: $height solid $color; + $transparent-border-style: $width solid transparent; + height: 0; + width: 0; + + @if $direction==up { + border-bottom: $color-border-style; + border-left: $transparent-border-style; + border-right: $transparent-border-style; + } + + @else if $direction==right { + border-left: $color-border-style; + border-top: $transparent-border-style; + border-bottom: $transparent-border-style; + } + + @else if $direction==down { + border-top: $color-border-style; + border-left: $transparent-border-style; + border-right: $transparent-border-style; + } + + @else if $direction==left { + border-right: $color-border-style; + border-top: $transparent-border-style; + border-bottom: $transparent-border-style; + } +} diff --git a/admin-ui/src/assets/styles/ruoyi.scss b/admin-ui/src/assets/styles/ruoyi.scss new file mode 100644 index 0000000..88f3702 --- /dev/null +++ b/admin-ui/src/assets/styles/ruoyi.scss @@ -0,0 +1,277 @@ + /** + * 通用css样式布局处理 + * Copyright (c) 2019 ruoyi + */ + + /** 基础通用 **/ +.pt5 { + padding-top: 5px; +} +.pr5 { + padding-right: 5px; +} +.pb5 { + padding-bottom: 5px; +} +.mt5 { + margin-top: 5px; +} +.mr5 { + margin-right: 5px; +} +.mb5 { + margin-bottom: 5px; +} +.mb8 { + margin-bottom: 8px; +} +.ml5 { + margin-left: 5px; +} +.mt10 { + margin-top: 10px; +} +.mr10 { + margin-right: 10px; +} +.mb10 { + margin-bottom: 10px; +} +.ml10 { + margin-left: 10px; +} +.mt20 { + margin-top: 20px; +} +.mr20 { + margin-right: 20px; +} +.mb20 { + margin-bottom: 20px; +} +.ml20 { + margin-left: 20px; +} + +.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 { + font-family: inherit; + font-weight: 500; + line-height: 1.1; + color: inherit; +} + +.el-form .el-form-item__label { + font-weight: 700; +} +.el-dialog:not(.is-fullscreen) { + margin-top: 6vh !important; +} + +.el-dialog.scrollbar .el-dialog__body { + overflow: auto; + overflow-x: hidden; + max-height: 70vh; + padding: 10px 20px 0; +} + +.el-table { + .el-table__header-wrapper, .el-table__fixed-header-wrapper { + th { + word-break: break-word; + background-color: #f8f8f9 !important; + color: #515a6e; + height: 40px !important; + font-size: 13px; + } + } + .el-table__body-wrapper { + .el-button [class*="el-icon-"] + span { + margin-left: 1px; + } + } +} + +/** 表单布局 **/ +.form-header { + font-size:15px; + color:#6379bb; + border-bottom:1px solid #ddd; + margin:8px 10px 25px 10px; + padding-bottom:5px +} + +/** 表格布局 **/ +.pagination-container { + // position: relative; + height: 25px; + margin-bottom: 10px; + margin-top: 15px; + padding: 10px 20px !important; +} + +/* tree border */ +.tree-border { + margin-top: 5px; + border: 1px solid #e5e6e7; + background: #FFFFFF none; + border-radius:4px; + width: 100%; +} + +.pagination-container .el-pagination { + right: 0; + position: absolute; +} + +@media ( max-width : 768px) { + .pagination-container .el-pagination > .el-pagination__jump { + display: none !important; + } + .pagination-container .el-pagination > .el-pagination__sizes { + display: none !important; + } +} + +.el-table .fixed-width .el-button--small { + padding-left: 0; + padding-right: 0; + width: inherit; +} + +/** 表格更多操作下拉样式 */ +.el-table .el-dropdown-link { + cursor: pointer; + color: #409EFF; + margin-left: 10px; +} + +.el-table .el-dropdown, .el-icon-arrow-down { + font-size: 12px; +} + +.el-tree-node__content > .el-checkbox { + margin-right: 8px; +} + +.list-group-striped > .list-group-item { + border-left: 0; + border-right: 0; + border-radius: 0; + padding-left: 0; + padding-right: 0; +} + +.list-group { + padding-left: 0px; + list-style: none; +} + +.list-group-item { + border-bottom: 1px solid #e7eaec; + border-top: 1px solid #e7eaec; + margin-bottom: -1px; + padding: 11px 0px; + font-size: 13px; +} + +.pull-right { + float: right !important; +} + +.el-card__header { + padding: 14px 15px 7px !important; + min-height: 40px; +} + +.el-card__body { + padding: 15px 20px 20px 20px !important; +} + +.card-box { + padding-right: 15px; + padding-left: 15px; + margin-bottom: 10px; +} + +/* button color */ +.el-button--cyan.is-active, +.el-button--cyan:active { + background: #20B2AA; + border-color: #20B2AA; + color: #FFFFFF; +} + +.el-button--cyan:focus, +.el-button--cyan:hover { + background: #48D1CC; + border-color: #48D1CC; + color: #FFFFFF; +} + +.el-button--cyan { + background-color: #20B2AA; + border-color: #20B2AA; + color: #FFFFFF; +} + +/* text color */ +.text-navy { + color: #1ab394; +} + +.text-primary { + color: inherit; +} + +.text-success { + color: #1c84c6; +} + +.text-info { + color: #23c6c8; +} + +.text-warning { + color: #f8ac59; +} + +.text-danger { + color: #ed5565; +} + +.text-muted { + color: #888888; +} + +/* image */ +.img-circle { + border-radius: 50%; +} + +.img-lg { + width: 120px; + height: 120px; +} + +.avatar-upload-preview { + position: absolute; + top: 50%; + transform: translate(50%, -50%); + width: 200px; + height: 200px; + border-radius: 50%; + box-shadow: 0 0 4px #ccc; + overflow: hidden; +} + +/* 拖拽列样式 */ +.sortable-ghost{ + opacity: .8; + color: #fff!important; + background: #42b983!important; +} + +/* 表格右侧工具栏样式 */ +.top-right-btn { + margin-left: auto; +} diff --git a/admin-ui/src/assets/styles/sidebar.scss b/admin-ui/src/assets/styles/sidebar.scss new file mode 100644 index 0000000..0854934 --- /dev/null +++ b/admin-ui/src/assets/styles/sidebar.scss @@ -0,0 +1,238 @@ +#app { + + .main-container { + min-height: 100%; + transition: margin-left .28s; + margin-left: $base-sidebar-width; + position: relative; + } + + .sidebarHide { + margin-left: 0!important; + } + + .sidebar-container { + -webkit-transition: width .28s; + transition: width 0.28s; + width: $base-sidebar-width !important; + background-color: $base-menu-background; + height: 100%; + position: fixed; + font-size: 0px; + top: 0; + bottom: 0; + left: 0; + z-index: 1001; + overflow: hidden; + // -webkit-box-shadow: 2px 0 6px rgba(0,21,41,.35); + // box-shadow: 2px 0 6px rgba(0,21,41,.35); + + // reset element-ui css + .horizontal-collapse-transition { + transition: 0s width ease-in-out, 0s padding-left ease-in-out, 0s padding-right ease-in-out; + } + + .scrollbar-wrapper { + overflow-x: hidden !important; + } + + .el-scrollbar__bar.is-vertical { + right: 0px; + } + + .el-scrollbar { + height: 100%; + } + + &.has-logo { + .el-scrollbar { + height: calc(100% - 50px); + } + } + + .is-horizontal { + display: none; + } + + a { + display: inline-block; + width: 100%; + overflow: hidden; + } + + .svg-icon { + margin-right: 16px; + } + + .el-menu { + border: none; + height: 100%; + width: 100% !important; + } + + .el-menu-item, .menu-title { + overflow: hidden !important; + text-overflow: ellipsis !important; + white-space: nowrap !important; + } + + .el-menu-item .el-menu-tooltip__trigger { + display: inline-block !important; + } + + // menu hover + .sub-menu-title-noDropdown, + .el-sub-menu__title { + &:hover { + background-color: rgba(0, 0, 0, 0.06) !important; + } + } + + & .theme-dark .is-active > .el-sub-menu__title { + color: $base-menu-color-active !important; + } + + & .nest-menu .el-sub-menu>.el-sub-menu__title, + & .el-sub-menu .el-menu-item { + min-width: $base-sidebar-width !important; + + &:hover { + background-color: rgba(0, 0, 0, 0.06) !important; + } + } + + & .theme-dark .nest-menu .el-sub-menu>.el-sub-menu__title, + & .theme-dark .el-sub-menu .el-menu-item { + background-color: $base-sub-menu-background !important; + + &:hover { + background-color: $base-sub-menu-hover !important; + } + } + } + + .hideSidebar { + .sidebar-container { + width: 54px !important; + } + + .main-container { + margin-left: 54px; + } + + .sub-menu-title-noDropdown { + padding: 0 !important; + position: relative; + + .el-tooltip { + padding: 0 !important; + + .svg-icon { + margin-left: 20px; + } + } + } + + .el-sub-menu { + overflow: hidden; + + &>.el-sub-menu__title { + padding: 0 !important; + + .svg-icon { + margin-left: 20px; + } + + } + } + + .el-menu--collapse { + .el-sub-menu { + &>.el-sub-menu__title { + &>span { + height: 0; + width: 0; + overflow: hidden; + visibility: hidden; + display: inline-block; + } + &>i { + height: 0; + width: 0; + overflow: hidden; + visibility: hidden; + display: inline-block; + } + } + } + } + } + + .el-menu--collapse .el-menu .el-sub-menu { + min-width: $base-sidebar-width !important; + } + + // mobile responsive + .mobile { + .main-container { + margin-left: 0px; + } + + .sidebar-container { + transition: transform .28s; + width: $base-sidebar-width !important; + } + + &.hideSidebar { + .sidebar-container { + pointer-events: none; + transition-duration: 0.3s; + transform: translate3d(-$base-sidebar-width, 0, 0); + } + } + } + + .withoutAnimation { + + .main-container, + .sidebar-container { + transition: none; + } + } +} + +// when menu collapsed +.el-menu--vertical { + &>.el-menu { + .svg-icon { + margin-right: 16px; + } + } + + .nest-menu .el-sub-menu>.el-sub-menu__title, + .el-menu-item { + &:hover { + // you can use $sub-menuHover + background-color: rgba(0, 0, 0, 0.06) !important; + } + } + + // the scroll bar appears when the sub-menu is too long + >.el-menu--popup { + max-height: 100vh; + overflow-y: auto; + + &::-webkit-scrollbar-track-piece { + background: #d3dce6; + } + + &::-webkit-scrollbar { + width: 6px; + } + + &::-webkit-scrollbar-thumb { + background: #99a9bf; + border-radius: 20px; + } + } +} diff --git a/admin-ui/src/assets/styles/transition.scss b/admin-ui/src/assets/styles/transition.scss new file mode 100644 index 0000000..eb49895 --- /dev/null +++ b/admin-ui/src/assets/styles/transition.scss @@ -0,0 +1,53 @@ +// global transition css + +/* fade */ +.fade-enter-active, +.fade-leave-active { + transition: opacity 0.28s; +} + +.fade-enter, +.fade-leave-active { + opacity: 0; +} + +/* fade-transform */ +.fade-transform--move, +.fade-transform-leave-active, +.fade-transform-enter-active { + transition: all .5s; +} + +.fade-transform-leave-active { + position: absolute; +} + +.fade-transform-enter { + opacity: 0; + transform: translateX(-30px); +} + +.fade-transform-leave-to { + opacity: 0; + transform: translateX(30px); +} + +/* breadcrumb transition */ +.breadcrumb-enter-active, +.breadcrumb-leave-active { + transition: all .5s; +} + +.breadcrumb-enter, +.breadcrumb-leave-active { + opacity: 0; + transform: translateX(20px); +} + +.breadcrumb-move { + transition: all .5s; +} + +.breadcrumb-leave-active { + position: absolute; +} diff --git a/admin-ui/src/assets/styles/variables.module.scss b/admin-ui/src/assets/styles/variables.module.scss new file mode 100644 index 0000000..4f92c7b --- /dev/null +++ b/admin-ui/src/assets/styles/variables.module.scss @@ -0,0 +1,65 @@ +// base color +$blue: hsl(209, 63%, 29%); +$light-blue: hsl(209, 64%, 49%); +$red: #C03639; +$pink: #E65D6E; +$green: #30B08F; +$tiffany: #4AB7BD; +$yellow: #FEC171; +$panGreen: #30B08F; + +// 默认菜单主题风格 +$base-menu-color: #bfcbd9; +$base-menu-color-active: #f4f4f5; +$base-menu-background: hsl(210, 63%, 30%); +$base-logo-title-color: #ffffff; + +$base-menu-light-color: rgba(0, 0, 0, 0.7); +$base-menu-light-background: #ffffff; +$base-logo-light-title-color: #001529; + +$base-sub-menu-background: hsl(210, 63%, 25%); +$base-sub-menu-hover: hsl(210, 63%, 20%); + +// 自定义暗色菜单风格 +/** +$base-menu-color:hsla(0,0%,100%,.65); +$base-menu-color-active:#fff; +$base-menu-background:#001529; +$base-logo-title-color: #ffffff; + +$base-menu-light-color:rgba(0,0,0,.70); +$base-menu-light-background:#ffffff; +$base-logo-light-title-color: #001529; + +$base-sub-menu-background:#000c17; +$base-sub-menu-hover:#001528; +*/ + +$--color-primary: #1c4c7a; +$--color-success: #67C23A; +$--color-warning: #E6A23C; +$--color-danger: #F56C6C; +$--color-info: #909399; + +$base-sidebar-width: 200px; + +// the :export directive is the magic sauce for webpack +// https://www.bluematador.com/blog/how-to-share-variables-between-js-and-sass +:export { + menuColor: $base-menu-color; + menuLightColor: $base-menu-light-color; + menuColorActive: $base-menu-color-active; + menuBackground: $base-menu-background; + menuLightBackground: $base-menu-light-background; + subMenuBackground: $base-sub-menu-background; + subMenuHover: $base-sub-menu-hover; + sideBarWidth: $base-sidebar-width; + logoTitleColor: $base-logo-title-color; + logoLightTitleColor: $base-logo-light-title-color; + primaryColor: $--color-primary; + successColor: $--color-success; + dangerColor: $--color-danger; + infoColor: $--color-info; + warningColor: $--color-warning; +} diff --git a/admin-ui/src/auto/components/WCronInput.vue b/admin-ui/src/auto/components/WCronInput.vue new file mode 100644 index 0000000..f3dee7e --- /dev/null +++ b/admin-ui/src/auto/components/WCronInput.vue @@ -0,0 +1,59 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/WImageView.vue b/admin-ui/src/auto/components/WImageView.vue new file mode 100644 index 0000000..445f03f --- /dev/null +++ b/admin-ui/src/auto/components/WImageView.vue @@ -0,0 +1,32 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/WMove.vue b/admin-ui/src/auto/components/WMove.vue new file mode 100644 index 0000000..59be651 --- /dev/null +++ b/admin-ui/src/auto/components/WMove.vue @@ -0,0 +1,127 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/WPhone.vue b/admin-ui/src/auto/components/WPhone.vue new file mode 100644 index 0000000..36e4b7d --- /dev/null +++ b/admin-ui/src/auto/components/WPhone.vue @@ -0,0 +1,58 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/WSensitive.vue b/admin-ui/src/auto/components/WSensitive.vue new file mode 100644 index 0000000..e2356cb --- /dev/null +++ b/admin-ui/src/auto/components/WSensitive.vue @@ -0,0 +1,84 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/WTemplate.vue b/admin-ui/src/auto/components/WTemplate.vue new file mode 100644 index 0000000..b67dd7f --- /dev/null +++ b/admin-ui/src/auto/components/WTemplate.vue @@ -0,0 +1,10 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/WUpload.vue b/admin-ui/src/auto/components/WUpload.vue new file mode 100644 index 0000000..0aecb0f --- /dev/null +++ b/admin-ui/src/auto/components/WUpload.vue @@ -0,0 +1,138 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/WUser.vue b/admin-ui/src/auto/components/WUser.vue new file mode 100644 index 0000000..70b3aa3 --- /dev/null +++ b/admin-ui/src/auto/components/WUser.vue @@ -0,0 +1,204 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/WUserSelect.vue b/admin-ui/src/auto/components/WUserSelect.vue new file mode 100644 index 0000000..3605c37 --- /dev/null +++ b/admin-ui/src/auto/components/WUserSelect.vue @@ -0,0 +1,81 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/auto/components/vue3Cron.vue b/admin-ui/src/auto/components/vue3Cron.vue new file mode 100644 index 0000000..737e519 --- /dev/null +++ b/admin-ui/src/auto/components/vue3Cron.vue @@ -0,0 +1,720 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/auto/custom/READMD.md b/admin-ui/src/auto/custom/READMD.md new file mode 100644 index 0000000..732fbda --- /dev/null +++ b/admin-ui/src/auto/custom/READMD.md @@ -0,0 +1 @@ +# 自定义组件 \ No newline at end of file diff --git a/admin-ui/src/auto/index.js b/admin-ui/src/auto/index.js new file mode 100644 index 0000000..2ed279b --- /dev/null +++ b/admin-ui/src/auto/index.js @@ -0,0 +1,56 @@ + +/** + * 自定义全局组件的自动注册 + */ + +import { defineAsyncComponent,createVNode,render } from 'vue'; + +export default { + install(Vue) { + + //自动组件异步注册 + let files = import.meta.glob('./components/*.vue');//异步导入 + // const files = import.meta.globEager('./global/*.vue');//同步导入 + for(let fileName in files) { + let moduleName = fileName.replace(/^.*\/(\w+)\.vue$/,"$1"); + Vue.component(moduleName, defineAsyncComponent(files[fileName]));//注册异步组件 + console.debug("注册异步组件",moduleName) + // Vue.component(moduleName, files[fileName].default);//注册同步组件 + } + + //自动组件异步注册 + files = import.meta.glob('./custom/*.vue');//异步导入 + // const files = import.meta.globEager('./global/*.vue');//同步导入 + for(let fileName in files) { + let moduleName = fileName.replace(/^.*\/(\w+)\.vue$/,"$1"); + Vue.component(moduleName, defineAsyncComponent(files[fileName]));//注册异步组件 + console.debug("注册异步组件",moduleName) + // Vue.component(moduleName, files[fileName].default);//注册同步组件 + } + + //自动单例组件创建 + // files = import.meta.globEager('./singleton/*.vue');//同步导入 + // for(let fileName in files) { + // let moduleName = fileName.replace(/^.*\/(\w+)\.vue$/,"$1"); + // Vue.component("_"+moduleName, files[fileName].default); + // console.debug(Vue); + // let instance= createVNode("_"+moduleName); + // console.debug(instance); + + // render(instance, document.querySelector('body')); + // // window.instance=instance; + // // Vue.config.globalProperties['$'+moduleName]=instance; + + + // // Vue.component(moduleName, files[fileName].default); + // // console.debug(Vue); + // // const instance = createApp(files[fileName].default); + // // let div = document.createElement("div"); + // // div.setAttribute("data-name",moduleName); + // // document.body.appendChild(div); + // // let vm = instance.mount(div); + // // window.vm=vm; + // // Vue.config.globalProperties['$'+moduleName]=vm; + // } + } +} diff --git a/admin-ui/src/components/Breadcrumb/index.vue b/admin-ui/src/components/Breadcrumb/index.vue new file mode 100644 index 0000000..489cba1 --- /dev/null +++ b/admin-ui/src/components/Breadcrumb/index.vue @@ -0,0 +1,66 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/DictTag/index.vue b/admin-ui/src/components/DictTag/index.vue new file mode 100644 index 0000000..c03a1a6 --- /dev/null +++ b/admin-ui/src/components/DictTag/index.vue @@ -0,0 +1,49 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/Editor/index.vue b/admin-ui/src/components/Editor/index.vue new file mode 100644 index 0000000..bc8da7b --- /dev/null +++ b/admin-ui/src/components/Editor/index.vue @@ -0,0 +1,245 @@ + + + + + diff --git a/admin-ui/src/components/FileUpload/index.vue b/admin-ui/src/components/FileUpload/index.vue new file mode 100644 index 0000000..14f68e4 --- /dev/null +++ b/admin-ui/src/components/FileUpload/index.vue @@ -0,0 +1,222 @@ + + + + + diff --git a/admin-ui/src/components/Hamburger/index.vue b/admin-ui/src/components/Hamburger/index.vue new file mode 100644 index 0000000..18c201e --- /dev/null +++ b/admin-ui/src/components/Hamburger/index.vue @@ -0,0 +1,41 @@ + + + + + diff --git a/admin-ui/src/components/HeaderSearch/index.vue b/admin-ui/src/components/HeaderSearch/index.vue new file mode 100644 index 0000000..543559b --- /dev/null +++ b/admin-ui/src/components/HeaderSearch/index.vue @@ -0,0 +1,179 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/IconSelect/index.vue b/admin-ui/src/components/IconSelect/index.vue new file mode 100644 index 0000000..5b06806 --- /dev/null +++ b/admin-ui/src/components/IconSelect/index.vue @@ -0,0 +1,74 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/IconSelect/requireIcons.js b/admin-ui/src/components/IconSelect/requireIcons.js new file mode 100644 index 0000000..ac22fd7 --- /dev/null +++ b/admin-ui/src/components/IconSelect/requireIcons.js @@ -0,0 +1,8 @@ +let icons = [] +const modules = import.meta.glob('./../../assets/icons/svg/*.svg'); +for (const path in modules) { + const p = path.split('assets/icons/svg/')[1].split('.svg')[0]; + icons.push(p); +} + +export default icons \ No newline at end of file diff --git a/admin-ui/src/components/ImagePreview/index.vue b/admin-ui/src/components/ImagePreview/index.vue new file mode 100644 index 0000000..1dfe123 --- /dev/null +++ b/admin-ui/src/components/ImagePreview/index.vue @@ -0,0 +1,85 @@ + + + + + diff --git a/admin-ui/src/components/ImageUpload/index.vue b/admin-ui/src/components/ImageUpload/index.vue new file mode 100644 index 0000000..8cad89c --- /dev/null +++ b/admin-ui/src/components/ImageUpload/index.vue @@ -0,0 +1,223 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/Pagination/index.vue b/admin-ui/src/components/Pagination/index.vue new file mode 100644 index 0000000..179c9d4 --- /dev/null +++ b/admin-ui/src/components/Pagination/index.vue @@ -0,0 +1,103 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/ParentView/index.vue b/admin-ui/src/components/ParentView/index.vue new file mode 100644 index 0000000..7bf6148 --- /dev/null +++ b/admin-ui/src/components/ParentView/index.vue @@ -0,0 +1,3 @@ + diff --git a/admin-ui/src/components/RightToolbar/index.vue b/admin-ui/src/components/RightToolbar/index.vue new file mode 100644 index 0000000..becb12c --- /dev/null +++ b/admin-ui/src/components/RightToolbar/index.vue @@ -0,0 +1,105 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/RuoYi/Doc/index.vue b/admin-ui/src/components/RuoYi/Doc/index.vue new file mode 100644 index 0000000..3e69482 --- /dev/null +++ b/admin-ui/src/components/RuoYi/Doc/index.vue @@ -0,0 +1,13 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/components/RuoYi/Git/index.vue b/admin-ui/src/components/RuoYi/Git/index.vue new file mode 100644 index 0000000..c8d6fd5 --- /dev/null +++ b/admin-ui/src/components/RuoYi/Git/index.vue @@ -0,0 +1,13 @@ + + + diff --git a/admin-ui/src/components/Screenfull/index.vue b/admin-ui/src/components/Screenfull/index.vue new file mode 100644 index 0000000..7ad28ea --- /dev/null +++ b/admin-ui/src/components/Screenfull/index.vue @@ -0,0 +1,22 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/SizeSelect/index.vue b/admin-ui/src/components/SizeSelect/index.vue new file mode 100644 index 0000000..4c2e7e9 --- /dev/null +++ b/admin-ui/src/components/SizeSelect/index.vue @@ -0,0 +1,45 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/SvgIcon/index.vue b/admin-ui/src/components/SvgIcon/index.vue new file mode 100644 index 0000000..8c101f6 --- /dev/null +++ b/admin-ui/src/components/SvgIcon/index.vue @@ -0,0 +1,53 @@ + + + + + diff --git a/admin-ui/src/components/SvgIcon/svgicon.js b/admin-ui/src/components/SvgIcon/svgicon.js new file mode 100644 index 0000000..4431719 --- /dev/null +++ b/admin-ui/src/components/SvgIcon/svgicon.js @@ -0,0 +1,10 @@ +import * as components from '@element-plus/icons-vue' + +export default { + install: (app) => { + for (const key in components) { + const componentConfig = components[key]; + app.component(componentConfig.name, componentConfig); + } + }, +}; diff --git a/admin-ui/src/components/TopNav/index.vue b/admin-ui/src/components/TopNav/index.vue new file mode 100644 index 0000000..ac1d2e5 --- /dev/null +++ b/admin-ui/src/components/TopNav/index.vue @@ -0,0 +1,186 @@ + + + + + diff --git a/admin-ui/src/components/TreeSelect/index.vue b/admin-ui/src/components/TreeSelect/index.vue new file mode 100644 index 0000000..4ff0e76 --- /dev/null +++ b/admin-ui/src/components/TreeSelect/index.vue @@ -0,0 +1,156 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/components/bg/WBg1.vue b/admin-ui/src/components/bg/WBg1.vue new file mode 100644 index 0000000..1e72f44 --- /dev/null +++ b/admin-ui/src/components/bg/WBg1.vue @@ -0,0 +1,1669 @@ + + + diff --git a/admin-ui/src/components/iFrame/index.vue b/admin-ui/src/components/iFrame/index.vue new file mode 100644 index 0000000..091b1a2 --- /dev/null +++ b/admin-ui/src/components/iFrame/index.vue @@ -0,0 +1,31 @@ + + + diff --git a/admin-ui/src/layout/components/Navbar.vue b/admin-ui/src/layout/components/Navbar.vue new file mode 100644 index 0000000..028b99c --- /dev/null +++ b/admin-ui/src/layout/components/Navbar.vue @@ -0,0 +1,201 @@ + + + + + diff --git a/admin-ui/src/layout/components/Settings/index.vue b/admin-ui/src/layout/components/Settings/index.vue new file mode 100644 index 0000000..2cdf53a --- /dev/null +++ b/admin-ui/src/layout/components/Settings/index.vue @@ -0,0 +1,244 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/layout/components/Sidebar/Link.vue b/admin-ui/src/layout/components/Sidebar/Link.vue new file mode 100644 index 0000000..8011431 --- /dev/null +++ b/admin-ui/src/layout/components/Sidebar/Link.vue @@ -0,0 +1,40 @@ + + + diff --git a/admin-ui/src/layout/components/Sidebar/Logo.vue b/admin-ui/src/layout/components/Sidebar/Logo.vue new file mode 100644 index 0000000..f83544b --- /dev/null +++ b/admin-ui/src/layout/components/Sidebar/Logo.vue @@ -0,0 +1,82 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/layout/components/Sidebar/SidebarItem.vue b/admin-ui/src/layout/components/Sidebar/SidebarItem.vue new file mode 100644 index 0000000..c423fb1 --- /dev/null +++ b/admin-ui/src/layout/components/Sidebar/SidebarItem.vue @@ -0,0 +1,102 @@ + + + diff --git a/admin-ui/src/layout/components/Sidebar/index.vue b/admin-ui/src/layout/components/Sidebar/index.vue new file mode 100644 index 0000000..200d5bc --- /dev/null +++ b/admin-ui/src/layout/components/Sidebar/index.vue @@ -0,0 +1,54 @@ + + + diff --git a/admin-ui/src/layout/components/TagsView/ScrollPane.vue b/admin-ui/src/layout/components/TagsView/ScrollPane.vue new file mode 100644 index 0000000..5c2977a --- /dev/null +++ b/admin-ui/src/layout/components/TagsView/ScrollPane.vue @@ -0,0 +1,105 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/layout/components/TagsView/index.vue b/admin-ui/src/layout/components/TagsView/index.vue new file mode 100644 index 0000000..0228b30 --- /dev/null +++ b/admin-ui/src/layout/components/TagsView/index.vue @@ -0,0 +1,345 @@ + + + + + + + \ No newline at end of file diff --git a/admin-ui/src/layout/components/index.js b/admin-ui/src/layout/components/index.js new file mode 100644 index 0000000..fd57731 --- /dev/null +++ b/admin-ui/src/layout/components/index.js @@ -0,0 +1,4 @@ +export { default as AppMain } from './AppMain' +export { default as Navbar } from './Navbar' +export { default as Settings } from './Settings' +export { default as TagsView } from './TagsView/index.vue' diff --git a/admin-ui/src/layout/index.vue b/admin-ui/src/layout/index.vue new file mode 100644 index 0000000..3ddb165 --- /dev/null +++ b/admin-ui/src/layout/index.vue @@ -0,0 +1,111 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/main.js b/admin-ui/src/main.js new file mode 100644 index 0000000..9a86094 --- /dev/null +++ b/admin-ui/src/main.js @@ -0,0 +1,101 @@ +import { createApp } from 'vue' + +import Cookies from 'js-cookie' + +import ElementPlus from 'element-plus' +// import locale from 'element-plus/lib/locale/lang/zh-cn' // 中文语言 + +import zhCn from 'element-plus/dist/locale/zh-cn.mjs' + +import '@/assets/styles/index.scss' // global css +import App from './App' +import { store, useSettingsStore } from './store' +import router from './router' +import directive from './directive' // directive + +// 注册指令 +import plugins from './plugins' // plugins +import { download } from '@/utils/request' + +// svg图标 +import 'virtual:svg-icons-register' +import SvgIcon from '@/components/SvgIcon' +import elementIcons from '@/components/SvgIcon/svgicon' + +import './permission' // permission control + +import { useDict } from '@/utils/dict' +import { getConfigKey, updateConfigByKey } from "@/api/system/config"; +import { parseTime, resetForm, addDateRange, handleTree, selectDictLabel, selectDictLabels } from '@/utils/ruoyi' + +// 分页组件 +import Pagination from '@/components/Pagination' +// 自定义表格工具组件 +import RightToolbar from '@/components/RightToolbar' +// 富文本组件 +import Editor from "@/components/Editor" +// 文件上传组件 +import FileUpload from "@/components/FileUpload" +// 图片上传组件 +import ImageUpload from "@/components/ImageUpload" +// 图片预览组件 +import ImagePreview from "@/components/ImagePreview" +// 自定义树选择组件 +import TreeSelect from '@/components/TreeSelect' +// 字典标签组件 +import DictTag from '@/components/DictTag' + +const app = createApp(App) + +// 全局方法挂载 +app.config.globalProperties.useDict = useDict +app.config.globalProperties.getConfigKey = getConfigKey +app.config.globalProperties.updateConfigByKey = updateConfigByKey +app.config.globalProperties.download = download +app.config.globalProperties.parseTime = parseTime +app.config.globalProperties.resetForm = resetForm +app.config.globalProperties.handleTree = handleTree +app.config.globalProperties.addDateRange = addDateRange +app.config.globalProperties.selectDictLabel = selectDictLabel +app.config.globalProperties.selectDictLabels = selectDictLabels +app.config.globalProperties.setTitle = (title) => { useSettingsStore().setTitle(title) } + +// 全局组件挂载 +app.component('DictTag', DictTag) +app.component('Pagination', Pagination) +app.component('TreeSelect', TreeSelect) +app.component('FileUpload', FileUpload) +app.component('ImageUpload', ImageUpload) +app.component('ImagePreview', ImagePreview) +app.component('RightToolbar', RightToolbar) +app.component('Editor', Editor) + +app.use(router) +app.use(store) +app.use(plugins) +app.use(elementIcons) +app.component('svg-icon', SvgIcon) + +directive(app) + + +//自定义工具类注册 +import { util } from '@/utils' +app.use(util) + +//自动自定义全局异步组件注册 +import auto from '@/auto' +app.use(auto); + + +// 使用element-plus 并且设置全局的大小 +app.use(ElementPlus, { + locale: zhCn, + // 支持 large、default、small + size: Cookies.get('size') || 'default' +}) + +// 修改 el-dialog 默认点击遮照为不关闭 +app._context.components.ElDialog.props.closeOnClickModal.default = false + +app.mount('#app') diff --git a/admin-ui/src/permission.js b/admin-ui/src/permission.js new file mode 100644 index 0000000..a474e0e --- /dev/null +++ b/admin-ui/src/permission.js @@ -0,0 +1,63 @@ +import router from './router' +import { ElMessage } from 'element-plus' +import NProgress from 'nprogress' +import 'nprogress/nprogress.css' +import { getToken } from '@/utils/auth' +import { isHttp } from '@/utils/validate' +import { isRelogin } from '@/utils/request' +import useUserStore from '@/store/modules/user' +import useSettingsStore from '@/store/modules/settings' +import usePermissionStore from '@/store/modules/permission' + +NProgress.configure({ showSpinner: false }); + +const whiteList = ['/login', '/register']; + +router.beforeEach((to, from, next) => { + NProgress.start() + if (getToken()) { + to.meta.title && useSettingsStore().setTitle(to.meta.title) + /* has token*/ + if (to.path === '/login') { + next({ path: '/' }) + NProgress.done() + } else { + if (useUserStore().roles.length === 0) { + isRelogin.show = true + // 判断当前用户是否已拉取完user_info信息 + useUserStore().getInfo().then(() => { + isRelogin.show = false + usePermissionStore().generateRoutes().then(accessRoutes => { + // 根据roles权限生成可访问的路由表 + accessRoutes.forEach(route => { + if (!isHttp(route.path)) { + router.addRoute(route) // 动态添加可访问路由表 + } + }) + next({ ...to, replace: true }) // hack方法 确保addRoutes已完成 + }) + }).catch(err => { + useUserStore().logOut().then(() => { + ElMessage.error(err) + next({ path: '/' }) + }) + }) + } else { + next() + } + } + } else { + // 没有token + if (whiteList.indexOf(to.path) !== -1) { + // 在免登录白名单,直接进入 + next() + } else { + next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页 + NProgress.done() + } + } +}) + +router.afterEach(() => { + NProgress.done() +}) diff --git a/admin-ui/src/plugins/auth.js b/admin-ui/src/plugins/auth.js new file mode 100644 index 0000000..5e8c28d --- /dev/null +++ b/admin-ui/src/plugins/auth.js @@ -0,0 +1,60 @@ +import useUserStore from '@/store/modules/user' + +function authPermission(permission) { + const all_permission = "*:*:*"; + const permissions = useUserStore().permissions + if (permission && permission.length > 0) { + return permissions.some(v => { + return all_permission === v || v === permission + }) + } else { + return false + } +} + +function authRole(role) { + const super_admin = "admin"; + const roles = useUserStore().roles + if (role && role.length > 0) { + return roles.some(v => { + return super_admin === v || v === role + }) + } else { + return false + } +} + +export default { + // 验证用户是否具备某权限 + hasPermi(permission) { + return authPermission(permission); + }, + // 验证用户是否含有指定权限,只需包含其中一个 + hasPermiOr(permissions) { + return permissions.some(item => { + return authPermission(item) + }) + }, + // 验证用户是否含有指定权限,必须全部拥有 + hasPermiAnd(permissions) { + return permissions.every(item => { + return authPermission(item) + }) + }, + // 验证用户是否具备某角色 + hasRole(role) { + return authRole(role); + }, + // 验证用户是否含有指定角色,只需包含其中一个 + hasRoleOr(roles) { + return roles.some(item => { + return authRole(item) + }) + }, + // 验证用户是否含有指定角色,必须全部拥有 + hasRoleAnd(roles) { + return roles.every(item => { + return authRole(item) + }) + } +} diff --git a/admin-ui/src/plugins/cache.js b/admin-ui/src/plugins/cache.js new file mode 100644 index 0000000..6b5c00b --- /dev/null +++ b/admin-ui/src/plugins/cache.js @@ -0,0 +1,77 @@ +const sessionCache = { + set (key, value) { + if (!sessionStorage) { + return + } + if (key != null && value != null) { + sessionStorage.setItem(key, value) + } + }, + get (key) { + if (!sessionStorage) { + return null + } + if (key == null) { + return null + } + return sessionStorage.getItem(key) + }, + setJSON (key, jsonValue) { + if (jsonValue != null) { + this.set(key, JSON.stringify(jsonValue)) + } + }, + getJSON (key) { + const value = this.get(key) + if (value != null) { + return JSON.parse(value) + } + }, + remove (key) { + sessionStorage.removeItem(key); + } +} +const localCache = { + set (key, value) { + if (!localStorage) { + return + } + if (key != null && value != null) { + localStorage.setItem(key, value) + } + }, + get (key) { + if (!localStorage) { + return null + } + if (key == null) { + return null + } + return localStorage.getItem(key) + }, + setJSON (key, jsonValue) { + if (jsonValue != null) { + this.set(key, JSON.stringify(jsonValue)) + } + }, + getJSON (key) { + const value = this.get(key) + if (value != null) { + return JSON.parse(value) + } + }, + remove (key) { + localStorage.removeItem(key); + } +} + +export default { + /** + * 会话级缓存 + */ + session: sessionCache, + /** + * 本地缓存 + */ + local: localCache +} diff --git a/admin-ui/src/plugins/download.js b/admin-ui/src/plugins/download.js new file mode 100644 index 0000000..0613085 --- /dev/null +++ b/admin-ui/src/plugins/download.js @@ -0,0 +1,65 @@ +import axios from 'axios' +import { ElLoading, ElMessage } from 'element-plus' +import { saveAs } from 'file-saver' +import { getToken } from '@/utils/auth' +import errorCode from '@/utils/errorCode' +import { blobValidate } from '@/utils/ruoyi' + +const baseURL = import.meta.env.VITE_APP_BASE_API +let downloadLoadingInstance; + +export default { + oss(ossId) { + var url = baseURL + '/system/oss/download/' + ossId + downloadLoadingInstance = ElLoading.service({ text: "正在下载数据,请稍候", background: "rgba(0, 0, 0, 0.7)", }) + axios({ + method: 'get', + url: url, + responseType: 'blob', + headers: { 'Authorization': 'Bearer ' + getToken() } + }).then((res) => { + const isBlob = blobValidate(res.data); + if (isBlob) { + const blob = new Blob([res.data], { type: 'application/octet-stream' }) + this.saveAs(blob, decodeURIComponent(res.headers['download-filename'])) + } else { + this.printErrMsg(res.data); + } + downloadLoadingInstance.close(); + }).catch((r) => { + console.error(r) + Message.error('下载文件出现错误,请联系管理员!') + downloadLoadingInstance.close(); + }) + }, + zip(url, name) { + var url = baseURL + url + axios({ + method: 'get', + url: url, + responseType: 'blob', + headers: { + 'Authorization': 'Bearer ' + getToken(), + 'datasource': localStorage.getItem("dataName") + } + }).then((res) => { + const isBlob = blobValidate(res.data); + if (isBlob) { + const blob = new Blob([res.data], { type: 'application/zip' }) + this.saveAs(blob, name) + } else { + this.printErrMsg(res.data); + } + }) + }, + saveAs(text, name, opts) { + saveAs(text, name, opts); + }, + async printErrMsg(data) { + const resText = await data.text(); + const rspObj = JSON.parse(resText); + const errMsg = errorCode[rspObj.code] || rspObj.msg || errorCode['default'] + ElMessage.error(errMsg); + } +} + diff --git a/admin-ui/src/plugins/index.js b/admin-ui/src/plugins/index.js new file mode 100644 index 0000000..47d1b41 --- /dev/null +++ b/admin-ui/src/plugins/index.js @@ -0,0 +1,18 @@ +import tab from './tab' +import auth from './auth' +import cache from './cache' +import modal from './modal' +import download from './download' + +export default function installPlugins(app){ + // 页签操作 + app.config.globalProperties.$tab = tab + // 认证对象 + app.config.globalProperties.$auth = auth + // 缓存对象 + app.config.globalProperties.$cache = cache + // 模态框对象 + app.config.globalProperties.$modal = modal + // 下载文件 + app.config.globalProperties.$download = download +} diff --git a/admin-ui/src/plugins/modal.js b/admin-ui/src/plugins/modal.js new file mode 100644 index 0000000..b59e14d --- /dev/null +++ b/admin-ui/src/plugins/modal.js @@ -0,0 +1,82 @@ +import { ElMessage, ElMessageBox, ElNotification, ElLoading } from 'element-plus' + +let loadingInstance; + +export default { + // 消息提示 + msg(content) { + ElMessage.info(content) + }, + // 错误消息 + msgError(content) { + ElMessage.error(content) + }, + // 成功消息 + msgSuccess(content) { + ElMessage.success(content) + }, + // 警告消息 + msgWarning(content) { + ElMessage.warning(content) + }, + // 弹出提示 + alert(content) { + ElMessageBox.alert(content, "系统提示") + }, + // 错误提示 + alertError(content) { + ElMessageBox.alert(content, "系统提示", { type: 'error' }) + }, + // 成功提示 + alertSuccess(content) { + ElMessageBox.alert(content, "系统提示", { type: 'success' }) + }, + // 警告提示 + alertWarning(content) { + ElMessageBox.alert(content, "系统提示", { type: 'warning' }) + }, + // 通知提示 + notify(content) { + ElNotification.info(content) + }, + // 错误通知 + notifyError(content) { + ElNotification.error(content); + }, + // 成功通知 + notifySuccess(content) { + ElNotification.success(content) + }, + // 警告通知 + notifyWarning(content) { + ElNotification.warning(content) + }, + // 确认窗体 + confirm(content) { + return ElMessageBox.confirm(content, "系统提示", { + confirmButtonText: '确定', + cancelButtonText: '取消', + type: "warning", + }) + }, + // 提交内容 + prompt(content) { + return ElMessageBox.prompt(content, "系统提示", { + confirmButtonText: '确定', + cancelButtonText: '取消', + type: "warning", + }) + }, + // 打开遮罩层 + loading(content) { + loadingInstance = ElLoading.service({ + lock: true, + text: content, + background: "rgba(0, 0, 0, 0.7)", + }) + }, + // 关闭遮罩层 + closeLoading() { + loadingInstance.close(); + } +} diff --git a/admin-ui/src/plugins/tab.js b/admin-ui/src/plugins/tab.js new file mode 100644 index 0000000..59e7006 --- /dev/null +++ b/admin-ui/src/plugins/tab.js @@ -0,0 +1,65 @@ +import useTagsViewStore from '@/store/modules/tagsView' +import router from '@/router' + +export default { + // 刷新当前tab页签 + refreshPage(obj) { + const { path, query, matched } = router.currentRoute.value; + if (obj === undefined) { + matched.forEach((m) => { + if (m.components && m.components.default && m.components.default.name) { + if (!['Layout', 'ParentView'].includes(m.components.default.name)) { + obj = { name: m.components.default.name, path: path, query: query }; + } + } + }); + } + return useTagsViewStore().delCachedView(obj).then(() => { + const { path, query } = obj + router.replace({ + path: '/redirect' + path, + query: query + }) + }) + }, + // 关闭当前tab页签,打开新页签 + closeOpenPage(obj) { + useTagsViewStore().delView(router.currentRoute.value); + if (obj !== undefined) { + return router.push(obj); + } + }, + // 关闭指定tab页签 + closePage(obj) { + if (obj === undefined) { + return useTagsViewStore().delView(router.currentRoute.value).then(({ lastPath }) => { + return router.push(lastPath || '/index'); + }); + } + return useTagsViewStore().delView(obj); + }, + // 关闭所有tab页签 + closeAllPage() { + return useTagsViewStore().delAllViews(); + }, + // 关闭左侧tab页签 + closeLeftPage(obj) { + return useTagsViewStore().delLeftTags(obj || router.currentRoute.value); + }, + // 关闭右侧tab页签 + closeRightPage(obj) { + return useTagsViewStore().delRightTags(obj || router.currentRoute.value); + }, + // 关闭其他tab页签 + closeOtherPage(obj) { + return useTagsViewStore().delOthersViews(obj || router.currentRoute.value); + }, + // 打开tab页签 + openPage(url) { + return router.push(url); + }, + // 修改tab页签 + updatePage(obj) { + return useTagsViewStore().updateVisitedView(obj); + } +} diff --git a/admin-ui/src/router/index.js b/admin-ui/src/router/index.js new file mode 100644 index 0000000..4efec14 --- /dev/null +++ b/admin-ui/src/router/index.js @@ -0,0 +1,175 @@ +import { createWebHistory,createWebHashHistory, createRouter } from 'vue-router' +/* Layout */ +import Layout from '@/layout' + +/** + * Note: 路由配置项 + * + * hidden: true // 当设置 true 的时候该路由不会再侧边栏出现 如401,login等页面,或者如一些编辑页面/edit/1 + * alwaysShow: true // 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式--如组件页面 + * // 只有一个时,会将那个子路由当做根路由显示在侧边栏--如引导页面 + * // 若你想不管路由下面的 children 声明的个数都显示你的根路由 + * // 你可以设置 alwaysShow: true,这样它就会忽略之前定义的规则,一直显示根路由 + * redirect: noRedirect // 当设置 noRedirect 的时候该路由在面包屑导航中不可被点击 + * name:'router-name' // 设定路由的名字,一定要填写不然使用时会出现各种问题 + * query: '{"id": 1, "name": "ry"}' // 访问路由的默认传递参数 + * roles: ['admin', 'common'] // 访问路由的角色权限 + * permissions: ['a:a:a', 'b:b:b'] // 访问路由的菜单权限 + * meta : { + noCache: true // 如果设置为true,则不会被 缓存(默认 false) + title: 'title' // 设置该路由在侧边栏和面包屑中展示的名字 + icon: 'svg-name' // 设置该路由的图标,对应路径src/assets/icons/svg + breadcrumb: false // 如果设置为false,则不会在breadcrumb面包屑中显示 + activeMenu: '/system/user' // 当路由设置了该属性,则会高亮相对应的侧边栏。 + } + */ + +// 公共路由 +export const constantRoutes = [ + { + path: '/redirect', + component: Layout, + hidden: true, + children: [ + { + path: '/redirect/:path(.*)', + component: () => import('@/views/redirect/index.vue') + } + ] + }, + { + path: '/login', + component: () => import('@/views/login'), + hidden: true + }, + { + path: '/register', + component: () => import('@/views/register'), + hidden: true + }, + { + path: "/:pathMatch(.*)*", + component: () => import('@/views/error/404'), + hidden: true + }, + { + path: '/401', + component: () => import('@/views/error/401'), + hidden: true + }, + { + path: '', + component: Layout, + redirect: '/index', + children: [ + { + path: '/index', + component: () => import('@/views/index'), + name: 'Index', + meta: { title: '首页', icon: 'dashboard', affix: true } + } + ] + }, + { + path: '/user', + component: Layout, + hidden: true, + redirect: 'noredirect', + children: [ + { + path: 'profile', + component: () => import('@/views/system/user/profile/index'), + name: 'Profile', + meta: { title: '个人中心', icon: 'user' } + } + ] + } +] + +// 动态路由,基于用户权限动态去加载 +export const dynamicRoutes = [ + { + path: '/system/user-auth', + component: Layout, + hidden: true, + permissions: ['system:user:edit'], + children: [ + { + path: 'role/:userId(\\d+)', + component: () => import('@/views/system/user/authRole'), + name: 'AuthRole', + meta: { title: '分配角色', activeMenu: '/system/user' } + } + ] + }, + { + path: '/system/role-auth', + component: Layout, + hidden: true, + permissions: ['system:role:edit'], + children: [ + { + path: 'user/:roleId(\\d+)', + component: () => import('@/views/system/role/authUser'), + name: 'AuthUser', + meta: { title: '分配用户', activeMenu: '/system/role' } + } + ] + }, + { + path: '/system/dict-data', + component: Layout, + hidden: true, + permissions: ['system:dict:list'], + children: [ + { + path: 'index/:dictId(\\d+)', + component: () => import('@/views/system/dict/data'), + name: 'Data', + meta: { title: '字典数据', activeMenu: '/system/dict' } + } + ] + }, + { + path: '/system/oss-config', + component: Layout, + hidden: true, + permissions: ['monitor:job:list'], + children: [ + { + path: 'index', + component: () => import('@/views/system/oss/config'), + name: 'OssConfig', + meta: { title: '配置管理', activeMenu: '/system/oss'} + } + ] + }, + { + path: '/tool/gen-edit', + component: Layout, + hidden: true, + permissions: ['tool:gen:edit'], + children: [ + { + path: 'index/:tableId(\\d+)', + component: () => import('@/views/tool/gen/editTable'), + name: 'GenEdit', + meta: { title: '修改生成配置', activeMenu: '/tool/gen' } + } + ] + } +] + +const router = createRouter({ + history: createWebHashHistory(import.meta.env.VITE_APP_CONTEXT_PATH), + routes: constantRoutes, + scrollBehavior(to, from, savedPosition) { + if (savedPosition) { + return savedPosition + } else { + return { top: 0 } + } + }, +}); + +export default router; diff --git a/admin-ui/src/settings.js b/admin-ui/src/settings.js new file mode 100644 index 0000000..15276a3 --- /dev/null +++ b/admin-ui/src/settings.js @@ -0,0 +1,47 @@ +export default { + /** + * 网页标题 + */ + title: import.meta.env.VITE_APP_TITLE, + /** + * 侧边栏主题 深色主题theme-dark,浅色主题theme-light + */ + sideTheme: 'theme-light', + /** + * 是否系统布局配置 + */ + showSettings: false, + + /** + * 是否显示顶部导航 + */ + topNav: false, + + /** + * 是否显示 tagsView + */ + tagsView: true, + + /** + * 是否固定头部 + */ + fixedHeader: true, + + /** + * 是否显示logo + */ + sidebarLogo: true, + + /** + * 是否显示动态标题 + */ + dynamicTitle: true, + + /** + * @type {string | array} 'production' | ['production', 'development'] + * @description Need show err logs component. + * The default is only used in the production env + * If you want to also use it in dev, you can pass ['production', 'development'] + */ + errorLog: 'production' +} diff --git a/admin-ui/src/store/index.js b/admin-ui/src/store/index.js new file mode 100644 index 0000000..0a1715e --- /dev/null +++ b/admin-ui/src/store/index.js @@ -0,0 +1,17 @@ +import { createPinia } from 'pinia'; +import useAppStore from './modules/app'; +import useDictStore from './modules/dict'; +import usePermissionStore from './modules/permission'; +import useSettingsStore from './modules/settings'; +import useTagsViewStore from './modules/tagsView'; +import useUserStore from './modules/user'; +import piniaPluginPersist from 'pinia-plugin-persist' + +const store = createPinia() +store.use(piniaPluginPersist) + +export { store, useAppStore, useDictStore, usePermissionStore, useSettingsStore, useTagsViewStore, useUserStore } + +export { useLocalStore } from './modules/local' +export { useSessionStore } from './modules/session' +export { useCacheStore } from './modules/cache' \ No newline at end of file diff --git a/admin-ui/src/store/modules/app.js b/admin-ui/src/store/modules/app.js new file mode 100644 index 0000000..0b57159 --- /dev/null +++ b/admin-ui/src/store/modules/app.js @@ -0,0 +1,46 @@ +import Cookies from 'js-cookie' + +const useAppStore = defineStore( + 'app', + { + state: () => ({ + sidebar: { + opened: Cookies.get('sidebarStatus') ? !!+Cookies.get('sidebarStatus') : true, + withoutAnimation: false, + hide: false + }, + device: 'desktop', + size: Cookies.get('size') || 'default' + }), + actions: { + toggleSideBar(withoutAnimation) { + if (this.sidebar.hide) { + return false; + } + this.sidebar.opened = !this.sidebar.opened + this.sidebar.withoutAnimation = withoutAnimation + if (this.sidebar.opened) { + Cookies.set('sidebarStatus', 1) + } else { + Cookies.set('sidebarStatus', 0) + } + }, + closeSideBar({ withoutAnimation }) { + Cookies.set('sidebarStatus', 0) + this.sidebar.opened = false + this.sidebar.withoutAnimation = withoutAnimation + }, + toggleDevice(device) { + this.device = device + }, + setSize(size) { + this.size = size; + Cookies.set('size', size) + }, + toggleSideBarHide(status) { + this.sidebar.hide = status + } + } + }) + +export default useAppStore diff --git a/admin-ui/src/store/modules/cache.js b/admin-ui/src/store/modules/cache.js new file mode 100644 index 0000000..646bcbe --- /dev/null +++ b/admin-ui/src/store/modules/cache.js @@ -0,0 +1,29 @@ + +/** + * 通用数据仓库 + */ +export const useCacheStore = defineStore('cacheStore', { + state: () => { + return { + cache:{} + } + }, + //计算字段 + getters: { + + }, + //方法 + actions: { + + }, + persist: { + enabled: true, // 开启缓存 默认会存储在本地localStorage + strategies: [ + { + key: 'cacheStore', + storage: sessionStorage, + }, + ] + } + +}) \ No newline at end of file diff --git a/admin-ui/src/store/modules/dict.js b/admin-ui/src/store/modules/dict.js new file mode 100644 index 0000000..27fc308 --- /dev/null +++ b/admin-ui/src/store/modules/dict.js @@ -0,0 +1,57 @@ +const useDictStore = defineStore( + 'dict', + { + state: () => ({ + dict: new Array() + }), + actions: { + // 获取字典 + getDict(_key) { + if (_key == null && _key == "") { + return null; + } + try { + for (let i = 0; i < this.dict.length; i++) { + if (this.dict[i].key == _key) { + return this.dict[i].value; + } + } + } catch (e) { + return null; + } + }, + // 设置字典 + setDict(_key, value) { + if (_key !== null && _key !== "") { + this.dict.push({ + key: _key, + value: value + }); + } + }, + // 删除字典 + removeDict(_key) { + var bln = false; + try { + for (let i = 0; i < this.dict.length; i++) { + if (this.dict[i].key == _key) { + this.dict.splice(i, 1); + return true; + } + } + } catch (e) { + bln = false; + } + return bln; + }, + // 清空字典 + cleanDict() { + this.dict = new Array(); + }, + // 初始字典 + initDict() { + } + } + }) + +export default useDictStore diff --git a/admin-ui/src/store/modules/local.js b/admin-ui/src/store/modules/local.js new file mode 100644 index 0000000..e7b8309 --- /dev/null +++ b/admin-ui/src/store/modules/local.js @@ -0,0 +1,31 @@ + +/** + * 通用数据仓库 + */ +export const useLocalStore = defineStore('localStore', { + state: () => { + return { + test: undefined, + loginBg:true, + obj:{}, + } + }, + //计算字段 + getters: { + + }, + //方法 + actions: { + + }, + persist: { + enabled: true, // 开启缓存 默认会存储在本地localStorage + strategies: [ + { + key: 'localStore', + storage: localStorage, + }, + ] + } + +}) \ No newline at end of file diff --git a/admin-ui/src/store/modules/permission.js b/admin-ui/src/store/modules/permission.js new file mode 100644 index 0000000..ef506e9 --- /dev/null +++ b/admin-ui/src/store/modules/permission.js @@ -0,0 +1,138 @@ +import auth from '@/plugins/auth' +import router, { constantRoutes, dynamicRoutes } from '@/router' +import { getRouters } from '@/api/menu' +import Layout from '@/layout/index' +import ParentView from '@/components/ParentView' +import InnerLink from '@/layout/components/InnerLink' + +// 匹配views里面所有的.vue文件 +const modules = import.meta.glob('./../../views/**/*.vue') + +const usePermissionStore = defineStore( + 'permission', + { + state: () => ({ + routes: [], + addRoutes: [], + defaultRoutes: [], + topbarRouters: [], + sidebarRouters: [] + }), + actions: { + setRoutes(routes) { + this.addRoutes = routes + this.routes = constantRoutes.concat(routes) + }, + setDefaultRoutes(routes) { + this.defaultRoutes = constantRoutes.concat(routes) + }, + setTopbarRoutes(routes) { + this.topbarRouters = routes + }, + setSidebarRouters(routes) { + this.sidebarRouters = routes + }, + generateRoutes(roles) { + return new Promise(resolve => { + // 向后端请求路由数据 + getRouters().then(res => { + const sdata = JSON.parse(JSON.stringify(res.data)) + const rdata = JSON.parse(JSON.stringify(res.data)) + const defaultData = JSON.parse(JSON.stringify(res.data)) + const sidebarRoutes = filterAsyncRouter(sdata) + const rewriteRoutes = filterAsyncRouter(rdata, false, true) + const defaultRoutes = filterAsyncRouter(defaultData) + const asyncRoutes = filterDynamicRoutes(dynamicRoutes) + asyncRoutes.forEach(route => { router.addRoute(route) }) + this.setRoutes(rewriteRoutes) + this.setSidebarRouters(constantRoutes.concat(sidebarRoutes)) + this.setDefaultRoutes(sidebarRoutes) + this.setTopbarRoutes(defaultRoutes) + resolve(rewriteRoutes) + }) + }) + } + } + }) + +// 遍历后台传来的路由字符串,转换为组件对象 +function filterAsyncRouter(asyncRouterMap, lastRouter = false, type = false) { + return asyncRouterMap.filter(route => { + if (type && route.children) { + route.children = filterChildren(route.children) + } + if (route.component) { + // Layout ParentView 组件特殊处理 + if (route.component === 'Layout') { + route.component = Layout + } else if (route.component === 'ParentView') { + route.component = ParentView + } else if (route.component === 'InnerLink') { + route.component = InnerLink + } else { + route.component = loadView(route.component) + } + } + if (route.children != null && route.children && route.children.length) { + route.children = filterAsyncRouter(route.children, route, type) + } else { + delete route['children'] + delete route['redirect'] + } + return true + }) +} + +function filterChildren(childrenMap, lastRouter = false) { + var children = [] + childrenMap.forEach((el, index) => { + if (el.children && el.children.length) { + if (el.component === 'ParentView' && !lastRouter) { + el.children.forEach(c => { + c.path = el.path + '/' + c.path + if (c.children && c.children.length) { + children = children.concat(filterChildren(c.children, c)) + return + } + children.push(c) + }) + return + } + } + if (lastRouter) { + el.path = lastRouter.path + '/' + el.path + } + children = children.concat(el) + }) + return children +} + +// 动态路由遍历,验证是否具备权限 +export function filterDynamicRoutes(routes) { + const res = [] + routes.forEach(route => { + if (route.permissions) { + if (auth.hasPermiOr(route.permissions)) { + res.push(route) + } + } else if (route.roles) { + if (auth.hasRoleOr(route.roles)) { + res.push(route) + } + } + }) + return res +} + +export const loadView = (view) => { + let res; + for (const path in modules) { + const dir = path.split('views/')[1].split('.vue')[0]; + if (dir === view) { + res = () => modules[path](); + } + } + return res; +} + +export default usePermissionStore diff --git a/admin-ui/src/store/modules/session.js b/admin-ui/src/store/modules/session.js new file mode 100644 index 0000000..f63b0a1 --- /dev/null +++ b/admin-ui/src/store/modules/session.js @@ -0,0 +1,30 @@ + +/** + * 通用数据仓库 + */ +export const useSessionStore = defineStore('sessionStore', { + state: () => { + return { + test: undefined, + obj:{} + } + }, + //计算字段 + getters: { + + }, + //方法 + actions: { + + }, + persist: { + enabled: true, // 开启缓存 默认会存储在本地localStorage + strategies: [ + { + key: 'sessionStore', + storage: sessionStorage, + }, + ] + } + +}) \ No newline at end of file diff --git a/admin-ui/src/store/modules/settings.js b/admin-ui/src/store/modules/settings.js new file mode 100644 index 0000000..5b33285 --- /dev/null +++ b/admin-ui/src/store/modules/settings.js @@ -0,0 +1,38 @@ +import defaultSettings from '@/settings' +import { useDynamicTitle } from '@/utils/dynamicTitle' + +const { sideTheme, showSettings, topNav, tagsView, fixedHeader, sidebarLogo, dynamicTitle } = defaultSettings + +const storageSetting = JSON.parse(localStorage.getItem('layout-setting')) || '' + +const useSettingsStore = defineStore( + 'settings', + { + state: () => ({ + title: '', + theme: storageSetting.theme || import.meta.env.VITE_APP_COLOR || '#409EFF', + sideTheme: storageSetting.sideTheme || sideTheme, + showSettings: showSettings, + topNav: storageSetting.topNav === undefined ? topNav : storageSetting.topNav, + tagsView: storageSetting.tagsView === undefined ? tagsView : storageSetting.tagsView, + fixedHeader: storageSetting.fixedHeader === undefined ? fixedHeader : storageSetting.fixedHeader, + sidebarLogo: storageSetting.sidebarLogo === undefined ? sidebarLogo : storageSetting.sidebarLogo, + dynamicTitle: storageSetting.dynamicTitle === undefined ? dynamicTitle : storageSetting.dynamicTitle + }), + actions: { + // 修改布局设置 + changeSetting(data) { + const { key, value } = data + if (this.hasOwnProperty(key)) { + this[key] = value + } + }, + // 设置网页标题 + setTitle(title) { + this.title = title + useDynamicTitle(); + } + } + }) + +export default useSettingsStore diff --git a/admin-ui/src/store/modules/tagsView.js b/admin-ui/src/store/modules/tagsView.js new file mode 100644 index 0000000..9d07f33 --- /dev/null +++ b/admin-ui/src/store/modules/tagsView.js @@ -0,0 +1,182 @@ +const useTagsViewStore = defineStore( + 'tags-view', + { + state: () => ({ + visitedViews: [], + cachedViews: [], + iframeViews: [] + }), + actions: { + addView(view) { + this.addVisitedView(view) + this.addCachedView(view) + }, + addIframeView(view) { + if (this.iframeViews.some(v => v.path === view.path)) return + this.iframeViews.push( + Object.assign({}, view, { + title: view.meta.title || 'no-name' + }) + ) + }, + addVisitedView(view) { + if (this.visitedViews.some(v => v.path === view.path)) return + this.visitedViews.push( + Object.assign({}, view, { + title: view.meta.title || 'no-name' + }) + ) + }, + addCachedView(view) { + if (this.cachedViews.includes(view.name)) return + if (!view.meta.noCache) { + this.cachedViews.push(view.name) + } + }, + delView(view) { + return new Promise(resolve => { + this.delVisitedView(view) + this.delCachedView(view) + resolve({ + visitedViews: [...this.visitedViews], + cachedViews: [...this.cachedViews] + }) + }) + }, + delVisitedView(view) { + return new Promise(resolve => { + for (const [i, v] of this.visitedViews.entries()) { + if (v.path === view.path) { + this.visitedViews.splice(i, 1) + break + } + } + this.iframeViews = this.iframeViews.filter(item => item.path !== view.path) + resolve([...this.visitedViews]) + }) + }, + delIframeView(view) { + return new Promise(resolve => { + this.iframeViews = this.iframeViews.filter(item => item.path !== view.path) + resolve([...this.iframeViews]) + }) + }, + delCachedView(view) { + return new Promise(resolve => { + const index = this.cachedViews.indexOf(view.name) + index > -1 && this.cachedViews.splice(index, 1) + resolve([...this.cachedViews]) + }) + }, + delOthersViews(view) { + return new Promise(resolve => { + this.delOthersVisitedViews(view) + this.delOthersCachedViews(view) + resolve({ + visitedViews: [...this.visitedViews], + cachedViews: [...this.cachedViews] + }) + }) + }, + delOthersVisitedViews(view) { + return new Promise(resolve => { + this.visitedViews = this.visitedViews.filter(v => { + return v.meta.affix || v.path === view.path + }) + this.iframeViews = this.iframeViews.filter(item => item.path === view.path) + resolve([...this.visitedViews]) + }) + }, + delOthersCachedViews(view) { + return new Promise(resolve => { + const index = this.cachedViews.indexOf(view.name) + if (index > -1) { + this.cachedViews = this.cachedViews.slice(index, index + 1) + } else { + this.cachedViews = [] + } + resolve([...this.cachedViews]) + }) + }, + delAllViews(view) { + return new Promise(resolve => { + this.delAllVisitedViews(view) + this.delAllCachedViews(view) + resolve({ + visitedViews: [...this.visitedViews], + cachedViews: [...this.cachedViews] + }) + }) + }, + delAllVisitedViews(view) { + return new Promise(resolve => { + const affixTags = this.visitedViews.filter(tag => tag.meta.affix) + this.visitedViews = affixTags + this.iframeViews = [] + resolve([...this.visitedViews]) + }) + }, + delAllCachedViews(view) { + return new Promise(resolve => { + this.cachedViews = [] + resolve([...this.cachedViews]) + }) + }, + updateVisitedView(view) { + for (let v of this.visitedViews) { + if (v.path === view.path) { + v = Object.assign(v, view) + break + } + } + }, + delRightTags(view) { + return new Promise(resolve => { + const index = this.visitedViews.findIndex(v => v.path === view.path) + if (index === -1) { + return + } + this.visitedViews = this.visitedViews.filter((item, idx) => { + if (idx <= index || (item.meta && item.meta.affix)) { + return true + } + const i = this.cachedViews.indexOf(item.name) + if (i > -1) { + this.cachedViews.splice(i, 1) + } + if(item.meta.link) { + const fi = this.iframeViews.findIndex(v => v.path === item.path) + this.iframeViews.splice(fi, 1) + } + return false + }) + resolve([...this.visitedViews]) + }) + }, + delLeftTags(view) { + return new Promise(resolve => { + const index = this.visitedViews.findIndex(v => v.path === view.path) + if (index === -1) { + return + } + this.visitedViews = this.visitedViews.filter((item, idx) => { + if (idx >= index || (item.meta && item.meta.affix)) { + return true + } + const i = this.cachedViews.indexOf(item.name) + if (i > -1) { + this.cachedViews.splice(i, 1) + } + if(item.meta.link) { + const fi = this.iframeViews.findIndex(v => v.path === item.path) + this.iframeViews.splice(fi, 1) + } + return false + }) + resolve([...this.visitedViews]) + }) + } + } + }) + +export default useTagsViewStore diff --git a/admin-ui/src/store/modules/user.js b/admin-ui/src/store/modules/user.js new file mode 100644 index 0000000..1f932e8 --- /dev/null +++ b/admin-ui/src/store/modules/user.js @@ -0,0 +1,78 @@ +import { login, logout, getInfo } from '@/api/login' +import { getToken, setToken, removeToken } from '@/utils/auth' +import defAva from '@/assets/images/avatar.png' + +import {useCacheStore} from '../index' + +const useUserStore = defineStore( + 'user', + { + state: () => ({ + token: getToken(), + name: '', + avatar: '', + roles: [], + permissions: [] + }), + actions: { + // 登录 + login(userInfo) { + const username = userInfo.username.trim() + const password = userInfo.password + const code = userInfo.code + const uuid = userInfo.uuid + return new Promise((resolve, reject) => { + login(username, password, code, uuid).then(res => { + setToken(res.data.token) + this.token = res.data.token + useCacheStore().cache={}; + resolve() + }).catch(error => { + reject(error) + }) + }) + }, + // 获取用户信息 + getInfo() { + return new Promise((resolve, reject) => { + getInfo().then(res => { + const user = res.data.user + const avatar = (user.avatar == "" || user.avatar == null) ? defAva : user.avatar; + + if (res.data.roles && res.data.roles.length > 0) { // 验证返回的roles是否是一个非空数组 + this.roles = res.data.roles + this.permissions = res.data.permissions + } else { + this.roles = ['ROLE_DEFAULT'] + } + this.name = user.userName + this.avatar = avatar; + resolve(res) + }).catch(error => { + reject(error) + }) + }) + }, + // 退出系统 + logOut() { + return new Promise((resolve, reject) => { + logout(this.token).then(() => { + this.token = '' + this.roles = [] + this.permissions = [] + removeToken() + resolve() + }).catch(error => { + // reject(error) + this.token = '' + this.roles = [] + this.permissions = [] + removeToken() + resolve() + }) + }) + } + } + }) + +export default useUserStore diff --git a/admin-ui/src/utils/auth.js b/admin-ui/src/utils/auth.js new file mode 100644 index 0000000..08a43d6 --- /dev/null +++ b/admin-ui/src/utils/auth.js @@ -0,0 +1,15 @@ +import Cookies from 'js-cookie' + +const TokenKey = 'Admin-Token' + +export function getToken() { + return Cookies.get(TokenKey) +} + +export function setToken(token) { + return Cookies.set(TokenKey, token) +} + +export function removeToken() { + return Cookies.remove(TokenKey) +} diff --git a/admin-ui/src/utils/dict.js b/admin-ui/src/utils/dict.js new file mode 100644 index 0000000..9648f14 --- /dev/null +++ b/admin-ui/src/utils/dict.js @@ -0,0 +1,24 @@ +import useDictStore from '@/store/modules/dict' +import { getDicts } from '@/api/system/dict/data' + +/** + * 获取字典数据 + */ +export function useDict(...args) { + const res = ref({}); + return (() => { + args.forEach((dictType, index) => { + res.value[dictType] = []; + const dicts = useDictStore().getDict(dictType); + if (dicts) { + res.value[dictType] = dicts; + } else { + getDicts(dictType).then(resp => { + res.value[dictType] = resp.data.map(p => ({ label: p.dictLabel, value: p.dictValue, elTagType: p.listClass, elTagClass: p.cssClass })) + useDictStore().setDict(dictType, res.value[dictType]); + }) + } + }) + return toRefs(res.value); + })() +} \ No newline at end of file diff --git a/admin-ui/src/utils/dynamicTitle.js b/admin-ui/src/utils/dynamicTitle.js new file mode 100644 index 0000000..3094657 --- /dev/null +++ b/admin-ui/src/utils/dynamicTitle.js @@ -0,0 +1,15 @@ +import {store} from '@/store' +import defaultSettings from '@/settings' +import useSettingsStore from '@/store/modules/settings' + +/** + * 动态修改标题 + */ +export function useDynamicTitle() { + const settingsStore = useSettingsStore(); + if (settingsStore.dynamicTitle) { + document.title = settingsStore.title + ' - ' + defaultSettings.title; + } else { + document.title = defaultSettings.title; + } +} \ No newline at end of file diff --git a/admin-ui/src/utils/errorCode.js b/admin-ui/src/utils/errorCode.js new file mode 100644 index 0000000..d2111ee --- /dev/null +++ b/admin-ui/src/utils/errorCode.js @@ -0,0 +1,6 @@ +export default { + '401': '认证失败,无法访问系统资源', + '403': '当前操作没有权限', + '404': '访问资源不存在', + 'default': '系统未知错误,请反馈给管理员' +} diff --git a/admin-ui/src/utils/index.js b/admin-ui/src/utils/index.js new file mode 100644 index 0000000..ab7b5f1 --- /dev/null +++ b/admin-ui/src/utils/index.js @@ -0,0 +1,398 @@ +import { parseTime } from './ruoyi' +import prototypes from "./modules/prototypes" +import timerEvent from "./modules/timerEvent"; +export const util = { + install(Vue) { + prototypes(); + timerEvent(); + } +} + +/** + * 表格时间格式化 + */ +export function formatDate(cellValue) { + if (cellValue == null || cellValue == "") return ""; + var date = new Date(cellValue) + var year = date.getFullYear() + var month = date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1 + var day = date.getDate() < 10 ? '0' + date.getDate() : date.getDate() + var hours = date.getHours() < 10 ? '0' + date.getHours() : date.getHours() + var minutes = date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes() + var seconds = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds() + return year + '-' + month + '-' + day + ' ' + hours + ':' + minutes + ':' + seconds +} + +/** + * @param {number} time + * @param {string} option + * @returns {string} + */ +export function formatTime(time, option) { + if (('' + time).length === 10) { + time = parseInt(time) * 1000 + } else { + time = +time + } + const d = new Date(time) + const now = Date.now() + + const diff = (now - d) / 1000 + + if (diff < 30) { + return '刚刚' + } else if (diff < 3600) { + // less 1 hour + return Math.ceil(diff / 60) + '分钟前' + } else if (diff < 3600 * 24) { + return Math.ceil(diff / 3600) + '小时前' + } else if (diff < 3600 * 24 * 2) { + return '1天前' + } + if (option) { + return parseTime(time, option) + } else { + return ( + d.getMonth() + + 1 + + '月' + + d.getDate() + + '日' + + d.getHours() + + '时' + + d.getMinutes() + + '分' + ) + } +} + +/** + * @param {string} url + * @returns {Object} + */ +export function getQueryObject(url) { + url = url == null ? window.location.href : url + const search = url.substring(url.lastIndexOf('?') + 1) + const obj = {} + const reg = /([^?&=]+)=([^?&=]*)/g + search.replace(reg, (rs, $1, $2) => { + const name = decodeURIComponent($1) + let val = decodeURIComponent($2) + val = String(val) + obj[name] = val + return rs + }) + return obj +} + +/** + * @param {string} input value + * @returns {number} output value + */ +export function byteLength(str) { + // returns the byte length of an utf8 string + let s = str.length + for (var i = str.length - 1; i >= 0; i--) { + const code = str.charCodeAt(i) + if (code > 0x7f && code <= 0x7ff) s++ + else if (code > 0x7ff && code <= 0xffff) s += 2 + if (code >= 0xDC00 && code <= 0xDFFF) i-- + } + return s +} + +/** + * @param {Array} actual + * @returns {Array} + */ +export function cleanArray(actual) { + const newArray = [] + for (let i = 0; i < actual.length; i++) { + if (actual[i]) { + newArray.push(actual[i]) + } + } + return newArray +} + +/** + * @param {Object} json + * @returns {Array} + */ +export function param(json) { + if (!json) return '' + return cleanArray( + Object.keys(json).map(key => { + if (json[key] === undefined) return '' + return encodeURIComponent(key) + '=' + encodeURIComponent(json[key]) + }) + ).join('&') +} + +/** + * @param {string} url + * @returns {Object} + */ +export function param2Obj(url) { + const search = decodeURIComponent(url.split('?')[1]).replace(/\+/g, ' ') + if (!search) { + return {} + } + const obj = {} + const searchArr = search.split('&') + searchArr.forEach(v => { + const index = v.indexOf('=') + if (index !== -1) { + const name = v.substring(0, index) + const val = v.substring(index + 1, v.length) + obj[name] = val + } + }) + return obj +} + +/** + * @param {string} val + * @returns {string} + */ +export function html2Text(val) { + const div = document.createElement('div') + div.innerHTML = val + return div.textContent || div.innerText +} + +/** + * Merges two objects, giving the last one precedence + * @param {Object} target + * @param {(Object|Array)} source + * @returns {Object} + */ +export function objectMerge(target, source) { + if (typeof target !== 'object') { + target = {} + } + if (Array.isArray(source)) { + return source.slice() + } + Object.keys(source).forEach(property => { + const sourceProperty = source[property] + if (typeof sourceProperty === 'object') { + target[property] = objectMerge(target[property], sourceProperty) + } else { + target[property] = sourceProperty + } + }) + return target +} + +/** + * @param {HTMLElement} element + * @param {string} className + */ +export function toggleClass(element, className) { + if (!element || !className) { + return + } + let classString = element.className + const nameIndex = classString.indexOf(className) + if (nameIndex === -1) { + classString += '' + className + } else { + classString = + classString.substr(0, nameIndex) + + classString.substr(nameIndex + className.length) + } + element.className = classString +} + +/** + * @param {string} type + * @returns {Date} + */ +export function getTime(type) { + if (type === 'start') { + return new Date().getTime() - 3600 * 1000 * 24 * 90 + } else { + return new Date(new Date().toDateString()) + } +} + +/** + * @param {Function} func + * @param {number} wait + * @param {boolean} immediate + * @return {*} + */ +export function debounce(func, wait, immediate) { + let timeout, args, context, timestamp, result + + const later = function() { + // 据上一次触发时间间隔 + const last = +new Date() - timestamp + + // 上次被包装函数被调用时间间隔 last 小于设定时间间隔 wait + if (last < wait && last > 0) { + timeout = setTimeout(later, wait - last) + } else { + timeout = null + // 如果设定为immediate===true,因为开始边界已经调用过了此处无需调用 + if (!immediate) { + result = func.apply(context, args) + if (!timeout) context = args = null + } + } + } + + return function(...args) { + context = this + timestamp = +new Date() + const callNow = immediate && !timeout + // 如果延时不存在,重新设定延时 + if (!timeout) timeout = setTimeout(later, wait) + if (callNow) { + result = func.apply(context, args) + context = args = null + } + + return result + } +} + +/** + * This is just a simple version of deep copy + * Has a lot of edge cases bug + * If you want to use a perfect deep copy, use lodash's _.cloneDeep + * @param {Object} source + * @returns {Object} + */ +export function deepClone(source) { + if (!source && typeof source !== 'object') { + throw new Error('error arguments', 'deepClone') + } + const targetObj = source.constructor === Array ? [] : {} + Object.keys(source).forEach(keys => { + if (source[keys] && typeof source[keys] === 'object') { + targetObj[keys] = deepClone(source[keys]) + } else { + targetObj[keys] = source[keys] + } + }) + return targetObj +} + +/** + * @param {Array} arr + * @returns {Array} + */ +export function uniqueArr(arr) { + return Array.from(new Set(arr)) +} + +/** + * @returns {string} + */ +export function createUniqueString() { + const timestamp = +new Date() + '' + const randomNum = parseInt((1 + Math.random()) * 65536) + '' + return (+(randomNum + timestamp)).toString(32) +} + +/** + * Check if an element has a class + * @param {HTMLElement} elm + * @param {string} cls + * @returns {boolean} + */ +export function hasClass(ele, cls) { + return !!ele.className.match(new RegExp('(\\s|^)' + cls + '(\\s|$)')) +} + +/** + * Add class to element + * @param {HTMLElement} elm + * @param {string} cls + */ +export function addClass(ele, cls) { + if (!hasClass(ele, cls)) ele.className += ' ' + cls +} + +/** + * Remove class from element + * @param {HTMLElement} elm + * @param {string} cls + */ +export function removeClass(ele, cls) { + if (hasClass(ele, cls)) { + const reg = new RegExp('(\\s|^)' + cls + '(\\s|$)') + ele.className = ele.className.replace(reg, ' ') + } +} + +export function makeMap(str, expectsLowerCase) { + const map = Object.create(null) + const list = str.split(',') + for (let i = 0; i < list.length; i++) { + map[list[i]] = true + } + return expectsLowerCase + ? val => map[val.toLowerCase()] + : val => map[val] +} + +export const exportDefault = 'export default ' + +export const beautifierConf = { + html: { + indent_size: '2', + indent_char: ' ', + max_preserve_newlines: '-1', + preserve_newlines: false, + keep_array_indentation: false, + break_chained_methods: false, + indent_scripts: 'separate', + brace_style: 'end-expand', + space_before_conditional: true, + unescape_strings: false, + jslint_happy: false, + end_with_newline: true, + wrap_line_length: '110', + indent_inner_html: true, + comma_first: false, + e4x: true, + indent_empty_lines: true + }, + js: { + indent_size: '2', + indent_char: ' ', + max_preserve_newlines: '-1', + preserve_newlines: false, + keep_array_indentation: false, + break_chained_methods: false, + indent_scripts: 'normal', + brace_style: 'end-expand', + space_before_conditional: true, + unescape_strings: false, + jslint_happy: true, + end_with_newline: true, + wrap_line_length: '110', + indent_inner_html: true, + comma_first: false, + e4x: true, + indent_empty_lines: true + } +} + +// 首字母大小 +export function titleCase(str) { + return str.replace(/( |^)[a-z]/g, L => L.toUpperCase()) +} + +// 下划转驼峰 +export function camelCase(str) { + return str.replace(/_[a-z]/g, str1 => str1.substr(-1).toUpperCase()) +} + +export function isNumberStr(str) { + return /^[+-]?(0|([1-9]\d*))(\.\d+)?$/g.test(str) +} + diff --git a/admin-ui/src/utils/jsencrypt.js b/admin-ui/src/utils/jsencrypt.js new file mode 100644 index 0000000..6daeb07 --- /dev/null +++ b/admin-ui/src/utils/jsencrypt.js @@ -0,0 +1,30 @@ +import JSEncrypt from 'jsencrypt/bin/jsencrypt.min' + +// 密钥对生成 http://web.chacuo.net/netrsakeypair + +const publicKey = `MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAM1GfQdZPr/vZbEPP75WyIIPGn8Uoox2 +MQD96nRCbCBwEaM3dp11sY/Ga2bwKiqPOrmNa8xVYsqqD91HY5RrTv0CAwEAAQ==` + +const privateKey = `MIIBVQIBADANBgkqhkiG9w0BAQEFAASCAT8wggE7AgEAAkEAzUZ9B1k+v+9lsQ8/ +vlbIgg8afxSijHYxAP3qdEJsIHARozd2nXWxj8ZrZvAqKo86uY1rzFViyqoP3Udj +lGtO/QIDAQABAkBeAPWos9nkk4ECQHV0eNGBneEIaS63HDj8t0ryyqgxgc51NemU +Nnf3LgZmKi8NOAMGDV1khIoKgkiauetZtOKBAiEA8+btcqtVw0xAKdakh8LVx9p/ +GMEfkIcTqrIZ0ETIFMUCIQDXdRQDp5tfzM4ZREWVt745MQIUhT1ogEicIHofTq4k +2QIgR+XAAzh8jJiSpYKvd5G4oTRImQx8+IbJBl1//IP6Ex0CIQCNXYwcOcSAPuib +O2hMq5pr+/PZcvKvtjvt9IEsOXuZQQIhAIscGt8KDKP3kh/7CmIHgatUCpznQMWU +x435DUicqF75` + +// 加密 +export function encrypt(txt) { + const encryptor = new JSEncrypt() + encryptor.setPublicKey(publicKey) // 设置公钥 + return encryptor.encrypt(txt) // 对数据进行加密 +} + +// 解密 +export function decrypt(txt) { + const encryptor = new JSEncrypt() + encryptor.setPrivateKey(privateKey) // 设置私钥 + return encryptor.decrypt(txt) // 对数据进行解密 +} + diff --git a/admin-ui/src/utils/modules/prototypes.js b/admin-ui/src/utils/modules/prototypes.js new file mode 100644 index 0000000..d580df8 --- /dev/null +++ b/admin-ui/src/utils/modules/prototypes.js @@ -0,0 +1,181 @@ +/** + * 原型扩展库 + */ +export default function() { + + Date.prototype.clone=function(){ + return new Date(this.valueOf()); + } + + + function formatInt(str, split = ',') { + const len = str.length; + return len <= 3 ? str : formatInt(str.slice(0, len - 3),split) + split + str.slice(len - 3, len); + } + + /** + * 使用split分割格式化数字字符 + * @param {*} digits + * @param {*} split + */ + Number.prototype.format = function (digits = 2, split = ',') { + if (isFinite(this)) { + let str = this.toFixed(digits) + if (digits < 1) { + return formatInt(str, split); + } else { + let index = str.indexOf("."); + return formatInt(str.slice(0, index),split) + str.slice(index); + } + } else { + return "-"; + } + } + + /** + * 将日期对象格式化成字符串 + * @param {String} format 格式支持:yyyy-MM-dd HH:mm:ss.S 默认:yyyy-MM-dd + */ + Date.prototype.format = function(format) { + format = format == null ? "yyyy-MM-dd" : format; + let o = { + "M+": this.getMonth() + 1, //month + "d+": this.getDate(), //day + "H+": this.getHours(), //hour + "m+": this.getMinutes(), //minute + "s+": this.getSeconds(), //second + "q+": Math.floor((this.getMonth() + 3) / 3), //quarter + "S": this.getMilliseconds() //millisecond + } + + if (/(y+)/.test(format)) + format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length)); + for (var k in o) + if (new RegExp("(" + k + ")").test(format)) + format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]) + .length)); + return format; + } + + Number.prototype.toDate = function() { + return new Date(this); + } + + Number.prototype.toChina = function() { + let number = this.toString(); + if (number.match(/\D/) || number.length >= 14) { + throw new Error("只能是正整数,且不能超过14位"); + } + let zhArray = ['零', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十']; // 数字对应中文 + let baseArray = ['', '十', '百', '千', '万', '十', '百', '千', '亿', '十', '百', '千', '万']; //进位填充字符,第一位是 个位,可省略 + let string = String(number).split('').reverse().map((item, index) => { // 把数字切割成数组并倒序排列,然后进行遍历转成中文 + // 如果当前位为0,直接输出数字, 否则输出 数字 + 进位填充字符 + item = Number(item) == 0 ? zhArray[Number(item)] : zhArray[Number(item)] + baseArray[index]; + return item; + }).reverse().join(''); // 倒叙回来数组,拼接成字符串 + string = string.replace(/^一十/, '十'); // 如果以 一十 开头,可省略一 + string = string.replace(/零+/, '零'); // 如果有多位相邻的零,只写一个即可 + return string; + } + + String.prototype.cny = function(){ + let n = this; + if (n == 0) { + return "零元整"; + } + if (!/^(\+|-)?(0|[1-9]\d*)(\.\d+)?$/.test(n)) + return "数据非法"; + let unit = "仟佰拾亿仟佰拾万仟佰拾元角分", str = ""; + n += "00"; + let a = parseFloat(n); + if (a < 0) { + n = n.substr(1); + } + let p = n.indexOf('.'); + if (p >= 0) { + n = n.substring(0, p) + n.substr(p + 1, 2); + } + + unit = unit.substr(unit.length - n.length); + + for (var i = 0; i < n.length; i++) + str += '零壹贰叁肆伍陆柒捌玖'.charAt(n.charAt(i)) + unit.charAt(i); + if (a > 0) { + return str.replace(/零(仟|佰|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(万|亿|元)/g, "$1").replace(/(亿)万|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整"); + + } else { + + return "负" + str.replace(/零(仟|佰|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(万|亿|元)/g, "$1").replace(/(亿)万|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整"); + } + + } + /** + * 将字符串格式化成日期对象 + * @param {String} format 格式支持:yyyy-MM-dd HH:mm:ss.S 默认:yyyy-MM-dd + */ + String.prototype.toDate = function(format) { + if (/^\d+$/.test(this)) { + return new Date(Number(this)); + } + format = format == null ? "yyyy-MM-dd" : format; + let d = new Date(0); + d.setMinutes(d.getTimezoneOffset()); + let o = { + "y+": d.setFullYear, //year + "M+": d.setMonth, //month + "d+": d.setDate, //day + "H+": d.setHours, //hour + "m+": d.setMinutes, //minute + "s+": d.setSeconds, //second + "S+": d.setMilliSeconds //millisecond + } + let regx = format + for (let k in o) { + if (new RegExp("(" + k + ")").test(format)) + regx = regx.replace(new RegExp(k), "[0-9]+"); + } + + if (!new RegExp("^" + regx + "$").test(this)) { + throw new Error("日期格式不正确:" + format); + } + + for (var k in o) { + if (new RegExp("(" + k + ")").test(format)) { + regx = format; + for (let temp in o) { + if (temp == k) { + regx = regx.replace(new RegExp(temp), "([0-9]+)"); + } else { + regx = regx.replace(new RegExp(temp), "[0-9]+"); + } + + } + let val = Number(this.replace(new RegExp("^" + regx + "$"), "$1")); + if(k == "M+"){ + --val; + } + Reflect.apply(o[k],d,[val]) + } + } + return d; + } + + String.prototype.toTime = function() { + if(!/^(\d{2,}):(\d{2}):(\d{2})$/.test(this)){ + throw new Error("含时分秒的字符串需符合格式:(\\d{2,}):(\\d{2}):(\\d{2})"); + } + let ts = this.split(":"); + return parseInt(ts[0])*3600+parseInt(ts[1])*60+parseInt(ts[2]); + // return eval(this.replace(/^(\d{2}):(\d{2}):(\d{2})$/, "$1*3600+$2*60+$3")); + } + + Number.prototype.toTime = function() { + let ss = this % 60; + let temp = (this - ss) / 60; + let mm = temp % 60; + let hh = (temp - mm) / 60; + + return `${hh.toString().padStart(2,"0")}:${mm.toString().padStart(2,"0")}:${ss.toString().padStart(2,"0")}` + } + +}; \ No newline at end of file diff --git a/admin-ui/src/utils/modules/timerEvent.js b/admin-ui/src/utils/modules/timerEvent.js new file mode 100644 index 0000000..2f084a6 --- /dev/null +++ b/admin-ui/src/utils/modules/timerEvent.js @@ -0,0 +1,25 @@ +export default function(){} +/** + * 触发周期性事件 + */ +let count = 0; +window.dispatchEvent(new CustomEvent("timer", { bubbles: false, detail: { count: count } })); +window.setInterval(() => { + count++; + if (count > 36000000) { + count = 0; + } + window.dispatchEvent(new CustomEvent("timer", { bubbles: false, detail: { count: count } })); + if(count%5==0){ + window.dispatchEvent(new CustomEvent("timer5",{bubbles: false})); + } + if(count%10==0){ + window.dispatchEvent(new CustomEvent("timer10",{bubbles: false})); + } + if(count%30==0){ + window.dispatchEvent(new CustomEvent("timer30",{bubbles: false})); + } + if(count%60==0){ + window.dispatchEvent(new CustomEvent("timer60",{bubbles: false})); + } +}, 1000); \ No newline at end of file diff --git a/admin-ui/src/utils/permission.js b/admin-ui/src/utils/permission.js new file mode 100644 index 0000000..93fee87 --- /dev/null +++ b/admin-ui/src/utils/permission.js @@ -0,0 +1,51 @@ +import useUserStore from '@/store/modules/user' + +/** + * 字符权限校验 + * @param {Array} value 校验值 + * @returns {Boolean} + */ +export function checkPermi(value) { + if (value && value instanceof Array && value.length > 0) { + const permissions = useUserStore().permissions + const permissionDatas = value + const all_permission = "*:*:*"; + + const hasPermission = permissions.some(permission => { + return all_permission === permission || permissionDatas.includes(permission) + }) + + if (!hasPermission) { + return false + } + return true + } else { + console.error(`need roles! Like checkPermi="['system:user:add','system:user:edit']"`) + return false + } +} + +/** + * 角色权限校验 + * @param {Array} value 校验值 + * @returns {Boolean} + */ +export function checkRole(value) { + if (value && value instanceof Array && value.length > 0) { + const roles = useUserStore().roles + const permissionRoles = value + const super_admin = "admin"; + + const hasRole = roles.some(role => { + return super_admin === role || permissionRoles.includes(role) + }) + + if (!hasRole) { + return false + } + return true + } else { + console.error(`need roles! Like checkRole="['admin','editor']"`) + return false + } +} \ No newline at end of file diff --git a/admin-ui/src/utils/request.js b/admin-ui/src/utils/request.js new file mode 100644 index 0000000..8fc1863 --- /dev/null +++ b/admin-ui/src/utils/request.js @@ -0,0 +1,234 @@ +import axios from 'axios' +import { ElNotification, ElMessageBox, ElMessage, ElLoading } from 'element-plus' +import { getToken } from '@/utils/auth' +import errorCode from '@/utils/errorCode' +import { tansParams, blobValidate } from '@/utils/ruoyi' +import cache from '@/plugins/cache' +import { saveAs } from 'file-saver' +import useUserStore from '@/store/modules/user' + +let downloadLoadingInstance; +// 是否显示重新登录 +export let isRelogin = { show: false }; + +axios.defaults.headers['Content-Type'] = 'application/json;charset=UTF-8' +// 对应国际化资源文件后缀 +axios.defaults.headers['Content-Language'] = 'zh_CN' +// 创建axios实例 +const service = axios.create({ + // axios中请求配置有baseURL选项,表示请求URL公共部分 + baseURL: import.meta.env.VITE_APP_BASE_API, + // 超时 + timeout: 10000, + custom: { + returnData: true + } +}) + +service.HEADER_FORM = 'application/x-www-form-urlencoded' +service.HEADER_UPLOAD = 'multipart/form-data'; +service.HEADER_JSON = 'application/json;charset=UTF-8'; +service.HEADER_TEXT = 'text/plain;charset=UTF-8'; + + +// request拦截器 +service.interceptors.request.use(config => { + // 是否需要设置 token + const isToken = (config.headers || {}).isToken === false + // 是否需要防止数据重复提交 + const isRepeatSubmit = (config.headers || {}).repeatSubmit === false + if (getToken() && !isToken) { + config.headers['Authorization'] = 'Bearer ' + getToken() // 让每个请求携带自定义token 请根据实际情况自行修改 + } + // get请求映射params参数 + if (config.method === 'get' && config.params) { + let url = config.url + '?' + tansParams(config.params); + url = url.slice(0, -1); + config.params = {}; + config.url = url; + } + if (config.data && (config.method === 'post' || config.method === 'put')) { + if (config.data.constructor == URLSearchParams) { + config.headers['Content-Type'] = service.HEADER_FORM + } else if (config.data.constructor == FormData) { + config.headers['Content-Type'] = service.HEADER_UPLOAD + } + } + if (!isRepeatSubmit && (config.method === 'post' || config.method === 'put')) { + const requestObj = { + url: config.url, + data: typeof config.data === 'object' ? JSON.stringify(config.data) : config.data, + time: new Date().getTime() + } + const sessionObj = cache.session.getJSON('sessionObj') + if (sessionObj === undefined || sessionObj === null || sessionObj === '') { + cache.session.setJSON('sessionObj', requestObj) + } else { + const s_url = sessionObj.url; // 请求地址 + const s_data = sessionObj.data; // 请求数据 + const s_time = sessionObj.time; // 请求时间 + const interval = 1000; // 间隔时间(ms),小于此时间视为重复提交 + if (s_data === requestObj.data && requestObj.time - s_time < interval && s_url === requestObj.url) { + const message = '数据正在处理,请勿重复提交'; + console.warn(`[${s_url}]: ` + message) + return Promise.reject(new Error(message)) + } else { + cache.session.setJSON('sessionObj', requestObj) + } + } + } + return config +}, error => { + console.log(error) + Promise.reject(error) +}) + +// 响应拦截器 +service.interceptors.response.use(res => { + // 未设置状态码则默认成功状态 + const code = res.data.code || 200; + // 获取错误信息 + const msg = errorCode[code] || res.data.msg || errorCode['default'] + // 二进制数据则直接返回 + if (res.request.responseType === 'blob' || res.request.responseType === 'arraybuffer') { + if (res.config.custom.returnData) { + return res.data; + } else { + return res; + } + + } + if (code === 401) { + if (!isRelogin.show) { + isRelogin.show = true; + ElMessageBox.confirm('登录状态已过期,您可以继续留在该页面,或者重新登录', '系统提示', { confirmButtonText: '重新登录', cancelButtonText: '取消', type: 'warning' }).then(() => { + isRelogin.show = false; + useUserStore().logOut().then(() => { + location.href = import.meta.env.VITE_APP_CONTEXT_PATH; + }) + }).catch(() => { + isRelogin.show = false; + }); + } + return Promise.reject('无效的会话,或者会话已过期,请重新登录。') + } else if (code === 500) { + ElMessage({ message: msg, type: 'error' }) + return Promise.reject(new Error(msg)) + } else if (code === 601) { + ElMessage({ message: msg, type: 'warning' }) + return Promise.reject(new Error(msg)) + } else if (code !== 200) { + ElNotification.error({ title: msg }) + return Promise.reject('error') + } else { + if (res.config.custom.returnData) { + return Promise.resolve(res.data) + } else { + return Promise.resolve(res) + } + + } +}, + error => { + console.log('err' + error) + let { message } = error; + if (message == "Network Error") { + message = "后端接口连接异常"; + } else if (message.includes("timeout")) { + message = "系统接口请求超时"; + } else if (message.includes("Request failed with status code")) { + message = "系统接口" + message.substr(message.length - 3) + "异常"; + } + ElMessage({ message: message, type: 'error', duration: 5 * 1000 }) + return Promise.reject(error) + } +) + +// 通用下载方法 +export function download(url, params, filename, config) { + downloadLoadingInstance = ElLoading.service({ text: "正在下载数据,请稍候", background: "rgba(0, 0, 0, 0.7)", }) + return service.post(url, params, { + transformRequest: [(params) => { return tansParams(params) }], + headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, + responseType: 'blob', + ...config + }).then(async (data) => { + const isBlob = blobValidate(data); + if (isBlob) { + const blob = new Blob([data]) + saveAs(blob, filename) + } else { + const resText = await data.text(); + const rspObj = JSON.parse(resText); + const errMsg = errorCode[rspObj.code] || rspObj.msg || errorCode['default'] + ElMessage.error(errMsg); + } + downloadLoadingInstance.close(); + }).catch((r) => { + console.error(r) + ElMessage.error('下载文件出现错误,请联系管理员!') + downloadLoadingInstance.close(); + }) +} + + + +/** +* 格式化参数成URLSearchParams +* @param {String|Array|Object|HTMLFormElement|FormData|URLSearchParams} param +* @return {URLSearchParams} +*/ +service.params = function (param) { + if (param == null || param == "") { + return new URLSearchParams(); + } + if (param.constructor == Array) { + let param1 = new URLSearchParams(); + for (let obj of param) { + param1.append(obj.name, obj.value); + } + param = param1; + } else if (param.constructor == Object) { + let param1 = new URLSearchParams(); + for (let name in param) { + param1.append(name, param[name]); + } + param = param1; + } else { + if (param.constructor == HTMLFormElement) { + param = new FormData(param); + } + if (param.constructor == FormData || param.constructor == String) { + param = new URLSearchParams(param); + } + } + + return param; +} + +service.formData = function (param) { + if (param == null || param == "") { + return new FormData(); + } + if (param.constructor == Array) { + let param1 = new FormData(); + for (let obj of param) { + param1.append(obj.name, obj.value); + } + return param1; + } + if (param.constructor == Object) { + let param1 = new FormData(); + for (let name in param) { + param1.append(name, param[name]); + } + return param1; + } + + if (param.constructor == HTMLFormElement) { + return new FormData(param); + } + return new FormData(); +} + +export default service diff --git a/admin-ui/src/utils/ruoyi.js b/admin-ui/src/utils/ruoyi.js new file mode 100644 index 0000000..4efca08 --- /dev/null +++ b/admin-ui/src/utils/ruoyi.js @@ -0,0 +1,246 @@ + + +/** + * 通用js方法封装处理 + * Copyright (c) 2019 ruoyi + */ + +// 日期格式化 +export function parseTime(time, pattern) { + if (arguments.length === 0 || !time) { + return null + } + const format = pattern || '{y}-{m}-{d} {h}:{i}:{s}' + let date + if (typeof time === 'object') { + date = time + } else { + if ((typeof time === 'string') && (/^[0-9]+$/.test(time))) { + time = parseInt(time) + } else if (typeof time === 'string') { + time = time.replace(new RegExp(/-/gm), '/').replace('T', ' ').replace(new RegExp(/\.[\d]{3}/gm), ''); + } + if ((typeof time === 'number') && (time.toString().length === 10)) { + time = time * 1000 + } + date = new Date(time) + } + const formatObj = { + y: date.getFullYear(), + m: date.getMonth() + 1, + d: date.getDate(), + h: date.getHours(), + i: date.getMinutes(), + s: date.getSeconds(), + a: date.getDay() + } + const time_str = format.replace(/{(y|m|d|h|i|s|a)+}/g, (result, key) => { + let value = formatObj[key] + // Note: getDay() returns 0 on Sunday + if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value] } + if (result.length > 0 && value < 10) { + value = '0' + value + } + return value || 0 + }) + return time_str +} + +// 表单重置 +export function resetForm(refName) { + if (this.$refs[refName]) { + this.$refs[refName].resetFields(); + } +} + +// 添加日期范围 +export function addDateRange(params, dateRange, propName) { + let search = params; + search.params = typeof (search.params) === 'object' && search.params !== null && !Array.isArray(search.params) ? search.params : {}; + dateRange = Array.isArray(dateRange) ? dateRange : []; + if (typeof (propName) === 'undefined') { + search.params['beginTime'] = dateRange[0]; + search.params['endTime'] = dateRange[1]; + } else { + search.params['begin' + propName] = dateRange[0]; + search.params['end' + propName] = dateRange[1]; + } + return search; +} + +// 回显数据字典 +export function selectDictLabel(datas, value) { + if (value === undefined) { + return ""; + } + var actions = []; + Object.keys(datas).some((key) => { + if (datas[key].value == ('' + value)) { + actions.push(datas[key].label); + return true; + } + }) + if (actions.length === 0) { + actions.push(value); + } + return actions.join(''); +} + +// 回显数据字典(字符串数组) +export function selectDictLabels(datas, value, separator) { + if (value === undefined || value.length ===0) { + return ""; + } + if (Array.isArray(value)) { + value = value.join(","); + } + var actions = []; + var currentSeparator = undefined === separator ? "," : separator; + var temp = value.split(currentSeparator); + Object.keys(value.split(currentSeparator)).some((val) => { + var match = false; + Object.keys(datas).some((key) => { + if (datas[key].value == ('' + temp[val])) { + actions.push(datas[key].label + currentSeparator); + match = true; + } + }) + if (!match) { + actions.push(temp[val] + currentSeparator); + } + }) + return actions.join('').substring(0, actions.join('').length - 1); +} + +// 字符串格式化(%s ) +export function sprintf(str) { + var args = arguments, flag = true, i = 1; + str = str.replace(/%s/g, function () { + var arg = args[i++]; + if (typeof arg === 'undefined') { + flag = false; + return ''; + } + return arg; + }); + return flag ? str : ''; +} + +// 转换字符串,undefined,null等转化为"" +export function parseStrEmpty(str) { + if (!str || str == "undefined" || str == "null") { + return ""; + } + return str; +} + +// 数据合并 +export function mergeRecursive(source, target) { + for (var p in target) { + try { + if (target[p].constructor == Object) { + source[p] = mergeRecursive(source[p], target[p]); + } else { + source[p] = target[p]; + } + } catch (e) { + source[p] = target[p]; + } + } + return source; +}; + +/** + * 构造树型结构数据 + * @param {*} data 数据源 + * @param {*} id id字段 默认 'id' + * @param {*} parentId 父节点字段 默认 'parentId' + * @param {*} children 孩子节点字段 默认 'children' + */ +export function handleTree(data, id, parentId, children) { + let config = { + id: id || 'id', + parentId: parentId || 'parentId', + childrenList: children || 'children' + }; + + var childrenListMap = {}; + var nodeIds = {}; + var tree = []; + + for (let d of data) { + let parentId = d[config.parentId]; + if (childrenListMap[parentId] == null) { + childrenListMap[parentId] = []; + } + nodeIds[d[config.id]] = d; + childrenListMap[parentId].push(d); + } + + for (let d of data) { + let parentId = d[config.parentId]; + if (nodeIds[parentId] == null) { + tree.push(d); + } + } + + for (let t of tree) { + adaptToChildrenList(t); + } + + function adaptToChildrenList(o) { + if (childrenListMap[o[config.id]] !== null) { + o[config.childrenList] = childrenListMap[o[config.id]]; + } + if (o[config.childrenList]) { + for (let c of o[config.childrenList]) { + adaptToChildrenList(c); + } + } + } + return tree; +} + +/** +* 参数处理 +* @param {*} params 参数 +*/ +export function tansParams(params) { + let result = '' + for (const propName of Object.keys(params)) { + const value = params[propName]; + var part = encodeURIComponent(propName) + "="; + if (value !== null && value !== "" && typeof (value) !== "undefined") { + if (typeof value === 'object') { + for (const key of Object.keys(value)) { + if (value[key] !== null && value[key] !== "" && typeof (value[key]) !== 'undefined') { + let params = propName + '[' + key + ']'; + var subPart = encodeURIComponent(params) + "="; + result += subPart + encodeURIComponent(value[key]) + "&"; + } + } + } else { + result += part + encodeURIComponent(value) + "&"; + } + } + } + return result +} + + +// 返回项目路径 +export function getNormalPath(p) { + if (p.length === 0 || !p || p == 'undefined') { + return p + }; + let res = p.replace('//', '/') + if (res[res.length - 1] === '/') { + return res.slice(0, res.length - 1) + } + return res; +} + +// 验证是否为blob格式 +export function blobValidate(data) { + return data.type !== 'application/json' +} diff --git a/admin-ui/src/utils/scroll-to.js b/admin-ui/src/utils/scroll-to.js new file mode 100644 index 0000000..c5d8e04 --- /dev/null +++ b/admin-ui/src/utils/scroll-to.js @@ -0,0 +1,58 @@ +Math.easeInOutQuad = function(t, b, c, d) { + t /= d / 2 + if (t < 1) { + return c / 2 * t * t + b + } + t-- + return -c / 2 * (t * (t - 2) - 1) + b +} + +// requestAnimationFrame for Smart Animating http://goo.gl/sx5sts +var requestAnimFrame = (function() { + return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || function(callback) { window.setTimeout(callback, 1000 / 60) } +})() + +/** + * Because it's so fucking difficult to detect the scrolling element, just move them all + * @param {number} amount + */ +function move(amount) { + document.documentElement.scrollTop = amount + document.body.parentNode.scrollTop = amount + document.body.scrollTop = amount +} + +function position() { + return document.documentElement.scrollTop || document.body.parentNode.scrollTop || document.body.scrollTop +} + +/** + * @param {number} to + * @param {number} duration + * @param {Function} callback + */ +export function scrollTo(to, duration, callback) { + const start = position() + const change = to - start + const increment = 20 + let currentTime = 0 + duration = (typeof (duration) === 'undefined') ? 500 : duration + var animateScroll = function() { + // increment the time + currentTime += increment + // find the value with the quadratic in-out easing function + var val = Math.easeInOutQuad(currentTime, start, change, duration) + // move the document.body + move(val) + // do the animation unless its over + if (currentTime < duration) { + requestAnimFrame(animateScroll) + } else { + if (callback && typeof (callback) === 'function') { + // the animation is done so lets callback + callback() + } + } + } + animateScroll() +} diff --git a/admin-ui/src/utils/theme.js b/admin-ui/src/utils/theme.js new file mode 100644 index 0000000..f4badc6 --- /dev/null +++ b/admin-ui/src/utils/theme.js @@ -0,0 +1,49 @@ +// 处理主题样式 +export function handleThemeStyle(theme) { + document.documentElement.style.setProperty('--el-color-primary', theme) + for (let i = 1; i <= 9; i++) { + document.documentElement.style.setProperty(`--el-color-primary-light-${i}`, `${getLightColor(theme, i / 10)}`) + } + for (let i = 1; i <= 9; i++) { + document.documentElement.style.setProperty(`--el-color-primary-dark-${i}`, `${getDarkColor(theme, i / 10)}`) + } +} + +// hex颜色转rgb颜色 +export function hexToRgb(str) { + str = str.replace('#', '') + let hexs = str.match(/../g) + for (let i = 0; i < 3; i++) { + hexs[i] = parseInt(hexs[i], 16) + } + return hexs +} + +// rgb颜色转Hex颜色 +export function rgbToHex(r, g, b) { + let hexs = [r.toString(16), g.toString(16), b.toString(16)] + for (let i = 0; i < 3; i++) { + if (hexs[i].length == 1) { + hexs[i] = `0${hexs[i]}` + } + } + return `#${hexs.join('')}` +} + +// 变浅颜色值 +export function getLightColor(color, level) { + let rgb = hexToRgb(color) + for (let i = 0; i < 3; i++) { + rgb[i] = Math.floor((255 - rgb[i]) * level + rgb[i]) + } + return rgbToHex(rgb[0], rgb[1], rgb[2]) +} + +// 变深颜色值 +export function getDarkColor(color, level) { + let rgb = hexToRgb(color) + for (let i = 0; i < 3; i++) { + rgb[i] = Math.floor(rgb[i] * (1 - level)) + } + return rgbToHex(rgb[0], rgb[1], rgb[2]) +} diff --git a/admin-ui/src/utils/validate.js b/admin-ui/src/utils/validate.js new file mode 100644 index 0000000..702add4 --- /dev/null +++ b/admin-ui/src/utils/validate.js @@ -0,0 +1,93 @@ +/** + * 判断url是否是http或https + * @param {string} path + * @returns {Boolean} + */ + export function isHttp(url) { + return url.indexOf('http://') !== -1 || url.indexOf('https://') !== -1 +} + +/** + * 判断path是否为外链 + * @param {string} path + * @returns {Boolean} + */ + export function isExternal(path) { + return /^(https?:|mailto:|tel:)/.test(path) +} + +/** + * @param {string} str + * @returns {Boolean} + */ +export function validUsername(str) { + const valid_map = ['admin', 'editor'] + return valid_map.indexOf(str.trim()) >= 0 +} + +/** + * @param {string} url + * @returns {Boolean} + */ +export function validURL(url) { + const reg = /^(https?|ftp):\/\/([a-zA-Z0-9.-]+(:[a-zA-Z0-9.&%$-]+)*@)*((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9][0-9]?)(\.(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])){3}|([a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]+\.(com|edu|gov|int|mil|net|org|biz|arpa|info|name|pro|aero|coop|museum|[a-zA-Z]{2}))(:[0-9]+)*(\/($|[a-zA-Z0-9.,?'\\+&%$#=~_-]+))*$/ + return reg.test(url) +} + +/** + * @param {string} str + * @returns {Boolean} + */ +export function validLowerCase(str) { + const reg = /^[a-z]+$/ + return reg.test(str) +} + +/** + * @param {string} str + * @returns {Boolean} + */ +export function validUpperCase(str) { + const reg = /^[A-Z]+$/ + return reg.test(str) +} + +/** + * @param {string} str + * @returns {Boolean} + */ +export function validAlphabets(str) { + const reg = /^[A-Za-z]+$/ + return reg.test(str) +} + +/** + * @param {string} email + * @returns {Boolean} + */ +export function validEmail(email) { + const reg = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/ + return reg.test(email) +} + +/** + * @param {string} str + * @returns {Boolean} + */ +export function isString(str) { + if (typeof str === 'string' || str instanceof String) { + return true + } + return false +} + +/** + * @param {Array} arg + * @returns {Boolean} + */ +export function isArray(arg) { + if (typeof Array.isArray === 'undefined') { + return Object.prototype.toString.call(arg) === '[object Array]' + } + return Array.isArray(arg) +} diff --git a/admin-ui/src/views/WTemplate.vue b/admin-ui/src/views/WTemplate.vue new file mode 100644 index 0000000..b67dd7f --- /dev/null +++ b/admin-ui/src/views/WTemplate.vue @@ -0,0 +1,10 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/views/demo/demo/index.vue b/admin-ui/src/views/demo/demo/index.vue new file mode 100644 index 0000000..ef37f76 --- /dev/null +++ b/admin-ui/src/views/demo/demo/index.vue @@ -0,0 +1,404 @@ + + + diff --git a/admin-ui/src/views/demo/tree/index.vue b/admin-ui/src/views/demo/tree/index.vue new file mode 100644 index 0000000..4fa8ffd --- /dev/null +++ b/admin-ui/src/views/demo/tree/index.vue @@ -0,0 +1,281 @@ + + + diff --git a/admin-ui/src/views/error/401.vue b/admin-ui/src/views/error/401.vue new file mode 100644 index 0000000..1ba3792 --- /dev/null +++ b/admin-ui/src/views/error/401.vue @@ -0,0 +1,82 @@ + + + + + diff --git a/admin-ui/src/views/error/404.vue b/admin-ui/src/views/error/404.vue new file mode 100644 index 0000000..f205303 --- /dev/null +++ b/admin-ui/src/views/error/404.vue @@ -0,0 +1,227 @@ + + + + + diff --git a/admin-ui/src/views/index.vue b/admin-ui/src/views/index.vue new file mode 100644 index 0000000..b6a5d4e --- /dev/null +++ b/admin-ui/src/views/index.vue @@ -0,0 +1,185 @@ + + + + + + diff --git a/admin-ui/src/views/index/WCount2.vue b/admin-ui/src/views/index/WCount2.vue new file mode 100644 index 0000000..4a27573 --- /dev/null +++ b/admin-ui/src/views/index/WCount2.vue @@ -0,0 +1,58 @@ + + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/index/WCount3.vue b/admin-ui/src/views/index/WCount3.vue new file mode 100644 index 0000000..d3194b2 --- /dev/null +++ b/admin-ui/src/views/index/WCount3.vue @@ -0,0 +1,61 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/index/WNoticeList.vue b/admin-ui/src/views/index/WNoticeList.vue new file mode 100644 index 0000000..645c587 --- /dev/null +++ b/admin-ui/src/views/index/WNoticeList.vue @@ -0,0 +1,96 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/index/count2.js b/admin-ui/src/views/index/count2.js new file mode 100644 index 0000000..2484f95 --- /dev/null +++ b/admin-ui/src/views/index/count2.js @@ -0,0 +1,82 @@ +import * as echarts from 'echarts'; +// import {remoteCount2} from '@/api/estate/customer'; + + +let option = { + color:["#3d7bbf"], + grid: { + left: '10px', + right: '10px', + bottom: '10px', + top: '25px', + containLabel: true + }, + xAxis: { + type: 'category', + data: [] + }, + yAxis: { + type: 'value' + }, + series: [ + { + data: [], + type: 'bar', + label: { + show: true, + position: 'top' + } + } + ] +}; + + + +let chart = null; + +let resetOption = JSON.stringify(option); + +/** + * echart 初始化 + * @param {*} data + * @param {*} ele + */ +export const chartInit = async (ele) => { + chart = echarts.init(ele); + chart.setOption(option); + return Promise.resolve(chart); +} + + + + +let map = new Map(); +/** + * echart发生改变 + * @param {*} arg - 数据 + */ +export const chartChange = async (num) => { + + option = JSON.parse(resetOption); + + let names = []; + let vs = []; + let d = new Date(); + for(let i = 0 ;i < num;i++){ + names.unshift(d.format("MM月")); + d.setMonth(d.getMonth()-1); + vs.unshift(0); + } + + // let r = await remoteCount2({num}); + + // for(let item of r.data){ + // vs[item.i]=item.value; + // } + + option.xAxis.data=names; + option.series[0].data=vs; + + chart.setOption(option); + +} \ No newline at end of file diff --git a/admin-ui/src/views/index/count3.js b/admin-ui/src/views/index/count3.js new file mode 100644 index 0000000..5ad5c75 --- /dev/null +++ b/admin-ui/src/views/index/count3.js @@ -0,0 +1,83 @@ +import * as echarts from 'echarts'; +// import {remoteCount3} from '@/api/estate/customer'; + + +let option = { + color:["#d44d4d"], + grid: { + left: '10px', + right: '10px', + bottom: '10px', + top: '25px', + containLabel: true + }, + xAxis: { + type: 'category', + data: [] + }, + yAxis: { + type: 'value' + }, + series: [ + { + data: [], + type: 'line', + smooth:true, + label: { + show: true, + position: 'top' + } + } + ] +}; + + + +let chart = null; + +let resetOption = JSON.stringify(option); + +/** + * echart 初始化 + * @param {*} data + * @param {*} ele + */ +export const chartInit = async (ele) => { + chart = echarts.init(ele); + chart.setOption(option); + return Promise.resolve(chart); +} + + + + +let map = new Map(); +/** + * echart发生改变 + * @param {*} arg - 数据 + */ +export const chartChange = async (num) => { + + option = JSON.parse(resetOption); + + let names = []; + let vs = []; + let d = new Date(); + for(let i = 0 ;i < num;i++){ + names.unshift(d.format("MM月")); + d.setMonth(d.getMonth()-1); + vs.unshift(0); + } + + // let r = await remoteCount3({num}); + + // for(let item of r.data){ + // vs[item.i]=item.value; + // } + + option.xAxis.data=names; + option.series[0].data=vs; + + chart.setOption(option); + +} \ No newline at end of file diff --git a/admin-ui/src/views/login.vue b/admin-ui/src/views/login.vue new file mode 100644 index 0000000..5915e22 --- /dev/null +++ b/admin-ui/src/views/login.vue @@ -0,0 +1,139 @@ + + + diff --git a/admin-ui/src/views/monitor/admin/index.vue b/admin-ui/src/views/monitor/admin/index.vue new file mode 100644 index 0000000..1b13d64 --- /dev/null +++ b/admin-ui/src/views/monitor/admin/index.vue @@ -0,0 +1,13 @@ + + + diff --git a/admin-ui/src/views/monitor/cache/index.vue b/admin-ui/src/views/monitor/cache/index.vue new file mode 100644 index 0000000..b3fadf7 --- /dev/null +++ b/admin-ui/src/views/monitor/cache/index.vue @@ -0,0 +1,129 @@ + + + diff --git a/admin-ui/src/views/monitor/cache/list.vue b/admin-ui/src/views/monitor/cache/list.vue new file mode 100644 index 0000000..c2a4db4 --- /dev/null +++ b/admin-ui/src/views/monitor/cache/list.vue @@ -0,0 +1,246 @@ + + + diff --git a/admin-ui/src/views/monitor/logininfor/index.vue b/admin-ui/src/views/monitor/logininfor/index.vue new file mode 100644 index 0000000..bd58a5d --- /dev/null +++ b/admin-ui/src/views/monitor/logininfor/index.vue @@ -0,0 +1,225 @@ + + + diff --git a/admin-ui/src/views/monitor/online/index.vue b/admin-ui/src/views/monitor/online/index.vue new file mode 100644 index 0000000..eb17ebc --- /dev/null +++ b/admin-ui/src/views/monitor/online/index.vue @@ -0,0 +1,106 @@ + + + diff --git a/admin-ui/src/views/monitor/operlog/index.vue b/admin-ui/src/views/monitor/operlog/index.vue new file mode 100644 index 0000000..d1760f8 --- /dev/null +++ b/admin-ui/src/views/monitor/operlog/index.vue @@ -0,0 +1,291 @@ + + + diff --git a/admin-ui/src/views/monitor/xxljob/index.vue b/admin-ui/src/views/monitor/xxljob/index.vue new file mode 100644 index 0000000..9a73f52 --- /dev/null +++ b/admin-ui/src/views/monitor/xxljob/index.vue @@ -0,0 +1,13 @@ + + + diff --git a/admin-ui/src/views/redirect/index.vue b/admin-ui/src/views/redirect/index.vue new file mode 100644 index 0000000..a469960 --- /dev/null +++ b/admin-ui/src/views/redirect/index.vue @@ -0,0 +1,14 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/views/register.vue b/admin-ui/src/views/register.vue new file mode 100644 index 0000000..89bb530 --- /dev/null +++ b/admin-ui/src/views/register.vue @@ -0,0 +1,219 @@ + + + + + diff --git a/admin-ui/src/views/system/config/index.vue b/admin-ui/src/views/system/config/index.vue new file mode 100644 index 0000000..ef1d5ef --- /dev/null +++ b/admin-ui/src/views/system/config/index.vue @@ -0,0 +1,306 @@ + + + diff --git a/admin-ui/src/views/system/cron/components/WCronAdd.vue b/admin-ui/src/views/system/cron/components/WCronAdd.vue new file mode 100644 index 0000000..c9b0539 --- /dev/null +++ b/admin-ui/src/views/system/cron/components/WCronAdd.vue @@ -0,0 +1,67 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/cron/components/WCronEdit.vue b/admin-ui/src/views/system/cron/components/WCronEdit.vue new file mode 100644 index 0000000..185c5be --- /dev/null +++ b/admin-ui/src/views/system/cron/components/WCronEdit.vue @@ -0,0 +1,67 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/cron/components/WCronList.vue b/admin-ui/src/views/system/cron/components/WCronList.vue new file mode 100644 index 0000000..03a0660 --- /dev/null +++ b/admin-ui/src/views/system/cron/components/WCronList.vue @@ -0,0 +1,166 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/cron/components/WCronRun.vue b/admin-ui/src/views/system/cron/components/WCronRun.vue new file mode 100644 index 0000000..48b00ee --- /dev/null +++ b/admin-ui/src/views/system/cron/components/WCronRun.vue @@ -0,0 +1,56 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/cron/cron.js b/admin-ui/src/views/system/cron/cron.js new file mode 100644 index 0000000..bc0fa7a --- /dev/null +++ b/admin-ui/src/views/system/cron/cron.js @@ -0,0 +1,20 @@ +import request from '@/utils/request' + +const base = '/system/cron/' + + +export const add = (data) => request.post(base, data) + +export const update = (data) => request.put(base, data) + +export const list = (group = 0) => request.get(base + 'list-' + group) + +export const remove = (ids) => request.delete(base + ids) + +export const page = (params) => request.get(base + 'page', { params }) + +export const logPage = (params) => request.get(base + 'log-page', { params }) + +export const current = (group = 0) => request.get(base + 'current-' + group) + +export const start = (cronId, taskId, paramEls) => request.post(base + "/start", request.params({ cronId, taskId, paramEls })) \ No newline at end of file diff --git a/admin-ui/src/views/system/cron/index.vue b/admin-ui/src/views/system/cron/index.vue new file mode 100644 index 0000000..6c01d78 --- /dev/null +++ b/admin-ui/src/views/system/cron/index.vue @@ -0,0 +1,230 @@ + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/dept/index.vue b/admin-ui/src/views/system/dept/index.vue new file mode 100644 index 0000000..3afac89 --- /dev/null +++ b/admin-ui/src/views/system/dept/index.vue @@ -0,0 +1,278 @@ + + + diff --git a/admin-ui/src/views/system/dict/data.vue b/admin-ui/src/views/system/dict/data.vue new file mode 100644 index 0000000..2d68e57 --- /dev/null +++ b/admin-ui/src/views/system/dict/data.vue @@ -0,0 +1,350 @@ + + + diff --git a/admin-ui/src/views/system/dict/index.vue b/admin-ui/src/views/system/dict/index.vue new file mode 100644 index 0000000..dec505a --- /dev/null +++ b/admin-ui/src/views/system/dict/index.vue @@ -0,0 +1,313 @@ + + + diff --git a/admin-ui/src/views/system/links/components/WAdd.vue b/admin-ui/src/views/system/links/components/WAdd.vue new file mode 100644 index 0000000..0441194 --- /dev/null +++ b/admin-ui/src/views/system/links/components/WAdd.vue @@ -0,0 +1,101 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/links/components/WEdit.vue b/admin-ui/src/views/system/links/components/WEdit.vue new file mode 100644 index 0000000..d50d79c --- /dev/null +++ b/admin-ui/src/views/system/links/components/WEdit.vue @@ -0,0 +1,116 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/links/index.vue b/admin-ui/src/views/system/links/index.vue new file mode 100644 index 0000000..5fba53a --- /dev/null +++ b/admin-ui/src/views/system/links/index.vue @@ -0,0 +1,128 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/menu/index.vue b/admin-ui/src/views/system/menu/index.vue new file mode 100644 index 0000000..1ef3d38 --- /dev/null +++ b/admin-ui/src/views/system/menu/index.vue @@ -0,0 +1,441 @@ + + + diff --git a/admin-ui/src/views/system/notice/index.vue b/admin-ui/src/views/system/notice/index.vue new file mode 100644 index 0000000..3d6931b --- /dev/null +++ b/admin-ui/src/views/system/notice/index.vue @@ -0,0 +1,283 @@ + + + diff --git a/admin-ui/src/views/system/oss/config.vue b/admin-ui/src/views/system/oss/config.vue new file mode 100644 index 0000000..4f2efa1 --- /dev/null +++ b/admin-ui/src/views/system/oss/config.vue @@ -0,0 +1,382 @@ + + + diff --git a/admin-ui/src/views/system/oss/index.vue b/admin-ui/src/views/system/oss/index.vue new file mode 100644 index 0000000..27e0632 --- /dev/null +++ b/admin-ui/src/views/system/oss/index.vue @@ -0,0 +1,374 @@ + + + diff --git a/admin-ui/src/views/system/post/index.vue b/admin-ui/src/views/system/post/index.vue new file mode 100644 index 0000000..fbc92b3 --- /dev/null +++ b/admin-ui/src/views/system/post/index.vue @@ -0,0 +1,277 @@ + + + diff --git a/admin-ui/src/views/system/role/authUser.vue b/admin-ui/src/views/system/role/authUser.vue new file mode 100644 index 0000000..66b5f5e --- /dev/null +++ b/admin-ui/src/views/system/role/authUser.vue @@ -0,0 +1,172 @@ + + + + diff --git a/admin-ui/src/views/system/role/index.vue b/admin-ui/src/views/system/role/index.vue new file mode 100644 index 0000000..9050599 --- /dev/null +++ b/admin-ui/src/views/system/role/index.vue @@ -0,0 +1,560 @@ + + + diff --git a/admin-ui/src/views/system/role/selectUser.vue b/admin-ui/src/views/system/role/selectUser.vue new file mode 100644 index 0000000..9be1ec9 --- /dev/null +++ b/admin-ui/src/views/system/role/selectUser.vue @@ -0,0 +1,140 @@ + + + diff --git a/admin-ui/src/views/system/user/authRole.vue b/admin-ui/src/views/system/user/authRole.vue new file mode 100644 index 0000000..a689932 --- /dev/null +++ b/admin-ui/src/views/system/user/authRole.vue @@ -0,0 +1,112 @@ + + + diff --git a/admin-ui/src/views/system/user/index.vue b/admin-ui/src/views/system/user/index.vue new file mode 100644 index 0000000..dabad64 --- /dev/null +++ b/admin-ui/src/views/system/user/index.vue @@ -0,0 +1,658 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/user/profile/index.vue b/admin-ui/src/views/system/user/profile/index.vue new file mode 100644 index 0000000..09e4c32 --- /dev/null +++ b/admin-ui/src/views/system/user/profile/index.vue @@ -0,0 +1,87 @@ + + + diff --git a/admin-ui/src/views/system/user/profile/resetPwd.vue b/admin-ui/src/views/system/user/profile/resetPwd.vue new file mode 100644 index 0000000..dec2d79 --- /dev/null +++ b/admin-ui/src/views/system/user/profile/resetPwd.vue @@ -0,0 +1,57 @@ + + + diff --git a/admin-ui/src/views/system/user/profile/userAvatar.vue b/admin-ui/src/views/system/user/profile/userAvatar.vue new file mode 100644 index 0000000..f1ee18b --- /dev/null +++ b/admin-ui/src/views/system/user/profile/userAvatar.vue @@ -0,0 +1,171 @@ + + + + + \ No newline at end of file diff --git a/admin-ui/src/views/system/user/profile/userInfo.vue b/admin-ui/src/views/system/user/profile/userInfo.vue new file mode 100644 index 0000000..2d62c84 --- /dev/null +++ b/admin-ui/src/views/system/user/profile/userInfo.vue @@ -0,0 +1,56 @@ + + + diff --git a/admin-ui/vite.config.js b/admin-ui/vite.config.js new file mode 100644 index 0000000..fc44d3a --- /dev/null +++ b/admin-ui/vite.config.js @@ -0,0 +1,66 @@ +import { defineConfig, loadEnv } from 'vite' +import path from 'path' +import createVitePlugins from './vite/plugins' + +// https://vitejs.dev/config/ +export default defineConfig(({ mode, command }) => { + const env = loadEnv(mode, process.cwd()) + return { + // 部署生产环境和开发环境下的URL。 + // 默认情况下,vite 会假设你的应用是被部署在一个域名的根路径上 + // 例如 https://www.ruoyi.vip/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.ruoyi.vip/admin/,则设置 baseUrl 为 /admin/。 + base: env.VITE_APP_CONTEXT_PATH, + plugins: createVitePlugins(env, command === 'build'), + resolve: { + // https://cn.vitejs.dev/config/#resolve-alias + alias: { + // 设置路径 + '~': path.resolve(__dirname, './'), + // 设置别名 + '@': path.resolve(__dirname, './src') + }, + // https://cn.vitejs.dev/config/#resolve-extensions + extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue'] + }, + // vite 相关配置 + server: { + hmr: true, + port: 80, + host: true, + open: true, + proxy: { + // https://cn.vitejs.dev/config/#server-proxy + '/dev-api': { + target: 'http://127.0.0.1:8080', + changeOrigin: true, + rewrite: (p) => p.replace(/^\/dev-api/, '') + }, + '/upload': { + target: 'http://127.0.0.1:8080', + changeOrigin: true + }, + '/files': { + target: 'http://192.168.3.205:9000', + changeOrigin: true + } + } + }, + //fix:error:stdin>:7356:1: warning: "@charset" must be the first rule in the file + css: { + postcss: { + plugins: [ + { + postcssPlugin: 'internal:charset-removal', + AtRule: { + charset: (atRule) => { + if (atRule.name === 'charset') { + atRule.remove(); + } + } + } + } + ] + } + } + } +}) diff --git a/admin-ui/vite/plugins/auto-import.js b/admin-ui/vite/plugins/auto-import.js new file mode 100644 index 0000000..a5d3576 --- /dev/null +++ b/admin-ui/vite/plugins/auto-import.js @@ -0,0 +1,12 @@ +import autoImport from 'unplugin-auto-import/vite' + +export default function createAutoImport() { + return autoImport({ + imports: [ + 'vue', + 'vue-router', + 'pinia' + ], + dts: false + }) +} diff --git a/admin-ui/vite/plugins/compression.js b/admin-ui/vite/plugins/compression.js new file mode 100644 index 0000000..e90aaec --- /dev/null +++ b/admin-ui/vite/plugins/compression.js @@ -0,0 +1,28 @@ +import compression from 'vite-plugin-compression' + +export default function createCompression(env) { + const { VITE_BUILD_COMPRESS } = env + const plugin = [] + if (VITE_BUILD_COMPRESS) { + const compressList = VITE_BUILD_COMPRESS.split(',') + if (compressList.includes('gzip')) { + // http://doc.ruoyi.vip/ruoyi-vue/other/faq.html#使用gzip解压缩静态文件 + plugin.push( + compression({ + ext: '.gz', + deleteOriginFile: false + }) + ) + } + if (compressList.includes('brotli')) { + plugin.push( + compression({ + ext: '.br', + algorithm: 'brotliCompress', + deleteOriginFile: false + }) + ) + } + } + return plugin +} diff --git a/admin-ui/vite/plugins/index.js b/admin-ui/vite/plugins/index.js new file mode 100644 index 0000000..10e17c3 --- /dev/null +++ b/admin-ui/vite/plugins/index.js @@ -0,0 +1,15 @@ +import vue from '@vitejs/plugin-vue' + +import createAutoImport from './auto-import' +import createSvgIcon from './svg-icon' +import createCompression from './compression' +import createSetupExtend from './setup-extend' + +export default function createVitePlugins(viteEnv, isBuild = false) { + const vitePlugins = [vue()] + vitePlugins.push(createAutoImport()) + vitePlugins.push(createSetupExtend()) + vitePlugins.push(createSvgIcon(isBuild)) + isBuild && vitePlugins.push(...createCompression(viteEnv)) + return vitePlugins +} diff --git a/admin-ui/vite/plugins/setup-extend.js b/admin-ui/vite/plugins/setup-extend.js new file mode 100644 index 0000000..a4980f3 --- /dev/null +++ b/admin-ui/vite/plugins/setup-extend.js @@ -0,0 +1,5 @@ +import setupExtend from 'vite-plugin-vue-setup-extend' + +export default function createSetupExtend() { + return setupExtend() +} diff --git a/admin-ui/vite/plugins/svg-icon.js b/admin-ui/vite/plugins/svg-icon.js new file mode 100644 index 0000000..30a4140 --- /dev/null +++ b/admin-ui/vite/plugins/svg-icon.js @@ -0,0 +1,10 @@ +import { createSvgIconsPlugin } from 'vite-plugin-svg-icons' +import path from 'path' + +export default function createSvgIcon(isBuild) { + return createSvgIconsPlugin({ + iconDirs: [path.resolve(process.cwd(), 'src/assets/icons/svg')], + symbolId: 'icon-[dir]-[name]', + svgoOptions: isBuild + }) +} diff --git a/document/Git commit 规范.md b/document/Git commit 规范.md new file mode 100644 index 0000000..fffce83 --- /dev/null +++ b/document/Git commit 规范.md @@ -0,0 +1,130 @@ +## 简介 + +实际开发过程中少不了使用Git进行代码版本管理,每次代码提交时都需要写`Commit message`,此时规范就相当重要了,业内做的比较好的,比较具有参考价值的就是Angular的提交。 + +--- + +## Commit message 的格式 + +Angular提交规范: + +每次提交,Commit message 都包括三个部分:header,body 和 footer。 + +```xml +(): #header +// 空一行 + +// 空一行 +