11wqe1 7 months ago
parent
commit
0e64628981

+ 29 - 30
src/components/pages/components/report.vue

@@ -302,16 +302,16 @@ export default {
                     _workjson.bgInfo.push(element.content);
                   }
                 }
-                for (let d = 0; d < cocopiInfo.length; d++) {
-                  if (
-                    cocopiInfo[d].stage == chapI &&
-                    cocopiInfo[d].task == _tI[1] &&
-                    cocopiInfo[d].userid == _uname[i].userid
-                  ) {
-                    const element = cocopiInfo[d];
-                    _workjson.cocopiInfo.push(element.content);
-                  }
-                }
+                // for (let d = 0; d < cocopiInfo.length; d++) {
+                //   if (
+                //     cocopiInfo[d].stage == chapI &&
+                //     cocopiInfo[d].task == _tI[1] &&
+                //     cocopiInfo[d].userid == _uname[i].userid
+                //   ) {
+                //     const element = cocopiInfo[d];
+                //     _workjson.cocopiInfo.push(element.content);
+                //   }
+                // }
                 for (let d = 0; d < wordInfo.length; d++) {
                   if (
                     wordInfo[d].stage == chapI &&
@@ -456,16 +456,16 @@ export default {
                     _workjson.bgInfo.push(element.content);
                   }
                 }
-                for (let d = 0; d < cocopiInfo.length; d++) {
-                  if (
-                    cocopiInfo[d].stage == chapI &&
-                    cocopiInfo[d].task == _tI[1] &&
-                    cocopiInfo[d].userid == _uname[i].userid
-                  ) {
-                    const element = cocopiInfo[d];
-                    _workjson.cocopiInfo.push(element.content);
-                  }
-                }
+                // for (let d = 0; d < cocopiInfo.length; d++) {
+                //   if (
+                //     cocopiInfo[d].stage == chapI &&
+                //     cocopiInfo[d].task == _tI[1] &&
+                //     cocopiInfo[d].userid == _uname[i].userid
+                //   ) {
+                //     const element = cocopiInfo[d];
+                //     _workjson.cocopiInfo.push(element.content);
+                //   }
+                // }
                 for (let d = 0; d < wordInfo.length; d++) {
                   if (
                     wordInfo[d].stage == chapI &&
@@ -573,7 +573,7 @@ export default {
 
             chooseData.testJson.testJson.forEach((e,eIndex)=>{
                 var _div2 = document.createElement("div");
-                _div2.innerHTML = `<h5>第${eIndex + 1}题:${
+                _div2.innerHTML = `<h5>第${eIndex}题:${
                     e.teststitle
                 }  选择:${
                   chooseData.anwer[eIndex].length > 1? chooseData.anwer[eIndex].join(',') : chooseData.anwer[eIndex]
@@ -650,15 +650,15 @@ export default {
         }
       }
       
-      var _cocopi = "";
+      // var _cocopi = "";
 
-      if (workJson.cocopiInfo.length > 0) {
+      // if (workJson.cocopiInfo.length > 0) {
 
-        var _cocopi = "<h4>cocopi<h3>";
-        for (var i = 0; i < workJson.cocopiInfo.length; i++) {
-          _cocopi += `<h6>不支持查看</h6>`;
-        }
-      }
+      //   var _cocopi = "<h4>cocopi<h3>";
+      //   for (var i = 0; i < workJson.cocopiInfo.length; i++) {
+      //     _cocopi += `<h6>不支持查看</h6>`;
+      //   }
+      // }
 
       var _word = "";
       if (workJson.wordInfo.length > 0) {
@@ -683,7 +683,6 @@ export default {
         !workJson.pjInfo.length &&
         !workJson.xztkInfo.length &&
         !workJson.chooseInfo.length &&
-        !workJson.cocopiInfo.length &&
         !workJson.bgInfo.length 
 
 
@@ -692,7 +691,7 @@ export default {
         return "";
       }
       
-      return _title + _subtitle + _img + _ask + _pjInfo + _answer + _xztkInfo + _link + _choose + _lccjInfo + _bg + _cocopi + _word;
+      return _title + _subtitle + _img + _ask + _pjInfo + _answer + _xztkInfo + _link + _choose + _lccjInfo + _bg  + _word;
     },
     async generate(a) {
       // 将html文件中需要用到的数据挂载到store上

+ 122 - 92
src/components/pages/components/studentWorksDetail.vue

@@ -1411,13 +1411,31 @@
                             v-for="(item, index) in worksDetail[sIndex].eList"
                             :key="index"
                           >
+                          <el-tooltip
+                              class="item"
+                              effect="dark"
+                              v-if="worksDetail[sIndex].state == 5"
+                              :content="item.detail"
+                              placement="top-start"
+                            >
+                              <div class="RootImgBlock">
+                                <img
+                                  v-if="item.isai == 1"
+                                  class="RootImg"
+                                  src="../../../assets/icon/conSentences/Brootper.svg"
+                                  alt=""
+                                />
+                                {{ item.detail }}
+                              </div>
+                            </el-tooltip>
                             <el-tooltip
                               class="item"
                               effect="dark"
+                              v-else
                               :content="item.value"
                               placement="top-start"
                             >
-                            <div class="RootImgBlock">
+                              <div class="RootImgBlock">
                                 <img
                                   v-if="item.isai == 1"
                                   class="RootImg"
@@ -1430,7 +1448,7 @@
                             <el-rate
                               class="rate_size"
                               style="min-width: 120px"
-                              v-model="worksDetail[sIndex].rateList[item.value]"
+                              v-model="worksDetail[sIndex].rateList[item.detail]"
                               @change="getStar(sIndex)"
                             ></el-rate>
                           </div>
@@ -1453,7 +1471,8 @@
                               .eList"
                             :key="tarIndex"
                           >
-                            <span v-if="item.target"> {{ item.target }}</span>
+                          <span v-if="worksDetail[sIndex].state == 5"> {{ item.target }}</span>
+                          <span v-else> {{ item.target[item.target.length-1] }}</span>
                           </div>
                         </div>
                       </div>
@@ -1859,13 +1878,16 @@ export default {
       return function(val) {
         let sco = 0;
         let num = 0;
-
+        
         for (const key in val) {
-          if (val[key] || key != 'content') {
+          if (val[key] && key != 'content') {
             sco += val[key] * 1;
           }
           num += 1;
         }
+        
+        if(sco == 0) return '0.0'
+        
         return (sco / (num - 1)).toFixed(1);
       };
     },
@@ -2068,6 +2090,7 @@ export default {
                 wordInfo: [],
                 scopeId: res.data[0][k].id,
                 stagetask: stagetask,
+                state: res.data[0][k].state,
                 time: "",
               };
               checkJson[stagetask] = {
@@ -2547,7 +2570,7 @@ export default {
                 result[l].eList = eList;
                 for (var i = 0; i < eList.length; i++) {
                   _ooption.push({ value: 0, name: eList[i].value });
-                  result[l].rateList[eList[i].value] = 0;
+                  result[l].rateList[eList[i].detail] = 0;
                 }
                 result[l].rateList.content = "";
                 this.ooption[l] = _ooption;
@@ -2600,7 +2623,7 @@ export default {
                       result[l].eList = eList;
                       for (var i = 0; i < eList.length; i++) {
                         _ooption.push({ value: 0, name: eList[i].value });
-                        result[l].rateList[eList[i].value] = 0;
+                        result[l].rateList[eList[i].detail] = 0;
                       }
                       result[l].rateList.content = "";
                       this.ooption[l] = _ooption;
@@ -2744,91 +2767,91 @@ export default {
             wordInfo: []
           };
           var eList = [];
-          if (workEvaList.length > 0) {
-            for (var qi = 0; qi < workEvaList.length; qi++) {
-              var eListOld =
-                chapters[workEvaList[qi].stage].chapterInfo[0].taskJson[
-                  workEvaList[qi].task
-                ].eList;
-              var _ooption = [];
-              if (eListOld && eListOld.length) {
-                var eListNew = Object.keys(eListOld).map(function(key) {
-                  return {
-                    detail: eListOld[key].detail,
-                    score: eListOld[key].score,
-                    value: eListOld[key].value
-                  };
-                });
-                eList = eListNew;
-                if (eList && eList.length) {
-                  workJson.eList = eList;
-                  for (var i = 0; i < eList.length; i++) {
-                    _ooption.push({ value: 0, name: eList[i].value });
-                    workJson.rateList[eList[i].value] = 0;
-                  }
-                  workJson.rateList.content = "";
-                  this.ooption = _ooption;
-                } else {
-                  workJson.eList = [
-                    { value: "意识能力", detail: "", score: 5 },
-                    { value: "科学探究能力", detail: "", score: 5 },
-                    { value: "实践创新能力", detail: "", score: 5 },
-                    { value: "学习反思能力", detail: "", score: 5 },
-                    { value: "工程思维能力", detail: "", score: 5 }
-                  ];
-                  for (var i = 0; i < workJson.eList.length; i++) {
-                    _ooption.push({ value: 0, name: workJson.eList[i].value });
-                    workJson.rateList[workJson.eList[i].value] = 0;
-                  }
-                  workJson.rateList.content = "";
-                  this.ooption = [
-                    { value: 0, name: "意识能力" },
-                    { value: 0, name: "科学探究能力" },
-                    { value: 0, name: "实践创新能力" },
-                    { value: 0, name: "学习反思能力" },
-                    { value: 0, name: "工程思维能力" }
-                  ];
-                }
-              }
-            }
-          }
-          var _rate = [],
-            _rateList = [];
-          if (workEvaList.length > 0) {
-            for (var p = 0; p < workEvaList.length; p++) {
-              if (workEvaList[p].rate && eList && eList.length) {
-                _rate[p] = JSON.parse(workEvaList[p].rate);
-              }
-              _rateList[p] = Object.keys(JSON.parse(workEvaList[p].rate));
-              for (var i = 0; i < _rateList[p].length; i++) {
-                var _c = Object.keys(workJson.rateList);
-                if (_c.indexOf(_rateList[p][i]) != -1) {
-                  workJson.rateList[_rateList[i]] = _rate[_rateList[i]];
-                }
-              }
-              for (var i = 0; i < this.ooption[p].length; i++) {
-                if (_rateList[p].indexOf(this.ooption[p][i].name) != -1) {
-                  this.ooption[p][i].value = _rate[p][this.ooption[p][i].name];
-                }
-              }
-            }
-          } else {
-            if (this.sInfo.rate) {
-              _rate = JSON.parse(this.sInfo.rate);
-              _rateList = Object.keys(JSON.parse(this.sInfo.rate));
-              for (var i = 0; i < _rateList.length; i++) {
-                var _c = Object.keys(workJson.rateList);
-                if (_c.indexOf(_rateList[i]) != -1) {
-                  workJson.rateList[_rateList[i]] = _rate[_rateList[i]];
-                }
-              }
-              for (var i = 0; i < this.ooption.length; i++) {
-                if (_rateList.indexOf(this.ooption[i].name) != -1) {
-                  this.ooption[i].value = _rate[this.ooption[i].name];
-                }
-              }
-            }
-          }
+          // if (workEvaList.length > 0) {
+          //   for (var qi = 0; qi < workEvaList.length; qi++) {
+          //     var eListOld =
+          //       chapters[workEvaList[qi].stage].chapterInfo[0].taskJson[
+          //         workEvaList[qi].task
+          //       ].eList;
+          //     var _ooption = [];
+          //     if (eListOld && eListOld.length) {
+          //       var eListNew = Object.keys(eListOld).map(function(key) {
+          //         return {
+          //           detail: eListOld[key].detail,
+          //           score: eListOld[key].score,
+          //           value: eListOld[key].value
+          //         };
+          //       });
+          //       eList = eListNew;
+          //       if (eList && eList.length) {
+          //         workJson.eList = eList;
+          //         for (var i = 0; i < eList.length; i++) {
+          //           _ooption.push({ value: 0, name: eList[i].value });
+          //           workJson.rateList[eList[i].value] = 0;
+          //         }
+          //         workJson.rateList.content = "";
+          //         this.ooption = _ooption;
+          //       } else {
+          //         workJson.eList = [
+          //           { value: "意识能力", detail: "", score: 5 },
+          //           { value: "科学探究能力", detail: "", score: 5 },
+          //           { value: "实践创新能力", detail: "", score: 5 },
+          //           { value: "学习反思能力", detail: "", score: 5 },
+          //           { value: "工程思维能力", detail: "", score: 5 }
+          //         ];
+          //         for (var i = 0; i < workJson.eList.length; i++) {
+          //           _ooption.push({ value: 0, name: workJson.eList[i].value });
+          //           workJson.rateList[workJson.eList[i].value] = 0;
+          //         }
+          //         workJson.rateList.content = "";
+          //         this.ooption = [
+          //           { value: 0, name: "意识能力" },
+          //           { value: 0, name: "科学探究能力" },
+          //           { value: 0, name: "实践创新能力" },
+          //           { value: 0, name: "学习反思能力" },
+          //           { value: 0, name: "工程思维能力" }
+          //         ];
+          //       }
+          //     }
+          //   }
+          // }
+          // var _rate = [],
+          //   _rateList = [];
+          // if (workEvaList.length > 0) {
+          //   for (var p = 0; p < workEvaList.length; p++) {
+          //     if (workEvaList[p].rate && eList && eList.length) {
+          //       _rate[p] = JSON.parse(workEvaList[p].rate);
+          //     }
+          //     _rateList[p] = Object.keys(JSON.parse(workEvaList[p].rate));
+          //     for (var i = 0; i < _rateList[p].length; i++) {
+          //       var _c = Object.keys(workJson.rateList);
+          //       if (_c.indexOf(_rateList[p][i]) != -1) {
+          //         workJson.rateList[_rateList[i]] = _rate[_rateList[i]];
+          //       }
+          //     }
+          //     for (var i = 0; i < this.ooption[p].length; i++) {
+          //       if (_rateList[p].indexOf(this.ooption[p][i].name) != -1) {
+          //         this.ooption[p][i].value = _rate[p][this.ooption[p][i].name];
+          //       }
+          //     }
+          //   }
+          // } else {
+          //   if (this.sInfo.rate) {
+          //     _rate = JSON.parse(this.sInfo.rate);
+          //     _rateList = Object.keys(JSON.parse(this.sInfo.rate));
+          //     for (var i = 0; i < _rateList.length; i++) {
+          //       var _c = Object.keys(workJson.rateList);
+          //       if (_c.indexOf(_rateList[i]) != -1) {
+          //         workJson.rateList[_rateList[i]] = _rate[_rateList[i]];
+          //       }
+          //     }
+          //     for (var i = 0; i < this.ooption.length; i++) {
+          //       if (_rateList.indexOf(this.ooption[i].name) != -1) {
+          //         this.ooption[i].value = _rate[this.ooption[i].name];
+          //       }
+          //     }
+          //   }
+          // }
 
           for (var i = 0; i < worksDetail.length; i++) {
             workJson.img.push({
@@ -3568,7 +3591,14 @@ export default {
         if (element) {
           element.scrollIntoView({
             behavior: 'smooth'
+          },()=>{
+            let scrollBody = document.querySelector(".zyBoxC").parentElement
+            scrollBody.scrollTop = scrollBody.scrollTop - 30
           });
+          setTimeout(() => {
+            let scrollBody = document.querySelector(".zyBoxC").parentElement
+            scrollBody.scrollTop = scrollBody.scrollTop - 70
+          }, 500);
         }
         var a = s + "-" + i;
         // var b = document.getElementById(a);

File diff suppressed because it is too large
+ 1035 - 263
src/components/pages/components/worksDetail2.vue


+ 41 - 5
src/components/pages/components/worksDetail3.vue

@@ -1060,18 +1060,44 @@
                             v-for="(item, index) in worksDetail[sIndex].eList"
                             :key="index"
                           >
+                          <el-tooltip
+                              class="item"
+                              effect="dark"
+                              v-if="worksDetail[sIndex].state == 5"
+                              :content="item.detail"
+                              placement="top-start"
+                            >
+                              <div class="RootImgBlock">
+                                <img
+                                  v-if="item.isai == 1"
+                                  class="RootImg"
+                                  src="../../../assets/icon/conSentences/Brootper.svg"
+                                  alt=""
+                                />
+                                {{ item.detail }}
+                              </div>
+                            </el-tooltip>
                             <el-tooltip
                               class="item"
                               effect="dark"
+                              v-else
                               :content="item.value"
                               placement="top-start"
                             >
-                              <span>{{ item.value }}</span>
+                              <div class="RootImgBlock">
+                                <img
+                                  v-if="item.isai == 1"
+                                  class="RootImg"
+                                  src="../../../assets/icon/conSentences/Brootper.svg"
+                                  alt=""
+                                />
+                                {{ item.value }}
+                              </div>
                             </el-tooltip>
                             <el-rate
                               class="rate_size"
                               style="min-width: 120px"
-                              v-model="worksDetail[sIndex].rateList[item.value]"
+                              v-model="worksDetail[sIndex].rateList[item.detail]"
                               @change="getStar(sIndex)"
                             ></el-rate>
                           </div>
@@ -1081,7 +1107,8 @@
                         <div class="worksTarget" v-if="isShow(worksDetail[sIndex].eList)"><span>目标</span></div>
                         <div class="worksTargetCon" v-if="isShow(worksDetail[sIndex].eList)">
                             <div v-for="(item,tarIndex) in worksDetail[sIndex].eList" :key="tarIndex">
-                              <span v-if="item.target"> {{ item.target }}</span>
+                              <span v-if="worksDetail[sIndex].state == 5"> {{ item.target }}</span>
+                              <span v-else> {{ item.target[item.target.length-1] }}</span>
                             </div>
                         </div>
                       </div>
@@ -1580,6 +1607,7 @@ export default {
                 wordInfo: [],
                 scopeId: res.data[0][k].id,
                 stagetask: stagetask,
+                state: res.data[0][k].state,
                 time: "",
               };
               checkJson[stagetask] = {
@@ -2434,11 +2462,13 @@ export default {
         let num = 0
 
         for (const key in val) {
-          if (val[key]  || val[key] == 0) {
-            sco+= val[key] * 1
+          if (val[key] && key != 'content') {
+            sco += val[key] * 1
           }
           num+=1
         }
+        if (sco == 0) return '0.0'
+        
         return (sco / (num - 1)).toFixed(1)
       }
     },
@@ -4120,4 +4150,10 @@ ol {
   object-fit: contain;
   cursor: pointer;
 }
+.RootImgBlock{
+    width: 50%;
+    white-space: nowrap;
+    overflow: hidden;
+    text-overflow: ellipsis;
+}
 </style>

+ 2 - 2
src/components/pages/works.vue

@@ -909,7 +909,7 @@ export default {
   background: #fff;
   overflow: auto;
   z-index: 1;
-  width: 95%;
+  width: 100%;
   left: 50%;
   transform: translateX(-50%);
   padding: 20px;
@@ -985,7 +985,7 @@ export default {
   background: #fff;
   overflow: auto;
   z-index: 1;
-  width: 95%;
+  width: 100%;
   left: 50%;
   -webkit-transform: translateX(-50%);
   transform: translateX(-50%);

Some files were not shown because too many files changed in this diff