瀏覽代碼

Merge branch 'beta' of https://git.cocorobo.cn/CocoRoboLabs/pbl-teacher-table into beta

SanHQin 7 月之前
父節點
當前提交
3f99f9d75d

+ 1 - 1
dist/index.html

@@ -32,7 +32,7 @@
       width: 100%;
       background: #e6eaf0;
       font-family: '黑体';
-    }</style><link href=./static/css/app.950b02e0ab4f6fffc20037eab06db226.css rel=stylesheet></head><body><div id=app></div><script type=text/javascript src=./static/js/manifest.571c38d63f24b1ae9e16.js></script><script type=text/javascript src=./static/js/vendor.35dfb1d95a63059f336f.js></script><script type=text/javascript src=./static/js/app.4758f15f922a73b6724b.js></script></body></html><script>function stopSafari() {
+    }</style><link href=./static/css/app.22f1680fc730d77db17b9fb994d02bff.css rel=stylesheet></head><body><div id=app></div><script type=text/javascript src=./static/js/manifest.571c38d63f24b1ae9e16.js></script><script type=text/javascript src=./static/js/vendor.35dfb1d95a63059f336f.js></script><script type=text/javascript src=./static/js/app.c4ab183d8fe1f910d2d8.js></script></body></html><script>function stopSafari() {
     //阻止safari浏览器双击放大功能
     let lastTouchEnd = 0  //更新手指弹起的时间
     document.documentElement.addEventListener("touchstart", function (event) {

文件差異過大導致無法顯示
+ 0 - 0
dist/static/css/app.22f1680fc730d77db17b9fb994d02bff.css


文件差異過大導致無法顯示
+ 0 - 0
dist/static/css/app.22f1680fc730d77db17b9fb994d02bff.css.map


文件差異過大導致無法顯示
+ 0 - 0
dist/static/js/app.c4ab183d8fe1f910d2d8.js


文件差異過大導致無法顯示
+ 0 - 0
dist/static/js/app.c4ab183d8fe1f910d2d8.js.map


文件差異過大導致無法顯示
+ 0 - 0
dist/static/js/manifest.571c38d63f24b1ae9e16.js.map


+ 93 - 86
src/components/pages/aiAddCourse/addCourse.vue

@@ -2390,11 +2390,11 @@
                                 @contextmenu.prevent="openAiDialog2(1, 'aiTask3',itemTaskIndex)"
                                 @click="openAiDialog2(2, 'aiTask3',itemTaskIndex)">重新生成任务</button>
                             </el-tooltip>
-                            <el-tooltip effect="light" content="右键单击可配置提示词" placement="bottom">
+                            <!-- <el-tooltip effect="light" content="右键单击可配置提示词" placement="bottom">
                               <button class="c_pub_button_confirm" style="margin: 0 0 0 20px;"
                                 @contextmenu.prevent="openAiDialog2(1, 'aiTask3','all')"
                                 @click="openAiDialog2(2, 'aiTask3','all')">重新生成任务</button>
-                            </el-tooltip>
+                            </el-tooltip> -->
                           </div>
                         </div>
                         <!-- padding: 20px; -->
@@ -7604,6 +7604,9 @@ export default {
       }
     },
     steps(newValue, old) {
+      if(newValue == 2){
+        this.steps = old
+      }
       if (newValue == 4) {
         let cPan = 1;
         for (var i = 0; i < this.unitJson.length; i++) {
@@ -16441,9 +16444,8 @@ ${msg}
 let message2 = `NOTICE
 Role: 你是一名教师,你正在使用一个在线学习平台来教授学生,你已经完成了教案,你现在需要将教案变为学生上课用的任务单(work sheet)。该在线学习平台为每个任务提供了资源区(视频,ppt,阅读资料将放在这里),多种互动工具(学生点击工具即可上传他们的作业或者回答,这些互动工具类似kahoot一样允许教师轻松收集,统计,追踪学生作业),以及和任务绑定的目标和评价系统。
 Language: Please use the same language as the user requirement, if the user speaks Chinese, the specific text of your answer should also be in Chinese.
-ATTENTION: Use '##' to SPLIT SECTIONS, not '#'. Output format carefully referenced "Format example".作业提交工具只能出现一次。
+ATTENTION: Use '##' to SPLIT SECTIONS, not '#'. Output format carefully referenced "Format example".
 Instruction: Based on the context, follow "Format example", write content.
-注意:作业提交工具只能出现一次。
 
 # Context
 ## 要求
@@ -16464,15 +16466,8 @@ ${msg2}
 工具名称:选择题
 工具指引:同学们,老师想要考察一下你对“热传递”这一概念的理解和掌握程度。请仔细阅读每个问题,并给出准确的答案哦~
 
-工具名称:作业提交
-工具指引:同学们,当你们完成实验报告后,我们需要用PPT来汇报项目成果。PPT是一种强大的工具,能帮助我们将复杂的信息以直观、有趣的方式展示出来。首先,打开PPT工具,新建一个演示文稿,并设置好基本结构,如标题页、实验背景、实验方法、数据分析、结论与建议等。接着,可以通过选择合适的主题和背景,美化幻灯片,插入图片、图标和图表,让PPT更生动。记住要保持文字简洁、突出重点,并为每张幻灯片添加适当的动画效果。制作完成后,多次练习你的演讲,确保表达清晰自然。最后,保存并分享你的PPT,准备好精彩的展示吧!期待看到你们的优秀成果,有问题随时来问我哦!
-
-注意:作业提交工具只能出现一次。
-
 # Format example
-{"toolChoose":[{"tool":"工具名","detail":"工具描述"},{"tool":"工具名","detail":"工具描述"}]}
-
-注意:作业提交工具只能出现一次。`
+{"toolChoose":[{"tool":"工具名","detail":"工具描述"},{"tool":"工具名","detail":"工具描述"}]}`
 
 let message3 = `NOTICE
 Role: 你是一名教师,你正在使用一个在线学习平台来教授学生,你已经完成了教案,你现在需要将教案变为学生上课用的任务单(work sheet)。该在线学习平台为每个任务提供了资源区(视频,ppt,阅读资料将放在这里),多种互动工具(学生点击工具即可上传他们的作业或者回答,这些互动工具类似kahoot一样允许教师轻松收集,统计,追踪学生作业),以及和任务绑定的目标和评价系统。
@@ -16535,9 +16530,8 @@ ${msg}
 let message2 = `NOTICE
 Role: 你是一名教师,你正在使用一个在线学习平台来教授学生,你已经完成了教案,你现在需要将教案变为学生上课用的任务单(work sheet)。该在线学习平台为每个任务提供了资源区(视频,ppt,阅读资料将放在这里),多种互动工具(学生点击工具即可上传他们的作业或者回答,这些互动工具类似kahoot一样允许教师轻松收集,统计,追踪学生作业),以及和任务绑定的目标和评价系统。
 Language: Please use the same language as the user requirement, if the user speaks Chinese, the specific text of your answer should also be in Chinese.
-ATTENTION: Use '##' to SPLIT SECTIONS, not '#'. Output format carefully referenced "Format example".作业提交工具只能出现一次。
+ATTENTION: Use '##' to SPLIT SECTIONS, not '#'. Output format carefully referenced "Format example".
 Instruction: Based on the context, follow "Format example", write content.
-注意:作业提交工具只能出现一次。
 
 # Context
 ## 要求
@@ -16558,15 +16552,8 @@ ${msg2}
 工具名称:选择题
 工具指引:同学们,老师想要考察一下你对“热传递”这一概念的理解和掌握程度。请仔细阅读每个问题,并给出准确的答案哦~
 
-工具名称:作业提交
-工具指引:同学们,当你们完成实验报告后,我们需要用PPT来汇报项目成果。PPT是一种强大的工具,能帮助我们将复杂的信息以直观、有趣的方式展示出来。首先,打开PPT工具,新建一个演示文稿,并设置好基本结构,如标题页、实验背景、实验方法、数据分析、结论与建议等。接着,可以通过选择合适的主题和背景,美化幻灯片,插入图片、图标和图表,让PPT更生动。记住要保持文字简洁、突出重点,并为每张幻灯片添加适当的动画效果。制作完成后,多次练习你的演讲,确保表达清晰自然。最后,保存并分享你的PPT,准备好精彩的展示吧!期待看到你们的优秀成果,有问题随时来问我哦!
-
-注意:作业提交工具只能出现一次。
-
 # Format example
-{"toolChoose":[{"tool":"工具名","detail":"工具描述"},{"tool":"工具名","detail":"工具描述"}]}
-
-注意:作业提交工具只能出现一次。`
+{"toolChoose":[{"tool":"工具名","detail":"工具描述"},{"tool":"工具名","detail":"工具描述"}]}`
 
 let message3 = `NOTICE
 Role: 你是一名教师,你正在使用一个在线学习平台来教授学生,你已经完成了教案,你现在需要将教案变为学生上课用的任务单(work sheet)。该在线学习平台为每个任务提供了资源区(视频,ppt,阅读资料将放在这里),多种互动工具(学生点击工具即可上传他们的作业或者回答,这些互动工具类似kahoot一样允许教师轻松收集,统计,追踪学生作业),以及和任务绑定的目标和评价系统。
@@ -16961,15 +16948,16 @@ ${this.courseText && this.aiCallBack == 2 ? '注意,优化原有的<参考内
         }
         // this.$forceUpdate();
       };
+      let _this = this
       this.isTextCancelSource.onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.textLoading = false
-        this.ttextLoading = false
-        this.isTextCancelToken = null
-        this.isTextCancelSource.close();
-        this.isTextCancelSource = null;
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.textLoading = false
+        _this.ttextLoading = false
+        _this.isTextCancelToken = null
+        _this.isTextCancelSource.close();
+        _this.isTextCancelSource = null;
       };
     },
     numberToChinese(number) {
@@ -19532,15 +19520,17 @@ ${msg}
         }
         // this.$forceUpdate();
       };
+
+      let _this = _this
       this.isOutlineTaskCancelSource[_tindex2].onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.taskDetailLoading.splice(this.taskDetailLoading.indexOf(loading), 1)
-        this.ttaskDetailLoading.splice(this.ttaskDetailLoading.indexOf(loading), 1)
-        this.isOutlineTaskCancelToken[_tindex2] = null
-        this.isOutlineTaskCancelSource[_tindex2].close();
-        this.isOutlineTaskCancelSource[_tindex2] = null;
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.taskDetailLoading.splice(this.taskDetailLoading.indexOf(loading), 1)
+        _this.ttaskDetailLoading.splice(this.ttaskDetailLoading.indexOf(loading), 1)
+        _this.isOutlineTaskCancelToken[_tindex2] = null
+        _this.isOutlineTaskCancelSource[_tindex2].close();
+        _this.isOutlineTaskCancelSource[_tindex2] = null;
       };
     },
     async aiOutlineDetail(msg, index) {
@@ -19859,15 +19849,17 @@ ${taskArray.length ? '其他任务大纲内容' + taskArray.join(',') : ''}
         }
         // this.$forceUpdate();
       };
+
+      let _this = this
       this.isOutlineTaskCancelSource[_tindex2].onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.taskDetailLoading.splice(this.taskDetailLoading.indexOf(loading), 1)
-        this.ttaskDetailLoading.splice(this.ttaskDetailLoading.indexOf(loading), 1)
-        this.isOutlineTaskCancelToken[_tindex2] = null
-        this.isOutlineTaskCancelSource[_tindex2].close();
-        this.isOutlineTaskCancelSource[_tindex2] = null;
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.taskDetailLoading.splice(this.taskDetailLoading.indexOf(loading), 1)
+        _this.ttaskDetailLoading.splice(this.ttaskDetailLoading.indexOf(loading), 1)
+        _this.isOutlineTaskCancelToken[_tindex2] = null
+        _this.isOutlineTaskCancelSource[_tindex2].close();
+        _this.isOutlineTaskCancelSource[_tindex2] = null;
       };
     },
     async aiDetail2(msg, index) {
@@ -20017,12 +20009,13 @@ ${_this.aiCallBack.taskDetail}
         }
         // this.$forceUpdate();
       };
+      let _this = this
       _source.onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.taskDetailLoading2.splice(this.taskDetailLoading2.indexOf(loading), 1)
-        this.ttaskDetailLoading2.splice(this.ttaskDetailLoading2.indexOf(loading), 1)
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.taskDetailLoading2.splice(this.taskDetailLoading2.indexOf(loading), 1)
+        _this.ttaskDetailLoading2.splice(this.ttaskDetailLoading2.indexOf(loading), 1)
         _source.close();
       };
     },
@@ -20174,12 +20167,14 @@ ${msg} 输出格式和内容要求参考#格式与要求
         }
         // this.$forceUpdate();
       };
+
+      let _this = this
       _source.onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.taskDetailLoading3.splice(this.taskDetailLoading3.indexOf(loading), 1)
-        this.ttaskDetailLoading3.splice(this.ttaskDetailLoading3.indexOf(loading), 1)
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.taskDetailLoading3.splice(this.taskDetailLoading3.indexOf(loading), 1)
+        _this.ttaskDetailLoading3.splice(this.ttaskDetailLoading3.indexOf(loading), 1)
         _source.close();
       };
     },
@@ -20520,12 +20515,14 @@ ${_text2}`
         }
         // this.$forceUpdate();
       };
+
+      let _this = this
       _source.onerror = function(event) {
           // 处理错误,可以尝试重新连接
-          console.error('EventSource error:', event);
-          this.$message.error("网络错误")
-          this.taskDetailLoading5.splice(this.taskDetailLoading5.indexOf(loading), 1)
-          this.ttaskDetailLoading5.splice(this.ttaskDetailLoading5.indexOf(loading), 1)
+          console.log('EventSource error:', event);
+          _this.$message.error("网络错误")
+          _this.taskDetailLoading5.splice(this.taskDetailLoading5.indexOf(loading), 1)
+          _this.ttaskDetailLoading5.splice(this.ttaskDetailLoading5.indexOf(loading), 1)
           _source.close();
       };
     },
@@ -20697,13 +20694,15 @@ ${(_this.templateid == "4480d65a-1e48-11ef-bee5-005056b86db5" || _this.templatei
           // 处理流数据
         }
       };
+
+      let _this = this
       _source.onerror = function(event) {
-          // 处理错误,可以尝试重新连接
-          console.error('EventSource error:', event);
-          this.$message.error("网络错误")
-          this.taskDetailLoading5.splice(this.taskDetailLoading5.indexOf(loading), 1)
-          this.ttaskDetailLoading5.splice(this.ttaskDetailLoading5.indexOf(loading), 1)
-          _source.close();
+        // 处理错误,可以尝试重新连接
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.taskDetailLoading5.splice(this.taskDetailLoading5.indexOf(loading), 1)
+        _this.ttaskDetailLoading5.splice(this.ttaskDetailLoading5.indexOf(loading), 1)
+        _source.close();
       };
     },
     aiDetail52getAiContentText(_e, loading, _tindex2, _source){
@@ -20907,12 +20906,14 @@ ${this.aitype == 'aiCpote4' ? '## 目标层\n'+this.cpote['cpote3'] : ''}`
         }
         // this.$forceUpdate();
       };
+
+      let _this = this
       _source.onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.cpoteLoading[loading] = false
-        this.cpotetLoading[loading] = false
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.cpoteLoading[loading] = false
+        _this.cpotetLoading[loading] = false
         _source.close();
       };
     },
@@ -21090,15 +21091,17 @@ ${this.teacherCourseText && this.aiCallBack == 2 ? '注意,优化原有的<参
         
         // this.$forceUpdate();
       };
+
+      let _this = this
       this.isTeacherTextCancelSource.onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.teacherTextLoading = false
-        this.tteacherTextLoading = false
-        this.isTeacherTextCancelToken = null
-        this.isTeacherTextCancelSource.close();
-        this.isTeacherTextCancelSource = null;
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.teacherTextLoading = false
+        _this.tteacherTextLoading = false
+        _this.isTeacherTextCancelToken = null
+        _this.isTeacherTextCancelSource.close();
+        _this.isTeacherTextCancelSource = null;
       };
     },
     async aitargetTextDetail(msg) {
@@ -21276,15 +21279,17 @@ ${this.targetCourseText && this.aiCallBack == 2 ? '注意,优化原有的<参
         
         // this.$forceUpdate();
       };
+
+      let _this = this
       this.isTargetCancelSource1.onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.targetTextLoading = false
-        this.ttargetTextLoading = false
-        this.isTargetCancelToken1 = null
-        this.isTargetCancelSource1.close();
-        this.isTargetCancelSource1 = null;
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.targetTextLoading = false
+        _this.ttargetTextLoading = false
+        _this.isTargetCancelToken1 = null
+        _this.isTargetCancelSource1.close();
+        _this.isTargetCancelSource1 = null;
       };
     },
     async aitargetTextDetail2(msg) {
@@ -21625,15 +21630,17 @@ ${this.targetCourseText && this.aiCallBack == 2 ? '注意,优化原有的<参
         }
         // this.$forceUpdate();
       };
+
+      let _this = this
       this.isTargetCancelSource2.onerror = function(event) {
         // 处理错误,可以尝试重新连接
-        console.error('EventSource error:', event);
-        this.$message.error("网络错误")
-        this.targetTextLoading2 = false
-        this.ttargetTextLoading2 = false
-        this.isTargetCancelToken2 = null
-        this.isTargetCancelSource2.close();
-        this.isTargetCancelSource2 = null;
+        console.log('EventSource error:', event);
+        _this.$message.error("网络错误")
+        _this.targetTextLoading2 = false
+        _this.ttargetTextLoading2 = false
+        _this.isTargetCancelToken2 = null
+        _this.isTargetCancelSource2.close();
+        _this.isTargetCancelSource2 = null;
       };
     },
     async aitargetTextDetail3(msg) {

+ 303 - 37
src/components/pages/components/report.vue

@@ -1,5 +1,5 @@
 <template>
-  <div class="r_box">
+  <div class="r_box" v-loading="isLoading">
     <div class="r_cbox">
       <span>学生姓名</span>
       <el-select
@@ -68,8 +68,6 @@
 </template>
 
 <script>
-import htmlDocx from "html-docx-js/dist/html-docx";
-import saveAs from "file-saver";
 export default {
   props: ["cid"],
   data() {
@@ -92,16 +90,20 @@ export default {
       cocopiInfo: [],
       wordInfo: [],
       course: {},
+      isLoading:false
     };
   },
   methods: {
     getCourseDetail() {
+      this.isLoading=true
       let params = {
         cid: this.cid,
       };
       this.ajax
         .get(this.$store.state.api + "getCourseWorksReport", params)
         .then((res) => {
+          console.log('res',res.data);
+          
           this.course = res.data[0][0];
           var dyJSON = JSON.parse(res.data[0][0].chapters);
           let dyList = [];
@@ -113,20 +115,24 @@ export default {
             }
           }
           this.dyList = dyList;
+          console.log(' this.dyList', this.dyList);
+          
           this.userAarray = res.data[1];
-          this.imgList = res.data[2];
-          this.askList = res.data[3];
-          this.questList = res.data[4];
-          this.wordList = res.data[5];
-          this.chooseInfo = res.data[6];
+          this.imgList = res.data[2]; //图片
+          this.askList = res.data[3]; //问卷调查
+          this.questList = res.data[4]; //问答
+          this.wordList = res.data[5]; //word等
+          this.chooseInfo = res.data[6]; //选择题
           this.pjInfo = res.data[7]; //个人评价作业
           this.xztkInfo = res.data[8]; //选择匹配作业
           this.lccjInfo = res.data[9]; //排序作业
           this.bgInfo = res.data[10]; //表格作业
           this.cocopiInfo = res.data[11]; //cocopi或源码编辑作业
           this.wordInfo = res.data[12]; //文档作业
+          this.isLoading=false
         })
         .catch((err) => {
+          this.isLoading=false
           console.error(err);
         });
     },
@@ -146,6 +152,7 @@ export default {
           _uname.push(_userA[i]);
         }
       }
+      
 
       if (!_chap.length) {
         for (var i = 0; i < this.dyList.length; i++) {
@@ -167,22 +174,13 @@ export default {
 
       let workArray = [];
 
-      // json{
-      //       img: [],
-      //       askList: [],
-      //       questList: {},
-      //       wordList: [],
-      //       chapName: "",
-      //       taskName: "",
-      //       username:""
-      //     }
-
       for (let i = 0; i < _uname.length; i++) {
         for (let chapI = 0; chapI < _chap.length; chapI++) {
           if (_task.length) {
             for (let taskI = 0; taskI < _task.length; taskI++) {
-              let _tI = _task[taskI].split("-");
+              let _tI = _task[taskI].split("-");  //阶段-任务
               if (_tI[0] == _chap[chapI]) {
+                
                 let _workjson = {
                   img: [],
                   askList: [],
@@ -197,19 +195,19 @@ export default {
                   wordInfo: [],
                   chapName:
                     "第" +
-                    (parseInt(_chap[chapI]) + 1) +
+                    (parseInt(chapI) + 1) +
                     "阶段 " +
-                    this.dyList[_chap[chapI]].name,
+                    this.dyList[chapI].name,
                   taskName:
                     "任务" +
                     (parseInt(_tI[1]) + 1) +
-                    this.dyList[_chap[chapI]].taskList[_tI[1]].name,
+                    this.dyList[chapI].taskList[_tI[1]].name,
                   username: _uname[i].username,
                 };
                 // imgList;askList;questList;wordList;
                 for (let a = 0; a < imgList.length; a++) {
                   if (
-                    imgList[a].stage == _chap[chapI] &&
+                    imgList[a].stage == chapI &&
                     imgList[a].task == _tI[1] &&
                     imgList[a].userid == _uname[i].userid
                   ) {
@@ -218,7 +216,7 @@ export default {
                 }
                 for (let b = 0; b < askList.length; b++) {
                   if (
-                    askList[b].stage == _chap[chapI] &&
+                    askList[b].stage == chapI &&
                     askList[b].task == _tI[1] &&
                     askList[b].userid == _uname[i].userid
                   ) {
@@ -254,20 +252,89 @@ export default {
                     _workjson.wordList.push(element.content);
                   }
                 }
+                for (let d = 0; d < pjInfo.length; d++) {
+                  if (
+                    pjInfo[d].stage == chapI &&
+                    pjInfo[d].task == _tI[1] &&
+                    pjInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = pjInfo[d];
+                    _workjson.pjInfo.push(element.content);
+                  }
+                }
+                for (let d = 0; d < chooseInfo.length; d++) {
+                  if (
+                    chooseInfo[d].stage == chapI &&
+                    chooseInfo[d].task == _tI[1] &&
+                    chooseInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = chooseInfo[d];
+                    _workjson.chooseInfo.push(element.content);
+                  }
+                }
+                for (let d = 0; d < xztkInfo.length; d++) {
+                  if (
+                    xztkInfo[d].stage == chapI &&
+                    xztkInfo[d].task == _tI[1] &&
+                    xztkInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = xztkInfo[d];
+                    _workjson.xztkInfo.push(element.content);
+                  }
+                }
+                for (let d = 0; d < lccjInfo.length; d++) {
+                  if (
+                    lccjInfo[d].stage == chapI &&
+                    lccjInfo[d].task == _tI[1] &&
+                    lccjInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = lccjInfo[d];
+                    _workjson.lccjInfo.push(element.content);
+                  }
+                }
+                for (let d = 0; d < bgInfo.length; d++) {
+                  if (
+                    bgInfo[d].stage == chapI &&
+                    bgInfo[d].task == _tI[1] &&
+                    bgInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = bgInfo[d];
+                    _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 < wordInfo.length; d++) {
+                  if (
+                    wordInfo[d].stage == chapI &&
+                    wordInfo[d].task == _tI[1] &&
+                    wordInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = wordInfo[d];
+                    _workjson.wordInfo.push(element.content);
+                  }
+                }
+
                 workArray.push(_workjson);
               }
             }
           } else {
             for (
               let taskI = 0;
-              taskI < this.dyList[_chap[chapI]].taskList.length;
+              taskI < this.dyList[chapI].taskList.length;
               taskI++
             ) {
-              let _tI = [
-                _chap[chapI],
-                this.dyList[_chap[chapI]].taskList[taskI].id,
-              ];
-              if (_tI[0] == _chap[chapI]) {
+              let _tI = [chapI, this.dyList[chapI].taskList[taskI].id];
+              if (_tI[0] == chapI) {
+
                 let _workjson = {
                   img: [],
                   askList: [],
@@ -282,13 +349,13 @@ export default {
                   wordInfo: [],
                   chapName:
                     "第" +
-                    (parseInt(_chap[chapI]) + 1) +
+                    (parseInt(chapI) + 1) +
                     "阶段 " +
-                    this.dyList[_chap[chapI]].name,
+                    this.dyList[chapI].name,
                   taskName:
                     "任务" +
                     (parseInt(_tI[1]) + 1) +
-                    this.dyList[_chap[chapI]].taskList[_tI[1]].name,
+                    this.dyList[chapI].taskList[_tI[1]].name,
                   username: _uname[i].username,
                 };
                 // imgList;askList;questList;wordList;
@@ -339,6 +406,77 @@ export default {
                     _workjson.wordList.push(element.content);
                   }
                 }
+                for (let d = 0; d < chooseInfo.length; d++) {
+                  if (
+                    chooseInfo[d].stage == chapI &&
+                    chooseInfo[d].task == _tI[1] &&
+                    chooseInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = chooseInfo[d];
+                    _workjson.chooseInfo.push(element.content);
+                  }
+                }
+                for (let d = 0; d < pjInfo.length; d++) {
+                  if (
+                    pjInfo[d].stage == chapI &&
+                    pjInfo[d].task == _tI[1] &&
+                    pjInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = pjInfo[d];
+                    _workjson.pjInfo.push(element.content);
+                  }
+                }
+                for (let d = 0; d < xztkInfo.length; d++) {
+                  if (
+                    xztkInfo[d].stage == chapI &&
+                    xztkInfo[d].task == _tI[1] &&
+                    xztkInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = xztkInfo[d];
+                    _workjson.xztkInfo.push(element.content);
+                  }
+                }
+                for (let d = 0; d < lccjInfo.length; d++) {
+                  if (
+                    lccjInfo[d].stage == chapI &&
+                    lccjInfo[d].task == _tI[1] &&
+                    lccjInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = lccjInfo[d];
+                    _workjson.lccjInfo.push(element.content);
+                  }
+                }
+                for (let d = 0; d < bgInfo.length; d++) {
+                  if (
+                    bgInfo[d].stage == chapI &&
+                    bgInfo[d].task == _tI[1] &&
+                    bgInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = bgInfo[d];
+                    _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 < wordInfo.length; d++) {
+                  if (
+                    wordInfo[d].stage == chapI &&
+                    wordInfo[d].task == _tI[1] &&
+                    wordInfo[d].userid == _uname[i].userid
+                  ) {
+                    const element = wordInfo[d];
+                    _workjson.wordInfo.push(element.content);
+                  }
+                }
+
                 workArray.push(_workjson);
               }
             }
@@ -360,6 +498,8 @@ export default {
         "<div >" + "<h2>" + workJson.chapName + "-" + workJson.username;
       ("</h2>");
       ("</div>");
+      // console.log('workJson',workJson);
+      
       var _subtitle = "<h3>" + workJson.taskName + "</h3>";
       var _img = "";
       if (workJson.img.length > 0) {
@@ -409,7 +549,7 @@ export default {
         for (var i = 0; i < workJson.questList.length; i++) {
           var _div = document.createElement("div");
           _div.innerHTML = `<h4>问答:${workJson.questList[i].answerTitle}</h4>`;
-          _div.innerHTML += `<div>${workJson.questList[i].answer}</div>`;
+          _div.innerHTML += `<h6>${workJson.questList[i].answer}</h6>`;
           _answer += `<div>${_div.innerHTML}</div>`;
         }
       }
@@ -417,19 +557,142 @@ export default {
       var _link = "";
       if (workJson.wordList.length > 0) {
         for (var i = 0; i < workJson.wordList.length; i++) {
-          _link += `<div style="margin-top:10px"><a href='${workJson.wordList[i]}'>${workJson.wordList[i]}</a></div>`;
+          _link += `<h6 style="margin-top:10px"><a href='${workJson.wordList[i]}'>${workJson.wordList[i]}</a></h6>`;
+        }
+      }
+
+      
+      var _choose = "";
+      if (workJson.chooseInfo.length > 0) {
+        var _choose = "<h3>选择题</h3>";
+        for (var i = 0; i < workJson.chooseInfo.length; i++) {
+            let chooseData = JSON.parse(workJson.chooseInfo[i])[0]
+            
+            let _div = document.createElement("div");
+            _div.innerHTML = `<h4>标题:${chooseData.testJson.testTitle}</h4>`;
+
+            chooseData.testJson.testJson.forEach((e,eIndex)=>{
+                var _div2 = document.createElement("div");
+                _div2.innerHTML = `<h5>第${eIndex + 1}题:${
+                    e.teststitle
+                }  选择:${
+                  chooseData.anwer[eIndex].length > 1? chooseData.anwer[eIndex].join(',') : chooseData.anwer[eIndex]
+                } 答案:${
+                    e.type == 1 ? e.answer : e.answer.join(',')
+                }</h5> `;
+                // console.log('_div2',_div2);
+                var _div3 = document.createElement("div");
+                e.checkList.forEach((k,kIndex)=>{
+                    _div3.innerHTML += `<span style="margin-right:5px">${kIndex + 1}.${
+                        k
+                    }</span>`;
+                })
+                _div2.innerHTML += `<div>${_div3.innerHTML}</div>`;
+                _div.innerHTML += `<div>${_div2.innerHTML}</div>`;
+
+            })
+           
+            _choose += `<div>${_div.innerHTML}</div>`;
+        }
+      }
+
+      var _pjInfo = "";
+      if (workJson.pjInfo.length > 0) {
+        let pjData = JSON.parse(workJson.pjInfo[0]).eStar
+       
+        var _pjInfo = "<h3>个人评价</h3>"
+
+        pjData.forEach((e,index) => {
+            
+          _pjInfo += `<div>${index + 1}评:${e}分</div>`;
+        });
+        _pjInfo += `<h6>评语:${JSON.parse(workJson.pjInfo[0]).eBzText}</h6>`;
+      }
+
+      var _xztkInfo = "";
+      if (workJson.xztkInfo.length > 0) {
+        var _xztkInfo = "<h3>选择匹配</h3>"
+        // console.log('workJson.xztkInfo',workJson.xztkInfo);
+        workJson.xztkInfo.forEach((e,i)=>{
+          _xztkInfo += `<h6>${e}</h6>`;
+        })
+      }
+     
+      var _lccjInfo = ""
+      if (workJson.lccjInfo.length>0) {
+        let lccjData= JSON.parse(workJson.lccjInfo[0])
+
+          if (lccjData.length > 0) {
+           _lccjInfo = "<h3>排序<h3>";
+            for (var i = 0; i < lccjData.length; i++) {
+              var _div = document.createElement("div");
+              _div.innerHTML = `<h4>第${i+1}题${lccjData[i].sentenceTitle}</h4> `;
+              var _div2 = document.createElement("div");
+              _div2.innerHTML+= ` 句子 ${i + 1}:${ lccjData[i].addSentence.join(',')} 选择:${
+                  lccjData[i].chooseSenList.join(',') 
+                } 答案:${
+                  lccjData[i].rightAnswer.join(',') 
+                }`
+              _div.innerHTML += `<h4>${_div2.innerHTML}</h4>`;
+              _lccjInfo += `<h4>${_div.innerHTML}</h4>`;
+            }
+          }
+      }
+          
+
+      var _bg = "";
+      if (workJson.bgInfo.length > 0) {
+        var _bg = "<h3>表格<h3>";
+        for (var i = 0; i < workJson.bgInfo.length; i++) {
+          var _div = document.createElement("div");
+          _div.innerHTML = `<h6>${JSON.parse(workJson.bgInfo[i]).text}</h6> `;
+          _bg += `<div>${_div.innerHTML}</div>`;
+        }
+      }
+      
+      var _cocopi = "";
+
+      if (workJson.cocopiInfo.length > 0) {
+
+        var _cocopi = "<h4>cocopi<h3>";
+        for (var i = 0; i < workJson.cocopiInfo.length; i++) {
+          _cocopi += `<h6>不支持查看</h6>`;
+        }
+      }
+
+      var _word = "";
+      if (workJson.wordInfo.length > 0) {
+        
+        var _word = "<h3>文档<h3>";
+        for (var i = 0; i < workJson.wordInfo.length; i++) {
+          var _div = document.createElement("div");
+          let wrdT = workJson.wordInfo[i]
+          _div.innerHTML = `<h6>${JSON.parse(wrdT).text}</h6> `;
+          _word += `<div>${_div.innerHTML}</div>`;
         }
       }
 
+
       if (
         !workJson.img.length &&
         !workJson.askList.length &&
         !workJson.questList.length &&
-        !workJson.wordList.length
+        !workJson.wordList.length &&
+        !workJson.lccjInfo.length &&
+        !workJson.wordInfo.length &&
+        !workJson.pjInfo.length &&
+        !workJson.xztkInfo.length &&
+        !workJson.chooseInfo.length &&
+        !workJson.cocopiInfo.length &&
+        !workJson.bgInfo.length 
+
+
+
       ) {
         return "";
       }
-      return _title + _subtitle + _img + _ask + _answer + _link;
+      
+      return _title + _subtitle + _img + _ask + _pjInfo + _answer + _xztkInfo + _link + _choose + _lccjInfo + _bg + _cocopi + _word;
     },
     async generate(a) {
       // 将html文件中需要用到的数据挂载到store上
@@ -495,6 +758,9 @@ export default {
   },
   watch: {
     cid(newValue, oldValue) {
+      this.uname = [];
+      this.chap = [];
+      this.task = [];
       this.getCourseDetail();
     },
   },

+ 65 - 119
src/components/pages/components/worksDetail2.vue

@@ -218,7 +218,7 @@
                 type="primary"
                 size="small"
                 @click="
-                  lookWork(scope.row.id, scope.row.userid, 0, scope.$index)
+                  lookWork(scope.row.id, scope.row.userid, 0, scope.$index,scope.row)
                 "
                 >查看&批改</el-button
               >
@@ -228,14 +228,14 @@
                 @click="lookData(scope.row.userid)"
                 >生成报告</el-button
               >-->
-              <el-button
+              <!-- <el-button
                 type="primary"
                 size="small"
                 @click="
                   lookWork2(scope.row.id, scope.row.userid, scope.row.courseid, dyList[scope.row.stage].name,dyList[scope.row.stage].taskList[scope.row.task].name)
                 "
                 >导出作业</el-button
-              >
+              > -->
               <!-- <el-button
                 class="de_button"
                 type="primary"
@@ -2178,7 +2178,7 @@ export default {
       }
       // this.getWorks();
     },
-    lookWork(id, uid, type, index) {
+    lookWork(id, uid, type, index,con) {
       this.scopeId1 = id;
       this.studentId = uid;
       let params = {
@@ -2936,9 +2936,16 @@ export default {
             }
           }
 				
-					this.$nextTick(()=>{
-						this.openTask(this.chooseDy?this.chooseDy:0,this.chooseTask?this.chooseTask:0,this.chooseDy?this.dyList2.findIndex(i=>i.id==this.chooseDy):0,this.chooseTask?this.dyList2[this.dyList2.findIndex(i=>i.id==this.chooseDy)].taskList.findIndex(i=>i.id==this.chooseTask):0)
-					})
+          // if(this.cutTabNum == 2){
+            this.$nextTick(()=>{
+              this.openTask2(con)
+            })
+          // }else{
+          //   this.$nextTick(()=>{
+          //     this.openTask(con,this.chooseDy?this.chooseDy:0,this.chooseTask?this.chooseTask:0,this.chooseDy?this.dyList2.findIndex(i=>i.id==this.chooseDy):0,this.chooseTask?this.dyList2[this.dyList2.findIndex(i=>i.id==this.chooseDy)].taskList.findIndex(i=>i.id==this.chooseTask):0)
+          //   })
+          // }
+					
           // this.preStep();
           // this.nextStep();
         })
@@ -3382,97 +3389,44 @@ 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)).filter(e => {return e!='content'});
-              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]];
-                }
-              }
 
-              // console.log('1',JSON.parse(JSON.stringify(_rateList[p])));
-              // console.log('2',JSON.parse(JSON.stringify(this.ooption[p])));
 
-              
-              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];
-                }
+          var _title =
+            "<h2>" +
+            "第" +
+            (this.sInfo.stage + 1) +
+            "阶段 " +
+            this.dyList[this.sInfo.stage].name +
+            "</h2>";
+          var _subtitle =
+            "<h3>" +
+            "任务" +
+            (this.sInfo.task + 1) +
+            " " +
+            this.dyList[this.sInfo.stage].taskList[this.sInfo.task].name +
+            "-" +
+            this.sInfo.sName +
+            "</h3>";
+
+
+
+          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]];
               }
             }
-          } 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 < 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({
               src: worksDetail[i].content,
@@ -3611,8 +3565,6 @@ export default {
             }
           }
 
-          // console.log('lccjInfo',lccjInfo);
-          
           if (lccjInfo.length > 0) {
             for (var i = 0; i < lccjInfo.length; i++) {
               var lccj = lccjInfo[i];
@@ -3624,7 +3576,6 @@ export default {
               });
             }
           }
-          
 
           for (var i = 0; i < bgInfo.length; i++) {
             var bg = bgInfo[i];
@@ -3721,22 +3672,7 @@ export default {
           this.$forceUpdate;
 
           var _course = `<h1>${this.sInfo.course}</h1>`;
-          var _title =
-            "<h2>" +
-            "第" +
-            (this.sInfo.stage + 1) +
-            "阶段 " +
-            this.dyList[this.sInfo.stage].name +
-            "</h2>";
-          var _subtitle =
-            "<h3>" +
-            "任务" +
-            (this.sInfo.task + 1) +
-            " " +
-            this.dyList[this.sInfo.stage].taskList[this.sInfo.task].name +
-            "-" +
-            this.sInfo.sName +
-            "</h3>";
+         
           var _img = "";
           if (workJson.img.length > 0) {
             for (var i = 0; i < workJson.img.length; i++) {
@@ -3870,15 +3806,6 @@ export default {
                 var _div = document.createElement("div");
                 _div.innerHTML = `<h4>第${i+1}题${workJson.lccjInfo[0].lccjInfo[i].sentenceTitle}</h4> `;
                 var _div2 = document.createElement("div");
-                // for (
-                //   var j = 0;
-                //   j < workJson.lccjInfo[0][lccjInfo][i].chooseSenList.length;
-                //   j++
-                // ) {
-                //   _div2.innerHTML += ` 句子 ${j + 1} : ${
-                //     workJson.lccjInfo[0][lccjInfo][i].chooseSenList[j]
-                //   }`;
-                // }
                 _div2.innerHTML+= ` 句子 ${i + 1}:${ workJson.lccjInfo[0].lccjInfo[i].addSentence.join(',')} 选择:${
                     workJson.lccjInfo[0].lccjInfo[i].chooseSenList.join(',') 
                   } 答案:${
@@ -3945,7 +3872,7 @@ export default {
       this.dyList2[s].isOpen = !this.dyList2[s].isOpen;
     },
     openTask(s, i, dyi, navi) {
-      console.log('openTask2',s, i, dyi, navi);
+      // console.log('openTask2',con,s, i, dyi, navi);
 
       if (!this.dyList2[dyi].taskList[navi].isWork) {
         this.$message.warning("该任务暂时没提交作业");
@@ -3965,6 +3892,25 @@ export default {
         this.navId = a;
       }
     },
+    openTask2(con) {
+      console.log(con);
+      
+      let s = con.stage
+      let i = con.task
+
+      const element = document.getElementById(`${s}+${i}`);
+      if (element) {
+        element.scrollIntoView({
+          behavior: 'smooth'
+        });
+      }
+      var a = s + "-" + i;
+    
+      this.stageIndex = s;
+      this.taskCount = i;
+      this.navId = a;
+
+    },
     async generate(a,stage,task) {
       // 将html文件中需要用到的数据挂载到store上
       this.$store.commit("update", ["report", a]);

+ 48 - 1
src/components/pages/test/add/setInfo/index.vue

@@ -65,6 +65,7 @@
                             <div class="whiteBg" style="border-radius: 0; margin-top: 0px;margin-bottom: 10px;" v-if="teaType.length">
                                 <div class="c_info_title" style="padding: 0 0 15px;margin: 0 auto 0 0;">设置填写范围
                                     <span style="font-weight: 500; color: #7F7979E5;">(符合以下所有条件的教师)</span>
+                                    <span style="font-weight: 500; margin-left: 10px; cursor: pointer;" @click="checkTeacher">已选:{{ teacherArray.length }}人</span>
                                 </div>
                                 <div class="typeBox" v-for="item in teaType" :key="item.id" style="margin: 0 0 10px">
                                     <span>{{ item.name + ":" }}</span>
@@ -137,6 +138,17 @@
                 </el-button>
             </span>
         </el-dialog>
+        <el-dialog title="填写返回已选教师" :visible.sync="dialogTeacher" :append-to-body="true" :before-close="handleClose"
+            class="dialog_diy" width="500px">
+            <van-divider>
+                <div style="display: flex;flex-wrap: wrap;line-height: 20px;">
+                    <span style="color: #00000099;">已选教师名单:</span>
+                    <span style="word-break: break-word;" v-for="(item, index) in teacherArray" :key="item.userid">
+                        {{ item.username }}{{ index == teacherArray.length - 1 ? '' : '、' }}
+                    </span>
+                </div>
+            </van-divider>
+        </el-dialog>
     </div>
 </template>
 
@@ -215,7 +227,9 @@ export default {
             juriDialog: false,
             checkAll: false,
             ischeckAll: false,
-            teaType: []
+            teaType: [],
+            teacherArray:[],
+            dialogTeacher: false,
         }
     },
     computed: {
@@ -258,7 +272,37 @@ export default {
             },
         },
     },
+    watch: {
+        teaType: {
+            immediate: true,
+            deep: true,
+            handler(newValue, oldValue) {
+                this.getTestWorkTeacherCount()
+            },
+        },
+    },
     methods: {
+        getTestWorkTeacherCount(){
+            let j3 = []
+            if(this.teaType.length){
+                this.teaType.forEach(e => {
+                    j3.push(e.value)
+                })
+            }
+            let params = [{
+                juri: j3.length ? j3.join(',') : "",
+                userid: this.$route.query.userid
+            }]
+            this.ajax
+                .post(this.$store.state.api + "getTestWorkTeacherCount", params)
+                .then((res) => {
+                    this.teacherArray = res.data[0]
+                })
+                .catch((err) => {
+                    this.$message.error("网络不佳");
+                    console.error(err);
+                });
+        },
         Ochange() {
             this.$forceUpdate()
             this.$emit("update:typeInfo", this.teaType)
@@ -450,6 +494,9 @@ export default {
             this.checkList = JSON.parse(JSON.stringify(this.checkList2));
             this.$emit("update:juriList", this.checkList)
             this.juriDialog = false
+        },
+        checkTeacher(){
+            this.dialogTeacher = true
         }
     },
     mounted() {

+ 15 - 0
src/components/pages/test/check/index.vue

@@ -1268,6 +1268,21 @@ export default {
         .then(async (res) => {
           this.testJson = res.data[0][0]
           console.log('this.testJson',JSON.parse(JSON.stringify(this.testJson)));
+
+          let a = ''
+          if(this.testJson.juriP){
+              a = this.testJson.juriP
+          }
+          if(this.testJson.juriP2){
+              if(a){
+                  a = this.testJson.juriP+','+this.testJson.juriP2
+              }else {
+                  a = this.testJson.juriP2
+              }
+          }
+          this.testJson.juriP = a
+
+
           if (this.testJson.juriP) {
             let ajuri2 =  this.testJson.juri2.split (',');
             this.TeachingOptions = ajuri2.map((key, index) => ({

+ 14 - 1
src/components/pages/test/index.vue

@@ -857,7 +857,20 @@ export default {
                     this.isLoading = false;
                     this.total = res.data[0].length > 0 ? res.data[0][0].num : 0;
                     this.course = res.data[0];
-
+                    for(var i = 0; i < this.course.length; i++) {
+                        let a = ''
+                        if(this.course[i].juriP){
+                            a = this.course[i].juriP
+                        }
+                        if(this.course[i].juriP2){
+                            if(a){
+                                a = this.course[i].juriP+','+this.course[i].juriP2
+                            }else {
+                                a = this.course[i].juriP2
+                            }
+                        }
+                        this.course[i].juriP = a
+                    }
                 })
                 .catch((err) => {
                     this.isLoading = false;

部分文件因文件數量過多而無法顯示