ShopCriteria.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <?php
  2. namespace App\Repositories\Criteria;
  3. use App\Models\Device;
  4. use App\Models\Role;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. use Prettus\Repository\Contracts\CriteriaInterface;
  8. use Prettus\Repository\Contracts\RepositoryInterface;
  9. class ShopCriteria extends RequestCriteria implements CriteriaInterface
  10. {
  11. /**
  12. * @var \Illuminate\Http\Request
  13. */
  14. protected $request;
  15. public function __construct(Request $request)
  16. {
  17. $this->request = $request;
  18. }
  19. /**
  20. * @inheritDoc
  21. */
  22. public function apply($model, RepositoryInterface $repository)
  23. {
  24. if ($name = $this->request->get('name', false)) {
  25. $model = $model->where('name', 'like', "%{$name}%");
  26. }
  27. if ($this->request->filled('lat') && $this->request->filled('lng')) {
  28. $lat = $this->request->get('lat');
  29. $lng = $this->request->get('lng');
  30. $model = $model->select(['*', DB::raw("ACOS(SIN(({$lat} * 3.1415) / 180 ) *SIN((lat* 3.1415) / 180 ) +
  31. COS(({$lat} * 3.1415) / 180 ) * COS((lat* 3.1415) / 180 ) *COS(({$lng} * 3.1415) / 180
  32. - (lng* 3.1415) / 180 ) ) * 6380 as distance")])->orderBy('distance', 'asc');
  33. }
  34. //管理员
  35. if (is_admin_login()) {
  36. $admin = login_admin();
  37. switch ($admin->type) {
  38. case Role::Merchants:
  39. $model = $model->where('admin_id', $admin->id);
  40. break;
  41. case Role::Invest:
  42. case Role::Agency:
  43. $ids = Device::query()->where('merchant_id', $admin->id)->orWhere('agency_id', $admin->id)->orWhere('invest_id', $admin->id)->pluck('shop_id')->toArray();
  44. $model = $model->where(function ($query) use ($ids, $admin) {
  45. return $query->whereIn('id', $ids)->orWhere('admin_id', $admin->id);
  46. });
  47. break;
  48. }
  49. }
  50. return parent::apply($model, $repository);
  51. }
  52. }