HomeController.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. <?php
  2. namespace App\Community\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\Order;
  5. use App\Models\Schedule;
  6. use App\Models\SchedulePeriod;
  7. use Encore\Admin\Controllers\Dashboard;
  8. use Encore\Admin\Facades\Admin;
  9. use Encore\Admin\Layout\Column;
  10. use Encore\Admin\Layout\Content;
  11. use Encore\Admin\Layout\Row;
  12. use Encore\Admin\Widgets\InfoBox;
  13. class HomeController extends Controller
  14. {
  15. public function index(){
  16. return redirect('/cdms/home');
  17. }
  18. public function home(Content $content)
  19. {
  20. if(!Admin::user()->inroles(['administrator','manager'])){
  21. return redirect('/cdms/notices');
  22. }
  23. return $content
  24. ->title('数据概况')
  25. ->description('社区段实时数据')
  26. ->row(function (Row $row){
  27. return $row->column(12,'<p style="font-family:Arial,Helvetica,sans-serif; font-size:1.2em; margin-top20px;vertical-align:middle; font-weight:normal ">实时概况</p>');
  28. })
  29. ->row(function (Row $row){
  30. $data = StatController::service();
  31. $row->column(3,new InfoBox('今日预约数量(人次)', 'users', 'aqua', '/cdms/home', $data['schedule_paitent']));
  32. $row->column(3,new InfoBox('今日排班(人)', 'calendar-check-o', 'aqua', '/cdms/home', $data['schedule_docter']));
  33. $row->column(3,new InfoBox('接诊患者(人次)', 'user', 'aqua', '/cdms/home', $data['paitent_num']));
  34. })
  35. ->row(function (Row $row){
  36. return $row->column(12,'<p style="font-family:Arial,Helvetica,sans-serif; font-size:1.2em; margin-top20px;vertical-align:middle; font-weight:normal ">疫苗概况</p>');
  37. })
  38. ->row(function (Row $row){
  39. $data = StatController::vaccine();
  40. $row->column(3,new InfoBox('今日预约数量(人次)', 'users', 'aqua', '/cdms/home', $data['schedule_paitent']));
  41. // $row->column(3,new InfoBox('疫苗种类(种)', 'eyedropper', 'aqua', '/cdms/home', $data['sum_num']));
  42. $row->column(3,new InfoBox('疫苗库存量)', 'home', 'aqua', '/cdms/home', $data['have_num']));
  43. $row->column(3,new InfoBox('疫苗库存告急(种)', 'genderless', 'aqua', '/cdms/home', $data['less_num']));
  44. })
  45. ->row(function (Row $row){
  46. $data = StatController::vaccine();
  47. $row->column(3,new InfoBox('昨日接种量(人次)', 'genderless', 'aqua', '/cdms/home', $data['less_num']));
  48. $row->column(3,new InfoBox('明日预约量(人次)', 'genderless', 'aqua', '/cdms/home', $data['less_num']));
  49. // $row->column(3,new InfoBox('今日预约(人支)', 'hospital-o', 'aqua', '/cdms/home', $data['today_schedule']));
  50. // $row->column(3,new InfoBox('预计今日消耗(支)', 'calendar', 'aqua', '/cdms/home', $data['today_vaccine']));
  51. })
  52. ->row(function (Row $row){
  53. return $row->column(12,'<p style="font-family:Arial,Helvetica,sans-serif; font-size:1.2em; margin-top20px;vertical-align:middle; font-weight:normal ">订单概况</p>');
  54. })
  55. ->row(function (Row $row){
  56. $data = StatController::nurse();
  57. $row->column(3,new InfoBox('门诊订单(个)', 'first-order', 'aqua', '/cdms/home', $data[0]));
  58. $row->column(3,new InfoBox('计免订单(个)', 'first-order', 'aqua', '/cdms/home', $data[1]));
  59. $row->column(3,new InfoBox('儿保订单(个)', 'first-order', 'aqua', '/cdms/home', $data[2]));
  60. })
  61. ->row(function (Row $row){
  62. return $row->column(12,'<p style="font-family:Arial,Helvetica,sans-serif; font-size:1.2em; margin-top20px;vertical-align:middle; font-weight:normal ">今日排班 </p>');
  63. })
  64. ->row(function (Row $row){
  65. $data = StatController::schedule();
  66. $row->column(3,new InfoBox('计免医生(人)', 'hospital-o', 'aqua', '/cdms/home', $data['vaccine_num']));
  67. $row->column(3,new InfoBox('儿保医生(人)', 'hospital-o', 'aqua', '/cdms/home', $data['nurse_num']));
  68. $row->column(3,new InfoBox('门诊医生(人)', 'hospital-o', 'aqua', '/cdms/home', $data['clinic_num']));
  69. });
  70. // ->row($this->real_data())
  71. // ->row($this->vaccine_data())
  72. // ->row($this->nurse_data())
  73. // ->row($this->schedule_data());
  74. }
  75. //1. 门诊预约
  76. //(1) 今日预约数量
  77. //(2) 今日排班(人)
  78. //(3) 昨日预约数
  79. //(4) 昨日接诊人数
  80. //2. 计免预约
  81. //(1) 今日预约数量(人次)
  82. //(2) 疫苗库存量
  83. //(3) 疫苗库存告急(种)
  84. //(4) 昨日接种量(人次)
  85. //(5) 明日预约量(人次)
  86. //3. 儿保预约
  87. //(1) 今日预约数量(人次)
  88. //(2) 昨日预约数量(人次)
  89. //(3) 昨日服务数量(人次)
  90. //(4) 明日预约数量(人次)
  91. public function real_data()
  92. {
  93. $data = StatController::service();
  94. return view('cdms.real_data',compact('data'));
  95. }
  96. public function vaccine_data()
  97. {
  98. $data = StatController::vaccine();
  99. return view('cdms.vaccine_data',compact('data'));
  100. }
  101. public function nurse_data()
  102. {
  103. $data = StatController::nurse();
  104. return view('cdms.nurse_data',compact('data'));
  105. }
  106. public function schedule_data()
  107. {
  108. $data = StatController::schedule();
  109. return view('cdms.schedule_data',compact('data'));
  110. }
  111. public function order_detail()
  112. {
  113. $id = request('id');
  114. if(empty($id)){
  115. return redirect('/cdms/docter_chats');
  116. }
  117. $data = Order::where('id',$id)->with('orderPatient')->first();
  118. if(!empty($data->orderPatient->medical_imgs)){
  119. $data->orderPatient->medical_imgs = object_array(json_decode($data->orderPatient->medical_imgs ));
  120. } else {
  121. $data->orderPatient->medical_imgs = [];
  122. }
  123. $content = new Content();
  124. $status = Order::getStatus();
  125. $content->view('cdms.order_detail',compact('data','status'));
  126. return $content;
  127. }
  128. public function schedule(){
  129. $time = redirect('time');
  130. $time = '2020-12-07至2020-12-13';
  131. $data = sechedule_timeperiod();
  132. $org_id = Admin::user()->org_id;
  133. $where = [];
  134. if($org_id){
  135. $where['organization_id'] = $org_id;
  136. }
  137. if($time){
  138. } else {
  139. $where['schedule_date']=date('Y-m-d',strtotime('this week'));
  140. }
  141. Schedule::where($where)->pluck('id');
  142. }
  143. }