Wenzhen.php 9.8 KB

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