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