You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
182 lines
5.7 KiB
182 lines
5.7 KiB
<style lang="scss" scoped>
|
|
.container{
|
|
background:#F6F6F6;
|
|
padding:14px 0;
|
|
min-height:100%;
|
|
}
|
|
</style>
|
|
<template>
|
|
<view class="container">
|
|
<u-form class="card inline" errorType="toast" :model="formData" ref="form" :rules="rules" labelWidth="auto">
|
|
<d-form
|
|
v-for="(v,k) in fields"
|
|
:key="k"
|
|
v-bind="v"
|
|
:required="!!rules[k]"
|
|
:field="k"
|
|
:value="(/^dateRange$|^select$|^map$/.test(v.type)?fields[k].value:formData[k])"
|
|
ref="dForm"
|
|
@input="formData[k]=$event"
|
|
@selectRDate="selectDate"
|
|
@select="fields[k].value=$event.map(v=>v.value);formData[k]=fields[k].value[0]"
|
|
@imgs="fields[k].value=$event"
|
|
@editorMap="editorMap"/>
|
|
</u-form>
|
|
<button class="cu-btn round bg-green shadow submit" @click="sumbit">保存</button>
|
|
</view>
|
|
</template>
|
|
<script>
|
|
import request from '@/common/request'
|
|
export default{
|
|
data(){
|
|
return{
|
|
fields:{
|
|
plantBaseInfoId:{label:"基地名称",type:"select",columns:[[]],value:[],disabled:this.$store.getters['userInfo'].roleCode=="base_admin"},
|
|
plotName:{label:"地块名称"},
|
|
plotNumber:{label:"地块编号"},
|
|
drawArea:{label:"勾画面积(亩)",disabled:true,type:'digit'},
|
|
realityArea:{label:"实际面积",type:'digit'},
|
|
image:{label:"地块图片",type:"upImg",num:3,value:''},
|
|
date:{label:"使用日期",type:"dateRange",value:[]},
|
|
// longitude:{label:"经/纬度",type:"map",value:[]},
|
|
hb:{label:"海拔",type:"digit"},
|
|
manager:{label:"基地管理员",disabled:true},
|
|
phone:{label:"管理员电话",type:"number",disabled:true},
|
|
address:{label:"详细地址",type:"textarea"},
|
|
},
|
|
formData:{
|
|
plantBaseInfoId:"",
|
|
plantBaseName:"",
|
|
plotNumber:"",
|
|
plotName:"",
|
|
drawArea:'',
|
|
realityArea:'',
|
|
image:[],
|
|
beginTime:"",
|
|
endTime:"",
|
|
longitude:"",
|
|
latitude:"",
|
|
address:"",
|
|
},
|
|
rules:{
|
|
plantBaseInfoId:{required:true, message:"基地名称必填!", trigger:"change"},
|
|
// plotNumber:{required:false, message:"地块编号必填!", trigger:"blur"},
|
|
plotName:{required:true, message:"地块名称必填!", trigger:"blur"},
|
|
// drawArea:{required:true, type:'number', message:"!", trigger:"blur"},
|
|
realityArea:{required:true, type:'number', message:"实际面积必填!", trigger:"blur"},
|
|
image:{required:true, type:"array", min:1, validator:(rule,val,call)=>{
|
|
if(this.fields.image.value.length<=0)call(new Error('地块图片必选!'));
|
|
else call()
|
|
}, trigger:"change"},
|
|
// date:{required:true,validator:(rule,val,call)=>{
|
|
// if(!this.fields.date.value[0])call(new Error('请选择开始时间!'));
|
|
// else if(!this.fields.date.value[1])call(new Error('请选择结束时间!'));
|
|
// else call()
|
|
// }, trigger:"change"}
|
|
},
|
|
eventChannel:null,
|
|
}
|
|
},
|
|
async onLoad(options){
|
|
await this.init()
|
|
if(options.id){
|
|
this.getDetail(options.id)
|
|
}else if(this.$store.getters['userInfo'].roleCode=="base_admin"){
|
|
var baseVal=this.fields.plantBaseInfoId.columns[0].find(v=>v.value==this.$store.state.baseInfo.id)
|
|
if(baseVal){
|
|
this.formData.plantBaseInfoId=baseVal.value
|
|
this.fields.plantBaseInfoId.value=[baseVal.value]
|
|
}
|
|
}
|
|
this.eventChannel=this.getOpenerEventChannel()
|
|
},
|
|
methods:{
|
|
async init(){
|
|
var res=await request("/api/plantPlot/getAllPlantBaseInfo",{
|
|
params:{companyId:this.$store.getters.userInfo.companyId}
|
|
})
|
|
if(res.statu){
|
|
this.fields.plantBaseInfoId.columns = [res.data.map(v=>({label:v.baseName,value:v.id}))]
|
|
}else{
|
|
uni.showModal({
|
|
title:"提示",
|
|
content:res.msg||"获取基地名称下拉选项失败!",
|
|
showCancel:false,
|
|
})
|
|
}
|
|
},
|
|
selectDate(e){
|
|
switch(e.type){
|
|
case "start":this.fields.date.value[0]=e.value;break;
|
|
case 'end':this.fields.date.value[1]=e.value;break;
|
|
}
|
|
},
|
|
sumbit(){
|
|
this.$refs.form.validate().then(async valid=>{
|
|
if(valid){
|
|
var res=await request("/api/plantPlot/addOrUpdate",{
|
|
method:"post",
|
|
body:{
|
|
...this.formData,
|
|
image:this.fields.image.value,
|
|
beginTime:this.fields.date.value[0],
|
|
endTime:this.fields.date.value[1],
|
|
}
|
|
})
|
|
if(res.statu){
|
|
this.eventChannel.emit("update")
|
|
uni.navigateBack()
|
|
//新增数据,首页刷新
|
|
if(!this.formData.id){
|
|
this.$provise.emit("updateMassif")
|
|
}
|
|
}else{
|
|
uni.showModal({
|
|
title:"提示",
|
|
content:res.msg||"地块基地信息保存失败!",
|
|
showCancel:false,
|
|
})
|
|
}
|
|
}
|
|
})
|
|
},
|
|
async getDetail(id){
|
|
var res=await request('/api/plantPlot/queryById',{
|
|
params:{id}
|
|
})
|
|
if(res.statu){
|
|
this.formData={...res.data,image:res.data.image||[]}
|
|
this.fields.date.value=[res.data.beginTime, res.data.endTime]
|
|
this.fields.plantBaseInfoId.value=[res.data.plantBaseInfoId]
|
|
this.fields.image.value=res.data.image?.join?.(',')||''
|
|
// this.fields.longitude.value=this.formData.longitude.split(";").map(v=>{
|
|
// var point=v.split(",")
|
|
// if(point.length==2){
|
|
// return {longitude:point[0],latitude:point[1]}
|
|
// }
|
|
// return null
|
|
// }).filter(v=>v)
|
|
}else{
|
|
uni.showModal({
|
|
title:"提示",
|
|
content:res.msg||"获取详情失败!",
|
|
showCancel:false,
|
|
})
|
|
}
|
|
},
|
|
editorMap(e){
|
|
this.fields.longitude.value=e
|
|
this.formData.longitude=e.map(v=>`${v.longitude},${v.latitude}`).join(';')
|
|
},
|
|
},
|
|
onBackPress(e){
|
|
var dForm=this.$refs.dForm.find(v=>v.field=='longitude')
|
|
if(dForm?.showMap){//是否开启地图
|
|
dForm.showMap=false
|
|
return true
|
|
}else{
|
|
return false
|
|
}
|
|
},
|
|
}
|
|
</script>
|
|
|