|
@@ -178,7 +178,52 @@
|
|
</el-card>
|
|
</el-card>
|
|
</div>
|
|
</div>
|
|
<div v-if="item.contentType == 4">
|
|
<div v-if="item.contentType == 4">
|
|
|
|
+ <el-card class="box-card">
|
|
|
|
+
|
|
|
|
+ <el-form-item label="选择课程">
|
|
|
|
+ <el-select
|
|
|
|
+ v-model="item.courseId"
|
|
|
|
+ placeholder="请选择课程"
|
|
|
|
+ style="margin-right: 10px"
|
|
|
|
+ size="mini"
|
|
|
|
+ @change="handleRuleCourseChange(item)"
|
|
|
|
+ >
|
|
|
|
+ <el-option
|
|
|
|
+ v-for="dict in courseList"
|
|
|
|
+ :key="dict.dictValue"
|
|
|
|
+ :label="dict.dictLabel"
|
|
|
|
+ :value="parseInt(dict.dictValue)"
|
|
|
|
+ />
|
|
|
|
+ </el-select>
|
|
|
|
+ <el-select
|
|
|
|
+ v-model="item.videoId"
|
|
|
|
+ placeholder="请选择小节"
|
|
|
|
+ size="mini"
|
|
|
|
+ style="margin-right: 10px"
|
|
|
|
+ filterable
|
|
|
|
+ remote
|
|
|
|
+ :remote-method="(query) => remoteMethodRuleVideo(query, item)"
|
|
|
|
+ :loading="videoOptionsLoading"
|
|
|
|
+ @change="handleRuleVideoChange(item)"
|
|
|
|
+ >
|
|
|
|
+ <el-option
|
|
|
|
+ v-for="dict in videoOptions || []"
|
|
|
|
+ :key="dict.dictValue"
|
|
|
|
+ :label="dict.dictLabel"
|
|
|
|
+ :value="parseInt(dict.dictValue)"
|
|
|
|
+ />
|
|
|
|
+ </el-select>
|
|
|
|
+ </el-form-item>
|
|
|
|
|
|
|
|
+ <el-card class="box-card" style="margin-top: 10px">
|
|
|
|
+ <el-form-item label="标题" prop="miniprogramTitle">
|
|
|
|
+ <el-input v-model="item.miniprogramTitle" placeholder="请输入小程序消息标题,最长为64字" />
|
|
|
|
+ </el-form-item>
|
|
|
|
+ <el-form-item label="封面" prop="miniprogramPicUrl">
|
|
|
|
+ <ImageUpload v-model="item.miniprogramPicUrl" type="image" :num="10" :width="150" :height="150" />
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-card>
|
|
|
|
+ </el-card>
|
|
</div>
|
|
</div>
|
|
<div v-if="item.contentType == 5 ">
|
|
<div v-if="item.contentType == 5 ">
|
|
|
|
|
|
@@ -315,7 +360,52 @@
|
|
</el-card>
|
|
</el-card>
|
|
</div>
|
|
</div>
|
|
<div v-if="item.contentType == 4">
|
|
<div v-if="item.contentType == 4">
|
|
|
|
+ <el-card class="box-card">
|
|
|
|
+
|
|
|
|
+ <el-form-item label="选择课程">
|
|
|
|
+ <el-select
|
|
|
|
+ v-model="item.courseId"
|
|
|
|
+ placeholder="请选择课程"
|
|
|
|
+ style="margin-right: 10px"
|
|
|
|
+ size="mini"
|
|
|
|
+ @change="handleRuleCourseChange(item)"
|
|
|
|
+ >
|
|
|
|
+ <el-option
|
|
|
|
+ v-for="dict in courseList"
|
|
|
|
+ :key="dict.dictValue"
|
|
|
|
+ :label="dict.dictLabel"
|
|
|
|
+ :value="parseInt(dict.dictValue)"
|
|
|
|
+ />
|
|
|
|
+ </el-select>
|
|
|
|
+ <el-select
|
|
|
|
+ v-model="item.videoId"
|
|
|
|
+ placeholder="请选择小节"
|
|
|
|
+ size="mini"
|
|
|
|
+ style="margin-right: 10px"
|
|
|
|
+ filterable
|
|
|
|
+ remote
|
|
|
|
+ :remote-method="(query) => remoteMethodRuleVideo(query, item)"
|
|
|
|
+ :loading="videoOptionsLoading"
|
|
|
|
+ @change="handleRuleVideoChange(item)"
|
|
|
|
+ >
|
|
|
|
+ <el-option
|
|
|
|
+ v-for="dict in videoOptions || []"
|
|
|
|
+ :key="dict.dictValue"
|
|
|
|
+ :label="dict.dictLabel"
|
|
|
|
+ :value="parseInt(dict.dictValue)"
|
|
|
|
+ />
|
|
|
|
+ </el-select>
|
|
|
|
+ </el-form-item>
|
|
|
|
|
|
|
|
+ <el-card class="box-card" style="margin-top: 10px">
|
|
|
|
+ <el-form-item label="标题" prop="miniprogramTitle">
|
|
|
|
+ <el-input v-model="item.miniprogramTitle" placeholder="请输入小程序消息标题,最长为64字" />
|
|
|
|
+ </el-form-item>
|
|
|
|
+ <el-form-item label="封面" prop="miniprogramPicUrl">
|
|
|
|
+ <ImageUpload v-model="item.miniprogramPicUrl" type="image" :num="10" :width="150" :height="150" />
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-card>
|
|
|
|
+ </el-card>
|
|
</div>
|
|
</div>
|
|
<div v-if="item.contentType == 5 ">
|
|
<div v-if="item.contentType == 5 ">
|
|
|
|
|
|
@@ -449,7 +539,7 @@
|
|
|
|
|
|
<script>
|
|
<script>
|
|
import { listCourseFinishTempParent, getCourseFinishTempParent, delCourseFinishTempParent, addCourseFinishTempParent, updateCourseFinishTempParent, exportCourseFinishTempParent } from "@/api/course/courseFinishTempParent";
|
|
import { listCourseFinishTempParent, getCourseFinishTempParent, delCourseFinishTempParent, addCourseFinishTempParent, updateCourseFinishTempParent, exportCourseFinishTempParent } from "@/api/course/courseFinishTempParent";
|
|
-import {courseList} from '@/api/qw/sop'
|
|
|
|
|
|
+import {courseList, videoList} from '@/api/qw/sop'
|
|
import ImageUpload from '@/views/qw/sop/ImageUpload.vue'
|
|
import ImageUpload from '@/views/qw/sop/ImageUpload.vue'
|
|
import { getUserList } from '@/api/company/companyUser'
|
|
import { getUserList } from '@/api/company/companyUser'
|
|
import userVideo from "@/views/qw/userVideo/userVideo.vue";
|
|
import userVideo from "@/views/qw/userVideo/userVideo.vue";
|
|
@@ -460,6 +550,9 @@ export default {
|
|
components: { ImageUpload ,userVideo},
|
|
components: { ImageUpload ,userVideo},
|
|
data() {
|
|
data() {
|
|
return {
|
|
return {
|
|
|
|
+ videoOptionsLoading: false,
|
|
|
|
+ videoOptions: [],
|
|
|
|
+ videoLoading: false,
|
|
videoNumOptions: {
|
|
videoNumOptions: {
|
|
title: '选择视频号',
|
|
title: '选择视频号',
|
|
open: false,
|
|
open: false,
|
|
@@ -508,7 +601,7 @@ export default {
|
|
courseId: null,
|
|
courseId: null,
|
|
},
|
|
},
|
|
// 表单参数
|
|
// 表单参数
|
|
- form: {},
|
|
|
|
|
|
+ form: {companyUserIds: [],},
|
|
// 表单校验
|
|
// 表单校验
|
|
rules: {
|
|
rules: {
|
|
name:[
|
|
name:[
|
|
@@ -544,6 +637,83 @@ export default {
|
|
this.getList();
|
|
this.getList();
|
|
},
|
|
},
|
|
methods: {
|
|
methods: {
|
|
|
|
+ // 处理规则中课程变化
|
|
|
|
+ handleRuleCourseChange(item) {
|
|
|
|
+ // 为当前规则项单独加载视频列表
|
|
|
|
+ videoList(item.courseId).then((response) => {
|
|
|
|
+ // 只保存视频列表,不保存整个响应对象
|
|
|
|
+ this.videoOptions = response.list;
|
|
|
|
+
|
|
|
|
+ this.$set(item, 'videoId', null); // Reset video selection when course changes
|
|
|
|
+
|
|
|
|
+ // 自动设置封面为课程封面
|
|
|
|
+ const selectedCourse = this.courseList.find(
|
|
|
|
+ course => parseInt(course.dictValue) === item.courseId
|
|
|
|
+ );
|
|
|
|
+ if (selectedCourse) {
|
|
|
|
+ this.$set(item, 'miniprogramPicUrl', selectedCourse.dictImgUrl);
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ },
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ // 处理规则中视频变化
|
|
|
|
+ handleRuleVideoChange(item) {
|
|
|
|
+ if (!item.videoId) return;
|
|
|
|
+
|
|
|
|
+ // 自动设置标题为视频标题
|
|
|
|
+ const selectedVideo = (this.videoOptions || []).find(
|
|
|
|
+ video => parseInt(video.dictValue) === item.videoId
|
|
|
|
+ );
|
|
|
|
+ if (selectedVideo) {
|
|
|
|
+ this.$set(item, 'miniprogramTitle', selectedVideo.dictLabel);
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+
|
|
|
|
+ // 远程搜索规则中的视频
|
|
|
|
+ remoteMethodRuleVideo(query, item) {
|
|
|
|
+ if (!item.courseId) {
|
|
|
|
+ this.$message.warning('请先选择课程');
|
|
|
|
+ this.videoOptions = [];
|
|
|
|
+ reject();
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ this.videoOptionsLoading = true;
|
|
|
|
+ const data = query ? { title: query } : {};
|
|
|
|
+
|
|
|
|
+ videoList(item.courseId, data).then((response) => {
|
|
|
|
+ this.videoOptions = response.list;
|
|
|
|
+ this.videoOptionsLoading = false;
|
|
|
|
+ resolve(response);
|
|
|
|
+ }).catch((error) => {
|
|
|
|
+ this.videoOptionsLoading = false;
|
|
|
|
+ reject(error);
|
|
|
|
+ });
|
|
|
|
+ },
|
|
|
|
+ remoteMethodVideo(query) {
|
|
|
|
+ if (!this.form.courseId) {
|
|
|
|
+ this.$message.warning('请先选择课程');
|
|
|
|
+ this.videoList = []; // 清空小节列表
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ if (query !== '') {
|
|
|
|
+ this.videoLoading = true;
|
|
|
|
+ // 这里调用接口搜索小节,假设 videoList 方法支持搜索参数
|
|
|
|
+ var data = {
|
|
|
|
+ title:query
|
|
|
|
+ }
|
|
|
|
+ videoList(this.form.courseId, data).then((response) => {
|
|
|
|
+ this.videoList = response.list;
|
|
|
|
+ this.videoLoading = false;
|
|
|
|
+ });
|
|
|
|
+ } else {
|
|
|
|
+ // 如果查询为空,则加载全部
|
|
|
|
+ videoList(this.form.courseId).then((response) => {
|
|
|
|
+ this.videoList = response.list;
|
|
|
|
+ });
|
|
|
|
+ }
|
|
|
|
+ },
|
|
/** 查询完课模板列表 */
|
|
/** 查询完课模板列表 */
|
|
getList() {
|
|
getList() {
|
|
this.loading = true;
|
|
this.loading = true;
|
|
@@ -649,7 +819,19 @@ export default {
|
|
}
|
|
}
|
|
this.form.companyUserIds = this.companyUserIds.toString()
|
|
this.form.companyUserIds = this.companyUserIds.toString()
|
|
|
|
|
|
- this.form.setting = JSON.stringify(this.setting)
|
|
|
|
|
|
+
|
|
|
|
+ const processedSetting = this.setting.map(item => {
|
|
|
|
+ const newItem = {...item};
|
|
|
|
+ if (newItem.videoOptions) {
|
|
|
|
+ delete newItem.videoOptions;
|
|
|
|
+ }
|
|
|
|
+ if (newItem.videoLoading !== undefined) {
|
|
|
|
+ delete newItem.videoLoading;
|
|
|
|
+ }
|
|
|
|
+ return newItem;
|
|
|
|
+ });
|
|
|
|
+
|
|
|
|
+ this.form.setting = JSON.stringify(processedSetting);
|
|
this.form.chatSetting = JSON.stringify(this.chatSetting)
|
|
this.form.chatSetting = JSON.stringify(this.chatSetting)
|
|
|
|
|
|
if (this.setting.length <= 0) {
|
|
if (this.setting.length <= 0) {
|