| | |
| | | ENV = development |
| | | |
| | | # 本地环境接口地址 |
| | | VITE_API_URL = http://localhost:8181/ |
| | | VITE_API_URL = 'http://testbs.ihemodialysis.com/' |
| | |
| | | ENV = production |
| | | |
| | | # 线上环境接口地址 |
| | | VITE_API_URL = https://lyt-top.gitee.io/vue-next-admin-preview/ |
| | | VITE_API_URL = 'https://hemobs.icoldchain.cn/' |
| | |
| | | { |
| | | "name": "vue-next-admin", |
| | | "name": "vue-nutritional-management", |
| | | "version": "2.4.33", |
| | | "lockfileVersion": 2, |
| | | "requires": true, |
| | | "packages": { |
| | | "": { |
| | | "name": "vue-next-admin", |
| | | "name": "vue-nutritional-management", |
| | | "version": "2.4.33", |
| | | "license": "MIT", |
| | | "dependencies": { |
| | |
| | | }, |
| | | "node_modules/@element-plus/icons-vue": { |
| | | "version": "2.3.1", |
| | | "resolved": "https://registry.npmjs.org/@element-plus/icons-vue/-/icons-vue-2.3.1.tgz", |
| | | "resolved": "https://registry.npmmirror.com/@element-plus/icons-vue/-/icons-vue-2.3.1.tgz", |
| | | "integrity": "sha512-XxVUZv48RZAd87ucGS48jPf6pKu0yV5UCg9f4FFwtrYxXOwWuVJo6wOvSLKEoMQKjv8GsX/mhP6UsC1lRwbUWg==", |
| | | "peerDependencies": { |
| | | "vue": "^3.2.0" |
| | |
| | | }, |
| | | "@element-plus/icons-vue": { |
| | | "version": "2.3.1", |
| | | "resolved": "https://registry.npmjs.org/@element-plus/icons-vue/-/icons-vue-2.3.1.tgz", |
| | | "resolved": "https://registry.npmmirror.com/@element-plus/icons-vue/-/icons-vue-2.3.1.tgz", |
| | | "integrity": "sha512-XxVUZv48RZAd87ucGS48jPf6pKu0yV5UCg9f4FFwtrYxXOwWuVJo6wOvSLKEoMQKjv8GsX/mhP6UsC1lRwbUWg==", |
| | | "requires": {} |
| | | }, |
| New file |
| | |
| | | import request from "/@/utils/request"; |
| | | |
| | | /** |
| | | * 查询检索血透患者 |
| | | *@param params 要传的参数值 |
| | | *@return 返回的接口数据 |
| | | */ |
| | | export function QueryList(params: object) { |
| | | return request({ |
| | | url: '/patient/info/list', |
| | | method: 'post', |
| | | headers: { |
| | | 'Content-Type': 'application/x-www-form-urlencoded' |
| | | }, |
| | | params |
| | | }); |
| | | } |
| | |
| | | import request from '/@/utils/request'; |
| | | |
| | | /** |
| | | * (不建议写成 request.post(xxx),因为这样 post 时,无法 params 与 data 同时传参) |
| | | * |
| | | * 登录api接口集合 |
| | | * @method signIn 用户登录 |
| | | * @method signOut 用户退出登录 |
| | | * 用户登录 |
| | | * @param params 要传的参数值 |
| | | * @returns 返回接口数据 |
| | | */ |
| | | export function useLoginApi() { |
| | | return { |
| | | signIn: (data: object) => { |
| | | return request({ |
| | | url: '/user/signIn', |
| | | method: 'post', |
| | | data, |
| | | }); |
| | | export function signIn(params: string) { |
| | | return request({ |
| | | url: '/user/info/login', |
| | | method: 'post', |
| | | headers: { |
| | | 'Content-Type': 'application/x-www-form-urlencoded' |
| | | }, |
| | | signOut: (data: object) => { |
| | | return request({ |
| | | url: '/user/signOut', |
| | | method: 'post', |
| | | data, |
| | | }); |
| | | }, |
| | | }; |
| | | data: params, |
| | | }); |
| | | } |
| | | /** |
| | | * 用户退出登录 |
| | | * @param params 要传的参数值 |
| | | * @returns 返回接口数据 |
| | | */ |
| | | export function signOut(params: object) { |
| | | return request({ |
| | | url: '/user/signOut', |
| | | method: 'post', |
| | | data: params, |
| | | }); |
| | | } |
| | | export function getuserinfo() { |
| | | return request({ |
| | | url: '/user/info/getUserInfo', |
| | | method: 'post' |
| | | }) |
| | | } |
| | |
| | | <template> |
| | | <el-container class="layout-container"> |
| | | <LayoutAside /> |
| | | <!-- 不要菜单栏 --> |
| | | <!-- <LayoutAside /> --> |
| | | <el-container class="layout-container-view h100"> |
| | | |
| | | <el-scrollbar ref="layoutScrollbarRef" class="layout-backtop"> |
| | | <LayoutHeader /> |
| | | <LayoutMain ref="layoutMainRef" /> |
| | |
| | | <template> |
| | | <div v-if="isShowBreadcrumb" class="layout-navbars-breadcrumb"> |
| | | <!-- <div v-if="isShowBreadcrumb" class="layout-navbars-breadcrumb"> |
| | | <SvgIcon |
| | | class="layout-navbars-breadcrumb-icon" |
| | | :name="themeConfig.isCollapse ? 'ele-Expand' : 'ele-Fold'" |
| | |
| | | </el-breadcrumb-item> |
| | | </transition-group> |
| | | </el-breadcrumb> |
| | | </div> --> |
| | | <div class="layout-navbars-breadcrumb"> |
| | | |
| | | <el-avatar shape="square" style="width: 48px; height: 35px;background-color: #ffffff;margin-right: 10px;margin-left: 10px;" fit="contain" :src="logo" /> |
| | | |
| | | <div class="titleHome">营养管理系统</div> |
| | | </div> |
| | | </template> |
| | | |
| | |
| | | import { storeToRefs } from 'pinia'; |
| | | import { useThemeConfig } from '/@/stores/themeConfig'; |
| | | import { useRoutesList } from '/@/stores/routesList'; |
| | | import logo from '/@/assets/imgs/logo.png' |
| | | |
| | | // 定义变量内容 |
| | | const stores = useRoutesList(); |
| | |
| | | font-size: 18px; |
| | | color: var(--next-bg-topBarColor); |
| | | height: 100%; |
| | | width: 40px; |
| | | width: 48px; |
| | | opacity: 0.8; |
| | | &:hover { |
| | | opacity: 1; |
| | |
| | | color: var(--el-color-primary) !important; |
| | | } |
| | | } |
| | | .titleHome{ |
| | | height: 25px; |
| | | font-family: HYYakuHei, HYYakuHei; |
| | | font-weight: normal; |
| | | font-size: 21px; |
| | | color: #333333; |
| | | line-height: 25px; |
| | | letter-spacing: 1px; |
| | | text-align: left; |
| | | font-style: normal; |
| | | } |
| | | } |
| | | </style> |
| | |
| | | <div class="layout-navbars-breadcrumb-index"> |
| | | <Logo v-if="setIsShowLogo" /> |
| | | <Breadcrumb /> |
| | | |
| | | <Horizontal :menuList="state.menuList" v-if="isLayoutTransverse" /> |
| | | <User /> |
| | | </div> |
| | |
| | | import other from '/@/utils/other'; |
| | | |
| | | import ElementPlus from 'element-plus'; |
| | | import * as ElementPlusIconsVue from '@element-plus/icons-vue' |
| | | import '/@/theme/index.scss'; |
| | | import VueGridLayout from 'vue-grid-layout'; |
| | | |
| | | const app = createApp(App); |
| | | |
| | | //您需要从 @element-plus/icons-vue 中导入所有图标并进行全局注册。 |
| | | for (const [key, component] of Object.entries(ElementPlusIconsVue)) { |
| | | app.component(key, component) |
| | | } |
| | | directive(app); |
| | | other.elSvg(app); |
| | | |
| | |
| | | { |
| | | path: '/home', |
| | | name: 'home', |
| | | component: () => import('/@/views/home/index.vue'), |
| | | component: () => import('../views/home/index.vue'), |
| | | meta: { |
| | | title: 'message.router.home', |
| | | isLink: '', |
| | |
| | | // 是否开启菜单手风琴效果 |
| | | isUniqueOpened: true, |
| | | // 是否开启固定 Header |
| | | isFixedHeader: false, |
| | | isFixedHeader: true, |
| | | // 初始化变量,用于更新菜单 el-scrollbar 的高度,请勿删除 |
| | | isFixedHeaderChange: false, |
| | | // 是否开启经典布局分割菜单(仅经典布局生效) |
| | |
| | | import { defineStore } from 'pinia'; |
| | | import Cookies from 'js-cookie'; |
| | | import { Session } from '/@/utils/storage'; |
| | | import { getuserinfo } from '../api/login'; |
| | | |
| | | /** |
| | | * 用户信息 |
| | |
| | | time: 0, |
| | | roles: [], |
| | | authBtnList: [], |
| | | clientCode:'', |
| | | clientName:'' |
| | | }, |
| | | }), |
| | | actions: { |
| | |
| | | if (Session.get('userInfo')) { |
| | | this.userInfos = Session.get('userInfo'); |
| | | } else { |
| | | console.log('Session里没有userInfo') |
| | | const userInfos = <UserInfos>await this.getApiUserInfo(); |
| | | this.userInfos = userInfos; |
| | | } |
| | |
| | | // 模拟接口数据 |
| | | // https://gitee.com/lyt-top/vue-next-admin/issues/I5F1HP |
| | | async getApiUserInfo() { |
| | | const userinfoRes = await getuserinfo() |
| | | console.log('-----------用token 换用户信息---------------') |
| | | console.log(userinfoRes.data) |
| | | const userRet=userinfoRes.data |
| | | return new Promise((resolve) => { |
| | | setTimeout(() => { |
| | | // 模拟数据,请求接口时,记得删除多余代码及对应依赖的引入 |
| | | const userName = Cookies.get('userName'); |
| | | const userName = userRet.userName |
| | | // 模拟数据 |
| | | let defaultRoles: Array<string> = []; |
| | | let defaultAuthBtnList: Array<string> = []; |
| | |
| | | // test 按钮权限标识 |
| | | let testAuthBtnList: Array<string> = ['btn.add', 'btn.link']; |
| | | // 不同用户模拟不同的用户权限 |
| | | if (userName === 'admin') { |
| | | let isadmin=false; |
| | | if(userRet.roles.length > 0){ |
| | | const x=userRet.roles.findIndex(e=>{return e.roleName==='admin'}) |
| | | if(x>=0){ |
| | | isadmin=true |
| | | } |
| | | else{ |
| | | isadmin=false |
| | | } |
| | | } |
| | | if (isadmin) { |
| | | defaultRoles = adminRoles; |
| | | defaultAuthBtnList = adminAuthBtnList; |
| | | } else { |
| | |
| | | // 用户信息模拟数据 |
| | | const userInfos = { |
| | | userName: userName, |
| | | photo: |
| | | userName === 'admin' |
| | | photo:userRet.userAvatar==='' |
| | | ? 'https://img2.baidu.com/it/u=1978192862,2048448374&fm=253&fmt=auto&app=138&f=JPEG?w=504&h=500' |
| | | : 'https://img2.baidu.com/it/u=2370931438,70387529&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500', |
| | | : userRet.userAvatar, |
| | | time: new Date().getTime(), |
| | | roles: defaultRoles, |
| | | authBtnList: defaultAuthBtnList, |
| | | clientCode:userRet.currentClientInfo.code, |
| | | clientName:userRet.currentClientInfo.clientName, |
| | | }; |
| | | Session.set('userInfo', userInfos); |
| | | // Session.set('userInfo', userInfos); |
| | | resolve(userInfos); |
| | | }, 0); |
| | | }); |
| | |
| | | roles: string[]; |
| | | time: number; |
| | | userName: string; |
| | | clientCode:string, |
| | | clientName:string |
| | | [key: string]: T; |
| | | } |
| | | declare interface UserInfosState { |
| | |
| | | (config) => { |
| | | // 在发送请求之前做些什么 token |
| | | if (Session.get('token')) { |
| | | config.headers!['Authorization'] = `${Session.get('token')}`; |
| | | config.headers!['Authorization'] = `Bearer ${Session.get('token')}`; |
| | | } |
| | | return config; |
| | | }, |
| | |
| | | .then(() => {}) |
| | | .catch(() => {}); |
| | | } |
| | | if(res.code===200){ |
| | | return response.data; |
| | | } |
| | | if(res.code === 400){ |
| | | ElMessage.error(res.message); |
| | | } |
| | | if(res.code === 500){ |
| | | ElMessage.error(res.message); |
| | | } |
| | | return Promise.reject(service.interceptors.response); |
| | | } else { |
| | | return res; |
| | |
| | | ElMessage.error('网络超时'); |
| | | } else if (error.message == 'Network Error') { |
| | | ElMessage.error('网络连接错误'); |
| | | } else { |
| | | } else if (error.message.indexOf('status code 401') != -1) { |
| | | ElMessage.error('token 过期了'); |
| | | Session.clear(); // 清除浏览器全部临时缓存 |
| | | window.location.href = '/'; // 去登录页 |
| | | }else { |
| | | if (error.response.data) ElMessage.error(error.response.statusText); |
| | | else ElMessage.error('接口路径找不到'); |
| | | } |
| | | console.log |
| | | return Promise.reject(error); |
| | | } |
| | | ); |
| | |
| | | <template> |
| | | <div class="home-container layout-pd"> |
| | | <el-row :gutter="15" class="home-card-one mb15"> |
| | | <el-col |
| | | :xs="24" |
| | | :sm="12" |
| | | :md="12" |
| | | :lg="6" |
| | | :xl="6" |
| | | v-for="(v, k) in state.homeOne" |
| | | :key="k" |
| | | :class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }" |
| | | > |
| | | <div class="home-card-item flex"> |
| | | <div class="flex-margin flex w100" :class="` home-one-animation${k}`"> |
| | | <div class="flex-auto"> |
| | | <span class="font30">{{ v.num1 }}</span> |
| | | <span class="ml5 font16" :style="{ color: v.color1 }">{{ v.num2 }}%</span> |
| | | <div class="mt10">{{ v.num3 }}</div> |
| | | </div> |
| | | <div class="home-card-item-icon flex" :style="{ background: `var(${v.color2})` }"> |
| | | <i class="flex-margin font32" :class="v.num4" :style="{ color: `var(${v.color3})` }"></i> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row :gutter="15" class="home-card-two mb15"> |
| | | <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16"> |
| | | <div class="home-card-item"> |
| | | <div style="height: 100%" ref="homeLineRef"></div> |
| | | </div> |
| | | </el-col> |
| | | <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8" class="home-media"> |
| | | <div class="home-card-item"> |
| | | <div style="height: 100%" ref="homePieRef"></div> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row :gutter="15" class="home-card-three"> |
| | | <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8"> |
| | | <div class="home-card-item"> |
| | | <div class="home-card-item-title">快捷导航工具</div> |
| | | <div class="home-monitor"> |
| | | <div class="flex-warp"> |
| | | <div class="flex-warp-item" v-for="(v, k) in state.homeThree" :key="k"> |
| | | <div class="flex-warp-item-box" :class="`home-animation${k}`"> |
| | | <div class="flex-margin"> |
| | | <i :class="v.icon" :style="{ color: v.iconColor }"></i> |
| | | <span class="pl5">{{ v.label }}</span> |
| | | <div class="mt10">{{ v.value }}</div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </el-col> |
| | | <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16" class="home-media"> |
| | | <div class="home-card-item"> |
| | | <div style="height: 100%" ref="homeBarRef"></div> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | | <div class="home-container layout-pd "> |
| | | <el-row :gutter="15" > |
| | | <el-col :span="4" class="patTabel"> |
| | | <el-table :data="state.filterTableData" |
| | | stripe |
| | | :height="state.tableHeight.left" |
| | | size="default" |
| | | highlight-current-row |
| | | @current-change="handleCurrentChange" |
| | | style="width: 100%"> |
| | | <el-table-column> |
| | | <template #header> |
| | | <div class="home-title"> |
| | | <el-avatar shape="square" style="width: 16px; height: 16px;background-color: #ffffff;margin-right: 10px;margin-left: 10px;" fit="contain" :src="huanzheliebiao" /> |
| | | |
| | | <div class="titleHome">患者列表</div> |
| | | </div> |
| | | <el-input size="default" @change="getPatients" v-model="state.search" placeholder="支持模糊查询" :prefix-icon="Search"/> |
| | | </template> |
| | | <template #default="scope"> |
| | | <el-row> |
| | | <el-col :span="12">{{scope.row.patientName}}</el-col> |
| | | <el-col :span="6">{{scope.row.patientGenderText}}</el-col> |
| | | <el-col :span="6">{{scope.row.age}}</el-col> |
| | | </el-row> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | </el-col> |
| | | <el-col :span="20" class="detailRight"> |
| | | <el-tabs v-model="state.activeName" class="demo-tabs" @tab-click="handleClick"> |
| | | <el-tab-pane label="患者档案" name="患者档案"> |
| | | <template #label> |
| | | <span class="custom-tabs-label home-title"> |
| | | <el-icon><Avatar /></el-icon> |
| | | <span style="margin-left: 5px">患者档案</span> |
| | | </span> |
| | | </template> |
| | | 患者档案 |
| | | </el-tab-pane> |
| | | <el-tab-pane label="生化数据" name="生化数据"> |
| | | <template #label> |
| | | <span class="custom-tabs-label home-title"> |
| | | <el-icon><Aim /></el-icon> |
| | | <span style="margin-left: 5px">生化数据</span> |
| | | </span> |
| | | </template> |
| | | Config |
| | | </el-tab-pane> |
| | | <el-tab-pane label="用药记录" name="用药记录"> |
| | | <template #label> |
| | | <span class="custom-tabs-label home-title"> |
| | | <el-icon><Edit /></el-icon> |
| | | <span style="margin-left: 5px">用药记录</span> |
| | | </span> |
| | | </template> |
| | | Role |
| | | </el-tab-pane> |
| | | <el-tab-pane label="历史服务" name="历史服务"> |
| | | <template #label> |
| | | <span class="custom-tabs-label home-title"> |
| | | <el-icon><ZoomIn /></el-icon> |
| | | <span style="margin-left: 5px">历史服务</span> |
| | | </span> |
| | | </template> |
| | | Task |
| | | </el-tab-pane> |
| | | <el-tab-pane label="膳食调查" name="膳食调查"> |
| | | <template #label> |
| | | <span class="custom-tabs-label home-title"> |
| | | <el-icon><Notification /></el-icon> |
| | | <span style="margin-left: 5px">膳食调查</span> |
| | | </span> |
| | | </template> |
| | | Task |
| | | </el-tab-pane> |
| | | <el-tab-pane label="营养筛查评估" name="营养筛查评估"> |
| | | <template #label> |
| | | <span class="custom-tabs-label home-title"> |
| | | <el-icon><Histogram /></el-icon> |
| | | <span style="margin-left: 5px">营养筛查评估</span> |
| | | </span> |
| | | </template> |
| | | Task |
| | | </el-tab-pane> |
| | | <el-tab-pane label="方案" name="方案"> |
| | | <template #label> |
| | | <span class="custom-tabs-label home-title"> |
| | | <el-icon><Grid /></el-icon> |
| | | <span style="margin-left: 5px">方案</span> |
| | | </span> |
| | | </template> |
| | | Task |
| | | </el-tab-pane> |
| | | <el-tab-pane label="随访记录" name="随访记录"> |
| | | <template #label> |
| | | <span class="custom-tabs-label home-title"> |
| | | <el-icon><ChatDotRound /></el-icon> |
| | | <span style="margin-left: 5px">随访记录</span> |
| | | </span> |
| | | </template> |
| | | Task |
| | | </el-tab-pane> |
| | | </el-tabs> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </template> |
| | | |
| | | <script setup lang="ts" name="home"> |
| | | import huanzheliebiao from '/@/assets/imgs/huanzheliebiao.png' |
| | | import { reactive, onMounted, ref, watch, nextTick, onActivated, markRaw } from 'vue'; |
| | | import * as echarts from 'echarts'; |
| | | import {QueryList} from '/@/api/Patients' |
| | | import { storeToRefs } from 'pinia'; |
| | | import { useThemeConfig } from '/@/stores/themeConfig'; |
| | | import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; |
| | | |
| | | // 定义变量内容 |
| | | const homeLineRef = ref(); |
| | | const homePieRef = ref(); |
| | | const homeBarRef = ref(); |
| | | const storesTagsViewRoutes = useTagsViewRoutes(); |
| | | const storesThemeConfig = useThemeConfig(); |
| | | const { themeConfig } = storeToRefs(storesThemeConfig); |
| | | const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); |
| | | import { useUserInfo } from '/@/stores/userInfo'; |
| | | const stores = useUserInfo(); |
| | | const { userInfos } = storeToRefs(stores); |
| | | import { ElLoading, TabsPaneContext } from 'element-plus' |
| | | import { Search } from '@element-plus/icons-vue' |
| | | interface User { |
| | | code:string, |
| | | patientName: string |
| | | patientGenderText: string |
| | | age: string |
| | | } |
| | | const currentRow=ref() |
| | | const state = reactive({ |
| | | global: { |
| | | homeChartOne: null, |
| | |
| | | homeCharThree: null, |
| | | dispose: [null, '', undefined], |
| | | } as any, |
| | | homeOne: [ |
| | | { |
| | | num1: '125,12', |
| | | num2: '-12.32', |
| | | num3: '订单统计信息', |
| | | num4: 'fa fa-meetup', |
| | | color1: '#FF6462', |
| | | color2: '--next-color-primary-lighter', |
| | | color3: '--el-color-primary', |
| | | }, |
| | | { |
| | | num1: '653,33', |
| | | num2: '+42.32', |
| | | num3: '月度计划信息', |
| | | num4: 'iconfont icon-ditu', |
| | | color1: '#6690F9', |
| | | color2: '--next-color-success-lighter', |
| | | color3: '--el-color-success', |
| | | }, |
| | | { |
| | | num1: '125,65', |
| | | num2: '+17.32', |
| | | num3: '年度计划信息', |
| | | num4: 'iconfont icon-zaosheng', |
| | | color1: '#6690F9', |
| | | color2: '--next-color-warning-lighter', |
| | | color3: '--el-color-warning', |
| | | }, |
| | | { |
| | | num1: '520,43', |
| | | num2: '-10.01', |
| | | num3: '访问统计信息', |
| | | num4: 'fa fa-github-alt', |
| | | color1: '#FF6462', |
| | | color2: '--next-color-danger-lighter', |
| | | color3: '--el-color-danger', |
| | | }, |
| | | ], |
| | | homeThree: [ |
| | | { |
| | | icon: 'iconfont icon-yangan', |
| | | label: '浅粉红', |
| | | value: '2.1%OBS/M', |
| | | iconColor: '#F72B3F', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-wendu', |
| | | label: '深红(猩红)', |
| | | value: '30℃', |
| | | iconColor: '#91BFF8', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-shidu', |
| | | label: '淡紫红', |
| | | value: '57%RH', |
| | | iconColor: '#88D565', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-shidu', |
| | | label: '弱紫罗兰红', |
| | | value: '107w', |
| | | iconColor: '#88D565', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '中紫罗兰红', |
| | | value: '57DB', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '紫罗兰', |
| | | value: '57PV', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '暗紫罗兰', |
| | | value: '517Cpd', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '幽灵白', |
| | | value: '12kg', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '海军蓝', |
| | | value: '64fm', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | ], |
| | | myCharts: [] as EmptyArrayType, |
| | | charts: { |
| | | theme: '', |
| | | bgColor: '', |
| | | color: '#303133', |
| | | }, |
| | | filterTableData:[ |
| | | { |
| | | name: '张山', |
| | | sex: '男', |
| | | age: '12', |
| | | }, |
| | | { |
| | | name: '张山二', |
| | | sex: '男', |
| | | age: '12', |
| | | }, |
| | | { |
| | | name: '王二小', |
| | | sex: '男', |
| | | age: '12', |
| | | }, |
| | | ], |
| | | activeName:'患者档案', |
| | | tableHeight:{ |
| | | left:0, |
| | | detailRight:0 |
| | | }, |
| | | search:'' |
| | | }); |
| | | onMounted(()=>{ |
| | | setTableHeight() |
| | | getPatients() |
| | | }) |
| | | const handleCurrentChange = (val: User | undefined) => { |
| | | currentRow.value = val |
| | | } |
| | | const getPatients=()=>{ |
| | | const loading = ElLoading.service({ |
| | | lock: true, |
| | | text: 'Loading', |
| | | background: 'rgba(0, 0, 0, 0.7)', |
| | | }) |
| | | var ps= { |
| | | page: 0, |
| | | size: 0, |
| | | wherecondition:`client_code="${userInfos.value.clientCode}" and (patient_name like "%${state.search.toLowerCase()}%" |
| | | OR patient_name_py like "%${state.search.toLowerCase()}%")` |
| | | } |
| | | QueryList(ps).then(res=>{ |
| | | console.log('----------------患者--------') |
| | | console.log(res.data) |
| | | state.filterTableData=res.data.list |
| | | }).finally(e=>{ |
| | | loading.close() |
| | | }) |
| | | } |
| | | /**设置高度 */ |
| | | const setTableHeight = () => { |
| | | let height = document.documentElement.clientHeight; |
| | | console.log('窗口高度') |
| | | const navDom = document.querySelector('.layout-navbars-breadcrumb-index'); |
| | | if (navDom) { |
| | | height -= navDom.scrollHeight; |
| | | } |
| | | state.tableHeight.detailRight=height |
| | | state.tableHeight.left = height-77; |
| | | // const demoFormDom = document.querySelector('.card_box_search') |
| | | |
| | | // 折线图 |
| | | const initLineChart = () => { |
| | | if (!state.global.dispose.some((b: any) => b === state.global.homeChartOne)) state.global.homeChartOne.dispose(); |
| | | state.global.homeChartOne = markRaw(echarts.init(homeLineRef.value, state.charts.theme)); |
| | | const option = { |
| | | backgroundColor: state.charts.bgColor, |
| | | title: { |
| | | text: '政策补贴额度', |
| | | x: 'left', |
| | | textStyle: { fontSize: '15', color: state.charts.color }, |
| | | }, |
| | | grid: { top: 70, right: 20, bottom: 30, left: 30 }, |
| | | tooltip: { trigger: 'axis' }, |
| | | legend: { data: ['预购队列', '最新成交价'], right: 0 }, |
| | | xAxis: { |
| | | data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'], |
| | | }, |
| | | yAxis: [ |
| | | { |
| | | type: 'value', |
| | | name: '价格', |
| | | splitLine: { show: true, lineStyle: { type: 'dashed', color: '#f5f5f5' } }, |
| | | }, |
| | | ], |
| | | series: [ |
| | | { |
| | | name: '预购队列', |
| | | type: 'line', |
| | | symbolSize: 6, |
| | | symbol: 'circle', |
| | | smooth: true, |
| | | data: [0, 41.1, 30.4, 65.1, 53.3, 53.3, 53.3, 41.1, 30.4, 65.1, 53.3, 10], |
| | | lineStyle: { color: '#fe9a8b' }, |
| | | itemStyle: { color: '#fe9a8b', borderColor: '#fe9a8b' }, |
| | | areaStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ |
| | | { offset: 0, color: '#fe9a8bb3' }, |
| | | { offset: 1, color: '#fe9a8b03' }, |
| | | ]), |
| | | }, |
| | | }, |
| | | { |
| | | name: '最新成交价', |
| | | type: 'line', |
| | | symbolSize: 6, |
| | | symbol: 'circle', |
| | | smooth: true, |
| | | data: [0, 24.1, 7.2, 15.5, 42.4, 42.4, 42.4, 24.1, 7.2, 15.5, 42.4, 0], |
| | | lineStyle: { color: '#9E87FF' }, |
| | | itemStyle: { color: '#9E87FF', borderColor: '#9E87FF' }, |
| | | areaStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ |
| | | { offset: 0, color: '#9E87FFb3' }, |
| | | { offset: 1, color: '#9E87FF03' }, |
| | | ]), |
| | | }, |
| | | emphasis: { |
| | | itemStyle: { |
| | | color: { |
| | | type: 'radial', |
| | | x: 0.5, |
| | | y: 0.5, |
| | | r: 0.5, |
| | | colorStops: [ |
| | | { offset: 0, color: '#9E87FF' }, |
| | | { offset: 0.4, color: '#9E87FF' }, |
| | | { offset: 0.5, color: '#fff' }, |
| | | { offset: 0.7, color: '#fff' }, |
| | | { offset: 0.8, color: '#fff' }, |
| | | { offset: 1, color: '#fff' }, |
| | | ], |
| | | }, |
| | | borderColor: '#9E87FF', |
| | | borderWidth: 2, |
| | | }, |
| | | }, |
| | | }, |
| | | ], |
| | | }; |
| | | state.global.homeChartOne.setOption(option); |
| | | state.myCharts.push(state.global.homeChartOne); |
| | | }; |
| | | // 饼图 |
| | | const initPieChart = () => { |
| | | if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose(); |
| | | state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme)); |
| | | var getname = ['房屋及结构物', '专用设备', '通用设备', '文物和陈列品', '图书、档案']; |
| | | var getvalue = [34.2, 38.87, 17.88, 9.05, 2.05]; |
| | | var data = []; |
| | | for (var i = 0; i < getname.length; i++) { |
| | | data.push({ name: getname[i], value: getvalue[i] }); |
| | | } |
| | | const colorList = ['#51A3FC', '#36C78B', '#FEC279', '#968AF5', '#E790E8']; |
| | | const option = { |
| | | backgroundColor: state.charts.bgColor, |
| | | title: { |
| | | text: '房屋建筑工程', |
| | | x: 'left', |
| | | textStyle: { fontSize: '15', color: state.charts.color }, |
| | | }, |
| | | tooltip: { trigger: 'item', formatter: '{b} <br/> {c}%' }, |
| | | graphic: { |
| | | elements: [ |
| | | { |
| | | type: 'image', |
| | | z: -1, |
| | | style: { |
| | | image: themeConfig.value.isIsDark |
| | | ? '' |
| | | : '', |
| | | width: 230, |
| | | height: 230, |
| | | }, |
| | | left: '16.5%', |
| | | top: 'center', |
| | | }, |
| | | ], |
| | | }, |
| | | legend: { |
| | | type: 'scroll', |
| | | orient: 'vertical', |
| | | right: '0%', |
| | | left: '65%', |
| | | top: 'center', |
| | | itemWidth: 14, |
| | | itemHeight: 14, |
| | | data: getname, |
| | | textStyle: { |
| | | rich: { |
| | | name: { |
| | | fontSize: 14, |
| | | fontWeight: 400, |
| | | width: 200, |
| | | height: 35, |
| | | padding: [0, 0, 0, 60], |
| | | color: state.charts.color, |
| | | }, |
| | | rate: { |
| | | fontSize: 15, |
| | | fontWeight: 500, |
| | | height: 35, |
| | | width: 40, |
| | | padding: [0, 0, 0, 30], |
| | | color: state.charts.color, |
| | | }, |
| | | }, |
| | | }, |
| | | }, |
| | | series: [ |
| | | { |
| | | type: 'pie', |
| | | radius: ['82', themeConfig.value.isIsDark ? '50' : '102'], |
| | | center: ['32%', '50%'], |
| | | itemStyle: { |
| | | color: function (params: any) { |
| | | return colorList[params.dataIndex]; |
| | | }, |
| | | }, |
| | | label: { show: false }, |
| | | labelLine: { show: false }, |
| | | data: data, |
| | | }, |
| | | ], |
| | | }; |
| | | state.global.homeChartTwo.setOption(option); |
| | | state.myCharts.push(state.global.homeChartTwo); |
| | | }; |
| | | // 柱状图 |
| | | const initBarChart = () => { |
| | | if (!state.global.dispose.some((b: any) => b === state.global.homeCharThree)) state.global.homeCharThree.dispose(); |
| | | state.global.homeCharThree = markRaw(echarts.init(homeBarRef.value, state.charts.theme)); |
| | | const option = { |
| | | backgroundColor: state.charts.bgColor, |
| | | title: { |
| | | text: '地热开发利用', |
| | | x: 'left', |
| | | textStyle: { fontSize: '15', color: state.charts.color }, |
| | | }, |
| | | tooltip: { trigger: 'axis' }, |
| | | legend: { data: ['供温', '回温', '压力值(Mpa)'], right: 0 }, |
| | | grid: { top: 70, right: 80, bottom: 30, left: 80 }, |
| | | xAxis: [ |
| | | { |
| | | type: 'category', |
| | | data: ['1km', '2km', '3km', '4km', '5km', '6km'], |
| | | boundaryGap: true, |
| | | axisTick: { show: false }, |
| | | }, |
| | | ], |
| | | yAxis: [ |
| | | { |
| | | name: '供回温度(℃)', |
| | | nameLocation: 'middle', |
| | | nameTextStyle: { padding: [3, 4, 50, 6] }, |
| | | splitLine: { show: true, lineStyle: { type: 'dashed', color: '#f5f5f5' } }, |
| | | axisLine: { show: false }, |
| | | axisTick: { show: false }, |
| | | axisLabel: { color: state.charts.color, formatter: '{value} ' }, |
| | | }, |
| | | { |
| | | name: '压力值(Mpa)', |
| | | nameLocation: 'middle', |
| | | nameTextStyle: { padding: [50, 4, 5, 6] }, |
| | | splitLine: { show: false }, |
| | | axisLine: { show: false }, |
| | | axisTick: { show: false }, |
| | | axisLabel: { color: state.charts.color, formatter: '{value} ' }, |
| | | }, |
| | | ], |
| | | series: [ |
| | | { |
| | | name: '供温', |
| | | type: 'line', |
| | | smooth: true, |
| | | showSymbol: true, |
| | | // 矢量画五角星 |
| | | symbol: 'path://M150 0 L80 175 L250 75 L50 75 L220 175 Z', |
| | | symbolSize: 12, |
| | | yAxisIndex: 0, |
| | | areaStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ |
| | | { offset: 0, color: 'rgba(250,180,101,0.3)' }, |
| | | { offset: 1, color: 'rgba(250,180,101,0)' }, |
| | | ]), |
| | | shadowColor: 'rgba(250,180,101,0.2)', |
| | | shadowBlur: 20, |
| | | }, |
| | | itemStyle: { color: '#FF8000' }, |
| | | // data中可以使用对象,value代表相应的值,另外可加入自定义的属性 |
| | | data: [ |
| | | { value: 1, stationName: 's1' }, |
| | | { value: 3, stationName: 's2' }, |
| | | { value: 4, stationName: 's3' }, |
| | | { value: 9, stationName: 's4' }, |
| | | { value: 3, stationName: 's5' }, |
| | | { value: 2, stationName: 's6' }, |
| | | ], |
| | | }, |
| | | { |
| | | name: '回温', |
| | | type: 'line', |
| | | smooth: true, |
| | | showSymbol: true, |
| | | symbol: 'emptyCircle', |
| | | symbolSize: 12, |
| | | yAxisIndex: 0, |
| | | areaStyle: { |
| | | color: new echarts.graphic.LinearGradient( |
| | | 0, |
| | | 0, |
| | | 0, |
| | | 1, |
| | | [ |
| | | { offset: 0, color: 'rgba(199, 237, 250,0.5)' }, |
| | | { offset: 1, color: 'rgba(199, 237, 250,0.2)' }, |
| | | ], |
| | | false |
| | | ), |
| | | }, |
| | | itemStyle: { |
| | | color: '#3bbc86', |
| | | }, |
| | | data: [ |
| | | { value: 31, stationName: 's1' }, |
| | | { value: 36, stationName: 's2' }, |
| | | { value: 54, stationName: 's3' }, |
| | | { value: 24, stationName: 's4' }, |
| | | { value: 73, stationName: 's5' }, |
| | | { value: 22, stationName: 's6' }, |
| | | ], |
| | | }, |
| | | { |
| | | name: '压力值(Mpa)', |
| | | type: 'bar', |
| | | barWidth: 30, |
| | | yAxisIndex: 1, |
| | | itemStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ |
| | | { offset: 0, color: 'rgba(108,80,243,0.3)' }, |
| | | { offset: 1, color: 'rgba(108,80,243,0)' }, |
| | | ]), |
| | | //柱状图圆角 |
| | | borderRadius: [30, 30, 0, 0], |
| | | }, |
| | | data: [ |
| | | { value: 11, stationName: 's1' }, |
| | | { value: 34, stationName: 's2' }, |
| | | { value: 54, stationName: 's3' }, |
| | | { value: 39, stationName: 's4' }, |
| | | { value: 63, stationName: 's5' }, |
| | | { value: 24, stationName: 's6' }, |
| | | ], |
| | | }, |
| | | ], |
| | | }; |
| | | state.global.homeCharThree.setOption(option); |
| | | state.myCharts.push(state.global.homeCharThree); |
| | | }; |
| | | // 批量设置 echarts resize |
| | | const initEchartsResizeFun = () => { |
| | | nextTick(() => { |
| | | for (let i = 0; i < state.myCharts.length; i++) { |
| | | setTimeout(() => { |
| | | state.myCharts[i].resize(); |
| | | }, i * 1000); |
| | | } |
| | | }); |
| | | }; |
| | | // 批量设置 echarts resize |
| | | const initEchartsResize = () => { |
| | | window.addEventListener('resize', initEchartsResizeFun); |
| | | }; |
| | | // 页面加载时 |
| | | onMounted(() => { |
| | | initEchartsResize(); |
| | | }); |
| | | // 由于页面缓存原因,keep-alive |
| | | onActivated(() => { |
| | | initEchartsResizeFun(); |
| | | }); |
| | | // 监听 pinia 中的 tagsview 开启全屏变化,重新 resize 图表,防止不出现/大小不变等 |
| | | watch( |
| | | () => isTagsViewCurrenFull.value, |
| | | () => { |
| | | initEchartsResizeFun(); |
| | | } |
| | | ); |
| | | // 监听 pinia 中是否开启深色主题 |
| | | watch( |
| | | () => themeConfig.value.isIsDark, |
| | | (isIsDark) => { |
| | | nextTick(() => { |
| | | state.charts.theme = isIsDark ? 'dark' : ''; |
| | | state.charts.bgColor = isIsDark ? 'transparent' : ''; |
| | | state.charts.color = isIsDark ? '#dadada' : '#303133'; |
| | | setTimeout(() => { |
| | | initLineChart(); |
| | | }, 500); |
| | | setTimeout(() => { |
| | | initPieChart(); |
| | | }, 700); |
| | | setTimeout(() => { |
| | | initBarChart(); |
| | | }, 1000); |
| | | }); |
| | | }, |
| | | { |
| | | deep: true, |
| | | immediate: true, |
| | | } |
| | | ); |
| | | /** 切换明细tabs*/ |
| | | const handleClick=(tab: TabsPaneContext, event: Event)=>{ |
| | | console.log(tab, event) |
| | | } |
| | | </script> |
| | | |
| | | <style scoped lang="scss"> |
| | | <style lang="scss"> |
| | | $homeNavLengh: 8; |
| | | .home-container { |
| | | overflow: hidden; |
| | | .home-card-one, |
| | | .home-card-two, |
| | | .home-card-three { |
| | | .home-card-item { |
| | | width: 100%; |
| | | height: 130px; |
| | | border-radius: 4px; |
| | | transition: all ease 0.3s; |
| | | padding: 20px; |
| | | overflow: hidden; |
| | | background: var(--el-color-white); |
| | | color: var(--el-text-color-primary); |
| | | border: 1px solid var(--next-border-color-light); |
| | | &:hover { |
| | | box-shadow: 0 2px 12px var(--next-color-dark-hover); |
| | | transition: all ease 0.3s; |
| | | } |
| | | &-icon { |
| | | width: 70px; |
| | | height: 70px; |
| | | border-radius: 100%; |
| | | flex-shrink: 1; |
| | | i { |
| | | color: var(--el-text-color-placeholder); |
| | | } |
| | | } |
| | | &-title { |
| | | font-size: 15px; |
| | | font-weight: bold; |
| | | height: 30px; |
| | | } |
| | | } |
| | | } |
| | | .home-card-one { |
| | | @for $i from 0 through 3 { |
| | | .home-one-animation#{$i} { |
| | | opacity: 0; |
| | | animation-name: error-num; |
| | | animation-duration: 0.5s; |
| | | animation-fill-mode: forwards; |
| | | animation-delay: calc($i/4) + s; |
| | | } |
| | | } |
| | | } |
| | | .home-card-two, |
| | | .home-card-three { |
| | | .home-card-item { |
| | | height: 400px; |
| | | width: 100%; |
| | | overflow: hidden; |
| | | .home-monitor { |
| | | height: 100%; |
| | | .flex-warp-item { |
| | | width: 25%; |
| | | height: 111px; |
| | | display: flex; |
| | | .flex-warp-item-box { |
| | | margin: auto; |
| | | text-align: center; |
| | | color: var(--el-text-color-primary); |
| | | display: flex; |
| | | border-radius: 5px; |
| | | background: var(--next-bg-color); |
| | | cursor: pointer; |
| | | transition: all 0.3s ease; |
| | | &:hover { |
| | | background: var(--el-color-primary-light-9); |
| | | transition: all 0.3s ease; |
| | | } |
| | | } |
| | | @for $i from 0 through $homeNavLengh { |
| | | .home-animation#{$i} { |
| | | opacity: 0; |
| | | animation-name: error-num; |
| | | animation-duration: 0.5s; |
| | | animation-fill-mode: forwards; |
| | | animation-delay: calc($i/10) + s; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | .patTabel{ |
| | | .el-table th.el-table__cell { |
| | | background-color: #6babfa; |
| | | color:#606266; |
| | | } |
| | | .el-table__body tr.current-row>td.el-table__cell{ |
| | | background: #E4F6DE; |
| | | color: #5FCD00; |
| | | /* height: 25px; */ |
| | | /* border: tomato solid 1px; */ |
| | | } |
| | | } |
| | | |
| | | } |
| | | .patTitle{ |
| | | height: 25px; |
| | | font-family: AlibabaPuHuiTi, AlibabaPuHuiTi; |
| | | font-weight: 500; |
| | | font-size: 18px; |
| | | color: #333333; |
| | | line-height: 20px; |
| | | letter-spacing: 1px; |
| | | text-align: left; |
| | | font-style: normal; |
| | | // margin-top: -10px; |
| | | } |
| | | .home-title{ |
| | | margin-bottom: 4px; |
| | | flex: 1; |
| | | height: inherit; |
| | | display: flex; |
| | | align-items: center; |
| | | } |
| | | .detailRight{ |
| | | background-color: #ffffff; |
| | | } |
| | | |
| | | </style> |
| | | |
| New file |
| | |
| | | <template> |
| | | <div class="home-container layout-pd"> |
| | | <el-row :gutter="15" class="home-card-one mb15"> |
| | | <el-col |
| | | :xs="24" |
| | | :sm="12" |
| | | :md="12" |
| | | :lg="6" |
| | | :xl="6" |
| | | v-for="(v, k) in state.homeOne" |
| | | :key="k" |
| | | :class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }" |
| | | > |
| | | <div class="home-card-item flex"> |
| | | <div class="flex-margin flex w100" :class="` home-one-animation${k}`"> |
| | | <div class="flex-auto"> |
| | | <span class="font30">{{ v.num1 }}</span> |
| | | <span class="ml5 font16" :style="{ color: v.color1 }">{{ v.num2 }}%</span> |
| | | <div class="mt10">{{ v.num3 }}</div> |
| | | </div> |
| | | <div class="home-card-item-icon flex" :style="{ background: `var(${v.color2})` }"> |
| | | <i class="flex-margin font32" :class="v.num4" :style="{ color: `var(${v.color3})` }"></i> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row :gutter="15" class="home-card-two mb15"> |
| | | <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16"> |
| | | <div class="home-card-item"> |
| | | <div style="height: 100%" ref="homeLineRef"></div> |
| | | </div> |
| | | </el-col> |
| | | <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8" class="home-media"> |
| | | <div class="home-card-item"> |
| | | <div style="height: 100%" ref="homePieRef"></div> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row :gutter="15" class="home-card-three"> |
| | | <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8"> |
| | | <div class="home-card-item"> |
| | | <div class="home-card-item-title">快捷导航工具</div> |
| | | <div class="home-monitor"> |
| | | <div class="flex-warp"> |
| | | <div class="flex-warp-item" v-for="(v, k) in state.homeThree" :key="k"> |
| | | <div class="flex-warp-item-box" :class="`home-animation${k}`"> |
| | | <div class="flex-margin"> |
| | | <i :class="v.icon" :style="{ color: v.iconColor }"></i> |
| | | <span class="pl5">{{ v.label }}</span> |
| | | <div class="mt10">{{ v.value }}</div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </el-col> |
| | | <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16" class="home-media"> |
| | | <div class="home-card-item"> |
| | | <div style="height: 100%" ref="homeBarRef"></div> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </template> |
| | | |
| | | <script setup lang="ts" name="home"> |
| | | import { reactive, onMounted, ref, watch, nextTick, onActivated, markRaw } from 'vue'; |
| | | import * as echarts from 'echarts'; |
| | | import { storeToRefs } from 'pinia'; |
| | | import { useThemeConfig } from '/@/stores/themeConfig'; |
| | | import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes'; |
| | | |
| | | // 定义变量内容 |
| | | const homeLineRef = ref(); |
| | | const homePieRef = ref(); |
| | | const homeBarRef = ref(); |
| | | const storesTagsViewRoutes = useTagsViewRoutes(); |
| | | const storesThemeConfig = useThemeConfig(); |
| | | const { themeConfig } = storeToRefs(storesThemeConfig); |
| | | const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes); |
| | | const state = reactive({ |
| | | global: { |
| | | homeChartOne: null, |
| | | homeChartTwo: null, |
| | | homeCharThree: null, |
| | | dispose: [null, '', undefined], |
| | | } as any, |
| | | homeOne: [ |
| | | { |
| | | num1: '125,12', |
| | | num2: '-12.32', |
| | | num3: '订单统计信息', |
| | | num4: 'fa fa-meetup', |
| | | color1: '#FF6462', |
| | | color2: '--next-color-primary-lighter', |
| | | color3: '--el-color-primary', |
| | | }, |
| | | { |
| | | num1: '653,33', |
| | | num2: '+42.32', |
| | | num3: '月度计划信息', |
| | | num4: 'iconfont icon-ditu', |
| | | color1: '#6690F9', |
| | | color2: '--next-color-success-lighter', |
| | | color3: '--el-color-success', |
| | | }, |
| | | { |
| | | num1: '125,65', |
| | | num2: '+17.32', |
| | | num3: '年度计划信息', |
| | | num4: 'iconfont icon-zaosheng', |
| | | color1: '#6690F9', |
| | | color2: '--next-color-warning-lighter', |
| | | color3: '--el-color-warning', |
| | | }, |
| | | { |
| | | num1: '520,43', |
| | | num2: '-10.01', |
| | | num3: '访问统计信息', |
| | | num4: 'fa fa-github-alt', |
| | | color1: '#FF6462', |
| | | color2: '--next-color-danger-lighter', |
| | | color3: '--el-color-danger', |
| | | }, |
| | | ], |
| | | homeThree: [ |
| | | { |
| | | icon: 'iconfont icon-yangan', |
| | | label: '浅粉红', |
| | | value: '2.1%OBS/M', |
| | | iconColor: '#F72B3F', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-wendu', |
| | | label: '深红(猩红)', |
| | | value: '30℃', |
| | | iconColor: '#91BFF8', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-shidu', |
| | | label: '淡紫红', |
| | | value: '57%RH', |
| | | iconColor: '#88D565', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-shidu', |
| | | label: '弱紫罗兰红', |
| | | value: '107w', |
| | | iconColor: '#88D565', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '中紫罗兰红', |
| | | value: '57DB', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '紫罗兰', |
| | | value: '57PV', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '暗紫罗兰', |
| | | value: '517Cpd', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '幽灵白', |
| | | value: '12kg', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | { |
| | | icon: 'iconfont icon-zaosheng', |
| | | label: '海军蓝', |
| | | value: '64fm', |
| | | iconColor: '#FBD4A0', |
| | | }, |
| | | ], |
| | | myCharts: [] as EmptyArrayType, |
| | | charts: { |
| | | theme: '', |
| | | bgColor: '', |
| | | color: '#303133', |
| | | }, |
| | | }); |
| | | |
| | | // 折线图 |
| | | const initLineChart = () => { |
| | | if (!state.global.dispose.some((b: any) => b === state.global.homeChartOne)) state.global.homeChartOne.dispose(); |
| | | state.global.homeChartOne = markRaw(echarts.init(homeLineRef.value, state.charts.theme)); |
| | | const option = { |
| | | backgroundColor: state.charts.bgColor, |
| | | title: { |
| | | text: '政策补贴额度', |
| | | x: 'left', |
| | | textStyle: { fontSize: '15', color: state.charts.color }, |
| | | }, |
| | | grid: { top: 70, right: 20, bottom: 30, left: 30 }, |
| | | tooltip: { trigger: 'axis' }, |
| | | legend: { data: ['预购队列', '最新成交价'], right: 0 }, |
| | | xAxis: { |
| | | data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'], |
| | | }, |
| | | yAxis: [ |
| | | { |
| | | type: 'value', |
| | | name: '价格', |
| | | splitLine: { show: true, lineStyle: { type: 'dashed', color: '#f5f5f5' } }, |
| | | }, |
| | | ], |
| | | series: [ |
| | | { |
| | | name: '预购队列', |
| | | type: 'line', |
| | | symbolSize: 6, |
| | | symbol: 'circle', |
| | | smooth: true, |
| | | data: [0, 41.1, 30.4, 65.1, 53.3, 53.3, 53.3, 41.1, 30.4, 65.1, 53.3, 10], |
| | | lineStyle: { color: '#fe9a8b' }, |
| | | itemStyle: { color: '#fe9a8b', borderColor: '#fe9a8b' }, |
| | | areaStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ |
| | | { offset: 0, color: '#fe9a8bb3' }, |
| | | { offset: 1, color: '#fe9a8b03' }, |
| | | ]), |
| | | }, |
| | | }, |
| | | { |
| | | name: '最新成交价', |
| | | type: 'line', |
| | | symbolSize: 6, |
| | | symbol: 'circle', |
| | | smooth: true, |
| | | data: [0, 24.1, 7.2, 15.5, 42.4, 42.4, 42.4, 24.1, 7.2, 15.5, 42.4, 0], |
| | | lineStyle: { color: '#9E87FF' }, |
| | | itemStyle: { color: '#9E87FF', borderColor: '#9E87FF' }, |
| | | areaStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ |
| | | { offset: 0, color: '#9E87FFb3' }, |
| | | { offset: 1, color: '#9E87FF03' }, |
| | | ]), |
| | | }, |
| | | emphasis: { |
| | | itemStyle: { |
| | | color: { |
| | | type: 'radial', |
| | | x: 0.5, |
| | | y: 0.5, |
| | | r: 0.5, |
| | | colorStops: [ |
| | | { offset: 0, color: '#9E87FF' }, |
| | | { offset: 0.4, color: '#9E87FF' }, |
| | | { offset: 0.5, color: '#fff' }, |
| | | { offset: 0.7, color: '#fff' }, |
| | | { offset: 0.8, color: '#fff' }, |
| | | { offset: 1, color: '#fff' }, |
| | | ], |
| | | }, |
| | | borderColor: '#9E87FF', |
| | | borderWidth: 2, |
| | | }, |
| | | }, |
| | | }, |
| | | ], |
| | | }; |
| | | state.global.homeChartOne.setOption(option); |
| | | state.myCharts.push(state.global.homeChartOne); |
| | | }; |
| | | // 饼图 |
| | | const initPieChart = () => { |
| | | if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose(); |
| | | state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme)); |
| | | var getname = ['房屋及结构物', '专用设备', '通用设备', '文物和陈列品', '图书、档案']; |
| | | var getvalue = [34.2, 38.87, 17.88, 9.05, 2.05]; |
| | | var data = []; |
| | | for (var i = 0; i < getname.length; i++) { |
| | | data.push({ name: getname[i], value: getvalue[i] }); |
| | | } |
| | | const colorList = ['#51A3FC', '#36C78B', '#FEC279', '#968AF5', '#E790E8']; |
| | | const option = { |
| | | backgroundColor: state.charts.bgColor, |
| | | title: { |
| | | text: '房屋建筑工程', |
| | | x: 'left', |
| | | textStyle: { fontSize: '15', color: state.charts.color }, |
| | | }, |
| | | tooltip: { trigger: 'item', formatter: '{b} <br/> {c}%' }, |
| | | graphic: { |
| | | elements: [ |
| | | { |
| | | type: 'image', |
| | | z: -1, |
| | | style: { |
| | | image: themeConfig.value.isIsDark |
| | | ? '' |
| | | : '', |
| | | width: 230, |
| | | height: 230, |
| | | }, |
| | | left: '16.5%', |
| | | top: 'center', |
| | | }, |
| | | ], |
| | | }, |
| | | legend: { |
| | | type: 'scroll', |
| | | orient: 'vertical', |
| | | right: '0%', |
| | | left: '65%', |
| | | top: 'center', |
| | | itemWidth: 14, |
| | | itemHeight: 14, |
| | | data: getname, |
| | | textStyle: { |
| | | rich: { |
| | | name: { |
| | | fontSize: 14, |
| | | fontWeight: 400, |
| | | width: 200, |
| | | height: 35, |
| | | padding: [0, 0, 0, 60], |
| | | color: state.charts.color, |
| | | }, |
| | | rate: { |
| | | fontSize: 15, |
| | | fontWeight: 500, |
| | | height: 35, |
| | | width: 40, |
| | | padding: [0, 0, 0, 30], |
| | | color: state.charts.color, |
| | | }, |
| | | }, |
| | | }, |
| | | }, |
| | | series: [ |
| | | { |
| | | type: 'pie', |
| | | radius: ['82', themeConfig.value.isIsDark ? '50' : '102'], |
| | | center: ['32%', '50%'], |
| | | itemStyle: { |
| | | color: function (params: any) { |
| | | return colorList[params.dataIndex]; |
| | | }, |
| | | }, |
| | | label: { show: false }, |
| | | labelLine: { show: false }, |
| | | data: data, |
| | | }, |
| | | ], |
| | | }; |
| | | state.global.homeChartTwo.setOption(option); |
| | | state.myCharts.push(state.global.homeChartTwo); |
| | | }; |
| | | // 柱状图 |
| | | const initBarChart = () => { |
| | | if (!state.global.dispose.some((b: any) => b === state.global.homeCharThree)) state.global.homeCharThree.dispose(); |
| | | state.global.homeCharThree = markRaw(echarts.init(homeBarRef.value, state.charts.theme)); |
| | | const option = { |
| | | backgroundColor: state.charts.bgColor, |
| | | title: { |
| | | text: '地热开发利用', |
| | | x: 'left', |
| | | textStyle: { fontSize: '15', color: state.charts.color }, |
| | | }, |
| | | tooltip: { trigger: 'axis' }, |
| | | legend: { data: ['供温', '回温', '压力值(Mpa)'], right: 0 }, |
| | | grid: { top: 70, right: 80, bottom: 30, left: 80 }, |
| | | xAxis: [ |
| | | { |
| | | type: 'category', |
| | | data: ['1km', '2km', '3km', '4km', '5km', '6km'], |
| | | boundaryGap: true, |
| | | axisTick: { show: false }, |
| | | }, |
| | | ], |
| | | yAxis: [ |
| | | { |
| | | name: '供回温度(℃)', |
| | | nameLocation: 'middle', |
| | | nameTextStyle: { padding: [3, 4, 50, 6] }, |
| | | splitLine: { show: true, lineStyle: { type: 'dashed', color: '#f5f5f5' } }, |
| | | axisLine: { show: false }, |
| | | axisTick: { show: false }, |
| | | axisLabel: { color: state.charts.color, formatter: '{value} ' }, |
| | | }, |
| | | { |
| | | name: '压力值(Mpa)', |
| | | nameLocation: 'middle', |
| | | nameTextStyle: { padding: [50, 4, 5, 6] }, |
| | | splitLine: { show: false }, |
| | | axisLine: { show: false }, |
| | | axisTick: { show: false }, |
| | | axisLabel: { color: state.charts.color, formatter: '{value} ' }, |
| | | }, |
| | | ], |
| | | series: [ |
| | | { |
| | | name: '供温', |
| | | type: 'line', |
| | | smooth: true, |
| | | showSymbol: true, |
| | | // 矢量画五角星 |
| | | symbol: 'path://M150 0 L80 175 L250 75 L50 75 L220 175 Z', |
| | | symbolSize: 12, |
| | | yAxisIndex: 0, |
| | | areaStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ |
| | | { offset: 0, color: 'rgba(250,180,101,0.3)' }, |
| | | { offset: 1, color: 'rgba(250,180,101,0)' }, |
| | | ]), |
| | | shadowColor: 'rgba(250,180,101,0.2)', |
| | | shadowBlur: 20, |
| | | }, |
| | | itemStyle: { color: '#FF8000' }, |
| | | // data中可以使用对象,value代表相应的值,另外可加入自定义的属性 |
| | | data: [ |
| | | { value: 1, stationName: 's1' }, |
| | | { value: 3, stationName: 's2' }, |
| | | { value: 4, stationName: 's3' }, |
| | | { value: 9, stationName: 's4' }, |
| | | { value: 3, stationName: 's5' }, |
| | | { value: 2, stationName: 's6' }, |
| | | ], |
| | | }, |
| | | { |
| | | name: '回温', |
| | | type: 'line', |
| | | smooth: true, |
| | | showSymbol: true, |
| | | symbol: 'emptyCircle', |
| | | symbolSize: 12, |
| | | yAxisIndex: 0, |
| | | areaStyle: { |
| | | color: new echarts.graphic.LinearGradient( |
| | | 0, |
| | | 0, |
| | | 0, |
| | | 1, |
| | | [ |
| | | { offset: 0, color: 'rgba(199, 237, 250,0.5)' }, |
| | | { offset: 1, color: 'rgba(199, 237, 250,0.2)' }, |
| | | ], |
| | | false |
| | | ), |
| | | }, |
| | | itemStyle: { |
| | | color: '#3bbc86', |
| | | }, |
| | | data: [ |
| | | { value: 31, stationName: 's1' }, |
| | | { value: 36, stationName: 's2' }, |
| | | { value: 54, stationName: 's3' }, |
| | | { value: 24, stationName: 's4' }, |
| | | { value: 73, stationName: 's5' }, |
| | | { value: 22, stationName: 's6' }, |
| | | ], |
| | | }, |
| | | { |
| | | name: '压力值(Mpa)', |
| | | type: 'bar', |
| | | barWidth: 30, |
| | | yAxisIndex: 1, |
| | | itemStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ |
| | | { offset: 0, color: 'rgba(108,80,243,0.3)' }, |
| | | { offset: 1, color: 'rgba(108,80,243,0)' }, |
| | | ]), |
| | | //柱状图圆角 |
| | | borderRadius: [30, 30, 0, 0], |
| | | }, |
| | | data: [ |
| | | { value: 11, stationName: 's1' }, |
| | | { value: 34, stationName: 's2' }, |
| | | { value: 54, stationName: 's3' }, |
| | | { value: 39, stationName: 's4' }, |
| | | { value: 63, stationName: 's5' }, |
| | | { value: 24, stationName: 's6' }, |
| | | ], |
| | | }, |
| | | ], |
| | | }; |
| | | state.global.homeCharThree.setOption(option); |
| | | state.myCharts.push(state.global.homeCharThree); |
| | | }; |
| | | // 批量设置 echarts resize |
| | | const initEchartsResizeFun = () => { |
| | | nextTick(() => { |
| | | for (let i = 0; i < state.myCharts.length; i++) { |
| | | setTimeout(() => { |
| | | state.myCharts[i].resize(); |
| | | }, i * 1000); |
| | | } |
| | | }); |
| | | }; |
| | | // 批量设置 echarts resize |
| | | const initEchartsResize = () => { |
| | | window.addEventListener('resize', initEchartsResizeFun); |
| | | }; |
| | | // 页面加载时 |
| | | onMounted(() => { |
| | | initEchartsResize(); |
| | | }); |
| | | // 由于页面缓存原因,keep-alive |
| | | onActivated(() => { |
| | | initEchartsResizeFun(); |
| | | }); |
| | | // 监听 pinia 中的 tagsview 开启全屏变化,重新 resize 图表,防止不出现/大小不变等 |
| | | watch( |
| | | () => isTagsViewCurrenFull.value, |
| | | () => { |
| | | initEchartsResizeFun(); |
| | | } |
| | | ); |
| | | // 监听 pinia 中是否开启深色主题 |
| | | watch( |
| | | () => themeConfig.value.isIsDark, |
| | | (isIsDark) => { |
| | | nextTick(() => { |
| | | state.charts.theme = isIsDark ? 'dark' : ''; |
| | | state.charts.bgColor = isIsDark ? 'transparent' : ''; |
| | | state.charts.color = isIsDark ? '#dadada' : '#303133'; |
| | | setTimeout(() => { |
| | | initLineChart(); |
| | | }, 500); |
| | | setTimeout(() => { |
| | | initPieChart(); |
| | | }, 700); |
| | | setTimeout(() => { |
| | | initBarChart(); |
| | | }, 1000); |
| | | }); |
| | | }, |
| | | { |
| | | deep: true, |
| | | immediate: true, |
| | | } |
| | | ); |
| | | </script> |
| | | |
| | | <style scoped lang="scss"> |
| | | $homeNavLengh: 8; |
| | | .home-container { |
| | | overflow: hidden; |
| | | .home-card-one, |
| | | .home-card-two, |
| | | .home-card-three { |
| | | .home-card-item { |
| | | width: 100%; |
| | | height: 130px; |
| | | border-radius: 4px; |
| | | transition: all ease 0.3s; |
| | | padding: 20px; |
| | | overflow: hidden; |
| | | background: var(--el-color-white); |
| | | color: var(--el-text-color-primary); |
| | | border: 1px solid var(--next-border-color-light); |
| | | &:hover { |
| | | box-shadow: 0 2px 12px var(--next-color-dark-hover); |
| | | transition: all ease 0.3s; |
| | | } |
| | | &-icon { |
| | | width: 70px; |
| | | height: 70px; |
| | | border-radius: 100%; |
| | | flex-shrink: 1; |
| | | i { |
| | | color: var(--el-text-color-placeholder); |
| | | } |
| | | } |
| | | &-title { |
| | | font-size: 15px; |
| | | font-weight: bold; |
| | | height: 30px; |
| | | } |
| | | } |
| | | } |
| | | .home-card-one { |
| | | @for $i from 0 through 3 { |
| | | .home-one-animation#{$i} { |
| | | opacity: 0; |
| | | animation-name: error-num; |
| | | animation-duration: 0.5s; |
| | | animation-fill-mode: forwards; |
| | | animation-delay: calc($i/4) + s; |
| | | } |
| | | } |
| | | } |
| | | .home-card-two, |
| | | .home-card-three { |
| | | .home-card-item { |
| | | height: 400px; |
| | | width: 100%; |
| | | overflow: hidden; |
| | | .home-monitor { |
| | | height: 100%; |
| | | .flex-warp-item { |
| | | width: 25%; |
| | | height: 111px; |
| | | display: flex; |
| | | .flex-warp-item-box { |
| | | margin: auto; |
| | | text-align: center; |
| | | color: var(--el-text-color-primary); |
| | | display: flex; |
| | | border-radius: 5px; |
| | | background: var(--next-bg-color); |
| | | cursor: pointer; |
| | | transition: all 0.3s ease; |
| | | &:hover { |
| | | background: var(--el-color-primary-light-9); |
| | | transition: all 0.3s ease; |
| | | } |
| | | } |
| | | @for $i from 0 through $homeNavLengh { |
| | | .home-animation#{$i} { |
| | | opacity: 0; |
| | | animation-name: error-num; |
| | | animation-duration: 0.5s; |
| | | animation-fill-mode: forwards; |
| | | animation-delay: calc($i/10) + s; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | </style> |
| | |
| | | </template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item class="login-animation3"> |
| | | <!-- <el-form-item class="login-animation3"> |
| | | <el-col :span="15"> |
| | | <el-input |
| | | text |
| | |
| | | <el-col :span="8"> |
| | | <el-button class="login-content-code" v-waves>1234</el-button> |
| | | </el-col> |
| | | </el-form-item> |
| | | </el-form-item> --> |
| | | <el-form-item class="login-animation4"> |
| | | <el-button type="primary" class="login-content-submit" round v-waves @click="onSignIn" :loading="state.loading.signIn"> |
| | | <span>{{ $t('message.account.accountBtnText') }}</span> |
| | |
| | | import { Session } from '/@/utils/storage'; |
| | | import { formatAxis } from '/@/utils/formatTime'; |
| | | import { NextLoading } from '/@/utils/loading'; |
| | | import { signIn } from '/@/api/login'; |
| | | import { error } from 'console'; |
| | | |
| | | // 定义变量内容 |
| | | const { t } = useI18n(); |
| | |
| | | }); |
| | | // 登录 |
| | | const onSignIn = async () => { |
| | | state.loading.signIn = true; |
| | | // 存储 token 到浏览器缓存 |
| | | Session.set('token', Math.random().toString(36).substr(0)); |
| | | // 模拟数据,对接接口时,记得删除多余代码及对应依赖的引入。用于 `/src/stores/userInfo.ts` 中不同用户登录判断(模拟数据) |
| | | Cookies.set('userName', state.ruleForm.userName); |
| | | if (!themeConfig.value.isRequestRoutes) { |
| | | // 前端控制路由,2、请注意执行顺序 |
| | | const isNoPower = await initFrontEndControlRoutes(); |
| | | signInSuccess(isNoPower); |
| | | } else { |
| | | // 模拟后端控制路由,isRequestRoutes 为 true,则开启后端控制路由 |
| | | // 添加完动态路由,再进行 router 跳转,否则可能报错 No match found for location with path "/" |
| | | const isNoPower = await initBackEndControlRoutes(); |
| | | // 执行完 initBackEndControlRoutes,再执行 signInSuccess |
| | | signInSuccess(isNoPower); |
| | | try{ |
| | | state.loading.signIn = true; |
| | | const signInRes = await signIn(`user_no=${state.ruleForm.userName}&user_password=${state.ruleForm.password}`) |
| | | if(signInRes.data){ |
| | | // 存储 token 到浏览器缓存 |
| | | Session.set('token', signInRes.data); |
| | | // 模拟数据,对接接口时,记得删除多余代码及对应依赖的引入。用于 `/src/stores/userInfo.ts` 中不同用户登录判断(模拟数据) |
| | | Cookies.set('userName', state.ruleForm.userName); |
| | | // 前端控制路由,2、请注意执行顺序 |
| | | const isNoPower = await initFrontEndControlRoutes(); |
| | | signInSuccess(isNoPower); |
| | | |
| | | } |
| | | }catch(err){ |
| | | console.log(err) |
| | | state.loading.signIn = false |
| | | } |
| | | |
| | | |
| | | // 存储 token 到浏览器缓存 |
| | | // Session.set('token', '999'); |
| | | // 模拟数据,对接接口时,记得删除多余代码及对应依赖的引入。用于 `/src/stores/userInfo.ts` 中不同用户登录判断(模拟数据) |
| | | // Cookies.set('userName', state.ruleForm.userName); |
| | | // if (!themeConfig.value.isRequestRoutes) { |
| | | // // 前端控制路由,2、请注意执行顺序 |
| | | // const isNoPower = await initFrontEndControlRoutes(); |
| | | // signInSuccess(isNoPower); |
| | | // } else { |
| | | // // 模拟后端控制路由,isRequestRoutes 为 true,则开启后端控制路由 |
| | | // // 添加完动态路由,再进行 router 跳转,否则可能报错 No match found for location with path "/" |
| | | // const isNoPower = await initBackEndControlRoutes(); |
| | | // // 执行完 initBackEndControlRoutes,再执行 signInSuccess |
| | | // signInSuccess(isNoPower); |
| | | // } |
| | | }; |
| | | // 登录成功后的跳转 |
| | | const signInSuccess = (isNoPower: boolean | undefined) => { |