require("../css/qcScore.less");
const $ = require('jquery');
require('jquery-templates');
require('./modal.js');
const {post,getUrlArgObject,setBoxHeight,getCookie,initScroll} = require('./utils.js');
const {api} = require('./api.js');
let checkOk = require('./../images/checkOk.png')
window.document.title="质控评分-"+getUrlArgObject("name");
$(function(){
//本页全局变量
let global_flawData = {}; //缺陷数据
let global_flawDataPay = {}; //缺陷数据
const global_id=getUrlArgObject("id");
const global_age = getUrlArgObject("age");
let global_check;
let global_check_home;
const global_code = getUrlArgObject("code");
let global_activeTab=$(".sub-menu .page.active").attr("code"); //当前激活菜单项
let global_modules ={}; //模板数据缓存
let global_flaws=[]; //缺陷条目列表缓存
let global_selectedFlaw = {}; //新增时选中的条目信息
getAllModules();
let hasAu3 = hasData('FUNC000011'); //新增缺陷权限
if(hasAu3){
$(".add-flaw").click(function(){
getQcCasesEntry();
});
}
function initMenu(data){
const menu=[{id:0,name:"缺陷总览",parentId: -1,sonMode: []},...(data||[])];
//菜单数据填充
$("#subMenuTmpl").tmpl(menu).appendTo("#subMenu");
$("#miniMenuTmpl").tmpl(menu).appendTo(".menu-mini ul");
//菜单收起展开
$(".sub-menu .list-1").on("click",function(){
$(".sub-menu .list-1 .slide-up").removeClass('slide-up');
$(this).toggleClass('slide-up');
$(this).find("ul").slideToggle();
// setTimeout(function(){
// initScroll("subMenu","Y",2)
// },300)
});
$(".sub-menu .list-1 li").on("click",function(e){
e.stopPropagation();
});
//收起菜单
$(".slide-show").click(function(){
$(".sub-menu,.copy-right").animate({"width":"60px"},function(){
$(this).hide();
$(".menu-mini").show();
});
$(".tab-container").animate({"margin-left":"60px"});
});
//展开菜单
$(".slide-hide").click(function(){
$(".menu-mini").hide();
$(".sub-menu,.copy-right").show().animate({"width":"220px"},function(){
});
$(".tab-container").animate({"margin-left":"220px"});
});
//右侧内容切换
$(".page").on("click",function(){
$(".info-item .cont,.flaw-item,td").removeClass("active"); //清空缺陷定位背景
const title = $(this).attr("code");
if(title == '缺陷总览'){
$(".check").css('display','none')
}else if(title == '病案首页'){
$(".check").css('display','block').text(global_check_home==1?'重新核查':'病案首页核查')
}else{
$(".check").css('display','block')
}
if(title==="缺陷总览"||title==="谈话告知书"||title==="知情同意书"){
if(title==="缺陷总览"){
getRecordDetailUpdate()
}
$(".flaw-table .page-item").hide();
$(".flaw-table,.flaw-table .page-item[code="+title+"]").show();
}else{
$(".flaw-table").hide();
}
if(title === '医嘱信息'){
$("#contentIframeIn").css({display:'block'}).contents().find(".adviceWrp").height(window.innerHeight-$("#patientInfo").height()-20+'px')
$(window).resize(function(){
$("#contentIframeIn").contents().find(".adviceWrp").height(window.innerHeight-$("#patientInfo").height()-20+'px')
});
}else{
$("#contentIframeIn").css({display:'none'})
}
//选中样式
$(".sub-menu .active,.menu-mini .active").removeClass('active');
const mItems = $(".sub-menu .page[code="+title+"],.menu-mini .page[code="+title+"]");
mItems.addClass("active");
mItems.parents(".list-1").addClass("active");
//显示对应内容
const code=$(this).attr("code");
global_activeTab=code;
//initModuleData();
$(".content-item,.flaw-item").hide();
$(".content-item[code='"+code+"']").show();
showFlawList();
$("#contentInfo").scrollTop(0)
});
// initScroll("subMenu","Y",2)
}
//判断有无某一权限
function hasData(data){
let trdObj = JSON.parse(getCookie("trdObj"))
let lis = trdObj[global_code]
if(!lis){
return false
}
if(lis.indexOf(data)>-1){//有权限
return true
}
return false;
}
//获取病例明细
function getRecordDetail(){
post(api.getRecordDetail,{'behospitalCode':global_id}).then(function(res){
if(res.data.code==='0'){
const data = res.data.data;
const {beHospital,result,msg,checkStatus,drgs,mrStatus} = data;
global_check = checkStatus
global_check_home = mrStatus
const info=Object.assign(beHospital,result);
initMenu(JSON.parse(result.menuData));
// $(".sub-menu>ul>li:first-child.page,.menu-mini>ul>li:first-child.page").addClass("active");
$(".subMenu >li:first-child.page,.menu-mini>ul>li:first-child.page").addClass("active");
global_activeTab=$(".sub-menu .page.active").attr("code");
initPatientInfo(info);
initContent(result.pageData);
initList(msg);
initScoreItem(msg);
global_flawData=msg;
global_flawDataPay=drgs;
setBoxHeight();
changePay()
}
});
}
function getRecordDetailUpdate(){
post(api.getRecordDetail,{'behospitalCode':global_id}).then(function(res){
if(res.data.code==='0'){
const data = res.data.data;
const {beHospital,result,msg,checkStatus,drgs} = data;
// global_check = checkStatus
// const info=Object.assign(beHospital,result);
// initMenu(JSON.parse(result.menuData));
// $(".subMenu >li:first-child.page,.menu-mini>ul>li:first-child.page").addClass("active");
// global_activeTab=$(".sub-menu .page.active").attr("code");
// initPatientInfo(info);
// initContent(result.pageData);
initList(msg);
initScoreItem(msg);
global_flawData=msg;
global_flawDataPay=drgs;
// setBoxHeight();
// changePay()
}
});
}
function changePay(){
$(document).on('click',".titleSpecial span",function(){
let type = $(this).attr("data-type")
if(type == 1){
initList(global_flawDataPay,type);
}else{
initList(global_flawData,type);
}
})
}
//填充患者信息
function initPatientInfo(data){
let hasCheck = false
if(hasData("FUNC000014")){
hasCheck = true
}
const obj=Object.assign({},data,{age:!global_age||global_age=="null"?"-":global_age,hasCheck,checkState:global_check,checkStateHome:global_check_home});
$("#infoTmpl").tmpl(obj).appendTo("#patientInfo");
$(".check").on("click", function(){
checkQc()
})
}
//显示病例模块明细
function initContent(data){
const obj = JSON.parse(data);
let info=[];
let hml='',moduleId='';
formatSpecPage(obj["谈话告知书"],"谈话告知书");
formatSpecPage(obj["知情同意书"],"知情同意书");
// formatSpecPage(obj["医嘱信息"],"医嘱信息");
for(let k in obj){
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]);
$.tmpl(hml,info).appendTo("#contentInfo");
}else{
const icon=require("../images/empty1.png");
const sid=moduleId?"("+moduleId+")":"";
const code=k.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'');
const emptyStr=`
暂无信息~
`;
if(!$(".content-item[code="+code+"] .empty").length){ //显示一条空提示即可
hml='' +
'
'+k+sid+'
'+emptyStr+'';
$.tmpl(hml,{}).appendTo("#contentInfo");
}
}
}
}
$(".content-item[code="+global_activeTab+"]").show();
//console.log(obj)
}
function formatInfoData(k,data){
let obj = {},name="";
for(let i in data){
if(i!=="mode_id"){
name=i.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,"").replace(/^[0-9]+/,"a"); //过滤key中存在的特殊符号,模板会渲染不出来且不报错
obj[name]=data[i].replace(/\n/g,"
")||"";
}else{
obj[i]=data[i].replace(/\n/g,"
")||"";
}
}
return Object.assign({title:k},obj);
}
//知情同意书、谈话告知书
function formatSpecPage(data,title,type){
$(".page-item[code='缺陷总览']").remove()
$("#appointBookTmpl").tmpl({title,data}).appendTo(".flaw-table");
$(".page-anchor").on("click",function(){
const code=$(this).attr("code");
const pCode=$(this).parents("tr").attr("code").replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'');
//菜单同步状态
$(".sub-menu .page[code="+pCode+"]").parents(".list-1").click();
$(".sub-menu .page[code="+pCode+"],.menu-mini .page[code="+pCode+"").click();
//缺陷定位
$(".info-item .cont,.flaw-item,td").removeClass("active");
const flawItem=$(".flaw-item .title a[code="+code+"]");
if(!flawItem.length){
$.alerModal({"message":'模块数据缺失~',type:"tip",time:'1000',isFather: true, fatherWrapper: $(".flaw-table", parent.document)});
return;
}
$(".flaw-item .title a[code="+code+"]").click();
const anch=$(".flaw-item .title a[code="+code+"]").attr("href");
if($(anch)[0]){
$('#contentInfo').scrollTop($(anch).offset().top-60);
}
});
if(type&&type == 1){
$(".titleNo").css({
'background-color': '#00A1FF',
'color': '#fff',
'border-color': '#00A1FF'
})
$(".titlePay").css({
'background-color': '#fff',
'border': '1px solid #777',
'border-right':0,
'color': '#777'
})
setBoxHeight()
}else if(type&&type==2){
$(".titleNo").css({
'background-color': '#fff',
'border': '1px solid #777',
'border-left':0,
'color': '#777'
})
$(".titlePay").css({
'background-color': '#00A1FF',
'color': '#fff',
'border-color': '#00A1FF'
})
setBoxHeight()
}
}
function initList(data,type){
//$("#flawTotalList").tmpl({title:"缺陷总览",data:data}).appendTo(".flaw-table");
formatSpecPage(data,"缺陷总览",type);
$(".flaw-table").show();
$(".flaw-table .page-item[code="+global_activeTab+"]").show();
$(".slide-up").off("click").on("click",function(){
const name = $(this).text();
$("tr[code='"+name+"']").slideToggle();
$(this).toggleClass("down");
});
}
//评分项数据填充
function initScoreItem(data){
$("#flaws .flaw-box").html("");
let hasAu = hasData('FUNC000013'); //修改缺陷权限
let hasAu2 = hasData('FUNC000012'); //删除缺陷权限
for(let k in data){
$("#flawTmpl").tmpl(data[k]).appendTo("#flaws .flaw-box");
}
showFlawList();
$(".flaw-item .oper a").click(function () {
const i = $(".flaw-item[code="+global_activeTab+"]").index($(this).parents(".flaw-item"));
const code=$(this).attr("code");
const isEdit = $(this).is(".edit-flaw");
//if(!hasAu)return
if(isEdit&&hasAu){
showModal('0',code,i);
}else if(!isEdit&&hasAu2){
showModal('1',code,i);
}
})
$(".edit-flaw").css({"opacity":hasAu?"1":"0.5",cursor:hasAu?"pointer":"unset"});
$(".del-flaw").css({"opacity":hasAu2?"1":"0.5",cursor:hasAu2?"pointer":"unset"});
$(".add-flaw").css({"opacity":hasAu3?"1":"0.5",cursor:hasAu3?"pointer":"unset"});
$(".flaw-item .title a[href]").click(function(){
const id = $(this).attr("href");
const anchors=$(this).attr("anchors").split(",");
let ans = anchors.map((it)=>{
return "#anchor"+it;
});
$(".info-item .cont,.flaw-item,td").removeClass("active");
$(ans.join(",")).addClass("active");
$(this).parents(".flaw-item").addClass("active");
});
}
//显示缺陷列表
function showFlawList(){
const hml = $(".flaw-item[code="+global_activeTab+"]");
if(hml.length){
hml.show();
$("#flaws .empty").hide();
}else{
$("#flaws .empty").length?$("#flaws .empty").show():$("#emptyTmpl").tmpl().appendTo("#flaws .flaw-box");
}
}
//删除评分项
function delScore(id,info){
const param={
'behospitalCode':global_id,
'optResultAlgVO':{
'id':id
}
};
post(api.delScore,param).then(function(res){
if(res.data.code==='0'){
$("#delModal").hide();
updateFlaws(res.data.data);
$("#anchor"+info.pageKeyList[0]).removeClass("active");
$.alerModal({"message":"删除成功",type:"tip",time:'1000'});
}
});
}
//修改评分项
function editScore(info){
const param={
"behospitalCode": global_id,
"optResultAlgVO": info
};
post(api.editScore,param).then(function(res){
if(res.data.code==='0'){
$("#delModal").hide();
updateFlaws(res.data.data);
$.alerModal({"message":"修改成功",type:"tip",time:'1000',win:true});
}
});
}
//添加评分项
function addScore(info){
const optResultAlgVO = {
"casesEntryId": info.casesEntryId,
"casesId": info.casesId,
"casesScore": info.caseScore,
"code": info.code || "",
"id": info.id || "",
"info":info.info || "",
"isReject": info.isReject,
"msg": info.msg || "",
"score": info.score
}
const param={
"behospitalCode": global_id,
"optResultAlgVO": optResultAlgVO
};
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("");
$("#delModal").show();
$("#delModal .cancel").hide();
$(".info-item .cont,.flaw-item .title,td").removeClass("active");
//事件解绑
$("#delModal .confirm").off("click");
$("#qcScore,#qcMsg").off("input");
const flawsList = formatFlawKeys(global_flawData);
const info = flawsList[global_activeTab]&&flawsList[global_activeTab][i];
if(flag==='0'){ //修改
$("#delModal .title").text("修改");
$("#delModal .confirm").text("保存");
$("#editTmpl").tmpl(info).appendTo("#delModal .modal-body");
//分数输入验证
$("#qcScore").on("input",function(){
const val=$(this).val();
if(/^[0-9]\d*$|^[0-9]\d*(.\d)?$/.test(val) && val <= 100){
$(".edit-box .warning").hide();
}else{
$(".edit-box .warning .red").text("支持≥0且≤100的数字输入,最多保留小数点后1位~");
$(".edit-box .warning").show();
}
});
//提示信息输入验证
$("#qcMsg").on("input",function(){
const val=$(this).val();
$(this).attr("title",val)
if(val.trim()){
$(".edit-box .warning").hide();
}else{
$(".edit-box .warning .red").text("提示信息不能为空~");
$(".edit-box .warning").show();
}
});
$("#delModal .confirm").click(function(){
if($(".edit-box .warning").is(":visible")){
return;
}
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();
$(this).attr("title",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=Number($("#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 .modal-body").html('确定要删除该评分记录吗?
');
$("#delModal .confirm").text("取消").click(function(){
$("#delModal").hide();
});
$("#delModal .cancel").show().text("删除").click(function(){
delScore(code,info);
});
}
}
//缺陷列表key值去掉特殊符号
function formatFlawKeys(data){
const obj = {};
for(let k in data){
obj[k.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'')]=data[k];
}
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");
}else{
global_flaws=data;
if($("#delModal").css("display") == "block"){
$("#flawDropTmpl").tmpl({info:data}).appendTo("#delModal .modal-body ul");
return
}
showModal('2',data);
}
}
});
}
//增加条目弹窗元素事件
$("body").on("click",".add-box .flaw-drop-input",function(){
$(".add-box .drop-box").addClass("show");
});
$("body").on("blur",".add-box .flaw-drop-input",function(){
setTimeout(function(){
$(".add-box .drop-box").removeClass("show");
},300)
});
$("body").on("input",".add-box .flaw-drop-input",function(){
$(this).attr({"code":"","title":$(this).val().trim()});
getQcCasesEntry($(this).val().trim());
});
$("body").on("click",".add-box .drop-box li",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,"title":entryName});
$("#addQcMsg").val(msg).attr("title",msg);
$("#addQcScore").val(score);
$(".add-box .warning").hide();
$(".add-box .drop-box").removeClass("show");
});
//更新缺陷列表
function updateFlaws(info){
$("#patientInfo .level").text("质控等级:"+info.level);
$("#patientInfo .score").text("质控得分:"+info.scoreRes);
const param = {
'behospitalCode':global_id,
'paramStr':[
"msg"
]
};
post(api.getRecordDetail,param).then(function(res){
if(res.data.code==='0'){
const data = res.data.data;
const {msg} = data;
initScoreItem(msg);
global_flawData=msg;
}
});
}
//获取病例模板
function getInfoModule(moduleId){
const param = {
moduleId:moduleId
};
post(api.getInfoModule,param).then(function(res){
if(res.data.code==='0'){
const data = res.data.data;
cachemoduleDatas(data);
getRecordDetail();
}
});
}
//模板数据缓存
function cachemoduleDatas(data){
const moudle=data.moduleDetail;
global_modules[data.modeName]=[];
for(let i in moudle){
global_modules[data.modeName].push(moudle[i]);
}
}
//初始化模板
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 = '' +
'
'+global_modules[mid].modeName+'('+mid+')
'+
(n>1?'
':'
');
for(let i in module){
hml=hml+'
';
for(let j=0;j"
}
return hml+"
";
}
//基础类型结构生成
function simpleStructure(data,obj){
const {name, val,monoLine,addLine,position,bold,retract,id} = data;
if(name==="手术记录表格-1"){
const value = val.replace("【","").replace("】","");
const diag = obj[0][value]?JSON.parse(obj[0][value]):"";
let thml=`
`;
thml+=$("#tableTmpl").tmpl({k:"手术信息",data:diag})[0].outerHTML+"
";
return thml;
}
if(name==="出院诊断表格-1"){
const value = val.replace("【","").replace("】","");
const diag = obj[0][value]?JSON.parse(obj[0][value]):"";
let thml=`
`;
thml+=$("#tableTmpl").tmpl({k:"出院诊断",data:diag})[0].outerHTML+"
";
return thml;
}
const posClass = position===1?'text-left':'';
const boldClass = bold===1?'text-bold':'';
const retractClass = retract===1?'text-indent':'';
const lineHml = ('
'+ extractVars(val)+'
');
const txtHml = ('
'+ extractVars(val)+'
');
let hml = addLine||monoLine?`
`:`
`;
hml=hml+`${name}`+ (addLine?lineHml:txtHml)+ `
`;
return hml;
}
//组合类型结构生成
function combineStructure(data){
const {name,questionMapping,id} = data;
let hml='
';
const colNum = Math.ceil(questionMapping.length/2);
let tdVal='';
const regexp = /(【(.+?)】)/g;
for(let i=0;i"+questionMapping[i].name+extractVars(questionMapping[i].val)+""+questionMapping[i+1].name+extractVars(questionMapping[i+1].val)+" | ";
}else{
tdVal=""+questionMapping[i].name+extractVars(questionMapping[i].val)+" | | ";
}
if(i==0){
hml=hml+`${name} | ${tdVal}`;
}else{
hml=hml+`
${tdVal}`;
}
hml=hml+"
";
i=((i+2)>questionMapping.length?i+1:i+2)
}
hml=hml+"
";
return hml;
}
//抽取变量
function extractVars(org){
const regexp = /(【(.+?)】)/g;
const arr = org.split(regexp);
//console.log(arr)
let htl = '',val='';
for(let i=0;i
{
if(res.data.code==='0') {
const data = res.data.data;
global_modules=data;
getRecordDetail();
$("#loading").hide();
setTimeout(function(){
$(".operation").show()
},50)
}
});
}
function checkQc(){
console.log('global_activeTab',global_activeTab)
const param={
behospitalCode:getUrlArgObject("id"),
hospitalId:getUrlArgObject("hid"),
checkType: global_activeTab == '病案首页'?'1':'0'
};
post(api.checkQc,param).then((res)=>{
if(res.data.code==='0') {
if(global_activeTab == '病案首页'){
global_check_home = 1
}else{
global_check = 1
}
$(".check").text("重新核查")
$.alerModal({"message":"核查成功",type:"tip",time:'1000',win:true});
}else{
$.alerModal({"message":res.data.msg ||"核查失败",type:"tip",time:'1000',isFather: false});
}
});
}
});