tools.js 79 KB

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