1293 lines
		
	
	
		
			32 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			1293 lines
		
	
	
		
			32 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <!-- 新增线下订单-->
 | ||
| <template>
 | ||
| 	<view class="content">
 | ||
| 		<headersVue :titles="title" style="position: static !important;">
 | ||
| 			<u-icon name="arrow-left" color="#fff" size="18"></u-icon>
 | ||
| 		</headersVue>
 | ||
| 		<u-loading-page :loading="isLoading" style="z-index: 3"></u-loading-page>
 | ||
| 
 | ||
| 
 | ||
| 		<view class="mub">
 | ||
| 			<view class="top-ail">
 | ||
| 				<u-upload :fileList="fileList" @afterRead="afterRead1" @delete="deletePic1" multiple :maxCount="1">
 | ||
| 					<view class="dlanniu" style="width: 345px;">
 | ||
| 						<uni-icons type="scan" size="20" color="#ffffff"></uni-icons>
 | ||
| 						<text style="margin-left: 10px;">行驶证扫描</text>
 | ||
| 					</view>
 | ||
| 				</u-upload>
 | ||
| 
 | ||
| 				<view class="box-list" v-if="driverLicenesImg != undefined">
 | ||
| 
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left">行驶证照片</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<u-album :urls="driverLicenesImg"></u-album>
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 				</view>
 | ||
| 
 | ||
| 				<!-- 名称 -->
 | ||
| 
 | ||
| 				<view class="box-list">
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left">接车类型</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<u-radio-group v-model="radiovalue1" iconPlacement="left" name="name" placement="row"
 | ||
| 								@change="groupChange">
 | ||
| 								<u-radio style="margin-right: 10rpx;" :customStyle="{marginBottom: '8px'}"
 | ||
| 									v-for="(item, index) in radiolist1" :key="index" :label="item.name"
 | ||
| 									:name="item.label">
 | ||
| 								</u-radio>
 | ||
| 							</u-radio-group>
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left">客户姓名</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="buyName" placeholder="请输入客户姓名">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left">住址</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="userAddress" placeholder="请输入住址">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left">
 | ||
| 							<text style="color: red;font-weight: bold;text-align: center;">*</text>
 | ||
| 							车牌号
 | ||
| 						</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="carNum" placeholder="请输入车牌号">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left" @click="showzhi = true">使用性质
 | ||
| 							<text class="xixi">点击选择</text>
 | ||
| 						</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="carNature" placeholder="请输入使用性质">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left">品牌型号</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="carModel" placeholder="请输入品牌型号">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left">车辆识别代号</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="carIdNo" placeholder="请输入车辆识别代号">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left" @click="showRegisterDate = true">
 | ||
| 							<text style="color: red;font-weight: bold;text-align: center;">*</text>
 | ||
| 							车辆注册日期
 | ||
| 							<text class="xixi">点击选择</text>
 | ||
| 						</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="carRegisterDateStr" placeholder="请输入车辆注册日期">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left" @click="$refs.picker.show()">
 | ||
| 							渠道/来源
 | ||
| 							<text class="xixi">点击选择</text>
 | ||
| 						</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<uni-data-picker ref="picker" v-model='cssj' :localdata="columns" popup-title="请选择业务渠道和来源"
 | ||
| 								@change="onchange" @nodeclick="onnodeclick"
 | ||
| 								:map="{ text: 'name', value: 'id' }"></uni-data-picker>
 | ||
| 							<!-- <input type="text" v-model="customerSource" placeholder="请输入客户来源"> -->
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left">
 | ||
| 							<text style="color: red;font-weight: bold;text-align: center;">*</text>
 | ||
| 							经办人
 | ||
| 						</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="otherName" placeholder="请输入经办人">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left"><text
 | ||
| 								style="color: red;font-weight: bold;text-align: center;">*</text>经办人手机号</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="otherPhone" placeholder="请输入经办人手机号">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left" @click="handleClick">
 | ||
| 							商品选择
 | ||
| 							<text class="xixi">点击选择</text>
 | ||
| 						</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<text>{{ goodstext }}</text>
 | ||
| 							<!-- 	<input type="text" v-model="goodstext"  placeholder="请选择商品"> -->
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box">
 | ||
| 						<view class="l-left"><text style="color: red;font-weight: bold;text-align: center;">*</text>联系方式
 | ||
| 						</view>
 | ||
| 						<view class="l-right">
 | ||
| 							<input type="text" v-model="buyPhone" placeholder="请输入联系方式">
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box" style="display: block;">
 | ||
| 						<view class="" style="margin-bottom: 20rpx;">备注</view>
 | ||
| 						<view class="">
 | ||
| 							<u--textarea v-model="content" placeholder="请输入备注"></u--textarea>
 | ||
| 						</view>
 | ||
| 					</view>
 | ||
| 					<view class="list-box" style="display: block;">
 | ||
| 						<view class="" style=""><text
 | ||
| 								style="color: red;font-weight: bold;text-align: center;">*</text>接车图片</view>
 | ||
| 
 | ||
| 						<u-upload :fileList="fileList1" @afterRead="afterRead" @delete="deletePic" name="1" multiple
 | ||
| 							:maxCount="10"></u-upload>
 | ||
| 					</view>
 | ||
| 				</view>
 | ||
| 				<view class="dlanniu" @click="getgoodes()">
 | ||
| 					<text>接车</text>
 | ||
| 				</view>
 | ||
| 
 | ||
| 
 | ||
| 				<!-- <u-picker :show="show" :columns="columns" :defaultIndex="kehuDefaultIndex" @confirm="confirms"
 | ||
| 					@cancel="cancels" keyName="label"></u-picker> -->
 | ||
| 				<qianziyu-select :show="show" name="label" @search="getCustomerSource" :dataLists="columns"
 | ||
| 					:showSearch=true @cancel="cancels" :checkboxData="driverLicenseTypeArr" @submit="confirms"
 | ||
| 					@update:checkboxData="driverLicenseTypeArr = $event">
 | ||
| 				</qianziyu-select>
 | ||
| 
 | ||
| 				<u-picker :show="showgoods" ref="uPicker" :columns="goodsone" :defaultIndex="goodsDefaultIndex"
 | ||
| 					@confirm="confirmgoods" @cancel="cancelgoods" @change="changeHandler" keyName="label"></u-picker>
 | ||
| 
 | ||
| 				<u-picker :show="shownature" :columns="nature" @confirm="confirmsnature" @cancel="cancelsnature"
 | ||
| 					keyName="label"></u-picker>
 | ||
| 
 | ||
| 				<u-picker :show="showxin" :columns="xinlist" :defaultIndex="xinDefaultIndex" @confirm="confirmxin"
 | ||
| 					@cancel="cancelxin" keyName="label"></u-picker>
 | ||
| 				<u-picker :show="showzhi" :columns="zhilist" @confirm="confirmzhi" @cancel="cancelzhi"
 | ||
| 					keyName="label"></u-picker>
 | ||
| 				<u-picker :show="showLeadMan" :columns="leadManList" :defaultIndex="defaultIndex"
 | ||
| 					@confirm="confirmLeadMan" @cancel="cancelLeadMan" keyName="nickname"></u-picker>
 | ||
| 				<u-picker :show="showMeetMan" :columns="meetManList" :defaultIndex="defaultIndex"
 | ||
| 					@confirm="confirmMeetMan" @cancel="showMeetMan = false" keyName=" "></u-picker>
 | ||
| 				<u-datetime-picker :minDate="946656000000" :maxDate="new Date().getTime()" :show="showRegisterDate"
 | ||
| 					v-model="carRegisterDate" mode="date" @cancel="showRegisterDate = false"
 | ||
| 					@confirm="confirmRegisterDate"></u-datetime-picker>
 | ||
| 			</view>
 | ||
| 		</view>
 | ||
| 	</view>
 | ||
| </template>
 | ||
| 
 | ||
| <script>
 | ||
| 	import config from '@/config';
 | ||
| 	import request from '../../utils/request';
 | ||
| 	import upload from '@/utils/upload.js'
 | ||
| 	import {
 | ||
| 		getToken,
 | ||
| 		getTenantId
 | ||
| 	} from '@/utils/auth'
 | ||
| 	import {
 | ||
| 		formatDate,
 | ||
| 		handleTree
 | ||
| 	} from "@/utils/utils";
 | ||
| 	import headersVue from "@/components/header/headers.vue";
 | ||
| 	import USwitch from "@/uni_modules/uview-ui/components/u-switch/u-switch.vue";
 | ||
| 
 | ||
| 	export default {
 | ||
| 		components: {
 | ||
| 			USwitch,
 | ||
| 			headersVue
 | ||
| 		},
 | ||
| 		data() {
 | ||
| 			return {
 | ||
| 				imagePath: '',
 | ||
| 				fileList: [],
 | ||
| 				title: '新增接车',
 | ||
| 				customerSource: '',
 | ||
| 				customerSourceId: '',
 | ||
| 				businessChannel: '',
 | ||
| 				businessChannelId: '',
 | ||
| 				fileList1: [],
 | ||
| 				buyName: '',
 | ||
| 				nickname: '',
 | ||
| 				buyPhone: '',
 | ||
| 				userAddress: '',
 | ||
| 				content: '',
 | ||
| 				carNum: '',
 | ||
| 				baseImageUrl: this.$baseImageUrl,
 | ||
| 				carStatus: '',
 | ||
| 				carIdNo: '',
 | ||
| 				radioValue: '0',
 | ||
| 				carModel: '',
 | ||
| 				carNature: '',
 | ||
| 				cssj: '',
 | ||
| 				otherPhone: '',
 | ||
| 				otherName: '',
 | ||
| 				showRegisterDate: false,
 | ||
| 				show: false,
 | ||
| 				shownature: false,
 | ||
| 				showgoods: false,
 | ||
| 				showxin: false,
 | ||
| 				showzhi: false,
 | ||
| 				showRecord: false,
 | ||
| 				showLeadMan: false,
 | ||
| 				showMeetMan: false,
 | ||
| 				skuId: undefined,
 | ||
| 				inspectionWorkNodes: [],
 | ||
| 				driverLicenseTypeArr: [],
 | ||
| 				defaultIndex: [0],
 | ||
| 				kehuDefaultIndex: [0],
 | ||
| 				goodsDefaultIndex: [0, 0],
 | ||
| 				meetName: '',
 | ||
| 				columns: [],
 | ||
| 				options: [],
 | ||
| 				nature: [],
 | ||
| 				goodsone: [],
 | ||
| 				goodstwo: [],
 | ||
| 				columnData: [],
 | ||
| 				xinlist: [],
 | ||
| 				zhilist: [],
 | ||
| 				isLoading: false,
 | ||
| 				userInfo: {},
 | ||
| 				recordTime: Number(new Date()),
 | ||
| 				baseUrl: this.$baseImageUrl,
 | ||
| 				goodsId: '',
 | ||
| 				msg: '3',
 | ||
| 				radiolist1: [{
 | ||
| 						name: '接待',
 | ||
| 						label: 0
 | ||
| 					},
 | ||
| 					{
 | ||
| 						name: '上门取车',
 | ||
| 						label: 1
 | ||
| 					},
 | ||
| 					{
 | ||
| 						name: '业务接车',
 | ||
| 						label: 2
 | ||
| 					}
 | ||
| 				],
 | ||
| 				radiovalue1: 0,
 | ||
| 				tapnum: 0,
 | ||
| 				fenlist: [],
 | ||
| 				goodstext: '',
 | ||
| 				ftitle: null,
 | ||
| 				shopImages: [],
 | ||
| 				shoplist: {},
 | ||
| 				province: '',
 | ||
| 				carRegisterDateStr: '',
 | ||
| 				unitName: '',
 | ||
| 				kehui: '',
 | ||
| 				naturetext: '',
 | ||
| 				customerData: [],
 | ||
| 				meetType: 0,
 | ||
| 				inspectionWorkNodeStr: "",
 | ||
| 				leadManId: undefined,
 | ||
| 				driverLicenesImg: undefined,
 | ||
| 				meetManId: undefined,
 | ||
| 				leadManList: [],
 | ||
| 				meetManList: [],
 | ||
| 				isInsert: true,
 | ||
| 				inspectionId: undefined,
 | ||
| 				xinDefaultIndex: [0],
 | ||
| 				recordTimeStr: '',
 | ||
| 				carRegisterDate: '',
 | ||
| 				appointmentId: null
 | ||
| 			}
 | ||
| 		},
 | ||
| 		async onLoad(options) {
 | ||
| 			this.isLoading = true
 | ||
| 			await this.getinitialize()
 | ||
| 			this.userInfo = uni.getStorageSync('staffinfo')
 | ||
| 			if (!this.userInfo || !this.userInfo.userInfo) {
 | ||
| 				request({
 | ||
| 					url: '/rescue/getJcWorkerInfo',
 | ||
| 					method: 'get',
 | ||
| 
 | ||
| 				}).then((res) => {
 | ||
| 					if (res.code == 200) {
 | ||
| 						uni.setStorageSync('staffinfo', res.data)
 | ||
| 						uni.setStorageSync('userId', res.data.user.id)
 | ||
| 					}
 | ||
| 				})
 | ||
| 			}
 | ||
| 			console.log('当前用户信息', this.userInfo);
 | ||
| 			if (this.userInfo.userInfo) {
 | ||
| 				this.otherPhone = this.userInfo.userInfo.mobile
 | ||
| 				this.otherName = this.userInfo.userInfo.nickname
 | ||
| 			}
 | ||
| 			if (options.type) {
 | ||
| 				if (options.type === 'business') {
 | ||
| 					// 业务经理接车
 | ||
| 					//1.设置默认接车为业务接车
 | ||
| 					this.radiovalue1 = 2
 | ||
| 
 | ||
| 					//2.找出对应的客户来源和业务
 | ||
| 					console.log('客户来源', this.columns);
 | ||
| 					console.log('当前userId', uni.getStorageSync('userId'));
 | ||
| 					const result = this.findUserWithParent(this.columns, uni.getStorageSync('userId'))
 | ||
| 					console.log('查询出来的shuju ', result)
 | ||
| 					if (result) {
 | ||
| 						this.customerSource = result.child.name
 | ||
| 						this.customerSourceId = result.child.id
 | ||
| 						this.businessChannel = result.parent.name
 | ||
| 						this.businessChannelId = result.parent.id
 | ||
| 						this.cssj = this.customerSourceId
 | ||
| 					}
 | ||
| 				}
 | ||
| 			}
 | ||
| 
 | ||
| 			this.isLoading = false
 | ||
| 		},
 | ||
| 		onShow() {
 | ||
| 
 | ||
| 		},
 | ||
| 
 | ||
| 		methods: {
 | ||
| 			handleClick() {
 | ||
| 				if (this.isInsert) {
 | ||
| 					this.showgoods = true;
 | ||
| 				} else {
 | ||
| 					uni.showToast({
 | ||
| 						title: '不可修改商品',
 | ||
| 						icon: 'none'
 | ||
| 					})
 | ||
| 				}
 | ||
| 			},
 | ||
| 			onchange(e) {
 | ||
| 				console.log('选择的内容', e);
 | ||
| 				this.customerSource = e.detail.value[1].text
 | ||
| 				this.customerSourceId = e.detail.value[1].value
 | ||
| 				this.businessChannel = e.detail.value[0].text
 | ||
| 				this.businessChannelId = e.detail.value[0].value
 | ||
| 			},
 | ||
| 			onnodeclick(e) {
 | ||
| 				console.log('选择的内容', e);
 | ||
| 				console.log('bangding', this.cssj);
 | ||
| 			},
 | ||
| 			/**
 | ||
| 			 * @param {Object} data
 | ||
| 			 * @param {Object} userId
 | ||
| 			 */
 | ||
| 			findUserWithParent(data, userId) {
 | ||
| 				for (const parent of data) {
 | ||
| 					if (Array.isArray(parent.children)) {
 | ||
| 						for (const child of parent.children) {
 | ||
| 							if (child.userIds && child.userIds.includes(userId)) {
 | ||
| 								return {
 | ||
| 									parent,
 | ||
| 									child
 | ||
| 								};
 | ||
| 							}
 | ||
| 						}
 | ||
| 					}
 | ||
| 				}
 | ||
| 				return null; // 未找到
 | ||
| 			},
 | ||
| 			async getCustomerSource(searchValue) {
 | ||
| 				console.log('搜索内容', searchValue);
 | ||
| 				let res = await request({
 | ||
| 					url: '/partnerOwn/partner/getCustomerSource',
 | ||
| 					method: 'get',
 | ||
| 					params: {
 | ||
| 						searchValue: searchValue
 | ||
| 					}
 | ||
| 				})
 | ||
| 				this.columns = res.data
 | ||
| 			},
 | ||
| 			async afterRead(event) {
 | ||
| 				// 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式
 | ||
| 				let lists = [].concat(event.file)
 | ||
| 				let fileListLen = this[`fileList${event.name}`].length
 | ||
| 				lists.map((item) => {
 | ||
| 					this[`fileList${event.name}`].push({
 | ||
| 						...item,
 | ||
| 
 | ||
| 					})
 | ||
| 				})
 | ||
| 				for (let i = 0; i < lists.length; i++) {
 | ||
| 					const result = await this.uploadFilePromise(lists[i].url)
 | ||
| 					console.log(result)
 | ||
| 					let item = this[`fileList${event.name}`][fileListLen]
 | ||
| 					this[`fileList${event.name}`].splice(fileListLen, 1, Object.assign(item, {
 | ||
| 						status: 'success',
 | ||
| 						message: '',
 | ||
| 						url: result
 | ||
| 					}))
 | ||
| 					fileListLen++
 | ||
| 				}
 | ||
| 			},
 | ||
| 			async uploadFilePromise(url) {
 | ||
| 				let res = await upload({
 | ||
| 					url: '/common/upload',
 | ||
| 					filePath: url,
 | ||
| 				})
 | ||
| 				return res.data.url
 | ||
| 
 | ||
| 			},
 | ||
| 			deletePic(event) {
 | ||
| 				this[`fileList${event.name}`].splice(event.index, 1)
 | ||
| 			},
 | ||
| 			handleRadioChange(newValue) {
 | ||
| 				if (newValue === '0') {
 | ||
| 					this.recordTime = ''
 | ||
| 				}
 | ||
| 			},
 | ||
| 			formatter(type, value) {
 | ||
| 				if (type === 'year') {
 | ||
| 					return `${value}年`
 | ||
| 				}
 | ||
| 				if (type === 'month') {
 | ||
| 					return `${value}月`
 | ||
| 				}
 | ||
| 				if (type === 'day') {
 | ||
| 					return `${value}日`
 | ||
| 				}
 | ||
| 				return value
 | ||
| 			},
 | ||
| 			groupChange() {
 | ||
| 				console.log(this.radiovalue1);
 | ||
| 			},
 | ||
| 			changeHandler(e) {
 | ||
| 				const {
 | ||
| 					columnIndex,
 | ||
| 					value,
 | ||
| 					values, // values为当前变化列的数组内容
 | ||
| 					index,
 | ||
| 					// 微信小程序无法将picker实例传出来,只能通过ref操作
 | ||
| 					picker = this.$refs.uPicker
 | ||
| 				} = e
 | ||
| 				// 当第一列值发生变化时,变化第二列(后一列)对应的选项
 | ||
| 				if (columnIndex === 0) {
 | ||
| 					// picker为选择器this实例,变化第二列对应的选项
 | ||
| 					picker.setColumnValues(1, this.columnData[index])
 | ||
| 				}
 | ||
| 			},
 | ||
| 			confirms(e) {
 | ||
| 				this.customerSource = e.label
 | ||
| 				this.show = false
 | ||
| 			},
 | ||
| 			cancels() {
 | ||
| 				this.show = false
 | ||
| 			},
 | ||
| 			// xin
 | ||
| 			confirmxin(e) {
 | ||
| 				this.carStatus = e.value[0].label
 | ||
| 				this.showxin = false
 | ||
| 			},
 | ||
| 			cancelxin() {
 | ||
| 				this.showxin = false
 | ||
| 			},
 | ||
| 			//zhi
 | ||
| 			confirmzhi(e) {
 | ||
| 				this.carNature = e.value[0].label
 | ||
| 				this.showzhi = false
 | ||
| 			},
 | ||
| 			confirmLeadMan(e) {
 | ||
| 				this.nickname = e.value[0].nickname
 | ||
| 				this.leadManId = e.value[0].id
 | ||
| 				this.showLeadMan = false
 | ||
| 			},
 | ||
| 			confirmMeetMan(e) {
 | ||
| 				this.meetName = e.value[0].nickname
 | ||
| 				this.meetManId = e.value[0].id
 | ||
| 				this.showMeetMan = false
 | ||
| 			},
 | ||
| 			confirmRecord(e) {
 | ||
| 				//将时间戳转换
 | ||
| 				this.recordTime = e.value
 | ||
| 				this.recordTimeStr = this.formatTimestamp(e)
 | ||
| 				this.showRecord = false
 | ||
| 			},
 | ||
| 			confirmRegisterDate(e) {
 | ||
| 				//将时间戳转换
 | ||
| 				this.carRegisterDateStr = formatDate(e.value)
 | ||
| 				this.carRegisterDate = e.value
 | ||
| 				console.log(this.carRegisterDate)
 | ||
| 				this.showRegisterDate = false
 | ||
| 			},
 | ||
| 			cancelzhi() {
 | ||
| 				this.showzhi = false
 | ||
| 			},
 | ||
| 			formatTimestamp(e) {
 | ||
| 				if (!e || !e.value) {
 | ||
| 					console.error('Invalid input');
 | ||
| 					return null;
 | ||
| 				}
 | ||
| 
 | ||
| 				const timestamp = parseInt(e.value, 10); // 确保时间戳为整数
 | ||
| 				if (isNaN(timestamp)) {
 | ||
| 					console.error('Invalid timestamp');
 | ||
| 					return null;
 | ||
| 				}
 | ||
| 
 | ||
| 				const date = new Date(timestamp); // 将时间戳转换为 Date 对象
 | ||
| 				const year = date.getFullYear();
 | ||
| 				const month = String(date.getMonth() + 1).padStart(2, '0'); // 月份从 0 开始,需要加 1
 | ||
| 				const day = String(date.getDate()).padStart(2, '0');
 | ||
| 				const hours = String(date.getHours()).padStart(2, '0');
 | ||
| 				const minutes = String(date.getMinutes()).padStart(2, '0');
 | ||
| 				// const seconds = String(date.getSeconds()).padStart(2, '0');
 | ||
| 
 | ||
| 				// 格式化为 YYYY-MM-DD HH:mm:ss
 | ||
| 				return `${year}-${month}-${day} ${hours}:${minutes}`;
 | ||
| 			},
 | ||
| 			cancelLeadMan() {
 | ||
| 				this.showLeadMan = false
 | ||
| 			},
 | ||
| 			cancelRecord() {
 | ||
| 				this.showRecord = false
 | ||
| 			},
 | ||
| 			findItemById(data, id) {
 | ||
| 				for (const group of data) {
 | ||
| 					for (const item of group) {
 | ||
| 						if (item.value === id) {
 | ||
| 							return item; // 找到匹配的对象后返回
 | ||
| 						}
 | ||
| 					}
 | ||
| 				}
 | ||
| 				return null; // 如果没有找到,返回 null
 | ||
| 			},
 | ||
| 			findGroupById(data, id) {
 | ||
| 				for (let index = 0; index < data.length; index++) {
 | ||
| 					const group = data[index];
 | ||
| 					for (const item of group) {
 | ||
| 						if (item.value === id) {
 | ||
| 							return {
 | ||
| 								group,
 | ||
| 								index
 | ||
| 							}; // 返回组和对应的索引
 | ||
| 						}
 | ||
| 					}
 | ||
| 				}
 | ||
| 				return null; // 如果没有找到,返回 null
 | ||
| 			},
 | ||
| 
 | ||
| 			confirmsnature(e) {
 | ||
| 				this.naturetext = e.value[0].label
 | ||
| 				this.shownature = false
 | ||
| 			},
 | ||
| 			cancelsnature() {
 | ||
| 				this.shownature = false
 | ||
| 			},
 | ||
| 			confirmgoods(e) {
 | ||
| 				this.goodstext = e.value[1].label
 | ||
| 				this.skuId = e.value[1].value
 | ||
| 				this.showgoods = false
 | ||
| 			},
 | ||
| 			cancelgoods() {
 | ||
| 				this.showgoods = false
 | ||
| 			},
 | ||
| 			async getinitialize() {
 | ||
| 				let res = await request({
 | ||
| 					url: '/channel/list',
 | ||
| 					method: 'get',
 | ||
| 				})
 | ||
| 				this.columns = handleTree(res.data, 'id', 'pid')
 | ||
| 				let rescar = await request({
 | ||
| 					url: '/rescue/dict/data/type/car_nature',
 | ||
| 					method: 'get',
 | ||
| 				})
 | ||
| 				this.nature.push(rescar.data)
 | ||
| 				let resx = await request({
 | ||
| 					url: '/system/inspectionGoods/partnerGoodsListCol',
 | ||
| 					method: 'get',
 | ||
| 				})
 | ||
| 				this.goodsone.push(resx.data.goodsList)
 | ||
| 				this.goodsone.push(resx.data.skuList[0])
 | ||
| 				this.columnData = resx.data.skuList
 | ||
| 				let resxin = await request({
 | ||
| 					url: '/rescue/dict/data/type/car_status',
 | ||
| 					method: 'get',
 | ||
| 				})
 | ||
| 				this.xinlist.push(resxin.data)
 | ||
| 				let reszhi = await request({
 | ||
| 					url: '/rescue/dict/data/type/car_use_nature',
 | ||
| 					method: 'get',
 | ||
| 				})
 | ||
| 				this.zhilist.push(reszhi.data)
 | ||
| 
 | ||
| 			},
 | ||
| 			toSelectProject() {
 | ||
| 				uni.navigateTo({
 | ||
| 					url: `/pages/index/selectProject?selectProject=${JSON.stringify(this.inspectionWorkNodes)}`
 | ||
| 				})
 | ||
| 			},
 | ||
| 			async getgoodes() {
 | ||
| 				if (this.carNum == '' || this.carRegisterDate == '' || !this.buyPhone) {
 | ||
| 					uni.showToast({
 | ||
| 						title: '车牌号 车辆注册日期 联系方式 必填!',
 | ||
| 						icon: 'none'
 | ||
| 					})
 | ||
| 					return
 | ||
| 				}
 | ||
| 				if (this.otherName == '' || this.otherPhone == '') {
 | ||
| 					uni.showToast({
 | ||
| 						title: '经办人 经办人手机号 必填!',
 | ||
| 						icon: 'none'
 | ||
| 					})
 | ||
| 					return
 | ||
| 				}
 | ||
| 				if (this.fileList1.length == 0) {
 | ||
| 					uni.showToast({
 | ||
| 						title: '车辆照片必须上传',
 | ||
| 						icon: 'none'
 | ||
| 					})
 | ||
| 					return
 | ||
| 				}
 | ||
| 				let data = {
 | ||
| 					partnerId: uni.getStorageSync('partnerId'),
 | ||
| 					buyName: this.buyName,
 | ||
| 					buyPhone: this.buyPhone,
 | ||
| 					userAddress: this.userAddress,
 | ||
| 					unitName: this.unitName,
 | ||
| 					carNum: this.carNum,
 | ||
| 					carModel: this.carModel,
 | ||
| 					carStatus: this.carStatus,
 | ||
| 					carIdNo: this.carIdNo,
 | ||
| 					customerSource: this.customerSource,
 | ||
| 					customerSourceId: this.customerSourceId,
 | ||
| 					businessChannelId: this.businessChannelId,
 | ||
| 					businessChannel: this.businessChannel,
 | ||
| 					skuId: this.skuId,
 | ||
| 					carNature: this.carNature,
 | ||
| 					inspectionWorkNodes: this.inspectionWorkNodes,
 | ||
| 					leadManId: this.leadManId,
 | ||
| 					startTime: this.recordTime,
 | ||
| 					otherPhone: this.otherPhone,
 | ||
| 					otherName: this.otherName,
 | ||
| 					carRegisterDate: this.carRegisterDate,
 | ||
| 					meetManId: this.meetManId,
 | ||
| 					appointmentId: this.appointmentId,
 | ||
| 					content: this.content,
 | ||
| 					images: this.fileList1.map(item => item.url).join(','),
 | ||
| 					meetType: this.radiovalue1,
 | ||
| 				}
 | ||
| 
 | ||
| 				let res = await request({
 | ||
| 					url: '/inspection-meet-car-order/add',
 | ||
| 					method: 'post',
 | ||
| 					data: data
 | ||
| 				})
 | ||
| 				if (res.code == 200) {
 | ||
| 					uni.showToast({
 | ||
| 						title: "接车成功",
 | ||
| 						icon: "none"
 | ||
| 					})
 | ||
| 				}
 | ||
| 				setTimeout(() => {
 | ||
| 					uni.$emit('refresh')
 | ||
| 					uni.navigateBack()
 | ||
| 				}, 2000);
 | ||
| 			},
 | ||
| 			async edit() {
 | ||
| 				if (this.carNum == '' || this.customerSource == "" || this.leadManId == undefined || this
 | ||
| 					.businessChannel == "") {
 | ||
| 					uni.showToast({
 | ||
| 						title: '车牌号 客户来源 引车员 必填!',
 | ||
| 						icon: 'none'
 | ||
| 					})
 | ||
| 					return
 | ||
| 				}
 | ||
| 
 | ||
| 				let data = {
 | ||
| 					partnerId: uni.getStorageSync('partnerId'),
 | ||
| 					id: this.inspectionId,
 | ||
| 					buyName: this.buyName,
 | ||
| 					buyPhone: this.buyPhone,
 | ||
| 					userAddress: this.userAddress,
 | ||
| 					unitName: this.unitName,
 | ||
| 					carNum: this.carNum,
 | ||
| 					carModel: this.carModel,
 | ||
| 					carStatus: this.carStatus,
 | ||
| 					carIdNo: this.carIdNo,
 | ||
| 					customerSource: this.customerSource,
 | ||
| 					customerSourceId: this.customerSourceId,
 | ||
| 					businessChannelId: this.businessChannelId,
 | ||
| 					businessChannel: this.businessChannel,
 | ||
| 					skuId: this.skuId,
 | ||
| 					carNature: this.carNature,
 | ||
| 					inspectionWorkNodes: this.inspectionWorkNodes,
 | ||
| 					leadManId: this.leadManId,
 | ||
| 					carRegisterDate: this.carRegisterDate,
 | ||
| 					status: '2',
 | ||
| 					meetManId: this.meetManId,
 | ||
| 				}
 | ||
| 
 | ||
| 				let res = await request({
 | ||
| 					url: '/system/info/update',
 | ||
| 					method: 'post',
 | ||
| 					data: data
 | ||
| 				})
 | ||
| 				if (res.code == 200) {
 | ||
| 					uni.showToast({
 | ||
| 						title: "修改成功"
 | ||
| 					})
 | ||
| 					let resp = await request({
 | ||
| 						url: '/system/info/getWeorkNodesById',
 | ||
| 						method: 'get',
 | ||
| 						params: {
 | ||
| 							inspectionId: this.inspectionId
 | ||
| 						}
 | ||
| 					})
 | ||
| 					//调用重新检测
 | ||
| 					let res = await request({
 | ||
| 						url: '/system/info/recheck',
 | ||
| 						method: 'post',
 | ||
| 						data: {
 | ||
| 							inspectionInfoId: this.inspectionId,
 | ||
| 							workNodes: resp.data
 | ||
| 						}
 | ||
| 					})
 | ||
| 				}
 | ||
| 				setTimeout(() => {
 | ||
| 					uni.navigateTo({
 | ||
| 						url: '/pages/staff/staff'
 | ||
| 					})
 | ||
| 				}, 2000);
 | ||
| 			},
 | ||
| 			/*根据工单Id查询工单详情*/
 | ||
| 			getInspectionInfo() {
 | ||
| 				request({
 | ||
| 					url: '/system/info/' + this.inspectionId,
 | ||
| 					method: 'get'
 | ||
| 				}).then(res => {
 | ||
| 					this.shoplist = res.data
 | ||
| 					this.buyName = res.data.buyName
 | ||
| 					this.buyPhone = res.data.buyPhone
 | ||
| 					this.userAddress = res.data.userAddress
 | ||
| 					this.unitName = res.data.unitName
 | ||
| 					this.carNum = res.data.carNum
 | ||
| 					this.carModel = res.data.carModel
 | ||
| 					this.carStatus = res.data.carStatus
 | ||
| 					this.carIdNo = res.data.carIdNo
 | ||
| 					this.customerSource = res.data.customerSource
 | ||
| 					this.businessChannel = res.data.businessChannel
 | ||
| 					this.skuId = res.data.skuId
 | ||
| 					this.carNature = res.data.carNature
 | ||
| 					this.leadManId = res.data.leadManId
 | ||
| 					this.otherPhone = res.data.otherPhone
 | ||
| 					setTimeout(() => {
 | ||
| 						let result = this.leadManList
 | ||
| 							.map((subArray, subArrayIndex) => {
 | ||
| 								const index = subArray.findIndex(item => item.id === res.data
 | ||
| 									.leadManId);
 | ||
| 								if (index !== -1) {
 | ||
| 									// 返回的是子数组的索引和匹配项的索引
 | ||
| 									return {
 | ||
| 										subArrayIndex,
 | ||
| 										itemIndex: index
 | ||
| 									};
 | ||
| 								} else {
 | ||
| 									// 没有找到匹配项,返回 null 或 undefined
 | ||
| 									return null;
 | ||
| 								}
 | ||
| 							})
 | ||
| 							.filter(item => item !== null); // 过滤掉没有匹配的项
 | ||
| 						let index = result[0].itemIndex
 | ||
| 						let subArrayIndex = result[0].subArrayIndex
 | ||
| 						this.defaultIndex = [index]
 | ||
| 						this.nickname = this.leadManList[subArrayIndex][index].nickname
 | ||
| 
 | ||
| 						//客户来源
 | ||
| 						let kehuResult = this.columns
 | ||
| 							.map((subArray, subArrayIndex) => {
 | ||
| 								const index = subArray.findIndex(item => item.label === res.data
 | ||
| 									.customerSource);
 | ||
| 								if (index !== -1) {
 | ||
| 									// 返回的是子数组的索引和匹配项的索引
 | ||
| 									return {
 | ||
| 										subArrayIndex,
 | ||
| 										itemIndex: index
 | ||
| 									};
 | ||
| 								} else {
 | ||
| 									// 没有找到匹配项,返回 null 或 undefined
 | ||
| 									return null;
 | ||
| 								}
 | ||
| 							})
 | ||
| 							.filter(item => item !== null); // 过滤掉没有匹配的项
 | ||
| 						this.kehuDefaultIndex = [kehuResult[0].itemIndex]
 | ||
| 
 | ||
| 						// 新旧车
 | ||
| 						//客户来源
 | ||
| 						let xinResult = this.xinlist
 | ||
| 							.map((subArray, subArrayIndex) => {
 | ||
| 								const index = subArray.findIndex(item => item.label === res.data
 | ||
| 									.carStatus);
 | ||
| 								if (index !== -1) {
 | ||
| 									// 返回的是子数组的索引和匹配项的索引
 | ||
| 									return {
 | ||
| 										subArrayIndex,
 | ||
| 										itemIndex: index
 | ||
| 									};
 | ||
| 								} else {
 | ||
| 									// 没有找到匹配项,返回 null 或 undefined
 | ||
| 									return null;
 | ||
| 								}
 | ||
| 							})
 | ||
| 							.filter(item => item !== null); // 过滤掉没有匹配的项
 | ||
| 						let a = [kehuResult[0]]
 | ||
| 						this.xinDefaultIndex = [a.itemIndex]
 | ||
| 					}, 1000);
 | ||
| 				})
 | ||
| 			},
 | ||
| 
 | ||
| 			// 提交
 | ||
| 			async getgoods() {
 | ||
| 
 | ||
| 				let res = await request({
 | ||
| 					url: '/partnerOwn/partner/editPartnerInfo',
 | ||
| 					method: 'post',
 | ||
| 					data: this.shoplist
 | ||
| 				})
 | ||
| 				if (res.code == 200) {
 | ||
| 					uni.showToast({
 | ||
| 						title: "修改成功"
 | ||
| 					})
 | ||
| 				}
 | ||
| 				setTimeout(() => {
 | ||
| 					uni.navigateBack()
 | ||
| 				}, 2000);
 | ||
| 			},
 | ||
| 			getxz(e) {
 | ||
| 				this.releasebox.goodsCategoryId = e.value[0].id
 | ||
| 				this.ftitle = e.value[0].categoryName
 | ||
| 			},
 | ||
| 			gettapindex(index) {
 | ||
| 				this.tapnum = index
 | ||
| 			},
 | ||
| 			getback() {
 | ||
| 				uni.navigateBack()
 | ||
| 			},
 | ||
| 			getyes() {
 | ||
| 				this.show = false
 | ||
| 			},
 | ||
| 			open() {},
 | ||
| 			close() {
 | ||
| 				this.guige = false
 | ||
| 			},
 | ||
| 			deletePic1(event) {
 | ||
| 				this[`fileList${event.name}`].splice(event.index, 1)
 | ||
| 			},
 | ||
| 			async afterRead1(event) {
 | ||
| 				// 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式
 | ||
| 				let lists = [].concat(event.file)
 | ||
| 				let fileListLen = this[`fileList${event.name}`].length
 | ||
| 				lists.map((item) => {
 | ||
| 					this[`fileList${event.name}`].push({
 | ||
| 						...item,
 | ||
| 
 | ||
| 					})
 | ||
| 				})
 | ||
| 				for (let i = 0; i < lists.length; i++) {
 | ||
| 					const result = await this.uploadFilePromise1(lists[i].url)
 | ||
| 					let item = this[`fileList${event.name}`][fileListLen]
 | ||
| 					this[`fileList${event.name}`].splice(fileListLen, 1, Object.assign(item, {
 | ||
| 						status: 'success',
 | ||
| 						message: '',
 | ||
| 						url: result
 | ||
| 					}))
 | ||
| 					fileListLen++
 | ||
| 				}
 | ||
| 			},
 | ||
| 			uploadFilePromise1(url) {
 | ||
| 				uni.showLoading({
 | ||
| 
 | ||
| 					title: '扫描中',
 | ||
| 
 | ||
| 				});
 | ||
| 
 | ||
| 				return new Promise((resolve, reject) => {
 | ||
| 					let a = uni.uploadFile({
 | ||
| 						url: this.$baseUrl + '/common/uploadImg', // 仅为示例,非真实的接口地址
 | ||
| 						filePath: url,
 | ||
| 						name: 'file',
 | ||
| 						header: {
 | ||
| 							'Tenant-Id': getTenantId(),
 | ||
| 							'Authorization': 'Bearer ' + getToken()
 | ||
| 						},
 | ||
| 						formData: {
 | ||
| 							user: 'test'
 | ||
| 						},
 | ||
| 						success: (res) => {
 | ||
| 							try {
 | ||
| 								let img = JSON.parse(res.data);
 | ||
| 								this.imagePath = img.data.url
 | ||
| 
 | ||
| 								setTimeout(() => {
 | ||
| 									this.vehicleLicenseOCR()
 | ||
| 								}, 1000)
 | ||
| 
 | ||
| 							} catch (e) {
 | ||
| 								//TODO handle the exception
 | ||
| 							}
 | ||
| 							setTimeout(() => {
 | ||
| 								resolve(res.data.data)
 | ||
| 							}, 1000)
 | ||
| 						}
 | ||
| 					});
 | ||
| 				})
 | ||
| 			},
 | ||
| 			async vehicleLicenseOCR() {
 | ||
| 				let data = {
 | ||
| 					imagePath: this.baseUrl + '/' + this.imagePath
 | ||
| 					//imagePath :'http://www.nuoyunr.com/lananRsc/detection/jsz.jpg'
 | ||
| 				}
 | ||
| 				let res = await request({
 | ||
| 					url: '/partnerOwn/partner/vehicleLicenseOCR',
 | ||
| 					method: 'post',
 | ||
| 					params: data
 | ||
| 				})
 | ||
| 				this.buyName = res.data.FrontInfo.Owner
 | ||
| 				this.userAddress = res.data.FrontInfo.Address
 | ||
| 				this.carNum = res.data.FrontInfo.PlateNo
 | ||
| 				this.carModel = res.data.FrontInfo.Model
 | ||
| 				this.carIdNo = res.data.FrontInfo.Vin
 | ||
| 				this.carNature = res.data.FrontInfo.UseCharacter
 | ||
| 				this.carRegisterDate = res.data.FrontInfo.RegisterDate
 | ||
| 				this.carRegisterDateStr = formatDate(this.carRegisterDate)
 | ||
| 				uni.hideLoading();
 | ||
| 				uni.showToast({
 | ||
| 					title: '识别成功',
 | ||
| 				});
 | ||
| 
 | ||
| 
 | ||
| 			}
 | ||
| 
 | ||
| 
 | ||
| 		}
 | ||
| 	}
 | ||
| </script>
 | ||
| 
 | ||
| <style scoped lang="scss">
 | ||
| 	.content {
 | ||
| 		box-sizing: border-box;
 | ||
| 		width: 100%;
 | ||
| 		height: calc(100vh);
 | ||
| 		background: white;
 | ||
| 	}
 | ||
| 
 | ||
| 	.top-heder {
 | ||
| 		width: 100%;
 | ||
| 		height: 46px;
 | ||
| 		background: white;
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 		justify-content: space-between;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 5px 15px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.t-title {
 | ||
| 		font-size: 17px;
 | ||
| 		font-weight: bold;
 | ||
| 		color: #333333;
 | ||
| 	}
 | ||
| 
 | ||
| 	.t-left {
 | ||
| 		width: 10%;
 | ||
| 	}
 | ||
| 
 | ||
| 	.t-you {
 | ||
| 		height: 100%;
 | ||
| 		width: 20%;
 | ||
| 	}
 | ||
| 
 | ||
| 	.t-input {
 | ||
| 		width: 80%;
 | ||
| 		height: 36px;
 | ||
| 		background: #F0F0F0;
 | ||
| 		border-radius: 50px;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 0 15px;
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 
 | ||
| 	}
 | ||
| 
 | ||
| 	.top-ail {
 | ||
| 		width: 100%;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 15px;
 | ||
| 		background-color: #F4F4F4;
 | ||
| 		// height: calc(100vh);
 | ||
| 	}
 | ||
| 
 | ||
| 	.mub {
 | ||
| 		background-color: #F4F4F4;
 | ||
| 		height: calc(100vh);
 | ||
| 	}
 | ||
| 
 | ||
| 	.dix {
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 	}
 | ||
| 
 | ||
| 	.upimg {
 | ||
| 		width: 100%;
 | ||
| 		height: 126px;
 | ||
| 		border-radius: 8px;
 | ||
| 		box-sizing: border-box;
 | ||
| 
 | ||
| 		background-color: white;
 | ||
| 
 | ||
| 		image {
 | ||
| 			width: 100%;
 | ||
| 			height: 100%;
 | ||
| 		}
 | ||
| 	}
 | ||
| 
 | ||
| 	.box-list {
 | ||
| 		width: 100%;
 | ||
| 		border-radius: 8px;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 10px;
 | ||
| 		background-color: white;
 | ||
| 		margin: 10px auto;
 | ||
| 	}
 | ||
| 
 | ||
| 	.list-box {
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 		justify-content: space-between;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 15px 5px;
 | ||
| 		border-bottom: 1px solid #EEEEEE;
 | ||
| 	}
 | ||
| 
 | ||
| 	.l-left {
 | ||
| 		font-size: 16px;
 | ||
| 		font-weight: 400;
 | ||
| 		color: #333333;
 | ||
| 	}
 | ||
| 
 | ||
| 	.l-right {
 | ||
| 		font-size: 16px;
 | ||
| 		font-weight: 400;
 | ||
| 		color: #999999;
 | ||
| 		text-align: right;
 | ||
| 	}
 | ||
| 
 | ||
| 	.xiaolan {
 | ||
| 		// width: 109px;
 | ||
| 		// height: 30px;
 | ||
| 		background: #E2EAFF;
 | ||
| 		border-radius: 50px;
 | ||
| 		display: flex;
 | ||
| 		align-content: center;
 | ||
| 		justify-self: center;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 5px;
 | ||
| 		font-size: 14px;
 | ||
| 		font-weight: 400;
 | ||
| 		color: #0D2E8D;
 | ||
| 	}
 | ||
| 
 | ||
| 	.xiaohui {
 | ||
| 		// width: 141px;
 | ||
| 		// height: 30px;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 0px 10px;
 | ||
| 		background: #F7F7F7;
 | ||
| 		border-radius: 50px;
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 		justify-content: center;
 | ||
| 		margin: 10px;
 | ||
| 
 | ||
| 	}
 | ||
| 
 | ||
| 	.hui-right {
 | ||
| 		border-left: 1px solid #DDDDDD;
 | ||
| 		padding: 5px;
 | ||
| 		margin-left: 5px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.wrap-box {
 | ||
| 		width: 100%;
 | ||
| 		box-sizing: border-box;
 | ||
| 		display: flex;
 | ||
| 		flex-wrap: wrap;
 | ||
| 	}
 | ||
| 
 | ||
| 	.bottom-di {
 | ||
| 		width: 100%;
 | ||
| 		height: 56px;
 | ||
| 		background: #FFFFFF;
 | ||
| 		border-radius: 8px;
 | ||
| 		display: flex;
 | ||
| 		justify-content: space-between;
 | ||
| 		align-items: center;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 0px 20px;
 | ||
| 		margin-bottom: 10px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.thui {
 | ||
| 		font-size: 16px;
 | ||
| 		font-weight: 400;
 | ||
| 		color: #666666;
 | ||
| 		margin-top: 10px;
 | ||
| 		margin-left: 8px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.imgs {
 | ||
| 		box-sizing: border-box;
 | ||
| 		margin-top: 20px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.p-box {
 | ||
| 		border-radius: 10px;
 | ||
| 		overflow: hidden;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 20px;
 | ||
| 		width: 100%;
 | ||
| 		background-color: white;
 | ||
| 	}
 | ||
| 
 | ||
| 	.p-top {
 | ||
| 		width: 100%;
 | ||
| 		text-align: center;
 | ||
| 		font-size: 17px;
 | ||
| 		font-weight: bold;
 | ||
| 		color: #000000;
 | ||
| 		margin-bottom: 20px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.on-input {
 | ||
| 		width: 100%;
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 		box-sizing: border-box;
 | ||
| 
 | ||
| 	}
 | ||
| 
 | ||
| 	.ipt-kuang {
 | ||
| 		width: 70%;
 | ||
| 		height: 30px;
 | ||
| 		background: #FFFFFF;
 | ||
| 		border-radius: 8px 8px 8px 8px;
 | ||
| 		opacity: 1;
 | ||
| 		border: 1px solid #DDDDDD;
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 		margin: 10px auto;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 0px 10px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.t-left {
 | ||
| 		width: 20%;
 | ||
| 		font-size: 14px;
 | ||
| 		font-weight: 400;
 | ||
| 		color: #000000;
 | ||
| 	}
 | ||
| 
 | ||
| 	.dlanniu {
 | ||
| 		width: 80%;
 | ||
| 		height: 45px;
 | ||
| 		background: linear-gradient(180deg, #327DFB 0%, #327DFB 100%);
 | ||
| 		border-radius: 50px;
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 		justify-content: center;
 | ||
| 		margin: 20px auto;
 | ||
| 		color: white;
 | ||
| 	}
 | ||
| 
 | ||
| 	.da {
 | ||
| 		font-size: 16px;
 | ||
| 	}
 | ||
| 
 | ||
| 	//
 | ||
| 	.top {
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 0px 15px;
 | ||
| 		width: 100%;
 | ||
| 		border-radius: 10px;
 | ||
| 		margin: 10px auto;
 | ||
| 		background-color: white;
 | ||
| 	}
 | ||
| 
 | ||
| 	.top-box {
 | ||
| 		display: flex;
 | ||
| 		justify-content: space-between;
 | ||
| 		align-items: center;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 20px 0px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.tb-left {
 | ||
| 		height: 100%;
 | ||
| 		width: 80%;
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 	}
 | ||
| 
 | ||
| 	.uicon {
 | ||
| 		width: 18px;
 | ||
| 		height: 18px;
 | ||
| 		border-radius: 4px;
 | ||
| 		color: white;
 | ||
| 		background: orangered;
 | ||
| 		display: flex;
 | ||
| 		justify-content: center;
 | ||
| 		align-items: center;
 | ||
| 		font-size: 12px;
 | ||
| 		font-weight: bold;
 | ||
| 		margin-right: 6px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.tb-right {
 | ||
| 		width: 20px;
 | ||
| 		height: 26px;
 | ||
| 
 | ||
| 		image {
 | ||
| 			width: 100%;
 | ||
| 			height: 100%;
 | ||
| 		}
 | ||
| 	}
 | ||
| 
 | ||
| 	.text1 {
 | ||
| 		font-size: 16px;
 | ||
| 		font-weight: bold;
 | ||
| 		color: #363636;
 | ||
| 	}
 | ||
| 
 | ||
| 	.hong1 {
 | ||
| 		margin-top: 5px;
 | ||
| 		font-size: 12px;
 | ||
| 		font-weight: 400;
 | ||
| 		color: #FF5453;
 | ||
| 	}
 | ||
| 
 | ||
| 	.hong2 {
 | ||
| 		margin-top: 5px;
 | ||
| 		font-size: 12px;
 | ||
| 		font-weight: 400;
 | ||
| 
 | ||
| 	}
 | ||
| 
 | ||
| 	.tinput {
 | ||
| 		width: 100%;
 | ||
| 		display: flex;
 | ||
| 		background: white;
 | ||
| 		align-items: center;
 | ||
| 		justify-content: space-between;
 | ||
| 		box-sizing: border-box;
 | ||
| 		padding: 16px;
 | ||
| 		margin-top: 14px;
 | ||
| 	}
 | ||
| 
 | ||
| 	.xixi {
 | ||
| 		font-size: 12px;
 | ||
| 		color: #0D2E8D;
 | ||
| 		margin-left: 10px;
 | ||
| 	}
 | ||
| </style> | 
