From 7ae4f8a626802bc8f027aa091046db97635da879 Mon Sep 17 00:00:00 2001
From: chenyc <501753378@qq.com>
Date: 星期一, 19 八月 2024 19:16:35 +0800
Subject: [PATCH] 完成首页母版
---
package-lock.json | 8
src/assets/imgs/huanzheliebiao.png | 0
src/layout/main/defaults.vue | 4
src/utils/request.ts | 18
src/api/Patients/index.ts | 17
src/stores/themeConfig.ts | 2
src/main.ts | 6
.env.development | 2
src/layout/navBars/topBar/breadcrumb.vue | 22
src/stores/userInfo.ts | 31
src/views/home/index.vue | 832 +++++++---------------------
src/router/route.ts | 2
src/types/pinia.d.ts | 2
src/assets/imgs/logo.png | 0
src/layout/navBars/topBar/index.vue | 1
.env.production | 2
src/views/login/component/account.vue | 54 +
src/api/login/index.ts | 50 +
src/views/home/index222.vue | 633 +++++++++++++++++++++
19 files changed, 1,019 insertions(+), 667 deletions(-)
diff --git a/.env.development b/.env.development
index 86f9384..bb87784 100644
--- a/.env.development
+++ b/.env.development
@@ -2,4 +2,4 @@
ENV = development
# 本地环境接口地址
-VITE_API_URL = http://localhost:8181/
\ No newline at end of file
+VITE_API_URL = 'http://testbs.ihemodialysis.com/'
\ No newline at end of file
diff --git a/.env.production b/.env.production
index 478a841..270412d 100644
--- a/.env.production
+++ b/.env.production
@@ -2,4 +2,4 @@
ENV = production
# 线上环境接口地址
-VITE_API_URL = https://lyt-top.gitee.io/vue-next-admin-preview/
\ No newline at end of file
+VITE_API_URL = 'https://hemobs.icoldchain.cn/'
\ No newline at end of file
diff --git a/package-lock.json b/package-lock.json
index 1a944f7..ee4feda 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1,11 +1,11 @@
{
- "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": {
@@ -103,7 +103,7 @@
},
"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"
@@ -4360,7 +4360,7 @@
},
"@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": {}
},
diff --git a/src/api/Patients/index.ts b/src/api/Patients/index.ts
new file mode 100644
index 0000000..b5df8c4
--- /dev/null
+++ b/src/api/Patients/index.ts
@@ -0,0 +1,17 @@
+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
+ });
+}
\ No newline at end of file
diff --git a/src/api/login/index.ts b/src/api/login/index.ts
index 71ed946..6840349 100644
--- a/src/api/login/index.ts
+++ b/src/api/login/index.ts
@@ -1,27 +1,35 @@
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'
+ })
}
diff --git a/src/assets/imgs/huanzheliebiao.png b/src/assets/imgs/huanzheliebiao.png
new file mode 100644
index 0000000..167d4d1
--- /dev/null
+++ b/src/assets/imgs/huanzheliebiao.png
Binary files differ
diff --git a/src/assets/imgs/logo.png b/src/assets/imgs/logo.png
new file mode 100644
index 0000000..f918d98
--- /dev/null
+++ b/src/assets/imgs/logo.png
Binary files differ
diff --git a/src/layout/main/defaults.vue b/src/layout/main/defaults.vue
index 8122aef..b6ba0e8 100644
--- a/src/layout/main/defaults.vue
+++ b/src/layout/main/defaults.vue
@@ -1,7 +1,9 @@
<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" />
diff --git a/src/layout/navBars/topBar/breadcrumb.vue b/src/layout/navBars/topBar/breadcrumb.vue
index 7dfaca6..0105f4c 100644
--- a/src/layout/navBars/topBar/breadcrumb.vue
+++ b/src/layout/navBars/topBar/breadcrumb.vue
@@ -1,5 +1,5 @@
<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'"
@@ -20,6 +20,12 @@
</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>
@@ -31,6 +37,7 @@
import { storeToRefs } from 'pinia';
import { useThemeConfig } from '/@/stores/themeConfig';
import { useRoutesList } from '/@/stores/routesList';
+import logo from '/@/assets/imgs/logo.png'
// 定义变量内容
const stores = useRoutesList();
@@ -116,7 +123,7 @@
font-size: 18px;
color: var(--next-bg-topBarColor);
height: 100%;
- width: 40px;
+ width: 48px;
opacity: 0.8;
&:hover {
opacity: 1;
@@ -142,5 +149,16 @@
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>
diff --git a/src/layout/navBars/topBar/index.vue b/src/layout/navBars/topBar/index.vue
index bd8804a..0b9c973 100644
--- a/src/layout/navBars/topBar/index.vue
+++ b/src/layout/navBars/topBar/index.vue
@@ -2,6 +2,7 @@
<div class="layout-navbars-breadcrumb-index">
<Logo v-if="setIsShowLogo" />
<Breadcrumb />
+
<Horizontal :menuList="state.menuList" v-if="isLayoutTransverse" />
<User />
</div>
diff --git a/src/main.ts b/src/main.ts
index 4373425..e979762 100644
--- a/src/main.ts
+++ b/src/main.ts
@@ -7,11 +7,15 @@
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);
diff --git a/src/router/route.ts b/src/router/route.ts
index 21a9f3f..b4576af 100644
--- a/src/router/route.ts
+++ b/src/router/route.ts
@@ -50,7 +50,7 @@
{
path: '/home',
name: 'home',
- component: () => import('/@/views/home/index.vue'),
+ component: () => import('../views/home/index.vue'),
meta: {
title: 'message.router.home',
isLink: '',
diff --git a/src/stores/themeConfig.ts b/src/stores/themeConfig.ts
index 0a4ebf7..3adef00 100644
--- a/src/stores/themeConfig.ts
+++ b/src/stores/themeConfig.ts
@@ -64,7 +64,7 @@
// 是否开启菜单手风琴效果
isUniqueOpened: true,
// 是否开启固定 Header
- isFixedHeader: false,
+ isFixedHeader: true,
// 初始化变量,用于更新菜单 el-scrollbar 的高度,请勿删除
isFixedHeaderChange: false,
// 是否开启经典布局分割菜单(仅经典布局生效)
diff --git a/src/stores/userInfo.ts b/src/stores/userInfo.ts
index 33e7970..887d209 100644
--- a/src/stores/userInfo.ts
+++ b/src/stores/userInfo.ts
@@ -1,6 +1,7 @@
import { defineStore } from 'pinia';
import Cookies from 'js-cookie';
import { Session } from '/@/utils/storage';
+import { getuserinfo } from '../api/login';
/**
* 用户信息
@@ -14,6 +15,8 @@
time: 0,
roles: [],
authBtnList: [],
+ clientCode:'',
+ clientName:''
},
}),
actions: {
@@ -22,6 +25,7 @@
if (Session.get('userInfo')) {
this.userInfos = Session.get('userInfo');
} else {
+ console.log('Session里没有userInfo')
const userInfos = <UserInfos>await this.getApiUserInfo();
this.userInfos = userInfos;
}
@@ -29,10 +33,14 @@
// 模拟接口数据
// 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> = [];
@@ -45,7 +53,17 @@
// 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 {
@@ -55,15 +73,16 @@
// 用户信息模拟数据
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);
});
diff --git a/src/types/pinia.d.ts b/src/types/pinia.d.ts
index f7c32ad..806a210 100644
--- a/src/types/pinia.d.ts
+++ b/src/types/pinia.d.ts
@@ -9,6 +9,8 @@
roles: string[];
time: number;
userName: string;
+ clientCode:string,
+ clientName:string
[key: string]: T;
}
declare interface UserInfosState {
diff --git a/src/utils/request.ts b/src/utils/request.ts
index 6212fc4..792f154 100644
--- a/src/utils/request.ts
+++ b/src/utils/request.ts
@@ -20,7 +20,7 @@
(config) => {
// 在发送请求之前做些什么 token
if (Session.get('token')) {
- config.headers!['Authorization'] = `${Session.get('token')}`;
+ config.headers!['Authorization'] = `Bearer ${Session.get('token')}`;
}
return config;
},
@@ -44,6 +44,15 @@
.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;
@@ -55,10 +64,15 @@
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);
}
);
diff --git a/src/views/home/index.vue b/src/views/home/index.vue
index d351e1e..3c14bf2 100644
--- a/src/views/home/index.vue
+++ b/src/views/home/index.vue
@@ -1,85 +1,130 @@
<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,
@@ -87,547 +132,116 @@
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>
+
diff --git a/src/views/home/index222.vue b/src/views/home/index222.vue
new file mode 100644
index 0000000..d351e1e
--- /dev/null
+++ b/src/views/home/index222.vue
@@ -0,0 +1,633 @@
+<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>
diff --git a/src/views/login/component/account.vue b/src/views/login/component/account.vue
index a646f5a..03b0338 100644
--- a/src/views/login/component/account.vue
+++ b/src/views/login/component/account.vue
@@ -27,7 +27,7 @@
</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
@@ -46,7 +46,7 @@
<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>
@@ -68,6 +68,8 @@
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();
@@ -93,22 +95,40 @@
});
// 登录
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) => {
--
Gitblit v1.8.0