Skip to content

Commit

Permalink
Use proper markdown syntax conventions
Browse files Browse the repository at this point in the history
  • Loading branch information
khinshankhan authored Nov 22, 2023
1 parent 3ff4089 commit bc30dd6
Showing 1 changed file with 39 additions and 40 deletions.
79 changes: 39 additions & 40 deletions src/content/spotlights/what-is-tailwind.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,26 +8,25 @@ created_at: "2023/09/10"
title: What is Tailwind?
---

Tailwind
**What is Tailwind CSS?**
## What is Tailwind CSS?

Tailwind is an open-source CSS framework that provides utility-like classes such as `flex`, `w-1/4`, `m-5` and `hover:font-bold`. Tailwind enables developers to quickly build expressive user interfaces and responsive websites using its low-level CSS classes.

**Why should I use Tailwind?**
## Why should I use Tailwind?

- Sensible and consistent defaults
- Easy to customize and extend to your liking. All the styles are customizable and adding new variants is easy
- Extremely lightweight in production
- Tailwind’s build system produces a minimal size CSS bundle that only contains the classes actually used in your HTML, making it lighter than alternatives
- Enables quick iteration and fast prototyping

You may still be wondering "Okay, but why Tailwind? It goes against what I've learned." You can read Adam Wathan's (author of Tailwind) blog post here https://adamwathan.me/css-utility-classes-and-separation-of-concerns But tldr you've probably learned a way that basically creates a 1:1 mapping of HTML elements to CSS classes. It's painful to work in such a codebase and your CSS file is needlessly huge. A major problem with this is that it doesn't allow for easy reuse of styles to build more complex or similar components.
You may still be wondering "Okay, but why Tailwind? It goes against what I've learned." You can read Adam Wathan's (author of Tailwind) [blog post](https://adamwathan.me/css-utility-classes-and-separation-of-concerns). TLDR you've probably learned a way that basically creates a 1:1 mapping of HTML elements to CSS classes. It's painful to work in such a codebase and your CSS file is needlessly huge. A major problem with this is that it doesn't allow for easy reuse of styles to build more complex or similar components.

Utility classes are content agnostic and sane to compose (use together to build something greater). In Wathan's words: "amazing thing about this is that before you know it, you can build entirely new UI components without writing any new CSS". Your utility classes can be composed in a way that aligns to your design system, allowing you to move faster and stay aligned with designs. We'll take a look at this later.

**What does code using Tailwind look like?**
## What does code using Tailwind look like?

Let’s say you want to create a Toast that looks like:
Let’s say you want to create a Toast that looks like:

![Image of Toast Component](https://i.imgur.com/srVxaLa.png)

Expand Down Expand Up @@ -72,7 +71,9 @@ If you were to make this component using custom CSS it would look something like
padding: 1.5rem;
border-radius: 0.5rem;
background-color: #fff;
box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
box-shadow:
0 20px 25px -5px rgba(0, 0, 0, 0.1),
0 10px 10px -5px rgba(0, 0, 0, 0.04);
}
.chat-notification-logo-wrapper {
flex-shrink: 0;
Expand All @@ -98,20 +99,19 @@ If you were to make this component using custom CSS it would look something like
</style>
```

**How do I set up Tailwind for my project?**

Tailwind provides a comprehensive installation guide for your preferred project setup, whether that’s Laravel, Ruby on Rails, React, or even if you just want a simple cdn to plug and play https://tailwindcss.com/docs/installation. We recommend using PostCSS, which is compatible with most framework guides as well. Tailwind does rely a bit on your build system, so the steps vary, but we’ll explain the core concept shared between all the variations:
## How do I set up Tailwind for my project?

Tailwind provides a comprehensive [installation guide](https://tailwindcss.com/docs/installation) for your preferred project setup, whether that’s Laravel, Ruby on Rails, React, or even if you just want a simple cdn to plug and play. We recommend using PostCSS, which is compatible with most framework guides as well. Tailwind does rely a bit on your build system, so the steps vary, but we’ll explain the core concept shared between all the variations:

Firstly, when working with designers, you’ll want to set up variants based on the design system. You can use CVA to create variants. Let’s look at an example
Tailwind is a step between easy DX and code your browsers understand. If you look at the docs for padding https://tailwindcss.com/docs/padding for example, you’ll notice that `px-0` is equal to the properties
Tailwind is a step between easy DX and code your browsers understand. If you look at the [docs for padding](https://tailwindcss.com/docs/padding) for example, you’ll notice that `px-0` is equal to the properties

```css
padding-left: 0px;
padding-right: 0px;
```

Your browser doesn’t understand `px-0` but it does understand the properties `padding-left` and `padding-right`. You can easily create new mappings of shorthand classes to CSS properties or override current ones via the tailwind config. Classes being mapped to the properties still need to be outputted to CSS files for usage in browsers when viewing a page. We need to add Tailwind’s custom CSS directives into a CSS file which will be processed by PostCSS when we build our site. These `@tailwind` blocks are special and they’ll be picked up by the Tailwind plugins to insert Tailwind’s generated styles (you can read more about them here https://tailwindcss.com/docs/functions-and-directives).
Your browser doesn’t understand `px-0` but it does understand the properties `padding-left` and `padding-right`. You can easily create new mappings of shorthand classes to CSS properties or override current ones via the tailwind config. Classes being mapped to the properties still need to be outputted to CSS files for usage in browsers when viewing a page. We need to add Tailwind’s custom CSS directives into a CSS file which will be processed by PostCSS when we build our site. These `@tailwind` blocks are special and they’ll be picked up by the Tailwind plugins to insert Tailwind’s generated styles (you can read more about them [here](https://tailwindcss.com/docs/functions-and-directives)).

```css
// File: styles.css
Expand All @@ -124,7 +124,7 @@ The above CSS code is obviously invalid CSS, and it’s unable to do anything us

The outputted CSS files are what get used in your project.

The reason we recommend PostCSS is because you can transform your CSS after it’s been built. This sounds strange but it’s a powerful concept, eg because then you can use Autoprefixer https://github.com/postcss/autoprefixer which can add prefixes like webkit or moz to properties to ensure they work cross-browser, eg
The reason we recommend PostCSS is because you can transform your CSS after it’s been built. This sounds strange but it’s a powerful concept, eg because then you can use [Autoprefixer](https://github.com/postcss/autoprefixer) which can add prefixes like webkit or moz to properties to ensure they work cross-browser, eg

```css
.example {
Expand All @@ -142,13 +142,13 @@ becomes
}
```

You can poke around for other PostCSS plugins, they range from useful (autoprefixer, cssnano, etc) to useless but fun (Australian anyone? https://github.com/dp-lewis/postcss-australian-stylesheets).
You can poke around for other PostCSS plugins, they range from useful (autoprefixer, cssnano, etc) to useless but fun ([Australian anyone?](https://github.com/dp-lewis/postcss-australian-stylesheets)).

**How do I use Tailwind?**
## How do I use Tailwind?

Let's go through how to "build entirely new UI components without writing any new CSS". We'll zero in on React for this part, but generally, most frameworks have equivalent composable elements and styling. We'll try making a button (sounds simple, but is it?)

In React, a basic concept is components. They’re composable by nature, and are supposed to be self-contained and reusable. This is the perfect place to use tailwind styles. In this example we'll also use the CVA library (https://cva.style/docs), to abstract away the variant conditions and provide type safety.
In React, a basic concept is components. They’re composable by nature, and are supposed to be self-contained and reusable. This is the perfect place to use tailwind styles. In this example we'll also use the [CVA library](https://cva.style/docs), to abstract away the variant conditions and provide type safety.

```js
export const foobarVariants = cva(
Expand Down Expand Up @@ -264,29 +264,28 @@ export const ConfirmDialog = ({ children }) => (
);
```


**Still, so many classes seems like a mess and a pain to work with**
## Still, so many classes seems like a mess and a pain to work with

At some point, when you’re using tailwind extensively, your file is going to be filled up with inline styles, which can be a bit of a nuisance to read, or even more important: keeping track of what’s what and where.

Yep, we also thought it’d be a pain in the beginning and slept on Tailwind for a while. However, the community and support is crazily extensive.

Tailwind itself is an opinionated CSS framework, and so naturally it has some guidance/opinions on how you should handle this, which can be read up on at reusing styles (https://tailwindcss.com/docs/reusing-styles) and adding custom styles https://tailwindcss.com/docs/adding-custom-styles. The general tendency and advice is to go with inline styling rather than declaring custom styles (because it’ll keep your bundle size small and increase reusability).
Tailwind itself is an opinionated CSS framework, and so naturally it has some guidance/opinions on how you should handle this, which can be read up on at [reusing styles](https://tailwindcss.com/docs/reusing-styles) and [adding custom styles](https://tailwindcss.com/docs/adding-custom-styles). The general tendency and advice is to go with inline styling rather than declaring custom styles (because it’ll keep your bundle size small and increase reusability).

There are several tools which can help you organize this inline CSS, to better keep track of it such as automatically sorting your styling, which is very helpful as you start adding complex styling such as responsiveness, states such as hover, focus etc.
Such plugins exist for tools like https://prettier.io, namely https://github.com/tailwindlabs/prettier-plugin-tailwindcss.
There are also other tools that achieve the same, such as a VSCode extension: https://github.com/heybourn/headwind.
There are several tools which can help you organize this inline CSS, to better keep track of it such as automatically sorting your styling, which is very helpful as you start adding complex styling such as responsiveness, states such as hover, focus etc.
Such plugins exist for tools like [prettier](https://prettier.io), namely [Tailwind prettier plugin](https://github.com/tailwindlabs/prettier-plugin-tailwindcss.).
There are also other tools that achieve the same, such as [the headwind VSCode extension](https://github.com/heybourn/headwind.).
With these tools you’ll easily be able to streamline your stylings, and not worry about which order they’re being applied in, or customize it to your heart's content.

The tailwind blog https://tailwindcss.com/blog/automatic-class-sorting-with-prettier outlines why the sort order is very very powerful: it’s the same order that Tailwind orders them in your CSS. This means you can actually predict which classes will override or complement which classes by just reading the order instead of trying it out and account for edge cases like css load time (2 min example of a headache inducing issue this resolves https://youtu.be/QBajvZaWLXs?t=316)
The tailwind blog has a [post](https://tailwindcss.com/blog/automatic-class-sorting-with-prettier) which outlines why the sort order is very very powerful: it’s the same order that Tailwind orders them in your CSS. This means you can actually predict which classes will override or complement which classes by just reading the order instead of trying it out and account for edge cases like css load time ([2 min example of a headache inducing issue](https://youtu.be/QBajvZaWLXs?t=316) this resolves)

In addition, colocation of styles with the actual component makes so much sense. You no longer have to jump between 2, 3, or however many n files you did before (eg button.tsx -> button.css.ts -> global.css.ts). If you want to update a button, you generally go to the file you declared the button (button.tsx) and that’s it.

**How to extend Tailwind**
## How to extend Tailwind

You’re probably (hopefully) hyped up at this point. A question that may be lingering in your mind may be, how do I really customize it to my design system and branding?

The customizing is as easy editing your `tailwind.config.js` file. You can extend or override the default (https://github.com/tailwindlabs/tailwindcss/blob/master/stubs/config.full.js). Keys missing in your config fallback to the default config. If you declare a key like `colors` under theme, it’ll replace the default config with your colors config. If you declare the key `colors` under extend under theme, it’ll merge the tailwind default config with your config for that.
The customizing is as easy editing your `tailwind.config.js` file. You can extend or override [the default](https://github.com/tailwindlabs/tailwindcss/blob/master/stubs/config.full.js). Keys missing in your config fallback to the default config. If you declare a key like `colors` under theme, it’ll replace the default config with your colors config. If you declare the key `colors` under extend under theme, it’ll merge the tailwind default config with your config for that.

So this:

Expand All @@ -311,7 +310,7 @@ export default {
2: "2",
},
},
}
};
```

Will completely replace the default zIndex, whereas
Expand All @@ -334,8 +333,9 @@ export default {
},
},
},
}
};
```

Will result in a merge like

```js
Expand Down Expand Up @@ -365,22 +365,21 @@ Will result in a merge like
}
```

Again, the tailwind docs are super comprehensive! Check them out https://tailwindcss.com/docs/configuration

**Where can I try Tailwind CSS?**
Again, the [tailwind docs](https://tailwindcss.com/docs/configuration) are super comprehensive! Check them out!

Tailwind has a dedicated sandbox environment where you can test all its features (including the build system). The sandbox is available at https://play.tailwindcss.com/
## Where can I try Tailwind CSS?

Tailwind has a dedicated sandbox environment where you can test all its features (including the build system). The sandbox is available at [https://play.tailwindcss.com/](https://play.tailwindcss.com/)

**Resources**
## Resources

- Tailwind website: https://tailwindcss.com
- Tailwind Labs youtube: https://www.youtube.com/tailwindlabs
- awesome-tailwindcss: https://github.com/aniftyco/awesome-tailwindcss
- Component examples: https://tailwindcomponents.com
- Twind (Tailwind in JS): https://github.com/tw-in-js/twind
- CVA: https://cva.style/docs
- Prettier plugin tailwindcss: https://github.com/tailwindlabs/prettier-plugin-tailwindcss
- Headwind: https://github.com/heybourn/headwind
- [Tailwind website (best resource)](https://tailwindcss.com/docs/functions-and-directives)
- [Tailwind Labs youtube](https://www.youtube.com/tailwindlabs)
- [awesome-tailwindcss](https://github.com/aniftyco/awesome-tailwindcss)
- [Component examples](https://tailwindcomponents.com)
- [Twind (Tailwind in JS)](https://github.com/tw-in-js/twind)
- [CVA](https://cva.style/docs)
- [Prettier plugin tailwindcss](https://github.com/tailwindlabs/prettier-plugin-tailwindcss.)
- [Headwind](https://github.com/heybourn/headwind.)

Cheers! Happy tailwind-ing?

0 comments on commit bc30dd6

Please sign in to comment.