|
|
@@ -1,129 +1,227 @@
|
|
|
<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="80px"
|
|
|
- label-position="right"
|
|
|
- size="small"
|
|
|
- style="max-width: 500px"
|
|
|
- >
|
|
|
- <el-form-item prop="collectionId" label="藏品id">
|
|
|
- <el-input v-model="formData.collectionId"> </el-input>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="num" label="数量配置">
|
|
|
- <el-input-number type="number" v-model="formData.num"> </el-input-number>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="application" label="用途">
|
|
|
- <el-input-number type="application" v-model="formData.application"> </el-input-number>
|
|
|
- </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>
|
|
|
+ <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="audit" label="是否需要审核">
|
|
|
+ <el-radio-group v-model="formData.audit">
|
|
|
+ <el-radio :label="true"> 人工审核 </el-radio>
|
|
|
+ <el-radio :label="false"> 自动匹配 </el-radio>
|
|
|
+ </el-radio-group>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="collectionName" label="藏品名称" v-if="formData.audit === true">
|
|
|
+ <el-input v-model="formData.collectionName" :disabled="!canEdit" class="width"> </el-input>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="rule" label="匹配规则设置" v-if="formData.audit === false">
|
|
|
+ <template v-if="formData.rule && formData.rule.and">
|
|
|
+ <div v-for="(item, i) in formData.rule.and" class="rule-item">
|
|
|
+ <el-select v-model="item.detail.tag" value-key="id" size="mini">
|
|
|
+ <el-option v-for="item in tags" :key="item.id" :value="item" :label="item.name">
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
+ <span style="padding: 0 10px; color: #606266; font-weight: bold"> × 1 </span>
|
|
|
+ <i @click="delRule(i)" class="el-icon-delete icon-del"> </i>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ <el-button size="mini" @click="addRule"> 添加 </el-button>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="num" label="藏品数量">
|
|
|
+ <el-input-number
|
|
|
+ type="number"
|
|
|
+ v-model="formData.num"
|
|
|
+ :disabled="!canEdit"
|
|
|
+ :step="1"
|
|
|
+ :min="0"
|
|
|
+ class="width1"
|
|
|
+ >
|
|
|
+ </el-input-number>
|
|
|
+ <div class="tip">0表示不限</div>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="application" label="用途">
|
|
|
+ <el-input-number type="application" v-model="formData.application"> </el-input-number>
|
|
|
+ </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: 'MetaDestroyActivityEdit',
|
|
|
- created() {
|
|
|
- if (this.$route.query.id) {
|
|
|
- this.$http
|
|
|
- .get('metaDestroyActivity/get/' + this.$route.query.id)
|
|
|
- .then(res => {
|
|
|
- this.formData = res;
|
|
|
- })
|
|
|
- .catch(e => {
|
|
|
- console.log(e);
|
|
|
- this.$message.error(e.error);
|
|
|
- });
|
|
|
- }
|
|
|
- },
|
|
|
- data() {
|
|
|
- return {
|
|
|
- saving: false,
|
|
|
- formData: {},
|
|
|
- rules: {
|
|
|
- collectionId: [
|
|
|
- {
|
|
|
- required: true,
|
|
|
- message: '请输入藏品id',
|
|
|
- trigger: 'blur'
|
|
|
- }
|
|
|
- ],
|
|
|
- num: [
|
|
|
- {
|
|
|
- required: true,
|
|
|
- message: '请输入数量配置',
|
|
|
- trigger: 'blur'
|
|
|
- }
|
|
|
- ]
|
|
|
- }
|
|
|
- };
|
|
|
- },
|
|
|
- methods: {
|
|
|
- onSave() {
|
|
|
- this.$refs.form.validate(valid => {
|
|
|
- if (valid) {
|
|
|
- this.submit();
|
|
|
- } else {
|
|
|
- return false;
|
|
|
- }
|
|
|
- });
|
|
|
- },
|
|
|
- submit() {
|
|
|
- let data = { ...this.formData };
|
|
|
+ name: 'MetaDestroyActivityEdit',
|
|
|
+ created() {
|
|
|
+ if (this.$route.query.id) {
|
|
|
+ this.$http
|
|
|
+ .get('metaDestroyActivity/get/' + this.$route.query.id)
|
|
|
+ .then(res => {
|
|
|
+ this.formData = res;
|
|
|
+ })
|
|
|
+ .catch(e => {
|
|
|
+ console.log(e);
|
|
|
+ this.$message.error(e.error);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ this.$http.post('/tag/all', { size: 10000 }, { body: 'json' }).then(res => {
|
|
|
+ this.tags = res.content;
|
|
|
+ });
|
|
|
+ },
|
|
|
+ data() {
|
|
|
+ return {
|
|
|
+ tags: [],
|
|
|
+ saving: false,
|
|
|
+ formData: {},
|
|
|
+ rules: {
|
|
|
+ collectionId: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请输入藏品id',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ num: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请输入数量配置',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ audit: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请选择是否需要审核',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ rule: [
|
|
|
+ { required: true, message: '请选择规则', trigger: 'blur' },
|
|
|
+ {
|
|
|
+ validator: (rule, value, callback) => {
|
|
|
+ if (!this.formData.audit) {
|
|
|
+ if (!this.formData.rule) {
|
|
|
+ callback(new Error('请填写规则'));
|
|
|
+ } else if (!this.formData.rule.and) {
|
|
|
+ callback(new Error('请填写规则'));
|
|
|
+ } else if (!this.formData.rule.and.length) {
|
|
|
+ callback(new Error('请填写规则'));
|
|
|
+ } else {
|
|
|
+ for (let i = 0; i < this.formData.rule.and.length; i++) {
|
|
|
+ if (
|
|
|
+ !(this.formData.rule.and[i].detail && this.formData.rule.and[i].detail.tag)
|
|
|
+ ) {
|
|
|
+ callback(new Error('请选择'));
|
|
|
+ callback = null;
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (callback) {
|
|
|
+ callback();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ callback();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ };
|
|
|
+ },
|
|
|
+ computed: {
|
|
|
+ canEdit() {
|
|
|
+ return !!!this.$route.query.id;
|
|
|
+ }
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ onSave() {
|
|
|
+ this.$refs.form.validate(valid => {
|
|
|
+ if (valid) {
|
|
|
+ this.submit();
|
|
|
+ } else {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ },
|
|
|
+ submit() {
|
|
|
+ let data = { ...this.formData };
|
|
|
|
|
|
- this.saving = true;
|
|
|
- this.$http
|
|
|
- .post('/metaDestroyActivity/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(`/metaDestroyActivity/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 || '删除失败');
|
|
|
- }
|
|
|
- });
|
|
|
- }
|
|
|
- }
|
|
|
+ this.saving = true;
|
|
|
+ this.$http
|
|
|
+ .post('/metaDestroyActivity/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(`/metaDestroyActivity/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 || '删除失败');
|
|
|
+ }
|
|
|
+ });
|
|
|
+ },
|
|
|
+ addRule() {
|
|
|
+ if (!(this.formData.rule && this.formData.rule.and)) {
|
|
|
+ this.$set(this.formData, 'rule', { and: [] });
|
|
|
+ }
|
|
|
+ this.formData.rule.and.push({ detail: { tag: null, num: 1 } });
|
|
|
+ },
|
|
|
+ delRule(i) {
|
|
|
+ this.formData.rule.and.splice(i, 1);
|
|
|
+ }
|
|
|
+ }
|
|
|
};
|
|
|
</script>
|
|
|
<style lang="less" scoped>
|
|
|
+.width1 {
|
|
|
+ width: 150px;
|
|
|
+}
|
|
|
+
|
|
|
+.rule-item {
|
|
|
+ display: flex;
|
|
|
+ align-items: center;
|
|
|
+ margin-bottom: 10px;
|
|
|
|
|
|
+ .icon-del {
|
|
|
+ color: #f56c6c;
|
|
|
+ cursor: pointer;
|
|
|
+ font-size: 18px;
|
|
|
+ }
|
|
|
+}
|
|
|
</style>
|