| | |
| | | 'plugin:vue/vue3-recommended', |
| | | './.eslintrc-auto-import.json', |
| | | 'plugin:@typescript-eslint/recommended', |
| | | "prettier", |
| | | 'plugin:prettier/recommended', |
| | | 'prettier', |
| | | 'plugin:prettier/recommended' |
| | | ], |
| | | parserOptions: { |
| | | ecmaVersion: '2020', |
| | | sourceType: 'module', |
| | | project: "./tsconfig.*?.json", |
| | | project: './tsconfig.*?.json', |
| | | parser: '@typescript-eslint/parser' |
| | | }, |
| | | plugins: ['vue', '@typescript-eslint', 'import', 'promise', 'node', 'prettier'], |
| | |
| | | ## 平台简介 |
| | | |
| | | * 本仓库为前端技术栈 [Vue3](https://v3.cn.vuejs.org) + [TS](https://www.typescriptlang.org/) + [Element Plus](https://element-plus.org/zh-CN) + [Vite](https://cn.vitejs.dev) 版本。 |
| | | * 配套后端代码仓库地址 |
| | | * [RuoYi-Vue-Plus 5.X(注意版本号)](https://gitee.com/dromara/RuoYi-Vue-Plus) |
| | | * [RuoYi-Cloud-Plus 2.X(注意版本号)](https://gitee.com/dromara/RuoYi-Cloud-Plus) |
| | | - 本仓库为前端技术栈 [Vue3](https://v3.cn.vuejs.org) + [TS](https://www.typescriptlang.org/) + [Element Plus](https://element-plus.org/zh-CN) + [Vite](https://cn.vitejs.dev) 版本。 |
| | | - 配套后端代码仓库地址 |
| | | - [RuoYi-Vue-Plus 5.X(注意版本号)](https://gitee.com/dromara/RuoYi-Vue-Plus) |
| | | - [RuoYi-Cloud-Plus 2.X(注意版本号)](https://gitee.com/dromara/RuoYi-Cloud-Plus) |
| | | |
| | | ## 前端运行 |
| | | |
| | |
| | | # 启动服务 |
| | | npm run dev |
| | | |
| | | # 构建生产环境 |
| | | # 构建生产环境 |
| | | npm run build:prod |
| | | |
| | | # 前端访问地址 http://localhost:80 |
| | |
| | | |
| | | ## 本框架与RuoYi的业务差异 |
| | | |
| | | | 业务 | 功能说明 | 本框架 | RuoYi | |
| | | |--------|-----------------------------------------|-----|------------------| |
| | | | 租户管理 | 系统内租户的管理 如:租户套餐、过期时间、用户数量、企业信息等 | 支持 | 无 | |
| | | | 租户套餐管理 | 系统内租户所能使用的套餐管理 如:套餐内所包含的菜单等 | 支持 | 无 | |
| | | | 用户管理 | 用户的管理配置 如:新增用户、分配用户所属部门、角色、岗位等 | 支持 | 支持 | |
| | | | 部门管理 | 配置系统组织机构(公司、部门、小组) 树结构展现支持数据权限 | 支持 | 支持 | |
| | | | 岗位管理 | 配置系统用户所属担任职务 | 支持 | 支持 | |
| | | | 菜单管理 | 配置系统菜单、操作权限、按钮权限标识等 | 支持 | 支持 | |
| | | | 角色管理 | 角色菜单权限分配、设置角色按机构进行数据范围权限划分 | 支持 | 支持 | |
| | | | 字典管理 | 对系统中经常使用的一些较为固定的数据进行维护 | 支持 | 支持 | |
| | | | 参数管理 | 对系统动态配置常用参数 | 支持 | 支持 | |
| | | | 通知公告 | 系统通知公告信息发布维护 | 支持 | 支持 | |
| | | | 操作日志 | 系统正常操作日志记录和查询 系统异常信息日志记录和查询 | 支持 | 支持 | |
| | | | 登录日志 | 系统登录日志记录查询包含登录异常 | 支持 | 支持 | |
| | | | 文件管理 | 系统文件展示、上传、下载、删除等管理 | 支持 | 无 | |
| | | | 文件配置管理 | 系统文件上传、下载所需要的配置信息动态添加、修改、删除等管理 | 支持 | 无 | |
| | | | 在线用户管理 | 已登录系统的在线用户信息监控与强制踢出操作 | 支持 | 支持 | |
| | | | 定时任务 | 运行报表、任务管理(添加、修改、删除)、日志管理、执行器管理等 | 支持 | 仅支持任务与日志管理 | |
| | | | 代码生成 | 多数据源前后端代码的生成(java、html、xml、sql)支持CRUD下载 | 支持 | 仅支持单数据源 | |
| | | | 系统接口 | 根据业务代码自动生成相关的api接口文档 | 支持 | 支持 | |
| | | | 服务监控 | 监视集群系统CPU、内存、磁盘、堆栈、在线日志、Spring相关配置等 | 支持 | 仅支持单机CPU、内存、磁盘监控 | |
| | | | 缓存监控 | 对系统的缓存信息查询,命令统计等。 | 支持 | 支持 | |
| | | | 在线构建器 | 拖动表单元素生成相应的HTML代码。 | 支持 | 支持 | |
| | | | 使用案例 | 系统的一些功能案例 | 支持 | 不支持 | |
| | | | 业务 | 功能说明 | 本框架 | RuoYi | |
| | | | ------------ | ------------------------------------------------------------- | ------ | ----------------------------- | |
| | | | 租户管理 | 系统内租户的管理 如:租户套餐、过期时间、用户数量、企业信息等 | 支持 | 无 | |
| | | | 租户套餐管理 | 系统内租户所能使用的套餐管理 如:套餐内所包含的菜单等 | 支持 | 无 | |
| | | | 用户管理 | 用户的管理配置 如:新增用户、分配用户所属部门、角色、岗位等 | 支持 | 支持 | |
| | | | 部门管理 | 配置系统组织机构(公司、部门、小组) 树结构展现支持数据权限 | 支持 | 支持 | |
| | | | 岗位管理 | 配置系统用户所属担任职务 | 支持 | 支持 | |
| | | | 菜单管理 | 配置系统菜单、操作权限、按钮权限标识等 | 支持 | 支持 | |
| | | | 角色管理 | 角色菜单权限分配、设置角色按机构进行数据范围权限划分 | 支持 | 支持 | |
| | | | 字典管理 | 对系统中经常使用的一些较为固定的数据进行维护 | 支持 | 支持 | |
| | | | 参数管理 | 对系统动态配置常用参数 | 支持 | 支持 | |
| | | | 通知公告 | 系统通知公告信息发布维护 | 支持 | 支持 | |
| | | | 操作日志 | 系统正常操作日志记录和查询 系统异常信息日志记录和查询 | 支持 | 支持 | |
| | | | 登录日志 | 系统登录日志记录查询包含登录异常 | 支持 | 支持 | |
| | | | 文件管理 | 系统文件展示、上传、下载、删除等管理 | 支持 | 无 | |
| | | | 文件配置管理 | 系统文件上传、下载所需要的配置信息动态添加、修改、删除等管理 | 支持 | 无 | |
| | | | 在线用户管理 | 已登录系统的在线用户信息监控与强制踢出操作 | 支持 | 支持 | |
| | | | 定时任务 | 运行报表、任务管理(添加、修改、删除)、日志管理、执行器管理等 | 支持 | 仅支持任务与日志管理 | |
| | | | 代码生成 | 多数据源前后端代码的生成(java、html、xml、sql)支持CRUD下载 | 支持 | 仅支持单数据源 | |
| | | | 系统接口 | 根据业务代码自动生成相关的api接口文档 | 支持 | 支持 | |
| | | | 服务监控 | 监视集群系统CPU、内存、磁盘、堆栈、在线日志、Spring相关配置等 | 支持 | 仅支持单机CPU、内存、磁盘监控 | |
| | | | 缓存监控 | 对系统的缓存信息查询,命令统计等。 | 支持 | 支持 | |
| | | | 在线构建器 | 拖动表单元素生成相应的HTML代码。 | 支持 | 支持 | |
| | | | 使用案例 | 系统的一些功能案例 | 支持 | 不支持 | |
| | | |
| | | ## 演示图例 |
| | | |
| | | | | | |
| | | |--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | | | | |
| | | | ---------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | | |  |  | |
| | |
| | | <!DOCTYPE html> |
| | | <!doctype html> |
| | | <html lang="zh-CN"> |
| | | <head> |
| | | <meta charset="UTF-8" /> |
| | |
| | | <meta name="renderer" content="webkit" /> |
| | | <base target="_blank" /> |
| | | <style type="text/css"> |
| | | html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{border:0;font-size:100%;font:inherit;vertical-align:baseline;margin:0;padding:0}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:none}table{border-collapse:collapse;border-spacing:0} |
| | | a{text-decoration:none;color:#0072c6;}a:hover{text-decoration:none;color:#004d8c;} |
| | | body{width:960px;margin:0 auto;padding:10px;font-size:14px;line-height:24px;color:#454545;font-family:'Microsoft YaHei UI','Microsoft YaHei',DengXian,SimSun,'Segoe UI',Tahoma,Helvetica,sans-serif;overflow-y:scroll} |
| | | h1{font-size:40px;line-height:80px;font-weight:100;margin-bottom:10px;} |
| | | h2{font-size:20px;line-height:25px;font-weight:100;margin:10px 0;} |
| | | em{color:red} |
| | | p{margin-bottom:10px;} |
| | | hr{margin:20px 0;border:0;border-top:1px solid #dadada} |
| | | span{display:block;font-size:12px;line-height:12px;} |
| | | .clean{clear:both;} |
| | | .browser{padding:10px 10px;} |
| | | .browser li{width:auto;padding:0 80px;margin-top:30px;height:34px;line-height:22px;float:left;list-style:none;background:url() no-repeat;padding-left:40px} |
| | | .browser .browser-firefox{background-position:0 -34px} |
| | | .browser .browser-ie{background-position:0 -68px;margin-left:0px} |
| | | .browser .browser-360{background-position:0 -170px;margin-left: -27px} |
| | | html, |
| | | body, |
| | | div, |
| | | span, |
| | | applet, |
| | | object, |
| | | iframe, |
| | | h1, |
| | | h2, |
| | | h3, |
| | | h4, |
| | | h5, |
| | | h6, |
| | | p, |
| | | blockquote, |
| | | pre, |
| | | a, |
| | | abbr, |
| | | acronym, |
| | | address, |
| | | big, |
| | | cite, |
| | | code, |
| | | del, |
| | | dfn, |
| | | em, |
| | | img, |
| | | ins, |
| | | kbd, |
| | | q, |
| | | s, |
| | | samp, |
| | | small, |
| | | strike, |
| | | strong, |
| | | sub, |
| | | sup, |
| | | tt, |
| | | var, |
| | | b, |
| | | u, |
| | | i, |
| | | center, |
| | | dl, |
| | | dt, |
| | | dd, |
| | | ol, |
| | | ul, |
| | | li, |
| | | fieldset, |
| | | form, |
| | | label, |
| | | legend, |
| | | table, |
| | | caption, |
| | | tbody, |
| | | tfoot, |
| | | thead, |
| | | tr, |
| | | th, |
| | | td, |
| | | article, |
| | | aside, |
| | | canvas, |
| | | details, |
| | | embed, |
| | | figure, |
| | | figcaption, |
| | | footer, |
| | | header, |
| | | hgroup, |
| | | menu, |
| | | nav, |
| | | output, |
| | | ruby, |
| | | section, |
| | | summary, |
| | | time, |
| | | mark, |
| | | audio, |
| | | video { |
| | | border: 0; |
| | | font-size: 100%; |
| | | font: inherit; |
| | | vertical-align: baseline; |
| | | margin: 0; |
| | | padding: 0; |
| | | } |
| | | article, |
| | | aside, |
| | | details, |
| | | figcaption, |
| | | figure, |
| | | footer, |
| | | header, |
| | | hgroup, |
| | | menu, |
| | | nav, |
| | | section { |
| | | display: block; |
| | | } |
| | | body { |
| | | line-height: 1; |
| | | } |
| | | ol, |
| | | ul { |
| | | list-style: none; |
| | | } |
| | | blockquote, |
| | | q { |
| | | quotes: none; |
| | | } |
| | | blockquote:before, |
| | | blockquote:after, |
| | | q:before, |
| | | q:after { |
| | | content: none; |
| | | } |
| | | table { |
| | | border-collapse: collapse; |
| | | border-spacing: 0; |
| | | } |
| | | a { |
| | | text-decoration: none; |
| | | color: #0072c6; |
| | | } |
| | | a:hover { |
| | | text-decoration: none; |
| | | color: #004d8c; |
| | | } |
| | | body { |
| | | width: 960px; |
| | | margin: 0 auto; |
| | | padding: 10px; |
| | | font-size: 14px; |
| | | line-height: 24px; |
| | | color: #454545; |
| | | font-family: 'Microsoft YaHei UI', 'Microsoft YaHei', DengXian, SimSun, 'Segoe UI', Tahoma, Helvetica, sans-serif; |
| | | overflow-y: scroll; |
| | | } |
| | | h1 { |
| | | font-size: 40px; |
| | | line-height: 80px; |
| | | font-weight: 100; |
| | | margin-bottom: 10px; |
| | | } |
| | | h2 { |
| | | font-size: 20px; |
| | | line-height: 25px; |
| | | font-weight: 100; |
| | | margin: 10px 0; |
| | | } |
| | | em { |
| | | color: red; |
| | | } |
| | | p { |
| | | margin-bottom: 10px; |
| | | } |
| | | hr { |
| | | margin: 20px 0; |
| | | border: 0; |
| | | border-top: 1px solid #dadada; |
| | | } |
| | | span { |
| | | display: block; |
| | | font-size: 12px; |
| | | line-height: 12px; |
| | | } |
| | | .clean { |
| | | clear: both; |
| | | } |
| | | .browser { |
| | | padding: 10px 10px; |
| | | } |
| | | .browser li { |
| | | width: auto; |
| | | padding: 0 80px; |
| | | margin-top: 30px; |
| | | height: 34px; |
| | | line-height: 22px; |
| | | float: left; |
| | | list-style: none; |
| | | background: url() |
| | | no-repeat; |
| | | padding-left: 40px; |
| | | } |
| | | .browser .browser-firefox { |
| | | background-position: 0 -34px; |
| | | } |
| | | .browser .browser-ie { |
| | | background-position: 0 -68px; |
| | | margin-left: 0px; |
| | | } |
| | | .browser .browser-360 { |
| | | background-position: 0 -170px; |
| | | margin-left: -27px; |
| | | } |
| | | </style> |
| | | </head> |
| | | <body style="margin-top:50px"> |
| | | <body style="margin-top: 50px"> |
| | | <h1>请升级您的浏览器,以便我们更好的为您提供服务!</h1> |
| | | <p>您正在使用 Internet Explorer 的早期版本(IE11以下版本或使用该内核的浏览器)。这意味着在升级浏览器前,您将无法访问此网站。</p> |
| | | <hr /> |
| | |
| | | <!DOCTYPE html> |
| | | <!doctype html> |
| | | <html> |
| | | <head> |
| | | <meta charset="utf-8" /> |
| | |
| | | <title>RuoYi-Vue-Plus多租户管理系统</title> |
| | | <!--[if lt IE 11 |
| | | ]><script> |
| | | window.location.href='/html/ie.html'; |
| | | window.location.href = '/html/ie.html'; |
| | | </script><! |
| | | [endif]--> |
| | | <style> |
| | |
| | | margin: -75px 0 0 -75px; |
| | | border-radius: 50%; |
| | | border: 3px solid transparent; |
| | | border-top-color: #FFF; |
| | | border-top-color: #fff; |
| | | -webkit-animation: spin 2s linear infinite; |
| | | -ms-animation: spin 2s linear infinite; |
| | | -moz-animation: spin 2s linear infinite; |
| | |
| | | } |
| | | |
| | | #loader:before { |
| | | content: ""; |
| | | content: ''; |
| | | position: absolute; |
| | | top: 5px; |
| | | left: 5px; |
| | |
| | | bottom: 5px; |
| | | border-radius: 50%; |
| | | border: 3px solid transparent; |
| | | border-top-color: #FFF; |
| | | border-top-color: #fff; |
| | | -webkit-animation: spin 3s linear infinite; |
| | | -moz-animation: spin 3s linear infinite; |
| | | -o-animation: spin 3s linear infinite; |
| | |
| | | } |
| | | |
| | | #loader:after { |
| | | content: ""; |
| | | content: ''; |
| | | position: absolute; |
| | | top: 15px; |
| | | left: 15px; |
| | |
| | | bottom: 15px; |
| | | border-radius: 50%; |
| | | border: 3px solid transparent; |
| | | border-top-color: #FFF; |
| | | border-top-color: #fff; |
| | | -moz-animation: spin 1.5s linear infinite; |
| | | -o-animation: spin 1.5s linear infinite; |
| | | -ms-animation: spin 1.5s linear infinite; |
| | | -webkit-animation: spin 1.5s linear infinite; |
| | | animation: spin 1.5s linear infinite; |
| | | } |
| | | |
| | | |
| | | @-webkit-keyframes spin { |
| | | 0% { |
| | |
| | | } |
| | | } |
| | | |
| | | |
| | | #loader-wrapper .loader-section { |
| | | position: fixed; |
| | | top: 0; |
| | | width: 51%; |
| | | height: 100%; |
| | | background: #7171C6; |
| | | background: #7171c6; |
| | | z-index: 1000; |
| | | -webkit-transform: translateX(0); |
| | | -ms-transform: translateX(0); |
| | |
| | | right: 0; |
| | | } |
| | | |
| | | |
| | | .loaded #loader-wrapper .loader-section.section-left { |
| | | -webkit-transform: translateX(-100%); |
| | | -ms-transform: translateX(-100%); |
| | | transform: translateX(-100%); |
| | | -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000); |
| | | transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000); |
| | | -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); |
| | | transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); |
| | | } |
| | | |
| | | .loaded #loader-wrapper .loader-section.section-right { |
| | | -webkit-transform: translateX(100%); |
| | | -ms-transform: translateX(100%); |
| | | transform: translateX(100%); |
| | | -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000); |
| | | transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000); |
| | | -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); |
| | | transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); |
| | | } |
| | | |
| | | .loaded #loader { |
| | |
| | | |
| | | #loader-wrapper .load_title { |
| | | font-family: 'Open Sans'; |
| | | color: #FFF; |
| | | color: #fff; |
| | | font-size: 19px; |
| | | width: 100%; |
| | | text-align: center; |
| | |
| | | font-weight: normal; |
| | | font-style: italic; |
| | | font-size: 13px; |
| | | color: #FFF; |
| | | color: #fff; |
| | | opacity: 0.5; |
| | | } |
| | | </style> |
| | |
| | | } |
| | | |
| | | // 根据参数键名查询参数值 |
| | | export function getConfigKey(configKey: string): AxiosPromise<String> { |
| | | export function getConfigKey(configKey: string): AxiosPromise<string> { |
| | | return request({ |
| | | url: '/system/config/configKey/' + configKey, |
| | | method: 'get' |
| | |
| | | -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; |
| | | font-family: |
| | | Helvetica Neue, |
| | | Helvetica, |
| | | PingFang SC, |
| | | Hiragino Sans GB, |
| | | Microsoft YaHei, |
| | | Arial, |
| | | sans-serif; |
| | | } |
| | | |
| | | label { |
| | |
| | | |
| | | // 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; |
| | | transition: |
| | | 0s width ease-in-out, |
| | | 0s padding-left ease-in-out, |
| | | 0s padding-right ease-in-out; |
| | | } |
| | | |
| | | .scrollbar-wrapper { |
| | |
| | | background-color: rgba(0, 0, 0, 0.1) !important; |
| | | } |
| | | } |
| | | |
| | | |
| | | & .theme-dark .nest-menu .el-sub-menu > .el-sub-menu__title, |
| | | & .theme-dark .el-sub-menu .el-menu-item { |
| | |
| | | <div> |
| | | <template v-for="(item, index) in options"> |
| | | <template v-if="values.includes(item.value)"> |
| | | <span v-if="(item.elTagType === 'default' || item.elTagType === '') && (item.elTagClass === '' || item.elTagClass == null)" |
| | | :key="item.value" :index="index" :class="item.elTagClass"> |
| | | {{ item.label + " " }} |
| | | <span |
| | | v-if="(item.elTagType === 'default' || item.elTagType === '') && (item.elTagClass === '' || item.elTagClass == null)" |
| | | :key="item.value" |
| | | :index="index" |
| | | :class="item.elTagClass" |
| | | > |
| | | {{ item.label + ' ' }} |
| | | </span> |
| | | <el-tag |
| | | v-else |
| | | :key="item.value + ''" |
| | | :disable-transitions="true" |
| | | :index="index" |
| | | :type="(item.elTagType === 'primary' || item.elTagType === 'default')? '' : item.elTagType" |
| | | :type="item.elTagType === 'primary' || item.elTagType === 'default' ? '' : item.elTagType" |
| | | :class="item.elTagClass" |
| | | > |
| | | {{ item.label + ' ' }} |
| | |
| | | </template> |
| | | |
| | | <script setup name="Online" lang="ts"> |
| | | import { forceLogout, list as initData } from "@/api/monitor/online"; |
| | | import { OnlineQuery, OnlineVO } from "@/api/monitor/online/types"; |
| | | import api from "@/api/system/user"; |
| | | import {to} from "await-to-js"; |
| | | import { forceLogout, list as initData } from '@/api/monitor/online'; |
| | | import { OnlineQuery, OnlineVO } from '@/api/monitor/online/types'; |
| | | import { to } from 'await-to-js'; |
| | | |
| | | const { proxy } = getCurrentInstance() as ComponentInternalInstance; |
| | | const { sys_device_type } = toRefs<any>(proxy?.useDict('sys_device_type')); |
| | |
| | | if (!err) { |
| | | await forceLogout(row.tokenId); |
| | | await getList(); |
| | | proxy?.$modal.msgSuccess("删除成功"); |
| | | proxy?.$modal.msgSuccess('删除成功'); |
| | | } |
| | | } |
| | | }; |
| | | |
| | | onMounted(() => { |
| | | getList(); |
| | |
| | | <el-table-column v-if="false" label="字典编码" align="center" prop="dictCode" /> |
| | | <el-table-column label="字典标签" align="center" prop="dictLabel"> |
| | | <template #default="scope"> |
| | | <span v-if="(scope.row.listClass === '' || scope.row.listClass === 'default') && (scope.row.cssClass === '' || scope.row.cssClass == null)">{{ scope.row.dictLabel }}</span> |
| | | <el-tag v-else :type="(scope.row.listClass === 'primary' || scope.row.listClass === 'default') ? '' : scope.row.listClass" :class="scope.row.cssClass">{{ scope.row.dictLabel }}</el-tag> |
| | | <span |
| | | v-if="(scope.row.listClass === '' || scope.row.listClass === 'default') && (scope.row.cssClass === '' || scope.row.cssClass == null)" |
| | | >{{ scope.row.dictLabel }}</span |
| | | > |
| | | <el-tag |
| | | v-else |
| | | :type="scope.row.listClass === 'primary' || scope.row.listClass === 'default' ? '' : scope.row.listClass" |
| | | :class="scope.row.cssClass" |
| | | >{{ scope.row.dictLabel }}</el-tag |
| | | > |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="字典键值" align="center" prop="dictValue" /> |
| | |
| | | <template #header> |
| | | <el-row :gutter="10" class="mb8"> |
| | | <el-col :span="1.5"> |
| | | <el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['system:ossConfig:add']">新增</el-button> |
| | | <el-button v-hasPermi="['system:ossConfig:add']" type="primary" plain icon="Plus" @click="handleAdd">新增</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button type="success" plain icon="Edit" :disabled="single" @click="handleUpdate()" v-hasPermi="['system:ossConfig:edit']">修改</el-button> |
| | | <el-button v-hasPermi="['system:ossConfig:edit']" type="success" plain icon="Edit" :disabled="single" @click="handleUpdate()" |
| | | >修改</el-button |
| | | > |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete()" v-hasPermi="['system:ossConfig:remove']"> |
| | | <el-button v-hasPermi="['system:ossConfig:remove']" type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete()"> |
| | | 删除 |
| | | </el-button> |
| | | </el-col> |
| | |
| | | <el-table-column label="操作" fixed="right" align="center" width="150" class-name="small-padding"> |
| | | <template #default="scope"> |
| | | <el-tooltip content="修改" placement="top"> |
| | | <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['system:ossConfig:edit']"></el-button> |
| | | <el-button v-hasPermi="['system:ossConfig:edit']" link type="primary" icon="Edit" @click="handleUpdate(scope.row)"></el-button> |
| | | </el-tooltip> |
| | | <el-tooltip content="删除" placement="top"> |
| | | <el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['system:ossConfig:remove']"></el-button> |
| | | <el-button v-hasPermi="['system:ossConfig:remove']" link type="primary" icon="Delete" @click="handleDelete(scope.row)"></el-button> |
| | | </el-tooltip> |
| | | </template> |
| | | </el-table-column> |
| | |
| | | <template> |
| | | <div class="user-info-head" @click="editCropper()"> |
| | | <img :src="options.img" title="点击上传头像" class="img-circle img-lg" /> |
| | | <el-dialog :title="title" v-model="open" width="800px" append-to-body @opened="modalOpened" @close="closeDialog"> |
| | | <el-dialog v-model="open" :title="title" width="800px" append-to-body @opened="modalOpened" @close="closeDialog"> |
| | | <el-row> |
| | | <el-col :xs="24" :md="12" :style="{ height: '350px' }"> |
| | | <vue-cropper |
| | |
| | | const res = await uploadAvatar(formData); |
| | | open.value = false; |
| | | options.img = res.data.imgUrl; |
| | | userStore.setAvatar(options.img as string) |
| | | proxy?.$modal.msgSuccess("修改成功"); |
| | | userStore.setAvatar(options.img as string); |
| | | proxy?.$modal.msgSuccess('修改成功'); |
| | | visible.value = false; |
| | | }); |
| | | }; |
| | |
| | | <el-tabs v-model="preview.activeName"> |
| | | <el-tab-pane |
| | | v-for="(value, key) in preview.data" |
| | | :key="value" |
| | | :label="key.substring(key.lastIndexOf('/') + 1, key.indexOf('.vm'))" |
| | | :name="key.substring(key.lastIndexOf('/') + 1, key.indexOf('.vm'))" |
| | | :key="value" |
| | | > |
| | | <el-link v-copyText="value" v-copyText:callback="copyTextSuccess" :underline="false" icon="DocumentCopy" style="float: right"> |
| | | 复制 |
| | |
| | | import setupExtend from 'unplugin-vue-setup-extend-plus/vite' |
| | | import setupExtend from 'unplugin-vue-setup-extend-plus/vite'; |
| | | |
| | | export default () => { |
| | | return setupExtend({}) |
| | | return setupExtend({}); |
| | | }; |