Skip to main content

Text

Ignite's Text Component is an enhanced version of the built-in React Native Text component. It adds internationalization and several useful (and customizable) property presets. You shouldn't need the built-in React Native Text component if you use this. It does everything the built-in one does and more.

By enhancing the Ignite Text component and using it across your app, you can make sure the right fonts, font weight, and other styles and behaviors are shared across your whole app.

text-component

Props

text

The text optional prop is the text of the component. We encourage you to not use this but rather use the tx prop instead.

<Text text="My Text" />

tx

The tx optional prop is the string key used to look up the translated text for the user's locale. Ignite uses i18n-js for internationalization.


```tsx
<Text tx="welcomeScreen.readyForLaunch" />

txOptions

The txOptions optional prop is an object of options to pass to i18n. Useful for interpolation as well as explicitly setting locale or translation fallbacks. You'll be defining these in the app/i18n/*.json files, and can use {{variableName}} for interpolation.

// in en.json
profile: {
details: "{{name}} who is {{age}} years old"
}
// in your component
<Text
tx="profile.details"
txOptions={{
name: "Jamon",
age: 40,
}}
/>

style

The style optional prop is an object with overrides for this particular component. You can use style overrides with presets.

<Text tx="welcome.title" style={{ fontSize: 40 }} />

weight

The weight optional prop is the font weight to use for the text. It utilizes the fonts defined in the app/theme/typography.tsx file.

<Text tx="welcome.title" weight="medium" />

size

The size optional prop is the font size to use for the text. The options are defined as $sizeStyles in app/components/Text.tsx. You can add sizes as you need to the $sizeStyles object and use them in your Text component.

<Text tx="welcome.title" size="lg" />

preset

The preset optional prop specifies the string of the preset style you want to use. You can use style overrides with presets.

<Text preset="bold" text="This is bold" />

Presets

Presets allow you to have a consistent look and feel across your app without having to redefine the styles all the time.

<View preset="heading" text="My Header" />

You'll want to customize these presets and add more. You can do this in the text.presets.ts file.

If you find yourself overriding styles with the style prop a lot, you probably need a new preset for that use case.

Available Presets

default: The default text styles.

bold: A bold version of the default text.

heading: Large headers.

subheading: A smaller piece of secondary information.

formLabel: Form input label.

formHelper: Form assistive information.

Custom Presets

Feel free to add your own presets by emulating the style you see with the provided presets. In a typical Infinite Red project, we will have a dozen or more presets that we use across the project. Simply add a new key to the $presets object in app/components/Text.tsx and then pass the name of the preset to the preset prop.

$presets = {
label: [$baseStyle, $sizeStyles.md, $fontWeightStyles.medium] as StyleProp<TextStyle>,
}
<Text preset="label" text="Email" />