| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508 | <!-- 拼团订单的详情 --><template>  <s-layout title="拼团详情" class="detail-wrap" :navbar="state.data && !state.loading ? 'inner': 'normal'" :onShareAppMessage="shareInfo">    <view v-if="state.loading"></view>    <view v-if="state.data && !state.loading">      <!-- 团长信息 + 活动信息 -->      <view        class="recharge-box"        v-if="state.data.headRecord"        :style="[          {            marginTop: '-' + Number(statusBarHeight + 88) + 'rpx',            paddingTop: Number(statusBarHeight + 108) + 'rpx',          },        ]"      >        <s-goods-item          class="goods-box"          :img="state.data.headRecord.picUrl"          :title="state.data.headRecord.spuName"          :price="state.data.headRecord.combinationPrice"          priceColor="#E1212B"          @tap="            sheep.$router.go('/pages/goods/groupon', {              id: state.data.headRecord.activityId            })          "          :style="[{ top: Number(statusBarHeight + 108) + 'rpx' }]"        >          <template #groupon>            <view class="ss-flex">              <view class="sales-title">{{ state.data.headRecord.userSize }}人团</view>              <view class="num-title ss-m-l-20">已拼{{ state.data.headRecord.userCount }}件</view>            </view>          </template>        </s-goods-item>      </view>      <view class="countdown-box detail-card ss-p-t-44 ss-flex-col ss-col-center">        <!-- 情况一:拼团成功 -->        <view v-if="state.data.headRecord.status === 1">          <view v-if="state.data.orderId">            <view class="countdown-title ss-flex">              <text class="cicon-check-round" />              恭喜您~拼团成功            </view>          </view>          <view v-else>            <view class="countdown-title ss-flex">              <text class="cicon-info" />              抱歉~该团已满员            </view>          </view>        </view>        <!-- 情况二:拼团失败 -->        <view v-if="state.data.headRecord.status === 2">          <view class="countdown-title ss-flex">            <text class="cicon-info"></text>            {{ state.data.orderId ? '拼团超时,已自动退款' : '该团已解散' }}          </view>        </view>        <!-- 情况三:拼团进行中 -->        <view v-if="state.data.headRecord.status === 0">          <view v-if="state.data.headRecord.expireTime <= new Date().getTime()">            <view class="countdown-title ss-flex">              <text class="cicon-info"></text>              拼团已结束,请关注下次活动            </view>          </view>          <view class="countdown-title ss-flex" v-else>            还差            <view class="num">{{ state.data.headRecord.userSize - state.data.headRecord.userCount }}人</view>            拼团成功            <view class="ss-flex countdown-time">              <view class="countdown-h ss-flex ss-row-center">{{ endTime.h }}</view>              <view class="ss-m-x-4">:</view>              <view class="countdown-num ss-flex ss-row-center">                {{ endTime.m }}              </view>              <view class="ss-m-x-4">:</view>              <view class="countdown-num ss-flex ss-row-center">                {{ endTime.s }}              </view>            </view>          </view>        </view>        <!-- 拼团的记录列表,展示每个参团人 -->        <view class="ss-m-t-60 ss-flex ss-flex-wrap ss-row-center">          <!-- 团长 -->          <view class="header-avatar ss-m-r-24 ss-m-b-20">            <image :src="sheep.$url.cdn(state.data.headRecord.avatar)" class="avatar-img"></image>            <view class="header-tag ss-flex ss-col-center ss-row-center">团长</view>          </view>          <!-- 团员 -->          <view            class="header-avatar ss-m-r-24 ss-m-b-20"            v-for="item in state.data.memberRecords"            :key="item.id"          >            <image :src="sheep.$url.cdn(item.avatar)" class="avatar-img"></image>            <view              class="header-tag ss-flex ss-col-center ss-row-center"              v-if="item.is_leader == '1'"            >              团长            </view>          </view>          <!-- 还有几个坑位 -->          <view class="default-avatar ss-m-r-24 ss-m-b-20" v-for="item in state.remainNumber" :key="item">            <image              :src="sheep.$url.static('/static/images/unknown.png')"              class="avatar-img"            ></image>          </view>        </view>      </view>      <!-- 情况一:拼团成功;情况二:拼团失败 -->      <view        v-if="state.data.headRecord.status === 1 || state.data.headRecord.status === 2"        class="ss-m-t-40 ss-flex ss-row-center"      >        <button          class="ss-reset-button order-btn"          v-if="state.data.orderId"          @tap="onDetail(state.data.orderId)"        >          查看订单        </button>        <button class="ss-reset-button join-btn" v-else @tap="onCreateGroupon"> 我要开团 </button>      </view>      <!-- 情况三:拼团进行中,查看订单或参加或邀请好友或参加 -->      <view v-if="state.data.headRecord.status === 0" class="ss-m-t-40 ss-flex ss-row-center">        <view v-if="state.data.headRecord.expireTime <= new Date().getTime()">          <button            class="ss-reset-button join-btn"            v-if="state.data.orderId"            @tap="onDetail(state.data.orderId)"          >            查看订单          </button>          <button            class="ss-reset-button disabled-btn"            v-else            disabled            @tap="onDetail(state.data.orderId)"          >            去参团          </button>        </view>        <view v-else class="ss-flex ss-row-center">          <view v-if="state.data.orderId">            <button              class="ss-reset-button join-btn"              :disabled="endTime.ms <= 0"              @tap="onShare"            >              邀请好友来拼团            </button>          </view>          <view v-else>            <button              class="ss-reset-button join-btn"              :disabled="endTime.ms <= 0"              @tap="onJoinGroupon()"            >              立即参团            </button>          </view>        </view>      </view>      <!-- TODO 非繁人:这里暂时没接入 -->      <view v-if="state.data.goods">        <s-select-groupon-sku          :show="state.showSelectSku"          :goodsInfo="state.data.goods"          :grouponAction="state.grouponAction"          :grouponNum="state.grouponNum"          @buy="onBuy"          @change="onSkuChange"          @close="state.showSelectSku = false"        />      </view>    </view>    <s-empty v-if="!state.data && !state.loading" icon="/static/goods-empty.png" />  </s-layout></template><script setup>  import { computed, reactive } from 'vue';  import sheep from '@/sheep';  import { onLoad } from '@dcloudio/uni-app';  import { useDurationTime } from '@/sheep/hooks/useGoods';  import { showShareModal } from '@/sheep/hooks/useModal';  import { isEmpty } from 'lodash';  import CombinationApi from "@/sheep/api/promotion/combination";  const headerBg = sheep.$url.css('/static/img/shop/user/withdraw_bg.png');  const statusBarHeight = sheep.$platform.device.statusBarHeight * 2;  const state = reactive({    data: {}, // 拼团详情    loading: true,    grouponAction: 'create',    showSelectSku: false,    grouponNum: 0,    number: 0,    activity: {},    combinationHeadId: null, // 拼团团长编号  });  // todo 非繁人:分享要再接下  const shareInfo = computed(() => {    if (isEmpty(state.data)) return {};    return sheep.$platform.share.getShareInfo(      {        title: state.data.headRecord.spuName,        image: sheep.$url.cdn(state.data.headRecord.picUrl),        desc: state.data.goods?.subtitle,        params: {          page: '5',          query: state.data.id,        },      },      {        type: 'groupon', // 邀请拼团海报        title: state.data.headRecord.spuName, // 商品标题        image: sheep.$url.cdn(state.data.headRecord.picUrl), // 商品主图        price: state.data.goods?.price, // 商品价格        original_price: state.data.goods?.original_price, // 商品原价      },    );  });  // 订单详情  function onDetail(orderId) {    sheep.$router.go('/pages/order/detail', {      id: orderId,    });  }  // 去开团 TODO 非繁人:这里没接入  function onCreateGroupon() {    state.grouponAction = 'create';    state.grouponId = 0;    state.showSelectSku = true;  }  // 规格变更 TODO 非繁人:这里没接入  function onSkuChange(e) {    state.selectedSkuPrice = e;  }  // 立即参团 TODO 非繁人:这里没接入  function onJoinGroupon() {    state.grouponAction = 'join';    state.grouponId = state.data.activityId;    state.combinationHeadId = state.data.id;    state.grouponNum = state.data.num;    state.showSelectSku = true;  }  // 立即购买 TODO 非繁人:这里没接入  function onBuy(sku) {    sheep.$router.go('/pages/order/confirm', {      data: JSON.stringify({        order_type: 'goods',        combinationActivityId: state.data.activity.id,        combinationHeadId: state.combinationHeadId,        items: [          {            skuId: sku.id,            count: sku.count,          },        ],      }),    });  }  const endTime = computed(() => {    return useDurationTime(state.data.headRecord.expireTime);  });  // 获取拼团团队详情  async function getGrouponDetail(id) {    const { code, data } = await CombinationApi.getCombinationRecordDetail(id);    if (code === 0) {      state.data = data;      const remainNumber = Number(state.data.headRecord.userSize - state.data.headRecord.userCount);      state.remainNumber = remainNumber > 0 ? remainNumber : 0;      // 获取活动信息      const { data: activity } = await CombinationApi.getCombinationActivity(data.headRecord.activityId);      state.activity = activity;    } else {      state.data = null;    }    state.loading = false;  }  function onShare() {    showShareModal();  }  onLoad((options) => {    getGrouponDetail(options.id);  });</script><style lang="scss" scoped>  .recharge-box {    position: relative;    margin-bottom: 120rpx;    background: v-bind(headerBg) center/750rpx 100%        no-repeat,      linear-gradient(115deg, #f44739 0%, #ff6600 100%);    border-radius: 0 0 5% 5%;    height: 100rpx;    .goods-box {      width: 710rpx;      border-radius: 20rpx;      position: absolute;      left: 20rpx;      box-sizing: border-box;    }    .sales-title {      height: 32rpx;      background: rgba(#ffe0e2, 0.29);      border-radius: 16rpx;      font-size: 24rpx;      font-weight: 400;      padding: 6rpx 20rpx;      color: #f7979c;    }    .num-title {      font-size: 24rpx;      font-weight: 400;      color: #999999;    }  }  .countdown-time {    font-size: 26rpx;    font-weight: 500;    color: #383a46;    .countdown-h {      font-size: 24rpx;      font-family: OPPOSANS;      font-weight: 500;      color: #ffffff;      padding: 0 4rpx;      margin-left: 16rpx;      height: 40rpx;      background: linear-gradient(90deg, #ff6000 0%, #fe832a 100%);      border-radius: 6rpx;    }    .countdown-num {      font-size: 24rpx;      font-family: OPPOSANS;      font-weight: 500;      color: #ffffff;      width: 40rpx;      height: 40rpx;      background: linear-gradient(90deg, #ff6000 0%, #fe832a 100%);      border-radius: 6rpx;    }  }  .countdown-box {    // height: 364rpx;    background: #ffffff;    border-radius: 10rpx;    box-sizing: border-box;    .countdown-title {      font-size: 28rpx;      font-weight: 500;      color: #333333;      .cicon-check-round {        color: #42b111;        margin-right: 24rpx;      }      .cicon-info {        color: #d71e08;        margin-right: 24rpx;      }      .num {        color: #ff6000;      }    }    .header-avatar {      width: 86rpx;      height: 86rpx;      background: #ececec;      border-radius: 50%;      border: 4rpx solid #edc36c;      position: relative;      box-sizing: border-box;      .avatar-img {        width: 100%;        height: 100%;        border-radius: 50%;      }      .header-tag {        width: 72rpx;        height: 36rpx;        font-size: 24rpx;        line-height: nor;        background: linear-gradient(132deg, #f3dfb1, #f3dfb1, #ecbe60);        border-radius: 16rpx;        position: absolute;        left: 4rpx;        top: -36rpx;      }    }    .default-avatar {      width: 86rpx;      height: 86rpx;      background: #ececec;      border-radius: 50%;      .avatar-img {        width: 100%;        height: 100%;        border-radius: 50%;      }    }    .user-avatar {      width: 86rpx;      height: 86rpx;      background: #ececec;      border-radius: 50%;    }  }  .order-btn {    width: 668rpx;    height: 70rpx;    border: 2rpx solid #dfdfdf;    border-radius: 35rpx;    color: #999999;    font-weight: 500;    font-size: 26rpx;    line-height: normal;  }  .disabled-btn {    width: 668rpx;    height: 70rpx;    background: #dddddd;    border-radius: 35rpx;    color: #999999;    font-weight: 500;    font-size: 28rpx;    line-height: normal;  }  .join-btn {    width: 668rpx;    height: 70rpx;    background: linear-gradient(90deg, #ff6000 0%, #fe832a 100%);    box-shadow: 0px 8rpx 6rpx 0px rgba(255, 104, 4, 0.22);    border-radius: 35rpx;    color: #fff;    font-weight: 500;    font-size: 28rpx;    line-height: normal;  }  .detail-cell-wrap {    width: 100%;    padding: 10rpx 20rpx;    box-sizing: border-box;    border-top: 2rpx solid #dfdfdf;    background-color: #fff;    // min-height: 60rpx;    .label-text {      font-size: 28rpx;      font-weight: 400;    }    .cell-content {      font-size: 28rpx;      font-weight: 500;      color: $dark-6;    }    .right-forwrad-icon {      font-size: 28rpx;      font-weight: 500;      color: $dark-9;    }  }</style>
 |