From 070ff71561be29e98bbc90e6d77f43f806f5b50b Mon Sep 17 00:00:00 2001
From: chenyc <501753378@qq.com>
Date: 星期四, 09 一月 2025 16:12:50 +0800
Subject: [PATCH] 34

---
 src/views/home/components/pingubiao/editDietary2.vue |   52 +++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 43 insertions(+), 9 deletions(-)

diff --git a/src/views/home/components/pingubiao/editDietary2.vue b/src/views/home/components/pingubiao/editDietary2.vue
index fea6bd2..049ae82 100644
--- a/src/views/home/components/pingubiao/editDietary2.vue
+++ b/src/views/home/components/pingubiao/editDietary2.vue
@@ -1,8 +1,8 @@
 <template>
     <div class="dietarySurvey-item">
-        <el-dialog v-model="state.dialogTableVisible" title="主观全面评定(SGA)评价" :fullscreen="true" width="100%">
+        <el-dialog v-model="state.dialogTableVisible" title="SGA" :fullscreen="true" width="100%">
             <div class="container" style="width: 100%; height: 100%;overflow: auto;">
-                <div>
+                <div id="pinggu2">
                     <div>
                         <el-form size="small">
                             <div style="width: 100%">
@@ -11,7 +11,7 @@
                                     <tr>
                                         <th colspan="2">
                                             <el-form-item label="初次调查日期">
-                                                <el-date-picker v-model="state.tableData.初次调查日期" type="date"
+                                                <el-date-picker v-model="state.tableData.初次调查日期" type="date" readonly
                                                     style="width: 100px;" placeholder="" format="YYYY/MM/DD"
                                                     value-format="YYYY-MM-DD" />
                                             </el-form-item>
@@ -19,7 +19,7 @@
                                         </th>
                                         <th colspan="2">
                                             <el-form-item label="更新日期">
-                                                <el-date-picker v-model="state.tableData.更新日期" type="date"
+                                                <el-date-picker v-model="state.tableData.更新日期" type="date" readonly
                                                     style="width: 100px;" placeholder="" format="YYYY/MM/DD"
                                                     value-format="YYYY-MM-DD" />
                                             </el-form-item>
@@ -28,7 +28,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>
 
@@ -427,6 +427,14 @@
                     <el-button type="primary" @click="onSubmit">
                         保存
                     </el-button>
+                    <el-button v-if="state.viewInfo.id" type="primary" v-print="'#pinggu2'">
+                        <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>
@@ -437,6 +445,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';
@@ -455,7 +464,7 @@
 const state = reactive({
     dialogTableVisible: false,
     tableData: {
-        表名: '主观全面评定(SGA)评价',
+        表名: 'SGA',
         初次调查日期: "",
         填表日期: '',
         更新日期: '',
@@ -542,7 +551,7 @@
         surveryTime: formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS'),
         surveryPerson: userInfos.value.code,
         surveryJsonBody: '',
-        suveryFormName: '主观全面评定(SGA)评价',
+        suveryFormName: 'SGA',
         surveryFormType: 1,
         updateTime: ''
     }
@@ -579,7 +588,7 @@
         surveryTime: formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS'),
         surveryPerson: userInfos.value.code,
         surveryJsonBody: JSON.stringify(state.tableData),
-        suveryFormName: '主观全面评定(SGA)评价',
+        suveryFormName: 'SGA',
         updateTime: ''
     }
     console.log(info)
@@ -621,6 +630,8 @@
         console.log(mode)
         state.viewInfo = mode
         state.tableData = JSON.parse(mode.surveryJsonBody)
+        state.tableData.初次调查日期=mode.surveryTime
+        state.tableData.更新日期=mode.updateTime
         state.dialogTableVisible = true
 
 
@@ -629,7 +640,7 @@
 }
 const getPageInfo = () => {
     state.tableData = {
-        表名: '主观全面评定(SGA)评价',
+        表名: 'SGA',
         初次调查日期: formatDate(new Date(), 'YYYY-mm-dd'),
         填表日期: '',
         更新日期: formatDate(new Date(), 'YYYY-mm-dd'),
@@ -707,8 +718,31 @@
             input1: '',
         }
     }
+    state.viewInfo={
+        id: 0,
+        code: '',
+        clientCode: userInfos.value.clientCode,
+        patientCode: patientsInfo.value.code,
+        surveryTime: formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS'),
+        surveryPerson: userInfos.value.code,
+        surveryJsonBody: '',
+        suveryFormName: 'SGA',
+        surveryFormType: 1,
+        updateTime: ''
+    }
 }
+const generatePDF=()=> {
+      const element = document.getElementById('pinggu2');
+      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