Remove bundle, add services in sculpin_kernel.yml
This commit is contained in:
parent
278c7a1d44
commit
ed4133b573
13 changed files with 341 additions and 479 deletions
|
|
@ -1,30 +0,0 @@
|
|||
# Talks Bundle
|
||||
|
||||
## Twig Extensions
|
||||
|
||||
### Functions
|
||||
* `getTalks()` - get all talks
|
||||
|
||||
```twig
|
||||
{% set talks = getTalks(data.talks) %}
|
||||
```
|
||||
|
||||
### Filters
|
||||
|
||||
* `events` - get events from talks
|
||||
|
||||
```twig
|
||||
{% set talks = getTalks(data.talks)|events
|
||||
```
|
||||
|
||||
* `past` - filter by past events
|
||||
|
||||
```twig
|
||||
{% set talks = getTalks(data.talks)|past
|
||||
```
|
||||
|
||||
* `upcoming` - filter by current and upcoming events
|
||||
|
||||
```twig
|
||||
{% set talks = getTalks(data.talks)|upcoming
|
||||
```
|
||||
|
|
@ -1,5 +0,0 @@
|
|||
{
|
||||
"require": {
|
||||
"tightenco/collect": "^5.4"
|
||||
}
|
||||
}
|
||||
|
|
@ -1,20 +0,0 @@
|
|||
<?php
|
||||
|
||||
namespace App\Talks\DependencyInjection;
|
||||
|
||||
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
||||
use Symfony\Component\HttpKernel\DependencyInjection\Extension;
|
||||
use Symfony\Component\DependencyInjection\Loader\YamlFileLoader;
|
||||
use Symfony\Component\Config\FileLocator;
|
||||
|
||||
class SculpinTalksExtension extends Extension
|
||||
{
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function load(array $configs, ContainerBuilder $container)
|
||||
{
|
||||
$loader = new YamlFileLoader($container, new FileLocator(__DIR__ . '/../Resources/config'));
|
||||
$loader->load('services.yml');
|
||||
}
|
||||
}
|
||||
|
|
@ -1,5 +0,0 @@
|
|||
services:
|
||||
twig.format_talks:
|
||||
class: 'App\Talks\TwigExtension\TalksExtension'
|
||||
tags:
|
||||
- { name: twig.extension }
|
||||
|
|
@ -1,9 +0,0 @@
|
|||
<?php
|
||||
|
||||
namespace App\Talks;
|
||||
|
||||
use Symfony\Component\HttpKernel\Bundle\Bundle;
|
||||
|
||||
class SculpinTalksBundle extends Bundle
|
||||
{
|
||||
}
|
||||
|
|
@ -1,96 +0,0 @@
|
|||
<?php
|
||||
|
||||
namespace App\Tests\Talks;
|
||||
|
||||
use App\Talks\TwigExtension\TalksExtension;
|
||||
use DateTime;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Tightenco\Collect\Support\Collection;
|
||||
|
||||
class RetrievingEventsTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var TalksExtension
|
||||
*/
|
||||
private $extension;
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function setUp()
|
||||
{
|
||||
$this->extension = new TalksExtension();
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function get_past_events()
|
||||
{
|
||||
$talkA = [
|
||||
'title' => 'Test Driven Drupal',
|
||||
'events' => [
|
||||
[
|
||||
'event' => 'php_south_wales',
|
||||
'date' => (new DateTime('+1 days'))->getTimestamp(),
|
||||
],
|
||||
[
|
||||
'event' => 'drupalcamp_london',
|
||||
'date' => (new DateTime('-1 days'))->getTimestamp(),
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
$talkB = [
|
||||
'title' => 'Taking Flight with Tailwind CSS',
|
||||
'events' => [
|
||||
[
|
||||
'event' => 'blue_conf_2019',
|
||||
'date' => (new DateTime('-2 days'))->getTimestamp(),
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
$talks = $this->extension->getTalks([$talkA, $talkB]);
|
||||
$events = $this->extension->filterPastEvents($talks);
|
||||
|
||||
$this->assertInstanceOf(Collection::class, $talks);
|
||||
$this->assertInstanceOf(Collection::class, $events);
|
||||
|
||||
$this->assertCount(2, $events);
|
||||
}
|
||||
/** @test */
|
||||
public function get_current_or_upcoming_events()
|
||||
{
|
||||
$talkA = [
|
||||
'title' => 'Test Driven Drupal',
|
||||
'events' => [
|
||||
[
|
||||
'event' => 'php_south_wales',
|
||||
'date' => (new DateTime('+0 days'))->getTimestamp(),
|
||||
],
|
||||
[
|
||||
'event' => 'drupalcamp_london',
|
||||
'date' => (new DateTime('-1 days'))->getTimestamp(),
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
$talkB = [
|
||||
'title' => 'Taking Flight with Tailwind CSS',
|
||||
'events' => [
|
||||
[
|
||||
'event' => 'blue_conf_2019',
|
||||
'date' => (new DateTime('+2 days'))->getTimestamp(),
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
|
||||
$talks = $this->extension->getTalks([$talkA, $talkB]);
|
||||
$events = $this->extension->filterUpcomingEvents($talks);
|
||||
|
||||
$this->assertInstanceOf(Collection::class, $talks);
|
||||
$this->assertInstanceOf(Collection::class, $events);
|
||||
|
||||
$this->assertCount(2, $events);
|
||||
}
|
||||
}
|
||||
|
|
@ -1,180 +0,0 @@
|
|||
<?php
|
||||
|
||||
namespace App\Tests\Talks;
|
||||
|
||||
use App\Talks\TwigExtension\TalksExtension;
|
||||
use DateTime;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Tightenco\Collect\Support\Collection;
|
||||
|
||||
class RetrievingTalksTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var TalksExtension
|
||||
*/
|
||||
private $extension;
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function setUp()
|
||||
{
|
||||
$this->extension = new TalksExtension();
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function talks_given_multiple_times_are_only_returned_once()
|
||||
{
|
||||
$talkA = [
|
||||
'title' => 'Talk A',
|
||||
'events' => [
|
||||
['event' => 'event_a', 'date' => (new DateTime('-1 days'))->getTimestamp()],
|
||||
['event' => 'event_b', 'date' => (new DateTime('+1 days'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$talkB = [
|
||||
'title' => 'Talk B',
|
||||
'events' => [
|
||||
['event' => 'event_a', 'date' => (new DateTime('-3 days'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$this->assertCount(2, $this->extension->getTalks([$talkA, $talkB]));
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function talks_are_ordered_by_the_most_recent_event_date()
|
||||
{
|
||||
$talkA = [
|
||||
'title' => 'Talk A',
|
||||
'events' => [
|
||||
['event' => 'event_a', 'date' => (new DateTime('-5 days'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$talkB = [
|
||||
'title' => 'Talk B',
|
||||
'events' => [
|
||||
['event' => 'event_a', 'date' => (new DateTime('-20 days'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$talkC = [
|
||||
'title' => 'Talk C',
|
||||
'events' => [
|
||||
['event' => 'event_a', 'date' => (new DateTime('-3 days'))->getTimestamp()],
|
||||
['event' => 'event_b', 'date' => (new DateTime('-10 days'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$unorderedTalks = [$talkC, $talkA, $talkB];
|
||||
$orderedTalks = $this->extension->getTalks($unorderedTalks);
|
||||
|
||||
$this->assertEquals([$talkC, $talkA, $talkB], $orderedTalks->toArray());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function only_past_talks_can_be_retrieved()
|
||||
{
|
||||
$pastTalk = [
|
||||
'title' => 'Past talk',
|
||||
'events' => [
|
||||
['date' => (new DateTime('-1 day'))->getTimestamp()],
|
||||
]
|
||||
];
|
||||
|
||||
$futureTalk = [
|
||||
'title' => 'Future talk',
|
||||
'events' => [
|
||||
['date' => (new DateTime('+1 day'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$talks = $this->extension->getTalks([$pastTalk, $futureTalk]);
|
||||
$filtered = $this->extension->filterPastTalks($talks);
|
||||
|
||||
$this->assertCount(1, $filtered);
|
||||
$this->assertSame($pastTalk, $filtered->first());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function only_current_and_future_talks_can_be_retrieved()
|
||||
{
|
||||
$pastTalk = [
|
||||
'title' => 'Past talk',
|
||||
'events' => [
|
||||
['date' => (new DateTime('-1 day'))->getTimestamp()],
|
||||
]
|
||||
];
|
||||
|
||||
$todayTalk = [
|
||||
'title' => 'A talk that it happening today',
|
||||
'events' => [
|
||||
['date' => (new DateTime('now'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$futureTalk = [
|
||||
'title' => 'Future talk',
|
||||
'events' => [
|
||||
['date' => (new DateTime('+1 day'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$talks = $this->extension->getTalks([$pastTalk, $todayTalk, $futureTalk]);
|
||||
$filtered = $this->extension->filterUpcomingTalks($talks);
|
||||
|
||||
$this->assertSame(2, $filtered->count());
|
||||
$this->assertSame([$todayTalk, $futureTalk], $filtered->toArray());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function if_a_talk_is_both_upcoming_and_past_then_it_is_only_shown_as_upcoming()
|
||||
{
|
||||
$talk = [
|
||||
'title' => 'An upcoming talk that has been given before',
|
||||
'events' => [
|
||||
['date' => (new DateTime('-1 week'))->getTimestamp()],
|
||||
['date' => (new DateTime('+1 week'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$talks = $this->extension->getTalks([$talk]);
|
||||
|
||||
$this->assertCount(1, $this->extension->filterUpcomingTalks($talks));
|
||||
$this->assertEmpty($this->extension->filterPastTalks($talks));
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function get_events_from_talks()
|
||||
{
|
||||
$talkA = [
|
||||
'title' => 'Talk A',
|
||||
'events' => [
|
||||
['event' => 'event_a', 'date' => (new DateTime('-1 days'))->getTimestamp()],
|
||||
['event' => 'event_b', 'date' => (new DateTime('+1 days'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$talkB = [
|
||||
'title' => 'Talk B',
|
||||
'events' => [
|
||||
['event' => 'event_a', 'date' => (new DateTime('-3 days'))->getTimestamp()],
|
||||
],
|
||||
];
|
||||
|
||||
$talks = collect([$talkA, $talkB]);
|
||||
|
||||
tap($this->extension->getAllEvents($talks), function (Collection $events) {
|
||||
$this->assertCount(3, $events);
|
||||
|
||||
$this->assertSame(
|
||||
['event_a', 'event_b', 'event_a'],
|
||||
$events->pluck('event')->toArray()
|
||||
);
|
||||
|
||||
$this->assertSame(3, $events->pluck('date')->unique()->count());
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
@ -1,6 +1,6 @@
|
|||
<?php
|
||||
|
||||
namespace App\Talks\TwigExtension;
|
||||
namespace App\TwigExtension\Talk;
|
||||
|
||||
use Sculpin\Contrib\ProxySourceCollection\ProxySourceCollection;
|
||||
use Tightenco\Collect\Support\Collection;
|
||||
Loading…
Add table
Add a link
Reference in a new issue