Wenzhen.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. <?php
  2. namespace app\api\controller\tvuser;
  3. use app\common\controller\Api;
  4. use think\Db;
  5. use addons\epay\library\Service;
  6. use app\common\library\Tenim;
  7. use app\common\model\Wenzhenorder;
  8. /**
  9. * 问诊订单
  10. */
  11. class Wenzhen extends Api
  12. {
  13. protected $noNeedLogin = '';
  14. protected $noNeedRight = '*';
  15. //添加成员
  16. private function add_member(){
  17. $field = [
  18. 'gender',
  19. 'age',
  20. 'marital_status',
  21. 'allergies_status',
  22. 'familymedical_status',
  23. 'chronicdisease_status',
  24. ];
  25. $data = request_post_hub($field);
  26. $data['user_id'] = $this->auth->id;
  27. return $data;
  28. }
  29. //判断是否 健康E家自己的vip
  30. private function checkvip(){
  31. $is_my_vip = 0;
  32. $tv_userid = $this->auth->tv_userid;
  33. //跨数据库查询
  34. $tv_user = Db::connect('database_tv')->name('hu_user')->where('id',$tv_userid)->find();
  35. if(!empty($tv_user)){
  36. $is_my_vip = $tv_user['is_my_vip'];
  37. }
  38. return $is_my_vip;
  39. }
  40. //创建订单
  41. public function create_order(){
  42. //判断用户来源
  43. if($this->auth->comefrom != 2){
  44. $this->error('用户错误');
  45. }
  46. //判断是否 健康E家自己的vip
  47. $checkvip = $this->checkvip();
  48. if(!$checkvip){
  49. $this->error('您不是健康E家的VIP用户');
  50. }
  51. //检查本月是否已经下过一个有效单了
  52. $checkmap = [
  53. 'user_id' => $this->auth->id,
  54. 'comefrom'=> 2,
  55. 'status' => ['IN','10,20,25,30'],//有效订单
  56. ];
  57. $check_order = Db::name('wenzhen_order')->where($checkmap)->whereTime('createtime','month')->find();
  58. if(!empty($check_order)){
  59. $this->error('您本月的免费问诊次数已用完');
  60. }
  61. //问诊患者
  62. $member_data = $this->add_member();
  63. //问诊信息
  64. $doctor_id = input('doctor_id',0);
  65. $ordertype = 2;
  66. $book_date = input('book_date',0); //2024-05-05
  67. $book_hour = input('book_time',0); //10:00
  68. $book_time = strtotime($book_date.' '.$book_hour);
  69. $auth_id = $this->auth->id;
  70. $order_no = createUniqueNo('TV',$auth_id);
  71. //医生信息
  72. $doctor_info = Db::name('doctor_info')->where('doctor_id',$doctor_id)->find();
  73. if(empty($doctor_info)){
  74. $this->error('不存在的医生');
  75. }
  76. //价格
  77. $price = 0;
  78. if($ordertype == 2){
  79. if($doctor_info['video_switch'] != 1){
  80. $this->error('该医生未开通视频问诊');
  81. }
  82. }
  83. //排班判断
  84. if($ordertype == 2){
  85. //检查
  86. if($book_time < time() + 7200){
  87. //测试临时屏蔽
  88. //$this->error('最早只能预约'.date('m-d H:00',time() + 10800)); //最早预约两个小时后的一个整点
  89. }
  90. //排班状态
  91. $doctor_paiban = Db::name('doctor_paiban')->where('doctor_id',$doctor_id)->where('activetime',$book_time)->find();
  92. if(empty($doctor_paiban)){
  93. $this->error('您预约的时间该医生无法接诊');
  94. }
  95. if($doctor_paiban['active'] != 1){
  96. $this->error('您预约的时间该医生无法接诊');
  97. }
  98. //是否排满
  99. $map = [
  100. 'doctor_id' => $doctor_id,
  101. 'book_time' => $book_time,
  102. 'ordertype' => 2,
  103. 'status' => ['IN','10,20,25,30'],//有效订单
  104. ];
  105. $order_count = Db::name('wenzhen_order')->where($map)->count();
  106. if($order_count >= 4){
  107. $this->error('该时间点已排满');
  108. }
  109. }
  110. //订单数据
  111. $order_data = [
  112. 'order_no' => $order_no,
  113. 'user_id' => $auth_id,
  114. 'member_id' => 0,
  115. 'doctor_id' => $doctor_id,
  116. 'ordertype' => $ordertype,
  117. 'total_fee' => $price,
  118. 'book_time' => $book_time,
  119. 'createtime' => time(),
  120. 'status' => 10,//订单状态enum
  121. 'pay_type' => 'tvvip',
  122. 'pay_time' => time(),
  123. 'comefrom' => 2,
  124. ];
  125. Db::startTrans();
  126. //下单
  127. $order_id = Db::name('wenzhen_order')->insertGetId($order_data);
  128. if(!$order_id){
  129. Db::rollback();
  130. $this->error('下单失败');
  131. }
  132. //订单附表,就诊人信息
  133. $member_data['order_id'] = $order_id;
  134. $order_member_id = Db::name('wenzhen_order_member')->insertGetId($member_data);
  135. if(!$order_member_id){
  136. Db::rollback();
  137. $this->error('下单失败');
  138. }
  139. //
  140. Db::commit();
  141. $this->success('下单成功',$order_id);
  142. }
  143. //订单列表
  144. public function order_list(){
  145. //判断用户来源
  146. if($this->auth->comefrom != 2){
  147. $this->error('用户错误');
  148. }
  149. $status = input('status','all');
  150. $where = ['user_id'=>$this->auth->id];
  151. if($status != 'all'){
  152. $where['order.status'] = $status;
  153. if($status == 20){// 已接诊、问诊中
  154. $where['order.status'] = ['IN',[20,25]];
  155. }
  156. }
  157. $field = [
  158. 'order.id','order.order_no','order.book_time','order.status','order.ordertype','order.accept_time','order.video_time','order.doctor_id',
  159. 'doctor.avatar as doctor_avatar','doctor.nickname as doctor_nickname','doctor.hospital as doctor_hospital',
  160. 'keshi.name as keshi_name',
  161. 'level.name as level_name',
  162. ];
  163. $list = Db::name('wenzhen_order')->alias('order')
  164. ->field($field)
  165. ->join('doctor','order.doctor_id = doctor.id','LEFT')
  166. ->join('doctor_level level','doctor.level_id = level.id','LEFT')
  167. ->join('keshi','doctor.keshi_id = keshi.id','LEFT')
  168. ->order('order.id desc')
  169. ->where($where)
  170. ->autopage()->select();
  171. $list = list_domain_image($list,['doctor_avatar']);
  172. if(!empty($list)){
  173. //循环处理
  174. foreach($list as $key => $val){
  175. //医生原因的退款,都直接算到退珍
  176. if(in_array($val['status'],[16,18,22])){
  177. $val['status'] = 100;
  178. }
  179. //视频拨打中 也算问诊中
  180. if($val['status'] == 25){
  181. $val['status'] = 20;
  182. }
  183. $list[$key] = $val;
  184. }
  185. }
  186. $this->success(1,$list);
  187. }
  188. //用户发起退珍
  189. //因为存在第三方,悲观锁
  190. public function tuizhen(){
  191. $apilimit = $this->apiLimit();
  192. if(!$apilimit){
  193. $this->error('操作频繁');
  194. }
  195. //判断用户来源
  196. if($this->auth->comefrom != 2){
  197. $this->error('用户错误');
  198. }
  199. //订单详情
  200. $order_id = input('order_id',0);
  201. Db::startTrans();
  202. $wenzhen_order = Db::name('wenzhen_order')->where('user_id',$this->auth->id)->where('comefrom',2)->where('id',$order_id)->lock(true)->find();
  203. if(empty($wenzhen_order)){
  204. Db::rollback();
  205. $this->error('不存在的订单');
  206. }
  207. //仅限视频订单
  208. if($wenzhen_order['ordertype'] == 1){
  209. Db::rollback();
  210. $this->error('图文问诊不能退诊');
  211. }
  212. //状态限制
  213. if(!in_array($wenzhen_order['status'],[10,20])){
  214. Db::rollback();
  215. $this->error('当前订单不能退诊');
  216. }
  217. //修改订单
  218. $nowtime = time();
  219. $update = [
  220. 'status' => 13,
  221. 'cancel_time' => $nowtime,
  222. 'cancel_reason' => '用户退诊',
  223. 'finish_time' => $nowtime,
  224. ];
  225. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->update($update);
  226. if(!$update_rs){
  227. Db::rollback();
  228. $this->error('退诊失败');
  229. }
  230. Db::commit();
  231. $this->success('退珍成功');
  232. }
  233. }