|
|
@@ -0,0 +1,471 @@
|
|
|
+<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"
|
|
|
+ >
|
|
|
+ <el-form-item prop="reason" label="拒绝理由" v-if="formData.reason">
|
|
|
+ <el-input
|
|
|
+ type="textarea"
|
|
|
+ v-model="formData.reason"
|
|
|
+ :rows="3"
|
|
|
+ style="width: calc(90vw - 450px)"
|
|
|
+ disabled
|
|
|
+ ></el-input>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="name" label="名称">
|
|
|
+ <el-input v-model="formData.name" disabled style="width: 500px"></el-input>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="pic" label="图片">
|
|
|
+ <object-upload
|
|
|
+ v-model="formData.pic[0]"
|
|
|
+ disabled
|
|
|
+ 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>
|
|
|
+ <el-form-item prop="category" label="分类">
|
|
|
+ <el-select v-model="formData.category" disabled>
|
|
|
+ <el-option v-for="item in cateogories" :label="item" :value="item" :key="item"></el-option>
|
|
|
+ </el-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"
|
|
|
+ disabled
|
|
|
+ ></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"
|
|
|
+ disabled
|
|
|
+ ></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="125" 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></el-input-number>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item prop="price" label="原价">
|
|
|
+ <el-input-number type="number" v-model="formData.originalPrice" disabled></el-input-number>
|
|
|
+ </el-form-item>
|
|
|
+ </div>
|
|
|
+ <el-form-item prop="total" label="发行数量">
|
|
|
+ <el-input-number v-model="formData.total" disabled></el-input-number>
|
|
|
+ </el-form-item>
|
|
|
+ <div class="inline-wrapper">
|
|
|
+ <el-form-item prop="maxCount" label="限购">
|
|
|
+ <el-input-number v-model="formData.maxCount" :min="0" :step="1" disabled></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" disabled></el-input>
|
|
|
+ <div class="tip">相同识别码的藏品共享限购数量</div>
|
|
|
+ </el-form-item>
|
|
|
+ </div>
|
|
|
+ <el-form-item class="form-submit">
|
|
|
+ <el-button @click="$router.go(-1)" :disabled="saving">取消</el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </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"
|
|
|
+ disabled
|
|
|
+ ></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"
|
|
|
+ disabled
|
|
|
+ ></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';
|
|
|
+export default {
|
|
|
+ name: 'CompanyCollectionEdit',
|
|
|
+ components: { ModelUpload },
|
|
|
+ created() {
|
|
|
+ Promise.all([
|
|
|
+ new Promise((resolve, reject) => {
|
|
|
+ if (this.$route.query.id) {
|
|
|
+ return this.$http
|
|
|
+ .get('companyCollection/get/' + 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;
|
|
|
+ resolve();
|
|
|
+ })
|
|
|
+ .catch(e => {
|
|
|
+ console.log(e);
|
|
|
+ this.$message.error(e.error);
|
|
|
+ resolve();
|
|
|
+ });
|
|
|
+ }
|
|
|
+ return resolve();
|
|
|
+ }),
|
|
|
+ this.$http
|
|
|
+ .post('/privilegeOption/all', { size: 10000, query: { del: false } }, { body: 'json' })
|
|
|
+ .then(res => {
|
|
|
+ this.privilegeOptions = res.content;
|
|
|
+ return Promise.resolve();
|
|
|
+ })
|
|
|
+ ]).then(() => {
|
|
|
+ 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);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ });
|
|
|
+ },
|
|
|
+ data() {
|
|
|
+ return {
|
|
|
+ saving: false,
|
|
|
+ formData: {
|
|
|
+ pic: [],
|
|
|
+ privileges: [],
|
|
|
+ properties: []
|
|
|
+ },
|
|
|
+ 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'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ detail: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请输入详情',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ type: [
|
|
|
+ {
|
|
|
+ required: true,
|
|
|
+ message: '请输入类型',
|
|
|
+ trigger: 'blur'
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ total: [
|
|
|
+ {
|
|
|
+ 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: '请填写分类' }]
|
|
|
+ },
|
|
|
+ statusOptions: [
|
|
|
+ { label: '审核中', value: 'PENDING' },
|
|
|
+ { label: '通过', value: 'SUCCESS' },
|
|
|
+ { label: '失败', value: 'FAIL' }
|
|
|
+ ],
|
|
|
+ customUrl: resolveUrl(this.$baseUrl, 'upload/3dModel'),
|
|
|
+ cateogories: ['勋章', '收藏品', '数字艺术', '门票', '游戏', '音乐', '使用', '其他'],
|
|
|
+ scale: 1,
|
|
|
+ yOffset: 0,
|
|
|
+ privilegeOptions: [],
|
|
|
+ privilegeForm: {},
|
|
|
+ privelegeRules: {
|
|
|
+ detail: [{ required: true, message: '请填写内容' }],
|
|
|
+ remark: [{ required: true, message: '请填写说明' }]
|
|
|
+ },
|
|
|
+ showPrivilegeEditDialog: false
|
|
|
+ };
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ onSave() {
|
|
|
+ this.$refs.form.validate(valid => {
|
|
|
+ if (valid) {
|
|
|
+ this.submit();
|
|
|
+ } else {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ },
|
|
|
+ submit() {
|
|
|
+ let data = { ...this.formData };
|
|
|
+ data.status = 'PENDING';
|
|
|
+
|
|
|
+ this.saving = true;
|
|
|
+ this.$http
|
|
|
+ .post('/companyCollection/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(`/companyCollection/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 || '删除失败');
|
|
|
+ }
|
|
|
+ });
|
|
|
+ },
|
|
|
+ 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);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+};
|
|
|
+</script>
|
|
|
+<style lang="less" scoped>
|
|
|
+.inline-wrapper {
|
|
|
+ .el-form-item {
|
|
|
+ display: inline-block;
|
|
|
+ }
|
|
|
+}
|
|
|
+.tip {
|
|
|
+ font-size: 12px;
|
|
|
+ color: @text3;
|
|
|
+ margin-top: 5px;
|
|
|
+}
|
|
|
+/deep/.el-input.is-disabled .el-input__inner {
|
|
|
+ color: #7c7e7e;
|
|
|
+}
|
|
|
+/deep/.el-textarea.is-disabled .el-textarea__inner {
|
|
|
+ color: #7c7e7e;
|
|
|
+}
|
|
|
+</style>
|