Note
This branch is forked from the pre-released sdk-v3 branch and published to our private package registry @wisdomhealth-inc/shopify-js-buy-sdk
Caution
Note: The JS Buy SDK is deprecated as of January, 2025. It will no longer be updated or maintained by Shopify past that point. A final major version will be released in January 2025 to remove the SDK's dependency on the deprecated Checkout APIs, replacing them with Cart APIs. Updating to this new version will allow the SDK to continue to function for most use cases.
If you are using the JS Buy SDK, you have two options:
-
Recommended Option: switch to the Storefront API Client
- The Storefront API Client manages the API's authentication information and provides various methods that enable devs to interact with the API. This is the preferred and more future-proof solution. See this migration guide to help you transition.
-
Stopgap Option: Upgrade to JS Buy SDK V3 (coming soon)
- This allows you to maintain your current setup with minimal changes for use cases that are supported by the Cart API. A migration guide with details on supported use cases will be available soon. If you choose this option, we still recommend that you switch to the Storefront API Client in the future.
Critical Deadline: July 1st, 2025. You must implement one of these changes by this date, or customers will not be able to complete purchases. Please choose the option that best suits your needs and timelines.
Shopify JavaScript Buy SDK
To upgrade simply run either of the following commands
If using NPM
npm install shopify-buy@3
If using Yarn
yarn install shopify-buy@3
To validate that the upgrade was successful or that your are using v3.0, open your package.json
and make sure the shopify-buy
dependency is set to 3.0.0
or higher.
In addition you can check that the client is using the Cart API by monitoring the network tab on your preferred developer tools when adding a line item to the cart. If you see that the operation performed was cartLinesAdd
rather than checkoutCreate
, then you are using v3.0.
How will I know my e-commerce experience will still work after I take action?
If you migrate to Storefront API Client, there is virtually no use case that can’t be addressed with the right technical implementation. Upfront planning and following the migration guide will be critical to a smooth successful migration. If you decide to switch to the JS Buy SDK v3.0, the majority of use cases should still work successfully, but there’s no guarantee it will work with future Shopify features. Additionally, there are several fields that are no longer compatible:
Note
If you don't use any of thes fields, you only have to bump the package version and everything will work
field | compatibility | notes | solution? |
---|---|---|---|
completedAt | Not supported. Defaults to null |
The Cart API does not maintain the state of a completed Cart that became an order. | |
order | Not supported. Defaults to null |
To retrieve customer orders, please use either the Customer Account API or the legacy Customer API. | |
orderStatusUrl | Not supported. Defaults to null |
same as above | |
ready | Not supported. Defaults to false |
The Cart API returns only carts that are considered ready. Simply bypass or remove any existing code depending on this field. | |
requiresShipping | Not supported. Defaults to true |
The Cart API does not contain shipping information, this is currently handled in the Checkout flow. Remove any existing code depending on these fields. | |
shippingLine | Not supported. Defaults to null |
same as above | |
taxExempt | Not supported. Defaults to false |
The Cart API does not have Tax aware as this is currently handled in the Checkout flow. Remove any existing code depending on this field. | |
taxesIncluded | Not supported. Defaults to false |
same as above |
The updated checkout interface supports all existing methods with some limitations:
method | compatibility | notes |
---|---|---|
fetch | ✅ | |
create | ✅ |
- Does not create localized checkouts when passing presentmentCurrencyCode - Does not localize an empty checkout created with buyerIdentity.countryCode . (Must create with lineItems) |
updateAttributes | ✅ |
- It does not update a checkout to support allowPartialAddresses |
updateEmail | ✅ | |
addLineItems | ✅ | |
replaceLineItems | ✅ | |
updateLineItems | ✅ | |
removeLineItems | ✅ | |
addDiscount | ✅ | - It does not apply an order-level fixed amount discount to an empty checkout - It does not apply an order-level percentage discount to an empty checkout |
removeDiscount | ✅ | |
addGiftCards | ✅ | |
removeGiftCard | ✅ | |
updateShippingAddress | ✅ |
Why is the JS Buy SDK being deprecated?
We know the important role the JS Buy SDK library played in allowing merchants to create e-commerce experiences. When it was first released in 2016, our main priority was to provide quick and easy ways to interact with our GraphQL APIs. However, over the years, a lot has changed and the SDK is no longer the optimal client to fully leverage all of Shopify capabilities.
What do I need to do now?
You have multiple options: a) switch to the Storefront API Client, our recommendation and more future-proof solution; see our migration guide to help you transition, docs, NPM package or b) upgrade to JS Buy SDK V3, our last and final release of the JS Buy SDK library. See this upgrade guide to install v3.0. c) switch to one of our other solutions.
Shopify has evolved since the JS Buy SDK was first released, so we encourage you to explore and determine if one of our themes for an Online Store is a better fit for your needs. This action must be completed before July 1, 2025 11:00 AM ET.
Something’s gone wrong and I’m not sure what it is. Is the JS Buy SDK the reason?
The only functionality that should be affected is the cart and checkout. For example, customers can’t complete purchases or the website crashes when a customer attempts to add to cart or view their cart. Other possible issues could be related to any existing workflows that rely on the .order
, .completedAt
or any other no longer supported Checkout specific fields. We have set these fields to their default values to mitigate any breaking changes, but we can’t guarantee all existing functionality.
What if I run into issues upgrading?
You may be using one of the fields that is no longer supported in JS Buy SDK v3.0. If you are not a developer, we recommend contacting the people who last worked on your store, whether that was to initially build it or help maintain it over time. If you are looking to work with an agency, check out our partner directory for more information.
How do I find out if my store is using JS Buy SDK?
If your store is affected, you would have received an email from us. Another way to verify is to search for shopify-buy
in your codebase or the snippets you embedded into your site. If this is not possible, then we recommend contacting a third-party partner.
I think I’m on an earlier version of JS Buy SDK. How do I upgrade to v3.0?
We’d recommend reviewing our changelog to first upgrade your store to v2.22.0 of the JS Buy SDK, and then upgrade to v3.0 after that. In addition, we are constantly evolving our solutions and we encourage you to explore them and see if one might better fit your needs.
What happens if I do not take any action?
If you do not take any action before July 1, 2025 11:00 AM ET
, your store will lose the ability for customers to complete purchases and your site may become unavailable for users with existing carts.
I read that the Checkout API is being deprecated in April 2025, but the JS Buy SDK that uses Checkout APIs is being deprecated on July 1, 2025. Which date is it? and what if I can’t complete the upgrade by April?
All merchants using JS Buy SDK will be granted an automatic one-time extension to complete the switch to v3.0 before July 1, 2025 at 11:00 AM ET. The JS Buy SDK v3.0 update removes the dependency on Checkout APIs and replaces them with Cart APIs. This means that when you call methods on the Checkout resource, they’ll use Cart APIs instead. We did our best to keep the inputs and outputs the same, but some features from the Checkout APIs do not have a Cart API equivalent, so please test thoroughly after upgrading.
How long will JS Buy SDK v3.0 be supported?
JS Buy SDK v3.0 will be supported until January 1, 2026. Upgrading to JS Buy SDK v3.0 should be considered a short-term solution before implementing a long-term solution such as Storefront Client, Hydrogen, or Storefront Web Components or Online Store Editor.
Why would I upgrade to JS Buy SDK v3.0 if it’s the last and final release?
This option is the easiest and fastest way to remain functional and give you more time to consider, plan and implement a better long-term solution such as using the Storefront Client.
How long will it take to migrate to Storefront API Client?
This will heavily depend on your e-commerce experience and what level of technical resources you have available. If you do not have access to technical resources or are unsure where to begin, you can review the migration guide, or contact a third-party agency who could provide consultation.
How will I know I have successfully switched to JS Buy SDK v3.0?
Once you have updated your project to use v3.0, you can check your package.json to ensure that the shopify-buy
dependency is now at 3.0.0. In addition you can check that the client is using the Cart API by monitoring the network tab of your preferred developer tools when adding a line item to the cart. If you see that the operation performed was cartLinesAdd
rather than checkoutCreate
, then you have switched to v3.0 successfully. More information
I’m debating if I should migrate to the Storefront API Client. What are the benefits?
Migrating to the Storefront API Client is a great way to future-proof your e-commerce experience by gaining full control on how your store interacts with Shopify APIs. You will get access to [globally-deployed Carts](https://shopify.dev/docs/storefronts/headless/building-with-the-storefront-api/cart/manage), offering improved performance, scalability, and a richer feature set including subscriptions, product bundles, contextual pricing, Shopify Functions, and UI extensions, and more. In addition, we have other solutions available that might better fit your needs like Hydrogen, Storefront Web Components or Online Store Editor.Where can I find the Checkout interface documentation?
The Checkout API is deprecated. To find the legacy documentation, you can visit this page
Note: For help with migrating from v0 of JS Buy SDK to v1 check out the Migration Guide.
The JS Buy SDK is a lightweight library that allows you to build ecommerce into any website. It's based on Shopify's Storefront API and provides the ability to retrieve products and collections from your shop, add products to a cart, and checkout.
Full API docs are available here.
View our Changelog for details about our releases.
Each version of the JS Buy SDK uses a specific Storefront API version and the support of an SDK version is directly linked to the support of the corresponding Storefront API version. Storefront API versioning information can be found here.
- Shopify JavaScript Buy SDK
With Yarn:
yarn add shopify-buy
With NPM:
npm install shopify-buy
CDN:
There is a minified UMD build of the latest release available via CDN (see the Changelog for details about the latest release):
<script src="https://sdks.shopifycdn.com/js-buy-sdk/v2/latest/index.umd.min.js"></script>
If you don't want to use the latest version, you can use a specific older release version:
<script src="https://sdks.shopifycdn.com/js-buy-sdk/1.11.0/index.umd.min.js"></script>
You can also fetch the unoptimized release for a version (2.0.1 and above). This will be larger than the optimized version, as it will contain all fields that are available in the Storefront API:
<script src="https://sdks.shopifycdn.com/js-buy-sdk/2.0.1/index.unoptimized.umd.min.js"></script>
The JS Buy SDK has four build versions: ES, CommonJS, AMD, and UMD.
ES, CommonJS:
import Client from 'shopify-buy';
AMD:
import Client from 'shopify-buy/index.amd';
UMD:
import Client from 'shopify-buy/index.umd';
UMD Unoptimized: This will be larger than the optimized version, as it will contain all fields that are available in the Storefront API. This should only be used when you need to add custom queries to supplement the JS Buy SDK queries.
import Client from 'shopify-buy/index.unoptimized.umd';
If your store supports multiple languages, Storefront API can return translated resource types and fields. Learn more about translating content.
import Client from 'shopify-buy';
// Initializing a client to return content in the store's primary language
const client = Client.buildClient({
domain: 'your-shop-name.myshopify.com',
storefrontAccessToken: 'your-storefront-access-token'
});
// Initializing a client to return translated content
const clientWithTranslatedContent = Client.buildClient({
domain: 'your-shop-name.myshopify.com',
storefrontAccessToken: 'your-storefront-access-token',
language: 'ja-JP'
});
// Fetch all products in your shop
client.product.fetchAll().then((products) => {
// Do something with the products
console.log(products);
});
// Fetch a single product by ID
const productId = 'gid://shopify/Product/7857989384';
client.product.fetch(productId).then((product) => {
// Do something with the product
console.log(product);
});
// Fetch a single product by Handle
const handle = 'product-handle';
client.product.fetchByHandle(handle).then((product) => {
// Do something with the product
console.log(product);
});
// Fetch all collections, including their products
client.collection.fetchAllWithProducts().then((collections) => {
// Do something with the collections
console.log(collections);
console.log(collections[0].products);
});
// Fetch a single collection by ID, including its products
const collectionId = 'gid://shopify/Collection/369312584';
// Set a parameter for first x products, defaults to 20 if you don't provide a param
client.collection.fetchWithProducts(collectionId, {productsFirst: 10}).then((collection) => {
// Do something with the collection
console.log(collection);
console.log(collection.products);
});
Not all fields that are available on the Storefront API are exposed through the SDK. If you use the unoptimized version of the SDK, you can easily build your own queries. In order to do this, use the UMD Unoptimized build.
// fetch the large, unoptimized version of the SDK
import Client from 'shopify-buy/index.unoptimized.umd';
const client = Client.buildClient({
domain: 'your-shop-name.myshopify.com',
storefrontAccessToken: 'your-storefront-access-token'
});
// Build a custom products query using the unoptimized version of the SDK
const productsQuery = client.graphQLClient.query((root) => {
root.addConnection('products', {args: {first: 10}}, (product) => {
product.add('title');
product.add('tags');// Add fields to be returned
});
});
// Call the send method with the custom products query
client.graphQLClient.send(productsQuery).then(({model, data}) => {
// Do something with the products
console.log(model);
});
For more complete examples of using JS Buy SDK, check out our storefront-api-examples project. There are JS Buy SDK specific example apps in Node, Ember, and React. You can use these examples as a guideline for creating your own custom storefront.
For help on setting up the repo locally, building, testing, and contributing please see CONTRIBUTING.md.
All developers who wish to contribute through code or issues, take a look at the CODE_OF_CONDUCT.md.
MIT, see LICENSE.md for details.