HomeController.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  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::orderTotal();
  31. $row->column(3,new InfoBox('门诊订单总数(个)', 'users', 'aqua', '/cdms/home', $data[0]));
  32. $row->column(3,new InfoBox('儿保订单总数(个)', 'calendar-check-o', 'aqua', '/cdms/home', $data[1]));
  33. $row->column(3,new InfoBox('计免订单总数(个)', 'user', 'aqua', '/cdms/home', $data[2]));
  34. $row->column(3,new InfoBox('服务患者次数(次)', 'user', 'aqua', '/cdms/home', $data[3]));
  35. })
  36. ->row(function (Row $row){
  37. 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>');
  38. })
  39. ->row(function (Row $row){
  40. $data = StatController::clinc();
  41. $row->column(3,new InfoBox('今日预约数量(人)', 'users', 'aqua', '/cdms/home', $data['today']));
  42. // $row->column(3,new InfoBox('疫苗种类(种)', 'eyedropper', 'aqua', '/cdms/home', $data['sum_num']));
  43. $row->column(3,new InfoBox('今日排班人数(人)', 'home', 'aqua', '/cdms/home', $data['docters']));
  44. $row->column(3,new InfoBox('昨日预约数量(人)', 'genderless', 'aqua', '/cdms/home', $data['yesterday']));
  45. $row->column(3,new InfoBox('昨日接诊人数(人)', 'genderless', 'aqua', '/cdms/home', $data['people']));
  46. })
  47. ->row(function (Row $row){
  48. 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>');
  49. })
  50. ->row(function (Row $row){
  51. $data = StatController::nurse();
  52. $row->column(3,new InfoBox('今日预约数量(人)', 'first-order', 'aqua', '/cdms/home', $data['today']));
  53. $row->column(3,new InfoBox('昨日预约数量(人)', 'first-order', 'aqua', '/cdms/home', $data['yesterday']));
  54. $row->column(3,new InfoBox('昨日接种人数(人)', 'first-order', 'aqua', '/cdms/home', $data['people']));
  55. $row->column(3,new InfoBox('明日预约数量(人)', 'first-order', 'aqua', '/cdms/home', $data['tomorrow']));
  56. })
  57. ->row(function (Row $row){
  58. 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>');
  59. })
  60. ->row(function (Row $row){
  61. $data = StatController::nurse();
  62. $row->column(3,new InfoBox('今日预约数量(人)', 'first-order', 'aqua', '/cdms/home', $data['today']));
  63. $row->column(3,new InfoBox('昨日预约数量(人)', 'first-order', 'aqua', '/cdms/home', $data['yesterday']));
  64. $row->column(3,new InfoBox('昨日接种人数(人)', 'first-order', 'aqua', '/cdms/home', $data['people']));
  65. $row->column(3,new InfoBox('明日预约数量(人)', 'first-order', 'aqua', '/cdms/home', $data['tomorrow']));
  66. })
  67. ->row(function (Row $row){
  68. 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>');
  69. })
  70. ->row(function (Row $row){
  71. $data = StatController::vaccineToal();
  72. $row->column(3,new InfoBox('疫苗总库存(支)', 'first-order', 'aqua', '/cdms/home', $data['have_num']));
  73. $row->column(3,new InfoBox('疫苗库存告急(中)', 'first-order', 'aqua', '/cdms/home', $data['less_num']));
  74. $row->column(3,new InfoBox('昨日接种消耗(支)', 'first-order', 'aqua', '/cdms/home', $data['yesterday']));
  75. });
  76. }
  77. public function real_data()
  78. {
  79. $data = StatController::service();
  80. return view('cdms.real_data',compact('data'));
  81. }
  82. public function vaccine_data()
  83. {
  84. $data = StatController::vaccine();
  85. return view('cdms.vaccine_data',compact('data'));
  86. }
  87. public function nurse_data()
  88. {
  89. $data = StatController::nurse();
  90. return view('cdms.nurse_data',compact('data'));
  91. }
  92. public function schedule_data()
  93. {
  94. $data = StatController::schedule();
  95. return view('cdms.schedule_data',compact('data'));
  96. }
  97. public function order_detail()
  98. {
  99. $id = request('id');
  100. if(empty($id)){
  101. return redirect('/cdms/docter_chats');
  102. }
  103. $data = Order::where('id',$id)->with('orderPatient')->first();
  104. if(!empty($data->orderPatient->medical_imgs)){
  105. $data->orderPatient->medical_imgs = object_array(json_decode($data->orderPatient->medical_imgs ));
  106. } else {
  107. $data->orderPatient->medical_imgs = [];
  108. }
  109. $content = new Content();
  110. $status = Order::getStatus();
  111. $content->view('cdms.order_detail',compact('data','status'));
  112. return $content;
  113. }
  114. public function schedule(){
  115. $time = redirect('time');
  116. $time = '2020-12-07至2020-12-13';
  117. $data = sechedule_timeperiod();
  118. $org_id = Admin::user()->org_id;
  119. $where = [];
  120. if($org_id){
  121. $where['organization_id'] = $org_id;
  122. }
  123. if($time){
  124. } else {
  125. $where['schedule_date']=date('Y-m-d',strtotime('this week'));
  126. }
  127. Schedule::where($where)->pluck('id');
  128. }
  129. }