Wenzhen.php 8.6 KB

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