lsc 8 miesięcy temu
rodzic
commit
15b682499c

+ 1 - 1
dist/index.html

@@ -32,7 +32,7 @@
       width: 100%;
       background: #e6eaf0;
       font-family: '黑体';
-    }</style><link href=./static/css/app.854f119a5bb58743bf6d1fc4108802ca.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.2485ee65a402fb60e5a9.js></script><script type=text/javascript src=./static/js/app.f0593d34540bacec8d2a.js></script></body></html><script>function stopSafari() {
+    }</style><link href=./static/css/app.36ae00dea4f7a681f06ab40aa9af0672.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.2485ee65a402fb60e5a9.js></script><script type=text/javascript src=./static/js/app.e4de5b2bc23073b71eb8.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.36ae00dea4f7a681f06ab40aa9af0672.css


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


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


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


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


+ 320 - 23
src/components/pages/aiAddCourse/addCourse.vue

@@ -1261,6 +1261,8 @@
               <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;"
+                      @click="openAiDialog2(2, 'aiCpote1')">{{cpote.cpote1 ? '重新生成概念群' : '生成概念群'}}</button>
                 </div>
                 <div class="task_outline">
                   <div class="outline_detail" v-loading="cpoteLoading.cpote1" element-loading-text="小可正在努力生成中,请稍等...">
@@ -1287,6 +1289,8 @@
               <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;"
+                  @click="openAiDialog2(2, 'aiCpote2')">{{cpote.cpote2 ? '重新生成问题链' : '生成问题链'}}</button>
                 </div>
                 <div class="task_outline">
                   <div class="outline_detail" v-loading="cpoteLoading.cpote2" element-loading-text="小可正在努力生成中,请稍等...">
@@ -1313,6 +1317,8 @@
               <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;"
+                  @click="openAiDialog2(2, 'aiCpote3')">{{cpote.cpote3 ? '重新生成目标层' : '生成目标层'}}</button>
                 </div>
                 <div class="task_outline">
                   <div class="outline_detail" v-loading="cpoteLoading.cpote3" element-loading-text="小可正在努力生成中,请稍等...">
@@ -1339,6 +1345,8 @@
               <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;"
+                  @click="openAiDialog2(2, 'aiCpote4')">{{cpote.cpote4 ? '重新生成任务簇' : '生成任务簇'}}</button>
                 </div>
                 <div class="task_outline">
                   <div class="outline_detail" v-loading="cpoteLoading.cpote4" element-loading-text="小可正在努力生成中,请稍等...">
@@ -1365,14 +1373,19 @@
               <div class="whiteBg" style="border-radius: 0; margin-top: 15px">
                 <div class="c_info_title">
                   教案
-                  <el-tooltip effect="light" content="右键单击可配置提示词" placement="bottom" v-if="istemplate == 1 && dArray.length">
+                  <el-tooltip effect="light" content="右键单击可配置提示词" placement="bottom" v-if="istemplate == 1 && dArray.length && templateid != '4480d65a-1e48-11ef-bee5-005056b86db5'">
                     <button class="c_pub_button_confirm" style="margin: 0 20px 0 auto;"
                       @contextmenu.prevent="openAiDialog(1, 'aiTeacher2')"
-                      @click="openAiDialog(2, 'aiTeacher2')" v-if="istemplate == 1 && dArray.length">生成教案</button>
+                      @click="openAiDialog(2, 'aiTeacher2')">生成教案</button>
                    </el-tooltip>
                     <button class="c_pub_button_confirm" style="margin: 0 20px 0 auto;"
                       @click="openAiDialog2(2, 'aiTeacher2')" v-if="panTeacher() > 0 && istemplate != 1">重新生成教案</button>
-                  <!-- <button class="c_pub_button_confirm" style="margin: 0 20px 0 auto;">AI优化</button> -->
+                  <el-tooltip effect="light" content="右键单击可配置提示词" placement="bottom" v-if="panTeacher() == 0 && istemplate == 1 && templateid == '4480d65a-1e48-11ef-bee5-005056b86db5'">
+                      <button class="c_pub_button_confirm" style="margin: 0 20px 0 auto;"
+                      @contextmenu.prevent="openAiDialog(1, 'aiTeacher3')"
+                      @click="openAiDialog(2, 'aiTeacher3')">生成教案</button>
+                   </el-tooltip>
+                   <!-- <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">
@@ -1421,7 +1434,7 @@
               <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_return" v-if="!isOutline && !courseTextBool" @click="clickGenTT2">
+              <button class="c_pub_button_return" v-if="!isOutline && !courseTextBool && (templateid == 'cf5722a4-401b-11ef-b873-005056b86db5' || templateid == 'cf5722a4-401b-11ef-b873-005056b86dc4')" @click="clickGenTT2">
                 重新生成概况和目标
               </button>
               <el-tooltip effect="light" content="右键单击可配置提示词" placement="bottom"  v-if="steps < 4">
@@ -4933,6 +4946,7 @@
         <aiTips ttitle="cpote" title="问题链" :detail="aiJson.cpote2" pan="cpote2" @setAiJson="setAiJson"  v-if="templateid == '4480d65a-1e48-11ef-bee5-005056b86db5'"/>
         <aiTips ttitle="cpote" title="目标层" :detail="aiJson.cpote3" pan="cpote3" @setAiJson="setAiJson"  v-if="templateid == '4480d65a-1e48-11ef-bee5-005056b86db5'"/>
         <aiTips ttitle="cpote" title="任务簇" :detail="aiJson.cpote4" pan="cpote4" @setAiJson="setAiJson"  v-if="templateid == '4480d65a-1e48-11ef-bee5-005056b86db5'"/>
+        <aiTips ttitle="cpote" title="生成任务" :detail="aiJson.aiCpoteTask" pan="aiCpoteTask" @setAiJson="setAiJson"  v-if="templateid == '4480d65a-1e48-11ef-bee5-005056b86db5'"/>
         <!-- <aiTips ttitle="课程大纲" title="生成教案按钮" :detail="aiJson.aiTeacher" pan="aiTeacher" @setAiJson="setAiJson" /> -->
         <!-- <aiTips ttitle="生成教案" title="教案描述优化" :detail="aiJson.teacherDetail" pan="teacherDetail"
           @setAiJson="setAiJson" /> -->
@@ -6763,7 +6777,7 @@ export default {
       courseTextBool: false,
       teacherCourseTextB: false,
       targetCourseTextB: false,
-      courseTextB: false,
+      courseTextB: true,
       targetCourseText2B: false,
     };
   },
@@ -7540,7 +7554,7 @@ export default {
 
 
           if (!this.isOutline2 && this.templateid == "4480d65a-1e48-11ef-bee5-005056b86db5") {
-            this.openAiDialog(clickType, 'aiTeacher')
+            this.openAiDialog(clickType, 'aiTeacher3')
             return;
           }
 
@@ -8034,7 +8048,7 @@ export default {
             this.$message.success("粘贴成功");
             this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
               i
-            ].chapterData.push({
+            ].chapterData.unshift({
               name: "链接",
               title: "嵌入代码",
               url: match[1],
@@ -8062,7 +8076,7 @@ export default {
       this.dialogVisibleAiCreate = true;
     },
     createAiPpt(json){
-      this.unitJson[0].chapterInfo[0].taskJson[this.lineCount].chapterData.push(json);
+      this.unitJson[0].chapterInfo[0].taskJson[this.lineCount].chapterData.unshift(json);
       this.dialogVisibleAiCreate = false;
     },
     openAiCreateVideo(i){
@@ -8070,7 +8084,7 @@ export default {
       this.dialogVisibleAiCreateVideo = true;
     },
     createAiVideo(json){
-      this.unitJson[0].chapterInfo[0].taskJson[this.lineCount].chapterData.push(json);
+      this.unitJson[0].chapterInfo[0].taskJson[this.lineCount].chapterData.unshift(json);
       // this.dialogVisibleAiCreateVideo = false;
     },
     async createTeacherAn(index){
@@ -8179,7 +8193,7 @@ export default {
                     }else {
                       _index = index
                     }
-                    _this.unitJson[0].chapterInfo[0].taskJson[_index].chapterData.push({
+                    _this.unitJson[0].chapterInfo[0].taskJson[_index].chapterData.unshift({
                         name: file.name,
                         url: data.Location,
                         type: 3,
@@ -8278,7 +8292,7 @@ export default {
       for (var i = 0; i < keys.length; i++) {
         this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
           this.lineCount
-        ].chapterData.push({
+        ].chapterData.unshift({
           name: "链接",
           title: this.sourceData[keys[i]].name,
           url: this.sourceData[keys[i]].url,
@@ -8836,7 +8850,7 @@ export default {
                 }
                 _this.unitJson[unitIndex].chapterInfo[0].taskJson[
                   itemTaskIndex
-                ].chapterData.push({
+                ].chapterData.unshift({
                   name: file.name,
                   url: data.Location,
                   uid: file.uid,
@@ -8846,7 +8860,7 @@ export default {
               } else if (type == 2 || type == 3 || type == 12) {
                 _this.unitJson[unitIndex].chapterInfo[0].taskJson[
                   itemTaskIndex
-                ].chapterData.push({
+                ].chapterData.unshift({
                   name: file.name,
                   url: data.Location,
                   uid: file.uid,
@@ -9130,7 +9144,7 @@ export default {
                   type: _type,
                   fileid: fileid,
                 });
-                _this.unitJson[0].chapterInfo[0].taskJson[0].chapterData.push({
+                _this.unitJson[0].chapterInfo[0].taskJson[0].chapterData.unshift({
                   name: file.name,
                   url: data.Location,
                   uid: file.uid,
@@ -9167,7 +9181,7 @@ export default {
                   type: _type,
                   fileid: fileid,
                 });
-                _this.unitJson[0].chapterInfo[0].taskJson[0].chapterData.push({
+                _this.unitJson[0].chapterInfo[0].taskJson[0].chapterData.unshift({
                   name: file.name,
                   url: data.Location,
                   uid: file.uid,
@@ -9311,7 +9325,7 @@ export default {
               if (type == 2 || type == 3) {
                 _this.unitJson[unitIndex].chapterInfo[0].taskJson[
                   itemTaskIndex
-                ].chapterData.push({
+                ].chapterData.unshift({
                   name: file.name,
                   // name: string+''+(_this.unitJson[unitIndex].chapterInfo[0].taskJson[
                   //   itemTaskIndex
@@ -10514,6 +10528,11 @@ export default {
               this.aiJson.aiOutlineDetail = this.aiJson.aiOutlineDetail ? this.aiJson.aiOutlineDetail : '参考<课程名字>、<任务名>和<课程简要描述>的内容,为该序列生成任务详情。任务详情中需要包含教学目标,任务设计和评价标准。'
             }
 
+
+            // if(this.templateid == '4480d65a-1e48-11ef-bee5-005056b86db5'){
+            //   this.aiJson.aiCpoteTask = this.aiJson.aiCpoteTask ? this.aiJson.aiCpoteTask : '请根据<任务簇>,帮我取出里面对应的任务名'
+            // }
+
             // if(this.templateid == 'cf5722a4-401b-11ef-b873-005056b86db5'){
             //   this.aiJson.aiAbstract = this.aiJson.aiAbstract ? this.aiJson.aiAbstract : '从用户提供的教案资料(文件形式)中,自动总结教案摘要与教案的学科关键词(每个学科3个)。注意,在提取信息方面你绝对不能虚拟出不存在的东西。然后,你基于用户上传的教案,生成项目的驱动性问题和最终作品。'
             //   this.aiJson.aiTarget = this.aiJson.aiTarget ? this.aiJson.aiTarget : '从用户提供的教案资料中,提取出课程目标(如不存在课程目标则返回“未提取到目标”。注意,在提取信息方面你绝对不能虚拟出不存在的东西。'
@@ -10948,7 +10967,7 @@ export default {
     addAttTextMessage() {
       this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
         this.taskCount
-      ].chapterData.push({
+      ].chapterData.unshift({
         name: this.AttText.title,
         url: this.AttText.text,
         type: 6,
@@ -10983,7 +11002,7 @@ export default {
     addLine() {
       this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
         this.lineCount
-      ].chapterData.push({
+      ].chapterData.unshift({
         name: "链接",
         title: this.lineTitle,
         url: this.line,
@@ -11392,7 +11411,7 @@ export default {
       if (this.chapTools[0].tools.indexOf(4) != -1) {
         this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
           this.chapCount
-        ].chapterData.push({
+        ].chapterData.unshift({
           name: this.chapTools[0].toolDetail,
           url: this.chapTools[0].tools,
           type: 7,
@@ -11401,7 +11420,7 @@ export default {
       } else {
         this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
           this.chapCount
-        ].chapterData.push({
+        ].chapterData.unshift({
           name: this.chapTools[0].toolDetail,
           url: this.chapTools[0].tools,
           type: 7,
@@ -14483,6 +14502,10 @@ export default {
         this.aiJson['aiOutlineTask'] = string
         this.aiJson['aiOutlineDetail'] = string2
         this.aiText2 = ''
+      }if(pan == 'aiTeacher3'){
+        this.aiJson['aiCpoteTask'] = string
+        this.aiJson['teacherDetail2'] = string2
+        this.aiText2 = ''
       }else {
         this.aiJson[pan] = string
       }
@@ -14551,7 +14574,7 @@ export default {
         });
     },
     openAiDialog(clickType, type, callback, index, tindex) {
-      if(clickType == 1 && this.tipsJson.istips == 1 && this.istemplate != 1){
+      if(clickType == 1 && this.tipsJson.istips == 1 && this.istemplate != 1 && this.tipsJson.userid != this.userid && this.userid != '5943e08c-b7d4-11ed-8d51-005056b86db5'){
         this.$message.error("您没有权限修改/查看提示词");
         return;
       }
@@ -14563,6 +14586,7 @@ export default {
         this.$message.error("请补充填写课程名称");
         return;
       }
+      this.aiText2 = ''
       this.clickType = clickType
       let sub = []
       if (this.courseTypeId.length) {
@@ -14675,6 +14699,10 @@ export default {
       } else if (type == "aiTeacher2") {
         this.aitype = "aiTeacher2"
         this.aiText = this.aiJson.teacherDetail2 ? this.aiJson.teacherDetail2 : '请根据<任务名>、<任务描述>,<课程简要描述>,为该任务设计详细的教案,教案需要包含该任务的教学目标,教学过程(包含分步骤的教师活动和学生活动,教师活动与学生活动应该一一对应),相关知识点的讲解,练习(练习需要包含示例答案)。'
+      } else if (type == "aiTeacher3") {
+        this.aitype = type
+        this.aiText = this.aiJson.aiCpoteTask
+        this.aiText2 = this.aiJson.teacherDetail2
       } else if (type == "teacherDetail") {
         if (this.ttaskDetailLoading5.indexOf('task-' + index) !== -1) {
           this.$message({
@@ -14971,7 +14999,29 @@ ${this.templateid != "4480d65a-1e48-11ef-bee5-005056b86db5" ? '## 参考上下
             this.aiDetail52(msg, i)
           }
         }, 0)
-      } else if (this.aitype == "aiteacherTextDetail") {
+      } else if (this.aitype == "aiTeacher3"){
+        this.loading = true
+        let message = `NOTICE
+Role: 你是创建课程的老师,可以利用file_search的方式完整的去分析文件内容(注:如果文件内容里面不包含需要检索的内容,就不引用文件内容),并生成需要的JSON数据。
+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".
+Instruction: Based on the context, follow "Format example", write content.
+
+# Context
+## 要求 
+${msg} 以及##参考资料
+
+## 参考资料
+任务簇:${this.cpote.cpote4}
+
+# Format example
+[{"task": "任务1的名字"}, {"task": "任务2的名字"}, {"task": "任务2的名字"}, {"task": "任务n的名字"}]`
+
+        this.aiGetTask3(message, () => {
+          this.loading = false
+          this.isOutline2 = true
+        })
+      }  else if (this.aitype == "aiteacherTextDetail") {
         this.aiteacherTextDetail(msg)
       } else if (this.aitype == "aitargetTextDetail") {
         this.aitargetTextDetail(msg)
@@ -15733,6 +15783,252 @@ ${this.courseText && this.aiCallback == 2 ? '注意,优化原有的<参考内
           console.log(error);
         });
     },
+    async aiGetTask3(messages, callback) {
+      let _this = this
+
+      // 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'
+      //   }],
+      //   stream: false,
+      //   uid: this.userid,
+      //   mind_map_question: "",
+      // })
+      // // let params = JSON.stringify({
+      // //     message: {
+      // //         anthropic_version: "bedrock-2023-05-31",
+      // //         max_tokens: 4096,
+      // //         temperature: 0,
+      // //         top_p: 1,
+      // //         messages: [{
+      // //           content: messages,
+      // //           role: 'user'
+      // //         }], // 
+      // //     },
+      // //     model: "Claude 3 Sonnet" // Claude 3 Sonnet或者Claude 3 Haiku
+      // // });
+
+      // _this.ajax.post('https://gpt4.cocorobo.cn/chat', params).then(function (response) {
+      //   // _this.ajax.post('https://claude3.cocorobo.cn/claude3Chat', 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);
+      //     let dArray = JSON.parse(data.choices[0].message.content)
+      //     _this.dArray = dArray
+      //     _this.unitJson[0].chapterInfo[0].taskJson = []
+
+      //     for (var i = 0; i < dArray.length; i++) {
+      //       let _task = dArray[i]
+      //       _this.unitJson[0].chapterInfo[0].taskJson.push({
+      //         task: _task.task,
+      //         taskDetail: "",
+      //         taskDetail2: _task.detail,
+      //         taskDetail3: "",
+      //         chapterData: [],
+      //         toolText: "",
+      //         toolChoose: [
+      //           {
+      //             tool: [],
+      //             toolDetail: "",
+      //             toolType: 0,
+      //             askCount: 1,
+      //             askTitle: "",
+      //             askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
+      //           },
+      //         ],
+      //         isShowTools: false,
+      //         askCount: 1,
+      //         isFold: 2,
+      //         askTitle: "",
+      //         askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
+      //         checkJson: [{ checkCount: [], checkPerent: [] }],
+      //         homeworkList: [],
+      //       })
+      //     }
+      //       _this.unitJson[0].chapterInfo[0].taskJson[0].chapterData = _this.infoData
+      //           _this.unitJson2 = JSON.parse(JSON.stringify(_this.unitJson))
+      //     _this.$forceUpdate();
+      //   }
+      //   // if (data.result) {
+      //   //   console.log(data.result);
+      //   //   let dArray = JSON.parse(data.result)
+      //   //   _this.dArray = dArray
+      //   //   _this.unitJson[0].chapterInfo[0].taskJson = []
+
+      //   //   for (var i = 0; i < dArray.length; i++) {
+      //   //     let _task = dArray[i]
+      //   //     _this.unitJson[0].chapterInfo[0].taskJson.push({
+      //   //       task: _task.task,
+      //   //       taskDetail: "",
+      //   //       taskDetail2: _task.detail,
+      //   //       taskDetail3: "",
+      //   //       chapterData: [],
+      //   //       toolText: "",
+      //   //       toolChoose: [
+      //   //         {
+      //   //           tool: [],
+      //   //           toolDetail: "",
+      //   //           toolType: 0,
+      //   //           askCount: 1,
+      //   //           askTitle: "",
+      //   //           askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
+      //   //         },
+      //   //       ],
+      //   //       isShowTools: false,
+      //   //       askCount: 1,
+      //   //       isFold: 1,
+      //   //       askTitle: "",
+      //   //       askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
+      //   //       checkJson: [{ checkCount: [], checkPerent: [] }],
+      //   //       homeworkList: [],
+      //   //     })
+      //   //   }
+      //   //   _this.unitJson2 = JSON.parse(JSON.stringify(_this.unitJson))
+      //   //   _this.$forceUpdate();
+      //   // }
+      //   callback ? callback() : ''
+      // }).catch(function (error) {
+      //   _this.loading = false
+      //   console.log(error);
+      // });
+
+      let parm = {
+        assistant_id: '6063369f-289a-11ef-8bf4-12e77c4cb76b',
+        message: [{"type":"text", "text":messages.replaceAll('\n', " ").replaceAll('*', "")}],
+        session_name: uuidv4(),
+        userId: this.userid,
+        file_ids: '',
+      }
+      this.ajax
+        .post("https://gpt4.cocorobo.cn/ai_agent_park_chat", parm)
+        .then((response) => {
+          console.log(response);
+          let data = response.data.FunctionResponse
+          if (data.message) {
+            console.log(data.message);
+            let dArray = {}
+            try {
+              dArray = JSON.parse(data.message.replaceAll('```json','').replaceAll('```',''))
+            } catch (error) {
+                console.log("error_________________" + error);
+              try {
+                  let regex = new RegExp("(?<=```json)([\\s\\S]*?)(?=```)");
+                  let match = data.message.match(regex);
+                  dArray = JSON.parse(match[0]);
+
+
+                  // var message = data.message;
+                  // var jsonStart = message.indexOf("```json") + 7; // `+ 7` 是为了跳过 ```json
+                  // var jsonEnd = message.indexOf("```", jsonStart);
+                  // var jsonString = message.substring(jsonStart, jsonEnd).trim();
+                  // dArray = JSON.parse(jsonString);
+              } catch (error) {
+                console.log("error_________________" + error);
+              }
+            }
+            _this.dArray = dArray
+
+            if(_this.panOutline() > 0){
+              for(var i = 0; i < _this.unitJson[0].chapterInfo[0].taskJson.length; i++){
+                _this.unitJson[0].chapterInfo[0].taskJson[i].task = ""
+                _this.unitJson[0].chapterInfo[0].taskJson[i].taskDetail3 = ""
+              }
+              for (var i = 0; i < dArray.length; i++) {
+                let _task = dArray[i]
+                if(_this.unitJson[0].chapterInfo[0].taskJson[i]){
+                  _this.unitJson[0].chapterInfo[0].taskJson[i].task = _task.task
+                  // _this.unitJson[0].chapterInfo[0].taskJson[i].taskDetail2 = _task.detail
+                }else {
+                  _this.unitJson[0].chapterInfo[0].taskJson.push({
+                    task: _task.task,
+                    taskDetail: "",
+                    taskDetail2: "",
+                    taskDetail3: "",
+                    chapterData: [],
+                    toolText: "",
+                    toolChoose: [
+                      {
+                        tool: [],
+                        toolDetail: "",
+                        toolType: 0,
+                        askCount: 1,
+                        askTitle: "",
+                        askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
+                      },
+                    ],
+                    isShowTools: false,
+                    askCount: 1,
+                    isFold: 2,
+                    askTitle: "",
+                    askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
+                    checkJson: [{ checkCount: [], checkPerent: [] }],
+                    homeworkList: [],
+                  })
+                }
+
+              }
+            }else { 
+              _this.unitJson[0].chapterInfo[0].taskJson = []
+
+              for (var i = 0; i < dArray.length; i++) {
+                let _task = dArray[i]
+                _this.unitJson[0].chapterInfo[0].taskJson.push({
+                  task: _task.task,
+                  taskDetail: "",
+                  taskDetail2: "",
+                  taskDetail3: "",
+                  chapterData: [],
+                  toolText: "",
+                  toolChoose: [
+                    {
+                      tool: [],
+                      toolDetail: "",
+                      toolType: 0,
+                      askCount: 1,
+                      askTitle: "",
+                      askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
+                    },
+                  ],
+                  isShowTools: false,
+                  askCount: 1,
+                  isFold: 2,
+                  askTitle: "",
+                  askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
+                  checkJson: [{ checkCount: [], checkPerent: [] }],
+                  homeworkList: [],
+                })
+              }
+            }
+
+
+
+            _this.unitJson[0].chapterInfo[0].taskJson[0].chapterData = JSON.parse(JSON.stringify(_this.infoData))
+            _this.unitJson2 = JSON.parse(JSON.stringify(_this.unitJson))
+            _this.$forceUpdate();
+
+
+            setTimeout(()=>{
+              for (var i = 0; i < _this.unitJson[0].chapterInfo[0].taskJson.length; i++) {
+                this.aiDetail52(_this.aiJson['teacherDetail2'], i)
+              }
+            }, 0)
+          }
+          callback ? callback() : ''
+        })
+        .catch((error) => {
+          _this.loading = false
+          console.log(error);
+        });
+    },
     async aiGet3(messages, callback) {
       let _this = this
 
@@ -17547,7 +17843,8 @@ ${msg}
 ## 补充描述
 课程简要描述:${_this.courseText}
 任务名:${_this.unitJson[0].chapterInfo[0].taskJson[_tindex2].task}
-${_this.unitJson[0].chapterInfo[0].taskJson[_tindex2].taskDetail2 ? '任务描述:' + _this.unitJson[0].chapterInfo[0].taskJson[_tindex2].taskDetail2.replaceAll('#','').replaceAll('*','').replaceAll('-','').replaceAll('\n','') : ''}`
+${_this.unitJson[0].chapterInfo[0].taskJson[_tindex2].taskDetail2 ? '任务描述:' + _this.unitJson[0].chapterInfo[0].taskJson[_tindex2].taskDetail2.replaceAll('#','').replaceAll('*','').replaceAll('-','').replaceAll('\n','') : ''}
+${_this.templateid == "4480d65a-1e48-11ef-bee5-005056b86db5" ? '#任务簇:'+_this.cpote.cpote4.replaceAll('#','').replaceAll('*','').replaceAll('-','').replaceAll('\n','') : ''}`
 
 // ## 补充参考资料
 // - 补充资料:${url.join(",")}

+ 2 - 2
src/components/pages/aiAddCourse/aiDialog.vue

@@ -6,12 +6,12 @@
                 <span :class="{active: type == 1}">基础创建</span>
             </div>
             <div class="ai_detail" v-if="type == 1">
-                <span class="title">{{text2 ? '生成任务提示词' : '默认的提示词'}}</span>
+                <span class="title">{{text2 ? '默认的提示词1' : '默认的提示词'}}</span>
                 <textarea rows="10" class="binfo_input binfo_textarea" cols v-model="text"
                       placeholder="请输入...."></textarea>
             </div>
             <div class="ai_detail" v-if="text2 && type == 1" style="margin-top: 10px;">
-                <span class="title">生成大纲描述提示词</span>
+                <span class="title">默认的提示词2</span>
                 <textarea rows="10" class="binfo_input binfo_textarea" cols v-model="text2"
                       placeholder="请输入...."></textarea>
             </div>

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