|
@@ -1,30 +1,42 @@
|
|
|
<template>
|
|
|
<!-- 新增编辑产品类别 -->
|
|
|
<div class="addEditCategory">
|
|
|
- <el-dialog :title="title" :visible.sync="dialogVisible" :before-close="handleClose" width="600px" :close-on-click-modal="false">
|
|
|
- <el-form :model="form" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
|
|
|
+ <el-dialog :title="title" :visible.sync="dialogVisible" :before-close="handleClose" width="700px" :close-on-click-modal="false">
|
|
|
+ <el-form :model="form" :rules="rules" ref="ruleForm" label-width="110px" class="demo-ruleForm">
|
|
|
<el-form-item label="类别名称" prop="name" >
|
|
|
<el-input v-model="form.name" placeholder="请输入类别名称"></el-input>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="参考许可费率" prop="rate">
|
|
|
- <el-input v-model="form.rate" placeholder="请输入参考许可费率(介于 0 ~ 1 之间)"></el-input>
|
|
|
+ <el-input v-model="form.licenseRate" placeholder="请输入参考许可费率(介于 0 ~ 1 之间)"></el-input>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="谁可以看" prop="rate">
|
|
|
+ <div v-for="item in $constants.showType" :key="item.value" >
|
|
|
+ <div>
|
|
|
+ <el-radio :checked="item.value == form.showType" :label="item.value" v-model="form.showType" @input="changeShowType(item.value)">{{item.label}}</el-radio>
|
|
|
+ </div>
|
|
|
+ <div v-if="form.showType && item.value == form.showType && [0,1].indexOf(item.value)==-1" class="person" @click="showDialog">
|
|
|
+ <p>选择朋友</p>
|
|
|
+ <p v-html="getNames(form.persons)">
|
|
|
+ </p>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="图片" prop="">
|
|
|
<el-upload ref="upload" action="#" :auto-upload="false" :on-change="handleChange" list-type="picture" :show-file-list="false">
|
|
|
- <span v-if="form.pictures&&form.pictures.length>0" class="avatar">
|
|
|
+ <span v-if="form.systemFileList&&form.systemFileList.length>0" class="avatar">
|
|
|
<span class="deleteImg">
|
|
|
<span>
|
|
|
<i class="el-icon-zoom-in" @click.stop="handlePictureCardPreview"></i>
|
|
|
<i class="el-icon-delete" @click.stop="handleRemove"></i>
|
|
|
</span>
|
|
|
</span>
|
|
|
- <el-image ref="image" style="width:100%;height: 100%;" :src="form.pictures[0].id?$p2 + form.pictures[0].url:form.pictures[0].url" :preview-src-list="form.pictures?form.pictures.map(item=>{return item.id? $p2 + item.url:item.url}):[]"></el-image>
|
|
|
+ <el-image ref="image" style="width:100%;height: 100%;" :src="form.systemFileList[0].id?$p2 + form.systemFileList[0].url:form.systemFileList[0].url" :preview-src-list="form.systemFileList?form.systemFileList.map(item=>{return item.id? $p2 + item.url:item.url}):[]"></el-image>
|
|
|
</span>
|
|
|
<i v-else class="el-icon-plus avatar-uploader-icon"></i>
|
|
|
</el-upload>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="类别备注" prop="">
|
|
|
- <el-input v-model="form.remark" type="textarea" :rows="2" placeholder="请输入类别备注"></el-input>
|
|
|
+ <el-form-item label="描述" prop="">
|
|
|
+ <el-input v-model="form.description" type="textarea" :rows="2" placeholder="请输入描述"></el-input>
|
|
|
</el-form-item>
|
|
|
</el-form>
|
|
|
<div slot="footer" class="dialog-footer">
|
|
@@ -32,11 +44,17 @@
|
|
|
<el-button type="primary" @click="submit" >确定</el-button>
|
|
|
</div>
|
|
|
</el-dialog>
|
|
|
+
|
|
|
+ <choose-person ref="choosePerson" @getPersonIds="getPersonIds"></choose-person>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
+import choosePerson from '@/views/components/dialog/person.vue'
|
|
|
export default {
|
|
|
+ components:{
|
|
|
+ choosePerson
|
|
|
+ },
|
|
|
data() {
|
|
|
return {
|
|
|
// 弹窗的title
|
|
@@ -49,18 +67,29 @@ export default {
|
|
|
rules: {
|
|
|
name: [ { required: true, message: '请输入类别名称', trigger: 'blur' },],
|
|
|
},
|
|
|
+ //待上传的文件
|
|
|
+ file:[]
|
|
|
};
|
|
|
},
|
|
|
mounted() { },
|
|
|
methods: {
|
|
|
// 上传的change
|
|
|
- handleChange(file,fileList){},
|
|
|
+ handleChange(file,fileList){
|
|
|
+ this.$set(this.form,'systemFileList', [{url:file.url}])
|
|
|
+ this.file = [file.raw]
|
|
|
+ },
|
|
|
// 点击已上传的文件
|
|
|
- handlePictureCardPreview(file) { },
|
|
|
+ handlePictureCardPreview(file) {
|
|
|
+ this.$refs.image.showViewer = true
|
|
|
+ },
|
|
|
// 文件列表移除文件
|
|
|
- handleRemove(file) { },
|
|
|
+ handleRemove(file) {
|
|
|
+ this.file = []
|
|
|
+ this.form.systemFileList = []//直接清空适用于单张图片
|
|
|
+ },
|
|
|
// 打开弹窗
|
|
|
open(row) {
|
|
|
+ this.form = JSON.parse(JSON.stringify(row))
|
|
|
if (row.id) {
|
|
|
this.title = '编辑产品类别'
|
|
|
} else {
|
|
@@ -72,7 +101,31 @@ export default {
|
|
|
submit() {
|
|
|
this.$refs.ruleForm.validate(valid => {
|
|
|
if (valid) {
|
|
|
- this.handleClose()
|
|
|
+ var formData = new FormData()
|
|
|
+ formData.append('productCategory',JSON.stringify(this.form))
|
|
|
+ if(this.file.length>0){
|
|
|
+ this.file.forEach(item=>{
|
|
|
+ formData.append("files", item);
|
|
|
+ })
|
|
|
+ }
|
|
|
+ if(this.form.id){
|
|
|
+ this.$api.updateProductCategory(formData).then(response=>{
|
|
|
+ this.$message.success('更新成功')
|
|
|
+ this.$emit('getMessage','更新成功')
|
|
|
+ this.handleClose()
|
|
|
+ }).catch(error=>{
|
|
|
+
|
|
|
+ })
|
|
|
+ }else{
|
|
|
+ this.$api.addProductCategory(formData).then(response=>{
|
|
|
+ this.$message.success('添加成功')
|
|
|
+ this.$emit('getMessage','添加成功')
|
|
|
+ this.handleClose()
|
|
|
+ }).catch(error=>{
|
|
|
+
|
|
|
+ })
|
|
|
+ }
|
|
|
+
|
|
|
} else {
|
|
|
|
|
|
}
|
|
@@ -83,11 +136,71 @@ export default {
|
|
|
this.$refs.ruleForm.resetFields()
|
|
|
this.dialogVisible = false;
|
|
|
},
|
|
|
+ //切换谁可以看类型
|
|
|
+ changeShowType(val){
|
|
|
+ this.form.showType1 = this.form.showType
|
|
|
+ this.$set(this.form,'showType',val)
|
|
|
+ this.$set(this.form,'persons',[])
|
|
|
+ this.$set(this.form,'showPersonId',[])
|
|
|
+ if(this.form.showType == 2 || this.form.showType == 3){
|
|
|
+ this.showDialog()
|
|
|
+ }
|
|
|
+
|
|
|
+ },
|
|
|
+ showDialog(){
|
|
|
+ this.$refs.choosePerson.open(this.form.showPersonId,this.form.persons)
|
|
|
+ },
|
|
|
+ getPersonIds({personIds,persons}){
|
|
|
+ if(personIds.length>0){
|
|
|
+ this.$set(this.form,'persons',persons)
|
|
|
+ this.$set(this.form,'showPersonId',personIds)
|
|
|
+ }else{
|
|
|
+ if(this.form.showType == this.form.showType1){
|
|
|
+ this.$set(this.form,'showType',0)
|
|
|
+ }else{
|
|
|
+ this.$set(this.form,'showType',this.form.showType1)
|
|
|
+ }
|
|
|
+
|
|
|
+ this.$set(this.form,'persons',[])
|
|
|
+ this.$set(this.form,'showPersonId',[])
|
|
|
+ }
|
|
|
+ },
|
|
|
+
|
|
|
+ getNames(row){
|
|
|
+ if(!row){
|
|
|
+ return ''
|
|
|
+ }
|
|
|
+ var arr = row.map(item=>{
|
|
|
+ return item.name
|
|
|
+ })
|
|
|
+ return arr.join('、')
|
|
|
+ }
|
|
|
},
|
|
|
};
|
|
|
</script>
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
+.person{
|
|
|
+ height:50px;
|
|
|
+ padding-left:30px;
|
|
|
+ cursor: pointer;
|
|
|
+ p{
|
|
|
+ margin:0;
|
|
|
+ height: 30px;
|
|
|
+ line-height: 30px;
|
|
|
+ }
|
|
|
+ p:first-child{
|
|
|
+ color: green;
|
|
|
+ }
|
|
|
+ p:last-child{
|
|
|
+ font-size: 12px;
|
|
|
+ overflow: hidden;
|
|
|
+ white-space: nowrap;
|
|
|
+ text-overflow:ellipsis;
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
.avatar-uploader-icon {
|
|
|
background-color: #fbfdff;
|
|
|
border: 1px dashed #c0ccda;
|