Wenzhen.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456
  1. <?php
  2. namespace app\api\controller\doctor;
  3. use app\common\controller\Apic;
  4. use think\Db;
  5. use app\common\model\Wenzhenorder;
  6. use app\common\library\Tenim;
  7. /**
  8. * 问诊订单
  9. */
  10. class Wenzhen extends Apic
  11. {
  12. protected $noNeedLogin = '';
  13. protected $noNeedRight = '*';
  14. //订单列表
  15. public function order_list(){
  16. $where = ['doctor_id'=>$this->auth->id];
  17. //订单状态
  18. $status = input('status',10);
  19. if($status != 'all'){
  20. $where['order.status'] = $status;
  21. if($status == 20){
  22. $where['order.status'] = ['IN',[20,25]];
  23. }
  24. if($status == 100){
  25. $where['order.status'] = ['IN',[13,16,18,22]];
  26. }
  27. }
  28. //问诊类型
  29. $ordertype = input('ordertype',0);
  30. if($ordertype){
  31. $where['order.ordertype'] = $ordertype;
  32. }
  33. //查询
  34. $field = [
  35. 'order.id','order.user_id','order.doctor_id','order.order_no','order.createtime','order.status','order.ordertype','order.accept_time','order.video_time','order.book_time',
  36. 'member.realname as member_realname','member.gender as member_gender','member.birthday as member_birthday',
  37. 'member.marital_status','member.allergies_status','member.familymedical_status','member.chronicdisease_status',
  38. ];
  39. $list = Db::name('wenzhen_order')->alias('order')
  40. ->field($field)
  41. ->join('wenzhen_order_member member','order.id = member.order_id','LEFT')
  42. ->order('order.id desc')
  43. ->where($where)
  44. ->autopage()->select();
  45. if(!empty($list)){
  46. //循环处理
  47. foreach($list as $key => $val){
  48. //患者资料
  49. $gender = $val['member_gender'] == 1 ? '男' : '女';
  50. $age = birthtime_to_age($val['member_birthday']).'岁';
  51. $marital = $val['marital_status'] == 1 ? '已婚' : '未婚';
  52. $val['member_info'] = $gender.'|'.$age.'|'.$marital;
  53. $allergies_status = $val['allergies_status'] == 1 ? '有' : '无';
  54. $familymedical_status = $val['familymedical_status'] == 1 ? '有' : '无';
  55. $chronicdisease_status = $val['chronicdisease_status'] == 1 ? '有' : '无';
  56. $val['member_remark'] = $allergies_status.'过敏史、'.$familymedical_status.'家族遗传史、'.$chronicdisease_status.'慢性病/肿瘤/手术/放射治疗';
  57. unset($val['member_gender']);
  58. unset($val['member_birthday']);
  59. unset($val['marital_status']);
  60. unset($val['allergies_status']);
  61. unset($val['familymedical_status']);
  62. unset($val['chronicdisease_status']);
  63. //追加
  64. $val = $this->orderinfo_appen($val);
  65. $list[$key] = $val;
  66. }
  67. }
  68. $this->success(1,$list);
  69. }
  70. //单个订单,追加数据
  71. private function orderinfo_appen($val){
  72. //订单类型
  73. $ordertype_data = [
  74. 1 => ['name'=>'图文问诊','name_en'=>'Text and Image Consultation'],
  75. 2 => ['name'=>'视频问诊','name_en'=>'Video Consultation'],
  76. ];
  77. //开始处理
  78. //订单类型,辅助
  79. $val['ordertype_data'] = $ordertype_data[$val['ordertype']];
  80. //状态组合
  81. $status_array = [
  82. 0 => 0,
  83. 3 => 3,
  84. 10 => 10,
  85. 13 => 100, //已退珍
  86. 16 => 100, //已退珍
  87. 18 => 100, //已退珍
  88. 20 => 20, //咨询中
  89. 22 => 100, //已退珍
  90. 25 => 20, //咨询中
  91. 30 => 30
  92. ];
  93. $val['status'] = isset($status_array[$val['status']]) ? $status_array[$val['status']] : $val['status'];
  94. $val['feedback_images'] = empty($val['feedback_images']) ? '' : $val['feedback_images'];
  95. //处理完成,返回
  96. return $val;
  97. }
  98. //订单状态备注枚举
  99. //状态:0=未付款,3=已失效,10=待接诊,13=用户退诊,16=医生未接诊,18=医生退诊,20=已接诊,22=超时未拨打,25=视频通话中,30=问诊完成
  100. //订单详情
  101. public function order_info(){
  102. $order_id = input('order_id',0);
  103. //订单详情
  104. $field = [
  105. 'id','order_no','user_id','member_id','doctor_id','ordertype','total_fee','book_time','createtime','status','cancel_time','cancel_reason',
  106. 'pay_type','pay_time','accept_time','video_time','finish_time','feedback_time','feedback_remark','feedback_images',
  107. ];
  108. $wenzhen_order = Db::name('wenzhen_order')->field($field)->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  109. if(empty($wenzhen_order)){
  110. $this->error('不存在的订单');
  111. }
  112. $wenzhen_order = info_domain_image($wenzhen_order,['feedback_images']);
  113. $wenzhen_order = $this->orderinfo_appen($wenzhen_order);
  114. //就诊人详情
  115. $order_member_info = Db::name('wenzhen_order_member')->where('order_id',$order_id)->find();
  116. $order_member_info = info_domain_image($order_member_info,['member_images']);
  117. $order_member_info['age'] = birthtime_to_age($order_member_info['birthday']);
  118. $wenzhen_order['member_info'] = $order_member_info;
  119. //医生详情
  120. /*$field = [
  121. 'd.nickname','d.avatar','d.keshi_id','d.level_id','d.hospital','d.goodat','d.ordernum',
  122. 'keshi.name as keshi_name',
  123. 'level.name as level_name'
  124. ];
  125. $doctor_info = Db::name('doctor')->alias('d')
  126. ->field($field)
  127. ->join('doctor_level level','d.level_id = level.id','LEFT')
  128. ->join('keshi','d.keshi_id = keshi.id','LEFT')
  129. ->where('d.id',$wenzhen_order['doctor_id'])->find();
  130. $doctor_info = info_domain_image($doctor_info,['avatar']);
  131. $wenzhen_order['doctor_info'] = $doctor_info;*/
  132. //视频订单是否能拨打
  133. $wenzhen_order['video_call_switch'] = 0;
  134. if($wenzhen_order['ordertype'] == 2 && $wenzhen_order['status'] == 20){
  135. if(time() >= $wenzhen_order['book_time']){
  136. $wenzhen_order['video_call_switch'] = 1;
  137. }
  138. }
  139. $this->success(1,$wenzhen_order);
  140. }
  141. //退珍
  142. //因为存在第三方,悲观锁
  143. public function tuizhen(){
  144. $apilimit = $this->apiLimit();
  145. if(!$apilimit){
  146. $this->error('操作频繁');
  147. }
  148. //订单详情
  149. $order_id = input('order_id',0);
  150. Db::startTrans();
  151. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->lock(true)->find();
  152. if(empty($wenzhen_order)){
  153. Db::rollback();
  154. $this->error('不存在的订单');
  155. }
  156. if($wenzhen_order['status'] != 10){
  157. Db::rollback();
  158. $this->error('待接诊订单才能退诊');
  159. }
  160. //修改订单
  161. $nowtime = time();
  162. $update = [
  163. 'status' => 18,
  164. 'cancel_time' => $nowtime,
  165. 'cancel_reason' => input('cancel_reason','医生主动退珍'),
  166. 'finish_time' => $nowtime,
  167. ];
  168. //余额支付的直接退款
  169. if($wenzhen_order['pay_type'] == 'wallet'){
  170. //用户加钱
  171. $logtype = $wenzhen_order['ordertype'] == 1 ? 13 : 14;
  172. $rs_wallet = model('wallet')->lockChangeAccountRemain($wenzhen_order['user_id'],'money',$wenzhen_order['total_fee'],$logtype,$remark='医生问诊退珍','wenzhen_order',$order_id);
  173. if($rs_wallet['status'] === false){
  174. Db::rollback();
  175. $this->error($rs_wallet['msg']);
  176. }
  177. //订单退款参数
  178. $update['refund_price'] = $wenzhen_order['total_fee'];
  179. $update['refund_status'] = 3;
  180. }else{
  181. $update['refund_status'] = 1; //待退款
  182. //发起退款
  183. $Wenzhenorder_model = new Wenzhenorder;
  184. $refund_rs = $Wenzhenorder_model->old_refund($wenzhen_order,$wenzhen_order['total_fee']);
  185. if($refund_rs === true){
  186. $update['refund_status'] = 3; //退款完成
  187. }
  188. }
  189. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->update($update);
  190. if(!$update_rs){
  191. Db::rollback();
  192. $this->error('退珍失败');
  193. }
  194. Db::commit();
  195. $this->success('退珍成功');
  196. }
  197. //接珍
  198. public function jiezhen(){
  199. $apilimit = $this->apiLimit();
  200. if(!$apilimit){
  201. $this->error('操作频繁');
  202. }
  203. //订单详情
  204. $order_id = input('order_id',0);
  205. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  206. if(empty($wenzhen_order)){
  207. $this->error('不存在的订单');
  208. }
  209. if($wenzhen_order['status'] != 10){
  210. $this->error('待接诊订单才能接诊');
  211. }
  212. //修改订单
  213. $nowtime = time();
  214. $update = [
  215. 'status' => 20,
  216. 'accept_time' => $nowtime,
  217. ];
  218. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',10)->update($update);
  219. if(!$update_rs){
  220. $this->error('接诊失败');
  221. }
  222. //发送im消息给用户
  223. if($wenzhen_order['ordertype'] == 1){
  224. $tenim = new Tenim();
  225. $message = [
  226. 'businessID' => 'order_status_doctor',
  227. 'name' => '您已接诊',
  228. 'status' => '20',
  229. 'id' => (string)$order_id,
  230. 'content' => '请尽快联系患者,超时将自动取消订单',
  231. ];
  232. $rs = $tenim->sendCustomMessageToUser('user'.$wenzhen_order['user_id'],'doctor'.$wenzhen_order['doctor_id'],$message);
  233. $message = [
  234. 'businessID' => 'order_status',
  235. 'name' => '医生已接诊',
  236. 'status' => '20',
  237. 'id' => (string)$order_id,
  238. 'content' => '请补充问题,便于医生更快的确认病情',
  239. ];
  240. $rs = $tenim->sendCustomMessageToUser('user'.$wenzhen_order['user_id'],'doctor'.$wenzhen_order['doctor_id'],$message);
  241. //发送im消息给用户,让他能输入
  242. $message = [
  243. 'businessID' => 'order_status_doctor_type',
  244. 'name' => '',
  245. 'status' => '20',
  246. 'id' => (string)$order_id,
  247. 'content' => '',
  248. ];
  249. $rs = $tenim->sendCustomMessageToUser('user'.$wenzhen_order['user_id'],'doctor'.$wenzhen_order['doctor_id'],$message);
  250. }
  251. $this->success('接珍成功');
  252. }
  253. //第一次拨打视频
  254. public function first_video(){
  255. $apilimit = $this->apiLimit();
  256. if(!$apilimit){
  257. $this->error('操作频繁');
  258. }
  259. //订单详情
  260. $order_id = input('order_id',0);
  261. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  262. if(empty($wenzhen_order)){
  263. $this->error('不存在的订单');
  264. }
  265. if($wenzhen_order['ordertype'] != 2 || $wenzhen_order['status'] != 20){
  266. $this->error('已接诊的视频订单才能拨打视频');
  267. }
  268. if($wenzhen_order['book_time'] < time() - 300){
  269. $this->error('未到预约时间');
  270. }
  271. //修改订单
  272. $nowtime = time();
  273. $update = [
  274. 'status' => 25,
  275. 'video_time' => $nowtime,
  276. ];
  277. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',20)->update($update);
  278. if(!$update_rs){
  279. $this->error('操作失败');
  280. }
  281. $this->success('操作成功');
  282. }
  283. //完成
  284. public function finish(){
  285. $apilimit = $this->apiLimit();
  286. if(!$apilimit){
  287. $this->error('操作频繁');
  288. }
  289. //订单详情
  290. $order_id = input('order_id',0);
  291. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  292. if(empty($wenzhen_order)){
  293. $this->error('不存在的订单');
  294. }
  295. if($wenzhen_order['ordertype'] == 1){
  296. if($wenzhen_order['status'] != 20){
  297. $this->error('已接诊订单才能完成');
  298. }
  299. $old_status = 20;
  300. }
  301. if($wenzhen_order['ordertype'] == 2){
  302. if($wenzhen_order['status'] != 25){
  303. $this->error('尚未发起视频,不能结束');
  304. }
  305. $old_status = 25;
  306. }
  307. //修改订单
  308. $nowtime = time();
  309. $update = [
  310. 'status' => 30,
  311. 'finish_time' => $nowtime,
  312. ];
  313. Db::startTrans();
  314. //给医生结算钱
  315. $logtype = $wenzhen_order['ordertype'] == 1 ? 111 : 112;
  316. $rs_wallet = model('walletdoctor')->lockChangeAccountRemain($this->auth->id,'money',$wenzhen_order['total_fee'],$logtype,$remark='问诊订单','wenzhen_order',$order_id);
  317. if($rs_wallet['status'] === false){
  318. Db::rollback();
  319. $this->error($rs_wallet['msg']);
  320. }
  321. //订单状态
  322. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',$old_status)->update($update);
  323. if(!$update_rs){
  324. Db::rollback();
  325. $this->error('操作失败');
  326. }
  327. //医生接诊量
  328. Db::name('doctor')->where('id',$this->auth->id)->setInc('ordernum');
  329. Db::commit();
  330. //发送im消息给用户,让他不能再输入
  331. $tenim = new Tenim();
  332. $message = [
  333. 'businessID' => 'order_status_doctor_type',
  334. 'name' => '',
  335. 'status' => '30',
  336. 'id' => (string)$order_id,
  337. 'content' => '',
  338. ];
  339. $rs = $tenim->sendCustomMessageToUser('user'.$wenzhen_order['user_id'],'doctor'.$wenzhen_order['doctor_id'],$message);
  340. $this->success('操作成功');
  341. }
  342. //反馈
  343. public function feedback(){
  344. $apilimit = $this->apiLimit();
  345. if(!$apilimit){
  346. $this->error('操作频繁');
  347. }
  348. //订单详情
  349. $order_id = input('order_id',0);
  350. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  351. if(empty($wenzhen_order)){
  352. $this->error('不存在的订单');
  353. }
  354. if($wenzhen_order['status'] != 30){
  355. //$this->error('已完成订单才能反馈');
  356. }
  357. //修改订单
  358. $nowtime = time();
  359. $update = [
  360. 'feedback_time' => $nowtime,
  361. 'feedback_remark' => input('feedback_remark',''),
  362. 'feedback_images' => input('feedback_images',''),
  363. ];
  364. Db::startTrans();
  365. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->update($update);
  366. if(!$update_rs){
  367. $this->error('反馈失败');
  368. Db::rollback();
  369. }
  370. Db::commit();
  371. $this->success('反馈成功');
  372. }
  373. }