From 96de5562aa8245de24582623951fed016cf90a00 Mon Sep 17 00:00:00 2001
From: zhongshujie <2862698242@qq.com>
Date: 星期二, 08 四月 2025 11:02:45 +0800
Subject: [PATCH] Merge branch 'master' of http://182.92.203.7:2001/r/wyyDatabase

---
 src/views/directory/index.vue |  266 +++++++++++++++++++++++++++++++++-------------------
 1 files changed, 167 insertions(+), 99 deletions(-)

diff --git a/src/views/directory/index.vue b/src/views/directory/index.vue
index 30043b4..a3561dd 100644
--- a/src/views/directory/index.vue
+++ b/src/views/directory/index.vue
@@ -4,77 +4,26 @@
       <p>鐜嬫案鐐庨櫌澹鐢熺洰褰�</p>
     </div>
     <div class="page-main-title">
-      <p @click="changeTab('chart')" :class="[activeTabs == 'chart' ? 'active-tab' : '']">
-        <img :src="[activeTabs == 'chart' ? chartIcon : noChartIcon]" alt="">
+      <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="">
+      <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-if="activeTabs == 'chart'">
-      <!-- <div class="pageBox">
-        <div class="main" v-loading="loading" element-loading-text="鍔犺浇涓�..."
-          element-loading-background="rgba(255,255,255,.5)">
-          <div class="main-content">
-            <div class="detailBox">
-              <div class="legendBox">
-                <div class="legendItem">
-                  <div class="lengend-color"></div>
-                  <div class="lengend-text">鐢�</div>
-                </div>
-                <div class="legendItem">
-                  <div class="lengend-color"></div>
-                  <div class="lengend-text">鏃�</div>
-                </div>
-                <div class="legendItem">
-                  <div class="lengend-color"></div>
-                  <div class="lengend-text">鍑�</div>
-                </div>
-                <div class="legendItem">
-                  <div class="lengend-color"></div>
-                  <div class="lengend-text">鏈�</div>
-                </div>
-                <div class="legendItem">
-                  <div class="lengend-color"></div>
-                  <div class="lengend-text">涓�</div>
-                </div>
-                <div class="legendItem">
-                  <div class="lengend-color"></div>
-                  <div class="lengend-text">鏈煡</div>
-                </div>
-              </div>
-              <div class="echartsBox">
-                <div class="clickBox" id="clickBox">
-                  <div class="clickBoxContent">
-                    <div class="imgBox" style="width: 300px; height: 150px">
-                      <img :src="detailData.img" />
-                    </div>
-                    <div class="title">{{ detailData.title }}</div>
-                    <div class="subTitle">{{ detailData.subTitle }}</div>
-                    <div class="desc">{{ detailData.desc }}</div>
-                    <div class="btnBox">
-                      <div @click="gotoDetail()" class="detailBtn">浜嗚В鏇村</div>
-                      <img class="closeBtn" @click.stop="closeDetail()"
-                        src="@/assets/images/chronology/icon_close.svg" />
-                    </div>
-                  </div>
-                </div>
-                <div class="echarts" style="width: 100%; height: 100%"></div>
-              </div>
-              <div class="toponymBox">
-                <div class="imgBox" style="width: 280px; height: 280px">
-                  <img :src="toponymData.img" />
-                </div>
-                <div class="">鎴忛櫌锛歿{ toponymData.toponymName || "-" }}</div>
-                <div class="">鍐滃巻锛歿{ toponymData.chineseTime || "-" }}</div>
-              </div>
-            </div>
-          </div>
-        </div>
-      </div> -->
+      <div class="radial-tree-container">
+        <div ref="chart" style="width: 100%; height: 600px"></div>
+      </div>
     </div>
     <!-- 鍒楄〃鏄剧ず -->
     <div class="page-main" v-if="activeTabs == 'list'">
@@ -85,17 +34,14 @@
             <p class="table-title-degree">{{ item.degree }}</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 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">
           <tr class="table-heading">
-            <th>
-              濮撳悕
-            </th>
-            <th>
-              鎬у埆
-            </th>
+            <th>濮撳悕</th>
+            <th>鎬у埆</th>
             <th>瀛︿範鏃堕棿</th>
             <th>宸ヤ綔鍗曚綅锛堝埌浜岀骇鍗曚綅鍏ㄧО锛�</th>
             <th>鑱屽姟</th>
@@ -120,7 +66,8 @@
 </template>
 
 <script>
-import echarts from "@/assets/js/echarts.min.js";
+import * as echarts from "echarts";
+import axios from "axios";
 export default {
   data() {
     return {
@@ -161,7 +108,7 @@
               position: "鍘熼櫌闀�",
               title: "涓讳换鍖诲笀銆佹暀鎺�",
             },
-          ]
+          ],
         },
         {
           name: "鍖椾含涓尰鑽ぇ瀛�",
@@ -192,7 +139,7 @@
               position: "鍘熼櫌闀�",
               title: "涓讳换鍖诲笀銆佹暀鎺�",
             },
-          ]
+          ],
         },
         {
           name: "鍖椾含涓尰鑽ぇ瀛�",
@@ -223,14 +170,13 @@
               position: "鍘熼櫌闀�",
               title: "涓讳换鍖诲笀銆佹暀鎺�",
             },
-          ]
+          ],
         },
         {
           name: "鍖椾含涓尰鑽ぇ瀛�",
           degree: "纭曞+",
           isShow: "true",
-          studentList: [
-          ]
+          studentList: [],
         },
         {
           name: "鍖椾含涓尰鑽ぇ瀛�",
@@ -261,14 +207,13 @@
               position: "鍘熼櫌闀�",
               title: "涓讳换鍖诲笀銆佹暀鎺�",
             },
-          ]
+          ],
         },
         {
           name: "鍖椾含涓尰鑽ぇ瀛�",
           degree: "纭曞+",
           isShow: "true",
-          studentList: [
-          ]
+          studentList: [],
         },
         {
           name: "鍖椾含涓尰鑽ぇ瀛�",
@@ -299,23 +244,147 @@
               position: "鍘熼櫌闀�",
               title: "涓讳换鍖诲笀銆佹暀鎺�",
             },
-          ]
+          ],
         },
-      ]
-    }
+      ],
+      chart: null,
+      chartData: {
+        name: "Root",
+        children: [
+          {
+            name: "鐜嬬帀鏉�",
+            children: [
+              { name: "Leaf 1-1" },
+              { name: "Leaf 1-2" },
+              { name: "Leaf 1-3" },
+            ],
+          },
+          {
+            name: "Node 2",
+            children: [
+              {
+                name: "Node 2-1",
+                children: [{ name: "Leaf 2-1-1" }, { name: "Leaf 2-1-2" }],
+              },
+              { name: "Leaf 2-2" },
+            ],
+          },
+          {
+            name: "Node 3",
+            children: [{ name: "Leaf 3-1" }, { name: "Leaf 3-2" }],
+          },
+        ],
+      },
+    };
   },
 
+  mounted() {
+    this.initChart();
+    window.addEventListener("resize", this.handleResize);
+  },
+  beforeDestroy() {
+    window.removeEventListener("resize", this.handleResize);
+    if (this.chart) {
+      this.chart.dispose();
+    }
+  },
   methods: {
     changeTab(key) {
-      this.activeTabs = key
+      this.activeTabs = key;
       console.log(this.activeTabs, "activeTabs");
-      // if (key == "chart") {
+      if (key == "chart") {
+        this.$nextTick(() => {
+          this.initChart();
+          window.addEventListener("resize", this.handleResize);
+        });
+      }
+    },
+    initChart() {
+      this.chart = echarts.init(this.$refs.chart);
+      const option = {
+        tooltip: {
+          trigger: "item",
+          triggerOn: "mousemove",
+          formatter: (params) => {
+            const data = params.data;
+            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> 鐢� </span> <span> 纭曞+ </span> <span> 鍖椾含涓尰鑽ぇ瀛� </span></div>
+                <div style="font-size: 16px; font-weight: bold; margin-bottom: 5px;text-align: left;margin-top: 10px;">
+                  <p style="margin-bottom: 5px;">瀛︿範鏃堕棿锛�1985.09 -1988.07</p>
+                  <p style="margin-bottom: 5px;">鐜板伐浣滃崟浣嶏細鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰尰闄�</p>
+                  <p style="margin-bottom: 5px;">鑱屽姟锛氬師闄㈤暱</p>
+                  <p style="margin-bottom: 5px;">鑱岀О锛氫富浠诲尰甯堛�佹暀鎺�</p>
+                  </div>
+                
+              </div>
+            `;
+          },
+        },
+        series: [
+          {
+            type: "tree",
+            data: [this.chartData],
+            layout: "radial",
+            symbol: "emptyCircle",
+            symbolSize: 7,
+            initialTreeDepth: -1, // 灞曞紑鎵�鏈夎妭鐐�
+            animationDurationUpdate: 750,
+            emphasis: {
+              focus: "descendant",
+            },
+            label: {
+              position: "left",
+              verticalAlign: "middle",
+              align: "right",
+              fontSize: 12,
+              rotate: 0,
+            },
+            leaves: {
+              label: {
+                position: "right",
+                verticalAlign: "middle",
+                align: "left",
+              },
+            },
+            expandAndCollapse: true,
+            lineStyle: {
+              color: "#ccc",
+              width: 1,
+            },
+            itemStyle: {
+              color: "#4f8ff7",
+              borderColor: "#4f8ff7",
+            },
+            roam: true,
+            center: ["10%", "15%"], // 寰皟鍨傜洿灞呬腑
+            radius: "60%", // 澧炲ぇ鍗婂緞鍗犳瘮
+            nodePadding: 20,
+          },
+        ],
+      };
 
-      // } else if (key == 'list') {
-
-      // }
-    }
-  }
+      this.chart.setOption(option);
+    },
+    handleResize() {
+      if (this.chart) {
+        this.chart.resize();
+      }
+    },
+  },
 };
 </script>
 
@@ -350,13 +419,13 @@
   justify-content: center;
   cursor: pointer;
   margin-bottom: 75px;
-  color: #9E9E9E;
+  color: #9e9e9e;
 
   p {
     display: flex;
     align-items: center;
     padding: 15.5px 20px;
-    border-bottom: 2px solid #9E9E9E;
+    border-bottom: 2px solid #9e9e9e;
   }
 
   img {
@@ -376,8 +445,6 @@
   color: #937950 !important;
   border-bottom: 2px solid #937950 !important;
 }
-
-
 
 .page-main {
   width: 1313px;
@@ -416,15 +483,18 @@
   }
 }
 
+.charts-main {
+  // background-color: #000;
+}
+
 .table-title {
   display: flex;
   align-items: center;
   justify-content: space-between;
   padding: 10px 28px;
-  background-color: #D8CBB6;
+  background-color: #d8cbb6;
   margin-bottom: 4px;
   margin-top: 2px;
-
 
   .table-title-left {
     display: flex;
@@ -452,7 +522,6 @@
     font-weight: bold;
   }
 
-
   .table-title-right {
     cursor: pointer;
   }
@@ -461,6 +530,5 @@
     width: 20px;
     height: auto;
   }
-
 }
 </style>

--
Gitblit v1.9.1