From 83ef13dab87cb59fccf0514d7d47f2ca0cae9f0f Mon Sep 17 00:00:00 2001
From: chenyc <501753378@qq.com>
Date: 星期六, 21 十二月 2024 23:06:11 +0800
Subject: [PATCH] 更新

---
 src/views/home/components/pingubiao/editDietary3.vue |   30 ++++++++++++++++++++++++++----
 1 files changed, 26 insertions(+), 4 deletions(-)

diff --git a/src/views/home/components/pingubiao/editDietary3.vue b/src/views/home/components/pingubiao/editDietary3.vue
index bba3df4..c8d87a9 100644
--- a/src/views/home/components/pingubiao/editDietary3.vue
+++ b/src/views/home/components/pingubiao/editDietary3.vue
@@ -2,7 +2,7 @@
 	<div class="dietarySurvey-item">
 		<el-dialog v-model="state.dialogTableVisible" title="营养不良炎症评分表(MIS)" :fullscreen="true" width="100%">
 			<div class="container" style="width: 100%; height: 100%; overflow: auto">
-				<div>
+				<div id="pinggu3">
 					<div>
 						<el-form size="small">
 							<div style="width: 100%">
@@ -10,7 +10,7 @@
 									<tr>
 										<th colspan="2">
 											<el-form-item label="初次调查日期">
-												<el-date-picker
+												<el-date-picker readonly
 													v-model="state.tableData.初次调查日期"
 													type="date"
 													style="width: 100px"
@@ -22,7 +22,7 @@
 										</th>
 										<th colspan="2">
 											<el-form-item label="更新日期">
-												<el-date-picker
+												<el-date-picker readonly
 													v-model="state.tableData.更新日期"
 													type="date"
 													style="width: 100px"
@@ -34,7 +34,7 @@
 										</th>
 										<th colspan="2">
 											<el-form-item label="记录者">
-												<el-input v-model="state.tableData.记录者" style="width: 100px" placeholder="" />
+												<el-input v-model="state.tableData.记录者" style="width: 100px" readonly placeholder="" />
 											</el-form-item>
 										</th>
 									</tr>
@@ -194,6 +194,14 @@
 				<div class="dialog-footer" style="text-align: center">
 					<el-button @click="funhui">取消</el-button>
 					<el-button type="primary" @click="onSubmit"> 保存 </el-button>
+					<el-button v-if="state.viewInfo.id" type="primary" v-print="'#pinggu3'">
+                        <el-icon><Printer /></el-icon>
+                        打印
+                    </el-button>
+                    <el-button type="primary" v-if="state.viewInfo.id" @click="generatePDF">
+                        <el-icon><Position /></el-icon>
+                        导出
+                    </el-button>
 				</div>
 			</template>
 		</el-dialog>
@@ -201,6 +209,7 @@
 </template>
 
 <script setup lang="ts" name="visualizingLinkDemo2">
+import html2pdf from 'html2pdf.js';
 import { reactive, onMounted, onUnmounted, ref, computed } from 'vue';
 import { formatDate } from '/@/utils/formatTime';
 import { NextLoading } from '/@/utils/loading';
@@ -343,6 +352,8 @@
 		console.log(mode);
 		state.viewInfo = mode;
 		state.tableData = JSON.parse(mode.surveryJsonBody);
+		state.tableData.初次调查日期=mode.surveryTime
+        state.tableData.更新日期=mode.updateTime
 		state.dialogTableVisible = true;
 	}
 };
@@ -407,7 +418,18 @@
 		updateTime: '',
 	};
 };
+const generatePDF=()=> {
+      const element = document.getElementById('pinggu3');
+      const opt = {
+        margin: 10,
+        filename: `${state.tableData.表名}.pdf`,
+        image: { type: 'jpeg', quality: 0.98 },
+        html2canvas: { scale: 2 },
+        jsPDF: { unit: 'mm', format: 'a4', orientation: 'portrait' }
+      };
+      html2pdf().set(opt).from(element).save();
 
+}
 // 第二步:暴露方法
 defineExpose({ getData, openShow });
 </script>

--
Gitblit v1.8.0