You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
591 lines
18 KiB
591 lines
18 KiB
<template>
|
|
|
|
<view style="display: flex;flex-direction: column;">
|
|
|
|
<view class="top">
|
|
<NavBar ref="nav" navTitle="详情" :showIcon="true" :start-change-height="page.startHeight"
|
|
:end-change-height="page.endHeight">
|
|
</NavBar>
|
|
<view style="display: flex;flex-direction: column;margin-top: 25vw; margin-left: 5vw;">
|
|
<view style="font-size: 17px;color: #fff;height: 8vw;line-height: 8vw;margin-top: 5vw;">
|
|
{{data.state}}
|
|
</view>
|
|
<view
|
|
style="font-size: 12px;color: white;line-height: 7vw;height: 7vw;color: #fff;box-sizing: border-box;">
|
|
卡号:{{data.serialNumber}}
|
|
</view>
|
|
<view style="font-size: 12px;color: white;line-height: 7vw;height: 7vw;color: #fff;">
|
|
{{data.time}}
|
|
</view>
|
|
</view>
|
|
|
|
</view>
|
|
<view
|
|
style="display: flex;flex-direction: row;justify-content: center;
|
|
background-color: #fff;height: 25vw; border-top-left-radius: 25px;border-top-right-radius: 25px;margin-top: -9.06vw;">
|
|
|
|
<image src="https://supervise.yxtsoft.com/lpk/image/giftpack.png" mode="aspectFit"
|
|
style="margin-left: 20px;margin-right: 20px; width: 80vw;height: 25vw;"></image>
|
|
|
|
<text style="color: #fff;font-size: 18px;z-index: 10;position: absolute;margin-top: 11vw;">{{data.pname}}</text>
|
|
|
|
</view>
|
|
<loading-state ref="pageView" @request="request">
|
|
|
|
<view style="background-color: #fff;margin-top: 10px;padding: 10px 15px;">
|
|
|
|
<view style="display: flex;flex-direction: row;align-items: center;">
|
|
<view style="background: #FF9D33; border-radius: 50%;width: 12px;height: 12px;"></view>
|
|
<view style="background: #FFDAB2; border-radius: 50%;width: 12px;height: 12px;"></view>
|
|
<text style="margin-left: 8px;font-size: 14px;color: #333;">商品明细</text>
|
|
</view>
|
|
|
|
</view>
|
|
|
|
<view v-for="(item,index) in data.goodsVos" :key="index" @click="itemClick(item.goodsSid)"
|
|
style="display: flex;flex-direction: row;background-color: #fff;padding-left: 10px;padding-right: 10px;">
|
|
|
|
<view style="display: flex;flex-direction: row;background-color: #fff;padding: 10px 15px;
|
|
border-bottom: 1px #F1F2F3 solid; width: 100%;">
|
|
<image :src="item.pic" style="width: 60px;height: 60px;flex-shrink: 0;"></image>
|
|
<view style="margin-left: 10px;margin-right: 10px;flex: 1;">
|
|
<text class="text" style="font-weight: 500;">{{item.goods}}
|
|
</text>
|
|
<view style="font-size: 12px;color: #666666;margin-top: 5px;">{{item.remarks}}</view>
|
|
<view style="display: flex;flex-direction: row;justify-content: space-between;margin-top: 5px;">
|
|
<text
|
|
style="font-size: 12px;color: #666666;margin-right: 10px;">总数:{{item.num}}{{item.unitName}}
|
|
</text>
|
|
<view style="font-size: 12px;color: #666666;">可预约:{{item.lnum}}{{item.unitName}}</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
<view style="background-color: #fff;margin-top: 10px;padding: 10px 15px;">
|
|
|
|
<view style="display: flex;flex-direction: row;align-items: center;">
|
|
<view style="background: #FF9D33; border-radius: 50%;width: 12px;height: 12px;"></view>
|
|
<view style="background: #FFDAB2; border-radius: 50%;width: 12px;height: 12px;"></view>
|
|
<text style="margin-left: 8px;font-size: 14px;color: #333;">预约记录</text>
|
|
</view>
|
|
|
|
</view>
|
|
|
|
|
|
<view v-for="(item,index) in data.orderCardVoList" :key="index"
|
|
style="display: flex;flex-direction: row;background-color: #fff;padding-left: 10px;padding-right: 10px;">
|
|
|
|
<view style="display: flex;flex-direction: column;background-color: #fff;
|
|
border-bottom: 1px #F1F2F3 solid; width: 100%;padding-left: 20px;padding-bottom: 10px;">
|
|
<view style="display: flex;flex-direction: row;align-items: center;margin-top: 10px;">
|
|
<image src="https://supervise.yxtsoft.com/lpk/image/date.png" style="width: 20px;height: 20px;">
|
|
</image>
|
|
<text style="margin-left: 5px;font-size: 12px; color: #999;">提货时间:{{item.reserveDate}}</text>
|
|
</view>
|
|
<view style="display: flex;flex-direction: row;align-items: center;margin-top: 5px;">
|
|
<image src="https://supervise.yxtsoft.com/lpk/image/location.png"
|
|
style="width: 20px;height: 20px;">
|
|
</image>
|
|
<text style="margin-left: 5px;font-size: 12px; color: #999;">提货地点:{{item.store}}</text>
|
|
</view>
|
|
<view style="display: flex;flex-direction: row;align-items: center;margin-top: 5px;">
|
|
<image src="https://supervise.yxtsoft.com/lpk/image/user2.png" mode="aspectFill"
|
|
style="width: 20px;height: 20px;">
|
|
</image>
|
|
<text
|
|
style="margin-left: 5px;font-size: 12px; color: #999;">提 货 人:{{item.userName}}</text>
|
|
</view>
|
|
<view style="display: flex;flex-direction: row;align-items: center;margin-top: 5px;">
|
|
<image src="https://supervise.yxtsoft.com/lpk/image/phone2.png" mode="aspectFill"
|
|
style="width: 20px;height: 20px;">
|
|
</image>
|
|
<text style="margin-left: 5px;font-size: 12px; color: #999;">联系电话:{{item.userPhone}}</text>
|
|
</view>
|
|
<view style=" display: flex;flex-direction: row;align-items: center;margin-top: 8px;">
|
|
<text style="color: #999; font-size: 12px;">- {{item.goods}}</text>
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
<view style="height: 50px;"></view>
|
|
|
|
<view v-if="data.notRese" style="width: 100%; background-color: #fff;height: 15vw;position: fixed;bottom: 0;overflow:hidden;
|
|
display: flex;flex-direction: row;" >
|
|
<view style="flex: 1;"></view>
|
|
<text style=" width: 20vw;font-size: 16px;color: #fff; background-color: #FF9D33;
|
|
padding: 10px 20px; display:margin:auto;text-align: center;line-height: 10vw;" @click="showDialog">预约提货</text>
|
|
|
|
</view>
|
|
|
|
|
|
</loading-state>
|
|
<!-- <view>
|
|
<image src="../../static/edit_bg.png" style="width: 100%;height: 40vw;z-index: 0;"></image>
|
|
<view style="display: flex;flex-direction: column;margin-top: -40vw;">
|
|
<view style="display: flex;flex-direction: row;justify-content: space-between;align-items: center;">
|
|
<view style="flex: 1;display: flex;flex-direction: column;z-index: 1;margin-left: 15px;">
|
|
<view style="font-size: 17px;color: #FFFFFF;height: 8vw;line-height: 8vw;margin-top: 5vw;">
|
|
{{data.state}}
|
|
</view>
|
|
<view
|
|
style="font-size: 12px;color: white;line-height: 7vw;height: 7vw;color: #f1f2f3;box-sizing: border-box;">
|
|
{{data.name}}
|
|
</view>
|
|
<view style="font-size: 12px;color: white;line-height: 4vw;height: 4vw;color: #f1f2f3;">
|
|
{{data.time}}
|
|
</view>
|
|
</view>
|
|
<image src='../../static/gift2.png'
|
|
style="width: 40px;height: 40px;padding-right: 30px;flex-shrink: 0;">
|
|
</image>
|
|
</view>
|
|
|
|
<view
|
|
style="background: #FFFFFF;border-radius: 20rpx;z-index: 1;height: 14vw;margin-left: 15px;margin-right: 15px;margin-top: 4vw;display: flex;align-items: center;">
|
|
<image src="../../static/pName.png" style="width: 15px;height: 15px;margin-left: 15px;"></image>
|
|
<view style="margin-left: 15px;font-size: 14px;">{{data.pname}}</view>
|
|
</view>
|
|
|
|
<view style="background: #FFFFFF;border-radius: 20rpx;padding: 15px;margin: 10px 15px;">
|
|
|
|
<view
|
|
style="display: flex;flex-direction: row;align-items: center;border-bottom: 1rpx #f1f2f3 solid;padding-bottom: 10px;">
|
|
<image src="../../static/mingxi.png" style="width: 15px;height: 15px;"></image>
|
|
<view style="margin-left: 10px;font-size: 14px;">商品明细</view>
|
|
</view>
|
|
<view v-for="(item,index) in data.goodsVos" :key="index" @click="itemClick(item.goodsSid)"
|
|
style="display: flex;flex-direction: row;margin-top: 15px;">
|
|
<image :src="item.pic" style="width: 60px;height: 60px;flex-shrink: 0;"></image>
|
|
<view style="margin-left: 10px;margin-right: 10px;flex: 1;">
|
|
<text class="text" style="font-weight: 500;">{{item.goods}}
|
|
</text>
|
|
<view style="font-size: 12px;color: #666666;margin-top: 10px;">{{item.remarks}}</view>
|
|
</view>
|
|
<view style="display: flex;flex-direction: row;">
|
|
<text style="font-size: 12px;color: #666666;margin-right: 10px;">总数:{{item.num}}
|
|
</text>
|
|
<view style="font-size: 12px;color: #666666;">剩余:{{item.lnum}}</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
<view style="height: 60px;"></view>
|
|
<view v-if="data.showBtn||data.showRecord"
|
|
style="position: fixed;bottom: 0;height: 50px;background: #f3f4f6;border-top: 1rpx #cacaca solid;width: 100%;display: flex;flex-direction: row;box-sizing: border-box;align-items: center;padding-right: 15px;">
|
|
<view style="flex: 1;"></view>
|
|
<view v-if="data.showRecord" class="btn" style="flex-shrink: 0;color: #191919;"
|
|
@click.stop="showRecord(page.sid)">
|
|
预约记录</view>
|
|
<view v-if="data.showBtn" class="btn" style="flex-shrink: 0;color: royalblue;"
|
|
@click.stop="booking(page.sid)">预约提货
|
|
</view>
|
|
</view>
|
|
</view> -->
|
|
|
|
<!-- 弹窗蒙版 -->
|
|
<view class="model" catchtouchmove='preventTouchMove' v-if='showModal' @click.stop="colseDialog()"></view>
|
|
<view class="modalDlg" catchtouchmove='preventTouchMove' v-if='showModal'>
|
|
|
|
<view style="display: flex;flex-direction: column;margin-top: 10px;">
|
|
<text>提货地点</text>
|
|
<view
|
|
style="margin-top: 10px;background:#F5F5F5 ; display: flex;flex-direction: row;justify-content: space-between;width: 100%;border-radius: 4px;min-height: 35px;align-items: center;"
|
|
@click="address">
|
|
<view v-if="stringIsEmpty(data.addressName)" style="color: #666;font-size: 12px;margin-left: 10px;">
|
|
请选择提货点</view>
|
|
<view v-if="stringIsNotEmpty(data.addressName)"
|
|
style="color: #666;font-size: 12px;margin-left: 10px;">{{data.addressName}}</view>
|
|
<uni-icons type="bottom" size="14" color="#999" style="flex-direction: 0;margin: 0px 5px;" />
|
|
</view>
|
|
</view>
|
|
|
|
<view style="display: flex;flex-direction: column;margin-top: 10px;">
|
|
<text>提货时间</text>
|
|
<view style="display: flex;align-items: center;margin-top: 6px;">
|
|
<uni-datetime-picker type="date" v-model="data.reserveDate" style="flex: 1;background: #F8F8F8;"
|
|
:start="data.start" :end="data.end" @showing='showing' :disabledDate="disabledDate" />
|
|
</view>
|
|
</view>
|
|
|
|
<view style="display: flex;flex-direction: column;margin-top: 10px;">
|
|
<text>提货人</text>
|
|
<view style="display: flex;align-items: center;margin-top: 6px;">
|
|
<input placeholder="请输入提货人"
|
|
style="font-size: 30rpx;flex: 1;background: #F8F8F8;border-radius: 5px;height: 40px;line-height: 40px;padding-left: 10px;"
|
|
:value="data.userName" @input="onKeyInput1" />
|
|
</view>
|
|
</view>
|
|
|
|
<view style="display: flex;flex-direction: column;margin-top: 10px;">
|
|
<text>联系电话</text>
|
|
<view style="display: flex;align-items: center;margin-top: 6px;">
|
|
<input maxlength="11" placeholder="请输入联系电话"
|
|
style="font-size: 30rpx;flex: 1;background: #F8F8F8;border-radius: 5px;height: 40px;line-height: 40px;padding-left: 10px;"
|
|
type="number" :value="data.userPhone" @input="onKeyInput2" />
|
|
</view>
|
|
</view>
|
|
|
|
<view style="background: #F5F5F5; border-radius: 5px;margin-top: 15px;">
|
|
<view v-for="(item,index) in data.goodsVos"
|
|
style="display: flex;flex-direction: row;margin-top: 15px; margin-bottom: 10px;">
|
|
<view
|
|
style="margin-left: 10px;margin-right: 10px;flex: 1;display: flex;flex-direction: column;justify-content: space-between;align-items: flex-end;">
|
|
<text class="text" style="font-weight: 500;width: 100%;font-size: 12px;">{{item.goods}}
|
|
</text>
|
|
<uni-number-box ref="box" style="margin-top: -20px;" :min="0" :max="item.lnum" v-model="item.select"
|
|
:showTextView="page.showTextView"></uni-number-box>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
<view style="display: flex;flex-direction: row;align-items: center;justify-content: center; margin-top: 20px; margin-bottom: 10px;">
|
|
|
|
<text style="border-radius:30px; font-size: 14px;color: #666;background-color: #F5F5F5; padding: 5px 30px;margin-right: 20px;" @click.stop="colseDialog()">取消</text>
|
|
<text style="border-radius: 30px; font-size: 14px;color: #fff; background-color: #FF9D33; padding: 5px 30px;margin-left: 20px;" @click="save">确认</text>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
data() {
|
|
return {
|
|
showModal: false,
|
|
page: {
|
|
sid: '',
|
|
showTextView:false,
|
|
startHeight: 0,
|
|
endHeight: 0
|
|
},
|
|
data: {
|
|
time: "",
|
|
name: "",
|
|
pname: "",
|
|
state: "",
|
|
notRese:false,
|
|
showBtn: false,
|
|
showRecord: false,
|
|
goodsVos: [],
|
|
value: "",
|
|
userName: "",
|
|
userPhone: "",
|
|
},
|
|
disabledDate:[
|
|
// '2023-12-16'
|
|
]
|
|
}
|
|
},
|
|
onLoad(options) {
|
|
this.page.sid = options.sid
|
|
this.request()
|
|
this.getSun()
|
|
uni.$on("order", (e) => {
|
|
this.$nextTick(() => {
|
|
this.$refs.pageView.setLoadState(0)
|
|
})
|
|
this.request();
|
|
})
|
|
|
|
uni.$on("address", (e) => {
|
|
// 相当与下拉刷新
|
|
this.data.value = e.sid;
|
|
this.data.addressName = e.name;
|
|
})
|
|
|
|
let info = uni.getSystemInfoSync();
|
|
|
|
this.page.startHeight = info.windowWidth * 0.6
|
|
this.page.endHeight = info.windowWidth * 0.8
|
|
},
|
|
onUnload() {
|
|
uni.$off('order');
|
|
uni.$off('address');
|
|
},
|
|
methods: {
|
|
showDialog() {
|
|
this.showModal = true
|
|
},
|
|
colseDialog(){
|
|
this.showModal = false
|
|
},
|
|
address() {
|
|
uni.navigateTo({
|
|
url: '/pages/SelectAddressActivity'
|
|
})
|
|
},
|
|
onKeyInput1: function(event) {
|
|
this.data.userName = event.target.value
|
|
},
|
|
onKeyInput2: function(event) {
|
|
this.data.userPhone = event.target.value
|
|
},
|
|
showing(e) {
|
|
this.page.showTextView = e
|
|
},
|
|
save() {
|
|
if (this.stringIsEmpty(this.data.value)) {
|
|
this.shortToast('请选择提货地点')
|
|
return
|
|
}
|
|
if (this.stringIsEmpty(this.data.reserveDate)) {
|
|
this.shortToast('请选择提货时间')
|
|
return
|
|
}
|
|
if (this.stringIsEmpty(this.data.userName)) {
|
|
this.shortToast('请输入提货人员')
|
|
return
|
|
}
|
|
if (this.stringIsEmpty(this.data.userPhone)) {
|
|
this.shortToast('请输入手机号码')
|
|
return
|
|
}
|
|
if (this.data.userPhone.length != 11) {
|
|
this.shortToast('手机号码格式不对')
|
|
return
|
|
}
|
|
|
|
|
|
let num = 0;
|
|
for (var i = 0; i < this.data.goodsVos.length; i++) {
|
|
num += Number(this.data.goodsVos[i].select);
|
|
}
|
|
if (num == 0) {
|
|
this.shortToast('您未选择任何商品')
|
|
return
|
|
}
|
|
|
|
let _this = this
|
|
_this.$api.cardBookingSave(this.data).then((resp) => {
|
|
uni.navigateBack()
|
|
uni.$emit('order', {})
|
|
}).catch(e => {
|
|
_this.shortToast(e.msg)
|
|
})
|
|
|
|
},
|
|
|
|
request() {
|
|
let _this = this
|
|
_this.$api.cardDetail(this.page.sid).then((resp) => {
|
|
_this.data = resp
|
|
_this.$nextTick(() => {
|
|
_this.$refs.pageView.setLoadState(2)
|
|
})
|
|
}).catch(e => {
|
|
_this.$nextTick(() => {
|
|
_this.$refs.pageView.setLoadState(1)
|
|
})
|
|
})
|
|
},
|
|
|
|
getSun(){
|
|
let _this = this
|
|
_this.$api.isSaturAndSun(this.page.sid).then((resp) => {
|
|
|
|
// console.log("aaa",resp)
|
|
|
|
this.disabledDate = resp
|
|
|
|
}).catch(e => {
|
|
|
|
})
|
|
},
|
|
|
|
showRecord(sid) {
|
|
uni.navigateTo({
|
|
url: '/pages/card/card_record?sid=' + sid
|
|
})
|
|
},
|
|
booking(sid) {
|
|
uni.navigateTo({
|
|
url: '/pages/card/card_booking?sid=' + sid
|
|
})
|
|
},
|
|
itemClick(goodsSid) {
|
|
uni.navigateTo({
|
|
url: '/pages/good/goodsDetail?sid=' + goodsSid
|
|
})
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
.top {
|
|
width: 100vw;
|
|
/* height: 126.66vw; */
|
|
height: 65vw;
|
|
/* 加载背景图 */
|
|
background-image: url(https://supervise.yxtsoft.com/lpk/image/normal.png);
|
|
/* 让背景图基于容器大小伸缩 */
|
|
background-size: 100% 100%;
|
|
}
|
|
|
|
.text {
|
|
white-space: normal;
|
|
text-overflow: -o-ellipsis-lastline;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
display: -webkit-box;
|
|
-webkit-line-clamp: 2;
|
|
line-clamp: 2;
|
|
-webkit-box-orient: vertical;
|
|
}
|
|
|
|
uni-page-body,
|
|
page {
|
|
background: #F1F2F3;
|
|
}
|
|
|
|
.btn {
|
|
border: 1px solid;
|
|
padding-left: 30rpx;
|
|
padding-right: 30rpx;
|
|
padding-top: 12rpx;
|
|
padding-bottom: 12rpx;
|
|
border-radius: 50rpx;
|
|
height: 15px;
|
|
margin-left: 25rpx;
|
|
font-size: 26rpx;
|
|
}
|
|
|
|
/* 弹窗样式 */
|
|
.model {
|
|
position: absolute;
|
|
width: 100%;
|
|
height: 100%;
|
|
background: #000;
|
|
z-index: 999;
|
|
opacity: 0.5;
|
|
top: 0;
|
|
left: 0;
|
|
}
|
|
|
|
.modalDlg {
|
|
/* 设置超出滚动 */
|
|
overflow: auto;
|
|
width: 90%;
|
|
position: fixed;
|
|
top: 50vw;
|
|
left: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
z-index: 9999;
|
|
margin: 0 auto;
|
|
padding: 35rpx;
|
|
background-color: #fff;
|
|
border-radius: 20rpx;
|
|
display: flex;
|
|
flex-direction: column;
|
|
|
|
}
|
|
|
|
.windowRow {
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
padding-bottom: 15rpx;
|
|
width: 100%;
|
|
}
|
|
|
|
.userTitle {
|
|
font-size: 42rpx;
|
|
}
|
|
|
|
.back {
|
|
text-align: center;
|
|
color: #f0a500;
|
|
font-size: 30rpx;
|
|
}
|
|
|
|
.wishName {
|
|
width: 100%;
|
|
justify-content: center;
|
|
flex-direction: row;
|
|
display: flex;
|
|
margin: 40rpx 0rpx;
|
|
}
|
|
|
|
.wish_put {
|
|
width: 100%;
|
|
border: #ededef 1rpx solid;
|
|
background-color: #f6f7fb;
|
|
border-radius: 12rpx;
|
|
padding: 30rpx 20rpx;
|
|
margin: 20rpx 0rpx;
|
|
}
|
|
|
|
.holder_cls {
|
|
color: #909399;
|
|
}
|
|
|
|
.wishbnt {
|
|
background-color: #fec600;
|
|
text-align: center;
|
|
border-radius: 50rpx;
|
|
padding: 25rpx;
|
|
color: white;
|
|
}
|
|
|
|
/*弹窗样式结束*/
|
|
|
|
/* 下面的姓名样式,不要也没什么影响 */
|
|
.jiantou {
|
|
width: 35rpx;
|
|
height: 35rpx;
|
|
margin-left: 10rpx;
|
|
}
|
|
|
|
.fenge {
|
|
margin-bottom: 30rpx;
|
|
}
|
|
|
|
.xian {
|
|
border-bottom: #e5e5e5 1rpx solid;
|
|
}
|
|
|
|
.yellow {
|
|
color: #f0a500;
|
|
font-weight: 700;
|
|
}
|
|
|
|
.box {
|
|
background-color: white;
|
|
padding: 0rpx 25rpx;
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
.row {
|
|
height: 120rpx;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.you {
|
|
height: 100%;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.zhushi {
|
|
font-size: 28rpx;
|
|
color: #808080;
|
|
}
|
|
|
|
/* 下面的姓名样式结束 */
|
|
</style>
|