拆分原材料和外购成品的业务流程(报检、下单、检验)
| ¶Ô±ÈÐÂÎļþ |
| | |
| | | //éå®è®¢åæ¥æ£æ¥è¯¢æ¥å£ |
| | | import request from '@/utils/request' |
| | | |
| | | // éå®è®¢åæ¥æ£æ¥è¯¢å
¨é¨ |
| | | export function getIfsByAll(query) { |
| | | return request({ |
| | | url: '/ifsOrderInspection/getIfsByAll', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // éå®è®¢åæ¥æ£æ¥çå·²å®æä¿¡æ¯ |
| | | export function getIfsByFinish(query) { |
| | | return request({ |
| | | url: '/ifsOrderInspection/getIfsByFinish', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| ¶Ô±ÈÐÂÎļþ |
| | |
| | | //ifsé¶ä»¶å±æ§æ¥å£ |
| | | import request from '@/utils/request' |
| | | |
| | | // æ°å¢æä¿åé¶ä»¶å±æ§ |
| | | export function saveOrUpdateProps(data) { |
| | | return request({ |
| | | url: '/ifsPartProps/saveOrUpdateProps', |
| | | method: 'post', |
| | | data: data |
| | | }) |
| | | } |
| | | // æ¥è¯¢ifs订åçé¶ä»¶å±æ§è®°å½ |
| | | export function getOneByIfsId(ifsId) { |
| | | return request({ |
| | | url: '/ifsPartProps/getOneByIfsId/' + ifsId, |
| | | method: 'get' |
| | | }) |
| | | } |
| ¶Ô±ÈÐÂÎļþ |
| | |
| | | // å¤è´ä¸å页é¢ç¸å
³æ¥å£ |
| | | import request from '@/utils/request' |
| | | |
| | | // æ¥è¯¢IFS订å-å¾
æ¥æ£ |
| | | export function getWarehouseSubmit(query) { |
| | | return request({ |
| | | url: '/outsourcingFinishProduct/getWarehouseSubmit', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | |
| | | // æ¥è¯¢IFS订å-å¾
æ£éª |
| | | export function getIfsByStateOne(query) { |
| | | return request({ |
| | | url: '/outsourcingFinishProduct/getIfsByStateOne', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ¥è¯¢åææä¸å-å·²æ£éª |
| | | export function getIfsByOver(query) { |
| | | return request({ |
| | | url: '/outsourcingFinishProduct/getIfsByOver', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ¥è¯¢åææä¸å-å
¨é¨ |
| | | export function getIfsByAll(query) { |
| | | return request({ |
| | | url: '/outsourcingFinishProduct/getIfsByAll', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | |
| | | name: "AddOrder", |
| | | meta: { title: "è¿è¡æåä¸å", activeMenu: "/business/productOrder",keepAlive: true }, |
| | | }, |
| | | { |
| | | // å¤è´ä¸å-è¿è¡å¤è´ä¸å |
| | | path: "customsInspectionOrder", |
| | | component: () => |
| | | import("@/views/business/productOrder/components/addOrder.vue"), |
| | | name: "CustomsInspectionOrder", |
| | | meta: { |
| | | title: "è¿è¡å¤è´æåä¸å", |
| | | activeMenu: "/business/outsourcingFinishProduct", |
| | | keepAlive: true |
| | | }, |
| | | }, |
| | | ], |
| | | }, |
| | | { |
| | | // å¤è´æåä¸å |
| | | path: "/outsourcingFinishProduct", |
| | | component: Layout, |
| | | hidden: true, |
| | | permissions: ["business:outsourcingFinishProduct"], |
| | | children: [ |
| | | { |
| | | // æ¥çæåä¸å详æ
|
| | | path: "addView", |
| | | component: () => |
| | | import("@/views/business/productOrder/components/addView.vue"), |
| | | name: "AddView", |
| | | meta: { title: "æ¥çæåä¸å详æ
", activeMenu: "/business/outsourcingFinishProduct",keepAlive: true }, |
| | | }, |
| | | { |
| | | // è¿è¡ä¸å-æåä¸å |
| | | path: "addOrder", |
| | | component: () => |
| | | import("@/views/business/productOrder/components/addOrder.vue"), |
| | | name: "AddOrder", |
| | | meta: { title: "è¿è¡æåä¸å", activeMenu: "/business/outsourcingFinishProduct",keepAlive: true }, |
| | | }, |
| | | { |
| | | // å¤è´ä¸å-è¿è¡å¤è´ä¸å |
| | | path: "customsInspectionOrder", |
| | | component: () => |
| | | import("@/views/business/materialOrder/customsInspectionOrder"), |
| | | name: "CustomsInspectionOrder", |
| | | meta: { |
| | | title: "è¿è¡å¤è´æåä¸å", |
| | | activeMenu: "/business/outsourcingFinishProduct", |
| | | keepAlive: true |
| | | }, |
| | | }, |
| | | ], |
| | | }, |
| | | { |
| | |
| | | :header-cell-style="{ background: '#f8f8f9', color: '#515a6e' }" border |
| | | tooltip-effect="dark" height="100%"> |
| | | <el-table-column type="index" label="åºå·" align="center" width="65"></el-table-column> |
| | | <el-table-column prop="deviceName" align="center" min-width="100" label="设å¤åç§°"></el-table-column> |
| | | <el-table-column prop="deviceName" align="center" min-width="100" label="设å¤åç§°" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="sample" align="center" label="æ£éªå¯¹è±¡" show-overflow-tooltip |
| | | min-width="150"></el-table-column> |
| | | <el-table-column prop="inspectionItemClass" align="center" label="æ£éªé¡¹åç±»" min-width="120"></el-table-column> |
| | | <el-table-column prop="inspectionItem" align="center" label="æ£éªé¡¹" min-width="100"></el-table-column> |
| | | <el-table-column prop="inspectionItemSubclass" align="center" label="æ£éªå项" min-width="100"></el-table-column> |
| | | <el-table-column prop="referx" align="center" label="åç
§X" min-width="100"></el-table-column> |
| | | <el-table-column prop="x" align="center" label="X"></el-table-column> |
| | | <el-table-column prop="refery" align="center" label="åç
§Y" min-width="100"></el-table-column> |
| | | <el-table-column prop="y" align="center" label="Y"></el-table-column> |
| | | <el-table-column prop="anotherName" align="center" label="å«å" min-width="100"></el-table-column> |
| | | <el-table-column prop="matchingName" align="center" label="å¹é
åç§°" min-width="100"></el-table-column> |
| | | <el-table-column prop="formula" align="center" label="å
¬å¼"></el-table-column> |
| | | <el-table-column prop="inspectionItemClass" align="center" label="æ£éªé¡¹åç±»" min-width="120" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="inspectionItem" align="center" label="æ£éªé¡¹" min-width="100" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="inspectionItemSubclass" align="center" label="æ£éªå项" min-width="100" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="referx" align="center" label="åç
§X" min-width="100" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="x" align="center" label="X" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="refery" align="center" label="åç
§Y" min-width="100" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="y" align="center" label="Y" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="anotherName" align="center" label="å«å" min-width="100" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="matchingName" align="center" label="å¹é
åç§°" min-width="100" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="formula" align="center" label="å
¬å¼" show-overflow-tooltip></el-table-column> |
| | | <el-table-column fixed="right" label="æä½" width="120" align="center"> |
| | | <template slot-scope="scope"> |
| | | <el-button type="text" @click="dataConfig(scope.row)">æ°éé
ç½®</el-button> |
| | |
| | | :content="formula.content" :key="key" placement="top"> |
| | | <label>{{ formula.label }}()</label> |
| | | </el-tooltip> |
| | | <el-input type="textarea" autosi:autosize="{ minRows: 2, maxRows: 4}" ze placeholder="请è¾å
¥å
容" |
| | | <el-input type="textarea" autosize:autosize="{ minRows: 2, maxRows: 4}" placeholder="请è¾å
¥å
容" |
| | | v-model="configForm.formula" @change="evalResult"> |
| | | </el-input> |
| | | </template> |
| | |
| | | structureItemParameterId: row.structureItemParameterId |
| | | }).then(res => { |
| | | const data = res.data; |
| | | console.log("æ°éé
ç½®--",data) |
| | | if (data[0]) { |
| | | this.domains.splice(0, 1); |
| | | let formula = data[0].formula |
| | |
| | | } |
| | | } |
| | | } |
| | | if (isIncludes === false && this.configForm.formula !== "" && this.configForm.formula !== undefined) { |
| | | if (isIncludes === false && this.configForm.formula !== "" && this.configForm.formula !== null && this.configForm.formula !== undefined) { |
| | | i.formula = "(" + this.configForm.formula + ")"; |
| | | } else { |
| | | i.formula = this.configForm.formula; |
| | |
| | | tabList: [ |
| | | { label: "å§æ", value: 0 }, |
| | | { label: "åææ", value: 1 }, |
| | | { label: "å¤è´", value: 2 }, |
| | | ], |
| | | active: 1, |
| | | tabIndex: 0, |
| | |
| | | lookTableLoading: false, |
| | | // æ°æ®æ¥çç¸å
³å段---ç»æ |
| | | retestVisible: false, |
| | | upIndex: 0 |
| | | upIndex: 0, |
| | | tabLabel: '' |
| | | }; |
| | | }, |
| | | mounted() { |
| | |
| | | }, |
| | | refreshTable(e) { |
| | | this.page.current = 1; |
| | | this.queryParams.typeSource = this.tabIndex; |
| | | let typeSource = null; |
| | | if(this.tabIndex===1){ |
| | | typeSource=1 |
| | | }else if(this.tabIndex===2){ |
| | | typeSource = 0 |
| | | } |
| | | this.queryParams.tabLabel = this.tabLabel; |
| | | this.queryParams.typeSource = typeSource; |
| | | this.getList(); |
| | | }, |
| | | // ä¸è½½æ¥å |
| | |
| | | }, |
| | | handleTab(m, i) { |
| | | this.tabIndex = i; |
| | | this.tabLabel = m.label; |
| | | this.queryParams.sonLaboratory = ""; |
| | | this.refreshTable(); |
| | | }, |
| | |
| | | <template> |
| | | <div v-loading="loading" class="inspection" style="background-color: rgb(245, 247, 251);"> |
| | | <el-row class="title"> |
| | | <el-col :span="8" style="text-align: left"> |
| | | <el-col v-if="insOrder.ifsOrderType!=='02wg'" :span="8" style="text-align: left;"> |
| | | <el-form :inline="true" :model="otherForm" class="form-inline" label-width="50px" |
| | | style="text-align: right; padding-top: 0; display: inline"> |
| | | <el-form-item label="温度:" style="margin-bottom: 0"> |
| | |
| | | </el-form-item> |
| | | </el-form> |
| | | </el-col> |
| | | <el-col :span="16" style="text-align: right"> |
| | | <el-col :span="insOrder.ifsOrderType!=='02wg'?16:24" style="text-align: right"> |
| | | <el-button v-if="insOrder.ifsOrderType" size="small" type="primary" @click="showMaterialPropsDialog">IFSç©æå±æ§æ´æ°</el-button> |
| | | <el-button size="small" type="primary" @click="refreshView">å·æ°</el-button> |
| | | <el-button v-if="typeSource == 1" size="small" type="primary" @click="openPurchase">è¿è´§éªè¯</el-button> |
| | | <el-button v-if="state == 1 && typeSource == 1" size="small" type="primary" |
| | |
| | | @blur="subOtherForm(insOrder.remark, 'remark')"></el-input> |
| | | <!-- <el-tag v-if="currentKey">{{ insOrder.remark }}</el-tag> --> |
| | | </el-form-item> |
| | | <template v-if="insOrder.isSplitOrder && insOrder.isSplitOrder===1"> |
| | | <el-form-item label="夿¤é¢è²:"> |
| | | <el-input v-model="insOrder.outerColor" clearable disabled placeholder="" size="small"></el-input> |
| | | </el-form-item> |
| | | <el-form-item label="ç»ç¼é¢è²:"> |
| | | <el-input v-model="insOrder.insulationColor" clearable disabled placeholder="" size="small"></el-input> |
| | | </el-form-item> |
| | | <el-form-item label="çå·:"> |
| | | <el-input v-model="insOrder.drumNo" clearable disabled placeholder="" size="small"></el-input> |
| | | </el-form-item> |
| | | </template> |
| | | </el-form> |
| | | </div> |
| | | <div class="center"> |
| | |
| | | :purchaseDialog="purchaseDialog" @resetPurchaseDialog="resetPurchaseDialog"></purchase-verification> |
| | | <!--æ¥çå·¥æ¶å¼¹æ¡--> |
| | | <viewManHourDia ref="viewManHourDia" @submit="openAddVerifyDia"></viewManHourDia> |
| | | <!-- IFSç©æå±æ§ç¼è¾å¼¹æ¡--> |
| | | <el-dialog |
| | | title="æ´æ°IFSåºåç©ææ¹æ¬¡å±æ§" |
| | | :visible.sync="ifsMaterialPropsVisible" |
| | | width="20%"> |
| | | <el-form style="width:100%" :model="ifsMaterialPropsForm"> |
| | | <el-form-item label="è½½å
·ç¼å·(Attr1):"> |
| | | <el-input size="small" v-model="ifsMaterialPropsForm.drumNo"></el-input> |
| | | </el-form-item> |
| | | <el-form-item label="èµ·å§ç±³æ (Attr2):"> |
| | | <el-input size="small" v-model="ifsMaterialPropsForm.startMeterMark"></el-input> |
| | | </el-form-item> |
| | | <el-form-item label="æªæ¢ç±³æ (Attr3):"> |
| | | <el-input size="small" v-model="ifsMaterialPropsForm.endMeterMark"></el-input> |
| | | </el-form-item> |
| | | <!-- <el-form-item label="å
¥åºé¿åº¦">--> |
| | | <!-- <el-input v-model="ifsMaterialPropsForm.inboundLength"></el-input>--> |
| | | <!-- </el-form-item>--> |
| | | <el-form-item label="ç»ç¼é¢è²(Attr4):"> |
| | | <el-input size="small" v-model="ifsMaterialPropsForm.insulationColor"></el-input> |
| | | </el-form-item> |
| | | <el-form-item label="夿¤é¢è²(Attr5):"> |
| | | <el-input size="small" v-model="ifsMaterialPropsForm.outerColor"></el-input> |
| | | </el-form-item> |
| | | <el-form-item label="å°åä¿¡æ¯(Attr8):"> |
| | | <el-select size="small" v-model="ifsMaterialPropsForm.letteringInfo" placeholder="è¯·éæ©"> |
| | | <el-option v-for="(item,index) in letteringInfoList" :label="item.dictLabel" :value="item.dictValue" :key="index"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-form> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="closePartPropDialog()">å æ¶</el-button> |
| | | <el-button type="primary" @click="saveOrUpdatePartProp()">ç¡® å®</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | |
| | | import DataWorker from '@/workers/DataWorker.worker.js'; |
| | | import html2canvas from "html2canvas"; |
| | | import { mapGetters } from "vuex"; |
| | | import { connect,disconnect,weightList } from "@/utils/connect.js"; |
| | | import viewManHourDia from "@/views/business/inspectionTask/components/viewManHourDia.vue"; |
| | | import {connect,disconnect,weightList} from "@/utils/connect"; |
| | | import {getOneByIfsId,saveOrUpdateProps} from "@/api/business/ifsPartProps.js"; |
| | | export default { |
| | | name: 'Inspection', |
| | | components: { |
| | |
| | | }, |
| | | data() { |
| | | return { |
| | | letteringInfoList: [], |
| | | ifsMaterialPropsForm:{ |
| | | id:null, |
| | | ifsOrderId: null, |
| | | drumNo: '', // è½½å
·ç¼å· |
| | | startMeterMark: '', // èµ·å§ç±³æ |
| | | endMeterMark: '', // æªæ¢ç±³æ |
| | | insulationColor: '', // ç»ç¼é¢è² |
| | | outerColor: '', // 夿¤é¢è² |
| | | inboundLength: '', // å
¥åºé¿åº¦ |
| | | letteringInfo: '', // å°åä¿¡æ¯ |
| | | }, |
| | | ifsMaterialPropsVisible:false, |
| | | sonLaboratory: null, |
| | | orderId: null, |
| | | state: null, |
| | |
| | | } |
| | | }); |
| | | } |
| | | console.log("å¤çåçæ¨¡æ¿-",this.tableList) |
| | | }, |
| | | // ç¹æ®æ£éªé¡¹--çå¬è®¾å¤ä¿¡æ¯æ¹å |
| | | equipForm: { |
| | |
| | | } |
| | | }, |
| | | methods: { |
| | | closePartPropDialog(){ |
| | | this.ifsMaterialPropsForm = { |
| | | id:null, |
| | | ifsOrderId: null, |
| | | drumNo: '', // è½½å
·ç¼å· |
| | | startMeterMark: '', // èµ·å§ç±³æ |
| | | endMeterMark: '', // æªæ¢ç±³æ |
| | | insulationColor: '', // ç»ç¼é¢è² |
| | | outerColor: '', // 夿¤é¢è² |
| | | inboundLength: '', // å
¥åºé¿åº¦ |
| | | letteringInfo: '', // å°åä¿¡æ¯ |
| | | } |
| | | this.ifsMaterialPropsVisible = false; |
| | | }, |
| | | getPartProps(ifsId){ |
| | | getOneByIfsId(ifsId).then((res)=>{ |
| | | if(res.code==200 && res.data){ |
| | | this.ifsMaterialPropsForm = res.data; |
| | | } |
| | | }) |
| | | }, |
| | | saveOrUpdatePartProp(){ |
| | | saveOrUpdateProps({ |
| | | ...this.ifsMaterialPropsForm, |
| | | partNo: this.insOrder.partNo, |
| | | lotBatchNo: this.insOrder.lotBatchNo, |
| | | }).then((res)=>{ |
| | | if(res.code==200){ |
| | | this.$message.success("ä¿åæå"); |
| | | this.ifsMaterialPropsVisible = false; |
| | | } |
| | | }) |
| | | }, |
| | | //æå¼IFSç©æå±æ§å¼¹æ¡ |
| | | showMaterialPropsDialog(){ |
| | | this.getPartProps(this.insOrder.ifsInventoryId) |
| | | this.$nextTick(()=>{ |
| | | this.ifsMaterialPropsVisible = true; |
| | | }) |
| | | }, |
| | | disconnect() { |
| | | return disconnect |
| | | }, |
| | | sss() { |
| | | console.log(this.$store.state.weightList) // |
| | | }, |
| | |
| | | laboratory: this.sonLaboratory, |
| | | }).then(async (res) => { |
| | | this.insOrder = res.data.insOrder; |
| | | //æ¥è¯¢é¶ä»¶å±æ§ |
| | | this.getPartProps(res.data.insOrder.ifsInventoryId) |
| | | this.supplierDensity = res.data.supplierDensity; |
| | | this.getList() |
| | | this.urgentList.forEach((m) => { |
| | |
| | | return newObj; |
| | | }, |
| | | handleDataAcquisition(data, noDialog) { |
| | | console.log("dadad--",data) |
| | | // æ¯å¦å¯ä»¥ç¼è¾æ°éæ°æ® |
| | | if (this.dataAcquisitionEidtAble) { |
| | | this.getDataType = 1; |
| | |
| | | }; |
| | | } |
| | | // å¾ªç¯æ°éæ°æ® |
| | | console.log(data[i],i) |
| | | for (let j in data[i]) { |
| | | console.log("jjjjj--",j) |
| | | // æ¼æ¥å符串 æ£éªé¡¹åç±»+æ£éªé¡¹+æ£éªå项 |
| | | let str0 = ""; |
| | | if (i.includes("@")) { |
| | |
| | | this.getDataIndexLoading = false; |
| | | this.dataGetDia = false; |
| | | this.getDataTypeId = ""; |
| | | console.log("dadada---",this.dataAcquisitionInfo) |
| | | this.worker0.postMessage( |
| | | JSON.stringify({ |
| | | dataAcquisitionInfo: this.dataAcquisitionInfo, |
| | |
| | | // çå¬ Worker è¿åçç»æ |
| | | this.worker0.onmessage = (event) => { |
| | | let result = JSON.parse(event.data); |
| | | console.log("Worker è¿åçç»æ:", result); |
| | | if (result.method == "changeInput") { |
| | | // ééåçæ°æ®ï¼éè¦è¿è¡è®¡ç®ç线ç¨è¿è¡è®¡ç® |
| | | let { list, n } = result.value; |
| | |
| | | if (c.v.ps != undefined && c.v.ps.value === "æ£éªé¡¹") { |
| | | if (count4 === 0) { |
| | | if (c.v.v) { |
| | | c.v.v = c.v.v.replace(/\s*/g, ""); |
| | | c.v.v = c.v.v.replace(/[\n\r\s]*/g, ""); |
| | | } |
| | | str += c.v.v; |
| | | count4 += 1; |
| | |
| | | ) { |
| | | if (count4 === 1) { |
| | | if (c.v.v) { |
| | | c.v.v = c.v.v.replace(/\s*/g, ""); |
| | | c.v.v = c.v.v.replace(/[\n\r\s]*/g, ""); |
| | | } |
| | | str += c.v.v; |
| | | count4 += 1; |
| | |
| | | if (c.v.ps != undefined && c.v.ps.value === "æ£éªé¡¹åç±»") { |
| | | if (count4 === 0) { |
| | | if (c.v.v) { |
| | | c.v.v = c.v.v.replace(/\s*/g, ""); |
| | | c.v.v = c.v.v.replace(/[\n\r\s]*/g, ""); |
| | | } |
| | | str += c.v.v; |
| | | count4 += 1; |
| | |
| | | } else if (c.v.ps != undefined && c.v.ps.value === "æ£éªé¡¹") { |
| | | if (count4 === 1) { |
| | | if (c.v.v) { |
| | | c.v.v = c.v.v.replace(/\s*/g, ""); |
| | | console.log("è¿å
¥1111111") |
| | | c.v.v = c.v.v.replace(/[\n\r\s]*/g, ""); |
| | | } |
| | | str += c.v.v; |
| | | count4 += 1; |
| | |
| | | ) { |
| | | if (count4 === 2) { |
| | | if (c.v.v) { |
| | | c.v.v = c.v.v.replace(/\s*/g, ""); |
| | | c.v.v = c.v.v.replace(/[\n\r\s]*/g, ""); |
| | | } |
| | | str += c.v.v; |
| | | count4 += 1; |
| | |
| | | if (str === "æºæ¢°æ§è½å¹²ææä¼¸å¼ºåº¦(纵å)") { |
| | | if (c.v.ps != undefined && c.v.ps.value === "åä½") { |
| | | if (c.v.v) { |
| | | c.v.v = c.v.v.replace(/\s*/g, ""); |
| | | c.v.v = c.v.v.replace(/[\n\r\s]*/g, ""); |
| | | } |
| | | str2 = str + c.v.v; |
| | | unit2 = c.v.v; |
| | |
| | | undefined |
| | | ? "" |
| | | : this.currentSample.insProduct[i].inspectionItemClass; |
| | | inspectionItemClass = inspectionItemClass.replace(/\s*/g, ""); |
| | | inspectionItemClass = inspectionItemClass.replace(/[\n\r\s]*/g, ""); |
| | | let inspectionItem = |
| | | this.currentSample.insProduct[i].inspectionItem == null || |
| | | this.currentSample.insProduct[i].inspectionItem == undefined |
| | | ? "" |
| | | : this.currentSample.insProduct[i].inspectionItem; |
| | | inspectionItem = inspectionItem.replace(/\s*/g, ""); |
| | | inspectionItem = inspectionItem.replace(/[\n\r\s]*/g, ""); |
| | | let inspectionItemSubclass = |
| | | this.currentSample.insProduct[i].inspectionItemSubclass == |
| | | null || |
| | |
| | | ? "" |
| | | : this.currentSample.insProduct[i].inspectionItemSubclass; |
| | | inspectionItemSubclass = inspectionItemSubclass.replace( |
| | | /\s*/g, |
| | | /[\n\r\s]*/g, |
| | | "" |
| | | ); |
| | | if (inspectionItemSubclass === "å¹²ææä¼¸å¼ºåº¦(纵å)") { |
| | |
| | | this.$message.error("请æå®å¤æ ¸äººå"); |
| | | return; |
| | | } |
| | | if (!this.otherForm.humidity) { |
| | | if (!this.otherForm.humidity && this.insOrder.ifsOrderType!=='02wg') { |
| | | this.$message.error("请è¾å
¥æ¹¿åº¦"); |
| | | return; |
| | | } |
| | | if (!this.otherForm.temperature) { |
| | | if (!this.otherForm.temperature && this.insOrder.ifsOrderType!=='02wg') { |
| | | this.$message.error("请è¾å
¥æ¸©åº¦"); |
| | | return; |
| | | } |
| | |
| | | this.confirmSubmit(false) |
| | | }); |
| | | }else{ |
| | | this.confirmSubmit(false) |
| | | this.confirmSubmit(true) |
| | | } |
| | | } else { |
| | | let newData = []; |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <div> |
| | | <div v-show="!cableConfigShow&&!auxiliaryShow"> |
| | | <div class="header"> |
| | | <div> |
| | | <span>éè´è®¢åä¿¡æ¯</span> |
| | |
| | | <el-button v-show="active==1" size="small" @click="templateDia=true"> |
| | | <span style="color: #3A7BFA;">ä¿å模æ¿</span> |
| | | </el-button> |
| | | <el-button v-if="active==1&&addObj.sample!=undefined&&(addObj.sample.indexOf('çµç¼')>-1 ||addObj.sample.indexOf('综å')>-1)" size="small" type="primary" @click="openCableConfig">çµç¼é
ç½®</el-button> |
| | | <el-button v-if="active==1&&addObj.sample!=undefined&&addObj.sample.indexOf('çµç¼')>-1" size="small" type="primary" @click="openAuxiliaryCore">è¾
å©çº¿è¯é
ç½®</el-button> |
| | | <el-button v-show="active==1 && addObj.orderType === 'è¿åæ£éª'" :loading="noNeedCheckLoad" size="small" type="primary" @click="noNeedCheck">å
æ£</el-button> |
| | | <el-button v-show="active==1" :loading="saveLoad" size="small" type="primary" @click="save">æäº¤</el-button> |
| | | <el-button size="small" @click="goBack"> |
| | |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="search"> |
| | | <div class="search" v-show="!cableConfigShow&&!auxiliaryShow"> |
| | | <el-form ref="addObj" :inline="true" :model="addObj" :rules="addObjRules" label-width="90px"> |
| | | <el-row> |
| | | <el-col :span="6"> |
| | |
| | | </el-row> |
| | | </el-form> |
| | | </div> |
| | | <div> |
| | | <div v-show="!cableConfigShow&&!auxiliaryShow"> |
| | | <div style="display: flex;justify-content: space-between;background-color: #F5F7FB;margin-bottom: 6px"> |
| | | <div v-if="active==1"> |
| | | <el-form :inline="true" :model="addObj1" label-width="90px"> |
| | |
| | | <el-table-column :filter-method="filterHandler" :filters="filters" label="åå®éªå®¤" min-width="130" prop="sonLaboratory" |
| | | show-overflow-tooltip></el-table-column> |
| | | </el-table> |
| | | </div> |
| | | </div > |
| | | <!--ç¹æ®å¼å¤çæ¡--> |
| | | <el-dialog :before-close="beforeClose" :close-on-click-modal="false" :close-on-press-escape="false" :show-close="false" |
| | | :visible.sync="bsm1DiaAll" |
| | |
| | | <el-button :loading="noNeedCheckLoad" type="primary" @click="handleNoNeedCheck">ç¡® å®</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | <!--çµç¼é
ç½®--> |
| | | <cableConfig v-if="cableConfigShow" ref="cableConfigShow" :active="active" :isSpecial="isSpecial" :sampleSelectionList="sampleSelectionList" @goBackAdd="goBackAdd"/> |
| | | <!--è¾
å©çº¿è¯é
ç½®--> |
| | | <auxiliary-wire-core v-if="auxiliaryShow" :active="active" :isSpecial="isSpecial" :sampleSelectionList="sampleSelectionList" @goBackAdd2="goBackAdd2"></auxiliary-wire-core> |
| | | </div> |
| | | </template> |
| | | |
| | |
| | | delRawMaterOrderTemplate, |
| | | getInsOrder, |
| | | getUserNow, |
| | | notificationRawOrder, selectRawMaterOrderTemplate, |
| | | notificationRawOrder, |
| | | selectRawMaterOrderTemplate, |
| | | selectRawMaterOrderTemplateById, |
| | | selectsStandardMethodByFLSSM, |
| | | selectStandardMethodEnum, |
| | | selectStandardProductList, |
| | | selectStandardTreeListByPartNo |
| | | } from "@/api/business/rawMaterialOrder"; |
| | | |
| | | import {dateFormat} from "@/utils/date"; |
| | | import AuxiliaryWireCore from "../productOrder/components/auxiliaryWireCore.vue"; |
| | | import cableConfig from "../productOrder/components/cable-config.vue"; |
| | | export default { |
| | | name: "CustomsInspectionOrder", |
| | | dicts: ['check_type', 'urgency_level'], |
| | | components: {}, |
| | | components: {cableConfig, AuxiliaryWireCore}, |
| | | props: { |
| | | }, |
| | | data() { |
| | | return { |
| | | cableConfigShow: false, |
| | | auxiliaryShow: false, |
| | | isSpecial: false, |
| | | sampleSelectionList: [],//æ ·åè¡¨æ ¼é䏿°æ® |
| | | isOutsourcing: 'f',//æ¯å¦å¤è´æå |
| | | customsInspection: {}, |
| | | orderType: '', |
| | | active: 0, |
| | |
| | | // this.addObj.method = null |
| | | // this.productList = [] |
| | | // }, |
| | | isOutsourcing:{ |
| | | deep: true, |
| | | handler(newVal){ |
| | | if(newVal && newVal==='t'){ |
| | | this.addObj.appointed = dateFormat(new Date(),'yyyy-MM-dd') |
| | | this.addObj.testQuantity = this.customsInspection.qtyArrived |
| | | this.addObj.orderType = 'è¿åæ£éª' |
| | | this.addObj.typeSource = 0 |
| | | } |
| | | } |
| | | }, |
| | | productList: { |
| | | deep: true, |
| | | handler(val) { |
| | |
| | | created() { |
| | | this.active = this.$route.query.active |
| | | this.orderType = this.$route.query.orderType |
| | | this.isOutsourcing = this.$route.query.isOutsourcing |
| | | this.currentId = this.$route.query.currentId |
| | | this.isReport = this.$route.query.isReport |
| | | this.customsInspection = this.$route.query.customsInspection |
| | |
| | | activated() { |
| | | this.active = this.$route.query.active |
| | | this.orderType = this.$route.query.orderType |
| | | this.isOutsourcing = this.$route.query.isOutsourcing |
| | | this.currentId = this.$route.query.currentId |
| | | this.isReport = this.$route.query.isReport |
| | | this.customsInspection = this.$route.query.customsInspection |
| | |
| | | // this.getInfo() // è·åæ°æ® |
| | | // }, |
| | | methods: { |
| | | goBackAdd () { |
| | | this.cableConfigShow = false |
| | | }, |
| | | goBackAdd2 () { |
| | | this.auxiliaryShow = false |
| | | }, |
| | | // ç¼è¾è¦æ±å¼è¡¨æ ¼ |
| | | editSpecial () { |
| | | this.isSpecial = true |
| | | this.$nextTick(() => { |
| | | this.$refs.productTable.doLayout(); |
| | | }); |
| | | }, |
| | | areObjectsValuesEqual (objects, property) { |
| | | if (!objects || objects.length === 0) return false; |
| | | const firstValue = objects[0][property]; |
| | | return objects.every(obj => obj[property] === firstValue); |
| | | }, |
| | | // è¾
å©çº¿è¯é
ç½® |
| | | openAuxiliaryCore () { |
| | | if (this.active == 1) { |
| | | if (this.sampleIds.length === 0) { |
| | | this.$message.error("æªéæ©æ ·å") |
| | | } else if (this.sampleIds.length === 1) { |
| | | if (!this.sampleSelectionList[0].standardMethodListId) { |
| | | this.$message.error("æ ·åæªéæ©æ£éªæ å") |
| | | return |
| | | } |
| | | this.auxiliaryShow = true |
| | | } else { |
| | | // åæ¶é
ç½®å¤ä¸ªæ ·åççµç¼é
ç½®æ¶å¿
须鿩ç¸åçæ£éªæ å |
| | | if (!this.sampleSelectionList.every(value => value.standardMethodListId)) { |
| | | this.$message.error("æ ·åæªéæ©æ£éªæ å") |
| | | } else { |
| | | if (!this.areObjectsValuesEqual(this.sampleSelectionList, 'standardMethodListId')) { |
| | | this.$message.error("è¯·éæ©ç¸åçæ£éªæ å") |
| | | return |
| | | } |
| | | this.auxiliaryShow = true |
| | | } |
| | | } |
| | | } else { |
| | | if (this.sampleId === null) { |
| | | this.$message.error('æªé䏿 ·å') |
| | | } |
| | | } |
| | | }, |
| | | //æå¼çµç¼é
ç½®å¼¹æ¡ |
| | | openCableConfig() { |
| | | if (this.active == 1) { |
| | | if (this.sampleIds.length === 0) { |
| | | this.$message.error("æªéæ©æ ·å") |
| | | } else if (this.sampleIds.length === 1) { |
| | | if (!this.sampleSelectionList[0].standardMethodListId) { |
| | | this.$message.error("æ ·åæªéæ©æ£éªæ å") |
| | | return |
| | | } |
| | | this.cableConfigShow = true |
| | | } else { |
| | | // åæ¶é
ç½®å¤ä¸ªæ ·åççµç¼é
ç½®æ¶å¿
须鿩ç¸åçæ£éªæ å |
| | | if (!this.sampleSelectionList.every(value => value.standardMethodListId)) { |
| | | this.$message.error("æ ·åæªéæ©æ£éªæ å") |
| | | } else { |
| | | if (!this.areObjectsValuesEqual(this.sampleSelectionList, 'standardMethodListId')) { |
| | | this.$message.error("è¯·éæ©ç¸åçæ£éªæ å") |
| | | return |
| | | } |
| | | this.cableConfigShow = true |
| | | } |
| | | } |
| | | } else { |
| | | if (this.sampleId === null) { |
| | | this.$message.error('æªé䏿 ·å') |
| | | } |
| | | } |
| | | }, |
| | | save1 () { |
| | | if (this.bsm1DiaList.length > 0) { |
| | | this.bsm1DiaList.forEach(item => { |
| | |
| | | }) |
| | | } |
| | | }) |
| | | } else { |
| | | } else{ |
| | | notificationRawOrder({ifsInventoryId:this.customsInspection.id}).then(res => { |
| | | if (res.code === 200) { |
| | | if (res.data === 1) { |
| | |
| | | this.$set(this.addObj, 'receiverDate', this.customsInspection.receiverDate) |
| | | this.$set(this.addObj, 'orderNo', this.customsInspection.orderNo) |
| | | this.$set(this.addObj, 'declareUser', this.customsInspection.declareUser) |
| | | this.$set(this.addObj, 'testQuantity', this.customsInspection.testQuantity) |
| | | if(this.isOutsourcing==='f'){ |
| | | this.$set(this.addObj, 'testQuantity', this.customsInspection.testQuantity) |
| | | } |
| | | this.$set(this.addObj, 'buyUnitMeas', this.customsInspection.buyUnitMeas) |
| | | this.$set(this.addObj, 'updateBatchNo', this.customsInspection.updateBatchNo) |
| | | this.$set(this.addObj, 'partDetail', this.customsInspection.partDesc) |
| | |
| | | }) |
| | | }, |
| | | getProNum() { |
| | | this.sampleSelectionList.forEach((m, i) => { |
| | | this.$set(this.sampleSelectionList[i], 'proNum', m.insProduct.filter(a => a.state == 1).length) |
| | | }) |
| | | this.$refs.sampleTable.doLayout() |
| | | }, |
| | | methodFocus() { |
| | |
| | | val.forEach(a => { |
| | | this.sampleIds.push(a.id) |
| | | }) |
| | | this.sampleSelectionList = val |
| | | }, |
| | | // éä¸è¡¨æ ¼è¡çåè° |
| | | rowClick(row, column, event) { |
| | |
| | | this.sampleId = row.id |
| | | if (this.active !== 1) { |
| | | this.sampleIds = [] |
| | | this.sampleIds.push(row.id) |
| | | this.sampleSelectionList.forEach(ele=>{ |
| | | if(ele.id == row.id){ |
| | | this.sampleIds.push(row.id) |
| | | } |
| | | }) |
| | | } |
| | | // this.productList = row.insProduct |
| | | if (this.productList !== null) { |
| | |
| | | }, |
| | | // ä¸å |
| | | playOrder(row) { |
| | | this.$router.push({ path: "/materialOrder/customsInspectionOrder", query: { orderType: 0, customsInspection: row, active: 1 } }); |
| | | this.$router.push({ path: "/materialOrder/customsInspectionOrder", query: {isOutsourcing:'f', orderType: 0, customsInspection: row, active: 1 } }); |
| | | }, |
| | | // å£åº¦æ£éªä¸å |
| | | playOrderSec(row) { |
| | | this.$router.push({ path: "/materialOrder/customsInspectionOrder", query: { orderType: 1, customsInspection: row, active: 1 } }); |
| | | this.$router.push({ path: "/materialOrder/customsInspectionOrder", query: {isOutsourcing:'f', orderType: 1, customsInspection: row, active: 1 } }); |
| | | }, |
| | | // ç¹å»æ ·ååç§°æ¥ç详æ
|
| | | selectAllByOne(row) { |
| ¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <div> |
| | | <div class="search"> |
| | | <el-form :model="entity" ref="entity" size="small" :inline="true"> |
| | | <el-form-item label="æ¹å·" prop="updateBatchNo"> |
| | | <el-input v-model="entity.updateBatchNo" clearable placeholder="请è¾å
¥" size="small" |
| | | @keyup.enter.native="goSearch"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="å§æç¼å·" prop="entrustCode" v-if="tabIndex !== 0"> |
| | | <el-input v-model="entity.entrustCode" clearable placeholder="请è¾å
¥" size="small" |
| | | @keyup.enter.native="goSearch"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="é¶ä»¶å·" prop="partNo"> |
| | | <el-input v-model="entity.partNo" clearable placeholder="请è¾å
¥" size="small" |
| | | @keyup.enter.native="goSearch"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="é¶ä»¶æè¿°" prop="partDesc"> |
| | | <el-input v-model="entity.partDesc" clearable placeholder="请è¾å
¥" size="small" |
| | | @keyup.enter.native="goSearch"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item> |
| | | <el-button v-if="tabIndex === 2 || tabIndex === 3 || tabIndex === 4" |
| | | :icon="!more ? 'el-icon-arrow-down' : 'el-icon-arrow-up'" style="color: #3A7BFA;" type="text" |
| | | @click="more = !more">{{ !more ? 'æ´å¤' : 'æ¶èµ·' }}</el-button> |
| | | <el-button size="mini" type="primary" @click="goSearch">æ¥è¯¢</el-button> |
| | | <el-button size="mini" @click="refresh()">éç½®</el-button> |
| | | </el-form-item> |
| | | <el-form-item label="ä¾åºååç§°" prop="supplierName" |
| | | v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-input v-model="entity.supplierName" clearable placeholder="请è¾å
¥" size="small" |
| | | @keyup.enter.native="goSearch"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="æ ·ååå·" prop="sampleModel" |
| | | v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-input v-model="entity.sampleModel" clearable placeholder="请è¾å
¥" size="small" |
| | | @keyup.enter.native="goSearch"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="æ£éªç¶æ" prop="inspectStatus" |
| | | v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-select v-model="entity.inspectStatus" clearable size="small" @change="goSearch"> |
| | | <el-option v-for="(a, i) in inspectStatusList" :key="i" :label="a.label" :value="a.value"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="ä¸åæ¶é´" prop="date" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-date-picker v-model="entity.date" end-placeholder="ç»ææ¥æ" format="yyyy-MM-dd" placeholder="éæ©æ¥æ" @change="goSearch" |
| | | range-separator="è³" size="small" start-placeholder="å¼å§æ¥æ" type="daterange" value-format="yyyy-MM-dd"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | </el-form> |
| | | </div> |
| | | <div class="table"> |
| | | <div class="table-tab"> |
| | | <div> |
| | | <ul class="tab"> |
| | | <li :class="{ active: tabIndex === 0 }" v-if="checkPermi(['get:raw:await'])" @click="handleTab(0)">å¾
ä¸å</li> |
| | | <li :class="{ active: tabIndex === 1 }" v-if="checkPermi(['get:raw:testing'])" @click="handleTab(1)">æ£éªä¸</li> |
| | | <li :class="{ active: tabIndex === 2 }" v-if="checkPermi(['get:raw:check'])" @click="handleTab(2)">å·²æ£éª</li> |
| | | <li :class="{ active: tabIndex === 3 }" v-if="checkPermi(['get:Ifs:ByAll'])" @click="handleTab(3)">å
¨é¨</li> |
| | | </ul> |
| | | </div> |
| | | <div> |
| | | <el-button v-show="tabIndex === 3" :loading="outLoading" size="small" type="primary" |
| | | @click="handleOut">导åº</el-button> |
| | | <el-button v-if="tabIndex !== 0" size="small" type="primary" @click="openPrint">æ ç¾æå°</el-button> |
| | | </div> |
| | | </div> |
| | | <!--å¾
ä¸å--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData" :column="column" v-if="tabIndex === 0" @pagination="pagination" |
| | | ref="tableData" :rowClassName="changeRowClass" :height="'calc(100vh - 290px)'" |
| | | key="tableData" :page="page" :tableLoading="tableLoading"></lims-table> |
| | | </div> |
| | | <!--æ£éªä¸--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData1" :column="column1" v-if="tabIndex === 1" :isSelection="true" |
| | | :rowClassName="changeRowClass" :handleSelectionChange="selectMethod" @pagination="pagination1" |
| | | :height="'calc(100vh - 290px)'" key="tableData1" :page="page1" :tableLoading="tableLoading1"></lims-table> |
| | | </div> |
| | | <!--å·²æ£éª--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData2" :column="column2" v-if="tabIndex === 2" :isSelection="true" |
| | | :rowClassName="changeRowClass" :handleSelectionChange="selectMethod" @pagination="pagination2" |
| | | :height="'calc(100vh - 290px)'" key="tableData2" :page="page2" :tableLoading="tableLoading2"></lims-table> |
| | | </div> |
| | | <!--å
¨é¨--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData3" :column="column3" v-if="tabIndex === 3" :isSelection="true" |
| | | :rowClassName="changeRowClass" :handleSelectionChange="selectMethod" @pagination="pagination3" |
| | | :height="'calc(100vh - 290px)'" key="tableData3" :page="page3" :tableLoading="tableLoading3"></lims-table> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <!-- 确认å
æ£å¼¹æ¡ --> |
| | | <el-dialog :visible.sync="exemptionVisible" title="确认å
æ£" width="42%"> |
| | | <div style="display: flex"> |
| | | <span style="width: 90px; line-height: 32px">è§æ ¼åå·ï¼</span> |
| | | <el-input v-model="exemptionInfo.partDetail" clearable placeholder="请è¾å
¥" size="small"></el-input> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-row> |
| | | <el-button @click="exemptionVisible = false">å æ¶</el-button> |
| | | <el-button :loading="exemptionLoading" type="primary" @click="submitExemption">ç¡® å®</el-button> |
| | | </el-row> |
| | | </span> |
| | | </el-dialog> |
| | | <!-- æ¤éæ¥æ£ --> |
| | | <el-dialog :visible.sync="declareDialogVisible" title="æ¥æ£æ¤é" width="30%"> |
| | | <p style="font-size:16px;color:#333333">æ¹å·<span style="color:#34BD66">{{ this.insOrderRow.updateBatchNo |
| | | }}</span>çä¿¡æ¯æ¯å¦<span style="color: #FF4902">æ¤éæ¥æ£</span> |
| | | </p> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-row> |
| | | <el-button @click="declareDialogVisible = false">å æ¶</el-button> |
| | | <el-button :loading="upLoad" type="primary" @click="submitDeclare">ç¡® å®</el-button> |
| | | </el-row> |
| | | </span> |
| | | </el-dialog> |
| | | <!-- æ¤éä¸å --> |
| | | <el-dialog :visible.sync="quashDialogVisible" title="ä¸åæ¤é" width="30%"> |
| | | <el-button size="small" type="primary" @click="cancelQuashOrder('enterOrderId')">æ¤éè¿åæ£éªä¸å</el-button> |
| | | <el-button size="small" type="primary" @click="cancelQuashOrder('quarterOrderId')">æ¤éå£åº¦æ£éªä¸å</el-button> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-row> |
| | | <el-button @click="quashDialogVisible = false">å æ¶</el-button> |
| | | </el-row> |
| | | </span> |
| | | </el-dialog> |
| | | <!-- ä¿®æ¹å§æç¼å·å¼¹æ¡ --> |
| | | <el-dialog :visible.sync="entrustCodeVisible" title="æç¤º" width="30%"> |
| | | <el-input v-model="entrustCodeInfo.entrustCode"></el-input> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="entrustCodeVisible = false">å æ¶</el-button> |
| | | <el-button :loading="submitCodeLoading" type="primary" @click="submitCode">ç¡® å®</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | <!--æ ç¾æå°å¼¹æ¡--> |
| | | <print-dialog v-if="printDialog" ref="printDialog" :printDialog="printDialog" |
| | | @closePrintDialog="closePrintDialog"></print-dialog> |
| | | <!--æ°æ®æ¥çå¼¹æ¡--> |
| | | <data-look-visible v-if="dataDialogVisible" ref="dataDialogVisible" :dataDialogVisible="dataDialogVisible" |
| | | :dataLookInfo="dataLookInfo" @closeDataLook="closeDataLook"></data-look-visible> |
| | | <!--éä»¶æ¥çå¼¹æ¡--> |
| | | <files-look-visible v-if="filesDialogVisible" ref="filesDialogVisible" :filesDialogVisible="filesDialogVisible" |
| | | :filesLookInfo="filesLookInfo" @closeFilesLook="closeFilesLook"></files-look-visible> |
| | | <!--æ¥åä¸è½½å¼¹æ¡--> |
| | | <down-file-dialog v-if="downFileDialogVisible" ref="downFileDialogVisible" |
| | | :downFileDialogVisible="downFileDialogVisible" :downLoadInfo="downLoadInfo" |
| | | @closeDownFileDialog="closeDownFileDialog"></down-file-dialog> |
| | | <!--产ä¸é¾ä¿¡æ¯æ¥ç--> |
| | | <ShowInfo v-if="showInfoDialog" ref="showInfoDialog" :showInfoDialog="showInfoDialog"></ShowInfo> |
| | | <!--æ£éªä»»å¡ä¿¡æ¯æ¥ç--> |
| | | <el-dialog :visible.sync="InspectInfoDialog" title="æ°æ®æ¥ç" width="400px" @closed="closeInsInfoDialog"> |
| | | <div style="margin-bottom: 8px"> |
| | | <span style="font-size: 16px;">è¿åæ£éªåå§æ°æ®</span> |
| | | <el-link :disabled="!insInfo.enterOrderId" :underline="false" style="vertical-align: bottom;margin-left: 6px" |
| | | type="primary" @click="viewInsInfo0">æ¥ç</el-link> |
| | | </div> |
| | | <div> |
| | | <span style="font-size: 16px;">å£åº¦æ£éªåå§æ°æ®</span> |
| | | <el-link :disabled="!insInfo.quarterOrderId" :underline="false" style="vertical-align: bottom;margin-left: 6px" |
| | | type="primary" @click="viewInsInfo1">æ¥ç</el-link> |
| | | </div> |
| | | </el-dialog> |
| | | <!-- <Inspection v-if="state>0" :key="InspectionKey" :inspectorList="inspectorList" :orderId="orderId"--> |
| | | <!-- :sonLaboratory="'åææ'" :state="state"--> |
| | | <!-- :typeSource="typeSource"--> |
| | | <!-- @goback="goback" @refreshView="refreshView"/>--> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import PrintDialog from "@/views/business/materialOrderComponents/materialOrder/printDialog.vue"; |
| | | import ShowInfo from "@/views/business/materialOrderComponents/materialOrder/showInfo.vue"; |
| | | import DataLookVisible from "@/views/business/materialOrderComponents/materialOrder/dataLookVisible.vue"; |
| | | import FilesLookVisible from "@/views/business/materialOrderComponents/materialOrder/filesLookVisible.vue"; |
| | | import DownFileDialog from "@/views/business/materialOrderComponents/materialOrder/downFileDialog.vue"; |
| | | import limsTable from "@/components/Table/lims-table.vue"; |
| | | import { |
| | | getWarehouseSubmit, |
| | | concessionRelease, |
| | | getIfsByAll, |
| | | getIfsByOver, |
| | | getIfsByQuarter, |
| | | getIfsByStateOne, |
| | | rawAllExport, |
| | | rawOrderRelease, |
| | | repealEnterRawOrder, |
| | | repealQuarterRawOrder, |
| | | revokeInspectionReport, |
| | | updateEntrustCode |
| | | } from "@/api/business/outsourcingFinishProductInspection"; |
| | | import {mapGetters} from "vuex"; |
| | | |
| | | export default { |
| | | name: "MaterialOrder", |
| | | // import å¼å
¥çç»ä»¶éè¦æ³¨å
¥å°å¯¹è±¡ä¸æè½ä½¿ç¨ |
| | | components: { limsTable, DownFileDialog, FilesLookVisible, DataLookVisible, ShowInfo, PrintDialog }, |
| | | data() { |
| | | // è¿éåæ¾æ°æ® |
| | | return { |
| | | tableData: [], |
| | | tableLoading: false, |
| | | column: [ |
| | | { label: 'æ¹å·', prop: 'updateBatchNo' }, |
| | | { label: 'é¶ä»¶å·', prop: 'partNo' }, |
| | | { label: 'é¶ä»¶æè¿°', prop: 'partDesc' }, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return null |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return null |
| | | } |
| | | } |
| | | }, |
| | | { label: 'æµè¾¾çéè´æ°é', prop: 'purQtyInStore',width: '130px' }, |
| | | { label: 'åä½', prop: 'buyUnitMeas' }, |
| | | { label: '订åå·', prop: 'orderNo' }, |
| | | { label: 'æ¥æ¶æ¶é´', prop: 'receiverDate' }, |
| | | { label: 'æ¥æ£æ¶é´', prop: 'declareDate' }, |
| | | { |
| | | dataType: 'action', |
| | | label: 'æä½', |
| | | operation: [ |
| | | { |
| | | name: 'ä¸å', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.playOrder(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'å
æ£', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.exemption(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ¤éæ¥æ£', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.cancelDeclare(row); |
| | | }, |
| | | }, |
| | | ] |
| | | } |
| | | ], |
| | | page: { |
| | | total: 0, |
| | | size: 20, |
| | | current: 1 |
| | | }, |
| | | tableData1: [], |
| | | tableLoading1: false, |
| | | column1: [ |
| | | { label: 'æ¹å·', prop: 'updateBatchNo' }, |
| | | { |
| | | label: 'å§æç¼å·', |
| | | prop: 'entrustCode', |
| | | width: "160px", |
| | | dataType: "link", |
| | | linkMethod: "changeEntrustCode", |
| | | }, |
| | | { label: 'é¶ä»¶å·', prop: 'partNo' }, |
| | | { label: 'é¶ä»¶æè¿°', prop: 'partDesc' }, |
| | | { |
| | | label: 'æ ·ååç§°', |
| | | prop: 'sampleName', |
| | | width: "160px", |
| | | dataType: "link", |
| | | linkMethod: "selectAllByOne", |
| | | }, |
| | | { label: 'æ ·ååå·', prop: 'sampleModel' }, |
| | | { label: 'æ£éªäºº', prop: 'userName' }, |
| | | { label: 'ä¸åæ¶é´', prop: 'sendTime' }, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return null |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return null |
| | | } |
| | | } |
| | | }, |
| | | { label: 'æµè¾¾çéè´æ°é', prop: 'purQtyInStore',width: '130px' }, |
| | | { label: 'åä½', prop: 'buyUnitMeas' }, |
| | | { label: '订åå·', prop: 'orderNo' }, |
| | | { label: 'æ¥æ¶æ¶é´', prop: 'receiverDate' }, |
| | | { label: 'æ¥æ£æ¶é´', prop: 'declareDate' }, |
| | | { |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | operation: [ |
| | | { |
| | | name: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleDataLook(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleFileLook(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ¤éä¸å', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.cancelOrder(row); |
| | | }, |
| | | }, |
| | | ] |
| | | } |
| | | ], |
| | | page1: { |
| | | total: 0, |
| | | size: 20, |
| | | current: 1 |
| | | }, |
| | | tableData2: [], |
| | | tableLoading2: false, |
| | | column2: [ |
| | | { |
| | | label: 'å§æç¼å·', |
| | | prop: 'entrustCode', |
| | | width: "160px", |
| | | dataType: "link", |
| | | linkMethod: "changeEntrustCode", |
| | | }, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'æ£éªç¶æ', |
| | | prop: 'inspectStatus', |
| | | formatData: (params) => { |
| | | if (params == 0) { |
| | | return 'æ£éªä¸' |
| | | } else if (params == 1) { |
| | | return 'åæ ¼' |
| | | } else if (params == 2) { |
| | | return 'ä¸åæ ¼' |
| | | } else if (params == 3) { |
| | | return 'æªä¸å' |
| | | } else if (params == 4) { |
| | | return 'è®©æ¥æ¾è¡' |
| | | } else { |
| | | return null |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 0) { |
| | | return 'warning' |
| | | } else if (params == 1) { |
| | | return 'success' |
| | | } else if (params == 2) { |
| | | return 'danger' |
| | | } else if (params == 3) { |
| | | return 'info' |
| | | } else if (params == 4) { |
| | | return '' |
| | | } else { |
| | | return null |
| | | } |
| | | } |
| | | }, |
| | | { label: '订åå·', prop: 'orderNo' }, |
| | | { label: 'æµè¾¾çéè´æ°é', prop: 'purQtyInStore',width: '130px' }, |
| | | { label: 'ä¸åæ¶é´', prop: 'sendTime' }, |
| | | { label: 'æ¹å·', prop: 'updateBatchNo' }, |
| | | { label: 'é¶ä»¶å·', prop: 'partNo' }, |
| | | { label: 'é¶ä»¶æè¿°', prop: 'partDesc' }, |
| | | { label: 'ä¾åºååç§°', prop: 'supplierName' }, |
| | | { label: 'ä¸åæ ¼æè¿°', prop: 'unqualifiedDesc' }, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'å
æ£', |
| | | prop: 'isExemption', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'å
æ£' |
| | | } else { |
| | | return null |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'success' |
| | | } else { |
| | | return null |
| | | } |
| | | } |
| | | }, |
| | | { |
| | | label: 'æ ·ååç§°', |
| | | prop: 'sampleName', |
| | | width: "160px", |
| | | dataType: "link", |
| | | linkMethod: "selectAllByOne", |
| | | }, |
| | | { label: 'æ ·ååå·', prop: 'sampleModel' }, |
| | | { label: 'æ£éªäºº', prop: 'userName' }, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return null |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return null |
| | | } |
| | | } |
| | | }, |
| | | { label: 'åä½', prop: 'buyUnitMeas' }, |
| | | { label: 'æ¥æ¶æ¶é´', prop: 'receiverDate' }, |
| | | { label: 'æ¥æ£æ¶é´', prop: 'declareDate' }, |
| | | { |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | operation: [ |
| | | { |
| | | name: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleDataLook(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleFileLook(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'æ¥åä¸è½½', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.download(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'åå§è®°å½', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.viewInspectInfo(row); |
| | | }, |
| | | disabled: (row) => { |
| | | return row.sampleName === null |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ¾è¡', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.goPass(row); |
| | | }, |
| | | disabled: (row) => { |
| | | return row.inspectStatus != 2 |
| | | }, |
| | | showHide: (row) => { |
| | | return this.checkPermi([ |
| | | "get:raw:check:operation", |
| | | ]); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'å£åº¦æ¤é', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.repealQuarter(row); |
| | | }, |
| | | disabled: (row) => { |
| | | return row.quarterOrderId == null || row.quarterReportId != null |
| | | }, |
| | | showHide: (row) => { |
| | | return this.checkPermi([ |
| | | "get:raw:check:operation", |
| | | ]); |
| | | }, |
| | | }, |
| | | ] |
| | | } |
| | | ], |
| | | page2: { |
| | | total: 0, |
| | | size: 20, |
| | | current: 1 |
| | | }, |
| | | tableData3: [], |
| | | tableLoading3: false, |
| | | column3: [ |
| | | { label: 'å§æç¼å·', prop: 'entrustCode',width: "160px", }, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'æ£éªç¶æ', |
| | | prop: 'inspectStatus', |
| | | formatData: (params) => { |
| | | if (params == 0) { |
| | | return 'æ£éªä¸' |
| | | } else if (params == 1) { |
| | | return 'åæ ¼' |
| | | } else if (params == 2) { |
| | | return 'ä¸åæ ¼' |
| | | } else if (params == 3) { |
| | | return 'æªä¸å' |
| | | } else if (params == 4) { |
| | | return 'è®©æ¥æ¾è¡' |
| | | } else { |
| | | return null |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 0) { |
| | | return 'warning' |
| | | } else if (params == 1) { |
| | | return 'success' |
| | | } else if (params == 2) { |
| | | return 'danger' |
| | | } else if (params == 3) { |
| | | return 'info' |
| | | } else if (params == 4) { |
| | | return '' |
| | | } else { |
| | | return null |
| | | } |
| | | } |
| | | }, |
| | | { label: '订åå·', prop: 'orderNo' }, |
| | | { label: 'æµè¾¾çéè´æ°é', prop: 'purQtyInStore',width: '130px' }, |
| | | { label: 'ä¸åæ¶é´', prop: 'sendTime' }, |
| | | { label: 'æ¹å·', prop: 'updateBatchNo' }, |
| | | { label: 'é¶ä»¶å·', prop: 'partNo' }, |
| | | { label: 'é¶ä»¶æè¿°', prop: 'partDesc' }, |
| | | { label: 'ä¾åºååç§°', prop: 'supplierName' }, |
| | | { label: 'ä¸åæ ¼æè¿°', prop: 'unqualifiedDesc' }, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'å
æ£', |
| | | prop: 'isExemption', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'å
æ£' |
| | | } else { |
| | | return null |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'success' |
| | | } else { |
| | | return null |
| | | } |
| | | } |
| | | }, |
| | | { |
| | | label: 'æ ·ååç§°', |
| | | prop: 'sampleName', |
| | | width: "160px", |
| | | dataType: "link", |
| | | linkMethod: "selectAllByOne", |
| | | }, |
| | | { label: 'æ ·ååå·', prop: 'sampleModel' }, |
| | | { label: 'æ£éªäºº', prop: 'userName' }, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return null |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return null |
| | | } |
| | | } |
| | | }, |
| | | { label: 'åä½', prop: 'buyUnitMeas' }, |
| | | { label: 'æ¥æ¶æ¶é´', prop: 'receiverDate' }, |
| | | { label: 'æ¥æ£æ¶é´', prop: 'declareDate' }, |
| | | { |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | operation: [ |
| | | { |
| | | name: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleDataLook(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleFileLook(row); |
| | | }, |
| | | } |
| | | ] |
| | | } |
| | | ], |
| | | page3: { |
| | | total: 0, |
| | | size: 20, |
| | | current: 1 |
| | | }, |
| | | entity: { |
| | | updateBatchNo: null, |
| | | entrustCode: null, |
| | | partDesc: null, |
| | | supplierName: null, |
| | | sampleModel: null, |
| | | partNo: null, |
| | | inspectStatus: null, |
| | | date: null, |
| | | beginDeclareDate: null, |
| | | endDeclareDate: null, |
| | | }, |
| | | tabList: [ |
| | | { |
| | | label: 'å¾
ä¸å', |
| | | value: 0 |
| | | }, |
| | | { |
| | | label: 'æ£éªä¸', |
| | | value: 1 |
| | | }, |
| | | { |
| | | label: 'å·²æ£éª', |
| | | value: 2 |
| | | }, |
| | | { |
| | | label: 'å£åº¦æ£éª', |
| | | value: 4 |
| | | }, |
| | | { |
| | | label: 'å
¨é¨', |
| | | value: 3 |
| | | } |
| | | ], |
| | | more: false, |
| | | tabIndex: '', |
| | | multipleSelection: [], |
| | | active: 0, //1ï¼ä¸åï¼2ï¼æ¥ç |
| | | orderType: 0, //0ï¼åææä¸åï¼1ï¼å£åº¦æ£éªä¸å |
| | | currentId: null, |
| | | btnLoading: false, |
| | | quashDialogVisible: false, // æ¤éä¸åæéå¼¹æ¡ |
| | | declareDialogVisible: false, // æ¤éæ¥æ£æéå¼¹æ¡ |
| | | insOrderRow: {}, |
| | | upLoad: false, |
| | | filesDialogVisible: false, // éä»¶æ¥çå¼¹æ¡ |
| | | printDialog: false, // æ ç¾æå°å¼¹æ¡ |
| | | showInfoDialog: false, // 产ä¸é¾ä¿¡æ¯æ¥ç |
| | | dataDialogVisible: false, // æ°æ®æ¥çå¼¹æ¡ |
| | | dataLookInfo: {}, // æ°æ®æ¥çå¼¹æ¡æ°æ® |
| | | filesLookInfo: {}, // éä»¶æ¥çå¼¹æ¡æ°æ® |
| | | downFileDialogVisible: false, // æ¥åä¸è½½å¼¹æ¡ |
| | | downLoadInfo: {}, // æ¥åä¸è½½å¼¹æ¡ |
| | | entrustCodeVisible: false, // ä¿®æ¹å§æç¼å·å¼¹æ¡ |
| | | entrustCodeInfo: {}, |
| | | submitCodeLoading: false, |
| | | exemptionVisible: false, // å
æ£ç¡®è®¤å¼¹æ¡ |
| | | exemptionLoading: false, |
| | | exemptionInfo: {}, |
| | | inspectStatusList: [ |
| | | { label: 'æ£éªä¸', value: 0 }, |
| | | { label: 'åæ ¼', value: 1 }, |
| | | { label: 'ä¸åæ ¼', value: 2 }, |
| | | { label: 'æªä¸å', value: 3 }, |
| | | { label: 'è®©æ¥æ¾è¡', value: 4 }, |
| | | ], |
| | | state: 0, |
| | | orderId: 0, |
| | | inspectorList: [],//æ£éªäººåå表 |
| | | InspectionKey: 1, |
| | | typeSource: null,// 0:æåä¸åï¼1ï¼åææä¸å, 2: éåä¸ä¸å |
| | | InspectInfoDialog: false, // æ°æ®æ¥çå¼¹æ¡ |
| | | insInfo: {}, |
| | | outLoading: false |
| | | } |
| | | }, |
| | | computed: { |
| | | ...mapGetters(['nickName']) |
| | | }, |
| | | mounted() { |
| | | if (this.checkPermi(['get:raw:await'])) { |
| | | this.tabIndex = 0 |
| | | } else { |
| | | this.tabIndex = 2 |
| | | } |
| | | this.refreshTable() |
| | | }, |
| | | activated () { |
| | | this.refreshTable() |
| | | }, |
| | | // æ¹æ³éå |
| | | methods: { |
| | | // ç¹å»æ¥è¯¢åè° |
| | | goSearch() { |
| | | this.page.current = 1 |
| | | this.page1.current = 1 |
| | | this.page2.current = 1 |
| | | this.page3.current = 1 |
| | | this.refreshTable() |
| | | }, |
| | | // æ¥è¯¢åè° |
| | | refreshTable() { |
| | | if (this.tabIndex === 0) { |
| | | // å¾
ä¸åæ¥è¯¢ |
| | | this.getPurchaseOrderList() |
| | | } else if (this.tabIndex === 1) { |
| | | // æ£éªä¸æ¥è¯¢ |
| | | this.getIfsByStateOneList() |
| | | } else if (this.tabIndex === 2) { |
| | | // å·²æ£éªæ¥è¯¢ |
| | | this.getIfsByOverList() |
| | | } else if (this.tabIndex === 4) { |
| | | // æ¥è¯¢å£åº¦æ£éª |
| | | this.getIfsByQuarterList() |
| | | } else { |
| | | // å
¨é¨æ¥è¯¢ |
| | | this.getIfsByAllList() |
| | | } |
| | | }, |
| | | // å¾
ä¸åæ¥è¯¢ |
| | | getPurchaseOrderList() { |
| | | this.tableLoading = true |
| | | const params = { ...this.entity, isInspect: 1, state: 0, ...this.page } |
| | | getWarehouseSubmit(params).then(res => { |
| | | this.tableLoading = false |
| | | if (res.code === 200) { |
| | | this.tableData = res.data.records |
| | | this.page.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading = false |
| | | }) |
| | | }, |
| | | // æ£éªä¸æ¥è¯¢ |
| | | getIfsByStateOneList() { |
| | | this.tableLoading1 = true |
| | | const params = { ...this.entity, orderState: 1, state: 1, ...this.page1 } |
| | | getIfsByStateOne(params).then(res => { |
| | | this.tableLoading1 = false |
| | | if (res.code === 200) { |
| | | this.tableData1 = res.data.records |
| | | this.page1.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading1 = false |
| | | }) |
| | | }, |
| | | // å·²æ£éªæ¥è¯¢ |
| | | getIfsByOverList() { |
| | | this.tableLoading2 = true |
| | | if(null != this.entity.date){ |
| | | this.entity.beginDeclareDate = this.entity.date[0] |
| | | this.entity.endDeclareDate = this.entity.date[1] |
| | | } else { |
| | | this.entity.beginDeclareDate = '' |
| | | this.entity.endDeclareDate = '' |
| | | } |
| | | const params = { ...this.entity, orderState: 4, state: 2, ...this.page2 } |
| | | getIfsByOver(params).then(res => { |
| | | this.tableLoading2 = false |
| | | if (res.code === 200) { |
| | | this.tableData2 = res.data.records |
| | | this.page2.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading2 = false |
| | | }) |
| | | }, |
| | | // æ¥è¯¢å£åº¦æ£éª |
| | | getIfsByQuarterList() { |
| | | this.tableLoading4 = true |
| | | if(null != this.entity.date){ |
| | | this.entity.beginDeclareDate = this.entity.date[0] |
| | | this.entity.endDeclareDate = this.entity.date[1] |
| | | } else { |
| | | this.entity.beginDeclareDate = '' |
| | | this.entity.endDeclareDate = '' |
| | | } |
| | | const params = { ...this.entity, ...this.page4 } |
| | | getIfsByQuarter(params).then(res => { |
| | | this.tableLoading4 = false |
| | | if (res.code === 200) { |
| | | this.tableData4 = res.data.records |
| | | this.page4.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading4 = false |
| | | }) |
| | | }, |
| | | // å
¨é¨ |
| | | getIfsByAllList() { |
| | | this.tableLoading3 = true |
| | | if(null != this.entity.date){ |
| | | this.entity.beginDeclareDate = this.entity.date[0] |
| | | this.entity.endDeclareDate = this.entity.date[1] |
| | | } else { |
| | | this.entity.beginDeclareDate = '' |
| | | this.entity.endDeclareDate = '' |
| | | } |
| | | const params = { ...this.entity, isInspect: 1, ...this.page3 } |
| | | getIfsByAll(params).then(res => { |
| | | this.tableLoading3 = false |
| | | if (res.code === 200) { |
| | | this.tableData3 = res.data.records |
| | | this.page3.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading3 = false |
| | | }) |
| | | }, |
| | | // é ç½® |
| | | refresh() { |
| | | this.resetForm('entity') |
| | | this.refreshTable() |
| | | }, |
| | | pagination(page) { |
| | | this.page.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | pagination1(page) { |
| | | this.page1.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | pagination2(page) { |
| | | this.page2.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | pagination3(page) { |
| | | this.page3.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | pagination4(page) { |
| | | this.page4.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | // æ¥çæ£éªæ°æ® |
| | | viewInspectInfo(row) { |
| | | //å½åæ£éªä»»å¡çæ£éªäººå表 |
| | | let inspectorList = [] |
| | | if (row.userName) { |
| | | inspectorList = row.userName.split(',') |
| | | } |
| | | inspectorList.push(this.nickName) |
| | | this.inspectorList = inspectorList |
| | | this.insInfo = row |
| | | this.InspectInfoDialog = true |
| | | }, |
| | | closeInsInfoDialog() { |
| | | this.InspectInfoDialog = false |
| | | }, |
| | | // ç´æ¥æ¾è¡ |
| | | goPass(row) { |
| | | this.$confirm('æ¯å¦æ¾è¡å½åæ°æ®?', 'æç¤º', { |
| | | confirmButtonText: 'ç¡®å®', |
| | | cancelButtonText: 'åæ¶', |
| | | type: 'warning' |
| | | }).then(() => { |
| | | concessionRelease({ ifsInventoryId: row.id }).then(res => { |
| | | if (res.code === 200) { |
| | | this.$message({ |
| | | type: 'success', |
| | | message: 'æ¾è¡æå!' |
| | | }); |
| | | this.refresh() |
| | | } |
| | | }) |
| | | }).catch(() => { |
| | | this.$message({ |
| | | type: 'error', |
| | | message: 'æ¾è¡å¤±è´¥' |
| | | }); |
| | | }); |
| | | }, |
| | | // å£åº¦æ¤é |
| | | repealQuarter(row) { |
| | | this.$confirm('æ¯å¦æ¤éå£åº¦ä¸å?', "è¦å", { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning" |
| | | }).then(() => { |
| | | repealQuarterRawOrder({ quarterOrderId: row.quarterOrderId }).then(res => { |
| | | if (res.code === 200) { |
| | | this.$message.success('æ¤éæå') |
| | | this.refreshTable('page') |
| | | } |
| | | }) |
| | | }).catch(() => { }) |
| | | }, |
| | | viewInsInfo0() { |
| | | let inspectorList = [] |
| | | inspectorList.push(this.nickName) |
| | | this.InspectInfoDialog = false |
| | | if (this.checkPermi(['business:inspectionView'])) { |
| | | this.$router.push({ |
| | | name: "InspectionView", |
| | | query: { |
| | | sonLaboratory: 'åææ', |
| | | state: 3, |
| | | typeSource: this.insInfo.typeSource, |
| | | orderId: this.insInfo.enterOrderId, |
| | | inspectorList: inspectorList, |
| | | }, |
| | | }) |
| | | } else { |
| | | this.$router.push({ |
| | | path: "/inspectionTask/inspection", |
| | | query: { |
| | | sonLaboratory: 'åææ', |
| | | state: 3, |
| | | typeSource: this.insInfo.typeSource, |
| | | orderId: this.insInfo.enterOrderId, |
| | | inspectorList: inspectorList, |
| | | }, |
| | | }) |
| | | } |
| | | }, |
| | | viewInsInfo1() { |
| | | let inspectorList = [] |
| | | inspectorList.push(this.nickName) |
| | | this.InspectInfoDialog = false |
| | | if (this.checkPermi(['business:inspectionView'])) { |
| | | this.$router.push({ |
| | | name: "InspectionView", |
| | | query: { |
| | | sonLaboratory: 'åææ', |
| | | state: 3, |
| | | typeSource: this.insInfo.typeSource, |
| | | orderId: this.insInfo.quarterOrderId, |
| | | inspectorList: inspectorList, |
| | | }, |
| | | }) |
| | | } else { |
| | | this.$router.push({ |
| | | path: "/inspectionTask/inspection", |
| | | query: { |
| | | sonLaboratory: 'åææ', |
| | | state: 3, |
| | | typeSource: this.insInfo.typeSource, |
| | | orderId: this.insInfo.quarterOrderId, |
| | | inspectorList: inspectorList, |
| | | }, |
| | | }) |
| | | } |
| | | }, |
| | | goback() { |
| | | this.state = 0 |
| | | this.refreshTable('page') |
| | | }, |
| | | // å·æ°é¡µé¢ |
| | | refreshView() { |
| | | this.InspectionKey++ |
| | | }, |
| | | // éææä¸å |
| | | copper() { |
| | | this.$router.push({ path: "/materialOrder/copperOrder", query: { active: 1 } }); |
| | | }, |
| | | // æå¼æ ç¾æå°å¼¹æ¡ |
| | | openPrint() { |
| | | if (this.multipleSelection.length > 0) { |
| | | this.printDialog = true |
| | | this.$nextTick(() => { |
| | | let selection = this.multipleSelection |
| | | this.$refs.printDialog.getLabelPrinting(selection) |
| | | }) |
| | | } else { |
| | | this.$message.error('è¯·éæ©éè¦æå°çæ°æ®') |
| | | } |
| | | }, |
| | | // å
³éæ ç¾æå°å¼¹æ¡ |
| | | closePrintDialog() { |
| | | this.printDialog = false |
| | | }, |
| | | // ä¸å |
| | | playOrder(row) { |
| | | this.$router.push({ path: "/outsourcingFinishProduct/customsInspectionOrder", query: {isOutsourcing:'t', orderType: 0, customsInspection: row, active: 1 } }); |
| | | }, |
| | | // ç¹å»æ ·ååç§°æ¥ç详æ
|
| | | selectAllByOne(row) { |
| | | if (row.isCopper == 1) { |
| | | this.currentId = row.enterOrderId |
| | | this.$router.push({ path: "/materialOrder/CopperView", query: { customsInspection: row, active: 2, currentId: this.currentId } }); |
| | | } else { |
| | | this.currentId = row.insOrderId |
| | | this.$router.push({ path: "/materialOrder/customsInspectionView", query: { customsInspection: row, active: 2, currentId: this.currentId } }); |
| | | } |
| | | }, |
| | | // æå¼å
æ£å¼¹æ¡ |
| | | exemption(row) { |
| | | this.exemptionVisible = true |
| | | this.exemptionInfo = row |
| | | this.$set(this.exemptionInfo, 'partDetail', row.partDesc) |
| | | }, |
| | | // æäº¤å
æ£ä¿¡æ¯ |
| | | submitExemption() { |
| | | this.exemptionLoading = true |
| | | rawOrderRelease({ |
| | | ifsInventoryId: this.exemptionInfo.id, |
| | | partDetail: this.exemptionInfo.partDetail |
| | | }).then(res => { |
| | | if (res.code === 200) { |
| | | this.exemptionVisible = false |
| | | this.$message.success('æä½æå') |
| | | this.refresh() |
| | | } |
| | | this.exemptionLoading = false |
| | | }).catch(err => { |
| | | console.log(err) |
| | | this.exemptionLoading = false |
| | | }) |
| | | }, |
| | | // æå¼æ¤éæ¥æ£å¼¹æ¡ |
| | | cancelDeclare(row) { |
| | | this.declareDialogVisible = true |
| | | this.insOrderRow = row |
| | | }, |
| | | // æäº¤æ¤éæ¥æ£ç³è¯· |
| | | submitDeclare() { |
| | | revokeInspectionReport({ id: this.insOrderRow.id }).then(res => { |
| | | if (res.code === 200) { |
| | | this.declareDialogVisible = false |
| | | this.refreshTable() |
| | | this.$message.success("æ¤éæ¥æ£æå") |
| | | } |
| | | }).catch(err => { |
| | | console.log(err) |
| | | }) |
| | | }, |
| | | // æå¼æ¤éä¸åçå¼¹æ¡ |
| | | cancelOrder(row) { |
| | | if (row.enterOrderId && row.quarterOrderId) { |
| | | this.quashDialogVisible = true |
| | | } else if (row.enterOrderId && !row.quarterOrderId) { |
| | | this.$confirm('æ¯å¦æ¤éè¿åä¸å?', "è¦å", { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning" |
| | | }).then(() => { |
| | | repealEnterRawOrder({ enterOrderId: row.enterOrderId }).then(res => { |
| | | if (res.code === 200) { |
| | | this.$message.success('æ¤éæå') |
| | | this.refreshTable('page') |
| | | } |
| | | }) |
| | | }).catch(() => { }) |
| | | } else if (!row.enterOrderId && row.quarterOrderId) { |
| | | this.$confirm('æ¯å¦æ¤éå£åº¦ä¸å?', "è¦å", { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning" |
| | | }).then(() => { |
| | | repealQuarterRawOrder({ quarterOrderId: row.quarterOrderId }).then(res => { |
| | | if (res.code === 200) { |
| | | this.$message.success('æ¤éæå') |
| | | this.refreshTable('page') |
| | | } |
| | | }) |
| | | }).catch(() => { }) |
| | | } |
| | | this.insOrderRow = row |
| | | }, |
| | | cancelQuashOrder(type) { |
| | | if (type === 'enterOrderId') { |
| | | this.$confirm('æ¯å¦æ¤éå½åæ°æ®?', "è¦å", { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning" |
| | | }).then(() => { |
| | | repealEnterRawOrder({ enterOrderId: this.insOrderRow.enterOrderId }).then(res => { |
| | | if (res.code === 200) { |
| | | this.$message.success('æ¤éæå') |
| | | this.refreshTable('page') |
| | | } |
| | | }) |
| | | }).catch(() => { }) |
| | | } else { |
| | | this.$confirm('æ¯å¦æ¤éå½åæ°æ®?', "è¦å", { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning" |
| | | }).then(() => { |
| | | repealQuarterRawOrder({ quarterOrderId: this.insOrderRow.quarterOrderId }).then(res => { |
| | | if (res.code === 200) { |
| | | this.$message.success('æ¤éæå') |
| | | this.refreshTable() |
| | | } |
| | | }) |
| | | }).catch(() => { }) |
| | | } |
| | | }, |
| | | // æ°æ®æ¥ç |
| | | handleDataLook(row) { |
| | | this.dataLookInfo = row |
| | | this.dataDialogVisible = true; |
| | | }, |
| | | // å
³éæ°æ®æ¥çå¼¹æ¡ |
| | | closeDataLook() { |
| | | this.dataDialogVisible = false |
| | | }, |
| | | // éä»¶æ¥ç |
| | | handleFileLook(row) { |
| | | this.filesDialogVisible = true |
| | | this.filesLookInfo = row |
| | | }, |
| | | // å
³ééä»¶æ¥çå¼¹æ¡ |
| | | closeFilesLook() { |
| | | this.filesDialogVisible = false |
| | | }, |
| | | // æ¥åä¸è½½ |
| | | download(row) { |
| | | this.downFileDialogVisible = true |
| | | this.downLoadInfo = row |
| | | }, |
| | | // å
³éæ¥åä¸è½½å¼¹æ¡ |
| | | closeDownFileDialog() { |
| | | this.downFileDialogVisible = false |
| | | }, |
| | | // æ¥ç产ä¸é¾ä¿¡æ¯ |
| | | openInfoDialog(row) { |
| | | this.showInfoDialog = true |
| | | this.$nextTick(() => { |
| | | this.$refs.showInfoDialog.getInfo(row.id) |
| | | }) |
| | | }, |
| | | // ä¿®æ¹å§æç¼å· |
| | | changeEntrustCode(row) { |
| | | this.entrustCodeVisible = true |
| | | this.entrustCodeInfo = { ...row } |
| | | }, |
| | | // å¯¼åº |
| | | handleOut() { |
| | | this.outLoading = true |
| | | let params = {} |
| | | if (this.multipleSelection.length > 0) { |
| | | params.ids = this.multipleSelection.map(item => item.id).join(','); |
| | | } else { |
| | | params = {...this.entity} |
| | | } |
| | | rawAllExport(params).then(res => { |
| | | this.outLoading = false |
| | | const blob = new Blob([res], { type: 'application/octet-stream' }); |
| | | this.$download.saveAs(blob, 'åæææ£æµä¿¡æ¯å¯¼åº.xlsx'); |
| | | }) |
| | | }, |
| | | // æäº¤ä¿®æ¹å§æç¼å·ä¿¡æ¯ |
| | | submitCode() { |
| | | this.submitCodeLoading = true |
| | | try { |
| | | updateEntrustCode({ |
| | | id: this.entrustCodeInfo.id, |
| | | entrustCode: this.entrustCodeInfo.entrustCode, |
| | | }).then(res => { |
| | | if (res.code === 200) { |
| | | this.entrustCodeVisible = false |
| | | this.$message.success('ä¿®æ¹æå') |
| | | } |
| | | this.refreshTable() |
| | | this.submitCodeLoading = false |
| | | }) |
| | | } catch (e) { |
| | | this.submitCodeLoading = false |
| | | } |
| | | }, |
| | | // 忢ä¸åtabè¡¨æ ¼ |
| | | handleTab(m) { |
| | | this.tabIndex = m; |
| | | this.multipleSelection = [] |
| | | this.refreshTable() |
| | | }, |
| | | // è¡¨æ ¼éæ©æ¹æ³ |
| | | selectMethod(val) { |
| | | this.multipleSelection = val |
| | | }, |
| | | changeRowClass({ row, rowIndex }) { |
| | | if (row.isFirst == 1) { |
| | | return 'highlight-danger-row-border' |
| | | } |
| | | return '' |
| | | }, |
| | | }, |
| | | } |
| | | </script> |
| | | |
| | | <style scoped> |
| | | .table-tab { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | } |
| | | |
| | | .tab { |
| | | list-style-type: none; |
| | | display: flex; |
| | | margin-bottom: 12px; |
| | | margin-top: 0; |
| | | padding-left: 0; |
| | | } |
| | | |
| | | .tab li { |
| | | line-height: 24px; |
| | | padding: 6px 14px; |
| | | font-size: 14px; |
| | | color: #333333; |
| | | border: 1px solid #EEEEEE; |
| | | cursor: pointer; |
| | | } |
| | | |
| | | .tab li:nth-child(1) { |
| | | border-radius: 8px 0 0 8px; |
| | | } |
| | | |
| | | .tab li:nth-child(4) { |
| | | border-radius: 0 8px 8px 0; |
| | | } |
| | | |
| | | .tab li.active { |
| | | border-color: #3A7BFA; |
| | | color: #3A7BFA; |
| | | } |
| | | </style> |
| | |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="éå®è®¢ååç±»" prop="orderType" v-if="(tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-select v-model="componentData.orderType" clearable size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | <el-option v-for="(item,index) in orderTypeList" :label="item.dictLabel" :value="item.dictValue" :key="index"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-row> |
| | | </el-form> |
| | | </div> |
| | |
| | | @click="handleDown">导åº</el-button> |
| | | <el-button v-if="tabIndex === 0" :loading="btnLoading" size="small" type="primary" |
| | | @click="openIFS">è·åIFS订å</el-button> |
| | | <el-button v-if="tabIndex === 0" size="small" type="primary" @click="declareS">æ¥æ£</el-button> |
| | | <el-button v-if="tabIndex === 0" size="small" type="primary" @click="declareS">æ¹éæ¥æ£</el-button> |
| | | <el-button v-if="tabIndex === 0" size="small" type="primary" @click="addDeclare">æ°å¢æ¥æ£ä¿¡æ¯</el-button> |
| | | </div> |
| | | </div> |
| | |
| | | </div> |
| | | </div> |
| | | <!-- æ¹éæ¥æ£ --> |
| | | <el-dialog :visible.sync="declareDialogSVisible" title="ç¡®è®¤æ¥æ£" width="30%"> |
| | | <p style="font-size:16px;color:#333333">æ¯å¦ç¡®è®¤æ¥æ£éæ©çæ°æ®ï¼</p> |
| | | <el-dialog :visible.sync="declareDialogSVisible" title="æ¹éæ¥æ£" width="30%" :before-close="resetBatchFormData"> |
| | | <el-form ref="declareBatchObj" :inline="true" :model="declareBatchObj" :rules="declareObjBatchRules" label-width="130px" |
| | | label-position="right"> |
| | | <el-form-item class="declareObj-form-item" label="éå®è®¢ååç±»ï¼" prop="orderType"> |
| | | <el-select v-model="declareBatchObj.orderType" prop="orderType" clearable size="small"> |
| | | <el-option v-for="(item,index) in orderTypeList" :value="item.dictValue" :label="item.dictLabel" :key="index"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-form> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-row> |
| | | <el-button @click="declareDialogSVisible = false">å æ¶</el-button> |
| | | <el-button @click="resetBatchFormData()">å æ¶</el-button> |
| | | <el-button :loading="submitDeclareLoading" type="primary" @click="submitDeclareS">ç¡® å®</el-button> |
| | | </el-row> |
| | | </span> |
| | | </el-dialog> |
| | | <!-- ç¡®è®¤æ¥æ£ --> |
| | | <el-dialog :close-on-click-modal="false" :title="declareType === 'add' ? 'æ°å¢æ¥æ£ä¿¡æ¯' : 'åæææ¥æ£'" |
| | | <el-dialog :close-on-click-modal="false" :title="declareType === 'add' ? 'æ°å¢æ¥æ£ä¿¡æ¯' : 'éå®è®¢åæ¥æ£'" |
| | | :visible.sync="declareDialogVisible" width="800px" @close="resetFormData"> |
| | | <el-form ref="declareObj" :inline="true" :model="declareObj" :rules="declareObjRules" label-width="130px" |
| | | label-position="right"> |
| | |
| | | <el-select v-model="declareObj.isExpire" prop="isExpire" :disabled="declareType !== 'add'" clearable |
| | | size="small"> |
| | | <el-option :value="1" label="è¿æç©æ"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item class="declareObj-form-item" label="éå®è®¢ååç±»ï¼" prop="orderType"> |
| | | <el-select v-model="declareObj.orderType" clearable size="small"> |
| | | <el-option v-for="(item,index) in orderTypeList" :value="item.dictValue" :label="item.dictLabel" :key="index"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-form> |
| | |
| | | addIfsInventoryQuantity, |
| | | advancedGodown, |
| | | concessionRelease, delIfsInventory, |
| | | getIfsByAll, |
| | | getIfsByFinish, |
| | | getIfsOrder, |
| | | getWarehouseSubmit, inspectionReport, inspectionReportOne, rawAllExport, |
| | | revokeInspectionReport,downloadTemplate,confirmSplitOrder |
| | | } from '@/api/business/materialInspection' |
| | | import { |
| | | getIfsByAll, |
| | | getIfsByFinish, |
| | | } from '@/api/business/ifsOrderInspection' |
| | | import { getDicts } from "@/api/system/dict/data"; |
| | | import limsTable from "@/components/Table/lims-table.vue"; |
| | | import {transformExcel} from '@/utils/file' |
| | | |
| | |
| | | data() { |
| | | // è¿éåæ¾æ°æ® |
| | | return { |
| | | declareBatchObj:{ |
| | | orderType:'' |
| | | }, |
| | | declareObjBatchRules:{ |
| | | orderType: [ |
| | | { required: true, message: 'è¯·éæ©éå®è®¢ååç±»', trigger: 'change' } |
| | | ], |
| | | }, |
| | | confirmSplitOrderLoading: false, |
| | | detailDataLoading: false, |
| | | pushToMes:false,//æ¯å¦åæ¥å°mes |
| | |
| | | } |
| | | }, |
| | | { label: '订åå·', prop: 'orderNo' }, |
| | | { label: '订ååç±»', prop: 'orderTypeName' }, |
| | | { label: 'æµè¾¾çéè´æ°é', prop: 'purQtyInStore',width:'160px' }, |
| | | { label: 'æ¥æ£æ¶é´', prop: 'declareDate' }, |
| | | { label: 'æ¹å·', prop: 'updateBatchNo' }, |
| | |
| | | receiverDate: '', // æ¥æ¶æ¶é´ |
| | | buyUnitMeas: '', // åä½ |
| | | isExpire: '', // åä½ |
| | | orderType: null, // éå®è®¢ååç±» |
| | | }, |
| | | componentData: { // è¡¨æ ¼æ°æ® |
| | | updateBatchNo: null, |
| | |
| | | date: null, |
| | | entrustCode: '', |
| | | inspectStatus: '', |
| | | orderType: null, |
| | | }, |
| | | declareDialogVisible1: false, |
| | | upLoad: false, |
| | |
| | | buyUnitMeas: [ |
| | | { required: false, message: '请填ååä½', trigger: 'blur' } |
| | | ], |
| | | orderType: [ |
| | | { required: true, message: 'è¯·éæ©éå®è®¢ååç±»', trigger: 'change' } |
| | | ], |
| | | }, |
| | | tabList: [ |
| | | { |
| | |
| | | ], |
| | | outLoading: false, |
| | | upLoading: false, |
| | | orderTypeList: [], |
| | | } |
| | | }, |
| | | mounted() { |
| | | this.refreshTable() |
| | | this.getOrderTypeList() |
| | | }, |
| | | // æ¹æ³éå |
| | | methods: { |
| | | getOrderTypeList(){ |
| | | getDicts('inspection_type').then(res=>{ |
| | | if(res.code === 200){ |
| | | this.orderTypeList = res.data |
| | | } |
| | | }).catch(error=>{ |
| | | console.error(error) |
| | | }) |
| | | }, |
| | | resetOrderSplitData(){ |
| | | this.orderSplitBasicData = [] |
| | | this.orderSplitDetailData = [] |
| | |
| | | // 忢tabè¡¨æ ¼ |
| | | handleTab(m) { |
| | | this.tabIndex = m; |
| | | if([0,1].includes(this.tabIndex)){ |
| | | this.componentData.orderType = null |
| | | } |
| | | this.refreshTable() |
| | | }, |
| | | // æ¥è¯¢åè° |
| | |
| | | }, |
| | | // æäº¤æ¹éæ¥æ£ |
| | | submitDeclareS() { |
| | | let ids = [] |
| | | this.multipleSelection.forEach(item => { |
| | | ids.push(item.id) |
| | | }) |
| | | this.declareDialogSVisible = true |
| | | inspectionReport({ ids: ids }).then(res => { |
| | | if (res.code === 200) { |
| | | this.declareDialogSVisible = false |
| | | this.$message.success('æ¥æ£æå') |
| | | this.refreshTable() |
| | | this.$refs.declareBatchObj.validate(valid=>{ |
| | | if(valid){ |
| | | let ids = [] |
| | | this.multipleSelection.forEach(item => { |
| | | ids.push(item.id) |
| | | }) |
| | | this.declareDialogSVisible = true |
| | | inspectionReport({ |
| | | ids: ids, |
| | | orderType: this.declareBatchObj.orderType |
| | | }).then(res => { |
| | | if (res.code === 200) { |
| | | this.declareDialogSVisible = false |
| | | this.$message.success('æ¥æ£æå') |
| | | this.refreshTable() |
| | | } |
| | | this.submitDeclareLoading = false |
| | | }).catch(err => { |
| | | this.submitDeclareLoading = false |
| | | console.log(err) |
| | | }) |
| | | } |
| | | this.submitDeclareLoading = false |
| | | }).catch(err => { |
| | | this.submitDeclareLoading = false |
| | | console.log(err) |
| | | }) |
| | | }, |
| | | // æå¼æ¥æ£ç¡®è®¤å¼¹æ¡ |
| | |
| | | if (valid) { |
| | | inspectionReportOne({ |
| | | id: this.declareObj.id, |
| | | updateBatchNo: this.declareObj.updateBatchNo |
| | | updateBatchNo: this.declareObj.updateBatchNo, |
| | | orderType: this.declareObj.orderType |
| | | }).then(res => { |
| | | if (res.code === 200) { |
| | | this.declareDialogVisible = false |
| | |
| | | } |
| | | }, |
| | | resetFormData() { |
| | | this.$refs['declareObj'].resetFields(); |
| | | this.$refs.declareObj.resetFields(); |
| | | this.declareDialogVisible = false |
| | | }, |
| | | resetBatchFormData() { |
| | | this.$refs.declareBatchObj.resetFields(); |
| | | this.declareDialogSVisible = false |
| | | }, |
| | | // æå¼å é¤å¼¹æ¡ |
| | | deleteMaterial(row) { |
| | |
| | | receiverDate: '', // æ¥æ¶æ¶é´ |
| | | buyUnitMeas: '', // åä½ |
| | | isExpire: '', // åä½ |
| | | orderType: null, // éå®è®¢ååç±» |
| | | } |
| | | } |
| | | }, |
| | |
| | | scrollbar-width: none; |
| | | " @node-click="handleNodeClick" |
| | | @node-drop="handleDrop"> |
| | | <div slot-scope="{ node, data }" class="custom-tree-node"> |
| | | <el-row style="width: 100%"> |
| | | <el-col :class="{ sort: node.level > 3 }" :span="19" :title="data.label" style="text-align: left"> |
| | | <span> |
| | | <i :class="`node_i ${data.children != undefined |
| | | ? data.code === '[1]' |
| | | ? 'el-icon-folder-opened' |
| | | : 'el-icon-folder' |
| | | : 'el-icon-tickets' |
| | | }`"></i> |
| | | {{ data.label }} |
| | | </span> |
| | | </el-col> |
| | | <el-col v-if=" |
| | | checkPermi(['standard:standardLibrary:delStandardTree']) && |
| | | (node.data.children === null || |
| | | node.data.children === undefined) |
| | | " :span="2" style="text-align: right"> |
| | | <el-button size="mini" type="text" @click.stop="editTreeName(node.data)"> |
| | | <div slot-scope="{ node, data }" class="custom-tree-node" style="width: calc(100% - 15px)"> |
| | | <div style="display: flex;align-items: center;flex-wrap: nowrap;flex-direction: row;justify-content: space-between;"> |
| | | <div style="width: calc(100% - 50px);text-overflow: ellipsis;white-space: nowrap;" |
| | | :style="`overflow:${(node.data.children === null || node.data.children === undefined)?'clip':'visible'}`" |
| | | > |
| | | <i :class="`node_i ${data.children != undefined |
| | | ? data.code === '[1]' |
| | | ? 'el-icon-folder-opened' |
| | | : 'el-icon-folder' |
| | | : 'el-icon-tickets' |
| | | }`"></i> |
| | | {{data.label}} |
| | | </div> |
| | | <div v-if="(node.data.children === null || node.data.children === undefined)" style="width:50px"> |
| | | <el-button v-if="checkPermi(['standard:standardLibrary:delStandardTree'])" size="mini" type="text" @click.stop="editTreeName(node.data)"> |
| | | <i class="el-icon-edit"></i> |
| | | </el-button> |
| | | </el-col> |
| | | <el-col v-if=" |
| | | checkPermi(['standard:standardLibrary:delStandardTree']) && |
| | | (node.data.children === null || |
| | | node.data.children === undefined) |
| | | " :span="2" style="text-align: right"> |
| | | <el-button size="mini" type="text" @click.stop="remove(node, data)"> |
| | | <el-button style="margin-left: 0" size="mini" v-if="checkPermi(['standard:standardLibrary:delStandardTree'])" type="text" @click.stop="remove(node, data)"> |
| | | <i class="el-icon-delete"></i> |
| | | </el-button> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </div> |
| | | |
| | | |
| | | |
| | | |
| | | <!-- <div style="display: inline-block;width: calc(100% - 60px);text-overflow: ellipsis;white-space: nowrap;" :style="`overflow:${(node.data.children === null || node.data.children === undefined)?'clip':'visible'}`">--> |
| | | <!-- <i :class="`node_i ${data.children != undefined--> |
| | | <!-- ? data.code === '[1]'--> |
| | | <!-- ? 'el-icon-folder-opened'--> |
| | | <!-- : 'el-icon-folder'--> |
| | | <!-- : 'el-icon-tickets'--> |
| | | <!-- }`"></i>--> |
| | | <!-- {{ data.label }}--> |
| | | <!-- </div>--> |
| | | <!-- <span v-if="(node.data.children === null || node.data.children === undefined)" style="text-align: right">--> |
| | | <!-- <el-button style="width:20px" v-if="checkPermi(['standard:standardLibrary:delStandardTree'])" size="mini" type="text" @click.stop="editTreeName(node.data)">--> |
| | | <!-- <i class="el-icon-edit"></i>--> |
| | | <!-- </el-button>--> |
| | | <!-- <el-button style="width:20px;margin-left: 0" size="mini" v-if="checkPermi(['standard:standardLibrary:delStandardTree'])" type="text" @click.stop="remove(node, data)">--> |
| | | <!-- <i class="el-icon-delete"></i>--> |
| | | <!-- </el-button>--> |
| | | <!-- </span>--> |
| | | <!-- <el-row style="width: 100%">--> |
| | | <!-- <el-col :class="{ sort: node.level > 3 }" :span="19" :title="data.label" style="text-align: left">--> |
| | | |
| | | <!-- </el-col>--> |
| | | <!-- <el-col v-if="--> |
| | | <!-- checkPermi(['standard:standardLibrary:delStandardTree']) &&--> |
| | | <!-- (node.data.children === null ||--> |
| | | <!-- node.data.children === undefined)--> |
| | | <!-- " :span="2" style="text-align: right">--> |
| | | |
| | | <!-- </el-col>--> |
| | | <!-- <el-col v-if="--> |
| | | <!-- checkPermi(['standard:standardLibrary:delStandardTree']) &&--> |
| | | <!-- (node.data.children === null ||--> |
| | | <!-- node.data.children === undefined)--> |
| | | <!-- " :span="2" style="text-align: right">--> |
| | | |
| | | <!-- </el-col>--> |
| | | <!-- </el-row>--> |
| | | </div> |
| | | </el-tree> |
| | | </div> |
| | |
| | | const data = JSON.parse(event.data); |
| | | dataAcquisitionInfo = data.dataAcquisitionInfo; |
| | | list = data.list; |
| | | // console.log(111,dataAcquisitionInfo) |
| | | arrSpecial = [] |
| | | // å¤çæ°æ® |
| | | handleData() |