Skip to content

React

Using PatternFly Elements in your React app

To get web components to work with React it’s pretty easy and straightforward. If you’d like to follow along, go ahead and create a new React CodeSandbox on codesandbox.io. The React sandbox uses create-react-app to scaffold an app and you can view your changes in real-time right in the web app. With CodeSandbox, you can also add any npm dependency with just a few button clicks. If you want to run this app locally, you can clone the repository on GitHub.

“Using PatternFly Elements in your React App” is broken down into four sections:

Each section will show you exactly what you need to do with code snippets and an accompanying CodeSandbox that you can edit or fork.

Initial setup

Import React and ReactDOM at the top of the index.js file in the /src/ directory.

import React from 'react';
import ReactDOM from 'react-dom';

Adding PatternFly Elements

With the setup complete, let’s add a couple of PatternFly Elements web components to our application to make sure everything is hooked up properly. We’re going to add a card (pf-card). Later, we’ll add an accordion (pf-accordion) and some CSS to help with our layout (pf-layouts).

Once again, if we were building this app locally, we’d install our dependencies from npm using yarn.

yarn add @patternfly/elements

But if you’re using CodeSandbox, just search for "@patternfly/pf-card"

In our index.js file in the /src/ directory, let’s add the import statements for our components to the top of the file.

import React from "react";
import ReactDOM from "react-dom";
import "@patternfly/elements/pf-card/pf-card.js";
import "./styles.css";

Let’s add some simple markup in the App function in the index.js file to see that our pf-card is working.

function App() {
return (
<div className="App">
<h1>PatternFly Elements with React</h1>
<pf-card>
<img alt="From https://picsum.photos/" src="https://picsum.photos/id/1019/300/200" />
<p>This is the light pf-card and <a href="#">a link</a>.</p>
<p>
Leverage agile frameworks to provide a robust synopsis for high level
overviews. Iterative approaches to corporate strategy foster collaborative
thinking to further the overall value proposition.
</p>
<p>
Organically grow the holistic world view of disruptive innovation via
workplace diversity and empowerment.
</p>
<a class="cta" slot="footer" href="#">Learn more</a>
</pf-card>
</div>
);
}

Below is the accompanying CodeSandbox to see that our initial setup is correct and that we’ve successfully added our web components to our app.

Interacting with our web components API

After adding our accordion, let’s say that we’d like to have the first panel of the accordion open up after the page loads. To work with the accordion, there are a few things that we need to hook up.

👉 Note: React 18@experimental provides support for HTML, so the useEffect/useRef workaround is no longer needed for property setting and event listeners

First, let’s import useRef and useEffect.

import React, { useRef, useEffect } from "react";

Now let’s create a React Ref so we can work with the pf-accordion DOM API. To learn more about Refs and the DOM in React, check out their documentation. We’ll start by creating a new ref inside our App function.

const accordion = useRef();

We'll add a useEffect callback and call the toggle method on the ref's current element (our <pf-accordion>), so we can open the first panel of the accordion when the page loads.

useEffect(() => {
accordion.current.toggle(0);
});

Next, let’s add all of our markup from the App function we had previously to our return method. We’ll also want to add a ref attribute to the opening tag of pf-accordion and set it equal to {accordion}.

function App() {
const accordion = useRef();

useEffect(() => {
accordion.current.toggle(0);
});

return (
<div className="App">
<h1>PatternFly Elements with React</h1>
<section>
<pf-card rounded>
<img alt="From https://picsum.photos/" src="https://picsum.photos/id/1019/300/200" />
<p>
This is the light pf-card and <a href="#">a link</a>.
</p>
<p>
Leverage agile frameworks to provide a robust synopsis for high
level overviews. Iterative approaches to corporate strategy foster
collaborative thinking to further the overall value proposition.
</p>
<p>
Organically grow the holistic world view of disruptive innovation
via workplace diversity and empowerment.
</p>
<a class="cta" slot="footer" href="#">Learn more</a>
</pf-card>
</section>
<section>
<pf-accordion ref={accordion}>
<pf-accordion-header>
<h3>Why do wizards need money if they could just create it?</h3>
</pf-accordion-header>
<pf-accordion-panel>
<p>
There is legislation that decides what you can conjure and what
you can not. Because things that you conjure out of thin air
will not last, it is illegal in the wizarding world.
</p>
</pf-accordion-panel>
<pf-accordion-header>
<h3>Why doesn't Harry have a portrait of his parents?</h3>
</pf-accordion-header>
<pf-accordion-panel>
<p>
<a href="#">The characters in the portraits</a> are not actually
ghosts. They mainly are there just to repeat common phrases or
serve as a general
<a href="foobarbaz.com">
representation of the individual
</a>{" "}
they depict. A portrait of his parents would not be of much help
to Harry.
</p>
</pf-accordion-panel>
<pf-accordion-header>
<h3>
Why is Harry considered a half-blood if both of his parents
could use magic?
</h3>
</pf-accordion-header>
<pf-accordion-panel>
<p>
Because Harry's grandparents were not able to do magic. This is
generally frowned upon by those who consider themselves pure,
such as the Malfoy's or other antagonists.
</p>
</pf-accordion-panel>
<pf-accordion-header>
<h3>Is Hogwarts the only wizarding school?</h3>
</pf-accordion-header>
<pf-accordion-panel>
<p>
No! It has been revealed that there are actually 11 long
established and prestigious schools around the globe. These
include Castelobruxo in the rainforest of Brazil, Durmstrang
Institute (whereas nobody is certain of it’s whereabouts), and
Ilvermorny, right here in the United States.
</p>
</pf-accordion-panel>
<pf-accordion-header>
<h3>Where do the main characters work as adults?</h3>
</pf-accordion-header>
<pf-accordion-panel>
<p>
Harry and Hermione are at the Ministry: he ends up leading the
Auror department. Ron helps George at the joke shop and does
very well. Ginny becomes a professional Quidditch player and
then sportswriter for the Daily Prophet.
</p>
<p>
<a
href="https://www.pottermore.com/collection/characters"
target="blank"
>
Read more about the characters
</a>
</p>
</pf-accordion-panel>
</pf-accordion>
</section>
</div>
);
}

Now, when the page loads, the accordion will have the first panel opened. Below is the accompanying CodeSandbox.

I realize that may have been a lot. So let’s recap what we did.

  1. Initial Setup: Added the web component polyfills
  2. Adding PatternFly Elements (web components): Added the following web components as dependencies in our app: pf-card, and pf-accordion
  3. Adding PatternFly Elements (web components): Imported the web components into our index.js file
  4. Adding PatternFly Elements (web components): Added the markup for our components in index.js
  5. Interacting with our web components API: Created a reference to the accordion so we could open the first panel after the page loads

Wrap up

So there you have it. We’ve added web components to our React app and gained the benefits of using portable, pre-made components that can also be used in other frameworks like Angular and Vue. If your app is written in Angular or Vue, check out our other two posts: “Using PatternFly Elements in your Angular App” and “Using PatternFly Elements in your Vue App.”

© 2018-2024 Red Hat, Inc. Deploys by Netlify