CaseRecord2.vue 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <template>
  2. <div class="bcjl">
  3. <div class="title">{{ titleName }}</div>
  4. <div class="info-header mb40">
  5. <el-row :gutter="32">
  6. <el-col :span="6">
  7. <span class="text-blod">科室:</span>
  8. <span>{{ data.keshi }}</span>
  9. </el-col>
  10. <el-col :span="6">
  11. <span class="text-blod">姓名:</span>
  12. <span>{{ data.brxm }}</span>
  13. </el-col>
  14. <el-col :span="6">
  15. <span class="text-blod">床号:</span>
  16. <span>{{ data.ch }}</span>
  17. </el-col>
  18. <el-col :span="6">
  19. <span class="text-blod">住院号:</span>
  20. <span>{{ data.brbh }}</span>
  21. </el-col>
  22. </el-row>
  23. </div>
  24. <div class="info-content">
  25. <el-row :gutter="32">
  26. <el-col :span="24" class="mb40">
  27. <el-row :gutter="32">
  28. <el-col :span="10">
  29. <span class="date">{{ data ? data.date : '' }}</span>
  30. </el-col>
  31. <el-col :span="8">
  32. <span class="content-title">{{data ? data.title : '' }}</span>
  33. </el-col>
  34. </el-row>
  35. </el-col>
  36. </el-row>
  37. <el-row :gutter="32">
  38. <!-- type 1为普通病程记录 2. 术前 3术后 4.查房 -->
  39. <template v-if="data.type === 1">
  40. <el-col :span="24" class="mb10">
  41. <span class="text-blod">病历特点:</span>
  42. <div v-for="(item, index) of data.BLTD" :key="`bltd1${index}`" class="pl76 mb20">{{ item.trim() }}</div>
  43. </el-col>
  44. <el-col :span="24" class="mb10">
  45. <span class="text-blod">初步诊断:</span>
  46. <div v-for="(item, index) of data.CBZD" :key="`cbzd1${index}`" class="pl76 mb20">{{ item.trim() }}</div>
  47. </el-col>
  48. <el-col :span="24" class="mb10">
  49. <span class="text-blod">诊断依据:</span>
  50. <div v-for="(item, index) of data.ZDYJ" :key="`zdyj1${index}`" class="pl76 mb20">{{ item.trim() }}</div>
  51. </el-col>
  52. <el-col :span="24" class="mb10">
  53. <span class="text-blod">鉴别诊断:</span>
  54. <div v-for="(item, index) of data.JBZD" :key="`jbzd1${index}`" class="pl76 mb20">{{ item.trim() }}</div>
  55. </el-col>
  56. <el-col :span="24" class="mb10">
  57. <span class="text-blod">诊疗计划:</span>
  58. <div v-for="(item, index) of data.ZLJH" :key="`zljh1${index}`" class="pl76 mb20">{{ item.trim() }}</div>
  59. </el-col>
  60. </template>
  61. <!-- type 2术前 -->
  62. <template v-if="[2].includes(data.type)">
  63. <el-col :span="24" class="mb10" v-if="data.SSZC">
  64. <div class="text-blod">术前讨论由<span style="padding: 0 20px; border-bottom: 1px solid #000;">{{ data.SSZC }}</span>医师主持,讨论结论及术前小结记录如下:</div>
  65. </el-col>
  66. <el-col :span="24" class="mb10" v-if="data.JYBQ">
  67. <span class="text-blod">简要病情:</span>
  68. <div v-for="(item, index) of data.JYBQ" :key="`jybq2${index}`" class="pl76 mb20">{{ item }}</div>
  69. </el-col>
  70. <el-col :span="24" class="mb10" v-if="data.SSZZ">
  71. <span class="text-blod">术前诊断:</span>
  72. <div v-for="(item, index) of data.SSZZ" :key="`sszz2${index}`" class="pl76 mb20">{{ item }}</div>
  73. </el-col>
  74. <el-col :span="24" class="mb10" v-if="data.SZZY">
  75. <span class="text-blod">手术指征:</span>
  76. <div v-for="(item, index) of data.SZZY" :key="`szzz2${index}`" class="pl76 mb20">{{ item }}</div>
  77. </el-col>
  78. <el-col :span="24" class="mb10" v-if="data.NSSS">
  79. <span class="text-blod">拟施手术名称和方式:</span>
  80. <div v-for="(item, index) of data.NSSS" :key="`nsss2${index}`" class="pl76 mb20">{{ item }}</div>
  81. </el-col>
  82. <el-col :span="24" class="mb10" v-if="data.NSMZ">
  83. <span class="text-blod">拟施麻醉方式:</span>
  84. <div v-for="(item, index) of data.NSMZ" :key="`nsmz2${index}`" class="pl76 mb20">{{ item }}</div>
  85. </el-col>
  86. <el-col :span="24" class="mb10" v-if="data.OTHER">
  87. <span class="text-blod">术前准备:</span>
  88. <div v-for="(item, index) of data.OTHER" :key="`other2${index}`" class="pl76 mb20">{{ item }}</div>
  89. </el-col>
  90. <el-col :span="24" class="mb10" v-if="data.SZZY">
  91. <span class="text-blod">术中注意事项:</span>
  92. <div v-for="(item, index) of data.SZZY" :key="`szzz2${index}`" class="pl76 mb20">{{ item }}</div>
  93. </el-col>
  94. <el-col :span="24" class="mb10" v-if="data.SHCL">
  95. <span class="text-blod">术后处理:</span>
  96. <div v-for="(item, index) of data.SHCL" :key="`shcl2${index}`" class="pl76 mb20">{{ item }}</div>
  97. </el-col>
  98. <el-col :span="24" class="mb10" v-if="data.desc">
  99. <span class="text-blod">其他描述:</span>
  100. <div v-for="(item, index) of data.desc" :key="`desc2${index}`" class="pl76 mb20">{{ item }}</div>
  101. </el-col>
  102. </template>
  103. <!-- type 3术后查房 -->
  104. <template v-if="[3].includes(data.type)">
  105. <el-col :span="24" class="mb10" v-if="data.desc">
  106. <div v-for="(item, index) of data.desc" :key="`bltd3${index}`" class="mb20">{{ item.trim() }}</div>
  107. </el-col>
  108. </template>
  109. <!-- type 4术后查房 -->
  110. <template v-if="[4].includes(data.type)">
  111. <el-col :span="24" class="mb10" v-if="data.desc">
  112. <div v-for="(item, index) of data.desc" :key="`bltd3${index}`" class="mb20">{{ item.trim() }}</div>
  113. </el-col>
  114. </template>
  115. <el-col :span="24" class="mt80">
  116. <div class="fr" style="margin-right: 100px;">
  117. <span class="text-blod">医生签名:</span>
  118. <!-- 接口暂无字段 -->
  119. </div>
  120. </el-col>
  121. </el-row>
  122. </div>
  123. </div>
  124. </template>
  125. <script>
  126. export default {
  127. props: {
  128. data: {
  129. type: Object,
  130. default() {
  131. return {};
  132. },
  133. },
  134. },
  135. computed: {
  136. titleName() {
  137. let str
  138. const type = this.data.type
  139. if (type === 1) {
  140. str = '首次病程记录'
  141. } else if (type === 2) {
  142. str = '术前小结及术前讨论结论记录'
  143. } else if (type === 3) {
  144. str = '术后首次病程记录'
  145. } else if (type === 4) {
  146. str = '查房记录'
  147. }
  148. return str
  149. }
  150. }
  151. };
  152. </script>
  153. <style lang="scss" scoped>
  154. .bcjl {
  155. margin: 0 30px;
  156. line-height: 1.5;
  157. padding-bottom: 100px;
  158. .title {
  159. font-size: 24px;
  160. font-weight: bold;
  161. color: #2c3240;
  162. text-align: center;
  163. margin: 20px;
  164. }
  165. .mb10 {
  166. margin-bottom: 10px;
  167. }
  168. .mb20 {
  169. margin-bottom: 20px;
  170. }
  171. .mb40 {
  172. margin-bottom: 40px;
  173. }
  174. .mt80 {
  175. margin-top: 80px;
  176. }
  177. .pl76 {
  178. padding-left: 76px;
  179. }
  180. .fr {
  181. float: right;
  182. }
  183. .text-blod {
  184. font-weight: bold;
  185. }
  186. .info-header {
  187. padding: 20px 0;
  188. border-bottom: 1.5px solid #e2dfdf;
  189. }
  190. .info-content {
  191. overflow: hidden;
  192. .date {
  193. font-weight: 600;
  194. }
  195. .content-title {
  196. font-weight: 600;
  197. }
  198. }
  199. }
  200. </style>