Skip to content

Commit

Permalink
EWPP-2714: Adapt Event Description extra field rendering.
Browse files Browse the repository at this point in the history
  • Loading branch information
22Alexandra committed Nov 15, 2022
1 parent f9333e7 commit dd9760c
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 23 deletions.
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@
"openeuropa/behat-transformation-context": "~0.1",
"openeuropa/code-review": "^2.0",
"openeuropa/oe_contact_forms": "^1.5",
"openeuropa/oe_content": "^3.0.0-alpha4",
"openeuropa/oe_content": "dev-EWPP-2714",
"openeuropa/oe_corporate_blocks": "^4.4",
"openeuropa/oe_corporate_countries": "~2.0",
"openeuropa/oe_media": "^1.19",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,12 @@ public function viewElements(ContentEntityInterface $entity) {
$build['#fields']['title'] = $title;
$build['#fields']['text'] = $text;

// If we have a media but no description text, we use the 'right_simple'
// variant of the pattern to render the media on the left side.
if (empty($build['#fields']['text']) && isset($build['#fields']['image'])) {
$build['#variant'] = 'right_simple';
}

return $build;
}

Expand Down Expand Up @@ -159,13 +165,18 @@ public function getRenderableTitle(ContentEntityInterface $entity): array {
public function getRenderableText(ContentEntityInterface $entity): array {
$event = EventNodeWrapper::getInstance($entity);

// By default 'body' is the event description field.
// If the event is over and we have a report, we use 'oe_event_report_text'.
// By default 'body' is the event description field. If the event is over,
// we use 'oe_event_report_text'.
$field_name = 'body';
if ($event->isOver($this->requestDateTime) && !$entity->get('oe_event_report_text')->isEmpty()) {
if ($event->isOver($this->requestDateTime)) {
$field_name = 'oe_event_report_text';
}

// If the field we're using is empty, we don't have a description text.
if ($entity->get($field_name)->isEmpty()) {
return [];
}

/** @var \Drupal\Core\Entity\EntityViewBuilderInterface $view_builder */
$view_builder = $this->entityTypeManager->getViewBuilder('node');
$build = $view_builder->viewField($entity->get($field_name), [
Expand Down Expand Up @@ -222,7 +233,12 @@ protected function addFeaturedMediaThumbnail(array &$build, ContentEntityInterfa
$cache->addCacheableDependency($thumbnail->entity);
$build['#fields']['image'] = ImageValueObject::fromImageItem($thumbnail);

// Only display a caption if we have an image to be captioned by.
// Only display a caption if we have an image to be captioned by and there
// is a caption set.
if ($entity->get('oe_event_featured_media_legend')->isEmpty()) {
$cache->applyTo($build);
return;
}
/** @var \Drupal\Core\Entity\EntityViewBuilderInterface $view_builder */
$view_builder = $this->entityTypeManager->getViewBuilder('node');
$build['#fields']['caption'] = $view_builder->viewField($entity->get('oe_event_featured_media_legend'), [
Expand Down
40 changes: 22 additions & 18 deletions tests/src/Functional/ContentEventRenderTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -498,36 +498,40 @@ public function testEventRendering(): void {

// Assert "Description" title is not rendered unless there is a body text.
$this->assertSession()->pageTextNotContains('Description');

// Assert "Full text", "Featured media", "Featured media legend" fields.
$node->set('body', 'Event full text');
$node->save();
$this->drupalGet($node->toUrl());

$description_content = $this->assertSession()->elementExists('css', 'article > div > div:nth-child(3)');
$text_featured = new TextFeaturedMediaAssert();
$text_featured_expected_values = [
'title' => 'Description',
'text' => 'Event full text',
];
$text_featured->assertPattern($text_featured_expected_values, $description_content->getHtml());

$node->set('oe_event_featured_media_legend', 'Event featured media legend');
// Fill in "Featured media" field.
$media_image = $this->createMediaImage('event_featured_media');
$node->set('oe_event_featured_media', [$media_image])->save();
$this->drupalGet($node->toUrl());

// Assert "Description" field group contains only the heading and media.
$description_content = $this->assertSession()->elementExists('css', 'article > div > div:nth-child(3)');
$text_featured = new TextFeaturedMediaAssert();
// Caption should not be rendered if the legend is not provided.
$text_featured_expected_values = [
'title' => 'Description',
'caption' => 'Event featured media legend',
'text' => 'Event full text',
'caption' => NULL,
'image' => [
'alt' => 'Alternative text event_featured_media',
'src' => 'event_featured_media.png',
],
];
// If the "Full text" field is not filled in, we render using the
// "right_simple" variant with the image on the left.
$text_featured->assertVariant('right_simple', $description_content->getHtml());
$text_featured->assertPattern($text_featured_expected_values, $description_content->getHtml());
// Fill in "Featured media legend" field.
$node->set('oe_event_featured_media_legend', 'Event featured media legend')->save();
$this->drupalGet($node->toUrl());
// Assert caption is rendered.
$text_featured_expected_values['caption'] = 'Event featured media legend';
$text_featured->assertPattern($text_featured_expected_values, $description_content->getHtml());

// Fill in the "Full text" field too.
$node->set('body', 'Event full text')->save();
$this->drupalGet($node->toUrl());
$text_featured_expected_values['text'] = 'Event full text';
// Assert we render using the "left_simple" variant when "Full text" is
// provided.
$text_featured->assertVariant('left_simple', $description_content->getHtml());
$text_featured->assertPattern($text_featured_expected_values, $description_content->getHtml());

// Assert "Description summary" field value.
Expand Down

0 comments on commit dd9760c

Please sign in to comment.