|  | @ -206,6 +206,23 @@ const Index = () => { | 
			
		
	
		
		
			
				
					|  |  |   const [appointUser, setAppointUser] = useState(null) // 责任人在userList的index |  |  |   const [appointUser, setAppointUser] = useState(null) // 责任人在userList的index | 
			
		
	
		
		
			
				
					|  |  |   const [handleAdvice, setHandleAdvice] = useState('') // 处理意见 |  |  |   const [handleAdvice, setHandleAdvice] = useState('') // 处理意见 | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |   const [roadTypeList, setRoadTypeList] = useState([ | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       value: '县', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       text: '县道', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       checked: true | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     }, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       value: '乡', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       text: '乡道', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       checked: false | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     }, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       value: '村', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       text: '村道', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       checked: false | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     }, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |   ]); | 
			
		
	
		
		
			
				
					|  |  |   const [routeNameList, setRouteNameList] = useState([]); |  |  |   const [routeNameList, setRouteNameList] = useState([]); | 
			
		
	
		
		
			
				
					|  |  |   const [routeCodeList, setRouteCodeList] = useState([]); |  |  |   const [routeCodeList, setRouteCodeList] = useState([]); | 
			
		
	
		
		
			
				
					|  |  |   const [sectionNoList, setSectionNoList] = useState([]); |  |  |   const [sectionNoList, setSectionNoList] = useState([]); | 
			
		
	
	
		
		
			
				
					|  | @ -328,7 +345,19 @@ const Index = () => { | 
			
		
	
		
		
			
				
					|  |  |             setHandleCenter(data.handleContent) |  |  |             setHandleCenter(data.handleContent) | 
			
		
	
		
		
			
				
					|  |  |           } |  |  |           } | 
			
		
	
		
		
			
				
					|  |  |           setIsBeforeReport(dayjs(data.time).diff('2023-08-03 00:00:00', 'h') < 0) |  |  |           setIsBeforeReport(dayjs(data.time).diff('2023-08-03 00:00:00', 'h') < 0) | 
			
		
	
		
		
			
				
					
					|  |  | 
 |  |  |           // 设置道路类型 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |           let items = roadTypeList | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           const head = data.codeRoad?.slice(0, 1) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           const level = head | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             ? head === 'X' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |               ? '县' : head === 'Y' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 ? '乡' : '村' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             : '' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           for (let i = 0, len = items.length; i < len; ++i) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             items[i].checked = items[i].value === (data.road_?.level || level) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           setRoadTypeList(items) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           // 设置道路路段 | 
			
		
	
		
		
			
				
					|  |  |           setRoadChecked({ |  |  |           setRoadChecked({ | 
			
		
	
		
		
			
				
					|  |  |             routeName: data.road, |  |  |             routeName: data.road, | 
			
		
	
		
		
			
				
					|  |  |             routeCode: data.codeRoad, |  |  |             routeCode: data.codeRoad, | 
			
		
	
	
		
		
			
				
					|  | @ -378,6 +407,7 @@ const Index = () => { | 
			
		
	
		
		
			
				
					|  |  |           }) |  |  |           }) | 
			
		
	
		
		
			
				
					|  |  |         } |  |  |         } | 
			
		
	
		
		
			
				
					|  |  |       }) |  |  |       }) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       // 获取道路路段列表 | 
			
		
	
		
		
			
				
					|  |  |       request.get(getRoadSection()).then(res => { |  |  |       request.get(getRoadSection()).then(res => { | 
			
		
	
		
		
			
				
					|  |  |         Taro.hideLoading() |  |  |         Taro.hideLoading() | 
			
		
	
		
		
			
				
					|  |  |         if (res.statusCode == 200 || res.statusCode == 204) { |  |  |         if (res.statusCode == 200 || res.statusCode == 204) { | 
			
		
	
	
		
		
			
				
					|  | @ -390,12 +420,13 @@ const Index = () => { | 
			
		
	
		
		
			
				
					|  |  |           let routeCode = [] |  |  |           let routeCode = [] | 
			
		
	
		
		
			
				
					|  |  |           let sectionNo = [] |  |  |           let sectionNo = [] | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           const selLevel = roadTypeList.find(item => item.checked).value | 
			
		
	
		
		
			
				
					|  |  |           data.forEach(item => { |  |  |           data.forEach(item => { | 
			
		
	
		
		
			
				
					|  |  |             nextSourceRoadStartSel.push(item.startingPlaceName) |  |  |             nextSourceRoadStartSel.push(item.startingPlaceName) | 
			
		
	
		
		
			
				
					|  |  |             nextSourceRoadEndSel.push(item.stopPlaceName) |  |  |             nextSourceRoadEndSel.push(item.stopPlaceName) | 
			
		
	
		
		
			
				
					|  |  |             nextCodeRoadSel.push(item.routeCode) |  |  |             nextCodeRoadSel.push(item.routeCode) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |             if (item.routeName && !routeName.includes(item.routeName)) { |  |  |             if (item.routeName && !routeName.includes(item.routeName) && item.level === selLevel) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |               routeName.push(item.routeName) |  |  |               routeName.push(item.routeName) | 
			
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |             if (item.routeCode && !routeCode.includes(item.routeCode)) { |  |  |             if (item.routeCode && !routeCode.includes(item.routeCode)) { | 
			
		
	
	
		
		
			
				
					|  | @ -726,22 +757,28 @@ const Index = () => { | 
			
		
	
		
		
			
				
					|  |  |     } |  |  |     } | 
			
		
	
		
		
			
				
					|  |  |   } |  |  |   } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |   const handleRoadCheckChange = (value, key) => { |  |  |   const handleRoadCheckChange = (value, key, typeList = roadTypeList) => { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |     let nextValue = { |  |  |     let nextValue = { | 
			
		
	
		
		
			
				
					|  |  |       ...roadChecked, |  |  |       ...roadChecked, | 
			
		
	
		
		
			
				
					|  |  |       [key]: value |  |  |       [key]: value | 
			
		
	
		
		
			
				
					|  |  |     } |  |  |     } | 
			
		
	
		
		
			
				
					|  |  |     let routeName = [] |  |  |  | 
			
		
	
		
		
			
				
					|  |  |     let routeCode = [] |  |  |     let routeCode = [] | 
			
		
	
		
		
			
				
					|  |  |     let sectionNo = [] |  |  |     let sectionNo = [] | 
			
		
	
		
		
			
				
					
					|  |  |     let data = [...roadList] |  |  |     let data = roadList.filter(r => r.level === typeList.find(t => t.checked).value) | 
			
				
				
			
		
	
		
		
			
				
					|  |  |     data.forEach(v => { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       if (v.routeName && !routeName.includes(v.routeName)) { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         routeName.push(v.routeName) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       } |  |  |  | 
			
		
	
		
		
			
				
					|  |  |     }); |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     if (key == 'routeName') { |  |  |     if (key == 'routeName') { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       // routeName关键字筛选 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       let routeName = [] | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       data.forEach(item => { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         if (item.routeName && !routeName.includes(item.routeName)) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           routeName.push(item.routeName) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       }) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       if (value) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         routeName = routeName.filter(item => item.indexOf(value) > -1) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       setRouteNameList(routeName) | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |       nextValue.routeCode = '' |  |  |       nextValue.routeCode = '' | 
			
		
	
		
		
			
				
					|  |  |       nextValue.sectionNo = '' |  |  |       nextValue.sectionNo = '' | 
			
		
	
		
		
			
				
					|  |  |       data?.forEach(v => { |  |  |       data?.forEach(v => { | 
			
		
	
	
		
		
			
				
					|  | @ -768,8 +805,6 @@ const Index = () => { | 
			
		
	
		
		
			
				
					|  |  |       setSectionNoList(sectionNo) |  |  |       setSectionNoList(sectionNo) | 
			
		
	
		
		
			
				
					|  |  |     } |  |  |     } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     setRouteNameList(routeName) |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |     if (nextValue?.routeName) { |  |  |     if (nextValue?.routeName) { | 
			
		
	
		
		
			
				
					|  |  |       setRouteCodeDisabled(false) |  |  |       setRouteCodeDisabled(false) | 
			
		
	
		
		
			
				
					|  |  |     } else { |  |  |     } else { | 
			
		
	
	
		
		
			
				
					|  | @ -1039,24 +1074,58 @@ const Index = () => { | 
			
		
	
		
		
			
				
					|  |  |       } |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |     }) |  |  |     }) | 
			
		
	
		
		
			
				
					|  |  |   } |  |  |   } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |   function roadTypeChange(e) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     let items = roadTypeList | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     for (let i = 0, len = items.length; i < len; ++i) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       items[i].checked = items[i].value === e.detail.value | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     handleRoadCheckChange('', 'routeName', items) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     setRoadTypeList(items) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |   return ( |  |  |   return ( | 
			
		
	
		
		
			
				
					|  |  |     <View className='patrol'> |  |  |     <View className='patrol'> | 
			
		
	
		
		
			
				
					|  |  |       { |  |  |       { | 
			
		
	
		
		
			
				
					|  |  |         isPatrol || isAnomaly ? <> |  |  |         isPatrol || isAnomaly ? <> | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           <View className='code-choice'> | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             <Text style={{ color: 'red' }}>* </Text>道路类型: | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             <View className='radio-list'> | 
			
		
	
		
		
			
				
					|  |  |  |  |  |               <RadioGroup onChange={roadTypeChange}> | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 {roadTypeList.map((item, i) => { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   return <Radio | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     className='radio' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     color='#2579C7' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     value={item.value} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     checked={item.checked} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     disabled={isView} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   >{item.text}</Radio> | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 })} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |               </RadioGroup> | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             </View> | 
			
		
	
		
		
			
				
					|  |  |  |  |  |           </View> | 
			
		
	
		
		
			
				
					|  |  |           <View className='code-choice'> |  |  |           <View className='code-choice'> | 
			
		
	
		
		
			
				
					|  |  |             <Text style={{ color: 'red' }}>* </Text>路线名称: |  |  |             <Text style={{ color: 'red' }}>* </Text>路线名称: | 
			
		
	
		
		
			
				
					|  |  |             <View className='select-box'> |  |  |             <View className='select-box'> | 
			
		
	
		
		
			
				
					
					|  |  |               <Picker |  |  |               <View className='picker'> | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                 mode='selector' |  |  |                 <Input | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                 range={routeNameList} |  |  |                   style={{ textAlign: 'right' }} | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                 onChange={e => handleRoadCheckChange(routeNameList[e.detail.value], 'routeName')} |  |  |                   type='text' | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                 disabled={isView} |  |  |                   placeholder='输入关键字筛选' | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |               > |  |  |                   border={false} | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                 <View className='picker'> |  |  |                   value={roadChecked.routeName} | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                   <View>{roadChecked.routeName || '请选择路线名称'}</View> |  |  |                   onInput={e => handleRoadCheckChange(e.detail.value, 'routeName')} | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |                   disabled={isView} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 /> | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 <Picker | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   mode='selector' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   range={routeNameList} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   onChange={e => handleRoadCheckChange(routeNameList[e.detail.value], 'routeName')} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   disabled={isView} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 > | 
			
		
	
		
		
			
				
					|  |  |                   <AtIcon className='arrow' value='chevron-down' size='20' color='#999' /> |  |  |                   <AtIcon className='arrow' value='chevron-down' size='20' color='#999' /> | 
			
		
	
		
		
			
				
					
					|  |  |                 </View> |  |  |                 </Picker> | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |               </Picker> |  |  |               </View> | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |               {!isView && <AtIcon |  |  |               {!isView && <AtIcon | 
			
		
	
		
		
			
				
					|  |  |                 value='close-circle' |  |  |                 value='close-circle' | 
			
		
	
		
		
			
				
					|  |  |                 size='20' |  |  |                 size='20' | 
			
		
	
	
		
		
			
				
					|  | @ -1109,18 +1178,6 @@ const Index = () => { | 
			
		
	
		
		
			
				
					|  |  |               />} |  |  |               />} | 
			
		
	
		
		
			
				
					|  |  |             </View> |  |  |             </View> | 
			
		
	
		
		
			
				
					|  |  |           </View> |  |  |           </View> | 
			
		
	
		
		
			
				
					|  |  |           <View className='code-choice'> |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             <Text style={{ color: 'red' }}>* </Text>道路类型: |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             <Input |  |  |  | 
			
		
	
		
		
			
				
					|  |  |               style={{ width: '30%' }} |  |  |  | 
			
		
	
		
		
			
				
					|  |  |               type='text' |  |  |  | 
			
		
	
		
		
			
				
					|  |  |               value={isView && isBeforeReport |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                 ? projectType |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                 : roadCodeHead === 'X' ? '县道' : roadCodeHead === 'Y' ? '乡道' : '村道'} |  |  |  | 
			
		
	
		
		
			
				
					|  |  |               onInput={() => { }} |  |  |  | 
			
		
	
		
		
			
				
					|  |  |               disabled={true} |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             /> |  |  |  | 
			
		
	
		
		
			
				
					|  |  |           </View> |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         </> : '' |  |  |         </> : '' | 
			
		
	
		
		
			
				
					|  |  |       } |  |  |       } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  | 
 |