1
This commit is contained in:
		
							
								
								
									
										60
									
								
								openhis-ui-vue3/src/plugins/auth.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								openhis-ui-vue3/src/plugins/auth.js
									
									
									
									
									
										Normal file
									
								
							| @@ -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) | ||||
|     }) | ||||
|   } | ||||
| } | ||||
							
								
								
									
										77
									
								
								openhis-ui-vue3/src/plugins/cache.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								openhis-ui-vue3/src/plugins/cache.js
									
									
									
									
									
										Normal file
									
								
							| @@ -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 | ||||
| } | ||||
							
								
								
									
										79
									
								
								openhis-ui-vue3/src/plugins/download.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								openhis-ui-vue3/src/plugins/download.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,79 @@ | ||||
| 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/openhis' | ||||
|  | ||||
| const baseURL = import.meta.env.VITE_APP_BASE_API | ||||
| let downloadLoadingInstance; | ||||
|  | ||||
| export default { | ||||
|   name(name, isDelete = true) { | ||||
|     var url = baseURL + "/common/download?fileName=" + encodeURIComponent(name) + "&delete=" + isDelete | ||||
|     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]) | ||||
|         this.saveAs(blob, decodeURIComponent(res.headers['download-filename'])) | ||||
|       } else { | ||||
|         this.printErrMsg(res.data); | ||||
|       } | ||||
|     }) | ||||
|   }, | ||||
|   resource(resource) { | ||||
|     var url = baseURL + "/common/download/resource?resource=" + encodeURIComponent(resource); | ||||
|     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]) | ||||
|         this.saveAs(blob, decodeURIComponent(res.headers['download-filename'])) | ||||
|       } else { | ||||
|         this.printErrMsg(res.data); | ||||
|       } | ||||
|     }) | ||||
|   }, | ||||
|   zip(url, name) { | ||||
|     var url = baseURL + url | ||||
|     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/zip' }) | ||||
|         this.saveAs(blob, name) | ||||
|       } else { | ||||
|         this.printErrMsg(res.data); | ||||
|       } | ||||
|       downloadLoadingInstance.close(); | ||||
|     }).catch((r) => { | ||||
|       console.error(r) | ||||
|       ElMessage.error('下载文件出现错误,请联系管理员!') | ||||
|       downloadLoadingInstance.close(); | ||||
|     }) | ||||
|   }, | ||||
|   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); | ||||
|   } | ||||
| } | ||||
|  | ||||
							
								
								
									
										18
									
								
								openhis-ui-vue3/src/plugins/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								openhis-ui-vue3/src/plugins/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -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 | ||||
| } | ||||
							
								
								
									
										82
									
								
								openhis-ui-vue3/src/plugins/modal.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								openhis-ui-vue3/src/plugins/modal.js
									
									
									
									
									
										Normal file
									
								
							| @@ -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(); | ||||
|   } | ||||
| } | ||||
							
								
								
									
										69
									
								
								openhis-ui-vue3/src/plugins/tab.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								openhis-ui-vue3/src/plugins/tab.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | ||||
| 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(({ visitedViews }) => { | ||||
|         const latestView = visitedViews.slice(-1)[0] | ||||
|         if (latestView) { | ||||
|           return router.push(latestView.fullPath) | ||||
|         } | ||||
|         return router.push('/'); | ||||
|       }); | ||||
|     } | ||||
|     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); | ||||
|   } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 guorui
					guorui