CityArea.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\model\system;
  12. use qiniu\basic\BaseModel;
  13. use qiniu\traits\ModelTrait;
  14. use think\model\relation\HasMany;
  15. /**
  16. * 城市数据(包含街道)
  17. * Class CityArea
  18. * @package app\model\other
  19. */
  20. class CityArea extends BaseModel
  21. {
  22. use ModelTrait;
  23. /**
  24. * @var string
  25. */
  26. protected $name = 'city_area';
  27. /**
  28. * @var string
  29. */
  30. protected $key = 'id';
  31. protected $order = 'id asc';
  32. /**
  33. * @return HasMany
  34. */
  35. public function children()
  36. {
  37. return $this->hasMany(self::class, 'parent_id', 'id');
  38. }
  39. /**
  40. * @param array $where
  41. * @return \think\Model|null
  42. */
  43. public function search(array $where = [])
  44. {
  45. return parent::search($where)->when(isset($where['pid']) && $where['pid'] !== '', function ($query) use ($where) {
  46. $query->where('parent_id', $where['pid']);
  47. })->when(isset($where['address']) && $where['address'] !== '', function ($query) use ($where) {
  48. $address = explode('/', trim($where['address'], '/'));
  49. if (isset($address[0]) && isset($address[1]) && $address[0] == $address[1]) {//直辖市:北京市北京市朝阳区
  50. array_shift($address);
  51. }
  52. $p = array_shift($address);
  53. if (mb_strlen($p) - 1 === mb_strpos($p, '市')) {
  54. $p = mb_substr($p, 0, -1);
  55. } elseif (mb_strlen($p) - 1 === mb_strpos($p, '省')) {
  56. $p = mb_substr($p, 0, -1);
  57. } elseif (mb_strlen($p) - 3 === mb_strpos($p, '自治区')) {
  58. $p = mb_substr($p, 0, -3);
  59. }
  60. $pcity = $this->getModel()->where('name', $p)->value('id');
  61. $path = ['', $pcity];
  62. $street = $p;
  63. $i = 0;
  64. foreach ($address as $item) {
  65. //县级市,只有三级地址;市和县相同
  66. if ($item == ($address[$i-1] ?? '')) continue;
  67. $pcity = $this->getModel()->whereLike('path', implode('/', $path) . '/%')->where('name', $item)->value('id');
  68. if (!$pcity) {
  69. break;
  70. }
  71. $path[] = $pcity;
  72. $street = $item;
  73. $i++;
  74. }
  75. array_pop($path);
  76. $query->whereLike('path', implode('/', $path) . '/%')->where('name', $street);
  77. });
  78. }
  79. }