Writereport.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421
  1. <?php
  2. namespace app\inter\controller;
  3. //use Doctrine\Common\Cache\Cache;
  4. use think\Controller;
  5. use think\Db;
  6. use think\Session;
  7. use app\common\library\UUIDs;
  8. use think\Cache;
  9. use think\Log;
  10. use app\common\library\Verify;
  11. class WriteReport extends Base
  12. {
  13. public function index(){
  14. try{
  15. log::record('-----请求值-----');
  16. log::record($_REQUEST);
  17. log::record('-----请求值-----');
  18. $sessionid = $_REQUEST['sessionid'];
  19. if(isset($_REQUEST['is_remote']) && !empty($_REQUEST['is_remote'])){
  20. $is_remote = $_REQUEST['is_remote'];
  21. }else{
  22. $is_remote = 0;
  23. }
  24. $doctor = Cache::get($sessionid);
  25. $institution = DB::table('institution')->where('id',$doctor['institution_id'])->field('name,report_subtitle')->find();
  26. $param = $_REQUEST['param'];
  27. $id = $param['id'];
  28. $info = DB::table('exams')->where('id',$id)->field(['id','study_id','exam_class','exam_datetime','exam_sub_class','body_part','accession_num','patient_id'])->find();
  29. $exam_class = DB::table('constant')->where('id',$info['exam_class'])->field('constant_value')->find();
  30. $info['exam_class'] = $exam_class['constant_value'];
  31. $exam_subclass = DB::table('exam_subclass')->where('id',$info['exam_sub_class'])->field('name')->find();
  32. $info['exam_sub_class'] = $exam_subclass['name'];
  33. $patient_info = DB::table('patient_infos')->where('id',$info['patient_id'])->field(['id','temp_patient_id','name','sex','age'])->find();
  34. $info['pid'] = $patient_info['temp_patient_id'];
  35. $info['name'] = $patient_info['name'];
  36. $info['sex'] = $patient_info['sex'];
  37. $info['age'] = $patient_info['age'];
  38. $info['hospital_name'] = $institution['name'];
  39. $info['hospital_title'] = $institution['report_subtitle'];
  40. $info['images'] = isset($param['images']) ? $param['images'] : '';
  41. $report = DB::table('report')->where('exam_id',$id)->field('report_datetime,report_doctor_id,review_datetime,review_doctor_id,impression,description')->find();
  42. $report_doctor = DB::table('doctors')->where('id',$report['report_doctor_id'])->field('realname')->find();
  43. $info['report_doctor'] = $report_doctor['realname'];
  44. $info['report_datetime'] = $report['report_datetime'];
  45. $review_doctor = DB::table('doctors')->where('id',$report['review_doctor_id'])->field('realname')->find();
  46. $info['review_doctor'] = $review_doctor['realname'];
  47. $info['review_datetime'] = $report['review_datetime'];
  48. $info['description'] = $report['description'];
  49. $info['impression'] = $report['impression'];
  50. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info,'sessionid'=>$sessionid,'is_remote'=>$is_remote]);
  51. }catch(\Exception $e){
  52. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  53. }
  54. }
  55. public function upload($files){
  56. // 获取表单上传文件
  57. foreach($files as $file){
  58. // 移动到框架应用根目录/public/uploads/ 目录下
  59. $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');
  60. if($info){
  61. return $info->getSaveName();
  62. // 成功上传后 获取上传信息
  63. // 输出 jpg
  64. // echo $info-> getExtension();
  65. // 输出 42a79759f284b767dfcb2a0197904287.jpg
  66. // echo $info->getFilename();
  67. }else{
  68. // 上传失败获取错误信息
  69. // echo $file->getError();
  70. }
  71. }
  72. }
  73. public function write(){
  74. try{
  75. $sessionid = $_REQUEST['sessionid'];
  76. if(isset($_REQUEST['is_remote']) && $_REQUEST['is_remote'] == 1){
  77. // 是远程写报告 7
  78. $return = Verify::check_role($sessionid,7);
  79. }else{
  80. // 本地写报告权限 2
  81. $return = Verify::check_role($sessionid,2);
  82. }
  83. if($return != 1){
  84. return json_encode(['status'=>'fail','code'=>'1029','msg'=>'没有操作权限']);
  85. }
  86. $param = $_REQUEST['param'];
  87. // Verify::wreportCheck($param);
  88. $doctor = Cache::get($sessionid);
  89. $remote_app = DB::table('remote_application')->where('exam_id',$param['id'])->field('remote_doctor_id')->find();
  90. if(!empty($remote_app['remote_doctor_id'])){
  91. if($remote_app['remote_doctor_id'] != $doctor['id']){
  92. // return json_encode(['status'=>'fail','code'=>'1029','msg'=>'已被指定报告医生,您没有操作权限']);
  93. }
  94. }
  95. $this->uuids = new UUIDs();
  96. $id = $this->uuids->uuid16();
  97. //初步报告生成
  98. $film_type = isset($param['film_type']) ? $param['film_type'] : '';
  99. $exam_status = $this->get_exam_status($doctor['id'],7);
  100. DB::table('exams')->where('id',$param['id'])->update(['exam_status'=>$exam_status,'film_type'=>$film_type]);
  101. $patient_info = array();
  102. $patient_info['id'] = isset($param['pid']) ? $param['pid'] : '';
  103. $patient_info['name'] = isset($param['name']) ? $param['name'] : '';
  104. $patient_info['age'] = isset($param['age']) ? $param['age'] : '';
  105. $patient_info['sex'] = isset($param['sex']) ? $param['sex'] : '';
  106. $patient = DB::table('patient_infos')->where('id',$param['pid'])->update($patient_info);
  107. $info = array();
  108. $info['exam_id'] = $param['id'];
  109. $info['impression'] = isset($param['impression']) ? $param['impression'] : '';
  110. $info['description'] = isset($param['description']) ? $param['description'] : '';
  111. if(isset($param['r_result']) && $param['r_result'] == 'true'){
  112. $info['report_result'] = 2;
  113. }else{
  114. $info['report_result'] = 1;
  115. }
  116. $info['report_datetime'] = date('Y-m-d H:i:s',time());
  117. $info['report_doctor_id'] = $doctor['id'];
  118. $report_info = DB::table('report')->where('exam_id',$param['id'])->find();
  119. if($report_info){
  120. $report = DB::table('report')->where('exam_id',$param['id'])->update($info);
  121. }else{
  122. $info['id'] = $id;
  123. $report = DB::table('report')->insert($info);
  124. }
  125. //写入log日志
  126. $log = array();
  127. $log['id'] = UUIDs::uuid16();
  128. $log['impression'] = isset($param['impression']) ? $param['impression'] : '';
  129. $log['description'] = isset($param['description']) ? $param['description'] : '';
  130. $log['report_id'] = $id;
  131. $log['createdAt'] = date('Y-m-d H:i:s',time());
  132. $log['doctor_id'] = $doctor['id'];
  133. $log['type'] = 1; //写报告
  134. $report_log = DB::table('report_record')->insert($log);
  135. return json_encode(['status'=>'ok','code'=>'0000','msg'=>'保存成功','sessionid'=>$sessionid]);
  136. }catch(\Exception $e){
  137. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  138. }
  139. }
  140. public function get_exam_status($doctorid,$status){
  141. $doctor_class = DB::table('doctor_class')->where('doctor_id',$doctorid)->field('doctor_class')->find();
  142. if(strpos($doctor_class['doctor_class'],'9')){
  143. return 9;
  144. }elseif(strpos($doctor_class['doctor_class'],'8')){
  145. return 8;
  146. }else{
  147. return $status;
  148. }
  149. }
  150. public function public_template(){
  151. $sessionid = $_REQUEST['sessionid'];
  152. $doctor = Cache::get($sessionid);
  153. $exam = $_REQUEST['exam_class'];
  154. //第一级 公共模板
  155. $info = $this->get_template(1,$doctor['id'],$exam);
  156. echo json_encode($info);
  157. }
  158. public function private_template(){
  159. $sessionid = $_REQUEST['sessionid'];
  160. $doctor = Cache::get($sessionid);
  161. $exam = $_REQUEST['exam_class'];
  162. //第一级 公共模板
  163. $info = $this->get_template(2,$doctor['id'],$exam);
  164. echo json_encode($info);
  165. }
  166. public function get_template($public,$id,$exam){
  167. // 查询exam_class表
  168. $examCla = DB::table('constant')->where('id',$exam)->field('constant_value as name')->find();
  169. if($public == 1){
  170. $t = DB::table('templates')->where('is_public',$public)->where('exam_class_id',$examCla['name'])->field(['id','title as label','impression','description','parent_id'])->select();
  171. }else{
  172. // 私有模板 添加创建人条件
  173. $t = DB::table('templates')->where('is_public',$public)->where('create_user',$id)->where('exam_class_id',$examCla['name'])->field(['id','title as label','impression','description','parent_id'])->select();
  174. }
  175. if(!$t){
  176. return '';
  177. }
  178. $data = array();
  179. foreach ($t as $k => $v) {
  180. if($v['parent_id'] == 0){
  181. $data[] = $v;
  182. }
  183. }
  184. foreach ($data as $k => $v) {
  185. unset($data[$k]['impression']);
  186. unset($data[$k]['description']);
  187. unset($data[$k]['parent_id']);
  188. }
  189. foreach ($t as $k => $v) {
  190. foreach ($data as $key => $value) {
  191. if($v['parent_id'] == $value['id']){
  192. unset($t[$k]['parent_id']);
  193. $data[$key]['children'][] = $t[$k];
  194. }
  195. }
  196. }
  197. if($data){
  198. return $data;
  199. }
  200. }
  201. //确认 5
  202. public function confirm(){
  203. try{
  204. $sessionid = $_REQUEST['sessionid'];
  205. $doctor = Cache::get($sessionid);
  206. $id = $_REQUEST['id'];
  207. $status = DB::table('exams')->where('id',$id)->field('exam_status')->find();
  208. if($status['exam_status'] < 8 ){
  209. return json_encode(['status'=>'fail','code'=>'1033','msg'=>'只能确认通过审核的报告']);
  210. }elseif($status['exam_status'] == 9){
  211. return json_encode(['status'=>'fail','code'=>'1034','msg'=>'已经确认过该报告,不可再次确认']);
  212. }
  213. $exam_status = $this->get_exam_status($doctor['id'],9);
  214. DB::table('exams')->where('id',$id)->update(['exam_status'=>$exam_status]);
  215. DB::table('report')->where('exam_id',$id)->update(['confirm_doctor_id'=>$doctor['id'],'confirm_datetime'=>date('Y-m-d H:i:s')]);
  216. // 添加 确认log日志
  217. $info = array();
  218. $info['id'] = UUIDs::uuid16();
  219. $info['createdAt'] = date('Y-m-d H:i:s',time());
  220. $info['doctor_id'] = $doctor['id'];
  221. $info['type'] = 3;
  222. $info['report_id'] = '';
  223. DB::table('report_record')->insert($info);
  224. return json_encode(['status'=>'ok','code'=>'0000','msg'=>'已确认']);
  225. }catch(\Exception $e){
  226. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  227. }
  228. }
  229. // 审核
  230. public function examine(){
  231. try{
  232. $id = $_REQUEST['id'];
  233. $status = DB::table('exams')->where('id',$id)->field('exam_status')->find();
  234. if($status['exam_status'] < 7){
  235. return json_encode(['status'=>'fail','code'=>'1032','msg'=>'只能审核已提交的报告']);
  236. }elseif($status['exam_status']>7){
  237. return json_encode(['status'=>'fail','code'=>'1035','msg'=>'报告已通过审核步骤,请勿重复操作']);
  238. }
  239. $report = DB::table('report')->where('exam_id',$id)->field('id')->find();
  240. $param = $_REQUEST['param'];
  241. $sessionid = $_REQUEST['sessionid'];
  242. $doctor = Cache::get($sessionid);
  243. if(isset($_REQUEST['is_remote']) && $_REQUEST['is_remote'] == 1){
  244. // 是远程审核报告 8
  245. $return = Verify::check_role($sessionid,8);
  246. }else{
  247. // 本地审核权限 3
  248. $return = Verify::check_role($sessionid,3);
  249. }
  250. $report_info = array();
  251. $report_info['impression'] = isset($param['impression']) ? $param['impression'] : '';
  252. $report_info['description'] = isset($param['description']) ? $param['description'] : '';
  253. $report_info['report_result'] = isset($param['r_result']) ? $param['r_result'] : '';
  254. $report_info['review_datetime'] = date('Y-m-d H:i:s',time());
  255. $report_info['review_doctor_id'] = $doctor['id'];
  256. DB::table('report')->where('id',$report['id'])->update($report_info);
  257. $info = array();
  258. $info['id'] = UUIDs::uuid16();
  259. $info['type'] = 2; //审核
  260. $info['createdAt'] = date('Y-m-d H:i:s',time());
  261. $info['doctor_id'] = $doctor['id'];
  262. $info['impression'] = isset($param['impression']) ? $param['impression'] : '';
  263. $info['description'] = isset($param['description']) ? $param['description'] : '';
  264. $info['report_id'] = $report['id'];
  265. DB::table('report_record')->insert($info);
  266. $exam_status = $this->get_exam_status($doctor['id'],8);
  267. DB::table('exams')->where('id',$id)->update(['exam_status'=>$exam_status]);
  268. return json_encode(['status'=>'ok','code'=>'0000','msg'=>'已审核']);
  269. }catch(\Exception $e){
  270. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  271. }
  272. }
  273. public function getrole(){
  274. try{
  275. if(isset($_REQUEST['is_remote']) && $_REQUEST['is_remote'] == 1){
  276. $is_remote = $_REQUEST['is_remote'];
  277. }
  278. $sessionid = $_REQUEST['sessionid'];
  279. $doctor = Cache::get($sessionid);
  280. $dclass = DB::table('doctor_class')->where('doctor_id',$doctor['id'])->field('doctor_class')->find();
  281. $doctor_class = explode(',',$dclass['doctor_class']);
  282. $info = array();
  283. foreach ($doctor_class as $k=>$v) {
  284. switch($v){
  285. case 2: //报告医生
  286. if(isset($is_remote)){
  287. //远程报告
  288. break;
  289. }
  290. $info['bg'] = 1;
  291. break;
  292. case 7: //远程报告医生
  293. if(!isset($is_remote)){
  294. //远程报告
  295. break;
  296. }
  297. $info['bg'] = 1;
  298. break;
  299. case 3: //3审核医生
  300. if(isset($is_remote)){
  301. //远程报告
  302. break;
  303. }
  304. $info['sh'] = 2;
  305. break;
  306. case 8: //远程审核医生
  307. if(!isset($is_remote)){
  308. //远程报告
  309. break;
  310. }
  311. $info['sh'] = 2;
  312. break;
  313. case 4: //确认医生
  314. $info['qr'] = 3;
  315. break;
  316. }
  317. }
  318. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info]);
  319. }catch(\Exception $e){
  320. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  321. }
  322. }
  323. public function get_report_log(){
  324. try{
  325. $sessionid = $_REQUEST['sessionid'];
  326. $doctor = Cache::get($sessionid);
  327. $exam_id = $_REQUEST['id'];
  328. $report = DB::table('report')->where('exam_id',$exam_id)->field('id')->find();
  329. $log_id = $report['id'];
  330. $log = DB::table('report_record')->where('doctor_id',$doctor['id'])->where('report_id',$log_id)->order('createdAt asc,type asc')->select();
  331. foreach ($log as $k => $v) {
  332. $doc = DB::table('doctors')->where('id',$v['doctor_id'])->field('realname')->find();
  333. $log[$k]['doctor_name'] = $doc['realname'];
  334. }
  335. return json_encode(['status'=>'ok','code'=>'0000','info'=>$log]);
  336. }catch(\Exception $e){
  337. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  338. }
  339. }
  340. public function print_report(){
  341. try{
  342. $sessionid = $_REQUEST['sessionid'];
  343. $doctor = Cache::get($sessionid);
  344. $id = $_REQUEST['id'];
  345. $info = array();
  346. // 检查日期 住院号 床号
  347. $exam_info = DB::table('exams')->where('id',$id)->field('id,exam_datetime,exam_class,hopitalized_no,bed_no,exam_project,patient_id')->find();
  348. $info['id'] = $exam_info['id'];
  349. if(!empty($exam_info['exam_datetime'])){
  350. $datetime = explode(' ',$exam_info['exam_datetime']);
  351. $info['exam_datetime'] = $datetime[0];
  352. }else{
  353. $info['exam_datetime'] = '';
  354. }
  355. $info['hopitalized_no'] = $exam_info['hopitalized_no'];
  356. $info['bed_no'] = $exam_info['bed_no'];
  357. // 检查项目
  358. $project = DB::table('exam_project')->where('id',$exam_info['exam_project'])->field('name')->find();
  359. $info['project'] = $project['name'];
  360. //检查类
  361. $exam_class = DB::table('constant')->where('id',$exam_info['exam_class'])->field('constant_value')->find();
  362. $info['exam_class'] = $exam_class['constant_value'];
  363. // 病历号 姓名 年龄 性别
  364. $patient_info = DB::table('patient_infos')->where('id',$exam_info['patient_id'])->field('temp_patient_id,name,sex,age')->find();
  365. $remote = DB::table('remote_application')->where('exam_id',$id)->field('req_doctor_id')->find();
  366. $info['pnumber'] = $patient_info['temp_patient_id'];
  367. $info['name'] = $patient_info['name'];
  368. $info['sex'] = $patient_info['sex'];
  369. $info['age'] = $patient_info['age'];
  370. // 申请医生
  371. $application_name = DB::table('doctors')->where('id',$remote['req_doctor_id'])->field('realname,department_id')->find();
  372. $info['application_name'] = $application_name['realname'];
  373. // 申请科室
  374. $department = DB::table('department')->where('id',$application_name['department_id'])->field('department_name')->find();
  375. $info['department_name'] = $department['department_name'];
  376. // 报告时间 影像所见 意见建议
  377. $report = DB::table('report')->where('exam_id',$id)->field('report_datetime,impression,description,report_doctor_id,review_doctor_id')->find();
  378. if(!empty($report['report_datetime'])){
  379. $datetime1 = explode(' ',$report['report_datetime']);
  380. $info['report_datetime'] = $datetime1[0];
  381. }else{
  382. $info['report_datetime'] = '';
  383. }
  384. // $info['report_datetime'] = $report['report_datetime'];
  385. $info['impression'] = $report['impression'];
  386. $info['description'] = $report['description'];
  387. // 报告医生
  388. $report_doctor = DB::table('doctors')->where('id',$report['report_doctor_id'])->field('realname')->find();
  389. $info['report_doctor'] = $report_doctor['realname'];
  390. //审核医生
  391. $review_doctor = DB::table('doctors')->where('id',$report['review_doctor_id'])->field('realname')->find();
  392. $info['review_doctor'] = $review_doctor['realname'];
  393. $hospital = DB::table('institution')->where('id',$doctor['institution_id'])->field('name')->find();
  394. $info['hospital'] = $hospital['name'];
  395. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info,'sessionid'=>$sessionid]);
  396. }catch(\Exception $e){
  397. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  398. }
  399. }
  400. public function change_film(){
  401. $id = $_REQUEST['id'];
  402. $film = $_REQUEST['film_type'];
  403. DB::table('exams')->where('id',$id)->update(['film_type'=>$film]);
  404. return json_encode(['status'=>'ok','code'=>'0000']);
  405. }
  406. }