|
@ -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> |
|
|
|
|
|
</> : '' |
|
|
</> : '' |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|