|
|
@@ -3,7 +3,7 @@
|
|
|
<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>
|
|
|
+ <!-- <el-button @click="onSave" :loading="saving" type="primary">保存</el-button> -->
|
|
|
</page-title>
|
|
|
<div class="edit-view__content-wrapper">
|
|
|
<div class="edit-view__content-section">
|
|
|
@@ -11,291 +11,91 @@
|
|
|
:model="formData"
|
|
|
:rules="rules"
|
|
|
ref="form"
|
|
|
- label-width="120px"
|
|
|
+ label-width="110px"
|
|
|
label-position="right"
|
|
|
size="small"
|
|
|
+ style="max-width: 750px"
|
|
|
>
|
|
|
- <el-form-item prop="name" label="名称">
|
|
|
- <el-input v-model="formData.name" :disabled="!canEdit" style="width: 500px"></el-input>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="pic" label="图片">
|
|
|
- <object-upload
|
|
|
- v-model="formData.pic[0]"
|
|
|
- :disabled="!canEdit"
|
|
|
- compress
|
|
|
- width="3000"
|
|
|
- height="3000"
|
|
|
- ></object-upload>
|
|
|
- <div class="tip">支持JPG、PNG、GIF、MP4,推荐长宽比1:1</div>
|
|
|
- </el-form-item>
|
|
|
- <!-- <el-form-item prop="model3d" label="3D模型">
|
|
|
- <model-upload
|
|
|
- :limit="1"
|
|
|
- v-model="formData.model3d"
|
|
|
- :customUrl="customUrl"
|
|
|
- accept="application/zip"
|
|
|
- format="json"
|
|
|
- single
|
|
|
- ></model-upload>
|
|
|
- <div class="tip">请将FBX文件与贴图打包成zip压缩包上传</div>
|
|
|
- </el-form-item> -->
|
|
|
- <el-form-item label="相机距离" v-if="formData.model3d">
|
|
|
- <el-input-number v-model="scale" :min="0.1" :step="0.1"></el-input-number>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="Y轴偏移" v-if="formData.model3d">
|
|
|
- <el-input-number v-model="yOffset"></el-input-number>
|
|
|
- </el-form-item>
|
|
|
- <div class="inline-wrapper">
|
|
|
- <el-form-item prop="minterId" label="铸造者">
|
|
|
- <minter-select
|
|
|
- v-model="formData.minterId"
|
|
|
- @detail="onMinterDetail"
|
|
|
- :disabled="!canEdit"
|
|
|
- ></minter-select>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="category" label="分类">
|
|
|
- <el-select v-model="formData.category" :disabled="!canEdit">
|
|
|
- <el-option
|
|
|
- v-for="item in cateogories"
|
|
|
- :label="item"
|
|
|
- :value="item"
|
|
|
- :key="item"
|
|
|
- ></el-option>
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </div>
|
|
|
- <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="{ $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 label="特权" prop="privileges" style="width: calc(100vw - 450px)">
|
|
|
- <el-table :data="privilegeOptions">
|
|
|
- <el-table-column prop="name" label="可选特权" width="150"></el-table-column>
|
|
|
- <el-table-column prop="description"></el-table-column>
|
|
|
- <el-table-column width="155" align="right">
|
|
|
- <template v-slot="{ row, $index }">
|
|
|
- <el-button size="mini" v-if="!row.added" @click="addPrivilege(row, $index)">
|
|
|
- 添加
|
|
|
- </el-button>
|
|
|
- <el-button size="mini" v-if="!!row.added" plain @click="editPrivilege(row, $index)">
|
|
|
- 编辑
|
|
|
- </el-button>
|
|
|
- <el-button
|
|
|
- size="mini"
|
|
|
- v-if="!!row.added"
|
|
|
- type="danger"
|
|
|
- plain
|
|
|
- @click="delPrivilege(row, $index)"
|
|
|
- >
|
|
|
- 删除
|
|
|
- </el-button>
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- </el-table>
|
|
|
- </el-form-item>
|
|
|
- <div class="inline-wrapper">
|
|
|
- <el-form-item prop="price" label="价格">
|
|
|
- <el-input-number
|
|
|
- type="number"
|
|
|
- v-model="formData.price"
|
|
|
- :disabled="!canEdit"
|
|
|
- ></el-input-number>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="price" label="原价">
|
|
|
- <el-input-number
|
|
|
- type="number"
|
|
|
- v-model="formData.originalPrice"
|
|
|
- :disabled="!canEdit"
|
|
|
- ></el-input-number>
|
|
|
- </el-form-item>
|
|
|
- </div>
|
|
|
- <div class="inline-wrapper">
|
|
|
- <el-form-item prop="royalties" label="版税(%)">
|
|
|
- <el-input-number v-model="formData.royalties" :min="0" :max="99" :disabled="!canEdit">
|
|
|
- </el-input-number>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="serviceCharge" label="手续费(%)">
|
|
|
- <el-input-number v-model="formData.serviceCharge" :min="0" :max="99" :disabled="!canEdit">
|
|
|
- </el-input-number>
|
|
|
- </el-form-item>
|
|
|
- </div>
|
|
|
- <el-form-item prop="total" label="发行数量">
|
|
|
- <el-input-number v-model="formData.total" :disabled="!canEdit"></el-input-number>
|
|
|
- </el-form-item>
|
|
|
-
|
|
|
- <el-form-item prop="scanCode" label="仅扫码可见">
|
|
|
- <el-radio v-model="formData.scanCode" :label="true">是</el-radio>
|
|
|
- <el-radio v-model="formData.scanCode" :label="false">否</el-radio>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="onShelf" label="上架" v-if="!formData.scanCode">
|
|
|
- <el-radio v-model="formData.onShelf" :label="true">是</el-radio>
|
|
|
- <el-radio v-model="formData.onShelf" :label="false">否</el-radio>
|
|
|
- </el-form-item>
|
|
|
-
|
|
|
- <div class="inline-wrapper">
|
|
|
- <el-form-item prop="startTime" label="定时发布">
|
|
|
- <el-radio v-model="formData.scheduleSale" :label="true">是</el-radio>
|
|
|
- <el-radio v-model="formData.scheduleSale" :label="false">否</el-radio>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item
|
|
|
- prop="startTime"
|
|
|
- label="发布时间"
|
|
|
- v-if="formData.scheduleSale"
|
|
|
- style="margin-left: 22px"
|
|
|
- >
|
|
|
- <el-date-picker
|
|
|
- v-model="formData.startTime"
|
|
|
- type="datetime"
|
|
|
- value-format="yyyy-MM-dd HH:mm:ss"
|
|
|
- placeholder="发布时间"
|
|
|
- ></el-date-picker>
|
|
|
- </el-form-item>
|
|
|
- </div>
|
|
|
-
|
|
|
- <el-form-item
|
|
|
- prop="salable"
|
|
|
- label="可售"
|
|
|
- v-if="
|
|
|
- formData.onShelf === true || (formData.scanCode === true && formData.scheduleSale === false)
|
|
|
- "
|
|
|
- >
|
|
|
- <el-radio v-model="formData.salable" :label="true">是</el-radio>
|
|
|
- <el-radio v-model="formData.salable" :label="false">仅展示</el-radio>
|
|
|
- </el-form-item>
|
|
|
-
|
|
|
- <el-form-item prop="sort" label="排序">
|
|
|
+ <el-form-item prop="reason" label="拒绝理由" v-if="formData.reason && formData.status != 'SUCCESS'">
|
|
|
+ <el-input
|
|
|
+ type="textarea"
|
|
|
+ v-model="formData.reason"
|
|
|
+ :rows="3"
|
|
|
+ style="width: 500px"
|
|
|
+ disabled
|
|
|
+ ></el-input>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="sort" label="排序" v-if="formData.status == 'SUCCESS'">
|
|
|
<el-input-number v-model="formData.sort" :min="0"></el-input-number>
|
|
|
<div class="tip">数字越大排序越靠前,相同数值按创建时间倒序排列</div>
|
|
|
</el-form-item>
|
|
|
-
|
|
|
- <div class="inline-wrapper">
|
|
|
- <el-form-item prop="maxCount" label="限购">
|
|
|
- <el-input-number v-model="formData.maxCount" :min="0" :step="1"></el-input-number>
|
|
|
- <div class="tip">0表示不限购</div>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="countId" label="限购识别码" v-if="formData.maxCount > 0">
|
|
|
- <el-input v-model="formData.countId" style="width: 300px"></el-input>
|
|
|
- <div class="tip">相同识别码的藏品共享限购数量</div>
|
|
|
- </el-form-item>
|
|
|
- </div>
|
|
|
-
|
|
|
- <el-form-item prop="holdDays" label="持有天数">
|
|
|
+ <el-form-item prop="maxCollection" label="最多藏品数量">
|
|
|
<el-input-number
|
|
|
type="number"
|
|
|
- :min="0"
|
|
|
- :step="1"
|
|
|
- :max="2147483647"
|
|
|
- v-model="formData.holdDays"
|
|
|
- style="width: 180px"
|
|
|
+ v-model="formData.maxCollection"
|
|
|
></el-input-number>
|
|
|
- <div class="tip">持有多少天可转赠/转让。为空时,按系统设置天数。</div>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="noSoldOut" label="售罄">
|
|
|
- <el-radio v-model="formData.noSoldOut" :label="false">是</el-radio>
|
|
|
- <el-radio v-model="formData.noSoldOut" :label="true">否</el-radio>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="couponPayment" label="支付方式">
|
|
|
- <el-radio-group v-model="formData.couponPayment">
|
|
|
- <el-radio :label="true">兑换券</el-radio>
|
|
|
- <el-radio :label="false">支付宝/微信</el-radio>
|
|
|
- </el-radio-group>
|
|
|
</el-form-item>
|
|
|
-
|
|
|
- <el-form-item prop="vip" label="享有特权">
|
|
|
- <el-radio-group v-model="formData.vip">
|
|
|
- <el-radio :label="true">白名单权利</el-radio>
|
|
|
- <el-radio :label="false">无特权</el-radio>
|
|
|
- </el-radio-group>
|
|
|
- </el-form-item>
|
|
|
-
|
|
|
- <el-form-item prop="headBg" label="展厅头部背景">
|
|
|
- <single-upload v-model="formData.headBg"></single-upload>
|
|
|
+ <el-form-item prop="userId" label="用户ID">
|
|
|
+ <el-input-number
|
|
|
+ type="number"
|
|
|
+ v-model="formData.userId"
|
|
|
+ style="width: 200px"
|
|
|
+ disabled
|
|
|
+ ></el-input-number>
|
|
|
</el-form-item>
|
|
|
- <el-form-item prop="showroomBg" label="展厅背景">
|
|
|
- <single-upload v-model="formData.showroomBg"></single-upload>
|
|
|
+ <el-form-item prop="nickname" label="昵称">
|
|
|
+ <el-input v-model="formData.nickname" style="width: 280px" disabled></el-input>
|
|
|
</el-form-item>
|
|
|
- <el-form-item prop="maxCollection" label="最多可放数量">
|
|
|
- <el-input-number type="number" v-model="formData.maxCollection" :min="1"></el-input-number>
|
|
|
+ <el-form-item prop="pic" label="logo">
|
|
|
+ <single-upload v-model="formData.pic" :disabled="true"></single-upload>
|
|
|
</el-form-item>
|
|
|
-
|
|
|
- <div class="inline-wrapper">
|
|
|
- <el-form-item prop="assignment" label="拉新任务指标">
|
|
|
- <el-input-number
|
|
|
- type="number"
|
|
|
- :min="0"
|
|
|
- :step="1"
|
|
|
- :max="5"
|
|
|
- v-model="formData.assignment"
|
|
|
- ></el-input-number>
|
|
|
- <div class="tip">0表示无拉新任务限制</div>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="totalQuota" label="白名单额度" v-if="formData.assignment > 0">
|
|
|
- <el-input-number
|
|
|
- type="number"
|
|
|
- :min="0"
|
|
|
- :step="1"
|
|
|
- v-model="formData.totalQuota"
|
|
|
- :disabled="!editQuota"
|
|
|
- ></el-input-number>
|
|
|
- <div class="tip">多少人拉新可获得积分</div>
|
|
|
- </el-form-item>
|
|
|
- </div>
|
|
|
- <el-form-item prop="openQuota" label="白名单分享" v-if="formData.assignment > 0">
|
|
|
- <el-radio v-model="formData.openQuota" :label="true">开启</el-radio>
|
|
|
- <el-radio v-model="formData.openQuota" :label="false">关闭</el-radio>
|
|
|
+ <el-form-item prop="introduction" label="简介">
|
|
|
+ <el-input type="textarea" :rows="4" v-model="formData.introduction" disabled></el-input>
|
|
|
</el-form-item>
|
|
|
- <div class="inline-wrapper">
|
|
|
- <el-form-item prop="timeDelay" label="延迟销售" v-if="formData.assignment > 0">
|
|
|
- <el-radio v-model="formData.timeDelay" :label="true">是</el-radio>
|
|
|
- <el-radio v-model="formData.timeDelay" :label="false">否</el-radio>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item
|
|
|
- prop="saleTime"
|
|
|
- label="销售时间"
|
|
|
- v-if="formData.assignment > 0 && formData.timeDelay"
|
|
|
- style="margin-left: 22px"
|
|
|
- >
|
|
|
- <el-date-picker
|
|
|
- v-model="formData.saleTime"
|
|
|
- type="datetime"
|
|
|
- value-format="yyyy-MM-dd HH:mm:ss"
|
|
|
- placeholder="销售时间"
|
|
|
- ></el-date-picker>
|
|
|
- </el-form-item>
|
|
|
- </div>
|
|
|
-
|
|
|
- <el-form-item label="分享海报" v-if="formData.assignment > 0">
|
|
|
- <single-upload v-model="formData.shareBg"></single-upload>
|
|
|
+ <el-form-item prop="headBg" label="背景">
|
|
|
+ <el-image :src="formData.headBg" style="height: 170px"></el-image>
|
|
|
+ <el-image :src="formData.showroomBg" style="height: 170px"></el-image>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="注册海报" v-if="formData.assignment > 0">
|
|
|
- <single-upload v-model="formData.registerBg"></single-upload>
|
|
|
+ <!-- <el-form-item prop="publish" label="发布">
|
|
|
+ <el-radio v-model="formData.publish" :label="true">是</el-radio>
|
|
|
+ <el-radio v-model="formData.publish" :label="false">否</el-radio>
|
|
|
+ </el-form-item> -->
|
|
|
+ <!-- <el-form-item prop="status" label="状态">
|
|
|
+ <el-select v-model="formData.status" clearable filterable placeholder="请选择">
|
|
|
+ <el-option
|
|
|
+ v-for="item in statusOptions"
|
|
|
+ :key="item.value"
|
|
|
+ :label="item.label"
|
|
|
+ :value="item.value"
|
|
|
+ >
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item> -->
|
|
|
+ <el-form-item prop="collections" label="藏品">
|
|
|
+ <el-table :data="formData.collections">
|
|
|
+ <el-table-column type="index" label="#"></el-table-column>
|
|
|
+ <el-table-column prop="collectionId" label="ID" width="110">
|
|
|
+ <template slot-scope="{ row }">
|
|
|
+ <el-link @click="$router.push('/companyCollectionShelf?id=' + row.collectionId)">{{
|
|
|
+ row.collectionId
|
|
|
+ }}</el-link>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="pic" label="图" width="110">
|
|
|
+ <template slot-scope="{ row }">
|
|
|
+ <el-image
|
|
|
+ style="width: 30px; height: 30px"
|
|
|
+ :src="row.pic"
|
|
|
+ fit="cover"
|
|
|
+ :preview-src-list="[row.pic]"
|
|
|
+ ></el-image>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="name" label="名称"></el-table-column>
|
|
|
+ </el-table>
|
|
|
</el-form-item>
|
|
|
-
|
|
|
<el-form-item class="form-submit">
|
|
|
- <el-button @click="onSave" :loading="saving" type="primary"> 保存 </el-button>
|
|
|
+ <!-- <el-button @click="onSave" :loading="saving" type="primary"> 保存 </el-button> -->
|
|
|
<!-- <el-button @click="onDelete" :disabled="saving" type="danger" v-if="formData.id">
|
|
|
删除
|
|
|
</el-button> -->
|
|
|
@@ -304,345 +104,35 @@
|
|
|
</el-form>
|
|
|
</div>
|
|
|
</div>
|
|
|
-
|
|
|
- <el-dialog :visible.sync="showPrivilegeEditDialog" width="600px" :title="privilegeForm.name">
|
|
|
- <el-form
|
|
|
- ref="privilegeForm"
|
|
|
- :model="privilegeForm"
|
|
|
- label-position="right"
|
|
|
- label-width="80px"
|
|
|
- :rules="privelegeRules"
|
|
|
- >
|
|
|
- <el-form-item
|
|
|
- prop="detail"
|
|
|
- label="详细内容"
|
|
|
- v-if="privilegeForm.type === 'text' || privilegeForm.type === 'exchange'"
|
|
|
- >
|
|
|
- <el-input type="textarea" :autosize="{ minRows: 3 }" v-model="privilegeForm.detail"></el-input>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item prop="detail" label="二维码" v-if="privilegeForm.type === 'qrcode'">
|
|
|
- <single-upload v-model="privilegeForm.detail"></single-upload>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item
|
|
|
- prop="remark"
|
|
|
- label="说明"
|
|
|
- v-if="privilegeForm.type === 'qrcode' || privilegeForm.type === 'code'"
|
|
|
- >
|
|
|
- <el-input type="textarea" :autosize="{ minRows: 3 }" v-model="privilegeForm.remark"></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-form>
|
|
|
- <div slot="footer">
|
|
|
- <el-button @click="showPrivilegeEditDialog = false">取消</el-button>
|
|
|
- <el-button type="primary" @click="savePrivilege">保存</el-button>
|
|
|
- </div>
|
|
|
- </el-dialog>
|
|
|
</div>
|
|
|
</template>
|
|
|
<script>
|
|
|
-import resolveUrl from 'resolve-url';
|
|
|
-import ModelUpload from '../components/ModelUpload.vue';
|
|
|
-import { format, parse, isBefore } from 'date-fns';
|
|
|
-import SingleUpload from '../components/SingleUpload.vue';
|
|
|
export default {
|
|
|
- name: 'CollectionEdit',
|
|
|
- components: { ModelUpload, SingleUpload },
|
|
|
+ name: 'ShowroomEdit',
|
|
|
created() {
|
|
|
- Promise.all([
|
|
|
- new Promise((resolve, reject) => {
|
|
|
- if (this.$route.query.id) {
|
|
|
- return this.$http
|
|
|
- .get('collection/getInfo/' + this.$route.query.id)
|
|
|
- .then(res => {
|
|
|
- if (res.model3d) {
|
|
|
- let url = new URL(res.model3d.url);
|
|
|
- this.scale = Number(url.searchParams.get('scale')) || 1;
|
|
|
- this.yOffset = Number(url.searchParams.get('yOffset')) || 0;
|
|
|
- res.model3d.url = url.origin + url.pathname;
|
|
|
- }
|
|
|
- res.properties = res.properties || [];
|
|
|
- res.privileges = res.privileges || [];
|
|
|
- this.formData = res;
|
|
|
- if (res.totalQuota !== res.vipQuota) {
|
|
|
- this.editQuota = false;
|
|
|
- }
|
|
|
- resolve();
|
|
|
- })
|
|
|
- .catch(e => {
|
|
|
- console.log(e);
|
|
|
- this.$message.error(e.error);
|
|
|
- resolve();
|
|
|
- });
|
|
|
- }
|
|
|
- return resolve();
|
|
|
- }),
|
|
|
+ if (this.$route.query.id) {
|
|
|
this.$http
|
|
|
- .post('/privilegeOption/all', { size: 10000, query: { del: false } }, { body: 'json' })
|
|
|
+ .get('showroom/get/' + this.$route.query.id)
|
|
|
.then(res => {
|
|
|
- this.privilegeOptions = res.content;
|
|
|
- return Promise.resolve();
|
|
|
+ this.formData = res;
|
|
|
})
|
|
|
- ]).then(() => {
|
|
|
- console.log(this.formData, this.privilegeOptions);
|
|
|
- this.formData.privileges.forEach(p => {
|
|
|
- let idx = this.privilegeOptions.findIndex(i => i.name === p.name);
|
|
|
- if (idx > -1) {
|
|
|
- this.$set(this.privilegeOptions[idx], 'added', true);
|
|
|
- }
|
|
|
- });
|
|
|
- });
|
|
|
- },
|
|
|
- computed: {
|
|
|
- canEdit() {
|
|
|
- return !!!this.$route.query.id;
|
|
|
+ .catch(e => {
|
|
|
+ console.log(e);
|
|
|
+ this.$message.error(e.error);
|
|
|
+ });
|
|
|
}
|
|
|
},
|
|
|
data() {
|
|
|
return {
|
|
|
saving: false,
|
|
|
- formData: {
|
|
|
- onShelf: false,
|
|
|
- salable: true,
|
|
|
- properties: [],
|
|
|
- type: 'SHOWROOM',
|
|
|
- source: 'OFFICIAL',
|
|
|
- pic: [],
|
|
|
- scheduleSale: true,
|
|
|
- sort: 0,
|
|
|
- privileges: [],
|
|
|
- maxCount: 0,
|
|
|
- countId: null,
|
|
|
- canResale: true,
|
|
|
- scanCode: false,
|
|
|
- noSoldOut: true,
|
|
|
- assignment: 0,
|
|
|
- couponPayment: false,
|
|
|
- maxCollection: 20
|
|
|
- },
|
|
|
- rules: {
|
|
|
- name: [
|
|
|
- {
|
|
|
- required: true,
|
|
|
- message: '请输入名称',
|
|
|
- trigger: 'blur'
|
|
|
- }
|
|
|
- ],
|
|
|
- pic: [
|
|
|
- {
|
|
|
- validator: (rule, value, callback) => {
|
|
|
- if (value) {
|
|
|
- if (!(value instanceof Array)) {
|
|
|
- callback(new Error('请上传内容'));
|
|
|
- return;
|
|
|
- } else {
|
|
|
- for (let f of value) {
|
|
|
- if (!f.url) {
|
|
|
- callback(new Error('请上传内容'));
|
|
|
- return;
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- callback();
|
|
|
- } else {
|
|
|
- callback(new Error('请上传内容'));
|
|
|
- }
|
|
|
- },
|
|
|
- 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'
|
|
|
- }
|
|
|
- ],
|
|
|
- category: [{ required: true, message: '请填写分类' }],
|
|
|
- royalties: [{ required: true, message: '请填写版税' }],
|
|
|
- serviceCharge: [{ required: true, message: '请填手续费' }],
|
|
|
- startTime: [
|
|
|
- {
|
|
|
- validator: (rule, value, callback) => {
|
|
|
- if (this.formData.scheduleSale) {
|
|
|
- if (!value) {
|
|
|
- callback(new Error('请填写发布时间'));
|
|
|
- } else if (isBefore(parse(value, 'yyyy-MM-dd HH:mm:ss', new Date()), new Date())) {
|
|
|
- callback(new Error('发布时间不能小于当前时间'));
|
|
|
- } else {
|
|
|
- callback();
|
|
|
- }
|
|
|
- } else {
|
|
|
- callback();
|
|
|
- }
|
|
|
- },
|
|
|
- trigger: 'blur'
|
|
|
- }
|
|
|
- ],
|
|
|
- saleTime: [
|
|
|
- {
|
|
|
- validator: (rule, value, callback) => {
|
|
|
- if (this.formData.timeDelay) {
|
|
|
- if (!value) {
|
|
|
- callback(new Error('请填写销售时间'));
|
|
|
- } else if (isBefore(parse(value, 'yyyy-MM-dd HH:mm:ss', new Date()), new Date())) {
|
|
|
- callback(new Error('销售时间不能小于当前时间'));
|
|
|
- } else if (this.formData.scheduleSale) {
|
|
|
- if (
|
|
|
- isBefore(
|
|
|
- parse(value, 'yyyy-MM-dd HH:mm:ss', new Date()),
|
|
|
- parse(this.formData.startTime, 'yyyy-MM-dd HH:mm:ss', new Date())
|
|
|
- )
|
|
|
- ) {
|
|
|
- callback(new Error('销售时间不能小于发布时间'));
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- callback();
|
|
|
- },
|
|
|
- trigger: 'blur'
|
|
|
- }
|
|
|
- ],
|
|
|
- timeDelay: [
|
|
|
- {
|
|
|
- validator: (rule, value, callback) => {
|
|
|
- if (this.formData.assignment > 0) {
|
|
|
- if (value === '' || value === undefined) {
|
|
|
- callback(new Error('请选择是否延迟销售'));
|
|
|
- return;
|
|
|
- }
|
|
|
- }
|
|
|
- callback();
|
|
|
- },
|
|
|
- trigger: 'blur'
|
|
|
- }
|
|
|
- ],
|
|
|
- totalQuota: [
|
|
|
- {
|
|
|
- validator: (rule, value, callback) => {
|
|
|
- if (this.formData.assignment > 0) {
|
|
|
- if (value === '' || value === undefined) {
|
|
|
- callback(new Error('请输入白名单额度'));
|
|
|
- return;
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- callback();
|
|
|
- },
|
|
|
- trigger: 'blur'
|
|
|
- }
|
|
|
- ],
|
|
|
- openQuota: [
|
|
|
- {
|
|
|
- validator: (rule, value, callback) => {
|
|
|
- if (this.formData.assignment > 0) {
|
|
|
- if (value === '' || value === undefined) {
|
|
|
- callback(new Error('请选择开启/关闭白名单分享'));
|
|
|
- return;
|
|
|
- }
|
|
|
- }
|
|
|
- callback();
|
|
|
- },
|
|
|
- trigger: 'blur'
|
|
|
- }
|
|
|
- ]
|
|
|
- },
|
|
|
- sourceOptions: [
|
|
|
- { label: '官方', value: 'OFFICIAL' },
|
|
|
- { label: '用户铸造', value: 'USER' },
|
|
|
- { label: '转让', value: 'TRANSFER' }
|
|
|
- ],
|
|
|
- cateogories: ['勋章', '收藏品', '数字艺术', '门票', '游戏', '音乐', '使用', '其他'],
|
|
|
- privilegeOptions: [],
|
|
|
- showPrivilegeEditDialog: false,
|
|
|
- privilegeForm: {},
|
|
|
- privelegeRules: {
|
|
|
- detail: [{ required: true, message: '请填写内容' }],
|
|
|
- remark: [{ required: true, message: '请填写说明' }]
|
|
|
- },
|
|
|
- customUrl: resolveUrl(this.$baseUrl, 'upload/3dModel'),
|
|
|
- scale: 1,
|
|
|
- yOffset: 0,
|
|
|
- editQuota: true
|
|
|
+ formData: {},
|
|
|
+ rules: {},
|
|
|
+ statusOptions: [
|
|
|
+ { label: '未审核', value: 'NOT_AUTH' },
|
|
|
+ { label: '认证中', value: 'PENDING' },
|
|
|
+ { label: '已认证', value: 'SUCCESS' },
|
|
|
+ { label: '失败', value: 'FAIL' }
|
|
|
+ ]
|
|
|
};
|
|
|
},
|
|
|
methods: {
|
|
|
@@ -657,16 +147,10 @@ export default {
|
|
|
},
|
|
|
submit() {
|
|
|
let data = { ...this.formData };
|
|
|
- if (data.model3d) {
|
|
|
- data.model3d.url = data.model3d.url + '?scale=' + this.scale + '&yOffset=' + this.yOffset;
|
|
|
- }
|
|
|
- if (this.editQuota && data.totalQuota) {
|
|
|
- data.vipQuota = data.totalQuota;
|
|
|
- }
|
|
|
|
|
|
this.saving = true;
|
|
|
this.$http
|
|
|
- .post(this.formData.id ? '/collection/save' : '/collection/create', data, { body: 'json' })
|
|
|
+ .post('/showroom/save', data, { body: 'json' })
|
|
|
.then(res => {
|
|
|
this.saving = false;
|
|
|
this.$message.success('成功');
|
|
|
@@ -681,7 +165,7 @@ export default {
|
|
|
onDelete() {
|
|
|
this.$confirm('删除将无法恢复,确认要删除么?', '警告', { type: 'error' })
|
|
|
.then(() => {
|
|
|
- return this.$http.post(`/collection/del/${this.formData.id}`);
|
|
|
+ return this.$http.post(`/showroom/del/${this.formData.id}`);
|
|
|
})
|
|
|
.then(() => {
|
|
|
this.$message.success('删除成功');
|
|
|
@@ -693,104 +177,25 @@ export default {
|
|
|
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);
|
|
|
- },
|
|
|
- addPrivilege(row, i) {
|
|
|
- this.privilegeForm = { ...row };
|
|
|
- this.showPrivilegeEditDialog = true;
|
|
|
- if (this.$refs.privilegeForm) {
|
|
|
- this.$nextTick(() => {
|
|
|
- this.$refs.privilegeForm.clearValidate();
|
|
|
- });
|
|
|
- }
|
|
|
- },
|
|
|
- editPrivilege(row, i) {
|
|
|
- this.privilegeForm = { ...(this.formData.privileges.find(e => e.name === row.name) || {}) };
|
|
|
- this.showPrivilegeEditDialog = true;
|
|
|
- if (this.$refs.privilegeForm) {
|
|
|
- this.$nextTick(() => {
|
|
|
- this.$refs.privilegeForm.clearValidate();
|
|
|
- });
|
|
|
- }
|
|
|
- },
|
|
|
- delPrivilege(row, i) {
|
|
|
- let idx = this.formData.privileges.findIndex(e => e.name === row.name);
|
|
|
- if (idx > -1) {
|
|
|
- this.formData.privileges.splice(idx, 1);
|
|
|
- }
|
|
|
- this.$set(this.privilegeOptions[i], 'added', false);
|
|
|
- },
|
|
|
- savePrivilege() {
|
|
|
- this.$refs.privilegeForm
|
|
|
- .validate()
|
|
|
- .then(() => {
|
|
|
- let i = this.formData.privileges.findIndex(e => e.name === this.privilegeForm.name);
|
|
|
- if (i > -1) {
|
|
|
- this.$set(this.formData.privileges, i, { ...this.privilegeForm });
|
|
|
- } else {
|
|
|
- this.formData.privileges.push({ ...this.privilegeForm });
|
|
|
- }
|
|
|
- let ii = this.privilegeOptions.findIndex(i => i.name === this.privilegeForm.name);
|
|
|
- console.log(ii);
|
|
|
- this.$set(this.privilegeOptions[ii], 'added', true);
|
|
|
- this.showPrivilegeEditDialog = false;
|
|
|
- })
|
|
|
- .catch(e => {
|
|
|
- console.log(e);
|
|
|
- });
|
|
|
- }
|
|
|
- },
|
|
|
- watch: {
|
|
|
- 'formData.scanCode'(val) {
|
|
|
- if (val === true) {
|
|
|
- this.$set(this.formData, 'onShelf', false);
|
|
|
- }
|
|
|
}
|
|
|
}
|
|
|
};
|
|
|
</script>
|
|
|
<style lang="less" scoped>
|
|
|
-/deep/ .el-switch__label--left {
|
|
|
- width: 50px;
|
|
|
- text-align: right;
|
|
|
+/deep/.el-input.is-disabled .el-input__inner {
|
|
|
+ color: #7c7e7e;
|
|
|
}
|
|
|
-.number-percent {
|
|
|
- display: flex;
|
|
|
- align-items: center;
|
|
|
- .percent {
|
|
|
- border: 1px solid #dcdfe6;
|
|
|
- border-radius: 4px;
|
|
|
- width: 30px;
|
|
|
- text-align: center;
|
|
|
- line-height: 30px;
|
|
|
- color: @text2;
|
|
|
- font-size: 13px;
|
|
|
- }
|
|
|
-}
|
|
|
-.tip {
|
|
|
- font-size: 12px;
|
|
|
- color: @text3;
|
|
|
- margin-top: 5px;
|
|
|
+/deep/.el-textarea.is-disabled .el-textarea__inner {
|
|
|
+ color: #7c7e7e;
|
|
|
}
|
|
|
.inline-wrapper {
|
|
|
.el-form-item {
|
|
|
display: inline-block;
|
|
|
}
|
|
|
}
|
|
|
-.right-margin {
|
|
|
- margin-left: 50px;
|
|
|
+.tip {
|
|
|
+ font-size: 12px;
|
|
|
+ color: @text3;
|
|
|
+ margin-top: 5px;
|
|
|
}
|
|
|
-</style>
|
|
|
+</style>
|