lsc 10 месяцев назад
Родитель
Сommit
b0904b755a

+ 1 - 1
dist/index.html

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

Разница между файлами не показана из-за своего большого размера
+ 0 - 0
dist/static/css/app.1c77ed4aa0cbdb1859b5785e8e6e144d.css


Разница между файлами не показана из-за своего большого размера
+ 0 - 0
dist/static/css/app.1c77ed4aa0cbdb1859b5785e8e6e144d.css.map


Разница между файлами не показана из-за своего большого размера
+ 0 - 0
dist/static/css/app.3b7ea0cdcda135c07e7f45387f91673d.css.map


Разница между файлами не показана из-за своего большого размера
+ 0 - 0
dist/static/js/app.1a1d09dcf5c24bc11a27.js


Разница между файлами не показана из-за своего большого размера
+ 0 - 0
dist/static/js/app.1a1d09dcf5c24bc11a27.js.map


Разница между файлами не показана из-за своего большого размера
+ 0 - 0
dist/static/js/manifest.571c38d63f24b1ae9e16.js.map


+ 1 - 0
src/assets/css/button.css

@@ -198,6 +198,7 @@
   background-image: url(../icon/new/icon_setting.png);
 }
 
+.r_pub_button_edit,
 .r_pub_button_op,
 .r_pub_button_retrun {
   color: #0061FF;

+ 11 - 0
src/assets/icon/course/aiEdit.svg

@@ -0,0 +1,11 @@
+<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
+<g clip-path="url(#clip0_116_14)">
+<path d="M12.1088 14.9675H8.39495L7.67614 17.5H5.3999L9.23357 5.40002H11.1504L14.9841 17.5H12.7078L12.1088 14.9675ZM8.87416 12.9977H11.5098L10.192 8.49537L8.87416 12.9977ZM17.4999 17.5H15.3435V5.40002H17.4999V17.5Z" fill="#4F4F4F"/>
+<path d="M12.0094 1.54089C6.34728 1.54089 1.70752 6.10201 1.70752 11.7641C1.70752 17.4262 6.34728 22.0659 12.0094 22.0659C17.6714 22.0659 22.3112 17.4262 22.3112 11.7641C22.3112 6.10201 17.6714 1.54089 12.0094 1.54089ZM12.0094 21.0436C6.89776 21.0436 2.72984 16.8757 2.72984 11.7641C2.72984 6.65249 6.89776 2.48457 12.0094 2.48457C17.121 2.48457 21.2889 6.65249 21.2889 11.7641C21.2889 16.8757 17.121 21.0436 12.0094 21.0436Z" fill="#4F4F4F" stroke="#4F4F4F" stroke-width="0.8"/>
+</g>
+<defs>
+<clipPath id="clip0_116_14">
+<rect width="22" height="22" fill="white" transform="translate(1 1)"/>
+</clipPath>
+</defs>
+</svg>

+ 185 - 4
src/components/pages/aiAddCourse/addCourse.vue

@@ -125,7 +125,7 @@
                                 border-radius: 5px;
                                 font-weight: 600;
                                 padding: 12px 14px 12px 71px;
-                              " />
+                              "  @change="setCover"/>
                             <el-switch v-model="isTeacherSee" active-text="是否公开此课程"
                               style="justify-content: center; width: 200px"></el-switch>
                           </div>
@@ -172,7 +172,7 @@
                         </div>
                       </div>
                     </div>
-                    <div class="right_first">
+                    <div class="right_first" v-loading="imageloading2">
                       <!-- <div class="ai_box">
                       <div class="ai_content" @click="openAI"><img src="../../../assets/icon/new/ai.png"/><span>AI共创</span></div>
                     </div> -->
@@ -675,12 +675,16 @@
                     </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>
+                        v-model="item.taskDetail3" v-if="item.isTask3"></textarea>
+                      <div class="markBox" v-html="MarkdownT(item.taskDetail3)" v-else></div>
                       <div class="op_box">
                         <div class="op_remark">*可以将需要优化的建议添加在任务描述后,点击“智能优化”,自动进行修改</div>
-                        <div class="r_pub_button_op"
+                        <div style="display: flex;">
+                          <div class="r_pub_button_op"
                           @contextmenu.prevent="openAiDialog(1, 'teacherDetail', item.taskDetail3, index)"
                           @click="openAiDialog(2, 'teacherDetail', item.taskDetail3, index)">智能优化</div>
+                          <div class="r_pub_button_edit" style="margin-left:10px" @click="editTask3(index)">{{ item.isTask3 ? '确定' : '编辑'}}</div>
+                        </div>
                       </div>
                     </div>
                   </div>
@@ -5105,6 +5109,7 @@ import aiDialog from './aiDialog'
 import aiTips from './aiTips.vue'
 import tipsDialog from './tipsDialog.vue'
 import { v4 as uuidv4 } from "uuid";
+import MarkdownIt from "markdown-it";
 
 export default {
   components: {
@@ -5207,6 +5212,7 @@ export default {
       oid: this.$route.query.oid,
       org: this.$route.query.org,
       role: this.$route.query.role,
+      aiId: this.$route.query.aiId != undefined ? this.$route.query.aiId : "",
       cid: this.$route.query.cid != undefined ? this.$route.query.cid : "",
       dialogVisibleTable: false,
       dialogVisibleWord: false,
@@ -5360,6 +5366,7 @@ export default {
       isPasteChoice: false,
       imageList: [],
       imageloading: false,
+      imageloading2: false,
       searchImageValue: "",
       ppage: 1,
       toolsData: toolsData,
@@ -5569,6 +5576,13 @@ export default {
         return this.grade.length ? _c2.join("、") : "";
       };
     },
+    MarkdownT() {
+      return function (c) {
+        let md = new MarkdownIt();
+        return c
+          ? md.render(c) : "";
+      };
+    },
   },
   watch: {
     unitIndex(newValue, oldValue) {
@@ -10630,6 +10644,66 @@ export default {
             console.error(err);
           });
       }
+
+      if(this.aiId){
+        let params = {
+          cid: this.aiId,
+        };
+        this.ajax
+          .get(this.$store.state.api + "select_course_detail", params)
+          .then((res) => {
+ 
+            this.$forceUpdate();
+            this.courseName = res.data[0][0].title;
+            this.courseText = res.data[0][0].brief;
+            this.courseText2 = res.data[0][0].reBrief;
+            this.cover = JSON.parse(res.data[0][0].cover);
+            this.noneBtnImg = this.cover.length >= 1;
+            if (res.data[0][0].refile) {
+              this.infoData = JSON.parse(res.data[0][0].refile)
+            }
+
+            this.checkboxList2 = res.data[0][0].juri
+              ? res.data[0][0].juri.split(",")
+              : [];
+            this.inviteCode = [];
+            for (var i = 0; i < res.data[2].length; i++) {
+              this.inviteCode.push({
+                cid: res.data[2][i].classid,
+                ic: res.data[2][i].code,
+              });
+            }
+
+            this.checkboxList3 = res.data[0][0].course_teacher
+              ? res.data[0][0].course_teacher.split(",")
+              : [];
+            this.isTeacherSee = res.data[0][0].open == 1 ? true : false;
+            this.myWord = res.data[0][0].template;
+            this.templateC.id = "123";
+            this.courseTypeId = [];
+            for (var i = 0; i < res.data[1].length; i++) {
+              this.courseTypeId.push(res.data[1][i].typeid);
+            }
+            console.log(this.courseTypeId);
+
+           
+            this.setMan();
+            this.unitJson[
+              this.unitIndex
+            ].chapterInfo[0].taskJson[0].toolOpen = true;
+
+            this.$forceUpdate();
+            setTimeout(() => {
+              this.checkEva(this.evalua);
+              setTimeout(() => {
+                this.checkEva(this.evalua);
+              }, 100);
+            }, 100);
+          })
+          .catch((err) => {
+            console.error(err);
+          });
+      }
       // if(this.cidType != 1 && this.templateid == ''){
       //   this.promptShow = true
       // }
@@ -11998,6 +12072,37 @@ export default {
         this.isPasteTask = true;
       }
     },
+    setCover() {
+      var _this = this;
+      if(_this.cover.length){
+        return;
+      }
+      _this.imageloading2 = true
+      _this.ajax
+        .post("https://gpt.cocorobo.cn/search_image", {
+          page: _this.ppage,
+          pagesize: 9,
+          query: _this.courseName,
+        })
+        .then(function (response) {
+          // console.log(response.data.data);
+          var data = response.data.FunctionResponse.result;
+          _this.cover = [];
+          setTimeout(() => {
+              _this.cover[0] = {
+              name: "网络图片.png",
+              url: data[0].thumbnail
+            };
+            _this.imgChange1(null, null, 1, null);
+            _this.$forceUpdate();
+          }, 0);
+          _this.imageloading2 = false
+        })
+        .catch(function (error) {
+          _this.imageloading2 = false
+          console.log(error);
+        });
+    },
     searchImage() {
       var _this = this;
       _this.imageList = [];
@@ -12458,6 +12563,14 @@ export default {
       this.aiJson[pan] = string
       this.$forceUpdate();
     },
+    editTask3(index){
+      if(this.unitJson[0].chapterInfo[0].taskJson[index].isTask3){
+        this.unitJson[0].chapterInfo[0].taskJson[index].isTask3 = false
+      }else {
+        this.unitJson[0].chapterInfo[0].taskJson[index].isTask3 = true
+      }
+      this.$forceUpdate();
+    },
     openAiDialog(clickType, type, callback, index, tindex) {
       this.clickType = clickType
       let sub = []
@@ -18007,4 +18120,72 @@ ol {
 .text_panel>>>.text {
   height: 400px;
 }
+
+.markBox{
+  padding: 20px 14px;
+  line-height: 29px;
+  font-size: 16px;
+  background: #f4f4f4;
+  border-radius: 5px;
+}
+
+/* table 样式 */
+.markBox >>> table {
+  border-top: 1px solid #ccc;
+  border-left: 1px solid #ccc;
+}
+
+.markBox >>> table td,
+.markBox >>> table th {
+  border-bottom: 1px solid #ccc;
+  border-right: 1px solid #ccc;
+  /* padding: 20px 5px; */
+  padding: 5px 10px;
+  max-width: 0px;
+  height: 30px;
+  vertical-align: baseline;
+  box-sizing: border-box;
+}
+
+.markBox >>> table th {
+  border-bottom: 2px solid #ccc;
+  text-align: center;
+}
+
+/* blockquote 样式 */
+.markBox >>> blockquote {
+  display: block;
+  border-left: 8px solid #d0e5f2;
+  padding: 5px 10px;
+  margin: 10px 0;
+  line-height: 1.4;
+  font-size: 100%;
+  background-color: #f1f1f1;
+}
+
+/* code 样式 */
+.markBox >>> code {
+  display: inline-block;
+  /* *display: inline; */
+  zoom: 1;
+  background-color: #f1f1f1;
+  border-radius: 3px;
+  padding: 3px 5px;
+  margin: 0 3px;
+}
+
+.markBox >>> pre code {
+  display: block;
+}
+
+/* ul ol 样式 */
+.markBox >>> ul,
+ol {
+  margin: 10px 0 10px 20px;
+}
+
+.markBox >>> li,ul{
+  list-style: none;
+
+}
 </style>

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

@@ -185,8 +185,8 @@ export default {
                     this.searchDataList = res.data[0]
                     if (!this.input2) {
                         this.searchDataList.unshift({
-                            name: "默认模板",
-                            detail: "默认模板",
+                            name: "项目式学习 (Project-Based Learning, PBL)",
+                            detail: "项目式学习是一种以学生为中心的教学方法,通过实际项目和问题解决,培养学生的深度学习和应用能力。",
                             id:''
                         });
                     }

+ 19 - 1
src/components/pages/course.vue

@@ -220,6 +220,11 @@
 									<img style="height: 90%;width: 90%;" src="../../assets/icon/course/lookeye.svg">
 								</div>
     					</el-tooltip>
+							<el-tooltip effect="dark" content="Ai一下" placement="top">
+    					  <div class="t_b_Item" @click="aiCourse(item.courseId)">
+									<img src="../../assets/icon/course/aiEdit.svg">
+								</div>
+    					</el-tooltip>
 
 							<el-tooltip effect="dark" content="复制" placement="top">
     					  <div class="t_b_Item" @click="copyCourse(item.courseId)">
@@ -271,7 +276,6 @@
 									<img src="../../assets/icon/course/share.svg">
 								</div>
     					</el-tooltip>
-
 							<!-- v-if="role == '1'" -->
               <!-- <div @click="get(item)">预览</div> -->
               <!-- <div @click="jump(item.courseId)" v-else>评课</div> -->
@@ -634,6 +638,20 @@ export default {
       }
       // this.$router.push(path);
     },
+    aiCourse(courseId){
+      this.$router.push(
+          "/aiAddCourse?userid=" +
+          this.userid +
+          "&oid=" +
+          this.oid +
+          "&org=" +
+          this.org +
+          "&role=" +
+          this.role +
+          "&aiId=" +
+          courseId
+        );
+    },
     reset() {
       this.typeE = []
       this.typea = ''

Некоторые файлы не были показаны из-за большого количества измененных файлов