2018-02-06 08:59:18 +00:00
|
|
|
|
---
|
|
|
|
|
title: Using Tailwind CSS in your Drupal Theme
|
2020-03-08 14:32:13 +00:00
|
|
|
|
date: 2018-02-05
|
2018-12-31 12:13:05 +00:00
|
|
|
|
excerpt: What is Tailwind CSS, and how do I use it in Drupal theme?
|
2018-02-06 08:59:18 +00:00
|
|
|
|
tags:
|
2020-03-08 17:52:59 +00:00
|
|
|
|
- drupal
|
|
|
|
|
- drupal-planet
|
|
|
|
|
- drupal-theming
|
|
|
|
|
- tailwind-css
|
2018-02-06 08:59:18 +00:00
|
|
|
|
---
|
2020-03-08 17:52:59 +00:00
|
|
|
|
|
2018-02-06 08:59:18 +00:00
|
|
|
|
## What is Tailwind?
|
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
> Tailwind is a utility-first CSS framework for rapidly building custom user
|
|
|
|
|
> interfaces.
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
It generates a number of utility classes that you can add to your theme's markup
|
|
|
|
|
to apply different styling, as well as the ability to apply classes to other
|
|
|
|
|
markup and create components comprised of utility classes using a custom
|
|
|
|
|
`@apply` PostCSS directive.
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
|
|
|
|
## Initial Configuration
|
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
The installation and configuration steps are essentially the same as those
|
|
|
|
|
outlined within the [Tailwind documentation][1], and should be performed within
|
|
|
|
|
your custom theme's directory (e.g. `sites/all/themes/custom/mytheme` for Drupal
|
|
|
|
|
7 or `themes/custom/mytheme` for Drupal 8:
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
|
|
|
|
1. Require PostCSS and Tailwind via `npm` or `yarn`.
|
|
|
|
|
1. Generate a configuration file using `./node_modules/.bin/tailwind init`.
|
|
|
|
|
1. Tweak the settings as needed.
|
|
|
|
|
1. Add a `postcss.config.js` file.
|
|
|
|
|
1. Configure your build tool (Gulp, Grunt, Webpack).
|
|
|
|
|
1. Generate the CSS.
|
2020-03-08 17:52:59 +00:00
|
|
|
|
1. Include a path to the generated CSS in your `MYTHEME.info`,
|
|
|
|
|
`MYTHEME.info.yml` or `MYTHEME.libraries.yml` file.
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
|
|
|
|
## PostCSS Configuration
|
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
Create a `postcss.config.js` file and add `tailwindcss` as a plugin, passing the
|
|
|
|
|
path to the config file:
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
2018-06-01 21:42:43 +00:00
|
|
|
|
```language-js
|
2018-02-06 08:59:18 +00:00
|
|
|
|
module.exports = {
|
|
|
|
|
plugins: [
|
|
|
|
|
require('tailwindcss')('./tailwind.js'),
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Configuration for Drupal
|
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
There are some configuration settings within `tailwind.js` that you’ll need to
|
|
|
|
|
change to make things work nicely with Drupal. These are within the `options`
|
|
|
|
|
section:
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
2018-06-01 21:42:43 +00:00
|
|
|
|
```language-js
|
2018-02-06 08:59:18 +00:00
|
|
|
|
options: {
|
|
|
|
|
prefix: 'tw-',
|
|
|
|
|
important: true,
|
|
|
|
|
...
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### Prefix
|
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
By adding a prefix like `tw-`, we can ensure that the Tailwind classes don’t
|
|
|
|
|
conflict with core HTML classes like `block`. We can also ensure that they won't
|
|
|
|
|
conflict with any other existing HTML or CSS.
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
|
|
|
|
No prefix:
|
|
|
|
|
|
2018-09-04 18:58:54 +00:00
|
|
|
|
![](/images/blog/using-tailwind-drupal/prefix-1.png){.with-border}
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
|
|
|
|
With prefix:
|
|
|
|
|
|
2018-09-04 18:58:54 +00:00
|
|
|
|
![](/images/blog/using-tailwind-drupal/prefix-2.png){.with-border}
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
|
|
|
|
### Important
|
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
We can also set the `!important` rule on all Tailwind’s generated classes. We
|
|
|
|
|
need to do this if we want to override core styles which have more specific
|
|
|
|
|
rules.
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
For example: if I had this core markup then the left margin added by `tw-ml-4`
|
|
|
|
|
would be overridden by core’s `.item-list ul` styling.
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
|
|
|
|
```language-html
|
|
|
|
|
<div class="item-list">
|
|
|
|
|
<ul class="tw-ml-4">
|
|
|
|
|
...
|
|
|
|
|
</ul>
|
|
|
|
|
</div>
|
|
|
|
|
```
|
|
|
|
|
|
2018-09-04 18:58:54 +00:00
|
|
|
|
![](/images/blog/using-tailwind-drupal/important-1.png){.with-border}
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
With the `!important` rule enabled though, the Tailwind’s class takes precedence
|
|
|
|
|
and is applied.
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
2018-09-04 18:58:54 +00:00
|
|
|
|
![](/images/blog/using-tailwind-drupal/important-2.png){.with-border}
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
|
|
|
|
## Example
|
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
For an example of Tailwind within a Drupal 8 theme, see the custom theme for the
|
|
|
|
|
[Drupal Bristol website][0] on GitHub.
|
2018-02-06 08:59:18 +00:00
|
|
|
|
|
2020-03-08 17:52:59 +00:00
|
|
|
|
[0]:
|
|
|
|
|
https://github.com/drupalbristol/drupal-bristol-website/tree/master/web/themes/custom/drupalbristol
|
2018-02-06 08:59:18 +00:00
|
|
|
|
[1]: https://tailwindcss.com/docs/installation
|
|
|
|
|
[2]: https://www.npmjs.com/get-npm
|
|
|
|
|
[3]: https://yarnpkg.com/lang/en/docs/install
|