Как проверить забронированные слоты с указанием дат - PullRequest
0 голосов
/ 31 марта 2020

Это мой массив, и я хочу вернуть массив, который уже забронировал дату.
В настоящее время он работает по времени, но когда я делаю это более одного дня, он перестает работать:

$bookedData  = array(   
    Id : 1
    date : "2020-03-31"
    endDate : "2020-04-01"
    time : "19:00:00"
    endTime : "11:30:00"
)
foreach($bookedData as $booked) {             /* checking fr all slots*/
    if (strlen($booked->time) > 0 && strlen($booked->endTime) > 0 {
        if ($booked->time !=$booked->endTime) {
            $appStrtTime = strtotime($booked->time); /* It gives time startTime */
            $appEndTime = strtotime($booked->endtime); /* It gives endTime */

            $AddMins = 5*60;
            while ($appStartTime < $appEndTime) {  /* if starttime is less than endtime then return false */
                $time = date("G:i:s", $appStartTime);
                $key = array_search($time, $ReturnArray);
                if($key!= false) {
                    unset($ReturnArray[$key]); /* if slot already available then unset it */
                }
                $appStartTime +=$AddMins;
            }
            $appStartTime += $AddMins;
        }
    } else {
        $key = array_search($booked->time, $ReturnArray);
        if ($key != false) {
                unset($ReturnArray[$key]);
        }
    }
    }
}
if (count($ReturnArray) > 0) {
    unset($ReturnArray[count($ReturnArray) - 1]);
}
$ReturnArray = array_values($ReturnArray);  
}

Ответы [ 2 ]

0 голосов
/ 02 апреля 2020

Согласно вашему комментарию

Например, если я выберу дату начала 31 марта, а время 19:00, то я хочу получить все слоты после этого времени, например 19: 00,19: 15, ... До даты окончания

Я хотел бы go для этого кода здесь:

$start = new \DateTime('2020-03-31 19:00');
$end = new \DateTime('2020-03-31 21:30');
$slotSize = 15; // 15 minute intervals

$slots = [];
do {
    // Add here your custom code to skip specific timeslots
    // As an example I used a custom function as an example
    if (slot_is_blocked_by_existing_bookings($slot, $bookings)) {
        continue;
    }

    $slots[] = clone $start;
} while ($start->add(new \DateInterval("PT{$slotSize}M")) <= $end);

и вот пример вывода списка $slots, который содержит DateTime-objets (строка, отформатированная в RFC3339 для удобства чтения)

array:11 [
  0 => "2020-03-31T19:00:00+00:00"
  1 => "2020-03-31T19:15:00+00:00"
  2 => "2020-03-31T19:30:00+00:00"
  3 => "2020-03-31T19:45:00+00:00"
  4 => "2020-03-31T20:00:00+00:00"
  5 => "2020-03-31T20:15:00+00:00"
  6 => "2020-03-31T20:30:00+00:00"
  7 => "2020-03-31T20:45:00+00:00"
  8 => "2020-03-31T21:00:00+00:00"
  9 => "2020-03-31T21:15:00+00:00"
  10 => "2020-03-31T21:30:00+00:00"
]
0 голосов
/ 31 марта 2020

Вот некоторые правки вашего кода:

$appStartTime = strtotime($booked['date'] . ' ' . $booked['time']);
$appEndTime = strtotime($booked['endDate'] . ' ' . $booked['endTime']);
while ($appStartTime < $appEndTime) 
{

   $time = strtotime($appStartTime);
   // ...carry on with the rest of the code

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...