detailDialog.vue 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. <template>
  2. <div class="quality-report-container">
  3. <div v-if="reportData.reportNumber">
  4. <div class="title">
  5. 质检报告
  6. </div>
  7. <!-- 质检报告表格 -->
  8. <div style="display: flex; align-items: center; justify-content: space-between; font-size: 14px; margin-bottom: 10px;">
  9. <div>
  10. <span class="label">编号:</span>
  11. <span class="value">{{ reportData.code }}</span>
  12. </div>
  13. <div>
  14. <span class="label">报告单号:</span>
  15. <span class="value">{{ reportData.reportNumber }}</span>
  16. </div>
  17. </div>
  18. <table class="quality-report-table">
  19. <tbody>
  20. <tr>
  21. <td class="label">检品名称:</td>
  22. <td class="value">{{ reportData.productName }}</td>
  23. <td class="label">批号/序列号:</td>
  24. <td class="value"></td>
  25. </tr>
  26. <tr>
  27. <td class="label">规格型号:</td>
  28. <td class="value">{{ reportData.specification }}</td>
  29. <td class="label">数量:</td>
  30. <td class="value">{{ reportData.total }}</td>
  31. </tr>
  32. <tr>
  33. <td class="label">请验日期:</td>
  34. <td class="value">{{ reportData.pleaseVerifyDate }}</td>
  35. <td class="label">请验部门:</td>
  36. <td class="value">{{ reportData.pleaseVerifyDepartment }}</td>
  37. </tr>
  38. <tr>
  39. <td class="label">报告日期:</td>
  40. <td class="value">{{ reportData.reportDate }}</td>
  41. <td class="label">有效期:</td>
  42. <td class="value">{{ reportData.expirationDate }}</td>
  43. </tr>
  44. <tr>
  45. <td class="label">检品来源:</td>
  46. <td class="value">{{ reportData.source }}</td>
  47. <td class="label">储存条件:</td>
  48. <td class="value">{{ reportData.storageCondition }}</td>
  49. </tr>
  50. <tr>
  51. <td class="label">检验依据:</td>
  52. <td class="value" colspan="3">{{ reportData.inspectionBasis }}</td>
  53. </tr>
  54. </tbody>
  55. </table>
  56. <!-- 检验项目表格 -->
  57. <table class="quality-report-table">
  58. <thead>
  59. <tr>
  60. <th class="label">检验项目</th>
  61. <th class="label">标准规定</th>
  62. <th class="label">检验结果</th>
  63. </tr>
  64. </thead>
  65. <tbody>
  66. <tr v-for="item in reportDetail">
  67. <td class="value">{{ item.item }}</td>
  68. <td class="value">{{ item.standardRegulations }}</td>
  69. <td class="value">{{ item.results }}</td>
  70. </tr>
  71. </tbody>
  72. </table>
  73. <!-- 结论表格 -->
  74. <table class="quality-report-table">
  75. <tbody>
  76. <tr>
  77. <td class="label">结论:</td>
  78. <td class="value" colspan="3">{{ reportData.conclusion }}</td>
  79. </tr>
  80. <tr>
  81. <td class="label">备注:</td>
  82. <td class="value" colspan="3">{{ reportData.remarks }}</td>
  83. </tr>
  84. </tbody>
  85. </table>
  86. <div style="display: flex; align-items: center; justify-content: space-between; font-size: 14px; margin-top: 10px;">
  87. <div>
  88. <span class="label">检验员/日期:</span>
  89. <span class="value">{{ reportData.inspector }}/{{ reportData.inspectionTime }}</span>
  90. </div>
  91. <div>
  92. <span class="label">复核人/日期:</span>
  93. <span class="value">{{ reportData.reviewer }}/{{ reportData.reviewTime }}</span>
  94. </div>
  95. <div>
  96. <span class="label">审核人/日期:</span>
  97. <span class="value">{{ reportData.checker }}/{{ reportData.approvedDate }}</span>
  98. </div>
  99. </div>
  100. </div>
  101. <browse
  102. v-else
  103. :url="fileUrl"
  104. ></browse>
  105. </div>
  106. </template>
  107. <script>
  108. import { getDetail, getListDetail, getDetailById } from '@/api/bpm/components/qualityReportApproval/qualityReportApproval';
  109. import browse from '@/components/jimureport/browse.vue'
  110. import { getJmPrintViewUrl } from '@/components/jimureport//api.js';
  111. import { getToken } from '@/utils/token-util';
  112. export default {
  113. props: {
  114. taskDefinitionKey: {
  115. type: String,
  116. default: 'starter'
  117. },
  118. businessId: {
  119. default: ''
  120. },
  121. isView: {
  122. default: ''
  123. },
  124. businessCode: {
  125. default: ''
  126. },
  127. },
  128. components: {
  129. browse
  130. },
  131. data() {
  132. return {
  133. // 质检报告数据
  134. reportData: {},
  135. reportDetail: [],
  136. fileUrl: '',
  137. };
  138. },
  139. mounted() {
  140. this.open()
  141. },
  142. methods: {
  143. async open() {
  144. const detail = await getDetailById(this.businessId);
  145. // this.reportData = detail;
  146. // this.showEditFlag = true;
  147. console.log('detail~~~', detail);
  148. if(detail.data.reportTemplateJson?.basicInfoData) {
  149. this.reportData = detail.data.reportTemplateJson.basicInfoData;
  150. this.reportDetail = detail.data.reportTemplateJson.inspectionItems;
  151. const reportApprovalTaskVos = detail.data.reportApprovalTaskVos || [];
  152. const reviewTime = reportApprovalTaskVos?.[reportApprovalTaskVos.length - 2]?.endTime?.split(' ')[0] || '';
  153. const approvedDate = reportApprovalTaskVos?.[reportApprovalTaskVos.length - 3]?.endTime?.split(' ')[0] || '';
  154. const reviewer = reportApprovalTaskVos?.[reportApprovalTaskVos.length - 2]?.approvalUserName || '';
  155. const checker = reportApprovalTaskVos?.[reportApprovalTaskVos.length - 3]?.approvalUserName || '';
  156. this.$set(this.reportData, 'inspectionTime', this.reportData.inspectionTime?.split(' ')[0] || '');
  157. this.$set(this.reportData, 'reviewTime', this.reportData.reviewTime?.split(' ')[0] || reviewTime || '');
  158. this.$set(this.reportData, 'approvedDate', this.reportData.approvedDate?.split(' ')[0] || approvedDate || '');
  159. this.$set(this.reportData, 'reviewer', this.reportData.reviewer || reviewer || '');
  160. this.$set(this.reportData, 'checker', this.reportData.checker || checker || '');
  161. } else {
  162. // 组件挂载时加载数据
  163. // this.loadReportData();
  164. // this.loadListDetail();
  165. console.log('this.businessCode~~~', this.businessCode);
  166. let url = await getJmPrintViewUrl('qmsqualityinspectionprint');
  167. this.fileUrl = `${url}?token=${getToken()}&id=${this.businessId}`;
  168. console.log('fileUrl~~~', this.fileUrl);
  169. }
  170. },
  171. // 可以根据需要添加数据加载方法
  172. async loadReportData() {
  173. // // 从API获取质检报告数据
  174. const detail = await getDetail(this.businessId);
  175. this.reportData = detail;
  176. },
  177. async loadListDetail() {
  178. const detail = await getListDetail(this.businessId);
  179. this.reportDetail = detail;
  180. }
  181. }
  182. };
  183. </script>
  184. <style scoped lang="scss">
  185. .quality-report-container {
  186. padding: 20px;
  187. background-color: #ffffff;
  188. min-height: 100%;
  189. }
  190. .title {
  191. font-size: 20px;
  192. font-weight: 600;
  193. text-align: center;
  194. margin-bottom: 20px;
  195. color: #333333;
  196. }
  197. .quality-report-table {
  198. width: 100%;
  199. border-collapse: collapse;
  200. // margin-bottom: 20px;
  201. font-size: 14px;
  202. }
  203. .quality-report-table td,
  204. .quality-report-table th {
  205. border: 1px solid #ddd;
  206. padding: 8px;
  207. text-align: left;
  208. }
  209. .quality-report-table th {
  210. background-color: #f5f5f5;
  211. font-weight: 600;
  212. color: #333333;
  213. }
  214. .quality-report-table .label {
  215. width: 120px;
  216. background-color: #f9f9f9;
  217. font-weight: 500;
  218. color: #333333;
  219. }
  220. .quality-report-table .value {
  221. color: #555555;
  222. min-width: 150px;
  223. }
  224. .quality-report-table tr:hover {
  225. background-color: #fafafa;
  226. }
  227. </style>