This commit is contained in:
2022-11-07 14:54:47 +08:00
commit 8cfe73aaef
1227 changed files with 194899 additions and 0 deletions

View File

@@ -0,0 +1,183 @@
<!--
* @Author: gtz
* @Date: 2022-04-15 10:05:37
* @LastEditors: gtz
* @LastEditTime: 2022-04-15 10:05:39
* @Description: file content
* @FilePath: \mt-bus-fe\src\views\orderManage\components\HeadForm.vue
-->
<!--
* @Author: zwq
* @Date: 2020-12-29 16:18:27
* @LastEditors: gtz
* @LastEditTime: 2022-04-11 11:25:26
* @Description:
-->
<template>
<el-form :inline="true" @keyup.enter.native="getDataList()">
<el-form-item v-for="(item, index) in keyName" :key="index" :label="item.name">
<el-input v-if="item.type === 'input'" v-model="key[index]" style="width:150px" :placeholder="placeholderName[index]" clearable />
<el-select v-if="item.type === 'select'" v-model="key[index]" style="width:150px" :placeholder="placeholderName[index]" clearable>
<!-- 这里用 :value="i.alarmId" :label="i.alarmGrade" 可以将数据传进select -->
<el-option v-for="i in item.option" :key="i.value" :value="i.value" :label="i.label" />
</el-select>
<el-date-picker
v-if="item.type === 'datePicker'"
v-model="key[index]"
type="daterange"
align="right"
unlink-panels
:range-separator="'formItem.to' | i18nFilter"
:start-placeholder="'formItem.beginTime' | i18nFilter"
:end-placeholder="'formItem.endTime' | i18nFilter"
:picker-options="pickerOptions"
/>
</el-form-item>
<el-form-item>
<el-button @click="getDataList()">{{ searchTitle | i18nFilter }}</el-button>
<el-button v-if="showAdd" type="primary" @click="addNew()">{{ addTitle | i18nFilter }}</el-button>
<el-button v-if="showExportTemplate" type="success" @click="exportTemplate()">{{ exportTemplateTitle | i18nFilter }}</el-button>
<el-button v-if="showExport" type="success" @click="exportFile()">{{ exportTitle | i18nFilter }}</el-button>
<el-upload
v-if="showImport"
class="upload-demo"
style="display: inline-block"
:on-success="importFile"
:action="importUrl"
:show-file-list="false"
>
<el-button type="success">{{ importTitle | i18nFilter }}</el-button>
</el-upload>
</el-form-item>
</el-form>
</template>
<script>
export default {
props: {
keyName: {
type: Array,
default: () => {
return []
}
},
showAdd: {
type: Boolean,
default: () => {
return true
}
},
showExportTemplate: {
type: Boolean,
default: () => {
return false
}
},
showExport: {
type: Boolean,
default: () => {
return false
}
},
showImport: {
type: Boolean,
default: () => {
return false
}
},
placeholderName: {
type: Array,
default: () => {
return []
}
},
importUrl: {
type: String,
default: ''
},
searchTitle: {
type: String,
default: 'btn.search'
},
addTitle: {
type: String,
default: 'btn.add'
},
exportTitle: {
type: String,
default: 'btn.export'
},
importTitle: {
type: String,
default: 'btn.import'
},
exportTemplateTitle: {
type: String,
default: 'btn.exportTemplate'
}
},
data() {
return {
key: [],
pickerOptions: {
shortcuts: [{
text: this.$t('datePickerOption.lastWeek'),
onClick(picker) {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7)
picker.$emit('pick', [start, end])
}
}, {
text: this.$t('datePickerOption.lastMonth'),
onClick(picker) {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)
picker.$emit('pick', [start, end])
}
}, {
text: this.$t('datePickerOption.lastThreeMonths'),
onClick(picker) {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)
picker.$emit('pick', [start, end])
}
}]
}
}
},
mounted() {
this.keyName.map(item => {
if (item.type === 'datePicker') {
this.key.push([])
} else {
this.key.push(null)
}
})
},
methods: {
getDataList() {
this.$emit('getDataList', this.key)
},
addNew() {
this.$emit('addNew')
},
exportTemplate() {
this.$emit('exportTemplate')
},
exportFile() {
this.$emit('exportFile', this.key)
},
importFile(response, file, fileList) {
this.$emit('importFile', response, file, fileList)
}
}
}
</script>
<style>
</style>

View File

@@ -0,0 +1,41 @@
<!--
* @Date: 2021-01-07 20:09:37
* @LastEditors: zwq
* @LastEditTime: 2021-03-20 15:17:31
* @FilePath:
* @Description:
-->
<template>
<div>
<span>
<el-button type="text" size="small" @click="emitClick">{{ 'routerTitle.order.workOrderManage.tagDetail' | i18nFilter }}</el-button>
</span>
<tag-detail v-if="tagDetailVisible" ref="tagDetail" :packaging-box-id="injectData.id" />
</div>
</template>
<script>
import tagDetail from './tagDetail'
export default {
components: { tagDetail },
props: {
injectData: {
type: Object,
default: () => ({})
}
},
data() {
return {
tagDetailVisible: false
}
},
methods: {
emitClick() {
this.tagDetailVisible = true
this.$nextTick(() => {
this.$refs.tagDetail.init()
})
}
}
}
</script>

View File

@@ -0,0 +1,27 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-30 11:22:36
* @Description:
-->
<template>
<span>
{{ injectData[injectData.prop] ? injectData[injectData.prop].map(item => {
return item.name
}).join(',') : '' }}
</span>
</template>
<script>
export default {
name: '',
props: {
injectData: {
type: Object,
default: () => ({})
}
}
}
</script>

View File

@@ -0,0 +1,135 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 16:37:56
* @LastEditors: zwq
* @LastEditTime: 2021-05-28 16:16:27
* @Description:
-->
<template>
<el-dialog
:title="!dataForm.id ? 'btn.add' : 'btn.edit' | i18nFilter"
:visible.sync="visible"
>
<el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="100px" @keyup.enter.native="dataFormSubmit()">
<el-form-item :label="$t('module.orderManage.powerClassification.typeName')" prop="name">
<el-input v-model="dataForm.name" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.powerClassification.typeName')])" clearable />
</el-form-item>
<el-form-item :label="$t('module.orderManage.powerClassification.typeCode')" prop="code">
<el-input v-model="dataForm.code" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.powerClassification.typeCode')])" clearable />
</el-form-item>
<el-form-item :label="$t('module.orderManage.powerClassification.parentClass')" prop="parentId">
<el-cascader
ref="cascader"
v-model="dataForm.parentId"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.powerClassification.parentClass')])"
:props="{ checkStrictly: true,value: 'id',label: 'name' }"
:options="parentArr"
filterable
clearable
@change="setParent"
/>
</el-form-item>
<el-form-item :label="$t('module.basicData.visual.Remarks')" prop="remark">
<el-input v-model="dataForm.remark" :placeholder="$i18nForm(['placeholder.input', $t('module.basicData.visual.Remarks')])" clearable />
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">{{ 'btn.cancel' | i18nFilter }}</el-button>
<el-button type="primary" @click="dataFormSubmit()">{{ 'btn.confirm' | i18nFilter }}</el-button>
</span>
</el-dialog>
</template>
<script>
import { powerClassificationTree, powerClassificationDetail, powerClassificationUpdate, powerClassificationAdd, powerClassificationCode } from '@/api/orderManage/powerClassification'
export default {
data() {
return {
visible: false,
dataForm: {
id: 0,
name: '',
code: '',
parentId: '',
parentName: '',
remark: ''
},
parentArr: [],
dataRule: {
name: [
{
required: true,
message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.powerClassification.typeName')]),
trigger: 'blur' }
],
parentId: [
{
required: true,
message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.powerClassification.parentClass')]),
trigger: 'change' }
]
}
}
},
methods: {
init(id) {
this.dataForm.id = id || ''
this.visible = true
this.parentArr.splice(0, this.parentArr.length)
powerClassificationTree().then(res => {
this.parentArr = res.data
})
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
if (this.dataForm.id) {
powerClassificationDetail(this.dataForm.id).then(res => {
this.dataForm = res.data
})
} else {
powerClassificationCode().then(res => {
this.dataForm.code = res.data
})
}
})
},
// 表单提交
dataFormSubmit() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
const data = this.dataForm
data.parentId = data.parentId[data.parentId.length - 1]
if (this.dataForm.id) {
powerClassificationUpdate(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
} else {
powerClassificationAdd(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
}
}
})
},
setParent(val) {
this.dataForm.parentName = this.$refs['cascader'].getCheckedNodes()[0].pathLabels[this.$refs['cascader'].getCheckedNodes()[0].pathLabels.length - 1]
}
}
}
</script>

View File

@@ -0,0 +1,18 @@
<template>
<span>
{{ injectData.status ? injectData.statusObj[String(injectData.status)] : '' }}
</span>
</template>
<script>
export default {
name: '',
props: {
injectData: {
type: Object,
default: () => ({})
}
}
}
</script>

View File

@@ -0,0 +1,131 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 16:37:56
* @LastEditors: zwq
* @LastEditTime: 2021-03-30 18:39:46
* @Description:
-->
<template>
<el-drawer
:append-to-body="true"
:show-close="false"
:visible.sync="visible"
size="40%"
>
<div slot="title" style=" background-color:#02BCFF;font-size:1.5em;color:white;padding:5px 20px">
{{ !dataForm.id ? 'btn.add' : 'btn.edit' | i18nFilter }}
</div>
<el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="100px" @keyup.enter.native="dataFormSubmit()">
<el-form-item :label="$t('module.basicData.visual.AttributeName')" prop="attrName">
<el-input v-model="dataForm.attrName" :placeholder="$i18nForm(['placeholder.input', $t('module.basicData.visual.AttributeName')])" clearable />
</el-form-item>
<el-form-item :label="$t('module.basicData.visual.AttributeValue')" prop="attrValue">
<el-input v-model="dataForm.attrValue" :placeholder="$i18nForm(['placeholder.input', $t('module.basicData.visual.AttributeValue')])" clearable />
</el-form-item>
</el-form>
<div class="drawer-footer">
<el-button @click="visible = false">{{ 'btn.cancel' | i18nFilter }}</el-button>
<el-button type="primary" :loading="btnLoading" @click="dataFormSubmit()">{{ 'btn.confirm' | i18nFilter }}</el-button>
</div>
</el-drawer>
</template>
<script>
import { substrateBatchAttrDetail, substrateBatchAttrUpdate, substrateBatchAttrAdd } from '@/api/orderManage/substrateBatchAttr'
export default {
props: {
subId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
visible: false,
btnLoading: false,
dataForm: {
id: 0,
attrName: '',
attrValue: ''
},
dataRule: {
attrName: [
{ required: true, message: this.$i18nForm(['placeholder.input', this.$t('module.basicData.visual.AttributeName')]), trigger: 'blur' }
],
attrValue: [
{ required: true, message: this.$i18nForm(['placeholder.input', this.$t('module.basicData.visual.AttributeValue')]), trigger: 'blur' }
]
}
}
},
methods: {
init(id) {
this.dataForm.id = id || ''
this.btnLoading = false
this.visible = true
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
if (this.dataForm.id) {
substrateBatchAttrDetail(this.dataForm.id).then(res => {
this.dataForm.attrName = res.data.name
this.dataForm.attrValue = res.data.value
})
}
})
},
// 表单提交
dataFormSubmit() {
this.btnLoading = true
this.$refs['dataForm'].validate((valid) => {
if (valid) {
const data = {
'name': this.dataForm.attrName,
'value': this.dataForm.attrValue,
'subId': this.subId,
'id': this.dataForm.id
}
if (this.dataForm.id) {
substrateBatchAttrUpdate(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
} else {
substrateBatchAttrAdd(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
}
}
})
}
}
}
</script>
<style scoped>
.drawer-footer {
width: 100%;
margin-top: 50px;
border-top: 1px solid #e8e8e8;
padding: 10px 50px;
text-align: left;
background: #fff;
}
</style>

View File

@@ -0,0 +1,235 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 16:37:56
* @LastEditors: zwq
* @LastEditTime: 2021-03-31 11:24:59
* @enName:
-->
<template>
<div style="margin:20px">
<div slot="title" style=" background-color:#02BCFF;font-size:1.5em;color:white;padding:5px 20px;margin:20px">{{ isdetail? 'btn.detail' : !dataForm.id ? 'btn.add' : 'btn.edit' | i18nFilter }}</div>
<div style="margin:0 15px">
<el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="100px" @keyup.enter.native="dataFormSubmit()">
<el-form-item :label="$t('module.orderManage.substrateBatch.batchName')" prop="name">
<el-input v-model="dataForm.name" :disabled="isdetail" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.substrateBatch.batchName')])" clearable />
</el-form-item>
<el-form-item :label="$t('module.orderManage.substrateBatch.batchCode')" prop="code">
<el-input v-model="dataForm.code" :disabled="isdetail" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.substrateBatch.batchCode')])" clearable />
</el-form-item>
<el-form-item :label="$t('module.basicData.visual.Remarks')" prop="remark">
<el-input v-model="dataForm.remark" :disabled="isdetail" :placeholder="$i18nForm(['placeholder.input', $t('module.basicData.visual.Remarks')])" clearable />
</el-form-item>
</el-form>
<div style="margin:20px">
<el-button type="success" @click="goback()">{{ 'btn.back' | i18nFilter }}</el-button>
<el-button v-if="isdetail" type="primary" @click="goEdit()">{{ 'btn.edit' | i18nFilter }}</el-button>
<span v-if="!isdetail">
<el-button type="primary" @click="dataFormSubmit()">{{ 'btn.save' | i18nFilter }}</el-button>
<el-button v-if="listQuery.subId" type="primary" @click="addNew()">{{ 'btn.addattr' | i18nFilter }}</el-button>
</span>
</div>
<div style="height:380px;overflow:auto">
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
>
<method-btn
v-if="!isdetail"
slot="handleBtn"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
</div>
</div>
<substrate-batch-attr-add v-if="addOrUpdateVisible" ref="addOrUpdate" :sub-id="listQuery.subId" @refreshDataList="getList" />
</div>
</template>
<script>import i18n from '@/lang'
import { substrateBatchDetail, substrateBatchUpdate, substrateBatchAdd, substrateBatchCode } from '@/api/orderManage/substrateBatch'
import { substrateBatchAttrList, substrateBatchAttrDelete } from '@/api/orderManage/substrateBatchAttr'
import BaseTable from '@/components/BaseTable'
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import substrateBatchAttrAdd from './substrateBatchAttr-add'
import { timeFormatter } from '@/filters'
const tableBtn = [
{
type: 'edit',
btnName: 'btn.edit'
},
{
type: 'delete',
btnName: 'btn.delete'
}
]
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.basicData.factory.createTime'),
filter: timeFormatter,
align: 'center'
},
{
prop: 'name',
label: i18n.t('module.basicData.visual.AttributeName'),
align: 'center'
},
{
prop: 'value',
label: i18n.t('module.basicData.visual.AttributeValue'),
align: 'center'
}
]
export default {
components: { BaseTable, MethodBtn, substrateBatchAttrAdd },
data() {
return {
addOrUpdateVisible: false,
tableBtn,
trueWidth: 200,
tableProps,
list: [],
dataForm: {
name: '',
code: '',
enName: '',
abbr: '',
category: '',
description: '',
remark: ''
},
dataRule: {
name: [
{ required: true, message: this.$i18nForm(['placeholder.input', this.$t('module.basicData.material.MaterialName')]), trigger: 'blur' }
],
code: [
{ required: true, message: this.$i18nForm(['placeholder.input', this.$t('module.basicData.material.MaterialCoding')]), trigger: 'blur' }
]
},
listQuery: {
current: 1,
size: 990,
subId: ''
},
isdetail: false
}
},
created() {
this.listQuery.subId = this.$route.query.id
this.init()
},
methods: {
init() {
this.isdetail = false
this.isdetail = Boolean(this.$route.query.isdetail)
this.list.splice(0, this.list.length)
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
if (this.listQuery.subId) {
substrateBatchDetail(this.listQuery.subId).then(res => {
this.dataForm = res.data
})
substrateBatchAttrList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
})
} else {
substrateBatchCode().then(res => {
this.dataForm.code = res.data
})
}
})
},
getList() {
substrateBatchAttrList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
})
},
handleClick(raw) {
if (raw.type === 'delete') {
this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}[${raw.data.name}]?`, this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
}).then(() => {
substrateBatchAttrDelete(raw.data.id).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.getList()
}
})
})
}).catch(() => {})
} else {
this.addNew(raw.data.id)
}
},
// 表单提交
dataFormSubmit() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
this.dataForm.id = this.listQuery.subId
const data = this.dataForm
if (this.listQuery.subId) {
substrateBatchUpdate(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500
})
})
} else {
substrateBatchAdd(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500
})
this.listQuery.subId = res.data.id
})
}
}
})
},
// 新增 / 修改
addNew(id) {
this.addOrUpdateVisible = true
this.$nextTick(() => {
this.$refs.addOrUpdate.init(id)
})
},
goEdit() {
this.isdetail = false
},
goback() {
this.$router.go(-1)
}
}
}
</script>
<style scoped>
.drawer-footer {
width: 100%;
margin-top: 50px;
border-top: 1px solid #e8e8e8;
border-bottom: 1px solid #e8e8e8;
padding: 10px 50px;
text-align: left;
background: #fff;
}
</style>

View File

@@ -0,0 +1,197 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 16:37:56
* @LastEditors: zwq
* @LastEditTime: 2021-07-21 09:33:06
* @Description:
-->
<template>
<el-drawer
:append-to-body="true"
:show-close="false"
:visible.sync="visible"
size="55%"
>
<div
slot="title"
style=" background-color:#02BCFF;font-size:1.5em;color:white;padding:5px 20px"
>
{{ "routerTitle.order.workOrderManage.tagDetail" | i18nFilter }}
</div>
<el-card class="box-card">
<div slot="header" class="clearfix">
<span><b>{{ "BOX_ID" + dataForm.id }}</b></span>
<el-button
type="primary"
style="float:right"
size="small"
@click="btnClickPrint"
>{{ "btn.print" | i18nFilter }}</el-button>
</div>
<div class="text item">
<el-row :gutter="20">
<el-col
:span="6"
><div>{{ "Power" + dataForm.power }}</div></el-col>
<el-col
:span="6"
><div>{{ "SAP Material" + dataForm.sapMaterial }}</div></el-col>
</el-row>
</div>
</el-card>
<div id="tablePrint">
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
</div>
</el-drawer>
</template>
<script>
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import {
packagingDetail,
packagingBoxList
} from '@/api/orderManage/workOrder/workOrder'
// import { timeFormatter } from '@/filters'
import { getLodop } from '@/assets/libs/LodopFuncs.js'
import { getInfo } from '@/api/packing-manage/packing-label.js'
const tableProps = [
{
prop: 'woSubstrateId',
label: i18n.t('module.orderManage.packingTags.moduleId'),
align: 'center'
},
// {
// prop: 'finishProduceTime',
// label: i18n.t('module.orderManage.packingTags.UnloadingTime'),
// align: 'center'
// },
// {
// prop: 'name',
// label: i18n.t('module.orderManage.packingTags.UnloadingEquipment'),
// align: 'center',
// filter: timeFormatter
// },
{
prop: 'oneCode',
label: i18n.t('module.orderManage.packingTags.oneDimensionalCode'),
align: 'center'
}
]
export default {
components: { BaseTable },
props: {
packagingBoxId: {
type: String,
default: () => ({})
}
},
data() {
return {
visible: false,
tableProps,
list: [],
total: 0,
listLoading: false,
dataForm: {},
listQuery: {
current: 1,
size: 500
}
}
},
methods: {
init() {
this.visible = true
this.listLoading = true
packagingDetail(this.packagingBoxId).then(res => {
this.dataForm = res.data
})
this.getList()
},
getList() {
this.listQuery.packagingBoxId = this.packagingBoxId
this.listLoading = true
packagingBoxList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.listLoading = false
})
},
// btnClickPrint() {
// const LODOP = getLodop()
// const strHTML = document.getElementById('tablePrint').innerHTML
// LODOP.ADD_PRINT_HTM(30, 5, '100%', '80%', strHTML) // 装载模板
// LODOP.PREVIEW()
// }
btnClickPrint() {
getInfo({ id: '1387070313172353025' }).then(res => {
this.printPreview('预览', res.data.content)
})
},
printPreview(name = '预览', modelCode) {
console.log(modelCode)
const LODOP = getLodop()
LODOP.PRINT_INIT(name)
const aaa = LODOP.ADD_PRINT_DATA('ProgramData', modelCode)
console.log(aaa)
const obj = {
time: this.dataForm.packagingTime,
orderCode: this.orderCode,
power: this.dataForm.power,
sapMaterial: this.dataForm.sapMaterial,
BarCode: this.dataForm.boxNo
}
this.list.forEach((item, index) => {
const str = 'modul' + (index + 1)
obj[str] = item.woSubstrateId
})
Object.keys(obj).forEach(key => {
LODOP.SET_PRINT_STYLEA(key, 'CONTENT', obj[key])
})
LODOP.NewPageA()
LODOP.PREVIEW()
},
print(name = '打印') {
console.log(name, this.currentIndex)
// 装载模板
const modelCode = this.printModels[this.currentIndex].printModelContent
console.log(modelCode)
this.objs.forEach(obj => {
const LODOP = getLodop() // 调用getLodop获取LODOP对象
LODOP.PRINT_INIT(name)
const aaa = LODOP.ADD_PRINT_DATA('ProgramData', modelCode)
console.log(aaa)
obj.partCode = obj.itemCode
obj.productTypeName = obj.itemTypeName
Object.keys(obj).forEach(key => {
LODOP.SET_PRINT_STYLEA(key, 'CONTENT', obj[key])
})
// LODOP.ADD_PRINT_HTM(10, 10, 350, 600, `--------${index}----------`);
LODOP.NewPageA()
LODOP.PRINT()
})
}
}
}
</script>
<style scoped>
.drawer-footer {
width: 100%;
margin-top: 50px;
border-top: 1px solid #e8e8e8;
padding: 10px 50px;
text-align: left;
background: #fff;
}
</style>

View File

@@ -0,0 +1,27 @@
<!--
* @Author: gtz
* @Date: 2022-04-20 10:25:35
* @LastEditors: gtz
* @LastEditTime: 2022-04-20 10:29:32
* @Description: file content
* @FilePath: \mt-bus-fe\src\views\orderManage\components\unitColumn.vue
-->
<template>
<span>
{{ (injectData.dictDataId || injectData.unitCode) ? injectData.unitObj[String(injectData.dictDataId || injectData.unitCode)] : '' }}
</span>
</template>
<script>
export default {
name: '',
props: {
injectData: {
type: Object,
default: () => ({})
}
}
}
</script>

View File

@@ -0,0 +1,123 @@
<!--
* @Author: your name
* @Date: 2021-07-21 16:13:20
* @LastEditTime: 2021-07-21 17:32:59
* @LastEditors: Please set LastEditors
* @Description: In User Settings Edit
* @FilePath: \mt-bus-fe\src\views\orderManage\consumption\consumption.vue
-->
<template>
<div>
<div class="method-btn-area">
<el-input v-model="listQuery.key" :placeholder="$i18nForm(['placeholder.input', this.$t('module.orderManage.consumption.workOrderId')])" filterable clearable style="width: 200px;" />
<!-- <el-select v-model="listQuery.workerId" :placeholder="$t('module.equipmentManager.eqManagerManage.worker')" clearable style="width: 200px;">
<el-option
v-for="item in workerList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select> -->
<el-button type="primary" @click="getList">{{ 'btn.search' | i18nFilter }}</el-button>
</div>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
>
<method-btn
slot="handleBtn"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList1()"
/>
</div>
</template>
<script>
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import i18n from '@/lang'
import { getPower } from '@/api/orderManage/order/order'
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
const tableBtn = [
{
type: 'detail',
btnName: 'btn.detail'
}
]
const tableProps = [
{
prop: 'workOrderId',
label: i18n.t('module.orderManage.consumption.workOrderId'),
align: 'center'
},
{
prop: 'power',
label: i18n.t('module.orderManage.consumption.power'),
align: 'center'
},
{
prop: 'workOrderStatus',
label: i18n.t('module.orderManage.consumption.workOrderStatus'),
align: 'center'
}
]
export default {
components: {
BaseTable,
Pagination,
MethodBtn
},
data() {
return {
tableProps,
tableBtn,
list: [],
listLoading: true,
total: 0,
listQuery: {
current: 1,
size: 10,
key: ''
}
}
},
mounted() {
this.getList()
},
methods: {
getList() {
getPower(this.listQuery).then(res => {
if (res.code === 0) {
this.list = res.data.records
this.listLoading = false
}
})
// this.list = result.data.records
},
handleClick(raw) {
const id = raw.data.workOrderId
this.$router.push({
path: '/powerList',
query: {
id
}
})
}
}
}
</script>
<style>
</style>

View File

@@ -0,0 +1,94 @@
<!--
* @Author: your name
* @Date: 2021-07-21 17:08:01
* @LastEditTime: 2021-07-21 17:33:37
* @LastEditors: Please set LastEditors
* @Description: In User Settings Edit
* @FilePath: \mt-bus-fe\src\views\orderManage\consumption\list.vue
-->
<template>
<div>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList1()"
/>
</div>
</template>
<script>
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import i18n from '@/lang'
import { getPower } from '@/api/orderManage/order/order'
const tableBtn = [
{
type: 'detail',
btnName: 'btn.detail'
}
]
const tableProps = [
{
prop: 'equipmentName',
label: i18n.t('module.orderManage.consumption.equipmentName'),
align: 'center'
},
{
prop: 'power',
label: i18n.t('module.orderManage.consumption.power'),
align: 'center'
},
{
prop: 'workOrderStatus',
label: i18n.t('module.orderManage.consumption.workOrderStatus'),
align: 'center'
}
]
export default {
components: {
BaseTable,
Pagination
},
data() {
return {
tableProps,
tableBtn,
list: [],
listLoading: true,
total: 0,
listQuery: {
current: 1,
size: 10,
workOrderId: this.$route.query.id
}
}
},
mounted() {
this.getList()
},
methods: {
getList() {
console.log(this.listQuery.workOrderId)
getPower(this.listQuery).then(res => {
if (res.code === 0) {
this.list = res.data.records
this.listLoading = false
}
})
}
}
}
</script>
<style>
</style>

View File

@@ -0,0 +1,237 @@
<!--
* @Author: zwq
* @Date: 2021-06-24 15:21:19
* @LastEditors: Please set LastEditors
* @LastEditTime: 2021-07-21 16:45:26
* @Description:
-->
<template>
<div style="padding:10px">
<span>{{ $t('module.orderManage.erpToMes.erpToMesMaterial') }}</span>
<base-table
:page="listQuery1.current"
:limit="listQuery1.size"
:table-config="tableProps1"
:table-data="list1"
:is-loading="listLoading1"
/>
<pagination
v-show="total1 > 0"
:total="total1"
:page.sync="listQuery1.current"
:limit.sync="listQuery1.size"
@pagination="getList1()"
/>
<hr>
<span>{{ $t('module.orderManage.erpToMes.erpToMesMaterialBom') }}</span>
<base-table
:page="listQuery2.current"
:limit="listQuery2.size"
:table-config="tableProps2"
:table-data="list2"
:is-loading="listLoading2"
/>
<pagination
v-show="total2 > 0"
:total="total2"
:page.sync="listQuery2.current"
:limit.sync="listQuery2.size"
@pagination="getLis2()"
/>
<hr>
<span>{{ $t('module.orderManage.erpToMes.erpToMesOrder') }}</span>
<base-table
:page="listQuery3.current"
:limit="listQuery3.size"
:table-config="tableProps3"
:table-data="list3"
:is-loading="listLoading3"
/>
<pagination
v-show="total3 > 0"
:total="total3"
:page.sync="listQuery3.current"
:limit.sync="listQuery3.size"
@pagination="getList3()"
/>
</div>
</template>
<script>
import { erpToMesMaterialList, erpToMesMaterialBomList, erpToMesOrderList } from '@/api/orderManage/erpToMes'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import i18n from '@/lang'
const tableProps1 = [
{
prop: 'batchNumber',
label: i18n.t('module.orderManage.erpToMes.batchNumber'),
align: 'center'
},
{
prop: 'materialsCode',
label: i18n.t('module.orderManage.erpToMes.materialsCode'),
align: 'center'
},
{
prop: 'materialsName',
label: i18n.t('module.orderManage.erpToMes.materialsName'),
align: 'center'
},
{
prop: 'quantity',
label: i18n.t('module.orderManage.erpToMes.quantity'),
align: 'center'
},
{
prop: 'unit',
label: i18n.t('module.orderManage.erpToMes.unit'),
align: 'center'
}
]
const tableProps2 = [
{
prop: 'bomContent',
label: i18n.t('module.orderManage.erpToMes.bomContent'),
align: 'center'
},
{
prop: 'craftCode',
label: i18n.t('module.orderManage.erpToMes.craftCode'),
align: 'center'
},
{
prop: 'craftName',
label: i18n.t('module.orderManage.erpToMes.craftName'),
align: 'center'
},
{
prop: 'materialsBomCode',
label: i18n.t('module.orderManage.erpToMes.materialsBomCode'),
align: 'center'
},
{
prop: 'materialsBomName',
label: i18n.t('module.orderManage.erpToMes.materialsBomName'),
align: 'center'
},
{
prop: 'substrateBatch',
label: i18n.t('module.orderManage.erpToMes.substrateBatch'),
align: 'center'
}
]
const tableProps3 = [
{
prop: 'customerCode',
label: i18n.t('module.orderManage.erpToMes.customerCode'),
align: 'center'
},
{
prop: 'customerName',
label: i18n.t('module.orderManage.erpToMes.customerName'),
align: 'center'
},
{
prop: 'orderCode',
label: i18n.t('module.orderManage.erpToMes.orderCode'),
align: 'center'
},
{
prop: 'orderName',
label: i18n.t('module.orderManage.erpToMes.orderName'),
align: 'center'
},
{
prop: 'quantity',
label: i18n.t('module.orderManage.erpToMes.quantity'),
align: 'center'
}
]
export default {
name: 'ErpToMesData',
components: { Pagination, BaseTable },
data() {
return {
tableProps1,
tableProps2,
tableProps3,
list1: [],
list2: [],
list3: [],
total1: 0,
total2: 0,
total3: 0,
listLoading1: true,
listLoading2: true,
listLoading3: true,
listQuery1: {
current: 1,
size: 10
},
listQuery2: {
current: 1,
size: 10
},
listQuery3: {
current: 1,
size: 10
}
}
},
created() {
this.getList1()
this.getList2()
this.getList3()
},
methods: {
getList1() {
this.listLoading1 = true
erpToMesMaterialList(this.listQuery1).then(response => {
if (response.data.records) {
this.list1 = response.data.records
} else {
this.list1.splice(0, this.list1.length)
}
this.total1 = response.data.total
this.listLoading1 = false
})
},
getList2() {
this.listLoading2 = true
erpToMesMaterialBomList(this.listQuery2).then(response => {
if (response.data.records) {
this.list2 = response.data.records
} else {
this.list2.splice(0, this.list2.length)
}
this.total2 = response.data.total
this.listLoading2 = false
})
},
getList3() {
this.listLoading3 = true
erpToMesOrderList(this.listQuery3).then(response => {
if (response.data.records) {
this.list3 = response.data.records
} else {
this.list3.splice(0, this.list3.length)
}
this.total3 = response.data.total
this.listLoading3 = false
})
}
}
}
</script>
<style scoped>
span{
background-color: #ECF5FF;
font-size: 20px;
padding: 5px;
color: #409EFF;
}
</style>

View File

@@ -0,0 +1,110 @@
<template>
<el-dialog :title="'btn.add' | i18nFilter" :visible.sync="visible" @closed="handleClosed">
<el-form
ref="dataForm"
:model="dataForm"
:rules="dataRule"
label-width="100px"
>
<el-form-item
:label="this.$t('module.orderManage.feeInfo.orderName')"
prop="orderId"
>
<el-select
v-model="dataForm.orderId"
filterable
:placeholder="this.$t('module.orderManage.feeInfo.orderName')"
@change="selectOrder()"
>
<el-option
v-for="item in list"
:key="item.orderId"
:label="item.name"
:value="item.orderId"
/>
</el-select>
</el-form-item>
<el-form-item
:label="this.$t('module.orderManage.feeInfo.orderCode')"
prop="code"
>
<el-input
v-model="dataForm.code"
clearable
:placeholder="this.$t('module.orderManage.feeInfo.orderCode')"
disabled
/>
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">
{{ 'btn.cancel' | i18nFilter }}
</el-button>
<el-button type="primary" @click="dataFormSubmit()">
{{ 'btn.confirm' | i18nFilter }}
</el-button>
</span>
</el-dialog>
</template>
<script>
import { listForAdd } from '@/api/orderManage/fee/fee'
import { orderAdd } from '@/api/orderManage/fee/fee'
export default {
props: {
},
data() {
return {
visible: false,
list: '',
dataForm: {
code: '',
orderId: ''
},
dataRule: {
orderId: [
{ required: true, message: this.$t('module.orderManage.feeInfo.orderName'), trigger: 'blur' }
]
}
}
},
methods: {
init() {
this.visible = true
listForAdd().then(res => {
this.list = res.data
})
},
selectOrder() {
this.list.map(item => {
if (item.orderId === this.dataForm.orderId) {
this.dataForm.code = item.code
}
})
},
dataFormSubmit() {
this.$refs['dataForm'].validate(valid => {
if (valid) {
orderAdd({ orderId: this.dataForm.orderId }).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.handleClosed()
this.$emit('refreshDataList')
}
})
})
}
})
},
handleClosed() {
this.$refs['dataForm'].resetFields()
this.visible = false
}
}
}
</script>

View File

@@ -0,0 +1,418 @@
<template>
<el-dialog :title="'btn.edit' | i18nFilter" :visible.sync="visible" @closed="handleClosed">
<div>
<ul style="list-style: none;display: flex;text-align: left;">
<li style="width: 50%;">{{ this.$t('module.orderManage.order.OrderName') | i18nFilter }} {{ orderName }}</li>
<li style="width: 50%;">{{ this.$t('module.orderManage.order.OrderCode') | i18nFilter }} {{ orderCode }}</li>
</ul>
</div>
<!-- 新增编辑 -->
<template>
<el-divider content-position="center">
<span class="lb-text-middle">
{{ dividingLine | i18nFilter }}{{ this.$t('module.orderManage.feeInfo.details') | i18nFilter }}
</span>
</el-divider>
<el-row>
<div v-if="displayCreateStockButton" class="lb-create-stock-container">
<button @click.prevent="displayCreateStockForm">
+{{ dividingLine | i18nFilter }}{{ this.$t('module.orderManage.feeInfo.details') | i18nFilter }}
</button>
</div>
<div v-else class="lb-create-stock-alert">
<el-form
ref="detailData"
style="padding: 24px;"
:model="detailData"
label-position="top"
:rules="stockFormValidationRules"
>
<el-row :gutter="20">
<template v-for="(item, index) in detailForm">
<el-col :span="8">
<el-form-item :key="index" :label="item.label ? item.label : ''" :prop="item.param">
<!-- input -->
<el-input
v-if="item.type === 'input'"
v-model="detailData[item.param]"
clearable
:style="item.width ? 'width:' + item.width + 'px' : 'width:100%'"
:placeholder="['placeholder.input', item.placeholder] | i18nFilterForm"
/>
<!-- select -->
<el-select
v-if="item.type === 'select'"
v-model="detailData[item.param]"
:filterable="item.filterable ? item.filterable : false"
:clearable="item.clearable === false ? false : true"
:style="item.width ? item.width + 'px' : 'width:100%'"
:placeholder="['placeholder.select', item.label] | i18nFilterForm"
>
<template v-for="(sub, i) in item.selectOptions">
<el-option :key="i" :label="sub.name" :value="sub.id" />
</template>
</el-select>
<!-- inputNumber -->
<el-input-number
v-if="item.type === 'inputNumber'"
v-model="detailData[item.param]"
:min="item.min ? item.min : 0"
:max="item.max ? item.max : 'Infinity'"
:precision="item.precision"
:step="item.step ? item.step : 1"
:style="item.width ? 'width:' + item.width + 'px' : 'width:100%'"
/>
</el-form-item>
</el-col>
</template>
</el-row>
<div style="text-align: center;">
<el-button @click="cancelCreateOrEditController">
{{ 'btn.cancel' | i18nFilter }}
</el-button>
<el-button type="primary" @click="stockCreateOrEditController">
{{ 'btn.confirm' | i18nFilter }}
</el-button>
</div>
</el-form>
</div>
</el-row>
<!-- table -->
<template>
<el-row>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-data="diaList"
:table-config="tableProps"
:is-loading="listLoading"
>
<template>
<method-btn slot="handleBtn" :width="100" :method-list="tableBtn" @clickBtn="tablebtnClick" />
</template>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page-sizes="[3, 5, 10, 20]"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getOrderDetail"
/>
</el-row>
</template>
</template>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">
{{ 'btn.cancel' | i18nFilter }}
</el-button>
</span>
</el-dialog>
</template>
<script>
import Pagination from '@/components/Pagination'
import BaseTable from '@/components/BaseTable'
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import { orderDetail } from '@/api/orderManage/order/order'
import { feeDetailPage, feeDetailAdd, feeDetail, UpdateDetail, deleteDetail } from '@/api/orderManage/fee/fee'
const tableBtn = [
{
type: 'edit',
btnName: 'btn.edit'
},
{
type: 'delete',
btnName: 'btn.delete'
}
]
export default {
components: {
BaseTable,
MethodBtn,
Pagination
},
props: {
dividingLine: {
type: String,
default: ''
},
detailForm: {
type: Array,
default: () => {
return []
}
}
},
data() {
const detailData = {}
const stockFormValidationRules = {}
for (const obj of this.detailForm) {
detailData[obj.param] = obj.defaultSelect || '' // defaultSelect下拉框默认选中项
stockFormValidationRules[obj.param] = []
const newObj = {}
newObj.required = obj.required
newObj.message = this.$i18nForm(['placeholder.input', obj.placeholder])
newObj.trigger = obj.trigger
stockFormValidationRules[obj.param].push(newObj)
}
return {
orderName: '',
orderCode: '',
visible: false,
tableProps: null,
listQuery: {
current: 1,
size: 3,
orderId: '',
queryType: ''
},
detailData, // 中间新增明细的form
stockFormValidationRules,
displayCreateStockButton: true,
total: 0,
diaList: [],
detailEdit: false, // 编辑明细
tableBtn,
listLoading: false
}
},
methods: {
init(tableProps, orderId, feeType) {
// 表格配置 订单id费用类型
this.listQuery.orderId = orderId
this.tableProps = tableProps
this.listQuery.queryType = feeType
this.visible = true
// 根据orderId查订单详情
orderDetail(this.listQuery.orderId).then(res => {
console.log(res)
this.orderName = res.data.name
this.orderCode = res.data.code
})
this.getOrderDetail()
},
getOrderDetail() {
// 查询该订单的明细
this.listLoading = true
feeDetailPage(this.listQuery).then(res => {
this.diaList = res.data.records ? res.data.records : []
this.total = res.data.total
this.listLoading = false
})
},
displayCreateStockForm() {
this.displayCreateStockButton = false
this.detailEdit = false
},
cancelCreateOrEditController() {
// 取消
// 恢复按钮
this.displayCreateStockButton = true
// 清空form中的数据
for (const obj of this.detailForm) {
this.detailData[obj.param] = obj.defaultSelect || ''
}
},
tablebtnClick(raw) {
this.detailData.id = raw.data.id
this.detailEdit = true
if (raw.type === 'edit') {
// 编辑明细,调用接口查最新信息
feeDetail({ id: this.detailData.id }).then(res => {
console.log(res)
this.displayCreateStockButton = false
this.detailData = res.data
})
} else {
// 删除明细
this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}?`, this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
})
.then(() => {
// 删除费用明细
deleteDetail({ id: raw.data.id }).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.listQuery.current = 1
this.getOrderDetail()
}
})
})
})
.catch(() => {})
}
},
// 判断明细当前是编辑,还是新增
stockCreateOrEditController() {
// 确定
if (this.detailEdit) {
// 编辑
this.submitEditStockForm()
} else {
// 新增
this.submitCreateStockForm()
}
},
submitEditStockForm() {
// 编辑 明细表单提交
this.$refs['detailData'].validate(valid => {
if (valid) {
console.log('调用编辑明细接口')
UpdateDetail(this.detailData).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.cancelCreateOrEditController()
this.getOrderDetail()
}
})
})
}
})
},
submitCreateStockForm() {
// 新增 明细表单提交
this.$refs['detailData'].validate(valid => {
if (valid) {
this.detailData.queryType = this.listQuery.queryType
this.detailData.orderId = this.listQuery.orderId
feeDetailAdd(this.detailData).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.displayCreateStockButton = true
this.$refs['detailData'].resetFields()
this.getOrderDetail()
}
})
})
}
})
},
// 弹窗关闭
handleClosed() {
this.cancelCreateOrEditController()
this.$emit('refreshDataList')
this.visible = false
this.orderName = ''
this.orderCode = ''
// this.tableProps = null
this.listQuery = {
current: 1,
size: 3,
orderId: '',
queryType: ''
}
this.diaList = []
}
}
}
</script>
<style lang="scss">
.lb-text-middle {
font-size: 18px;
}
.lb-create-stock-container {
border: 3px dashed #ccc;
width: 235px;
margin: 24px auto 0;
transition: background-color 0.2s ease-out;
&:hover {
background-color: #ccc;
button {
color: white;
}
}
button {
cursor: pointer;
color: #999;
transition: color 0.2s ease-out;
background-color: unset;
border: none;
outline: none;
letter-spacing: 5px;
font-size: 20px;
display: inline-block;
width: 235px;
height: 50px;
}
}
.lb-create-stock-alert {
position: relative;
width: 100%;
border-radius: 8px;
padding: 8px;
min-height: 50px;
overflow: hidden;
background-color: #eee;
}
// 动画效果
// 关键帧
.flip-diagonal-1-tr {
-webkit-animation: flip-diagonal-1-tr 0.5s cubic-bezier(0.455, 0.03, 0.515, 0.955) both;
animation: flip-diagonal-1-tr 0.5s cubic-bezier(0.455, 0.03, 0.515, 0.955) both;
}
/* ----------------------------------------------
* Generated by Animista on 2022-3-11 13:18:44
* Licensed under FreeBSD License.
* See http://animista.net/license for more info.
* w: http://animista.net, t: @cssanimista
* ---------------------------------------------- */
/**
* ----------------------------------------
* animation flip-diagonal-1-tr
* ----------------------------------------
*/
@-webkit-keyframes flip-diagonal-1-tr {
0% {
-webkit-transform: rotate3d(1, 1, 0, 0deg);
transform: rotate3d(1, 1, 0, 0deg);
}
100% {
-webkit-transform: rotate3d(1, 1, 0, 180deg);
transform: rotate3d(1, 1, 0, 180deg);
}
}
@keyframes flip-diagonal-1-tr {
0% {
-webkit-transform: rotate3d(1, 1, 0, 0deg);
transform: rotate3d(1, 1, 0, 0deg);
}
100% {
-webkit-transform: rotate3d(1, 1, 0, 180deg);
transform: rotate3d(1, 1, 0, 180deg);
}
}
</style>
<style scoped>
.lb-create-stock-alert >>> .el-form-item {
text-align: left;
}
.lb-create-stock-alert >>> .el-form-item .el-form-item__label {
padding: 0;
}
</style>

View File

@@ -0,0 +1,216 @@
<template>
<el-dialog :title="'btn.detail' | i18nFilter" :visible.sync="visible" @closed="handleClosed">
<div>
<ul style="list-style: none;display: flex;text-align: left;">
<li style="width: 50%;">{{ $t('module.orderManage.feeInfo.orderName') }}: {{ orderName }}</li>
<li style="width: 50%;">{{ $t('module.orderManage.feeInfo.orderCode') }}: {{ orderCode }}</li>
</ul>
</div>
<div>
<el-tabs v-model="feeType" @tab-click="changeTabs">
<el-tab-pane name="1" :label="$t('module.orderManage.feeInfo.transportationCosts')" />
<el-tab-pane name="2" :label="$t('module.orderManage.feeInfo.staffCosts')" />
<el-tab-pane name="3" :label="$t('module.orderManage.feeInfo.wasteCosts')" />
<el-tab-pane name="4" :label="$t('module.orderManage.feeInfo.equipmentCosts')" />
<el-tab-pane name="5" :label="$t('module.orderManage.feeInfo.otherCosts')" />
</el-tabs>
</div>
<div>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page-sizes="[3, 5, 10, 20]"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList"
/>
</div>
</el-dialog>
</template>
<script>
import { orderDetail } from '@/api/orderManage/order/order'
import BaseTable from '@/components/BaseTable'
import i18n from '@/lang'
import { feeDetailPage } from '@/api/orderManage/fee/fee'
import Pagination from '@/components/Pagination'
import newBasicData from '@/filters/newBasicData'
const tableProps1 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.feeType')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
const tableProps2 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.staffType')
},
{
prop: 'time',
label: i18n.t('module.orderManage.feeInfo.lengthOfwork')
},
{
prop: 'source',
label: i18n.t('module.orderManage.feeInfo.costSource'),
filter: newBasicData('1526436576788647938')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
const tableProps3 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.wasteType')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan')
},
{
prop: 'count',
label: i18n.t('module.orderManage.feeInfo.quantity')
},
{
prop: 'source',
label: i18n.t('module.orderManage.feeInfo.costSource'),
filter: newBasicData('1526436576788647938')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
const tableProps4 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.deviceType')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
const tableProps5 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.otheType')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
export default {
components: { BaseTable, Pagination },
data() {
return {
visible: false,
orderName: '',
orderCode: '',
orderId: '',
feeType: '1',
listQuery: {
current: 1,
size: 3
},
total: 0,
listLoading: true,
list: [],
tableProps: [], // 表格配置项
tableProps1,
tableProps2,
tableProps3,
tableProps4,
tableProps5
}
},
methods: {
init(orderId) {
this.visible = true
this.orderId = orderId
// 根据orderId查订单详情
orderDetail(this.orderId).then(res => {
console.log(res)
this.orderName = res.data.name
this.orderCode = res.data.code
})
this.configTable()
this.getList()
},
changeTabs() {
this.configTable()
this.listQuery.current = 1
this.getList()
},
getList() {
// 查询该订单的明细
this.listQuery.orderId = this.orderId
this.listQuery.queryType = this.feeType
feeDetailPage(this.listQuery).then(res => {
this.list = res.data.records ? res.data.records : []
this.total = res.data.total
this.listLoading = false
})
},
configTable() {
if (this.feeType === '1') {
this.tableProps = this.tableProps1
} else if (this.feeType === '2') {
this.tableProps = this.tableProps2
} else if (this.feeType === '3') {
this.tableProps = this.tableProps3
} else if (this.feeType === '4') {
this.tableProps = this.tableProps4
} else if (this.feeType === '5') {
this.tableProps = this.tableProps5
}
},
handleClosed() {
this.visible = false
this.orderName = ''
this.orderCode = ''
this.orderId = ''
this.feeType = '1'
this.listQuery = {
current: 1,
size: 3
}
this.total = 0
this.listLoading = false
this.list = []
this.tableProps = []
}
}
}
</script>

View File

@@ -0,0 +1,414 @@
<template>
<div style="height:23px;line-height:23px;">
<el-button type="text" size="small" style="font-size: 16px;font-weight: bold;padding: 0;" @click="emitClick">{{ parseFloat(showFee).toFixed(2) }}</el-button>
<edit-detail
v-if="visible"
ref="updateForm"
:dividing-line="dividingTitle"
:detail-form="detailForm"
@refreshDataList="getList"
/>
</div>
</template>
<script>
import EditDetail from './EditDetail.vue'
import i18n from '@/lang'
import newBasicData from '@/filters/newBasicData'
const detailForm1 = [
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.feeType'),
placeholder: i18n.t('module.orderManage.feeInfo.feeType'),
param: 'costType',
required: true,
trigger: 'blur'
},
{
type: 'inputNumber',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan'),
placeholder: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan'),
param: 'cost',
min: 0,
max: 999999999999,
precision: 4,
required: true,
trigger: 'blur'
},
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.remark'),
placeholder: i18n.t('module.orderManage.feeInfo.remark'),
param: 'remark',
required: true,
trigger: 'blur'
}
]
const detailForm2 = [
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.staffType'),
placeholder: i18n.t('module.orderManage.feeInfo.staffType'),
param: 'costType',
required: true,
trigger: 'blur'
},
{
type: 'inputNumber',
label: i18n.t('module.orderManage.feeInfo.lengthOfwork'),
placeholder: i18n.t('module.orderManage.feeInfo.lengthOfwork'),
param: 'time',
min: 0,
max: 999999999999,
precision: 1,
required: true,
trigger: 'blur'
},
{
type: 'select',
label: i18n.t('module.orderManage.feeInfo.costSource'),
placeholder: i18n.t('module.orderManage.feeInfo.costSource'),
selectOptions: [],
param: 'source',
required: true,
trigger: 'blur'
},
{
type: 'inputNumber',
label: i18n.t('module.orderManage.feeInfo.fee'),
placeholder: i18n.t('module.orderManage.feeInfo.fee'),
param: 'cost',
min: 0,
max: 999999999999,
precision: 4,
required: true,
trigger: 'blur'
},
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.remark'),
placeholder: i18n.t('module.orderManage.feeInfo.remark'),
param: 'remark',
required: true,
trigger: 'blur'
}
]
const detailForm3 = [
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.wasteType'),
placeholder: i18n.t('module.orderManage.feeInfo.wasteType'),
param: 'costType',
required: true,
trigger: 'blur'
},
{
type: 'inputNumber',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan'),
placeholder: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan'),
param: 'cost',
required: true,
min: 0,
max: 999999999999,
precision: 4,
trigger: 'blur'
},
{
type: 'inputNumber',
label: i18n.t('module.orderManage.feeInfo.quantity'),
placeholder: i18n.t('module.orderManage.feeInfo.quantity'),
param: 'count',
min: 0,
max: 999999999999,
precision: 2,
required: true,
trigger: 'blur'
},
{
type: 'select',
label: i18n.t('module.orderManage.feeInfo.costSource'),
placeholder: i18n.t('module.orderManage.feeInfo.costSource'),
selectOptions: [],
param: 'source',
required: true,
trigger: 'blur'
},
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.remark'),
placeholder: i18n.t('module.orderManage.feeInfo.remark'),
param: 'remark',
required: true,
trigger: 'blur'
}
]
const detailForm4 = [
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.deviceType'),
placeholder: i18n.t('module.orderManage.feeInfo.deviceType'),
param: 'costType',
required: true,
trigger: 'blur'
},
{
type: 'inputNumber',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan'),
placeholder: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan'),
param: 'cost',
min: 0,
max: 999999999999,
precision: 4,
required: true,
trigger: 'blur'
},
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.remark'),
placeholder: i18n.t('module.orderManage.feeInfo.remark'),
param: 'remark',
required: true,
trigger: 'blur'
}
]
const detailForm5 = [
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.otheType'),
placeholder: i18n.t('module.orderManage.feeInfo.otheType'),
param: 'costType',
required: true,
trigger: 'blur'
},
{
type: 'inputNumber',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan'),
placeholder: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan'),
param: 'cost',
min: 0,
max: 999999999999,
precision: 4,
required: true,
trigger: 'blur'
},
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.remark'),
placeholder: i18n.t('module.orderManage.feeInfo.remark'),
param: 'remark',
required: true,
trigger: 'blur'
}
]
const tableProps1 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.feeType')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
const tableProps2 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.staffType')
},
{
prop: 'time',
label: i18n.t('module.orderManage.feeInfo.lengthOfwork')
},
{
prop: 'source',
label: i18n.t('module.orderManage.feeInfo.costSource'),
filter: newBasicData('1526436576788647938')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
const tableProps3 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.wasteType')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan')
},
{
prop: 'count',
label: i18n.t('module.orderManage.feeInfo.quantity')
},
{
prop: 'source',
label: i18n.t('module.orderManage.feeInfo.costSource'),
filter: newBasicData('1526436576788647938')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
const tableProps4 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.deviceType')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
const tableProps5 = [
{
prop: 'costType',
label: i18n.t('module.orderManage.feeInfo.otheType')
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.fee') + i18n.t('module.orderManage.feeInfo.yuan')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.feeInfo.remark')
}
]
export default {
components: { EditDetail },
props: {
injectData: {
type: Object,
default: () => ({})
}
},
data() {
return {
showFee: '',
showFeeType: '',
visible: false,
dividingTitle: '',
feeSource: JSON.parse(localStorage.getItem('dictObj'))['1526436576788647938'],
listQuery: {
current: 1,
size: 100,
dictTypeId: '1523941494259912706'
},
detailForm: [],
detailForm1,
detailForm2,
detailForm3,
detailForm4,
detailForm5,
tableProps: [], // 表格配置项
tableProps1,
tableProps2,
tableProps3,
tableProps4,
tableProps5
}
},
watch: {
injectData(newVal, oldVal) {
if ((oldVal.tranCost !== newVal.tranCost) || (oldVal.teamCost !== newVal.teamCost) || (oldVal.scrapCost !== newVal.scrapCost) || (oldVal.equipmentCost !== newVal.equipmentCost) || (oldVal.otherCost !== newVal.otherCost)) {
this.init()
}
}
},
mounted() {
this.init()
},
methods: {
emitClick() {
this.visible = true
const arr = []
this.feeSource.map(item => {
arr.push({
id: item.dataCode,
name: item.dataName
})
})
if (this.showFeeType === '2') {
this.detailForm2[2].selectOptions = arr
} else if (this.showFeeType === '3') {
this.detailForm3[3].selectOptions = arr
}
this.$nextTick(() => {
this.$refs.updateForm.init(this.tableProps, this.injectData.orderId, this.showFeeType)
})
},
init() {
if (this.injectData.prop === 'tranCost') {
this.showFee = this.injectData.tranCost ? this.injectData.tranCost : 0
console.log(this.showFee)
this.showFeeType = '1'
this.dividingTitle = i18n.t('module.orderManage.feeInfo.transportationCosts')
this.detailForm = this.detailForm1
this.tableProps = this.tableProps1
} else if (this.injectData.prop === 'teamCost') {
this.showFee = this.injectData.teamCost ? this.injectData.teamCost : 0
this.showFeeType = '2'
this.dividingTitle = i18n.t('module.orderManage.feeInfo.staffCosts')
this.detailForm = this.detailForm2
this.tableProps = this.tableProps2
} else if (this.injectData.prop === 'scrapCost') {
this.showFee = this.injectData.scrapCost ? this.injectData.scrapCost : 0
this.showFeeType = '3'
this.dividingTitle = i18n.t('module.orderManage.feeInfo.wasteCosts')
this.detailForm = this.detailForm3
this.tableProps = this.tableProps3
} else if (this.injectData.prop === 'equipmentCost') {
this.showFee = this.injectData.equipmentCost ? this.injectData.equipmentCost : 0
this.showFeeType = '4'
this.dividingTitle = i18n.t('module.orderManage.feeInfo.equipmentCosts')
this.detailForm = this.detailForm4
this.tableProps = this.tableProps4
} else if (this.injectData.prop === 'otherCost') {
this.showFee = this.injectData.otherCost ? this.injectData.otherCost : 0
this.showFeeType = '5'
this.dividingTitle = i18n.t('module.orderManage.feeInfo.otherCosts')
this.detailForm = this.detailForm5
this.tableProps = this.tableProps5
}
},
getList() {
this.$emit('emitData', { action: 'editFee' })
}
}
}
</script>

View File

@@ -0,0 +1,266 @@
<template>
<div class="app-container">
<head-form
:form-config="headFormConfig"
@headBtnClick="btnClick"
/>
<base-table
:top-btn-config="topBtnConfig"
:page="listQuery.current"
:limit="listQuery.size"
:height="tableH"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
@clickTopBtn="clickTopBtn"
@emitFun="getList"
>
<method-btn
v-if="tableBtn.length"
slot="handleBtn"
:width="trueWidth"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
<add-detailForm
ref="addOrder"
@refreshDataList="getList"
/>
<fee-detail
ref="feeDetails"
/>
</div>
</template>
<script>
import HeadForm from '@/components/basicData/HeadForm'
import i18n from '@/lang'
import { timeFormatter, amountFormatter } from '@/filters'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination'
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import AddDetailForm from './components/AddDetailForm.vue'
import FeeDetail from './components/FeeDetail.vue'
import { orderList } from '@/api/orderManage/order/order'
import { List, deleteFee } from '@/api/orderManage/fee/fee'
import newBasicData from '@/filters/newBasicData'
import feeDetailEdit from './components/feeDetailEdit.vue'
import { tableHeight } from '@/utils/index'
const topBtnConfig = [
{
type: 'add',
btnName: 'btn.add'
}
]
const tableBtn = [
{
type: 'detail',
btnName: 'btn.detail'
},
{
type: 'delete',
btnName: 'btn.delete'
}
]
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.feeInfo.createTime'),
filter: timeFormatter,
minWidth: 160,
isFixed: true
},
{
prop: 'name',
label: i18n.t('module.orderManage.feeInfo.orderName'),
isFixed: true
},
{
prop: 'code',
label: i18n.t('module.orderManage.feeInfo.orderCode')
},
{
prop: 'source',
label: i18n.t('module.orderManage.feeInfo.source'),
filter: newBasicData('1526436576788647938'),
width: 100
},
{
prop: 'status',
label: i18n.t('module.orderManage.feeInfo.state'),
filter: newBasicData('1526063541841727490'),
width: 100
},
{
prop: 'cost',
label: i18n.t('module.orderManage.feeInfo.costAll') + i18n.t('module.orderManage.feeInfo.yuan'),
filter: amountFormatter,
align: 'right'
},
{
prop: 'tranCost',
label: i18n.t('module.orderManage.feeInfo.transportationCosts') + i18n.t('module.orderManage.feeInfo.yuan'),
subcomponent: feeDetailEdit,
align: 'right',
width: 120
},
{
prop: 'teamCost',
label: i18n.t('module.orderManage.feeInfo.staffCosts') + i18n.t('module.orderManage.feeInfo.yuan'),
subcomponent: feeDetailEdit,
align: 'right',
width: 120
},
{
prop: 'scrapCost',
label: i18n.t('module.orderManage.feeInfo.wasteCosts') + i18n.t('module.orderManage.feeInfo.yuan'),
subcomponent: feeDetailEdit,
align: 'right',
width: 120
},
{
prop: 'equipmentCost',
label: i18n.t('module.orderManage.feeInfo.equipmentCosts') + i18n.t('module.orderManage.feeInfo.yuan'),
subcomponent: feeDetailEdit,
align: 'right',
width: 120
},
{
prop: 'otherCost',
label: i18n.t('module.orderManage.feeInfo.otherCosts') + i18n.t('module.orderManage.feeInfo.yuan'),
subcomponent: feeDetailEdit,
align: 'right',
width: 120
}
]
export default {
name: 'Freight',
components: { HeadForm, Pagination, BaseTable, MethodBtn, AddDetailForm, FeeDetail },
data() {
return {
topBtnConfig,
listQuery: {
current: 1,
size: 20,
name: '',
startTime: '',
endTime: ''
},
tableBtn,
trueWidth: 100,
tableH: tableHeight(280),
tableProps,
list: [],
total: 0,
listLoading: false,
headFormConfig: [
{
type: 'input',
label: i18n.t('module.orderManage.feeInfo.orderName'),
placeholder: this.$t('module.orderManage.feeInfo.orderName'),
param: 'keyName'
},
{
type: 'datePicker',
label: this.$t('module.orderManage.track.ProcessTime'),
dateType: 'daterange',
format: 'yyyy-MM-dd',
valueFormat: 'yyyy-MM-dd',
rangeSeparator: '-',
startPlaceholder: this.$t('module.orderManage.feeInfo.startTime'),
endPlaceholder: this.$t('module.orderManage.feeInfo.endTime'),
param: 'timeSlot'
},
{
type: 'button',
btnName: 'btn.search',
name: 'search',
color: 'primary'
}
],
headFormValue: {}
}
},
mounted() {
window.addEventListener('resize', () => {
this.tableH = tableHeight(280)
})
this.getList()
this.getOrderList()
},
methods: {
getList() {
this.listQuery.name = this.headFormValue.keyName
this.listQuery.startTime = this.headFormValue.timeSlot ? this.headFormValue.timeSlot[0] + 'T00:00:00' : ''
this.listQuery.endTime = this.headFormValue.timeSlot ? this.headFormValue.timeSlot[1] + 'T23:59:59' : ''
List(this.listQuery).then(response => {
this.list = response.data.records ? response.data.records : []
this.total = response.data.total
})
},
getOrderList() { // 获取订单列表
const listQuery = {
current: 1,
size: 1000
}
orderList(listQuery).then(response => {
if (response.data.records) {
this.headFormConfig[0].selectOptions = response.data.records
}
})
},
handleClick(raw) {
if (raw.type === 'delete') {
this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}[${raw.data.name}]?`, this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
}).then(() => {
deleteFee({ id: raw.data.id }).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.listQuery.current = 1
this.getList()
}
})
})
}).catch(() => {})
} else {
this.$nextTick(() => {
this.$refs.feeDetails.init(raw.data.orderId)
})
}
},
btnClick(val) {
this.headFormValue = val
// 如果点击的是搜索栏的其他按钮在这里继续写判断
if (this.headFormValue.btnName === 'search') {
this.listQuery.current = 1
this.getList()
}
},
clickTopBtn(val) {
if (val === 'add') {
this.addNew()// 新增
}
},
addNew() {
this.$nextTick(() => {
this.$refs.addOrder.init()
})
}
}
}
</script>

View File

@@ -0,0 +1,12 @@
<!--
* @Author: zwq
* @Date: 2021-01-12 11:13:03
* @LastEditors: zwq
* @LastEditTime: 2021-02-23 13:35:09
* @Description:
-->
<template>
<div id="orderManage">
<router-view />
</div>
</template>

View File

@@ -0,0 +1,197 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-18 18:35:28
* @Description:
-->
<template>
<div class="app-container">
<el-form
ref="formData"
:rules="rules"
:model="formData"
:inline="true"
size="medium"
label-width="80px"
>
<el-form-item :label="$t('module.orderManage.order.WorkOrderName')" prop="workOrderId">
<el-select v-model="formData.workOrderId" filterable :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.WorkOrderName')])" clearable>
<el-option
v-for="item in WorkOrderList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.EquipmentName')" prop="equipmentId">
<el-select v-model="formData.equipmentId" filterable :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.EquipmentName')])" clearable>
<el-option
v-for="item in equipmentList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item :label="$t('module.orderManage.track.event')" prop="equipmentEventId">
<el-input v-model="formData.equipmentEventId" :placeholder="$i18nForm(['placeholder.input', this.$t('module.orderManage.track.event')])" style="width:200px" clearable />
</el-form-item>
<el-form-item :label="$t('module.orderManage.track.parameterName')" prop="equipmentParameterId">
<el-input v-model="formData.equipmentParameterId" :placeholder="$i18nForm(['placeholder.input', this.$t('module.orderManage.track.parameterName')])" style="width:200px" clearable />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="getList()"> {{ 'btn.search' | i18nFilter }} </el-button>
</el-form-item>
</el-form>
<base-table
:page="formData.current"
:limit="formData.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="formData.current"
:limit.sync="formData.size"
@pagination="getList()"
/>
</div>
</template>
<script>
import { workOrderList } from '@/api/orderManage/workOrder/workOrder'
import { equipmentInfoList } from '@/api/basicData/Equipment/equipmentInfo'
import { equipmentEventTrackList } from '@/api/orderManage/infoTrack/infoTrack'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.createTime'),
filter: timeFormatter
},
{
prop: 'name',
label: i18n.t('module.orderManage.order.EquipmentName'),
align: 'center'
},
{
prop: 'paramName',
label: i18n.t('module.orderManage.track.parameterName'),
align: 'center'
},
{
prop: 'paramValue',
label: i18n.t('module.orderManage.track.parameterValue'),
align: 'center'
},
{
prop: 'eventName',
label: i18n.t('module.orderManage.track.event'),
align: 'center'
}
]
export default {
name: 'ScrapInfo',
components: { Pagination, BaseTable },
data() {
return {
trueWidth: 200,
tableProps,
list: [],
total: 0,
listLoading: false,
formData: {
workOrderId: '',
equipmentId: '',
equipmentEventId: '',
equipmentParameterId: '',
current: 1,
size: 10
},
equipmentList: [],
WorkOrderList: [],
rules: {
workOrderId: [{
required: true,
message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.WorkOrderName')]),
trigger: 'change'
}]
}
}
},
created() {
this.init()
},
methods: {
init() {
const listQuery = {
current: 1,
size: 500
}
this.equipmentList.splice(0, this.equipmentList.length)
equipmentInfoList(listQuery).then(response => {
if (response.data.records) {
this.equipmentList = response.data.records
}
})
this.WorkOrderList.splice(0, this.WorkOrderList.length)
workOrderList(listQuery).then(response => {
if (response.data.records) {
this.WorkOrderList = response.data.records
}
})
},
getList() {
this.$refs['formData'].validate((valid) => {
if (valid) {
this.listLoading = true
equipmentEventTrackList(this.formData).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
}
})
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,211 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: juzi
* @LastEditTime: 2022-04-22
* @Description:
-->
<template>
<div class="app-container">
<top-title />
<head-form
:form-config="headFormConfig"
@headBtnClick="btnClick"
/>
<base-table
:page="formData.current"
:limit="formData.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="formData.current"
:limit.sync="formData.size"
@pagination="getList()"
/>
</div>
</template>
<script>
import TopTitle from '@/components/TopTitle'
import HeadForm from '@/components/basicData/HeadForm'
import { workOrderList } from '@/api/orderManage/workOrder/workOrder'
import { equipmentInfoList } from '@/api/basicData/Equipment/equipmentInfo'
import { equipmentParametersTrackList } from '@/api/orderManage/infoTrack/infoTrack'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
// import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
// {
// prop: 'createTime',
// label: i18n.t('module.orderManage.order.createTime'),
// filter: timeFormatter
// },
// {
// prop: 'workOrderNo',
// label: i18n.t('module.orderManage.order.WorkOrderCode'),
// align: 'center'
// },
// {
// prop: 'code',
// label: i18n.t('module.orderManage.order.processCode'),
// align: 'center'
// },
{
prop: 'substrateNo',
label: i18n.t('module.orderManage.order.basePlateId'),
align: 'center'
},
{
prop: 'eventName',
label: i18n.t('module.orderManage.track.event'),
align: 'center'
},
{
prop: 'paramName',
label: i18n.t('module.orderManage.track.parameterName')
},
{
prop: 'paramValue',
label: i18n.t('module.orderManage.track.parameterValue')
},
{
prop: 'eventTime',
label: i18n.t('module.orderManage.track.occurTime'),
align: 'center'
}
]
export default {
name: 'ScrapInfo',
components: { TopTitle, HeadForm, Pagination, BaseTable },
data() {
return {
trueWidth: 200,
tableProps,
list: [],
total: 0,
listLoading: false,
formData: {
substrateNo: '',
workOrderId: '',
equipmentId: '',
equipmentParameterId: '',
current: 1,
size: 10
},
WorkOrderList: [],
equipmentList: [],
headFormConfig: [
{
type: 'select',
label: this.$t('module.orderManage.order.WorkOrderName'),
selectOptions: [],
param: 'workOrderId',
defaultSelect: '',
clearable: false,
required: true
},
{
type: 'select',
label: this.$t('module.orderManage.order.EquipmentName'),
selectOptions: [],
param: 'equipmentId'
},
{
type: 'input',
label: i18n.t('module.orderManage.order.basePlate'),
placeholder: this.$t('module.orderManage.order.basePlate'),
param: 'substrateNo'
},
{
type: 'input',
label: i18n.t('module.orderManage.track.parameterName'),
placeholder: this.$t('module.orderManage.track.parameterName'),
param: 'equipmentParameterId'
},
{
type: 'button',
btnName: 'btn.search',
name: 'search',
color: 'primary'
}
],
headFormValue: {}
}
},
created() {
this.init()
},
methods: {
init() {
const listQuery = {
current: 1,
size: 500
}
this.equipmentList.splice(0, this.equipmentList.length)
equipmentInfoList(listQuery).then(response => {
if (response.data.records) {
this.equipmentList = response.data.records
this.headFormConfig[1].selectOptions = this.equipmentList
}
})
this.WorkOrderList.splice(0, this.WorkOrderList.length)
workOrderList(listQuery).then(response => {
if (response.data.records) {
this.WorkOrderList = response.data.records
this.headFormConfig[0].selectOptions = this.WorkOrderList
this.headFormConfig[0].defaultSelect = this.WorkOrderList[0].id
}
})
},
getList() {
// this.$refs['formData'].validate((valid) => {
// if (valid) {
this.listLoading = true
this.formData.substrateNo = this.headFormValue.substrateNo
this.formData.workOrderId = this.headFormValue.workOrderId
this.formData.equipmentId = this.headFormValue.equipmentId
this.formData.equipmentParameterId = this.headFormValue.equipmentParameterId
equipmentParametersTrackList(this.formData).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
// }
// })
},
btnClick(val) {
this.headFormValue = val
// 如果点击的是搜索栏的其他按钮在这里继续写判断
if (this.headFormValue.btnName === 'search') {
this.getList()
}
}
}
}
</script>

View File

@@ -0,0 +1,185 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: juzi
* @LastEditTime: 2022-04-22
* @Description:
-->
<template>
<div class="app-container">
<top-title />
<head-form
:form-config="headFormConfig"
@headBtnClick="btnClick"
/>
<base-table
:page="formData.current"
:limit="formData.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="formData.current"
:limit.sync="formData.size"
@pagination="getList()"
/>
</div>
</template>
<script>
import TopTitle from '@/components/TopTitle'
import HeadForm from '@/components/basicData/HeadForm'
import { workOrderList } from '@/api/orderManage/workOrder/workOrder'
import { processSubstrateDataTrackList } from '@/api/orderManage/infoTrack/infoTrack'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'workOrderNo',
label: i18n.t('module.orderManage.order.WorkOrderCode'),
align: 'center'
},
// {
// prop: 'processFlowCode',
// label: i18n.t('module.orderManage.order.processCode'),
// align: 'center'
// },
{
prop: 'substrateNo',
label: i18n.t('module.orderManage.order.basePlateId'),
align: 'center'
},
{
prop: 'startProduceTime',
label: i18n.t('module.orderManage.order.loadingTime'),
align: 'center',
filter: timeFormatter
},
{
prop: 'finishProduceTime',
label: i18n.t('module.orderManage.order.unLoadingTime'),
filter: timeFormatter
}
]
export default {
name: 'ScrapInfo',
components: { TopTitle, HeadForm, Pagination, BaseTable },
data() {
return {
trueWidth: 200,
tableProps,
list: [],
total: 0,
listLoading: false,
formData: {
current: 1,
size: 10
},
WorkOrderList: [],
headFormConfig: [
{
type: 'select',
label: this.$t('module.orderManage.order.WorkOrderName'),
selectOptions: [],
param: 'workOrderId',
defaultSelect: '',
clearable: false,
required: true
},
{
type: 'input',
label: i18n.t('module.orderManage.order.basePlateCode'),
placeholder: this.$t('module.orderManage.order.basePlateCode'),
param: 'substrateNo'
},
{
type: 'datePicker',
label: this.$t('module.orderManage.order.loadingTime'),
dateType: 'daterange',
format: 'yyyy-MM-dd',
valueFormat: 'yyyy-MM-dd',
rangeSeparator: '-',
startPlaceholder: this.$t('module.orderManage.order.StartTime'),
endPlaceholder: this.$t('module.orderManage.order.EndTime'),
param: 'timeSlot'
},
{
type: 'button',
btnName: 'btn.search',
name: 'search',
color: 'primary'
}
],
headFormValue: {}
}
},
created() {
this.init()
},
methods: {
init() {
const listQuery = {
current: 1,
size: 500
}
this.WorkOrderList.splice(0, this.WorkOrderList.length)
workOrderList(listQuery).then(response => {
if (response.data.records) {
this.WorkOrderList = response.data.records
this.headFormConfig[0].selectOptions = this.WorkOrderList
this.headFormConfig[0].defaultSelect = this.WorkOrderList[0].id
}
})
},
getList() {
// this.$refs['formData'].validate((valid) => {
// if (valid) {
this.listLoading = true
this.formData.substrateNo = this.headFormValue.substrateNo
this.formData.workOrderId = this.headFormValue.workOrderId
this.formData.startTime = this.headFormValue.timeSlot ? this.headFormValue.timeSlot[0] : ''
this.formData.endTime = this.headFormValue.timeSlot ? this.headFormValue.timeSlot[1] : ''
processSubstrateDataTrackList(this.formData).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
// }
// })
},
btnClick(val) {
this.headFormValue = val
// 如果点击的是搜索栏的其他按钮在这里继续写判断
if (this.headFormValue.btnName === 'search') {
this.getList()
}
}
}
}
</script>

View File

@@ -0,0 +1,224 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-30 19:05:32
* @Description:
-->
<template>
<div class="app-container">
<el-form
ref="formData"
:rules="rules"
:model="formData"
:inline="true"
size="medium"
label-width="80px"
>
<el-form-item :label="$t('module.orderManage.order.WorkOrderName')" prop="workOrderId">
<el-select v-model="formData.workOrderId" filterable :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.WorkOrderName')])" clearable>
<el-option
v-for="item in WorkOrderList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.EquipmentName')" prop="equipmentId">
<el-select v-model="formData.equipmentId" filterable :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.EquipmentName')])" clearable>
<el-option
v-for="item in equipmentList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.basePlateCode')" prop="substrateNo">
<el-input v-model="formData.substrateNo" :placeholder="$i18nForm(['placeholder.input', this.$t('module.orderManage.order.basePlateCode')])" style="width:200px" clearable />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="getList()"> {{ 'btn.search' | i18nFilter }} </el-button>
</el-form-item>
</el-form>
<base-table
:page="formData.current"
:limit="formData.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
>
<method-btn
slot="handleBtn"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="formData.current"
:limit.sync="formData.size"
@pagination="getList()"
/>
<substrateEquipmentDetail v-if="substrateVisible" ref="substrateDetail" />
</div>
</template>
<script>
import { workOrderList } from '@/api/orderManage/workOrder/workOrder'
import { equipmentInfoList } from '@/api/basicData/Equipment/equipmentInfo'
import { substrateEquipmentList } from '@/api/orderManage/infoTrack/infoTrack'
import substrateEquipmentDetail from './substrateEquipmentDetail'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableBtn = [
{
type: 'detail',
btnName: 'btn.detail'
}
]
const tableProps = [
// {
// prop: 'createTime',
// label: i18n.t('module.orderManage.order.createTime'),
// filter: timeFormatter
// },
{
prop: 'name',
label: i18n.t('module.orderManage.order.EquipmentName'),
align: 'center'
},
{
prop: 'substrateNo',
label: i18n.t('module.orderManage.order.basePlateCode'),
align: 'center'
},
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.StartTime'),
align: 'center',
filter: timeFormatter
},
{
prop: 'startProduceTime',
label: i18n.t('module.orderManage.track.ProcessTime'),
align: 'center',
filter: timeFormatter
},
{
prop: 'finishProduceTime',
label: i18n.t('module.orderManage.order.finishTime'),
align: 'center',
filter: timeFormatter
}
]
export default {
name: 'ScrapInfo',
components: { Pagination, BaseTable, MethodBtn, substrateEquipmentDetail },
data() {
return {
trueWidth: 200,
tableProps,
tableBtn,
list: [],
total: 0,
substrateVisible: false,
listLoading: false,
formData: {
substrateNo: '',
workOrderId: '',
equipmentId: '',
current: 1,
size: 10
},
equipmentList: [],
WorkOrderList: [],
rules: {
workOrderId: [{
required: true,
message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.WorkOrderName')]),
trigger: 'change'
}]
}
}
},
created() {
this.init()
},
methods: {
init() {
const listQuery = {
current: 1,
size: 500
}
this.equipmentList.splice(0, this.equipmentList.length)
equipmentInfoList(listQuery).then(response => {
if (response.data.records) {
this.equipmentList = response.data.records
}
})
this.WorkOrderList.splice(0, this.WorkOrderList.length)
workOrderList(listQuery).then(response => {
if (response.data.records) {
this.WorkOrderList = response.data.records
}
})
},
getList() {
this.$refs['formData'].validate((valid) => {
if (valid) {
this.listLoading = true
substrateEquipmentList(this.formData).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
}
})
},
handleClick(raw) {
this.substrateVisible = true
this.$nextTick(() => {
this.$refs.substrateDetail.init(raw)
})
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,118 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 16:37:56
* @LastEditors: zwq
* @LastEditTime: 2021-03-30 19:08:59
* @Description:
-->
<template>
<el-drawer
:append-to-body="true"
:show-close="false"
:visible.sync="visible"
size="55%"
>
<el-card class="box-card">
<div class="text item">
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.order.basePlateCode')+''+dataForm.substrateNo }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.order.EquipmentName')+''+dataForm.name }}</div></el-col>
</el-row>
</div>
</el-card>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
</el-drawer>
</template>
<script>
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination'
import { substrateEquipmentDetail } from '@/api/orderManage/infoTrack/infoTrack'
import { timeFormatter } from '@/filters'
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.createTime'),
filter: timeFormatter
},
{
prop: 'eventName',
label: i18n.t('module.orderManage.track.event'),
align: 'center'
},
{
prop: 'paramName',
label: i18n.t('module.orderManage.track.parameterName'),
align: 'center'
},
{
prop: 'paramValue',
label: i18n.t('module.orderManage.track.parameterValue'),
align: 'center'
}
]
export default {
components: { BaseTable, Pagination },
data() {
return {
visible: false,
tableProps,
list: [],
total: 0,
listLoading: false,
dataForm: {},
listQuery: {
current: 1,
size: 10
}
}
},
methods: {
init() {
this.visible = true
this.listLoading = true
this.getList()
},
getList(raw) {
this.dataForm = raw
this.listQuery.orderId = raw.id
this.listLoading = true
substrateEquipmentDetail(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
}
}
}
</script>
<style scoped>
.drawer-footer {
width: 100%;
margin-top: 50px;
border-top: 1px solid #e8e8e8;
padding: 10px 50px;
text-align: left;
background: #fff;
}
</style>

View File

@@ -0,0 +1,173 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: juzi
* @LastEditTime: 2022-04-22
* @Description:
-->
<template>
<div class="app-container">
<top-title />
<head-form
:form-config="headFormConfig"
@headBtnClick="btnClick"
/>
<base-table
:page="formData.current"
:limit="formData.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="formData.current"
:limit.sync="formData.size"
@pagination="getList()"
/>
</div>
</template>
<script>
import TopTitle from '@/components/TopTitle'
import HeadForm from '@/components/basicData/HeadForm'
import { workOrderList } from '@/api/orderManage/workOrder/workOrder'
import { substrateParametersTrackList } from '@/api/orderManage/infoTrack/infoTrack'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.createTime'),
filter: timeFormatter
},
{
prop: 'name',
label: i18n.t('module.orderManage.order.EquipmentName'),
align: 'center'
},
{
prop: 'paramName',
label: i18n.t('module.orderManage.track.parameterName'),
align: 'center'
},
{
prop: 'paramValue',
label: i18n.t('module.orderManage.track.parameterValue'),
align: 'center'
},
{
prop: 'eventName',
label: i18n.t('module.orderManage.track.event'),
align: 'center'
}
]
export default {
name: 'ScrapInfo',
components: { TopTitle, HeadForm, Pagination, BaseTable },
data() {
return {
trueWidth: 200,
tableProps,
list: [],
total: 0,
listLoading: false,
formData: {
substrateNo: '',
workOrderId: '',
current: 1,
size: 10
},
WorkOrderList: [],
headFormConfig: [
{
type: 'select',
label: this.$t('module.orderManage.order.WorkOrderName'),
selectOptions: [],
param: 'workOrderId',
defaultSelect: '',
clearable: false,
required: true
},
{
type: 'input',
label: i18n.t('module.orderManage.order.basePlateCode'),
placeholder: this.$t('module.orderManage.order.basePlateCode'),
param: 'substrateNo'
},
{
type: 'button',
btnName: 'btn.search',
name: 'search',
color: 'primary'
}
],
headFormValue: {}
}
},
created() {
this.init()
},
methods: {
init() {
const listQuery = {
current: 1,
size: 500
}
this.WorkOrderList.splice(0, this.WorkOrderList.length)
workOrderList(listQuery).then(response => {
if (response.data.records) {
this.WorkOrderList = response.data.records
this.headFormConfig[0].selectOptions = this.WorkOrderList
this.headFormConfig[0].defaultSelect = this.WorkOrderList[0].id
}
})
},
getList() {
// this.$refs['formData'].validate((valid) => {
// if (valid) {
this.listLoading = true
this.formData.substrateNo = this.headFormValue.substrateNo
this.formData.workOrderId = this.headFormValue.workOrderId
substrateParametersTrackList(this.formData).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
// }
// })
},
btnClick(val) {
this.headFormValue = val
// 如果点击的是搜索栏的其他按钮在这里继续写判断
if (this.headFormValue.btnName === 'search') {
this.getList()
}
}
}
}
</script>

View File

@@ -0,0 +1,345 @@
<!--
* @Author: zwq
* @Date: 2021-07-19 15:18:30
* @LastEditors: zwq
* @LastEditTime: 2021-07-19 15:50:36
* @Description:
-->
<template>
<el-row :gutter="10">
<el-form
ref="dataForm"
:model="dataForm"
:rules="rules"
size="medium"
label-width="110px"
style="margin:30px"
label-position="left"
>
<el-col :span="6">
<el-form-item label="grade" prop="grade">
<el-input v-model="dataForm.grade" placeholder="grade" clearable :style="{width: '100%'}" />
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item :label="$t('module.orderManage.erpToMes.mfoCode')" prop="mfoCode">
<el-input v-model="dataForm.mfoCode" :placeholder="$t('module.orderManage.erpToMes.mfoCode')" clearable :style="{width: '100%'}" />
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item :label="$t('module.orderManage.erpToMes.packagingBoxId')" prop="packagingBoxId">
<el-input
v-model="dataForm.packagingBoxId"
oninput="value=value.replace(/[^\d]/g,'')"
:placeholder="$t('module.orderManage.erpToMes.packagingBoxId')"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item :label="$t('module.orderManage.erpToMes.reportTime')" prop="reportTime">
<el-date-picker
v-model="dataForm.reportTime"
:style="{width: '100%'}"
:placeholder="$t('module.orderManage.erpToMes.reportTime')"
clearable
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="totlePower" prop="totlePower">
<el-input
v-model="dataForm.totlePower"
placeholder="totlePower"
oninput="value=value.replace(/[^\d]/g,'')"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId1" prop="substrateId1">
<el-input
v-model="dataForm.substrateId1"
placeholder="substrateId1"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId2" prop="substrateId2">
<el-input
v-model="dataForm.substrateId2"
placeholder="substrateId2"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId3" prop="substrateId3">
<el-input
v-model="dataForm.substrateId3"
placeholder="substrateId3"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId4" prop="substrateId4">
<el-input
v-model="dataForm.substrateId4"
placeholder="substrateId4"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId5" prop="substrateId5">
<el-input
v-model="dataForm.substrateId5"
placeholder="substrateId5"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId6" prop="substrateId6">
<el-input
v-model="dataForm.substrateId6"
placeholder="substrateId6"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId7" prop="substrateId7">
<el-input
v-model="dataForm.substrateId7"
placeholder="substrateId7"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId8" prop="substrateId8">
<el-input
v-model="dataForm.substrateId8"
placeholder="substrateId8"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId9" prop="substrateId9">
<el-input
v-model="dataForm.substrateId9"
placeholder="substrateId9"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId10" prop="substrateId10">
<el-input
v-model="dataForm.substrateId10"
placeholder="substrateId10"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId11" prop="substrateId11">
<el-input
v-model="dataForm.substrateId11"
placeholder="substrateId11"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId12" prop="substrateId12">
<el-input
v-model="dataForm.substrateId12"
placeholder="substrateId12"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId13" prop="substrateId13">
<el-input
v-model="dataForm.substrateId13"
placeholder="substrateId13"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId14" prop="substrateId14">
<el-input
v-model="dataForm.substrateId14"
placeholder="substrateId14"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId15" prop="substrateId15">
<el-input
v-model="dataForm.substrateId15"
placeholder="substrateId15"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId16" prop="substrateId16">
<el-input
v-model="dataForm.substrateId16"
placeholder="substrateId16"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId17" prop="substrateId17">
<el-input
v-model="dataForm.substrateId17"
placeholder="substrateId17"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId18" prop="substrateId18">
<el-input
v-model="dataForm.substrateId18"
placeholder="substrateId18"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId19" prop="substrateId19">
<el-input
v-model="dataForm.substrateId19"
placeholder="substrateId19"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="substrateId20" prop="substrateId20">
<el-input
v-model="dataForm.substrateId20"
placeholder="substrateId20"
clearable
:style="{width: '100%'}"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label-width="0" prop="">
<el-button type="primary" size="medium" @click="submit"> 提交 </el-button>
</el-form-item>
</el-col>
</el-form>
</el-row>
</template>
<script>
import { mesToErpAdd } from '@/api/orderManage/erpToMes'
export default {
components: {},
props: [],
data() {
return {
dataForm: {
grade: undefined,
mfoCode: undefined,
packagingBoxId: undefined,
reportTime: undefined,
totlePower: undefined,
substrateId1: undefined,
substrateId2: undefined,
substrateId3: undefined,
substrateId4: undefined,
substrateId5: undefined,
substrateId6: undefined,
substrateId7: undefined,
substrateId8: undefined,
substrateId9: undefined,
substrateId10: undefined,
substrateId11: undefined,
substrateId12: undefined,
substrateId13: undefined,
substrateId14: undefined,
substrateId15: undefined,
substrateId16: undefined,
substrateId17: undefined,
substrateId18: undefined,
substrateId19: undefined,
substrateId20: undefined
},
rules: {
grade: [],
mfoCode: [],
packagingBoxId: [],
reportTime: [],
totlePower: [],
substrateId1: []
}
}
},
computed: {},
watch: {},
created() {
this.init()
},
mounted() {},
methods: {
init() {
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
})
},
submit() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
mesToErpAdd(this.dataForm).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.init()
}
})
})
}
})
}
}
}
</script>

View File

@@ -0,0 +1,25 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-30 11:22:36
* @Description:
-->
<template>
<span>
{{ injectData.actualQuantity >= 0 && injectData. planQuantity >= 0 ? ((injectData.actualQuantity / injectData.planQuantity) * 100).toFixed(2) + '%' : '' }}
</span>
</template>
<script>
export default {
name: '',
props: {
injectData: {
type: Object,
default: () => ({})
}
}
}
</script>

View File

@@ -0,0 +1,122 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-04-27 09:40:10
* @Description:
-->
<template>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
</template>
<script>
import { list } from '@/api/material-manage/bom-list.js'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'name',
label: i18n.t('module.materialManager.materialbom.name'),
align: 'center'
},
{
prop: 'code',
label: i18n.t('module.materialManager.materialbom.bomcode'),
align: 'center'
},
{
prop: 'quantity',
label: i18n.t('module.materialManager.materialbom.quantity'),
align: 'center'
},
{
prop: 'unit',
label: i18n.t('module.materialManager.materialbom.unit'),
align: 'center'
},
{
prop: 'remark',
label: i18n.t('module.orderManage.order.Remarks'),
align: 'center'
}
]
export default {
name: '',
components: { BaseTable },
props: {
bomId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
tableProps,
list: [],
listLoading: false,
listQuery: {
current: 1,
size: 500,
bomId: ''
}
}
},
methods: {
init() {
this.listQuery.bomId = this.bomId
if (this.bomId) {
this.getList()
} else {
this.$message.error(this.$t('module.orderManage.order.materialBomMessage'))
}
},
getList() {
this.listLoading = true
list(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,437 @@
<!--
* @Author: zwq
* @Date: 2021-03-04 15:58:33
* @LastEditors: juzi
* @LastEditTime: 2022-05-07
* @Description:
-->
<template>
<el-dialog
:title="!dataForm.id ? 'btn.add' : 'btn.edit' | i18nFilter"
:visible.sync="visible"
class="hfxny-dialog"
@open="onOpen"
@close="onClose"
>
<div style="max-height: 50vh; padding-right: 8px; overflow: hidden; overflow-y: scroll;">
<el-row :gutter="24">
<el-form
ref="dataForm"
:model="dataForm"
class="dataForm"
:rules="rules"
label-position="top"
label-width="120px"
>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.OrderCode')" prop="code">
<el-input
v-model="dataForm.code"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.OrderCode')])"
clearable
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.OrderName')" prop="name">
<el-input
v-model="dataForm.name"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.OrderName')])"
clearable
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.ProductName')" prop="productId">
<el-select
v-model="dataForm.productId"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.ProductName')])"
clearable
filterable
:style="{ width: '100%' }"
@change="changeProduct"
>
<el-option
v-for="(item, index) in productOptions"
:key="index"
:label="item.name + '|' + item.code"
:value="item.id"
>
<span style="float: left">{{ item.name }}</span>
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.code }}</span>
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.unit')">
<el-input v-model="temp.unitName" disabled clearable :style="{ width: '100%' }" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.specifications')">
<el-input v-model="temp.specName" disabled clearable :style="{ width: '100%' }" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.PlannedProcessingVolume')" prop="planQuantity">
<el-input-number
v-model="dataForm.planQuantity"
:min="1"
:max="9999999999999"
:style="{ width: '100%' }"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.PlannedProcessingVolume')])"
:step="1"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.price')" prop="price">
<el-input-number
v-model="dataForm.price"
:min="0"
:precision="2"
:max="9999999999999"
:style="{ width: '100%' }"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.price')])"
:step="1"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.packageSpecifications')" prop="packSpec">
<el-select
v-model="dataForm.packSpec"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.packageSpecifications')])"
clearable
:style="{ width: '100%' }"
>
<el-option
v-for="item in packSpecOptions"
:key="item.dataCode"
:label="item.dataName"
:value="item.dataCode"
/>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.customer')" prop="customerId">
<el-select
v-model="dataForm.customerId"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.customer')])"
clearable
filterable
:style="{ width: '100%' }"
>
<el-option
v-for="(item, index) in customerArr"
:key="index"
:label="item.name + (item.address ? '|' + item.address : '')"
:value="item.id"
>
<span style="float: left">{{ item.name }}</span>
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.address }}</span>
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.priority')" prop="priority">
<el-select
v-model="dataForm.priority"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.priority')])"
clearable
:style="{ width: '100%' }"
>
<el-option
v-for="(item, index) in priorityOptions"
:key="index"
:label="item.dataName"
:value="parseInt(item.dataCode)"
/>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.ProductProcess')" prop="processFlowId">
<el-select
v-model="dataForm.processFlowId"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.ProductProcess')])"
clearable
:style="{ width: '100%' }"
>
<el-option v-for="(item, index) in processOptions" :key="index" :label="item.name" :value="item.id" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.workers')" prop="worker">
<el-input
v-model="dataForm.worker"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.workers')])"
clearable
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.PlanningStartTime')" prop="planStartProduceTime">
<el-date-picker
v-model="dataForm.planStartProduceTime"
type="date"
format="yyyy-MM-dd"
:style="{ width: '100%' }"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.PlanningStartTime')])"
clearable
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.PlanningEndTime')" prop="planFinishProduceTime">
<el-date-picker
v-model="dataForm.planFinishProduceTime"
type="date"
format="yyyy-MM-dd"
:style="{ width: '100%' }"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.PlanningEndTime')])"
clearable
/>
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item :label="$t('module.orderManage.order.Remarks')" prop="remark">
<el-input
v-model="dataForm.remark"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.Remarks')])"
clearable
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item :label="$t('module.orderManage.order.Description')" prop="description">
<el-input
v-model="dataForm.description"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.Description')])"
clearable
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
</el-form>
</el-row>
</div>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">{{ 'btn.cancel' | i18nFilter }}</el-button>
<el-button type="primary" @click="dataFormSubmit()">{{ 'btn.confirm' | i18nFilter }}</el-button>
</span>
</el-dialog>
</template>
<script>
import { orderDetail, orderUpdate, orderAdd, orderCode } from '@/api/orderManage/order/order'
import { list as customerList } from '@/api/basicData/CustomerSupplier/customer'
import { list as ProductPoolList } from '@/api/basicData/ProductPool'
import { list as BomList } from '@/api/material-manage/bom'
import { list } from '@/api/art-manage/art.js'
export default {
components: {},
inheritAttrs: false,
data() {
return {
visible: false,
dataForm: {
name: undefined,
code: undefined,
planQuantity: undefined,
productId: null,
customerId: '',
priority: undefined,
processFlowId: undefined,
planStartProduceTime: null,
planFinishProduceTime: null,
remark: undefined,
description: undefined,
dictDataId: '',
price: '',
worker: '',
packSpec: ''
},
temp: {
unitName: '',
specName: ''
},
rules: {
code: [
{
required: true,
message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.OrderCode')]),
trigger: 'blur'
}
],
name: [
{
required: true,
message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.OrderName')]),
trigger: 'blur'
}
],
planQuantity: [
{
required: true,
message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.PlannedProcessingVolume')]),
trigger: 'blur'
}
],
processFlowId: [
{
required: true,
message: this.$i18nForm(['placeholder.select', this.$t('module.orderManage.order.ProductProcess')]),
trigger: 'blur'
}
]
},
unitList: JSON.parse(localStorage.getItem('dictObj'))['1'],
powerClassificationArr: [],
priorityOptions: JSON.parse(localStorage.getItem('dictObj'))['1524577291887898626'],
processOptions: [],
productOptions: [],
packSpecOptions: JSON.parse(localStorage.getItem('dictObj'))['1522121700583342082'],
materialBomOptions: [],
customerArr: [],
productUnitObj: {}
}
},
computed: {},
watch: {},
created() {},
mounted() {},
methods: {
init(id) {
const listQuery = {
current: 1,
size: 500
}
this.dataForm.id = id || ''
this.customerArr.splice(0, this.customerArr.length)
customerList(listQuery).then(response => {
if (response.data.records) {
this.customerArr = response.data.records
}
})
this.materialBomOptions.splice(0, this.materialBomOptions.length)
BomList(listQuery).then(response => {
if (response.data.records) {
this.materialBomOptions = response.data.records
}
})
this.productOptions.splice(0, this.productOptions.length)
ProductPoolList(listQuery).then(response => {
if (response.data.records) {
this.productOptions = response.data.records
response.data.records.map(item => {
this.productUnitObj[item.id] = String(item.dictDataId)
})
}
})
this.processOptions.splice(0, this.processOptions.length)
list(listQuery).then(response => {
if (response.data.records) {
this.processOptions = response.data.records
}
})
this.visible = true
this.$nextTick(() => {
this.onClose()
if (this.dataForm.id) {
orderDetail(this.dataForm.id).then(res => {
this.dataForm = res.data
this.dataForm.dictDataId = res.data.dictDataId + ''
// 获取默认的单位和规格
this.specName(res.data.productId)
this.unitName(res.data.dictDataId)
})
} else {
orderCode().then(res => {
this.dataForm.code = res.data
})
}
})
},
onOpen() {},
onClose() {
this.$refs['dataForm'].resetFields()
this.dataForm.dictDataId = ''
this.temp.unitName = ''
this.temp.specName = ''
},
dataFormSubmit() {
this.$refs['dataForm'].validate(valid => {
if (valid) {
const data = this.dataForm
if (this.dataForm.id) {
orderUpdate(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
} else {
orderAdd(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
}
}
})
},
changeProduct(v) {
this.dataForm.dictDataId = this.productUnitObj[String(v)]
this.unitName(this.dataForm.dictDataId)
this.specName(v)
},
specName(pid) {
this.productOptions &&
this.productOptions.map(item => {
if (pid === item.id) {
this.temp.specName = (item.specifications ? item.specifications : '') + (item.area ? '|' + item.area : '')
}
})
},
unitName(dictDataId) {
this.unitList &&
this.unitList.map(item => {
if (dictDataId === item.dataCode) {
this.temp.unitName = item.dataName
}
})
}
}
}
</script>
<style scoped>
.dataForm >>> .el-form-item__label {
padding: 0;
}
.hfxny-dialog >>> .el-dialog__body {
padding: 30px 30px 30px 40px;
}
</style>

View File

@@ -0,0 +1,237 @@
<!--
* @Author: zwq
* @Date: 2021-02-23 11:05:06
* @LastEditors: gtz
* @LastEditTime: 2022-04-20 13:39:13
* @Description: 工单监控
-->
<template>
<el-drawer :title="'btn.detail' | i18nFilter" :wrapper-closable="false" :visible.sync="visible" size="60%" class="drawer">
<small-title slot="title" :no-padding="true">
{{ 'routerTitle.order.orderManage.orderIssue' | i18nFilter }}
</small-title>
<div class="detailBox">
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.OrderName') }}</p>
<p class="text">{{ stringfilter(dataForm.name) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.OrderCode') }}</p>
<p class="text">{{ stringfilter(dataForm.code) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.ProductName') }}</p>
<p class="text">{{ stringfilter(dataForm.productName) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.ProductCode') }}</p>
<p class="text">{{ stringfilter(dataForm.productCode) }}</p>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.IssueOrderTime') }}</p>
<p class="text">{{ timefilter(dataForm.changeWorkOrder) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.status') }}</p>
<p class="text">{{ stringfilter(statusfilter(dataForm.status)) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ (dataForm.status === 9 ? $t('module.orderManage.order.CompletionTime') : $t('module.orderManage.order.PlanningEndTime')) }}</p>
<p class="text">{{ (dataForm.status === 9 ? timefilter(dataForm.finishProduceTime) : timefilter(dataForm.planFinishProduceTime)) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.specifications') }}</p>
<p class="text">{{ stringfilter(dataForm.specifications) }}</p>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.packageSpecifications') }}</p>
<p class="text">{{ stringfilter(dataForm.packSpec) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.unit') }}</p>
<p class="text">{{ stringfilter(dataForm.dictDataId) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.price') }}</p>
<p class="text">{{ dataForm.price }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.PlannedProcessingVolume') }}</p>
<p class="text">{{ dataForm.planQuantity }}</p>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.ActualFinishedProduct') }}</p>
<p class="text">{{ dataForm.actualQuantity }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.orderDetail.completionSchedule') }}</p>
<p class="text">{{ towNumber((stringfilter(dataForm.actualQuantity / dataForm.planQuantity)) * 100) + '%' }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.orderDetail.processingSquareMeters') }}</p>
<p class="text">{{ dataForm.quantity }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.customer') }}</p>
<p class="text">{{ stringfilter(dataForm.customerName) }}</p>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.NumberOfDamages') }}</p>
<p class="text">{{ dataForm.scrapQuantity }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.EstimatedTime') }}</p>
<p class="text">{{ stringfilter(dataForm.time) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.workers') }}</p>
<p class="text">{{ stringfilter(dataForm.worker) }}</p>
</el-col>
</el-row>
</div>
<order-info v-if="dataForm.status && dataForm.status !== 1" ref="orderInfo" :order-id="OrderId" />
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">{{ 'btn.cancel' | i18nFilter }}</el-button>
</span>
</el-drawer>
</template>
<script>
import SmallTitle from '@/components/BaseDrawer/components/SmallTitle.vue'
import { orderDetail } from '@/api/orderManage/order/order'
import { timeFormatter } from '@/filters'
import orderInfo from './orderInfo'
export default {
name: '',
components: { orderInfo, SmallTitle },
props: {
unitList: {
type: Array,
default: () => []
},
spacList: {
type: Array,
default: () => []
}
},
data() {
return {
visible: false,
packageVisible: false,
scrapVisible: false,
OrderId: '',
activeIndex: '1',
dataForm: {}
}
},
mounted() {
console.log(this.unitList)
},
methods: {
handleClick() {
// this.addOrUpdateVisible = true
// this.$nextTick(() => {
// this.$refs.addOrUpdate.init(id)
// })
},
init(id) {
this.OrderId = id
this.dataForm = {}
this.visible = true
orderDetail(this.OrderId).then((res) => {
const obj = res.data
this.unitList.map((k) => {
if (obj.dictDataId + '' === k.dataCode + '') {
obj.dictDataId = k.dataName
}
})
this.spacList.map((k) => {
if (obj.packSpec + '' === k.dataCode + '') {
obj.packSpec = k.dataName
}
})
this.dataForm = obj
if (this.dataForm.status && this.dataForm.status !== 1) {
this.$nextTick(() => {
this.$refs.orderInfo.init()
})
}
})
},
scrapClick() {
this.scrapVisible = true
this.$nextTick(() => {
this.$refs.scrapDetail.init()
})
},
packageClick() {
this.packageVisible = true
this.$nextTick(() => {
this.$refs.packageDetail.init()
})
},
towNumber(val) {
return val.toFixed(2)
},
timefilter(obj) {
return timeFormatter(obj).substring(0, timeFormatter(obj).lastIndexOf(' '))
},
statusfilter(val) {
const orderStatus = JSON.parse(localStorage.getItem('dictObj'))['1526063541841727490']
let temp = ''
orderStatus && orderStatus.map((item) => {
if (item.dataCode === val + '') {
temp = item.dataName
}
})
return temp
},
stringfilter(objString) {
return objString || ''
}
}
}
</script>
<style scoped>
.drawer >>> .el-drawer {
border-radius: 8px 0 0 8px;
}
.drawer >>> .el-form-item__label {
padding: 0;
}
.drawer >>> .el-drawer__header {
margin: 0;
padding: 32px 32px 24px;
border-bottom: 1px solid #dcdfe6;
margin-bottom: 30px;
}
.detailBox p {
margin: 0;
padding: 0 32px;
}
.detailBox .title {
font-size: 14px;
font-weight: 600;
color: rgba(0,0,0,0.65);
padding-bottom: 10px;
}
.detailBox .text {
font-size: 14px;
font-weight: 400;
color: rgba(102,102,102,0.75);
padding-bottom: 20px;
}
</style>

View File

@@ -0,0 +1,39 @@
<!--
* @Date: 2021-01-07 20:09:37
* @LastEditors: gtz
* @LastEditTime: 2022-04-20 13:40:05
* @FilePath: \mt-bus-fe\src\views\orderManage\order\components\orderDetailBtn.vue
* @Description:
-->
<template>
<span>
<el-button type="text" size="small" @click="emitClick">{{ $t('module.orderManage.order.detail') }}</el-button>
<order-detail v-if="visible" ref="orderDetail" :unit-obj="injectData.unitObj" />
</span>
</template>
<script>
import orderDetail from './orderDetail.vue'
export default {
components: { orderDetail },
props: {
injectData: {
type: Object,
default: () => ({})
}
},
data() {
return {
visible: false
}
},
methods: {
emitClick() {
this.visible = true
this.$nextTick(() => {
this.$refs.orderDetail.init(this.injectData.id)
})
}
}
}
</script>

View File

@@ -0,0 +1,153 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: gtz
* @LastEditTime: 2022-04-20 10:48:00
* @Description:
-->
<template>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
:height="tableH"
/>
</template>
<script>
import { workOrderList } from '@/api/orderManage/workOrder/workOrder'
import mapColumn from '../../components/mapColumn.vue'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import { timeFormatter } from '@/filters'
import { tableHeight } from '@/utils/index'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'startProduceTime',
label: i18n.t('module.orderManage.order.executionTime'),
filter: timeFormatter,
minWidth: 160,
isFixed: true
},
{
prop: 'name',
label: i18n.t('module.orderManage.order.WorkOrderName'),
minWidth: 220,
isFixed: true
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.WorkOrderCode'),
width: 200
},
{
prop: 'actualQuantity',
label: i18n.t('module.orderManage.order.completQuantity')
},
{
prop: 'orderName',
label: i18n.t('module.orderManage.order.OrderName'),
width: 180
},
{
prop: 'quantity',
label: i18n.t('module.orderManage.orderDetail.processingSquareMeters')
},
{
prop: 'finishProduceTime',
label: i18n.t('module.orderManage.order.finishTime'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'productlines',
label: i18n.t('module.orderManage.order.ProductLines'),
subcomponent: mapColumn
},
{
prop: 'workers',
label: i18n.t('module.orderManage.order.workers')
},
{
prop: 'remark',
label: i18n.t('module.orderManage.order.Remarks')
}
]
export default {
name: '',
components: { BaseTable },
props: {
orderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
tableProps,
list: [],
tableH: tableHeight(440),
listLoading: false,
listQuery: {
current: 1,
size: 500,
orderId: ''
}
}
},
mounted() {
window.addEventListener('resize', () => {
this.tableH = tableHeight(440)
})
},
methods: {
init() {
this.listQuery.orderId = this.orderId
this.getList()
},
getList() {
this.listLoading = true
workOrderList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,134 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 16:37:56
* @LastEditors: zwq
* @LastEditTime: 2021-03-25 18:39:26
* @enName:
-->
<template>
<el-dialog
:title="'routerTitle.order.orderManage.orderIssue' | i18nFilter"
:visible.sync="visible"
>
<div style="font-size:20px;margin:0 0 18px 10% ;color:#1890FF;">{{ $t('module.orderManage.orderDetail.remainingPlannedQuantity')+''+remainingPlannedQuantity }}</div>
<el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="110px" @keyup.enter.native="dataFormSubmit()">
<el-form-item :label="$t('module.orderManage.order.WorkOrderName')" prop="name">
<el-input v-model="dataForm.name" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.WorkOrderName')])" clearable />
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.WorkOrderCode')" prop="workOrderNo">
<el-input v-model="dataForm.workOrderNo" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.WorkOrderCode')])" clearable />
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.PlannedProcessingVolume')" prop="planQuantity">
<el-input-number v-model="dataForm.planQuantity" :max="remainingPlannedQuantity" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.PlannedProcessingVolume')])" :step="1" />
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.priority')" prop="priority">
<el-select v-model="dataForm.priority" filterable :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.priority')])" clearable>
<el-option
v-for="item in priorityArr"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.Remarks')" prop="remark">
<el-input v-model="dataForm.remark" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.Remarks')])" clearable />
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">{{ 'btn.cancel' | i18nFilter }}</el-button>
<el-button type="primary" @click="dataFormSubmit()">{{ 'btn.confirm' | i18nFilter }}</el-button>
</span>
</el-dialog>
</template>
<script>
import { workOrderAdd, workOrderCode } from '@/api/orderManage/workOrder/workOrder'
export default {
props: {
orderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
visible: false,
dataForm: {
name: '',
orderId: '',
workOrderNo: '',
priority: 2,
planQuantity: '',
remark: ''
},
priorityArr: [
{
label: '低',
value: 1
},
{
label: '正常',
value: 2
},
{
label: '高',
value: 3
}
],
remainingPlannedQuantity: 0,
dataRule: {
name: [
{ required: true, message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.WorkOrderName')]), trigger: 'blur' }
],
workOrderNo: [
{ required: true, message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.WorkOrderCode')]), trigger: 'blur' }
],
planQuantity: [
{ required: true, message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.PlannedProcessingVolume')]), trigger: 'blur' }
]
}
}
},
methods: {
init(remainingPlannedQuantity) {
this.remainingPlannedQuantity = remainingPlannedQuantity
this.visible = true
this.dataForm.orderId = this.orderId
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
workOrderCode().then(res => {
this.dataForm.workOrderNo = res.data
})
})
},
// 表单提交
dataFormSubmit() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
if (this.dataForm.planQuantity > 0) {
workOrderAdd(this.dataForm).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
} else {
this.$message({
message: '计划加工量不能小于1',
type: 'warning'
})
}
}
})
}
}
}
</script>

View File

@@ -0,0 +1,241 @@
<!--
* @Author: zwq
* @Date: 2021-02-23 11:05:06
* @LastEditors: zwq
* @LastEditTime: 2021-06-22 16:29:19
* @Description: 工单监控
-->
<template>
<div>
<el-card class="box-card">
<div slot="header" class="clearfix">
<el-button style="margin-right:50px" type="success" @click="goback()">{{ 'btn.back' | i18nFilter }}</el-button>
<span><b>{{ $t('module.orderManage.order.OrderCode')+''+stringfilter(dataForm.orderNo) }}</b></span>
</div>
<div class="text item">
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.order.OrderName')+''+stringfilter(dataForm.name) }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.order.process')+''+stringfilter(dataForm.processFlowName) }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.order.customer')+''+stringfilter(dataForm.customerName) }}</div></el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.order.ActualTargetQuantity')+''+stringfilter(dataForm.planQuantity) }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.orderDetail.issuedQuantity')+''+stringfilter(issuedQuantity) }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.orderDetail.remainingPlannedQuantity')+''+stringfilter(remainingPlannedQuantity) }}</div></el-col>
</el-row>
<el-row :gutter="20">
<!-- <el-col :span="6"><div>{{ $t('module.orderManage.orderDetail.issueTime')+''+timefilter(dataForm.startProduceTime) }}</div></el-col> -->
<el-col :span="6"><div>{{ $t('module.orderManage.order.DeliveryTime')+''+timefilter(dataForm.deliveryTime) }}</div></el-col>
</el-row>
<el-row>
<el-col>
<el-button type="primary" :disabled="remainingPlannedQuantity<1" :order-id="orderId" @click="issueClick()"> {{ 'routerTitle.order.orderManage.orderIssue' | i18nFilter }} </el-button>
</el-col>
</el-row>
</div>
</el-card>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
>
<method-btn
slot="handleBtn"
:width="trueWidth"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
<orderIssue-add v-if="addOrUpdateVisible" ref="addOrUpdate" :order-id="orderId" @refreshDataList="getList" />
</div>
</template>
<script>
import { orderDetail } from '@/api/orderManage/order/order'
import { workOrderList, workOrderDelete } from '@/api/orderManage/workOrder/workOrder'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import orderIssueAdd from './orderIssue-add'
import { timeFormatter } from '@/filters'
const tableBtn = [
{
type: 'delete',
btnName: 'btn.delete'
}
]
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.createTime'),
filter: timeFormatter,
align: 'center'
},
{
prop: 'name',
label: i18n.t('module.orderManage.order.WorkOrderName'),
align: 'center'
},
{
prop: 'workOrderNo',
label: i18n.t('module.orderManage.order.WorkOrderCode'),
align: 'center'
},
{
prop: 'planQuantity',
label: i18n.t('module.orderManage.order.PlannedProcessingVolume'),
align: 'center'
},
{
prop: 'remark',
label: i18n.t('module.orderManage.order.Remarks'),
align: 'center'
}
]
export default {
name: '',
components: { Pagination, BaseTable, MethodBtn, orderIssueAdd },
data() {
return {
orderId: '',
addOrUpdateVisible: false,
tableProps,
tableBtn,
list: [],
total: 0,
trueWidth: 200,
listLoading: false,
listQuery: {
current: 1,
size: 10,
orderId: ''
},
dataForm: {},
issuedQuantity: 0,
remainingPlannedQuantity: 0
}
},
created() {
this.orderId = this.$route.query.id
this.init()
},
methods: {
init() {
this.listQuery.orderId = this.orderId
this.issuedQuantity = 0
this.dataForm = {}
orderDetail(this.orderId).then(res => {
this.dataForm = res.data
this.getList()
})
},
handleClick(raw) {
if (raw.type === 'delete') {
this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}[${raw.data.name}]`, this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
}).then(() => {
workOrderDelete(raw.data.id).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.getList()
}
})
})
}).catch(() => {})
}
},
getList() {
this.listLoading = true
this.issuedQuantity = 0
this.remainingPlannedQuantity = this.dataForm.planQuantity
workOrderList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
this.list.forEach(item => {
this.issuedQuantity += item.planQuantity
})
this.remainingPlannedQuantity = this.remainingPlannedQuantity - this.issuedQuantity
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
},
issueClick() {
this.addOrUpdateVisible = true
this.$nextTick(() => {
this.$refs.addOrUpdate.init(this.remainingPlannedQuantity)
})
},
goback() {
this.$router.go(-1)
},
towNumber(val) {
return val.toFixed(2)
},
timefilter(obj) {
return timeFormatter(obj).substring(0, timeFormatter(obj).lastIndexOf(' '))
},
statusfilter(val) {
const orderStatus = {
'1': '新增',
'2': '启动',
'3': '暂停',
'9': '完成'
}
return orderStatus?.[val]
},
stringfilter(objString) {
return objString || ''
}
}
}
</script>
<style scoped>
.text {
font-size: 18px;
}
.item {
margin-bottom: 18px;
}
.clearfix:before,
.clearfix:after {
display: table;
content: "";
}
.clearfix:after {
clear: both
}
.box-card {
font-size: 20px;
margin: auto;
margin-top: 20px;
}
.el-row {
margin-bottom: 20px;
}
.el-col {
border-radius: 4px;
}
</style>

View File

@@ -0,0 +1,148 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-25 16:33:10
* @Description:
-->
<template>
<el-drawer
:visible.sync="visible"
:append-to-body="true"
size="65%"
>
<div slot="title" style=" background-color:#02BCFF;font-size:1.5em;color:white;padding:5px 20px">{{ 'routerTitle.order.orderManage.packageDetail' | i18nFilter }}</div>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
</base-table></el-drawer>
</template>
<script>
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import detailBtn from '../../components/detailBtn'
// import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.reportingTime')
// filter: timeFormatter
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.packageNumber'),
align: 'center'
},
{
prop: 'SAP',
label: i18n.t('module.orderManage.order.SAPMaterial')
},
{
prop: 'power',
label: i18n.t('module.orderManage.order.power')
},
{
prop: 'detail',
label: i18n.t('module.orderManage.order.detail'),
subcomponent: detailBtn
}
]
export default {
name: '',
components: { Pagination, BaseTable },
props: {
orderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
visible: false,
tableProps,
list: [],
total: 0,
listLoading: false,
listQuery: {
current: 1,
size: 10
}
}
},
methods: {
init() {
this.visible = true
this.listQuery = {
current: 1,
size: 10
}
this.getList()
},
getList() {
this.list = [
{
'createTime': '2020-12-21 1344:15',
'code': '110',
'SAP': ''
}
]
// this.listLoading = true
// staffList(this.listQuery).then(response => {
// if (response.data.records) {
// this.list = response.data.records
// } else {
// this.list.splice(0, this.list.length)
// }
// this.total = response.data.total
// this.listLoading = false
// })
},
goback() {
this.visible = false
this.$emit('refreshDataList')
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,120 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-22 14:23:15
* @Description:
-->
<template>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
</template>
<script>
import i18n from '@/lang'
import { reportList } from '@/api/orderManage/order/order'
import BaseTable from '@/components/BaseTable'
import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'reportTime',
label: i18n.t('module.orderManage.order.reportingTime'),
filter: timeFormatter,
align: 'center'
},
{
prop: 'reportType',
label: i18n.t('module.orderManage.order.workReportMethod'),
align: 'center'
},
{
prop: 'workOrderStatus',
label: i18n.t('module.orderManage.order.status'),
align: 'center'
},
{
prop: 'goodQuantity',
label: i18n.t('module.orderManage.order.goodQuantity'),
align: 'center'
},
{
prop: 'scrapQuantity',
label: i18n.t('module.orderManage.order.scrapQuantity'),
align: 'center'
}
]
export default {
name: '',
components: { BaseTable },
props: {
orderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
tableProps,
list: [],
listLoading: false,
listQuery: {
current: 1,
size: 10,
orderId: ''
}
}
},
methods: {
init() {
this.listQuery.orderId = this.orderId
this.getList()
},
getList() {
this.listLoading = true
reportList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,139 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-25 16:33:27
* @Description:
-->
<template>
<el-dialog
:title="'routerTitle.order.orderManage.scrapDetail' | i18nFilter"
:visible.sync="visible"
:before-close="goback"
:append-to-body="true"
width="80%"
>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
</base-table></el-dialog>
</template>
<script>
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
// import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.initiateTime')
// filter: timeFormatter
},
{
prop: 'scrapId',
label: i18n.t('module.orderManage.order.scrapId'),
align: 'center'
},
{
prop: 'scrapLevel',
label: i18n.t('module.orderManage.order.scrapLevel')
}
]
export default {
name: '',
components: { Pagination, BaseTable },
props: {
orderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
visible: false,
tableProps,
list: [],
total: 0,
listLoading: false,
listQuery: {
current: 1,
size: 10
}
}
},
methods: {
init() {
this.visible = true
this.listQuery = {
current: 1,
size: 10
}
this.getList()
},
getList() {
this.list = [
{
'createTime': '2020-12-21 1344:15',
'scrapId': '110',
'scrapLevel': ''
}
]
// this.listLoading = true
// staffList(this.listQuery).then(response => {
// if (response.data.records) {
// this.list = response.data.records
// } else {
// this.list.splice(0, this.list.length)
// }
// this.total = response.data.total
// this.listLoading = false
// })
},
goback() {
this.visible = false
this.$emit('refreshDataList')
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,148 @@
<template>
<el-dialog
:title="'routerTitle.order.orderManage.orderIssue' | i18nFilter"
:visible.sync="visible"
width="40%"
:append-to-body="true"
@closed="cancelWOrkorder"
>
<el-form
ref="dataForm"
style="padding: 24px 0;"
:model="dataForm"
label-width="90px"
:rules="dataFormRules"
>
<el-form-item :label="$t('module.orderManage.order.WorkOrderName')" prop="name">
<el-input
v-model="dataForm.name"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.WorkOrderName')])"
clearable
/>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.WorkOrderCode')" prop="code">
<el-input
v-model="dataForm.code"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.WorkOrderCode')])"
clearable
/>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.PlannedProcessingVolume')" prop="planQuantity">
<el-input-number
v-model="dataForm.planQuantity"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.PlannedProcessingVolume')])"
:style="{ width: '100%' }"
:step="1"
:max="maxPlanQuantity"
:min="0"
/>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.ProductLines')" prop="productlines">
<el-select
v-model="dataForm.productlines"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.ProductLines')])"
multiple
clearable
>
<el-option
v-for="(item, index) in productLineOptions"
:key="index"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.workers')" prop="workers">
<el-input
v-model="dataForm.workers"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.workers')])"
clearable
/>
</el-form-item>
<div style="text-align: center;">
<el-button @click="cancelWOrkorder">
{{ 'btn.cancel' | i18nFilter }}
</el-button>
<el-button type="primary" @click="addWOrkorder">
{{ 'btn.confirm' | i18nFilter }}
</el-button>
</div>
</el-form>
</el-dialog>
</template>
<script>
import { toWorkOrder } from '@/api/orderManage/order/order'
import { getProductLineList, workOrderAdd } from '@/api/orderManage/workOrder/workOrder'
import i18n from '@/lang'
export default {
data() {
return {
visible: false,
maxPlanQuantity: 9999999999,
dataForm: {
name: '',
code: '',
planQuantity: '',
productlines: '',
workers: ''
},
productLineOptions: [],
dataFormRules: {
name: [{ required: true, message: i18n.t('module.orderManage.order.WorkOrderName'), trigger: 'blur' }],
code: [{ required: true, message: i18n.t('module.orderManage.order.WorkOrderCode'), trigger: 'blur' }],
planQuantity: [{ required: true, message: i18n.t('module.orderManage.order.PlannedProcessingVolume'), trigger: 'blur' }],
productlines: [{ required: true, message: i18n.t('module.orderManage.order.ProductLines'), trigger: 'blur' }],
workers: [{ required: true, message: i18n.t('module.orderManage.order.workers'), trigger: 'blur' }]
}
}
},
methods: {
init(id) {
this.visible = true
const listQuery = {
current: 1,
size: 500
}
toWorkOrder(id).then(res => {
this.dataForm = res.data
this.maxPlanQuantity = res.data.planQuantity
getProductLineList(listQuery).then(response => {
if (response.data.records) {
this.productLineOptions = response.data.records
}
})
})
},
cancelWOrkorder() {
// 清空form中的数据
this.visible = false
this.dataForm.name = ''
this.dataForm.code = ''
this.dataForm.planQuantity = ''
this.dataForm.productlines = ''
this.dataForm.workers = ''
},
addWOrkorder() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
workOrderAdd(this.dataForm).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
}
})
this.$emit('refreshDataList')
this.cancelWOrkorder()
})
}
})
}
}
}
</script>
<style lang="scss">
</style>

View File

@@ -0,0 +1,216 @@
<template>
<el-drawer
size="60%"
:visible.sync="visible"
:wrapper-closable="false"
class="drawer"
@close="close"
>
<small-title slot="title" :no-padding="true">
{{ 'routerTitle.order.orderManage.orderIssue' | i18nFilter }}
</small-title>
<div>
<ul class="detailBox">
<li style="width: 50%;">
<p class="title">{{ this.$t('module.orderManage.order.OrderName') | i18nFilter }}</p>
<p class="text">{{ orderName }}</p>
</li>
<li style="width: 50%;">
<p class="title">{{ this.$t('module.orderManage.order.OrderCode') | i18nFilter }}</p>
<p class="text">{{ orderCode }}</p>
</li>
</ul>
</div>
<div class="tableBox">
<small-title>
{{ this.$t('module.orderManage.order.workOrderInfo') | i18nFilter }}
</small-title>
<base-table
:top-btn-config="topBtnConfig"
:page="listQuery.current"
:limit="listQuery.size"
:height="tableH"
:table-data="diaList"
:table-config="tableProps"
@clickTopBtn="clickTopBtn"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList"
/>
</div>
<workorder-add v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="getList" />
</el-drawer>
</template>
<script>
import SmallTitle from '@/components/BaseDrawer/components/SmallTitle.vue'
import WorkorderAdd from './workorder-add.vue'
import Pagination from '@/components/Pagination'
import BaseTable from '@/components/BaseTable'
import { orderDetail } from '@/api/orderManage/order/order'
import { getProductLineList, workOrderList } from '@/api/orderManage/workOrder/workOrder'
import i18n from '@/lang'
import { tableHeight } from '@/utils/index'
const topBtnConfig = [
{
type: 'add',
btnName: 'btn.add'
}
]
const tableProps = [
{
prop: 'name',
label: i18n.t('module.orderManage.order.WorkOrderName')
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.WorkOrderCode')
},
{
prop: 'planQuantity',
label: i18n.t('module.orderManage.order.PlannedProcessingVolume')
},
{
prop: 'productlines',
label: i18n.t('module.orderManage.order.ProductLines')
},
{
prop: 'workers',
label: i18n.t('module.orderManage.order.workers')
}
]
export default {
components: {
BaseTable,
Pagination,
SmallTitle,
WorkorderAdd
},
data() {
return {
topBtnConfig,
orderName: '',
orderCode: '',
visible: false,
tableProps,
tableH: tableHeight(350),
listQuery: {
current: 1,
size: 20,
orderId: ''
},
total: 0,
diaList: [],
productLineOptions: [],
addOrUpdateVisible: false
}
},
mounted() {
window.addEventListener('resize', () => {
this.tableH = tableHeight(350)
})
},
methods: {
init(id) {
const listQuery = {
current: 1,
size: 500
}
this.listQuery.orderId = id
this.visible = true
orderDetail(this.listQuery.orderId).then((res) => {
this.orderName = res.data.name
this.orderCode = res.data.code
this.productLineOptions.splice(0, this.productLineOptions.length)
this.getList()
})
getProductLineList(listQuery).then(response => {
if (response.data.records) {
this.productLineOptions = response.data.records
}
})
},
getList() { // 查询已下发的工单
workOrderList(this.listQuery).then(res => {
if (res.data.records && res.data.records.length > 0) {
const obj = res.data.records
let str = ''
for (const i of obj) {
if (i.productlines.length > 0) {
str += i.productlines.map(item => {
return item.name
})
i.productlines = str
str = ''
} else {
i.productlines = ''
}
}
this.total = res.data.total
this.diaList = obj
} else {
this.total = 0
this.diaList = []
}
})
},
clickTopBtn(val) {
if (val === 'add') {
this.addNew() // 新增
}
},
addNew() {
this.addOrUpdateVisible = true
this.$nextTick(() => {
this.$refs.addOrUpdate.init({ id: this.listQuery.orderId })
})
},
close() {
this.visible = false
}
}
}
</script>
<style scoped>
.drawer >>> .el-drawer {
border-radius: 8px 0 0 8px;
}
.drawer >>> .el-form-item__label {
padding: 0;
}
.drawer >>> .el-drawer__header {
margin: 0;
padding: 32px 32px 24px;
border-bottom: 1px solid #dcdfe6;
margin-bottom: 30px;
}
.detailBox {
list-style: none;
display: flex;
text-align: left;
}
.detailBox p {
margin: 0;
}
.detailBox .title {
font-size: 14px;
font-weight: 600;
color: rgba(0,0,0,0.65);
padding-bottom: 10px;
}
.detailBox .text {
font-size: 14px;
font-weight: 400;
color: rgba(102,102,102,0.75);
}
.tableBox {
padding: 0 32px;
}
</style>

View File

@@ -0,0 +1,522 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: gtz
* @LastEditTime: 2022-07-25 10:35:12
* @Description:
-->
<template>
<div class="app-container">
<head-form :form-config="headFormConfig" @headBtnClick="btnClick" />
<el-row>
<el-tabs v-model="orderStatus" @tab-click="getList">
<el-tab-pane name="1" :label="$t('module.orderManage.order.all')" />
<el-tab-pane name="2" :label="$t('module.orderManage.order.unComplete')" />
<el-tab-pane name="3" :label="$t('module.orderManage.order.complete')" />
</el-tabs>
</el-row>
<base-table
:top-btn-config="topBtnConfig"
:page="listQuery.current"
:limit="listQuery.size"
:height="tableH"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
@clickTopBtn="clickTopBtn"
>
<method-btn
v-if="tableBtn.length"
slot="handleBtn"
:method-list="tableBtn"
:width="trueWidth"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
<order-add v-if="addOrUpdateVisible" ref="addOrUpdate" :unit-list="unitList" @refreshDataList="getList" />
<order-detail v-if="showDetail" ref="showDetail" :unit-list="unitList" :spac-list="packSpacList" />
<workorder v-if="showWorkorder" ref="showWorkorder" :unit-list="unitList" :spac-list="packSpacList" />
</div>
</template>
<script>
import HeadForm from '@/components/basicData/HeadForm'
import { orderList, orderDelete } from '@/api/orderManage/order/order'
import i18n from '@/lang'
import orderAdd from './components/order-add'
import orderDetail from './components/orderDetail'
import workorder from './components/workorder'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import completionSchedule from './components/completionSchedule.vue'
import { timeFormatter, amountFormatter } from '@/filters'
import newBasicData from '@/filters/newBasicData'
import { tableHeight } from '@/utils/index'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const topBtnConfig = [
{
type: 'add',
btnName: 'btn.add'
}
]
const tableBtn = [
{
type: 'detail',
btnName: 'btn.detail'
},
{
type: 'issue',
btnName: 'routerTitle.order.orderManage.orderIssue'
},
{
type: 'edit',
btnName: 'btn.edit',
showParam: {
type: '&',
data: [
{
type: 'equal',
name: 'source',
value: 1
},
{
type: 'unindexof',
name: 'status',
value: [2, 9]
}
]
}
},
{
type: 'delete',
btnName: 'btn.delete',
showParam: {
type: '&',
data: [
{
type: 'equal',
name: 'source',
value: 1
},
{
type: 'unindexof',
name: 'status',
value: [2, 9]
}
]
}
}
]
const tableBtn2 = [
{
type: 'detail',
btnName: 'btn.detail'
}
]
const tablePropsAll = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.createTime'),
filter: timeFormatter,
width: 160,
isFixed: true
},
{
prop: 'name',
label: i18n.t('module.orderManage.order.OrderName'),
isFixed: true
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.OrderCode')
},
// {
// prop: 'changeWorkOrder',
// label: i18n.t('module.orderManage.order.triggerTime'),
// filter: timeFormatter
// },
{
prop: 'priority',
label: i18n.t('module.orderManage.order.priority'),
filter: newBasicData('1524577291887898626'),
width: 100
},
{
prop: 'customerName',
label: i18n.t('module.orderManage.order.customer')
},
{
prop: 'source',
label: i18n.t('module.orderManage.order.source'),
filter: newBasicData('1523941494259912706'),
width: 100
},
{
prop: 'status',
label: i18n.t('module.orderManage.order.status'),
filter: newBasicData('1526063541841727490'),
width: 100
},
{
prop: 'productName',
label: i18n.t('module.orderManage.order.ProductName')
},
{
prop: 'planQuantity',
label: i18n.t('module.orderManage.order.PlannedProcessingVolume'),
width: 100
},
{
prop: 'dictDataId',
label: i18n.t('module.orderManage.order.unit'),
filter: newBasicData('1'),
width: 100
},
{
prop: 'price',
label: i18n.t('module.orderManage.order.price'),
filter: amountFormatter,
align: 'right',
width: 100
}
]
const tablePropsUnComplete = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.createTime'),
filter: timeFormatter,
width: 160,
isFixed: true
},
{
prop: 'name',
label: i18n.t('module.orderManage.order.OrderName'),
isFixed: true
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.OrderCode')
},
// {
// prop: 'changeWorkOrder',
// label: i18n.t('module.orderManage.order.triggerTime'),
// filter: timeFormatter
// },
{
prop: 'planFinishProduceTime',
label: i18n.t('module.orderManage.order.PlanningEndTime'),
width: 160,
filter: timeFormatter
},
{
prop: 'priority',
label: i18n.t('module.orderManage.order.priority'),
filter: newBasicData('1524577291887898626'),
width: 100
},
{
prop: 'customerName',
label: i18n.t('module.orderManage.order.customer'),
width: 100
},
{
prop: 'source',
label: i18n.t('module.orderManage.order.source'),
filter: newBasicData('1523941494259912706'),
width: 100
},
{
prop: 'status',
label: i18n.t('module.orderManage.order.status'),
filter: newBasicData('1526063541841727490'),
width: 100
},
{
prop: 'productName',
label: i18n.t('module.orderManage.order.ProductName')
},
{
prop: 'planQuantity',
label: i18n.t('module.orderManage.order.PlannedProcessingVolume'),
width: 100
},
{
prop: 'dictDataId',
label: i18n.t('module.orderManage.order.unit'),
filter: newBasicData('1'),
width: 100
},
{
prop: 'price',
label: i18n.t('module.orderManage.order.price'),
filter: amountFormatter,
align: 'right',
width: 100
}
]
const tablePropsComplete = [
{
prop: 'name',
label: i18n.t('module.orderManage.order.OrderName'),
isFixed: true
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.OrderCode')
},
// {
// prop: 'changeWorkOrder',
// label: i18n.t('module.orderManage.order.triggerTime'),
// filter: timeFormatter
// },
{
prop: 'finishProduceTime',
label: i18n.t('module.orderManage.order.CompletionTime'),
width: 160,
filter: timeFormatter
},
{
prop: 'customerName',
label: i18n.t('module.orderManage.order.customer'),
width: 100
},
{
prop: 'source',
label: i18n.t('module.orderManage.order.source'),
filter: newBasicData('1523941494259912706'),
width: 100
},
{
prop: 'productName',
label: i18n.t('module.orderManage.order.ProductName')
},
{
prop: 'planQuantity',
label: i18n.t('module.orderManage.order.PlannedProcessingVolume'),
width: 100
},
{
prop: 'dictDataId',
label: i18n.t('module.orderManage.order.unit'),
filter: newBasicData('1'),
width: 100
},
{
prop: 'price',
label: i18n.t('module.orderManage.order.price'),
width: 100
},
{
prop: 'actualQuantity',
label: i18n.t('module.orderManage.order.ActualFinishedProduct'),
width: 100
},
{
prop: 'completionSchedule',
label: i18n.t('module.orderManage.orderDetail.completionSchedule'),
subcomponent: completionSchedule,
width: 100
}
]
export default {
name: 'ScrapInfo',
components: { HeadForm, Pagination, BaseTable, MethodBtn, orderAdd, orderDetail, workorder },
data() {
return {
topBtnConfig,
addOrUpdateVisible: false,
showDetail: false,
showWorkorder: false,
tableBtn,
trueWidth: 150,
tableH: tableHeight(333),
tableProps: [],
list: [],
total: 0,
listLoading: false,
tablePropsAll,
tablePropsUnComplete,
tablePropsComplete,
listQuery: {
current: 1,
size: 20
},
headFormConfig: [
{
type: 'input',
label: i18n.t('module.orderManage.order.OrderName'),
placeholder: this.$t('module.orderManage.order.OrderName'),
param: 'name'
},
{
type: 'datePicker',
label: this.$t('module.orderManage.order.triggerTime'),
dateType: 'daterange',
format: 'yyyy-MM-dd',
valueFormat: 'yyyy-MM-dd',
rangeSeparator: '-',
startPlaceholder: this.$t('module.orderManage.order.StartTime'),
endPlaceholder: this.$t('module.orderManage.order.EndTime'),
param: 'searchTime'
},
{
type: 'button',
btnName: 'btn.search',
name: 'search',
color: 'primary'
}
],
headFormValue: {},
unitList: JSON.parse(localStorage.getItem('dictObj'))['1'],
unitObj: {},
packSpacList: JSON.parse(localStorage.getItem('dictObj'))['1522121700583342082'],
orderStatus: '1'
}
},
created() {
this.tableProps = this.tablePropsAll
},
mounted() {
window.addEventListener('resize', () => {
this.tableH = tableHeight(333)
})
this.unitList.map((item) => {
this.unitObj[item.dataCode] = item.dataName
})
this.getList()
},
methods: {
handleClick(raw) {
if (raw.type === 'delete') {
if (raw.data.status !== 4) {
this.$confirm(
`${this.$t('module.basicData.visual.TipsBefore')}[${raw.data.name}]?`,
this.$t('module.basicData.visual.Tips'),
{
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
}
)
.then(() => {
orderDelete(raw.data.id).then((response) => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.listQuery.current = 1
this.getList()
}
})
})
})
.catch(() => {})
} else {
this.$message({
message: this.$t('module.orderManage.order.warnMessage'),
type: 'warning'
})
}
} else if (raw.type === 'edit') {
this.addNew(raw.data.id)
} else if (raw.type === 'detail') {
this.showDetail = true
this.$nextTick(() => {
this.$refs.showDetail.init(raw.data.id)
})
} else if (raw.type === 'issue') {
this.showWorkorder = true
this.$nextTick(() => {
this.$refs.showWorkorder.init(raw.data.id)
})
} else {
this.$message.warning('功能待开发')
}
},
getList() {
if (this.orderStatus === '1') {
this.listQuery.status = ''
this.tableBtn = tableBtn
this.trueWidth = 150
this.tableProps = this.tablePropsAll
this.topBtnConfig = [{ type: 'add', btnName: 'btn.add' }]
} else if (this.orderStatus === '3') {
this.listQuery.status = 9
this.tableBtn = tableBtn2
this.trueWidth = 80
this.tableProps = this.tablePropsComplete
this.topBtnConfig = []
} else if (this.orderStatus === '2') {
this.listQuery.status = 1
this.tableBtn = tableBtn
this.trueWidth = 150
this.tableProps = this.tablePropsUnComplete
this.topBtnConfig = []
}
this.listLoading = true
this.listQuery.name = this.headFormValue.name
if (this.headFormValue.searchTime && this.headFormValue.searchTime.length) {
this.listQuery.startTime = this.headFormValue.searchTime[0] + 'T00:00:00'
this.listQuery.endTime = this.headFormValue.searchTime[1] + 'T23:59:59'
} else {
this.listQuery.startTime = ''
this.listQuery.endTime = ''
}
orderList(this.listQuery).then((response) => {
console.log(response.data.records)
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
},
// 新增 / 修改
addNew(id) {
this.addOrUpdateVisible = true
this.$nextTick(() => {
this.$refs.addOrUpdate.init(id)
})
},
btnClick(val) {
this.headFormValue = val
// 如果点击的是搜索栏的其他按钮在这里继续写判断
if (this.headFormValue.btnName === 'search') {
this.listQuery.current = 1
this.getList()
}
},
clickTopBtn(val) {
if (val === 'add') {
this.addNew() // 新增
}
}
}
}
</script>

View File

@@ -0,0 +1,321 @@
<template>
<div id="container" ref="container" class="visual-container order-cockpit">
<el-row
class="container-title"
:style="{
height: beilv * 88 + 'px',
lineHeight: beilv * 88 + 'px',
fontSize: beilv * 30 + 'px'
}"
>
<div :style="{ paddingLeft: 645 * beilv + 'px' }">
<img src="../../../assets/img/logo.png" style="width:1.1em;position: relative;top:.4em" alt="">
合肥新能源数字工厂工单管理驾驶舱
</div>
<el-button
type="text"
class="title-button"
:style="{ right: 33 * beilv + 'px', top: 37 * beilv + 'px' }"
@click="changeFullScreen"
>
<svg-icon v-if="isFullScreen" icon-class="unFullScreenView" :style="{fontSize: 33 * beilv + 'px'}" />
<svg-icon v-else icon-class="fullScreenView" :style="{fontSize: 33 * beilv + 'px'}" />
</el-button>
</el-row>
<el-row class="container-main">
<!-- -->
<el-row :style="{ padding: '0 ' + 9 * beilv + 'px' }" :gutter="16 * beilv">
<el-col :span="10">
<base-container :beilv="beilv" :height="412" :title="'工单一览表'" :title-icon="'cockpit_1_1'">
<work-order :beilv="beilv" :order-msg="orderList" />
</base-container>
</el-col>
<el-col :span="14">
<base-container :beilv="beilv" :height="412" :title="'订单池'" :title-icon="'cockpit_1_2'">
<div class="box-padding specil-table1">
<base-table
:page="1"
:limit="12"
:show-index="false"
:beilv="beilv"
:table-config="orderPool"
:table-data="orderPoolList"
/>
</div>
</base-container>
</el-col>
</el-row>
<!-- -->
<el-row :style="{ padding: '0 ' + 9 * beilv + 'px' }">
<el-col :style="{ margin: 16 * beilv + 'px' + ' 0' }" :span="24">
<base-container :beilv="beilv" :height="520" :title="'在途/完成订单监控'" :title-icon="'cockpit_1_3'">
<div class="box-padding specil-table2">
<base-table
:page="1"
:limit="16"
:show-index="false"
:beilv="beilv"
:table-config="orderMonitiring"
:table-data="orderMonitiringList"
/>
</div>
</base-container>
</el-col>
</el-row>
</el-row>
</div>
</template>
<script>
import baseContainer from './components/baseContainer'
import workOrder from './components/workOrder.vue'
import screenfull from 'screenfull'
import BaseTable from './components/baseTable.vue'
import moment from 'moment'
import orderStatus from './components/orderStatus.vue'
const orderPool = [
{
prop: 'customerName',
label: '客户名称',
minWidth: 35.2
},
{
prop: 'orderCode',
label: '订单编号',
minWidth: 32
},
{
prop: 'productName',
label: '产品名称',
minWidth: 32
},
{
prop: 'planNum',
label: '计划加工量',
minWidth: 23.6
},
{
prop: 'planDelivery',
label: '计划交货期',
minWidth: 28.8
},
{
prop: 'status',
label: '订单状态',
subcomponent: orderStatus,
minWidth: 19
}
]
const orderMonitiring = [
{
prop: 'customerName',
label: '客户名称',
minWidth: 35.2
},
{
prop: 'orderCode',
label: '订单编号',
minWidth: 33.2
},
{
prop: 'status',
label: '订单状态',
subcomponent: orderStatus,
minWidth: 27
},
{
prop: 'completion',
label: '完成率',
minWidth: 24.8
},
{
prop: 'yield',
label: '良品率',
minWidth: 24.8
},
{
prop: 'shiftCosts',
label: '班组费用',
minWidth: 24.8
},
{
prop: 'energyCosts',
label: '能耗费用',
minWidth: 29.4
},
{
prop: 'equipmentCost',
label: '设备费用',
minWidth: 29.4
},
{
prop: 'materialCost',
label: '材料费用',
minWidth: 29.4
},
{
prop: 'totalCost',
label: '总费用',
minWidth: 31.6
}
]
export default {
name: 'Cockpit',
components: {
baseContainer,
workOrder,
BaseTable
},
data() {
return {
beilv: 1,
isFullScreen: false,
orderPool,
orderPoolList: [],
orderMonitiring,
orderMonitiringList: [],
orderList: []
}
},
watch: {
isFullScreen: function(val) {
if (val) {
this.beilv = document.body.offsetWidth / 1920
} else {
this.beilv = document.getElementById('container').offsetWidth / 1920
}
},
'sidebar.opened': function(val) {
console.log(val)
if (!this.isFullScreen) {
setTimeout(() => {
this.beilv = document.getElementById('container').offsetWidth / 1920
}, 300)
}
}
},
mounted() {
this.beilv = document.getElementById('container').offsetWidth / 1920
window.addEventListener('resize', () => {
if (this.isFullScreen) {
this.beilv = document.body.offsetWidth / 1920
} else {
this.beilv = document.getElementById('container').offsetWidth / 1920
}
})
this.getMsg()
},
methods: {
getMsg() {
this.orderList = [
{ code: 'ZGD20221024000110', state: '激活', name: '光伏玻璃2.0', line: 'A', workCode: '20221024000110', percentage: '100%' },
{ code: 'ZGD20221028000157', state: '激活', name: '光伏玻璃2.0', line: 'A', workCode: '20221028000157', percentage: '85%' },
{ code: 'ZGD20221030000142', state: '激活', name: '光伏玻璃2.0', line: 'A', workCode: '20221030000142', percentage: '72%' },
{ code: 'ZGD20221030000098', state: '激活', name: '光伏玻璃2.0', line: 'A', workCode: '20221030000098', percentage: '46%' }
]
const compList = ['SHABO沙玻', 'KIBING旗滨', '金晶玻璃', '济南金昊', '东莞佳美特', '汇中矿产', '文盛新材料', '西点化学', '开源塑胶', '奥驰商贸', '竹中科技', '程龙玻璃']
const arr = []
const temp = []
for (let i = 0; i < 20; i++) {
const obj = {}
const sj = parseInt(Math.random() * 200)
obj.customerName = compList[parseInt(Math.random() * (compList.length))]
obj.orderCode = moment().subtract(sj, 'days').format('YYYYMMDD') + '0000' + parseInt(Math.random() * 89 + 10)
obj.productName = '光伏玻璃2.0'
obj.planNum = parseInt(Math.random() * 800 + 100)
obj.planDelivery = moment().add(sj, 'days').format('YYYY-MM-DD')
obj.status = parseInt(Math.random() * 3 + 1)
arr.push(obj)
}
this.orderPoolList = arr
for (let i = 0; i < 20; i++) {
const obj = {}
const sj = parseInt(Math.random() * 200)
obj.customerName = compList[parseInt(Math.random() * (compList.length))]
obj.orderCode = moment().subtract(sj, 'days').format('YYYYMMDD') + '0000' + parseInt(Math.random() * 89 + 10)
obj.status = parseInt(Math.random() * 3 + 1)
obj.completion = obj.status === 1 ? '0.00%' : (obj.status === 3 ? '100%' : parseInt(Math.random() * 100) + '%')
obj.yield = parseInt(Math.random() * 50 + 50) + '%'
obj.shiftCosts = obj.status === 1 ? parseInt(0).toFixed(2) : parseInt(Math.random() * 800 + 100).toFixed(2)
obj.energyCosts = obj.status === 1 ? parseInt(0).toFixed(2) : parseInt(Math.random() * 800 + 100).toFixed(2)
obj.equipmentCost = obj.status === 1 ? parseInt(0).toFixed(2) : parseInt(Math.random() * 800 + 100).toFixed(2)
obj.materialCost = obj.status === 1 ? parseInt(0).toFixed(2) : parseInt(Math.random() * 800 + 100).toFixed(2)
obj.totalCost = parseInt(obj.shiftCosts + obj.energyCosts + obj.equipmentCost + obj.materialCost).toFixed(2)
temp.push(obj)
}
this.orderMonitiringList = temp
},
change() {
this.isFullScreen = screenfull.isFullscreen
},
init() {
if (screenfull.enabled) {
screenfull.on('change', this.change)
}
},
destroy() {
if (screenfull.enabled) {
screenfull.off('change', this.change)
}
},
changeFullScreen() {
if (!screenfull.enabled) {
this.$message({
message: 'you browser can not work',
type: 'warning'
})
return false
}
this.isFullScreen = !this.isFullScreen
screenfull.toggle(this.$refs.container)
}
}
}
</script>
<style lang="scss" scoped>
.visual-container {
width: 100%;
min-width: 960px;
background: url('../../../assets/img/cockpit/cockpit-back.png') no-repeat;
background-size: cover;
.container-title {
width: 100%;
background: url('../../../assets/img/cockpit/title.png') no-repeat;
background-size: 100% 100%;
color: #fff;
.title-button {
color: #00fff0;
font-size: 20px;
position: absolute;
}
}
.container-main {
padding: 16px 8px;
}
.box-padding {
padding: 0 16px;
}
}
</style>
<style lang="scss">
.order-cockpit {
.specil-table1 {
.el-table .cell {
padding-left: 25px;
padding-right: 25px;
}
.el-table--border th:first-child .cell,
.el-table--border td:first-child .cell {
padding-left: 25px;
}
}
.specil-table2 {
.el-table .cell {
padding-left: 50px;
}
.el-table--border th:first-child .cell,
.el-table--border td:first-child .cell {
padding-left: 50px;
}
}
}
</style>

View File

@@ -0,0 +1,145 @@
<!--
* @Author: gtz
* @Date: 2022-01-19 15:58:17
* @LastEditors: zhp
* @LastEditTime: 2022-01-24 09:18:01
* @Description: file content
* @FilePath: \mt-bus-fe\src\views\OperationalOverview\components\baseContainer\index.vue
-->
<template>
<div class="base-container" :style="{height: height * beilv + 'px', fontSize: 12 * beilv + 'px'}">
<div class="line" />
<div class="line line-vertical" />
<div class="line line-right" />
<div class="line line-right-vertical" />
<div class="line line-bottom" />
<div class="line line-bottom-vertical" />
<div class="line line-bottom-right" />
<div class="line line-bottom-right-vertical" />
<div class="bar-item">
<div v-if="title" class="bar-title">
<span>
<svg-icon :icon-class="titleIcon" style="font-size: 1.5em; position: relative; top: .08em" />
{{ title }}
</span>
</div>
<div class="bar-content">
<slot />
</div>
</div>
</div>
</template>
<script>
export default {
name: 'BaseContainer',
props: {
title: {
type: String,
default: ''
},
titleIcon: {
type: String,
default: ''
},
height: {
type: Number,
default: 200
},
baseSize: {
type: Number,
default: 12
},
beilv: {
type: Number,
default: 1
}
},
data() {
return {
curIndex: 0
}
},
mounted() {
},
methods: {
changeTab(num) {
this.curIndex = num
this.$emit('tabSelect', num)
}
}
}
</script>
<style lang="scss" scoped>
.base-container {
color: #fff;
width: 100%;
background-color: rgba($color: #061027, $alpha: 0.15);
position: relative;
border: 2px solid;
border-image: linear-gradient(90deg, rgba(82, 255, 241, 0.6), rgba(95, 190, 249, 0), rgba(82, 255, 241, 0.6)) 2 2;
box-shadow: inset 0px 0px 20px 0px rgba(255,255,255,0.15);
.line {
position: absolute;
border-top: 4px solid #52FFF1;
width: 2em;
top: -.25em;
left: -.25em;
&-vertical {
top: calc(-5em / 12);
left: calc(-1em / 12);
transform: rotate(90deg);
transform-origin: left;
}
&-right {
top: -.25em;
right: -.25em;
left: inherit;
}
&-right-vertical {
top: calc(-5em / 12);
right: calc(-1em / 12);
left: inherit;
transform: rotate(-90deg);
transform-origin: right;
}
&-bottom {
top: inherit;
left: -.25em;
bottom: -.25em;
}
&-bottom-vertical {
top: inherit;
left: calc(-1em / 12);
bottom: calc(-5em / 12);
transform: rotate(-90deg);
transform-origin: left;
}
&-bottom-right {
top: inherit;
left: inherit;
right: -.25em;
bottom: -.25em;
}
&-bottom-right-vertical {
top: inherit;
left: inherit;
right: calc(-1em / 12);
bottom: calc(-5em / 12);
transform: rotate(90deg);
transform-origin: right;
}
}
.bar-title {
width: 100%;
color: #52FFF1;
font-size: 1.5em;
padding: .67em;
}
// .bar-content{
// padding: 1em;
// }
}
</style>

View File

@@ -0,0 +1,176 @@
<!--
* @Date: 2020-12-14 09:07:03
* @LastEditors: gtz
* @LastEditTime: 2022-06-14 11:12:39
* @FilePath: \mt-bus-fe\src\views\OperationalOverview\components\baseTable.vue
* @Description:
-->
<template>
<div class="visual-base-table-container">
<el-table
v-loading="isLoading"
:header-cell-style="{background:'rgba(79,114,136,0.29)',color:'#fff',height: 28 * beilv + 'px',lineHeight: 28 * beilv + 'px',padding: 0,fontSize: 12 * beilv + 'px'}"
:row-style="setRowStyle"
:data="renderData"
border
style="width: 100%; background: transparent"
>
<el-table-column v-if="page && limit && showIndex" prop="_pageIndex" :label="'tableHeader.index' | i18nFilter" :width="70 * beilv" align="center" />
<el-table-column
v-for="item in renderTableHeadList"
:key="item.prop"
:show-overflow-tooltip="showOverflow"
v-bind="item"
>
<template slot-scope="scope">
<component :is="item.subcomponent" v-if="item.subcomponent" :inject-data="{...scope.row, ...item}" @emitData="emitData" />
<span v-else>{{ scope.row[item.prop] | commonFilter(item.filter) }}</span>
</template>
</el-table-column>
<slot name="content" />
</el-table>
</div>
</template>
<script>
import { isObject, isString } from 'lodash'
export default {
name: 'BaseTable',
filters: {
commonFilter: (source, filterType = a => a) => {
return filterType(source)
}
},
props: {
tableData: {
type: Array,
required: true,
validator: val => val.filter(item => !isObject(item)).length === 0
},
tableConfig: {
type: Array,
required: true,
validator: val => val.filter(item => !isString(item.prop) || !isString(item.label)).length === 0
},
isLoading: {
type: Boolean,
required: false
},
page: {
type: Number,
required: false,
default: 1
},
limit: {
type: Number,
required: false,
default: 5
},
beilv: {
type: Number,
default: 1
},
showOverflow: {
type: Boolean,
default: true
},
showIndex: {
type: Boolean,
default: true
}
},
data() {
return {
tableConfigBak: [],
selectedBox: new Array(100).fill(true)
}
},
computed: {
renderData() {
if (this.tableData.length && !this.tableData[0]._pageIndex) {
this.tableData.forEach((item, index) => {
item._pageIndex = (this.page - 1) * this.limit + index + 1
})
}
return this.tableData.slice((this.page - 1) * this.limit, this.page * this.limit)
},
renderTableHeadList() {
return this.tableConfig.filter((item, index) => {
return this.selectedBox[index]
})
}
},
beforeMount() {
this.selectedBox = new Array(100).fill(true)
},
methods: {
emitData(val) {
this.$emit('emitFun', val)
},
setRowStyle(v) {
if (v.rowIndex % 2 === 0) {
return {
background: 'rgba(76,97,123,0.2)',
color: 'rgba(255,255,255,0.5)',
height: 26 * this.beilv + 'px',
lineHeight: 26 * this.beilv + 'px',
padding: 0,
fontSize: 12 * this.beilv + 'px'
}
} else {
return {
background: 'rgba(79,114,136,0.29)',
color: 'rgba(255,255,255,0.5)',
height: 26 * this.beilv + 'px',
lineHeight: 26 * this.beilv + 'px',
padding: 0,
fontSize: 12 * this.beilv + 'px'
}
}
},
setCellStyle(v) {
return {
lineHeight: 23 * this.beilv + 'px'
}
}
}
}
</script>
<style lang="scss">
@import "~@/styles/index.scss";
.visual-base-table-container {
.el-table {
border: 0;
}
.el-table::before,.el-table--border::after {
background-color: transparent;
}
.el-table th,td{
border-color: #0D1728 !important;
padding: 0;
}
.el-table tr {
background: transparent;
}
.el-table__row:hover > td {
background-color: rgba(79,114,136,0.29) !important;
}
.el-table__row--striped:hover > td {
background-color: rgba(79,114,136,0.29) !important;
}
}
.setting {
text-align: right;
padding: 15px;
.setting-box {
width: 100px;
}
i {
color: #aaa;
@extend .pointer;
}
}
</style>

View File

@@ -0,0 +1,42 @@
<template>
<div :style="{ height: 15 * beilv + 'px' }">
<span v-if="this.injectData.status === 3">
<svg-icon icon-class="green_dot" style="font-size: 14px; position: relative; top: .08em" />
已完成
</span>
<span v-if="this.injectData.status === 1">
<svg-icon icon-class="yellow_dot" style="font-size: 14px; position: relative; top: .08em" />
在途
</span>
<span v-if="this.injectData.status === 2">
<svg-icon icon-class="blue_dot" style="font-size: 14px; position: relative; top: .08em" />
已下发
</span>
</div>
</template>
<script>
export default {
name: 'OrderStatus',
props: {
injectData: {
type: Object,
default: () => ({})
}
},
data() {
return {
beilv: 1
}
},
mounted() {
this.beilv = document.getElementById('container').offsetWidth / 1920
window.addEventListener('resize', () => {
if (this.isFullScreen) {
this.beilv = document.body.offsetWidth / 1920
} else {
this.beilv = document.getElementById('container').offsetWidth / 1920
}
})
}
}
</script>

View File

@@ -0,0 +1,101 @@
<template>
<div class="order-box" :style="{ padding: '0 ' + 16 * beilv + 'px', fontSize: 14 * beilv + 'px'}">
<!-- 小块 -->
<div v-for="(item,index) in orderMsg" :key="index" :style="{ padding: 10 * beilv + 'px' + ' 20px ' + 16 * beilv + 'px' + ' 16px'}" class="box">
<p class="line1">
<span>工单编号<span class="light-color">{{ item.code }}</span></span>
<span class="fr">
状态
<span class="state">{{ item.state }}</span>
</span>
</p>
<p :style="{ paddingLeft: 15 * beilv + 'px'}">
<span>产品名称<span class="light-color">{{ item.name }}</span></span>
<span class="fr">
产线
<span class="light-color" style="margin-right: 25px">{{ item.line }}</span>
</span>
</p>
<p :style="{ paddingLeft: 15 * beilv + 'px'}">
<span>所属订单编号<span class="light-color">{{ item.workCode }}</span></span>
</p>
<div :style="{ paddingLeft: 15 * beilv + 'px'}">
<span v-if="item.percentage === '100%'" class="blue-color"> 订单进度</span>
<span v-else class="light-color">订单进度</span>
<span class="light-color fr">{{ item.percentage }}</span>
<div class="progress-box">
<div
class="progress"
:style="{height: 8 * beilv + 'px', width: item.percentage}"
/>
</div>
</div>
</div>
</div>
</template>
<script>
export default {
name: 'WorkOrder',
props: {
orderMsg: {
type: Array,
default: () => []
},
beilv: {
type: Number,
default: 1
}
}
}
</script>
<style lang='scss' scoped>
.order-box {
display: flex;
flex-flow: row wrap;
justify-content: space-between;
.box {
width: 49.5%;
height: 49.5%;
margin-bottom: 8px;
background-image: url('../../../../assets/img/cockpit/module-back.png');
background-repeat: no-repeat;
background-size: 100% 100%;
.light-color {
opacity: 0.5;
}
.blue-color {
color: #3E6AE9;
}
.line1::before {
display: inline-block;
content: "";
width: 4px;
height: 14px;
border-radius: 2px;
margin-right: 8px;
vertical-align: middle;
background-color: #4BFFC8;
}
.state {
display: inline-block;
color: #70F97F;
padding: 2px 4px;
border-radius: 2px;
background: #366F5D;
}
}
}
.progress-box {
border-radius: 5px;
background: #1E2D45;
.progress {
text-align: right;
line-height: 18px;
border-radius: 5px;
padding-right: 5px;
margin-top: 10px;
background: linear-gradient(270deg, #47F8DC 0%, #4573FE 100%);
}
}
</style>

View File

@@ -0,0 +1,143 @@
<!--
* @Author: gtz
* @Date: 2022-01-19 15:58:17
* @LastEditors: zhp
* @LastEditTime: 2022-01-24 09:18:01
* @Description: file content
* @FilePath: \mt-bus-fe\src\views\OperationalOverview\components\baseContainer\index.vue
-->
<template>
<div class="base-container" :style="{height: height * beilv + 'px', fontSize: 12 * beilv + 'px'}">
<div class="line" />
<div class="line line-vertical" />
<div class="line line-right" />
<div class="line line-right-vertical" />
<div class="line line-bottom" />
<div class="line line-bottom-vertical" />
<div class="line line-bottom-right" />
<div class="line line-bottom-right-vertical" />
<div class="bar-item">
<div v-if="title" class="bar-title">
<span>
<svg-icon :icon-class="titleIcon" style="font-size: 1.5em; position: relative; top: .08em" />
{{ title }}
</span>
</div>
<div class="bar-content">
<slot />
</div>
</div>
</div>
</template>
<script>
export default {
name: 'BaseContainer',
props: {
title: {
type: String,
default: ''
},
titleIcon: {
type: String,
default: ''
},
height: {
type: Number,
default: 200
},
baseSize: {
type: Number,
default: 12
},
beilv: {
type: Number,
default: 1
}
},
data() {
return {
curIndex: 0
}
},
mounted() {
},
methods: {
changeTab(num) {
this.curIndex = num
this.$emit('tabSelect', num)
}
}
}
</script>
<style lang="scss" scoped>
.base-container {
color: #fff;
width: 100%;
background-color: rgba($color: #061027, $alpha: 0.15);
position: relative;
border: 2px solid;
border-image: linear-gradient(90deg, rgba(82, 255, 241, 0.6), rgba(95, 190, 249, 0), rgba(82, 255, 241, 0.6)) 2 2;
.line {
position: absolute;
border-top: 4px solid #52FFF1;
width: 2em;
top: -.25em;
left: -.25em;
&-vertical {
top: calc(-5em / 12);
left: calc(-1em / 12);
transform: rotate(90deg);
transform-origin: left;
}
&-right {
top: -.25em;
right: -.25em;
left: inherit;
}
&-right-vertical {
top: calc(-5em / 12);
right: calc(-1em / 12);
left: inherit;
transform: rotate(-90deg);
transform-origin: right;
}
&-bottom {
top: inherit;
left: -.25em;
bottom: -.25em;
}
&-bottom-vertical {
top: inherit;
left: calc(-1em / 12);
bottom: calc(-5em / 12);
transform: rotate(-90deg);
transform-origin: left;
}
&-bottom-right {
top: inherit;
left: inherit;
right: -.25em;
bottom: -.25em;
}
&-bottom-right-vertical {
top: inherit;
left: inherit;
right: calc(-1em / 12);
bottom: calc(-5em / 12);
transform: rotate(90deg);
transform-origin: right;
}
}
.bar-title {
width: 100%;
color: #52FFF1;
font-size: 1.5em;
padding: .67em;
}
// .bar-content{
// padding: 1em;
// }
}
</style>

View File

@@ -0,0 +1,58 @@
<template>
<div class="dataShowBox" :style="{height: height * beilv + 'px'}">
<el-row>
<el-col :span="7" :style="{paddingTop: 24 * beilv + 'px'}">
<div class="numStyle" :style="{marginBottom: 8 * beilv + 'px', fontSize: 32 * beilv + 'px'}">12131</div>
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">品类1</div>
</el-col>
<el-col :span="1">
<span class="aa" :style="{height: 80 * beilv + 'px', marginTop: 16 * beilv + 'px'}" />
</el-col>
<el-col :span="7" :style="{paddingTop: 24 * beilv + 'px'}">
<div class="numStyle" :style="{marginBottom: 8 * beilv + 'px', fontSize: 32 * beilv + 'px'}">12131</div>
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">品类2</div>
</el-col>
<el-col :span="1">
<span class="aa" :style="{height: 80 * beilv + 'px', marginTop: 16 * beilv + 'px'}" />
</el-col>
<el-col :span="7" :style="{paddingTop: 24 * beilv + 'px'}">
<div class="numStyle" :style="{marginBottom: 8 * beilv + 'px', fontSize: 32 * beilv + 'px'}">12131</div>
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">品类3</div>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
props: {
height: {
type: Number,
default: 200
},
beilv: {
type: Number,
default: 1
}
}
}
</script>
<style lang="scss" scoped>
.dataShowBox {
text-align: center;
width: 100%;
background: rgba(0, 255, 241, 0.03);
box-shadow: inset 0px 0px 20px 0px rgba(255, 255, 255, 0.22);
}
.numStyle {
color: #52fff1;
}
.fontStyle {
color: #ffffff;
}
.aa {
display: block;
width: 1px;
background: linear-gradient(153deg, rgba(153, 255, 249, 0) 0%, #60fff1 46%, rgba(96, 255, 241, 0) 100%);
margin: auto;
}
</style>

View File

@@ -0,0 +1,71 @@
<template>
<div class="dataShowMain" :style="{height: height * beilv + 'px'}">
<el-row>
<el-col :span="7" :style="{paddingTop: 64 * beilv + 'px'}">
<div class="numStyle" :style="{marginBottom: 16 * beilv + 'px'}">
<span :style="{fontSize: 24 * beilv + 'px'}">¥</span>
<span :style="{fontSize: 36 * beilv + 'px'}">400,000.</span>
<span :style="{fontSize: 24 * beilv + 'px'}">00</span>
</div>
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}"> 年度销售目标 </div>
</el-col>
<el-col :span="1">
<span class="aa" :style="{height: 160 * beilv + 'px', marginTop: 28 * beilv + 'px'}" />
</el-col>
<el-col :span="7" :style="{paddingTop: 64 * beilv + 'px'}">
<div class="numStyle" :style="{marginBottom: 16 * beilv + 'px'}">
<span :style="{fontSize: 24 * beilv + 'px'}">¥</span>
<span :style="{fontSize: 36 * beilv + 'px'}">417,997.</span>
<span :style="{fontSize: 24 * beilv + 'px'}">00</span>
</div>
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}"> 年度完成值 </div>
</el-col>
<el-col :span="1">
<span class="aa" :style="{height: 160 * beilv + 'px', marginTop: 28 * beilv + 'px'}" />
</el-col>
<el-col :span="7" :style="{paddingTop: 64 * beilv + 'px'}">
<div class="numStyle" :style="{marginBottom: 16 * beilv + 'px'}">
<span :style="{fontSize: 36 * beilv + 'px'}">104.</span>
<span :style="{fontSize: 24 * beilv + 'px'}">5</span>
<span :style="{fontSize: 36 * beilv + 'px'}">%</span>
</div>
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}"> 目标完成率 </div>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
props: {
height: {
type: Number,
default: 200
},
beilv: {
type: Number,
default: 1
}
}
}
</script>
<style scoped>
.dataShowMain {
text-align: center;
height: 90px;
background: rgba(0, 255, 241, 0.03);
box-shadow: inset 0px 0px 20px 0px rgba(255, 255, 255, 0.22);
}
.numStyle {
color: #fff;
font-weight: 600;
}
.fontStyle {
color: #52fff1;
}
.aa {
display: block;
width: 1px;
background: linear-gradient(153deg, rgba(153, 255, 249, 0) 0%, #60fff1 46%, rgba(96, 255, 241, 0) 100%);
margin: auto;
}
</style>

View File

@@ -0,0 +1,191 @@
<template>
<div id="monthChart" :style="{ height: height * beilv + 'px', width:width}" />
</template>
<script>
import echarts from 'echarts'
import resize from './mixins/resize'
export default {
mixins: [resize],
props: {
beilv: {
type: Number,
default: 1
},
height: {
type: String,
default: '300px'
},
width: {
type: String,
default: '100%'
}
},
data() {
return {
chart: null
}
},
mounted() {
this.$nextTick(() => {
this.initChart()
})
},
methods: {
initChart() {
this.chart = echarts.init(document.getElementById('monthChart'))
this.chart.setOption({
legend: {
itemWidth: 15, // 设置legend图标的宽度
itemHeight: 15, // 设置legend图标的高度
right: '10%',
data: ['求和项:金额', '求和项:数量'],
textStyle: {
color: '#ffffff80'
}
},
xAxis: {
type: 'category',
data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'],
axisLine: {
lineStyle: {
color: '#ffffff80'
},
show: false
},
axisTick: {
show: false
}
},
yAxis: [
{
type: 'value',
name: '金额',
position: 'left',
alignTicks: true,
axisLine: {
lineStyle: {
type: 'solid',
color: '#21325980'
},
show: true
},
splitLine: {
lineStyle: {
type: 'solid',
color: '#21325980'
}
},
axisTick: {
show: false
},
axisLabel: {
// y轴文字的配置
textStyle: {
color: '#ffffff80' // Y轴内容文字颜色
},
formatter: '{value} W'
},
nameTextStyle: {
color: '#FFFFFF80',
fontSize: 12
}
},
{
type: 'value',
name: '数量',
position: 'right',
alignTicks: true,
splitLine: {
lineStyle: {
type: 'dashed',
color: '#21325980'
}
},
axisLine: {
lineStyle: {
type: 'dashed',
color: '#21325980'
}
},
axisTick: {
show: false
},
axisLabel: {
// y轴文字的配置
textStyle: {
color: '#ffffff80' // Y轴内容文字颜色
}
},
nameTextStyle: {
color: '#FFFFFF80',
fontSize: 12
}
}
],
series: [
{
name: '求和项:金额',
data: [12, 20, 15, 8, 7, 11, 13, 11, 9, 10.5, 13, 15],
type: 'bar',
barMaxWidth: 'auto',
barWidth: 12,
itemStyle: {
color: {
x: 0,
y: 0,
x2: 1,
y2: 0,
type: 'linear',
colorStops: [
{
offset: 0,
color: '#1EBEAC' // 0% 处的颜色
},
{
offset: 1,
color: '#52FDEA' // 100% 处的颜色
}
]
}
}
},
{
data: [12, 20, 15, 8, 7, 11, 13, 11, 9, 10.5, 13, 15],
type: 'pictorialBar',
barMaxWidth: '20',
symbolPosition: 'end',
symbol: 'diamond',
itemStyle: {
// 设置symbol的颜色
normal: {
color: '#A4FFF5'
}
},
symbolOffset: [0, '-50%'],
symbolSize: [12, 10],
zlevel: 2
},
{
name: '求和项:数量',
type: 'line',
yAxisIndex: 1,
data: [90, 210, 180, 120, 60, 90, 150, 120, 40, 130, 145, 90],
showSymbol: true,
symbol: 'circle',
symbolSize: 5,
color: '#DE9134',
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{ offset: 0, color: 'rgba(255, 145, 52, 1)' }, // 顶端颜色
{ offset: 1, color: 'rgba(255, 145, 52, 0.1)' } // 底部颜色
])
}
}
}
]
})
}
}
}
</script>

View File

@@ -0,0 +1,55 @@
import { debounce } from '@/utils'
export default {
data() {
return {
$_sidebarElm: null,
$_resizeHandler: null
}
},
mounted() {
this.$_resizeHandler = debounce(() => {
if (this.chart) {
this.chart.resize()
}
}, 100)
this.$_initResizeEvent()
this.$_initSidebarResizeEvent()
},
beforeDestroy() {
this.$_destroyResizeEvent()
this.$_destroySidebarResizeEvent()
},
// to fixed bug when cached by keep-alive
// https://github.com/PanJiaChen/vue-element-admin/issues/2116
activated() {
this.$_initResizeEvent()
this.$_initSidebarResizeEvent()
},
deactivated() {
this.$_destroyResizeEvent()
this.$_destroySidebarResizeEvent()
},
methods: {
// use $_ for mixins properties
// https://vuejs.org/v2/style-guide/index.html#Private-property-names-essential
$_initResizeEvent() {
window.addEventListener('resize', this.$_resizeHandler)
},
$_destroyResizeEvent() {
window.removeEventListener('resize', this.$_resizeHandler)
},
$_sidebarResizeHandler(e) {
if (e.propertyName === 'width') {
this.$_resizeHandler()
}
},
$_initSidebarResizeEvent() {
this.$_sidebarElm = document.getElementsByClassName('sidebar-container')[0]
this.$_sidebarElm && this.$_sidebarElm.addEventListener('transitionend', this.$_sidebarResizeHandler)
},
$_destroySidebarResizeEvent() {
this.$_sidebarElm && this.$_sidebarElm.removeEventListener('transitionend', this.$_sidebarResizeHandler)
}
}
}

View File

@@ -0,0 +1,160 @@
<template>
<div>
<div :id="id" :style="{ height: height * beilv + 'px', width:width}" />
</div>
</template>
<script>
import echarts from 'echarts'
import resize from './mixins/resize'
const color1 = new echarts.graphic.LinearGradient(
0,
1,
0,
0,
[
{ offset: 0, color: '#E77657' },
{ offset: 1, color: '#53222A' }
],
false
)
const color2 = new echarts.graphic.LinearGradient(
0,
0,
1,
0,
[
{ offset: 0, color: '#31AFF0' },
{ offset: 1, color: '#0B3A52' }
],
false
)
const color3 = new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{ offset: 0, color: '#F9A237' },
{ offset: 1, color: '#6E4A27' }
],
false
)
const color4 = new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{ offset: 0, color: '#7AEAE0' },
{ offset: 1, color: '#18433F' }
],
false
)
export default {
mixins: [resize],
props: {
id: {
type: String,
default: 'OverviewLine'
},
beilv: {
type: Number,
default: 1
},
height: {
type: String,
default: '300px'
},
width: {
type: String,
default: '100%'
},
pieData: {
type: Array,
default: () => []
},
formatter: {
type: String,
default: '{firstLine|{b}} \n {secondLine|{c}}'
},
pieStyle: {
type: Object,
default: () => {}
}
},
data() {
return {
chart: null
}
},
mounted() {
this.$nextTick(() => {
this.initChart()
})
},
beforeDestroy() {
if (!this.chart) {
return
}
this.chart.dispose()
this.chart = null
},
methods: {
initChart() {
this.chart = echarts.init(document.getElementById(this.id))
this.chart.setOption({
tooltip: {
trigger: 'item'
},
color: [color1, color2, color3, color4],
series: [
{
name: 'Access From',
type: 'pie',
radius: ['60%', '90%'],
hoverAnimation: false,
itemStyle: {
borderRadius: 0,
borderWidth: 3,
borderColor: '#060F20'
},
labelLine: {
show: true,
length: 0,
length2: this.beilv * this.pieStyle.line_s,
smooth: true,
lineStyle: {
width: 1,
cap: 'butt'
}
},
label: {
formatter: this.pieStyle.formatter,
minMargin: 5,
rich: {
firstLine: {
fontSize: this.beilv * 14,
lineHeight: this.beilv * 30,
color: '#ffffff80'
},
secondLine: {
fontSize: this.beilv * this.pieStyle.num_fs,
color: '#fff'
}
}
},
data: this.pieStyle.pieData,
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
}
}
]
})
}
}
}
</script>

View File

@@ -0,0 +1,55 @@
<template>
<el-row class="progress-main-box">
<el-col :span="24">
<template v-for="(item,index) in productData">
<el-row :key="index" :style="{marginBottom: 18 * beilv + 'px'}">
<el-col :span="4" style="text-align: right;padding-right:5px">{{ item.name }}</el-col>
<el-col :span="20">
<div
class="progress"
:class="index%2===0?'progress1':'progress2'"
:style="{height: 18 * beilv + 'px', width: item.percentage}"
>
{{ item.number }}
</div>
</el-col>
</el-row>
</template>
</el-col>
</el-row>
</template>
<script>
export default {
naem: 'progressBox',
props: {
productData: {
type: Array,
default: () => []
},
beilv: {
type: Number,
default: 1
}
},
data() {
return {}
}
}
</script>
<style scoped>
.progress-main-box {
padding: 0 10px;
}
.progress {
text-align: right;
line-height: 18px;
border-radius: 5px;
padding-right: 5px;
}
.progress1 {
background: linear-gradient(270deg, #83f7ec 0%, rgba(76, 236, 213, 0.05) 100%);
}
.progress2 {
background: linear-gradient(270deg, #3ac6fc 0%, rgba(56, 195, 255, 0.05) 100%);
}
</style>

View File

@@ -0,0 +1,204 @@
<template>
<div class="ringChartContainer">
<ul v-if="orderList.length > 0" class="pieBox">
<li v-for="(item,index) in orderList" :key="index">
<div>
<span class="title">{{ item.name }}</span>
</div>
<div :id="item.id" style="height:250px;width:250px" />
</li>
</ul>
<div v-else class="imgBox">
<img src="./../../../../assets/img/empty.png" alt="">
</div>
</div>
</template>
<script>
import echarts from 'echarts'
import i18n from '@/lang'
export default {
props: {
orderList: {
type: Array,
default: () => {
return []
}
}
},
data() {
return {
dataS: []
}
},
mounted() {
},
methods: {
initChart() {
for (const item of this.orderList) {
var chartDom = document.getElementById(item.id)
var myChart = echarts.init(chartDom)
var outQuantity = item.outQuantity ? item.outQuantity : 0 // 加工数量
var scrapQuantity = item.scrapQuantity ? item.scrapQuantity : 0 // 损坏数量
var planQuantity = item.planQuantity ? item.planQuantity : 0 // 计划加工量
var syQuantity = (planQuantity - outQuantity - scrapQuantity) > 0 ? (planQuantity - outQuantity - scrapQuantity) : 0// 剩余数量
var option = {
color: ['#2C3AAE', '#C5E951', '#DCE4F1'],
tooltip: {
trigger: 'item'
},
legend: {
icon: 'circle',
bottom: '5%',
left: 'center',
itemWidth: 8,
itemHeight: 8
},
series: [
// 内圆1
{
type: 'pie',
zlevel: 2, // 层级
radius: ['46%', '50%'],
center: ['50%', '45%'],
itemStyle: {
normal: {
shadowBlur: 10,
shadowColor: 'rgba(209, 204, 214, 0.64)',
color: '#fff',
label: {
show: false
},
labelLine: {
show: false
}
}
},
tooltip: {
show: false
},
hoverAnimation: false,
data: [100]
},
// 外环1
{
type: 'pie',
radius: ['70%', '71%'],
center: ['50%', '45%'],
zlevel: 1, // 层级
itemStyle: {
normal: {
shadowBlur: 10,
shadowColor: 'rgba(0,0,0,.5)',
color: '#fff',
label: {
show: false
},
labelLine: {
show: false
}
}
},
tooltip: {
show: false
},
hoverAnimation: false,
data: [100]
},
// 占比环
{
name: 'Access From',
type: 'pie',
radius: ['50%', '70%'],
center: ['50%', '45%'],
clockWise: true,
avoidLabelOverlap: false,
hoverAnimation: false,
silent: true,
label: {
normal: {
show: true,
position: 'center',
color: '#9A9EBA',
formatter: ['{a|' + planQuantity + '}', '{b|' + i18n.t('module.orderManage.orderMonitoring.orderQuantity') + '}'].join('\n\n'),
rich: {
a: {
color: '#2F3AA7',
fontSize: 24
},
b: {
color: '#1E2AA8',
fontSize: 12
}
}
}
},
labelLine: {
show: false
},
data: [
{
value: outQuantity,
name: i18n.t('module.orderManage.orderMonitoring.processingCapacity') + outQuantity,
itemStyle: {
normal: {
color: '#2C3AAE'
}
}
},
{
value: scrapQuantity,
name: i18n.t('module.orderManage.orderMonitoring.damageQuantity') + scrapQuantity,
itemStyle: {
normal: {
color: '#C5E951'
}
}
},
{
value: syQuantity,
itemStyle: {
normal: {
color: '#DCE4F1'
}, // 默认颜色
emphasis: {
color: '#DCE4F1'
} // hover 颜色
}
}
]
}
]
}
myChart.setOption(option, true)
}
}
}
}
</script>
<style scoped>
ul {
list-style: none;
margin: 0;
padding: 0;
}
.pieBox {
display: flex;
flex-flow: row wrap;
}
.pieBox > li {
background-color: rgba(247, 248, 255, 0.7);
margin: 0 16px 16px 0;
padding: 16px;
}
.pieBox .title {
font-size: 14px;
font-family: PingFangSC-Semibold, PingFang SC;
font-weight: 600;
color: rgba(0, 0, 0, 0.85);
}
.imgBox {
text-align: center;
padding-top: 20px;
}
</style>

View File

@@ -0,0 +1,200 @@
<template>
<div id="saleTop" :style="{ height: height * beilv + 'px', width:width}" />
</template>
<script>
import echarts from 'echarts'
import resize from './mixins/resize'
export default {
mixins: [resize],
props: {
beilv: {
type: Number,
default: 1
},
height: {
type: String,
default: '300px'
},
width: {
type: String,
default: '100%'
}
},
data() {
return {
chart: null
}
},
mounted() {
this.$nextTick(() => {
this.initChart()
})
},
beforeDestroy() {
if (!this.chart) {
return
}
this.chart.dispose()
this.chart = null
},
methods: {
initChart() {
this.chart = echarts.init(document.getElementById('saleTop'))
this.chart.setOption({
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow'
}
},
grid: {
left: '3%',
right: '4%',
bottom: '3%',
containLabel: true
},
xAxis: [
{
type: 'category',
data: ['员工2', '员工1', '员工3'],
axisTick: {
show: false
},
axisLine: {
show: false,
lineStyle: {
color: '#fff'
}
}
}
],
yAxis: [
{
type: 'value',
show: false
}
],
series: [
{
name: 'Direct',
type: 'bar',
barWidth: 32,
itemStyle: {
// 柱状颜色和圆角
barBorderRadius: [16, 16, 16, 16] // (顺时针左上,右上,右下,左下)
},
label: {
// 柱体上显示数值
show: true, // 开启显示
position: 'top', // 在上方显示
textStyle: {
// 数值样式
fontSize: this.beilv * 22,
color: '#FFF89F'
},
formatter: '{c}'
},
data: [
{
value: 100,
itemStyle: {
color: new echarts.graphic.LinearGradient(
0,
1,
0,
0,
[
{ offset: 0, color: '#281B0E' },
{ offset: 1, color: '#3AC6FC' }
],
false
)
}
},
{
value: 205,
itemStyle: {
color: new echarts.graphic.LinearGradient(
0,
1,
0,
0,
[
{ offset: 0, color: '#281B0E' },
{ offset: 1, color: '#F9A237' }
],
false
)
}
},
{
value: 152,
itemStyle: {
color: new echarts.graphic.LinearGradient(
0,
1,
0,
0,
[
{ offset: 0, color: '#281B0E' },
{ offset: 1, color: '#83F7EC' }
],
false
)
}
}
]
},
{
type: 'pictorialBar',
name: 'pictorial element',
symbolSize: 50,
z: 10,
data: [
{
value: 100,
symbol:
'image://data:',
xAxis: 0,
symbolPosition: 'end',
symbolOffset: [0, this.beilv * -200 + '%']
},
{
value: 205,
symbol:
'image://',
xAxis: 1,
symbolPosition: 'end',
symbolOffset: [0, this.beilv * -200 + '%']
},
{
value: 152,
symbol:
'image://data:',
xAxis: 2,
symbolPosition: 'end',
symbolOffset: [0, this.beilv * -200 + '%']
}
]
}
]
})
}
}
}
</script>
<style scoped>
.progress {
width: 12px;
border-radius: 5px;
}
.progress1 {
background: linear-gradient(180deg, #3ac6fc 0%, rgba(56, 195, 255, 0.05) 100%);
}
.progress2 {
background: linear-gradient(346deg, #281b0e 0%, #f9a237 100%);
}
.progress3 {
background: linear-gradient(180deg, #83f7ec 0%, rgba(76, 236, 213, 0.05) 100%);
}
</style>

View File

@@ -0,0 +1,239 @@
<template>
<div class="app-container">
<head-form :form-config="headFormConfig" @headBtnClick="btnClick" />
<el-tabs v-model="activeName" @tab-click="toggleClick">
<el-tab-pane :label="this.$t('module.orderManage.orderMonitoring.datasheets')" name="dataList" />
<el-tab-pane :label="this.$t('module.orderManage.orderMonitoring.donutChart')" name="ringChart" />
</el-tabs>
<!-- 数据列表 -->
<div v-if="showList">
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:height="tableH"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
>
<method-btn
v-if="tableBtn.length"
slot="handleBtn"
:width="trueWidth"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
</div>
<!-- 环状图 -->
<ring-chart v-else ref="ringCharts" :order-list="list" />
</div>
</template>
<script>
import HeadForm from '@/components/basicData/HeadForm'
import i18n from '@/lang'
import { timeFormatter, rateFormatter } from '@/filters'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import { orderMonitor } from '@/api/orderManage/order/order'
import ringChart from './components/ringChart.vue'
import newBasicData from '@/filters/newBasicData'
import Vue from 'vue'
import { tableHeight } from '@/utils/index'
// detail是跳到监控详情的详情是假数据目前暂时不放详情按钮
const tableBtn = [
// {
// type: 'detail',
// btnName: 'btn.detail'
// }
]
const tableProps = [
{
prop: 'name',
label: i18n.t('module.orderManage.orderMonitoring.orderName'),
minWidth: 230,
isFixed: true
},
{
prop: 'startProduceTime',
label: i18n.t('module.orderManage.orderMonitoring.startProcessingTime'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'finishProduceTime',
label: i18n.t('module.orderManage.orderMonitoring.completeTime'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'pdl',
label: i18n.t('module.orderManage.orderMonitoring.processingLine')
},
{
prop: 'outRate',
label: i18n.t('module.orderManage.orderMonitoring.processingCompletionRate'),
minWidth: 160,
filter: rateFormatter
},
{
prop: 'inQuantity',
label: i18n.t('module.orderManage.orderMonitoring.originalFilmInput')
},
{
prop: 'inRate',
label: i18n.t('module.orderManage.orderMonitoring.originalFilmusage'),
filter: rateFormatter
},
{
prop: 'scrapRate',
label: i18n.t('module.orderManage.orderMonitoring.scrapRate'),
filter: rateFormatter
},
{
prop: 'customerName',
label: i18n.t('module.orderManage.orderMonitoring.customer')
},
{
prop: 'status',
label: i18n.t('module.orderManage.orderMonitoring.orderStatus'),
filter: newBasicData('1526063541841727490')
},
{
prop: 'unitCode',
label: i18n.t('module.orderManage.orderMonitoring.unit'),
filter: newBasicData('1')
},
{
prop: 'outQuantity',
label: i18n.t('module.orderManage.orderMonitoring.processingCapacity')
},
{
prop: 'specifications',
label: i18n.t('module.orderManage.orderMonitoring.productSpecifications')
},
{
prop: 'price',
label: i18n.t('module.orderManage.orderMonitoring.price')
}
]
export default {
name: 'OrderMonitoring',
components: { HeadForm, BaseTable, Pagination, MethodBtn, ringChart },
data() {
return {
showList: true,
headFormConfig: [
{
type: 'input',
label: i18n.t('module.orderManage.orderMonitoring.orderName'),
placeholder: i18n.t('module.orderManage.orderMonitoring.orderName'),
param: 'name'
},
{
type: 'datePicker',
label: i18n.t('module.orderManage.orderMonitoring.period'),
dateType: 'daterange',
format: 'yyyy-MM-dd',
valueFormat: 'yyyy-MM-dd',
rangeSeparator: '-',
startPlaceholder: this.$t('module.orderManage.orderMonitoring.startTime'),
endPlaceholder: this.$t('module.orderManage.orderMonitoring.endTime'),
param: 'searchTime'
},
{
type: 'button',
btnName: 'btn.search',
name: 'search',
color: 'primary'
}
],
headFormValue: {},
activeName: 'dataList',
listQuery: {
current: 1,
size: 20,
name: '',
startTime: '',
endTime: ''
},
tableProps,
tableBtn,
list: [],
listLoading: false,
trueWidth: 80,
tableH: tableHeight(333),
total: 0,
unitList: JSON.parse(localStorage.getItem('dictObj'))['1'],
unitObj: {},
statusList: JSON.parse(localStorage.getItem('dictObj'))['1'],
statusObj: {}
}
},
mounted() {
window.addEventListener('resize', () => {
this.tableH = tableHeight(333)
})
this.unitList.map((item) => {
this.unitObj[item.dataCode] = item.dataName
})
Vue.set(this.tableProps[12], 'unitObj', this.unitObj)
this.statusList.map(item => {
this.statusObj[item.dataCode] = item.dataName
})
Vue.set(this.tableProps[11], 'statusObj', this.statusObj)
this.getList()
},
methods: {
getList() {
this.listQuery.name = this.headFormValue.name
this.listQuery.startTime = this.headFormValue.searchTime ? this.headFormValue.searchTime[0] + 'T00:00:00' : ''
this.listQuery.endTime = this.headFormValue.searchTime ? this.headFormValue.searchTime[1] + 'T23:59:59' : ''
orderMonitor(this.listQuery).then(res => {
if (res.data.records) {
this.list = res.data.records
} else {
this.list = []
}
this.total = res.data.total
if (!this.showList) {
this.$nextTick(() => {
this.$refs.ringCharts.initChart()
})
}
})
},
btnClick(val) {
this.headFormValue = val
// 如果点击的是搜索栏的其他按钮在这里继续写判断
if (this.headFormValue.btnName === 'search') {
this.listQuery.current = 1
this.getList()
}
},
toggleClick() {
if (this.activeName === 'ringChart') {
this.showList = false
this.$nextTick(() => {
this.$refs.ringCharts.initChart()
})
} else if (this.activeName === 'dataList') {
this.showList = true
}
this.getList()
},
handleClick() {
this.$router.push({
name: 'orderMonitoringDetail'
})
}
}
}
</script>

View File

@@ -0,0 +1,301 @@
<template>
<div id="container" ref="container" class="visual-container">
<el-row
class="container-title"
:style="{
height: beilv * 88 + 'px',
lineHeight: beilv * 88 + 'px',
fontSize: beilv * 30 + 'px'
}"
>
<img src="../../../assets/img/logo.png" style="width:1.1em;position:relative;top:.4em" alt="">
合肥新能源数智工厂订单监控查询
<el-button
type="text"
class="title-button"
:style="{ right: 33 * beilv + 'px', top: 37 * beilv + 'px' }"
@click="changeFullScreen"
>
<svg-icon v-if="isFullScreen" icon-class="unFullScreenView" />
<svg-icon v-else icon-class="fullScreenView" />
</el-button>
</el-row>
<el-row class="container-main">
<el-row :style="{ padding: '0 ' + 9 * beilv + 'px' }" :gutter="9 * beilv">
<el-col :span="6">
<el-row>
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24" style="position: relative;">
<base-container :beilv="beilv" :height="463" :title="'三大品类'" :title-icon="'productType'">
<pie-chart1 :id="'pie-chart1'" :beilv="beilv" :height="'256'" :pie-style="pieStyle1" />
<dataShowBox :beilv="beilv" :height="112" style="position: absolute;bottom: 0;" />
</base-container>
</el-col>
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
<base-container :beilv="beilv" :height="463" :title="'销售额前十产品'" :title-icon="'5_4'">
<progressBox :beilv="beilv" :product-data="progressData1" :style="{paddingTop: 20 * beilv + 'px'}" />
</base-container>
</el-col>
</el-row>
</el-col>
<el-col :span="12">
<el-row>
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
<dataShowMain :beilv="beilv" :height="216" />
</el-col>
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
<base-container :beilv="beilv" :height="711" :title="'各个季度完成情况'" :title-icon="'number'">
<pie-chart2 :id="'pie-chart2'" :beilv="beilv" :height="'310'" :pie-style="pieStyle2" />
<div>
<div class="bar-title">
<span>
<svg-icon :icon-class="'5_2'" style="font-size: 1.5em; position: relative; top: .08em" />
各月情况
</span>
</div>
<lineChart :beilv="beilv" :height="'330'" />
</div>
</base-container>
</el-col>
</el-row>
</el-col>
<el-col :span="6">
<el-row>
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
<base-container :beilv="beilv" :height="463" :title="'销售三甲员工'" :title-icon="'1_1'">
<saleTop :beilv="beilv" :height="'356'" />
</base-container>
</el-col>
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
<base-container :beilv="beilv" :height="463" :title="'大客户'" :title-icon="'1_4'">
<progressBox :beilv="beilv" :product-data="progressData2" :style="{paddingTop: 20 * beilv + 'px'}" />
</base-container>
</el-col>
</el-row>
</el-col>
</el-row>
</el-row>
</div>
</template>
<script>
import baseContainer from './components/baseContainer'
import pieChart1 from './components/pieChart'
import pieChart2 from './components/pieChart'
import screenfull from 'screenfull'
import dataShowBox from './components/dataShowBox'
import dataShowMain from './components/dataShowMain'
import progressBox from './components/progressBox'
import saleTop from './components/saleTop'
import lineChart from './components/lineChart'
const pieStyle1 = {
num_fs: 18,
line_s: 24,
pieData: [
{ value: 330, name: '品类1' },
{ value: 120, name: '品类2' },
{ value: 250, name: '品类3' }
],
formatter: '{firstLine|{b}} \n {secondLine|{d}%}'
}
const pieStyle2 = {
num_fs: 24,
line_s: 95,
pieData: [
{ value: 329, name: '第一季度' },
{ value: 119, name: '第二季度' },
{ value: 251, name: '第三季度' },
{ value: 301, name: '第四季度' }
],
formatter: '{firstLine|{b} {d}%} \n {secondLine|{c}}'
}
export default {
name: 'OrderMonitoringDetail',
components: {
baseContainer,
pieChart1,
pieChart2,
dataShowBox,
dataShowMain,
progressBox,
saleTop,
lineChart
},
data() {
return {
beilv: 1,
isFullScreen: false,
pieStyle1,
pieStyle2,
progressData1: [],
progressData2: []
}
},
watch: {
isFullScreen: function(val) {
if (val) {
this.beilv = document.body.offsetWidth / 1920
} else {
this.beilv = document.getElementById('container').offsetWidth / 1920
}
},
'sidebar.opened': function(val) {
console.log(val)
if (!this.isFullScreen) {
setTimeout(() => {
this.beilv = document.getElementById('container').offsetWidth / 1920
}, 300)
}
}
},
mounted() {
this.beilv = document.getElementById('container').offsetWidth / 1920
window.addEventListener('resize', () => {
if (this.isFullScreen) {
this.beilv = document.body.offsetWidth / 1920
} else {
this.beilv = document.getElementById('container').offsetWidth / 1920
}
})
this.getMsg()
},
methods: {
getMsg() {
this.progressData1 = [
{ name: '产品1', number: 1000, percentage: '100%' },
{ name: '产品2', number: 900, percentage: '90%' },
{ name: '产品3', number: 850, percentage: '85%' },
{ name: '产品4', number: 700, percentage: '70%' },
{ name: '产品5', number: 620, percentage: '62%' },
{ name: '产品6', number: 550, percentage: '55%' },
{ name: '产品7', number: 530, percentage: '53%' },
{ name: '产品8', number: 500, percentage: '50%' },
{ name: '产品9', number: 430, percentage: '43%' },
{ name: '产品10', number: 300, percentage: '30%' }
]
this.progressData2 = [
{ name: '客户1', number: 1000, percentage: '100%' },
{ name: '客户2', number: 900, percentage: '90%' },
{ name: '客户3', number: 850, percentage: '85%' },
{ name: '客户4', number: 700, percentage: '70%' },
{ name: '客户5', number: 620, percentage: '62%' },
{ name: '客户6', number: 550, percentage: '55%' },
{ name: '客户7', number: 530, percentage: '53%' },
{ name: '客户8', number: 500, percentage: '50%' },
{ name: '客户9', number: 430, percentage: '43%' },
{ name: '客户10', number: 300, percentage: '30%' }
]
},
change() {
this.isFullScreen = screenfull.isFullscreen
},
init() {
if (screenfull.enabled) {
screenfull.on('change', this.change)
}
},
destroy() {
if (screenfull.enabled) {
screenfull.off('change', this.change)
}
},
changeFullScreen() {
if (!screenfull.enabled) {
this.$message({
message: 'you browser can not work',
type: 'warning'
})
return false
}
screenfull.toggle(this.$refs.container)
}
}
}
</script>
<style lang="scss" scoped>
.visual-container {
width: 100%;
min-width: 960px;
background: url('../../../assets/img/OperationalOverview/back.png') no-repeat;
background-size: cover;
.container-title {
width: 100%;
background: url('../../../assets/img/OperationalOverview/title.png') no-repeat;
background-size: 100% 100%;
color: #00fff0;
text-align: center;
.title-button {
color: #00fff0;
font-size: 20px;
position: absolute;
}
}
.container-main {
padding: 16px;
}
}
.now-team-title {
margin: 0;
margin-top: -1em;
font-size: 1.2em;
line-height: 2em;
color: #fff;
}
.main-title {
text-align: center;
}
.now-secondary-title {
margin: 0;
font-size: 1em;
line-height: 2em;
color: #fff;
}
.now-team-content {
font-size: 3em;
line-height: 1em;
color: #52fff1;
text-align: center;
}
// ::v-deep .el-progress-bar__inner {
// background-color: unset;
// background-image: linear-gradient(to right, #4573fe, #47f8dc);
// }
</style>
<style lang="scss">
.visual-container {
::-webkit-scrollbar {
width: 8px;
height: 8px;
background-color: transparent;
}
::-webkit-scrollbar-track-piece {
background: #1b2b3d;
}
::-webkit-scrollbar-corner {
background: #1b2b3d;
}
::-webkit-scrollbar-track {
width: 6px;
background: #1b2b3d;
-webkit-border-radius: 2em;
-moz-border-radius: 2em;
border-radius: 2em;
}
::-webkit-scrollbar-thumb {
background: rgba($color: #5bc4be, $alpha: 0.7);
background-clip: padding-box;
min-height: 28px;
-webkit-border-radius: 2em;
-moz-border-radius: 2em;
border-radius: 2em;
transition: background-color 0.3s;
cursor: pointer;
}
::-webkit-scrollbar-thumb:hover {
background-color: rgba($color: #5bc4be, $alpha: 1);
}
}
</style>

View File

@@ -0,0 +1,183 @@
<!--
* @Author: zwq
* @Date: 2021-02-27 14:39:57
* @LastEditors: zwq
* @LastEditTime: 2021-06-22 16:25:52
* @Description:
-->
<template>
<div>
<el-card class="box-card">
<div slot="header" class="clearfix">
<el-button style="margin-right:50px" type="success" @click="goback()">{{ 'btn.back' | i18nFilter }}</el-button>
<span><b>{{ $t('module.orderManage.order.WorkOrderCode')+''+stringfilter(dataForm.workOrderNo) }}</b></span>
</div>
<div class="text item">
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.order.WorkOrderName')+''+stringfilter(dataForm.name) }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.order.status')+'' }}{{ dataForm.status|commonFilter(basicData('workOrderStatus')) }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.workOrderDetail.workOrderSource')+'' }}{{ dataForm.triggerOrigin|commonFilter(basicData('source')) }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.order.createTime')+''+timefilter(dataForm.createTime) }}</div></el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.order.PlannedProcessingVolume')+''+stringfilter(dataForm.planQuantity) }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.workOrderDetail.processingTechnology')+''+stringfilter(dataForm.processFlowName) }}</div></el-col>
<!-- <el-col :span="6"><div>{{ $t('module.orderManage.order.PlanningEndTime')+''+timefilter(dataForm.planFinishProduceTime) }}</div></el-col> -->
</el-row>
</div>
</el-card>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
</div>
</template>
<script>
import i18n from '@/lang'
import { workOrderDetail, packagingList } from '@/api/orderManage/workOrder/workOrder'
import { timeFormatter } from '@/filters'
import basicData from '@/filters/basicData'
import BaseTable from '@/components/BaseTable'
import detailBtn from './components/detailBtn'
import Pagination from '@/components/Pagination'
const tableProps = [
{
prop: 'boxNo',
label: 'boxID',
align: 'center'
},
{
prop: 'power',
label: 'power',
align: 'center'
},
{
prop: 'grade',
label: i18n.t('module.orderManage.packingTags.plateGrade'),
align: 'center'
},
{
prop: 'printTime',
label: i18n.t('module.orderManage.packingTags.PrintingTime'),
align: 'center',
filter: timeFormatter
},
{
prop: 'substrateQuantity',
label: i18n.t('module.orderManage.packingTags.moduleQuantity'),
align: 'center'
},
{
prop: 'remark',
label: i18n.t('module.orderManage.order.Remarks'),
align: 'center'
},
{
prop: 'opration',
label: i18n.t('module.orderManage.packingTags.opration'),
subcomponent: detailBtn
}
]
export default {
name: '',
filters: {
commonFilter: (source, filterType = a => a) => {
return filterType(source)
}
},
components: { BaseTable, Pagination },
data() {
return {
workOrderId: '',
tableProps,
list: [],
total: 0,
listLoading: false,
listQuery: {
current: 1,
size: 10
},
dataForm: {},
basicData
}
},
created() {
this.workOrderId = this.$route.query.id
this.init()
},
methods: {
init() {
this.dataForm = {}
workOrderDetail(this.workOrderId).then(res => {
this.dataForm = res.data
})
this.listQuery.workOrderId = this.workOrderId
this.getList()
},
getList() {
this.listLoading = true
packagingList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
},
goback() {
this.$router.go(-1)
},
timefilter(obj) {
return timeFormatter(obj).substring(0, timeFormatter(obj).lastIndexOf(' '))
},
stringfilter(objString) {
return objString || ''
}
}
}
</script>
<style scoped>
.text {
font-size: 18px;
}
.item {
margin-bottom: 18px;
}
.clearfix:before,
.clearfix:after {
display: table;
content: "";
}
.clearfix:after {
clear: both
}
.box-card {
font-size: 30px;
margin: auto;
margin-top: 20px;
}
.el-row {
margin-bottom: 20px;
}
.el-col {
border-radius: 4px;
}
</style>

View File

@@ -0,0 +1,213 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: juzi
* @LastEditTime: 2022-04-22
* @Description:
-->
<template>
<div class="app-container">
<top-title />
<head-form
:form-config="headFormConfig"
@headBtnClick="btnClick"
/>
<base-table
:top-btn-config="topBtnConfig"
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
@clickTopBtn="clickTopBtn"
>
<method-btn
slot="handleBtn"
:width="trueWidth"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
<powerClassification-add v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="getList" />
</div>
</template>
<script>
import TopTitle from '@/components/TopTitle'
import { powerClassificationList, powerClassificationDelete } from '@/api/orderManage/powerClassification'
import powerClassificationAdd from './components/powerClassification-add.vue'
import HeadForm from '@/components/basicData/HeadForm'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import i18n from '@/lang'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const topBtnConfig = [
{
type: 'add',
btnName: 'btn.add'
}
]
const tableBtn = [
{
type: 'edit',
btnName: 'btn.edit'
},
{
type: 'delete',
btnName: 'btn.delete'
}
]
const tableProps = [
{
prop: 'parentName',
label: i18n.t('module.orderManage.powerClassification.parentClass'),
align: 'center'
},
{
prop: 'name',
label: i18n.t('module.orderManage.powerClassification.typeName'),
align: 'center'
},
{
prop: 'code',
label: i18n.t('module.orderManage.powerClassification.typeCode'),
align: 'center'
},
{
prop: 'remark',
label: i18n.t('module.orderManage.powerClassification.Remarks'),
align: 'center'
}
]
export default {
name: 'PowerClassification',
components: { TopTitle, Pagination, BaseTable, MethodBtn, HeadForm, powerClassificationAdd },
filters: {
statusFilter(status) {
const statusMap = {
published: 'success',
draft: 'info',
deleted: 'danger'
}
return statusMap[status]
}
},
data() {
return {
topBtnConfig,
addOrUpdateVisible: false,
tableBtn,
trueWidth: 200,
tableProps,
list: [],
total: 0,
listLoading: true,
listQuery: {
current: 1,
size: 10,
name: '',
code: ''
},
headFormConfig: [
{
type: 'input',
label: i18n.t('module.basicData.visual.keyword'),
placeholder: this.$t('module.orderManage.powerClassification.typeName'),
param: 'keyName'
},
{
type: 'button',
btnName: 'btn.search',
name: 'search',
color: 'primary'
}
],
headFormValue: {}
}
},
created() {
this.getList()
},
methods: {
handleClick(raw) {
if (raw.type === 'delete') {
this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}[${raw.data.name}]?`, this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
}).then(() => {
powerClassificationDelete(raw.data.id).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.getList()
}
})
})
}).catch(() => {})
} else {
this.addNew(raw.data.id)
}
},
getList() {
this.listLoading = true
this.listQuery.name = this.headFormValue.keyName
this.listQuery.code = this.headFormValue.keyName
powerClassificationList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
},
// 新增 / 修改
addNew(id) {
this.addOrUpdateVisible = true
this.$nextTick(() => {
this.$refs.addOrUpdate.init(id)
})
},
btnClick(val) {
this.headFormValue = val
// 如果点击的是搜索栏的其他按钮在这里继续写判断
if (this.headFormValue.btnName === 'search') {
this.getList()
}
},
clickTopBtn(val) {
if (val === 'add') {
this.addNew()// 新增
}
}
}
}
</script>

View File

@@ -0,0 +1,196 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: Please set LastEditors
* @LastEditTime: 2021-07-21 16:55:18
* @Description:
-->
<template>
<div class="app-container">
<head-form
:placeholder-name="placeholderName"
:key-name="keyName"
@getDataList="getList"
@add="addNew"
/>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
>
<method-btn
slot="handleBtn"
:width="trueWidth"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
</div>
</template>
<script>import i18n from '@/lang'
import { substrateBatchList, substrateBatchDelete } from '@/api/orderManage/substrateBatch'
import HeadForm from '@/components/basicData/HeadForm'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableBtn = [
{
type: 'edit',
btnName: 'btn.edit'
},
{
type: 'delete',
btnName: 'btn.delete'
},
{
type: 'detail',
btnName: 'btn.detail'
}
]
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.basicData.factory.createTime'),
filter: timeFormatter,
align: 'center'
},
{
prop: 'name',
label: i18n.t('module.orderManage.substrateBatch.batchName'),
align: 'center'
},
{
prop: 'code',
label: i18n.t('module.orderManage.substrateBatch.batchCode'),
align: 'center'
},
{
prop: 'remark',
label: i18n.t('module.basicData.visual.Remarks'),
align: 'center'
}
]
export default {
name: 'SubstrateBatch',
components: { Pagination, BaseTable, MethodBtn, HeadForm },
filters: {
statusFilter(status) {
const statusMap = {
published: 'success',
draft: 'info',
deleted: 'danger'
}
return statusMap[status]
}
},
data() {
return {
keyName: i18n.t('module.basicData.visual.keyword'),
placeholderName: this.$t('module.orderManage.substrateBatch.batchCode'),
tableBtn,
trueWidth: 240,
tableProps,
list: [],
total: 0,
listLoading: true,
listQuery: {
current: 1,
size: 10
}
}
},
created() {
this.getList()
},
methods: {
handleClick(raw) {
console.log(raw)
if (raw.type === 'delete') {
this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}[${raw.data.name}]?`, this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
}).then(() => {
substrateBatchDelete(raw.data.id).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.getList()
}
})
})
}).catch(() => {})
} else if (raw.type === 'edit') {
this.addNew(raw.data.id)
} else {
this.addNew(raw.data.id, true)
}
},
getList(key) {
this.listLoading = true
this.listQuery.name = key
this.listQuery.code = key
substrateBatchList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
},
// 新增 / 修改
addNew(id, isdetail) {
this.$router.push({
name: 'substrateBatchAttr',
query: {
id: id,
isdetail: isdetail
}
})
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,263 @@
<template>
<el-drawer :visible.sync="visible" size="60%" class="drawer" @closed="cancelDialog">
<small-title slot="title" :no-padding="true">
{{ 'btn.detail' | i18nFilter }}
</small-title>
<div>
<ul class="detailBox">
<li style="width: 50%;">
<p class="title">{{ this.$t('module.orderManage.order.WorkOrderName') | i18nFilter }}</p>
<p class="text">{{ orderName }}</p>
</li>
<li style="width: 50%;">
<p class="title">{{ this.$t('module.orderManage.order.WorkOrderCode') | i18nFilter }}</p>
<p class="text">{{ orderCode }}</p>
</li>
</ul>
</div>
<div class="tableBox">
<small-title>
{{ this.$t('module.orderManage.workOrderDetail.batchInfo') | i18nFilter }}
</small-title>
<!-- table -->
<template>
<el-row>
<base-table
:top-btn-config="topBtnConfig"
:page="listQuery.current"
:limit="listQuery.size"
:height="tableH"
:table-data="diaList"
:table-config="tableProps"
@clickTopBtn="clickTopBtn"
>
<template>
<method-btn slot="handleBtn" :width="100" :method-list="tableBtn" @clickBtn="tablebtnClick" />
</template>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getOrderDetail"
/>
</el-row>
</template>
</div>
<span slot="footer" class="dialog-footer">
<el-button @click="cancelDialog">
{{ 'btn.cancel' | i18nFilter }}
</el-button>
</span>
<edit-batch-add v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="getOrderDetail" />
</el-drawer>
</template>
<script>
import SmallTitle from '@/components/BaseDrawer/components/SmallTitle.vue'
import {
getMaterialPage,
workOrderDetail,
delBatch
} from '@/api/orderManage/workOrder/workOrder'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination'
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import i18n from '@/lang'
import newBasicData from '@/filters/newBasicData'
import { timeFormatter } from '@/filters'
import EditBatchAdd from './editBatchAdd.vue'
import { tableHeight } from '@/utils/index'
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.workOrderDetail.createTime'),
filter: timeFormatter
},
{
prop: 'dateName',
label: i18n.t('module.orderManage.workOrderDetail.originalBatch')
},
{
prop: 'specification',
label: i18n.t('module.orderManage.workOrderDetail.specification'),
filter: newBasicData('1528564570336985090')
},
{
prop: 'operator',
label: i18n.t('module.orderManage.workOrderDetail.operator')
},
{
prop: 'quantity',
label: i18n.t('module.orderManage.workOrderDetail.quantity')
},
{
prop: 'unitCode',
label: i18n.t('module.orderManage.workOrderDetail.unit'),
filter: newBasicData('1')
}
]
export default {
components: { Pagination, BaseTable, MethodBtn, SmallTitle, EditBatchAdd },
props: {},
data() {
return {
orderName: '',
orderCode: '',
isAlready: false, // true 订单已完成
visible: false,
listQuery: {
current: 1,
size: 20,
id: ''
},
tableH: tableHeight(380),
total: 0,
topBtnConfig: [],
tableProps,
tableBtn: [],
diaList: [],
addOrUpdateVisible: false
}
},
mounted() {
window.addEventListener('resize', () => {
this.tableH = tableHeight(380)
})
},
methods: {
init(id) {
this.visible = true
this.listQuery.id = id
// 根据orderId查订单详情
workOrderDetail(this.listQuery.id).then((res) => {
if (res.data.status === 9) {
this.isAlready = true
this.tableBtn = []
this.topBtnConfig = []
} else {
this.topBtnConfig = [
{
type: 'add',
btnName: 'btn.add'
}
]
this.tableBtn = [
{
type: 'edit',
btnName: 'btn.edit'
},
{
type: 'delete',
btnName: 'btn.delete'
}
]
}
this.orderName = res.data.name
this.orderCode = res.data.code
})
this.getOrderDetail()
},
getOrderDetail() {
// 查询该工单的批次明细
getMaterialPage({
current: this.listQuery.current,
size: this.listQuery.size,
workOrderId: this.listQuery.id
}).then((res) => {
this.diaList = res.data.records ? res.data.records : []
this.total = res.data.total ? res.data.total : 0
})
},
cancelDialog() {
this.visible = false
this.isAlready = false
},
tablebtnClick(raw) {
if (raw.type === 'edit') {
const param = {}
param.workOrderId = ''
param.id = raw.data.id
this.addNew(param)
} else {
// 删除明细
this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}?`, this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
})
.then(() => {
// 删除费用明细
delBatch({ id: raw.data.id }).then((res) => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.listQuery.current = 1
this.getOrderDetail()
}
})
})
})
.catch(() => {})
}
},
clickTopBtn(val) {
if (!this.isAlready) {
if (val === 'add') {
const param = {}
param.workOrderId = this.listQuery.id
param.id = ''
this.addNew(param)
}
}
},
addNew(param) {
this.addOrUpdateVisible = true
this.$nextTick(() => {
this.$refs.addOrUpdate.init(param)
})
}
}
}
</script>
<style scoped>
.drawer >>> .el-drawer {
border-radius: 8px 0 0 8px;
}
.drawer >>> .el-form-item__label {
padding: 0;
}
.drawer >>> .el-drawer__header {
margin: 0;
padding: 32px 32px 24px;
border-bottom: 1px solid #dcdfe6;
margin-bottom: 30px;
}
.detailBox {
list-style: none;
display: flex;
text-align: left;
}
.detailBox p {
margin: 0;
}
.detailBox .title {
font-size: 14px;
font-weight: 600;
color: rgba(0,0,0,0.65);
padding-bottom: 10px;
}
.detailBox .text {
font-size: 14px;
font-weight: 400;
color: rgba(102,102,102,0.75);
}
.tableBox {
padding: 0 32px;
}
</style>

View File

@@ -0,0 +1,238 @@
<template>
<el-dialog
:title="this.$t('module.orderManage.workOrderDetail.batchInfo')"
:visible.sync="visible"
width="40%"
:append-to-body="true"
@closed="cancel"
>
<div class="tableBox">
<el-form
ref="batchData"
style="padding: 24px 0;"
:model="batchData"
label-width="110px"
:rules="batchDataRules"
>
<el-form-item :label="this.$t('module.orderManage.workOrderDetail.originalBatch')" prop="dateName">
<el-input
v-model="batchData.dateName"
clearable
:placeholder="['placeholder.input', this.$t('module.orderManage.workOrderDetail.originalBatch')] | i18nFilterForm"
/>
</el-form-item>
<el-form-item :label="this.$t('module.orderManage.workOrderDetail.specification')" prop="specification">
<el-select
v-model="batchData.specification"
filterable
clearable
:placeholder="['placeholder.select', this.$t('module.orderManage.workOrderDetail.specification')] | i18nFilterForm"
>
<el-option
v-for="item in specificationOptions"
:key="item.dataCode"
:label="item.dataName"
:value="item.dataCode"
/>
</el-select>
</el-form-item>
<el-form-item :label="this.$t('module.orderManage.workOrderDetail.operator')" prop="operator">
<!-- 操作人 -->
<el-input
v-model="batchData.operator"
clearable
:placeholder="['placeholder.input', this.$t('module.orderManage.workOrderDetail.operator')] | i18nFilterForm"
/>
</el-form-item>
<el-form-item :label="this.$t('module.orderManage.workOrderDetail.quantity')" prop="quantity">
<!-- inputNumber -->
<el-input-number v-model="batchData.quantity" :min="0" :style="{ width: '100%' }" />
</el-form-item>
<el-form-item :label="this.$t('module.orderManage.workOrderDetail.unit')" prop="unitCode">
<!-- select -->
<el-select
v-model="batchData.unitCode"
filterable
clearable
:placeholder="['placeholder.select', this.$t('module.orderManage.workOrderDetail.unit')] | i18nFilterForm"
>
<el-option
v-for="item in unitOptions"
:key="item.dataCode"
:label="item.dataName"
:value="item.dataCode"
/>
</el-select>
</el-form-item>
<div style="text-align: center;">
<el-button @click="cancel">
{{ 'btn.cancel' | i18nFilter }}
</el-button>
<el-button type="primary" @click="createOrEditController">
{{ 'btn.confirm' | i18nFilter }}
</el-button>
</div>
</el-form>
</div>
</el-dialog>
</template>
<script>
import {
getBatchById,
addBatch,
editBatch
} from '@/api/orderManage/workOrder/workOrder'
export default {
props: {},
data() {
return {
visible: false,
batchData: {
dateName: '',
specification: '',
operator: '',
quantity: '',
unitCode: '',
workOrderId: ''
},
unitOptions: JSON.parse(localStorage.getItem('dictObj'))['1'],
unitObj: {},
specificationOptions: JSON.parse(localStorage.getItem('dictObj'))['1528564570336985090'],
detailEdit: false, // 编辑明细
batchDataRules: {
dateName: [
{
required: true,
message: this.$t('module.orderManage.workOrderDetail.originalBatch'),
trigger: 'blue'
}
],
quantity: [
{
required: true,
message: this.$t('module.orderManage.workOrderDetail.quantity'),
trigger: 'blue'
}
],
unitCode: [
{
required: true,
message: this.$t('module.orderManage.workOrderDetail.unit'),
trigger: 'change'
}
]
}
}
},
mounted() {
this.unitOptions.map((item) => {
this.unitObj[item.dataCode] = item.dataName
})
},
methods: {
init(param) {
this.visible = true
this.batchData.workOrderId = param.workOrderId
if (param.id) {
this.batchData.id = param.id
this.detailEdit = true
getBatchById({ id: this.batchData.id }).then((res) => {
this.batchData = res.data
})
} else {
this.detailEdit = false
this.batchData.id = ''
}
},
cancel() {
this.visible = false
this.$refs['batchData'].resetFields()
},
// 判断明细当前是编辑,还是新增
createOrEditController() {
// 确定
if (this.detailEdit) {
// 编辑
this.submitEditStockForm()
} else {
// 新增
this.submitCreateStockForm()
}
},
submitEditStockForm() {
// 编辑 明细表单提交
this.$refs['batchData'].validate((valid) => {
if (valid) {
editBatch(this.batchData).then((res) => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.cancel()
this.$emit('refreshDataList')
}
})
})
}
})
},
submitCreateStockForm() {
// 新增 明细表单提交
this.$refs['batchData'].validate((valid) => {
if (valid) {
addBatch(this.batchData).then((res) => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.cancel()
this.$emit('refreshDataList')
}
})
})
}
})
}
}
}
</script>
<style scoped>
.drawer >>> .el-drawer {
border-radius: 8px 0 0 8px;
}
.drawer >>> .el-form-item__label {
padding: 0;
}
.drawer >>> .el-drawer__header {
margin: 0;
padding: 32px 32px 24px;
border-bottom: 1px solid #dcdfe6;
margin-bottom: 30px;
}
.detailBox {
list-style: none;
display: flex;
text-align: left;
}
.detailBox p {
margin: 0;
}
.detailBox .title {
font-size: 14px;
font-weight: 600;
color: rgba(0,0,0,0.65);
padding-bottom: 10px;
}
.detailBox .text {
font-size: 14px;
font-weight: 400;
color: rgba(102,102,102,0.75);
}
.tableBox {
padding: 0 32px;
}
</style>

View File

@@ -0,0 +1,68 @@
<!--
* @Author: zwq
* @Date: 2021-03-03 16:39:34
* @LastEditors: zwq
* @LastEditTime: 2021-03-04 10:10:45
* @Description:
-->
<template>
<div id="monitorChart" :style="{width: '700px', height: '500px'}" style="margin-left:10%" />
</template>
<script>
import echarts from 'echarts'
export default {
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
chart: null
}
},
mounted() {
this.init()
},
beforeDestroy() {
if (!this.chart) {
return
}
this.chart.dispose()
this.chart = null
},
methods: {
init() {
this.chart = echarts.init(document.getElementById('monitorChart'))
this.chart.setOption({
color: '#91cc75',
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow'
}
},
xAxis: {
type: 'category',
data: ['设备1', '设备2', '设备3', '设备4', '设备5', '设备6', '设备7']
},
yAxis: {
type: 'value'
},
series: [{
name: '电量消耗',
data: [323.234, 323.841, 755.45, 251.453, 454.786, 484.786, 154.786],
barWidth: '60%',
type: 'bar'
}]
})
}
}
}
</script>

View File

@@ -0,0 +1,134 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-06 17:48:35
* @Description:
-->
<template>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
</template>
<script>
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
// import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'name',
label: i18n.t('module.orderManage.order.EquipmentName')
// filter: timeFormatter
},
{
prop: 'consume',
label: i18n.t('module.orderManage.order.PowerConsumption'),
align: 'center'
}
]
export default {
name: '',
components: { BaseTable },
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
tableProps,
list: [],
listLoading: false,
listQuery: {
current: 1,
size: 10
}
}
},
methods: {
init() {
this.listQuery = {
current: 1,
size: 10
}
this.getList()
},
getList() {
this.list = [
{
'name': '设备1',
'consume': '323,234'
},
{
'name': '设备2',
'consume': '323.841'
},
{
'name': '设备3',
'consume': '755.45'
},
{
'name': '设备4',
'consume': '251.453'
},
{
'name': '设备5',
'consume': '454.786'
},
{
'name': '设备6',
'consume': '484.786'
},
{
'name': '设备7',
'consume': '154.786'
}
]
// this.listLoading = true
// staffList(this.listQuery).then(response => {
// if (response.data.records) {
// this.list = response.data.records
// } else {
// this.list.splice(0, this.list.length)
// }
// this.listLoading = false
// })
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,183 @@
<template>
<el-drawer
size="60%"
:visible.sync="visible"
:wrapper-closable="false"
class="drawer"
@close="cancelBtn"
>
<small-title slot="title" :no-padding="true">
{{ startOrStop === 'start' ? 'btn.start' : 'btn.stop' | i18nFilter }}
</small-title>
<div>
<ul class="detailBox">
<li style="width: 50%;">
<p class="title">{{ this.$t('module.orderManage.order.WorkOrderName') | i18nFilter }}</p>
<p class="text">{{ name }}</p>
</li>
<li style="width: 50%;">
<p class="title">{{ this.$t('module.orderManage.order.WorkOrderCode') | i18nFilter }}</p>
<p class="text">{{ code }}</p>
</li>
</ul>
</div>
<div class="tableBox">
<base-table :page="1" :limit="500" :sbox="true" :height="tableH" :table-config="tableProps" :table-data="list" :is-loading="listLoading" @selectChangeFun="selectC" />
</div>
<div style="position: absolute; bottom: 24px; right: 24px;">
<el-button @click="cancelBtn">{{ 'btn.cancel' | i18nFilter }}</el-button>
<el-button type="primary" @click="sureBtn">{{ 'btn.confirm' | i18nFilter }}</el-button>
</div>
</el-drawer>
</template>
<script>
import SmallTitle from '@/components/BaseDrawer/components/SmallTitle.vue'
import BaseTable from '@/components/BaseTable'
import { listPld, startOrder, stopOrder, workOrderDetail } from '@/api/orderManage/workOrder/workOrder'
import i18n from '@/lang'
const tableProps = [
{
prop: 'name',
label: i18n.t('module.orderManage.order.ProductLines')
},
{
prop: 'workOrderName',
label: i18n.t('module.orderManage.order.WorkOrderName')
}
]
export default {
components: { BaseTable, SmallTitle },
data() {
return {
visible: false,
tableH: 300,
list: [],
listLoading: false,
tableProps,
startOrStop: 'start',
selectBox: [],
productlines: [],
orderId: '',
name: '',
code: ''
}
},
methods: {
init(id, val) {
// 查询产线
this.visible = true
this.listLoading = true
this.startOrStop = val
this.orderId = id
workOrderDetail(this.orderId).then(res => {
this.name = res.data.name
this.code = res.data.code
})
if (this.startOrStop === 'start') { // 开始
listPld({
id: ''
}).then(res => {
this.list = res.data
this.listLoading = false
})
} else { // 结束
listPld({
id: this.orderId
}).then(res => {
this.list = res.data
this.listLoading = false
})
}
},
selectC(val) {
this.selectBox = val
},
cancelBtn() { // 取消
this.visible = false
this.list = []
this.selectBox = []
this.productlines = []
this.listLoading = false
this.orderId = ''
},
sureBtn() { // 确定
if (this.selectBox.length === 0) {
this.$message({
message: this.$t('module.orderManage.order.selectTip'),
type: 'error',
duration: 1500
})
return false
}
this.selectBox.map(item => {
this.productlines.push(item.id)
})
if (this.startOrStop === 'start') {
startOrder({
id: this.orderId,
productlines: this.productlines
}).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500
})
this.cancelBtn()
this.$emit('refreshDataList')
})
} else if (this.startOrStop === 'stop') {
stopOrder({
id: this.orderId,
productlines: this.productlines
}).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500
})
this.cancelBtn()
this.$emit('refreshDataList')
})
}
}
}
}
</script>
<style scoped>
.drawer >>> .el-drawer {
border-radius: 8px 0 0 8px;
}
.drawer >>> .el-form-item__label {
padding: 0;
}
.drawer >>> .el-drawer__header {
margin: 0;
padding: 32px 32px 24px;
border-bottom: 1px solid #dcdfe6;
margin-bottom: 30px;
}
.detailBox {
list-style: none;
display: flex;
text-align: left;
}
.detailBox p {
margin: 0;
}
.detailBox .title {
font-size: 14px;
font-weight: 600;
color: rgba(0,0,0,0.65);
padding-bottom: 10px;
}
.detailBox .text {
font-size: 14px;
font-weight: 400;
color: rgba(102,102,102,0.75);
}
.tableBox {
padding: 0 32px;
}
</style>

View File

@@ -0,0 +1,18 @@
<template>
<span>
{{ injectData.unitCode ? injectData.unitObj[String(injectData.unitCode)] : '' }}
</span>
</template>
<script>
export default {
name: '',
props: {
injectData: {
type: Object,
default: () => ({})
}
}
}
</script>

View File

@@ -0,0 +1,100 @@
<!--
* @Author: zwq
* @Date: 2021-02-27 14:49:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-06 19:22:29
* @Description: 工单验证
-->
<template>
<div>
<el-card class="box-card">
<div class="text item">
<el-row>
<el-col :span="12">
<el-row :gutter="20">
<el-col :span="23"><div class="title">{{ $t('module.orderManage.FalseData.FalseData22') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData23') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData24') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData25') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData26') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData5') }}</div></el-col>
</el-row>
</el-col>
<el-col :span="12">
<el-row :gutter="20">
<el-col :span="23"><div class="title">{{ $t('module.orderManage.FalseData.FalseData27') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData23') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData524') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData25') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData28') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData29') }}</div></el-col>
</el-row>
</el-col>
</el-row>
</div>
</el-card>
</div>
</template>
<script>
export default {
name: '',
components: { },
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
}
},
created() {
},
methods: {
init() {
this.getList()
},
getList() {
// this.listLoading = true
// staffList(this.listQuery).then(response => {
// if (response.data.records) {
// this.list = response.data.records
// } else {
// this.list.splice(0, this.list.length)
// }
// this.listLoading = false
// })
}
}
}
</script>
<style scoped>
.text {
font-size: 18px;
}
.item {
margin-bottom: 18px;
}
.box-card {
width: 80%;
font-size: 30px;
margin: auto;
margin-top: 20px;
}
.el-col {
border-radius: 4px;
margin-bottom: 20px;
}
.title{
font-size: 40px;
color: #1588F5;
}
</style>

View File

@@ -0,0 +1,138 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-06 19:17:31
* @Description:
-->
<template>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
</template>
<script>
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
// import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'name',
label: i18n.t('module.orderManage.order.EquipmentName')
// filter: timeFormatter
},
{
prop: 'code',
label: i18n.t('module.orderManage.VerifyTable.EquipmentCode'),
align: 'center'
},
{
prop: 'abbr',
label: i18n.t('module.orderManage.VerifyTable.equipmentAbbreviation')
},
{
prop: 'status',
label: i18n.t('module.orderManage.order.status')
},
{
prop: 'formula',
label: i18n.t('module.orderManage.VerifyTable.EquipmentFormula')
},
{
prop: 'formula1',
label: i18n.t('module.orderManage.VerifyTable.ProcessFormulaRequir')
},
{
prop: 'same',
label: i18n.t('module.orderManage.VerifyTable.IsSame')
}
]
export default {
name: '',
components: { BaseTable },
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
tableProps,
list: [],
listLoading: false,
listQuery: {
current: 1,
size: 10
}
}
},
methods: {
init() {
this.listQuery = {
current: 1,
size: 10
}
this.getList()
},
getList() {
this.list = [
{
'name': '承压机',
'code': 'SB001',
'abbr': 'CYS',
'status': '运行正常'
},
{
'name': '传输线',
'code': 'SB002',
'abbr': 'TTS',
'status': '报警'
}
]
// this.listLoading = true
// staffList(this.listQuery).then(response => {
// if (response.data.records) {
// this.list = response.data.records
// } else {
// this.list.splice(0, this.list.length)
// }
// this.listLoading = false
// })
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,139 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-06 19:34:39
* @Description:
-->
<template>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
</template>
<script>
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
// import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'name',
label: i18n.t('module.orderManage.VerifyTable.teamName')
// filter: timeFormatter
},
{
prop: 'leader',
label: i18n.t('module.orderManage.VerifyTable.teamLeader'),
align: 'center'
},
{
prop: 'num',
label: i18n.t('module.orderManage.VerifyTable.number')
},
{
prop: 'major',
label: i18n.t('module.orderManage.VerifyTable.professional')
},
{
prop: 'wtime',
label: i18n.t('module.orderManage.VerifyTable.workingHours')
}
]
export default {
name: '',
components: { BaseTable },
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
tableProps,
list: [],
listLoading: false,
listQuery: {
current: 1,
size: 10
}
}
},
methods: {
init() {
this.listQuery = {
current: 1,
size: 10
}
this.getList()
},
getList() {
this.list = [
{
'name': '班组1',
'leader': '张三',
'num': '21',
'major': '电工,维修工,计划员,仓管员',
'wtime': '2020-11-26 19:12:37'
},
{
'name': '班组2',
'leader': '卫升',
'num': '12',
'major': '电工,维修工,仓管员',
'wtime': '2020-11-11 06:12:57'
},
{
'name': '班组3',
'leader': '李渊',
'num': '32',
'major': '会计,审核员',
'wtime': '2020-11-05 12:10:17'
}
]
// this.listLoading = true
// staffList(this.listQuery).then(response => {
// if (response.data.records) {
// this.list = response.data.records
// } else {
// this.list.splice(0, this.list.length)
// }
// this.listLoading = false
// })
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,115 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-06 19:25:55
* @Description:
-->
<template>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
</template>
<script>
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
// import { timeFormatter } from '@/filters'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'name',
label: i18n.t('module.orderManage.VerifyTable.materielName')
// filter: timeFormatter
},
{
prop: 'code',
label: i18n.t('module.orderManage.VerifyTable.materielCode'),
align: 'center'
},
{
prop: 'spec',
label: i18n.t('module.orderManage.VerifyTable.Spec')
}
]
export default {
name: '',
components: { BaseTable },
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
tableProps,
list: [],
listLoading: false,
listQuery: {
current: 1,
size: 10
}
}
},
methods: {
init() {
this.listQuery = {
current: 1,
size: 10
}
this.getList()
},
getList() {
this.list = [
{
'name': '001油漆',
'code': 'YQ-110',
'spec': '30D * 11B'
}
]
// this.listLoading = true
// staffList(this.listQuery).then(response => {
// if (response.data.records) {
// this.list = response.data.records
// } else {
// this.list.splice(0, this.list.length)
// }
// this.listLoading = false
// })
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,99 @@
<!--
* @Author: zwq
* @Date: 2021-02-27 14:49:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-03 16:28:15
* @Description: 工单验证
-->
<template>
<div>
<el-card class="box-card">
<div class="text item">
<el-row>
<el-col :span="12">
<el-row :gutter="20">
<el-col :span="23"><div class="title">{{ $t('module.orderManage.FalseData.FalseData31') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData32') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData33') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData34') }}</div></el-col>
</el-row>
</el-col>
<el-col :span="12">
<el-row :gutter="20">
<el-col :span="23"><div class="title">{{ $t('module.orderManage.FalseData.FalseData38') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData35') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData33') }}</div></el-col>
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData36') }}</div></el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="23"><div>{{ $t('module.orderManage.FalseData.FalseData37') }}</div></el-col>
</el-row>
</el-col>
</el-row>
</div>
</el-card>
</div>
</template>
<script>
export default {
name: '',
components: { },
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
}
},
created() {
},
methods: {
init() {
this.getList()
},
getList() {
// this.listLoading = true
// staffList(this.listQuery).then(response => {
// if (response.data.records) {
// this.list = response.data.records
// } else {
// this.list.splice(0, this.list.length)
// }
// this.listLoading = false
// })
}
}
}
</script>
<style scoped>
.text {
font-size: 18px;
}
.item {
margin-bottom: 18px;
}
.box-card {
width: 80%;
font-size: 30px;
margin: auto;
margin-top: 20px;
}
.el-col {
border-radius: 4px;
margin-bottom: 20px;
}
.title{
font-size: 40px;
color: #1588F5;
}
</style>

View File

@@ -0,0 +1,258 @@
<!--
* @Author: zwq
* @Date: 2021-02-26 15:32:13
* @LastEditors: gtz
* @LastEditTime: 2022-04-20 11:27:49
* @Description:
-->
<template>
<el-dialog
:title="!dataForm.id ? 'btn.add' : 'btn.edit' | i18nFilter"
:visible.sync="visible"
@open="onOpen"
@close="onClose"
>
<el-row :gutter="10">
<el-form
ref="dataForm"
:model="dataForm"
size="medium"
label-width="105px"
label-position="right"
:rules="dataFormRules"
>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.OrderName')" prop="orderName">
<el-input
v-model="dataForm.orderName"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.OrderName')])"
disabled
clearable
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.WorkOrderName')" prop="name">
<el-input
v-model="dataForm.name"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.WorkOrderName')])"
disabled
clearable
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.ProductName')" prop="productId">
<el-select
v-model="dataForm.productId"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.ProductName')])"
disabled
clearable
:style="{ width: '100%' }"
@change="changeProduct"
>
<el-option v-for="(item, index) in productOptions" :key="index" :label="item.name" :value="item.id" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.specifications')" prop="specifications">
<el-select
v-model="dataForm.productId"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.specifications')])"
disabled
clearable
:style="{ width: '100%' }"
>
<el-option
v-for="(item, index) in productOptions"
:key="index"
:label="item.specifications"
:value="item.id"
/>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.PlannedProcessingVolume')" prop="planQuantity">
<el-input-number
v-model="dataForm.planQuantity"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.PlannedProcessingVolume')])"
:style="{ width: '100%' }"
:step="1"
:min="0"
:max="9999999999999"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.PlanningEndTime')" prop="planQuantity">
<el-date-picker
v-model="dataForm.planFinishProduceTime"
type="datetime"
:placeholder="$t('module.orderManage.order.PlanningEndTime')"
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.ProductLines')" prop="productlines">
<el-select
v-model="dataForm.productlines"
:placeholder="$i18nForm(['placeholder.select', $t('module.orderManage.order.ProductLines')])"
multiple
clearable
:style="{ width: '100%' }"
>
<el-option v-for="(item, index) in productLineOptions" :key="index" :label="item.name" :value="item.id" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item :label="$t('module.orderManage.order.workers')" prop="workers">
<el-input
v-model="dataForm.workers"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.workers')])"
clearable
:style="{ width: '100%' }"
/>
</el-form-item>
</el-col>
</el-form>
</el-row>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">{{ 'btn.cancel' | i18nFilter }}</el-button>
<el-button type="primary" @click="dataFormSubmit()">{{ 'btn.confirm' | i18nFilter }}</el-button>
</span>
</el-dialog>
</template>
<script>
import { workOrderDetail, workOrderUpdate, workOrderAdd, workOrderCode, getProductLineList } from '@/api/orderManage/workOrder/workOrder'
import { list as ProductPoolList } from '@/api/basicData/ProductPool'
import i18n from '@/lang'
export default {
components: {},
inheritAttrs: false,
props: {
unitList: {
type: Array,
default: () => []
}
},
data() {
return {
visible: false,
dataForm: {
id: 0,
orderName: '',
name: '',
planQuantity: '',
planFinishProduceTime: '',
productId: '',
workers: '',
productlines: null
},
dataFormRules: {
planQuantity: [{ required: true, message: i18n.t('module.orderManage.order.PlannedProcessingVolume'), trigger: 'blur' }],
planFinishProduceTime: [{ required: true, message: i18n.t('module.orderManage.order.PlanningEndTime'), trigger: 'blur' }],
productlines: [{ required: true, message: i18n.t('module.orderManage.order.ProductLines'), trigger: 'blur' }],
workers: [{ required: true, message: i18n.t('module.orderManage.order.workers'), trigger: 'blur' }]
},
productOptions: [],
productUnitObj: {},
productLineOptions: []
}
},
computed: {},
watch: {},
created() { },
mounted() { },
methods: {
init(id) {
const listQuery = {
current: 1,
size: 500
}
this.dataForm.id = id || ''
this.productOptions.splice(0, this.productOptions.length)
ProductPoolList(listQuery).then(response => {
if (response.data.records) {
this.productOptions = response.data.records
response.data.records.map(item => {
this.productUnitObj[item.id] = String(item.dictDataId)
})
}
})
this.productLineOptions.splice(0, this.productLineOptions.length)
getProductLineList(listQuery).then(response => {
if (response.data.records) {
this.productLineOptions = response.data.records
}
})
this.visible = true
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
if (this.dataForm.id) {
workOrderDetail(this.dataForm.id).then(res => {
this.dataForm = res.data
if (this.dataForm.productlines && this.dataForm.productlines.length) {
this.dataForm.productlines = this.dataForm.productlines.map(i => {
return String(i.id)
})
}
})
} else {
workOrderCode().then(res => {
this.dataForm.workOrderNo = res.data
})
}
})
},
onOpen() { },
onClose() {
this.$refs['dataForm'].resetFields()
},
dataFormSubmit() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
this.dataForm.planFinishProduceTime = this.dataForm.planFinishProduceTime ? this.dataForm.planFinishProduceTime : ''
const data = this.dataForm
if (this.dataForm.id) {
workOrderUpdate(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
} else {
workOrderAdd(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
}
}
})
},
changeProduct(v) {
this.dataForm.dictDataId = this.productUnitObj[String(v)]
}
}
}
</script>

View File

@@ -0,0 +1,97 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 16:37:56
* @LastEditors: zwq
* @LastEditTime: 2021-04-15 14:00:51
* @enName:
-->
<template>
<el-dialog
:title="'routerTitle.order.workOrderManage.closeworkorder' | i18nFilter"
:visible.sync="visible"
>
<el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="110px" @keyup.enter.native="dataFormSubmit()">
<el-form-item :label="$t('module.orderManage.order.CompletionTime')" prop="finishProduceTime">
<el-date-picker
v-model="dataForm.finishProduceTime"
type="date"
format="yyyy-MM-dd"
:style="{width: '50%'}"
:placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.CompletionTime')])"
clearable
/>
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.ActualFinishedProduct')" prop="actualQuantity">
<el-input-number v-model="dataForm.actualQuantity" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.ActualFinishedProduct')])" :step="1" />
</el-form-item>
<el-form-item :label="$t('module.orderManage.order.DamageQuantityPlate')" prop="scrapQuantity">
<el-input-number v-model="dataForm.scrapQuantity" :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.DamageQuantityPlate')])" :step="1" />
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">{{ 'btn.cancel' | i18nFilter }}</el-button>
<el-button type="primary" @click="dataFormSubmit()">{{ 'btn.confirm' | i18nFilter }}</el-button>
</span>
</el-dialog>
</template>
<script>
import { workOrderUpdate } from '@/api/orderManage/workOrder/workOrder'
export default {
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
visible: false,
dataForm: {
finishProduceTime: '',
actualQuantity: '',
scrapQuantity: ''
},
closeData: {},
dataRule: {
finishProduceTime: [
{ required: true, message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.CompletionTime')]), trigger: 'change' }
]
}
}
},
methods: {
init(dataForm) {
this.visible = true
this.closeData = dataForm
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
})
},
// 表单提交
dataFormSubmit() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
this.closeData.status = 9
this.closeData.finishProduceTime = this.dataForm.finishProduceTime
this.closeData.actualQuantity = this.dataForm.actualQuantity
this.closeData.scrapQuantity = this.dataForm.scrapQuantity
workOrderUpdate(this.closeData).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
}
})
}
}
}
</script>

View File

@@ -0,0 +1,207 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-25 16:34:30
* @Description:
-->
<template>
<el-dialog
:title="'routerTitle.order.workOrderManage.issueworkorder' | i18nFilter"
:visible.sync="visible"
:before-close="goback"
:append-to-body="true"
width="80%"
>
<el-form
ref="formData"
:rules="rules"
:model="formData"
:inline="true"
size="medium"
label-width="150px"
>
<el-form-item :label="$t('module.orderManage.order.destination')" prop="syncTarget">
<el-select v-model="formData.syncTarget" filterable :placeholder="$i18nForm(['placeholder.input', $t('module.orderManage.order.destination')])" clearable>
<el-option
v-for="item in issueDestination"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="issueworkorder()"> {{ 'routerTitle.order.workOrderManage.issueworkorder' | i18nFilter }} </el-button>
</el-form-item>
</el-form>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
/>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
</el-dialog>
</template>
<script>
import { workOrderIssueList, syncAdd } from '@/api/orderManage/workOrder/workOrder'
import i18n from '@/lang'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import { timeFormatter } from '@/filters'
import basicData from '@/filters/basicData'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableProps = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.initiateTime'),
filter: timeFormatter,
align: 'center'
},
{
prop: 'syncTarget',
label: i18n.t('module.orderManage.order.destination'),
align: 'center',
filter: basicData('source')
},
{
prop: 'syncStatus',
label: i18n.t('module.orderManage.order.status'),
align: 'center',
filter: basicData('workStatus')
},
{
prop: 'reason',
label: i18n.t('module.orderManage.order.reason'),
align: 'center'
}
]
export default {
name: '',
components: { Pagination, BaseTable },
props: {
workOrderId: {
type: String,
default: () => {
return ''
}
}
},
data() {
return {
visible: false,
tableProps,
list: [],
total: 0,
listLoading: false,
formData: {
syncTarget: ''
},
issueDestination: [
{
label: '00A',
value: 4
},
{
label: 'PID1',
value: 3
},
{
label: '00C',
value: 5
}
],
listQuery: {
current: 1,
size: 10,
workOrderId: ''
},
rules: {
syncTarget: [{
required: true,
message: this.$i18nForm(['placeholder.input', this.$t('module.orderManage.order.destination')]),
trigger: 'change'
}]
}
}
},
methods: {
init(id) {
this.visible = true
this.listQuery.workOrderId = this.workOrderId
this.getList()
},
getList() {
this.listLoading = true
workOrderIssueList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
},
issueworkorder() {
this.$refs['formData'].validate((valid) => {
if (valid) {
const data = {
'wordOrderId': this.workOrderId,
'syncTarget': this.formData.syncTarget
}
syncAdd(data).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.getList()
}
})
})
}
})
},
goback() {
this.visible = false
this.$emit('refreshDataList')
}
}
}
</script>
<style scoped>
.edit-input {
padding-right: 100px;
}
.cancel-btn {
position: absolute;
right: 15px;
top: 10px;
}
</style>

View File

@@ -0,0 +1,40 @@
<!--
* @Date: 2021-01-07 20:09:37
* @LastEditors: gtz
* @LastEditTime: 2022-04-20 13:24:46
* @FilePath: \mt-bus-fe\src\views\orderManage\workOrder\components\workOrderBtn.vue
* @Description:
-->
<template>
<span>
<el-button type="text" size="small" @click="emitClick">{{ $t('module.orderManage.order.workOrderDetail') }}</el-button>
<work-order-detail v-if="visible" ref="orderDetail" :unit-obj="injectData.unitObj" @refreshDataList="refreshDataList" />
</span>
</template>
<script>
import workOrderDetail from './workOrderOperation.vue'
export default {
components: { workOrderDetail },
props: {
injectData: {
type: Object,
default: () => ({})
}
},
data() {
return {
visible: false
}
},
methods: {
emitClick() {
this.visible = true
this.$nextTick(() => {
this.$refs.orderDetail.init(this.injectData.id)
})
},
refreshDataList() {}
}
}
</script>

View File

@@ -0,0 +1,134 @@
<!--
* @Author: zwq
* @Date: 2021-02-23 11:05:06
* @LastEditors: zwq
* @LastEditTime: 2021-03-06 17:45:45
* @Description: 工单监控
-->
<template>
<div>
<el-card class="box-card">
<div slot="header" class="clearfix">
<span><b>{{ $t('module.orderManage.order.WorkOrderProgress') }}</b></span>
<el-button style="float: right;" type="success" @click="goback()">{{ 'btn.back' | i18nFilter }}</el-button>
</div>
<div class="text item">
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData2') }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData3') }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData5') }}</div></el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData6') }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData8') }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData9') }}</div></el-col>
</el-row>
</div>
<div style="width:50%">
<el-progress :text-inside="true" :stroke-width="26" :percentage="78" />
</div>
</el-card>
<el-card>
<div slot="header" class="clearfix">
<span><b>{{ $t('module.orderManage.order.energyConsumption') }}</b></span>
</div>
<el-menu
:default-active="activeIndex"
mode="horizontal"
background-color="#545c64"
text-color="#fff"
active-text-color="#ffd04b"
@select="handleSelect"
>
<el-menu-item index="1">{{ $t('module.orderManage.order.energyConsumptionChart') }}</el-menu-item>
<el-menu-item index="2">{{ $t('module.orderManage.order.energyConsumptionTable') }}</el-menu-item>
</el-menu>
</el-card>
<monitor-chart v-if="chartVisible" ref="monitorChart" :work-order-id="workOrderId" @refreshDataList="handleClick" />
<monitor-table v-if="tableVisible" ref="monitorTable" :work-order-id="workOrderId" @refreshDataList="handleClick" />
</div>
</template>
<script>
import monitorChart from './monitor-chart'
import monitorTable from './monitor-table'
export default {
name: '',
components: { monitorChart, monitorTable },
data() {
return {
chartVisible: false,
tableVisible: false,
workOrderId: '',
activeIndex: '1'
}
},
created() {
this.workOrderId = this.$route.query.id
this.handleSelect('1')
},
methods: {
handleClick() {
// this.addOrUpdateVisible = true
// this.$nextTick(() => {
// this.$refs.addOrUpdate.init(id)
// })
},
handleSelect(key, keyPath) {
this.chartVisible = false
this.tableVisible = false
switch (key) {
case '1':
this.chartVisible = true
this.$nextTick(() => {
this.$refs.monitorChart.init()
})
break
case '2':
this.tableVisible = true
this.$nextTick(() => {
this.$refs.monitorTable.init()
})
break
}
},
goback() {
this.$router.go(-1)
}
}
}
</script>
<style scoped>
.text {
font-size: 18px;
}
.item {
margin-bottom: 18px;
}
.clearfix:before,
.clearfix:after {
display: table;
content: "";
}
.clearfix:after {
clear: both
}
.box-card {
width: 70%;
font-size: 20px;
margin: auto;
margin-top: 20px;
margin-bottom: 20px;
}
.el-row {
margin-bottom: 20px;
}
.el-col {
border-radius: 4px;
}
</style>

View File

@@ -0,0 +1,239 @@
<!--
* @Author: zwq
* @Date: 2021-02-27 14:39:57
* @LastEditors: gtz
* @LastEditTime: 2022-04-20 13:40:30
* @Description:
-->
<template>
<el-dialog
:title="'btn.detail' | i18nFilter"
:close-on-click-modal="false"
:visible.sync="visible"
width="1200"
>
<div class="detailBox">
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.WorkOrderName') }}</p>
<p class="text">{{ stringfilter(dataForm.name) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.workOrderDetail.workOrderStatus') }}</p>
<p class="text">{{ dataForm.status|commonFilter(newBasicData('1526063541841727490')) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.source') }}</p>
<p class="text">{{ dataForm.triggerOrigin|commonFilter(newBasicData('1523941494259912706')) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.createTime') }}</p>
<p class="text">{{ timefilter(dataForm.createTime) }}</p>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.PlannedProcessingVolume') }}</p>
<p class="text">{{ dataForm.planQuantity }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.unit') }}</p>
<p class="text">{{ stringfilter(dataForm.dictDataId ? unitObj[String(dataForm.dictDataId)] : '') }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.specifications') }}</p>
<p class="text">{{ stringfilter(dataForm.specifications) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.ActualFinishedProduct') }}</p>
<p class="text">{{ dataForm.actualQuantity }}</p>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.ProductName') }}</p>
<p class="text">{{ stringfilter(dataForm.productName) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.priority') }}</p>
<p class="text">{{ dataForm.priority | commonFilter(newBasicData('1524577291887898626')) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.triggerTime') }}</p>
<p class="text">{{ timefilter(dataForm.triggerTime) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.StartTime') }}</p>
<p class="text">{{ timefilter(dataForm.startProduceTime) }}</p>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.PlanningEndTime') }}</p>
<p class="text">{{ timefilter(dataForm.planFinishProduceTime) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.EndTime') }}</p>
<p class="text">{{ timefilter(dataForm.finishProduceTime) }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.ProductLines') }}</p>
<p class="text">{{ (dataForm.productlines && dataForm.productlines.length ? dataForm.productlines.map(item => item.name).join(',') : '') }}</p>
</el-col>
<el-col :span="6">
<p class="title">{{ $t('module.orderManage.order.workers') }}</p>
<p class="text">{{ stringfilter(dataForm.workers) }}</p>
</el-col>
</el-row>
</div>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">{{ 'btn.cancel' | i18nFilter }}</el-button>
<!-- <el-button type="primary" @click="stopWorkOrder()">{{ 'btn.end' | i18nFilter }}</el-button> -->
</span>
</el-dialog>
</template>
<script>
import { workOrderDetail, updateForStatus, workOrderComplete } from '@/api/orderManage/workOrder/workOrder'
import { timeFormatter } from '@/filters'
import newBasicData from '@/filters/newBasicData'
export default {
name: '',
filters: {
commonFilter: (source, filterType = a => a) => {
return filterType(source)
}
},
props: {
unitObj: {
type: Object,
default: () => {}
}
},
data() {
return {
visible: false,
workOrderId: '',
dataForm: {},
newBasicData
}
},
created() {
this.init()
},
methods: {
init(id) {
this.workOrderId = id
this.visible = true
this.dataForm = {}
this.$nextTick(() => {
workOrderDetail(this.workOrderId).then(res => {
this.dataForm = res.data
})
})
},
stopWorkOrder() {
this.$confirm(this.$t('module.orderManage.order.stopBefore'), this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
}).then(() => {
workOrderComplete({ id: this.workOrderId }).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.visible = false
this.$emit('refreshDataList')
}
})
})
}).catch(() => {})
},
handleClick() {
// this.addOrUpdateVisible = true
// this.$nextTick(() => {
// this.$refs.addOrUpdate.init(id)
// })
},
activation() {
const data = {}
data.status = '3'
data.id = this.workOrderId
updateForStatus(data).then(res => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500
})
})
},
closeClick() {
this.closeVisible = true
this.$nextTick(() => {
this.$refs.closeWorkOrder.init(this.dataForm)
})
},
issueClick() {
this.issueVisible = true
this.$nextTick(() => {
this.$refs.issueWorkOrder.init()
})
},
tagsClick() {
this.$router.push({
name: 'packingTags',
query: {
id: this.workOrderId
}
})
},
verifyClick() {
this.$router.push({
name: 'workOrderVerify',
query: {
id: this.workOrderId
}
})
},
monitorClick() {
this.$router.push({
name: 'workOrderMonitor',
query: {
id: this.workOrderId
}
})
},
goback() {
this.$router.go(-1)
},
timefilter(obj) {
return timeFormatter(obj).substring(0, timeFormatter(obj).lastIndexOf(' '))
},
stringfilter(objString) {
return objString || ''
}
}
}
</script>
<style scoped>
.detailBox p {
margin: 0;
padding: 0 20px;
}
.detailBox .title {
font-size: 14px;
font-weight: 600;
color: rgba(0,0,0,0.65);
padding-bottom: 10px;
}
.detailBox .text {
font-size: 14px;
font-weight: 400;
color: rgba(102,102,102,0.75);
padding-bottom: 20px;
}
</style>

View File

@@ -0,0 +1,163 @@
<!--
* @Author: zwq
* @Date: 2021-02-27 14:49:11
* @LastEditors: zwq
* @LastEditTime: 2021-03-06 17:58:53
* @Description: 工单验证
-->
<template>
<div>
<el-card class="box-card">
<div slot="header" class="clearfix">
<span><b>{{ $t('module.orderManage.FalseData.FalseData1') }}</b></span>
<el-button style="float: right;" type="success" @click="goback()">{{ 'btn.back' | i18nFilter }}</el-button>
</div>
<div class="text item">
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData2') }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData3') }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData5') }}</div></el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData6') }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData8') }}</div></el-col>
<el-col :span="6"><div>{{ $t('module.orderManage.FalseData.FalseData9') }}</div></el-col>
</el-row>
</div>
</el-card>
<el-card>
<div slot="header" class="clearfix">
<span><b>{{ $t('module.orderManage.order.workOrderVerificationResult') }}</b></span>
</div>
<el-menu
:default-active="activeIndex"
mode="horizontal"
background-color="#545c64"
text-color="#fff"
active-text-color="#ffd04b"
@select="handleSelect"
>
<el-menu-item index="1">{{ $t('module.orderManage.order.deviceDetection') }}</el-menu-item>
<el-menu-item index="2">{{ $t('module.orderManage.order.process') }}</el-menu-item>
<el-menu-item index="3">{{ $t('module.orderManage.order.useMaterial') }}</el-menu-item>
<el-menu-item index="4">{{ $t('module.orderManage.order.basePlate') }}</el-menu-item>
<el-menu-item index="5">{{ $t('module.orderManage.order.team') }}</el-menu-item>
</el-menu>
</el-card>
<verify-equipment v-if="equipmentVisible" ref="verifyEquipment" :work-order-id="workOrderId" @refreshDataList="handleClick" />
<verify-craft v-if="craftVisible" ref="verifyCraft" :work-order-id="workOrderId" @refreshDataList="handleClick" />
<verify-group v-if="groupVisible" ref="verifyGroup" :work-order-id="workOrderId" @refreshDataList="handleClick" />
<verify-materiel v-if="materielVisible" ref="verifyMateriel" :work-order-id="workOrderId" @refreshDataList="handleClick" />
<verify-plate v-if="plateVisible" ref="verifyPlate" :work-order-id="workOrderId" @refreshDataList="handleClick" />
</div>
</template>
<script>
import verifyEquipment from './verify-equipment'
import verifyCraft from './verify-craft'
import verifyGroup from './verify-group'
import verifyMateriel from './verify-materiel'
import verifyPlate from './verify-plate'
export default {
name: '',
components: { verifyEquipment, verifyCraft, verifyGroup, verifyMateriel, verifyPlate },
data() {
return {
equipmentVisible: false,
craftVisible: false,
groupVisible: false,
materielVisible: false,
plateVisible: false,
workOrderId: '',
activeIndex: '1'
}
},
created() {
this.workOrderId = this.$route.query.id
this.handleSelect('1')
},
methods: {
handleClick() {
// this.addOrUpdateVisible = true
// this.$nextTick(() => {
// this.$refs.addOrUpdate.init(id)
// })
},
handleSelect(key, keyPath) {
this.equipmentVisible = false
this.craftVisible = false
this.groupVisible = false
this.materielVisible = false
this.plateVisible = false
switch (key) {
case '1':
this.equipmentVisible = true
this.$nextTick(() => {
this.$refs.verifyEquipment.init()
})
break
case '2':
this.craftVisible = true
this.$nextTick(() => {
this.$refs.verifyCraft.init()
})
break
case '3':
this.materielVisible = true
this.$nextTick(() => {
this.$refs.verifyMateriel.init()
})
break
case '4':
this.plateVisible = true
this.$nextTick(() => {
this.$refs.verifyPlate.init()
})
break
case '5':
this.groupVisible = true
this.$nextTick(() => {
this.$refs.verifyGroup.init()
})
break
}
},
goback() {
this.$router.go(-1)
}
}
}
</script>
<style scoped>
.text {
font-size: 18px;
}
.item {
margin-bottom: 18px;
}
.clearfix:before,
.clearfix:after {
display: table;
content: "";
}
.clearfix:after {
clear: both
}
.box-card {
width: 80%;
font-size: 30px;
margin: auto;
margin-top: 20px;
}
.el-row {
margin-bottom: 20px;
}
.el-col {
border-radius: 4px;
}
</style>

View File

@@ -0,0 +1,510 @@
<!--
* @Author: zwq
* @Date: 2020-12-29 15:41:11
* @LastEditors: gtz
* @LastEditTime: 2022-07-25 10:35:36
* @Description:
-->
<template>
<div class="app-container">
<head-form
:form-config="headFormConfig"
@headBtnClick="btnClick"
/>
<el-row>
<el-tabs v-model="orderStatus" @tab-click="getList">
<el-tab-pane name="1" :label="$t('module.orderManage.order.all')" />
<el-tab-pane name="2" :label="$t('module.orderManage.order.unComplete')" />
<el-tab-pane name="3" :label="$t('module.orderManage.order.complete')" />
</el-tabs>
</el-row>
<base-table
:page="listQuery.current"
:limit="listQuery.size"
:height="tableH"
:table-config="tableProps"
:table-data="list"
:is-loading="listLoading"
@emitFun="handleTableEvents"
>
<method-btn
v-if="tableBtn.length"
slot="handleBtn"
:width="trueWidth"
:method-list="tableBtn"
@clickBtn="handleClick"
/>
</base-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="listQuery.current"
:limit.sync="listQuery.size"
@pagination="getList()"
/>
<workOrder-add v-if="addOrUpdateVisible" ref="addOrUpdate" :unit-list="unitList" @refreshDataList="getList" />
<work-order-detail v-if="visibleOrderDetail" ref="orderDetail" :unit-obj="unitObj" @refreshDataList="getList" />
<start-stop ref="startStopOrder" @refreshDataList="getList" />
<edit-batch v-if="updateBatch" ref="updateBatch" />
</div>
</template>
<script>
import HeadForm from '@/components/basicData/HeadForm'
import { workOrderList, workOrderDelete } from '@/api/orderManage/workOrder/workOrder'
import i18n from '@/lang'
import workOrderAdd from './components/workOrder-add'
import completionSchedule from '../order/components/completionSchedule.vue'
import mapColumn from '../components/mapColumn.vue'
import BaseTable from '@/components/BaseTable'
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
import { timeFormatter } from '@/filters'
import newBasicData from '@/filters/newBasicData'
import workOrderDetail from './components/workOrderOperation.vue'
import commonBtn from '@/components/BaseTable/subcomponents/CommonBtn.vue'
import startStop from './components/startStop.vue'
import { tableHeight } from '@/utils/index'
import editBatch from './components/editBatch.vue'
/**
* 表格表头配置项 TypeScript接口注释
* tableConfig<ConfigItem> = []
*
* Interface ConfigItem = {
* prop: string,
* label: string,
* width: string,
* align: string,
* subcomponent: function,
* filter: function
* }
*
*
*/
const tableBtn1 = [
{
type: 'detail',
btnName: 'btn.detail'
},
{
type: 'start',
btnName: 'btn.start',
showParam: {
type: '&',
data: [
{
type: 'indexof',
name: 'status',
value: [1, 2, 3, 4]
}
]
}
},
{
type: 'stop',
btnName: 'btn.end',
showParam: {
type: '&',
data: [
{
type: 'unequal',
name: 'status',
value: 9
}
]
}
},
{
type: 'edit',
btnName: 'btn.edit',
showParam: {
type: '&',
data: [
{
type: 'indexof',
name: 'status',
value: [1, 2]
}
]
}
},
{
type: 'delete',
btnName: 'btn.delete',
showParam: {
type: '&',
data: [
{
type: 'indexof',
name: 'status',
value: [1, 2]
}
]
}
}
]
const tableBtn2 = [
{
type: 'detail',
btnName: 'btn.detail'
}
]
const tablePropsAll = [
{
prop: 'createTime',
label: i18n.t('module.orderManage.order.createTime'),
filter: timeFormatter,
minWidth: 160,
isFixed: true
},
{
prop: 'name',
label: i18n.t('module.orderManage.order.WorkOrderName'),
minWidth: 230,
isFixed: true
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.WorkOrderCode'),
width: 180
},
{
prop: 'triggerTime',
label: i18n.t('module.orderManage.order.IssueOrder'),
filter: timeFormatter,
minWidth: 160
},
{
prop: 'startProduceTime',
label: i18n.t('module.orderManage.order.WorkOrderStartTime'),
filter: timeFormatter,
minWidth: 160
},
{
prop: 'orderName',
label: i18n.t('module.orderManage.order.OrderName')
},
{
prop: 'priority',
label: i18n.t('module.orderManage.order.priority'),
filter: newBasicData('1524577291887898626'),
width: 100
},
{
prop: 'triggerOrigin',
label: i18n.t('module.orderManage.order.source'),
filter: newBasicData('1523941494259912706'),
width: 100
},
{
prop: 'status',
label: i18n.t('module.orderManage.workOrderDetail.workOrderStatus'),
filter: newBasicData('1526063541841727490'),
width: 100
},
{
prop: 'planQuantity',
label: i18n.t('module.orderManage.order.PlannedProcessingVolume'),
width: 100
},
{
prop: 'actualQuantity',
label: i18n.t('module.orderManage.order.ActualFinishedProduct'),
width: 100
},
{
prop: 'scrapQuantity',
label: i18n.t('module.orderManage.order.NumberOfDamages'),
width: 100
},
{
prop: 'batch',
label: i18n.t('module.orderManage.workOrderDetail.originalBatch'),
subcomponent: commonBtn,
buttonContent: i18n.t('module.orderManage.workOrderDetail.batchDetail'),
emitFullData: true
}
]
const tablePropsUnComplete = [
{
prop: 'name',
label: i18n.t('module.orderManage.order.WorkOrderName'),
minWidth: 230,
isFixed: true
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.WorkOrderCode'),
width: 180
},
{
prop: 'workers',
label: i18n.t('module.orderManage.order.workers'),
width: 100
},
{
prop: 'triggerTime',
label: i18n.t('module.orderManage.order.IssueOrder'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'startProduceTime',
label: i18n.t('module.orderManage.order.WorkOrderStartTime'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'planFinishProduceTime',
label: i18n.t('module.orderManage.order.PlanningEndTime'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'customerName',
label: i18n.t('module.orderManage.order.customer'),
width: 100
},
{
prop: 'priority',
label: i18n.t('module.orderManage.order.priority'),
filter: newBasicData('1524577291887898626'),
width: 100
},
{
prop: 'triggerOrigin',
label: i18n.t('module.orderManage.order.source'),
filter: newBasicData('1523941494259912706'),
width: 100
},
{
prop: 'dictDataId',
label: i18n.t('module.orderManage.order.unit'),
filter: newBasicData('1'),
width: 100
},
{
prop: 'planQuantity',
label: i18n.t('module.orderManage.order.PlannedProcessingVolume'),
width: 100
}
]
const tablePropsComplete = [
{
prop: 'name',
label: i18n.t('module.orderManage.order.WorkOrderName'),
minWidth: 230,
isFixed: true
},
{
prop: 'code',
label: i18n.t('module.orderManage.order.WorkOrderCode'),
width: 180
},
{
prop: 'workers',
label: i18n.t('module.orderManage.order.workers'),
width: 100
},
{
prop: 'triggerTime',
label: i18n.t('module.orderManage.order.IssueOrder'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'startProduceTime',
label: i18n.t('module.orderManage.order.WorkOrderStartTime'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'finishProduceTime',
label: i18n.t('module.orderManage.order.CompletionTime'),
minWidth: 160,
filter: timeFormatter
},
{
prop: 'dictDataId',
label: i18n.t('module.orderManage.order.unit'),
filter: newBasicData('1'),
width: 100
},
{
prop: 'planQuantity',
label: i18n.t('module.orderManage.order.PlannedProcessingVolume'),
width: 100
},
{
prop: 'actualQuantity',
label: i18n.t('module.orderManage.order.ActualFinishedProduct'),
width: 100
},
{
prop: 'completionSchedule',
label: i18n.t('module.orderManage.orderDetail.completionSchedule'),
subcomponent: completionSchedule,
width: 100
},
{
prop: 'productlines',
label: i18n.t('module.orderManage.order.ProductLines'),
subcomponent: mapColumn
}
]
export default {
name: 'ScrapInfo',
components: { HeadForm, Pagination, BaseTable, MethodBtn, workOrderAdd, editBatch, workOrderDetail, startStop },
data() {
return {
addOrUpdateVisible: false,
tableBtn: [],
tableBtn1,
tableBtn2,
trueWidth: 180,
tableH: tableHeight(333),
tablePropsAll,
tablePropsUnComplete,
tablePropsComplete,
tableProps: [],
list: [],
total: 0,
listLoading: false,
listQuery: {
current: 1,
size: 20
},
headFormConfig: [
{
type: 'input',
label: i18n.t('module.orderManage.order.WorkOrderName'),
placeholder: this.$t('module.orderManage.order.WorkOrderName'),
param: 'workOrderNo'
},
{
type: 'datePicker',
label: this.$t('module.orderManage.order.ActualStartTime'),
dateType: 'daterange',
format: 'yyyy-MM-dd',
valueFormat: 'yyyy-MM-dd',
rangeSeparator: '-',
startPlaceholder: this.$t('module.orderManage.order.StartTime'),
endPlaceholder: this.$t('module.orderManage.order.EndTime'),
param: 'timeSlot'
},
{
type: 'button',
btnName: 'btn.search',
name: 'search',
color: 'primary'
}
],
visibleOrderDetail: false,
updateBatch: false,
headFormValue: {},
orderStatus: '1',
unitList: JSON.parse(localStorage.getItem('dictObj'))['1'],
unitObj: {}
}
},
mounted() {
window.addEventListener('resize', () => {
this.tableH = tableHeight(333)
})
this.unitList.map(item => {
this.unitObj[item.dataCode] = item.dataName
})
this.getList()
},
methods: {
handleClick(raw) {
if (raw.type === 'delete') {
this.$confirm(`${this.$t('module.basicData.visual.TipsBefore')}[${raw.data.name}]`, this.$t('module.basicData.visual.Tips'), {
confirmButtonText: this.$t('module.basicData.visual.confirmButtonText'),
cancelButtonText: this.$t('module.basicData.visual.cancelButtonText'),
type: 'warning'
}).then(() => {
workOrderDelete(raw.data.id).then(response => {
this.$message({
message: this.$t('module.basicData.visual.success'),
type: 'success',
duration: 1500,
onClose: () => {
this.listQuery.current = 1
this.getList()
}
})
})
}).catch(() => {})
} else if (raw.type === 'detail') {
this.visibleOrderDetail = true
this.$nextTick(() => {
this.$refs.orderDetail.init(raw.data.id)
})
} else if (raw.type === 'edit') {
this.addNew(raw.data.id)
} else if (raw.type === 'start') {
this.$refs.startStopOrder.init(raw.data.id, 'start')
} else if (raw.type === 'stop') {
this.$refs.startStopOrder.init(raw.data.id, 'stop')
}
},
getList() {
if (this.orderStatus === '1') {
this.listQuery.status = ''
this.tableBtn = this.tableBtn1
this.trueWidth = 180
this.tableProps = this.tablePropsAll
} else if (this.orderStatus === '3') {
this.listQuery.status = 9
this.tableBtn = this.tableBtn2
this.trueWidth = 60
this.tableProps = this.tablePropsComplete
} else if (this.orderStatus === '2') {
this.listQuery.status = 1
this.tableBtn = this.tableBtn1
this.trueWidth = 180
this.tableProps = this.tablePropsUnComplete
}
this.listLoading = true
this.listQuery.name = this.headFormValue.workOrderNo
this.listQuery.startTime = this.headFormValue.timeSlot ? this.headFormValue.timeSlot[0] + 'T00:00:00' : ''
this.listQuery.endTime = this.headFormValue.timeSlot ? this.headFormValue.timeSlot[1] + 'T23:59:59' : ''
workOrderList(this.listQuery).then(response => {
if (response.data.records) {
this.list = response.data.records
} else {
this.list.splice(0, this.list.length)
}
this.total = response.data.total
this.listLoading = false
})
},
// 新增 / 修改
addNew(id) {
this.addOrUpdateVisible = true
this.$nextTick(() => {
this.$refs.addOrUpdate.init(id)
})
},
btnClick(val) {
this.headFormValue = val
// 如果点击的是搜索栏的其他按钮在这里继续写判断
if (this.headFormValue.btnName === 'search') {
this.listQuery.current = 1
this.getList()
}
},
handleTableEvents({ action, data }) {
switch (action) {
case 'view-detail-action':
this.updateBatch = true
this.$nextTick(() => {
this.$refs.updateBatch.init(data.id)
})
}
}
}
}
</script>