Previously, a set ofDocumentation Index
Fetch the complete documentation index at: https://dev.smile.io/llms.txt
Use this file to discover all available pages before exploring further.
Smile.* methods were bundled with Smile UI, which allowed you to fetch and interact with customer and loyalty program data using JavaScript. These methods are being deprecated and replaced with a new standalone JavaScript SDK library that can be used independently of (or together with) Smile UI. This guide will walk you through what’s new and how to migrate your code.
Smile.* methods bundled with Smile UI will be removed on August 1, 2026. Please migrate to the new JavaScript SDK as soon as possible to avoid any potential issues.What’s new
The new JavaScript SDK, Smile.js, is a standalone library can be used with or without Smile UI. It offers methods for fetching and interacting with customer and loyalty program data, and works with modern JavaScript tooling and frameworks. Once you’ve upgraded, you’ll be able to:- Load the SDK via a script tag or a bundler like Vite or Webpack.
- Use included TypeScript type definitions for autocomplete and type checking.
- Preload multiple resources in a single API call to reduce latency and load times.
- Log customers in and out programmatically without a full page reload.
- Access additional data such as detailed customer VIP status and program settings.
How to migrate
To migrate to the new JavaScript SDK, you need to make the following changes to your code. Each step contains instructions and examples to guide you along the way.1. Include the JavaScript SDK
- Shopify
- BigCommerce
- Custom storefront
2. Update method calls
Any call sites for deprecatedSmile.* methods should be updated to use the corresponding methods from the JavaScript SDK instead.
Old Smile.* method | New JavaScript SDK method |
|---|---|
Smile.createActivity() | Smile.activities.create() |
Smile.customerReady() | Listen for the smile-js-initialized event instead. |
Smile.fetchAllCustomerPointsProducts() | Smile.customerPointsProducts.get() |
Smile.fetchAllPointsProducts() | Smile.pointsProducts.get() |
Smile.fetchAllRewardFulfillments() | Smile.rewardFulfillments.get() |
Smile.fetchCustomer() | Based on the data you need, use any of: • Smile.customer.current() - name & referral URL • Smile.customerPointsWallet.get() - points balance • Smile.customerVipStatus.get() - VIP tier |
Smile.fetchPointsProduct() | Smile.pointsProducts.get() |
Smile.purchasePointsProduct() | Smile.pointsProducts.purchase() (see note) Note: The points_to_spend parameter has changed to pointsToSpend. |
Smile.ready() | Listen for the smile-js-initialized event instead. |
3. Update customer ready calls
TheSmileUI.customerReady() method is now deprecated, and the appropriate replacement depends on what you’re trying to achieve.
- To detect when it’s safe to call other
SmileUI.*methods, use theSmileUI.ready()method. This would typically be for situations where you want to programmatically open the loyalty panel or launcher. - To detect when it’s safe to call other
Smile.*methods, listen for thesmile-js-initializedevent from the JavaScript SDK. This would typically be for situations where you want to programmatically access information about the customer or loyalty program (like displaying their points balance).
- Calling SmileUI.* methods
- Calling Smile.* methods
4. Update object properties
The JavaScript SDK now returns all objects withcamelCase property names (instead of snake_case) for improved compatibility with modern JavaScript frameworks and tooling. As such, you’ll need to update any code that accesses object properties to use the new camelCase names.
5. Audit for preloading
The JavaScript SDK introduces the ability to preload resources, enabling you to retrieve multiple resources on initial page load and reduce the number of roundtrip API calls being made. This helps improve performance and reduce latency, while also providing instant access to preloaded data via new.preloaded() methods on each resource class.
Read our guide on preloading resources, and then audit your code for opportunities to switch from using .get() methods to the new .preloaded() methods instead. Often, it’s as simple as replacing a single .get() call with a single .preloaded() call, like so:
6. Preload points settings
TheSmile.formatPoints() method is now part of the JavaScript SDK and requires that the account’s points settings be preloaded before points values can be formatted.
- Shopify
- BigCommerce
- Custom storefront
Smile.formatPoints() method, you’ll need to call Smile.preload() with pointsSettings before formatting points.7. Audit manual page reloads
- With Smile UI
- Standalone JavaScript SDK
8. Check for deprecation warnings
After the completing the migration steps above, you should no longer see any deprecation warnings in the browser console when viewing your storefront. If you do, it means that you’re still using one or more of the deprecatedSmile.* methods and your code requires further updates.
Where to get help
While we aren’t able to assist with updating, debugging, or reviewing custom code, our support team can help answer questions or clarify details related to the migration process or the JavaScript SDK itself. If you need assistance updating your code, our team can help connect you with an agency partner who specializes in Smile integrations.FAQ
Does this affect me if I only use the standard rewards panel and launcher?
Does this affect me if I only use the standard rewards panel and launcher?
Smile.* methods (like Smile.fetchCustomer() or Smile.createActivity()). If your storefront only uses the out-of-the-box rewards panel and launcher and hasn’t been customized with code that calls these methods, no action is required.This migration only applies if you (or your developer) wrote custom code using the deprecated methods — typically to embed loyalty information directly into your storefront (e.g. a customer’s points balance in the site header) or to build custom loyalty pages and experiences.How do I know if I'm using a deprecated method?
How do I know if I'm using a deprecated method?
Smile.* methods in the browser console. If you see any, you’ll need to update your code to use the corresponding methods from the JavaScript SDK instead.If you’ve visited every page on your website and don’t see any deprecation warnings, try searching through your codebase for any remaining references to the deprecated methods.If you’ve done both and haven’t found any references to the deprecated methods in your codebase or seen any deprecation warnings in the browser console, no migration is required.What is the full list of methods that are being deprecated?
What is the full list of methods that are being deprecated?
Smile.createActivity()Smile.customerReady()Smile.fetchAllCustomerPointsProducts()Smile.fetchAllPointsProducts()Smile.fetchAllRewardFulfillments()Smile.fetchCustomer()Smile.fetchPointsProduct()Smile.formatPoints()Smile.purchasePointsProduct()Smile.ready()
What should I do if I'm using a deprecated method?
What should I do if I'm using a deprecated method?
Can Smile do the migration for me?
Can Smile do the migration for me?
What happens if I don't migrate by August 1, 2026?
What happens if I don't migrate by August 1, 2026?
Smile.* methods will be removed entirely. Any custom code still calling them will throw errors and stop working — for example, custom points balance displays, referral URL displays, or any custom loyalty pages built using the deprecated methods would break.Standard Smile UI functionality (the rewards panel and launcher) is not affected and will continue to work as expected.Will my customers' points balances or other loyalty data be affected by the migration?
Will my customers' points balances or other loyalty data be affected by the migration?
Will my customers experience any downtime during the migration?
Will my customers experience any downtime during the migration?
Smile.* methods will continue to work (with deprecation warnings in the browser console) up until that date. This means you can migrate incrementally and test thoroughly before the deadline.After August 1, 2026, any custom code still using the deprecated methods will stop working, which could affect custom-built parts of your storefront.My developer or agency built our custom integration — what should I send them?
My developer or agency built our custom integration — what should I send them?
Can I run both the old Smile.* methods and the new JavaScript SDK side-by-side during migration?
Can I run both the old Smile.* methods and the new JavaScript SDK side-by-side during migration?
Smile.* methods will continue to work (with deprecation warnings in the browser console) alongside their new JavaScript SDK equivalents. This means you can migrate one method call at a time, test as you go, and ship changes incrementally rather than all at once.How can I test the migration before deploying to production?
How can I test the migration before deploying to production?
- Shopify: Use a development store or a duplicate of your live theme to test changes before publishing.
- BigCommerce: Use a staging or preview store.
- Custom storefront: Use whatever staging or preview environment you typically deploy to before production.
Why are the Smile.* methods being deprecated?
Why are the Smile.* methods being deprecated?
Smile.* methods were bundled with Smile UI and were difficult to use in modern JavaScript projects. The new JavaScript SDK is a standalone library that brings several improvements:- Works with modern frameworks and bundlers (e.g. Vite, Webpack)
- Includes TypeScript type definitions for autocomplete and type checking
- Supports preloading multiple resources in a single API call to reduce latency
- Allows logging customers in and out programmatically without a full page reload
- Provides access to additional data such as detailed VIP status and program settings