Wenzhen.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372
  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. /**
  7. * 问诊订单
  8. */
  9. class Wenzhen extends Apic
  10. {
  11. protected $noNeedLogin = '';
  12. protected $noNeedRight = '*';
  13. //订单列表
  14. public function order_list(){
  15. $where = ['doctor_id'=>$this->auth->id];
  16. //订单状态
  17. $status = input('status',10);
  18. if($status != 'all'){
  19. $where['order.status'] = $status;
  20. if($status == 100){
  21. $where['order.status'] = ['IN',[13,16,18,22]];
  22. }
  23. }
  24. //问诊类型
  25. $ordertype = input('ordertype',0);
  26. if($ordertype){
  27. $where['order.ordertype'] = $ordertype;
  28. }
  29. //查询
  30. $field = [
  31. 'order.id','order.order_no','order.createtime','order.status','order.ordertype','order.accept_time','order.video_time','order.book_time',
  32. 'member.realname as member_realname','member.gender as member_gender','member.birthday as member_birthday',
  33. 'member.marital_status','member.allergies_status','member.familymedical_status','member.chronicdisease_status',
  34. ];
  35. $list = Db::name('wenzhen_order')->alias('order')
  36. ->field($field)
  37. ->join('wenzhen_order_member member','order.id = member.order_id','LEFT')
  38. ->order('order.id desc')
  39. ->where($where)
  40. ->autopage()->select();
  41. if(!empty($list)){
  42. //循环处理
  43. foreach($list as $key => $val){
  44. //患者资料
  45. $gender = $val['member_gender'] == 1 ? '男' : '女';
  46. $age = birthtime_to_age($val['member_birthday']).'岁';
  47. $marital = $val['marital_status'] == 1 ? '已婚' : '未婚';
  48. $val['member_info'] = $gender.'|'.$age.'|'.$marital;
  49. $allergies_status = $val['allergies_status'] == 1 ? '有' : '无';
  50. $familymedical_status = $val['familymedical_status'] == 1 ? '有' : '无';
  51. $chronicdisease_status = $val['chronicdisease_status'] == 1 ? '有' : '无';
  52. $val['member_remark'] = $allergies_status.'过敏史、'.$familymedical_status.'家族遗传史、'.$chronicdisease_status.'慢性病/肿瘤/手术/放射治疗';
  53. unset($val['member_gender']);
  54. unset($val['member_birthday']);
  55. unset($val['marital_status']);
  56. unset($val['allergies_status']);
  57. unset($val['familymedical_status']);
  58. unset($val['chronicdisease_status']);
  59. //追加
  60. $val = $this->orderinfo_appen($val);
  61. $list[$key] = $val;
  62. }
  63. }
  64. $this->success(1,$list);
  65. }
  66. //单个订单,追加数据
  67. private function orderinfo_appen($val){
  68. //订单类型
  69. $ordertype_data = [
  70. 1 => ['name'=>'图文问诊','name_en'=>'Text and Image Consultation'],
  71. 2 => ['name'=>'视频问诊','name_en'=>'Video Consultation'],
  72. ];
  73. //开始处理
  74. //订单类型,辅助
  75. $val['ordertype_data'] = $ordertype_data[$val['ordertype']];
  76. //处理完成,返回
  77. return $val;
  78. }
  79. //订单状态备注枚举
  80. //状态:0=未付款,3=已失效,10=待接诊,13=用户退诊,16=医生未接诊,18=医生退诊,20=已接诊,22=超时未拨打,25=视频通话中,30=问诊完成
  81. //订单详情
  82. public function order_info(){
  83. $order_id = input('order_id',0);
  84. //订单详情
  85. $field = [
  86. 'id','order_no','user_id','member_id','doctor_id','ordertype','total_fee','book_time','createtime','status','cancel_time','cancel_reason',
  87. 'pay_type','pay_time','accept_time','video_time','finish_time','feedback_time','feedback_remark','feedback_images',
  88. ];
  89. $wenzhen_order = Db::name('wenzhen_order')->field($field)->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  90. if(empty($wenzhen_order)){
  91. $this->error('不存在的订单');
  92. }
  93. $wenzhen_order = info_domain_image($wenzhen_order,['feedback_images']);
  94. $wenzhen_order = $this->orderinfo_appen($wenzhen_order);
  95. //就诊人详情
  96. $order_member_info = Db::name('wenzhen_order_member')->where('order_id',$order_id)->find();
  97. $order_member_info = info_domain_image($order_member_info,['member_images']);
  98. $order_member_info['age'] = birthtime_to_age($order_member_info['birthday']);
  99. $wenzhen_order['member_info'] = $order_member_info;
  100. //医生详情
  101. /*$field = [
  102. 'd.nickname','d.avatar','d.keshi_id','d.level_id','d.hospital','d.goodat','d.ordernum',
  103. 'keshi.name as keshi_name',
  104. 'level.name as level_name'
  105. ];
  106. $doctor_info = Db::name('doctor')->alias('d')
  107. ->field($field)
  108. ->join('doctor_level level','d.level_id = level.id','LEFT')
  109. ->join('keshi','d.keshi_id = keshi.id','LEFT')
  110. ->where('d.id',$wenzhen_order['doctor_id'])->find();
  111. $doctor_info = info_domain_image($doctor_info,['avatar']);
  112. $wenzhen_order['doctor_info'] = $doctor_info;*/
  113. $this->success(1,$wenzhen_order);
  114. }
  115. //退珍
  116. public function tuizhen(){
  117. $apilimit = $this->apiLimit();
  118. if(!$apilimit){
  119. $this->error('操作频繁');
  120. }
  121. //订单详情
  122. $order_id = input('order_id',0);
  123. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  124. if(empty($wenzhen_order)){
  125. $this->error('不存在的订单');
  126. }
  127. if($wenzhen_order['status'] != 10){
  128. $this->error('待接诊订单才能退诊');
  129. }
  130. //修改订单
  131. $nowtime = time();
  132. $update = [
  133. 'status' => 18,
  134. 'cancel_time' => $nowtime,
  135. 'cancel_reason' => input('cancel_reason','医生主动退珍'),
  136. 'finish_time' => $nowtime,
  137. ];
  138. Db::startTrans();
  139. //余额支付的直接退款
  140. if($wenzhen_order['pay_type'] == 'wallet'){
  141. //用户加钱
  142. $logtype = $wenzhen_order['ordertype'] == 1 ? 13 : 14;
  143. $rs_wallet = model('wallet')->lockChangeAccountRemain($wenzhen_order['user_id'],'money',$wenzhen_order['total_fee'],$logtype,$remark='医生问诊退珍','wenzhen_order',$order_id);
  144. if($rs_wallet['status'] === false){
  145. Db::rollback();
  146. $this->error($rs_wallet['msg']);
  147. }
  148. //订单退款参数
  149. $update['refund_price'] = $wenzhen_order['total_fee'];
  150. $update['refund_status'] = 3;
  151. }else{
  152. $update['refund_status'] = 1; //待退款
  153. //发起退款
  154. $Wenzhenorder_model = new Wenzhenorder;
  155. $refund_rs = $Wenzhenorder_model->old_refund($wenzhen_order,$wenzhen_order['total_fee']);
  156. if($refund_rs === true){
  157. $update['refund_status'] = 3; //退款完成
  158. }
  159. }
  160. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',10)->update($update);
  161. if(!$update_rs){
  162. Db::rollback();
  163. $this->error('退珍失败');
  164. }
  165. Db::commit();
  166. $this->success(1,'退珍成功');
  167. }
  168. //接珍
  169. public function jiezhen(){
  170. $apilimit = $this->apiLimit();
  171. if(!$apilimit){
  172. $this->error('操作频繁');
  173. }
  174. //订单详情
  175. $order_id = input('order_id',0);
  176. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  177. if(empty($wenzhen_order)){
  178. $this->error('不存在的订单');
  179. }
  180. if($wenzhen_order['status'] != 10){
  181. $this->error('待接诊订单才能接诊');
  182. }
  183. //修改订单
  184. $nowtime = time();
  185. $update = [
  186. 'status' => 20,
  187. 'accept_time' => $nowtime,
  188. ];
  189. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',10)->update($update);
  190. if(!$update_rs){
  191. Db::rollback();
  192. $this->error('接诊失败');
  193. }
  194. Db::commit();
  195. $this->success(1,'接珍成功');
  196. }
  197. //第一次拨打视频
  198. public function first_video(){
  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['ordertype'] != 2 || $wenzhen_order['status'] != 20){
  210. $this->error('已接诊的视频订单才能拨打视频');
  211. }
  212. if($wenzhen_order['book_time'] < time() - 300){
  213. $this->error('未到预约时间');
  214. }
  215. //修改订单
  216. $nowtime = time();
  217. $update = [
  218. 'status' => 25,
  219. 'video_time' => $nowtime,
  220. ];
  221. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',20)->update($update);
  222. if(!$update_rs){
  223. $this->error('操作失败');
  224. }
  225. $this->success(1,'操作成功');
  226. }
  227. //完成
  228. public function finish(){
  229. $apilimit = $this->apiLimit();
  230. if(!$apilimit){
  231. $this->error('操作频繁');
  232. }
  233. //订单详情
  234. $order_id = input('order_id',0);
  235. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  236. if(empty($wenzhen_order)){
  237. $this->error('不存在的订单');
  238. }
  239. if($wenzhen_order['ordertype'] == 1){
  240. if($wenzhen_order['status'] != 20){
  241. $this->error('已接诊订单才能完成');
  242. }
  243. $old_status = 20;
  244. }
  245. if($wenzhen_order['ordertype'] == 2){
  246. if($wenzhen_order['status'] != 25){
  247. $this->error('尚未发起视频,不能结束');
  248. }
  249. $old_status = 25;
  250. }
  251. //修改订单
  252. $nowtime = time();
  253. $update = [
  254. 'status' => 30,
  255. 'finish_time' => $nowtime,
  256. ];
  257. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',$old_status)->update($update);
  258. if(!$update_rs){
  259. $this->error('操作失败');
  260. }
  261. $this->success(1,'操作成功');
  262. }
  263. //反馈
  264. public function feedback(){
  265. $apilimit = $this->apiLimit();
  266. if(!$apilimit){
  267. $this->error('操作频繁');
  268. }
  269. //订单详情
  270. $order_id = input('order_id',0);
  271. $wenzhen_order = Db::name('wenzhen_order')->where('doctor_id',$this->auth->id)->where('id',$order_id)->find();
  272. if(empty($wenzhen_order)){
  273. $this->error('不存在的订单');
  274. }
  275. if($wenzhen_order['status'] != 30){
  276. $this->error('已完成订单才能反馈');
  277. }
  278. //修改订单
  279. $nowtime = time();
  280. $update = [
  281. 'feedback_time' => $nowtime,
  282. 'feedback_remark' => input('feedback_remark',''),
  283. 'feedback_images' => input('feedback_images',''),
  284. ];
  285. Db::startTrans();
  286. //医生
  287. $logtype = $wenzhen_order['ordertype'] == 1 ? 111 : 112;
  288. $rs_wallet = model('walletdoctor')->lockChangeAccountRemain($this->auth->id,'money',$wenzhen_order['total_fee'],$logtype,$remark='问诊订单','wenzhen_order',$order_id);
  289. if($rs_wallet['status'] === false){
  290. Db::rollback();
  291. $this->error($rs_wallet['msg']);
  292. }
  293. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',30)->update($update);
  294. if(!$update_rs){
  295. $this->error('反馈失败');
  296. Db::rollback();
  297. }
  298. Db::commit();
  299. $this->success(1,'反馈成功');
  300. }
  301. }