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.
 
 
 
 

366 lines
15 KiB

<template>
<view class="container">
<form @submit="editorFormSubmit" :data-formcontent="formdata.content" :data-formid="cateid" >
<view class="content">
<view class="form-item flex">
<view class="title"> 工单类型:</view>
<view class="inputbox flex">
<picker class="picker" mode="selector" @change="BindPickerChange" :range="cate" :value="index" range-key="name">
<view class="uni-input">{{catename}}</view>
</picker>
<text class="iconfont iconjiantou" style="color:#ccc;font-weight:normal"></text>
</view>
</view>
<view class="form-item" v-for="(item,idx) in formdata.content" :key="item.id">
<view class="label">{{item.val1}}<text v-if="item.val3==1" style="color:red"> *</text></view>
<block v-if="item.key=='input'">
<input type="text" :name="'form'+idx" class="input" :placeholder="item.val2" :data-formidx="'form'+idx" placeholder-style="font-size:28rpx"/>
</block>
<block v-if="item.key=='textarea'">
<textarea :name="'form'+idx" class='textarea' :placeholder="item.val2" :data-formidx="'form'+idx" placeholder-style="font-size:28rpx"/>
</block>
<block v-if="item.key=='radio'">
<radio-group class="radio-group" :name="'form'+idx" :data-formidx="'form'+idx">
<label v-for="(item1,idx1) in item.val2" :key="item1.id" class="flex-y-center">
<radio class="radio" :value="item1"/>{{item1}}
</label>
</radio-group>
</block>
<block v-if="item.key=='checkbox'">
<checkbox-group :name="'form'+idx" class="checkbox-group" :data-formidx="'form'+idx">
<label v-for="(item1,idx1) in item.val2" :key="item1.id" class="flex-y-center">
<checkbox class="checkbox" :value="item1"/>{{item1}}
</label>
</checkbox-group>
</block>
<block v-if="item.key=='selector'">
<picker class="picker" mode="selector" :name="'form'+idx" :range="item.val2" @change="editorBindPickerChange" :data-idx="idx" :data-formidx="'form'+idx">
<view v-if="editorFormdata[idx] || editorFormdata[idx]===0"> {{item.val2[editorFormdata[idx]]}}</view>
<view v-else>请选择</view>
</picker>
<text class="iconfont iconjiantou" style="color:#999;font-weight:normal"></text>
</block>
<block v-if="item.key=='time'">
<picker class="picker" mode="time" :name="'form'+idx" value="" :start="item.val2[0]" :end="item.val2[1]" :range="item.val2" @change="editorBindPickerChange" :data-bid="formdata" :data-idx="idx" :data-formidx="'form'+idx" >
<view v-if="editorFormdata[idx]">{{editorFormdata[idx]}}</view>
<view v-else>请选择</view>
</picker>
<text class="iconfont iconjiantou" style="color:#999;font-weight:normal"></text>
</block>
<block v-if="item.key=='date'">
<picker class="picker" mode="date" :name="'form'+idx" value="" :start="item.val2[0]" :end="item.val2[1]" :range="item.val2" @change="editorBindPickerChange" :data-bid="formdata" :data-idx="idx" :data-formidx="'form'+idx">
<view v-if="editorFormdata[idx]">{{editorFormdata[idx]}}</view>
<view v-else>请选择</view>
</picker>
<text class="iconfont iconjiantou" style="color:#999;font-weight:normal"></text>
</block>
<block v-if="item.key=='region'">
<uni-data-picker :localdata="items" popup-title="请选择省市区" :placeholder="formdata['form'+idx] || '请选择省市区'" @change="onchange" :data-formidx="'form'+idx"></uni-data-picker>
<!-- <picker class="picker" mode="region" :name="'form'+idx" value="" @change="editorBindPickerChange" :data-idx="idx">
<view v-if="editorFormdata[idx]">{{editorFormdata[idx]}}</view>
<view v-else>请选择省市区</view>
</picker> -->
<input type="text" style="display:none" :name="'form'+idx" :value="regiondata ? regiondata : formdata['form'+idx]"/>
</block>
<block v-if="item.key=='upload'">
<input type="text" style="display:none" :name="'form'+idx" :value="editorFormdata['content_pics'+idx]"/>
<view class="flex" style="flex-wrap:wrap;padding-top:20rpx">
<view class="form-imgbox" v-if="editorFormdata['content_pic'+idx]" v-for="(item, index) in editorFormdata['content_pic'+idx]" :key="index">
<view class="form-imgbox-close" @tap="removeimg" :data-pindex="index" :data-field="'content_pic'+idx" :data-idx="idx"><image :src="event_rul + '/static/img/static/img/ico-del.png'"></image></view>
<view class="form-imgbox-img"><image :src="item" @click="previewImage" :data-url="item" mode="widthFix" /></view>
</view>
<view class="form-uploadbtn" :style="{background:'url('+pre_url+'/static/img/shaitu_icon.png) no-repeat 50rpx',backgroundSize:'80rpx 80rpx',backgroundColor:'#F3F3F3'}" @click="editorChooseImage" :data-field="'content_pic'+idx" :data-idx="idx" :data-formidx="'form'+idx"></view>
</view>
</block>
</view>
<view class="dp-form-item" v-if="formdata.payset==1">
<text class="label">支付金额:</text>
<input type="text" class="input" name="price" :value='formdata.price' v-if="formdata.priceedit==1" @input="setfield" data-formidx="price"/>
<text v-if="formdata.priceedit==0">{{formdata.price}}</text>
<text style="padding-left:10rpx">元</text>
</view>
</view>
<view style="height: 100rpx;"></view>
<view class="btnbox"> <button class="dp-form-btn" form-type="submit" :data-formcontent="formdata.content" :data-formid="cateid" :style="{background:t('color1')}" >提交</button> </view>
</form>
<!--悬浮按钮-->
<view class="myworkorder" @tap="goto" data-url="record">我的工单</view>
<nodata v-if="nodata"></nodata>
<nomore v-if="nomore"></nomore>
<loading v-if="loading"></loading>
<dp-tabbar :opt="opt"></dp-tabbar>
<popmsg ref="popmsg"></popmsg>
</view>
</template>
<script>
var app = getApp();
export default {
data() {
return {
opt:{},
loading:false,
isload: false,
cate:[],
nomore: false,
nodata:false,
index:0,
catename:'请选择',
pre_url:app.globalData.pre_url,
editorFormdata:[],
formdata:{},
formvaldata:{},
regiondata:'',
cateid:'',
event_rul: app.globalData.event_url,
};
},
onLoad: function (opt) {
this.opt = app.getopts(opt);
this.st = this.opt.st || 'all';
this.type = this.opt.type || '';
this.orderid = this.opt.id || '';
this.cateid = this.opt.cateid || '';
this.getdata();
},
methods: {
changetab: function (st) {
this.st = st;
uni.pageScrollTo({
scrollTop: 0,
duration: 0
});
this.getdata();
},
onchange(e) {
const value = e.detail.value
console.log(value[0].text + ',' + value[1].text + ',' + value[2].text)
this.regiondata = value[0].text + ',' + value[1].text + ',' + value[2].text;
},
getdata: function () {
var that = this;
app.get('ApiIndex/getCustom',{}, function (customs) {
var url = app.globalData.pre_url+'/static/area.json';
uni.request({
url: app.globalData.pre_url+'/static/area.json',
data: {},
method: 'GET',
header: { 'content-type': 'application/json' },
success: function(res2) {
that.items = res2.data
}
});
});
app.post('ApiWorkorder/getcategory', { type:that.type ,cateid:that.cateid}, function (res) {
that.isload = true;
var cate = res.data;
that.cate = cate;
//console.log(that.cateid)
if(that.cateid){
that.BindPickerChanges();
}
})
},
BindPickerChange:function(e){
var that = this;
var index = e.detail.value;
that.index = index
console.log(index);
that.catename = that.cate[index].name
var cateid = that.cate[index].id
that.cateid = cateid
/*app.post('ApiWorkorder/getform', {id:cateid }, function (res) {
that.isload = true;
that.loading=false
if(res && res.status == 1 && res.data){
var formcontent = res.data;
that.formdata = formcontent
console.log(formdata);
}
})*/
that.formdata = that.cate[index]
},
BindPickerChanges:function(){
var that = this;
var index = that.index;
that.catename = that.cate[index].name
var cateid = that.cate[index].id
that.cateid = cateid
that.formdata = that.cate[index]
},
editorChooseImage: function (e) {
var that = this;
var idx = e.currentTarget.dataset.idx;
var field = e.currentTarget.dataset.field;
var pics = that.editorFormdata[field]
//console.log(field);
if(!pics) pics = [];
app.chooseImage(function(urls){
for(var i=0;i<urls.length;i++){
pics.push(urls[i]);
}
that.editorFormdata[field] = pics;
that.editorFormdata['content_pics'+idx] = that.editorFormdata[field].join(',');
that.formvaldata[field] = pics;
//that.editorFormdata = editorFormdata
that.getdata();
},5)
},
removeimg:function(e){
var that = this;
var idx = e.currentTarget.dataset.idx;
var pindex= e.currentTarget.dataset.pindex
var field= e.currentTarget.dataset.field
var pics = that.editorFormdata[field]
that.editorFormdata[field].splice(pindex,1)
that.editorFormdata['content_pics'+idx] = that.editorFormdata[field].join(',');
//console.log(that.editorFormdata[field]);
that.getdata();
},
editorBindPickerChange:function(e){
var that=this
var idx = e.currentTarget.dataset.idx;
var val = e.detail.value;
var editorFormdata = that.editorFormdata;
if(!editorFormdata) editorFormdata = [];
editorFormdata[idx] = val;
this.editorFormdata = editorFormdata
//console.log(this.editorFormdata);
this.test = Math.random();
var field = e.currentTarget.dataset.formidx;
this.formvaldata[field] = val;
that.getdata();
},
editorFormSubmit:function(e){
var that = this;
if(this.submitDisabled) return ;
//console.log('form发生了submit事件携带数据为', e.detail.value)
//var subdata = e.detail.value;
var formcontent = e.currentTarget.dataset.formcontent;
var formid = e.currentTarget.dataset.formid;
var formdataval = e.detail.value;
//console.log(formdataval);
var newformdata = {};
for (var i = 0; i < formcontent.length;i++){
//console.log(subdata['form' + i]);
if (formcontent[i].key == 'region') {
formdataval['form' + i] = that.regiondata;
}
if (formcontent[i].val3 == 1 && (formdataval['form' + i] === '' || formdataval['form' + i] === null || formdataval['form' + i] === undefined || formdataval['form' + i].length==0)){
app.alert(formcontent[i].val1+' 必填');return;
}
if (formcontent[i].key =='switch'){
if (subdata['form' + i]==false){
subdata['form' + i] = ''
}else{
subdata['form' + i] = ''
}
}
if (formcontent[i].key == 'input' && formcontent[i].val4 && formdataval['form' + i]!==''){
if(formcontent[i].val4 == '2'){ //手机号
if (!/^1[3456789]\d{9}$/.test(formdataval['form' + i])) {
app.alert(formcontent[i].val1+' 格式错误');return;
}
}
if(formcontent[i].val4 == '3'){ //身份证号
if (!/(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(formdataval['form' + i])) {
app.alert(formcontent[i].val1+' 格式错误');return;
}
}
if(formcontent[i].val4 == '4'){ //邮箱
if (!/^(.+)@(.+)$/.test(formdataval['form' + i])) {
app.alert(formcontent[i].val1+' 格式错误');return;
}
}
}
newformdata['form'+i] = formdataval['form' + i];
}
that.submitDisabled = true;
app.showLoading('提交中');
var pages = getCurrentPages(); //获取加载的页面
var currentPage = pages[pages.length - 1]; //获取当前页面的对象
var thispath = '/' + (currentPage.route ? currentPage.route : currentPage.__route__); //当前页面url
var opts = currentPage.$vm.opt;
app.post('ApiWorkorder/formsubmit', {formid:formid,formdata:newformdata,price:that.cate[that.index].price,type:that.type,orderid:that.orderid},function(data){
app.showLoading(false);
if (data.status == 0) {
setTimeout(function () {
app.error(data.msg);
}, 100)
that.submitDisabled = false;
return;
}else if(data.status == 1) { //无需付款
that.subscribeMessage(function () {
setTimeout(function () {
app.success(data.msg);
}, 100)
setTimeout(function () {
app.goto('record');
}, 1000)
});
return;
}else if(data.status==2){
that.subscribeMessage(function () {
setTimeout(function () {
app.goto('/pages/pay/pay?id='+data.payorderid+'&tourl=record');
}, 100);
});
}
that.submitDisabled = false;
});
},
}
}
</script>
<style>
.content{ width:90%;margin-top:40rpx; background: #fff; margin: 40rpx; border-radius:10rpx; padding: 20rpx;}
.dp-form-btn{color:#fff;width:90%;height:66rpx;display:flex;align-items:center;justify-content:center;border-radius:50rpx}
.btnbox{ background: #fff; position: fixed; bottom: 0; width: 100%; padding: 20rpx 0;}
.form-item .inputbox{ align-items: center; color: #ccc}
.content .item .uni-input{ color: #ccc}
.form-item {width: 100%;padding: 16rpx 0;background: #fff;display: flex;align-items: center;justify-content:space-between;border-bottom: 1px #ededed solid;}
.form-item .label {color: #333;width: 150rpx;flex-shrink:0}
.form-item .radio{transform:scale(.7);}
.form-item .checkbox{transform:scale(.7);}
.form-item .input {height: 70rpx;padding-left: 10rpx;text-align: right;flex:1;border:1px solid #eee;padding:0 8rpx;border-radius:2px;}
.form-item .textarea{height:140rpx;line-height:40rpx;overflow: hidden;flex:1;border:1px solid #eee;border-radius:2px;padding:8rpx}
.form-item .radio-group{display:flex;flex-wrap:wrap;justify-content:flex-end}
.form-item .radio{height: 70rpx;line-height: 70rpx;display:flex;align-items:center}
.form-item .radio2{display:flex;align-items:center;}
.form-item .radio .myradio{margin-right:10rpx;display:inline-block;border:1px solid #aaa;background:#fff;height:32rpx;width:32rpx;border-radius:50%}
.form-item .checkbox-group{display:flex;flex-wrap:wrap;justify-content:flex-end}
.form-item .checkbox{height: 70rpx;line-height: 70rpx;display:flex;align-items:center}
.form-item .checkbox2{display:flex;align-items:center;height: 40rpx;line-height: 40rpx;}
.form-item .checkbox .mycheckbox{margin-right:10rpx;display:inline-block;border:1px solid #aaa;background:#fff;height:32rpx;width:32rpx;border-radius:2px}
.form-item .picker{height: 70rpx;line-height:70rpx;flex:1;text-align:right}
.form-imgbox{margin-right:16rpx;margin-bottom:10rpx;font-size:24rpx;position: relative;}
.form-imgbox-close{position: absolute;display: block;width:32rpx;height:32rpx;right:-16rpx;top:-16rpx;color:#999;font-size:32rpx;background:#fff}
.form-imgbox-close image{width:100%;height:100%}
.form-imgbox-img{display: block;width:200rpx;height:200rpx;padding:2px;border: #d3d3d3 1px solid;background-color: #f6f6f6;overflow:hidden}
.form-imgbox-img>image{max-width:100%;}
.form-imgbox-repeat{position: absolute;display: block;width:32rpx;height:32rpx;line-height:28rpx;right: 2px;bottom:2px;color:#999;font-size:30rpx;background:#fff}
.form-uploadbtn{position:relative;height:200rpx;width:200rpx}
.myworkorder{ background: #fff; width: 150rpx; height: 70rpx; position: fixed; right: 0%; bottom: 20%; display: flex; align-items: center; border-top-left-radius: 30rpx; border-bottom-left-radius: 30rpx; justify-content: center;}
</style>