Browse Source

(+)异常反馈过滤

dev
ww664853070 2 years ago
parent
commit
4266ff0707
  1. 32
      weapp/src/packages/patrol/index.jsx
  2. 31
      weapp/src/packages/patrolView/index.jsx
  3. 8
      weapp/src/packages/patrolView/index.scss
  4. 6
      web/client/src/sections/fillion/components/patrolTable.js

32
weapp/src/packages/patrol/index.jsx

@ -59,6 +59,7 @@ const Index = () => {
const [handleId, setHandleId] = useState([]) const [handleId, setHandleId] = useState([])
const [video, setVideo] = useState('') const [video, setVideo] = useState('')
const [videoqn, setVideoqn] = useState([]) const [videoqn, setVideoqn] = useState([])
const [handleType, setHandleType] = useState('')
const prjType = const prjType =
isAnomaly ? isAnomaly ?
@ -140,13 +141,14 @@ const Index = () => {
setRoadSectionEnd(data.roadSectionEnd) setRoadSectionEnd(data.roadSectionEnd)
setAddress(data.address) setAddress(data.address)
setContent(data.content) setContent(data.content)
setHandleType(data.handleState)
setScenePic(data.scenePic ? data.scenePic.map(item => ({ url: imgUrl + item })) : []) setScenePic(data.scenePic ? data.scenePic.map(item => ({ url: imgUrl + item })) : [])
setHandlePic(data.handlePic ? data.handlePic.map(item => ({ url: imgUrl + item })) : []) setHandlePic(data.handlePic ? data.handlePic.map(item => ({ url: imgUrl + item })) : [])
setConserveBeforePic(data.conserveBeforePic ? data.conserveBeforePic.map(item => ({ url: imgUrl + item })) : []) setConserveBeforePic(data.conserveBeforePic ? data.conserveBeforePic.map(item => ({ url: imgUrl + item })) : [])
setConserveUnderwayPic(data.conserveUnderwayPic ? data.conserveUnderwayPic.map(item => ({ url: imgUrl + item })) : []) setConserveUnderwayPic(data.conserveUnderwayPic ? data.conserveUnderwayPic.map(item => ({ url: imgUrl + item })) : [])
setConserveAfterPic(data.conserveAfterPic ? data.conserveAfterPic.map(item => ({ url: imgUrl + item })) : []) setConserveAfterPic(data.conserveAfterPic ? data.conserveAfterPic.map(item => ({ url: imgUrl + item })) : [])
setHandleId(data.id) setHandleId(data.id)
setVideo(imgUrl + data.videoUrl[0]) setVideo(data.videoUrl[0] ? imgUrl + data.videoUrl[0] : '')
if (data.handleContent) { if (data.handleContent) {
setHandleCenter(data.handleContent) setHandleCenter(data.handleContent)
} }
@ -249,7 +251,7 @@ const Index = () => {
]) ])
}, [reportType]) }, [reportType])
function report () { function report() {
if (!canReport) { return } if (!canReport) { return }
if ( if (
(isPatrol && (!projectType || !road)) (isPatrol && (!projectType || !road))
@ -326,7 +328,7 @@ const Index = () => {
}) })
} }
function deleteReport () { function deleteReport() {
Taro.showModal({ Taro.showModal({
title: '提示', title: '提示',
content: '确定删除吗?', content: '确定删除吗?',
@ -353,7 +355,7 @@ const Index = () => {
}) })
} }
function handleInput ({ detail: { value } }, type) { function handleInput({ detail: { value } }, type) {
switch (type) { switch (type) {
case 'roadSectionStart': case 'roadSectionStart':
setRoadSectionStart(value) setRoadSectionStart(value)
@ -388,15 +390,15 @@ const Index = () => {
} }
} }
function handleTypeChange (e) { function handleTypeChange(e) {
setReportType(e.detail.value) setReportType(e.detail.value)
} }
function handleImgChange (files, operationType, index, type) { function handleImgChange(files, operationType, index, type) {
if (operationType === 'remove') { if (operationType === 'remove') {
setImg(false) setImg(false)
} }
function setImg (isAdd, url) { function setImg(isAdd, url) {
switch (type) { switch (type) {
case 'scenePic': case 'scenePic':
let nextImg = sceneImg let nextImg = sceneImg
@ -496,12 +498,12 @@ const Index = () => {
} }
} }
function handleImgClick (index, file) { function handleImgClick(index, file) {
Taro.previewImage({ Taro.previewImage({
urls: [file.url] // http urls: [file.url] // http
}) })
} }
function handleImgClicks (index, file) { function handleImgClicks(index, file) {
Taro.previewImage({ Taro.previewImage({
urls: [file] // http urls: [file] // http
}) })
@ -523,7 +525,7 @@ const Index = () => {
} }
} }
}, [road]) }, [road])
function handleOk () { function handleOk() {
if (!canReport) { return } if (!canReport) { return }
let str = handleCenter.trim() let str = handleCenter.trim()
if (!str) { if (!str) {
@ -568,7 +570,7 @@ const Index = () => {
} }
}) })
} }
function addVideo () { function addVideo() {
wx.chooseMedia({ wx.chooseMedia({
count: 1, count: 1,
mediaType: ['video'], mediaType: ['video'],
@ -611,6 +613,7 @@ const Index = () => {
} }
}) })
} }
console.log(handleType,'handleType');
return ( return (
<View className='patrol'> <View className='patrol'>
{/* { {/* {
@ -941,11 +944,10 @@ const Index = () => {
<AtButton type='primary' className='sub-btn' onClick={report}>上报</AtButton> <AtButton type='primary' className='sub-btn' onClick={report}>上报</AtButton>
} }
{ {
wait == 'wait' || handle == 'handle' ? <view> handleType == '已处理' || wait == 'wait' || handle == 'handle' ? <view>
<view className='patrol-img'><text style={{ color: 'red' }}>*</text>处理内容</view> <view className='patrol-img'><text style={{ color: 'red' }}>*</text>处理内容</view>
<AtTextarea <AtTextarea
title='处理内容:' title='处理内容:'
placeholder='请输入处理内容'
value={handleCenter} value={handleCenter}
onChange={(v, e) => handleInput(e, 'wait')} onChange={(v, e) => handleInput(e, 'wait')}
disabled={handle == 'handle' ? true : false} disabled={handle == 'handle' ? true : false}
@ -959,7 +961,7 @@ const Index = () => {
{handlePic.map(item => ( {handlePic.map(item => (
<Image className='img' src={item.url} onClick={() => handleImgClicks(undefined, item)} /> <Image className='img' src={item.url} onClick={() => handleImgClicks(undefined, item)} />
))} ))}
</View> : </View> : handleType != '已处理' ?
<AtImagePicker <AtImagePicker
className='img-picker' className='img-picker'
count={3 - handlePic.length} count={3 - handlePic.length}
@ -967,7 +969,7 @@ const Index = () => {
files={handlePic} files={handlePic}
onChange={(files, operationType, index) => handleImgChange(files, operationType, index, 'wait')} onChange={(files, operationType, index) => handleImgChange(files, operationType, index, 'wait')}
onImageClick={handleImgClick} onImageClick={handleImgClick}
/> /> : ''
} }
{handle != 'handle' ? <AtButton type='primary' className='sub-btn' onClick={handleOk}>提交</AtButton> : ''} {handle != 'handle' ? <AtButton type='primary' className='sub-btn' onClick={handleOk}>提交</AtButton> : ''}
</View> </View>

31
weapp/src/packages/patrolView/index.jsx

@ -14,7 +14,7 @@ import patrolActiveIcon from '../../static/img/patrolView/patrol-active.svg'
import conserveIcon from '../../static/img/patrolView/conserve.svg' import conserveIcon from '../../static/img/patrolView/conserve.svg'
import conserveActiveIcon from '../../static/img/patrolView/conserve-active.svg' import conserveActiveIcon from '../../static/img/patrolView/conserve-active.svg'
function Index () { function Index() {
const userInfo = Taro.getStorageSync('userInfo') || {}; const userInfo = Taro.getStorageSync('userInfo') || {};
const router = useRouter() const router = useRouter()
const { params: { filter, kind, } } = router const { params: { filter, kind, } } = router
@ -32,6 +32,8 @@ function Index () {
const [systemInfo, setSystemInfo] = useState('') const [systemInfo, setSystemInfo] = useState('')
const [page, setPage] = useState(0) const [page, setPage] = useState(0)
const [num, setNum] = useState(Math.random()) const [num, setNum] = useState(Math.random())
const [typeSearchList, setTypeSearchList] = useState(['全部', '待处理', '不处理', '已处理'])
const [typeSearch, setTypeSearch] = useState('全部')
const limit = 10 const limit = 10
@ -54,13 +56,13 @@ function Index () {
useEffect(() => { useEffect(() => {
setPage(0) setPage(0)
setNum(Math.random()) setNum(Math.random())
}, [reportType, datePicker]) }, [reportType, datePicker, typeSearch])
useEffect(() => { useEffect(() => {
getList(page == 0 ? true : false) getList(page == 0 ? true : false)
}, [num]) }, [num])
function dealError (error) { function dealError(error) {
Taro.showToast({ Taro.showToast({
title: error, title: error,
icon: 'none', icon: 'none',
@ -70,6 +72,12 @@ function Index () {
} }
const getList = (isInit) => { const getList = (isInit) => {
Taro.showLoading({ title: '加载中' }) Taro.showLoading({ title: '加载中' })
let handleState = ''
if (typeSearch != '全部') {
handleState = typeSearch
} else {
handleState = isWait ? '待处理' : ishandle ? '已处理' : ''
}
const data = { const data = {
limit, limit,
page, page,
@ -78,7 +86,7 @@ function Index () {
keyword: filterText, keyword: filterText,
reportType: isWait || ishandle ? 'anomaly' : reportType, reportType: isWait || ishandle ? 'anomaly' : reportType,
userId: filter === 'my' && !ishandle ? userInfo.id : '', userId: filter === 'my' && !ishandle ? userInfo.id : '',
handleState: isWait ? '待处理' : ishandle ? '已处理' : '', handleState: handleState,
performerId: isWait || ishandle ? userInfo.id : '' performerId: isWait || ishandle ? userInfo.id : ''
} }
request.get(getReportList(), data).then(res => { request.get(getReportList(), data).then(res => {
@ -143,7 +151,9 @@ function Index () {
const handleDetail = index => { const handleDetail = index => {
Taro.navigateTo({ url: `/packages/patrol/index?type=view&id=${listData[index].id}&kind=${kind == 'wait' || kind == 'handle' ? 'anomaly' : kind}&wait=${kind == 'wait' ? 'wait' : ''}&handle=${kind == 'handle' ? 'handle' : ''}&videoShow=${kind == 'wait' || kind == 'handle' ? 'videoShow' : ''}` }) Taro.navigateTo({ url: `/packages/patrol/index?type=view&id=${listData[index].id}&kind=${kind == 'wait' || kind == 'handle' ? 'anomaly' : kind}&wait=${kind == 'wait' ? 'wait' : ''}&handle=${kind == 'handle' ? 'handle' : ''}&videoShow=${kind == 'wait' || kind == 'handle' ? 'videoShow' : ''}` })
} }
const setType = (e) => {
setTypeSearch(e.detail.value == 1 ? '待处理' : e.detail.value == 2 ? '不处理' : e.detail.value == 3 ? '已处理' : '全部')
}
return ( return (
<View> <View>
{/* { {/* {
@ -163,7 +173,7 @@ function Index () {
} */} } */}
<View className='filter-box' style={{ top: isPatrol && false ? "40px" : '0' }}> <View className='filter-box' style={{ top: isPatrol && false ? "40px" : '0' }}>
<View className='filter-item'> <View className='filter-item' style={{ width: '270rpx' }}>
<View style={{ float: 'left', marginLeft: '20rpx', color: '#333' }}>日期</View> <View style={{ float: 'left', marginLeft: '20rpx', color: '#333' }}>日期</View>
<Picker <Picker
className='picker' className='picker'
@ -177,6 +187,15 @@ function Index () {
<Image className='filter-img' src={chevronDown} /> <Image className='filter-img' src={chevronDown} />
</Picker> </Picker>
</View> </View>
{
kind == 'anomaly' ? <View style={{ display: 'flex', lineHeight: '98rpx', marginRight: '20rpx' }}>
<View style={{ color: '#333' }}>状态</View>
<Picker range={typeSearchList} onChange={setType}>
<View style={{ float: 'left' }}>{typeSearch}</View>
<Image style={{ display: 'block', width: '14rpx', height: '8rpx', float: 'left', marginTop: '44rpx', marginLeft: '10rpx' }} src={chevronDown} />
</Picker>
</View> : ''
}
<View class='head-search'> <View class='head-search'>
<Image className='search-img' src={searchIcon} /> <Image className='search-img' src={searchIcon} />
<Input class='heard-search-input' value={filterText} placeholder={ <Input class='heard-search-input' value={filterText} placeholder={

8
weapp/src/packages/patrolView/index.scss

@ -63,7 +63,7 @@ page {
} }
.head-search { .head-search {
width: 400rpx; width: 300rpx;
display: flex; display: flex;
background: #fff; background: #fff;
padding: 10rpx 26rpx 15rpx; padding: 10rpx 26rpx 15rpx;
@ -73,16 +73,16 @@ page {
border: 2rpx solid #00000011; border: 2rpx solid #00000011;
height: 68rpx; height: 68rpx;
line-height: 68rpx; line-height: 68rpx;
margin: 14rpx 30rpx 14rpx 0; margin: 14rpx 14rpx 14rpx 0;
.search-img { .search-img {
width: 36rpx; width: 44rpx;
height: 36rpx; height: 36rpx;
margin-top: 5rpx; margin-top: 5rpx;
} }
.heard-search-input { .heard-search-input {
margin-left: 26rpx; margin-left: 10rpx;
font-size: 28rpx; font-size: 28rpx;
width: 100%; width: 100%;
color: #333; color: #333;

6
web/client/src/sections/fillion/components/patrolTable.js

@ -254,16 +254,16 @@ const DetailList = (props) => {
<Button <Button
onClick={() => { checkDetail(record); handleOpen(); }} onClick={() => { checkDetail(record); handleOpen(); }}
style={{ marginRight: 10 }}>查看</Button>, style={{ marginRight: 10 }}>查看</Button>,
isAnomaly && record.handleState != '处理' && record.performerId === null && user?.username === 'SuperAdmin' ? isAnomaly && record.handleState != '处理' && record.performerId === null && user?.username === 'SuperAdmin' ?
<Button disabled={user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE' || 'FEEDBACKMANAGE')[0].isshow === "true" ? true : ''} <Button disabled={user?.username !== 'SuperAdmin' && user?.userResources?.filter(i => i.resourceId === 'FEEDBACKMANAGE' || 'FEEDBACKMANAGE')[0].isshow === "true" ? true : ''}
onClick={() => { setVis(true); setRecordId(record.id) }}>指派</Button> : null, onClick={() => { setVis(true); setRecordId(record.id) }}>指派</Button> : null,
isAnomaly && record.handleState != '处理' && record.performerId === null && user?.username === 'SuperAdmin' ? isAnomaly && record.handleState != '处理' && record.performerId === null && user?.username === 'SuperAdmin' ?
< Popover < Popover
content={ content={
[ [
<div style={{ width: '100%', height: 30 }}> <div style={{ width: '100%', height: 30 }}>
<Button onClick={() => setNoProcessingPopVisible(false)} style={{ float: "right" }} ></Button> <Button onClick={() => setNoProcessingPopVisible(false)} style={{ float: "right" }} ></Button>
<Button type="primary" onClick={() => dispatch(handleReport(record.id, { handleState: '处理' })).then(res => { <Button type="primary" onClick={() => dispatch(handleReport(record.id, { handleState: '处理' })).then(res => {
if (res.success) { if (res.success) {
setNoProcessingPopVisible(false) setNoProcessingPopVisible(false)
setNoProcessingSelectRecord(null) setNoProcessingSelectRecord(null)

Loading…
Cancel
Save