From 143b8e2ec209a703c21c0f87709e90f0d752f016 Mon Sep 17 00:00:00 2001 From: schangxiang@126.com <schangxiang@126.com> Date: 周二, 10 12月 2024 14:51:04 +0800 Subject: [PATCH] Merge branch 'master' of http://222.71.245.114:9086/r/LA24030-LuLI_PackageLine --- LA24030_LuLiPackageLine_Pda/pages/artificial/artificial.vue | 1056 ++++------------- LA24030_LuLiPackageLine_Pda/api/putIn/artificial.js | 14 LA24030_LuLiPackageLine_Pda/pages/untie/untie.vue | 476 ------- LA24030_LuLiPackageLine_Pda/pages/index/index.vue | 4 LA24030_LuLiPackageLine_Pda/pages/takeMaterial/orderpiece/orderpiece.vue | 1458 ++++-------------------- LA24030_LuLiPackageLine_Web/src/views/home/index.vue | 390 +++--- 6 files changed, 776 insertions(+), 2,622 deletions(-) diff --git a/LA24030_LuLiPackageLine_Pda/api/putIn/artificial.js b/LA24030_LuLiPackageLine_Pda/api/putIn/artificial.js index 04ae317..1958638 100644 --- a/LA24030_LuLiPackageLine_Pda/api/putIn/artificial.js +++ b/LA24030_LuLiPackageLine_Pda/api/putIn/artificial.js @@ -225,3 +225,17 @@ }) } +export function WmsOperationTaskSetNG(data){ + return request({ + url: `/api/WmsOperationTask/SetNG`, + method: 'post', + data: data + }) +} +export function WmsOperationTaskCancelNG(data){ + return request({ + url: `/api/WmsOperationTask/CancelNG`, + method: 'post', + data: data + }) +} diff --git a/LA24030_LuLiPackageLine_Pda/pages/artificial/artificial.vue b/LA24030_LuLiPackageLine_Pda/pages/artificial/artificial.vue index 4f70ce6..bef7f0e 100644 --- a/LA24030_LuLiPackageLine_Pda/pages/artificial/artificial.vue +++ b/LA24030_LuLiPackageLine_Pda/pages/artificial/artificial.vue @@ -1,799 +1,283 @@ <template> - <view style="padding-bottom:150px" class="boxTip"> - <cu-custom bgColor="bg-white" :isBack="true"> - <block slot="backText"> - </block> - <block slot="content">缁勭洏</block> - </cu-custom> - <!-- <view class="flex justify-end align-center padding_right30rpx padding_top12rpx"> - <text class="fontSize12rpx"> 鎿嶄綔浜猴細{{operator}} </text> - </view> --> - <u-form labelPosition="left" label-width="180rpx" :model="warehouse" ref="warehouseRef"> + <view class="overflow" style="padding-bottom: 150rpx"> + <cu-custom bgColor="bg-white" :isBack="true"> + <block slot="backText"> </block> + <block slot="content">鏉夸欢鏌ョ湅</block> + </cu-custom> + <u-form + labelPosition="left" + label-width="180rpx" + :model="warehouse" + ref="warehouseRef" + > + <!-- <u-row + class="border_bottom margin_top10rpx padding_left25rpx" + style="background-color: #fff" + > + <u-col span="12"> + <u-form-item + label="鍖呰鍙�:" + prop="packageCode" + required + class="uFormItem" + > + <u-input + v-model.trim="warehouse.packageCode" + @confirm="getContainerData(1)" + placeholder="璇峰綍鍏ユ垨鎵爜" + class="width" + :focus="curFoucus" + > + </u-input> + </u-form-item> + </u-col> + </u-row> --> + <u-row + class="border_bottom margin_top10rpx padding_left25rpx" + style="background-color: #fff" + > + <u-col span="12"> + <u-form-item label="閮ㄤ欢鏉$爜:" class="uFormItem"> + <u-input + v-model="warehouse.upi" + ref="materialRef" + placeholder="璇锋壂鐮佸綍鍏�" + @focus="warehouse.upi = ''" + :focus="curFoucus" + @confirm="getContainerData" + style="font-weight: bolder; margin-left: 15rpx" + class="width padding_left25rpx" + > + </u-input> + </u-form-item> + </u-col> + </u-row> + </u-form> + <!-- 鍒楄〃 --> + <view class="margin_top10rpx"> + <u-swipe-action + :show="item.show" + :index="eindex" + v-for="(item, eindex) in singlist" + :key="eindex" + :options="options" + @click="longpress" + @open="open" + @close="close" + class="margin_bottom10rpx" + > + <view class="item u-border-bottom"> + <!-- 姝ゅ眰wrap鍦ㄦ涓哄繀鍐欑殑锛屽惁鍒欏彲鑳戒細鍑虹幇鏍囬瀹氫綅閿欒 --> + <view class="title-wrap"> + <view + :class="item.checked ? 'bg_item' : ''" + class="fontSize32rpx width margin_auto background_fff padding10 relative box_sizing transition" + > + <!-- 閮ㄤ欢鍚嶇О upi銆佹潗鏂欍�佸昂瀵革紝浣嶇疆銆佹澘浠剁姸鎬� --> + <u-row> + <u-col span="12" class="flex align-center"> + <!-- <u-checkbox v-model="item.checked" size="50rpx"></u-checkbox> --> + <view + class="flex justify-center align-center" + style=" + background-color: #f18202; + color: #fff; + border-radius: 50vh; + width: 40rpx; + height: 40rpx; + " + > + {{ eindex + 1 }} + </view> + <text class="color_f18202 padding_left10rpx"> + {{ item.upi }} + </text> + </u-col> + </u-row> + <u-row> + <u-col span="8"> + <text class="color_80 padding_left25rpx"> + 閮ㄤ欢鍚嶇О锛� {{ item.detailName }} + </text> + </u-col> + <u-col span="4"> + <text class="color_80"> 浣嶇疆锛歿{ item.location }} </text> + </u-col> + </u-row> + <u-row> + <u-col span="8"> + <text class="color_80 padding_left25rpx"> + 鏉愭枡锛歿{ item.info18 }} + </text> + </u-col> + <u-col span="4"> + <text class="color_80"> 灏哄锛歿{ item.info16 }} </text> + </u-col> + </u-row> + <u-row> + <u-col span="8"> + <text class="color_80 padding_left25rpx"> + 鏉夸欢鐘舵�侊細{{ getEnumName(item.upiStatus) }} + </text> + </u-col> + <u-col span="4"> + <text class="color_80"> 娆″簭锛歿{ item.shelf }} </text> + </u-col> + </u-row> + </view> + </view> + </view> + </u-swipe-action> + </view> + <modal-code :rescode="rescode" :resmessage="resmessage" ref="resmodal" /> - <u-row class="border_bottom margin_top10rpx padding_left25rpx" style="background-color: #fff;"> - <u-col span="12"> - <u-form-item label="瀹瑰櫒缂栧彿:" prop="containerCode" required class="uFormItem"> - <u-input :focus="curFoucus" v-model.trim="warehouse.containerCode" @confirm="getMaterialDetails(1)" - placeholder="璇锋壂鐮佸綍鍏�" :disabled="kwbhAllowed" style="font-weight: bolder;margin-left: 15rpx;" - class="width padding_left25rpx"> - </u-input> - </u-form-item> - </u-col> - </u-row> - - <u-row v-if="warehouse.containerCode" class="border_bottom margin_top10rpx padding_left25rpx" - style="background-color: #fff;"> - <u-col span="12"> - <u-form-item label="鐗╂枡璺熻釜鐮�:" class="uFormItem"> - <u-input v-model="warehouse.snCode" ref="materialRef" placeholder="璇锋壂鐮佸綍鍏�" - @focus="warehouse.snCode = ''" @confirm="getMaterialDetails" - style="font-weight: bolder;margin-left: 15rpx;" class="width padding_left25rpx"> - </u-input> - </u-form-item> - </u-col> - </u-row> - <u-row class="border_bottom margin_top10rpx background_fff padding_left25rpx"> - <u-col span="12"> - <u-form-item label="鐩爣搴撳尯:" prop="tray" class="uFormItem"> - <input v-model="warehouse.areaCode" type="select" placeholder="璇烽�夋嫨鐩爣搴撳尯" @focus="containerFocus" - class="width"></input> - <u-action-sheet :list="wolist" v-model="modalshow" @click="confirmXl"></u-action-sheet> - <!-- <u-select v-model="modalshow" :list="wolist" @confirm="confirm" value-name="id" label-name="name"></u-select> --> - </u-form-item> - </u-col> - </u-row> - <u-row class="border_bottom margin_top10rpx padding_left25rpx" style="background-color: #fff;"> - <u-col span="10"> - <u-form-item label="鐩爣搴撲綅:" class="uFormItem"> - <u-input v-model="warehouse.placeCode" placeholder="璇锋壂鐮佸綍鍏�" - style="font-weight: bolder;margin-left: 15rpx;" class="width padding_left25rpx"> - </u-input> - </u-form-item> - </u-col> - <u-col span="2" @tap="containerFocus2"> - <span class="fontSize15rpx">鎺ㄨ崘</span> - <u-icon name="arrow-right" size="14" class="fontSize15rpx"></u-icon> - </u-col> - - <view class="boxList" v-show="modalshow2" @click="modalshow2 = false" @touchmove.stop> - <view class="innerWrap"> - <ul v-for="(item, eindex) in containerList" :key="eindex"> - <li @click="confirm2(eindex)"> {{ item.text }}</li> - </ul> - </view> - </view> - - </u-row> - </u-form> - <modal-code :rescode='rescode' :resmessage='resmessage' ref="resmodal" /> - <view style="margin-bottom: 200rpx;" class="margin_top10rpx"> - <view v-for="(item, eindex) in singlist" :key="eindex" class="margin_bottom10rpx"> - <u-swipe-action :show="item.show" :index="eindex" @click="longpress" @open="open" @close='close' - :options="options" style="width: 100vw;"> - <view class="fontSize32rpx background_fff padding10" :class="item.enAbled == 0 ? 'bg_item' : ''"> - <u-row> - <u-col span="12" class="flex"> - <text class="flex justify-center align-center circkle06">{{ eindex + 1 }}</text> - <text class="color_f18202 padding_left10rpx"> - {{ item.materialCode }}-{{ item.materialName }} - </text> - <!-- <u-icon name="plus-circle" v-if="item.enAbled!=1"></u-icon> --> - </u-col> - </u-row> - <u-row> - <u-col span="12"> - <text class="color_80 padding_left25rpx"> - 璐ㄦ鐘舵�侊細{{ item.qcStatusName }} - </text> - </u-col> - </u-row> - <u-row> - <u-col span="12"> - <view class="color_80 padding_left25rpx"> - <text style="display: inline-block">鎵规锛歿{ item.batch }}</text> - </view> - </u-col> - </u-row> - <u-row> - <u-col span="12"> - <text class="color_80 padding_left25rpx"> - 璺熻釜鐮侊細{{ item.snCode }} - </text> - </u-col> - </u-row> - <u-row> - <u-col span="8"> - <text class="color_80 padding_left25rpx"> - - </text> - </u-col> - <u-col span="4"> - <text class="color_f18202 "> - 鏁伴噺锛歿{ item.quantity }} - </text> - </u-col> - </u-row> - <!-- <u-row> - <u-col span="7"> - </u-col> - <u-col span="5" class="flex"> - <view class="color_80"> - 鏁伴噺锛� - </view> - <input :class="item.enAbled ? '' : 'border_bottom_f18202 inputGray'" - class="text-left color_f18202 fontSize32rpx inputGray2" v-model="item.quantity" - type="number" :disabled="item.enAbled == 1" @blur="changeNum(item)" @click="clicki(item)" - placeholder="0" /> - </u-col> - </u-row> --> - </view> - </u-swipe-action> - </view> - </view> - <button-modal :issueShow='true' issueTitle="閲嶇疆" subTitle='缁勭洏' restTiltle='缁勭洏涓婃灦' @reset='goWarhouse' @submit='submit' - @issue="reset" /> - - </view> + <button-modal + :subShow="true" + garmenTitle="閲嶇疆" + @submit="rest" + @reset="rest" + /> + </view> </template> <script> -import ButtonModal from '../../components/buttonModal.vue' -import ModalCode from '../../components/ModalCode.vue' +import ButtonModal from "../../components/buttonModal.vue"; +import ModalCode from "../../components/ModalCode.vue"; import { - getOrderNo, - addGroupDisk, - onlyUpdateDutyCycle, - getareaTypesList, - getContainDetail, - getContainerRecord, - getBhbMaterialList, - PdaBindListForSNCode, - getRecommendList -} from '../../api/putIn/artificial.js' -import { - getDate -} from '../../utils/dateTime.js' -import { - getAttrValue -} from '../../utils/tool.js' -import { - bindputawayConfirm -} from '../../api/putaway/putaway.js' - + getBhbMaterialList, + getenumDataList, +} from "../../api/putIn/artificial.js"; export default { - data() { - return { - containerList: [], - curFoucus: true, - rescode: 0, - resmessage: "", - putCode: '', //瀹瑰櫒浜岀淮鐮� - detailshow: false, - operator: '', - focu: false, //娓呯┖鎸夐挳闅愭樉 - focuM: false, //鐗╂枡闅愭樉鎸夐挳 - Datetime: getDate(), - singlist: [], //鐗╂枡璇︽儏 - wolist: [], - options: [ - // { - // text: '璇︽儏', - // style: { - // backgroundColor: '#fc9f35' - // } - // } - { - text: '鍒犻櫎', - style: { - backgroundColor: '#fc4b4b' - } - } - ], - materlist: {}, - warehouse: { - containerCode: '', - materialCode: '', - storehouseCode: "", - snCode: "", - // gridNumber: 1, - // useNumber: 0, - // exitNumber: 0, - // dutyCycle:1 - }, - modalshow: false, - modalshow2: false, - gridable: true, - gridFocus: false, - detailable: false, - detailableZb: false, - batchNo: '', //鎵爜鍒扮殑褰撳墠鐗╂枡鐨勬壒娆� - warehouseRules: { - containerCode: [{ - required: true, - message: '瀹瑰櫒缂栧彿涓嶈兘涓虹┖', - trigger: 'blur' - }], - materialCode: [{ - required: true, - message: '鐗╂枡缂栧彿涓嶈兘涓虹┖', - trigger: 'blur' - }] - }, - orderType: 1, - warhouseTph: '', - timerPrint: null, - kwbhAllowed: false, //鏄惁绂佺敤搴撲綅缂栧彿 - arrD: [], - statusTp: { - 'tpStatus': '' - } - }; - }, - components: { - ButtonModal, - ModalCode - }, - onLoad(option) { - if (option.orderType) { - this.orderType = option.orderType - } - }, - onReady() { - this.$refs.warehouseRef.setRules(this.warehouseRules) - }, - mounted() { - this.operator = JSON.parse(uni.getStorageSync('userInfo')).name - this.getVehicleType() - }, - computed: { - containerCode() { - return this.warehouse.containerCode - } - }, - watch: { - containerCode(val) { - if (!val) { - this.detailable = false; - this.detailableZb = false; - this.warehouse.exitNumber = 0 - } - }, - singlist(val) { - this.warehouse.exitNumber = val.length - } - }, - methods: { - //瀹瑰櫒绫诲瀷鑱氱劍浜嬩欢 - containerFocus() { - uni.hideKeyboard() - this.modalshow = true - }, - gridBtnClick() { - this.gridable = !this.gridable - if (!this.gridable) { - this.$nextTick(() => { - this.gridFocus = true; - }) - } else { - this.$nextTick(() => { - this.gridFocus = false; - }) - } - }, - //瀹瑰櫒缂栧彿鐐瑰嚮 - containerClick() { - uni.scanCode({ - scanType: ['barCode', 'qrCode'], - autoDecodeCharset: true, - success: (res) => { - this.warehouse.containerCode = res.result - this.containerBlur() - }, - fail: (err) => { - this.rescode = 400 - this.resmessage = `鎵弿澶辫触${err}` - this.$refs.resmodal.show = true - } - }) - }, - //瀹瑰櫒澶辩劍浜嬩欢 - containerBlur() { - Promise.all([this.getContainerRecord(), this.getContainerData()]) - }, - //鑾峰彇褰撳墠瀹瑰櫒涓嬬粍鐩樿褰� - getContainerRecord() { - this.kwbhAllowed = false - //姣忔鏌ヨ缃┖鏉愭枡鍒楄〃 - this.singlist = []; - if (this.warehouse.containerCode == '') { - return - } - getContainerRecord({ - containerCode: this.warehouse.containerCode - }).then(res => { - if (res.code == 200) { - this.kwbhAllowed = true - if (Array.isArray(res.data) && res.data.length > 0) { - if (res.data[0].orderNo) { - this.putCode = res.data[0].orderNo; - } - this.warehouse.dutyCycle = res.data[0].dutyCycle; //搴撳瓨鍗犳瘮 銆怑ditby shaocx,2023-05-22銆� - const recordArr = res.data.reduce((curr, item) => { - curr.push({ - code: item.materialCode, - batchNo: item.batchNo, - quantityNow: item.quantity, - quantity: item.quantity, - materialName: item.materialName, - materialTypeName: item.materialTypeName, - specificationModel: item.specificationModel, - id: '', - unionCode: item.unionCode, - replaceMaterialCode: item.replaceMaterialCode, - stockFlagStatus: item.stockFlagStatus, - show: false, - enAbled: 1 //鎺у埗鏁伴噺鏄惁鍙互杈撳叆 - }) - return curr - }, []) - this.singlist.push(...recordArr) - } - } else { - this.kwbhAllowed = false - } + data() { + return { + operator: "", + warehouse: { + packageCode: "", + upi: "", + }, + singlist: [], //璇︽儏鍒楄〃 + ordersId: 0, //褰撳墠瀹瑰櫒缁戝畾鐨勪笂鏋跺崟 + rescode: 0, + resmessage: "", + options: [ + { + text: "鎵撳嵃", + style: { + backgroundColor: "#fc9f35", + }, + }, + ], + detailshow: false, + materlist: {}, + curFoucus: true, + timer: null, + timerSm: null, + detailableZb: false, + detailable: false, + gridFocus: false, + gridable: true, + kwbhAllowed: false, + enumList: [], + }; + }, + components: { + ButtonModal, + ModalCode, + }, + created() { + getenumDataList({ + EnumName: "UpiStatusEnum", + }).then((res) => { + this.enumList = res.result || []; + }); + }, + onLoad() { + this.operator = JSON.parse(uni.getStorageSync("userInfo")).name; + }, + mounted() {}, - }) + methods: { + getEnumName(value) { + const name = this.enumList.find((item) => item.value === value); + return name ? name.name : ""; + }, + // 濡傛灉鎵撳紑涓�涓殑鏃跺�欙紝涓嶉渶瑕佸叧闂叾浠栵紝鍒欐棤闇�瀹炵幇鏈柟娉� + open(index) { + // 鍏堝皢姝e湪琚搷浣滅殑swipeAction鏍囪涓烘墦寮�鐘舵�侊紝鍚﹀垯鐢变簬props鐨勭壒鎬ч檺鍒讹紝 + // 鍘熸湰涓�'false'锛屽啀娆¤缃负'false'浼氭棤鏁� + this.singlist[index].show = true; + this.singlist.map((val, idx) => { + if (index != idx) this.singlist[idx].show = false; + }); + }, + close(index) { + this.singlist[index].show = false; + }, + //鐗╂枡璇︽儏 + longpress(index, eindex) { + this.materlist = this.singlist[index]; + this.detailshow = true; + }, - }, - //鑾峰彇瀹瑰櫒鐨勪俊鎭� - getContainerData() { - getContainDetail(this.warehouse.containerCode).then(res => { - const result = res.data.rows; - if (Array.isArray(result) && result.length == 1) { - // 铏氭嫙3涓兘涓嶆樉绀猴紱鏂欑锛氭樉绀烘爡鏍硷紱閽㈡墭锛氫笉鏄剧ず绌洪棿鍗犳瘮 - if (res.data.rows[0].isVirtual == 0) { //瀹炵墿 - if (res.data.rows[0].wareContainerType == '299120688255045' || res.data.rows[0] - .wareContainerType == '293486279884869') { // 閽㈠埗瀹瑰櫒 濉戞枡瀹瑰櫒 -鏄剧ず鍗犳瘮 - this.detailableZb = true; - this.detailable = false; - } else { //鏂欑 - 鏄剧ず鏍呮牸鏁� - this.detailableZb = false; - this.detailable = true; - } - } else { - this.detailable = false; - this.detailableZb = false; - } - this.warehouse.gridNumber = res.data.rows[0].gridNumber; - this.warehouse.useNumber = res.data.rows[0].useNumber; - } else { - uni.showToast({ - title: '搴撲綅涓嶅瓨鍦�', - icon: 'none', - duration: 2000 - }); - this.kwbhAllowed = false - } + rest() { + this.warehouse.upi = ""; + this.singlist = []; + }, - }) - }, - - - //鐗╂枡缂栫爜鐐瑰嚮 - materialClick() { - uni.scanCode({ - scanType: ['barCode', 'qrCode'], - autoDecodeCharset: true, - success: (res) => { - this.warehouse.materialCode = getAttrValue(res.result, 'PARTSNUMBER') - this.batchNo = getAttrValue(res.result, 'LOTNO') - this.getMaterialDetails() - }, - fail: (err) => { - this.rescode = 400 - this.resmessage = `鎵弿澶辫触${err}` - this.$refs.resmodal.show = true - } - }) - }, - //鐗╂枡鏌ヨ - getMaterialDetails(pram) { - if (!this.warehouse.containerCode) { - uni.showToast({ - title: '瀹瑰櫒缂栧彿涓嶈兘涓虹┖', - icon: 'none', - duration: 2000 - }) - return - } - //鎵鍣ㄧ紪鍙� 鍔犺浇鎵�鏈夌墿鏂� - if (pram == 1) { - this.singlist = []; - getBhbMaterialList({ - 'containerCode': this.warehouse.containerCode, - 'SNCode': this.warehouse.snCode - }).then((res) => { - if (res.code == 200) { - if (res.result == null) { - this.rescode = 400 - this.resmessage = '鏌ユ棤鏁版嵁' - this.$refs.resmodal.show = true - return - } else { - if (res.result.length == 0) { - console.log("绌烘墭") - this.singlist = []; - return - } else { - console.log("鏈夋枡") - res.result.forEach((item, index) => { - item.notDelete = 1 //宸茬粍鐩樼殑鐗╂枡 涓嶈鍒犻櫎 瑕佸幓瑙g粦椤甸潰瑙g粦 - }) - this.singlist = res.result; - } - } - } else { - this.resmessage = res.message - this.rescode = res.code - this.$refs.resmodal.show = true + //鑾峰彇瀹瑰櫒鐨勪俊鎭� + getContainerData(param) { + if (!this.warehouse.upi) { + uni.showToast({ + title: "璇锋壂閮ㄤ欢鏉$爜", + icon: "none", + duration: 2000, + }); + return; + } + getBhbMaterialList({ + packageCode: this.warehouse.packageCode, + upi: this.warehouse.upi, + }).then((res) => { + const result = res.result; + if (Array.isArray(result) && result.length == 0) { + uni.showToast({ + title: "鏁版嵁涓嶅瓨鍦�", + icon: "none", + duration: 2000, + }); + return; + } + this.singlist = res.result; + }); + }, - } - }) - - } else { - - //鐗╂枡鏌ヨ - PdaBindListForSNCode({ - 'containerCode': this.warehouse.containerCode, - 'SNCode': this.warehouse.snCode - }).then((res) => { - if (res.code == 200) { - if (res.result == null || !res.result.stockQuanOutput) { - this.rescode = 400 - this.resmessage = '鏌ユ棤鏁版嵁' - this.$refs.resmodal.show = true - return - } else { - // 鏍规嵁id 鍒ゆ柇鐗╂枡鏄惁瀛樺湪 - var item = res.result.stockQuanOutput; - //debugger - let index = this.singlist.findIndex(v => v.snCode == item.snCode); - if (index == -1) { - if (!res.result.validateResult && res.result.validateFailReason) { - uni.showModal({ - title: '鎻愮ず', - content: res.result.validateFailReason, - showCancel: true, - cancelColor: '#333333', - success: (res => { - if (res.confirm) { - this.singlist.unshift({ - ...item - }) - } else if (res.cancel) { - - } - }) - }); - } else { - this.singlist.unshift({ - ...item - }) - } - } - } - } else { - this.resmessage = res.message - this.rescode = res.code - this.$refs.resmodal.show = true - } - }) - - } - - }, - //鍒犻櫎璇︽儏 - longpress(index, eindex) { - uni.showModal({ - title: '鎻愮ず', - content: '鏄惁纭鍒犻櫎锛�', - showCancel: true, - cancelColor: '#333333', - success: (res => { - if (res.confirm) { - this.singlist[index].cardNum = true - if (eindex == 0) { //鍒犻櫎 - if(this.singlist[index].notDelete==1){ - uni.showToast({ - title: '宸茬粍鐩樼殑鐗╂枡 涓嶈鍒犻櫎 瑕佸幓瑙g粦椤甸潰瑙g粦', - icon: 'none', - duration: 2000 - }); - return - } - this.singlist.splice(index, 1) - } else { - this.materlist = this.singlist[index] - this.detailshow = true - } - } else if (res.cancel) { - - } - }) - }); - }, - //缂栬緫鐘舵�佹牱寮� - dc(e) { - e.cardNum = true - this.$forceUpdate() - }, - //鍗$墖閫変腑 - clicki(e) { - e.cardNum = true - this.$forceUpdate() - }, - // 濡傛灉鎵撳紑涓�涓殑鏃跺�欙紝涓嶉渶瑕佸叧闂叾浠栵紝鍒欐棤闇�瀹炵幇鏈柟娉� - open(index) { - // 鍏堝皢姝e湪琚搷浣滅殑swipeAction鏍囪涓烘墦寮�鐘舵�侊紝鍚﹀垯鐢变簬props鐨勭壒鎬ч檺鍒讹紝 - // 鍘熸湰涓�'false'锛屽啀娆¤缃负'false'浼氭棤鏁� - this.singlist[index].cardNum = true; - this.$forceUpdate() - this.singlist[index].show = true; - this.singlist.map((val, idx) => { - if (index != idx) this.singlist[idx].show = false; - }) - }, - close(index) { - this.singlist[index].show = false; - this.singlist[index].cardNum = false; - this.$forceUpdate() - }, - //鏀瑰彉缁勭洏鏁伴噺 - changeNum(val) { - val.cardNum = false - if (!val.quantity) { - uni.showModal({ - title: '鎻愮ず', - content: '缁勭洏鏁伴噺涓嶈兘涓虹┖', - showCancel: false - }) - } - if (val.quantity < 0) { - uni.showModal({ - title: '鎻愮ず', - content: '缁勭洏鏁伴噺蹇呴』澶т簬0', - showCancel: false - }) - } - - }, - //鍏ㄩ儴鍙栨秷 - reset() { - this.singlist = []; - this.warehouse.containerCode = '' - this.warehouse.snCode = '' - this.warehouse.areaCode = '' - this.warehouse.placeCode = '' - this.$refs.warehouseRef.resetFields(); - this.$forceUpdate() - this.kwbhAllowed = false - }, - //閲嶇疆椤甸潰淇℃伅 - rest() { - this.reset() - }, - //纭 - submit() { - this.$refs.warehouseRef.setRules(this.warehouseRules) - this.$refs.warehouseRef.validate(valid => { - if (valid) { - - let arrN1 = this.singlist.findIndex((v) => v.quantity == '' || v.quantity <= 0) - if (arrN1 > -1) { - uni.showToast({ - title: '鐗╂枡鏁伴噺闇�瑕佸ぇ浜�0', - icon: 'none', - duration: 2000 - }); - return - } - - //鐗╂枡璇︽儏 - let matatilDetails = this.singlist; - - let arrSub = matatilDetails.filter((v) => v.enAbled != 1) - //璇锋眰鍙傛暟 - /// 鏍囪 - /// 1锛氱墿鏂欑粍鐩� - /// 2锛氬鍣ㄧ粍鐩� - /// 3锛氱墿鏂欒В缁� - /// 4锛氬鍣ㄨВ缁� - let params = { - Flag: 1, - ContainerCode: this.warehouse.containerCode, - orderDetails: arrSub - } - uni.showModal({ - title: '鎻愮ず', - content: '鏄惁纭缁勭洏锛�', - showCancel: true, - cancelColor: '#333333', - success: (res => { - if (res.confirm) { - addGroupDisk(params).then(res => { - this.warhouseTph = this.warehouse.containerCode; - this.rescode = res.code; - this.resmessage = res.message || '缁勭洏鎴愬姛锛�'; - this.$refs.resmodal.show = true; - this.rest(); - }) - } else if (res.cancel) { - - } - }) - }); - } - }) - }, - - // 绉熺洏涓婃灦 - goWarhouse() { - //鐗╂枡璇︽儏 - let matatilDetails = this.singlist; - - let arrSub = matatilDetails.filter((v) => v.enAbled != 1) - - bindputawayConfirm({ - flag:1, // - "ActionType": 3004, //缁勭洏涓婃灦 - "ContainerCode": this.warehouse.containerCode, - "StorehouseCode": this.warehouse.storehouseCode, - "areaCode": this.warehouse.areaCode || '', - "placeCode": this.warehouse.placeCode || '', - "orderDetails": arrSub - }).then(res => { - this.rescode = res.code; - this.resmessage = res.message || '缁勭洏涓婃灦鎴愬姛锛�'; - this.$refs.resmodal.show = true; - this.reset(); - }) - // if(this.warehouse.areaCode==''&&this.warehouse.placeCode){ - // uni.showToast({ - // title: '璇峰~鍐欑洰鏍囧簱鍖烘垨鐩爣搴撲綅锛�', - // icon: 'none', - // duration: 2000 - // }) - // return; - // } - // if (this.warhouseTph == '') { - // uni.showToast({ - // title: '缁勭洏鎴愬姛鍚庯紝鍙叆搴擄紒', - // icon: 'none', - // duration: 2000 - // }) - // return - // } - // uni.navigateTo({ - // url: '/pages/putIn/three/three?type=鍏ュ簱鍗�&containerCode=' + this.warhouseTph - // }) - }, - getVehicleType() { - getareaTypesList().then((res) => { - // if (res.data.rows.length == 0) { - // this.rescode = 400 - // this.resmessage = '鏆傛棤鏁版嵁' - // this.$refs.resmodal.show = true - // return - // } - var arr = res.result.items; - arr.map(item => { - item.text = item.areaCode; - return item; - }) - this.wolist = arr - }) - }, - confirmXl(index) { - this.warehouse.areaCode = this.wolist[index].areaCode; - // this.warehouse.ContainerTypeCode = this.wolist[index].id; - }, - filterMark(stockFlagStatus) { - let str = '' - let arr4 = this.arrD.filter(v => v.value == stockFlagStatus) - if (arr4.length > 0) { - str = arr4[0].title - } - return str - }, - //------鑾峰彇鎺ㄨ崘 - containerFocus2() { - // //debugger - if (!this.warehouse.areaCode) { - uni.showToast({ - title: '璇烽�夋嫨鐩爣搴撳尯锛�', - icon: 'none', - duration: 2000 - }); - return - } - getRecommendList({ - 'containerCode': this.warehouse.containerCode, - 'areaCode': this.warehouse.areaCode - }).then(res => { - this.modalshow2 = true; - - this.containerList = res.result.reduce((curr, item) => { - curr.push({ - text: item.placeCode, - }) - return curr; - }, []) - }) - }, - //------鑾峰彇鎺ㄨ崘绫诲瀷閫夋嫨 - confirm2(index) { - this.warehouse.placeCode = this.containerList[index].text; - }, - } -} + //鍏ㄩ儴鍙栨秷 + back() { + this.ordersId = 0; + this.singlist = []; + this.$refs.warehouseRef.resetFields(); + this.warehouse.packageCode = ""; + }, + }, +}; </script> -<style lang="scss" scoped> +<style lang="scss"> +.content { + height: 500rpx; + overflow-y: scroll; + width: 100%; + padding: 15rpx; + box-sizing: border-box; + + .content-item { + padding: 15rpx; + background-color: #fff; + margin-bottom: 15rpx; + border-radius: 8rpx; + font-size: 32rpx; + } +} + .bg_item { - background: #FFEBCD !important; + background: #ffebcd !important; } - -.inputGray2 { - line-height: 30px; - border-top: 10rpx solid transparent; -} - -.inputGray { - border-top: 0rpx solid transparent; - -} - - - -.boxList { - transition: all ease 2s; - position: fixed; - bottom: 0; - left: 0; - top: 0; - right: 0; - width: 100%; - height: 100%; - z-index: 999; - background: rgba(0, 0, 0, 0.6); - - .innerWrap { - max-height: 50%; - overflow-y: auto; - background: white; - position: absolute; - bottom: 0; - left: 0; - width: 100%; - - ul { - padding: 0; - margin: 0; - - li { - padding: 0; - margin: 0; - border-bottom: 1px solid #e4e7ed; - list-style-type: none; - display: flex; - flex-direction: row; - line-height: 1; - justify-content: center; - align-items: center; - font-size: 13px; - padding: 14px 0; - flex-direction: column; - } - } - } - -} -</style> \ No newline at end of file +</style> diff --git a/LA24030_LuLiPackageLine_Pda/pages/index/index.vue b/LA24030_LuLiPackageLine_Pda/pages/index/index.vue index 5581230..a7ba2a1 100644 --- a/LA24030_LuLiPackageLine_Pda/pages/index/index.vue +++ b/LA24030_LuLiPackageLine_Pda/pages/index/index.vue @@ -103,9 +103,9 @@ // 鍙渶閰嶇疆杩欓噷 cleanoutlistForUrl: [ { - name: '鏍囧噯鏀惰揣', + name: 'NG澶勭悊', icon: 'icon-shouhuoguanli', - src: '../../static/index/takeMaterial.png', + src: '../../static/index/cancel.png', pages: '../takeMaterial/orderpiece/orderpiece' }, diff --git a/LA24030_LuLiPackageLine_Pda/pages/takeMaterial/orderpiece/orderpiece.vue b/LA24030_LuLiPackageLine_Pda/pages/takeMaterial/orderpiece/orderpiece.vue index def461e..4d8b7aa 100644 --- a/LA24030_LuLiPackageLine_Pda/pages/takeMaterial/orderpiece/orderpiece.vue +++ b/LA24030_LuLiPackageLine_Pda/pages/takeMaterial/orderpiece/orderpiece.vue @@ -1,1260 +1,346 @@ <template> - <view class="overflow" style="padding-bottom: 100px"> - <!-- 椤堕儴 --> + <view class="overflow" style="padding-bottom: 150rpx"> <cu-custom bgColor="bg-white" :isBack="true"> - <block slot="backText"></block> - <block slot="content">鏍囧噯鏀惰揣</block> + <block slot="backText"> </block> + <block slot="content">NG澶勭悊</block> </cu-custom> - <!-- 閬尅灞� --> - <modal-code - ref="resmodal" - :rescode="rescode" - :resmessage="resmessage" - :showBtn="showBtn" - @goYuKu="goYuKu" - /> - <!-- 鏀惰揣 --> - <view class="" v-if="renameFocus"> - <u-form - labelPosition="left" - label-width="180rpx" - :model="warehouse" - ref="warehouseRef" - > - <u-row - class="margin_top10rpx margin_bottom10rpx padding_left25rpx" - style="background-color: #fff" - > - <u-col span="12"> - <u-form-item required label="鐗╂枡璺熻釜鐮�:" class="uFormItem"> - <u-input - v-model.trim="warehouse.barcodeMy" - placeholder="璇峰綍鍏ユ垨鎵爜" - @focus="warehouse.barcodeMy = ''" - class="width padding_left25rpx" - :focus="true" - @confirm="materialBlur(1)" - > - </u-input> - </u-form-item> - </u-col> - </u-row> - </u-form> - <view style="margin-bottom: 180rpx" v-show="singlist.length > 0"> - <checkbox-group @change="checkboxChange"> - <view - v-for="(item, eindex) in singlist" - :key="eindex" - class="margin_top10rpx" - > - <u-swipe-action - :show="item.show" - :index="eindex" - @click="longpredel" - @open="open" - @close="close" - :options="options" - > - <view - class="fontSize32rpx background_fff padding10" - :class="item.isYueku == '鏄�' ? 'bg_item' : ''" - style="width: 100vw" - > - <u-row> - <u-col span="12"> - <label class="flex align-center"> - <text - class="flex justify-center align-center circkle06" - >{{ eindex + 1 }}</text - > - <view - class="color_f18202 padding_left10rpx" - style="flex: 1; word-break: break-all" - > - {{ item.materialCode }}-{{ item.materialName }} - </view> - </label> - </u-col> - </u-row> - <u-row> - <u-col span="12"> - <view class="padding_left25rpx" style="color: #808080"> - ASN锛歿{ item.asnNo }} - </view> - </u-col> - </u-row> - <u-row> - <u-col span="12"> - <view class="padding_left25rpx" style="color: #808080"> - 渚涘簲鍟嗘壒娆★細{{ item.supplierBatch }} - </view> - </u-col> - </u-row> - <u-row> - <u-col span="7"> - <view class="padding_left25rpx" style="color: #808080"> - 鏈�楂樺簱瀛樻暟锛歿{ Number(item.maxImumqty).toFixed(3) }} - </view> - </u-col> - <u-col span="5"> - <view class="" style="color: #808080"> - 搴撳瓨鏁帮細{{ Number(item.stockQty).toFixed(3) }} - </view> - </u-col> - </u-row> - <u-row> - <u-col span="7"> - <view class="padding_left25rpx" style="color: #808080"> - 琛屽彿锛歿{ item.asnLineNumber }} - </view> - </u-col> - <u-col span="5"> - <view class="" style="color: #808080"> - 杞崲鐜囷細{{ item.translateRate }} - </view> - </u-col> - </u-row> - - <u-row> - <u-col span="7"> - <view class="padding_left25rpx" style="color: #808080"> - 閲囪喘鍗曚綅锛歿{ item.poUnit }} - </view> - </u-col> - <u-col span="5"> - <view class="" style="color: #808080"> - 搴撳瓨鍗曚綅锛歿{ item.materialUnit }} - </view> - </u-col> - </u-row> - - <u-row> - <u-col span="7"> - <view class="padding_left25rpx" style="color: #808080"> - 閲囪喘鏁伴噺锛歿{ Number(item.poQuantity).toFixed(3) }} - </view> - </u-col> - <u-col span="5"> - <view class="" style="color: #f18202"> - 鏀惰揣鏁伴噺锛歿{ Number(item.quantity).toFixed(3) }} - </view> - </u-col> - </u-row> - </view> - </u-swipe-action> - </view> - </checkbox-group> - </view> - <u-popup - v-model="detailshow" - border-radius="14" - @close="detailshow = false" - mode="bottom" - > - <h2 class="text_align_center padding_bottom18 padding15">鐗╂枡淇℃伅</h2> - <!-- <view class="line flex justify-between"> - <text class="text-gray">鎵撳嵃寮犳暟</text> - <text> - <u-input - v-model.trim="contLabel" - placeholder="璇疯緭鍏ユ墦鍗板紶鏁�" - class="width" - @focus="contLabel = ''" - style="font-size: 36rpx; text-align: right" - > - </u-input> - </text> - </view> --> - <!-- <view class="line flex justify-between"> - <text class="text-gray">鎵撳嵃鏀惰揣鏁伴噺</text> - <text> - <u-input - v-model.trim="ermNum" - placeholder="璇疯緭鍏ユ墦鍗版敹璐ф暟閲�" - class="width" - @focus="ermNum = ''" - style="font-size: 36rpx; text-align: right" - > - </u-input> - </text> - </view> --> - - <view class="line flex justify-between"> - <text class="text-gray">鐗╂枡缂栧彿</text> - <text>{{ materlist.materialCode }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">鐗╂枡鍚嶇О</text> - <text>{{ materlist.materialName }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">鏀惰揣鏁伴噺</text> - <text>{{ materlist.quantity }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">搴撳瓨鍗曚綅</text> - <text>{{ materlist.materialUnit }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">閲囪喘鍗曚綅</text> - <text>{{ materlist.poUnit }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">琛屽彿</text> - <text>{{ materlist.asnLineNumber }}</text> - </view> - <!-- <view class="margin_top140rpx"> - <button-modal :subShow='true' garmenTitle='鎵撳嵃' @submit='init' @reset='rest' /> - <button-modal :cleaningShow='true' allTitle='钃濈墮鎵撳嵃' cleaningTitle='鏂戦┈鎵撳嵃' @allsubmit="init(1)" - @submit='init(2)' /> - </view> --> - </u-popup> - <button-modal - :empTytowerShow="true" - cleaningTitle="閲嶇疆" - garmenTitle="涓嬩竴姝�" - @submit="next" - @reset="resthandle" - /> - <!-- <button-modal :issueShow='true' issueTitle="瓒婂簱" subTitle='涓嬩竴姝�' restTiltle='閲嶇疆' @reset='rest' - @submit='next' @issue="goYuKu"/> --> - </view> - <!-- 纭鏀惰揣 --> - <view class="" v-else> - <u-tabs-swiper - ref="tabs" - :current="current" - @change="tabsChange" - bar-width="75" - :list="lists" - :is-scroll="false" - class="margin_bottom10rpx" - active-color="#f18202" - inactive-color="#f18202" - > - </u-tabs-swiper> - <scroll-view scroll-y="true" style="height: 45vh"> - <!-- <view class="margin_top10rpx overflow_auto" style="height:calc(100% - 20rpx)"> --> - <view - v-if="current == 0" - v-for="(item, eindex) in lastlist" - :key="eindex" - style="background-color: #fff" - class="padding10" - > - <u-row class="padding10"> - <u-col span="12" class="flex" style="align-items: flex-start"> - <view - style=" - background-color: #f18202; - color: #fff; - border-radius: 50%; - width: 20px; - height: 20px; - line-height: 20px; - text-align: center; - " - > - {{ eindex + 1 }} - </view> - <view - class="color_f18202 padding_left10rpx" - style="flex: 1; word-break: break-all" - > - {{ item.materialCode }}-{{ item.materialName }} - </view> - </u-col> - </u-row> - <u-row> - <u-col span="12" class="text06"> - <view class="padding_left25rpx"> 鍗曞彿锛歿{ item.asnNo }} </view> - </u-col> - </u-row> - <u-row> - <u-col span="7" class="text06"> - <view class="padding_left25rpx"> - 搴撳瓨鍗曚綅锛歿{ item.materialUnit }} - </view> - </u-col> - <u-col span="5" class="text06"> - <view class="" style="color: #808080"> - 閲囪喘鍗曚綅锛歿{ item.poUnit }} - </view> - </u-col> - </u-row> - <u-row> - <u-col span="7" class="text06"> - <view class="padding_left25rpx"> - 杞崲鐜囷細{{ item.translateRate }} - </view> - </u-col> - <u-col span="5" class="text06"> - 閲囪喘鏁伴噺锛歿{ Number(item.poQuantity).toFixed(3) }} - </u-col> - </u-row> - <u-row class=""> - <u-col span="7" class="text06"> - <view class="padding_left25rpx"> - - </view> - </u-col> - <u-col span="5" class="color_f18202"> - - 鏀惰揣鏁伴噺锛歿{ Number(item.quantity).toFixed(3) }} - </u-col> - </u-row> - </view> - <view - v-if="current == 1" - v-for="(item, eindex) in lacklist" - :key="eindex" - style="background-color: #fff; margin-top: 6rpx" - > - <u-row class="padding10"> - <u-col span="12" class="flex" style="align-items: flex-start"> - <view - style=" - background-color: #f18202; - color: #fff; - border-radius: 50%; - width: 20px; - height: 20px; - line-height: 20px; - text-align: center; - " - > - {{ eindex + 1 }} - </view> - <view - class="color_f18202 padding_left10rpx" - style="flex: 1; word-break: break-all" - > - {{ item.wareMaterialCode }} - </view> - </u-col> - </u-row> - <u-row> - <u-col span="8" class="text06"> 鎵规锛歿{ item.barNo }} </u-col> - <u-col span="4" class="text06 text-right"> - 閲囪喘鏁帮細{{ item.deliveryQuantity }} - </u-col> - </u-row> - <u-row class=""> - <u-col span="4" class="text06"> - 宸叉敹璐ф暟锛歿{ item.goodsQuantity }} - </u-col> - <u-col span="4" class="text06"> - 鏈鏀惰揣鏁帮細{{ item.uncollectedQuantity }} - </u-col> - - </u-row> - </view> - </scroll-view> - <view class="fontSize32rpx"> - <!-- <u-row class="padding15 background_fff" style="margin-bottom: 6rpx"> - <u-col span="6" class="text-gray"> - 閲囪喘鏁�: {{ QuantityTotal }} - </u-col> - <u-col span="6" class="font_weight_bold" style="text-align: right"> - 宸叉敹璐ф暟: {{ collectedTotal }} - </u-col> - </u-row> --> - <u-row class="padding15 background_fff" style="margin-bottom: 6rpx"> - <u-col span="6" class="text-gray"> </u-col> - <u-col - span="6" - class="font_weight_bold color_f18202" - style="text-align: right" - > - 鏈鏀惰揣鏁�: {{ uncollectedTotal }} - <!-- 缂烘枡鎬绘暟: {{ lackTotal }} --> - </u-col> - </u-row> - </view> - - <!-- 鎵归噺鍥剧墖涓婁紶 --> - <view - class="width fixed bottom140 margin_auto background_fff padding15 border_radius margin_bottom10rpx relative box_sizing transition boxImgWrap" - > - <view - class="ImgListBox" - v-for="(item, eindex) in fileListImgSrc" - :key="eindex" - > - <image - class="imgUp" - :src="item.bendiSrc" - mode="" - @click="imgClick(eindex)" - ></image> - <u-icon - @click="delimage(item.resSrc, eindex)" - name="close-circle-fill" - color="red" - size="60" - class="closeIcon" - ></u-icon> - </view> - <view class="addImgBox"> - <u-icon name="plus" @click="upload" size="48"></u-icon> - <text class="fontSize32rpx">閫夋嫨鍥剧墖</text> - </view> - </view> - - <button-modal - :empTytowerShow="true" - cleaningTitle="涓婁竴姝�" - garmenTitle="鏀惰揣瀹屾垚" - @submit="submit" - @reset="reset(1)" - /> - </view> - <u-action-sheet - :list="wolist2" - v-model="modalshow2" - @click="confirm2" - ></u-action-sheet> - - <!-- 娣诲姞鎵规 --> - <u-popup - v-model="detailshowPc" - border-radius="14" - @close="detailshowPc = false" - mode="bottom" + <u-form + labelPosition="left" + label-width="180rpx" + :model="warehouse" + ref="warehouseRef" > - <h2 class="text_align_center padding_bottom18 padding15">鐗╂枡鎵规淇℃伅</h2> - <!-- <view class="line flex justify-between"> - <text class="text-gray">鐗╂枡缂栧彿</text> - <text>{{materlist.wareMaterialCode}}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">鐗╂枡鍚嶇О</text> - <text>{{materlist.name}}</text> - </view> --> - <view class="line flex justify-between"> - <text class="text-gray">鎵规</text> - <text> - <u-input - v-model.trim="addBatch" - placeholder="璇疯緭鍏ユ壒娆�" - class="width" - @focus="addBatch = ''" - style="font-size: 36rpx; text-align: right" + <!-- <u-row + class="border_bottom margin_top10rpx padding_left25rpx" + style="background-color: #fff" + > + <u-col span="12"> + <u-form-item + label="鍖呰鍙�:" + prop="packageCode" + required + class="uFormItem" > - </u-input> - </text> - </view> - <view class="margin_top140rpx"> - <button-modal :subShow="true" garmenTitle="纭" @submit="submitPc" /> - </view> - </u-popup> + <u-input + v-model.trim="warehouse.packageCode" + @confirm="getContainerData(1)" + placeholder="璇峰綍鍏ユ垨鎵爜" + class="width" + :focus="curFoucus" + > + </u-input> + </u-form-item> + </u-col> + </u-row> --> + <u-row + class="border_bottom margin_top10rpx padding_left25rpx" + style="background-color: #fff" + > + <u-col span="12"> + <u-form-item label="閮ㄤ欢鏉$爜:" class="uFormItem"> + <u-input + v-model="warehouse.upi" + ref="materialRef" + placeholder="璇锋壂鐮佸綍鍏�" + @focus="warehouse.upi = ''" + @confirm="getContainerData" + style="font-weight: bolder; margin-left: 15rpx" + class="width padding_left25rpx" + > + </u-input> + </u-form-item> + </u-col> + </u-row> + </u-form> + <!-- 鍒楄〃 --> + <view class="margin_top10rpx"> + <u-swipe-action + :show="item.show" + :index="eindex" + v-for="(item, eindex) in singlist" + :key="eindex" + :options="options" + @click="longpress" + @open="open" + @close="close" + class="margin_bottom10rpx" + > + <view class="item u-border-bottom"> + <!-- 姝ゅ眰wrap鍦ㄦ涓哄繀鍐欑殑锛屽惁鍒欏彲鑳戒細鍑虹幇鏍囬瀹氫綅閿欒 --> + <view class="title-wrap"> + <view + :class="item.checked ? 'bg_item' : ''" + class="fontSize32rpx width margin_auto background_fff padding10 relative box_sizing transition" + > + <!-- 閮ㄤ欢鍚嶇О upi銆佹潗鏂欍�佸昂瀵革紝浣嶇疆銆佹澘浠剁姸鎬� --> + <u-row> + <u-col span="12" class="flex align-center"> + <!-- <u-checkbox v-model="item.checked" size="50rpx"></u-checkbox> --> + <view + class="flex justify-center align-center" + style=" + background-color: #f18202; + color: #fff; + border-radius: 50vh; + width: 40rpx; + height: 40rpx; + " + > + {{ eindex + 1 }} + </view> + <text class="color_f18202 padding_left10rpx"> + {{ item.upi }} + </text> + </u-col> + </u-row> + <u-row> + <u-col span="8"> + <text class="color_80 padding_left25rpx"> + 閮ㄤ欢鍚嶇О锛� {{ item.detailName }} + </text> + </u-col> + <u-col span="4"> + <text class="color_80"> 浣嶇疆锛歿{ item.location }} </text> + </u-col> + </u-row> + <u-row> + <u-col span="8"> + <text class="color_80 padding_left25rpx"> + 鏉愭枡锛歿{ item.info18 }} + </text> + </u-col> + <u-col span="4"> + <text class="color_80"> 灏哄锛歿{ item.info16 }} </text> + </u-col> + </u-row> + <u-row> + <u-col span="8"> + <text class="color_80 padding_left25rpx"> + 鏉夸欢鐘舵�侊細{{ getEnumName(item.upiStatus) }} + </text> + </u-col> + <u-col span="4"> + <text class="color_80"> 娆″簭锛歿{ item.shelf }} </text> + </u-col> + </u-row> + </view> + </view> + </view> + </u-swipe-action> + </view> + <modal-code :rescode="rescode" :resmessage="resmessage" ref="resmodal" /> + + <button-modal + :issueShow="true" + issueTitle="閲嶇疆" + subTitle="纭NG" + restTiltle="鍙栨秷NG" + @reset="submit(2)" + @submit="submit(1)" + @issue="rest" + /> </view> </template> - <script> -import ButtonModal from "../../../components/buttonModal.vue"; -import ModalCode from "../../../components/ModalCode.vue"; -import tkiBarcode from "@/components/tki-barcode/tki-barcode"; -import bluet from "@/components/blue.vue"; -import BluePrint from "@/pages/print/bluePrint.js"; +import ButtonModal from "@/components/buttonModal.vue"; +import ModalCode from "@/components/ModalCode.vue"; import { - getMaterial, - getPurchaseOrderDetail, - addDelivery, - getQhdOrderDetail, - getSapSelect, - addShouhuoJiaoYan, -} from "../../../api/takeMaterial/orderpiece.js"; -import { pathToBase64, base64ToPath } from "image-tools"; -import { addPrintRecord } from "../../../api/print.js"; -import { getAttrValue } from "@/utils/tool.js"; -import { translateapp, translateImg } from "@/utils/compress.js"; -import { deletePicture } from "@/api/deliver.js"; -import printComp from "@/mixins/printPoLabel.js"; -import printBanma from "@/mixins/printBanma.js"; -import mixCheckbox from "@/mixins/checkboxYueKu.js"; + WmsOperationTaskSetNG, + WmsOperationTaskCancelNG, + getBhbMaterialList, + getenumDataList, +} from "@/api/putIn/artificial.js"; export default { - mixins: [printComp, printBanma, mixCheckbox], data() { return { - materialCode: "", //鐗╂枡缂栧彿 - renameFocus: true, - detailshow: false, - rescode: 0, - autoFoucs: true, - resmessage: "", - showBtn: 0, - current: 0, //婊戝潡榛樿鍊� - fileList: [], - fileListImgSrc: [], //涓婁紶鍥剧墖鍒楄〃 - lastlist: [], - overlist: [], //鏀惰揣鍒楄〃 - lacklist: [], //缂烘枡鍒楄〃 - image: "", //褰撳墠鏄剧ず鐨勫浘鐗囧湴鍧� - action: this.$myHOST + "/api/sysFile/uploadFile", - singlist: [], //鐗╂枡璇︽儏 - lists: [ - { - name: "鏀惰揣(0)", - }, - { - name: "", - }, - ], - list: [], - arr: [], - materlist: {}, //鐗╂枡璇︽儏鏁版嵁 + operator: "", warehouse: { - barcodeMy: "", - PageSize: 10000, - PageNo: 1, + packageCode: "", + upi: "", }, - warehouseRules: { - barcodeMy: [ - { - required: true, - message: "鏉$爜涓嶈兘涓虹┖", - trigger: "blur", - }, - ], - }, + singlist: [ ], //璇︽儏鍒楄〃 + ordersId: 0, //褰撳墠瀹瑰櫒缁戝畾鐨勪笂鏋跺崟 + rescode: 0, + resmessage: "", options: [ { - text: "璇︽儏", + text: "鎵撳嵃", style: { backgroundColor: "#fc9f35", }, }, - { - text: "鍒犻櫎", - style: { - backgroundColor: "#fc4b4b", - }, - }, ], - operator: "", - QuantityTotal: 0, //閫佽揣鎬绘暟 - collectedTotal: 0, //宸叉敹璐ф暟 - uncollectedTotal: 0, //鏀惰揣鎬绘暟 - lackTotal: 0, //缂鸿揣鎬绘暟 - code: "", - addForm: { - //鎵撳嵃璁板綍 - code: "", - name: "", - batchNo: "", - specificationModel: "", - }, - lotNo: "", - contLabel: 1, //鎵撳嵃寮犳暟 - ermNum: "", detailshow: false, + materlist: {}, + curFoucus: true, timer: null, - printflag: false, - sapLocate: "", - modalshow2: false, - wolist2: [], - timerT: null, - addBatch: "", - detailshowPc: false, - itemPcAddIndex: "", + timerSm: null, + detailableZb: false, + detailable: false, + gridFocus: false, + gridable: true, + kwbhAllowed: false, + enumList: [], }; }, components: { ButtonModal, ModalCode, - tkiBarcode, - bluet, }, - onLoad(option) { - // 瓒婂簱杩斿洖 鏌ユ暟鎹� - if (option.po) { - this.warehouse.PurchaseNo = option.po; - this.warehouse.asnNo = option.po; - this.materialBlur(); - } + created() { + getenumDataList({ + EnumName: "UpiStatusEnum", + }).then((res) => { + this.enumList = res.result || []; + }); }, - onReady() { - this.$refs.warehouseRef.setRules(this.warehouseRules); - }, - mounted() { + onLoad() { this.operator = JSON.parse(uni.getStorageSync("userInfo")).name; - // this.getVehicleType2() //SAP涓嬫媺 }, + mounted() {}, methods: { - showDetail(item, eindex) { - if (item.WareMaterialCode == "") { - return; - } - item.childen = !item.childen; - if (this.singlist[eindex].SortingOrderDetailsList.length > 0) { - return; - } - getQhdOrderDetail({ - WareMaterialCode: item.wareMaterialCode, - // 'orderType':this.orderType - }).then((res) => { - if (res.code == 200) { - if (Array.isArray(res.data) && res.data.length >= 0) { - if (res.data.length == 0) { - uni.showToast({ - title: "鏆傛棤鍙栬揣鏁版嵁", - icon: "none", - duration: 2000, - }); - return; - } - res.data.forEach((item) => { - item.uncollectedQuantity = ""; - // return item; - }); - this.singlist[eindex].SortingOrderDetailsList = res.data; - } - } - }); + getEnumName(value) { + const name = this.enumList.find((item) => item.value === value); + return name ? name.name : ""; }, - //鑾峰彇print date print time - getCurrentDate() { - let date = new Date(); - let year = date.getFullYear(); //骞� - let month = date.getMonth() + 1; //鏈� - month = month >= 10 ? month : "0" + month; - let day = date.getDate(); //鏃� - day = day >= 10 ? day : "0" + day; - let hour = date.getHours(); //鏃� - hour = hour >= 10 ? hour : "0" + hour; - let min = date.getMinutes(); //鍒� - min = min >= 10 ? min : "0" + min; - let second = date.getSeconds(); //绉� - second = second >= 10 ? second : "0" + second; - return { - date: `${day}.${month}.${year}`, - time: `${hour}:${min}:${second}`, - formate: `${year}/${month}/${day}`, - }; - }, - //鎵撳嵃 - init(param) { - const arr = ["wareMaterialCode", "barNo", "uncollectedQuantity"]; - const arrzw = ["鐗╂枡缂栧彿", "鎵规", "瀹為檯鏀惰揣鏁�"]; - let isAllow = ""; - Object.keys(this.materlist).forEach((item) => { - if (arr.includes(item)) { - if (!this.materlist[item]) { - isAllow = arr.indexOf(item); - return; - } - } - }); - if (isAllow != "") { - this.detailshow = false; - this.rescode = 400; - this.resmessage = `${arrzw[isAllow]}涓虹┖锛屼笉鑳界户缁墦鍗癭; - this.showBtn = 0; - this.$refs.resmodal.show = true; - return; - } - - if (!this.contLabel || !this.ermNum) { + //鑾峰彇鐨勪俊鎭� + getContainerData() { + if (!this.warehouse.upi) { uni.showToast({ - title: "鏁伴噺涓嶈兘涓虹┖涓斿ぇ浜�0", - icon: "none", - }); - return; - } - if (param == 1) { - this.printComp(); - } else { - // 渚涘簲鍟嗙紪鍙� 渚涘簲鍟嗗悕瀛� - if (this.materlist.supplier) { - let arr = this.materlist.supplier.split(" "); - this.materlist.supplier = arr[0]; - this.materlist.supplierName = arr[1]; - } - console.log(this.materlist); - this.printBanma(); - } - }, - //鐗╂枡鏌ヨ - materialBlur(param) { - var pramCd = {}; - if (this.warehouse.barcodeMy && this.warehouse.barcodeMy.length > 0) { - if (this.warehouse.barcodeMy.indexOf(",") != -1) { - pramCd = { - SN_1d: "", - SN_2d: this.warehouse.barcodeMy - }; - } else { - pramCd = { - SN_1d: this.warehouse.barcodeMy, - SN_2d: "", - }; - } - console.log(pramCd) - getPurchaseOrderDetail({ - ...pramCd, - }).then((res) => { - if (res.code == 200) { - var arrList = res.result.items; - if (arrList.length == 0) { - this.resmessage = "鏆傛棤鏁版嵁"; - this.rescode = 400; - this.showBtn = 0; - this.$refs.resmodal.show = true; - } - if (Array.isArray(arrList) && arrList.length >= 1) { - arrList.forEach((item) => { - item.uncollectedQuantity = ""; - item.key = item.id; - }); - var stockQty = arrList[0].stockQty || 0; - var allHe = Number(arrList[0].quantity + stockQty).toFixed(3); - //鏈�楂樺簱瀛榤axImumqty < 鏀惰揣鏁皅uantity + 搴撳瓨鏁皊tockQty - if(arrList[0].maxImumqty && arrList[0].maxImumqty > 0 && - (arrList[0].maxImumqty < allHe)){ - var s1 = `鐗╂枡${arrList[0].materialCode}褰撳墠搴撳瓨${stockQty}鍜屾敹璐ф暟${arrList[0].quantity}涔嬪拰瓒呭嚭鏈�楂樺簱瀛�${arrList[0].maxImumqty}锛屾槸鍚︾户缁敹璐э紵`; - uni.showModal({ - title: "鎻愮ず", - content: s1, - showCancel: true, - cancelColor: "#333333", - success: (res) => { - if (res.confirm) { - arrList.forEach((item) => { - var arrNo = this.singlist.findIndex((v) => v.id == item.id); - if (arrNo == -1) { - this.singlist.unshift(item); - } - }); - } else if (res.cancel) { - } - }, - }); - }else{ - arrList.forEach((item) => { - var arrNo = this.singlist.findIndex((v) => v.id == item.id); - if (arrNo == -1) { - this.singlist.unshift(item); - } - }); - } - } else { - this.resmessage = "鏆傛棤鏁版嵁"; - this.rescode = 400; - this.showBtn = 0; - this.$refs.resmodal.show = true; - } - } - }); - } else { - uni.showToast({ - title: "璇锋壂鐮�", + title: "璇锋壂閮ㄤ欢鏉$爜", icon: "none", duration: 2000, }); + return; } - - }, - //鍒犻櫎璇︽儏 - longpredel(index, eindex) { - if (eindex == 1) { - this.singlist.splice(index, 1); - } else { - this.materlist = this.singlist[index]; - this.detailshow = true; - } - }, - //鍗$墖閫変腑 - click(e) { - e.cardNum = true; - this.$forceUpdate(); + getBhbMaterialList({ + upi: this.warehouse.upi, + }).then((res) => { + const result = res.result; + if (Array.isArray(result) && result.length == 0) { + uni.showToast({ + title: "鏁版嵁涓嶅瓨鍦�", + icon: "none", + duration: 2000, + }); + this.singlist = []; + return; + } + this.singlist = res.result; + }); }, // 濡傛灉鎵撳紑涓�涓殑鏃跺�欙紝涓嶉渶瑕佸叧闂叾浠栵紝鍒欐棤闇�瀹炵幇鏈柟娉� open(index) { // 鍏堝皢姝e湪琚搷浣滅殑swipeAction鏍囪涓烘墦寮�鐘舵�侊紝鍚﹀垯鐢变簬props鐨勭壒鎬ч檺鍒讹紝 // 鍘熸湰涓�'false'锛屽啀娆¤缃负'false'浼氭棤鏁� - this.singlist[index].cardNum = true; this.singlist[index].show = true; this.singlist.map((val, idx) => { if (index != idx) this.singlist[idx].show = false; }); - this.$forceUpdate(); }, close(index) { this.singlist[index].show = false; - this.singlist[index].cardNum = false; - this.$forceUpdate(); }, - // tabs閫氱煡swiper鍒囨崲 - tabsChange(index) { - this.current = index; - }, - //鏀瑰彉鏀惰揣鏁伴噺 - changeNum(val) { - val.cardNum = false; - if (!val.uncollectedQuantity) { - this.rescode = 400; - this.resmessage = "鏀惰揣鏁伴噺涓嶈兘涓虹┖涓斿ぇ浜�0"; - this.showBtn = 0; - this.$refs.resmodal.show = true; - } - // val.uncollectedQuantity = Number(val.uncollectedQuantity.toString().match(/^\d+(?:\.\d{0,2})?/)) //淇濈暀2浣嶅皬鏁� - let num1 = Number( - Number(val.deliveryQuantity) - Number(val.goodsQuantity) - ).toFixed(3); //蹇呴』淇濈暀3浣嶅皬鏁� -鍚﹀垯浼氶�犳垚鍓╀綑鐗╂枡鏄皬鏁扮殑鏃跺��,鏃犳硶鏀惰揣 - if (Number(val.uncollectedQuantity).toFixed(3) > Number(num1)) { - val.uncollectedQuantity = 0; - this.rescode = 400; - this.resmessage = - "鏀惰揣鏁�" + - val.uncollectedQuantity + - "涓嶈兘澶т簬閲囪喘鎬绘暟" + - val.deliveryQuantity + - "鍑忓凡鏀惰揣鏁�" + - val.goodsQuantity; - this.showBtn = 0; - this.$refs.resmodal.show = true; - } - if (val.uncollectedQuantity && val.uncollectedQuantity >= 0) { - val.edit = true; - this.$forceUpdate(); - } + //鐗╂枡璇︽儏 + longpress(index, eindex) { + this.materlist = this.singlist[index]; + this.detailshow = true; }, - changeNumIn(val, valParent) { - if (val.uncollectedQuantity === "" || val.uncollectedQuantity < 0) { - this.rescode = 400; - this.resmessage = "鏀惰揣鏁伴噺涓嶈兘涓虹┖"; - this.showBtn = 0; - this.$refs.resmodal.show = true; - } - val.uncollectedQuantity = Number( - val.uncollectedQuantity.toString().match(/^\d+(?:\.\d{0,3})?/) - ); //淇濈暀2浣嶅皬鏁� - - if (val.uncollectedQuantity > val.quantity) { - val.uncollectedQuantity = 0; - this.rescode = 400; - this.resmessage = "涓嶈兘澶т簬缂烘枡鏁�"; - this.showBtn = 0; - this.$refs.resmodal.show = true; - } - if (val.uncollectedQuantity > valParent.uncollectedQuantity) { - val.uncollectedQuantity = 0; - this.rescode = 400; - this.resmessage = "涓嶈兘澶т簬鏀惰揣鏁�"; - this.showBtn = 0; - this.$refs.resmodal.show = true; - } - }, - upload() { - this.fileList = []; - uni.chooseImage({ - sourceType: ["camera", "album"], - sizeType: "original", //閫夋嫨鍘熷浘 - count: 1, - success: (res) => { - res.tempFilePaths.forEach((item, index) => { - uni.showLoading({ - title: "涓婁紶涓�...", - }); - translateapp(item, 80, (imgUrl) => { - let fileData = [{ uri: imgUrl }]; - uni.uploadFile({ - url: this.action, - files: fileData, //blob: - fileType: "image", - success: (res) => { - uni.hideLoading(); - const resJson = JSON.parse(res.data); - if (resJson.code == 200) { - var jsonImg = resJson.result; - if ( - jsonImg == null || - jsonImg.url == null || - jsonImg.url == "" - ) { - this.image = ""; - this.fileList = []; - this.$u.toast("鍥剧墖涓婁紶鏈嶅姟鍣ㄥけ璐�"); - return; - } - this.fileList.push(jsonImg.url); - this.fileListImgSrc.push({ - resSrc: jsonImg.url, - bendiSrc: item, - }); - } else { - this.$u.toast("鍥剧墖涓婁紶澶辫触"); - this.fileList = []; - this.image = ""; - } - }, - }); - }); - }); - }, - }); - }, - // 鍒犻櫎鍥剧墖 - delimage(filepath, index) { - if (!filepath) { - return; - } - deletePicture({ - id: filepath, - }).then((res) => { - if (res.code == 200) { - this.fileListImgSrc.splice(index, 1); - this.$u.toast("绉婚櫎鍥剧墖鎴愬姛"); - } else { - this.rescode = 400; - this.resmessage = `鍒犻櫎鍥剧墖澶辫触`; - this.$refs.resmodal.show = true; - } - }); - }, - //棰勮鍥剧墖 - imgClick(index) { - var urlsArr = []; - this.fileListImgSrc.forEach((item) => { - urlsArr.push(item.resSrc); - }); - uni.previewImage({ - urls: urlsArr, - current: urlsArr[index], - }); - }, - //鐩戝惉鍘熺敓杩斿洖閿� - onBackPress(e) { - this.delimage(); - }, - //涓嬩竴姝� - next() { - if (this.warehouse.asnNo == "") { - uni.showToast({ - title: "璇疯緭鍏SN鍗曞彿锛�", - icon: "none", - }); - return; - } - this.singlist.forEach((item, index) => { - item.uncollectedQuantity = item.quantity; - }); - // // isBatchMge涓簍rue: 鎵规绠$悊鐨勭墿鏂� 蹇呴』杈撳叆 - // let arrMge = this.singlist.filter((v)=>(v.isBatchMge == 1 && v.barNo==''|| v.isBatchMge == 1 && v.barNo==null)).filter((v2)=>(v2.uncollectedQuantity>0)) - // if(arrMge.length>0){ - // uni.showToast({ - // title: `${arrMge[0].wareMaterialCode}璇峰~鍐欑┖鐨勬壒娆, - // icon:'none' - // }) - // return + //纭 + submit(type) { + // const filterArr = this.singlist.filter((item) => item.checked); + // if (filterArr.length <= 0) { + // this.rescode = 400; + // this.resmessage = "璇烽�夋嫨瑙g粦鐨勭墿鏂欙紒"; + // this.$refs.resmodal.show = true; + // return; // } - this.lastlist = this.singlist.filter((v) => v.uncollectedQuantity > 0); - - this.lacklist = this.singlist.reduce((curr, item) => { - if ( - item.deliveryQuantity - - item.uncollectedQuantity - - item.goodsQuantity > - 0 - ) { - curr.push(item); - } - return curr; - }, []); - - let params2 = []; - - this.lastlist.forEach((item, index) => { - params2.push({ - ...item, - // id: item.id, - // wareMaterialCode: item.wareMaterialCode, - // uncollectedQuantity: item.uncollectedQuantity, - // purchaseNo: this.warehouse.PurchaseNo, - // asnNo: this.warehouse.asnNo,//鍒拌揣鍗曞彿 - // batchNo: item.barNo, - // isCheck: item.isCheck, - // isBatchMge: item.isBatchMge, - // ebelp: item.ebelp, - // sap_Location: item.sap_Location, //sap浣嶇疆 - }); - }); - - // 宸叉敹璐ф暟 - this.QuantityTotal = this.singlist.reduce((prev, next) => { - let num = Number(prev) + Number(next.deliveryQuantity); - return Number(num).toFixed(3); - }, 0); - - this.collectedTotal = this.singlist.reduce((prev, next) => { - let num = Number(prev) + Number(next.goodsQuantity); - return Number(num).toFixed(3); - }, 0); - this.uncollectedTotal = this.singlist.reduce((prev, next) => { - let num = Number(prev) + Number(next.uncollectedQuantity); - return Number(num).toFixed(3); - }, 0); - this.lackTotal = this.singlist.reduce((prev, next) => { - let num = - Number(prev) + - Number(next.deliveryQuantity) - - Number(next.uncollectedQuantity) - - Number(next.goodsQuantity); - return Number(num).toFixed(3); - }, 0); - this.lists[0].name = `鏀惰揣(${this.lastlist.length})`; - // this.lists[1].name = `缂烘枡(${this.lacklist.length})` - this.lists[1].name = ""; - - if (this.uncollectedTotal <= 0) { - uni.showToast({ - title: "鏀惰揣鎬绘暟澶т簬0", - icon: "none", - duration: 2000, - }); + // const warehousOrderDetails = filterArr.reduce((curr, item) => { + // curr.push({ + // ...item, + // }); + // return curr; + // }, []); + var upi = this.singlist[0]?.upi || ""; + if (this.singlist.length != 1 || !upi) { + this.rescode = 400; + this.resmessage = "璇锋壂姝g‘鐨勯儴浠舵潯鐮侊紒"; + this.$refs.resmodal.show = true; return; } - - this.renameFocus = false; - - // addShouhuoJiaoYan(params2).then((res) => { - // if (res.code == 200) { - // if (res.data) { - // uni.showModal({ - // title: '鎻愮ず', - // content: `${res.data}锛岀‘璁や笅涓�姝ワ紵`, - // showCancel: true, - // cancelColor: '#333333', - // success: (res => { - // if (res.confirm) { - // this.renameFocus = false; - // } else if (res.cancel) { - // } - // }) - // }); - // } else { - // this.renameFocus = false - // } - // } - // }) - }, - //纭鏀惰揣 - submit() { - if (this.uncollectedTotal <= 0) { - uni.showToast({ - title: "鏀惰揣鎬绘暟澶т簬0", - icon: "none", - duration: 2000, - }); - return; - } - let params = []; - //鍥剧墖鍦板潃 - let idImg = []; - if (this.fileListImgSrc && this.fileListImgSrc.length > 0) { - this.fileListImgSrc.forEach((item) => { - idImg.push(item.resSrc); + const params = { + Upi: upi, + Reason: "", + }; + if (type == 1) { + uni.showModal({ + title: "NG澶勭悊", + content: "鏄惁纭NG澶勭悊锛�", + showCancel: true, + cancelColor: "#333333", + success: (res) => { + if (res.confirm) { + WmsOperationTaskSetNG(params).then((res) => { + this.rescode = 200; + this.$refs.resmodal.show = true; + this.resmessage = "NG澶勭悊鎴愬姛"; + this.rest(); + }); + } else if (res.cancel) { + } + }, }); } - this.lastlist.forEach((item, index) => { - params.push({ - PDAReceivingActionType: 1, //鏍囧噯鏀惰揣 - OrderAsnDetailsId: item.id, //ASN鍗曟槑缁咺D - createdUserId: JSON.parse(uni.getStorageSync("userInfo")).id, - createdUserName: JSON.parse(uni.getStorageSync("userInfo")).name, - updatedUserId: JSON.parse(uni.getStorageSync("userInfo")).id, - updatedUserName: JSON.parse(uni.getStorageSync("userInfo")).name, - id: item.id, - ...item, - ImageIds: idImg.join(","), //鍥剧墖鍦板潃 + + if (type == 2) { + uni.showModal({ + title: "鍙栨秷NG澶勭悊", + content: "鏄惁纭鍙栨秷NG澶勭悊锛�", + showCancel: true, + cancelColor: "#333333", + success: (res) => { + if (res.confirm) { + WmsOperationTaskCancelNG(params).then((res) => { + this.rescode = 200; + this.$refs.resmodal.show = true; + this.resmessage = "鍙栨秷NG鎴愬姛"; + this.rest(); + }); + } else if (res.cancel) { + } + }, }); - }); - uni.showModal({ - title: "鎻愮ず", - content: "鏄惁纭鏀惰揣锛�", - showCancel: true, - cancelColor: "#333333", - success: (res) => { - if (res.confirm) { - addDelivery(params).then((res) => { - this.rescode = res.code; - this.resmessage = res.message || "鏀惰揣鎴愬姛"; - this.$refs.resmodal.show = true; - if (res.code == 200) { - this.showBtn = 0; - this.renameFocus = true; - this.singlist = []; - this.warehouse.barcodeMy = ""; - this.fileList = []; - this.fileListImgSrc = []; - } else { - this.showBtn = 0; - } - }); - } else if (res.cancel) { - } - }, - }); + } }, - //娓呮閫変腑 - resthandle(parm) { - uni.showModal({ - title: "鎻愮ず", - content: "鏄惁纭閲嶇疆锛�", - showCancel: true, - cancelColor: "#333333", - success: (res) => { - if (res.confirm) { - this.rest(); - } else if (res.cancel) { - } - }, - }); - }, - //娓呮閫変腑 - rest(parm) { - this.warehouse.barcodeMy = ""; - this.autoFoucs = true; + rest() { + this.warehouse.upi = ""; this.singlist = []; - this.asnNo = ""; - this.delimage(); }, - reset(back) { - if (back) { - this.autoFoucs = false; - } - this.renameFocus = true; - }, - //鎵撳嵃 - onPrint() { - let _this = this; - if (!uni.getStorageSync("deviceId")) { - uni.showToast({ - title: "璇疯繛鎺ユ墦鍗版満", - icon: "error", - duration: 2000, - }); - return; - } - this.writeBLECharacteristicValue(); - }, - beforeDestroy() { - // 閿�姣佸畾鏃跺櫒 - if (this.timer) { - clearTimeout(this.timer); - this.timer = null; - } - }, - //绫诲瀷鑱氱劍浜嬩欢 - containerFocus2() { - uni.hideKeyboard(); - this.modalshow2 = true; - }, - getVehicleType2() { - getSapSelect().then((res) => { - if (res.code == 200) { - const dataT = res.data; - if (dataT && dataT.length == 0) { - this.wolist2 = []; - return; - } - let dataDst = []; - dataT.forEach((item) => { - dataDst.push({ - text: item, - id: item, - }); - }); - this.wolist2 = dataDst; - this.sapLocate = dataDst[0].id; - } - }); - }, - //绫诲瀷閫夋嫨 - confirm2(index) { - // this.warehouse.containerCode = this.wolist2[index].text; - // this.warehouse.containerCode = this.wolist2[index].id; - console.log(this.wolist2[index].text); - this.sapLocate = this.wolist2[index].text; - this.singlist.forEach((item) => { - item.sap_Location = this.wolist2[index].text; - }); - console.log(this.singlist); - this.$forceUpdate(); - }, - goYuKu() { - this.$refs.resmodal.show = false; - uni.navigateTo({ - url: - "/pages/takeMaterial/orderpiece/poYueku?po=" + - this.warehouse.PurchaseNo, - }); - // uni.showModal({ - // title: '鎻愮ず', - // content: '鏄惁纭瓒婂簱锛�', - // showCancel: true, - // cancelColor: '#333333', - // success: (res => { - // if (res.confirm) { - // uni.navigateTo({ - // url: '/pages/crossDock/crossDock?ids='+this.arrIds - // }) - // } else if (res.cancel) { - // } - // }) - // }); - }, - // 娣诲姞鎵规 - addBath(index) { - this.itemPcAddIndex = index; - this.detailshowPc = true; - }, - // 纭 娣诲姞鎵规 - submitPc() { - if (!this.addBatch) { - uni.showToast({ - title: "鎵规鍙蜂笉鑳戒负绌猴紒", - icon: "none", - duration: 2000, - }); - return; - } - let itemNow = JSON.parse( - JSON.stringify(this.singlist[this.itemPcAddIndex]) - ); - itemNow.barNo = this.addBatch; - itemNow.uncollectedQuantity = 1; - this.singlist.splice(this.itemPcAddIndex, 0, itemNow); - this.detailshowPc = false; - }, + + }, }; </script> - <style lang="scss"> -.title-wrap { - margin-bottom: 15rpx; - border-bottom: 1px solid #f18202; - border-top: 1px solid #f18202; - padding: 3px; +.content { + height: 500rpx; + overflow-y: scroll; + width: 100%; + padding: 15rpx; + box-sizing: border-box; + + .content-item { + padding: 15rpx; + background-color: #fff; + margin-bottom: 15rpx; + border-radius: 8rpx; + font-size: 32rpx; + } } .bg_item { background: #ffebcd !important; } - -.qhd_wp { - padding: 0 20rpx; - border-top: 1px solid #f18202; -} - -.detail_btn { - text-align: right; - padding: 10px; -} - - </style> diff --git a/LA24030_LuLiPackageLine_Pda/pages/untie/untie.vue b/LA24030_LuLiPackageLine_Pda/pages/untie/untie.vue index d002003..a9e7d82 100644 --- a/LA24030_LuLiPackageLine_Pda/pages/untie/untie.vue +++ b/LA24030_LuLiPackageLine_Pda/pages/untie/untie.vue @@ -23,6 +23,7 @@ > <u-input v-model.trim="warehouse.packageCode" + @focus="warehouse.packageCode = ''" @confirm="getContainerData(1)" placeholder="璇峰綍鍏ユ垨鎵爜" class="width" @@ -37,7 +38,7 @@ style="background-color: #fff" > <u-col span="12"> - <u-form-item label="鏉夸欢鍙�:" class="uFormItem"> + <u-form-item label="閮ㄤ欢鏉$爜:" class="uFormItem"> <u-input v-model="warehouse.upi" ref="materialRef" @@ -75,7 +76,7 @@ <!-- 閮ㄤ欢鍚嶇О upi銆佹潗鏂欍�佸昂瀵革紝浣嶇疆銆佹澘浠剁姸鎬� --> <u-row> <u-col span="12" class="flex align-center"> - <u-checkbox v-model="item.checked" size="50rpx"></u-checkbox> + <!-- <u-checkbox v-model="item.checked" size="50rpx"></u-checkbox> --> <view class="flex justify-center align-center" style=" @@ -116,7 +117,7 @@ <u-row> <u-col span="8"> <text class="color_80 padding_left25rpx"> - 鏉夸欢鐘舵�侊細{{ item.upiStatus }} + 鏉夸欢鐘舵�侊細{{ getEnumName(item.upiStatus) }} </text> </u-col> <u-col span="4"> @@ -129,54 +130,12 @@ </u-swipe-action> </view> <modal-code :rescode="rescode" :resmessage="resmessage" ref="resmodal" /> - <u-popup - v-model="detailshow" - border-radius="14" - @close="detailshow = false" - mode="bottom" - > - <!-- <view class="pop "> --> - <h2 class="text_align_center padding_bottom18 padding15">鐗╂枡淇℃伅</h2> - <view class="line flex justify-between"> - <text class="text-gray">鐗╂枡缂栧彿</text> - <text>{{ this.materlist.materialCode }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">鐗╂枡鍚嶇О</text> - <text>{{ this.materlist.materialName }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">鐗╂枡灏忕被</text> - <text>{{ this.materlist.materialTypeName }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">鎵规</text> - <text>{{ this.materlist.batchNo }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">鐗╂枡瑙勬牸</text> - <text>{{ this.materlist.specificationModel }}</text> - </view> - <view class="line flex justify-between"> - <text class="text-gray">鏁伴噺</text> - <text>{{ this.materlist.unBindQuantity }}</text> - </view> - <!-- </view> --> - <view class="margin_top140rpx"> - <button-modal - :subShow="true" - garmenTitle="鎵撳嵃" - @submit="init" - @reset="rest" - /> - </view> - </u-popup> + <button-modal - :empTytowerShow="true" - cleaningTitle="閲嶇疆" - garmenTitle="鐗╂枡瑙g粦" - @submit="submit" - @reset="back" + :subShow="true" + garmenTitle="閲嶇疆" + @submit="rest" + @reset="rest" /> </view> </template> @@ -228,24 +187,32 @@ gridFocus: false, gridable: true, kwbhAllowed: false, + enumList: [], }; }, components: { ButtonModal, ModalCode, }, + created() { + getenumDataList({ + EnumName: "UpiStatusEnum", + }).then((res) => { + this.enumList = res.result || []; + }); + }, onLoad() { this.operator = JSON.parse(uni.getStorageSync("userInfo")).name; }, mounted() { - getenumDataList({ - EnumName: "UpiStatusEnum", - }).then((res) => { - this.singlist = res.data.result || []; - }); + }, methods: { + getEnumName(value) { + const name = this.enumList.find((item) => item.value === value); + return name? name.name : ""; + }, // 濡傛灉鎵撳紑涓�涓殑鏃跺�欙紝涓嶉渶瑕佸叧闂叾浠栵紝鍒欐棤闇�瀹炵幇鏈柟娉� open(index) { // 鍏堝皢姝e湪琚搷浣滅殑swipeAction鏍囪涓烘墦寮�鐘舵�侊紝鍚﹀垯鐢变簬props鐨勭壒鎬ч檺鍒讹紝 @@ -263,323 +230,12 @@ this.materlist = this.singlist[index]; this.detailshow = true; }, - //鏍囩閲嶆柊鎵撳嵃 - init() { - const arr = ["materialCode", "unBindQuantity"]; - const arrzw = ["鐗╂枡缂栧彿", "鏈瑙g粦鏁伴噺"]; - let isAllow = ""; - Object.keys(this.materlist).forEach((item) => { - if (arr.includes(item)) { - if (!this.materlist[item]) { - isAllow = arr.indexOf(item); - // this.rescode = 400 - // this.resmessage = `${arrzw[isAllow]}涓虹┖锛屼笉鑳界户缁墦鍗癭 - // this.resmessage = `${item}涓虹┖锛屼笉鑳界户缁墦鍗癭 - // this.$refs.resmodal.show = true - return; - } - } - }); - if (isAllow != "") { - this.detailshow = false; - this.rescode = 400; - this.resmessage = `${arrzw[isAllow]}涓虹┖锛屼笉鑳界户缁墦鍗癭; - this.$refs.resmodal.show = true; - return; - } - if ( - this.materlist.unBindQuantity <= 0 || - this.materlist.unBindQuantity > this.materlist.quantity - ) { - this.detailshow = false; - this.rescode = 400; - this.resmessage = `鏁伴噺涓嶇鍚堣鑼冿紝涓嶈兘缁х画鎵撳嵃`; - this.$refs.resmodal.show = true; - return; - } - if (!this.materlist.specificationModel) { - this.materlist.specificationModel = ""; - } - let ptintContext = [ - { - type: "text", - x: 0, - y: 0, - text: "", - size: 2, - rotate: 0, - bold: 0, - underline: false, - reverse: false, - }, - { - type: "text", - x: 0, - y: 0, - text: "", - size: 2, - rotate: 0, - bold: 0, - underline: false, - reverse: false, - }, - { - type: "text", - x: 0, - y: 0, - text: "", - size: 2, - rotate: 0, - bold: 0, - underline: false, - reverse: false, - }, - /* 浠ヤ笂绌烘暟鎹紝涓洪槻姝涪鍖呮椂鎵撳嵃涓嶆甯� */ - { type: "line", x1: 3, y1: 3, x2: 565, y2: 3, width: 2 }, - { type: "line", x1: 3, y1: 3, x2: 3, y2: 345, width: 2 }, - { type: "line", x1: 3, y1: 345, x2: 565, y2: 345, width: 2 }, - { type: "line", x1: 565, y1: 345, x2: 565, y2: 3, width: 2 }, - { - type: "text", - x: 80, - y: 15, - text: "鐗ч噹姹借溅瑁呭(姝︽眽)鏈夐檺鍏徃", - size: 3, - rotate: 0, - bold: 1, - underline: false, - reverse: false, - }, - { type: "line", x1: 3, y1: 60, x2: 565, y2: 60, width: 2 }, - { - type: "text", - x: 10, - y: 75, - text: `鐗╂枡缂栧彿: ${this.materlist.materialCode}`, - size: 2, - rotate: 0, - bold: 1, - underline: false, - reverse: false, - }, - { type: "line", x1: 3, y1: 110, x2: 380, y2: 110, width: 2 }, - { - type: "text", - x: 10, - y: 125, - text: `鐗╂枡鍚嶇О: ${this.materlist.materialTypeName || ""}`, - size: 2, - rotate: 0, - bold: 1, - underline: false, - reverse: false, - }, - { type: "line", x1: 3, y1: 160, x2: 380, y2: 160, width: 2 }, - { - type: "text", - x: 10, - y: 175, - text: `鎵规: ${this.materlist.batchNo}`, - size: 2, - rotate: 0, - bold: 1, - underline: false, - reverse: false, - }, - { type: "line", x1: 3, y1: 210, x2: 565, y2: 210, width: 2 }, - { type: "line", x1: 380, y1: 60, x2: 380, y2: 210, width: 2 }, - { - type: "qr", - x: 410, - y: 72, - text: `PARTS NUMBER: ${this.materlist.materialCode},SAP: ${ - this.materlist.sap_Location || "" - },BOXNUM: ${this.materlist.boxNo || ""},LOT NO: ${ - this.materlist.batchNo - },QUANTITY: ${this.materlist.unBindQuantity}`, - width: 3, - level: 1, - }, - { - type: "text", - x: 10, - y: 225, - text: `瑙勬牸鍨嬪彿: ${ - this.materlist.specificationModel.length > 32 - ? this.materlist.specificationModel.substr(0, 32) - : this.materlist.specificationModel - }`, - size: 2, - rotate: 0, - bold: 1, - underline: false, - reverse: false, - }, - { type: "line", x1: 3, y1: 260, x2: 565, y2: 260, width: 2 }, - { - type: "text", - x: 120, - y: 290, - text: "MAKINO J(CHINA) CO.LTD", - size: 3, - rotate: 0, - bold: 1, - underline: false, - reverse: false, - }, - ]; - console.log(ptintContext); - BluePrint.print(this.$store, ptintContext) - .then(() => { - // 鍏抽棴寮规 骞舵仮澶嶆粦鍔ㄥ潡 - this.detailshow = false; - this.addForm.code = this.materlist.materlist; - this.addForm.name = this.materlist.materialName; - this.addForm.batchNo = this.materlist.batchNo; - this.addForm.specificationModel = this.materlist.specificationModel; - addPrintRecord(this.addForm).then((res) => { - console.log(res); - }); - uni.showToast({ - title: "鎵撳嵃鎴愬姛", - duration: 2000, - }); - }) - .catch((err) => { - // uni.showToast({ - // title:'鎵撳嵃澶辫触', - // duration: 2000 - // }) - }); + + rest() { + this.warehouse.upi = ""; + this.warehouse.packageCode = ""; + this.singlist = []; }, - materialBlur() { - clearTimeout(this.timerSm); - this.timerSm = null; - if (this.warehouse.materialCode == "") { - return; - } - - this.timer = setTimeout(() => { - //澶氭瑙﹀彂bug 寤惰繜bug - //鍒ゆ柇褰撳墠鐗╂枡鏄惁鍦ㄧ洏鐐瑰垪琛ㄤ腑 - const index = this.singlist.findIndex( - (item) => - item.materialCode == this.warehouse.materialCode && - item.batchNo == lotNo - ); - if (index > -1) { - this.singlist[index].checked = 1; - this.singlist.unshift(...this.singlist.splice(index, 1)); - return; - } else { - clearTimeout(this.timer); - this.timer = null; - this.containerBlur(); - } - }, 100); - }, - containerBlur() { - if ( - this.warehouse.packageCode == "" || - this.warehouse.materialCode == "" - ) { - return; - } - getContainerMaterial(this.warehouse).then((res) => { - if (res.data == null || res.data.length == 0) { - this.rescode = 400; - this.resmessage = "鏆傛棤鏁版嵁"; - this.$refs.resmodal.show = true; - return; - } - this.warehouse.dutyCycle = res.data[0].dutyCycle || 0; - //缁欐墍鏈夌殑鏉愭枡涓�涓湭閫変腑鐨勭姸鎬� - res.data.map((item) => { - (item.checked = true), (item.unBindQuantity = ""); - }); - this.singlist.unshift(...res.data); - this.ordersId = res.data[0].ordersId; - }); - }, - //瑙g粦鏁伴噺澶辩劍浜嬩欢 - changeNum(option) { - //鍒ゆ柇鏄惁鍕鹃�夛紝濡傛灉鍕鹃�変簡锛屽氨瑕佸鏁伴噺鏍¢獙 - if (!option.checked) { - return; - } - if (option.unBindQuantity == "") { - this.rescode = 400; - this.resmessage = "瑙g粦鏁伴噺涓嶈兘涓虹┖"; - this.$refs.resmodal.show = true; - } - - if (option.unBindQuantity <= 0) { - this.rescode = 400; - this.resmessage = "瑙g粦鏁伴噺蹇呴』澶т簬0"; - this.$refs.resmodal.show = true; - } - if (option.unBindQuantity > option.quantity) { - this.rescode = 400; - this.resmessage = "瑙g粦鏁伴噺涓嶈兘澶т簬搴撳瓨鏁伴噺"; - this.$refs.resmodal.show = true; - } - if (this.detailable) { - let filterHas = this.singlist.filter( - (item) => item.unBindQuantity == Number(item.quantity) - ); - if (filterHas.length > 0) { - this.warehouse.exitNumber = - this.warehouse.useNumber - filterHas.length; - } - } - }, - //纭瑙g粦 - submit() { - const filterArr = this.singlist.filter((item) => item.checked); - if (filterArr.length <= 0) { - this.rescode = 400; - this.resmessage = "璇烽�夋嫨瑙g粦鐨勭墿鏂欙紒"; - this.$refs.resmodal.show = true; - return; - } - //鍒ゆ柇閫変腑鐨勯噷闈㈡槸鍚﹀瓨鍦ㄨВ缁戠殑鏁伴噺涓嶇鍚堣鑼冪殑 - // const index = filterArr.findIndex(item => item.unBindQuantity == '' || item.unBindQuantity <= 0 || item.unBindQuantity > item.quantity) - // if (index > -1) { - // this.rescode = 400 - // this.resmessage = '瑙g粦鏁伴噺涓嶇鍚堣姹�' - // this.$refs.resmodal.show = true - // return - // } - const warehousOrderDetails = filterArr.reduce((curr, item) => { - curr.push({ - ...item, - }); - return curr; - }, []); - const params = { - flag: 3, //3锛氱墿鏂欒В缁� - packageCode: this.warehouse.packageCode, - orderDetails: warehousOrderDetails, - }; - uni.showModal({ - title: "瑙g粦", - content: "鏄惁纭瑙g粦锛�", - showCancel: true, - cancelColor: "#333333", - success: (res) => { - if (res.confirm) { - unbindOrder(params).then((res) => { - this.rescode = 200; - this.$refs.resmodal.show = true; - this.resmessage = "瑙g粦鎴愬姛"; - this.back(); - }); - } else if (res.cancel) { - } - }, - }); - }, - rest() {}, //妫�鏌ュ鍣ㄦ爡鏍兼暟 checkGrid() {}, //鑾峰彇瀹瑰櫒鐨勪俊鎭� @@ -587,9 +243,9 @@ if (param == 1) { this.warehouse.upi = ""; } - if (this.warehouse.packageCode == "") { + if (!this.warehouse.packageCode) { uni.showToast({ - title: "璇锋壂瀹瑰櫒缂栧彿", + title: "璇锋壂鍖呰鍙�", icon: "none", duration: 2000, }); @@ -599,79 +255,20 @@ packageCode: this.warehouse.packageCode, upi: this.warehouse.upi, }).then((res) => { - // //debugger const result = res.result; if (Array.isArray(result) && result.length == 0) { uni.showToast({ - title: "鏁版嵁涓嶅瓨鍦�", + title: "娌℃湁鏌ュ埌鏁版嵁", icon: "none", duration: 2000, }); + this.singlist = []; return; - // this.kwbhAllowed = true } - //瀹瑰櫒缂栧彿鍏ュ彛 - // if (param == 1) { - // } - if (res.result && res.result.length == 1) { - res.result[0].checked = true; - } - this.singlist = res.result; - - //鐗╂枡鍏ュ彛 鏍规嵁id 鍒ゆ柇鐗╂枡鏄惁瀛樺湪 - // res.result.forEach(item => { - // let index = this.singlist.findIndex(v => v.upi == item.upi); - // if (index == -1) { - - // this.singlist.unshift({ - // ...item - // }) - // } - // }); + this.singlist = result; }); }, - onlyUpdateDutyCycleClick() { - this.$refs.warehouseRef.setRules(this.warehouseRules); - this.$refs.warehouseRef.validate((valid) => { - if (valid) { - //璇锋眰鍙傛暟 - let params = { - warepackageCode: this.warehouse.packageCode, - dutyCycle: this.warehouse.dutyCycle, - }; - uni.showModal({ - title: "鎻愮ず", - content: "鏄惁纭浠呮洿鏂扮┖闂村崰姣旀暟鎹紵", - showCancel: true, - cancelColor: "#333333", - success: (res) => { - if (res.confirm) { - onlyUpdateDutyCycle(params).then((res) => { - this.warhouseTph = this.warehouse.packageCode; - this.rescode = res.code; - this.resmessage = res.message; - this.$refs.resmodal.show = true; - this.rest(); - }); - } else if (res.cancel) { - } - }, - }); - } - }); - }, - gridBtnClick() { - this.gridable = !this.gridable; - if (!this.gridable) { - this.$nextTick(() => { - this.gridFocus = true; - }); - } else { - this.$nextTick(() => { - this.gridFocus = false; - }); - } - }, + //鍏ㄩ儴鍙栨秷 back() { this.ordersId = 0; @@ -680,12 +277,7 @@ this.warehouse.packageCode = ""; }, }, - unmounted() { - if (this.timer) { - clearTimeout(this.timer); - this.timer = null; - } - }, + }; </script> <style lang="scss"> diff --git a/LA24030_LuLiPackageLine_Web/src/views/home/index.vue b/LA24030_LuLiPackageLine_Web/src/views/home/index.vue index 6ae4a8f..0571968 100644 --- a/LA24030_LuLiPackageLine_Web/src/views/home/index.vue +++ b/LA24030_LuLiPackageLine_Web/src/views/home/index.vue @@ -5,13 +5,33 @@ <div class="home-card-item flex"> <div class="flex-margin flex w100" :class="` home-one-animation${1}`"> <div class="flex-auto"> - <span class="ml5 font16">褰撴棩璁㈠崟鎬绘暟</span> + <span class="ml5 font16">鏈懆涓嬬嚎璁㈠崟鏁�</span> <div class="font30">{{ state.orderNum }}</div> </div> </div> </div> </el-col> - <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" v-for="(v, k) in state.homeOne" :key="k" :class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }"> + <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" class="home-media home-media-lg"> + <div class="home-card-item flex"> + <div class="flex-margin flex w100" :class="` home-one-animation${1}`"> + <div class="flex-auto"> + <span class="ml5 font16">涓嬬嚎鍖呮暟</span> + <div class="font30">{{ state.orderNum }}</div> + </div> + </div> + </div> + </el-col> + <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" class="home-media home-media-lg"> + <div class="home-card-item flex"> + <div class="flex-margin flex w100" :class="` home-one-animation${1}`"> + <div class="flex-auto"> + <span class="ml5 font16">涓嬬嚎鏉挎暟</span> + <div class="font30">{{ state.orderNum }}</div> + </div> + </div> + </div> + </el-col> + <!-- <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" v-for="(v, k) in state.homeOne" :key="k" :class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }"> <div class="home-card-item flex"> <div class="flex-margin flex w100" :class="` home-one-animation${k}`"> <div class="flex-auto"> @@ -24,37 +44,12 @@ </div> </div> </div> - </el-col> - </el-row> - <el-row :gutter="15" class="home-card-two mb15"> - <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16"> - <div class="home-card-item"> - <div style="height: 100%" ref="homeLineRef"></div> - </div> - </el-col> - <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8" class="home-media"> - <div class="home-card-item"> - <div class="home-card-item-title">蹇嵎瀵艰埅宸ュ叿</div> - <div class="home-monitor"> - <div class="flex-warp"> - <div class="flex-warp-item" v-for="(v, k) in state.homeThree" :key="k" @click="routerJupm(v)"> - <div class="flex-warp-item-box" :class="`home-animation${k}`"> - <div class="flex-margin"> - <i :class="v.icon" :style="{ color: v.iconColor }"></i> - <span class="pl5">{{ v.label }}</span> - <div class="mt10">{{ v.value }}</div> - </div> - </div> - </div> - </div> - </div> - </div> - </el-col> + </el-col> --> </el-row> <el-row :gutter="15" class="home-card-three"> <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8"> <div class="home-card-item"> - <div style="height: 100%" ref="homePieRef"></div> + <div style="height: 100%" id="homePieChart"></div> </div> </el-col> <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16" class="home-media"> @@ -83,7 +78,7 @@ </template> <script setup lang="ts" name="home"> -import { reactive, onMounted, ref, watch, nextTick, onActivated, markRaw, onUnmounted } from 'vue'; +import { reactive, onMounted, ref, watch, nextTick, onActivated, markRaw, onUnmounted, onBeforeUnmount } from 'vue'; import * as echarts from 'echarts'; import { storeToRefs } from 'pinia'; import { useThemeConfig } from '/@/stores/themeConfig'; @@ -94,6 +89,61 @@ const router = useRouter(); // 鎺ュ彛鏁版嵁 const loadingwms = ref(false); +const pieChartRef = ref(null); +let myChart = null; +const optionPie = { + title: { + text: '缂撳瓨宀涚粺璁�', + left: 'center', + textStyle: { + color: '#333', + }, + }, + tooltip: { + trigger: 'item', + }, + legend: { + orient: 'vertical', + left: 'left', + }, + series: [ + { + name: '搴撲綅鐘舵��', + type: 'pie', + radius: ['50%', '70%'], + data: [ + { name: '鎬诲簱浣�360', value: 120 }, + { name: '鏈夎揣搴撲綅', value: 90 }, + { name: '鏃犺揣搴撲綅', value: 60 }, + { name: '閿佸畾搴撲綅', value: 30 }, + ], + emphasis: { + itemStyle: { + shadowBlur: 10, + shadowOffsetX: 0, + shadowColor: 'rgba(0, 0, 0, 0.5)', + }, + }, + label: { + formatter: '{b}: {c} ({d}%)', + }, + }, + ], +}; + +onMounted(() => { + nextTick(() => { + myChart = echarts.init(document.getElementById('homePieChart') as HTMLDivElement); + const data = [ + { name: '鎬诲簱浣�360', value: 120 }, + { name: '鏈夎揣搴撲綅', value: 90 }, + { name: '鏃犺揣搴撲綅', value: 60 }, + { name: '閿佸畾搴撲綅', value: 30 }, + ]; + myChart.setOption(optionPie); + }); +}); + // 鏌ヨ const handleQuery1 = async () => { loadingwms.value = true; @@ -107,7 +157,6 @@ // state.homeOne[1].num1 = result.warehousingNumber || 0 // state.homeOne[1].num2 = result.allWarehousingNumber || 0 // state.homeOne[1].numA = Math.round((result.warehousingNumber || 0) / (result.allWarehousingNumber || 0)* 10000) / 100 || 0 - // } loadingwms.value = false; }; @@ -245,77 +294,7 @@ // color3: '--el-color-danger', // }, ], - homeThree: [ - { - icon: 'iconfont icon-yangan', - // label: '娴呯矇绾�', - label: '鍩虹鏁版嵁', - value: '搴撲綅淇℃伅', - route: '/wmsbase/wmsplace', - // value: '2.1%OBS/M', - iconColor: '#F72B3F', - }, - { - icon: 'iconfont icon-wendu', - // label: '娣辩孩(鐚╃孩)', - label: '鍗曟嵁绠$悊', - value: '涓婃灦鍗�', - route: '/wmsOrder/wmsordermovement', - // value: '30鈩�', - iconColor: '#91BFF8', - }, - { - icon: 'iconfont icon-shidu', - label: '鎶ヨ〃涓績', - // label: '娣$传绾�', - // value: '57%RH', - value: '搴撲綅瑙嗗浘', - route: '/reportCenter/storageView', - iconColor: '#88D565', - }, - { - icon: 'iconfont icon-shidu', - // label: '寮辩传缃楀叞绾�', - label: '鐩樼偣绠$悊', - value: '鐩樼偣鍗曟嵁', - // value: '107w', - route: '/Check/wmsinventorycheckorder', - iconColor: '#88D565', - }, - { - icon: 'iconfont icon-zaosheng', - label: '鎵撳嵃涓績', - // label: '涓传缃楀叞绾�', - value: '璺熻釜鐮佹墦鍗�', - // value: '57DB', - route: '/printCenter/wmsstockquanPrint', - iconColor: '#FBD4A0', - }, - // { - // icon: 'iconfont icon-zaosheng', - // label: '绱綏鍏�', - // value: '57PV', - // iconColor: '#FBD4A0', - // }, - // { - // icon: 'iconfont icon-zaosheng', - // label: '鏆楃传缃楀叞', - // value: '517Cpd', - // iconColor: '#FBD4A0', - // }, - // { - // icon: 'iconfont icon-zaosheng', - // label: '骞界伒鐧�', - // value: '12kg', - // iconColor: '#FBD4A0', - // }, - // { - // icon: 'iconfont icon-zaosheng', - // label: '娴峰啗钃�', - // value: '64fm', - // iconColor: '#FBD4A0', - // }, - ], + myCharts: [] as EmptyArrayType, charts: { theme: '', @@ -407,92 +386,92 @@ state.myCharts.push(state.global.homeChartOne); }; // 楗煎浘 -const initPieChart = (arr: any) => { - if (arr == null) return false; - if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose(); - state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme)); - var getname = ['绌哄簱浣嶆暟閲�', '绌哄鍣ㄥ簱浣嶆暟閲�', '瀛樿揣鏁伴噺', '鎬诲簱浣嶏細1000']; - var getvalue = [arr.emptyPlaceNumber, arr.containerPlaceNumber, arr.stockPlaceNumber]; - var data = []; - for (var i = 0; i < getname.length - 1; i++) { - data.push({ name: getname[i], value: getvalue[i] }); - } - const colorList = ['#51A3FC', '#36C78B', '#FEC279', '#968AF5', '#E790E8']; - const option = { - backgroundColor: state.charts.bgColor, - title: { - text: '搴撲綅鍗犳瘮 鎬诲簱浣嶏細' + arr.allPlaceNumber, - x: 'left', - textStyle: { fontSize: '15', color: state.charts.color }, - }, - tooltip: { trigger: 'item' }, - // tooltip: { trigger: 'item', formatter: '{b} <br/> {c}%' }, - graphic: { - elements: [ - { - type: 'image', - z: -1, - style: { - image: themeConfig.value.isIsDark - ? '' - : '', - width: 230, - height: 230, - }, - left: '16.5%', - top: 'center', - }, - ], - }, - legend: { - type: 'scroll', - orient: 'vertical', - right: '0%', - left: '65%', - top: 'center', - itemWidth: 14, - itemHeight: 14, - data: getname, - textStyle: { - rich: { - name: { - fontSize: 14, - fontWeight: 400, - width: 200, - height: 35, - padding: [0, 0, 0, 60], - color: state.charts.color, - }, - rate: { - fontSize: 15, - fontWeight: 500, - height: 35, - width: 40, - padding: [0, 0, 0, 30], - color: state.charts.color, - }, - }, - }, - }, - series: [ - { - type: 'pie', - radius: ['82', themeConfig.value.isIsDark ? '50' : '102'], - center: ['32%', '50%'], - itemStyle: { - color: function (params: any) { - return colorList[params.dataIndex]; - }, - }, - label: { show: true }, - labelLine: { show: true }, - data: data, - }, - ], - }; - state.global.homeChartTwo.setOption(option); - state.myCharts.push(state.global.homeChartTwo); -}; +// const initPieChart = (arr: any) => { +// if (arr == null) return false; +// if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose(); +// state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme)); +// var getname = ['鎬诲簱浣�360', '鏈夎揣搴撲綅', '鏃犺揣搴撲綅', '閿佸畾搴撲綅']; +// var getvalue = [arr.emptyPlaceNumber, arr.containerPlaceNumber, arr.stockPlaceNumber]; +// var data = []; +// for (var i = 0; i < getname.length - 1; i++) { +// data.push({ name: getname[i], value: getvalue[i] }); +// } +// const colorList = ['#51A3FC', '#36C78B', '#FEC279', '#968AF5']; +// const option = { +// backgroundColor: state.charts.bgColor, +// title: { +// text: '搴撲綅鍗犳瘮 鎬诲簱浣嶏細' + arr.allPlaceNumber, +// x: 'left', +// textStyle: { fontSize: '15', color: state.charts.color }, +// }, +// tooltip: { trigger: 'item' }, +// // tooltip: { trigger: 'item', formatter: '{b} <br/> {c}%' }, +// graphic: { +// elements: [ +// { +// type: 'image', +// z: -1, +// style: { +// image: themeConfig.value.isIsDark +// ? '' +// : '', +// width: 230, +// height: 230, +// }, +// left: '16.5%', +// top: 'center', +// }, +// ], +// }, +// legend: { +// type: 'scroll', +// orient: 'vertical', +// right: '0%', +// left: '65%', +// top: 'center', +// itemWidth: 14, +// itemHeight: 14, +// data: getname, +// textStyle: { +// rich: { +// name: { +// fontSize: 14, +// fontWeight: 400, +// width: 200, +// height: 35, +// padding: [0, 0, 0, 60], +// color: state.charts.color, +// }, +// rate: { +// fontSize: 15, +// fontWeight: 500, +// height: 35, +// width: 40, +// padding: [0, 0, 0, 30], +// color: state.charts.color, +// }, +// }, +// }, +// }, +// series: [ +// { +// type: 'pie', +// radius: ['82', themeConfig.value.isIsDark ? '50' : '102'], +// center: ['32%', '50%'], +// itemStyle: { +// color: function (params: any) { +// return colorList[params.dataIndex]; +// }, +// }, +// label: { show: true }, +// labelLine: { show: true }, +// data: data, +// }, +// ], +// }; +// state.global.homeChartTwo.setOption(option); +// state.myCharts.push(state.global.homeChartTwo); +// }; // 鏌辩姸鍥� const option = { backgroundColor: state.charts.bgColor, @@ -671,18 +650,17 @@ // 瀹氭椂鍣� let timeInter: any = null; // 椤甸潰鍔犺浇鏃� -onMounted(() => { - // initEchartsResize(); - - // timeInter = setInterval(() => { - // nextTick(() => { - // handleQuery1(); - // handleQuery2(); - // handleQuery3('1'); - // handleQuery4(); - // }); - // }, 15000); //璋冪敤棰戠巼鏀逛负 15绉掍竴娆℃煡璇€�� -}); +// onMounted(() => { +// // initEchartsResize(); +// // timeInter = setInterval(() => { +// // nextTick(() => { +// // handleQuery1(); +// // handleQuery2(); +// // handleQuery3('1'); +// // handleQuery4(); +// // }); +// // }, 15000); //璋冪敤棰戠巼鏀逛负 15绉掍竴娆℃煡璇€�� +// }); onUnmounted(() => { clearInterval(timeInter); //閿�姣� @@ -708,12 +686,12 @@ state.charts.theme = isIsDark ? 'dark' : ''; state.charts.bgColor = isIsDark ? 'transparent' : ''; state.charts.color = isIsDark ? '#dadada' : '#303133'; - // setTimeout(() => { - // initLineChart(null,null,null); - // }, 500); - // setTimeout(() => { - // initPieChart(null); - // }, 700); + setTimeout(() => { + initLineChart(null, null, null); + }, 500); + setTimeout(() => { + initPieChart(null); + }, 700); // setTimeout(() => { // initBarChart(null,null,null,null); // }, 1000); -- Gitblit v1.9.3