Compare commits

..

No commits in common. "391e06a382774c005d09d82476c82199a95e23a1" and "b41ba04cb401b06b478a522ddb538b12e7165ee6" have entirely different histories.

14 changed files with 846 additions and 2534 deletions

View File

@ -1,138 +0,0 @@
<!--
filename: index.vue
author: liubin
date: 2024-04-02 09:49:36
description:
-->
<template>
<!-- 按钮切换 -->
<div
v-if="buttonMode"
class="button-nav">
<button
v-for="m in menus"
:key="m"
@click="currentMenu = m"
:data-text="m"
:class="[m === currentMenu ? 'active' : '']"></button>
</div>
<!-- 标签切换 -->
<div
v-else
class="custom-tabs"
style="height: 100%; width: 100%">
<el-tabs
class="tag-nav"
v-model="currentMenu"
style="height: 100%">
<el-tab-pane
v-for="(m, idx) in menus"
:key="m"
:label="idx == 0 ? `\u2002${m}\u2002` : `\u3000${m}\u3000`"
:name="m">
<slot :name="`tab${idx + 1}`"></slot>
</el-tab-pane>
</el-tabs>
</div>
</template>
<script>
export default {
name: 'ButtonNav',
props: {
menus: {
type: Array,
required: true,
default: () => [],
validator: (val) => {
return val.length > 0;
},
},
buttonMode: {
type: Boolean,
default: true,
},
},
data() {
return {
currentMenu: '',
};
},
created() {
this.currentMenu = this.menus[0];
},
watch: {
currentMenu(val) {
this.$emit('change', val);
},
},
};
</script>
<style scoped lang="scss">
.button-nav {
width: 100%;
// padding: 12px 0;
display: flex;
gap: 12px;
* {
user-select: none;
}
button {
cursor: pointer;
appearance: none;
outline: none;
border: none;
background: #fff;
border-radius: 8px;
padding: 20px;
color: #888;
letter-spacing: 2px;
flex: 1;
box-sizing: padding-box;
position: relative;
&::after {
content: attr(data-text);
position: absolute;
top: 10px;
left: 50%;
font-size: 18px;
font-weight: 500;
transform: translate(-50%);
}
&.active {
color: #111;
border-bottom: 4px solid #0b58ff;
}
}
}
</style>
<style scoped>
.custom-tabs >>> .el-tabs__header {
margin-bottom: 8px;
display: inline-block;
/* transform: translateY(-12px); */
}
.custom-tabs >>> .el-tabs__item {
padding-left: 0px !important;
padding-right: 0px !important;
line-height: 36px !important;
height: 36px;
}
.custom-tabs >>> .el-tabs__content {
height: calc(100% - 42px);
}
.custom-tabs >>> .el-tab-pane {
box-sizing: border-box;
height: 100%;
padding: 20px;
border: 10px solid #f002;
}
</style>

View File

@ -1,11 +1,6 @@
<template> <template>
<el-drawer <el-drawer :visible.sync="drawer" :append-to-body="true" size="80%" >
:visible.sync="drawer" <small-title slot="title" :no-padding="true">
:append-to-body="true"
size="80%">
<small-title
slot="title"
:no-padding="true">
<!-- <template v-for="demo in demoList"> --> <!-- <template v-for="demo in demoList"> -->
<!-- <el-button :key="demo.name" :type="demo.name === curDemo ? 'primary' : ' '" @click="curDemo = demo.name"> --> <!-- <el-button :key="demo.name" :type="demo.name === curDemo ? 'primary' : ' '" @click="curDemo = demo.name"> -->
<!-- {{ $t('module.packingManage.printModelDesign') }} --> <!-- {{ $t('module.packingManage.printModelDesign') }} -->
@ -15,7 +10,7 @@
</small-title> </small-title>
<el-card> <el-card>
<el-row style="margin-bottom: 10px"> <el-row style="margin-bottom: 10px">
<!-- <el-col :span="4"> --> <el-col :span="4">
<!-- 模板选择 --> <!-- 模板选择 -->
<!-- <el-select <!-- <el-select
@ -30,65 +25,26 @@
{{ opt.name }} {{ opt.name }}
</el-option> </el-option>
</el-select> --> </el-select> -->
<!-- </el-col> --> </el-col>
<el-col :span="24"> <el-col :span="20">
<!-- 纸张设置 --> <!-- 纸张设置 -->
<el-button-group style="margin:0 10px"> <el-button-group style="margin:0 10px">
<el-button <el-button v-for="(value,type) in paperTypes" :key="type" :type="curPaperType === type ? 'primary' : ' '"
v-for="(value, type) in paperTypes"
:key="type"
:type="curPaperType === type ? 'primary' : ' '"
@click="setPaper(type,value)"> @click="setPaper(type,value)">
{{ type }} {{ type }}
</el-button> </el-button>
</el-button-group> </el-button-group>
<el-input-number <el-input-number style="margin:0 10px" :value="scaleValue " :precision="2" :step="0.1" :min="scaleMin"
style="margin: 0 10px; width: 140px" :max="scaleMax" @change="changeScale" />
:value="scaleValue" <el-popover v-model="paperPopVisible" placement="bottom" width="300" title="设置纸张宽高(mm)">
:precision="2" <div style="display: flex;align-items: center;justify-content: space-between;margin-bottom: 10px">
:step="0.1" <el-input v-model="paperWidth" type="number" style=" width: 100px; text-align: center" place="宽mm" />~
:min="scaleMin" <el-input v-model="paperHeight" type="number" style=" width: 100px; text-align: center" place="高mm" />
:max="scaleMax"
@change="changeScale" />
<el-popover
v-model="paperPopVisible"
placement="bottom"
width="300"
title="设置纸张宽高(mm)">
<div
style="
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 10px;
">
<el-input
v-model="paperWidth"
type="number"
style="width: 100px; text-align: center"
place="宽mm" />
~
<el-input
v-model="paperHeight"
type="number"
style="width: 100px; text-align: center"
place="高mm" />
</div> </div>
<div> <div>
<el-button <el-button type="primary" style="width: 100%" size="mini" @click="otherPaper">确定</el-button>
type="primary"
style="width: 100%"
size="mini"
@click="otherPaper">
确定
</el-button>
</div> </div>
<el-button <el-button slot="reference" type="primary" style="margin:0 10px">自定义宽高</el-button>
slot="reference"
type="primary"
style="margin: 0 10px">
自定义宽高
</el-button>
</el-popover> </el-popover>
<!-- <a-button-group>--> <!-- <a-button-group>-->
@ -116,57 +72,38 @@
<!-- 预览/打印 --> <!-- 预览/打印 -->
<el-button-group> <el-button-group>
<el-button <el-button type="primary" icon="redo" @click="rotatePaper()">旋转</el-button>
type="primary" <el-button type="primary" icon="el-icon-view" @click="preView">
icon="redo"
@click="rotatePaper()">
旋转
</el-button>
<el-button
type="primary"
icon="el-icon-view"
@click="preView">
预览 预览
</el-button> </el-button>
<!-- <el-button type="primary" icon="el-icon-printer" @click="print"> <!-- <el-button type="primary" icon="el-icon-printer" @click="print">
直接打印 直接打印
</el-button> --> </el-button> -->
<el-button <el-button type="primary" icon="el-icon-s-management" @click="save">
type="primary"
icon="el-icon-s-management"
@click="save">
保存 保存
</el-button> </el-button>
<el-button <el-button type="danger" icon="el-icon-delete" @click="clearPaper">
type="danger"
icon="el-icon-delete"
@click="clearPaper">
清空 清空
</el-button> </el-button>
</el-button-group> </el-button-group>
<!-- 保存/清空 --> <!-- 保存/清空 -->
</el-col> </el-col>
</el-row> </el-row>
<el-row :gutter="24"> <el-row :gutter="24">
<el-col :span="4"> <el-col :span="4">
<el-card style="height: 100vh"> <el-card style="height: 100vh">
<el-row> <el-row>
<el-col <el-col :span="24" class="rect-printElement-types hiprintEpContainer" />
:span="24"
class="rect-printElement-types hiprintEpContainer" />
</el-row> </el-row>
</el-card> </el-card>
</el-col> </el-col>
<el-col :span="16"> <el-col :span="16">
<el-card class="card-design"> <el-card class="card-design">
<div <div id="hiprint-printTemplate" class="hiprint-printTemplate" />
id="hiprint-printTemplate"
class="hiprint-printTemplate" />
</el-card> </el-card>
</el-col> </el-col>
<el-col <el-col :span="4" class="params_setting_container">
:span="4"
class="params_setting_container">
<el-card> <el-card>
<el-row class="hinnn-layout-sider"> <el-row class="hinnn-layout-sider">
<div id="PrintElementOptionSetting" /> <div id="PrintElementOptionSetting" />
@ -181,14 +118,15 @@
</template> </template>
<script> <script>
import printPreview from './preview';
import { MessageBox } from 'element-ui'; import printPreview from './preview'
import { hiprint } from 'vue-plugin-hiprint'; import { MessageBox } from 'element-ui'
import providers from './providers'; import { hiprint } from 'vue-plugin-hiprint'
import providers from './providers'
// import printData from './print-data' // import printData from './print-data'
import $ from 'jquery'; import $ from 'jquery'
import SmallTitle from './SmallTitle.vue'; import SmallTitle from './SmallTitle.vue'
let hiprintTemplate = null; let hiprintTemplate = null
export default { export default {
name: 'PrintCustom', name: 'PrintCustom',
components: { printPreview, SmallTitle }, components: { printPreview, SmallTitle },
@ -215,34 +153,30 @@ export default {
drawer: false, drawer: false,
// //
paperTypes: { paperTypes: {
A3: { 'A3': {
width: 420, width: 420,
height: 296.6, height: 296.6
}, },
A4: { 'A4': {
width: 210, width: 210,
height: 297, height: 297
}, },
A5: { 'A5': {
width: 210, width: 210,
height: 147.6, height: 147.6
}, },
A6: { 'B3': {
width: 95,
height: 125,
},
B3: {
width: 500, width: 500,
height: 352.6, height: 352.6
}, },
B4: { 'B4': {
width: 250, width: 250,
height: 352.6, height: 352.6
}, },
B5: { 'B5': {
width: 250, width: 250,
height: 175.6, height: 175.6
}, }
}, },
scaleValue: 1, scaleValue: 1,
scaleMax: 5, scaleMax: 5,
@ -250,59 +184,59 @@ export default {
// //
paperPopVisible: false, paperPopVisible: false,
paperWidth: '210', paperWidth: '210',
paperHeight: '297', paperHeight: '297'
}; }
}, },
computed: { computed: {
curPaperType() { curPaperType() {
let type = 'other'; let type = 'other'
const types = this.paperTypes; const types = this.paperTypes
for (const key in types) { for (const key in types) {
const item = types[key]; const item = types[key]
const { width, height } = this.curPaper; const { width, height } = this.curPaper
if (item.width === width && item.height === height) { if (item.width === width && item.height === height) {
type = key; type = key
} }
} }
return type; return type
}, }
}, },
created() { created() {
// $('.hiprintEpContainer').empty() // $('.hiprintEpContainer').empty()
}, },
destroyed () { destroyed () {
$('.hiprintEpContainer').empty(); $('.hiprintEpContainer').empty()
console.log(11111); console.log(11111)
}, },
methods: { methods: {
// handleClose() { // handleClose() {
// $('.hiprintEpContainer').empty() // $('.hiprintEpContainer').empty()
// }, // },
closed() { closed() {
$('.hiprintEpContainer').empty(); $('.hiprintEpContainer').empty()
$('.hiprint-printTemplate').empty(); $('.hiprint-printTemplate').empty()
}, },
init(data) { init(data) {
this.drawer = true; this.drawer = true
this.modelData = data; this.modelData = data
this.modeList = providers.map((e) => { this.modeList = providers.map((e) => {
return { type: e.type, name: e.name, value: e.value }; return { type: e.type, name: e.name, value: e.value }
}); })
this.changeMode(); this.changeMode()
}, },
changeMode() { changeMode() {
// hiprintTemplate.clear() // hiprintTemplate.clear()
// console.log(this.modelData) // console.log(this.modelData)
this.$nextTick(() => { this.$nextTick(() => {
const { mode } = this; const { mode } = this
const provider = providers[mode]; const provider = providers[mode]
hiprint.init({ hiprint.init({
providers: [provider.f], providers: [provider.f]
}); })
// $('#hiprint-printTemplate').empty() // $('#hiprint-printTemplate').empty()
// console.log(JSON.parse(this.modelData)) // console.log(JSON.parse(this.modelData))
hiprint.setConfig(); hiprint.setConfig()
// //
hiprint.setConfig({ hiprint.setConfig({
movingDistance: 2.5, movingDistance: 2.5,
@ -310,15 +244,15 @@ export default {
supportOptions: [ supportOptions: [
{ {
name: 'styler', name: 'styler',
hidden: true, hidden: true
}, },
{ {
name: 'formatter', name: 'formatter',
hidden: true, hidden: true
}, }
], ]
}, }
}); })
// console.log(this.modelData) // console.log(this.modelData)
// console.log($('#hiprint-printTemplate').empty()) // console.log($('#hiprint-printTemplate').empty())
@ -333,38 +267,35 @@ export default {
// paginationContainer: '.hiprint-printPagination' // paginationContainer: '.hiprint-printPagination'
// }) // })
// } else { // } else {
$('.hiprintEpContainer').empty(); $('.hiprintEpContainer').empty()
console.log(this.modelData || {}); console.log(this.modelData || {});
hiprint.PrintElementTypeManager.build( hiprint.PrintElementTypeManager.build('.hiprintEpContainer', provider.value)
'.hiprintEpContainer', $('.hiprint-printTemplate').empty()
provider.value
);
$('.hiprint-printTemplate').empty();
// const templates = this.$ls.get('KEY_TEMPLATES', {}) // const templates = this.$ls.get('KEY_TEMPLATES', {})
const template = provider.value; const template = provider.value
// console.log(template) // console.log(template)
if (this.modelData) { if (this.modelData) {
hiprintTemplate = new hiprint.PrintTemplate({ hiprintTemplate = new hiprint.PrintTemplate({
template: JSON.parse(this.modelData), template: JSON.parse(this.modelData),
settingContainer: '#PrintElementOptionSetting', settingContainer: '#PrintElementOptionSetting',
paginationContainer: '.hiprint-printPagination', paginationContainer: '.hiprint-printPagination'
}); })
} else { } else {
hiprintTemplate = new hiprint.PrintTemplate({ hiprintTemplate = new hiprint.PrintTemplate({
template:{}, template:{},
settingContainer: '#PrintElementOptionSetting', settingContainer: '#PrintElementOptionSetting',
paginationContainer: '.hiprint-printPagination', paginationContainer: '.hiprint-printPagination'
}); })
} }
// } // }
hiprintTemplate.design('#hiprint-printTemplate'); hiprintTemplate.design('#hiprint-printTemplate')
// console.log(hiprintTemplate) // console.log(hiprintTemplate)
console.log(hiprintTemplate); console.log(hiprintTemplate);
// hiprintTemplate.design('#hiprint-printTemplate', { grid: true }) // hiprintTemplate.design('#hiprint-printTemplate', { grid: true })
// , zoomtrue // , zoomtrue
this.scaleValue = hiprintTemplate.editingPanel.scale || 1; this.scaleValue = hiprintTemplate.editingPanel.scale || 1
// this.scaleValue = hiprintTemplate.editingPanel.scale || 1 // this.scaleValue = hiprintTemplate.editingPanel.scale || 1
}); })
}, },
/** /**
* 设置纸张大小 * 设置纸张大小
@ -374,110 +305,97 @@ export default {
setPaper(type, value) { setPaper(type, value) {
try { try {
if (Object.keys(this.paperTypes).includes(type)) { if (Object.keys(this.paperTypes).includes(type)) {
this.curPaper = { this.curPaper = { type: type, width: value.width, height: value.height }
type: type, hiprintTemplate.setPaper(value.width, value.height)
width: value.width,
height: value.height,
};
hiprintTemplate.setPaper(value.width, value.height);
} else { } else {
this.curPaper = { this.curPaper = { type: 'other', width: value.width, height: value.height }
type: 'other', hiprintTemplate.setPaper(value.width, value.height)
width: value.width,
height: value.height,
};
hiprintTemplate.setPaper(value.width, value.height);
} }
} catch (error) { } catch (error) {
this.$message.error(`操作失败: ${error}`); this.$message.error(`操作失败: ${error}`)
} }
}, },
changeScale(currentValue, oldValue) { changeScale(currentValue, oldValue) {
let big = false; let big = false
currentValue <= oldValue ? (big = false) : (big = true); currentValue <= oldValue ? big = false : big = true
let scaleValue = this.scaleValue; let scaleValue = this.scaleValue
if (big) { if (big) {
scaleValue += 0.1; scaleValue += 0.1
if (scaleValue > this.scaleMax) scaleValue = 5; if (scaleValue > this.scaleMax) scaleValue = 5
} else { } else {
scaleValue -= 0.1; scaleValue -= 0.1
if (scaleValue < this.scaleMin) scaleValue = 0.5; if (scaleValue < this.scaleMin) scaleValue = 0.5
} }
if (hiprintTemplate) { if (hiprintTemplate) {
// scaleValue: , false: (), true, // scaleValue: , false: (), true,
hiprintTemplate.zoom(scaleValue); hiprintTemplate.zoom(scaleValue)
this.scaleValue = scaleValue; this.scaleValue = scaleValue
} }
}, },
clearPaper() { clearPaper() {
MessageBox.confirm('是否确认清空模板信息?', '警告', { MessageBox.confirm('是否确认清空模板信息?', '警告', {
confirmButtonText: '确定', confirmButtonText: '确定',
cancelButtonText: '取消', cancelButtonText: '取消',
type: 'warning', type: 'warning'
}) }).then(() => {
.then(() => {
try { try {
hiprintTemplate.clear(); hiprintTemplate.clear()
} catch (error) { } catch (error) {
this.$message.error(`操作失败: ${error}`); this.$message.error(`操作失败: ${error}`)
} }
}).catch((err) => {
console.log(err)
}) })
.catch((err) => {
console.log(err);
});
}, },
otherPaper() { otherPaper() {
const value = {}; const value = {}
value.width = this.paperWidth; value.width = this.paperWidth
value.height = this.paperHeight; value.height = this.paperHeight
this.paperPopVisible = false; this.paperPopVisible = false
this.setPaper('other', value); this.setPaper('other', value)
}, },
rotatePaper() { rotatePaper() {
if (hiprintTemplate) { if (hiprintTemplate) {
hiprintTemplate.rotatePaper(); hiprintTemplate.rotatePaper()
} }
}, },
preView() { preView() {
const { width } = this.curPaper; const { width } = this.curPaper
this.$refs.preView.show(hiprintTemplate, this.printData, width); this.$refs.preView.show(hiprintTemplate, this.printData, width)
}, },
print() { print() {
// if (window.hiwebSocket.opened) { // if (window.hiwebSocket.opened) {
const printerList = hiprintTemplate.getPrinterList(); const printerList = hiprintTemplate.getPrinterList()
console.log(printerList); console.log(printerList)
hiprintTemplate.print2(this.printData, { hiprintTemplate.print2(this.printData, { printer: '', title: '预览打印' })
printer: '',
title: '预览打印',
});
// return // return
// } // }
// this.$message.error(',') // this.$message.error(',')
}, },
save() { save() {
// console.log(hiprintTemplate.getJson()) // console.log(hiprintTemplate.getJson())
const { mode } = this; const { mode } = this
const provider = providers[mode]; const provider = providers[mode]
// console.log(hiprintTemplate.getJson()) // console.log(hiprintTemplate.getJson())
this.setTemplate({ this.setTemplate({
name: provider.value, name: provider.value,
json: hiprintTemplate.getJson(), json: hiprintTemplate.getJson()
}); })
}, },
setTemplate(payload) { setTemplate(payload) {
// const templates = this.$ls.get('KEY_TEMPLATES', {}) // const templates = this.$ls.get('KEY_TEMPLATES', {})
// console.log(payload.json) // console.log(payload.json)
// templates[payload.name] = payload.json // templates[payload.name] = payload.json
// this.$ls.set('KEY_TEMPLATES', templates) // this.$ls.set('KEY_TEMPLATES', templates)
this.$message.info('保存成功'); this.$message.info('保存成功')
// console.log(JSON.stringify(payload.json)) // console.log(JSON.stringify(payload.json))
this.drawer = false; this.drawer = false
this.$emit('saveData', payload.json); this.$emit('saveData', payload.json)
$('.hiprintEpContainer').empty(); $('.hiprintEpContainer').empty()
// this.$parent.$parent.getModelData(payload.json) // this.$parent.$parent.getModelData(payload.json)
}, }
}, }
}; }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
@ -495,4 +413,5 @@ export default {
overflow-x: auto; overflow-x: auto;
overflow-y: auto; overflow-y: auto;
} }
</style> </style>

View File

@ -1,45 +0,0 @@
<template>
<div class="tableInner">
<el-input
v-if="list.isEdit"
type="number"
v-model="list[itemProp]"
@blur="changeInput" />
<span v-else>{{ list[itemProp] }}</span>
</div>
</template>
<script>
export default {
name: 'InputArea',
props: {
injectData: {
type: Object,
default: () => ({}),
},
itemProp: {
type: String,
},
},
data() {
return {
list: {},
};
},
mounted() {
this.initData();
},
watch: {
injectData() {
this.initData();
},
},
methods: {
initData() {
this.list = this.injectData;
},
changeInput() {
this.$emit('emitData', this.list);
},
},
};
</script>

View File

@ -1,226 +0,0 @@
<template>
<div class="other-msg-box">
<el-radio-group
v-model="chooseMsg"
@change="changeChoose">
<el-radio :label="1">
<div style="display: inline-block">
<el-form
:inline="true"
:model="printMsg1"
class="demo-form-inline">
<el-form-item label="客户">
<el-select
size="small"
v-model="printMsg1.customerId"
filterable
placeholder="客户">
<el-option
v-for="item in customerList"
:key="item.id"
:label="item.name"
:value="item.id"></el-option>
</el-select>
</el-form-item>
<el-form-item label="封箱人员工号">
<el-input
v-model="printMsg1.sealWorker"
size="small"
placeholder="封箱人员工号"></el-input>
</el-form-item>
<el-form-item label="打包人员工号">
<el-input
v-model="printMsg1.packWorker"
size="small"
placeholder="打包人员工号"></el-input>
</el-form-item>
<el-form-item label="流程卡号">
<el-input
v-model="printMsg1.processCard"
size="small"
style="width: 120px"
placeholder="流程卡号"></el-input>
</el-form-item>
<el-form-item label="托盘规格">
<el-input
v-model="printMsg1.pallet"
size="small"
style="width: 120px"
placeholder="托盘规格"></el-input>
</el-form-item>
<el-form-item label="备注">
<el-input
v-model="printMsg1.remark"
size="small"
placeholder="备注"></el-input>
</el-form-item>
</el-form>
</div>
</el-radio>
<el-radio :label="2">
<div style="display: inline-block">
<el-form
:inline="true"
:model="printMsg2"
class="demo-form-inline">
<el-form-item label="客户">
<el-select
size="small"
v-model="printMsg2.customerId"
filterable
placeholder="客户">
<el-option
v-for="item in customerList"
:key="item.id"
:label="item.name"
:value="item.id"></el-option>
</el-select>
</el-form-item>
<el-form-item label="封箱人员工号">
<el-input
v-model="printMsg2.sealWorker"
size="small"
placeholder="封箱人员工号"></el-input>
</el-form-item>
<el-form-item label="打包人员工号">
<el-input
v-model="printMsg2.packWorker"
size="small"
placeholder="打包人员工号"></el-input>
</el-form-item>
<el-form-item label="流程卡号">
<el-input
v-model="printMsg2.processCard"
size="small"
style="width: 120px"
placeholder="流程卡号"></el-input>
</el-form-item>
<el-form-item label="托盘规格">
<el-input
v-model="printMsg2.pallet"
size="small"
style="width: 120px"
placeholder="托盘规格"></el-input>
</el-form-item>
<el-form-item label="备注">
<el-input
v-model="printMsg2.remark"
size="small"
placeholder="备注"></el-input>
</el-form-item>
</el-form>
</div>
</el-radio>
<el-radio :label="3">
<div style="display: inline-block">
<el-form
:inline="true"
:model="printMsg3"
class="demo-form-inline">
<el-form-item label="客户">
<el-select
size="small"
v-model="printMsg3.customerId"
filterable
placeholder="客户">
<el-option
v-for="item in customerList"
:key="item.id"
:label="item.name"
:value="item.id"></el-option>
</el-select>
</el-form-item>
<el-form-item label="封箱人员工号">
<el-input
v-model="printMsg3.sealWorker"
size="small"
placeholder="封箱人员工号"></el-input>
</el-form-item>
<el-form-item label="打包人员工号">
<el-input
v-model="printMsg3.packWorker"
size="small"
placeholder="打包人员工号"></el-input>
</el-form-item>
<el-form-item label="流程卡号">
<el-input
v-model="printMsg3.processCard"
size="small"
style="width: 120px"
placeholder="流程卡号"></el-input>
</el-form-item>
<el-form-item label="托盘规格">
<el-input
v-model="printMsg3.pallet"
size="small"
style="width: 120px"
placeholder="托盘规格"></el-input>
</el-form-item>
<el-form-item label="备注">
<el-input
v-model="printMsg3.remark"
size="small"
placeholder="备注"></el-input>
</el-form-item>
</el-form>
</div>
</el-radio>
</el-radio-group>
</div>
</template>
<script>
import { getCustomerList } from '@/api/base/packingInfo';
export default {
name: 'OtherMsg',
props: {
printMsg1: {
type: Object,
default: () => ({}),
},
printMsg2: {
type: Object,
default: () => ({}),
},
printMsg3: {
type: Object,
default: () => ({}),
},
},
data() {
return {
chooseMsg: 1,
customerList: [],
};
},
mounted() {
this.getCList();
},
methods: {
getCList() {
getCustomerList().then((res) => {
console.log(res);
console.log('customer');
this.customerList = res.data;
});
},
changeChoose(val) {
this.$emit('changeChoose', val);
},
},
};
</script>
<style lang="scss" scoped>
.other-msg-box {
.el-radio {
display: block;
line-height: 36px;
.demo-form-inline {
width: 100%;
white-space: normal;
}
.el-form-item {
margin-bottom: 0px;
}
}
}
</style>

View File

@ -1,182 +0,0 @@
<template>
<div class="show-box">
<!-- 搜索工作栏 -->
<search-bar
:formConfigs="formConfig"
ref="searchBarForm"
@headBtnClick="buttonClick2" />
<!-- 列表 -->
<base-table
:page="queryParams2.pageNo"
:limit="queryParams2.pageSize"
:table-props="tableProps"
:table-data="list2">
<method-btn
v-if="tableBtn2.length"
slot="handleBtn"
:width="240"
label="操作"
:method-list="tableBtn2"
@clickBtn="handleClick2" />
</base-table>
<pagination
:page.sync="queryParams2.pageNo"
:limit.sync="queryParams2.pageSize"
:total="total2"
@pagination="getList2" />
</div>
</template>
<script>
import { parseTime } from '@/utils/ruoyi';
import { getPackingPage } from '@/api/base/packingInfo';
import { getCorePLList } from '@/api/base/coreProductionLine';
const tableProps = [
{
prop: 'packagingCode',
label: '成品周转编号',
minWidth: 180,
showOverflowtooltip: true,
},
{
prop: 'lineId',
label: '产线',
showOverflowtooltip: true,
},
{
prop: 'specifications',
label: '规格',
showOverflowtooltip: true,
},
{
prop: 'check',
label: '判定',
showOverflowtooltip: true,
},
{
prop: 'workStation',
label: '工位号',
showOverflowtooltip: true,
},
{
prop: 'num',
label: '片数',
},
{
prop: 'remark',
label: '备注1',
showOverflowtooltip: true,
},
{
prop: 'printStatus',
label: '打印状态',
filter: (val) => (val == 1 ? '未打印' : '已打印'),
},
{
prop: 'createTime',
label: '时间',
filter: parseTime,
minWidth: 160,
showOverflowtooltip: true,
},
{
prop: 'groupClass',
label: '班次',
showOverflowtooltip: true,
},
];
export default {
name: 'Printed',
data() {
return {
formConfig: [
{
type: 'select',
label: '产线',
selectOptions: [],
param: 'lineId',
filterable: true,
},
{
type: 'datePicker',
label: '时间段',
dateType: 'daterange',
format: 'yyyy-MM-dd HH:mm:ss',
valueFormat: 'yyyy-MM-dd HH:mm:ss',
rangeSeparator: '-',
startPlaceholder: '开始时间',
endPlaceholder: '结束时间',
param: 'timeVal',
defaultSelect: [],
width: 350,
},
{
type: 'button',
btnName: '查询',
name: 'search',
color: 'primary',
},
],
//
queryParams2: {
pageNo: 1,
pageSize: 20,
printStatus: '2',
lineId: '',
createTime: [],
},
total2: 0,
tableProps,
list2: [],
tableBtn2: [
this.$auth.hasPermi('base:order-group:update')
? {
type: 'reprint',
btnName: '重打',
}
: undefined,
this.$auth.hasPermi('base:order-group:query')
? {
type: 'detail',
btnName: '详情',
}
: undefined,
this.$auth.hasPermiAnd([
'base:order-group:update',
'base:core-product:query',
'base:core-customer:query',
])
? {
type: 'edit',
btnName: '编辑',
}
: undefined,
].filter((v) => v),
};
},
mounted() {
this.getLineList();
},
methods: {
getLineList() {
getCorePLList().then((res) => {
console.log(res);
this.formConfig[0].selectOptions = res.data;
});
},
getList2() {
getPackingPage({ ...this.queryParams2 }).then((res) => {
console.log(res);
this.list2 = res.data.records || [];
this.total2 = res.data.total;
});
},
buttonClick2(val) {
console.log(val);
this.queryParams2.lineId = val.lineId;
this.queryParams2.createTime = val.timeVal;
this.getList2();
},
handleClick2() {},
},
};
</script>

View File

@ -1,332 +0,0 @@
<template>
<div class="show-box">
<!-- 单选 -->
<other-msg
:printMsg1="printMsg1"
:printMsg2="printMsg2"
:printMsg3="printMsg3"
@changeChoose="changeChoose" />
<!-- 搜索工作栏 -->
<search-bar
:formConfigs="formConfig"
ref="searchBarForm"
@headBtnClick="buttonClick" />
<!-- 列表 -->
<base-table
:page="queryParams.pageNo"
:limit="queryParams.pageSize"
:table-props="tableProps"
:table-data="list"
@emitFun="inputChange">
<method-btn
v-if="tableBtn.length"
slot="handleBtn"
:width="260"
label="操作"
:method-list="tableBtn"
@clickBtn="handleClick" />
</base-table>
<pagination
:page.sync="queryParams.pageNo"
:limit.sync="queryParams.pageSize"
:total="total"
@pagination="getList" />
<!-- 预览 -->
<print-preview ref="preView" />
</div>
</template>
<script>
import { parseTime } from '@/utils/ruoyi';
import inputArea from './InputArea.vue';
const tableProps = [
{
prop: 'packagingCode',
label: '成品周转编号',
minWidth: 160,
showOverflowtooltip: true,
},
{
prop: 'lineId',
label: '产线',
showOverflowtooltip: true,
},
{
prop: 'specifications',
label: '规格',
showOverflowtooltip: true,
},
{
prop: 'check',
label: '判定',
showOverflowtooltip: true,
},
{
prop: 'workStation',
label: '工位号',
showOverflowtooltip: true,
},
{
prop: 'num',
label: '片数',
subcomponent: inputArea,
minWidth: 120,
},
{
prop: 'remark',
label: '备注1',
showOverflowtooltip: true,
},
{
prop: 'printStatus',
label: '打印状态',
filter: (val) => (val == 1 ? '未打印' : '已打印'),
},
{
prop: 'createTime',
label: '时间',
filter: parseTime,
minWidth: 160,
showOverflowtooltip: true,
},
{
prop: 'groupClass',
label: '班次',
showOverflowtooltip: true,
},
];
import OtherMsg from './OtherMsg';
import { getPackingPage, updatePacking } from '@/api/base/packingInfo';
import { getCorePLList } from '@/api/base/coreProductionLine';
import printPreview from './preview';
import printTemplate from '../print-template';
export default {
name: 'UnPrint',
components: { OtherMsg, printPreview },
data() {
return {
printMsg1: {
customerId: '',
sealWorker: '',
packWorker: '',
processCard: '',
pallet: '',
remark: '',
},
printMsg2: {
customerId: '',
sealWorker: '',
packWorker: '',
processCard: '',
pallet: '',
remark: '',
},
printMsg3: {
customerId: '',
sealWorker: '',
packWorker: '',
processCard: '',
pallet: '',
remark: '',
},
chooseMsg: 1, //
formConfig: [
{
type: 'select',
label: '产线',
selectOptions: [],
param: 'lineId',
filterable: true,
},
{
type: 'datePicker',
label: '时间段',
dateType: 'daterange',
format: 'yyyy-MM-dd HH:mm:ss',
valueFormat: 'yyyy-MM-dd HH:mm:ss',
rangeSeparator: '-',
startPlaceholder: '开始时间',
endPlaceholder: '结束时间',
param: 'timeVal',
defaultSelect: [],
width: 350,
},
{
type: 'button',
btnName: '查询',
name: 'search',
color: 'primary',
},
],
//
queryParams: {
pageNo: 1,
pageSize: 20,
printStatus: '1',
lineId: '',
createTime: [],
},
total: 0,
tableProps,
list: [],
tableBtn: [
this.$auth.hasPermiAnd([
'base:order:query',
'base:order-con-group-order:create',
])
? {
type: 'view',
btnName: '预览',
}
: undefined,
this.$auth.hasPermi('base:order-group:update')
? {
type: 'print',
btnName: '打印',
}
: undefined,
this.$auth.hasPermi('base:order-group:update')
? {
type: 'printed',
btnName: '已打印',
}
: undefined,
this.$auth.hasPermiAnd([
'base:order-group:update',
'base:core-product:query',
'base:core-customer:query',
])
? {
type: 'edit',
btnName: '编辑',
showParam: {
type: '&',
data: [
{
type: 'unequal',
name: 'isEdit',
value: true,
},
],
},
}
: undefined,
this.$auth.hasPermiAnd([
'base:order-group:update',
'base:core-product:query',
'base:core-customer:query',
])
? {
type: 'save',
btnName: '保存',
showParam: {
type: '&',
data: [
{
type: 'equal',
name: 'isEdit',
value: true,
},
],
},
}
: undefined,
this.$auth.hasPermi('base:order-group:query')
? {
type: 'delete',
btnName: '删除',
}
: undefined,
].filter((v) => v),
printData: {},
};
},
mounted() {
this.getLineList();
console.log(printTemplate);
console.log('================printTemplate');
},
methods: {
getLineList() {
getCorePLList().then((res) => {
this.formConfig[0].selectOptions = res.data;
});
},
getList() {
getPackingPage({ ...this.queryParams }).then((res) => {
this.list = res.data.records || [];
this.total = res.data.total;
});
},
//
changeChoose(val) {
this.chooseMsg = val;
},
buttonClick(val) {
this.queryParams.lineId = val.lineId;
this.queryParams.createTime = val.timeVal;
this.getList();
},
handleClick(val) {
console.log(val);
switch (val.type) {
case 'edit':
this.editNum(val.data);
break;
case 'save':
this.saveNum(val.data);
break;
case 'view':
this.preView();
break;
case 'print':
this.printTemp();
break;
default:
}
},
//
editNum(val) {
let obj = this.list[val._pageIndex - 1];
obj.isEdit = true;
this.$set(this.list, val._pageIndex - 1, obj);
},
//
saveNum(val) {
//
updatePacking({ id: val.id, num: val.num }).then(() => {
this.getList();
});
},
// num
inputChange(val) {
this.list[val._pageIndex - 1][val.prop] = val[val.prop];
},
//
preView() {
var hiprintTemplate = new hiprint.PrintTemplate({
template: printTemplate,
});
this.$refs.preView.show(hiprintTemplate);
},
//
printTemp() {
console.log('11');
var printData = {};
let hiprintTemplate = this.$print(
undefined,
printTemplate,
printData,
{},
{
styleHandler: () => {
let css =
'<link href="http://hiprint.io/Content/hiprint/css/print-lock.css" media="print" rel="stylesheet">';
return css;
},
}
);
console.log(hiprintTemplate);
},
},
};
</script>

View File

@ -1,69 +0,0 @@
<template>
<el-form
ref="unPrintEdit"
:rules="rules"
label-width="130px"
:model="form">
<el-row :gutter="20">
<el-col :span="24">
<el-form-item
label="成品周转编号"
prop="packagingCode">
<el-input
readonly
v-model="form.packagingCode"></el-input>
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item
label="片数"
prop="num">
<el-input-number
v-model="form.num"
:min="0"
:max="999999"
style="width: 100%"
label="片数"></el-input-number>
</el-form-item>
</el-col>
</el-row>
</el-form>
</template>
<script>
import { getPacking } from '@/api/base/packingInfo';
export default {
name: 'UnPrintEdit',
data() {
return {
form: {
id: '',
packagingCode: '',
num: null,
},
rules: {
num: [{ required: true, message: '片数不能为空', trigger: 'blur' }],
},
};
},
methods: {
init(id) {
console.log('init');
this.form.id = id;
getPacking(id).then((res) => {
console.log(res);
});
},
submitForm() {
this.$refs['unPrintEdit'].validate((valid) => {
if (valid) {
console.log('保存');
this.$emit('successSubmit');
}
});
},
formClear() {
this.$refs.unPrintEdit.resetFields();
},
},
};
</script>

View File

@ -1,100 +0,0 @@
<template>
<base-dialog
dialogTitle="预览"
:dialogVisible="visible"
width="50%"
@cancel="hideModal"
:before-close="hideModal">
<!-- <div>
<el-button
:loading="waitShowPrinter"
type="primary"
icon="printer"
@click.stop="print">
打印
</el-button>
<el-button
type="primary"
icon="printer"
@click.stop="toPdf">
pdf
</el-button>
</div> -->
<div id="preview_content" />
<template slot="footer">
<el-button
key="close"
@click="hideModal">
关闭
</el-button>
</template>
</base-dialog>
</template>
<script>
export default {
name: 'PrintPreview',
props: {},
data() {
return {
visible: false,
spinning: true,
waitShowPrinter: false,
// mm
width: 0,
//
hiprintTemplate: {},
//
printData: {},
};
},
computed: {},
watch: {},
created() {},
mounted() {},
methods: {
hideModal() {
this.visible = false;
},
show(hiprintTemplate, printData, width = '210') {
this.visible = true;
this.spinning = true;
this.width = width;
this.hiprintTemplate = hiprintTemplate;
this.printData = printData;
console.log(hiprintTemplate);
console.log(printData);
setTimeout(() => {
// eslint-disable-next-line no-undef
$('#preview_content').html(hiprintTemplate.getHtml(printData));
this.spinning = false;
}, 500);
},
print() {
this.waitShowPrinter = true;
this.hiprintTemplate.print(
this.printData,
{},
{
callback: () => {
console.log('callback');
this.waitShowPrinter = false;
},
}
);
},
toPdf() {
this.hiprintTemplate.toPdf({}, '打印预览');
},
},
};
</script>
<!-- <style lang="less" scoped>
/deep/ .ant-modal-body {
padding: 0px;
}
/deep/ .ant-modal-content {
margin-bottom: 24px;
}
</style> -->

View File

@ -1,47 +0,0 @@
<template>
<div class="packagingPrintLog-box">
<div style="width: 100%">
<ButtonNav
:menus="['未打印', '已打印']"
:button-mode="true"
@change="currentMenu"></ButtonNav>
</div>
<!-- 未打印 -->
<UnPrint v-if="activeMenu == '未打印'" />
<!-- 已打印 -->
<Printed v-else />
</div>
</template>
<script>
import ButtonNav from '@/components/ButtonNav';
import UnPrint from './components/UnPrint';
import Printed from './components/Printed';
export default {
name: 'packagingPrintLog',
components: { ButtonNav, UnPrint, Printed },
data() {
return {
activeMenu: '未打印',
};
},
methods: {
currentMenu(val) {
console.log(val);
this.activeMenu = val;
},
},
};
</script>
<style lang="scss" scoped>
.packagingPrintLog-box {
min-height: calc(100vh - 120px - 8px);
background-color: #f2f4f9;
.show-box {
min-height: calc(100vh - 128px - 52px);
margin-top: 8px;
padding: 16px;
border-radius: 8px;
background-color: #fff;
}
}
</style>

View File

@ -1,554 +0,0 @@
export default {
panels: [
{
index: 0,
name: 1,
height: 125,
width: 95,
paperHeader: 0,
paperFooter: 354.33070866141736,
printElements: [
{
options: {
left: 5,
top: 5,
height: 30,
width: 256.5,
right: 262.2421875,
bottom: 34.9921875,
vCenter: 133.9921875,
hCenter: 19.9921875,
coordinateSync: false,
widthHeightSync: false,
borderColor: 'green',
backgroundColor: 'green',
},
printElementType: { title: '矩形', type: 'rect' },
},
{
options: {
left: 35,
top: 15,
height: 20,
width: 195,
title: '厂内镀膜/钢化片周转标签',
coordinateSync: false,
widthHeightSync: false,
fontSize: 16.5,
color: '#ffffff',
qrCodeLevel: 0,
right: 232.9921875,
bottom: 35.24609375,
vCenter: 135.4921875,
hCenter: 25.24609375,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: { left: 50, top: 35, height: 52.5, width: 9 },
printElementType: { title: '竖线', type: 'vline' },
},
{
options: {
left: 5,
top: 35,
height: 309,
width: 256.5,
right: 261.4921875,
bottom: 343.9921875,
vCenter: 133.2421875,
hCenter: 189.4921875,
},
printElementType: { title: '矩形', type: 'rect' },
},
{
options: {
left: 10,
top: 42.5,
height: 18,
width: 36,
title: '线别',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 45.99609375,
bottom: 60.4921875,
vCenter: 27.99609375,
hCenter: 51.4921875,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 55,
top: 42.5,
height: 18,
width: 200,
title: '判定:良品/保留/再检',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 93.4921875,
bottom: 59.25,
vCenter: 75.4921875,
hCenter: 50.25,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 5,
top: 62.5,
height: 9,
width: 256.5,
right: 259.9921875,
bottom: 72.4921875,
vCenter: 132.4921875,
hCenter: 67.9921875,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 55,
top: 70,
height: 18,
width: 46,
title: '备注:',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 91.2421875,
bottom: 86.25,
vCenter: 73.2421875,
hCenter: 77.25,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 190,
top: 87.5,
height: 169.5,
width: 9,
right: 199.74609375,
bottom: 255.75,
vCenter: 195.24609375,
hCenter: 171,
},
printElementType: { title: '竖线', type: 'vline' },
},
{
options: {
left: 5,
top: 87.5,
height: 9,
width: 256.5,
right: 260.7421875,
bottom: 96.75,
vCenter: 132.4921875,
hCenter: 92.25,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 77.5,
top: 90,
height: 15,
width: 36,
title: '规格',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 113.49609375,
bottom: 105.4921875,
vCenter: 95.49609375,
hCenter: 97.9921875,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 207.5,
top: 100,
height: 18,
width: 36,
title: '用户',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 242.7421875,
bottom: 116.25,
vCenter: 224.7421875,
hCenter: 107.25,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 25,
top: 102.5,
height: 15,
width: 156,
title: '长*宽*厚度单位mm',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 179.25,
bottom: 117.4921875,
vCenter: 101.25,
hCenter: 109.9921875,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 5,
top: 117.5,
height: 9,
width: 256.5,
right: 263.7421875,
bottom: 125.7421875,
vCenter: 135.4921875,
hCenter: 121.2421875,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 130,
top: 145,
height: 55.5,
width: 9,
right: 138.99609375,
bottom: 199.5,
vCenter: 134.49609375,
hCenter: 171.75,
},
printElementType: { title: '竖线', type: 'vline' },
},
{
options: {
left: 5,
top: 145,
height: 9,
width: 256.5,
right: 260.25,
bottom: 154.2421875,
vCenter: 132,
hCenter: 149.7421875,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 45,
top: 155,
height: 18,
width: 36,
title: '编号',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 82.2421875,
bottom: 171.75,
vCenter: 64.2421875,
hCenter: 162.75,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 135,
top: 155,
height: 18,
width: 49.5,
title: '工位号',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 186,
bottom: 172.9921875,
vCenter: 161.25,
hCenter: 163.9921875,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 197.5,
top: 155,
height: 18,
width: 60,
title: '流程卡号',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 256.74609375,
bottom: 143.7421875,
vCenter: 226.74609375,
hCenter: 134.7421875,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 5,
top: 175,
height: 9,
width: 256.5,
right: 259.2421875,
bottom: 183.75,
vCenter: 130.9921875,
hCenter: 179.25,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 50,
top: 200,
height: 58.5,
width: 9,
right: 58.9921875,
bottom: 259.5,
vCenter: 54.4921875,
hCenter: 230.25,
},
printElementType: { title: '竖线', type: 'vline' },
},
{
options: {
left: 110,
top: 200,
height: 58.5,
width: 9,
right: 117.75,
bottom: 256.9921875,
vCenter: 113.25,
hCenter: 227.7421875,
},
printElementType: { title: '竖线', type: 'vline' },
},
{
options: {
left: 5,
top: 200,
height: 9,
width: 256.5,
right: 262.9921875,
bottom: 210.24609375,
vCenter: 134.7421875,
hCenter: 205.74609375,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 10,
top: 210,
height: 18,
width: 36,
title: '日期',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 45.99609375,
bottom: 228,
vCenter: 27.99609375,
hCenter: 219,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 67.5,
top: 210,
height: 18,
width: 36,
title: '班次',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 103.5,
bottom: 228,
vCenter: 85.5,
hCenter: 219,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 207.5,
top: 210,
height: 18,
width: 36,
title: '片数',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 243.4921875,
bottom: 228,
vCenter: 225.4921875,
hCenter: 219,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 5,
top: 230,
height: 9,
width: 256.5,
right: 261.4921875,
bottom: 239.25,
vCenter: 133.2421875,
hCenter: 234.75,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 5,
top: 257.5,
height: 9,
width: 256.5,
right: 261.4921875,
bottom: 266.49609375,
vCenter: 133.2421875,
hCenter: 261.99609375,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 10,
top: 262.5,
height: 18,
width: 87,
title: '封箱人员工号:',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 46.9921875,
bottom: 279.24609375,
vCenter: 28.9921875,
hCenter: 270.24609375,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 5,
top: 280,
height: 9,
width: 256.5,
right: 262.2421875,
bottom: 289.2421875,
vCenter: 133.9921875,
hCenter: 284.7421875,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 10,
top: 285,
height: 18,
width: 87,
title: '打包人员工号:',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 96.4921875,
bottom: 301.74609375,
vCenter: 52.9921875,
hCenter: 292.74609375,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 5,
top: 300,
height: 9,
width: 256.5,
right: 264.4921875,
bottom: 308.49609375,
vCenter: 136.2421875,
hCenter: 303.99609375,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 10,
top: 305,
height: 18,
width: 247.5,
title: '备注1单层镀/双层镀/丝印打孔/打孔钢片',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 96.99609375,
bottom: 322.9921875,
vCenter: 53.49609375,
hCenter: 313.9921875,
},
printElementType: { title: '文本', type: 'text' },
},
{
options: {
left: 5,
top: 322.5,
height: 9,
width: 256.5,
right: 262.2421875,
bottom: 332.7421875,
vCenter: 133.9921875,
hCenter: 328.2421875,
},
printElementType: { title: '横线', type: 'hline' },
},
{
options: {
left: 10,
top: 327.5,
height: 18,
width: 87,
title: '备注2',
coordinateSync: false,
widthHeightSync: false,
fontSize: 12,
qrCodeLevel: 0,
right: 97.9921875,
bottom: 343.74609375,
vCenter: 54.4921875,
hCenter: 334.74609375,
},
printElementType: { title: '文本', type: 'text' },
},
],
paperNumberLeft: 372.5,
paperNumberTop: 337.5,
paperNumberContinue: true,
watermarkOptions: {},
},
]
}

View File

@ -6,130 +6,138 @@
* @Description: * @Description:
--> -->
<template> <template>
<el-dialog <el-dialog class="baseDialog" :visible.sync="visible" :show-close="false" :wrapper-closable="false" width="30%" show-close="true">
class="baseDialog" <small-title slot="title" :no-padding="true">
:visible.sync="visible"
:show-close="true"
:wrapper-closable="false"
width="50%">
<small-title
slot="title"
:no-padding="true">
{{ !dataForm.id ? '新增' : '编辑' }} {{ !dataForm.id ? '新增' : '编辑' }}
</small-title> </small-title>
<div class="content"> <div class="content">
<div class="visual-part"> <div class="visual-part">
<el-form <el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="100px"
ref="dataForm"
:model="dataForm"
:rules="dataRule"
label-width="100px"
@keyup.enter.native="dataFormSubmit"> @keyup.enter.native="dataFormSubmit">
<el-row :gutter="20"> <el-row :gutter="20">
<el-col :span="24"> <el-col :span="12">
<el-form-item <el-form-item label="模板名称" prop="name">
label="模板名称" <el-input v-model="dataForm.name" clearable placeholder="请输入模板名称" />
prop="name">
<el-input
v-model="dataForm.name"
clearable
placeholder="请输入模板名称" />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="12">
<el-form-item <el-form-item label="标签类型" prop="typeId">
label="标签类型" <el-select v-model="dataForm.typeId" style="width: 100%;" placeholder="请选择标签类型" clearable>
prop="typeId"> <el-option v-for="dict in typeList" :key="dict.id" :label="dict.name" :value="dict.id" />
<el-select
v-model="dataForm.typeId"
style="width: 100%"
placeholder="请选择标签类型"
clearable>
<el-option
v-for="dict in typeList"
:key="dict.id"
:label="dict.name"
:value="dict.id" />
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<el-row :gutter="20"> <el-row :gutter="20">
<el-col :span="24"> <el-col :span="12">
<el-form-item <el-form-item label="打印方式" prop="printModel">
label="打印方式" <el-select v-model="dataForm.printModel" style="width: 100%;" placeholder="请选择打印方式" clearable>
prop="printModel"> <el-option v-for="dict in printModelList" :key="dict.id" :label="dict.name" :value="dict.id" />
<el-select
v-model="dataForm.printModel"
style="width: 100%"
placeholder="请选择打印方式"
clearable>
<el-option
v-for="dict in printModelList"
:key="dict.id"
:label="dict.name"
:value="dict.id" />
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="12">
<el-form-item <el-form-item label="标签备注" prop="remark">
label="标签备注" <el-input v-model="dataForm.remark" clearable placeholder="请输入标签备注" />
prop="remark">
<el-input
v-model="dataForm.remark"
clearable
placeholder="请输入标签备注" />
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<el-row :gutter="20"> <el-row :gutter="20">
<el-col :span="24"> <el-col :span="12">
<el-form-item <el-form-item label="模板设计" prop="content">
label="模板设计" <el-button icon="el-icon-edit" @click="btnClickDesign()">模板设计</el-button>
prop="content">
<el-button
icon="el-icon-edit"
@click="btnClickDesign()">
模板设计
</el-button>
</el-form-item> </el-form-item>
</el-col> </el-col>
<!-- <el-col :span="12">
<el-form-item label="单位平方数" prop="area">
<el-input v-model="dataForm.area" placeholder="请输入单位平方数" />
</el-form-item>
</el-col> -->
</el-row> </el-row>
<!-- <el-row :gutter="20">
<el-col :span="24">
<el-form-item label="完成单位产品用时" prop="processTime">
<el-input v-model="dataForm.processTime" placeholder="请输入完成单位产品用时" />
</el-form-item>
</el-col>
</el-row> -->
</el-form> </el-form>
<!-- <small-title
style="margin: 16px 0; padding-left: 8px"
:no-padding="true">
产品属性列表
</small-title>
<div class="attr-list">
<base-table
:table-props="tableProps"
:page="listQuery.pageNo"
:limit="listQuery.pageSize"
:add-button-show="isdetail ? null : '添加属性'"
@emitButtonClick="addNew()"
:table-data="productAttributeList">
<method-btn
v-if="!isdetail"
slot="handleBtn"
:width="120"
label="操作"
:method-list="tableBtn"
@clickBtn="handleClick" />
</base-table>
<pagination
v-show="listQuery.total > 0"
:total="listQuery.total"
:page.sync="listQuery.pageNo"
:limit.sync="listQuery.pageSize"
:page-sizes="[5, 10, 15]"
@pagination="getList" />
</div> -->
</div> </div>
</div> </div>
<template slot="footer">
<el-button <!-- <div style="position: absolute; bottom: 24px; right: 24px">
style="" <el-button style="margin-right: 10px" @click="goback()">返回</el-button>
@click="goback()"> <el-button v-if="isdetail" type="primary" @click="goEdit()">
取消 编辑
</el-button> </el-button>
<span v-if="!isdetail">
<el-button type="primary" @click="dataFormSubmit()">保存</el-button>
<el-button <el-button
v-if="dataForm.id && !isdetail"
type="primary" type="primary"
@click="dataFormSubmit()"> @click="addNew()">
确定 添加属性
</el-button> </el-button>
</span>
</div> -->
<template slot="footer">
<el-button style="" @click="goback()">取消</el-button>
<!-- <el-button v-if="isdetail" type="primary" @click="goEdit()">
编辑
</el-button> -->
<el-button type="primary" @click="dataFormSubmit()">确定</el-button>
</template> </template>
<print-model-design <print-model-design v-if="modelShow" ref="printModelDesign" @saveData="getModelData" />
v-if="modelShow"
ref="printModelDesign"
@saveData="getModelData" />
</el-dialog> </el-dialog>
</template> </template>
<script> <script>
import { import {
createPackingModel, createPackingModel,
updatePackingModel, updatePackingModel,
getPackingModel, getPackingModel,
getTypeList, // getWorkOrderList,
// getCode,
// getCustomerList,
getTypeList
} from '@/api/base/printModel.js'; } from '@/api/base/printModel.js';
// import productAttrAdd from './attr-add'; // import productAttrAdd from './attr-add';
import { parseTime } from '../mixins/code-filter'; import { parseTime } from '../mixins/code-filter';
import SmallTitle from './SmallTitle'; import SmallTitle from './SmallTitle';
import printModelDesign from '../custom/index'; import printModelDesign from '../custom/index'
const tableBtn = [ const tableBtn = [
{ {
@ -180,11 +188,11 @@ export default {
printModelList: [ printModelList: [
{ {
id: 1, id: 1,
name: '自动', name:'自动'
}, },
{ {
id: 2, id: 2,
name: '手动', name: '手动'
}, },
], ],
listQuery: { listQuery: {
@ -246,17 +254,17 @@ export default {
}, },
methods: { methods: {
getModelData(data) { getModelData(data) {
console.log(data); console.log(data)
this.content = JSON.stringify(data); this.content = JSON.stringify(data)
this.dataForm.content = JSON.stringify(data); this.dataForm.content = JSON.stringify(data)
}, },
btnClickDesign() { btnClickDesign() {
console.log(11111); console.log(11111)
this.modelShow = true; this.modelShow = true
this.$nextTick(() => { this.$nextTick(() => {
this.$refs.printModelDesign.init(this.dataForm.content); this.$refs.printModelDesign.init(this.dataForm.content)
console.log(this.dataForm.content); console.log(this.dataForm.content)
}); })
// this.$router.push({ // this.$router.push({
// path: '/printModelDesign' // path: '/printModelDesign'
// }) // })
@ -266,7 +274,7 @@ export default {
// this.listQuery.total = 0; // this.listQuery.total = 0;
// }, // },
init(id) { init(id) {
this.getDict(); this.getDict()
// this.initData(); // this.initData();
// this.isdetail = isdetail || false; // this.isdetail = isdetail || false;
this.dataForm.id = id || null; this.dataForm.id = id || null;
@ -298,9 +306,9 @@ export default {
// }) // })
getTypeList().then((response) => { getTypeList().then((response) => {
console.log(response); console.log(response);
this.typeList = response.data; this.typeList = response.data
// this.listQuery.total = response.data.total; // this.listQuery.total = response.data.total;
}); })
// getWorkOrderList().then((response) => { // getWorkOrderList().then((response) => {
// // console.log(response); // // console.log(response);
// this.workOrderList = response.data // this.workOrderList = response.data
@ -431,6 +439,8 @@ export default {
} }
</style> --> </style> -->
<style> <style>
.baseDialog .el-dialog__header { .baseDialog .el-dialog__header {
font-size: 16px; font-size: 16px;
color: rgba(0, 0, 0, 0.85); color: rgba(0, 0, 0, 0.85);
@ -443,7 +453,7 @@ export default {
display: inline-block; display: inline-block;
width: 4px; width: 4px;
height: 16px; height: 16px;
background-color: #0b58ff; background-color: #0B58FF;
border-radius: 1px; border-radius: 1px;
margin-right: 8px; margin-right: 8px;
position: relative; position: relative;
@ -458,4 +468,6 @@ export default {
padding: 9px 10px 9px 16px; padding: 9px 10px 9px 16px;
font-size: 14px; font-size: 14px;
} }
</style> </style>

View File

@ -6,72 +6,106 @@
* @Description: * @Description:
--> -->
<template> <template>
<el-dialog <el-dialog class="baseDialog" :visible.sync="visible" :show-close="false" :wrapper-closable="false" width="40%" show-close="true">
class="baseDialog" <small-title slot="title" :no-padding="true">
:visible.sync="visible"
:show-close="true"
:wrapper-closable="false"
width="50%">
<small-title
slot="title"
:no-padding="true">
{{ !dataForm.id ? '新增' : '编辑' }} {{ !dataForm.id ? '新增' : '编辑' }}
</small-title> </small-title>
<div class="content"> <div class="content">
<div class="visual-part"> <div class="visual-part">
<el-form <el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="auto"
ref="dataForm"
:model="dataForm"
:rules="dataRule"
label-width="auto"
@keyup.enter.native="dataFormSubmit"> @keyup.enter.native="dataFormSubmit">
<el-row :gutter="20"> <el-row :gutter="20">
<el-col :span="24"> <el-col :span="12">
<el-form-item <el-form-item label="名称" prop="name">
label="名称" <el-input v-model="dataForm.name" clearable placeholder="名称" />
prop="name">
<el-input
v-model="dataForm.name"
clearable
placeholder="名称" />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="12">
<el-form-item <el-form-item label="类型描述" prop="description">
label="类型描述" <el-input v-model="dataForm.description" clearable placeholder="类型描述" />
prop="description">
<el-input
v-model="dataForm.description"
clearable
placeholder="类型描述" />
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<!-- <el-row :gutter="20">
<el-col :span="24">
<el-form-item label="完成单位产品用时" prop="processTime">
<el-input v-model="dataForm.processTime" placeholder="请输入完成单位产品用时" />
</el-form-item>
</el-col>
</el-row> -->
</el-form> </el-form>
<!-- <small-title
style="margin: 16px 0; padding-left: 8px"
:no-padding="true">
产品属性列表
</small-title>
<div class="attr-list">
<base-table
:table-props="tableProps"
:page="listQuery.pageNo"
:limit="listQuery.pageSize"
:add-button-show="isdetail ? null : '添加属性'"
@emitButtonClick="addNew()"
:table-data="productAttributeList">
<method-btn
v-if="!isdetail"
slot="handleBtn"
:width="120"
label="操作"
:method-list="tableBtn"
@clickBtn="handleClick" />
</base-table>
<pagination
v-show="listQuery.total > 0"
:total="listQuery.total"
:page.sync="listQuery.pageNo"
:limit.sync="listQuery.pageSize"
:page-sizes="[5, 10, 15]"
@pagination="getList" />
</div> -->
</div> </div>
</div> </div>
<template slot="footer">
<el-button <!-- <div style="position: absolute; bottom: 24px; right: 24px">
style="" <el-button style="margin-right: 10px" @click="goback()">返回</el-button>
@click="goback()"> <el-button v-if="isdetail" type="primary" @click="goEdit()">
取消 编辑
</el-button> </el-button>
<span v-if="!isdetail">
<el-button type="primary" @click="dataFormSubmit()">保存</el-button>
<el-button <el-button
v-if="dataForm.id && !isdetail"
type="primary" type="primary"
@click="dataFormSubmit()"> @click="addNew()">
确定 添加属性
</el-button> </el-button>
</span>
</div> -->
<template slot="footer">
<el-button style="" @click="goback()">取消</el-button>
<!-- <el-button v-if="isdetail" type="primary" @click="goEdit()">
编辑
</el-button> -->
<el-button type="primary" @click="dataFormSubmit()">确定</el-button>
</template> </template>
</el-dialog> </el-dialog>
</template> </template>
<script> <script>
import { import {
createPackingType, createPackingType,
updatePackingType, updatePackingType,
getPackingType, getPackingType,
// getWorkOrderList,
// getCode,
// getCustomerList,
// getModelList
} from '@/api/base/modelType.js'; } from '@/api/base/modelType.js';
// import productAttrAdd from './attr-add';
import { parseTime } from '../mixins/code-filter'; import { parseTime } from '../mixins/code-filter';
import SmallTitle from './SmallTitle'; import SmallTitle from './SmallTitle';
@ -115,8 +149,13 @@ export default {
productAttributeList: [], productAttributeList: [],
dataForm: { dataForm: {
id: null, id: null,
// name: '', //
name: '', // name: '', //
// area: 0, // (float only)
description: null, // id description: null, // id
// workOrderId: null, // (s)
// customerId: '', //
// content: '', // id
}, },
listQuery: { listQuery: {
pageSize: 10, pageSize: 10,
@ -132,10 +171,18 @@ export default {
}, },
], ],
}, },
// isdetail: false,
}; };
}, },
methods: { methods: {
// initData() {
// this.productAttributeList.splice(0);
// this.listQuery.total = 0;
// },
init(id) { init(id) {
// this.getDict()
// this.initData();
// this.isdetail = isdetail || false;
this.dataForm.id = id || null; this.dataForm.id = id || null;
this.visible = true; this.visible = true;
@ -147,10 +194,66 @@ export default {
getPackingType(id).then((response) => { getPackingType(id).then((response) => {
this.dataForm = response.data; this.dataForm = response.data;
}); });
//
// this.getList();
} else {
// getCode().then((res) => {
// this.dataForm.packagingCode = res.data;
// });
} }
}); });
}, },
// getDict() {
// //
// getCustomerList().then((response) => {
// console.log(response);
// this.customerList = response.data
// // this.listQuery.total = response.data.total;
// })
// getModelList().then((response) => {
// console.log(response);
// this.modelList = response.data
// // this.listQuery.total = response.data.total;
// })
// getWorkOrderList().then((response) => {
// // console.log(response);
// this.workOrderList = response.data
// // this.listQuery.total = response.data.total;
// })
// },
// handleClick(raw) {
// if (raw.type === 'delete') {
// this.$confirm(
// `${
// raw.data.name
// ? '[=' + raw.data.name + ']'
// : '[=' + raw.data._pageIndex + ']'
// }?`,
// '',
// {
// confirmButtonText: '',
// cancelButtonText: '',
// type: 'warning',
// }
// )
// .then(() => {
// deleteProductAttr(raw.data.id).then(({ data }) => {
// this.$message({
// message: '',
// type: 'success',
// duration: 1500,
// onClose: () => {
// this.getList();
// },
// });
// });
// })
// .catch(() => {});
// } else {
// this.addNew(raw.data.id);
// }
// },
// //
dataFormSubmit() { dataFormSubmit() {
this.$refs['dataForm'].validate((valid) => { this.$refs['dataForm'].validate((valid) => {
@ -191,7 +294,60 @@ export default {
}, },
}; };
</script> </script>
<!-- <style scoped>
.drawer >>> .el-drawer {
border-radius: 8px 0 0 8px;
display: flex;
flex-direction: column;
}
.drawer >>> .el-form-item__label {
padding: 0;
}
.drawer >>> .el-drawer__header {
margin: 0;
padding: 32px 32px 24px;
border-bottom: 1px solid #dcdfe6;
}
.drawer >>> .el-drawer__body {
flex: 1;
height: 1px;
display: flex;
flex-direction: column;
}
.drawer >>> .content {
padding: 30px 24px;
flex: 1;
display: flex;
flex-direction: column;
/* height: 100%; */
}
.drawer >>> .visual-part {
flex: 1 auto;
max-height: 76vh;
overflow: hidden;
overflow-y: scroll;
padding-right: 10px; /* 调整滚动条样式 */
}
.drawer >>> .el-form,
.drawer >>> .attr-list {
padding: 0 16px;
}
.drawer-body__footer {
display: flex;
justify-content: flex-end;
padding: 18px;
}
</style> -->
<style> <style>
.baseDialog .el-dialog__header { .baseDialog .el-dialog__header {
font-size: 16px; font-size: 16px;
color: rgba(0, 0, 0, 0.85); color: rgba(0, 0, 0, 0.85);
@ -204,7 +360,7 @@ export default {
display: inline-block; display: inline-block;
width: 4px; width: 4px;
height: 16px; height: 16px;
background-color: #0b58ff; background-color: #0B58FF;
border-radius: 1px; border-radius: 1px;
margin-right: 8px; margin-right: 8px;
position: relative; position: relative;
@ -219,4 +375,7 @@ export default {
padding: 9px 10px 9px 16px; padding: 9px 10px 9px 16px;
font-size: 14px; font-size: 14px;
} }
</style> </style>

View File

@ -1,85 +0,0 @@
<template>
<div class="app-container">
<div>开发中</div>
<!-- 搜索工作栏 -->
<!-- <search-bar
:formConfigs="formConfig"
ref="searchBarForm"
@headBtnClick="buttonClick" />
<div class="report-box">
<div class="top-box">
<div class="left-top">
<base-table
:table-props="tableProp1"
:table-data="tableData"
:span-method="spanMethod"
:max-height="tableH" />
</div>
<div class="right-top"></div>
</div>
<div class="bottom-box">
<div class="left-bottom"></div>
<div class="right-bottom"></div>
</div>
</div> -->
</div>
</template>
<script>
const tableProp1 = [
{
prop: 'col1',
label: '生产线',
fixed: true,
},
];
export default {
name: 'productionDayR',
data() {
return {
formConfig: [
{
type: 'datePicker',
label: '日',
dateType: 'date',
format: 'yyyy-MM-dd',
valueFormat: 'yyyy-MM-dd',
placeholder: '日',
param: 'searchTime',
width: 150,
},
{
type: 'button',
btnName: '查询',
name: 'search',
color: 'primary',
},
{
type: 'separate',
},
{
type: this.$auth.hasPermi('base:group-classes:create')
? 'button'
: '',
btnName: '导出',
name: 'add',
color: 'primary',
plain: true,
},
],
};
},
mounted() {},
methods: {},
};
</script>
<style lang="scss" scoped>
.report-box {
.left-top,
.right-top,
.left-bottom,
.right-bottom {
display: inline-block;
border: 1px solid red;
}
}
</style>