CheckCardController.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Models\CheckCard;
  4. use App\Models\Student;
  5. use Carbon\Carbon;
  6. use Illuminate\Http\Request;
  7. class CheckCardController extends Controller
  8. {
  9. protected $redirect_index = '/admin/CheckCard/index';
  10. protected $view_path = 'admin.check-cards.';
  11. protected $pre_uri = '/admin/CheckCard/';
  12. protected $model_name = '打卡';
  13. protected $model;
  14. public function __construct()
  15. {
  16. parent::__construct();
  17. $this->model = new CheckCard();
  18. }
  19. public function index(Request $request)
  20. {
  21. $list = $this->model->where('id', '>', 0)->orderBy('created_at', 'desc')->get();
  22. if(!empty($request->input('keyword')) && !empty(trim($request->input('keyword')))) {
  23. $keyword = trim($request->input('keyword'));
  24. $list = $list->filter(function ($value) use($keyword) {
  25. if(!empty($value->student) && !(strpos($value->student->name, $keyword) === false)) {
  26. return true;
  27. }
  28. if(!empty($value->course) && !(strpos($value->course->name, $keyword) === false)) {
  29. return true;
  30. }
  31. return false;
  32. });
  33. }
  34. if(!empty($request->input('begin_date'))) {
  35. $begin_date_time = Carbon::createFromTimestamp(strtotime($request->input('begin_date')))->toDateTimeString();
  36. } else {
  37. $begin_date_time = Carbon::now()->subYears(10)->toDateTimeString();
  38. }
  39. if(!empty($request->input('end_date'))) {
  40. $end_date_time = Carbon::createFromTimestamp(strtotime($request->input('end_date')))->addDay()->toDateTimeString();
  41. } else {
  42. $end_date_time = Carbon::now()->addYears(10)->toDateTimeString();
  43. }
  44. if(!empty($begin_date_time) || !empty($end_date_time)) {
  45. $list = $list->filter(function ($value) use($begin_date_time, $end_date_time) {
  46. return $value->begin_date_time >= $begin_date_time && $value->end_date_time < $end_date_time;
  47. });
  48. }
  49. $list = $this->paginate($list);
  50. foreach($list as $item) {
  51. $item->duration = $item->getDuration();
  52. }
  53. list($pre_uri, $model_name) = array($this->pre_uri, $this->model_name);
  54. return view($this->view_path . 'index', compact('list', 'pre_uri', 'model_name'));
  55. }
  56. public function rank(Request $request)
  57. {
  58. $students = Student::all();
  59. foreach($students as $student) {
  60. $tmp = $student->getCheckCardTime($request->input('begin_date'), $request->input('end_date'));
  61. $student->total = (int)$tmp['total'];
  62. $student->totalHuman = $tmp['totalHuman'];
  63. $student->courseName = $student->getCourseName();
  64. }
  65. $students = $students->sortByDesc('total');
  66. $rank = 0;
  67. foreach($students as $student) {
  68. $student->rank = ++$rank;
  69. }
  70. $list = $this->paginate($students);
  71. list($pre_uri, $model_name) = array($this->pre_uri, $this->model_name);
  72. return view($this->view_path . 'rank', compact('list', 'pre_uri', 'model_name'));
  73. }
  74. }