链街Dcat后台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

101 lines
3.8 KiB

  1. <?php
  2. namespace App\Admin\Renderable;
  3. use Dcat\Admin\Grid;
  4. use Dcat\Admin\Grid\LazyRenderable;
  5. use App\Models\ImsCjdcOrderMain as OrderMainModel;
  6. use App\Models\v3\Market as MarketModel;
  7. class OrderDeliveryById extends LazyRenderable
  8. {
  9. protected $title = '配送记录';
  10. public function grid(): Grid
  11. {
  12. // 获取外部传递的参数
  13. $horsemanId = $this->horseman_id ?? 0;
  14. $startTime = $this->start_time ?? null;
  15. $endTime = $this->end_time ?? null;
  16. $marketId = $this->market_id ?? 0;
  17. if(empty($startTime) && empty($endTime)){
  18. $startTime = date('Y-m-d', time());
  19. $endTime = date('Y-m-d', time());
  20. }
  21. $model = OrderMainModel::where('type', OrderMainModel::ORDER_TYPE_ONLINE)
  22. ->where('shipping_type', OrderMainModel::ORDER_SHIPPING_TYPE_MARKET)
  23. ->whereIn('state',OrderMainModel::ORDER_STATE_FINISH)
  24. ->where('created_at','>=',strtotime('2020-10-01 00:00:00'));;
  25. if($horsemanId > 0){
  26. $model->where('horseman_id',$horsemanId);
  27. }
  28. if($startTime){
  29. $startTime = $startTime.' 00:00:00';
  30. $model->where('created_at','>=',strtotime($startTime));
  31. }
  32. if($endTime){
  33. $endTime = $endTime.' 23:59:59';
  34. $model->where('created_at','<=',strtotime($endTime));
  35. }
  36. if($marketId > 0){
  37. $model->where('market_id',$marketId);
  38. }
  39. return Grid::make($model, function (Grid $grid) use($marketId){
  40. $marketList = MarketModel::getMarketArray();
  41. $grid->column('global_order_id','订单编号');
  42. $grid->column('market_id','下单市场')->display(function($marketId) use($marketList){
  43. return $marketList[$marketId] ?? '';
  44. });
  45. $grid->column('state','状态')
  46. ->using(
  47. OrderMainModel::STATE_LIST
  48. );
  49. $grid->column('created_at','下单时间')->display(function($createdAt){
  50. return date('Y-m-d H:i:s',$createdAt);
  51. });
  52. // 搜索
  53. $grid->filter(function (Grid\Filter $filter) use($marketList, $marketId){
  54. $filter->equal('user_id','下单用户懒ID')->width(3);
  55. $filter->equal('global_order_id','订单编号')->width(3);
  56. if(!$marketId){
  57. $filter->equal('market_id','下单市场')->select($marketList)->width(4);
  58. }
  59. $filter->whereBetween('created_at',function($q){
  60. $start = $this->input['start'] ?? null;
  61. $end = $this->input['end'] ?? null;
  62. if($start !== null){
  63. $q->where('created_at','>=',strtotime($start));
  64. }
  65. if($end !== null){
  66. $q->where('created_at','<=',strtotime($end));
  67. }
  68. })->datetime()->width(7);
  69. });
  70. $grid->model()->orderBy('id','desc');
  71. // 每页10条
  72. $grid->paginate(10);
  73. $grid->disableActions();
  74. $grid->disableRowSelector();
  75. });
  76. }
  77. public function default()
  78. {
  79. // 获取外部传递的参数
  80. $horsemanId = $this->payload['horseman_id'] ?? 0;
  81. $startTime = $this->payload['start_time'] ?? request()->input('start_time', null);
  82. $endTime = $this->payload['end_time'] ?? request()->input('end_time', null);
  83. $marketId = $this->payload['market_id'] ?? 0;
  84. return [
  85. 'horseman_id' => $horsemanId,
  86. 'start_time' => $startTime,
  87. 'end_time' => $endTime,
  88. 'market_id' => $marketId,
  89. ];
  90. }
  91. }