Integrating the Card
Our homepage is displaying blog posts that meet the requirements of the Drupal View we created, but they lack styles. As we indicated before, each blog article will be represented by a Card component. Let's integrate the Card so our articles inherit all the attributes of the component.Let's recap the work we've done and what the next steps are:
We built the Card component (with the Card Wide variant)
Created a Blog content type with designated View Modes (Full content, Featured, & Teaser)
We created a Drupal View to generate the blog listing sections in our homepage
Finally, we created several blog posts to populate the homepage
Next steps:
We'll get back to the full view of a blog post later, for now we are going to focus on associating the Card component with the Teaser view mode, and the Card Wide variant with the Featured view mode. How do we do this? The answer is Twig template suggestions.
Exercise: Creating twig templates for blog posts
In your Drupal site, navigate to the Homepage node
Right-click on any of the Blog posts articles within the From our blog section, and select Inspect or Inspect Element
Scroll up in the inspector's code until you find the
<article>
element that wraps the entire article you clicked on. There may be multiple<article>
tags within each article, but ensure you are looking at the main article wrapper. See screenshot below (click on it to zoom in):
I've marked a couple of important items in the screenshot above to ensure you are looking at the correct section in the code.
THEME HOOK: Tells you what entity you are currently looking at. In this example we are looking at the node, which is what we want since we are trying to configure the Blog nodes with the right component.
Next I have outlined all the possible template FILE NAME SUGGESTIONS Drupal is telling us we can use for this particular type of node. We know we are looking at a node as all the template suggestion names start with the word node--*. We can get as specific or general as we need to.
Finally, I have pointed out where the current template being used (
node.html.twig
) is located.
IMPORTANT: To ensure we are all following along with the same article type, please ensure you selected an article from the From our blog collection of articles. This means you should see the word teaser
somewhere in the list of template names above. If you don't see it, close your code inspector and repeat steps 2 & 3 above with a different article.
Creating a template suggestion for Articles in teaser view mode
The focus at this point is to create template suggestions for all article nodes that will be displayed in the Teaser view mode. So if we look at the list of file name suggestions above we can ignore the top 4 names as those are either related to the full section of content or are extremely specific to only the single article we are looking at.
So based on the remaining names after ignoring the first 4, we can select the following name:
node--article--teaser.html.twig
.node is the Drupal entity we are trying to integrate with
blog is the content type (also an entity)This names is exactly what we need to style all blog nodes that will be displayed in teaser view mode.
Now that we've selected the template we need, let's create it by making a copy from
core/themes/stable/templates/content/node.html.twig
into your theme's templates directory (/themes/custom/training_theme/src/templates/content/
Rename the newly copied template as
node--article--teaser.html.twig
Click your Drupal's cache
I know I will be creating other node related template suggestion so I will leave the copy of node.html.twig
unchanged in my /templates folder so I can keep making copies of it.
If you reload the homepage, you shouldn't really notice much difference. However, if you right-click on the same article as you did before and select Inspect or Inspect Element, and scroll to the <article>
element, you should see your new template being used by Drupal to render some of the blog nodes. See below for an example:
Integrating the Card component
OK, now that our custom twig template is ready, it's time to plug it to our Card component so our blog posts start looking nice.
We'll break the integration process down so we can explain each part of it. You will find the full template at the bottom of this page.
Open node--article--teaser.html.twig in your editor and remove all the code except for the comments at the top of the template
At the bottom of the template, add the following code:
3. Now let's create a twig variable for the card's title field
4. Now, let's add an embed
twig statement for the Card component:
5. Now let's start mapping the card's variables with Drupal fields and variables.
6. Let's now make use of the article_title
variable we created above
7. Time to add the twig blocks for date and tag fields. Update your template as follows:
Full integration code
Rendering blog nodes as cards in Drupal
Now that the card integration is complete, let's take a look at how the blog nodes look in Drupal.
After saving all your changes to node--blog--teaser.html.twig, clear Drupal's cache
Reload the homepage
What's up with the Tags?
The card looks great but it looks like the tags are not styled at all. We'll fix them next.
Last updated