Selaa lähdekoodia

Merge branch 'version1.2.1' of http://192.168.2.236:10080/zhouna/AIPlatform into version1.2.1

luolei 5 vuotta sitten
vanhempi
commit
02311d9e74

+ 393 - 0
src/css/assertType.less

@@ -0,0 +1,393 @@
+@import './reset.less';
+
+.container{
+    width: 100%;
+    height: 100%;
+    overflow: auto;
+    background-color: #fff;
+}
+.assertType {
+    .dayFilter {
+        .levelList {
+            height: 80px;
+        }
+        .selectLevel,.levelList  {
+            width: 180px;
+        }
+        .deptListWrap {
+            display: none;
+        }
+    }
+    .filterItem.deptListWrap {
+        .selectDept,.deptList {
+            width: 180px;
+        }
+    }
+    ul,li{
+        list-style: none;
+    }
+    h2{
+        width: 100%;
+        box-sizing: border-box;
+        background-color: #fff;
+        z-index: 20;
+        height: 44px;
+        line-height: 44px;
+        padding: 0 0 0 15px;
+        border-bottom: 1px solid #E2E5EF;
+        font-size: 16px;
+        font-weight: bold   ;
+        letter-spacing: 1px;
+    }
+    .main-body{
+        margin: 20px 0;
+        padding: 0 35px;
+        min-width: 1090px;
+        /*width: 100%;*/
+    }
+    table{
+        .table;
+        min-width: 1090px;
+        th,td{
+            text-align: center;
+        }
+        th{
+            white-space: nowrap;
+        }
+        th[code]{
+            cursor: pointer;
+            &:after{
+                content:"";
+                display:inline-block;
+                width: 11px;
+                height: 14px;
+                margin-left: 4px;
+                vertical-align: middle;
+                background: url("../images/grey.png");
+            }
+            &.asc:after{
+                background: url("../images/up_blue.png");
+            }
+            &.desc:after{
+                background: url("../images/down_blue.png");
+            }
+        }
+        td{
+            white-space: nowrap;
+        }
+        .moduleNumber{
+            text-align: center;
+        }
+        .scoreOperaItem{
+            width: 50px;
+            cursor: pointer;
+        }
+        
+    }
+    .tabFoot{
+        height: 40px;
+        /*border: 1px solid #E2E5EF;
+        border-top: none;
+        box-sizing: border-box;*/
+    }
+    .scoreOpera{
+        height: 50px;
+        line-height: 50px;
+        margin: 0 20px 0 0;
+        cursor: pointer;
+        img{
+            margin: 0 10px 0 0;
+        }
+    }
+    
+    .recordScoreOperaBtn{
+        cursor: pointer;
+        color: @activeColor;
+    }
+    .recordScoreBtn{
+        cursor: pointer;
+        display: inline-block;
+        width:68px;
+        height:30px;
+        line-height: 30px;
+        text-align: center;
+        border-radius:4px;
+        box-sizing: border-box;
+        border: 1px solid @activeColor;
+        color: @activeColor;
+    }
+    .filterBox{
+        margin-bottom: 15px;
+    }
+    .filterItem{
+        position: relative;
+        display: inline-block;
+        float: left;
+        height: 40px;
+        line-height: 40px;
+        margin: 0 20px 15px 0;
+        span{
+            display: inline-block;
+            line-height: 40px;
+            position: relative;
+        }
+        input{
+            width:120px;
+            height:40px;
+            border-radius:4px;
+            border: 1px solid #E2E5EF;
+            outline: none;
+            margin-right: 10px;
+            padding: 0 10px;
+            box-sizing: border-box;
+        }
+    }
+    
+    .filterDropList{
+        position: absolute;
+        right: 0;
+        max-height: 200px;
+        overflow-y: auto;
+        background: #fff;
+        display: none;
+        border: 1px solid #e4e7ed;
+        box-shadow: 0 2px 12px 0 #e4e7ed;
+        z-index: 2;
+        li{
+            padding: 0 10px;
+        }
+    }
+    .deptList{
+        width: 160px;
+        max-height: 400px;
+    }
+    .levelList{
+        width: 120px;
+        height: 120px;
+        li:hover{
+            background-color: #EEF4FF;
+            cursor: pointer;
+        }
+    }
+    .selectLevel,.selectDept{
+        display: inline-block;
+        position: relative;
+        width:120px;
+        padding: 0 10px;
+        height:40px;
+        border-radius:4px;
+        border: 1px solid #E2E5EF;
+        box-sizing: border-box;
+        cursor: pointer;
+    }
+    .selectDept{
+        width: 160px;
+    }
+    
+    .filter{
+        display: inline-block;
+        width:60px;
+        height:36px;
+        background:@activeColor;
+        border-radius:4px;
+        color: #fff;
+        text-align: center;
+        line-height: 36px;
+        position: relative;
+        top: 2px;
+        cursor: pointer;
+        float: left;
+    }
+    .arrow{
+        position: absolute;
+        width: 10px;
+        top: 16px;
+        right: 10px;
+    }
+    .iconCheck{
+        width: 14px;
+    }
+    .fl{
+        float: left;
+    }
+    .clearfix:after {
+        content: '';
+        height: 0;
+        line-height: 0;
+        display: block;
+        visibility: hidden;
+        clear: both;
+    }
+    .clearfix{
+        zoom:1
+    }
+    .divide{
+        margin: 0 10px;
+    }
+    .datapickerBox{
+        position: relative;
+        display: inline-block;
+        width: 120px;
+        height: 40px;
+        input{
+            position: absolute;
+        }
+    }
+    .iconCalen{
+        position: absolute;
+        width: 15px;
+        top: 12px;
+        right: 10px;
+    }
+    .textCenter{
+        text-align: center;
+    }
+    .patientNameSpan{
+        color: #00A1F0;
+        cursor: pointer;
+    }
+    .patientNameSpans{
+        color: #FF4D4F;
+        cursor: pointer;
+        margin-left: 30px;
+    }
+    
+    .deptItem:hover{
+        background-color: #EEF4FF;
+        cursor: pointer;
+    }
+    .ellipsis{
+        overflow: hidden;
+        text-overflow:ellipsis;
+        white-space: nowrap;
+    }
+    
+    
+    .pagination{
+        margin: 35px 0 0 0  ;
+        text-align: right;
+    }
+    .totalSum{
+        font-size:12px;
+        line-height:17px;
+        color: #777777;
+        margin-right: 20px;
+    }
+    .pageNum,.prePage,.nextPage, .more{
+        display: inline-block;
+        width: 20px;
+        cursor: pointer;
+        margin: 0 20px 0 0;
+        text-align: center;
+        color: #777;
+    }
+    .prePage,.nextPage{
+        img{
+            position: relative;
+            top: 0px   ;
+        }
+    }
+     .more{
+        cursor: not-allowed;
+    }
+    .arrowPage{
+        width: 6px;
+    }
+    .activePage{
+        color: @activeColor;
+    }
+    
+    
+    
+    .ui-datepicker-calendar {
+        border: 0 none;
+        min-width: 0;
+    }
+    .ui-datepicker thead {
+        background-color: #fff;
+        color: #c3cbd6;
+    }
+    .ui-datepicker td {
+        padding: 0;
+        height: auto;
+        color: #657180;
+    }
+    .ui-datepicker td span, .ui-datepicker td a {
+        text-align: center;
+        height: 30px;
+        line-height: 30px;
+    }
+    
+    .ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default {
+        border: 0;
+        background-color: #fff;
+        &:hover {
+            background-color: #c4d8fe;
+        }
+    }
+    .ui-datepicker select.ui-datepicker-month, .ui-datepicker select.ui-datepicker-year {
+        color: #333;
+        font-weight: normal;
+        height: 30px;
+        line-height: 30px;
+        margin: 0 5px;
+        width: 40%;
+        border-radius: 3px;
+    }
+    .ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next {
+        top: 5px;
+    }
+    .ui-state-active, .ui-widget-content .ui-state-active {
+        background-color: @activeColor !important;
+        color: #fff;
+    }
+    .ui-state-highlight, .ui-widget-content .ui-state-highlight {
+        background-color: #fff5bf !important;
+        color: #657180;
+    }
+    .ui-widget-header {
+        background-color: #fff;
+        border: 0 none;
+    }
+    
+    input::-webkit-outer-spin-button,
+    input::-webkit-inner-spin-button {
+        -webkit-appearance: none;
+    }
+     
+    input[type="number"] {
+        -moz-appearance: textfield;
+    }
+}
+.addTypeAssert {
+    display: inline-block;
+    width: 100px;
+    height: 32px;
+    background: #00A1FF;
+    border-radius: 4px;
+    color: #fff;
+    text-align: center;
+    line-height: 32px;
+    cursor: pointer;
+    float: left;
+    margin-left: 15px;
+    a {
+        color: #fff;
+    }
+}
+.assertTypeActive {
+    padding-left: 30px !important;
+    text-align: center;
+    overflow: hidden;
+    span {
+        border-right: 1px solid #ccc;
+        padding: 0 8px;
+        float: left;
+        cursor: pointer;
+        box-sizing: border-box;
+        color: #00A1F0;
+    }
+    .assertTypeDel {
+        border-right: 1px solid transparent;
+    }
+}

+ 89 - 0
src/css/assertTypeDetail.less

@@ -0,0 +1,89 @@
+@import './reset.less';
+.container{
+    width: 100%;
+    height: 100%;
+    overflow: auto;
+    background-color: #fff;
+}
+.assertTypeDetail {
+    
+    .filterBox{
+        margin-bottom: 15px;
+    }
+    .main-body{
+        margin: 20px 0;
+        padding: 0 35px;
+        min-width: 1090px;
+        /*width: 100%;*/
+    }
+    .filterItem{
+        position: relative;
+        height: 40px;
+        line-height: 40px;
+        margin: 0 20px 15px 0;
+        float: none !important;
+        span{
+            display: inline-block;
+            line-height: 40px;
+            position: relative;
+        }
+        .explainL:before {
+            content: "*";
+            color: #f56c6c;
+            margin-right: 4px;
+        }
+        input{
+            width:120px;
+            height:40px;
+            border-radius:4px;
+            border: 1px solid #E2E5EF;
+            outline: none;
+            margin-right: 10px;
+            padding: 0 10px;
+            box-sizing: border-box;
+        }
+    }
+    
+    .selectLevel,.selectDept{
+        display: inline-block;
+        position: relative;
+        width:120px;
+        padding: 0 10px;
+        height:40px;
+        border-radius:4px;
+        border: 1px solid #E2E5EF;
+        box-sizing: border-box;
+        cursor: pointer;
+    }
+    .selectDept{
+        width: 160px;
+    }
+    .filterDropList{
+        position: absolute;
+        right: 0;
+        max-height: 200px;
+        overflow-y: auto;
+        background: #fff;
+        display: none;
+        border: 1px solid #e4e7ed;
+        box-shadow: 0 2px 12px 0 #e4e7ed;
+        z-index: 2;
+        li{
+            padding: 0 10px;
+        }
+    }
+    
+    .deptList{
+        width: 160px;
+        max-height: 400px;
+    }
+    .listTypeAll {
+        li {
+            height: 48px;
+            line-height: 48px;
+            background-color: #fff;
+            cursor: pointer;
+            padding-bottom: 1px solid #ebeef5;
+        }
+    }
+}

+ 1 - 1
src/css/console.less

@@ -32,7 +32,7 @@ body.console {
   background: @activeBg;
   min-width: 1185px;
   padding: 10px;
-  padding-bottom: 0px;
+  /*padding-bottom: 0px;*/
   box-sizing: border-box;
   ul {
     padding: 0 40px;

+ 6 - 5
src/css/deptConsole.less

@@ -29,7 +29,8 @@ body.console {
   // overflow: auto;
   height: auto;
   background: @activeBg;
-  min-width: 1080px;
+  min-width: 1185px;
+  padding: 10px;
   ul {
     padding: 0 40px;
   }
@@ -296,9 +297,9 @@ body.console {
   
   .defect {
     background-color: @themeColor;
-    height: 452px;
+    height: 455px;
     overflow: hidden;
-    border-bottom: 10px solid @activeBg;
+    /*border-bottom: 10px solid @activeBg;*/
     .list {
       padding: 15px 5px;
       width: 100%;
@@ -388,7 +389,7 @@ body.console {
       padding-bottom: 2px;
       margin-bottom: 10px;
       cursor: pointer;
-      color: @fstColor;
+      color: @secColor;
       img {
         top: 1px;
       }
@@ -451,7 +452,7 @@ body.console {
 }
 .explainNum {
   margin-top: 8px;
-  color: @fstColor;
+  color: @secColor;
 }
 
 .toggleSlide {

+ 61 - 7
src/css/qcScore.less

@@ -14,9 +14,9 @@
 .patient-info{
   /*height: 50px;*/
   line-height: 50px;
-  border-bottom: 1px #E2E5EF solid;
+  border-bottom: 10px #F5F6FA solid;
   text-align: center;
-  margin-bottom: 20px;
+  /*margin-bottom: 20px;*/
   span{
     color: #333;
     margin-right: 40px;
@@ -170,6 +170,7 @@
     height: 100%;
     position: relative;
     overflow-y: auto;
+    border-right: 10px #F5F6FA solid;
   }
   .content-item{
     display: none;
@@ -372,6 +373,18 @@
         margin-bottom: 5px;
         box-sizing: border-box;
         padding-left: 5px;
+        .add-icon{
+          font-size: 12px;
+          display: inline-block;
+          text-align: center;
+          width:32px;
+          height:14px;
+          line-height: 14px;
+          color: #FFAD00;
+          border:1px #FFAD00 solid;
+          border-radius:8px;
+          margin-right: 6px;
+        }
         &.active{
           background: #FFF0DA;
         }
@@ -419,10 +432,38 @@
   span{
     display: inline-block;
     width: 70px;
-    margin-right: 20px;
+    margin-right: 12px;
     text-align: right;
   }
 }
+.add-box{
+  .drop-box{
+    position: relative;
+    margin-bottom: 10px;
+  }
+  ul{
+    display: none;
+    position: absolute;
+    right: 0;
+    width: 300px;
+    background: #fff;
+    border:1px @tableBorderColor solid;
+    height: 205px;
+    overflow: auto;
+    li{
+      line-height: 25px;
+      padding: 0 5px;
+      cursor: pointer;
+      white-space: nowrap;
+      overflow: hidden;
+      text-overflow: ellipsis;
+      &:hover{
+        background: @tableBorderColor;
+      }
+    }
+
+  }
+}
 .standard_table {
   tr {
     td.standard_fst {
@@ -482,9 +523,9 @@
 
 /********缺陷总览*********/
 .flaw-table{
-  height: 100%;
+  height: 97%;
   overflow-y: auto;
-  margin-right: 30px;
+  /*margin: 0 30px 0 20px;*/
   .slide-up{
     cursor: pointer;
     color: @activeColor;
@@ -500,11 +541,24 @@
       content: "+";
     }
   }
+  .page-item{
+    display: none;
+    h2{
+      height: 44px;
+      line-height: 44px;
+      border-bottom: 1px @tableBorderColor solid;
+      font-size: 16px;
+      font-weight: normal;
+      margin-bottom: 20px;
+      text-indent: 20px;
+    }
+  }
   table{
-    width: 100%;
+    width: 97%;
     border:1px solid #E2E5EF;
     border-collapse: collapse;/*关键代码*/
-    margin-bottom: 40px;
+    /*margin-bottom: 40px;*/
+    margin: 0 30px 40px 20px;
     thead{
       background: #EFF0F9;
 

+ 51 - 0
src/html/assertType.html

@@ -0,0 +1,51 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+    <meta charset="UTF-8">
+    <meta name="viewport" content="width=device-width, initial-scale=1.0">
+    <meta http-equiv="X-UA-Compatible" content="ie=edge">
+    <title>病案首页合格率占比</title>
+</head>
+
+<body>
+    <div class="container assertType">
+        <div class="partTitle">
+          <p>质控类型维护</p>
+          <!-- <p><a href="deptConsole.html">控制台(科室) / </a>病案首页合格率占比</p> -->
+          <div class="dateDetail fr">
+            
+          </div>
+        </div>
+        <div class="partTitleT"></div>
+        <div class="grayLine"></div>
+        <div class="main-body">
+            <div class="filterBox clearfix">
+                <span class="filterItem typeFilter">
+                    <span>质控类型:</span>
+                    <input class="patientNumInp" style="width: 148px;" type="text" placeholder="请输入质控类型">
+                </span>
+                <span class="filter">查询</span>
+                <span class="addTypeAssert"><a href="assertTypeDetail.html">添加质控类型</a></span>
+            </div>
+            <div>
+                <table>
+                    <thead>
+                        <th class="moduleName" style="width: 65px;">序号</th>
+                        <th class="beHospitalId textCenter">质控ID</th>
+                        <th class="beHospitalId textCenter">质控类型</th>
+                        <th class="beHospitalId textCenter" style="width: 200px;">操作</th>
+                    </thead>
+                    <tbody>
+
+                    </tbody>
+                </table>
+            </div>
+
+            <div class="pagination"></div>
+        </div>
+        
+    </div>
+</body>
+
+</html>

+ 47 - 0
src/html/assertTypeDetail.html

@@ -0,0 +1,47 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+    <meta charset="UTF-8">
+    <meta name="viewport" content="width=device-width, initial-scale=1.0">
+    <title>Document</title>
+</head>
+<body>
+    <div class="container assertTypeDetail">
+        <div class="partTitle">
+            <p>质控类型维护/新增</p>
+            <div class="dateDetail fr">
+              
+            </div>
+          </div>
+          <div class="partTitleT"></div>
+          <div class="grayLine"></div>     
+          <div class="main-body">
+            <div class="filterBox clearfix">
+                <div class="filterItem typeFilter deptListWrap">
+                    <span class="explainL" style="overflow:hidden">科室名称:</span>
+                    <span class="selectDept ellipsis" data-id=""><i>--</i></span>
+                    <ul class="deptList filterDropList">
+                        
+                    </ul>
+                </div>   
+                <div class="filterItem typeFilter">
+                    <span class="explainL">质控类型:</span>
+                    <input class="patientNumInp" style="width: 148px;" type="text" placeholder="请输入质控类型">
+                </div>
+                <div class="filterItem typeFilter">
+                    <span class="explainL">质控条目:</span>
+                    <ul class="listTypeAll">
+                        <li>
+                            <span>病案首页</span><i></i>
+                        </li>
+                    </ul>
+                </div>
+                <!-- <span class="filter">查询</span>
+                <span class="addTypeAssert"><a href="assertTypeDetail.html">添加质控类型</a></span> -->
+            </div>
+
+            <div class="pagination"></div>
+        </div>
+    </div>
+</body>
+</html>

+ 1 - 1
src/html/deptConsole.html

@@ -29,7 +29,7 @@
     </div>
   </div>
   <div class="partTitleT"></div>
-  <div class="grayLine"></div>
+  <!--<div class="grayLine"></div>-->
   <div class="partWrap clearfix">
       <div class="part01 fl">
         <p class="partTitlePub clearfix" style="cursor: default;">

+ 1 - 0
src/html/qcList.html

@@ -81,6 +81,7 @@
                     <th class="bedNum textCenter" code="bed_code">床号</th>
                     <th class="inHospitalDate textCenter" code="behospital_date">入院日期</th>
                     <th class="outHospitalDate textCenter desc" code="leave_hospital_date">出院日期</th>
+                    <th class="diagnose textCenter" code="diagnose">主诊断</th>
                     <th class="doctorName textCenter" code="beh_doctor_name">住院医生</th>
                     <th class="doctorName textCenter" code="doctor_name">主管医生</th>
                     <th class="doctorName textCenter" code="director_doctor_name">主任医生</th>

+ 1 - 0
src/html/qcListDept.html

@@ -80,6 +80,7 @@
                         <th class="bedNum textCenter" code="bed_code">床号</th>
                         <th class="inHospitalDate textCenter" code="behospital_date">入院日期</th>
                         <th class="outHospitalDate textCenter desc" code="leave_hospital_date">出院日期</th>
+                        <th class="diagnose textCenter" code="diagnose">主诊断</th>
                         <th class="doctorName textCenter" code="beh_doctor_name">住院医生</th>
                         <th class="doctorName textCenter" code="doctor_name">主管医生</th>
                         <th class="doctorName textCenter" code="director_doctor_name">主任医生</th>

+ 1 - 0
src/html/qcListPerson.html

@@ -80,6 +80,7 @@
                         <th class="bedNum textCenter" code="bed_code">床号</th>
                         <th class="inHospitalDate textCenter" code="behospital_date">入院日期</th>
                         <th class="outHospitalDate textCenter desc" code="leave_hospital_date">出院日期</th>
+                        <th class="diagnose textCenter" code="diagnose">主诊断</th>
                         <th class="doctorName textCenter" code="beh_doctor_name">住院医生</th>
                         <th class="doctorName textCenter" code="doctor_name">主管医生</th>
                         <th class="doctorName textCenter" code="director_doctor_name">主任医生</th>

+ 87 - 447
src/html/qcScore.html

@@ -10,11 +10,11 @@
         <li class="list-1 menu-${id}">
             <p>${name}</p>
             {{else}}
-        <li class="page menu-${id}" code="${name}">${name}
+        <li class="page menu-${id}" code="${name}" mode="${id}">${name}
             {{/if}}
             <ul>
                 {{each sonMode}}
-                <li class="page" code="${name.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'')}">${name}</li>
+                <li class="page" code="${name.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'')}" mode="${id}">${name}</li>
                 {{/each}}
             </ul>
         </li>
@@ -91,7 +91,6 @@
              </tr>
              <tr><td colspan="2" class="table-tip">入院病情:1.有,2.临床未确定,3.情况不明,4.无。</td></tr>
          </table>
-         <!--<p class="table-tip"></p>-->
          {{else}}
              <table>
          <tr>
@@ -124,444 +123,12 @@
          </table>
          {{/if}}
     </script>
-    <script type="text/html" id="indexTmpl">
-        <div class="content-item" code="${title.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'')}">
-            <h2 class="title">${title}</h2>
-            <div class="container content-ht">
-                <div class="info-item cont-2">
-                    <div class="cont">
-                        <span class="label">医疗付费方式:</span>
-                        <span>${医疗付费方式}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">医疗机构:</span>
-                        <span>${医疗机构名称}(组织机构代码:${医疗机构代码}) </span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">健康卡号:</span>
-                        <span>${健康卡号}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">第${住院次数}次住院</span>
-                        <span></span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">病案号:</span>
-                        <span>${病案号}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-5">
-                    <div class="cont">
-                        <span class="label">姓名:</span>
-                        <span>${姓名}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">性别:</span>
-                        <span>${性别}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">出生日期:</span>
-                        <span>${出生日期.slice(0,10)}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">年龄:</span>
-                        <span>${年龄}${年龄单位}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">国籍:</span>
-                        <span>${国籍}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">(年龄不足1周岁的)年龄月数:</span>
-                        <span> ${新生儿出生月数}月&nbsp;&nbsp;${新生儿出生天数}天</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">新生儿出生体重:</span>
-                        <span>${新生儿出生体重}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">新生儿入院体重:</span>
-                        <span>${新生儿入院体重}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">出生地:</span>
-                        <span>${出生地}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">籍贯:</span>
-                        <span>${籍贯}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">民族:</span>
-                        <span>${民族}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">身份证号:</span>
-                        <span>${身份证号}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">职业:</span>
-                        <span>${职业}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">婚姻:</span>
-                        <span>${婚姻}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">现住址:</span>
-                        <span>${现住址}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">电话:</span>
-                        <span>${现住址电话}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">邮编:</span>
-                        <span>${现住址邮编}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-2">
-                    <div class="cont">
-                        <span class="label">户口地址:</span>
-                        <span>${户口地址}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">邮编:</span>
-                        <span>${户口地址邮编}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">工作单位及地址:</span>
-                        <span>${工作单位}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">单位电话:</span>
-                        <span>${工作单位电话}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">邮编:</span>
-                        <span>${工作单位邮编}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-4">
-                    <div class="cont">
-                        <span class="label">联系人姓名:</span>
-                        <span>${联系人姓名}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">关系:</span>
-                        <span>${联系人关系}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">地址:</span>
-                        <span>${联系人地址}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">电话:</span>
-                        <span>${联系人电话}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">入院途径:</span>
-                        <span>${入院途径}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-4">
-                    <div class="cont">
-                        <span class="label">入院时间:</span>
-                        <span>${入院时间}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">入院科别:</span>
-                        <span>${入院科别}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">病床:</span>
-                        <span>${入院床位序号}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">转科科别:</span>
-                        <span>${转科科别}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-4">
-                    <div class="cont">
-                        <span class="label">出院时间:</span>
-                        <span>${出院时间}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">出院科别:</span>
-                        <span>${出院科别}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">病床:</span>
-                        <span>${出院床位号码}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">实际住院:</span>
-                        <span>${实际住院天数}天</span>
-                    </div>
-                </div>
-                <div class="info-item no-border cont-2">
-                    <div class="cont">
-                        <span class="label">门(急)诊诊断:</span>
-                        <span>${门急诊诊断}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">疾病编码:</span>
-                        <span>${门急诊诊断编码}</span>
-                    </div>
-                </div>
-                <div class="info-table" id="diagTable"></div>
-                <div class="info-item cont-2">
-                    <div class="cont">
-                        <span class="label">损伤、中毒的外部原因:</span>
-                        <span>${损伤中毒因素}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">疾病编码:</span>
-                        <span>${损伤中毒因素编码}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">病理诊断:</span>
-                        <span>${病理诊断}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">疾病编码:</span>
-                        <span>${病理诊断编码}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">病理号:</span>
-                        <span>${病理诊断编号}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">药物过敏:</span>
-                        <span>${药物过敏}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">过敏药物:</span>
-                        <span>${过敏药物}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">死亡患者尸检:</span>
-                        <span>${死亡患者尸检}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-2">
-                    <div class="cont">
-                        <span class="label">血型:</span>
-                        <span>${血型}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">Rh:</span>
-                        <span>${Rh}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-4">
-                    <div class="cont">
-                        <span class="label">科主任:</span>
-                        <span>${科主任}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">主任(副主任)医师:</span>
-                        <span>${主任医师}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">主治医师:</span>
-                        <span>${主治医师}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">住院医师:</span>
-                        <span>${住院医师}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-4">
-                    <div class="cont">
-                        <span class="label">责任护士:</span>
-                        <span>${责任护士}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">进修医师:</span>
-                        <span>${进修医师}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">实习医师:</span>
-                        <span>${实习医师}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">编码员:</span>
-                        <span>${编码员}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-4">
-                    <div class="cont">
-                        <span class="label">病案质量:</span>
-                        <span>${病案质量}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">质控医师:</span>
-                        <span>${质控医师}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">质控护士:</span>
-                        <span>${质控护士}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">质控日期:</span>
-                        <span>${质控日期}</span>
-                    </div>
-                </div>
-                <div class="info-table" id="surgeryTable"></div>
-                <div class="info-item cont-2">
-                    <div class="cont">
-                        <span class="label">离院方式:</span>
-                        <span>${离院方式}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">拟接收医疗机构名称:</span>
-                        <span>${接收机构名称}</span>
-                    </div>
-                </div>
-                <div class="info-item cont-2">
-                    <div class="cont">
-                        <span class="label">是否有出院31天内再住院计划:</span>
-                        <span>${a天内再住院计划}</span>
-                    </div>
-                    <div class="cont">
-                        <span class="label">目的:</span>
-                        <span>${再住院目的}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">颅脑损伤患者昏迷时间:</span>
-                        <span>入院前:${颅脑损伤患者昏迷前天数}天${颅脑损伤患者昏迷前小时}小时${颅脑损伤患者昏迷前分钟}分钟&nbsp;&nbsp;&nbsp;&nbsp;入院后:${颅脑损伤患者昏迷后天数}天${颅脑损伤患者昏迷后小时}小时${颅脑损伤患者昏迷后分钟}分钟</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">住院费用(元):</span>
-                        <span>总费用${总费用}(自付金额: ${自付金额})</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">1.综合医疗服务类:</span>
-                        <span>(1)一般医疗服务费:${一般医疗服务费} (2)一般治疗操作费:${一般治疗服务费} (3)护理费:${护理费} (4)其他费用:${其他费用} </span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">2.诊断类:</span>
-                        <span>(5)病理诊断费:${病理诊断费} (6)实验室诊断费:${实验室诊断费} (7)影像学诊断费:${影像学诊断费} (8)临床诊断项目费:${临床诊断项目费}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">3.治疗类:</span>
-                        <span>(9)非手术治疗项目费:${非手术治疗项目费}(临床物理治疗费:${临床物理治疗费}) (10)手术治疗费:${手术治疗费}(麻醉费:${麻醉费} 手术费:${手术费}) </span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">4.康复类:</span>
-                        <span>(11)康复费:${康复类}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">5.中医类:</span>
-                        <span>(12)中医治疗费: ${中医治疗费}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">6.西药类:</span>
-                        <span>(13)西药费:${西药费}(抗菌药物费用:${抗菌药物费用}) </span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">7.中药类:</span>
-                        <span> (14)中成药费:${中成药费} (15)中草药费:${中草药费} </span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">8.血液和血液制品类:</span>
-                        <span>(16)血费:${血费} (17)白蛋白类制品费:${白蛋白类制品费} (18)球蛋白类制品费:${球蛋白类制品费} (19)凝血因子类制品费:${凝血因子类制品费} (20)细胞因子类制品费:${细胞因子类制品费}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">9.耗材类:</span>
-                        <span>(21)检查用一次性医用材料费:${检查用一次性医用材料费} (22)治疗用一次性医用材料费:${治疗用一次性医用材料费} (23)手术用一次性医用材料费:${手术用一次性医用材料费}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">10.其他类:</span>
-                        <span>(24)其他费:${其他类其他费}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">单病种管理:</span>
-                        <span>${单病种管理}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">临床路径管理:</span>
-                        <span>${临床路径管理}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">诊断符合情况:</span>
-                        <span> 1.门诊与出院:${门诊与住院} 2.入院与出院:${入院与出院} 3.术前与术后:${术前与术后} 4.临床与病理:${临床与病理} 5.放射与病理:${放射与病理}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">抢救情况:</span>
-                        <span>抢救${病人抢救次数}次 成功${病人抢救成功次数}次</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">是否为自动出院:</span>
-                        <span>${是否为自动出院}</span>
-                    </div>
-                </div>
-                <div class="info-item">
-                    <div class="cont">
-                        <span class="label">转归情况:</span>
-                        <span>${转归情况}</span>
-                    </div>
-                </div>
-            </div>
-        </div>
-    </script>
     <script type="text/html" id="flawTmpl">
         <div class="flaw-item" code="${modelName.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'')}">
             <div class="title">
+                {{if gradeType===2}}
+                <i class="add-icon">人工</i>
+                {{/if}}
                 {{if info}}
                 <a {{if pageKeyList[0]}} anchors="${pageKeyList}" href="#anchor${pageKeyList[0]}" {{/if}}>${msg}(${info})</a>
                 {{else}}
@@ -596,22 +163,77 @@
             <p class="warning"><span></span><span class="red">支持≥0的数字输入,最多保留小数点后1位~</span></p>
         </div>
     </script>
-    <script type="text/html" id="flawTotalList">
+    <script type="text/html" id="flawDropTmpl">
+        {{each(i,it) info}}
+        <li idx="${i}" name="${it.entryName}">${it.entryName}</li>
+        {{/each}}
+    </script>
+    <script type="text/html" id="addFlawTmpl">
+        <div class="edit-box add-box">
+            <div class="drop-box">
+                <span>质控条目: </span>
+                <input type="text" class="flaw-drop-input"/>
+                <ul></ul>
+            </div>
+            <!--<p><span>模块名称: </span><input type="text" value="${modelName}" /></p>-->
+            <p><span style="margin-right: 16px;">提示信息:</span><input id="addQcMsg" type="text" value="${msg}" /></p>
+            <p><span>分值:</span> <input id="addQcScore" type="text" value="${score}" /></p>
+            <p class="warning"><span></span><span class="red">支持≥0的数字输入,最多保留小数点后1位~</span></p>
+        </div>
+    </script>
+    <!--<script type="text/html" id="flawTotalList">
         {{if Object.keys(data).length===0}}
             <div class="empty">
-                <img src="../images/empty.png" alt="空"/>
-                <p>暂无数据~</p>
+                <img src="../images/empty1.png" alt="空"/>
+                <p>暂无信息~</p>
             </div>
         {{else}}
-        <table>
-            <thead>
+        <div class="page-item" code="缺陷总览">
+            <h2 class="title">${title}</h2>
+            <table>
+                <thead>
                 <tr>
                     <th width="250">来源</th>
                     <th>缺陷详情</th>
                     <th width="150">扣分</th>
                 </tr>
-            </thead>
-            <tbody>
+                </thead>
+                <tbody>
+                {{each(i,val) data}}
+                <tr><td colspan="3" class="slide-up">${i}</td></tr>
+                {{each val}}
+                <tr code="${i}">
+                    <td style="text-indent: 14px;">${modelName}</td>
+                    <td>${standardMsg}</td>
+                    <td class="red">${score}</td>
+                </tr>
+                {{/each}}
+                {{/each}}
+                </tbody>
+            </table>
+        </div>
+
+        {{/if}}
+    </script>-->
+    <script type="text/html" id="appointBookTmpl">
+        <div class="page-item" code="${title}">
+            <h2 class="title" code="${title}">${title}</h2>
+            {{if !data}}
+            <div class="empty">
+                <img src="../images/empty1.png" alt="空"/>
+                <p>暂无信息~</p>
+            </div>
+            {{else}}
+            {{if title==='缺陷总览'}}
+            <table>
+                <thead>
+                <tr>
+                    <th width="250">来源</th>
+                    <th>缺陷详情</th>
+                    <th width="150">扣分</th>
+                </tr>
+                </thead>
+                <tbody>
                 {{each(i,val) data}}
                 <tr><td colspan="3" class="slide-up">${i}</td></tr>
                 {{each val}}
@@ -622,9 +244,27 @@
                 </tr>
                 {{/each}}
                 {{/each}}
+                </tbody>
+            </table>
+            {{else}}<table code="${title}">
+            <thead>
+            <tr>
+                <th width="100" align="center">序号</th>
+                <th>文书详情</th>
+            </tr>
+            </thead>
+            <tbody>
+            {{each(i,val) data}}
+            <tr>
+                <td align="center">${i+1}</td>
+                <td>${recTitle}</td>
+            </tr>
+            {{/each}}
             </tbody>
         </table>
-        {{/if}}
+            {{/if}}
+            {{/if}}
+        </div>
     </script>
 </head>
 <body>
@@ -653,7 +293,7 @@
             <div class="operation fr" id="flaws">
                 <div class="flaw-title">
                     <span>缺陷详情</span>
-                    <!--<a href="javascript:void(0);">+ 新增</a>-->
+                    <a href="javascript:void(0);" class="add-flaw">+ 新增</a>
                 </div>
                 <div class="flaw-box content-ht">
                     <!--<div class="empty">

BIN
src/images/empty.png


+ 7 - 2
src/js/api.js

@@ -6,8 +6,8 @@ const api = {
     delScore:'/qc/behospitalInfo/delCase' ,//删除评分项
     editScore:'/qc/behospitalInfo/updCase' ,//修改评分
     addScore:'/qc/behospitalInfo/addCase' ,//添加评分项
+    findQcCasesEntry:"/qc/casesEntryHospital/findQcCasesEntry",//条目下拉列表
     getRecordDetail:'/qc/behospitalInfo/getByBehospitalCode', //获取病例明细
-    getInfoModule:'/qc/module/getById',
     getModuleById:'/qc/module/getModuleMap',
     getQcCases:'/qc/cases/getQcCases',
     getQcCasesAll:'/qc/casesEntryHospital/getQcCasesAll',
@@ -65,7 +65,12 @@ const api = {
     homePageLevelByDeptLimit:'/consoleByDept/homePageLevelStatisticsByDept',//病案首页合格率占比keshi详情
     homePageLevelStatisticsByDept:'/consoleByDept/homePageLevelByDeptLimit',//病案首页合格率占比(科室)-内页
     levelStatisticsByDept:'/consoleByDept/levelStatisticsByDept',//科室缺陷占比排行
-    resultStatisticsByDeptAndDoctorPage:'/consoleByDept/resultStatisticsByDeptAndDoctorPage'//缺陷明细-科室(分页)-内页
+    resultStatisticsByDeptAndDoctorPage:'/consoleByDept/resultStatisticsByDeptAndDoctorPage',//缺陷明细-科室(分页)-内页
+    qcType:'/qc/qcType/page',//质控类型(分页列表)
+    getEntryByHospital:'/qc/qcType/getEntryByHospital',//质控类型新增条目分组
+    saveOrUpdate:'/qc/qcType/saveOrUpdate',//质控类型新增更新修改
+    typeDelete:'/qc/qcType/delete',//质控类型删除
+    typeGetById:'/qc/qcType/getById',//根据id返回
 }
 module.exports = {
     api

+ 604 - 0
src/js/assertType.js

@@ -0,0 +1,604 @@
+const $ = require('jquery');
+require("../css/assertType.less");
+require('./modal.js');
+const {api} = require('./api.js')
+const {post,getCookie,getUrlArgObjectNew} = require('./utils.js')
+require('./../resource/jquery-ui/jquery-ui.min.js');
+require('./../resource/jquery-ui/jquery-ui.min.css');
+const iconCheck= require("./../images/icon_check.png")
+const iconUnCheck = require("./../images/icon_unchecked.png")
+const  iconCalenBlue= require("./../images/icon_calen_blue.png")
+const  iconCalenGrey= require("./../images/icon_calen_grey.png")
+const iconDown= require("./../images/arrow_down.png")
+const iconUp = require("./../images/arrow_up.png")
+const loadingImg = require("./../images/loading.gif")
+const arrowLeft= require("./../images/arrow_left.png")
+const arrowRight = require("./../images/arrow_right.png")
+
+$(".selectLevel").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
+$(".selectDept").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
+let tabList = [], name = "", behospitalCode="", behosDateStart="", level="",behosDateEnd="", scoreSum = 0,statisticsType=2,
+  nameTemp = "", behospitalCodeTemp="",levelTemp="", deptId="",deptIdTemp="", doctorName="", doctorNum="",doctorNameTemp="",doctorNumTemp="",
+  data_desc=[],data_asc=[];
+let deptList = JSON.parse(getCookie("deptList"))||[]
+$(function(){
+    let srcUrl = $("#contentIframe",parent.document).attr("src")
+    statisticsType = getUrlArgObjectNew("dateType",srcUrl)||2
+    deptId = deptIdTemp = getUrlArgObjectNew("deptName",srcUrl)||""
+    if(statisticsType == 1){
+        $(".monthYear .mon").css({
+            backgroundColor:'#00A1FF',
+            color:'#fff'
+        }).siblings().css({
+            color:'#00A1FF',
+            backgroundColor:'#fff'
+        })
+    }else{
+        $(".monthYear .year").css({
+            backgroundColor:'#00A1FF',
+            color:'#fff'
+        }).siblings().css({
+            color:'#00A1FF',
+            backgroundColor:'#fff'
+        })
+    }
+    if(deptId){
+        $(".selectDept").html(deptId).attr({
+            "data-id":deptId,
+            "title":deptId
+        }).append(`<img class="arrow" src=${iconDown} alt="下拉">`)
+        getDeptList()
+    }else{
+        getDeptList(1)
+    }
+    getTabData(1)
+})
+
+$(".abnormalClear").click(function(){
+    deptId = deptList[0].deptName
+    behospitalCode = ""
+    $(".patientNumInp").val("")
+    $(".selectDept").html(deptId).attr({
+        "data-id":deptId,
+        "title":deptId
+    })
+    getTabData(1)
+})
+$(".partTitle a").click(function(){
+    //初始菜单选中        
+    focusMenuItem('YH-KZTKS')
+    $(".container",parent.document).addClass("console-cont");
+})
+
+function focusMenuItem(code){
+    const ele = $(parent.document).find(".menu .page[code="+code+"]");
+    const parEle = ele.parents(".list-1");
+    if(!parEle.is(".list-1-show")){
+      parEle.click();
+    }
+    //console.log($(parent.document).find(".menu .page[code='YH-ZKK-GMKQXZB_XQ']"))
+    ele.click();
+  }
+$('.datapickerBox').append(`<img class="iconCalen" src=${iconCalenGrey} />`)
+$('.iconCalen').on("mouseenter", function(e){
+    $(this).attr("src", iconCalenBlue)
+})
+$('.iconCalen').on("mouseleave", function(e){
+    $(this).attr("src", iconCalenGrey)
+})
+$('.iconCalen').on("click", function(e){
+    $(this).parent().find("input").focus()
+})
+$('.recordScoreBtn').css("opacity",hasData('FUNC000017')?'1':'0.5')
+
+//科室处理
+function getDeptList(flg){
+    let str = ``
+    if(deptList.length<=0)return
+    if(flg){
+        $(".partDetail .selectDept ").attr("data-id",deptList[0].deptName).find("i").html(deptList[0].deptName)
+        deptId = deptIdTemp = deptList[0].deptName
+    }
+    for(let i = 0;i < deptList.length;i++){
+        let tmp = deptList[i]
+        str += `<li class="deptItem ellipsis" title="${tmp.deptName}" data-id="${tmp.deptName}" data-name="${tmp.deptName}">${tmp.deptName}</li>`
+    }
+    $(".partDetail .filterDropList").html(str)
+    getTabData(1)
+}
+
+dateChange()
+//所有数据切换日期筛选
+function dateChange(){
+    $(".monthYear .mon").click(function(){
+        $(this).css({
+            backgroundColor:'#00A1FF',
+            color:'#fff'
+        }).siblings().css({
+            color:'#00A1FF',
+            backgroundColor:'#fff'
+        })
+        $(".dayDetail .deptListWrap").css("display","block")
+        $(".dayDetail .dayFilter").css("display","none")
+        statisticsType = 1
+        getTabData(1)
+    })
+    $(".monthYear .year").click(function(){
+        $(this).css({
+            backgroundColor:'#00A1FF',
+            color:'#fff'
+        }).siblings().css({
+            color:'#00A1FF',
+            backgroundColor:'#fff'
+        })
+        $(".dayDetail .deptListWrap").css("display","none")
+        $(".dayDetail .dayFilter").css("display","block")
+        statisticsType = 2
+        getTabData(1)
+    })
+}
+//判断有无某一权限
+  function hasData(data){
+    let trdObj = JSON.parse(getCookie("trdObj"))
+    let lis = trdObj['YH-BLZK-ZKPF']
+    if(!lis){
+      return false
+    }
+    if(lis.indexOf(data)>-1){//有权限
+        return true
+    }
+    return false;
+}
+function getTabData(activePage){
+    const param = {
+        current:activePage,
+        name: behospitalCode, //条目名
+        size: 15
+    }
+    post(api.qcType,param).then(res =>{
+        if(res.data.code == '0'){
+            const data = res.data.data;
+            tabList = data.records||[];
+            const totalPage = data.pages;
+            const totalNum = data.total;
+            renderTab(tabList,data.hospitalId,activePage);
+            
+            renderPagination(totalPage,Number(activePage),totalNum)
+            if(totalPage > 1){
+                renderPagination(totalPage,Number(activePage),totalNum)
+            } else{
+                $('.pagination').html("")
+            }
+        }else{
+            $.alerModal({"message":res.data.msg,type:"tip",time:'1000',isFather: true, fatherWrapper: $("#mainBox", parent.document)});
+        }
+    }).catch((e) =>{
+    
+    })
+}
+
+
+$(".filter").on("click", function(e){
+    name = nameTemp
+    behospitalCode = behospitalCodeTemp
+    level = levelTemp
+    deptId = deptIdTemp
+    getTabData(1)
+})
+function renderTab(data,hisId,activePage){
+    let str = ``
+    for(let i = 0; i < data.length; i++){
+        const item = data[i]
+        str += `
+            <tr  data-index=${i}>
+                <td  class="textCenter">${(activePage-1)*15 + i+1}</td>
+                <td >${item.id || "-"}</td>
+                <td >${item.name || "-"}</td>
+                <td class="assertTypeActive clearfix">
+                    <span class="assertTypeEdit" data-index="${i}" data-type="1" data-id="${item.id}">修改</span>
+                    <span class="assertTypeCopy" data-index="${i}" data-type="2" data-id="${item.id}">复制</span>
+                    <span class="assertTypeDel" data-index="${i}" data-type="3" data-id="${item.id}">删除</span> 
+                </td>
+            </tr>
+        `
+    }
+    $('tbody').html(str?str:`<tr><td colspan="17" style="text-align: center;color: #aaa">
+        <img style="margin-top:50px;width:100px;" src="${require('../images/empty.png')}" />
+        <p style="margin-top:20px;margin-bottom:30px;color:#ccc;position:relative;left:5px;">暂无数据~</p>
+    </td></tr>`)
+    bindScoreDetail(hisId)
+    $(".goHomeDetail").click(function(){
+        let docName = $(this).attr("data-doc")
+        $(parent.document).find("#contentIframe").attr("src","quexianDetail.html?from=1&casesId=243&deptName="+deptIdTemp+"&docName="+docName+"&shijian="+statisticsType)
+    })
+}
+
+function scoreDetail(id,age,hid,code){
+    window.open(`./qcScore.html?id=${id}&age=${age}&hid=${hid}&code=${code}`)
+}
+function bindScoreDetail(hisId){
+    $('.assertTypeDel').on('click',function(e){
+        const index = $(this).attr("data-index")
+        const id = $(this).attr("data-id")
+        const type = $(this).attr("data-type")
+        const item = tabList[index]
+        midifyMsgBox(item,type,id)
+    })
+}
+
+  
+function midifyMsgBox(item,type){
+    const itemCopy = JSON.parse(JSON.stringify(item))
+    let msgBox = ''
+    if(type == 1){
+        msgBox = `<div class="midifyMsgBox">
+            <div class="mask"></div>
+            <div class="midifyMsgContent abnormal">
+                <p class="midifyMsgTitle">修改 <img class="iconClose" src=${require('./../images/icon_close_default.png')} alt="关闭" /></p>
+                <div class="itemMsgInfoBox">
+                    <span class="itemMsgLab abnormalLeft">状态:</span> 
+                    <span class="abnormalAll" data-status="${itemCopy.status}">${itemCopy.status == 0?"未处理":"已处理"}</span>
+                    <ul class="abnormalStatusLis">
+                        <li data-status="0">未处理</li>
+                        <li data-status="1">已处理</li>
+                    </ul>
+                </div>
+                <div class="itemMsgInfoBox">
+                    <span class="itemMsgLab abnormalLeft abnormalMark">备注:</span> 
+                    <span class="itemInfoRight"> 
+                        <textarea class="abnormalTxt" placeholder="请输入内容" >${itemCopy.remark}</textarea>
+                    </span>
+                </div>
+                <div  class="itemMsgInfoTips">支持≥0的数字输入,最多保留小数点后1位~</div>
+                <div class="midifyMsgBtn abnormalBtn">
+                    <span class="midifyEdit">保存</span>
+                </div>
+            </div>
+        </div>`
+    }else if(type==3){
+        msgBox = `<div class="midifyMsgBox">
+            <div class="mask"></div>
+            <div class="midifyMsgContent midifyMsgContentDel">
+                <p class="midifyMsgTitle">修改 <img class="iconClose" src=${require('./../images/icon_close_default.png')} alt="关闭" /></p>
+                <p class="delTips">确认要删除该条异常记录?</p>
+                <div class="midifyMsgBtn midifyMsgBtnDel">
+                    <span class="midifyEdit midifyEditDel">删除</span>
+                    <span class="midifyEdit midifyEditQuit">取消</span>
+                </div>
+            </div>
+        </div>`
+    }
+    $("#mainBox", parent.document).append(msgBox)
+    $(".midifyEditDel", parent.document).on("click",function(){
+        let ids = []
+        ids.push(itemCopy.id)
+        console.log(ids)
+        delModifyOne(ids)
+    })
+    $(".midifyEditQuit", parent.document).on("click",function(){
+        $("#mainBox .midifyMsgBox", parent.document).remove()
+    })
+    $(".abnormalAll", parent.document).on("click",function(){
+        $(".abnormalStatusLis", parent.document).slideToggle()
+    })
+    $(".abnormalStatusLis li", parent.document).on("click",function(){
+        let status = $(this).attr("data-status")
+        let str = $(this).html()
+        $(".abnormalAll", parent.document).attr("data-status",status).html(str)
+        $(".abnormalStatusLis", parent.document).slideToggle()
+    })
+    $("#mainBox .midifyMsgBox .iconClose", parent.document).on("click", function(e){
+        $("#mainBox .midifyMsgBox", parent.document).remove()
+    })
+    $("#mainBox .midifyMsgBox .itemScore", parent.document).on("keypress", function(event){
+        return (/[\d\.]/.test(String.fromCharCode(event.keyCode)))
+     })
+    $("#mainBox .midifyMsgBox .itemScore", parent.document).on("input", function(e){
+       const val = $(this).val() 
+       itemCopy.score = val
+    })
+    $("#mainBox .midifyMsgBox .midifyEdit", parent.document).on("click", function(e){
+        saveModifyOne(itemCopy)
+    })
+}
+//保存修改
+function delModifyOne(ids){
+    let param = {
+        "ids": ids
+    }
+    post(api.typeDelete,param).then(res =>{
+        if(res.data.code == '0'){
+            const data = res.data.data;
+            getTabData(1)
+            $("#mainBox .midifyMsgBox", parent.document).remove()
+            $.alerModal({"message":'删除成功',type:"tip",time:'1000',isFather: true, fatherWrapper: $("#mainBox", parent.document)});
+        }else{
+            
+        }
+    }).catch((e) =>{
+    
+    })
+}
+//保存修改
+function saveModifyOne(itemCopy){
+    let txt = $(".abnormalTxt", parent.document).val()
+    let status = $(".abnormalAll", parent.document).attr("data-status")
+    let param = {
+        "id": itemCopy.id,
+        "remark": txt,
+        "status": status
+    }
+    post(api.saveQcAnnormal,param).then(res =>{
+        if(res.data.code == '0'){
+            const data = res.data.data;
+            getTabData(1)
+            $("#mainBox .midifyMsgBox", parent.document).remove()
+            $.alerModal({"message":'修改成功',type:"tip",time:'1000',isFather: true, fatherWrapper: $("#mainBox", parent.document)});
+        }else{
+            
+        }
+    }).catch((e) =>{
+    
+    })
+}
+//选择病历等级
+$('.selectLevel').on("click", function(e){
+    e.stopPropagation()
+    $(".deptList ").css("display", "none")
+    $(".selectDept .arrow").attr("src",iconDown)
+    const showList =  $(".levelList ").css("display")
+    if(showList == "none" ||!showList){
+        $(".levelList ").css("display","block")
+        $(".selectLevel .arrow").attr("src",iconUp)
+    }else{
+        $(".levelList ").css("display", "none")
+        $(".selectLevel .arrow").attr("src",iconDown)
+    }
+})
+
+bindLeveldSelect()
+//是否启用选择
+function bindLeveldSelect(){
+    $('.levelItem').on("click",function(){
+        const levelItemName = $(this).attr("data-name")
+        const levelItemItemId = $(this).attr("data-id")
+        levelTemp =levelItemItemId
+        $('.selectLevel').html(levelItemName)
+        $(".levelList").css("display", "none")
+        $(".selectLevel").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
+    })
+}
+
+//全选绑定
+
+$('.selectDept').on("click", function(e){
+    e.stopPropagation()
+    $(".levelList ").css("display","none")
+    $(".selectLevel .arrow").attr("src",iconDown)
+    const showList =  $(".deptList ").css("display")
+    if(showList == "none" ||!showList){
+        $(".deptList ").css("display","block")
+        $(".selectDept .arrow").attr("src",iconUp)
+    }else{
+        $(".deptList ").css("display", "none")
+        $(".selectDept .arrow").attr("src",iconDown)
+    }
+})
+
+
+bindDeptSelect()
+//科室选择
+function bindDeptSelect(){
+    $('.deptItem').on("click",function(){
+        const deptItemName = $(this).attr("data-name")
+        const deptItemId = $(this).attr("data-id")
+        deptIdTemp =deptItemId
+        if(deptItemName.length > 10){
+            $('.selectDept').html(deptItemName.substring(0,8)+'...')
+        }else{
+            $('.selectDept').html(deptItemName)
+        }
+        $('.selectDept ').attr({'title':deptItemName,'data-id':deptItemName})
+        $(".selectDept").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
+
+        $(".deptList").css("display", "none")
+    })
+}
+function loading(){
+    const str = `
+    <div class="loadingBox">
+            <div class="mask"></div>
+            <img class="loadingImg" src=${loadingImg}  alt="loading" />
+        </div>
+    `
+    $("#mainBox", parent.document).append(str)
+}
+function hideLoading(){
+    $("#mainBox .loadingBox", parent.document).remove()
+}
+$('.recordScoreBtn').on("click",function(e){
+    if(!hasData('FUNC000017')){
+        return
+    }
+    let scoreList = []
+    for(let i = 0; i <tabList.length; i++){
+        if(tabList[i].hasSelect){
+            scoreList.push(tabList[i].behospitalCode)
+        }
+    }
+    if(scoreList.length === 0){
+        $.alerModal({"message":'请选择要评分的项!',type:"tip",time:'1000',isFather: true, fatherWrapper: $("#mainBox", parent.document)});
+        return
+    } else{
+        loading()
+        for(let j = 0; j < scoreList.length; j++){
+            recordScore(scoreList[j],scoreList.length)
+        }
+    }
+})
+$("th[code]").on("click",function(e){
+    const code=$(this).attr("code");
+    if(data_asc[0]===code){
+      data_desc=[code];
+      data_asc=[];
+      $("th[code]").removeClass("asc desc");
+      $(this).addClass("desc");
+    }else{
+      data_desc=[];
+      data_asc=[code];
+      $("th[code]").removeClass("asc desc");
+      $(this).addClass("asc");
+    }
+    getTabData(1);
+});
+function recordScore(behospitalCode,totalNum){
+    const param = {
+        behospitalCode: behospitalCode
+    }
+    post(api.recordScore,param).then(res =>{
+        if(res.data.code == '0'){
+            scoreSum++
+            if(scoreSum === totalNum){
+                hideLoading()
+                scoreSum = 0
+                const activePage = $(".activePage").attr('data-page') || 1
+
+                getTabData(activePage)
+            }
+      
+        }else{}
+    }).catch((e) =>{
+    
+    })
+}
+$(".patientNumInp").on("input", function(e){
+    const val = $(this).val().trim()
+    behospitalCodeTemp = val
+})
+$(".patientNameInp").on("input", function(e){
+    const val = $(this).val().trim()
+    nameTemp = val
+})
+$(".doctorInp").on("input", function(e){
+    const val = $(this).val().trim()
+    doctorNameTemp = val
+})
+$(".doctorNumInp").on("input", function(e){
+  const val = $(this).val().trim();
+    doctorNumTemp = val
+})
+$(function() {
+    $.datepicker.regional['zh-CN'] = {
+    clearText: '清除',
+    clearStatus: '清除已选e799bee5baa6e59b9ee7ad9431333361303131日期',
+    closeText: '关闭',
+    closeStatus: '不改变当前选择',
+    prevText: '<上月',
+    prevStatus: '显示上月',
+    prevBigText: '<<',
+    prevBigStatus: '显示上一年',
+    nextText: '下月>',
+    nextStatus: '显示下月',
+    nextBigText: '>>',
+    nextBigStatus: '显示下一年',
+    currentText: '今天',
+    currentStatus: '显示本月',
+    monthNames: ['一月','二月','三月','四月','五月','六月', '七月','八月','九月','十月','十一月','十二月'],
+    monthNamesShort: ['一月','二月','三月','四月','五月','六月', '七月','八月','九月','十月','十一月','十二月'],
+    yearNamesShort: ['一月','二月','三月','四月','五月','六月', '七月','八月','九月','十月','十一月','十二月'],
+    monthStatus: '选择月份',
+    yearStatus: '选择年份',
+    weekHeader: '周',
+    weekStatus: '年内周次',
+    dayNames: ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'],
+    dayNamesShort: ['周日','周一','周二','周三','周四','周五','周六'],
+    dayNamesMin: ['日','一','二','三','四','五','六'],
+    dayStatus: '设置 DD 为一周起始',
+    dateStatus: '选择 m月 d日, DD',
+    dateFormat: 'yy-mm-dd',
+    firstDay: 1,
+    initStatus: '请选择日期',
+    isRTL: false};
+    $.datepicker.setDefaults($.datepicker.regional['zh-CN']);
+
+    $( "#datepicker" ).datepicker({
+        changeMonth: true,
+        changeYear: true,
+        dateFormat:"yy/mm/dd"
+    });
+    $( "#datepicker2" ).datepicker({
+        changeMonth: true,
+        changeYear: true,
+        dateFormat:"yy/mm/dd"
+    });
+});
+
+//分页渲染
+function renderPagination(totalPage,activePage,totalNum){
+    let str = `<span class="totalSum">共${totalPage}页/${totalNum}条数据</span><span class="prePage"><img class="arrowPage" src=${arrowLeft} /></span>`
+    if(totalPage <= 6){
+        for(let i = 1; i <= totalPage; i++){
+          
+            str += `<span class="pageNum ${'page'+i}" data-page=${i}>${i}</span>`
+        }
+    }else{
+        if(activePage <= 3){ //选中页数小于4
+            for(let i = 1; i <= 4; i++){
+                str += `<span class="pageNum ${'page'+i}" data-page=${i}>${i}</span>`
+            }
+            str += `<span class="more" >...</span>`
+        str += `<span class="pageNum ${'page'+totalPage}" data-page=${totalPage}>${totalPage}</span>`
+
+        } else if(activePage > totalPage -3){
+            str += `<span class="pageNum page1" data-page=1>1</span>`
+            str += `<span class="more" >...</span>`
+            str += `<span class="pageNum ${'page'+(totalPage-3)}" data-page=${totalPage -3}>${totalPage -3}</span>`
+            str += `<span class="pageNum ${'page'+(totalPage-2)}" data-page=${totalPage -2}>${totalPage -2}</span>`
+            str += `<span class="pageNum ${'page'+(totalPage-1)}" data-page=${totalPage -1}>${totalPage -1}</span>`
+            str += `<span class="pageNum ${'page'+totalPage}" data-page=${totalPage}>${totalPage}</span>`
+        } else {
+            str += `<span class="pageNum page1" data-page=1>1</span>`
+            str += `<span class="more" >...</span>`
+            str += `<span class="pageNum ${'page'+(activePage -1)}" data-page=${activePage -1}>${activePage -1}</span>`
+            str += `<span class="pageNum ${'page'+activePage}" data-page=${activePage}>${activePage}</span>`
+            str += `<span class="pageNum ${'page'+(activePage +1)}" data-page=${activePage +1}>${activePage +1}</span>`
+            str += `<span class="more" >...</span>`
+            str += `<span class="pageNum ${'page'+totalPage}" data-page=${totalPage}>${totalPage}</span>`
+        }
+       
+    }
+    str += `<span class="nextPage"><img class="arrowPage" src=${arrowRight} /></span>`
+    $('.pagination').html(str)
+    $('.page' + activePage).addClass('activePage')
+    $(".pageNum").on("click", function(e){
+        const activePageNow = Number($(this).attr('data-page'))
+        getTabData(activePageNow)
+        // renderPagination(totalPage,activePageNow,totalNum)
+    })
+    $(".prePage").on("click", function(e){
+        let activePageNow = Number($(".activePage").attr('data-page'))
+        if(activePageNow > 1){
+            activePageNow--
+            getTabData(activePageNow)
+            // renderPagination(totalPage,activePageNow,totalNum)
+        }
+    })
+    $(".nextPage").on("click", function(e){
+        let activePageNow = Number($(".activePage").attr('data-page'))
+        if(activePageNow < totalPage){
+            activePageNow++
+            getTabData(activePageNow)
+            // renderPagination(totalPage,activePageNow,totalNum)
+        }
+    })
+    
+}
+
+$(document).on("click", function(){
+    $(".levelList ").css("display", "none")
+    $(".deptList").css("display", "none")
+    $(".selectDept .arrow").attr("src",iconDown)
+})
+
+$((function($){
+})($));

+ 24 - 0
src/js/assertTypeDetail.js

@@ -0,0 +1,24 @@
+const $ = require('jquery');
+require("../css/assertTypeDetail.less");
+require('./modal.js');
+const {api} = require('./api.js')
+const {post,getCookie,getUrlArgObjectNew} = require('./utils.js')
+
+
+$(function(){
+    getList()//获取条目列表
+
+})
+function getList(){
+    post(api.getEntryByHospital,{}).then(res =>{
+        let result = res.data
+        if(result.code == '0'){
+            const data = result.data;
+            console.log(data)
+        }else{
+            
+        }
+    }).catch((e) =>{
+    
+    })
+}

+ 21 - 16
src/js/deptConsole.js

@@ -179,8 +179,13 @@ function renderDeptLis(data){
         for(let i = 0;i < datafour[name].length;i++){
             datafour[name][i].value = datafour[name][i].num
         }
-        emptyCircleB(datafour[name])
-        panDetailB(datafour[name])
+        if(hospital=="台州市立"){
+            emptyCircleB(datafour[name])
+            panDetailB(datafour[name])
+        }else{
+            emptyCircleBc(datafour[name])
+            panDetailBc(datafour[name])
+        }
         $(this).addClass("li0").siblings().removeClass("li0")
     })
 }
@@ -256,16 +261,16 @@ function getBarData(type){
         }
     }
     if(hospital=="长兴医院"&&hasData("FUNC000076")){
-        post(api.getAverageScore,{//病案首页
+        post(api.homePageLevelStatisticsByDept,{//病案首页
             "type": type||1//1月2年
         }).then((res)=>{
             let data = res.data;
             if(data.code == 0){
-                let result1 = data.data['各科室质控平均分']||[]
+                let result1 = data.data||[]
                 let dataX1=[],dataY1=[]
                 for(let i = 0;i < result1.length;i++){
-                    dataX1.push(result1[i].name)
-                    dataY1.push(result1[i].averageValue)
+                    dataX1.push(result1[i].doctorName)
+                    dataY1.push(result1[i].firstLevelPercentStr.replace('%',''))
                 }
                 lineChartSpecial(dataX1,dataY1)
             }
@@ -354,7 +359,7 @@ function lineChartSpecial(dataX,dataY){
         }],
         series: [
             {
-                name: '质控平均分',
+                name: '病案首页合格率',
                 type: 'bar',
                 barWidth: '23%',
                 data: dataY
@@ -450,7 +455,7 @@ function part02pan(data,dom){
     });
     let bgColor = '#fff';
     let title = '总量';
-    let color = ['#37CBCB','#dedede'];
+    let color = ['#3fffd1','#4c5c82'];
     let echartData = data;
     option = {
         // backgroundColor: bgColor,
@@ -463,14 +468,14 @@ function part02pan(data,dom){
                 rich: {
                     val: {
                         fontSize: 14,
-                        color: '#fff',
+                        color: '#E9EBEF',
                         fontWeight: 'bold',
                         padding: [10, 0]
                     },
                     name: {
                         fontSize: 12,
                         fontWeight: 'normal',
-                        color: '#fff',
+                        color: '#E9EBEF',
                     }
                 }
             }
@@ -524,14 +529,14 @@ function emptyCircleB(data){
                 rich: {
                     val: {
                         fontSize: 24,
-                        color: '#fff',
+                        color: '#E9EBEF',
                         fontWeight: 'bold',
                         padding: [10, 0]
                     },
                     name: {
                         fontSize: 12,
                         fontWeight: 'normal',
-                        color: '#fff',
+                        color: '#E9EBEF',
                     }
                 }
             }
@@ -555,7 +560,7 @@ function emptyCircleB(data){
             itemStyle: {
                 normal: {
                     // borderColor: bgColor,
-                    borderWidth: 2
+                    borderWidth: 3
                 }
             },
             labelLine: {
@@ -619,14 +624,14 @@ function emptyCircleBc(data){
                 rich: {
                     val: {
                         fontSize: 24,
-                        color: '#fff',
+                        color: '#E9EBEF',
                         fontWeight: 'bold',
                         padding: [10, 0]
                     },
                     name: {
                         fontSize: 12,
                         fontWeight: 'normal',
-                        color: '#fff',
+                        color: '#E9EBEF',
                     }
                 }
             }
@@ -650,7 +655,7 @@ function emptyCircleBc(data){
             itemStyle: {
                 normal: {
                     borderColor:  '#203463',
-                    borderWidth: 2
+                    borderWidth: 3
                 }
             },
             labelLine: {

+ 0 - 1
src/js/deptScoreDetail.js

@@ -25,7 +25,6 @@ $(function(){
     let srcUrl = $("#contentIframe",parent.document).attr("src")
     deptId = deptIdTemp = getUrlArgObjectNew("deptName",srcUrl)||""
     statisticsType = getUrlArgObjectNew("dateType",srcUrl)||""
-    console.log(deptIdTemp,deptId)
     if(statisticsType == 1){
         $(".monthYear .mon").css({
             backgroundColor:'#00A1FF',

+ 1 - 0
src/js/qcList.js

@@ -172,6 +172,7 @@ function renderTab(data,hisId){
                 <td  class="textCenter">${item.bedCode || "-"}</td>
                 <td  class="textCenter">${item.behospitalDate&&item.behospitalDate.slice(0,10) || "-"}</td>
                 <td  class="textCenter">${item.leaveHospitalDate&&item.leaveHospitalDate.slice(0,10)|| "-"}</td>
+                <td  class="textCenter">${item.diagnose|| "-"}</td>
                 <td  class="textCenter">${item.behDoctorName   || "-"}</td>
                 <td  class="textCenter">${item.doctorName || "-"}</td>
                 <td  class="textCenter">${item.directorDoctorName || "-"}</td>

+ 1 - 0
src/js/qcListDept.js

@@ -187,6 +187,7 @@ function renderTab(data){
                 <td  class="textCenter">${item.bedCode || "-"}</td>
                 <td  class="textCenter">${item.behospitalDate&&item.behospitalDate.slice(0,10) || "-"}</td>
                 <td  class="textCenter">${item.leaveHospitalDate&&item.leaveHospitalDate.slice(0,10)|| "-"}</td>
+                <td  class="textCenter">${item.diagnose|| "-"}</td>
                 <td  class="textCenter">${item.behDoctorName   || "-"}</td>
                 <td  class="textCenter">${item.doctorName || "-"}</td>
                 <td  class="textCenter">${item.directorDoctorName || "-"}</td>

+ 1 - 0
src/js/qcListPerson.js

@@ -187,6 +187,7 @@ function renderTab(data){
                 <td  class="textCenter">${item.bedCode || "-"}</td>
                 <td  class="textCenter">${item.behospitalDate&&item.behospitalDate.slice(0,10) || "-"}</td>
                 <td  class="textCenter">${item.leaveHospitalDate&&item.leaveHospitalDate.slice(0,10)|| "-"}</td>
+                <td  class="textCenter">${item.diagnose|| "-"}</td>
                 <td  class="textCenter">${item.behDoctorName   || "-"}</td>
                 <td  class="textCenter">${item.doctorName || "-"}</td>
                 <td  class="textCenter">${item.directorDoctorName || "-"}</td>

+ 153 - 62
src/js/qcScore.js

@@ -4,21 +4,22 @@ require('jquery-templates');
 require('./modal.js');
 const {post,getUrlArgObject,setBoxHeight,getCookie} = require('./utils.js');
 const {api} = require('./api.js');
-//本页全局变量
-let global_flawData = {};    //缺陷数据
-const global_id=getUrlArgObject("id");
-const global_age = getUrlArgObject("age");
-const global_code = getUrlArgObject("code");
-let global_activeTab=$(".sub-menu .page.active").attr("code");  //当前激活菜单项
-let global_modules ={};   //模板数据缓存
 window.document.title="质控评分-"+getUrlArgObject("name");
 
 $(function(){
-  //getSubMenu();
-  //initScoreItem();
-  //getRecordDetail();
-  getAllModules()
-  //getInfoModule(15);    //根据对应id获取模板
+//本页全局变量
+  let global_flawData = {};    //缺陷数据
+  const global_id=getUrlArgObject("id");
+  const global_age = getUrlArgObject("age");
+  const global_code = getUrlArgObject("code");
+  let global_activeTab=$(".sub-menu .page.active").attr("code");  //当前激活菜单项
+  let global_modules ={};   //模板数据缓存
+  let global_flaws=[];  //缺陷条目列表缓存
+  let global_selectedFlaw = {};    //新增时选中的条目信息
+  getAllModules();
+  $(".add-flaw").click(function(){
+    getQcCasesEntry();
+  });
 function initMenu(data){
   const menu=[{id:0,name:"缺陷总览",parentId: -1,sonMode: []},...(data||[])];
   //菜单数据填充
@@ -50,8 +51,10 @@ function initMenu(data){
   });
   //右侧内容切换
   $(".page").on("click",function(){
-    if($(this).attr("code")==="缺陷总览"){
-      $(".flaw-table").show();
+    const title = $(this).attr("code");
+    if(title==="缺陷总览"||title==="谈话告知书"||title==="知情同意书"){
+      $(".flaw-table .page-item").hide();
+      $(".flaw-table,.flaw-table .page-item[code="+title+"]").show();
     }else{
       $(".flaw-table").hide();
     }
@@ -97,31 +100,11 @@ function getRecordDetail(){
       initList(msg);
       initScoreItem(msg);
       global_flawData=msg;
-      /*let obj = JSON.parse(result.pageData)
-      
-      infoNotNull(obj,'查房记录')&&wardRound(obj['查房记录'],'查房记录')
-      infoNotNull(obj,'术前讨论、术前小结')&&preoperation(obj['术前讨论、术前小结'],'术前讨论、术前小结')
-      infoNotNull(obj,'阶段小结')&&summary(obj['阶段小结'],'阶段小结')
-      infoNotNull(obj,'手术记录')&&operationRecord(obj['手术记录'],'手术记录')
-      infoNotNull(obj,'会诊申请单')&&applicationForm(obj['会诊申请单'],'会诊申请单')
-      infoNotNull(obj,'会诊结果单')&&resultForm(obj['会诊结果单'],'会诊结果单')
-      infoNotNull(obj,'会诊记录')&&consultationNote(obj['会诊记录'],'会诊记录')
-      infoNotNull(obj,'疑难病例讨论记录')&&difficultRecord(obj['疑难病例讨论记录'],'疑难病例讨论记录')
-      infoNotNull(obj,'病危通知书')&&illnessNotice(obj['病危通知书'],'病危通知书')
-      infoNotNull(obj,'病理检验送检单')&&pathologicTest(obj['病理检验送检单'],'病理检验送检单')
-      infoNotNull(obj,'抢救记录')&&rescueRecord(obj['抢救记录'],'抢救记录')
-      infoNotNull(obj,'输血后效果评价')&&transfusionEvaluate(obj['输血后效果评价'],'输血后效果评价')*/
       setBoxHeight();
     }
   });
 }
-//判断模块内容是否不为空
-function infoNotNull(obj,moduleName){
-  if( obj[moduleName]&&obj[moduleName].length > 0 &&Object.keys(obj[moduleName][0]).length !== 0 ){
-    return true
-  }
-  return false
-}
+
 //填充患者信息
 function initPatientInfo(data){
   const obj=Object.assign({},data,{age:!global_age||global_age=="null"?"-":global_age});
@@ -132,29 +115,21 @@ function initContent(data){
   const obj = JSON.parse(data);
   let info=[];
   let hml='',moduleId='';
+  formatSpecPage(obj["谈话告知书"],"谈话告知书");
+  formatSpecPage(obj["知情同意书"],"知情同意书");
   for(let k in obj){
-    if(k==="病案首页"){   //病案首页不使用动态模板
-      info=formatInfoData(k,obj[k][0]);
-      $("#indexTmpl").tmpl(info).appendTo("#contentInfo");
+    if(k==="谈话告知书"||k==="知情同意书"){
       continue;
     }
     for(let i in obj[k]){
       info=formatInfoData(k,obj[k][i]);
       moduleId=info.mode_id;
       if(global_modules[moduleId]){
-        hml=initModuleData(moduleId,obj[k].length);
+        hml=initModuleData(moduleId,obj[k]);
         $.tmpl(hml,info).appendTo("#contentInfo");
       };
     }
   }
-  if(obj["病案首页"]&&obj["病案首页"][0]["出院诊断"]){
-    const diag = JSON.parse(obj["病案首页"][0]["出院诊断"]);
-    $("#tableTmpl").tmpl({k:"出院诊断",data:diag}).appendTo("#diagTable");
-  }
-  if(obj["病案首页"]&&obj["病案首页"][0]["手术信息"]){
-    const diag = JSON.parse(obj["病案首页"][0]["手术信息"]);
-    $("#tableTmpl").tmpl({k:"手术信息",data:diag}).appendTo("#surgeryTable");
-  }
   $(".content-item[code="+global_activeTab+"]").show();
   //console.log(obj)
 }
@@ -172,21 +147,15 @@ function formatInfoData(k,data){
   return Object.assign({title:k},obj);
 }
 
-/*function formatData(data,title){
-  if(!keyMaps[title]){
-    return data;
+//知情同意书、谈话告知书
+  function formatSpecPage(data,title){
+    $("#appointBookTmpl").tmpl({title,data}).appendTo(".flaw-table");
   }
-  const keyArr=Object.keys(keyMaps[title]);
-  let obj={};
-  keyArr.map((k)=>{
-    obj[keyMaps[title][k]]=data[0][k]||"";
-  });
-  const obj1=Object.assign({},obj,data[0]);
-  return [obj1];
-}*/
 
 function initList(data){
-  $("#flawTotalList").tmpl({data:data}).appendTo(".flaw-table");
+  //$("#flawTotalList").tmpl({title:"缺陷总览",data:data}).appendTo(".flaw-table");
+  formatSpecPage(data,"缺陷总览");
+  $(".flaw-table .page-item[code="+global_activeTab+"]").show();
   $(".slide-up").off("click").on("click",function(){
     const name = $(this).text();
     $("tr[code='"+name+"']").slideToggle();
@@ -270,6 +239,22 @@ function editScore(info){
     }
   });
 }
+//添加评分项
+function addScore(info){
+  const param={
+    "behospitalCode": global_id,
+    "optResultAlgVO": info
+  };
+  post(api.addScore,param).then(function(res){
+    if(res.data.code==='0'){
+      $("#delModal").hide();
+      updateFlaws(res.data.data);
+      $.alerModal({"message":"添加成功",type:"tip",time:'1000'});
+    }
+  });
+}
+
+
 //显示删除/修改弹窗
 function showModal(flag,code,i){
   $("#delModal .modal-body").html("");
@@ -311,6 +296,45 @@ function showModal(flag,code,i){
       const obj = Object.assign({},info,{msg:$("#delModal #qcMsg").val(),score:$("#delModal #qcScore").val()});
       editScore(obj);
     });
+  }else if(flag==='2'){   //新增
+    $("#delModal .title").text("新增");
+    $("#delModal .confirm").text("保存");
+    $("#addFlawTmpl").tmpl().appendTo("#delModal .modal-body");
+    $("#flawDropTmpl").tmpl({info:code}).appendTo("#delModal .modal-body ul");
+    //分数输入验证
+    $("#addQcScore").on("input",function(){
+      const val=$(this).val();
+      if(/^[0-9]\d*$|^[0-9]\d*(.\d)?$/.test(val) && val <= 100){
+        $(".add-box .warning").hide();
+      }else{
+        $(".add-box .warning .red").text("支持≥0且≤100的数字输入,最多保留小数点后1位~");
+        $(".add-box .warning").show();
+      }
+    });
+    //提示信息输入验证
+    $("#addQcMsg").on("input",function(){
+      const val=$(this).val();
+      if(val.trim()){
+        $(".add-box .warning").hide();
+      }else{
+        $(".add-box .warning .red").text("提示信息不能为空~");
+        $(".add-box .warning").show();
+      }
+    });
+    $("#delModal .confirm").click(function(){
+      if(!$(".flaw-drop-input").attr("code")){
+        $(".add-box .warning .red").text("请选择质控条目~");
+        $(".add-box .warning").show();
+        return;
+      }
+      const msg=$("#delModal #addQcMsg").val();
+      const score=$("#delModal #addQcScore").val();
+      if($(".add-box .warning").is(":visible")||!msg.trim()||!score){
+        return;
+      }
+      const obj = Object.assign({},global_selectedFlaw,{msg,score});
+      addScore(obj);
+    });
   }else{
     $("#delModal .title").text("删除评分");
     $("#delModal .confirm").text("确定");
@@ -328,6 +352,57 @@ function formatFlawKeys(data){
     }
     return obj;
   }
+  //获取缺陷条目下拉列表
+  function getQcCasesEntry(name){
+  const id=$("#subMenu [code="+global_activeTab+"]").attr("mode");
+    const param = {
+      'behospitalCode':global_id,
+      'entryName':name,
+      'modeId':id
+    };
+    post(api.findQcCasesEntry,param).then(function(res){
+      if(res.data.code==='0'){
+        const data = res.data.data;
+        if(name){
+          global_flaws=data;
+          $("#delModal .modal-body ul").html("");
+          $("#flawDropTmpl").tmpl({info:data}).appendTo("#delModal .modal-body ul");
+          addFlawEvent();
+        }else{
+          global_flaws=data;
+          showModal('2',data);
+          addFlawEvent();
+        }
+      }
+    });
+  }
+//增加条目弹窗元素事件
+  function addFlawEvent(){
+    $(".add-box .flaw-drop-input").off("click").on("click",function(){
+      $(".add-box .drop-box ul").show();
+    });
+    $(".add-box .flaw-drop-input").off("blur").on("blur",function(){
+      setTimeout(function(){
+        $(".add-box .drop-box ul").hide();
+      },300)
+
+    });
+    $(".add-box .flaw-drop-input").off("input").on("input",function(){
+      $(this).attr("code","");
+      getQcCasesEntry($(this).val().trim());
+    });
+    $(".add-box .drop-box li").off("click").on("click",function(){
+      const n = $(this).attr("idx");
+      const flaw=global_flaws[n];
+      const {score,msg,entryName,casesEntryId}=flaw;
+      global_selectedFlaw=flaw;
+      $(".flaw-drop-input").val(entryName).attr("code",casesEntryId);
+      $("#addQcMsg").val(msg);
+      $("#addQcScore").val(score);
+      $(".add-box .warning").hide();
+      $(".add-box .drop-box ul").hide();
+    });
+  }
 
 //更新缺陷列表
   function updateFlaws(info){
@@ -373,7 +448,8 @@ function formatFlawKeys(data){
   }
 
 //初始化模板
-  function initModuleData(mid,n){
+  function initModuleData(mid,obj){
+    const n = obj.length;
     const module=global_modules[mid].moduleDetail;
     const key = global_modules[mid].modeName.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'');
     let hml = '<div class="content-item" code="'+key+'">' +
@@ -387,7 +463,7 @@ function formatFlawKeys(data){
         const {tagType} = detal;
         switch (tagType) {
           case 1:
-            hml = hml + simpleStructure(detal);
+            hml = hml + simpleStructure(detal,obj);
             break;
           case 4:
             hml = hml + combineStructure(detal);
@@ -402,8 +478,23 @@ function formatFlawKeys(data){
   }
 
   //基础类型结构生成
-  function simpleStructure(data){
+  function simpleStructure(data,obj){
     const {name, val,monoLine,addLine,position,bold,retract,id} = data;
+    if(name==="手术记录表格-1"){
+      const value = val.replace("【","").replace("】","");
+      const diag = JSON.parse(obj[0][value]);
+      let thml=`<div class="cont" style="width: 100%;" id="anchor${id}">`;
+      thml+=$("#tableTmpl").tmpl({k:"手术信息",data:diag})[0].outerHTML+"</div>";
+      return thml;
+    }
+    if(name==="出院诊断表格-1"){
+      const value = val.replace("【","").replace("】","");
+      const diag = JSON.parse(obj[0][value]);
+
+      let thml=`<div class="cont" style="width: 100%;" id="anchor${id}">`;
+      thml+=$("#tableTmpl").tmpl({k:"出院诊断",data:diag})[0].outerHTML+"</div>";
+      return thml;
+    }
     const posClass = position===1?'text-left':'';
     const boldClass = bold===1?'text-bold':'';
     const retractClass = retract===1?'text-indent':'';

+ 5 - 3
src/js/utils.js

@@ -1,7 +1,7 @@
 const qs = require('qs');
 const $ = require("jquery");
 var Utils = require('./rePromise');
-const baseUrl = "http://192.168.2.241:5858"
+const baseUrl = "http://192.168.2.236:5858"
 //页面映射
 const pageMap={
   'YH-KZT':'console.html',
@@ -33,6 +33,8 @@ const pageMap={
   "YH-ZKK-BASYHGLZB_XQ":'partDetailControl.html',
   "YH-KSZR-BASYHGLZB_XQ":'partDetail.html',
 
+  "YH-JCSJWH-ZKLXWH":'assertType.html',
+
 };
 
 //重写assign方法
@@ -169,8 +171,8 @@ $(".modal .close").click(function(){
 //计算容器高度
 function setBoxHeight(){
   const ht=window.innerHeight;
-  $(".content-box,.flaw-table").height((ht-75)+'px');
-  $(".content-ht").height((ht-140)+"px");
+  $(".content-box,.flaw-table").height((ht-55)+'px');
+  $(".content-ht").height((ht-120)+"px");
 }
 setBoxHeight();
 $(window).resize(function(){

+ 28 - 0
webpack.config.js

@@ -39,6 +39,8 @@ module.exports = {
     quexianDetailControl: path.resolve(__dirname, 'src/js', 'quexianDetailControl.js'),
     mukuaiControl: path.resolve(__dirname, 'src/js', 'mukuaiControl.js'),
     tiaomuControl: path.resolve(__dirname, 'src/js', 'tiaomuControl.js'),
+    assertType: path.resolve(__dirname, 'src/js', 'assertType.js'),
+    assertTypeDetail: path.resolve(__dirname, 'src/js', 'assertTypeDetail.js'),
     vendor: 'lodash'// 多个页面所需的公共库文件,防止重复打包带入
   },
   output: {
@@ -90,6 +92,32 @@ module.exports = {
         collapseWhitespace: true //删除空白符与换行符
       }
     }),
+    new HtmlWebpackPlugin({
+      title: 'assertTypeDetail.html',
+      template: path.resolve(__dirname, 'src/html', 'assertTypeDetail.html'),
+      filename: 'assertTypeDetail.html',
+      chunks: ['assertTypeDetail', 'vendor', 'common'],
+      hash: true, //防止缓存
+      inject: true,
+      minify: {
+        removeAttributeQuotes: true, //压缩 去掉引号
+        removeComments: true, //移除HTML中的注释
+        collapseWhitespace: true //删除空白符与换行符
+      }
+    }),
+    new HtmlWebpackPlugin({
+      title: 'assertType.html',
+      template: path.resolve(__dirname, 'src/html', 'assertType.html'),
+      filename: 'assertType.html',
+      chunks: ['assertType', 'vendor', 'common'],
+      hash: true, //防止缓存
+      inject: true,
+      minify: {
+        removeAttributeQuotes: true, //压缩 去掉引号
+        removeComments: true, //移除HTML中的注释
+        collapseWhitespace: true //删除空白符与换行符
+      }
+    }),
     new HtmlWebpackPlugin({
       title: 'mukuaiControl.html',
       template: path.resolve(__dirname, 'src/html', 'mukuaiControl.html'),