Collect Data with React
This guide will show you how to collect data in a React application without touching the data.
Key concepts in this guide:
Getting Started
To get started, you will need a Basis Theory account.
Next you will need a Public Application in order to initialize JavaScript Elements for your web page.
Click here to create a Public Application or login to your Basis Theory account and create a new application with the following settings:
- Name - Collect Data from Web Guide
- Application Type - Public
- Permissions - token:create
Setup the Project
We will create a new React application using the create-react-app template.
Run the following in your terminal:
npx create-react-app collect-react-guide
cd collect-react-guide
npm start
This will scaffoled a new React app called collect-react-guide and will launch the new application when completed.
Install the React Elements SDK
We will need to install Basis Theory's React Elements SDK, which will render a secure iFrame for capturing the data.
Run the following in a terminal to install the React SDK:
npm install --save @basis-theory/basis-theory-react
Initialize the Web SDK
Now we need to initialize Basis Theory React Elements.
Open the App.js file in the src directory and replace the contents with the following to initialize Basis Theory React:
import {
  BasisTheoryProvider,
  useBasisTheory,
} from '@basis-theory/basis-theory-react';
function App() {
  const { bt } = useBasisTheory('<API_KEY>', { elements: true });
  return (
    <BasisTheoryProvider bt={bt}>
      Hello World!
    </BasisTheoryProvider>
  );
}
export default App;
This code is importing the Basis Theory React SDK, initializing the SDK via useBasisTheory, and adding the BasisTheoryProvider context provider.
Add Your Form Components
Now we need to add a Basis Theory React component to our page. We will add the Text Element component.
We will import the TextElement and add it inside of our BasisTheoryProvider:
import { useRef } from 'react';
import {
  BasisTheoryProvider,
  TextElement,
  useBasisTheory,
} from '@basis-theory/basis-theory-react';
function App() {
  const { bt } = useBasisTheory('<API_KEY>', { elements: true });
  const textRef = useRef(null);
  return (
    <BasisTheoryProvider bt={bt}>
      <TextElement
        id="exampleTextElement"
        ref={textRef}
        placeholder="Input text"
      />
    </BasisTheoryProvider>
  );
}
export default App;
This will create a new instance of a Text Element will inject an iFrame that is rendered by Basis Theory. The Basis Theory SDK will hold a reference to the Text Element which enables interactions with the underlying data without direct access to the value.
We are also leveraging Refs to hold a reference to our TextElement.
Tokenize the Text Value
We want to be able to tokenize the value within the Text Element without exposing it to our web application.
We need to add a submit button and a handler for the submit event which will tokenize the underlying data. Also, we want to display the resulting token by adding state to hold the token and a <pre> element to display the value.
import { useRef, useState } from 'react';
import {
  BasisTheoryProvider,
  TextElement,
  useBasisTheory,
} from '@basis-theory/basis-theory-react';
function App() {
  const { bt } = useBasisTheory('<API_KEY>', { elements: true });
  const textRef = useRef(null);
  const [token, setToken] = useState('');
  const submit = async () => {
    const response = await bt.tokens.create({
      type: 'token',
      data: textRef.current,
    });
    setToken(response);
  };
  return (
    <BasisTheoryProvider bt={bt}>
      <TextElement
        id="exampleTextElement"
        ref={textRef}
        placeholder="Input text"
      />
      <button onClick={submit}>Submit</button>
      {token &&
        <pre>{JSON.stringify(token, undefined, 2)}</pre>
      }
    </BasisTheoryProvider>
  );
}
export default App;
When our form is submitted, Basis Theory's SDK will pass the value for the element reference. This will be securely submitted directly to the Create Token Endpoint. The resulting token is then surfaced to the client device.
Running the Example
We can run our resulting application by running the following in a terminal:
npm start
This will open the React application in our browser to http://localhost:3000/
Conclusion
You can now capture any data without your application accessing the underlying value drastically reducing compliance and regulatory scope.
Try typing a value and clicking the submit button will securely send the data directly to Basis Theory and return you a token. The resulting token is displayed directly on the page.