Dashboard.php 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <?php
  2. namespace app\admin\controller\exam;
  3. use addons\exam\enum\CommonStatus;
  4. use addons\exam\enum\RoomSignupStatus;
  5. use addons\exam\model\UserModel;
  6. use app\admin\model\exam\GradeModel;
  7. use app\admin\model\exam\PaperModel;
  8. use app\admin\model\exam\QuestionModel;
  9. use app\admin\model\exam\RoomGradeModel;
  10. use app\admin\model\exam\RoomModel;
  11. use app\admin\model\exam\RoomSignupModel;
  12. use app\common\controller\Backend;
  13. use fast\Date;
  14. /**
  15. * 控制台
  16. * @icon fa fa-dashboard
  17. * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
  18. */
  19. class Dashboard extends Backend
  20. {
  21. /**
  22. * 查看
  23. */
  24. public function index()
  25. {
  26. try {
  27. \think\Db::execute("SET @@sql_mode='';");
  28. } catch (\Exception $e) {
  29. }
  30. $column = [];
  31. $start_time = Date::unixtime('day', -6);
  32. $end_time = Date::unixtime('day', 0, 'end');
  33. $join_list = UserModel::where('jointime', 'between time', [$start_time, $end_time])
  34. ->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date')
  35. ->group('join_date')
  36. ->select();
  37. for ($time = $start_time; $time <= $end_time;) {
  38. $column[] = date("Y-m-d", $time);
  39. $time += 86400;
  40. }
  41. $user_list = array_fill_keys($column, 0);
  42. foreach ($join_list as $k => $v) {
  43. $user_list[$v['join_date']] = $v['nums'];
  44. }
  45. $today_time = Date::unixtime('day', 0, 'begin');
  46. $this->view->assign([
  47. // 用户总数
  48. 'total_user_count' => UserModel::count(),
  49. // 今日新增用户数
  50. 'today_user_count' => UserModel::where('createtime', '>', $today_time)->count(),
  51. // 总题数
  52. 'total_question_count' => QuestionModel::where('status', CommonStatus::NORMAL)->count(),
  53. // 总试卷数
  54. 'total_paper_count' => PaperModel::where('status', CommonStatus::NORMAL)->count(),
  55. // 总考场数
  56. 'total_room_count' => RoomModel::where('status', CommonStatus::NORMAL)->count(),
  57. // 总参与考试次数
  58. 'total_exam_user_count' => GradeModel::count(),
  59. // 今日参与考试次数
  60. 'today_exam_user_count' => GradeModel::where('createtime', '>', $today_time)->count(),
  61. // 总参与考场考试次数
  62. // 'total_room_user_count' => RoomGradeModel::count(),
  63. // 今日参与考场考试次数
  64. // 'today_room_user_count' => RoomGradeModel::where('createtime', '>', $today_time)->count(),
  65. // 待处理报名数量
  66. // 'total_wait_apply_signup_count' => RoomSignupModel::where('status', RoomSignupStatus::WAIT)->count(),
  67. ]);
  68. $this->assignconfig('column', array_keys($user_list));
  69. $this->assignconfig('user_data', array_values($user_list));
  70. return $this->view->fetch();
  71. }
  72. }