<img height="1" width="1" style="display:none" src="https://www.facebook.com/tr?id=278116885016877&amp;ev=PageView&amp;noscript=1">

Jul 18, 2023 | 5 Minute Read

Single Directory Components: A Neat Approach To Drupal Development

Table of Contents

Introduction

Single Directory Components (SDC) was recently introduced as an experimental module in Drupal Core. Scheduled for release in June 2023 in version 10.1.0, SDC is all set to bring a new level of organization and modularity to Drupal.  

 

 

What Is The Function Of SDC In Drupal?

SDC empowers themes and modules to create components within their respective directories in the project. A component is a collection of files essential for rendering, including - Twig, YAML, and optionally CSS and JavaScript.

When a template calls for the component, SDC automatically generates a library to load the necessary CSS and JavaScript. SDC provides a comprehensive API for creating and extending components, building a solid foundation for incorporating additional functionalities.

Although SDC is an independent module, the long-term plan is to integrate its functionality into Drupal Core's base theme system once it achieves stability. Let’s look at some of the prominent changes that are brought forth by SDC:

 

Before SDC

After SDC

Previously, Drupal relied on various directories scattered throughout theme or module directories to store frontend assets such as JavaScript, CSS, and templates. 

Developers can create a centralized directory for each component, housing all the relevant frontend assets, including Twig, YAML, CSS, JavaScript, and more. 

This approach often resulted in a disorganized and challenging-to-maintain codebase.

This approach greatly simplifies asset management, making it easier to locate, update, and maintain component-related files.

Without having any sort of familiarity with the Drupal ecosystem:

  • It can get challenging to understand the origins of the CSS and JS files. 
  • Locating the assets can be complicated as the relevant files are scattered throughout the file system
  • Maintaining context can be difficult too, as it's not always clear what data is required for a component or where to find the associated template.

SDC implements the single directory component approach. As a result:

  • Everything required for the component is in a single directory. This includes: my-component.twig, my-styles.css, my-behaviors.js, and my-component.php. If it affects how the component renders, users can find it in the same directory.
  • This way the components are easier to find, needn’t have unaccounted code, and can be easily reused.

Benefits Of Using Single Directory Components

Beneits_of_Using_SDC

Organization  

SDCs promote improved organization by consolidating all the files for a component in a single directory, fostering a structured approach to code organization. This clarity makes it easier to manage and maintain components.

Furthermore, by loading CSS and JS files based on components, the overall weight of page assets is reduced, leading to improved page performance. This approach ensures that unused CSS and JS are not unnecessarily loaded on the page.

Easy To Find And Delete

When it comes to CSS refactoring, there is a sense of fear about accidentally deleting CSS that might still be in use elsewhere. However, with component-based styling, the styles are specifically applied to each individual component. This makes it easier to refactor and delete CSS confidently, knowing that it only affects that particular component.

Modularity And Reusability

SDC also enables modularity and reusability by encapsulating all component code and assets within a single directory. This means that components can be easily reused across different projects or within the same project, saving valuable development time and effort.

 

Users can reuse a component by using the following code: 

{ % include (my_theme : my-component) % }

By including the component ID, users can generate HTML, CSS, and JS specific to that component. When they need to include or extend the component, a library is automatically generated. Ergo, users don't have to manually attach the library.

Maintenance

Maintenance becomes a breeze with SDC, as all the components’ files are conveniently located in one place. This simplifies the process of updating or modifying components without the need to navigate through multiple directories or files.

Additionally, SDC automatically generates a library for loading the necessary CSS and JavaScript files when the associated template is invoked. This automated process ensures that the required assets are seamlessly included, reducing manual configuration and streamlining frontend development.

Clean Code

SDC also improves code readability by clearly indicating the dependencies and relationships between different component files. This helps developers understand and manage dependencies more effectively.

Standardization

SDC promotes consistency and standardization in component development by providing a predefined structure. This encourages cleaner, more maintainable code across the entire project or organization. 

By embracing SDCs, Drupal developers can enjoy a more organized, modular, and efficient frontend development workflow. With improved asset management, simplified maintenance, and enhanced collaboration, SDC empowers developers to create outstanding web experiences with ease and confidence.

How To Create A Component In SDC

Creating a component in SDC comprises of the following steps:

Step 1: Enable The SDC Module

To install the SDC module, the first step is to navigate to the extended page and proceed with the installation. This module will function the same way as the other modules and won’t require any additional configuration. 

Once SDC reaches a stable state, it will no longer exist as a separate module. Instead, it will be enabled by default. Additionally, there’s an option to install Drupal core dev (drupal/core-dev). While this step is not mandatory, it does provide highly informative error messages from the SDC module.

Enable_SDC_Module

Step 2: Create SDC Component 

The next step is to create the directory called components. This is where all the components are going to live. For every component create a new directory, each of which will contain components.yml, twig file. Get more details about creating a component here.

Step 3: Render This Component

To render these components, leverage the power of Twig's include and embed functionalities, along with template inheritance. These techniques provide flexibility in passing variables and updating values.

When using the include statement, include a specific component template within another template. This allows passing the variables to the included component. Additionally, this helps customize the components’ behavior and appearance based on the context.

Embedding also allows the creation of reusable component templates that can be extended or overridden by other templates. By extending a base template, users can inherit its variables and logic, while still having the flexibility to update or add new variables specific to the extended template.

In both the instances, passing variables to the component templates can be done by simply providing the necessary values when including or extending the templates. This helps dynamically update the components’ behavior or appearance based on the values passed from the parent template or within the components itself.

 

Embed syntax:

{ % embed 'olivero:page-title' with {

 classes: classes,

 title_suffix: title_suffix,

 title: title,

} % }

{ % endembed % }

Include syntax:

{ { include(

      'Olivero:page-title', {

        classes: classes,

        title_suffix: title_suffix,

        title: title,

      },

  ) } }

Steps To Create A Component Using The SDC Approach

Here’s a quick demonstration for users who want to understand the steps to create a component using the SDC approach:

  • Step 1: Create a directory called components inside the Olivero theme.This can also be done with any other core or custom theme. For instance, Olivero can be used due to its wide-ranging familiarity.
  • Step 2: Inside the components directory, create a subdirectory named page-title. This directory will replace the existing page title with the new page-title component.
  • Step 3: Create a file named page-title.component.yml within the page-title directory. This file will define the schema and types for the component.
  • Step 4: Create a file named page-title.twig and copy the markup from the original page-title.html.twig file. Paste the copied markup into this new Twig file.
  • Step 5: To utilize the component, employ the embed function in the page-title.html.twig file. This enables users to call and customize the component by replacing variable values.

Page_Title_HTML_Twig

 

  • Step 6: Place the CSS and JS files inside the components directory. This eliminates the need to manually create or attach a library. The assets will now be automatically loaded, simplifying the process and ensuring proper inclusion of CSS and JS files for the components.
  • Step 7: Now users will be able to view that the title is coming from the Olivero:page-title component.

Olivero_Page_Title_Component

Advanced Features To Try

SDCs provide the flexibility to override libraries when necessary. 

There might be instances where they’ll need to pass an attribute for a JS file or include additional JS files. In such cases, the users can override the libraries to accommodate these requirements. In addition, they can specify dependencies for the JS files. 

For example, if the JS code relies on Drupal, users can declare this dependency in the component.yml file. This facilitates the necessary additions to the libraries.yml file directly within the component.yml file. Learn more about metadata (component.yml) here.

 

# This is how you take control of the keys in your library

# declaration. The overrides specified here will be merged (shallow merge) with

# the auto-generated library. The result of the merge will become the library

# for the component.

libraryOverrides:

  # Once you add a key in the overrides, you take control of it. What you type

  # here is what will end up in the library component.

  dependencies:

    - core/drupal

    - core/once

  # Here we are taking control of the JS assets. So we need to specify

  # everything, even the parts that were auto-generated. This is useful when

  # adding additional files or tweaking the <script> tag's attributes.

  js:

    my-component.js: { attributes: { defer: true } }

    my-other-file.js: {}

Future Advantages

It is possible to create a component within one theme/module and utilize it in another theme/module. The essential requirement is that the metadata defined in the components.yml file along with ensuring that the inputs are compatible with the new theme. 

To incorporate the component into the new theme, copy the component files and paste them into the desired theme directory. By utilizing the embed or include functionality, the component can be rendered within the new theme, allowing for easy reusability and integration.

In traditional Drupal theming, CSS and JS files are often scattered throughout the file system and included globally, leading to larger file sizes and unnecessary loading of assets on each page. This may impact the page load times and overall performance.

With SDC, the CSS and JS files are organized and stored within component directories. This structure ensures that only the relevant assets for a specific component are loaded when that component is rendered on a page. Unused CSS and JS files associated with other components are not called, resulting in a more optimized asset loading process.

Conclusion

SDCs introduce a new level of organization and modularity to Drupal frontend development. They simplify asset management, enhance collaboration, and improve code readability. By using the SDCs, Drupal developers can easily  streamline their workflow, save time, and create exceptional web experiences with confidence.

FAQ'S

What Advantages Does SDC Offer For Drupal Themes Compared To The Current Approach?

The main advantage of using SDC in Drupal themes is that frontend developers can create components without the need to learn specific Drupal theming concepts. However, users still need to have an understanding of Drupal concepts in order to effectively utilize these components within templates.

What Makes SDC Different From Twig-Based Theming?

SDC goes beyond Twig-based theming by enabling the creation of a common design system with independent or combined UI elements following atomic design principles. These elements can be utilized and reused across one or multiple themes, allowing for greater flexibility and modularity in frontend development.

Can I Start Creating SDC-Style Components Now?
Yes. Get started by taking a look and understanding the step-by-step overview of creating SDC components.
Does SDC Handle Contextual Links, Attributes, Title Suffix, And More?

Yes, SDC allows users to pass variables such as contextual links, attributes, and title suffixes to the component using Twig's include or embed functionality. This offers flexibility in customizing the component's behavior and appearance.

How To Attach Additional CSS/JS To My Component?

To attach additional CSS or JS files to the component, users can utilize the libraryOverrides key in the *.component.yml file. This allows them to specify additional libraries and their respective CSS or JS files for the components.

Are Schemas Mandatory When Defining Components?

Schemas are not mandatory when defining components in themes. However, components without schemas cannot be overridden. To enforce that all components within a theme have schemas, users can add enforce_sdc_schemas: true to the theme.info.yml file.

Which Contrib Modules Are Compatible With SDC?

At the moment, the following contrib modules are compatible with SDC:

  • CL Server 2.x
  • CL Devel 2.x
  • CL Generator 2.x
About the Author
Gaurav Mahlawat, Drupal Contributor
About the Author

Gaurav Mahlawat, Drupal Contributor

Enthusiastic about mythology and historical books, Gaurav loves to surf memes on the internet and watch crime thrillers and superhero movies. His life’s essential value? Hard work.


Back to Top
âś–