From 2b8cbeec005f8ac6f65818da28fc239cf82fc716 Mon Sep 17 00:00:00 2001 From: 杨磊 <505174330@qq.com> Date: 星期一, 28 四月 2025 10:50:31 +0800 Subject: [PATCH] 字体文件 --- src/views/directory/index.vue | 805 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 802 insertions(+), 3 deletions(-) diff --git a/src/views/directory/index.vue b/src/views/directory/index.vue index e9f4253..3b4d41b 100644 --- a/src/views/directory/index.vue +++ b/src/views/directory/index.vue @@ -1,9 +1,808 @@ <template> - <div>瀛︾敓鍚嶅綍</div> + <div class="page"> + <div class="page-header"> + <p> + <span>鐜嬫案鐐庨櫌澹鐢熺洰褰�</span> + </p> + </div> + <div class="page-main-father"> + <div class="page-main-title"> + <p + @click="changeTab('chart')" + :class="[activeTabs == 'chart' ? 'active-tab' : '']" + > + <img + :src="[activeTabs == 'chart' ? chartIcon : noChartIcon]" + alt="" + /> + <span>鍥捐〃鏄剧ず</span> + </p> + <p + @click="changeTab('list')" + :class="[activeTabs == 'list' ? 'active-tab' : '']" + > + <img :src="[activeTabs == 'list' ? listIcon : noListIcon]" alt="" /> + <span>鍒楄〃鏄剧ず</span> + </p> + </div> + <!-- 鍥捐〃鏄剧ず --> + <div + class="charts-main" + v-show="activeTabs == 'chart'" + v-loading="loading" + element-loading-text="鍥捐〃鍔犺浇涓�" + element-loading-spinner="el-icon-loading" + element-loading-background="rgba(0, 0, 0, 0)" + > + <div class="radial-tree-container" v-show="!loading"> + <div ref="chart" style="width: 100%; height: 70vh"></div> + </div> + + <div class="legend"> + <div class="tagItem" v-for="(item, index) in legendList" :key="index"> + <div class="tagColor" :style="{ background: item.color }"></div> + <div class="tagText" :style="{ color: item.color }"> + {{ item.name }} + </div> + </div> + </div> + <transition name="el-fade-in-linear"> + <div class="tooltipBox" v-show="tooltipShow"> + <div + style=" + padding: 10px; + background: #fdf8f0; + border-radius: 5px; + width: 100%; + max-height: 500px; + text-align: center; + " + > + <div class="closeBtn" @click="tooltipShow = false"> + <i class="el-icon-close"></i> + </div> + <div style="display: flex"> + <div + style=" + width: 80px; + height: 80px; + position: relative; + margin-bottom: 10px; + background: #d8d8d8; + " + > + <img + class="autoImg" + :src=" + currentNodeInfo.icon + ? currentNodeInfo.icon + : '@/assets/images/directory/touxiang.png' + " + alt="" + /> + </div> + <div + style="padding-top: 20px; text-align: left; margin-left: 20px" + > + <div + style=" + font-size: 16px; + font-weight: bold; + margin-bottom: 5px; + " + > + {{ currentNodeInfo.name }} + </div> + <div style="margin-top: 20px"> + <span> + {{ + currentNodeInfo.gender == "male" ? "鐢�" : "濂�" || "-" + }} + </span> + <span> {{ currentNodeInfo.academicName || "-" }} </span> + <span> + {{ + legendList.find( + (item) => item.value == currentNodeInfo.unit + )?.name || "-" + }} + </span> + </div> + </div> + </div> + + <div + style=" + font-size: 16px; + font-weight: bold; + margin-bottom: 5px; + text-align: left; + margin-top: 10px; + " + > + <p style="margin-bottom: 15px"> + 瀛︿範鏃堕棿锛歿{ currentNodeInfo.studyTime || "-" }} + </p> + <p style="margin-bottom: 15px"> + 鐜板伐浣滃崟浣嶏細 + {{ currentNodeInfo.currentEmployer_secondary || "-" }} + </p> + <p style="margin-bottom: 15px"> + 鑱屽姟锛歿{ currentNodeInfo.jobTitle || "-" }} + </p> + <p style="margin-bottom: 15px"> + 鑱岀О锛歿{ currentNodeInfo.professionalTitle || "-" }} + </p> + </div> + <div + style=" + text-align: left; + line-height: 22px; + max-height: 200px; + overflow-y: auto; + padding: 10px; + " + > + <div v-html="currentNodeInfo.studentProfile"></div> + </div> + <!-- <div + style=" + display: flex; + justify-content: space-between; + margin-top: 20px; + " + > + <div style="text-align: left; width: 48%; line-height: 22px"> + <p> + 瑙傚か鏄庡爞涔嬪畯澹篃锛屽垯绐佸厐鐬虫洦锛屼箥鏄庝箥钂欙紝鑻ュぇ鍙ゅ厓姘斾箣缁撶┖銆傚穬宓搁娌擄紝鑻ュ惮鑻ュ丢锛屼技澶╅槂鍦伴棬涔嬪紑闃栥�傚皵涔冨垝宀濆硥浠ュ渤绔嬶紝閮佺┕宕囪�岄缚绾枫�傚啝鐧剧帇鑰屽瀭鍕嬶紝鐑涗竾璞¤�岃吘鏂囥�傜獧鎯氭亶浠ユ礊鍚紝鍛煎祵宀╄�屽倣鍒嗐�傚張姣斾箮鏄嗗北涔嬪ぉ鏌憋紝鐭椾節闇勮�屽瀭浜戙�� + </p> + </div> + <div> + <img src="@/assets/images/directory/test.png" alt="" /> + </div> + </div> --> + </div> + </div> + </transition> + </div> + <!-- 鍒楄〃鏄剧ず --> + <div class="page-main" v-show="activeTabs == 'list'"> + <div + v-loading="loading" + style="min-height: 550px" + element-loading-background="rgba(0, 0, 0, 0)" + element-loading-text="瀛︾敓鍒楄〃鍔犺浇涓�" + element-loading-spinner="el-icon-loading" + > + <div v-for="(item, index) in universityList" :key="index"> + <div + class="table-title" + v-if="item.studentList && item.studentList.length > 0" + > + <div class="table-title-left"> + <p class="table-title-name">{{ item.unitName }}</p> + <p class="table-title-degree">{{ item.academicDegreeName }}</p> + <p class="table-title-number"> + {{ item.studentList.length }}浜� + </p> + </div> + <div + class="table-title-right" + @click="item.isShow = !item.isShow" + > + <img :src="[item.isShow ? topIcon : bottomIcon]" alt="" /> + </div> + </div> + <table + cellpadding="100" + v-if=" + item.studentList && item.studentList.length > 0 && item.isShow + " + style="vertical-align: middle" + > + <tr class="table-heading"> + <th>濮撳悕</th> + <th>鎬у埆</th> + <th>瀛︿範鏃堕棿</th> + <th>宸ヤ綔鍗曚綅锛堝埌浜岀骇鍗曚綅鍏ㄧО锛�</th> + <th>鑱屽姟</th> + <th>鑱岀О</th> + </tr> + <tr v-for="(citem, cindex) in item.studentList" :key="cindex"> + <td> + {{ citem.name }} + </td> + <td> + {{ citem.gender == "male" ? "鐢�" : "濂�" }} + </td> + <td>{{ citem.studyTime }}</td> + <td>{{ citem.currentEmployer_secondary }}</td> + <td> + {{ + citem.jobTitle === undefined || citem.jobTitle === "" + ? "-" + : citem.jobTitle + }} + </td> + <td> + {{ + citem.professionalTitle === undefined || + citem.professionalTitle === "" + ? "-" + : citem.professionalTitle + }} + </td> + </tr> + </table> + </div> + </div> + <!-- <el-empty v-if="!resultList.length"></el-empty> --> + </div> + </div> + </div> </template> <script> -export default {}; +import * as echarts from "echarts"; +import axios from "axios"; +import debounce from "lodash/debounce"; +import treeData from "./treeData.json"; +import MG from "@/assets/js/middleGround/WebMiddleGroundApi.js"; +import { forEach } from "lodash"; +import { method } from "lodash"; +export default { + data() { + return { + unitRefCode: "unit", + academicDegreeRefCode: "academicDegree", + unitList: [], + academicDegreeList: [], + chartIcon: require("@/assets/images/directory/chartIcon.png"), + noChartIcon: require("@/assets/images/directory/noChartIcon.png"), + listIcon: require("@/assets/images/directory/listIcon.png"), + noListIcon: require("@/assets/images/directory/noListIcon.png"), + topIcon: require("@/assets/images/directory/topIcon.png"), + bottomIcon: require("@/assets/images/directory/bottomIcon.png"), + activeTabs: "chart", + universityList: [], + chart: null, + chartData: {}, + currentNodeInfo: {}, + tooltipShow: false, + legendList: [ + { + color: "#87A7B9", + name: "鍖椾含涓尰澶у", + value: "BUCM", + }, + { + color: "#C48787", + name: "鍖椾含甯堣寖澶у", + value: "BNU", + }, + { + color: "#6F8F5A", + name: "涓浗涓尰绉戝闄�", + value: "CACMS", + }, + { + color: "#937950", + name: "骞垮窞涓尰鑽ぇ瀛�", + value: "GZUCM", + }, + { + color: "#8D77B3", + name: "鎷滃笀寮熷瓙", + value: "disciple", + }, + ], + loading: false, + }; + }, + + mounted() { + this.initChart(); + window.addEventListener("resize", this.handleResize); + this.getSelectData(); + this.getStudentList(); + }, + beforeDestroy() { + // window.removeEventListener("resize", this.handleResize); + if (this.chart) { + this.chart.dispose(); + } + }, + methods: { + changeTab(key) { + this.activeTabs = key; + console.log(this.activeTabs, "activeTabs"); + if (key == "chart") { + this.initChart(); + } + }, + initChart() { + this.chart = echarts.init(this.$refs.chart); + const option = { + tooltip: { + trigger: "item", + triggerOn: "mousemove", + backgroundColor: "#FDF8F0", + formatter: (params) => { + const data = params.data; + this.currentNodeInfo = data; + console.log(data, "data"); + if (data.cmsItemType == "student") { + return ` + <div style=" + padding: 10px; + background: #FDF8F0; + border-radius: 5px; + max-width: 300px; + width: 360px; + text-align: center; + "> + <div style="width: 80px;height: 80px;position: relative; margin: 0 auto; margin-bottom: 10px;background: #D8D8D8;"> + <img class="autoImg" src="${ + data.icon + ? data.icon + : require("@/assets/images/directory/touxiang.png") + }" alt=""> + </div> + <div style="font-size: 16px; font-weight: bold; margin-bottom: 5px;">${ + data.name || "-" + }</div> + <div> <span> ${ + data.gender == "male" ? "鐢�" : "濂�" || "-" + } </span> <span> ${data.academicName || "-"} </span> <span> ${ + this.legendList.find((item) => item.value == data.unit)?.name || + "-" + } </span></div> + <div style="font-size: 16px; font-weight: bold; margin-bottom: 5px;text-align: left;margin-top: 10px;overflow: hidden;"> + <p style="margin-bottom: 5px;">瀛︿範鏃堕棿锛�${ + data.studyTime || "-" + }</p> + <p style="margin-bottom: 5px; white-space: pre-wrap" >鐜板伐浣滃崟浣嶏細${ + data.currentEmployer_secondary || "-" + }</p> + <p style="margin-bottom: 5px;">鑱屽姟锛�${ + data.jobTitle || "-" + }</p> + <p style="margin-bottom: 5px;">鑱岀О锛�${ + data.professionalTitle || "-" + }</p> + </div> + + </div> + `; + } else { + return ` + <div style=" + padding: 10px; + background: #FDF8F0; + border-radius: 5px; + max-width: 300px; + width: 360px; + text-align: center; + "> + <div style="width: 80px;height: 80px;position: relative; margin: 0 auto; margin-bottom: 10px;background: #D8D8D8;"> + <img class="autoImg" src="${require("@/assets/images/directory/touxiang.png")}" alt=""> + </div> + <div style="font-size: 16px; font-weight: bold; margin-bottom: 5px;">${ + data.name + }</div> + <div> <span> ${data.academicDegreeName || "-"} </span></div> + + </div> + `; + } + }, + }, + textStyle: { + color: "#bc1c00", // 璁剧疆鏁翠綋瀛椾綋棰滆壊涓虹孩鑹� + }, + edgeLabel: { + normal: { + color: "#bc1c00", // 璁剧疆绾挎潯鐨勯鑹蹭负绾㈣壊 + }, + }, + series: [ + { + type: "tree", + data: [this.chartData], + top: "10%", + bottom: "10%", + layout: "radial", + symbol: "circle", + symbolSize: 7, + initialTreeDepth: 3, // 灞曞紑鎵�鏈夎妭鐐� + animationDurationUpdate: 750, + emphasis: { + focus: "descendant", + }, + + label: { + position: "top", //鏍囩鐨勪綅缃�� + verticalAlign: "middle", //鏂囧瓧鍨傜洿瀵归綈鏂瑰紡锛岄粯璁よ嚜鍔ㄣ�� + fontSize: 12, //鏂囧瓧鐨勫瓧浣撳ぇ灏� + color: "#bc1c00", + }, + // leaves: { + // symbol: "emptyCircle", + // label: { + // fontSize: 12, + // }, + // }, + expandAndCollapse: false, + lineStyle: { + color: "#bc1c00", + width: 1, + }, + itemStyle: { + color: function (params) { + return "green"; + }, + }, + roam: true, + center: ["5%", "0%"], // 寰皟鍨傜洿灞呬腑 + radius: "100%", // 澧炲ぇ鍗婂緞鍗犳瘮 + nodePadding: 120, + }, + ], + }; + + this.chart.setOption(option); + this.chart.on("click", (params) => { + console.log("鐐瑰嚮鏃剁殑鍥炶皟", params); + this.tooltipShow = true; + }); + }, + handleResize() { + if (this.chart) { + this.chart.resize(); + } + }, + //鑾峰彇涓嬫媺閫夋嫨妗嗙殑鍐呭 + async getSelectData() { + try { + // 鍚屾椂鍙戣捣涓や釜寮傛璇锋眰锛屽苟绛夊緟瀹冧滑鐨勭粨鏋� + const [unitListResult, academicDegreeListResult] = await Promise.all([ + this.getSelectContent(this.unitRefCode), + this.getSelectContent(this.academicDegreeRefCode), + ]); + this.unitList = unitListResult.option.map((item) => { + return { + ...item, + studentList: [], // 璁剧疆鑷畾涔夊瓧娈电殑榛樿鍊� + }; + }); + this.academicDegreeList = academicDegreeListResult.option; + console.log(this.academicDegreeList, "this.academicDegreeList"); + } catch (error) { + console.error("鑾峰彇涓嬫媺妗嗘暟鎹け璐�:", error); + } + }, + + //鑾峰彇閫夋嫨鍐呭 + getSelectContent(refCode) { + let requestData = { refCodes: [refCode] }; + return MG.store + .getProductTypeField(requestData) + .then((res) => { + console.log(res, "涓嬫媺妗嗘暟鎹�"); + const selestList = JSON.parse(res[0].config); + return selestList; + }) + .catch((error) => { + console.error("鑾峰彇鑽h獕澶辫触:", error); + return null; + }); + }, + + // 鑾峰彇鍒楄〃鏄剧ず + getStudentList() { + this.loading = true; + MG.resource + .getItem({ + path: "WYY_student", + fields: { + // 鎬у埆 + gender: "", + //瀛︿範鏃堕棿 + studyTime: [], + // 鍗曚綅 + unit: [], + // 鐜板伐浣滃崟浣嶏紙鍒颁簩绾у崟浣嶅叏绉帮級 + currentEmployer_secondary: "", + //鑱屽姟 + jobTitle: "", + professionalTitle: "", + //瀛︿綅 + academicDegree: "", + // 瀛︾敓绠�浠� + studentProfile: "", + }, + paging: { + size: 99999, + }, + }) + .then((res) => { + let arrList = []; + this.unitList.forEach((item) => { + this.academicDegreeList.forEach((citem) => { + arrList.push({ + unitName: item.name, + name: item.name, + unitValue: item.value, + academicDegreeName: citem.name, + academicDegreeValue: citem.value, + isShow: false, + studentList: [], + itemStyle: { + color: + this.legendList.find( + (legendItem) => legendItem.value === item.value + )?.color || "#000000", + }, + children: [], + }); + }); + }); + this.loading = false; + console.log(res, "res"); + if (res.datas && res.datas.length) { + res.datas.forEach((item) => { + arrList.forEach((citem) => { + if ( + item.unit == citem.unitValue && + item.academicDegree == citem.academicDegreeValue + ) { + item.academicName = this.academicDegreeList.find( + (f) => f.value == item.academicDegree + )?.name; + citem.studentList.push(item); + citem.children.push(item); + } + }); + }); + arrList = arrList.filter((item) => item.studentList.length); + console.log(arrList, "arrList"); + this.universityList = arrList; + // this.chartData.children = arrList; + const temp_chartData = { + name: "鐜嬫案鐐�", + children: arrList, + }; + this.chartData = temp_chartData; + + console.log(this.chartData, "this.chartData"); + this.initChart(); + } + }) + .catch((error) => { + console.error("鑾峰彇鑽h獕澶辫触:", error); + }); + }, + }, +}; </script> -<style></style> +<style lang="less" scoped> +.page { + width: 100%; + height: 100%; + box-sizing: border-box; + background-color: #e9e1d4; + position: relative; + overflow: hidden; + display: flex; + flex-direction: column; +} + +.page-header { + padding: 8px 0; + height: 9.4%; + width: 100%; + text-align: left; + border-bottom: 2px solid #937950; + background-color: #e9e1d4; + position: sticky; + top: 0; + z-index: 100; + + p { + height: 100%; + font-family: Alimama DongFangDaKai; + font-size: 30px; + text-indent: 1em; + border-bottom: 1px solid #937950; + display: flex; + align-items: center; + } +} + +.page-main-father { + flex: 1; + width: 100%; + height: 100%; + min-width: 1200px; + overflow: auto; + padding-top: 2%; + padding-bottom: 2%; +} + +.page-main-title { + display: flex; + align-items: center; + justify-content: center; + cursor: pointer; + margin-bottom: 25px; + color: #9e9e9e; + margin-top: 1%; + + p { + display: flex; + align-items: center; + padding: 15.5px 20px; + border-bottom: 2px solid #9e9e9e; + } + + img { + width: 24px; + height: auto; + margin-right: 10px; + } + + span { + font-family: Source Han Sans; + font-size: 24px; + font-weight: bold; + } +} + +.active-tab { + color: #937950 !important; + border-bottom: 2px solid #937950 !important; +} + +.page-main { + width: 77.3%; + min-height: 600px; + margin: 0 auto; + overflow: hidden; + margin-bottom: 100px; + padding-top: 50px; + table { + width: 100%; + border-collapse: collapse; + } + + tr { + width: 100%; + background-color: #fff; + background-clip: padding-box; + border-bottom: 2px solid transparent; + } + + th { + font-family: Source Han Serif CN; + font-size: 14px; + font-weight: bold; + padding: 4px 41px; + text-wrap: nowrap; + } + + td { + font-family: Source Han Serif CN; + font-size: 14px; + padding: 6px 41px; + text-align: center; + display: table-cell; + vertical-align: middle; + } + + td:nth-child(1) { + text-wrap: nowrap; + } + + tr:last-child td { + border-bottom: none; + /* 绉婚櫎鏈�鍚庝竴琛岀殑涓嬭竟妗� */ + } +} + +.charts-main { + // background-color: #000; + position: relative; + margin: 0 auto; + min-height: 600px; +} + +.table-title { + display: flex; + align-items: center; + justify-content: space-between; + padding: 10px 28px; + background-color: #d8cbb6; + margin-bottom: 4px; + margin-top: 2px; + + .table-title-left { + display: flex; + align-items: center; + } + + .table-title-name { + width: 200px; + overflow: hidden; + font-family: Source Han Serif CN; + font-size: 18px; + font-weight: bold; + } + + .table-title-degree { + font-family: Source Han Serif CN; + font-size: 14px; + font-weight: bold; + margin-right: 40px; + } + + .table-title-number { + font-family: Source Han Serif CN; + font-size: 14px; + font-weight: bold; + } + + .table-title-right { + cursor: pointer; + } + + img { + width: 20px; + height: auto; + } +} + +.tooltipBox { + max-height: 500px; + max-width: 500px; + background-color: #fdf8f0; + position: absolute; + right: 40px; + top: 12vh; +} + +.closeBtn { + position: absolute; + top: 10px; + right: 0; + cursor: pointer; +} + +.legend { + position: absolute; + bottom: 300px; + left: 100px; +} + +.tagItem { + display: flex; + margin-top: 20px; +} + +.tagColor { + width: 20px; + height: 20px; +} + +.tagText { + margin-left: 30px; +} +::v-deep .el-loading-spinner { + color: #937950 !important; +} + +::v-deep .el-loading-spinner .el-loading-text { + font-size: 14px; + color: #937950; +} +</style> -- Gitblit v1.9.1