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/editDietary.vue | 31 ++++++++++++++++++++++++++++---
1 files changed, 28 insertions(+), 3 deletions(-)
diff --git a/src/views/home/components/pingubiao/editDietary.vue b/src/views/home/components/pingubiao/editDietary.vue
index ae33d75..44673c0 100644
--- a/src/views/home/components/pingubiao/editDietary.vue
+++ b/src/views/home/components/pingubiao/editDietary.vue
@@ -2,7 +2,7 @@
<div class="dietarySurvey-item">
<el-dialog v-model="state.dialogTableVisible" title="营养风险筛查表(NRS2002)" :fullscreen="true" width="100%">
<div class="container" style="width: 100%; height: 100%; overflow: auto">
- <div>
+ <div id="pinggu1">
<div>
<el-form size="small">
<div style="width: 100%">
@@ -11,6 +11,7 @@
<th colspan="2">
<el-form-item label="初次调查日期">
<el-date-picker
+ readonly
v-model="state.tableData.初次调查日期"
type="date"
style="width: 100px"
@@ -23,6 +24,7 @@
<th colspan="2">
<el-form-item label="更新日期">
<el-date-picker
+ readonly
v-model="state.tableData.更新日期"
type="date"
style="width: 100px"
@@ -34,7 +36,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>
@@ -188,6 +190,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="'#pinggu1'">
+ <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>
@@ -195,6 +205,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';
@@ -324,6 +335,8 @@
console.log(mode);
state.viewInfo = mode;
state.tableData = JSON.parse(mode.surveryJsonBody);
+ state.tableData.初次调查日期=mode.surveryTime
+ state.tableData.更新日期=mode.updateTime
state.dialogTableVisible = true;
}
};
@@ -362,6 +375,18 @@
updateTime: '',
};
};
+const generatePDF=()=> {
+ const element = document.getElementById('pinggu1');
+ 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 });
@@ -394,4 +419,4 @@
border-color: #666666;
background-color: #ffffff;
}
-</style>
+</style>
\ No newline at end of file
--
Gitblit v1.8.0