From ccf73d764231f2ff01a23154c33b26cd49f7ca17 Mon Sep 17 00:00:00 2001
From: chenyc <501753378@qq.com>
Date: 星期五, 08 十一月 2024 09:15:08 +0800
Subject: [PATCH] 添加导出和打印功能

---
 src/views/home/components/editDietary.vue |   33 +++++++++++++++++++++++++++++++--
 1 files changed, 31 insertions(+), 2 deletions(-)

diff --git a/src/views/home/components/editDietary.vue b/src/views/home/components/editDietary.vue
index a6365ec..9a86413 100644
--- a/src/views/home/components/editDietary.vue
+++ b/src/views/home/components/editDietary.vue
@@ -2,7 +2,7 @@
     <div class="dietarySurvey-item">
         <el-dialog  v-model="state.dialogTableVisible" title="膳食调查表" :fullscreen="true" width="100%">
             <div class="container" style="width: 100%; height: 100%;overflow: auto;">
-                <div>
+                <div id="printFrom1">
                     <div>
                         <el-form size="small">
                             <div style="width: 100%">
@@ -122,7 +122,7 @@
                                         </td>
                                     </tr>
                                     <tr>
-                                        <td class="6">
+                                        <td colspan="6">
                                             5.三天饮食记录表(食材、份量)
                                         </td>
                                     </tr>
@@ -314,6 +314,9 @@
                                                 <el-input v-model="state.tableData.睡眠.input1" type="textarea"
                                                     :autosize="{ minRows: 1, maxRows: 6 }" placeholder="备注" />
                                             </el-form-item>
+                                        </td>
+                                        <td colspan="3">
+                                            
                                         </td>
                                     </tr>
                                     <tr>
@@ -549,6 +552,15 @@
                     <el-button type="primary" @click="onSubmit">
                         保存
                     </el-button>
+                    <el-button v-if="state.viewInfo.id" type="primary" v-print="'#printFrom1'">
+                        <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>
@@ -559,6 +571,7 @@
 </template>
 
 <script setup lang="ts" name="visualizingLinkDemo2">
+import html2pdf from 'html2pdf.js';
 import { reactive, onMounted, onUnmounted, ref } from 'vue';
 import { formatDate } from '/@/utils/formatTime';
 import { NextLoading } from '/@/utils/loading';
@@ -652,6 +665,22 @@
 const funhui=()=>{
     state.dialogTableVisible=false
 }
+// 打印
+const onPrint=()=>{
+    
+}
+const generatePDF=()=> {
+      const element = document.getElementById('printFrom1');
+      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();
+
+}
 const onSubmit = () => {
   console.log('submit!')
   console.log(state.tableData)

--
Gitblit v1.8.0