Drupal CMS

Drupal is een open-source content management systeem (CMS) dat wordt gebruikt voor het bouwen en beheren van websites en webapplicaties. Het is gebaseerd op PHP en biedt een scala aan functies en tools voor het maken van aangepaste websites en webapplicaties.

Het is dan ook één van de grootste spelers in CMS-land en dient voor meer dan duizenden bedrijven als platform voor websites. Al overtuigd van deze CMS-krachtpatser? Wij alvast wel.

Wat is Drupal?

Drupal is een open-source content management system (CMS) met Belgische roots. Het is een zeer veilig, flexibel en betrouwbaar platform en wordt ondersteund door een wereldwijde community van ontwikkelaars. Drupal is erg geliefd doordat ze eenvoudig aan te passen is en daarom uitmuntend geschikt is voor maatwerk. Denk maar aan het koppelen van je eigen CRM of software.

Omdat Drupal open-source is, wordt het actief onderhouden en ontwikkeld door een grote gemeenschap van ontwikkelaars en gebruikers, waardoor het voortdurend wordt verbeterd en geüpdatet met nieuwe functies en mogelijkheden.

Is Drupal de beste keuze voor jou?

Deze Belgische trots is een geweldig CMS voor uiteenlopende type projecten. Ben je niet zeker of Drupal wel de beste keuze voor jouw einddoel is? Geen nood. Nadat we bij onze verkennende gesprekken jouw business en klanten volledig uit de doeken hebben gedaan, bekijken we samen met jou welke technologie het beste bij jouw wensen en noden past.

make it fly - Drupal

Drupal als CMS

Drupal is een CMS dat al enkele jaren aan een steile opmars bezig is. Dagelijks werken er wereldwijd duizenden developers aan de uitbreiding van dit platform waardoor er ondertussen meer dan 15.000 (!) extra modules beschikbaar zijn. Drupal is een veelgebruikt CMS voor web en web app development.

Bij Duo zijn we overtuigd van de kracht die in het Drupal content management systeem schuilt en daarom gebruiken we dit vaak als basis voor onze web development. Hierop bouwen onze Drupal developers dan verder en programmeren modules op maat waarmee unieke, interactieve en gebruiksvriendelijke websites en webshops worden gecreëerd.

Enkele reden waarom je zou kiezen voor Drupal, op een rijtje:

  • je geniet van technologie dat met je meegroeit

  • garandeer de meest gebruiksvriendelijke ervaring

  • integreer eenvoudig interne systemen en externe tools

  • beheer centraal je inhoud en verspreidt via diverse kanalen (omnichannel)

  • profiteer van de flexibiliteit, vrijheid en mobielvriendelijkheid van je Drupal website

make it fly - Drupal

De voordelen van Drupal CMS

Deze krachtpatser brengt natuurlijk tal van voordelen met zich mee:

Gebruiksvriendelijk

Drupal zorgt ervoor dat je als eindgebruiker, die misschien niet over alle technische kennis beschikt, zelf gemakkelijk inhoud kunt wijzigen of toevoegen met behulp van een overzichtelijk en gebruiksvriendelijke gebruikersinterface.

Flexibel

Drupal is een zeer flexibel content management systeem, omdat het in staat is de inhoud van de website op basis van tags te organiseren in vooraf bepaalde categorieën. Elke node of content type kan bestaan uit uiteenlopende types inhoud: tekst, afbeeldingen, video, formulieren… Drupal - in tegenstelling tot vele andere content management systemen - kunnen we inzetten voor:

Een eenvoudige website die je huisstijl omarmt en je identiteit uitstraalt? Dan is een Drupal website iets voor jou. Overzichtelijk en makkelijk vindbaar.

Drupal biedt een krachtige en uitgebreide set functies voor e-commerce websites, zoals geavanceerde zoekfunctionaliteit, productcatalogi, winkelwagentjes, betaalgateways, en integratie met externe systemen zoals ERP en CRM.

  • Campagnewebsites of miniwebsites

Je merk echt in de kijker zetten doe je met je identiteit, positionering én een brand of campagne website. Alles wat je nodig hebt om je consumenten te informeren en met hen te communiceren heb je in handen. Daarbovenop geeft het je merk online een unieke look.

Uitbreidbaar

Drupal CMS heeft een modulair ontwerp. Door modules toe te voegen of op maat te schrijven kunnen onze developers handige functies aan je website toevoegen Deze modules kunnen eenvoudig geïmplementeerd worden en maken je website uniek.

Mobielvriendelijk

Het is natuurlijk belangrijk dat je website zich ook op mobiele toestellen perfect aanpast. Dit gaat het best als je website zich aan de grootte van het scherm aanpast, in het zogenaamde responsive webdesign. Drupal zorgt dat we op een vlotte manier een responsive design kunnen integreren. Op deze manier kunnen we je website op alle toestellen (smartphones, tablets en desktops) perfect weergeven.

Externe integratiemogelijkheden

Moeten bepaalde acties op je website ook met een bestaand systeem, zoals een ERP- of CRM-pakket, gekoppeld worden? Met Drupal is het perfect mogelijk om die koppeling te maken. Onze ervaring met diverse systemen zorgt ervoor dat de integratie met externe tools of applicaties, web services of backend-systemen steeds feilloos in je website geïntegreerd wordt.

Zoekmachinevriendelijk (of SEO-vriendelijk)

Een parel van een website moet kunnen gevonden worden door zoekmachines om organisch verkeer naar de website te brengen. Drupal behaalt telkens opnieuw zeer mooie resultaten bij zoekmachines door de uiteenlopende SEO-modules en optimalisatiemogelijkheden.

  1. Is it possible to add a marker popup with text when using the form formatter (Leaflet Map Default)

    Fons

    Problem/Motivation

    Hello, i'm currently using this awesome module and it's really nice. Thank you!

    The only feature that I miss / can't find is how to add marker popup data (preferably text) when using the form formatter (Leaflet Map Default).

    Now I can add markers (without data / pop-up info), polygons, lines, etc.

    How can this be achieved, can anyone put me in the right direction?

    Thanks in advance!

  2. TermStorage::loadTree is not language aware

    Randal

    Problem/Motivation

    As a result of #2615864, this module also suffers from issues with translations. It always retrieves taxonomy terms in their default language, rather than the current language.

    Steps to reproduce

    Create translations of the dictionary vocabulary terms, and add the words to a page in a different language than the default language of the terms.

    Proposed resolution

    Slightly rework the functionality regarding the loading of taxonomy terms in the TooltipManager class.

    I will create a MR with my proposal.

  3. Install Tocbot library with composer

    Fons

    Problem/Motivation

    It would be nice if we could add the steps to add the Tocbot library that is used by this module with composer.

    Proposed resolution

    Update the Readme file and project detail page on drupal.org

    Remaining tasks

    Create a patch, if you are open to this suggestion I don't mind creating and posting the patch. -> Patch in comments

    As I see it now the following steps are needed:

    INSTALLATION VIA COMPOSER

    1. It is assumed you are installing Drupal with Composer (https://www.drupal.org/download).

    2. Add the following entry in the "repositories" section of your main composer.json file.

    {
                "type": "package",
                "package": {
                    "name": "tscanlin/tocbot",
                    "version": "4.30.0",
                    "type": "drupal-library",
                    "source": {
                        "url": "https://github.com/tscanlin/tocbot",
                        "type": "git",
                        "reference": "v4.30.0"
                    }
                }
            }
    

    Now you can run the following command to install chosen in the right folder:

    composer require tscanlin/tocbot

    3. Clear the cache 4. Go to Administration > Configuration > Content Authoring > Tocbot Settings (/admin/config/content/tocbot) 5. Configure the module to your needs 6. Click "Save configuration"

  4. Blazy renders the same classes on all blazy elements on a page.

    Fons

    Problem/Motivation

    I'm using blazy on a page in different layout blocks.

    I've noticed the blazy field gets injected with the same classes for all media fields which to me makes no sense.

    Steps to reproduce

    Create a page with multiple blazy elements, you'll notice the same group of classes is used on all elements instead of the relevant classes per item.

    Proposed resolution

    Don't make a huge group of classes and render them on all elements but instead only show the relevant classes per item.

    The classes are added in an array in the following file:

    blazy/src/Attributes.php

    in the following function:

    /**
       * Returns the classes applicable only to the first, not nested containers.
       */
      private static function firstClasses(array &$attributes, $blazies, array $options): array {
    

    If you print the classes before the return you'll see the same array that is printed for every item.

    Remaining tasks

    Needs review

  5. Header is always shown in Claro even when regions in it are empty

    Fons

    Problem/Motivation

    The header of Claro is always rendered even when the regions (page.breadcrumb & page.header) are have no content in it.

    Because of this the background and the background color of the header is always rendered which is odd.

    Steps to reproduce

    Assign no content to the breadcrumb and header regions in Claro, you'll see the background is show on screen.

    Proposed resolution

    Add a check to see if one of the regions (breadcrumb or header) is filled, if not don't render the header at all.

  6. Error on disabling the "navigation_layout"

    Fons

    Problem/Motivation

    I disabled some layouts using this module which works fine.

    When hiding the navigation_layout an error is thrown:

    The website encountered an unexpected error. Try again later.
    
    Drupal\Component\Plugin\Exception\PluginNotFoundException: The "navigation_layout" plugin does not exist. Valid plugin IDs for Drupal\Core\Layout\LayoutPluginManager are: layout_onecol, layout_twocol_bricks, layout_threecol_25_50_25, layout_threecol_33_34_33, layout_builder_blank in Drupal\Core\Plugin\DefaultPluginManager->doGetDefinition() (line 53 of core/lib/Drupal/Component/Plugin/Discovery/DiscoveryTrait.php).

    Seems like the navigation_layout does not exist but I do see it when using layout builder (see screenshots in attachment).

    Steps to reproduce

    Disable the navigation_layout

  7. TypeError_: unserialize(): Argument #1 ($data) must be of type string, array given in _unserialize()

    Randal

    Hi @mahde,

    Thanks for taking the time to debug and updating the MR! This brings us back to my comment in #5 though, there's only one piece of code in the module that updates the user data for roles, and it always serializes it.. I don't understand how it could possibly contain an array unless some other module messes with it 😓

  8. TypeError_: unserialize(): Argument #1 ($data) must be of type string, array given in _unserialize()

    Randal

    I'm sorry guys, I've tried debugging this but nothing seems to point to an error 😓

    Could you perhaps provide me with a list of contrib modules currently in use? That way I could test with those, maybe one of them triggers something malicious in msqrole.

    PS. I did fix some little bits here and there in the latest release, in the D11 compatible version there were some regressions, but none of which should have caused the main issue raised here. The "access denied" error you mentioned, @mahde, should be fixed though.

  9. TypeError_: unserialize(): Argument #1 ($data) must be of type string, array given in _unserialize()

    Randal

    Hi markconroy,

    Thanks for reporting a possible bug. Could you provide a little more information on how to reproduce this error? I don't seem to get this on a clean install. Any contrib modules that might interfere?

    From what I can tell, the unserialize function in the below piece of code should only be run if the data isn't empty.

        if (!empty($this->getData($uid, 'roles'))) {
          $data = unserialize($this->getData($uid, 'roles'));
        }

    However, it should be impossible for this data to be anything but a string, since it's only set by one function (the below code) and that code serializes the value before committing it to the DB.

      public function setRoles($uid, array $roles) {
        return $this->setData($uid, 'roles', serialize($roles));
      }

    Hence why it sounds like some external source might be messing with the msqrole user data 🤔

    PS. While the MR seems just fine, it simply shouldn't be needed.. Hence why I currently see that check more as unnecessary clutter, so I'd prefer to be able to reproduce it and perhaps fix it in a different way 😇

  10. Offering to co-maintain Fixed Path Alias

    Randal

    Kind request for the current maintainer of this module to grant this person co-maintainership. I see there's no longer any supported version, while this is definitely a useful feature.

    Thanks in advance!

  11. Cloned entities don't retain their Inline Block usage

    Randal

    Hi @remoschneider,

    Please, refrain from posting a patch that isn't functionally brought up to date. The patch you posted applies, but is buggy due to the lack of the 'getPluginBlockId'-method in the InlineBlockEntityOperations class.

    I'll post a patch that is functionally in line with the old one, if someone wants to turn it into an MR.

  12. Different sites served from the same domain share the session cookie name

    Randal

    @alexpott

    • MR applies cleanly to 10.3.x
    • Done some tests and the results are as expected:
      • Same hash salt -> same session cookie name
      • Different hash salt -> different session cookie name
      • Can stay logged in across all subsites of a multisite on the same hostname with different hash salt
      • Giving all subsites the same hash salt has the expected behavior of being logged out when visiting a different subsite

    Seems ready to me! Thanks for the MR.

  13. Email message field

    Sven Decabooter

    This module provides an email message field (consisting of an email subject and email body). While this could also be achieved by a regular textfield + textarea field, there are occasions where you want to reference an email message as a whole. This module provides that ability.

    Features

    • Drupal field for adding an email subject / body.
    • SOON: Submodule: optional integration with Site Settings and Labels module, to allow easy integration of configurable email messages into Drupal mails - via hook_mail() or Symfony Mailer.

    SOON:

    • Site Settings and Labels
    • Drupal Symfony Mailer
  14. Allow altering of the language fallback for path aliases

    Randal

    Hi @google01,

    Merge request definitely applies to 10.3.x.

    The contents of this: https://git.drupalcode.org/project/drupal/-/merge_requests/5373.diff Should be downloaded and placed in a local folder (e.g. YOUR_PROJECT/patches/core/3091336.patch), make sure there's an empty line at the end, and then add `patches/core/3091336.patch` in your composer patches list.

  15. Make the module extendable with plugins

    Randal

    Could a maintainer please take a look at this issue? It doesn't change the module's initial installation state, and it adds a lot of possible functionality.

    I think this could really spearhead this module's already superb usefulness. (And I'd also be sad to see the work I put in it be for naught :))

  16. Copy block configuration from admin theme when enabling an admin theme

    Randal

    Is there any progress on this, or any way to circumvent this and move forward? Recipes are included in 10.3.x, I feel like the priority of solving this should be a little higher now.

    I can't seem to get it fixed myself, other than patching core and removing the functionality entirely, but that seems a little nuclear...

    On the other hand, I personally do think that this copy functionality should be removed. It definitely doesn't make much sense to copy blocks from one theme to another, given that regions could be entirely different.

  17. Breadcrumbs block within Layout Builder causes errors when moving blocks

    Randal

    Thank you for your patch, alecsmrekar, it seems to work.

    I am however unclear on why this issue pops up at all. why is the `layout_builder.move_block_form`-route being triggered when the arguments clearly call for the `layout_builder.move_block` route.

    I'm wondering if changing the path for one of the two routes would be a more stable solution? Two routes with very similar paths and arguments, that seems like asking for trouble to me.

    Perhaps all non-publicly accessible routes (like ajax routes) should get some prefix, for example.

  18. Add Gitlab CI support

    Sven Decabooter

    Problem/Motivation

    Steps to reproduce

    Proposed resolution

    Remaining tasks

    User interface changes

    API changes

    Data model changes

  19. Add Gitlab CI support

    Sven Decabooter

    Problem/Motivation

    Steps to reproduce

    Proposed resolution

    Remaining tasks

    User interface changes

    API changes

    Data model changes

Fons Vandamme

Gebruik Drupal als CMS voor een veilige en betrouwbare website die altijd up-to-date is.

Fons Vandamme
Drupal Architect & Sales manager

Met doordachte positionering scheppen we met Drupal een optimale visuele hiërarchie, cohesie en gebruiksvriendelijkheid.