lsc 2 tahun lalu
induk
melakukan
a6a886ce1e
6 mengubah file dengan 974 tambahan dan 268 penghapusan
  1. 31 0
      package-lock.json
  2. 1 0
      package.json
  3. 1 1
      src/components/pages/curriculum.vue
  4. 791 218
      src/components/pages/data.vue
  5. 148 49
      src/components/pages/score.vue
  6. 2 0
      src/main.js

+ 31 - 0
package-lock.json

@@ -3494,6 +3494,22 @@
         "stream-shift": "^1.0.0"
       }
     },
+    "echarts": {
+      "version": "5.0.2",
+      "resolved": "https://registry.npmmirror.com/echarts/-/echarts-5.0.2.tgz",
+      "integrity": "sha512-En0VYpc96nw2/2AZoBWPHsGi471zMublttj50kfFpYAeR4geup0Tj9iVgEXh7QYZFPnRiruDJEjcB5PXZ+BYzQ==",
+      "requires": {
+        "tslib": "2.0.3",
+        "zrender": "5.0.4"
+      },
+      "dependencies": {
+        "tslib": {
+          "version": "2.0.3",
+          "resolved": "https://registry.npmmirror.com/tslib/-/tslib-2.0.3.tgz",
+          "integrity": "sha512-uZtkfKblCEQtZKBF6EBXVZeQNl82yqtDQdv+eck8u7tdPxjLu2/lp5/uPW+um2tpuxINHWy3GhiccY7QgEaVHQ=="
+        }
+      }
+    },
     "ee-first": {
       "version": "1.1.1",
       "resolved": "https://registry.npm.taobao.org/ee-first/download/ee-first-1.1.1.tgz",
@@ -12238,6 +12254,21 @@
           "dev": true
         }
       }
+    },
+    "zrender": {
+      "version": "5.0.4",
+      "resolved": "https://registry.npmmirror.com/zrender/-/zrender-5.0.4.tgz",
+      "integrity": "sha512-DJpy0yrHYY5CuH6vhb9IINWbjvBUe/56J8aH86Jb7O8rRPAYZ3M2E469Qf5B3EOIfM3o3aUrO5edRQfLJ+l1Qw==",
+      "requires": {
+        "tslib": "2.0.3"
+      },
+      "dependencies": {
+        "tslib": {
+          "version": "2.0.3",
+          "resolved": "https://registry.npmmirror.com/tslib/-/tslib-2.0.3.tgz",
+          "integrity": "sha512-uZtkfKblCEQtZKBF6EBXVZeQNl82yqtDQdv+eck8u7tdPxjLu2/lp5/uPW+um2tpuxINHWy3GhiccY7QgEaVHQ=="
+        }
+      }
     }
   }
 }

+ 1 - 0
package.json

@@ -11,6 +11,7 @@
   },
   "dependencies": {
     "axios": "^0.21.1",
+    "echarts": "^5.0.2",
     "element-ui": "^2.15.1",
     "file-saver": "^2.0.5",
     "jquery": "^3.6.0",

+ 1 - 1
src/components/pages/curriculum.vue

@@ -232,7 +232,7 @@
     <div v-if="proVisible" class="mask">
       <div class="progressBox">
         <div class="lbox">
-          <img :src="require('../../assets/loading.gif')" />压缩上传中,请稍后
+          <img :src="require('../../assets/loading.gif')" />上传中,请稍后
         </div>
         <el-progress
           :text-inside="true"

+ 791 - 218
src/components/pages/data.vue

@@ -1,85 +1,118 @@
 <template>
   <div style="width: 100%">
     <el-main>
-        <div class="tou">
-          <span>平台数据检测</span>
+      <div class="tou">
+        <span>平台数据检测</span>
+      </div>
+      <div id="statistics">
+        <div class="count">
+          <!-- <h4><div></div>目前平台学生(个)</h4> -->
+          <div>
+            <span>{{statics.sCount}}</span>
+            <img src="../../assets/dataimage/greenUp.png" />
+          </div>
         </div>
-        <div id="statistics">
-            <div class="count">
-                <!-- <h4><div></div>目前平台学生(个)</h4> -->
-                <div><span>1024</span><img src="../../assets/dataimage/greenUp.png"></div>
-            </div>
-            <div class="count">
-                <!-- <h4><div></div>劳动作业数量</h4> -->
-                <div><span>1863</span><img src="../../assets/dataimage/redUp.png"></div>
-            </div>
-            <div class="count">
-                <!-- <h4><div></div>劳动课程数量</h4> -->
-                <div><span>228</span><img src="../../assets/dataimage/blueUp.png"></div>
-            </div>
+        <div class="count">
+          <!-- <h4><div></div>劳动作业数量</h4> -->
+          <div>
+            <span>{{statics.wCount}}</span>
+            <img src="../../assets/dataimage/redUp.png" />
+          </div>
         </div>
-        <div id="graphicalArea">
-            <div class="graphical">
-                <span>课程劳动教育</span>
-                <div><img src="../../assets/dataimage/1.png"></div>
-            </div>
-            <div class="graphical">
-                <span>五育融合</span>
-                <div><img src="../../assets/dataimage/2.png"></div>
-            </div>
-            <div class="graphical">
-                <span>得奖占比</span>
-                <div><img src="../../assets/dataimage/3.png"></div>
-            </div>
-            <div class="graphical">
-                <span>家校社</span>
-                <div><img src="../../assets/dataimage/4.png"></div>
-            </div>
-            <div class="graphical">
-                <span>义工社团情况</span>
-                <div><img src="../../assets/dataimage/5.png"></div>
-            </div>
-            <div class="graphical">
-                <span>劳动素养</span>
-                <div><img src="../../assets/dataimage/6.png"></div>
-            </div>
+        <div class="count">
+          <!-- <h4><div></div>劳动课程数量</h4> -->
+          <div>
+            <span>{{statics.cCount}}</span>
+            <img src="../../assets/dataimage/blueUp.png" />
+          </div>
+        </div>
+      </div>
+      <div id="graphicalArea">
+        <div class="graphical">
+          <span>课程劳动教育</span>
+          <div>
+            <!-- <img src="../../assets/dataimage/1.png" style="width:90%" /> -->
+            <div
+              v-if="loading"
+              id="course_canvas"
+              class="echart"
+              style="width: 100%; height: 100%;margin:0 0 0 1rem"
+            ></div>
+          </div>
+        </div>
+        <div class="graphical">
+          <span>五育融合</span>
+          <div>
+            <!-- <img src="../../assets/dataimage/2.png" style="width:90%" /> -->
+            <div
+              id="five_canvas"
+              class="echart"
+              style="width: 100%; height: 100%;margin:0 0 0 1rem"
+            ></div>
+          </div>
+        </div>
+        <div class="graphical">
+          <span>得奖占比</span>
+          <div>
+            <div
+              id="title_canvas"
+              class="echart"
+              style="width: 100%; height: 100%;margin:0 0 0 1rem"
+            ></div>
+          </div>
+        </div>
+        <div class="graphical">
+          <span>家校社</span>
+          <div>
+            <!-- <img src="../../assets/dataimage/4.png" style="width:90%" /> -->
+            <div id="hsc_canvas" class="echart" style="width: 100%; height: 100%;margin:0 0 0 1rem"></div>
+          </div>
         </div>
-        <el-table
-            :data="tableData"
-            stripe="true"
-            :header-cell-style="{ background: '#3867d6',color:'#ffffff',textAlign:'center'}"
-            style="width: 91.5%;margin-top:20px;">
-            <el-table-column
-                type="index"
-                label="排名"
-                align="center"
-                width="250">
-                <!-- <img src="../../assets/dataimage/flag.png"> -->
-            </el-table-column>
-            <el-table-column
-                prop="name"
-                label="姓名"
-                align="center"
-                width="300">
-            </el-table-column>
-            <el-table-column
-                prop="class"
-                label="班级"
-                align="center"
-                width="200">
-            </el-table-column>
-            <el-table-column
-                prop="fraction"
-                label="积分"
-                align="center"
-                width="200">
-            </el-table-column>
-            <el-table-column
-                prop="school"
-                align="center"
-                label="学校">
-            </el-table-column>
-        </el-table>
+        <div class="graphical">
+          <span>义工社团情况</span>
+          <div>
+            <!-- <img src="../../assets/dataimage/5.png" style="width:90%" /> -->
+            <div
+              id="home_canvas"
+              class="echart"
+              style="width: 100%; height: 100%;margin:0 0 0 1rem"
+            ></div>
+          </div>
+        </div>
+        <div class="graphical">
+          <span>劳动素养</span>
+          <div>
+            <!-- <img src="../../assets/dataimage/6(1).png" width="200rem" />
+            <img src="../../assets/dataimage/6.png" />-->
+            <div id="lao_canvas" class="echart" style="width: 100%; height: 100%;margin:0 0 0 1rem"></div>
+          </div>
+        </div>
+      </div>
+      <el-table
+        :data="tableData"
+        :stripe="true"
+        :header-cell-style="{ background: '#3867d6',color:'#ffffff',textAlign:'center'}"
+        style="width: 91.5%;margin-top:20px;"
+        height="500px"
+      >
+        <el-table-column prop="name" label="排名" align="center" min-width="100">
+          <template slot-scope="scope">
+            <div style="display:flex;align-items:center;justify-content: center;">
+              {{scope.$index+1}}
+              <img src="../../assets/dataimage/flag.png" />
+            </div>
+          </template>
+          <!-- <img src="../../assets/dataimage/flag.png"> -->
+        </el-table-column>
+        <el-table-column prop="name" label="姓名" align="center" min-width="100"></el-table-column>
+        <el-table-column prop="classname" label="班级" align="center" min-width="100">
+          <template slot-scope="scope">
+            <div>{{scope.row.classname ? scope.row.classname : '暂无班级'}}</div>
+          </template>
+        </el-table-column>
+        <el-table-column prop="zscore" label="积分" align="center" min-width="100"></el-table-column>
+        <el-table-column prop="school" align="center" label="学校" min-width="100"></el-table-column>
+      </el-table>
     </el-main>
   </div>
 </template>
@@ -88,154 +121,694 @@
 export default {
   data() {
     return {
-        tableData: [{
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          }, {
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          }, {
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          }, {
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          },{
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          },{
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          },{
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          },{
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          },{
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          },{
-            name: '王小虎',
-            class: '六年级三班',
-            fraction:687,
-            school:'深圳市龙岗区X城外国语小学'
-          }]
+      timer:null,
+      chartObj1: null,
+      chartObj2: null,
+      chartObj3: null,
+      chartObj4: null,
+      chartObj5: null,
+      chartObj6: null,
+      loading: false,
+      tableData: [],
+      oid: "1123",
+      statics: {
+        sCount: 0,
+        wCount: 0,
+        cCount: 0,
+      },
+      courseJson: {
+        data: [],
+        sData: [],
+      },
+      CourseOption: {
+        xAxis: {
+          type: "category",
+          data: [],
+          axisLabel: {
+            interval: 0,
+            formatter: function (val) {
+              var strs = val.split(""); //字符串数组
+              var str = "";
+              for (var i = 0, s; (s = strs[i++]); ) {
+                //遍历字符串数组
+                str += s;
+                if (!(i % 2)) str += "\n";
+              }
+              return str;
+            },
+          },
+        },
+        tooltip: {
+          confine: true,
+          enterable: true, //鼠标是否可以移动到tooltip区域内
+          backgroundColor: "rgba(255,255,255,0.9)",
+          textStyle: {
+            // 文字样式
+            align: "left",
+          },
+          left: "right",
+          top: "bottom",
+        },
+        yAxis: {
+          type: "value",
+        },
+        series: [
+          {
+            data: [],
+            type: "bar",
+            showBackground: true,
+            backgroundStyle: {
+              color: "rgba(220, 220, 220, 0.8)",
+            },
+            itemStyle: {
+              color: "rgb(84,111,198)",
+            },
+          },
+        ],
+      },
+      titleJson: [],
+      titleOption: {
+        tooltip: {
+          trigger: "item",
+        },
+        legend: {
+          orient: "horizontal",
+          left: "center",
+          bottom: "5%",
+          icon: "circle",
+          itemGap: 18,
+          //   selectedMode: false,
+        },
+        series: [
+          {
+            name: "得奖占比",
+            type: "pie",
+            radius: "70%",
+            center: ["50%", "50%"],
+            data: [],
+            itemStyle: {
+              emphasis: {
+                shadowBlur: 10,
+                shadowOffsetX: 0,
+                shadowColor: "rgba(0, 0, 0, 0.5)",
+              },
+              normal: {
+                label: {
+                  show: true,
+                  formatter: "{d}%",
+                  inside: true,
+                  position: "inner",
+                },
+                labelLine: { show: false },
+              },
+            },
+          },
+        ],
+      },
+      studentJson: [],
+      homeJson: {
+        data: [],
+        sData: [],
+      },
+      homeOption: {
+        tooltip: {
+          trigger: "axis",
+          axisPointer: {
+            // type: "shadow",
+          },
+        },
+        grid: {
+          left: "1%",
+          bottom: "10%",
+          top: "15%",
+          containLabel: true,
+        },
+        xAxis: {
+          type: "value",
+          boundaryGap: [0, 1],
+          minInterval: 1,
+          position: "top",
+          axisLine: {
+            onZero: false,
+          },
+        },
+        yAxis: {
+          type: "category",
+          data: [],
+          inverse: true,
+          axisLabel: {
+            inside: true,
+            textStyle: {
+              color: "#fff",
+            },
+          },
+          axisTick: {
+            show: false,
+          },
+          axisLine: {
+            show: false,
+          },
+          z: 10,
+        },
+        dataZoom: [
+          {
+            type: "inside",
+            yAxisIndex: 0,
+            startValue: 0,
+            endValue: 5,
+            zoomLock: true,
+          },
+        ],
+        series: [
+          {
+            type: "bar",
+            data: [],
+            showBackground: true,
+            barWidth: "65%",
+            itemStyle: {
+              normal: {
+                barBorderRadius: [0, 5000, 5000, 0],
+                color: this.$echarts.graphic.LinearGradient(0, 0, 1, 0, [
+                  {
+                    offset: 0,
+                    color: "rgb(71,171,98)",
+                  },
+                  {
+                    offset: 1,
+                    color: "rgb(185,244,200)",
+                  },
+                ]),
+              },
+            },
+            label: {
+              show: true,
+              position: "right",
+              color: "#2e2e2e",
+            },
+          },
+        ],
+      },
+      fiveJson: {
+        data: [],
+        cData: [],
+        wData: [],
+      },
+      fiveOption: {
+        tooltip: {
+          trigger: "axis",
+          axisPointer: {
+            label: {
+              backgroundColor: "#6a7985",
+            },
+          },
+        },
+        xAxis: {
+          type: "category",
+          data: [],
+          boundaryGap: false,
+          axisLabel: {
+            interval: 0,
+            formatter: function (val) {
+              var strs = val.split(""); //字符串数组
+              var str = "";
+              for (var i = 0, s; (s = strs[i++]); ) {
+                //遍历字符串数组
+                str += s;
+                if (!(i % 2)) str += "\n";
+              }
+              return str;
+            },
+          },
+        },
+        yAxis: [
+          {
+            boundaryGap: [0, 0.5],
+            minInterval: 1,
+            type: "value",
+          },
+        ],
+        series: [
+          {
+            name: "课程数量",
+            type: "line",
+            data: [],
+          },
+          {
+            name: "作业数量",
+            type: "line",
+            data: [],
+          },
+        ],
+      },
+      hscJson: {
+        data: ["家", "校", "社"],
+        cData: [0, 0, 0],
+      },
+      hscOption: {
+        tooltip: {
+          trigger: "axis",
+        },
+        xAxis: {
+          type: "category",
+          boundaryGap: false,
+          data: ["家", "校", "社"],
+        },
+        grid: {
+          left: "1%",
+          bottom: "10%",
+          containLabel: true,
+        },
+        yAxis: {
+          boundaryGap: [0, 0.5],
+          minInterval: 1,
+          type: "value",
+        },
+        series: [
+          {
+            name: "课程数量",
+            data: [],
+            type: "line",
+            lineStyle: {
+              color: "rgb(56 174 0)",
+            },
+            itemStyle: {
+              color: "rgb(56 174 0)",
+            },
+            areaStyle: {
+              color: {
+                type: "linear",
+                x: 0,
+                y: 0,
+                x2: 0,
+                y2: 1,
+                colorStops: [
+                  {
+                    offset: 0,
+                    color: "rgb(56 174 0)", // 0% 处的颜色
+                  },
+                  {
+                    offset: 1,
+                    color: "white", // 100% 处的颜色
+                  },
+                ],
+                global: false, // 缺省为 false
+              },
+            },
+          },
+        ],
+      },
+      laoJson: [],
+      laoOption: {
+        tooltip: {
+          trigger: "item",
+        },
+        legend: {
+          orient: "horizontal",
+          left: "center",
+          bottom: "5%",
+          icon: "circle",
+          itemGap: 18,
+          //   selectedMode: false,
+        },
+        series: [
+          {
+            name: "课程占比",
+            type: "pie",
+            radius: "70%",
+            center: ["50%", "50%"],
+            data: [],
+            itemStyle: {
+              emphasis: {
+                shadowBlur: 10,
+                shadowOffsetX: 0,
+                shadowColor: "rgba(0, 0, 0, 0.5)",
+              },
+              normal: {
+                label: {
+                  show: true,
+                  formatter: "{d}%",
+                  inside: true,
+                  position: "inner",
+                },
+                labelLine: { show: false },
+              },
+            },
+          },
+        ],
+      },
     };
   },
+  methods: {
+    a(a) {
+      console.log(a);
+    },
+
+    init() {
+      this.courseJson = {
+        data: [],
+        sData: [],
+      };
+      this.titleJson = [];
+      this.studentJson = [];
+      this.homeJson = {
+        data: [],
+        sData: [],
+      };
+      this.fiveJson = {
+        data: [],
+        cData: [],
+        wData: [],
+      };
+      this.hscJson = {
+        data: ["家", "校", "社"],
+        cData: [0, 0, 0],
+      };
+      this.laoJson = [];
+    },
+    getDataStatic2() {
+      let params = { oid: this.oid };
+      this.ajax
+        .get(this.$store.state.api + "getDataAdmin", params)
+        .then((res) => {
+          this.statics.sCount = res.data[0][0].sCount; //学校人数
+          this.statics.wCount = res.data[1][0].wCount; //作业总数
+          this.statics.cCount = res.data[2][0].cCount; //课程总数
+          res.data[3].filter((item, index) => {
+            //劳动课程数量
+            this.courseJson.data.push(item.name);
+            this.courseJson.sData.push(item.number);
+          });
+          res.data[4].filter((item, index) => {
+            //劳动课程数量
+            this.titleJson.push({
+              value: item.tCount,
+              name:
+                item.title == "1"
+                  ? "星级义工"
+                  : item.title == "3"
+                  ? "劳动教育小讲师"
+                  : "少年科学院小院士",
+            });
+          });
+          this.tableData = res.data[5]; //学生积分排行榜
+          res.data[6].filter((item, index) => {
+            //义工社团情况
+            this.homeJson.data.push(item.workName);
+            this.homeJson.sData.push(item.hCount);
+          });
+
+          res.data[7].filter((item, index) => {
+            //五育融合
+            this.fiveJson.data.push(item.name);
+            this.fiveJson.cData.push(item.cCount);
+            this.fiveJson.wData.push(item.wCount);
+
+            //劳动素养
+            this.laoJson.push({
+              value: item.cCount,
+              name: item.name,
+            });
+          });
+
+          res.data[8].filter((item, index) => {
+            //家校社
+            if (item.type == "0") {
+              this.hscJson.cData[0] = item.tCount;
+            } else if (item.type == "1") {
+              this.hscJson.cData[1] = item.tCount;
+            } else if (item.type == "2") {
+              this.hscJson.cData[2] = item.tCount;
+            }
+          });
+          this.setChart2();
+        })
+        .catch((err) => {
+          console.error(err);
+        });
+    },
+    getDataStatic() {
+      this.loading = false;
+      let params = { oid: this.oid };
+      this.ajax
+        .get(this.$store.state.api + "getDataAdmin", params)
+        .then((res) => {
+          this.loading = true;
+
+          this.statics.sCount = res.data[0][0].sCount; //学校人数
+          this.statics.wCount = res.data[1][0].wCount; //作业总数
+          this.statics.cCount = res.data[2][0].cCount; //课程总数
+          res.data[3].filter((item, index) => {
+            //劳动课程数量
+            this.courseJson.data.push(item.name);
+            this.courseJson.sData.push(item.number);
+          });
+          res.data[4].filter((item, index) => {
+            //劳动课程数量
+            this.titleJson.push({
+              value: item.tCount,
+              name:
+                item.title == "1"
+                  ? "星级义工"
+                  : item.title == "3"
+                  ? "劳动教育小讲师"
+                  : "少年科学院小院士",
+            });
+          });
+          this.tableData = res.data[5]; //学生积分排行榜
+          res.data[6].filter((item, index) => {
+            //义工社团情况
+            this.homeJson.data.push(item.workName);
+            this.homeJson.sData.push(item.hCount);
+          });
+
+          res.data[7].filter((item, index) => {
+            //五育融合
+            this.fiveJson.data.push(item.name);
+            this.fiveJson.cData.push(item.cCount);
+            this.fiveJson.wData.push(item.wCount);
+
+            //劳动素养
+            this.laoJson.push({
+              value: item.cCount,
+              name: item.name,
+            });
+          });
+
+          res.data[8].filter((item, index) => {
+            //家校社
+            if (item.type == "0") {
+              this.hscJson.cData[0] = item.tCount;
+            } else if (item.type == "1") {
+              this.hscJson.cData[1] = item.tCount;
+            } else if (item.type == "2") {
+              this.hscJson.cData[2] = item.tCount;
+            }
+          });
+          this.setChart();
+        })
+        .catch((err) => {
+          console.error(err);
+        });
+    },
+    setChart() {
+      // 雷达图显示的标签
+      let newPromise = new Promise((resolve) => {
+        resolve();
+      });
+      //然后异步执行echarts的初始化函数
+      newPromise.then(() => {
+        const chartObj1 = this.$echarts.init(
+          //劳动课程
+          this.$el.querySelector("#course_canvas")
+        );
+        this.CourseOption.xAxis.data = this.courseJson.data;
+        this.CourseOption.series[0].data = this.courseJson.sData;
+
+        const chartObj2 = this.$echarts.init(
+          //得奖占比
+          this.$el.querySelector("#title_canvas")
+        );
+        this.titleOption.series[0].data = this.titleJson;
 
+        const chartObj3 = this.$echarts.init(
+          //义工社团情况
+          this.$el.querySelector("#home_canvas")
+        );
+        this.homeOption.yAxis.data = this.homeJson.data;
+        this.homeOption.series[0].data = this.homeJson.sData;
+
+        const chartObj4 = this.$echarts.init(
+          //五育融合
+          this.$el.querySelector("#five_canvas")
+        );
+        this.fiveOption.xAxis.data = this.fiveJson.data;
+        this.fiveOption.series[0].data = this.fiveJson.cData;
+        this.fiveOption.series[1].data = this.fiveJson.wData;
+
+        const chartObj5 = this.$echarts.init(
+          //家校社
+          this.$el.querySelector("#hsc_canvas")
+        );
+        this.hscOption.series[0].data = this.hscJson.cData;
+
+        const chartObj6 = this.$echarts.init(
+          //得奖占比
+          this.$el.querySelector("#lao_canvas")
+        );
+        this.laoOption.series[0].data = this.laoJson;
+
+        // 初始化雷达图
+        this.chartObj1 = chartObj1;
+        this.chartObj1.setOption(this.CourseOption);
+        this.chartObj2 = chartObj2;
+        this.chartObj2.setOption(this.titleOption);
+        this.chartObj3 = chartObj3;
+        this.chartObj3.setOption(this.homeOption);
+        this.chartObj4 = chartObj4;
+        this.chartObj4.setOption(this.fiveOption);
+        this.chartObj5 = chartObj5;
+        this.chartObj5.setOption(this.hscOption);
+        this.chartObj6 = chartObj6;
+        this.chartObj6.setOption(this.laoOption);
+        console.log(this.chartObj1);
+      });
+    },
+    setChart2() {
+      this.CourseOption.xAxis.data = this.courseJson.data;
+      this.CourseOption.series[0].data = this.courseJson.sData;
+      this.titleOption.series[0].data = this.titleJson;
+      this.homeOption.yAxis.data = this.homeJson.data;
+      this.homeOption.series[0].data = this.homeJson.sData;
+      this.fiveOption.xAxis.data = this.fiveJson.data;
+      this.fiveOption.series[0].data = this.fiveJson.cData;
+      this.fiveOption.series[1].data = this.fiveJson.wData;
+      this.hscOption.series[0].data = this.hscJson.cData;
+      this.laoOption.series[0].data = this.laoJson;
+
+      this.chartObj1.setOption(this.CourseOption);
+      this.chartObj2.setOption(this.titleOption);
+      this.chartObj3.setOption(this.homeOption);
+      this.chartObj4.setOption(this.fiveOption);
+      this.chartObj5.setOption(this.hscOption);
+      this.chartObj6.setOption(this.laoOption);
+      // console.log(this.chartObj1);
+    },
+  },
+  destroyed() {
+    this.timer = null
+    clearInterval(this.timer)
+  },
+  created() {
+    this.getDataStatic();
+    this.timer = setInterval(() => {
+      this.init();
+      this.getDataStatic2();
+    }, 5000);
+    var _this = this;
+    window.onresize = function () {
+      //   this.$echarts.resize();
+      _this.chartObj1.resize();
+      _this.chartObj2.resize();
+      _this.chartObj3.resize();
+      _this.chartObj4.resize();
+      _this.chartObj5.resize();
+      _this.chartObj6.resize();
+    };
+  },
 };
 </script>
 
 <style scoped>
-#statistics{
-    width: 100%;
-    height: 150px;
-    display: flex;
-    justify-content:flex-start;
-    margin-top:20px ;
-}
-.count{
-    position: relative;
-    height: 100%;
-    width: 400px;
-    border-radius: 15px;
-}
-.count:nth-child(1){
-    background-image: url('../../assets/dataimage/studentMessage.png');
-}
-.count:nth-child(2){
-    background-image: url('../../assets/dataimage/labourMessage.png');
-}
-.count:nth-child(3){
-    background-image: url('../../assets/dataimage/curriculumMessage.png');
-}
-.count:nth-child(n+2){
-    margin-left: 25px;
-}
-.count>h4>div{
-    float: left;
-    width: 4px;
-    height: 20px;
-    margin-right:8px ;
-    background: white;
-}
-.count>h4{
-    top: 20px;
-    left: 40px;
-    position: absolute;
-    color: white;
-    font-weight:300 ;
-    font-size:.89em ;
-}
-.count>div{
-    position: absolute;
-    top: 45px;
-    left: 40px;
-}
-.count>div>span{
-    color: white;
-    font-size:4em ;
-    margin-right: 5px;
-}
-.count>div>img{
-    position: relative;
-    bottom: -5px;
-}
-#graphicalArea{
-    width: 100%;
-    position: relative;
-    display: flex;
-    justify-content: flex-start;
-    flex-direction: row;
-    flex-wrap: wrap;
-}
-.graphical{
-    position: relative;
-    box-sizing: border-box;
-    width: 45%;
-    height: 450px;
-    margin-top:20px ;
-    /* border-radius: 10px; */
-    background: #f1f2f6;
-}
-.graphical:nth-child(2n){
-    margin-left:20px ;
-}
-.graphical>span{
-    position:absolute;
-    font-size:1.1em ;
-    font-weight:500 ;
-    top: 15px;
-    left: 10px;
-    color: #636e72;
-}
-.graphical>div{
-    width: 100%;
-    height: 100%;
-    display: flex;
-    justify-content: center;
-    align-items: center;
-}
-main{
-    overflow-y:hidden ;
+#statistics {
+  width: 100%;
+  height: 150px;
+  display: flex;
+  justify-content: flex-start;
+  margin-top: 20px;
+}
+.count {
+  position: relative;
+  height: 100%;
+  width: 400px;
+  border-radius: 15px;
+}
+.count:nth-child(1) {
+  background-image: url("../../assets/dataimage/studentMessage.png");
+}
+.count:nth-child(2) {
+  background-image: url("../../assets/dataimage/labourMessage.png");
+}
+.count:nth-child(3) {
+  background-image: url("../../assets/dataimage/curriculumMessage.png");
+}
+.count:nth-child(n + 2) {
+  margin-left: 25px;
+}
+.count > h4 > div {
+  float: left;
+  width: 4px;
+  height: 20px;
+  margin-right: 8px;
+  background: white;
+}
+.count > h4 {
+  top: 20px;
+  left: 40px;
+  position: absolute;
+  color: white;
+  font-weight: 300;
+  font-size: 0.89em;
+}
+.count > div {
+  position: absolute;
+  top: 45px;
+  left: 25px;
+}
+.count > div > span {
+  color: white;
+  font-size: 4em;
+  margin-right: 5px;
+}
+.count > div > img {
+  position: relative;
+  bottom: -5px;
+}
+#graphicalArea {
+  width: 100%;
+  position: relative;
+  display: flex;
+  justify-content: flex-start;
+  flex-direction: row;
+  flex-wrap: wrap;
+}
+.graphical {
+  position: relative;
+  box-sizing: border-box;
+  width: 45%;
+  height: 450px;
+  margin-top: 20px;
+  /* border-radius: 10px; */
+  background: #f1f2f6;
+}
+.graphical:nth-child(2n) {
+  margin-left: 20px;
+}
+.graphical > span {
+  position: absolute;
+  font-size: 1.1em;
+  font-weight: 500;
+  top: 15px;
+  left: 10px;
+  color: #636e72;
+}
+.graphical > div {
+  width: 100%;
+  height: 100%;
+  display: flex;
+  justify-content: center;
+  align-items: center;
+}
+main {
+  overflow-y: hidden;
 }
 </style>

+ 148 - 49
src/components/pages/score.vue

@@ -3,13 +3,18 @@
     <el-main>
       <div class="tou">积分兑换</div>
       <div>
+        <el-button
+          size="small"
+          type="primary"
+          style="position: absolute; right: 110px; top: 90px"
+          @click="scoreDialog = true"
+        >积分设置</el-button>
         <el-button
           size="small"
           type="primary"
           style="position: absolute; right: 20px; top: 90px"
           @click="goTo('/scoreProduct')"
-          >礼品列表</el-button
-        >
+        >礼品列表</el-button>
         <!-- <div>Banner管理</div>      -->
         <el-table
           ref="table"
@@ -22,31 +27,30 @@
           :height="tableHeight"
           v-loading="isLoading"
         >
-          <el-table-column prop="name" label="姓名" min-width="15">
-          </el-table-column>
-          <el-table-column prop="classname" label="班级" min-width="15">
-          </el-table-column>
-          <el-table-column prop="spname" label="兑换礼品" min-width="15">
-          </el-table-column>
+          <el-table-column prop="name" label="姓名" min-width="15"></el-table-column>
+          <el-table-column prop="classname" label="班级" min-width="15"></el-table-column>
+          <el-table-column prop="spname" label="兑换礼品" min-width="15"></el-table-column>
           <el-table-column label="兑换码" min-width="15">
-            <template slot-scope="scope">
-              {{ scope.row.number ? scope.row.number : "暂无" }}
-            </template>
+            <template slot-scope="scope">{{ scope.row.number ? scope.row.number : "暂无" }}</template>
           </el-table-column>
           <el-table-column label="是否审核" min-width="15">
             <template slot-scope="scope">
+              <!-- {{
+              scope.row.type == 0
+              ? "未审核"
+              : scope.row.type == 1
+              ? "已通过"
+              : scope.row.type == 3 ? '已兑换'
+              : "已拒绝"
+              }}-->
               {{
-                scope.row.type == 0
-                  ? "未审核"
-                  : scope.row.type == 1
-                  ? "已通过"
-                  : scope.row.type == 3 ? '已兑换'
-                  : "已拒绝"
+              scope.row.type == 0
+              ? "未审核"
+              : "已通过"
               }}
             </template>
           </el-table-column>
-          <el-table-column prop="time" label="创建时间" width="180px">
-          </el-table-column>
+          <el-table-column prop="time" label="创建时间" width="180px"></el-table-column>
           <el-table-column prop="do" label="操作" width="180px">
             <template slot-scope="scope">
               <div class="pb_buttonBox" style="justify-content: flex-start;">
@@ -54,14 +58,20 @@
                   size="mini"
                   type="primary"
                   @click="shen(scope.row)"
-                  >{{scope.row.type != 0 ? '已审核' : '审核'}}</el-button
-                >
-                <el-button type="primary" size="mini" v-if="scope.row.type == 1" @click="isCan(scope.row.id)">
-                    兑换确认
-                </el-button>
-                <el-button type="primary" size="mini" v-if="scope.row.type == 3" :disabled="true" @click="isCan(scope.row.id)">
-                    已确认
-                </el-button>
+                >{{scope.row.type != 0 ? '已审核' : '审核'}}</el-button>
+                <!-- <el-button
+                  type="primary"
+                  size="mini"
+                  v-if="scope.row.type == 1"
+                  @click="isCan(scope.row.id)"
+                >兑换确认</el-button>-->
+                <!-- <el-button
+                  type="primary"
+                  size="mini"
+                  v-if="scope.row.type == 3"
+                  :disabled="true"
+                  @click="isCan(scope.row.id)"
+                >已确认</el-button>-->
               </div>
             </template>
           </el-table-column>
@@ -74,8 +84,7 @@
           :page-size="10"
           :total="total"
           @current-change="handleCurrentChange"
-        >
-        </el-pagination>
+        ></el-pagination>
       </div>
     </el-main>
     <el-dialog
@@ -112,11 +121,45 @@
         </div>
       </div>
       <div slot="footer">
-        <el-button @click="reject" v-if="res.type == 0">拒 绝</el-button>
+        <!-- <el-button @click="reject" v-if="res.type == 0">拒 绝</el-button> -->
         <el-button type="primary" @click="confirm" v-if="res.type == 0">通 过</el-button>
         <el-button @click="handleClose" v-if="res.type != 0">关闭</el-button>
       </div>
     </el-dialog>
+    <el-dialog
+      title="积分设置"
+      :visible.sync="scoreDialog"
+      width="600px"
+      :before-close="handleClose"
+      class="dialog_diy"
+    >
+      <div class="spBox">
+        <el-table
+          :data="settingData"
+          style="width: 100%"
+          stripe
+          border
+          :header-cell-style="{ background: '#f1f1f1', 'text-align': 'center' }"
+          :cell-style="{ 'text-align': 'center' }"
+        >
+          <el-table-column prop="name" label="积分规则" min-width="80"></el-table-column>
+          <el-table-column prop="score" label="获取积分" min-width="20">
+            <template slot-scope="scope">
+              <div>
+                <el-input
+                  placeholder="请输入积分"
+                  v-model="scope.row.score"
+                  @change="updateScore(scope.row.score,scope.row.id)"
+                ></el-input>
+              </div>
+            </template>
+          </el-table-column>
+        </el-table>
+      </div>
+      <div slot="footer">
+        <el-button @click="scoreDialog = false">关闭</el-button>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -125,12 +168,14 @@ export default {
   data() {
     return {
       dialogVisible: false,
+      scoreDialog: false,
       tableData: [],
       isLoading: false,
       total: 0,
       page: 1,
       tableHeight: 500,
       res: {},
+      settingData: [],
     };
   },
   methods: {
@@ -186,7 +231,7 @@ export default {
     },
     getData() {
       this.isLoading = true;
-      let params = { page: this.page,oid:this.$store.state.userInfo.organizeid };
+      let params = { page: this.page };
       this.ajax
         .get(this.$store.state.api + "getScoreHistory", params)
         .then((res) => {
@@ -203,8 +248,8 @@ export default {
       this.res = res;
       this.dialogVisible = true;
     },
-    isCan(res){
-         var _this = this;
+    isCan(res) {
+      var _this = this;
       _this
         .$confirm("此礼品确定是否被学生兑换了吗?", "提示", {
           confirmButtonText: "是",
@@ -217,14 +262,14 @@ export default {
               aid: res,
             },
           ];
-          this.ajax
-            .post(this.$store.state.api + "updateScoreCan", params)
+          _this.ajax
+            .post(_this.$store.state.api + "updateScoreCan", params)
             .then((res) => {
-              this.$message.success("修改成功");
-              this.getData();
+              _this.$message.success("通过成功");
+              _this.getData();
             })
             .catch((err) => {
-              this.$message.error("修改失败");
+              _this.$message.error("通过失败");
               console.error(err);
             });
         })
@@ -241,28 +286,28 @@ export default {
         .then(() => {
           let params = [
             {
-              aid: this.res.id,
-              uid: this.res.userid,
+              aid: _this.res.id,
+              uid: _this.res.userid,
               anum: null,
               t: "2",
-              nc: `您兑换的“<span style="color: orange">${this.res.spname}</span>”礼品,已拒绝审核, 请联系线下管理员了解情况。`,
+              nc: `您兑换的“<span style="color: orange">${_this.res.spname}</span>”礼品,已拒绝审核, 请联系线下管理员了解情况。`,
             },
           ];
-          this.ajax
-            .post(this.$store.state.api + "updateScoreHistory", params)
+          _this.ajax
+            .post(_this.$store.state.api + "updateScoreHistory", params)
             .then((res) => {
               console.log(res);
               if (res.data[0][0].success == "1") {
-                this.$message.success("拒绝成功");
-                this.init();
+                _this.$message.success("拒绝成功");
+                _this.init();
               } else if (res.data[0][0].success == "5") {
-                this.$message.error(
+                _this.$message.error(
                   "通过失败,此礼品已经审核过了,请刷新后重试"
                 );
               } else if (res.data[0][0].success == "2") {
-                this.$message.error("通过失败,此礼品不存在");
+                _this.$message.error("通过失败,此礼品不存在");
               }
-              this.getData();
+              _this.getData();
             })
             .catch((err) => {
               console.error(err);
@@ -284,7 +329,7 @@ export default {
           anum: _number,
           t: "1",
           nc: `您兑换的“<span style="color: orange">${this.res.spname}</span>”礼品,已通过审核, 请联系线下管理员,将姓名与班级或兑换码报给管理员,进行兑换。兑换编码:<span style="color: orange">${_number}</span>`,
-          c:"兑换" + this.res.spname
+          c: "兑换" + this.res.spname,
         },
       ];
       this.ajax
@@ -309,11 +354,65 @@ export default {
           console.error(err);
         });
     },
+    getScoreSetting() {
+      let params = {
+        oid: "1123",
+      };
+      this.ajax
+        .get(this.$store.state.api + "getScoreSettingAdmin", params)
+        .then((res) => {
+          this.settingData = res.data[0];
+        })
+        .catch((err) => {
+          // this.$message.error("修改失败");
+          console.error(err);
+        });
+    },
+    myIsNaN(val) {
+      // isNaN()函数 把空串 空格 以及NUll 按照0来处理 所以先去除,
+      if (val === "" || val == null) {
+        return false;
+      }
+      if (!isNaN(val)) {
+        //对于空数组和只有一个数值成员的数组或全是数字组成的字符串,isNaN返回false,例如:'123'、[]、[2]、['123'],isNaN返回false,
+        //所以如果不需要val包含这些特殊情况,则这个判断改写为if(!isNaN(val) && typeof val === 'number' )
+        return true;
+      } else {
+        return false;
+      }
+    },
+    updateScore(score, id) {
+      if (!this.myIsNaN(score)) {
+        this.$message.error("请输入数字");
+        return;
+      } else if (score == "") {
+        this.$message.error("不能为空");
+        return;
+      }
+
+      let params = [
+        {
+          score: score,
+          id: id,
+        },
+      ];
+      this.ajax
+        .post(this.$store.state.api + "UpdateScoreSetting", params)
+        .then((res) => {
+          this.$message.success("修改成功");
+          this.getScoreSetting();
+        })
+        .catch((err) => {
+          this.$message.error("修改失败");
+          console.error(err);
+        });
+    },
   },
   created() {
     this.$nextTick(function () {
       this.changeHeight();
       this.getData();
+      this.getScoreSetting();
     });
   },
 };

+ 2 - 0
src/main.js

@@ -11,6 +11,7 @@ import './common/player.css'
 import VideoPlayer from 'vue-video-player'
 import 'video.js/dist/video-js.css' //videoJs的样式
 import 'vue-video-player/src/custom-theme.css' //vue-video-player的样式
+const echarts = require('echarts');
 Vue.use(VueCookies).use(VideoPlayer)
 
 Vue.prototype.$loading = Loading
@@ -18,6 +19,7 @@ Vue.prototype.$store = store;// 将store实例挂在vue原型上
 Vue.prototype.ajax = ajax
 Vue.prototype.$message = Message
 Vue.config.productionTip = false
+Vue.prototype.$echarts = echarts
 
 /* eslint-disable no-new */
 new Vue({