FrontSheetExport.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  1. <template>
  2. <div class="layout_container">
  3. <header>
  4. <el-date-picker
  5. v-model="month"
  6. :clearable="false"
  7. placeholder="出院日期"
  8. style="width: 110px"
  9. type="month"
  10. ></el-date-picker>
  11. <el-divider direction="vertical"></el-divider>
  12. <el-button type="primary" icon="Search" @click="getAnalyzedSheets(false)"
  13. >检索(省质控)</el-button
  14. >
  15. <el-button type="success" icon="Search" @click="getAnalyzedSheets(true)"
  16. >检索(HQMS)</el-button
  17. >
  18. <el-divider direction="vertical" />
  19. <el-button type="primary" icon="Download" @click="exportExcel"
  20. >导出csv</el-button
  21. >
  22. </header>
  23. <div class="layout_main layout_el-table">
  24. <el-table
  25. :data="
  26. cptSheets.slice(pageSize * (currentPage - 1), pageSize * currentPage)
  27. "
  28. stripe
  29. >
  30. <el-table-column width="33" label="剔除">
  31. <template #default="scope">
  32. <el-button
  33. icon="Minus"
  34. size="small"
  35. circle
  36. type="danger"
  37. @click.prevent="deleteRow(scope.$index, scope.row)"
  38. ></el-button>
  39. </template>
  40. </el-table-column>
  41. <el-table-column type="expand">
  42. <template #default="props">
  43. <div style="display: flex">
  44. <div style="width: 40%">
  45. <div
  46. style="
  47. width: 100%;
  48. padding: 4px;
  49. background: rgb(128, 128, 128);
  50. font-weight: bold;
  51. color: white;
  52. "
  53. >
  54. 出院诊断
  55. </div>
  56. <div
  57. style="
  58. display: flex;
  59. font-size: 13px;
  60. font-weight: bold;
  61. padding: 4px 0;
  62. "
  63. >
  64. <div style="width: 10%">序号</div>
  65. <div style="width: 30%">诊断编码</div>
  66. <div>诊断名称</div>
  67. </div>
  68. <div v-for="item in props.row.disdiagList">
  69. <div
  70. style="
  71. display: flex;
  72. padding: 4px 0;
  73. border-bottom: 1px dashed lightskyblue;
  74. "
  75. >
  76. <div style="width: 10%">{{ item.no }}</div>
  77. <div style="width: 30%">{{ item.code }}</div>
  78. <div>{{ item.name }}</div>
  79. </div>
  80. </div>
  81. </div>
  82. <div
  83. v-show="props.row.surgeryList.length > 0"
  84. style="width: 55%; margin-left: 30px"
  85. >
  86. <div
  87. style="
  88. width: 100%;
  89. padding: 4px;
  90. background: rgb(128, 128, 128);
  91. font-weight: bold;
  92. color: white;
  93. "
  94. >
  95. 手术记录
  96. </div>
  97. <div
  98. style="
  99. display: flex;
  100. font-size: 13px;
  101. font-weight: bold;
  102. padding: 4px 0;
  103. "
  104. >
  105. <div style="width: 10%">序号</div>
  106. <div style="width: 25%">手术时间</div>
  107. <div style="width: 20%">手术编码</div>
  108. <div>手术名称</div>
  109. </div>
  110. <div v-for="item in props.row.surgeryList">
  111. <div
  112. style="
  113. display: flex;
  114. padding: 4px 0;
  115. border-bottom: 1px dashed lightskyblue;
  116. "
  117. >
  118. <div style="width: 10%">{{ item.no }}</div>
  119. <div style="width: 25%">{{ item.date }}</div>
  120. <div style="width: 20%">{{ item.code }}</div>
  121. <div>{{ item.name }}</div>
  122. </div>
  123. </div>
  124. </div>
  125. </div>
  126. </template>
  127. </el-table-column>
  128. <el-table-column prop="bah" width="100">
  129. <template #header>
  130. <el-input
  131. v-model="patNo"
  132. size="small"
  133. placeholder="住院号"
  134. clearable
  135. />
  136. </template>
  137. </el-table-column>
  138. <el-table-column
  139. prop="admissTimes"
  140. label="次数"
  141. width="50"
  142. ></el-table-column>
  143. <el-table-column prop="name" label="姓名" width="100"></el-table-column>
  144. <el-table-column prop="sex" label="性别" width="50"></el-table-column>
  145. <el-table-column prop="socialNo" label="身份证号"></el-table-column>
  146. <el-table-column
  147. prop="birthDate"
  148. label="出生日期"
  149. width="100"
  150. ></el-table-column>
  151. <el-table-column
  152. prop="phone"
  153. label="电话"
  154. width="100"
  155. ></el-table-column>
  156. <el-table-column prop="admissDate" label="入院时间"></el-table-column>
  157. <el-table-column prop="admissDept" label="入院科室"></el-table-column>
  158. <el-table-column prop="dismissDate" label="出院时间"></el-table-column>
  159. <el-table-column prop="dismissDept" label="出院科室"></el-table-column>
  160. <el-table-column
  161. prop="admissDoctorName"
  162. label="入院医生"
  163. width="100"
  164. ></el-table-column>
  165. <el-table-column
  166. prop="mainDoctorName"
  167. label="主治医生"
  168. width="100"
  169. ></el-table-column>
  170. </el-table>
  171. </div>
  172. <div>
  173. <el-pagination
  174. :current-page="currentPage"
  175. :page-size="pageSize"
  176. :page-sizes="[10, 30, 50, 100]"
  177. :total="sheets.length"
  178. layout="total, sizes, prev, pager, next, jumper"
  179. @size-change="handleSizeChange"
  180. @current-change="handleCurrentChange"
  181. ></el-pagination>
  182. </div>
  183. </div>
  184. </template>
  185. <script setup name="FrontSheetExport">
  186. import { ElMessage } from "element-plus";
  187. import { formatMonth } from "@/utils/date";
  188. import { fetchSheets } from "@/api/case-front-sheet";
  189. import { exportCSV } from "@/utils/ExportCVS";
  190. import env from "@/utils/setting";
  191. const month = ref(null);
  192. const patNo = ref("");
  193. const sheets = ref([]);
  194. const cptSheets = computed(() => {
  195. return sheets.value.filter(item => {
  196. return item.bah.indexOf(patNo.value) !== -1;
  197. });
  198. });
  199. const pageSize = ref(30);
  200. const currentPage = ref(1);
  201. const handleSizeChange = val => {
  202. pageSize.value = val;
  203. };
  204. const handleCurrentChange = val => {
  205. currentPage.value = val;
  206. };
  207. const getAnalyzedSheets = isHqms => {
  208. if (!month.value) {
  209. ElMessage({
  210. message: "请先选择出院日期",
  211. type: "warning",
  212. duration: 2500,
  213. showClose: true,
  214. });
  215. return;
  216. }
  217. month.value = formatMonth(month.value);
  218. fetchSheets(month.value, isHqms).then(res => {
  219. sheets.value = res;
  220. });
  221. };
  222. function deleteRow(index, row) {
  223. if (sheets.value[index] !== row) {
  224. index = sheets.value.findIndex(item => {
  225. return item === row;
  226. });
  227. }
  228. sheets.value.splice(index, 1);
  229. }
  230. const exportExcel = () => {
  231. if (sheets.value.length === 0) {
  232. ElMessage({
  233. message: "没有可以导出的数据!",
  234. type: "warning",
  235. duration: 2500,
  236. showClose: true,
  237. });
  238. } else {
  239. sheets.value.forEach(itm => {
  240. itm.instituionCode = env.VITE_SHEET_HOSPITAL_CODE;
  241. itm.instituionName = env.VITE_HOSPITAL_NAME;
  242. itm.certtype = itm.country === "中国" ? "1" : "9";
  243. itm.unitinfo = itm.unitName + "/" + itm.unitPlace;
  244. itm.daytimeSurgery = 0;
  245. itm.blank = "-";
  246. const diagList = itm.disdiagList;
  247. itm.otherDisdiagSize = diagList.length - 1;
  248. for (let i = 0; i < diagList.length; i++) {
  249. itm["disdiagCode" + i] = diagList[i].code;
  250. itm["disdiagName" + i] = diagList[i].name;
  251. itm["disdiagAdms" + i] = diagList[0].admissStatus;
  252. itm["disdiagDiss" + i] = diagList[0].dismissStatus;
  253. }
  254. const surgeryList = itm.surgeryList;
  255. if (surgeryList.length === 0) {
  256. itm.surgeryCode0 = "";
  257. itm.surgeryName0 = "";
  258. itm.surgeryDate0 = "";
  259. itm.surgeryLevel0 = "";
  260. itm.surgeryLasttime0 = "";
  261. itm.surgeryOptor0 = "";
  262. itm.surgeryAst10 = "";
  263. itm.surgeryAst20 = "";
  264. itm.surgeryWjwCh0 = "";
  265. itm.surgeryAnae0 = "";
  266. itm.surgeryAnaeLevel0 = "";
  267. itm.surgeryAnaeName0 = "";
  268. } else {
  269. for (let i = 0; i < surgeryList.length; i++) {
  270. itm["surgeryCode" + i] = surgeryList[i].code;
  271. itm["surgeryName" + i] = surgeryList[i].name;
  272. itm["surgeryDate" + i] = surgeryList[i].date;
  273. itm["surgeryLevel" + i] = surgeryList[i].level;
  274. itm["surgeryLasttime" + i] = "";
  275. itm["surgeryOptor" + i] = surgeryList[i].operatorName;
  276. itm["surgeryAst1" + i] = surgeryList[i].assistantOneName;
  277. itm["surgeryAst2" + i] = surgeryList[i].assistantTwoName;
  278. itm["surgeryWjwCh" + i] = surgeryList[i].wjwCutHeal;
  279. itm["surgeryAnae" + i] = surgeryList[i].anaesthesia;
  280. itm["surgeryAnaeLevel" + i] = "";
  281. itm["surgeryAnaeName" + i] = surgeryList[i].anaesthesiaorName;
  282. }
  283. }
  284. });
  285. const title = {
  286. instituionCode: "A01",
  287. instituionName: "A02",
  288. bah: "A48",
  289. admissTimes: "A49",
  290. admissDate: "B12",
  291. dismissDate: "B15",
  292. healthCardNo: "A47",
  293. payMethod: "A46C",
  294. name: "A11",
  295. sex: "A12C",
  296. birthDate: "A13",
  297. age: "A14",
  298. country: "A15C",
  299. marriage: "A21C",
  300. occupation: "A38C",
  301. nation: "A19C",
  302. certtype: "A20N",
  303. socialNo: "A20",
  304. birthPlaceName: "A22",
  305. nativePlace: "A23C",
  306. hkPlaceName: "A24",
  307. hkZipCode: "A25C",
  308. livePlace: "A26",
  309. phone: "A27",
  310. addrZipCode: "A28C",
  311. unitinfo: "A29",
  312. unitPhone: "A30",
  313. unitZipCode: "A31C",
  314. contactName: "A32",
  315. contactRelation: "A33C",
  316. contactAddrName: "A34",
  317. contactPhone: "A35",
  318. daytimeSurgery: "B38",
  319. zyAdmissWay: "B11C",
  320. admissDeptCode: "B13C",
  321. admissWard: "B14",
  322. zkWard: "B21C",
  323. dismissDeptCode: "B16C",
  324. dismissWard: "B17",
  325. admissDays: "B20",
  326. clinicDiagCode: "C01C",
  327. clinicDiagStr: "C02N",
  328. disdiagCode0: "C03C",
  329. disdiagName0: "C04N",
  330. disdiagAdms0: "C05C",
  331. disdiagDiss0: "F05",
  332. // 理想情况是在这里做其他诊断的插入
  333. pathologicDiagCode: "C09C",
  334. pathologicDiagStr: "C10N",
  335. blh: "C11",
  336. hurtReasonCode: "C12C",
  337. hurtReasonName: "C13N",
  338. allergy: "C24C",
  339. allergicMedicine: "C25",
  340. hbsAg: "F10",
  341. hcvAb: "F11",
  342. hivAb: "F12",
  343. deptLeader: "B22C",
  344. deptLeaderName: "B22",
  345. leaderDoctor: "B23C",
  346. leaderDoctorName: "B23",
  347. mainDoctor: "B24C",
  348. mainDoctorName: "B24",
  349. admissDoctor: "B25C",
  350. admissDoctorName: "B25",
  351. dutyNurse: "B26C",
  352. dutyNurseName: "B26",
  353. studyDoctorName: "B27",
  354. internshipDoctorName: "B28",
  355. coderName: "B29",
  356. qualityControlLevel: "B30C",
  357. qualityControlDoctorName: "B31",
  358. qualityControlNurseName: "B32",
  359. qualityControlDate: "B33",
  360. autopsy: "C34C",
  361. bloodType: "C26C",
  362. rh: "C27C",
  363. surgeryCode0: "C14x01C",
  364. surgeryName0: "C15x01N",
  365. surgeryDate0: "C16x01",
  366. surgeryLevel0: "C17x01",
  367. surgeryLasttime0: "F13",
  368. surgeryOptor0: "C18x01",
  369. surgeryAst10: "C19x01",
  370. surgeryAst20: "C20x01",
  371. surgeryWjwCh0: "C21x01C",
  372. surgeryAnae0: "C22x01C",
  373. surgeryAnaeLevel0: "F15",
  374. surgeryAnaeName0: "C23x01",
  375. // 理想情况是在这里做其他手术的插入
  376. ageDays: "A16",
  377. newBornWeight: "A18x01",
  378. newBornAdmissWeight: "A17",
  379. comaDaysBeforeAdmiss: "C28",
  380. comaHoursBeforeAdmiss: "C29",
  381. comaMinutesBeforeAdmiss: "C30",
  382. comaDaysAfterAdmiss: "C31",
  383. comaHoursAfterAdmiss: "C32",
  384. comaMinutesAfterAdmiss: "C33",
  385. admissAgainInOneMonth: "B36C",
  386. admissAgainPurpose: "B37",
  387. zyDismissWay: "B34C",
  388. dismissDestination: "B35",
  389. totalCost: "D01",
  390. selfPay: "D09",
  391. surgicalFee: "D20",
  392. anesthetizeFee: "D20x01",
  393. surgeryFee: "D20x02",
  394. tcmTreatmentFee: "D22",
  395. };
  396. for (let i = 1; i < 41; i++) {
  397. let mark = ("0" + i).slice(-2);
  398. title["disdiagCode" + i] = `C06x${mark}C`;
  399. title["disdiagName" + i] = `C07x${mark}N`;
  400. title["disdiagAdms" + i] = `C08x${mark}C`;
  401. title["disdiagDiss" + i] = `F06x${mark}`;
  402. }
  403. for (let i = 1; i < 41; i++) {
  404. let mark = ("0" + i).slice(-2);
  405. title["surgeryCode" + i] = `C35x${mark}C`;
  406. title["surgeryName" + i] = `C36x${mark}N`;
  407. title["surgeryDate" + i] = `C37x${mark}`;
  408. title["surgeryLevel" + i] = `C38x${mark}`;
  409. title["surgeryLasttime" + i] = `F14x${mark}`;
  410. title["surgeryOptor" + i] = `C39x${mark}`;
  411. title["surgeryAst1" + i] = `C40x${mark}`;
  412. title["surgeryAst2" + i] = `C41x${mark}`;
  413. title["surgeryWjwCh" + i] = `C42x${mark}C`;
  414. title["surgeryAnae" + i] = `C43x${mark}C`;
  415. title["surgeryAnaeLevel" + i] = `F16x${mark}`;
  416. title["surgeryAnaeName" + i] = `C44x${mark}`;
  417. }
  418. const yearMonth = month.value.split("-");
  419. const fileName = `${env.VITE_HOSPITAL_CODE}_${env.VITE_HOSPITAL_NAME}_${yearMonth[0]}_${yearMonth[1]}.csv`;
  420. exportCSV(sheets.value, title, fileName, ",");
  421. }
  422. };
  423. </script>