Appointment.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <?php
  2. namespace app\api\controller;
  3. use app\api\controller\base\Base;
  4. use app\common\model\Address;
  5. use app\common\model\Appointment as appointmentModel;
  6. use app\common\model\AppointmentApplication;
  7. use app\common\model\AppointmentTicket;
  8. use think\Exception;
  9. use time\DateHelper;
  10. class Appointment extends Base
  11. {
  12. //获取地址列表
  13. public function addressList()
  14. {
  15. $post = $this->request->param();
  16. $validate = new \think\Validate([
  17. ['page', 'number'],
  18. ['pagenum', 'number|<=:1000']
  19. ]);
  20. if (!$validate->check($post)) {
  21. $this->json_error('提交失败:' . $validate->getError());
  22. }
  23. $pagenum = $this->request->param('pagenum', 20, 'intval');
  24. $datalist = (new Address())->paginate($pagenum, true);
  25. if (empty($datalist)) {
  26. $this->json_error("没有数据");
  27. }
  28. foreach ($datalist as $key => $item) {
  29. $item['thumb_url'] = geturl($item->thumb, '', true);
  30. $datalist[$key] = $item;
  31. }
  32. $this->json_success("查询成功", $datalist);
  33. }
  34. //按地址id获取号源信息
  35. public function getTicketByAddressId()
  36. {
  37. $post = $this->request->param();
  38. $validate = new \think\Validate([
  39. ['address_id', 'require|number'],
  40. ['daytime', 'dateFormat:Y-m-d'],
  41. ]);
  42. if (!$validate->check($post)) {
  43. $this->json_error('提交失败:' . $validate->getError());
  44. }
  45. $address_id = $this->request->param('address_id');
  46. $daytime = $this->request->param('daytime', date('Y-m-d'));
  47. try {
  48. //生成工作日号源
  49. \app\common\model\Appointment::createWeekTicketAll($daytime);
  50. } catch (Exception $e) {
  51. $this->json_error($e->getMessage());
  52. }
  53. $ticketModel = new AppointmentTicket();
  54. $tickets = $ticketModel->where('address_id', $address_id)->where('appointment_daytime', strtotime($daytime))->select();
  55. foreach ($tickets as $k => $item) {
  56. $appoint = $item->appointment;
  57. //专家信息
  58. $item->specialist;
  59. $item->specialist->head_pic = geturl($item->specialist->head_pic, '', true);
  60. //拆分预约时段
  61. $ticketPeriods = (new AppointmentApplication())->where('appointment_ticket_id', $item->id)->column('appointment_time');
  62. $item['morning_time_period'] = $this->setPeriodStatus(DateHelper::splitTimePeriod($appoint->morning_start_time, $appoint->morning_end_time, $appoint->morning_num), $ticketPeriods);
  63. $item['afternoon_time_period'] = $this->setPeriodStatus(DateHelper::splitTimePeriod($appoint->afternoon_start_time, $appoint->afternoon_end_time, $appoint->afternoon_num), $ticketPeriods);
  64. $item['night_time_period'] = $this->setPeriodStatus(DateHelper::splitTimePeriod($appoint->night_start_time, $appoint->night_end_time, $appoint->night_num), $ticketPeriods);
  65. //剩余预约号码
  66. $item['morning_remaining'] = count($item['morning_time_period']);
  67. $item['afternoon_remaining'] = count($item['afternoon_time_period']);
  68. $item['night_remaining'] = count($item['night_time_period']);
  69. $tickets[$k] = $item;
  70. }
  71. $this->json_success("查询成功", $tickets);
  72. }
  73. /**
  74. * @param $timePeriods array 拆分的时间段
  75. * @param $ticketPeriods array 已经预约的时间段
  76. * @return array
  77. */
  78. private function setPeriodStatus($timePeriods, $ticketPeriods)
  79. {
  80. $daytime = $this->request->param('daytime', date('Y-m-d'));
  81. $arr = [];
  82. $now = time();
  83. foreach ($timePeriods as $ticket => $period) {
  84. //排除过期时段
  85. $timerang = explode(' - ', $period);
  86. $period_end = $timerang[1];
  87. if ($now > strtotime($daytime . ' ' . $period_end)) {
  88. continue;
  89. }
  90. //标记预约状态
  91. if (in_array($period, $ticketPeriods)) {
  92. // $arr[] = ['period' => $period, 'status' => 1];
  93. continue;//排除已被预约的
  94. } else {
  95. $arr[] = ['period' => $period, 'status' => 0];
  96. }
  97. }
  98. return $arr;
  99. }
  100. //按时间获取地址列表
  101. public function addressListByDayTime()
  102. {
  103. $ticketModel = new AppointmentTicket();
  104. $post = $this->request->param();
  105. $validate = new \think\Validate([
  106. ['daytime', 'date|dateFormat:Y-m-d'],
  107. ['page', 'number'],
  108. ['pagenum', 'number|<=:1000']
  109. ]);
  110. if (!$validate->check($post)) {
  111. $this->json_error('提交失败:' . $validate->getError());
  112. }
  113. $daytime = $this->request->param('daytime', date('Y-m-d'));
  114. try {
  115. //生成工作日号源
  116. \app\common\model\Appointment::createWeekTicketAll($daytime);
  117. } catch (Exception $e) {
  118. $this->json_error($e->getMessage());
  119. }
  120. $addressIds = $ticketModel->where('appointment_daytime', strtotime($daytime))->distinct(true)->column('address_id');
  121. $where = [];
  122. $where['id'] = ['in', $addressIds];
  123. $pagenum = $this->request->param('pagenum', 20, 'intval');
  124. $datalist = (new Address())->where($where)->paginate($pagenum, true);
  125. if (empty($datalist)) {
  126. $this->json_error("没有数据");
  127. }
  128. foreach ($datalist as $key => $item) {
  129. $item['thumb_url'] = geturl($item->thumb, '', true);
  130. $datalist[$key] = $item;
  131. }
  132. $this->json_success("查询成功", $datalist);
  133. }
  134. }