Merge remote-tracking branch 'origin/master'
New file |
| | |
| | | import request from '@/utils/request' |
| | | |
| | | // 查询考核规则列表 |
| | | export function listCheckRule(query) { |
| | | return request({ |
| | | url: '/check-rule/page', |
| | | method: 'post', |
| | | data: query |
| | | }) |
| | | } |
| | | |
| | | // 查询考核规则详细 |
| | | export function getCheckRule(id) { |
| | | return request({ |
| | | url: '/check-rule/' + id, |
| | | method: 'get' |
| | | }) |
| | | } |
| | | |
| | | // 新增考核规则 |
| | | export function addCheckRule(data) { |
| | | return request({ |
| | | url: '/check-rule', |
| | | method: 'post', |
| | | data: data |
| | | }) |
| | | } |
| | | |
| | | // 修改考核规则 |
| | | export function updateCheckRule(data) { |
| | | return request({ |
| | | url: '/check-rule', |
| | | method: 'put', |
| | | data: data |
| | | }) |
| | | } |
| | | |
| | | // 删除考核规则 |
| | | export function delCheckRule(id) { |
| | | return request({ |
| | | url: '/check-rule/' + id, |
| | | method: 'delete' |
| | | }) |
| | | } |
| | | |
| | | // 获取运维单位下拉列表 |
| | | export function ruleSelect() { |
| | | return request({ |
| | | url: '/check-rule/list', |
| | | method: 'get' |
| | | }) |
| | | } |
New file |
| | |
| | | import request from '@/utils/request' |
| | | |
| | | // 查询考核模板列表 |
| | | export function listCheckTemplate(query) { |
| | | return request({ |
| | | url: '/check-template/page', |
| | | method: 'post', |
| | | data: query |
| | | }) |
| | | } |
| | | |
| | | // 查询考核模板详细 |
| | | export function getCheckTemplate(id) { |
| | | return request({ |
| | | url: '/check-template/' + id, |
| | | method: 'get' |
| | | }) |
| | | } |
| | | |
| | | // 新增考核模板 |
| | | export function addCheckTemplate(data) { |
| | | return request({ |
| | | url: '/check-template', |
| | | method: 'post', |
| | | data: data |
| | | }) |
| | | } |
| | | |
| | | // 修改考核模板 |
| | | export function updateCheckTemplate(data) { |
| | | return request({ |
| | | url: '/check-template', |
| | | method: 'put', |
| | | data: data |
| | | }) |
| | | } |
| | | |
| | | // 删除考核模板 |
| | | export function delCheckTemplate(id) { |
| | | return request({ |
| | | url: '/check-template/' + id, |
| | | method: 'delete' |
| | | }) |
| | | } |
| | |
| | | import request from '@/utils/request' |
| | | |
| | | // 查询违规审核列表 |
| | | export function listAuditing(query) { |
| | | export function listAuditing(data) { |
| | | return request({ |
| | | url: '/default-auditing/page', |
| | | method: 'get', |
| | | params: query |
| | | method: 'post', |
| | | data: data |
| | | }) |
| | | } |
| | | |
| | |
| | | method: 'delete' |
| | | }) |
| | | } |
| | | |
| | | // 审核 |
| | | export function auditing(data) { |
| | | return request({ |
| | | url: '/default-auditing/auditing', |
| | | method: 'post', |
| | | data: data |
| | | }) |
| | | } |
New file |
| | |
| | | /** |
| | | $base-menu-color:hsla(0,0%,100%,.65); |
| | | $base-menu-color-active:#fff; |
| | | $base-menu-background:#001529; |
| | | $base-logo-title-color: #ffffff; |
| | | |
| | | $base-menu-light-color:rgba(0,0,0,.70); |
| | | $base-menu-light-background:#ffffff; |
| | | $base-logo-light-title-color: #001529; |
| | | |
| | | $base-sub-menu-background:#000c17; |
| | | $base-sub-menu-hover:#001528; |
| | | */ |
| | | :export { |
| | | menuColor: #bfcbd9; |
| | | menuLightColor: rgba(0, 0, 0, 0.7); |
| | | menuColorActive: #f4f4f5; |
| | | menuBackground: #304156; |
| | | menuLightBackground: #ffffff; |
| | | subMenuBackground: #1f2d3d; |
| | | subMenuHover: #001528; |
| | | sideBarWidth: 200px; |
| | | logoTitleColor: #ffffff; |
| | | logoLightTitleColor: #001529; |
| | | } |
| | | |
| | | /* fade */ |
| | | .fade-enter-active, |
| | | .fade-leave-active { |
| | | transition: opacity 0.28s; |
| | | } |
| | | |
| | | .fade-enter, |
| | | .fade-leave-active { |
| | | opacity: 0; |
| | | } |
| | | |
| | | /* fade-transform */ |
| | | .fade-transform--move, |
| | | .fade-transform-leave-active, |
| | | .fade-transform-enter-active { |
| | | transition: all .5s; |
| | | } |
| | | |
| | | .fade-transform-enter { |
| | | opacity: 0; |
| | | transform: translateX(-30px); |
| | | } |
| | | |
| | | .fade-transform-leave-to { |
| | | opacity: 0; |
| | | transform: translateX(30px); |
| | | } |
| | | |
| | | /* breadcrumb transition */ |
| | | .breadcrumb-enter-active, |
| | | .breadcrumb-leave-active { |
| | | transition: all .5s; |
| | | } |
| | | |
| | | .breadcrumb-enter, |
| | | .breadcrumb-leave-active { |
| | | opacity: 0; |
| | | transform: translateX(20px); |
| | | } |
| | | |
| | | .breadcrumb-move { |
| | | transition: all .5s; |
| | | } |
| | | |
| | | .breadcrumb-leave-active { |
| | | position: absolute; |
| | | } |
| | | |
| | | .el-breadcrumb__inner, |
| | | .el-breadcrumb__inner a { |
| | | font-weight: 400 !important; |
| | | } |
| | | |
| | | .el-upload input[type="file"] { |
| | | display: none !important; |
| | | } |
| | | |
| | | .el-upload__input { |
| | | display: none; |
| | | } |
| | | |
| | | .cell .el-tag { |
| | | margin-right: 0px; |
| | | } |
| | | |
| | | .small-padding .cell { |
| | | padding-left: 5px; |
| | | padding-right: 5px; |
| | | } |
| | | |
| | | .fixed-width .el-button--mini { |
| | | padding: 7px 10px; |
| | | width: 60px; |
| | | } |
| | | |
| | | .status-col .cell { |
| | | padding: 0 10px; |
| | | text-align: center; |
| | | } |
| | | |
| | | .status-col .cell .el-tag { |
| | | margin-right: 0px; |
| | | } |
| | | |
| | | .el-dialog { |
| | | transform: none; |
| | | left: 0; |
| | | position: relative; |
| | | margin: 0 auto; |
| | | } |
| | | |
| | | .upload-container .el-upload { |
| | | width: 100%; |
| | | } |
| | | |
| | | .upload-container .el-upload .el-upload-dragger { |
| | | width: 100%; |
| | | height: 200px; |
| | | } |
| | | |
| | | .el-dropdown-menu a { |
| | | display: block; |
| | | } |
| | | |
| | | .el-range-editor.el-input__inner { |
| | | display: inline-flex !important; |
| | | } |
| | | |
| | | .el-range-separator { |
| | | box-sizing: content-box; |
| | | } |
| | | |
| | | .el-menu--collapse |
| | | > div |
| | | > .el-submenu |
| | | > .el-submenu__title |
| | | .el-submenu__icon-arrow { |
| | | display: none; |
| | | } |
| | | |
| | | #app .main-container { |
| | | height: 100%; |
| | | transition: margin-left .28s; |
| | | margin-left: 200px; |
| | | position: relative; |
| | | } |
| | | |
| | | #app .sidebarHide { |
| | | margin-left: 0 !important; |
| | | } |
| | | |
| | | #app .sidebar-container { |
| | | -webkit-transition: width .28s; |
| | | transition: width 0.28s; |
| | | width: 200px !important; |
| | | background-color: #304156; |
| | | height: 100%; |
| | | position: fixed; |
| | | font-size: 0px; |
| | | top: 0; |
| | | bottom: 0; |
| | | left: 0; |
| | | z-index: 1001; |
| | | overflow: hidden; |
| | | -webkit-box-shadow: 2px 0 6px rgba(0, 21, 41, 0.35); |
| | | box-shadow: 2px 0 6px rgba(0, 21, 41, 0.35); |
| | | } |
| | | |
| | | #app .sidebar-container .horizontal-collapse-transition { |
| | | transition: 0s width ease-in-out, 0s padding-left ease-in-out, 0s padding-right ease-in-out; |
| | | } |
| | | |
| | | #app .sidebar-container .scrollbar-wrapper { |
| | | overflow-x: hidden !important; |
| | | } |
| | | |
| | | #app .sidebar-container .el-scrollbar__bar.is-vertical { |
| | | right: 0px; |
| | | } |
| | | |
| | | #app .sidebar-container .el-scrollbar { |
| | | height: 100%; |
| | | } |
| | | |
| | | #app .sidebar-container.has-logo .el-scrollbar { |
| | | height: calc(100% - 50px); |
| | | } |
| | | |
| | | #app .sidebar-container .is-horizontal { |
| | | display: none; |
| | | } |
| | | |
| | | #app .sidebar-container a { |
| | | display: inline-block; |
| | | width: 100%; |
| | | overflow: hidden; |
| | | } |
| | | |
| | | #app .sidebar-container .svg-icon { |
| | | margin-right: 16px; |
| | | } |
| | | |
| | | #app .sidebar-container .el-menu { |
| | | border: none; |
| | | height: 100%; |
| | | width: 100% !important; |
| | | } |
| | | |
| | | #app .sidebar-container .el-menu-item, #app .sidebar-container .el-submenu__title { |
| | | overflow: hidden !important; |
| | | text-overflow: ellipsis !important; |
| | | white-space: nowrap !important; |
| | | } |
| | | |
| | | #app .sidebar-container .submenu-title-noDropdown:hover, |
| | | #app .sidebar-container .el-submenu__title:hover { |
| | | background-color: rgba(0, 0, 0, 0.06) !important; |
| | | } |
| | | |
| | | #app .sidebar-container .theme-dark .is-active > .el-submenu__title { |
| | | color: #f4f4f5 !important; |
| | | } |
| | | |
| | | #app .sidebar-container .nest-menu .el-submenu > .el-submenu__title, |
| | | #app .sidebar-container .el-submenu .el-menu-item { |
| | | min-width: 200px !important; |
| | | } |
| | | |
| | | #app .sidebar-container .nest-menu .el-submenu > .el-submenu__title:hover, |
| | | #app .sidebar-container .el-submenu .el-menu-item:hover { |
| | | background-color: rgba(0, 0, 0, 0.06) !important; |
| | | } |
| | | |
| | | #app .sidebar-container .theme-dark .nest-menu .el-submenu > .el-submenu__title, |
| | | #app .sidebar-container .theme-dark .el-submenu .el-menu-item { |
| | | background-color: #1f2d3d !important; |
| | | } |
| | | |
| | | #app .sidebar-container .theme-dark .nest-menu .el-submenu > .el-submenu__title:hover, |
| | | #app .sidebar-container .theme-dark .el-submenu .el-menu-item:hover { |
| | | background-color: #001528 !important; |
| | | } |
| | | |
| | | #app .hideSidebar .sidebar-container { |
| | | width: 54px !important; |
| | | } |
| | | |
| | | #app .hideSidebar .main-container { |
| | | margin-left: 54px; |
| | | } |
| | | |
| | | #app .hideSidebar .submenu-title-noDropdown { |
| | | padding: 0 !important; |
| | | position: relative; |
| | | } |
| | | |
| | | #app .hideSidebar .submenu-title-noDropdown .el-tooltip { |
| | | padding: 0 !important; |
| | | } |
| | | |
| | | #app .hideSidebar .submenu-title-noDropdown .el-tooltip .svg-icon { |
| | | margin-left: 20px; |
| | | } |
| | | |
| | | #app .hideSidebar .el-submenu { |
| | | overflow: hidden; |
| | | } |
| | | |
| | | #app .hideSidebar .el-submenu > .el-submenu__title { |
| | | padding: 0 !important; |
| | | } |
| | | |
| | | #app .hideSidebar .el-submenu > .el-submenu__title .svg-icon { |
| | | margin-left: 20px; |
| | | } |
| | | |
| | | #app .hideSidebar .el-menu--collapse .el-submenu > .el-submenu__title > span { |
| | | height: 0; |
| | | width: 0; |
| | | overflow: hidden; |
| | | visibility: hidden; |
| | | display: inline-block; |
| | | } |
| | | |
| | | #app .el-menu--collapse .el-menu .el-submenu { |
| | | min-width: 200px !important; |
| | | } |
| | | |
| | | #app .mobile .main-container { |
| | | margin-left: 0px; |
| | | } |
| | | |
| | | #app .mobile .sidebar-container { |
| | | transition: transform .28s; |
| | | width: 200px !important; |
| | | } |
| | | |
| | | #app .mobile.hideSidebar .sidebar-container { |
| | | pointer-events: none; |
| | | transition-duration: 0.3s; |
| | | transform: translate3d(-200px, 0, 0); |
| | | } |
| | | |
| | | #app .withoutAnimation .main-container, |
| | | #app .withoutAnimation .sidebar-container { |
| | | transition: none; |
| | | } |
| | | |
| | | .el-menu--vertical > .el-menu .svg-icon { |
| | | margin-right: 16px; |
| | | } |
| | | |
| | | .el-menu--vertical .nest-menu .el-submenu > .el-submenu__title:hover, |
| | | .el-menu--vertical .el-menu-item:hover { |
| | | background-color: rgba(0, 0, 0, 0.06) !important; |
| | | } |
| | | |
| | | .el-menu--vertical > .el-menu--popup { |
| | | max-height: 100vh; |
| | | overflow-y: auto; |
| | | } |
| | | |
| | | .el-menu--vertical > .el-menu--popup::-webkit-scrollbar-track-piece { |
| | | background: #d3dce6; |
| | | } |
| | | |
| | | .el-menu--vertical > .el-menu--popup::-webkit-scrollbar { |
| | | width: 6px; |
| | | } |
| | | |
| | | .el-menu--vertical > .el-menu--popup::-webkit-scrollbar-thumb { |
| | | background: #99a9bf; |
| | | border-radius: 20px; |
| | | } |
| | | |
| | | /** |
| | | $base-menu-color:hsla(0,0%,100%,.65); |
| | | $base-menu-color-active:#fff; |
| | | $base-menu-background:#001529; |
| | | $base-logo-title-color: #ffffff; |
| | | |
| | | $base-menu-light-color:rgba(0,0,0,.70); |
| | | $base-menu-light-background:#ffffff; |
| | | $base-logo-light-title-color: #001529; |
| | | |
| | | $base-sub-menu-background:#000c17; |
| | | $base-sub-menu-hover:#001528; |
| | | */ |
| | | :export { |
| | | menuColor: #bfcbd9; |
| | | menuLightColor: rgba(0, 0, 0, 0.7); |
| | | menuColorActive: #f4f4f5; |
| | | menuBackground: #304156; |
| | | menuLightBackground: #ffffff; |
| | | subMenuBackground: #1f2d3d; |
| | | subMenuHover: #001528; |
| | | sideBarWidth: 200px; |
| | | logoTitleColor: #ffffff; |
| | | logoLightTitleColor: #001529; |
| | | } |
| | | |
| | | .blue-btn { |
| | | background: #324157; |
| | | } |
| | | |
| | | .blue-btn:hover { |
| | | color: #324157; |
| | | } |
| | | |
| | | .blue-btn:hover:before, .blue-btn:hover:after { |
| | | background: #324157; |
| | | } |
| | | |
| | | .light-blue-btn { |
| | | background: #3A71A8; |
| | | } |
| | | |
| | | .light-blue-btn:hover { |
| | | color: #3A71A8; |
| | | } |
| | | |
| | | .light-blue-btn:hover:before, .light-blue-btn:hover:after { |
| | | background: #3A71A8; |
| | | } |
| | | |
| | | .red-btn { |
| | | background: #C03639; |
| | | } |
| | | |
| | | .red-btn:hover { |
| | | color: #C03639; |
| | | } |
| | | |
| | | .red-btn:hover:before, .red-btn:hover:after { |
| | | background: #C03639; |
| | | } |
| | | |
| | | .pink-btn { |
| | | background: #E65D6E; |
| | | } |
| | | |
| | | .pink-btn:hover { |
| | | color: #E65D6E; |
| | | } |
| | | |
| | | .pink-btn:hover:before, .pink-btn:hover:after { |
| | | background: #E65D6E; |
| | | } |
| | | |
| | | .green-btn { |
| | | background: #30B08F; |
| | | } |
| | | |
| | | .green-btn:hover { |
| | | color: #30B08F; |
| | | } |
| | | |
| | | .green-btn:hover:before, .green-btn:hover:after { |
| | | background: #30B08F; |
| | | } |
| | | |
| | | .tiffany-btn { |
| | | background: #4AB7BD; |
| | | } |
| | | |
| | | .tiffany-btn:hover { |
| | | color: #4AB7BD; |
| | | } |
| | | |
| | | .tiffany-btn:hover:before, .tiffany-btn:hover:after { |
| | | background: #4AB7BD; |
| | | } |
| | | |
| | | .yellow-btn { |
| | | background: #FEC171; |
| | | } |
| | | |
| | | .yellow-btn:hover { |
| | | color: #FEC171; |
| | | } |
| | | |
| | | .yellow-btn:hover:before, .yellow-btn:hover:after { |
| | | background: #FEC171; |
| | | } |
| | | |
| | | .pan-btn { |
| | | font-size: 14px; |
| | | color: #fff; |
| | | padding: 14px 36px; |
| | | border-radius: 8px; |
| | | border: none; |
| | | outline: none; |
| | | transition: 600ms ease all; |
| | | position: relative; |
| | | display: inline-block; |
| | | } |
| | | |
| | | .pan-btn:hover { |
| | | background: #fff; |
| | | } |
| | | |
| | | .pan-btn:hover:before, .pan-btn:hover:after { |
| | | width: 100%; |
| | | transition: 600ms ease all; |
| | | } |
| | | |
| | | .pan-btn:before, .pan-btn:after { |
| | | content: ''; |
| | | position: absolute; |
| | | top: 0; |
| | | right: 0; |
| | | height: 2px; |
| | | width: 0; |
| | | transition: 400ms ease all; |
| | | } |
| | | |
| | | .pan-btn::after { |
| | | right: inherit; |
| | | top: inherit; |
| | | left: 0; |
| | | bottom: 0; |
| | | } |
| | | |
| | | .custom-button { |
| | | display: inline-block; |
| | | line-height: 1; |
| | | white-space: nowrap; |
| | | cursor: pointer; |
| | | background: #fff; |
| | | color: #fff; |
| | | -webkit-appearance: none; |
| | | text-align: center; |
| | | box-sizing: border-box; |
| | | outline: 0; |
| | | margin: 0; |
| | | padding: 10px 15px; |
| | | font-size: 14px; |
| | | border-radius: 4px; |
| | | } |
| | | |
| | | body { |
| | | height: 100%; |
| | | overflow: hidden; |
| | | -moz-osx-font-smoothing: grayscale; |
| | | -webkit-font-smoothing: antialiased; |
| | | text-rendering: optimizeLegibility; |
| | | font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif; |
| | | } |
| | | |
| | | label { |
| | | font-weight: 700; |
| | | } |
| | | |
| | | html { |
| | | height: 100%; |
| | | box-sizing: border-box; |
| | | } |
| | | |
| | | #app { |
| | | height: 100%; |
| | | } |
| | | |
| | | *, |
| | | *:before, |
| | | *:after { |
| | | box-sizing: inherit; |
| | | } |
| | | |
| | | .no-padding { |
| | | padding: 0px !important; |
| | | } |
| | | |
| | | .padding-content { |
| | | padding: 4px 0; |
| | | } |
| | | |
| | | a:focus, |
| | | a:active { |
| | | outline: none; |
| | | } |
| | | |
| | | a, |
| | | a:focus, |
| | | a:hover { |
| | | cursor: pointer; |
| | | color: inherit; |
| | | text-decoration: none; |
| | | } |
| | | |
| | | div:focus { |
| | | outline: none; |
| | | } |
| | | |
| | | .fr { |
| | | float: right; |
| | | } |
| | | |
| | | .fl { |
| | | float: left; |
| | | } |
| | | |
| | | .pr-5 { |
| | | padding-right: 5px; |
| | | } |
| | | |
| | | .pl-5 { |
| | | padding-left: 5px; |
| | | } |
| | | |
| | | .block { |
| | | display: block; |
| | | } |
| | | |
| | | .pointer { |
| | | cursor: pointer; |
| | | } |
| | | |
| | | .inlineBlock { |
| | | display: block; |
| | | } |
| | | |
| | | .clearfix:after { |
| | | visibility: hidden; |
| | | display: block; |
| | | font-size: 0; |
| | | content: " "; |
| | | clear: both; |
| | | height: 0; |
| | | } |
| | | |
| | | aside { |
| | | background: #eef1f6; |
| | | padding: 8px 24px; |
| | | margin-bottom: 20px; |
| | | border-radius: 2px; |
| | | display: block; |
| | | line-height: 32px; |
| | | font-size: 16px; |
| | | font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif; |
| | | color: #2c3e50; |
| | | -webkit-font-smoothing: antialiased; |
| | | -moz-osx-font-smoothing: grayscale; |
| | | } |
| | | |
| | | aside a { |
| | | color: #337ab7; |
| | | cursor: pointer; |
| | | } |
| | | |
| | | aside a:hover { |
| | | color: #20a0ff; |
| | | } |
| | | |
| | | .app-container { |
| | | padding: 20px; |
| | | } |
| | | |
| | | .components-container { |
| | | margin: 30px 50px; |
| | | position: relative; |
| | | } |
| | | |
| | | .pagination-container { |
| | | margin-top: 30px; |
| | | } |
| | | |
| | | .text-center { |
| | | text-align: center; |
| | | } |
| | | |
| | | .sub-navbar { |
| | | height: 50px; |
| | | line-height: 50px; |
| | | position: relative; |
| | | width: 100%; |
| | | text-align: right; |
| | | padding-right: 20px; |
| | | transition: 600ms ease position; |
| | | background: linear-gradient(90deg, #20b6f9 0%, #20b6f9 0%, #2178f1 100%, #2178f1 100%); |
| | | } |
| | | |
| | | .sub-navbar .subtitle { |
| | | font-size: 20px; |
| | | color: #fff; |
| | | } |
| | | |
| | | .sub-navbar.draft { |
| | | background: #d0d0d0; |
| | | } |
| | | |
| | | .sub-navbar.deleted { |
| | | background: #d0d0d0; |
| | | } |
| | | |
| | | .link-type, |
| | | .link-type:focus { |
| | | color: #337ab7; |
| | | cursor: pointer; |
| | | } |
| | | |
| | | .link-type:hover, |
| | | .link-type:focus:hover { |
| | | color: #20a0ff; |
| | | } |
| | | |
| | | .filter-container { |
| | | padding-bottom: 10px; |
| | | } |
| | | |
| | | .filter-container .filter-item { |
| | | display: inline-block; |
| | | vertical-align: middle; |
| | | margin-bottom: 10px; |
| | | } |
New file |
| | |
| | | :export{menuColor:#bfcbd9;menuLightColor:rgba(0,0,0,0.7);menuColorActive:#f4f4f5;menuBackground:#304156;menuLightBackground:#fff;subMenuBackground:#1f2d3d;subMenuHover:#001528;sideBarWidth:200px;logoTitleColor:#fff;logoLightTitleColor:#001529}.fade-enter-active,.fade-leave-active{transition:opacity 0.28s}.fade-enter,.fade-leave-active{opacity:0}.fade-transform--move,.fade-transform-leave-active,.fade-transform-enter-active{transition:all .5s}.fade-transform-enter{opacity:0;transform:translateX(-30px)}.fade-transform-leave-to{opacity:0;transform:translateX(30px)}.breadcrumb-enter-active,.breadcrumb-leave-active{transition:all .5s}.breadcrumb-enter,.breadcrumb-leave-active{opacity:0;transform:translateX(20px)}.breadcrumb-move{transition:all .5s}.breadcrumb-leave-active{position:absolute}.el-breadcrumb__inner,.el-breadcrumb__inner a{font-weight:400 !important}.el-upload input[type="file"]{display:none !important}.el-upload__input{display:none}.cell .el-tag{margin-right:0px}.small-padding .cell{padding-left:5px;padding-right:5px}.fixed-width .el-button--mini{padding:7px 10px;width:60px}.status-col .cell{padding:0 10px;text-align:center}.status-col .cell .el-tag{margin-right:0px}.el-dialog{transform:none;left:0;position:relative;margin:0 auto}.upload-container .el-upload{width:100%}.upload-container .el-upload .el-upload-dragger{width:100%;height:200px}.el-dropdown-menu a{display:block}.el-range-editor.el-input__inner{display:inline-flex !important}.el-range-separator{box-sizing:content-box}.el-menu--collapse>div>.el-submenu>.el-submenu__title .el-submenu__icon-arrow{display:none}#app .main-container{height:100%;transition:margin-left .28s;margin-left:200px;position:relative}#app .sidebarHide{margin-left:0 !important}#app .sidebar-container{-webkit-transition:width .28s;transition:width 0.28s;width:200px !important;background-color:#304156;height:100%;position:fixed;font-size:0px;top:0;bottom:0;left:0;z-index:1001;overflow:hidden;-webkit-box-shadow:2px 0 6px rgba(0,21,41,0.35);box-shadow:2px 0 6px rgba(0,21,41,0.35)}#app .sidebar-container .horizontal-collapse-transition{transition:0s width ease-in-out, 0s padding-left ease-in-out, 0s padding-right ease-in-out}#app .sidebar-container .scrollbar-wrapper{overflow-x:hidden !important}#app .sidebar-container .el-scrollbar__bar.is-vertical{right:0px}#app .sidebar-container .el-scrollbar{height:100%}#app .sidebar-container.has-logo .el-scrollbar{height:calc(100% - 50px)}#app .sidebar-container .is-horizontal{display:none}#app .sidebar-container a{display:inline-block;width:100%;overflow:hidden}#app .sidebar-container .svg-icon{margin-right:16px}#app .sidebar-container .el-menu{border:none;height:100%;width:100% !important}#app .sidebar-container .el-menu-item,#app .sidebar-container .el-submenu__title{overflow:hidden !important;text-overflow:ellipsis !important;white-space:nowrap !important}#app .sidebar-container .submenu-title-noDropdown:hover,#app .sidebar-container .el-submenu__title:hover{background-color:rgba(0,0,0,0.06) !important}#app .sidebar-container .theme-dark .is-active>.el-submenu__title{color:#f4f4f5 !important}#app .sidebar-container .nest-menu .el-submenu>.el-submenu__title,#app .sidebar-container .el-submenu .el-menu-item{min-width:200px !important}#app .sidebar-container .nest-menu .el-submenu>.el-submenu__title:hover,#app .sidebar-container .el-submenu .el-menu-item:hover{background-color:rgba(0,0,0,0.06) !important}#app .sidebar-container .theme-dark .nest-menu .el-submenu>.el-submenu__title,#app .sidebar-container .theme-dark .el-submenu .el-menu-item{background-color:#1f2d3d !important}#app .sidebar-container .theme-dark .nest-menu .el-submenu>.el-submenu__title:hover,#app .sidebar-container .theme-dark .el-submenu .el-menu-item:hover{background-color:#001528 !important}#app .hideSidebar .sidebar-container{width:54px !important}#app .hideSidebar .main-container{margin-left:54px}#app .hideSidebar .submenu-title-noDropdown{padding:0 !important;position:relative}#app .hideSidebar .submenu-title-noDropdown .el-tooltip{padding:0 !important}#app .hideSidebar .submenu-title-noDropdown .el-tooltip .svg-icon{margin-left:20px}#app .hideSidebar .el-submenu{overflow:hidden}#app .hideSidebar .el-submenu>.el-submenu__title{padding:0 !important}#app .hideSidebar .el-submenu>.el-submenu__title .svg-icon{margin-left:20px}#app .hideSidebar .el-menu--collapse .el-submenu>.el-submenu__title>span{height:0;width:0;overflow:hidden;visibility:hidden;display:inline-block}#app .el-menu--collapse .el-menu .el-submenu{min-width:200px !important}#app .mobile .main-container{margin-left:0px}#app .mobile .sidebar-container{transition:transform .28s;width:200px !important}#app .mobile.hideSidebar .sidebar-container{pointer-events:none;transition-duration:0.3s;transform:translate3d(-200px, 0, 0)}#app .withoutAnimation .main-container,#app .withoutAnimation .sidebar-container{transition:none}.el-menu--vertical>.el-menu .svg-icon{margin-right:16px}.el-menu--vertical .nest-menu .el-submenu>.el-submenu__title:hover,.el-menu--vertical .el-menu-item:hover{background-color:rgba(0,0,0,0.06) !important}.el-menu--vertical>.el-menu--popup{max-height:100vh;overflow-y:auto}.el-menu--vertical>.el-menu--popup::-webkit-scrollbar-track-piece{background:#d3dce6}.el-menu--vertical>.el-menu--popup::-webkit-scrollbar{width:6px}.el-menu--vertical>.el-menu--popup::-webkit-scrollbar-thumb{background:#99a9bf;border-radius:20px}:export{menuColor:#bfcbd9;menuLightColor:rgba(0,0,0,0.7);menuColorActive:#f4f4f5;menuBackground:#304156;menuLightBackground:#fff;subMenuBackground:#1f2d3d;subMenuHover:#001528;sideBarWidth:200px;logoTitleColor:#fff;logoLightTitleColor:#001529}.blue-btn{background:#324157}.blue-btn:hover{color:#324157}.blue-btn:hover:before,.blue-btn:hover:after{background:#324157}.light-blue-btn{background:#3A71A8}.light-blue-btn:hover{color:#3A71A8}.light-blue-btn:hover:before,.light-blue-btn:hover:after{background:#3A71A8}.red-btn{background:#C03639}.red-btn:hover{color:#C03639}.red-btn:hover:before,.red-btn:hover:after{background:#C03639}.pink-btn{background:#E65D6E}.pink-btn:hover{color:#E65D6E}.pink-btn:hover:before,.pink-btn:hover:after{background:#E65D6E}.green-btn{background:#30B08F}.green-btn:hover{color:#30B08F}.green-btn:hover:before,.green-btn:hover:after{background:#30B08F}.tiffany-btn{background:#4AB7BD}.tiffany-btn:hover{color:#4AB7BD}.tiffany-btn:hover:before,.tiffany-btn:hover:after{background:#4AB7BD}.yellow-btn{background:#FEC171}.yellow-btn:hover{color:#FEC171}.yellow-btn:hover:before,.yellow-btn:hover:after{background:#FEC171}.pan-btn{font-size:14px;color:#fff;padding:14px 36px;border-radius:8px;border:none;outline:none;transition:600ms ease all;position:relative;display:inline-block}.pan-btn:hover{background:#fff}.pan-btn:hover:before,.pan-btn:hover:after{width:100%;transition:600ms ease all}.pan-btn:before,.pan-btn:after{content:'';position:absolute;top:0;right:0;height:2px;width:0;transition:400ms ease all}.pan-btn::after{right:inherit;top:inherit;left:0;bottom:0}.custom-button{display:inline-block;line-height:1;white-space:nowrap;cursor:pointer;background:#fff;color:#fff;-webkit-appearance:none;text-align:center;box-sizing:border-box;outline:0;margin:0;padding:10px 15px;font-size:14px;border-radius:4px}body{height:100%;overflow:hidden;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-family:Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif}label{font-weight:700}html{height:100%;box-sizing:border-box}#app{height:100%}*,*:before,*:after{box-sizing:inherit}.no-padding{padding:0px !important}.padding-content{padding:4px 0}a:focus,a:active{outline:none}a,a:focus,a:hover{cursor:pointer;color:inherit;text-decoration:none}div:focus{outline:none}.fr{float:right}.fl{float:left}.pr-5{padding-right:5px}.pl-5{padding-left:5px}.block{display:block}.pointer{cursor:pointer}.inlineBlock{display:block}.clearfix:after{visibility:hidden;display:block;font-size:0;content:" ";clear:both;height:0}aside{background:#eef1f6;padding:8px 24px;margin-bottom:20px;border-radius:2px;display:block;line-height:32px;font-size:16px;font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;color:#2c3e50;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}aside a{color:#337ab7;cursor:pointer}aside a:hover{color:#20a0ff}.app-container{padding:20px}.components-container{margin:30px 50px;position:relative}.pagination-container{margin-top:30px}.text-center{text-align:center}.sub-navbar{height:50px;line-height:50px;position:relative;width:100%;text-align:right;padding-right:20px;transition:600ms ease position;background:linear-gradient(90deg, #20b6f9 0%, #20b6f9 0%, #2178f1 100%, #2178f1 100%)}.sub-navbar .subtitle{font-size:20px;color:#fff}.sub-navbar.draft{background:#d0d0d0}.sub-navbar.deleted{background:#d0d0d0}.link-type,.link-type:focus{color:#337ab7;cursor:pointer}.link-type:hover,.link-type:focus:hover{color:#20a0ff}.filter-container{padding-bottom:10px}.filter-container .filter-item{display:inline-block;vertical-align:middle;margin-bottom:10px} |
| | |
| | | children: [ |
| | | { |
| | | path: 'index', |
| | | // component: () => import('@/views/index'), |
| | | component: () => import('@/views/index'), |
| | | name: 'Index', |
| | | meta: { title: '首页', icon: 'dashboard', affix: true } |
| | | } |
New file |
| | |
| | | <template> |
| | | <div class="data-chart-container"> |
| | | <el-card class="data-card" :body-style="{ height: '100%' }"> |
| | | <div class="card-content"> |
| | | <div class="title-container"> |
| | | <h1>运维监控报表</h1> |
| | | <div class="select-container"> |
| | | <el-select v-model="company" placeholder="请选择运维公司" @change="companyChange"> |
| | | <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value"> |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | <div class="date-container"> |
| | | <el-date-picker v-model="dateRange" type="daterange" range-separator="至" start-placeholder="开始日期" |
| | | end-placeholder="结束日期"> |
| | | </el-date-picker> |
| | | </div> |
| | | </div> |
| | | <div class="chart-container"> |
| | | <div id="chartContent" ref="chartContent"></div> |
| | | </div> |
| | | </div> |
| | | </el-card> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import * as echarts from 'echarts'; |
| | | let lineChart = null; |
| | | let observer = null; |
| | | export default { |
| | | name: 'DataChart', |
| | | data() { |
| | | return { |
| | | dateRange: '', |
| | | company: '', |
| | | options: [ |
| | | { label: 'XX运维公司1', value: 'XX运维公司1' }, |
| | | { label: 'XX运维公司2', value: 'XX运维公司2' }, |
| | | { label: 'XX运维公司3', value: 'XX运维公司3' }, |
| | | { label: 'XX运维公司4', value: 'XX运维公司4' }, |
| | | ], |
| | | dataList: [ |
| | | { |
| | | name: 'XX运维公司1', |
| | | state: { '1月': 1000, '2月': 2131, '3月': 1233, '4月': 2132, '5月': 3211 }, |
| | | state2: { '1月': 123, '2月': 213, '3月': 1412, '4月': 23, '5月': 123 } |
| | | }, |
| | | { |
| | | name: 'XX运维公司2', |
| | | state: { '1月': 213, '2月': 2131, '3月': 1233, '4月': 2132, '5月': 3211 }, |
| | | state2: { '1月': 123, '2月': 123, '3月': 1412, '4月': 23, '5月': 123 } |
| | | }, |
| | | { |
| | | name: 'XX运维公司3', |
| | | state: { '1月': 1000, '2月': 2131, '3月': 1233, '4月': 2132, '5月': 3211, '6月': 1321 }, |
| | | state2: { '1月': 123, '2月': 213, '3月': 123, '4月': 23, '5月': 123 } |
| | | }, |
| | | { |
| | | name: 'XX运维公司4', |
| | | state: { '1月': 1000, '2月': 2131, '3月': 1233, '4月': 2132, '5月': 3211 }, |
| | | state2: { '1月': 123, '2月': 613, '3月': 1412, '4月': 2336, '5月': 123 } |
| | | }, |
| | | { |
| | | name: 'XX运维公司5', |
| | | state: { '1月': 1000, '2月': 433, '3月': 1233, '4月': 2132, '5月': 8886 }, |
| | | state2: { '1月': 123, '2月': 213, '3月': 1412, '4月': 23, '5月': 123 } |
| | | }, |
| | | ], |
| | | } |
| | | }, |
| | | methods: { |
| | | initChart() { |
| | | const option = { |
| | | legend: { |
| | | right: '2%', |
| | | top: '5%', |
| | | icon: 'rect', |
| | | data: [ |
| | | { |
| | | |
| | | name: '正常数', |
| | | itemStyle: { |
| | | color: 'rgba(62, 144, 247, 1)' |
| | | } |
| | | }, |
| | | { |
| | | name: '异常数', |
| | | itemStyle: { |
| | | color: 'rgba(85, 192, 191, 1)' |
| | | } |
| | | }, |
| | | ], |
| | | }, |
| | | grid: { |
| | | left: 0, |
| | | right: 0, |
| | | bottom: 0, |
| | | top: '20%', |
| | | containLabel: true |
| | | }, |
| | | tooltip: {}, |
| | | xAxis: { |
| | | type: 'category', |
| | | data: Object.keys(this.acitveData.state), |
| | | }, |
| | | yAxis: {}, |
| | | series: [ |
| | | { |
| | | name: '正常数', |
| | | data: Object.entries(this.acitveData.state).map(([key, value]) => value), |
| | | type: 'line', |
| | | itemStyle: { |
| | | color: 'rgba(62, 144, 247, 1)' |
| | | } |
| | | }, |
| | | { |
| | | name: '异常数', |
| | | data: Object.entries(this.acitveData.state2).map(([key, value]) => value), |
| | | type: 'line', |
| | | itemStyle: { |
| | | color: 'rgba(85, 192, 191, 1)' |
| | | } |
| | | } |
| | | ] |
| | | }; |
| | | lineChart.setOption(option, true); |
| | | }, |
| | | |
| | | |
| | | companyChange() { |
| | | this.acitveData = this.dataList.find((item) => { |
| | | return item.name === this.company; |
| | | }); |
| | | if (this.acitveData) { |
| | | this.initChart(); |
| | | } |
| | | }, |
| | | |
| | | // 监听变化 |
| | | observe() { |
| | | if (!observer) { |
| | | observer = new ResizeObserver(entries => { |
| | | this.handleResize(); |
| | | }) |
| | | } |
| | | observer.observe(this.$refs.chartContent); |
| | | }, |
| | | // 窗口变换 |
| | | handleResize() { |
| | | if (lineChart) { |
| | | lineChart.resize(); |
| | | } |
| | | } |
| | | |
| | | }, |
| | | mounted() { |
| | | this.acitveData = this.dataList[0]; |
| | | this.company = this.acitveData.name; |
| | | lineChart = echarts.init(this.$refs.chartContent); |
| | | this.initChart(); |
| | | this.observe(); |
| | | }, |
| | | beforeDestroy() { |
| | | if (lineChart) { |
| | | lineChart.dispose(); |
| | | observer.unobserve(this.$refs.chartContent); |
| | | } |
| | | }, |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | .data-chart-container { |
| | | height: 400px; |
| | | margin-bottom: 20px; |
| | | |
| | | .data-card { |
| | | height: 100%; |
| | | |
| | | .card-content { |
| | | width: 100%; |
| | | height: 100%; |
| | | position: relative; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .title-container { |
| | | position: absolute; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | z-index: 2; |
| | | |
| | | |
| | | .more-button { |
| | | cursor: pointer; |
| | | font-size: 16px; |
| | | padding: 0 10px; |
| | | } |
| | | } |
| | | |
| | | .chart-container { |
| | | |
| | | width: 100%; |
| | | height: 100%; |
| | | |
| | | #chartContent { |
| | | width: 100%; |
| | | height: 100%; |
| | | } |
| | | } |
| | | |
| | | .select-container { |
| | | margin: 0 20px; |
| | | width: 180px; |
| | | } |
| | | </style> |
New file |
| | |
| | | <template> |
| | | <div class="data-table-container"> |
| | | <el-card class="data-card" :body-style="{ height: '100%' }"> |
| | | <div class="card-content"> |
| | | <div class="title-container"> |
| | | <h1>核算报表</h1> |
| | | <div class="more-button"> |
| | | <span>更多</span> |
| | | <i class="el-icon-arrow-right"></i> |
| | | </div> |
| | | </div> |
| | | <div class="table-container"> |
| | | <div class="table-content"> |
| | | <el-table :data="tableData" :show-header="false" class="data-table"> |
| | | <el-table-column> |
| | | <template slot-scope="scope"> |
| | | <p>{{ scope.row.name }}</p> |
| | | <p>{{ scope.row.date }}</p> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" width="80px"> |
| | | |
| | | <template slot-scope="scope"> |
| | | <div class="more-info"> |
| | | <span>详情</span> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </el-card> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | export default { |
| | | name: 'DataCheck', |
| | | |
| | | data() { |
| | | return { |
| | | tableData: [ |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | ] |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | .data-table-container { |
| | | height: 400px; |
| | | |
| | | .data-card { |
| | | height: 100%; |
| | | |
| | | .card-content { |
| | | width: 100%; |
| | | height: 100%; |
| | | display: flex; |
| | | flex-direction: column; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .table-container { |
| | | position: relative; |
| | | flex: 1; |
| | | |
| | | .table-content { |
| | | position: absolute; |
| | | top: 0; |
| | | left: 0; |
| | | bottom: 0; |
| | | right: 0; |
| | | overflow-y: scroll; |
| | | } |
| | | } |
| | | |
| | | .title-container { |
| | | width: 100%; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | |
| | | .more-button { |
| | | cursor: pointer; |
| | | font-size: 16px; |
| | | padding: 0 10px; |
| | | } |
| | | } |
| | | |
| | | .more-info { |
| | | cursor: pointer; |
| | | font-size: 16px; |
| | | padding: 0 10px; |
| | | } |
| | | |
| | | .data-table { |
| | | width: 100%; |
| | | } |
| | | |
| | | ::v-deep .data-table>>>.el-table__row>td { |
| | | /* 去除表格线 */ |
| | | border: none; |
| | | } |
| | | |
| | | ::v-deep .data-table th { |
| | | border: none; |
| | | } |
| | | |
| | | ::v-deep .data-table td, |
| | | ::v-deep .data-table th.is-leaf { |
| | | border: none; |
| | | } |
| | | |
| | | // 表格最外边框 |
| | | ::v-deep .el-table--border, |
| | | ::v-deep .el-table--group { |
| | | border: none; |
| | | |
| | | } |
| | | |
| | | ::v-deep .el-table--border::after, |
| | | ::v-deep .el-table--group::after, |
| | | ::v-deep .el-table::before { |
| | | background-color: transparent; |
| | | } |
| | | </style> |
New file |
| | |
| | | <template> |
| | | <div class="data-table-container"> |
| | | |
| | | <el-card class="data-card" :body-style="{ height: '100%' }"> |
| | | <div class="card-content"> |
| | | <div class="title-container"> |
| | | <h1>运维单位违约责任排名</h1> |
| | | <div class="more-button"> |
| | | <span>更多</span> |
| | | <i class="el-icon-arrow-right"></i> |
| | | </div> |
| | | </div> |
| | | <el-table :data="tableData" style="width: 100%" height="350"> |
| | | <el-table-column prop="name" label="单位" align="center"> |
| | | </el-table-column> |
| | | <el-table-column prop="num" label="违约数" align="center"> |
| | | </el-table-column> |
| | | </el-table> |
| | | </div> |
| | | </el-card> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | export default { |
| | | name: 'DataRank', |
| | | |
| | | data() { |
| | | return { |
| | | tableData: [ |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | ] |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | .data-table-container { |
| | | height: 450px; |
| | | margin-bottom: 20px; |
| | | |
| | | .data-card { |
| | | height: 100%; |
| | | |
| | | .card-content { |
| | | width: 100%; |
| | | height: 100%; |
| | | display: flex; |
| | | flex-direction: column; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .title-container { |
| | | width: 100%; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | |
| | | .more-button { |
| | | cursor: pointer; |
| | | font-size: 16px; |
| | | padding: 0 10px; |
| | | } |
| | | } |
| | | |
| | | .table-container { |
| | | position: relative; |
| | | flex: 1; |
| | | |
| | | .table-content { |
| | | position: absolute; |
| | | top: 0; |
| | | left: 0; |
| | | bottom: 0; |
| | | right: 0; |
| | | overflow-y: scroll; |
| | | } |
| | | } |
| | | |
| | | .data-table { |
| | | width: 100%; |
| | | } |
| | | </style> |
New file |
| | |
| | | <template> |
| | | <div class="data-table-container"> |
| | | |
| | | <el-card class="data-card" :body-style="{ height: '100%' }"> |
| | | <div class="card-content"> |
| | | <div class="title-container"> |
| | | <h1>运维到期预警</h1> |
| | | <div class="more-button"> |
| | | <span>更多</span> |
| | | <i class="el-icon-arrow-right"></i> |
| | | </div> |
| | | </div> |
| | | |
| | | <el-table :data="tableData" height="400"> |
| | | <el-table-column prop="date" label="警报时间" align="center"> |
| | | </el-table-column> |
| | | <el-table-column prop="name" label="点位信息" align="center"> |
| | | </el-table-column> |
| | | <el-table-column prop="date" label="运维截止时间" align="center"> |
| | | </el-table-column> |
| | | <el-table-column label="操作" align="center"> |
| | | <template slot-scope="scope"> |
| | | <el-button size="mini">编辑</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | </div> |
| | | </el-card> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | export default { |
| | | name: 'DataTable', |
| | | data() { |
| | | return { |
| | | tableData: [ |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | { |
| | | date: '2024.02.28 15:14:01', |
| | | name: '运维公司名称1', |
| | | address: '上海市普陀区金沙江路 1518 弄', |
| | | num: 111, |
| | | }, |
| | | ] |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | .data-table-container { |
| | | height: 450px; |
| | | margin-bottom: 20px; |
| | | |
| | | .data-card { |
| | | height: 100%; |
| | | |
| | | .card-content { |
| | | width: 100%; |
| | | height: 100%; |
| | | display: flex; |
| | | flex-direction: column; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .title-container { |
| | | width: 100%; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | |
| | | .more-button { |
| | | cursor: pointer; |
| | | font-size: 16px; |
| | | padding: 0 10px; |
| | | } |
| | | } |
| | | </style> |
New file |
| | |
| | | <template> |
| | | <div class="data-container"> |
| | | <el-row> |
| | | <el-col> |
| | | <h1 class="title">运维报表</h1> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row :gutter="20" class="data-plane"> |
| | | <el-col :xs='24' :md="6" :xl="{ span: '4-8' }" :sm="12" v-for="item, index in dataList" :key="item.id"> |
| | | <div class="col-content"> |
| | | <el-card> |
| | | <el-row type="flex" align="middle" justify="space-between"> |
| | | <el-col :xl="8" :lg="8" :md="10" :sm="8" :xs="6"> |
| | | <div class="icon-container" :style="{ backgroundColor: iconList[index].color }"> |
| | | <i :class="iconList[index].icon" class="icon-font"></i> |
| | | </div> |
| | | </el-col> |
| | | <el-col :xl="14" :lg="14" :md="12" :sm="14" :xs="16"> |
| | | <div class="data-info"> |
| | | <div class="data-num">{{ item.num }}</div> |
| | | <div class="data-lable">{{ item.type }}</div> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | | </el-card> |
| | | </div> |
| | | </el-col> |
| | | |
| | | </el-row> |
| | | </div> |
| | | |
| | | </template> |
| | | |
| | | <script> |
| | | export default { |
| | | name: 'DataView', |
| | | data() { |
| | | return { |
| | | dataList: [ |
| | | { id: 1, type: '工单数', num: 523, }, |
| | | { id: 2, type: '恢复数', num: 50, }, |
| | | { id: 3, type: '待恢复数', num: 523, }, |
| | | { id: 4, type: '产生违约事项数', num: 123, }, |
| | | { id: 5, type: '产生违约责任书', num: 512323, }, |
| | | ], |
| | | iconList: [ |
| | | { icon: 'el-icon-tickets', color: '#7868d9' }, |
| | | { icon: 'el-icon-s-claim', color: '#3eba45' }, |
| | | { icon: 'el-icon-edit', color: '#3da7f8' }, |
| | | { icon: 'el-icon-warning', color: '#ffbe40' }, |
| | | { icon: 'el-icon-error', color: '#fe640d' }, |
| | | ] |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | .data-container { |
| | | margin-bottom: 20px; |
| | | } |
| | | .title { |
| | | text-align: left; |
| | | } |
| | | |
| | | .icon-container { |
| | | height: 80px; |
| | | } |
| | | |
| | | .col-content { |
| | | margin-bottom: 10px; |
| | | } |
| | | |
| | | .icon-container { |
| | | display: flex; |
| | | justify-content: center; |
| | | align-items: center; |
| | | border-radius: 8px; |
| | | |
| | | .icon-font { |
| | | font-size: 30px; |
| | | color: #fff; |
| | | } |
| | | } |
| | | |
| | | .data-info { |
| | | display: flex; |
| | | height: 100%; |
| | | flex-direction: column; |
| | | justify-content: center; |
| | | text-align: left; |
| | | |
| | | .data-num { |
| | | font-size: 32px; |
| | | } |
| | | |
| | | .data-lable { |
| | | font-size: 16px; |
| | | text-indent: 3px; |
| | | } |
| | | } |
| | | |
| | | @media screen and (min-width: 1200px) { |
| | | .el-col-md-6 { |
| | | width: 20%; |
| | | } |
| | | } |
| | | </style> |
New file |
| | |
| | | <template> |
| | | <div class="data-container"> |
| | | <el-row :gutter="40"> |
| | | <el-col :xs='24' :md="24" :sm="24" :lg="17" :xl="17"> |
| | | <data-table></data-table> |
| | | <data-chart></data-chart> |
| | | </el-col> |
| | | <el-col :xs='24' :md="24" :sm="24" :lg="7" :xl="7"> |
| | | <data-rank></data-rank> |
| | | <data-check></data-check> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import DataTable from '../data-table/index.vue'; |
| | | import DataRank from '../data-rank/index.vue'; |
| | | import DataCheck from '../data-check/index.vue'; |
| | | import DataChart from '../data-chart/index.vue'; |
| | | export default { |
| | | name: 'DataWrapper', |
| | | components: { |
| | | DataTable, |
| | | DataRank, |
| | | DataCheck, |
| | | DataChart |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | |
| | | </style> |
| | |
| | | <template> |
| | | <template> |
| | | <div class="app-container home"> |
| | | <el-row :gutter="20"> |
| | | <el-col :sm="24" :lg="24"> |
| | | <blockquote class="text-warning" style="font-size: 14px"> |
| | | 领取阿里云通用云产品1888优惠券 |
| | | <br /> |
| | | <el-link |
| | | href="https://www.aliyun.com/minisite/goods?userCode=brki8iof" |
| | | type="primary" |
| | | target="_blank" |
| | | >https://www.aliyun.com/minisite/goods?userCode=brki8iof</el-link |
| | | > |
| | | <br /> |
| | | 领取腾讯云通用云产品2860优惠券 |
| | | <br /> |
| | | <el-link |
| | | href="https://cloud.tencent.com/redirect.php?redirect=1025&cps_key=198c8df2ed259157187173bc7f4f32fd&from=console" |
| | | type="primary" |
| | | target="_blank" |
| | | >https://cloud.tencent.com/redirect.php?redirect=1025&cps_key=198c8df2ed259157187173bc7f4f32fd&from=console</el-link |
| | | > |
| | | <br /> |
| | | 阿里云服务器折扣区 |
| | | <el-link href="http://aly.ruoyi.vip" type="primary" target="_blank" |
| | | >>☛☛点我进入☚☚</el-link |
| | | > |
| | | 腾讯云服务器秒杀区 |
| | | <el-link href="http://txy.ruoyi.vip" type="primary" target="_blank" |
| | | >>☛☛点我进入☚☚</el-link |
| | | ><br /> |
| | | <h4 class="text-danger"> |
| | | 云产品通用红包,可叠加官网常规优惠使用。(仅限新用户) |
| | | </h4> |
| | | </blockquote> |
| | | |
| | | <hr /> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row :gutter="20"> |
| | | <el-col :sm="24" :lg="12" style="padding-left: 20px"> |
| | | <h2>若依后台管理框架</h2> |
| | | <p> |
| | | 一直想做一款后台管理系统,看了很多优秀的开源项目但是发现没有合适自己的。于是利用空闲休息时间开始自己写一套后台系统。如此有了若依管理系统,她可以用于所有的Web应用程序,如网站管理后台,网站会员中心,CMS,CRM,OA等等,当然,您也可以对她进行深度定制,以做出更强系统。所有前端后台代码封装过后十分精简易上手,出错概率低。同时支持移动客户端访问。系统会陆续更新一些实用功能。 |
| | | </p> |
| | | <p> |
| | | <b>当前版本:</b> <span>v{{ version }}</span> |
| | | </p> |
| | | <p> |
| | | <el-tag type="danger">¥免费开源</el-tag> |
| | | </p> |
| | | <p> |
| | | <el-button |
| | | type="primary" |
| | | size="mini" |
| | | icon="el-icon-cloudy" |
| | | plain |
| | | @click="goTarget('https://gitee.com/y_project/RuoYi-Vue')" |
| | | >访问码云</el-button |
| | | > |
| | | <el-button |
| | | size="mini" |
| | | icon="el-icon-s-home" |
| | | plain |
| | | @click="goTarget('http://ruoyi.vip')" |
| | | >访问主页</el-button |
| | | > |
| | | </p> |
| | | </el-col> |
| | | |
| | | <el-col :sm="24" :lg="12" style="padding-left: 50px"> |
| | | <el-row> |
| | | <el-col :span="12"> |
| | | <h2>技术选型</h2> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <h4>后端技术</h4> |
| | | <ul> |
| | | <li>SpringBoot</li> |
| | | <li>Spring Security</li> |
| | | <li>JWT</li> |
| | | <li>MyBatis</li> |
| | | <li>Druid</li> |
| | | <li>Fastjson</li> |
| | | <li>...</li> |
| | | </ul> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <h4>前端技术</h4> |
| | | <ul> |
| | | <li>Vue</li> |
| | | <li>Vuex</li> |
| | | <li>Element-ui</li> |
| | | <li>Axios</li> |
| | | <li>Sass</li> |
| | | <li>Quill</li> |
| | | <li>...</li> |
| | | </ul> |
| | | </el-col> |
| | | </el-row> |
| | | </el-col> |
| | | </el-row> |
| | | <el-divider /> |
| | | <el-row :gutter="20"> |
| | | <el-col :xs="24" :sm="24" :md="12" :lg="8"> |
| | | <el-card class="update-log"> |
| | | <div slot="header" class="clearfix"> |
| | | <span>联系信息</span> |
| | | </div> |
| | | <div class="body"> |
| | | <p> |
| | | <i class="el-icon-s-promotion"></i> 官网:<el-link |
| | | href="http://www.ruoyi.vip" |
| | | target="_blank" |
| | | >http://www.ruoyi.vip</el-link |
| | | > |
| | | </p> |
| | | <p> |
| | | <i class="el-icon-user-solid"></i> QQ群:<s> 满937441 </s> <s> 满887144332 </s> |
| | | <s> 满180251782 </s> <s> 满104180207 </s> <s> 满186866453 </s> <s> 满201396349 </s> |
| | | <s> 满101456076 </s> <s> 满101539465 </s> <s> 满264312783 </s> <s> 满167385320 </s> |
| | | <s> 满104748341 </s> <s> 满160110482 </s> <s> 满170801498 </s> <s> 满108482800 </s> |
| | | <s> 满101046199 </s> <s> 满136919097 </s> <s> 满143961921 </s> <s> 满174951577 </s> <a href="http://qm.qq.com/cgi-bin/qm/qr?_wv=1027&k=Lj0nHRAPD5CZv1jTOciuxXVloBJLS2Lp&authKey=Q2RxC6%2Ffxney9yOGBY0sDJxFhX9b7o1FRY1bsESmkbcZ4PFt6Vx92FpVo9O1u9p4&noverify=0&group_code=161281055" target="_blank">161281055</a> |
| | | </p> |
| | | <p> |
| | | <i class="el-icon-chat-dot-round"></i> 微信:<a |
| | | href="javascript:;" |
| | | >/ *若依</a |
| | | > |
| | | </p> |
| | | <p> |
| | | <i class="el-icon-money"></i> 支付宝:<a |
| | | href="javascript:;" |
| | | class="支付宝信息" |
| | | >/ *若依</a |
| | | > |
| | | </p> |
| | | </div> |
| | | </el-card> |
| | | </el-col> |
| | | <el-col :xs="24" :sm="24" :md="12" :lg="8"> |
| | | <el-card class="update-log"> |
| | | <div slot="header" class="clearfix"> |
| | | <span>更新日志</span> |
| | | </div> |
| | | <el-collapse accordion> |
| | | <el-collapse-item title="v3.8.7 - 2023-12-08"> |
| | | <ol> |
| | | <li>操作日志记录部门名称</li> |
| | | <li>全局数据存储用户编号</li> |
| | | <li>新增编程式判断资源访问权限</li> |
| | | <li>操作日志列表新增IP地址查询</li> |
| | | <li>定时任务新增页去除状态选项</li> |
| | | <li>代码生成支持选择前端模板类型</li> |
| | | <li>显隐列组件支持复选框弹出类型</li> |
| | | <li>通用排序属性orderBy参数限制长度</li> |
| | | <li>Excel自定义数据处理器增加单元格/工作簿对象</li> |
| | | <li>升级oshi到最新版本6.4.8</li> |
| | | <li>升级druid到最新版本1.2.20</li> |
| | | <li>升级fastjson到最新版2.0.43</li> |
| | | <li>升级pagehelper到最新版1.4.7</li> |
| | | <li>升级commons.io到最新版本2.13.0</li> |
| | | <li>升级element-ui到最新版本2.15.14</li> |
| | | <li>修复五级路由缓存无效问题</li> |
| | | <li>修复外链带端口出现的异常</li> |
| | | <li>修复树模板父级编码变量错误</li> |
| | | <li>修复字典表详情页面搜索问题</li> |
| | | <li>修复内链iframe没有传递参数问题</li> |
| | | <li>修复自定义字典样式不生效的问题</li> |
| | | <li>修复字典缓存删除方法参数错误问题</li> |
| | | <li>修复Excel导入数据临时文件无法删除问题</li> |
| | | <li>修复未登录带参数访问成功后参数丢失问题</li> |
| | | <li>修复HeaderSearch组件跳转query参数丢失问题</li> |
| | | <li>修复代码生成导入后必填项与数据库不匹配问题</li> |
| | | <li>修复Excels导入时无法获取到dictType字典值问题</li> |
| | | <li>优化下载zip方法新增遮罩层</li> |
| | | <li>优化头像上传参数新增文件名称</li> |
| | | <li>优化字典标签支持自定义分隔符</li> |
| | | <li>优化菜单管理类型为按钮状态可选</li> |
| | | <li>优化前端防重复提交数据大小限制</li> |
| | | <li>优化TopNav菜单没有图标svg不显示</li> |
| | | <li>优化数字金额大写转换精度丢失问题</li> |
| | | <li>优化富文本Editor组件检验图片格式</li> |
| | | <li>优化页签在Firefox浏览器被遮挡的问题</li> |
| | | <li>优化个人中心/基本资料修改时数据显示问题</li> |
| | | <li>优化缓存监控图表支持跟随屏幕大小自适应调整</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.8.6 - 2023-06-30"> |
| | | <ol> |
| | | <li>支持登录IP黑名单限制</li> |
| | | <li>新增监控页面图标显示</li> |
| | | <li>操作日志新增消耗时间属性</li> |
| | | <li>屏蔽定时任务bean违规的字符</li> |
| | | <li>日志管理使用索引提升查询性能</li> |
| | | <li>日志注解支持排除指定的请求参数</li> |
| | | <li>支持自定义隐藏属性列过滤子对象</li> |
| | | <li>升级oshi到最新版本6.4.3</li> |
| | | <li>升级druid到最新版本1.2.16</li> |
| | | <li>升级fastjson到最新版2.0.34</li> |
| | | <li>升级spring-boot到最新版本2.5.15</li> |
| | | <li>升级element-ui到最新版本2.15.13</li> |
| | | <li>移除apache/commons-fileupload依赖</li> |
| | | <li>修复页面切换时布局错乱的问题</li> |
| | | <li>修复匿名注解Anonymous空指针问题</li> |
| | | <li>修复路由跳转被阻止时内部产生报错信息问题</li> |
| | | <li>修复isMatchedIp的参数判断产生空指针的问题</li> |
| | | <li>修复用户多角色数据权限可能出现权限抬升的情况</li> |
| | | <li>修复开启TopNav后一级菜单路由参数设置无效问题</li> |
| | | <li>修复DictTag组件value没有匹配的值时则展示value</li> |
| | | <li>优化文件下载出现的异常</li> |
| | | <li>优化选择图标组件高亮回显</li> |
| | | <li>优化弹窗后导航栏偏移的问题</li> |
| | | <li>优化修改密码日志存储明文问题</li> |
| | | <li>优化页签栏关闭其他出现的异常问题</li> |
| | | <li>优化页签关闭左侧选项排除首页选项</li> |
| | | <li>优化关闭当前tab页跳转最右侧tab页</li> |
| | | <li>优化缓存列表清除操作提示不变的问题</li> |
| | | <li>优化字符未使用下划线不进行驼峰式处理</li> |
| | | <li>优化用户导入更新时需获取用户编号问题</li> |
| | | <li>优化侧边栏的平台标题与VUE_APP_TITLE保持同步</li> |
| | | <li>优化导出Excel时设置dictType属性重复查缓存问题</li> |
| | | <li>连接池Druid支持新的配置connectTimeout和socketTimeout</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.8.5 - 2023-01-01"> |
| | | <ol> |
| | | <li>定时任务违规的字符</li> |
| | | <li>重置时取消部门选中</li> |
| | | <li>新增返回警告消息提示</li> |
| | | <li>忽略不必要的属性数据返回</li> |
| | | <li>修改参数键名时移除前缓存配置</li> |
| | | <li>导入更新用户数据前校验数据权限</li> |
| | | <li>兼容Excel下拉框内容过多无法显示的问题</li> |
| | | <li>升级echarts到最新版本5.4.0</li> |
| | | <li>升级core-js到最新版本3.25.3</li> |
| | | <li>升级oshi到最新版本6.4.0</li> |
| | | <li>升级kaptcha到最新版2.3.3</li> |
| | | <li>升级druid到最新版本1.2.15</li> |
| | | <li>升级fastjson到最新版2.0.20</li> |
| | | <li>升级pagehelper到最新版1.4.6</li> |
| | | <li>优化弹窗内容过多展示不全问题</li> |
| | | <li>优化swagger-ui静态资源使用缓存</li> |
| | | <li>开启TopNav没有子菜单隐藏侧边栏</li> |
| | | <li>删除fuse无效选项maxPatternLength</li> |
| | | <li>优化导出对象的子列表为空会出现[]问题</li> |
| | | <li>优化编辑头像时透明部分会变成黑色问题</li> |
| | | <li>优化小屏幕上修改头像界面布局错位的问题</li> |
| | | <li>修复代码生成勾选属性无效问题</li> |
| | | <li>修复文件上传组件格式验证问题</li> |
| | | <li>修复回显数据字典数组异常问题</li> |
| | | <li>修复sheet超出最大行数异常问题</li> |
| | | <li>修复Log注解GET请求记录不到参数问题</li> |
| | | <li>修复调度日志点击多次数据不变化的问题</li> |
| | | <li>修复主题颜色在Drawer组件不会加载问题</li> |
| | | <li>修复文件名包含特殊字符的文件无法下载问题</li> |
| | | <li>修复table中更多按钮切换主题色未生效修复问题</li> |
| | | <li>修复某些特性的环境生成代码变乱码TXT文件问题</li> |
| | | <li>修复代码生成图片/文件/单选时选择必填无法校验问题</li> |
| | | <li>修复某些特性的情况用户编辑对话框中角色和部门无法修改问题</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.8.4 - 2022-09-26"> |
| | | <ol> |
| | | <li>数据逻辑删除不进行唯一验证</li> |
| | | <li>Excel注解支持导出对象的子列表方法</li> |
| | | <li>Excel注解支持自定义隐藏属性列</li> |
| | | <li>Excel注解支持backgroundColor属性设置背景色</li> |
| | | <li>支持配置密码最大错误次数/锁定时间</li> |
| | | <li>登录日志新增解锁账户功能</li> |
| | | <li>通用下载方法新增config配置选项</li> |
| | | <li>支持多权限字符匹配角色数据权限</li> |
| | | <li>页面内嵌iframe切换tab不刷新数据</li> |
| | | <li>操作日志记录支持排除敏感属性字段</li> |
| | | <li>修复多文件上传报错出现的异常问题</li> |
| | | <li>修复图片预览组件src属性为null值控制台报错问题</li> |
| | | <li>升级oshi到最新版本6.2.2</li> |
| | | <li>升级fastjson到最新版2.0.14</li> |
| | | <li>升级pagehelper到最新版1.4.3</li> |
| | | <li>升级core-js到最新版本3.25.2</li> |
| | | <li>升级element-ui到最新版本2.15.10</li> |
| | | <li>优化任务过期不执行调度</li> |
| | | <li>优化字典数据使用store存取</li> |
| | | <li>优化修改资料头像被覆盖的问题</li> |
| | | <li>优化修改用户登录账号重复验证</li> |
| | | <li>优化代码生成同步后值NULL问题</li> |
| | | <li>优化定时任务支持执行父类方法</li> |
| | | <li>优化用户个人信息接口防止修改部门</li> |
| | | <li>优化布局设置使用el-drawer抽屉显示</li> |
| | | <li>优化没有权限的用户编辑部门缺少数据</li> |
| | | <li>优化日志注解记录限制请求地址的长度</li> |
| | | <li>优化excel/scale属性导出单元格数值类型</li> |
| | | <li>优化日志操作中重置按钮时重复查询的问题</li> |
| | | <li>优化多个相同角色数据导致权限SQL重复问题</li> |
| | | <li>优化表格上右侧工具条(搜索按钮显隐&右侧样式凸出)</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.8.3 - 2022-06-27"> |
| | | <ol> |
| | | <li>新增缓存列表菜单功能</li> |
| | | <li>代码生成树表新增(展开/折叠)</li> |
| | | <li>Excel注解支持color字体颜色</li> |
| | | <li>新增Anonymous匿名访问不鉴权注解</li> |
| | | <li>用户头像上传限制只能为图片格式</li> |
| | | <li>接口使用泛型使其看到响应属性字段</li> |
| | | <li>检查定时任务bean所在包名是否为白名单配置</li> |
| | | <li>添加页签openPage支持传递参数</li> |
| | | <li>用户缓存信息添加部门ancestors祖级列表</li> |
| | | <li>升级element-ui到最新版本2.15.8</li> |
| | | <li>升级oshi到最新版本6.1.6</li> |
| | | <li>升级druid到最新版本1.2.11</li> |
| | | <li>升级fastjson到最新版2.0.8</li> |
| | | <li>升级spring-boot到最新版本2.5.14</li> |
| | | <li>降级jsencrypt版本兼容IE浏览器</li> |
| | | <li>删除多余的salt字段</li> |
| | | <li>新增获取不带后缀文件名称方法</li> |
| | | <li>新增获取配置文件中的属性值方法</li> |
| | | <li>新增内容编码/解码方便插件集成使用</li> |
| | | <li>字典类型必须以字母开头,且只能为(小写字母,数字,下滑线)</li> |
| | | <li>优化设置分页参数默认值</li> |
| | | <li>优化对空字符串参数处理的过滤</li> |
| | | <li>优化显示顺序orderNum类型为整型</li> |
| | | <li>优化表单构建按钮不显示正则校验</li> |
| | | <li>优化字典数据回显样式下拉框显示值</li> |
| | | <li>优化R响应成功状态码与全局保持一致</li> |
| | | <li>优化druid开启wall过滤器出现的异常问题</li> |
| | | <li>优化用户管理左侧树型组件增加选中高亮保持</li> |
| | | <li>优化新增用户与角色信息&用户与岗位信息逻辑</li> |
| | | <li>优化默认不启用压缩文件缓存防止node_modules过大</li> |
| | | <li>修复字典数据显示不全问题</li> |
| | | <li>修复操作日志查询类型条件为0时会查到所有数据</li> |
| | | <li>修复Excel注解prompt/combo同时使用不生效问题</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.8.2 - 2022-04-01"> |
| | | <ol> |
| | | <li>前端支持设置是否需要防止数据重复提交</li> |
| | | <li>开启TopNav没有子菜单情况隐藏侧边栏</li> |
| | | <li>侧边栏菜单名称过长悬停显示标题</li> |
| | | <li>用户访问控制时校验数据权限,防止越权</li> |
| | | <li>导出Excel时屏蔽公式,防止CSV注入风险</li> |
| | | <li>组件ImagePreview支持多图预览显示</li> |
| | | <li>组件ImageUpload支持多图同时选择上传</li> |
| | | <li>组件FileUpload支持多文件同时选择上传</li> |
| | | <li>服务监控新增运行参数信息显示</li> |
| | | <li>定时任务目标字符串过滤特殊字符</li> |
| | | <li>定时任务目标字符串验证包名白名单</li> |
| | | <li>代码生成列表图片支持预览</li> |
| | | <li>代码生成编辑修改打开新页签</li> |
| | | <li>代码生成新增Java类型Boolean</li> |
| | | <li>代码生成子表支持日期/字典配置</li> |
| | | <li>代码生成同步保留必填/类型选项</li> |
| | | <li>升级oshi到最新版本6.1.2</li> |
| | | <li>升级fastjson到最新版1.2.80</li> |
| | | <li>升级pagehelper到最新版1.4.1</li> |
| | | <li>升级spring-boot到最新版本2.5.11</li> |
| | | <li>升级spring-boot-mybatis到最新版2.2.2</li> |
| | | <li>添加遗漏的分页参数合理化属性</li> |
| | | <li>修改npm即将过期的注册源地址</li> |
| | | <li>修复分页组件请求两次问题</li> |
| | | <li>修复通用文件下载接口跨域问题</li> |
| | | <li>修复Xss注解字段值为空时的异常问题</li> |
| | | <li>修复选项卡点击右键刷新丢失参数问题</li> |
| | | <li>修复表单清除元素位置未垂直居中问题</li> |
| | | <li>修复服务监控中运行参数显示条件错误</li> |
| | | <li>修复导入Excel时字典字段类型为Long转义为空问题</li> |
| | | <li>修复登录超时刷新页面跳转登录页面还提示重新登录问题</li> |
| | | <li>优化加载字典缓存数据</li> |
| | | <li>优化IP地址获取到多个的问题</li> |
| | | <li>优化任务队列满时任务拒绝策略</li> |
| | | <li>优化文件上传兼容Weblogic环境</li> |
| | | <li>优化定时任务默认保存到内存中执行</li> |
| | | <li>优化部门修改缩放后出现的错位问题</li> |
| | | <li>优化Excel格式化不同类型的日期对象</li> |
| | | <li>优化菜单表关键字导致的插件报错问题</li> |
| | | <li>优化Oracle用户头像列为空时不显示问题</li> |
| | | <li>优化页面若未匹配到字典标签则返回原字典值</li> |
| | | <li>优化修复登录失效后多次请求提示多次弹窗问题</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.8.1 - 2022-01-01"> |
| | | <ol> |
| | | <li>新增Vue3前端代码生成模板</li> |
| | | <li>新增图片预览组件</li> |
| | | <li>新增压缩插件实现打包Gzip</li> |
| | | <li>自定义xss校验注解实现</li> |
| | | <li>自定义文字复制剪贴指令</li> |
| | | <li>代码生成预览支持复制内容</li> |
| | | <li>路由支持单独配置菜单或角色权限</li> |
| | | <li>用户管理部门查询选择节点后分页参数初始</li> |
| | | <li>修复用户分配角色属性错误</li> |
| | | <li>修复打包后字体图标偶现的乱码问题</li> |
| | | <li>修复菜单管理重置表单出现的错误</li> |
| | | <li>修复版本差异导致的懒加载报错问题</li> |
| | | <li>修复Cron组件中周回显问题</li> |
| | | <li>修复定时任务多参数逗号分隔的问题</li> |
| | | <li>修复根据ID查询列表可能出现的主键溢出问题</li> |
| | | <li>修复tomcat配置参数已过期问题</li> |
| | | <li>升级clipboard到最新版本2.0.8</li> |
| | | <li>升级oshi到最新版本v5.8.6</li> |
| | | <li>升级fastjson到最新版1.2.79</li> |
| | | <li>升级spring-boot到最新版本2.5.8</li> |
| | | <li>升级log4j2到2.17.1,防止漏洞风险</li> |
| | | <li>优化下载解析blob异常提示</li> |
| | | <li>优化代码生成字典组重复问题</li> |
| | | <li>优化查询用户的角色组&岗位组代码</li> |
| | | <li>优化定时任务cron表达式小时设置24</li> |
| | | <li>优化用户导入提示溢出则显示滚动条</li> |
| | | <li>优化防重复提交标识组合为(key+url+header)</li> |
| | | <li>优化分页方法设置成通用方便灵活调用</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.8.0 - 2021-12-01"> |
| | | <ol> |
| | | <li>新增配套并同步的Vue3前端版本</li> |
| | | <li>新增通用方法简化模态/缓存/下载/权限/页签使用</li> |
| | | <li>优化导出数据/使用通用下载方法</li> |
| | | <li>Excel注解支持自定义数据处理器</li> |
| | | <li>Excel注解支持导入导出标题信息</li> |
| | | <li>Excel导入支持@Excels注解</li> |
| | | <li>新增组件data-dict,简化数据字典使用</li> |
| | | <li>新增Jaxb依赖,防止jdk8以上出现的兼容错误</li> |
| | | <li>生产环境使用路由懒加载提升页面响应速度</li> |
| | | <li>修复五级以上菜单出现的404问题</li> |
| | | <li>防重提交注解支持配置间隔时间/提示消息</li> |
| | | <li>日志注解新增是否保存响应参数</li> |
| | | <li>任务屏蔽违规字符&参数忽略双引号中的逗号</li> |
| | | <li>升级SpringBoot到最新版本2.5.6</li> |
| | | <li>升级pagehelper到最新版1.4.0</li> |
| | | <li>升级spring-boot-mybatis到最新版2.2.0</li> |
| | | <li>升级oshi到最新版本v5.8.2</li> |
| | | <li>升级druid到最新版1.2.8</li> |
| | | <li>升级velocity到最新版本2.3</li> |
| | | <li>升级fastjson到最新版1.2.78</li> |
| | | <li>升级axios到最新版本0.24.0</li> |
| | | <li>升级dart-sass到版本1.32.13</li> |
| | | <li>升级core-js到最新版本3.19.1</li> |
| | | <li>升级jsencrypt到最新版本3.2.1</li> |
| | | <li>升级js-cookie到最新版本3.0.1</li> |
| | | <li>升级file-saver到最新版本2.0.5</li> |
| | | <li>升级sass-loader到最新版本10.1.1</li> |
| | | <li>升级element-ui到最新版本2.15.6</li> |
| | | <li>新增sendGet无参请求方法</li> |
| | | <li>禁用el-tag组件的渐变动画</li> |
| | | <li>代码生成点击预览重置激活tab</li> |
| | | <li>AjaxResult重写put方法,以方便链式调用</li> |
| | | <li>优化登录/验证码请求headers不设置token</li> |
| | | <li>优化用户个人信息接口防止修改用户名</li> |
| | | <li>优化Cron表达式生成器关闭时销毁避免缓存</li> |
| | | <li>优化注册成功提示消息类型success</li> |
| | | <li>优化aop语法,使用spring自动注入注解</li> |
| | | <li>优化记录登录信息,移除不必要的修改</li> |
| | | <li>优化mybatis全局默认的执行器</li> |
| | | <li>优化Excel导入图片可能出现的异常</li> |
| | | <li>修复代码生成模板主子表删除缺少事务</li> |
| | | <li>修复日志记录可能出现的转换异常</li> |
| | | <li>修复代码生成复选框字典遗漏问题</li> |
| | | <li>修复关闭xss功能导致可重复读RepeatableFilter失效</li> |
| | | <li>修复字符串无法被反转义问题</li> |
| | | <li>修复后端主子表代码模板方法名生成错误问题</li> |
| | | <li>修复xss过滤后格式出现的异常</li> |
| | | <li>修复swagger没有指定dataTypeClass导致启动出现warn日志</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.7.0 - 2021-09-13"> |
| | | <ol> |
| | | <li>参数管理支持配置验证码开关</li> |
| | | <li>新增是否开启用户注册功能</li> |
| | | <li>定时任务支持在线生成cron表达式</li> |
| | | <li>菜单管理支持配置路由参数</li> |
| | | <li>支持自定义注解实现接口限流</li> |
| | | <li>Excel注解支持Image图片导入</li> |
| | | <li>自定义弹层溢出滚动样式</li> |
| | | <li>自定义可拖动弹窗宽度指令</li> |
| | | <li>自定义可拖动弹窗高度指令</li> |
| | | <li>修复任意账户越权问题</li> |
| | | <li>修改时检查用户数据权限范围</li> |
| | | <li>修复保存配置主题颜色失效问题</li> |
| | | <li>新增暗色菜单风格主题</li> |
| | | <li>菜单&部门新增展开/折叠功能</li> |
| | | <li>页签新增关闭左侧&添加图标</li> |
| | | <li>顶部菜单排除隐藏的默认路由</li> |
| | | <li>顶部菜单同步系统主题样式</li> |
| | | <li>跳转路由高亮相对应的菜单栏</li> |
| | | <li>代码生成主子表多选行数据</li> |
| | | <li>日期范围支持添加多组</li> |
| | | <li>升级element-ui到最新版本2.15.5</li> |
| | | <li>升级oshi到最新版本v5.8.0</li> |
| | | <li>升级commons.io到最新版本v2.11.0</li> |
| | | <li>定时任务屏蔽ldap远程调用</li> |
| | | <li>定时任务屏蔽http(s)远程调用</li> |
| | | <li>补充定时任务表字段注释</li> |
| | | <li>定时任务对检查异常进行事务回滚</li> |
| | | <li>启用父部门状态排除顶级节点</li> |
| | | <li>富文本新增上传文件大小限制</li> |
| | | <li>默认首页使用keep-alive缓存</li> |
| | | <li>修改代码生成字典回显样式</li> |
| | | <li>自定义分页合理化传入参数</li> |
| | | <li>修复字典组件值为整形不显示问题</li> |
| | | <li>修复定时任务日志执行状态显示</li> |
| | | <li>角色&菜单新增字段属性提示信息</li> |
| | | <li>修复角色分配用户页面参数类型错误提醒</li> |
| | | <li>优化布局设置动画特效</li> |
| | | <li>优化异常处理信息</li> |
| | | <li>优化错误token导致的解析异常</li> |
| | | <li>密码框新增显示切换密码图标</li> |
| | | <li>定时任务新增更多操作</li> |
| | | <li>更多操作按钮添加权限控制</li> |
| | | <li>导入用户样式优化</li> |
| | | <li>提取通用方法到基类控制器</li> |
| | | <li>优化使用权限工具获取用户信息</li> |
| | | <li>优化用户不能删除自己</li> |
| | | <li>优化XSS跨站脚本过滤</li> |
| | | <li>优化代码生成模板</li> |
| | | <li>验证码默认20s超时</li> |
| | | <li>BLOB下载时清除URL对象引用</li> |
| | | <li>代码生成导入表按创建时间排序</li> |
| | | <li>修复代码生成页面数据编辑保存之后总是跳转第一页的问题</li> |
| | | <li>修复带safari浏览器无法格式化utc日期格式yyyy-MM-dd'T'HH:mm:ss.SSS问题</li> |
| | | <li>多图上传组件移除多余的api地址&验证失败导致图片删除问题&无法删除相应图片修复</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.6.0 - 2021-07-12"> |
| | | <ol> |
| | | <li>角色管理新增分配用户功能</li> |
| | | <li>用户管理新增分配角色功能</li> |
| | | <li>日志列表支持排序操作</li> |
| | | <li>优化参数&字典缓存操作</li> |
| | | <li>系统布局配置支持动态标题开关</li> |
| | | <li>菜单路由配置支持内链访问</li> |
| | | <li>默认访问后端首页新增提示语</li> |
| | | <li>富文本默认上传返回url类型</li> |
| | | <li>新增自定义弹窗拖拽指令</li> |
| | | <li>全局注册常用通用组件</li> |
| | | <li>全局挂载字典标签组件</li> |
| | | <li>ImageUpload组件支持多图片上传</li> |
| | | <li>FileUpload组件支持多文件上传</li> |
| | | <li>文件上传组件添加数量限制属性</li> |
| | | <li>富文本编辑组件添加类型属性</li> |
| | | <li>富文本组件工具栏配置视频</li> |
| | | <li>封装通用iframe组件</li> |
| | | <li>限制超级管理员不允许操作</li> |
| | | <li>用户信息长度校验限制</li> |
| | | <li>分页组件新增pagerCount属性</li> |
| | | <li>添加bat脚本执行应用</li> |
| | | <li>升级oshi到最新版本v5.7.4</li> |
| | | <li>升级element-ui到最新版本2.15.2</li> |
| | | <li>升级pagehelper到最新版1.3.1</li> |
| | | <li>升级commons.io到最新版本v2.10.0</li> |
| | | <li>升级commons.fileupload到最新版本v1.4</li> |
| | | <li>升级swagger到最新版本v3.0.0</li> |
| | | <li>修复关闭confirm提示框控制台报错问题</li> |
| | | <li>修复存在的SQL注入漏洞问题</li> |
| | | <li>定时任务屏蔽rmi远程调用</li> |
| | | <li>修复用户搜索分页变量错误</li> |
| | | <li>修复导出角色数据范围翻译缺少仅本人</li> |
| | | <li>修复表单构建选择下拉选择控制台报错问题</li> |
| | | <li>优化图片工具类读取文件</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.5.0 - 2021-05-25"> |
| | | <ol> |
| | | <li>新增菜单导航显示风格TopNav(false为左侧导航菜单,true为顶部导航菜单)</li> |
| | | <li>布局设置支持保存&重置配置</li> |
| | | <li>修复树表数据显示不全&加载慢问题</li> |
| | | <li>新增IE浏览器版本过低提示页面</li> |
| | | <li>用户登录后记录最后登录IP&时间</li> |
| | | <li>页面导出按钮点击之后添加遮罩</li> |
| | | <li>富文本编辑器支持自定义上传地址</li> |
| | | <li>富文本编辑组件新增readOnly属性</li> |
| | | <li>页签TagsView新增关闭右侧功能</li> |
| | | <li>显隐列组件加载初始默认隐藏列</li> |
| | | <li>关闭头像上传窗口还原默认图片</li> |
| | | <li>个人信息添加手机&邮箱重复验证</li> |
| | | <li>代码生成模板导出按钮点击后添加遮罩</li> |
| | | <li>代码生成模板树表操作列添加新增按钮</li> |
| | | <li>代码生成模板修复主子表字段重名问题</li> |
| | | <li>升级fastjson到最新版1.2.76</li> |
| | | <li>升级druid到最新版本v1.2.6</li> |
| | | <li>升级mybatis到最新版3.5.6 阻止远程代码执行漏洞</li> |
| | | <li>升级oshi到最新版本v5.6.0</li> |
| | | <li>velocity剔除commons-collections版本,防止3.2.1版本的反序列化漏洞</li> |
| | | <li>数据监控页默认账户密码防止越权访问</li> |
| | | <li>修复firefox下表单构建拖拽会新打卡一个选项卡</li> |
| | | <li>修正后端导入表权限标识</li> |
| | | <li>修正前端操作日志&登录日志权限标识</li> |
| | | <li>设置Redis配置HashKey序列化</li> |
| | | <li>删除操作日志记录信息</li> |
| | | <li>上传媒体类型添加视频格式</li> |
| | | <li>修复请求形参未传值记录日志异常问题</li> |
| | | <li>优化xss校验json请求条件</li> |
| | | <li>树级结构更新子节点使用replaceFirst</li> |
| | | <li>优化ExcelUtil空值处理</li> |
| | | <li>日志记录过滤BindingResult对象,防止异常</li> |
| | | <li>修改主题后mini类型按钮无效问题</li> |
| | | <li>优化通用下载完成后删除节点</li> |
| | | <li>通用Controller添加响应返回消息</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.4.0 - 2021-02-22"> |
| | | <ol> |
| | | <li>代码生成模板支持主子表</li> |
| | | <li>表格右侧工具栏组件支持显隐列</li> |
| | | <li>图片组件添加预览&移除功能</li> |
| | | <li>Excel注解支持Image图片导出</li> |
| | | <li>操作按钮组调整为朴素按钮样式</li> |
| | | <li>代码生成支持文件上传组件</li> |
| | | <li>代码生成日期控件区分范围</li> |
| | | <li>代码生成数据库文本类型生成表单文本域</li> |
| | | <li>用户手机邮箱&菜单组件修改允许空字符串</li> |
| | | <li>升级SpringBoot到最新版本2.2.13 提升启动速度</li> |
| | | <li>升级druid到最新版本v1.2.4</li> |
| | | <li>升级fastjson到最新版1.2.75</li> |
| | | <li>升级element-ui到最新版本2.15.0</li> |
| | | <li>修复IE11浏览器报错问题</li> |
| | | <li>优化多级菜单之间切换无法缓存的问题</li> |
| | | <li>修复四级菜单无法显示问题</li> |
| | | <li>修正侧边栏静态路由丢失问题</li> |
| | | <li>修复角色管理-编辑角色-功能权限显示异常</li> |
| | | <li>配置文件新增redis数据库索引属性</li> |
| | | <li>权限工具类增加admin判断</li> |
| | | <li>角色非自定义权限范围清空选择值</li> |
| | | <li>修复导入数据为负浮点数时丢失精度问题</li> |
| | | <li>移除path-to-regexp正则匹配插件</li> |
| | | <li>修复生成树表代码异常</li> |
| | | <li>修改ip字段长度防止ipv6地址长度不够</li> |
| | | <li>防止get请求参数值为false或0等特殊值会导致无法正确的传参</li> |
| | | <li>登录后push添加catch防止出现检查错误</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.3.0 - 2020-12-14"> |
| | | <ol> |
| | | <li>新增缓存监控功能</li> |
| | | <li>支持主题风格配置</li> |
| | | <li>修复多级菜单之间切换无法缓存的问题</li> |
| | | <li>多级菜单自动配置组件</li> |
| | | <li>代码生成预览支持高亮显示</li> |
| | | <li>支持Get请求映射Params参数</li> |
| | | <li>删除用户和角色解绑关联</li> |
| | | <li>去除用户手机邮箱部门必填验证</li> |
| | | <li>Excel支持注解align对齐方式</li> |
| | | <li>Excel支持导入Boolean型数据</li> |
| | | <li>优化头像样式,鼠标移入悬停遮罩</li> |
| | | <li>代码生成预览提供滚动机制</li> |
| | | <li>代码生成删除多余的数字float类型</li> |
| | | <li>修正转换字符串的目标字符集属性</li> |
| | | <li>回显数据字典防止空值报错</li> |
| | | <li>日志记录增加过滤多文件场景</li> |
| | | <li>修改缓存Set方法可能导致嵌套的问题</li> |
| | | <li>移除前端一些多余的依赖</li> |
| | | <li>防止安全扫描YUI出现的风险提示</li> |
| | | <li>修改node-sass为dart-sass</li> |
| | | <li>升级SpringBoot到最新版本2.1.18</li> |
| | | <li>升级poi到最新版本4.1.2</li> |
| | | <li>升级oshi到最新版本v5.3.6</li> |
| | | <li>升级bitwalker到最新版本1.21</li> |
| | | <li>升级axios到最新版本0.21.0</li> |
| | | <li>升级element-ui到最新版本2.14.1</li> |
| | | <li>升级vue到最新版本2.6.12</li> |
| | | <li>升级vuex到最新版本3.6.0</li> |
| | | <li>升级vue-cli到版本4.5.9</li> |
| | | <li>升级vue-router到最新版本3.4.9</li> |
| | | <li>升级vue-cli到最新版本4.4.6</li> |
| | | <li>升级vue-cropper到最新版本0.5.5</li> |
| | | <li>升级clipboard到最新版本2.0.6</li> |
| | | <li>升级core-js到最新版本3.8.1</li> |
| | | <li>升级echarts到最新版本4.9.0</li> |
| | | <li>升级file-saver到最新版本2.0.4</li> |
| | | <li>升级fuse.js到最新版本6.4.3</li> |
| | | <li>升级js-beautify到最新版本1.13.0</li> |
| | | <li>升级js-cookie到最新版本2.2.1</li> |
| | | <li>升级path-to-regexp到最新版本6.2.0</li> |
| | | <li>升级quill到最新版本1.3.7</li> |
| | | <li>升级screenfull到最新版本5.0.2</li> |
| | | <li>升级sortablejs到最新版本1.10.2</li> |
| | | <li>升级vuedraggable到最新版本2.24.3</li> |
| | | <li>升级chalk到最新版本4.1.0</li> |
| | | <li>升级eslint到最新版本7.15.0</li> |
| | | <li>升级eslint-plugin-vue到最新版本7.2.0</li> |
| | | <li>升级lint-staged到最新版本10.5.3</li> |
| | | <li>升级runjs到最新版本4.4.2</li> |
| | | <li>升级sass-loader到最新版本10.1.0</li> |
| | | <li>升级script-ext-html-webpack-plugin到最新版本2.1.5</li> |
| | | <li>升级svg-sprite-loader到最新版本5.1.1</li> |
| | | <li>升级vue-template-compiler到最新版本2.6.12</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.2.1 - 2020-11-18"> |
| | | <ol> |
| | | <li>阻止任意文件下载漏洞</li> |
| | | <li>代码生成支持上传控件</li> |
| | | <li>新增图片上传组件</li> |
| | | <li>调整默认首页</li> |
| | | <li>升级druid到最新版本v1.2.2</li> |
| | | <li>mapperLocations配置支持分隔符</li> |
| | | <li>权限信息调整</li> |
| | | <li>调整sql默认时间</li> |
| | | <li>解决代码生成没有bit类型的问题</li> |
| | | <li>升级pagehelper到最新版1.3.0</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v3.2.0 - 2020-10-10"> |
| | | <ol> |
| | | <li>升级springboot版本到2.1.17 提升安全性</li> |
| | | <li>升级oshi到最新版本v5.2.5</li> |
| | | <li>升级druid到最新版本v1.2.1</li> |
| | | <li>升级jjwt到版本0.9.1</li> |
| | | <li>升级fastjson到最新版1.2.74</li> |
| | | <li>修改sass为node-sass,避免el-icon图标乱码</li> |
| | | <li>代码生成支持同步数据库</li> |
| | | <li>代码生成支持富文本控件</li> |
| | | <li>代码生成页面时不忽略remark属性</li> |
| | | <li>代码生成添加select必填选项</li> |
| | | <li>Excel导出类型NUMERIC支持精度浮点类型</li> |
| | | <li>Excel导出targetAttr优化获取值,防止get方法不规范</li> |
| | | <li>Excel注解支持自动统计数据总和</li> |
| | | <li>Excel注解支持设置BigDecimal精度&舍入规则</li> |
| | | <li>菜单&数据权限新增(展开/折叠 全选/全不选 父子联动)</li> |
| | | <li>允许用户分配到部门父节点</li> |
| | | <li>菜单新增是否缓存keep-alive</li> |
| | | <li>表格操作列间距调整</li> |
| | | <li>限制系统内置参数不允许删除</li> |
| | | <li>富文本组件优化,支持自定义高度&图片冲突问题</li> |
| | | <li>富文本工具栏样式对齐</li> |
| | | <li>导入excel整形值校验优化</li> |
| | | <li>修复页签关闭所有时固定标签路由不刷新问题</li> |
| | | <li>表单构建布局型组件新增按钮</li> |
| | | <li>左侧菜单文字过长显示省略号</li> |
| | | <li>修正根节点为子部门时,树状结构显示问题</li> |
| | | <li>修正调用目标字符串最大长度</li> |
| | | <li>修正菜单提示信息错误</li> |
| | | <li>修正定时任务执行一次权限标识</li> |
| | | <li>修正数据库字符串类型nvarchar</li> |
| | | <li>优化递归子节点</li> |
| | | <li>优化数据权限判断</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | |
| | | <el-collapse-item title="v3.1.0 - 2020-08-13"> |
| | | <ol> |
| | | <li>表格工具栏右侧添加刷新&显隐查询组件</li> |
| | | <li>后端支持CORS跨域请求</li> |
| | | <li>代码生成支持选择上级菜单</li> |
| | | <li>代码生成支持自定义路径</li> |
| | | <li>代码生成支持复选框</li> |
| | | <li>Excel导出导入支持dictType字典类型</li> |
| | | <li>Excel支持分割字符串组内容</li> |
| | | <li>验证码类型支持(数组计算、字符验证)</li> |
| | | <li>升级vue-cli版本到4.4.4</li> |
| | | <li>修改 node-sass 为 dart-sass</li> |
| | | <li>表单类型为Integer/Long设置整形默认值</li> |
| | | <li>代码生成器默认mapper路径与默认mapperScan路径不一致</li> |
| | | <li>优化防重复提交拦截器</li> |
| | | <li>优化上级菜单不能选择自己</li> |
| | | <li>修复角色的权限分配后,未实时生效问题</li> |
| | | <li>修复在线用户日志记录类型</li> |
| | | <li>修复富文本空格和缩进保存后不生效问题</li> |
| | | <li>修复在线用户判断逻辑</li> |
| | | <li>唯一限制条件只返回单条数据</li> |
| | | <li>添加获取当前的环境配置方法</li> |
| | | <li>超时登录后页面跳转到首页</li> |
| | | <li>全局异常状态汉化拦截处理</li> |
| | | <li>HTML过滤器改为将html转义</li> |
| | | <li>检查字符支持小数点&降级改成异常提醒</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | |
| | | <el-collapse-item title="v3.0.0 - 2020-07-20"> |
| | | <ol> |
| | | <li>单应用调整为多模块项目</li> |
| | | <li>升级element-ui版本到2.13.2</li> |
| | | <li>删除babel,提高编译速度。</li> |
| | | <li>新增菜单默认主类目</li> |
| | | <li>编码文件名修改为uuid方式</li> |
| | | <li>定时任务cron表达式验证</li> |
| | | <li>角色权限修改时已有权限未自动勾选异常修复</li> |
| | | <li>防止切换权限用户后登录出现404</li> |
| | | <li>Excel支持sort导出排序</li> |
| | | <li>创建用户不允许选择超级管理员角色</li> |
| | | <li>修复代码生成导入表结构出现异常页面不提醒问题</li> |
| | | <li>修复代码生成点击多次表修改数据不变化的问题</li> |
| | | <li>修复头像上传成功二次打开无法改变裁剪框大小和位置问题</li> |
| | | <li>修复布局为small者mini用户表单显示错位问题</li> |
| | | <li>修复热部署导致的强换异常问题</li> |
| | | <li>修改用户管理复选框宽度,防止部分浏览器出现省略号</li> |
| | | <li>IpUtils工具,清除Xss特殊字符,防止Xff注入攻击</li> |
| | | <li>生成domain 如果是浮点型 统一用BigDecimal</li> |
| | | <li>定时任务调整label-width,防止部署出现错位</li> |
| | | <li>调整表头固定列默认样式</li> |
| | | <li>代码生成模板调整,字段为String并且必填则加空串条件</li> |
| | | <li>代码生成字典Integer/Long使用parseInt</li> |
| | | <li> |
| | | 修复dict_sort不可update为0的问题&查询返回增加dict_sort升序排序 |
| | | </li> |
| | | <li>修正岗位导出权限注解</li> |
| | | <li>禁止加密密文返回前端</li> |
| | | <li>修复代码生成页面中的查询条件创建时间未生效的问题</li> |
| | | <li>修复首页搜索菜单外链无法点击跳转问题</li> |
| | | <li>修复菜单管理选择图标,backspace删除时不过滤数据</li> |
| | | <li>用户管理部门分支节点不可检查&显示计数</li> |
| | | <li>数据范围过滤属性调整</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | |
| | | <el-collapse-item title="v2.3.0 - 2020-06-01"> |
| | | <ol> |
| | | <li>升级fastjson到最新版1.2.70 修复高危安全漏洞</li> |
| | | <li>dev启动默认打开浏览器</li> |
| | | <li>vue-cli使用默认source-map</li> |
| | | <li>slidebar eslint报错优化</li> |
| | | <li>当tags-view滚动关闭右键菜单</li> |
| | | <li>字典管理添加缓存读取</li> |
| | | <li>参数管理支持缓存操作</li> |
| | | <li>支持一级菜单(和主页同级)在main区域显示</li> |
| | | <li>限制外链地址必须以http(s)开头</li> |
| | | <li>tagview & sidebar 主题颜色与element ui(全局)同步</li> |
| | | <li>修改数据源类型优先级,先根据方法,再根据类</li> |
| | | <li>支持是否需要设置token属性,自定义返回码消息。</li> |
| | | <li>swagger请求前缀加入配置。</li> |
| | | <li>登录地点设置内容过长则隐藏显示</li> |
| | | <li>修复定时任务执行一次按钮后不提示消息问题</li> |
| | | <li>修改上级部门(选择项排除本身和下级)</li> |
| | | <li>通用http发送方法增加参数 contentType 编码类型</li> |
| | | <li>更换IP地址查询接口</li> |
| | | <li>修复页签变量undefined</li> |
| | | <li>添加校验部门包含未停用的子部门</li> |
| | | <li>修改定时任务详情下次执行时间日期显示错误</li> |
| | | <li>角色管理查询设置默认排序字段</li> |
| | | <li>swagger添加enable参数控制是否启用</li> |
| | | <li>只对json类型请求构建可重复读取inputStream的request</li> |
| | | <li>修改代码生成字典字段int类型没有自动选中问题</li> |
| | | <li>vuex用户名取值修正</li> |
| | | <li>表格树模板去掉多余的)</li> |
| | | <li>代码生成序号修正</li> |
| | | <li>全屏情况下不调整上外边距</li> |
| | | <li>代码生成Date字段添加默认格式</li> |
| | | <li>用户管理角色选择权限控制</li> |
| | | <li>修复路由懒加载报错问题</li> |
| | | <li>模板sql.vm添加菜单状态</li> |
| | | <li>设置用户名称不能修改</li> |
| | | <li>dialog添加append-to-body属性,防止ie遮罩</li> |
| | | <li>菜单区分状态和显示隐藏功能</li> |
| | | <li>升级fastjson到最新版1.2.68 修复安全加固</li> |
| | | <li>修复代码生成如果选择字典类型缺失逗号问题</li> |
| | | <li>登录请求params更换为data,防止暴露url</li> |
| | | <li>日志返回时间格式处理</li> |
| | | <li>添加handle控制允许拖动的元素</li> |
| | | <li>布局设置点击扩大范围</li> |
| | | <li>代码生成列属性排序查询</li> |
| | | <li>代码生成列支持拖动排序</li> |
| | | <li>修复时间格式不支持ios问题</li> |
| | | <li>表单构建添加父级class,防止冲突</li> |
| | | <li>定时任务并发属性修正</li> |
| | | <li>角色禁用&菜单隐藏不查询权限</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | |
| | | <el-collapse-item title="v2.2.0 - 2020-03-18"> |
| | | <ol> |
| | | <li>系统监控新增定时任务功能</li> |
| | | <li>添加一个打包Web工程bat</li> |
| | | <li>修复页签鼠标滚轮按下的时候,可以关闭不可关闭的tag</li> |
| | | <li>修复点击退出登录有时会无提示问题</li> |
| | | <li>修复防重复提交注解无效问题</li> |
| | | <li>修复通知公告批量删除异常问题</li> |
| | | <li>添加菜单时路由地址必填限制</li> |
| | | <li>代码生成字段描述可编辑</li> |
| | | <li>修复用户修改个人信息导致缓存不过期问题</li> |
| | | <li>个人信息创建时间获取正确属性值</li> |
| | | <li>操作日志详细显示正确类型</li> |
| | | <li>导入表单击行数据时选中对应的复选框</li> |
| | | <li>批量替换表前缀逻辑调整</li> |
| | | <li>固定重定向路径表达式</li> |
| | | <li>升级element-ui版本到2.13.0</li> |
| | | <li>操作日志排序调整</li> |
| | | <li>修复charts切换侧边栏或者缩放窗口显示bug</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | |
| | | <el-collapse-item title="v2.1.0 - 2020-02-24"> |
| | | <ol> |
| | | <li>新增表单构建</li> |
| | | <li>代码生成支持树表结构</li> |
| | | <li>新增用户导入</li> |
| | | <li>修复动态加载路由页面刷新问题</li> |
| | | <li>修复地址开关无效问题</li> |
| | | <li>汉化错误提示页面</li> |
| | | <li>代码生成已知问题修改</li> |
| | | <li>修复多数据源下配置关闭出现异常处理</li> |
| | | <li>添加HTML过滤器,用于去除XSS漏洞隐患</li> |
| | | <li>修复上传头像控制台出现异常</li> |
| | | <li>修改用户管理分页不正确的问题</li> |
| | | <li>修复验证码记录提示错误</li> |
| | | <li>修复request.js缺少Message引用</li> |
| | | <li>修复表格时间为空出现的异常</li> |
| | | <li>添加Jackson日期反序列化时区配置</li> |
| | | <li>调整根据用户权限加载菜单数据树形结构</li> |
| | | <li>调整成功登录不恢复按钮,防止多次点击</li> |
| | | <li>修改用户个人资料同步缓存信息</li> |
| | | <li>修复页面同时出现el-upload和Editor不显示处理</li> |
| | | <li>修复在角色管理页修改菜单权限偶尔未选中问题</li> |
| | | <li>配置文件新增redis密码属性</li> |
| | | <li>设置mybatis全局的配置文件</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | |
| | | <el-collapse-item title="v2.0.0 - 2019-12-02"> |
| | | <ol> |
| | | <li>新增代码生成</li> |
| | | <li>新增@RepeatSubmit注解,防止重复提交</li> |
| | | <li>新增菜单主目录添加/删除操作</li> |
| | | <li>日志记录过滤特殊对象,防止转换异常</li> |
| | | <li>修改代码生成路由脚本错误</li> |
| | | <li>用户上传头像实时同步缓存,无需重新登录</li> |
| | | <li>调整切换页签后不重新加载数据</li> |
| | | <li>添加jsencrypt实现参数的前端加密</li> |
| | | <li>系统退出删除用户缓存记录</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v1.1.0 - 2019-11-11"> |
| | | <ol> |
| | | <li>新增在线用户管理</li> |
| | | <li>新增按钮组功能实现(批量删除、导出、清空)</li> |
| | | <li>新增查询条件重置按钮</li> |
| | | <li>新增Swagger全局Token配置</li> |
| | | <li>新增后端参数校验</li> |
| | | <li>修复字典管理页面的日期查询异常</li> |
| | | <li>修改时间函数命名防止冲突</li> |
| | | <li>去除菜单上级校验,默认为顶级</li> |
| | | <li>修复用户密码无法修改问题</li> |
| | | <li>修复菜单类型为按钮时不显示权限标识</li> |
| | | <li>其他细节优化</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | <el-collapse-item title="v1.0.0 - 2019-10-08"> |
| | | <ol> |
| | | <li>若依前后端分离系统正式发布</li> |
| | | </ol> |
| | | </el-collapse-item> |
| | | </el-collapse> |
| | | </el-card> |
| | | </el-col> |
| | | <el-col :xs="24" :sm="24" :md="12" :lg="8"> |
| | | <el-card class="update-log"> |
| | | <div slot="header" class="clearfix"> |
| | | <span>捐赠支持</span> |
| | | </div> |
| | | <div class="body"> |
| | | <img |
| | | src="@/assets/images/pay.png" |
| | | alt="donate" |
| | | width="100%" |
| | | /> |
| | | <span style="display: inline-block; height: 30px; line-height: 30px" |
| | | >你可以请作者喝杯咖啡表示鼓励</span |
| | | > |
| | | </div> |
| | | </el-card> |
| | | </el-col> |
| | | </el-row> |
| | | <data-view></data-view> |
| | | <data-wrapper></data-wrapper> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import DataView from './home/data-view/index.vue'; |
| | | import DataWrapper from './home/data-wrapper/index.vue'; |
| | | |
| | | export default { |
| | | name: "Index", |
| | | components: { |
| | | DataView, |
| | | DataWrapper |
| | | }, |
| | | data() { |
| | | return { |
| | | // 版本号 |
| | | version: "3.8.7" |
| | | |
| | | }; |
| | | }, |
| | | methods: { |
| | | goTarget(href) { |
| | | window.open(href, "_blank"); |
| | | } |
| | | } |
| | | }; |
| | | </script> |
| | | |
| | |
| | | font-size: 17.5px; |
| | | border-left: 5px solid #eee; |
| | | } |
| | | |
| | | hr { |
| | | margin-top: 20px; |
| | | margin-bottom: 20px; |
| | | border: 0; |
| | | border-top: 1px solid #eee; |
| | | } |
| | | |
| | | .col-item { |
| | | margin-bottom: 20px; |
| | | } |
| | |
| | | margin: 0; |
| | | } |
| | | |
| | | font-family: "open sans", "Helvetica Neue", Helvetica, Arial, sans-serif; |
| | | font-family: "open sans", |
| | | "Helvetica Neue", |
| | | Helvetica, |
| | | Arial, |
| | | sans-serif; |
| | | font-size: 13px; |
| | | color: #676a6c; |
| | | overflow-x: hidden; |
| | |
| | | } |
| | | } |
| | | </style> |
| | | |
New file |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |
| | | <el-form-item label="规则名称" prop="ruleName"> |
| | | <el-input |
| | | v-model="queryParams.ruleName" |
| | | placeholder="请输入规则名称" |
| | | clearable |
| | | @clear="handleQuery" |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="创建时间" prop="createTime"> |
| | | <el-date-picker |
| | | v-model="daterangeCreateTime" |
| | | style="width: 240px" |
| | | value-format="yyyy-MM-dd HH:mm:ss" |
| | | type="daterange" |
| | | range-separator="-" |
| | | start-placeholder="开始日期" |
| | | end-placeholder="结束日期" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item> |
| | | <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> |
| | | <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> |
| | | </el-form-item> |
| | | </el-form> |
| | | |
| | | <el-row :gutter="10" class="mb8"> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="primary" |
| | | plain |
| | | icon="el-icon-plus" |
| | | size="mini" |
| | | @click="handleAdd" |
| | | v-hasPermi="['system:checkRule:add']" |
| | | >新增</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="success" |
| | | plain |
| | | icon="el-icon-edit" |
| | | size="mini" |
| | | :disabled="single" |
| | | @click="handleUpdate" |
| | | v-hasPermi="['system:checkRule:edit']" |
| | | >修改</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="danger" |
| | | plain |
| | | icon="el-icon-delete" |
| | | size="mini" |
| | | :disabled="multiple" |
| | | @click="handleDelete" |
| | | v-hasPermi="['system:checkRule:remove']" |
| | | >删除</el-button> |
| | | </el-col> |
| | | <!-- <el-col :span="1.5">--> |
| | | <!-- <el-button--> |
| | | <!-- type="warning"--> |
| | | <!-- plain--> |
| | | <!-- icon="el-icon-download"--> |
| | | <!-- size="mini"--> |
| | | <!-- @click="handleExport"--> |
| | | <!-- v-hasPermi="['system:checkRule:export']"--> |
| | | <!-- >导出</el-button>--> |
| | | <!-- </el-col>--> |
| | | <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |
| | | </el-row> |
| | | |
| | | <el-table v-loading="loading" :data="checkRuleList" @selection-change="handleSelectionChange"> |
| | | <el-table-column type="selection" width="55" align="center" /> |
| | | <el-table-column label="规则名称" align="center" prop="ruleName" /> |
| | | <el-table-column label="规则描述" align="center" prop="ruleDetail" /> |
| | | <el-table-column label="天网视频点位数" align="center" prop="videoPointNum" /> |
| | | <el-table-column label="车辆卡口点位数" align="center" prop="vehicleCheckpointNum" /> |
| | | <el-table-column label="人脸卡口点位数" align="center" prop="faceChceckpointNum" /> |
| | | <el-table-column label="创建时间" align="center" prop="createTime" /> |
| | | <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['system:checkRule:edit']" |
| | | >修改</el-button> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-delete" |
| | | @click="handleDelete(scope.row)" |
| | | v-hasPermi="['system:checkRule:remove']" |
| | | >删除</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | |
| | | <pagination |
| | | v-show="total>0" |
| | | :total="total" |
| | | :page.sync="queryParams.pageNum" |
| | | :limit.sync="queryParams.pageSize" |
| | | @pagination="getList" |
| | | /> |
| | | |
| | | <!-- 添加或修改考核规则对话框 --> |
| | | <el-dialog :title="title" :visible.sync="open" width="600px" append-to-body> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |
| | | <el-form-item label="规则名称" prop="ruleName"> |
| | | <el-input v-model="form.ruleName" placeholder="请输入规则名称" /> |
| | | </el-form-item> |
| | | <el-form-item label="规则描述" prop="ruleDetail"> |
| | | <el-input v-model="form.ruleDetail" type="textarea" show-word-limit maxlength="150" placeholder="请输入规则描述" /> |
| | | </el-form-item> |
| | | <el-form-item label="参数配置" prop="ruleDetail"> |
| | | <div class="row-warp"> |
| | | <div class="row"> |
| | | <div class="row-left">参数名</div> |
| | | <div class="row-right">条件</div> |
| | | </div> |
| | | <div class="row"> |
| | | <div class="row-left">天网视频点位数</div> |
| | | <div class="row-right"> |
| | | <div>不少于</div> |
| | | <div> |
| | | <el-input class="input-w" type="number" v-model="form.videoPointNum"/> |
| | | </div> |
| | | |
| | | </div> |
| | | </div> |
| | | <div class="row"> |
| | | <div class="row-left">车辆卡口点位数</div> |
| | | <div class="row-right"> |
| | | <div>不少于</div> |
| | | <div><el-input class="input-w" type="number" v-model="form.vehicleCheckpointNum"/></div> |
| | | </div> |
| | | </div> |
| | | <div class="row"> |
| | | <div class="row-left">人脸卡口点位数</div> |
| | | <div class="row-right"> |
| | | <div>不少于</div> |
| | | <div> |
| | | <el-input class="input-w" type="number" v-model="form.faceChceckpointNum"/></div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </el-form-item> |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | | <el-button type="primary" @click="submitForm">确 定</el-button> |
| | | <el-button @click="cancel">取 消</el-button> |
| | | </div> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import { listCheckRule, getCheckRule, delCheckRule, addCheckRule, updateCheckRule } from "@/api/platform/check-rule"; |
| | | |
| | | export default { |
| | | name: "CheckRule", |
| | | data() { |
| | | return { |
| | | // 遮罩层 |
| | | loading: true, |
| | | // 选中数组 |
| | | ids: [], |
| | | // 非单个禁用 |
| | | single: true, |
| | | // 非多个禁用 |
| | | multiple: true, |
| | | // 显示搜索条件 |
| | | showSearch: true, |
| | | // 总条数 |
| | | total: 0, |
| | | // 考核规则表格数据 |
| | | checkRuleList: [], |
| | | daterangeCreateTime: [], |
| | | // 弹出层标题 |
| | | title: "", |
| | | // 是否显示弹出层 |
| | | open: false, |
| | | // 查询参数 |
| | | queryParams: { |
| | | pageNum: 1, |
| | | pageSize: 10, |
| | | ruleName: null, |
| | | createTime: null, |
| | | }, |
| | | // 表单参数 |
| | | form: {}, |
| | | // 表单校验 |
| | | rules: { |
| | | ruleName: [ |
| | | { required: true, message: "规则名称不能为空", trigger: "blur" } |
| | | ], |
| | | } |
| | | }; |
| | | }, |
| | | created() { |
| | | this.getList(); |
| | | }, |
| | | methods: { |
| | | /** 查询考核规则列表 */ |
| | | getList() { |
| | | this.loading = true; |
| | | if (null != this.daterangeCreateTime && '' != this.daterangeCreateTime) { |
| | | this.queryParams["start"] = this.daterangeCreateTime[0]; |
| | | this.queryParams["end"] = this.daterangeCreateTime[1]; |
| | | } |
| | | listCheckRule(this.queryParams).then(response => { |
| | | this.checkRuleList = response.data; |
| | | this.total = response.total; |
| | | this.loading = false; |
| | | }); |
| | | }, |
| | | // 取消按钮 |
| | | cancel() { |
| | | this.open = false; |
| | | this.reset(); |
| | | }, |
| | | // 表单重置 |
| | | reset() { |
| | | this.form = { |
| | | id: null, |
| | | ruleName: null, |
| | | ruleDetail: null, |
| | | videoPointNum: null, |
| | | vehicleCheckpointNum: null, |
| | | faceChceckpointNum: null, |
| | | createTime: null, |
| | | updateTime: null, |
| | | deleted: null |
| | | }; |
| | | this.resetForm("form"); |
| | | }, |
| | | /** 搜索按钮操作 */ |
| | | handleQuery() { |
| | | this.queryParams.pageNum = 1; |
| | | this.getList(); |
| | | }, |
| | | /** 重置按钮操作 */ |
| | | resetQuery() { |
| | | this.resetForm("queryForm"); |
| | | this.handleQuery(); |
| | | }, |
| | | // 多选框选中数据 |
| | | handleSelectionChange(selection) { |
| | | this.ids = selection.map(item => item.id) |
| | | this.single = selection.length!==1 |
| | | this.multiple = !selection.length |
| | | }, |
| | | /** 新增按钮操作 */ |
| | | handleAdd() { |
| | | this.reset(); |
| | | this.open = true; |
| | | this.title = "添加考核规则"; |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | handleUpdate(row) { |
| | | this.reset(); |
| | | const id = row.id || this.ids |
| | | getCheckRule(id).then(response => { |
| | | this.form = response.data; |
| | | this.open = true; |
| | | this.title = "修改考核规则"; |
| | | }); |
| | | }, |
| | | /** 提交按钮 */ |
| | | submitForm() { |
| | | this.$refs["form"].validate(valid => { |
| | | if (valid) { |
| | | if (this.form.id != null) { |
| | | updateCheckRule(this.form).then(response => { |
| | | this.$modal.msgSuccess("修改成功"); |
| | | this.open = false; |
| | | this.getList(); |
| | | }); |
| | | } else { |
| | | addCheckRule(this.form).then(response => { |
| | | this.$modal.msgSuccess("新增成功"); |
| | | this.open = false; |
| | | this.getList(); |
| | | }); |
| | | } |
| | | } |
| | | }); |
| | | }, |
| | | /** 删除按钮操作 */ |
| | | handleDelete(row) { |
| | | const ids = row.id || this.ids; |
| | | this.$modal.confirm('是否确认删除考核规则编号为"' + ids + '"的数据项?').then(function() { |
| | | return delCheckRule(ids); |
| | | }).then(() => { |
| | | this.getList(); |
| | | this.$modal.msgSuccess("删除成功"); |
| | | }).catch(() => {}); |
| | | }, |
| | | /** 导出按钮操作 */ |
| | | handleExport() { |
| | | this.download('system/checkRule/export', { |
| | | ...this.queryParams |
| | | }, `checkRule_${new Date().getTime()}.xlsx`) |
| | | } |
| | | } |
| | | }; |
| | | </script> |
| | | |
| | | <style scoped> |
| | | .input-w { |
| | | margin-left: 5px; |
| | | width: 100px; |
| | | } |
| | | .row-warp { |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: center; |
| | | text-align: center; |
| | | border: solid 1px gray; |
| | | /*padding: 3px;*/ |
| | | } |
| | | .row { |
| | | display: flex; |
| | | flex-direction: row; |
| | | justify-content: center; |
| | | align-items: center; |
| | | border-bottom: solid 1px gray; |
| | | padding: 3px; |
| | | } |
| | | .row:last-of-type { |
| | | border-bottom: none; |
| | | } |
| | | .row-left { |
| | | flex: 2; |
| | | border-right: solid 1px gray; |
| | | } |
| | | .row-right { |
| | | flex: 4; |
| | | display: flex; |
| | | flex-direction: row; |
| | | justify-content: center; |
| | | } |
| | | </style> |
New file |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |
| | | <el-form-item label="状态" prop="status"> |
| | | <el-input |
| | | v-model="queryParams.status" |
| | | placeholder="请输入状态" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="创建时间"> |
| | | <el-date-picker |
| | | v-model="daterangeCreateTime" |
| | | style="width: 240px" |
| | | value-format="yyyy-MM-dd" |
| | | type="daterange" |
| | | range-separator="-" |
| | | start-placeholder="开始日期" |
| | | end-placeholder="结束日期" |
| | | ></el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item> |
| | | <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> |
| | | <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> |
| | | </el-form-item> |
| | | </el-form> |
| | | |
| | | <el-row :gutter="10" class="mb8"> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="primary" |
| | | plain |
| | | icon="el-icon-plus" |
| | | size="mini" |
| | | @click="handleAdd" |
| | | v-hasPermi="['system:checkTemplate:add']" |
| | | >新增</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="success" |
| | | plain |
| | | icon="el-icon-edit" |
| | | size="mini" |
| | | :disabled="single" |
| | | @click="handleUpdate" |
| | | v-hasPermi="['system:checkTemplate:edit']" |
| | | >修改</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="danger" |
| | | plain |
| | | icon="el-icon-delete" |
| | | size="mini" |
| | | :disabled="multiple" |
| | | @click="handleDelete" |
| | | v-hasPermi="['system:checkTemplate:remove']" |
| | | >删除</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="warning" |
| | | plain |
| | | icon="el-icon-download" |
| | | size="mini" |
| | | @click="handleExport" |
| | | v-hasPermi="['system:checkTemplate:export']" |
| | | >导出</el-button> |
| | | </el-col> |
| | | <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |
| | | </el-row> |
| | | |
| | | <el-table v-loading="loading" :data="checkTemplateList" @selection-change="handleSelectionChange"> |
| | | <el-table-column type="selection" width="55" align="center" /> |
| | | <el-table-column label="模板名称" align="center" prop="templateName" /> |
| | | <el-table-column label="调整系数" align="center" prop="adjustCoefficient" /> |
| | | <el-table-column label="调整系数计算方式" align="center" prop="adjustWay" /> |
| | | <el-table-column label="状态" align="center" prop="status" /> |
| | | <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['system:checkTemplate:edit']" |
| | | >修改</el-button> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-delete" |
| | | @click="handleDelete(scope.row)" |
| | | v-hasPermi="['system:checkTemplate:remove']" |
| | | >删除</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | |
| | | <pagination |
| | | v-show="total>0" |
| | | :total="total" |
| | | :page.sync="queryParams.pageNum" |
| | | :limit.sync="queryParams.pageSize" |
| | | @pagination="getList" |
| | | /> |
| | | |
| | | <!-- 添加或修改考核模板对话框 --> |
| | | <el-dialog :title="title" :visible.sync="open" width="700px" append-to-body> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |
| | | <el-form-item label="模板名称" prop="templateName"> |
| | | <el-input v-model="form.templateName" placeholder="请输入模板名称" /> |
| | | </el-form-item> |
| | | <el-form-item label="考核规则"> |
| | | <div class="row-warp"> |
| | | <div class="row" v-for="(form) in tempRuleFormList"> |
| | | <div class="row-left"> |
| | | <div>规则</div> |
| | | <div class="margin-5"> |
| | | <el-select v-model="form.ruleId" placeholder="请选择"> |
| | | <el-option |
| | | v-for="item in ruleList" |
| | | :key="item.id" |
| | | :label="item.value" |
| | | :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | </div> |
| | | <div class="row-right"> |
| | | <div>权重</div> |
| | | <div class="margin-5"> |
| | | <el-input type="number" v-model="form.weight"/> |
| | | </div> |
| | | </div> |
| | | <div class="item-op"> |
| | | <el-button @click="removeRule(form)" type="danger" icon="el-icon-delete" circle></el-button> |
| | | </div> |
| | | </div> |
| | | <div style="margin-top: 25px"> |
| | | <el-button type="success" @click="nextAdd" size="mini" plain>添加</el-button> |
| | | </div> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="调整系数" prop="adjustCoefficient"> |
| | | <el-input v-model="form.adjustCoefficient" placeholder="请输入系数值" /> |
| | | </el-form-item> |
| | | <el-form-item label="调整方式" prop="adjustWay"> |
| | | <el-select v-model="form.adjustWay" placeholder="请选择调整系数计算方式"> |
| | | <el-option |
| | | label="乘" |
| | | value="*"> |
| | | </el-option> |
| | | <el-option |
| | | label="除" |
| | | value="/"> |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="状态" prop="status"> |
| | | <el-radio v-model="form.status" label="use">启用</el-radio> |
| | | <el-radio v-model="form.status" label="stop">停用</el-radio> |
| | | </el-form-item> |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | | <el-button type="primary" @click="submitForm">确 定</el-button> |
| | | <el-button @click="cancel">取 消</el-button> |
| | | </div> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import { listCheckTemplate, getCheckTemplate, delCheckTemplate, addCheckTemplate, updateCheckTemplate } from "@/api/platform/check-template"; |
| | | import { ruleSelect } from '../../../api/platform/check-rule' |
| | | |
| | | export default { |
| | | name: "CheckTemplate", |
| | | data() { |
| | | return { |
| | | ruleList: [], |
| | | // 临时规则表单 |
| | | tempRuleForm: {}, |
| | | // 临时规则表单列表 |
| | | tempRuleFormList: [{"ruleId": null, "adjustCoefficient": null}], |
| | | // 最终 |
| | | ruleFormList: [], |
| | | // 遮罩层 |
| | | loading: true, |
| | | // 选中数组 |
| | | ids: [], |
| | | // 非单个禁用 |
| | | single: true, |
| | | // 非多个禁用 |
| | | multiple: true, |
| | | // 显示搜索条件 |
| | | showSearch: true, |
| | | // 总条数 |
| | | total: 0, |
| | | // 考核模板表格数据 |
| | | checkTemplateList: [], |
| | | // 弹出层标题 |
| | | title: "", |
| | | // 是否显示弹出层 |
| | | open: false, |
| | | // 状态时间范围 |
| | | daterangeCreateTime: [], |
| | | // 查询参数 |
| | | queryParams: { |
| | | pageNum: 1, |
| | | pageSize: 10, |
| | | status: null, |
| | | createTime: null, |
| | | }, |
| | | // 表单参数 |
| | | form: {}, |
| | | // 表单校验 |
| | | rules: { |
| | | adjustCoefficient: [ |
| | | { required: true, message: "调整系数不能为空", trigger: "blur" } |
| | | ], |
| | | adjustWay: [ |
| | | { required: true, message: "调整方式:乘除不能为空", trigger: "blur" } |
| | | ], |
| | | } |
| | | }; |
| | | }, |
| | | created() { |
| | | this.getList(); |
| | | this.selectCheckRule(); |
| | | }, |
| | | methods: { |
| | | removeRule(form) { |
| | | console.log(form) |
| | | this.ruleFormList = this.ruleFormList.filter(item => item !== form); |
| | | this.tempRuleFormList = this.tempRuleFormList.filter(item => item !== form) |
| | | }, |
| | | nextAdd() { |
| | | if (this.tempRuleFormList.length === 0) { |
| | | this.tempRuleFormList.push({"ruleId": null, "adjustCoefficient": null}) |
| | | } else { |
| | | this.ruleFormList.push(this.tempRuleForm); |
| | | this.tempRuleFormList.push(this.tempRuleForm); |
| | | this.tempRuleForm = {}; |
| | | } |
| | | |
| | | }, |
| | | // 考核规则下拉数据 |
| | | selectCheckRule() { |
| | | ruleSelect().then(res => { |
| | | this.ruleList = res.data; |
| | | }) |
| | | }, |
| | | /** 查询考核模板列表 */ |
| | | getList() { |
| | | this.loading = true; |
| | | if (null != this.daterangeCreateTime && '' != this.daterangeCreateTime) { |
| | | this.queryParams["start"] = this.daterangeCreateTime[0]; |
| | | this.queryParams["end"] = this.daterangeCreateTime[1]; |
| | | } |
| | | listCheckTemplate(this.queryParams).then(response => { |
| | | this.checkTemplateList = response.data; |
| | | this.total = response.total; |
| | | this.loading = false; |
| | | }); |
| | | }, |
| | | // 取消按钮 |
| | | cancel() { |
| | | this.open = false; |
| | | this.reset(); |
| | | }, |
| | | // 表单重置 |
| | | reset() { |
| | | this.form = { |
| | | id: null, |
| | | adjustCoefficient: null, |
| | | adjustWay: null, |
| | | status: null, |
| | | createTime: null, |
| | | updateTime: null, |
| | | deleted: null |
| | | }; |
| | | this.resetForm("form"); |
| | | }, |
| | | /** 搜索按钮操作 */ |
| | | handleQuery() { |
| | | this.queryParams.pageNum = 1; |
| | | this.getList(); |
| | | }, |
| | | /** 重置按钮操作 */ |
| | | resetQuery() { |
| | | this.daterangeCreateTime = []; |
| | | this.resetForm("queryForm"); |
| | | this.handleQuery(); |
| | | }, |
| | | // 多选框选中数据 |
| | | handleSelectionChange(selection) { |
| | | this.ids = selection.map(item => item.id) |
| | | this.single = selection.length!==1 |
| | | this.multiple = !selection.length |
| | | }, |
| | | /** 新增按钮操作 */ |
| | | handleAdd() { |
| | | this.reset(); |
| | | this.open = true; |
| | | this.title = "添加考核模板"; |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | handleUpdate(row) { |
| | | this.reset(); |
| | | const id = row.id || this.ids |
| | | getCheckTemplate(id).then(response => { |
| | | this.form = response.data; |
| | | this.tempRuleFormList = this.form.ruleFormList; |
| | | this.open = true; |
| | | this.title = "修改考核模板"; |
| | | }); |
| | | }, |
| | | /** 提交按钮 */ |
| | | submitForm() { |
| | | this.$refs["form"].validate(valid => { |
| | | if (valid) { |
| | | this.form.ruleFormList = this.ruleFormList; |
| | | if (this.form.id != null) { |
| | | updateCheckTemplate(this.form).then(response => { |
| | | this.$modal.msgSuccess("修改成功"); |
| | | this.open = false; |
| | | this.getList(); |
| | | }); |
| | | } else { |
| | | addCheckTemplate(this.form).then(response => { |
| | | this.$modal.msgSuccess("新增成功"); |
| | | this.open = false; |
| | | this.getList(); |
| | | }); |
| | | } |
| | | } |
| | | }); |
| | | }, |
| | | /** 删除按钮操作 */ |
| | | handleDelete(row) { |
| | | const ids = row.id || this.ids; |
| | | this.$modal.confirm('是否确认删除考核模板编号为"' + ids + '"的数据项?').then(function() { |
| | | return delCheckTemplate(ids); |
| | | }).then(() => { |
| | | this.getList(); |
| | | this.$modal.msgSuccess("删除成功"); |
| | | }).catch(() => {}); |
| | | }, |
| | | /** 导出按钮操作 */ |
| | | handleExport() { |
| | | this.download('system/checkTemplate/export', { |
| | | ...this.queryParams |
| | | }, `checkTemplate_${new Date().getTime()}.xlsx`) |
| | | } |
| | | } |
| | | }; |
| | | </script> |
| | | |
| | | <style scoped> |
| | | .margin-5 { |
| | | margin-left: 5px; |
| | | } |
| | | .row-warp { |
| | | display: flex; |
| | | flex-direction: column; |
| | | } |
| | | .row { |
| | | display: flex; |
| | | flex-direction: row; |
| | | align-items: center; |
| | | justify-content: center; |
| | | margin: 5px 0; |
| | | } |
| | | .row-left { |
| | | flex: 1; |
| | | display: flex; |
| | | flex-direction: row; |
| | | } |
| | | .row-right { |
| | | flex: 1; |
| | | display: flex; |
| | | flex-direction: row; |
| | | } |
| | | </style> |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |
| | | <el-form-item label="违规" prop="defaultId"> |
| | | <el-input |
| | | v-model="queryParams.defaultId" |
| | | placeholder="请输入违规" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="100px"> |
| | | <el-form-item label="违约运维单位" prop="belongUnit"> |
| | | <el-select v-model="queryParams.unitId" @change="handleQuery" clearable placeholder="违约单位"> |
| | | <el-option |
| | | v-for="item in unitList" |
| | | :key="item.id" |
| | | :label="item.value" |
| | | :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="审核时间"> |
| | | <el-date-picker |
| | | v-model="daterangeAuditingTime" |
| | | style="width: 240px" |
| | | value-format="yyyy-MM-dd" |
| | | value-format="yyyy-MM-dd HH:mm:ss" |
| | | type="daterange" |
| | | range-separator="-" |
| | | start-placeholder="开始日期" |
| | | end-placeholder="结束日期" |
| | | ></el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item label="审核人" prop="auditingUser"> |
| | | <el-input |
| | | v-model="queryParams.auditingUser" |
| | | placeholder="请输入审核人" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="创建时间"> |
| | | <el-date-picker |
| | | v-model="daterangeCreateTime" |
| | | style="width: 240px" |
| | | value-format="yyyy-MM-dd" |
| | | value-format="yyyy-MM-dd HH:mm:ss" |
| | | type="daterange" |
| | | range-separator="-" |
| | | start-placeholder="开始日期" |
| | |
| | | |
| | | <el-table v-loading="loading" :data="auditingList" @selection-change="handleSelectionChange"> |
| | | <el-table-column type="selection" width="55" align="center" /> |
| | | <el-table-column label="违规" align="center" prop="defaultId" /> |
| | | <el-table-column label="违约单位" align="center" prop="unitName" width="180"/> |
| | | <el-table-column label="违约规则" align="center" prop="defaultRuleName"width="120" /> |
| | | <el-table-column label="审核人" align="center" prop="auditingUserName" /> |
| | | <el-table-column label="审核状态" align="center" prop="auditingStatus" /> |
| | | <el-table-column label="审核说明" align="center" prop="remark" /> |
| | | <el-table-column label="审核时间" align="center" prop="auditingTime" width="180"> |
| | | <template slot-scope="scope"> |
| | | <span>{{ parseTime(scope.row.auditingTime, '{y}-{m}-{d}') }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="审核人" align="center" prop="auditingUser" /> |
| | | <el-table-column label="创建时间" align="center" prop="createTime" width="180"> |
| | | <template slot-scope="scope"> |
| | | <span>{{ parseTime(scope.row.createTime, '{y}-{m}-{d}') }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |
| | | <el-table-column label="审核说明" align="center" prop="remark" width="180"/> |
| | | <el-table-column label="审核时间" align="center" prop="auditingTime" width="180"/> |
| | | <el-table-column label="创建时间" align="center" prop="createTime" width="180"/> |
| | | <el-table-column label="操作" align="center" fixed="right" class-name="small-padding fixed-width"> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['system:auditing:edit']" |
| | | >修改</el-button> |
| | | icon="el-icon-s-check" |
| | | @click="handleAuditing(scope.row)" |
| | | v-hasPermi="['system:auditing:auditing']" |
| | | >审核</el-button> |
| | | <!-- <el-button--> |
| | | <!-- size="mini"--> |
| | | <!-- type="text"--> |
| | | <!-- icon="el-icon-edit"--> |
| | | <!-- @click="handleUpdate(scope.row)"--> |
| | | <!-- v-hasPermi="['system:auditing:edit']"--> |
| | | <!-- >修改</el-button>--> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | |
| | | @pagination="getList" |
| | | /> |
| | | |
| | | <!-- 添加或修改违规审核对话框 --> |
| | | <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |
| | | <!-- 审核 --> |
| | | <el-dialog title="违约审核" :visible.sync="auditingOpen" width="500px" append-to-body> |
| | | <el-form ref="auditingForm" :model="auditingForm" :rules="auditingRules" label-width="80px"> |
| | | <el-form-item label="违约单位"> |
| | | <el-input v-model="auditingForm.unitName" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="违约规则"> |
| | | <el-input v-model="auditingForm.defaultRuleName" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="审核结果" prop="auditingStatus"> |
| | | <el-radio v-model="auditingForm.auditingResult" label="pass">通过</el-radio> |
| | | <el-radio v-model="auditingForm.auditingResult" label="return">驳回</el-radio> |
| | | </el-form-item> |
| | | <el-form-item label="审核说明" prop="remark"> |
| | | <el-input v-model="auditingForm.remark" type="textarea" show-word-limit maxlength="100"/> |
| | | </el-form-item> |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | | <el-button type="primary" @click="submitForm">确 定</el-button> |
| | | <el-button @click="cancel">取 消</el-button> |
| | | <el-button type="primary" @click="submitAuditing">确 定</el-button> |
| | | <el-button @click="closeAuditing">取 消</el-button> |
| | | </div> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import { listAuditing, getAuditing, delAuditing, addAuditing, updateAuditing } from "@/api/platform/default-auditing"; |
| | | import { listAuditing, getAuditing, delAuditing, addAuditing, updateAuditing,auditing } from "@/api/platform/default-auditing"; |
| | | import { unitSelect } from "@/api/platform/unit"; |
| | | |
| | | export default { |
| | | name: "Auditing", |
| | | data() { |
| | | return { |
| | | auditingOpen: false, |
| | | auditingForm: {}, |
| | | unitList: [], |
| | | // 遮罩层 |
| | | loading: true, |
| | | // 选中数组 |
| | |
| | | // 表单参数 |
| | | form: {}, |
| | | // 表单校验 |
| | | rules: { |
| | | defaultId: [ |
| | | { required: true, message: "违规不能为空", trigger: "blur" } |
| | | auditingRules: { |
| | | auditingStatus: [ |
| | | { required: true, message: "请先完成审核结果", trigger: "blur" } |
| | | ], |
| | | } |
| | | }; |
| | | }, |
| | | created() { |
| | | this.getList(); |
| | | this.getUnitSelect(); |
| | | }, |
| | | methods: { |
| | | // 提交审核 |
| | | submitAuditing() { |
| | | this.$refs["auditingForm"].validate(valid => { |
| | | if (valid) { |
| | | auditing(this.auditingForm).then(res => { |
| | | if (res.code === 200) { |
| | | this.auditingOpen = false; |
| | | this.$modal.msgSuccess("审核成功"); |
| | | this.getList(); |
| | | } else { |
| | | this.$modal.msgSuccess(res.msg) |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | }, |
| | | // 打开审核 |
| | | handleAuditing(row) { |
| | | this.auditingOpen = true; |
| | | this.auditingForm = row; |
| | | this.auditingForm.auditingStatus = this.auditingForm.auditingStatus ? this.auditingForm.auditingStatus : null |
| | | }, |
| | | // 关闭审核 |
| | | closeAuditing() { |
| | | this.auditingForm = {}; |
| | | this.auditingOpen = false; |
| | | }, |
| | | getUnitSelect() { |
| | | // 运维单位下拉列表 |
| | | unitSelect().then((res) => { |
| | | this.unitList = res.data; |
| | | }) |
| | | }, |
| | | /** 查询违规审核列表 */ |
| | | getList() { |
| | | this.loading = true; |
| | | this.queryParams.params = {}; |
| | | if (null != this.daterangeAuditingTime && '' != this.daterangeAuditingTime) { |
| | | this.queryParams.params["beginAuditingTime"] = this.daterangeAuditingTime[0]; |
| | | this.queryParams.params["endAuditingTime"] = this.daterangeAuditingTime[1]; |
| | | this.queryParams["auditingStartTime"] = this.daterangeAuditingTime[0]; |
| | | this.queryParams["auditingEndTime"] = this.daterangeAuditingTime[1]; |
| | | } |
| | | if (null != this.daterangeCreateTime && '' != this.daterangeCreateTime) { |
| | | this.queryParams.params["beginCreateTime"] = this.daterangeCreateTime[0]; |
| | | this.queryParams.params["endCreateTime"] = this.daterangeCreateTime[1]; |
| | | this.queryParams["createStartTime"] = this.daterangeCreateTime[0]; |
| | | this.queryParams["createEndTime"] = this.daterangeCreateTime[1]; |
| | | } |
| | | listAuditing(this.queryParams).then(response => { |
| | | this.auditingList = response.rows; |
| | | this.auditingList = response.data; |
| | | this.total = response.total; |
| | | this.loading = false; |
| | | }); |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="100px"> |
| | | <el-form-item label="点位名称" prop="pointName"> |
| | | <el-input |
| | | v-model="queryParams.pointName" |