lsc 9 hónapja
szülő
commit
1ffde3b3a7

+ 1 - 1
dist/index.html

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

A különbségek nem kerülnek megjelenítésre, a fájl túl nagy
+ 0 - 0
dist/static/css/app.d77257d7d6e226c97d8f6ad9ce790d0a.css


A különbségek nem kerülnek megjelenítésre, a fájl túl nagy
+ 0 - 0
dist/static/css/app.d77257d7d6e226c97d8f6ad9ce790d0a.css.map


A különbségek nem kerülnek megjelenítésre, a fájl túl nagy
+ 0 - 0
dist/static/js/app.82aba29f7eade0c11919.js


A különbségek nem kerülnek megjelenítésre, a fájl túl nagy
+ 0 - 0
dist/static/js/app.82aba29f7eade0c11919.js.map


A különbségek nem kerülnek megjelenítésre, a fájl túl nagy
+ 0 - 0
dist/static/js/manifest.571c38d63f24b1ae9e16.js.map


+ 13 - 5
src/components/pages/aiAddCourse/addCourse.vue

@@ -5238,7 +5238,7 @@
     </aiDialog>
     <tipsDialog :dialogVisibleTips.sync="dialogVisibleTips" :tipsJson.sync="tipsJson" :aiJson="aiJson" :userid="userid"
       @retrunCourse="retrunCourse" :templateid="templateid"></tipsDialog>
-    <aiCreateDialog :dialogVisibleAiCreate.sync="dialogVisibleAiCreate" :courseName="courseName" @createAiPpt="createAiPpt" :infoData="infoData"></aiCreateDialog>
+    <aiCreateDialog :dialogVisibleAiCreate.sync="dialogVisibleAiCreate" :courseName="courseName" @createAiPpt="createAiPpt" :infoData="infoData" :courseTypeId="courseTypeId"></aiCreateDialog>
     <aiCreateVideoDialog :dialogVisibleAiCreateVideo.sync="dialogVisibleAiCreateVideo" :courseName="courseName" @createAiVideo="createAiVideo"></aiCreateVideoDialog>
   </div>
 </template>
@@ -5602,7 +5602,7 @@ export default {
       aitype: "",
       aiJson: {
         "aiDetail": "请根据<课程简要描述>设计一个名为<课程名字>的<课程学科>学科的,面向<面向年级>的项目式学习课程。",
-        "aiOutline": "请为这个名为<课程名字>的<课程学科>学科的,面向<面向年级>学生的项目式学习课程设计序列教学活动(需要每个任务都需要至少50个token的详细描述)。你需要参考课程简要描述<课程简要描述>,并产出每个教学任务的设计(可以直接使用文件内容)以及每个教学活动的评价量规(学生能做到...)。",
+        "aiOutline": "请为这个名为<课程名字>的<课程学科>学科的,面向<面向年级>学生的项目式学习课程设计序列教学活动(需要每个任务都需要至少100个token的详细描述)。你需要参考课程简要描述<课程简要描述>,并产出每个教学任务的设计(可以直接使用文件内容)以及每个教学活动的评价量规(学生能做到...)。",
         "aiTask": "请根据<教学任务教案>。",
         "aiDetail1": "请根据<课程描述>,重新设计该教学任务。任务需要至少50个token的详细描述,包含任务设计,评价标准。",
         "aiDetail2": "请你在考虑到整个课程的情况下,优化该任务描述和任务名:<任务名>:<任务描述>",
@@ -12946,9 +12946,9 @@ export default {
       this.$forceUpdate();
     },
     openAiDialog(clickType, type, callback, index, tindex) {
-      if(clickType == 1){
-        return;
-      }
+      // if(clickType == 1){
+      //   return;
+      // }
       if (this.courseName == "") {
         this.$message.error("请补充填写课程名称");
         return;
@@ -13154,6 +13154,7 @@ export default {
 // ${this.infoData.length ? '使用文件检索的方式完整的去分析文件内容,并请完全按照要求输出。' : ''}
         let message = `NOTICE
 Role: 作为学生的学习指导Agent,你熟悉熟悉PBL(基于问题的学习)和5EX教学模型,能够根据学生的学情数据(当前的学习任务设计、学习表现数据、作业数据等)生成自适应的学习任务和对应的5道考核题目。
+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.
 
@@ -13312,6 +13313,7 @@ ${this.templateid == "4480d65a-1e48-11ef-bee5-005056b86db5" ? '## 目标层\n'+t
 // 补充描述:${this.courseText2} ##补充参考资料和
 
       let msg = `
+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".
 
 --------
@@ -14088,6 +14090,7 @@ ${message} 以及##参考资料 以文本格式输出项目概况,驱动性问
         }
       }
       let messages = `
+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".
 
 --------
@@ -14197,6 +14200,7 @@ ${msg} 及#教学任务描述 以文本格式输出任务设计和评价标准
       const _tindex = 'task-' + index
       const _tindex2 = index
       let messages = `
+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".
 
 --------
@@ -14305,6 +14309,7 @@ ${msg}
       const _tindex3 = tindex
       // **重点考虑该任务及工具名和工具内容的情况下*
       let messages = `
+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".
 
 --------
@@ -14421,6 +14426,7 @@ ${msg} 输出格式和内容要求参考#格式与要求
       }
       // **重点考虑该任务详情**
       let messages = `
+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".
 
 --------
@@ -14511,6 +14517,7 @@ ${msg} 输出格式和内容要求参考# 格式与要求
         _text2 += `任务名称:${_this.unitJson[0].chapterInfo[0].taskJson[i].task} 教案描述:${_this.unitJson[0].chapterInfo[0].taskJson[i].taskDetail3.replaceAll('#','').replaceAll('*','').replaceAll('-','').replaceAll('\n','')} \n`
       }
       let messages = `
+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".
 
 --------
@@ -14648,6 +14655,7 @@ ${_text2}`
 // ${this.cpote[_index] ? '## 优化内容\n'+this.cpote[_index] : ''}
 
       let messages = `
+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".
 
 ${msg} 

+ 234 - 170
src/components/pages/aiAddCourse/aiCreateDialog.vue

@@ -1,7 +1,7 @@
 <template>
     <el-dialog title="AI生成PPT" :visible.sync="dialogVisibleAiCreate" :append-to-body="true" width="700px"
         :before-close="handleClose" class="dialog_diy">
-        <div style="height: 500px;padding:15px" v-loading="loading">
+        <div style="height: 500px; padding: 15px" v-loading="loading">
             <!-- <div class="t_box">
                 <span>选择:</span>
                 <el-radio-group v-model="radio" @change="changeRadio">
@@ -10,15 +10,21 @@
                     <el-radio :label="2">视频</el-radio>
                 </el-radio-group>
             </div> -->
-            <!-- <div class="t_box">
-                <span>提示词:</span>
-                <textarea rows="10" class="binfo_input binfo_textarea" cols placeholder="请输入提示词"
-                    v-model="detail"></textarea>
-            </div> -->
-            <wOffice v-if="url" :url="url"></wOffice>
+            <div class="t_box" v-if="steps == 1" style="height: 100%">
+                <textarea style="height: 100%" rows="10" class="binfo_input binfo_textarea" cols placeholder="请生成大纲"
+                    v-model="outline"></textarea>
+            </div>
+            <div style="height: 100%" v-else>
+                <wOffice v-if="url" :url="url"></wOffice>
+            </div>
         </div>
         <span slot="footer" class="dialog-footer">
-            <el-button @click="aiGet" type="primary">重新生成</el-button>
+            <el-button @click="aiGet(2)" type="primary" :disabled="loading">重新生成大纲</el-button>
+            <el-button @click="aiGet(1)" type="primary" :disabled="loading">{{
+                url ? "重新生成PPT" : "生成PPT"
+                }}</el-button>
+            <el-button @click="steps = 1" type="primary" v-if="steps == 2">上一步</el-button>
+            <el-button @click="steps = 2" type="primary" v-else-if="steps == 1 && url">下一步</el-button>
             <el-button @click="confirm" type="primary">确 定</el-button>
             <el-button @click="close">关 闭</el-button>
         </span>
@@ -26,8 +32,8 @@
 </template>
 
 <script>
-import Pptxgen from "pptxgenjs"
-import wOffice from '../components/wOffice.vue'
+import Pptxgen from "pptxgenjs";
+import wOffice from "../components/wOffice.vue";
 import { v4 as uuidv4 } from "uuid";
 
 export default {
@@ -37,16 +43,20 @@ export default {
     props: {
         dialogVisibleAiCreate: {
             type: Boolean,
-            default: false
+            default: false,
         },
         courseName: {
             type: String,
-            default: ""
+            default: "",
         },
         infoData: {
             type: Array,
-            default: ""
-        }
+            default: "",
+        },
+        courseTypeId: {
+            type: Array,
+            default: "",
+        },
     },
     // 根据用户给你的参考资料
     data() {
@@ -65,147 +75,182 @@ export default {
 ## 限制
 - 你不能输出错误的知识,如果你实在不清楚,输出“对不起,我不确定”
 - 你不能输出违反伦理的内容`,
-                word: '',
-                video: ''
+                word: "",
+                video: "",
             },
             aiUrl: {
-                ppt: '',
-                word: '',
-                video: ''
+                ppt: "",
+                word: "",
+                video: "",
             },
             detail: "",
             loading: false,
             url: "",
-            uJson: {}
-        }
+            uJson: {},
+            outline: "",
+            steps: 1,
+        };
     },
     watch: {
         dialogVisibleAiCreate(newValue, oldValue) {
             if (newValue) {
-                // if (this.radio == 0) {
-                    this.detail =  `## 任务
-请根据用户给你的参考资料,生成关于${this.courseName},为教师生成这节课的教学ppt,页数在20页左右。PPT的内容主要是讲解该课程中所有可能涉及到的知识点。
-
-## 工作流
-1. 从用户提供的参考资料中提取10个最重要的知识点(知识点水平限制在小学和初中),并输出。
-2. 针对10个知识点中的每个,你使用1~3页ppt详细的对知识点进行讲解。你的讲解词应该在100token左右
-3. 讲解完所有知识点后,再根据知识点出5道单选题(放在5页ppt中)
-
-## 限制
-- 你不能输出错误的知识,如果你实在不清楚,输出“对不起,我不确定”
-- 你不能输出违反伦理的内容`
-                // }
-                // if (this.radio == 1) {
-                //     this.detail = this.aiJson.word
-                // }
-                // if (this.radio == 2) {
-                //     this.detail = this.aiJson.video
-                // }
-                // this.loading = false
-                this.aiGet()
+                this.aiGet(2);
             }
         },
     },
     methods: {
         handleClose(done) {
-            this.close()
+            this.close();
             done();
         },
         close() {
-            this.$emit('update:dialogVisibleAiCreate', false)
+            this.$emit("update:dialogVisibleAiCreate", false);
         },
         confirm() {
-            if(this.url){
-                this.$emit('createAiPpt', this.uJson)
-            }else {
-                this.$message.error('请先生成ppt');
+            if (this.url) {
+                this.$emit("createAiPpt", this.uJson);
+            } else {
+                this.$message.error("请先生成ppt");
             }
         },
         changeRadio() {
             if (this.radio == 0) {
-                this.detail = this.aiJson.ppt
+                this.detail = this.aiJson.ppt;
             }
             if (this.radio == 1) {
-                this.detail = this.aiJson.word
+                this.detail = this.aiJson.word;
             }
             if (this.radio == 2) {
-                this.detail = this.aiJson.video
+                this.detail = this.aiJson.video;
             }
         },
         createFileid(url) {
-            let _this = this
+            let _this = this;
             return new Promise((resolve, reject) => {
                 try {
-                _this.ajax
-                .put("https://gpt4.cocorobo.cn/upload_file_knowledge", {
-                    url: url,
-                })
-                .then((res) => {
-                    let _data = res.data.FunctionResponse;
-                    if (_data.result && _data.result.id) {
-                    resolve(_data.result.id)
-                    }
-                }).catch(function (error) {
-                    resolve('')
-                });
-                }catch (e){
-                resolve()
+                    _this.ajax
+                        .put("https://gpt4.cocorobo.cn/upload_file_knowledge", {
+                            url: url,
+                        })
+                        .then((res) => {
+                            let _data = res.data.FunctionResponse;
+                            if (_data.result && _data.result.id) {
+                                resolve(_data.result.id);
+                            }
+                        })
+                        .catch(function (error) {
+                            resolve("");
+                        });
+                } catch (e) {
+                    resolve();
                 }
-                
             });
         },
-        async aiGet() {
-            if(this.loading){
-                this.$message.error('正在生成中,请稍后');
+        async aiGet(type) {
+            if (this.loading) {
+                this.$message.error("正在生成中,请稍后");
                 return;
             }
-            this.url = ''
-            this.uJson = {}
-            let _this = this
+            this.url = "";
+            this.uJson = {};
+            let _this = this;
 
-            let fileid = []
+            let fileid = [];
             if (_this.infoData.length) {
                 for (var i = 0; i < _this.infoData.length; i++) {
-                if(_this.infoData[i].fileid){
-                    fileid.push(_this.infoData[i].fileid)
-                }else {
-                    let _fileid = await _this.createFileid(_this.infoData[i].url)
-                    if(_fileid){
-                    _this.infoData[i].fileid = _fileid
-                    _this.$forceUpdate();
-                    fileid.push(_fileid)
+                    if (_this.infoData[i].fileid) {
+                        fileid.push(_this.infoData[i].fileid);
+                    } else {
+                        let _fileid = await _this.createFileid(_this.infoData[i].url);
+                        if (_fileid) {
+                            _this.infoData[i].fileid = _fileid;
+                            _this.$forceUpdate();
+                            fileid.push(_fileid);
+                        }
                     }
                 }
+            }
+            console.log("fileid=========", fileid);
+
+            let mclass = [];
+            if (_this.courseTypeId.length) {
+                for (var i = 0; i < _this.courseTypeId.length; i++) {
+                    let _sid = _this.courseTypeId[i];
+                    for (
+                        var j = 0;
+                        j <
+                        _this.CourseTypeJson["34628934-d02f-11ec-8c78-005056b86db5"].length;
+                        j++
+                    ) {
+                        if (
+                            _sid ==
+                            _this.CourseTypeJson["34628934-d02f-11ec-8c78-005056b86db5"][j].id
+                        ) {
+                            mclass.push(
+                                _this.CourseTypeJson["34628934-d02f-11ec-8c78-005056b86db5"][j]
+                                    .name
+                            );
+                        }
+                    }
                 }
             }
-            console.log('fileid=========',fileid)  
-
-
-            let message = ''
-            if (_this.radio == 0) {
+            let message = "";
+            if (type == 1) {
                 message = `NOTICE
-Role: 提供的参考资料中读取10个最重要的知识点(知识点水平限制在小学和初中,作为ppt内容。
+Role: 从用户提供的参考资料中提取5个最重要的学科概念${mclass.length ? "(水平限制在{面向年级}中)" : ""},作为ppt内容。
 Output: Provide your output in json format.
+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 
 ## 任务
-请根据用户给你的参考资料,生成关于${this.courseName},为教师生成这节课的教学ppt,页数在20页左右。PPT的内容主要是讲解该课程中所有可能涉及到的知识点。
+将参考#参考资料,为教师生成这节课的教学ppt。PPT的内容主要是讲解该课程中所有可能涉及到的知识点,每个知识点用1页讲解你的输出应该符合#Format example
 
 ## 工作流
-1. 提供的参考资料中读取10个最重要的知识点(知识点水平限制在小学和初中,作为ppt内容。
-2. 针对10个知识点中的每个,你使用1~3页ppt详细的对知识点进行讲解。你的讲解词应该在100token左右
-3. 讲解完所有知识点后,再根据知识点出5道单选题(放在5页ppt中)。
+1. 针对大纲中的每个知识点,生成200字左右的详细讲解。你的语气应该让小学或初中的学生清晰易懂的讲解。请尽可能的详细,这对我很重要。
+2. 针对大纲中的每个测试,详细设计不同测试题目,例如单选,多选,对错题等。
 
-# Format example
-[{"page": "页码(数字)","title": "标题","task": "对应教学任务:依据用户输入的参考资料而定,如果用户未提供则不输出","points": "知识点讲解:针对知识点的详细讲解,你的语气应该让小学或初中的学生清晰易懂的讲解。你的讲解词在100 token左右。请尽可能的详细,这对我很重要。"}]`
-            } else if (_this.radio == 1) {
+## 限制
+- 你不能输出错误的知识,如果你实在不清楚,修改大纲中的知识点。
+- 你不能输出违反伦理的内容
 
-            } else if (_this.radio == 2) {
+## 工作流
+1. 从用户提供的参考资料中提取5个最重要的学科概念,并输出。
+2. 分解每个学科概念为几个子知识点
+3. 简要描述每个知识点
+4.生成5个测试题以考察学生的掌握情况
 
-            }
+## 参考资料
+${_this.outline}
 
+# Format example
+[{"page": "页码(数字)","title": "学科概念(请从给你的大纲中摘取)(标题)","task": "知识点(请从给你的大纲中摘取)(子标题)","points": "知识点讲解:针对大纲中的每个知识点,生成200字左右的详细讲解。你的语气应该让小学或初中的学生清晰易懂的讲解。你的讲解词在100 token左右。请尽可能的详细,这对我很重要。"}]`;
+            } else {
+                message = `# 任务
+请根据参考资料,生成关于${this.courseName},为教师生成这节课的教学ppt的大纲,大纲的主要内容课程知识点的讲解与相关练习和测试。你的输出应该符合#输出格式
+
+# 工作流
+1. 从用户提供的参考资料中提取5个最重要的学科概念${mclass.length ? "(水平限制在{面向年级}中)" : ""},并输出。
+2. 分解每个学科概念为几个子知识点
+3. 简要描述每个知识点
+4.生成5个测试题以考察学生的掌握情况
+
+${mclass.length ? "#参考资料\n面向年级:" + mclass.join(",") : ""}
+
+# 输出格式
+- 标题:学科概念1
+  --知识点:知识点1
+  --知识点:知识点2
+  --知识点:知识点3
+  --知识点:知识点4
+  --知识点:知识点5
+
+# 限制
+- 你不能输出错误的知识,如果你实在不清楚,输出“对不起,我不确定”
+- 你不能输出违反伦理的内容
+`;
+            }
 
             // let params = JSON.stringify({
             //     // "model": "Chat",
@@ -245,106 +290,128 @@ Instruction: Based on the context, follow "Format example", write content.
             //     console.log(error);
             // });
 
-
             let parm = {
-                assistant_id: '6063369f-289a-11ef-8bf4-12e77c4cb76b',
-                message: [{"type":"text", "text":message}],
+                assistant_id:
+                    type == 1
+                        ? "6063369f-289a-11ef-8bf4-12e77c4cb76b"
+                        : "f8e1ebb2-2e0d-11ef-8bf4-12e77c4cb76b",
+                message: [{ type: "text", text: message }],
                 session_name: uuidv4(),
                 userId: this.userid,
-                file_ids: fileid.length ? [...fileid] : '',
-            }
-            _this.loading = true
+                file_ids: fileid.length ? [...fileid] : "",
+            };
+            _this.loading = true;
             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);
-                    try {
-                        let _data = JSON.parse(data.message.replaceAll('```json','').replaceAll('```',''))
-                        _this.createPpt(_data)
-                    } catch (e) {
-                        console.log('error_________________'+e);
-                        // _this.$message.error(data.message)
-                        try {
-                            // let _data = JSON.parse(data.message.match(/(?<=```json).*?(?=```)/)[0])
-                            var message = data.message;
-                            var jsonStart = message.indexOf("```json") + 7; // `+ 7` 是为了跳过 ```json
-                            var jsonEnd = message.indexOf("```", jsonStart);
-                            if (jsonStart !== -1 && jsonEnd !== -1) {
-                                var jsonString = message.substring(jsonStart, jsonEnd).trim();
-                                var _data2 = JSON.parse(jsonString);
-                                _this.createPpt(_data2);
-                            }else {
-                                _this.$message.error('生成失败,正在重新生成')
-                                _this.aiGet()
+                    console.log(response);
+                    let data = response.data.FunctionResponse;
+                    if (data.message) {
+                        console.log(data.message);
+                        if (type == 1) {
+                            try {
+                                let _data = JSON.parse(
+                                    data.message.replaceAll("```json", "").replaceAll("```", "")
+                                );
+                                _this.createPpt(_data);
+                                _this.steps = 2;
+                            } catch (e) {
+                                console.log("error_________________" + e);
+                                // _this.$message.error(data.message)
+                                try {
+                                    // let _data = JSON.parse(data.message.match(/(?<=```json).*?(?=```)/)[0])
+                                    var message = data.message;
+                                    var jsonStart = message.indexOf("```json") + 7; // `+ 7` 是为了跳过 ```json
+                                    var jsonEnd = message.indexOf("```", jsonStart);
+                                    if (jsonStart !== -1 && jsonEnd !== -1) {
+                                        var jsonString = message
+                                            .substring(jsonStart, jsonEnd)
+                                            .trim();
+                                        var _data2 = JSON.parse(jsonString);
+                                        _this.createPpt(_data2);
+                                        _this.steps = 2;
+                                    } else {
+                                        _this.$message.error("生成失败,正在重新生成");
+                                        _this.aiGet(type);
+                                    }
+                                } catch (error) {
+                                    _this.$message.error("生成失败,正在重新生成");
+                                    _this.aiGet(type);
+                                    _this.loading = false;
+                                }
                             }
-                        } catch (error) {
-                            _this.$message.error('生成失败,正在重新生成')
-                            _this.aiGet()
-                            _this.loading = false   
+                        } else {
+                            _this.outline = data.message;
+                            _this.steps = 1;
+                            _this.loading = false;
                         }
                     }
-                }
                 })
                 .catch((error) => {
-                _this.loading = false
-                console.log(error);
+                    _this.loading = false;
+                    console.log(error);
                 });
         },
         createPpt(array) {
             // 1. 创建PPT
-            const pres = new Pptxgen()
+            const pres = new Pptxgen();
             for (var i = 0; i < array.length; i++) {
                 // 2. 创建一个PPT页面,每调用一次 pres.addSlide() 都可以生成一张新的页面
                 // 建议把每个页面的构造抽成一个个函数,然后通过函数调用生成新页面,代码不会很乱
-                const _slide = pres.addSlide()
+                const _slide = pres.addSlide();
 
                 // 3. 调用addTetx(),在PPT页面中插入文字“Hello World from PptxGenJS...”
                 // 括号里面是对文字的配置,文字横坐标x为1.5,纵坐标y为1.5,字体颜色 363636……
                 // 关于坐标长度与px的转换 x 1 = 127~128px 左右
-                const tempResult1 = array[i].title
+                const page = i+1 > 10 ? i+1 : "0"+(i+1);
+                _slide.addText(page, {
+                    x: 0.2, // 横坐标
+                    y: 0.5,
+                    color: "363636",
+                    fontSize: 20, // 字号
+                    align: "left",
+                });
+                const tempResult1 = array[i].title;
                 _slide.addText(tempResult1, {
-                    x: 0.5, // 横坐标
+                    x: 0.6, // 横坐标
                     y: 0.5,
-                    color: '363636',
-                    fontSize: 24, // 字号
-                    fill: { color: 'F1F1F1' },
-                    align: 'center'
-                })
-                const tempResult2 = array[i].task
+                    color: "363636",
+                    fontSize: 28, // 字号
+                    bold: true,
+                    align: "left",
+                });
+                const tempResult2 = array[i].task;
                 _slide.addText(tempResult2, {
-                    x: 0.5, // 横坐标
-                    y: 2,
-                    color: '363636',
+                    x: 0.6, // 横坐标
+                    y: 1.5,
+                    color: "363636",
                     fontSize: 18, // 字号
-                    fill: { color: 'F1F1F1' },
-                    align: 'center'
-                })
-                const tempResult3 = array[i].points
+                    align: "left",
+                });
+                const tempResult3 = array[i].points;
                 _slide.addText(tempResult3, {
-                    x: 0.5, // 横坐标
-                    y: 4,
-                    color: '363636',
+                    x: 0.6, // 横坐标
+                    y: 3,
+                    w: "60%",
+                    color: "363636",
                     fontSize: 18, // 字号
-                    fill: { color: 'F1F1F1' },
-                    align: 'center'
-                })
+                    align: "left",
+                });
             }
 
             // 获取PPTX文件的ArrayBuffer
 
             // 保存为 Blob 并处理
-            pres.write('blob').then((blob) => {
+            pres.write("blob").then((blob) => {
                 // 现在你有了一个 Blob 对象
                 console.log(blob);
 
-                const file = new File([blob], 'aiPpt.pptx', { type: "application/vnd.openxmlformats-officedocument.presentationml.presentation" });
-                console.log(pres)
-                this.beforeUpload(file)
+                const file = new File([blob], "aiPpt.pptx", {
+                    type: "application/vnd.openxmlformats-officedocument.presentationml.presentation",
+                });
+                console.log(pres);
+                this.beforeUpload(file);
             });
-
         },
         beforeUpload(event) {
             var file = event;
@@ -382,23 +449,23 @@ Instruction: Based on the context, follow "Format example", write content.
                         // console.log("Uploaded : " + parseInt((evt.loaded * 80) / evt.total) + '%');
                     })
                     .send(function (err, data) {
-                        _this.loading = false
+                        _this.loading = false;
                         if (err) {
                             _this.$message.error("上传失败");
                         } else {
-                            _this.url = data.Location
+                            _this.url = data.Location;
                             _this.uJson = {
-                              name: file.name,
-                              url: data.Location,
-                              type: 3,
-                            }
+                                name: file.name,
+                                url: data.Location,
+                                type: 3,
+                            };
                             console.log(data.Location);
                         }
                     });
             }
         },
     },
-}
+};
 </script>
 
 <style scoped>
@@ -418,7 +485,6 @@ Instruction: Based on the context, follow "Format example", write content.
     padding: 0px;
 }
 
-
 .dialog_diy>>>.el-dialog__title {
     color: #fff;
 }
@@ -435,7 +501,6 @@ Instruction: Based on the context, follow "Format example", write content.
     color: #fff;
 }
 
-
 .dialog_diy>>>.el-dialog__body,
 .dialog_diy>>>.el-dialog__footer {
     background: #fafafa;
@@ -473,7 +538,6 @@ Instruction: Based on the context, follow "Format example", write content.
     border: 1.5px solid #3681fc !important;
 }
 
-
 .t_box {
     display: flex;
     margin-bottom: 15px;

+ 1 - 1
src/components/pages/aiAddCourse/aiCreateVideoDialog.vue

@@ -118,7 +118,7 @@ export default {
             let _this = this
             _this.loading = true
             this.ajax
-                .get(`https://www.googleapis.com/youtube/v3/search?key=AIzaSyBUvNQ5Wyua4PbStE2vp3t7MIY4htry-4M&part=snippet&q=${this.detail}`)
+                .get(`https://www.googleapis.com/youtube/v3/search?key=AIzaSyBUvNQ5Wyua4PbStE2vp3t7MIY4htry-4M&part=snippet&q=${this.detail}&maxResults=10`)
                 .then((response) => {
                     console.log(response);
                     _this.data = response.data.items

+ 2 - 2
src/components/pages/course.vue

@@ -594,8 +594,8 @@ export default {
       // this.$router.push(path);
     },
     oepnTemplate(){
-      this.goToCourseTemplate('');
-      // this.dialogVisibleTemplate = true;
+      // this.goToCourseTemplate('');
+      this.dialogVisibleTemplate = true;
     },
     goToCourseTemplate(tid){
       this.$router.push(

Nem az összes módosított fájl került megjelenítésre, mert túl sok fájl változott