FrontSheetExport.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558
  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,exportCharCSV } from "@/utils/ExportCVS";
  190. import {
  191. DATEFORMAT,
  192. formatDateToStr,
  193. } from "@/utils/moment-utils";
  194. import env from "@/utils/setting";
  195. const month = ref(null);
  196. const patNo = ref("");
  197. const sheets = ref([]);
  198. const cptSheets = computed(() => {
  199. return sheets.value.filter(item => {
  200. return item.bah.indexOf(patNo.value) !== -1;
  201. });
  202. });
  203. const pageSize = ref(30);
  204. const currentPage = ref(1);
  205. const handleSizeChange = val => {
  206. pageSize.value = val;
  207. };
  208. const handleCurrentChange = val => {
  209. currentPage.value = val;
  210. };
  211. const getAnalyzedSheets = isHqms => {
  212. if (!month.value) {
  213. ElMessage({
  214. message: "请先选择出院日期",
  215. type: "warning",
  216. duration: 2500,
  217. showClose: true,
  218. });
  219. return;
  220. }
  221. month.value = formatMonth(month.value);
  222. fetchSheets(month.value, isHqms).then(res => {
  223. sheets.value = res;
  224. });
  225. };
  226. function deleteRow(index, row) {
  227. if (sheets.value[index] !== row) {
  228. index = sheets.value.findIndex(item => {
  229. return item === row;
  230. });
  231. }
  232. sheets.value.splice(index, 1);
  233. }
  234. const exportExcel = () => {
  235. // console.log("export", formatDateToStr(sheets.value[0].dismissDate,DATEFORMAT.DATE_TIME))
  236. // return
  237. if (sheets.value.length === 0) {
  238. ElMessage({
  239. message: "没有可以导出的数据!",
  240. type: "warning",
  241. duration: 2500,
  242. showClose: true,
  243. });
  244. } else {
  245. sheets.value.forEach(itm => {
  246. itm.instituionCode = env.VITE_SHEET_HOSPITAL_CODE;
  247. itm.instituionName = env.VITE_HOSPITAL_NAME;
  248. itm.certtype = itm.country === "CHN" ? "1" : "9";
  249. // itm.unitinfo = itm.unitName + "/" + itm.unitPlace;
  250. itm.unitinfo = itm.unitPlace;
  251. itm.admissDate = formatDateToStr(itm.admissDate,DATEFORMAT.DATE_TIME_TILT);
  252. itm.dismissDate = formatDateToStr(itm.dismissDate,DATEFORMAT.DATE_TIME_TILT);
  253. itm.birthDate = formatDateToStr(itm.birthDate,DATEFORMAT.DATE_TILT);
  254. itm.qualityControlDate = formatDateToStr(itm.qualityControlDate,DATEFORMAT.DATE_TILT);
  255. itm.surgeryDate0 = formatDateToStr(itm.surgeryDate0,DATEFORMAT.DATE_TILT);
  256. itm.daytimeSurgery = 0;
  257. itm.blank = "-";
  258. // console.log("DATE_TILT",itm)
  259. const diagList = itm.disdiagList;
  260. itm.otherDisdiagSize = diagList.length - 1;
  261. for (let i = 0; i < diagList.length; i++) {
  262. itm["disdiagCode" + i] = diagList[i].code;
  263. itm["disdiagName" + i] = diagList[i].name;
  264. itm["disdiagAdms" + i] = diagList[0].admissStatus;
  265. itm["disdiagDiss" + i] = diagList[0].dismissStatus;
  266. }
  267. const surgeryList = itm.surgeryList;
  268. if (surgeryList.length === 0) {
  269. itm.surgeryCode0 = "";
  270. itm.surgeryName0 = "";
  271. itm.surgeryDate0 = "";
  272. itm.surgeryLevel0 = "";
  273. itm.surgeryLasttime0 = "";
  274. itm.surgeryOptor0 = "";
  275. itm.surgeryAst10 = "";
  276. itm.surgeryAst20 = "";
  277. itm.surgeryWjwCh0 = "";
  278. itm.surgeryAnae0 = "";
  279. // itm.surgeryAnaeLevel0 = "";
  280. // itm.surgeryAnaeName0 = "";
  281. } else {
  282. for (let i = 0; i < surgeryList.length; i++) {
  283. itm["surgeryCode" + i] = surgeryList[i].code;
  284. itm["surgeryName" + i] = surgeryList[i].name;
  285. itm["surgeryDate" + i] = surgeryList[i].date;
  286. itm["surgeryLevel" + i] = surgeryList[i].level;
  287. itm["surgeryLasttime" + i] = "";
  288. itm["surgeryOptor" + i] = surgeryList[i].operatorName;
  289. itm["surgeryAst1" + i] = surgeryList[i].assistantOneName;
  290. itm["surgeryAst2" + i] = surgeryList[i].assistantTwoName;
  291. itm["surgeryWjwCh" + i] = surgeryList[i].wjwCutHeal;
  292. itm["surgeryAnae" + i] = surgeryList[i].anaesthesia;
  293. itm["surgeryAnaeLevel" + i] = "";
  294. itm["surgeryAnaeName" + i] = surgeryList[i].anaesthesiaorName;
  295. }
  296. }
  297. });
  298. const title = {
  299. instituionCode: "A01",
  300. instituionName: "A02",
  301. bah: "A48",
  302. admissTimes: "A49",
  303. admissDate: "B12",
  304. dismissDate: "B15",
  305. healthCardNo: "A47",
  306. payMethod: "A46C",
  307. name: "A11",
  308. sex: "A12C",
  309. birthDate: "A13",
  310. age: "A14",
  311. country: "A15C",
  312. marriage: "A21C",
  313. occupation: "A38C",
  314. nation: "A19C",
  315. certtype: "A20N",
  316. socialNo: "A20",
  317. birthPlaceName: "A22",
  318. nativePlace: "A23C",
  319. hkPlaceName: "A24",
  320. hkZipCode: "A25C",
  321. livePlace: "A26",
  322. phone: "A27",
  323. addrZipCode: "A28C",
  324. unitinfo: "A29",
  325. unitPhone: "A30",
  326. unitZipCode: "A31C",
  327. contactName: "A32",
  328. contactRelation: "A33C",
  329. contactAddrName: "A34",
  330. contactPhone: "A35",
  331. daytimeSurgery: "B38",
  332. zyAdmissWay: "B11C",
  333. admissDeptCode: "B13C",
  334. admissWard: "B14",
  335. zkWard: "B21C",
  336. dismissDeptCode: "B16C",
  337. dismissWard: "B17",
  338. admissDays: "B20",
  339. clinicDiagCode: "C01C",
  340. clinicDiagStr: "C02N",
  341. rysqk: "F01",
  342. ryzdbm: "F02C",
  343. ryzdmc: "F03N",
  344. ryhqzrq: "F04",
  345. disdiagCode0: "C03C",
  346. disdiagName0: "C04N",
  347. disdiagAdms0: "C05C",
  348. disdiagDiss0: "F05",
  349. };
  350. const titleConnetOne = {
  351. // 理想情况是在这里做其他诊断的插入
  352. pathologicDiagCode: "C09C",
  353. pathologicDiagStr: "C10N",
  354. blh: "C11",
  355. hurtReasonCode: "C12C",
  356. hurtReasonName: "C13N",
  357. allergy: "C24C",
  358. allergicMedicine: "C25",
  359. hbsAg: "F10",
  360. hcvAb: "F11",
  361. hivAb: "F12",
  362. deptLeader: "B22C",
  363. deptLeaderName: "B22",
  364. leaderDoctor: "B23C",
  365. leaderDoctorName: "B23",
  366. mainDoctor: "B24C",
  367. mainDoctorName: "B24",
  368. admissDoctor: "B25C",
  369. admissDoctorName: "B25",
  370. dutyNurse: "B26C",
  371. dutyNurseName: "B26",
  372. studyDoctorName: "B27",
  373. internshipDoctorName: "B28",
  374. coderName: "B29",
  375. qualityControlLevel: "B30C",
  376. qualityControlDoctorName: "B31",
  377. qualityControlNurseName: "B32",
  378. qualityControlDate: "B33",
  379. autopsy: "C34C",
  380. bloodType: "C26C",
  381. rh: "C27C",
  382. surgeryCode0: "C14x01C",
  383. surgeryName0: "C15x01N",
  384. surgeryDate0: "C16x01",
  385. surgeryLevel0: "C17x01",
  386. surgeryLasttime0: "F13",
  387. surgeryOptor0: "C18x01",
  388. surgeryAst10: "C19x01",
  389. surgeryAst20: "C20x01",
  390. surgeryWjwCh0: "C21x01C",
  391. surgeryAnae0: "C22x01C",
  392. surgeryAnaeLevel0: "F15",
  393. surgeryAnaeName0: "C23x01",
  394. admissAgainInOneMonth:"B36C",
  395. admissAgainPurpose:"B37",
  396. zyDismissWay:"B34C",
  397. dismissDestination:"B35",
  398. totalCost:"D01",
  399. selfPay:"D09",
  400. };
  401. const titleChar = {
  402. instituionCode: "组织机构代码",
  403. instituionName: "医疗机构名称",
  404. bah: "病案号",
  405. admissTimes: "住院次数",
  406. admissDate: "入院时间",
  407. dismissDate: "出院时间",
  408. healthCardNo: "健康卡号",
  409. payMethod: "医疗付费方式",
  410. name: "姓名",
  411. sex: "性别",
  412. birthDate: "出生日期",
  413. age: "年龄(岁)",
  414. country: "国籍",
  415. marriage: "婚姻",
  416. occupation: "职业",
  417. nation: "民族",
  418. certtype: "证件类别",
  419. socialNo: "证件号码",
  420. birthPlaceName: "出生地址",
  421. nativePlace: "籍贯省(自治区、直辖市)",
  422. hkPlaceName: "户口地址",
  423. hkZipCode: "户口地址邮政编码",
  424. livePlace: "现住址",
  425. phone: "现住址电话",
  426. addrZipCode: "现住址邮政编码",
  427. unitinfo: "工作单位及地址",
  428. unitPhone: "工作单位电话",
  429. unitZipCode: "工作单位邮政编码",
  430. contactName: "联系人姓名",
  431. contactRelation: "联系人关系",
  432. contactAddrName: "联系人地址",
  433. contactPhone: "联系人电话",
  434. daytimeSurgery: "是否为日间手术",
  435. zyAdmissWay: "入院途径",
  436. admissDeptCode: "入院科别",
  437. admissWard: "入院病房",
  438. zkWard: "转科科别",
  439. dismissDeptCode: "出院科别",
  440. dismissWard: "出院病房",
  441. admissDays: "实际住院(天)",
  442. clinicDiagCode: "门(急)诊诊断编码",
  443. clinicDiagStr: "门(急)诊诊断名称",
  444. rysqk: "入院时情况",
  445. ryzdbm: "入院诊断编码",
  446. ryzdmc: "入院诊断名称",
  447. ryhqzrq: "入院后确诊日期",
  448. disdiagCode0: "出院主要诊断编码",
  449. disdiagName0: "出院主要诊断名称",
  450. disdiagAdms0: "出院主要诊断入院病情",
  451. disdiagDiss0: "主要诊断出院情况",
  452. };
  453. const titleCharConnectOne = {
  454. // 理想情况是在这里做其他诊断的插入
  455. pathologicDiagCode: "病理诊断编码",
  456. pathologicDiagStr: "病理诊断名称",
  457. blh: "病理号",
  458. hurtReasonCode: "损伤、中毒外部原因编码",
  459. hurtReasonName: "损伤、中毒外部原因名称",
  460. allergy: "有无药物过敏",
  461. allergicMedicine: "过敏药物名称",
  462. hbsAg: "HBsAg",
  463. hcvAb: "HCV-Ab",
  464. hivAb: "HIV-Ab",
  465. deptLeader: "科主任编码",
  466. deptLeaderName: "科主任",
  467. leaderDoctor: "主(副主)任医师编码",
  468. leaderDoctorName: "主(副主)任医师",
  469. mainDoctor: "主治医师编码",
  470. mainDoctorName: "主治医师",
  471. admissDoctor: "住院医师编码",
  472. admissDoctorName: "住院医师",
  473. dutyNurse: "责任护士编码",
  474. dutyNurseName: "责任护士",
  475. studyDoctorName: "进修医师",
  476. internshipDoctorName: "实习医师",
  477. coderName: "编码员",
  478. qualityControlLevel: "病案质量",
  479. qualityControlDoctorName: "质控医师",
  480. qualityControlNurseName: "质控护师",
  481. qualityControlDate: "质控日期",
  482. autopsy: "死亡患者尸检",
  483. bloodType: "ABO血型",
  484. rh: "Rh血型",
  485. surgeryCode0: "主要手术操作编码",
  486. surgeryName0: "主要手术操作名称",
  487. surgeryDate0: "主要手术操作日期",
  488. surgeryLevel0: "主要手术操作级别",
  489. surgeryLasttime0: "主要手术持续时间",
  490. surgeryOptor0: "主要手术操作术者",
  491. surgeryAst10: "主要手术操作Ⅰ助",
  492. surgeryAst20: "主要手术操作Ⅱ助",
  493. surgeryWjwCh0: "主要手术操作切口愈合等级",
  494. surgeryAnae0: "主要手术操作麻醉方式",
  495. surgeryAnaeLevel0: "主要手术麻醉分级",
  496. surgeryAnaeName0: "主要手术操作麻醉医师",
  497. admissAgainInOneMonth:"是否有出院31天内再住院计划",
  498. admissAgainPurpose:"出院31天内再住院计划目的",
  499. zyDismissWay:"离院方式",
  500. dismissDestination:"医嘱转院、转社区卫生服务机构/乡镇卫生院名称",
  501. totalCost:"住院总费用",
  502. selfPay:"住院总费用其中自费金额",
  503. };
  504. for (let i = 1; i < 41; i++) {
  505. let mark = ("0" + i).slice(-2);
  506. title["disdiagCode" + i] = `C06x${mark}C`;
  507. title["disdiagName" + i] = `C07x${mark}N`;
  508. title["disdiagAdms" + i] = `C08x${mark}C`;
  509. title["disdiagDiss" + i] = `F06x${mark}`;
  510. titleChar["disdiagCode" + i] = `出院其他诊断编码${mark}`;
  511. titleChar["disdiagName" + i] = `出院其他诊断名称${mark}`;
  512. titleChar["disdiagAdms" + i] = `出院其他诊断入院病情${mark}`;
  513. titleChar["disdiagDiss" + i] = `其他诊断出院情况${mark}`;
  514. }
  515. // for (let i = 1; i < 41; i++) {
  516. // let mark = ("0" + i).slice(-2);
  517. // title["surgeryCode" + i] = `C35x${mark}C`;
  518. // title["surgeryName" + i] = `C36x${mark}N`;
  519. // title["surgeryDate" + i] = `C37x${mark}`;
  520. // title["surgeryLevel" + i] = `C38x${mark}`;
  521. // title["surgeryLasttime" + i] = `F14x${mark}`;
  522. // title["surgeryOptor" + i] = `C39x${mark}`;
  523. // title["surgeryAst1" + i] = `C40x${mark}`;
  524. // title["surgeryAst2" + i] = `C41x${mark}`;
  525. // title["surgeryWjwCh" + i] = `C42x${mark}C`;
  526. // title["surgeryAnae" + i] = `C43x${mark}C`;
  527. // title["surgeryAnaeLevel" + i] = `F16x${mark}`;
  528. // title["surgeryAnaeName" + i] = `C44x${mark}`;
  529. // }
  530. const yearMonth = month.value.split("-");
  531. // const fileName = `${env.VITE_UNIFIED_SOCIAL_CREDIT_CODE_CODE}_${env.VITE_HOSPITAL_NAME}_${yearMonth[0]}_${yearMonth[1]}.csv`;
  532. const fileName = `hqmsts_${env.VITE_HOSPITAL_NAME}_${yearMonth[0]}_${yearMonth[1]}.csv`;
  533. exportCharCSV(sheets.value, Object.assign(title,titleConnetOne),Object.assign(titleChar,titleCharConnectOne), fileName, ",");
  534. }
  535. };
  536. </script>