From 3bab59284578d6e6d2fa2f807895c60ebc54bdcc Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期二, 17 六月 2025 16:01:23 +0800
Subject: [PATCH] 测试完成

---
 src/views/knowledge/education/index.vue |  285 ++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 273 insertions(+), 12 deletions(-)

diff --git a/src/views/knowledge/education/index.vue b/src/views/knowledge/education/index.vue
index c70696b..3be5dc8 100644
--- a/src/views/knowledge/education/index.vue
+++ b/src/views/knowledge/education/index.vue
@@ -161,6 +161,16 @@
                   >鍒犻櫎</el-button
                 >
               </el-col>
+              <el-col :span="1.5">
+                <el-button
+                  type="success"
+                  plain
+                  icon="el-icon-data-line"
+                  size="medium"
+                  @click="statistics"
+                  >缁熻鍒嗘瀽</el-button
+                >
+              </el-col>
 
               <!-- <el-col :span="1.5"> </el-col> -->
             </el-row>
@@ -312,15 +322,15 @@
                       ><i class="el-icon-edit"></i>浜岀淮鐮�</span
                     ></el-button
                   > -->
-                  <!-- <el-button
+                  <el-button
                     size="medium"
                     type="text"
                     @click="Vieweducation(scope.row)"
                     v-hasPermi="['system:user:edit']"
                     ><span class="button-textck"
-                      ><i class="el-icon-edit"></i>鏌ョ湅</span
+                      ><i class="el-icon-edit"></i>棰勮</span
                     ></el-button
-                  > -->
+                  >
                   <el-button
                     size="medium"
                     type="text"
@@ -444,6 +454,29 @@
         <div class="qrcode-img"></div>
       </div>
     </el-dialog>
+    <el-dialog title="妯℃澘棰勮" :visible.sync="previewtf" width="60%">
+      <div class="preview-left">
+        <!-- 鍗曢�� -->
+        <div v-html="htmlRichText"></div>
+      </div>
+      <!-- <span slot="footer" class="dialog-footer">
+        <el-button @click="previewGo">鍓嶅線妯℃澘璇︽儏淇敼</el-button>
+        <el-button type="primary" @click="previewFn">纭浣跨敤</el-button>
+      </span> --> </el-dialog
+    >\
+    <!-- 缁熻鍥捐〃 -->
+    <el-dialog width="80%" title="绠¢ゲ瀹f暀缁熻" :visible.sync="statisticson">
+      <div class="grid-content bg-purple" style="min-height: 300px">
+        <div class="title">
+          瀹f暀缁熻
+          <span class="el-icon-s-unfold moreIcon"></span>
+        </div>
+        <div class="cooperate">
+          <!-- 鍚堜綔鍖哄煙 -->
+          <div class="pieChart" id="pieCharts"></div>
+        </div>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -461,11 +494,12 @@
   getillnesslist,
   illnesslistget,
   getillness,
+  deltargetillness,
 } from "@/api/AiCentre/index";
 import { listDept } from "@/api/system/dept";
 import { getToken } from "@/utils/auth";
 import store from "@/store";
-
+import axios from "axios";
 import Treeselect from "@riophae/vue-treeselect";
 import "@riophae/vue-treeselect/dist/vue-treeselect.css";
 export default {
@@ -489,10 +523,13 @@
       total: 0,
       nameeducation: "",
       haoeducation: "",
+      statisticson: false,
       indexid: null,
       inputValue: "",
+      htmlRichText: "",
       radio: "涓诲垎绫�",
       inputVisible: false,
+      previewtf: false,
       illnessVisible: false, //鎸囨爣鐤剧梾寮规
       deptOptions: [],
       courtyardlist: [],
@@ -551,7 +588,9 @@
       xjxsoptions: [],
       deptList: [],
       props: { multiple: true, value: "deptId", label: "deptName" },
-
+      Collarr: [],
+      Collarrname: [],
+      Collarrvalue: [],
       //绫诲埆鍒楄〃
       editableTabs: [],
       // 鏌ヨ鍙傛暟
@@ -600,6 +639,113 @@
       this.nameeducation = row.userName;
       this.haoeducation = row.nickName;
     },
+    // 鍚堜綔鍟嗙偣浣嶆眹鎬荤粺璁¢ゼ鐘跺浘
+    async getnodeCollect() {
+      // const res = await getnodeCollect();
+      // this.nodeCollect = res.data;
+      // this.nodeCollect = [
+      //   { name: "闂ㄨ瘖闅忚", value: 1232 },
+      //   { name: "鍑洪櫌闅忚", value: 342 },
+      // ];
+      this.myPieChart();
+    },
+    // 楗肩姸鍥�
+    myPieChart() {
+      // 鍩轰簬鍑嗗濂界殑dom锛屽垵濮嬪寲echarts瀹炰緥
+      var echarts = require("echarts");
+      var mypPieCharts = echarts.init(document.getElementById("pieCharts"));
+      this.mypPieCharts = mypPieCharts;
+      // 鎸囧畾鍥捐〃鐨勯厤缃」鍜屾暟鎹�
+      var optionPie = {
+        tooltip: {
+          trigger: "item",
+          formatter: "{a} <br/>{b} : {c} ({d}%)",
+        },
+        legend: {
+          left: "left",
+          orient: "horizontal", // 鍥句緥椤规按骞虫帓鍒�
+          top: "top", // 鍥句緥鏀剧疆鍦ㄩ《閮�
+          data: this.Collarrname,
+        },
+        toolbox: {
+          feature: {
+            magicType: {
+              type: ["stack"],
+            },
+            dataView: {},
+          },
+        },
+        xAxis: [
+          {
+            type: "category",
+            data: this.Collarrname,
+            axisLabel: {
+              formatter: "{value}",
+            },
+          },
+        ],
+        grid: { top: "30%", left: "10%", right: "40%", bottom: "10%" },
+        yAxis: [
+          {
+            type: "value",
+          },
+        ],
+        series: [
+          {
+            name: "鏌ョ湅娆℃暟",
+            type: "bar",
+            data: this.Collarrvalue,
+            seriesLayoutBy: "row",
+            smooth: true,
+            label: {
+              show: true,
+              position: "inside",
+            },
+            emphasis: { focus: "series" },
+          },
+          {
+            name: "鏌ョ湅娆℃暟姣旂巼",
+            type: "pie",
+            radius: "30%",
+            radius: ["40%", "70%"],
+            center: ["80%", "60%"],
+            data: this.Collarr,
+            emphasis: {
+              focus: "self",
+            },
+            itemStyle: {
+              borderRadius: 10,
+              borderColor: "#fff",
+              borderWidth: 2,
+            },
+            label: {
+              formatter: "{b}: {d}%",
+            },
+          },
+        ],
+      };
+      mypPieCharts.on("updateAxisPointer", function (event) {
+        const xAxisInfo = event.axesInfo[0];
+        if (xAxisInfo) {
+          const dimension = xAxisInfo.value + 1;
+          mypPieCharts.setOption({
+            series: {
+              id: "pie",
+              label: {
+                formatter: "{b}: {@[" + dimension + "]} ",
+              },
+              encode: {
+                value: dimension,
+                tooltip: dimension,
+              },
+            },
+          });
+        }
+      });
+
+      // 浣跨敤鍒氭寚瀹氱殑閰嶇疆椤瑰拰鏁版嵁鏄剧ず鍥捐〃銆�
+      mypPieCharts.setOption(optionPie);
+    },
     // 琛ㄥ崟閲嶇疆
     reset() {
       this.form = {};
@@ -628,22 +774,37 @@
     /** 鏂板鎸夐挳鎿嶄綔 */
     handleAdd() {
       this.$router.push({
-        path: "/knowledge/education/compilequer/",
+        path: "/knowledge/educationinfo/",
       });
     },
     /** 淇敼鎸夐挳鎿嶄綔 */
     handleUpdate(row) {
       this.$router.push({
-        path: "/knowledge/education/compilequer/",
+        path: "/knowledge/educationinfo/",
         query: { id: row.id },
       });
     },
     // 鏌ョ湅瀹f暀
-    Vieweducation() {
-      this.$router.push({
-        path: "/knowledge/education/examine/",
-        query: { id: row.id },
-      });
+    Vieweducation(row) {
+      this.htmlRichText = null;
+      this.previewtf = true;
+      axios
+        .get(row.htmlRichText)
+        .then((response) => {
+          console.log(response.data, "鏁版嵁"); // 杈撳嚭鑾峰彇鍒扮殑鏂囦欢鍐呭
+          this.htmlRichText = response.data;
+          this.htmlRichText = this.addStyleToImages(this.htmlRichText);
+        })
+        .catch((error) => {
+          this.$modal.msgError("鑾峰彇瀵屾枃鏈け璐�");
+          console.error("Failed to fetch file:", error);
+        });
+    },
+    addStyleToImages(html) {
+      return html.replace(
+        /<img([^>]*)style=(['"])(?:(?!\2).)*\2([^>]*)>/g,
+        '<img$1style="width:100%;height:auto;"$3>'
+      );
     },
 
     /** 鍒犻櫎鎸夐挳鎿嶄綔 */
@@ -659,6 +820,29 @@
           this.$modal.msgSuccess("鍒犻櫎鎴愬姛");
         })
         .catch(() => {});
+    },
+    // 鎵撳紑缁熻鍥捐〃
+    statistics() {
+      //鍙栨暟鎹�
+      let obj = { assortid: 13, isavailable: "", pageNum: 1, pageSize: 20 };
+      getlibrarylist(obj).then((response) => {
+        console.log(response.rows, "response.rows");
+        response.rows.forEach((item) => {
+          this.Collarr.push({ name: item.preachname, value: item.watchCount });
+        });
+        this.Collarrname = this.Collarr.map((item) => item.name);
+
+        // 鎻愬彇 value 灞炴�у埌涓�涓柊鏁扮粍
+        this.Collarrvalue = this.Collarr.map((item) =>
+          parseInt(item.value, 10)
+        );
+        this.statisticson = true;
+        this.$nextTick(function () {
+          this.getnodeCollect();
+        });
+        this.total = response.total;
+        this.loading = false;
+      });
     },
 
     // 鍒嗙被鏍�-----------------------------------------
@@ -953,6 +1137,83 @@
     vertical-align: bottom;
   }
 }
+
+.bg-purple {
+  background: #fff;
+}
+
+.grid-content {
+  min-height: 36px;
+  border-radius: 20px;
+  padding: 0 10px;
+}
+.title {
+  -webkit-box-align: center;
+  -ms-flex-align: center;
+  align-items: center;
+  -webkit-box-flex: 1;
+  -ms-flex: 1;
+  flex: 1;
+  font-size: 16px;
+  font-family: PingFangSC-Semibold, PingFang SC;
+  font-weight: 600;
+  color: #333;
+  padding-top: 17px;
+  padding-bottom: -4px;
+
+  span {
+    margin-left: 10px;
+    font-size: 12px;
+    font-family: PingFangSC-Regular, PingFang SC;
+    font-weight: 400;
+    color: #999;
+  }
+}
+.moreIcon {
+  font-size: 22px !important;
+  margin-left: 400px !important;
+  color: #5f84ff !important;
+  cursor: pointer;
+}
+.cooperate {
+  width: 100%;
+  height: 280px;
+  margin-top: 25px;
+  display: flex;
+  .pieChart {
+    flex: 1;
+  }
+  .Points {
+    width: 154px;
+    height: 230px;
+    text-align: center;
+    padding: 20px 0;
+    background: linear-gradient(135deg, transparent, #f8f8f9 0) 0 0,
+      linear-gradient(-135deg, transparent 12px, #f8f8f9 0) 100% 0,
+      linear-gradient(-45deg, transparent, #f8f8f9 0) 100% 100%,
+      linear-gradient(45deg, transparent 12px, #f8f8f9 0) 0 100%;
+    background-size: 50% 50%;
+    background-repeat: no-repeat;
+    p {
+      height: 33px;
+      margin-bottom: 10px;
+      font-size: 24px;
+      font-family: PingFangSC-Semibold, PingFang SC;
+      font-weight: 600;
+      color: #072074;
+      line-height: 33px;
+    }
+    span {
+      height: 17px;
+      margin-top: 6px;
+      font-size: 12px;
+      font-family: PingFangSC-Regular, PingFang SC;
+      font-weight: 400;
+      color: #000412;
+      line-height: 17px;
+    }
+  }
+}
 ::v-deep .el-tree-node__content {
   display: -webkit-box;
   display: -ms-flexbox;

--
Gitblit v1.9.3