Shopify Checkout UI Extension Example

As you might have already read on the Shopify website, checkout.liquid is deprecated and stores need to upgrade to Checkout Extensibility by August 13, 2024. So here is an example of how to build a Checkout UI extension.

For this example, our requirement is going to be to provide a free item (e.g. t-shirt) on checkout when the total purchase is greater than a thousand. Clear enough?

Checkout UI Extension Setup

If you have read my past blogs then you probably already have a development store and partner account. In any case, these are the prerequisites:

  • A Shopify Partner account
  • A development store that use the Checkout and Customer Accounts Extensibiliy
  • Shopify CLI
Shopify Checkout UI Extension Example – Create Store

This example was created on a Windows 11 machine with Node v20.11.0, npm v10.2.4 and Shopify CLI v3.60.1. For the final check, on the bottom left of your Shopify Admin page, it should say Checkout and Customer Accounts Extensibility as shown below.

Shopify Checkout UI Extension Example – Checkout Extensibility

Checkout UI Extension Scaffolding

Super simple, run shopify app init to create you project. You can choose what name you like for your project. In this example, our project name is checkout-practice-app

C:\shopify>shopify app init

Welcome. Let’s get started by naming your app project. You can change it later.

?  Your project name?
  checkout-practice-app

?  Get started building your app:
  Start by adding your first extension

╭─ info ─────────────────────────────────────────────────────────────────────────╮
                                                                                
  Initializing project with `npm`                                               
  Use the `--package-manager` flag to select a different package manager.       
                                                                                
╰────────────────────────────────────────────────────────────────────────────────╯


╭─ success ──────────────────────────────────────────────────────────────────────╮
                                                                                
  checkout-practice-app is ready for you to build!                              
                                                                                
  Next steps                                                                    
     Run `cd checkout-practice-app`                                            
     For extensions, run `shopify app generate extension`                      
     To see your app, run `shopify app dev`                                    
                                                                                
  Reference                                                                     
     Shopify docs [1]                                                          │
     For an overview of commands, run `shopify app --help`                     
                                                                                
╰────────────────────────────────────────────────────────────────────────────────╯
[1] https://shopify.dev

Checkout UI Extension App

Next step is to create the checkout UI extension. This is the code that will modify the checkout page. Change to you project directory and run npm run generate extension. You can choose what technology stack you’ld like to work in. I have chosen JavaScript React for this example.

C:\shopify\checkout-practice-app>npm run generate extension

> checkout-practice-app@1.0.0 generate
> shopify app generate extension


Before proceeding, your project needs to be associated with an app.

?  Create this project as a new app on Shopify?
  Yes, create it as a new app

?  App name:
  checkout-practice-app

╭─ info ─────────────────────────────────────────────────────────────────────────╮
                                                                                
  Using shopify.app.toml:                                                       
                                                                                
     Org:             Joel Patrick Llosa                                       
     App:             checkout-practice-app                                    
                                                                                
   You can pass `--reset` to your command to reset your app configuration.      
                                                                                
╰────────────────────────────────────────────────────────────────────────────────╯

?  Type of extension?
  Checkout UI

?  Name your extension:
  free-shirt-1000

?  What would you like to work in?
  JavaScript React


╭─ success ──────────────────────────────────────────────────────────────────────╮
                                                                                
  Your extension was created in extensions/free-shirt-1000.                     
                                                                                
  Next steps                                                                    
     To preview this extension along with the rest of the project, run `npm
      run shopify app dev`                                                      
                                                                                
  Reference                                                                     
     For more details, see the docs [1]                                        │
                                                                                
╰────────────────────────────────────────────────────────────────────────────────╯
[1] https://shopify.dev/api/checkout-extensions/checkout/configuration

Take a look at your Shopify Partners portal page and your app should be there.

Shopify Checkout UI Extension Example – App Created

Checkout UI Extension Logic

Checkout.jsx

import {
  BlockLayout,
  InlineLayout,
  Text,
  useTranslate,
  reactExtension,
  useSettings,
  useSubtotalAmount,
} from '@shopify/ui-extensions-react/checkout';

export default reactExtension(
  'purchase.checkout.cart-line-list.render-after',
  () => <Extension />,
);

function Extension() {
  const translate = useTranslate();
  const { freebie_title: freeItem } = useSettings();
  const { amount } = useSubtotalAmount();

  if (freeItem && amount > 1000) {
    return (
      <InlineLayout columns={['fill', '20%']}>
          <Text>{ freeItem }</Text>
          <BlockLayout inlineAlignment="end">
              <Text>Free</Text>
          </BlockLayout>
      </InlineLayout>
    );
  }  
}

What does this piece of code do? This UI extension targets purchase.checkout.cart-line-list.render-after. Which means this UI will be inserted at that target location. It will be rendered after all line items.

Moving along, we use 3 APIs provided by Shopify. The useTranslate hook returns the I18nTranslate interface used to translate strings. We can do something like &lt;Text&gt;{translate('welcome')}&lt;/Text&gt; which pulls the welcome message in en.default.json and renders it in a Text component. But we won’t be using it in this example.

The useSettings hook returns the settings values defined by the merchant for the extension. These settings values are found on shopify.extension.toml. The value of the key freebie_title is then assigned to freeItem. We can set the value in the customize mode of the checkout page which is driven by the below extension settings.

shopify.extension.toml

...snipped...

[extensions.settings]
  [[extensions.settings.fields]]
    key = "freebie_title"
    type = "single_line_text_field"
    name = "Freebie title"
    description = "Free item name"

The useSubtotalAmount API returns a Money value representing the subtotal value of the items in the cart at the current step of checkout. Obviously we’ll need the amount to check if it more than a thousand so we can render the free item. So if there is a free item set and the sub total is more than a thousand we render the free item using Shopify provided React components. This ends the coding part.

Running and Customizing the App

Time to run the app. Execute npm run dev and follow the instructions (e.g. “P” to preview in your browser).

C:\shopify\checkout-practice-app>npm run dev

> checkout-practice-app@1.0.0 dev
> shopify app dev

?  Which store would you like to use to view your project?
  checkout-practice

╭─ info ─────────────────────────────────────────────────────────────────────────╮
                                                                                
  Using shopify.app.toml:                                                       
                                                                                
     Org:             Joel Patrick Llosa                                       
     App:             checkout-practice-app                                    
     Dev store:       checkout-practice.myshopify.com                          
     Update URLs:     Not yet configured                                       
                                                                                
   You can pass `--reset` to your command to reset your app configuration.      
                                                                                
╰────────────────────────────────────────────────────────────────────────────────╯

 Created extension free-shirt-1000.
07:43:25  graphiql    GraphiQL server started on port 3457
07:43:25  extensions  Bundling UI extension free-shirt-1000...
07:43:25  extensions  Parsed locales for extension free-shirt-1000 at
C:/shopify/checkout-practice-app/extensions/free-shirt-1000
07:43:25  extensions  free-shirt-1000 successfully built
07:43:25  extensions  Parsed locales for extension free-shirt-1000 at
C:/shopify/checkout-practice-app/extensions/free-shirt-1000
07:43:27  extensions  Draft updated successfully for extension: free-shirt-1000

────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
 Press d  toggle development store preview:  on
 Press g  open GraphiQL (Admin API) in your browser
 Press p  preview in your browser
 Press q  quit

Preview URL: https://damaged-breakfast-campus-syria.trycloudflare.com/extensions/dev-console
GraphiQL URL: http://localhost:3457/graphiql

Before we can see our app in action, we need to do some bits and bobs. Go to Settings > Checkout > Customize to add the app block.

Shopify Checkout UI Extension Example – Customize Checkout

Add app block. Can you see the free-shirt-1000 extension?

Shopify Checkout UI Extension Example – free-shirt-1000

App block added. Can you see it below the line items?

Shopify Checkout UI Extension Example – App Block Added

App block settings. Does it remind you of the extension settings in shopify.extension.toml? We’re giving away an Acme Brand T-shirt for purchases over a thousand.

Shopify Checkout UI Extension Example – App Block Settings

Now, go purchase something over a thousand and go to checkout. You should have something like below.

Shopify Checkout UI Extension Example – Over a Thousand Purchase

Try buying something that’s below a thousand and go to checkout. You are not getting a free item.

Shopify Checkout UI Extension – Under a Thousand Purchase

Shopify Checkout UI Extension Summary

There you have it. Your first Shopify Checkout UI Extension. To recap, create the scaffolding using Shopify CLI. After that is in place generate an extension. Choose a target location in the checkout page and add your custom logic. Last bit is doing some bit of config to render your UI extension. Good luck creating your own Shopify Checkout UI Extension in the future. Grab the repo here, github.com/jpllosa/checkout-practice-app.

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *