Ignite Built-in Components
Ignite comes with a number of customizable built-in React Native components -- sort of a lightweight design system, in a way. It's the system we (at Infinite Red) tend to use the most often with our own custom mobile designs, and is designed to emphasize flexibility and customizability over out-of-the-box power.
There are a number of other options out there that work great with Ignite -- UI Kitten, RN Elements, and more. But if you're building something with a totally custom design, Ignite's built-in components work great.
Components
Here's a summary of each component. Click through to view detailed documentation and code examples!
AutoImage
This is a wrapper around React Native's Image component, which automatically resizes the image to fit the container.
<AutoImage
source={{ uri: "https://pbs.twimg.com/profile_images/845384502067159040/pqF2RQ2q_400x400.jpg" }}
/>
Full AutoImage Component Documentation
Button
This is a component that renders a TouchableOpacity
with given text or children.
<Button
text="Click It"
tx="button.clickIt"
preset="primary"
onPress={() => Alert.alert("pressed")}
style={[{ paddingVertical: 100 }, { borderRadius: 0 }]}
textStyle={[{ fontSize: 20 }, { color: "#a511dc" }]}
/>
<Button onPress={() => Alert.alert("pressed")}>
<Text>Click It</Text>
</Button>
Full Button Component Documentation
Card
The Card
component is useful for displaying related information in a contained way. Where you'll use ListItem
for horizontal information, Card
can be used for vertical information.
<Card
preset="reversed"
verticalAlignment="space-between"
LeftComponent={<Text>Left</Text>}
RightComponent={<Text>Right</Text>}
heading="Card Heading"
headingStyle={{ color: "#a511dc" }}
HeadingTextProps={{ weight: "bold" }}
content="Card Content"
contentStyle={{ color: "#a511dc" }}
ContentTextProps={{ weight: "light" }}
footer="Card Footer"
footerStyle={{ color: "#a511dc" }}
FooterTextProps={{ weight: "medium" }}
/>
Full Card Component Documentation
EmptyState
The EmptyState
component can be used when there is no data to display and direct the user on how to proceed.
<EmptyState
preset="default"
style={{ padding: 10 }}
imageSource={require("../../assets/images/sad-face.png")}
imageStyle={{ height: 400, width: 400 }}
ImageProps={{ resizeMode: "contain" }}
heading="EmptyState Heading"
headingStyle={{ color: "#a511dc" }}
HeadingTextProps={{ weight: "bold" }}
content="EmptyState Content"
contentStyle={{ color: "#a511dc" }}
ContentTextProps={{ weight: "light" }}
button="Press here"
buttonOnPress={handleButtonPress}
/>
Full EmptyState Component Documentation
Header
The Header
component is a component that will appear at the top of your screen. It is used to hold navigation buttons and the screen title.
<Header
headerTx="header.title"
headerText="Header Title"
leftIcon="back"
rightIcon="bullet"
onLeftPress={() => navigation.goBack()}
onRightPress={() => Alert.alert("pressed")}
style={{ backgroundColor: "purple" }}
titleStyle={{ color: "white" }}
/>
Full Header Component Documentation
Icon
This is a component that renders an icon.
<Icon
icon="back"
color="#a511dc"
size={30}
containerStyle={{ backgroundColor: "#fff" }}
style={{ resizeMode: "contain" }}
onPress={() => Alert.alert("pressed")}
/>
Full Icon Component Documentation
Screen
This is a component that renders a screen. It is used to wrap your entire screen, and handles scrolling, safe areas, and keyboard avoiding behavior.
<Screen preset="scroll">
<Header headerTitle="screen" />
// ... content here ...
</Screen>
Full Screen Component Documentation
Text
This is an enhanced version of the built-in React Native Text component. It adds internationalization and property presets.
<Text
preset="header"
tx="welcome.header"
txOptions={{
name: rootStore.currentUser.name,
}}
style={$header}
/>
Full Text Component Documentation
TextField
This component renders a View with a TextInput
and a text label.
const [input, setInput] = useState("")
const inputRef = useRef()
<TextField
value={input}
onChangeText={setInput}
labelTx="signup.name"
placeholderTx="signup.nameplaceholder"
style={$header}
inputStyle={$inputStyle}
preset="default"
forwardedRef={inputRef}
/>
Full Text Component Documentation
Toggle
This component is a flexible component that can be used to toggle a boolean value. It can be used to render a switch, checkbox, or radio button.
<Toggle
variant="checkbox"
value={value}
onValueChange={setValue}
labelTx="signup.rememberMe"
labelStyle={{ color: "#a511dc" }}
containerStyle={{ backgroundColor: "#fff" }}
/>
Full Toggle Component Documentation
Custom Components
Ignite includes a generator for creating custom components. If the built in components don't fit your needs, you can create your own.
npx ignite-cli generate component MyCustomButton
Running the generator will create a new component in the components
directory.
-- app
-- components
-- MyCustomButton.tsx