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.
3884 lines
97 KiB
3884 lines
97 KiB
<template>
|
|
<view class="page1" :class="{'is-sticky': lastScrollTop>583}">
|
|
<view class="swiper-container">
|
|
<view class="swiper-page" v-if="currentIndex == 0">
|
|
<view style="position: relative;height: 545rpx;">
|
|
<view style="width:100%;height: 260rpx;position: fixed;top: 0;background: url('https://jewel-shop.oss-cn-beijing.aliyuncs.com/8bc15960c2dc40268e295d6dd23aecce.png') no-repeat;z-index: 90;"
|
|
v-if="lastScrollTop>583"></view>
|
|
<view class="campus-hero campus-hero--ad">
|
|
<swiper class="swiper hero-bg-swiper" circular :indicator-dots="indicatorDots" :autoplay="autoplay"
|
|
:interval="interval" :duration="duration">
|
|
<swiper-item v-for="(item,index) in adList" :key="index"
|
|
@tap="goAdPage(item)">
|
|
<img class="hero-bg-img" :src="item.adImage" alt="" />
|
|
</swiper-item>
|
|
</swiper>
|
|
<view class="hero-bg-mask"></view>
|
|
<view class="hero-glow hero-glow-a"></view>
|
|
<view class="hero-glow hero-glow-b"></view>
|
|
<view class="hero-particle hero-particle-a"></view>
|
|
<view class="hero-particle hero-particle-b"></view>
|
|
<view class="hero-particle hero-particle-c"></view>
|
|
</view>
|
|
<view class="order-notice-wrap">
|
|
|
|
<swiper class="swiper" vertical circular :autoplay="orderLists.length <= 0" v-if="orderLists.length <= 0"
|
|
:interval="onlineWorkerInterval" :duration="onlineWorkerDuration"
|
|
style="height: 150rpx;margin-top: -100rpx;">
|
|
<swiper-item v-for="(item,index) in gaoxiaoList" :key="index">
|
|
<view class="order-msg-box life-status-row">
|
|
<view class="life-ip order-msg-left">
|
|
<img src="/static/images/img/songshu.png" alt="" />
|
|
</view>
|
|
<view class="life-status-main order-msg-center">
|
|
<view class="life-status-title">
|
|
{{item.title}}
|
|
</view>
|
|
<view class="life-progress">
|
|
<view class="life-progress-bar" style="width: 56%;"></view>
|
|
</view>
|
|
<view class="life-status-desc">{{item.content}} · 附近宿舍在拼</view>
|
|
</view>
|
|
<view class="life-action order-msg-right" @tap.stop="goDetail('2')">
|
|
去拼
|
|
</view>
|
|
</view>
|
|
</swiper-item>
|
|
</swiper>
|
|
<swiper class="swiper" vertical circular :autoplay="orderLists.length > 0" v-else
|
|
:interval="onlineWorkerInterval" :duration="onlineWorkerDuration"
|
|
style="height: 150rpx;margin-top: -100rpx;">
|
|
<swiper-item v-if="orderLists.length > 0" v-for="(item,index) in orderLists" :key="index"
|
|
@tap="goOrderDetail(item)">
|
|
<view class="order-msg-box life-status-row">
|
|
<view class="life-ip order-msg-left">
|
|
<img src="/static/images/img/songshu.png" alt="" />
|
|
</view>
|
|
<view class="life-status-main order-msg-center">
|
|
<view class="life-status-title">
|
|
<text v-if="item.status == 0">订单进度 · 待支付</text>
|
|
<text v-if="item.status == 2">跑腿状态 · 等待接单</text>
|
|
<text v-if="item.status == 10">拼团订单 · 待成团</text>
|
|
<text v-if="item.status == 3 && item.deliveryType == 1">外卖配送 · 骑手已接单</text>
|
|
<text v-if="item.status == 3 && item.deliveryType == 2">到店消费 · 等你核销</text>
|
|
<text v-if="item.status == 4 && item.deliveryType == 1">外卖配送 · 已取货</text>
|
|
<text v-if="item.status == 5">校园任务完成啦</text>
|
|
<text v-if="item.status == 7">退款状态 · 等商家确认</text>
|
|
<text v-if="item.status == 6">订单已取消</text>
|
|
<text v-if="item.status == 8">订单已退款</text>
|
|
<text v-if="item.status == 11">售后中 · 正在处理</text>
|
|
<text v-if="item.status == 12">售后已完成</text>
|
|
</view>
|
|
<view class="life-progress">
|
|
<view class="life-progress-bar" :style="{'width': item.status == 10 ? '68%' : (item.status == 0 ? '38%' : '82%')}"></view>
|
|
</view>
|
|
<view class="life-status-desc"
|
|
v-if="item.deliveryType == 1 && (item.status == 3 || item.status == 4) && item.deliveryInfo != null">
|
|
预计 {{item.deliveryInfo.mustFinishTime | formatHourMinute }} 送达
|
|
</view>
|
|
<view class="life-status-desc" v-else>点开看看,订单的最新状态</view>
|
|
</view>
|
|
<view class="life-action order-msg-right">
|
|
查看
|
|
</view>
|
|
</view>
|
|
</swiper-item>
|
|
</swiper>
|
|
</view>
|
|
|
|
|
|
<view class="menu-box">
|
|
<view class="menu-list world-run" @tap="goDetail('1')">
|
|
<view class="world-light"></view>
|
|
<view class="world-dot world-dot-a"></view>
|
|
<img src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/7690c4f897604fca804ea932bc3c1239.png"
|
|
alt="" />
|
|
<view class="menu-name">跑腿星球</view>
|
|
<view class="menu-desc">小事接力</view>
|
|
</view>
|
|
<view class="menu-list world-food" @tap="goDetail('2')" style="position: relative;">
|
|
<view class="world-light"></view>
|
|
<view class="world-dot world-dot-b"></view>
|
|
<img src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/553230c20dea4e5c85f1e396058a7493.png"
|
|
alt="" />
|
|
<!-- <img src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/1a02b40d853a4cfdb062fff44ec49e6a.png"
|
|
alt="" style="position: absolute;top: -10rpx;right: 0;width: 78rpx;height: 32rpx;"> -->
|
|
<view class="menu-name">饭团星球</view>
|
|
<view class="menu-desc">食堂搭子</view>
|
|
</view>
|
|
<view class="menu-list world-store" @tap="goDetail('3')">
|
|
<view class="world-light"></view>
|
|
<img src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/28b5cfec79d74871b0ce67743fb7619c.png"
|
|
alt="" />
|
|
<view class="menu-name">团团星球</view>
|
|
<view class="menu-desc">周边娱乐</view>
|
|
</view>
|
|
<view class="menu-list world-luck" @tap="goDetail('4')">
|
|
<view class="world-light"></view>
|
|
<view class="world-dot world-dot-c"></view>
|
|
<img src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/41cfb56caff4419b94b69d0f2303b602.png"
|
|
alt="" />
|
|
<view class="menu-name">白嫖星球</view>
|
|
<view class="menu-desc">抽点惊喜</view>
|
|
</view>
|
|
<view class="menu-list world-fish" @tap="goDetail('5')">
|
|
<view class="world-light"></view>
|
|
<img src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/a083b7d159264bbc967034088fa7eb3a.png"
|
|
alt="" />
|
|
<view class="menu-name">i/e星球</view>
|
|
<view class="menu-desc">思想漂流</view>
|
|
</view>
|
|
</view>
|
|
<view class="like-box">
|
|
<view class="like-head" style="position: relative;">
|
|
<view class="like-title">
|
|
<img @tap="pageshow" src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/e0c44bc9b69a46559d3aa4160d3cf4a5.png"
|
|
alt="" />
|
|
</view>
|
|
<view class="seckill-entry" @tap="goSeckillGroup">
|
|
<view class="heat-dot heat-dot-a"></view>
|
|
<view class="heat-dot heat-dot-b"></view>
|
|
<view class="seckill-entry-light"></view>
|
|
<view class="seckill-entry-info" style="padding-left: 20rpx;">
|
|
<view class="seckill-entry-title">秒杀团</view>
|
|
<view class="seckill-entry-sub">速速加入,就等你啦!</view>
|
|
</view>
|
|
<view class="seckill-entry-btn">抢</view>
|
|
</view>
|
|
</view>
|
|
|
|
<view class="like-content-box">
|
|
<view class="brand-memory-strip">
|
|
<text>热闹值 {{88 + waimaiCount}}</text>
|
|
<text>省钱榜 Top1</text>
|
|
<text>爆款指数 ↑</text>
|
|
<text>拼团王在线</text>
|
|
</view>
|
|
<view class="group-orbit group-orbit-a"></view>
|
|
<view class="group-orbit group-orbit-b"></view>
|
|
<view class="like-left like-world-left">
|
|
<view class="like-content-title">
|
|
<view style="width: 100%;font-weight: 700;">食堂星球热拼</view>
|
|
<image class="like-hot-gif" src="/static/images/img/loading.gif" mode="aspectFit"></image>
|
|
|
|
<img src="/static/images/img/yousanjiao.png" alt=""
|
|
style="width: 28rpx;height: 28rpx;position: absolute;top: 20rpx;right: 12rpx;padding-bottom: 10rpx;">
|
|
</view>
|
|
<view class="like-content">
|
|
<view class="content-list" v-if="item.position == 'home_center_left_top' "
|
|
v-for="(item,index) in mallAds" :key="index" @tap="goAdPage(item)">
|
|
<view class="list-img">
|
|
<img :src="item.adImage" alt="">
|
|
<view class="list-type">正在拼</view>
|
|
</view>
|
|
<view class="list-product">
|
|
<view class="list-name">
|
|
|
|
<view class="list-text">{{item.title}}</view>
|
|
</view>
|
|
<view class="list-price" style="color: #00231C;">
|
|
¥{{item.productList[0].groupPrice}}</view>
|
|
<view class="list-total">
|
|
<text style="color: red;">{{item.productList[0].groupMembers}}人团</text>
|
|
<view class="group-cta" style="margin-left: 14rpx;">去拼</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="content-list" v-if="item.position == 'home_center_left_bottom' "
|
|
v-for="(item,index) in mallAds" :key="index" @tap="goAdPage(item)">
|
|
<view class="list-img">
|
|
<img :src="item.adImage" alt="">
|
|
<view class="list-type">正在拼</view>
|
|
</view>
|
|
<view class="list-product">
|
|
<view class="list-name">
|
|
|
|
<view class="list-text">{{item.title}}</view>
|
|
</view>
|
|
<view class="list-price" style="color: #00231C;">
|
|
¥{{item.productList[0].groupPrice}}</view>
|
|
<view class="list-total">
|
|
<text style="color: red;">{{item.productList[0].groupMembers}}人团</text>
|
|
<view class="group-cta" style="margin-left: 14rpx;">去拼</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="like-left like-world-right">
|
|
<view class="like-content-title">
|
|
<view style="font-weight: 700;">宿舍搭子开团</view>
|
|
<image class="like-hot-gif" src="/static/images/img/loading.gif" mode="aspectFit"></image>
|
|
|
|
<img src="/static/images/img/yousanjiao.png" alt=""
|
|
style="width: 28rpx;height: 28rpx;position: absolute;top: 20rpx;right: 12rpx;padding-bottom: 10rpx;">
|
|
</view>
|
|
<view class="like-content">
|
|
<view class="content-list" v-if="item.position == 'home_center_right_top' "
|
|
v-for="(item,index) in mallAds" :key="index" @tap="goAdPage(item)">
|
|
<view class="list-img">
|
|
<img :src="item.adImage" alt="">
|
|
<view class="list-type">正在拼</view>
|
|
</view>
|
|
<view class="list-product">
|
|
<view class="list-name">
|
|
|
|
<view class="list-text">{{item.title}}</view>
|
|
</view>
|
|
<view class="list-price" style="color: #00231C;">
|
|
¥{{item.productList[0].groupPrice}}</view>
|
|
<view class="list-total">
|
|
<text style="color: red;">{{item.productList[0].groupMembers}}人团</text>
|
|
<view class="group-cta" style="margin-left: 14rpx;">去拼</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="content-list" v-if="item.position == 'home_center_right_bottom' "
|
|
v-for="(item,index) in mallAds" :key="index" @tap="goAdPage(item)">
|
|
<view class="list-img">
|
|
<img :src="item.adImage" alt="">
|
|
<view class="list-type">正在拼</view>
|
|
</view>
|
|
<view class="list-product">
|
|
<view class="list-name">
|
|
|
|
<view class="list-text">{{item.title}}</view>
|
|
</view>
|
|
<view class="list-price" style="color: #00231C;">
|
|
¥{{item.productList[0].groupPrice}}</view>
|
|
<view class="list-total">
|
|
<text style="color: red;">{{item.productList[0].groupMembers}}人团</text>
|
|
<view class="group-cta" style="margin-left: 14rpx;">去拼</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="daimai-box" style="padding-bottom:180rpx;">
|
|
<view class="daimai-tab" id="menuList" :class="{'daimai-tab--sticky': lastScrollTop>583}"
|
|
:style="{'top': (navBarHeight+46) + 'px'}">
|
|
<view class="daimai-tab-item" :class="{'active': checked == 'waimai'}"
|
|
@tap="checkTab1('waimai')">
|
|
<view class="daimai-tab-glow"></view>
|
|
<view class="daimai-tab-icon">饭</view>
|
|
<view class="daimai-tab-info">
|
|
<text class="daimai-tab-label">外卖</text>
|
|
<text class="daimai-tab-count">{{waimaiCount}}</text>
|
|
</view>
|
|
</view>
|
|
<view class="daimai-tab-item" :class="{'active': checked == 'kuaidi'}"
|
|
@tap="checkTab1('kuaidi')">
|
|
<view class="daimai-tab-glow"></view>
|
|
<view class="daimai-tab-icon">递</view>
|
|
<view class="daimai-tab-info">
|
|
<text class="daimai-tab-label">快递</text>
|
|
<text class="daimai-tab-count">{{kuaidiCount}}</text>
|
|
</view>
|
|
</view>
|
|
<view class="daimai-tab-item" :class="{'active': checked == 'paotui'}"
|
|
@tap="checkTab1('paotui')">
|
|
<view class="daimai-tab-glow"></view>
|
|
<view class="daimai-tab-icon">跑</view>
|
|
<view class="daimai-tab-info">
|
|
<text class="daimai-tab-label">跑腿</text>
|
|
<text class="daimai-tab-count">{{paotuiCount}}</text>
|
|
</view>
|
|
</view>
|
|
<view class="daimai-tab-item" :class="{'active': checked == 'zhipai'}"
|
|
@tap="checkTab1('zhipai')" v-if="worker != null">
|
|
<view class="daimai-tab-glow"></view>
|
|
<view class="daimai-tab-icon">派</view>
|
|
<view class="daimai-tab-info">
|
|
<text class="daimai-tab-label">指派单</text>
|
|
<text class="daimai-tab-count">{{zhipaiCount}}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="title-sort" v-if="(lastScrollTop>300 || getAreaData.id != undefined || putAreaData.id != undefined || checkYongjin)" :class="{'title-sort--sticky': lastScrollTop>583}"
|
|
:style="{'top': (navBarHeight+90) + 'px'}">
|
|
<view class="sort-member" style="position: relative;">
|
|
<view @tap="checkAdd">
|
|
取餐地址 <text style="font-size: 20rpx;">▼</text>
|
|
</view>
|
|
<view class="sort-value" v-if="isgetArea">
|
|
<view class="sort-value1" v-for="(item,index) in getshopArea" :key="index"
|
|
@tap="searchOrder('getarea',item)">{{item.title}}</view>
|
|
</view>
|
|
</view>
|
|
<view class="sort-member" style="position: relative;">
|
|
<view @tap="checkAdd1">
|
|
送餐地址 <text style="font-size: 20rpx;">▼</text>
|
|
</view>
|
|
<view class="sort-value" v-if="isputArea">
|
|
<view class="sort-value1" v-for="(item,index) in putshopArea" :key="index"
|
|
@tap="searchOrder('putarea',item)">{{item.title}}</view>
|
|
</view>
|
|
</view>
|
|
<view @tap="searchOrder('yongjin')" class="sort-member" style="border-radius: 60rpx"
|
|
:style="{'background':checkYongjin==true?'linear-gradient(135deg, rgba(255, 247, 215, 0.95), rgba(166, 255, 234, 0.72))':'rgba(248, 255, 250, 0.86)','border':checkYongjin==true?'1px solid rgba(255, 188, 119, 0.72)':'1px solid rgba(166, 255, 234, 0.46)'}">
|
|
佣金
|
|
</view>
|
|
<view @tap="searchOrder('shuaxin')" class="sort-member" hover-class="box-hover" style="border-radius: 60rpx">
|
|
刷新
|
|
</view>
|
|
</view>
|
|
<view class="sort-text"
|
|
v-if="getAreaData.id != undefined || putAreaData.id != undefined || checkYongjin"
|
|
:style="{'top': (navBarHeight+140) + 'px'}">
|
|
<view class="sort-text-inner">
|
|
<view @tap="searchOrder('delgetarea')" class="guize1-qusong"
|
|
v-if="getAreaData.id != undefined">
|
|
<view class="qusong1">
|
|
取
|
|
</view>
|
|
<view class="qusong2">
|
|
{{getAreaData.title}}
|
|
</view>
|
|
</view>
|
|
<view @tap="searchOrder('delputarea')" class="guize1-qusong"
|
|
v-if="putAreaData.id != undefined">
|
|
<view class="qusong1">
|
|
送
|
|
</view>
|
|
<view class="qusong2" style="background: rgba(209, 206, 255, 1);">
|
|
{{putAreaData.title}}
|
|
</view>
|
|
</view>
|
|
<view @tap="searchOrder('delyongjin')" class="guize1-qusong" v-if="checkYongjin">
|
|
<view class="qusong1">
|
|
佣
|
|
</view>
|
|
<view class="qusong2 commission-chip">
|
|
佣金优先
|
|
</view>
|
|
</view>
|
|
<view @tap="clearCheck"
|
|
v-if="getAreaData.id != undefined || putAreaData.id != undefined || checkYongjin"
|
|
class="clear-filter">
|
|
清空
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
<view class="delivery-list-wrap">
|
|
|
|
<view class="empty-delivery" v-if="deliveryItem.length <= 0">
|
|
<view class="empty-delivery-icon">校园</view>
|
|
<view class="empty-delivery-title">暂时没有可抢订单</view>
|
|
<view class="empty-delivery-desc">可以切换分类或调整筛选条件,新的校园订单会在这里出现</view>
|
|
</view>
|
|
<view class="list-1" v-for="(item,index) in deliveryItem" :key="index"
|
|
@tap="productDetail(item)">
|
|
<view class="daoda-time">
|
|
送达时间:{{item.mustFinishTime != null ? item.mustFinishTime : '' | formatHourMinute }}
|
|
</view>
|
|
<view class="order-page">
|
|
<view class="maotou" v-if="item.deliveryType == 1 && !item.workerId">
|
|
外卖
|
|
</view>
|
|
<view class="maotou1" v-if="item.deliveryType == 2">
|
|
代取快递
|
|
</view>
|
|
<view class="maotou2" v-if="item.deliveryType == 3">
|
|
代跑腿
|
|
</view>
|
|
<view class="maotou3" v-if="item.workerId">
|
|
指派单
|
|
</view>
|
|
<view class="shangjia">
|
|
<text
|
|
style="font-weight: 700;">{{item.shopName != null ? item.shopName : ''}}</text>
|
|
<view v-if="item.deliveryType == 1"
|
|
style="width: 32rpx;height: 30rpx;font-weight: 700;font-size: 20rpx;color: #fff;text-align: center;background: #00BFFF;border-radius: 10rpx;margin: 20rpx 0 0 10rpx;line-height: 30rpx;">
|
|
详
|
|
</view>
|
|
<view v-else style="font-weight: 700;">
|
|
{{item.allCount ? item.allCount : 0}}件
|
|
</view>
|
|
</view>
|
|
<view class="shangpin">
|
|
<view class="qu-song">
|
|
<view class="qu-box">
|
|
<view class='qu-tu'>
|
|
<img src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/1f77398a73454a6595c12a3c18731599.png"
|
|
alt="" />
|
|
</view>
|
|
<view class="qu-text">
|
|
<view class="qu-left">
|
|
{{item.shopAddress != null ? item.shopAddress : ''}}
|
|
</view>
|
|
<view class="qu-right">
|
|
<img @tap.stop="makeCall(item.shopPhone)"
|
|
src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/869a7af6a1c24bf3a0d523c4a18b55c6.png"
|
|
alt="" style="width: 55rpx;height: 55rpx;" />
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="qu-box" style="margin-top:15rpx;">
|
|
<view class='qu-tu'>
|
|
<img src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/d0764fb4138747769538cf1cafa3b017.png"
|
|
alt="" />
|
|
</view>
|
|
<view class="qu-text">
|
|
<view class="qu-left">
|
|
{{item.receiverAddress != null ? item.receiverAddress : ''}}
|
|
</view>
|
|
<view class="qu-right">
|
|
<img @tap.stop="makeCall(item.receiverPhone)"
|
|
src="https://jewel-shop.oss-cn-beijing.aliyuncs.com/869a7af6a1c24bf3a0d523c4a18b55c6.png"
|
|
alt="" style="width: 55rpx;height: 55rpx;" />
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="yongjin">
|
|
<view style="width: 50%;color: #777;padding-left: 4%;display: flex;">
|
|
配送佣金
|
|
<view class="chaoda" v-if="item.isBig !=null && item.isBig == 1">
|
|
超大/超重
|
|
</view>
|
|
</view>
|
|
<view style="font-weight: 700;width: 50%;text-align: right;">
|
|
¥{{(item.deliveryFee + item.deliveryFeeMarketplace).toFixed(2)}}
|
|
<text style="color: #777;font-size: 22rpx;"
|
|
v-if="item.deliveryFeeMarketplace > 0">(包含¥{{item.deliveryFeeMarketplace}}平台佣金)</text>
|
|
</view>
|
|
</view>
|
|
<view class="beizhu" v-if="item.remark != null && item.remark != ''">
|
|
备注:{{item.remark}}
|
|
</view>
|
|
<view class="dispatch-action-box" :class="{'dispatch-action-box--single': checked != 'zhipai'}">
|
|
<view class="qiangdan-btn" :id="'swipe-order-' + item.id"
|
|
@tap.stop="noop"
|
|
@touchstart.stop="startSwipeOrder($event,item,index)"
|
|
@touchmove.stop.prevent="moveSwipeOrder"
|
|
@touchend.stop="endSwipeOrder(item,index)"
|
|
@touchcancel.stop="resetSwipeOrder">
|
|
<view class="qiangdan-progress"
|
|
:style="swipeOrder.id === item.id && swipeOrder.index === index ? swipeOrder.progressStyle : swipeOrderDefaultStyle.progress"></view>
|
|
<view class="qiangdan-text">
|
|
<text v-if="swipeOrder.id !== item.id || swipeOrder.index !== index || swipeOrder.progress <= 0">向右滑动抢单</text>
|
|
<text v-else-if="swipeOrder.progress < 92">继续滑动确认</text>
|
|
<text v-else>松手接单</text>
|
|
</view>
|
|
<view class="qiangdan-thumb"
|
|
:style="swipeOrder.id === item.id && swipeOrder.index === index ? swipeOrder.thumbStyle : swipeOrderDefaultStyle.thumb">
|
|
<text>接</text>
|
|
</view>
|
|
</view>
|
|
<view class="reject-order-btn" v-if="checked == 'zhipai'"
|
|
@tap.stop="rejectOrder(item,index)">
|
|
<text>拒绝接单</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
</view>
|
|
<view class="swiper-page" v-show="currentIndex == 1">
|
|
<de-livery ref="deLiveryPage"></de-livery>
|
|
</view>
|
|
<view class="swiper-page" v-show="currentIndex == 3">
|
|
<post-list ref="postListPage"></post-list>
|
|
</view>
|
|
<view class="swiper-page" v-show="currentIndex == 4">
|
|
<my-center ref="myCenterPage"></my-center>
|
|
</view>
|
|
</view>
|
|
<!-- 弹出区域选择 -->
|
|
<uni-popup ref="areaPopup" :is-mask-click="false" background-color="transparent">
|
|
<view class="campus-area-popup">
|
|
<view class="area-popup-glow area-popup-glow-a"></view>
|
|
<view class="area-popup-glow area-popup-glow-b"></view>
|
|
<view class="campus-area-header">
|
|
<view class="campus-area-kicker">选择你的校园半径</view>
|
|
<view class="campus-area-title">你现在在哪个校区?</view>
|
|
<view class="campus-area-subtitle">选定后,会优先展示附近同学正在拼的内容。</view>
|
|
</view>
|
|
<view class="campus-area-search">
|
|
<text class="area-search-icon">⌕</text>
|
|
<input v-model="areaKeyword" confirm-type="search" placeholder="搜索学校 / 校区 / 区域"
|
|
placeholder-class="area-search-placeholder" />
|
|
</view>
|
|
<scroll-view scroll-y class="campus-area-list">
|
|
<view class="campus-area-item" v-for="(item,index) in filteredAreaList" :key="index"
|
|
@tap="onClickArea(item)">
|
|
<view class="area-item-main">
|
|
<view class="area-item-dot"></view>
|
|
<text>{{item.title}}</text>
|
|
</view>
|
|
<view class="area-item-action">进入</view>
|
|
</view>
|
|
<view class="campus-area-empty" v-if="filteredAreaList.length === 0">
|
|
<view class="area-empty-title">没找到这个校区</view>
|
|
<view class="area-empty-desc">换个关键词试试,比如学校简称或区域名</view>
|
|
</view>
|
|
</scroll-view>
|
|
</view>
|
|
</uni-popup>
|
|
<!-- 弹出区域选择 -->
|
|
<uni-popup ref="pagesPopup" background-color="#fff">
|
|
<view class="popup-area-content" style="height: 1200rpx;overflow: scroll;">
|
|
<view class="popup-area-title">
|
|
<text>查看页面</text>
|
|
</view>
|
|
<view class="popup-area-container" v-for="(item,index) in pages" :key="index" @tap="aaaaaaa(item)">
|
|
<text style="display: inline-block">{{item.name}}</text>
|
|
</view>
|
|
</view>
|
|
</uni-popup>
|
|
<uni-popup ref="productPopup" background-color="transparent">
|
|
<view class="product-popup-content">
|
|
<view class="product-popup-header">
|
|
<view class="product-popup-title">商品详情</view>
|
|
<view class="product-popup-subtitle">请核对商品规格和数量</view>
|
|
</view>
|
|
<view class="product-popup-list" v-if="productData.goodsList != null && productData.goodsList.length > 0">
|
|
<view class="product-popup-card" v-for="(item1,index1) in productData.goodsList" :key="index1">
|
|
<view class="product-popup-img">
|
|
<img :src="item1.productPicture" alt="">
|
|
</view>
|
|
<view class="product-popup-info">
|
|
<view class="product-popup-name">
|
|
{{item1.productName}}
|
|
</view>
|
|
<view class="product-popup-spec">
|
|
<text class="product-popup-label">规格</text>
|
|
<text class="product-popup-spec-text">{{item1.specs | delNode}}</text>
|
|
</view>
|
|
</view>
|
|
<view class="product-popup-quantity">
|
|
<view class="product-popup-quantity-num">x{{item1.quantity}}</view>
|
|
<view class="product-popup-quantity-label">数量</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="product-popup-empty" v-else>
|
|
暂无商品详情
|
|
</view>
|
|
</view>
|
|
</uni-popup>
|
|
<!-- 参团成功提示弹出层 -->
|
|
<uni-popup ref="tishiPopup" background-color="#fff">
|
|
<view class="tishi-popup">
|
|
<view class="tishi-copy">
|
|
<view class="tishi-copy-title">抢单成功</view>
|
|
<view class="tishi-copy-desc">
|
|
点击下方<text class="tishi-copy-highlight">"配送"</text>按钮,即可开始送单啦
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</uni-popup>
|
|
<tab-bar ref="tabBar" :width="width" @tab-index="changeIndex" :currentIndex="currentIndex"></tab-bar>
|
|
</view>
|
|
</template>
|
|
<script>
|
|
import tabBar from "@/components/tab-bar/tab-bar.vue";
|
|
import deLivery from "@/components/tab-bar/delivery.vue";
|
|
import postList from "@/components/tab-bar/postList.vue";
|
|
import myCenter from "@/components/tab-bar/myCenter.vue";
|
|
export default {
|
|
data() {
|
|
return {
|
|
adList:[],
|
|
pages: [{
|
|
name: '商家账单详情111',
|
|
url: '/package2/shop/shopSettlementDetail'
|
|
}, {
|
|
name: '商家订单详情111',
|
|
url: '/package2/shop/orderDetail'
|
|
}, {
|
|
name: '发布订单评价111',
|
|
url: '/package1/order/orderEvaluate'
|
|
}, {
|
|
name: '优惠券列表111',
|
|
url: '/package2/myCenter/couponList'
|
|
}, {
|
|
name: '订单列表111',
|
|
url: '/package1/order/orderList'
|
|
}, {
|
|
name: '待成团页111',
|
|
url: '/package1/order/pendGroup'
|
|
}, {
|
|
name: '新增商品111',
|
|
url: '/package2/myCenter/addGoods'
|
|
}, {
|
|
name: '代买饭111',
|
|
url: '/package1/buyFood/buyFood'
|
|
}, {
|
|
name: '配送员列表111',
|
|
url: '/package1/index/deliveryPersonList'
|
|
}, {
|
|
name: '拼团商家详情111',
|
|
url: '/package2/group/groupBuyDetail'
|
|
}, {
|
|
name: '拼团单一商家111',
|
|
url: '/package2/group/groupBuySingle'
|
|
}, {
|
|
name: '拼团页111',
|
|
url: '/package2/group/groupBuyList'
|
|
}, {
|
|
name: '商家搜索页111',
|
|
url: '/package2/group/searchGroup'
|
|
}, {
|
|
name: '商家评价111',
|
|
url: '/package2/group/shopEvaluate'
|
|
}, {
|
|
name: '商品详情页111',
|
|
url: '/package1/goods/goodsDetail'
|
|
}, {
|
|
name: '订单详情111',
|
|
url: '/package1/order/orderDetail'
|
|
}, {
|
|
name: '订单支付页111',
|
|
url: '/package1/order/orderConfirm'
|
|
}, {
|
|
name: '商家注册111',
|
|
url: '/package2/shop/merchantRegister'
|
|
}, {
|
|
name: '代取快递/跑腿111',
|
|
url: '/package1/runErrand/runErrand'
|
|
}, {
|
|
name: '兼职注册111',
|
|
url: '/package2/myCenter/partTimeJobRegister'
|
|
}, {
|
|
name: '支付页',
|
|
url: '/package1/payment/payment'
|
|
}, {
|
|
name: '帖子详情页',
|
|
url: '/package1/post/postDetail'
|
|
}, {
|
|
name: '地址列表',
|
|
url: '/package2/myCenter/addressList'
|
|
}, {
|
|
name: '我的钱包',
|
|
url: '/package2/myCenter/wallet'
|
|
}, {
|
|
name: '我的发布',
|
|
url: '/package2/myCenter/myPost'
|
|
}, {
|
|
name: '我的朋友',
|
|
url: '/package2/myCenter/myFriend'
|
|
}, {
|
|
name: '我的收藏',
|
|
url: '/package2/myCenter/myCollect'
|
|
}, {
|
|
name: '个人中心',
|
|
url: '/package2/myCenter/myCenter'
|
|
}, {
|
|
name: '商家注册',
|
|
url: '/package2/shop/merchantRegister'
|
|
}, {
|
|
name: '发布',
|
|
url: '/package1/tabbar/release'
|
|
}, {
|
|
name: '农场',
|
|
url: '/package1/farm/farm'
|
|
}],
|
|
areaName: '',
|
|
gaoxiaoList:[{
|
|
title:'拼团搭子哪里找',
|
|
content:'隔壁宿舍全是宝!'
|
|
},{
|
|
title:'这门“省钱课”',
|
|
content:'拼团就是你的满分答案!'
|
|
},{
|
|
title:'有件事你知道吗?',
|
|
content:'拼团和期末不挂科一样重要!'
|
|
}],
|
|
indicatorDots: false,
|
|
autoplay: true,
|
|
mallAds: [],
|
|
deliveryItem: [],
|
|
interval: 4000,
|
|
onlineWorkerInterval: 4000,
|
|
duration: 1000,
|
|
onlineWorkerDuration: 1000,
|
|
latitude: 39.909, // 默认纬度,可以设为用户当前位置或配送员位置
|
|
longitude: 116.39742, // 默认经度
|
|
markers: [], // 标记点,可以包括配送员位置和用户位置
|
|
polyline: [], // 路线,如果需要显示配送员路线
|
|
currentIndex: 0,
|
|
width: 0,
|
|
dataTabList: [{
|
|
name: '猜你喜欢',
|
|
isCheck: true
|
|
}, {
|
|
name: '代买饭',
|
|
isCheck: false
|
|
}, {
|
|
name: '代取快递/跑腿',
|
|
isCheck: false
|
|
}],
|
|
dataList: [],
|
|
areaList: [],
|
|
areaKeyword: '',
|
|
orderLists: [],
|
|
waimaiCount: 0,
|
|
kuaidiCount: 0,
|
|
paotuiCount: 0,
|
|
productData: [],
|
|
zhipaiCount: 0,
|
|
searchForm: {
|
|
hallOnly: true,
|
|
status: 0,
|
|
pageNum: 1,
|
|
pageSize:10,
|
|
getAreaId: '',
|
|
putAreaId: '',
|
|
paths: ['home_top', 'home_center_left_top', 'home_center_left_bottom', 'home_center_right_top',
|
|
'home_center_right_bottom'
|
|
],
|
|
order: '',
|
|
regionId: '',
|
|
deliveryType: 1,
|
|
waimaiData: [],
|
|
workerId: uni.getStorageSync('worker') ? uni.getStorageSync('worker').workerId : '',
|
|
kuaidiData: []
|
|
},
|
|
checked: 'waimai',
|
|
navBarHeight: 0,
|
|
menuListOffsetTop: 0,
|
|
lastScrollTop: 0,
|
|
lastRefreshTime: 0,
|
|
worker: null,
|
|
isSwitching: true,
|
|
getAreaData: {},
|
|
putAreaData: {},
|
|
yongjin: false,
|
|
waimailistData: [],
|
|
kuaidilistData: [],
|
|
isgetArea: false,
|
|
isputArea: false,
|
|
checkYongjin: false,
|
|
getshopArea: [],
|
|
putshopArea: [],
|
|
totalPages: 1,
|
|
swipeOrderDefaultStyle: {
|
|
progress: 'width: 0%;',
|
|
thumb: 'left: 0%; transform: translateX(-0%);'
|
|
},
|
|
swipeOrder: {
|
|
id: '',
|
|
index: -1,
|
|
startX: 0,
|
|
startProgress: 0,
|
|
progress: 0,
|
|
progressStyle: 'width: 0%;',
|
|
thumbStyle: 'left: 0%; transform: translateX(-0%);',
|
|
trackWidth: 0,
|
|
confirmed: false
|
|
}
|
|
}
|
|
},
|
|
components: {
|
|
tabBar,
|
|
deLivery,
|
|
postList,
|
|
myCenter
|
|
},
|
|
computed: {
|
|
filteredAreaList() {
|
|
const keyword = this.areaKeyword.trim().toLowerCase()
|
|
if (!keyword) return this.areaList
|
|
return this.areaList.filter((item) => {
|
|
const title = item.title ? String(item.title).toLowerCase() : ''
|
|
return title.indexOf(keyword) > -1
|
|
})
|
|
}
|
|
},
|
|
filters: {
|
|
formatHourMinute(value) {
|
|
if (!value) return '';
|
|
|
|
const date = new Date(value);
|
|
|
|
// 获取日 (getDate),并补齐0
|
|
const day = String(date.getDate()).padStart(2, '0');
|
|
|
|
// 获取小时 (getHours),并补齐0
|
|
const hour = String(date.getHours()).padStart(2, '0');
|
|
|
|
// 获取分钟 (getMinutes),并补齐0
|
|
const minute = String(date.getMinutes()).padStart(2, '0');
|
|
|
|
// 拼接格式:日-日-时:分
|
|
return `${day}-${hour}:${minute}`;
|
|
},
|
|
delNode(data) {
|
|
// 1. 统一转为字符串
|
|
let str;
|
|
if (typeof data === 'object' && data !== null) {
|
|
// 对象或数组 → JSON 字符串
|
|
str = JSON.stringify(data);
|
|
} else if (typeof data === 'string') {
|
|
str = data;
|
|
} else {
|
|
// 其他类型(数字、布尔等)先转字符串
|
|
str = String(data);
|
|
}
|
|
|
|
// 2. 删除所有大括号 { } 和双引号 "
|
|
const result = str.replace(/[{}"]/g, '');
|
|
return result;
|
|
}
|
|
},
|
|
onPageScroll(e) {
|
|
const scrollTop = e.scrollTop;
|
|
// 原始 scrollTop 走非响应式字段,避免每帧 setData
|
|
const prev = this._scrollTopRaw || 0;
|
|
const isScrollingUp = scrollTop < prev;
|
|
// 向上滑到靠近页面顶部时(背景头图区域),切换到上一个分类
|
|
// 门槛用 80px:用户需要明确地滑回头部较大区域,避免误触发
|
|
if (isScrollingUp && scrollTop < 80 && !this.isSwitching) {
|
|
const currIdx = this.menuList ? this.menuList.findIndex(m => m.checked) : -1;
|
|
if (currIdx > 0) {
|
|
this._switchCategory(currIdx - 1);
|
|
}
|
|
}
|
|
this._scrollTopRaw = scrollTop;
|
|
// 模板里只关心 >300 / >583 两个布尔判断,所以把 lastScrollTop 阶段化:
|
|
// <300 → 0;300~583 → 400;>583 → 600,确保跨阶段时才触发一次 setData
|
|
const stage = scrollTop > 583 ? 600 : (scrollTop > 300 ? 400 : 0);
|
|
if (stage !== this.lastScrollTop) {
|
|
this.lastScrollTop = stage;
|
|
}
|
|
},
|
|
onReachBottom() {
|
|
// 接管原 delivery-list scroll-view 的 scrolltolower 分页
|
|
if (this.searchForm.pageNum >= this.totalPages) return;
|
|
this.searchForm.pageNum++;
|
|
this.getDelivery();
|
|
},
|
|
onLoad() {
|
|
|
|
},
|
|
onShow() {
|
|
this.indexInit()
|
|
},
|
|
onReady() {
|
|
// 记录分类栏相对页面的偏移量,用于上滑检测
|
|
setTimeout(() => {
|
|
const query = uni.createSelectorQuery().in(this);
|
|
query.select('#menuList').boundingClientRect(rect => {
|
|
if (rect) this.menuListOffsetTop = rect.top + (this._scrollTopRaw || 0);
|
|
}).exec();
|
|
}, 500);
|
|
},
|
|
methods: {
|
|
indexInit() {
|
|
let that = this
|
|
uni.getSystemInfo({
|
|
success: function(info) {
|
|
that.width = info.screenWidth * 2;
|
|
}
|
|
});
|
|
let worker = uni.getStorageSync('worker')
|
|
if (worker != '' && worker != undefined && worker != null) {
|
|
this.worker = worker
|
|
}
|
|
that.searchForm.workerId = uni.getStorageSync('worker') ? uni.getStorageSync('worker').workerId : ''
|
|
// 获取用户当前位置
|
|
// this.getUserLocation();
|
|
this.getUserOrders();
|
|
if (!uni.getStorageSync('area')) {
|
|
this.checkArea()
|
|
} else {
|
|
if (uni.getStorageSync('area')) {
|
|
this.searchForm.regionId = JSON.parse(uni.getStorageSync('area')).id;
|
|
}
|
|
let area = JSON.parse(uni.getStorageSync('area'))
|
|
this.areaName = area.title
|
|
if (uni.getStorageSync('waimaiData')) {
|
|
this.waimailistData = []
|
|
let waimailist = uni.getStorageSync('waimaiData')
|
|
if (waimailist.length > 0) {
|
|
for (let a = 0; a < waimailist.length; a++) {
|
|
let waimai = {
|
|
getAreaId: waimailist[a].getAreaId,
|
|
putAreaId: waimailist[a].putAreaId
|
|
}
|
|
this.waimailistData.push(waimai);
|
|
}
|
|
}
|
|
}
|
|
if (uni.getStorageSync('kuaidiData')) {
|
|
this.kuaidilistData = []
|
|
let waimailist = uni.getStorageSync('kuaidiData')
|
|
if (waimailist.length > 0) {
|
|
for (let a = 0; a < waimailist.length; a++) {
|
|
let waimai = {
|
|
getAreaId: waimailist[a].getAreaId,
|
|
putAreaId: waimailist[a].putAreaId
|
|
}
|
|
this.kuaidilistData.push(waimai);
|
|
}
|
|
}
|
|
}
|
|
this.searchForm.waimaiData = this.waimailistData;
|
|
this.searchForm.kuaidiData = [];
|
|
this.getDelivery();
|
|
this.getShopArea();
|
|
this.$refs.tabBar.getWorkerCounts()
|
|
}
|
|
// 计算导航栏高度用于sticky offset:statusBarHeight + 40px内容区
|
|
const info = uni.getSystemInfoSync();
|
|
this.navBarHeight = info.statusBarHeight;
|
|
this.swipeOrderBaseWidth = info.windowWidth * 0.86;
|
|
},
|
|
clearCheck() {
|
|
this.checkYongjin = false
|
|
this.putAreaData = {}
|
|
this.getAreaData = {}
|
|
this.searchForm.getAreaId = ""
|
|
this.searchForm.putAreaId = ""
|
|
this.searchForm.order = ""
|
|
this.getDelivery()
|
|
this.$forceUpdate()
|
|
},
|
|
// 内部切换方法:带isSwitching保护,防止程序化滚动期间闪回
|
|
_switchCategory(index) {
|
|
if (this.isSwitching) return;
|
|
this.isSwitching = true;
|
|
this.checkTab(index);
|
|
// 400ms后解除锁(动画200ms,预留200ms缓冲)
|
|
setTimeout(() => {
|
|
this.isSwitching = false;
|
|
}, 400);
|
|
},
|
|
productDetail(item) {
|
|
this.productData = item;
|
|
this.$refs.productPopup.open()
|
|
},
|
|
getSwipeProgress(item, index) {
|
|
if (this.swipeOrder.id === item.id && this.swipeOrder.index === index) {
|
|
return this.swipeOrder.progress
|
|
}
|
|
return 0
|
|
},
|
|
isSwipeOrderActive(item, index) {
|
|
return this.swipeOrder.id === item.id && this.swipeOrder.index === index && this.swipeOrder.progress > 0
|
|
},
|
|
//滑动开始
|
|
startSwipeOrder(event, item, index) {
|
|
const touch = event.touches && event.touches[0]
|
|
if (!touch) return
|
|
this.swipeOrder = {
|
|
id: item.id,
|
|
index,
|
|
startX: touch.clientX,
|
|
startProgress: 0,
|
|
progress: 0,
|
|
progressStyle: 'width: 0%;',
|
|
thumbStyle: 'left: 0%; transform: translateX(-0%);',
|
|
trackWidth: this.swipeOrderBaseWidth || 0,
|
|
confirmed: false
|
|
}
|
|
this.$nextTick(() => {
|
|
uni.createSelectorQuery().in(this).select('#swipe-order-' + item.id).boundingClientRect((rect) => {
|
|
if (rect && this.swipeOrder.id === item.id && this.swipeOrder.index === index) {
|
|
this.swipeOrder.trackWidth = rect.width
|
|
}
|
|
}).exec()
|
|
})
|
|
},
|
|
moveSwipeOrder(event) {
|
|
const touch = event.touches && event.touches[0]
|
|
if (!touch || this.swipeOrder.id === '') return
|
|
const trackWidth = this.swipeOrder.trackWidth || this.swipeOrderBaseWidth || 1
|
|
const deltaX = Math.max(0, touch.clientX - this.swipeOrder.startX)
|
|
const progress = Math.min(100, Math.round(deltaX / (trackWidth * 0.72) * 100))
|
|
this.setSwipeOrderProgress(progress)
|
|
},
|
|
//滑动结束
|
|
endSwipeOrder(item, index) {
|
|
if (this.swipeOrder.id !== item.id || this.swipeOrder.index !== index) return
|
|
if (this.swipeOrder.progress >= 92 && !this.swipeOrder.confirmed) {
|
|
this.swipeOrder.confirmed = true
|
|
this.setSwipeOrderProgress(100)
|
|
this.getOrder(item, index)
|
|
return
|
|
}
|
|
this.resetSwipeOrder()
|
|
},
|
|
resetSwipeOrder() {
|
|
this.swipeOrder = {
|
|
id: '',
|
|
index: -1,
|
|
startX: 0,
|
|
startProgress: 0,
|
|
progress: 0,
|
|
progressStyle: 'width: 0%;',
|
|
thumbStyle: 'left: 0%; transform: translateX(-0%);',
|
|
trackWidth: 0,
|
|
confirmed: false
|
|
}
|
|
},
|
|
setSwipeOrderProgress(progress) {
|
|
if (this.swipeOrder.progress === progress) return
|
|
const progressValue = progress + '%'
|
|
this.swipeOrder.progress = progress
|
|
this.swipeOrder.progressStyle = 'width: ' + progressValue + ';'
|
|
this.swipeOrder.thumbStyle = 'left: ' + progressValue + '; transform: translateX(-' + progressValue + ');'
|
|
},
|
|
noop() {},
|
|
pageshow(){
|
|
this.$refs.pagesPopup.open()
|
|
},
|
|
getOrder(item, index) {
|
|
let that = this
|
|
|
|
let data = {
|
|
groupId: item.groupId ? item.groupId : '',
|
|
deliveryId: item.id,
|
|
workerId: uni.getStorageSync('worker') ? uni.getStorageSync('worker').workerId : '',
|
|
workerPhone: uni.getStorageSync('worker') ? uni.getStorageSync('worker').mobile : '',
|
|
workerName: uni.getStorageSync('worker') ? uni.getStorageSync('worker').workerName : '',
|
|
regionId: JSON.parse(uni.getStorageSync('area')).id,
|
|
geolocation: that.latitude + ',' + that.longitude
|
|
}
|
|
|
|
that.tui.request("/mall/delivery/accept", "POST", data, false, true).then((res) => {
|
|
that.loadStatus = 'nomore';
|
|
if (res.code == 200) {
|
|
that.resetSwipeOrder();
|
|
if (!uni.getStorageSync('worker') && res.result != null) {
|
|
this.$refs.tishiPopup.open()
|
|
uni.setStorageSync('worker', res.result)
|
|
that.$refs.tabBar.indexWorkerCount ++
|
|
}else{
|
|
if(res.message == '接单成功'){
|
|
that.tui.toast(res.message);
|
|
that.$refs.tabBar.indexWorkerCount ++
|
|
}else{
|
|
that.tui.toast(res.message,2000);
|
|
}
|
|
}
|
|
that.deliveryItem.splice(index, 1)
|
|
|
|
if (item.workerId != null && item.workerId != undefined && item.workerId != '') {
|
|
that.zhipaiCount -= 1
|
|
} else {
|
|
if (item.deliveryType == 1) {
|
|
that.waimaiCount -= 1
|
|
} else if (item.deliveryType == 2) {
|
|
that.kuaidiCount -= 1
|
|
} else if (item.deliveryType == 3) {
|
|
that.paotuiCount -= 1
|
|
}
|
|
}
|
|
|
|
setTimeout(res => {
|
|
this.getUserLocation(uni.getStorageSync('worker') ? uni.getStorageSync('worker').workerId : res.result.workerId)
|
|
}, 2000)
|
|
that.$forceUpdate();
|
|
} else {
|
|
that.resetSwipeOrder();
|
|
that.tui.toast(res.message);
|
|
return;
|
|
}
|
|
}).catch((res) => {});
|
|
},
|
|
rejectOrder(item, index) {
|
|
let that = this
|
|
this.tui.request("/mall/delivery/reject", "POST", {
|
|
deliveryId: item.id
|
|
}, false, true).then((res) => {
|
|
if (res.code == 200) {
|
|
that.deliveryItem.splice(index, 1)
|
|
that.tui.toast(res.message);
|
|
if (item.workerId != null && item.workerId != undefined && item.workerId != '') {
|
|
that.zhipaiCount -= 1
|
|
} else {
|
|
if (item.deliveryType == 1) {
|
|
that.waimaiCount -= 1
|
|
} else if (item.deliveryType == 2) {
|
|
that.kuaidiCount -= 1
|
|
} else if (item.deliveryType == 3) {
|
|
that.paotuiCount -= 1
|
|
}
|
|
}
|
|
that.$forceUpdate();
|
|
} else {
|
|
that.tui.toast(res.message);
|
|
return;
|
|
}
|
|
uni.hideLoading();
|
|
}).catch((res) => {});
|
|
},
|
|
getDelivery() {
|
|
let that = this
|
|
that.waimaiCount = 0
|
|
that.kuaidiCount = 0
|
|
that.paotuiCount = 0
|
|
that.zhipaiCount = 0
|
|
that.adList = []
|
|
this.tui.request("/mall/delivery/page", "POST", this.searchForm, false, false).then((res) => {
|
|
that.loadStatus = 'nomore';
|
|
if (res.code == 200) {
|
|
that.mallAds = res.result.mallAds
|
|
for(let i=0;i<that.mallAds.length;i++){
|
|
if(that.mallAds[i].position == 'home_top'){
|
|
that.adList.push(that.mallAds[i])
|
|
// 判断字符串中是否包含逗号
|
|
if (that.mallAds[i].adImage.indexOf(',') !== -1) {
|
|
if (that.mallAds[i].adImage.endsWith(',')) {
|
|
that.mallAds[i].adImage = that.mallAds[i].adImage.slice(0, -1);
|
|
}
|
|
}
|
|
}else{
|
|
if (that.mallAds[i].adImage.endsWith(',')) {
|
|
that.mallAds[i].adImage = that.mallAds[i].adImage.slice(0, -1);
|
|
}
|
|
|
|
}
|
|
}
|
|
if (that.searchForm.pageNum == 1) {
|
|
that.deliveryItem = res.result.records;
|
|
} else {
|
|
that.deliveryItem = [...that.deliveryItem, ...res.result.records]
|
|
}
|
|
if (res.result.orderCount != null && res.result.orderCount.length > 0) {
|
|
for (let i = 0; i < res.result.orderCount.length; i++) {
|
|
if (res.result.orderCount[i].deliveryType == 1) {
|
|
that.waimaiCount = res.result.orderCount[i].orderCount
|
|
} else if (res.result.orderCount[i].deliveryType == 2) {
|
|
that.kuaidiCount = res.result.orderCount[i].orderCount
|
|
} else if (res.result.orderCount[i].deliveryType == 3) {
|
|
that.paotuiCount = res.result.orderCount[i].orderCount
|
|
}
|
|
}
|
|
}else{
|
|
that.waimaiCount = 0
|
|
that.kuaidiCount = 0
|
|
that.paotuiCount = 0
|
|
}
|
|
|
|
if (res.result.zhipaiCount != undefined && res.result.zhipaiCount != null) {
|
|
that.zhipaiCount = res.result.zhipaiCount
|
|
}
|
|
that.totalPages = res.result.pages; // pages = 总页数
|
|
that.$forceUpdate();
|
|
} else {
|
|
that.tui.toast(res.message);
|
|
return;
|
|
}
|
|
uni.hideLoading();
|
|
}).catch((res) => {});
|
|
},
|
|
//广告跳转
|
|
goAdPage(item) {
|
|
uni.navigateTo({
|
|
url: item.linkUrl + item.linkParams
|
|
})
|
|
},
|
|
checkTab(index) {
|
|
for (let i = 0; i < this.menuList.length; i++) {
|
|
this.menuList[i].checked = (i === index);
|
|
}
|
|
// 重置分页
|
|
this.searchForm.pageNum = 1;
|
|
this.pageNum = 1;
|
|
this.total = 1;
|
|
this.productItem = [];
|
|
// this.getProduct(this.menuList[index].id);
|
|
// 滚动到正确位置:分类栏刚好吸顶在nav-bar下方
|
|
// menuListOffsetTop - navBarHeight 使分类栏正好在sticky位置,首条商品可见
|
|
const target = this.menuListOffsetTop - this.navBarHeight;
|
|
uni.pageScrollTo({
|
|
scrollTop: target > 0 ? target : 0,
|
|
duration: 200
|
|
});
|
|
},
|
|
//本方法展示所有已经完成页面,方便查找
|
|
aaaaaaa(item) {
|
|
uni.navigateTo({
|
|
url: item.url
|
|
})
|
|
},
|
|
goSeckillGroup() {
|
|
uni.navigateTo({
|
|
url: '/package2/seckill/seckillGroup'
|
|
})
|
|
},
|
|
//跳转到子页面
|
|
goDetail(type) {
|
|
let url = ''
|
|
switch (type) {
|
|
case '1':
|
|
url = '/package1/runErrand/runErrand'
|
|
break;
|
|
case '2':
|
|
url = '/package2/group/groupBuyList'
|
|
break;
|
|
case '3':
|
|
url = '/package2/group/studentStoreList'
|
|
break;
|
|
case '4':
|
|
url = '/package1/planet/index'
|
|
break;
|
|
case '5':
|
|
url = '/package1/ieBrowser/index'
|
|
break;
|
|
}
|
|
uni.navigateTo({
|
|
url: url
|
|
})
|
|
},
|
|
//跳转到订单详情
|
|
goOrderDetail(item) {
|
|
uni.navigateTo({
|
|
url: '/package1/order/orderDetail?id=' + item.id
|
|
});
|
|
},
|
|
//选择区域
|
|
onClickArea(item) {
|
|
uni.setStorageSync('area', JSON.stringify(item))
|
|
this.areaName = item.title
|
|
this.areaKeyword = ''
|
|
this.searchForm.regionId = item.id
|
|
this.getDelivery();
|
|
this.getShopArea();
|
|
let that = this
|
|
that.tui.request("/worker/admin/add", "POST", {
|
|
userId: uni.getStorageSync('id'),
|
|
isChangeArea: 0,
|
|
region: item.id
|
|
}, false, true).then((res) => {
|
|
if (res.code == 200) {
|
|
if (res.result != null) {
|
|
uni.setStorageSync('worker', res.result)
|
|
}
|
|
} else {
|
|
that.tui.toast(res.message)
|
|
return
|
|
}
|
|
uni.hideLoading()
|
|
}).catch((res) => {})
|
|
this.$refs.areaPopup.close()
|
|
},
|
|
checkArea() {
|
|
this.tui.request("/app/shopArea/getByParentId/0", "get", {}, false, false).then((res) => {
|
|
if (res.code == 200) {
|
|
this.areaList = res.result
|
|
this.areaKeyword = ''
|
|
this.$refs.areaPopup.open();
|
|
} else {
|
|
this.tui.toast(res.message)
|
|
}
|
|
})
|
|
},
|
|
//获取筛选条件列表
|
|
getShopArea() {
|
|
let that = this
|
|
that.tui.request("/app/shopArea/getByParentId/" + that.searchForm.regionId, "GET", {}, false, true).then((
|
|
res) => {
|
|
if (res.code == 200) {
|
|
if (res.result != null) {
|
|
that.getshopArea = res.result
|
|
that.putshopArea = res.result
|
|
}
|
|
} else {
|
|
that.tui.toast(res.message)
|
|
return
|
|
}
|
|
}).catch((res) => {})
|
|
},
|
|
//获取用户当前未完成订单
|
|
getUserOrders() {
|
|
let that = this
|
|
that.tui.request("/mall/order/getOrdersByUserId/" + uni.getStorageSync('id'), "GET", {}, false, true).then(
|
|
(res) => {
|
|
if (res.code == 200) {
|
|
if (res.result != null) {
|
|
that.orderLists = res.result
|
|
that.$forceUpdate()
|
|
}
|
|
} else {
|
|
that.tui.toast(res.message)
|
|
return
|
|
}
|
|
}).catch((res) => {})
|
|
},
|
|
//点击下拉框中某一条筛选条件
|
|
searchOrder(type, value) {
|
|
if (type == 'shuaxin') {
|
|
const now = Date.now();
|
|
const refreshInterval = 10 * 1000;
|
|
const diff = now - this.lastRefreshTime;
|
|
if (diff < refreshInterval) {
|
|
const waitSeconds = Math.ceil((refreshInterval - diff) / 1000);
|
|
this.tui.toast(waitSeconds + '秒后再刷新');
|
|
return;
|
|
}
|
|
this.lastRefreshTime = now;
|
|
}
|
|
if (type == 'getarea') {
|
|
if (this.searchForm.getAreaId == value.id) {
|
|
this.searchForm.getAreaId = ''
|
|
this.getAreaData = {}
|
|
} else {
|
|
this.searchForm.getAreaId = value.id
|
|
this.getAreaData = value
|
|
}
|
|
this.isgetArea = !this.isgetArea
|
|
// this.searchForm.shopArea = value
|
|
} else if (type == 'putarea') {
|
|
if (this.searchForm.putAreaId == value.id) {
|
|
this.searchForm.putAreaId = ''
|
|
this.putAreaData = {}
|
|
} else {
|
|
this.searchForm.putAreaId = value.id
|
|
this.putAreaData = value
|
|
}
|
|
this.isputArea = !this.isputArea
|
|
} else if (type == 'yongjin') {
|
|
this.checkYongjin = !this.checkYongjin
|
|
if (this.checkYongjin) {
|
|
this.searchForm.order = 'deliveryFee'
|
|
} else {
|
|
this.searchForm.order = ''
|
|
}
|
|
} else if (type == 'delgetarea') {
|
|
this.searchForm.getAreaId = ''
|
|
this.getAreaData = {}
|
|
} else if (type == 'delputarea') {
|
|
this.searchForm.putAreaId = ''
|
|
this.putAreaData = {}
|
|
} else if (type == 'delyongjin') {
|
|
this.checkYongjin = false
|
|
this.searchForm.order = ''
|
|
}
|
|
this.searchForm.pageNum = 1
|
|
this.getDelivery();
|
|
},
|
|
// 获取用户位置
|
|
getUserLocation(id) {
|
|
let that = this;
|
|
uni.getLocation({
|
|
type: 'gcj02', // 返回国测局坐标,用于微信小程序地图组件
|
|
isHighAccuracy:true,
|
|
success: (res) => {
|
|
that.latitude = res.latitude;
|
|
that.longitude = res.longitude;
|
|
that.tui.request('/worker/admin/editLocation', "POST", {workerId:id,geolocation:that.latitude + ',' + that.longitude}, false, false,true).then((res) => {
|
|
|
|
}).catch((res) => {});
|
|
},
|
|
fail: (err) => {}
|
|
});
|
|
},
|
|
//配送单列表切换
|
|
checkTab1(type) {
|
|
this.checked = type
|
|
if (type == 'waimai') {
|
|
this.searchForm.deliveryType = 1
|
|
this.searchForm.waimaiData = this.waimailistData;
|
|
this.searchForm.kuaidiData = [];
|
|
} else if (type == 'kuaidi') {
|
|
this.searchForm.deliveryType = 2
|
|
this.searchForm.waimaiData = [];
|
|
this.searchForm.kuaidiData = this.kuaidilistData;
|
|
} else if (type == 'paotui') {
|
|
this.searchForm.deliveryType = 3
|
|
this.searchForm.waimaiData = [];
|
|
this.searchForm.kuaidiData = [];
|
|
} else if (type == 'zhipai') {
|
|
this.searchForm.deliveryType = 4
|
|
this.searchForm.waimaiData = [];
|
|
this.searchForm.kuaidiData = [];
|
|
}
|
|
this.getDelivery()
|
|
this.$nextTick(() => {
|
|
this.scrollToDaimaiPanel()
|
|
})
|
|
this.$forceUpdate()
|
|
},
|
|
scrollToDaimaiPanel() {
|
|
const query = uni.createSelectorQuery().in(this);
|
|
query.select('#menuList').boundingClientRect(rect => {
|
|
if (!rect) return;
|
|
const stickyTop = this.navBarHeight + 46;
|
|
const target = rect.top + (this._scrollTopRaw || 0) - stickyTop;
|
|
uni.pageScrollTo({
|
|
scrollTop: target > 0 ? target : 0,
|
|
duration: 260
|
|
});
|
|
}).exec();
|
|
},
|
|
//拨打电话
|
|
makeCall(phone) {
|
|
uni.makePhoneCall({
|
|
phoneNumber: phone
|
|
});
|
|
},
|
|
// 页面卸载时清除定时器
|
|
onUnload() {
|
|
if (this.deliveryTimer) {
|
|
clearInterval(this.deliveryTimer);
|
|
}
|
|
},
|
|
//筛选条件
|
|
checkAdd() {
|
|
this.isgetArea = !this.isgetArea
|
|
},
|
|
//筛选条件
|
|
checkAdd1() {
|
|
this.isputArea = !this.isputArea
|
|
},
|
|
//底部tab切换组件状态改变
|
|
changeIndex(index) {
|
|
let that = this;
|
|
this.lastIndex = this.currentIndex
|
|
if(index != 2){
|
|
this.currentIndex = index
|
|
}
|
|
|
|
switch (index) {
|
|
case 0:
|
|
this.indexInit()
|
|
break;
|
|
case 1:
|
|
that.$refs.deLiveryPage.init()
|
|
break;
|
|
case 2:
|
|
uni.navigateTo({
|
|
url: '/package1/tabbar/release'
|
|
})
|
|
break;
|
|
case 3:
|
|
that.$refs.postListPage.init()
|
|
break;
|
|
case 4:
|
|
that.$refs.myCenterPage.init()
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
page {
|
|
width: 100%;
|
|
height: 100%;
|
|
font-size: 28rpx;
|
|
background: linear-gradient(180deg, #f2fff8 0%, #fffdf4 32%, #f7fbf6 100%);
|
|
color: #00231C;
|
|
}
|
|
|
|
.page1 {
|
|
width: 100%;
|
|
height: 100%;
|
|
font-size: 28rpx;
|
|
background:
|
|
radial-gradient(circle at 12% 12%, rgba(166, 255, 234, 0.34) 0, rgba(166, 255, 234, 0) 240rpx),
|
|
radial-gradient(circle at 90% 36%, rgba(255, 216, 168, 0.26) 0, rgba(255, 216, 168, 0) 260rpx);
|
|
}
|
|
|
|
/* 吸顶后上方区域不可见,暂停所有 infinite 动画,降低主线程合成压力 */
|
|
.page1.is-sticky .like-content-box::before,
|
|
.page1.is-sticky .like-left,
|
|
.page1.is-sticky .like-hot-gif,
|
|
.page1.is-sticky .list-type,
|
|
.page1.is-sticky .list-total text,
|
|
.page1.is-sticky .group-cta,
|
|
.page1.is-sticky .hero-particle,
|
|
.page1.is-sticky .life-ip,
|
|
.page1.is-sticky .life-progress-bar,
|
|
.page1.is-sticky .menu-list img,
|
|
.page1.is-sticky .world-light,
|
|
.page1.is-sticky .world-dot,
|
|
.page1.is-sticky .seckill-entry,
|
|
.page1.is-sticky .seckill-entry-light,
|
|
.page1.is-sticky .seckill-entry-sub,
|
|
.page1.is-sticky .seckill-entry-btn,
|
|
.page1.is-sticky .heat-dot,
|
|
.page1.is-sticky .brand-memory-strip text {
|
|
animation-play-state: paused !important;
|
|
}
|
|
|
|
.swiper-container {
|
|
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
|
|
.swiper-page {
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
|
|
.swiper {
|
|
width: 100%;
|
|
height: 440rpx;
|
|
z-index: 99 !important;
|
|
}
|
|
|
|
.swiper img {
|
|
width: 100%;
|
|
height: 100%;
|
|
z-index: 99 !important;
|
|
border-radius:10px;
|
|
}
|
|
|
|
.campus-hero {
|
|
width: 100%;
|
|
height: 440rpx;
|
|
margin: 0;
|
|
border-radius: 0 0 26rpx 26rpx;
|
|
background: linear-gradient(135deg, #eaffd9 0%, #b9ffe9 46%, #fff7c8 100%);
|
|
box-shadow: 0 18rpx 38rpx rgba(44, 155, 121, 0.1);
|
|
overflow: hidden;
|
|
position: relative;
|
|
z-index: 2;
|
|
}
|
|
|
|
.hero-bg-swiper {
|
|
position: absolute;
|
|
left: 0;
|
|
top: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
z-index: 0 !important;
|
|
}
|
|
|
|
.hero-bg-img {
|
|
width: 100%;
|
|
height: 100%;
|
|
display: block;
|
|
object-fit: cover;
|
|
border-radius: 0 0 26rpx 26rpx !important;
|
|
transform: scale(1.01);
|
|
}
|
|
|
|
.hero-bg-mask {
|
|
width: 100%;
|
|
height: 100%;
|
|
position: absolute;
|
|
left: 0;
|
|
top: 0;
|
|
z-index: 1;
|
|
pointer-events: none;
|
|
background:
|
|
linear-gradient(180deg, rgba(234, 255, 246, 0.02) 0%, rgba(234, 255, 246, 0.1) 68%, rgba(234, 255, 246, 0.24) 100%),
|
|
radial-gradient(circle at 8% 12%, rgba(166, 255, 234, 0.18) 0, rgba(166, 255, 234, 0) 170rpx);
|
|
}
|
|
|
|
.hero-live-strip {
|
|
display: flex;
|
|
align-items: center;
|
|
position: absolute;
|
|
left: 30rpx;
|
|
right: 30rpx;
|
|
bottom: 18rpx;
|
|
z-index: 4;
|
|
overflow: hidden;
|
|
pointer-events: none;
|
|
}
|
|
|
|
.hero-live-strip text {
|
|
flex-shrink: 0;
|
|
height: 42rpx;
|
|
margin-right: 12rpx;
|
|
padding: 0 16rpx;
|
|
border-radius: 999rpx;
|
|
background: rgba(255, 255, 255, 0.72);
|
|
color: #0f695b;
|
|
font-size: 20rpx;
|
|
font-weight: 900;
|
|
line-height: 42rpx;
|
|
box-shadow: 0 8rpx 18rpx rgba(0, 35, 28, 0.08);
|
|
}
|
|
|
|
.campus-hero::after {
|
|
content: '';
|
|
width: 520rpx;
|
|
height: 520rpx;
|
|
position: absolute;
|
|
right: -210rpx;
|
|
bottom: -220rpx;
|
|
border-radius: 50%;
|
|
background: rgba(255, 255, 255, 0.26);
|
|
box-shadow: inset 0 0 80rpx rgba(255, 255, 255, 0.42);
|
|
z-index: 1;
|
|
pointer-events: none;
|
|
}
|
|
|
|
.hero-glow,
|
|
.hero-particle {
|
|
position: absolute;
|
|
border-radius: 50%;
|
|
pointer-events: none;
|
|
z-index: 2;
|
|
}
|
|
|
|
.hero-glow {
|
|
opacity: 0.26;
|
|
}
|
|
|
|
.hero-glow-a {
|
|
width: 220rpx;
|
|
height: 220rpx;
|
|
left: -70rpx;
|
|
top: -60rpx;
|
|
background: rgba(255, 255, 255, 0.36);
|
|
}
|
|
|
|
.hero-glow-b {
|
|
width: 180rpx;
|
|
height: 180rpx;
|
|
right: 120rpx;
|
|
top: -70rpx;
|
|
background: rgba(255, 255, 255, 0.28);
|
|
}
|
|
|
|
.hero-particle {
|
|
width: 16rpx;
|
|
height: 16rpx;
|
|
background: rgba(255, 255, 255, 0.78);
|
|
box-shadow: 0 0 20rpx rgba(255, 255, 255, 0.8);
|
|
animation: particleDrift 8s ease-in-out infinite;
|
|
}
|
|
|
|
.hero-particle-a {
|
|
left: 80rpx;
|
|
top: 70rpx;
|
|
}
|
|
|
|
.hero-particle-b {
|
|
right: 96rpx;
|
|
top: 48rpx;
|
|
animation-delay: 1s;
|
|
}
|
|
|
|
.hero-particle-c {
|
|
left: 330rpx;
|
|
bottom: 62rpx;
|
|
animation-delay: 1.8s;
|
|
}
|
|
|
|
.order-notice-wrap {
|
|
// background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(250, 255, 250, 0.72) 100%);
|
|
position: relative;
|
|
top:10rpx;
|
|
z-index: 3;
|
|
}
|
|
|
|
.order-msg-box {
|
|
width: 95%;
|
|
height: 146rpx;
|
|
padding: 18rpx;
|
|
box-sizing: border-box;
|
|
border-radius: 36rpx;
|
|
border: 1px solid rgba(255, 255, 255, 0.82);
|
|
background:
|
|
radial-gradient(circle at 88% 8%, rgba(166, 255, 234, 0.24) 0, rgba(166, 255, 234, 0) 130rpx),
|
|
linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(247, 255, 251, 0.76));
|
|
box-shadow: 0 20rpx 46rpx rgba(0, 35, 28, 0.09), inset 0 0 0 1px rgba(255, 255, 255, 0.68);
|
|
z-index: 99;
|
|
position: absolute;
|
|
left: 2.5%;
|
|
bottom: 0;
|
|
display: flex;
|
|
align-items: center;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.order-msg-box::after {
|
|
content: '';
|
|
width: 260rpx;
|
|
height: 150rpx;
|
|
border-radius: 50%;
|
|
background: linear-gradient(135deg, rgba(255, 244, 217, 0.34) 0%, rgba(166, 255, 234, 0) 72%);
|
|
position: absolute;
|
|
right: -130rpx;
|
|
top: -80rpx;
|
|
}
|
|
|
|
.order-msg-left {
|
|
width: 88rpx;
|
|
height: 88rpx;
|
|
flex-shrink: 0;
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
|
|
.order-msg-left img {
|
|
width: 70rpx;
|
|
height: 70rpx;
|
|
margin: 9rpx;
|
|
}
|
|
|
|
.order-msg-center {
|
|
flex: 1;
|
|
min-width: 0;
|
|
height: auto;
|
|
display: flex;
|
|
flex-direction: column;
|
|
margin-left: 18rpx;
|
|
padding-left: 0;
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
|
|
.order-msg-right {
|
|
width: 78rpx;
|
|
height: 58rpx;
|
|
margin-left: 16rpx;
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
|
|
.life-ip {
|
|
border-radius: 30rpx;
|
|
background: linear-gradient(135deg, #fff7d7, #a6ffea);
|
|
box-shadow: 0 12rpx 24rpx rgba(0, 35, 28, 0.08);
|
|
}
|
|
|
|
.life-status-title {
|
|
color: #0f3e36;
|
|
font-size: 28rpx;
|
|
font-weight: 900;
|
|
line-height: 36rpx;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.life-progress {
|
|
width: 100%;
|
|
height: 12rpx;
|
|
margin: 12rpx 0 8rpx;
|
|
border-radius: 999rpx;
|
|
background: rgba(16, 118, 98, 0.08);
|
|
overflow: hidden;
|
|
}
|
|
|
|
.life-progress-bar {
|
|
height: 100%;
|
|
border-radius: 999rpx;
|
|
background: linear-gradient(90deg, #42d7b9, #fff171);
|
|
box-shadow: 0 0 18rpx rgba(66, 215, 185, 0.52);
|
|
}
|
|
|
|
.life-status-desc {
|
|
color: rgba(18, 73, 63, 0.58);
|
|
font-size: 22rpx;
|
|
font-weight: 700;
|
|
line-height: 30rpx;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.life-action {
|
|
border-radius: 999rpx;
|
|
background: #073f34;
|
|
color: #fff;
|
|
font-size: 22rpx;
|
|
font-weight: 900;
|
|
line-height: 58rpx;
|
|
text-align: center;
|
|
box-shadow: 0 12rpx 24rpx rgba(7, 63, 52, 0.18);
|
|
transition: transform 0.18s ease;
|
|
}
|
|
|
|
.life-action:active {
|
|
transform: translateY(-4rpx) scale(0.97);
|
|
}
|
|
|
|
.tabbar {
|
|
width: 100%;
|
|
height: 100rpx;
|
|
background-color: #ffffff;
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: space-around;
|
|
align-items: center;
|
|
border-top: 1px solid #eee;
|
|
box-shadow: 0 -2rpx 10rpx rgba(0, 0, 0, 0.05);
|
|
z-index: 100;
|
|
}
|
|
|
|
.tab-item {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
height: 100%;
|
|
flex: 1;
|
|
position: relative;
|
|
}
|
|
|
|
.tab-text {
|
|
font-size: 28rpx;
|
|
color: #666;
|
|
transition: color 0.3s;
|
|
}
|
|
|
|
.tab-item.active .tab-text {
|
|
color: #007aff;
|
|
font-weight: bold;
|
|
}
|
|
|
|
.tab-indicator {
|
|
position: absolute;
|
|
bottom: 10rpx;
|
|
width: 40rpx;
|
|
height: 4rpx;
|
|
background-color: #007aff;
|
|
border-radius: 2rpx;
|
|
animation: indicatorScale 0.3s ease;
|
|
}
|
|
|
|
@keyframes indicatorScale {
|
|
0% {
|
|
transform: scaleX(0.5);
|
|
opacity: 0;
|
|
}
|
|
|
|
100% {
|
|
transform: scaleX(1);
|
|
opacity: 1;
|
|
}
|
|
}
|
|
|
|
/* 滑动动画效果增强 */
|
|
.swiper-item {
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
}
|
|
|
|
/* 如果需要自定义滑动动画,可以添加以下样式 */
|
|
.swiper-container .uni-swiper-wrapper {
|
|
transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
|
|
}
|
|
|
|
@keyframes softBreath {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0) scale(1);
|
|
}
|
|
|
|
50% {
|
|
transform: translateY(-5rpx) scale(1.025);
|
|
}
|
|
}
|
|
|
|
@keyframes particleDrift {
|
|
0%,
|
|
100% {
|
|
opacity: 0.55;
|
|
transform: translate3d(0, 0, 0);
|
|
}
|
|
|
|
50% {
|
|
opacity: 1;
|
|
transform: translate3d(20rpx, -18rpx, 0);
|
|
}
|
|
}
|
|
|
|
@keyframes lightFlow {
|
|
0%,
|
|
100% {
|
|
opacity: 1;
|
|
}
|
|
|
|
50% {
|
|
opacity: 0.94;
|
|
}
|
|
}
|
|
|
|
@keyframes itemFloat {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0) rotate(0deg);
|
|
}
|
|
|
|
50% {
|
|
transform: translateY(-6rpx) rotate(-2deg);
|
|
}
|
|
}
|
|
|
|
@keyframes numberJump {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0);
|
|
}
|
|
|
|
50% {
|
|
transform: translateY(-3rpx);
|
|
}
|
|
}
|
|
|
|
@keyframes heatParticle {
|
|
0%,
|
|
100% {
|
|
opacity: 0.35;
|
|
transform: translateY(0) scale(0.8);
|
|
}
|
|
|
|
50% {
|
|
opacity: 1;
|
|
transform: translateY(-12rpx) scale(1.18);
|
|
}
|
|
}
|
|
|
|
@keyframes seckillHeatPulse {
|
|
0%,
|
|
100% {
|
|
box-shadow: 0 16rpx 30rpx rgba(255, 91, 39, 0.24), 0 0 40rpx rgba(255, 188, 80, 0.26);
|
|
}
|
|
|
|
50% {
|
|
box-shadow: 0 18rpx 36rpx rgba(255, 91, 39, 0.3), 0 0 54rpx rgba(255, 203, 91, 0.36);
|
|
}
|
|
}
|
|
|
|
@keyframes brandChipFloat {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0);
|
|
}
|
|
|
|
50% {
|
|
transform: translateY(-3rpx);
|
|
}
|
|
}
|
|
|
|
.menu-box {
|
|
width: 95%;
|
|
height: 214rpx;
|
|
display: flex;
|
|
align-items: flex-end;
|
|
margin: 30rpx auto 0;
|
|
padding: 50rpx 8rpx 12rpx;
|
|
box-sizing: border-box;
|
|
border-radius: 38rpx;
|
|
border: 1px solid rgba(255, 255, 255, 0.9);
|
|
background:
|
|
radial-gradient(circle at 12% 0%, rgba(255, 255, 255, 0.94) 0, rgba(255, 255, 255, 0) 150rpx),
|
|
radial-gradient(circle at 92% 78%, rgba(88, 205, 122, 0.18) 0, rgba(88, 205, 122, 0) 170rpx),
|
|
linear-gradient(135deg, rgba(255, 255, 255, 0.96) 0%, rgba(244, 255, 241, 0.94) 50%, rgba(231, 255, 244, 0.96) 100%);
|
|
box-shadow: 0 20rpx 46rpx rgba(0, 35, 28, 0.075), inset 0 1rpx 0 rgba(255, 255, 255, 0.9);
|
|
position: relative;
|
|
z-index: 99;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.menu-box::before {
|
|
content: '校园生活 · 一站搞定';
|
|
position: absolute;
|
|
left: 26rpx;
|
|
top: 17rpx;
|
|
color: #2c8b6f;
|
|
font-size: 22rpx;
|
|
font-weight: 900;
|
|
letter-spacing: 1rpx;
|
|
}
|
|
|
|
.menu-box::after {
|
|
content: '本周精选活动 >';
|
|
position: absolute;
|
|
right: 24rpx;
|
|
top: 16rpx;
|
|
height: 42rpx;
|
|
padding: 0 18rpx;
|
|
border-radius: 999rpx;
|
|
background: rgba(255, 255, 255, 0.76);
|
|
color: #1e6a58;
|
|
font-size: 22rpx;
|
|
font-weight: 900;
|
|
line-height: 42rpx;
|
|
box-shadow: 0 8rpx 18rpx rgba(0, 35, 28, 0.06);
|
|
}
|
|
|
|
.menu-list {
|
|
flex: 1;
|
|
height: 142rpx;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
position: relative;
|
|
z-index: 1;
|
|
border-radius: 30rpx;
|
|
overflow: hidden;
|
|
transition: transform 0.2s cubic-bezier(0.2, 0.9, 0.3, 1.2), background 0.2s ease, box-shadow 0.2s ease;
|
|
}
|
|
|
|
.menu-list:active {
|
|
background: rgba(255, 255, 255, 0.76);
|
|
transform: translateY(-5rpx) scale(0.95);
|
|
box-shadow: 0 10rpx 20rpx rgba(0, 35, 28, 0.06);
|
|
}
|
|
|
|
.menu-list img {
|
|
width: 76rpx;
|
|
height: 76rpx;
|
|
display: block;
|
|
margin: 0 auto;
|
|
position: relative;
|
|
z-index: 2;
|
|
}
|
|
|
|
.menu-list:nth-child(2) img {
|
|
animation-delay: 0.3s;
|
|
}
|
|
|
|
.menu-list:nth-child(3) img {
|
|
animation-delay: 0.6s;
|
|
}
|
|
|
|
.menu-list:nth-child(4) img {
|
|
animation-delay: 0.9s;
|
|
}
|
|
|
|
.menu-list:nth-child(5) img {
|
|
animation-delay: 1.2s;
|
|
}
|
|
|
|
.menu-name {
|
|
text-align: center;
|
|
font-size: 21rpx;
|
|
font-weight: 900;
|
|
margin-top: 6rpx;
|
|
color: #183f36;
|
|
line-height: 28rpx;
|
|
position: relative;
|
|
z-index: 2;
|
|
text-shadow: 0 1rpx 0 rgba(255, 255, 255, 0.85);
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.menu-desc {
|
|
margin-top: 0;
|
|
color: rgba(18, 73, 63, 0.58);
|
|
font-size: 17rpx;
|
|
font-weight: 800;
|
|
line-height: 22rpx;
|
|
position: relative;
|
|
z-index: 2;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.world-light {
|
|
width: 96rpx;
|
|
height: 96rpx;
|
|
position: absolute;
|
|
left: 50%;
|
|
top: 10rpx;
|
|
margin-left: -48rpx;
|
|
border-radius: 50%;
|
|
background: radial-gradient(circle, rgba(166, 255, 234, 0.62) 0%, rgba(166, 255, 234, 0) 68%);
|
|
box-shadow: 0 0 24rpx rgba(166, 255, 234, 0.32);
|
|
z-index: 1;
|
|
}
|
|
|
|
.world-food .world-light {
|
|
background: radial-gradient(circle, rgba(255, 232, 151, 0.72) 0%, rgba(255, 232, 151, 0) 68%);
|
|
}
|
|
|
|
.world-store .world-light {
|
|
background: radial-gradient(circle, rgba(205, 233, 255, 0.72) 0%, rgba(205, 233, 255, 0) 68%);
|
|
}
|
|
|
|
.world-luck .world-light {
|
|
background: radial-gradient(circle, rgba(255, 203, 229, 0.72) 0%, rgba(255, 203, 229, 0) 68%);
|
|
}
|
|
|
|
.world-fish .world-light {
|
|
background: radial-gradient(circle, rgba(198, 255, 144, 0.62) 0%, rgba(198, 255, 144, 0) 68%);
|
|
}
|
|
|
|
.world-dot {
|
|
width: 10rpx;
|
|
height: 10rpx;
|
|
position: absolute;
|
|
border-radius: 50%;
|
|
background: rgba(255, 255, 255, 0.96);
|
|
box-shadow: 0 0 16rpx rgba(166, 255, 234, 0.9);
|
|
z-index: 2;
|
|
animation: none;
|
|
}
|
|
|
|
.world-dot-a {
|
|
left: 18rpx;
|
|
top: 34rpx;
|
|
}
|
|
|
|
.world-dot-b {
|
|
right: 18rpx;
|
|
top: 48rpx;
|
|
animation-delay: 0.8s;
|
|
}
|
|
|
|
.world-dot-c {
|
|
left: 24rpx;
|
|
bottom: 50rpx;
|
|
animation-delay: 1.4s;
|
|
}
|
|
|
|
.like-box,
|
|
.daimai-box {
|
|
width: 95%;
|
|
margin: 12rpx auto;
|
|
}
|
|
|
|
.daimai-tab {
|
|
display: flex;
|
|
align-items: center;
|
|
height: 88rpx;
|
|
padding: 8rpx;
|
|
margin: 0 8rpx;
|
|
box-sizing: border-box;
|
|
position: sticky;
|
|
top: 0;
|
|
z-index: 96;
|
|
border-radius: 34rpx;
|
|
background: rgba(255, 255, 255, 0.62);
|
|
border-bottom-left-radius: 0;
|
|
border-bottom-right-radius: 0;
|
|
}
|
|
|
|
.daimai-tab--sticky {
|
|
background: rgba(255, 255, 255, 1);
|
|
box-shadow: 0 16rpx 36rpx rgba(130, 84, 43, 0.08);
|
|
}
|
|
|
|
.daimai-tab-item {
|
|
flex: 1;
|
|
min-width: 0;
|
|
height: 68rpx;
|
|
margin-right: 10rpx;
|
|
border-radius: 26rpx;
|
|
border: 1px solid rgba(255, 184, 116, 0.16);
|
|
background: rgba(255, 252, 244, 0.82);
|
|
box-shadow: 0 8rpx 22rpx rgba(130, 84, 43, 0.04);
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
position: relative;
|
|
overflow: hidden;
|
|
color: #7d756c;
|
|
transition: transform 0.22s cubic-bezier(0.2, 0.9, 0.3, 1.35), box-shadow 0.22s ease, background 0.22s ease, color 0.22s ease;
|
|
}
|
|
|
|
.daimai-tab-item:last-child {
|
|
margin-right: 0;
|
|
}
|
|
|
|
.daimai-tab-item:active {
|
|
transform: scale(0.94);
|
|
box-shadow: 0 4rpx 12rpx rgba(255, 150, 93, 0.14);
|
|
}
|
|
|
|
.daimai-tab-item.active {
|
|
border-color: rgba(255, 188, 119, 0.72);
|
|
background: linear-gradient(135deg, #fff7d7 0%, #ffd8a8 45%, #ffb8a3 100%);
|
|
box-shadow: 0 14rpx 30rpx rgba(255, 158, 100, 0.28);
|
|
color: #63351d;
|
|
transform: translateY(-4rpx);
|
|
animation: daimaiTabPop 0.34s cubic-bezier(0.2, 0.9, 0.3, 1.35);
|
|
}
|
|
|
|
.daimai-tab-item.active:active {
|
|
transform: translateY(-2rpx) scale(0.96);
|
|
}
|
|
|
|
.daimai-tab-glow {
|
|
width: 88rpx;
|
|
height: 88rpx;
|
|
border-radius: 50%;
|
|
background: rgba(255, 255, 255, 0.42);
|
|
position: absolute;
|
|
top: -38rpx;
|
|
right: -26rpx;
|
|
opacity: 0;
|
|
transform: scale(0.6);
|
|
transition: opacity 0.22s ease, transform 0.26s ease;
|
|
}
|
|
|
|
.daimai-tab-item.active .daimai-tab-glow {
|
|
opacity: 1;
|
|
transform: scale(1.08);
|
|
}
|
|
|
|
.daimai-tab-icon {
|
|
width: 40rpx;
|
|
height: 40rpx;
|
|
margin-right: 8rpx;
|
|
border-radius: 14rpx;
|
|
background: rgba(255, 221, 176, 0.56);
|
|
color: #724126;
|
|
font-size: 22rpx;
|
|
font-weight: 900;
|
|
line-height: 40rpx;
|
|
text-align: center;
|
|
z-index: 1;
|
|
}
|
|
|
|
.daimai-tab-item.active .daimai-tab-icon {
|
|
background: rgba(255, 255, 255, 0.5);
|
|
color: #63351d;
|
|
box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.36);
|
|
}
|
|
|
|
.daimai-tab-info {
|
|
min-width: 0;
|
|
display: flex;
|
|
align-items: center;
|
|
z-index: 1;
|
|
}
|
|
|
|
.daimai-tab-label {
|
|
font-size: 24rpx;
|
|
font-weight: 900;
|
|
white-space: nowrap;
|
|
letter-spacing: 1rpx;
|
|
}
|
|
|
|
.daimai-tab-count {
|
|
min-width: 30rpx;
|
|
height: 30rpx;
|
|
margin-left: 6rpx;
|
|
padding: 0 8rpx;
|
|
border-radius: 999rpx;
|
|
background: rgba(255, 221, 176, 0.66);
|
|
color: #724126;
|
|
font-size: 20rpx;
|
|
font-weight: 900;
|
|
line-height: 30rpx;
|
|
text-align: center;
|
|
box-sizing: border-box;
|
|
}
|
|
|
|
.daimai-tab-item.active .daimai-tab-count {
|
|
background: rgba(255, 255, 255, 0.88);
|
|
color: #ff734d;
|
|
box-shadow: 0 4rpx 12rpx rgba(255, 115, 77, 0.18);
|
|
}
|
|
|
|
@keyframes daimaiTabPop {
|
|
0% {
|
|
transform: translateY(0) scale(0.94);
|
|
}
|
|
|
|
65% {
|
|
transform: translateY(-6rpx) scale(1.04);
|
|
}
|
|
|
|
100% {
|
|
transform: translateY(-4rpx) scale(1);
|
|
}
|
|
}
|
|
|
|
.like-head {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
}
|
|
|
|
.like-title {
|
|
width: 218rpx;
|
|
height: 64rpx;
|
|
filter: drop-shadow(0 8rpx 10rpx rgba(0, 35, 28, 0.06));
|
|
}
|
|
|
|
.like-title img {
|
|
width: 100%;
|
|
height: 100%;
|
|
background-size: 100%;
|
|
}
|
|
|
|
.seckill-entry {
|
|
width: 280rpx;
|
|
height: 76rpx;
|
|
padding: 0 12rpx;
|
|
box-sizing: border-box;
|
|
border-radius: 999rpx;
|
|
border: 1px solid rgba(255, 255, 255, 0.52);
|
|
background:
|
|
radial-gradient(circle at 18% 4%, rgba(255, 255, 255, 0.55) 0, rgba(255, 255, 255, 0) 76rpx),
|
|
linear-gradient(135deg, #ff4b27 0%, #ff8b18 48%, #ffd257 100%);
|
|
box-shadow: 0 16rpx 30rpx rgba(255, 91, 39, 0.24), 0 0 40rpx rgba(255, 188, 80, 0.26);
|
|
display: flex;
|
|
align-items: center;
|
|
position: relative;
|
|
overflow: hidden;
|
|
animation: none;
|
|
}
|
|
|
|
.seckill-entry:active {
|
|
transform: scale(0.96);
|
|
}
|
|
|
|
.seckill-entry-light {
|
|
width: 190rpx;
|
|
height: 120rpx;
|
|
background: linear-gradient(105deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.76) 46%, rgba(255, 255, 255, 0) 100%);
|
|
position: absolute;
|
|
top: -20rpx;
|
|
left: -220rpx;
|
|
transform: rotate(12deg);
|
|
animation: seckillEntrySweep 4.8s ease-in-out infinite;
|
|
}
|
|
|
|
.seckill-entry-icon {
|
|
width: 54rpx;
|
|
height: 54rpx;
|
|
margin-right: 10rpx;
|
|
border-radius: 50%;
|
|
background: rgba(255, 255, 255, 0.92);
|
|
color: #ff4f24;
|
|
font-size: 26rpx;
|
|
font-weight: 900;
|
|
line-height: 54rpx;
|
|
text-align: center;
|
|
box-shadow: inset 0 -4rpx 0 rgba(255, 197, 69, 0.38);
|
|
position: relative;
|
|
z-index: 1;
|
|
animation: none;
|
|
}
|
|
|
|
.seckill-entry-info {
|
|
flex: 1;
|
|
min-width: 0;
|
|
position: relative;
|
|
z-index: 1;
|
|
color: #fff;
|
|
}
|
|
|
|
.seckill-entry-title {
|
|
font-size: 28rpx;
|
|
font-weight: 900;
|
|
line-height: 34rpx;
|
|
letter-spacing: 1rpx;
|
|
text-shadow: 0 3rpx 8rpx rgba(183, 35, 0, 0.24);
|
|
}
|
|
|
|
.seckill-entry-sub {
|
|
margin-top: 2rpx;
|
|
font-size: 18rpx;
|
|
font-weight: 700;
|
|
opacity: 0.92;
|
|
white-space: nowrap;
|
|
animation: none;
|
|
}
|
|
|
|
.seckill-entry-btn {
|
|
width: 54rpx;
|
|
height: 54rpx;
|
|
border-radius: 50%;
|
|
background: #fff;
|
|
color: #ff3d18;
|
|
font-size: 26rpx;
|
|
font-weight: 900;
|
|
line-height: 54rpx;
|
|
text-align: center;
|
|
position: relative;
|
|
z-index: 1;
|
|
box-shadow: 0 8rpx 18rpx rgba(158, 32, 0, 0.22);
|
|
animation: seckillBtnBeat 2.8s ease-in-out infinite;
|
|
}
|
|
|
|
.heat-dot {
|
|
width: 12rpx;
|
|
height: 12rpx;
|
|
position: absolute;
|
|
border-radius: 50%;
|
|
background: rgba(255, 255, 255, 0.92);
|
|
box-shadow: 0 0 16rpx rgba(255, 255, 255, 0.88);
|
|
z-index: 1;
|
|
animation: heatParticle 3.2s ease-in-out infinite;
|
|
}
|
|
|
|
.heat-dot-a {
|
|
left: 34rpx;
|
|
top: 18rpx;
|
|
}
|
|
|
|
.heat-dot-b {
|
|
right: 74rpx;
|
|
bottom: 16rpx;
|
|
animation-delay: 0.5s;
|
|
}
|
|
|
|
.like-content-box {
|
|
height: 400rpx;
|
|
background:
|
|
radial-gradient(circle at 8% 12%, rgba(255, 255, 255, 0.92) 0, rgba(255, 255, 255, 0) 118rpx),
|
|
radial-gradient(circle at 86% 88%, rgba(116, 255, 216, 0.36) 0, rgba(116, 255, 216, 0) 150rpx),
|
|
linear-gradient(135deg, rgba(229, 255, 247, 0.96) 0%, rgba(255, 250, 226, 0.9) 46%, rgba(221, 255, 246, 0.96) 100%),
|
|
url("https://jewel-shop.oss-cn-beijing.aliyuncs.com/6d65d349d68f40e7886c978190b6ea33.png") no-repeat;
|
|
background-size: 100%, 100%, 100%, 100%;
|
|
margin-top: 10rpx;
|
|
display: flex;
|
|
border-radius: 34rpx;
|
|
overflow: hidden;
|
|
border: 1px solid rgba(255, 255, 255, 0.82);
|
|
box-shadow: 0 22rpx 52rpx rgba(50, 137, 95, 0.14), inset 0 1rpx 0 rgba(255, 255, 255, 0.88);
|
|
position: relative;
|
|
}
|
|
|
|
.like-content-box::before {
|
|
content: '';
|
|
width: 560rpx;
|
|
height: 260rpx;
|
|
background:
|
|
linear-gradient(90deg, rgba(255, 255, 255, 0.34) 1px, transparent 1px),
|
|
linear-gradient(0deg, rgba(255, 255, 255, 0.28) 1px, transparent 1px);
|
|
background-size: 42rpx 42rpx;
|
|
position: absolute;
|
|
left: 84rpx;
|
|
bottom: -130rpx;
|
|
transform: perspective(360rpx) rotateX(62deg);
|
|
animation: none;
|
|
z-index: 1;
|
|
opacity: 0.62;
|
|
}
|
|
|
|
.like-content-box::after {
|
|
content: '';
|
|
position: absolute;
|
|
left: 34rpx;
|
|
right: 34rpx;
|
|
bottom: 18rpx;
|
|
height: 18rpx;
|
|
border-radius: 50%;
|
|
background: rgba(19, 128, 102, 0.08);
|
|
box-shadow: 0 0 22rpx rgba(19, 128, 102, 0.08);
|
|
z-index: 1;
|
|
}
|
|
|
|
.like-left {
|
|
width: 45%;
|
|
background:
|
|
radial-gradient(circle at 86% 4%, rgba(166, 255, 234, 0.36) 0, rgba(166, 255, 234, 0) 92rpx),
|
|
linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(249, 255, 251, 0.78) 100%);
|
|
border: 1px solid rgba(255, 255, 255, 0.88);
|
|
border-radius: 30rpx;
|
|
height: 330rpx;
|
|
margin: 58rpx 0 0 3.3%;
|
|
box-shadow: 0 18rpx 34rpx rgba(0, 35, 28, 0.08), inset 0 1rpx 0 rgba(255, 255, 255, 0.92);
|
|
overflow: hidden;
|
|
position: relative;
|
|
z-index: 2;
|
|
animation: none;
|
|
}
|
|
|
|
.like-world-right {
|
|
background:
|
|
radial-gradient(circle at 8% 4%, rgba(255, 225, 154, 0.34) 0, rgba(255, 225, 154, 0) 98rpx),
|
|
linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(248, 255, 250, 0.78) 100%);
|
|
}
|
|
|
|
.like-left::before {
|
|
content: '';
|
|
position: absolute;
|
|
left: 18rpx;
|
|
right: 18rpx;
|
|
top: 50rpx;
|
|
height: 1px;
|
|
background: linear-gradient(90deg, transparent, rgba(27, 191, 156, 0.4), transparent);
|
|
z-index: 2;
|
|
}
|
|
|
|
.like-left::after {
|
|
content: '';
|
|
position: absolute;
|
|
right: -38rpx;
|
|
top: -38rpx;
|
|
width: 118rpx;
|
|
height: 118rpx;
|
|
border-radius: 50%;
|
|
border: 20rpx solid rgba(166, 255, 234, 0.2);
|
|
z-index: 1;
|
|
}
|
|
|
|
.like-content-title {
|
|
width: 100%;
|
|
height: 54rpx;
|
|
position: relative;
|
|
line-height: 54rpx;
|
|
padding: 0 14rpx;
|
|
color: #173f36;
|
|
font-size: 23rpx;
|
|
letter-spacing: 1rpx;
|
|
text-shadow: 0 1rpx 0 rgba(255, 255, 255, 0.86);
|
|
box-sizing: border-box;
|
|
z-index: 3;
|
|
}
|
|
|
|
.like-hot-gif {
|
|
width: 34rpx;
|
|
height: 34rpx;
|
|
position: absolute;
|
|
top: 10rpx;
|
|
right: 42rpx;
|
|
animation: none;
|
|
}
|
|
|
|
.like-content {
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
.content-list {
|
|
display: flex;
|
|
height: 128rpx;
|
|
margin: 0 10rpx 10rpx;
|
|
border-radius: 26rpx;
|
|
background:
|
|
linear-gradient(135deg, rgba(255, 255, 255, 0.96) 0%, rgba(245, 255, 251, 0.84) 100%);
|
|
border: 1px solid rgba(255, 255, 255, 0.9);
|
|
box-shadow: 0 12rpx 24rpx rgba(0, 35, 28, 0.07);
|
|
overflow: hidden;
|
|
position: relative;
|
|
transition: transform 0.18s cubic-bezier(0.2, 0.9, 0.3, 1.24), box-shadow 0.18s ease;
|
|
}
|
|
|
|
.content-list::before {
|
|
content: '';
|
|
position: absolute;
|
|
left: 84rpx;
|
|
right: 18rpx;
|
|
bottom: 12rpx;
|
|
height: 8rpx;
|
|
border-radius: 999rpx;
|
|
background: linear-gradient(90deg, rgba(27, 191, 156, 0.42) 0%, rgba(255, 220, 120, 0.64) 58%, rgba(255, 255, 255, 0.24) 100%);
|
|
z-index: 1;
|
|
}
|
|
|
|
.content-list:active {
|
|
box-shadow: 0 16rpx 30rpx rgba(0, 35, 28, 0.1);
|
|
transform: scale(0.98) translateY(-4rpx);
|
|
}
|
|
|
|
.list-img {
|
|
width: 122rpx;
|
|
height: 128rpx;
|
|
padding: 10rpx 0 10rpx 10rpx;
|
|
position: relative;
|
|
box-sizing: border-box;
|
|
z-index: 2;
|
|
}
|
|
|
|
.list-img img {
|
|
width: 100%;
|
|
height: 100%;
|
|
border-radius: 24rpx;
|
|
box-shadow: 0 12rpx 20rpx rgba(0, 35, 28, 0.12);
|
|
object-fit: cover;
|
|
}
|
|
|
|
.list-product {
|
|
flex: 1;
|
|
min-width: 0;
|
|
padding: 12rpx 10rpx 0 12rpx;
|
|
box-sizing: border-box;
|
|
position: relative;
|
|
z-index: 3;
|
|
}
|
|
|
|
.list-name {
|
|
height: 30rpx;
|
|
line-height: 30rpx;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.list-type {
|
|
display: inline-block;
|
|
font-size: 17rpx;
|
|
padding: 4rpx 8rpx;
|
|
background: linear-gradient(135deg, rgba(166, 255, 234, 0.98) 0%, rgba(255, 251, 205, 0.98) 100%);
|
|
border: 1px solid rgba(255, 255, 255, 0.72);
|
|
border-radius: 999rpx;
|
|
position: absolute;
|
|
top: 14rpx;
|
|
left: 12rpx;
|
|
font-weight: 900;
|
|
color: #125e50;
|
|
box-shadow: 0 6rpx 14rpx rgba(0, 35, 28, 0.1);
|
|
transform: rotate(-5deg);
|
|
animation: none;
|
|
}
|
|
|
|
.list-text {
|
|
display: block;
|
|
font-size: 21rpx;
|
|
font-weight: 900;
|
|
color: #173f36;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.list-price {
|
|
color: #ff4b35 !important;
|
|
height: 34rpx;
|
|
margin-top: 5rpx;
|
|
font-size: 27rpx;
|
|
font-weight: 900;
|
|
line-height: 34rpx;
|
|
text-decoration: none;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
text-shadow: 0 4rpx 10rpx rgba(255, 75, 53, 0.14);
|
|
}
|
|
|
|
.list-total {
|
|
font-size: 20rpx;
|
|
font-weight: 800;
|
|
color: #5f4a24;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
margin-top: 4rpx;
|
|
min-width: 0;
|
|
}
|
|
|
|
.list-total text {
|
|
flex: 1;
|
|
min-width: 0;
|
|
font-size: 17rpx;
|
|
font-weight: 800;
|
|
color: rgba(18, 73, 63, 0.58) !important;
|
|
animation: none;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.group-cta {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
flex: 0 0 56rpx;
|
|
width: 56rpx;
|
|
height: 32rpx;
|
|
line-height: 1;
|
|
margin-left: 6rpx;
|
|
padding: 0;
|
|
box-sizing: border-box;
|
|
border-radius: 999rpx;
|
|
border: 1px solid rgba(255, 255, 255, 0.72);
|
|
background: linear-gradient(135deg, #12c99e 0%, #8fffe0 100%);
|
|
color: #0d5d4e;
|
|
font-size: 18rpx;
|
|
font-weight: 900;
|
|
text-align: center;
|
|
white-space: nowrap;
|
|
box-shadow: 0 7rpx 14rpx rgba(27, 191, 156, 0.2);
|
|
animation: none;
|
|
}
|
|
|
|
.brand-memory-strip {
|
|
position: absolute;
|
|
left: 18rpx;
|
|
right: 18rpx;
|
|
top: 9rpx;
|
|
height: 32rpx;
|
|
display: flex;
|
|
align-items: center;
|
|
overflow: hidden;
|
|
z-index: 3;
|
|
pointer-events: none;
|
|
}
|
|
|
|
.brand-memory-strip text {
|
|
flex-shrink: 0;
|
|
height: 32rpx;
|
|
margin-right: 10rpx;
|
|
padding: 0 12rpx;
|
|
border-radius: 999rpx;
|
|
background: rgba(255, 255, 255, 0.78);
|
|
color: #0f695b;
|
|
font-size: 18rpx;
|
|
font-weight: 900;
|
|
line-height: 32rpx;
|
|
box-shadow: 0 6rpx 14rpx rgba(0, 35, 28, 0.06);
|
|
animation: none;
|
|
}
|
|
|
|
.group-scene-mark {
|
|
position: absolute;
|
|
right: 24rpx;
|
|
top: 48rpx;
|
|
height: 34rpx;
|
|
padding: 0 14rpx;
|
|
border-radius: 999rpx;
|
|
background: rgba(10, 66, 54, 0.82);
|
|
color: rgba(255, 255, 255, 0.94);
|
|
font-size: 18rpx;
|
|
font-weight: 900;
|
|
line-height: 34rpx;
|
|
z-index: 4;
|
|
box-shadow: 0 10rpx 22rpx rgba(0, 35, 28, 0.14);
|
|
}
|
|
|
|
.group-orbit {
|
|
position: absolute;
|
|
border-radius: 50%;
|
|
border: 1px solid rgba(255, 255, 255, 0.58);
|
|
z-index: 1;
|
|
}
|
|
|
|
.group-orbit-a {
|
|
width: 220rpx;
|
|
height: 220rpx;
|
|
left: -74rpx;
|
|
top: 88rpx;
|
|
}
|
|
|
|
.group-orbit-b {
|
|
width: 280rpx;
|
|
height: 280rpx;
|
|
right: -120rpx;
|
|
top: 38rpx;
|
|
border-color: rgba(166, 255, 234, 0.48);
|
|
}
|
|
|
|
.brand-memory-strip text:nth-child(2) {
|
|
animation-delay: 0.4s;
|
|
}
|
|
|
|
.brand-memory-strip text:nth-child(3) {
|
|
animation-delay: 0.8s;
|
|
}
|
|
|
|
.brand-memory-strip text:nth-child(4) {
|
|
animation-delay: 1.2s;
|
|
}
|
|
|
|
@keyframes groupLightSweep {
|
|
0% {
|
|
left: -380rpx;
|
|
opacity: 0;
|
|
}
|
|
|
|
24% {
|
|
opacity: 1;
|
|
}
|
|
|
|
64% {
|
|
left: 760rpx;
|
|
opacity: 0;
|
|
}
|
|
|
|
100% {
|
|
left: 760rpx;
|
|
opacity: 0;
|
|
}
|
|
}
|
|
|
|
@keyframes seckillEntryFloat {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0);
|
|
}
|
|
|
|
50% {
|
|
transform: translateY(-4rpx);
|
|
}
|
|
}
|
|
|
|
@keyframes seckillEntrySweep {
|
|
0% {
|
|
left: -220rpx;
|
|
opacity: 0;
|
|
}
|
|
|
|
34% {
|
|
opacity: 0.9;
|
|
}
|
|
|
|
72%,
|
|
100% {
|
|
left: 470rpx;
|
|
opacity: 0;
|
|
}
|
|
}
|
|
|
|
@keyframes seckillIconPulse {
|
|
0%,
|
|
100% {
|
|
transform: scale(1);
|
|
}
|
|
|
|
50% {
|
|
transform: scale(1.08);
|
|
}
|
|
}
|
|
|
|
@keyframes seckillBtnBeat {
|
|
0%,
|
|
100% {
|
|
transform: scale(1);
|
|
}
|
|
|
|
50% {
|
|
transform: scale(1.08);
|
|
}
|
|
}
|
|
|
|
@keyframes groupCardFloat {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0);
|
|
}
|
|
|
|
50% {
|
|
transform: translateY(-5rpx);
|
|
}
|
|
}
|
|
|
|
@keyframes hotBadgePulse {
|
|
0%,
|
|
100% {
|
|
transform: scale(1);
|
|
}
|
|
|
|
50% {
|
|
transform: scale(1.1) rotate(-3deg);
|
|
}
|
|
}
|
|
|
|
@keyframes groupMemberPulse {
|
|
0%,
|
|
100% {
|
|
transform: rotate(-4deg) scale(1);
|
|
}
|
|
|
|
50% {
|
|
transform: rotate(-4deg) scale(1.06);
|
|
}
|
|
}
|
|
|
|
@keyframes groupPricePop {
|
|
0%,
|
|
100% {
|
|
transform: scale(1);
|
|
}
|
|
|
|
50% {
|
|
transform: scale(1.06);
|
|
}
|
|
}
|
|
|
|
@keyframes groupCtaNudge {
|
|
0%,
|
|
100% {
|
|
transform: translateX(0);
|
|
}
|
|
|
|
50% {
|
|
transform: translateX(3rpx);
|
|
}
|
|
}
|
|
|
|
.list-1 {
|
|
width: 98%;
|
|
background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(253, 255, 250, 0.96) 100%);
|
|
border: 1px solid rgba(255, 255, 255, 0.86);
|
|
border-radius: 34rpx;
|
|
margin: 22rpx auto 0;
|
|
overflow: hidden;
|
|
contain: content;
|
|
will-change: transform;
|
|
transform: translateZ(0);
|
|
backface-visibility: hidden;
|
|
}
|
|
|
|
.daoda-time {
|
|
width: 242rpx;
|
|
height: 48rpx;
|
|
font-size: 24rpx;
|
|
padding-left: 14rpx;
|
|
font-weight: 700;
|
|
border-radius: 14rpx;
|
|
line-height: 48rpx;
|
|
text-align: left;
|
|
background: rgba(166, 255, 234, 0.42);
|
|
color: #125e50;
|
|
margin: 20rpx 0 20rpx 20rpx;
|
|
}
|
|
|
|
.shangjia {
|
|
width: 100%;
|
|
height: 70rpx;
|
|
margin: 0 auto;
|
|
line-height: 70rpx;
|
|
padding-left: 28rpx;
|
|
display: flex;
|
|
}
|
|
|
|
.maotou {
|
|
width: 90rpx;
|
|
background: url('https://jewel-shop.oss-cn-beijing.aliyuncs.com/bdb867ba5a8a4e13b7e61a87f61148a1.png') no-repeat;
|
|
height: 90rpx;
|
|
background-size: 100%;
|
|
position: absolute;
|
|
top: -60rpx;
|
|
right: 10rpx;
|
|
text-align: center;
|
|
line-height: 90rpx;
|
|
font-weight: 900;
|
|
font-size: 24rpx;
|
|
}
|
|
.maotou1 {
|
|
width: 130rpx;
|
|
background: url('https://jewel-shop.oss-cn-beijing.aliyuncs.com/6f9117df70b048e2b35badb5d3338706.png') no-repeat;
|
|
height: 74rpx;
|
|
background-size: 100%;
|
|
position: absolute;
|
|
top: -60rpx;
|
|
right: 10rpx;
|
|
text-align: center;
|
|
line-height: 90rpx;
|
|
font-weight: 900;
|
|
font-size: 24rpx;
|
|
}
|
|
.maotou2 {
|
|
width: 90rpx;
|
|
background: url('https://jewel-shop.oss-cn-beijing.aliyuncs.com/8204237989b34bc88e47acd39b98aadf.png') no-repeat;
|
|
height: 90rpx;
|
|
background-size: 100%;
|
|
position: absolute;
|
|
top: -60rpx;
|
|
right: 10rpx;
|
|
text-align: center;
|
|
line-height: 90rpx;
|
|
font-weight: 900;
|
|
font-size: 24rpx;
|
|
}
|
|
.maotou3 {
|
|
width: 90rpx;
|
|
background: url('https://jewel-shop.oss-cn-beijing.aliyuncs.com/a1584a13e9db4b6fbcc66890219d0018.png') no-repeat;
|
|
height: 90rpx;
|
|
background-size: 100%;
|
|
position: absolute;
|
|
top: -60rpx;
|
|
right: 10rpx;
|
|
text-align: center;
|
|
line-height: 90rpx;
|
|
font-weight: 900;
|
|
font-size: 24rpx;
|
|
}
|
|
.order-page {
|
|
width: 95%;
|
|
position: relative;
|
|
height: auto;
|
|
border-radius: 32rpx;
|
|
border: 1px solid rgba(166, 255, 234, 0.78);
|
|
background: rgba(255, 255, 255, 0.74);
|
|
box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.7);
|
|
margin: 0 auto;
|
|
}
|
|
|
|
.shangjialogo {
|
|
width: 40rpx;
|
|
height: 40rpx;
|
|
margin: 8rpx 20rpx 0 28rpx;
|
|
|
|
img {
|
|
width: 100%;
|
|
height: 100%;
|
|
background-size: 100%;
|
|
}
|
|
}
|
|
|
|
.shangpin {
|
|
display: flex;
|
|
}
|
|
|
|
.shangpintu {
|
|
width: 120rpx;
|
|
height: 120rpx;
|
|
margin-left: 20rpx;
|
|
|
|
img {
|
|
width: 100%;
|
|
height: 100%;
|
|
background-size: 100%;
|
|
}
|
|
}
|
|
|
|
.shangpinxinxi {
|
|
padding: 0 20rpx;
|
|
flex: 1;
|
|
}
|
|
|
|
.pinming {
|
|
font-size: 24rpx;
|
|
font-weight: 700;
|
|
}
|
|
|
|
.guige {
|
|
font-size: 20rpx;
|
|
height: 56rpx;
|
|
line-height: 56rpx;
|
|
color: #777;
|
|
}
|
|
|
|
.shuliang {
|
|
font-size: 20rpx;
|
|
display: flex;
|
|
height: 40rpx;
|
|
line-height: 40rpx;
|
|
color: #777;
|
|
}
|
|
|
|
.qu-song {
|
|
width: 95%;
|
|
margin: 0 auto;
|
|
font-size: 24rpx;
|
|
}
|
|
|
|
.qu-box {
|
|
display: flex;
|
|
}
|
|
|
|
.qu-tu {
|
|
width: 50rpx;
|
|
height: 50rpx;
|
|
|
|
img {
|
|
width: 100%;
|
|
height: 100%;
|
|
background-size: 100%;
|
|
}
|
|
}
|
|
|
|
.qu-text {
|
|
display: flex;
|
|
flex: 1;
|
|
height: auto;
|
|
line-height: 50rpx;
|
|
color: #40534d;
|
|
width: 90%;
|
|
}
|
|
|
|
.qu-left {
|
|
width: 80%;
|
|
padding-left: 10rpx;
|
|
word-wrap: break-word;
|
|
word-break: break-all;
|
|
white-space: normal;
|
|
}
|
|
|
|
.qu-right {
|
|
width: 20%;
|
|
text-align: right;
|
|
padding-right: 10rpx;
|
|
font-weight: 700;
|
|
}
|
|
|
|
.yongjin {
|
|
height: 50rpx;
|
|
display: flex;
|
|
font-size: 24rpx;
|
|
line-height: 50rpx;
|
|
width: 95%;
|
|
margin: 20rpx auto;
|
|
color: #40534d;
|
|
}
|
|
|
|
.qiangdan-btn {
|
|
width: 100%;
|
|
height: 100rpx;
|
|
border-radius: 999rpx;
|
|
background: linear-gradient(135deg, rgba(246, 255, 252, 0.98) 0%, rgba(235, 255, 249, 0.96) 100%);
|
|
border: 1px solid rgba(166, 255, 234, 0.72);
|
|
box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72), 0 12rpx 26rpx rgba(0, 35, 28, 0.06);
|
|
position: relative;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.qiangdan-progress {
|
|
height: 100%;
|
|
border-radius: 999rpx;
|
|
background: linear-gradient(90deg, rgba(166, 255, 234, 0.42) 0%, rgba(108, 226, 202, 0.78) 100%);
|
|
transition: width 0.16s ease-out;
|
|
}
|
|
|
|
.qiangdan-text {
|
|
width: 100%;
|
|
height: 100%;
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
color: #2a665b;
|
|
font-size: 28rpx;
|
|
font-weight: 900;
|
|
letter-spacing: 2rpx;
|
|
}
|
|
|
|
.qiangdan-thumb {
|
|
width: 82rpx;
|
|
height: 82rpx;
|
|
border-radius: 50%;
|
|
position: absolute;
|
|
left: 0;
|
|
top: 9rpx;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
background: rgba(255, 255, 255, 0.96);
|
|
border: 1px solid rgba(166, 255, 234, 0.9);
|
|
box-shadow: 0 10rpx 22rpx rgba(0, 35, 28, 0.12);
|
|
color: #1b7a69;
|
|
font-size: 28rpx;
|
|
font-weight: 900;
|
|
transition: left 0.16s ease-out, transform 0.16s ease-out;
|
|
}
|
|
|
|
.dispatch-action-box {
|
|
width: 95%;
|
|
margin: 20rpx auto 24rpx;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
}
|
|
|
|
.dispatch-action-box--single {
|
|
margin-bottom: 20rpx;
|
|
}
|
|
|
|
.reject-order-btn {
|
|
min-width: 220rpx;
|
|
height: 58rpx;
|
|
margin-top: 14rpx;
|
|
padding: 0 34rpx;
|
|
border-radius: 999rpx;
|
|
border: 1px solid rgba(255, 108, 96, 0.5);
|
|
background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(255, 244, 241, 0.96) 100%);
|
|
box-shadow: 0 8rpx 18rpx rgba(255, 108, 96, 0.12);
|
|
box-sizing: border-box;
|
|
color: #e45c50;
|
|
font-size: 24rpx;
|
|
font-weight: 800;
|
|
line-height: 58rpx;
|
|
text-align: center;
|
|
transition: transform 0.18s ease, box-shadow 0.18s ease;
|
|
|
|
&:active {
|
|
transform: scale(0.96);
|
|
box-shadow: 0 4rpx 10rpx rgba(255, 108, 96, 0.1);
|
|
}
|
|
}
|
|
|
|
.paotui-title {
|
|
display: flex;
|
|
flex: 1;
|
|
line-height: 88rpx;
|
|
text-align: right;
|
|
padding-right: 20rpx;
|
|
}
|
|
|
|
.paotui-text {
|
|
font-size: 28rpx;
|
|
color: red;
|
|
font-weight: bold;
|
|
flex: 1;
|
|
}
|
|
|
|
.paotui-num {
|
|
font-size: 24rpx;
|
|
padding: 0 10rpx;
|
|
}
|
|
|
|
.popup-area-content {
|
|
align-items: center;
|
|
justify-content: center;
|
|
height: auto;
|
|
background-color: #fff;
|
|
padding: 10px 20px;
|
|
border-radius: 10px;
|
|
}
|
|
|
|
.popup-area-title {
|
|
font-size: 36rpx;
|
|
font-weight: bold;
|
|
text-align: center;
|
|
position: relative;
|
|
margin-top: 10px;
|
|
}
|
|
|
|
.popup-area-container {
|
|
margin-top: 20rpx;
|
|
height: 100rpx;
|
|
border-radius: 20rpx;
|
|
background: #088FEB;
|
|
line-height: 100rpx;
|
|
text-align: center;
|
|
border-bottom: 1px solid #eee;
|
|
border-top: 1px solid #eee;
|
|
color: #fff;
|
|
padding: 0 10px;
|
|
}
|
|
|
|
.campus-area-popup {
|
|
position: relative;
|
|
box-sizing: border-box;
|
|
width: 650rpx;
|
|
min-height: 620rpx;
|
|
max-height: 78vh;
|
|
overflow: hidden;
|
|
padding: 38rpx 30rpx 30rpx;
|
|
border: 1rpx solid rgba(255, 255, 255, 0.78);
|
|
border-radius: 42rpx;
|
|
background:
|
|
radial-gradient(circle at 16% 8%, rgba(227, 255, 150, 0.34), rgba(227, 255, 150, 0) 220rpx),
|
|
radial-gradient(circle at 92% 18%, rgba(166, 255, 234, 0.44), rgba(166, 255, 234, 0) 260rpx),
|
|
rgba(255, 255, 255, 0.92);
|
|
box-shadow: 0 30rpx 86rpx rgba(7, 61, 51, 0.18);
|
|
backdrop-filter: blur(24rpx);
|
|
}
|
|
|
|
.area-popup-glow {
|
|
position: absolute;
|
|
border-radius: 999rpx;
|
|
pointer-events: none;
|
|
}
|
|
|
|
.area-popup-glow-a {
|
|
top: -82rpx;
|
|
right: -68rpx;
|
|
width: 230rpx;
|
|
height: 230rpx;
|
|
background: rgba(166, 255, 234, 0.46);
|
|
filter: blur(10rpx);
|
|
}
|
|
|
|
.area-popup-glow-b {
|
|
left: -56rpx;
|
|
bottom: 82rpx;
|
|
width: 180rpx;
|
|
height: 180rpx;
|
|
background: rgba(227, 255, 150, 0.34);
|
|
filter: blur(14rpx);
|
|
}
|
|
|
|
.campus-area-header {
|
|
position: relative;
|
|
z-index: 1;
|
|
text-align: center;
|
|
}
|
|
|
|
.campus-area-kicker {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
height: 44rpx;
|
|
padding: 0 22rpx;
|
|
border: 1rpx solid rgba(255, 255, 255, 0.82);
|
|
border-radius: 999rpx;
|
|
background: linear-gradient(90deg, rgba(227, 255, 150, 0.72), rgba(166, 255, 234, 0.72));
|
|
box-shadow: 0 10rpx 26rpx rgba(13, 114, 82, 0.1);
|
|
color: #073d33;
|
|
font-size: 22rpx;
|
|
font-weight: 700;
|
|
}
|
|
|
|
.campus-area-title {
|
|
margin-top: 22rpx;
|
|
color: #073d33;
|
|
font-size: 38rpx;
|
|
font-weight: 900;
|
|
line-height: 1.25;
|
|
}
|
|
|
|
.campus-area-subtitle {
|
|
width: 500rpx;
|
|
margin: 12rpx auto 0;
|
|
color: rgba(7, 61, 51, 0.52);
|
|
font-size: 23rpx;
|
|
line-height: 1.5;
|
|
}
|
|
|
|
.campus-area-search {
|
|
position: relative;
|
|
z-index: 1;
|
|
display: flex;
|
|
align-items: center;
|
|
height: 82rpx;
|
|
margin-top: 30rpx;
|
|
padding: 0 26rpx;
|
|
border: 1rpx solid rgba(7, 61, 51, 0.06);
|
|
border-radius: 999rpx;
|
|
background: rgba(255, 255, 255, 0.72);
|
|
box-shadow: inset 0 1rpx 0 rgba(255, 255, 255, 0.92), 0 14rpx 34rpx rgba(7, 61, 51, 0.08);
|
|
}
|
|
|
|
.area-search-icon {
|
|
margin-right: 14rpx;
|
|
color: rgba(7, 61, 51, 0.5);
|
|
font-size: 34rpx;
|
|
font-weight: 700;
|
|
}
|
|
|
|
.campus-area-search input {
|
|
flex: 1;
|
|
height: 82rpx;
|
|
color: #073d33;
|
|
font-size: 27rpx;
|
|
}
|
|
|
|
.area-search-placeholder {
|
|
color: rgba(7, 61, 51, 0.34);
|
|
}
|
|
|
|
.campus-area-list {
|
|
position: relative;
|
|
z-index: 1;
|
|
height: 360rpx;
|
|
max-height: 610rpx;
|
|
margin-top: 24rpx;
|
|
}
|
|
|
|
.campus-area-item {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
min-height: 92rpx;
|
|
margin-bottom: 16rpx;
|
|
padding: 0 18rpx 0 24rpx;
|
|
border: 1rpx solid rgba(255, 255, 255, 0.78);
|
|
border-radius: 28rpx;
|
|
background: rgba(255, 255, 255, 0.66);
|
|
box-shadow: 0 12rpx 30rpx rgba(7, 61, 51, 0.07);
|
|
color: #073d33;
|
|
}
|
|
|
|
.campus-area-item:active {
|
|
transform: scale(0.985);
|
|
opacity: 0.9;
|
|
}
|
|
|
|
.area-item-main {
|
|
display: flex;
|
|
align-items: center;
|
|
min-width: 0;
|
|
font-size: 28rpx;
|
|
font-weight: 800;
|
|
}
|
|
|
|
.area-item-main text {
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.area-item-dot {
|
|
flex-shrink: 0;
|
|
width: 16rpx;
|
|
height: 16rpx;
|
|
margin-right: 16rpx;
|
|
border-radius: 50%;
|
|
background: linear-gradient(135deg, #e3ff96, #a6ffea);
|
|
box-shadow: 0 0 18rpx rgba(13, 114, 82, 0.22);
|
|
}
|
|
|
|
.area-item-action {
|
|
flex-shrink: 0;
|
|
height: 50rpx;
|
|
margin-left: 18rpx;
|
|
padding: 0 22rpx;
|
|
border-radius: 999rpx;
|
|
background: linear-gradient(90deg, rgba(227, 255, 150, 0.95), rgba(166, 255, 234, 0.95));
|
|
box-shadow: 0 10rpx 24rpx rgba(13, 114, 82, 0.14), 0 0 22rpx rgba(166, 255, 234, 0.42);
|
|
color: #073d33;
|
|
font-size: 22rpx;
|
|
font-weight: 900;
|
|
line-height: 50rpx;
|
|
}
|
|
|
|
.campus-area-empty {
|
|
padding: 70rpx 0 56rpx;
|
|
text-align: center;
|
|
}
|
|
|
|
.area-empty-title {
|
|
color: #073d33;
|
|
font-size: 28rpx;
|
|
font-weight: 800;
|
|
}
|
|
|
|
.area-empty-desc {
|
|
margin-top: 12rpx;
|
|
color: rgba(7, 61, 51, 0.45);
|
|
font-size: 23rpx;
|
|
}
|
|
|
|
.chaoda {
|
|
height: 30rpx;
|
|
line-height: 30rpx;
|
|
margin: 10rpx 0 0 20rpx;
|
|
padding: 0 10rpx;
|
|
background: rgba(255, 117, 88, 1);
|
|
color: #fff;
|
|
border-radius: 10rpx;
|
|
font-size: 20rpx;
|
|
}
|
|
|
|
.beizhu {
|
|
width: 95%;
|
|
margin: 0 auto;
|
|
background: rgba(255, 117, 88, 0.08);
|
|
border: 1px solid rgba(255, 117, 88, 0.12);
|
|
border-radius: 20rpx;
|
|
height: 120rpx;
|
|
padding: 20rpx;
|
|
color: rgba(255, 57, 57, 1);
|
|
}
|
|
|
|
.title-sort {
|
|
height: 100rpx;
|
|
display: flex;
|
|
position: sticky;
|
|
top: 0;
|
|
z-index: 95;
|
|
background: rgba(255, 255, 255, 1);
|
|
padding: 20rpx 10rpx 0;
|
|
box-sizing: border-box;
|
|
box-shadow: 0 12rpx 26rpx rgba(0, 35, 28, 0.05);
|
|
margin: 0 10px;
|
|
font-size: 12px;
|
|
}
|
|
|
|
.title-sort--sticky {
|
|
animation: stickyPanelIn 0.24s ease;
|
|
}
|
|
|
|
.sort-text {
|
|
height: auto;
|
|
display: flex;
|
|
position: sticky;
|
|
top: 0;
|
|
z-index: 94;
|
|
background: rgba(255, 255, 255, 0.96);
|
|
padding: 20rpx 10rpx 10rpx;
|
|
box-sizing: border-box;
|
|
box-shadow: 0 12rpx 22rpx rgba(0, 35, 28, 0.04);
|
|
animation: filterChipIn 0.22s ease;
|
|
border-bottom-left-radius: 26rpx;
|
|
border-bottom-right-radius: 26rpx;
|
|
margin: 0 10px;
|
|
}
|
|
|
|
.sort-text-inner {
|
|
display: flex;
|
|
align-items: center;
|
|
flex-wrap: wrap;
|
|
width: 100%;
|
|
}
|
|
|
|
.sort-member {
|
|
height: 60rpx;
|
|
line-height: 60rpx;
|
|
text-align: center;
|
|
background: rgba(248, 255, 250, 0.86);
|
|
width: 24%;
|
|
margin-right: 4%;
|
|
border: 1px solid rgba(166, 255, 234, 0.46);
|
|
border-radius: 24rpx;
|
|
color: #40534d;
|
|
font-weight: 700;
|
|
box-shadow: 0 8rpx 18rpx rgba(0, 35, 28, 0.04);
|
|
}
|
|
|
|
.sort-value {
|
|
width: 160rpx;
|
|
height: auto;
|
|
max-height: 300rpx;
|
|
overflow: scroll;
|
|
background: rgba(0, 35, 28, 0.82);
|
|
position: absolute;
|
|
top: 76rpx;
|
|
right: 0;
|
|
border-radius: 24rpx;
|
|
color: #fff;
|
|
font-size: 22rpx;
|
|
box-shadow: 0 16rpx 34rpx rgba(0, 35, 28, 0.16);
|
|
}
|
|
|
|
.sort-value1 {
|
|
border-bottom: 1px solid #eee;
|
|
}
|
|
|
|
.guize1-qusong {
|
|
display: flex;
|
|
align-items: center;
|
|
margin: 0 18rpx 14rpx 0;
|
|
max-width: 300rpx;
|
|
animation: filterChipIn 0.22s ease;
|
|
}
|
|
|
|
.qusong1 {
|
|
width: 40rpx;
|
|
height: 40rpx;
|
|
background: linear-gradient(90deg, #e3ff96, #a6ffea);
|
|
border-radius: 40rpx;
|
|
text-align: center;
|
|
line-height: 40rpx;
|
|
font-size: 20rpx;
|
|
z-index: 80;
|
|
}
|
|
|
|
.qusong2 {
|
|
height: 40rpx;
|
|
font-size: 22rpx;
|
|
line-height: 38rpx;
|
|
text-align: center;
|
|
background: rgba(166, 255, 234, 0.62);
|
|
padding: 0 20rpx;
|
|
margin-left: -14rpx;
|
|
font-weight: 700;
|
|
border-top-right-radius: 40rpx;
|
|
border-bottom-right-radius: 40rpx;
|
|
max-width: 230rpx;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.commission-chip {
|
|
background: rgba(255, 221, 176, 0.72);
|
|
}
|
|
|
|
.clear-filter {
|
|
height: 40rpx;
|
|
padding: 0 20rpx;
|
|
margin-bottom: 14rpx;
|
|
border-radius: 999rpx;
|
|
background: rgba(0, 191, 255, 0.08);
|
|
color: #00A8D8;
|
|
font-size: 22rpx;
|
|
font-weight: 800;
|
|
line-height: 40rpx;
|
|
}
|
|
|
|
.delivery-list-wrap {
|
|
/* 改为单一 page-scroll:内容跟随页面滚动,不再是独立 scroll-view */
|
|
width: 100%;
|
|
}
|
|
|
|
.empty-delivery {
|
|
width: 98%;
|
|
min-height: 1120rpx;
|
|
margin: 24rpx auto 0;
|
|
padding: 54rpx 36rpx;
|
|
box-sizing: border-box;
|
|
border-radius: 36rpx;
|
|
border: 1px solid rgba(166, 255, 234, 0.5);
|
|
background:
|
|
radial-gradient(circle at 78% 8%, rgba(255, 216, 168, 0.28) 0, rgba(255, 216, 168, 0) 150rpx),
|
|
linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 255, 251, 0.96) 100%);
|
|
box-shadow: 0 16rpx 38rpx rgba(0, 35, 28, 0.06);
|
|
text-align: center;
|
|
animation: emptyFloatIn 0.32s ease;
|
|
}
|
|
|
|
.empty-delivery-icon {
|
|
width: 104rpx;
|
|
height: 104rpx;
|
|
margin: 0 auto 22rpx;
|
|
border-radius: 36rpx;
|
|
background: linear-gradient(135deg, #fff7d7 0%, #a6ffea 100%);
|
|
color: #125e50;
|
|
font-size: 28rpx;
|
|
font-weight: 900;
|
|
line-height: 104rpx;
|
|
box-shadow: 0 14rpx 26rpx rgba(0, 35, 28, 0.08);
|
|
}
|
|
|
|
.empty-delivery-title {
|
|
color: #243f38;
|
|
font-size: 30rpx;
|
|
font-weight: 900;
|
|
}
|
|
|
|
.empty-delivery-desc {
|
|
width: 88%;
|
|
margin: 14rpx auto 0;
|
|
color: #74817d;
|
|
font-size: 24rpx;
|
|
line-height: 38rpx;
|
|
}
|
|
|
|
.product-popup-content {
|
|
width: 680rpx;
|
|
max-height: 880rpx;
|
|
padding: 34rpx 28rpx 30rpx;
|
|
box-sizing: border-box;
|
|
overflow: scroll;
|
|
border-radius: 36rpx;
|
|
background:
|
|
radial-gradient(circle at 92% 4%, rgba(166, 255, 234, 0.38) 0, rgba(166, 255, 234, 0) 180rpx),
|
|
linear-gradient(180deg, #ffffff 0%, #f8fffc 100%);
|
|
box-shadow: 0 24rpx 56rpx rgba(0, 35, 28, 0.18);
|
|
}
|
|
|
|
.product-popup-header {
|
|
margin-bottom: 26rpx;
|
|
text-align: center;
|
|
}
|
|
|
|
.product-popup-title {
|
|
color: #143d35;
|
|
font-size: 36rpx;
|
|
font-weight: 900;
|
|
line-height: 48rpx;
|
|
}
|
|
|
|
.product-popup-subtitle {
|
|
margin-top: 8rpx;
|
|
color: #7b8a85;
|
|
font-size: 24rpx;
|
|
line-height: 34rpx;
|
|
}
|
|
|
|
.product-popup-list {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 20rpx;
|
|
}
|
|
|
|
.product-popup-card {
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 22rpx;
|
|
border: 1px solid rgba(166, 255, 234, 0.58);
|
|
border-radius: 28rpx;
|
|
background: rgba(255, 255, 255, 0.88);
|
|
box-shadow: 0 12rpx 28rpx rgba(0, 35, 28, 0.06);
|
|
}
|
|
|
|
.product-popup-img {
|
|
width: 128rpx;
|
|
height: 128rpx;
|
|
flex-shrink: 0;
|
|
overflow: hidden;
|
|
border-radius: 22rpx;
|
|
background: #f0f5f3;
|
|
|
|
img {
|
|
width: 100%;
|
|
height: 100%;
|
|
background-size: 100%;
|
|
}
|
|
}
|
|
|
|
.product-popup-info {
|
|
flex: 1;
|
|
min-width: 0;
|
|
padding: 0 22rpx;
|
|
}
|
|
|
|
.product-popup-name {
|
|
color: #172f2a;
|
|
font-size: 30rpx;
|
|
font-weight: 900;
|
|
line-height: 42rpx;
|
|
}
|
|
|
|
.product-popup-spec {
|
|
display: flex;
|
|
align-items: flex-start;
|
|
margin-top: 16rpx;
|
|
}
|
|
|
|
.product-popup-label {
|
|
flex-shrink: 0;
|
|
height: 34rpx;
|
|
padding: 0 14rpx;
|
|
border-radius: 999rpx;
|
|
background: rgba(166, 255, 234, 0.72);
|
|
color: #126255;
|
|
font-size: 20rpx;
|
|
font-weight: 800;
|
|
line-height: 34rpx;
|
|
}
|
|
|
|
.product-popup-spec-text {
|
|
flex: 1;
|
|
margin-left: 12rpx;
|
|
color: #65736f;
|
|
font-size: 24rpx;
|
|
line-height: 34rpx;
|
|
word-break: break-all;
|
|
}
|
|
|
|
.product-popup-quantity {
|
|
width: 92rpx;
|
|
height: 92rpx;
|
|
flex-shrink: 0;
|
|
border-radius: 28rpx;
|
|
background: linear-gradient(135deg, #fff4ce 0%, #a6ffea 100%);
|
|
color: #103f36;
|
|
text-align: center;
|
|
box-shadow: 0 10rpx 20rpx rgba(0, 35, 28, 0.08);
|
|
}
|
|
|
|
.product-popup-quantity-num {
|
|
padding-top: 16rpx;
|
|
font-size: 30rpx;
|
|
font-weight: 900;
|
|
line-height: 34rpx;
|
|
}
|
|
|
|
.product-popup-quantity-label {
|
|
margin-top: 2rpx;
|
|
color: #52736b;
|
|
font-size: 20rpx;
|
|
line-height: 28rpx;
|
|
}
|
|
|
|
.product-popup-empty {
|
|
padding: 80rpx 20rpx;
|
|
border-radius: 28rpx;
|
|
background: rgba(247, 255, 251, 0.9);
|
|
color: #7b8a85;
|
|
font-size: 28rpx;
|
|
font-weight: 700;
|
|
text-align: center;
|
|
}
|
|
|
|
@keyframes stickyPanelIn {
|
|
0% {
|
|
opacity: 0.88;
|
|
transform: translateY(-8rpx);
|
|
}
|
|
|
|
100% {
|
|
opacity: 1;
|
|
transform: translateY(0);
|
|
}
|
|
}
|
|
|
|
@keyframes filterChipIn {
|
|
0% {
|
|
opacity: 0;
|
|
transform: translateY(-8rpx) scale(0.98);
|
|
}
|
|
|
|
100% {
|
|
opacity: 1;
|
|
transform: translateY(0) scale(1);
|
|
}
|
|
}
|
|
|
|
@keyframes emptyFloatIn {
|
|
0% {
|
|
opacity: 0;
|
|
transform: translateY(18rpx);
|
|
}
|
|
|
|
100% {
|
|
opacity: 1;
|
|
transform: translateY(0);
|
|
}
|
|
}
|
|
.box1 {
|
|
width: 95%;
|
|
margin: 0 auto 20rpx;
|
|
background: #fff;
|
|
border-radius: 20rpx;
|
|
padding: 20rpx;
|
|
}
|
|
.goods-img {
|
|
width: 160rpx;
|
|
height: 160rpx;
|
|
position: relative;
|
|
|
|
img {
|
|
width: 100%;
|
|
background-size: 100%;
|
|
height: 100%;
|
|
}
|
|
}
|
|
|
|
.goods-content {
|
|
flex: 1;
|
|
padding-left: 20rpx;
|
|
}
|
|
|
|
.goods-name {
|
|
font-size: 32rpx;
|
|
font-weight: 900;
|
|
}
|
|
|
|
.goods-content-center {
|
|
display: flex;
|
|
margin: 16rpx 0;
|
|
color: #777;
|
|
}
|
|
|
|
.goods-content-bottom {
|
|
display: flex;
|
|
line-height: 56rpx;
|
|
color: #777;
|
|
}
|
|
|
|
.pintuan-left-price {
|
|
width: 50%;
|
|
text-align: right;
|
|
font-weight: 700;
|
|
color: #000;
|
|
}
|
|
.tishi-popup{
|
|
background:url('https://jewel-shop.oss-cn-beijing.aliyuncs.com/629843c61a014d69bf3a1195f51a898b.png') no-repeat;
|
|
width: 300px;
|
|
height: 285px;
|
|
box-sizing: border-box;
|
|
background-size: 100% 100%;
|
|
position: relative;
|
|
text-align: center;
|
|
}
|
|
|
|
.tishi-copy {
|
|
position: absolute;
|
|
top: 72px;
|
|
left: 46px;
|
|
width: 194px;
|
|
}
|
|
|
|
.tishi-copy-title {
|
|
color: #21443c;
|
|
font-size: 16px;
|
|
font-weight: 900;
|
|
line-height: 23px;
|
|
letter-spacing: 0.2px;
|
|
text-shadow: 0 1px 0 rgba(255, 255, 255, 0.8);
|
|
}
|
|
|
|
.tishi-copy-desc {
|
|
margin-top: 13px;
|
|
color: #6d7d78;
|
|
font-size: 14px;
|
|
font-weight: 700;
|
|
line-height: 21px;
|
|
letter-spacing: 0.1px;
|
|
}
|
|
|
|
.tishi-copy-highlight {
|
|
color: #ff7043;
|
|
font-weight: 900;
|
|
}
|
|
.box-hover {
|
|
background: rgba(248, 255, 237, 0.86);
|
|
}
|
|
</style>
|