new_recover.html 56 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>新建计划</title>
  6. <link rel="stylesheet" type="text/css" href="../../../css/bootstrap.min.css" />
  7. <link rel="stylesheet" type="text/css" href="../../../css/cross.css" />
  8. <link rel="stylesheet" type="text/css" href="../../../css/cross.ui.css" />
  9. <link rel="stylesheet" type="text/css" href="../../../css/style.min.css" />
  10. <link href="../../../plugins/toastr/toastr.min.css" rel="stylesheet">
  11. <link rel="stylesheet" type="text/css" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css" />
  12. <link rel="stylesheet" type="text/css" href="../css/new_recover.css" />
  13. <script src="../../../js/esModule.js" type="text/javascript"></script>
  14. </head>
  15. <body class="m0">
  16. <div id="app" v-cloak>
  17. <div class="c-position-a" style="top: -999px; left: -999px;" v-show="isTest"></div>
  18. <div class="c-h100 clearfix">
  19. <div class="fl c-h100 w400 person_info c-border-r" style="overflow: hidden;">
  20. <div v-if="!patiInfo" class="c-h100" style="overflow: auto;">
  21. <div class="c-border-b c-t-center pt20">
  22. <div class="set-photo imgw80">
  23. <img src="../../../images/p-female.png" alt="居民头像" />
  24. </div>
  25. <p class="ptb10">患者名</p>
  26. </div>
  27. <div>
  28. <div class="no-result c-t-center pt20">
  29. <img src="../images/wushuju01_img.png" alt="无数据" />
  30. <p class="c-999">暂无相关信息</p>
  31. <div class="pt30">
  32. <span class="c-fff btn cur-pit plr10 ptb5 bgc-12b7f5 b-r-3" @click="selectPatient()">同步信息</span>
  33. </div>
  34. </div>
  35. </div>
  36. </div>
  37. <div v-else class="c-h100 plr10" style="overflow: auto;">
  38. <div class="c-t-center pt20 c-position-r">
  39. <div class="set-photo imgw80">
  40. <img :src="setPatImg(patiInfo.photo)" alt="居民头像" />
  41. </div>
  42. <h3 class="ptb10 m0 c-f16">{{patiInfo.name}}</h3>
  43. <span class="c-position-a set-qiehuan cur-pit" @click="selectPatient()"></span>
  44. </div>
  45. <h4 class="h30 m0 c-f14 c-border-b f-w500">基本信息</h4>
  46. <ul class="c-333 m0 p0 pb20">
  47. <li class="pt10"><span class="c-999">性&emsp;&emsp;别:</span>{{patiInfo.sex == 1 ? "男" : "女"}}</li>
  48. <li class="pt10"><span class="c-999">年&emsp;&emsp;龄:</span>{{patiInfo.age}}岁</li>
  49. <li class="pt10"><span class="c-999">身份证号:</span>{{patiInfo.idcard}}</li>
  50. <li class="pt10"><span class="c-999">地&emsp;&emsp;址:</span>{{patiInfo.address}}</li>
  51. </ul>
  52. <h4 class="h30 m0 c-f14 c-border-b f-w500">家庭医生</h4>
  53. <ul class="c-333 m0 p0 pb20">
  54. <li class="pt10"><span class="c-999">签约社区:</span>{{patiInfo.ssHospitalName || patiInfo.jtHospitalName}}</li>
  55. <li class="pt10"><span class="c-999">全科医生:</span>{{patiInfo.ssDoctorName || patiInfo.jtDoctorName}}</li>
  56. <li class="pt10"><span class="c-999">健&ensp;管&ensp;师:</span>{{patiInfo.ssDoctorHealthName || patiInfo.jtDoctorHealthName}}</li>
  57. </ul>
  58. <!-- <h4 class="h30 m0 c-f14 c-border-b">诊疗信息</h4> -->
  59. <!-- <ul class="c-333 m0 p0 pb20" >
  60. <div class="input-group mtb10" >
  61. <label style="transform: translateY(50%); color: #999999;font-weight: normal;">就诊事件:</label>
  62. <div class="input-group-btn" style="width: 80%; transform: translateY(50%);top: -5px;">
  63. <button style="width:223px;padding: 0; text-overflow: ellipsis; overflow: hidden;" v-bind:disabled="edit" type="button" class="btn btn-white dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  64. {{diagnosisInfo[indexOrder].orgName}}
  65. <span class="caret" style="position: absolute; top: 50%; right: 20px; margin-top: -2px;"></span>
  66. </button>
  67. <ul class="dropdown-menu" style="min-width: 206px;" >
  68. <li class="c-f14 c-border-b" style="text-align: center; padding: 2px;cursor:pointer;" v-for="(v, i) in diagnosisInfo" @click="orderHospital(i)" v-html="v.orgName"></li>
  69. </ul>
  70. </div>
  71. </div>
  72. <li class="pt10" style="display: flex;" id="department">
  73. <label class="c-999" style="font-weight: normal;">入院科室:</label>
  74. <input class="form-control" v-bind:disabled="edit" v-bind:value="nodata == true? '请输入': subsidiaryInfo.data.department" style=" text-align: center; height: 22px; border-radius: 3px; width: 80%;">
  75. </li>
  76. <li class="pt10" style="display: flex;" id="attendingDoctor">
  77. <label class="c-999" style="font-weight: normal;">主治医师:</label>
  78. <input class="form-control" v-bind:disabled="edit" v-bind:value="nodata == true? '请输入': subsidiaryInfo.data.attendingDoctor" style="text-align: center; height: 22px; border-radius: 3px; width: 80%;">
  79. </li>
  80. <li class="pt10" style="display: flex;" id="admissionDiagnosis">
  81. <label class="c-999" style="font-weight: normal;">入院诊断:</label>
  82. <input class="form-control" v-bind:disabled="edit" v-bind:value="nodata == true? '请输入': subsidiaryInfo.data.admissionDiagnosis" style="text-align: center; height: 22px; border-radius: 3px; width: 80%;">
  83. </li>
  84. <li class="pt10" style="display: flex;" id="dischargeDiagnosis">
  85. <label class="c-999" style="font-weight: normal;">出院诊断:</label>
  86. <input class="form-control" v-bind:disabled="edit" v-bind:value="nodata == true? '请输入': subsidiaryInfo.data.dischargeDiagnosis" style="text-align: center; height: 22px; border-radius: 3px; width: 80%;">
  87. </li>
  88. </ul> -->
  89. <!-- <h4 class="h30 m0 c-f14 c-border-b c-999">医嘱小结</h4> -->
  90. <!-- <textarea v-bind:disabled="edit" class="tipText m0 pt10 c-333 mt10" style="height: 200px; width: 100%; border:1px solid #e1e1e1; resize:none;text-indent:28px" v-html="subsidiaryInfo.data.dischargeOrder"></textarea> -->
  91. <!-- <button type="button" class="btn btn-default fr" style="width: 60px; background: #12B7F5; border-radius: 0px ;border: 0px ;" @click="editdiagnosis()" v-html="edit == true? '编辑':'保存'"></button> -->
  92. <h4 class="h30 m0 c-f14 c-border-b f-w500" style="overflow: hidden;">
  93. 康复建议
  94. <span class="click-text" @click="editAdviceTextarea">
  95. {{isEdit == true? '编辑':'保存'}}
  96. </span>
  97. </h4>
  98. <textarea v-bind:disabled="isEdit" v-model="adviceContent" class="m0 p10 c-333 mt10" :class="{'bg-f5f5fa':isEdit, 'bd-red':showAdviceContentTip}" style="width: 100%;height: 200px; width: 100%; border:1px solid #e1e1e1; resize:none;" placeholder="请输入您的康复建议..."></textarea>
  99. <h4 class="h30 m0 c-f14 c-border-b f-w500" style="overflow: hidden;">
  100. 住院病历
  101. </h4>
  102. <div v-if="medicalRecordsList.length>0" v-for="(o, i) in medicalRecordsList" class="mt10">
  103. <div class="flex vc c-f14 c-border plr10 ptb5 link-control" style="cursor: pointer;" @click="editMedicalRecords(o, i)" :class="{'bd-12b7f5': curMedicalRecordsIndex==i}">
  104. <span class="c-666 mr15">
  105. {{formatter(o.admissionTime)}}
  106. </span>
  107. <div class="flex1 c-12b7f5 ellipsis-1">
  108. {{o.hospitalName}}
  109. </div>
  110. </div>
  111. </div>
  112. <button type="button" class="btn btn-default fr" style="width: 100%; background: #12B7F5; border-radius: 0px ;border: 0px ;padding: 10px;margin-top: 15px;" @click="addMedicalRecords()">添加住院病历</button>
  113. </div>
  114. </div>
  115. <div class="fl c-h100 w-100-400">
  116. <div class="c-h100 plr5" v-if="!isPlan">
  117. <h4 class="m0 pl15 lh40 c-border-b f-w500 c-position-r"><span class="c-position-a set-blue-span"></span>配置康复计划</h4>
  118. <div style="overflow: hidden; height: calc(100% - 41px);">
  119. <div style="overflow: auto; height: 100%;">
  120. <div class="un-select c-t-center pt45" v-if="!patiInfo">
  121. <img src="../images/wushuju_img.png" alt="" />
  122. <p class="c-999">您还没有选择居民</p>
  123. </div>
  124. <ul class="muban_con lh40 c-t-center pt30" v-else>
  125. <li class="mb20" v-for="(muban, index) in mubanList" :key="index" @click="addMuban(muban.id)">{{muban.title}}</li>
  126. <li class="addmuban-btn c-fff" @click="addMuban()">新增模板</li>
  127. </ul>
  128. </div>
  129. </div>
  130. </div>
  131. <div class="clearfix c-h100" v-else>
  132. <div class="fl w-100-400 c-h100">
  133. <div class="plr5 c-h100-79">
  134. <h4 class="m0 pl15 lh40 c-border-b set-label f-w500 c-position-r">
  135. <em class="c-position-a set-blue-span"></em>
  136. 配置康复计划
  137. <!-- <span v-for="(label, index) in spanLabel" :key="index" class="fr ml20 pl20 c-f14 c-999 cur-pit" :class="{'active': index == labelIndex}" @click="setLabelIndex(index, label)">{{label.labelName}}</span> -->
  138. </h4>
  139. <div class="c-h100-41" style="overflow: hidden;">
  140. <ul class="c-h100 p0 m0" style="overflow: auto;">
  141. <li class="mt10 plr10 ptb5 c-border b-r-3 clearfix" v-for="(detail, index) in templateDetail" :key="index">
  142. <div v-if="detail.name=='康复咨询'||detail.name=='远程健康监测'">
  143. <div class="fl w-100-78 c-333">
  144. <p :class='detail.isTimeSame ? "m0 p0 mb10 txt-ells cur-pit c-red" : "m0 p0 mb10 txt-ells cur-pit"' @click="lookProject(detail)">{{detail.name}}</p>
  145. <div class="clearfix">
  146. <p class="w400 m0 mb10 p0 fl"><span class="c-999">医&emsp;&emsp;院:</span>{{docInfo.hospitalName}}</p>
  147. <p class="m0 p0 mb10 fl"><span class="c-999">费&emsp;&emsp;用:</span>0.00</p>
  148. </div>
  149. <div class="m0 p0 clearfix">
  150. <div class="w400 m0 mb10 p0 fl clearfix">
  151. <span class="fl c-999">选择频次:</span>
  152. <div class="fl c-position-r w100">
  153. 不限频次
  154. </div>
  155. </div>
  156. </div>
  157. <div class="clearfix">
  158. <span class="fl c-999">备&emsp;&emsp;注:</span>
  159. <div class="fl maxw600 plr15 ptb10 c-border set-textarea">
  160. <textarea placeholder="不补充说明特殊用法、方式" v-model="detail.remark" name="" rows="" cols=""></textarea>
  161. </div>
  162. </div>
  163. </div>
  164. <div class='fr w60 c-t-right clearfix'>
  165. <div class="clearfix mb10"><span class="fr sub-tap cur-pit" @click="subTemplate(index, detail)"></span></div>
  166. </div>
  167. </div>
  168. <div v-else>
  169. <div class="fl w-100-78 c-333">
  170. <p :class='detail.isTimeSame ? "m0 p0 mb10 txt-ells cur-pit c-red" : "m0 p0 mb10 txt-ells cur-pit"' @click="lookProject(detail)">{{detail.name}}</p>
  171. <div class="clearfix">
  172. <p class="w400 m0 mb10 p0 fl"><span class="c-999">医&emsp;&emsp;院:</span>{{detail.executeHospitalName}}</p>
  173. <p class="m0 p0 mb10 fl"><span class="c-999">费&emsp;&emsp;用:</span>0.00</p>
  174. </div>
  175. <div class="m0 p0 clearfix">
  176. <div class="w400 m0 mb10 p0 fl clearfix">
  177. <span class="fl c-999">选择频次:</span>
  178. <div class="fl c-position-r w100">
  179. <p class="m0 p0 plr10 c-border cur-pit set-xia" :class="{'set-shang':detail.selectFre}" @click="changeSelectFre(index, detail.selectFre)">{{detail.frequencyCode}}</p>
  180. <ul class="m0 p0 c-border-b c-border-l c-border-r c-position-a doc_list" v-if="detail.selectFre" style="overflow-y: auto; height: 100px;">
  181. <li class="plr10 c-border-t cur-pit" v-for="(list, indDoc) in detail.frequencyList" :key="indDoc" @click="selectFre(index, list)">{{list.code}}</li>
  182. </ul>
  183. </div>
  184. </div>
  185. <div class="m0 mb10 p0 fl clearfix">
  186. <span class="fl c-999">执行人员:</span>
  187. <div class="fl c-position-r w100">
  188. <p class="m0 p0 plr10 c-border cur-pit set-xia" :class="{'set-shang':detail.selectDoc}" @click="changeSelectDoc(index, detail.selectDoc)">{{detail.executeDoctorName}}</p>
  189. <ul class="m0 p0 c-border-b c-border-l c-border-r c-position-a doc_list" v-if="detail.selectDoc" style="overflow-y: auto; max-height: 100px;">
  190. <li class="plr10 c-border-t cur-pit" v-for="(list, indDoc) in detail.docList" :key="indDoc" @click="selectLi(index, list)">{{list.name}}</li>
  191. </ul>
  192. </div>
  193. </div>
  194. </div>
  195. <div class="pl65 mb10 set-label" v-if="detail.frequency.unit == 'H'">
  196. <span :class="detail.timeType == 1 ? 'pl20 mr5 cur-pit active' : 'pl20 mr5 cur-pit'" @click="selectTimeType(index, 1)">白天</span>
  197. <span :class="detail.timeType == 2 ? 'pl20 mr5 cur-pit active' : 'pl20 mr5 cur-pit'" @click="selectTimeType(index, 2)">晚上</span>
  198. <span :class="detail.timeType == 0 ? 'pl20 cur-pit active' : 'pl20 cur-pit'" @click="selectTimeType(index, 0)">全天</span>
  199. </div>
  200. <div>
  201. <div class="clearfix">
  202. <span class="fl c-999 lh24">起始时间:</span>
  203. <div class="fl maxw600 mb10">
  204. <el-date-picker v-model="detail.value14[0]" type="date" placeholder="开始日期" value-format="yyyy-MM-dd" :picker-options="pickerOptions1" @input="getRandgeDate(index, 0)">
  205. </el-date-picker>
  206. <span>—</span>
  207. <el-date-picker v-model="detail.value14[1]" type="date" placeholder="结束日期" value-format="yyyy-MM-dd" :picker-options="pickerOptions1" @input="getRandgeDate(index, 1)">
  208. </el-date-picker>
  209. </div>
  210. </el-date-picker>
  211. <span class="fl lh24 mlr10 c-999">或</span>
  212. <div class="fl maxw600 mb10">
  213. <el-date-picker type="dates" :picker-options="pickerOptions1" v-model="detail.value15" value-format="yyyy-MM-dd" @input="getSelectDate(index)" placeholder="选择一个或者多个日期"></el-date-picker>
  214. </div>
  215. </div>
  216. </div>
  217. <div class="clearfix">
  218. <span class="fl c-999">备&emsp;&emsp;注:</span>
  219. <div class="fl maxw600 plr15 ptb10 c-border set-textarea">
  220. <textarea placeholder="不补充说明特殊用法、方式" v-model="detail.remark" name="" rows="" cols=""></textarea>
  221. </div>
  222. </div>
  223. </div>
  224. <div class='fr w60 c-t-right clearfix'>
  225. <p class="m0 p0 mb10">×{{mul(detail.executeTime.length, detail.frequency.count)}}</p>
  226. <div class="clearfix mb10"><span class="fr sub-tap cur-pit" @click="subTemplate(index, detail)"></span></div>
  227. <div class="clearfix"><span class="fr fuzhi-tap cur-pit" @click="copyTemplate(index, detail)"></span></div>
  228. </div>
  229. </div>
  230. </li>
  231. <li class="pt100 c-t-center" v-if="!templateDetail.length">
  232. <span class="set-right-arraw pr20">请在右侧“服务项”列表中选择</span>
  233. </li>
  234. </ul>
  235. </div>
  236. </div>
  237. <div>
  238. <p class="m0 p0 pl20 ptb10 c-border-b set-label">支付方式:<span class="ml10 pl20 active">按服务支付</span><em class="c-red ml20">(按选择支付方式完成收费)</em></p>
  239. <div class="pl20 lh40">总费用:
  240. <span class="c-red c-f16">¥{{allFee}}</span>
  241. <span class="fr lh30 cur-pit plr15 c-t-center c-fff" :class="havePlan ? 'bgc-12b7f5' : 'bgc-d7dce6'" @click="createRehabilitationPlan()">生成计划</span>
  242. <span class="fr lh30 cur-pit plr15 c-t-center bgc-green c-fff" @click="canclePlan()">取消</span>
  243. </div>
  244. </div>
  245. </div>
  246. <div class="fr w400 c-h100 c-border-l">
  247. <div class="plr5 c-h100">
  248. <h4 class="m0 pl15 lh40 c-border-b c-position-r f-w500">
  249. <em class="c-position-a set-blue-span"></em>添加其他项目
  250. </h4>
  251. <div class="clearfix mtb10 c-border">
  252. <input class="fl search-input plr10" type="text" v-model="searchKey" placeholder="输入项目名称" />
  253. <span class="fr search-btn" @click="searchProject()"></span>
  254. </div>
  255. <div class="c-h100-99" style="overflow: hidden;">
  256. <div class="c-h100 p0 m0" style="overflow: auto;">
  257. <ul class="p0 m0 pr10">
  258. <li v-for="(o, i) in serviceItems" :key="i" class="clearfix ptb5">
  259. <!-- @click="selectProject(i, o)" -->
  260. <div class="fl c-border w-100-66 cur-pit border-c12b7f5 ptb5 plr5 b-r-3 clearfix" :class="o.isSelect ? 'bgc-12b7f5' : 'bgc-fff'">
  261. <p class="fl w-100-78 txt-ells lh18" :class="o.isSelect ? 'c-fff' : 'c-666'">{{o.name}}</p>
  262. </div>
  263. <span class="fr h30 btn cur-pit plr10 bgc-12b7f5 c-fff b-r-3" style="padding: 0 10px;" v-if="!o.isSelect" @click="addProject(i, o)">添加</span>
  264. <span class="fr h30 btn plr10 bgc-e1e1e1 c-fff b-r-3" style="padding: 0 10px;" v-else>添加</span>
  265. </li>
  266. </ul>
  267. </div>
  268. </div>
  269. <!-- <div class="c-h100-99" style="overflow: hidden;">
  270. <ul class="c-h100 p0 m0" style="overflow: auto;">
  271. <li v-for="(project1, index) in projectList" :key="index">
  272. <h4 class="set-arrow c-f14 h30 p0 m0 pl20 f-w500 cur-pit" :class="{'active': index == proIndex1}" @click="selectPro(1, index)">{{project1.itemType == 1 ? '诊疗服务' : '健康服务'}}</h4>
  273. <ul class="c-h100 p0 m0 pl10" v-if="index == proIndex1">
  274. <li v-for="(project2, index2) in project1.item" :key="index2">
  275. <p class="set-arrow h30 c-f14 pl20 m0 c-333 cur-pit" :class="{'active': index2 == proIndex2}" @click="selectPro(2, index2)">{{project2.itemName}}</p>
  276. <ul class="p0 m0 pr10" v-if="index2 == proIndex2">
  277. <li v-for="(project3, index3) in project2.hospitalServiceItems" :key="index3" class="clearfix ptb5">
  278. <div class="fl c-border w-100-66 cur-pit border-c12b7f5 ptb5 plr5 b-r-3 clearfix" :class="project3.isSelect ? 'bgc-12b7f5' : 'bgc-fff'" @click="selectProject(index, index2, index3, project3)">
  279. <p class="fl w-100-78 txt-ells lh18" :class="project3.isSelect ? 'c-fff' : 'c-666'">{{project3.specialistServiceItemDO.title}}</p>
  280. <span class="fr lh18 b-r-3 c-f12 ml5 bgc-4dcd70 plr5 c-fff" v-if="project3.flag == 1 || project3.flag == 3">社区</span>
  281. <span class="fr lh18 b-r-3 c-f12 ml5 bgc-55cefc plr5 c-fff" v-if="project3.flag == 2 || project3.flag == 3">医院</span>
  282. </div>
  283. <span class="fr h30 btn cur-pit plr10 bgc-12b7f5 c-fff b-r-3" style="padding: 0 10px;" v-if="!project3.isSelect" @click="addProject(index, index2, index3, project3)">添加</span>
  284. <span class="fr h30 btn plr10 bgc-e1e1e1 c-fff b-r-3" style="padding: 0 10px;" v-else>添加</span>
  285. </li>
  286. </ul>
  287. </li>
  288. </ul>
  289. </li>
  290. </ul>
  291. </div> -->
  292. </div>
  293. </div>
  294. </div>
  295. </div>
  296. </div>
  297. </div>
  298. <script src="../../../js/vue.js" type="text/javascript" charset="utf-8"></script>
  299. <script src="../../../js/jquery-2.2.4.js"></script>
  300. <script src="../../../plugins/layer/layer.min.js"></script>
  301. <script src="../../../plugins/toastr/toastr.min.js"></script>
  302. <script src="../../../js/bootstrap.min.js"></script>
  303. <script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
  304. <script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
  305. <script src="../../../js/util.js" type="text/javascript" charset="utf-8"></script>
  306. <script src="https://unpkg.com/element-ui/lib/index.js" type="text/javascript" charset="utf-8"></script>
  307. <script src="../../../api/http-request.js" type="text/javascript"></script>
  308. <script src="../../../api/recover_api.js" type="text/javascript"></script>
  309. <script type="text/javascript" src="../../../api/rehabilitation-api.js"></script>
  310. <script type="text/javascript">
  311. var doctorType = (JSON.parse(window.localStorage.getItem('docInfo'))||{}).level,
  312. docInfo = JSON.parse(window.localStorage.getItem('docInfo'))
  313. console.log('docInfodocInfodocInfodocInfo', docInfo)
  314. var httpData=GetRequest()
  315. function showSuccessMessage(msg) {
  316. layer.msg(msg, {
  317. icon: 1
  318. })
  319. }
  320. function showErrorMessage(msg) {
  321. layer.msg(msg, {
  322. icon: 5
  323. })
  324. }
  325. function showWarningMessage(msg) {
  326. layer.msg(msg, {
  327. icon: 2
  328. })
  329. }
  330. function showInfoMessage(msg) {
  331. layer.msg(msg, {
  332. icon: 6
  333. })
  334. }
  335. top.recoverVue = new Vue({
  336. el: "#app",
  337. data: {
  338. pickerOptions1: {
  339. disabledDate: function(time) {
  340. return time.getTime() < Date.now() - 8.64e7;
  341. }
  342. },
  343. surefont: '添加',
  344. isTest: false,
  345. pati: null,
  346. teamCode: null,
  347. isPlan: false,
  348. proIndex1: null,
  349. proIndex2: null,
  350. patiInfo: null,
  351. diseaseObj: null, // 疾病
  352. mubanList: [],
  353. templateDetail: [],
  354. templateResult: [],
  355. allFee: 0,
  356. projectList: null,
  357. serviceItems: null, // 服务项列表
  358. labelIndex: 2,
  359. labelCode: 1,
  360. spanLabel: [{
  361. labelName: "(转)家庭病床",
  362. code: 3
  363. }, {
  364. labelName: "(转)社区医院",
  365. code: 2
  366. }, {
  367. labelName: "康复计划",
  368. code: 1
  369. }],
  370. jDlist: [], //家签医生
  371. zDlist: [], //专科医生
  372. selectProjectDetail: null,
  373. searchKey: null,
  374. havePlan: false,
  375. frequencyList: [],
  376. diagnosisInfo:"",
  377. indexOrder:0,
  378. profileRes:[],
  379. nodata:false,
  380. subsidiaryInfo:{},
  381. edit:true,
  382. selectDiseaseIndex:'',
  383. isPlanId :'',
  384. selectPatientIndex: '',
  385. adviceContent: '', //康复建议
  386. isEdit: false,
  387. medicalRecordsList: [],
  388. docInfo: JSON.parse(window.localStorage.getItem('docInfo')),
  389. showAdviceContentTip: false,
  390. curMedicalRecordsIndex: -1,
  391. diseaseCodeArr: [],
  392. diseaseNameArr: []
  393. },
  394. watch: {
  395. adviceContent: function(){
  396. var vm = this
  397. if(vm.adviceContent.trim().length>0){
  398. vm.showAdviceContentTip = false
  399. } else {
  400. vm.showAdviceContentTip = true
  401. }
  402. },
  403. templateDetail: function(){
  404. if(this.templateDetail.length==0){
  405. this.havePlan = false
  406. }
  407. }
  408. },
  409. mounted: function() {
  410. this.selectFrequencys()
  411. if(httpData.patient) {
  412. this.isPlan = false
  413. this.allFee = 0
  414. this.templateDetail = []
  415. this.pati = {patient: httpData.patient}
  416. this.getPatientInfo()
  417. // this.diagnosisQuery()
  418. }
  419. if(httpData.teamCode){
  420. this.teamCode = httpData.teamCode
  421. this.findTemplateList()
  422. }
  423. },
  424. methods: {
  425. // 添加住院病历
  426. addMedicalRecords: function(){
  427. var vm = this
  428. this.selectPatientIndex = layer.open({
  429. type: 2,
  430. area: ['480px', '520px'],
  431. shade: 0.5,
  432. title: '添加住院病历',
  433. closeBtn: 1,
  434. shift: 5,
  435. shadeClose: false, //点击遮罩关闭层
  436. content: "medical-records.html?patient="+vm.pati.patient+'&patientName='+vm.pati.patientName
  437. });
  438. },
  439. // 编辑住院病历
  440. editMedicalRecords: function(o, i){
  441. var vm = this
  442. vm.curMedicalRecordsIndex = i
  443. window.localStorage.setItem('curMedicalRecords', JSON.stringify(o))
  444. this.selectPatientIndex = layer.open({
  445. type: 2,
  446. area: ['480px', '520px'],
  447. shade: 0.5,
  448. title: '添加住院病历',
  449. closeBtn: 1,
  450. shift: 5,
  451. shadeClose: false, //点击遮罩关闭层
  452. content: "medical-records.html?patient="+vm.pati.patient+'&patientName='+vm.pati.patientName+'&medicalRecordsId='+o.id
  453. });
  454. },
  455. //关闭添加住院病历弹框
  456. closeMedicalRecords: function(){
  457. layer.close(this.selectPatientIndex)
  458. },
  459. completeMedicalRecords: function(type, data){
  460. if(type=='edit'){
  461. this.$set(this.medicalRecordsList, this.curMedicalRecordsIndex, data)
  462. } else {
  463. this.medicalRecordsList.unshift(data)
  464. }
  465. layer.close(this.selectPatientIndex)
  466. },
  467. //获取诊疗信息
  468. diagnosisQuery:function(){
  469. var vm = this;
  470. loadding = layer.load(0, {shade: false});
  471. params = {
  472. patient: this.pati.patient,
  473. // patient:"3b26a7905e034c36a5ba8e65bdc0dc7f",
  474. type: '2',
  475. page: 1,
  476. pageSize: 50,
  477. lastTime: ''
  478. }
  479. recoverAPI.diagnosisQuery(params).then(function(res){
  480. layer.close(loadding)
  481. if (res.status == 200) {
  482. if(res.data.length == 0){
  483. vm.diagnosisInfo = [{orgName:'无'}]
  484. console.log(vm.diagnosisInfo)
  485. vm.nodata = true
  486. }else{
  487. vm.diagnosisInfo = res.data;
  488. }
  489. vm.orderHospital(0)
  490. }else{
  491. vm.diagnosisInfo = [{orgName:'无'}]
  492. vm.orderHospital(0)
  493. showErrorMessage(res.msg);
  494. }
  495. })
  496. },
  497. //按照医院查询诊疗信息
  498. orderHospital:function(index){
  499. var vm = this;
  500. vm.indexOrder = index
  501. loadding = layer.load(0, {shade: false});
  502. var sec_params = {
  503. patient: vm.pati.patient,
  504. event:vm.diagnosisInfo[index].id || "",
  505. // patient:"3b26a7905e034c36a5ba8e65bdc0dc7f",
  506. // event:"26eec2df-caa9-4b7e-9993-0ad7ae8d0a15",
  507. catalog:'0213',
  508. serial:"1"
  509. }
  510. recoverAPI.diagnosisSubsidiary(sec_params).then(function(res){
  511. layer.close(loadding)
  512. vm.subsidiaryInfo = vm.selectXmlDom(res,'0213')
  513. console.log(vm.subsidiaryInfo)
  514. })
  515. },
  516. //获取xml数据
  517. selectXmlDom: function (profileRes,tempalteCode) {
  518. var vm = this;
  519. if(profileRes.status == 200){
  520. var $dom = $(profileRes.data.replace(/<\?xml .*\?>/,'')),
  521. version = $dom.find(">version").length?$dom.find(">version").attr("code"):$dom.attr('version');
  522. $.trim(version) || (function () {
  523. version = $dom.find(">ClinicalDocument").length? '2.0.0.1' : '';
  524. })();
  525. if($.trim(version)) {
  526. var verNum = version.split('.')[0];
  527. var jsonData = {}
  528. // xml 转 json
  529. if((typeof profileRes.data=='string')&&profileRes.data.constructor==String) {
  530. // 去除携带的脚本内容
  531. profileRes.data = profileRes.data.replace(/<script[^>]*?>[\s\S]*?<\/script>/ig,'');
  532. // console.log(profileRes.data.replace(/<\?xml .*\?>/,''))
  533. jsonData = vm.handleData(profileRes.data.replace(/<\?xml .*\?>/,''));
  534. }
  535. }
  536. }else{
  537. showErrorMessage(profileRes.msg)
  538. jsonData = {data:{}}
  539. }
  540. return jsonData;
  541. },
  542. handleData :function (xmlStr) {
  543. var $xmlDom = $(xmlStr),
  544. $nodes = {
  545. } ;
  546. var resultData = [];
  547. return {
  548. data:{
  549. "department": $xmlDom.find('component section entry inDept').text(),//科室
  550. "dednumber": $xmlDom.find('component section entry bed').text(),//床号
  551. "HospitalizationNumber": "",//住院号
  552. "name": $xmlDom.find('recordTarget patient name').text(),//姓名
  553. "sex": $xmlDom.find('recordTarget patient sex').text(),//性别
  554. "nation": $xmlDom.find('recordTarget nation').text(),//民族
  555. "marriage": $xmlDom.find('recordTarget marriage').text(),//婚姻
  556. "admissionTime": $xmlDom.find('component section entry inTime').attr('value'),//入院时间
  557. "dischargeTime": $xmlDom.find('component section entry outTime').attr('value'),//出院时间
  558. "lengthStay": $xmlDom.find('component section entry inHospitalDay').text(),//住院天数
  559. "admissionStatus": $xmlDom.find('component section entry inCondition').text(),//入院情况
  560. "admissionDiagnosis": $xmlDom.find('component section entry inDiagnosis').text(),//入院诊断
  561. "dischargeDiagnosis": $xmlDom.find('component section entry outDiagnosis').text(),//出院诊断
  562. "DiagnosisProcess": $xmlDom.find('component section entry remedialCourse').text(),//诊疗经过
  563. "dischargeStatus": $xmlDom.find('component section entry outCondition').text(),//出院情况
  564. "dischargeOrder": $xmlDom.find('component section entry outOrder').text(),//出院医嘱
  565. "treatmentOutcome": $xmlDom.find('component section entry remedialResult').text(),//治疗结果
  566. "residentPhysician": $xmlDom.find('residentDoctor name').text(),//住院医师
  567. "attendingDoctor": $xmlDom.find('inChargeDoctor name').text(),//主治医师
  568. "time": $xmlDom.find('inChargeDoctor time').attr('value')//时间
  569. }
  570. }
  571. },
  572. //编辑诊疗
  573. editdiagnosis:function(){
  574. var vm = this;
  575. vm.edit = !vm.edit;
  576. vm.nodata = false
  577. vm.subsidiaryInfo.data.department = $('#department').find('input').val()
  578. vm.subsidiaryInfo.data.attendingDoctor = $('#attendingDoctor').find('input').val()
  579. vm.subsidiaryInfo.data.admissionDiagnosis = $('#department').find('input').val()
  580. vm.subsidiaryInfo.data.dischargeDiagnosis = $('#dischargeDiagnosis').find('input').val()
  581. },
  582. // 获取居民标签(健康情况、疾病类型、自定义分组)
  583. getPatientLabelInfo: function(){
  584. var vm = this,
  585. loading = layer.load(0, {shade: false})
  586. var params = {
  587. patient: this.pati.patient
  588. }
  589. rehaAPI.getPatientLabelInfo(params).then(function(res){
  590. layer.close(loading)
  591. if(res.status == 200) {
  592. var healthLabel = res.data['healthLabel']||[],
  593. diseaseLabel = res.data['diseaseServer']||[],
  594. customLabel = res.data['customLabel']||[];
  595. $.each(diseaseLabel, function(index, item){
  596. vm.diseaseCodeArr.push(item.disease)
  597. vm.diseaseNameArr.push(item.diseaseName)
  598. })
  599. } else {
  600. showErrorMessage(res.msg);
  601. }
  602. })
  603. },
  604. // 编辑康复建议
  605. editAdviceTextarea: function(){
  606. this.isEdit = !this.isEdit
  607. },
  608. // 获取频次列表
  609. selectFrequencys: function() {
  610. var vm = this,
  611. loadding = layer.load(0, {shade: false});
  612. recoverAPI.selectFrequencys().then(function(res) {
  613. layer.close(loadding)
  614. if(res.status == 200) {
  615. vm.frequencyList = res.data
  616. } else {
  617. showErrorMessage(res.msg);
  618. }
  619. })
  620. },
  621. // 获取居民信息
  622. getPatientInfo: function() {
  623. // this.findPatientSignSpecialistInfo()
  624. var vm = this,
  625. loadding = layer.load(0, {shade: false}),
  626. params = {
  627. patient: this.pati.patient
  628. }
  629. recoverAPI.getPatientInfo(params).then(function(res) {
  630. layer.close(loadding)
  631. if(res.status == 200) {
  632. vm.patiInfo = res.data
  633. vm.pati.patientName = res.data.name
  634. vm.jDlist.push({
  635. name: docInfo.name,
  636. code: docInfo.code,
  637. hospitalName: docInfo.hospitalName
  638. })
  639. vm.jDlist.push({
  640. name: vm.patiInfo.ssDoctorName || vm.patiInfo.jtDoctorName,
  641. code: vm.patiInfo.ssDoctor || vm.patiInfo.jtDoctor,
  642. hospitalName: vm.patiInfo.jtHospitalName
  643. })
  644. vm.jDlist.push({
  645. name: vm.patiInfo.ssDoctorHealthName || vm.patiInfo.jtDoctorHealthName,
  646. code: vm.patiInfo.ssDoctorHealth || vm.patiInfo.jtDoctorHealth,
  647. hospitalName: vm.patiInfo.jtHospitalName
  648. })
  649. // 获取居民标签
  650. vm.getPatientLabelInfo()
  651. if(!vm.teamCode){
  652. vm.findPatientSignSpecialistInfo()
  653. }
  654. } else {
  655. showErrorMessage(res.msg);
  656. }
  657. })
  658. },
  659. // 签约专科信息
  660. findPatientSignSpecialistInfo: function() {
  661. var vm = this,
  662. params = {
  663. patient: this.pati.patient,
  664. doctor: docInfo.code
  665. }
  666. recoverAPI.findPatientSignSpecialistInfo(params).then(function(res) {
  667. if(res.status == 200) {
  668. vm.pati.teamCode = res.data.teamCode
  669. vm.teamCode = res.data.teamCode
  670. vm.specialistTeam(res.data.teamCode)
  671. } else {
  672. showErrorMessage(res.msg);
  673. }
  674. })
  675. },
  676. // 获取专科团队
  677. specialistTeam: function(teamCode) {
  678. var vm = this,
  679. params = {
  680. teamId: teamCode
  681. }
  682. recoverAPI.specialistTeam(params).then(function(res) {
  683. if(res.status == 200) {
  684. vm.zDlist = res.data.members
  685. } else {
  686. showErrorMessage(res.msg);
  687. }
  688. })
  689. },
  690. // 模板列表
  691. findTemplateList: function() {
  692. var vm = this,
  693. loadding = layer.load(0, {shade: false}),
  694. params = {
  695. patient: this.pati.patient,
  696. doctor: docInfo.code,
  697. adminTeamCode: vm.teamCode
  698. }
  699. recoverAPI.findTemplateList(params).then(function(res) {
  700. layer.close(loadding)
  701. if(res.status == 200) {
  702. vm.mubanList = res.data
  703. } else {
  704. showErrorMessage(res.msg);
  705. }
  706. })
  707. },
  708. // 模板详细
  709. findTemplateDetail: function(templateId) {
  710. var vm = this,
  711. loadding = layer.load(0, {shade: false}),
  712. params = {
  713. templateId: templateId
  714. }
  715. recoverAPI.findTemplateDetail(params).then(function(res) {
  716. layer.close(loadding)
  717. if(res.status == 200) {
  718. vm.templateDetail = []
  719. vm.templateResult = res.data
  720. vm.getServiceItemList().then(function(){
  721. $.each(vm.serviceItems, function(index,o) {
  722. $.each(vm.templateResult, function(index1, o1) {
  723. if(o1.code == o.code) {
  724. o.isSelect = true
  725. o1.isSelect = true
  726. o1.selectDoc = false
  727. o1.selectDate = 1
  728. o1.value14 = []
  729. o1.value15 = null
  730. o1.executeTime = []
  731. o1.selectDateRange = []
  732. // 默认频次
  733. o1.selectFre = false
  734. o1.frequencyCode = vm.frequencyList[0].code
  735. o1.frequency = vm.frequencyList[0]
  736. o1.frequencyList = vm.frequencyList
  737. o1.timeType = 0
  738. o1.remark = null
  739. o1.executeDoctor = vm.jDlist[0].code
  740. o1.executeDoctorName = vm.jDlist[0].name
  741. o1.executeHospitalName = vm.jDlist[0].hospitalName
  742. o1.docList = vm.jDlist
  743. vm.templateDetail.push(o1)
  744. }
  745. })
  746. return o
  747. })
  748. })
  749. // vm.findServiceItemsByHospital()
  750. } else {
  751. showErrorMessage(res.msg);
  752. }
  753. })
  754. },
  755. // 服务项目列表 2020-03-03 新增接口
  756. getServiceItemList: function(isSearch){
  757. var vm = this,
  758. loadding = layer.load(0, {shade: false}),
  759. params = {
  760. name: vm.searchKey
  761. }
  762. return rehaAPI.getServiceItemList(params).then(function(res) {
  763. layer.close(loadding)
  764. if(res.status == 200) {
  765. var serviceItems = res.data
  766. vm.serviceItems = $.each(serviceItems, function(index,o) {
  767. o.isSelect = false
  768. return o;
  769. })
  770. }else {
  771. showErrorMessage(res.msg);
  772. }
  773. })
  774. },
  775. // 服务项目列表
  776. // findServiceItemsByHospital: function() {
  777. // var vm = this,
  778. // loadding = layer.load(0, {shade: false}),
  779. // params = {
  780. // doctor: docInfo.code,
  781. // patient: this.pati.patient,
  782. // serviceItemName: this.searchKey
  783. // }
  784. // recoverAPI.findServiceItemsByHospital(params).then(function(res) {
  785. // layer.close(loadding)
  786. // if(res.status == 200) {
  787. // vm.projectList = $.each(res.data[0], function(index, o) {
  788. // $.each(vm.templateResult, function(index1, o1) {
  789. // if(o1.specialistServiceItemDO.itemType == o.itemType) {
  790. // $.each(o.item, function(index2, o2) {
  791. // if(o1.specialistServiceItemDO.diseaseItem == o2.itemName) {
  792. // $.each(o2.hospitalServiceItems, function(index3, o3) {
  793. // if(o3.serviceItemId == o1.serviceItemId) {
  794. // o3.isSelect = true
  795. // o3.selectDoc = false
  796. // o3.selectDate = 1
  797. // o3.value14 = []
  798. // o3.value15 = null
  799. // o3.specialistServiceItemDO.executeTime = []
  800. // o3.specialistServiceItemDO.selectDateRange = []
  801. // // 默认频次
  802. // o3.selectFre = false
  803. // o3.frequencyCode = vm.frequencyList[0].code
  804. // o3.frequency = vm.frequencyList[0]
  805. // o3.frequencyList = vm.frequencyList
  806. // o3.timeType = 0
  807. // o3.remark = null
  808. // // 标识 (1 社区 2 医院 3 社区、医院)
  809. // if(o3.flag == 2) {
  810. // o3.executeDoctor = vm.zDlist[0].code
  811. // o3.executeDoctorName = vm.zDlist[0].name
  812. // o3.docList = vm.zDlist
  813. // } else {
  814. // o3.executeDoctor = vm.jDlist[0].code
  815. // o3.executeDoctorName = vm.jDlist[0].name
  816. // o3.docList = vm.jDlist
  817. // }
  818. // vm.templateDetail.push(o3)
  819. // }
  820. // });
  821. // }
  822. // });
  823. // }
  824. // });
  825. // return o;
  826. // });
  827. // } else {
  828. // showErrorMessage(res.msg);
  829. // }
  830. // })
  831. // },
  832. searchProject: function() {
  833. this.getServiceItemList(true)
  834. },
  835. setPatImg: function(src) {
  836. if(!src) {
  837. return "../../../images/p-female.png"
  838. } else {
  839. var str = httpRequest.getImgUrl(src);
  840. return str
  841. }
  842. },
  843. changeSelectFre: function(index, bool) {
  844. this.templateDetail[index].selectFre = !bool
  845. this.isTest = !this.isTest
  846. },
  847. changeSelectDoc: function(index, bool) {
  848. this.templateDetail[index].selectDoc = !bool
  849. this.isTest = !this.isTest
  850. },
  851. // 选择频次
  852. selectFre: function(index, list) {
  853. this.templateDetail[index].selectFre = false
  854. this.templateDetail[index].frequencyCode = list.code
  855. this.templateDetail[index].frequency = list
  856. this.templateDetail[index] = this.templateDetail[index]
  857. this.isTest = !this.isTest
  858. },
  859. // 选择时间段
  860. selectTimeType: function(index, timetype) {
  861. this.templateDetail[index].timeType = timetype
  862. this.isTest = !this.isTest
  863. },
  864. // 选择执行医生
  865. selectLi: function(index, list) {
  866. this.templateDetail[index].selectDoc = false
  867. this.templateDetail[index].executeDoctor = list.code
  868. this.templateDetail[index].executeDoctorName = list.name
  869. this.templateDetail[index].executeHospitalName = list.hospitalName
  870. this.templateDetail[index] = this.templateDetail[index]
  871. this.isTest = !this.isTest
  872. },
  873. // 删除配置计划
  874. subTemplate: function(index, detail) {
  875. var vm = this
  876. this.isTest = !this.isTest
  877. this.templateDetail.splice(index, 1)
  878. var len = detail.executeTime.length
  879. var deleteJudge = true
  880. $.each(vm.templateDetail, function(index, o) {
  881. if(o.code == detail.code) {
  882. deleteJudge = false
  883. }
  884. });
  885. if(deleteJudge) {
  886. $.each(vm.serviceItems, function(index, o) {
  887. if(detail.code == o.code) {
  888. o.isSelect = false
  889. o.executeTime = []
  890. vm.serviceItems[index] = o
  891. }
  892. });
  893. }
  894. this.judgeHavePlan()
  895. },
  896. // 复制计划
  897. copyTemplate: function(index, detail) {
  898. var vm = this,
  899. obj = JSON.parse(JSON.stringify(detail));
  900. this.isTest = !this.isTest
  901. obj.executeTime = []
  902. obj.value14 = []
  903. obj.value15 = null
  904. this.templateDetail.push(obj)
  905. if(obj.code!='2'&&obj.code!='3'){
  906. this.havePlan = false
  907. }
  908. },
  909. // 选择项目
  910. selectProject: function(index, index2, index3, o) {
  911. this.selectProjectDetail = o
  912. this.selectPatientIndex = layer.open({
  913. type: 2,
  914. area: ['400px', '500px'],
  915. shade: 0.5,
  916. title: '选择项目',
  917. closeBtn: 1,
  918. shift: 5,
  919. shadeClose: false, //点击遮罩关闭层
  920. content: "select-project.html?isLook=true&projectId=" + o.id + "&index=" + index + "&index3=" + index3 + "&index2=" + index2
  921. });
  922. },
  923. // 添加项目
  924. addProject: function(index, obj) {
  925. if(obj) {
  926. this.selectProjectDetail = obj
  927. }
  928. if(this.selectProjectDetail.isSelect) {
  929. showWarningMessage("已添加!")
  930. return false;
  931. }
  932. this.selectProjectDetail.isSelect = true
  933. this.selectProjectDetail.selectDoc = false
  934. this.selectProjectDetail.selectDate = 1
  935. this.selectProjectDetail.value14 = []
  936. this.selectProjectDetail.value15 = null
  937. this.selectProjectDetail.executeTime = []
  938. this.selectProjectDetail.selectDateRange = []
  939. // 频次选择
  940. this.selectProjectDetail.selectFre = false
  941. this.selectProjectDetail.frequencyCode = this.frequencyList[0].code
  942. this.selectProjectDetail.frequency = this.frequencyList[0]
  943. this.selectProjectDetail.frequencyList = this.frequencyList
  944. this.selectProjectDetail.timeType = 0
  945. this.selectProjectDetail.remark = null
  946. this.selectProjectDetail.executeDoctor = this.jDlist[0].code
  947. this.selectProjectDetail.executeDoctorName = this.jDlist[0].name
  948. this.selectProjectDetail.executeHospitalName = this.jDlist[0].hospitalName
  949. this.selectProjectDetail.docList = this.jDlist
  950. this.templateDetail.push(this.selectProjectDetail)
  951. this.serviceItems[index] = this.selectProjectDetail
  952. if(this.selectProjectDetail.code!='2'&&this.selectProjectDetail.code!='3'){
  953. this.havePlan = false
  954. }
  955. },
  956. // 查看项目
  957. lookProject: function(o) {
  958. this.selectPatientIndex = layer.open({
  959. type: 2,
  960. area: ['400px', '500px'],
  961. shade: 0.5,
  962. title: '查看项目',
  963. closeBtn: 1,
  964. shift: 5,
  965. shadeClose: false, //点击遮罩关闭层
  966. content: "select-project.html?projectId=" + o.id
  967. });
  968. },
  969. // 选择居民
  970. selectPatient: function() {
  971. this.selectPatientIndex = layer.open({
  972. type: 2,
  973. area: ['400px', '500px'],
  974. shade: 0.5,
  975. title: '同步患者',
  976. closeBtn: 1,
  977. shift: 5,
  978. shadeClose: false, //点击遮罩关闭层
  979. content: "select-patient.html"
  980. });
  981. },
  982. // 选择居民回调
  983. selectPatientOk: function(pati) {
  984. this.isPlan = false
  985. this.allFee = 0
  986. this.templateDetail = []
  987. this.pati = pati
  988. this.isEdit = false
  989. this.showAdviceContentTip = false
  990. this.medicalRecordsList = []
  991. this.getPatientInfo()
  992. this.findTemplateList()
  993. // this.diagnosisQuery()
  994. layer.close(this.selectPatientIndex)
  995. },
  996. // 添加模板
  997. addMuban: function(oId) {
  998. var vm = this
  999. var templateId = oId||''
  1000. vm.newPlan(templateId)
  1001. },
  1002. // 取消计划
  1003. canclePlan: function(obj) {
  1004. var vm = this
  1005. cancleIndex = layer.open({
  1006. type: 2,
  1007. area: ['400px', '180px'],
  1008. shade: 0.5,
  1009. title: '取消确认',
  1010. closeBtn: 1,
  1011. shift: 5,
  1012. shadeClose: false, //点击遮罩关闭层
  1013. content: "cancle_sure.html"
  1014. });
  1015. },
  1016. cancleSure: function() {
  1017. this.isPlan = false
  1018. this.allFee = 0
  1019. this.templateDetail = []
  1020. },
  1021. // (disease, templateId)
  1022. newPlan: function(templateId) {
  1023. // this.diseaseObj = disease
  1024. // var templateId = this.templateId
  1025. this.isPlan = true
  1026. if(templateId) {
  1027. this.findTemplateDetail(templateId)
  1028. } else {
  1029. this.templateDetail = []
  1030. this.getServiceItemList()
  1031. // this.findServiceItemsByHospital()
  1032. }
  1033. },
  1034. selectPro: function(pro, index) {
  1035. if(pro == 1) {
  1036. this.proIndex2 = null;
  1037. this.proIndex1 == index ? this.proIndex1 = null : this.proIndex1 = index
  1038. } else {
  1039. this.proIndex2 == index ? this.proIndex2 = null : this.proIndex2 = index
  1040. }
  1041. },
  1042. setLabelIndex: function(index, label) {
  1043. this.labelIndex = index
  1044. this.labelCode = label.code
  1045. },
  1046. changeSelectDate: function(index, num) {
  1047. if(this.templateDetail[index].executeTime.length) {
  1048. showWarningMessage("请先清除此选项的计划时间!");
  1049. return false;
  1050. }
  1051. this.isTest = !this.isTest
  1052. this.templateDetail[index].selectDate = num
  1053. },
  1054. openSelectTime: function(index) {
  1055. var vm = this
  1056. selectTimeIndex = layer.open({
  1057. type: 2,
  1058. area: ['600px', '500px'],
  1059. shade: 0.5,
  1060. title: '服务时间选择',
  1061. closeBtn: 1,
  1062. shift: 5,
  1063. shadeClose: false, //点击遮罩关闭层
  1064. content: "select_timer.html"
  1065. });
  1066. },
  1067. formatter: function(time){
  1068. return new Date(time).format('yyyy-MM-dd')
  1069. },
  1070. // 选择日期
  1071. getSelectDate: function(index) {
  1072. var vm = this,
  1073. projectId = vm.templateDetail[index].code;
  1074. if(!this.templateDetail[index].value15) {
  1075. return false;
  1076. }
  1077. vm.templateDetail = $.map(vm.templateDetail, function(o, index) {
  1078. if(projectId == o.code) {
  1079. o.isTimeSame = false
  1080. }
  1081. return o
  1082. })
  1083. this.templateDetail[index].executeTime = []
  1084. var arr = this.templateDetail[index].value15
  1085. this.templateDetail[index].executeTime = arr
  1086. this.templateDetail[index].value14 = []
  1087. this.isTest = !this.isTest
  1088. this.judgeHavePlan()
  1089. },
  1090. // 选择周期
  1091. getRandgeDate: function(index, i) {
  1092. var vm = this
  1093. var templateDetail=this.templateDetail[index]
  1094. if(!templateDetail.value14[i]){
  1095. this.templateDetail[index].executeTime = []
  1096. this.havePlan = false
  1097. return false
  1098. }
  1099. if(templateDetail.value14[0]>templateDetail.value14[1]){
  1100. showWarningMessage("开始时间应小于结束时间!")
  1101. return false;
  1102. }
  1103. var projectId = vm.templateDetail[index].code;
  1104. vm.templateDetail = $.map(vm.templateDetail, function(o, index) {
  1105. if(projectId == o.code) {
  1106. o.isTimeSame = false
  1107. }
  1108. return o
  1109. })
  1110. this.templateDetail[index].executeTime = []
  1111. var arr = this.templateDetail[index].value14,
  1112. startTime = new Date(arr[0]).getTime(),
  1113. endTime = new Date(arr[1]).getTime(),
  1114. absTime = endTime - startTime,
  1115. oneday = 60 * 60 *24 * 1000,
  1116. i = 0;
  1117. for(i; i * oneday <= absTime; i++) {
  1118. var num = i * oneday + startTime,
  1119. str = new Date(num).format("yyyy-MM-dd")
  1120. this.templateDetail[index].executeTime.push(str)
  1121. }
  1122. var obj = {
  1123. startTime: arr[0],
  1124. endTime: arr[1],
  1125. length: i
  1126. }
  1127. this.templateDetail[index].selectDateRange.push(obj)
  1128. this.templateDetail[index].value15 = null
  1129. this.isTest = !this.isTest
  1130. this.judgeHavePlan()
  1131. },
  1132. // 计算总费用
  1133. checkAllMoney: function() {
  1134. var vm = this
  1135. this.allFee = 0
  1136. $.each(vm.templateDetail, function(index, o) {
  1137. var fee = vm.mul(vm.mul(o.expense, o.frequency.count), o.executeTime.length)
  1138. vm.allFee = vm.add(vm.allFee, fee)
  1139. });
  1140. },
  1141. judgeHavePlan: function() {
  1142. var arr = []
  1143. for(var k = 0; k < this.templateDetail.length; k++) {
  1144. if(this.templateDetail[k].code!='2'&&this.templateDetail[k].code!='3'){
  1145. if(this.templateDetail[k].executeTime[0]) {
  1146. arr.push(true)
  1147. }else {
  1148. arr.push(false)
  1149. }
  1150. }
  1151. }
  1152. var flag = _.every(arr, Boolean)
  1153. if(flag){
  1154. this.havePlan = true
  1155. }else{
  1156. this.havePlan = false
  1157. }
  1158. },
  1159. createRehabilitationPlan: function() {
  1160. var vm = this
  1161. if(!this.adviceContent){
  1162. vm.showAdviceContentTip = true
  1163. showWarningMessage("请输入康复建议!")
  1164. return false;
  1165. }
  1166. if(vm.medicalRecordsList.length==0){
  1167. showWarningMessage("请选择住院病历!")
  1168. return false;
  1169. }
  1170. if(!this.havePlan) {
  1171. showWarningMessage("请选择计划时间!")
  1172. return false;
  1173. }
  1174. var codeArr=[];
  1175. $.each(vm.medicalRecordsList,function(i, o){
  1176. codeArr.push(o.code)
  1177. })
  1178. var loadding = layer.load(0, {shade: false}),
  1179. data = {
  1180. patient: this.pati.patient,
  1181. name: this.pati.patientName,
  1182. title: this.pati.patientName + "的康复计划",
  1183. disease: this.diseaseCodeArr.join(','),
  1184. diseaseName: this.diseaseNameArr.join(','),
  1185. planType: this.labelCode || 1,
  1186. payment: 2,
  1187. totalExpense: this.allFee || 0,
  1188. adviceContent: this.adviceContent,
  1189. medicalRecordsCode: codeArr.join(','),
  1190. teamCode: vm.teamCode,
  1191. detail: [],
  1192. };
  1193. $.each(vm.templateDetail, function(index, o) {
  1194. if(o.code=='2'||o.code=='3'){
  1195. var obj = {
  1196. hospitalServiceItemId: o.code,
  1197. type: 2,
  1198. doctor: '',
  1199. doctorName: '',
  1200. executeTimes: '',
  1201. frequencyCode: '',
  1202. timeType: 0,
  1203. remark: o.remark || ''
  1204. }
  1205. data.detail.push(obj)
  1206. }else{
  1207. if(o.executeTime.length) {
  1208. var executeTime = []
  1209. $.each(o.executeTime, function(ind, v) {
  1210. v += ' 00:00'
  1211. executeTime.push(v)
  1212. });
  1213. var obj = {
  1214. hospitalServiceItemId: o.code,
  1215. type: 2,
  1216. doctor: o.executeDoctor,
  1217. doctorName: o.executeDoctorName,
  1218. executeTimes: executeTime.join(","),
  1219. frequencyCode: o.frequencyCode,
  1220. timeType: o.timeType,
  1221. remark: o.remark || ''
  1222. }
  1223. data.detail.push(obj)
  1224. }
  1225. }
  1226. });
  1227. var params = {
  1228. json: JSON.stringify(data)
  1229. }
  1230. // console.log('paramsparamsparamsparamsparams', data)
  1231. // return
  1232. recoverAPI.createRehabilitationPlan(params).then(function(res) {
  1233. layer.close(loadding)
  1234. if(res.status == 200) {
  1235. vm.isPlanId = res.data
  1236. // if(vm.isPlanId){
  1237. // var thr_parems ={
  1238. // patient:vm.pati.patient,
  1239. // patientName:vm.pati.patientName,
  1240. // planId:vm.isPlanId,
  1241. // hospitalName:$('.input-group-btn button').text().trim(),
  1242. // department:$('#department').find('input').val(),//vm.subsidiaryInfo.data.department|| ""
  1243. // attendingDoctorName:$('#attendingDoctor').find('input').val(),//vm.subsidiaryInfo.data.attendingDoctor ||""
  1244. // admittingDiagnosis:$('#admissionDiagnosis').find('input').val(),//vm.subsidiaryInfo.data.admissionDiagnosis || ""
  1245. // dischargeDiagnosis:$('#dischargeDiagnosis').find('input').val(),//vm.subsidiaryInfo.data.dischargeDiagnosis|| ""
  1246. // advice:$('.tipText').val().trim(),//vm.subsidiaryInfo.data.dischargeOrder ||""
  1247. // dischargeTime:vm.subsidiaryInfo.data.dischargeTime || ""
  1248. // }
  1249. // loadding = layer.load(0, {shade: false});
  1250. // recoverAPI.preservationInfo(thr_parems).then(function(res){
  1251. // layer.close(loadding)
  1252. // if (res.status == 200) {
  1253. // setTimeout(function() {
  1254. // window.location.href = "../../rehabilitation/html/health_control.html"
  1255. // }, 1000)
  1256. // showSuccessMessage('保存成功')
  1257. // }else{
  1258. // showErrorMessage(res.msg);
  1259. // }
  1260. // })
  1261. // }
  1262. setTimeout(function() {
  1263. window.location.href = "../../rehabilitation/html/health_control.html"
  1264. }, 1000)
  1265. showSuccessMessage("康复计划配置成功!")
  1266. } else {
  1267. showErrorMessage(res.msg || "同康复计划项目创建时间重复!");
  1268. vm.templateDetail = $.map(vm.templateDetail, function(o, index) {
  1269. $.each(res.data, function(ind, v) {
  1270. if(v == o.id) {
  1271. o.isTimeSame = true
  1272. }
  1273. });
  1274. return o
  1275. })
  1276. }
  1277. })
  1278. },
  1279. // 字符串方法计算加减乘除(精确度百分位)
  1280. add: function(num1,num2){
  1281. var r1,r2,m,n;
  1282. try{r1=num1.toString().split(".")[1].length}catch(e){r1=0}
  1283. try{r2=num2.toString().split(".")[1].length}catch(e){r2=0}
  1284. m = Math.pow(10,Math.max(r1,r2));
  1285. n = (r1>=r2)?r1:r2;
  1286. return ((num1*m + num2*m)/m).toFixed(n);
  1287. },
  1288. sub: function(num1,num2){
  1289. var r1,r2,m,n;
  1290. try{r1=num1.toString().split(".")[1].length}catch(e){r1=0}
  1291. try{r2=num2.toString().split(".")[1].length}catch(e){r2=0}
  1292. n = (r1>=r2)?r1:r2;
  1293. m = Math.pow(10,Math.max(r1,r2));
  1294. return ((num1*m - num2*m)/m).toFixed(n);
  1295. },
  1296. mul: function(num1,num2){
  1297. var m = 0;
  1298. try{m+=num1.toString().split(".")[1].length}catch(e){}
  1299. try{m+=num2.toString().split(".")[1].length}catch(e){}
  1300. return (Number(num1.toString().replace(".",""))*Number(num2.toString().replace(".","")))/Math.pow(10,m)
  1301. },
  1302. div: function(arg1,arg2){
  1303. var t1=0,t2=0,r1,r2;
  1304. try{t1=arg1.toString().split(".")[1].length}catch(e){}
  1305. try{t2=arg2.toString().split(".")[1].length}catch(e){}
  1306. r1=Number(arg1.toString().replace(".",""));
  1307. r2=Number(arg2.toString().replace(".",""));
  1308. return (r1/r2)*Math.pow(10,t2-t1);
  1309. }
  1310. }
  1311. })
  1312. </script>
  1313. </body>
  1314. </html>