|
|
@@ -0,0 +1,355 @@
|
|
|
+<template>
|
|
|
+ <div class="edit-view">
|
|
|
+ <page-title>
|
|
|
+ <el-button @click="$router.go(-1)" :disabled="saving">取消</el-button>
|
|
|
+ <el-button @click="onDelete" :disabled="saving" type="danger" v-if="formData.id">
|
|
|
+ 删除
|
|
|
+ </el-button>
|
|
|
+ <el-button @click="onSave" :loading="saving" type="primary">保存</el-button>
|
|
|
+ </page-title>
|
|
|
+ <div class="edit-view__content-wrapper">
|
|
|
+ <div class="edit-view__content-section">
|
|
|
+ <el-form :model="formData" :rules="rules" ref="form" label-width="120px" label-position="right" size="small"
|
|
|
+ style="max-width: 500px;">
|
|
|
+ <el-form-item prop="name" label="任务名称">
|
|
|
+ <el-input v-model="formData.name"></el-input>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="detail" label="任务详情">
|
|
|
+ <el-input v-model="formData.detail" type="textarea" :autosize="{ minRows: 3, maxRows: 20 }"
|
|
|
+ placeholder="请输入任务详情">
|
|
|
+ </el-input>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="type" label="任务分类">
|
|
|
+ <el-select v-model="formData.type" clearable filterable placeholder="请选择" :disabled="!canEdit"
|
|
|
+ @change="changeTaskType">
|
|
|
+ <el-option v-for="item in typeOptions" :key="item.value" :label="item.label"
|
|
|
+ :value="item.value">
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <template v-if="formData && formData.type == 'MAIN_LINE'">
|
|
|
+ <el-form-item prop="metaNodeTask" label="节点任务配置" style="width: calc(100vw - 1550px)" size="mini">
|
|
|
+ <el-table :data="formData.metaNodeTask">
|
|
|
+ <el-table-column prop="atomTaskIndex" label="索引" align="center" width="50">
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
+ {{ $index }}
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="atomTaskId" label="任务" align="center">
|
|
|
+ <template v-slot="{ row }">
|
|
|
+ <el-select v-model="row.atomTaskId" clearable filterable placeholder="请选择"
|
|
|
+ :disabled="!canEdit" style="width: 150px">
|
|
|
+ <el-option v-for="item in atomTasks" :key="item.id" :label="item.name"
|
|
|
+ :value="item.id">
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column width="100" label="操作" align="center">
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
+ <el-button type="danger" plain size="mini" @click="delNodeTask($index)"
|
|
|
+ :disabled="!canEdit">
|
|
|
+ 删除
|
|
|
+ </el-button>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item>
|
|
|
+ <el-button size="mini" @click="addNodeTask" :disabled="!canEdit"> 添加节点任务 </el-button>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="metaBranchLineTask" label="支线任务配置" style="width: calc(100vw - 1550px)"
|
|
|
+ size="mini">
|
|
|
+ <el-table :data="formData.metaBranchLineTask">
|
|
|
+ <el-table-column prop="atomTaskIndex" label="索引" align="center" width="50">
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
+ {{ $index }}
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="atomTaskId" label="任务" align="center">
|
|
|
+ <template v-slot="{ row }">
|
|
|
+ <el-select v-model="row.atomTaskId" clearable filterable placeholder="请选择"
|
|
|
+ :disabled="!canEdit" style="width: 150px">
|
|
|
+ <el-option v-for="item in atomTasks" :key="item.id" :label="item.name"
|
|
|
+ :value="item.id">
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column width="100" label="操作" align="center">
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
+ <el-button type="danger" plain size="mini" @click="delBranchLineTask($index)"
|
|
|
+ :disabled="!canEdit">
|
|
|
+ 删除
|
|
|
+ </el-button>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item>
|
|
|
+ <el-button size="mini" @click="addBranchLineTask" :disabled="!canEdit"> 添加支线任务 </el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </template>
|
|
|
+ <template v-if="formData && formData.type == 'BRANCH_LINE'">
|
|
|
+ <el-form-item prop="metaBranchLineTask" label="支线任务配置" style="width: calc(100vw - 1550px)"
|
|
|
+ size="mini">
|
|
|
+ <el-table :data="formData.metaBranchLineTask">
|
|
|
+ <el-table-column prop="atomTaskIndex" label="索引" align="center" width="50">
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
+ {{ $index }}
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="atomTaskId" label="任务" align="center">
|
|
|
+ <template v-slot="{ row }">
|
|
|
+ <el-select v-model="row.atomTaskId" clearable filterable placeholder="请选择"
|
|
|
+ :disabled="!canEdit" style="width: 150px">
|
|
|
+ <el-option v-for="item in atomTasks" :key="item.id" :label="item.name"
|
|
|
+ :value="item.id">
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column width="100" label="操作" align="center">
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
+ <el-button type="danger" plain size="mini" @click="delBranchLineTask($index)"
|
|
|
+ :disabled="!canEdit">
|
|
|
+ 删除
|
|
|
+ </el-button>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item>
|
|
|
+ <el-button size="mini" @click="addBranchLineTask" :disabled="!canEdit"> 添加支线任务 </el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </template>
|
|
|
+ <template v-if="formData && formData.type == 'DAILY'">
|
|
|
+ <el-form-item prop="metaDailyTask" label="日常任务配置" style="width: calc(100vw - 1550px)" size="mini">
|
|
|
+ <el-table :data="formData.metaDailyTask">
|
|
|
+ <el-table-column prop="atomTaskIndex" label="索引" align="center" width="50">
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
+ {{ $index }}
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="atomTaskId" label="任务" align="center">
|
|
|
+ <template v-slot="{ row }">
|
|
|
+ <el-select v-model="row.atomTaskId" clearable filterable placeholder="请选择"
|
|
|
+ :disabled="!canEdit" style="width: 150px">
|
|
|
+ <el-option v-for="item in atomTasks" :key="item.id" :label="item.name"
|
|
|
+ :value="item.id">
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column width="100" label="操作" align="center">
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
+ <el-button type="danger" plain size="mini" @click="delDailyTask($index)"
|
|
|
+ :disabled="!canEdit">
|
|
|
+ 删除
|
|
|
+ </el-button>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item>
|
|
|
+ <el-button size="mini" @click="addDailyTask" :disabled="!canEdit"> 添加日常任务 </el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </template>
|
|
|
+ <el-form-item label="所属频道" prop="channelId">
|
|
|
+ <el-select v-model="formData.channelId" placeholder="请选择" style="width: 100%" :disabled="!canEdit">
|
|
|
+ <el-option v-for="item in channels" :key="item.id" :label="item.name" :value="item.id">
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="autoReceive" label="是否自动领取">
|
|
|
+ <el-switch v-model="formData.autoReceive"> </el-switch>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="publish" label="是否发布">
|
|
|
+ <el-switch v-model="formData.publish"> </el-switch>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item class="form-submit">
|
|
|
+ <el-button @click="onSave" :loading="saving" type="primary">
|
|
|
+ 保存
|
|
|
+ </el-button>
|
|
|
+ <el-button @click="onDelete" :disabled="saving" type="danger" v-if="formData.id">
|
|
|
+ 删除
|
|
|
+ </el-button>
|
|
|
+ <el-button @click="$router.go(-1)" :disabled="saving">取消</el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </el-form>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+</template>
|
|
|
+<script>
|
|
|
+export default {
|
|
|
+ name: 'MetaTaskNewEdit',
|
|
|
+ created() {
|
|
|
+ if (this.$route.query.id) {
|
|
|
+ this.$http
|
|
|
+ .get('metaTaskNew/get/' + this.$route.query.id)
|
|
|
+ .then(res => {
|
|
|
+ this.formData = res;
|
|
|
+ })
|
|
|
+ .catch(e => {
|
|
|
+ console.log(e);
|
|
|
+ this.$message.error(e.error);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ this.$http.get('/metaChannel/findAll').then(res => {
|
|
|
+ this.channels = res;
|
|
|
+ });
|
|
|
+ this.$http.get('/metaAtomTask/findAll').then(res => {
|
|
|
+ this.atomTasks = res;
|
|
|
+ });
|
|
|
+ },
|
|
|
+ computed: {
|
|
|
+ canEdit() {
|
|
|
+ return !!!this.$route.query.id;
|
|
|
+ }
|
|
|
+ },
|
|
|
+ data() {
|
|
|
+ return {
|
|
|
+ atomTasks: [],
|
|
|
+ channels: [],
|
|
|
+ saving: false,
|
|
|
+ formData: {
|
|
|
+ metaNodeTask: [],
|
|
|
+ metaBranchLineTask: [],
|
|
|
+ metaDailyTask: []
|
|
|
+ },
|
|
|
+ rules: {
|
|
|
+ name: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请输入任务名称',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ detail: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请输入任务详情',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ type: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请输入任务类型',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ channelId: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请选择所属频道',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ },
|
|
|
+ typeOptions: [
|
|
|
+ { label: '主线任务', value: 'MAIN_LINE' },
|
|
|
+ { label: '支线任务', value: 'BRANCH_LINE' },
|
|
|
+ { label: '日常任务', value: 'DAILY' }
|
|
|
+ ]
|
|
|
+ };
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ changeTaskType() {
|
|
|
+ this.formData.metaNodeTask = [];
|
|
|
+ this.formData.metaBranchLineTask = [];
|
|
|
+ this.formData.metaDailyTask = [];
|
|
|
+ },
|
|
|
+ addDailyTask() {
|
|
|
+ this.formData.metaDailyTask.push({
|
|
|
+ atomTaskId: ''
|
|
|
+ });
|
|
|
+ },
|
|
|
+ addBranchLineTask() {
|
|
|
+ this.formData.metaBranchLineTask.push({
|
|
|
+ atomTaskId: ''
|
|
|
+ });
|
|
|
+ },
|
|
|
+ addNodeTask() {
|
|
|
+ this.formData.metaNodeTask.push({
|
|
|
+ atomTaskId: ''
|
|
|
+ });
|
|
|
+ },
|
|
|
+ delDailyTask(i) {
|
|
|
+ this.formData.metaDailyTask.splice(i, 1);
|
|
|
+ },
|
|
|
+ delBranchLineTask(i) {
|
|
|
+ this.formData.metaBranchLineTask.splice(i, 1);
|
|
|
+ },
|
|
|
+ delNodeTask(i) {
|
|
|
+ this.formData.metaNodeTask.splice(i, 1);
|
|
|
+ },
|
|
|
+ onSave() {
|
|
|
+ this.$refs.form.validate(valid => {
|
|
|
+ if (valid) {
|
|
|
+ this.submit();
|
|
|
+ } else {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ },
|
|
|
+ submit() {
|
|
|
+ let data = { ...this.formData };
|
|
|
+ if (data.metaNodeTask) {
|
|
|
+ for (var i = 0; i < data.metaNodeTask.length; i++) {
|
|
|
+ data.metaNodeTask[i].atomTaskIndex = i;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (data.metaBranchLineTask) {
|
|
|
+ for (var i = 0; i < data.metaBranchLineTask.length; i++) {
|
|
|
+ data.metaBranchLineTask[i].atomTaskIndex = i;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (data.metaDailyTask) {
|
|
|
+ for (var i = 0; i < data.metaDailyTask.length; i++) {
|
|
|
+ data.metaDailyTask[i].atomTaskIndex = i;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (data.type === 'MAIN_LINE' && data.metaNodeTask.length <= 0 && data.metaBranchLineTask.length <= 0) {
|
|
|
+ this.$message.error('至少添加一种节点任务或者支线任务');
|
|
|
+ } else if (data.type === 'BRANCH_LINE' && data.metaBranchLineTask.length <= 0) {
|
|
|
+ this.$message.error('至少添加一种支线任务');
|
|
|
+ } else if (data.type === 'DAILY' && data.metaDailyTask.length <= 0) {
|
|
|
+ this.$message.error('至少添加一种日常任务');
|
|
|
+ } else {
|
|
|
+ this.saving = true;
|
|
|
+ this.$http
|
|
|
+ .post('/metaTaskNew/save', data, { body: 'json' })
|
|
|
+ .then(res => {
|
|
|
+ this.saving = false;
|
|
|
+ this.$message.success('成功');
|
|
|
+ this.$router.go(-1);
|
|
|
+ })
|
|
|
+ .catch(e => {
|
|
|
+ console.log(e);
|
|
|
+ this.saving = false;
|
|
|
+ this.$message.error(e.error);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ },
|
|
|
+ onDelete() {
|
|
|
+ this.$confirm('删除将无法恢复,确认要删除么?', '警告', { type: 'error' })
|
|
|
+ .then(() => {
|
|
|
+ return this.$http.post(`/metaTaskNew/del/${this.formData.id}`);
|
|
|
+ })
|
|
|
+ .then(() => {
|
|
|
+ this.$message.success('删除成功');
|
|
|
+ this.$router.go(-1);
|
|
|
+ })
|
|
|
+ .catch(e => {
|
|
|
+ if (e !== 'cancel') {
|
|
|
+ console.log(e);
|
|
|
+ this.$message.error((e || {}).error || '删除失败');
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+};
|
|
|
+</script>
|
|
|
+<style lang="less" scoped></style>
|