lsc 1 year ago
parent
commit
61499a3e86

+ 1 - 1
dist/index.html

@@ -25,7 +25,7 @@
       height: 100%;
       width: 100%;
       background: #e6eaf0;
-    }</style><link href=./static/css/app.522811d44c4ce498ed5569229ec2fe73.css rel=stylesheet></head><body><div id=app></div><script type=text/javascript src=./static/js/manifest.3512a67a6213c2df4180.js></script><script type=text/javascript src=./static/js/vendor.1b8e037bd3fbbd358d74.js></script><script type=text/javascript src=./static/js/app.51f26eed99cfc68ddaf8.js></script></body></html><script>function stopSafari() {
+    }</style><link href=./static/css/app.978c9c293c3d2c14cbd65c37e251e8df.css rel=stylesheet></head><body><div id=app></div><script type=text/javascript src=./static/js/manifest.3512a67a6213c2df4180.js></script><script type=text/javascript src=./static/js/vendor.1b8e037bd3fbbd358d74.js></script><script type=text/javascript src=./static/js/app.53b5f449f9cbf85e4094.js></script></body></html><script>function stopSafari() {
     //阻止safari浏览器双击放大功能
     let lastTouchEnd = 0  //更新手指弹起的时间
     document.documentElement.addEventListener("touchstart", function (event) {

File diff suppressed because it is too large
+ 0 - 0
dist/static/css/app.522811d44c4ce498ed5569229ec2fe73.css.map


File diff suppressed because it is too large
+ 0 - 0
dist/static/css/app.978c9c293c3d2c14cbd65c37e251e8df.css


File diff suppressed because it is too large
+ 0 - 0
dist/static/css/app.978c9c293c3d2c14cbd65c37e251e8df.css.map


File diff suppressed because it is too large
+ 0 - 0
dist/static/js/app.51f26eed99cfc68ddaf8.js


File diff suppressed because it is too large
+ 0 - 0
dist/static/js/app.53b5f449f9cbf85e4094.js


File diff suppressed because it is too large
+ 0 - 0
dist/static/js/app.53b5f449f9cbf85e4094.js.map


File diff suppressed because it is too large
+ 0 - 0
dist/static/js/manifest.3512a67a6213c2df4180.js.map


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

@@ -3330,7 +3330,7 @@
             </button>
             <div class="spanName">选择本地文件</div>
           </div>
-          <div>
+          <!-- <div>
             <el-button @click="getAllBanner" v-if="isSysPic == false">选择系统文件</el-button>
             <div class="isSysPic" v-if="isSysPic == true && cover.length > 0">
               <img :src="cover[0].url" alt="" />
@@ -3339,7 +3339,7 @@
               </div>
             </div>
             <div class="spanName">选择系统文件</div>
-          </div>
+          </div> -->
           <div>
             <el-button @click="searchImageValue = courseName, resetImage()" v-if="isSysPic2 == false">选择网络文件</el-button>
             <div class="isSysPic" v-if="isSysPic2 == true && cover.length > 0">

+ 2 - 2
src/components/pages/easy/addCourse.vue

@@ -4181,7 +4181,7 @@
             </button>
             <div class="spanName">选择本地文件</div>
           </div>
-          <div>
+          <!-- <div>
             <el-button @click="getAllBanner" v-if="isSysPic == false">选择系统文件</el-button>
             <div class="isSysPic" v-if="isSysPic == true && cover.length > 0">
               <img :src="cover[0].url" alt="" />
@@ -4190,7 +4190,7 @@
               </div>
             </div>
             <div class="spanName">选择系统文件</div>
-          </div>
+          </div> -->
           <div>
             <el-button @click="searchImageValue = courseName, resetImage()" v-if="isSysPic2 == false">选择网络文件</el-button>
             <div class="isSysPic" v-if="isSysPic2 == true && cover.length > 0">

+ 2 - 2
src/components/pages/synergyCourse/addCourse.vue

@@ -2275,7 +2275,7 @@
             </button>
             <div class="spanName">选择本地文件</div>
           </div>
-          <div>
+          <!-- <div>
             <el-button @click="getAllBanner" v-if="isSysPic == false">选择系统文件</el-button>
             <div class="isSysPic" v-if="isSysPic == true && cover.length > 0">
               <img :src="cover[0].url" alt="" />
@@ -2284,7 +2284,7 @@
               </div>
             </div>
             <div class="spanName">选择系统文件</div>
-          </div>
+          </div> -->
           <div>
             <el-button @click="searchImageValue = courseName, resetImage()" v-if="isSysPic2 == false">选择网络文件</el-button>
             <div class="isSysPic" v-if="isSysPic2 == true && cover.length > 0">

+ 2 - 2
src/components/pages/task/addCourse.vue

@@ -4521,7 +4521,7 @@
             </button>
             <div class="spanName">选择本地文件</div>
           </div>
-          <div>
+          <!-- <div>
             <el-button @click="getAllBanner" v-if="isSysPic == false">选择系统文件</el-button>
             <div class="isSysPic" v-if="isSysPic == true && cover.length > 0">
               <img :src="cover[0].url" alt="" />
@@ -4530,7 +4530,7 @@
               </div>
             </div>
             <div class="spanName">选择系统文件</div>
-          </div>
+          </div> -->
           <div>
             <el-button @click="searchImageValue = courseName, resetImage()" v-if="isSysPic2 == false">选择网络文件</el-button>
             <div class="isSysPic" v-if="isSysPic2 == true && cover.length > 0">

+ 4 - 4
src/components/pages/test/add/components/checkOrder.vue

@@ -108,7 +108,7 @@ export default {
         selectType() {
             return function (item, index) {
                 if (item.ttype == 1) {
-                    return index + 1 + "、" + this.options2[item.type];
+                    return index + 1 + "、" + this.options2[item.type] + (item.json && this.etype != 'edit' ? `:${item.json.title}` : "");
                 } else if (item.ttype == 2) {
                     return `第${index + 1}组 (共${item.array.length}题)`;
                 } else if (item.ttype == 3) {
@@ -204,8 +204,8 @@ export default {
                         this.manualJson[_check[0]].array[_check[1]].array.splice(_check[2], 1)
                     }
                     this.$emit("update:checkC", "")
-                    this.$forceUpdate()
                     this.$emit("changeJson", this.manualJson);
+                    this.$forceUpdate()
                 })
                 .catch(() => { });
         },
@@ -295,8 +295,8 @@ export default {
     display: block;
     background-image: url('../../../../../assets/icon/new/icon_course_drag.png');
     background-size: 100% 100%;
-    width: 20px;
-    height: 20px;
+    min-width: 20px;
+    min-height: 20px;
     cursor: pointer;
 }
 

+ 124 - 29
src/components/pages/test/add/setInfo/aiCreate.vue

@@ -1,24 +1,26 @@
 <template>
   <div>
-    <el-dialog
-      title="智能创建"
-      :visible.sync="aiDialogVisible"
-      :append-to-body="true" 
-      width="600px"
-      :before-close="handleClose"
-      class="pub_dialog_diy" v-loading="loading">
+    <el-dialog title="智能创建" :visible.sync="aiDialogVisible" :append-to-body="true" width="600px"
+      :before-close="handleClose" class="pub_dialog_diy" v-loading="loading">
       <div>
         <div class="ex_box">
           例子:请你以富文本的形式给我出三个关于小学数学单位换算的选择题,每个选择题选项不少于4个,需要答案,但不需要解释,符号请使用中文的
         </div>
         <div class="ac_box">
-          <el-input v-model="text" placeholder="请在这里输入要发送的消息" size="normal" type="textarea" resize="none" :rows="3"></el-input>
+          <el-input v-model="text" placeholder="请在这里输入要发送的消息" size="normal" type="textarea" resize="none"
+            :rows="3"></el-input>
           <el-button type="primary" size="mini" @click="generate" style="margin-left:10px">生成</el-button>
         </div>
-        <div class="ac_content">
+        <div class="ac_content" v-if="aiCreate.length">
           <div class="title">生成内容:</div>
-          <div class="box" v-if="aiCreate">
-            <div></div>
+          <div class="box">
+            <div v-for="(item, index) in aiCreate" :key="index" class="choice">
+              <div class="title">{{ `${index + 1}:${item.title}` }}</div>
+              <div class="options">
+                <span v-for="(option, oIndex) in item.options" :key="`${index}-${oIndex}`">{{ option }}</span>
+              </div>
+              <div class="answer">{{ `答案:${item.answer}` }}</div>
+            </div>
           </div>
         </div>
       </div>
@@ -27,7 +29,7 @@
         <el-button type="primary" @click="exportT">导入</el-button>
       </div>
     </el-dialog>
-    
+
   </div>
 </template>
 
@@ -38,24 +40,25 @@ export default {
     aiJson: {
       type: Array,
     },
-    aiDialogVisible:{
+    aiDialogVisible: {
       type: Boolean,
     }
   },
   data() {
     return {
-      text:"",
-      aiCreate:"",
-      loading:false
+      text: "",
+      aiCreate: [],
+      aiType: "",
+      loading: false
     }
   },
   methods: {
-    handleClose(done){
+    handleClose(done) {
       this.close()
       done()
     },
     close() {
-      this.$emit('update:aiDialogVisible',false)
+      this.$emit('update:aiDialogVisible', false)
     },
     guid() {
       var _num,
@@ -71,11 +74,21 @@ export default {
       }
       return _guid;
     },
-    generate(){
-      if(this.text == ""){
+    generate() {
+      if (this.text == "") {
         this.$message.error("请输入要发送的消息")
         return
       }
+
+      if (this.text.indexOf("选择题") !== -1) {
+        this.aiType = 1
+      } else if (this.text.indexOf("问答题") !== -1) {
+        this.aiType = 2
+      } else if (this.text.indexOf("填空题") !== -1) {
+        this.aiType = 3
+      } else if (this.text.indexOf("添加文档") !== -1) {
+        this.aiType = 4
+      }
       this.loading = true
       let param = {
         model: "gpt-3.5-turbo",
@@ -116,7 +129,7 @@ export default {
         }
       );
     },
-    generate2(aiReturn){
+    generate2(aiReturn) {
       this.loading = true
       let param = {
         model: "gpt-3.5-turbo",
@@ -128,7 +141,7 @@ export default {
         messages: [
           {
             role: "user",
-            content: `${JSON.stringify(aiReturn)},要求返回格式是Array [{"title":"",opition:[],answer:[]}]`
+            content: `${JSON.stringify(aiReturn)},要求返回格式是Array [{"title":"",options:[],answer:[]}]`
           },
         ],
         uid: this.guid(),
@@ -146,6 +159,8 @@ export default {
             return;
           }
           let aiCreate = res.data.FunctionResponse.choices[0].message.content;
+          aiCreate = JSON.parse(aiCreate)
+          console.log(aiCreate)
           this.aiCreate = aiCreate;
           this.loading = false
         },
@@ -154,31 +169,111 @@ export default {
           this.loading = false
         }
       );
+    },
+    exportT() {
+      if (!this.aiCreate.length) {
+        this.$message.error("请先创建Ai内容!");
+        return;
+      }
+      if(this.aiType !== 1){
+        this.$message.error("目前只支持选择题的创建!输入内容必须包含选择题三个字!");
+        return;
+      }
+      var json = JSON.parse(JSON.stringify(this.aiJson))
+      let array = []
+      let englishIndex = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']
+      if(this.aiType === 1){
+        for (var i = 0; i < this.aiCreate.length; i++) {
+          let answer = []
+          let type = 1
+          if (this.aiCreate[i].answer) {
+            if (this.aiCreate[i].answer.length > 1) {
+              type = 2
+              for (var j = 0; j < this.aiCreate[i].answer.length; j++) {
+                answer.push(englishIndex.indexOf(this.aiCreate[i].answer[j].toLocaleUpperCase()))
+              }
+            } else {
+              answer = [englishIndex.indexOf(this.aiCreate[i].answer[0].toLocaleUpperCase())]
+            }
+          }
+
+          let options = []
+          for (var j = 0; j < this.aiCreate[i].options.length; j++) {
+            options.push({
+              img: "",
+              option: this.aiCreate[i].options[j]
+            })
+          }
+          array.push(
+            {
+              json: {
+                answer: answer,
+                array: options,
+                title: this.aiCreate[i].title,
+                type: type
+              },
+              ttype: 1,
+              type: 1
+            }
+          )
+        }
+      }
+      if (!json.length || json[0].ttype == 1) {
+        json = [...json, ...array]
+      } else if((json[0].ttype == 2 || json[0].ttype == 3) && !json[0].array.length){
+        json[0].array = array
+      } else if(json[0].ttype == 2 && json[0].array.length){
+        json[0].array = [...json[0].array, ...array]
+      } else if(json[0].ttype == 3 && json[0].array.length){
+        if(json[0].array[0].ttype == 2){
+          json[0].array[0].array = [...json[0].array[0].array, ...array]
+        }else {
+          json[0].array = [...json[0].array, ...array]
+        }
+      }
+      this.$emit("update:aiJson", json)
+      this.close()
     }
   },
 }
 </script>
 
 <style scoped>
-.ac_box{
+.ac_box {
   display: flex;
   width: 100%;
   align-items: flex-end;
   margin-bottom: 10px;
 }
 
-.ex_box{
+.ex_box {
   margin-bottom: 10px;
   color: #909090;
 }
 
-.ac_content{
+.ac_content {}
 
-}
-.ac_content > .title{
+.ac_content>.title {
   margin-bottom: 10px;
 }
-.ac_content > .box{
-  
+
+.ac_content>.box {}
+
+.ac_content>.box>.choice+.choice {
+  margin-top: 10px;
+}
+
+.ac_content>.box>.choice>div+div {
+  margin-top: 10px;
+}
+
+.ac_content>.box>.choice>.options {
+  display: flex;
+  flex-wrap: wrap;
+}
+
+.ac_content>.box>.choice>.options>span {
+  margin-right: 10px;
+  margin-bottom: 5px;
 }
 </style>

+ 1 - 1
src/components/pages/test/add/setInfo/manualCreated.vue

@@ -75,7 +75,7 @@ export default {
         },
         changeJson(json) {
             this.checkJson = json;
-            this.$emit("update:cJson", json);
+            this.$emit("update:manualJson", json);
         },
         addCheck() {
             if (!this.topicType) {

Some files were not shown because too many files changed in this diff