Elizabeth's proactive approach involves introducing urinal toilet attachment , an ingenious concept that optimizes space and functionality.

printOne.vue 8.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. <template>
  2. <div id='prescription-print'>
  3. <div class="prescription-print">
  4. <div class="printTitle">{{orgname}} &nbsp;&nbsp; 门诊病历</div>
  5. <div class="infoTitle">
  6. <div>姓名:{{patient.name?patient.name:''}}</div>
  7. <div>性别:
  8. <span v-if="patient.gender == 1">男</span>
  9. <span v-if="patient.gender == 2">女</span>
  10. </div>
  11. <div>年龄:{{patient.age?patient.age:''}}岁</div>
  12. </div>
  13. <div class="infoTitle">
  14. <div>婚姻状况:
  15. <span v-if="patient.marital_status == 1">未婚</span>
  16. <span v-if="patient.marital_status == 2">已婚</span>
  17. <span v-if="patient.marital_status == 3">离异</span>
  18. </div>
  19. <div>职业:{{getProfession(patient.profession)?getProfession(patient.profession):''}}</div>
  20. </div>
  21. <div class="otherInfo">
  22. <div>医保号:</div>
  23. <div style="flex:1;">{{patient.health_care_no?patient.health_care_no:''}}</div>
  24. </div>
  25. <div class="otherInfo">
  26. <div>联系电话:</div>
  27. <div style="flex:1;">{{patient.phone?patient.phone:''}}</div>
  28. </div>
  29. <div class="otherInfo">
  30. <div>通讯地址:</div>
  31. <div style="flex:1;">{{patient.home_address?patient.home_address:''}}</div>
  32. </div>
  33. <div class="otherInfo">
  34. <div>药物过敏史:</div>
  35. <div style="flex:1;">{{patient.past_history?patient.past_history:''}}</div>
  36. </div>
  37. <div class="otherInfo">
  38. <div>病历编号:</div>
  39. <div style="flex:1;">{{patient.id?patient.id:''}}</div>
  40. </div>
  41. <div style="page-break-after:always;margin-top:50px;"></div>
  42. </div>
  43. <div class="prescription-print">
  44. <div class="printTitle">病历内容</div>
  45. <div class="recordTitle">
  46. <div>科别:{{getDeparment(hispatient.departments)?getDeparment(hispatient.departments):''}}</div>
  47. <div>姓名:{{patient.name?patient.name:''}}</div>
  48. <div>性别:
  49. <span v-if="patient.gender == 1">男</span>
  50. <span v-if="patient.gender == 2">女</span>
  51. </div>
  52. <div>年龄:{{patient.age?patient.age:''}}岁</div>
  53. </div>
  54. <div class="otherInfo">
  55. <div class="otherName">主诉:</div>
  56. <div style="flex:1;">{{history.chief_conplaint?history.chief_conplaint:''}}</div>
  57. </div>
  58. <div class="otherInfo">
  59. <div class="otherName">现病史:</div>
  60. <div style="flex:1;">{{history.history_of_present_illness?history.history_of_present_illness:''}}</div>
  61. </div>
  62. <div class="otherInfo">
  63. <div class="otherName">既往史:</div>
  64. <div style="flex:1;">{{history.past_history?history.past_history:''}}</div>
  65. </div>
  66. <div class="otherInfo">
  67. <div class="otherName">药物过敏史:</div>
  68. <div style="flex:1;">{{history.allergic_history?history.allergic_history:''}}</div>
  69. </div>
  70. <div class="otherInfo">
  71. <div class="otherName">个人史:</div>
  72. <div style="flex:1;">{{history.personal_history?history.personal_history:''}}</div>
  73. </div>
  74. <div class="otherInfo">
  75. <div class="otherName">家族史:</div>
  76. <div style="flex:1;">{{history.family_history?history.family_history:''}}</div>
  77. </div>
  78. <div class="otherInfo">
  79. <div class="otherName">体格检查:</div>
  80. <div style="flex:1;">无</div>
  81. </div>
  82. <div class="otherInfo">
  83. <div class="otherName">门诊诊断:</div>
  84. <div style="flex:1;">{{history.diagnostic?history.diagnostic:''}}</div>
  85. </div>
  86. <div class="otherInfo">
  87. <div class="otherName">门诊医嘱:</div>
  88. <div style="flex:1;">{{history.doctor_advice?history.doctor_advice:''}}</div>
  89. </div>
  90. <div style="display:flex;justify-content: space-between;">
  91. <div style="margin-top:20px;">
  92. 打印日期:{{ printDate }}
  93. </div>
  94. <div style="margin-top:20px;text-align:right;">
  95. 医生签名:{{getDoctor(history.doctor)?getDoctor(history.doctor):''}}
  96. </div>
  97. </div>
  98. </div>
  99. </div>
  100. </template>
  101. <script>
  102. import { getDataConfig } from "@/utils/data";
  103. import { getAllDoctorList,getPatientCaseHistory } from "@/api/project/project"
  104. export default {
  105. props:{
  106. patient:Object,
  107. hispatient:Object,
  108. patientid:Number
  109. // history:Object,
  110. },
  111. data(){
  112. return{
  113. educationOptions:[],
  114. departmentList:[],
  115. orgname:'',
  116. history:{},
  117. printDate:''
  118. }
  119. },
  120. methods:{
  121. getProfession(id){
  122. var name = "";
  123. for(let i=0;i<this.educationOptions.length;i++){
  124. if(id == this.educationOptions[i].id){
  125. name = this.educationOptions[i].name
  126. }
  127. }
  128. return name
  129. },
  130. getAllDoctorList(){
  131. getAllDoctorList().then(response=>{
  132. if(response.data.state == 1){
  133. var doctor = response.data.data.doctor;
  134. this.doctorList = doctor;
  135. var department = response.data.data.department;
  136. console.log("department",department);
  137. this.departmentList = department
  138. }
  139. })
  140. },
  141. getDoctor(id){
  142. var name = "";
  143. for(let i=0;i<this.doctorList.length;i++){
  144. if(id == this.doctorList[i].admin_user_id){
  145. name = this.doctorList[i].user_name
  146. }
  147. }
  148. return name
  149. },
  150. getPatientCaseHistory(){
  151. const params = {
  152. patient_id:this.patientid
  153. };
  154. console.log("病历22222",params);
  155. getPatientCaseHistory(params).then(response=>{
  156. if(response.data.state == 1){
  157. var patient = response.data.data.patient;
  158. // console.log("patinet",patient)
  159. this.patient = patient;
  160. var history = response.data.data.history;
  161. console.log("中国history222222",history);
  162. this.history = history;
  163. var hispatient = response.data.data.hispatient;
  164. // console.log("hispatient",hispatient)
  165. this.hispatient = hispatient
  166. }
  167. })
  168. },
  169. getDeparment(id){
  170. var name = '';
  171. for(let i=0;i<this.departmentList.length;i++){
  172. if(id == this.departmentList[i].id){
  173. name = this.departmentList[i].name
  174. }
  175. }
  176. return name
  177. }
  178. },
  179. created(){
  180. this.educationOptions = getDataConfig("patient", "education_types");
  181. this.getAllDoctorList();
  182. this.getPatientCaseHistory();
  183. var xtuser = this.$store.getters.xt_user;
  184. this.orgname = xtuser.org.org_name;
  185. var data = new Date();
  186. var month =data.getMonth() < 9 ? "0" + (data.getMonth() + 1) : data.getMonth() + 1;
  187. var date = data.getDate() <= 9 ? "0" + data.getDate() : data.getDate();
  188. this.printDate = data.getFullYear() + "-" + month + "-" + date;
  189. }
  190. }
  191. </script>
  192. <style lang="scss" scoped>
  193. .prescription-print{
  194. -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 60px rgba(0, 0, 0, 0.06) inset;
  195. -moz-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
  196. box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
  197. margin-bottom: 20px;
  198. padding:20px 10px;
  199. }
  200. .printTitle{
  201. font-size: 22px;
  202. text-align: center;
  203. font-weight: bold;
  204. }
  205. .infoTitle{
  206. display: flex;
  207. margin-top:10px;
  208. line-height: 24px;
  209. padding:0 10px;
  210. }
  211. .infoTitle div{
  212. width: 200px;
  213. }
  214. .otherInfo{
  215. display: flex;
  216. margin-top:10px;
  217. line-height: 24px;
  218. padding:0 10px;
  219. }
  220. .recordTitle{
  221. display: flex;
  222. margin-top:10px;
  223. line-height: 24px;
  224. padding:0 10px;
  225. border-bottom: 2px solid #000;
  226. }
  227. .recordTitle div{
  228. width: 200px;
  229. }
  230. </style>