Skip to content
/ oe_theme Public
forked from openeuropa/oe_theme

OpenEuropa Drupal 8 theme based on the Europa Component Library.

License

Notifications You must be signed in to change notification settings

fpfis/oe_theme

 
 

Repository files navigation

OpenEuropa theme

Build Status

Drupal 8 theme based on the Europa Component Library (ECL).

Development setup

Requirements:

You can build test site by running the following steps.

  • Install the node dependencies:
$ npm install
  • Build the artifacts:
$ npm run build
  • Install all the composer dependencies:
$ composer install
  • Customize build settings by copying runner.yml.dist to runner.yml and changing relevant values.

  • Setup test site by running:

$ ./vendor/bin/run drupal:site-setup

This will symlink the theme in the proper directory within the test site and perform token substitution in test configuration files.

  • Install test site by running:
$ ./vendor/bin/run drupal:site-install

Your test site will be available at ./build.

Working with Drupal 8 static caches

In order to enable and disable Twig and other static caches you can use the following Drupal Console commands:

$ ./vendor/bin/drupal site:mode dev  # Disable all caches.
$ ./vendor/bin/drupal site:mode prod # Enable all caches.

Using Docker Compose

Alternatively you can build a test site using Docker and Docker-compose with the provided configuration.

Requirements:

Run:

$ docker-compose up -d

Then:

$ docker-compose exec -u node node npm install
$ docker-compose exec -u node node npm run build
$ docker-compose exec -u web web composer install
$ docker-compose exec -u web web ./vendor/bin/run drupal:site-setup
$ docker-compose exec -u web web ./vendor/bin/run drupal:site-install

Your test site will be available at http://localhost:8080/build.

Run tests as follows:

$ docker-compose exec -u web web ./vendor/bin/phpunit
$ docker-compose exec -u web web ./vendor/bin/behat

ECL components

You can use the ECL components in your Twig templates by referencing them using the ECL Twig Loader as shown below:

{% include "@ecl/logos" with {
  "to": "https://ec.europa.eu",
  "title": "European Commission",
} %}

Or:

{% include "@ec-europa/ecl-logos" with {
  "to": "https://ec.europa.eu",
  "title": "European Commission",
} %}

JavaScript components can be accessed by ECL.methodName(), e.g. ECL.accordions().

Update ECL

To update ECL components change the @ec-europa/ecl-preset-full version in package.json and run:

$ npm install && npm run build

This will update assets such as images and fonts and re-compile CSS. Resulting changes are not meant to be committed to this repository.

Watching and re-compiling Sass and JS changes

To watch for Sass and JS file changes - ./sass folder - in order to re-compile them to the destination folder:

$ npm run watch

Resulting changes are not meant to be committed to this repository.

About

OpenEuropa Drupal 8 theme based on the Europa Component Library.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • HTML 58.2%
  • PHP 36.1%
  • Gherkin 2.9%
  • JavaScript 2.7%
  • CSS 0.1%