yyb
4 天以前 401c336a14f1a523d9873d4cad6edc13ad43e4d2
车间订单取消下发功能点逻辑编写
已修改1个文件
571 ■■■■ 文件已修改
pages/product/WorkshopOrderCancellationIssued/index.vue 571 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/product/WorkshopOrderCancellationIssued/index.vue
@@ -1,9 +1,8 @@
//车间订单取消下发
// 车间订单下发
<template>
    <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" />
        <view class="packing-registration-param">
            <view class="packing-registration-param-view">
@@ -12,8 +11,9 @@
                        <text class="item-one">订单号</text>
                    </view>
                    <view class="packing-registration-param-item-right">
                        <text class="item-one item-two" @click="seachPersonnelNo()">{{ registerInfo.value1 == '' ?
                            "点击选择" : registerInfo.value1 }}</text>
                        <text class="item-one item-two" @click="seachPersonnelNo()">{{
              registerInfo.value1 == "" ? "点击选择" : registerInfo.value1
            }}</text>
                        <u-icon name="arrow-right" color="#687792" size="28" @click="seachPersonnelNo()"
                            v-show="registerInfo.value1 == ''"></u-icon>
                    </view>
@@ -36,7 +36,7 @@
                        <view class="content-body">
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">订单号:</view>
                                    <view class="_label-name">批号</view>
                                </view>
                                <view class="_content">
                                    {{ item.value0 }}
@@ -44,7 +44,7 @@
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">子件:</view>
                                    <view class="_label-name">零件号:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value1 }}
@@ -55,7 +55,15 @@
                                    <view class="_label-name">零件描述:</view>
                                </view>
                                <view class="_content">
                                    {{ item.value0 }}
                                    {{ item.value2 }}
                                </view>
                            </view>
                            <view class="row-list">
                                <view class="_label">
                                    <view class="_label-name">取消下发数量</view>
                                </view>
                                <view class="_content">
                                    {{ item.value3 }}
                                </view>
                            </view>
                        </view>
@@ -64,342 +72,307 @@
            </scroll-view>
            <scan></scan>
        </view>
        <u-modal v-model="showModal" title="" :show-cancel-button="true" :show-confirm-button="true" @confirm="confirm"
            @cancel="cancel">
            <view class="popup-content">
                <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">
                                <text class="item-one item-two">{{ modalList.value }}</text>
                            </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">
                                <text class="item-one item-two">{{ modalList.value1 }}</text>
                            </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">
                                <text class="item-one item-two">{{ modalList.value2 }}</text>
                            </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">
                                <u-input class="item-one item-two" v-model="modalList.value3" />
                            </view>
                        </view>
                    </view>
                </view>
            </view>
        </u-modal>
    </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'
            },
            registerInfo: {
                value1: '',
            },
            hasScanSnList: [{
                value0: '11111111111111111111111',
                value1: '111',
                value2: '111',
                value3: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '111',
            },
            {
                value0: '111',
                value1: '111',
                value2: '111',
                value3: '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
    import scan from "@/components/scan/scan.vue";
    import content_bg from "@/static/custom/packing/backBg.png";
    export default {
        components: {
            scan,
        },
        //订单号
        seachPersonnelNo() {
            console.log('车间订单号')
            uni.navigateTo({
                url: '/pages/product/report/orderList'
            })
        },
        goScan() {
            uni.scanCode({
                scanType: ['qrCode'],
                success: res => {
                    try {
                        console.log('扫码结果:', res);
                        this.scanHandle(res.result)
                    } catch (e) { }
                }
        data() {
            return {
                background: {
                    backgroundImage: `url(${content_bg})`,
                    backgroundAttachment: "fixed",
                    backgroundSize: "100% auto",
                    backgroundRepeat: "no-repeat",
                },
                labelStyle: {
                    fontSize: "32rpx",
                    whiteSpace: "nowrap",
                },
                //弹窗列表
                modalList: {
                    value: "",
                    value1: "",
                    value2: "",
                    value3: "",
                },
                registerInfo: {
                    value1: "",
                },
                hasScanSnList: [{
                        value0: "11111111111111111111111",
                        value1: "111",
                        value2: "111",
                        value3: "111",
                    },
                    {
                        value0: "111",
                        value1: "111",
                        value2: "111",
                        value3: "111",
                    },
                    {
                        value0: "111",
                        value1: "111",
                        value2: "111",
                        value3: "111",
                    },
                ],
            };
        },
        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();
            });
        },
        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)
                }
            }
        methods: {
            // 点击确认后获取下发记录
            confirm() {
                // 处理确认逻辑
                this.showModal = false;
                this.$u.api.workReporting
                ._({}).then((res) => {
                    console.log("res", res);
                    this.hasScanSnList = res.data.records;
                });
            },
            // 模态框取消
            cancel() {
                this.showModal = false; // 关闭弹窗
            },
            setNo(val) {
                console.log("11111", val);
                this.registerInfo.value1 = val.value1;
            },
            //订单号
            seachPersonnelNo() {
                console.log("车间订单号");
                uni.navigateTo({
                    url: "/pages/product/report/orderList",
                });
            },
        },
        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>
.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-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-view {
        height: 180rpx;
        background-color: #fff;
        border-radius: 10rpx;
        padding: 0rpx 23rpx;
        margin-bottom: 30rpx;
    .packing-registration-param {
        padding: 40rpx 30rpx 10rpx 30rpx;
        .packing-registration-param-item {
            height: 90rpx;
            border: 1px solid #ADC8E4;
            line-height: 90rpx;
        .packing-registration-param-title {
            display: flex;
            justify-content: space-between;
            border: none;
            flex-direction: row;
            align-items: center;
            margin-bottom: 30rpx;
            .packing-registration-param-item-left {
                .item-one {
                    font-size: 30rpx;
                    color: #666666;
                }
            .title-label {
                margin-left: 14rpx;
                font-size: 34rpx;
                font-weight: bold;
                color: #283e65;
            }
        }
            .packing-registration-param-item-right {
        .packing-registration-param-view {
            height: 180rpx;
            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;
                .item-one {
                    font-size: 30rpx;
                    color: #333333;
                    margin-right: 6rpx;
                .packing-registration-param-item-left {
                    .item-one {
                        font-size: 30rpx;
                        color: #666666;
                    }
                }
                .item-two {
                    font-size: 30rpx;
                    color: #A6B4CC;
                    margin-right: 6rpx;
                }
                .packing-registration-param-item-right {
                    display: flex;
                    justify-content: space-between;
                .item-three {
                    font-size: 30rpx;
                    color: #214DED;
                    margin-right: 6rpx;
                    .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;
            .param-extra {
                border-bottom: 1px solid #ededed;
            }
        }
    }
}
.wrap .packing-registration-scroll-list {
    height: calc(100vh - var(--window-top) - var(--window-bottom) - 400rpx);
    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;
    .wrap .packing-registration-scroll-list {
        height: calc(100vh - var(--window-top) - var(--window-bottom) - 400rpx);
        width: 100%;
    }
    .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;
    .packing-registration-scroll-list-group {
        ::v-deep .u-cell-item-box {
            background-color: rgba(250, 252, 255, 0.36) !important;
            padding: 0rpx 30rpx;
        }
        .content-header {
            width: 40rpx;
            height: 90rpx;
        .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-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;
            .content-header {
                width: 40rpx;
                height: 90rpx;
                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 {
                .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: 500;
                    color: #666666;
                    font-weight: bold;
                    color: #626369;
                }
            }
            .row-list ._content {
                flex: 1.5;
                text-align: right;
                color: #909399;
                font-size: 24rpx;
            }
            .content-body {
                flex: 1;
                background-color: #ffffff;
                border-radius: 10rpx;
                padding: 0rpx 23rpx;
            .row-list .s1 {
                color: #d35651;
                .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>