program - show events without sessions at the end of next events #18
This commit is contained in:
parent
9c55ee0e5d
commit
881f384e22
2 changed files with 21 additions and 17 deletions
|
|
@ -1,36 +1,37 @@
|
|||
<?php
|
||||
|
||||
return function($kirby) {
|
||||
$orderedSeason = new Pages();
|
||||
|
||||
foreach ($kirby->collection('current-season')->children() as $event) {
|
||||
$sessions = $event->isMapadoEvent() == 'true' ? $event->remoteSessions()->toStructure() : $event->sessions()->toStructure();
|
||||
|
||||
$sessionDates = $sessions->map(function($session) {
|
||||
return $session->date()->value();
|
||||
})->data;
|
||||
|
||||
if (!empty($sessionDates)) {
|
||||
$orderedSeason->add($event);
|
||||
}
|
||||
$orderedSeason->add($event);
|
||||
}
|
||||
|
||||
$endOfProgramEvents = $orderedSeason->filter(function ($event) {
|
||||
$sessions = $event->isMapadoEvent() == 'true' ? $event->remoteSessions()->toStructure() : $event->sessions()->toStructure();
|
||||
$sessionDates = $sessions->map(function($session) {
|
||||
return $session->date()->value();
|
||||
})->data;
|
||||
|
||||
$normalEvents = $orderedSeason->filter(function ($event) {
|
||||
return $event->status() === 'listed';
|
||||
return empty($sessionDates) || $event->status() === 'unlisted';
|
||||
});
|
||||
|
||||
$endOfProgramEvents = $orderedSeason->filter(function ($event) {
|
||||
return $event->status() === 'unlisted';
|
||||
$normalEvents = $orderedSeason->filter(function ($event) use ($endOfProgramEvents) {
|
||||
return $event->status() === 'listed' && !$endOfProgramEvents->has($event);
|
||||
});
|
||||
|
||||
$normalEvents = $normalEvents->sortBy(function ($event) {
|
||||
$sessions = $event->isMapadoEvent() == 'true' ? $event->remoteSessions()->toStructure() : $event->sessions()->toStructure();
|
||||
|
||||
$sessionDates = $sessions->map(function($session) {
|
||||
return $session->date()->value();
|
||||
})->data;
|
||||
|
||||
return min($sessionDates);
|
||||
return !empty($sessionDates) ? min($sessionDates) : PHP_INT_MAX;
|
||||
});
|
||||
|
||||
$orderedSeason = $normalEvents->merge($endOfProgramEvents);
|
||||
|
|
|
|||
|
|
@ -22,24 +22,24 @@ function getMonthNumber($month) {
|
|||
function splitNextAndPreviousEvents($events) {
|
||||
$next = new Pages();
|
||||
$previous = new Pages();
|
||||
$noDateEvents = new Pages();
|
||||
|
||||
foreach ($events as $event) {
|
||||
$sessions = $event->isMapadoEvent() == 'true' ? $event->remoteSessions()->toStructure() : $event->sessions()->toStructure();
|
||||
|
||||
$sessionDates = $sessions->map(function($session) {
|
||||
return $session->date()->value();
|
||||
})->data;
|
||||
|
||||
if (empty($sessionDates)) {
|
||||
$noDateEvents->add($event);
|
||||
continue;
|
||||
}
|
||||
|
||||
$futureDates = array_filter($sessionDates, function ($date) {
|
||||
// strtotime() gives the timestamp for midnight
|
||||
// time() gives the current timestamp so if the event occurs today it will be considered as past after midnight
|
||||
// so we need to add a day, in seconds
|
||||
$oneDayInSecond = 24*60*60;
|
||||
$oneDayInSecond = 24 * 60 * 60;
|
||||
$dateTimeStamp = strtotime($date) + $oneDayInSecond;
|
||||
|
||||
return $dateTimeStamp >= time();
|
||||
});
|
||||
|
||||
|
||||
if (!empty($futureDates)) {
|
||||
$next->add($event);
|
||||
|
|
@ -48,12 +48,15 @@ function splitNextAndPreviousEvents($events) {
|
|||
}
|
||||
}
|
||||
|
||||
$next = $next->merge($noDateEvents);
|
||||
|
||||
return [
|
||||
'next' => $next,
|
||||
'previous' => $previous,
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
function buildFieldsString($requestFields) {
|
||||
$fields = [];
|
||||
foreach ($requestFields as $field) {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue