| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404 | <template>    <view class="content"><!-- labelAlign="right" -->        <up-form :model="form" labelWidth="70" ref="uFormRef">            <view class="title" style="margin-top: 0;">                服务信息            </view>            <up-form-item label="产品品类" :required="rules.class1[0].required" prop="class1">                <up-radio-group v-model="form.class1">                    <up-radio :customStyle="{ marginLeft: '12px' }" v-for="(item) in class1" :key="item.value"                        :label="item.value" :name="item.value">                    </up-radio>                </up-radio-group>            </up-form-item>            <up-form-item label="服务类型" :required="rules.servicetype[0].required" prop="servicetype">                <up-radio-group v-model="form.servicetype">                    <up-radio :customStyle="{ marginLeft: '12px' }" v-for="(item) in ['安装', '维修', '清洗']" :key="item"                        :label="item" :name="item">                    </up-radio>                </up-radio-group>            </up-form-item>            <up-form-item label="服务地址" :required="rules.province[0].required" prop="province">                <picker class="picker" mode="region" :value="[form.province, form.city, form.county]"                    @change="changeRegion">                    {{ [form.province, form.city, form.county].join("-") || '选择省市县' }}                </picker>            </up-form-item>            <view style="margin-top: -30rpx;">                <up-form-item label="" prop="address">                    <up-textarea maxlength="499" v-model="form.address" placeholder="详细地址" autoHeight height="20" />                </up-form-item>            </view>            <up-form-item label="联系人" :required="rules.scenecontact[0].required" prop="scenecontact">                <up-input v-model="form.scenecontact" placeholder="联系人" clearable />            </up-form-item>            <up-form-item label="联系人电话" :required="rules.scenecontactphonenumber[0].required"                prop="scenecontactphonenumber">                <up-input type="number" v-model="form.scenecontactphonenumber" placeholder="联系人电话" clearable />            </up-form-item>            <view class="title">                产品信息            </view>            <up-form-item label="序列号" :required="rules.sku[0].required" prop="sku">                <up-input v-model="form.sku" :disabled="detail.sku" placeholder="序列号" clearable @blur="skuConfirm">                    <template #suffix>                        <up-icon v-if="!detail.sku" name="scan" color="#2979ff" size="28" @click="openScan" />                    </template>                </up-input>            </up-form-item>            <up-form-item label="产品名称" prop="itemname">                <up-input v-model="form.itemname" disabled placeholder="选择产品">                    <!-- <template #suffix>                        <up-button v-if="!disabled" type="success" size="mini" text="选择产品" @click="toSelectProduct" />                    </template> -->                </up-input>            </up-form-item>            <up-form-item label="产品型号" prop="model">                <up-input v-model="form.model" disabled placeholder="型号" />            </up-form-item>            <up-form-item label="经销商" prop="serviceenterprisename">                <up-textarea maxlength="499" v-model="form.serviceenterprisename" disabled placeholder="经销商" autoHeight                    height="20" />            </up-form-item>            <up-form-item label="客户名称" prop="contact">                <up-input v-model="form.contact" disabled placeholder="客户名称" />            </up-form-item>            <up-form-item label="客户电话" prop="phonenumber">                <up-input v-model="form.phonenumber" :disabled="detail.sku" placeholder="客户电话">                    <template #suffix>                        <up-button v-if="!detail.sku" type="success" :disabled="!form.phonenumber" size="mini" text="查询"                            @click="phonenumberConfirm" />                    </template>                </up-input>            </up-form-item>            <up-form-item label="保修卡号" prop="cardno">                <up-input v-model="form.cardno" disabled placeholder="保修卡号" />            </up-form-item>        </up-form>        <view style="padding-bottom: 50px;width: 350rpx;margin: 40rpx auto 0;" @click="save">            <My-button text="保存" :loading="loading" />        </view>    </view>    <up-popup :show="products.length" @close="closePopup" :customStyle="{        width: '80vw',    }" mode="right">        <scroll-view :safeAreaInsetBottom="false" scroll-y style="width: 100%;height: 100vh;">            <view class="product" v-for="item in products" :key="item.itemid" hover-class="navigator-hover"                @click="changeItem(item)">                <view class="itemname">                    {{ item.itemname }}                </view>                <view class="row">                    序列号: {{ item.sku || '--' }}                </view>                <view class="row">                    产品编号: {{ item.itemno || '--' }}                </view>                <view class="row">                    产品型号: {{ item.model || '--' }}                </view>                <view class="row">                    经销商: {{ item.enterprisename || '--' }}                </view>                <view class="row">                    用户信息: {{ item.name || '--' }} {{ item.phonenumber || '--' }}                </view>            </view>            <view style="height: 30px;" />        </scroll-view>    </up-popup></template><script setup>import { ref, reactive, getCurrentInstance } from 'vue';const { $Http } = getCurrentInstance().proxy;import { onLoad } from '@dcloudio/uni-app';const uFormRef = ref(null);const form = reactive({    class1: '', // 产品品类    servicetype: '', // 服务类型    address: "", // 详细地址    province: '', // 省份    city: '', // 城市    county: '', // 区县    scenecontact: '', // 联系人    scenecontactphonenumber: '', // 联系人电话    sku: '', // 序列号    'contact': "", // 客户名称    'itemid': "", //    产品ID    'itemname': "", // 产品名称    'itemno': "", // 产品编号    'model': "", // 型号    'phonenumber': "", // 客户电话    'unitname': "", // 计量单位    'spec': "", // 规格    serviceenterprisename: "", //  经销商    cardno: "" // 保修卡号});const rules = reactive({    class1: [{ required: true, message: '请选择产品品类', trigger: 'change' }],    servicetype: [{ required: true, message: '请选择服务类型', trigger: 'change' }],    province: [{ required: true, message: '请选择省市县', trigger: 'change' }],    address: [{ required: true, message: '请输入详细地址', trigger: 'blur' }],    scenecontact: [{ required: true, message: '请输入联系人', trigger: 'blur' }],    sku: [{ required: true, message: '请输入序列号', trigger: 'blur' }],    scenecontactphonenumber: [{ required: true, message: '请输入联系人电话', trigger: 'blur', pattern: /^1(3[0-9]|4[01456879]|5[0-35-9]|6[2567]|7[0-8]|8[0-9]|9[0-35-9])\d{8}$/, message: '请输入正确的手机号码' }],});const class1 = ref(''); // 产品品类let sa_workorderid = 0;onLoad((options) => {    sa_workorderid = options.id;    getDetail()    $Http.getClass('prodclass1').then(res => {        uFormRef.value.setRules(rules);        class1.value = res.data;        if (res.code !== 1) return uni.showToast({ title: res.msg, icon: 'none' });    });});let detail = reactive({});// 保存let loading = ref(false);function save() {    if (querySku.value === false) return uni.showToast({ title: '序列号不正确', icon: 'none' });    if (loading.value) return;    uFormRef.value.validate().then(valid => {        if (valid) {            let content = {                "sa_workorderid": sa_workorderid,                sa_serviceorderid: detail.sa_serviceorderid,                ...form            };            loading.value = true;            $Http.basic({                "id": "20230208140003",                content            }).then(res => {                loading.value = false;                console.log("保存工单", res);                uni.showToast({ title: res.code !== 1 ? res.msg : "保存成功", icon: 'none', mask: res.code == 1 });                if (res.code == 1) setTimeout(() => {                    uni.navigateBack();                }, 500);            }).catch(err => {                loading.value = false;                console.error("保存工单失败", err);                uni.showToast({ title: '保存失败,请稍后重试', icon: 'none' });            });        }    })}let disabled = ref(false);function getDetail() {    $Http.basic({ "id": "20230208140103", "content": { "nocache": true, sa_workorderid } }).then(res => {        console.log("工单详情", res)        if (res.code !== 1) return uni.showToast({ title: res.msg, icon: 'none' });        detail = reactive(res.data);        for (const key in form) {            if (detail[key] !== undefined) {                form[key] = detail[key];            }        }        disabled.value = detail.item ? true : false    })}function changeRegion(e) {    form.province = e.detail.value[0];    form.city = e.detail.value[1];    form.county = e.detail.value[2];}let querySku = ref(true); // SKU是否正确function skuConfirm() {    if (form.sku) {        ['contact', 'serviceenterprisename', 'cardno', 'itemid', 'itemname', 'itemno', 'model', 'phonenumber', 'unitname', 'spec'].forEach(key => {            form[key] = '';        });        $Http.basic({            "id": 2025080813465203,            "content": {                "pageNumber": 1,                "pageSize": 1,                "where": {                    condition: form.sku,                }            }        }).then(res => {            console.log(res)            if (res.code !== 1) return uni.showToast({ title: res.msg, icon: 'none' });            if (res.data.length === 0 || res.data[0].sku !== form.sku) {                uni.showToast({ title: '未找到对应的产品信息', icon: 'none' });                querySku.value = false;                return;            }            querySku.value = true;            res.data[0].contact = res.data[0].name;            res.data[0].serviceenterprisename = res.data[0].serviceenterprisename || res.data[0].enterprisename;            ['contact', 'phonenumber', 'serviceenterprisename', 'cardno', 'itemid', 'itemname', 'itemno', 'model', 'unitname', 'spec'].forEach(key => {                form[key] = res.data[0][key] || '';            });            uni.showToast({ title: '已填充表单', icon: 'none' });        })    } else {        form.sku = '';    }}let products = ref([]); // 产品列表function closePopup() {    products.value = [];}function changeItem(item) {    item.contact = item.name;    if (item.itemid == detail.itemid) {        handle();    } else {        uni.showModal({            title: '提示',            content: `当前选择的产品与工单中的产品不一致,是否继续?`,            success: function ({ confirm }) {                if (confirm) handle()            }        });    }    function handle() {        item.serviceenterprisename = item.serviceenterprisename || item.enterprisename;        ['contact', 'serviceenterprisename', 'sku', 'cardno', 'itemid', 'itemname', 'itemno', 'model', 'phonenumber', 'unitname', 'spec'].forEach(key => {            form[key] = item[key] || '';        });        uni.showToast({ title: '已填充表单', icon: 'none' });        querySku.value = true;        closePopup();    }}function phonenumberConfirm() {    // 校验手机号    let reg = /^1(3[0-9]|4[01456879]|5[0-35-9]|6[2567]|7[0-8]|8[0-9]|9[0-35-9])\d{8}$/;    if (!reg.test(form.phonenumber)) {        return uni.showToast({ title: '请输入正确的手机号', icon: 'none' });    }    $Http.basic({        "id": 2025080813465203,        "content": {            "pageNumber": 1,            "pageSize": 50,            phonenumber: form.phonenumber,            "where": {                // phonenumber: form.phonenumber,            }        }    }).then(res => {        console.log("根据用户手机查询", res)        if (res.code !== 1) return uni.showToast({ title: res.msg, icon: 'none' });        if (res.data.length === 0) return uni.showToast({ title: '未找到对应的客户信息', icon: 'none' });        if (res.data.length == 1 && detail.itemid == res.data[0].itemid) {            changeItem(res.data[0]);        } else {            products.value = res.data;        }    })}function openScan() {    uni.scanCode({        onlyFromCamera: true,        scanType: ['qrCode', 'barCode'],        success: (res) => {            console.log("扫码结果", res);            if (res.result) {                form.sku = res.result;                skuConfirm();            } else {                uni.showToast({ title: '扫码失败,请重试', icon: 'none' });            }        },        fail: (err) => {            console.error("扫码失败", err);            uni.showToast({ title: '扫码失败,请重试', icon: 'none' });        }    });}//去选择产品function toSelectProduct() {    uni.navigateTo({        url: '/pages/select/product'    });    $Http.onSelected = (item) => {        ['contact', 'serviceenterprisename', 'sku', 'cardno', 'itemid', 'itemname', 'itemno', 'model', 'phonenumber', 'unitname', 'spec'].forEach(key => {            form[key] = item[key] || '';        });        uni.navigateBack()        delete $Http.onSelected    }}</script><style lang="scss" scoped>.content {    width: 100vw;    padding: 20px;    box-sizing: border-box;    min-height: 100vh;    background: #fff;    .picker {        width: 100%;        // border-bottom: 1px solid #dadbde;        font-size: 32rpx;        color: #606266;        padding: 9px;        border-radius: 8rpx;    }    .title {        font-size: 34rpx;        color: #4773EE;        margin: 20rpx 0;        font-weight: bold;    }}.product {    padding: 20rpx;    background: #fff;    margin: 10rpx 0;    border-radius: 8rpx;    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);    .itemname {        font-size: 32rpx;        color: #333;        font-weight: bold;        margin-bottom: 10rpx;    }    .row {        font-size: 28rpx;        color: #666;        margin-top: 8rpx;    }}</style>
 |