lsc 1 year ago
parent
commit
8059dc06fc

+ 1 - 1
dist/index.html

@@ -25,7 +25,7 @@
       height: 100%;
       width: 100%;
       background: #e6eaf0;
-    }</style><link href=./static/css/app.946e92a413f5cdd329871c2165f370eb.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.f5a1d7fb7b4bd63d79a6.js></script></body></html><script>function stopSafari() {
+    }</style><link href=./static/css/app.cd394a165ac5d81ebbab45320e098bb1.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.2846cac6c8919459dde2.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.946e92a413f5cdd329871c2165f370eb.css


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


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


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


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


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


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


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


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

@@ -185,3 +185,34 @@
   margin-right: 7px;
   background-image: url(../icon/new/icon_return.png);
 }
+
+.r_pub_button_course {
+  color: #fff;
+  background-color: #466b99;
+  font-size: 14px;
+  font-weight: 500;
+  border-radius: 4px;
+  box-sizing: border-box;
+  border: none;
+  cursor: pointer;
+  transition: all 0.2s ease-in-out;
+  padding: 12px 20px;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+  line-height: 1;
+  position: relative;
+}
+
+
+.r_pub_button_course::before {
+  content: "";
+  width: 14px;
+  height: 14px;
+  min-width: 14px;
+  min-height: 14px;
+  background-size: 100% 100%;
+  display: block;
+  margin-right: 7px;
+  background-image: url(../icon/new/upload.png);
+}

BIN
src/assets/icon/new/u_source.png


BIN
src/assets/icon/new/upload.png


+ 147 - 71
src/components/pages/addCourse.vue

@@ -660,6 +660,7 @@
                                     <!-- <div v-if="item1.type == 7" class="chapter_upload_l_i8" style="margin-left: 1px"></div> -->
                                     <div v-if="item1.type == 8" class="chapter_upload_l_i8" style="margin-left: 1px">
                                     </div>
+                                    <div v-if="item1.type == 14" class="chapter_upload_l_i14" style="margin-left: 1px"></div>
                                     <div v-if="item1.type == 12" class="chapter_upload_l_i12" style="margin-left: 1px">
                                     </div>
                                     <div v-if="item1.type == 13" class="chapter_upload_l_i13" style="margin-left: 1px">
@@ -706,6 +707,15 @@
                                   overflow: hidden;
                                   text-overflow: ellipsis;
                                 " readonly="true" @click="selectLine(itemTaskIndex, index1)" />
+                                <input :placeholder="item1.title ? item1.title : '链接'
+                                      " v-if="item1.type == 14" style="
+                                  border: none;
+                                  outline: none;
+                                  width: 80%;
+                                  white-space: nowrap;
+                                  overflow: hidden;
+                                  text-overflow: ellipsis;
+                                " readonly="true" @click="openUpdateSource(itemTaskIndex, index1)" />
                                   </div>
                                   <div class="chapter_upload_ic">
                                     <div class="chapter_upload_noSee" v-if="item1.type == 12">
@@ -750,6 +760,9 @@
                                   </div>
                                   <div class="chapter_upload_ic_edit" v-if="item1.type == 8"  @click="selectLine(itemTaskIndex, index1)">
                                     <div></div>
+                                  </div>
+                                  <div class="chapter_upload_ic_edit" v-if="item1.type == 14"  @click="openUpdateSource(itemTaskIndex, index1)">
+                                    <div></div>
                                   </div>
                                     <div class="chapter_upload_ic_r" @click.stop="
                                       deleteChapterData(
@@ -848,50 +861,50 @@
                               itemTask.chapterData.length == 0
                               "><img src="../../assets/icon/new/c_none.png" alt /></div>
                             <div v-else class="add_chapters_box" style="display: flex; flex-direction: column">
-                              <div v-for="(item1, index1) in itemTask.chapterData" :key="item1.id">
-                                <div class="chapter_upload" @click="
-                                  getChapterData(
-                                    $event,
-                                    unitIndex,
-                                    index,
-                                    index1,
-                                    item1.type
-                                  )
-                                  ">
-                                  <div class="chapter_upload_t" style="width: 100%"></div>
-                                  <div class="chapter_upload_o" style="
+                                  <div class="chapter_upload"  v-for="(item1, index1) in itemTask.chapterData" :key="item1.id" @click="
+                                    getChapterData(
+                                      $event,
+                                      unitIndex,
+                                      index,
+                                      index1,
+                                      item1.type
+                                    )
+                                    ">
+                                    <div class="chapter_upload_t" style="width: 100%"></div>
+                                    <div class="chapter_upload_o" style="
                                 position: relative;
                                 display: flex;
                                 align-items: center;
                               ">
-                                    <div class="chapter_upload_l" style="padding: 1px 0 0 10px">
-                                      <div v-if="item1.type == 2" class="chapter_upload_l_i2"></div>
-                                      <div v-if="item1.type == 3" class="chapter_upload_l_i3" style="margin-left: 1px">
-                                      </div>
-                                      <div v-if="item1.type == 6" class="chapter_upload_l_i6" style="margin-left: 1px">
-                                      </div>
-                                      <!-- <div v-if="item1.type == 7" class="chapter_upload_l_i8" style="margin-left: 1px"></div> -->
-                                      <div v-if="item1.type == 8" class="chapter_upload_l_i8" style="margin-left: 1px">
-                                      </div>
-                                      <div v-if="item1.type == 12" class="chapter_upload_l_i12" style="margin-left: 1px">
+                                      <div class="chapter_upload_l" style="padding: 1px 0 0 10px">
+                                        <div v-if="item1.type == 2" class="chapter_upload_l_i2"></div>
+                                        <div v-if="item1.type == 3" class="chapter_upload_l_i3" style="margin-left: 1px">
+                                        </div>
+                                        <div v-if="item1.type == 6" class="chapter_upload_l_i6" style="margin-left: 1px">
+                                        </div>
+                                        <!-- <div v-if="item1.type == 7" class="chapter_upload_l_i8" style="margin-left: 1px"></div> -->
+                                        <div v-if="item1.type == 8" class="chapter_upload_l_i8" style="margin-left: 1px">
+                                        </div>
+                                        <div v-if="item1.type == 14" class="chapter_upload_l_i14" style="margin-left: 1px"></div>
+                                        <div v-if="item1.type == 12" class="chapter_upload_l_i12" style="margin-left: 1px">
+                                        </div>
+                                        <div v-if="item1.type == 13" class="chapter_upload_l_i13" style="margin-left: 1px">
+                                        </div>
                                       </div>
-                                      <div v-if="item1.type == 13" class="chapter_upload_l_i13" style="margin-left: 1px">
-                                      </div>
-                                    </div>
-                                    <div class="chapter_upload_n">
-                                      <span style="
+                                      <div class="chapter_upload_n">
+                                        <span style="
                                     font-size: 14px;
                                     color: rgb(109, 109, 109);
                                     height: 14px;
-                                    line-height: 12px;
+                                    line-height: 14px;
                                   " v-if="item1.type == 2 ||
                                     item1.type == 3 ||
                                     item1.type == 7
                                     ">{{ item1.text }}-</span>
-                                      <input readonly="true" v-if="item1.type == 2 ||
-                                        item1.type == 3 ||
-                                        item1.type == 7
-                                        " v-model="item1.name" :placeholder="item1.name" @click="
+                                        <input readonly="true" v-if="item1.type == 2 ||
+                                          item1.type == 3 ||
+                                          item1.type == 7
+                                          " :placeholder="item1.name" @click="
     updataVideoT(
       $event,
       unitIndex,
@@ -909,7 +922,7 @@
                                     overflow: hidden;
                                     text-overflow: ellipsis;
                                   " />
-                                      <input :placeholder="item1.name" v-if="item1.type == 6" style="
+                                        <input :placeholder="item1.name" v-if="item1.type == 6" style="
                                     border: none;
                                     outline: none;
                                     width: 80%;
@@ -917,8 +930,8 @@
                                     overflow: hidden;
                                     text-overflow: ellipsis;
                                   " readonly="true" @click="selectAttText(itemTaskIndex, index1)" />
-                                      <input :placeholder="item1.title ? item1.title : '链接'
-                                        " v-if="item1.type == 8" style="
+                                        <input :placeholder="item1.title ? item1.title : '链接'
+                                          " v-if="item1.type == 8 || item1.type == 14" style="
                                     border: none;
                                     outline: none;
                                     width: 80%;
@@ -926,46 +939,69 @@
                                     overflow: hidden;
                                     text-overflow: ellipsis;
                                   " readonly="true" @click="selectLine(itemTaskIndex, index1)" />
-                                    </div>
-                                    <div class="chapter_upload_ic">
-                                      <div class="chapter_upload_noSee" v-if="item1.type == 12">
                                       </div>
-                                      <div class="chapter_upload_ud" style="z-index: 99">
-                                        <div class="chapter_upload_up" @click="
-                                          upCd(
+                                      <div class="chapter_upload_ic">
+                                        <div class="chapter_upload_noSee" v-if="item1.type == 12">
+                                        </div>
+                                        <div class="chapter_upload_ud" style="z-index: 99">
+                                          <div class="chapter_upload_up" @click="
+                                            upCd(
+                                              $event,
+                                              unitIndex,
+                                              index,
+                                              itemTaskIndex,
+                                              index1
+                                            )
+                                            "></div>
+                                          <div class="chapter_upload_down" @click="
+                                            downCd(
+                                              $event,
+                                              unitIndex,
+                                              index,
+                                              itemTaskIndex,
+                                              index1
+                                            )
+                                            "></div>
+                                        </div>
+                                        <div class="chapter_upload_ic_edit" v-if="item1.type == 2 ||
+                                          item1.type == 3 ||
+                                          item1.type == 12 ||
+                                          item1.type == 13 ||
+                                          item1.type == 7
+                                          "  @click.stop="
+                                          updataVideoT(
                                             $event,
                                             unitIndex,
-                                            index,
                                             itemTaskIndex,
                                             index1
                                           )
-                                          "></div>
-                                        <div class="chapter_upload_down" @click="
-                                          downCd(
-                                            $event,
-                                            unitIndex,
-                                            index,
-                                            itemTaskIndex,
-                                            index1
-                                          )
-                                          "></div>
-                                      </div>
-                                      <div class="chapter_upload_ic_r" style="position: absolute" @click.stop="
-                                        deleteChapterData(
-                                          $event,
-                                          unitIndex,
-                                          index,
-                                          index1,
-                                          itemTaskIndex
-                                        )
-                                        ">
-                                        <div></div>
+                                          ">
+                                          <div></div>
+                                        </div>
+                                        <div class="chapter_upload_ic_edit" v-if="item1.type == 6"  @click="selectAttText(itemTaskIndex, index1)">
+                                          <div></div>
+                                        </div>
+                                        <div class="chapter_upload_ic_edit" v-if="item1.type == 8"  @click="selectLine(itemTaskIndex, index1)">
+                                          <div></div>
+                                        </div>
+                                        <div class="chapter_upload_ic_edit" v-if="item1.type == 14"  @click="openUpdateSource(itemTaskIndex, index1)">
+                                          <div></div>
+                                        </div>
+                                          <div class="chapter_upload_ic_r" @click.stop="
+                                            deleteChapterData(
+                                              $event,
+                                              unitIndex,
+                                              index,
+                                              index1,
+                                              itemTaskIndex
+                                            )
+                                            ">
+                                            <div></div>
+                                          </div>
                                       </div>
                                     </div>
                                   </div>
-                                </div>
                               </div>
-                            </div>
                           </div>
                           <div class="add_info_box" style="margin: 10px 0 0">
                             <button class="c_pub_button_add pub_btn_add_img" @click="addImg($event)">
@@ -2379,14 +2415,15 @@
         <el-button type="primary" @click="isAddOrUpdateLine">确定</el-button>
       </span>
     </el-dialog>
-    <el-dialog title="添加资源" :visible.sync="dialogVisibleSource" :append-to-body="true" width="100%"
+    <el-dialog :title="updateSourcePan ? '修改资源' : '添加资源'" :visible.sync="dialogVisibleSource" :append-to-body="true" width="100%"
       :before-close="handleClose" class="dialog_diy source_diy">
       <div>
-        <sourceDialog :sourceData.sync="sourceData"></sourceDialog>
+        <sourceDialog :sourceData.sync="sourceData" :updateSourcePan="updateSourcePan"></sourceDialog>
       </div>
       <span slot="footer" class="dialog-footer">
         <el-button @click="dialogVisibleSource = false">取 消</el-button>
-        <el-button type="primary" @click="addSource">确定</el-button>
+        <el-button type="primary" @click="addSource" v-if="!updateSourcePan">确定</el-button>
+        <el-button type="primary" @click="updateSource" v-else>确定</el-button>
       </span>
     </el-dialog>
     <el-dialog title="添加课程成员" :visible.sync="dialogVisible3" :append-to-body="true" width="25%" height="80%"
@@ -3622,6 +3659,7 @@ export default {
       icode: "",
       easyArray: [2, 4],
       sourceData: {},
+      updateSourcePan: false,
       videoJson: {},
       isBtnDisplay: false,
       isStepDisplay: false,
@@ -3951,7 +3989,7 @@ export default {
     },
     closeConfirm(tool){
       this
-        .$confirm("是否保存?", "提示", {
+        .$confirm("是否保存已编辑内容?", "提示", {
           confirmButtonText: "保存",
           cancelButtonText: "不保存",
           type: "warning",
@@ -4032,7 +4070,7 @@ export default {
     },
     retrunCourse(){
       this
-        .$confirm("是否保存?", "提示", {
+        .$confirm("是否保存已编辑内容?", "提示", {
           confirmButtonText: "保存",
           cancelButtonText: "不保存",
           type: "warning",
@@ -4491,6 +4529,7 @@ export default {
       this.lineCount = i;
       this.sourceData = {};
       this.dialogVisibleSource = true;
+      this.updateSourcePan = false;
     },
     addSource() {
       if (!Object.keys(this.sourceData).length) {
@@ -4505,12 +4544,32 @@ export default {
           name: "链接",
           title: this.sourceData[keys[i]].name,
           url: this.sourceData[keys[i]].url,
-          type: 8,
+          type: 14,
+          id:keys[i]
         });
       }
       this.$forceUpdate();
       this.dialogVisibleSource = false;
     },
+    updateSource() {
+      if (!Object.keys(this.sourceData).length) {
+        this.$message.error("请选择要上传的资源");
+        return;
+      }
+      let keys = Object.keys(this.sourceData);
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].url = this.sourceData[keys[0]].url;
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].title = this.sourceData[keys[0]].name;
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].id = keys[0];
+      this.updateSourcePan = false;
+      this.$forceUpdate();
+      this.dialogVisibleSource = false;
+    },
     deleteM(i, j) {
       this.testJson.testJson[i].timuList.splice(j, 1);
     },
@@ -6178,6 +6237,17 @@ export default {
       this.lineType = 1;
       this.dialogVisible7 = true;
     },
+    openUpdateSource(itemTaskIndex, i){
+      this.sourceData = {}
+      let source = this.unitJson[this.unitIndex].chapterInfo[0].taskJson[itemTaskIndex].chapterData[i]
+      this.sourceData[source.id] = {}
+      this.sourceData[source.id].name = source.title
+      this.sourceData[source.id].url = source.url
+      this.dialogVisibleSource = true;
+      this.updateSourcePan = true;
+      this.taskCount = itemTaskIndex;
+      this.lineCount = i;
+    },
     updateLine() {
       this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
         this.taskCount
@@ -9741,6 +9811,7 @@ export default {
 .chapter_upload_l_i8,
 .chapter_upload_l_i6,
 .chapter_upload_l_i12,
+.chapter_upload_l_i14,
 .chapter_upload_l_i13 {
   width: 15px;
   height: 15px;
@@ -9759,6 +9830,11 @@ export default {
   background-image: url("../../assets/icon/new/u_url.png");
 }
 
+.chapter_upload_l_i14 {
+  background-image: url("../../assets/icon/new/u_source.png");
+}
+
+
 .chapter_upload_l_i6 {
   background-image: url("../../assets/icon/new/u_picture.png");
 }

+ 39 - 3
src/components/pages/course.vue

@@ -22,9 +22,17 @@
         </div>
         <div class="student_button">
           <!-- <el-button type="primary" class="bgColor" @click="openCourse">协同编辑</el-button> -->
-          <el-button type="primary" class="bgColor" @click="goToCourse3()">创建极简式课程</el-button>
+          <!-- <el-button type="primary" class="bgColor" @click="goToCourse3()">创建极简式课程</el-button>
           <el-button type="primary" class="bgColor" @click="goToCourse2()">创建任务式课程</el-button>
-          <el-button type="primary" class="bgColor" @click="goToCourse()">创建阶段式课程</el-button>
+          <el-button type="primary" class="bgColor" @click="goToCourse()">创建阶段式课程</el-button> -->
+          <button class="r_pub_button_course" @mouseenter="btnDisplay = true" @mouseleave="btnDisplay = false">
+            <span>创建课程</span>
+            <div v-show="btnDisplay" class="buttonBox">
+              <div type="primary" @click="goToCourse3()">极简式课程</div>
+              <div type="primary" @click="goToCourse2()">任务式课程</div>
+              <div type="primary" @click="goToCourse()">阶段式课程</div>
+            </div>
+          </button>
         </div>
       </div>
       <div class="reBox">
@@ -381,6 +389,7 @@ export default {
       typed: "",
       pTypeCheck: [],
       pTypeCheckName: [],
+      btnDisplay:false
     };
   },
   methods: {
@@ -1227,7 +1236,7 @@ export default {
 
 .student_button {
   display: flex;
-  overflow: hidden;
+  /* overflow: hidden; */
   height: 40px;
 }
 
@@ -1871,4 +1880,31 @@ export default {
   -webkit-box-shadow: none !important;
   box-shadow: none !important;
 }
+
+.buttonBox{
+  position: absolute;
+  bottom: -0;
+  transform: translateY(100%);
+  background: #fff;
+  border-radius: 5px;
+  box-shadow: 0 0 3px 1px #e3e3e3;
+  width: 100%;
+}
+
+.buttonBox > div{
+  height: 40px;
+  line-height: 40px;
+  width: 100%;
+  text-align: center;
+  color: #000;
+  box-sizing: border-box;
+}
+
+.buttonBox > div + div{
+  border-top: 1px solid #e0e0e0;
+}
+
+.buttonBox > div:hover{
+  background: #f6f8ff;
+}
 </style>

+ 58 - 6
src/components/pages/easy/addCourse.vue

@@ -206,6 +206,7 @@
                                   <div v-if="item1.type == 6" class="chapter_upload_l_i6" style="margin-left: 1px"></div>
                                   <!-- <div v-if="item1.type == 7" class="chapter_upload_l_i8" style="margin-left: 1px"></div> -->
                                   <div v-if="item1.type == 8" class="chapter_upload_l_i8" style="margin-left: 1px"></div>
+                                  <div v-if="item1.type == 14" class="chapter_upload_l_i14" style="margin-left: 1px"></div>
                                   <div v-if="item1.type == 12" class="chapter_upload_l_i12" style="margin-left: 1px">
                                   </div>
                                   <div v-if="item1.type == 13" class="chapter_upload_l_i13" style="margin-left: 1px">
@@ -252,6 +253,15 @@
                                   overflow: hidden;
                                   text-overflow: ellipsis;
                                 " readonly="true" @click="selectLine(0, index1)" />
+                                 <input :placeholder="item1.title ? item1.title : '链接'
+                                    " v-if="item1.type == 14" style="
+                                  border: none;
+                                  outline: none;
+                                  width: 80%;
+                                  white-space: nowrap;
+                                  overflow: hidden;
+                                  text-overflow: ellipsis;
+                                " readonly="true" @click="openUpdateSource(0, index1)" />
                                 </div>
                                 <div class="chapter_upload_ic">
                                   <div class="chapter_upload_noSee" v-if="item1.type == 12">
@@ -297,6 +307,9 @@
                                   <div class="chapter_upload_ic_edit" v-if="item1.type == 8"  @click="selectLine(0, index1)">
                                     <div></div>
                                   </div>
+                                  <div class="chapter_upload_ic_edit" v-if="item1.type == 14"  @click="openUpdateSource(0, index1)">
+                                    <div></div>
+                                  </div>
                                   <div class="chapter_upload_ic_r" @click.stop="
                                     deleteChapterData(
                                       $event,
@@ -3321,14 +3334,15 @@
         <el-button type="primary" @click="isAddOrUpdateLine">确定</el-button>
       </span>
     </el-dialog>
-    <el-dialog title="添加资源" :visible.sync="dialogVisibleSource" :append-to-body="true" width="100%"
+    <el-dialog :title="updateSourcePan ? '修改资源' : '添加资源'" :visible.sync="dialogVisibleSource" :append-to-body="true" width="100%"
       :before-close="handleClose" class="dialog_diy source_diy">
       <div>
-        <sourceDialog :sourceData.sync="sourceData"></sourceDialog>
+        <sourceDialog :sourceData.sync="sourceData" :updateSourcePan="updateSourcePan"></sourceDialog>
       </div>
       <span slot="footer" class="dialog-footer">
         <el-button @click="dialogVisibleSource = false">取 消</el-button>
-        <el-button type="primary" @click="addSource">确定</el-button>
+        <el-button type="primary" @click="addSource" v-if="!updateSourcePan">确定</el-button>
+        <el-button type="primary" @click="updateSource" v-else>确定</el-button>
       </span>
     </el-dialog>
     <el-dialog title="添加课程成员" :visible.sync="dialogVisible3" :append-to-body="true" width="25%" height="80%"
@@ -4532,6 +4546,7 @@ export default {
       icode: "",
       easyArray: [2, 4],
       sourceData: {},
+      updateSourcePan: false,
       videoJson: {},
       isBtnDisplay:false,
       isPasteTask:false,
@@ -4837,7 +4852,7 @@ export default {
     },
     closeConfirm(tool){
       this
-        .$confirm("是否保存?", "提示", {
+        .$confirm("是否保存已编辑内容?", "提示", {
           confirmButtonText: "保存",
           cancelButtonText: "不保存",
           type: "warning",
@@ -4918,7 +4933,7 @@ export default {
     },
     lastSteps() {
       this
-        .$confirm("是否保存?", "提示", {
+        .$confirm("是否保存已编辑内容?", "提示", {
           confirmButtonText: "保存",
           cancelButtonText: "不保存",
           type: "warning",
@@ -5220,6 +5235,7 @@ export default {
       this.lineCount = i;
       this.sourceData = {};
       this.dialogVisibleSource = true;
+      this.updateSourcePan = false;
     },
     addSource() {
       if (!Object.keys(this.sourceData).length) {
@@ -5234,12 +5250,32 @@ export default {
           name: "链接",
           title: this.sourceData[keys[i]].name,
           url: this.sourceData[keys[i]].url,
-          type: 8,
+          type: 14,
+          id:keys[i]
         });
       }
       this.$forceUpdate();
       this.dialogVisibleSource = false;
     },
+    updateSource() {
+      if (!Object.keys(this.sourceData).length) {
+        this.$message.error("请选择要上传的资源");
+        return;
+      }
+      let keys = Object.keys(this.sourceData);
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].url = this.sourceData[keys[0]].url;
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].title = this.sourceData[keys[0]].name;
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].id = keys[0];
+      this.updateSourcePan = false;
+      this.$forceUpdate();
+      this.dialogVisibleSource = false;
+    },
     deleteM(i, j) {
       this.testJson.testJson[i].timuList.splice(j, 1);
     },
@@ -6892,6 +6928,17 @@ export default {
       this.lineType = 1;
       this.dialogVisible7 = true;
     },
+    openUpdateSource(itemTaskIndex, i){
+      this.sourceData = {}
+      let source = this.unitJson[this.unitIndex].chapterInfo[0].taskJson[itemTaskIndex].chapterData[i]
+      this.sourceData[source.id] = {}
+      this.sourceData[source.id].name = source.title
+      this.sourceData[source.id].url = source.url
+      this.dialogVisibleSource = true;
+      this.updateSourcePan = true;
+      this.taskCount = itemTaskIndex;
+      this.lineCount = i;
+    },
     updateLine() {
       this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
         this.taskCount
@@ -10430,6 +10477,7 @@ export default {
 .chapter_upload_l_i8,
 .chapter_upload_l_i6,
 .chapter_upload_l_i12,
+.chapter_upload_l_i14,
 .chapter_upload_l_i13 {
   width: 15px;
   height: 15px;
@@ -10448,6 +10496,10 @@ export default {
   background-image: url("../../../assets/icon/new/u_url.png");
 }
 
+.chapter_upload_l_i14 {
+  background-image: url("../../../assets/icon/new/u_source.png");
+}
+
 .chapter_upload_l_i6 {
   background-image: url("../../../assets/icon/new/u_picture.png");
 }

+ 59 - 6
src/components/pages/task/addCourse.vue

@@ -345,6 +345,7 @@
                                   <div v-if="item1.type == 6" class="chapter_upload_l_i6" style="margin-left: 1px"></div>
                                   <!-- <div v-if="item1.type == 7" class="chapter_upload_l_i8" style="margin-left: 1px"></div> -->
                                   <div v-if="item1.type == 8" class="chapter_upload_l_i8" style="margin-left: 1px"></div>
+                                  <div v-if="item1.type == 14" class="chapter_upload_l_i14" style="margin-left: 1px"></div>
                                   <div v-if="item1.type == 12" class="chapter_upload_l_i12" style="margin-left: 1px">
                                   </div>
                                   <div v-if="item1.type == 13" class="chapter_upload_l_i13" style="margin-left: 1px">
@@ -391,6 +392,15 @@
                                   overflow: hidden;
                                   text-overflow: ellipsis;
                                 " readonly="true" @click="selectLine(itemTaskIndex, index1)" />
+                                <input :placeholder="item1.title ? item1.title : '链接'
+                                    " v-if="item1.type == 14" style="
+                                  border: none;
+                                  outline: none;
+                                  width: 80%;
+                                  white-space: nowrap;
+                                  overflow: hidden;
+                                  text-overflow: ellipsis;
+                                " readonly="true" @click="openUpdateSource(itemTaskIndex, index1)" />
                                 </div>
                                 <div class="chapter_upload_ic">
                                   <div class="chapter_upload_noSee" v-if="item1.type == 12">
@@ -436,6 +446,9 @@
                                   <div class="chapter_upload_ic_edit" v-if="item1.type == 8"  @click="selectLine(itemTaskIndex, index1)">
                                     <div></div>
                                   </div>
+                                  <div class="chapter_upload_ic_edit" v-if="item1.type == 14"  @click="openUpdateSource(itemTaskIndex, index1)">
+                                    <div></div>
+                                  </div>
                                   <div class="chapter_upload_ic_r" @click.stop="
                                     deleteChapterData(
                                       $event,
@@ -5338,7 +5351,7 @@
       </span>
     </el-dialog>
     <el-dialog
-      title="添加资源"
+      :title="updateSourcePan ? '修改资源' : '添加资源'"
       :visible.sync="dialogVisibleSource"
       :append-to-body="true"
       width="100%"
@@ -5346,11 +5359,12 @@
       class="dialog_diy source_diy"
     >
       <div>
-        <sourceDialog :sourceData.sync="sourceData"></sourceDialog>
+        <sourceDialog :sourceData.sync="sourceData" :updateSourcePan="updateSourcePan"></sourceDialog>
       </div>
       <span slot="footer" class="dialog-footer">
         <el-button @click="dialogVisibleSource = false">取 消</el-button>
-        <el-button type="primary" @click="addSource">确定</el-button>
+        <el-button type="primary" @click="addSource" v-if="!updateSourcePan">确定</el-button>
+        <el-button type="primary" @click="updateSource" v-else>确定</el-button>
       </span>
     </el-dialog>
     <el-dialog
@@ -7091,6 +7105,7 @@ export default {
       icode: "",
       easyArray: [2, 4],
       sourceData: {},
+      updateSourcePan: false,
       videoJson: {},
       isBtnDisplay:false,
       isPasteTask:false,
@@ -7396,7 +7411,7 @@ export default {
     },
     closeConfirm(tool){
       this
-        .$confirm("是否保存?", "提示", {
+        .$confirm("是否保存已编辑内容?", "提示", {
           confirmButtonText: "保存",
           cancelButtonText: "不保存",
           type: "warning",
@@ -7477,7 +7492,7 @@ export default {
     },
     lastSteps() {
       this
-        .$confirm("是否保存?", "提示", {
+        .$confirm("是否保存已编辑内容?", "提示", {
           confirmButtonText: "保存",
           cancelButtonText: "不保存",
           type: "warning",
@@ -7768,6 +7783,7 @@ export default {
       this.lineCount = i;
       this.sourceData = {};
       this.dialogVisibleSource = true;
+      this.updateSourcePan = false;
     },
     addSource() {
       if (!Object.keys(this.sourceData).length) {
@@ -7782,12 +7798,32 @@ export default {
           name: "链接",
           title: this.sourceData[keys[i]].name,
           url: this.sourceData[keys[i]].url,
-          type: 8,
+          type: 14,
+          id:keys[i]
         });
       }
       this.$forceUpdate();
       this.dialogVisibleSource = false;
     },
+    updateSource() {
+      if (!Object.keys(this.sourceData).length) {
+        this.$message.error("请选择要上传的资源");
+        return;
+      }
+      let keys = Object.keys(this.sourceData);
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].url = this.sourceData[keys[0]].url;
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].title = this.sourceData[keys[0]].name;
+      this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
+        this.taskCount
+      ].chapterData[this.lineCount].id = keys[0];
+      this.updateSourcePan = false;
+      this.$forceUpdate();
+      this.dialogVisibleSource = false;
+    },
     deleteM(i, j) {
       this.testJson.testJson[i].timuList.splice(j, 1);
     },
@@ -9437,6 +9473,17 @@ export default {
       this.lineType = 1;
       this.dialogVisible7 = true;
     },
+    openUpdateSource(itemTaskIndex, i){
+      this.sourceData = {}
+      let source = this.unitJson[this.unitIndex].chapterInfo[0].taskJson[itemTaskIndex].chapterData[i]
+      this.sourceData[source.id] = {}
+      this.sourceData[source.id].name = source.title
+      this.sourceData[source.id].url = source.url
+      this.dialogVisibleSource = true;
+      this.updateSourcePan = true;
+      this.taskCount = itemTaskIndex;
+      this.lineCount = i;
+    },
     updateLine() {
       this.unitJson[this.unitIndex].chapterInfo[0].taskJson[
         this.taskCount
@@ -12946,6 +12993,7 @@ export default {
 .chapter_upload_l_i8,
 .chapter_upload_l_i6,
 .chapter_upload_l_i12,
+.chapter_upload_l_i14,
 .chapter_upload_l_i13 {
   width: 15px;
   height: 15px;
@@ -12964,6 +13012,11 @@ export default {
   background-image: url("../../../assets/icon/new/u_url.png");
 }
 
+.chapter_upload_l_i14 {
+  background-image: url("../../../assets/icon/new/u_source.png");
+}
+
+
 .chapter_upload_l_i6 {
   background-image: url("../../../assets/icon/new/u_picture.png");
 }

+ 16 - 3
src/components/pages/teacherSource/dialog.vue

@@ -123,6 +123,10 @@ export default {
         sourceData: {
             type: Object,
         },
+        updateSourcePan:{
+            type: Boolean,
+            default: false
+        }
     },
     data() {
         return {
@@ -194,10 +198,19 @@ export default {
     methods: {
         checka(item){
             let _sourceData = this.sourceData
-            if(_sourceData[item.id]){
-                delete _sourceData[item.id]
+            if(this.updateSourcePan){
+                if(_sourceData[item.id]){
+                    delete _sourceData[item.id]
+                }else{
+                    _sourceData = {}
+                    _sourceData[item.id] = item
+                }
             }else{
-                _sourceData[item.id] = item
+                if(_sourceData[item.id]){
+                    delete _sourceData[item.id]
+                }else{
+                    _sourceData[item.id] = item
+                }
             }
             this.$forceUpdate()
             this.$emit("update:sourceData",_sourceData)

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