address.vue 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. <template>
  2. <view class="page b-t">
  3. <singleList ref="listRef" url="addr.list" :sendData="reqData" @reqEnd="searchEnd">
  4. <template v-slot:items="{list}">
  5. <view class="list b-b" v-for="(item, index) in list" :key="index" @click="checkAddress(item)">
  6. <image :src="item.checked? '/static/check-do.png' : '/static/check-un.png' " mode="aspectFill" class="check" v-if="sourcePage==='mang'"></image>
  7. <view class="content flex-col">
  8. <view class="u-box align-center">
  9. <text class="name">{{item.consignee}}</text>
  10. <text class="mobile">{{item.mobile}}</text>
  11. <text v-if="item.is_default==='1'" class="tag">默认</text>
  12. <view class="ic-wrap del align-center justify-center">
  13. <image src="/static/addr-del.png" mode="aspectFill" class="ic" @click.stop="deleteAddress(item)"></image>
  14. </view>
  15. <view class="ic-wrap edit align-center justify-center">
  16. <image src="/static/addr-edit.png" mode="aspectFill" class="ic" @click.stop="addAddress(item.id)"></image>
  17. </view>
  18. </view>
  19. <view class="address-box">
  20. <text class="address">{{item.full_address}}</text>
  21. </view>
  22. </view>
  23. </view>
  24. <empty v-if="sRes && sRes==='empty'"/>
  25. </template>
  26. </singleList>
  27. <view class="add-btn" @click="addAddress()">新增地址</view>
  28. <safe-area bgColor="#f8f8f8"/>
  29. </view>
  30. </template>
  31. <script>
  32. export default {
  33. data() {
  34. return {
  35. sourcePage: '',
  36. // addressList: [
  37. // {
  38. // id:1,
  39. // is_default:true,
  40. // addr:'山东省临沂市河东区',
  41. // desc:'山东省临沂市河东区山东省临沂市河东区山东省临沂市河东区山东省临沂市河东区山东省临沂市河东区',
  42. // name:'mork',
  43. // mobile:'15263970923',
  44. // checked:true,
  45. // }
  46. // ],
  47. reqData:{}, //请求数据
  48. sRes:'', //搜索结果 empty,noMore
  49. }
  50. },
  51. onLoad(option) {
  52. // console.log(option.source);
  53. this.sourcePage = option.sourcePage;
  54. },
  55. onShow() {
  56. this.$nextTick(()=>{
  57. this.$refs.listRef.getList(true);
  58. })
  59. // this.refreshList();
  60. },
  61. onReachBottom() {
  62. this.$refs.listRef.getList();
  63. },
  64. methods: {
  65. //获取我的收货地址
  66. // async getList() {
  67. // let res = await this.$api.request('/addons/unishop/address/all', 'POST', {
  68. // page: 1,
  69. // pagesize: 50
  70. // });
  71. // let list = res.data;
  72. // if (list) {
  73. // this.addressList = list;
  74. // }
  75. // },
  76. //添加或修改成功之后回调
  77. // refreshList(data, type) {
  78. // //添加或修改后事件,这里直接在最前面添加了一条数据,实际应用中直接刷新地址列表即可
  79. // // this.addressList.unshift(data);
  80. // this.addressList=[];
  81. // this.getList();
  82. // },
  83. searchEnd({loadingType,pageOneRes}){
  84. if(loadingType === 'noMore' && pageOneRes && pageOneRes.length === 0){
  85. this.sRes='empty';
  86. }else{
  87. this.sRes=loadingType;
  88. }
  89. },
  90. //选择地址
  91. checkAddress(item) {
  92. // if (this.source == 1) {
  93. // 上一页盲盒页情况
  94. // if(this.$tools.prePage().setDefaultAddr){
  95. // this.$tools.prePage().setDefaultAddr(item);
  96. // uni.navigateBack()
  97. // }
  98. // }
  99. //盲盒页进
  100. if(this.sourcePage === 'mang'){
  101. this.$store.commit('userInfo/ADDR_INFO',item)
  102. uni.navigateBack()
  103. }
  104. },
  105. addAddress(id = 0) {
  106. this.navTo('/pages/address/addressManage',{id})
  107. },
  108. async deleteAddress(item) {
  109. let [error, res] = await uni.showModal({
  110. title: '确定删除地址?',
  111. content: item.address
  112. })
  113. if (res.confirm) {
  114. await this.$request('addr.del',{id:item.id});
  115. this.$refs.listRef.getList(true);
  116. if(item.id === this.addrInfo.id){
  117. this.$store.commit('userInfo/ADDR_INFO',{});
  118. }
  119. }
  120. }
  121. }
  122. }
  123. </script>
  124. <style lang='scss'>
  125. page {
  126. background: #f8f8f8;
  127. }
  128. .page{
  129. padding: 30rpx 20rpx;
  130. /* min-height: 100vh;
  131. padding-bottom: calc(var(--safe-area-inset-bottom) / 2); */
  132. position: relative;
  133. }
  134. .list {
  135. padding: 20upx 20upx 50rpx 73rpx;
  136. background: #fff;
  137. position: relative;
  138. border-radius: 10rpx;
  139. margin-bottom: 24rpx;
  140. .check{
  141. position: absolute;
  142. left: 17rpx;
  143. top: 60rpx;
  144. width: 34rpx;
  145. height: 34rpx;
  146. z-index: 2;
  147. }
  148. }
  149. .u-box {
  150. color: #999;
  151. height: 48rpx;
  152. .name{
  153. font-size: 30rpx;
  154. font-family: PingFang SC;
  155. font-weight: 500;
  156. color: #333333;
  157. margin-right: 20rpx;
  158. }
  159. .mobile{
  160. font-size: 30rpx;
  161. font-family: PingFang SC;
  162. font-weight: 500;
  163. color: #333333;
  164. margin-right: 12rpx;
  165. }
  166. .tag{
  167. width: 61rpx;
  168. height: 34rpx;
  169. background: #92B99C;
  170. border-radius: 4rpx;
  171. line-height: 34rpx;
  172. text-align: center;
  173. font-size: 22rpx;
  174. font-family: PingFang SC;
  175. font-weight: 500;
  176. color: #FFFFFF;
  177. }
  178. .ic-wrap{
  179. height: 48rpx;
  180. width: 64rpx;
  181. &.del{
  182. margin-left: auto;
  183. .ic{
  184. width: 28rpx;
  185. height: 28rpx;
  186. }
  187. }
  188. &.edit{
  189. margin-left: 8rpx;
  190. }
  191. .ic{
  192. width: 24rpx;
  193. height: 24rpx;
  194. }
  195. }
  196. }
  197. .address-box {
  198. margin-top: 13rpx;
  199. display: flex;
  200. align-items: flex-start;
  201. .address {
  202. font-size: 24upx;
  203. color: #999;
  204. max-width: 600rpx;
  205. line-height: 40rpx;
  206. }
  207. }
  208. .add-btn {
  209. display: flex;
  210. align-items: center;
  211. justify-content: center;
  212. width: 710upx;
  213. height: 80upx;
  214. margin: 240rpx auto 10rpx;
  215. font-size: 30upx;
  216. color: #fff;
  217. background-color: $base-color;
  218. border-radius: 38upx;
  219. }
  220. </style>