| | |
| | | <div class="elTableDiv"> |
| | | <el-table |
| | | :data="tableData" |
| | | :height="tableHeight+'px'" |
| | | :height="isIpad? (tableHeight+50):tableHeight" |
| | | border |
| | | stripe |
| | | :style="{width: 100+'%',height:tableHeight+'px',}" |
| | |
| | | <div class="elTableDiv"> |
| | | <el-table |
| | | :data="WXtableData" |
| | | :height="tableHeight+'px'" |
| | | :height="isIpad? (tableHeight+50):tableHeight" |
| | | border |
| | | stripe |
| | | :style="{width: 100+'%',height:tableHeight+'px',}" |
| | |
| | | <el-dialog |
| | | :title="dialogTitle" |
| | | :visible.sync="dialogVisible" |
| | | width="800" |
| | | width="850px" |
| | | class="dialogVisible" |
| | | :top="dialogTitle==='自制报工'?'5vh':'15vh'" |
| | | :close-on-click-modal="false" |
| | |
| | | </div> |
| | | </span> |
| | | </el-dialog> |
| | | |
| | | <!--打印预览页面--> |
| | | <el-dialog |
| | | title="预览" |
| | | :visible.sync="dialogVisible2" |
| | | width="1140" |
| | | :close-on-click-modal="false" |
| | | @close="dialogVisible2Close" |
| | | > |
| | | <!-- 要打印的区域 --> |
| | | <div id="printMe2" style="padding: 30px;"> |
| | | <div |
| | | style="display: flex;width: 250px;height: 150px;border: 1px solid #000;text-align: center;font-size: 10px;" |
| | | > |
| | | |
| | | <div style="width: 60px;display: flex;flex-direction: column;border-right: 1px solid #000"> |
| | | <div |
| | | style="display: flex;height: 75%;border-bottom:1px solid #000;justify-content: center;align-items: center " |
| | | > |
| | | <div id="qrCode2" ref="qrCodeDiv2" /> |
| | | </div> |
| | | <div style="display: flex;height: 25%;justify-content: flex-start;align-items: center"> |
| | | <div style="margin-left: 5px;width: 40px">数量:</div> |
| | | {{ qrForm.startqty }} |
| | | </div> |
| | | </div> |
| | | |
| | | <div style="width:190px;display: flex;flex-direction: column"> |
| | | <div |
| | | style="display: flex;height: 25%;border-bottom:1px solid #000;justify-content: flex-start;align-items: center;text-align: left" |
| | | > |
| | | <div style="width: 60px;margin-left: 5px;">工单编号:</div> |
| | | <div>{{ qrForm.wo_code }}</div> |
| | | </div> |
| | | <div |
| | | style="display: flex;height: 25%;border-bottom:1px solid #000;justify-content: flex-start;align-items: center ;text-align: left" |
| | | > |
| | | <div style="width: 60px;margin-left: 5px;">产品编码:</div> |
| | | <div>{{ qrForm.partcode }}</div> |
| | | </div> |
| | | <div |
| | | style="display: flex;height: 25%;border-bottom:1px solid #000 ;justify-content: flex-start;align-items: center;text-align: left" |
| | | > |
| | | <div style="width:60px;margin-left: 5px;">产品名称:</div> |
| | | <div>{{ qrForm.partname }}</div> |
| | | </div> |
| | | <div style="display: flex;height: 25%;justify-content: flex-start;align-items: center;text-align: left"> |
| | | <div style="width: 60px;margin-left: 5px;">下道工序:</div> |
| | | <div>{{ qrForm.nextstepname }}</div> |
| | | </div> |
| | | |
| | | </div> |
| | | |
| | | </div> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <div class="footerButton"> |
| | | <el-button @click="dialogVisible2 = false">取 消</el-button> |
| | | <el-button v-print="printObj2" type="primary">确 定</el-button> |
| | | </div> |
| | | </span> |
| | | </el-dialog> |
| | | |
| | | </div> |
| | | </template> |
| | | |
| | |
| | | SavaMesOrderStepReport |
| | | } from '@/api/scgl' |
| | | import { urlAddRandomNo, webapp_ws_ajax_run, webapp_ws_autoupdate } from '@/utils/grwebapp' |
| | | import QRCode from 'qrcodejs2' |
| | | |
| | | const SER_HZ = /^[\u4e00-\u9fa5]+$/ |
| | | export default { |
| | |
| | | return { |
| | | mainHeight: 0, |
| | | tableHeight: 0, |
| | | isIpad: false, |
| | | // produceCode: '', // 工序码 |
| | | // WXproduceCode: '', // 外协工序码 |
| | | radioSelected: '', // 工序选中 |
| | |
| | | { required: true, message: '请输入报工数量', trigger: ['blur', 'change'] } |
| | | ] |
| | | }, |
| | | activeName: '' |
| | | activeName: '', |
| | | dialogVisible2: false, |
| | | printObj2: { |
| | | id: 'printMe2', |
| | | popTitle: '打印模板', |
| | | preview: false, |
| | | extraHead: '<meta http-equiv="Content-Language" content="zh-cn"/>', |
| | | closeCallback(vue) { // 关闭打印的回调事件(无法确定点击的是确认还是取消) |
| | | console.log('11212', vue) |
| | | // vue.dialogVisible = false |
| | | vue.dialogVisible2 = false |
| | | vue.dialogVisible = false |
| | | }, |
| | | beforeOpenCallback(vue) { |
| | | vue.printLoading = true |
| | | console.log('打开之前') |
| | | console.log() |
| | | }, |
| | | openCallback(vue) { |
| | | vue.printLoading = false |
| | | console.log('执行了打印') |
| | | } |
| | | }, |
| | | qrForm: { |
| | | qrvalue: '', |
| | | startqty: '', |
| | | wo_code: '', |
| | | partcode: '', |
| | | partname: '', |
| | | nextstepname: '' |
| | | } |
| | | } |
| | | }, |
| | | // computed: { |
| | | // qrLink: function() { |
| | | // return this.$store.getters.getPreviewUrl |
| | | // } |
| | | // }, |
| | | // watch: { |
| | | // qrLink: function(newVal, oldNew) { |
| | | // if (newVal !== oldNew) { |
| | | // this.$nextTick(() => { |
| | | // this.bindQRCode(newVal) |
| | | // }) |
| | | // } |
| | | // } |
| | | // }, |
| | | created() { |
| | | this.getMesOrderStepSearch() |
| | | this.tabClick() |
| | |
| | | |
| | | this.$nextTick(() => { |
| | | $("input[name='produceCode']")[0].focus() |
| | | // this.bindQRCode('10001;001') |
| | | }) |
| | | // webapp_urlprotocol_startup() |
| | | webapp_ws_autoupdate(true) |
| | | // webapp_ws_autoupdate(true) |
| | | }, |
| | | methods: { |
| | | async getMesOrderStepSearch() { |
| | |
| | | } |
| | | SavaMesOrderStepIn(data).then(res => { |
| | | if (res.code === '200') { |
| | | this.WXprint() |
| | | this.WXprint2() |
| | | this.$message.success('收料成功!') |
| | | this.dialogVisible = false |
| | | this.dialogVisible2 = true |
| | | this.tabClick() |
| | | } else { |
| | | this.$message.error('收料失败!') |
| | |
| | | ngqty: this.dialogForm.noputqty === '' ? 0 : this.dialogForm.noputqty, // 不良数量 |
| | | badcode: this.dialogForm.badcode.length < 1 ? '' : this.dialogForm.badcode.join(';')// 不良原因 |
| | | } |
| | | |
| | | SavaMesOrderStepReport(data).then(res => { |
| | | if (res.code === '200') { |
| | | this.ZZprint() |
| | | this.ZZprint2() |
| | | this.$message.success('报工成功!') |
| | | this.dialogVisible = false |
| | | this.dialogVisible2 = true |
| | | this.tabClick() |
| | | } else { |
| | | this.$message.error('报工失败!') |
| | |
| | | } |
| | | }) |
| | | }, |
| | | async ZZprint() { |
| | | const obj = { |
| | | recordset: [ |
| | | { |
| | | wo_code: this.dialogForm.wo_code, // 工单编号 |
| | | partcode: this.dialogForm.partcode, // 产品编码 |
| | | partname: this.dialogForm.partname, // 产品名称 |
| | | next_stepname: this.dialogForm.nextstepname, // 下道工序 |
| | | qty: this.dialogForm.startqty, // 数量 |
| | | // qrcode: this.form.orderstepqrcode// 二维码 |
| | | qrcode: this.dialogForm.wo_code + ';' + this.dialogForm.nextstepcode // 二维码 |
| | | } |
| | | ] |
| | | } |
| | | const args = { |
| | | type: 'print', // preview print |
| | | showOptionDlg: false, // 如果不显示打印对话框而直接打印,将此行注释去掉即可 |
| | | report: urlAddRandomNo('./static/grf/报工产出标签.grf'), |
| | | data: obj |
| | | } |
| | | webapp_ws_ajax_run(args) |
| | | // 生成二维码 |
| | | bindQRCode(text) { |
| | | new QRCode(this.$refs.qrCodeDiv2, { |
| | | text: text, |
| | | width: 50, |
| | | height: 50, |
| | | colorDark: '#000', // 二维码颜色 |
| | | colorLight: '#ffffff', // 二维码背景色 |
| | | correctLevel: QRCode.CorrectLevel.L// 容错率,L/M/H |
| | | }) |
| | | }, |
| | | // 外协收料打印 |
| | | WXprint() { |
| | | // 参数具体说明请参考帮助文档中的“WEB报表(B/S报表)->WEB报表客户端->启动参数说明”部分 |
| | | const obj = { |
| | | recordset: [ |
| | | { |
| | | wo_code: this.dialogForm.wo_code, // 工单编号 |
| | | partcode: this.dialogForm.partcode, // 产品编码 |
| | | partname: this.dialogForm.partname, // 产品名称 |
| | | next_stepname: this.dialogForm.nextstepname, // 下道工序 |
| | | qty: this.dialogForm.sqty, // 数量 |
| | | // qrcode: this.WXform.orderstepqrcode// 二维码 |
| | | qrcode: this.dialogForm.wo_code + ';' + this.dialogForm.nextstepcode// 二维码 |
| | | } |
| | | ] |
| | | } |
| | | const args = { |
| | | type: 'print', // preview print |
| | | showOptionDlg: false, // 如果不显示打印对话框而直接打印,将此行注释去掉即可 |
| | | report: urlAddRandomNo('./static/grf/外协收料标签.grf'), |
| | | data: obj |
| | | } |
| | | webapp_ws_ajax_run(args) |
| | | ZZprint2() { |
| | | this.qrForm.qrvalue = this.dialogForm.wo_code + ';' + this.dialogForm.nextstepcode |
| | | this.qrForm.startqty = this.dialogForm.startqty |
| | | this.qrForm.wo_code = this.dialogForm.wo_code |
| | | this.qrForm.partcode = this.dialogForm.partcode |
| | | this.qrForm.partname = this.dialogForm.partname |
| | | this.qrForm.nextstepname = this.dialogForm.nextstepname |
| | | |
| | | this.$nextTick(() => { |
| | | this.bindQRCode(this.qrForm.qrvalue) |
| | | console.log(this.$refs.qrCodeDiv2, 123) |
| | | // console.log(this.$refs.qrCodeDiv2.querySelectorAll('#qrCode2>img'), 1) |
| | | // console.log(this.$refs.qrCodeDiv2.querySelectorAll('#qrCode2>canvas'), 2) |
| | | }) |
| | | }, |
| | | WXprint2() { |
| | | this.qrForm.qrvalue = this.dialogForm.wo_code + ';' + this.dialogForm.nextstepcode |
| | | this.qrForm.startqty = this.dialogForm.sqty |
| | | this.qrForm.wo_code = this.dialogForm.wo_code |
| | | this.qrForm.partcode = this.dialogForm.partcode |
| | | this.qrForm.partname = this.dialogForm.partname |
| | | this.qrForm.nextstepname = this.dialogForm.nextstepname |
| | | this.$nextTick(() => { |
| | | this.bindQRCode(this.qrForm.qrvalue) |
| | | }) |
| | | }, |
| | | dialogVisible2Close() { |
| | | this.qrForm.qrvalue = '' |
| | | this.qrForm.startqty = '' |
| | | this.qrForm.wo_code = '' |
| | | this.qrForm.partcode = '' |
| | | this.qrForm.partname = '' |
| | | this.qrForm.nextstepname = '' |
| | | this.$refs.qrCodeDiv2 = '' |
| | | }, |
| | | |
| | | // 获取页面高度 |
| | | getHeight() { |
| | | this.$nextTick(() => { |
| | | this.mainHeight = window.innerHeight - 250 |
| | | this.tableHeight = this.mainHeight - 80 |
| | | this.tableHeight = this.mainHeight - 50 |
| | | this.isIpad = window.innerHeight < 769 |
| | | if (window.innerHeight < 769) { |
| | | this.tableHeight = this.tableHeight - 50 |
| | | } |
| | | }) |
| | | } |
| | | } |
| | |
| | | } |
| | | } |
| | | </style> |
| | | <style media="print"> |
| | | /*@media print {*/ |
| | | @page { |
| | | size: auto; |
| | | margin: 3mm; |
| | | font-size: 10px; |
| | | } |
| | | |
| | | </style> |