|
|
<template> <div> <el-form label-position="top" style="margin-top: -0px"> <el-row :gutter="20"> <el-col :span="20"> <el-button v-if="notifyNo===''" @click="addNotify()" type="primary" class="yzzButtonAn">新建申请单</el-button> <el-button v-if="notifyNo!=''" type="primary" @click="chooseSOSModal()" class="yzzButtonAn">选择工单</el-button> <el-button v-if="notifyNo!=''" type="primary" @click="xiadaNotifyModel()" class="yzzButtonAn">下达申请单</el-button> <el-button v-if="notifyNo!=''" type="primary" @click="deleteNotify()" class="yzzButtonAn">删除申请单</el-button> <!-- <el-button v-if="notifyNo!=''" type="primary" @click="noBomModel()" class="yzzButtonAn">非BOM物料</el-button> <el-button v-if="notifyNo!=''" type="primary" @click="noControlModel()" class="yzzButtonAn">不管控物料</el-button> --> <!-- <el-button @click="importModel()" type="primary" style="margin-left: 2px;margin-top: 0px">{{'导入'}}</el-button> --> </el-col> </el-row> <el-row :gutter="10" v-if="notifyNo!=''"> <el-col :span="3"> <el-form-item :label="'工厂编码'"> <el-input v-model="notifyData.site" disabled></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item :label="'申请单号'"> <el-input v-model="notifyData.notifyNo" disabled style="width: 100%;"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item :label="'申请账号'"> <el-input v-model="notifyData.username" disabled></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item :label="'申请日期'"> <el-input v-model="notifyData.notifyDate" disabled></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item :label="'状态'"> <el-select v-model="notifyData.status" style="width: 100%" disabled> <el-option label="全部" value=""></el-option> <el-option v-for="item in notifyStatusList" :key="item.listValue" :label="item.listDesc" :value="item.listValue"></el-option> </el-select> </el-form-item> </el-col> </el-row> <!-- <el-row :gutter="10" v-if="notifyNo!=''"> <el-col :span="12"> <el-form-item :label="'备注'"> <el-input v-model="notifyData.remark" style="width: 100%;"></el-input> </el-form-item> </el-col> </el-row> -->
</el-form>
<el-tabs style="font-size: 12px;min-height: 200px" class="customer-tab" v-model="activeName" type="border-card" v-if="notifyNo!=''"> <el-tab-pane label="已申请工单" name="sos"> <el-table :height="height" :data="dataList" border style="width: 100%;"> <el-table-column v-for="(item,index) in columnList" :key="index" :sortable="item.columnSortable" :prop="item.columnProp" :header-align="item.headerAlign" :show-overflow-tooltip="item.showOverflowTooltip" :align="item.align" :fixed="item.fixed==''?false:item.fixed" :min-width="item.columnWidth" :label="item.columnLabel"> <template slot-scope="scope"> <span v-if="!item.columnHidden">{{ scope.row[item.columnProp] }}</span> <span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px" /></span> </template> </el-table-column> <el-table-column fixed="right" header-align="center" align="center" width="100" label="操作"> <template slot-scope="scope"> <a type="text" size="small" @click="enterSOSDetail(scope.row)">物料</a> <a type="text" size="small" @click="deleteNotifySOS(scope.row)">删除</a> </template> </el-table-column> </el-table> </el-tab-pane> <!-- <el-tab-pane label="非BOM物料" name="noBom"> <el-table :data="dataList2" :height="height" border style="width: 100%; "> <el-table-column v-for="(item,index) in columnList4" :key="index" :sortable="item.columnSortable" :prop="item.columnProp" :header-align="item.headerAlign" :show-overflow-tooltip="item.showOverflowTooltip" :align="item.align" :fixed="item.fixed==''?false:item.fixed" :min-width="item.columnWidth" :label="item.columnLabel"> <template slot-scope="scope"> <span v-if="!item.columnHidden"> {{ scope.row[item.columnProp] }}</span> <span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px" /></span> </template> </el-table-column> <el-table-column header-align="center" align="center" width="80" label="操作"> <template slot-scope="scope"> <a type="text" size="small" @click="deleteNotifyMaterial(scope.row)">删除</a>
</template> </el-table-column> </el-table> </el-tab-pane> <el-tab-pane label="不管控物料" name="noControl"> <el-table :data="dataList3" :height="height" border style="width: 100%; "> <el-table-column v-for="(item,index) in columnList4" :key="index" :sortable="item.columnSortable" :prop="item.columnProp" :header-align="item.headerAlign" :show-overflow-tooltip="item.showOverflowTooltip" :align="item.align" :fixed="item.fixed==''?false:item.fixed" :min-width="item.columnWidth" :label="item.columnLabel"> <template slot-scope="scope"> <span v-if="!item.columnHidden"> {{ scope.row[item.columnProp] }}</span> <span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px" /></span> </template> </el-table-column> <el-table-column header-align="center" align="center" width="80" label="操作"> <template slot-scope="scope"> <a type="text" size="small" @click="deleteNotifyMaterial(scope.row)">删除</a>
</template> </el-table-column> </el-table> </el-tab-pane> --> </el-tabs> <el-dialog title="选择工单" :close-on-click-modal="false" v-drag :visible.sync="seqNoModalFlag" width="1000px"> <el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: -5px;"> <el-row :gutter="20"> <el-col :span="4"> <el-form-item :label="'生产订单号'"> <el-input v-model="seqNoData.orderNo"></el-input> </el-form-item> </el-col> <!-- <el-col :span="4"> <el-form-item> <span slot="label" style="" @click="getBaseList(216)"><a herf="#">加工中心</a></span> <el-input v-model="seqNoData.sWorkcenterno"></el-input> </el-form-item> </el-col> --> <el-col :span="4"> <el-form-item :label="'日期'"> <el-date-picker style="width: 100%" v-model="seqNoData.startDate" type="date" value-format="yyyy-MM-dd" placeholder="选择日期"> </el-date-picker> </el-form-item> </el-col> <el-col :span="4"> <el-form-item :label="'到'"> <el-date-picker style="width: 100%" v-model="seqNoData.endDate" type="date" value-format="yyyy-MM-dd" placeholder="选择日期"> </el-date-picker> </el-form-item> </el-col> </el-row> <el-row :gutter="20"> <el-col :span="6"> <el-form-item> <el-button type="primary" @click="searchSOSRouting()" style="margin-top: 5px" class="">查询</el-button>
</el-form-item> </el-col> </el-row> </el-form> <el-table :height="400" :data="seqNoList" border style="width: 100%;" class="choose-sos-table"> <el-table-column v-for="(item,index) in columnList2" :key="index" :sortable="item.columnSortable" :prop="item.columnProp" :header-align="item.headerAlign" :show-overflow-tooltip="item.showOverflowTooltip" :align="item.align" :fixed="item.fixed==''?false:item.fixed" :min-width="item.columnWidth" :label="item.columnLabel"> <template slot-scope="scope"> <span v-if="!item.columnHidden">{{ scope.row[item.columnProp] }}</span> <span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px" /></span> </template> </el-table-column> <el-table-column fixed="left" header-align="center" align="center" width="80" label="操作"> <template slot-scope="scope"> <el-button type="primary" size="mini" plain class="choose-sos-btn" :loading="chooseLoading" @click="chooseSOS(scope.row)">选择</el-button> </template> </el-table-column> </el-table> <el-footer style="height:40px;margin-top: 10px;text-align:center"> <el-button type="primary" @click="seqNoModalFlag = false">关闭</el-button> </el-footer> </el-dialog> <el-dialog title="保存工单" :close-on-click-modal="false" v-drag :visible.sync="saveSeqNoModalFlag" width="750px"> <el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: -5px;"> <el-row :gutter="20"> <el-col :span="6"> <el-form-item :label="'生产订单号'"> <el-input v-model="notifyOrderData.orderNo" disabled></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item :label="'工单数量'"> <el-input v-model="notifyOrderData.qtyRequired" disabled></el-input> </el-form-item> </el-col> </el-row> <el-row :gutter="20"> <el-col :span="6"> <el-form-item :label="'物料'"> <el-input v-model="notifyOrderData.partNo" disabled></el-input> </el-form-item> </el-col> <el-col :span="12"> <el-form-item :label="'物料名称'"> <el-input v-model="notifyOrderData.partDesc" disabled style="width: 204%" ></el-input> </el-form-item> </el-col> </el-row> <el-row :gutter="20"> <el-col :span="6"> <el-form-item :label="'退料时间'"> <el-date-picker style="width: 100%" v-model="notifyOrderData.needDate" type="datetime" value-format="yyyy-MM-dd HH:mm" placeholder="选择日期"> </el-date-picker> </el-form-item> </el-col> <el-col :span="6"> <el-form-item :label="'此次退料数量'"> <el-input v-model="notifyOrderData.unissureQty" @input=" value=>notifyOrderData.unissureQty = value.match(/0$|^[1-9]\d*/) ? value.match(/0$|^[1-9]\d*/)[0] : ''"></el-input> </el-form-item> </el-col> <!-- <el-col :span="6"> <el-form-item :label="' '"> <el-button type="primary" @click="qtyAllForSeqNo()">全数退料</el-button> </el-form-item> </el-col> --> </el-row> </el-form> <el-footer style="height:40px;margin-top: 10px;text-align:center"> <el-button type="primary" @click="saveSOS()">保存</el-button> <el-button type="primary" @click="saveSeqNoModalFlag=false">关闭</el-button> </el-footer> </el-dialog> <el-dialog title="变更BU" :close-on-click-modal="false" v-drag :visible.sync="changeBuFlag" width="350px"> <el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: -5px;"> <el-row :gutter="20"> <el-col :span="12"> <el-form-item :label="'工厂编码'"> <el-input v-model="notifyData.site" disabled></el-input> </el-form-item> </el-col> <el-col :span="12"> <el-form-item :label="'申请单号'"> <el-input v-model="notifyData.notifyNo" disabled></el-input> </el-form-item> </el-col> <el-col :span="12"> <el-form-item :label="'BU'"> <el-select v-model="newBu" placeholder="请选择" style="width: 100%"> <el-option v-for="i in buList" :key="i.buNo" :label="i.buNo+' - '+i.buDesc" :value="i.buNo"> </el-option> </el-select> </el-form-item> </el-col> </el-row> </el-form> <el-footer style="height:40px;margin-top: 10px;text-align:center"> <el-button type="primary" @click="saveNewBu()">保存</el-button> <el-button type="primary" @click="changeBuFlag=false">关闭</el-button> </el-footer> </el-dialog> <el-dialog title="申请明细" :close-on-click-modal="false" v-drag :visible.sync="materialModalFlag" width="900px"> <el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: -5px;"> <el-row :gutter="20"> <el-col :span="6"> <el-form-item :label="'生产订单号'"> <el-input v-model="sobomData.orderNo" disabled></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item :label="'产品编码'"> <el-input v-model="sobomData.partNo" disabled></el-input> </el-form-item> </el-col> </el-row> </el-form> <div class="yzzTable"> <el-table :height="400" :data="sobomList" border v-loading="bomLoadFlag" style="width: 100%;"> <el-table-column v-for="(item,index) in columnList3" :key="index" :sortable="item.columnSortable" :prop="item.columnProp" :header-align="item.headerAlign" :show-overflow-tooltip="item.showOverflowTooltip" :align="item.align" :fixed="item.fixed==''?false:item.fixed" :min-width="item.columnWidth" :label="item.columnLabel"> <template slot-scope="scope"> <div v-if="item.columnProp === 'qtyToUnissue'"> <el-input v-model="scope.row.qtyToUnissue" style="height: 11px; width: 98%;" :step="0" :min="0"></el-input> </div> <div v-else-if="item.columnProp === 'remark'"> <el-input v-model="scope.row.remark" style="padding: 0;width: 100%"></el-input> </div> <div v-else> <span v-if="!item.columnHidden">{{ scope.row[item.columnProp] }}</span> <span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px" /></span>
</div> </template> </el-table-column> <!-- <el-table-column prop="" header-align="center" align="center" min-width="50" label="操作"> <template slot-scope="scope"> <el-button type="primary" @click="qtyAllForBom(scope.row)" style="width: 100%">全数领料</el-button> </template> </el-table-column> -->
</el-table> </div> <el-footer style="height:40px;margin-top: 10px;text-align:center"> <el-button type="primary" @click="saveMaterialDetail()">保存</el-button> <el-button type="primary" @click="materialModalFlag=false">关闭</el-button> </el-footer> </el-dialog>
<el-dialog width="600px" title="选择非BOM物料" :close-on-click-modal="false" :visible.sync="partModelFlag"> <el-form :inline="true" label-position="top" label-width="100px"> <el-row :gutter="20"> <el-col :span="6"> <el-form-item style="margin-left: 0px" label="物料编码"> <el-input v-model="partSearch.partNo"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item style="margin-left: 0px" label="物料名称"> <el-input v-model="partSearch.partDesc"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item style="margin-left: 0px" label="规格型号"> <el-input v-model="partSearch.spec"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item label=" "> <el-button type="primary" @click="searchPartModel()">{{'查询'}}</el-button> </el-form-item> </el-col> </el-row> </el-form> <el-table height="450" :data="partList" border @row-dblclick="chooseNoBomPartNo" style="width: 100%;"> <el-table-column prop="partNo" header-align="center" align="left" min-width="80" style="font-size: 20px" label="物料编码"> </el-table-column> <el-table-column prop="partDesc" header-align="center" align="left" min-width="120" style="font-size: 20px" label="物料描述"> </el-table-column> <el-table-column prop="spec" header-align="center" align="left" min-width="120" style="font-size: 20px" label="规格型号"> </el-table-column> <el-table-column prop="sku" header-align="center" align="left" min-width="80" label="SKU"> </el-table-column> <el-table-column prop="umid" header-align="center" align="left" min-width="60" label="计量单位"> </el-table-column> </el-table> </el-dialog> <el-dialog width="600px" title="选择不管控物料" :close-on-click-modal="false" :visible.sync="noControlPartModelFlag"> <el-form :inline="true" label-position="top" label-width="100px"> <el-row :gutter="20"> <el-col :span="6"> <el-form-item style="margin-left: 0px" label="物料编码"> <el-input v-model="partSearch.partNo"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item style="margin-left: 0px" label="物料名称"> <el-input v-model="partSearch.partDesc"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item style="margin-left: 0px" label="规格型号"> <el-input v-model="partSearch.spec"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item label=" "> <el-button type="primary" @click="searchNoControlPartModel()">{{'查询'}}</el-button> </el-form-item> </el-col> </el-row> </el-form> <el-table height="450" :data="partList2" border @row-dblclick="chooseNoControlPartNo" style="width: 100%;">
<el-table-column prop="partNo" header-align="center" align="left" min-width="80" style="font-size: 20px" label="物料编码"> </el-table-column> <el-table-column prop="partDesc" header-align="center" align="left" min-width="120" style="font-size: 20px" label="物料描述"> </el-table-column> <el-table-column prop="spec" header-align="center" align="left" min-width="120" style="font-size: 20px" label="规格型号"> </el-table-column> <el-table-column prop="sku" header-align="center" align="left" min-width="80" label="SKU"> </el-table-column> <el-table-column prop="umid" header-align="center" align="left" min-width="60" label="计量单位"> </el-table-column> </el-table> </el-dialog> <el-dialog width="500px" title="物料库存 VS 需求数量" :close-on-click-modal="false" :visible.sync="xiadaModelFlag"> <div class="board666"> <el-table height="300" :data="xiadaList" border :row-class-name="tableRowClassName" style="width: 100%;"> <el-table-column prop="componentPartNo" header-align="center" align="left" min-width="80" style="font-size: 20px" label="物料编码"> </el-table-column> <el-table-column prop="partDesc" header-align="center" align="left" min-width="120" style="font-size: 20px" label="物料描述"> </el-table-column> <el-table-column prop="qtyToIssue" header-align="center" align="right" min-width="80" style="font-size: 20px" label="发料数量"> </el-table-column> <el-table-column prop="qtyOnHand" header-align="center" align="right" min-width="80" label="库存数量"> </el-table-column> <el-table-column prop="qtyAvailable" header-align="center" align="right" min-width="80" label="可用数量"> </el-table-column> </el-table> </div> <el-footer style="height:40px;margin-top: 10px;text-align:center"> <el-button type="primary" @click="xiadaNotify()">确定下达</el-button> <el-button type="primary" @click="xiadaModelFlag=false">取消</el-button> </el-footer> </el-dialog>
<el-dialog title="保存物料" :close-on-click-modal="false" v-drag :visible.sync="saveOtherPartModalFlag" width="600px"> <el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: -5px;"> <el-row :gutter="20"> <el-col :span="6"> <el-form-item :label="'物料编码'"> <el-input v-model="otherPartData.componentPartNo" disabled></el-input> </el-form-item> </el-col> <el-col :span="18"> <el-form-item :label="'物料描述'"> <el-input v-model="otherPartData.partDesc" disabled></el-input> </el-form-item> </el-col>
</el-row> <el-row :gutter="20"> <el-col :span="6"> <el-form-item :label="'计量单位'"> <el-input v-model="otherPartData.umid" disabled></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item :label="'需求数量'"> <el-input-number v-model="otherPartData.qtyToIssue" style="padding: 0;width: 100%" :step="0" :min="0" :controls="false"></el-input-number>
</el-form-item> </el-col> </el-row> <el-row :gutter="20"> <el-col :span="24"> <el-form-item :label="'备注'"> <el-input v-model="otherPartData.remark"></el-input> </el-form-item> </el-col> </el-row> </el-form> <el-footer style="height:40px;margin-top: 10px;text-align:center"> <el-button type="primary" @click="saveOtherPart()">保存</el-button> <el-button type="primary" @click="saveOtherPartModalFlag=false">关闭</el-button> </el-footer> </el-dialog> <el-dialog title="选择申请类型" :close-on-click-modal="false" v-drag :visible.sync="showAddNotifyTypeDialog" width="400px"> <el-form :inline="true" label-position="top" label-width="500px" style="margin-left: 7px;margin-top: -5px;"> <el-row :gutter="20"> <el-col :span="24"> <el-form-item label="申请类型"> <el-radio-group v-model="selectedNotifyType"> <el-radio label="production">生产领料单</el-radio> <el-radio label="outsourced">委外领料单</el-radio> </el-radio-group> </el-form-item> </el-col> <el-col :span="24"> <el-form-item label="备注" class="issueNotify"> <el-input type="textarea" v-model="selectedNotifyRemark" :rows="3" placeholder="请输入内容" style="width: 100%"></el-input> </el-form-item> </el-col> </el-row> </el-form> <el-footer style="height:30px;text-align:center;"> <el-button type="primary" @click="confirmAddNotify()">确认</el-button> <el-button type="primary" @click="showAddNotifyTypeDialog=false">取消</el-button> </el-footer> </el-dialog> <Chooselist ref="baseList" @getBaseData="getBaseData"></Chooselist> </div></template>
<script>import { getSOScheduledRoutingListForUnissure, createNotify, getUserNotifyNo, deleteUnissueNotifyHeader, getAllNotifyStatus, getNotifyNoDetail, saveUnissueNotifyOrderList, getSOSBOMForIssure, saveUnissueMaterialDetail, deleteNotifyUnissue, getIFSShopOrderByOrderNo, searchUnissueNotifyMaterialList, updateNotifyStatus,} from '@/api/orderIssure/productionInboundRequest.js'import Chooselist from '@/views/modules/common/Chooselist_eam'
export default { name: 'newSoIssueNotify', components: { Chooselist, }, watch: { // notifyOrderData: {
// deep: true,
// handler: function (newV, oldV) {
// this.notifyOrderData.locationNo = this.notifyOrderData.locationNo.toUpperCase()
// }
// },
}, data() { return { activeName: 'sos', noControlPartModelFlag: false, buList: [], partList: [], partList2: [], notifyStatusList: [], notifyNo: '', notifyData: { site: '', bu: '', notifyNo: '', notifyDate: '', enteredDate: '', userName: '', userDisplay: '', remark: '', planIssueDate: '', }, dataList2: [], dataList3: [], // 是否收藏
favorite: false, changeBuFlag: false, partModelFlag: false, newBu: '', // 导出 start
exportData: [], exportName: '设备分组' + this.dayjs().format('YYYYMMDDHHmmss'), exportHeader: ['设备分组'], exportFooter: [], exportList: [], // 导出 end
searchData: { site: this.$store.state.user.site, userName: this.$store.state.user.name, groupID: '', groupDesc: '', buDesc: '', active: 'Y', page: 1, limit: 10, }, sobomData: { orderno: '', seqno: '', partNo: '', }, //申请单序号
itemNo: '', notifyOrderData: { partNo: '', orderNo: '', itemNo: '', seqNo: '', partDesc: '', qtyrequired: '', sResourceID: '', unissureQty: '', locationNo: '', needDate: '', }, seqNoData: { site: this.$store.state.user.site, seqno: '', sResourceID: '', sWorkcenterno: '', operatorId: '', sShiftno: '', startDate: '', endDate: '', }, seqNoList: [], height: 200, pageIndex: 1, pageSize: 20, totalPage: 0, dataList: [], sobomList: [], dataListSelections: [], seqNoModalFlag: false, materialModalFlag: false, modalDisableFlag: false, saveSeqNoModalFlag: false, bomLoadFlag: false, xiadaList: [], columnList4: [ { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table4ComponentPartNo', tableId: '701001Table4', tableName: '非BOM材料明细', columnProp: 'componentPartNo', headerAlign: 'center', align: 'center', columnLabel: '材料编码', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 100, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table4PartDesc', tableId: '701001Table4', tableName: '非BOM材料明细', columnProp: 'partDesc', headerAlign: 'center', align: 'left', columnLabel: '材料名称', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 130, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table4QtyToIssue', tableId: '701001Table4', tableName: '非BOM材料明细', columnProp: 'qtyToIssue', headerAlign: 'center', align: 'right', columnLabel: '申请数量', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table4Remark', tableId: '701001Table4', tableName: '非BOM材料明细', columnProp: 'remark', headerAlign: 'center', align: 'left', columnLabel: '备注', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 200, }, ], modalData: { flag: '', bu: '', site: this.$store.state.user.site, groupID: '', groupDesc: '', active: '', createBy: this.$store.state.user.name, updateBy: this.$store.state.user.name, }, // 展示列集
columnList: [ { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table1ItemNo', tableId: '701001Table1', tableName: '领料申请工单子表', columnProp: 'itemNo', headerAlign: 'center', align: 'right', columnLabel: '序号', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 50, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table1SOOrderNo', tableId: '701001Table1', tableName: '领料申请工单子表', columnProp: 'soorderNo', headerAlign: 'center', align: 'center', columnLabel: '生产订单号', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 120, }, /* { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table1OpsItemNo', tableId: '701001Table1', tableName: '领料申请工单子表', columnProp: 'opsItemNo', headerAlign: 'center', align: 'right', columnLabel: '工序', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table1ItemDesc', tableId: '701001Table1', tableName: '领料申请工单子表', columnProp: 'itemDesc', headerAlign: 'center', align: 'left', columnLabel: '工序名称', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 100, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table1LocationNo', tableId: '701001Table1', tableName: '领料申请工单子表', columnProp: 'locationNo', headerAlign: 'center', align: 'left', columnLabel: '机台编码', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, */ { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table1NeedDate', tableId: '701001Table1', tableName: '领料申请派工单子表', columnProp: 'needDate', headerAlign: 'center', align: 'left', columnLabel: '退料时间', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table1IssureQty', tableId: '701001Table1', tableName: '领料申请派工单子表', columnProp: 'unissureQty', headerAlign: 'center', align: 'right', columnLabel: '退料数量', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, ], columnList2: [ { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2Orderno', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'orderNo', headerAlign: 'center', align: 'center', columnLabel: '生产订单', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 120, }, /* { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2Itemno', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'itemNo', headerAlign: 'center', align: 'right', columnLabel: '工序', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 50, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2ItemDesc', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'itemDesc', headerAlign: 'center', align: 'left', columnLabel: '工序名称', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 100, }, */ { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2PartNo', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'partNo', headerAlign: 'center', align: 'left', columnLabel: '物料编码', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2PartNo', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'partDesc', headerAlign: 'center', align: 'left', columnLabel: '物料名称', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 120, showOverflowTooltip: true, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2Qtyrequired', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'lotSize', headerAlign: 'center', align: 'right', columnLabel: '工单数量', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2Qtyreported', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'qtyReported', headerAlign: 'center', align: 'right', columnLabel: '报工数量', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2SScheduleddate', tableId: '701001Table2', tableName: '查询工单', columnProp: 'startDate', headerAlign: 'center', align: 'left', columnLabel: '工单开始日期', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 100, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2SScheduleddate', tableId: '701001Table2', tableName: '查询工单', columnProp: 'finishDate', headerAlign: 'center', align: 'left', columnLabel: '工单结束日期', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 100, }, /* { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2SWorkcenterno', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'sWorkCenterNo', headerAlign: 'center', align: 'left', columnLabel: '加工中心编码', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2WorkCenterDesc', tableId: '701001Table2', tableName: '查询工单', columnProp: 'workCenterDesc', headerAlign: 'center', align: 'left', columnLabel: '加工中心名称', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 100, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2SResourceid', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'sResourceID', headerAlign: 'center', align: 'left', columnLabel: '机台编码', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 60, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2ResourceDesc', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'resourceDesc', headerAlign: 'center', align: 'left', columnLabel: '机台名称', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 100, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table2OperatorDesc', tableId: '701001Table2', tableName: '查询派工单', columnProp: 'operatorDesc', headerAlign: 'center', align: 'left', columnLabel: '操作员', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 100, },*/ ], columnList3: [ { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table3ComponentPartNo', tableId: '701001Table3', tableName: '领料申请BOM子表', columnProp: 'componentPartNo', headerAlign: 'center', align: 'left', columnLabel: '物料编码', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 80, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table3PartDesc', tableId: '701001Table3', tableName: '领料申请BOM子表', columnProp: 'componentPartDesc', headerAlign: 'center', align: 'left', columnLabel: '物料描述', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 120, }, /* { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table3QtyRequired', tableId: '701001Table3', tableName: '领料申请BOM子表', columnProp: 'qtyRequired', headerAlign: 'center', align: 'right', columnLabel: '需求数量', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 50, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table3QtyOnHand', tableId: '701001Table3', tableName: '领料申请BOM子表', columnProp: 'qtyOnHand', headerAlign: 'center', align: 'right', columnLabel: '现场库存', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 50, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table3StockQty', tableId: '701001Table3', tableName: '领料申请BOM子表', columnProp: 'stockQty', headerAlign: 'center', align: 'right', columnLabel: 'ERP库存', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 50, }, */ { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table3QtyToIssue', tableId: '701001Table3', tableName: '领料申请BOM子表', columnProp: 'qtyToUnissue', headerAlign: 'center', align: 'right', columnLabel: '本次退货数量', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 60, }, { userId: this.$store.state.user.name, functionId: 701001, serialNumber: '701001Table3Remark', tableId: '701001Table3', tableName: '领料申请BOM子表', columnProp: 'remark', headerAlign: 'center', align: 'left', columnLabel: '备注', columnHidden: false, columnImage: false, columnSortable: false, sortLv: 0, status: true, fixed: '', columnWidth: 150, }, ], rules: { groupIdType: [ { required: true, message: ' ', trigger: ['blur', 'change'], }, ], groupDescType: [ { required: true, message: ' ', trigger: ['blur', 'change'], }, ], activeType: [ { required: true, message: ' ', trigger: ['blur', 'change'], }, ], bu: [ { required: true, message: ' ', trigger: ['blur', 'change'], }, ], }, userBuList: [], authSearch: false, authSave: false, authUpdate: false, authDelete: false, menuId: this.$route.meta.menuId, partSearch: { site: '', sourceBu: '', partNo: '', partDesc: '', spec: '', }, xiadaModelFlag: false, saveOtherPartModalFlag: false, otherPartData: { site: '', notifyNo: '', itemNo: '', bOMItemNo: '', componentPartNo: '', qtyToIssue: '', issueType: '', partDesc: '', umid: '', remark: '', }, showAddNotifyTypeDialog: false, selectedNotifyType: 'production', selectedNotifyRemark:'', chooseLoading: false, } },
mounted() { /* this.$nextTick(() => { this.height = window.innerHeight - 300 }) */ },
created() { // 按钮控制
this.getButtonAuthData() // 获取用户的 site 和 bu
//this.getSiteAndBuByUserName()
// 校验用户是否收藏
/* this.favoriteIsOk()*/
this.getUserNotifyNo() // 动态列
/* this.getTableUserColumn(this.$route.meta.menuId+'table1',1) this.getTableUserColumn(this.$route.meta.menuId+'table2',2) this.getTableUserColumn(this.$route.meta.menuId+'table3',3) this.getTableUserColumn(this.$route.meta.menuId+'table4',4) */ // if (!this.authSearch) {
// // 获取数据列表
// this.getDataList()
// }
},
methods: { deleteNotifyMaterial(row) { this.$confirm('确认删除?', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }).then(() => { deleteNotifyMaterialWithOutLog(row).then(({ data }) => { if (data && data.code === 0) { this.searchOtherPart('非BOM物料') this.searchOtherPart('不管控物料') this.$message({ message: '操作成功', type: 'success', duration: 1500, onClose: () => {}, }) } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }) }, getBaseList(val, type) { this.tagNo = val let conSql = '' this.$nextTick(() => { let strVal = ''
if (val === 515) { strVal = this.seqNoData.sResourceid conSql = " and site = '" + this.notifyData.site + "'" + " and bu_no = '" + this.notifyData.bu + "'" this.$refs.baseList.init(val, strVal, conSql) } if (val === 216) { strVal = this.seqNoData.sWorkcenterno conSql = " and site = '" + this.notifyData.site + "'" + " and bu_no = '" + this.notifyData.bu + "'" this.$refs.baseList.init(val, strVal, conSql) } if (val === 215) { strVal = this.notifyOrderData.locationNo this.$refs.baseList.init(val, strVal) } }) }, chooseNoBomPartNo(row) { this.otherPartData = { site: this.notifyData.site, notifyNo: this.notifyData.notifyNo, itemNo: 998, bOMItemNo: '', componentPartNo: row.partNo, qtyToIssue: '', issueType: '非BOM物料', partDesc: row.partDesc, umid: row.umid, remark: '', } this.saveOtherPartModalFlag = true }, chooseNoControlPartNo(row) { this.otherPartData = { site: this.notifyData.site, notifyNo: this.notifyData.notifyNo, itemNo: 999, bOMItemNo: '', componentPartNo: row.partNo, qtyToIssue: '', issueType: '不管控物料', partDesc: row.partDesc, umid: row.umid, remark: '', } this.saveOtherPartModalFlag = true }, tableRowClassName({ row, rowIndex }) { if (row.qtyToIssue > row.qtyAvailable) { return 'error-row' }
return '' }, // 列表方法的回调
getBaseData(val) { if (this.tagNo === 515) { this.seqNoData.sResourceid = val.resource_id } if (this.tagNo === 215) { this.notifyOrderData.locationNo = val.location_id } if (this.tagNo === 216) { this.seqNoData.sWorkcenterno = val.work_center_no } }, getUserNotifyNo() { let inData = { site: this.$store.state.user.site, username: this.$store.state.user.name, } this.getAllNotifyStatus() getUserNotifyNo(inData).then(({ data }) => { if (data.code === 0) { if (data.row != null) { this.notifyNo = data.row.notifyNo this.notifyData = data.row this.getNotifyNoDetail() /* this.searchOtherPart('非BOM物料') this.searchOtherPart('不管控物料') */ } else { this.notifyNo = '' this.notifyData = { site: '', bu: '', notifyNo: '', notifyDate: '', enteredDate: '', userName: '', userDisplay: '', remark: '', planIssueDate: '', } this.dataList = [] } } else { this.notifyNo = '' this.notifyData = { site: '', bu: '', notifyNo: '', notifyDate: '', enteredDate: '', userName: '', userDisplay: '', remark: '', planIssueDate: '', } this.dataList = [] } }) }, getNotifyNoDetail() { let inData = { site: this.$store.state.user.site, notifyNo: this.notifyNo, } getNotifyNoDetail(inData).then(({ data }) => { if (data.code === 0) { this.dataList = data.rows } }) }, addNotify() { //this.showAddNotifyTypeDialog = true
let inData = { site: this.$store.state.user.site, userName: this.$store.state.user.name, } createNotify(inData).then(({ data }) => { if (data.code === 0) { this.showAddNotifyTypeDialog = false this.$message({ message: '操作成功', type: 'success', duration: 1500, onClose: () => {}, }) this.getUserNotifyNo() } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }, confirmAddNotify() { let outWorkOrderFlag = 'N' if (this.selectedNotifyType === 'outsourced') { outWorkOrderFlag = 'Y' } else { outWorkOrderFlag = 'N' } let inData = { site: this.$store.state.user.site, userName: this.$store.state.user.name, outWorkOrderFlag: outWorkOrderFlag, remark: this.selectedNotifyRemark, } this.getAllNotifyStatus() createNotify(inData).then(({ data }) => { if (data.code === 0) { this.showAddNotifyTypeDialog = false this.$message({ message: '操作成功', type: 'success', duration: 1500, onClose: () => {}, }) this.getUserNotifyNo() } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }, chooseSOS(row) { if (this.dataList.length > 0) { //这边是有个判断的,判断派工单号不能重复
let stop = false for (let i = 0; i < this.dataList.length; i++) { if (this.dataList[i].seqNo == row.seqno) { stop = true } } if (stop) { this.$alert('已经选择过此工单,请返回点击明细直接操作!!', '提示', { confirmButtonText: '确定', }) return false } } let inData = { site: this.$store.state.user.site, orderNo: row.orderNo, } this.chooseLoading = true getIFSShopOrderByOrderNo(inData).then(({ data }) => { if (data.code === 0) { console.log("data",data); this.notifyOrderData.partNo = data.shopOrderVo[0].partNo this.notifyOrderData.orderNo = data.shopOrderVo[0].orderNo this.notifyOrderData.itemNo = data.shopOrderVo[0].itemNo this.notifyOrderData.seqNo = data.shopOrderVo[0].seqNo this.notifyOrderData.partDesc = data.shopOrderVo[0].partDesc this.notifyOrderData.qtyRequired = data.shopOrderVo[0].lotSize this.notifyOrderData.sResourceID = row.sResourceID this.notifyOrderData.unissureQty = '' this.notifyOrderData.needDate = this.dayjs().format('YYYY-MM-DD HH:mm') this.notifyOrderData.locationNo = row.sResourceID this.saveSeqNoModalFlag = true }else { this.$meassage.error(data.msg) return; } }).finally(() => { this.chooseLoading = false }) }, saveSOS() { if ( this.notifyOrderData.needDate == null || this.notifyOrderData.needDate == '' ) { this.$message.warning('请选择时间!') return false } // if(this.notifyOrderData.locationNo==null||this.notifyOrderData.locationNo==''){
// this.$message.warning('请输入机台!')
// return false
// }
if ( this.notifyOrderData.unissureQty == null || this.notifyOrderData.unissureQty == '' || this.notifyOrderData.unissureQty <= 0 ) { this.$message.warning('请填写领取数量!') return false } let row = this.notifyOrderData console.log("row",row); if (this.dataList.length > 0) { let stop = false for (let i = 0; i < this.dataList.length; i++) { if (this.dataList[i].seqNo == row.seqno) { stop = true } } if (stop) { this.$alert('已经选择过此工单,请返回点击明细直接操作!!', '提示', { confirmButtonText: '确定', }) return false } } this.$confirm('确定选择工单' + row.orderNo + '?', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }).then(() => { let inData = { site: this.$store.state.user.site, notifyNo: this.notifyNo, fgPartNo: row.partNo, soorderNo: row.orderNo, opsItemNo: row.itemNo, seqNo: row.seqNo, locationNo: row.locationNo, needDate: row.needDate, unissureQty: row.unissureQty, } saveUnissueNotifyOrderList(inData).then(({ data }) => { if (data.code === 0) { this.saveSeqNoModalFlag = false row.itemNo = data.itemNo this.getNotifyNoDetail() this.enterSOS(row) } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }) }, qtyAllForSeqNo() { this.notifyOrderData.unissureQty = this.notifyOrderData.qtyRequired }, qtyAllForBom(row) { row.qtyToIssue = row.qtyRequired }, enterSOSDetail(row) { let rows = { site: this.$store.state.user.site, notifyNo: this.notifyNo, soorderNo: row.soorderNo, seqNo: row.seqNo, partNo: row.fgPartNo, itemNo: row.itemNo, }
this.searchUnissueNotifyMaterialList(rows) //this.enterSOS(rows)
}, searchUnissueNotifyMaterialList(row){ this.bomLoadFlag = true this.materialModalFlag = true searchUnissueNotifyMaterialList(row).then(({ data }) => { if (data.code === 0) { this.sobomList = data.rows } }).finally(() => { this.bomLoadFlag = false }) },
enterSOS(row) { console.log("row",row); this.seqNoModalFlag = false this.materialModalFlag = true this.sobomList = [] this.sobomData = { orderNo: row.orderNo, seqNo: row.seqNo, partNo: row.partNo, } this.bomLoadFlag = true let inData = { site: this.$store.state.user.site, notifyNo: this.notifyNo, orderNo: row.orderNo, seqNo: row.seqNo, partNo: row.partNo, itemNo: row.itemNo, } getSOSBOMForIssure(inData).then(({ data }) => { this.bomLoadFlag = false if (data.code === 0) { this.sobomList = data.rows for (let i = 0; i < this.sobomList.length; i++) { this.sobomList[i].itemNo = inData.itemNo } } }) }, ToSOS() { this.seqNoModalFlag = true this.materialModalFlag = false }, chooseSOSModal() { this.seqNoData = { site: this.$store.state.user.site, orderno: '', seqno: '', sResourceid: '', sWorkcenterno: '', operatorId: '', sShiftno: '', startDate: this.dayjs().format('YYYY-MM-DD'), endDate: this.dayjs().format('YYYY-MM-DD'), } //this.searchSOSRouting()查询工单列表
this.seqNoModalFlag = true }, searchSOSRouting() { getSOScheduledRoutingListForUnissure(this.seqNoData).then(({ data }) => { if (data.code === 0) { this.seqNoList = data.rows } }) }, saveMaterialDetail() { for (let i = 0; i < this.sobomList.length; i++) { if ( this.sobomList[i].applyQty === '' || this.sobomList[i].applyQty == null ) { this.sobomList[i].applyQty = 0 } this.sobomList[i].notifyNo = this.notifyNo this.sobomList[i].site = this.$store.state.user.site } let materialList = this.sobomList.filter((item) => item.qtyToUnissue > 0) if (materialList.length == 0) { this.$alert('没有需要保存的内容!', '提示', { confirmButtonText: '确定', }) return false } console.log("this.sobomList",materialList); saveUnissueMaterialDetail(materialList).then(({ data }) => { if (data.code === 0) { this.materialModalFlag = false this.chooseSOSModal() this.$message.success('操作成功') } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }, //获取用户的bu
getSiteAndBuByUserName() { let tempData = { username: this.$store.state.user.name, } getSiteAndBuByUserName(tempData).then(({ data }) => { if (data.code === 0 && data.row != null) { this.userBuList = data.rows } }) }, // 校验用户是否收藏
favoriteIsOk() { let userFavorite = { userId: this.$store.state.user.id, languageCode: this.$i18n.locale, } userFavoriteList(userFavorite).then(({ data }) => { for (let i = 0; i < data.list.length; i++) { if (this.$route.meta.menuId === data.list[i].menuId) { this.favorite = true } } }) },
// 收藏 OR 取消收藏
favoriteFunction() { let userFavorite = { userId: this.$store.state.user.id, functionId: this.$route.meta.menuId, } if (this.favorite) { removeUserFavorite(userFavorite).then(({ data }) => { this.$message.success(data.msg) this.favorite = false }) } else { // 收藏
saveUserFavorite(userFavorite).then(({ data }) => { this.$message.success(data.msg) this.favorite = true }) } },
//导出excel
async createExportData() { this.searchData.limit = -1 this.searchData.page = 1 await eamGroupSearch(this.searchData).then(({ data }) => { this.exportList = data.page.list }) return this.exportList },
startDownload() {},
finishDownload() {},
fields() { let json = '{' this.columnList.forEach((item, index) => { if (index == this.columnList.length - 1) { json += '"' + item.columnLabel + '"' + ':' + '"' + item.columnProp + '"' } else { json += '"' + item.columnLabel + '"' + ':' + '"' + item.columnProp + '"' + ',' } }) json += '}' let s = eval('(' + json + ')') return s }, noBomModel() { this.partSearch = { site: this.notifyData.site, sourceBu: this.notifyData.bu, partNo: '', partDesc: '', spec: '', } this.partModelFlag = true this.searchPartModel() }, noControlModel() { this.partSearch = { site: this.notifyData.site, sourceBu: this.notifyData.bu, partNo: '', partDesc: '', spec: '', } this.noControlPartModelFlag = true this.searchNoControlPartModel() }, searchPartModel() { getPartList(this.partSearch).then(({ data }) => { if (data.code === 0) { this.partList = data.rows } }) }, searchNoControlPartModel() { getNoControlPartList(this.partSearch).then(({ data }) => { if (data.code === 0) { this.partList2 = data.rows } }) }, xiadaNotifyModel() { if ( this.dataList.length == 0 && this.dataList2.length == 0 && this.dataList3.length == 0 ) { this.$alert('没有明细记录无法下达!!', '提示', { confirmButtonText: '确定', }) return false } this.$confirm('确定下达' + '?', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }).then(() => { updateNotifyStatus(this.notifyData).then(({ data }) => { if (data.code === 0) { this.$message.success('下达成功') this.getUserNotifyNo() } }).catch(() => { this.$message.error(data.msg) }) }) /* checkPartStock(this.notifyData).then(({ data }) => { if (data.code === 0) { this.xiadaList = data.rows } }) */ //this.xiadaModelFlag = true
}, xiadaNotify() { xiadaNotify(this.notifyData).then(({ data }) => { if (data.code === 0) { this.xiadaModelFlag = false this.getUserNotifyNo() this.$message.success('操作成功') } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }, saveOtherPart() { if ( this.otherPartData.qtyToIssue == null || this.otherPartData.qtyToIssue == '' || this.otherPartData.qtyToIssue <= 0 ) { this.$message.warning('请填写领取数量!') return false } this.$confirm('确定保存' + '?', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }).then(() => { saveOtherPart(this.otherPartData).then(({ data }) => { if (data.code === 0) { this.saveOtherPartModalFlag = false if (this.otherPartData.issueType === '非BOM物料') { this.partModelFlag = false this.activeName = 'noBom' this.searchOtherPart('非BOM物料') } if (this.otherPartData.issueType === '不管控物料') { this.noControlPartModelFlag = false this.activeName = 'noControl' this.searchOtherPart('不管控物料') } this.$message.success('操作成功') } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }) }, deleteNotify() { if (this.dataList.length > 0) { this.$alert('请先删除已经申请的明细记录!!', '提示', { confirmButtonText: '确定', }) return false } deleteUnissueNotifyHeader(this.notifyData).then(({ data }) => { if (data.code === 0) { this.getUserNotifyNo() this.$message.success(data.msg) } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }, updateBuModel() { if (this.dataList.length > 0) { this.$alert( '已经选择了工单,无法切换BU,请删除已选工单!', '错误', { confirmButtonText: '确定', } ) } let inData = { site: this.notifyData.site, username: this.$store.state.user.name, } getBuByUserNameSite(inData).then(({ data }) => { if (data && data.code === 0) { this.buList = data.rows } }) this.newBu = this.notifyData.bu this.changeBuFlag = true }, saveNewBu() { let inData = { bu: this.newBu, site: this.notifyData.site, notifyNo: this.notifyData.notifyNo, } updateNotifyBu(inData).then(({ data }) => { if (data && data.code === 0) { this.notifyData.bu = this.newBu this.changeBuFlag = false this.$message({ message: '操作成功', type: 'success', duration: 1500, onClose: () => {}, }) } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }, searchOtherPart(type) { let inData = { site: this.notifyData.site, notifyNo: this.notifyData.notifyNo, issueType: type, } searchOtherPart(inData).then(({ data }) => { if (data && data.code === 0) { if (type === '非BOM物料') { this.dataList2 = data.rows } if (type === '不管控物料') { this.dataList3 = data.rows } } }) }, // 删除
deleteNotifySOS(row) { this.$confirm(`是否删除这个工单的申请信息?`, '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning', }) .then(() => { deleteNotifyUnissue(row).then(({ data }) => { if (data && data.code === 0) { this.getNotifyNoDetail() this.$message({ message: '操作成功', type: 'success', duration: 1500, onClose: () => {}, }) } else { this.$alert(data.msg, '错误', { confirmButtonText: '确定', }) } }) }) .catch(() => {}) },
// 动态列开始 获取 用户保存的 格式列
async getTableUserColumn(tableId, columnId) { let queryTableUser = { userId: this.$store.state.user.name, functionId: this.$route.meta.menuId, tableId: tableId, status: true, languageCode: this.$i18n.locale, } await getTableUserListLanguage(queryTableUser).then(({ data }) => { if (data.rows.length > 0) { //this.columnList1 = []
switch (columnId) { case 1: this.columnList = data.rows break case 2: this.columnList2 = data.rows break case 3: this.columnList3 = data.rows break case 4: this.columnList4 = data.rows break } } else { this.getColumnList(tableId, columnId) } }) },
// 获取 tableDefault 列
async getColumnList(tableId, columnId) { let queryTable = { functionId: this.$route.meta.menuId, tableId: tableId, languageCode: this.$i18n.locale, } await getTableDefaultListLanguage(queryTable).then(({ data }) => { if (!data.rows.length == 0) { switch (columnId) { case 1: this.columnList = data.rows break case 2: this.columnList2 = data.rows break case 3: this.columnList3 = data.rows break case 4: this.columnList4 = data.rows break } } else { // this.showDefault = true.
} }) }, //获取按钮的权限数据
getButtonAuthData() { let searchFlag = this.isAuth(this.menuId + ':search') let saveFlag = this.isAuth(this.menuId + ':save') let updateFlag = this.isAuth(this.menuId + ':update') let deleteFlag = this.isAuth(this.menuId + ':delete') //处理页面的权限数据
this.authSearch = !searchFlag this.authSave = !saveFlag this.authUpdate = !updateFlag this.authDelete = !deleteFlag }, searchTable() {}, getAllNotifyStatus() { let inData = { site: this.$store.state.user.site, listName: 'ISSUENOTIFYHEADER_STATUS', locale: this.$i18n.locale, } getAllNotifyStatus(inData).then(({ data }) => { this.notifyStatusList = data console.log('notifyStatusList', this.notifyStatusList) }) }, },}</script><style scoped>
.board666 .el-table .error-row { background: #f86868;}
/* 在 <style scoped> 下,使用深度选择器作用到 ElementUI 内部结构 */.issueNotify { width: 100%; height: auto;}.issueNotify /deep/ .el-form-item__content { display: inline !important;}
.site-content > .el-tabs > .el-tabs__content > .site-tabs__tools { top: 35px; height: 40px; font-size: 16px; line-height: 40px;}
.text-right /deep/ .el-input__inner { text-align: right !important;}
.text-right /deep/ .el-input-number__input { text-align: right !important;}
.yzzTable /deep/.el-table .cell { line-height: 20px; font-size: 12px; height: 20px;}</style><style scoped>/* 选择工单弹窗:紧凑表格与按钮样式 */.choose-sos-btn { height: 14px; box-sizing: border-box; padding: 0 6px; line-height: 12px; font-size: 12px; display: inline-flex; align-items: center; justify-content: center;}</style>
|