tools.js 72 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873
  1. import store from '@store';
  2. import {CLEAR_MAIN_SUIT,CLEAR_SEARCH} from '@store/types/mainSuit';
  3. import {CLEAR_CURRENT_ILL,CURRENT_CLEAR} from '@store/types/currentIll';
  4. import {CLEAROTHERHISTORY,OTHERHIS_CLEAR} from '@store/types/otherHistory';
  5. import {CLEARCHECKBODY,SET,CHECKBODY_CLEAR} from '@store/types/checkBody';
  6. import {clearAssistData,addAssistLabel} from '@store/actions/assistCheck';
  7. import {clearAllLabel,addLabel} from '@store/actions/inspect';
  8. import {CLEAR_ALL_DIAG} from '@store/types/diagnosticList';
  9. import {CLEAR_ALL_PUSH_MESSAGE, SET_TIPS,BILLING_ADVICE,PUSHCHANGE,SET_MR_ANALYSE} from '@store/types/pushMessage';
  10. import {ISREAD, SETREADDITEMS,SET_SELECTED_AREA,SET_CURRENT_MODULE} from "../store/types/homePage";
  11. import {CLEAR_FIRST_MAIN_DIAG, CLEAR_ALL_TREAT} from "../store/types/treat";
  12. import {tabChange} from '@store/actions/tabTemplate';
  13. import {CLEAR_ASSESS_RESULT_VALUE} from '@types/assessResult';
  14. import { SET_READ_MODE } from "@store/types/typeConfig";
  15. import config from '@config/index';
  16. import up from '@images/up.png';
  17. import down from '@images/down.png';
  18. import $ from 'jquery';
  19. import {CLEAR_SEARCH_PARAM} from "../store/types/print";
  20. /***
  21. * 工具函数
  22. *
  23. * ***/
  24. const qs = require('qs');
  25. //localStorage方法封装
  26. const storageLocal = {
  27. set: function (name, data) {
  28. if(!data) {
  29. return;
  30. }
  31. if(typeof data !== 'string') {
  32. data = JSON.stringify(data);
  33. }
  34. localStorage.setItem(name, data);
  35. },
  36. get: function (name) {
  37. return localStorage.getItem(name);
  38. },
  39. remove: function (name) {
  40. localStorage.removeItem(name);
  41. },
  42. clear: function () {
  43. localStorage.clear();
  44. }
  45. };
  46. //是否为空
  47. const isNull = (item)=>{
  48. return String(item)=== "" || String(item)==="null" || String(item)==="undefined";
  49. };
  50. const isNotNull = (item)=>{
  51. return !(isNull(item));
  52. };
  53. //判断是否为ie浏览器
  54. const isIE = () => { //ie?
  55. if (!!window.ActiveXObject || "ActiveXObject" in window){
  56. return true;
  57. } else{
  58. return false;
  59. }
  60. }
  61. const deepClone = (data)=>{
  62. return JSON.parse(JSON.stringify(data)||null)||{};
  63. };
  64. const getUrlArgObject = (parm) => {
  65. let query = window.location.search;
  66. let args = qs.parse(query.substr(1));
  67. return args[parm];//返回对象
  68. }
  69. const getAllDataList =(baseList) =>{ //获取所有模块结构化的数据
  70. let jsonData = {};
  71. // console.log(baseList,'=======================');
  72. jsonData.chief = baseList.mainSuit.saveText&&baseList.mainSuit.saveText[0]; // 主诉
  73. jsonData.currentIll = baseList.currentIll.saveText && baseList.currentIll.saveText[0]; //现病史
  74. jsonData.pastHistory = baseList.pastHistory.saveText && baseList.pastHistory.saveText[0]; //既往史
  75. jsonData.personalHistory = baseList.personalHistory.saveText && baseList.personalHistory.saveText[0]; //个人史
  76. jsonData.familyHistory = baseList.familyHistory.saveText && baseList.familyHistory.saveText[0]; //家族史
  77. jsonData.marriageHistory = baseList.marriageHistory.saveText && baseList.marriageHistory.saveText[0]; //婚育史
  78. jsonData.menstruationHistory = baseList.menstruationHistory.saveText && baseList.menstruationHistory.saveText[0]; //月经史
  79. jsonData.checkBody = baseList.checkBody.saveText && baseList.checkBody.saveText[0]; //查体
  80. //月经史公式
  81. // const other = baseList.otherHistory;
  82. // jsonData.lis = {};
  83. // jsonData.chief = baseList.mainSuit.data; //主诉
  84. // jsonData.present = baseList.currentIll.data; //现病史
  85. // jsonData.other = other.data; //其他史
  86. // jsonData.otherHistoryIsEmpty = other.isEmpty;
  87. // jsonData['yjs_1'] = other['yjs_1'];
  88. // jsonData['yjs_2'] = other['yjs_2'];
  89. // jsonData['yjs_3'] = other['yjs_3'];
  90. // jsonData['yjs_4'] = other['yjs_4'];
  91. // jsonData.vital = baseList.checkBody.data; //查体
  92. // jsonData.checkBodyIsEmpty = baseList.checkBody.isEmpty;
  93. // jsonData.lis.labelList = baseList.inspect.labelList; //化验
  94. // jsonData.lis.getExcelDataList = baseList.inspect.getExcelDataList; //化验导入
  95. // jsonData.checkedListImport = baseList.assistCheck.checkedListImport; //辅检导入
  96. // jsonData.pacs = baseList.assistCheck.assistLabel; //辅检
  97. // jsonData.diag = baseList.diagnosticList.diagnosticList; //诊断
  98. // jsonData.advice = baseList.pushMessage.advice; //医嘱
  99. // jsonData.addItems = baseList.homePage.addItems||{};
  100. // jsonData.mainsuitIds = baseList.mainSuit.mainIds; //主诉去重
  101. // jsonData.mainChronicDesease = baseList.mainSuit.chronicDesease; //主诉慢病{}
  102. // jsonData.diagChronicMagItem = baseList.diagnosticList.chronicMagItem; //诊断慢病{}
  103. // jsonData.currentIds = baseList.currentIll.symptomIds; //现病史去重
  104. // jsonData.isFirstMainDiag = baseList.treat.isFirstMainDiag; //治疗方案
  105. // jsonData.mainReadSonM = baseList.mainSuit.addSmoduleData; //主诉-子模板
  106. // jsonData.currReadSonM = baseList.currentIll.useEmpty?baseList.currentIll.currentEmptySon:baseList.currentIll.processModule; //现病史-子模板
  107. return jsonData;
  108. }
  109. const getAllDataStringList =(baseList) =>{ //获取所有模块文本的数据
  110. let jsonDataString = {};
  111. jsonDataString.lis = {};
  112. let chiefData = [],presentData=[],otherData=[],vitalData=[];
  113. if(baseList.mainSuit.saveText.length == 1 && baseList.mainSuit.saveText[0].trim() == ''){
  114. chiefData = []
  115. }else{
  116. chiefData = baseList.mainSuit.saveText
  117. }
  118. if(baseList.currentIll.saveText.length == 1 && baseList.currentIll.saveText[0].trim() == ''){
  119. presentData = []
  120. }else{
  121. presentData = baseList.currentIll.saveText
  122. }
  123. const oText = baseList.otherHistory.saveText;
  124. if(oText.length == 1 && oText[0] && oText[0].trim() == ''){
  125. otherData = []
  126. }else{
  127. otherData = baseList.otherHistory.saveText
  128. }
  129. if(baseList.checkBody.saveText.length == 1 && baseList.checkBody.saveText[0].trim() == ''){
  130. vitalData = []
  131. }else{
  132. vitalData = baseList.checkBody.saveText
  133. }
  134. jsonDataString = {
  135. 'chief' : JSON.stringify(chiefData),
  136. 'present' : JSON.stringify(presentData),
  137. 'other' : JSON.stringify(otherData),
  138. 'vital' : JSON.stringify(vitalData),
  139. 'lis' : baseList.inspect.inspectStrPlus,
  140. 'pacs' : baseList.assistCheck.dataString,
  141. 'diag' : baseList.diagnosticList.diagnosticStr,
  142. 'advice' : baseList.pushMessage.AdviceStr
  143. }
  144. return jsonDataString;
  145. }
  146. // 返回文本信息 _lcq
  147. const formatTextInfo = (baseList) =>{
  148. return {
  149. 'chief': JSON.stringify(baseList.mainSuit.saveText),
  150. 'present': JSON.stringify(baseList.currentIll.saveText),
  151.        'pastHistory': JSON.stringify(baseList.pastHistory.saveText),
  152.        'personalHistory': JSON.stringify(baseList.personalHistory.saveText),
  153.        'familyHistory': JSON.stringify(baseList.familyHistory.saveText),
  154.        'marriageHistory': JSON.stringify(baseList.marriageHistory.saveText),
  155.        'menstruationHistory': JSON.stringify(baseList.menstruationHistory.saveText),
  156. 'vital': JSON.stringify(baseList.checkBody.saveText),
  157. //        'lis': baseList.inspect.inspectStrPlus,
  158. //        'pacs': baseList.assistCheck.dataString,
  159. //        'diag': baseList.diagnosticList.diagnosticStr,
  160. //        'advice': baseList.pushMessage.AdviceStr
  161.   }
  162. }
  163. /**
  164. *
  165. * @param {回读数据} reData
  166. * @param {回读数据是历史病历'history',还是模板'template',预问诊引用'preIcss'} type
  167. * @param {什么操作,回读'push'还是清空'clear'} action
  168. * @param {引用的话是保存时候的文本类型,编辑的时候是当前页面设置的文本类型} whichSign
  169. */
  170. const pushAllDataList =(whichSign,action,reData,type) =>{ //回读清空所有的数据
  171. store.getState().inspect.context.scrollArea&&store.getState().inspect.context.scrollArea.scrollTop()
  172. if(action == 'clear'){ //清空
  173. const embedPush=require('@store/async-actions/pushMessage').embedPush; //直接在上面import会报错
  174. const block = Object.assign(JSON.parse(config.textLabel),{full:true});//空白时保留一个自由文本标签
  175. //清除已删除标签记录
  176. //localStorage.removeItem('deletedTags');
  177. //store.dispatch({type: SET_READ_MODE, readMode: -1,readConfig:-1,isPreIcss:false}); //清除回读模式值
  178. store.dispatch({type: CLEAR_MAIN_SUIT,data:[],saveText:[],editClear:true,mainIds:[],mainTailIds:[],clearAction:true,symptomFeature:[],chronicDesease:null,mainReadSonM:[]});
  179. store.dispatch({type: CLEAR_CURRENT_ILL,data:[],saveText:[],editClear:true,symptomIds:[],currReadSonM:[]});
  180. store.dispatch({type: CLEAROTHERHISTORY,data:[block],isEmpty:true,saveText:[],editClear:true,yjs_1:'',yjs_2:'',yjs_3:'',yjs_4:''});
  181. store.dispatch({type: CLEARCHECKBODY,data:[block],isEmpty:true,saveText:[]});
  182. //store.dispatch({type:SETREADDITEMS}); //清空已存的血压加号项
  183. store.dispatch(clearAssistData([],'',[]));
  184. store.dispatch(clearAllLabel([],[],''));
  185. store.dispatch(embedPush({mode:1})); //刷新右侧推送
  186. //右侧搜索条件清空
  187. store.dispatch({
  188. type: CLEAR_SEARCH_PARAM,
  189. data: Math.random()
  190. });
  191. //tab跳回辅助信息
  192. store.dispatch(tabChange('0'));
  193. store.dispatch({
  194. type: SET_TIPS,
  195. tips: {}
  196. })
  197. store.dispatch({
  198. type: CLEAR_ALL_DIAG,
  199. data:[],
  200. saveText:'',
  201. mainSuitStr: '',
  202. chronicMagItem:null
  203. });
  204. store.dispatch({
  205. type: CLEAR_ALL_PUSH_MESSAGE,
  206. data:{},
  207. saveText:'',
  208. });
  209. store.dispatch({
  210. type:CLEAR_FIRST_MAIN_DIAG,
  211. flag:true
  212. });
  213. store.dispatch({
  214. type: CLEAR_ALL_TREAT,
  215. });
  216. //清空已选的指标推送数据及填的值
  217. /*store.dispatch({
  218. type: CLEAR_ASSESS_RESULT_VALUE,
  219. });*/
  220. store.dispatch({//推送重置
  221. type: BILLING_ADVICE,
  222. determine:[],
  223. doubt:[],
  224. possible:[],
  225. vigilant: [],
  226. likely:[],
  227. lab: [],
  228. pacs:[],
  229. setPushEmergency:{},
  230. setPushEmergencyIdx:''
  231. });
  232. /*store.dispatch({
  233. type: SET_CURRENT_MODULE,
  234. moduleName: ''
  235. })
  236. store.dispatch({
  237. type: SET_MR_ANALYSE,
  238. MRAnalyseResult: []
  239. })*/
  240. storageLocal.remove('emrParam');
  241. // Notify.success('页面已清空')
  242. }else if(type == 'preIcss'){
  243. store.dispatch({type: SET_READ_MODE, readMode: whichSign,isPreIcss:true});
  244. store.dispatch({ //主诉文本框
  245. type: CLEAR_MAIN_SUIT,
  246. data:[],
  247. saveText:reData.chief
  248. });
  249. store.dispatch({
  250. type: CLEAR_CURRENT_ILL,
  251. data:[],
  252. saveText:reData.current
  253. });
  254. store.dispatch({
  255. type: CLEAROTHERHISTORY,
  256. data:[],
  257. isEmpty:false,
  258. saveText:reData.other
  259. });
  260. store.dispatch({
  261. type: SET,
  262. isEmpty:reData.checkBody?false:true,
  263. data:reData.checkBody,
  264. isText:true, //查体只显示文本
  265. });
  266. store.dispatch({type:SETREADDITEMS}); //清空已存的血压加号项
  267. store.dispatch(clearAssistData([],'',[]));
  268. store.dispatch(clearAllLabel([],[],''));
  269. store.dispatch({
  270. type: SET_TIPS,
  271. tips: {}
  272. })
  273. store.dispatch({
  274. type: CLEAR_ALL_DIAG,
  275. data:[],
  276. saveText:'',
  277. mainSuitStr: '',
  278. chronicMagItem:null
  279. });
  280. store.dispatch({
  281. type: CLEAR_ALL_PUSH_MESSAGE,
  282. data:{},
  283. saveText:'',
  284. });
  285. store.dispatch({
  286. type:CLEAR_FIRST_MAIN_DIAG,
  287. flag:true
  288. });
  289. store.dispatch({
  290. type: CLEAR_ALL_TREAT,
  291. });
  292. //清空已选的指标推送数据及填的值
  293. store.dispatch({
  294. type: CLEAR_ASSESS_RESULT_VALUE,
  295. });
  296. store.dispatch({//推送重置
  297. type: BILLING_ADVICE,
  298. determine:[],
  299. doubt:[],
  300. possible:[],
  301. vigilant: [],
  302. likely:[],
  303. lab: [],
  304. pacs:[],
  305. setPushEmergency:{},
  306. setPushEmergencyIdx:''
  307. });
  308. storageLocal.remove('emrParam');
  309. }else{
  310. let dataJson = JSON.parse(reData.dataJson);
  311. const docConfig = dataJson.docConfigs;
  312. //回读/引用设置回读模式值(主诉-其他史使用)
  313. store.dispatch({type: SET_READ_MODE, readMode: whichSign,readConfig:docConfig});
  314. if (whichSign == 0) {
  315. //其他史data
  316. const oData = dataJson.other;
  317. const onlyOneText = oData.length==1&&oData[0].tagType==8&&!(oData[0].name||oData[0].value);
  318. if(type == 'template'){ //结构化模板回读
  319. let dataJsonStr = JSON.parse(reData.preview);
  320. // console.log(dataJson,dataJsonStr,'结构化模板引用')
  321. //清空已选的指标推送数据及填的值
  322. store.dispatch({
  323. type: CLEAR_ASSESS_RESULT_VALUE,
  324. });
  325. store.dispatch({
  326. type: CLEAR_MAIN_SUIT,
  327. data:dataJson.chief,
  328. saveText:JSON.parse(dataJsonStr.chief),
  329. mainIds:dataJson.mainsuitIds?dataJson.mainsuitIds:[],
  330. chronicDesease:dataJson.mainChronicDesease,
  331. mainReadSonM:dataJson.mainReadSonM,
  332. });
  333. store.dispatch({
  334. type: CLEAR_CURRENT_ILL,
  335. data:dataJson.present,
  336. saveText:JSON.parse(dataJsonStr.present),
  337. symptomIds:dataJson.currentIds?dataJson.currentIds:[],
  338. currReadSonM:dataJson.currReadSonM
  339. });
  340. store.dispatch({
  341. type: CLEAROTHERHISTORY,
  342. data:dataJson.other,
  343. yjs_1:dataJson.yjs_1,
  344. yjs_2:dataJson.yjs_2,
  345. yjs_3:dataJson.yjs_3,
  346. yjs_4:dataJson.yjs_4,
  347. isEmpty:onlyOneText?true:false,//dataJson.otherHistoryIsEmpty,
  348. saveText:JSON.parse(dataJsonStr.other),
  349. editClear:dataJson.other.length>0?false:true
  350. });
  351. store.dispatch({
  352. type: CLEARCHECKBODY,
  353. data:dataJson.vital,
  354. isEmpty:dataJson.checkBodyIsEmpty,
  355. saveText:JSON.parse(dataJsonStr.vital)
  356. });
  357. store.dispatch(clearAllLabel(
  358. dataJson.lis.labelList,
  359. dataJson.lis.getExcelDataList,
  360. dataJsonStr.lis.split('-')[0],
  361. dataJsonStr.lis.split('-')[1]
  362. ));
  363. store.dispatch(clearAssistData(dataJson.pacs,dataJsonStr.pacs,dataJson.checkedListImport||[]));
  364. store.dispatch({
  365. type: CLEAR_ALL_DIAG,
  366. data:dataJson.diag,
  367. saveText:dataJsonStr.diag,
  368. chronicMagItem:dataJson.diagChronicMagItem
  369. });
  370. store.dispatch({
  371. type: CLEAR_ALL_PUSH_MESSAGE,
  372. data:dataJson.advice,
  373. saveText:dataJsonStr.advice
  374. });
  375. store.dispatch({
  376. type:SETREADDITEMS,
  377. data:dataJson.addItems
  378. });
  379. store.dispatch({
  380. type:CLEAR_FIRST_MAIN_DIAG,
  381. flag:dataJson.isFirstMainDiag
  382. });
  383. //tab跳回辅助信息
  384. store.dispatch(tabChange('0'));
  385. }else{ //结构化历史病历回读
  386. let dataJsonStr = reData.detailList;
  387. //清空已选的指标推送数据及填的值
  388. store.dispatch({
  389. type: CLEAR_ASSESS_RESULT_VALUE,
  390. });
  391. store.dispatch({
  392. type: CLEAR_MAIN_SUIT,
  393. data:dataJson.chief,
  394. saveText:dataJsonStr[0].content ? JSON.parse(dataJsonStr[0].content) :[],
  395. mainIds:dataJson.mainsuitIds?dataJson.mainsuitIds:[],
  396. chronicDesease:dataJson.mainChronicDesease,
  397. mainReadSonM:dataJson.mainReadSonM,
  398. });
  399. store.dispatch({
  400. type: CLEAR_CURRENT_ILL,
  401. data:dataJson.present,
  402. saveText:dataJsonStr[1].content ? JSON.parse(dataJsonStr[1].content):[],
  403. symptomIds:dataJson.currentIds?dataJson.currentIds:[],
  404. currReadSonM:dataJson.currReadSonM
  405. });
  406. store.dispatch({
  407. type: CLEAROTHERHISTORY,
  408. data:dataJson.other,
  409. yjs_1:dataJson.yjs_1,
  410. yjs_2:dataJson.yjs_2,
  411. yjs_3:dataJson.yjs_3,
  412. yjs_4:dataJson.yjs_4,
  413. saveText:dataJsonStr[2].content ? JSON.parse(dataJsonStr[2].content):[],
  414. isEmpty:onlyOneText?true:false,//dataJson.otherHistoryIsEmpty,回读回来后判断是否只有一个空标签,是的话要使用模板
  415. editClear:dataJson.other.length>0?false:true
  416. });
  417. store.dispatch({
  418. type: CLEARCHECKBODY,
  419. data:dataJson.vital,
  420. isEmpty:dataJson.checkBodyIsEmpty,
  421. saveText:dataJsonStr[3].content ? JSON.parse(dataJsonStr[3].content):[]
  422. });
  423. store.dispatch(clearAllLabel(
  424. dataJson.lis.labelList,
  425. dataJson.lis.getExcelDataList,
  426. dataJsonStr[4].content ? dataJsonStr[4].content.split('-')[0] :'',
  427. dataJsonStr[4].content ? dataJsonStr[4].content.split('-')[1] :''
  428. ));
  429. store.dispatch(clearAssistData(
  430. dataJson.pacs,
  431. dataJsonStr[5].content ? dataJsonStr[5].content:'',
  432. dataJson.checkedListImport||[]
  433. ));
  434. store.dispatch({
  435. type: CLEAR_ALL_DIAG,
  436. data:dataJson.diag,
  437. saveText:dataJsonStr[6].content ? dataJsonStr[6].content:'',
  438. chronicMagItem:dataJson.diagChronicMagItem
  439. });
  440. store.dispatch({
  441. type: CLEAR_ALL_PUSH_MESSAGE,
  442. data:dataJson.advice,
  443. saveText:dataJsonStr[7].content ? dataJsonStr[7].content:''
  444. });
  445. store.dispatch({
  446. type:SETREADDITEMS,
  447. data:dataJson.addItems
  448. });
  449. store.dispatch({
  450. type:CLEAR_FIRST_MAIN_DIAG,
  451. flag:dataJson.isFirstMainDiag
  452. });
  453. }
  454. } else {
  455. if(type == 'template'){ //纯文本模板回读
  456. //let dataJson = JSON.parse(reData.dataJson);
  457. let dataJsonStr = JSON.parse(reData.preview);
  458. // console.log(dataJson,dataJsonStr,'纯文本模板引用')
  459. store.dispatch({ //主诉文本框
  460. type: CLEAR_MAIN_SUIT,
  461. data:[],
  462. saveText:JSON.parse(dataJsonStr.chief)
  463. });
  464. store.dispatch({
  465. type: CLEAR_CURRENT_ILL,
  466. data:[],
  467. saveText:JSON.parse(dataJsonStr.present)
  468. });
  469. store.dispatch({
  470. type: CLEAROTHERHISTORY,
  471. data:[],
  472. isEmpty:dataJson.otherHistoryIsEmpty,
  473. saveText:JSON.parse(dataJsonStr.other)
  474. });
  475. store.dispatch({
  476. type: CLEARCHECKBODY,
  477. data:dataJson.vital,
  478. isEmpty:dataJson.checkBodyIsEmpty,
  479. flg:true,
  480. saveText:JSON.parse(dataJsonStr.vital)
  481. });
  482. store.dispatch(clearAllLabel(
  483. dataJson.lis.labelList,
  484. dataJson.lis.getExcelDataList,
  485. dataJsonStr.lis.split('-')[0],
  486. dataJsonStr.lis.split('-')[1]
  487. ));
  488. store.dispatch(clearAssistData(dataJson.pacs,dataJsonStr.pacs,dataJson.checkedListImport||[]));
  489. store.dispatch({
  490. type: CLEAR_ALL_DIAG,
  491. data:dataJson.diag,
  492. saveText:dataJsonStr.diag
  493. });
  494. store.dispatch({
  495. type: CLEAR_ALL_PUSH_MESSAGE,
  496. data:dataJson.advice,
  497. saveText:dataJsonStr.advice,
  498. });
  499. store.dispatch({
  500. type:SETREADDITEMS,
  501. data:dataJson.addItems
  502. });
  503. store.dispatch({
  504. type:CLEAR_FIRST_MAIN_DIAG,
  505. flag:dataJson.isFirstMainDiag
  506. });
  507. //tab跳回辅助信息
  508. store.dispatch(tabChange('0'));
  509. }else{ //纯文本历史病历回读
  510. //let dataJson = JSON.parse(reData.dataJson);
  511. let dataJsonStr = reData.detailList;
  512. // console.log(dataJson,dataJsonStr,'纯文本历史病历回读')
  513. if(!dataJson && !dataJsonStr && !reData.sign){
  514. return;
  515. }
  516. store.dispatch({
  517. type: CLEAR_MAIN_SUIT,
  518. data:[],
  519. saveText:dataJsonStr[0].content ? JSON.parse(dataJsonStr[0].content) :[]
  520. });
  521. store.dispatch({
  522. type: CLEAR_CURRENT_ILL,
  523. data:[],
  524. saveText:dataJsonStr[1].content ? JSON.parse(dataJsonStr[1].content) :[]
  525. });
  526. store.dispatch({
  527. type: CLEAROTHERHISTORY,
  528. data:[],
  529. isEmpty:dataJson.otherHistoryIsEmpty,
  530. saveText:dataJsonStr[2].content ? JSON.parse(dataJsonStr[2].content) :[]
  531. });
  532. store.dispatch({
  533. type: CLEARCHECKBODY,
  534. data:dataJson.vital,
  535. flg:true,
  536. isEmpty:dataJson.checkBodyIsEmpty,
  537. saveText:dataJsonStr[3].content ? JSON.parse(dataJsonStr[3].content):[]
  538. });
  539. store.dispatch(clearAllLabel(
  540. dataJson.lis.labelList,
  541. dataJson.lis.getExcelDataList,
  542. dataJsonStr[4].content ? dataJsonStr[4].content.split('-')[0] :'',
  543. dataJsonStr[4].content ? dataJsonStr[4].content.split('-')[1]:''
  544. ));
  545. store.dispatch(clearAssistData(
  546. dataJson.pacs,
  547. dataJsonStr[5].content ? dataJsonStr[5].content:'',
  548. dataJson.checkedListImport||[]
  549. ));
  550. store.dispatch({
  551. type: CLEAR_ALL_DIAG,
  552. data:dataJson.diag,
  553. saveText:dataJsonStr[6].content ? dataJsonStr[6].content:''
  554. });
  555. store.dispatch({
  556. type: CLEAR_ALL_PUSH_MESSAGE,
  557. data:dataJson.advice,
  558. saveText:dataJsonStr[7].content ? dataJsonStr[7].content:''
  559. });
  560. store.dispatch({
  561. type:SETREADDITEMS,
  562. data:dataJson.addItems
  563. });
  564. store.dispatch({
  565. type:CLEAR_FIRST_MAIN_DIAG,
  566. flag:dataJson.isFirstMainDiag
  567. });
  568. }
  569. }
  570. }
  571. store.dispatch({
  572. type:ISREAD
  573. });
  574. }
  575. function filterArr(arr){
  576. let tmpArr = arr.filter((item)=>{
  577. if(item){
  578. return item
  579. }
  580. });
  581. return tmpArr.join("").replace(/\s/g,'');
  582. }
  583. function filterDataArr(arrTmp){ //数据处理
  584. if(!Array.isArray(arrTmp)){
  585. return
  586. }
  587. let tmpArr = [];
  588. tmpArr = arrTmp.map((it,i)=>{ //连续的标点符号保留第一个
  589. if(!it)return '';
  590. if(!it.match(config.punctuationReg)&&!arrTmp[i-1]){ //只有标点符号或者前一个标签无值是(说明本标点灰显,不显示在预览中)
  591. return '';
  592. }
  593. return it.replace(config.punReg,function(word){
  594. return word.substr(0,1);
  595. });
  596. });
  597. return trimDots(tmpArr.join('')); //去掉开头的标点符号,最后的标点保留第一个,中间连续的保留第一个
  598. }
  599. //其他史预览数据处理-月经史
  600. function filterOtherDataArr(arrTmp,jsonArr){
  601. let tmpArr = [];
  602. let index1 = jsonArr.findIndex((item)=>{
  603. return item.formulaCode=='yjs_1';
  604. });
  605. let index2 = jsonArr.findIndex((item)=>{
  606. return item.formulaCode=='yjs_2';
  607. });
  608. let index3 = jsonArr.findIndex((item)=>{
  609. return item.formulaCode=='yjs_3';
  610. });
  611. let index4 = jsonArr.findIndex((item)=>{
  612. return item.formulaCode=='yjs_4';
  613. });
  614. if(index1==-1&&index2==-1&&index3==-1&&index4==-1){//无月经史
  615. return {str1:filterDataArr(arrTmp),str2:''};
  616. }
  617. tmpArr = arrTmp.map((it,i)=>{ //连续的标点符号保留第一个
  618. if(!it.match(config.punctuationReg)&&!arrTmp[i-1]||[index1,index2,index3,index4].includes(i)){ //只有标点符号或者前一个标签无值是(说明本标点灰显,不显示在预览中)
  619. return '';
  620. }
  621. return it.replace(config.punReg,function(word){
  622. return word.substr(0,1);
  623. });
  624. });
  625. const splitNum = [index1,index2,index3,index4].find((i)=>i!=-1);
  626. const str1 = [...tmpArr].splice(0,splitNum).join("");
  627. const str2 = [...tmpArr].splice(splitNum).join("");
  628. return {str1:trimDots(str1),str2:trimDots(str2),index:index1};
  629. }
  630. //去掉开头的标点符号,最后的标点保留第一个,中间连续的保留第一个
  631. function trimDots(str){
  632. if(!str)return'' ;
  633. return str.replace(config.punReg,function(word){
  634. return word.substr(0,1);
  635. }).replace(/^[,,.。::"“??”;;、!!\s]+/,'').replace(/[,,.。::"“??”;;、!!\s]*$/,'。');
  636. }
  637. //标签间连续标点只保留一个,保留前面一个
  638. function formatContinueDots(data){
  639. let arr=[];
  640. arr=data&&data.filter((it,i)=>{
  641. if(i==0||(it.name&&(it.name.match(config.punctuationReg))||(data[i-1].name&&data[i-1].name.match(config.punctuationReg)))){
  642. return it;
  643. }
  644. if(!it.name){ //主诉现病史病情变化
  645. return it;
  646. }
  647. });
  648. return arr;
  649. }
  650. // 取消默认行为
  651. function preventDefault(event) {
  652. if (event.preventDefault) {
  653. event.preventDefault();
  654. } else {
  655. event.returnValue = false;
  656. }
  657. }
  658. //ie8添加解除事件兼容
  659. function windowEventHandler(type,func,dom){
  660. let win = dom?dom:window;
  661. if(win.addEventListener){
  662. win.addEventListener(type, func);
  663. }else{
  664. win.attachEvent('on'+type,func);
  665. }
  666. }
  667. function windowRemoveEventHandler(type,func,dom){
  668. let win = dom?dom:window;
  669. if(win.addEventListener){
  670. win.removeEventListener(type, func);
  671. }else{
  672. win.detachEvent('on'+type,func);
  673. }
  674. }
  675. //禁止回车事件
  676. function handleEnter(event){
  677. event = event?event:window.event;
  678. if(event.keyCode==13){return false;}
  679. }
  680. //获取病例输入的内容
  681. // function getEMRParams(){
  682. // const state = store.getState();
  683. // const {message} = state.patInfo;
  684. // const {mainSuit,currentIll,otherHistory,checkBody,inspect,assistCheck,diagnosticList} = state;
  685. // //console.log('message', message)
  686. // const main = filterDataArr(mainSuit.saveText)||'',
  687. // current=filterDataArr(currentIll.saveText)||'',
  688. // other = filterDataArr(otherHistory.saveText)||'',
  689. // vital = filterDataArr(checkBody.saveText)||'',
  690. // lis = inspect.pushItem, //化验推送所需数据
  691. // pacs = assistCheck.dataString||'',
  692. // dis=diagnosticList.diagnosticStrNoType||'',
  693. // advice = '',
  694. // diseaeId = [];
  695. // const age = message.patientAge;
  696. // const sex = message.sex;
  697. // const patientId = message.patientId //病人id,取上次用药
  698. // const hosCode = message.hospitalCode
  699. // return {main,current,other,vital,lis,pacs,dis,advice,diseaeId,sex,age, patientId, hosCode};
  700. // };
  701. function getEMRParams(){
  702. const state = store.getState();
  703. const {message} = state.patInfo;
  704. const {mainSuit,currentIll,otherHistory,checkBody,inspect,assistCheck,diagnosticList} = state;
  705. const diag = [];
  706. for(let i = 0; i < diagnosticList.diagnosticList.length; i++) {
  707. diag.push({"dateValue": "","name": "","uniqueName": diagnosticList.diagnosticList[i].name})
  708. }
  709. const obj = {
  710. "hosCode": message.hospitalCode,
  711. "age": message.patientAge,
  712. "sex": message.sex,
  713. "deptName":message.hospitalDeptName,
  714. "chief": filterDataArr(mainSuit.saveText)||'',
  715. "symptom": filterDataArr(currentIll.saveText)||'',
  716. "vital": filterDataArr(checkBody.saveText)||'',
  717. "pasts": filterDataArr(otherHistory.saveText)||'',
  718. "infectious": "",
  719. "operation": "",
  720. "allergy": "",
  721. "vaccination": "",
  722. "personal": "",
  723. "marital": "",
  724. "family": "",
  725. "menstrual": "",
  726. "other": filterDataArr(otherHistory.saveText)||'',
  727. "lisString": "",
  728. "pacsString": "",
  729. "diagString": "",
  730. "drugString": "",
  731. "lis": inspect.pushItem,
  732. "pacs": assistCheck.dataArr||[],
  733. "diag": [],
  734. "lisOrder": [],
  735. "pacsOrder": [],
  736. "diagOrder": diag,
  737. "drugOrder": [],
  738. "operationOrder": [],
  739. "otherOrder": [],
  740. "patientId": message.patientId,
  741. "drug": [],
  742. "marriage": ""
  743. }
  744. return obj;
  745. };
  746. function getMRInfo() {
  747. const state = store.getState();
  748. const {message} = state.patInfo;
  749. const {mainSuit,currentIll,otherHistory,checkBody,inspect,assistCheck,diagnosticList} = state;
  750. let diagStr = ""
  751. for(let i = 0; i < diagnosticList.diagnosticList.length; i++) {
  752. if(i == 0) {
  753. diagStr +=diagnosticList.diagnosticList[i].name
  754. } else {
  755. diagStr += ',' + diagnosticList.diagnosticList[i].name
  756. }
  757. }
  758. let str = `姓名: ${message.patientName}
  759. 性别:${message.patientSex}
  760. 年龄:${message.patientAge}
  761. 主诉:${filterDataArr(mainSuit.saveText)}
  762. 现病史:${filterDataArr(currentIll.saveText)}
  763. 其他史:${filterDataArr(otherHistory.saveText)}
  764. 查体:${filterDataArr(checkBody.saveText)}
  765. 化验:${inspect.inspectStrPlus}
  766. 辅检:${assistCheck.dataString}
  767. 诊断:${diagStr}
  768. 医师签名:${message.doctorName}`
  769. //let str = "姓  名:姜** /r/n性   别:女/r/n年 龄:34岁/r/n民 族:汉族/r/n职 业:经商/r/n出 生 地:浙江省长兴县/r/n婚 姻:已婚/r/n联系地址:*** /r/n病史陈述者:患者本人/r/n入院日期:2019-12-04 10:12/r/n /r/n记录日期:2019-12-04 14:37/r/n /r/n主 诉: 腹痛1周 /r/n现 病 史: 患者1周前饮食辛辣食物后出现腹痛,主要为脐以上为主,呈持续性钝痛,无明显恶心呕吐,无肩背部疼痛,无咳嗽咳痰,无腹泻腹痛,无胸闷气促,无头晕头痛,无视物旋转,无异常阴道流血流液等情况,自诉近一周感下腹坠胀感,为求进一步诊治拟\"腹痛待查\"收住入院。/r/n患病来,神志清,精神软,胃纳差,睡眠一步,大小便如常,近期体重无明显改变。 /r/n既 往 史: 否认\"高血压,糖尿病,冠心病\"病史,否认\"肝炎,结核\"等传染病史,否认重大外伤史,否认手术史,否认输血史,既往存在头孢过敏,具体不详,否认长期药物使用史,否认药物成瘾,预防接种史不详。 /r/n个 人 史: 出生并生长于浙江省长兴县,经商,初中文化,否认疫区居住史,否认放射物、毒物、粉尘接触史,否认吸烟,否认饮酒,否认特殊嗜好,否认不洁性交史。 /r/n月 经 史: ,经量中等,颜色正常,无痛经,经期规律;白带量一般,性状无殊。 /r/n婚 育 史: 27岁结婚,否认近亲结婚,配偶健康状况良好,夫妻关系和睦,育有1女,均健康。/r/n家 族 史: 父亲体健,母已故(死因不详),有2哥,均体健,家族中无传染病及遗传病史,否认两系三代内遗传性、家族性疾病史,否认家族中有\"肝炎、结核\"等传染病史,否认两系三代内\"胃癌、肺癌\"等肿瘤病史,否认类似疾病史。 /r/n体格检查(一)/r/n /r/n一般状况:/r/n体温36.3℃,脉搏68次/分,呼吸19次/分,血压133/81mmHg。/r/n意识清晰,自主体位,面容无殊,体重56Kg,身高163cm,查体合作。 /r/n皮 肤:/r/n皮肤色泽正常,弹性好,未见明显水肿,未见皮疹,未见皮下出血,未见肝掌及蜘蛛痣。/r/n淋 巴 结:/r/n未触及明显浅表淋巴结肿大 /r/n头 部:/r/n外形大小正常,无畸形。听力粗测正常。眼睑正常,结膜正常,巩膜无黄染,瞳孔等大等圆,直径3mm,对光反射灵敏。鼻部外形正常,通气顺畅,副鼻窦区无压痛,乳突无压痛。口腔粘膜正常,扁桃体无肿大。/r/n颈  部:/r/n颈软,无抵抗感,气管位置居中,颈静脉无怒张。/r/n胸  部:/r/n外形正常,肋间隙正常,双侧乳房正常对称。/r/n肺 部:/r/n呼吸运动正常对称,双肺叩诊呈清音,呼吸音清晰,未闻及干、湿啰音。/r/n心 脏:/r/n心率68次/分,心律齐,心音有力,P2<A2,各瓣膜听诊区未闻及杂音。 /r/n血 管:/r/n周围血管征阴性。 /r/n腹  部:/r/n外形正常,未见肠形及蠕动波,腹壁松软,脐以上及下腹存在轻压痛,无反跳痛,/r/n包块未触及,肝脏肋下未触及,胆囊肋下未触及,脾脏肋下未触及,双肾区无叩痛,肠鸣音正常,3~5次/分,移动性浊音阴性。/r/n外生殖器:/r/n未见明显畸形 /r/n直肠肛门:/r/n未见明显畸形 /r/n四肢脊柱:/r/n脊柱无畸形,无压痛叩击痛,无放射痛,活动自如,四肢正常。/r/n神经系统:/r/n四肢肌张力正常,肌力V级,膝腱反射双侧正常,Babinski征双侧阴性。/r/n其 他:/r/n详见专科检查。/r/n/r/n体格检查(二)/r/n补 充 及 专 科 情 况/r/n体温36.3℃,脉搏68次/分,呼吸19次/分,血压133/81mmHg神志清,呼吸平稳,浅表淋巴结未及肿大,两肺呼吸音清,双下肺未闻及湿罗音,心率68次/分,律齐,未闻及病理性杂音,腹平软,脐以上及下腹存在轻压痛,无反跳痛,肝脾肋下未触及,双下肢无浮肿。/r/n /r/n /r/n心脏相对浊音界/r/n /r/n右界cm/r/n肋间/r/n左界cm/r/n/r/n 2/r/nⅡ/r/n 2/r/n/r/n 2/r/nⅢ/r/n 4/r/n/r/n 3/r/nⅣ/r/n 6/r/n/r/n /r/nⅤ/r/n 8/r/n/r/n左锁骨中线距胸骨中线 8 cm/r/n辅助检查: 2019-12-4 心电图未见明显异常。 /r/n /r/n初步诊断:1、腹痛待查 2.盆腔炎/r/n修正诊断: /r/n 医师签名:李勇 /r/n /r/n2019-12-04 /r/n /r/n补充诊断:"
  770. let label = ["姓名","性别","年龄",
  771. "主诉","现病史","其他史","查体","化验","辅检",
  772. "诊断","医师签名"]
  773. const param = {
  774. "cid":0,
  775. "medrec":
  776. [
  777. {
  778. "content": {
  779. "content":str
  780. },
  781. "label": label,
  782. "title": "入院记录"
  783. }
  784. ],
  785. "token": ""
  786. }
  787. return param
  788. }
  789. function didPushParamChange(){
  790. const emrData = getEMRParams();
  791. const oldParams = storageLocal.get('emrParam');
  792. const newParams = JSON.stringify(emrData);
  793. if(newParams === oldParams){
  794. return false;
  795. }
  796. return true;
  797. }
  798. //判断模板保存时文本数据是否为空
  799. function isAllClear(jsonStr){
  800. if ( //结构化和文本数据都为空
  801. filterDataArr(JSON.parse(jsonStr.chief)) == '' &&
  802. filterDataArr(JSON.parse(jsonStr.present)) == '' &&
  803. filterDataArr(JSON.parse(jsonStr.other)) == '' && //这里都是filterDataArr不是filterArr,要去符号的
  804. filterDataArr(JSON.parse(jsonStr.vital)) == '' &&
  805. jsonStr.diag == '' &&
  806. jsonStr.lis == '' &&
  807. jsonStr.pacs == '' &&
  808. jsonStr.advice == ''
  809. ) {
  810. return false;
  811. }else{
  812. return true;
  813. }
  814. }
  815. //判断页面所有数据是否为空,包括空标签
  816. function isAllPartClear(jsonData,jsonStr,baseList){
  817. if ( //结构化和文本数据都为空
  818. JSON.stringify(jsonData.advice) == '{}' &&
  819. jsonData.chief.length < 1 &&
  820. jsonData.present.length < 1 &&
  821. // jsonData.other.length < 1 &&
  822. (jsonData.other.length > 0 ? baseList.otherHistory.isEmpty : true) &&
  823. //jsonData.vital.length < 1 &&
  824. (jsonData.vital.length > 0 ? baseList.checkBody.isEmpty : true) &&
  825. jsonData.diag.length < 1 &&
  826. jsonData.checkedListImport.length < 1 &&
  827. jsonData.pacs.length < 1 &&
  828. jsonData.lis.labelList.length < 1 &&
  829. jsonData.lis.getExcelDataList.length < 1 &&
  830. filterDataArr(JSON.parse(jsonStr.chief)) == '' &&
  831. filterDataArr(JSON.parse(jsonStr.present)) == '' &&
  832. filterDataArr(JSON.parse(jsonStr.other)) == '' && //这里都是filterDataArr不是filterArr,要去符号的
  833. filterDataArr(JSON.parse(jsonStr.vital)) == ''
  834. ) {
  835. return false;
  836. }else{
  837. return true;
  838. }
  839. }
  840. //判断除主诉外页面数据是否为空--慢病模板
  841. function ifOtherClear(jsonData,jsonStr,baseList){
  842. if ( //结构化和文本数据都为空
  843. JSON.stringify(jsonData.advice) == '{}' &&
  844. jsonData.present.length < 1 &&
  845. (jsonData.other.length > 0 ? baseList.otherHistory.isEmpty : true) &&
  846. (jsonData.vital.length > 0 ? baseList.checkBody.isEmpty : true) &&
  847. jsonData.diag.length < 1 &&
  848. jsonData.pacs.length < 1 &&
  849. jsonData.lis.labelList.length < 1 &&
  850. jsonData.lis.getExcelDataList.length < 1 &&
  851. filterDataArr(JSON.parse(jsonStr.present)) == '' &&
  852. filterDataArr(JSON.parse(jsonStr.other)) == '' && //这里都是filterDataArr不是filterArr,要去符号的
  853. filterDataArr(JSON.parse(jsonStr.vital)) == ''
  854. ) {
  855. return false;
  856. }else{
  857. return true;
  858. }
  859. }
  860. function normalVal(min,max){//添加正常值0处理
  861. if(!min&&!max){
  862. return null;
  863. }else if(min&&max){
  864. return `正常值:(${min}~${max})`
  865. }else if(!min && max){
  866. if(min == 0){
  867. return `正常值:(${min}~${max})`
  868. }
  869. return `正常值:(<${max})`
  870. }else if(min && !max){
  871. if(max == 0){
  872. return `正常值:(${min}~${max})`
  873. }
  874. return `正常值:(>${min})`
  875. }
  876. }
  877. /**
  878. *
  879. * @param {弹窗显示位置是否往下设置} stic
  880. */
  881. function getPageCoordinate(event,stic){//获取鼠标点击的位置
  882. let e = event || window.event;
  883. var scrollX = document.documentElement.scrollLeft || document.body.scrollLeft;
  884. var scrollY = document.documentElement.scrollTop || document.body.scrollTop;
  885. var x = e.pageX || (e.clientX + scrollX);
  886. var y = (e.pageY+(stic?25:0)) || (e.clientY + scrollY + (stic?25:0));//弹窗位置偏下25
  887. let obj = {
  888. boxLeft : x ,
  889. boxTop : y+18
  890. }
  891. return obj;
  892. }
  893. function timestampToTime(timestamp) { //excel导入2019年5月1日会转换成时间戳
  894. var date = new Date(timestamp);//时间戳为10位需*1000,时间戳为13位的话不需乘1000
  895. var Y = date.getFullYear() + '-';
  896. var M = (date.getMonth()+1 < 10 ? '0'+(date.getMonth()+1) : date.getMonth()+1) + '-';
  897. var D = date.getDate() + ' ';
  898. var h = date.getHours() + ':';
  899. var m = date.getMinutes() + ':';
  900. var s = date.getSeconds();
  901. return Y+M+D+h+m+s;
  902. }
  903. /**
  904. *
  905. * @param {需要年月日传个true,不需要不传或者false} flg
  906. */
  907. function getCurrentDate(flg,con){
  908. let link = con?con:'-'
  909. let myDate = new Date();
  910. let year = myDate.getFullYear(); //获取完整的年份(4位,1970-????)
  911. let mon = myDate.getMonth()-0+1; //获取当前月份(0-11,0代表1月)
  912. let day = myDate.getDate(); //获取当前日(1-31)
  913. let date = '';
  914. if(flg){
  915. var h = myDate.getHours();
  916. var m = myDate.getMinutes();
  917. var s = myDate.getSeconds();
  918. date = year+link+(mon<10?"0"+mon:mon)+link+(day<10?"0"+day:day)+' '+(h<10&&h!=0?"0"+h:h)+':'+(m<10&&m!=0?"0"+m:m)+':'+(s<10&&s!=0?"0"+s:s);
  919. }else{
  920. date = year+link+(mon<10?"0"+mon:mon)+link+(day<10?"0"+day:day);
  921. }
  922. return date;
  923. }
  924. function inspectAndAssist(){
  925. const state = store.getState();
  926. let mainType = state.typeConfig.mode
  927. if(mainType == 1){return}//文本模式不放化验辅检的模板
  928. let tmpAll = state.homePage.allModules;
  929. let tmpInspected = state.inspect.labelList;
  930. let tmpAssisted = state.assistCheck.assistLabel;
  931. let tmpInspect = [],tmpAssist = [],assayArr = [],tmpDetail=[],checkArr = [];
  932. for(let i = 0;i < tmpAll.length;i++){
  933. let tmpItem = tmpAll[i];
  934. if(tmpItem.type == 5){
  935. tmpInspect = tmpItem.moduleDetailDTOList || []
  936. }else if(tmpItem.type == 6){
  937. tmpAssist = tmpItem.moduleDetailDTOList || []
  938. }
  939. }
  940. for(let i = 0;i < tmpInspect.length;i++){//化验数据处理
  941. let tmpObj = { //添加化验
  942. details: [],
  943. name: '',
  944. questionId: '',
  945. showType: 1,
  946. uniqueName:''
  947. }
  948. if (tmpInspect[i].controlType == 0) {
  949. tmpDetail = tmpInspect[i].questionMapping
  950. }else if(tmpInspect[i].controlType == 1 || tmpInspect[i].controlType == 6){
  951. tmpDetail = new Array(tmpInspect[i])
  952. }
  953. tmpObj.questionId = tmpInspect[i].id
  954. tmpObj.name = tmpInspect[i].name
  955. tmpObj.details = tmpDetail
  956. tmpObj.uniqueName = tmpInspect[i].uniqueName || ''
  957. assayArr.push(tmpObj)
  958. }
  959. for(let i = 0;i < tmpAssist.length;i++){//辅检数据处理
  960. let tmpObj = { //添加辅检
  961. name: '',
  962. questionId: '',
  963. showType: 1,
  964. time:getCurrentDate(1),
  965. value:''
  966. }
  967. tmpObj.questionId = tmpAssist[i].id
  968. tmpObj.name = tmpAssist[i].name
  969. checkArr.push(tmpObj)
  970. }
  971. if(assayArr.length>0 && tmpInspected.length == 0){//化验
  972. store.dispatch(addLabel(assayArr))
  973. }
  974. if(checkArr.length > 0 && tmpAssisted.length == 0){//辅检
  975. store.dispatch(addAssistLabel(checkArr))
  976. }
  977. }
  978. function readyKeepHistory(){
  979. let baseList = store.getState();
  980. let jsonStr = getAllDataStringList(baseList);
  981. if(filterDataArr(JSON.parse(jsonStr.chief)) == ''){
  982. return 1;//主诉不能为空
  983. }else if(!jsonStr.diag || jsonStr.diag.trim().length < 1){
  984. return 2;//诊断不能为空
  985. }else{
  986. return 3;
  987. }
  988. }
  989. //评估图表数据转换
  990. function parseChartData(indexData){
  991. let arr=[],obj={},temp={};
  992. let nameArr=[],nameObj={};
  993. if(!indexData){
  994. return [];
  995. }
  996. indexData.indexData.map((it)=>{
  997. temp=indexData.indexConfigData.find((i)=>{return it.uniqueId==i.uniqueId});
  998. arr=obj[temp.groupType]||[];
  999. nameArr=nameObj[temp.groupType]||[];
  1000. obj[temp.groupType]=[...arr,it];
  1001. nameObj[temp.groupType]=[...nameArr,it.itemName];
  1002. });
  1003. //nameObj,obj;
  1004. return {nameObj,obj};
  1005. }
  1006. // 时间戳转换日期
  1007. function dateParser(timestamp,link = '-'){
  1008. let time = new Date(timestamp);
  1009. let year = time.getFullYear();
  1010. let month = time.getMonth()+1;
  1011. let date = time.getDate();
  1012. let hour = time.getHours();
  1013. let minute = time.getMinutes();
  1014. let second = time.getSeconds();
  1015. // let result = year+link+month+link+date;
  1016. let result = year+link+(month<10?"0"+month:month)+link+(date<10?"0"+date:date)+' '+(hour<10&&hour!=0?"0"+hour:hour)+':'+(minute<10&&minute!=0?"0"+minute:minute)+':'+(second<10&&second!=0?"0"+second:second);
  1017. return result;
  1018. }
  1019. //获取组合组件已填文字填入saveText
  1020. function getSaveText(data){//console.log(data)
  1021. const hasValue = data.questionMapping.findIndex((it)=>it.value!==undefined)!==-1; //有值时血压类型中文本标签要加入值
  1022. const arr = data.questionMapping.map((it)=>{
  1023. return it.value?(it.labelPrefix||'')+(it.value||'')+(it.labelSuffix||''):(hasValue&&!notTextLabel(it)?it.name:'');
  1024. });
  1025. return arr.join('');
  1026. }
  1027. //添加自由文本标签
  1028. function notTextLabel(label){
  1029. return +label.tagType!==8;
  1030. }
  1031. /*
  1032. * 给标签组添加自由文本标签
  1033. * 入参:arr源数组,
  1034. * noPre是否不添加前置文本标签,默认false即添加
  1035. * noEnd是否不添加后置文本标签,默认false即添加
  1036. * 出参:newArr添加自由文本标签后的数据Array,
  1037. * saveText添加自由文本后对应的预览数据Array,
  1038. * */
  1039. function fullfillText(arr,noPre=false,noEnd=false,boxMark){
  1040. let newArr =[],
  1041. pre={},
  1042. textLabel={},
  1043. notText = true,
  1044. saveText=[],
  1045. tempText = '',
  1046. value = '',
  1047. cNum = 0;
  1048. Array.isArray(arr)&&arr.map((it,i)=>{
  1049. notText = notTextLabel(it);
  1050. cNum = i;
  1051. value = it.value||'';
  1052. textLabel = JSON.parse(config.textLabel);
  1053. //n个显示的标签最后一个标签后面要落关标,所以+1
  1054. if(i===0){
  1055. //第一个标签不是文本标签时在前面添加文本标签
  1056. if(!noPre&&notText){
  1057. newArr.push(textLabel);
  1058. saveText.push('');
  1059. }
  1060. newArr.push(it);
  1061. if(it.tagType == 6||it.tagType == 2){
  1062. tempText = getDefaultedSaveText(it,boxMark);
  1063. }else if(it.tagType == 3){
  1064. tempText = getSaveText(it);
  1065. }else{ //非血压类组合标签
  1066. tempText = value?it.labelPrefix+value+it.labelSuffix:'';
  1067. tempText = notText?tempText:it.value||it.name;
  1068. }
  1069. saveText.push(tempText);
  1070. // 模板只有一个标签时第一项后面也要加空标签
  1071. if(arr.length==1&&notText){
  1072. newArr.push(JSON.parse(config.textLabel));
  1073. saveText.push('');
  1074. }
  1075. }else{
  1076. pre = arr[i-1];
  1077. //如果本身不是文本标签且前面一个也不是文本标签,该标签前面添加文本标签
  1078. if(notTextLabel(pre)&&notText){
  1079. newArr.push(textLabel,it);
  1080. if(it.tagType == 6||it.tagType == 2){
  1081. tempText = getDefaultedSaveText(it,boxMark);
  1082. }else if(it.tagType == 3){
  1083. tempText = getSaveText(it);
  1084. }else{
  1085. tempText = value ? it.labelPrefix + value + it.labelSuffix : '';
  1086. }
  1087. saveText.push("",tempText);
  1088. }else{ //本身是或者前面是文本标签时,前面不添加文本标签
  1089. newArr.push(it);
  1090. if(it.tagType == 6||it.tagType == 2){
  1091. tempText = getDefaultedSaveText(it,boxMark);
  1092. }else if(it.tagType == 3){
  1093. tempText = getSaveText(it);
  1094. } else{
  1095. tempText = value ? it.labelPrefix + value + it.labelSuffix : '';
  1096. tempText = notText ? tempText : (it.value || it.value == "" ? it.value : it.name);
  1097. }
  1098. saveText.push(tempText);
  1099. }
  1100. if(notText&&!noEnd&&i===arr.length-1){//最后一个非文本标签,后面添加一个文本标签
  1101. //不能用上面的变量textLabel,因为上一个if可能也进了,这样就是同一个对象,值改变时会同步
  1102. newArr.push(JSON.parse(config.textLabel));
  1103. saveText.push("");
  1104. }
  1105. }
  1106. });
  1107. return {newArr,saveText};
  1108. };
  1109. function getDefaultedSaveText(it,boxMark){
  1110. const state = store.getState();
  1111. const {readConfig,typeConfig}=state.typeConfig;
  1112. const hasReadMode = readConfig!==-1;
  1113. const curOtherMode =hasReadMode&&readConfig[2]!==null?readConfig[2]:typeConfig[2];
  1114. const curMode =hasReadMode&&readConfig[1]!==null?readConfig[1]:typeConfig[1];
  1115. const otherDefault=+curOtherMode===1;
  1116. const curDefault=+curMode===1;
  1117. const defaulted = (((boxMark=='2'&&curDefault)||(boxMark=='3'&&otherDefault)))&&it.selFlag=='1'&&it.value===undefined;
  1118. const ext = it.questionMapping.filter((i)=>{
  1119. return +i.exclusionType===1;
  1120. });
  1121. const text = ext.length>0&&defaulted?ext[0].questionDetailList[0].name:'';
  1122. //console.log(state);
  1123. return text;
  1124. }
  1125. /*
  1126. * 查体添加自由文本标签函数
  1127. * 默认标签直接添加,
  1128. * 前config.showCheckNum个源数据标签默认显示,剩余隐藏收起
  1129. * 入参:arr源数组,
  1130. * noPre是否不添加前置文本标签,默认false即添加
  1131. * noEnd是否不添加后置文本标签,默认false即添加
  1132. * showInCheck是否默认在查体中展开
  1133. * 出参:newArr添加自由文本标签后的数据Array,
  1134. * saveText添加自由文本后对应的预览数据Array,
  1135. * checkHiddenDefault查体是否全部标签展开
  1136. *
  1137. * */
  1138. function checkFullfillText(arr,noPre=false,noEnd=false){
  1139. let newArr =[],
  1140. pre={},
  1141. textLabel={},
  1142. notText = true,
  1143. saveText=[],
  1144. tempText = '',
  1145. value = '',
  1146. item={},
  1147. checkHiddenDefault=false;
  1148. arr&&arr.map((it,i)=>{
  1149. notText = notTextLabel(it);
  1150. value = it.value||'';
  1151. //textLabel = i==0?JSON.parse(config.textLabel):Object.assign({},JSON.parse(config.textLabel),{showInCheck:true});
  1152. //n个显示的标签最后一个标签后面要落关标,所以+1
  1153. //_textLabel = !ifEmpty&&cNum<config.showCheckNum+1?Object.assign({},JSON.parse(config._textLabel),{showInCheck:true}):JSON.parse(config._textLabel);
  1154. if(i===0){
  1155. textLabel = Object.assign({},JSON.parse(config.textLabel),{showInCheck:true});
  1156. //第一个标签不是文本标签时在前面添加文本标签
  1157. if(!noPre&&notText){
  1158. newArr.push(textLabel);
  1159. saveText.push('');
  1160. }
  1161. item = Object.assign({},it,{showInCheck:true});
  1162. newArr.push(item);
  1163. if(it.tagType != 3){
  1164. tempText = value?it.labelPrefix+value+it.labelSuffix:'';
  1165. tempText = notText?tempText:it.value||it.name;
  1166. }else{
  1167. tempText = getSaveText(it);
  1168. }
  1169. saveText.push(tempText);
  1170. // 模板只有一个标签时第一项后面也要加空标签
  1171. if(arr.length==1&&notText){
  1172. newArr.push(textLabel);
  1173. saveText.push('');
  1174. }
  1175. }else{
  1176. pre = arr[i-1];
  1177. item = i<config.showCheckNum?Object.assign({},it,{showInCheck:true}):it;
  1178. //判断单选项是否有默认选中,位置在隐藏区域时,查体所有标签展示
  1179. if(!checkHiddenDefault&&i>config.showCheckNum&&+it.tagType===1&&(+it.controlType===0||+it.controlType===1)){
  1180. if(it.questionDetailList.find((it)=>it.defaultSelect=='1')){
  1181. checkHiddenDefault=true;
  1182. }
  1183. }
  1184. //如果本身不是文本标签且前面一个也不是文本标签,该标签前面添加文本标签
  1185. if(notTextLabel(pre)&&notText){
  1186. textLabel = Object.assign(JSON.parse(config._textLabel),{showInCheck:i-1<config.showCheckNum?true:false});
  1187. newArr.push(textLabel,item);
  1188. if(it.tagType != 3) {
  1189. tempText = value ? it.labelPrefix + value + it.labelSuffix : '';
  1190. }else{
  1191. tempText = getSaveText(it);
  1192. }
  1193. saveText.push("",tempText);
  1194. }else{ //本身是或者前面是文本标签时,前面不添加文本标签
  1195. newArr.push(item);
  1196. if(it.tagType != 3) {
  1197. tempText = value ? it.labelPrefix + value + it.labelSuffix : '';
  1198. tempText = notText ? tempText : (it.value || it.value == "" ? it.value : it.name);
  1199. }else{
  1200. tempText = getSaveText(it);
  1201. }
  1202. saveText.push(tempText);
  1203. }
  1204. if(notText&&!noEnd&&i===arr.length-1){//最后一个非文本标签,后面添加一个文本标签
  1205. const _text = Object.assign(JSON.parse(config.textLabel),{showInCheck:arr.length>config.showCheckNum?false:true});
  1206. newArr.push(_text);
  1207. saveText.push("");
  1208. }
  1209. }
  1210. });
  1211. return {newArr,saveText,checkHiddenDefault};
  1212. }
  1213. //获取标签index,入参:病例项index+标签index+标签内index
  1214. function getLabelIndex(index){
  1215. let ikey = index.split('-')[1];
  1216. return ikey;
  1217. };
  1218. function getWindowInnerHeight(){
  1219. if(window.innerHeight!=undefined){
  1220. return window.innerHeight;
  1221. }else{
  1222. let by = document.body, ele = document.documentElement;
  1223. return Math.min(by.clientHeight,ele.clientHeight);
  1224. }
  1225. };
  1226. function getWindowInnerWidth(){
  1227. let width = window.innerWidth || document.body.clientWidth || document.documentElement.clientWidth
  1228. return width
  1229. };
  1230. function getIds(data){
  1231. let ids = [];
  1232. data&&data.forEach((it,i)=>{
  1233. ids.push(it.id);
  1234. })
  1235. return ids;
  1236. }
  1237. /**
  1238. *
  1239. * @param {日期相关} info
  1240. * @param {时间是否包含时分秒} flg
  1241. * @param {连接符} con
  1242. */
  1243. function getCalendarDate(info) {
  1244. let conect = '-';
  1245. let date = info.year + conect + (info.month < 10 ? '0' + info.month : info.month) + conect + (info.day < 10 ? '0' + info.day : info.day) + ' '+ (info.hour != 0&&(info.hour).toString().length<2 ? '0' + info.hour : info.hour)+':'+ (info.minute != 0&&(info.minute).toString().length<2 ? '0' + info.minute : info.minute)+':'+ (info.second&&(info.second).toString().length<2 ? '0' + info.second : info.second);
  1246. return date;
  1247. }
  1248. // 导出
  1249. function downloadExportedData(data, fileName) {
  1250. // var blob = new Blob([data], {type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8'}); //type表示xlsx类型
  1251. var blob = new Blob([data], {type: 'application/vnd.ms-excel;charset=UTF-8'}); //type表示xlsx类型
  1252. var href = window.URL.createObjectURL(blob);//创建下载的链接
  1253. // 为兼容FF26 (不支持a标签的模拟点击事件)
  1254. if (navigator.userAgent.indexOf("Firefox") > -1){
  1255. //window.open(requestUrl);
  1256. window.location.href = href;
  1257. }else {
  1258. var downloadElement = document.createElement('a');
  1259. downloadElement.href = href;
  1260. downloadElement.download = fileName; //下载后文件名
  1261. document.body.appendChild(downloadElement);
  1262. downloadElement.click(); //点击下载
  1263. document.body.removeChild(downloadElement); //下载完成移除元素
  1264. window.URL.revokeObjectURL(href);
  1265. }
  1266. }
  1267. function getStatusImg(type,val,status){
  1268. if(type == 0){//正常
  1269. return <span>{val} </span>
  1270. }else if(type == 1){//异常(表单输入的话非数字显示为异常)
  1271. return <span className={'red'}>{val} </span>
  1272. }
  1273. if(status == 1){
  1274. if(type == 2){
  1275. return <span style={{color:'#FF5D5D'}}>{val}<img src={up} alt=""/> </span>
  1276. }else if(type == 3){
  1277. return <span style={{color:"#D949FF"}}>{val}<img src={down} alt=""/> </span>
  1278. }
  1279. }else{
  1280. if(type == 2){
  1281. return <span>{val}<img src={up} alt=""/> </span>
  1282. }else if(type == 3){
  1283. return <span>{val}<img src={down} alt=""/> </span>
  1284. }
  1285. }
  1286. }
  1287. function getDomUpDown(min,max,value){
  1288. let dom = '';
  1289. if(min == null&&max == null||min == undefined&&max == undefined||min == ''&&max == ''){
  1290. dom = getStatusImg(0, value, 1)
  1291. }else if (!isNaN(min) && !isNaN(max) &&min!=null&&max!=null) {//有最大值最小值
  1292. if (isNaN(value)) {//输入的不是数据
  1293. dom = getStatusImg(1, value, 1)
  1294. } else if (value <= min) {//下降
  1295. dom = getStatusImg(3, value, 1)
  1296. } else if (value >= max) {//上升
  1297. dom = getStatusImg(2, value, 1)
  1298. } else {//正常
  1299. dom = getStatusImg(0, value, 1)
  1300. }
  1301. } else if (min==null && !isNaN(max)&&max!=null) {//有最大值无最小值
  1302. if (value >= max) {//上升
  1303. dom = getStatusImg(2, value, 1)
  1304. } else if(isNaN(value)){
  1305. dom = getStatusImg(1, value, 1)
  1306. }else {//正常
  1307. dom = getStatusImg(0, value, 1)
  1308. }
  1309. } else if (!isNaN(min) && max==null&&min!=null) {//有最小值无最大值
  1310. if (value <= min) {//下降
  1311. dom = getStatusImg(3, value, 1)
  1312. } else if(isNaN(value)){
  1313. dom = getStatusImg(1, value, 1)
  1314. }else {//正常
  1315. dom = getStatusImg(0, value, 1)
  1316. }
  1317. } else {//无最大最小值(中文))
  1318. dom = getStatusImg(1, value, 1)
  1319. }
  1320. return dom;
  1321. }
  1322. function getArrow(min,max,value){//1下降2上升3正常4标红
  1323. let dom = 3;
  1324. if(min == null&&max == null||min == undefined&&max == undefined||min == ''&&max == ''||value == null||value == undefined){
  1325. dom = 3
  1326. }else if (!isNaN(min) && !isNaN(max) &&min!=null&&max!=null) {//有最大值最小值
  1327. if (isNaN(value)) {//输入的不是数据
  1328. dom = 4
  1329. } else if (value <= min) {//下降
  1330. dom = 1
  1331. } else if (value >= max) {//上升
  1332. dom = 2
  1333. } else {//正常
  1334. dom = 3
  1335. }
  1336. } else if (min==null && !isNaN(max)&&max!=null) {//有最大值无最小值
  1337. if (value >= max) {//上升
  1338. dom = 2
  1339. } else if(isNaN(value)){
  1340. dom = 4
  1341. }else {//正常
  1342. dom = 3
  1343. }
  1344. } else if (!isNaN(min) && max==null&&min!=null) {//有最小值无最大值
  1345. if (value <= min) {//下降
  1346. dom = 1
  1347. } else if(isNaN(value)){
  1348. dom = 4
  1349. }else {//正常
  1350. dom = 3
  1351. }
  1352. } else {//无最大最小值(中文))
  1353. dom = 3
  1354. }
  1355. return dom;
  1356. }
  1357. //键值对转换
  1358. function parseNameVal(arr){
  1359. let obj = {};
  1360. Array.isArray(arr)&&arr.map((it)=>{
  1361. obj[it.code]=it.value;
  1362. });
  1363. return obj;
  1364. }
  1365. //化验数据处理
  1366. function getStringPlus(dataList){
  1367. let strPlus = '';
  1368. dataList && dataList.map((item)=>{
  1369. if(item.detailName){
  1370. let strTmp = item.name + ','+ item.detailName + ',' + (item.otherValue ? item.otherValue : (item.value + item.units)) +';'
  1371. // let strTmp = item.name + ','+(item.inpValue?(item.inpValue+','):'') + item.detailName + ',' + (item.otherValue ? item.otherValue : (item.value + item.units)) +';'
  1372. strPlus += strTmp;
  1373. }else{
  1374. // let strTmp = item.name+ (item.inpValue?(','+item.inpValue):';')
  1375. let strTmp = item.name+ ';'
  1376. strPlus += strTmp;
  1377. }
  1378. })
  1379. return strPlus;
  1380. }
  1381. /**
  1382. *
  1383. * @param {data1} excel导入的数据 getExcelDataList
  1384. * @param {data2} 填写单数据 labelList
  1385. */
  1386. function getPushList(data1,data2){ //推送数据
  1387. let tmpArr1 = [];
  1388. let tmpArr2 = [];
  1389. let totalTmpArr = [];
  1390. const now = dateParser(new Date());
  1391. data1.length>0 && data1.map((items)=>{ //excel导入的数据拼接
  1392. items.lisExcelRes.map((item)=>{
  1393. item.lisExcelItem.map((part)=>{
  1394. let tmpObj = {};
  1395. tmpObj.name = part.mealName || '';//套餐名
  1396. tmpObj.detailName = part.itemName || '';//化验项名
  1397. tmpObj.uniqueName = part.uniqueName || '';//公表名称
  1398. tmpObj.source = '1';//数据来源
  1399. tmpObj.maxValue = part.max || '';
  1400. tmpObj.minValue = part.min || '';
  1401. tmpObj.dateValue = part.time ||now;
  1402. tmpObj.units = part.unit || '';//单位
  1403. tmpObj.value = (part.value-0) === (part.value-0) ? part.value:'';//值
  1404. tmpObj.otherValue = (part.value-0) === (part.value-0) ?'':part.value; //阴性阳性
  1405. tmpArr1.push(tmpObj);
  1406. })
  1407. })
  1408. })
  1409. data2.length>0 && data2.map((item)=>{ //填写单数据拼接
  1410. item.details && item.details.map((val)=>{
  1411. if(val.value != undefined && val.value != ''){
  1412. let tmpObj = {};
  1413. tmpObj.name = item.name || '';
  1414. tmpObj.detailName = val.name || '';
  1415. tmpObj.uniqueName = val.uniqueName || '';//公表名称
  1416. tmpObj.source = '0'; //数据来源
  1417. tmpObj.maxValue = val.maxValue ? val.maxValue : '';
  1418. tmpObj.minValue = val.minValue ? val.minValue : '';
  1419. tmpObj.dateValue = val.time || now;
  1420. tmpObj.units = val.labelSuffix || '';
  1421. tmpObj.value = (val.value-0) === (val.value-0) ? val.value:'';
  1422. tmpObj.otherValue = (val.value-0) === (val.value-0) ?'':val.value;
  1423. tmpArr2.push(tmpObj);
  1424. }
  1425. })
  1426. })
  1427. totalTmpArr = tmpArr1.concat(tmpArr2);
  1428. return totalTmpArr;
  1429. }
  1430. function getPushLists(data1,data2){ //推送数据
  1431. let tmpArr1 = [];
  1432. let tmpArr2 = [];
  1433. let totalTmpArr = [];
  1434. data1.length>0 && data1.map((items)=>{ //excel导入的数据拼接
  1435. items.lisExcelRes.map((item)=>{
  1436. item.lisExcelItem.map((part)=>{
  1437. let tmpObj = {};
  1438. tmpObj.name = part.mealName || '';//套餐名
  1439. tmpObj.detailName = part.itemName || '';//化验项名
  1440. tmpObj.uniqueName = part.uniqueName || '';//公表名称
  1441. tmpObj.source = '1';//数据来源
  1442. tmpObj.maxValue = part.max || '';
  1443. tmpObj.minValue = part.min || '';
  1444. tmpObj.units = part.unit || '';//单位
  1445. tmpObj.value = (part.value-0) === (part.value-0) ? part.value:'';//值
  1446. tmpObj.otherValue = (part.value-0) === (part.value-0) ?'':part.value; //阴性阳性
  1447. tmpArr1.push(tmpObj);
  1448. })
  1449. })
  1450. })
  1451. data2.length>0 && data2.map((item)=>{ //填写单数据拼接
  1452. if(item.show){
  1453. item.details.map((val)=>{
  1454. if(val.value != undefined && val.value != ''){
  1455. let tmpObj = {};
  1456. tmpObj.name = item.name || '';
  1457. tmpObj.inpValue = item.inpValue || '';//套餐名
  1458. tmpObj.detailName = val.name || '';
  1459. tmpObj.uniqueName = val.uniqueName || '';//公表名称
  1460. tmpObj.source = '0'; //数据来源
  1461. tmpObj.maxValue = val.maxValue ? val.maxValue : '';
  1462. tmpObj.minValue = val.minValue ? val.minValue : '';
  1463. tmpObj.units = val.labelSuffix || '';
  1464. tmpObj.value = (val.value-0) === (val.value-0) ? val.value:'';
  1465. tmpObj.otherValue = (val.value-0) === (val.value-0) ?'':val.value;
  1466. tmpArr2.push(tmpObj);
  1467. }
  1468. })
  1469. }else{
  1470. let tmpObj = {};
  1471. tmpObj.name = item.name;
  1472. tmpObj.inpValue = item.inpValue;
  1473. tmpArr2.push(tmpObj);
  1474. }
  1475. })
  1476. totalTmpArr = tmpArr1.concat(tmpArr2);
  1477. return totalTmpArr;
  1478. }
  1479. function getAllString(checkedListImport,assistLabel,flg){
  1480. let tmpImportLis = [],tmpString='',tmpArr=[],tmpObj={};
  1481. for(let i = 0;i < checkedListImport.length;i++){
  1482. for(let j = 0;j < checkedListImport[i].length;j++){
  1483. tmpImportLis.push(checkedListImport[i][j])
  1484. }
  1485. }
  1486. let tempArr = tmpImportLis.concat(assistLabel)
  1487. for (let i = 0; i < tempArr.length; i++) {
  1488. let tmpVal = tempArr[i].value ? tempArr[i].value.trim() : tempArr[i].value;
  1489. let obj = {
  1490. "dateValue": tempArr[i].time||"",
  1491. "name": "",
  1492. "uniqueName": tempArr[i].name||"",
  1493. "desc": tempArr[i].value||"",
  1494. "result": tempArr[i].value||"",
  1495. }
  1496. tmpArr.push(obj)
  1497. tmpString += (tempArr[i].name + (tmpVal ? (':' + tmpVal) + ', ' : ':') + (tempArr[i].time ? '报告日期:' + tempArr[i].time : '') + '^;')
  1498. }
  1499. return tmpObj = {
  1500. arr:tmpArr,
  1501. str:tmpString
  1502. }
  1503. // if(flg){
  1504. // return tmpArr;
  1505. // }else{
  1506. // return tmpString;
  1507. // }
  1508. }
  1509. // 模板中处理tagType==4的数据
  1510. function resetTagtype(data){
  1511. let newDataArr = [];
  1512. if(data&&data.length>0){
  1513. for(let i=0; i<data.length;i++){
  1514. if(data[i].tagType==4){
  1515. newDataArr.push(...data[i].questionMapping);
  1516. }else{
  1517. newDataArr.push(data[i]);
  1518. }
  1519. }
  1520. }
  1521. return newDataArr;
  1522. }
  1523. //记录最近3次被删除的标签
  1524. function handleLocalDelTag(mark,index,tag){
  1525. const deledTag = localStorage.getItem('deletedTags')?JSON.parse(localStorage.getItem('deletedTags')):[];
  1526. if(tag.tagType){
  1527. deledTag.unshift(Object.assign({},tag,{delIndex:mark+'-'+index}));
  1528. }else{
  1529. deledTag.unshift({tags:tag,delIndex:mark+'-'+index});
  1530. }
  1531. deledTag.length = deledTag.length>config.recoverTagNum?config.recoverTagNum:deledTag.length;
  1532. localStorage.setItem('deletedTags',JSON.stringify(deledTag));
  1533. }
  1534. //删除被恢复的标签
  1535. function shiftLocalDelTag(){
  1536. const deledTags = localStorage.getItem('deletedTags')?JSON.parse(localStorage.getItem('deletedTags')):[];
  1537. deledTags.shift();
  1538. localStorage.setItem('deletedTags',JSON.stringify(deledTags));
  1539. }
  1540. //弹窗显示问题
  1541. function setPosition (e,dom,setHighter){
  1542. const isBlock = store.getState().typeConfig.typeConfig[0]===2; //自由模式
  1543. setTimeout(()=>{
  1544. const contHt =$(dom).height();
  1545. const $dom = isBlock?$("#EmrBlockContainer"):$("#EmrContainer");
  1546. const wrapHt = $dom.height();//滚动区域高度
  1547. const clickHt = getPageCoordinate(e).boxTop;//点击高度
  1548. const scrollHt = Math.abs(parseFloat($dom.parent('.scrollarea-content').css('margin-top'))) //滚动区滚动的距离
  1549. let btmHt = wrapHt-(clickHt-111)-scrollHt;//点击位置距离底部的距离
  1550. // console.log(wrapHt,clickHt,scrollHt,btmHt,contHt)
  1551. if(btmHt<contHt){
  1552. setHighter&&setHighter(contHt-btmHt+100);
  1553. }else{
  1554. setHighter&&setHighter(48); //标签填写单连续点击弹出,未超出需要恢复
  1555. }
  1556. // $(e.target)[0].scrollIntoView(true);
  1557. },10);
  1558. }
  1559. function moveEnd(obj,flg) {
  1560. if(window.getSelection){//ie11 10 9 ff safari
  1561. setTimeout(() => {
  1562. obj.focus(); //解决ff不获取焦点无法定位问题
  1563. var range = window.getSelection();//创建range
  1564. range.selectAllChildren(obj);//range 选择obj下所有子内容
  1565. if(flg){
  1566. range.collapseToStart();//光标移至开头
  1567. }else{
  1568. range.collapseToEnd();//光标移至最后
  1569. }
  1570. }, 0);
  1571. }
  1572. else if (document.selection) {//ie10 9 8 7 6 5
  1573. var range = document.selection.createRange();//创建选择对象
  1574. range.moveToElementText(obj);//range定位到obj
  1575. if(flg){
  1576. range.collapse(true);//光标移至开头
  1577. }else{
  1578. range.collapse(false);//光标移至最后
  1579. }
  1580. range.select();
  1581. }
  1582. }
  1583. /**
  1584. * 获取样式类名
  1585. * largeFontSize 18px middleFontSize 16px(暂无) simpleFontSize 14px
  1586. * flg 1标准字体时颜色加深,可以让选中的字体加粗
  1587. * 2体征颜色单独处理不需要设置
  1588. */
  1589. const setFontColorSize = (flg,pacs) => {
  1590. const classNameSelect = ['largeFontSize','middleFontSize','simpleFontSize','simpleLightColor','simpleColor','selectColor']
  1591. const state = store.getState();
  1592. let readConfig = state.typeConfig.readConfig
  1593. let mainType = readConfig==-1?state.typeConfig.typeConfig:readConfig;
  1594. let font = mainType[3],colour = mainType[4],classStr = '';
  1595. if(font == 1&&colour == 1){//字体加大颜色加深
  1596. if(flg == 2){
  1597. if(pacs == 1){
  1598. classStr = `largeFontSize pdright`
  1599. }else if(pacs == 2){
  1600. classStr = `largeFontSize widthChangeed`
  1601. }else if(pacs == 3){
  1602. classStr = `largeFontSize middleImg`
  1603. }else if(pacs == 4){
  1604. classStr = `largeFontSize titleWidth`
  1605. }else if(pacs == 5){
  1606. classStr = `largeFontSize specialSize`
  1607. }else if(pacs == 6){
  1608. classStr = `largeFontSize selectColor`
  1609. }else if(pacs == 7){
  1610. classStr = `largeFontSize fontWeight selectColor`
  1611. }else if(pacs == 8){
  1612. classStr = `largeFontSize selectColor`
  1613. }else{
  1614. classStr = `largeFontSize`
  1615. }
  1616. }else if(flg == 1){
  1617. classStr = `selectColor largeFontSize`
  1618. }else{
  1619. classStr = `selectColor largeFontSize`
  1620. }
  1621. }else if(font == 0&&colour == 1){//标准字体颜色加黑
  1622. if(flg == 2){
  1623. if(pacs == 6){
  1624. classStr = `simpleFontSize selectColor`
  1625. }else if(pacs == 7){
  1626. classStr = `simpleFontSize fontWeight selectColor`
  1627. }else if(pacs == 8){
  1628. classStr = `simpleFontSize selectColor`
  1629. }else{
  1630. classStr = `simpleFontSize`
  1631. }
  1632. }else if(flg == 1){
  1633. classStr = `selectColor simpleFontSize`
  1634. }else{
  1635. classStr = `selectColor simpleFontSize`
  1636. }
  1637. }else if(font == 1&&colour == 0){//大字体标准颜色
  1638. if(flg == 2){
  1639. if(pacs == 1){
  1640. classStr = `largeFontSize pdright`
  1641. }else if(pacs == 2){
  1642. classStr = `largeFontSize widthChangeed`
  1643. }else if(pacs == 3){
  1644. classStr = `largeFontSize middleImg`
  1645. }else if(pacs == 4){
  1646. classStr = `largeFontSize titleWidth`
  1647. }else if(pacs == 5){
  1648. classStr = `largeFontSize specialSize`
  1649. }else if(pacs == 6){
  1650. classStr = `largeFontSize`
  1651. }else if(pacs == 8){
  1652. classStr = `simpleColor largeFontSize`
  1653. }else if(pacs == 7){
  1654. classStr = `largeFontSize fontWeight`
  1655. }else{
  1656. classStr = `largeFontSize`
  1657. }
  1658. }else if(flg == 1){
  1659. classStr = `simpleLightColor largeFontSize`
  1660. }else{
  1661. classStr = `simpleColor largeFontSize`
  1662. }
  1663. }else{//都是标准的
  1664. if(flg == 2){
  1665. if(pacs == 7){
  1666. classStr = `simpleFontSize fontWeight`
  1667. }else if(pacs == 6){
  1668. classStr = `simpleFontSize`
  1669. }else if(pacs == 8){
  1670. classStr = `simpleColor simpleFontSize`
  1671. }else if(pacs == 7){
  1672. classStr = `simpleFontSize fontWeight`
  1673. }else{
  1674. classStr = `simpleFontSize`
  1675. }
  1676. }else if(flg == 1){
  1677. classStr = `simpleLightColor simpleFontSize`
  1678. }else{
  1679. classStr = `simpleColor simpleFontSize`
  1680. }
  1681. }
  1682. return classStr;
  1683. }
  1684. //获取生命体征或非生命体征标签
  1685. function getLifeLabels(arr,flag){ //flag=true获取非生命体征
  1686. const newArr = arr.filter((it)=>{
  1687. return flag?+it.specFlag!==4:+it.specFlag===4;
  1688. });
  1689. return newArr;
  1690. }
  1691. //获取已选中的标签
  1692. function getValuedLabels(arr){
  1693. const newArr = arr.filter((it)=>{
  1694. if(it.tagType=='3'){ //血压类型
  1695. if(+it.specFlag!==4&&it.questionMapping.findIndex((i)=>i.value!==undefined)!==-1){
  1696. return true;
  1697. }
  1698. return false;
  1699. }
  1700. return +it.specFlag!==4&&it.value;
  1701. });
  1702. return newArr;
  1703. }
  1704. //对象数组去重
  1705. function removeRepeat(arr1,arr2){ //arr1被完全保留的数组
  1706. const arr = arr2.reduce(function(newArr,item,inx){
  1707. const it = newArr.findIndex((i)=>i.id===item.id);
  1708. const firstInx = arr2.findIndex((i)=>i.id===item.id);
  1709. //旧体征标签比新体征标签多出的标签,已填值的保留,未填值的舍弃
  1710. if(it!==-1){
  1711. //多个相同标签,保留已填值的
  1712. if(firstInx!==inx&&(item.value!==undefined||(item.tagType=='3'&&item.questionMapping.findIndex((i)=>i.value!==undefined)!==-1))){ //重复的已填值标签
  1713. newArr.splice(inx-firstInx+it,0,item);
  1714. }
  1715. if(firstInx===inx){
  1716. newArr.splice(it,1,item);
  1717. }
  1718. }else if(item.value!==undefined||(it.tagType=='3'&&it.questionMapping.findIndex((i)=>i.value!==undefined)!==-1)){
  1719. newArr.push(item);
  1720. }
  1721. return newArr;
  1722. },[...arr1]);
  1723. return arr;
  1724. }
  1725. function handleMouseUp(param){
  1726. const {select_start,i,boxMark}= param;
  1727. if(select_start!==undefined){
  1728. store.dispatch({
  1729. type:SET_SELECTED_AREA,
  1730. data:{i,boxMark,dir:'end'}
  1731. });
  1732. //清空搜索结果以关闭搜索弹窗
  1733. const map = {
  1734. '1':CLEAR_SEARCH,
  1735. '2':CURRENT_CLEAR,
  1736. '3':OTHERHIS_CLEAR,
  1737. '4':CHECKBODY_CLEAR
  1738. };
  1739. store.dispatch({
  1740. type:map[boxMark]
  1741. });
  1742. window.getSelection().empty();
  1743. }
  1744. }
  1745. //判断不同科室内容是否相同
  1746. function checkDeptContent(jsonStr,tmpLis){
  1747. for(let i = 0;i <tmpLis.length;i++){
  1748. let dataStr = tmpLis[i].preview;
  1749. if(
  1750. filterDataArr(JSON.parse(jsonStr.chief)) == filterDataArr(eval('('+JSON.parse(dataStr).chief+')')) &&
  1751. filterDataArr(JSON.parse(jsonStr.present)) == filterDataArr(eval('('+JSON.parse(dataStr).present+')')) &&
  1752. filterDataArr(JSON.parse(jsonStr.other)) == filterDataArr(eval('('+JSON.parse(dataStr).other+')')) &&
  1753. filterDataArr(JSON.parse(jsonStr.vital)) == filterDataArr(eval('('+JSON.parse(dataStr).vital+')')) &&
  1754. jsonStr.lis == JSON.parse(dataStr).lis &&
  1755. jsonStr.pacs == JSON.parse(dataStr).pacs &&
  1756. jsonStr.diag == JSON.parse(dataStr).diag &&
  1757. jsonStr.advice == JSON.parse(dataStr).advice
  1758. ){
  1759. // Notify.info('该模板已保存');
  1760. return false;
  1761. }
  1762. }
  1763. }
  1764. module.exports = {
  1765. getIds,
  1766. getWindowInnerWidth,
  1767. getWindowInnerHeight,
  1768. getLabelIndex,
  1769. fullfillText,
  1770. checkFullfillText,
  1771. dateParser,
  1772. isNotNull,
  1773. isNull,
  1774. deepClone,
  1775. isIE,
  1776. storageLocal,
  1777. getUrlArgObject,
  1778. getAllDataList,
  1779. getAllDataStringList,
  1780. pushAllDataList,
  1781. filterArr,
  1782. filterDataArr,
  1783. filterOtherDataArr,
  1784. preventDefault,
  1785. handleEnter,
  1786. didPushParamChange,
  1787. getEMRParams,
  1788. getMRInfo,
  1789. windowEventHandler,
  1790. isAllClear,
  1791. normalVal,
  1792. getPageCoordinate,
  1793. windowRemoveEventHandler,
  1794. timestampToTime,
  1795. formatContinueDots,
  1796. inspectAndAssist,
  1797. getCurrentDate,
  1798. ifOtherClear,
  1799. readyKeepHistory,
  1800. parseChartData,
  1801. getCalendarDate,
  1802. downloadExportedData,
  1803. getStatusImg,
  1804. parseNameVal,
  1805. getStringPlus,
  1806. getPushLists,
  1807. getPushList,
  1808. getAllString,
  1809. resetTagtype,
  1810. handleLocalDelTag,
  1811. shiftLocalDelTag,
  1812. setPosition,
  1813. isAllPartClear,
  1814. getDomUpDown,
  1815. setFontColorSize,
  1816. moveEnd,
  1817. getLifeLabels,
  1818. getValuedLabels,
  1819. removeRepeat,
  1820. handleMouseUp,
  1821. checkDeptContent,
  1822. formatTextInfo,
  1823. getArrow,
  1824. };