|
@@ -70,8 +70,7 @@
|
|
|
</div>
|
|
|
<div class="whiteBg" style="border-radius: 0">
|
|
|
<div class="right_first">
|
|
|
- <div class="right_title">上传封面与成员</div>
|
|
|
-
|
|
|
+ <div class="right_title">上传封面</div>
|
|
|
<div style="
|
|
|
padding: 0 0 50px 20px;
|
|
|
display: flex;
|
|
@@ -101,17 +100,6 @@
|
|
|
align-items: baseline;
|
|
|
margin: 0 30px;
|
|
|
">
|
|
|
- <!-- <div style="margin: 0 80px">
|
|
|
- <div class="bInfo_title">
|
|
|
- 选择课程成员
|
|
|
- </div>
|
|
|
- <div
|
|
|
- class="addPeople"
|
|
|
- @click="addPP"
|
|
|
- v-if="this.checkboxList.length == 0"
|
|
|
- >添加成员</div>
|
|
|
- <div class="addPeople" @click="addPP" v-else>已添加,点击查看</div>
|
|
|
- </div>-->
|
|
|
<div style="margin: 0 30px 0 0; width: 150px">
|
|
|
<div class="bInfo_title">添加班级</div>
|
|
|
<div class="addPeople" @click="(dialogVisibleClass = true),
|
|
@@ -149,6 +137,282 @@
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
+ <div class="whiteBg" style="border-radius: 0; margin-top: 15px">
|
|
|
+ <div class="right_title">上传课程内容</div>
|
|
|
+ <div style=" padding: 0 0 50px 20px;display: flex;">
|
|
|
+ <div class="course_left">
|
|
|
+ <div class="stepsBottom2">
|
|
|
+ <div class="navTop">辅助导航</div>
|
|
|
+ <div class="navBottom">
|
|
|
+ <div class="navTask" :class="{
|
|
|
+ isNavTask: isClickColor > 0 && isClickColor == tIndex + 1,
|
|
|
+ }" v-for="(t, tIndex) in unitJson[unitIndex].chapterInfo[0]
|
|
|
+ .taskJson" :key="tIndex" @click="goToTask(tIndex)">
|
|
|
+ <div>任务{{ tIndex + 1 }}</div>
|
|
|
+ <div>
|
|
|
+ <el-tooltip effect="light" :content="t.task" placement="top">
|
|
|
+ <span>{{ t.task }}</span>
|
|
|
+ </el-tooltip>
|
|
|
+ </div>
|
|
|
+ <div class="moveBtn" v-if="unitJson[unitIndex].chapterInfo[0].taskJson.length > 1">
|
|
|
+ <div class="chapter_upload_up" style="width: 15px; height: 15px"
|
|
|
+ @click.stop="taskMove(1, tIndex)">
|
|
|
+ </div>
|
|
|
+ <div class="chapter_upload_down" style="width: 15px; height: 15px; margin: 2px 0 0"
|
|
|
+ @click.stop="taskMove(2, tIndex)"></div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="basic_box2">
|
|
|
+ <div style="margin: 0 0 40px 0; padding: 0 20px 0 20px"
|
|
|
+ v-for="(item, index) in unitJson[unitIndex].chapterInfo" :key="index">
|
|
|
+ <div class="taskBorder" :style="{ minHeight: unitJson[unitIndex].easy && 'unset' }"
|
|
|
+ v-for="(itemTask, itemTaskIndex) in item.taskJson" :key="itemTaskIndex">
|
|
|
+ <div v-if="unitJson[unitIndex].easy != 1">
|
|
|
+ <div :style="{
|
|
|
+ marginBottom:
|
|
|
+ unitJson[unitIndex].easy == 3 ||
|
|
|
+ (unitJson[unitIndex].easy == 5 &&
|
|
|
+ itemTask.taskType == 1)
|
|
|
+ ? '75px'
|
|
|
+ : '0',
|
|
|
+ }">
|
|
|
+ <div style="font-size: 22px; color: #8e8e8e" :id="'task' + itemTaskIndex">
|
|
|
+ 任务{{ itemTaskIndex + 1 }}
|
|
|
+ </div>
|
|
|
+ <div class="chapter_contentbox" style="
|
|
|
+ flex-direction: row;
|
|
|
+ justify-content: flex-start;
|
|
|
+ align-items: center;
|
|
|
+ ">
|
|
|
+ <div style="
|
|
|
+ border-left: 6px solid #5699e8;
|
|
|
+ height: 20px;
|
|
|
+ padding-left: 10px;
|
|
|
+ line-height: 22px;
|
|
|
+ ">
|
|
|
+ 任务名称
|
|
|
+ </div>
|
|
|
+ <div>
|
|
|
+ <input type="text" placeholder="输入任务名称" class="binfo_input" style="border-radius: 4px"
|
|
|
+ v-model="unitJson[unitIndex].chapterInfo[0].taskJson[
|
|
|
+ itemTaskIndex
|
|
|
+ ].task
|
|
|
+ " />
|
|
|
+ </div>
|
|
|
+ <div class="remove" v-if="item.taskJson.length > 1" @click="deleteTask(itemTaskIndex)"
|
|
|
+ style="position: absolute; right: 55px">
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="basic_box" style="
|
|
|
+ margin: 0;
|
|
|
+ min-height: 0;
|
|
|
+ width: 90% !important;
|
|
|
+ padding-top: 10px !important;
|
|
|
+ ">
|
|
|
+ <div style="
|
|
|
+ display: flex;
|
|
|
+ margin: 0 0 20px 0;
|
|
|
+ flex-direction: row;
|
|
|
+ justify-content: flex-start;
|
|
|
+ align-items: center;
|
|
|
+ ">
|
|
|
+ <div class="lineTitle">学习内容</div>
|
|
|
+ <div class="line"></div>
|
|
|
+ </div>
|
|
|
+ <div>
|
|
|
+ <div class="add_chapters_box" v-if="itemTask.chapterData &&
|
|
|
+ itemTask.chapterData.length == 0
|
|
|
+ " style="height: 185px"></div>
|
|
|
+ <div v-else class="add_chapters_box" style="display: flex; flex-direction: column">
|
|
|
+ <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_i1"></div>
|
|
|
+ <div v-if="item1.type == 3 ||
|
|
|
+ item1.type == 12 ||
|
|
|
+ item1.type == 6 ||
|
|
|
+ item1.type == 7
|
|
|
+ " class="chapter_upload_l_i5" style="margin-left: 1px"></div>
|
|
|
+ <div v-if="item1.type == 8" class="chapter_upload_l_i8" style="margin-left: 1px"></div>
|
|
|
+ </div>
|
|
|
+ <div class="chapter_upload_ic" style="
|
|
|
+ cursor: pointer;
|
|
|
+ position: absolute;
|
|
|
+ width: 45px;
|
|
|
+ right: 0;
|
|
|
+ top: 0;
|
|
|
+ ">
|
|
|
+ <div class="chapter_upload_ic_l"></div>
|
|
|
+ <div class="chapter_upload_ic_r" style="position: absolute" @click.stop="deleteChapterData(
|
|
|
+ $event,
|
|
|
+ unitIndex,
|
|
|
+ index,
|
|
|
+ index1,
|
|
|
+ itemTaskIndex
|
|
|
+ )
|
|
|
+ ">
|
|
|
+ <div></div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="chapter_upload_n">
|
|
|
+ <input v-if="item1.type == 2 ||
|
|
|
+ item1.type == 3 ||
|
|
|
+ item1.type == 12 ||
|
|
|
+ item1.type == 7
|
|
|
+ " :placeholder="item1.name" @change="updataVideoT(
|
|
|
+ $event,
|
|
|
+ unitIndex,
|
|
|
+ chapterIndex,
|
|
|
+ index1
|
|
|
+ )
|
|
|
+ " style="
|
|
|
+ border: none;
|
|
|
+ outline: none;
|
|
|
+ width: 80%;
|
|
|
+ minwidth: 215px;
|
|
|
+ z-index: 99;
|
|
|
+ font-size: 14px;
|
|
|
+ white-space: nowrap;
|
|
|
+ overflow: hidden;
|
|
|
+ text-overflow: ellipsis;
|
|
|
+ " />
|
|
|
+ <input :placeholder="item1.name" v-if="item1.type == 6" style="
|
|
|
+ border: none;
|
|
|
+ outline: none;
|
|
|
+ width: 80%;
|
|
|
+ white-space: nowrap;
|
|
|
+ overflow: hidden;
|
|
|
+ text-overflow: ellipsis;
|
|
|
+ " readonly="true" @click="selectAttText(itemTaskIndex, index1)" />
|
|
|
+ <input :placeholder="item1.title ? item1.title : '链接'
|
|
|
+ " v-if="item1.type == 8" style="
|
|
|
+ border: none;
|
|
|
+ outline: none;
|
|
|
+ width: 80%;
|
|
|
+ white-space: nowrap;
|
|
|
+ overflow: hidden;
|
|
|
+ text-overflow: ellipsis;
|
|
|
+ " readonly="true" @click="selectLine(itemTaskIndex, index1)" />
|
|
|
+ <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>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="add_info_box">
|
|
|
+ <button class="info_btn" @click="addImg($event)">
|
|
|
+ 添加视频
|
|
|
+ <!-- capture="camera" -->
|
|
|
+ <input type="file" accept="video/mp4, video/quicktime, video/x-msvideo" style="display: none"
|
|
|
+ v-if="inputShow" @change="beforeUpload2($event, unitIndex, 2, itemTaskIndex)
|
|
|
+ " />
|
|
|
+ </button>
|
|
|
+ <button class="info_btn" @click="addImg($event)">
|
|
|
+ 添加文档
|
|
|
+ <input type="file"
|
|
|
+ accept="application/pdf, application/.ppt, .ppt, .pptx, .xlsx, .xls, application/msword, application/vnd.openxmlformats-officedocument.wordprocessingml.document"
|
|
|
+ style="display: none" v-if="inputShow" @change="beforeUpload2($event, unitIndex, 3, itemTaskIndex)
|
|
|
+ " />
|
|
|
+ </button>
|
|
|
+ <button class="info_btn" @click="addAttText(itemTaskIndex)">
|
|
|
+ 添加图文
|
|
|
+ </button>
|
|
|
+ <button class="info_btn" @click="openLine(itemTaskIndex)">
|
|
|
+ 添加链接
|
|
|
+ </button>
|
|
|
+ <button class="info_btn" @click="pasteLine(itemTaskIndex)">
|
|
|
+ 粘贴链接
|
|
|
+ </button>
|
|
|
+ <button class="info_btn" @click="openSource(itemTaskIndex)">
|
|
|
+ 添加资源
|
|
|
+ </button>
|
|
|
+ <button class="info_btn" @click="addImg($event)">
|
|
|
+ 其他附件
|
|
|
+ <input type="file" accept="*" style="display: none" v-if="inputShow" @change="beforeUpload2($event, unitIndex, 12, itemTaskIndex)
|
|
|
+ " />
|
|
|
+ </button>
|
|
|
+ </div>
|
|
|
+ <div v-if="unitJson[unitIndex].chapterInfo[0].taskJson[
|
|
|
+ itemTaskIndex
|
|
|
+ ].proVisible
|
|
|
+ " class="mask">
|
|
|
+ <div class="progressBox">
|
|
|
+ <!-- <div id="closePro" class="closeCss">
|
|
|
+ <img src="../../../../assets/icon/close.png" alt />
|
|
|
+ </div> -->
|
|
|
+ <div class="lbox">
|
|
|
+ <img src="../../../assets/loading.gif" />上传中,请稍后
|
|
|
+ </div>
|
|
|
+ <div style="margin-bottom: 10px">
|
|
|
+ <span>{{
|
|
|
+ unitJson[unitIndex].chapterInfo[0].taskJson[
|
|
|
+ itemTaskIndex
|
|
|
+ ].isFinishSize
|
|
|
+ }}M</span>
|
|
|
+ /
|
|
|
+ <span>{{
|
|
|
+ unitJson[unitIndex].chapterInfo[0].taskJson[
|
|
|
+ itemTaskIndex
|
|
|
+ ].isAllSize
|
|
|
+ }}M</span>
|
|
|
+ </div>
|
|
|
+ <el-progress :text-inside="true" :stroke-width="20" :percentage="unitJson[unitIndex].chapterInfo[0].taskJson[
|
|
|
+ itemTaskIndex
|
|
|
+ ].progress
|
|
|
+ ? unitJson[unitIndex].chapterInfo[0].taskJson[
|
|
|
+ itemTaskIndex
|
|
|
+ ].progress
|
|
|
+ : 0
|
|
|
+ " style="width: 80%"></el-progress>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="addTaskBorder" @click="addTaskBorder" v-if="!unitJson[unitIndex].easy">
|
|
|
+ <div>
|
|
|
+ <img src="../../../assets/icon/addHw.png" alt />
|
|
|
+ <span>添加任务</span>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<div class="rightBox" v-if="this.steps == 2">
|
|
|
<div class="basic_box" style="padding: 20px 30px 0px !important; box-sizing: border-box">
|
|
@@ -1797,11 +2061,7 @@
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
- <div style="
|
|
|
- width: calc(100% - 20px);
|
|
|
- background: rgb(255, 255, 255);
|
|
|
- border-radius: 10px;
|
|
|
- " v-if="this.steps == 4">
|
|
|
+ <div class="rightBox" v-if="this.steps == 4">
|
|
|
<div class="basic_box_success">
|
|
|
<div class="right_img">
|
|
|
<img src="../../../assets/icon/right.png" alt />
|
|
@@ -1818,7 +2078,7 @@
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="info_btnBox">
|
|
|
- <button class="info_btn" v-if="steps == 1" @click="goTo(
|
|
|
+ <button class="info_btn" @click="goTo(
|
|
|
'/course?userid=' +
|
|
|
userid +
|
|
|
'&oid=' +
|
|
@@ -1831,11 +2091,8 @@
|
|
|
">
|
|
|
返回课程
|
|
|
</button>
|
|
|
- <button class="info_btn" v-if="steps > 1 && steps != 5" @click="lastSteps">
|
|
|
- {{ steps == 4 ? "返回首页" : "上一步" }}
|
|
|
- </button>
|
|
|
- <button class="info_btn" v-if="steps < 4" @click="nextSteps">
|
|
|
- {{ steps == 3 ? "确认上传" : "下一步" }}
|
|
|
+ <button class="info_btn" @click="nextSteps">
|
|
|
+ 确认上传
|
|
|
</button>
|
|
|
</div>
|
|
|
</div>
|
|
@@ -2925,16 +3182,6 @@ export default {
|
|
|
taskDetail: "",
|
|
|
chapterData: [],
|
|
|
toolText: "",
|
|
|
- toolChoose: [
|
|
|
- {
|
|
|
- tool: [],
|
|
|
- toolDetail: "",
|
|
|
- toolType: 0,
|
|
|
- askCount: 1,
|
|
|
- askTitle: "",
|
|
|
- askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
|
|
|
- },
|
|
|
- ],
|
|
|
isShowTools: false,
|
|
|
askCount: 1,
|
|
|
isFold: 0,
|
|
@@ -3185,6 +3432,18 @@ export default {
|
|
|
},
|
|
|
scrollChange() {
|
|
|
this.rightBoxHeight = $(".rightBox")[0].scrollHeight;
|
|
|
+ // document.querySelector('.course_left').scrollHeight
|
|
|
+ // document.querySelector('.stepsBottom2').scrollHeight
|
|
|
+ let stepsBottom2 = $(".stepsBottom2")[0].clientHeight
|
|
|
+ let client = $(".course_left")[0].clientHeight - stepsBottom2
|
|
|
+ let top = $(".rightBox")[0].scrollTop - 400
|
|
|
+ if(top > client){
|
|
|
+ $('.stepsBottom2')[0].style.top = client + 'px'
|
|
|
+ }else if(top > 0){
|
|
|
+ $('.stepsBottom2')[0].style.top = top + 'px'
|
|
|
+ }else{
|
|
|
+ $('.stepsBottom2')[0].style.top = '0px'
|
|
|
+ }
|
|
|
},
|
|
|
handleCheckAllChange(val) {
|
|
|
this.checkedCities = val ? cityOptions : [];
|
|
@@ -3258,57 +3517,39 @@ export default {
|
|
|
return _guid;
|
|
|
},
|
|
|
lastSteps() {
|
|
|
- if (this.steps == 4) {
|
|
|
- this.goTo(
|
|
|
- "/course?userid=" +
|
|
|
- this.userid +
|
|
|
- "&oid=" +
|
|
|
- this.oid +
|
|
|
- "&org=" +
|
|
|
- this.org +
|
|
|
- "&role=" +
|
|
|
- this.role
|
|
|
- );
|
|
|
- } else {
|
|
|
- if (this.cidType == 0) {
|
|
|
- this.steps--;
|
|
|
- if (this.steps == 1) {
|
|
|
- setTimeout(() => {
|
|
|
- this.checkEva(this.checkId);
|
|
|
- }, 0);
|
|
|
- }
|
|
|
- } else {
|
|
|
- if (this.steps == 3) {
|
|
|
- this.steps = 1;
|
|
|
- setTimeout(() => {
|
|
|
- this.checkEva(this.checkId);
|
|
|
- }, 0);
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
+ this.goTo(
|
|
|
+ "/course?userid=" +
|
|
|
+ this.userid +
|
|
|
+ "&oid=" +
|
|
|
+ this.oid +
|
|
|
+ "&org=" +
|
|
|
+ this.org +
|
|
|
+ "&role=" +
|
|
|
+ this.role
|
|
|
+ );
|
|
|
},
|
|
|
nextSteps() {
|
|
|
if (this.cid == "" || this.cid == undefined) {
|
|
|
- if (this.courseName == "") {
|
|
|
- this.$message.error("请将信息填写完整");
|
|
|
- return;
|
|
|
- } else {
|
|
|
- this.addWork();
|
|
|
- this.steps++;
|
|
|
- }
|
|
|
+ if (this.courseName == "") {
|
|
|
+ this.$message.error("请将信息填写完整");
|
|
|
+ return;
|
|
|
+ } else {
|
|
|
+ this.addWork();
|
|
|
+ this.steps = 4
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if (this.courseName == "") {
|
|
|
+ this.$message.error("请将信息填写完整");
|
|
|
+ return;
|
|
|
+ } else {
|
|
|
+ if (this.userid != this.courseUserid && this.role != '1') {
|
|
|
+ this.updateWork2();
|
|
|
} else {
|
|
|
- if (this.courseName == "") {
|
|
|
- this.$message.error("请将信息填写完整");
|
|
|
- return;
|
|
|
- } else {
|
|
|
- if (this.userid != this.courseUserid && this.role != '1') {
|
|
|
- this.updateWork2();
|
|
|
- } else {
|
|
|
- this.updateWork();
|
|
|
- }
|
|
|
- this.steps++;
|
|
|
- }
|
|
|
+ this.updateWork();
|
|
|
}
|
|
|
+ this.steps = 4
|
|
|
+ }
|
|
|
+ }
|
|
|
this.$refs.stepBox.scrollTop = 0;
|
|
|
},
|
|
|
unitSet(i) {
|
|
@@ -3423,24 +3664,36 @@ export default {
|
|
|
},
|
|
|
deleteTask(i) {
|
|
|
var _this = this;
|
|
|
- if (_this.time()) {
|
|
|
- _this
|
|
|
- .$confirm("确定删除此任务吗?", "提示", {
|
|
|
- confirmButtonText: "确定",
|
|
|
- cancelButtonText: "取消",
|
|
|
- type: "warning",
|
|
|
- })
|
|
|
- .then(() => {
|
|
|
- _this.unitJson[_this.unitIndex].chapterInfo[0].taskJson.splice(
|
|
|
- i,
|
|
|
- 1
|
|
|
- );
|
|
|
- _this.$message.success("删除成功");
|
|
|
- })
|
|
|
- .catch(() => {
|
|
|
- return;
|
|
|
- });
|
|
|
- }
|
|
|
+ _this
|
|
|
+ .$confirm("确定删除此任务吗?", "提示", {
|
|
|
+ confirmButtonText: "确定",
|
|
|
+ cancelButtonText: "取消",
|
|
|
+ type: "warning",
|
|
|
+ })
|
|
|
+ .then(() => {
|
|
|
+ _this.unitJson[_this.unitIndex].chapterInfo[0].taskJson.splice(
|
|
|
+ i,
|
|
|
+ 1
|
|
|
+ );
|
|
|
+ _this.$message.success("删除成功");
|
|
|
+
|
|
|
+ this.$nextTick(()=>{
|
|
|
+ $('.stepsBottom2')[0].style.transition = 'unset'
|
|
|
+ setTimeout(()=>{
|
|
|
+ let stepsBottom2 = $(".stepsBottom2")[0].clientHeight
|
|
|
+ let client = $(".basic_box2")[0].clientHeight - stepsBottom2 - 100
|
|
|
+ let top = $('.stepsBottom2')[0].offsetTop - 20
|
|
|
+ if(top > client){
|
|
|
+ $('.stepsBottom2')[0].style.top = client + 'px'
|
|
|
+ }
|
|
|
+ $('.stepsBottom2')[0].style.transition = 'all .5s'
|
|
|
+ this.$forceUpdate()
|
|
|
+ },500)
|
|
|
+ })
|
|
|
+ })
|
|
|
+ .catch(() => {
|
|
|
+ return;
|
|
|
+ });
|
|
|
},
|
|
|
handlePictureCardPreview(file) {
|
|
|
this.dialogImageUrl = file.url;
|
|
@@ -4228,16 +4481,6 @@ export default {
|
|
|
taskDetail: "",
|
|
|
chapterData: [],
|
|
|
toolText: "",
|
|
|
- toolChoose: [
|
|
|
- {
|
|
|
- tool: [],
|
|
|
- toolDetail: "",
|
|
|
- toolType: 0,
|
|
|
- askCount: 1,
|
|
|
- askTitle: "",
|
|
|
- askJson: [{ askstitle: "", askItem: 1, checkList: [] }],
|
|
|
- },
|
|
|
- ],
|
|
|
isShowTools: false,
|
|
|
askCount: 1,
|
|
|
isFold: 0,
|
|
@@ -4405,24 +4648,7 @@ export default {
|
|
|
) {
|
|
|
this.unitJson[i].chapterInfo[0].taskJson[j].proVisible = false;
|
|
|
this.unitJson[i].chapterInfo[0].taskJson[j].proVisible2 = false;
|
|
|
- if (
|
|
|
- this.unitJson[i].chapterInfo[0].taskJson[j].toolChoose.length > 1
|
|
|
- ) {
|
|
|
- for (
|
|
|
- var z = 0;
|
|
|
- z < this.unitJson[i].chapterInfo[0].taskJson[j].toolChoose.length;
|
|
|
- z++
|
|
|
- ) {
|
|
|
- if (
|
|
|
- !this.unitJson[i].chapterInfo[0].taskJson[j].toolChoose[z].tool
|
|
|
- .length
|
|
|
- ) {
|
|
|
- this.$message.error("请把工具添加完整");
|
|
|
- cPan = 2;
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
+
|
|
|
if (this.unitJson[i].chapterInfo[0].taskJson[j].eList) {
|
|
|
this.unitJson[i].chapterInfo[0].taskJson[j].eList = this.unitJson[
|
|
|
i
|
|
@@ -4470,7 +4696,7 @@ export default {
|
|
|
},
|
|
|
];
|
|
|
this.ajax
|
|
|
- .post(this.$store.state.api + "addWorkNew2", params)
|
|
|
+ .post(this.$store.state.api + "addWorkNew2E", params)
|
|
|
.then((res) => {
|
|
|
console.log(this.steps);
|
|
|
if (this.steps != 1 && this.steps != 2 && this.steps != 3) {
|
|
@@ -4505,28 +4731,6 @@ export default {
|
|
|
this.unitJson[_unitIndex].chapterInfo[0].taskJson[
|
|
|
j
|
|
|
].proVisible2 = false;
|
|
|
- if (
|
|
|
- this.unitJson[_unitIndex].chapterInfo[0].taskJson[j].toolChoose
|
|
|
- .length > 1
|
|
|
- ) {
|
|
|
- for (
|
|
|
- var z = 0;
|
|
|
- z <
|
|
|
- this.unitJson[_unitIndex].chapterInfo[0].taskJson[j].toolChoose
|
|
|
- .length;
|
|
|
- z++
|
|
|
- ) {
|
|
|
- if (
|
|
|
- !this.unitJson[_unitIndex].chapterInfo[0].taskJson[j].toolChoose[
|
|
|
- z
|
|
|
- ].tool.length
|
|
|
- ) {
|
|
|
- this.$message.error("请把工具添加完整");
|
|
|
- cPan = 2;
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
if (this.unitJson[_unitIndex].chapterInfo[0].taskJson[j].eList) {
|
|
|
this.unitJson[_unitIndex].chapterInfo[0].taskJson[j].eList =
|
|
|
this.unitJson[_unitIndex].chapterInfo[0].taskJson[j].eList.filter(
|
|
@@ -4573,24 +4777,6 @@ export default {
|
|
|
) {
|
|
|
this.unitJson[i].chapterInfo[0].taskJson[j].proVisible = false;
|
|
|
this.unitJson[i].chapterInfo[0].taskJson[j].proVisible2 = false;
|
|
|
- if (
|
|
|
- this.unitJson[i].chapterInfo[0].taskJson[j].toolChoose.length > 1
|
|
|
- ) {
|
|
|
- for (
|
|
|
- var z = 0;
|
|
|
- z < this.unitJson[i].chapterInfo[0].taskJson[j].toolChoose.length;
|
|
|
- z++
|
|
|
- ) {
|
|
|
- if (
|
|
|
- !this.unitJson[i].chapterInfo[0].taskJson[j].toolChoose[z].tool
|
|
|
- .length
|
|
|
- ) {
|
|
|
- this.$message.error("请把工具添加完整");
|
|
|
- cPan = 2;
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
if (this.unitJson[i].chapterInfo[0].taskJson[j].eList) {
|
|
|
this.unitJson[i].chapterInfo[0].taskJson[j].eList = this.unitJson[
|
|
|
i
|
|
@@ -5823,12 +6009,12 @@ export default {
|
|
|
},
|
|
|
pasteTask() {
|
|
|
let iframe = top.document.querySelectorAll("#AIChat iframe")[0]
|
|
|
- if(!iframe){
|
|
|
+ if (!iframe) {
|
|
|
this.$message.error("请使用AI共创生成")
|
|
|
return;
|
|
|
}
|
|
|
let copyData = iframe.contentWindow.copyData
|
|
|
- if(!copyData || !copyData.tasksData || !copyData.tasksData.length){
|
|
|
+ if (!copyData || !copyData.tasksData || !copyData.tasksData.length) {
|
|
|
this.$message.error("请使用AI共创生成")
|
|
|
return;
|
|
|
}
|
|
@@ -5865,12 +6051,12 @@ export default {
|
|
|
},
|
|
|
pasteStage() {
|
|
|
let iframe = top.document.querySelectorAll("#AIChat iframe")[0]
|
|
|
- if(!iframe){
|
|
|
+ if (!iframe) {
|
|
|
this.$message.error("请使用AI共创生成")
|
|
|
return;
|
|
|
}
|
|
|
let copyData = iframe.contentWindow.copyData
|
|
|
- if(!copyData || !copyData.stageData || !copyData.stageData.length){
|
|
|
+ if (!copyData || !copyData.stageData || !copyData.stageData.length) {
|
|
|
this.$message.error("请使用AI共创生成")
|
|
|
return;
|
|
|
}
|
|
@@ -6135,7 +6321,7 @@ export default {
|
|
|
this.timer = null;
|
|
|
// this.timer = setInterval(() => {
|
|
|
|
|
|
- this.seleteCourseUpdate();
|
|
|
+ // this.seleteCourseUpdate();
|
|
|
this.setMan();
|
|
|
this.selectAllType();
|
|
|
// }, 5000);
|
|
@@ -6896,8 +7082,7 @@ export default {
|
|
|
}
|
|
|
},
|
|
|
goToTask(i) {
|
|
|
- document.getElementsByClassName("rightBox")[0].scrollTop =
|
|
|
- document.getElementsByClassName("taskBorder")[i].offsetTop - 100;
|
|
|
+ $(".rightBox")[0].scrollTop = $(".taskBorder")[i].offsetTop + $(".taskBorder")[i].parentElement.parentElement.offsetTop;
|
|
|
this.isClickColor = i + 1;
|
|
|
},
|
|
|
taskMove(type, index) {
|
|
@@ -7157,6 +7342,12 @@ export default {
|
|
|
this.selectCourseDetail();
|
|
|
}, 500);
|
|
|
},
|
|
|
+ mounted () {
|
|
|
+ this.$nextTick(() => {
|
|
|
+ //监听这个dom的scroll事件
|
|
|
+ $('.rightBox')[0].addEventListener("scroll", this.scrollChange);
|
|
|
+ });;
|
|
|
+ },
|
|
|
};
|
|
|
</script>
|
|
|
|
|
@@ -7298,13 +7489,18 @@ export default {
|
|
|
padding: 0 20px 0 20px;
|
|
|
}
|
|
|
|
|
|
+.basic_box2 {
|
|
|
+ position: relative;
|
|
|
+ width: calc(100% - 300px);
|
|
|
+}
|
|
|
+
|
|
|
.basic_box_success {
|
|
|
width: 100%;
|
|
|
- min-height: 455px;
|
|
|
+ height: 100%;
|
|
|
padding: 50px 0;
|
|
|
position: relative;
|
|
|
text-align: center;
|
|
|
- border-bottom: 1px solid #bfbfbf;
|
|
|
+ /* border-bottom: 1px solid #bfbfbf; */
|
|
|
box-sizing: border-box;
|
|
|
display: flex;
|
|
|
align-items: center;
|
|
@@ -7856,7 +8052,7 @@ export default {
|
|
|
.right_img {
|
|
|
width: 150px;
|
|
|
height: 150px;
|
|
|
- margin: 0 auto;
|
|
|
+ margin: 20px auto;
|
|
|
}
|
|
|
|
|
|
.right_img>img {
|
|
@@ -8676,7 +8872,7 @@ ol {
|
|
|
border: 1px solid #e1e1e1;
|
|
|
border-radius: 10px;
|
|
|
margin-top: 20px;
|
|
|
- min-height: 1160px;
|
|
|
+ /* min-height: 1160px; */
|
|
|
position: relative;
|
|
|
background: #fbfbfb;
|
|
|
}
|
|
@@ -9665,6 +9861,24 @@ ol {
|
|
|
overflow: hidden;
|
|
|
}
|
|
|
|
|
|
+.course_left{
|
|
|
+ width:300px;
|
|
|
+ height:auto;
|
|
|
+ position: relative;
|
|
|
+}
|
|
|
+
|
|
|
+.stepsBottom2 {
|
|
|
+ width: 100%;
|
|
|
+ margin: 20px 0;
|
|
|
+ /* box-shadow: 0 0 10px 10px #f7f7f7; */
|
|
|
+ /* background: #f7f7f7; */
|
|
|
+ border-radius: 10px;
|
|
|
+ overflow: hidden;
|
|
|
+ height: fit-content;
|
|
|
+ position: relative;
|
|
|
+ transition: all .5s;
|
|
|
+}
|
|
|
+
|
|
|
.navTop {
|
|
|
background: #53749b;
|
|
|
color: #fff;
|
|
@@ -9676,7 +9890,7 @@ ol {
|
|
|
|
|
|
.navBottom {
|
|
|
background: #6b91b7;
|
|
|
- height: 180px;
|
|
|
+ height: 300px;
|
|
|
overflow: auto;
|
|
|
}
|
|
|
|