chenyc
2024-11-08 ccf73d764231f2ff01a23154c33b26cd49f7ca17
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%">
@@ -103,7 +103,7 @@
                                    </tr>
                                    <tr>
                                        <td>
                                            3.食物偏好
                                            4.食物偏好
                                        </td>
                                        <td colspan="3">
                                            <el-form-item>
@@ -122,7 +122,7 @@
                                        </td>
                                    </tr>
                                    <tr>
                                        <td class="6">
                                        <td colspan="6">
                                            5.三天饮食记录表(食材、份量)
                                        </td>
                                    </tr>
@@ -315,6 +315,9 @@
                                                    :autosize="{ minRows: 1, maxRows: 6 }" placeholder="备注" />
                                            </el-form-item>
                                        </td>
                                        <td colspan="3">
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
@@ -484,8 +487,12 @@
                                                    <el-checkbox value="皮肤问题(皮疹、湿疹、皮肤瘙痒等)">B:皮肤问题(皮疹、湿疹、皮肤瘙痒等)</el-checkbox>
                                                    <el-checkbox value="眼睛问题(发痒、发红、疼痛、流泪等)">C:眼睛问题(发痒、发红、疼痛、流泪等)</el-checkbox>
                                                    <el-checkbox value="呼吸道问题(咳嗽、呼吸困难、鼻塞等)">D:呼吸道问题(咳嗽、呼吸困难、鼻塞等)</el-checkbox>
                                                    <el-checkbox value="其他(吞咽困难等)">E:其他(吞咽困难等)</el-checkbox>
                                                    <el-checkbox disabled value="其他(吞咽困难等)">E:
                                                        <el-input v-model="state.tableData.过敏症状表现为以下哪些.input1"
                                                                placeholder="其他(吞咽困难等)" />
                                                    </el-checkbox>
                                                </el-radio-group>
                                            </el-form-item>
                                        </td>
@@ -506,7 +513,10 @@
                                                    v-model="state.tableData.您是如何知道自己食物过敏.type">
                                                    <el-radio value="自行判断">A:自行判断</el-radio>
                                                    <el-radio value="医生">B:医生</el-radio>
                                                    <el-radio value="其他形式">B:其他形式</el-radio>
                                                    <el-radio disabled value="其他形式">C:
                                                        <el-input v-model="state.tableData.您是如何知道自己食物过敏.input1"
                                                                placeholder="其他形式" />
                                                    </el-radio>
                                                </el-radio-group>
                                            </el-form-item>
@@ -542,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>
@@ -552,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';
@@ -645,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)