Rescue.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <?php
  2. namespace app\common\model;
  3. use app\admin\model\user\UserExt;
  4. use liuniu\BaseModel;
  5. use think\Exception;
  6. use think\Model;
  7. class Rescue extends BaseModel
  8. {
  9. // 表名
  10. protected $name = 'rescue';
  11. // 自动写入时间戳字段
  12. protected $autoWriteTimestamp = false;
  13. // 定义时间戳字段名
  14. protected $createTime = false;
  15. protected $updateTime = false;
  16. protected $deleteTime = false;
  17. // 追加属性
  18. protected $append = [
  19. 'work_week_text',
  20. 'status_text'
  21. ];
  22. public function getWorkWeekList()
  23. {
  24. return ['1' => __('Work_week 1'), '2' => __('Work_week 2'), '3' => __('Work_week 3'), '4' => __('Work_week 4'), '5' => __('Work_week 5'), '6' => __('Work_week 6'), '7' => __('Work_week 7')];
  25. }
  26. public function getStatusList()
  27. {
  28. return ['0' => __('Status 0'), '1' => __('Status 1'), '-1' => __('Status -1')];
  29. }
  30. public function getWorkWeekTextAttr($value, $data)
  31. {
  32. $value = $value ? $value : (isset($data['work_week']) ? $data['work_week'] : '');
  33. $valueArr = explode(',', $value);
  34. $list = $this->getWorkWeekList();
  35. return implode(',', array_intersect_key($list, array_flip($valueArr)));
  36. }
  37. public function getStatusTextAttr($value, $data)
  38. {
  39. $value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
  40. $list = $this->getStatusList();
  41. return isset($list[$value]) ? $list[$value] : '';
  42. }
  43. protected function setWorkWeekAttr($value)
  44. {
  45. return is_array($value) ? implode(',', $value) : $value;
  46. }
  47. /**
  48. * 获取排序sql
  49. * @param $latitude
  50. * @param $longitude
  51. * @return mixed
  52. */
  53. public static function distanceSql($latitude, $longitude)
  54. {
  55. $field = "(round(6367000 * 2 * asin(sqrt(pow(sin(((latitude * pi()) / 180 - ({$latitude} * pi()) / 180) / 2), 2) + cos(({$latitude} * pi()) / 180) * cos((latitude * pi()) / 180) * pow(sin(((longitude * pi()) / 180 - ({$longitude} * pi()) / 180) / 2), 2))))) AS distance";
  56. return $field;
  57. }
  58. /**
  59. * 门店列表
  60. * @return mixed
  61. */
  62. public static function lst($cid,$latitude, $longitude, $page, $limit,$user_id=0,$status=1,$type=0)
  63. {
  64. $model = new self();
  65. if($status>-2) $model = $model->where('status', $status);
  66. $model = $model->where('cid',$cid);
  67. if($type==0) {
  68. if ($user_id > 0) $model = $model->where('user_id', $user_id);
  69. }else{
  70. $model = $model->where('user_id','<>', $user_id);
  71. }
  72. if ($latitude && $longitude) {
  73. $model = $model->field(['*', self::distanceSql($latitude, $longitude)])->order('distance asc');
  74. }
  75. $list = $model->page((int)$page, (int)$limit)
  76. ->select();
  77. if ($latitude && $longitude) {
  78. foreach ($list as &$value) {
  79. //计算距离
  80. $value['distance'] = self::getDistance($latitude, $longitude, $value['latitude'], $value['longitude']);
  81. //转换单位
  82. $value['range'] = bcdiv($value['distance'], 1000, 1);
  83. $sp = SosBill::where('user_id',$user_id)->where('rescuers_id',$value['id'])->whereTime('createtime',"today")->find();
  84. $value['is_create'] =$sp?1:0;
  85. }
  86. }
  87. return $list;
  88. }
  89. public static function getDistance($lat1, $lng1, $lat2, $lng2)
  90. {
  91. $earthRadius = 6367000; //approximate radius of earth in meters
  92. $lat1 = ($lat1 * pi() ) / 180;
  93. $lng1 = ($lng1 * pi() ) / 180;
  94. $lat2 = ($lat2 * pi() ) / 180;
  95. $lng2 = ($lng2 * pi() ) / 180;
  96. $calcLongitude = $lng2 - $lng1;
  97. $calcLatitude = $lat2 - $lat1;
  98. $stepOne = pow(sin($calcLatitude / 2), 2) + cos($lat1) * cos($lat2) * pow(sin($calcLongitude / 2), 2);
  99. $stepTwo = 2 * asin(min(1, sqrt($stepOne)));
  100. $calculatedDistance = $earthRadius * $stepTwo;
  101. return round($calculatedDistance);
  102. }
  103. public static function create1($data)
  104. {
  105. self::startTrans();
  106. try {
  107. $user = UserExt::where('user_id', $data['user_id'])->find();
  108. if (!$user) {
  109. UserExt::create(['full_name' => $data['name'], 'cid' => $data['cid'], 'address' => $data['address'], 'user_id' => $data['user_id']]);
  110. } else {
  111. $ext = null;
  112. if (!$user['full_name']) $ext['full_name'] = $data['name'];
  113. if (!$user['address']) $ext['address'] = $data['address'];
  114. if ($ext) UserExt::where('user_id')->update($ext);
  115. }
  116. $rs = self::create($data);
  117. self::commit();
  118. return $rs;
  119. }catch (Exception $e)
  120. {
  121. return self::setErrorInfo($e->getMessage(),true);
  122. }
  123. }
  124. public static function getuserId($id)
  125. {
  126. return self::where('id',$id)->value('user_id');
  127. }
  128. }