Przeglądaj źródła

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

SanHQin 5 miesięcy temu
rodzic
commit
3786bdda45

+ 1 - 1
dist/index.html

@@ -32,7 +32,7 @@
       width: 100%;
       background: #e6eaf0;
       font-family: '黑体';
-    }</style><link href=./static/css/app.4091725a3d128ed2c96c705d5d65d69b.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.bba3ed5aca95350eeef8.js></script><script type=text/javascript src=./static/js/app.618cdc5ef4fa533b9cca.js></script></body></html><script>function stopSafari() {
+    }</style><link href=./static/css/app.3647ac6b3e5e9bf822ca0edc0770d223.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.bba3ed5aca95350eeef8.js></script><script type=text/javascript src=./static/js/app.8f4c6a223223b9cb81e1.js></script></body></html><script>function stopSafari() {
     //阻止safari浏览器双击放大功能
     let lastTouchEnd = 0  //更新手指弹起的时间
     document.documentElement.addEventListener("touchstart", function (event) {

Plik diff jest za duży
+ 0 - 0
dist/static/css/app.3647ac6b3e5e9bf822ca0edc0770d223.css


Plik diff jest za duży
+ 0 - 0
dist/static/css/app.3647ac6b3e5e9bf822ca0edc0770d223.css.map


Plik diff jest za duży
+ 0 - 0
dist/static/css/app.4091725a3d128ed2c96c705d5d65d69b.css


Plik diff jest za duży
+ 0 - 0
dist/static/css/app.4091725a3d128ed2c96c705d5d65d69b.css.map


Plik diff jest za duży
+ 0 - 0
dist/static/js/app.8f4c6a223223b9cb81e1.js


Plik diff jest za duży
+ 0 - 0
dist/static/js/app.8f4c6a223223b9cb81e1.js.map


Plik diff jest za duży
+ 0 - 0
dist/static/js/manifest.571c38d63f24b1ae9e16.js.map


+ 48 - 18
src/components/pages/aiAddCourse/addCourse.vue

@@ -1267,7 +1267,9 @@
                 </div>
                 <div style="width: 100%; padding: 0px 20px; box-sizing: border-box;display:flex;">
                   <div style="width: calc(100%);height: 100%" class='op_task_box inter_voiceBox'>
-                    <recordV></recordV>
+                    <recordV
+                    :videoText2.sync="recordVideoText"
+                    :audioUrl2.sync="recordAudioUrl"></recordV>
                   </div>
                   <div class="inter_box" v-show="interPan" style="margin: 0 0 0 10px">
                     <aiBoxCourseDetail  
@@ -7718,6 +7720,8 @@ export default {
       taskCancelToken2: [],
       isDisplay: true,
       isDialog: 0,
+      recordVideoText: "",
+      recordAudioUrl: "",
     };
   },
   directives: {
@@ -12335,6 +12339,8 @@ ${_this.unitJson[0].chapterInfo[0].taskJson[index].taskDetail3.replaceAll('#',''
             knowFileids: this.knowFileids,
             knowInfoData2: this.knowInfoData2,
             knowFileids2: this.knowFileids2,
+            recordVideoText: this.recordVideoText,
+            recordAudioUrl: this.recordAudioUrl,
           }),
           iresearch: this.isFileSearch ? 1 : 2,
         },
@@ -12612,6 +12618,8 @@ ${_this.unitJson[0].chapterInfo[0].taskJson[index].taskDetail3.replaceAll('#',''
             knowFileids: this.knowFileids,
             knowInfoData2: this.knowInfoData2,
             knowFileids2: this.knowFileids2,
+            recordVideoText: this.recordVideoText,
+            recordAudioUrl: this.recordAudioUrl,
           }),
           iresearch: this.isFileSearch ? 1 : 2,
         },
@@ -14763,6 +14771,9 @@ ${_this.unitJson[0].chapterInfo[0].taskJson[index].taskDetail3.replaceAll('#',''
                 this.knowFileids = (JSON.parse(res.data[0][0].setting).knowFileids) ? JSON.parse(res.data[0][0].setting).knowFileids : [];
                 this.knowInfoData2 = (JSON.parse(res.data[0][0].setting).knowInfoData2) ? JSON.parse(res.data[0][0].setting).knowInfoData2 : [];
                 this.knowFileids2 = (JSON.parse(res.data[0][0].setting).knowFileids2) ? JSON.parse(res.data[0][0].setting).knowFileids2 : [];
+                this.recordVideoText = (JSON.parse(res.data[0][0].setting).recordVideoText) ? JSON.parse(res.data[0][0].setting).recordVideoText : "";
+                this.recordAudioUrl = (JSON.parse(res.data[0][0].setting).recordAudioUrl) ? JSON.parse(res.data[0][0].setting).recordAudioUrl : "";
+                
                 if(this.targetCourseText2 || (!this.teacherCourseText)){
                   this.courseTextBool = true
                 }
@@ -14918,6 +14929,9 @@ ${_this.unitJson[0].chapterInfo[0].taskJson[index].taskDetail3.replaceAll('#',''
                 this.knowFileids = (JSON.parse(res.data[0][0].setting).knowFileids) ? JSON.parse(res.data[0][0].setting).knowFileids : [];
                 this.knowInfoData2 = (JSON.parse(res.data[0][0].setting).knowInfoData2) ? JSON.parse(res.data[0][0].setting).knowInfoData2 : [];
                 this.knowFileids2 = (JSON.parse(res.data[0][0].setting).knowFileids2) ? JSON.parse(res.data[0][0].setting).knowFileids2 : [];
+                this.recordVideoText = (JSON.parse(res.data[0][0].setting).recordVideoText) ? JSON.parse(res.data[0][0].setting).recordVideoText : "";
+                this.recordAudioUrl = (JSON.parse(res.data[0][0].setting).recordAudioUrl) ? JSON.parse(res.data[0][0].setting).recordAudioUrl : "";
+
                 if(this.targetCourseText2 || (!this.teacherCourseText)){
                   this.courseTextBool = true
                 }
@@ -16907,45 +16921,60 @@ ${_this.unitJson[0].chapterInfo[0].taskJson[index].taskDetail3.replaceAll('#',''
           console.error(err);
         });
     },
-    allEvaCan(){
+    allEvaCan() {
       if (this.taskLoading.length) {
         let _pan = 1
-        for(var k = 0; k < this.taskLoading.length; k++){
-          if(this.taskLoading[k]){
+        for (var k = 0; k < this.taskLoading.length; k++) {
+          if (this.taskLoading[k]) {
             this.$message({
-              message: `请等待任务${k+1}回答完毕后再继续`,
+              message: `请等待任务${k + 1}回答完毕后再继续`,
               type: "warning"
             });
             _pan = 2
           }
         }
-        if(_pan == 2){
+        if (_pan == 2) {
           return
         }
       }
-      if(this.taskGLoading.length){
+      if (this.taskGLoading.length) {
         let _pan = 1
-        for(var k = 0; k < this.taskGLoading.length; k++){
-          if(this.taskGLoading[k] && (this.taskGLoading[k][0] || this.taskGLoading[k][1] || this.taskGLoading[k][2])){
+        for (var k = 0; k < this.taskGLoading.length; k++) {
+          if (this.taskGLoading[k] && (this.taskGLoading[k][0] || this.taskGLoading[k][1] || this.taskGLoading[k][2])) {
             this.$message({
-              message: `请等待任务${k+1}回答完毕后再继续`,
+              message: `请等待任务${k + 1}回答完毕后再继续`,
               type: "warning"
             });
             _pan = 2
           }
         }
-        if(_pan == 2){
+        if (_pan == 2) {
           return
         }
       }
-      let taskJson = this.unitJson[0].chapterInfo[0].taskJson
-      for(var index = 0; index < taskJson.length; index++){
-        for (var j = 0; j < taskJson[index].toolChoose.length; j++) {
-          if(this.panTaskElist() == 0 && this.pjIndex.indexOf(taskJson[index].toolChoose[j].tool[0]) != -1){
-            this.$refs['evalist'+index+j][0].openAiDialog('elist');
+      this.$confirm("是否一键生成所有工具的评价设置?会占用您一些时间。", "提示", {
+        confirmButtonText: "确定",
+        cancelButtonText: "取消",
+        type: "warning",
+        customClass: 'custom-confirm-box'
+      })
+        .then(() => {
+          
+          let taskJson = this.unitJson[0].chapterInfo[0].taskJson
+          for (var index = 0; index < taskJson.length; index++) {
+            for (var j = 0; j < taskJson[index].toolChoose.length; j++) {
+              if (this.panTaskElist() == 0 && this.pjIndex.indexOf(taskJson[index].toolChoose[j].tool[0]) != -1) {
+                this.$refs['evalist' + index + j][0].openAiDialog('elist');
+              }
+            }
           }
-        }
-      }
+        })
+        .catch(() => {
+
+        });
+      setTimeout(() => {
+        this.setTipsIndex()
+      }, 500)
     },
     setAiJson(pan,string,string2,string3){
       if(pan == 'aiTeacher2'){
@@ -17258,6 +17287,7 @@ ${_this.unitJson[0].chapterInfo[0].taskJson[index].taskDetail3.replaceAll('#',''
           this.courseTextB = true
         }
       }
+      this.interSetting = false
     },
     changeLang(){
       window.course_lang = this.languageSetting

+ 4 - 2
src/components/pages/aiAddCourse/aiBoxCourseDetail.vue

@@ -412,7 +412,7 @@ export default {
     languageSetting: {
       type: Number,
       default: 0
-    }
+    },
   },
   data() {
     return {
@@ -1411,7 +1411,9 @@ ${message}`;
 <style scoped>
 .ai_body {
   height: 100%;
-  width: calc(100% - 20px);
+  width: calc(100%);
+  padding: 0 20px 10px;
+  box-sizing: border-box;
   margin: 0 auto;
   display: flex;
   flex-direction: column;

+ 20 - 2
src/components/pages/aiAddCourse/record.vue

@@ -60,13 +60,23 @@
 
 <script>
 export default {
+    props: {
+        videoText2: {
+            type: String,
+            default: ''
+        },
+        audioUrl2: {
+            type: String,
+            default: ''
+        }
+    },
     data() {
         return {
-            videoText: "",
+            videoText: this.videoText2,
             recorderProvider: "microsoft",//shengyang
             uploadFileLoading: false,
             controlsStatus: 0,  //0--点击开始录音  1--录音中   2--录音完毕预览  3--文字输入
-            audioUrl: "",
+            audioUrl: this.audioUrl2,
             languageRadio: 2, //设置选择语言
             recordedForm: {
                 time: "00:00:00", //时间
@@ -85,6 +95,14 @@ export default {
             },
         }
     },
+    watch: {
+        videoText(newValue, oldValue) {
+            this.$emit('update:videoText2', newValue)
+        },
+        audioUrl(newValue, oldValue) {
+            this.$emit('update:audioUrl2', newValue)
+        }
+    },
     methods: {
         updateRecordedTime({ duration }) {
             // 更新currentTime,将秒数转换为时分秒格式

+ 161 - 286
src/components/pages/components/exportDataDialog.vue

@@ -1,7 +1,7 @@
 <template>
-  <div
-    class="pbl">
-    <div class="pdfCon" ref="reportPdf" v-loading="loading">
+  <div class="pbl">
+    <div class="pdfCon" ref="reportPdf" v-loading="loading" element-loading-text="小可正在生成报告,请稍等。"
+    element-loading-spinner="el-icon-loading">
       <div class="AiBtn" v-if="isDown">
         <div style="display: flex;">
           <el-button type="primary" size="small" @click="getAiAnalysisCon2"
@@ -346,7 +346,9 @@
             <li>素养发展情况</li>
           </div>
           <div class="suy">素养发展雷达图</div>
-          <div style="width: 100%; background-color: #fff;border-radius: 10px;border: 1px solid #ccc;">
+          <div
+            style="width: 100%; background-color: #fff;border-radius: 10px;border: 1px solid #ccc;"
+          >
             <div
               ref="moreChart"
               style="width: 85%;margin: auto; height: 400px"
@@ -399,7 +401,8 @@
       </div>
 
       <!-- 作业内容 -->
-      <div
+
+      <!-- <div
         v-for="i in workList"
         :key="i.id"
         v-if="isStage(i.taskList) && claV"
@@ -408,9 +411,7 @@
           backgroundColor: '#FFFBDC'
         }"
       >
-        <div class="stageTit">
-          第{{ i.id * 1 + 1 }}阶段<span v-if="i.name">:{{ i.name }}</span>
-        </div>
+        <div class="stageTit">{{ courseTit }}-作业集</div>
         <div
           v-for="k in i.taskList"
           :key="k.task + 'a'"
@@ -430,7 +431,6 @@
               <span>{{ k.taskTit }}</span>
             </div>
             <div>
-              <!-- <span class="toolTit">文档工具</span> -->
             </div>
           </div>
           <div v-if="k.taskDetail" class="taskBri">
@@ -832,9 +832,7 @@
                 <div>提交时间:{{ l.time }}</div>
               </div>
 
-              <!-- 作业评分 -->
               <div class="taskScoCon">
-                <!-- 分数详情与素养 -->
                 <div style="flex: 1; display: flex; flex-wrap: wrap">
                   <div style="width: 410px; margin:0 20px 10px 0">
                     <div class="taskScoConTit">分数详情</div>
@@ -893,7 +891,6 @@
                   </div>
                 </div>
 
-                <!-- 评语 -->
                 <div
                   style="
                         flex: 1;
@@ -912,14 +909,13 @@
               </div>
             </div>
           </div>
-          <!-- 思维导图 -->
           <div class="taskTitInd">
             <div></div>
             <span>任务评价体系</span>
           </div>
           <exjsmind :treeData="k.treeData" :keyL="k.task.toString()"></exjsmind>
         </div>
-      </div>
+      </div> -->
     </div>
   </div>
 </template>
@@ -1175,7 +1171,7 @@ export default {
           this.worksDialogCon2 = this.worksDialogCon;
 
           // 获取作业信息内容
-          this.exportPdfSet();
+          // this.exportPdfSet();
 
           // ai分析语言
           if (res.data[0][0].setting) {
@@ -1198,14 +1194,14 @@ export default {
 
           // 处理班级,查看学生有几个班级
           let stuCla = [];
-          // digNum0  导出单个作业集 digNum1导出所有任务
+          // digNum0 导出单个作业集 digNum1导出所有任务 2查看pdf
 
           if (this.digNum == 0) {
             if (this.multipleSelection[0].classid) {
               stuCla = this.multipleSelection[0].classid.split(",");
             }
           } else if (this.digNum == 1) {
-            this.getWorks1();
+            // this.getWorks1();
           } else {
             if (this.worksDialogCon.classid) {
               stuCla = this.worksDialogCon.classid.split(",");
@@ -1255,7 +1251,7 @@ export default {
     },
 
     // 获取处理作业信息
-    async exportPdfSet(uid, con) {
+    async exportPdfSet() {
       let params = {
         uid: this.worksDialogCon2.userid,
         cid: this.cid
@@ -1447,7 +1443,7 @@ export default {
                               children: [
                                 {
                                   id: kind + "+" + elind + "+" + stind + "b",
-                                  topic: `工具${elind*1 + 1}`
+                                  topic: `工具${elind * 1 + 1}`
                                 }
                               ]
                             });
@@ -1456,7 +1452,7 @@ export default {
                               if (lc.topic == st.detail) {
                                 lc.children.push({
                                   id: kind + "+" + elind + "+" + stind + "b",
-                                  topic: `工具${elind*1 + 1}`
+                                  topic: `工具${elind * 1 + 1}`
                                 });
                               }
                             });
@@ -1558,9 +1554,19 @@ export default {
             // this.getDataStageMode(data);
             // } else {
             this.getDataAiMode(data);
+
+            if (this.data10 && this.data10.length) {
+              let Asd = this.data10[0].jsonTxt;
+              this.AiAnalysisCon2 = JSON.parse(Asd);
+              this.AiAnalysisCon2Copy = JSON.parse(
+                JSON.stringify(this.AiAnalysisCon2)
+              );
+            }
             // }
 
             setTimeout(() => {
+              this.loading = false;
+
               return resolve();
             }, 1500);
           })
@@ -1791,11 +1797,6 @@ export default {
       this.loading = true;
       await this.getData();
       if (this.data10 && this.data10.length) {
-        let Asd = this.data10[0].jsonTxt;
-        this.AiAnalysisCon2 = JSON.parse(Asd);
-        this.AiAnalysisCon2Copy = JSON.parse(
-          JSON.stringify(this.AiAnalysisCon2)
-        );
       } else {
         this.$message.info("当前报告暂无分析结果,请先点击【AI分析】");
       }
@@ -1816,39 +1817,37 @@ export default {
         await this.getData();
 
         if (this.data10 && this.data10.length) {
-          let Asd = this.data10[0].jsonTxt;
-          this.AiAnalysisCon2 = JSON.parse(Asd);
+          this.loading = false;
+          this.isDown = false;
+          setTimeout(() => {
+            this.getPdf();
+          }, 500);
+        }else{
+          await this.getAiAnalysisCon2()
         }
-        this.loading = false;
-        this.isDown = false;
-        setTimeout(() => {
-          this.getPdf();
-        }, 500);
+
       } else {
         this.circulatePdf();
       }
     },
-    isGetPdf(){
+    isGetPdf() {
       this.$confirm("确定导出本次学生报告吗?", "提示", {
         confirmButtonText: "确定",
         cancelButtonText: "取消",
-        type: "warning",
+        type: "warning"
       })
         .then(() => {
           this.isDown = false;
           setTimeout(() => {
-            this.getPdf()
+            this.getPdf();
           }, 500);
         })
-        .catch(() => {
-         
-        });
+        .catch(() => {});
     },
     // 下载pdf文件
     async getPdf() {
       const content = this.$refs.reportPdf;
-      console.log('content',content.offsetHeight);
-      
+      console.log("content", content.offsetHeight);
 
       html2canvas(content)
         .then(canvas => {
@@ -2119,22 +2118,7 @@ export default {
         uid: this.userid,
         mind_map_question: ""
       };
-      // let params = {
-
-      //   assistant_id: 'b19f1a1a-7586-11ef-8ce0-12e77c4cb76b',
-      //   file_ids: [],
-      //   temperature: this.mode == 3 ? 0.5 : 0.1,
-      //   message: [
-      //     {
-      //       type: "text",
-      //       text: messages.replaceAll("\n", " ").replaceAll("*", "")
-      //     }
-      //   ],
-      //   session_name: uuidv4(),
-      //   userId: this.userid,
-      //   model: "gpt-4o-mini"
-      // };
-
+   
       return new Promise((resolve, reject) => {
         this.ajax
           .post("https://gpt4.cocorobo.cn/chat", params)
@@ -2260,20 +2244,6 @@ export default {
     5.**定期自我评估:** 定期对自己的学习成果进行自我评估,以确保学习目标与个人发展目标一致。    
     6.**学习策略优化:** 尝试不同的学习方法,如主动学习、可视化学习等,找到最适合自己的学习策略。    `;
 
-      // let params = {
-      //   assistant_id: "b19f1a1a-7586-11ef-8ce0-12e77c4cb76b",
-      //   message: [
-      //     {
-      //       type: "text",
-      //       text: messages.replaceAll("\n", " ").replaceAll("*", "")
-      //     }
-      //   ],
-      //   session_name: uuidv4(),
-      //   userId: this.userid,
-      //   file_ids: [],
-      //   model: "gpt-4o-mini",
-      //   temperature: this.mode == 3 ? 0.5 : 0.1
-      // };
       let params = {
         model: "gpt-4o-mini",
         temperature: this.mode == 3 ? 0.5 : 0.1,
@@ -2291,39 +2261,41 @@ export default {
         uid: this.userid,
         mind_map_question: ""
       };
-      this.ajax
+      return new Promise((resolve, reject) => {
+        this.ajax
         .post("https://gpt4.cocorobo.cn/chat", params)
         .then(response => {
-          // let data = response.data.FunctionResponse;
-          // console.log(data);
-
-          // let md = new MarkdownIt();
-
-          // if (data && data.message) {
-          //   let content = data.message;
-          //   this.AiAnalysisCon2.allFx = md.render(content);
-          // }
 
           let data = response.data.FunctionResponse;
           console.log("data", data);
-          let md = new MarkdownIt();
 
           if (data.choices && data.choices.length && data.choices[0].message) {
             let content = data.choices[0].message.content;
             this.AiAnalysisCon2.allFx = content.replaceAll("<br>", "");
           }
 
-          // console.log("data", data);
           this.loading = false;
           this.canvasLing.splice(6, 1, false);
 
+          if (this.digNum == 0) {
+            this.loading = false;
+            this.isDown = false;
+            setTimeout(() => {
+              this.getPdf();
+            }, 500);
+          }
+         
+
           this.uploadData();
+          return resolve(1)
         })
         .catch(error => {
           this.canvasLing.splice(6, 1, false);
 
           console.log(error);
         });
+      })
+      
     },
     // 处理学习行为记录ai分析数据
     async getAiAnalysisCon2() {
@@ -2397,16 +2369,17 @@ export default {
         forAllList.push(mkAwit);
       }
       Promise.all(forAllList)
-        .then(values => {
-          // console.log(" this.AiAnalysisCon2", this.AiAnalysisCon2);
-          for (let index = 0; index < values.length; index++) {
-            this.canvasLing.splice(index, 1, false);
-          }
-          this.updateFx();
-        })
-        .catch(reason => {
-          console.error("reason", reason);
-        });
+      .then(async values => {
+        // console.log(" this.AiAnalysisCon2", this.AiAnalysisCon2);
+        for (let index = 0; index < values.length; index++) {
+          this.canvasLing.splice(index, 1, false);
+        }
+         this.updateFx();
+      })
+      .catch(reason => {
+        console.error("reason", reason);
+      });
+     
     },
     // 上传ai分析
     uploadData() {
@@ -2480,7 +2453,6 @@ export default {
           }
           this.courseName = this.tableData[0].course;
           this.circulatePdf();
-          // console.log(res.data[0]);
         })
         .catch(err => {
           this.isLoading = false;
@@ -2492,13 +2464,28 @@ export default {
       let _this = this;
       var zip = new JSZip();
       let pdfList = [];
+      this.isDown = false;
+
       for (let i = 0; i < this.tableData.length; i++) {
         this.loading = true;
 
+        let stuCla = "";
+        let ClaNam = "";
+        this.claOptions = [];
+        this.claV = "——";
+
+        if (this.tableData[i].classid) {
+          stuCla = this.tableData[i].classid.split(",");
+          ClaNam = this.tableData[i].class.split(",");
+          this.claV = stuCla[0];
+          this.claOptions.push({ value: stuCla[0], label: ClaNam[0] });
+        } 
         this.uid2 = this.tableData[i].userid;
         this.worksDialogCon2 = this.tableData[i];
+
+        // await this.exportPdfSet();
         await this.getData();
-        this.loading = false;
+
         let a = await this.getPdf2();
         pdfList.push(a);
       }
@@ -2512,49 +2499,83 @@ export default {
         // 使用FileSaver保存压缩包
         saveAs(content, _this.courseTit + "-学生报告汇总.zip");
       });
+      this.isDown = true;
 
       this.$emit("update:worksDialog", false);
       // this.worksDialog = false;
     },
     // 压缩pdf
     async getPdf2() {
-      let domHeight = this.$refs.reportPdf.offsetHeight;
-      // console.log('this.$refs.reportPdf',this.$refs.reportPdf.offsetHeight);
-      let maxHeight = 64257;
+      const content = this.$refs.reportPdf;
+      console.log("content", content.offsetHeight);
+
       return new Promise((resolve, reject) => {
-        html2canvas(this.$refs.reportPdf, {
-          useCORS: true, // 如果截图的内容里有图片,可能会有跨域的情况,加上这个参数,解决文件跨域问题
-          scale: maxHeight / domHeight > 1 ? 1 : maxHeight / domHeight
-        })
-          .then(canvas => {
-            const contentWidth = canvas.width;
-            const contentHeight = canvas.height;
-
-            var pageData = canvas.toDataURL("image/jpeg", 1.0);
-
-            var pdf = new jspdf("", "pt", [contentWidth, contentHeight]);
-
-            //有两个高度需要区分,一个是html页面的实际高度,和生成pdf的页面高度(841.89)
-            //当内容未超过pdf一页显示的范围,无需分页
-            // if (leftHeight < pageHeight) {
-            pdf.addImage(pageData, "JPEG", 0, 0, contentWidth, contentHeight);
-
-            var pdfData = {
-              pdfName:
-                this.worksDialogCon2.course +
-                "-作业集-" +
-                this.worksDialogCon2.sName +
-                ".pdf",
-              pdfCon: pdf.output("blob")
-            };
-            // pdfArray.push(pdfData);
-
-            return resolve(pdfData);
-          })
-          .catch(err => {
-            console.log(err);
-          });
+        html2canvas(content).then(canvas => {
+          const imgData = canvas.toDataURL("image/png");
+          const pdf = new jspdf("p", "pt", [
+            content.offsetWidth,
+            content.offsetHeight
+          ]);
+
+          pdf.addImage(
+            imgData,
+            "PNG",
+            0,
+            0,
+            content.offsetWidth,
+            content.offsetHeight
+          );
+          var pdfData = {
+            pdfName:
+              this.worksDialogCon2.course +
+              "-作业集-" +
+              this.worksDialogCon2.sName +
+              ".pdf",
+            pdfCon: pdf.output("blob")
+          };
+          return resolve(pdfData);
+        });
+      }).catch(err => {
+        console.log(err);
       });
+
+      // let domHeight = this.$refs.reportPdf.offsetHeight;
+      // // console.log('this.$refs.reportPdf',this.$refs.reportPdf.offsetHeight);
+      // let maxHeight = 64257;
+      // return new Promise((resolve, reject) => {
+      //   html2canvas(this.$refs.reportPdf, {
+      //     useCORS: true, // 如果截图的内容里有图片,可能会有跨域的情况,加上这个参数,解决文件跨域问题
+      //     scale: maxHeight / domHeight > 1 ? 1 : maxHeight / domHeight
+      //   })
+      //     .then(canvas => {
+      //       const contentWidth = canvas.width;
+      //       const contentHeight = canvas.height;
+
+      //       var pageData = canvas.toDataURL("image/jpeg", 1.0);
+
+      //       var pdf = new jspdf("", "pt", [contentWidth, contentHeight]);
+
+      //       //有两个高度需要区分,一个是html页面的实际高度,和生成pdf的页面高度(841.89)
+      //       //当内容未超过pdf一页显示的范围,无需分页
+      //       // if (leftHeight < pageHeight) {
+      //       pdf.addImage(pageData, "JPEG", 0, 0, contentWidth, contentHeight);
+
+      //       var pdfData = {
+      //         pdfName:
+      //           this.worksDialogCon2.course +
+      //           "-作业集-" +
+      //           this.worksDialogCon2.sName +
+      //           ".pdf",
+      //         pdfCon: pdf.output("blob")
+      //       };
+      //       // pdfArray.push(pdfData);
+
+      //       return resolve(pdfData);
+      //     })
+      //     .catch(err => {
+      //       console.log(err);
+      //     });
+      // });
     },
 
     // ai模式处理数据
@@ -2659,8 +2680,6 @@ export default {
 
     // 编辑
     extCon(val) {
-      console.log("extCon");
-
       this.exitCon.splice(val, 1, false);
     },
     // 确定
@@ -3853,155 +3872,6 @@ export default {
       done();
     }
 
-    //#region
-    // 获取文档id
-    // async createFileid(url) {
-    //   let _this = this;
-    //   return new Promise((resolve, reject) => {
-    //     try {
-    //       _this.ajax
-    //         .put("https://gpt4.cocorobo.cn/upload_file_knowledge", {
-    //           url: url
-    //         })
-    //         .then(res => {
-    //           let _data = res.data.FunctionResponse;
-    //           if (_data.result && _data.result.id) {
-    //             resolve(_data.result.id);
-    //           } else {
-    //             resolve(1);
-    //           }
-    //         })
-    //         .catch(function(error) {
-    //           resolve(1);
-    //         });
-    //     } catch (e) {
-    //       resolve(1);
-    //     }
-    //   });
-    // },
-
-    // 截图
-    //  async capture() {
-    //   await html2canvas(this.$refs.moreChart, {
-    //     useCORS: true // 如果截图的内容里有图片,可能会有跨域的情况,加上这个参数,解决文件跨域问题
-    //   }).then(canvas => {
-    //     const imgUrl = canvas.toDataURL("images/png");
-    //     let base64Data = imgUrl.split(",")[1];
-    //     let binaryData = atob(base64Data);
-    //     let uint8Array = new Uint8Array(binaryData.length);
-    //     for (let i = 0; i < binaryData.length; i++) {
-    //       uint8Array[i] = binaryData.charCodeAt(i);
-    //     }
-    //     // 获取blob文件流
-    //     let blob = new Blob([uint8Array], { type: "image/png" });
-    //     // 文件流转文件
-    //     let file = new File([blob], "filename.png", {
-    //       type: "image/png"
-    //     });
-    //     let a = this.beforeUpload(file);
-    //     this.suImg = a;
-    //   });
-
-    // html2canvas(this.$refs.jsm, {
-    //   useCORS: true // 如果截图的内容里有图片,可能会有跨域的情况,加上这个参数,解决文件跨域问题
-    // }).then(canvas => {
-    //   const imgUrl = canvas.toDataURL("images/png");
-    //   let base64Data = imgUrl.split(",")[1];
-    //   let binaryData = atob(base64Data);
-    //   let uint8Array = new Uint8Array(binaryData.length);
-    //   for (let i = 0; i < binaryData.length; i++) {
-    //     uint8Array[i] = binaryData.charCodeAt(i);
-    //   }
-    //   // 获取blob文件流
-    //   let blob = new Blob([uint8Array], { type: "image/png" });
-    //   // 文件流转文件
-    //   let file = new File([blob], "filename.png", {
-    //     type: "image/png",
-    //   });
-    //   let a = this.beforeUpload(file)
-    //   this.suImg.push(a)
-
-    // });
-    // },
-    // 上传图片
-    // beforeUpload(file) {
-    //   // const loading = this.openLoading();
-    //   // var file = "";
-
-    //   // for (let cfindex = 0; cfindex < event.target.files.length; cfindex++) {
-    //   // console.log("event.target.files", event.target.files);
-    //   // file = event.target.files[cfindex];
-    //   var credentials = {
-    //     accessKeyId: "AKIATLPEDU37QV5CHLMH",
-    //     secretAccessKey: "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"
-    //   }; //秘钥形式的登录上传
-    //   window.AWS.config.update(credentials);
-    //   window.AWS.config.region = "cn-northwest-1"; //设置区域
-
-    //   var bucket = new window.AWS.S3({ params: { Bucket: "ccrb" } }); //选择桶
-    //   var imgA = [
-    //     "png",
-    //     "jpg",
-    //     "jpeg",
-    //     "bmp",
-    //     "gif",
-    //     "webp",
-    //     "psd",
-    //     "svg",
-    //     "tiff"
-    //   ];
-    //   if (
-    //     imgA.indexOf(file.name.split(".")[file.name.split(".").length - 1]) ==
-    //     -1
-    //   ) {
-    //     this.$message.error("图片格式错误");
-    //     return;
-    //   }
-    //   this.imgLoading = true;
-    //   var _this = this;
-
-    //   this.inputShow = false;
-    //   this.progress = 0;
-    //   this.proVisible = true;
-    //   this.isFinishSize = 0;
-    //   this.isAllSize = (file.size / 1024 / 1024).toFixed(2);
-    //   _this.$forceUpdate();
-
-    //   if (file) {
-    //     var params = {
-    //       Key:
-    //         file.name.split(".")[0] +
-    //         new Date().getTime() +
-    //         "." +
-    //         file.name.split(".")[file.name.split(".").length - 1],
-    //       ContentType: file.type,
-    //       Body: file,
-    //       "Access-Control-Allow-Credentials": "*",
-    //       ACL: "public-read"
-    //     }; //key可以设置为桶的相抵路径,Body为文件, ACL最好要设置
-    //     var options = {
-    //       partSize: 2048 * 1024 * 1024,
-    //       queueSize: 2,
-    //       leavePartsOnError: true
-    //     };
-    //     bucket
-    //       .upload(params, options)
-    //       .on("httpUploadProgress", function(evt) {
-    //         //这里可以写进度条
-    //       })
-    //       .send(function(err, data) {
-    //         if (err) {
-    //           _this.$message.error("上传失败");
-    //         } else {
-    //           console.log(data.Location);
-
-    //           return data.Location;
-    //         }
-    //       });
-    //   }
-    //   // }
-    // },
-
     // 阶段模式处理数据
     // getDataStageMode(data) {
     //   data.forEach((e, eInd) => {
@@ -4341,13 +4211,19 @@ export default {
   height: 100%;
   box-sizing: border-box;
   margin: auto;
-  background-color: #F3F7FD;
+  background-color: #f3f7fd;
   box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
   /* padding: 20px; */
   /* padding-top: 10px; */
   overflow: auto;
   border-radius: 10px;
-  position: relative
+  position: relative;
+}
+.pbl >>> .el-loading-spinner{
+  top: 500px !important;
+}
+.zxt >>> .el-loading-spinner{
+  top: 50% !important;
 }
 .pdfCon {
   width: 810pt;
@@ -4790,8 +4666,8 @@ export default {
   font-weight: 600;
   font-size: 20px;
   margin-bottom: 20px;
-  color: rgba(242, 161, 75, 1);
-  border-left: 5px rgba(242, 161, 75, 1) solid;
+  color: #605449;
+  /* border-left: 5px 605449 solid; */
   padding-left: 5px;
 }
 .taskTitInd {
@@ -4864,7 +4740,6 @@ export default {
   font-weight: 400;
   line-height: 30px;
   padding: 0 10px;
-
 }
 .taskSco {
   background-color: rgba(253, 247, 243, 1);
@@ -4954,7 +4829,7 @@ export default {
   padding: 3px 10px;
   margin: 0 8px;
 }
-.taskCon{
+.taskCon {
   margin-bottom: 15px;
   background-color: #fff;
   padding: 20px;

+ 404 - 0
src/components/pages/components/lookReport.vue

@@ -0,0 +1,404 @@
+<template>
+  <div>
+    <div
+      style="display: flex;align-items: center;padding-bottom: 15px;font-size: 14px;color: rgba(0, 0, 0, 0.4);"
+    >
+      <span @click="pageBack" style="height: 100%;cursor: pointer;"
+        >评价管理</span
+      >
+      <span style="margin: 0 5px;">
+        <i class="el-icon-arrow-right"></i>
+      </span>
+      <span @click="pageBack" style="height: 100%;cursor: pointer;"
+        >查看课程</span
+      >
+      <span style="margin: 0 5px;">
+        <i class="el-icon-arrow-right"></i>
+      </span>
+      <div style="font-weight: 600;color: rgba(0, 0, 0, 0.9);">
+        {{ checkCourse.title }}-查看报告
+      </div>
+    </div>
+
+    <div class="JsonTit">
+      <div
+        style="width:94%;margin: 0 auto;font-size: 26px;color: rgba(0, 0, 0, 0.9);"
+      >
+        {{ checkCourse.title }}
+      </div>
+      <div class="JsonTitBtn">
+        <el-button
+          v-if="checkCourse.state == 5"
+          @click="exportWorkPdf"
+          type="primary"
+          size="small"
+          >一键导出</el-button
+        >
+        <el-button
+          style="margin-left: 20px;"
+          @click="pageBack"
+          type="primary"
+          size="small"
+          >返回</el-button
+        >
+      </div>
+    </div>
+
+    <div
+      class="student_search"
+      style="margin-bottom: 10px;justify-content: space-between;width: 94%;margin:30px auto;"
+    >
+      <div
+        style="display: flex;justify-content: space-between;align-items: center;width: 650px;"
+      >
+        <div style="margin-right: 10px;">筛选</div>
+        <div>
+          <el-select
+            class="r_select"
+            v-model="uClass"
+            placeholder="请选择班级"
+            filterable
+            @change="searchWork2"
+          >
+            <el-option label="所有班级" value></el-option>
+            <el-option
+              v-for="item in classAarray"
+              :key="item.id"
+              :label="item.name"
+              :value="item.id"
+            ></el-option>
+          </el-select>
+        </div>
+
+        <el-select
+          class="r_select"
+          v-model="uname"
+          placeholder="请选择学生"
+          @change="searchWork2"
+        >
+          <el-option label="所有学生" value></el-option>
+          <el-option
+            v-for="item in userAarray"
+            :key="item.userid"
+            :label="item.sName"
+            :value="item.userid"
+          >
+          </el-option>
+        </el-select>
+
+        <div class="typeCheck">
+          <el-switch v-model="typeCheckN"></el-switch
+          ><span style="font-size: 14px;">查看所有学生</span>
+        </div>
+      </div>
+    </div>
+    <div class="TableCss">
+      <el-table
+        v-loading="isLoading2"
+        ref="multipleTable"
+        :data="lookReportTab"
+        :fit="true"
+        style="width: 100%"
+        :header-cell-style="{ background: 'rgb(238,238,238)' }"
+      >
+        <el-table-column
+          prop="sName"
+          label="姓名"
+          min-width="20"
+          align="center"
+        ></el-table-column>
+        <el-table-column
+          label="班级"
+          min-width="20"
+          show-overflow-tooltip
+          align="center"
+        >
+          <template slot-scope="scope">
+            <div class="ellipsis">
+              {{ scope.row.class ? scope.row.class : "-" }}
+            </div>
+          </template>
+        </el-table-column>
+        <el-table-column align="center" label="操作" min-width="20">
+          <template slot-scope="scope">
+            <el-button
+              v-if="checkCourse.state == 5"
+              type="primary"
+              size="small"
+              @click="lookPdf(scope.row)"
+              >查看报告</el-button
+            >
+            <el-button
+              v-else
+              type="primary"
+              size="small"
+              @click="getReport(scope.row)"
+              >查看报告</el-button
+            >
+            <el-button
+              v-if="checkCourse.state == 5"
+              type="primary"
+              size="small"
+              @click="getPdf(scope.row)"
+              >导出报告</el-button
+            >
+          </template>
+        </el-table-column>
+      </el-table>
+      <div
+        v-if="!typeCheckN"
+        style="display: flex;justify-content: space-between; padding:15px 0"
+      >
+        <el-pagination
+          background
+          layout="prev, pager, next"
+          :page-size="10"
+          :total="total2"
+          @current-change="handleCurrentChange2"
+        ></el-pagination>
+        <div style="display: flex;" class="dialog-footer"></div>
+      </div>
+    </div>
+
+
+    <!-- ai查看报告 -->
+    <el-dialog
+      :visible.sync="worksDialog"
+      :before-close="handleClose"
+      class="worksDialogCSSExp"
+      style="overflow: hidden;"
+      :append-to-body="true"
+      :fullscreen="true"
+    >
+      <div slot="title" class="header-title">
+        <div style="color: #fff">{{ this.digNum == 2 ?'查看':'导出' }}报告</div>
+      </div>
+      <exportDataDialog  
+        v-if="checkCourse.state == 5"
+        :key="exportW" 
+        :digNum="digNum"
+        :oid="oid" 
+        :multipleSelection="multipleSelection" 
+        :worksDialogCon="worksDialogCon" 
+        :worksDialog.sync="worksDialog" 
+        :cid="checkCourse.courseId">
+      </exportDataDialog>
+
+      <div v-else style="padding: 10px 30px;box-sizing: border-box;">
+        <studentReport
+            :checkCourse="checkCourse.courseId"
+            :checkStudent="checkStudent"
+            @cancelR="cancelR"
+            :oid="oid"
+        ></studentReport>
+      </div>
+    </el-dialog>
+
+
+    <!-- 非ai查看报告
+    <div class="report_box" v-if="reportVisible">
+        <studentReport
+            :checkCourse="checkCourse.courseId"
+            :checkStudent="checkStudent"
+            @cancelR="cancelR"
+            :oid="oid"
+        ></studentReport> 
+    </div> -->
+  </div>
+</template>
+
+<script>
+import exportDataDialog from "./exportDataDialog.vue";
+import studentReport from "./studentReport.vue";
+
+export default {
+  props: ["signDialog", "checkCourse","oid"],
+  components: {
+    exportDataDialog,
+    studentReport
+  },
+  data() {
+    return {
+      // 查看报告table数据
+      lookReportTab: [],
+      exportW:0,
+      multipleSelection:[],
+      worksDialog:false,
+      digNum:0,
+      reportVisible: false,
+      checkStudent:'',
+      userAarray: [],
+      classAarray: [],
+      uname: "",
+      uClass: "",
+      typeCheckN: false,
+      page2: 1,
+      total2: 0,
+      isLoading2: false,
+      worksDialogCon:{}
+    };
+  },
+  mounted() {
+    this.getStudnet2();
+  },
+  watch: {
+    typeCheckN(newValue, oldValue) {
+      this.getStudnet2();
+    },
+    signDialog(newValue, oldValue) {
+      this.getStudnet2();
+    }
+  },
+  methods: {
+    // ai查看报告
+    lookPdf(val){
+      this.worksDialogCon=val
+      this.worksDialog = true;
+      this.digNum = 2
+      this.exportW++
+    },
+    // 一键导出
+    exportWorkPdf() {
+        this.worksDialog = true;
+        this.digNum = 1
+        this.exportW++
+    },
+    // 导出报告
+    getPdf(val) {
+
+        this
+        .$confirm("直接导出报告需要占用您一些时间,是否导出?", "提示", {
+          confirmButtonText: "确认",
+          cancelButtonText: "取消",
+          type: "warning",
+        })
+        .then(() => {
+            console.log('val',val);
+
+            this.worksDialogCon=val
+            this.worksDialog = true;
+
+            this.multipleSelection = []
+            this.multipleSelection.push(val)
+            this.digNum = 0
+            this.exportW++
+        })
+        .catch((err) => {
+            console.log(err);
+        });
+        
+
+    },
+    // 关闭弹框返回查看课程
+    pageBack() {
+      this.$emit("update:signDialog", false);
+    },
+
+    getStudnet2() {
+      this.isLoading2 = true;
+
+      let params = {
+        cid: this.checkCourse.courseId,
+        uCla: this.uClass,
+        uname: this.uname,
+        tck: this.typeCheckN ? 1 : 2,
+        stage: "",
+        task: "",
+        page: this.page2
+      };
+      // 获取学生列表
+      this.ajax
+        .get(this.$store.state.api + "getCourseWorks3Copy1", params)
+        .then(res => {
+          this.isLoading2 = false;
+          this.total2 = res.data[0].length > 0 ? res.data[0][0].num : 0;
+          this.lookReportTab = res.data[0];
+          this.userAarray = res.data[1];
+          this.classAarray = res.data[2];
+        })
+        .catch(err => {
+          this.isLoading2 = false;
+          console.error(err);
+        });
+    },
+    // 非ai查看报告
+    getReport(row) {
+      this.checkStudent = row.userid;
+      this.worksDialog = true;
+      // this.signDialog = false;
+    },
+    cancelR() {
+      this.checkStudent = "";
+      this.worksDialog = false;
+      // this.signDialog = true;
+    },
+
+    // 分页切换
+    handleCurrentChange2(val) {
+      this.page2 = val;
+      this.getStudnet2();
+    },
+
+    // 查看报告筛选班级
+    searchWork2() {
+      this.page2 = 1;
+      this.getStudnet2();
+    },
+    handleClose(done) {
+      done();
+    },
+   
+  }
+};
+</script>
+
+<style scoped>
+.TableCss {
+  width: 94%;
+  margin: auto;
+}
+.TableCss >>> .el-table__header-wrapper .el-table__header .el-checkbox {
+  display: none;
+}
+.JsonTit {
+  width: 100%;
+  padding: 20px 0;
+  display: flex;
+  justify-content: space-between;
+  align-items: center;
+}
+.JsonTitBtn {
+  display: flex;
+  align-items: center;
+}
+.typeCheck {
+  display: flex;
+  align-items: center;
+  justify-content: flex-end;
+  margin-left: 10px;
+  /* margin-bottom: 20px; */
+}
+.typeCheck > span {
+  margin-left: 10px;
+}
+
+
+
+.worksDialogCSSExp>>> .el-dialog__header {
+  /* padding: 9px 20px 10px; */
+  background: #32455b !important;
+}
+
+.worksDialogCSSExp >>> .el-dialog__wrapper{
+  overflow: hidden !important;
+}
+.worksDialogCSSExp >>> .el-dialog__body {
+  width: 100% !important;
+  padding: 0 !important;
+  height: calc(100% - 48px);
+  overflow: auto;
+}
+.worksDialogCSSExp >>> .el-dialog.is-fullscreen {
+  overflow: hidden;
+}
+</style>

+ 220 - 118
src/components/pages/works.vue

@@ -104,7 +104,7 @@
             <el-input
               v-model="cn"
               placeholder="筛选课程名称"
-              @input="search"
+              @change="search"
             ></el-input>
           </div>
 
@@ -123,7 +123,7 @@
               <el-input
                 v-model="cn"
                 placeholder="筛选学生名称"
-                @input="search"
+                @change="search"
               ></el-input>
           </div>
           <!-- <div
@@ -271,7 +271,7 @@
           </el-table>
          
         </div>
-        <div v-if="!isLoading" class="student_page">
+        <div class="student_page">
           <el-pagination
             background
             layout="prev, pager, next"
@@ -341,56 +341,101 @@
       </div>
       <span slot="footer" class="dialog-footer"> </span>
     </el-dialog>
+
+
+
+    <!-- 查看报告弹框新版全屏页面 -->
+
     <el-dialog
-      title="选择学生"
       :visible.sync="signDialog"
       width="500px"
       :before-close="handleClose"
-      class="dialog_diy check_diy"
+      class="lookWorksDialogCSSExp"
+      style="overflow: hidden;"
+      :append-to-body="true"
+      :fullscreen="true"
     >
-      <div>
-        <div class="student_search" style="margin-bottom: 10px;justify-content: space-between;">
+        <div slot="title" class="header-title">
+          <div style="color: #fff">查看报告</div>
+        </div>
+        <!-- <div style="display: flex;align-items: center;padding-bottom: 15px;font-size: 14px;color: rgba(0, 0, 0, 0.4);">
+          <span @click="pageBack" style="height: 100%;cursor: pointer;">评价管理</span>
+          <span style="margin: 0 5px;">
+            <i class="el-icon-arrow-right"></i>
+          </span>
+          <span @click="pageBack" style="height: 100%;cursor: pointer;">查看课程</span>
+          <span style="margin: 0 5px;">
+            <i class="el-icon-arrow-right"></i>
+          </span>
+          <div style="font-weight: 600;color: rgba(0, 0, 0, 0.9);">{{ checkCourse.title }}-查看报告</div>
+        </div>
+
+        <div class="JsonTit">
+          <div style="width:94%;margin: 0 auto;font-size: 26px;color: rgba(0, 0, 0, 0.9);">{{ checkCourse.title }}</div>
+          <div class="JsonTitBtn">
+            <el-button v-if="checkCourse.state == 5" @click="exportWorkPdf" type="primary" size="small"
+              >一键导出</el-button
+            >
+            <el-button style="margin-left: 20px;" @click="pageBack" type="primary" size="small">返回</el-button>
+          </div>
+        </div>
+
+        <div class="student_search" style="margin-bottom: 10px;justify-content: space-between;width: 94%;margin:30px auto;">
           <div style="display: flex;justify-content: space-between;">
             <div style="margin-right: 10px;">筛选</div>
             <div>
               <el-select
                 class="r_select"
-                v-model="uname"
+                v-model="uClass"
                 placeholder="请选择班级"
                 filterable
                 @change="searchWork2"
               >
                 <el-option label="所有班级" value></el-option>
                 <el-option
-                  v-for="item in userAarray"
+                  v-for="item in classAarray"
                   :key="item.id"
                   :label="item.name"
                   :value="item.id"
                 ></el-option>
               </el-select>
             </div>
+
+            <el-select
+              class="r_select"
+              v-model="uname"
+              placeholder="请选择学生"
+              @change="searchWork2"
+            >
+              <el-option label="所有学生" value></el-option>
+              <el-option
+                v-for="item in userAarray"
+                :key="item.userid"
+                :label="item.sName"
+                :value="item.userid"
+              >
+              </el-option>
+            </el-select>
+
+            <div class="typeCheck">
+              <el-switch v-model="typeCheckN"></el-switch
+              ><span style="font-size: 14px;">查看所有学生</span>
+            </div>
           </div>
-          
-          <!-- <el-button size="small" @click="exportPdfSetAllBtn" type="primary">一键导出</el-button> -->
-          
         </div>
         <div class="TableCss">
           <el-table
             v-loading="isLoading2"
             ref="multipleTable"
-            :data="res2"
+            :data="lookReportTab"
             border
-            :height="400"
             :fit="true"
             style="width: 100%"
             :row-class-name="tableRowClassName"
             :header-cell-style="{ background: 'rgb(238,238,238)' }"
               @selection-change="handleSelectionChange"
           >
-            <el-table-column
-              type="selection"
-              width="55">
-            </el-table-column>
+         
             <el-table-column
               prop="sName"
               label="姓名"
@@ -410,7 +455,7 @@
             <el-table-column align="center" label="操作" min-width="20">
               <template  slot-scope="scope">
                 <el-button
-                  v-if="checkState == 5"
+                  v-if="checkCourse.state == 5"
                   type="primary"
                   size="small"
                   @click="lookPdf(scope.row)"
@@ -423,11 +468,18 @@
                   @click="getReport(scope.row)"
                   >查看报告</el-button
                 >
+                <el-button
+                  v-if="checkCourse.state == 5"
+                  type="primary"
+                  size="small"
+                  @click="getPdf"
+                  >导出报告</el-button
+                >
               </template>
               
             </el-table-column>
           </el-table>
-          <div style="display: flex;justify-content: space-between; padding:15px 0">
+          <div v-if="!typeCheckN" style="display: flex;justify-content: space-between; padding:15px 0">
             <el-pagination
               background
               layout="prev, pager, next"
@@ -435,19 +487,19 @@
               :total="total2"
               @current-change="handleCurrentChange2"
             ></el-pagination>
-             <div style="display: flex;"  class="dialog-footer">
-              <el-button @click="exportPdfSetBtn" size="small" style="padding: 6px 18px;" type="primary">导出</el-button>
-
-              <el-button  style="margin-left: 10px;padding: 6px 18px;" size="small" @click="signDialog = false">关闭</el-button>
-            </div>
+            <div style="display: flex;"  class="dialog-footer"> </div>
           </div>
-        </div>
-      </div>
+        </div> -->
+
+        <lookReport  :oid="oid" @getReport="getReport"  :key="signDialog" :signDialog.sync="signDialog" :checkCourse="checkCourse"></lookReport>
      
     </el-dialog>
+
+
+
     <div class="report_box" v-if="reportVisible">
       <studentReport
-        :checkCourse="checkCourse"
+        :checkCourse="checkCourse.courseId"
         :checkStudent="checkStudent"
         @cancelR="cancelR"
         :oid="oid"
@@ -455,7 +507,6 @@
     </div>
 
     <el-dialog
-      title="文件预览"
       :visible.sync="worksDialog"
       :before-close="handleClose"
       class="worksDialogCSSExp"
@@ -473,12 +524,10 @@
         :multipleSelection="multipleSelection" 
         :worksDialogCon="worksDialogCon" 
         :worksDialog.sync="worksDialog" 
-        :cid="checkCourse">
+        :cid="checkCourse.courseId">
       </exportDataDialog>
     </el-dialog>
-    <!-- <div class="cancelbox" v-if="reportVisible">
-      <el-button @click="cancelR" type="primary" size="small">返回</el-button>
-    </div> -->
+   
   </div>
 </template>
 
@@ -489,7 +538,7 @@ import studentReport from "./components/studentReport";
 import "../../common/aws-sdk-2.235.1.min.js";
 import StudentWorksDetail from "./components/studentWorksDetail.vue";
 import exportDataDialog from "./components/exportDataDialog.vue";
-
+import lookReport from './components/lookReport'
 
 export default {
   components: {
@@ -497,7 +546,8 @@ export default {
     Report,
     studentReport,
     StudentWorksDetail,
-    exportDataDialog
+    exportDataDialog,
+    lookReport
   },
   data() {
     return {
@@ -536,18 +586,22 @@ export default {
       isLoading2: false,
       page2: 1,
       total2: 0,
-      res2: [],
+      // 查看报告table数据
+      lookReportTab: [],
       checkCourse: "",
-      checkState: "",
 
       reportVisible: false,
       checkStudent: "",
       userAarray: [],
+      classAarray:[],
       uname: "",
+      uClass:'',
       cutTabNum:0,
       tableData:[],
       dialogVisibleS:false,
-      multipleSelection: []
+      multipleSelection: [],
+
+      typeCheckN: false
     };
   },
   mounted() {
@@ -568,10 +622,14 @@ export default {
       };
     });
   },
+  watch: {
+    typeCheckN(newValue, oldValue) {
+        this.getStudnet()
+    },
+  },
   methods: {
-    // clearSelection() {
-    //     this.$refs.multipleTable.clearSelection();
-    // },
+
+
     handleSelectionChange(val) {
       if (val.length > 1) {
       this.$refs.multipleTable.clearSelection(); //清空列表的选中
@@ -583,41 +641,12 @@ export default {
             this.multipleSelection = []; //this.multipleTable是选中行的最后一条数据
       }
     },
-    lookPdf(val){
-      this.worksDialogCon=val
-      this.worksDialog = true;
-      this.digNum = 2
-      this.exportW++
-    },
-    // 导出pdf
-    exportPdfSetBtn(){
-      this.worksDialog = true;
-      this.digNum = 0
-      this.exportW++
-      
-    },
-    // 一键导出pdf
-    exportPdfSetAllBtn(){
+    
 
-      this.$confirm("是否导出全部学生报告?批量导出需要等待一会儿哦~ 。", "提示", {
-        confirmButtonText: "确定",
-        cancelButtonText: "取消",
-        type: "warning",
-      })
-      .then(() => {
-        this.worksDialog = true;
-        this.digNum = 1
-        this.exportW++
-      })
-      .catch(_ => {
-        this.$confirm.visible=false
-      })
-     
-      
-    },
     goTo(path) {
       this.$router.push(path);
     },
+    // 按学生查看所有学生
     getAllStudent() {
       this.isLoading = true;
       let params = {
@@ -640,6 +669,7 @@ export default {
           console.error(err);
         });
     },
+    // 切换按学生查看,按课程查看
     cutTabBtn(val){
       this.page = 1
       this.cn=''
@@ -692,6 +722,10 @@ export default {
     //       console.error(err);
     //     });
     // },
+
+
+
+    // 按课程查看所有数据
     getProject() {
       this.isLoading = true;
       let params = {
@@ -760,41 +794,19 @@ export default {
     cancelR() {
       this.checkStudent = "";
       this.reportVisible = false;
-      this.signDialog = true;
+      // this.signDialog = true;
     },
-    searchWork2() {
-      this.page2 = 1
-      this.getStudnet();
-    },
-   
-    // 显示查看报告弹框(小弹框)
+
+    // 显示查看报告弹框
     getStudnet(row) {
-    
+      
       //获取作业
       this.signDialog = true;
       this.isLoading2 = true;
-      this.checkCourse = row ? row.courseId : this.checkCourse;
-      this.checkState = row.state
-      this.getCourseDetail();
-      let params = {
-        cid: this.checkCourse,
-        uname: this.uname,
-        stage: "",
-        task: "",
-        page: this.page2,
-      };
-      // 获取学生列表
-      this.ajax
-        .get(this.$store.state.api + "getCourseWorks3Copy", params)
-        .then((res) => {
-          this.isLoading2 = false; 
-          this.total2 = res.data[0].length > 0 ? res.data[0][0].num : 0;
-          this.res2 = res.data[0];
-        })
-        .catch((err) => {
-          this.isLoading2 = false;
-          console.error(err);
-        });
+      this.checkCourse = row ? row : this.checkCourse;
+
+      // this.getCourseDetail();
+     
     },
     downloadFile(url){
       var credentials = {
@@ -841,36 +853,25 @@ export default {
     // 获取查看报告班级
     getCourseDetail() {
       let params = {
-        cid: this.checkCourse,
+        cid: this.checkCourse.courseId,
       };
       this.ajax
         .get(this.$store.state.api + "getCourseReportClassList", params)
         .then((res) => {
-          this.userAarray = res.data[0];
+          this.classAarray = res.data[0];
         })
         .catch((err) => {
           console.error(err);
         });
     },
+    // 查看报告
     getReport(row) {
       this.checkStudent = row.userid;
       this.reportVisible = true;
-      this.signDialog = false;
+      // this.signDialog = false;
     },
 
-    // getClass() {
-    //   let params = {
-    //     oid: this.oid,
-    //   };
-    //   this.ajax
-    //     .get(this.$store.state.api + "selectClassBySchool", params)
-    //     .then((res) => {
-    //       this.classJuri = res.data[0];
-    //     })
-    //     .catch((err) => {
-    //       console.error(err);
-    //     });
-    // },
+
     getEva() {
       let params = {
         oid: this.oid,
@@ -884,6 +885,59 @@ export default {
           console.error(err);
         });
     },
+        // lookPdf(val){
+    //   this.worksDialogCon=val
+    //   this.worksDialog = true;
+    //   this.digNum = 2
+    //   this.exportW++
+    // },
+       // 查看报告筛选班级
+    // searchWork2() {
+    //   this.page2 = 1
+    //   this.getStudnet();
+    // },
+       // clearSelection() {
+    //     this.$refs.multipleTable.clearSelection();
+    // },
+    // 导出pdf
+    // exportPdfSetBtn(){
+    //   this.worksDialog = true;
+    //   this.digNum = 0
+    //   this.exportW++
+      
+    // },
+        // getClass() {
+    //   let params = {
+    //     oid: this.oid,
+    //   };
+    //   this.ajax
+    //     .get(this.$store.state.api + "selectClassBySchool", params)
+    //     .then((res) => {
+    //       this.classJuri = res.data[0];
+    //     })
+    //     .catch((err) => {
+    //       console.error(err);
+    //     });
+    // },
+    // 一键导出pdf
+    // exportPdfSetAllBtn(){
+
+    //   this.$confirm("是否导出全部学生报告?批量导出需要等待一会儿哦~ 。", "提示", {
+    //     confirmButtonText: "确定",
+    //     cancelButtonText: "取消",
+    //     type: "warning",
+    //   })
+    //   .then(() => {
+    //     this.worksDialog = true;
+    //     this.digNum = 1
+    //     this.exportW++
+    //   })
+    //   .catch(_ => {
+    //     this.$confirm.visible=false
+    //   })
+     
+      
+    // },
   },
   created() {
     this.page = 1;
@@ -1114,6 +1168,28 @@ export default {
   text-overflow: ellipsis;
   white-space: nowrap;
 }
+.lookWorksDialogCSSExp >>> .el-dialog__header {
+  /* padding: 9px 20px 10px; */
+  background: #32455b !important;
+  color: #fff;
+}
+
+.lookWorksDialogCSSExp >>> .el-dialog__wrapper{
+  overflow: hidden !important;
+}
+.lookWorksDialogCSSExp >>> .el-dialog__body {
+  width: 100% !important;
+  height: calc(100% - 48px);
+  overflow: auto;
+  padding: 20px 45px;
+  box-sizing: border-box;
+}
+.lookWorksDialogCSSExp >>> .el-dialog.is-fullscreen {
+  overflow: hidden;
+}
+
+
+
 .worksDialogCSSExp>>> .el-dialog__header {
   /* padding: 9px 20px 10px; */
   background: #32455b !important;
@@ -1141,7 +1217,33 @@ export default {
 .TableCs >>>  .cell {
   visibility: hidden;
 } */
+.TableCss {
+  width: 94%;
+  margin: auto;
+}
 .TableCss >>> .el-table__header-wrapper .el-table__header .el-checkbox {
   display: none;
 }
+.JsonTit{
+  width: 100%;
+  padding: 20px 0;
+  display: flex;
+  justify-content: space-between;
+  align-items: center;
+
+}
+.JsonTitBtn{
+  display: flex;
+  align-items: center;
+}
+.typeCheck {
+  display: flex;
+  align-items: center;
+  justify-content: flex-end;
+  margin-left: 10px;
+  /* margin-bottom: 20px; */
+}
+.typeCheck > span {
+  margin-left: 10px;
+}
 </style>

Niektóre pliki nie zostały wyświetlone z powodu dużej ilości zmienionych plików