oliverdavies.uk/src/FormatTalksBundle/Twig/FormatTalksExtension.php

120 lines
2.9 KiB
PHP
Raw Normal View History

2017-10-28 00:31:21 +01:00
<?php
2017-10-28 12:17:09 +01:00
namespace FormatTalksBundle\Twig;
2017-10-28 00:31:21 +01:00
2017-10-29 20:10:04 +00:00
use Illuminate\Support\Collection;
use Twig_Extension;
use Twig_SimpleFilter;
class FormatTalksExtension extends Twig_Extension
2017-10-28 00:31:21 +01:00
{
2017-10-29 21:55:38 +00:00
/**
* @var string The current date.
*/
private $today;
2017-11-01 17:24:23 +00:00
public function __construct()
{
$this->today = (new \DateTime())->format('Y-m-d');
}
2017-10-28 00:31:21 +01:00
/**
* {@inheritdoc}
*/
public function getFilters()
{
return [
2017-10-29 20:10:04 +00:00
new Twig_SimpleFilter('all_talks', [$this, 'getAll']),
new Twig_SimpleFilter('upcoming_talks', [$this, 'getUpcoming']),
new Twig_SimpleFilter('past_talks', [$this, 'getPast']),
2017-10-28 00:31:21 +01:00
];
}
2017-10-29 20:10:04 +00:00
/**
* Get all upcoming and previous talks.
*
* Used to display the talk table on a specific talk page.
*
* @param array $data An associative array of talk and event data.
*
* @return array
*/
public function getAll(array $data) {
return $this->sort($this->format($data));
}
/**
* Get all upcoming talks.
*
* Used on the main talks page.
*
* @param array $data The talk and event data.
*
* @return array
*/
public function getUpcoming(array $data) {
2017-11-02 00:16:43 +00:00
return $this->sort($this->format($data)->filter(function ($talk) {
2017-10-29 21:55:38 +00:00
return $talk['event']['date'] >= $this->today;
2017-11-02 00:16:43 +00:00
}));
2017-10-29 20:10:04 +00:00
}
/**
* Get all past talks.
*
* Used on the main talks page and the talks archive.
*
* @param array $data The talk and event data.
*
* @return array
*/
public function getPast(array $data) {
2017-11-02 00:16:43 +00:00
return $this->sort($this->format($data)->filter(function ($talk) {
2017-10-29 21:55:38 +00:00
return $talk['event']['date'] < $this->today;
2017-11-02 00:16:43 +00:00
}));
2017-10-29 20:10:04 +00:00
}
/**
* Format the talk data into the required format.
*
* @param array $data The talk and event data.
*
* @return Collection The event and talk data.
*/
public function format(array $data)
{
2017-11-01 20:04:53 +00:00
$event_data = collect($data['event_data']);
2017-10-29 20:10:04 +00:00
2017-11-01 20:04:53 +00:00
return collect($data['talks'])->flatMap(function ($talk) use ($event_data) {
2017-10-28 13:16:35 +01:00
// Build an associative array with the talk, as well as the
// specified event data (e.g. date and time) as well as the shared
// event data (e.g. event name and website).
2017-11-01 20:04:53 +00:00
return collect($talk['events'])->map(function ($event) use ($talk, $event_data) {
2017-10-28 13:16:35 +01:00
$event = collect($event);
2017-11-01 20:04:53 +00:00
$event = $event->merge($event_data->get($event->get('event')))->all();
2017-10-28 13:16:35 +01:00
return compact('event', 'talk');
});
2017-10-29 20:10:04 +00:00
});
}
2017-10-29 20:10:04 +00:00
/**
* Sort and return the talks.
*
* @param Collection $talks The talk data.
*
* @return array
*/
private function sort(Collection $talks)
{
return $talks->sortByDesc('event.date')->all();
2017-10-28 00:31:21 +01:00
}
/**
* {@inheritdoc}
*/
public function getName()
{
return 'format_talks';
}
}