addrs.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472
  1. <template>
  2. <view class="pages">
  3. <view class="addrs">
  4. <view class="addrs-item" :class="item.defaultStatus==1?'default':''" v-for="(item,index) in addrsList" :key="index">
  5. <view class="addrs-item-content" @click="selectDefault(item)">
  6. <view class="addrs-item-upwrap">
  7. <view class="addrs-item-name">收货人:{{item.name}}</view>
  8. <view class="addrs-item-phoneNumber">{{item.phoneNumber}}</view>
  9. </view>
  10. <view class="addrs-item-addr">收货地址:{{item.province}}{{item.city}}{{item.region}}{{item.detailAddress}}</view>
  11. </view>
  12. <view class="addrs-item-icon-wrap" @click="editAddr(item)">
  13. <!-- <text class="iconfont iconGroup" v-if="item.defaultStatus == 1"></text> -->
  14. <text>编辑</text>
  15. </view>
  16. </view>
  17. </view>
  18. <view class="new-btn-wrap">
  19. <view class="new-btn" @click="newAddr">添加新地址</view>
  20. </view>
  21. <!-- 地址编辑 -->
  22. <view class="newaddr-page fix-content translate" :class="{ 'open': fixPageOpen }">
  23. <view class="fix-content-nav"><text @click="closeFixPage" class="iconfont iconhoutui"></text></view>
  24. <!-- <view class="form-item required">
  25. <view class="form-item-til">所在省</view>
  26. <view class="form-item-con">
  27. <input type="text" placeholder="请选择/输入" v-model="params.province" value="" />
  28. </view>
  29. </view>
  30. <view class="form-item required">
  31. <view class="form-item-til">所在市</view>
  32. <view class="form-item-con">
  33. <input type="text" placeholder="请选择/输入" v-model="params.city" value="" />
  34. </view>
  35. </view>
  36. <view class="form-item required">
  37. <view class="form-item-til">所在地区</view>
  38. <view class="form-item-con">
  39. <input type="text" placeholder="请选择/输入" v-model="params.region" value="" />
  40. </view>
  41. </view> -->
  42. <view class="form-item select-addr required" @click="addressShow = true">
  43. <view class="form-item-til">选择地址</view>
  44. <view class="form-item-con">
  45. <text v-if="address==''">请选择地址</text>
  46. {{address}}
  47. <pickerAddress v-model="addressShow" @confirm="addresspick" />
  48. </view>
  49. </view>
  50. <view class="form-item required">
  51. <view class="form-item-til">详细地址</view>
  52. <view class="form-item-con">
  53. <input type="text" placeholder="请输入详细地址" v-model="params.detailAddress" value="" />
  54. </view>
  55. </view>
  56. <view class="form-item required">
  57. <view class="form-item-til">联系人</view>
  58. <view class="form-item-con">
  59. <input type="text" placeholder="请输入联系人" v-model="params.name" value="" />
  60. </view>
  61. </view>
  62. <view class="form-item required">
  63. <view class="form-item-til">联系电话</view>
  64. <view class="form-item-con">
  65. <input type="text" placeholder="请输入联系电话" v-model="params.phoneNumber" value="" />
  66. </view>
  67. </view>
  68. <view class="form-item">
  69. <view class="form-item-til">邮政编码</view>
  70. <view class="form-item-con">
  71. <input type="text" placeholder="请输入邮政编码" v-model="params.postCode" value="" />
  72. </view>
  73. </view>
  74. <view class="form-item">
  75. <view class="form-item-til">设为默认收货地址</view>
  76. <view class="form-item-con" style="min-width: auto;">
  77. <switch :checked="params.defaultStatus==1?true:false" @change="switchDefaultStatus" />
  78. </view>
  79. </view>
  80. <view class="form-item" v-if="isedit">
  81. <view class="form-item-til" style="color: red;" @click="delAddr">删除收货地址</view>
  82. </view>
  83. <view class="form-item save-addr">
  84. <view class="form-item-til" @click="saveAddr">保存收货地址</view>
  85. </view>
  86. <!-- <baidu-map class="map" :center="center" :zoom="zoom" @ready="handlermap" :scroll-wheel-zoom="true" @click="clickEvent"
  87. ak="BSf4i2bljmxl8R0x28cjOy8KMVrCVzev">
  88. <bm-navigation anchor="BMAP_ANCHOR_TOP_RIGHT"></bm-navigation>
  89. <bm-city-list anchor="BMAP_ANCHOR_TOP_LEFT"></bm-city-list>
  90. <bm-geolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT" :showAddressBar="true" :autoLocation="true" @locationSuccess="getLoctionSuccess"></bm-geolocation>
  91. <bm-view :style="{width:'100%',height: '400px'}"></bm-view>
  92. </baidu-map> -->
  93. </view>
  94. <!-- 地址编辑 -->
  95. <uni-popup ref="popup" type="dialog">
  96. <uni-popup-dialog type="info" content="确认删除此地址吗?" :duration="2000" :before-close="true" @close="closepopup" @confirm="confirmpopup"></uni-popup-dialog>
  97. </uni-popup>
  98. </view>
  99. </template>
  100. <script>
  101. // import {
  102. // BaiduMap,
  103. // BmNavigation,
  104. // BmView,
  105. // BmGeolocation,
  106. // BmCityList
  107. // } from 'vue-baidu-map';
  108. import uniPopup from '@/components/uni-popup/uni-popup.vue';
  109. import uniPopupDialog from '@/components/uni-popup/uni-popup-dialog.vue';
  110. import pickerAddress from '@/components/liudx-pickerAddress/index.vue'
  111. const defaultparams= {
  112. token: '',
  113. name: '',
  114. phoneNumber: "",
  115. defaultStatus: "0",
  116. postCode: "",
  117. province: "",
  118. city: "",
  119. region: "",
  120. detailAddress: "",
  121. latitude: '',
  122. longitude: ''
  123. };
  124. export default {
  125. // beforeRouteEnter(to, from, next){
  126. // console.log('from',from);
  127. // next(vm =>{
  128. // console.log('22222222',from) // 上一页面的路由信息
  129. // })
  130. // },
  131. // beforeRouteLeave(to, from, next) {
  132. // console.log(' beforeRouteLeave !', this)
  133. // const answer = window.confirm('确认离开?')
  134. // answer ? next() : next(false)
  135. // },
  136. components: {
  137. // BaiduMap,
  138. // BmNavigation,
  139. // BmView,
  140. // BmGeolocation,
  141. // BmCityList,
  142. uniPopup,
  143. uniPopupDialog,
  144. pickerAddress
  145. },
  146. data() {
  147. return {
  148. addressShow: false,
  149. form: {
  150. province: '',
  151. city: '',
  152. area: '',
  153. },
  154. address: '',
  155. isedit: false,
  156. isselectAddr:false,
  157. addrsList: [],
  158. token:'',
  159. params: Object.assign({},defaultparams),
  160. ruleItems:{
  161. name: '',
  162. phoneNumber: "",
  163. province: "",
  164. city: "",
  165. region: "",
  166. detailAddress: "",
  167. },
  168. rules: {
  169. name: {rule: /^.{1,20}$/,msg: "请填写姓名(1-20个字符)"},
  170. province: {rule: /\S/,msg: "请填写必要内容"},
  171. city: {rule: /\S/,msg: "请填写必要内容"},
  172. region: {rule: /\S/,msg: "请填写必要内容"},
  173. detailAddress: {rule: /\S/,msg: "请填写详细地址"},
  174. phoneNumber: {rule: /(^1[3|4|5|7|8|9]\d{9}$)|(^09\d{8}$)/,msg: "请填写正确手机号"},
  175. },
  176. fixPageOpen: false,
  177. center: {
  178. lng: 106.632713,
  179. lat: 26.653157
  180. },
  181. zoom: 12,
  182. }
  183. },
  184. onShow() {
  185. let serf = this;
  186. this.getAddrList();
  187. },
  188. onLoad() {
  189. let self = this;
  190. uni.getStorage({
  191. key:'token',
  192. success: function (res) {
  193. self.token = res.data;
  194. // console.log(res.data);
  195. }
  196. });
  197. uni.getStorage({
  198. key:'selectAddr',
  199. success: function (res) {
  200. self.isselectAddr = true;
  201. // console.log(res.data);
  202. },
  203. fail:function(){
  204. self.isselectAddr = false;
  205. }
  206. });
  207. },
  208. onUnload() {
  209. this.isselectAddr = false;
  210. uni.setStorage({
  211. key:'selectAddr',
  212. data:false
  213. });
  214. },
  215. methods: {
  216. addresspick(obj) {
  217. console.log('addresspick',obj);
  218. this.params.province = obj.province.areaName;
  219. this.params.city = obj.city.areaName;
  220. this.params.region = obj.area.areaName||'';
  221. this.concatAddr();
  222. },
  223. concatAddr(){
  224. this.address = this.params.province + this.params.city +this.params.region;
  225. },
  226. getAddrList() {
  227. let thetoken = 'Bearer ' + this.token;
  228. this.$api.http.get(this.config.apiBaseurl + '/member/address/list',{header: {Authorization:thetoken}}).then(res => {
  229. // console.log('getAddrList', res);
  230. this.addrsList = res.data.data;
  231. if(this.addrsList.length == 1 && this.addrsList[0].defaultStatus!=1){
  232. // console.log('getAddrListlength', this.addrsList[0]);
  233. // setTimeout(function(){console.log(this)},5000);
  234. setTimeout(this.setDefault(this.addrsList[0].id),1000);
  235. // this.setDefault(this.addrsList[0].id);
  236. }
  237. }).catch(err => {
  238. // console.log('err', err)
  239. })
  240. },
  241. newAddr() {
  242. this.fixPageOpen = true;
  243. },
  244. closeFixPage(){
  245. this.fixPageOpen = false;
  246. this.params = Object.assign({},defaultparams);
  247. this.isedit = false;
  248. this.address = '';
  249. this.getAddrList();
  250. },
  251. //是否默认
  252. switchDefaultStatus(e) {
  253. if (e.target.value) {
  254. this.params.defaultStatus = 1;
  255. } else {
  256. this.params.defaultStatus = 0;
  257. }
  258. // console.log('this.params',this.params);
  259. },
  260. editAddr(item){
  261. this.isedit = true;
  262. this.params = Object.assign(this.params,item);
  263. this.concatAddr();
  264. this.fixPageOpen = true;
  265. },
  266. saveAddr(){
  267. console.log(this.isedit);
  268. for (let x in this.ruleItems) {
  269. // console.log('x',x)
  270. if(!this.validate(x)) return;
  271. }
  272. console.log('this.params',this.params);
  273. // var saveApi;
  274. if(this.isedit){
  275. // saveApi = this.config.apiBaseurl + '/member/address/update';
  276. // console.log(this.params);
  277. this.$api.http.put(this.config.apiBaseurl + '/member/address/update/'+this.params.id,this.params,{
  278. header: {
  279. Accept:'application/json',
  280. Authorization: 'Bearer '+ this.token, //注意Bearer后面有一空格
  281. },
  282. }).then(res => {
  283. this.closeFixPage();
  284. // console.log('res',res)
  285. }).catch(err =>{
  286. console.log('err',err)
  287. });
  288. }else{
  289. // saveApi = this.config.apiBaseurl + '/member/address/add';
  290. if(this.addrsList.length == 0 ){this.params.defaultStatus = 1}
  291. this.$api.http.post(this.config.apiBaseurl + '/member/address/add',this.params,{
  292. header: {
  293. Accept:'application/json',
  294. Authorization: 'Bearer '+ this.token, //注意Bearer后面有一空格
  295. },
  296. }).then(res => {
  297. this.closeFixPage();
  298. //产品跳转
  299. uni.getStorage({
  300. key:'productID',
  301. success: res => {
  302. console.log('productID',res.data);
  303. this.jumpProduct(res.data);
  304. uni.removeStorage({
  305. key:'productID'
  306. });
  307. }
  308. });
  309. //产品跳转
  310. // console.log('res',res)
  311. }).catch(err =>{
  312. console.log('err',err)
  313. });
  314. }
  315. },
  316. closepopup(done){
  317. done()
  318. },
  319. confirmpopup(done,value){
  320. this.$api.http.delete(this.config.apiBaseurl + '/member/address/delete/'+this.params.id,{},{
  321. header: {
  322. Accept:'application/json',
  323. Authorization: 'Bearer '+ this.token, //注意Bearer后面有一空格
  324. },
  325. }).then(res => {
  326. this.closeFixPage();
  327. // console.log('res',res)
  328. }).catch(err =>{
  329. console.log('err',err)
  330. });
  331. done()
  332. },
  333. delAddr(item){
  334. this.$refs.popup.open();
  335. },
  336. selectDefault(item){
  337. // console.log('item',item);
  338. if(item.defaultStatus != 1){
  339. this.setDefault(item.id);
  340. }
  341. console.log(this.$router);
  342. console.log(this.$router.history.current.fullPath);
  343. if(this.isselectAddr){this.$router.go(-1);}
  344. },
  345. setDefault(id){
  346. this.$api.http.put(this.config.apiBaseurl + '/member/address/default/'+id,{},{
  347. header: {
  348. Accept:'application/json',
  349. Authorization: 'Bearer '+ this.token, //注意Bearer后面有一空格
  350. },
  351. }).then(res => {
  352. // this.closeFixPage();
  353. console.log('res',res)
  354. }).catch(err =>{
  355. console.log('err',err)
  356. });
  357. },
  358. //判断验证是否符合要求
  359. validate(key) {
  360. let bool = true;
  361. if (!this.rules[key].rule.test(this.params[key])) {
  362. //提示信息
  363. uni.showToast({
  364. icon:"none",
  365. title: this.rules[key].msg,
  366. })
  367. //取反
  368. bool = false;
  369. return false;
  370. }
  371. return bool;
  372. },
  373. //产品跳转链接
  374. jumpProduct(id){
  375. uni.navigateTo({
  376. url:`/pages/product/product?id=${id}`,
  377. fail(err) {
  378. console.log(err)
  379. }
  380. })
  381. },
  382. // handlermap({
  383. // BMap,
  384. // map
  385. // }) {
  386. // let _this = this;
  387. // var geolocation = new BMap.Geolocation();
  388. // geolocation.getCurrentPosition(function(r) {
  389. // // console.log(r);
  390. // _this.center = {
  391. // lng: r.longitude,
  392. // lat: r.latitude
  393. // }; // 设置center属性值
  394. // // console.log('_this.center',_this.params);
  395. // if (_this.params.latitude && _this.params.longitude) {
  396. // let transqq = qqMapTransBMap(_this.params.longitude, _this.params.latitude);
  397. // // console.log('transqq',transqq);
  398. // _this.center = {
  399. // lng: transqq.lng,
  400. // lat: transqq.lat
  401. // };
  402. // };
  403. // let Icon_0 = new BMap.Icon("static/img/zuobiao.gif", new BMap.Size(64, 64), {
  404. // anchor: new BMap.Size(18, 32),
  405. // imageSize: new BMap.Size(36, 36)
  406. // });
  407. // let myMarker = new BMap.Marker(new BMap.Point(_this.params.longitude, _this.params.latitude), {
  408. // icon: Icon_0
  409. // });
  410. // // map.addOverlay(myMarker);
  411. // _this.autoLocationPoint = {
  412. // lng: r.longitude,
  413. // lat: r.latitude
  414. // }; // 自定义覆盖物
  415. // _this.initLocation = true;
  416. // }, {
  417. // enableHighAccuracy: true
  418. // })
  419. // window.map = map;
  420. // },
  421. //点击地图监听
  422. // clickEvent(e) {
  423. // map.clearOverlays();
  424. // let Icon_0 = new BMap.Icon("static/img/zuobiao.gif", new BMap.Size(64, 64), {
  425. // anchor: new BMap.Size(18, 32),
  426. // imageSize: new BMap.Size(36, 36)
  427. // });
  428. // var myMarker = new BMap.Marker(new BMap.Point(e.point.lng, e.point.lat), {
  429. // icon: Icon_0
  430. // });
  431. // map.addOverlay(myMarker);
  432. // //用所定位的经纬度查找所在地省市街道等信息
  433. // var point = new BMap.Point(e.point.lng, e.point.lat);
  434. // var gc = new BMap.Geocoder();
  435. // let _this = this;
  436. // gc.getLocation(point, function(rs) {
  437. // var addComp = rs.addressComponents;
  438. // console.log(rs); //地址信息
  439. // _this.params.province = rs.addressComponents.province;
  440. // _this.params.city = rs.addressComponents.city;
  441. // _this.params.region = rs.addressComponents.district;
  442. // uni.showToast({
  443. // title:"选择成功!",
  444. // icon:"none",
  445. // duration:800
  446. // });
  447. // // _this.params.detailAddress = rs.address;
  448. // });
  449. // //转为高德坐标
  450. // // let transGaode = bMapTransQQMap(e.point.lng, e.point.lat);
  451. // },
  452. }
  453. }
  454. </script>
  455. <style scoped>
  456. @import url("./addrs.css");
  457. </style>