update 优化 执行eslint:fix优化代码
This commit is contained in:
		| @ -1,6 +1,6 @@ | ||||
| import request from '@/utils/request'; | ||||
| import { AxiosPromise } from 'axios'; | ||||
| import {DeptForm, DeptQuery, DeptTreeVO, DeptVO} from './types'; | ||||
| import { DeptForm, DeptQuery, DeptTreeVO, DeptVO } from './types'; | ||||
|  | ||||
| // 查询部门列表 | ||||
| export const listDept = (query?: DeptQuery) => { | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| import {DeptTreeVO, DeptVO} from './../dept/types'; | ||||
| import { DeptTreeVO, DeptVO } from './../dept/types'; | ||||
| import { RoleVO } from '@/api/system/role/types'; | ||||
| import request from '@/utils/request'; | ||||
| import { AxiosPromise } from 'axios'; | ||||
|  | ||||
| @ -44,7 +44,7 @@ const findPathNum = (str, char = '/') => { | ||||
|   return str.split(char).length - 1; | ||||
| }; | ||||
| const getMatched = (pathList, routeList, matched) => { | ||||
|   let data = routeList.find((item) => item.path == pathList[0] || (item.name += '').toLowerCase() == pathList[0]); | ||||
|   const data = routeList.find((item) => item.path == pathList[0] || (item.name += '').toLowerCase() == pathList[0]); | ||||
|   if (data) { | ||||
|     matched.push(data); | ||||
|     if (data.children && pathList.length) { | ||||
|  | ||||
| @ -95,7 +95,7 @@ const options = ref<any>({ | ||||
| }); | ||||
|  | ||||
| const styles = computed(() => { | ||||
|   let style: any = {}; | ||||
|   const style: any = {}; | ||||
|   if (props.minHeight) { | ||||
|     style.minHeight = `${props.minHeight}px`; | ||||
|   } | ||||
| @ -121,9 +121,9 @@ const handleUploadSuccess = (res: any) => { | ||||
|   // 如果上传成功 | ||||
|   if (res.code === 200) { | ||||
|     // 获取富文本实例 | ||||
|     let quill = toRaw(quillEditorRef.value).getQuill(); | ||||
|     const quill = toRaw(quillEditorRef.value).getQuill(); | ||||
|     // 获取光标位置 | ||||
|     let length = quill.selection.savedRange.index; | ||||
|     const length = quill.selection.savedRange.index; | ||||
|     // 插入图片,res为服务器返回的图片链接地址 | ||||
|     quill.insertEmbed(length, 'image', res.data.url); | ||||
|     // 调整光标到最后 | ||||
|  | ||||
| @ -176,7 +176,7 @@ const handleUploadSuccess = (res: any, file: UploadFile) => { | ||||
|  | ||||
| // 删除文件 | ||||
| const handleDelete = (index: number) => { | ||||
|   let ossId = fileList.value[index].ossId; | ||||
|   const ossId = fileList.value[index].ossId; | ||||
|   delOss(ossId); | ||||
|   fileList.value.splice(index, 1); | ||||
|   emit('update:modelValue', listToString(fileList.value)); | ||||
|  | ||||
| @ -27,7 +27,7 @@ const realSrc = computed(() => { | ||||
|   if (!props.src) { | ||||
|     return; | ||||
|   } | ||||
|   let real_src = props.src.split(',')[0]; | ||||
|   const real_src = props.src.split(',')[0]; | ||||
|   return real_src; | ||||
| }); | ||||
|  | ||||
| @ -35,8 +35,8 @@ const realSrcList = computed(() => { | ||||
|   if (!props.src) { | ||||
|     return []; | ||||
|   } | ||||
|   let real_src_list = props.src.split(','); | ||||
|   let srcList: string[] = []; | ||||
|   const real_src_list = props.src.split(','); | ||||
|   const srcList: string[] = []; | ||||
|   real_src_list.forEach((item: string) => { | ||||
|     if (item.trim() === '') { | ||||
|       return; | ||||
|  | ||||
| @ -189,7 +189,7 @@ const handleUploadSuccess = (res: any, file: UploadFile) => { | ||||
| const handleDelete = (file: UploadFile): boolean => { | ||||
|   const findex = fileList.value.map((f) => f.name).indexOf(file.name); | ||||
|   if (findex > -1 && uploadList.value.length === number.value) { | ||||
|     let ossId = fileList.value[findex].ossId; | ||||
|     const ossId = fileList.value[findex].ossId; | ||||
|     delOss(ossId); | ||||
|     fileList.value.splice(findex, 1); | ||||
|     emit('update:modelValue', listToString(fileList.value)); | ||||
| @ -225,7 +225,7 @@ const handlePictureCardPreview = (file: any) => { | ||||
| const listToString = (list: any[], separator?: string) => { | ||||
|   let strs = ''; | ||||
|   separator = separator || ','; | ||||
|   for (let i in list) { | ||||
|   for (const i in list) { | ||||
|     if (undefined !== list[i].ossId && list[i].url.indexOf('blob:') !== 0) { | ||||
|       strs += list[i].ossId + separator; | ||||
|     } | ||||
|  | ||||
| @ -47,7 +47,7 @@ const routers = computed(() => permissionStore.getTopbarRoutes()); | ||||
|  | ||||
| // 顶部显示菜单 | ||||
| const topMenus = computed(() => { | ||||
|   let topMenus: RouteRecordRaw[] = []; | ||||
|   const topMenus: RouteRecordRaw[] = []; | ||||
|   routers.value.map((menu) => { | ||||
|     if (menu.hidden !== true) { | ||||
|       // 兼容顶部栏一级菜单内部跳转 | ||||
| @ -63,7 +63,7 @@ const topMenus = computed(() => { | ||||
|  | ||||
| // 设置子路由 | ||||
| const childrenMenus = computed(() => { | ||||
|   let childrenMenus: RouteRecordRaw[] = []; | ||||
|   const childrenMenus: RouteRecordRaw[] = []; | ||||
|   routers.value.map((router) => { | ||||
|     router.children?.forEach((item) => { | ||||
|       if (item.parentPath === undefined) { | ||||
| @ -118,7 +118,7 @@ const handleSelect = (key: string) => { | ||||
|     // 没有子路由路径内部打开 | ||||
|     const routeMenu = childrenMenus.value.find((item) => item.path === key); | ||||
|     if (routeMenu && routeMenu.query) { | ||||
|       let query = JSON.parse(routeMenu.query); | ||||
|       const query = JSON.parse(routeMenu.query); | ||||
|       router.push({ path: key, query: query }); | ||||
|     } else { | ||||
|       router.push({ path: key }); | ||||
| @ -132,7 +132,7 @@ const handleSelect = (key: string) => { | ||||
| }; | ||||
|  | ||||
| const activeRoutes = (key: string) => { | ||||
|   let routes: RouteRecordRaw[] = []; | ||||
|   const routes: RouteRecordRaw[] = []; | ||||
|   if (childrenMenus.value && childrenMenus.value.length > 0) { | ||||
|     childrenMenus.value.map((item) => { | ||||
|       if (key == item.parentPath || (key == 'index' && '' == item.path)) { | ||||
|  | ||||
| @ -40,16 +40,16 @@ watch( | ||||
| ); | ||||
|  | ||||
| onMounted(() => { | ||||
|   addIframe() | ||||
| }) | ||||
|   addIframe(); | ||||
| }); | ||||
|  | ||||
| watchEffect(() => { | ||||
|   addIframe() | ||||
| }) | ||||
|   addIframe(); | ||||
| }); | ||||
|  | ||||
| function addIframe() { | ||||
|   if (route.meta.link) { | ||||
|     useTagsViewStore().addIframeView(route) | ||||
|     useTagsViewStore().addIframeView(route); | ||||
|   } | ||||
| } | ||||
| </script> | ||||
|  | ||||
| @ -18,7 +18,7 @@ const tagsViewStore = useTagsViewStore(); | ||||
|  | ||||
| function iframeUrl(url: string | undefined, query: any) { | ||||
|   if (Object.keys(query).length > 0) { | ||||
|     let params = Object.keys(query) | ||||
|     const params = Object.keys(query) | ||||
|       .map((key) => key + '=' + query[key]) | ||||
|       .join('&'); | ||||
|     return url + '?' + params; | ||||
|  | ||||
| @ -98,7 +98,7 @@ import { dynamicClear, dynamicTenant } from '@/api/system/tenant'; | ||||
| import { TenantVO } from '@/api/types'; | ||||
| import notice from './notice/index.vue'; | ||||
| import router from '@/router'; | ||||
| import {ElMessageBoxOptions} from "element-plus/es/components/message-box/src/message-box.type"; | ||||
| import { ElMessageBoxOptions } from 'element-plus/es/components/message-box/src/message-box.type'; | ||||
|  | ||||
| const appStore = useAppStore(); | ||||
| const userStore = useUserStore(); | ||||
|  | ||||
| @ -86,7 +86,7 @@ const resolvePath = (routePath: string, routeQuery?: string): any => { | ||||
|     return props.basePath; | ||||
|   } | ||||
|   if (routeQuery) { | ||||
|     let query = JSON.parse(routeQuery); | ||||
|     const query = JSON.parse(routeQuery); | ||||
|     return { path: getNormalPath(props.basePath + '/' + routePath), query: query }; | ||||
|   } | ||||
|   return getNormalPath(props.basePath + '/' + routePath); | ||||
|  | ||||
| @ -63,9 +63,9 @@ const loginByCode = async (data: LoginData) => { | ||||
|  | ||||
| const init = async () => { | ||||
|   // 如果域名不相等 则重定向处理 | ||||
|   let host = window.location.host; | ||||
|   const host = window.location.host; | ||||
|   if (domain !== host) { | ||||
|     let urlFull = new URL(window.location.href); | ||||
|     const urlFull = new URL(window.location.href); | ||||
|     urlFull.host = domain; | ||||
|     window.location.href = urlFull.toString(); | ||||
|     return; | ||||
|  | ||||
| @ -67,7 +67,7 @@ const closeSearch = () => { | ||||
| }; | ||||
| // 菜单搜索数据过滤 | ||||
| const menuSearch = (queryString: string, cb: (options: any[]) => void) => { | ||||
|   let options = state.menuList.filter((item) => { | ||||
|   const options = state.menuList.filter((item) => { | ||||
|     return item.title.indexOf(queryString) > -1; | ||||
|   }); | ||||
|   cb(options); | ||||
|  | ||||
| @ -14,8 +14,8 @@ NProgress.configure({ showSpinner: false }); | ||||
| const whiteList = ['/login', '/register', '/social-callback', '/register*', '/register/*']; | ||||
|  | ||||
| const isWhiteList = (path: string) => { | ||||
|   return whiteList.some(pattern => isPathMatch(pattern, path)) | ||||
| } | ||||
|   return whiteList.some((pattern) => isPathMatch(pattern, path)); | ||||
| }; | ||||
|  | ||||
| router.beforeEach(async (to, from, next) => { | ||||
|   NProgress.start(); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| import { createPinia } from "pinia"; | ||||
| import { createPinia } from 'pinia'; | ||||
|  | ||||
| const store = createPinia(); | ||||
|  | ||||
|  | ||||
| @ -99,14 +99,14 @@ export const usePermissionStore = defineStore('permission', () => { | ||||
|   }; | ||||
|   const filterChildren = (childrenMap: RouteRecordRaw[], lastRouter?: RouteRecordRaw): RouteRecordRaw[] => { | ||||
|     let children: RouteRecordRaw[] = []; | ||||
|     childrenMap.forEach(el => { | ||||
|     childrenMap.forEach((el) => { | ||||
|       el.path = lastRouter ? lastRouter.path + '/' + el.path : el.path; | ||||
|       if (el.children && el.children.length && el.component?.toString() === 'ParentView') { | ||||
|         children = children.concat(filterChildren(el.children, el)); | ||||
|       } else { | ||||
|         children.push(el); | ||||
|       } | ||||
|     }) | ||||
|     }); | ||||
|     return children; | ||||
|   }; | ||||
|   return { | ||||
|  | ||||
| @ -5,7 +5,6 @@ import { useStorage } from '@vueuse/core'; | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| export const useSettingsStore = defineStore('setting', () => { | ||||
|   // @ts-ignore | ||||
|   const storageSetting = useStorage<LayoutSetting>('layout-setting', { | ||||
|     topNav: defaultSettings.topNav, | ||||
|     tagsView: defaultSettings.tagsView, | ||||
|  | ||||
							
								
								
									
										1
									
								
								src/types/module.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								src/types/module.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -48,4 +48,3 @@ export type ObjKeysToUnion<T, P extends string = ''> = T extends object | ||||
|       [K in keyof T]: ObjKeysToUnion<T[K], P extends '' ? `${K & string}` : `${P}.${K & string}`>; | ||||
|     }[keyof T] | ||||
|   : P; | ||||
|  | ||||
|  | ||||
| @ -178,11 +178,11 @@ export const handleTree = <T>(data: any[], id?: string, parentId?: string, child | ||||
|  | ||||
|   for (const d of data) { | ||||
|     const parentId = d[config.parentId]; | ||||
|     const parentObj = childrenListMap[parentId] | ||||
|     const parentObj = childrenListMap[parentId]; | ||||
|     if (!parentObj) { | ||||
|       tree.push(d); | ||||
|     } else { | ||||
|       parentObj[config.childrenList].push(d) | ||||
|       parentObj[config.childrenList].push(d); | ||||
|     } | ||||
|   } | ||||
|   return tree; | ||||
|  | ||||
| @ -22,7 +22,7 @@ | ||||
| <script setup lang="ts"> | ||||
| import errImage from '@/assets/401_images/401.gif'; | ||||
|  | ||||
| let { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
|  | ||||
| const errGif = ref(errImage + '?' + +new Date()); | ||||
|  | ||||
|  | ||||
| @ -22,7 +22,7 @@ | ||||
| </template> | ||||
|  | ||||
| <script setup lang="ts"> | ||||
| let message = computed(() => { | ||||
| const message = computed(() => { | ||||
|   return '找不到网页!'; | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -203,7 +203,6 @@ onMounted(() => { | ||||
|     line-height: 0; | ||||
|     color: #7483a3; | ||||
|   } | ||||
|  | ||||
| } | ||||
|  | ||||
| .register-form { | ||||
|  | ||||
| @ -300,7 +300,7 @@ const handleExport = () => { | ||||
|  | ||||
| /** 状态修改  */ | ||||
| const handleStatusChange = async (row: ClientVO) => { | ||||
|   let text = row.status === '0' ? '启用' : '停用'; | ||||
|   const text = row.status === '0' ? '启用' : '停用'; | ||||
|   try { | ||||
|     await proxy?.$modal.confirm('确认要"' + text + '"吗?'); | ||||
|     await changeStatus(row.clientId, row.status); | ||||
|  | ||||
| @ -87,16 +87,16 @@ | ||||
|           <el-input v-model="form.configKey" placeholder="请输入配置key" /> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="访问站点" prop="endpoint"> | ||||
|           <el-input v-model="form.endpoint" placeholder="请输入访问站点" > | ||||
|           <el-input v-model="form.endpoint" placeholder="请输入访问站点"> | ||||
|             <template #prefix> | ||||
|               <span style="color: #999;">{{ protocol }}</span> | ||||
|               <span style="color: #999">{{ protocol }}</span> | ||||
|             </template> | ||||
|           </el-input> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="自定义域名" prop="domain"> | ||||
|           <el-input v-model="form.domain" placeholder="请输入自定义域名" > | ||||
|           <el-input v-model="form.domain" placeholder="请输入自定义域名"> | ||||
|             <template #prefix> | ||||
|               <span style="color: #999;">{{ protocol }}</span> | ||||
|               <span style="color: #999">{{ protocol }}</span> | ||||
|             </template> | ||||
|           </el-input> | ||||
|         </el-form-item> | ||||
| @ -316,7 +316,7 @@ const submitForm = () => { | ||||
| }; | ||||
| /** 状态修改  */ | ||||
| const handleStatusChange = async (row: OssConfigVO) => { | ||||
|   let text = row.status === '0' ? '启用' : '停用'; | ||||
|   const text = row.status === '0' ? '启用' : '停用'; | ||||
|   try { | ||||
|     await proxy?.$modal.confirm('确认要"' + text + '""' + row.configKey + '"配置吗?'); | ||||
|     await changeOssConfigStatus(row.ossConfigId, row.status, row.configKey); | ||||
|  | ||||
| @ -255,9 +255,9 @@ const handleHeaderCLick = (column: any) => { | ||||
|   handleOrderChange(column.property, column.multiOrder); | ||||
| }; | ||||
| const handleOrderChange = (prop: string, order: string) => { | ||||
|   let orderByArr = queryParams.value.orderByColumn ? queryParams.value.orderByColumn.split(',') : []; | ||||
|   let isAscArr = queryParams.value.isAsc ? queryParams.value.isAsc.split(',') : []; | ||||
|   let propIndex = orderByArr.indexOf(prop); | ||||
|   const orderByArr = queryParams.value.orderByColumn ? queryParams.value.orderByColumn.split(',') : []; | ||||
|   const isAscArr = queryParams.value.isAsc ? queryParams.value.isAsc.split(',') : []; | ||||
|   const propIndex = orderByArr.indexOf(prop); | ||||
|   if (propIndex !== -1) { | ||||
|     if (order) { | ||||
|       //排序里已存在 只修改排序 | ||||
| @ -306,7 +306,7 @@ const handleDownload = (row: OssVO) => { | ||||
| }; | ||||
| /** 预览开关按钮  */ | ||||
| const handlePreviewListResource = async (preview: boolean) => { | ||||
|   let text = preview ? '启用' : '停用'; | ||||
|   const text = preview ? '启用' : '停用'; | ||||
|   try { | ||||
|     await proxy?.$modal.confirm('确认要"' + text + '""预览列表图片"配置吗?'); | ||||
|     await proxy?.updateConfigByKey('sys.oss.previewListResource', preview); | ||||
|  | ||||
| @ -323,7 +323,7 @@ const handleSelectionChange = (selection: RoleVO[]) => { | ||||
|  | ||||
| /** 角色状态修改 */ | ||||
| const handleStatusChange = async (row: RoleVO) => { | ||||
|   let text = row.status === '0' ? '启用' : '停用'; | ||||
|   const text = row.status === '0' ? '启用' : '停用'; | ||||
|   try { | ||||
|     await proxy?.$modal.confirm('确认要"' + text + '""' + row.roleName + '"角色吗?'); | ||||
|     await changeRoleStatus(row.roleId, row.status); | ||||
| @ -346,11 +346,11 @@ const getMenuTreeselect = async () => { | ||||
| /** 所有部门节点数据 */ | ||||
| const getDeptAllCheckedKeys = (): any => { | ||||
|   // 目前被选中的部门节点 | ||||
|   let checkedKeys = deptRef.value?.getCheckedKeys(); | ||||
|   const checkedKeys = deptRef.value?.getCheckedKeys(); | ||||
|   // 半选中的部门节点 | ||||
|   let halfCheckedKeys = deptRef.value?.getHalfCheckedKeys(); | ||||
|   const halfCheckedKeys = deptRef.value?.getHalfCheckedKeys(); | ||||
|   if (halfCheckedKeys) { | ||||
|     checkedKeys?.unshift.apply(checkedKeys, halfCheckedKeys); | ||||
|     checkedKeys?.unshift(...halfCheckedKeys); | ||||
|   } | ||||
|   return checkedKeys; | ||||
| }; | ||||
| @ -404,14 +404,14 @@ const getRoleDeptTreeSelect = async (roleId: string | number) => { | ||||
| /** 树权限(展开/折叠)*/ | ||||
| const handleCheckedTreeExpand = (value: boolean, type: string) => { | ||||
|   if (type == 'menu') { | ||||
|     let treeList = menuOptions.value; | ||||
|     const treeList = menuOptions.value; | ||||
|     for (let i = 0; i < treeList.length; i++) { | ||||
|       if (menuRef.value) { | ||||
|         menuRef.value.store.nodesMap[treeList[i].id].expanded = value; | ||||
|       } | ||||
|     } | ||||
|   } else if (type == 'dept') { | ||||
|     let treeList = deptOptions.value; | ||||
|     const treeList = deptOptions.value; | ||||
|     for (let i = 0; i < treeList.length; i++) { | ||||
|       if (deptRef.value) { | ||||
|         deptRef.value.store.nodesMap[treeList[i].id].expanded = value; | ||||
| @ -438,11 +438,11 @@ const handleCheckedTreeConnect = (value: any, type: string) => { | ||||
| /** 所有菜单节点数据 */ | ||||
| const getMenuAllCheckedKeys = (): any => { | ||||
|   // 目前被选中的菜单节点 | ||||
|   let checkedKeys = menuRef.value?.getCheckedKeys(); | ||||
|   const checkedKeys = menuRef.value?.getCheckedKeys(); | ||||
|   // 半选中的菜单节点 | ||||
|   let halfCheckedKeys = menuRef.value?.getHalfCheckedKeys(); | ||||
|   const halfCheckedKeys = menuRef.value?.getHalfCheckedKeys(); | ||||
|   if (halfCheckedKeys) { | ||||
|     checkedKeys?.unshift.apply(checkedKeys, halfCheckedKeys); | ||||
|     checkedKeys?.unshift(...halfCheckedKeys); | ||||
|   } | ||||
|   return checkedKeys; | ||||
| }; | ||||
|  | ||||
| @ -245,7 +245,7 @@ const getList = async () => { | ||||
|  | ||||
| // 租户套餐状态修改 | ||||
| const handleStatusChange = async (row: TenantVO) => { | ||||
|   let text = row.status === '0' ? '启用' : '停用'; | ||||
|   const text = row.status === '0' ? '启用' : '停用'; | ||||
|   try { | ||||
|     await proxy?.$modal.confirm('确认要"' + text + '""' + row.companyName + '"租户吗?'); | ||||
|     await changeTenantStatus(row.id, row.tenantId, row.status); | ||||
| @ -361,7 +361,7 @@ const handleExport = () => { | ||||
| /**同步租户字典*/ | ||||
| const handleSyncTenantDict = async () => { | ||||
|   await proxy?.$modal.confirm('确认要同步所有租户字典吗?'); | ||||
|   let res = await syncTenantDict(); | ||||
|   const res = await syncTenantDict(); | ||||
|   proxy?.$modal.msgSuccess(res.msg); | ||||
| }; | ||||
|  | ||||
|  | ||||
| @ -167,11 +167,11 @@ const getMenuTreeselect = async () => { | ||||
| // 所有菜单节点数据 | ||||
| const getMenuAllCheckedKeys = (): any => { | ||||
|   // 目前被选中的菜单节点 | ||||
|   let checkedKeys = menuTreeRef.value?.getCheckedKeys(); | ||||
|   const checkedKeys = menuTreeRef.value?.getCheckedKeys(); | ||||
|   // 半选中的菜单节点 | ||||
|   let halfCheckedKeys = menuTreeRef.value?.getHalfCheckedKeys(); | ||||
|   const halfCheckedKeys = menuTreeRef.value?.getHalfCheckedKeys(); | ||||
|   if (halfCheckedKeys) { | ||||
|     checkedKeys?.unshift.apply(checkedKeys, halfCheckedKeys); | ||||
|     checkedKeys?.unshift(...halfCheckedKeys); | ||||
|   } | ||||
|   return checkedKeys; | ||||
| }; | ||||
| @ -194,7 +194,7 @@ const getList = async () => { | ||||
|  | ||||
| // 租户套餐状态修改 | ||||
| const handleStatusChange = async (row: TenantPkgVO) => { | ||||
|   let text = row.status === '0' ? '启用' : '停用'; | ||||
|   const text = row.status === '0' ? '启用' : '停用'; | ||||
|   const [err] = await to(proxy?.$modal.confirm('确认要"' + text + '""' + row.packageName + '"套餐吗?') as Promise<any>); | ||||
|   if (err) { | ||||
|     row.status = row.status === '0' ? '1' : '0'; | ||||
| @ -241,7 +241,7 @@ const handleSelectionChange = (selection: TenantPkgVO[]) => { | ||||
| // 树权限(展开/折叠) | ||||
| const handleCheckedTreeExpand = (value: CheckboxValueType, type: string) => { | ||||
|   if (type == 'menu') { | ||||
|     let treeList = menuOptions.value; | ||||
|     const treeList = menuOptions.value; | ||||
|     for (let i = 0; i < treeList.length; i++) { | ||||
|       if (menuTreeRef.value) { | ||||
|         menuTreeRef.value.store.nodesMap[treeList[i].id].expanded = value as boolean; | ||||
|  | ||||
| @ -95,7 +95,7 @@ const getRowKey = (row: RoleVO): string => { | ||||
| }; | ||||
| /** 检查角色状态 */ | ||||
| const checkSelectable = (row: RoleVO): boolean => { | ||||
|   return row.status === "0"; | ||||
|   return row.status === '0'; | ||||
| }; | ||||
| /** 关闭按钮 */ | ||||
| const close = () => { | ||||
|  | ||||
| @ -498,7 +498,7 @@ const handleDelete = async (row?: UserVO) => { | ||||
|  | ||||
| /** 用户状态修改  */ | ||||
| const handleStatusChange = async (row: UserVO) => { | ||||
|   let text = row.status === '0' ? '启用' : '停用'; | ||||
|   const text = row.status === '0' ? '启用' : '停用'; | ||||
|   try { | ||||
|     await proxy?.$modal.confirm('确认要"' + text + '""' + row.userName + '"用户吗?'); | ||||
|     await api.changeUserStatus(row.userId, row.status); | ||||
|  | ||||
| @ -134,7 +134,7 @@ const beforeUpload = (file: UploadRawFile): any => { | ||||
| /** 上传图片 */ | ||||
| const uploadImg = async () => { | ||||
|   cropper.value.getCropBlob(async (data: any) => { | ||||
|     let formData = new FormData(); | ||||
|     const formData = new FormData(); | ||||
|     formData.append('avatarfile', data, options.fileName); | ||||
|     const res = await uploadAvatar(formData); | ||||
|     open.value = false; | ||||
|  | ||||
| @ -113,8 +113,8 @@ | ||||
| </template> | ||||
|  | ||||
| <script setup name="Gen" lang="ts"> | ||||
| import {delTable, genCode, getDataNames, listTable, previewTable, synchDb} from '@/api/tool/gen'; | ||||
| import {TableQuery, TableVO} from '@/api/tool/gen/types'; | ||||
| import { delTable, genCode, getDataNames, listTable, previewTable, synchDb } from '@/api/tool/gen'; | ||||
| import { TableQuery, TableVO } from '@/api/tool/gen/types'; | ||||
| import router from '@/router'; | ||||
| import ImportTable from './importTable.vue'; | ||||
|  | ||||
|  | ||||
| @ -34,7 +34,7 @@ | ||||
|         :default-expand-all="isExpandAll" | ||||
|         :tree-props="{ children: 'children', hasChildren: 'hasChildren' }" | ||||
|       > | ||||
|         <el-table-column label="分类名称" prop="categoryName" width="260"/> | ||||
|         <el-table-column label="分类名称" prop="categoryName" width="260" /> | ||||
|         <el-table-column label="显示顺序" align="center" prop="orderNum" width="200" /> | ||||
|         <el-table-column label="创建时间" align="center" prop="createTime" width="180" /> | ||||
|         <el-table-column label="操作" fixed="right" align="center" class-name="small-padding fixed-width"> | ||||
| @ -88,17 +88,16 @@ | ||||
| </template> | ||||
|  | ||||
| <script setup name="Category" lang="ts"> | ||||
| import { listCategory, getCategory, delCategory, addCategory, updateCategory } from "@/api/workflow/category"; | ||||
| import { listCategory, getCategory, delCategory, addCategory, updateCategory } from '@/api/workflow/category'; | ||||
| import { CategoryVO, CategoryQuery, CategoryForm } from '@/api/workflow/category/types'; | ||||
|  | ||||
| type CategoryOption = { | ||||
|   categoryId: number; | ||||
|   categoryName: string; | ||||
|   children?: CategoryOption[]; | ||||
| } | ||||
|  | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance;; | ||||
| }; | ||||
|  | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
|  | ||||
| const categoryList = ref<CategoryVO[]>([]); | ||||
| const categoryOptions = ref<CategoryOption[]>([]); | ||||
| @ -109,32 +108,29 @@ const loading = ref(false); | ||||
|  | ||||
| const queryFormRef = ref<ElFormInstance>(); | ||||
| const categoryFormRef = ref<ElFormInstance>(); | ||||
| const categoryTableRef = ref<ElTableInstance>() | ||||
| const categoryTableRef = ref<ElTableInstance>(); | ||||
|  | ||||
| const dialog = reactive<DialogOption>({ | ||||
|   visible: false, | ||||
|   title: '' | ||||
| }); | ||||
|  | ||||
|  | ||||
| const initFormData: CategoryForm = { | ||||
|   categoryId: undefined, | ||||
|   categoryName: "", | ||||
|   categoryName: '', | ||||
|   parentId: undefined, | ||||
|   orderNum: 0, | ||||
| } | ||||
|   orderNum: 0 | ||||
| }; | ||||
|  | ||||
| const data = reactive<PageData<CategoryForm, CategoryQuery>>({ | ||||
|   form: {...initFormData}, | ||||
|   form: { ...initFormData }, | ||||
|   queryParams: { | ||||
|     categoryName: undefined, | ||||
|     categoryName: undefined | ||||
|   }, | ||||
|   rules: { | ||||
|     categoryId: [ | ||||
|       { required: true, message: "流程分类ID不能为空", trigger: "blur" } | ||||
|     ], | ||||
|     parentId: [{ required: true, message: "请选择上级分类", trigger: "change" }], | ||||
|     categoryName: [{ required: true, message: "请输入分类名称", trigger: "blur" }] | ||||
|     categoryId: [{ required: true, message: '流程分类ID不能为空', trigger: 'blur' }], | ||||
|     parentId: [{ required: true, message: '请选择上级分类', trigger: 'change' }], | ||||
|     categoryName: [{ required: true, message: '请输入分类名称', trigger: 'blur' }] | ||||
|   } | ||||
| }); | ||||
|  | ||||
| @ -144,19 +140,19 @@ const { queryParams, form, rules } = toRefs(data); | ||||
| const getList = async () => { | ||||
|   loading.value = true; | ||||
|   const res = await listCategory(queryParams.value); | ||||
|   const data = proxy?.handleTree<CategoryVO>(res.data, "categoryId", "parentId"); | ||||
|   const data = proxy?.handleTree<CategoryVO>(res.data, 'categoryId', 'parentId'); | ||||
|   if (data) { | ||||
|     categoryList.value = data; | ||||
|     loading.value = false; | ||||
|   } | ||||
| } | ||||
| }; | ||||
|  | ||||
| /** 查询流程分类下拉树结构 */ | ||||
| const getTreeselect = async () => { | ||||
|   const res = await listCategory(); | ||||
|   categoryOptions.value = []; | ||||
|   // 处理树形数据 | ||||
|   const data = proxy?.handleTree<CategoryOption>(res.data, "categoryId", "parentId"); | ||||
|   const data = proxy?.handleTree<CategoryOption>(res.data, 'categoryId', 'parentId'); | ||||
|   if (data) { | ||||
|     categoryOptions.value = data; // 将处理后的树形数据赋值 | ||||
|   } | ||||
| @ -166,24 +162,24 @@ const getTreeselect = async () => { | ||||
| const cancel = () => { | ||||
|   reset(); | ||||
|   dialog.visible = false; | ||||
| } | ||||
| }; | ||||
|  | ||||
| // 表单重置 | ||||
| const reset = () => { | ||||
|   form.value = {...initFormData} | ||||
|   form.value = { ...initFormData }; | ||||
|   categoryFormRef.value?.resetFields(); | ||||
| } | ||||
| }; | ||||
|  | ||||
| /** 搜索按钮操作 */ | ||||
| const handleQuery = () => { | ||||
|   getList(); | ||||
| } | ||||
| }; | ||||
|  | ||||
| /** 重置按钮操作 */ | ||||
| const resetQuery = () => { | ||||
|   queryFormRef.value?.resetFields(); | ||||
|   handleQuery(); | ||||
| } | ||||
| }; | ||||
|  | ||||
| /** 新增按钮操作 */ | ||||
| const handleAdd = (row?: CategoryVO) => { | ||||
| @ -195,22 +191,22 @@ const handleAdd = (row?: CategoryVO) => { | ||||
|     form.value.parentId = undefined; | ||||
|   } | ||||
|   dialog.visible = true; | ||||
|   dialog.title = "添加流程分类"; | ||||
| } | ||||
|   dialog.title = '添加流程分类'; | ||||
| }; | ||||
|  | ||||
| /** 展开/折叠操作 */ | ||||
| const handleToggleExpandAll = () => { | ||||
|   isExpandAll.value = !isExpandAll.value; | ||||
|   toggleExpandAll(categoryList.value, isExpandAll.value) | ||||
| } | ||||
|   toggleExpandAll(categoryList.value, isExpandAll.value); | ||||
| }; | ||||
|  | ||||
| /** 展开/折叠操作 */ | ||||
| const toggleExpandAll = (data: CategoryVO[], status: boolean) => { | ||||
|   data.forEach((item) => { | ||||
|     categoryTableRef.value?.toggleRowExpansion(item, status) | ||||
|     if (item.children && item.children.length > 0) toggleExpandAll(item.children, status) | ||||
|   }) | ||||
| } | ||||
|     categoryTableRef.value?.toggleRowExpansion(item, status); | ||||
|     if (item.children && item.children.length > 0) toggleExpandAll(item.children, status); | ||||
|   }); | ||||
| }; | ||||
|  | ||||
| /** 修改按钮操作 */ | ||||
| const handleUpdate = async (row: CategoryVO) => { | ||||
| @ -222,8 +218,8 @@ const handleUpdate = async (row: CategoryVO) => { | ||||
|   const res = await getCategory(row.categoryId); | ||||
|   Object.assign(form.value, res.data); | ||||
|   dialog.visible = true; | ||||
|   dialog.title = "修改流程分类"; | ||||
| } | ||||
|   dialog.title = '修改流程分类'; | ||||
| }; | ||||
|  | ||||
| /** 提交按钮 */ | ||||
| const submitForm = () => { | ||||
| @ -231,25 +227,25 @@ const submitForm = () => { | ||||
|     if (valid) { | ||||
|       buttonLoading.value = true; | ||||
|       if (form.value.categoryId) { | ||||
|         await updateCategory(form.value).finally(() => buttonLoading.value = false); | ||||
|         await updateCategory(form.value).finally(() => (buttonLoading.value = false)); | ||||
|       } else { | ||||
|         await addCategory(form.value).finally(() => buttonLoading.value = false); | ||||
|         await addCategory(form.value).finally(() => (buttonLoading.value = false)); | ||||
|       } | ||||
|       proxy?.$modal.msgSuccess("操作成功"); | ||||
|       proxy?.$modal.msgSuccess('操作成功'); | ||||
|       dialog.visible = false; | ||||
|       getList(); | ||||
|     } | ||||
|   }); | ||||
| } | ||||
| }; | ||||
|  | ||||
| /** 删除按钮操作 */ | ||||
| const handleDelete = async (row: CategoryVO) => { | ||||
|   await proxy?.$modal.confirm('是否确认删除"' + row.categoryName + '"的分类?'); | ||||
|   loading.value = true; | ||||
|   await delCategory(row.categoryId).finally(() => loading.value = false); | ||||
|   await delCategory(row.categoryId).finally(() => (loading.value = false)); | ||||
|   await getList(); | ||||
|   proxy?.$modal.msgSuccess("删除成功"); | ||||
| } | ||||
|   proxy?.$modal.msgSuccess('删除成功'); | ||||
| }; | ||||
|  | ||||
| onMounted(() => { | ||||
|   getList(); | ||||
|  | ||||
| @ -222,7 +222,7 @@ const handleExport = () => { | ||||
| const handleCancelProcessApply = async (id: string) => { | ||||
|   await proxy?.$modal.confirm('是否确认撤销当前单据?'); | ||||
|   loading.value = true; | ||||
|   let data = { | ||||
|   const data = { | ||||
|     businessId: id, | ||||
|     message: '申请人撤销流程!' | ||||
|   }; | ||||
|  | ||||
| @ -4,7 +4,7 @@ | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script setup name="WarmFlow"> | ||||
| <script setup name="WarmFlow" lang="ts"> | ||||
| const { proxy } = getCurrentInstance(); | ||||
| import { onMounted } from 'vue'; | ||||
| import { getToken } from '@/utils/auth'; | ||||
| @ -24,12 +24,12 @@ const iframeLoaded = () => { | ||||
|   }; | ||||
| }; | ||||
| const open = async (definitionId, disabled) => { | ||||
|   let url = baseUrl + `/warm-flow-ui/index.html?id=${definitionId}&disabled=${disabled}`; | ||||
|   const url = baseUrl + `/warm-flow-ui/index.html?id=${definitionId}&disabled=${disabled}`; | ||||
|   iframeUrl.value = url + '&Authorization=Bearer ' + getToken() + '&clientid=' + import.meta.env.VITE_APP_CLIENT_ID; | ||||
| }; | ||||
| /** 关闭按钮 */ | ||||
| function close() { | ||||
|   const obj = { path: '/workflow/processDefinition', query: {activeName: proxy.$route.query.activeName}}; | ||||
|   const obj = { path: '/workflow/processDefinition', query: { activeName: proxy.$route.query.activeName } }; | ||||
|   proxy.$tab.closeOpenPage(obj); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -197,7 +197,7 @@ import { categoryTree } from '@/api/workflow/category'; | ||||
| import { CategoryTreeVO } from '@/api/workflow/category/types'; | ||||
| import { FlowDefinitionQuery, FlowDefinitionVo, FlowDefinitionForm } from '@/api/workflow/definition/types'; | ||||
| import { UploadRequestOptions, TabsPaneContext } from 'element-plus'; | ||||
| import { ElMessageBoxOptions } from "element-plus/es/components/message-box/src/message-box.type"; | ||||
| import { ElMessageBoxOptions } from 'element-plus/es/components/message-box/src/message-box.type'; | ||||
|  | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
|  | ||||
| @ -326,7 +326,7 @@ const handleSelectionChange = (selection: any) => { | ||||
| }; | ||||
| //分页 | ||||
| const getPageList = async () => { | ||||
|   let query = proxy.$route.query; | ||||
|   const query = proxy.$route.query; | ||||
|   if (query.activeName) { | ||||
|     activeName.value = query.activeName; | ||||
|   } | ||||
| @ -411,7 +411,7 @@ const handlerBeforeUpload = () => { | ||||
| }; | ||||
| //部署文件 | ||||
| const handlerImportDefinition = (data: UploadRequestOptions): XMLHttpRequest => { | ||||
|   let formData = new FormData(); | ||||
|   const formData = new FormData(); | ||||
|   uploadDialogLoading.value = true; | ||||
|   formData.append('file', data.file); | ||||
|   formData.append('category', selectCategory.value); | ||||
| @ -467,7 +467,7 @@ const reset = () => { | ||||
| const handleAdd = async () => { | ||||
|   reset(); | ||||
|   if (queryParams.value.category != '') { | ||||
|     form.value.category = queryParams.value.category | ||||
|     form.value.category = queryParams.value.category; | ||||
|   } | ||||
|   modelDialog.visible = true; | ||||
|   modelDialog.title = '新增流程'; | ||||
|  | ||||
| @ -352,7 +352,7 @@ const handleInvalid = async (row: FlowInstanceVO) => { | ||||
|   await proxy?.$modal.confirm('是否确认作废?'); | ||||
|   loading.value = true; | ||||
|   if ('running' === tab.value) { | ||||
|     let param = { | ||||
|     const param = { | ||||
|       id: row.id, | ||||
|       comment: deleteReason.value | ||||
|     }; | ||||
| @ -381,7 +381,7 @@ const handleInstanceVariable = async (row: FlowInstanceVO) => { | ||||
|   variableLoading.value = true; | ||||
|   variableVisible.value = true; | ||||
|   processDefinitionName.value = row.flowName; | ||||
|   let data = await instanceVariable(row.id); | ||||
|   const data = await instanceVariable(row.id); | ||||
|   variables.value = data.data.variable; | ||||
|   variableLoading.value = false; | ||||
| }; | ||||
|  | ||||
| @ -222,7 +222,7 @@ const handleCancelProcessApply = async (businessId: string) => { | ||||
|   await proxy?.$modal.confirm('是否确认撤销当前单据?'); | ||||
|   loading.value = true; | ||||
|   if ('running' === tab.value) { | ||||
|     let data = { | ||||
|     const data = { | ||||
|       businessId: businessId, | ||||
|       message: '申请人撤销流程!' | ||||
|     }; | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 疯狂的狮子Li
					疯狂的狮子Li