Collect Cards
In this guide, we will set up PublicSquare Elements SDKs to capture cards in a frontend application and securely authorize and store the cardholder data while avoiding PCI requirements.
Getting Started
To get started, you will need a PublicSquare Account.
Get your Publishable Key
Next you will need your Publishable Key. Go to your Developers section and click Reveal for your Publishable Key and copy the value.
Configuring PublicSquare Elements
PublicSquare Elements are available for the following technologies. Click below for detailed instructions on how to install and configure them.
Adding Card Elements
Once installed and configured, add the Card Elements to your application.
- JavaScript
- React
<input
  type="text"
  id="cardholderName"
  placeholder="Cardholder name"
  style={{ display: 'flex', width: '100%' }}
/>
<div id="cardNumber"></div>
<div style="display: flex;">
  <div id="cardExpirationDate" style="width: 100%;"></div>
  <div id="cardVerificationCode" style="width: 100%;"></div>
</div>
import { PublicSquare } from '@publicsquare/elements-js';
let publicsquare;
let cardNumberElement;
let cardExpirationDateElement;
let cardVerificationCodeElement;
async function init() {
  publicsquare = await new PublicSquare().init('<PUBLISHABLE_API_KEY>');
  // Creates Elements instances
  cardNumberElement = publicsquare.createCardNumberElement();
  cardNumberElement.mount('#cardNumber');
  cardExpirationDateElement = publicsquare.createCardExpirationDateElement();
  cardExpirationDateElement.mount('#cardExpirationDate');
  cardVerificationCodeElement = publicsquare.createCardVerificationCodeElement();
  cardExpirationDateElement.mount('#cardVerificationCode');
}
init();
import React, { useRef, useState } from 'react';
import {
  PublicSquareProvider,
  CardNumberElement,
  CardExpirationDateElement,
  CardVerificationCodeElement,
  usePublicSquare,
} from '@publicsquare/elements-react';
export default function App() {
  const { publicsquare } = usePublicSquare();
  // Refs to get access to the Elements instance
  const cardholderNameRef = useRef(null);
  const cardNumberRef = useRef(null);
  const cardExpirationRef = useRef(null);
  const cardVerificationRef = useRef(null);
  return (
    <PublicSquareProvider apiKey={apiKey}>
      <input
        type="text"
        id="cardholderName"
        placeholder="Cardholder name"
        ref={cardholderNameRef}
        style={{ display: 'flex', width: '100%' }}
      />
      <CardNumberElement
        id="cardNumber"
        ref={cardNumberRef}
      />
      <div style={{ display: 'flex' }}>
        <div style={{ width: '100%' }}>
          <CardExpirationDateElement
            id="cardExpirationDate"
            ref={cardExpirationRef}
          />
        </div>
        <div style={{ width: '100%' }}>
          <CardVerificationCodeElement
            id="cardVerificationCode"
            ref={cardVerificationRef}
            cardBrand={cardBrand}
          />
        </div>
      </div>
    </PublicSquareProvider>
  );
}
Storing Cards
Now that you are capturing cardholder data in your web application, it is time to store the card in your account.
To do this, we will call the create card method from the SDK, passing the Card Elements as data points in the payload.
Add a submit function along with a button to trigger it:
- JavaScript
- React
- cURL
<!-- Form from above -->
<button id="submit">Submit</button>
async function init () {
  ...
  document.getElementById("submit").addEventListener("click", submit);
}
async function submit (e: FormEvent<HTMLFormElement>,) {
  try {
    const formData = new FormData(e.currentTarget)
    const card = await publicsquare.cards.create({
      cardholder_name: formData.cardholderName,
      card: {
        number: cardNumberElement,
        expirationMonth: cardExpirationDateElement.month(),
        expirationYear: cardExpirationDateElement.year(),
        cvc: cardVerificationCodeElement,
      }
    });
    // store card.id in your database
  } catch (error) {
    console.error(error);
  }
}
init();
export default function App() {
  const submit = async () => {
    try {
      const card = await publicsquare.cards.create({
        // This can be any string text from the dom
        cardholder_name: cardholderNameRef.current.el.value,
        card: {
          // cardNumberRef.current is the CardNumberElement instance that will be decrypted within the secure
          // iFrame on the DOM so that the client never sees the card information.
          number: cardNumberRef.current,
          expirationMonth: cardExpirationRef.current.month(),
          expirationYear: cardExpirationRef.current.year(),
          cvc: cardVerificationRef.current,
        }
      });
      // store card.id in your database
    } catch (error) {
      console.error(error);
    }
  }
  return (
    <PublicSquareProvider bt={bt}>
      ...
      <button onClick={submit}>Submit</button>
    </PublicSquareProvider>
  );
}
curl -L 'https://collect.publicsquare.com' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'X-API-KEY: <PUBLISHABLE_API_KEY>' \
-d '{
  "cardholder_name": "John Smith",
  "card": {
    "number": "4242424242424242",
    "expirationMonth": 12,
    "expirationYear": 2025,
    "cvc": "123"
  }
}'
The created card object contains the non-sensitive information about the card:
{
  "id": "card_AjkCFKAYiTsjghXWMzoXFPMxj",
  "account_id": "acc_B518niGwGYKzig6vtrRVZGGGV",
  "environment": "test",
  "cardholder_name": "John Smith",
  "last4": "4242",
  "exp_month": "12",
  "exp_year": "2025",
  "brand": "visa",
  "fingerprint": "CC2XvyoohnqecEq4r3FtXv6MdCx4TbaW1UUTdCCN5MNL",
  "created_at": "2024-06-30T01:02:29.212Z",
  "modified_at": "2024-06-30T01:02:29.212Z"
}
You can safely store the card's id value in your database to link it with the appropriate payment or customer association.
You can optionally pass in a customer_id to associate with an existing Created Customer and billing_details to remove the requirement to pass them when Creating a Payment.
Conclusion
Following this guide, you have successfully collected a customer's credit card. To use this card, proceed with the Process Card Payments guide.