Compare commits
	
		
			No commits in common. "8ae783ebe45f4b97adbe3744e94e4b319155ea02" and "44b021d84af0163f3e227811d251f163e4254a09" have entirely different histories. 
		
	
	
		
			8ae783ebe4
			...
			44b021d84a
		
	
		
							
								
								
									
										2
									
								
								App.vue
								
								
								
								
							
							
						
						
									
										2
									
								
								App.vue
								
								
								
								
							|  | @ -11,7 +11,7 @@ | ||||||
| 			// 配置全局域名 | 			// 配置全局域名 | ||||||
| 			// #ifdef H5 | 			// #ifdef H5 | ||||||
| 				// this.globalData.hostapi = 'https://7and5.cn'; | 				// this.globalData.hostapi = 'https://7and5.cn'; | ||||||
| 				// this.globalData.hostapi = '/web'; | 				this.globalData.hostapi = '/web'; | ||||||
| 			// #endif  | 			// #endif  | ||||||
| 		}, | 		}, | ||||||
| 		onShow: function() { | 		onShow: function() { | ||||||
|  |  | ||||||
|  | @ -1,8 +1,8 @@ | ||||||
| @font-face { | @font-face { | ||||||
|   font-family: "iconfont"; /* Project id 3180711 */ |   font-family: "iconfont"; /* Project id 3180711 */ | ||||||
|   src: url('https://at.alicdn.com/t/font_3180711_635f9bvlgje.woff2?t=1652863135237') format('woff2'), |   src: url('https://at.alicdn.com/t/font_3180711_7fx7wl7itar.woff2?t=1647479558213') format('woff2'), | ||||||
|        url('https://at.alicdn.com/t/font_3180711_635f9bvlgje.woff?t=1652863135237') format('woff'), |        url('https://at.alicdn.com/t/font_3180711_7fx7wl7itar.woff?t=1647479558213') format('woff'), | ||||||
|        url('https://at.alicdn.com/t/font_3180711_635f9bvlgje.ttf?t=1652863135237') format('truetype'); |        url('https://at.alicdn.com/t/font_3180711_7fx7wl7itar.ttf?t=1647479558213') format('truetype'); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .icon { | .icon { | ||||||
|  | @ -13,66 +13,6 @@ | ||||||
|   -moz-osx-font-smoothing: grayscale; |   -moz-osx-font-smoothing: grayscale; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .icon-sj-left-top:before { |  | ||||||
|   content: "\e603"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-sj-top:before { |  | ||||||
|   content: "\e604"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-sj-right-top:before { |  | ||||||
|   content: "\e605"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-sj-bottom:before { |  | ||||||
|   content: "\e606"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-sj-right-bottom:before { |  | ||||||
|   content: "\e607"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-sj-left:before { |  | ||||||
|   content: "\e60d"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-zsj:before { |  | ||||||
|   content: "\e6bd"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-del:before { |  | ||||||
|   content: "\e718"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-cut:before { |  | ||||||
|   content: "\e609"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-add:before { |  | ||||||
|   content: "\e60a"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-add-picture05:before { |  | ||||||
|   content: "\e639"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-add-picture04:before { |  | ||||||
|   content: "\e636"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-add-picture03:before { |  | ||||||
|   content: "\e642"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-add-picture02:before { |  | ||||||
|   content: "\e8bc"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-add-picture01:before { |  | ||||||
|   content: "\e62c"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .icon-sandian:before { | .icon-sandian:before { | ||||||
|   content: "\e769"; |   content: "\e769"; | ||||||
| } | } | ||||||
|  | @ -153,7 +93,7 @@ | ||||||
|   content: "\e73f"; |   content: "\e73f"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .icon-shop-cart:before { | .icon-shopp-cart:before { | ||||||
|   content: "\e73d"; |   content: "\e73d"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -126,41 +126,18 @@ | ||||||
| 								break; | 								break; | ||||||
| 							case 2: | 							case 2: | ||||||
| 							// #ifdef APP-PLUS || MP-WEIXIN | 							// #ifdef APP-PLUS || MP-WEIXIN | ||||||
| 							this.$toolAll.tools.showToast(3) |  | ||||||
| 								uni.scanCode({ | 								uni.scanCode({ | ||||||
| 									onlyFromCamera:false, // 是否只能从相机扫码,不允许从相册选择图片 | 									onlyFromCamera:false, // 是否只能从相机扫码,不允许从相册选择图片 | ||||||
| 									scanType: ['qrCode'], // barCode:一维码, qrCode:二维码, datamatrix:Data Matrix 码, pdf417:PDF417 条码 | 									scanType: ['qrCode'], // barCode:一维码, qrCode:二维码, datamatrix:Data Matrix 码, pdf417:PDF417 条码 | ||||||
| 									autoDecodeCharset:true, // 是否启用自动识别字符编码功能,默认为否 | 									autoDecodeCharset:true, // 是否启用自动识别字符编码功能,默认为否 | ||||||
| 									success: function (res) { | 									success: function (res) { | ||||||
| 										// console.log(res); | 										console.log('条码类型:' + res.scanType); | ||||||
| 										// console.log('条码类型:' + res.scanType); | 										console.log('条码内容:' + res.result); | ||||||
| 										// console.log('条码内容:' + res.result); |  | ||||||
| 										let project_number = JSON.parse(res.result).project_number; |  | ||||||
| 										if(project_number) { |  | ||||||
| 											uni.navigateTo({ |  | ||||||
| 												url:`/pagesA/repairsPage/repairsPage?project_number=${project_number}` |  | ||||||
| 											}) |  | ||||||
| 										} else { |  | ||||||
| 											this.$toolAll.tools.showToast('请出示正确的码') |  | ||||||
| 										} |  | ||||||
| 									},fail() { |  | ||||||
| 										this.$toolAll.tools.showToast('扫描失败') |  | ||||||
| 									} | 									} | ||||||
| 								}); | 								}); | ||||||
| 							// #endif | 							// #endif | ||||||
| 							// #ifdef H5 | 							// #ifdef H5 | ||||||
| 								uni.showModal({ | 								this.scanCode(); | ||||||
| 									title:'提示', |  | ||||||
| 									content:'请使用,飞猴云服务APP进行扫一扫,是否马上下载APP?', |  | ||||||
| 									confirmText:'马上下载', |  | ||||||
| 									cancelText:'暂不下载', |  | ||||||
| 									success: (res) => { |  | ||||||
| 										if(res.confirm) { |  | ||||||
| 											 |  | ||||||
| 										} |  | ||||||
| 									} |  | ||||||
| 								}) |  | ||||||
| 								// this.scanCode(); |  | ||||||
| 							// #endif | 							// #endif | ||||||
| 								break; | 								break; | ||||||
| 							case 3: | 							case 3: | ||||||
|  | @ -180,23 +157,12 @@ | ||||||
| 					sizeType: ['original'], | 					sizeType: ['original'], | ||||||
| 					count: 1, | 					count: 1, | ||||||
| 					success: (res)=> { | 					success: (res)=> { | ||||||
| 						// uni.showModal({ | 						qrcode.decode(this.getObjectURL(res.tempFiles[0])) | ||||||
| 						// 	title:'进入了'+JSON.stringify(res) , |  | ||||||
| 						// 	content:JSON.stringify(res.tempFilePaths[0]) |  | ||||||
| 						// }) |  | ||||||
| 						qrcode.decode(this.getObjectURL(res.tempFilePaths[0])) |  | ||||||
| 						qrcode.callback = (codeRes) => { | 						qrcode.callback = (codeRes) => { | ||||||
| 							if (codeRes.indexOf('error') >= 0) { | 							if (codeRes.indexOf('error') >= 0) { | ||||||
| 								this.footList[2].title  = 3; |  | ||||||
| 								// 二维码识别失败 | 								// 二维码识别失败 | ||||||
| 								console.log('不合法二维码:' + codeRes); | 								console.log('不合法二维码:' + codeRes); | ||||||
| 								uni.showModal({ |  | ||||||
| 									title:'请出示正确的码', |  | ||||||
| 									content:res |  | ||||||
| 								}) |  | ||||||
| 								// this.$toolAll.tools.showToast('请出示正确的码') |  | ||||||
| 							} else { | 							} else { | ||||||
| 								this.footList[2].title  = 2; |  | ||||||
| 								// 二维码识别成功 | 								// 二维码识别成功 | ||||||
| 								let r = this.decodeStr(codeRes) | 								let r = this.decodeStr(codeRes) | ||||||
| 								// this.qrCodeRes = r | 								// this.qrCodeRes = r | ||||||
|  | @ -219,8 +185,6 @@ | ||||||
| 						// 	} | 						// 	} | ||||||
| 						// } | 						// } | ||||||
| 					},fail:(err)=> { | 					},fail:(err)=> { | ||||||
| 						this.footList[2].title  = 1; |  | ||||||
| 						this.$toolAll.tools.showToast(err) |  | ||||||
| 						this.$toolAll.tools.checkQx(err.code); | 						this.$toolAll.tools.checkQx(err.code); | ||||||
|                     } |                     } | ||||||
| 				}); | 				}); | ||||||
|  | @ -228,15 +192,13 @@ | ||||||
| 			// 获取文件地址函数 | 			// 获取文件地址函数 | ||||||
| 			getObjectURL(file) { | 			getObjectURL(file) { | ||||||
| 				var url = null | 				var url = null | ||||||
| 				// if (window.createObjectURL !== undefined) { // basic | 				if (window.createObjectURL !== undefined) { // basic | ||||||
| 				// 	url = window.createObjectURL(file) | 					url = window.createObjectURL(file) | ||||||
| 				// } else if (window.URL !== undefined) { // mozilla(firefox) | 				} else if (window.URL !== undefined) { // mozilla(firefox) | ||||||
| 				// 	url = window.URL.createObjectURL(file) | 					url = window.URL.createObjectURL(file) | ||||||
| 				// } else if (window.webkitURL !== undefined) { // webkit or chrome | 				} else if (window.webkitURL !== undefined) { // webkit or chrome | ||||||
| 				// 	url = window.webkitURL.createObjectURL(file) | 					url = window.webkitURL.createObjectURL(file) | ||||||
| 				// } | 				} | ||||||
| 				url = window.URL.createObjectURL(file) |  | ||||||
| 				this.footList[2].title  = url; |  | ||||||
| 				return url | 				return url | ||||||
| 			}, | 			}, | ||||||
| 			// 解码,输出:中文 | 			// 解码,输出:中文 | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -498,13 +498,8 @@ const tools = { | ||||||
| 		return !reg_identity.test(identity); | 		return !reg_identity.test(identity); | ||||||
| 	}, | 	}, | ||||||
|     // 手机号中间四位用"****"带替
 |     // 手机号中间四位用"****"带替
 | ||||||
|     hideMPhone(phone,str=''){ |     hideMPhone(phone){ | ||||||
| 		if(str) { |         return `${phone.substr(0, 3)}****${phone.substr(7)}` | ||||||
| 			return `${phone.substr(0, 3)}${str.padEnd(4,'x')}${phone.substr(7)}` |  | ||||||
| 		} else { |  | ||||||
| 			return `${phone.substr(0, 3)}****${phone.substr(7)}` |  | ||||||
| 		} |  | ||||||
|          |  | ||||||
|     }, |     }, | ||||||
| 	// 手机号中间加字符
 | 	// 手机号中间加字符
 | ||||||
| 	phoneAddChat(phone,startNum=3,endNum=7,character=' '){ | 	phoneAddChat(phone,startNum=3,endNum=7,character=' '){ | ||||||
|  |  | ||||||
|  | @ -31,17 +31,9 @@ | ||||||
|                     "<uses-permission android:name=\"android.permission.READ_LOGS\"/>", |                     "<uses-permission android:name=\"android.permission.READ_LOGS\"/>", | ||||||
|                     "<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>", |                     "<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>", | ||||||
|                     "<uses-feature android:name=\"android.hardware.camera.autofocus\"/>", |                     "<uses-feature android:name=\"android.hardware.camera.autofocus\"/>", | ||||||
|                     "<uses-permission android:name=\"android.permission.ACCESS_COARSE_LOCATION\"/>", |  | ||||||
|                     "<uses-permission android:name=\"android.permission.ACCESS_FINE_LOCATION\"/>", |  | ||||||
|                     "<uses-permission android:name=\"android.permission.ACCESS_MOCK_LOCATION\"/>", |  | ||||||
|                     "<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>", |                     "<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>", | ||||||
|                     "<uses-permission android:name=\"android.permission.CAMERA\"/>", |                     "<uses-permission android:name=\"android.permission.CAMERA\"/>", | ||||||
|                     "<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>", |                     "<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>", | ||||||
|                     "<uses-permission android:name=\"android.permission.GET_TASKS\"/>", |  | ||||||
|                     "<uses-permission android:name=\"android.permission.MODIFY_AUDIO_SETTINGS\"/>", |  | ||||||
|                     "<uses-permission android:name=\"android.permission.MOUNT_UNMOUNT_FILESYSTEMS\"/>", |  | ||||||
|                     "<uses-permission android:name=\"android.permission.READ_EXTERNAL_STORAGE\"/>", |  | ||||||
|                     "<uses-permission android:name=\"android.permission.READ_LOGS\"/>", |  | ||||||
|                     "<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>", |                     "<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>", | ||||||
|                     "<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>", |                     "<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>", | ||||||
|                     "<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>", |                     "<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>", | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| <template> | <template> | ||||||
| 	<view :style="{height: windowHeight+'px'}" style="overflow: hidden;"> | 	<view :style="{height: windowHeight+'px'}" style="overflow: hidden;"> | ||||||
| 		<image :src="ad_img || '/static/public/icon-guide.png'" mode="widthFix" style="width: 100%;"></image> | 		<image src="/static/public/icon-guide.png" mode="widthFix" style="width: 100%;"></image> | ||||||
| 	</view> | 	</view> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
|  | @ -8,18 +8,11 @@ | ||||||
| 	export default { | 	export default { | ||||||
| 		data() { | 		data() { | ||||||
| 			return { | 			return { | ||||||
| 				windowHeight:uni.getSystemInfoSync().windowHeight, | 				windowHeight:uni.getSystemInfoSync().windowHeight | ||||||
| 				ad_img:'' |  | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
| 		onLoad() { | 		onLoad() { | ||||||
| 			this.checkContext(); | 			this.checkContext(); | ||||||
| 			this.$requst.get('/universal/api.other/advertise').then(res=>{ |  | ||||||
| 				if(res.code) { |  | ||||||
| 					this.ad_img = res.data.ad_img; |  | ||||||
| 					uni.setStorageSync('adImg',this.ad_img); |  | ||||||
| 				} |  | ||||||
| 			}) |  | ||||||
| 		}, | 		}, | ||||||
| 		methods: { | 		methods: { | ||||||
| 			checkContext(){ | 			checkContext(){ | ||||||
|  | @ -52,7 +45,7 @@ | ||||||
| 					'/pages/login/login', | 					'/pages/login/login', | ||||||
| 					'/pages/tabbar/pagehome/pagehome' | 					'/pages/tabbar/pagehome/pagehome' | ||||||
| 				] | 				] | ||||||
| 				setTimeout(()=>{uni.reLaunch({url:arr[index]})},6000) | 				setTimeout(()=>{uni.reLaunch({url:arr[index]})},3000) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -94,26 +94,28 @@ | ||||||
|                 <view class="title-content"> |                 <view class="title-content"> | ||||||
|                     <view class="title"> |                     <view class="title"> | ||||||
|                         <image class="icon" src="../../static/iocn/xmlb.png" mode=""></image> |                         <image class="icon" src="../../static/iocn/xmlb.png" mode=""></image> | ||||||
|                         <view class="text" style="font-size: 28rpx;">项目列表</view> |                         <view class="text" style="font-size: 28rpx;"> | ||||||
|  |                             项目列表 | ||||||
|  |                         </view> | ||||||
|                     </view> |                     </view> | ||||||
|                     <picker :value="currentyear" :range="yearArr" @change="bindTimeChange"> |                     <picker mode="date" :value="time" @change="bindTimeChange"> | ||||||
|                         <view class="date disac" :style="{color: chooseyear ? '#000000' : '#999999',border: chooseyear ? '2rpx solid #000000' : '2rpx solid #999999'}"> |                         <view class="date scal09"> | ||||||
|                             {{chooseyear ? chooseyear+'年' : '选择年份'}} <i class="icon icon-zsj" style="font-size: 18rpx;"></i> |                             选择年份 <image class="icon" src="../../static/iocn/sjx.png" mode=""></image> | ||||||
| 							<!-- <image class="icon flexs" src="../../static/iocn/sjx.png" mode=""></image> --> |  | ||||||
|                         </view> |                         </view> | ||||||
|                     </picker> |                     </picker> | ||||||
|  |              | ||||||
|  |                 </view> | ||||||
|  |              | ||||||
|  |                 <view class="project-list-content" v-for="item in 5"> | ||||||
|  |                     <view class="li"> | ||||||
|  |                         <view class="text"> | ||||||
|  |                             南城校区液晶显示屏 | ||||||
|  |                         </view> | ||||||
|  |                         <view class="date"> | ||||||
|  |                             2022/3/1 | ||||||
|  |                         </view> | ||||||
|  |                     </view> | ||||||
|                 </view> |                 </view> | ||||||
| 				<view class="project-list-box"> |  | ||||||
| 					<view class="project-list-content" v-for="(item,index) in projectList" :key="index"> |  | ||||||
| 					    <view class="li"> |  | ||||||
| 					        <view class="text">{{item.project_name}}</view> |  | ||||||
| 					        <view class="date">{{item.create_time}}</view> |  | ||||||
| 					    </view> |  | ||||||
| 					</view> |  | ||||||
| 					<view v-if="!projectList.length" class="disjcac fc" style="height: 120rpx;"> |  | ||||||
| 						<pitera textStr="查询无果"></pitera> |  | ||||||
| 					</view> |  | ||||||
| 				</view> |  | ||||||
|             </view> |             </view> | ||||||
|             <view class="contact-way" @click="copyWxFun()"> |             <view class="contact-way" @click="copyWxFun()"> | ||||||
|                 <view class="title"> |                 <view class="title"> | ||||||
|  | @ -138,15 +140,14 @@ | ||||||
|      import containerSubgroupTwo from '@/components/containers/container-subgroup-two.vue'; |      import containerSubgroupTwo from '@/components/containers/container-subgroup-two.vue'; | ||||||
|     import statusNav from '../../components/status-nav.vue'; |     import statusNav from '../../components/status-nav.vue'; | ||||||
| 	import {queryDetail} from '@/jsFile/public-api.js'; | 	import {queryDetail} from '@/jsFile/public-api.js'; | ||||||
| 	import pitera from '@/components/nothing/pitera.vue'; |  | ||||||
|     export default { |     export default { | ||||||
|         components: { |         components: { | ||||||
|             statusNav, |             statusNav, | ||||||
|             containerSubgroupTwo, |             containerSubgroupTwo | ||||||
| 			pitera |  | ||||||
|         }, |         }, | ||||||
|         data() { |         data() { | ||||||
|             return { |             return { | ||||||
|  |                 time: '12:01', | ||||||
|                 dataArr:{ |                 dataArr:{ | ||||||
|                     customerName:"长沙警校", |                     customerName:"长沙警校", | ||||||
|                     customerCode:"xxxxxxxxx", |                     customerCode:"xxxxxxxxx", | ||||||
|  | @ -158,11 +159,8 @@ | ||||||
|                     area:"长沙", |                     area:"长沙", | ||||||
|                      |                      | ||||||
|                 }, |                 }, | ||||||
| 				clientId:'',//客户id |                 projectList:[], | ||||||
| 				yearArr:[],//年份 | 				clientId:''//客户id | ||||||
| 				currentyear: '',//当前年份 |  | ||||||
| 				chooseyear:'',//选中的年份 |  | ||||||
| 				projectList:[]//项目列表 |  | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
| 		onLoad(op){ | 		onLoad(op){ | ||||||
|  | @ -172,13 +170,6 @@ | ||||||
| 				// 调用查询客户详情信息事件 | 				// 调用查询客户详情信息事件 | ||||||
| 				this.queryDetailEv(); | 				this.queryDetailEv(); | ||||||
| 			} | 			} | ||||||
| 			let date = new Date(); |  | ||||||
| 			this.currentyear = date.getFullYear(); |  | ||||||
| 			for (let i = this.currentyear-10; i <= this.currentyear; i++) { |  | ||||||
| 				this.yearArr.push(i); |  | ||||||
| 			} |  | ||||||
| 			// 调用项目列表查询 |  | ||||||
| 			this.getProjectList(this.currentyear); |  | ||||||
| 		}, | 		}, | ||||||
|         methods: { |         methods: { | ||||||
| 			// 查询客户详情信息 | 			// 查询客户详情信息 | ||||||
|  | @ -191,58 +182,46 @@ | ||||||
| 					} | 					} | ||||||
| 				}) | 				}) | ||||||
| 			}, | 			}, | ||||||
|  |             getData(){ | ||||||
|  |                  | ||||||
|  |             }, | ||||||
|  |             // 拨打电话 | ||||||
|  |             telFun(){ | ||||||
|  |                 uni.makePhoneCall({ | ||||||
|  |                 	phoneNumber: '13608235524' //仅为示例 | ||||||
|  |                 }); | ||||||
|  |             }, | ||||||
|             // 选择年份 |             // 选择年份 | ||||||
|             bindTimeChange(data) { |             bindTimeChange(data) { | ||||||
| 				let index = data.detail.value; |                       console.log(data.detail.value) | ||||||
| 				this.chooseyear = this.yearArr[index]; |  | ||||||
| 				// 调用项目列表查询 |  | ||||||
| 				this.getProjectList(this.chooseyear); |  | ||||||
|             }, |             }, | ||||||
| 			// 项目列表查询 |  | ||||||
| 			getProjectList(year) { |  | ||||||
| 				this.$requst.post('/universal/api.search/project_year',{year}).then(res=>{ |  | ||||||
| 					if(res.code) { |  | ||||||
| 						this.projectList = res.data; |  | ||||||
| 					} |  | ||||||
| 				}) |  | ||||||
| 			}, |  | ||||||
|             essentialInformation(classText){ |             essentialInformation(classText){ | ||||||
| 				uni.createSelectorQuery().select('.'+classText).boundingClientRect(data=>{//目标位置的节点:类或者id |              | ||||||
| 					uni.createSelectorQuery().select(".arc-content").boundingClientRect(res=>{//最外层盒子的节点:类或者id |               // uni.createSelectorQuery().select('.'+classText).boundingClientRect(data=>{//目标位置的节点:类或者id | ||||||
| 						uni.pageScrollTo({ |               //            uni.createSelectorQuery().select(".arc-content").boundingClientRect(res=>{//最外层盒子的节点:类或者id | ||||||
| 							duration: 100,//过渡时间 |               //                  uni.pageScrollTo({ | ||||||
| 							scrollTop:data.top - res.top -uni.getSystemInfoSync().statusBarHeight-50,//到达距离顶部的top值 |               //                        duration: 100,//过渡时间 | ||||||
| 						}) |               //                        scrollTop:data.top - res.top -uni.getSystemInfoSync().statusBarHeight-40,//到达距离顶部的top值 | ||||||
| 					}).exec() |               //                  }) | ||||||
| 				}).exec();   |               //            }).exec() | ||||||
|  |               //      }).exec();   | ||||||
|             }, |             }, | ||||||
|  |                  | ||||||
|             // 复制微信 |             // 复制微信 | ||||||
|             copyWxFun(){ |             copyWxFun(){ | ||||||
| 				uni.setClipboardData({ |               uni.setClipboardData({ | ||||||
| 					data: 'hello', |               	data: 'hello', | ||||||
| 					success: function () {} |               	success: function () { | ||||||
| 				});   |               		console.log('success'); | ||||||
|             }, |               	} | ||||||
| 			// 拨打电话 |               });   | ||||||
| 			telFun(){ |             } | ||||||
| 			    uni.makePhoneCall({ |           | ||||||
| 			    	phoneNumber: '13608235524' //仅为示例 |  | ||||||
| 			    }); |  | ||||||
| 			} |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style> | <style> | ||||||
| 	 .project-list-box { |  | ||||||
| 		 min-height: 120rpx; |  | ||||||
| 		 max-height: 520rpx; |  | ||||||
| 		 overflow: hidden; |  | ||||||
| 		 overflow-y: scroll; |  | ||||||
| 	 } |  | ||||||
| 	 .project-list-box::-webkit-scrollbar{ |  | ||||||
| 		 display: none; |  | ||||||
| 	 } |  | ||||||
|     .content { |     .content { | ||||||
|         padding-right: 27rpx; |         padding-right: 27rpx; | ||||||
|         padding-left: 27rpx; |         padding-left: 27rpx; | ||||||
|  | @ -349,14 +328,15 @@ | ||||||
|         justify-content: center; |         justify-content: center; | ||||||
|         align-items: center; |         align-items: center; | ||||||
|         border-radius: 10rpx; |         border-radius: 10rpx; | ||||||
|  |         border: 2rpx solid #999999; | ||||||
|         font-size: 24rpx; |         font-size: 24rpx; | ||||||
|         display: flex; |         display: flex; | ||||||
|         align-items: center; |         align-items: center; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     .project-list .title-content .date .icon { |     .project-list .title-content .date .icon { | ||||||
|         /* width: 12rpx; |         width: 12rpx; | ||||||
|         height: 12rpx; */ |         height: 12rpx; | ||||||
|         margin-left: 5rpx; |         margin-left: 5rpx; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -34,9 +34,57 @@ | ||||||
| 					<view class="text">项目概况</view> | 					<view class="text">项目概况</view> | ||||||
| 				</view> | 				</view> | ||||||
| 				<view class="project-message-content"> | 				<view class="project-message-content"> | ||||||
| 					<view class="li" v-for="(item,index) in projectGK" :key="index"> | 					<view class="li"> | ||||||
| 						<view class="title-one">{{item.name}}</view> | 						<view class="title-one">客户名称</view> | ||||||
| 						<view class="text">:{{item.value}}</view> | 						<view class="text">:上海弘焱电子科技有限公司</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title-one">竣工日期</view> | ||||||
|  | 						<view class="text">:2022/2/26</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title-one">质保年限</view> | ||||||
|  | 						<view class="text">:1 年</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title-one">产品品类:</view> | ||||||
|  | 						<view class="text">单色LED屏</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title-one">品牌</view> | ||||||
|  | 						<view class="text">:海康威视</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title-one">维保次数</view> | ||||||
|  | 						<view class="text">:4 次</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title">规格型号</view> | ||||||
|  | 						<view class="text">:DS-CK15FI</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title">尺寸</view> | ||||||
|  | 						<view class="text">:4.57m*2.88m</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title">合同类型:</view> | ||||||
|  | 						<view class="text">制作安装</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title">合同开始</view> | ||||||
|  | 						<view class="text">: 2021/02/26</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title">合同结束</view> | ||||||
|  | 						<view class="text">:2021/02/2</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title">应用场景 </view> | ||||||
|  | 						<view class="text">:会议室</view> | ||||||
|  | 					</view> | ||||||
|  | 					<view class="li"> | ||||||
|  | 						<view class="title">安装位置</view> | ||||||
|  | 						<view class="text">:地下负二层总控电机室</view> | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
| 				<view class="project-message-title"> | 				<view class="project-message-title"> | ||||||
|  | @ -52,19 +100,17 @@ | ||||||
| 						<view class="text">尺寸</view> | 						<view class="text">尺寸</view> | ||||||
| 						<view class="text">数量</view> | 						<view class="text">数量</view> | ||||||
| 					</view> | 					</view> | ||||||
| 					<view class="project-material-box"> | 					<view class="project-materials-text"> | ||||||
| 						<view class="project-materials-text" v-for="(item,index) in project_material" :key="index"> | 						<view class="text">接收卡</view> | ||||||
| 							<view class="text clips2">{{item.name}}</view> | 						<view class="text">卡莱特</view> | ||||||
| 							<view class="text clips2">{{item.brand}}</view> | 						<view class="text">5A-75E</view> | ||||||
| 							<view class="text clips2">{{item.model}}</view> | 						<view class="text">1033876</view> | ||||||
| 							<view class="text clips2">{{item.batch}}</view> | 						<view class="text">*</view> | ||||||
| 							<view class="text clips2">{{item.size}}</view> | 						<view class="text">1台</view> | ||||||
| 							<view class="text clips2">{{item.quantity}}</view> |  | ||||||
| 						</view> |  | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
| 				<view class="record-nav"> | 				<view class="record-nav"> | ||||||
| 					<view class="li" @click="recordNav(index)" :class="item.state?'on':'mo'" | 					<view class="li" @click="recordNav(index)" :class="item.state?'on':''" | ||||||
| 						v-for="(item,index) in recordState"> | 						v-for="(item,index) in recordState"> | ||||||
| 						{{item.title}} | 						{{item.title}} | ||||||
| 					</view> | 					</view> | ||||||
|  | @ -74,8 +120,8 @@ | ||||||
| 					<view class="list"> | 					<view class="list"> | ||||||
| 						<view class="li pad-z40 fon27 col9" :class="index==0 ? 'activeTrack' : ''" v-for="(item,index) in recordList" :key="index"> | 						<view class="li pad-z40 fon27 col9" :class="index==0 ? 'activeTrack' : ''" v-for="(item,index) in recordList" :key="index"> | ||||||
| 							<view class="disac fw line-h60"> | 							<view class="disac fw line-h60"> | ||||||
| 								<view class="text">{{item.value}}</view> | 								<view class="text">{{item.time_line}}</view> | ||||||
| 								<view class="date">{{item.time}}</view> | 								<!-- <view class="date">2020-05-15 16:00</view> --> | ||||||
| 							</view> | 							</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<pitera v-if="recordList.length==0" :textStr="nomoreText"></pitera> | 						<pitera v-if="recordList.length==0" :textStr="nomoreText"></pitera> | ||||||
|  | @ -122,8 +168,6 @@ | ||||||
| 				recordList:[],//记录列表 | 				recordList:[],//记录列表 | ||||||
| 				nomoreText:'', | 				nomoreText:'', | ||||||
| 				projectId: "",//项目id | 				projectId: "",//项目id | ||||||
| 				projectGK:[],//项目概况 |  | ||||||
| 				project_material:[]//项目材料 |  | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
| 		onLoad(op) { | 		onLoad(op) { | ||||||
|  | @ -144,6 +188,11 @@ | ||||||
| 				} | 				} | ||||||
| 				this.$requst.get('/universal/api.project/recording',params).then(res=>{ | 				this.$requst.get('/universal/api.project/recording',params).then(res=>{ | ||||||
| 					if(res.code) { | 					if(res.code) { | ||||||
|  | 						/** | ||||||
|  | 						 * { | ||||||
|  | 						 * 	 time_line:'' | ||||||
|  | 						 * } | ||||||
|  | 						 */ | ||||||
| 						this.recordList = res.data.data; | 						this.recordList = res.data.data; | ||||||
| 					} else { | 					} else { | ||||||
| 						this.nomoreText = res.msg; | 						this.nomoreText = res.msg; | ||||||
|  | @ -160,8 +209,6 @@ | ||||||
| 					if (res.code) { | 					if (res.code) { | ||||||
| 						this.projectObj = res.data; | 						this.projectObj = res.data; | ||||||
| 						this.imgNum = this.projectObj.completed_img.length; | 						this.imgNum = this.projectObj.completed_img.length; | ||||||
| 						this.projectGK = this.projectObj.project_overview_min;//项目概况 |  | ||||||
| 						this.project_material = this.projectObj.project_material;//项目材料 |  | ||||||
| 					} else { | 					} else { | ||||||
| 			 | 			 | ||||||
| 					} | 					} | ||||||
|  | @ -185,14 +232,12 @@ | ||||||
| 	page { | 	page { | ||||||
| 		background-color: #F7F7F7; | 		background-color: #F7F7F7; | ||||||
| 	} | 	} | ||||||
| 	.project-material-box { | 
 | ||||||
| 		max-height: 520rpx; | 	.content { | ||||||
| 		overflow: hidden; | 		padding: 16rpx 0; | ||||||
| 		overflow-y: scroll; | 
 | ||||||
| 	} |  | ||||||
| 	.project-material-box::-webkit-scrollbar{ |  | ||||||
| 		display: none; |  | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	.swiper { | 	.swiper { | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		height: 500rpx; | 		height: 500rpx; | ||||||
|  | @ -259,16 +304,16 @@ | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.last-date { | 	.last-date { | ||||||
| 		/* width: 100%; */ | 		width: 100%; | ||||||
| 		padding: 10rpx 13rpx 10rpx; | 		padding: 10rpx 13rpx 10rpx; | ||||||
| 		box-shadow: 0rpx 5rpx 3rpx rgba(0, 0, 0, 0.1); | 		box-shadow: 0rpx 5rpx 3rpx rgba(0, 0, 0, 0.1); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.last-date-content { | 	.last-date-content { | ||||||
| 		/* width: 100%; */ | 		width: 100%; | ||||||
| 		height: 57rpx; | 		height: 57rpx; | ||||||
| 		display: flex; | 		display: flex; | ||||||
| 		padding: 0 20rpx; | 		padding-left: 20rpx; | ||||||
| 		align-items: center; | 		align-items: center; | ||||||
| 		border-radius: 10rpx; | 		border-radius: 10rpx; | ||||||
| 		background: linear-gradient(to right, #FFEBEB, #F7F7F7); | 		background: linear-gradient(to right, #FFEBEB, #F7F7F7); | ||||||
|  | @ -350,7 +395,7 @@ | ||||||
| 		margin-top: 10rpx; | 		margin-top: 10rpx; | ||||||
| 		background-color: #FFFFFF; | 		background-color: #FFFFFF; | ||||||
| 		justify-content: space-between; | 		justify-content: space-between; | ||||||
| 		border-bottom: 4rpx solid #D5D4D4; | 		border-bottom: 2rpx solid #D5D4D4; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.record-nav .li { | 	.record-nav .li { | ||||||
|  | @ -362,27 +407,17 @@ | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.record-nav .on { | 	.record-nav .on { | ||||||
| 		color: #00B1FF; | 		color: #00b1ff; | ||||||
| 	} | 	} | ||||||
| 	.record-nav .mo { | 
 | ||||||
| 		color: #000000; | 	.record-nav .on::after { | ||||||
| 	} |  | ||||||
| 	.record-nav .on::after,.record-nav .mo::after { |  | ||||||
| 		content: ""; | 		content: ""; | ||||||
| 		display: block; |  | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		height: 4rpx; | 		height: 2rpx; | ||||||
| 		position: absolute; | 		position: absolute; | ||||||
| 		/* #ifdef APP-PLUS || MP-WEIXIN */ |  | ||||||
| 		top: 68rpx; |  | ||||||
| 		/* #endif */ |  | ||||||
| 		/* #ifdef H5 */ |  | ||||||
| 		top: 65rpx; |  | ||||||
| 		/* #endif */ |  | ||||||
| 		left: 0rpx; |  | ||||||
| 	} |  | ||||||
| 	.record-nav .on::after{ |  | ||||||
| 		background-color: #00B1FF; | 		background-color: #00B1FF; | ||||||
|  | 		top: 65rpx; | ||||||
|  | 		left: 0rpx; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.record-content { | 	.record-content { | ||||||
|  |  | ||||||
|  | @ -11,23 +11,24 @@ | ||||||
| 				</view> | 				</view> | ||||||
| 				<view class="settlement-type"> | 				<view class="settlement-type"> | ||||||
| 					<view class="settlement-type-title">结算类型</view> | 					<view class="settlement-type-title">结算类型</view> | ||||||
|  | 
 | ||||||
| 					<view class="settlement-type-content"> | 					<view class="settlement-type-content"> | ||||||
| 						<view class="li liB"> | 						<view class="li liB"> | ||||||
| 							<view class="text">{{settlementType[0].title}}</view> | 							<view class="text">单次收费</view> | ||||||
| 							<view class="num">{{settlementType[0].num}}</view> | 							<view class="num">20</view> | ||||||
| 						</view> | 						</view> | ||||||
| 
 | 
 | ||||||
| 						<view class="li liC"> | 						<view class="li liC"> | ||||||
| 							<view class="text">{{settlementType[2].title}}</view> | 							<view class="text">验收扫尾</view> | ||||||
| 							<view class="num">{{settlementType[2].num}}</view> | 							<view class="num">3</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<view class="li liD"> | 						<view class="li liD"> | ||||||
| 							<view class="text">{{settlementType[1].title}}</view> | 							<view class="text">质保免费</view> | ||||||
| 							<view class="num">{{settlementType[1].num}}</view> | 							<view class="num">46</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<view class="li"> | 						<view class="li"> | ||||||
| 							<view class="text">{{settlementType[3].title}}</view> | 							<view class="text">包年签单</view> | ||||||
| 							<view class="num">{{settlementType[3].num}}</view> | 							<view class="num">10</view> | ||||||
| 						</view> | 						</view> | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
|  | @ -40,16 +41,59 @@ | ||||||
| 				<view class="brand-analysis"> | 				<view class="brand-analysis"> | ||||||
| 					<view class="settlement-type-title">品牌分析</view> | 					<view class="settlement-type-title">品牌分析</view> | ||||||
| 					<view class="brand-analysis-box"> | 					<view class="brand-analysis-box"> | ||||||
| 						<view class="li" v-for="(item,index) in brandAnalysis" :key="index"> | 						<view class="li"> | ||||||
| 							<view class="serial-number">{{item.id}}</view> | 							<view class="serial-number">1</view> | ||||||
| 							<view class="brand-analysis-center"> | 							<view class="brand-analysis-center"> | ||||||
| 								<view class="title-box"> | 								<view class="title-box"> | ||||||
| 									<view class="title">{{item.name}}</view> | 									<view class="title">海康威视</view> | ||||||
| 									<view class="cor" v-if="item.project_count">{{item.project_count}}</view> | 									<view class="cor">10</view> | ||||||
| 									<view class="cor1">{{item.proportion}}%</view> | 									<view class="cor1">23.3%</view> | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="percentage"> | 								<view class="percentage"> | ||||||
| 									<view class="percentage-box" :class="index%2!=0 ? 'percentage-box-ber' : ''" :style="{width:getPercentage(item.proportion,100)}"></view> | 									<view class="percentage-box" :style="{width:getPercentage(33,900)}"></view> | ||||||
|  | 								</view> | ||||||
|  | 							</view> | ||||||
|  | 							<image class="icon" src="../../static/iocn/xl.png" mode=""></image> | ||||||
|  | 						</view> | ||||||
|  | 						<view class="li"> | ||||||
|  | 							<view class="serial-number">2</view> | ||||||
|  | 							<view class="brand-analysis-center"> | ||||||
|  | 								<view class="title-box"> | ||||||
|  | 									<view class="title">海康威视</view> | ||||||
|  | 									<view class="cor">10</view> | ||||||
|  | 									<view class="cor1">23.3%</view> | ||||||
|  | 								</view> | ||||||
|  | 								<view class="percentage"> | ||||||
|  | 									<view class="percentage-box" :style="{width:getPercentage(33,900)}"></view> | ||||||
|  | 								</view> | ||||||
|  | 							</view> | ||||||
|  | 							<image class="icon" src="../../static/iocn/xl.png" mode=""></image> | ||||||
|  | 						</view> | ||||||
|  | 						<view class="li"> | ||||||
|  | 							<view class="serial-number">3</view> | ||||||
|  | 							<view class="brand-analysis-center"> | ||||||
|  | 								<view class="title-box"> | ||||||
|  | 									<view class="title">海康威视</view> | ||||||
|  | 									<view class="cor">10</view> | ||||||
|  | 									<view class="cor1">23.3%</view> | ||||||
|  | 								</view> | ||||||
|  | 								<view class="percentage"> | ||||||
|  | 									<view class="percentage-box" :style="{width:getPercentage(33,100)}"></view> | ||||||
|  | 								</view> | ||||||
|  | 							</view> | ||||||
|  | 							<image class="icon" src="../../static/iocn/xl.png" mode=""></image> | ||||||
|  | 						</view> | ||||||
|  | 						<view class="li"> | ||||||
|  | 							<view class="serial-number">4</view> | ||||||
|  | 							<view class="brand-analysis-center"> | ||||||
|  | 								<view class="title-box"> | ||||||
|  | 									<view class="title">海康威视</view> | ||||||
|  | 									<view class="cor">10</view> | ||||||
|  | 									<view class="cor1">23.3%</view> | ||||||
|  | 								</view> | ||||||
|  | 								<view class="percentage"> | ||||||
|  | 									<view class="percentage-box percentage-box-ber" | ||||||
|  | 										:style="{width:getPercentage(33,80)}"></view> | ||||||
| 								</view> | 								</view> | ||||||
| 							</view> | 							</view> | ||||||
| 							<image class="icon" src="../../static/iocn/xl.png" mode=""></image> | 							<image class="icon" src="../../static/iocn/xl.png" mode=""></image> | ||||||
|  | @ -91,86 +135,53 @@ | ||||||
| 						title: "本月", | 						title: "本月", | ||||||
| 					}, | 					}, | ||||||
| 				], | 				], | ||||||
| 				// 结算类型 | 
 | ||||||
| 				settlementType: [ | 
 | ||||||
| 					{title:'单次收费',num:0}, |  | ||||||
| 					{title:'验收扫尾',num:0}, |  | ||||||
| 					{title:'质保免费',num:0}, |  | ||||||
| 					{title:'包年签单',num:0}, |  | ||||||
| 				], |  | ||||||
| 				// 维保类型 |  | ||||||
| 				chartData: { | 				chartData: { | ||||||
| 					series: [{ | 					series: [{ | ||||||
| 						format: "tooltipDemo1", | 						format: "tooltipDemo1", | ||||||
| 						data: [] | 						data: [{ | ||||||
|  | 								name: "网络故障", | ||||||
|  | 								value: 50, | ||||||
|  | 								style: "straight", | ||||||
|  | 								color: "#7F90A4" | ||||||
|  | 							}, | ||||||
|  | 							{ | ||||||
|  | 								name: "模组故障", | ||||||
|  | 								value: 30, | ||||||
|  | 								style: "straight", | ||||||
|  | 								color: "#67E0FF", | ||||||
|  | 								style: "straight", | ||||||
|  | 							}, | ||||||
|  | 							{ | ||||||
|  | 								name: "网络错误", | ||||||
|  | 								value: 20, | ||||||
|  | 								style: "straight", | ||||||
|  | 								color: "#2D8DFE" | ||||||
|  | 							}, | ||||||
|  | 							{ | ||||||
|  | 								name: "信息错误", | ||||||
|  | 								value: 18, | ||||||
|  | 								color: "#44D2C1", | ||||||
|  | 								style: "straight", | ||||||
|  | 							}, | ||||||
|  | 							{ | ||||||
|  | 								name: "供电不足", | ||||||
|  | 								value: 8, | ||||||
|  | 								style: "straight", | ||||||
|  | 								color: "#F47936" | ||||||
|  | 							} | ||||||
|  | 						] | ||||||
| 					}] | 					}] | ||||||
| 				}, | 				}, | ||||||
| 				// 品牌分析 |  | ||||||
| 				brandAnalysis:[], |  | ||||||
| 				timestr:'all' |  | ||||||
| 				 |  | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
| 		onLoad() { | 		onLoad() { | ||||||
| 			// console.log(this.getPercentage(33, 66)) | 			console.log(this.getPercentage(33, 66)) | ||||||
| 			this.checkTJ(); |  | ||||||
| 		}, | 		}, | ||||||
| 		methods: { | 		methods: { | ||||||
| 			// 查询维保统计 |  | ||||||
| 			checkTJ() { |  | ||||||
| 				this.$requst.get('/universal/api.statistics/statistics_fault',{time:this.timestr}).then(res=>{ |  | ||||||
| 					if(res.code) { |  | ||||||
| 						this.settlementType = []; |  | ||||||
| 						// 结算类型 |  | ||||||
| 						for (let key in res.data.settlement_type) { |  | ||||||
| 							let obj = { |  | ||||||
| 								title: key, |  | ||||||
| 								num: res.data.settlement_type[key], |  | ||||||
| 							} |  | ||||||
| 							this.settlementType.push(obj) |  | ||||||
| 						} |  | ||||||
| 						// 维保类型 |  | ||||||
| 						let fault_type = []; |  | ||||||
| 						for (let key in res.data.fault_type) { |  | ||||||
| 							let obj = { |  | ||||||
| 								name: key, |  | ||||||
| 								value: parseFloat(res.data.fault_type[key]), |  | ||||||
| 								style: "straight", |  | ||||||
| 								color: "" |  | ||||||
| 							} |  | ||||||
| 							fault_type.push(obj) |  | ||||||
| 						} |  | ||||||
| 						this.chartData.series[0].data = fault_type; |  | ||||||
| 						this.chartData.series[0].data[0].color = '#56ddff'; |  | ||||||
| 						this.chartData.series[0].data[1].color = '#2d8dfe'; |  | ||||||
| 						this.chartData.series[0].data[2].color = '#7f90a4'; |  | ||||||
| 						this.chartData.series[0].data[3].color = '#44d2c1'; |  | ||||||
| 						this.chartData.series[0].data[4].color = '#2d8dfe'; |  | ||||||
| 						// 品牌分析 |  | ||||||
| 						this.brandAnalysis = res.data.brand_analyze; |  | ||||||
| 					} |  | ||||||
| 				}) |  | ||||||
| 			}, |  | ||||||
| 			navlistIndexFun(index) { | 			navlistIndexFun(index) { | ||||||
| 				this.navlistIndex = index; | 				this.navlistIndex = index | ||||||
| 				switch (index){ |  | ||||||
| 					case 0: |  | ||||||
| 					this.timestr = 'all'; |  | ||||||
| 						break; |  | ||||||
| 					case 1: |  | ||||||
| 					this.timestr = 'all'; |  | ||||||
| 						break; |  | ||||||
| 					case 2: |  | ||||||
| 					this.timestr = 'yesterday'; |  | ||||||
| 						break; |  | ||||||
| 					case 3: |  | ||||||
| 					this.timestr = 'week'; |  | ||||||
| 						break; |  | ||||||
| 					case 4: |  | ||||||
| 					this.timestr = 'month'; |  | ||||||
| 						break; |  | ||||||
| 				} |  | ||||||
| 				this.checkTJ(); |  | ||||||
| 			}, | 			}, | ||||||
| 			getPercentage(num, max) { | 			getPercentage(num, max) { | ||||||
| 				return Math.ceil(((num - 0) / (max - 0)) * 100) + "%" | 				return Math.ceil(((num - 0) / (max - 0)) * 100) + "%" | ||||||
|  |  | ||||||
|  | @ -4,164 +4,313 @@ | ||||||
| 		<container-subgroup-two> | 		<container-subgroup-two> | ||||||
| 			<view slot="content" style="margin: 0 -30rpx;"> | 			<view slot="content" style="margin: 0 -30rpx;"> | ||||||
| 				<view class="project-overview"> | 				<view class="project-overview"> | ||||||
| 					<view class="settlement-type-title">项目概况</view> | 					<view class="settlement-type-title"> | ||||||
|  | 						项目概况 | ||||||
|  | 					</view> | ||||||
| 					<view class="project-gross"> | 					<view class="project-gross"> | ||||||
| 						<view class="project-gross-title">累计总项目量</view> | 						<view class="project-gross-title"> | ||||||
| 						<view class="project-gross-num"> | 							累计总项目量 | ||||||
| 							<view class="li">0</view> |  | ||||||
| 							<view class="li">2</view> |  | ||||||
| 							<view class="li">9</view> |  | ||||||
| 							<view class="li">8</view> |  | ||||||
| 							<view class="li">5</view> |  | ||||||
| 						</view> | 						</view> | ||||||
|  | 						<view class="project-gross-num"> | ||||||
|  | 							<view class="li"> | ||||||
|  | 								0 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="li"> | ||||||
|  | 								2 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="li"> | ||||||
|  | 								9 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="li"> | ||||||
|  | 								8 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="li"> | ||||||
|  | 								5 | ||||||
|  | 							</view> | ||||||
|  | 						</view> | ||||||
|  | 
 | ||||||
| 						<view class="project-gross-box"> | 						<view class="project-gross-box"> | ||||||
| 							<view class="li"> | 							<view class="li"> | ||||||
| 								<view class="date">今日</view> | 								<view class="date"> | ||||||
|  | 									今日 | ||||||
|  | 								</view> | ||||||
|  | 
 | ||||||
| 								<view class="date-con"> | 								<view class="date-con"> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">新增项目量</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											新增项目量 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">新增工单量</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											新增工单量 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">项目维保率</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											项目维保率 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 							</view> | 							</view> | ||||||
|  | 
 | ||||||
| 							<view class="li"> | 							<view class="li"> | ||||||
| 								<view class="date">本周</view> | 								<view class="date"> | ||||||
|  | 									本周 | ||||||
|  | 								</view> | ||||||
|  | 
 | ||||||
| 								<view class="date-con"> | 								<view class="date-con"> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">新增项目量</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											新增项目量 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">新增工单量</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											新增工单量 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">项目维保率</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											项目维保率 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 							</view> | 							</view> | ||||||
|  | 
 | ||||||
| 							<view class="li"> | 							<view class="li"> | ||||||
| 								<view class="date">本月</view> | 								<view class="date"> | ||||||
|  | 									本月 | ||||||
|  | 								</view> | ||||||
|  | 
 | ||||||
| 								<view class="date-con"> | 								<view class="date-con"> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">新增项目量</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											新增项目量 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">新增工单量</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											新增工单量 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 									<view class="date-con-li"> | 									<view class="date-con-li"> | ||||||
| 										<view class="text">项目维保率</view> | 										<view class="text"> | ||||||
| 										<view class="single-amount">0单</view> | 											项目维保率 | ||||||
|  | 										</view> | ||||||
|  | 										<view class="single-amount"> | ||||||
|  | 											0单 | ||||||
|  | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 							</view> | 							</view> | ||||||
|  | 
 | ||||||
| 						</view> | 						</view> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
|  | 
 | ||||||
| 				<view class="data-icon"> | 				<view class="data-icon"> | ||||||
| 					<view class="settlement-type-title">年度项目数据明细</view> | 					<view class="settlement-type-title"> | ||||||
|  | 						年度项目数据明细 | ||||||
|  | 					</view> | ||||||
| 					<view class=""> | 					<view class=""> | ||||||
| 						<view class="charts-box"> | 						<view class="charts-box"> | ||||||
| 							<qiun-data-charts type="mix" :chartData="chartData" background="none" /> | 							<qiun-data-charts type="mix" :chartData="chartData" background="none" /> | ||||||
| 						</view> | 						</view> | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 				<view class="serve-data"> | 				<view class="serve-data"> | ||||||
| 					<view class="settlement-type-title">服务数据</view> | 					<view class="settlement-type-title"> | ||||||
|  | 						服务数据 | ||||||
|  | 					</view> | ||||||
| 					<view class="serve-data-box"> | 					<view class="serve-data-box"> | ||||||
| 						<view class="serve-data-left"> | 						<view class="serve-data-left"> | ||||||
| 							<view class="title">本月服务量</view> | 							<view class="title"> | ||||||
|  | 								本月服务量 | ||||||
|  | 							</view> | ||||||
| 							<view class="text-con"> | 							<view class="text-con"> | ||||||
| 								<view class="li"> | 								<view class="li"> | ||||||
| 									<view class="text">维保工单:</view> | 									<view class="text"> | ||||||
| 									<view class="num">3</view> | 										维保工单: | ||||||
|  | 									</view> | ||||||
|  | 									<view class="num"> | ||||||
|  | 										3 | ||||||
|  | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="li"> | 								<view class="li"> | ||||||
| 									<view class="text">巡检服务单:</view> | 									<view class="text"> | ||||||
| 									<view class="num">65465</view> | 										巡检服务单: | ||||||
|  | 									</view> | ||||||
|  | 									<view class="num"> | ||||||
|  | 										65465 | ||||||
|  | 									</view> | ||||||
|  | 
 | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="li"> | 								<view class="li"> | ||||||
| 									<view class="text">移屏服务单:</view> | 									<view class="text"> | ||||||
| 									<view class="num">32132</view> | 										移屏服务单: | ||||||
|  | 									</view> | ||||||
|  | 									<view class="num"> | ||||||
|  | 										32132 | ||||||
|  | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="li"> | 								<view class="li"> | ||||||
| 									<view class="text">拆屏工单:</view> | 									<view class="text"> | ||||||
| 									<view class="num">32132</view> | 										拆屏工单: | ||||||
|  | 									</view> | ||||||
|  | 									<view class="num"> | ||||||
|  | 										32132 | ||||||
|  | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 							</view> | 							</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<view class="serve-data-left"> | 						<view class="serve-data-left"> | ||||||
| 							<view class="title">累计服务量</view> | 							<view class="title"> | ||||||
|  | 								累计服务量 | ||||||
|  | 							</view> | ||||||
| 							<view class="text-con"> | 							<view class="text-con"> | ||||||
| 								<view class="li"> | 								<view class="li"> | ||||||
| 									<view class="text">维保工单:</view> | 									<view class="text"> | ||||||
| 									<view class="num">3</view> | 										维保工单: | ||||||
|  | 									</view> | ||||||
|  | 									<view class="num"> | ||||||
|  | 										3 | ||||||
|  | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="li"> | 								<view class="li"> | ||||||
| 									<view class="text">巡检服务单:</view> | 									<view class="text"> | ||||||
| 									<view class="num">65465</view> | 										巡检服务单: | ||||||
|  | 									</view> | ||||||
|  | 									<view class="num"> | ||||||
|  | 										65465 | ||||||
|  | 									</view> | ||||||
|  | 
 | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="li"> | 								<view class="li"> | ||||||
| 									<view class="text">移屏服务单:</view> | 									<view class="text"> | ||||||
| 									<view class="num">32132</view> | 										移屏服务单: | ||||||
|  | 									</view> | ||||||
|  | 									<view class="num"> | ||||||
|  | 										32132 | ||||||
|  | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="li"> | 								<view class="li"> | ||||||
| 									<view class="text">拆屏工单:</view> | 									<view class="text"> | ||||||
| 									<view class="num">32132</view> | 										拆屏工单: | ||||||
|  | 									</view> | ||||||
|  | 									<view class="num"> | ||||||
|  | 										32132 | ||||||
|  | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 							</view> | 							</view> | ||||||
| 						</view> | 						</view> | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
|  | 
 | ||||||
| 				<view class="data-icon"> | 				<view class="data-icon"> | ||||||
| 					<view class="settlement-type-title">年度服务数据汇总</view> | 					<view class="settlement-type-title"> | ||||||
|  | 						年度服务数据汇总 | ||||||
|  | 					</view> | ||||||
| 					<view class=""> | 					<view class=""> | ||||||
| 						<view class="charts-box"> | 						<view class="charts-box"> | ||||||
| 							<qiun-data-charts type="mix" :chartData="chartDataA" background="none" /> | 							<qiun-data-charts type="mix" :chartData="chartDataA" background="none" /> | ||||||
| 						</view> | 						</view> | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
|  | 
 | ||||||
| 				<view class="expire-project"> | 				<view class="expire-project"> | ||||||
| 					<view class="settlement-type-title settlement-type-titlea">质保即将到期项目</view> | 					<view class="settlement-type-title settlement-type-titlea"> | ||||||
|  | 						质保即将到期项目 | ||||||
|  | 					</view> | ||||||
|  | 
 | ||||||
| 					<view class="expire-project-box"> | 					<view class="expire-project-box"> | ||||||
| 						<view class="li-title li"> | 						<view class="li-title li"> | ||||||
| 							<view class="name">项目名称</view> | 							<view class="name"> | ||||||
| 							<view class="work-order">工单</view> | 								项目名称 | ||||||
| 							<view class="date">日期</view> | 							</view> | ||||||
|  | 							<view class="work-order"> | ||||||
|  | 								工单 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="date"> | ||||||
|  | 								日期 | ||||||
|  | 							</view> | ||||||
|  | 						</view> | ||||||
|  | 
 | ||||||
|  | 						<view class="li-text li"> | ||||||
|  | 							<view class="name"> | ||||||
|  | 								1.五岭新天地二期停车场xxxxxxxxxxxxx | ||||||
|  | 							</view> | ||||||
|  | 							<view class="work-order"> | ||||||
|  | 								6 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="date"> | ||||||
|  | 								22/2/24 | ||||||
|  | 							</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<view class="li-text li"> | 						<view class="li-text li"> | ||||||
| 							<view class="name">1.五岭新天地二期停车场xxxxxxxxxxxxx</view> | 							<view class="name"> | ||||||
| 							<view class="work-order">6</view> | 								1.五岭新天地二期停车场xxxxxxxxxxxxx | ||||||
| 							<view class="date">22/2/24</view> | 							</view> | ||||||
|  | 							<view class="work-order"> | ||||||
|  | 								6 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="date"> | ||||||
|  | 								22/2/24 | ||||||
|  | 							</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<view class="li-text li"> | 						<view class="li-text li"> | ||||||
| 							<view class="name">1.五岭新天地二期停车场xxxxxxxxxxxxx</view> | 							<view class="name"> | ||||||
| 							<view class="work-order">6</view> | 								1.五岭新天地二期停车场xxxxxxxxxxxxx | ||||||
| 							<view class="date">22/2/24</view> | 							</view> | ||||||
|  | 							<view class="work-order"> | ||||||
|  | 								6 | ||||||
|  | 							</view> | ||||||
|  | 							<view class="date"> | ||||||
|  | 								22/2/24 | ||||||
|  | 							</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<view class="li-text li"> | 						<view class="li-text li"> | ||||||
| 							<view class="name">1.五岭新天地二期停车场xxxxxxxxxxxxx</view> | 							<view class="name"> | ||||||
| 							<view class="work-order">6</view> | 								1.五岭新天地二期停车场xxxxxxxxxxxxx | ||||||
| 							<view class="date">22/2/24</view> | 							</view> | ||||||
| 						</view> | 							<view class="work-order"> | ||||||
| 						<view class="li-text li"> | 								6 | ||||||
| 							<view class="name">1.五岭新天地二期停车场xxxxxxxxxxxxx</view> | 							</view> | ||||||
| 							<view class="work-order">6</view> | 							<view class="date"> | ||||||
| 							<view class="date">22/2/24</view> | 								22/2/24 | ||||||
|  | 							</view> | ||||||
| 						</view> | 						</view> | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
|  | 
 | ||||||
| 			</view> | 			</view> | ||||||
| 		</container-subgroup-two> | 		</container-subgroup-two> | ||||||
| 	</view> | 	</view> | ||||||
|  | @ -178,70 +327,73 @@ | ||||||
| 		data() { | 		data() { | ||||||
| 			return { | 			return { | ||||||
| 				chartDataA: { | 				chartDataA: { | ||||||
| 					categories: ["1月","2月","3月","4月","5月","6月"], | 					categories: [ | ||||||
|  | 						"1月", | ||||||
|  | 						"2月", | ||||||
|  | 						"3月", | ||||||
|  | 						"4月", | ||||||
|  | 						"5月", | ||||||
|  | 						"6月" | ||||||
|  | 					], | ||||||
| 					series: [ | 					series: [ | ||||||
| 						{ | 						{ | ||||||
| 							name: "", | 							name: "", | ||||||
| 							index: 1, | 							index: 1, | ||||||
| 							data: [40,30,55,110,24,58], | 							data: [40,30,55,110,24,58], | ||||||
| 							type: "column", | 							type: "column", | ||||||
| 							"color": "#308de1" | 							color: "#308de1" | ||||||
| 						}, | 						}, | ||||||
| 						{ | 						{ | ||||||
| 							"name": "", | 							name: "", | ||||||
| 							"data": [40,30,55,110,24,58], | 							data: [40,30,55,110,24,58], | ||||||
| 							"type": "line", | 							type: "line", | ||||||
| 							"color": "#308de1" | 							color: "#308de1" | ||||||
| 						}, | 						}, | ||||||
| 						{ | 						{ | ||||||
| 							"name": "", | 							name: "", | ||||||
| 							"index": 2, | 							index: 2, | ||||||
| 							"data": [40,30,55,110,24,58], | 							data: [40,30,55,110,24,58], | ||||||
| 							"type": "point", | 							type: "point", | ||||||
| 							"color": "#308de1" | 							color: "#308de1" | ||||||
| 						} | 						} | ||||||
| 
 |  | ||||||
| 					] | 					] | ||||||
| 				}, | 				}, | ||||||
| 				chartData: { | 				chartData: { | ||||||
| 					categories: ["1月","2月","3月","4月","5月","6月"], | 					categories: [ | ||||||
|  | 						"1月", | ||||||
|  | 						"2月", | ||||||
|  | 						"3月", | ||||||
|  | 						"4月", | ||||||
|  | 						"5月", | ||||||
|  | 						"6月" | ||||||
|  | 					], | ||||||
| 					series: [ | 					series: [ | ||||||
| 						{ | 						{ | ||||||
| 							name: "", | 							name: "", | ||||||
| 							index: 1, | 							index: 1, | ||||||
| 							data: [40,30,55,110,24,58], | 							data: [40,30,55,110,24,58], | ||||||
| 							type: "column", | 							type: "column", | ||||||
| 							"color": "#fe4141" | 							color: "#fe4141", | ||||||
| 						}, | 						}, | ||||||
| 						{ | 						{ | ||||||
| 							"name": "", | 							name: "", | ||||||
| 							"data": [40,30,55,110,24,58], | 							data: [40,30,55,110,24,58], | ||||||
| 							"type": "line", | 							type: "line", | ||||||
| 							"color": "#fe4141" | 							color: "#fe4141", | ||||||
| 						}, | 						}, | ||||||
| 						{ | 						{ | ||||||
| 							"name": "", | 							name: "", | ||||||
| 							"index": 2, | 							index: 2, | ||||||
| 							"data": [40,30,55,110,24,58], | 							data: [40,30,55,110,24,58], | ||||||
| 							"type": "point", | 							type: "point", | ||||||
| 							"color": "#fe4141" | 							color: "#fe4141", | ||||||
| 						} | 						} | ||||||
| 					] | 					] | ||||||
| 				}, | 				}, | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
| 		onLoad() { |  | ||||||
| 			this.checkSJ(); |  | ||||||
| 		}, |  | ||||||
| 		methods: { | 		methods: { | ||||||
| 			// 查询数据看板数据 | 
 | ||||||
| 			checkSJ() { |  | ||||||
| 				this.$requst.get('/universal/api.statistics/data_kanban').then(res=>{ |  | ||||||
| 					if(res.code) { |  | ||||||
| 						 |  | ||||||
| 					} |  | ||||||
| 				}) |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|  | @ -4,56 +4,53 @@ | ||||||
| 		<container-subgroup-two> | 		<container-subgroup-two> | ||||||
| 			<view slot="content" style="margin: -30rpx;"> | 			<view slot="content" style="margin: -30rpx;"> | ||||||
| 				<view class="peopleManagement-input"> | 				<view class="peopleManagement-input"> | ||||||
| 					<input type="text" class="int" @confirm="callEv" v-model="keyword" placeholder="请输入关键字" placeholder-style="color:#999999;" /> | 					<input type="text" class="int" value="" placeholder="请输入关键字" placeholder-style="color:#999999;" /> | ||||||
| 					<image class="search" @tap="callEv" src="../../static/iocn/ss.png" mode=""></image> | 					<image class="search" src="../../static/iocn/ss.png" mode=""></image> | ||||||
| 					<view class="xian"></view> | 					<view class="xian"></view> | ||||||
| 				</view> | 				</view> | ||||||
| 				<view class="peopleManagement-content pad-x50"> | 				<view class="peopleManagement-content"> | ||||||
| 					<view class="li" v-for="(item,index) in dataList"> | 					<view class="li" v-for="(item,index) in dataList"> | ||||||
| 						<view class="head"> | 						<view class="head"> | ||||||
| 							<view class="name" @click="listStateFun(item)"> | 							<view class="name" @click="listStateFun(item)"> | ||||||
| 								<!-- 选中 --> | 								<view class="icon" v-if="item.state"></view> | ||||||
| 								<view class="icon" v-if="!item.state"></view> |  | ||||||
| 								<!-- 未选中 --> |  | ||||||
| 								<image class="iconImg" v-else src="../../static/iocn/pxz.png" mode=""></image> | 								<image class="iconImg" v-else src="../../static/iocn/pxz.png" mode=""></image> | ||||||
| 								<view class=""> | 								<view class=""> | ||||||
| 									{{item.name}}<text :class="item.isJob ? 'cor' : 'cor1'">({{item.isJob ? '正在作业' : '空闲中'}})</text> | 									{{item.title}}<text class="cor" v-if="item.isJob">(正在作业)</text> | ||||||
|  | 									<text class="cor1" v-else>(空闲中)</text> | ||||||
| 								</view> | 								</view> | ||||||
| 							</view> | 							</view> | ||||||
| 							<view class="state">已审核</view> | 							<view class="state">已审核</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<view class="con"> | 						<view class="con"> | ||||||
| 							<image class="img" :src="item.imgsrc" mode="aspectFill"></image> | 							<image class="img" src="../../static/del/500478055.png" mode=""></image> | ||||||
| 							<view class="text scal09"> | 							<view class="text scal09"> | ||||||
| 								<view class="code"> | 								<view class="code"> | ||||||
| 									<view class="">编号: {{item.number}}</view> | 									<view class="">编号: YG20211207-001</view> | ||||||
| 									<view class="iconCon"> | 									<view class="iconCon"> | ||||||
| 										<view v-for="(item1,index) in 5"> | 										<view v-for="(item,index) in 5"> | ||||||
| 											<image class="icon" v-if="index < item.rate" src="../../static/iocn/6.png" mode="aspectFill" ></image> | 											<image class="icon" v-if="index<=2" src="../../static/iocn/6.png" ></image> | ||||||
| 											<image class="icon" v-else src="../../static/iocn/7.png" mode="aspectFill" ></image> | 											<image class="icon" v-else src="../../static/iocn/7.png" ></image> | ||||||
| 										</view> | 										</view> | ||||||
| 									</view> | 									</view> | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="p"> | 								<view class="p"> | ||||||
| 									<view class="one">待处理:{{item.num}}单 </view> | 									<view class="one">待处理:1单 </view> | ||||||
| 									<view class="">已处理:{{item.allnum}}单 </view> | 									<view class="">已处理:1305单 </view> | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="address">当前定位:{{item.address}}</view> | 								<view class="address">当前定位:湖南省株洲市xxxxxxxx小区1栋202室</view> | ||||||
| 							</view> | 							</view> | ||||||
| 						</view> | 						</view> | ||||||
| 						<view class="bottom"> | 						<view class="bottom"> | ||||||
| 						  <view class="bottom-content"> | 						  <view class="bottom-content"> | ||||||
| 							  联系电话: <text class="cor3">{{$toolAll.tools.hideMPhone(item.phone,'x')}}</text> | 							  联系电话: <text class="cor3">157xxxx8279</text> | ||||||
| 						  </view>   | 						  </view>   | ||||||
| 						  <view class="bottom-content"> | 						  <view class="bottom-content"> | ||||||
| 							  注册时间: <text class="cor3">{{item.time}}</text> | 							  注册时间: <text class="cor3">2018-12-12</text> | ||||||
| 						  </view> | 						  </view> | ||||||
| 						</view> | 						</view> | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
| 				<pitera v-if="total == dataList.length && dataList.length" textStr="暂无更多人员列表"></pitera> | 				<button class="submit-button" type="default">派发工单</button> | ||||||
| 				<nothing-page v-if="!dataList.length" content="暂无人员状态数据"></nothing-page> |  | ||||||
| 				<button class="submit-button" type="default" :style="{display: tianxuan ? 'flex' : 'none'}">派发工单</button> |  | ||||||
| 			</view> | 			</view> | ||||||
| 		</container-subgroup-two> | 		</container-subgroup-two> | ||||||
|     </view> |     </view> | ||||||
|  | @ -62,92 +59,47 @@ | ||||||
| <script> | <script> | ||||||
|     import statusNav from '../../components/status-nav.vue'; |     import statusNav from '../../components/status-nav.vue'; | ||||||
| 	import containerSubgroupTwo from '@/components/containers/container-subgroup-two.vue'; | 	import containerSubgroupTwo from '@/components/containers/container-subgroup-two.vue'; | ||||||
| 	import pitera from '@/components/nothing/pitera.vue'; |  | ||||||
|     export default { |     export default { | ||||||
|         components: { |         components: { | ||||||
|             statusNav, |             statusNav, | ||||||
| 			containerSubgroupTwo, | 			containerSubgroupTwo | ||||||
| 			pitera |  | ||||||
|         }, |         }, | ||||||
|         data() { |         data() { | ||||||
|             return { |             return { | ||||||
|                 dataList: [ |                 dataList: [{ | ||||||
| 					// {id:'1',name: "陈志远",state: false,isJob: false,imgsrc:'https://s6.jpg.cm/2022/02/14/L4oDhy.jpg',number:'YG20211207-001',rate:5,num:2,allnum:2000,address:'湖南省株洲市xxxxxxxx小区1栋202室',phone:'173xxxx1088',time:'2018-12-12'}, |                         title: "陈志远", | ||||||
| 					// {id:'1',name: "陈志远",state: false,isJob: false,imgsrc:'https://s6.jpg.cm/2022/02/14/L4oDhy.jpg',number:'YG20211207-001',rate:3,num:2,allnum:2000,address:'湖南省株洲市xxxxxxxx小区1栋202室',phone:'173xxxx1088',time:'2018-12-12'}, |                         state: true, | ||||||
| 					// {id:'1',name: "陈志远",state: false,isJob: false,imgsrc:'https://s6.jpg.cm/2022/02/14/L4oDhy.jpg',number:'YG20211207-001',rate:2,num:2,allnum:2000,address:'湖南省株洲市xxxxxxxx小区1栋202室',phone:'173xxxx1088',time:'2018-12-12'}, |                         isJob: true, | ||||||
|                 ], | 
 | ||||||
| 				keyword:'',//关键字 |                     }, | ||||||
| 				page:1, |                     { | ||||||
| 				list_rows:20, |                         title: "瓜皮", | ||||||
| 				total:0, |                         state: false, | ||||||
| 				tianxuan:'' |                         isJob: true, | ||||||
|  |                     }, | ||||||
|  |                     { | ||||||
|  |                         title: "瓜娃子", | ||||||
|  |                         state: true, | ||||||
|  |                         isJob: false, | ||||||
|  |                     }, | ||||||
|  |                     { | ||||||
|  |                         title: "憨批", | ||||||
|  |                         state: true, | ||||||
|  |                         isJob: false, | ||||||
|  |                     }, | ||||||
|  |                 ] | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
| 		onReachBottom() { |  | ||||||
| 			if(this.total!=this.dataList.length) { |  | ||||||
| 				this.page++; |  | ||||||
| 				this.checkList(); |  | ||||||
| 			} |  | ||||||
| 		}, |  | ||||||
| 		onLoad() { |  | ||||||
| 			this.checkList(); |  | ||||||
| 		}, |  | ||||||
|         methods: { |         methods: { | ||||||
| 			// 查询人员状态列表 |      listStateFun(item){ | ||||||
| 			checkList() { |          item.state=!item.state | ||||||
| 				let params = { |      } | ||||||
| 					list_rows:this.list_rows, |  | ||||||
| 					page:this.page, |  | ||||||
| 					keyword:this.keyword |  | ||||||
| 				} |  | ||||||
| 				this.$requst.get('/universal/api.user/user_location',params).then(res=>{ |  | ||||||
| 					if(res.code) { |  | ||||||
| 						this.total = res.data.total; |  | ||||||
| 						if(this.page==1) this.dataList = []; |  | ||||||
| 						if(res.data.data.length) { |  | ||||||
| 							res.data.data.forEach(item=>{ |  | ||||||
| 								let obj = { |  | ||||||
| 									id:1, |  | ||||||
| 									name: item.name, |  | ||||||
| 									imgsrc:'https://s6.jpg.cm/2022/02/14/L4oDhy.jpg', |  | ||||||
| 									number:'YG20211207-001', |  | ||||||
| 									rate:5, |  | ||||||
| 									num:2, |  | ||||||
| 									allnum:2000, |  | ||||||
| 									address:item.address, |  | ||||||
| 									phone:'17366921088', |  | ||||||
| 									time:item.register_time, |  | ||||||
| 									state: false, |  | ||||||
| 									isJob: item.is_working ? true : false, |  | ||||||
| 								} |  | ||||||
| 								this.dataList.push(obj); |  | ||||||
| 							}) |  | ||||||
| 						} |  | ||||||
| 					} |  | ||||||
| 				}) |  | ||||||
| 			}, |  | ||||||
| 			// 调用查询事件 |  | ||||||
| 			callEv() { |  | ||||||
| 				this.page = 1; |  | ||||||
| 				this.checkList(); |  | ||||||
| 			}, |  | ||||||
| 			listStateFun(item){ |  | ||||||
| 				this.dataList.forEach(item1=>{item1.state = false}) |  | ||||||
| 				item.state = !item.state; |  | ||||||
| 				item.state ? this.tianxuan = item.id : ''; |  | ||||||
| 				console.log(this.tianxuan); |  | ||||||
| 			} |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style> | <style> | ||||||
|    .submit-button { |    .submit-button { | ||||||
| 		position: fixed; |  | ||||||
| 		display: none; |  | ||||||
| 		bottom: 30rpx; |  | ||||||
| 		left: 50%; |  | ||||||
| 		transform: translateX(-50%); |  | ||||||
|         width: 686rpx; |         width: 686rpx; | ||||||
|         border-radius: 50rpx; |         border-radius: 50rpx; | ||||||
|         height: 90rpx; |         height: 90rpx; | ||||||
|  | @ -192,6 +144,7 @@ | ||||||
|         top: 50%; |         top: 50%; | ||||||
|         margin-top: -14rpx; |         margin-top: -14rpx; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|     .peopleManagement-content .li { |     .peopleManagement-content .li { | ||||||
|         background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
|         padding-right: 30rpx; |         padding-right: 30rpx; | ||||||
|  | @ -269,8 +222,8 @@ | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     .peopleManagement-content .li .con .text .icon { |     .peopleManagement-content .li .con .text .icon { | ||||||
|         width: 28rpx; |         width: 24rpx; | ||||||
|         height: 26rpx; |         height: 24rpx; | ||||||
| 		margin-left: 10rpx; | 		margin-left: 10rpx; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -34,7 +34,7 @@ | ||||||
| 				<view class="project-list"> | 				<view class="project-list"> | ||||||
| 					<view class="li animated fadeIn" @click="projectDetailsFun(item.project_id)" v-for="(item,index) in dataList.data" :key="index"> | 					<view class="li animated fadeIn" @click="projectDetailsFun(item.project_id)" v-for="(item,index) in dataList.data" :key="index"> | ||||||
| 						<view class="message"> | 						<view class="message"> | ||||||
| 							<image class="img" :src="item.completed_img" mode="aspectFill" lazy-load></image> | 							<image class="img" src="../../static/del/img001.png" mode="aspectFill" lazy-load></image> | ||||||
| 							<view class="text disjb fc" style="height: 180rpx;"> | 							<view class="text disjb fc" style="height: 180rpx;"> | ||||||
| 								<view class="clips1 fon24 bold">{{item.project_name}}</view> | 								<view class="clips1 fon24 bold">{{item.project_name}}</view> | ||||||
| 								<view class="line-h38" style="margin-left: -20rpx;height: 80%;"> | 								<view class="line-h38" style="margin-left: -20rpx;height: 80%;"> | ||||||
|  |  | ||||||
|  | @ -53,166 +53,168 @@ | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| 	import yyMmDdHhSs from '@/components/dates/yy-mm-dd-hh-ss.vue'; |     import yyMmDdHhSs from '@/components/dates/yy-mm-dd-hh-ss.vue'; | ||||||
| 	import { | 	import {getFaultType} from '@/jsFile/public-api.js'; | ||||||
| 		getFaultType,uploadImg |     import { | ||||||
| 	} from '@/jsFile/public-api.js'; |         uploadImg | ||||||
|  |     } from '@/jsFile/public-api.js'; | ||||||
| 	// 引入qrcode.js (必须导出qrcode.js ) | 	// 引入qrcode.js (必须导出qrcode.js ) | ||||||
| 	var qrcode = require('@/jsFile/qrcode.js'); | 	var qrcode = require('@/jsFile/qrcode.js'); | ||||||
| 	// import jweixin from '@/jsFile/index.js'; |     export default { | ||||||
| 	export default { |         components: { | ||||||
| 		components: { |             yyMmDdHhSs | ||||||
| 			yyMmDdHhSs |         }, | ||||||
| 		}, |         data() { | ||||||
| 		data() { |             return { | ||||||
| 			return { |                 single: "2021-04-3", | ||||||
| 				single: "2021-04-3", |                 data: { | ||||||
| 				data: { |                     is_device: 0, | ||||||
| 					is_device: 0, |                     fault_type: "", | ||||||
| 					fault_type: "", |                     device_name: "", | ||||||
| 					device_name: "", |                     project_number: "", | ||||||
| 					project_number: "", |                     service_address: "", | ||||||
| 					service_address: "", |                     username: "", | ||||||
| 					username: "", |                     fault_picture: "", | ||||||
| 					fault_picture: "", |                     fault_describe: "", | ||||||
| 					fault_describe: "", |                     phone: "", | ||||||
| 					phone: "", |                     visit_time: "" | ||||||
| 					visit_time: "" |                 }, | ||||||
| 				}, |                 imgsrcArr: [], | ||||||
| 				imgsrcArr: [], |                 indexType: 0, | ||||||
| 				indexType: 0, |                 navDataState: ["有设备","无设备"], | ||||||
| 				navDataState: ["有设备", "无设备"], | 				current:0, | ||||||
| 				current: 0, |                 faultTypeData: [] | ||||||
| 				faultTypeData: [] |             } | ||||||
| 			} |         }, | ||||||
| 		}, |         onLoad() { | ||||||
| 		onLoad(op) { |             this.getType() | ||||||
| 			this.getType(); |         }, | ||||||
| 			if (op.project_number) this.data.project_number = op.project_number; |  | ||||||
| 		}, |  | ||||||
| 
 | 
 | ||||||
| 		methods: { |         methods: { | ||||||
| 			submitButton() { | 			submitButton() { | ||||||
| 				this.data.fault_type = this.faultTypeData[this.indexType].id | 			    this.data.fault_type = this.faultTypeData[this.indexType].id | ||||||
| 				if (this.current) { | 				if(this.current) { | ||||||
| 					if (!this.data.device_name) { | 					if (!this.data.device_name) { | ||||||
| 						this.$toolAll.tools.showToast("请填写设备名称或型号"); | 					    this.$toolAll.tools.showToast("请填写设备名称或型号"); | ||||||
| 						return | 					    return | ||||||
| 					} | 					} | ||||||
| 				} else { | 				} else { | ||||||
| 					if (!this.data.project_number) { | 					if (!this.data.project_number) { | ||||||
| 						this.$toolAll.tools.showToast("请填写设备编号"); | 					    this.$toolAll.tools.showToast("请填写设备编号"); | ||||||
| 						return | 					    return | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| 				if (!this.data.username) { | 			    if (!this.data.username) { | ||||||
| 					this.$toolAll.tools.showToast("请填写您的姓名"); | 			        this.$toolAll.tools.showToast("请填写您的姓名"); | ||||||
| 					return | 			        return | ||||||
| 				} | 			    } | ||||||
| 				if (this.$toolAll.tools.isPhone(this.data.phone)) { | 			    if (this.$toolAll.tools.isPhone(this.data.phone)) { | ||||||
| 					this.$toolAll.tools.showToast("请正确填写您的电话"); | 			        this.$toolAll.tools.showToast("请正确填写您的电话"); | ||||||
| 					return | 			        return | ||||||
| 				} | 			    } | ||||||
| 				this.data.is_device = this.current ? 0 : 1; //0:表示无设备 1:表示有设备 | 				this.data.is_device = this.current ? 0 : 1;//0:表示无设备 1:表示有设备 | ||||||
| 				this.$requst.post('/universal/api.order/repair', this.data).then(res => { | 			    this.$requst.post('/universal/api.order/repair', this.data).then(res => { | ||||||
| 					if (res.code) { | 			        if (res.code) { | ||||||
| 						this.$toolAll.tools.showToast('提交成功'); | 			            this.$toolAll.tools.showToast('提交成功'); | ||||||
| 						setTimeout(() => { | 						setTimeout(()=>{ | ||||||
| 							uni.navigateBack({ | 							uni.navigateBack({delta:1}) | ||||||
| 								delta: 1 | 						},1000) | ||||||
| 							}) | 			        } else { | ||||||
| 						}, 1000) |  | ||||||
| 					} else { |  | ||||||
| 						this.$toolAll.tools.showToast(res.msg); | 						this.$toolAll.tools.showToast(res.msg); | ||||||
| 					} | 			        } | ||||||
| 				}) | 			    }) | ||||||
| 			}, | 			}, | ||||||
| 			// 获取维保类型 |             // 获取维保类型 | ||||||
| 			getType() { |             getType() { | ||||||
| 				getFaultType().then(res => { |                 getFaultType().then(res=>{ | ||||||
| 					if (res.code) { | 					if (res.code) { | ||||||
| 						this.faultTypeData = [...res.data] | 					    this.faultTypeData = [...res.data] | ||||||
| 					} else { | 					} else { | ||||||
| 
 | 					 | ||||||
| 					} | 					} | ||||||
| 				}) | 				}) | ||||||
| 			}, |             }, | ||||||
| 			openDatetimePicker() { |             openDatetimePicker() { | ||||||
| 				this.$refs.myPicker.show(); |                 this.$refs.myPicker.show(); | ||||||
| 			}, |             }, | ||||||
| 			handleSubmit(e) { |             handleSubmit(e) { | ||||||
| 				this.data.visit_time = `${e.year}-${e.month}-${e.day} ${e.hour}:${e.minute}:00`; |                 this.data.visit_time = `${e.year}-${e.month}-${e.day} ${e.hour}:${e.minute}:00`; | ||||||
| 			}, |             }, | ||||||
| 			// 获取图片 |             // 获取图片 | ||||||
| 			chooseImg() { |             chooseImg() { | ||||||
| 				uni.chooseImage({ |                 uni.chooseImage({ | ||||||
| 					count: 1, |                     count: 1, | ||||||
| 					sourceType: ['album', 'camera'], |                     sourceType: ['album', 'camera'], | ||||||
| 					success: (res) => { |                     success: (res) => { | ||||||
| 						this.imgsrcArr = [] |                         this.imgsrcArr = [] | ||||||
| 						let imgsrc = res.tempFilePaths; |                         let imgsrc = res.tempFilePaths; | ||||||
| 						imgsrc.forEach(item => { |                         imgsrc.forEach(item => { | ||||||
| 							this.imgsrcArr.push(item); |                             this.imgsrcArr.push(item); | ||||||
| 						}) |                         }) | ||||||
| 						uploadImg({ |                         uploadImg({path: res.tempFilePaths[0]}).then(res => { | ||||||
| 							path: res.tempFilePaths[0] |  | ||||||
| 						}).then(res => { |  | ||||||
| 							if (res.code) { | 							if (res.code) { | ||||||
| 								this.$toolAll.tools.showToast('上传成功'); |                                 this.$toolAll.tools.showToast('上传成功'); | ||||||
| 								this.data.fault_picture = res.data.id |                                 this.data.fault_picture = res.data.id | ||||||
| 							} |                             } | ||||||
| 						}) |                         }) | ||||||
| 					}, |                     },fail:(err)=> { | ||||||
| 					fail: (err) => { |  | ||||||
| 						this.$toolAll.tools.checkQx(err.code); | 						this.$toolAll.tools.checkQx(err.code); | ||||||
| 					} |                     } | ||||||
| 				}) |                 }) | ||||||
| 			}, |             }, | ||||||
| 			scanCodeFun() { |             scanCodeFun() { | ||||||
| 				// #ifdef APP-PLUS || MP-WEIXIN |                 // #ifdef APP-PLUS || MP-WEIXIN | ||||||
| 				uni.scanCode({ |                 	uni.scanCode({ | ||||||
| 					onlyFromCamera: false, // 是否只能从相机扫码,不允许从相册选择图片 |                 		onlyFromCamera:false, // 是否只能从相机扫码,不允许从相册选择图片 | ||||||
| 					scanType: ['qrCode'], // barCode:一维码, qrCode:二维码, datamatrix:Data Matrix 码, pdf417:PDF417 条码 |                 		scanType: ['qrCode'], // barCode:一维码, qrCode:二维码, datamatrix:Data Matrix 码, pdf417:PDF417 条码 | ||||||
| 					autoDecodeCharset: true, // 是否启用自动识别字符编码功能,默认为否 |                 		autoDecodeCharset:true, // 是否启用自动识别字符编码功能,默认为否 | ||||||
| 					success: (res) => { |                 		success: function (res) { | ||||||
| 						console.log('条码类型:' + res.scanType); |                 			console.log('条码类型:' + res.scanType); | ||||||
| 						console.log('条码内容:' + res.result); |                 			console.log('条码内容:' + res.result); | ||||||
| 						let project_number = JSON.parse(res.result).project_number; |                 		} | ||||||
| 						if (project_number) this.data.project_number = project_number; |                 	}); | ||||||
| 					} |                 // #endif | ||||||
| 				}); |                 // #ifdef H5 | ||||||
| 				// #endif |                 	this.scanCode(); | ||||||
| 				// #ifdef H5 |                 // #endif | ||||||
| 				this.scanCode(); |             }, | ||||||
| 				// #endif |  | ||||||
| 			}, |  | ||||||
| 			scanCode() { | 			scanCode() { | ||||||
| 				let that = this | 				let that = this | ||||||
| 				// 调用uni提供的调用相机api | 				// 调用uni提供的调用相机api | ||||||
| 				uni.chooseImage({ | 				uni.chooseImage({ | ||||||
| 					sizeType: ['original'], | 					sizeType: ['original'], | ||||||
| 					count: 1, | 					count: 1, | ||||||
| 					success: (res) => { | 					success: (res)=> { | ||||||
| 						const tempFilePaths = res.tempFilePaths[0] // 获取到二维码图片的链接 | 						qrcode.decode(this.getObjectURL(res.tempFiles[0])) | ||||||
| 						qrcode.decode(tempFilePaths); // 解析二维码图片 | 						qrcode.callback = (codeRes) => { | ||||||
| 						qrcode.callback = function(res1) { | 							if (codeRes.indexOf('error') >= 0) { | ||||||
| 							// 解析失败返回 error decoding QR Code | 								// 二维码识别失败 | ||||||
| 							if (res1 == "error decoding QR Code") { | 								console.log('不合法二维码:' + codeRes); | ||||||
| 								uni.showToast({ |  | ||||||
| 									title: "识别二维码失败,请重新上传!", |  | ||||||
| 									duration: 2000, |  | ||||||
| 									icon: 'none' |  | ||||||
| 								}) |  | ||||||
| 							} else { | 							} else { | ||||||
| 								// 解析成功返回二维码链接 | 								// 二维码识别成功 | ||||||
| 						        let r = this.decodeStr(codeRes) | 								let r = this.decodeStr(codeRes) | ||||||
| 								console.log(res1) | 								// this.qrCodeRes = r | ||||||
|  | 								console.log(r); | ||||||
| 							} | 							} | ||||||
| 						} | 						} | ||||||
| 					}, | 						// const tempFilePaths = res.tempFilePaths[0] // 获取到二维码图片的链接 | ||||||
| 					fail: (err) => { | 						// qrcode.decode(tempFilePaths); // 解析二维码图片 | ||||||
|  | 						// qrcode.callback = function(res1) { | ||||||
|  | 						//    // 解析失败返回 error decoding QR Code | ||||||
|  | 						// 	if (res1 == "error decoding QR Code") { | ||||||
|  | 						// 		uni.showToast({ | ||||||
|  | 						// 			title: "识别二维码失败,请重新上传!", | ||||||
|  | 						// 			duration: 2000, | ||||||
|  | 						// 			icon: 'none' | ||||||
|  | 						// 		}) | ||||||
|  | 						// 	} else { | ||||||
|  | 						// 	// 解析成功返回二维码链接 | ||||||
|  | 						// 		console.log(res1) | ||||||
|  | 						// 	} | ||||||
|  | 						// } | ||||||
|  | 					},fail:(err)=> { | ||||||
| 						this.$toolAll.tools.checkQx(err.code); | 						this.$toolAll.tools.checkQx(err.code); | ||||||
| 					} | 			        } | ||||||
| 				}); | 				}); | ||||||
| 			}, | 			}, | ||||||
| 			// 获取文件地址函数 | 			// 获取文件地址函数 | ||||||
|  | @ -266,245 +268,252 @@ | ||||||
| 				} | 				} | ||||||
| 				return out; | 				return out; | ||||||
| 			}, | 			}, | ||||||
| 			mapFun() { |             mapFun() { | ||||||
| 				let that = this |                 let that = this | ||||||
| 				uni.chooseLocation({ | 				uni.chooseLocation({ | ||||||
| 					success: (res) => { | 				    success:(result)=> { | ||||||
| 						that.data.service_address = res.address | 				        that.data.service_address = result.address | ||||||
| 					} | 				    } | ||||||
| 				}) | 				}); | ||||||
| 				//           uni.getLocation({ |       //           uni.getLocation({ | ||||||
| 				//               type: 'wgs84', //返回可以用于uni.openLocation的经纬度gcj02 |       //               type: 'wgs84', //返回可以用于uni.openLocation的经纬度gcj02 | ||||||
| 				//               success: function(res) { |       //               success: function(res) { | ||||||
| 				// console.log(res); | 						// console.log(res); | ||||||
| 				//                   let latitude = res.latitude; |       //                   let latitude = res.latitude; | ||||||
| 				//                   let longitude = res.longitude; |       //                   let longitude = res.longitude; | ||||||
| 				//               } | 						// uni.chooseLocation({ | ||||||
| 				//           }); | 						// 	latitude:res.latitude, | ||||||
| 			}, | 						// 	longitude:res.longitude, | ||||||
| 			repairsNavFun(index) { | 						//     success:(result)=> { | ||||||
| 				this.current = index; | 						//         that.data.service_address = result.address | ||||||
| 			}, | 						//     } | ||||||
| 			repairsTypeFun(index) { | 						// }); | ||||||
| 				this.indexType = index |       //               } | ||||||
| 			} |       //           }); | ||||||
| 		} |             }, | ||||||
| 	} |             repairsNavFun(index) { | ||||||
|  |                 this.current = index; | ||||||
|  |             }, | ||||||
|  |             repairsTypeFun(index) { | ||||||
|  |                 this.indexType = index | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style> | <style> | ||||||
| 	.repairs-nav { |     .repairs-nav { | ||||||
| 		display: flex; |         display: flex; | ||||||
| 		background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
| 		justify-content: space-between; |         justify-content: space-between; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.repairs-nav .li { |     .repairs-nav .li { | ||||||
| 		width: 50%; |         width: 50%; | ||||||
| 		padding: 30rpx 0rpx; |         padding: 30rpx 0rpx; | ||||||
| 		text-align: center; |         text-align: center; | ||||||
| 		display: flex; |         display: flex; | ||||||
| 		align-items: center; |         align-items: center; | ||||||
| 		justify-content: center; |         justify-content: center; | ||||||
| 		font-size: 28rpx; |         font-size: 28rpx; | ||||||
| 		color: #343536; |         color: #343536; | ||||||
| 		border-bottom: 2rpx solid rgba(0, 0, 0, 0); |         border-bottom: 2rpx solid rgba(0, 0, 0, 0); | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.repairs-nav .on { |     .repairs-nav .on { | ||||||
| 		color: #00a2ea; |         color: #00a2ea; | ||||||
| 
 | 
 | ||||||
| 		border-bottom: 2rpx solid #00a2ea; |         border-bottom: 2rpx solid #00a2ea; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.content { |     .content { | ||||||
| 		background-color: #F7F7F7; |         background-color: #F7F7F7; | ||||||
| 		min-height: 100vh; |         min-height: 100vh; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.repairs-hint { |     .repairs-hint { | ||||||
| 		width: 100%; |         width: 100%; | ||||||
| 		height: 123rpx; |         height: 123rpx; | ||||||
| 		background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
| 		display: flex; |         display: flex; | ||||||
| 		padding-top: 20rpx; |         padding-top: 20rpx; | ||||||
| 		box-sizing: border-box; |         box-sizing: border-box; | ||||||
| 		margin-top: 23rpx; |         margin-top: 23rpx; | ||||||
| 		border-top: 2rpx solid #e7e7e7; |         border-top: 2rpx solid #e7e7e7; | ||||||
| 		border-bottom: 2rpx solid #e7e7e7; |         border-bottom: 2rpx solid #e7e7e7; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.repairs-hint .icon { |     .repairs-hint .icon { | ||||||
| 		width: 30rpx; |         width: 30rpx; | ||||||
| 		height: 27rpx; |         height: 27rpx; | ||||||
| 		margin-right: 15rpx; |         margin-right: 15rpx; | ||||||
| 		margin-top: 8rpx; |         margin-top: 8rpx; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.repairs-hint .text { |     .repairs-hint .text { | ||||||
| 		flex: 1; |         flex: 1; | ||||||
| 		color: #5e5e5e; |         color: #5e5e5e; | ||||||
| 		font-size: 22rpx; |         font-size: 22rpx; | ||||||
| 		line-height: 40rpx; |         line-height: 40rpx; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-type-title { |     .fault-type-title { | ||||||
| 		margin-top: 14rpx; |         margin-top: 14rpx; | ||||||
| 		/* width: 100%; */ |         /* width: 100%; */ | ||||||
| 		line-height: 80rpx; |         line-height: 80rpx; | ||||||
| 		margin-bottom: 13rpx; |         margin-bottom: 13rpx; | ||||||
| 		border-top: 2rpx solid #e7e7e7; |         border-top: 2rpx solid #e7e7e7; | ||||||
| 		border-bottom: 2rpx solid #e7e7e7; |         border-bottom: 2rpx solid #e7e7e7; | ||||||
| 		height: 80rpx; |         height: 80rpx; | ||||||
| 		background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
| 		color: #434242; |         color: #434242; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-type-content { |     .fault-type-content { | ||||||
| 		display: flex; |         display: flex; | ||||||
| 		flex-wrap: wrap; |         flex-wrap: wrap; | ||||||
| 		justify-content: space-between; |         justify-content: space-between; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-type-content .li { |     .fault-type-content .li { | ||||||
| 		width: 160rpx; |         width: 160rpx; | ||||||
| 		height: 59rpx; |         height: 59rpx; | ||||||
| 		background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
| 		font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 		color: #5e5e5e; |         color: #5e5e5e; | ||||||
| 		box-sizing: border-box; |         box-sizing: border-box; | ||||||
| 		text-align: center; |         text-align: center; | ||||||
| 		line-height: 59rpx; |         line-height: 59rpx; | ||||||
| 		border-radius: 22rpx; |         border-radius: 22rpx; | ||||||
| 		border: 2rpx solid #eeeeee; |         border: 2rpx solid #eeeeee; | ||||||
| 		margin-bottom: 15rpx; |         margin-bottom: 15rpx; | ||||||
| 
 | 
 | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-type-content .on { |     .fault-type-content .on { | ||||||
| 		color: #FFFFFF; |         color: #FFFFFF; | ||||||
| 		border: none; |         border: none; | ||||||
| 		background-color: #00a2ea; |         background-color: #00a2ea; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.information {} |     .information {} | ||||||
| 
 | 
 | ||||||
| 	.devicename { |     .devicename { | ||||||
| 		width: 100%; |         width: 100%; | ||||||
| 		height: 78rpx; |         height: 78rpx; | ||||||
| 		border-radius: 10rpx; |         border-radius: 10rpx; | ||||||
| 		background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
| 		padding: 0 16rpx; |         padding: 0 16rpx; | ||||||
| 		box-sizing: border-box; |         box-sizing: border-box; | ||||||
| 		display: flex; |         display: flex; | ||||||
| 		align-items: center; |         align-items: center; | ||||||
| 		justify-content: space-between; |         justify-content: space-between; | ||||||
| 		color: #9f9898; |         color: #9f9898; | ||||||
| 		font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 		line-height: 78rpx; |         line-height: 78rpx; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-pictures { |     .fault-pictures { | ||||||
| 		display: flex; |         display: flex; | ||||||
| 		align-items: center; |         align-items: center; | ||||||
| 		justify-content: center; |         justify-content: center; | ||||||
| 		margin-top: 18rpx; |         margin-top: 18rpx; | ||||||
| 		height: 320rpx; |         height: 320rpx; | ||||||
| 		box-sizing: border-box; |         box-sizing: border-box; | ||||||
| 		width: 100%; |         width: 100%; | ||||||
| 		background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
| 		flex-direction: column; |         flex-direction: column; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-pictures-con { |     .fault-pictures-con { | ||||||
| 		display: flex; |         display: flex; | ||||||
| 		flex-direction: column; |         flex-direction: column; | ||||||
| 		align-items: center; |         align-items: center; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-pictures .img { |     .fault-pictures .img { | ||||||
| 		width: 87rpx; |         width: 87rpx; | ||||||
| 		margin-bottom: 27rpx; |         margin-bottom: 27rpx; | ||||||
| 		height: 87rpx; |         height: 87rpx; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-pictures .text { |     .fault-pictures .text { | ||||||
| 		font-size: 30rpx; |         font-size: 30rpx; | ||||||
| 
 | 
 | ||||||
| 		color: #9f9898; |         color: #9f9898; | ||||||
| 
 | 
 | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-description { |     .fault-description { | ||||||
| 		height: 193rpx; |         height: 193rpx; | ||||||
| 		width: 100%; |         width: 100%; | ||||||
| 		box-sizing: border-box; |         box-sizing: border-box; | ||||||
| 		margin-top: 23rpx; |         margin-top: 23rpx; | ||||||
| 		padding: 23rpx 19rpx; |         padding: 23rpx 19rpx; | ||||||
| 		background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-description-text { |     .fault-description-text { | ||||||
| 		color: #9f9898; |         color: #9f9898; | ||||||
| 		font-size: 26rpx |         font-size: 26rpx | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.inputCss { |     .inputCss { | ||||||
| 		height: 78rpx; |         height: 78rpx; | ||||||
| 		width: 100%; |         width: 100%; | ||||||
| 		box-sizing: border-box; |         box-sizing: border-box; | ||||||
| 		padding: 0rpx 17rpx; |         padding: 0rpx 17rpx; | ||||||
| 		font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 		border-radius: 10rpx; |         border-radius: 10rpx; | ||||||
| 		background-color: #FFFFFF; |         background-color: #FFFFFF; | ||||||
| 		color: #000000; |         color: #000000; | ||||||
| 		display: flex; |         display: flex; | ||||||
| 		margin-top: 20rpx; |         margin-top: 20rpx; | ||||||
| 		align-items: center; |         align-items: center; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.detailed-address { |     .detailed-address { | ||||||
| 		justify-content: space-between; |         justify-content: space-between; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.inputCss-input-input { |     .inputCss-input-input { | ||||||
| 		font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 		color: #9f9898; |         color: #9f9898; | ||||||
| 
 | 
 | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.detailed-address .map { |     .detailed-address .map { | ||||||
| 		width: 151rpx; |         width: 151rpx; | ||||||
| 		height: 59rpx; |         height: 59rpx; | ||||||
| 		background-color: #F7F7F7; |         background-color: #F7F7F7; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.uni-datetime-pickerCss { |     .uni-datetime-pickerCss { | ||||||
| 		margin-top: 20rpx; |         margin-top: 20rpx; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.submit-button { |     .submit-button { | ||||||
| 		width: 100%; |         width: 100%; | ||||||
| 		margin-top: 44rpx; |         margin-top: 44rpx; | ||||||
| 		border-radius: 50rpx; |         border-radius: 50rpx; | ||||||
| 		height: 90rpx; |         height: 90rpx; | ||||||
| 		background-color: #02A2ea; |         background-color: #02A2ea; | ||||||
| 		line-height: 90rpx; |         line-height: 90rpx; | ||||||
| 		color: #FFFFFF; |         color: #FFFFFF; | ||||||
| 		text-align: center; |         text-align: center; | ||||||
| 		font-size: 30rpx; |         font-size: 30rpx; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.devicename .sm { |     .devicename .sm { | ||||||
| 		width: 42rpx; |         width: 42rpx; | ||||||
| 		height: 36rpx; |         height: 36rpx; | ||||||
| 	} |     } | ||||||
| 
 | 
 | ||||||
| 	.fault-pictures-img { |     .fault-pictures-img { | ||||||
| 		width: 100%; |         width: 100%; | ||||||
| 		height: 100%; |         height: 100%; | ||||||
| 
 | 
 | ||||||
| 	} |     } | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -200,7 +200,7 @@ | ||||||
|         methods: { |         methods: { | ||||||
| 			// app获取经纬度和详细地址 | 			// app获取经纬度和详细地址 | ||||||
| 			getAddress(){ | 			getAddress(){ | ||||||
| 				// this.$toolAll.tools.showToast('正在获取定位...') | 				this.$toolAll.tools.showToast('正在获取定位...') | ||||||
| 				// #ifdef APP-PLUS | 				// #ifdef APP-PLUS | ||||||
| 				if(this.addressFlag) { | 				if(this.addressFlag) { | ||||||
| 					this.addressFlag = false; | 					this.addressFlag = false; | ||||||
|  | @ -208,7 +208,7 @@ | ||||||
| 						type: 'gcj02',  | 						type: 'gcj02',  | ||||||
| 						geocode:true, | 						geocode:true, | ||||||
| 						success: (res)=> { | 						success: (res)=> { | ||||||
| 							// this.$toolAll.tools.showToast('定位成功'); | 							this.$toolAll.tools.showToast('定位成功'); | ||||||
| 							// console.log(res,'app'); | 							// console.log(res,'app'); | ||||||
| 							this.targetObj.address = `${res.address.province}${res.address.city}${res.address.district}${res.address.street || ''}${res.address.streetNum || ''}${res.address.poiName || ''}` | 							this.targetObj.address = `${res.address.province}${res.address.city}${res.address.district}${res.address.street || ''}${res.address.streetNum || ''}${res.address.poiName || ''}` | ||||||
| 							setTimeout(()=>{ | 							setTimeout(()=>{ | ||||||
|  | @ -240,7 +240,7 @@ | ||||||
| 								location: {latitude: res.latitude, longitude: res.longitude}, | 								location: {latitude: res.latitude, longitude: res.longitude}, | ||||||
| 								success:(res)=> {  | 								success:(res)=> {  | ||||||
| 									console.log(res,'WX'); | 									console.log(res,'WX'); | ||||||
| 									// this.$toolAll.tools.showToast('定位成功'); | 									this.$toolAll.tools.showToast('定位成功'); | ||||||
| 									this.targetObj.address = `${res.result.address_component.province}${res.result.address_component.city}${res.result.address_component.district}${res.result.address_component.street || ''}(${res.result.address_component.street_number || ''})` | 									this.targetObj.address = `${res.result.address_component.province}${res.result.address_component.city}${res.result.address_component.district}${res.result.address_component.street || ''}(${res.result.address_component.street_number || ''})` | ||||||
| 									setTimeout(()=>{ | 									setTimeout(()=>{ | ||||||
| 										this.addressFlag = true; | 										this.addressFlag = true; | ||||||
|  | @ -267,7 +267,7 @@ | ||||||
| 							let str =  `output=jsonp&key=QNHBZ-55RKF-OMFJJ-NPU7O-EPSDH-ACBAA&location=${res.latitude},${res.longitude}` | 							let str =  `output=jsonp&key=QNHBZ-55RKF-OMFJJ-NPU7O-EPSDH-ACBAA&location=${res.latitude},${res.longitude}` | ||||||
| 							jsonp('https://apis.map.qq.com/ws/geocoder/v1/?'+str,{}).then(res=>{ | 							jsonp('https://apis.map.qq.com/ws/geocoder/v1/?'+str,{}).then(res=>{ | ||||||
| 								console.log(res,'H5');  | 								console.log(res,'H5');  | ||||||
| 								// this.$toolAll.tools.showToast('定位成功'); | 								this.$toolAll.tools.showToast('定位成功'); | ||||||
| 								this.targetObj.address = `${res.result.address_component.province}${res.result.address_component.city}${res.result.address_component.district}${res.result.address_component.street || ''}(${res.result.address_component.street_number || ''})` | 								this.targetObj.address = `${res.result.address_component.province}${res.result.address_component.city}${res.result.address_component.district}${res.result.address_component.street || ''}(${res.result.address_component.street_number || ''})` | ||||||
| 								setTimeout(()=>{ | 								setTimeout(()=>{ | ||||||
| 									this.addressFlag = true; | 									this.addressFlag = true; | ||||||
|  |  | ||||||
|  | @ -35,7 +35,7 @@ | ||||||
| 					<view class="li animated fadeIn" @click="projectDetailsFun(item.order_status,item.order_id,item.btn.attributes.text,item.btn.attributes.color)" v-for="(item,index) in dataList" :key="index"> | 					<view class="li animated fadeIn" @click="projectDetailsFun(item.order_status,item.order_id,item.btn.attributes.text,item.btn.attributes.color)" v-for="(item,index) in dataList" :key="index"> | ||||||
| 						<view class="work-order-code">工单编号:{{item.order_number}}</view> | 						<view class="work-order-code">工单编号:{{item.order_number}}</view> | ||||||
| 						<view class="message"> | 						<view class="message"> | ||||||
| 							<image class="img" :src="item.cover_picture" mode="aspectFill" lazy-load></image> | 							<image class="img" src="../../static/del/img001.png" mode="aspectFill" lazy-load></image> | ||||||
| 							<view class="text disjb fc" style="height: 180rpx;"> | 							<view class="text disjb fc" style="height: 180rpx;"> | ||||||
| 								<view class="title flexs"> | 								<view class="title flexs"> | ||||||
| 									<view class="text clips1">{{item.project_name}}</view> | 									<view class="text clips1">{{item.project_name}}</view> | ||||||
|  | @ -43,7 +43,7 @@ | ||||||
| 								</view> | 								</view> | ||||||
| 								<view class="disjb fc line-h36" style="margin-left: -20rpx;"> | 								<view class="disjb fc line-h36" style="margin-left: -20rpx;"> | ||||||
| 									<view class="serial-number scal09"> | 									<view class="serial-number scal09"> | ||||||
| 										<view class="type" v-if="item.fault_type">#{{item.fault_type}}#</view> | 										<view class="type">#{{item.fault_type}}#</view> | ||||||
| 										<view class="date">{{item.failure_time}}</view> | 										<view class="date">{{item.failure_time}}</view> | ||||||
| 									</view> | 									</view> | ||||||
| 									<view class="specification scal09"> | 									<view class="specification scal09"> | ||||||
|  |  | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| <template> | <template> | ||||||
| 	<view class="content" :style="{paddingBottom: bottomHeight}"> | 	<view class="content"> | ||||||
| 		<statusNav returnColor="#c2c2c2" navBarTitle="处理工单"></statusNav> | 		<statusNav returnColor="#c2c2c2" navBarTitle="处理工单"></statusNav> | ||||||
| 		<container-subgroup-two> | 		<container-subgroup-two> | ||||||
| 			<view slot="content" style="margin: -20rpx -25rpx 0rpx;"> | 			<view slot="content" style="margin: -20rpx -25rpx 0rpx;"> | ||||||
|  | @ -99,13 +99,17 @@ | ||||||
| 					</view> | 					</view> | ||||||
| 					<view class="customerSignature"> | 					<view class="customerSignature"> | ||||||
| 						<view class="title"> | 						<view class="title"> | ||||||
|                             <view class="">客户签名</view> |                             <view class=""> | ||||||
| 							<view class="" @click="clearClick"   v-if="!isCanvas">清除 </view> |                                   客户签名 | ||||||
|  |                             </view> | ||||||
|  |                           <view class="" @click="clearClick"   v-if="!isCanvas"> | ||||||
|  |                              清除  | ||||||
|  |                           </view> | ||||||
|                         </view> |                         </view> | ||||||
| 						<view class='contents'> | 						<view class='contents'> | ||||||
| 							<canvas class='firstCanvas' canvas-id="firstCanvas" @touchmove='move' | 							<canvas class='firstCanvas' canvas-id="firstCanvas" @touchmove='move' | ||||||
| 								@touchstart='start($event)' @touchend='end' @touchcancel='cancel' @longtap='tap' | 								@touchstart='start($event)' @touchend='end' @touchcancel='cancel' @longtap='tap' | ||||||
| 								disable-scroll='false' @error='error'> | 								disable-scroll='true' @error='error'> | ||||||
| 							</canvas> | 							</canvas> | ||||||
| 							<!-- <button @click='clearClick'>清除</button> --> | 							<!-- <button @click='clearClick'>清除</button> --> | ||||||
| 							<!--          <button @click='saveClick'>保存图片</button> --> | 							<!--          <button @click='saveClick'>保存图片</button> --> | ||||||
|  | @ -130,7 +134,7 @@ | ||||||
| 					</view> | 					</view> | ||||||
| 					<view class="remark"> | 					<view class="remark"> | ||||||
| 						<view class="title">备注内容</view> | 						<view class="title">备注内容</view> | ||||||
| 						<textarea @focus="remarkEv" class="textarea" v-model="remarkText" placeholder="请输入备注内容" /> | 						<textarea class="textarea" v-model="remarkText" placeholder="请输入备注内容" /> | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
| 				<button class="submit-button" type="default" @tap="submitEv">提交审核</button> | 				<button class="submit-button" type="default" @tap="submitEv">提交审核</button> | ||||||
|  | @ -193,13 +197,13 @@ | ||||||
| 				billingIndex:0,//开票类型 0:专票 1:普票 2:不开票 | 				billingIndex:0,//开票类型 0:专票 1:普票 2:不开票 | ||||||
| 				isMoney: true,//是否收款 | 				isMoney: true,//是否收款 | ||||||
| 				isCanvas: true, | 				isCanvas: true, | ||||||
|  | 				signImage: '',//签名图片 | ||||||
| 				ifCollectionCode:false,//是否显示收款码 | 				ifCollectionCode:false,//是否显示收款码 | ||||||
| 				remarkText:'',//备注内容 | 				remarkText:'',//备注内容 | ||||||
| 				saveTimer:null,//保存签名延迟时间事件 | 				saveTimer:null,//保存签名延迟时间事件 | ||||||
| 				flag:true,//防抖 | 				flag:true,//防抖 | ||||||
| 				signId:'',//签名图片id | 				signId:'',//签名图片id | ||||||
| 				orderId:'',//工单id | 				orderId:''//工单id | ||||||
| 				bottomHeight:'' |  | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
| 		computed:{ | 		computed:{ | ||||||
|  | @ -302,12 +306,9 @@ | ||||||
| 						} | 						} | ||||||
| 						handleWorkOrderSubmit(params).then(res=>{ | 						handleWorkOrderSubmit(params).then(res=>{ | ||||||
| 							if(res.code) { | 							if(res.code) { | ||||||
| 								this.$toolAll.tools.showToast('提交成功,即将返回工单列表'); | 								uni.navigateTo({ | ||||||
| 								setTimeout(()=>{ | 								    url: `/pagesA/workOrder/workorderTwo?id=${this.orderId}` | ||||||
| 									uni.navigateTo({ | 								}) | ||||||
| 									    url: `/pagesA/workOrder/workOrderLlsit` |  | ||||||
| 									}) |  | ||||||
| 								},2000) |  | ||||||
| 							} else { | 							} else { | ||||||
| 								this.$toolAll.tools.showToast(res.msg); | 								this.$toolAll.tools.showToast(res.msg); | ||||||
| 							} | 							} | ||||||
|  | @ -324,7 +325,7 @@ | ||||||
| 				// } else  | 				// } else  | ||||||
| 				if(!this.paymentMode) { | 				if(!this.paymentMode) { | ||||||
| 					this.$toolAll.tools.showToast('请选择付款方式'); | 					this.$toolAll.tools.showToast('请选择付款方式'); | ||||||
| 				} else if(!this.signId) { | 				} else if(!this.signImage) { | ||||||
| 					this.$toolAll.tools.showToast('请签名'); | 					this.$toolAll.tools.showToast('请签名'); | ||||||
| 				} else { | 				} else { | ||||||
| 					result = true; | 					result = true; | ||||||
|  | @ -436,55 +437,24 @@ | ||||||
| 			}, | 			}, | ||||||
| 			//保存图片 | 			//保存图片 | ||||||
| 			saveClick: function() { | 			saveClick: function() { | ||||||
|  | 				var that = this | ||||||
| 				uni.canvasToTempFilePath({ | 				uni.canvasToTempFilePath({ | ||||||
| 					canvasId: 'firstCanvas', | 					canvasId: 'firstCanvas', | ||||||
| 					success:(res)=> { | 					success: function(res) { | ||||||
| 						// base64转图片路径 | 						// base64转图片路径 | ||||||
| 						// #ifdef APP-PLUS | 						base64ToPath(res.tempFilePath).then(path => { | ||||||
| 						uni.saveImageToPhotosAlbum({ | 							that.signImage = path; | ||||||
| 							filePath: res.tempFilePath, | 							console.log(that.signImage); | ||||||
| 							success:(resimg)=> { | 							uploadImg({path:that.signImage}).then(res=>{ | ||||||
| 								uploadImg({path:resimg.path}).then(result=>{ | 								if(res.code) { | ||||||
| 									if(result.code) { | 									that.signId = res.data.id; | ||||||
| 										this.signId = result.data.id; |  | ||||||
| 									} else { |  | ||||||
| 										this.$toolAll.tools.showToast(result.msg); |  | ||||||
| 									} |  | ||||||
| 								}) |  | ||||||
| 							} |  | ||||||
| 						}); |  | ||||||
| 						// #endif |  | ||||||
| 						// #ifdef MP-WEIXIN |  | ||||||
| 							wx.saveFile({ |  | ||||||
| 								tempFilePath: res.tempFilePath, |  | ||||||
| 								success:(wximg)=> { |  | ||||||
| 									uploadImg({path:wximg.savedFilePath}).then(result=>{ |  | ||||||
| 										if(result.code) { |  | ||||||
| 											this.signId = result.data.id; |  | ||||||
| 										} else { |  | ||||||
| 											this.$toolAll.tools.showToast(result.msg); |  | ||||||
| 										} |  | ||||||
| 									}) |  | ||||||
| 								} |  | ||||||
| 						    }) |  | ||||||
| 						// #endif |  | ||||||
| 						// #ifdef H5 |  | ||||||
| 							uploadImg({path:res.tempFilePath}).then(result=>{ |  | ||||||
| 								if(result.code) { |  | ||||||
| 									this.signId = result.data.id; |  | ||||||
| 								} else { | 								} else { | ||||||
| 									this.$toolAll.tools.showToast(result.msg); | 									that.$toolAll.tools.showToast(res.msg); | ||||||
| 								} | 								} | ||||||
| 							}) | 							}) | ||||||
| 						// #endif | 						}).catch(error => {}) | ||||||
| 					} | 					} | ||||||
| 				}) | 				}) | ||||||
| 			}, |  | ||||||
| 			remarkEv(){ |  | ||||||
| 				uni.onKeyboardHeightChange(res => { |  | ||||||
| 				  console.log(res.height) |  | ||||||
| 				  this.bottomHeight = res.height + 'px' |  | ||||||
| 				}) |  | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | @ -726,8 +696,6 @@ | ||||||
| 		background-color: #FFFFFF; | 		background-color: #FFFFFF; | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		height: 320rpx; | 		height: 320rpx; | ||||||
| 		border: 2rpx dashed #cccccc; |  | ||||||
| 		border-radius: 10rpx; |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.contents image { | 	.contents image { | ||||||
|  | @ -736,6 +704,11 @@ | ||||||
| 		background-color: orange; | 		background-color: orange; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	.firstCanvas { | ||||||
|  | 		border: 2rpx dashed #cccccc; | ||||||
|  | 		border-radius: 10rpx; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	.money-receiving-code { | 	.money-receiving-code { | ||||||
| 		width: 100%; | 		width: 100%; | ||||||
| 		height: 80rpx; | 		height: 80rpx; | ||||||
|  |  | ||||||
|  | @ -5,12 +5,10 @@ | ||||||
| 			<view slot="content" style="margin: -6rpx -30rpx 0 -30rpx;"> | 			<view slot="content" style="margin: -6rpx -30rpx 0 -30rpx;"> | ||||||
| 				<view class="bacf fon28 pad-sx30 pad-zy40"> | 				<view class="bacf fon28 pad-sx30 pad-zy40"> | ||||||
| 					<view class=" bold disjbac fw line-h50"> | 					<view class=" bold disjbac fw line-h50"> | ||||||
| 						<!-- 项目名称 --> | 						<view class="mar-y20">{{project_name}}</view> | ||||||
| 						<view class="mar-y20">{{orderObj.project_name || '项目名称'}}</view> | 						<view>{{project_number}}</view> | ||||||
| 						<!-- 项目编号 --> |  | ||||||
| 						<view>{{orderObj.order_number || '项目编号'}}</view> |  | ||||||
| 					</view> | 					</view> | ||||||
| 					<view class="mar-s10 mar-x30" style="color: #6b6a6a;">服务时间:{{orderObj.order_time}}</view> | 					<view class="mar-s10 mar-x30" style="color: #6b6a6a;">服务时间:{{project_time}}</view> | ||||||
| 					<view class="radius20 pad30 dis" style="border: 2rpx solid #dcdcdc;"> | 					<view class="radius20 pad30 dis" style="border: 2rpx solid #dcdcdc;"> | ||||||
| 						<image src="/static/public/icon-evaluate-pen.png" mode="widthFix" lazy-load style="width: 25rpx;height: 30rpx;"></image> | 						<image src="/static/public/icon-evaluate-pen.png" mode="widthFix" lazy-load style="width: 25rpx;height: 30rpx;"></image> | ||||||
| 						<textarea v-model="serviceExperience" maxlength="-1" class="fon24 mar-z20 width100" style="height: 200rpx;" placeholder="写下您的服务体验,帮助我们更好的管理提升" placeholder-style="font-size:24rpx;color: #aaaaaa;" /> | 						<textarea v-model="serviceExperience" maxlength="-1" class="fon24 mar-z20 width100" style="height: 200rpx;" placeholder="写下您的服务体验,帮助我们更好的管理提升" placeholder-style="font-size:24rpx;color: #aaaaaa;" /> | ||||||
|  | @ -52,17 +50,14 @@ | ||||||
| 					{imgsrc:''} | 					{imgsrc:''} | ||||||
| 				], | 				], | ||||||
| 				tempImgId:[], | 				tempImgId:[], | ||||||
|  | 				project_name:'长沙XXXXXXXXX项目名称', | ||||||
|  | 				project_number:'GD20220108-1002', | ||||||
|  | 				project_time:'2022-01-11 15 : 27', | ||||||
| 				rateNum:5,//技术服务评分 | 				rateNum:5,//技术服务评分 | ||||||
| 				attitudeNum:5,//客服态度评分 | 				attitudeNum:5,//客服态度评分 | ||||||
| 				serviceExperience:'',//服务体验 | 				serviceExperience:'',//服务体验 | ||||||
| 				flag:true, | 				flag:true, | ||||||
| 				orderId:'',//工单id | 				orderId:''//工单id | ||||||
| 				orderObj: { |  | ||||||
| 					order_id:28, |  | ||||||
| 					order_number:"", |  | ||||||
| 					order_time:"", |  | ||||||
| 					project_name:"" |  | ||||||
| 				} |  | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
| 		onLoad(op) { | 		onLoad(op) { | ||||||
|  | @ -75,7 +70,7 @@ | ||||||
| 			getOrderInfo(){ | 			getOrderInfo(){ | ||||||
| 				this.$requst.get('/universal/api.order/evaluate_order',{order_id:this.orderId}).then(res=>{ | 				this.$requst.get('/universal/api.order/evaluate_order',{order_id:this.orderId}).then(res=>{ | ||||||
| 					if(res.code) { | 					if(res.code) { | ||||||
| 						this.orderObj = res.data; | 						 | ||||||
| 					} else { | 					} else { | ||||||
| 						this.$toolAll.tools.showToast(res.msg); | 						this.$toolAll.tools.showToast(res.msg); | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
|  | @ -106,7 +106,7 @@ | ||||||
| 				id_card_no:'', // 身份证号码 | 				id_card_no:'', // 身份证号码 | ||||||
| 				imgList:[], | 				imgList:[], | ||||||
| 				flag:true, | 				flag:true, | ||||||
| 				temporaryImg:[], | 				temporaryImg:[] | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
|         onLoad() { |         onLoad() { | ||||||
|  | @ -140,13 +140,7 @@ | ||||||
| 						this.imgList[3] = res.data.agreement_document; | 						this.imgList[3] = res.data.agreement_document; | ||||||
| 						// 技能证书 | 						// 技能证书 | ||||||
| 						this.imgList[4] = res.data.skills_certificate; | 						this.imgList[4] = res.data.skills_certificate; | ||||||
| 						this.temporaryImg = [ | 						// this.temporaryImg = this.imgList[4]; | ||||||
| 							res.data.idcard_front_value, |  | ||||||
| 							res.data.idcard_reverse_value, |  | ||||||
| 							res.data.accident_insurance_value, |  | ||||||
| 							res.data.agreement_document_value, |  | ||||||
| 							res.data.skills_certificate_value |  | ||||||
| 						]; |  | ||||||
| 					} | 					} | ||||||
| 			   }) | 			   }) | ||||||
| 			}, | 			}, | ||||||
|  | @ -170,14 +164,12 @@ | ||||||
| 						} | 						} | ||||||
| 			 | 			 | ||||||
| 						this.$requst.post('/universal/api.user/user_info',params).then(res=>{ | 						this.$requst.post('/universal/api.user/user_info',params).then(res=>{ | ||||||
| 							if(res.code){ | 							if(res.code==1){ | ||||||
| 								this.$toolAll.tools.showToast('保存成功'); | 								this.$toolAll.tools.showToast('保存成功'); | ||||||
| 								setTimeout(()=>{ | 								setTimeout(()=>{ | ||||||
| 									uni.navigateBack({delta:1}) | 									uni.navigateBack({delta:1}) | ||||||
| 								},1000) | 								},1000) | ||||||
|                              |                              | ||||||
| 							} else { |  | ||||||
| 								this.$toolAll.tools.showToast(res.msg); |  | ||||||
| 							} | 							} | ||||||
| 						}) | 						}) | ||||||
| 					} else { | 					} else { | ||||||
|  |  | ||||||
|  | @ -17,6 +17,7 @@ | ||||||
| 				</view> | 				</view> | ||||||
| 				<view class="bbot disac pad-sx30 pad-zy30"> | 				<view class="bbot disac pad-sx30 pad-zy30"> | ||||||
| 					<view class="mar-y30 flexs disjbac" :style="{width: eareWidth + 'px'}">地 <view>区<text style="color: red;">*</text></view></view> | 					<view class="mar-y30 flexs disjbac" :style="{width: eareWidth + 'px'}">地 <view>区<text style="color: red;">*</text></view></view> | ||||||
|  | 					<!-- <view class="disjbac width100" @tap="chooseRegion"> --> | ||||||
| 					<view class="disjbac width100" @tap="openPicker"> | 					<view class="disjbac width100" @tap="openPicker"> | ||||||
| 						<view>{{region}}</view> | 						<view>{{region}}</view> | ||||||
| 						<i class="icon icon-next col9" style="font-size: 30rpx;"></i> | 						<i class="icon icon-next col9" style="font-size: 30rpx;"></i> | ||||||
|  | @ -67,12 +68,12 @@ | ||||||
| 				    cityName:'', | 				    cityName:'', | ||||||
| 				    townName:'', | 				    townName:'', | ||||||
| 				}, | 				}, | ||||||
| 				region:'',//地区 | 				region:'湖南省株洲市芦淞区', | ||||||
| 				newProvice:'',//省/市 | 				newProvice:'', | ||||||
| 				newCity:'',//市/区 | 				newCity:'', | ||||||
| 				newDistrict:'',//区 | 				newDistrict:'', | ||||||
| 				detailed_address:'',//详细地址 | 				detailed_address:'', | ||||||
| 				remarkText:'',//备注 | 				remarkText:'', | ||||||
| 				eareWidth:'', | 				eareWidth:'', | ||||||
| 				flag:true | 				flag:true | ||||||
| 			} | 			} | ||||||
|  | @ -82,7 +83,6 @@ | ||||||
| 			query.select('#timeBox').boundingClientRect((rect) => { | 			query.select('#timeBox').boundingClientRect((rect) => { | ||||||
| 				this.eareWidth = rect.width; | 				this.eareWidth = rect.width; | ||||||
| 			}).exec() | 			}).exec() | ||||||
| 			this.getDistrict(); |  | ||||||
| 		}, | 		}, | ||||||
| 		methods: { | 		methods: { | ||||||
| 			// 提交保存 | 			// 提交保存 | ||||||
|  | @ -93,22 +93,20 @@ | ||||||
| 						let params = { | 						let params = { | ||||||
| 							is_working:this.personnelStatus[this.statusNum].id,//人员状态 | 							is_working:this.personnelStatus[this.statusNum].id,//人员状态 | ||||||
| 							working_hours:this.workingHours[this.hoursNum].id ,//工作时段 | 							working_hours:this.workingHours[this.hoursNum].id ,//工作时段 | ||||||
| 							area_id:272, |  | ||||||
| 							area:this.region,//地区 | 							area:this.region,//地区 | ||||||
| 							address:this.detailed_address,//详细地址 | 							address:this.detailed_address,//详细地址 | ||||||
| 							service_distance: parseFloat(this.serviceRange[this.rangeNum]) || 0,//服务范围 | 							service_distance: parseFloat(this.serviceRange[this.rangeNum]) || 0,//服务范围 | ||||||
| 							remark:this.remarkText//备注 | 							remark:this.remarkText//备注 | ||||||
| 						} | 						} | ||||||
| 						this.$requst.post('/universal/api.user/service_area',params).then(res=>{ | 						console.log(params,87); | ||||||
| 							if(res.code) { | 						// this.$requst.post('/universal/api.user/service_area',params).then(res=>{ | ||||||
| 								this.$toolAll.tools.showToast('保存成功'); | 						// 	if(res.code) { | ||||||
| 								setTimeout(()=>{ | 						// 		this.$toolAll.tools.showToast('保存成功'); | ||||||
| 									uni.navigateBack({delta:1}) | 						// 		setTimeout(()=>{ | ||||||
| 								},1000) | 						// 			uni.navigateBack({delta:1}) | ||||||
| 							} else { | 						// 		},1000) | ||||||
| 								this.$toolAll.tools.showToast(res.msg); | 						// 	} | ||||||
| 							} | 						// }) | ||||||
| 						}) |  | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| 			}, | 			}, | ||||||
|  | @ -124,6 +122,33 @@ | ||||||
| 				} | 				} | ||||||
| 				return result; | 				return result; | ||||||
| 			}, | 			}, | ||||||
|  | 			// 选择地区 | ||||||
|  | 			chooseRegion(){ | ||||||
|  | 				uni.getLocation({ | ||||||
|  | 					type: 'gcj02', //返回可以用于uni.openLocation的经纬度 | ||||||
|  | 					success: function (res) { | ||||||
|  | 						const latitude = res.latitude; | ||||||
|  | 						const longitude = res.longitude; | ||||||
|  | 						console.log(latitude,longitude,78); | ||||||
|  | 						uni.chooseLocation({ | ||||||
|  | 							success: function (res) { | ||||||
|  | 								console.log(res,81); | ||||||
|  | 								console.log('位置名称:' + res.name); | ||||||
|  | 								console.log('详细地址:' + res.address); | ||||||
|  | 								console.log('纬度:' + res.latitude); | ||||||
|  | 								console.log('经度:' + res.longitude); | ||||||
|  | 							} | ||||||
|  | 						}); | ||||||
|  | 						// uni.openLocation({ | ||||||
|  | 						// 	latitude: latitude, | ||||||
|  | 						// 	longitude: longitude, | ||||||
|  | 						// 	success: function () { | ||||||
|  | 						// 		console.log('success'); | ||||||
|  | 						// 	} | ||||||
|  | 						// }); | ||||||
|  | 					} | ||||||
|  | 				}); | ||||||
|  | 			}, | ||||||
| 			getDistrict() { | 			getDistrict() { | ||||||
| 				let ya = this | 				let ya = this | ||||||
| 				uni.getLocation({ | 				uni.getLocation({ | ||||||
|  | @ -133,22 +158,11 @@ | ||||||
| 							header: { | 							header: { | ||||||
| 								'Content-Type':'application/json' | 								'Content-Type':'application/json' | ||||||
| 							}, | 							}, | ||||||
| 							success:(res)=> { | 							success:function(res) { | ||||||
| 								// console.log('地址数据:',res) | 								// console.log('地址数据:',res) | ||||||
| 								let provinceStr = res.data.result.address_component.province; | 								ya.newProvice = res.data.result.address_component.province | ||||||
| 								if(provinceStr=='北京市') { | 								ya.newCity = res.data.result.address_component.city | ||||||
| 									provinceStr = '北京'; | 								ya.newDistrict = res.data.result.address_component.district | ||||||
| 								} else if(provinceStr=='天津市') { |  | ||||||
| 									provinceStr = '天津'; |  | ||||||
| 								} else if(provinceStr=='上海市') { |  | ||||||
| 									provinceStr = '上海'; |  | ||||||
| 								} else if(provinceStr=='重庆市') { |  | ||||||
| 									provinceStr = '重庆'; |  | ||||||
| 								} |  | ||||||
| 								ya.newProvice = provinceStr; |  | ||||||
| 								ya.newCity = res.data.result.address_component.city; |  | ||||||
| 								ya.newDistrict = res.data.result.address_component.district; |  | ||||||
| 								this.region = ya.newProvice + ya.newCity + ya.newDistrict; |  | ||||||
| 							} | 							} | ||||||
| 						}) | 						}) | ||||||
| 					}, | 					}, | ||||||
|  |  | ||||||
|  | @ -142,61 +142,7 @@ | ||||||
| 			}, | 			}, | ||||||
| 			// 检测版本事件 | 			// 检测版本事件 | ||||||
| 			checkEdition(){ | 			checkEdition(){ | ||||||
| 				// status	int	 升级标志,1:需要升级;0:无需升级   | 				console.log('检测版本事件'); | ||||||
| 				// note	string	 升级日志   |  | ||||||
| 				// android_url	string	 安卓包下载地址   |  | ||||||
| 				// ios_url	string	 苹果更新商店地址   |  | ||||||
| 				// 检测升级 |  | ||||||
| 				plus.runtime.getProperty(plus.runtime.appid, (widgetInfo) => { |  | ||||||
| 					var platform = uni.getSystemInfoSync().platform; |  | ||||||
| 					this.$requst.get('/universal/api.other/update_version',{version:widgetInfo.version}).then(res=>{ |  | ||||||
| 						if(res.code) { |  | ||||||
| 							// 判断是否需要更新 |  | ||||||
| 							if (res.data.status) { |  | ||||||
| 								//content是版本更新内容 \n换行 |  | ||||||
| 								uni.showModal({ |  | ||||||
| 									title:`检测到有新版本`, |  | ||||||
| 									content:res.data.note, |  | ||||||
| 									confirmText:'更新', |  | ||||||
| 									cancelText:'取消', |  | ||||||
| 									success: (result) => { |  | ||||||
| 										if(result.confirm) { |  | ||||||
| 											//ios用户pkgUrl是苹果市场App地址,android自定义下载地址 |  | ||||||
| 											if(platform == 'ios'){ |  | ||||||
| 												// plus.runtime.launchApplication({ |  | ||||||
| 												// 	action: `itms-apps://itunes.apple.com/cn/app/id${appleId}?mt=8` |  | ||||||
| 												// }, function(e) { |  | ||||||
| 												// 	console.log('Open system default browser failed: ' + e.message); |  | ||||||
| 												// }); |  | ||||||
| 												plus.runtime.openURL(res.data.ios_url); |  | ||||||
| 											}else{ |  | ||||||
| 												var downloadTask = uni.downloadFile({ |  | ||||||
| 													url: res.data.android_url, |  | ||||||
| 													success: (downloadResult) => { |  | ||||||
| 														if (downloadResult.statusCode === 200) { |  | ||||||
| 															plus.runtime.install(downloadResult.tempFilePath, {force: false }, function() { |  | ||||||
| 																plus.runtime.restart(); |  | ||||||
| 															}, (e) => { |  | ||||||
| 																uni.showToast({ |  | ||||||
| 																	title: '安装升级包失败', |  | ||||||
| 																	icon: 'none' |  | ||||||
| 																}) |  | ||||||
| 															}); |  | ||||||
| 														} |  | ||||||
| 													} |  | ||||||
| 												}); |  | ||||||
| 												downloadTask.onProgressUpdate((e)=>{ |  | ||||||
| 													// 监听进度条 |  | ||||||
| 													// this.progress = e.progress |  | ||||||
| 												}) |  | ||||||
| 											} |  | ||||||
| 										} |  | ||||||
| 									} |  | ||||||
| 								}) |  | ||||||
| 							}  |  | ||||||
| 						} |  | ||||||
| 					}) |  | ||||||
| 				}); |  | ||||||
| 			}, | 			}, | ||||||
| 			// 去服务协议、服务条款、隐私政策、合作协议、飞猴云服务页面 | 			// 去服务协议、服务条款、隐私政策、合作协议、飞猴云服务页面 | ||||||
| 			gopageEv(index) { | 			gopageEv(index) { | ||||||
|  |  | ||||||
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 799 B After Width: | Height: | Size: 375 B | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 769 B After Width: | Height: | Size: 395 B | 
		Loading…
	
		Reference in New Issue