address.vue 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. <template>
  2. <view v-if="!loadding">
  3. <view v-if="listData.length>0">
  4. <view class="address-list bg-white">
  5. <view class="tr add_add" @click="addAddress()">新增收货地址</view>
  6. <view class="address p-30-0 d-s-c border-b-d" v-for="(item,index) in listData" :key="index">
  7. <view class="radio">
  8. <radio style="transform:scale(0.8)" color='#F6220C' :value="item.address_id+''" :checked="default_id==item.address_id+''"
  9. @click="radioChange(item.address_id)" />
  10. </view>
  11. <view class="info flex-1 ml20">
  12. <view class="user f32">
  13. <text>{{item.name}}</text>
  14. <text class="ml20 gray9 f26">{{item.phone}}</text>
  15. <text class="ml20 defaul_add" v-if="default_id==item.address_id">默认</text>
  16. </view>
  17. <view class="pt20 f26 gray3">
  18. {{item.region.province}}{{item.region.city}}{{item.region.region}}{{item.detail}}
  19. </view>
  20. </view>
  21. <view class="icon-box plus d-c-c ml30" @click="delAddress(item.address_id)">
  22. <image class="add_icon_img" src="../../../static/icon/delete.png" mode=""></image>
  23. </view>
  24. <view class="none_line ml30"></view>
  25. <view class="icon-box plus d-c-c ml30 mr40" @click="editAddress(item.address_id)">
  26. <image class="add_icon_img" src="../../../static/icon/edit.png" mode=""></image>
  27. </view>
  28. </view>
  29. </view>
  30. </view>
  31. <view v-else>
  32. <view class="none_add">
  33. <image class="no_add" src="../../../static/no_adress.png" mode=""></image>
  34. </view>
  35. <view class="no_add_add" @click="addAddress()">新增收货地址</view>
  36. </view>
  37. </view>
  38. </template>
  39. <script>
  40. export default {
  41. data() {
  42. return {
  43. /*是否加载完成*/
  44. loadding: true,
  45. indicatorDots: true,
  46. autoplay: true,
  47. interval: 2000,
  48. duration: 500,
  49. /*数据*/
  50. listData: [],
  51. /*默认地址id*/
  52. default_id: '0',
  53. options: {},
  54. /*订单修改*/
  55. dingC: '',
  56. oID: '',
  57. }
  58. },
  59. onLoad: function(options) {
  60. this.options = options;
  61. this.dingC = options.ding
  62. this.oID = options.order_id
  63. this.revAdd(options.ding)
  64. },
  65. onShow: function() {
  66. uni.showLoading({
  67. title: '加载中'
  68. });
  69. /*获取地址列表*/
  70. this.getData();
  71. },
  72. methods: {
  73. /*获取数据*/
  74. getData() {
  75. let self = this;
  76. let dataType = self.dataType;
  77. self._get('user.address/lists', {}, function(res) {
  78. self.listData = res.data.list;
  79. self.default_id = res.data.default_id + '';
  80. self.loadding = false;
  81. uni.hideLoading();
  82. });
  83. },
  84. /*跳转页面*/
  85. addAddress() {
  86. let delta = 1;
  87. if (this.options.source === 'order') {
  88. delta = 2;
  89. }
  90. this.gotoPage('/pages/user/address/add/add?delta=' + delta);
  91. },
  92. /*点击单选*/
  93. radioChange(e) {
  94. let self = this;
  95. self.default_id = e;
  96. if(self.dingC == '1'){
  97. self._post('user.order/addressedit', {
  98. order_id: self.oID,
  99. address_id: e,
  100. }, function(res) {
  101. // #ifndef H5
  102. uni.navigateBack();
  103. // #endif
  104. // #ifdef H5
  105. history.go(-1);
  106. // #endif
  107. });
  108. }else{
  109. self._post('user.address/setDefault', {
  110. address_id: e,
  111. }, function(res) {
  112. if (self.options.source === 'order') {
  113. // #ifndef H5
  114. uni.navigateBack();
  115. // #endif
  116. // #ifdef H5
  117. history.go(-1);
  118. // #endif
  119. }
  120. });
  121. }
  122. return false;
  123. },
  124. /*编辑地址*/
  125. editAddress(e) {
  126. this.gotoPage('/pages/user/address/edit/edit?address_id=' + e);
  127. },
  128. /*删除地址*/
  129. delAddress(e) {
  130. let self = this;
  131. wx.showModal({
  132. title: "提示",
  133. content: "您确定要移除当前收货地址吗?",
  134. success: function(o) {
  135. o.confirm && self._get('user.address/delete', {
  136. address_id: e
  137. }, function(result) {
  138. if (result.code == 1) {
  139. uni.showToast({
  140. title: '删除成功',
  141. duration: 2000
  142. });
  143. self.getData();
  144. }
  145. });
  146. }
  147. });
  148. }
  149. }
  150. }
  151. </script>
  152. <style>
  153. page {
  154. background-color: #FFFFFF;
  155. }
  156. .address-list {
  157. border-top: 16rpx solid #F2F2F2;
  158. padding: 0 20rpx;
  159. padding-bottom: 90rpx;
  160. }
  161. .foot-btns {
  162. padding: 0;
  163. }
  164. .foot-btns .btn-red {
  165. width: 100%;
  166. height: 90rpx;
  167. line-height: 90rpx;
  168. border-radius: 0;
  169. }
  170. .none_add {
  171. padding: 314rpx 214rpx 60rpx 214rpx;
  172. }
  173. .no_add {
  174. width: 322rpx;
  175. height: 180rpx;
  176. }
  177. .no_add_add {
  178. width: 320rpx;
  179. height: 80rpx;
  180. border: 2rpx solid #FFB7B7;
  181. border-radius: 40rpx;
  182. text-align: center;
  183. line-height: 80rpx;
  184. font-size: 32rpx;
  185. font-family: PingFang SC;
  186. font-weight: 500;
  187. color: #F6220C;
  188. margin: 0 auto;
  189. }
  190. .add_add {
  191. height: 64rpx;
  192. line-height: 64rpx;
  193. font-size: 26rpx;
  194. font-family: PingFang SC;
  195. font-weight: 500;
  196. color: #0777CD;
  197. padding: 0 35rpx;
  198. border-bottom: 1rpx solid #D9D9D9;
  199. }
  200. .defaul_add {
  201. padding: 9rpx 14rpx 10rpx 15rpx;
  202. background: #FFE7E4;
  203. font-size: 22rpx;
  204. font-family: PingFang SC;
  205. font-weight: 500;
  206. color: #F6220C;
  207. }
  208. .add_icon_img {
  209. width: 30rpx;
  210. height: 30rpx;
  211. }
  212. .none_line {
  213. width: 1rpx;
  214. height: 44rpx;
  215. background: #D9D9D9;
  216. }
  217. </style>