Address.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. <?php
  2. namespace Passport\Src;
  3. use Dever;
  4. use Passport\Lib\Base;
  5. class Address extends Base
  6. {
  7. # 获取默认地址
  8. public function getDefaultAddress($uid)
  9. {
  10. $where['uid'] = $uid;
  11. $where['type'] = 2;
  12. $data = Dever::db('passport/address')->one($where);
  13. return $data;
  14. }
  15. # 获取某个收货地址
  16. public function getOne($uid, $id)
  17. {
  18. $where['uid'] = $uid;
  19. $where['id'] = $id;
  20. $data = Dever::db('passport/address')->find($where);
  21. if ($data && Dever::project('area')) {
  22. $data = $this->getInfo($data);
  23. }
  24. return $data;
  25. }
  26. # 获取地址列表
  27. public function getAddress($uid)
  28. {
  29. $where['uid'] = $uid;
  30. $data = Dever::db('passport/address')->getList($where);
  31. if ($data && Dever::project('area')) {
  32. foreach ($data as $k => $v) {
  33. $data[$k] = $this->getInfo($v);
  34. }
  35. }
  36. return $data;
  37. }
  38. private function getInfo($data)
  39. {
  40. $data['address_info'] = $data['add_string'] = $data['address'] . $data['house_number'];
  41. $data['province_name'] = $data['city_name'] = $data['county_name'] = '';
  42. if ($data['province'] && $data['city'] && $data['county']) {
  43. $info = Dever::db('area/province')->find($data['province']);
  44. $data['province_name'] = $info['name'];
  45. $info = Dever::db('area/city')->find($data['city']);
  46. $data['city_name'] = $info['name'];
  47. $info = Dever::db('area/county')->find($data['county']);
  48. $data['county_name'] = $info['name'];
  49. //$data['address_info'] = $data['province_name'] . $data['city_name'] . $data['county_name'] .','. $data['address'] .','. $data['house_number'];
  50. $data['add_string'] = $data['province_name'] . $data['city_name'] . $data['county_name'] .','. $data['address'] .','. $data['house_number'] .','. $data['contact'] .','. $data['mobile'];
  51. }
  52. return $data;
  53. }
  54. # 删除和恢复
  55. public function del($uid, $id, $state = 2)
  56. {
  57. $info = $this->getOne($uid, $id);
  58. if ($info) {
  59. $update['where_id'] = $info['id'];
  60. $update['state'] = $state;
  61. Dever::db('passport/address')->update($update);
  62. } else {
  63. Dever::alert('更新失败');
  64. }
  65. return 'ok';
  66. }
  67. # 添加或者更新地址接口
  68. public function up()
  69. {
  70. $uid = $this->check();
  71. $id = Dever::input('id');
  72. $type = Dever::input('type', 2);
  73. $province = Dever::input('province');
  74. $city = Dever::input('city');
  75. $county = Dever::input('county');
  76. $contact = Dever::input('contact');
  77. $address = Dever::input('address');
  78. $country = Dever::input('country');
  79. $mobile = Dever::input('mobile');
  80. $sex = Dever::input('sex');
  81. $house_number = Dever::input('house_number');
  82. $tag = Dever::input('tag');
  83. return $this->upAddress($id, $uid, $type, $mobile, $contact, $province, $city, $county, $address, $country, $sex, $house_number, $tag);
  84. }
  85. # 添加或者更新地址
  86. public function upAddress($id, $uid, $type = 2, $mobile, $contact, $province = '', $city = '', $county = '', $address = '', $country = '', $sex = '', $house_number = '', $tag = '')
  87. {
  88. if ($contact) {
  89. $update['contact'] = $contact;
  90. }
  91. if ($country) {
  92. $update['country'] = $country;
  93. }
  94. if ($mobile) {
  95. $update['mobile'] = $mobile;
  96. }
  97. if ($province) {
  98. $update['province'] = $province;
  99. }
  100. if ($city) {
  101. $update['city'] = $city;
  102. }
  103. if ($county) {
  104. $update['county'] = $county;
  105. }
  106. if ($province && $city && $county) {
  107. $update['area'] = $province . ',' . $city . ',' . $county;
  108. }
  109. $update['type'] = $type;
  110. if ($address) {
  111. $update['address'] = $address;
  112. }
  113. if ($sex) {
  114. $update['sex'] = $sex;
  115. }
  116. if ($house_number) {
  117. $update['house_number'] = $house_number;
  118. }
  119. if ($tag) {
  120. $update['tag'] = $tag;
  121. }
  122. if ($type == 2) {
  123. Dever::db('passport/address')->updateType(array('where_type' => 2, 'set_type' => 1));
  124. }
  125. if ($id) {
  126. $update['where_id'] = $id;
  127. Dever::db('passport/address')->update($update);
  128. } else {
  129. $update['uid'] = $uid;
  130. $id = Dever::db('passport/address')->insert($update);
  131. }
  132. return $id;
  133. }
  134. }