lsc há 10 meses atrás
pai
commit
b22b3bbddc

+ 1 - 1
dist/index.html

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

Diff do ficheiro suprimidas por serem muito extensas
+ 0 - 0
dist/static/css/app.dea23c7470872a539db7b863d694e85b.css


Diff do ficheiro suprimidas por serem muito extensas
+ 0 - 0
dist/static/css/app.dea23c7470872a539db7b863d694e85b.css.map


Diff do ficheiro suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/app.c075b927ff9a2bf71d56.js


Diff do ficheiro suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/app.c075b927ff9a2bf71d56.js.map


Diff do ficheiro suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/manifest.571c38d63f24b1ae9e16.js.map


+ 271 - 85
src/components/pages/aiAddCourse/addCourse.vue

@@ -349,7 +349,8 @@
                 <div class="c_info_title">
                   课程简要描述
                   <button class="c_pub_button_confirm" style="margin: 0 20px 0 auto;"
-                     @contextmenu.prevent="openAiDialog(1, 'aiDetail')" @click="openAiDialog(2, 'aiDetail')">AI优化</button>
+                    @contextmenu.prevent="openAiDialog(1, 'aiDetail')"
+                    @click="openAiDialog(2, 'aiDetail')">AI优化</button>
                 </div>
                 <div style="width: 100%; padding: 0px 20px; box-sizing: border-box">
                   <div style="width: calc(100%)">
@@ -427,12 +428,12 @@
                         " @dragend="dragEnd()" :draggable="isdrag ==
                           'chapter-' + 0 + '-' + index1
                           " class="chapter_upload" v-for="(item1, index1) in infoData" :key="item1.id" @click="
-                                  getChapterData(
-                                    $event,
-                                    index1,
-                                    item1.type
-                                  )
-                                  " :class="{
+                            getChapterData(
+                              $event,
+                              index1,
+                              item1.type
+                            )
+                            " :class="{
                                     dragOverTop2:
                                       newIndex === index1 &&
                                       typeIndex ==
@@ -650,7 +651,36 @@
                         placeholder="请输入任务描述" v-model="item.taskDetail2"></textarea>
                       <div class="op_box">
                         <div class="op_remark">*可以将需要优化的建议添加在任务描述后,点击“智能优化”,自动进行修改</div>
-                        <div class="r_pub_button_op" @contextmenu.prevent="openAiDialog(1, 'aiDetail1',item.taskDetail2,index)" @click="openAiDialog(2, 'aiDetail1',item.taskDetail2,index)">智能优化</div>
+                        <div class="r_pub_button_op"
+                          @contextmenu.prevent="openAiDialog(1, 'aiDetail1', item.taskDetail2, index)"
+                          @click="openAiDialog(2, 'aiDetail1', item.taskDetail2, index)">智能优化</div>
+                      </div>
+                    </div>
+                  </div>
+                </div>
+              </div>
+            </div>
+            <div class="whiteBg" style="background: #fff; margin: 0 0 10px;padding: 0 0 15px;" v-if="isOutline2">
+              <div class="whiteBg" style="border-radius: 0; margin-top: 15px">
+                <div class="c_info_title">
+                  教案
+                  <!-- <button class="c_pub_button_confirm" style="margin: 0 20px 0 auto;">AI优化</button> -->
+                </div>
+                <div class="task_outline">
+                  <div class="outline_box" v-for="(item, index) in unitJson[0].chapterInfo[0].taskJson" :key="index">
+                    <div class="outline_task">
+                      <div class="title">任务{{ index + 1 }}</div>
+                      <input type="text" placeholder="输入任务名称" class="binfo_input" style="border-radius: 4px"
+                        v-model="item.task" />
+                    </div>
+                    <div class="outline_detail" v-loading="taskDetailLoading5.indexOf('task-' + index) !== -1">
+                      <textarea v-autoHeight="100" rows="4" class="binfo_input binfo_textarea" cols placeholder="请输入教案"
+                        v-model="item.taskDetail3"></textarea>
+                      <div class="op_box">
+                        <div class="op_remark">*可以将需要优化的建议添加在任务描述后,点击“智能优化”,自动进行修改</div>
+                        <div class="r_pub_button_op"
+                          @contextmenu.prevent="openAiDialog(1, 'teacherDetail', item.taskDetail3, index)"
+                          @click="openAiDialog(2, 'teacherDetail', item.taskDetail3, index)">智能优化</div>
                       </div>
                     </div>
                   </div>
@@ -675,11 +705,12 @@
               <button class="c_pub_button_return pub_btn_last_img" v-if="steps > 1 && steps != 5" @click="lastSteps">
                 {{ steps == 4 ? "返回课程" : "上一步" }}
               </button>
-              <button class="c_pub_button_confirm" v-if="steps < 4" @click="nextSteps(2)" @contextmenu.prevent="nextSteps(1)" :class="{
-                pub_btn_next_img: steps != 3,
-                pub_btn_finish_img: steps == 3,
-              }">
-                {{ steps == 3 ? "确认上传" : !isOutline ? "生成大纲" : "下一步" }}
+              <button class="c_pub_button_confirm" v-if="steps < 4" @click="nextSteps(2)"
+                @contextmenu.prevent="nextSteps(1)" :class="{
+                  pub_btn_next_img: steps != 3,
+                  pub_btn_finish_img: steps == 3,
+                }">
+                {{ steps == 3 ? "确认上传" : !isOutline ? "生成大纲" : !isOutline2 ? "生成教案" : "下一步" }}
               </button>
             </div>
           </div>
@@ -1481,11 +1512,11 @@
                                   "></textarea> -->
                               <div class="op_box">
                                 <div class="op_remark">*可以将需要优化的建议添加在任务描述后,点击“智能优化”,自动进行修改</div>
-                                <div class="r_pub_button_op" @contextmenu.prevent="openAiDialog(1, 'aiDetail2',unitJson[unitIndex].chapterInfo[0].taskJson[
+                                <div class="r_pub_button_op" @contextmenu.prevent="openAiDialog(1, 'aiDetail2', unitJson[unitIndex].chapterInfo[0].taskJson[
                                   itemTaskIndex
-                                ],itemTaskIndex)" @click="openAiDialog(2, 'aiDetail2',unitJson[unitIndex].chapterInfo[0].taskJson[
+                                ], itemTaskIndex)" @click="openAiDialog(2, 'aiDetail2', unitJson[unitIndex].chapterInfo[0].taskJson[
                                   itemTaskIndex
-                                ],itemTaskIndex)">智能优化</div>
+                                ], itemTaskIndex)">智能优化</div>
                               </div>
                             </div>
                           </div>
@@ -3143,7 +3174,10 @@
                                   " v-model="itemTool.toolDetail"></textarea>
                                 <div class="op_box">
                                   <div class="op_remark">*可以将需要优化的建议添加在工具描述后,点击“智能优化”,自动进行修改</div>
-                                  <div class="r_pub_button_op" @contextmenu.prevent="openAiDialog(1, 'aiDetail3',itemTool,itemTaskIndex, toolIndex)" @click="openAiDialog(2, 'aiDetail3',itemTool.toolDetail,itemTaskIndex, toolIndex)">智能优化</div>
+                                  <div class="r_pub_button_op"
+                                    @contextmenu.prevent="openAiDialog(1, 'aiDetail3', itemTool, itemTaskIndex, toolIndex)"
+                                    @click="openAiDialog(2, 'aiDetail3', itemTool.toolDetail, itemTaskIndex, toolIndex)">
+                                    智能优化</div>
                                 </div>
                               </div>
                             </div>
@@ -3438,7 +3472,9 @@
                                 margin: 20px 0;
                               ">
                               <div class="lineTitle clineTitle">评价设置</div>
-                              <div class="r_pub_button_op" style="margin-left:auto;" @contextmenu.prevent="openAiDialog(1, 'aiDetail4',itemTask.eList,itemTaskIndex)" @click="openAiDialog(2, 'aiDetail4',itemTask.eList,itemTaskIndex)">智能优化</div>
+                              <div class="r_pub_button_op" style="margin-left:auto;"
+                                @contextmenu.prevent="openAiDialog(1, 'aiDetail4', itemTask.eList, itemTaskIndex)"
+                                @click="openAiDialog(2, 'aiDetail4', itemTask.eList, itemTaskIndex)">智能优化</div>
                               <!-- <div class="line" style="width: 90%"></div> -->
                             </div>
                           </div>
@@ -5007,7 +5043,8 @@
     </evaBox>
     <EnglishVoice :oid="oid" :org="org" :EnglishVoiceDialog.sync="EnglishVoiceDialog"
       :englishVoiceJson="englishVoiceJson" @setEnglishVoiceJson="setEnglishVoiceJson"></EnglishVoice>
-    <aiDialog :dialogVisibleAiD.sync="dialogVisibleAiD" :aiText="aiText" @aiConfirm="aiConfirm" :clickType="clickType"></aiDialog>
+    <aiDialog :dialogVisibleAiD.sync="dialogVisibleAiD" :aiText="aiText" @aiConfirm="aiConfirm" :clickType="clickType">
+    </aiDialog>
   </div>
 </template>
 
@@ -5336,6 +5373,7 @@ export default {
       oneJson: [],
       updateKey: 1,
       isOutline: false,
+      isOutline2: false,
       infoData: [],
       infoproVisible: false,
       infoisFinishSize: 0,
@@ -5348,6 +5386,8 @@ export default {
       taskDetailLoading3: [],
       ttaskDetailLoading3: [],
       taskDetailLoading4: [],
+      taskDetailLoading5: [],
+      ttaskDetailLoading5: [],
       dArray: {},
       dialogVisibleAiD: false,
       aitype: "",
@@ -6034,6 +6074,11 @@ export default {
             this.openAiDialog(clickType, 'aiOutline')
             return;
           }
+
+          if (!this.isOutline2) {
+            this.openAiDialog(clickType, 'aiTeacher')
+            return;
+          }
           this.loading = true
 
           const functionA = () => {
@@ -6066,24 +6111,7 @@ export default {
           if (this.cid) {
             functionA()
           } else {
-            let url = []
-            if (this.infoData.length) {
-              for (var i = 0; i < this.infoData.length; i++) {
-                url.push(this.infoData[i].url)
-              }
-            }
-            let msg = `
-            ATTENTION: Use '##' to SPLIT SECTIONS, not '#'. Output format carefully referenced "Format example".
-
-            --------
-            ## 要求
-            请根据${JSON.stringify(this.dArray)}以及#补充参考资料为每个教学任务设计详细的教案,其中包括但不仅限于该任务的教学目标,教学过程,师生研讨,拓展,学生任务单,相关知识点的练习或Qui以及答案等。以文本格式输出。
-
-            --------
-            ## 补充参考资料
-            补充资料:${url.join(",")}
-            补充描述:${this.courseText2}`
-            this.aiGet4(msg, functionA, clickType)
+            this.openAiDialog(clickType, "aiTask", functionA)
           }
 
         } else {
@@ -10301,6 +10329,7 @@ export default {
         this.selectAllType();
       } else {
         this.isOutline = true
+        this.isOutline2 = true
         this.cidType = 1;
         let params = {
           cid: this.cid,
@@ -12243,7 +12272,7 @@ export default {
         }
       }
       if (type == "aiDetail") {
-        if(this.ttextLoading){
+        if (this.ttextLoading) {
           this.$message({
             message: "请回答完毕后再次发送",
             type: "warning"
@@ -12257,10 +12286,14 @@ export default {
         this.aiText = `请根据${this.courseText}设计一个名为${this.courseName}的${sub.length ? sub.join(",") + "学科的" : ""},面向${this.getListClassC(this.checkboxList2)}的项目式学习课程设计序列教学活动(需要每个任务都需要至少50个token的详细描述),每个教学活动的活动设计(可以直接使用文件内容)以及每个教学活动的评价量规(学生能做到...)。`
       } else if (type == "aiTask") {
         this.aitype = "aiTask"
-        this.aiText = `请根据${this.teacherText}。`
+        var _text = ""
+        for (var i = 0; i < this.teacherText.length; i++) {
+          _text += `任务名称:${this.teacherText[i].task} 教案:${this.teacherText[i].detail} \n`
+        }
+        this.aiText = `请根据${_text}。`
         this.aiCallBack = callback
       } else if (type == "aiDetail1") {
-        if(this.ttaskDetailLoading.indexOf('task-'+index) !== -1){
+        if (this.ttaskDetailLoading.indexOf('task-' + index) !== -1) {
           this.$message({
             message: "请回答完毕后再次发送",
             type: "warning"
@@ -12272,7 +12305,7 @@ export default {
         this.aiText = `请根据${callback},重新设计该教学任务。任务需要至少50个token的详细描述,包含任务设计,评价标准 \n`
         this.aiIndex = index
       } else if (type == "aiDetail2") {
-        if(this.ttaskDetailLoading2.indexOf('task-'+index) !== -1){
+        if (this.ttaskDetailLoading2.indexOf('task-' + index) !== -1) {
           this.$message({
             message: "请回答完毕后再次发送",
             type: "warning"
@@ -12283,7 +12316,7 @@ export default {
         this.aiText = `请你在考虑到整个课程的情况下,优化该任务描述和任务名:${callback.task}:${callback.taskDetail}`
         this.aiIndex = index
       } else if (type == "aiDetail3") {
-        if(this.ttaskDetailLoading3.indexOf('task-'+index+tindex) !== -1){
+        if (this.ttaskDetailLoading3.indexOf('task-' + index + tindex) !== -1) {
           this.$message({
             message: "请回答完毕后再次发送",
             type: "warning"
@@ -12292,15 +12325,36 @@ export default {
         }
         this.aitype = "aiDetail3"
         this.aiText = `请你在考虑到整个课程的情况下,**重点考虑该任务及工具名和工具内容的情况下**,优化工具指引。`
-        this.aiIndex = index+'-'+tindex
+        this.aiIndex = index + '-' + tindex
       } else if (type == "aiDetail4") {
         var _text = ""
-        for(var i = 0;i < callback.length; i++){
+        for (var i = 0; i < callback.length; i++) {
           _text += `评价维度:${callback[i].value} 维度描述:${callback[i].detail} `
         }
         this.aitype = "aiDetail4"
         this.aiText = `请你在考虑到整个课程的情况下,**重点考虑该任务详情**以及工具的情况下,优化评价标准。`
         this.aiIndex = index
+      } else if (type == "aiTeacher") {
+        this.aitype = "aiTeacher"
+        var _text = ""
+        for (var i = 0; i < this.dArray.length; i++) {
+          _text += `任务名称:${this.dArray[i].task} 任务描述:${this.dArray[i].detail} \n`
+        }
+        this.aiText = `请根据${_text}为每个教学任务设计详细的教案,其中包括但不仅限于该任务的教学目标,教学过程,师生研讨,拓展,学生任务单,相关知识点的练习或Qui以及答案等。`
+
+        this.aiCallBack = callback
+
+      } else if (type == "teacherDetail") {
+        if (this.ttaskDetailLoading5.indexOf('task-' + index) !== -1) {
+          this.$message({
+            message: "请回答完毕后再次发送",
+            type: "warning"
+          });
+          return;
+        }
+        this.aitype = "teacherDetail"
+        this.aiText = `请根据${callback}\n重新设计该教案。其中包括但不仅限于该任务的教学目标,教学过程,师生研讨,拓展,学生任务单,相关知识点的练习或Qui以及答案等。`
+        this.aiIndex = index
       }
       this.dialogVisibleAiD = true
     },
@@ -12321,18 +12375,18 @@ export default {
               --------
               ## 要求 
               ${msg} **你需要使用5EX教学活动设计框架,其定义参考#补充参考资料 中的5EX定义**。以及##补充参考资料,
-              然后根据Format example的要求返回
+              然后根据Format example的要求返回要以数组的格式
 
               --------
               ## Format example
               [
                       {
-                        task: '任务名称1',
-                        detail: '任务设计和评价标准'
+                        "task": "任务名称1",
+                        "detail": "任务设计和评价标准"
                       },
                       {
-                        task: '任务名称2',
-                        detail: '任务设计和评价标准'
+                        "task": "任务名称2",
+                        "detail": "任务设计和评价标准"
                       }
               ]
 
@@ -12355,7 +12409,7 @@ export default {
           this.loading = false
           this.isOutline = true
         })
-      } else if (this.aitype == "aiTask"){ 
+      } else if (this.aitype == "aiTask") {
         let message = `
             ATTENTION: Use '##' to SPLIT SECTIONS, not '#'. Output format carefully referenced "Format example".
 
@@ -12377,16 +12431,16 @@ export default {
             ## Format example
             [
               {
-                detail: "该描述是教师给与学生的指示(用于指导学生如何进行每个教学活动),对应到学生活动,你应该用友好,但是又清晰明确的口吻来撰写。",
-                elist:[
+                "detail": "该描述是教师给与学生的指示(用于指导学生如何进行每个教学活动),对应到学生活动,你应该用友好,但是又清晰明确的口吻来撰写。",
+                "elist":[
                   {"value":"评价名字1","detail":"评价维度1","score":5},
                   {"value":"评价名字2","detail":"评价维度2","score":5},
                   {"value":"评价名字3","detail":"评价维度3","score":5}
                 ],//至少3条评价标准,这个评价是教师用来评价学生表现的,需要包含评价维度,以及该维度中教师期待学生的表现,句式为学生应该能....
-                toolChoose: [
+                "toolChoose": [
                   {
-                    tool: "工具", //电子白板,文档,思维导图,表格,作业提交中选择其中一个工具
-                    detail: "工具描述"
+                    "tool": "工具", //电子白板,文档,思维导图,表格,作业提交中选择其中一个工具
+                    "detail": "工具描述"
                   }
                 ] //可0~2个工具
               }
@@ -12401,13 +12455,13 @@ export default {
             ## 示例
             [
               {
-                detail: "面向学生的任务描述",
-                elist:[
+                "detail": "面向学生的任务描述",
+                "elist":[
                   {"value":"评价名字1","detail":"评价维度1", "score": 5},
                   {"value":"评价名字2","detail":"评价维度2", "score": 5},
                   {"value":"评价名字3","detail":"评价维度3", "score": 5}
                 ],
-                toolChoose: [
+                "toolChoose": [
                   {
                     tool:"电子白板", 
                     detail: "工具描述"
@@ -12419,22 +12473,22 @@ export default {
                 ]
               },
               {
-                detail: "面向学生的任务描述",
-                elist:[
+                "detail": "面向学生的任务描述",
+                "elist":[
                   {"value":"评价名字1","detail":"评价维度1", "score": 5},
                   {"value":"评价名字2","detail":"评价维度2", "score": 5},
                   {"value":"评价名字3","detail":"评价维度3", "score": 5}
                 ],
-                toolChoose: []
+                "toolChoose": []
               },
               {
-                detail: "面向学生的任务描述",
-                elist:[
+                "detail": "面向学生的任务描述",
+                "elist":[
                   {"value":"评价名字1","detail":"评价维度1", "score": 5},
                   {"value":"评价名字2","detail":"评价维度2", "score": 5},
                   {"value":"评价名字3","detail":"评价维度3", "score": 5}
                 ],
-                toolChoose: [
+                "toolChoose": [
                   {
                     tool:"文档", 
                     detail: "工具描述"
@@ -12444,15 +12498,48 @@ export default {
             ]`
         this.loading = true
         this.aiGet3(message, this.aiCallBack)
-      } else if (this.aitype == "aiDetail1"){ 
+      } else if (this.aitype == "aiDetail1") {
         this.aiDetail(msg, this.aiIndex)
-      } else if (this.aitype == "aiDetail2"){ 
+      } else if (this.aitype == "aiDetail2") {
         this.aiDetail2(msg, this.aiIndex)
-      } else if (this.aitype == "aiDetail3"){
+      } else if (this.aitype == "aiDetail3") {
         let _index = this.aiIndex.split('-')
         this.aiDetail3(msg, _index[0], _index[1])
-      } else if (this.aitype == "aiDetail4"){ 
+      } else if (this.aitype == "aiDetail4") {
         this.aiDetail4(msg, this.aiIndex)
+      } else if (this.aitype == "teacherDetail") {
+        this.aiDetail5(msg, this.aiIndex)
+      } else if (this.aitype == "aiTeacher") {
+        this.loading = true
+        let message = `
+            ATTENTION: Use '##' to SPLIT SECTIONS, not '#'. Output format carefully referenced "Format example".
+
+            --------
+            ## 要求
+            ${msg} 以及##补充参考资料, 然后根据Format example的要求返回要以数组的格式
+
+            
+            --------
+            ## 补充参考资料
+            补充资料:${url.join(",")}
+            补充描述:${this.courseText2}
+
+            --------
+            ## Format example
+            [
+              {
+                "task": "任务名称1",
+                "detail": "教案"
+              },
+              {
+                 "task": "任务名称2",
+                 "detail": "教案"
+              }
+            ]`
+        this.aiGet4(message, () => {
+          this.loading = false
+          this.isOutline2 = true
+        })
       }
     },
     detailYou(message) {
@@ -12542,9 +12629,9 @@ export default {
         // if (data.choices && data.choices.length && data.choices[0].message) {
         //   _this.courseText = data.choices[0].message.content
         // }
-        if (res.data.FunctionResponse.result == "发送成功") {
+        if (response.data.FunctionResponse.result == "发送成功") {
         } else {
-          this.$message.warning(res.data.FunctionResponse.result);
+          this.$message.warning(response.data.FunctionResponse.result);
         }
 
       }).catch(function (error) {
@@ -12620,6 +12707,7 @@ export default {
               task: _task.task,
               taskDetail: "",
               taskDetail2: _task.detail,
+              taskDetail3: "",
               chapterData: [],
               toolText: "",
               toolChoose: [
@@ -12639,7 +12727,7 @@ export default {
               askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
               checkJson: [{ checkCount: [], checkPerent: [] }],
               homeworkList: [],
-            },)
+            })
           }
           _this.unitJson2 = JSON.parse(JSON.stringify(_this.unitJson))
           _this.$forceUpdate();
@@ -12680,7 +12768,7 @@ export default {
             "电子白板": { tool: 1, type: 1 },
             "文档": { tool: 52, type: 1 },
             "思维导图": { tool: 3, type: 1 },
-            "表格": { tool: 0, type: 1 },
+            "表格": { tool: 48, type: 1 },
             "作业提交": { tool: 16, type: 1 }
           }
           for (var i = 0; i < tArray.length; i++) {
@@ -12746,10 +12834,17 @@ export default {
         let data = response.data.FunctionResponse
         if (data.choices && data.choices.length && data.choices[0].message) {
           console.log(data.choices[0].message.content);
-          _this.teacherText = data.choices[0].message.content
-          _this.openAiDialog(clickType, "aiTask", callback)
+          let dArray = JSON.parse(data.choices[0].message.content)
+          _this.teacherText =  JSON.parse(data.choices[0].message.content)
+
+          for (var i = 0; i < dArray.length; i++) {
+            let _task = dArray[i]
+            _this.unitJson[0].chapterInfo[0].taskJson[i].taskDetail3 = _task.detail
+          }
+          _this.unitJson2 = JSON.parse(JSON.stringify(_this.unitJson))
+          _this.$forceUpdate();
         }
-        // callback ? callback() : ''
+        callback ? callback() : ''
         _this.loading = false
       }).catch(function (error) {
         _this.loading = false
@@ -12804,9 +12899,9 @@ export default {
         //   _this.$forceUpdate()
         // }
 
-        if (res.data.FunctionResponse.result == "发送成功") {
+        if (response.data.FunctionResponse.result == "发送成功") {
         } else {
-          this.$message.warning(res.data.FunctionResponse.result);
+          this.$message.warning(response.data.FunctionResponse.result);
         }
 
         // _this.taskDetailLoading.splice(_this.taskDetailLoading.indexOf(_tindex), 1)
@@ -12891,9 +12986,9 @@ export default {
         //   _this.$forceUpdate()
         // }
         // _this.taskDetailLoading2.splice(_this.taskDetailLoading.indexOf(_tindex), 1)
-        if (res.data.FunctionResponse.result == "发送成功") {
+        if (response.data.FunctionResponse.result == "发送成功") {
         } else {
-          this.$message.warning(res.data.FunctionResponse.result);
+          this.$message.warning(response.data.FunctionResponse.result);
         }
       }).catch(function (error) {
         _this.taskDetailLoading2.splice(_this.taskDetailLoading2.indexOf(_tindex), 1)
@@ -12984,9 +13079,9 @@ export default {
         //   _this.$forceUpdate()
         // }
         // _this.taskDetailLoading3.splice(_this.taskDetailLoading3.indexOf(_tindex), 1)
-        if (res.data.FunctionResponse.result == "发送成功") {
+        if (response.data.FunctionResponse.result == "发送成功") {
         } else {
-          this.$message.warning(res.data.FunctionResponse.result);
+          this.$message.warning(response.data.FunctionResponse.result);
         }
       }).catch(function (error) {
         _this.taskDetailLoading3.splice(_this.taskDetailLoading3.indexOf(_tindex), 1)
@@ -13037,9 +13132,9 @@ export default {
       const _tindex = 'task-' + index
       const _tindex2 = index
       var _text = ""
-        for(var i = 0;i < _this.unitJson[0].chapterInfo[0].taskJson[_tindex2].eList.length; i++){
-          _text += `评价维度:${_this.unitJson[0].chapterInfo[0].taskJson[_tindex2].eList[i].value} 维度描述:${_this.unitJson[0].chapterInfo[0].taskJson[_tindex2].eList[i].detail} `
-        }
+      for (var i = 0; i < _this.unitJson[0].chapterInfo[0].taskJson[_tindex2].eList.length; i++) {
+        _text += `评价维度:${_this.unitJson[0].chapterInfo[0].taskJson[_tindex2].eList[i].value} 维度描述:${_this.unitJson[0].chapterInfo[0].taskJson[_tindex2].eList[i].detail} `
+      }
       // **重点考虑该任务详情**
       let messages = `
       ATTENTION: Use '##' to SPLIT SECTIONS, not '#'.Output format carefully referenced "Format example".
@@ -13095,7 +13190,98 @@ export default {
         _this.taskDetailLoading4.splice(_this.taskDetailLoading.indexOf(_tindex), 1)
         console.log(error);
       });
-    }
+    },
+    aiDetail5(msg, index) {
+      let _this = this
+      const _tindex = 'task-' + index
+      const _tindex2 = index
+      let url = []
+      if (this.infoData.length) {
+        for (var i = 0; i < this.infoData.length; i++) {
+          url.push(this.infoData[i].url)
+        }
+      }
+      let messages = `
+      ATTENTION: Use '##' to SPLIT SECTIONS, not '#'.Output format carefully referenced "Format example".
+
+      --------
+      ## 要求
+      ${msg} 
+              
+      ## 补充参考资料
+      - 补充资料:${url.join(",")}
+      - 补充描述:${this.courseText2}`
+      _this.taskDetailLoading5.push(_tindex)
+      _this.ttaskDetailLoading5.push(_tindex)
+      let _uuid = uuidv4();
+      let params = JSON.stringify({
+        // "model": "Chat",
+        model: 'gpt-3.5-turbo',
+        temperature: 0,
+        max_tokens: 4096,
+        top_p: 1,
+        frequency_penalty: 0,
+        presence_penalty: 0,
+        messages: [{
+          content: messages,
+          role: 'user'
+        }],
+        uid: _uuid,
+        mind_map_question: "",
+      })
+      _this.ajax.post('https://gpt4.cocorobo.cn/chat', params).then(function (response) {
+        console.log(response);
+        // let data = response.data.FunctionResponse
+        // if (data.choices && data.choices.length && data.choices[0].message) {
+        //   console.log(data.choices[0].message.content);
+        //   _this.unitJson[0].chapterInfo[0].taskJson[_tindex2].taskDetail = data.choices[0].message.content
+        //   _this.$forceUpdate()
+        // }
+        // _this.taskDetailLoading2.splice(_this.taskDetailLoading.indexOf(_tindex), 1)
+        if (response.data.FunctionResponse.result == "发送成功") {
+        } else {
+          this.$message.warning(response.data.FunctionResponse.result);
+        }
+      }).catch(function (error) {
+        _this.taskDetailLoading5.splice(_this.taskDetailLoading5.indexOf(_tindex), 1)
+        _this.ttaskDetailLoading5.splice(_this.ttaskDetailLoading5.indexOf(_tindex), 1)
+        console.log(error);
+      });
+      _this.aiDetail5getAiContent(_uuid, _tindex, _tindex2)
+    },
+    aiDetail5getAiContent(_uid, loading, _tindex2) {
+      let _source = new EventSource(`https://gpt4.cocorobo.cn/stream/${_uid}`); //http://gpt4.cocorobo.cn:8011/stream/     https://gpt4.cocorobo.cn/stream/
+      let _allText = "";
+      let _mdText = "";
+      _source.onmessage = _e => {
+        if (_e.data.replace("'", "").replace("'", "") == "[DONE]") {
+          //对话已经完成
+          _mdText = _mdText.replace("_", "");
+          _source.close();
+          this.unitJson[0].chapterInfo[0].taskJson[_tindex2].taskDetail3 = _mdText;
+          this.taskDetailLoading5.splice(this.taskDetailLoading5.indexOf(loading), 1)
+          this.ttaskDetailLoading5.splice(this.ttaskDetailLoading5.indexOf(loading), 1)
+          return;
+        } else {
+          //对话还在继续
+          let _text = "";
+          _text = _e.data.replaceAll("'", "");
+          if (_allText == "") {
+            _allText = _text.replace(/^\n+/, ""); //去掉回复消息中偶尔开头就存在的连续换行符
+          } else {
+            _allText += _text;
+          }
+          _mdText = _allText + "_";
+          _mdText = _mdText.replace(/\\n/g, "\n");
+          _mdText = _mdText.replace(/\\/g, "");
+          if (_allText.split("```").length % 2 == 0) _mdText += "\n```\n";
+          //转化返回的回复流数据
+          this.unitJson[0].chapterInfo[0].taskJson[_tindex2].taskDetail3 = _mdText;
+          this.taskDetailLoading5.splice(this.taskDetailLoading5.indexOf(loading), 1)
+          // 处理流数据
+        }
+      };
+    },
   },
   beforeDestroy() {
     clearTimeout(this.timer);

Alguns ficheiros não foram mostrados porque muitos ficheiros mudaram neste diff