|
@@ -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);
|