| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282 | <template>  <s-layout :bgStyle="{ color: '#FFF' }" title="选择自提门店">    <view class="storeBox" ref="container">      <view        class="storeBox-box"        v-for="(item, index) in state.storeList"        :key="index"        @tap="checked(item)"      >        <view class="store-img">          <image :src="item.logo" class="img" />        </view>        <view class="store-cent-left">          <view class="store-name">{{ item.name }}</view>          <view class="store-address line1">            {{ item.areaName }}{{ ', ' + item.detailAddress }}          </view>        </view>        <view class="row-right ss-flex-col ss-col-center">          <view>            <!-- #ifdef H5 -->            <a class="store-phone" :href="'tel:' + item.phone">              <view class="iconfont">                <view class="ss-rest-button">                  <text class="_icon-forward" />                </view>              </view>            </a>            <!-- #endif -->            <!-- #ifdef MP -->            <view class="store-phone" @click="call(item.phone)">              <view class="iconfont">                <view class="ss-rest-button">                  <text class="_icon-forward" />                </view>              </view>            </view>            <!-- #endif -->          </view>          <view class="store-distance ss-flex ss-row-center" @tap.stop="showMaoLocation(item)">            <text class="addressTxt" v-if="item.distance">              距离{{ item.distance.toFixed(2) }}千米            </text>            <text class="addressTxt" v-else>查看地图</text>            <view class="iconfont">              <view class="ss-rest-button">                <text class="_icon-forward" />              </view>            </view>          </view>        </view>      </view>    </view>  </s-layout></template><script setup>  import DeliveryApi from '@/sheep/api/trade/delivery';  import { onMounted, reactive } from 'vue';  import { onLoad } from '@dcloudio/uni-app';  import sheep from '@/sheep';  const LONGITUDE = 'user_longitude';  const LATITUDE = 'user_latitude';  const state = reactive({    loaded: false,    loading: false,    storeList: [],    system_store: {},    locationShow: false,    user_latitude: 0,    user_longitude: 0,  });  const call = (phone) => {    uni.makePhoneCall({      phoneNumber: phone,    });  };  const selfLocation = () => {    // #ifdef H5    const jsWxSdk = sheep.$platform.useProvider('wechat').jsWxSdk;    if (jsWxSdk.isWechat()) {      jsWxSdk.getLocation((res) => {        state.user_latitude = res.latitude;        state.user_longitude = res.longitude;        uni.setStorageSync(LATITUDE, res.latitude);        uni.setStorageSync(LONGITUDE, res.longitude);        getList();      });    } else {      // #endif      uni.getLocation({        type: 'gcj02',        success: (res) => {          try {            state.user_latitude = res.latitude;            state.user_longitude = res.longitude;            uni.setStorageSync(LATITUDE, res.latitude);            uni.setStorageSync(LONGITUDE, res.longitude);          } catch (e) {            console.error(e);          }          getList();        },        complete: () => {          getList();        },      });      // #ifdef H5    }    // #endif  };  const showMaoLocation = (e) => {    // #ifdef H5    const jsWxSdk = sheep.$platform.useProvider('wechat').jsWxSdk;    if (jsWxSdk.isWechat()) {      jsWxSdk.openLocation({        latitude: Number(e.latitude),        longitude: Number(e.longitude),        name: e.name,        address: `${e.areaName}-${e.detailAddress}`,      });    } else {      // #endif      uni.openLocation({        latitude: Number(e.latitude),        longitude: Number(e.longitude),        name: e.name,        address: `${e.areaName}-${e.detailAddress}`,        success: function () {          console.log('success');        },      });      // #ifdef H5    }    // #endif  };  /**   * 选中门店   */  const checked = (addressInfo) => {    uni.$emit('SELECT_PICK_UP_INFO', {      addressInfo,    });    sheep.$router.back();  };  /**   * 获取门店列表数据   */  const getList = async () => {    if (state.loading || state.loaded) {      return;    }    state.loading = true;    const { data, code } = await DeliveryApi.getDeliveryPickUpStoreList({      latitude: state.user_latitude,      longitude: state.user_longitude,    });    if (code !== 0) {      return;    }    state.loading = false;    state.storeList = data;  };  onMounted(() => {    if (state.user_latitude && state.user_longitude) {      getList();    } else {      selfLocation();      getList();    }  });  onLoad(() => {    try {      state.user_latitude = uni.getStorageSync(LATITUDE);      state.user_longitude = uni.getStorageSync(LONGITUDE);    } catch (e) {      console.error(e);    }  });</script><style lang="scss" scoped>  .line1 {    overflow: hidden;    text-overflow: ellipsis;    white-space: nowrap;  }  .geoPage {    position: fixed;    width: 100%;    height: 100%;    top: 0;    z-index: 10000;  }  .storeBox {    width: 100%;    background-color: #fff;    padding: 0 30rpx;  }  .storeBox-box {    width: 100%;    height: auto;    display: flex;    align-items: center;    padding: 23rpx 0;    justify-content: space-between;    border-bottom: 1px solid #eee;  }  .store-cent {    display: flex;    align-items: center;    width: 80%;  }  .store-cent-left {    //width: 45%;    flex: 2;  }  .store-img {    flex: 1;    width: 120rpx;    height: 120rpx;    border-radius: 6rpx;    margin-right: 22rpx;  }  .store-img .img {    width: 100%;    height: 100%;  }  .store-name {    color: #282828;    font-size: 30rpx;    margin-bottom: 22rpx;    font-weight: 800;  }  .store-address {    color: #666666;    font-size: 24rpx;  }  .store-phone {    width: 50rpx;    height: 50rpx;    color: #fff;    border-radius: 50%;    display: block;    text-align: center;    line-height: 48rpx;    background-color: #e83323;    margin-bottom: 22rpx;    text-decoration: none;  }  .store-distance {    font-size: 22rpx;    color: #e83323;  }  .iconfont {    font-size: 20rpx;  }  .row-right {    flex: 2;    //display: flex;    //flex-direction: column;    //align-items: flex-end;    //width: 33.5%;  }</style>
 |