openeuropa / oe_paragraphs
Drupal module providing a collection of Paragraph types based on ECL components.
Installs: 135 014
Dependents: 4
Suggesters: 0
Security: 0
Stars: 4
Watchers: 22
Forks: 6
Open Issues: 4
Type:drupal-module
pkg:composer/openeuropa/oe_paragraphs
Requires
- php: >=8.3
- cweagans/composer-patches: ^1.7 || ^2.0
- drupal/core: ^10 || ^11
- drupal/paragraphs: ^1.18
- drupal/typed_link: ^2.0
Requires (Dev)
- composer/installers: ^1.5 || ^2.3
- drupal/address: ^1.9 || ^2.0
- drupal/composite_reference: ^2.1
- drupal/config_devel: ^1.9
- drupal/core-composer-scaffold: ^10 || ^11
- drupal/core-dev: ^10 || ^11
- drupal/core-utility: ^10 || ^11
- drupal/description_list_field: ^1.0
- drupal/drupal-extension: ^5.0
- drupal/entity_browser: ^2.15
- drupal/inline_entity_form: ^1.0-rc12 || ^3.0@RC
- drupal/json_field: ^1.1
- drush/drush: ^12 || ^13
- openeuropa/behat-transformation-context: ~0.2
- openeuropa/code-review-drupal: ^1.0.0-alpha
- openeuropa/oe_content: ^4.10.0
- openeuropa/oe_media: ^1.23.1
- openeuropa/oe_webtools: ^1.22
- openeuropa/rdf_skos: ^1.2
- openeuropa/task-runner-drupal-project-symlink: ^1.0
Suggests
- openeuropa/oe_media: Allows usage of paragraphs with different media attached to it.
- dev-master
- 1.31.0
- 1.30.0
- 1.29.0
- 1.28.0
- 1.27.0
- 1.26.0
- 1.25.0
- 1.24.0
- 1.23.3
- 1.23.2
- 1.23.1
- 1.23.0
- 1.22.0
- 1.21.0
- 1.20.0
- 1.19.0
- 1.18.0
- 1.17.0
- 1.16.0
- 1.15.0
- 1.14.0
- 1.13.1
- 1.13.0
- 1.12.0
- 1.11.0
- 1.10.0
- 1.9.0
- 1.8.0
- 1.7.0
- 1.6.0
- 1.5.1
- 1.5.0
- 1.4.0
- 1.3.0
- 1.2.0
- 1.1.0
- 1.0.0
- 1.0.0-beta2
- 1.0.0-beta1
- 0.6.0
- 0.5.0
- 0.4.1
- 0.4.0
- 0.3.0
- 0.2.3
- 0.2.2
- 0.2.1
- 0.2.0
- 0.1.1
- 0.1.0
- dev-EWPP-6075
- dev-EWPP-5805
- dev-EWPP-5628
- dev-EWPP-4991
- dev-contribution/UCPKN-2795
- dev-OEL-856
- dev-EWPP-1862
- dev-EWPP-873
- dev-EWPP-875
- dev-EPIC-EWPP-1194-Contact-paragraph
- dev-EWPP-811
- dev-test-build
- dev-OPENEUROPA-3299
- dev-OPENEUROPA-3149-3
- dev-OPENEUROPA-3094
- dev-OPENEUROPA-2258-test-php72
- dev-OPENEUROPA-2259
- dev-Issue-65
- dev-OPENEUROPA-2113-1
- dev-OPENEUROPA-2158
- dev-OPENEUROPA_2008
- dev-OPENEUROPA-1752
- dev-OPENEUROPA-1401
- dev-OPENEUROPA-1348
- dev-OPENEUROPA-793
- dev-OPENEUROPA-682
This package is auto-updated.
Last update: 2025-10-23 15:54:23 UTC
README
This module provides a number of Paragraph types that are based on a select number of components integrating ECL, the component library of the European Commission. These are intended to be used on landing pages of various sites of the European Commission.
Table of contents:
Installation
The recommended way of installing the OpenEuropa Authentication module is via Composer.
composer require openeuropa/oe_paragraphs
Enable the module
In order to enable the module in your project run:
./vendor/bin/drush en oe_paragraphs
Paragraphs
The module provides the following paragraph types:
- Accordion: The Accordion paragraph is a collection of collapsible items with icon, title and long text required fields.
- Accordion item: The Accordion item paragraph is a single accordion with icon, title and long text required fields. It is intended to be used exclusively in conjunction with the "Accordion" paragraph.
- Content row: The Content row paragraph allows editors to group multiple paragraphs together. An in-page navigation can be shown optionally.
- Contextual navigation: The Contextual navigation paragraph allows editors to add a number of links that helps the user navigate the page. The links, their visibility limit and navigation label can be configured using the available fields.
- Document: The Document paragraph allows editors to render documents.
- Links block: The Links block paragraph displays a list of links, with an optional title. It is used for instance with the dropdown component.
- Listing item: The Listing item paragraph displays content teasers. A list item is available in the following variants: default, date item, highlighted and thumbnail with primary or secondary image.
- Listing item block: The Listing item block paragraph allows editors to group multiple Listing item paragraphs in one, two or three columns. An optional link can be added to the block.
- Quote: The Quote paragraph allows editors to add a quotation with quote and its attribution.
- Rich text: The Rich text paragraph adds an optional title field and a long text field.
- Facts and figures: The facts and figures paragraph is used to deliver numerical representations of facts that are easier to portray visually through the use of statistics.
- Fact: Single fact item, to be used exclusively in conjunction with the "Facts and figures" paragraph type.
- Social media follow: The Social media follow paragraph allows the editor to add a list of social media links.
This project also ships with optional submodules, providing optional paragraph types. Check the ./modules
directory for more information.
Banner
Allows editors to create Banners that display a prominent message and related action. To get this paragraph type enable the OpenEuropa Paragraphs Banner submodule.
Carousel
The paragraph allows editors to create Carousel items similar to a Banner with multiple slides. To get this paragraph type enable the OpenEuropa Paragraphs Carousel submodule.
Chart
Allows editors to create paragraphs that display Webtools chart media entities. To get this paragraph type enable the OpenEuropa Paragraphs Chart submodule.
Description list
Allows editors to create paragraphs that provide HTML description lists with a heading. To get this paragraph type enable the OpenEuropa Paragraphs Description list submodule.
Iframe
Allows editors to create paragraphs that display Iframe media entities. To get this paragraph type enable the OpenEuropa Paragraphs Iframe submodule.
Map
Allows editors to create paragraphs that display Webtools map media entities. To get this paragraph type enable the OpenEuropa Paragraphs Map submodule.
Text with feature media
Allows editors to create paragraphs that show a rich text with a title and a featured media on the right, if any. To get this paragraph type enable the OpenEuropa Text with featured Media paragraph submodule.
Social feed - Deprecated (will be removed in 2.0 as the Webtools smk service is no longer supported)
Allows editors to create paragraphs that display Webtools social feed media entities. To get this paragraph type enable the OpenEuropa Paragraphs Social feed submodule.
Timeline
Allows editors to create paragraphs that display displays concurrent and/or sequential items visually on a time axis. To get this paragraph type enable the OpenEuropa Paragraphs Timeline submodule.
Development setup
You can build a test site by running the following steps.
- Install all the composer dependencies:
composer install
-
Customize build settings by copying
runner.yml.dist
torunner.yml
and changing relevant values. -
Install test site by running:
./vendor/bin/run drupal:site-install
Your test site will be available at ./build
.
Please note: project files and directories are symlinked within the test site by using the OpenEuropa Task Runner's Drupal project symlink command.
If you add a new file or directory in the root of the project, you need to re-run drupal:site-setup
in order to make
sure they are be correctly symlinked.
If you don't want to re-run a full site setup for that, you can simply run:
$ ./vendor/bin/run drupal:symlink-project
Using Docker Compose
Alternatively, you can build a development site using Docker and Docker Compose with the provided configuration.
Docker provides the necessary services and tools such as a web server and a database server to get the site running, regardless of your local host configuration.
Requirements:
Configuration
By default, Docker Compose reads two files, a docker-compose.yml
and an optional docker-compose.override.yml
file.
By convention, the docker-compose.yml
contains your base configuration and it's provided by default.
The override file, as its name implies, can contain configuration overrides for existing services or entirely new
services.
If a service is defined in both files, Docker Compose merges the configurations.
Find more information on Docker Compose extension mechanism on the official Docker Compose documentation.
Usage
To start, run:
docker-compose up
It's advised to not daemonize docker-compose
so you can turn it off (CTRL+C
) quickly when you're done working.
However, if you'd like to daemonize it, you have to add the flag -d
:
docker-compose up -d
Then:
docker-compose exec web composer install docker-compose exec web ./vendor/bin/run drupal:site-install
Using default configuration, the development site files should be available in the build
directory and the development site
should be available at: http://127.0.0.1:8080/build.
Running the tests
To run the grumphp checks:
docker-compose exec web ./vendor/bin/grumphp run
To run the phpunit tests:
docker-compose exec web ./vendor/bin/phpunit
To run the behat tests:
docker-compose exec web ./vendor/bin/behat
Step debugging
To enable step debugging from the command line, pass the XDEBUG_SESSION
environment variable with any value to
the container:
docker-compose exec -e XDEBUG_SESSION=1 web <your command>
Please note that, starting from XDebug 3, a connection error message will be outputted in the console if the variable is set but your client is not listening for debugging connections. The error message will cause false negatives for PHPUnit tests.
To initiate step debugging from the browser, set the correct cookie using a browser extension or a bookmarklet like the ones generated at https://www.jetbrains.com/phpstorm/marklets/.
Contributing
Please read the full documentation for details on our code of conduct, and the process for submitting pull requests to us.
Versioning
We use SemVer for versioning. For the available versions, see the tags on this repository.
Upgrade to 1.27.0
In 1.27.0 the requirement of the contrib allowed_formats module has been removed. When upgrading to this version, specifically require the contrib module in your project's code base and uninstall the module. This should be released and then the requirement can be safely removed in a feature release.