车间订单下发/车间取消下发/库存件盘点导体备货盘点/领料/取消领料页面开发及配置
已修改3个文件
已添加4个文件
1343 ■■■■■ 文件已修改
pages.json 52 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/product/receive/index.vue 7 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/storeManagement/CancelMaterialRequisition/index.vue 349 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/storeManagement/MaterialRequisition/index.vue 349 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/sys/home/index.vue 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/wareHouse/InventoryCheckConductiveMterials/index.vue 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/wareHouse/InventoryCountStockItems/index.vue 577 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages.json
@@ -183,6 +183,7 @@
        "navigationBarTitleText": "任务处理"
      }
    },
    // ç§»åº“
    {
      "path": "pages/wareHouse/moveWareHouse/index",
      "style": {
@@ -502,6 +503,47 @@
        "navigationStyle": "custom"
      }
    },
    // åº“存件盘点
    {
      "path": "pages/wareHouse/InventoryCountStockItems/index",
      "style": {
        "navigationStyle": "custom",
        "navigationBarTitleText": "",
        // "navigationBarBackgroundColor": "#CEE3FE",
        "enablePullDownRefresh": false
      }
    },
    // é¢†æ–™
        {
      "path": "pages/storeManagement/MaterialRequisition/index",
      "style": {
        "navigationStyle": "custom",
        "navigationBarTitleText": "",
        // "navigationBarBackgroundColor": "#CEE3FE",
        "enablePullDownRefresh": false
      }
    },
    // å–消领料
        {
      "path": "pages/storeManagement/CancelMaterialRequisition/index",
      "style": {
        "navigationStyle": "custom",
        "navigationBarTitleText": "",
        // "navigationBarBackgroundColor": "#CEE3FE",
        "enablePullDownRefresh": false
      }
    },
    // å¯¼ä½“备货盘点
        {
      "path": "pages/wareHouse/InventoryCheckConductiveMterials/index",
      "style": {
        "navigationStyle": "custom",
        "navigationBarTitleText": "",
        // "navigationBarBackgroundColor": "#CEE3FE",
        "enablePullDownRefresh": false
      }
    },
    // ç›˜ç‚¹æŠ¥å‘Šç›˜ç‚¹
    {
      "path": "pages/wareHouse/inventory/index",
      "style": {
@@ -760,6 +802,16 @@
        "enablePullDownRefresh": false
      }
    },
    // æŽ¥æ”¶(铜杆)
    {
      "path": "pages/product/receive/index",
      "style": {
        "navigationStyle": "custom",
        "navigationBarTitleText": "",
        // "navigationBarBackgroundColor": "#3281FF"
        "enablePullDownRefresh": false
      }
    },
    // è½¦é—´è®¢å•下发
    {
      "path": "pages/product/WorkshopOrderIssued/index",
pages/product/receive/index.vue
@@ -2,7 +2,7 @@
  <!-- æŽ¥æ”¶ï¼ˆé“œæ†ï¼‰ -->
  <view class="page">
    <view class="packing-registration-bg" />
    <u-navbar title="车间订单接收()" :background="background" :border-bottom="false" :title-bold="true" title-color="#000"
    <u-navbar title="车间订单接收(铜杆)" :background="background" :border-bottom="false" :title-bold="true" title-color="#000"
      back-icon-color="#000" />
    <u-form :model="form" ref="uForm" :label-width="280" :rules="rules" :error-type="['toast']" class="uForm">
      <u-form-item label="订单号" :border-bottom="false" prop="value1">
@@ -25,7 +25,7 @@
      </u-form-item>
      <u-form-item label="物料和工序" prop="value7">
        <u-checkbox-group>
          <u-checkbox :name="item.name" v-for="(item, index) in checkboxList" :key="index" v-model="item.value"
          <u-checkbox :name="item.name" :checked="item.checked" v-for="(item, index) in checkboxList" :disabled="item.disabled" :key="index" v-model="item.value"
            @change="changeCheckbox">
            {{ item.name }}
          </u-checkbox>
@@ -68,7 +68,8 @@
        },
        {
          name: '工序的自动报告',
          value: false
          value: true,
          disabled: true,
        },
        {
          name: '简化物料检查',
pages/storeManagement/CancelMaterialRequisition/index.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,349 @@
// å–消领料
<template>
    <view class="page">
        <view class="packing-registration-bg" />
        <u-navbar title="电解铜领料" :background="background" :border-bottom="false" :title-bold="true" title-color="#000"
            back-icon-color="#000" />
                                <view class="textST">
                        <text >取消领料记录:</text>
                    </view>
        <view class="wrap">
            <scroll-view class="packing-registration-scroll-list" scroll-y="true">
                <u-cell-group class="packing-registration-scroll-list-group" :border="false">
                    <!-- <div class="tip" style="text-align: center;" v-if="hasScanSnList.length==0">-请扫码-</div> -->
                    <view class="content" v-for="(item, index) in hasScanSnList" :key="index" :index="index">
                        <view class="content-header">
                            <view class="content-header-title">{{ index + 1 }}</view>
                        </view>
                        <view class="content-body">
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">零件号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value0 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">批次号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value1 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">WDR:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value4 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">库位号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value0 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">盘点数量:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value1 }}
                                </view>
                            </view>
                        </view>
                    </view>
                </u-cell-group>
            </scroll-view>
            <scan></scan>
        </view>
    </view>
</template>
<script>
import scan from "@/components/scan/scan.vue";
import content_bg from '@/static/custom/packing/backBg.png'
export default {
    components: {
        scan,
    },
    data() {
        return {
            background: {
                backgroundImage: `url(${content_bg})`,
                backgroundAttachment: 'fixed',
                backgroundSize: '100% auto',
                backgroundRepeat: 'no-repeat',
            },
            labelStyle: {
                fontSize: '32rpx',
                whiteSpace: 'nowrap'
            },
            hasScanSnList: [{
                value0: '11111111111111111111111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            ],
            delContent: null,
            staffList: [],
        };
    },
    onLoad(option) { },
    onShow() {
        let that = this
        uni.$off('scan') // æ¯æ¬¡è¿›æ¥å…ˆ ç§»é™¤å…¨å±€è‡ªå®šä¹‰äº‹ä»¶ç›‘听器
        uni.$on('scan', function (data) {
            console.log('onscan');
            //扫码成功后的回调,你可以写自己的逻辑代码在这里
            console.log('扫码结果:', data.code);
            that.scanHandle(data.code)
            that.$forceUpdate();
        })
    },
    onNavigationBarButtonTap() {
        this.goScan()
    },
    onReady() { },
    methods: {
        setNo(val) {
            console.log('11111', val)
            this.registerInfo.value1 = val.value1
            this.registerInfo.value2 = val.value2
        },
        //盘点报告号
        seachPersonnelNo() {
            console.log('11111')
            uni.navigateTo({
                url: '/pages/wareHouse/inventory/orderList'
            })
        },
        goScan() {
            uni.scanCode({
                scanType: ['qrCode'],
                success: res => {
                    try {
                        console.log('扫码结果:', res);
                        this.scanHandle(res.result)
                    } catch (e) { }
                }
            });
        },
        scanHandle(scanresult) {
            scanresult = scanresult.replace(/[\r\n]/g, "")
            if (scanresult.indexOf('{') > -1) {
                //二维码
                const result = JSON.parse(scanresult)
                //增加SN校验
                if (result.sn_no && result.sn_no != null && result.sn_no != '') {
                    if (this.hasScanSnList.length > 0) {
                        let hasScanSnIndex = this.hasScanSnList.indexOf(result.sn_no)
                        if (hasScanSnIndex < 0) {
                            this.hasScanSnList.push(result.sn_no)
                        } else {
                            this.$u.toast('请勿重复扫描')
                        }
                    } else {
                        this.hasScanSnList.push(result.sn_no)
                    }
                }
            } else {
                //增加SN校验
                if (this.hasScanSnList.length > 0) {
                    let hasScanSnIndex = this.hasScanSnList.indexOf(scanresult)
                    if (hasScanSnIndex < 0) {
                        this.hasScanSnList.push(scanresult)
                    } else {
                        this.$u.toast('请勿重复扫描')
                    }
                } else {
                    this.hasScanSnList.push(scanresult)
                }
            }
        },
        goSubmit() {
            // if (this.registerInfo.shiftId == null || this.registerInfo.shiftId == '') {
            //     this.$u.toast('请选择班次')
            //     return
            // }
            // if (this.registerInfo.value3 == null || this.registerInfo.value3 == '') {
            //     this.$u.toast('请选择日期')
            //     return
            // }
            // if (this.registerInfo.locNo == null || this.registerInfo.locNo == '') {
            //     this.$u.toast('请选择包装库位')
            //     return
            // }
            // if (this.hasScanSnList.length == 0) {
            //     this.$u.toast('无待提交的SN号明细')
            //     return
            // }
            // let registrList = []
            // this.staffList = []
            // this.staffNameList.forEach((item) => {
            //     this.staffList.push({
            //         staffId: item.id
            //     })
            // })
            // this.hasScanSnList.forEach((item) => {
            //     registrList.push({
            //         shiftId: this.registerInfo.shiftId,
            //         value3: this.registerInfo.value3,
            //         locNo: this.registerInfo.locNo,
            //         partBatchNo: item,
            //         staffList: this.staffList
            //     })
            // })
            // this.$u.api.pigxPacking.addPackageRegister(registrList).then(res => {
            //     let resData = res.data
            //     this.hasScanSnList = []
            //     this.$u.toast('提交成功')
            // }).catch((e) => {
            // })
        },
    }
};
</script>
<style lang="scss" scoped>
.textST {
    font-size: 14px;
    margin:0 0 13px 13px;
}
.packing-registration-bg {
    background-color: #F6F9FF;
    background-image: url('~@/static/custom/packing/backBg.png');
    padding: 0 20rpx;
    background-attachment: fixed;
    background-size: 100% auto;
    background-repeat: no-repeat;
    position: fixed;
    top: 0;
    bottom: 0;
    width: 100%;
    z-index: -1;
}
.wrap .packing-registration-scroll-list {
    height: calc(100vh - var(--window-top) - var(--window-bottom) - 250rpx);
    width: 100%;
}
.packing-registration-scroll-list-group {
    ::v-deep .u-cell-item-box {
        background-color: rgba(250, 252, 255, 0.36) !important;
        padding: 0rpx 30rpx;
    }
    .content {
        font-size: 12px;
        background-color: #ffffff;
        box-sizing: border-box;
        border-radius: 10rpx;
        margin: 0rpx 0rpx 16rpx;
        padding: 20rpx 8rpx;
        box-shadow: none;
        display: flex;
        align-items: center;
        .content-header {
            width: 40rpx;
            height: 90rpx;
            display: flex;
            align-items: center;
            .content-header-icon {
                background-image: url("~@/static/custom/moveWareHouse/header_icon.png");
                background-size: 100% auto;
                background-repeat: no-repeat;
                height: 28rpx;
                width: 28rpx;
            }
            .content-header-title {
                margin-left: 11rpx;
                font-size: 26rpx;
                font-weight: bold;
                color: #626369;
            }
        }
        .content-body {
            flex: 1;
            background-color: #ffffff;
            border-radius: 10rpx;
            padding: 0rpx 23rpx;
            .row-list {
                height: 60rpx;
                display: flex;
                flex-direction: row;
                padding: 0px;
                align-items: center;
            }
            .row-list ._label {
                display: flex;
                flex: 0.8;
                color: #909399;
                align-items: center;
                ._label-name {
                    margin-left: 11rpx;
                    font-size: 26rpx;
                    font-weight: 500;
                    color: #666666;
                }
            }
            .row-list ._content {
                flex: 1.5;
                text-align: right;
                color: #909399;
                font-size: 24rpx;
            }
            .row-list .s1 {
                color: #d35651;
            }
        }
    }
}
</style>
pages/storeManagement/MaterialRequisition/index.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,349 @@
// é¢†æ–™
<template>
    <view class="page">
        <view class="packing-registration-bg" />
        <u-navbar title="电解铜领料" :background="background" :border-bottom="false" :title-bold="true" title-color="#000"
            back-icon-color="#000" />
                                <view class="textST">
                        <text >领料记录:</text>
                    </view>
        <view class="wrap">
            <scroll-view class="packing-registration-scroll-list" scroll-y="true">
                <u-cell-group class="packing-registration-scroll-list-group" :border="false">
                    <!-- <div class="tip" style="text-align: center;" v-if="hasScanSnList.length==0">-请扫码-</div> -->
                    <view class="content" v-for="(item, index) in hasScanSnList" :key="index" :index="index">
                        <view class="content-header">
                            <view class="content-header-title">{{ index + 1 }}</view>
                        </view>
                        <view class="content-body">
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">零件号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value0 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">批次号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value1 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">WDR:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value4 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">库位号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value0 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">盘点数量:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value1 }}
                                </view>
                            </view>
                        </view>
                    </view>
                </u-cell-group>
            </scroll-view>
            <scan></scan>
        </view>
    </view>
</template>
<script>
import scan from "@/components/scan/scan.vue";
import content_bg from '@/static/custom/packing/backBg.png'
export default {
    components: {
        scan,
    },
    data() {
        return {
            background: {
                backgroundImage: `url(${content_bg})`,
                backgroundAttachment: 'fixed',
                backgroundSize: '100% auto',
                backgroundRepeat: 'no-repeat',
            },
            labelStyle: {
                fontSize: '32rpx',
                whiteSpace: 'nowrap'
            },
            hasScanSnList: [{
                value0: '11111111111111111111111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            ],
            delContent: null,
            staffList: [],
        };
    },
    onLoad(option) { },
    onShow() {
        let that = this
        uni.$off('scan') // æ¯æ¬¡è¿›æ¥å…ˆ ç§»é™¤å…¨å±€è‡ªå®šä¹‰äº‹ä»¶ç›‘听器
        uni.$on('scan', function (data) {
            console.log('onscan');
            //扫码成功后的回调,你可以写自己的逻辑代码在这里
            console.log('扫码结果:', data.code);
            that.scanHandle(data.code)
            that.$forceUpdate();
        })
    },
    onNavigationBarButtonTap() {
        this.goScan()
    },
    onReady() { },
    methods: {
        setNo(val) {
            console.log('11111', val)
            this.registerInfo.value1 = val.value1
            this.registerInfo.value2 = val.value2
        },
        //盘点报告号
        seachPersonnelNo() {
            console.log('11111')
            uni.navigateTo({
                url: '/pages/wareHouse/inventory/orderList'
            })
        },
        goScan() {
            uni.scanCode({
                scanType: ['qrCode'],
                success: res => {
                    try {
                        console.log('扫码结果:', res);
                        this.scanHandle(res.result)
                    } catch (e) { }
                }
            });
        },
        scanHandle(scanresult) {
            scanresult = scanresult.replace(/[\r\n]/g, "")
            if (scanresult.indexOf('{') > -1) {
                //二维码
                const result = JSON.parse(scanresult)
                //增加SN校验
                if (result.sn_no && result.sn_no != null && result.sn_no != '') {
                    if (this.hasScanSnList.length > 0) {
                        let hasScanSnIndex = this.hasScanSnList.indexOf(result.sn_no)
                        if (hasScanSnIndex < 0) {
                            this.hasScanSnList.push(result.sn_no)
                        } else {
                            this.$u.toast('请勿重复扫描')
                        }
                    } else {
                        this.hasScanSnList.push(result.sn_no)
                    }
                }
            } else {
                //增加SN校验
                if (this.hasScanSnList.length > 0) {
                    let hasScanSnIndex = this.hasScanSnList.indexOf(scanresult)
                    if (hasScanSnIndex < 0) {
                        this.hasScanSnList.push(scanresult)
                    } else {
                        this.$u.toast('请勿重复扫描')
                    }
                } else {
                    this.hasScanSnList.push(scanresult)
                }
            }
        },
        goSubmit() {
            // if (this.registerInfo.shiftId == null || this.registerInfo.shiftId == '') {
            //     this.$u.toast('请选择班次')
            //     return
            // }
            // if (this.registerInfo.value3 == null || this.registerInfo.value3 == '') {
            //     this.$u.toast('请选择日期')
            //     return
            // }
            // if (this.registerInfo.locNo == null || this.registerInfo.locNo == '') {
            //     this.$u.toast('请选择包装库位')
            //     return
            // }
            // if (this.hasScanSnList.length == 0) {
            //     this.$u.toast('无待提交的SN号明细')
            //     return
            // }
            // let registrList = []
            // this.staffList = []
            // this.staffNameList.forEach((item) => {
            //     this.staffList.push({
            //         staffId: item.id
            //     })
            // })
            // this.hasScanSnList.forEach((item) => {
            //     registrList.push({
            //         shiftId: this.registerInfo.shiftId,
            //         value3: this.registerInfo.value3,
            //         locNo: this.registerInfo.locNo,
            //         partBatchNo: item,
            //         staffList: this.staffList
            //     })
            // })
            // this.$u.api.pigxPacking.addPackageRegister(registrList).then(res => {
            //     let resData = res.data
            //     this.hasScanSnList = []
            //     this.$u.toast('提交成功')
            // }).catch((e) => {
            // })
        },
    }
};
</script>
<style lang="scss" scoped>
.textST {
    font-size: 14px;
    margin:0 0 13px 13px;
}
.packing-registration-bg {
    background-color: #F6F9FF;
    background-image: url('~@/static/custom/packing/backBg.png');
    padding: 0 20rpx;
    background-attachment: fixed;
    background-size: 100% auto;
    background-repeat: no-repeat;
    position: fixed;
    top: 0;
    bottom: 0;
    width: 100%;
    z-index: -1;
}
.wrap .packing-registration-scroll-list {
    height: calc(100vh - var(--window-top) - var(--window-bottom) - 250rpx);
    width: 100%;
}
.packing-registration-scroll-list-group {
    ::v-deep .u-cell-item-box {
        background-color: rgba(250, 252, 255, 0.36) !important;
        padding: 0rpx 30rpx;
    }
    .content {
        font-size: 12px;
        background-color: #ffffff;
        box-sizing: border-box;
        border-radius: 10rpx;
        margin: 0rpx 0rpx 16rpx;
        padding: 20rpx 8rpx;
        box-shadow: none;
        display: flex;
        align-items: center;
        .content-header {
            width: 40rpx;
            height: 90rpx;
            display: flex;
            align-items: center;
            .content-header-icon {
                background-image: url("~@/static/custom/moveWareHouse/header_icon.png");
                background-size: 100% auto;
                background-repeat: no-repeat;
                height: 28rpx;
                width: 28rpx;
            }
            .content-header-title {
                margin-left: 11rpx;
                font-size: 26rpx;
                font-weight: bold;
                color: #626369;
            }
        }
        .content-body {
            flex: 1;
            background-color: #ffffff;
            border-radius: 10rpx;
            padding: 0rpx 23rpx;
            .row-list {
                height: 60rpx;
                display: flex;
                flex-direction: row;
                padding: 0px;
                align-items: center;
            }
            .row-list ._label {
                display: flex;
                flex: 0.8;
                color: #909399;
                align-items: center;
                ._label-name {
                    margin-left: 11rpx;
                    font-size: 26rpx;
                    font-weight: 500;
                    color: #666666;
                }
            }
            .row-list ._content {
                flex: 1.5;
                text-align: right;
                color: #909399;
                font-size: 24rpx;
            }
            .row-list .s1 {
                color: #d35651;
            }
        }
    }
}
</style>
pages/sys/home/index.vue
@@ -74,12 +74,12 @@
                        },
                        {
                            name: '库存件盘点',
                            url: '/pages/wareHouse/inventory/index',
                            url: '/pages/wareHouse/InventoryCountStockItems/index',
                            icon: 'nine'
                        },
                        {
                            name: '导体备货盘点',
                            url: '/pages/wareHouse/inventory/index',
                            url: '/pages/wareHouse/InventoryCheckConductiveMterials/index',
                            icon: 'ten'
                        },
                    ]
@@ -89,12 +89,12 @@
                    list: [
                        {
                            name: '领料',
                            url: '/pages/wareHouse/moveWareHouse/index',
                            url: '/pages/storeManagement/MaterialRequisition/index',
                            icon: 'eleven'
                        },
                        {
                            name: '取消领料',
                            url: '/pages/wareHouse/inventory/index',
                            url: '/pages/storeManagement/CancelMaterialRequisition/index',
                            icon: 'twelve'
                        },
                    ]
pages/wareHouse/InventoryCheckConductiveMterials/index.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1 @@
// å¯¼ä½“备货盘点
pages/wareHouse/InventoryCountStockItems/index.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,577 @@
// åº“存件盘点
<template>
    <view class="page">
        <view class="packing-registration-bg" />
        <u-navbar title="库存件盘点" :background="background" :border-bottom="false" :title-bold="true" title-color="#000"
            back-icon-color="#000" />
        <view class="packing-registration-param">
            <view class="packing-registration-param-view">
                <view class="packing-registration-param-item param-extra">
                    <view class="packing-registration-param-item-left">
                        <text class="item-one">零件号</text>
                    </view>
                    <view class="packing-registration-param-item-right">
                        <view class="item-one item-two" @click="openPN()">
                            <text>{{ registerInfo.value6 == '' ? "扫码或点击输入" : registerInfo.value6 }}</text>
                        </view>
                        <u-icon name="arrow-right" color="#687792" size="28" v-show="registerInfo.value6 == ''"></u-icon>
                    </view>
                </view>
                <view class="packing-registration-param-item param-extra">
                    <view class="packing-registration-param-item-left">
                        <text class="item-one">批次号</text>
                    </view>
                    <view class="packing-registration-param-item-right" @click="openBatch()">
                        <text class="item-one item-two">{{ registerInfo.value3 == '' ? "扫码或点击输入" : registerInfo.value3 }}</text>
                        <u-icon name="arrow-right" color="#687792" size="28" v-show="registerInfo.value3 == ''"></u-icon>
                    </view>
                </view>
                <view class="packing-registration-param-item param-extra">
                    <view class="packing-registration-param-item-left">
                        <text class="item-one">WDR</text>
                    </view>
                    <view class="packing-registration-param-item-right" @click="openWDR()">
                        <text class="item-one item-two">{{ registerInfo.value0 == '' ? "扫码或点击输入" : registerInfo.value0 }}</text>
                        <u-icon name="arrow-right" color="#687792" size="28" v-show="registerInfo.value0 == ''"></u-icon>
                    </view>
                </view>
                <view class="packing-registration-param-item param-extra">
                    <view class="packing-registration-param-item-left">
                        <text class="item-one">库位号</text>
                    </view>
                    <view class="packing-registration-param-item-right" @click="openLocation()">
                        <view class="item-one item-two">
                            <text>{{ registerInfo.value4 == '' ? "扫码或点击输入" : registerInfo.value4 }}</text>
                        </view>
                        <u-icon name="arrow-right" color="#687792" size="28" v-show="registerInfo.value4 == ''"></u-icon>
                    </view>
                </view>
                <view class="packing-registration-param-item param-extra">
                    <view class="packing-registration-param-item-left">
                        <text class="item-one">盘点数量</text>
                    </view>
                    <view class="packing-registration-param-item-right" @click="openPhysicalInventory()">
                        <view class="item-one item-two">
                            <text>{{ registerInfo.value5 == '' ? "扫码或点击输入" : registerInfo.value5 }}</text>
                        </view>
                        <u-icon name="arrow-right" color="#687792" size="28" v-show="registerInfo.value4 == ''"></u-icon>
                    </view>
                </view>
            </view>
        </view>
        <view class="registration-form-footer">
                <u-button class="btn" type="primary" @click="goSubmit">提交</u-button>
        </view>
        <view class="wrap">
            <scroll-view class="packing-registration-scroll-list" scroll-y="true">
                <u-cell-group class="packing-registration-scroll-list-group" :border="false">
                    <!-- <div class="tip" style="text-align: center;" v-if="hasScanSnList.length==0">-请扫码-</div> -->
                    <view class="textST">
                        <text >{{`本次盘点记录(共${registerInfo.num}条):`}}</text>
                    </view>
                    <view class="content" v-for="(item, index) in hasScanSnList" :key="index" :index="index">
                        <view class="content-header">
                            <view class="content-header-title">{{ index + 1 }}</view>
                        </view>
                        <view class="content-body">
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">零件号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value0 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">批次号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value1 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">WDR:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value4 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">库位号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value0 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">盘点数量:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value1 }}
                                </view>
                            </view>
                        </view>
                    </view>
                </u-cell-group>
            </scroll-view>
            <scan></scan>
            <!-- é›¶ä»¶å· -->
            <modalBg ref="openPN" :confirm="confirmPN">
                <u-field v-model="registerInfo.value6" label="零件号:" placeholder="请输入" :border-bottom="false">
                </u-field>
            </modalBg>
            <!-- æ‰¹æ¬¡å· -->
            <modalBg ref="openBatch" :confirm="confirmBatch">
                <u-field v-model="registerInfo.value3" label="批次号:" placeholder="请输入" :border-bottom="false">
                </u-field>
            </modalBg>
            <!-- åº“位号 -->
            <modalBg ref="openLocation" :confirm="confirmLocation">
                <u-field v-model="registerInfo.value4" label="库位号:" placeholder="请输入" :border-bottom="false">
                </u-field>
            </modalBg>
            <!-- ç›˜ç‚¹æ•°é‡ -->
            <modalBg ref="openPhysicalInventory" :confirm="confirmPhysicalInventory">
                <u-field v-model="registerInfo.value5" label="盘点数量:" label-width="140" placeholder="请输入" :border-bottom="false">
                </u-field>
            </modalBg>
            <!-- WDR -->
            <modalBg ref="openWDR" :confirm="confirmWDR">
                <u-field v-model="registerInfo.value0" label="WDR:" label-width="140" placeholder="请输入" :border-bottom="false">
                </u-field>
            </modalBg>
        </view>
    </view>
</template>
<script>
import modalBg from '@/components/modal/modal-bg.vue'
import scan from "@/components/scan/scan.vue";
import content_bg from '@/static/custom/packing/backBg.png'
export default {
    components: {
        scan,
        modalBg
    },
    data() {
        return {
            background: {
                backgroundImage: `url(${content_bg})`,
                backgroundAttachment: 'fixed',
                backgroundSize: '100% auto',
                backgroundRepeat: 'no-repeat',
            },
            labelStyle: {
                fontSize: '32rpx',
                whiteSpace: 'nowrap'
            },
            registerInfo: {
                num: 0,
                value0: '',
                value1: '',
                value2: '',
                value3: '',
                value4: '',
                value5: '',
                value6: ''
            },
            hasScanSnList: [{
                value0: '11111111111111111111111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
                value4: '111',
            },
            ],
            delContent: null,
            staffList: [],
        };
    },
    onLoad(option) { },
    onShow() {
        let that = this
        uni.$off('scan') // æ¯æ¬¡è¿›æ¥å…ˆ ç§»é™¤å…¨å±€è‡ªå®šä¹‰äº‹ä»¶ç›‘听器
        uni.$on('scan', function (data) {
            console.log('onscan');
            //扫码成功后的回调,你可以写自己的逻辑代码在这里
            console.log('扫码结果:', data.code);
            that.scanHandle(data.code)
            that.$forceUpdate();
        })
    },
    onNavigationBarButtonTap() {
        this.goScan()
    },
    onReady() { },
    methods: {
        //WDR
        openWDR() {
            this.$refs.openWDR.open();
        },
        // å¼¹æ¡†ä¿å­˜
        confirmWDR() {
            console.log('保存', this.registerInfo.value6);
            // è¯·æ±‚接口,根据工单号查询其他信息并赋值
        },
        //零件号
        openPN() {
            this.$refs.openPN.open();
        },
        // å¼¹æ¡†ä¿å­˜
        confirmPN() {
            console.log('保存', this.registerInfo.value6);
            // è¯·æ±‚接口,根据工单号查询其他信息并赋值
        },
        //批次号
        openBatch() {
            this.$refs.openBatch.open();
        },
        // å¼¹æ¡†ä¿å­˜
        confirmBatch() {
            console.log('保存', this.registerInfo.value3);
            // è¯·æ±‚接口,根据工单号查询其他信息并赋值
        },
        //库位号
        openLocation() {
            this.$refs.openLocation.open();
        },
        // å¼¹æ¡†ä¿å­˜
        confirmLocation() {
            console.log('保存', this.registerInfo.value4);
            // è¯·æ±‚接口,根据工单号查询其他信息并赋值
        },
        //盘点数量
        openPhysicalInventory() {
            this.$refs.openPhysicalInventory.open();
        },
        // å¼¹æ¡†ä¿å­˜
        confirmPhysicalInventory() {
            console.log('保存', this.registerInfo.value5);
            // è¯·æ±‚接口,根据工单号查询其他信息并赋值
        },
        setNo(val) {
            console.log('11111', val)
            this.registerInfo.value1 = val.value1
            this.registerInfo.value2 = val.value2
        },
        //盘点报告号
        seachPersonnelNo() {
            console.log('11111')
            uni.navigateTo({
                url: '/pages/wareHouse/inventory/orderList'
            })
        },
        goScan() {
            uni.scanCode({
                scanType: ['qrCode'],
                success: res => {
                    try {
                        console.log('扫码结果:', res);
                        this.scanHandle(res.result)
                    } catch (e) { }
                }
            });
        },
        scanHandle(scanresult) {
            scanresult = scanresult.replace(/[\r\n]/g, "")
            if (scanresult.indexOf('{') > -1) {
                //二维码
                const result = JSON.parse(scanresult)
                //增加SN校验
                if (result.sn_no && result.sn_no != null && result.sn_no != '') {
                    if (this.hasScanSnList.length > 0) {
                        let hasScanSnIndex = this.hasScanSnList.indexOf(result.sn_no)
                        if (hasScanSnIndex < 0) {
                            this.hasScanSnList.push(result.sn_no)
                        } else {
                            this.$u.toast('请勿重复扫描')
                        }
                    } else {
                        this.hasScanSnList.push(result.sn_no)
                    }
                }
            } else {
                //增加SN校验
                if (this.hasScanSnList.length > 0) {
                    let hasScanSnIndex = this.hasScanSnList.indexOf(scanresult)
                    if (hasScanSnIndex < 0) {
                        this.hasScanSnList.push(scanresult)
                    } else {
                        this.$u.toast('请勿重复扫描')
                    }
                } else {
                    this.hasScanSnList.push(scanresult)
                }
            }
        },
        goSubmit() {
            // if (this.registerInfo.shiftId == null || this.registerInfo.shiftId == '') {
            //     this.$u.toast('请选择班次')
            //     return
            // }
            // if (this.registerInfo.value3 == null || this.registerInfo.value3 == '') {
            //     this.$u.toast('请选择日期')
            //     return
            // }
            // if (this.registerInfo.locNo == null || this.registerInfo.locNo == '') {
            //     this.$u.toast('请选择包装库位')
            //     return
            // }
            // if (this.hasScanSnList.length == 0) {
            //     this.$u.toast('无待提交的SN号明细')
            //     return
            // }
            // let registrList = []
            // this.staffList = []
            // this.staffNameList.forEach((item) => {
            //     this.staffList.push({
            //         staffId: item.id
            //     })
            // })
            // this.hasScanSnList.forEach((item) => {
            //     registrList.push({
            //         shiftId: this.registerInfo.shiftId,
            //         value3: this.registerInfo.value3,
            //         locNo: this.registerInfo.locNo,
            //         partBatchNo: item,
            //         staffList: this.staffList
            //     })
            // })
            // this.$u.api.pigxPacking.addPackageRegister(registrList).then(res => {
            //     let resData = res.data
            //     this.hasScanSnList = []
            //     this.$u.toast('提交成功')
            // }).catch((e) => {
            // })
        },
    }
};
</script>
<style lang="scss" scoped>
.textST {
    font-size: 14px;
    margin-bottom: 5px;
}
.packing-registration-bg {
    background-color: #F6F9FF;
    background-image: url('~@/static/custom/packing/backBg.png');
    padding: 0 20rpx;
    background-attachment: fixed;
    background-size: 100% auto;
    background-repeat: no-repeat;
    position: fixed;
    top: 0;
    bottom: 0;
    width: 100%;
    z-index: -1;
}
.packing-registration-param {
    padding: 40rpx 30rpx 10rpx 30rpx;
    .packing-registration-param-title {
        display: flex;
        flex-direction: row;
        align-items: center;
        margin-bottom: 30rpx;
        .title-label {
            margin-left: 14rpx;
            font-size: 34rpx;
            font-weight: bold;
            color: #283E65;
        }
    }
    .packing-registration-param-view {
        height: 440rpx;
        background-color: #fff;
        border-radius: 10rpx;
        padding: 0rpx 23rpx;
        margin-bottom: 30rpx;
        .packing-registration-param-item {
            height: 90rpx;
            border: 1px solid #ADC8E4;
            line-height: 90rpx;
            display: flex;
            justify-content: space-between;
            border: none;
            .packing-registration-param-item-left {
                .item-one {
                    font-size: 30rpx;
                    color: #666666;
                }
            }
            .packing-registration-param-item-right {
                display: flex;
                justify-content: space-between;
                .item-one {
                    font-size: 30rpx;
                    color: #333333;
                    margin-right: 6rpx;
                }
                .item-two {
                    font-size: 30rpx;
                    color: #A6B4CC;
                    margin-right: 6rpx;
                }
                .item-three {
                    font-size: 30rpx;
                    color: #214DED;
                    margin-right: 6rpx;
                }
            }
        }
        .param-extra {
            border-bottom: 1px solid #EDEDED;
        }
    }
}
.wrap .packing-registration-scroll-list {
    height: calc(100vh - var(--window-top) - var(--window-bottom) - 780rpx);
    width: 100%;
}
.packing-registration-scroll-list-group {
    ::v-deep .u-cell-item-box {
        background-color: rgba(250, 252, 255, 0.36) !important;
        padding: 0rpx 30rpx;
    }
    .content {
        font-size: 12px;
        background-color: #ffffff;
        box-sizing: border-box;
        border-radius: 10rpx;
        margin: 0rpx 0rpx 16rpx;
        padding: 20rpx 8rpx;
        box-shadow: none;
        display: flex;
        align-items: center;
        .content-header {
            width: 40rpx;
            height: 90rpx;
            display: flex;
            align-items: center;
            .content-header-icon {
                background-image: url("~@/static/custom/moveWareHouse/header_icon.png");
                background-size: 100% auto;
                background-repeat: no-repeat;
                height: 28rpx;
                width: 28rpx;
            }
            .content-header-title {
                margin-left: 11rpx;
                font-size: 26rpx;
                font-weight: bold;
                color: #626369;
            }
        }
        .content-body {
            flex: 1;
            background-color: #ffffff;
            border-radius: 10rpx;
            padding: 0rpx 23rpx;
            .row-list {
                height: 60rpx;
                display: flex;
                flex-direction: row;
                padding: 0px;
                align-items: center;
            }
            .row-list ._label {
                display: flex;
                flex: 0.8;
                color: #909399;
                align-items: center;
                ._label-name {
                    margin-left: 11rpx;
                    font-size: 26rpx;
                    font-weight: 500;
                    color: #666666;
                }
            }
            .row-list ._content {
                flex: 1.5;
                text-align: right;
                color: #909399;
                font-size: 24rpx;
            }
            .row-list .s1 {
                color: #d35651;
            }
        }
    }
}
.registration-form-footer {
    display: flex;
    margin-top: 10rpx;
    margin-bottom: 10rpx;
    margin-left: 20rpx;
    margin-right: 20rpx;
    padding-bottom: 14rpx;
    .btn {
        flex: 1;
        margin: 10rpx;
        background: #214DED;
        box-shadow: 0rpx 6rpx 8rpx 0rpx rgba(4, 49, 212, 0.3);
        font-weight: bold;
        color: #FEFEFE;
        font-family: PingFang SC;
    }
}
</style>