Wenzhen.php 8.3 KB

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