| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316 | <template>	<uni-drawer ref="drawer" mode="left" :mask-click="false" width="85%" :maskClick='true'>		<scroll-view class="scroll-view" scroll-y="true">			<uni-section :title="'编辑:' + (type==='in'?'入库记录':'出库记录')" type="line"></uni-section>			<view class="form-wrap" >				<uni-forms ref="form" label-position="top" :rules="rules" :model="form">										<view class="inbound" v-if="type==='in'">						<uni-forms-item label="入库人员" name="accountId" required>							<uni-data-select  v-model="form.accountId" :localdata="userList" placeholder="请选择入库人员" :clear="false"></uni-data-select>						</uni-forms-item>						<uni-forms-item label="入库类型" name="inboundType"  required>							<uni-data-select  v-model="form.inboundType" :localdata="inboundTypeList" placeholder="请选择入库类型" :clear="false"></uni-data-select>						</uni-forms-item>						<uni-forms-item label="物资种类" name="goodsCatId" required>							<uni-data-select v-model="form.goodsCatId" :localdata="goodsCats" placeholder="请选择物资种类" :clear="false"></uni-data-select>						</uni-forms-item>															<uni-forms-item label="物资数量" label-position="left" required>							<uni-easyinput v-model="form.qty" placeholder="请输入物资数量" :clearable="false" />						</uni-forms-item>						<uni-forms-item label="物资编号" >							<uni-easyinput v-model="form.goodsNo" placeholder="请输入物资编号" :clearable="false" />						</uni-forms-item>							<uni-forms-item label="存放位置" name="inboundLocation" required>							<uni-easyinput v-model="form.inboundLocation" placeholder="请输入存放位置" :clearable="false" />						</uni-forms-item>						<uni-forms-item label="物资名称" >							<uni-easyinput v-model="form.goodsTitle"  ></uni-easyinput>						</uni-forms-item>								<uni-forms-item label="生产日期">							<uni-datetime-picker type="date" v-model="form.goodsPdDate" />						</uni-forms-item>						<uni-forms-item label="过期时间">							<uni-datetime-picker type="date" v-model="form.goodsExpDate"/>						</uni-forms-item>						<uni-forms-item label="物资说明">							<uni-easyinput type="textarea" :maxlength="1000" v-model="form.goodsDesc" placeholder="请输入物资说明" autoHeight ></uni-easyinput>							<view class="word-limit">{{form.goodsDesc.length||0}}/1000</view>						</uni-forms-item>					</view>					<view class="outbound" v-if="type==='out'">						<uni-card margin="10px 0">							<uni-list>								<uni-list-item  title="物资种类" >									<template v-slot:footer><uni-tag  :text="form.goodsCatTitle" type="success"></uni-tag></template>								</uni-list-item>								<uni-list-item  title="库存数量" >									<template v-slot:footer><uni-tag  :text="`${form.qty}`" type="primary"></uni-tag></template>								</uni-list-item>							</uni-list>						</uni-card>						<uni-forms-item label="出库人员" name="accountId" required>							<uni-data-select  v-model="form.accountId" :localdata="userList" placeholder="请选择出库人员" :clear="false"></uni-data-select>						</uni-forms-item>						<uni-forms-item label="出库类型" name="outboundType" v-if="type==='out'" required>							<uni-data-select  v-model="form.outboundType" :localdata="outboundTypeList" placeholder="请选择出库类型" :clear="false"></uni-data-select>						</uni-forms-item>						<uni-forms-item label="出库地点" name="outboundLocation" required>							<uni-easyinput v-model="form.outboundLocation" placeholder="请输入存放位置" :clearable="false" />						</uni-forms-item>					</view>					<uni-forms-item label="备注">						<uni-easyinput type="textarea" :maxlength="500"						 v-model="form.remark" autoHeight 						placeholder="请输入备注"></uni-easyinput>						<view class="word-limit">{{form.remark.length||0}}/500</view>					</uni-forms-item>				</uni-forms>				<view class="handle-container">					<button class="save" type="primary" @click="onSubmit">保存</button>					<button class="cancel" type="default" @click="close">取消</button>				</view>			</view>			</scroll-view>	</uni-drawer></template><script>	import goodsApi from '@/api/goods.js'		import { parseTime } from '@/libs'	export default{		name:"RecordEdit",		computed:{			ocId(){				let accountInfo=uni.getStorageSync('accountInfo')				if(!accountInfo)return undefined				return accountInfo.ocId			},			goodsCats(){				let goodsCats=this.cats;				if(!goodsCats)return []				return goodsCats.map(item=>{					return{						value:item.goodsCatId,						text:item.goodsCatTitle					}				})			},			userList(){				let groupUser=uni.getStorageSync('groupUser')				let userList=[]				groupUser.map((item,index)=>{					userList.push({...item,value:`root-${index+1}`,text:item.name,disable:true})					if(Array.isArray(item.children)&&item.children.length>0){						userList=userList.concat(item.children.map(item=>{return{...item,value:item.accountId,text:item.accountName}}))					}							})				return userList			}								},		props:{			cats:{				type:Array,				default:()=>[]			}		},		data(){			return{				type:undefined,				rules:{					accountId:{						rules:[							{								required: true,								errorMessage:this.type==='in'?'入库人员':'出库人员'							}											],						validateTrigger:'submit'					},					intboundType:{						rules:[							{								required: true,								errorMessage:"请选择入库类型"							}											],						validateTrigger:'submit'					},					outboundType:{						rules:[							{								required: true,								errorMessage:"请选择出库类型"							}											],						validateTrigger:'submit'					},									goodsCatId:{						rules:[							{								required: true,								errorMessage: '请选择物资种类',							}						],						validateTrigger:'submit'					},				},				inboundTypeList:[					{ value: 1, text: '正常入库' },					{ value: 2, text: '报溢' },				],				outboundTypeList:[					{ value: 1, text: '正常出库' },					{ value: 2, text: '报损' },					{ value: 3, text: '过期' },						],				form:{					groupId: undefined,					groupName: undefined,					inboundId: 0,					inboundType: 1,					inboundTime: '',					inboundLocation: '',					accountId: "",					accountName:"",					goodsType: "",					goodsCatId: 1,					goodsCatTitle: '',					qty: 1,					goodsNo: '',					goodsTitle: '',					goodsPdDate: '',					goodsExpDate: '',					goodsDesc: '',					remark: '',					//out					outboundId: 0,					outboundType: 1,					outboundTime: '',					outboundLocation: ''				}			}		},		methods:{			resetForm(){				this.form={					groupId: undefined,					groupName: undefined,					inboundId: 0,					inboundType: 1,					inboundTime: '',					inboundLocation: '',					accountId: "",					accountName:"",					goodsType: "",					goodsCatId: 1,					goodsCatTitle: '',					qty: 1,					goodsNo: '',					goodsTitle: '',					goodsPdDate: '',					goodsExpDate: '',					goodsDesc: '',					remark: '',					//out					outboundId: 0,					outboundType: 1,					outboundTime: '',					outboundLocation: ''				}			},			onSubmit(){				this.$refs.form.validate().then(res=>{					let submitFx=this.type==='in'?goodsApi.updateInbound:goodsApi.updateOutbound					let user=this.userList.find(item=>this.form.accountId===item.accountId)					let goodsCat=this.goodsCats.find(item=>this.form.goodsCatId===item.value)					let params={						accountId: user.accountId,						accountName: user.accountName,						positionId: user.positionId,						positionName: user.positionName,						ocId:this.ocId,																		goodsType: this.form.goodsType,						goodsCatId: goodsCat.value,						goodsCatTitle:goodsCat.text,						qty: this.form.qty,						remark: this.form.remark					}					if(this.type==='in'){						params={...params,							goodsNo:this.form.goodsNo,							goodsTitle: this.form.goodsTitle,							goodsPdDate:this.form.goodsPdDate,							goodsExpDate: this.form.goodsExpDate,							goodsDesc: this.form.goodsDesc,							inboundId: this.form.inboundId,							inboundType: this.form.inboundType,							inboundTime: this.form.inboundTime,							inboundLocation: this.form.inboundLocation,						}					}else{						params={...params,							outboundId: this.form.outboundId,							outboundType: this.form.outboundType,							outboundTime: this.form.outboundTime,							outboundLocation: this.form.outboundLocation,						}					}					submitFx(params).then(()=>{						uni.showToast({							icon:"none",							title:"成功!!"						})						this.$emit('success')						this.close();					})				}).catch(err =>{					console.log(err)					uni.showToast({						icon:"none",						title:"请检查填写信息!"					})				})			},			show({type,item}){				this.resetForm()				this.form={...this.form,...item}				this.type=type				this.$refs.drawer.open()			},			close(){				this.$refs.drawer.close()			}		}	}</script><style lang="scss" scoped>	.scroll-view {		height: 100%;		padding: 20rpx;		box-sizing: border-box;		.form-wrap{			padding:40rpx 20rpx;			.handle-container{				display: flex;				justify-content: center;				align-items: center;				button{					width: 160rpx;					padding: 20rpx 16rpx;					line-height: 1;					font-size: 28rpx;					&.save{						background-color: #007aff;					}				}			}			.word-limit{				text-align: right;				padding: 10rpx 0;				color: #999;				font-size: 26rpx;			}		}	}</style>
 |