address-edit.vue 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  1. <template>
  2. <view class="content bg-drak ft-main">
  3. <view class="gap"></view>
  4. <view class="row dflex border-line padding-lr">
  5. <text class="tit">收货人</text>
  6. <input class="input" type="text" v-model="addrData.receiverName" placeholder="请输入收货人姓名"
  7. placeholder-class="placeholder" />
  8. </view>
  9. <view class="row dflex border-line padding-lr">
  10. <text class="tit">手机号</text>
  11. <input class="input" type="number" v-model="addrData.phoneNum" placeholder="请输入手机号码"
  12. placeholder-class="placeholder" />
  13. </view>
  14. <view class="row dflex border-line padding-left">
  15. <text class="tit">所在地区</text>
  16. <view class="dflex-b flex1">
  17. <view class="flex1 input_t" @click="openAddress">{{ addressName }}</view>
  18. <use-address ref="useAddress" @onConfirm="changeAddr" cancelColor="#bbb" themeColor="#FF6A6C">
  19. </use-address>
  20. <!-- <use-pickeraddr class="flex1" @change="changeAddr">
  21. <view class="input_t">{{ addressName }}</view>
  22. </use-pickeraddr> -->
  23. <!-- #ifdef MP-WEIXIN || MP-BAIDU -->
  24. <view class="iconfont icondizhi- input_t padding-lr-sm padding-tb-16" @click="choiceMapAddr"></view>
  25. <!-- #endif -->
  26. <!-- #ifdef MP-ALIPAY -->
  27. <view class="iconfont icondizhi- input_t padding-lr-sm padding-tb-16" @click="choiceAlipayMapAddr">
  28. </view>
  29. <!-- #endif -->
  30. </view>
  31. </view>
  32. <view class="row dflex border-line padding-lr">
  33. <text class="tit">详细地址</text>
  34. <input class="input" type="text" v-model="addrData.address" placeholder="请输入详细地址"
  35. placeholder-class="placeholder" />
  36. </view>
  37. <view class="gap"></view>
  38. <view class="row dflex-b padding-lr">
  39. <text class="tit">设为默认</text>
  40. <switch :checked="addrDefault" color="#FF6A6C" @change="switchChange" />
  41. </view>
  42. <view class="padding w-full margin-top">
  43. <view class="dflex-b border-radius-big">
  44. <view class="tac padding-tb-sm flex1 bg-base-a-tijiao" @click="submit">提交</view>
  45. </view>
  46. </view>
  47. </view>
  48. </template>
  49. <script>
  50. import {
  51. addressinfo,
  52. addressadd,
  53. addressupdate
  54. } from '../../../utils/api_user.js'
  55. import useAddress from '../../../components/use-address/use-address.vue'
  56. const __name = 'usemall-member-address';
  57. export default {
  58. components:{
  59. useAddress,
  60. },
  61. data() {
  62. return {
  63. addrDefault: false,
  64. addressName: '请选择地址 | 地图选择',
  65. addrData: {
  66. id:'',
  67. receiverName:'',
  68. phoneNum: '',
  69. address1: '',
  70. province: '',
  71. city: '',
  72. county: '',
  73. address: '',
  74. defaultFlag: 0,
  75. addr_source: '录入',
  76. remark: '家',
  77. longitude: '',
  78. latitude: '',
  79. },
  80. id: 0,
  81. type: 'add',
  82. };
  83. },
  84. onLoad(options) {
  85. console.log(options)
  86. let title = '新增收货人';
  87. if (options.type === 'edit') {
  88. title = '编辑收货人';
  89. this.id = options.id;
  90. // 收货人地址详情
  91. var _self=this
  92. var data=_self.id
  93. addressinfo(data).then((res) => {
  94. if(res.success){
  95. for (let key in _self.addrData) {
  96. _self.addrData[key] = res.data[key];
  97. }
  98. _self.addrDefault = _self.addrData.defaultFlag == '1';
  99. _self.addressName = _self.addrData.province + '-' + _self.addrData.city +
  100. '-' + _self.addrData.county;
  101. return
  102. }
  103. _self.$api.msg(res.msg);
  104. })
  105. } else {
  106. // #ifdef H5 || MP-360 || MP-QQ || MP-TOUTIAO
  107. this.addressName = "请选择地址";
  108. // #endif
  109. }
  110. this.type = options.type || 'add';
  111. uni.setNavigationBarTitle({
  112. title
  113. });
  114. },
  115. methods: {
  116. switchChange(e) {
  117. this.addrDefault = e.detail.value;
  118. },
  119. openAddress() {
  120. this.$refs.useAddress.open();
  121. },
  122. // 选择地址
  123. changeAddr(res) {
  124. let _this = this;
  125. _this.addrData.province = res.labelArr[0] || '';
  126. _this.addrData.city = res.labelArr[1] || '';
  127. _this.addrData.county = res.labelArr[2] || '';
  128. _this.addrData.address1 = res.label;
  129. _this.addressName = _this.addrData.address1;
  130. },
  131. // 选择地图地址
  132. choiceMapAddr(options) {
  133. let _this = this;
  134. uni.authorize({
  135. scope: 'scope.userLocation',
  136. success() {
  137. uni.chooseLocation({
  138. success: res => {
  139. console.log('位置', res);
  140. // console.log('位置名称:' + res.name);
  141. // console.log('详细地址:' + res.address);
  142. // console.log('纬度:' + res.latitude);
  143. // console.log('经度:' + res.longitude);
  144. if (res && res.name) {
  145. let __addr = _this.resolveAddr(res);
  146. _this.addrData.province = __addr.province || '';
  147. _this.addrData.city = __addr.city || '';
  148. _this.addrData.county = __addr.area || '';
  149. _this.addrData.address1 = __addr.addr;
  150. _this.addressName = _this.addrData.address1;
  151. _this.addrData.longitude = res.longitude + '';
  152. _this.addrData.latitude = res.latitude + '';
  153. _this.addrData.address = res.name;
  154. }
  155. },
  156. fail(err) {
  157. console.log(err);
  158. }
  159. });
  160. },
  161. fail(err) {
  162. uni.showModal({
  163. title: '位置未授权,打开设置',
  164. success: function(res) {
  165. if (res.confirm) {
  166. uni.openSetting({});
  167. }
  168. }
  169. });
  170. }
  171. });
  172. },
  173. // #ifdef MP-ALIPAY
  174. // 选择地图地址
  175. choiceAlipayMapAddr(options) {
  176. console.log('open-location', options);
  177. let _this = this;
  178. uni.chooseLocation({
  179. success: res => {
  180. console.log('位置', res);
  181. if (res && res.address1) {
  182. let __addr = _this.resolveAddr(res);
  183. _this.addrData.province = res.provinceName || '';
  184. _this.addrData.city = res.cityName || '';
  185. _this.addrData.county = res.adName || '';
  186. _this.addrData.address1 = [_this.addrData.province, _this.addrData.city, _this.addrData.county]
  187. .filter(x => x).join('-');
  188. _this.addressName = _this.addrData.address1;
  189. _this.addrData.longitude = res.longitude;
  190. _this.addrData.latitude = res.latitude;
  191. _this.addrData.address = res.name || res.address1;
  192. }
  193. },
  194. fail(err) {
  195. console.log(err);
  196. }
  197. });
  198. },
  199. // #endif
  200. // 解析地址
  201. resolveAddr(options) {
  202. let _this = this;
  203. let str = options.address;
  204. let __addr = {
  205. addr: ''
  206. };
  207. let __idx = 0;
  208. let __idx_pro = str.indexOf('省');
  209. if (__idx_pro == -1) {
  210. __idx = str.indexOf('自治区');
  211. if (__idx != -1) {
  212. __addr.province = str.substring(0, __idx + 3);
  213. } else {
  214. __addr.province = str.substring(0, 0);
  215. __idx = 0;
  216. }
  217. } else {
  218. __addr.province = str.substring(0, __idx_pro + 1);
  219. }
  220. if (__addr.province) __addr.addr += __addr.province + '-';
  221. let __idx_city = str.indexOf('市');
  222. if (__idx_city == -1) {
  223. __idx = str.indexOf('自治州');
  224. if (__idx != -1) {
  225. __addr.city = str.substring(__idx_pro + 1, __idx + 3);
  226. } else {
  227. __addr.city = str.substring(__idx + 1, __idx_city + 1);
  228. }
  229. } else {
  230. if (__idx == 0) {
  231. __addr.city = str.substring(__idx_pro + 1, __idx_city + 1);
  232. } else {
  233. __addr.city = str.substring(__idx + 3, __idx_city + 1);
  234. }
  235. }
  236. if (__addr.city) __addr.addr += __addr.city + '-';
  237. let __idx_area = str.lastIndexOf('区');
  238. if (__idx_area == -1) {
  239. __idx_area = str.indexOf('县');
  240. if (__idx == 0) {
  241. __addr.area = str.substring(__idx_city + 1, __idx_area + 1);
  242. } else {
  243. __addr.area = str.substring(__idx + 3, __idx_area + 1);
  244. }
  245. } else {
  246. if (__idx == 0) {
  247. __addr.area = str.substring(__idx_city + 1, __idx_area + 1);
  248. } else {
  249. __addr.area = str.substring(__idx + 3, __idx_area + 1);
  250. }
  251. }
  252. if (__addr.area) __addr.addr += __addr.area;
  253. return __addr;
  254. },
  255. //提交
  256. submit() {
  257. let _self=this
  258. if (_self.addrDefault) {
  259. _self.addrData.defaultFlag = '1';
  260. } else {
  261. _self.addrData.defaultFlag = '0';
  262. }
  263. let data = _self.addrData;
  264. if (!data.receiverName) {
  265. _self.$api.msg('请填写收货人');
  266. return;
  267. }
  268. if (!/(^1[3|4|5|7|8|9][0-9]{9}$)/.test(data.phoneNum)) {
  269. _self.$api.msg('请输入正确的手机号码');
  270. return;
  271. }
  272. if (!data.address) {
  273. _self.$api.msg('请填写详细地址');
  274. return;
  275. }
  276. if (_self.addrDefault) {
  277. // // 把默认为是的改成 否
  278. // _self.$db[__name]
  279. // .where('create_uid == $env.uid && defaultFlag == "1"')
  280. // .update({
  281. // defaultFlag: '0'
  282. // });
  283. }
  284. if (_self.type == 'add') {
  285. if (!data.address1) {
  286. _self.$api.msg('请选择地址');
  287. return;
  288. }
  289. //添加收货地址
  290. addressadd(data).then((res) => {
  291. if(res.success){
  292. _self.$api.msg('添加成功');
  293. _self.$api.timerout(() => {
  294. uni.navigateBack();
  295. }, 100);
  296. return
  297. }
  298. _self.$api.msg(res.msg);
  299. })
  300. } else {
  301. if (!_self.addressName) {
  302. _self.$api.msg('请选择地址');
  303. return;
  304. }
  305. if (!_self.id) {
  306. _self.$api.msg('当前ID异常,编辑失败');
  307. return;
  308. }
  309. //修改收货地址
  310. addressupdate(data).then((res) => {
  311. if(res.success){
  312. _self.$api.msg('编辑成功');
  313. _self.$api.timerout(() => {
  314. uni.navigateBack();
  315. }, 100);
  316. return
  317. }
  318. _self.$api.msg(res.msg);
  319. })
  320. }
  321. }
  322. }
  323. };
  324. </script>
  325. <style lang="scss">
  326. page {
  327. background: $page-color-base;
  328. }
  329. .row {
  330. background: #fff;
  331. position: relative;
  332. height: 110rpx;
  333. .tit {
  334. flex-shrink: 0;
  335. width: 150rpx;
  336. }
  337. .input {
  338. flex: 1;
  339. font-size: 30rpx;
  340. padding-left: 0;
  341. }
  342. .input_t {
  343. color: #333;
  344. }
  345. }
  346. </style>