|
|
<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="80px" label-position="left">
|
|
|
<el-row>
|
|
|
|
|
|
<el-col :span="22">
|
|
|
|
|
|
<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: 150px;"
|
|
|
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-select v-model="queryParam.mbch" filterable placeholder="目标船号" @change="czbhChange" >-->
|
|
|
<!-- <el-option-->
|
|
|
<!-- v-for="item in dictData.cbbm"-->
|
|
|
<!-- :key="item.cbbm"-->
|
|
|
<!-- :label="item.cbbm"-->
|
|
|
<!-- :value="item.cbbm">-->
|
|
|
<!-- </el-option>-->
|
|
|
<!-- </el-select>-->
|
|
|
<!-- </el-form-item>-->
|
|
|
<el-form-item label="批量:">
|
|
|
<el-input v-model="queryParam.dcpl" type="search" placeholder="批量" ></el-input>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="类型:">
|
|
|
<el-select v-model="queryParam.type" placeholder="类型" @change="" >
|
|
|
<el-option
|
|
|
v-for="item in optionsstats"
|
|
|
:key="item.value1"
|
|
|
:label="item.label1"
|
|
|
:value="item.value1">
|
|
|
</el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
<el-col :span="2">
|
|
|
<el-form-item style="float: right" >
|
|
|
<el-button type="success" @click="initList">查询</el-button>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
|
|
|
|
|
|
</el-row>
|
|
|
<el-row>
|
|
|
|
|
|
</el-row>
|
|
|
</el-form>
|
|
|
<el-form :inline="true" label-width="65px" label-position="left">
|
|
|
<el-row>
|
|
|
|
|
|
<el-col :span="22">
|
|
|
|
|
|
|
|
|
</el-col>
|
|
|
<el-col :span="2">
|
|
|
<el-form-item style="float: right" >
|
|
|
|
|
|
<el-button type="success" @click="copy">取自</el-button>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
|
|
|
|
|
|
</el-row>
|
|
|
<el-row>
|
|
|
|
|
|
</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
|
|
|
:align="'center'"
|
|
|
:height="height"
|
|
|
:checkbox-config="{checkField: 'checked'}"
|
|
|
:scroll-y="{enabled: true}"
|
|
|
:columns="tableColumn"
|
|
|
highlight-current-row
|
|
|
:data="tableData"
|
|
|
:custom-config="{ storage: true }"
|
|
|
highlight-hover-row
|
|
|
show-overflow
|
|
|
show-header-overflow
|
|
|
|
|
|
>
|
|
|
|
|
|
|
|
|
</vxe-grid>
|
|
|
</div>
|
|
|
|
|
|
</el-main>
|
|
|
</el-container>
|
|
|
</el-container>
|
|
|
<!-- 弹出层-->
|
|
|
<vxe-modal v-model="dialogVisible" width="1200" :title="title">
|
|
|
|
|
|
|
|
|
<template #default>
|
|
|
<el-row class="query_wrapper">
|
|
|
<el-row>
|
|
|
<el-button style="margin-right: 10px;" size="small" type="success" @click="submitUpload">上传到服务器</el-button>
|
|
|
</el-row>
|
|
|
</el-row>
|
|
|
<div class="mytable">
|
|
|
<vxe-table
|
|
|
border
|
|
|
show-header-overflow
|
|
|
show-overflow
|
|
|
:align="allAlign"
|
|
|
:data="tableupload">
|
|
|
<vxe-column type="seq" width="50"></vxe-column>
|
|
|
<vxe-column field="czbh" title="船号" width="100"></vxe-column>
|
|
|
<vxe-column field="ph" title="批号" width="100"></vxe-column>
|
|
|
<vxe-column field="type" title="类型"width="150"></vxe-column>
|
|
|
<vxe-column field="stype" title="小类" width="100"></vxe-column>
|
|
|
<vxe-column field="name" title="名称" width="400"></vxe-column>
|
|
|
</vxe-table>
|
|
|
</div>
|
|
|
</template>
|
|
|
</vxe-modal>
|
|
|
<SelectBom ref="selectBom" @callback="callback" />
|
|
|
</el-container>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
import {
|
|
|
getCzplBase,
|
|
|
getListBomRealy,
|
|
|
saveListBom,
|
|
|
addListBom, uploadBom,copyListBom
|
|
|
} from '@/api/sjzx/jcsj'
|
|
|
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'
|
|
|
import SelectBom from '@/views/sjzx/components/SelectBom'
|
|
|
export default {
|
|
|
name:'Bomcx',
|
|
|
components: {SelectBom},
|
|
|
data() {
|
|
|
return {
|
|
|
optionsstats:[
|
|
|
{
|
|
|
value1:'B',
|
|
|
label1: '板材'
|
|
|
},
|
|
|
{
|
|
|
value1:'X',
|
|
|
label1: '型材'
|
|
|
}
|
|
|
],
|
|
|
|
|
|
queryParam: {
|
|
|
dcch:'',
|
|
|
dcpl:'',
|
|
|
zt:'',
|
|
|
mbch:'',
|
|
|
},
|
|
|
tableData: [],
|
|
|
isupload:'02',
|
|
|
filedis:true,
|
|
|
uploadData:{
|
|
|
|
|
|
},
|
|
|
projectData:[],
|
|
|
projectData1:[],
|
|
|
projectColumns: [
|
|
|
{field: 'cbbm', title: '船号',width: 110},
|
|
|
{ field: 'wgbs', title: '完工标识', width: 80,
|
|
|
slots:{
|
|
|
default: 'wgbsEdit'
|
|
|
},
|
|
|
},
|
|
|
],
|
|
|
tableupload:[],
|
|
|
dialogVisible:false,
|
|
|
heads: { token: getToken() },
|
|
|
fileList: [],
|
|
|
dictData:{},
|
|
|
height: '500px',
|
|
|
bclqList:[],
|
|
|
xclqList:[],
|
|
|
bctjList:[],
|
|
|
xctjList:[],
|
|
|
tltList:[],
|
|
|
ljList:[],
|
|
|
title:'',
|
|
|
czbhu:'',
|
|
|
phu:'',
|
|
|
tableColumn: [
|
|
|
{ type: 'checkbox', width: 50 },
|
|
|
{ type: 'seq', width: 60, title: '序号' },
|
|
|
// { field: 'zt', title: '状态', width: 120,
|
|
|
// filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
// filterRender: { name: 'FilterCombination', },
|
|
|
// },
|
|
|
// { field: 'pid', title: 'pid', width: 120,
|
|
|
// filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
// filterRender: { name: 'FilterCombination', },
|
|
|
// },
|
|
|
|
|
|
{ field: 'dcch', title: '船号', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'mbch', title: '目标船号', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'sjch', title: '本船号', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
// { field: 'lqbs', title: '板材领取标识', width: 120,
|
|
|
// filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
// filterRender: { name: 'FilterCombination', },
|
|
|
// },
|
|
|
// { field: 'tjbs', title: '板材统计标识', width: 120,
|
|
|
// filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
// filterRender: { name: 'FilterCombination', },
|
|
|
// },
|
|
|
{ field: 'pl', title: '批量', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'fds', title: '分段', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
{ field: 'lqlb', title: '领取类别', width: 120,formatter: ['dictFormat','CLlQ'],
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'kw', title: '跨位', width: 120,formatter: ['dictFormat','QGKW'],
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
{ field: 'sbbh', title: '设备编号', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'sclx', title: '设备类型', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'zl', title: '组立', width: 120, formatter: ['dictFormat','ZLLB'],
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'wpcz', title: '物品材质', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'wpgg', title: '物品规格', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'bh', title: '板厚', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'bc', title: '板长', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'yqyl', title: '油漆油漆用量', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'qgcd', title: '切割长度', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'hxcd', title: '划线长度', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'tzbh', title: '图纸编号', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'tlsl', title: '套料数量', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'bclqzl', title: '板材领取重量', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'bcshzl', title: '板材实耗重量', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'bcylzl', title: '板材余料重量', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'bcljtlzl', title: '板材零件套料重量', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'bcqpyld', title: '前批余料代', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'ylbhgg', title: '余料信息', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'xqdd', title: '需求地点', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'pw', title: '抛丸', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'qbs', title: '曲标识', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'pklx', title: '坡口类型', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'pkbs', title: '坡口标识', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'pkcd', title: '坡口长度', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'dmbs', title: '打磨标识', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'dmcd', title: '打磨长度', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'zpsx', title: '装配顺序', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'fd', title: '分段号', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
{ field: 'ljbh', title: '零件编号', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'ljsl', title: '零件数量', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'ljsx', title: '零件属性', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'djmj', title: '单件面积', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'ljdz', title: '零件单重', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'blgs', title: '备料定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'pwgs', title: '抛丸定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'llgs', title: '理料定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'hxgs', title: '划线定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'qggs', title: '切割定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'pkgs', title: '坡口定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'qgs', title: '曲定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'dmgs', title: '打磨定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'zpgs', title: '装配定额工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkblgs', title: '备料实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkpwgs', title: '抛丸实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkllgs', title: '理料实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkhxgs', title: '划线实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkqggs', title: '切割实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkpkgs', title: '坡口实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkqgs', title: '曲实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkdmgs', title: '打磨实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
{ field: 'fkzpgs', title: '装配实动工时', width: 120,
|
|
|
filters: [{ data: { checks: [], sVal: '', sMenu: '', fType1: '', fVal1: '', fMode: 'and', fType2: '', fVal2: '' } }],
|
|
|
filterRender: { name: 'FilterCombination', },
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
]
|
|
|
|
|
|
}
|
|
|
},
|
|
|
computed: {
|
|
|
...mapGetters(['name', 'bmbm'])
|
|
|
},
|
|
|
created() {
|
|
|
window.addEventListener('resize', this.getHeight)
|
|
|
this.getHeight()
|
|
|
this.initBase()
|
|
|
|
|
|
|
|
|
},
|
|
|
methods: {
|
|
|
|
|
|
cellClickEvent({row}) {
|
|
|
this.queryParam.dcch = row.cbbm
|
|
|
this.$refs.xDown4.hidePanel()
|
|
|
},
|
|
|
focusEvent4() {
|
|
|
this.$refs.xDown4.showPanel()
|
|
|
},
|
|
|
keyupEvent4() {
|
|
|
console.log(1);
|
|
|
|
|
|
if (this.queryParam.dcch) {
|
|
|
console.log(this.projectData1);
|
|
|
this.projectData = this.projectData1.filter(row => row.cbbm.indexOf(this.queryParam.dcch.toUpperCase()) > -1)
|
|
|
} else {
|
|
|
this.projectData = this.projectData1.slice(0)
|
|
|
}
|
|
|
|
|
|
},
|
|
|
callback(obj, inputFive) {
|
|
|
|
|
|
// this.loadData()
|
|
|
|
|
|
},
|
|
|
|
|
|
uploadExcel() {
|
|
|
if (this.queryParam.cbbm === '') {
|
|
|
this.$message.error('请选择船号!')
|
|
|
return false;
|
|
|
} else {
|
|
|
|
|
|
}
|
|
|
|
|
|
// this.uploadData.czbh = this.queryParam.czbh
|
|
|
this.uploadData.isupload = this.isupload
|
|
|
},
|
|
|
|
|
|
czbhChange(){
|
|
|
// if (this.queryParam.dcch === '') {
|
|
|
// this.$message.error('请选择船号!')
|
|
|
// return false;
|
|
|
// }
|
|
|
// if (this.queryParam.dcpl === '') {
|
|
|
// this.$message.error('请输入正确批量!')
|
|
|
// return false;
|
|
|
// }
|
|
|
if (this.queryParam.cbbm === '') {
|
|
|
this.filedis=true
|
|
|
}else{
|
|
|
this.filedis=false
|
|
|
}
|
|
|
},
|
|
|
handleAddFolder () {
|
|
|
|
|
|
// this.fileList=[]
|
|
|
// this.bclqList=[],
|
|
|
// this.xclqList=[],
|
|
|
// this.bctjList=[],
|
|
|
// this.xctjList=[],
|
|
|
// this.tltList=[],
|
|
|
// this.ljList=[],
|
|
|
this.tableupload=[],
|
|
|
this.$nextTick(() => {
|
|
|
if (this.queryParam.dcch === ''|| this.queryParam.dcpl === '' ) {
|
|
|
this.filedis=true
|
|
|
this.$message.error('请输入正确船号 批量!')
|
|
|
}else{
|
|
|
this.filedis=false
|
|
|
this.$refs.upload.$children[0].$refs.input.webkitdirectory = true
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
},
|
|
|
uploadpre(name){
|
|
|
|
|
|
},
|
|
|
|
|
|
handleChange(file, fileList) {
|
|
|
this.fileList = fileList
|
|
|
console.log(file)
|
|
|
const bcph=""
|
|
|
if (file.name.includes("板材领取表")) {
|
|
|
this.czbhu= file.name.split("_")[0]
|
|
|
var underscoreIndex = file.name.indexOf("_");
|
|
|
var batchIndex = file.name.indexOf("批", underscoreIndex);
|
|
|
this.phu = file.name.substring(underscoreIndex + 1, batchIndex);
|
|
|
this.bclqList.push(file.name)
|
|
|
|
|
|
let a={czbh:this.czbhu,ph:this.phu,type:"板材",stype:"板材领取表",name:file.name,sort:1}
|
|
|
this.tableupload.push(a);
|
|
|
}
|
|
|
if (file.name.includes("型材领取表")) {
|
|
|
this.czbhu= file.name.split("_")[0]
|
|
|
var underscoreIndex = file.name.indexOf("_");
|
|
|
var batchIndex = file.name.indexOf("批", underscoreIndex);
|
|
|
this.phu = file.name.substring(underscoreIndex + 1, batchIndex);
|
|
|
this.xclqList.push(file.name)
|
|
|
let a={czbh:this.czbhu,ph:this.phu,type:"型材",stype:"型材领取表",name:file.name,sort:2}
|
|
|
this.tableupload.push(a);
|
|
|
}
|
|
|
if (file.name.includes("板材统计数据")) {
|
|
|
this.czbhu= file.name.split("_")[0]
|
|
|
var underscoreIndex = file.name.indexOf("_");
|
|
|
var batchIndex = file.name.indexOf("批", underscoreIndex);
|
|
|
this.phu = file.name.substring(underscoreIndex + 1, batchIndex);
|
|
|
this.bctjList.push(file.name)
|
|
|
let a={czbh:this.czbhu,ph:this.phu,type:"板材",stype:"板材统计数据",name:file.name,sort:3}
|
|
|
this.tableupload.push(a);
|
|
|
}
|
|
|
if (file.name.includes("型材统计数据")) {
|
|
|
this.czbhu= file.name.split("_")[0]
|
|
|
var underscoreIndex = file.name.indexOf("_");
|
|
|
var batchIndex = file.name.indexOf("批", underscoreIndex);
|
|
|
this.phu = file.name.substring(underscoreIndex + 1, batchIndex);
|
|
|
this.xctjList.push(file.name)
|
|
|
let a={czbh:this.czbhu,ph:this.phu,type:"型材",stype:"型材统计数据",name:file.name,sort:4}
|
|
|
this.tableupload.push(a);
|
|
|
}
|
|
|
if (file.name.includes("套料图")) {
|
|
|
this.czbhu= file.name.split("_")[0]
|
|
|
var underscoreIndex = file.name.indexOf("_");
|
|
|
var batchIndex = file.name.indexOf("套", underscoreIndex);
|
|
|
this.phu = file.name.substring(underscoreIndex + 1, batchIndex);
|
|
|
this.tltList.push(file.name)
|
|
|
let a={czbh:this.czbhu,ph:this.phu,type:"",stype:"套料图",name:file.name,sort:5}
|
|
|
this.tableupload.push(a);
|
|
|
}
|
|
|
if((file.name.match(/-/g)).length ===3){
|
|
|
this.ljList.push(file.name);
|
|
|
var parts = file.name.split('-')
|
|
|
var result = parts.slice(0, 3).join('-')
|
|
|
var parts1 = result.split('-')
|
|
|
|
|
|
this.czbhu = parts1.slice(0,2).join('-')
|
|
|
this.phu = parts1.slice(2,3)
|
|
|
let a={czbh:this.czbhu,ph:this.phu,type:"",stype:"零件",name:file.name,sort:6}
|
|
|
this.tableupload.push(a);
|
|
|
}
|
|
|
//this.title=this.czbhu+" "+this.phu+"批"
|
|
|
this.tableupload.sort((a,b)=>{
|
|
|
//return( a[age] - b[age])
|
|
|
return( a.sort - b.sort)
|
|
|
})
|
|
|
this.dialogVisible=true;
|
|
|
},
|
|
|
// 删除文件之前的钩子,参数为上传的文件和文件列表,若返回 false 或者返回 Promise 且被 reject,则停止删除。function(file, fileList)
|
|
|
handleRemove(file, fileList) {
|
|
|
this.fileList = fileList
|
|
|
|
|
|
},
|
|
|
|
|
|
//上传服务器
|
|
|
submitUpload() {
|
|
|
//判断是否有文件再上传
|
|
|
if (this.fileList.length === 0) {
|
|
|
return this.$message.warning('请选取文件后再上传')
|
|
|
}
|
|
|
// 下面的代码将创建一个空的FormData对象:
|
|
|
const formData = new FormData()
|
|
|
// 你可以使用FormData.append来添加键/值对到表单里面;
|
|
|
this.fileList.forEach((file) => {
|
|
|
formData.append('file', file.raw)
|
|
|
})
|
|
|
// 添加自定义参数,不传可删除
|
|
|
formData.append('czbh', this.queryParam.dcch)
|
|
|
formData.append('pl', this.queryParam.dcpl)
|
|
|
formData.append('isupload', '01')
|
|
|
uploadBom(formData).then(res=>{
|
|
|
if (res.data.zt == "01") {
|
|
|
this.$message.success('上传成功');
|
|
|
} else if (res.data.zt == "02") { //重新导入
|
|
|
this.$alert('该批量已导入数据,是否重新导入并覆盖该批量数据?', '提示', {
|
|
|
confirmButtonText: '确定',
|
|
|
cancelButtonText: '取消',
|
|
|
distinguishCancelAndClose: true,
|
|
|
type: 'warning'
|
|
|
}).then(type => {
|
|
|
formData
|
|
|
formData.set('isupload', '02')
|
|
|
uploadBom(formData).then(res => {
|
|
|
console.log(res.data)
|
|
|
if (res.data.zt == "01") {
|
|
|
this.$message({ message: '导入成功', type: 'success' })
|
|
|
this.dialogVisible=false;
|
|
|
this.tableData=res.data.data;
|
|
|
}
|
|
|
})
|
|
|
})
|
|
|
}
|
|
|
|
|
|
this.fileList = []
|
|
|
})
|
|
|
//自定义的接口也可以用ajax或者自己封装的接口
|
|
|
|
|
|
},
|
|
|
bomClick(){
|
|
|
if (this.queryParam.cbbm === '') {
|
|
|
this.$message.warning('选择船只编号')
|
|
|
return
|
|
|
}
|
|
|
|
|
|
addListBom(this.queryParam).then(res=>{
|
|
|
this.tableData=res.data;
|
|
|
})
|
|
|
},
|
|
|
|
|
|
|
|
|
initBase(){
|
|
|
getCzplBase({}).then(res=>{
|
|
|
this.dictData = res.data
|
|
|
this.projectData=res.data.cbbm
|
|
|
this.projectData1=res.data.cbbm
|
|
|
// const xGrid = this.$refs.xGrid
|
|
|
//
|
|
|
// const dwbm = xGrid.getColumnByField('dwbm')
|
|
|
// dwbm.editRender.options = res.data.xqdws
|
|
|
|
|
|
})
|
|
|
},
|
|
|
initList() {
|
|
|
if (this.queryParam.dcch === '') {
|
|
|
this.$message.warning('选择船只编号')
|
|
|
return
|
|
|
}
|
|
|
|
|
|
getListBomRealy(this.queryParam).then((res) => {
|
|
|
this.list = res.data
|
|
|
if (this.$refs.xGrid) {
|
|
|
this.$refs.xGrid.loadData(this.list)
|
|
|
}
|
|
|
|
|
|
})
|
|
|
},
|
|
|
formatDate ({ cellValue }) {
|
|
|
return XEUtils.toDateString(cellValue, 'yyyy/MM/dd')
|
|
|
},
|
|
|
|
|
|
checkBoxClick(row,column){
|
|
|
// console.log(row)
|
|
|
|
|
|
this.$refs.xGrid.setActiveCell(row,column)
|
|
|
},
|
|
|
|
|
|
selectChange(row) {
|
|
|
// this.$refs.xGrid.clearActived() // 清除单元格激活状态
|
|
|
this.$refs.xGrid.clearEdit() // 清除单元格激活状态d
|
|
|
// this.$refs.xGrid.setEditCell(row.row, row.column.property) // 设置单元格为激活状态
|
|
|
null2str(row.row)
|
|
|
},
|
|
|
getHeight() {
|
|
|
this.height = window.innerHeight - 190
|
|
|
},
|
|
|
copy(){
|
|
|
|
|
|
|
|
|
this.$refs.selectBom.show()
|
|
|
// if(this.queryParam.dcch===this.queryParam.mbch){
|
|
|
// this.$message.warning('船号和目标船号不能一致')
|
|
|
// return
|
|
|
// }
|
|
|
// if(this.queryParam.dcch==='' || this.queryParam.dcch===null ){
|
|
|
// this.$message.warning('船号不能为空')
|
|
|
// return
|
|
|
// }
|
|
|
// if(this.queryParam.mbch==='' || this.queryParam.mbch===null ){
|
|
|
// this.$message.warning('目标船号不能为空')
|
|
|
// return
|
|
|
// }
|
|
|
// copyListBom(this.queryParam).then(res=>{
|
|
|
// if(res.success){
|
|
|
// this.queryParam.dcch=this.queryParam.mbch;
|
|
|
// this.queryParam.mbch=''
|
|
|
// this.initList();
|
|
|
// }
|
|
|
// })
|
|
|
},
|
|
|
tjClick(){
|
|
|
let selectRecords = this.$refs.xGrid.getCheckboxRecords()
|
|
|
|
|
|
if(selectRecords.length<=0){
|
|
|
return
|
|
|
}
|
|
|
saveListBom(selectRecords).then(res=>{
|
|
|
if(res.success){
|
|
|
this.initList()
|
|
|
}
|
|
|
})
|
|
|
|
|
|
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
</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;
|
|
|
}
|
|
|
.my-table-list {
|
|
|
border: 1px solid #e8eaec;
|
|
|
float: left;
|
|
|
}
|
|
|
.my-table-list table {
|
|
|
width: 100%;
|
|
|
text-align: center;
|
|
|
}
|
|
|
.my-table-list .my-tr {
|
|
|
height: 32px;
|
|
|
text-align: left;
|
|
|
}
|
|
|
.my-table-list .my-tr:hover {
|
|
|
background-color: #f5f7fa;
|
|
|
}
|
|
|
.my-table-list td {
|
|
|
//border-right: 1px solid #e8eaec;
|
|
|
}
|
|
|
|
|
|
</style>
|