|
@@ -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(",")}
|