链街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.

115 lines
4.4 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. <?php
  2. namespace App\Admin\Controllers\v3;
  3. use App\Admin\Actions\Grid\v3\OrderReportLastMonth;
  4. use App\Admin\Actions\Grid\v3\OrderReportLastWeek;
  5. use App\Admin\Actions\Grid\v3\OrderReportToday;
  6. use App\Admin\Actions\Grid\v3\OrderReportYesterday;
  7. use App\Admin\Repositories\v3\OrderReport;
  8. use Dcat\Admin\Grid;
  9. use Dcat\Admin\Controllers\AdminController;
  10. use App\Models\v3\Market as MarketModel;
  11. use Dcat\Admin\Grid\Filter;
  12. class OrderReportController extends AdminController
  13. {
  14. // public static $searchTime = [];
  15. /**
  16. * Make a grid builder.
  17. *
  18. * @return Grid
  19. */
  20. protected function grid()
  21. {
  22. return Grid::make(new OrderReport(), function (Grid $grid) {
  23. $marketList = MarketModel::getMarketArray();
  24. $grid->combine('默认统计今天的数据', ['name', 'value'])->responsive()->help('如果未选择时间,则默认只统计当天的所有市场的数据,特殊:现存用户默认统计所有的数据');
  25. $grid->column('name');
  26. $grid->column('value');
  27. $grid->filter(function (Filter $filter) use($marketList) {
  28. // 更改为 panel 布局
  29. $filter->panel();
  30. $filter->equal('market_id','市场')->select($marketList);
  31. $filter->equal('start_time','开始时间')->date();
  32. $filter->equal('end_time','结束时间')->date();
  33. });
  34. $grid->tools([new OrderReportToday(), new OrderReportYesterday(), new OrderReportLastWeek(), new OrderReportLastMonth()]);
  35. // 每页1条
  36. $grid->paginate(10);
  37. $grid->disableCreateButton();
  38. $grid->disableBatchActions();
  39. $grid->disableBatchDelete();
  40. $grid->toolsWithOutline();
  41. $grid->disableDeleteButton();
  42. $grid->disableEditButton();
  43. $grid->disableQuickEditButton();
  44. $grid->disableViewButton();
  45. $grid->disableActions();
  46. $grid->disableRowSelector();
  47. });
  48. }
  49. /**
  50. * 获取一个时间段内的日期
  51. */
  52. public function periodDateArr($start_time,$end_time){
  53. $start_time = strtotime($start_time);
  54. $end_time = strtotime($end_time);
  55. $i=0;
  56. $arr = [];
  57. while ($start_time<=$end_time){
  58. $arr[date('Y-m-d',$start_time)]=date('Y年m月d日',$start_time);
  59. $start_time = strtotime('+1 day',$start_time);
  60. $i++;
  61. }
  62. return array_reverse($arr);
  63. // $grid->selector(function (Grid\Tools\Selector $selector) {
  64. // $today = date('Y-m-d');
  65. // $selector->selectOne('time', '选择日期', ['today'=>'今日', 'yesterday'=>'昨日', 'last_week'=>'上周','last_month'=>'上月'], function($query, $value) use($today){
  66. // $where = [];
  67. // switch($value){
  68. // case 'today':
  69. // $where['start_time'] = $today;
  70. // $where['end_time'] = $today;
  71. // break;
  72. // case 'yesterday':
  73. // $yesterday = date("Y-m-d",strtotime("-1 days",strtotime($today)));
  74. // $where['start_time'] = $yesterday;
  75. // $where['end_time'] = $yesterday;
  76. // break;
  77. // case 'last_week':
  78. // //上周日
  79. // $lastSunday = date('Y-m-d', strtotime('-1 sunday', time()));
  80. // // 上周一
  81. // $lastMonday = date('Y-m-d', strtotime('-1 monday', strtotime($lastSunday)));
  82. // $where['start_time'] = $lastMonday;
  83. // $where['end_time'] = $lastSunday;
  84. // break;
  85. // case 'last_month':
  86. // //上月初
  87. // $lastMonthStart = date('Y-m-d', strtotime('-1 month', strtotime(date('Y-m', time()) . '-01')));
  88. // // 上月底
  89. // $lastMonthEnd = date('Y-m-d', strtotime(date('Y-m', time()) . '-01') - 86400);
  90. // $where['start_time'] = $lastMonthStart;
  91. // $where['end_time'] = $lastMonthEnd;
  92. // break;
  93. // }
  94. // self::$searchTime = $where;
  95. // });
  96. // });
  97. }
  98. }