巴林闲侠 2 years ago
parent
commit
44a611cc4e
  1. 4
      api/app/lib/controllers/data/vehicle.js
  2. 2
      api/app/lib/models/report.js
  3. 4
      scripts/1.3.0/schema/6.update_report.sql
  4. 9
      scripts/1.3.1/schema/4.update_report.sql
  5. 2
      weapp/src/packages/patrol/index.jsx
  6. 3
      web/client/src/sections/auth/containers/login.js
  7. 4
      web/client/src/sections/fillion/components/uploads.js
  8. 11
      web/client/src/sections/fillion/containers/maintenanceSpotCheck.js
  9. 19
      web/client/src/sections/quanju/containers/footer/guanli/index.js
  10. 547
      web/client/src/sections/quanju/containers/footer/guanli/style.less
  11. 223
      web/client/src/sections/quanju/containers/footer/leadership/right/right-bottom.js
  12. 3
      web/client/src/sections/quanju/containers/heand/index.js

4
api/app/lib/controllers/data/vehicle.js

@ -7,8 +7,8 @@ async function get(ctx) {
const { type } = ctx.request.body; const { type } = ctx.request.body;
const { name } = ctx.query; const { name } = ctx.query;
const sequelize = ctx.fs.dc.orm const sequelize = ctx.fs.dc.orm
const sqlStr = `select count(p.road_marking) 标线,count(p.roadside_ditch) 边沟, const sqlStr = `select sum(p.road_marking) 标线,sum(p.roadside_ditch) 边沟,
count(p.guardrail) 护栏, count(p.roadside_trees) 行道树,count(p.wrong_lane) 错车道 sum(p.guardrail) 护栏, sum(p.roadside_trees) 行道树,sum(p.wrong_lane) 错车道
from ( from (
select t.*,row_number() over (partition by t.luduan order by t.time desc ) rn from ( select t.*,row_number() over (partition by t.luduan order by t.time desc ) rn from (
select code_road||'-'||road_section_start||'-'||road_section_end luduan, select code_road||'-'||road_section_start||'-'||road_section_end luduan,

2
api/app/lib/models/report.js

@ -163,7 +163,7 @@ module.exports = dc => {
handleState: { handleState: {
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: true, allowNull: true,
defaultValue: null, defaultValue: '已处理',
comment: null, comment: null,
primaryKey: false, primaryKey: false,
field: "handle_state", field: "handle_state",

4
scripts/1.3.0/schema/6.update_report.sql

@ -1,4 +0,0 @@
alter table report
add handle_opinions varchar(1024);
comment on column report.handle_opinions is '处理意见';

9
scripts/1.3.1/schema/4.update_report.sql

@ -1,6 +1,13 @@
ALTER TABLE "public"."report" ALTER TABLE "public"."report"
ADD COLUMN "handle_advice" varchar(1024); ADD COLUMN "handle_advice" varchar(1024)
add handle_opinions varchar(1024);
COMMENT ON COLUMN "public"."report"."handle_state" IS '待处理 / 已指派 / 已处理 / 不处理'; COMMENT ON COLUMN "public"."report"."handle_state" IS '待处理 / 已指派 / 已处理 / 不处理';
COMMENT ON COLUMN "public"."report"."handle_advice" IS '管理员处理意见'; COMMENT ON COLUMN "public"."report"."handle_advice" IS '管理员处理意见';
comment on column report.handle_opinions is '处理意见';

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

@ -871,7 +871,7 @@ const Index = () => {
if (isSuperAdmin) { if (isSuperAdmin) {
data = { data = {
handleState: isAppoint ? '已指派' : '不处理', handleState: isAppoint ? '已指派' : '不处理',
performerId: userList[appointUser].id, performerId: userList[appointUser]?.id,
handleAdvice, handleAdvice,
} }
} else { } else {

3
web/client/src/sections/auth/containers/login.js

@ -31,7 +31,8 @@ const Login = props => {
if (user && user.authorized) { if (user && user.authorized) {
hasAuth = allroutes?.filter((item) => { return user?.userResources.find((child) => { return child.resourceId === item.authCode }) }) hasAuth = allroutes?.filter((item) => { return user?.userResources.find((child) => { return child.resourceId === item.authCode }) })
if (user?.username === 'SuperAdmin') { if (user?.username === 'SuperAdmin') {
dispatch(push('/fillion/infor')) dispatch(push('/fillion/luzheng'))
} }
else if (hasAuth && hasAuth.length > 0) { else if (hasAuth && hasAuth.length > 0) {
const path = hasAuth[0].path const path = hasAuth[0].path

4
web/client/src/sections/fillion/components/uploads.js

@ -56,12 +56,13 @@ class Uploads extends Component {
componentWillReceiveProps (np) { componentWillReceiveProps (np) {
const { dispatch, value: thisEditData, onChange } = this.props; const { dispatch, value: thisEditData, onChange } = this.props;
const { value: nextEditData, clearFileList } = np; const { value: nextEditData, clearFileList } = np;
console.log(nextEditData,'哈哈哈哈')
const setFileList = () => { const setFileList = () => {
let defaultFileList = []; let defaultFileList = [];
defaultFileList = nextEditData.map((u, index) => { defaultFileList = nextEditData.map((u, index) => {
// let fileUrl = `${this.ApiRoot}/${u.storageUrl}`; // let fileUrl = `${this.ApiRoot}/${u.storageUrl}`;
let fileUrl = `${u.storageUrl}`; let fileUrl = `${u.url}`;
return { return {
uid: -index - 1, uid: -index - 1,
name: this.dealName(u.storageUrl), name: this.dealName(u.storageUrl),
@ -75,7 +76,6 @@ class Uploads extends Component {
fileList: defaultFileList fileList: defaultFileList
}); });
}; };
if (nextEditData && nextEditData.length) { if (nextEditData && nextEditData.length) {
if (!thisEditData || !this.state.fileList.length) { if (!thisEditData || !this.state.fileList.length) {
setFileList(); setFileList();

11
web/client/src/sections/fillion/containers/maintenanceSpotCheck.js

@ -450,7 +450,7 @@ const MaintenanceSpotCheck = (props) => {
<Modal visible={vis} onCancel={cancelHandler} title='养护抽查' onOk={okHandler}> <Modal visible={vis} onCancel={cancelHandler} title='养护抽查' onOk={okHandler}>
<Form form={form}> <Form form={form}>
<Form.Item <Form.Item
label="抽取比例" label="抽取比例(%)"
// name="percent" // name="percent"
rules={[{ required: true, message: '请填写抽取比例' }]} rules={[{ required: true, message: '请填写抽取比例' }]}
> >
@ -468,19 +468,18 @@ const MaintenanceSpotCheck = (props) => {
> >
<Input style={{ width: '80%' }} placeholder="请输入抽取比例" /> <Input style={{ width: '80%' }} placeholder="请输入抽取比例" />
</Form.Item> </Form.Item>
<Form.Item {/* <Form.Item
// name="percentSign" // name="percentSign"
noStyle noStyle
style={{ width: '20%', textAlign: 'center' }} style={{ width: '20%', textAlign: 'center' }}
> >
% %
</Form.Item> </Form.Item> */}
</Input.Group> </Input.Group>
</Form.Item> </Form.Item>
<Form.Item className="ant-row" > <Form.Item className="ant-row" >
<div style={{ display: 'flex', justifyContent: 'center' }}>
<Button type='primary' onClick={extractHandler}>开始抽取</Button> <Button style={{ marginLeft: '40%' }} type='primary' onClick={extractHandler}>开始抽取</Button>
</div>
</Form.Item> </Form.Item>
<Form.Item label='抽查总数' name='result'> <Form.Item label='抽查总数' name='result'>
<Input disabled /> <Input disabled />

19
web/client/src/sections/quanju/containers/footer/guanli/index.js

@ -65,7 +65,6 @@ const Guanli = (props) => {
} }
useEffect(() => { useEffect(() => {
requestleftDatas(); requestleftDatas();
// requestRightDatas() // requestRightDatas()
@ -79,12 +78,14 @@ const Guanli = (props) => {
if (index < 120) { if (index < 120) {
return <div key={index} className='guanli-right-item'> return <div key={index} className='guanli-right-item'>
<Tooltip title={<div className='popover-content'> <Tooltip title={<div className='popover-content'>
<div style={{ width: '100%', height: "100%", marginTop: "0", display: "flex" }}> <div style={{ width: '100%', height: "100%", marginTop: "0",paddingBottom: 20, display: "flex" }}>
{picfile?.length > 0 ? <Carousel autoplay style={{ width: 200, height: 200, margin: "20px 0px 0px 20px" }}> {picfile?.length > 0 ? <Carousel autoplay style={{ width: 200, height: 200, margin: "20px 0px 0px 20px" }}>
{picfile?.map(v => <Image {picfile?.map(v => <img className='picfileimg'
width={200} style={{ width: 200, height: 200,display: 'inline-block', }}
src={`/_file-server/${v.storageUrl}`} // src={`/_file-server/${v.storageUrl}`}
src={v.url}
width={`200px`}
/>)} />)}
</Carousel> </Carousel>
: <img src="/" style={{ : <img src="/" style={{
@ -102,14 +103,14 @@ const Guanli = (props) => {
{enforcementdate && moment(enforcementdate).format("YYYY-MM-DD") || "--"} {enforcementdate && moment(enforcementdate).format("YYYY-MM-DD") || "--"}
</span></p> </span></p>
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC", display: "flex" }}> <p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC", display: "flex" }}>
执法道路:<span style={{ 执法道路:<span title={roadname} style={{
color: "#EEF4FF", marginLeft: "10px", fontFamily: " PingFangSC-Medium, PingFang SC", color: "#EEF4FF", marginLeft: "10px", fontFamily: " PingFangSC-Medium, PingFang SC",
overflow: 'hidden', whiteSpace: "nowrap", textOverflow: "ellipsis", display: 'inline-block', width: 160 overflow: 'hidden', whiteSpace: "nowrap", textOverflow: "ellipsis", display: 'inline-block', width: 160
}}> }}>
{roadname} {roadname}
</span></p> </span></p>
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC", display: "flex" }}> <p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC", display: "flex" }}>
执法成果:<span style={{ 执法成果:<span title={enforcementreslt} style={{
color: "#EEF4FF", marginLeft: "10px", fontFamily: " PingFangSC-Medium, PingFang SC", color: "#EEF4FF", marginLeft: "10px", fontFamily: " PingFangSC-Medium, PingFang SC",
overflow: 'hidden', whiteSpace: "nowrap", textOverflow: "ellipsis", display: 'inline-block', width: 160 overflow: 'hidden', whiteSpace: "nowrap", textOverflow: "ellipsis", display: 'inline-block', width: 160
}}> }}>
@ -168,7 +169,7 @@ const Guanli = (props) => {
<span>处罚</span> <span>处罚</span>
<span>处理日期</span> <span>处理日期</span>
</div> */} </div> */}
o<div style={{ width: "100%", display: "flex", color: "#FFF" }}> <div style={{ width: "90%",margin:"auto", display: "flex", color: "#FFF" }}>
<div style={{ width: '50%', textAlign: "center" }}>执法日期</div> <div style={{ width: '50%', textAlign: "center" }}>执法日期</div>
<div style={{ width: '50%', textAlign: "center", }}>执法成果</div> <div style={{ width: '50%', textAlign: "center", }}>执法成果</div>
</div> </div>
@ -181,7 +182,7 @@ const Guanli = (props) => {
) )
} }
function mapStateToProps (state) { function mapStateToProps (state) {
const { auth, depMessage } = state; const { auth, depMessage, global } = state;
const pakData = (dep) => { const pakData = (dep) => {
return dep.map((d) => { return dep.map((d) => {
return { return {

547
web/client/src/sections/quanju/containers/footer/guanli/style.less

@ -1,7 +1,7 @@
@media screen and (max-width:1366px) { @media screen and (max-width: 1366px) {
html { html {
font-size: 12px; font-size: 12px;
} }
} }
// .guanli{ // .guanli{
@ -13,291 +13,298 @@
// display: flex; // display: flex;
// justify-content: space-between; // justify-content: space-between;
.guanli-left { .guanli-left {
width: 25%; width: 25%;
height: 100%; height: 100%;
position: absolute; position: absolute;
left: 0; left: 0;
.guanli-left-item { .guanli-left-item {
box-sizing: border-box; box-sizing: border-box;
width: 85%; width: 85%;
position: relative; position: relative;
// height: 30%; // height: 30%;
height: 24vh; height: 24vh;
margin: 0 auto 3%; margin: 0 auto 3%;
display: flex;
align-items: center;
padding: 0 10%;
justify-content: space-between;
border: 2px solid rgba(28, 96, 254, 0.5);
.guanli-left-item-left {
width: 45%;
height: 60%;
display: flex;
flex-direction: column;
align-items: center;
span {
font-size: 1.25rem;
font-family: PingFangSC-Regular, PingFang SC;
font-weight: 400;
color: rgba(216, 240, 255, 0.8);
}
div {
display: flex; display: flex;
align-items: center; justify-content: center;
padding: 0 10%; // align-items: ;
justify-content: space-between; font-size: 2.125rem;
border: 2px solid rgba(28, 96, 254, 0.5000); font-family: YouSheBiaoTiHei;
color: #ffffff;
.guanli-left-item-left { height: 70%;
width: 45%;
height: 60%;
display: flex;
flex-direction: column;
align-items: center;
span {
font-size: 1.25rem;
font-family: PingFangSC-Regular, PingFang SC;
font-weight: 400;
color: rgba(216, 240, 255, 0.8000);
}
div {
display: flex;
justify-content: center;
// align-items: ;
font-size: 2.125rem;
font-family: YouSheBiaoTiHei;
color: #FFFFFF;
height: 70%;
width: 100%;
background: url('/assets/images/quanju/guanlijiance_1.png') no-repeat;
background-size: 100% 80%;
background-position: center bottom;
span {
font-size: 1rem;
font-family: PingFangSC-Regular, PingFang SC;
font-weight: 400;
padding-top: 10%;
margin-left: 5px;
// height: 0;
color: rgba(216, 240, 255, 0.8000);
}
}
// background-color: pink;
}
.guanli-left-item-right {
width: 40%;
height: 50%;
position: relative;
span {
position: absolute;
width: 8px;
height: 8px;
background-color: #fff;
top: 1.5%;
left: 50%;
z-index: 10;
border-radius: 4px;
display: block;
}
// background-color: pink;
}
// background-color: pink;
}
}
.guanli-right {
width: 25%;
height: 100%;
position: absolute;
right: 0;
.guanli-right-top {
width: 100%; width: 100%;
// height: 5%; background: url("/assets/images/quanju/guanlijiance_1.png") no-repeat;
display: flex; background-size: 100% 80%;
justify-content: flex-end; background-position: center bottom;
align-items: center;
padding-right: 10px;
img {
width: 4%;
// height: 40%;
}
span { span {
&:nth-child(2) { font-size: 1rem;
font-size: 16px; font-family: PingFangSC-Regular, PingFang SC;
font-family: PingFangSC-Regular, PingFang SC; font-weight: 400;
font-weight: 400; padding-top: 10%;
color: rgba(216, 240, 255, 0.8000); margin-left: 5px;
margin: 0 10px 0 2px // height: 0;
} color: rgba(216, 240, 255, 0.8);
&:nth-child(3) {
font-size: 18px;
font-family: PingFangSC-Medium, PingFang SC;
font-weight: 500;
color: #FFFFFF;
margin-right: 10px;
}
&:nth-child(4) {
font-size: 14px;
font-family: PingFangSC-Regular, PingFang SC;
font-weight: 400;
color: rgba(216, 240, 255, 0.8000);
}
} }
}
// background-color: pink;
}
.guanli-left-item-right {
width: 40%;
height: 50%;
position: relative;
span {
position: absolute;
width: 8px;
height: 8px;
background-color: #fff;
top: 1.5%;
left: 50%;
z-index: 10;
border-radius: 4px;
display: block;
}
// background-color: pink;
} }
.guanli-right-title { // background-color: pink;
width: 90%; }
height: 5%; }
margin: auto;
display: flex;
align-items: center;
justify-content: space-around;
background: rgba(21, 77, 160, 0.2000);
span { .guanli-right {
font-size: 12px; width: 25%;
font-family: PingFangSC-Medium, PingFang SC; height: 100%;
font-weight: 500; position: absolute;
color: #FFFFFF; right: 0;
flex: 1;
text-align: center; .guanli-right-top {
// &:nth-child(1){ width: 100%;
// height: 5%;
// } display: flex;
} justify-content: flex-end;
align-items: center;
padding-right: 10px;
img {
width: 4%;
// height: 40%;
} }
.guanli-right-item { span {
width: 90%; &:nth-child(2) {
// height: 4%; font-size: 16px;
height: 3vh; font-family: PingFangSC-Regular, PingFang SC;
margin: auto; font-weight: 400;
display: flex; color: rgba(216, 240, 255, 0.8);
align-items: center; margin: 0 10px 0 2px;
justify-content: space-around; }
&:hover { &:nth-child(3) {
background: linear-gradient(270deg, rgba(0, 124, 230, 0) 0%, rgba(0, 70, 200, 0.8700) 100%); font-size: 18px;
} font-family: PingFangSC-Medium, PingFang SC;
font-weight: 500;
color: #ffffff;
margin-right: 10px;
}
&:nth-child(4) {
font-size: 14px;
font-family: PingFangSC-Regular, PingFang SC;
font-weight: 400;
color: rgba(216, 240, 255, 0.8);
}
}
}
.guanli-right-title {
width: 90%;
height: 5%;
margin: auto;
display: flex;
align-items: center;
justify-content: space-around;
background: rgba(21, 77, 160, 0.2);
span {
font-size: 12px;
font-family: PingFangSC-Medium, PingFang SC;
font-weight: 500;
color: #ffffff;
flex: 1;
text-align: center;
// &:nth-child(1){
// }
}
}
.guanli-right-item {
width: 90%;
// height: 4%;
height: 3vh;
margin: auto;
display: flex;
align-items: center;
justify-content: space-around;
&:hover {
background: linear-gradient(
270deg,
rgba(0, 124, 230, 0) 0%,
rgba(0, 70, 200, 0.87) 100%
);
}
// background: rgba(21,77,160,0.2000); // background: rgba(21,77,160,0.2000);
span { span {
font-size: 0.875rem; font-size: 0.875rem;
font-family: PingFangSC-Regular, PingFang SC; font-family: PingFangSC-Regular, PingFang SC;
font-weight: 400; font-weight: 400;
color: rgba(216, 240, 255, 0.8000); color: rgba(216, 240, 255, 0.8);
line-height: 20px; line-height: 20px;
flex: 1; flex: 1;
text-align: center; text-align: center;
// &:nth-child(1){ // &:nth-child(1){
// } // }
}
} }
}
} }
.popover-content { .popover-content {
// background-color: red; // background-color: red;
// .ant-popover-inner-content{ // .ant-popover-inner-content{
// padding: 0!important; // padding: 0!important;
// } // }
// .address { // .address {
// width: 80%; // width: 80%;
// height: 80%; // height: 80%;
// top: 10%; // top: 10%;
// position: absolute; // position: absolute;
// // background-color: pink; // // background-color: pink;
// .address1 { // .address1 {
// width: 194px; // width: 194px;
// height: 20px; // height: 20px;
// margin: 16px 0 24px 26px; // margin: 16px 0 24px 26px;
// span { // span {
// &:nth-child(1) { // &:nth-child(1) {
// margin-right: 20px; // margin-right: 20px;
// width: 42px; // width: 42px;
// height: 20px; // height: 20px;
// display: inline-block; // display: inline-block;
// overflow-wrap: break-word; // overflow-wrap: break-word;
// color: rgba(216, 240, 255, 0.8); // color: rgba(216, 240, 255, 0.8);
// font-size: 14px; // font-size: 14px;
// font-family: PingFangSC-Regular; // font-family: PingFangSC-Regular;
// white-space: nowrap; // white-space: nowrap;
// line-height: 20px; // line-height: 20px;
// text-align: left; // text-align: left;
// } // }
// &:nth-child(2) { // &:nth-child(2) {
// width: 28px; // width: 28px;
// height: 20px; // height: 20px;
// display: inline-block; // display: inline-block;
// overflow-wrap: break-word; // overflow-wrap: break-word;
// color: rgba(238, 244, 255, 1); // color: rgba(238, 244, 255, 1);
// font-size: 14px; // font-size: 14px;
// font-family: PingFangSC-Medium; // font-family: PingFangSC-Medium;
// white-space: nowrap; // white-space: nowrap;
// line-height: 20px; // line-height: 20px;
// text-align: left; // text-align: left;
// } // }
// } // }
// } // }
// .address2 { // .address2 {
// width: 194px; // width: 194px;
// height: 20px; // height: 20px;
// margin: 16px 0 24px 26px; // margin: 16px 0 24px 26px;
// span { // span {
// &:nth-child(1) { // &:nth-child(1) {
// margin-right: 35px; // margin-right: 35px;
// width: 28px; // width: 28px;
// height: 20px; // height: 20px;
// display: inline-block; // display: inline-block;
// overflow-wrap: break-word; // overflow-wrap: break-word;
// color: rgba(216, 240, 255, 0.8); // color: rgba(216, 240, 255, 0.8);
// font-size: 14px; // font-size: 14px;
// font-family: PingFangSC-Regular; // font-family: PingFangSC-Regular;
// white-space: nowrap; // white-space: nowrap;
// line-height: 20px; // line-height: 20px;
// text-align: right; // text-align: right;
// } // }
// &:nth-child(2) { // &:nth-child(2) {
// width: 126px; // width: 126px;
// height: 20px; // height: 20px;
// display: inline-block; // display: inline-block;
// overflow-wrap: break-word; // overflow-wrap: break-word;
// color: rgba(255, 255, 255, 1); // color: rgba(255, 255, 255, 1);
// font-size: 14px; // font-size: 14px;
// font-family: PingFangSC-Medium; // font-family: PingFangSC-Medium;
// white-space: nowrap; // white-space: nowrap;
// line-height: 20px; // line-height: 20px;
// text-align: right; // text-align: right;
// } // }
// } // }
// } // }
// } // }
.picfileimg {
width: 200px !important;
height: 200px !important;
}
} }
.popover { .popover {
.ant-tooltip-inner{ .ant-tooltip-inner {
min-width: 0 !important; min-width: 0 !important;
min-height: 0 !important; min-height: 0 !important;
background-color: rgba(0, 0, 0, 0) !important; background-color: rgba(0, 0, 0, 0) !important;
} }
.ant-tooltip-arrow{ .ant-tooltip-arrow {
display: none; display: none;
} }
// .ant-popover-arrow { // .ant-popover-arrow {
// .ant-popover-arrow-content { // .ant-popover-arrow-content {
// display: none; // display: none;
// } // }
// span { // span {
// display: none; // display: none;
// } // }
// } // }
// .ant-popover-inner { // .ant-popover-inner {
// .ant-popover-inner-content { // .ant-popover-inner-content {
// padding: 0; // padding: 0;
// } // }
// } // }
// .ant-popover-inner{padding:0 !important;} // .ant-popover-inner{padding:0 !important;}
} }

223
web/client/src/sections/quanju/containers/footer/leadership/right/right-bottom.js

@ -1,108 +1,139 @@
import React, { useState, useEffect } from 'react' import React, { useState, useEffect } from 'react'
import Module from '../../../public/module' import Module from '../../../public/module'
import { Spin } from 'antd' import { Carousel, Tooltip, } from 'antd'
import Lun from "./lunbo" import Lun from "./lunbo"
import moment from 'moment'
import "./left.less" import "./left.less"
import { getZhichaolist } from "../../../../actions/example" import { getZhichaolist } from "../../../../actions/example"
import { getRoadadministration } from '../../../../../fillion/actions/luzheng'
import NoData from '../../../public/noData';
import AutoRollComponent from '../../build/AutoRollComponent'
const Rightbottom = (props) => { const Rightbottom = (props) => {
const { dispatch } = props const { dispatch } = props
const style = { height: "28%", marginTop: "4%" } const style = { height: "28%", marginTop: "4%" }
const [beijing, setBeijing] = useState() const [beijing, setBeijing] = useState()
const [list, setList] = useState([]) const [list, setList] = useState([])
const [rightDatas, setrightDatas] = useState([]) const [rightDatas, setrightDatas] = useState([])
const [nums, setNums] = useState([]) const [nums, setNums] = useState([])
const [num, setNum] = useState() const [num, setNum] = useState()
const requestRightDatas = async () => { const [rightitemlist, setrightitemlist] = useState([])
const res = await dispatch(getZhichaolist())
var pattern = /[\u4e00-\u9fa5]*/; const requestRightDatas = async () => {
let d = res.payload.data?.overSpeedList?.filter((item, index) => { const res = await dispatch(getZhichaolist())
return /.*[\u4e00-\u9fa5_a-zA-Z]+.*$/.test(item.processingTime) == false var pattern = /[\u4e00-\u9fa5]*/;
}) let d = res.payload.data?.overSpeedList?.filter((item, index) => {
console.log(res); return /.*[\u4e00-\u9fa5_a-zA-Z]+.*$/.test(item.processingTime) == false
d.map((item, index) => { })
if (parseInt(item.processingTime.match(/([^.]*)$/)[0]) < 10) { console.log(res);
return item.processingTime = `${(item.processingTime.match(/^([^.]*)(.[^.]*)/)[0])}.0${parseInt(item.processingTime.match(/([^.]*)$/)[0])}` d.map((item, index) => {
} if (parseInt(item.processingTime.match(/([^.]*)$/)[0]) < 10) {
}) return item.processingTime = `${(item.processingTime.match(/^([^.]*)(.[^.]*)/)[0])}.0${parseInt(item.processingTime.match(/([^.]*)$/)[0])}`
d.sort((a, b) => b.processingTime.localeCompare(a.processingTime)) }
// setrightDatas(res.payload.data) })
setList(d) d.sort((a, b) => b.processingTime.localeCompare(a.processingTime))
} // setrightDatas(res.payload.data)
useEffect(() => { setList(d)
const zhichaolist = dispatch(getZhichaolist()).then((res) => { }
setNums(res.payload?.data?.processed) useEffect(() => {
// const zhichaolist = dispatch(getZhichaolist()).then((res) => {
}) // setNums(res.payload?.data?.processed)
requestRightDatas()
}, []) // })
console.log(list); // requestRightDatas()
const renderBody = () => { roadManagement()
return ( }, [])
<div style={{ width: "100%", height: "50%" }}>
{/* <Spin spinning={!list} tip="Loading" size="large"> */} const roadManagement = async () => {
{list?.map((item, index) => { await dispatch(getRoadadministration({})).then(res => {
return <li style={{ width: "100%", height: "3vh", marginTop: "5px", position: "relative", }} onMouseEnter={() => { if (res.success) {
setBeijing(index) setrightitemlist(res.payload.data?.rows || [])
setNum(index) }
// console.log(beijing); })
}} onMouseLeave={() => {
setBeijing()
setNum()
}}> }
{beijing == index ? <img src='/assets/images/leadership/bei.png' style={{ width: "100%", height: "100%", position: "absolute" }} /> : ""}
<div style={{ width: "30%", height: "100%", textAlign: "center", lineHeight: "3vh", fontSize: "14px", color: beijing == index ? "#FFFFFF" : "rgba(216,240,255,0.8000)", position: "absolute" }}>{item.licensePlate}</div> const renderContent = () => {
<div style={{ width: "10%", height: "100%", textAlign: "center", lineHeight: "3vh", fontSize: "14px", color: beijing == index ? "#FFFFFF" : "rgba(216,240,255,0.8000)", position: "absolute", left: "30%" }}>{item.overrunRate ? item.overrunRate + "%" : "--"}</div>
<div style={{ width: "30%", height: "100%", textAlign: "center", lineHeight: "3vh", fontSize: "14px", color: beijing == index ? "#FFFFFF" : "rgba(216,240,255,0.8000)", position: "absolute", left: "40%" }}>{item.deductPoints ? "-" + item.deductPoints + "分" : ""}{item.deductPoints && item.fine ? "和" : ""}{item.fine ? "-" + item.fine + "元" : ""}{item.deductPoints || item.fine ? "" : "--"}</div> return <div style={{ height: "100%" }}>
<div style={{ width: "30%", height: "100%", textAlign: "center", lineHeight: "3vh", fontSize: "14px", color: beijing == index ? "#FFFFFF" : "rgba(216,240,255,0.8000)", position: "absolute", left: "70%" }}>{item.processingTime ? item.processingTime : "--"}</div> {rightitemlist && rightitemlist.length !== 0 ? rightitemlist?.map(({ enforcementdate, enforcementreslt, roadname, picfile }, index) => {
{ if (index < 120) {
num == index ? <div style={{ position: "fixed", width: "400px", height: "200px", zIndex: 100, left: "55%", marginTop: "0", top: "78%" }}> return <div key={index} className='guanli-right-item'>
<img src='/assets/images/leadership/beijinglan.png' style={{ width: "100%", height: "100%" }} /> <Tooltip title={<div className='popover-content'>
<div style={{ position: "absolute", top: "0", width: "50%", padding: "20px" }}> <div style={{ width: '100%', height: "100%", marginTop: "0", paddingBottom: 20, display: "flex" }}>
<img src='/assets/images/leadership/yuanxing.png' style={{ width: "100%", height: "100%" }} />
<p style={{ color: "#09BAFF", position: "absolute", top: "42%", left: "27%", fontSize: "29px", fontFamily: "YouSheBiaoTiHei" }}>{item.overrunRate ? item.overrunRate + "%" : "--"}</p> {picfile?.length > 0 ? <Carousel autoplay style={{ width: 200, height: 200, margin: "20px 0px 0px 20px" }}>
<p style={{ color: "rgba(216,240,255,0.8)", position: "absolute", top: "60%", left: "43%", fontSize: "14px" }}>超限</p> {picfile?.map(v => <img className='picfileimg'
</div> style={{ width: 200, height: 200, display: 'inline-block', }}
<div style={{ position: "absolute", top: "0", width: "50%", left: "50%", paddingRight: "10px" }}> // src={`/_file-server/${v.storageUrl}`}
<p style={{ color: "rgba(216,240,255,0.8)", marginTop: "30px", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC" }}>车牌号<span style={{ color: "#EEF4FF", marginLeft: "33px", fontFamily: " PingFangSC-Medium, PingFang SC" }}>{item.licensePlate}</span></p> src={v.url}
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC" }}>检测点<span style={{ color: "#EEF4FF", marginLeft: "30px", fontFamily: " PingFangSC-Medium, PingFang SC" }}>{item.nameOfInspectionPoint ? item.nameOfInspectionPoint : "--"}</span></p> width={`200px`}
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC" }}>处罚<span style={{ color: "#FF0001", marginLeft: "50px", fontFamily: " PingFangSC-Medium, PingFang SC" }}>{item.deductPoints ? "-" + item.deductPoints + "分" : ""}{item.deductPoints && item.fine ? "和" : ""}{item.fine ? "-" + item.fine + "元" : ""}{item.deductPoints || item.fine ? "" : "--"}</span></p> />)}
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC" }}>日期<span style={{ color: "#EEF4FF", marginLeft: "50px", fontFamily: " PingFangSC-Medium, PingFang SC" }}>{item.processingTime ? item.processingTime : "--"}</span></p> </Carousel>
</div> : <img src="/" style={{
</div> : "" width: 200, height: 200, margin: "20px 0px 0px 20px", display: 'inline-block', borderRight: "1px solid #FFF",
}} />
} }
</li>
})
}
{/* </Spin> */} <div style={{ width: 240, marginLeft: 20, marginTop: 20, display: "flex", flexDirection: "column", justifyContent: "space-around" }}>
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC", display: "flex" }}>
执法日期:<span style={{
color: "#EEF4FF", marginLeft: "10px", fontFamily: " PingFangSC-Medium, PingFang SC",
overflow: 'hidden', whiteSpace: "nowrap", textOverflow: "ellipsis"
}}>
{enforcementdate && moment(enforcementdate).format("YYYY-MM-DD") || "--"}
</span></p>
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC", display: "flex" }}>
执法道路:<span title={roadname} style={{
color: "#EEF4FF", marginLeft: "10px", fontFamily: " PingFangSC-Medium, PingFang SC",
overflow: 'hidden', whiteSpace: "nowrap", textOverflow: "ellipsis", display: 'inline-block', width: 160
}}>
{roadname}
</span></p>
<p style={{ color: "rgba(216,240,255,0.8)", fontSize: "14px", fontFamily: "PingFangSC-Regular, PingFang SC", display: "flex" }}>
执法成果:<span title={enforcementreslt} style={{
color: "#EEF4FF", marginLeft: "10px", fontFamily: " PingFangSC-Medium, PingFang SC",
overflow: 'hidden', whiteSpace: "nowrap", textOverflow: "ellipsis", display: 'inline-block', width: 160
}}>
{enforcementreslt}</span></p>
</div>
</div>
</div>}
placement="leftTop"
overlayStyle={{ minWidth: 500, minHeight: 200, paddingTop: 10, margin: 0, backgroundImage: `url(../../../../../assets/images/leadership/beijinglan.png)` }}
overlayClassName='popover'
>
<div style={{ width: '100%', height: '100%', display: 'flex', color: "#FFF" }}>
<div style={{ width: '50%', textAlign: "center", }}>{enforcementdate && moment(enforcementdate).format("YYYY-MM-DD") || "--"}</div>
<div title={enforcementreslt} style={{ width: '50%', textAlign: "center", overflow: 'hidden', whiteSpace: "nowrap", textOverflow: "ellipsis" }}>{enforcementreslt}</div>
</div>
</Tooltip>
</div>
}
}) : ""}
</div>
}
return (
<>
<Module style={style} title={"道路隐患排查治理"}>
<div style={{ width: "90%", margin: "auto", display: "flex", color: "#FFF" }}>
<div style={{ width: '50%', textAlign: "center" }}>执法日期</div>
<div style={{ width: '50%', textAlign: "center", }}>执法成果</div>
</div> </div>
) {rightitemlist && rightitemlist.length !== 0 ? <AutoRollComponent content={renderContent()}
} containerStyle={{ position: "relative", height: "90%", }}
return ( divHeight={"100%"} divId={"chart-overview-deviceList"} /> : <NoData style={{ height: "20%" }} />}
<>
<Module style={style} title={"治超详情"}> </Module>
</>
<div style={{ position: "relative", width: "90%", height: "5%", left: "5%", textAlign: "right", fontSize: "16px", top: "-3%", color: "rgba(216,240,255,0.8)" }}> )
<img src='/assets/images/leadership/jiejue.png' style={{ width: "4.5%", height: "2vh", marginTop: "-1%" }} />
已处理<span style={{ color: "#FFFFFF", fontSize: "18px", paddingLeft: "2%", paddingRight: "2%" }}>{nums ? nums : 0}</span>
</div>
<div style={{ width: "90%", height: "3vh", backgroundColor: "rgba(21,77,160,0.2)", position: "relative", left: "5%", top: "5%" }}>
<p style={{ width: "30%", fontSize: "12px", color: "#FFFFFF", height: "100%", textAlign: "center", position: "absolute", lineHeight: "3vh" }}>车牌号</p>
<p style={{ width: "10%", fontSize: "12px", color: "#FFFFFF", height: "100%", textAlign: "center", position: "absolute", lineHeight: "3vh", left: "30%" }}>超限</p>
<p style={{ width: "30%", fontSize: "12px", color: "#FFFFFF", height: "100%", textAlign: "center", position: "absolute", lineHeight: "3vh", left: "40%" }}>处罚</p>
<p style={{ width: "30%", fontSize: "12px", color: "#FFFFFF", height: "100%", textAlign: "center", position: "absolute", lineHeight: "3vh", left: "70%" }}>处理日期</p>
</div>
{/* <Spin tip="Loading..." spinning={false} > */}
<Lun
content={renderBody()}
containerStyle={{ position: "relative", height: "70%", width: "90%", left: "5%", top: "8%" }}
divHeight={"100%"}
divId={"screen-slope-midde-top"}
/>
{/* </Spin> */}
</Module>
</>
)
} }
export default Rightbottom export default Rightbottom

3
web/client/src/sections/quanju/containers/heand/index.js

@ -17,8 +17,9 @@ const Header = (props) => {
const allroutes = JSON.parse(sessionStorage.getItem('allRoutes')) || [] const allroutes = JSON.parse(sessionStorage.getItem('allRoutes')) || []
const hasAuth = allroutes?.filter((item) => { return user?.userResources.find((child) => { return child.resourceId === item.authCode }) }) const hasAuth = allroutes?.filter((item) => { return user?.userResources.find((child) => { return child.resourceId === item.authCode }) })
if (user?.username === 'SuperAdmin') { if (user?.username === 'SuperAdmin') {
dispatch(push('/fillion/infor')) dispatch(push('/fillion/luzheng'))
} }
else if (hasAuth && hasAuth.length > 0) { else if (hasAuth && hasAuth.length > 0) {
const path = hasAuth[0].path const path = hasAuth[0].path
console.log('sasa', `${path}`) console.log('sasa', `${path}`)

Loading…
Cancel
Save