bonus-ui/src/views/superstore/shopMaterial/components/MaterialDialog.vue

466 lines
16 KiB
Vue
Raw Normal View History

2025-03-19 18:36:55 +08:00
<template>
<el-dialog
:title="title + ' - 商品'"
:visible.sync="visible"
width="800px"
append-to-body
:close-on-click-modal="false"
:destroy-on-close="true"
@close="handleClose"
>
<div style="width: 100%;height: 500px;overflow-y: auto;">
<el-form ref="form" :model="form" :rules="rules" label-width="120px">
<el-row>
<el-col :span="12">
<el-form-item label="商品名称" prop="productName">
2025-03-19 18:36:55 +08:00
<el-input
v-model="form.productName"
2025-03-19 18:36:55 +08:00
placeholder="请输入商品名称"
maxlength="40"
show-word-limit
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="条码" prop="barCode">
<el-input
v-model="form.barCode"
placeholder="请输入条码"
maxlength="20"
show-word-limit
/>
</el-form-item>
</el-col>
</el-row>
2025-03-26 15:47:02 +08:00
<el-row>
2025-03-19 18:36:55 +08:00
<el-col :span="12">
<el-form-item label="零售价" prop="salePrice">
<el-input
v-model="form.salePrice"
placeholder="请输入零售价"
maxlength="20"
2025-03-26 15:47:02 +08:00
@input="handleNumericInput('salePrice', $event)"
@blur="formatNumericValue('salePrice')"
2025-03-19 18:36:55 +08:00
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="计重类型" prop="salesMode" >
<el-select v-model="form.salesMode" placeholder="请选择计量类型" style="width: 100%" @change="getDrpUnitList">
<el-option label="按份" value="1" />
<el-option label="称重" value="2" />
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="所属区域" prop="areaId">
<el-cascader v-model="form.areaId"
:options="treeAreaOptions" :filterable="true" style="width: 100%;" :show-all-levels="false"
:props="{
emitPath: false,// 若设置 false则只返回该节点的值只返回最后选择的id
2025-04-09 09:07:42 +08:00
checkStrictly: false,//来设置父子节点取消选中关联,从而达到选择任意一级选项的目的
value:'id',label:'label'
2025-03-19 18:36:55 +08:00
}" clearable @change="handleAreaChange">
</el-cascader>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="商品单位" prop="unitId">
<el-select v-model="form.unitId" placeholder="请选择商品单位" style="width: 100%">
<el-option v-for="item in this.unitOptions"
:key="item.unitId"
:label="item.unitName"
:value="item.unitId"
></el-option>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="商品类别" prop="materialId">
<el-cascader v-model="form.materialId"
2025-03-19 18:36:55 +08:00
:options="treeTypeOptions" :filterable="true" style="width: 100%;" :show-all-levels="false"
:props="{
emitPath: false,// 若设置 false则只返回该节点的值只返回最后选择的id
checkStrictly: false,//来设置父子节点取消选中关联,从而达到选择任意一级选项的目的
2025-03-19 18:36:55 +08:00
value:'id',label:'categoryName'
}" clearable >
</el-cascader>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="商品进价" prop="prefPrice">
2025-03-19 18:36:55 +08:00
<el-input
v-model="form.prefPrice"
2025-03-19 18:36:55 +08:00
placeholder="请输入商品进价"
@input="handleNumericInput('prefPrice', $event)"
@blur="formatNumericValue('prefPrice')"
2025-03-19 18:36:55 +08:00
>
<template slot="append"></template>
</el-input>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="保质期" prop="qualityNum">
<el-select v-model="form.qualityType" style="width: 80px; margin-left: 10px">
2025-03-19 18:36:55 +08:00
<el-option label="按年" value="1" />
<el-option label="按月" value="2" />
<el-option label="按日" value="3" />
</el-select>
<el-input v-model="form.qualityNum" placeholder="请输入" style="width: 120px;margin-right: 10px;" @input="(v)=>(form.qualityNum=v.replace(/[^\d]/g,''))"/>
<span v-if="form.qualityType==1"></span>
<span v-if="form.qualityType==2"></span>
<span v-if="form.qualityType==3"></span>
2025-03-19 18:36:55 +08:00
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应资格证书" prop="supplyCertificate">
<el-select v-model="form.supplyCertificate" placeholder="请选择供应资格证书" style="width: 100%">
2025-03-19 18:36:55 +08:00
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="商品简介" prop="productRemark">
2025-03-19 18:36:55 +08:00
<el-input
type="textarea"
:rows="3"
placeholder="请输入商品简介"
v-model="form.productRemark">
2025-03-19 18:36:55 +08:00
</el-input>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="图片" prop="imgUrl">
2025-03-19 18:36:55 +08:00
<el-upload
:http-request="(obj) => imgUpLoad(obj, 'fileUrl')"
action="#"
:limit="1"
:file-list="fileList"
:show-file-list="true"
list-type="picture-card"
accept=".png, .jpg, .jpeg"
:on-success="handleAvatarSuccess"
:class="{ disabled: uploadDisabled }"
:on-remove="handleRemove"
>
<i
class="el-icon-plus avatar-uploader-icon"
></i>
</el-upload>
</el-form-item>
</el-col>
</el-row>
</el-form>
</div>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</template>
<script>
2025-04-09 09:07:42 +08:00
import { systemAreaTreeApi } from "@/api/base/area";
import { systemMaterialTreeApi,getDrpUnitListApi } from "@/api/superStore/shopMaterial";
2025-03-19 18:36:55 +08:00
import { imgUpLoadTwo } from '@/api/system/upload'
export default {
name: "MaterialDialog",
props: {
title: {
type: String,
default: '新增'
},
visible: {
type: Boolean,
default: false
}
},
data() {
return {
treeAreaOptions:[],//区域树
treeTypeOptions:[],//类型树
unitOptions:[],//单位下拉
form: {
productName: '',//商品名称
2025-03-19 18:36:55 +08:00
areaId: null,//所属区域
materialId: null,//商品类别
2025-03-19 18:36:55 +08:00
materialType: 2,
salesMode: '1',//计量类型
2025-03-26 15:47:02 +08:00
salePrice: '',//零售价(元)
2025-03-19 18:36:55 +08:00
unitId: '',//商品单位
prefPrice: '',//商品进价(元)
2025-03-19 18:36:55 +08:00
barCode: '',//条码
nutritionId:null,//营养信息
qualityType:"1",//保质期类型
qualityNum:"",//保质期
2025-03-19 18:36:55 +08:00
purPriceCeiling:'',//采购上限价格
size:'',//商品规格
taxRate:'',//商品税率
supplyCertificate: '',
productRemark:"",//简介
imgUrl:"",//图片
2025-03-19 18:36:55 +08:00
},
rules: {
productName: [{ required: true, message: '请输入商品名称', trigger: 'blur' }],
2025-03-19 18:36:55 +08:00
areaId: [{ required: true, message: '请选择所属区域', trigger: 'change' }],
salePrice: [{ required: true, message: '请输入零售价', trigger: 'change' }],
materialId: [{ required: true, message: '请选择商品类别', trigger: 'change' }],
2025-03-19 18:36:55 +08:00
salesMode: [{ required: true, message: '请选择计量类型', trigger: 'change' }],
unitId: [{ required: true, message: '请选择商品单位', trigger: 'change' }],
},
fileList: [],//档口图片
checkUrlList: [],//档口图片
checkUrlNameList: [],//档口图片
dialogVisible:false,//图片弹窗
dialogImageUrl:"",//图片弹窗
};
},
computed: {
//图片上传1张后隐藏上传框
uploadDisabled() {
return this.checkUrlList.length > 0
},
},
mounted() {
2025-03-19 18:36:55 +08:00
this.getAreaTreeData();//获取区域树
this.getTypeTreeData();//获取商品类别树
this.getDrpUnitList();//获取单位类型下拉
},
methods: {
//区域树
getAreaTreeData() {
systemAreaTreeApi({}).then((response) => {
2025-04-09 09:07:42 +08:00
this.treeAreaOptions = response.data;
this.getTypeTreeData()
2025-03-19 18:36:55 +08:00
});
},
//基础设置-选择区域
handleAreaChange(val){
console.log(this.form)
this.form.materialId=null
2025-03-19 18:36:55 +08:00
this.getTypeTreeData()
this.getDrpUnitList()
},
//类型树
getTypeTreeData() {
let param = {
categoryType:2,
// ifAdd: 1,
// areaId:this.form.areaId
2025-03-19 18:36:55 +08:00
}
systemMaterialTreeApi(param).then((response) => {
this.treeTypeOptions = response.data;
});
},
//单位类型拉下选
getDrpUnitList() {
let param = {
weighType:this.form.salesMode,
// areaId: this.form.areaId||""
// ifListUse: 1,
// current: 1,
// size: -1
2025-03-19 18:36:55 +08:00
}
this.form.unitId=null
getDrpUnitListApi(param).then((response) => {
this.unitOptions = response.data;
// if(response.data.records.length>0){
// response.data.records.forEach(item => {
// if(item.weighType==this.form.salesMode){
// this.unitOptions.push(item)
// }
// });
// }
2025-03-19 18:36:55 +08:00
});
},
setFormData(row){
console.log(row)
// this.form = Object.assign({}, row)
this.$set(this.form,"areaId",row.areaId)
this.getTypeTreeData()
this.getDrpUnitList()
this.$set(this.form,"areaName",row.areaName)
this.$set(this.form,"materialId",row.materialId)
2025-03-19 18:36:55 +08:00
this.$set(this.form,"categoryName",row.categoryName)
this.$set(this.form,"materialCode",row.materialCode)
this.$set(this.form,"materialId",row.materialId)
this.$set(this.form,"productName",row.productName)
2025-03-19 18:36:55 +08:00
this.$set(this.form,"materialType",row.materialType)
this.$set(this.form,"salesMode",row.salesMode+'')
2025-03-26 15:47:02 +08:00
this.$set(this.form,"unitId",row.unitId)
this.$set(this.form,"salePrice",Number((row.salePrice/100).toFixed(2)))
this.$set(this.form,"prefPrice",Number((row.prefPrice/100).toFixed(2)))
2025-03-19 18:36:55 +08:00
this.$set(this.form,"barCode",row.barCode)
if(row.qualityType){
this.$set(this.form,"qualityType",row.qualityType+"")
2025-03-19 18:36:55 +08:00
}else{
this.$set(this.form,"qualityType","1")
2025-03-19 18:36:55 +08:00
}
this.$set(this.form,"qualityNum",row.qualityNum)
this.$set(this.form,"supplyCertificate","")
this.$set(this.form,"productRemark",row.productRemark)
this.$set(this.form,"imgUrl",row.imgUrl)
2025-03-19 18:36:55 +08:00
//图片反显
if(row.imgUrl){
this.fileList=[{url:row.imgUrl}]
this.checkUrlList=[row.imgUrl]
2025-03-26 15:47:02 +08:00
}else{
this.fileList=[]
this.checkUrlList=[]
2025-03-19 18:36:55 +08:00
}
},
submitForm() {
this.$refs.form.validate(valid => {
if (valid) {
2025-03-26 15:47:02 +08:00
this.form.salePrice = Number(this.form.salePrice)*100;
this.form.prefPrice = Number(this.form.prefPrice)*100;
2025-03-19 18:36:55 +08:00
this.$emit('submit', this.form);
}
});
},
handleClose() {
this.$emit('update:visible', false);
this.$nextTick(() => {
this.reset();
});
},
cancel() {
this.$emit('update:visible', false);
this.$nextTick(() => {
this.reset();
});
},
reset() {
this.form = {
productName: '',//商品名称
2025-03-19 18:36:55 +08:00
areaId: null,//所属区域
materialId: null,//商品类别
2025-03-19 18:36:55 +08:00
materialType: 2,
salesMode: '1',//计量类型
2025-03-19 18:36:55 +08:00
unitId: '',//商品单位
2025-03-26 15:47:02 +08:00
salePrice: '',//商品售价(元)
prefPrice: '',//商品进价(元)
2025-03-19 18:36:55 +08:00
barCode: '',//条码
str:[],//营养信息类型
nutritionId:null,//营养信息
qualityType:"1",//保质期类型
qualityNum:"",//保质期
supplyCertificate: '',
productRemark:"",//简介
imgUrl:""
2025-03-19 18:36:55 +08:00
};
},
// 图片上传
imgUpLoad(param, name, index) {
// console.log(param,'image')
param.type = 'stall'
imgUpLoadTwo(param).then((res) => {
if (res.code == 200) {
2025-03-26 15:47:02 +08:00
this.checkUrlList.push(res.data.url)
this.checkUrlNameList.push(res.data.name)
this.$set(this.form,"imgUrl",res.data.url)
2025-03-19 18:36:55 +08:00
} else {
this.$modal.msgError(res.msg)
this.$set(this.form,"imgUrl","")
2025-03-19 18:36:55 +08:00
}
})
.catch((error) => {
this.$modal.msgError(error)
})
},
handleAvatarSuccess(res, file) {
console.log('success')
},
handleExceed(files, fileList) {
this.$message.warning('最多只可以上传一张图片')
},
handleRemove(file, fileList) {
let sum = 0
this.checkUrlNameList.forEach((item, index) => {
if (item == file.name) {
sum = index
}
})
this.checkUrlNameList.splice(sum, 1)
this.checkUrlList.splice(sum, 1)
},
//数字输入
handleNumericInput(field, event) {
2025-03-25 15:53:44 +08:00
const value = event;
2025-03-19 18:36:55 +08:00
// 只允许输入数字和小数点
let newValue = value.replace(/[^\d.]/g, '');
// 确保只有一个小数点
const parts = newValue.split('.');
if (parts.length > 2) {
newValue = parts[0] + '.' + parts.slice(1).join('');
}
// 限制小数点后最多两位
if (parts.length === 2 && parts[1].length > 2) {
newValue = parts[0] + '.' + parts[1].substring(0, 2);
}
// 设置字段值
if (field.includes('.')) {
const [obj, prop] = field.split('.');
2025-03-26 15:47:02 +08:00
this.form[obj][prop] = newValue;
2025-03-19 18:36:55 +08:00
} else {
2025-03-26 15:47:02 +08:00
this.form[field] = newValue;
2025-03-19 18:36:55 +08:00
}
},
formatNumericValue(field) {
let value;
if (field.includes('.')) {
const [obj, prop] = field.split('.');
value = this.form[obj][prop];
} else {
value = this.form[field];
}
if (!value || value === '' || value === '.') {
value = '0.00';
} else {
value = parseFloat(value).toFixed(2);
}
if (field.includes('.')) {
const [obj, prop] = field.split('.');
2025-03-26 15:47:02 +08:00
this.form[obj][prop] = value;
2025-03-19 18:36:55 +08:00
} else {
2025-03-26 15:47:02 +08:00
this.form[field] = value;
2025-03-19 18:36:55 +08:00
}
},
}
};
</script>
<style lang="scss" scoped>
//隐藏图片上传框的css
::v-deep.disabled {
.el-upload--picture-card {
display: none;
}
}
</style>