22
schangxiang@126.com
2024-12-15 f8c3e66071ff442b25c17e13c91b0b6e1d1cbea5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
<template>
    <el-dialog v-model="state.dialogVisible" draggable :close-on-click-modal="false" :width="state.width + 8 + 'mm'">
        <template #header>
                <div style="color: #fff">
                    <span>打印</span>
                </div>
            </template>
        <div id="preview_content" ref="previewContentRef"></div>
        <template #footer>
            <el-button :loading="state.waitShowPrinter" type="primary" icon="ele-Printer" @click.stop="print">直接打印</el-button>
            <!-- <el-button type="primary" icon="ele-Printer" @click.stop="toPdf">导出PDF</el-button> -->
            <el-button key="close" @click="hideDialog"> 关闭 </el-button>
        </template>
    </el-dialog>
</template>
 
<script lang="ts" setup>
import { nextTick, reactive, ref } from 'vue';
 
const state = reactive({
    dialogVisible: false,
    waitShowPrinter: false,
    width: 0, // 纸张宽 mm
    printData: {}, // 打印数据
    hiprintTemplate: {} as any,
});
 
const previewContentRef = ref();
 
const showDialog = (hiprintTemplate: any, printData: {}, width = 210) => {
    //debugger
    state.dialogVisible = true;
    state.width = width;
    state.hiprintTemplate = hiprintTemplate;
    state.printData = printData;
    nextTick(() => {
        while (previewContentRef.value?.firstChild) {
            previewContentRef.value.removeChild(previewContentRef.value.firstChild);
        }
        const newHtml = hiprintTemplate.getHtml(printData);
        previewContentRef.value.appendChild(newHtml[0]);
    });
};
 
const print = () => {
    console.log("直接打印")
    state.waitShowPrinter = true;
    state.hiprintTemplate.print(
        state.printData,
        {},
        {
            callback: () => {
                state.waitShowPrinter = false;
            },
        }
    );
};
 
const toPdf = () => {
    state.hiprintTemplate.toPdf({}, 'PDF文件');
};
 
const hideDialog = () => {
    state.dialogVisible = false;
};
 
defineExpose({ showDialog });
</script>
 
<style lang="less" scoped>
:deep(.ant-modal-body) {
    padding: 0px;
}
 
:deep(.ant-modal-content) {
    margin-bottom: 24px;
}
 
:deep(.el-dialog__title) {
    color: white !important;
}
 
</style>