Wenzhen.php 8.3 KB

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