From a6f64303f88508d1c4d6ce53ff46be6b745cfb93 Mon Sep 17 00:00:00 2001
From: chenyc <501753378@qq.com>
Date: 星期二, 14 十月 2025 15:21:59 +0800
Subject: [PATCH] 完成营养师管理

---
 src/views/home/components/pingubiao/editDietary4.vue |   71 +++++++++++++++++++++++++++--------
 1 files changed, 55 insertions(+), 16 deletions(-)

diff --git a/src/views/home/components/pingubiao/editDietary4.vue b/src/views/home/components/pingubiao/editDietary4.vue
index b354ec5..bb7630b 100644
--- a/src/views/home/components/pingubiao/editDietary4.vue
+++ b/src/views/home/components/pingubiao/editDietary4.vue
@@ -1,8 +1,8 @@
 <template>
     <div class="dietarySurvey-item">
-        <el-dialog  v-model="state.dialogTableVisible" title="PEW(蛋白质能量消耗评估)" :fullscreen="true" width="100%">
-            <div class="container" style="width: 100%; height: 100%;overflow: auto;">
-                <div>
+        <el-dialog  v-model="state.dialogTableVisible" title="PEW" :fullscreen="true" width="100%">
+            <div  style="width: 100%; height: 100%;overflow: auto;">
+                <div id="pinggu4">
                     <div>
                         <el-form size="small" >
                             <div style="width: 100%">
@@ -11,14 +11,14 @@
                                     <tr>
                                         <th colspan="2">
                                             <el-form-item label="初次调查日期">
-                                                <el-date-picker v-model="state.tableData.初次调查日期" type="date" style="width: 100px;"
+                                                <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>
 
                                         </th>
                                         <th colspan="2">
                                             <el-form-item label="更新日期">
-                                                <el-date-picker v-model="state.tableData.更新日期" type="date" style="width: 100px;"
+                                                <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>
 
@@ -26,7 +26,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>
 
@@ -114,8 +114,8 @@
                                             根据2008年ISRNM推荐的指标进行诊断,满足以下4条诊断标准(每项中至少1项符合)考虑存在PEW
 
                                         </td>
-                                        <td colspan="1" style="font-family: 600;color: blue; font-weight: 700;"> 
-                                            合计满足 {{sum}} 项
+                                        <td colspan="1" style="font-family: 600;color: blue; font-weight: 700;" :style="{color:sum?.color}"> 
+                                            合计满足{{sum.value}}项; {{sum.label}} 
                                         </td>
 
                                     </tr>
@@ -132,6 +132,14 @@
                     <el-button type="primary" @click="onSubmit">
                         保存
                     </el-button>
+                    <el-button v-if="state.viewInfo.id" type="primary" v-print="'#pinggu4'">
+                        <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>
@@ -142,6 +150,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';
@@ -161,7 +170,7 @@
     options:[0,1],
     dialogTableVisible:false,
     tableData: {
-        表名: 'PEW(蛋白质能量消耗评估)',
+        表名: 'PEW',
         初次调查日期:"",
         填表日期: '',
         更新日期: '',
@@ -181,7 +190,8 @@
         肌肉指标:{
             type: '', 
             input1: '',
-        }
+        },
+        结果:''
     },
     loading: false,
     viewInfo:{
@@ -192,7 +202,7 @@
         surveryTime: formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS'),
         surveryPerson: userInfos.value.code,
         surveryJsonBody: '',
-        suveryFormName:'PEW(蛋白质能量消耗评估)',
+        suveryFormName:'PEW',
         surveryFormType:1,
         updateTime: ''
     }
@@ -200,13 +210,26 @@
 })
 const sum = computed(() => {
     let x=0
+    const res={
+        value:'',
+        label:'',
+        color:''
+    }
     for(let key in state.tableData){
         console.log(key+'key=='+state.tableData[key]?.type)
         if(Number(state.tableData[key]?.type)){
             x+=Number(state.tableData[key]?.type)
         }
     }
-    return x
+    if(x>=4){
+        res.label="考虑存在PEW"
+        res.color='#F56C6C'
+    }else{
+        res.label="正常"
+        res.color='#303133'
+    }
+    res.value=x
+    return res
 })
 const funhui=()=>{
     state.dialogTableVisible=false
@@ -214,6 +237,7 @@
 const onSubmit = () => {
   console.log('submit!')
   console.log(state.tableData)
+  state.tableData.结果=sum.value
   const info:tiaochabiaoInfo={
     id: state.viewInfo.id,
     surveryFormType:1,
@@ -223,7 +247,7 @@
     surveryTime: formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS'),
     surveryPerson: userInfos.value.code,
     surveryJsonBody: JSON.stringify(state.tableData),
-    suveryFormName:'PEW(蛋白质能量消耗评估)',
+    suveryFormName:'PEW',
     updateTime: ''
   }
   console.log(info)
@@ -264,6 +288,8 @@
         console.log(mode)
         state.viewInfo=mode
         state.tableData=JSON.parse(mode.surveryJsonBody)
+        state.tableData.初次调查日期=mode.surveryTime
+        state.tableData.更新日期=mode.updateTime
         state.dialogTableVisible = true
 
 
@@ -272,7 +298,7 @@
 }
 const getPageInfo=()=>{
     state.tableData={
-        表名: 'PEW(蛋白质能量消耗评估)',
+        表名: 'PEW',
         初次调查日期:formatDate(new Date(),'YYYY-mm-dd'),
         填表日期: '',
         更新日期: formatDate(new Date(),'YYYY-mm-dd'),
@@ -292,7 +318,8 @@
         肌肉指标:{
             type: '', 
             input1: '肌肉量丢失(3个月内>5%或半年内>10%),上臂肌围减少(减少>10%参照群体第50个百分位数)',
-        }
+        },
+        结果:''
     }
     state.viewInfo={
         id: 0,
@@ -302,11 +329,23 @@
         surveryTime: formatDate(new Date(), 'YYYY-mm-dd HH:MM:SS'),
         surveryPerson: userInfos.value.code,
         surveryJsonBody: '',
-        suveryFormName:'PEW(蛋白质能量消耗评估)',
+        suveryFormName:'PEW',
         surveryFormType:1,
         updateTime: ''
     }
 }
+const generatePDF=()=> {
+      const element = document.getElementById('pinggu4');
+      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 })

--
Gitblit v1.8.0