环卫车小程序前端代码
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.
 
 
 

279 lines
7.7 KiB

<template>
<view class="se-m-20 se-p-20 se-br-10">
<u--form labelPosition="left" :model="form" :rules="rules" ref="uForm" labelWidth="80">
<u-form-item labelWidth="0">
<view class="se-fs-26 se-c-black se-pb-10">
请选择您要寻找的车辆类型
</view>
<view class="se-flex se-flex-ai-c se-flex-ff-rw">
<view v-if="item.name !='环卫设备及配件'" class="se-py-10 se-px-30 se-fs-22 se-br-10 se-mr-15 se-mt-10" :class="item.id==form.cartypeId ? 'se-bgc-green se-c-white se-b-green' : 'se-b se-c-text'" @click="handleCartype(item)" v-for="(item,index) in categoryList" :key="index">
{{item.name}}
</view>
</view>
</u-form-item>
<u-form-item label="类型" prop="categorytwoId" @click="showType=true">
<u--input border="bottom" v-model="form.categorytwoName" disabled placeholder="请填写类型"></u--input>
<u-icon slot="right" name="arrow-right"></u-icon>
</u-form-item>
<u-form-item label="车辆型号" prop="model">
<u--input v-model="form.model" placeholder="请填写车辆型号"></u--input>
</u-form-item>
<template v-if="form.cartypeName!='新车'">
<u-form-item label="年限" prop="date" @click="showDate=true" >
<u--input border="bottom" v-model="form.date" disabled placeholder="请填写年限"></u--input>
<u-icon slot="right" name="arrow-right"></u-icon>
</u-form-item>
</template>
<u-form-item label="公里数" prop="distance">
<u--input v-model="form.distance" placeholder="请填写公里数"></u--input>
</u-form-item>
<u-form-item label="联系人" prop="contacts">
<u--input v-model="form.contacts" placeholder="请填写联系人"></u--input>
</u-form-item>
<u-form-item label="联系电话" prop="phone">
<u--input v-model="form.phone" placeholder="请填写联系电话"></u--input>
</u-form-item>
<u-form-item label="备注" labelPosition="top" prop="remark">
<u--textarea class="se-mt-20" v-model="form.remark" count
placeholder="请填写备注"></u--textarea>
</u-form-item>
<u-form-item>
<view class="se-px-20 se-pt-20">
<view class="se-px-20 se-pb-80 se-fs-20 se-flex">
<view @click="onSubmit"
class="se-mx-10 se-flex-1 se-br-40 se-flex-h-c se-h-80 se-lh-80 se-ta-c se-fs-28 se-c-white se-bgc-green">
<text>确认申请</text>
</view>
</view>
</view>
</u-form-item>
</u--form>
<u-action-sheet
:show="showType"
:actions="categoryTwoList"
title="请选择类型"
@close="showType = false"
@select="categoryTwoSelect"
>
</u-action-sheet>
<u-picker :show="showDate" :columns="columns" @confirm="onConfirm"
@cancel="onCancel"></u-picker>
<!-- <u-datetime-picker
:maxDate="maxDate"
:show="showDate"
v-model="date"
mode="date"
@confirm="onConfirm"
@cancel="onCancel"
></u-datetime-picker> -->
</view>
</template>
<script>
const now = new Date();
const startOfToday = new Date(now.getFullYear(), now.getMonth(), now.getDate()).getTime();
const startOfYesterday = startOfToday - 24 * 60 * 60 * 1000;
import { queryTypeList,addApply,queryCategoryList } from "@/common/api.js"
export default {
components:{
},
data() {
return {
columns:[['2025', '2024', '2023', '2022', '2020', '2019', '2018', '2017', '2016', '2015', '2014', '2013', '2012', '2011', '2010', '2009', '2008', '2007', '2006', '2005', '2004', '2003', '2002', '2001', '2000']],
maxDate:startOfYesterday,
categoryTwoList:[],
categoryList:[],
showDate:false,
showType:false,
actions: [],
date:Number(new Date()),
form: {
cartypeId:"",
cartypeName:"",
categorytwoId:"",//id
categorytwoName:"",
type:"",//类型
model:"",//车辆型号
date:"",//时间
distance:"",//距离
price:"",//价格
contacts:"",//联系人
phone:"",//联系人电话
remark:"",//备注
},
rules: {
categorytwoName:[
{
type: 'string',
required: true,
message: '请填写类型',
trigger: ['blur', 'change']
}
],
model:[
{
type: 'string',
required: true,
message: '请选择车辆型号',
trigger: ['blur', 'change']
}
],
// date:[
// {
// validator: (rule, value, callback) => {
// console.info(this.form.cartypeName)
// return this.form.cartypeName=='新车' ? false : callback(new Error('请填写时间'))
// },
// message: '请填写时间',
// trigger: ['blur', 'change']
// }
// ],
distance:[
{
type: 'string',
required: true,
message: '请填写公里数',
trigger: ['blur', 'change']
}
],
price:[
{
type: 'string',
required: true,
message: '请填写价格',
trigger: ['blur', 'change']
}
],
contacts:[
{
type: 'string',
required: true,
message: '请填写联系人',
trigger: ['blur', 'change']
}
],
phone:[
{
type: 'string',
required: true,
message: '请填写联系电话',
trigger: ['blur', 'change']
}
],
}
}
},
onLoad(options) {
// this.onQueryTypeList()
this.onQueryCategoryList()
},
watch: {
},
methods: {
handleCartype(event){
this.form.cartypeId = event.id
this.form.cartypeName = event.name
this.categoryTwoList =event.carrentCategorytwoList
this.form.categorytwoId = ""
this.form.categorytwoName = ""
if(this.form.cartypeName=='新车'){
this.form.date = ""
}
},
onQueryCategoryList(){
let that = this
queryCategoryList({}).then(response=>{
console.info("queryCategoryList",response)
if(response.result.length>0){
that.categoryList = response.result
that.form.cartypeId = response.result[0].id
that.form.cartypeName = response.result[0].name
that.categoryTwoList = response.result[0].carrentCategorytwoList
}
}).catch(error=>{
})
},
onCancel(){
this.form.date = '';
this.showDate = false
},
onConfirm(e){
this.form.date = e.value[0];
this.showDate = false
// console.info('e',e)
// const date = new Date(e.value);
// const year = date.getFullYear();
// const month = String(date.getMonth() + 1).padStart(2, '0');
// const day = String(date.getDate()).padStart(2, '0');
// this.form.date = `${year}-${month}-${day}`;
// this.showDate = false
},
categoryTwoSelect(event){
this.form.categorytwoId = event.id
this.form.categorytwoName = event.name
},
onQueryTypeList(){
queryTypeList({}).then(response=>{
console.info("queryTypeList",response)
this.actions = response.result
}).catch(error=>{
})
},
onSubmit() {
this.$refs.uForm.validate().then(res => {
this.onAddApply()
// uni.$u.toast('校验通过')
}).catch(errors => {
console.info(errors)
// uni.$u.toast('校验失败')
})
},
onAddApply(){
let that = this
if(that.form.cartypeName!='新车' && !that.form.date){
return uni.$u.toast('请选择时间')
}
let params={
categoryoneId:that.form.cartypeId,
categorytwoId:that.form.categorytwoId,
model:that.form.model,
carTime:Number(that.form.date),
mileage:that.form.distance,
name:that.form.contacts,
phone:that.form.phone,
remark:that.form.remark
}
addApply(params).then(response=>{
uni.$u.toast(response.message)
setTimeout(()=>{
uni.navigateBack({
delta:1
})
},1500)
}).catch(error=>{
})
},
},
onReady() {
this.$refs.uForm.setRules(this.rules)
}
}
</script>
<style>
page {
background-color: #f5f5f5 !important;
}
</style>