消防队
完整度
-
-
+
+
-
+
{{node.name}}
- {{node.fireForceDetailInfo ? accMul(node.fireForceDetailInfo.integrityScore.toFixed(3),100,1) : 0}}%
+ {{node.fireForceDetailInfo ?
+ accMul(node.fireForceDetailInfo.integrityScore.toFixed(3),100,1) : 0}}%
-
-
highlight_off
+
+ highlight_off
+
-
-
-
+
+
+
{{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}}
@@ -66,27 +75,36 @@
{{node.name}}
- {{node.fireForceDetailInfo ? accMul(node.fireForceDetailInfo.integrityScore.toFixed(3),100,1) : 0}}%
+ {{node.fireForceDetailInfo ?
+ accMul(node.fireForceDetailInfo.integrityScore.toFixed(3),100,1) : 0}}%
-
-
highlight_off
-
+
+ highlight_off
+
+
-
+
{{item.name}}
- {{item.fireForceDetailInfo ? accMul(item.fireForceDetailInfo.integrityScore.toFixed(3),100,1) : 0}}%
+ {{item.fireForceDetailInfo ?
+ accMul(item.fireForceDetailInfo.integrityScore.toFixed(3),100,1) : 0}}%
-
-
highlight_off
+
+ highlight_off
+
@@ -94,14 +112,16 @@
- {{item.name}}
+ {{item.name}}
@@ -129,13 +149,17 @@
-
-
+
+
+
- close 关闭
+
+ close 关闭
+
-
+
基本信息
- *
+ *
队站名称:
-
+
@@ -194,7 +219,8 @@
备注:
-
+
位置信息
@@ -209,16 +235,18 @@
经度:
-
+
纬度:
-
+
-
+
人员数量
@@ -301,10 +329,10 @@
- *
+ *
队站名称:
-
+
@@ -322,7 +350,8 @@
备注:
-
+
位置信息
@@ -337,16 +366,18 @@
经度:
-
+
纬度:
-
+
-
+
人员数量
@@ -370,7 +401,7 @@
联系方式
-
+
站长姓名:
@@ -449,9 +480,9 @@
基本信息
-
+
- *
+ *
队伍类型:
@@ -463,7 +494,7 @@
- *
+ *
队伍名称:
@@ -479,8 +510,10 @@
站长:
-
-
+
+
@@ -492,8 +525,10 @@
负责人:
-
-
+
+
@@ -505,7 +540,8 @@
备注:
-
+
位置信息
@@ -520,16 +556,18 @@
经度:
-
+
纬度:
-
+
-
+
人员数量
@@ -553,7 +591,7 @@
辆
-
+
@@ -562,39 +600,336 @@
个
-
+
-
-
diff --git a/src/app/data-collection/fire-force/fire-force.component.scss b/src/app/data-collection/fire-force/fire-force.component.scss
index ff93dcc..94a15fc 100644
--- a/src/app/data-collection/fire-force/fire-force.component.scss
+++ b/src/app/data-collection/fire-force/fire-force.component.scss
@@ -1,7 +1,5 @@
-.box{
- width: 100%;
- height: 100%;
- background-color: #F2F4F6;
+.box {
+ background-color: #f2f4f6;
display: flex;
box-sizing: border-box;
padding: 10px;
@@ -9,43 +7,43 @@
font-weight: 400;
color: #000000;
}
-.listbox{
+.listbox {
width: 400px;
height: 100%;
background-color: #fff;
display: flex;
flex-direction: column;
- .topbox{
+ .topbox {
max-height: 200px;
box-sizing: border-box;
padding: 10px 22px 22px;
- .add{
+ .add {
height: 36px;
line-height: 36px;
display: flex;
justify-content: space-between;
}
- .searchbox{
- .inputbox{
+ .searchbox {
+ .inputbox {
width: 100%;
height: 36px;
font-size: 14px;
line-height: 36px;
margin: 10px 0;
display: flex;
- span{
+ span {
margin-right: 5px;
}
- select,input{
+ select,
+ input {
flex: 1;
- background-color: #F2F4F6;
+ background-color: #f2f4f6;
border: 0;
border-radius: 5px;
box-sizing: border-box;
- padding:0 8px;
-
+ padding: 0 8px;
}
- .gray{
+ .gray {
color: gray;
}
// input::-moz-placeholder {
@@ -61,12 +59,12 @@
}
}
}
- .contantbox{
+ .contentbox {
flex: 1;
overflow-y: auto;
display: flex;
flex-direction: column;
- .title{
+ .title {
display: flex;
justify-content: space-between;
width: 100%;
@@ -74,25 +72,25 @@
padding: 0 33px 0 22px;
height: 36px;
line-height: 36px;
- span{
+ span {
font-size: 14px;
font-weight: 500;
}
}
- .fireForceTree{
+ .fireForceTree {
flex: 1;
overflow-y: auto;
- .nodename{
+ .nodename {
flex: 1;
overflow: hidden;
- text-overflow:ellipsis
+ text-overflow: ellipsis;
}
- .integrity{
+ .integrity {
width: 100px;
height: 16px;
position: relative;
- background-color: #F2F4F6;
- .integrityNum{
+ background-color: #f2f4f6;
+ .integrityNum {
position: absolute;
left: 50%;
top: 50%;
@@ -101,23 +99,23 @@
font-size: 13px;
cursor: default;
}
- .integrityColorDiv{
+ .integrityColorDiv {
height: 100%;
}
}
- .mat-tree-node{
+ .mat-tree-node {
cursor: pointer;
}
- .selectedTreeNode{
+ .selectedTreeNode {
background-color: #d2eafd;
}
- .mat-tree-node:hover{
- background-color: #d2eafd;
+ .mat-tree-node:hover {
+ background-color: #d2eafd;
}
- .deletebtn{
+ .deletebtn {
width: 26px;
text-align: center;
- mat-icon{
+ mat-icon {
width: 20px;
height: 20px;
cursor: pointer;
@@ -125,15 +123,15 @@
vertical-align: middle;
color: rgba(49, 46, 46, 0.144);
}
- mat-icon:hover{
+ mat-icon:hover {
color: #000;
}
}
}
- .fireForceList{
+ .fireForceList {
flex: 1;
overflow-y: auto;
- li{
+ li {
cursor: pointer;
width: 100%;
height: 36px;
@@ -141,24 +139,24 @@
display: flex;
align-items: center;
font-size: 14px;
- div{
+ div {
float: left;
box-sizing: border-box;
}
- .name{
+ .name {
text-align: left;
width: 60%;
padding-left: 22px;
- white-space:nowrap;
- overflow:hidden;
- text-overflow:ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
}
- .integrity{
+ .integrity {
height: 58%;
width: 32%;
position: relative;
- background-color: #F2F4F6;
- .integrityNum{
+ background-color: #f2f4f6;
+ .integrityNum {
position: absolute;
left: 50%;
top: 50%;
@@ -167,14 +165,14 @@
font-size: 13px;
cursor: default;
}
- .integrityColorDiv{
+ .integrityColorDiv {
height: 100%;
}
}
- .deletebtn{
+ .deletebtn {
flex: 1;
text-align: center;
- mat-icon{
+ mat-icon {
width: 20px;
height: 20px;
cursor: pointer;
@@ -182,102 +180,100 @@
vertical-align: text-top;
color: rgba(49, 46, 46, 0.144);
}
- mat-icon:hover{
+ mat-icon:hover {
color: #000;
}
}
}
- li:hover{
+ li:hover {
background-color: #b3d3ee;
}
- .selectedLi{
+ .selectedLi {
background-color: #b3d3ee;
}
-
}
- .paginator{
+ .paginator {
height: 56px;
width: 100%;
}
}
}
-.mapbox{
+.mapbox {
flex: 1;
margin-left: 10px;
background-color: #fff;
display: flex;
flex-direction: column;
- .mapcheckbox{
+ .mapcheckbox {
width: 100%;
height: 50px;
line-height: 50px;
- mat-checkbox{
- margin-right:60px;
+ mat-checkbox {
+ margin-right: 60px;
font-size: 15px;
}
- mat-checkbox:nth-child(1){
+ mat-checkbox:nth-child(1) {
margin-left: 20px;
}
}
- #map{
+ #map {
flex: 1;
position: relative;
- #container{
+ #container {
width: 100%;
height: 100%;
}
- .gistopbox{
+ .gistopbox {
position: absolute;
box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
border-radius: 5px;
top: 3px;
width: 30%;
- height:40px;
- background: #FFFFFF;
+ height: 40px;
+ background: #ffffff;
display: flex;
align-items: center;
- cursor: default;;
- .inputBox{
+ cursor: default;
+ .inputBox {
width: 100%;
display: flex;
align-items: center;
justify-content: center;
box-sizing: border-box;
font-size: 14px;
- .positionInput{
+ .positionInput {
border: 0;
border-radius: 6px;
width: 80%;
height: 28px;
- background: #F2F2F2;
+ background: #f2f2f2;
margin-left: 8px;
box-sizing: border-box;
padding-left: 10px;
}
}
-
}
- .hidden{
+ .hidden {
opacity: 0;
z-index: -1;
}
- .show{
+ .show {
opacity: 1;
z-index: 1;
}
}
- .detailsbox{
+ .detailsbox {
width: 100%;
- height:500px;
+ height: 500px;
position: relative;
transition: height 0.5s;
- .putDown{
+ .putDown {
position: absolute;
right: 0;
top: -40px;
cursor: pointer;
}
- .tabsbox{
+ .tabsbox {
// margin-top: 10px;
width: 100%;
height: 40px;
@@ -287,28 +283,28 @@
display: flex;
justify-content: space-between;
font-size: 15px;
- .tabs{
- div{
+ .tabs {
+ div {
float: left;
width: 120px;
text-align: center;
cursor: pointer;
color: #000000;
opacity: 0.4;
- border-right: 1px solid #F2F4F6;
+ border-right: 1px solid #f2f4f6;
}
- .selectedBtn{
- background-color: #2196F3;
+ .selectedBtn {
+ background-color: #2196f3;
color: #fff;
opacity: 1;
}
}
- .btnbox{
+ .btnbox {
display: flex;
align-items: center;
flex: 1;
justify-content: flex-end;
- .uploadAttachment{
+ .uploadAttachment {
display: inline-block;
margin-right: 20px;
width: 120px;
@@ -316,103 +312,116 @@
height: 28px;
line-height: 28px;
position: relative;
- button{
+ button {
width: 100%;
height: 28px;
line-height: 28px;
- mat-icon{
+ mat-icon {
transform: rotate(25deg);
font-size: 20px;
width: 20px;
height: 20px;
}
}
- .a-upload{
- display: inline-block;
- position: absolute;
- left: 0;
- top: 0;
- display: inline-block;
- width: 100%;
- height: 100%;
- opacity: 0;
- input{
+ .a-upload {
+ display: inline-block;
+ position: absolute;
+ left: 0;
+ top: 0;
+ display: inline-block;
+ width: 100%;
+ height: 100%;
+ opacity: 0;
+ input {
width: 100%;
height: 100%;
cursor: pointer;
- }
- }
- }
- span{
+ }
+ }
+ }
+ span {
display: inline-block;
cursor: pointer;
- color: #2196F3;
- mat-icon{
+ color: #2196f3;
+ mat-icon {
vertical-align: sub;
font-size: 20px;
width: 20px;
height: 20px;
}
}
- span:hover{
- // text-decoration: underline;
- }
- .state{
- margin-right:30px;
+ .state {
+ margin-right: 30px;
}
- .submitAudit{
- margin-right:30px;
+ .submitAudit {
+ margin-right: 30px;
}
- .close{
+ .close {
margin-right: 30px;
}
+ .goback {
+ cursor: pointer;
+ display: flex;
+ align-items: center;
+ color: #2196f3;
+ img {
+ width: 14px;
+ height: 14px;
+ margin-right: 5px;
+ }
+ margin-right: 12px;
+ }
}
}
- .contant{
+ .content {
width: 100%;
- height:460px;
+ height: 460px;
overflow-y: auto;
- p{
- color: #2196F3;
- background-color: #F2F4F6;
+ p {
+ color: #2196f3;
+ background-color: #f2f4f6;
height: 33px;
line-height: 33px;
box-sizing: border-box;
padding-left: 20px;
font-size: 15px;
}
- span{
+ span {
font-size: 15px;
}
- input,select{
+ input,
+ select {
height: 30px;
line-height: 30px;
box-sizing: border-box;
- padding: 0 12px;
+ padding: 0 9px;
width: 60%;
margin-left: 5px;
- border: 1px solid #EBEBEB;
+ border: 1px solid #ebebeb;
border-radius: 5px;
}
- textarea{
+ textarea {
width: 89%;
margin-left: 5px;
height: 85%;
- border: 1px solid #EBEBEB;
+ border: 1px solid #ebebeb;
border-radius: 5px;
+ box-sizing: border-box;
+ padding: 3px 9px;
}
- .longinput{
+ .longinput {
width: 74%;
}
- .unitDiv{
+ .unitDiv {
width: 60%;
position: relative;
- input,select{
+ input,
+ select {
width: 100%;
box-sizing: border-box;
padding-right: 50px;
}
- .unit{
+ .unit {
position: absolute;
right: 13px;
top: 4px;
@@ -420,14 +429,14 @@
opacity: 0.4;
}
}
- .smallwidth{
+ .smallwidth {
width: 30%;
}
// 相关资料
- .fileDivBox{
+ .fileDivBox {
position: relative;
float: left;
- border: 1px solid #EBEBEB;
+ border: 1px solid #ebebeb;
width: 160px;
height: 162px;
box-sizing: border-box;
@@ -437,29 +446,29 @@
margin: 12px;
align-items: center;
cursor: pointer;
- .imgbox{
+ .imgbox {
width: 134px;
height: 110px;
display: flex;
justify-content: center;
align-items: center;
- .thumbnailImg{
+ .thumbnailImg {
width: 134px;
height: 110px;
}
}
-
- span{
+
+ span {
width: 100%;
text-align: center;
margin-top: 5px;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
- color: gray;
+ color: gray;
font-size: 14px;
}
- .deleteFile{
+ .deleteFile {
position: absolute;
right: 0;
top: 0;
@@ -468,54 +477,347 @@
font-size: 18px;
display: none;
}
- .btn{
+ .btn {
position: absolute;
height: 30px;
line-height: 30px;
font-size: 14px;
display: none;
}
- .btn1{
+ .btn1 {
top: 37px;
}
- .btn2{
+ .btn2 {
top: 78px;
}
}
- .fileDivBox:hover{
+ .fileDivBox:hover {
border: 1px solid #000;
- .deleteFile{
+ .deleteFile {
display: block;
-
}
- .deleteFile:hover{
+ .deleteFile:hover {
color: red;
}
- .btn{
+ .btn {
display: block;
}
}
}
- .masklayer{
+ .carOne {
+ width: 100%;
+ height: 100%;
+ display: flex;
+ flex-direction: column;
+ //车辆头部
+ .cartopbox {
+ max-height: 200px;
+ box-sizing: border-box;
+ padding: 10px 22px;
+ .add {
+ height: 36px;
+ line-height: 36px;
+ display: flex;
+ justify-content: space-between;
+ margin-bottom: 5px;
+ }
+ .searchbox {
+ display: flex;
+ flex-wrap: wrap;
+ .inputbox {
+ width: 50%;
+ height: 40px;
+ font-size: 14px;
+ line-height: 40px;
+ margin: 5px 0;
+ display: flex;
+ justify-content: flex-end;
+ align-items: center;
+ span {
+ margin-right: 5px;
+ overflow: hidden; /*超出部分隐藏*/
+ white-space: nowrap; /*不换行*/
+ text-overflow: ellipsis; /*超出部分文字以...显示*/
+ }
+ select,
+ input {
+ height: 100%;
+ width: 85%;
+ background-color: #f2f4f6;
+ border: 0;
+ border-radius: 5px;
+ box-sizing: border-box;
+ padding: 0 8px;
+ }
+
+ .shortselect {
+ width: 68.5%;
+ }
+ .searchbtn {
+ margin-left: 20px;
+ }
+ .gray {
+ color: gray;
+ }
+ }
+ }
+ }
+ .carList {
+ flex: 1;
+ overflow-y: auto;
+ box-sizing: border-box;
+ padding: 10px 22px;
+ border: 1px solid #f2f4f6;
+ table {
+ width: 100%;
+ border-spacing: 0px;
+ tr {
+ height: 33px;
+ width: 100%;
+ td:nth-child(1) {
+ width: 46%;
+ }
+ td:nth-child(2) {
+ width: 26%;
+ }
+ td:nth-child(3) {
+ width: 26%;
+ }
+ td:nth-child(4) {
+ width: 2%;
+ display: flex;
+ align-items: center;
+ height: 33px;
+ }
+ td {
+ border: none;
+ .integrity {
+ height: 18px;
+ width: 95%;
+ position: relative;
+ background-color: #f2f4f6;
+ .integrityNum {
+ position: absolute;
+ left: 50%;
+ top: 50%;
+ transform: translate(-50%, -50%);
+ color: black;
+ font-size: 13px;
+ cursor: default;
+ }
+ .integrityColorDiv {
+ height: 100%;
+ }
+ }
+ .deleteFile {
+ cursor: pointer;
+ }
+ }
+ .td1,
+ .td2 {
+ color: #2196f3;
+ }
+ }
+ .caritem:hover {
+ border: 0px;
+ cursor: default;
+ background-color: #d2eafd;
+ }
+ }
+ }
+ .pagingDevice {
+ width: 100%;
+ height: 40px;
+ }
+ }
+ .carTwo {
+ width: 100%;
+ height: 100%;
+ p {
+ margin-bottom: 10px;
+ }
+ .expandP {
+ display: flex;
+ justify-content: space-between;
+ box-sizing: border-box;
+ padding-right: 18px;
+ span {
+ display: flex;
+ align-items: center;
+ }
+ .add {
+ cursor: pointer;
+ img {
+ margin-right: 3px;
+ }
+ }
+ button{
+ background-color: #2196f3;
+ height: 32px;
+ line-height: 32px;
+ color: white;
+ border: 0;
+ border-radius: 4px;
+ cursor: pointer;
+ }
+ }
+ .carTwoItemBox {
+ display: flex;
+ flex-wrap: wrap;
+ div {
+ width: 50%;
+ display: flex;
+ justify-content: flex-end;
+ align-items: center;
+ margin-bottom: 10px;
+ input,
+ select {
+ height: 32px !important;
+ line-height: 32px;
+ width: 75% !important;
+ border: 1px solid #ebebeb;
+ border-radius: 4px;
+ margin-left: 0px;
+ }
+ textarea {
+ width: 75.1%;
+ height: 100px;
+ border-radius: 4px;
+ margin-left: 0px;
+ }
+ .unitDiv {
+ position: relative;
+ width: 75% !important;
+ margin-bottom: 0px;
+ input,
+ select {
+ width: 100% !important;
+ }
+ .unit {
+ position: absolute;
+ right: 13px;
+ top: 4px;
+ color: #000000;
+ opacity: 0.4;
+ }
+ }
+ }
+ .uploadbox {
+ width: 75%;
+ display: flex;
+ justify-content: flex-start;
+ align-items: flex-end;
+ margin-bottom: 0px;
+ position: relative;
+ .img {
+ width: 150px;
+ height: 100px;
+ }
+ .uploadbtn,.uploadinput {
+ width: 110px !important;
+ height: 30px;
+ background: #2196f3;
+ opacity: 1;
+ border-radius: 4px;
+ color: white;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ font-size: 14px;
+ position: absolute;
+ left: 160px;
+ bottom: 0px;
+ z-index: 0;
+ }
+ .uploadinput{
+ display: inline-block;
+ opacity: 0;
+ z-index: 1;
+ }
+ }
+ }
+ .carTwoItemBox2,
+ .carTwoItemBox3 {
+ .item {
+ display: flex;
+ flex-wrap: wrap;
+ div {
+ width: 33%;
+ display: flex;
+ justify-content: flex-end;
+ align-items: center;
+ margin-bottom: 10px;
+ input,
+ select {
+ height: 32px !important;
+ line-height: 32px;
+ width: 70% !important;
+ border: 1px solid #ebebeb;
+ border-radius: 4px;
+ margin-left: 0px;
+ }
+ textarea {
+ width: 75.1%;
+ height: 100px;
+ border-radius: 4px;
+ margin-left: 0px;
+ }
+ .unitDiv {
+ position: relative;
+ width: 70% !important;
+ margin-bottom: 0px;
+ input,
+ select {
+ width: 100% !important;
+ }
+ .unit {
+ position: absolute;
+ right: 13px;
+ top: 4px;
+ color: #000000;
+ opacity: 0.4;
+ }
+ }
+ }
+ .remark {
+ width: 99%;
+ textarea {
+ width: 86.9%;
+ }
+ }
+ .width50 {
+ width: 50%;
+ input,
+ select {
+ width: 80% !important;
+ }
+ .unitDiv {
+ width: 80% !important;
+ }
+ }
+ }
+ }
+ }
+ .masklayer {
position: absolute;
left: 0;
top: 0;
z-index: 2000;
width: 100%;
height: 100%;
- background: rgba(0,0,0,0.2);
+ background: rgba(0, 0, 0, 0.2);
display: flex;
justify-content: center;
align-items: center;
flex-direction: column;
- span{
+ span {
font-size: 14px;
margin-top: 5px;
}
- .progressbar{
+ .progressbar {
width: 15%;
}
- .cancelbtn{
+ .cancelbtn {
height: 32px;
line-height: 32px;
font-size: 14px;
@@ -523,8 +825,8 @@
}
}
}
- .noHeight{
- .tabsbox{
+ .noHeight {
+ .tabsbox {
margin-top: 10px;
}
height: 0px;
@@ -532,34 +834,33 @@
}
}
-
-.addWaterBox{
+.addWaterBox,.addWaterBox {
width: 260px;
- height: 284px;
+ height: 200px;
display: flex;
flex-direction: column;
- .topbox{
+ .topbox {
width: 100%;
height: 40px;
line-height: 40px;
- background-color: #2196F3;
+ background-color: #2196f3;
text-align: center;
- color: #FFFFFF;
+ color: #ffffff;
font-size: 15px;
}
- .contant{
+ .content {
flex: 1;
box-sizing: border-box;
padding: 0 30px;
display: flex;
flex-direction: column;
justify-content: space-around;
- div{
+ div {
width: 100%;
height: 36px;
line-height: 36px;
text-align: center;
- background-color: #F2F4F6;
+ background-color: #f2f4f6;
font-size: 14px;
cursor: pointer;
border: 1px solid #fff;
@@ -567,135 +868,138 @@
display: flex;
justify-content: center;
align-items: center;
- img{
+ img {
margin-right: 3px;
}
}
- .selectedDiv{
- background-color: #2196F3;
+ .selectedDiv {
+ background-color: #2196f3;
color: #fff;
- border: 1px solid #2196F3;
+ border: 1px solid #2196f3;
}
}
- .btnbox{
+ .btnbox {
width: 100%;
height: 50px;
box-sizing: border-box;
padding: 0px 30px;
display: flex;
- align-items: flex-start;;
+ align-items: flex-start;
justify-content: space-between;
- button{
+ button {
width: 80px;
height: 36px;
line-height: 36px;
}
}
}
+.addWaterBox{
+ height: 284px;
+}
-
-@media screen and (max-width:1400px){
- .box{
+@media screen and (max-width: 1400px) {
+ .box {
padding: 5px;
font-size: 14px;
}
- .listbox{
+ .listbox {
width: 310px;
- .contantbox{
- .waterList{
- li{
- .address{
+ .contentbox {
+ .waterList {
+ li {
+ .address {
width: 50%;
}
- .integrity{
+ .integrity {
width: 36%;
}
}
}
}
}
- .mapbox{
- .mapcheckbox{
+ .mapbox {
+ .mapcheckbox {
height: 30px;
line-height: 30px;
}
- #map{
- .gistopbox{
+ #map {
+ .gistopbox {
width: 43%;
}
}
- .detailsbox{
- height:338px;
+ .detailsbox {
+ height: 338px;
transition: height 0.5s;
- .tabsbox{
+ .tabsbox {
// margin-top: 5px;
height: 38px;
line-height: 38px;
- .tabs{
- div{
+ .tabs {
+ div {
width: 90px;
}
}
- .btnbox{
- .uploadAttachment{
+ .btnbox {
+ .uploadAttachment {
margin-right: 12px;
width: 80px;
- button{
- mat-icon{
+ button {
+ mat-icon {
display: none;
}
}
- }
- .state{
- margin-right:12px;
}
- .submitAudit{
- margin-right:12px;
+ .state {
+ margin-right: 12px;
}
- .close{
+ .submitAudit {
+ margin-right: 12px;
+ }
+ .close {
margin-right: 12px;
}
}
}
- .contant{
- height:300px;
-
- p{
+ .content {
+ height: 300px;
+
+ p {
padding-left: 20px;
font-size: 14px;
}
- span{
+ span {
font-size: 14px;
}
- input,select{
+ input,
+ select {
width: 50%;
}
- textarea{
+ textarea {
width: 87%;
}
- .longinput{
+ .longinput {
width: 66%;
}
- .unitDiv{
+ .unitDiv {
width: 50%;
position: relative;
}
- .setPositionBtn{
- width:85px;
+ .setPositionBtn {
+ width: 85px;
text-align: center;
margin-right: 8px;
- mat-icon{
+ mat-icon {
display: none;
}
}
}
}
- .noHeight{
- .tabsbox{
+ .noHeight {
+ .tabsbox {
margin-top: 10px;
}
height: 0px;
transition: height 0.5s;
}
}
-}
\ No newline at end of file
+}
diff --git a/src/app/data-collection/fire-force/fire-force.component.ts b/src/app/data-collection/fire-force/fire-force.component.ts
index 07eff1d..26b8998 100644
--- a/src/app/data-collection/fire-force/fire-force.component.ts
+++ b/src/app/data-collection/fire-force/fire-force.component.ts
@@ -1,6 +1,6 @@
import { FlatTreeControl } from '@angular/cdk/tree';
import { HttpClient } from '@angular/common/http';
-import { Inject, Renderer2 } from '@angular/core';
+import { Inject, Renderer2, ViewChild } from '@angular/core';
import { ElementRef } from '@angular/core';
import { Component, OnInit } from '@angular/core';
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
@@ -12,7 +12,9 @@ import { Console } from 'console';
import { TreeService } from 'src/app/http-interceptors/tree.service';
import Viewer from 'viewerjs'
declare var CryptoJS
-
+import { ObjectsService } from "src/app/services/objects.service";
+import { NzTreeSelectComponent } from 'ng-zorro-antd/tree-select'
+import { DateAdapter } from '@angular/material/core';
@Component({
selector: 'app-fire-force',
templateUrl: './fire-force.component.html',
@@ -20,77 +22,743 @@ declare var CryptoJS
})
export class FireForceComponent implements OnInit {
- constructor(private tree: TreeService,public snackBar: MatSnackBar,private http:HttpClient,private elementRef: ElementRef,public renderer2: Renderer2,public dialog: MatDialog) { }
-
- isCheckedOfSearchDiv:boolean = true//列表过滤滑块
- slideChange(e){
+ @ViewChild('treeCarTypeSelected') treeCarTypeSelected:NzTreeSelectComponent
+ @ViewChild('carDetailsTypeSelected') carDetailsTypeSelected:NzTreeSelectComponent
+
+ constructor(private tree: TreeService, public snackBar: MatSnackBar, private http: HttpClient, private elementRef: ElementRef, public renderer2: Renderer2, public dialog: MatDialog, private objectsSrv: ObjectsService) { }
+
+ isCheckedOfSearchDiv: boolean = true//列表过滤滑块
+ slideChange(e) {
this.isCheckedOfSearchDiv = e.checked
}
- searchForm:any = {
- name:'',
- integrityNum:''
- }
- listIntegrityNum:any[] = [
- {id:-1,name:'全部'},
- {id:0,name:'<=50%'},
- {id:1,name:'50%-60%'},
- {id:2,name:'60%-70%'},
- {id:3,name:'70%-80%'},
- {id:4,name:'80%-90%'},
- {id:5,name:'90%-100%'}
+
+ searchForm: any = {
+ name: '',
+ integrityNum: '',
+ }
+ carSearchForm: any = {
+ name: '',
+ organization: '',
+ carType: '',
+ integrityNum: ''
+ }
+ listIntegrityNum: any[] = [
+ { id: -1, name: '全部' },
+ { id: 0, name: '<=50%' },
+ { id: 1, name: '50%-60%' },
+ { id: 2, name: '60%-70%' },
+ { id: 3, name: '70%-80%' },
+ { id: 4, name: '80%-90%' },
+ { id: 5, name: '90%-100%' }
+ ]
+ checkBoxList: any[] = [
+ { id: 0, name: '总队', isChecked: false },
+ { id: 1, name: '支队', isChecked: false },
+ { id: 2, name: '大队', isChecked: false },
+ { id: 3, name: '中队(消防站)', isChecked: false },
+ { id: 4, name: '其他消防队伍', isChecked: false }
+ ]
+ isCarCheckedOfSearchDiv: boolean = true//车辆列表过滤滑块
+ carslideChange(e) {
+ this.isCarCheckedOfSearchDiv = e.checked
+ }
+ carsList: any = [
+
+ ]
+
+ //分页事件
+ carListChagePage(e) {
+ this.carListPageNumber = e.pageIndex + 1
+ // this.getAllWaterData()
+ }
+ carDataLength: any //获取的数据一共多少条
+ carListPageNumber: any = 1 //当前第几页
+ getCarList() {
+ let MinIntegrity = 0
+ let MaxIntegrity = 1.1
+ if (this.searchForm.integrityNum == '0') {
+ MinIntegrity = 0
+ MaxIntegrity = 0.5
+ } else if (this.searchForm.integrityNum == '1') {
+ MinIntegrity = 0.5
+ MaxIntegrity = 0.6
+ } else if (this.searchForm.integrityNum == '2') {
+ MinIntegrity = 0.6
+ MaxIntegrity = 0.7
+ } else if (this.searchForm.integrityNum == '3') {
+ MinIntegrity = 0.7
+ MaxIntegrity = 0.8
+ } else if (this.searchForm.integrityNum == '4') {
+ MinIntegrity = 0.8
+ MaxIntegrity = 0.9
+ } else if (this.searchForm.integrityNum == '5') {
+ MinIntegrity = 0.9
+ MaxIntegrity = 1.1
+ } else if (this.searchForm.integrityNum == '-1') {
+ MinIntegrity = 0
+ MaxIntegrity = 1.1
+ }
+ let params: any = {
+ Keyword: this.carSearchForm.name || '',
+ OrganizationId: this.carSearchForm.organization || '',
+ Category: this.treeCarTypeSelected && this.treeCarTypeSelected.getSelectedNodeList().length!=0 ? this.treeCarTypeSelected.getSelectedNodeList()[0].origin.title : '',
+ MinIntegrity: MinIntegrity,
+ MaxIntegrity: MaxIntegrity,
+ PageSize: 16,
+ PageNumber: this.carListPageNumber
+ }
+ console.log(params)
+ // console.log(this.treeCarTypeSelected.getSelectedNodeList()[0].origin.title)
+ this.http.get('/api/FireFightingVehicles', { params: params }).subscribe((data: any) => {
+ console.log('车辆列表', data)
+ this.carDataLength = data.totalCount
+ this.carsList = data.items
+ })
+ }
+ //重置车辆列表
+ resetCarList() {
+ this.carSearchForm = {
+ name: '',
+ organization: this.selectedFireForceId,
+ carType: '',
+ integrityNum: ''
+ }
+ this.getCarList()
+ }
+ addFireForceCar() {
+ let data = {
+ organization: this.selectedFireForceId
+ }
+ const dialogRef = this.dialog.open(AddFireForceCar, {
+ data: data,
+ id: 'addCar'
+ });
+ dialogRef.afterClosed().subscribe(
+ data => {
+ this.resetCarList()
+ this.getCarList()
+ }
+ );
+ }
+ //删除车辆
+ deleteCar(item, e) {
+ e.stopPropagation()
+ let isDelete = window.confirm(`确定要删除${item.name}车辆吗?`)
+ if (isDelete) {
+ this.http.delete(`/api/FireFightingVehicles/${item.id}`).subscribe(data => {
+ let config = new MatSnackBarConfig();
+ config.verticalPosition = 'top';
+ config.duration = 3000
+ this.snackBar.open('删除成功', '确定', config);
+ this.getCarList()
+ })
+ }
+
+ }
+ //进入车辆详情页
+ carPageIndex: number = 0
+ carDetailsId: string
+ carDetailsData: any
+ openCarDetails(item) {
+ console.log(item)
+ this.carPageIndex = 1
+ this.carDetailsId = item.id
+ this.carDetailsData = item
+ //消防器材
+ item.equipmentData ? this.carData.fireEquipment = JSON.parse(item.equipmentData) : this.carData.fireEquipment.data[0].equipmentOr = item.organizationId
+ //灭火剂
+ item.extinguishingAgentData ? this.carData.carExtinguishant = JSON.parse(item.extinguishingAgentData) : this.carData.carExtinguishant.data[0].extinguishantOr = item.organizationId
+ //作战用行动
+ item.combatInformationData ? this.carData.fightInfo = JSON.parse(item.combatInformationData) : null
+
+ this.carData.basicInfo.carName = item.name
+ this.carData.basicInfo.carOrganization = item.organizationId
+ this.carData.basicInfo.carNumber = item.registrationNumber
+
+ for (let index = 0; index < this.carTypeList.length; index++) {
+ const element = this.carTypeList[index];
+ if(element.title == item.category){
+ this.carData.basicInfo.carType = element.key
+ return
+ }
+ if(element.children && element.children.length != 0){
+ for (let i = 0; i < element.children.length; i++) {
+ const item = element.children[i];
+ if(item.title == item.category){
+ this.carData.basicInfo.carType = item.key
+ return
+ }
+ }
+ }
+ }
+ }
+ //返回车辆列表页
+ goback() {
+ this.carPageIndex = 0
+ this.clearCarDetails()
+ }
+ //重置车辆详情
+ clearCarDetails() {
+ this.carData = {
+ basicInfo: {
+ carType: '',//车辆类别
+ carName: '',
+ carNumber: '',
+ carOrganization: ''
+ },
+ fightInfo: {
+ pumpFlow: '',//水泵流量
+ fireGunFlow: '',//消防炮流量
+ pumpPressure: '',//水泵额定压力
+ waterCapacity: '',//载水量
+ carHeight: '',//车辆高度
+ carState: '',//车辆状态
+ remark: '',//备注
+ carPhoto: []//车辆照片
+ },
+ carExtinguishant: {//车载灭火剂
+ isExpand: null,
+ data: [
+ {
+ extinguishantType: '',//灭火剂类型
+ extinguishantName: '',//灭火剂名称
+ extinguishantOr: '',//所属队站
+ mixingRatio: '',//混合比
+ capacity: '',//车载量
+ manufacturer: '',//成产厂家
+ remark: ''//备注
+ }
+ ]
+ },
+ fireEquipment: {//消防器材
+ isExpand: null,
+ data: [
+ {
+ equipmentType: '',//器材类别
+ equipmentName: '',//器材名称
+ equipmentOr: '',//所属队站
+ capacity: '',//车载量
+ manufacturer: '',//成产厂家
+ remark: ''//备注
+ }
+ ]
+ }
+ }
+ }
+ //消防车类型
+ carTypeList: any = [
+ {
+ title: '灭火类消防车',
+ key: '1',
+ children: [
+ { title: '水罐车', key: '11', isLeaf: true },
+ { title: '泡沫车', key: '12', isLeaf: true },
+ { title: '高倍数泡沫车', key: '13', isLeaf: true },
+ { title: '干粉车', key: '14', isLeaf: true },
+ { title: '干粉泡沫联用车', key: '15', isLeaf: true },
+ { title: '干粉水联用车', key: '16', isLeaf: true },
+ { title: '干粉二氧化碳联用车', key: '17', isLeaf: true },
+ { title: '涡喷车', key: '18', isLeaf: true },
+ { title: '液氮车', key: '19', isLeaf: true },
+ { title: '二氧化碳车', key: '110', isLeaf: true },
+ { title: '其他灭火消防车', key: '111', isLeaf: true }
+ ]
+ },
+ {
+ title: '举高类消防车',
+ key: '2',
+ children: [
+ { title: '高喷车', key: '21', isLeaf: true },
+ { title: '曲臂登高车', key: '22', isLeaf: true },
+ { title: '直臂登高车', key: '23', isLeaf: true },
+ { title: '其他举高消防车', key: '24', isLeaf: true }
+ ]
+ },
+ {
+ title: '专勤类消防车',
+ key: '3',
+ children: [
+ { title: '抢险救援车', key: '31', isLeaf: true },
+ { title: '侦检车', key: '32', isLeaf: true },
+ { title: '勘察车', key: '33', isLeaf: true },
+ { title: '排烟车', key: '34', isLeaf: true },
+ { title: '照明车', key: '35', isLeaf: true },
+ { title: '宣传车', key: '36', isLeaf: true },
+ { title: '排烟照明车', key: '37', isLeaf: true },
+ { title: '通信指挥车', key: '38', isLeaf: true },
+ { title: '有毒气体处置车', key: '39', isLeaf: true },
+ { title: '防化消防车', key: '310', isLeaf: true },
+ { title: '挖掘车', key: '311', isLeaf: true },
+ { title: '铲车', key: '312', isLeaf: true },
+ { title: '破拆车', key: '313', isLeaf: true },
+ { title: '其他专勤消防车', key: '314', isLeaf: true }
+ ]
+ },
+ {
+ title: '后援类消防车',
+ key: '4',
+ children: [
+ { title: '饮食保障车', key: '41', isLeaf: true },
+ { title: '卫勤保障车', key: '42', isLeaf: true },
+ { title: '排障车', key: '43', isLeaf: true },
+ { title: '装备抢修车', key: '44', isLeaf: true },
+ { title: '拖车车', key: '45', isLeaf: true },
+ { title: '运兵车', key: '46', isLeaf: true },
+ { title: '运输车', key: '47', isLeaf: true },
+ { title: '运渣车', key: '48', isLeaf: true },
+ { title: '吊车', key: '49', isLeaf: true },
+ { title: '移动供气车', key: '410', isLeaf: true },
+ { title: '移动供液车', key: '411', isLeaf: true },
+ { title: '油料供给车', key: '412', isLeaf: true },
+ { title: '远程供水车(水泵)', key: '413', isLeaf: true },
+ { title: '远程供水车(水带铺设)', key: '414', isLeaf: true },
+ { title: '宿营车', key: '415', isLeaf: true },
+ { title: '发电车', key: '416', isLeaf: true },
+ { title: '淋浴车', key: '417', isLeaf: true },
+ { title: '其他后援消防车', key: '418', isLeaf: true }
+ ]
+ },
+ {
+ title: '机场消防车',
+ key: '5',
+ children: [
+ { title: '机场快速调动消防车', key: '51', isLeaf: true },
+ { title: '机场主力泡沫消防车', key: '52', isLeaf: true },
+ { title: '其他机场消防车', key: '53', isLeaf: true },
+ { title: '防爆消防车', key: '54', isLeaf: true },
+ { title: '轨道消防车(GD)', key: '55', isLeaf: true }
+ ]
+ },
+ {
+ title: '消防摩托车',
+ key: '6',
+ children: [
+ { title: '灭火消防摩托车', key: '61', isLeaf: true },
+ { title: '抢险救援摩托车', key: '62', isLeaf: true },
+ { title: '其他消防摩托车', key: '63', isLeaf: true }
+ ]
+ },
+ {
+ title: '联动类车辆',
+ key: '7',
+ children: [
+ { title: '急救车', key: '71', isLeaf: true },
+ { title: '警用指挥车', key: '72', isLeaf: true },
+ { title: '警用巡逻车', key: '73', isLeaf: true },
+ { title: '警用摩托车', key: '74', isLeaf: true },
+ { title: '电力抢修车', key: '75', isLeaf: true },
+ { title: '水力抢修车', key: '76', isLeaf: true },
+ { title: '燃气抢修车', key: '77', isLeaf: true },
+ { title: '特种工程车', key: '78', isLeaf: true },
+ { title: '环保监测车', key: '79', isLeaf: true },
+ { title: '其他联动车辆', key: '710', isLeaf: true }
+ ]
+ },
+ {
+ title: '其他消防车辆',
+ key: '8',
+ isLeaf: true
+ }
+
]
- checkBoxList:any[] = [
- {id:0,name:'总队',isChecked:false},
- {id:1,name:'支队',isChecked:false},
- {id:2,name:'大队',isChecked:false},
- {id:3,name:'中队(消防站)',isChecked:false},
- {id:4,name:'其他消防队伍',isChecked:false}
+ //灭火剂分类
+ extinguishantTypeList: any = [
+ {
+ key: '1',
+ title: '泡沫灭火剂',
+ children: [
+ {
+ key: '1-1',
+ title: '蛋白类泡沫灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '1-2',
+ title: '合成类泡沫灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '1-3',
+ title: '压缩空气泡沫灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '1-4',
+ title: '化学泡沫灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '1-5',
+ title: '其他类泡沫灭火剂',
+ isLeaf: true
+ }
+ ]
+ },
+ {
+ key: '2',
+ title: '水泵灭火剂',
+ children: [
+ {
+ key: '2-1',
+ title: '强化水',
+ isLeaf: true
+ },
+ {
+ key: '2-2',
+ title: '乳化水',
+ isLeaf: true
+ },
+ {
+ key: '2-3',
+ title: '润湿水',
+ isLeaf: true
+ },
+ {
+ key: '2-4',
+ title: '粘性水',
+ isLeaf: true
+ },
+ {
+ key: '2-5',
+ title: 'SD系列水泵灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '2-6',
+ title: '微胞囊类水泵灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '2-7',
+ title: '其他水泵灭火剂',
+ isLeaf: true
+ }
+ ]
+ },
+ {
+ key: '3',
+ title: '干粉灭火剂',
+ children: [
+ {
+ key: '3-1',
+ title: '普通干粉灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '3-2',
+ title: '超细干粉灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '3-3',
+ title: '金属火灾干粉灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '3-4',
+ title: '其他干粉灭火剂',
+ isLeaf: true
+ }
+ ]
+ },
+ {
+ key: '4',
+ title: '气体灭火剂',
+ children: [
+ {
+ key: '4-1',
+ title: '卤代烷烃灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '4-2',
+ title: '二氧化碳灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '4-3',
+ title: '惰性气体灭火剂',
+ isLeaf: true
+ },
+ {
+ key: '4-4',
+ title: '其他气体灭火剂',
+ isLeaf: true
+ }
+ ]
+ },
+ {
+ key: '5',
+ title: '其他灭火剂',
+ children: [
+ {
+ key: '5-1',
+ title: '液氮', isLeaf: true
+ },
+ {
+ key: '5-2',
+ title: '火碱',
+ isLeaf: true
+ },
+ {
+ key: '5-3',
+ title: '其他灭火剂',
+ isLeaf: true
+ }
+ ]
+ }
]
+ //消防器材分类
+ fireEquipmentTypeList: any = [
+ {
+ key: '1',
+ title: '消防人员防护装备',
+ isLeaf: true
+ },
+ {
+ key: '2',
+ title: '灭火器材装备',
+ isLeaf: true
+ },
+ {
+ key: '3',
+ title: '抢险救援装备',
+ isLeaf: true
+ },
+ {
+ key: '4',
+ title: '消防通讯指挥装备',
+ isLeaf: true
+ },
+ {
+ key: '5',
+ title: '特种消防装备',
+ isLeaf: true
+ },
+ {
+ key: '6',
+ title: '防火检查与火灾调查装备',
+ isLeaf: true
+ },
+ {
+ key: '7',
+ title: '其他类消防装备器材',
+ isLeaf: true
+ }
+ ]
+ expandOrKeys = [];
+ expandCarTypeKeys = [];
+
+ onChangeCarType($event: string): void {
+ console.log(this.treeCarTypeSelected.getSelectedNodeList()[0].origin.title);
+ }
+ carDetailsTypeChange($event: string): void {
+ console.log(this.carDetailsTypeSelected.getSelectedNodeList()[0].origin.title);
+ }
+ onChange($event: string): void {
+
+ }
+ searchCarList() {
+ this.getCarList()
+ }
+ //车辆详细信息
+ carData: any = {
+ basicInfo: {
+ carType: '',//车辆类别
+ carName: '',
+ carNumber: '',
+ carOrganization: ''
+ },
+ fightInfo: {
+ pumpFlow: '',//水泵流量
+ fireGunFlow: '',//消防炮流量
+ pumpPressure: '',//水泵额定压力
+ waterCapacity: '',//载水量
+ carHeight: '',//车辆高度
+ carState: '',//车辆状态
+ remark: '',//备注
+ carPhoto: []//车辆照片
+ },
+ carExtinguishant: {//车载灭火剂
+ isExpand: null,
+ data: [
+ {
+ extinguishantType: '',//灭火剂类型
+ extinguishantName: '',//灭火剂名称
+ extinguishantOr: '',//所属队站
+ mixingRatio: '',//混合比
+ capacity: '',//车载量
+ manufacturer: '',//成产厂家
+ remark: ''//备注
+ }
+ ]
+ },
+ fireEquipment: {//消防器材
+ isExpand: null,
+ data: [
+ {
+ equipmentType: '',//器材类别
+ equipmentName: '',//器材名称
+ equipmentOr: '',//所属队站
+ capacity: '',//车载量
+ manufacturer: '',//成产厂家
+ remark: ''//备注
+ }
+ ]
+ }
+ }
+ //车辆详情新增按钮
+ addCarDetailsItem(type) {
+ if (type == 'carExtinguishant') {
+ this.carData.carExtinguishant.data.push({
+ extinguishantType: '',//灭火剂类型
+ extinguishantName: '',//灭火剂名称
+ extinguishantOr: this.carDetailsData.organizationId,//所属队站
+ mixingRatio: '',//混合比
+ capacity: '',//车载量
+ manufacturer: '',//成产厂家
+ remark: ''//备注
+ })
+ } else if (type == 'fireEquipment') {
+ this.carData.fireEquipment.data.push({
+ equipmentType: '',//器材类别
+ equipmentName: '',//器材名称
+ equipmentOr: this.carDetailsData.organizationId,//所属队站
+ capacity: '',//车载量
+ manufacturer: '',//成产厂家
+ remark: ''//备注
+ })
+ }
+ }
+ deleteCarDetailsItem(arr, index) {
+ let isDelete = window.confirm('确定要删除该分组吗?')
+ if (isDelete) {
+ arr.splice(index, 1)
+ }
+ }
+ //上传车辆照片
+ uploadCarImg(e) {
+ // this.file = e.target.files[0] || null //上传的文件
+ let file = e.target.files[0] || null //获取上传的文件
+ this.openFileSelect(file, 'FireForce/car/' + this.carDetailsId)
+ }
+ //设置文件路径并上传
+ postFilePath
+ openFileSelect(file: File, extensionPath: string) {
+ this.postFilePath = extensionPath;
+ let fileSize = file.size || null //上传文件的总大小
+ let shardSize = 5 * 1024 * 1024 //5MB 超过5MB要分块上传
+ if (fileSize >= shardSize) // 超过5MB要分块上传
+ {
+ this.postFileByMul(file);
+ }
+ else //普通上传
+ {
+ this.postFile(file);
+ }
+ }
+
+ //上传文件
+ async postFile(file: File) {
+ await new Promise((resolve, reject) => {
+ this.objectsSrv.postFile(this.postFilePath, file).subscribe(data => {
+ let dataObj = data as any;
+ let filePath: string = ObjectsService.baseUrl + dataObj.objectName;
+ this.carData.fightInfo.carPhoto[0] = filePath
+ resolve('success')
+ });
+ })
+ }
+
+ /**
+ * 分块上传
+ * @param file
+ */
+ postFileByMul(file: File) {
+ this.objectsSrv.postFile_MultipartUpload(this.postFilePath, file).then((value) => {
+ let dataObj = value as any;
+ this.carData.fightInfo.carPhoto[0] = dataObj.filePath
+ });
+
+ }
+
+ //保存车辆信息
+ saveCarData(invalid) {
+ console.log(invalid)
+ if (invalid) {
+ let config = new MatSnackBarConfig();
+ config.verticalPosition = 'top';
+ config.duration = 3000
+ this.snackBar.open('还有必填项未填写!', '确定', config);
+ } else {
+
+
+ this.carDetailsData.category = this.carDetailsTypeSelected.getSelectedNodeList()[0].origin.title
+ this.carDetailsData.name = this.carData.basicInfo.carName
+ this.carDetailsData.registrationNumber = this.carData.basicInfo.carNumber
+ this.carDetailsData.organizationId = this.carData.basicInfo.carOrganization
+
+ this.carDetailsData.combatInformationData = JSON.stringify(this.carData.fightInfo)
+ this.carDetailsData.equipmentData = JSON.stringify(this.carData.fireEquipment)
+ this.carDetailsData.extinguishingAgentData = JSON.stringify(this.carData.carExtinguishant)
+
+ this.carDetailsData.updatedTime = new Date()
+
+ console.log('putbody',this.carDetailsData)
+ this.http.put(`/api/FireFightingVehicles/${this.carDetailsData.id}`,this.carDetailsData).subscribe(data=>{
+ let config = new MatSnackBarConfig();
+ config.verticalPosition = 'top';
+ config.duration = 3000
+ this.snackBar.open('保存成功', '确定', config);
+ })
+ }
+ }
+
//勾选力量类型checkbox在地图上显示marker
- checkBoxChange(){
+ checkBoxChange() {
let Levels = []
- this.checkBoxList.forEach(item =>{
- if(item.isChecked){
+ this.checkBoxList.forEach(item => {
+ if (item.isChecked) {
Levels.push(item.id)
}
})
- let params:any = {
- PageSize : 999999,
- Levels:Levels
+ let params: any = {
+ PageSize: 999999,
+ Levels: Levels
}
- if(Levels.length != 0){//如果勾选了checkbox
- this.http.get('/api/CustomFireForce',{params:params}).subscribe((data:any) => {
+ if (Levels.length != 0) {//如果勾选了checkbox
+ this.http.get('/api/CustomFireForce', { params: params }).subscribe((data: any) => {
this.createMarker(data)
})
- }else{
+ } else {
this.cluster.setData([])
}
}
//循环渲染出所有力量markers
- cluster:IMarkerCluster //力量聚合实例
- createMarker(list){
+ cluster: IMarkerCluster //力量聚合实例
+ createMarker(list) {
let markerArrcluster = []
this.cluster ? this.cluster.setData([]) : null
list.forEach((item) => {
let image
- if(item.forceType == 2){
+ if (item.forceType == 2) {
image = '/assets/fireForcesMarkers/qita.png'
- }else if(item.level == 0){
+ } else if (item.level == 0) {
image = '/assets/fireForcesMarkers/zongdui.png'
- }else if(item.level == 1){
+ } else if (item.level == 1) {
image = '/assets/fireForcesMarkers/zhidui.png'
- }else if(item.level == 2){
+ } else if (item.level == 2) {
image = '/assets/fireForcesMarkers/dadui.png'
- }else if(item.level == 3){
+ } else if (item.level == 3) {
image = '/assets/fireForcesMarkers/zhongdui.png'
}
// 用于点集合的数组
- item.fireForceDetailInfo.location ?
- markerArrcluster.push({
- lnglat : [item.fireForceDetailInfo.location.x,item.fireForceDetailInfo.location.y],
- image : image,
- data : item
- }) : null
+ item.fireForceDetailInfo.location ?
+ markerArrcluster.push({
+ lnglat: [item.fireForceDetailInfo.location.x, item.fireForceDetailInfo.location.y],
+ image: image,
+ data: item
+ }) : null
})
var gridSize = 60
@@ -98,167 +766,185 @@ export class FireForceComponent implements OnInit {
let render = MapFactory.RenderClusterMarkerInstance();
render.contentRender = (contextCount) => {
- var factor = Math.pow(contextCount / count, 1 / 18);
- var div = document.createElement('div');
- var Hue = 180 - factor * 180;
- var bgColor = 'hsla(' + Hue + ',100%,40%,0.7)';
- var fontColor = 'hsla(' + Hue + ',100%,90%,1)';
- var borderColor = 'hsla(' + Hue + ',100%,40%,1)';
- var shadowColor = 'hsla(' + Hue + ',100%,90%,1)';
- div.style.backgroundColor = bgColor;
- var size = Math.round(30 + Math.pow(contextCount / count, 1 / 5) * 20);
- div.style.width = div.style.height = size + 'px';
- div.style.border = 'solid 1px ' + borderColor;
- div.style.borderRadius = size / 2 + 'px';
- div.style.boxShadow = '0 0 5px ' + shadowColor;
- div.innerHTML = contextCount;
- div.style.lineHeight = size + 'px';
- div.style.color = fontColor;
- div.style.fontSize = '14px';
- div.style.textAlign = 'center';
- return div;
+ var factor = Math.pow(contextCount / count, 1 / 18);
+ var div = document.createElement('div');
+ var Hue = 180 - factor * 180;
+ var bgColor = 'hsla(' + Hue + ',100%,40%,0.7)';
+ var fontColor = 'hsla(' + Hue + ',100%,90%,1)';
+ var borderColor = 'hsla(' + Hue + ',100%,40%,1)';
+ var shadowColor = 'hsla(' + Hue + ',100%,90%,1)';
+ div.style.backgroundColor = bgColor;
+ var size = Math.round(30 + Math.pow(contextCount / count, 1 / 5) * 20);
+ div.style.width = div.style.height = size + 'px';
+ div.style.border = 'solid 1px ' + borderColor;
+ div.style.borderRadius = size / 2 + 'px';
+ div.style.boxShadow = '0 0 5px ' + shadowColor;
+ div.innerHTML = contextCount;
+ div.style.lineHeight = size + 'px';
+ div.style.color = fontColor;
+ div.style.fontSize = '14px';
+ div.style.textAlign = 'center';
+ return div;
};
render.pixelRender = (contextCount) => {
- var size = Math.round(30 + Math.pow(contextCount / count, 1 / 5) * 20);
- return MapFactory.PixelInstance(-size / 2, -size / 2);
+ var size = Math.round(30 + Math.pow(contextCount / count, 1 / 5) * 20);
+ return MapFactory.PixelInstance(-size / 2, -size / 2);
};
render.contentNonRender = (src) => {
- return `
`;
+ return `
`;
};
render.pixelNonRender = () => {
- return MapFactory.PixelInstance(-15, -15);
+ return MapFactory.PixelInstance(-15, -15);
}
this.cluster = MapFactory.MarkerClusterInstance(this.map, markerArrcluster, {
gridSize: gridSize, // 设置网格像素大小
render: render //自定义聚合点样式, 自定义非聚合点样式
});
- this.cluster.on('click',(e)=>{
- if(e.clusterData.length == 1){
+ this.cluster.on('click', (e) => {
+ if (e.clusterData.length == 1) {
let node = e.clusterData[0].data
// console.log(node)
this.clearData()
this.selectedFireForce = node.fireForceDetailInfo
this.selectedFireForceId = node.fireForceDetailId
- if(node.forceType != 0){//如果是其他消防力量
+ if (node.forceType != 0) {//如果是其他消防力量
this.selectedFireForceLevel = 4
- }else{
+ } else {
this.selectedFireForceLevel = node.level
}
this.FireForceDetailInfo.stationName = node.fireForceDetailInfo.name
- if(node.fireForceDetailId){
+ if (node.fireForceDetailId) {
let type
- if(node.forceType == 0){
+ if (node.forceType == 0) {
type = 0
- }else{
+ } else {
type = 1
}
this.isMasklayer = true
- this.http.get(`/api/FireForceDetail/${type}/${node.id}`).subscribe((data:any) => {
+ this.http.get(`/api/FireForceDetail/${type}/${node.id}`).subscribe((data: any) => {
this.isMasklayer = false
this.FireForceDetailInfo = data
- if(data.location && data.location.x){//如果已经标注单位坐标
+ if (data.location && data.location.x) {//如果已经标注单位坐标
this.positionLngLat = data.location
}
//相关资料
data.relevantInfomationData ? this.AttachmentArr = JSON.parse(data.relevantInfomationData) : null
- if(node.forceType == 0 && node.level == 0){
+ if (node.forceType == 0 && node.level == 0) {
this.ZongpersonCountData = JSON.parse(data.personCountData) || this.ZongpersonCountData
this.ZongcontactData = JSON.parse(data.contactData) || this.ZongcontactData
}
- if(node.forceType == 0 && node.level == 1){
+ if (node.forceType == 0 && node.level == 1) {
this.ZongpersonCountData = JSON.parse(data.personCountData) || this.ZongpersonCountData
this.ZhicontactData = JSON.parse(data.contactData) || this.ZhicontactData
}
- if(node.forceType == 0 && (node.level == 2 || node.level == 3)){
- this.DaZhongpersonCountData = JSON.parse(data.personCountData) || this.DaZhongpersonCountData
+ if (node.forceType == 0 && (node.level == 2 || node.level == 3)) {
+ this.DaZhongpersonCountData = JSON.parse(data.personCountData) || this.DaZhongpersonCountData
this.DaZhongcontactData = JSON.parse(data.contactData) || this.DaZhongcontactData
}
- if(node.forceType != 0){
+ if (node.forceType != 0) {
this.otherpersonCountData = JSON.parse(data.personCountData) || this.otherpersonCountData
this.othercontactData = JSON.parse(data.contactData) || this.otherpersonCountData
}
})
-
+
}
//寻找管辖单位
this.allFireForceList.forEach(item => {
- if(item.id == node.parentId){
+ if (item.id == node.parentId) {
this.superior.name = item.name
this.superior.code = item.code
}
})
}
- },this)
+ }, this)
}
- ngOnInit(): void {
+ ngOnInit(): void {
this.getAllFireForce()
+ this.getAllFireForce2()
setTimeout(() => {
this.createMap()
}, 0);
}
//获得所有消防力量
- newdata:any
- allFireForceList:any= []
- getAllFireForce(){
+ newdata: any
+ allFireForceList: any = []
+ getAllFireForce() {
let MinIntegrity = 0
let MaxIntegrity = 1.1
- if(this.searchForm.integrityNum == '0'){
+ if (this.searchForm.integrityNum == '0') {
MinIntegrity = 0
MaxIntegrity = 0.5
- }else if(this.searchForm.integrityNum == '1'){
+ } else if (this.searchForm.integrityNum == '1') {
MinIntegrity = 0.5
MaxIntegrity = 0.6
- }else if(this.searchForm.integrityNum == '2'){
+ } else if (this.searchForm.integrityNum == '2') {
MinIntegrity = 0.6
MaxIntegrity = 0.7
- }else if(this.searchForm.integrityNum == '3'){
+ } else if (this.searchForm.integrityNum == '3') {
MinIntegrity = 0.7
MaxIntegrity = 0.8
- }else if(this.searchForm.integrityNum == '4'){
+ } else if (this.searchForm.integrityNum == '4') {
MinIntegrity = 0.8
MaxIntegrity = 0.9
- }else if(this.searchForm.integrityNum == '5'){
+ } else if (this.searchForm.integrityNum == '5') {
MinIntegrity = 0.9
MaxIntegrity = 1.1
- }else if(this.searchForm.integrityNum == '-1'){
+ } else if (this.searchForm.integrityNum == '-1') {
MinIntegrity = 0
MaxIntegrity = 1.1
}
- let params:any = {
- Keyword : this.searchForm.name ? this.searchForm.name : '',
- MinIntegrity : MinIntegrity,
- MaxIntegrity : MaxIntegrity
+ let params: any = {
+ Keyword: this.searchForm.name ? this.searchForm.name : '',
+ MinIntegrity: MinIntegrity,
+ MaxIntegrity: MaxIntegrity
}
- this.http.get('/api/CustomFireForce',{params:params}).subscribe((data:any) => {
+ this.http.get('/api/CustomFireForce', { params: params }).subscribe((data: any) => {
this.allFireForceList = data
- this.dataSource.data = this.tree.toTree(data)
+ this.dataSource.data = this.tree.toTree(data)
this.treeControl.expand(this.treeControl.dataNodes[0]);
})
}
- upDateAllFireForce = ():void=>{
- this.http.get('/api/CustomFireForce').subscribe((data:any) => {
- this.newdata = this.tree.toTree(data)
- const nodes = this.treeControl.dataNodes;
- const expandNodes = [];
- nodes.forEach((item) => {
- if(item.expandable && this.treeControl.isExpanded(item)){
- expandNodes.push(item.id);
+ //获得当前点击队站的组织机构
+ clickOrganizationTree: any
+ getAllFireForce2() {
+ this.http.get('/api/CustomFireForce').subscribe((data: any) => {
+ this.clickOrganizationTree = data
+ this.clickOrganizationTree.forEach(item => {
+ item.children = []
+ item.title = item.name
+ item.key = item.id
+ this.clickOrganizationTree.forEach(element => {
+ if (element.parentId == item.id) {
+ item.children.push(element)
}
});
- this.dataSource.data = this.newdata;
- let newNodes = this.treeControl.dataNodes;
- newNodes = newNodes.filter(n => {
- return expandNodes.indexOf(n.id) >= 0;
- });
- newNodes.forEach(item => {
- this.treeControl.expand(item);
- });
- })
+ });
+ })
+ }
+ upDateAllFireForce = (): void => {
+ this.http.get('/api/CustomFireForce').subscribe((data: any) => {
+ this.newdata = this.tree.toTree(data)
+ const nodes = this.treeControl.dataNodes;
+ const expandNodes = [];
+ nodes.forEach((item) => {
+ if (item.expandable && this.treeControl.isExpanded(item)) {
+ expandNodes.push(item.id);
+ }
+ });
+ this.dataSource.data = this.newdata;
+ let newNodes = this.treeControl.dataNodes;
+ newNodes = newNodes.filter(n => {
+ return expandNodes.indexOf(n.id) >= 0;
+ });
+ newNodes.forEach(item => {
+ this.treeControl.expand(item);
+ });
+ })
}
private _transformer = (node, level: number) => {//要给渲染节点传那些属性参数
return {
@@ -267,70 +953,78 @@ export class FireForceComponent implements OnInit {
level: level,
id: node.id,
parentId: node.parentId,
- enabled:node.enabled,
- order:node.order,
- children:node.children,
- code:node.code,
- division:node.division,
- fireForceDetailId:node.fireForceDetailId,
- forceType:node.forceType,
- fireForceDetailInfo:node.fireForceDetailInfo,
- contentVerify:node.contentVerify,
+ enabled: node.enabled,
+ order: node.order,
+ children: node.children,
+ code: node.code,
+ division: node.division,
+ fireForceDetailId: node.fireForceDetailId,
+ forceType: node.forceType,
+ fireForceDetailInfo: node.fireForceDetailInfo,
+ contentVerify: node.contentVerify,
};
}
treeControl = new FlatTreeControl
(node => node.level, node => node.expandable);
treeFlattener = new MatTreeFlattener(this._transformer, node => node.level, node => node.expandable, node => node.children);
dataSource = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);
hasChild = (_: number, node: any) => node.expandable;
- selectedFireForceId:any
- selectedFireForceLevel:any
- selectedFireForce:any
+ selectedFireForceId: any
+ selectedFireForceLevel: any
+ selectedFireForce: any
//选择要显示的消防力量
- superior:any = { //上级单位
- name:'',
- code:''
+ superior: any = { //上级单位
+ name: '',
+ code: ''
}
- selectTreeNode(node){
- // console.log(node)
+ selectOrganizationTree: any = []
+ selectTreeNode(node) {
+ console.log(111222,node)
this.isGisTopBox = false
- if(this.selectedFireForceId != node.id){
+ if (this.selectedFireForceId != node.id) {
+
this.clearData()
+
+ this.carPageIndex = 0//回到车辆列表页
this.selectedFireForce = node
this.selectedFireForceId = node.id
- if(node.forceType != 0){//如果是其他消防力量
+
+ this.resetCarList()
+ this.clearCarDetails()
+ this.getCarList()
+ if (node.forceType != 0) {//如果是其他消防力量
this.selectedFireForceLevel = 4
- }else{
+ } else {
this.selectedFireForceLevel = node.level
}
this.FireForceDetailInfo.stationName = node.name
- if(this.newPositionMarker){
+ if (this.newPositionMarker) {
this.map.remove(this.newPositionMarker);
}
- if(node.fireForceDetailId){
+ if (node.fireForceDetailId) {
this.isPost = false//是否走post创建接口
let type
- if(node.forceType == 0){
+ if (node.forceType == 0) {
type = 0
- }else{
+ } else {
type = 1
}
this.isMasklayer = true
- this.http.get(`/api/FireForceDetail/${type}/${node.id}`).subscribe((data:any) => {
+ this.http.get(`/api/FireForceDetail/${type}/${node.id}`).subscribe((data: any) => {
this.isMasklayer = false
this.FireForceDetailInfo = data
// console.log(888,data)
- if(data.location && data.location.x){//如果已经标注单位坐标
+ if (data.location && data.location.x) {//如果已经标注单位坐标
this.positionLngLat = data.location
- this.map.setCenter([data.location.x,data.location.y]);
+ this.map.setCenter([data.location.x, data.location.y]);
this.newPositionMarker = MapFactory.MarkerInstance({
- position: [data.location.x,data.location.y],
+ position: [data.location.x, data.location.y],
content: this.newPositionMarkerContent,
offset: MapFactory.PixelInstance(-15, -18)
})
// 将 markers 添加到地图
this.map.add(this.newPositionMarker);
- }else{
+ } else {
this.map.setCity('上海市');
}
//相关资料
@@ -351,82 +1045,92 @@ export class FireForceComponent implements OnInit {
if (node.forceType != 0) {
this.otherpersonCountData = JSON.parse(data.personCountData) || this.otherpersonCountData
this.othercontactData = JSON.parse(data.contactData) || this.othercontactData
+ console.log(8888,this.othercontactData)
}
+ }, err => {
+ this.isMasklayer = false
+ alert('获取信息错误!')
})
} else {
-
this.map.setCity('上海市');
}
//寻找管辖单位
this.allFireForceList.forEach(item => {
- if(item.id == node.parentId){
+ if (item.id == node.parentId) {
this.superior.name = item.name
this.superior.code = item.code
}
})
+ //找出点击的组织及其下属机构
+ this.carSearchForm.organization = node.id
+ this.clickOrganizationTree.forEach(item => {
+ if (item.id == node.id) {
+ this.selectOrganizationTree[0] = item
+ console.log('点击的组织机构', this.selectOrganizationTree)
+ }
+ });
}
}
//搜索
- isTreeView:boolean = true//决定显示树还是列表
- searchList(){
- if(!this.searchForm.name && !this.searchForm.integrityNum){
+ isTreeView: boolean = true//决定显示树还是列表
+ searchList() {
+ if (!this.searchForm.name && !this.searchForm.integrityNum) {
this.isTreeView = true
- }else{
+ } else {
this.isTreeView = false
}
this.getAllFireForce()
}
//重置搜索
- reset(){
+ reset() {
this.isTreeView = true
this.selectedFireForceLevel = null
this.searchForm = {
- name:'',
- integrityNum:''
+ name: '',
+ integrityNum: ''
}
this.getAllFireForce()
}
//js乘法
- accMul(arg1,arg2,fix) {
- if(!parseInt(fix)==fix)
- {
- return;
+ accMul(arg1, arg2, fix) {
+ if (!parseInt(fix) == fix) {
+ return;
+ }
+ var m = 0, s1 = arg1.toString(), s2 = arg2.toString();
+ try { m += s1.split(".")[1].length } catch (e) { }
+ try { m += s2.split(".")[1].length } catch (e) { }
+ if (m > fix) {
+ return (Math.round(Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m - fix)) / Math.pow(10, fix));
+ } else if (m <= fix) {
+ return (Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m)).toFixed(fix);
+ } else {
+ return (arg1 * arg2).toFixed(fix).toString();
}
- var m=0,s1=arg1.toString(),s2=arg2.toString();
- try{m+=s1.split(".")[1].length}catch(e){}
- try{m+=s2.split(".")[1].length}catch(e){}
- if(m>fix){
- return (Math.round(Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m-fix))/Math.pow(10,fix));
- }else if(m<=fix){
- return (Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m)).toFixed(fix);
- }else{
- return (arg1*arg2).toFixed(fix).toString();
- }
- }
+ }
//完整度颜色
- integrity(width){
+ integrity(width) {
let _this = this
- let style:any = {}
- style.width = width +'%';
- if(width < 30){
+ let style: any = {}
+ style.width = width + '%';
+ if (width < 30) {
style.background = '#FF5D4A'
}
- if(width >= 30 && width < 60){
+ if (width >= 30 && width < 60) {
style.background = '#FFDD00'
}
- if(width >= 60){
+ if (width >= 60) {
style.background = '#5CD64E'
}
return style
}
//删除某条消防队
- deleteFireForce(item,e){
+ deleteFireForce(item, e) {
e.stopPropagation()
// console.log(this.dataSource.data)
let isDelete = window.confirm(`确定要删除${item.name}吗`)
- if(isDelete){
+ if (isDelete) {
// this.http.delete(`/api/CustomFireForce/${item.id}`).subscribe(data => {
// let config = new MatSnackBarConfig();
// config.verticalPosition = 'top';
@@ -444,219 +1148,219 @@ export class FireForceComponent implements OnInit {
itemId: item.id,
verifyState: 3,
}
- this.http.post('/api/ContentVerifies',body).subscribe((data) => {
+ this.http.post('/api/ContentVerifies', body).subscribe((data) => {
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('删除审核提交成功','确定',config);
+ this.snackBar.open('删除审核提交成功', '确定', config);
item.contentVerify = data
})
}
}
//当前点击tab页面第几个
- tabIndex:any = 1
- selectedTab(index){
+ tabIndex: any = 1
+ selectedTab(index) {
this.tabIndex = index
}
//消防力量详情提交信息
- FireForceDetailInfo:any = {
+ FireForceDetailInfo: any = {
// id:'',//编号
- stationName:'',//队站名称
- isIndependentAlarm:true,//是否独立报警
- phoneNumber:'',//联系电话
- faxNumber:'',//传真
- jurisdictionArea:null,//辖区面积
- remark:'',//备注
- address:'',//地址
- location:{
- x:'',
- y:''
+ stationName: '',//队站名称
+ isIndependentAlarm: true,//是否独立报警
+ phoneNumber: '',//联系电话
+ faxNumber: '',//传真
+ jurisdictionArea: null,//辖区面积
+ remark: '',//备注
+ address: '',//地址
+ location: {
+ x: '',
+ y: ''
},
- personCountData:[],//人员数量自定义
- contactData:[],//联系方式自定义
- dutyForceData:[],//执勤力量自定义
- relevantInfomationData:[]//相关资料
+ personCountData: [],//人员数量自定义
+ contactData: [],//联系方式自定义
+ dutyForceData: [],//执勤力量自定义
+ relevantInfomationData: []//相关资料
}
//总队支队人员数量
- ZongpersonCountData:any=[
- {PropertyName :'现役官兵人数',PropertyValue:''},
- {PropertyName :'政府专职消防员数',PropertyValue:''},
- {PropertyName :'消防文员数',PropertyValue:''}
+ ZongpersonCountData: any = [
+ { PropertyName: '现役官兵人数', PropertyValue: '' },
+ { PropertyName: '政府专职消防员数', PropertyValue: '' },
+ { PropertyName: '消防文员数', PropertyValue: '' }
]
//总队联系方式
- ZongcontactData:any=[
- {PropertyName :'总队长名称',PropertyValue:''},
- {PropertyName :'总队长联系方式',PropertyValue:''},
- {PropertyName :'总队政委名称',PropertyValue:''},
- {PropertyName :'总队政委联系方式',PropertyValue:''}
+ ZongcontactData: any = [
+ { PropertyName: '总队长名称', PropertyValue: '' },
+ { PropertyName: '总队长联系方式', PropertyValue: '' },
+ { PropertyName: '总队政委名称', PropertyValue: '' },
+ { PropertyName: '总队政委联系方式', PropertyValue: '' }
]
//支队联系方式
- ZhicontactData:any=[
- {PropertyName :'支队长名称',PropertyValue:''},
- {PropertyName :'支队长联系方式',PropertyValue:''},
- {PropertyName :'支队政委名称',PropertyValue:''},
- {PropertyName :'支队政委联系方式',PropertyValue:''}
+ ZhicontactData: any = [
+ { PropertyName: '支队长名称', PropertyValue: '' },
+ { PropertyName: '支队长联系方式', PropertyValue: '' },
+ { PropertyName: '支队政委名称', PropertyValue: '' },
+ { PropertyName: '支队政委联系方式', PropertyValue: '' }
]
//大队中队人员数量
- DaZhongpersonCountData:any=[
- {PropertyName :'现役人员',PropertyValue:''},
- {PropertyName :'政府专职消防员数',PropertyValue:''},
- {PropertyName :'每日执勤人数',PropertyValue:''}
+ DaZhongpersonCountData: any = [
+ { PropertyName: '现役人员', PropertyValue: '' },
+ { PropertyName: '政府专职消防员数', PropertyValue: '' },
+ { PropertyName: '每日执勤人数', PropertyValue: '' }
]
//大队中队联系方式
- DaZhongcontactData:any=[
- {PropertyName :'站长姓名',PropertyValue:''},
- {PropertyName :'站长联系方式',PropertyValue:''},
- {PropertyName :'指导员姓名',PropertyValue:''},
- {PropertyName :'指导员联系方式',PropertyValue:''},
- {PropertyName :'副指导员姓名',PropertyValue:''},
- {PropertyName :'副指导员联系方式',PropertyValue:''},
- {PropertyName :'副站长一姓名',PropertyValue:''},
- {PropertyName :'副站长一联系方式',PropertyValue:''},
- {PropertyName :'副站长二姓名',PropertyValue:''},
- {PropertyName :'副站长二联系方式',PropertyValue:''},
- {PropertyName :'副站长三姓名',PropertyValue:''},
- {PropertyName :'副站长三联系方式',PropertyValue:''}
+ DaZhongcontactData: any = [
+ { PropertyName: '站长姓名', PropertyValue: '' },
+ { PropertyName: '站长联系方式', PropertyValue: '' },
+ { PropertyName: '指导员姓名', PropertyValue: '' },
+ { PropertyName: '指导员联系方式', PropertyValue: '' },
+ { PropertyName: '副指导员姓名', PropertyValue: '' },
+ { PropertyName: '副指导员联系方式', PropertyValue: '' },
+ { PropertyName: '副站长一姓名', PropertyValue: '' },
+ { PropertyName: '副站长一联系方式', PropertyValue: '' },
+ { PropertyName: '副站长二姓名', PropertyValue: '' },
+ { PropertyName: '副站长二联系方式', PropertyValue: '' },
+ { PropertyName: '副站长三姓名', PropertyValue: '' },
+ { PropertyName: '副站长三联系方式', PropertyValue: '' }
]
//其他消防力量联系方式
- othercontactData:any = [
- {PropertyName :'队长',PropertyValue:''},
- {PropertyName :'联系方式',PropertyValue:''},
- {PropertyName :'站长',PropertyValue:''},
- {PropertyName :'联系方式',PropertyValue:''},
- {PropertyName :'负责人',PropertyValue:''},
- {PropertyName :'联系方式',PropertyValue:''}
+ othercontactData: any = [
+ { PropertyName: '队长', PropertyValue: '' },
+ { PropertyName: '联系方式', PropertyValue: '' },
+ { PropertyName: '站长', PropertyValue: '' },
+ { PropertyName: '联系方式', PropertyValue: '' },
+ { PropertyName: '负责人', PropertyValue: '' },
+ { PropertyName: '联系方式', PropertyValue: '' }
]
//其他消防力量人员数量
- otherpersonCountData:any = [
- {PropertyName :'每日执勤人数',PropertyValue:''},
- {PropertyName :'消防队员总人数',PropertyValue:''},
- {PropertyName :'执勤车辆数',PropertyValue:''},
- {PropertyName :'灭火剂总量',PropertyValue:''}
+ otherpersonCountData: any = [
+ { PropertyName: '每日执勤人数', PropertyValue: '' },
+ { PropertyName: '消防队员总人数', PropertyValue: '' },
+ { PropertyName: '执勤车辆数', PropertyValue: '' },
+ { PropertyName: '灭火剂总量', PropertyValue: '' }
]
//清空表单数据
- clearData(){
+ clearData() {
this.deletedFile = []//清空相关资料已删除缓存
this.AttachmentArr = []//清空相关资料
- this.positionLngLat = {x:'',y:''}
+ this.positionLngLat = { x: '', y: '' }
this.FireForceDetailInfo = {
// id:'',//编号
- stationName:'',//队站名称
- isIndependentAlarm:null,//是否独立报警
- phoneNumber:'',//联系电话
- faxNumber:'',//传真
- jurisdictionArea:null,//辖区面积
- remark:'',//备注
- address:'',//地址
- location:{
- x:'',
- y:''
+ stationName: '',//队站名称
+ isIndependentAlarm: null,//是否独立报警
+ phoneNumber: '',//联系电话
+ faxNumber: '',//传真
+ jurisdictionArea: null,//辖区面积
+ remark: '',//备注
+ address: '',//地址
+ location: {
+ x: '',
+ y: ''
},
- personCountData:[],//人员数量自定义
- contactData:[],//联系方式自定义
- dutyForceData:[],//执勤力量自定义
- relevantInfomationData:[]//相关资料
+ personCountData: [],//人员数量自定义
+ contactData: [],//联系方式自定义
+ dutyForceData: [],//执勤力量自定义
+ relevantInfomationData: []//相关资料
}
this.ZongpersonCountData = [
- {PropertyName :'现役官兵人数',PropertyValue:''},
- {PropertyName :'政府专职消防员数',PropertyValue:''},
- {PropertyName :'消防文员数',PropertyValue:''}
+ { PropertyName: '现役官兵人数', PropertyValue: '' },
+ { PropertyName: '政府专职消防员数', PropertyValue: '' },
+ { PropertyName: '消防文员数', PropertyValue: '' }
]
this.ZongcontactData = [
- {PropertyName :'总队长名称',PropertyValue:''},
- {PropertyName :'总队长联系方式',PropertyValue:''},
- {PropertyName :'总队政委名称',PropertyValue:''},
- {PropertyName :'总队政委联系方式',PropertyValue:''}
+ { PropertyName: '总队长名称', PropertyValue: '' },
+ { PropertyName: '总队长联系方式', PropertyValue: '' },
+ { PropertyName: '总队政委名称', PropertyValue: '' },
+ { PropertyName: '总队政委联系方式', PropertyValue: '' }
]
this.ZhicontactData = [
- {PropertyName :'支队长名称',PropertyValue:''},
- {PropertyName :'支队长联系方式',PropertyValue:''},
- {PropertyName :'支队政委名称',PropertyValue:''},
- {PropertyName :'支队政委联系方式',PropertyValue:''}
+ { PropertyName: '支队长名称', PropertyValue: '' },
+ { PropertyName: '支队长联系方式', PropertyValue: '' },
+ { PropertyName: '支队政委名称', PropertyValue: '' },
+ { PropertyName: '支队政委联系方式', PropertyValue: '' }
]
this.DaZhongpersonCountData = [
- {PropertyName :'现役人员',PropertyValue:''},
- {PropertyName :'政府专职消防员数',PropertyValue:''},
- {PropertyName :'每日执勤人数',PropertyValue:''}
+ { PropertyName: '现役人员', PropertyValue: '' },
+ { PropertyName: '政府专职消防员数', PropertyValue: '' },
+ { PropertyName: '每日执勤人数', PropertyValue: '' }
]
this.DaZhongcontactData = [
- {PropertyName :'站长姓名',PropertyValue:''},
- {PropertyName :'站长联系方式',PropertyValue:''},
- {PropertyName :'指导员姓名',PropertyValue:''},
- {PropertyName :'指导员联系方式',PropertyValue:''},
- {PropertyName :'副指导员姓名',PropertyValue:''},
- {PropertyName :'副指导员联系方式',PropertyValue:''},
- {PropertyName :'副站长一姓名',PropertyValue:''},
- {PropertyName :'副站长一联系方式',PropertyValue:''},
- {PropertyName :'副站长二姓名',PropertyValue:''},
- {PropertyName :'副站长二联系方式',PropertyValue:''},
- {PropertyName :'副站长三姓名',PropertyValue:''},
- {PropertyName :'副站长三联系方式',PropertyValue:''}
+ { PropertyName: '站长姓名', PropertyValue: '' },
+ { PropertyName: '站长联系方式', PropertyValue: '' },
+ { PropertyName: '指导员姓名', PropertyValue: '' },
+ { PropertyName: '指导员联系方式', PropertyValue: '' },
+ { PropertyName: '副指导员姓名', PropertyValue: '' },
+ { PropertyName: '副指导员联系方式', PropertyValue: '' },
+ { PropertyName: '副站长一姓名', PropertyValue: '' },
+ { PropertyName: '副站长一联系方式', PropertyValue: '' },
+ { PropertyName: '副站长二姓名', PropertyValue: '' },
+ { PropertyName: '副站长二联系方式', PropertyValue: '' },
+ { PropertyName: '副站长三姓名', PropertyValue: '' },
+ { PropertyName: '副站长三联系方式', PropertyValue: '' }
]
this.othercontactData = [
- {PropertyName :'队长',PropertyValue:''},
- {PropertyName :'联系方式',PropertyValue:''},
- {PropertyName :'站长',PropertyValue:''},
- {PropertyName :'联系方式',PropertyValue:''},
- {PropertyName :'负责人',PropertyValue:''},
- {PropertyName :'联系方式',PropertyValue:''}
+ { PropertyName: '队长', PropertyValue: '' },
+ { PropertyName: '联系方式', PropertyValue: '' },
+ { PropertyName: '站长', PropertyValue: '' },
+ { PropertyName: '联系方式', PropertyValue: '' },
+ { PropertyName: '负责人', PropertyValue: '' },
+ { PropertyName: '联系方式', PropertyValue: '' }
]
this.otherpersonCountData = [
- {PropertyName :'每日执勤人数',PropertyValue:''},
- {PropertyName :'消防队员总人数',PropertyValue:''},
- {PropertyName :'执勤车辆数',PropertyValue:''},
- {PropertyName :'灭火剂总量',PropertyValue:''}
+ { PropertyName: '每日执勤人数', PropertyValue: '' },
+ { PropertyName: '消防队员总人数', PropertyValue: '' },
+ { PropertyName: '执勤车辆数', PropertyValue: '' },
+ { PropertyName: '灭火剂总量', PropertyValue: '' }
]
}
//新增消防力量
- selectedFireForceTypeIndex:any//新增消防力量名称
- addFireForce(){
- if(this.selectedFireForceId && this.selectedFireForce.forceType == 0){
+ selectedFireForceTypeIndex: any//新增消防力量名称
+ addFireForce() {
+ if (this.selectedFireForceId && this.selectedFireForce.forceType == 0) {
const dialogRef = this.dialog.open(AddFireForce, {
data: {},
- id:'addWater'
+ id: 'addWater'
});
dialogRef.afterClosed().subscribe(
- data=>{
- if(typeof data === 'number' && !isNaN(data)){
+ data => {
+ if (typeof data === 'number' && !isNaN(data)) {
this.isPost = true
- this.selectedFireForceTypeIndex = data
- this.selectedFireForceLevel = data
- // this.newPositionMarker ? this.map.remove(this.newPositionMarker) : null
- // this.positionLngLat.x = 0
- // this.positionLngLat.y = 0
- // this.map.setCity('上海市');
- this.selectedFireForce.contentVerify = null
- this.clearData()
- }
+ this.selectedFireForceTypeIndex = data
+ this.selectedFireForceLevel = data
+ // this.newPositionMarker ? this.map.remove(this.newPositionMarker) : null
+ // this.positionLngLat.x = 0
+ // this.positionLngLat.y = 0
+ // this.map.setCity('上海市');
+ this.selectedFireForce.contentVerify = null
+ this.clearData()
+ }
}
);
- }else if(this.selectedFireForceId && this.selectedFireForce.forceType != 0){
+ } else if (this.selectedFireForceId && this.selectedFireForce.forceType != 0) {
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('该选中机构无法增加其他机构','确定',config);
- } else{
+ this.snackBar.open('该选中机构无法增加其他机构', '确定', config);
+ } else {
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('请先从左侧列表选择一个组织机构','确定',config);
+ this.snackBar.open('请先从左侧列表选择一个组织机构', '确定', config);
}
-
+
}
//保存
- isPost:boolean = false//是否走post创建接口
- newselectedFireForceId:any //创建成功其他消防力量后保存一下创建出来的id
- save(){
- if(!this.FireForceDetailInfo.stationName){
+ isPost: boolean = false//是否走post创建接口
+ newselectedFireForceId: any //创建成功其他消防力量后保存一下创建出来的id
+ save() {
+ if (!this.FireForceDetailInfo.stationName) {
alert('名称必填')
return
}
//删除一下数据库的文件
- if(this.deletedFile.length != 0){
+ if (this.deletedFile.length != 0) {
this.deletedFile.forEach(item => {
- this.http.delete(`/api/Objects/PlanPlatform/${item.objectName}`).subscribe(data=>{
+ this.http.delete(`/api/Objects/PlanPlatform/${item.objectName}`).subscribe(data => {
// console.log('删除原文件成功')
})
});
@@ -665,102 +1369,102 @@ export class FireForceComponent implements OnInit {
this.FireForceDetailInfo.relevantInfomationData = JSON.stringify(this.AttachmentArr)
// console.log(1111,this.FireForceDetailInfo)
//如果是总支大中
- this.FireForceDetailInfo.location = {x:'',y:''}
- if(this.atLastPositionLngLat.x){
+ this.FireForceDetailInfo.location = { x: '', y: '' }
+ if (this.atLastPositionLngLat.x) {
this.FireForceDetailInfo.location.x = this.atLastPositionLngLat.x
this.FireForceDetailInfo.location.y = this.atLastPositionLngLat.y
- }else{
+ } else {
this.FireForceDetailInfo.location = null
}
- if(this.selectedFireForce.forceType == 0&&(this.selectedFireForceLevel == 0 || this.selectedFireForceLevel == 1 || this.selectedFireForceLevel == 2 || this.selectedFireForceLevel == 3)){//如果是总队
+ if (this.selectedFireForce.forceType == 0 && (this.selectedFireForceLevel == 0 || this.selectedFireForceLevel == 1 || this.selectedFireForceLevel == 2 || this.selectedFireForceLevel == 3)) {//如果是总队
let body = this.FireForceDetailInfo
-
- if(this.selectedFireForceLevel == 0){//总队
- this.FireForceDetailInfo.personCountData = JSON.stringify(this.ZongpersonCountData)
+
+ if (this.selectedFireForceLevel == 0) {//总队
+ this.FireForceDetailInfo.personCountData = JSON.stringify(this.ZongpersonCountData)
this.FireForceDetailInfo.contactData = JSON.stringify(this.ZongcontactData)
this.FireForceDetailInfo.dutyForceData = null
}
- if(this.selectedFireForceLevel == 1){//支队
- this.FireForceDetailInfo.personCountData = JSON.stringify(this.ZongpersonCountData)
+ if (this.selectedFireForceLevel == 1) {//支队
+ this.FireForceDetailInfo.personCountData = JSON.stringify(this.ZongpersonCountData)
this.FireForceDetailInfo.contactData = JSON.stringify(this.ZhicontactData)
this.FireForceDetailInfo.dutyForceData = null
}
- if(this.selectedFireForceLevel == 2 || this.selectedFireForceLevel == 3){//大队 中队
- this.FireForceDetailInfo.personCountData = JSON.stringify(this.DaZhongpersonCountData)
+ if (this.selectedFireForceLevel == 2 || this.selectedFireForceLevel == 3) {//大队 中队
+ this.FireForceDetailInfo.personCountData = JSON.stringify(this.DaZhongpersonCountData)
this.FireForceDetailInfo.contactData = JSON.stringify(this.DaZhongcontactData)
this.FireForceDetailInfo.dutyForceData = null
}
// console.log('body',body)
- this.http.put(`/api/FireForceDetail/0/${this.selectedFireForce.id}`,body).subscribe(data => {
+ this.http.put(`/api/FireForceDetail/0/${this.selectedFireForce.id}`, body).subscribe(data => {
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('保存成功','确定',config);
+ this.snackBar.open('保存成功', '确定', config);
this.upDateAllFireForce()
})
}
//如果是其他消防力量
- else{
- if(!this.isPost){
+ else {
+ if (!this.isPost) {
let body = this.FireForceDetailInfo
- body.personCountData = JSON.stringify(this.otherpersonCountData)
+ body.personCountData = JSON.stringify(this.otherpersonCountData)
body.contactData = JSON.stringify(this.othercontactData)
body.dutyForceData = null
let id
- if(this.selectedFireForce.forceType == 0){
+ if (this.selectedFireForce.forceType == 0) {
id = this.newselectedFireForceId
- }else{
+ } else {
id = this.selectedFireForce.id
}
- this.http.put(`/api/FireForceDetail/1/${id}`,body).subscribe(data => {
+ this.http.put(`/api/FireForceDetail/1/${id}`, body).subscribe(data => {
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('保存成功','确定',config);
+ this.snackBar.open('保存成功', '确定', config);
this.upDateAllFireForce()
})
- }else{
+ } else {
let forceType
this.selectedFireForceTypeIndex == 4 ? forceType = 1 : null
this.selectedFireForceTypeIndex == 5 ? forceType = 2 : null
this.selectedFireForceTypeIndex == 6 ? forceType = 4 : null
let body = {
- organizationId:this.selectedFireForce.id,
- name:this.FireForceDetailInfo.stationName,
- createTime:new Date(),
- forceType:forceType
+ organizationId: this.selectedFireForce.id,
+ name: this.FireForceDetailInfo.stationName,
+ createTime: new Date(),
+ forceType: forceType
}
let params = {
- organizationId : this.selectedFireForce.id
+ organizationId: this.selectedFireForce.id
}
- this.http.post('/api/CustomFireForce',body,{params:params}).subscribe((data:any) => {
+ this.http.post('/api/CustomFireForce', body, { params: params }).subscribe((data: any) => {
this.newselectedFireForceId = data.id
this.selectedFireForce = data
let body = this.FireForceDetailInfo
body.personCountData = JSON.stringify(this.otherpersonCountData)
body.contactData = JSON.stringify(this.othercontactData)
body.dutyForceData = null
- this.http.put(`/api/FireForceDetail/1/${data.id}`,body).subscribe(data2 => {
+ this.http.put(`/api/FireForceDetail/1/${data.id}`, body).subscribe(data2 => {
this.upDateAllFireForce()
this.selectedFireForceId = data.id
this.isPost = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('保存成功','确定',config);
+ this.snackBar.open('保存成功', '确定', config);
})
})
}
-
+
}
-
-
+
+
}
//提交审核
- submitAudit(){
+ submitAudit() {
let isTrue = window.confirm('请确认保存后提交审核,否则将无法审核最新内容,是否继续?')
- if(isTrue){
+ if (isTrue) {
// console.log('提交审核的消防力量',this.FireForceDetailInfo)
let body = {
title: this.FireForceDetailInfo.stationName,
@@ -769,84 +1473,84 @@ export class FireForceComponent implements OnInit {
itemId: this.selectedFireForce.id,
verifyState: 3,
}
- this.http.post('/api/ContentVerifies',body).subscribe((data) => {
+ this.http.post('/api/ContentVerifies', body).subscribe((data) => {
this.selectedFireForce.contentVerify = data
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('提交成功','确定',config);
+ this.snackBar.open('提交成功', '确定', config);
})
}
-
+
}
//撤销审核
- cancelAudit(){
+ cancelAudit() {
let isTrue = window.confirm('您确认要撤销该审核吗?')
- if(isTrue){
+ if (isTrue) {
// console.log('撤销审核的消防力量',this.waterData)
this.http.delete(`/api/ContentVerifies/${this.selectedFireForce.contentVerify.id}`).subscribe((data) => {
this.selectedFireForce.contentVerify = null
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('撤销成功','确定',config);
+ this.snackBar.open('撤销成功', '确定', config);
})
}
}
- close(){
+ close() {
this.selectedFireForceLevel = null
this.selectedFireForceId = null
this.newPositionMarker ? this.map.remove(this.newPositionMarker) : null
this.isGisTopBox = false
}
- map:IMap
+ map: IMap
placeSearch: IPlaceSearch//构造地点查询类
- isMapLabel:boolean = false //是否已经标记坐标
- newPositionMarkerContent:any =
- '' +
- '
' +
- '
'
- newPositionMarkerContentBtn:any =
- ''
+ isMapLabel: boolean = false //是否已经标记坐标
+ newPositionMarkerContent: any =
+ '' +
+ '
' +
+ '
'
+ newPositionMarkerContentBtn: any =
+ ''
//创建地图
- newPositionMarker:IMarker//坐标实例
- createMap(){
+ newPositionMarker: IMarker//坐标实例
+ createMap() {
this.map = MapFactory.MapInstance('container', {
- zoom:12
+ zoom: 12
})
this.map.setCity('上海市');
//输入提示
var autoOptions = {
input: "tipinput"
};
- let auto = MapFactory.AutocompleteInstance(autoOptions,this);
+ let auto = MapFactory.AutocompleteInstance(autoOptions, this);
this.placeSearch = MapFactory.PlaceSearchInstance(this); //构造地点查询类
- auto.on("select", (e)=>{
- this.newPositionMarker.setPosition([e.poi.location.lng,e.poi.location.lat])
- this.positionLngLat = {x: e.poi.location.lng, y: e.poi.location.lat}
- this.map.setCenter([e.poi.location.lng,e.poi.location.lat]); //设置地图中心点
+ auto.on("select", (e) => {
+ this.newPositionMarker.setPosition([e.poi.location.lng, e.poi.location.lat])
+ this.positionLngLat = { x: e.poi.location.lng, y: e.poi.location.lat }
+ this.map.setCenter([e.poi.location.lng, e.poi.location.lat]); //设置地图中心点
});//注册监听,当选中某条记录时会触发
}
//点击位置
- isGisTopBox:boolean = false //
- searchTitle:any = ''//
+ isGisTopBox: boolean = false //
+ searchTitle: any = ''//
- positionLngLat:any = {x:'',y:''}//临时坐标点
- atLastPositionLngLat:any = {x:'',y:''}//最终坐标点
- setPosition(){
- if(!this.isGisTopBox){
+ positionLngLat: any = { x: '', y: '' }//临时坐标点
+ atLastPositionLngLat: any = { x: '', y: '' }//最终坐标点
+ setPosition() {
+ if (!this.isGisTopBox) {
this.isGisTopBox = true
this.newPositionMarker ? this.map.remove(this.newPositionMarker) : null
let center
- if(this.newPositionMarker && this.atLastPositionLngLat.x){//如果已经标注单位坐标
+ if (this.newPositionMarker && this.atLastPositionLngLat.x) {//如果已经标注单位坐标
center = [this.atLastPositionLngLat.x, this.atLastPositionLngLat.y]
- }else if(this.newPositionMarker && !this.atLastPositionLngLat.x && this.FireForceDetailInfo.location && this.FireForceDetailInfo.location.x){
+ } else if (this.newPositionMarker && !this.atLastPositionLngLat.x && this.FireForceDetailInfo.location && this.FireForceDetailInfo.location.x) {
center = [this.FireForceDetailInfo.location.x, this.FireForceDetailInfo.location.y]
- }else{
+ } else {
center = this.map.getCenter(); //获取当前地图中心位置
}
this.newPositionMarker = MapFactory.MarkerInstance({
@@ -855,18 +1559,18 @@ export class FireForceComponent implements OnInit {
content: this.newPositionMarkerContentBtn,
offset: MapFactory.PixelInstance(-15, -18)
});
- this.positionLngLat = {x: center.lng || center[0], y: center.lat || center[1]}
+ this.positionLngLat = { x: center.lng || center[0], y: center.lat || center[1] }
this.map.add(this.newPositionMarker);
this.isMapLabel = true
- this.newPositionMarker.on('dragend', (e)=>{
- this.positionLngLat = {x: e.lnglat.lng, y: e.lnglat.lat}
- },this)
+ this.newPositionMarker.on('dragend', (e) => {
+ this.positionLngLat = { x: e.lnglat.lng, y: e.lnglat.lat }
+ }, this)
//点击确定
- this.renderer2.listen(this.elementRef.nativeElement.querySelector('#setPositionOk'),'click',(event)=>{
+ this.renderer2.listen(this.elementRef.nativeElement.querySelector('#setPositionOk'), 'click', (event) => {
this.isGisTopBox = false
this.map.remove(this.newPositionMarker)
this.newPositionMarker = MapFactory.MarkerInstance({
- position: [this.positionLngLat.x,this.positionLngLat.y],
+ position: [this.positionLngLat.x, this.positionLngLat.y],
content: this.newPositionMarkerContent,
offset: MapFactory.PixelInstance(-15, -18)
});
@@ -874,29 +1578,29 @@ export class FireForceComponent implements OnInit {
this.map.add(this.newPositionMarker);
this.positionLngLat = this.atLastPositionLngLat
})
- this.renderer2.listen(this.elementRef.nativeElement.querySelector('#setPositionClose'),'click',(event)=>{
+ this.renderer2.listen(this.elementRef.nativeElement.querySelector('#setPositionClose'), 'click', (event) => {
this.isGisTopBox = false
this.map.remove(this.newPositionMarker)
- if(this.positionLngLat.x && this.positionLngLat.x != 0 && !this.atLastPositionLngLat.x){//直接取消
+ if (this.positionLngLat.x && this.positionLngLat.x != 0 && !this.atLastPositionLngLat.x) {//直接取消
this.map.remove(this.newPositionMarker)
this.positionLngLat = {}
this.atLastPositionLngLat = {}
- }else{
+ } else {
this.newPositionMarker = MapFactory.MarkerInstance({
- position: [this.atLastPositionLngLat.x,this.atLastPositionLngLat.y],
+ position: [this.atLastPositionLngLat.x, this.atLastPositionLngLat.y],
content: this.newPositionMarkerContent,
offset: MapFactory.PixelInstance(-15, -18)
});
- this.map.setCenter([this.atLastPositionLngLat.x,this.atLastPositionLngLat.y]); //设置地图中心点
+ this.map.setCenter([this.atLastPositionLngLat.x, this.atLastPositionLngLat.y]); //设置地图中心点
this.map.add(this.newPositionMarker);
this.positionLngLat = this.atLastPositionLngLat
}
})//取消
- this.renderer2.listen(this.elementRef.nativeElement.querySelector('#setPositionOk'),'touchstart',(event)=>{
+ this.renderer2.listen(this.elementRef.nativeElement.querySelector('#setPositionOk'), 'touchstart', (event) => {
this.isGisTopBox = false
this.map.remove(this.newPositionMarker)
this.newPositionMarker = MapFactory.MarkerInstance({
- position: [this.positionLngLat.x,this.positionLngLat.y],
+ position: [this.positionLngLat.x, this.positionLngLat.y],
content: this.newPositionMarkerContent,
offset: MapFactory.PixelInstance(-15, -18)
});
@@ -904,119 +1608,121 @@ export class FireForceComponent implements OnInit {
this.map.add(this.newPositionMarker);
this.positionLngLat = this.atLastPositionLngLat
})
- this.renderer2.listen(this.elementRef.nativeElement.querySelector('#setPositionClose'),'touchstart',(event)=>{
+ this.renderer2.listen(this.elementRef.nativeElement.querySelector('#setPositionClose'), 'touchstart', (event) => {
this.isGisTopBox = false
this.map.remove(this.newPositionMarker)
- if(this.positionLngLat.x && this.positionLngLat.x != 0 && !this.atLastPositionLngLat.x){//直接取消
+ if (this.positionLngLat.x && this.positionLngLat.x != 0 && !this.atLastPositionLngLat.x) {//直接取消
this.map.remove(this.newPositionMarker)
this.positionLngLat = {}
this.atLastPositionLngLat = {}
- }else{
+ } else {
this.newPositionMarker = MapFactory.MarkerInstance({
- position: [this.atLastPositionLngLat.x,this.atLastPositionLngLat.y],
+ position: [this.atLastPositionLngLat.x, this.atLastPositionLngLat.y],
content: this.newPositionMarkerContent,
offset: MapFactory.PixelInstance(-15, -18)
});
- this.map.setCenter([this.atLastPositionLngLat.x,this.atLastPositionLngLat.y]); //设置地图中心点
+ this.map.setCenter([this.atLastPositionLngLat.x, this.atLastPositionLngLat.y]); //设置地图中心点
this.map.add(this.newPositionMarker);
this.positionLngLat = this.atLastPositionLngLat
}
})//取消
}
-
+
}
//上传附件
- file:any; //上传的文件
- AttachmentArr:any = []//上传附件地址集合
- uploadId:any//分块上传id
- objectName:any
- progressBarValue:any = 0//分块上传进度
- isMasklayer:boolean = false//圆圈遮罩层是否打开
- isMasklayerUploading:boolean = false//上传进度条遮罩层是否打开
- isMasklayerDownload:boolean = false//下载进度条遮罩层是否打开
- uploadAttachment(e){
+ file: any; //上传的文件
+ AttachmentArr: any = []//上传附件地址集合
+ uploadId: any//分块上传id
+ objectName: any
+ progressBarValue: any = 0//分块上传进度
+ isMasklayer: boolean = false//圆圈遮罩层是否打开
+ isMasklayerUploading: boolean = false//上传进度条遮罩层是否打开
+ isMasklayerDownload: boolean = false//下载进度条遮罩层是否打开
+ uploadAttachment(e) {
this.file = e.target.files[0] || null //上传的文件
let file = e.target.files[0] || null //获取上传的文件
let fileSize = file.size || null //上传文件的总大小
let shardSize = 5 * 1024 * 1024 //5MB一个分片
-
- if (file && fileSize<=shardSize) { //上传文件<=5MB时
+
+ if (file && fileSize <= shardSize) { //上传文件<=5MB时
this.isMasklayer = true
let formData = new FormData()
- formData.append("file",file)
+ formData.append("file", file)
let storageFolderId //要存储到服务器的文件夹id 一般为当前选中单位的id 如果新创建的话就存到public文件夹
this.selectedFireForce.id ? storageFolderId = this.selectedFireForce.id : storageFolderId = 'public'
- this.http.post(`/api/Objects/PlanPlatform/FireForce/${storageFolderId}`,formData).subscribe((data:any)=>{
+ this.http.post(`/api/Objects/PlanPlatform/FireForce/${storageFolderId}`, formData).subscribe((data: any) => {
let obj = {
- objectName:data.objectName,
- fileName:data.fileName,
- fileLength:data.fileLength
+ objectName: data.objectName,
+ fileName: data.fileName,
+ fileLength: data.fileLength
}
this.AttachmentArr.push(obj)
this.isMasklayer = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('上传成功','确定',config);
+ this.snackBar.open('上传成功', '确定', config);
})
- } else if (file && fileSize>shardSize) { //上传文件>5MB时,分块上传
+ } else if (file && fileSize > shardSize) { //上传文件>5MB时,分块上传
this.isMasklayerUploading = true
- let data = {filename: file.name}
+ let data = { filename: file.name }
let storageFolderId //要存储到服务器的文件夹id 一般为当前选中单位的id 如果新创建的话就存到public文件夹
this.selectedFireForce.id ? storageFolderId = this.selectedFireForce.id : storageFolderId = 'public'
- this.http.post(`/api/NewMultipartUpload/PlanPlatform/FireForce/${storageFolderId}`,{},{params:data}).subscribe((data:any)=>{ //初始化分段上传
+ this.http.post(`/api/NewMultipartUpload/PlanPlatform/FireForce/${storageFolderId}`, {}, { params: data }).subscribe((data: any) => { //初始化分段上传
this.objectName = data.objectName
this.uploadId = data.uploadId
this.subsectionUploading()
})
}
}
- PartNumberETag:any=[]; //每次返回需要保存的信息
+ PartNumberETag: any = []; //每次返回需要保存的信息
//开始分段上传
- async subsectionUploading () {
+ async subsectionUploading() {
let file = this.file || null //获取上传的文件
let fileSize = file.size || null //上传文件的总大小
let shardSize = 5 * 1024 * 1024 //5MB一个分片
let allSlice = Math.ceil(fileSize / shardSize) //总文件/5MB===共分多少段
- for (let i = 0;i < allSlice;i++) { //循环分段上传
- let start = i * shardSize //切割文件开始位置
- let end = Math.min(fileSize, start + shardSize); //切割文件结束位置
- let formData = new FormData()
- formData.append("file",file.slice(start, end))
-
- //同步写法实现异步调用
- let result = await new Promise((resolve, reject) => {
- // await 需要后面返回一个 promise 对象
- this.http.post(`/api/MultipartUpload/PlanPlatform/${this.objectName}?uploadId=${this.uploadId}&partNumber=${i+1}`,formData).subscribe((data:any)=>{
- let msg = {
- "partNumber":data.partNumber || null,
- "eTag": data.eTag || null}
- resolve(msg) // 调用 promise 内置方法处理成功
- })
- });
- this.PartNumberETag.push(result)
- // this.progressBarValue = Number((i/allSlice).toFixed(2))*100
- this.progressBarValue = this.accMul(Number((i/allSlice).toFixed(2))*100,1,0)
- if (this.PartNumberETag.length === allSlice) {
- this.progressBarValue = 100
- this.endUploading()}
+ for (let i = 0; i < allSlice; i++) { //循环分段上传
+ let start = i * shardSize //切割文件开始位置
+ let end = Math.min(fileSize, start + shardSize); //切割文件结束位置
+ let formData = new FormData()
+ formData.append("file", file.slice(start, end))
+
+ //同步写法实现异步调用
+ let result = await new Promise((resolve, reject) => {
+ // await 需要后面返回一个 promise 对象
+ this.http.post(`/api/MultipartUpload/PlanPlatform/${this.objectName}?uploadId=${this.uploadId}&partNumber=${i + 1}`, formData).subscribe((data: any) => {
+ let msg = {
+ "partNumber": data.partNumber || null,
+ "eTag": data.eTag || null
+ }
+ resolve(msg) // 调用 promise 内置方法处理成功
+ })
+ });
+ this.PartNumberETag.push(result)
+ // this.progressBarValue = Number((i/allSlice).toFixed(2))*100
+ this.progressBarValue = this.accMul(Number((i / allSlice).toFixed(2)) * 100, 1, 0)
+ if (this.PartNumberETag.length === allSlice) {
+ this.progressBarValue = 100
+ this.endUploading()
+ }
}//for循环
}
//完成分块上传
- endUploading () {
+ endUploading() {
let data = this.PartNumberETag
- let paramsData = {uploadId:this.uploadId}
- this.http.post(`/api/CompleteMultipartUpload/PlanPlatform/${this.objectName}`,data,{params:paramsData}).subscribe(data=>{
- this.PartNumberETag =[] //清空保存返回的信息
+ let paramsData = { uploadId: this.uploadId }
+ this.http.post(`/api/CompleteMultipartUpload/PlanPlatform/${this.objectName}`, data, { params: paramsData }).subscribe(data => {
+ this.PartNumberETag = [] //清空保存返回的信息
let obj = {
- objectName:this.objectName,
- fileName:this.file.name,
- fileLength:this.file.size
+ objectName: this.objectName,
+ fileName: this.file.name,
+ fileLength: this.file.size
}
this.AttachmentArr.push(obj)
this.isMasklayerUploading = false//关闭进度条遮罩层
@@ -1024,74 +1730,75 @@ export class FireForceComponent implements OnInit {
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('上传成功','确定',config);
+ this.snackBar.open('上传成功', '确定', config);
})
}
//取消分块上传
cancelUploading() {
- this.http.delete(`/api/MultipartUpload/PlanPlatform/${this.objectName}?uploadId=${this.uploadId}`).subscribe(data=>{
+ this.http.delete(`/api/MultipartUpload/PlanPlatform/${this.objectName}?uploadId=${this.uploadId}`).subscribe(data => {
this.progressBarValue = 0;
- this.isMasklayerUploading= false
- this.PartNumberETag =[] //清空保存返回的信息
+ this.isMasklayerUploading = false
+ this.PartNumberETag = [] //清空保存返回的信息
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('取消上传成功','确定',config);
+ this.snackBar.open('取消上传成功', '确定', config);
})
}
//下载
- download (e) {
+ download(e) {
this.isMasklayerDownload = true //开启下载进度条
let file = e //传递过来的文件元数据
let fileSize = file.fileLength //下载文件的总大小
let shardSize = 3 * 1024 * 1024 //文件大小是否大于10MB
- if (file && fileSize<=shardSize) { //<=3MB时直接下载
+ if (file && fileSize <= shardSize) { //<=3MB时直接下载
this.progressBarValue = 60
- this.http.get(`/api/Objects/PlanPlatform/${e.objectName}`,{responseType: 'blob'},).subscribe(data=>{
+ this.http.get(`/api/Objects/PlanPlatform/${e.objectName}`, { responseType: 'blob' },).subscribe(data => {
let url = window.URL.createObjectURL(new Blob([data])); //createObjectURL创建一个下载Blob的url地址
let link = document.createElement("a");
link.style.display = "none";
link.href = url;
- let fileName = e.fileName ? e.fileName : e.objectName.split('/')[e.objectName.split('/').length-1]
+ let fileName = e.fileName ? e.fileName : e.objectName.split('/')[e.objectName.split('/').length - 1]
link.setAttribute("download", fileName);
document.body.appendChild(link);
link.click();
this.isMasklayerDownload = false //关闭下载进度条
this.progressBarValue = 0 //初始化进度条
})
- } else if (file && fileSize>shardSize) { //>3MB时分块下载
+ } else if (file && fileSize > shardSize) { //>3MB时分块下载
this.blockingDownload(e) //分段下载
}
}
//分段下载并合并
- async blockingDownload (e) {
+ async blockingDownload(e) {
let file = e //传递过来的文件元数据
let fileSize = file.fileLength //下载文件的总大小
let shardSize = 3 * 1024 * 1024 //3MB一个分片
let allSlice = Math.ceil(fileSize / shardSize) //总文件/3MB===共分多少段
- let allFile:any = [] //所有的file分段
+ let allFile: any = [] //所有的file分段
- for (let i=0;i{
- this.http.get(`/api/Objects/PlanPlatform/${e.objectName}`,{headers:{'range':`bytes= ${start}-${end}`},responseType:'blob'}).subscribe(data=>{
- result(data) })
+ let result = await new Promise((result, reject) => {
+ this.http.get(`/api/Objects/PlanPlatform/${e.objectName}`, { headers: { 'range': `bytes= ${start}-${end}` }, responseType: 'blob' }).subscribe(data => {
+ result(data)
+ })
})
allFile.push(result)
// this.progressBarValue = Number((i/allSlice).toFixed(2))*100 //文件进度数
- this.progressBarValue = this.accMul(Number((i/allSlice).toFixed(2))*100,1,0)
+ this.progressBarValue = this.accMul(Number((i / allSlice).toFixed(2)) * 100, 1, 0)
if (allFile.length === allSlice) { //合并文件输出给浏览器
let url = window.URL.createObjectURL(new Blob(allFile)); //createObjectURL创建一个下载Blob的url地址
let link = document.createElement("a");
link.style.display = "none";
link.href = url;
- let fileName = e.fileName ? e.fileName : e.objectName.split('/')[e.objectName.split('/').length-1]
+ let fileName = e.fileName ? e.fileName : e.objectName.split('/')[e.objectName.split('/').length - 1]
link.setAttribute("download", fileName);
document.body.appendChild(link);
link.click();
@@ -1104,31 +1811,31 @@ export class FireForceComponent implements OnInit {
}
//删除图片
- deletedFile:any = []
- deleteFile(item,e){
+ deletedFile: any = []
+ deleteFile(item, e) {
e.stopPropagation()
let isTrue = window.confirm('确定要删除该文件吗?')
- if(isTrue){
+ if (isTrue) {
let index
- this.AttachmentArr.forEach((element,key) => {
- if(element.objectName == item.objectName){
+ this.AttachmentArr.forEach((element, key) => {
+ if (element.objectName == item.objectName) {
index = key
}
});
- this.AttachmentArr.splice(index,1)
+ this.AttachmentArr.splice(index, 1)
this.deletedFile.push(item)
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
- this.snackBar.open('删除成功','确定',config);
+ this.snackBar.open('删除成功', '确定', config);
}
}
//点击文件
- clickFile(item){
- let suffix = item.fileName.split('.')[item.fileName.split('.').length-1]
- if(suffix == 'png' || suffix == 'jpg' || suffix == 'JPG'){
- let dom = document.getElementById(`viewerjs`)
+ clickFile(item) {
+ let suffix = item.fileName.split('.')[item.fileName.split('.').length - 1]
+ if (suffix == 'png' || suffix == 'jpg' || suffix == 'JPG') {
+ let dom = document.getElementById(`viewerjs`)
let pObjs = dom.childNodes;
let node = document.createElement("img")
node.style.display = "none";
@@ -1137,7 +1844,7 @@ export class FireForceComponent implements OnInit {
dom.appendChild(node)
setTimeout(() => {
let viewer = new Viewer(document.getElementById(`viewerjs`), {
- hidden:()=>{
+ hidden: () => {
dom.removeChild(pObjs[0]);
viewer.destroy();
}
@@ -1145,28 +1852,28 @@ export class FireForceComponent implements OnInit {
node.click();
}, 0);
}
- if(suffix == 'docx' || suffix == 'doc' || suffix == 'pdf'){
+ if (suffix == 'docx' || suffix == 'doc' || suffix == 'pdf') {
let fetchUrl = item.objectName
if (suffix == 'docx' || suffix == 'doc') {
let arr = fetchUrl.split('.')
arr[arr.length - 1] = 'pdf'
window.open(`/api/Objects/PlanPlatform/` + arr.join('.'))
- }else if (suffix == 'pdf') {
+ } else if (suffix == 'pdf') {
window.open(`/api/Objects/PlanPlatform/` + fetchUrl)
}
}
- if(suffix == 'mp4'){
+ if (suffix == 'mp4') {
const dialogRef = this.dialog.open(ViewDetails, {//调用open方法打开对话框并且携带参数过去
- data: {item:item,type:"video"},
- id:'videodialog'
+ data: { item: item, type: "video" },
+ id: 'videodialog'
});
dialogRef.afterClosed().subscribe();
}
}
//收起展开列表
- isPutDown:boolean = false
- putDown(){
+ isPutDown: boolean = false
+ putDown() {
this.isPutDown = !this.isPutDown
}
}
@@ -1180,17 +1887,17 @@ export class FireForceComponent implements OnInit {
styleUrls: ['./fire-force.component.scss']
})
export class AddFireForce {
-
- constructor(private http: HttpClient,public dialogRef: MatDialogRef,@Inject(MAT_DIALOG_DATA) public data,public snackBar: MatSnackBar) {}
+
+ constructor(private http: HttpClient, public dialogRef: MatDialogRef, @Inject(MAT_DIALOG_DATA) public data, public snackBar: MatSnackBar) { }
- addList:any = [
- {id:4, name:'微型消防站'},
- {id:5, name:'企业专职消防站'},
- {id:6, name:'义务(志愿)消防站'}
+ addList: any = [
+ { id: 4, name: '微型消防站' },
+ { id: 5, name: '企业专职消防站' },
+ { id: 6, name: '义务(志愿)消防站' }
]
- selectedFireForceTypeIndex:any = 4
- selecteAddType(item,key){
+ selectedFireForceTypeIndex: any = 4
+ selecteAddType(item, key) {
this.selectedFireForceTypeIndex = item.id
}
@@ -1198,12 +1905,57 @@ export class AddFireForce {
}
- confirm(){
+ confirm() {
this.dialogRef.close(this.selectedFireForceTypeIndex)
}
}
+//新增消防车辆弹出框
+@Component({
+ selector: 'addwater',
+ templateUrl: './addFireForceCar.html',
+ styleUrls: ['./fire-force.component.scss']
+})
+export class AddFireForceCar {
+
+ constructor(private http: HttpClient, public dialogRef: MatDialogRef, @Inject(MAT_DIALOG_DATA) public data, public snackBar: MatSnackBar) { }
+
+
+ addList: any = [
+ { id: 4, name: '微型消防站' },
+ { id: 5, name: '企业专职消防站' },
+ { id: 6, name: '义务(志愿)消防站' }
+ ]
+ selectedFireForceTypeIndex: any = 4
+ selecteAddType(item, key) {
+ this.selectedFireForceTypeIndex = item.id
+ }
+ ngOnInit(): void {
+
+ }
+
+ carName: string
+
+ onSubmit(value) {
+ // console.log('organizationId', this.data.organization)
+ // console.log(value)
+ let body = {
+ name: this.carName,
+ organizationId: this.data.organization
+ }
+ this.http.post('/api/FireFightingVehicles', body).subscribe(data => {
+ let config = new MatSnackBarConfig();
+ config.verticalPosition = 'top';
+ config.duration = 3000
+ this.snackBar.open('新增成功', '确定', config);
+ this.dialogRef.close(data)
+ })
+ }
+
+}
+
+
//查看图片大图和视频
@Component({
selector: 'viewdetails',
@@ -1214,15 +1966,15 @@ export class ViewDetails {
// myControl = new FormControl();
//注入MatDialogRef,可以用来关闭对话框
//要访问对话框组件中的数据,必须使用MAT_DIALOG_DATA注入令牌
- constructor(private http: HttpClient,public dialogRef: MatDialogRef,@Inject(MAT_DIALOG_DATA) public data) {}
- Url:string
+ constructor(private http: HttpClient, public dialogRef: MatDialogRef, @Inject(MAT_DIALOG_DATA) public data) { }
+ Url: string
onNoClick(): void {
this.dialogRef.close();
}
ngOnInit(): void {
- this.Url = '/api/Objects/PlanPlatform/' + this.data.item.objectName
+ this.Url = '/api/Objects/PlanPlatform/' + this.data.item.objectName
}
- closeDialog(){
+ closeDialog() {
this.dialogRef.close();
}
diff --git a/src/app/export-excel/export-excel.component.ts b/src/app/export-excel/export-excel.component.ts
index 63b2d70..f7e12d7 100644
--- a/src/app/export-excel/export-excel.component.ts
+++ b/src/app/export-excel/export-excel.component.ts
@@ -17,11 +17,11 @@ export class ExportExcelComponent implements OnInit {
responseType: 'blob' as 'json'
};
this.http.get('/api/StatisticsAnalysis/ExportToExcel',httpOptions).subscribe((data:any) => {
- // // 文件名中有中文 则对文件名进行转码
+ // 文件名中有中文 则对文件名进行转码
const link = document.createElement('a');
const blob = new Blob([data], {type: 'application/vnd.ms-excel'});
link.setAttribute('href', window.URL.createObjectURL(blob));
- link.setAttribute('download', '统计信息'+'.xlsx');
+ link.setAttribute('download', '统计信息'+'.xls');
link.style.visibility = 'hidden';
document.body.appendChild(link);
link.click();
diff --git a/src/app/gis-management/left-working/left-working.component.ts b/src/app/gis-management/left-working/left-working.component.ts
index 24bf2d3..34ce926 100644
--- a/src/app/gis-management/left-working/left-working.component.ts
+++ b/src/app/gis-management/left-working/left-working.component.ts
@@ -1,6 +1,5 @@
import { Component, EventEmitter, OnInit, Output, ViewChild } from '@angular/core';
import { FormControl } from '@angular/forms';
-import { id } from 'date-fns/locale';
@Component({
selector: 'app-left-working',
diff --git a/src/app/navigation/navigation.component.ts b/src/app/navigation/navigation.component.ts
index 3ca0cf8..802ced9 100644
--- a/src/app/navigation/navigation.component.ts
+++ b/src/app/navigation/navigation.component.ts
@@ -8,9 +8,6 @@ import { TreeService } from '../http-interceptors/tree.service'
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import { CacheTokenService } from '../http-interceptors/cache-token.service'//引入服务
import { Router, ActivatedRoute, ParamMap } from '@angular/router'
-import { is } from 'date-fns/locale';
-
-
@Component({
selector: 'app-navigation',
diff --git a/src/app/services/objects.service.ts b/src/app/services/objects.service.ts
new file mode 100644
index 0000000..3d35746
--- /dev/null
+++ b/src/app/services/objects.service.ts
@@ -0,0 +1,85 @@
+import { HttpClient } from '@angular/common/http';
+import { Injectable } from '@angular/core';
+import { Observable } from 'rxjs';
+
+@Injectable({
+ providedIn: 'root'
+})
+export class ObjectsService {
+
+ static readonly c_apiRoot = "/api/";//普通上传的API根路径
+ static readonly c_apiRoot_Multipart = "/api/";//分块上传的API根路径
+
+ // static testPath = "f1/f2";//测试路径
+
+ constructor(private http: HttpClient) { }
+
+
+
+ //普通上传,单个文件上限5M
+ static baseUrl = ObjectsService.c_apiRoot + 'Objects/PlanPlatform/';
+ postFile(extensionPath: string, file: File): Observable {
+ let formData = new FormData()
+ formData.append("file", file, file.name)
+ let data = { keepOriginalName: 'true' }
+ return this.http.post(ObjectsService.baseUrl + extensionPath, formData, { params: data });
+ }
+
+
+
+
+ //分块上传
+ static baseUrl_MultipartUpload = ObjectsService.c_apiRoot_Multipart + 'NewMultipartUpload/PlanPlatform/';
+ // {
+ // "objectName": "string",
+ // "uploadId": "string"
+ // }
+ postFile_MultipartUpload(extensionPath: string, file: File): Promise {
+ // let formData = new FormData()
+ // formData.append("file", file, file.name)
+ // return this.http.post(ObjectsService.baseUrl + extensionPath, formData);
+ let data = { keepOriginalName: 'true', filename: file.name }
+ return new Promise((resolve, reject) => {
+ this.http.post(ObjectsService.baseUrl_MultipartUpload + extensionPath, {}, { params: data }).subscribe(async (data: any) => { //初始化分段上传
+ let objectName = data.objectName
+ let uploadId = data.uploadId
+ let PartNumberETag = []; //每次返回需要保存的信息
+ //分块 处理
+ let fileSize = file.size || null //上传文件的总大小
+ let shardSize = 5 * 1024 * 1024 //5MB一个分片
+ let allSlice = Math.ceil(fileSize / shardSize) //总文件/5MB===共分多少段
+
+ for (let i = 0; i < allSlice; i++) { //循环分段上传
+ let start = i * shardSize //切割文件开始位置
+ let end = Math.min(fileSize, start + shardSize); //切割文件结束位置
+ let formData = new FormData()
+ formData.append("file", file.slice(start, end))
+
+ //同步写法实现异步调用
+ let result = await new Promise((resolve, reject) => {
+ // await 需要后面返回一个 promise 对象
+ this.http.post(ObjectsService.c_apiRoot_Multipart + `MultipartUpload/PlanPlatform/${objectName}?uploadId=${uploadId}&partNumber=${i + 1}`, formData).subscribe((data: any) => {
+ let msg = { "partNumber": data.partNumber || null, "eTag": data.eTag || null }
+ resolve(msg) // 调用 promise 内置方法处理成功
+ })
+ });
+ PartNumberETag.push(result)
+
+ if (PartNumberETag.length === allSlice) { //分块上传完成
+ let data = PartNumberETag
+ let paramsData = { uploadId: uploadId };
+ let path = ObjectsService.c_apiRoot_Multipart + 'CompleteMultipartUpload/PlanPlatform/' + objectName;
+ this.http.post(path, data, { params: paramsData }).subscribe(data => {
+ let objData: any = new Object();
+ objData.fileName = file.name;
+ objData.filePath = (ObjectsService.baseUrl + objectName).replace(file.name, "");
+ resolve(objData)
+ })
+ }
+ }//for循环
+
+ //分块 处理
+ })
+ })
+ }
+}
diff --git a/src/app/ui/material-bank/addmatlibrary.component.ts b/src/app/ui/material-bank/addmatlibrary.component.ts
index 366b348..b6f2eef 100644
--- a/src/app/ui/material-bank/addmatlibrary.component.ts
+++ b/src/app/ui/material-bank/addmatlibrary.component.ts
@@ -5,9 +5,6 @@ import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { MatSnackBar } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
-
-
@Component({
selector: 'addmatlibrary',
@@ -33,8 +30,19 @@ import format from 'date-fns/format';
order:number; //order
onSubmit(value){
+
let newdate = new Date();
- let time = format(newdate, 'yyyy-MM-dd')
+ function getDate(date){
+ //date是传过来的时间戳,注意需为13位,10位需*1000
+ //也可以不传,获取的就是当前时间
+ var time = new Date(date);
+ var year= time.getFullYear() //年
+ var month = ("0" + (time.getMonth() + 1)).slice(-2); //月
+ var day = ("0" + time.getDate()).slice(-2); //日
+ var mydate = year + "-" + month + "-" + day;
+ return mydate
+ }
+ let time = getDate(newdate)
this.http.post("/api/AssetLibraries",{
id: "",
name: value.name,
diff --git a/src/app/ui/material-bank/addoriginalcopy.component.ts b/src/app/ui/material-bank/addoriginalcopy.component.ts
index abe2bea..628e65f 100644
--- a/src/app/ui/material-bank/addoriginalcopy.component.ts
+++ b/src/app/ui/material-bank/addoriginalcopy.component.ts
@@ -4,7 +4,6 @@ import {FlatTreeControl} from '@angular/cdk/tree';
import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
-import format from 'date-fns/format';
import { TreeService } from '../../http-interceptors/tree.service'
import { FileUploader } from 'ng2-file-upload'
import { MatSnackBar,MatSnackBarConfig } from '@angular/material/snack-bar';
diff --git a/src/app/ui/material-bank/editmatlibrary.component.ts b/src/app/ui/material-bank/editmatlibrary.component.ts
index fcbba63..101fbee 100644
--- a/src/app/ui/material-bank/editmatlibrary.component.ts
+++ b/src/app/ui/material-bank/editmatlibrary.component.ts
@@ -5,7 +5,7 @@ import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { MatSnackBar } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
+// import format from 'date-fns/format';
@Component({
selector: 'editmatlibrary',
templateUrl: './editmatlibrary.component.html',
@@ -26,7 +26,17 @@ import format from 'date-fns/format';
}
onSubmit(value){
let newdate = new Date();
- let time = format(newdate, 'yyyy-MM-dd')
+ function getDate(date){
+ //date是传过来的时间戳,注意需为13位,10位需*1000
+ //也可以不传,获取的就是当前时间
+ var time = new Date(date);
+ var year= time.getFullYear() //年
+ var month = ("0" + (time.getMonth() + 1)).slice(-2); //月
+ var day = ("0" + time.getDate()).slice(-2); //日
+ var mydate = year + "-" + month + "-" + day;
+ return mydate
+ }
+ let time = getDate(newdate)
this.http.put(`/api/AssetLibraries/${this.data.material.id}`,{
id: this.data.material.id,
name: value.name,
diff --git a/src/app/ui/material-bank/editoriginalcopy.component.ts b/src/app/ui/material-bank/editoriginalcopy.component.ts
index 4a7f751..47b70c7 100644
--- a/src/app/ui/material-bank/editoriginalcopy.component.ts
+++ b/src/app/ui/material-bank/editoriginalcopy.component.ts
@@ -5,7 +5,6 @@ import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { MatSnackBar,MatSnackBarConfig } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
import { TreeService } from '../../http-interceptors/tree.service'
import { FileUploader } from 'ng2-file-upload'
import { DomSanitizer } from '@angular/platform-browser'
diff --git a/src/app/ui/material-bank/material-bank.component.ts b/src/app/ui/material-bank/material-bank.component.ts
index ae0decb..62db7d5 100644
--- a/src/app/ui/material-bank/material-bank.component.ts
+++ b/src/app/ui/material-bank/material-bank.component.ts
@@ -8,7 +8,7 @@ import { MatTableDataSource } from '@angular/material/table';
import { EditOriginalCopy } from './editoriginalcopy.component'
import { SelectOriginalCopy } from './selectoriginalcopy.component'
import { MatSnackBar,MatSnackBarConfig } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
+// import format from 'date-fns/format';
@@ -145,7 +145,17 @@ export class MaterialBankComponent implements OnInit {
//禁启用素材库
disabled(){
let newdate = new Date();
- let time = format(newdate, 'yyyy-MM-dd')
+ function getDate(date){
+ //date是传过来的时间戳,注意需为13位,10位需*1000
+ //也可以不传,获取的就是当前时间
+ var time = new Date(date);
+ var year= time.getFullYear() //年
+ var month = ("0" + (time.getMonth() + 1)).slice(-2); //月
+ var day = ("0" + time.getDate()).slice(-2); //日
+ var mydate = year + "-" + month + "-" + day;
+ return mydate
+ }
+ let time = getDate(newdate)
if(this.material.enabled){
this.http.put(`/api/AssetLibraries/${this.material.id}`,{
id: this.material.id,
diff --git a/src/app/ui/material-bank/selectoriginalcopy.component.ts b/src/app/ui/material-bank/selectoriginalcopy.component.ts
index 65d195f..8b7ad7b 100644
--- a/src/app/ui/material-bank/selectoriginalcopy.component.ts
+++ b/src/app/ui/material-bank/selectoriginalcopy.component.ts
@@ -5,7 +5,6 @@ import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { MatSnackBar } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
@Component({
selector: 'selectoriginalcopy',
templateUrl: './selectoriginalcopy.component.html',
diff --git a/src/app/ui/role/role.component.ts b/src/app/ui/role/role.component.ts
index 8fd68ca..144f439 100644
--- a/src/app/ui/role/role.component.ts
+++ b/src/app/ui/role/role.component.ts
@@ -3,7 +3,7 @@ import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog
import {FormControl} from '@angular/forms';
import { HttpClient } from '@angular/common/http';
import { CacheTokenService } from '../../http-interceptors/cache-token.service'
-import format from 'date-fns/format';
+// import format from 'date-fns/format';
import {MatTreeFlatDataSource, MatTreeFlattener} from '@angular/material/tree';
import {FlatTreeControl} from '@angular/cdk/tree';
import { TreeService } from '../../http-interceptors/tree.service'
@@ -51,7 +51,17 @@ export class RoleComponent implements OnInit {
//向上按钮
up(node){
let newdate = new Date();
- let time = format(newdate, 'yyyy-MM-dd')
+ function getDate(date){
+ //date是传过来的时间戳,注意需为13位,10位需*1000
+ //也可以不传,获取的就是当前时间
+ var time = new Date(date);
+ var year= time.getFullYear() //年
+ var month = ("0" + (time.getMonth() + 1)).slice(-2); //月
+ var day = ("0" + time.getDate()).slice(-2); //日
+ var mydate = year + "-" + month + "-" + day;
+ return mydate
+ }
+ let time = getDate(newdate)
this.http.put(//把上一节点order换成点击的节点
`/api/Roles/${this.dataSource[node.order -1].id}`,
{
@@ -82,7 +92,17 @@ export class RoleComponent implements OnInit {
//向下按钮
down(node){
let newdate = new Date();
- let time = format(newdate, 'yyyy-MM-dd')
+ function getDate(date){
+ //date是传过来的时间戳,注意需为13位,10位需*1000
+ //也可以不传,获取的就是当前时间
+ var time = new Date(date);
+ var year= time.getFullYear() //年
+ var month = ("0" + (time.getMonth() + 1)).slice(-2); //月
+ var day = ("0" + time.getDate()).slice(-2); //日
+ var mydate = year + "-" + month + "-" + day;
+ return mydate
+ }
+ let time = getDate(newdate)
this.http.put(//把下一节点order换成点击的节点
`/api/Roles/${this.dataSource[node.order + 1].id}`,
{
@@ -151,7 +171,17 @@ export class RoleComponent implements OnInit {
//启用或禁用按钮
open(roledata){
let newdate = new Date();
- let time = format(newdate, 'yyyy-MM-dd')
+ function getDate(date){
+ //date是传过来的时间戳,注意需为13位,10位需*1000
+ //也可以不传,获取的就是当前时间
+ var time = new Date(date);
+ var year= time.getFullYear() //年
+ var month = ("0" + (time.getMonth() + 1)).slice(-2); //月
+ var day = ("0" + time.getDate()).slice(-2); //日
+ var mydate = year + "-" + month + "-" + day;
+ return mydate
+ }
+ let time = getDate(newdate)
this.http.put(
`/api/Roles/${roledata['id']}`,
{
@@ -296,7 +326,17 @@ export class CreateRole {
//提交
onSubmit(value){
let newdate = new Date();
- let time = format(newdate, 'yyyy-MM-dd')
+ function getDate(date){
+ //date是传过来的时间戳,注意需为13位,10位需*1000
+ //也可以不传,获取的就是当前时间
+ var time = new Date(date);
+ var year= time.getFullYear() //年
+ var month = ("0" + (time.getMonth() + 1)).slice(-2); //月
+ var day = ("0" + time.getDate()).slice(-2); //日
+ var mydate = year + "-" + month + "-" + day;
+ return mydate
+ }
+ let time = getDate(newdate)
this.http.post(
'/api/Roles',
{
@@ -537,7 +577,17 @@ export class EditRole {
}
}
let newdate = new Date();
- let time = format(newdate, 'yyyy-MM-dd')
+ function getDate(date){
+ //date是传过来的时间戳,注意需为13位,10位需*1000
+ //也可以不传,获取的就是当前时间
+ var time = new Date(date);
+ var year= time.getFullYear() //年
+ var month = ("0" + (time.getMonth() + 1)).slice(-2); //月
+ var day = ("0" + time.getDate()).slice(-2); //日
+ var mydate = year + "-" + month + "-" + day;
+ return mydate
+ }
+ let time = getDate(newdate)
if(this.data['id'] != "0" && this.data['id'] != "1"){
this.http.put(
`/api/Roles/${this.data['id']}`,
diff --git a/src/app/ui/unit-information/addgroups.component.ts b/src/app/ui/unit-information/addgroups.component.ts
index b71963a..7fcf6a4 100644
--- a/src/app/ui/unit-information/addgroups.component.ts
+++ b/src/app/ui/unit-information/addgroups.component.ts
@@ -5,9 +5,6 @@ import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { MatSnackBar } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
-
-
@Component({
selector: 'addgroups',
diff --git a/src/app/ui/unit-information/addunitinfo.component.ts b/src/app/ui/unit-information/addunitinfo.component.ts
index 60a0e2f..881fede 100644
--- a/src/app/ui/unit-information/addunitinfo.component.ts
+++ b/src/app/ui/unit-information/addunitinfo.component.ts
@@ -5,7 +5,6 @@ import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { MatSnackBar } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
@Component({
selector: 'addunitinfo',
templateUrl: './addunitinfo.component.html',
diff --git a/src/app/ui/unit-information/editgroup.component.ts b/src/app/ui/unit-information/editgroup.component.ts
index 4bc9385..3103381 100644
--- a/src/app/ui/unit-information/editgroup.component.ts
+++ b/src/app/ui/unit-information/editgroup.component.ts
@@ -5,8 +5,6 @@ import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { MatSnackBar } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
-
@Component({
diff --git a/src/app/ui/unit-information/editunitinfo.component.ts b/src/app/ui/unit-information/editunitinfo.component.ts
index 749645d..fd4432c 100644
--- a/src/app/ui/unit-information/editunitinfo.component.ts
+++ b/src/app/ui/unit-information/editunitinfo.component.ts
@@ -5,7 +5,6 @@ import { HttpClient } from '@angular/common/http';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { MatSnackBar } from '@angular/material/snack-bar';
-import format from 'date-fns/format';
@Component({
selector: 'editunitinfo',
templateUrl: './editunitinfo.component.html',
diff --git a/src/app/ui/userdata/userdata.component.ts b/src/app/ui/userdata/userdata.component.ts
index 6df0a23..539ad95 100644
--- a/src/app/ui/userdata/userdata.component.ts
+++ b/src/app/ui/userdata/userdata.component.ts
@@ -4,7 +4,6 @@ import {MatTableDataSource} from '@angular/material/table';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import {FormControl} from '@angular/forms';
import { HttpClient,HttpHeaders } from '@angular/common/http';
-import format from 'date-fns/format';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
diff --git a/src/app/working-area/model/axLegend.ts b/src/app/working-area/model/axLegend.ts
index fd47146..51efe69 100644
--- a/src/app/working-area/model/axLegend.ts
+++ b/src/app/working-area/model/axLegend.ts
@@ -24,10 +24,10 @@ export class AxLegend extends AxShape {
super(assetData, workingArea);
this.angle = -this.workingArea.backgroundImage.angle;
this.name = this.assetData.Id;
- this.pivot.set(this.assetData.PivotX, this.assetData.PivotY);
+ this.pivot.set(this.assetData.PivotX == undefined ? 0 : this.assetData.PivotX, this.assetData.PivotY == undefined ? 0 : this.assetData.PivotY);
this.x = this.assetData.Point.x;
this.y = this.assetData.Point.y;
- this.scale.set(this.assetData.Scale);
+ this.scale.set(this.assetData.Scale == undefined ? 1 : this.assetData.Scale);
this.shapeMap = shapeMap;
this.createPoint();
this.refresh();
diff --git a/src/app/working-area/working-area.component.ts b/src/app/working-area/working-area.component.ts
index 7c2db23..6f723ea 100644
--- a/src/app/working-area/working-area.component.ts
+++ b/src/app/working-area/working-area.component.ts
@@ -16,7 +16,6 @@ import { PropertyInfo } from './model/PropertyInfo';
import { AxPreviewImageShape } from './model/axPreviewImageShape';
import { AxArrowConnector } from './model/axArrowConnector';
import { AxLegend, Legend } from './model/axLegend';
-import { AxGrid } from './model/axGrid';
import { AxSelection } from './model/axSelection';
import { AxMessageSystem } from './model/axMessageSystem';
import { Grid2D } from './model/grid2D';
@@ -24,7 +23,7 @@ import { Viewport } from 'pixi-viewport';
import { EVENT_IMAGE_RESIZE, EVENT_SELECTION_CHANGED } from './model/events';
import { Dimensioning } from './model/dimensioning';
import { Configuration, viewBounds } from './model/configuration';
-import { id } from 'date-fns/locale';
+
@Component({
@@ -1099,6 +1098,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
imageWidth: number = this.canvasData.selectStorey.imageWidth,
imageHeight: number = this.canvasData.selectStorey.imageHeight,
): Promise {
+ console.log('当前背景图',imageUrl)
if (imageAngle === undefined || imageAngle === null) {
imageAngle = 0;
}
diff --git a/src/assets/images/add2.png b/src/assets/images/add2.png
new file mode 100644
index 0000000..684b1f4
Binary files /dev/null and b/src/assets/images/add2.png differ
diff --git a/src/assets/images/goback.png b/src/assets/images/goback.png
new file mode 100644
index 0000000..34cb58c
Binary files /dev/null and b/src/assets/images/goback.png differ
diff --git a/src/assets/images/uploadbtn.png b/src/assets/images/uploadbtn.png
new file mode 100644
index 0000000..315b1bf
Binary files /dev/null and b/src/assets/images/uploadbtn.png differ
diff --git a/src/styles.scss b/src/styles.scss
index 9391785..a3e5af9 100644
--- a/src/styles.scss
+++ b/src/styles.scss
@@ -1,107 +1,144 @@
-
-@import './app/theme.scss';
+@import "./app/theme.scss";
@import "./app/ngZorroTree.css"; /* 引入组件样式 */
-// @import "~ng-zorro-antd/select/style/index.min.css"; /* 引入组件样式 */
-@font-face
-{
+// @import "~ng-zorro-antd/style/index.min.css"; /* 引入基本样式 */
+@import "~ng-zorro-antd/tree-select/style/index.min.css"; /* 引入组件样式 */
+@font-face {
font-family: Regular;
- src: url('./assets/font/SourceHanSansCN-Regular.otf'),
+ src: url("./assets/font/SourceHanSansCN-Regular.otf");
}
-html,body{
+html,
+body {
touch-action: none;
- width: 100%;
- height:100%;
- margin:0 auto;
- padding:0;
+ width: 100%;
+ height: 100%;
+ margin: 0 auto;
+ padding: 0;
overflow: hidden;
font-family: Regular;
- textarea{
- font-family: Regular
+ textarea {
+ font-family: Regular;
}
- user-select:auto!important
-}
-ul,ol,dl,li,dt,dd,p,form,input,h1,h2,h3,h4,h5,h6,section,article,aside,header,footer,nav,figure,time,mark,main,canvas{
- margin:0;
- padding:0;
-}
-b,strong,i,em,h1,h2,h3,h4,h5,h6{
- font-weight:500;
- font-style:normal;
-}
-img{
- border:none;
+ user-select: auto !important;
+}
+ul,
+ol,
+dl,
+li,
+dt,
+dd,
+p,
+form,
+input,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+section,
+article,
+aside,
+header,
+footer,
+nav,
+figure,
+time,
+mark,
+main,
+canvas {
+ margin: 0;
+ padding: 0;
}
-a{
+b,
+strong,
+i,
+em,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6 {
+ font-weight: 500;
+ font-style: normal;
+}
+img {
+ border: none;
+}
+a {
text-decoration: none;
- color:#000;
+ color: #000;
}
-ul,ol,li{
- list-style:none;
+ul,
+ol,
+li {
+ list-style: none;
overflow-x: hidden;
}
-.clearfn:after{
- content:"";
- clear:both;
+.clearfn:after {
+ content: "";
+ clear: both;
display: block;
- overflow:hidden;
- height:0;
+ overflow: hidden;
+ height: 0;
visibility: hidden;
}
//root标签
-app-root{
+app-root {
height: 100%;
}
-h1{
+h1 {
font-size: 16px;
}
.mat-expansion-panel-body {
padding: 0px !important;
}
.mat-expansion-indicator::after {
- color: white;
+ color: white;
}
.example-sidenav .mat-drawer-inner-container {
overflow: hidden;
}
-table th.mat-header-cell:last-of-type,table td.mat-cell:last-of-type,
-table td.mat-footer-cell:last-of-type{
+table th.mat-header-cell:last-of-type,
+table td.mat-cell:last-of-type,
+table td.mat-footer-cell:last-of-type {
padding-right: 0px;
}
-.mat-tab-body{
- height: 100%;
- overflow-y: auto;
+.mat-tab-body {
+ height: 100%;
+ overflow-y: auto;
}
-.mat-content { //可展开面板垂直居中
- align-items: center;
+.mat-content {
+ //可展开面板垂直居中
+ align-items: center;
}
//滚动条样式
-::-webkit-scrollbar{
- width: 5px;
- background-color: white;
+::-webkit-scrollbar {
+ width: 5px;
+ background-color: white;
}
-::-webkit-scrollbar-thumb{
- background-color: #999;
+::-webkit-scrollbar-thumb {
+ background-color: #999;
}
//x轴滚动条隐藏
-.example-sidenav-content {
- overflow-x: hidden; overflow-y: auto;
- }
-
-
+.example-sidenav-content {
+ overflow-x: hidden;
+ overflow-y: auto;
+}
-.mat-tab-body-wrapper{
+.mat-tab-body-wrapper {
height: 100%;
}
-.mat-tab-body-content{
- overflow: hidden!important;
+.mat-tab-body-content {
+ overflow: hidden !important;
}
//gis单位信息tabs样式
-#gis{
- .mat-tab-label{
+#gis {
+ .mat-tab-label {
height: 38px;
line-height: 38px;
min-width: 80px;
@@ -109,26 +146,33 @@ table td.mat-footer-cell:last-of-type{
}
}
//可展开面板按钮颜色
-#gisbasicinfo,#planlist,#allaround,#firefacilities,#keysite,#functionpartition,#realisticpicture{
+#gisbasicinfo,
+#planlist,
+#allaround,
+#firefacilities,
+#keysite,
+#functionpartition,
+#realisticpicture {
.mat-expansion-indicator::after {
color: #333333;
}
}
-#waitexamineergis{
+#waitexamineergis {
.mat-expansion-indicator::after {
color: #fff;
}
- mat-expansion-panel{
- box-shadow: 0 0 black;border: 1px solid #EEF1F5;
+ mat-expansion-panel {
+ box-shadow: 0 0 black;
+ border: 1px solid #eef1f5;
}
}
//gis标点弹出框样式
-#gispopupbox{
- .btn{
+#gispopupbox {
+ .btn {
width: 92px;
height: 36px;
- background: #FFFFFF;
- border: 1px solid #EEF1F5;
+ background: #ffffff;
+ border: 1px solid #eef1f5;
opacity: 1;
border-radius: 4px;
margin: 0 5px;
@@ -136,76 +180,84 @@ table td.mat-footer-cell:last-of-type{
// font-family: Source Han Sans CN;
font-weight: 400;
line-height: 36px;
- color: #0080FF;
+ color: #0080ff;
opacity: 1;
cursor: pointer;
display: table-cell; //主要是这个属性
text-align: center;
- img{
+ img {
vertical-align: middle;
margin-right: 3px;
padding-bottom: 2px;
}
}
-
}
//弹出框样式取消padding
-#shareDialog,#lookPlanDialog,#openPlanToolDialog,#addWater,#videodialog,#addLinkageForce,#videodialog2,#gisImgDialog{
+#shareDialog,
+#lookPlanDialog,
+#openPlanToolDialog,
+#addWater,
+#addCar,
+#videodialog,
+#addLinkageForce,
+#videodialog2,
+#gisImgDialog {
padding: 0;
}
-#setPosition,#map{
+#setPosition,
+#map {
.custom-content-marker {
position: relative;
width: 29px;
height: 36px;
}
-
+
.custom-content-marker img {
width: 100%;
height: 100%;
}
-
+
.custom-content-marker .btnbox {
position: absolute;
left: -20px;
bottom: -36px;
width: 68px;
height: 30px;
- background:#FFFFFF;
+ background: #ffffff;
border-radius: 60px;
- color: #EBEBEB;
+ color: #ebebeb;
display: flex;
justify-content: space-around;
box-sizing: border-box;
- padding: 0 5px;
+ padding: 0 5px;
align-items: center;
- img{
+ img {
width: 20px;
height: 20px;
cursor: pointer;
}
}
- .custom-content-marker .close-btn:hover{
+ .custom-content-marker .close-btn:hover {
background: #666;
}
}
-#fireForceTree{
- .mat-tree-node{
+#fireForceTree {
+ .mat-tree-node {
min-height: 40px;
flex: none;
box-sizing: border-box;
}
- .mat-icon-button{
+ .mat-icon-button {
width: 30px;
height: 30px;
line-height: 30px;
}
}
-#linkageForcesSwiper{
- .swiper-container{
- --swiper-navigation-size: 26px;/* 设置按钮大小 */
+#linkageForcesSwiper {
+ .swiper-container {
+ --swiper-navigation-size: 26px; /* 设置按钮大小 */
}
}
.KedaPosImg {
@@ -221,47 +273,48 @@ table td.mat-footer-cell:last-of-type{
background: no-repeat center;
}
//点聚合自定义图片大小
-.clusterImg{
+.clusterImg {
width: 30px;
height: 30px;
}
//水源采集点聚合
-.clusterImgCollection{
- width:30px;
- height:30px;
+.clusterImgCollection {
+ width: 30px;
+ height: 30px;
}
-#unitBasicInfo{
- .mat-expansion-indicator::after{
+#unitBasicInfo {
+ .mat-expansion-indicator::after {
color: black;
}
}
-td{
- word-break:break-all;
+td {
+ word-break: break-all;
}
-@media screen and (max-width:1400px){
- .mat-toolbar-row, .mat-toolbar-single-row {
- height: 50px!important;
+@media screen and (max-width: 1400px) {
+ .mat-toolbar-row,
+ .mat-toolbar-single-row {
+ height: 50px !important;
}
}
-#firefightingdevicelook,#firefightingdevice{
- .expansionheader{
- height: auto!important;
+#firefightingdevicelook,
+#firefightingdevice {
+ .expansionheader {
+ height: auto !important;
}
-
}
-#planContainer{
+#planContainer {
.custom-content-marker {
position: relative;
width: 28px;
height: 28px;
- }
-
- .custom-content-marker img {
+ }
+
+ .custom-content-marker img {
width: 100%;
height: 100%;
- }
-
- .custom-content-marker .close-btn {
+ }
+
+ .custom-content-marker .close-btn {
position: absolute;
top: -6px;
right: -8px;
@@ -273,15 +326,16 @@ td{
color: #fff;
text-align: center;
line-height: 15px;
- box-shadow: -1px 1px 1px rgba(10, 10, 10, .2);
- }
-
- .custom-content-marker .close-btn:hover{
+ box-shadow: -1px 1px 1px rgba(10, 10, 10, 0.2);
+ }
+
+ .custom-content-marker .close-btn:hover {
background: #666;
- }
+ }
}
-#setUnitPosition,#setUnitPositionLook{
+#setUnitPosition,
+#setUnitPositionLook {
.custom-content-marker {
position: relative;
// border: 1px solid red;
@@ -335,4 +389,63 @@ td{
.custom-content-marker .close-btn:hover {
background: #666;
}
+}
+.mat-paginator-container {
+ min-height: 40px !important;
+}
+#carcontent {
+ .cartopbox {
+ nz-tree-select {
+ width: 81.4%;
+ margin-right: 22px;
+ }
+ .ant-select-selector {
+ background-color: #f2f4f6;
+ height: 40px;
+ border: none;
+ border-radius: 5px;
+ padding-top: 5px;
+ box-sizing: border-box;
+ width: 104.7%;
+ }
+ input{
+ height: 40px;
+ }
+
+
+ }
+ .carTwoItemBox{
+ nz-tree-select {
+ width: 71.6%;
+ margin-right: 22px;
+ }
+ .ant-select-selector {
+ height: 34px;
+ border: none;
+ border-radius: 4px;
+ border: 1px solid #EBEBEB;
+ box-sizing: border-box;
+ padding-top: 1px;
+ width: 104.9%;
+ }
+ }
+ .carTwoItemBox2,.carTwoItemBox3{
+ nz-tree-select {
+ width: 64.3%;
+ margin-right: 22px;
+ }
+ .ant-select-selector {
+ height: 34px;
+ border: none;
+ border-radius: 4px;
+ border: 1px solid #EBEBEB;
+ box-sizing: border-box;
+ padding-top: 1px;
+ width: 104.9%;
+ }
+ }
+}
+
+.carTreeDropdown{
+ max-height: 239px;
}
\ No newline at end of file