MCPcopy
hub / github.com/tailwindlabs/tailwindcss-typography

github.com/tailwindlabs/tailwindcss-typography @v0.5.20 sqlite

repository ↗ · DeepWiki ↗ · release v0.5.20 ↗
23 symbols 52 edges 17 files 1 documented · 4%
README

  <img alt="Tailwind CSS Typography" src="https://raw.githubusercontent.com/tailwindlabs/tailwindcss-typography/HEAD/.github/logo-light.svg" width="450" height="70" style="max-width: 100%;">

The official Tailwind CSS Typography plugin provides a set of prose classes you can use to add beautiful typographic defaults to any vanilla HTML you don’t control, like HTML rendered from Markdown, or pulled from a CMS.

<article class="prose lg:prose-xl">{{ markdown }}</article>

To see what it looks like in action, check out our live demo on Tailwind Play.


Installation

Install the plugin from npm:

npm install -D @tailwindcss/typography

Then add the plugin to your main style.css file:

  @import "tailwindcss";
+ @plugin "@tailwindcss/typography";

If you are still using Tailwind CSS v3, add the plugin to your tailwind.config.js file:

// tailwind.config.js
module.exports = {
  theme: {
    // ...
  },
  plugins: [
    require('@tailwindcss/typography'),
    // ...
  ],
}

Basic usage

Now you can use the prose classes to add sensible typography styles to any vanilla HTML:

<article class="prose lg:prose-xl">
  <h1>Garlic bread with cheese: What the science tells us</h1>



    For years parents have espoused the health benefits of eating garlic bread with cheese to their
    children, with the food earning such an iconic status in our culture that kids will often dress
    up as warm, cheesy loaf for Halloween.






    But a recent study shows that the celebrated appetizer may be linked to a series of rabies cases
    springing up around the country.




</article>

Choosing a gray scale

This plugin includes a modifier class for each of the five gray scales Tailwind includes by default so you can easily style your content to match the grays you're using in your project.

<article class="prose prose-slate">{{ markdown }}</article>

Here are the classes that are generated using a totally default Tailwind CSS v2.0 build:

Class Gray scale
prose-gray (default) Gray
prose-slate Slate
prose-zinc Zinc
prose-neutral Neutral
prose-stone Stone

Modifier classes are designed to be used with the multi-class modifier pattern and must be used in conjunction with the base prose class.

[!NOTE] Always include the prose class when adding a gray scale modifier

<article class="prose prose-stone">{{ markdown }}</article>

To learn about creating your own color themes, read the adding custom color themes documentation.

Applying a type scale

Size modifiers allow you to adjust the overall size of your typography for different contexts.

<article class="prose prose-xl">{{ markdown }}</article>

Five different typography sizes are included out of the box:

Class Body font size
prose-sm 0.875rem (14px)
prose-base (default) 1rem (16px)
prose-lg 1.125rem (18px)
prose-xl 1.25rem (20px)
prose-2xl 1.5rem (24px)

These can be used in combination with Tailwind's breakpoint modifiers to change the overall font size of a piece of content at different viewport sizes:

<article class="prose md:prose-lg lg:prose-xl">{{ markdown }}</article>

Everything about the provided size modifiers has been hand-tuned by professional designers to look as beautiful as possible, including the relationships between font sizes, heading spacing, code block padding, and more.

Size modifiers are designed to be used with the multi-class modifier pattern and must be used in conjunction with the base prose class.

[!NOTE] Always include the prose class when adding a size modifier

<article class="prose prose-lg">{{ markdown }}</article>

To learn about customizing the included type scales, read the documentation on customizing the CSS.

Adapting to dark mode

Each default color theme includes a hand-designed dark mode version that you can trigger by adding the prose-invert class:

<article class="prose dark:prose-invert">{{ markdown }}</article>

To learn about creating your own color themes, read the adding custom color themes documentation.

Element modifiers

Use element modifiers to customize the style of individual elements in your content directly in your HTML:

<article class="prose prose-img:rounded-xl prose-headings:underline prose-a:text-blue-600">
  {{ markdown }}
</article>

This makes it easy to do things like style links to match your brand, add a border radius to images, and tons more.

Here's a complete list of available element modifiers:

Modifier Target
prose-headings:{utility} h1, h2, h3, h4, th
prose-lead:{utility} [class~="lead"]
prose-h1:{utility} h1
prose-h2:{utility} h2
prose-h3:{utility} h3
prose-h4:{utility} h4
prose-p:{utility} p
prose-a:{utility} a
prose-blockquote:{utility} blockquote
prose-figure:{utility} figure
prose-figcaption:{utility} figcaption
prose-strong:{utility} strong
prose-em:{utility} em
prose-kbd:{utility} kbd
prose-code:{utility} code
prose-pre:{utility} pre
prose-ol:{utility} ol
prose-ul:{utility} ul
prose-li:{utility} li
prose-dl:{utility} dl
prose-dt:{utility} dt
prose-dd:{utility} dd
prose-table:{utility} table
prose-thead:{utility} thead
prose-tr:{utility} tr
prose-th:{utility} th
prose-td:{utility} td
prose-img:{utility} img
prose-picture:{utility} picture
prose-video:{utility} video
prose-hr:{utility} hr

When stacking these modifiers with other modifiers like hover, you most likely want the other modifier to come last:

<article class="prose prose-a:text-blue-600 prose-a:hover:text-blue-500">{{ markdown }}</article>

If you are still using in Tailwind CSS v3, the modifier order is the opposite:

<article class="prose prose-a:text-blue-600 hover:prose-a:text-blue-500">{{ markdown }}</article>

Read the Tailwind CSS documentation on stacked modifiers to learn more.

Overriding max-width

Each size modifier comes with a baked in max-width designed to keep the content as readable as possible. This isn't always what you want though, and sometimes you'll want the content to just fill the width of its container.

In those cases, all you need to do is add max-w-none to your content to override the embedded max-width:














    <article class="prose max-w-none">{{ markdown }}</article>







Advanced topics

Undoing typography styles

If you have a block of markup embedded in some content that shouldn't inherit the prose styles, use the not-prose class to sandbox it:

<article class="prose">
  <h1>My Heading</h1>


...













...



</article>

Note that you can't nest new prose instances within a not-prose block at this time.

Even when using a prefix for your utilities not-prose should not have a prefix.

Adding custom color themes

To customize the color theme beyond simple CSS overrides, add a @utility directive to your CSS file:

@utility prose-pink {
  --tw-prose-body: var(--color-pink-800);
  --tw-prose-headings: var(--color-pink-900);
  --tw-prose-lead: var(--color-pink-700);
  --tw-prose-links: var(--color-pink-900);
  --tw-prose-bold: var(--color-pink-900);
  --tw-prose-counters: var(--color-pink-600);
  --tw-prose-bullets: var(--color-pink-400);
  --tw-prose-hr: var(--color-pink-300);
  --tw-prose-quotes: var(--color-pink-900);
  --tw-prose-quote-borders: var(--color-pink-300);
  --tw-prose-captions: var(--color-pink-700);
  --tw-prose-code: var(--color-pink-900);
  --tw-prose-pre-code: var(--color-pink-100);
  --tw-prose-pre-bg: var(--color-pink-900);
  --tw-prose-th-borders: var(--color-pink-300);
  --tw-prose-td-borders: var(--color-pink-200);
  --tw-prose-invert-body: var(--color-pink-200);
  --tw-prose-invert-headings: var(--color-white);
  --tw-prose-invert-lead: var(--color-pink-300);
  --tw-prose-invert-links: var(--color-white);
  --tw-prose-invert-bold: var(--color-white);
  --tw-prose-invert-counters: var(--color-pink-400);
  --tw-prose-invert-bullets: var(--color-pink-600);
  --tw-prose-invert-hr: var(--color-pink-700);
  --tw-prose-invert-quotes: var(--color-pink-100);
  --tw-prose-invert-quote-borders: var(--color-pink-700);
  --tw-prose-invert-captions: var(--color-pink-400);
  --tw-prose-invert-code: var(--color-white);
  --tw-prose-invert-pre-code: var(--color-pink-300);
  --tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);
  --tw-prose-invert-th-borders: var(--color-pink-600);
  --tw-prose-invert-td-borders: var(--color-pink-700);
}

For Tailwind v3, update the typography section in the JavaScript config file and provide your colors under the css key:

js {{ filename: 'tailwind.config.js' }} /** @type {import('tailwindcss').Config} */ module.exports = { theme: { extend: { typography: () => ({ pink: { css: { '--tw-prose-body': 'var(--color-pink-800)', '--tw-prose-headings': 'var(--color-pink-900)', '--tw-prose-lead': 'var(--color-pink-700)', '--tw-prose-links': 'var(--color-pink-900)', '--tw-prose-bold': 'var(--color-pink-900)', '--tw-prose-counters': 'var(--color-pink-600)', '--tw-prose-bullets': 'var(--color-pink-400)', '--tw-prose-hr': 'var(--color-pink-300)', '--tw-prose-quotes': 'var(--color-pink-900)', '--tw-prose-quote-borders': 'var(--color-pink-300)', '--tw-prose-captions': 'var(--color-pink-700)', '--tw-prose-code': 'var(--color-pink-900)', '--tw-prose-pre-code': 'var(--color-pink-100)', '--tw-prose-pre-bg': 'var(--color-pink-900)', '--tw-prose-th-borders': 'var(--color-pink-300)', '--tw-prose-td-borders': 'var(--color-pink-200)', '--tw-prose-invert-body': 'var(--color-pink-200)', '--tw-prose-invert-headings': 'var(--color-white)', '--tw-prose-invert-lead': 'var(--color-pink-300)', '--tw-prose-invert-links': 'var(--color-white)', '--tw-prose-invert-bold': 'var(--color-white)', '--tw-prose-invert-counters': 'var(--color-pink-400)', '--tw-prose-invert-bullets': 'var(--color-pink-600)', '--tw-prose-invert-hr': 'var(--color-pink-700)', '--tw-prose-invert-quotes': 'var(--color-pink-100)', '--tw-prose-invert-quote-borders': 'var(--color-pink-700)', '--tw-prose-invert-captions': 'var(--color-pink-400)', '--tw-prose-invert-code': 'var(--color-white)', '--tw-prose-invert-pre-code': 'var(--color-pink-300)', '--tw-prose-invert-pre-bg': 'rgb(0 0 0 / 50%)', '--tw-prose-invert-th-borders': 'var(--color-pink-600)', '--tw-prose-invert-td-borders': 'var(--color-pink-700)', }, }, }), }, }, }

See our internal style definitions for some more examples.

Changing the default class name

If you need to use a class name other than prose for any reason, you can do so using the className option when registering the plugin:

```css @import 'tailwi

Core symbols most depended-on inside this repo

em
called by 382
src/styles.js
round
called by 47
src/styles.js
rem
called by 15
src/styles.js
format
called by 10
jest/customMatchers.js
opacity
called by 10
src/styles.js
isPlainObject
called by 4
src/utils.js
inWhere
called by 3
src/index.js
isObject
called by 3
src/utils.js

Shape

Function 23

Languages

TypeScript100%

Modules by API surface

src/utils.js6 symbols
jest/customMatchers.js5 symbols
src/styles.js4 symbols
src/index.js3 symbols
src/index.test.js1 symbols
demo/pages/variants.js1 symbols
demo/pages/themes.js1 symbols
demo/pages/list-items.js1 symbols
demo/pages/_app.js1 symbols

Used by 1 indexed graphs manifest dependencies, hub-wide

Dependencies from manifests, versioned

@mdx-js/loader1.0.19 · 1×
@mdx-js/mdx1.6.6 · 1×
@next/mdx8.1.0 · 1×
autoprefixer10.2.1 · 1×
highlight.js10.4.1 · 1×
jest29.7.0 · 1×
jest-diff27.3.1 · 1×
next12.0.1 · 1×
postcss8.2.3 · 1×
postcss-selector-parser6.0.10 · 1×
prettier2.1.2 · 1×
react17.0.2 · 1×

For agents

$ claude mcp add tailwindcss-typography \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact