AppiontController.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Support\Facades\DB;
  4. use App\Models\Order;
  5. use App\Models\OrderPatient;
  6. use App\Models\Patient;
  7. use App\Models\User;
  8. use phpDocumentor\Reflection\Types\String_;
  9. class AppiontController extends Controller
  10. {
  11. public function __construct()
  12. {
  13. // 允许 $originarr 数组内的 域名跨域访问
  14. header('Access-Control-Allow-Origin:*');
  15. // 响应类型
  16. header('Access-Control-Allow-Methods:POST,GET,OPTIONS');
  17. // 带 cookie 的跨域访问
  18. header('Access-Control-Allow-Credentials: true');
  19. // 响应头设置
  20. header('Access-Control-Allow-Headers:x-requested-with,Content-Type,X-CSRF-Token,authorization');
  21. }
  22. public function getAppiontInfo()
  23. {
  24. // 允许 $originarr 数组内的 域名跨域访问
  25. header('Access-Control-Allow-Origin:*');
  26. // 响应类型
  27. header('Access-Control-Allow-Methods:POST,GET,OPTIONS');
  28. // 带 cookie 的跨域访问
  29. header('Access-Control-Allow-Credentials: true');
  30. // 响应头设置
  31. header('Access-Control-Allow-Headers:x-requested-with,Content-Type,X-CSRF-Token,authorization');
  32. $data = request()->all();
  33. $defaulRes = [
  34. 'server_handle_result'=>'0',
  35. 'reserve_check_result'=>'0',
  36. 'allow_get_ticket'=>'0',
  37. 'tip_msg'=>'',
  38. 'reserve_service_no'=>'Y',
  39. 'reserve_date'=>'',
  40. 'reserve_start_time'=>'',
  41. 'reserve_end_time'=>'',
  42. 'allow_post_ticket'=>'0',
  43. 'reserve_name'=>''
  44. ];
  45. if(request()->isMethod('post')){
  46. $defaulRes = ['server_handle_result'=>'0','tip_msg'=>'没有排号'];
  47. if(empty($data['orderId'])){
  48. $defaulRes['tip_msg'] = '请输入订单id';
  49. exit(json_encode($defaulRes));
  50. }
  51. if($data['reqNo']) {
  52. Order::where('id',intval($data['orderId']))->update(['is_ticket'=>1]);
  53. $defaulRes['server_handle_result'] = '1';
  54. $defaulRes['tip_msg'] = 'ok';
  55. }
  56. exit(json_encode($defaulRes));
  57. } else {
  58. if(empty($data['telephone'])){
  59. $defaulRes['tip_msg'] = '请输入手机号';
  60. exit(json_encode($defaulRes));
  61. }
  62. if(empty($data['sig'])){
  63. $defaulRes['tip_msg'] = '请输入sig签名';
  64. exit(json_encode($defaulRes));
  65. }
  66. if(empty($data['st']) ){
  67. $defaulRes['tip_msg'] = '请输入时间信息';
  68. exit(json_encode($defaulRes));
  69. }
  70. $sign = md5($data['id'].$data['telephone'].$data['barcode'].$data['st'].$data['area'].'2018');
  71. if(isset($data['sign']) && $data['sign'] == 1) dd($sign);
  72. if($data['sig'] != $sign){
  73. $defaulRes['tip_msg'] = '签名验证失败';
  74. exit(json_encode($defaulRes));
  75. }
  76. //先用患者表找,如果没有就直接查找用户表
  77. $user_id = Patient::where('phone',$data['telephone'])->value('user_id');
  78. if(empty($user_id)){
  79. $user_id = User::where('phone',$data['telephone'])->value('id');
  80. }
  81. if(empty($user_id)){
  82. $defaulRes['tip_msg'] = '无效账号';
  83. exit(json_encode($defaulRes));
  84. }
  85. DB::enableQueryLog();
  86. $order = Order::where('user_id',$user_id)
  87. ->where('organization_id',$data['area'])
  88. ->where('is_ticket','!=',1)
  89. ->where('product_type',4)
  90. ->select('id','order_sn','user_id','patient_id','is_ticket')
  91. ->with('orderPatient:order_id,appoint_start_time,appoint_end_time')
  92. ->with('patient:id,name');
  93. if($data['st']){
  94. $order = $order->whereHas('orderPatient',function ($query) use ($data){
  95. $query->whereBetween('appoint_end_time',[time(),strtotime('tomorrow')]);
  96. });
  97. }
  98. $order_list =$order->first();
  99. if(isset($data['sql']) && $data['sql'] == 1) dd(DB::getQueryLog());
  100. if(empty($order_list)){
  101. $defaulRes['tip_msg'] = '无预约';
  102. exit(json_encode($defaulRes));
  103. }
  104. $order = $order_list->toArray();
  105. $defaulRes['orderId'] = strval($order['id']);
  106. $defaulRes['server_handle_result'] = '1';
  107. if( $order['is_ticket'] == 0 && !empty($order['order_patient'])){
  108. $start = intval($order['order_patient']['appoint_start_time']);
  109. $end = intval($order['order_patient']['appoint_end_time']);
  110. $date = date('Y-m-d',intval($order['order_patient']['appoint_start_time']));
  111. if($end < time() ){
  112. $defaulRes['tip_msg'] = '预约已过期,您预约的时间为:'.$date.' '.date('H:i',$start).'~'.date('H:i',$end);
  113. exit(json_encode($defaulRes));
  114. }
  115. $defaulRes['reserve_start_time'] = date('H:i',$start);
  116. $defaulRes['reserve_end_time'] = date('H:i',$end);
  117. $defaulRes['allow_post_ticket'] = '1';
  118. $defaulRes['allow_get_ticket'] = '1';
  119. $defaulRes['reserve_check_result'] = '1';
  120. $defaulRes['reserve_date'] = $date;
  121. } else {
  122. $defaulRes['reserve_check_result'] = '1';
  123. $defaulRes['allow_post_ticket'] = '0';
  124. $defaulRes['tip_msg'] = '此订单已取号';
  125. }
  126. $defaulRes['reserve_name'] = $order['patient']['name'] ?? '';
  127. exit(json_encode($defaulRes));
  128. }
  129. }
  130. public function orverTime()
  131. {
  132. $st = strtotime('2020-02-25 18:00:00');
  133. $orders = Order::select('id')
  134. ->where(['product_type'=>4,'order_status'=>7])
  135. ->where('appoint_end_time','<',$st)->get();
  136. foreach ($orders as $order){
  137. Order::where('id',$order->id)->update(['order_status'=>4]);
  138. }
  139. }
  140. }