Skip to content

Commit

Permalink
EWPP-3321: Update List with illustrations pattern and paragraphs rend…
Browse files Browse the repository at this point in the history
…ering.
  • Loading branch information
22Alexandra committed Jun 9, 2023
1 parent c62cfbb commit 02d69fe
Show file tree
Hide file tree
Showing 10 changed files with 145 additions and 8 deletions.
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@
"openeuropa/oe_corporate_countries": "^2.0.0-alpha8",
"openeuropa/oe_media": "^1.23.1",
"openeuropa/oe_multilingual": "^1.13",
"openeuropa/oe_paragraphs": "^1.19",
"openeuropa/oe_paragraphs": "dev-EWPP-3320",
"openeuropa/oe_search": "^2.0@beta",
"openeuropa/oe_webtools": "^1.23",
"openeuropa/rdf_skos": "^1.0.0-alpha10",
Expand Down
18 changes: 18 additions & 0 deletions oe_theme.theme
Original file line number Diff line number Diff line change
Expand Up @@ -1858,6 +1858,13 @@ function _oe_theme_preprocess_paragraph_oe_illustration_list(array &$variables):
// Set the column value based on the selected variant.
$variant_value = $paragraph->get('oe_paragraphs_variant')->first()->value;
$variables['column'] = $variant_value === 'oe_illustration_vertical' ? 1 : $paragraph->get('field_oe_illustration_columns')->value;

if ($paragraph->hasField('field_oe_subtitle') && !$paragraph->get('field_oe_subtitle')->isEmpty()) {
$variables['value'] = $paragraph->get('field_oe_subtitle')->value;
}
if ($paragraph->hasField('field_oe_center') && !$paragraph->get('field_oe_center')->isEmpty()) {
$variables['centered'] = $paragraph->get('field_oe_center')->value;
}
}

/**
Expand Down Expand Up @@ -1914,6 +1921,7 @@ function oe_theme_preprocess_paragraph__oe_illustration_list_flags(array &$varia
'title' => $sub_paragraph->get('field_oe_title')->value,
'description' => $sub_paragraph->get('field_oe_text_long')->isEmpty() ? '' : $builder->viewField($sub_paragraph->get('field_oe_text_long')),
'icon' => $icon,
'value' => $variables['value'] ?? '',
];
}
}
Expand All @@ -1926,6 +1934,9 @@ function oe_theme_preprocess_paragraph__oe_illustration_list_icons(array &$varia
$variables['items'] = [];

$paragraph = $variables['paragraph'];
if ($paragraph->hasField('field_oe_size') && !$paragraph->get('field_oe_size')->isEmpty()) {
$size = substr($paragraph->get('field_oe_size')->value, 0, 1);
}
$builder = \Drupal::entityTypeManager()->getViewBuilder('paragraph');
/** @var \Drupal\paragraphs\Entity\Paragraph $sub_paragraph */
foreach ($paragraph->get('field_oe_paragraphs')->referencedEntities() as $sub_paragraph) {
Expand All @@ -1936,6 +1947,8 @@ function oe_theme_preprocess_paragraph__oe_illustration_list_icons(array &$varia
'title' => $sub_paragraph->get('field_oe_title')->value,
'description' => $sub_paragraph->get('field_oe_text_long')->isEmpty() ? '' : $builder->viewField($sub_paragraph->get('field_oe_text_long')),
'icon' => $sub_paragraph->get('field_oe_icon')->value,
'media_size' => $size ?? 'm',
'value' => $variables['value'] ?? '',
];
}
}
Expand All @@ -1949,6 +1962,9 @@ function oe_theme_preprocess_paragraph__oe_illustration_list_images(array &$vari
$paragraph = $variables['paragraph'];
$variables['items'] = [];

if ($paragraph->hasField('field_oe_size') && !$paragraph->get('field_oe_size')->isEmpty()) {
$size = substr($paragraph->get('field_oe_size')->value, 0, 1);
}
$entity_repository = \Drupal::service('entity.repository');
$cacheability = CacheableMetadata::createFromRenderArray($variables);
$builder = \Drupal::entityTypeManager()->getViewBuilder('paragraph');
Expand Down Expand Up @@ -1988,6 +2004,8 @@ function oe_theme_preprocess_paragraph__oe_illustration_list_images(array &$vari
'title' => $sub_paragraph->get('field_oe_title')->value,
'description' => $sub_paragraph->get('field_oe_text_long')->isEmpty() ? '' : $builder->viewField($sub_paragraph->get('field_oe_text_long')),
'image' => $image,
'media_size' => $size ?? 'm',
'value' => $variables['value'] ?? '',
];
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,5 @@
'column': column,
'zebra': zebra,
'items': items,
'centered': centered ?? false,
}) }}
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,5 @@
'column': column,
'zebra': zebra,
'items': items,
'centered': centered ?? false,
}) }}
Original file line number Diff line number Diff line change
Expand Up @@ -16,5 +16,6 @@
'column': column,
'zebra': zebra,
'items': items,
'square_image': square_image
'square_image': square_image,
'centered': centered ?? false,
}) }}
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ list_with_illustration:
type: "numeric"
label: "Column number"
description: "Number of columns. Maximum of 4 columns."
preview: 1
preview: 2
escape: false
zebra:
type: "boolean"
Expand All @@ -18,6 +18,12 @@ list_with_illustration:
label: "Square image"
description: "Whether the rendered image should be rendered in square or landscape mode (only applies to image)."
preview: true
centered:
type: "boolean"
label: "Centered"
description: "Define if the items should be centered."
preview: true
escape: false
items:
type: "array"
label: "Items"
Expand All @@ -29,10 +35,13 @@ list_with_illustration:
src: "https://placeimg.com/1000/500/arch"
alt: "Alternative text for featured item image"
icon: "italy"
value: "3.2 millions"
media_size: "s"
- title: "About the European Union"
description: "The EU and its institutions, how to visit and work at the EU."
image:
src: "https://placeimg.com/1000/500/arch"
alt: "Alternative text for featured item image"
icon: "budget"

value: "3.2 millions"
media_size: "m"
Original file line number Diff line number Diff line change
Expand Up @@ -30,4 +30,5 @@
'column': column,
'zebra': zebra,
'items': _items,
'centered': centered ?? false,
} only %}
70 changes: 67 additions & 3 deletions tests/src/Kernel/Paragraphs/IllustrationListsParagraphsTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -103,10 +103,12 @@ public function testIllustrationListFlagsRendering(): void {
$list_paragraph = Paragraph::create([
'type' => 'oe_illustration_list_flags',
'oe_paragraphs_variant' => 'default',
'field_oe_subtitle' => 'Highlighted Illustration list with flags',
'field_oe_title' => 'Illustration with flags test',
'field_oe_paragraphs' => $items,
'field_oe_illustration_columns' => 2,
'field_oe_illustration_ratio' => 'landscape',
'field_oe_center' => FALSE,
]);
$html = $this->renderParagraph($list_paragraph);

Expand All @@ -127,16 +129,21 @@ public function testIllustrationListFlagsRendering(): void {
'title' => 'Term 1',
'description' => 'Description 1',
'icon' => 'austria',
'value' => 'Highlighted Illustration list with flags',
], [
'title' => 'Term 2',
'icon' => 'belgium',
'value' => 'Highlighted Illustration list with flags',
], [
'description' => 'Description 3',
'icon' => 'france',
'value' => 'Highlighted Illustration list with flags',
], [
'icon' => 'finland',
'value' => 'Highlighted Illustration list with flags',
],
],
'centered' => FALSE,
];
$assert = new ListWithIllustrationAssert();
$assert->assertPattern($expected_values, $html);
Expand Down Expand Up @@ -175,10 +182,12 @@ public function testIllustrationListFlagsRendering(): void {
unset($expected_values['column']);
$assert->assertPattern($expected_values, $html);

// Assert vertical variant with zebra.
// Assert vertical variant with zebra and centered.
$list_paragraph->set('field_oe_center', TRUE);
$list_paragraph->set('field_oe_illustration_alternate', TRUE)->save();
$html = $this->renderParagraph($list_paragraph);
$expected_values['zebra'] = TRUE;
$expected_values['centered'] = TRUE;
$assert->assertPattern($expected_values, $html);
}

Expand Down Expand Up @@ -223,9 +232,12 @@ public function testIllustrationListIconsRendering(): void {
$list_paragraph = Paragraph::create([
'type' => 'oe_illustration_list_icons',
'oe_paragraphs_variant' => 'default',
'field_oe_subtitle' => 'Highlighted Illustration list with icons',
'field_oe_title' => 'Illustration with icons test',
'field_oe_paragraphs' => $items,
'field_oe_illustration_columns' => 2,
'field_oe_size' => 'small',
'field_oe_center' => FALSE,
]);
$html = $this->renderParagraph($list_paragraph);

Expand All @@ -244,16 +256,25 @@ public function testIllustrationListIconsRendering(): void {
'title' => 'Term 1',
'description' => 'Description 1',
'icon' => 'data',
'value' => 'Highlighted Illustration list with icons',
'media_size' => 'l',
], [
'title' => 'Term 2',
'icon' => 'facebook',
'value' => 'Highlighted Illustration list with icons',
'media_size' => 'l',
], [
'description' => 'Description 3',
'icon' => 'global',
'value' => 'Highlighted Illustration list with icons',
'media_size' => 'l',
], [
'icon' => 'package',
'value' => 'Highlighted Illustration list with icons',
'media_size' => 'l',
],
],
'centered' => FALSE,
];
$assert = new ListWithIllustrationAssert();
$assert->assertPattern($expected_values, $html);
Expand All @@ -270,10 +291,18 @@ public function testIllustrationListIconsRendering(): void {
unset($expected_values['column']);
$assert->assertPattern($expected_values, $html);

// Assert vertical variant with zebra.
$list_paragraph->set('field_oe_illustration_alternate', TRUE)->save();
// Assert vertical variant with zebra and centered.
$list_paragraph->set('field_oe_illustration_alternate', TRUE);
$list_paragraph->set('field_oe_center', TRUE);
// Update the icon size to Large.
$list_paragraph->set('field_oe_size', 'large')->save();
$html = $this->renderParagraph($list_paragraph);
$expected_values['zebra'] = TRUE;
$expected_values['centered'] = TRUE;
$expected_values['items'][0]['media_size'] = '2xl';
$expected_values['items'][1]['media_size'] = '2xl';
$expected_values['items'][2]['media_size'] = '2xl';
$expected_values['items'][3]['media_size'] = '2xl';
$assert->assertPattern($expected_values, $html);
}

Expand Down Expand Up @@ -341,10 +370,14 @@ public function testIllustrationListImagesRendering(): void {
$list_paragraph = Paragraph::create([
'type' => 'oe_illustration_list_images',
'oe_paragraphs_variant' => 'default',
'field_oe_subtitle' => 'Highlighted Illustration list with images',
'field_oe_title' => 'Illustration with images test',
'field_oe_paragraphs' => $items,
'field_oe_illustration_columns' => 2,
'field_oe_illustration_ratio' => 'landscape',
// Size value will take action only for "Square" ratio.
'field_oe_size' => 'small',
'field_oe_center' => FALSE,
]);
$html = $this->renderParagraph($list_paragraph);

Expand All @@ -367,25 +400,30 @@ public function testIllustrationListImagesRendering(): void {
'src' => 'example_1.jpeg',
'alt' => 'Alt',
],
'value' => 'Highlighted Illustration list with images',
], [
'title' => 'Term 2',
'image' => [
'src' => $this->container->get('file_url_generator')->generateAbsoluteString('avportal://P-038924/00-15.jpg'),
'alt' => 'Euro with miniature figurines',
],
'value' => 'Highlighted Illustration list with images',
], [
'description' => 'Description 3',
'image' => [
'src' => 'example_1.jpeg',
'alt' => 'Alt',
],
'value' => 'Highlighted Illustration list with images',
], [
'image' => [
'src' => 'example_1.jpeg',
'alt' => 'Alt',
],
'value' => 'Highlighted Illustration list with images',
],
],
'centered' => FALSE,
];
$assert = new ListWithIllustrationAssert();
$assert->assertPattern($expected_values, $html);
Expand All @@ -396,6 +434,28 @@ public function testIllustrationListImagesRendering(): void {
$html = $this->renderParagraph($list_paragraph);
$expected_values['column'] = 3;
$expected_values['square_image'] = TRUE;
$expected_values['items'][0]['media_size'] = 's';
$expected_values['items'][1]['media_size'] = 's';
$expected_values['items'][2]['media_size'] = 's';
$expected_values['items'][3]['media_size'] = 's';
$assert->assertPattern($expected_values, $html);

// Assert centered with medium and large size.
$list_paragraph->set('field_oe_center', TRUE);
$list_paragraph->set('field_oe_size', 'medium')->save();
$html = $this->renderParagraph($list_paragraph);
$expected_values['centered'] = TRUE;
$expected_values['items'][0]['media_size'] = 'm';
$expected_values['items'][1]['media_size'] = 'm';
$expected_values['items'][2]['media_size'] = 'm';
$expected_values['items'][3]['media_size'] = 'm';
$assert->assertPattern($expected_values, $html);
$list_paragraph->set('field_oe_size', 'large')->save();
$html = $this->renderParagraph($list_paragraph);
$expected_values['items'][0]['media_size'] = 'l';
$expected_values['items'][1]['media_size'] = 'l';
$expected_values['items'][2]['media_size'] = 'l';
$expected_values['items'][3]['media_size'] = 'l';
$assert->assertPattern($expected_values, $html);

// Assert vertical variant.
Expand All @@ -410,6 +470,10 @@ public function testIllustrationListImagesRendering(): void {
$html = $this->renderParagraph($list_paragraph);
$expected_values['zebra'] = TRUE;
$expected_values['square_image'] = FALSE;
$expected_values['items'][0]['media_size'] = NULL;
$expected_values['items'][1]['media_size'] = NULL;
$expected_values['items'][2]['media_size'] = NULL;
$expected_values['items'][3]['media_size'] = NULL;
$assert->assertPattern($expected_values, $html);
}

Expand Down
Loading

0 comments on commit 02d69fe

Please sign in to comment.