release-v1.0 #1

Merged
panchichun merged 57 commits from release-v1.0 into main 2024-09-13 17:04:18 +08:00
6 changed files with 2017 additions and 1385 deletions
Showing only changes of commit 3a21059ab4 - Show all commits

View File

@ -75,11 +75,11 @@ body #app .hideSidebar .sidebar-container {
width: 65px !important; width: 65px !important;
} }
body #app .openSidebar .sidebar-container { body #app .openSidebar .sidebar-container {
width:205px !important; width:180px !important;
} }
body #app .sidebar-container .nest-menu .el-sub-menu>.el-sub-menu__title, body #app .sidebar-container .nest-menu .el-sub-menu>.el-sub-menu__title,
body #app .sidebar-container .el-sub-menu .el-menu-item { body #app .sidebar-container .el-sub-menu .el-menu-item {
min-width: 205px!important; min-width: 180px!important;
} }
body #app .sidebar-container .scrollbar-wrapper { body #app .sidebar-container .scrollbar-wrapper {
padding-bottom: 95px; padding-bottom: 95px;
@ -336,7 +336,7 @@ body .hideSidebar .el-submenu__title i.icon-zhiliang-xianxing{
} }
body #app .sidebar-container .el-submenu .el-menu-item, body #app .sidebar-container .el-submenu .el-menu-item,
body #app .sidebar-container .nest-menu .el-submenu>.el-submenu__title { body #app .sidebar-container .nest-menu .el-submenu>.el-submenu__title {
min-width: 205px!important; min-width: 180px!important;
} }
/*main-container 右侧内容*/ /*main-container 右侧内容*/
@ -344,7 +344,7 @@ body #app .hideSidebar .main-container {
margin-left: 65px; margin-left: 65px;
} }
body #app .main-container { body #app .main-container {
margin-left: 205px; margin-left: 180px;
background:#f9fafe; background:#f9fafe;
background-size:100%; background-size:100%;
} }
@ -372,10 +372,10 @@ body #app .main-container .el-breadcrumb{
margin: 0 40px 0 40px; margin: 0 40px 0 40px;
display: block; display: block;
font-size: 14px; font-size: 14px;
} }
body #app .main-container .el-breadcrumb .float-right{ body #app .main-container .el-breadcrumb .float-right{
color: #666; color: #666;
} }
body #app .main-container .app-breadcrumb.el-breadcrumb .no-redirect{ body #app .main-container .app-breadcrumb.el-breadcrumb .no-redirect{
color: #a4a4a4 !important; color: #a4a4a4 !important;
} }
@ -386,7 +386,7 @@ body #app .main-container .app-breadcrumb.el-breadcrumb .el-breadcrumb__inner:ho
body #app .main-container .app-breadcrumb.el-breadcrumb .el-breadcrumb__inner:hover a, body #app .main-container .app-breadcrumb.el-breadcrumb .el-breadcrumb__inner:hover a,
body #app .main-container .app-breadcrumb.el-breadcrumb .el-breadcrumb__inner a:hover{ body #app .main-container .app-breadcrumb.el-breadcrumb .el-breadcrumb__inner a:hover{
color:#004098 !important; color:#004098 !important;
} }
/*hamburger-container 展开折叠菜单按钮*/ /*hamburger-container 展开折叠菜单按钮*/
body #app .app-wrapper .main-container .navbar .hamburger-container{ body #app .app-wrapper .main-container .navbar .hamburger-container{
@ -403,16 +403,16 @@ body #app .app-wrapper .main-container .navbar .hamburger-container{
font-size:22px !important; font-size:22px !important;
background:#fff; background:#fff;
transition: width .28s; transition: width .28s;
} }
body #app .app-wrapper.hideSidebar .navbar .hamburger-container{ body #app .app-wrapper.hideSidebar .navbar .hamburger-container{
width: 65px; width: 65px;
height: 50px; height: 50px;
text-align: center; text-align: center;
} }
body #app .main-container .navbar .hamburger-container *{ body #app .main-container .navbar .hamburger-container *{
color:#5F5E5E !important; color:#5F5E5E !important;
font-size:22px !important; font-size:22px !important;
} }
/*navbar 顶部导航*/ /*navbar 顶部导航*/
body #app .main-container .navbar{ body #app .main-container .navbar{
@ -558,14 +558,14 @@ body #app .main-container .tags-view-container{
box-shadow: none; box-shadow: none;
border: 0; border: 0;
height: 44px; height: 44px;
} }
body #app .main-container .tags-view-container .scroll-container{ body #app .main-container .tags-view-container .scroll-container{
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap{
height: 61px; height: 61px;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view{
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item{
margin-top: 10px; margin-top: 10px;
margin-left:0; margin-left:0;
@ -577,10 +577,10 @@ body #app .main-container .tags-view-container .scroll-container .el-scrollbar_
border-radius: 4px 4px 0 0; border-radius: 4px 4px 0 0;
padding:0 15px; padding:0 15px;
position:relative; position:relative;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view>.tags-view-item:first-child{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view>.tags-view-item:first-child{
margin-left:20px !important; margin-left:20px !important;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item:before{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item:before{
content:""; content:"";
display:block; display:block;
@ -590,27 +590,27 @@ body #app .main-container .tags-view-container .scroll-container .el-scrollbar_
width:1px; width:1px;
height:10px; height:10px;
background:#B4B0B0; background:#B4B0B0;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view>.tags-view-item:first-child:before{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view>.tags-view-item:first-child:before{
content:none; content:none;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active:before{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active:before{
content:none; content:none;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active+.tags-view-item:before{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active+.tags-view-item:before{
content:none; content:none;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active, body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active,
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active:hover{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active:hover{
background:#0E48AD !important; background:#0E48AD !important;
color: #fff; color: #fff;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item:hover{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item:hover{
color:#013A9D; color:#013A9D;
} }
body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active:before{ body #app .main-container .tags-view-container .scroll-container .el-scrollbar__wrap .el-scrollbar__view .tags-view-item.active:before{
content:none; content:none;
} }
body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item .el-icon-close{ body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item .el-icon-close{
font-size: 14px; font-size: 14px;
vertical-align: 1px; vertical-align: 1px;
@ -620,22 +620,22 @@ body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-it
height: 15px; height: 15px;
color: #707070; color: #707070;
margin: 0 0 0 6px; margin: 0 0 0 6px;
} }
body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item .el-icon-close:hover{ body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item .el-icon-close:hover{
background:#aaa; background:#aaa;
color:#fff; color:#fff;
} }
body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item .el-icon-close:before{ body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item .el-icon-close:before{
vertical-align: -1px; vertical-align: -1px;
transform: scale(1); transform: scale(1);
} }
body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item.active .el-icon-close{ body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item.active .el-icon-close{
color:#fff; color:#fff;
} }
body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item.active .el-icon-close:hover{ body #app .main-container .tags-view-container .tags-view-wrapper .tags-view-item.active .el-icon-close:hover{
background:#fff; background:#fff;
color:#013A9D; color:#013A9D;
} }
/*el-row*/ /*el-row*/
body .el-row+.el-row{ body .el-row+.el-row{
@ -664,15 +664,15 @@ body .el-card{
body .el-card .el-card__body{ body .el-card .el-card__body{
position:relative; position:relative;
padding: 16px !important; padding: 16px !important;
} }
body .el-card .no-cont{ body .el-card .no-cont{
padding: 75px 0; padding: 75px 0;
height: 275px; height: 275px;
box-sizing: border-box; box-sizing: border-box;
} }
body .el-card .no-cont .img img{ body .el-card .no-cont .img img{
width:100px; width:100px;
} }
body .el-card .el-card__header{ body .el-card .el-card__header{
box-sizing: border-box; box-sizing: border-box;
padding: 16px; padding: 16px;
@ -681,7 +681,7 @@ body .el-card .el-card__header{
font-weight: bold; font-weight: bold;
border-bottom: 1px solid #e6e6e6; border-bottom: 1px solid #e6e6e6;
background:transparent; background:transparent;
} }
body .el-card .el-card__header .title{ body .el-card .el-card__header .title{
display: inline-block; display: inline-block;
position:relative; position:relative;
@ -695,7 +695,7 @@ body .el-card .el-card__header .title:before{
width: 3px; width: 3px;
height: 14px; height: 14px;
background: #004098; background: #004098;
} }
body .el-card .el-card__header .clearfix{ body .el-card .el-card__header .clearfix{
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
@ -737,7 +737,7 @@ body .el-card .el-card__header .clearfix .header-button .el-button.el-button--pr
background:#3071b9; background:#3071b9;
border-color:#3071b9; border-color:#3071b9;
color: #fff; color: #fff;
} }
body .el-card .el-card__header .clearfix .header-button .el-button.el-button--info{ body .el-card .el-card__header .clearfix .header-button .el-button.el-button--info{
background: #F2F3F5; background: #F2F3F5;
border: 1px dashed #E5E6EB; border: 1px dashed #E5E6EB;
@ -751,12 +751,12 @@ body .el-card .el-card__header .clearfix .header-button .el-button.el-button--in
body .el-card .el-card__header .small-title{ body .el-card .el-card__header .small-title{
color: #141414; color: #141414;
font-size: 16px; font-size: 16px;
} }
body .el-card .el-card__header .el-button{ body .el-card .el-card__header .el-button{
line-height: 22px; line-height: 22px;
height: 24px; height: 24px;
padding: 0 10px !important; padding: 0 10px !important;
} }
body .el-drawer .el-drawer__body .el-card.box-card{ body .el-drawer .el-drawer__body .el-card.box-card{
border-radius: 0 !important; border-radius: 0 !important;
} }
@ -777,10 +777,10 @@ body .el-drawer__wrapper.no-padding .el-drawer .el-drawer__body{
/*el-form 表单组件*/ /*el-form 表单组件*/
body .el-form-item{ body .el-form-item{
margin-bottom: 25px; margin-bottom: 25px;
} }
body .el-form .el-row{ body .el-form .el-row{
margin:0; margin:0;
} }
body .el-form-item .el-form-item__label { body .el-form-item .el-form-item__label {
color: #5e5e5e; color: #5e5e5e;
font-weight:normal; font-weight:normal;
@ -886,7 +886,7 @@ body .el-form-border .el-form-item .el-checkbox-group .el-checkbox{
body .el-input-group{ body .el-input-group{
background: transparent; background: transparent;
border-radius: 2px; border-radius: 2px;
} }
body .el-input-group .el-input__inner{ body .el-input-group .el-input__inner{
background: #fff; background: #fff;
border-color: #DCDFE6; border-color: #DCDFE6;
@ -894,20 +894,20 @@ body .el-input-group .el-input__inner{
height: 30px; height: 30px;
line-height: 30px; line-height: 30px;
border-width:0px; border-width:0px;
} }
body .el-input-group .el-input__inner:hover{ body .el-input-group .el-input__inner:hover{
border-color: #DCDFE6; border-color: #DCDFE6;
} }
body .el-input.el-input-group .el-input__inner:focus, body .el-input.el-input-group .el-input__inner:focus,
body .el-input.el-input-group .el-input__inner:hover { body .el-input.el-input-group .el-input__inner:hover {
border-color:#DCDFE6; border-color:#DCDFE6;
} }
.el-input-group .el-input__prefix{ .el-input-group .el-input__prefix{
} }
.el-input-group .el-input__prefix .el-icon-search{ .el-input-group .el-input__prefix .el-icon-search{
color: #A7A7A7; color: #A7A7A7;
font-size: 18px; font-size: 18px;
} }
.el-input-group .el-input-group__append, .el-input-group .el-input-group__append,
.el-input-group .el-input-group__append:hover{ .el-input-group .el-input-group__append:hover{
background: transparent; background: transparent;
@ -916,10 +916,10 @@ body .el-input.el-input-group .el-input__inner:hover {
box-sizing: border-box; box-sizing: border-box;
padding: 0; padding: 0;
position:relative; position:relative;
} }
.el-input-group .el-input-group__append:before{ .el-input-group .el-input-group__append:before{
content:none; content:none;
} }
.el-input-group .el-input-group__append .el-button, .el-input-group .el-input-group__append .el-button,
.el-input-group .el-input-group__append .el-button:hover{ .el-input-group .el-input-group__append .el-button:hover{
width: auto; width: auto;
@ -931,19 +931,19 @@ body .el-input.el-input-group .el-input__inner:hover {
margin: 0; margin: 0;
padding: 0 10px; padding: 0 10px;
border-radius: 0 2px 2px 0 !important; border-radius: 0 2px 2px 0 !important;
} }
.el-input-group .el-input-group__append .el-button:hover{ .el-input-group .el-input-group__append .el-button:hover{
} }
.el-input-group .el-input-group__append .el-button i{ .el-input-group .el-input-group__append .el-button i{
font-size: 18px; font-size: 18px;
color: #fff; color: #fff;
line-height:32px; line-height:32px;
margin-left: 0; margin-left: 0;
} }
.el-input-group .el-input-group__append .el-button:hover i{ .el-input-group .el-input-group__append .el-button:hover i{
color:#fff; color:#fff;
} }
/*el-button 组件按钮*/ /*el-button 组件按钮*/
body .el-button{ body .el-button{
@ -954,33 +954,49 @@ body .el-button{
padding-bottom: 0; padding-bottom: 0;
padding-left: 15px; padding-left: 15px;
padding-right: 15px; padding-right: 15px;
} }
body .el-button,body .el-button:focus{ body .el-button,body .el-button:focus{
background: #fff; background: #fff;
border-color: #DCDFE6; border-color: #DCDFE6;
color: #515151; color: #515151;
} }
body .el-button:hover{ body .el-button:hover{
background:#fff; background:#fff;
border-color:#004098; border-color:#004098;
color:#004098; color:#004098;
} }
body .el-button.el-button--primary{ body .el-button.el-button--primary,
body .el-button.el-button--primary.is-plain,
body .el-button.el-button--primary:focus,
body .el-button.el-button--primary.is-plain:focus{
background:#004098; background:#004098;
border-color:#004098; border-color:#004098;
color: #fff; color: #fff;
} }
body .el-button.el-button--primary:hover{ body .el-button.el-button--primary:hover,
body .el-button.el-button--primary.is-plain:hover{
background:#3071b9; background:#3071b9;
border-color:#3071b9; border-color:#3071b9;
color: #fff; color: #fff;
} }
body .el-button.el-button--primary.is-disabled,
body .el-button.el-button--primary[disabled],
body .el-button.el-button--primary.is-disabled:hover,
body .el-button.el-button--primary[disabled]:hover,
body .el-button.el-button--primary.is-plain.is-disabled,
body .el-button.el-button--primary.is-plain[disabled],
body .el-button.el-button--primary.is-plain.is-disabled:hover,
body .el-button.el-button--primary.is-plain[disabled]:hover{
background: #7F9FCB;
border-color: #7F9FCB;
color: #fff;
}
body .el-button.el-button--text{ body .el-button.el-button--text{
color: #3071b9; color: #3071b9;
} }
body .el-button.el-button--text:hover{ body .el-button.el-button--text:hover{
color: #0656e4; color: #0656e4;
} }
body .el-button+.el-button { body .el-button+.el-button {
margin-left: 10px; margin-left: 10px;
} }
@ -1013,15 +1029,22 @@ body .el-drawer .el-drawer__header{
font-size: 18px; font-size: 18px;
font-weight: 500; font-weight: 500;
border-bottom: 1px solid rgba(0 0 0 / 5%); border-bottom: 1px solid rgba(0 0 0 / 5%);
} }
body .el-drawer .el-drawer__header .title{
text-align: left;
margin: 0;
color: #141414;
font-size: 18px;
font-weight: 500;
}
body .el-drawer .el-drawer__header .drawer-head-btn .el-card.is-always-shadow, body .el-drawer .el-drawer__header .drawer-head-btn .el-card.is-always-shadow,
body .el-drawer .el-drawer__header .drawer-head-btn .el-card.is-hover-shadow{ body .el-drawer .el-drawer__header .drawer-head-btn .el-card.is-hover-shadow{
box-shadow: none !important; box-shadow: none !important;
border-radius: 0 !important; border-radius: 0 !important;
} }
body .el-drawer .el-drawer__header .drawer-head-btn .el-card .el-card__body{ body .el-drawer .el-drawer__header .drawer-head-btn .el-card .el-card__body{
padding: 0 !important; padding: 0 !important;
} }
.el-drawer .el-drawer__header .el-drawer__close-btn{ .el-drawer .el-drawer__header .el-drawer__close-btn{
display: inline-block; display: inline-block;
color: #666; color: #666;
@ -1030,17 +1053,17 @@ body .el-drawer .el-drawer__header .drawer-head-btn .el-card .el-card__body{
border-radius: 4px; border-radius: 4px;
text-align: center; text-align: center;
cursor: pointer; cursor: pointer;
} }
.el-drawer .el-drawer__header .el-drawer__close-btn i{ .el-drawer .el-drawer__header .el-drawer__close-btn i{
line-height: 26px; line-height: 26px;
padding: 0; padding: 0;
color: #515151; color: #515151;
font-size: 16px; font-size: 16px;
font-weight: bold; font-weight: bold;
} }
body .el-drawer .el-drawer__body{ body .el-drawer .el-drawer__body{
padding: 16px 32px; padding: 16px 32px;
} }
.el-drawer .el-drawer__body .registerbox { .el-drawer .el-drawer__body .registerbox {
margin: 0; margin: 0;
padding-top: 0; padding-top: 0;
@ -1049,22 +1072,22 @@ body .el-drawer .el-drawer__body{
/*pagination-container 分页*/ /*pagination-container 分页*/
body .apparatus-card>.el-card__body .el-card.gray-card+.pagination-container{ body .apparatus-card>.el-card__body .el-card.gray-card+.pagination-container{
padding-bottom:20px !important; padding-bottom:20px !important;
} }
body .apparatus-card>.el-card__body .el-card.gray-card+.pagination-container .el-pagination{ body .apparatus-card>.el-card__body .el-card.gray-card+.pagination-container .el-pagination{
right:15px; right:15px;
} }
body .el-card.gray-card+.pagination-container{ body .el-card.gray-card+.pagination-container{
margin-top: -3px !important; margin-top: -3px !important;
} }
body .pagination-container{ body .pagination-container{
height: 28px !important; height: 28px !important;
box-sizing: content-box !important; box-sizing: content-box !important;
margin: 15px 0 0 !important; margin: 15px 0 0 !important;
padding: 0 20px !important; padding: 0 20px !important;
} }
body .pagination-container .el-pagination{ body .pagination-container .el-pagination{
padding:0 !important; padding:0 !important;
} }
body .el-pagination.is-background .el-pager li:not(.disabled).active, body .el-pagination.is-background .el-pager li:not(.disabled).active,
body .el-pagination.is-background .el-pager li:not(.disabled).active:hover { body .el-pagination.is-background .el-pager li:not(.disabled).active:hover {
background-color:#004098; background-color:#004098;
@ -1075,7 +1098,7 @@ body .el-pagination.is-background .el-pager li:not(.disabled):hover{
} }
body .el-pager li:hover{ body .el-pager li:hover{
color: #004098; color: #004098;
} }
body .el-pager li.active { body .el-pager li.active {
color: #004098; color: #004098;
} }
@ -1098,11 +1121,11 @@ body .el-pagination{
text-align: right; text-align: right;
justify-content: flex-end; justify-content: flex-end;
padding: 15px 0 0 0; padding: 15px 0 0 0;
} }
body .news-card>.el-card__body .gray-card+.el-pagination, body .news-card>.el-card__body .gray-card+.el-pagination,
body .gray-card+.el-pagination{ body .gray-card+.el-pagination{
padding-top:0 !important; padding-top:0 !important;
} }
/*el-message-box 确认框组件*/ /*el-message-box 确认框组件*/
.el-message-box .el-message-box__btns .el-button.el-button--default.el-button--primary, .el-message-box .el-message-box__btns .el-button.el-button--default.el-button--primary,
@ -1110,58 +1133,58 @@ body .gray-card+.el-pagination{
background:#004098; background:#004098;
border-color:#004098; border-color:#004098;
color: #fff; color: #fff;
} }
.el-message-box .el-message-box__btns .el-button.el-button--default.el-button--primary:hover, .el-message-box .el-message-box__btns .el-button.el-button--default.el-button--primary:hover,
.el-message-box .el-message-box__btns .el-button.el-button--primary:hover{ .el-message-box .el-message-box__btns .el-button.el-button--primary:hover{
background:#3071b9; background:#3071b9;
border-color:#3071b9; border-color:#3071b9;
color: #fff; color: #fff;
} }
.el-message-box .el-message-box__headerbtn:hover .el-message-box__close{ .el-message-box .el-message-box__headerbtn:hover .el-message-box__close{
color: #004098; color: #004098;
} }
/*el-dialog 对话框组件*/ /*el-dialog 对话框组件*/
body .el-dialog{ body .el-dialog{
border-radius:10px; border-radius:10px;
} }
body .el-dialog>.el-dialog__header{ body .el-dialog>.el-dialog__header{
border-bottom: 1px solid #D5D3D3; border-bottom: 1px solid #D5D3D3;
padding: 15px 30px; padding: 15px 30px;
height: 55px; height: 55px;
box-sizing: border-box; box-sizing: border-box;
margin: 0; margin: 0;
} }
body .el-dialog>.el-dialog__header .el-dialog__title{ body .el-dialog>.el-dialog__header .el-dialog__title{
color: #000; color: #000;
font-size:16px; font-size:16px;
font-weight:bold; font-weight:bold;
} }
body .el-dialog>.el-dialog__header .el-dialog__headerbtn{ body .el-dialog>.el-dialog__header .el-dialog__headerbtn{
top: 15px; top: 15px;
font-size: 22px; font-size: 22px;
height: 25px; height: 25px;
line-height: 25px; line-height: 25px;
color:#666; color:#666;
} }
body .el-dialog>.el-dialog__header .el-dialog__headerbtn:hover, body .el-dialog>.el-dialog__header .el-dialog__headerbtn:hover,
body .el-dialog>.el-dialog__header .el-dialog__headerbtn:hover i{ body .el-dialog>.el-dialog__header .el-dialog__headerbtn:hover i{
color: #004098; color: #004098;
} }
body .el-dialog>.el-dialog__body, body .el-dialog>.el-dialog__body,
body .el-overlay .el-overlay-dialog .el-dialog>.el-dialog__body{ body .el-overlay .el-overlay-dialog .el-dialog>.el-dialog__body{
padding:20px 30px !important; padding:20px 30px !important;
} }
body .el-dialog>.el-dialog__footer{ body .el-dialog>.el-dialog__footer{
padding: 10px 30px; padding: 10px 30px;
height: 55px; height: 55px;
box-sizing: border-box; box-sizing: border-box;
} }
body .el-dialog>.el-dialog__footer .dialog-footer{ body .el-dialog>.el-dialog__footer .dialog-footer{
} }
body .el-dialog>.el-dialog__footer .dialog-footer .el-button{ body .el-dialog>.el-dialog__footer .dialog-footer .el-button{
padding: 9.5px 22px; padding: 0 22px;
} }
/*el-input 输入框选择框文本框组件*/ /*el-input 输入框选择框文本框组件*/
body .el-input__prefix{ body .el-input__prefix{
@ -1217,7 +1240,7 @@ body .el-textarea__inner{
font-size: 14px; font-size: 14px;
color: #141414; color: #141414;
font-family: "-apple-system","BlinkMacSystemFont","Microsoft YaHei","system-ui"; font-family: "-apple-system","BlinkMacSystemFont","Microsoft YaHei","system-ui";
} }
body .el-input__inner::-webkit-input-placeholder, body .el-input__inner::-webkit-input-placeholder,
body .el-textarea__inner::-webkit-input-placeholder { body .el-textarea__inner::-webkit-input-placeholder {
color:#B4B0B0; color:#B4B0B0;
@ -1243,12 +1266,12 @@ body .el-date-editor .el-range-separator{
body .el-switch{ body .el-switch{
line-height: 34px; line-height: 34px;
height: 34px; height: 34px;
} }
body .el-input__inner{ body .el-input__inner{
height:34px; height:34px;
line-height:32px; line-height:32px;
border-radius: 2px; border-radius: 2px;
} }
body .el-input .el-input__icon, body .el-input .el-input__icon,
body .el-select .el-input__icon{ body .el-select .el-input__icon{
line-height:32px; line-height:32px;
@ -1257,30 +1280,30 @@ body .el-select .el-input__icon{
body .el-input-number .el-input-number__decrease, body .el-input-number .el-input-number__decrease,
body .el-input-number .el-input-number__increase{ body .el-input-number .el-input-number__increase{
height: 32px; height: 32px;
} }
body .el-input-number .el-input-number__decrease i, body .el-input-number .el-input-number__decrease i,
body .el-input-number .el-input-number__increase i{ body .el-input-number .el-input-number__increase i{
line-height:32px; line-height:32px;
} }
body .el-input i,body .el-select i{ body .el-input i,body .el-select i{
line-height:32px; line-height:32px;
} }
body .el-input .el-date-editor i{ body .el-input .el-date-editor i{
line-height: 32px; line-height: 32px;
height: 32px; height: 32px;
color: #4E5969; color: #4E5969;
} }
body .el-date-editor.el-range-editor i{ body .el-date-editor.el-range-editor i{
height: 26px; height: 26px;
line-height: 26px; line-height: 26px;
color: #4E5969; color: #4E5969;
} }
body .el-radio-group .el-radio{ body .el-radio-group .el-radio{
line-height:34px; line-height:34px;
} }
body .el-textarea__inner{ body .el-textarea__inner{
min-height:100% !important; min-height:100% !important;
} }
body .el-input-number__increase:hover:not(.is-disabled) ~ .el-input .el-input__inner:not(.is-disabled), body .el-input-number__increase:hover:not(.is-disabled) ~ .el-input .el-input__inner:not(.is-disabled),
body .el-input-number__decrease:hover:not(.is-disabled) ~ .el-input .el-input__inner:not(.is-disabled) { body .el-input-number__decrease:hover:not(.is-disabled) ~ .el-input .el-input__inner:not(.is-disabled) {
border-color: #004098; border-color: #004098;
@ -1368,7 +1391,7 @@ body .el-select-dropdown__item:hover {
.el-dropdown-menu .el-dropdown-menu__item:hover{ .el-dropdown-menu .el-dropdown-menu__item:hover{
background-color: #E5EFFF; background-color: #E5EFFF;
color: #004098; color: #004098;
} }
/*el-checkbox 多选组件*/ /*el-checkbox 多选组件*/
body .el-checkbox__input.is-checked + .el-checkbox__label { body .el-checkbox__input.is-checked + .el-checkbox__label {
@ -1421,35 +1444,35 @@ body .registerbox .avatar-uploader .el-upload{
color:#004098 !important; color:#004098 !important;
border-radius: 2px; border-radius: 2px;
height: 36px; height: 36px;
} }
body .el-upload:hover, body .el-upload:hover,
body .registerbox .avatar-uploader .el-upload:hover{ body .registerbox .avatar-uploader .el-upload:hover{
background:#004098; background:#004098;
border-color:#004098; border-color:#004098;
color:#fff !important; color:#fff !important;
} }
body .el-upload i, body .el-upload i,
body .registerbox .avatar-uploader .el-upload i{ body .registerbox .avatar-uploader .el-upload i{
color:#004098 !important; color:#004098 !important;
} }
body .el-upload:hover i, body .el-upload:hover i,
body .registerbox .avatar-uploader .el-upload:hover i{ body .registerbox .avatar-uploader .el-upload:hover i{
color:#fff !important; color:#fff !important;
} }
body .el-upload:hover .el-upload-dragger i{ body .el-upload:hover .el-upload-dragger i{
color:#004098 !important; color:#004098 !important;
} }
body .el-upload .el-button, body .el-upload .el-button,
body .el-upload .el-button:hover{ body .el-upload .el-button:hover{
border: none !important; border: none !important;
background: transparent !important; background: transparent !important;
} }
body .el-upload .el-button{ body .el-upload .el-button{
color:#004098 !important; color:#004098 !important;
} }
body .el-upload:hover .el-button{ body .el-upload:hover .el-button{
color:#fff !important; color:#fff !important;
} }
body .el-upload .el-button{ body .el-upload .el-button{
border-radius: 0 !important; border-radius: 0 !important;
display: block; display: block;
@ -1476,7 +1499,7 @@ body .el-upload-list__item.is-success .el-upload-list__item-name:hover {
margin: 0; margin: 0;
font-size:14px; font-size:14px;
color:#434344; color:#434344;
} }
.el-tree .el-tree-node .el-tree-node__content:hover { .el-tree .el-tree-node .el-tree-node__content:hover {
background-color: #E5EFFF ; background-color: #E5EFFF ;
color:#004098; color:#004098;
@ -1593,14 +1616,14 @@ body .el-table td .el-form-item{
border:0 !important; border:0 !important;
background: transparent !important; background: transparent !important;
height: 20px; height: 20px;
} }
.el-table td .el-button:hover{ .el-table td .el-button:hover{
font-size:14px !important; font-size:14px !important;
padding:0 !important; padding:0 !important;
color: #1890FF !important; color: #1890FF !important;
border:0 !important; border:0 !important;
background: transparent !important; background: transparent !important;
} }
.el-table td .el-input-group .el-input-group__append, .el-table td .el-input-group .el-input-group__append,
.el-table td .el-input-group .el-input-group__append:hover{ .el-table td .el-input-group .el-input-group__append:hover{
background: #004098; background: #004098;
@ -1665,6 +1688,37 @@ body .el-tabs--top .el-tabs__item.is-top:nth-child(2) {
body .el-tabs--top .el-tabs__item.is-top:last-child{ body .el-tabs--top .el-tabs__item.is-top:last-child{
padding-right: 20px; padding-right: 20px;
} }
body .el-card>.el-card__body .el-tabs--border-card{
box-shadow: none;
}
body .el-card>.el-card__body .search-btn .el-tabs--border-card{
border: 0;
}
body .el-card>.el-card__body .search-btn .el-tabs--border-card>.el-tabs__header{
border-bottom: 1px solid #e6e6e6;
background: transparent;
}
body .el-card>.el-card__body .search-btn .el-tabs--border-card>.el-tabs__header .el-tabs__item{
margin: 0;
border: none;
}
body .el-card>.el-card__body .search-btn .el-tabs--border-card>.el-tabs__header .el-tabs__item.is-active{
border: 0;
background: transparent;
color: #034aac;
font-weight: bold;
position: relative;
}
body .el-card>.el-card__body .search-btn .el-tabs--border-card>.el-tabs__header .el-tabs__item.is-active::after{
position: absolute;
left: 0;
bottom: 0;
background: #004098;
content: "";
display: block;
width: 100%;
height: 2px;
}
/*.el-dropdown-link*/ /*.el-dropdown-link*/
body .el-table .el-dropdown-link { body .el-table .el-dropdown-link {

View File

@ -0,0 +1,376 @@
<template>
<div>
<el-upload class="upload-demo" ref="upload" action="#"
:before-upload="beforeUpload"
:on-change="onChange"
:on-remove="handleRemove"
:multiple="isMultiple"
:on-exceed="handleExceed"
:accept="acceptType"
:limit="limit"
:file-list="fileList"
:auto-upload="true"
:http-request="uploadFile"
show-file-list>
<el-button slot="trigger" size="small" type="primary">选取文件</el-button>
<div slot="tip" class="el-upload__tip">只能上传{{acceptType}}文件</div>
</el-upload>
<div v-show="progressFlag" class="head-img">
<el-progress :text-inside="true" :stroke-width="14" :percentage="progressPercent" status="success"></el-progress>
</div>
</div>
</template>
<script>
import axios from 'axios'
import {
getToken
} from "@/utils/auth";
export default {
props: {
uploadUrl: {
type: String,
required: true
},
headers: {
type: Object,
default: () => ({})
},
extraData: {
type: Object,
default: () => ({})
},
onSuccess: {
type: Function,
default: () => {}
},
onError: {
type: Function,
default: () => {}
},
//
isMultiple: {
type: Boolean,
default() {
return false
}
},
//
type: {
type: Array,
default() {
return []
}
},
//
acceptType: {
type: String,
required: true
},
//
limit: {
type: Number,
default() {
return 1
}
},
},
data() {
return {
fileList: [],
progress: 0,
isUploading: false,
progressFlag: false, //
progressPercent: 0, //
partSize: 5 * 1024 * 1024,
};
},
methods: {
//
beforeUpload(file) {
/* const fileType = file.type.toLowerCase()
console.info("fileType=======", fileType)
const typeFlag = this.type.some(item => {
return fileType.indexOf(item) != -1
})
if (!typeFlag) {
this.$message.error('上传类型有误,请重新上传')
return false
}*/
},
/* //上传函数
submitUpload(file) {
// 便setTimeout --setTimeoutvue
var that = this;
// that.$refs.upload.submit();
//
if (this.fileList.length == 0) {
that.$message({
message: '请选择导入的文件',
type: 'warning',
duration: '2000'
});
return;
}
//FormData();
let paramFormData = new FormData();
// fileList
that.fileList.forEach(file => {
paramFormData.append("file", file.raw);
});
//progressFlag
that.progressFlag = true;
//axios
axios({
url: that.uploadUrl,
method: 'post',
data: paramFormData,
headers: {
'Authorization': 'Bearer ' + getToken(),
'Content-Type': 'multipart/form-data'
},
onUploadProgress: progressEvent => {
// progressEvent.loaded:
// progressEvent.total:
//
that.progressPercent = ((progressEvent.loaded / progressEvent.total) * 100) | 0;
}
}).then(res => {
console.info("res===========", res)
if (res.data.code == 200 && that.progressPercent === 100) {
setTimeout(function () {
that.$message({
message: '上传成功!',
type: 'success',
duration: '2000'
});
that.progressFlag = false;
that.progressPercent = 0
}, 500);
}
}).catch(error => {
that.progressFlag = false;
that.progressPercent = 0
that.$refs.upload.clearFiles();
that.$message({
message: '上传失败!',
type: 'error',
duration: '2000'
});
})
},*/
//
onChange(file, fileList) {
this.fileList = fileList;
},
handleRemove(file, fileList) {
this.fileList = fileList;
},
handleExceed(files, fileList) {
this.$message.warning(
"最多之能上传"+ this.limit +"个附件"
);
},
async uploadFile({ data, file }) {
let self = this
//
this.progress++
if (file.size < this.partSize) {
let formData = new FormData()
formData.append("file", file)
self.progressFlag = true;
axios({
url: self.uploadUrl,
method: 'post',
data: formData,
headers: {
'Authorization': 'Bearer ' + getToken(),
'Content-Type': 'multipart/form-data'
},
onUploadProgress: progressEvent => {
// progressEvent.loaded:
// progressEvent.total:
//
self.progressPercent = ((progressEvent.loaded / progressEvent.total) * 100) | 0;
}
}).then(res => {
setTimeout(() => {
if (res.data.code == 200 && self.progressPercent === 100) {
setTimeout(function () {
self.$message({
message: '上传成功!',
type: 'success',
duration: '2000'
});
self.progressFlag = false;
self.progressPercent = 0
}, 500);
} else {
self.$message({
message: '上传失败!',
type: 'error',
duration: '2000'
});
}
}, 1000);
}).catch(error => {
console.error(error)
self.progressFlag = false;
self.progressPercent = 0
self.$refs.upload.clearFiles();
self.$message({
message: '上传失败!',
type: 'error',
duration: '2000'
});
})
} else {
console.info("111111111111")
file._shardCount = Math.ceil(file.size / this.partSize) //
file.uploaded = 0
let formData = new FormData()
formData.append('fileName', file.name)
let self = this
//,uploadId initUpload(formData)
axios({
url: process.env.VUE_APP_BASE_API + "/common/initUpload",
method: 'post',
data: formData,
headers: {
'Authorization': 'Bearer ' + getToken(),
'Content-Type': 'multipart/form-data'
},
}).then(function (res) {
console.info("res=====initUpload=======", res)
if (res.status == 200) {
//0
file.uploadId = res.data.uploadId
file.objectKey = res.data
file.chunkId = 0
self.uploadByChunk(file)
} else {
this.progress--
self.$message.error(res.msg)
}
}).catch(error => {
self.progressPercent = 0
self.progressFlag = false;
console.error(error)
})
}
},
//
uploadByChunk(file) {
this._start = file.chunkId * this.partSize
this._end = Math.min(file.size, this._start + this.partSize)// +
let self = this
let fileData = file.slice(this._start, this._end)
//MD5
let reader = new FileReader()
reader.readAsBinaryString(fileData)
//
// reader.onloadend = function(e) {
// hex_md5md5OSSmd5-js
// self.md5Str[index] = (CryptoJS(this.result)).toLocaleUpperCase()
// self.md5Str[index] = CryptoJS.MD5(e.target.result)
// }
let form1 = new FormData()//newform
form1.append('chunkFile', fileData) //slice
form1.append('uploadId', file.uploadId)
form1.append('chunkId', (file.chunkId + 1).toString())
form1.append('shardCount', file._shardCount.toString()) //
self.progressFlag = true;
//Chunk chunkMD5 uploadChunk(form1)
axios({
url: process.env.VUE_APP_BASE_API + "/common/uploadChunk",
method: 'post',
data: form1,
headers: {
'Authorization': 'Bearer ' + getToken(),
'Content-Type': 'multipart/form-data'
},
onUploadProgress: progressEvent => {
// progressEvent.loaded:
// progressEvent.total:
//
self.progressPercent = ((progressEvent.loaded / progressEvent.total) * 100) | 0;
}
}).then(response => {
console.info("response=======uploadChunk=====", response)
if (response.status == 200) {
//MD5MD5
// self.md5Str[index] === response.msg ||
if (true) {
// this.$message.success('' + (index + 1).toString() + '')
file.uploaded++
self.percentageSend(file)
//
file.chunkId++
if (file.chunkId < file._shardCount) {
this.uploadByChunk(file)
}
} else {
//
this.$message.success('第' + (file.chunkId + 1).toString() + '块文件上传不成功,重新上传')
this.uploadByChunk(file.chunkId)
}
} else {
//
this.progress--
this.$message.error(response.msg)
}
})
},
//
percentageSend(file) {
let self = this
let perNum = Math.floor((file.uploaded / file._shardCount) * 100)
this.progressPercent = perNum
//
if (perNum === 100) {
let form2 = new FormData()//newform
form2.append('uploadId', file.uploadId)
form2.append('fileName', file.name)
//
// 访URL
axios({
url: process.env.VUE_APP_BASE_API + "/common/mergeFile",
method: 'post',
data: form2,
headers: {
'Authorization': 'Bearer ' + getToken(),
'Content-Type': 'multipart/form-data'
},
}).then(response => {
console.info("response====mergeFile========", response)
if (response.status == 200) {
setTimeout(function () {
self.$message({
message: '上传成功!',
type: 'success',
duration: '2000'
});
self.progressFlag = false;
self.progressPercent = 0
}, 500);
} else {
self.$message({
message: '上传失败!',
type: 'error',
duration: '2000'
});
}
console.info("file===============", file)
})
}
},
resetData() {
this.progress = 0;
},
}
};
</script>

View File

@ -3,21 +3,32 @@
<el-form ref="form" :model="form" :rules="rules" label-width="150px"> <el-form ref="form" :model="form" :rules="rules" label-width="150px">
<el-row> <el-row>
<el-col :span="24"> <el-col :span="24">
<!--<el-form-item label="文档类别" required> <el-form-item label="文件分类" prop="docCode">
<el-select placeholder="请选择"> <treeselect v-model="form.categoryId" :options="docCategory" :show-count="true" placeholder="请选择文件分类"/>
<el-option label="管理手册" value=""></el-option>
<el-option label="操作手册" value=""></el-option>
<el-option label="程序文件" value=""></el-option>
<el-option label="需求文档" value=""></el-option>
</el-select>
</el-form-item>-->
<el-form-item label="文档类别" prop="docType">
<el-input v-model="form.docType" placeholder="请输入文档类别" />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24">
<el-form-item label="文档编号" prop="docCode">
<el-input v-model="form.docCode" placeholder="请输入文档编号" maxlength="50" show-word-limit/>
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="文档名称" prop="docName">
<el-input v-model="form.docName" placeholder="请输入文档名称" maxlength="200" show-word-limit/>
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="文档类别" prop="docType">
<el-input v-model="form.docType" placeholder="请输入文档类别" maxlength="50" show-word-limit/>
</el-form-item>
</el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="文档来源" prop="docSource"> <el-form-item label="文档来源" prop="docSource">
<el-input v-model="form.docSource" placeholder="请输入文档来源" /> <el-input v-model="form.docSource" placeholder="请输入文档来源" maxlength="50" show-word-limit/>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
@ -27,16 +38,26 @@
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="负责人" prop="docPrincipals"> <el-form-item label="负责人" prop="docPrincipals">
<el-input v-model="form.docPrincipals" placeholder="请输入负责人" /> <el-input v-model="form.docPrincipals" placeholder="请输入负责人" maxlength="50" show-word-limit/>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="归属部门" prop="docRespDept"> <el-form-item label="归属单位" prop="docRespDept">
<el-input v-model="form.docRespDept" placeholder="请输入归属部门" /> <treeselect v-model="form.docRespDept" :options="deptOptions" :show-count="true" placeholder="请输入归属单位" />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="文件" required> <el-form-item label="文件" required>
<uploadVue
:uploadUrl="uploadFileUrl"
:type="['.txt','.doc','.docx','.pdf','.mp4','.zip','.rar','.7z','.png','.jpg','.jpeg']"
:acceptType="acceptType"
:limit="1"
:onSuccess="handleUploadSuccess"
:onError="handleUploadError"
/>
<!-- <uploadVue-->
<!-- <upload-progress/>
<el-upload <el-upload
class="upload-component" class="upload-component"
ref="upload" ref="upload"
@ -50,7 +71,7 @@
<el-button size="small" type="primary">点击上传</el-button> <el-button size="small" type="primary">点击上传</el-button>
<div slot="tip" class="el-upload__tip">只能上传jpg/png文件且不超过500kb</div> <div slot="tip" class="el-upload__tip">只能上传jpg/png文件且不超过500kb</div>
<div slot="tip" class="el-upload__tip"><el-progress :percentage="progress"></el-progress></div> <div slot="tip" class="el-upload__tip"><el-progress :percentage="progress"></el-progress></div>
</el-upload> </el-upload>-->
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
@ -71,7 +92,7 @@
</el-table-column>--> </el-table-column>-->
<el-table-column align="center" width="55"> <el-table-column align="center" width="55">
<template slot-scope="scope"> <template slot-scope="scope">
<el-radio v-model="templateSelection" :label="scope.row.prop1">&nbsp;</el-radio> <el-radio v-model="templateSelection" :label="scope.row.prop1"></el-radio>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="prop1" label="工具编号"></el-table-column> <el-table-column prop="prop1" label="工具编号"></el-table-column>
@ -93,8 +114,15 @@
import { addDocument, updateDocument } from "@/api/document/document"; import { addDocument, updateDocument } from "@/api/document/document";
import axios from 'axios'; import axios from 'axios';
import { getToken } from '@/utils/auth' import { getToken } from '@/utils/auth'
import { deptTreeSelect } from "@/api/system/user";
import { documentTree } from "@/api/documentCategory/documentCategory.js";
import Treeselect from "@riophae/vue-treeselect";
import uploadProgress from "./uploadProgress";
import uploadVue from '@/components/FileUpload/optimizeUpload.vue'
export default { export default {
name: 'editDocument', name: 'editDocument',
components: { Treeselect, uploadProgress, uploadVue},
props: { props: {
tooId: { tooId: {
type: String, type: String,
@ -124,10 +152,12 @@
], ],
// //
form: { form: {
categoryId: undefined,
docCode: '',
docName: '', docName: '',
docType: '', docType: '',
docPrincipals: '', docPrincipals: '',
docRespDept: '', docRespDept: undefined,
docSource: '', docSource: '',
toolId: '' toolId: ''
}, },
@ -135,16 +165,29 @@
progress: 0, progress: 0,
// //
rules: { rules: {
docCode: [
{ required: true, message: "文档编号不能为空", trigger: "blur" }
],
docName: [
{ required: true, message: "文档名称不能为空", trigger: "blur" }
],
docType: [ docType: [
{ required: true, message: "类别不能为空", trigger: "blur" } { required: true, message: "类别不能为空", trigger: "blur" }
], ],
docSource: [ docSource: [
{ required: true, message: "文档来源不能为空", trigger: "blur" } { required: true, message: "文档来源不能为空", trigger: "blur" }
] ]
} },
docCategory:[],
deptOptions:[],
uploadFileUrl: process.env.VUE_APP_BASE_API + "/common/upload", //
fileData: null,
acceptType: ".txt,.doc,.docx,.pdf,.mp4,.zip,.rar,.7z,.png,.jpg,.jpeg"
} }
}, },
created(){ created(){
this.getDeptTree();
this.getDocumentTree();
}, },
mounted(){ mounted(){
/* this.$nextTick(() => { /* this.$nextTick(() => {
@ -153,7 +196,8 @@
}, },
methods:{ methods:{
chooseToolConfirm(){ chooseToolConfirm(){
this.form.toolId = this.templateSelection this.$set(this.form, "toolId", this.templateSelection)
this.drawer1 = false;
}, },
singleElection(row) { singleElection(row) {
this.templateSelection = row.prop1 this.templateSelection = row.prop1
@ -182,7 +226,7 @@
}, },
// //
cancel() { cancel() {
this.open = false; this.drawer1 = false;
this.reset(); this.reset();
}, },
onChange(file, fileList) { onChange(file, fileList) {
@ -285,6 +329,46 @@
console.error('Failed to upload file:', error); console.error('Failed to upload file:', error);
}); });
}, },
/** 查询部门下拉树结构 */
getDeptTree() {
deptTreeSelect().then(response => {
this.deptOptions = response.data;
});
},
/** 查询树形下拉树结构 */
getDocumentTree() {
documentTree().then(response => {
this.docCategory = response.data;
});
},
/** 转换部门数据结构 */
normalizer(node) {
if (node.children && !node.children.length) {
delete node.children;
}
return {
id: node.deptId,
label: node.deptName,
children: node.children
};
},
// flag true
getData(data, flag, index) {
console.info("data============", data)
console.info("flag============", flag)
console.info("index============", index)
},
getError(message) {
this.$message.error(message);
},
handleUploadSuccess(response) {
alert('File uploaded successfully');
//
},
handleUploadError(error) {
alert('Failed to upload file');
//
}
} }
} }
</script> </script>

View File

@ -23,26 +23,21 @@
</el-card> </el-card>
<el-card class="lrtt"> <el-card class="lrtt">
<div class="lt"> <div class="lt">
<el-input <el-input placeholder="请输入..." prefix-icon="el-icon-search"></el-input>
v-model="deptName"
placeholder="请输入部门名称"
clearable
size="small"
prefix-icon="el-icon-search"
style="margin-bottom: 20px"
/>
<div class="divide"></div><!--divide 分隔--> <div class="divide"></div><!--divide 分隔-->
<el-tree <el-tree :data="docCategory" :props="docCategoryProps" @node-click="handleNodeClick">
:data="deptOptions" <span class="custom-tree-node" slot-scope="{ node, data }">
:props="defaultProps" <span>{{ node.label }}</span>
:expand-on-click-node="false" <el-dropdown>
:filter-node-method="filterNode" <span class="el-dropdown-link"><i class="el-icon-more"></i></span>
ref="tree" <el-dropdown-menu slot="dropdown">
node-key="id" <el-dropdown-item @click.native="handleDocCategoryAdd(data)"><i class="el-icon-plus"></i>添加</el-dropdown-item>
default-expand-all <el-dropdown-item v-if="data.types != 'system'" @@click.native="handleDocCategoryUpdate(data)"><i class="el-icon-edit"></i>编辑</el-dropdown-item>
highlight-current <el-dropdown-item v-if="data.types != 'system'" @@click.native="handleDocCategoryDelete(data)"><i class="el-icon-delete"></i>删除</el-dropdown-item>
@node-click="handleNodeClick" </el-dropdown-menu>
/> </el-dropdown>
</span>
</el-tree>
</div><!--lt --> </div><!--lt -->
<div class="rt"> <div class="rt">
<div class="operate"> <div class="operate">
@ -106,6 +101,28 @@
</div> </div>
</el-card> </el-card>
<el-dialog :title="docCategoryTitle" :visible.sync="docCategoryOpen" width="50%" append-to-body>
<el-form ref="docCategoryForm" :model="docCategoryForm" :rules="docCategoryRules" label-width="80px">
<el-form-item label="父分类" prop="parentId">
<treeselect v-model="docCategoryForm.parentId" :options="docCategory" :show-count="true" placeholder="如果不选择,默认为顶级节点" />
</el-form-item>
<el-form-item label="分类名称" prop="categoryName">
<el-input v-model="docCategoryForm.categoryName" placeholder="请输入分类名称" maxlength="50" show-word-limit/>
</el-form-item>
<el-form-item label="分类描述" prop="categoryDescription">
<el-input v-model="docCategoryForm.categoryDescription"
type="textarea" :rows="3" maxlength="500" show-word-limit
placeholder="请输入分类描述" />
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button type="primary" @click="docCategorySubmitForm"> </el-button>
<el-button @click="docCategoryCancel"> </el-button>
</span>
</el-dialog>
<el-dialog :title="viewDialogTitle" :visible.sync="viewDialogOpen" fullscreen width="500px" append-to-body> <el-dialog :title="viewDialogTitle" :visible.sync="viewDialogOpen" fullscreen width="500px" append-to-body>
<i-frame :src="previewUrl" /> <i-frame :src="previewUrl" />
</el-dialog> </el-dialog>
@ -128,15 +145,18 @@
<script> <script>
import { listDocument, getDocument, delDocument, addDocument, updateDocument } from "@/api/document/document"; import { listDocument, getDocument, delDocument, addDocument, updateDocument } from "@/api/document/document";
import { deptTreeSelect } from "@/api/system/user"; import { deptTreeSelect } from "@/api/system/user";
import { documentTree,addCategory,updateCategory,delCategory,getCategory } from "@/api/documentCategory/documentCategory.js";
import { Base64 } from 'js-base64'; import { Base64 } from 'js-base64';
import iFrame from "@/components/iFrame/index" import iFrame from "@/components/iFrame/index"
import editDocument from "./editDocument"; import editDocument from "./editDocument";
import uploadProgress from "./uploadProgress"; import uploadProgress from "./uploadProgress";
import { w3cwebsocket as WebSocket } from 'websocket'; import { w3cwebsocket as WebSocket } from 'websocket';
import Treeselect from "@riophae/vue-treeselect";
export default { export default {
name: "Document", name: "Document",
components: { iFrame, editDocument, uploadProgress }, components: { iFrame, editDocument, uploadProgress, Treeselect},
data() { data() {
return { return {
// //
@ -157,6 +177,12 @@ export default {
children: "children", children: "children",
label: "label" label: "label"
}, },
//
docCategory: undefined,
docCategoryProps: {
children: "children",
label: "label"
},
// //
total: 0, total: 0,
// //
@ -194,12 +220,35 @@ export default {
docSource: [ docSource: [
{ required: true, message: "文档来源不能为空", trigger: "blur" } { required: true, message: "文档来源不能为空", trigger: "blur" }
] ]
} },
docCategoryRules: {
categoryName: [
{ required: true, message: "分类名称不能为空", trigger: "blur" }
],
createBy: [
{ required: true, message: "创建人名称不能为空", trigger: "blur" }
],
createById: [
{ required: true, message: "创建人id不能为空", trigger: "blur" }
],
createTime: [
{ required: true, message: "创建时间不能为空", trigger: "blur" }
],
},
docCategoryTitle: "",
docCategoryOpen: false,
//
docCategoryForm: {
categoryName: null,
categoryDescription: null,
parentId: null
},
}; };
}, },
created() { created() {
this.getList(); this.getList();
this.getDeptTree(); this.getDeptTree();
this.getDocumentTree();
}, },
methods: { methods: {
/** 查询部门下拉树结构 */ /** 查询部门下拉树结构 */
@ -208,6 +257,12 @@ export default {
this.deptOptions = response.data; this.deptOptions = response.data;
}); });
}, },
/** 查询树形下拉树结构 */
getDocumentTree() {
documentTree().then(response => {
this.docCategory = response.data;
});
},
// //
filterNode(value, data) { filterNode(value, data) {
if (!value) return true; if (!value) return true;
@ -268,8 +323,71 @@ export default {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}).catch(() => {}); }).catch(() => {});
},
/** 新增按钮操作 */
handleDocCategoryAdd(data) {
console.info("data================", data)
this.docCategoryOpen = true;
// this.docCategoryForm.parentId = data.id;
this.$nextTick(() => {
this.resetDocCategoryForm();
this.docCategoryForm.parentId = data.id;
})
this.docCategoryTitle = "添加文档资源分类";
},
/** 删除按钮操作 */
handleDocCategoryDelete(row) {
this.$modal.confirm('是否删除该项数据?').then(function() {
return delCategory(row.id);
}).then(() => {
this.getDocumentTree();
this.$modal.msgSuccess("删除成功");
}).catch((err) => {
console.info("err============", err)
});
},
/** 修改按钮操作 */
handleDocCategoryUpdate(row) {
this.resetDocCategoryForm();
const id = row.id;
getCategory(id).then(response => {
this.docCategoryForm = response.data;
this.docCategoryOpen = true;
this.docCategoryTitle = "修改文档资源分类";
});
},
/** 提交按钮 */
docCategorySubmitForm() {
this.$refs["docCategoryForm"].validate(valid => {
if (valid) {
if (this.docCategoryForm.id != null) {
updateCategory(this.docCategoryForm).then(response => {
this.$modal.msgSuccess("修改成功");
this.docCategoryOpen = false;
this.getDocumentTree();
});
} else {
this.$set(this.docCategoryForm, "type", "user")
addCategory(this.docCategoryForm).then(response => {
this.$modal.msgSuccess("新增成功");
this.docCategoryOpen = false;
this.getDocumentTree();
});
} }
} }
});
},
//
docCategoryCancel() {
this.docCategoryOpen = false;
this.resetDocCategoryForm();
},
/** 重置 **/
resetDocCategoryForm(){
this.$refs.docCategoryForm.resetFields();
}
}
}; };
</script> </script>

View File

@ -124,7 +124,7 @@ export default {
}; };
</script> </script>
<style rel="stylesheet/scss" lang="scss"> <style rel="stylesheet/scss" lang="scss" scoped>
.login { .login {
display: flex; display: flex;
justify-content: center; justify-content: center;

View File

@ -146,7 +146,7 @@ export default {
}; };
</script> </script>
<style rel="stylesheet/scss" lang="scss"> <style rel="stylesheet/scss" lang="scss" scoped>
.register { .register {
display: flex; display: flex;
justify-content: center; justify-content: center;