Doctor.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <?php
  2. namespace app\admin\controller\statistics;
  3. use app\admin\model\doctors\DoctorModel;
  4. use app\common\controller\Backend;
  5. use think\Db;
  6. /**
  7. * 医生统计
  8. * @icon fa fa-circle-o
  9. */
  10. class Doctor extends Backend
  11. {
  12. protected $model = null;
  13. /**
  14. * 快速搜索时执行查找的字段
  15. */
  16. protected $searchFields = ['realname'];
  17. public function _initialize()
  18. {
  19. parent::_initialize();
  20. $this->model = new DoctorModel();
  21. }
  22. public function index()
  23. {
  24. //设置过滤方法
  25. $this->request->filter(['strip_tags']);
  26. if ($this->request->isAjax()) {
  27. //如果发送的来源是Selectpage,则转发到Selectpage
  28. if ($this->request->request('keyField')) {
  29. return $this->selectpage();
  30. }
  31. list($where, $sort, $order, $offset, $limit) = $this->buildparams($this->searchFields, true);
  32. // 过滤机构
  33. $childInsIds = $this->auth->getMyInsId();
  34. if($childInsIds == false){
  35. $more = false;
  36. } else {
  37. $more = ['institution_id' => ['in', $this->auth->getMyInsId()]];
  38. }
  39. $range_where = false;
  40. if($this->request->has('range')){
  41. $range = $this->request->param('range');
  42. $between = [
  43. substr($range, 0, 19),
  44. substr($range, 22, 19),
  45. ];
  46. $range_where = [
  47. 'createdAt' => ['between', $between]
  48. ];
  49. }
  50. $join = [
  51. ['institution i', 'd.institution_id = i.id', 'LEFT'],
  52. ];
  53. $field = [
  54. 'd.id','d.realname','d.institution_id','i.name as institution_name',
  55. '0 as local_report','0 as local_review','0 as remote_report','0 as remote_review', '0 as initiate_remote'
  56. ];
  57. $list = $this->model->alias('d')
  58. ->join($join)
  59. ->where($where)
  60. ->where($more)
  61. ->order($sort, $order)
  62. ->group('d.id')
  63. ->limit($offset, $limit)
  64. ->column($field);
  65. $total = $this->model->alias('d')
  66. ->join($join)
  67. ->where($where)
  68. ->where($more)
  69. ->group('d.id')
  70. ->count();
  71. $list = collection($list)->toArray();
  72. // 查询报告
  73. $doctor_ids = array_column($list,'id');
  74. $reports = model('report','model\report')
  75. ->where($range_where)
  76. ->where(function ($query) use ($doctor_ids) {
  77. $query->whereIn('report_doctor_id',$doctor_ids);
  78. $query->whereOr(['review_doctor_id'=>['in',$doctor_ids]]);
  79. })
  80. ->field('report_doctor_id,review_doctor_id,type')
  81. ->select();
  82. foreach ($reports as $val){
  83. if(isset($list[$val['report_doctor_id']])){
  84. if($val['type'] == '1'){
  85. $list[$val['report_doctor_id']]['local_report'] ++;
  86. } else {
  87. $list[$val['report_doctor_id']]['remote_report'] ++;
  88. }
  89. }
  90. if(isset($list[$val['review_doctor_id']])){
  91. if($val['type'] == '1'){
  92. $list[$val['review_doctor_id']]['local_review'] ++;
  93. } else {
  94. $list[$val['review_doctor_id']]['remote_review'] ++;
  95. }
  96. }
  97. }
  98. // 查询远程诊断
  99. $remote_data = model('Remote','model\remote')
  100. ->where($range_where)
  101. ->whereIn('req_doctor_id', $doctor_ids)
  102. ->column('req_doctor_id');
  103. foreach ($remote_data as $val){
  104. $list[$val]['initiate_remote'] ++;
  105. }
  106. $list = array_values($list);
  107. $result = array("total" => $total, "rows" => $list);
  108. return json($result);
  109. }
  110. return $this->view->fetch();
  111. }
  112. }