You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

698 lines
21 KiB

1 year ago
<template>
<!-- <el-dialog title="收货地址" :visible.sync="dialogFormVisible">-->
<el-container>
<el-header style="width: 100%; height: 80px;font-size: 12px">
<el-form :inline="true" label-width="60px" label-position="left">
<el-row>
<el-col :span="22">
8 months ago
<el-col :span="5" >
10 months ago
<el-form-item label="状态:">
8 months ago
<el-select v-model="queryParam.zt" placeholder="状态" @change="ztChange">
10 months ago
<el-option
v-for="item in statusOptions"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
</el-form-item>
</el-col>
1 year ago
<el-form-item label="船号:">
<vxe-pulldown ref="xDown4" transfer >
<template #default>
<vxe-input
v-model="queryParam.dcch"
placeholder="船号"
style="height: 28px;
line-height: 28px; width: 140px;"
suffix-icon="vxe-icon--search"
@keyup="keyupEvent4"
@focus="focusEvent4"
/>
</template>
<template #dropdown>
<div class="my-dropdown mytable " style="width: 250px">
<vxe-grid
highlight-hover-row
height="auto"
:data="projectData"
:columns="projectColumns"
@cell-click="cellClickEvent"
show-overflow
>
<template #wgbsEdit="{ row}">
<vxe-checkbox v-model="row.wgbs" checked-value="Y" unchecked-value="N" disabled ></vxe-checkbox>
</template>
</vxe-grid>
</div>
</template>
</vxe-pulldown>
</el-form-item>
<!-- <el-form-item label="批量:">-->
<!-- <el-input v-model="queryParam.pl" type="search" placeholder="批量" ></el-input>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="分段:">-->
<!-- <el-input v-model="queryParam.fd" type="search" placeholder="分段" ></el-input>-->
<!-- </el-form-item>-->
1 year ago
</el-col>
<el-col :span="2">
1 year ago
<el-form-item style="float: right" >
<el-button type="success" @click="initList"></el-button>
</el-form-item>
</el-col>
</el-row>
<el-row>
10 months ago
<el-col :span="20" >
8 months ago
<span style="width:6%" >作业区:</span>
<el-select v-model="inParam.scdw" placeholder="作业区" clearable style="width: 15%" @change="bzClick">
10 months ago
<el-option
8 months ago
v-for="item in this.dictData.resourcesCodes"
8 months ago
:key="item.zyq"
:label="item.zyq"
:value="item.zyq"
10 months ago
>
</el-option>
</el-select>
8 months ago
<span style="width:6%" >班组:</span>
<el-select v-model="inParam.zyq" placeholder="班组" clearable style="width: 15%" @change="bzClick1">
10 months ago
<el-option
8 months ago
v-for="item in this.dictData.zyqs"
8 months ago
:key="item.zyq+item.resourcesCode"
:label="item.zyq+item.resourcesCode"
:value="item.resourcesCode"
10 months ago
>
</el-option>
</el-select>
8 months ago
8 months ago
<el-select v-model="inParam.scry" placeholder="人员" clearable style="width: 15%" filterable >
<el-option
v-for="item in this.dictData.zyrys"
:key="item.id"
8 months ago
:label="item.zyq+item.resourcesCode+item.userName"
8 months ago
:value="item.userName"
>
</el-option>
</el-select>
10 months ago
<el-button type="info" @click="updates2()" style="width: 5%">批量</el-button>
<!-- <span style="width:6%" >反馈人员:</span>-->
<!-- <el-input v-model="inParam.slry" placeholder="反馈人员" clearable style="width:10%" />-->
<!-- <span style="width:6%" >反馈日期:</span>-->
<!-- <el-date-picker v-model="inParam.sljs" value-format="yyyy/MM/dd" format="yyyy/MM/dd" type="date" style="width: 15%" placeholder="反馈日期"/>-->
<!-- <el-button type="info" @click="updates('2')" style="width: 5%">批量</el-button>-->
1 year ago
</el-col>
<el-col :span="4" >
<el-form-item style="float: right" >
10 months ago
<el-button type="success" @click="slpgclick"></el-button>
8 months ago
<el-button type="success" @click="saveclick"></el-button>
10 months ago
1 year ago
</el-form-item>
</el-col>
</el-row>
</el-form>
</el-header>
<el-container style="padding-top: 0px">
<el-container>
<el-main>
<div class="mytable">
<vxe-grid
id="id"
ref="xGrid"
border
resizable
keep-source
:align="'center'"
:height="height"
:auto-resize="true"
:columns="tableColumn"
highlight-current-row
:data="list"
:scroll-y="{enabled: true}"
10 months ago
:edit-config="{trigger: 'click', mode: 'cell', showStatus: true}"
1 year ago
highlight-hover-row
show-overflow
show-header-overflow
8 months ago
:header-cell-style="headerCellStyle"
1 year ago
>
</vxe-grid>
</div>
</el-main>
</el-container>
</el-container>
</el-container>
</template>
<script>
import {
getPwPgd,
savePwFk,
getPgdBase,
savePwPgdXd,
savePwPgdXdBack,
savePwjhPg,
savePwjhPgBack
1 year ago
} from '@/api/jhzxgl/pgd'
import { mapGetters } from 'vuex'
import XEUtils from 'xe-utils'
import {null2str} from "@/utils/rpkj";
import { getToken } from '@/utils/auth'
import { startLoading, endLoading } from '@/utils'
import { Message } from 'element-ui'
export default {
10 months ago
name:'PwjhD',
1 year ago
data() {
return {
queryParam: {
dcch:'',
field:'',
user:'',
jhrqField:'',
zt:'42',
8 months ago
ztHx:'52'
1 year ago
},
8 months ago
zyqs:[],
zyrys:[],
1 year ago
statusOptions: [
{
value: "11",
label: "已打印",
},
1 year ago
{
8 months ago
value: "42",
label: "未派工",
1 year ago
},
{
value: "61",
8 months ago
label: "未报工",
1 year ago
},
{
value: "62",
8 months ago
label: "已报工",
1 year ago
},
1 year ago
],
10 months ago
inParam:{
slry:'',
slks:'',
sljs:'',
dw:'',
scry:'',
scdw:''
},
1 year ago
list: [],
heads: { token: getToken() },
uploadAction: process.env.VUE_APP_BASE_API + '/dmCzplpNew/uploadPl',
dictData:{},
height: '500px',
projectData:[],
projectData1:[],
projectColumns: [
{field: 'cbbm', title: '船号',width: 110},
{ field: 'wgbs', title: '完工标识', width: 80,
slots:{
default: 'wgbsEdit'
},
},
],
10 months ago
1 year ago
tableColumn: [
{ type: 'checkbox', width: 40 },
{ type: 'seq', width: 40, title: '序号' },
8 months ago
{
field: 'djh',
title: '单据号',
width: 100,
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
},
{ field: 'dcCh', title: '船号',width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
1 year ago
{ field: 'dcPl', title: '批量',width: 80,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
{ field: 'dcFd', title: '分段号',width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
{ field: 'zl', title: '组立',width: 80,formatter: ['dictFormat','ZLLB'],
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
{ field: 'kw', title: '跨位',width: 80,formatter: ['dictFormat','QGKW'],
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
{ field: 'tzbh', title: '套料图号',width: 90,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
{ field: 'jssj', title: '前方需求时间',width: 110,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
8 months ago
{ field: 'qgjhrq', title: '切割计划日期',width: 110,
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
// { field: 'lqlb', title: '领取类型',width: 90,formatter: ['dictFormat','CLlQ'],
// filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
// filterRender: { name: 'FilterCombination', }},
// { field: 'lx', title: '物资类型',width: 90,formatter:this.formatterLx,
// filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
// filterRender: { name: 'FilterCombination', }},
1 year ago
{ field: 'wpgg', title: '规格',width: 80,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination', }},
1 year ago
{ field: 'wpxh', title: '材质',width: 80,
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],},
1 year ago
8 months ago
{
field: 'lldw',
title: '理料垛位',
width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
1 year ago
},
{
8 months ago
field: 'llcs',
title: '理料层数',
width: 100,
10 months ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
10 months ago
},
{
field: 'qgry',
title: '切割人员',
width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
1 year ago
},
{
field: 'qgpgry',
title: '切割派工人',
width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
1 year ago
},
{
field: 'qgpgrq',
title: '切割派工日期',
width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
1 year ago
},
{
field: 'qgfkry',
title: '切割反馈人',
width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
1 year ago
},
{
field: 'qgfkrq',
title: '切割反馈日期',
width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
1 year ago
},
{
field: 'qgbz',
title: '切割备注',
width: 100,
1 year ago
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
filterRender: { name: 'FilterCombination' }
1 year ago
},
]
}
},
computed: {
...mapGetters(['name', 'bmbm'])
},
created() {
window.addEventListener('resize', this.getHeight)
this.getHeight()
this.initBase()
1 year ago
},
methods: {
8 months ago
headerCellStyle ({ column, columnIndex }) {
if (['qgry','qgpgrq','qgpgry','qgfkry','qgfkrq'].includes(column.property)) {
return {
backgroundColor: '#2db7f5',
color: '#ffffff'
}
}
},
1 year ago
cellClickEvent({row}) {
this.queryParam.dcch = row.cbbm
this.$refs.xDown4.hidePanel()
},
focusEvent4() {
this.$refs.xDown4.showPanel()
},
keyupEvent4() {
if (this.queryParam.dcch) {
10 months ago
this.projectData = this.projectData1.filter(row => row.cbbm.indexOf(this.queryParam.dcch.toUpperCase()) > -1)
1 year ago
} else {
this.projectData = this.projectData1.slice(0)
}
},
10 months ago
ztChange(){
this.list=[]
},
bzClick(){
console.log(this.dictData.gxry)
console.log(this.inParam.scdw)
8 months ago
this.dictData.zyqs= this.zyqs.filter(fst=>fst.zyq===this.inParam.scdw)
8 months ago
console.log(this.dictData.zyqs)
},
bzClick1(){
console.log(this.dictData.zyrys)
console.log(this.zyrys)
8 months ago
this.dictData.zyrys= this.zyrys.filter(fst=>fst.zyq+fst.resourcesCode===this.inParam.scdw+this.inParam.zyq)
10 months ago
console.log(this.dictData.gxry)
},
updates2(){
let selectRecords = this.$refs.xGrid.getCheckboxRecords()
1 year ago
10 months ago
if(selectRecords.length>0){
for(let i = 0; i < selectRecords.length; i++) {
1 year ago
// selectRecords[i].dw = this.inParam.dw
//selectRecords[i].scdw = this.inParam.scdw
selectRecords[i].qgry = this.inParam.scry
selectRecords[i].qgpgry = this.name
// selectRecords[i].pwpgrq = this.inParam.scry
1 year ago
10 months ago
}
this.$refs.xGrid.updateData(this.list)
1 year ago
}
},
10 months ago
updates(type){
let selectRecords = this.$refs.xGrid.getCheckboxRecords()
if(selectRecords.length>0){
for(let i = 0; i < selectRecords.length; i++) {
if(type==='1'){
selectRecords[i].slksrq = this.inParam.slks
}else if (type==='2'){
selectRecords[i].fkry = this.inParam.slry
selectRecords[i].fkrq = this.inParam.sljs
}
}
this.$refs.xGrid.updateData(this.list)
}
},
activeRowMethod({ row, rowIndex }){
// if(row.zt==="01"){
// return true
// }else{
// return false
// }
return true;
},
1 year ago
initBase(){
getPgdBase({}).then(res=>{
10 months ago
console.log(res.data)
8 months ago
this.zyqs=res.data.zyqs
this.zyrys=res.data.zyrys
1 year ago
this.dictData = res.data
this.projectData=res.data.cbbm
this.projectData1=res.data.cbbm
})
},
plClick(){
let selectRecords = this.$refs.xGrid.getCheckboxRecords()
if(selectRecords.length>0){
for(let i = 0; i < selectRecords.length; i++) {
selectRecords[i].fkyy = this.queryParam.fkyy
}
this.$refs.xGrid.updateData(this.list)
}
},
saveclick(){
if(this.queryParam.zt!=='61'){
10 months ago
return
}
10 months ago
let obj=this.$refs.xGrid.getCheckboxRecords()
// if(obj.length===0){
// this.$message({ message: '请填写反馈原因在进行反馈', type: 'warning' })
// return
// }
savePwjhPgBack({
'field': 'qgfkrq',
'fieldry': 'qgfkry',
'zxZtName':'QGFK',
'list':obj
}).then(res=>{
1 year ago
if(res.success){
this.initList()
}
})
},
10 months ago
slpgclick(){
8 months ago
if(this.queryParam.zt!=="42"){
10 months ago
return
}
1 year ago
let obj=this.$refs.xGrid.getCheckboxRecords()
if(obj.length===0){
return
}
8 months ago
for(let i =0;i<obj.length;i++){
let rows =this.$refs.xGrid.getRowSeq(obj[i])
if(obj[i].qgry==null||obj[i].qgry===''){
this.$message({ message: '第'+rows+'行施工人不能为空', type: 'error' })
return
}
}
// 判断施工人 不能为空
// if(this.queryParam.zt==='02'){
// this.$confirm('取消派工?', '提示', {
// confirmButtonText: '确定',
// cancelButtonText: '取消',
// type: 'warning'
// }).then(() =>{
savePwjhPgBack({
'field': 'qgpgrq',
'fieldry': 'qgpgry',
'zxZtName':'QGPG',
'list':obj
}).then(res=>{
if(res.success){
this.$message({ message: '派工成功', type: 'success' })
this.initList()
}
})
10 months ago
// })
// }else {
// this.$confirm('派工?', '提示', {
// confirmButtonText: '确定',
// cancelButtonText: '取消',
// type: 'warning'
// }).then(() =>{
// savePwjhPg(obj).then(res=>{
// if(res.success){
// this.initList()
// }
// })
//
// })
// }
10 months ago
},
xdClick(){
if(this.queryParam.zt!=="02"){
return
}
let obj=this.$refs.xGrid.getCheckboxRecords()
if(obj.length===0){
return
}
if(this.queryParam.zt==='03'){
this.$confirm('取消接收?', '提示', {
1 year ago
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() =>{
savePwPgdXdBack(obj).then(res=>{
1 year ago
if(res.success){
this.$message({ message: '取消下达成功', type: 'success' })
this.initList()
}
})
})
}else {
10 months ago
this.$confirm('接收?', '提示', {
1 year ago
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() =>{
savePwPgdXd(obj).then(res=>{
1 year ago
if(res.success){
this.$message({ message: '下达成功', type: 'success' })
1 year ago
this.initList()
}
})
})
}
},
initList() {
// if (this.queryParam.dcch === '') {
// this.$message.warning('选择船只编号')
// return
// }
// this.
8 months ago
if(this.queryParam.zt==='42'){
}else{
// this.queryParam.field='pwry';
this.queryParam.user=this.name;
1 year ago
}
getPwPgd(this.queryParam).then((res) => {
1 year ago
this.list = res.data
if (this.$refs.xGrid) {
this.$refs.xGrid.loadData(this.list)
console.log(this.list)
}
})
},
selectChange(row) {
// this.$refs.xGrid.clearActived() // 清除单元格激活状态
this.$refs.xGrid.clearEdit() // 清除单元格激活状态
// this.$refs.xGrid.setEditCell(row.row, row.column.property) // 设置单元格为激活状态
null2str(row.row)
},
getHeight() {
this.height = window.innerHeight - 190
},
}
}
</script>
<style lang="scss" scoped >
.el-header{margin:0;padding: 5px;height:auto;
.el-input{
width: 140px;
}
.el-select{
width: 140px;
}
}
.el-container{padding: 0;margin:0;}
.el-main{padding: 0;}
.el-col{padding: 0;height: 32px;}
.el-aside{background: #fff;padding: 0}
.el-container{padding: 0}
.el-row {}
.el-row:last-child {margin-bottom: 0; }
.tableStyles{
background: #0a76a4;
}
.my-dropdown {
width: 400px;
height: 400px;
background-color: #fff;
border: 1px solid #dcdfe6;
box-shadow: 0 0 6px 2px rgba(0, 0, 0, 0.1);
font-size: 12px;
}
.mytable1{
}
.borderClass{
}
.vxe-input {
display: inline-block !important;
position: relative !important;
width: auto;
}
.el-input {
display: inline-block !important;
position: relative !important;
width: auto;
}
.keyword-lighten {
color: #000;
background-color: #FFFF00;
}
.vxe-textarea--inner {
line-height: inherit;
}
.el-form-item__label-wrap {
margin-left: 0px !important;
float: left;
}
.fontClass{
font-size: 12px;
font-weight: bold;
}
</style>