Skip Navigation
React Magma

Component API

Heading

Basic Usage

The Heading component can be used with the level prop to render the HTML heading elements, levels 1-6.

import React from 'react';
import { Heading } from 'react-magma-dom';
export function Example() {
return (
<>
<Heading level={1}>Heading 1</Heading>
<Heading level={2}>Heading 2</Heading>
<Heading level={3}>Heading 3</Heading>
<Heading level={4}>Heading 4</Heading>
<Heading level={5}>Heading 5</Heading>
<Heading level={6}>Heading 6</Heading>
</>
);
}

Size

There are six visual styles for the heading: headingXLarge, headingLarge, headingMedium, headingSmall, headingXSmall and heading2XSmall. If not specified, a corresponding visual style will be applied based on the heading.

Visual style and heading level can be set independently so you can specify the correct semantic level and then apply any of the visual styles to change the visual appearance to fit your design.

Furthermore, the visualStyle prop can also accept the values for the four different paragraph visual styles: bodyLarge, bodyMedium, bodySmall, and bodyXSmall. These are sizes are also used with the Paragraph component.

import React from 'react';
import { Heading, TypographyVisualStyle } from 'react-magma-dom';
export function Example() {
return (
<>
<Heading level={2} visualStyle={TypographyVisualStyle.headingXLarge}>
H2 styled as Heading XLarge
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.headingLarge}>
H2 styled as Heading Large
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.headingMedium}>
H2 styled as Heading Medium
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.headingSmall}>
H2 styled as Heading Small
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.headingXSmall}>
H2 styled as Heading XSmall
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.heading2XSmall}>
H2 styled as Heading 2XSmall
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.bodyLarge}>
H2 styled as Body Large
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.bodyMedium}>
H2 styled as Body Medium
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.bodySmall}>
H2 styled as Body Small
</Heading>
<Heading level={2} visualStyle={TypographyVisualStyle.bodyXSmall}>
H2 styled as Body XSmall
</Heading>
</>
);
}

Context Variant

The contextVariant prop can be used to set additional styles on a heading component. The contextVariant can affect the font-size, text-transform, or font-family. The default contextVariant is default.

The expressive context variant can be used in marketing contexts, which may require more variety than the default styles.

The narrative context variant can be used for content-heavy contexts, such as a blog post or an e-reader.

import React from 'react';
import { Heading, TypographyContextVariant } from 'react-magma-dom';
export function Example() {
return (
<>
<div style={{ marginBottom: '40px' }}>
<Heading contextVariant={TypographyContextVariant.expressive} level={1}>
Expressive Heading 1
</Heading>
<Heading contextVariant={TypographyContextVariant.expressive} level={2}>
Expressive Heading 2
</Heading>
<Heading contextVariant={TypographyContextVariant.expressive} level={3}>
Expressive Heading 3
</Heading>
<Heading contextVariant={TypographyContextVariant.expressive} level={4}>
Expressive Heading 4
</Heading>
<Heading contextVariant={TypographyContextVariant.expressive} level={5}>
Expressive Heading 5
</Heading>
<Heading contextVariant={TypographyContextVariant.expressive} level={6}>
Expressive Heading 6
</Heading>
</div>
<div>
<Heading contextVariant={TypographyContextVariant.narrative} level={1}>
Narrative Heading 1
</Heading>
<Heading contextVariant={TypographyContextVariant.narrative} level={2}>
Narrative Heading 2
</Heading>
<Heading contextVariant={TypographyContextVariant.narrative} level={3}>
Narrative Heading 3
</Heading>
<Heading contextVariant={TypographyContextVariant.narrative} level={4}>
Narrative Heading 4
</Heading>
<Heading contextVariant={TypographyContextVariant.narrative} level={5}>
Narrative Heading 5
</Heading>
<Heading contextVariant={TypographyContextVariant.narrative} level={6}>
Narrative Heading 6
</Heading>
</div>
</>
);
}

Color

The color prop can be used to change the color of the heading to convey additional meaning. It accepts the values: success, danger and subdued.

import React from 'react';
import { Heading, TypographyColor } from 'react-magma-dom';
export function Example() {
return (
<>
<Heading color={TypographyColor.success} level={2}>
Success Color Heading
</Heading>
<Heading color={TypographyColor.danger} level={2}>
Danger Color Heading
</Heading>
<Heading color={TypographyColor.subdued} level={2}>
Subdued Color Heading
</Heading>
</>
);
}

Inverse

The isInverse property is an optional boolean that changes the colors so the component can appear on a dark background.

import React from 'react';
import { Card, CardBody, Heading, TypographyColor } from 'react-magma-dom';
export function Example() {
return (
<Card isInverse>
<CardBody>
<Heading isInverse level={2}>
Heading 2
</Heading>
<Heading color={TypographyColor.success} isInverse level={2}>
Success Color Heading
</Heading>
<Heading color={TypographyColor.danger} isInverse level={2}>
Danger Color Heading
</Heading>
<Heading isInverse level={2} color={TypographyColor.subdued}>
Heading 2 Subdued
</Heading>
</CardBody>
</Card>
);
}

No Margins

By default, the Heading component includes margins on the top and bottom. When the noMargins prop is applied, the element will have a margin value of 0.

import React from 'react';
import { Heading } from 'react-magma-dom';
export function Example() {
return (
<>
<Heading noMargins level={1}>
Heading 1
</Heading>
<Heading noMargins level={2}>
Heading 2
</Heading>
<Heading noMargins level={3}>
Heading 3
</Heading>
<Heading noMargins level={4}>
Heading 4
</Heading>
<Heading noMargins level={5}>
Heading 5
</Heading>
<Heading noMargins level={6}>
Heading 6
</Heading>
</>
);
}

Forward Ref

Using React's forwardRef feature you can gain access to the reference of the internal heading.

import React from 'react';
import { Button, Heading } from 'react-magma-dom';
export function Example() {
const headingRef = React.useRef<HTMLHeadingElement>();
function handleClick() {
headingRef.current.tabIndex = -1;
headingRef.current.focus();
}
return (
<>
<Heading ref={headingRef} level={1}>
Heading to Be Focused
</Heading>
<Button onClick={handleClick}>Click to focus heading</Button>
</>
);
}

Testing

Passing in the testId prop will add the data-testid attribute to the heading element for easier querying in tests.

<Heading testId="test-id">Heading 1</Heading>

Heading Props

This component uses forwardRef. The ref is applied to the heading element.

All of the global HTML attributes can be provided as props and will be applied to the heading (h1-6) element that gets rendered.

as

Type

string

Default

-


children

Description

The content of the component

Type

any

Default

-


color

Description

The color of the component, that helps to convey meaning or relative emphasis

Type

enum, one of:
TypographyColor.danger
TypographyColor.default
TypographyColor.subdued
TypographyColor.success

Default

TypographyColor.default


contextVariant

Description

Additional styles for typography based on the context of the content

Type

enum, one of:
TypographyContextVariant.default
TypographyContextVariant.expressive
TypographyContextVariant.narrative

Default

TypographyContextVariant.default


element

Type

string

Default

-


isInverse

Description

If true, the component will have inverse styling to better appear on a dark background

Type

boolean

Default

false


level

Required

Description

Number to indicate which level heading will render (e.g. h1, h2 etc.)

Type

1 | 2 | 3 | 4 | 5 | 6

Default

-


noMargins

Type

boolean

Default

-


ref

Type

any

Default

-


theme

Type

any

Default

-


visualStyle

Description

Applies visual styles including font-size, font-weight, line-height and margins

Type

enum, one of:
TypographyVisualStyle.bodyLarge
TypographyVisualStyle.bodyMedium
TypographyVisualStyle.bodySmall
TypographyVisualStyle.bodyXSmall
TypographyVisualStyle.heading2XLarge
TypographyVisualStyle.heading2XSmall
TypographyVisualStyle.headingLarge
TypographyVisualStyle.headingMedium
TypographyVisualStyle.headingSmall
TypographyVisualStyle.headingXLarge
TypographyVisualStyle.headingXSmall

Default

-


Deploys by Netlify