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. Automated Drupal 11 compatibility fixes for tablefield

    Fons

    I just tested the patch in comment #4 and everything seems to work fine.

    I was wondering if this can get merged in a new release?

    For now I'll use the patch as this is one of the modules that holds me from upgrading to Drupal 11.

    Thank you!

  2. 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"

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

    Fons

    Dear gausarts, thank you for the compliment and sorry to read that.

    Just a thought:

    If we would toggle this setting by default in the install file of the module it would only trigger / set it default for new installs.

    Existing installs wouldn't be affected, if you want to affect those (which you don't and I totally get that) you would add this in an update hook.

    If you are interested in a patch for the install file i'd be happy to make it but it is not a dealbreaker for me.

    Thank you for all your work and have a great evening! There are a lot of good people out there so try to focus on those, that may help!

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

    Fons

    Thank you for your reply, I checked the Blazy settings page but it seems that I read over the checkbox to disable these classes.

    I just checked the setting and everything looks better / clean now.

    If I may suggest an upgrade I think it's fair to check this setting by default as a clean DOM is preffered over all these classes in most cases but that is just my view.

    Thanks!

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

    Fons

    I created a patch that cleans out the function so the DOM is now a lot less bloated with unneeded classes.

    I might miss the point why all these classes are added on every media element but they are not needed for the module to work and I don't see the value they add.

    Feel free to enlighten me.

  6. 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

  7. 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.

  8. Error on disabling the "navigation_layout"

    Fons

    So for reasons beyond my control the "navigation_layout" seems to exist (core module navigation) and is something that is considered needed.

    If that's the case it would be best to alter this module so you can't disable it (since it will throw the error I mention).

    For now I disabled this module and disabled / hide the layouts with the following code in case somebody has the same problem as I do.

    In this example I hide all the layouts except the one col layout.

    /**
     * Implements hook_layout_alter().
     */
    function YOUR_MODULE_layout_alter(&$definitions)
    {
        // an array of layouts to keep.
        $layoutsWhitelist = ['navigation_layout'];
    
        // layouts that are required and cannot be removed.
        $requiredLayouts = ['layout_onecol', 'layout_builder_blank'];
    
        $layouts = array_merge($requiredLayouts, $layoutsWhitelist);
        
        $definitions = array_filter(
            $definitions,
            static fn(string $id) => in_array($id, $layouts, true),
            ARRAY_FILTER_USE_KEY
        );
    }
    
    /**
     * Implements hook_preprocess_item_list__layouts().
     */
    function YOUR_MODULE_preprocess_item_list__layouts(&$variables)
    {
        // For some reason removing this layout breaks the website so we hide it.
        $layoutToHide = ['navigation_layout'];
    
        $variables['items'] = array_filter(
            $variables['items'],
            static fn(string $id) => !in_array($id, $layoutToHide, true),
            ARRAY_FILTER_USE_KEY
        );
    }
    
  9. 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

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.