|
@@ -0,0 +1,409 @@
|
|
|
|
|
+<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="94px"
|
|
|
|
|
+ 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="pics" label="图片">
|
|
|
|
|
+ <multi-upload v-model="formData.pics"></multi-upload>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="minterId" label="创建者">
|
|
|
|
|
+ <minter-select v-model="formData.minterId" @detail="onMinterDetail"></minter-select>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="detail" label="详情" style="width: calc(100vw - 450px)">
|
|
|
|
|
+ <rich-text v-model="formData.detail"></rich-text>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="properties" label="特性" style="width: calc(100vw - 450px)" size="mini">
|
|
|
|
|
+ <el-table :data="formData.properties">
|
|
|
|
|
+ <el-table-column prop="name" label="名称">
|
|
|
|
|
+ <template v-slot="{ row }">
|
|
|
|
|
+ <el-input v-model="row.name" placeholder="20字以内" maxlength="20"></el-input>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </el-table-column>
|
|
|
|
|
+ <el-table-column prop="value" label="内容">
|
|
|
|
|
+ <template v-slot="{ row }">
|
|
|
|
|
+ <el-input v-model="row.value" placeholder="20字以内" maxlength="20"></el-input>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </el-table-column>
|
|
|
|
|
+ <el-table-column width="80" align="center">
|
|
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
|
|
+ <el-button type="danger" plain size="mini" @click="delProperty($index)">
|
|
|
|
|
+ 删除
|
|
|
|
|
+ </el-button>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </el-table-column>
|
|
|
|
|
+ </el-table>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item>
|
|
|
|
|
+ <el-button size="mini" @click="addProperty"> 添加特性 </el-button>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <!-- <el-form-item prop="type" label="类型">
|
|
|
|
|
+ <el-select v-model="formData.type" clearable filterable placeholder="请选择">
|
|
|
|
|
+ <el-option
|
|
|
|
|
+ v-for="item in typeOptions"
|
|
|
|
|
+ :key="item.value"
|
|
|
|
|
+ :label="item.label"
|
|
|
|
|
+ :value="item.value"
|
|
|
|
|
+ >
|
|
|
|
|
+ </el-option>
|
|
|
|
|
+ </el-select>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="source" label="来源">
|
|
|
|
|
+ <el-select v-model="formData.source" clearable filterable placeholder="请选择">
|
|
|
|
|
+ <el-option
|
|
|
|
|
+ v-for="item in sourceOptions"
|
|
|
|
|
+ :key="item.value"
|
|
|
|
|
+ :label="item.label"
|
|
|
|
|
+ :value="item.value"
|
|
|
|
|
+ >
|
|
|
|
|
+ </el-option>
|
|
|
|
|
+ </el-select>
|
|
|
|
|
+ </el-form-item> -->
|
|
|
|
|
+ <el-form-item prop="price" label="价格">
|
|
|
|
|
+ <el-input-number type="number" v-model="formData.price"></el-input-number>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="total" label="发行数量">
|
|
|
|
|
+ <el-input-number v-model="formData.total" disabled></el-input-number>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="collectionIds" label="包含作品" style="width: calc(100vw - 450px)">
|
|
|
|
|
+ <el-table :data="blindBoxItems">
|
|
|
|
|
+ <el-table-column
|
|
|
|
|
+ prop="id"
|
|
|
|
|
+ label="名称"
|
|
|
|
|
+ :formatter="collectionNameFormatter"
|
|
|
|
|
+ ></el-table-column>
|
|
|
|
|
+ <el-table-column prop="total" label="数量" width="100"></el-table-column>
|
|
|
|
|
+ <el-table-column prop="rare" label="稀有" width="100">
|
|
|
|
|
+ <template v-slot="{ row }">
|
|
|
|
|
+ <el-tag :type="row.rare ? 'success' : 'info'">{{ row.rare ? '是' : '否' }}</el-tag>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </el-table-column>
|
|
|
|
|
+ <el-table-column width="100">
|
|
|
|
|
+ <template v-slot="{ row, $index }">
|
|
|
|
|
+ <el-button @click="removeItem($index)" type="danger" plain size="mini"
|
|
|
|
|
+ >移除</el-button
|
|
|
|
|
+ >
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </el-table-column>
|
|
|
|
|
+ </el-table>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item>
|
|
|
|
|
+ <el-button size="mini" @click="addItem">添加作品</el-button>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <!-- <el-form-item prop="likes" label="点赞">
|
|
|
|
|
+ <el-input-number v-model="formData.likes"></el-input-number>
|
|
|
|
|
+ </el-form-item> -->
|
|
|
|
|
+ <el-form-item prop="onShelf" label="上架">
|
|
|
|
|
+ <el-switch v-model="formData.onShelf" active-text="上架" inactive-text="下架"></el-switch>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="salable" label="可售">
|
|
|
|
|
+ <el-switch v-model="formData.salable" active-text="可销售" inactive-text="仅展示"></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>
|
|
|
|
|
+ <el-dialog :visible.sync="showAddItemDialog" title="添加" width="600px">
|
|
|
|
|
+ <el-form
|
|
|
|
|
+ :model="addItemForm"
|
|
|
|
|
+ label-position="right"
|
|
|
|
|
+ label-width="80px"
|
|
|
|
|
+ ref="addItemForm"
|
|
|
|
|
+ :rules="addItemFormRules"
|
|
|
|
|
+ >
|
|
|
|
|
+ <el-form-item prop="id" label="作品">
|
|
|
|
|
+ <el-select v-model="addItemForm.id">
|
|
|
|
|
+ <el-option
|
|
|
|
|
+ v-for="item in collections"
|
|
|
|
|
+ :label="item.name"
|
|
|
|
|
+ :value="item.id"
|
|
|
|
|
+ :key="item.id"
|
|
|
|
|
+ ></el-option>
|
|
|
|
|
+ </el-select>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="total" label="数量">
|
|
|
|
|
+ <el-input-number v-model="addItemForm.total" :min="1" :max="addItemForm.max || 0"></el-input-number>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item prop="rare" label="稀有">
|
|
|
|
|
+ <el-switch v-model="addItemForm.rare" active-text="是" inactive-text="否"></el-switch>
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ </el-form>
|
|
|
|
|
+ <div slot="footer">
|
|
|
|
|
+ <el-button size="mini" @click="showAddItemDialog = false">取消</el-button>
|
|
|
|
|
+ <el-button size="mini" @click="onAddItem" type="primary">确定</el-button>
|
|
|
|
|
+ </div>
|
|
|
|
|
+ </el-dialog>
|
|
|
|
|
+ </div>
|
|
|
|
|
+</template>
|
|
|
|
|
+<script>
|
|
|
|
|
+export default {
|
|
|
|
|
+ name: 'BlindBoxEdit',
|
|
|
|
|
+ created() {
|
|
|
|
|
+ if (this.$route.query.id) {
|
|
|
|
|
+ this.$http
|
|
|
|
|
+ .get('collection/get/' + this.$route.query.id)
|
|
|
|
|
+ .then(res => {
|
|
|
|
|
+ res.properties = res.properties || [];
|
|
|
|
|
+ this.formData = res;
|
|
|
|
|
+ })
|
|
|
|
|
+ .catch(e => {
|
|
|
|
|
+ console.log(e);
|
|
|
|
|
+ this.$message.error(e.error);
|
|
|
|
|
+ });
|
|
|
|
|
+ this.$http
|
|
|
|
|
+ .post(
|
|
|
|
|
+ '/blindBoxItem/all',
|
|
|
|
|
+ { query: { blindBoxId: this.$route.query.id }, size: 10000 },
|
|
|
|
|
+ { body: 'json' }
|
|
|
|
|
+ )
|
|
|
|
|
+ .then(res => {
|
|
|
|
|
+ this.blindBoxItems = res.content;
|
|
|
|
|
+ });
|
|
|
|
|
+ }
|
|
|
|
|
+ this.$http.post('/collection/all', { query: { del: false }, size: 10000 }, { body: 'json' }).then(res => {
|
|
|
|
|
+ this.collections = res.content;
|
|
|
|
|
+ });
|
|
|
|
|
+ },
|
|
|
|
|
+ data() {
|
|
|
|
|
+ return {
|
|
|
|
|
+ saving: false,
|
|
|
|
|
+ formData: { onShelf: true, salable: true, properties: [], type: 'BLIND_BOX', source: 'OFFICIAL' },
|
|
|
|
|
+ rules: {
|
|
|
|
|
+ name: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入名称',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ pics: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入图片',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ minter: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入创建者',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ minterId: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入铸造者ID',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ minterAvatar: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入铸造者头像',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ detail: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入详情',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ type: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入类型',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ source: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入来源',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ total: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入发行数量',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ onShelf: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入上架',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ price: [
|
|
|
|
|
+ {
|
|
|
|
|
+ required: true,
|
|
|
|
|
+ message: '请输入价格',
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ],
|
|
|
|
|
+ properties: [
|
|
|
|
|
+ {
|
|
|
|
|
+ validator: (rule, value, callback) => {
|
|
|
|
|
+ if (value) {
|
|
|
|
|
+ if (!(value instanceof Array)) {
|
|
|
|
|
+ callback(new Error('properties must be array!'));
|
|
|
|
|
+ return;
|
|
|
|
|
+ } else {
|
|
|
|
|
+ for (let i = 0; i < value.length; i++) {
|
|
|
|
|
+ if (value[i].name === '' || value[i].name === undefined) {
|
|
|
|
|
+ callback(new Error('请填写名称'));
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ if (value[i].value === '' || value[i].value === undefined) {
|
|
|
|
|
+ callback(new Error('请填写内容'));
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ callback();
|
|
|
|
|
+ },
|
|
|
|
|
+ trigger: 'blur'
|
|
|
|
|
+ }
|
|
|
|
|
+ ]
|
|
|
|
|
+ },
|
|
|
|
|
+ typeOptions: [
|
|
|
|
|
+ { label: '默认', value: 'DEFAULT' },
|
|
|
|
|
+ { label: '盲盒', value: 'BLIND_BOX' },
|
|
|
|
|
+ { label: '拍卖', value: 'AUCTION' }
|
|
|
|
|
+ ],
|
|
|
|
|
+ sourceOptions: [
|
|
|
|
|
+ { label: '官方', value: 'OFFICIAL' },
|
|
|
|
|
+ { label: '用户铸造', value: 'USER' },
|
|
|
|
|
+ { label: '转让', value: 'TRANSFER' }
|
|
|
|
|
+ ],
|
|
|
|
|
+ collections: [],
|
|
|
|
|
+ showAddItemDialog: false,
|
|
|
|
|
+ blindBoxItems: [],
|
|
|
|
|
+ addItemForm: {},
|
|
|
|
|
+ addItemFormRules: {
|
|
|
|
|
+ id: [{ required: true, message: '请选择作品' }],
|
|
|
|
|
+ total: [{ required: true, message: '请输入数量' }]
|
|
|
|
|
+ }
|
|
|
|
|
+ };
|
|
|
|
|
+ },
|
|
|
|
|
+ methods: {
|
|
|
|
|
+ onSave() {
|
|
|
|
|
+ this.$refs.form.validate(valid => {
|
|
|
|
|
+ if (valid) {
|
|
|
|
|
+ this.submit();
|
|
|
|
|
+ } else {
|
|
|
|
|
+ return false;
|
|
|
|
|
+ }
|
|
|
|
|
+ });
|
|
|
|
|
+ },
|
|
|
|
|
+ submit() {
|
|
|
|
|
+ let data = { blindBox: { ...this.formData }, items: this.blindBoxItems };
|
|
|
|
|
+
|
|
|
|
|
+ this.saving = true;
|
|
|
|
|
+ this.$http
|
|
|
|
|
+ .post('/collection/createBlindBox', 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(`/collection/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 || '删除失败');
|
|
|
|
|
+ }
|
|
|
|
|
+ });
|
|
|
|
|
+ },
|
|
|
|
|
+ onMinterDetail(e) {
|
|
|
|
|
+ console.log(e);
|
|
|
|
|
+ this.$set(this.formData, 'minter', e.nickname);
|
|
|
|
|
+ this.$set(this.formData, 'minterAvatar', e.avatar);
|
|
|
|
|
+ },
|
|
|
|
|
+ addProperty() {
|
|
|
|
|
+ this.formData.properties.push({
|
|
|
|
|
+ name: '',
|
|
|
|
|
+ value: ''
|
|
|
|
|
+ });
|
|
|
|
|
+ },
|
|
|
|
|
+ delProperty(i) {
|
|
|
|
|
+ this.formData.properties.splice(i, 1);
|
|
|
|
|
+ },
|
|
|
|
|
+ addItem() {
|
|
|
|
|
+ this.addItemForm = { rare: false };
|
|
|
|
|
+ this.showAddItemDialog = true;
|
|
|
|
|
+ },
|
|
|
|
|
+ onAddItem() {
|
|
|
|
|
+ this.$refs.addItemForm
|
|
|
|
|
+ .validate()
|
|
|
|
|
+ .then(_ => {
|
|
|
|
|
+ this.blindBoxItems.push({ ...this.addItemForm });
|
|
|
|
|
+ this.showAddItemDialog = false;
|
|
|
|
|
+ })
|
|
|
|
|
+ .catch(_ => {});
|
|
|
|
|
+ },
|
|
|
|
|
+ collectionNameFormatter(row, column, value, index) {
|
|
|
|
|
+ return (this.collections.find(i => i.id === value) || {}).name || '';
|
|
|
|
|
+ },
|
|
|
|
|
+ removeItem(i) {
|
|
|
|
|
+ this.blindBoxItems.splice(i, 1);
|
|
|
|
|
+ }
|
|
|
|
|
+ },
|
|
|
|
|
+ watch: {
|
|
|
|
|
+ 'addItemForm.id'(val) {
|
|
|
|
|
+ if (val) {
|
|
|
|
|
+ this.$set(this.addItemForm, 'max', (this.collections.find(i => i.id === val) || {}).stock || 0);
|
|
|
|
|
+ }
|
|
|
|
|
+ },
|
|
|
|
|
+ blindBoxItems() {
|
|
|
|
|
+ this.$set(
|
|
|
|
|
+ this.formData,
|
|
|
|
|
+ 'total',
|
|
|
|
|
+ this.blindBoxItems.map(i => i.total).reduce((a, b) => a + b, 0)
|
|
|
|
|
+ );
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+};
|
|
|
|
|
+</script>
|
|
|
|
|
+<style lang="less" scoped></style>
|