Overview
Abandoned carts are one of the highest-impact opportunities to recover lost revenue. Most users who abandon a cart still intend to purchase — they just need a timely reminder. This guide shows you how to build an automated abandoned cart Journey in OneSignal that:- Detects cart activity
- Waits for a short period of inactivity
- Sends a personalized reminder
- Stops messaging immediately after purchase or cart removal
- Custom Events (recommended for most implementations)
- Tags (simpler, limited use cases)
What you will build
By the end of this guide, you will have:- Cart activity sent to OneSignal (via Tags or Custom Events)
- A clear, code-defined abandonment signal
- Message templates that personalize cart data
- A Journey that:
- Starts when an abandonment signal is received
- Waits before sending
- Sends an abandoned cart message
- Exits immediately when the cart is emptied or purchased
- Analytics to measure message and revenue performance
Choose your tracking method
You can track cart activity using either Custom Events or Tags.-
Use Custom Events if you:
- Can detect abandonment after a period of inactivity
- Want rich cart data (items, images, prices)
- Are comfortable ensuring events fire once per abandonment
-
Use Tags if you:
- Want state-based safety by default
- Only need simple cart data
- Prefer segment-controlled entry and exit
How abandoned carts are modeled
OneSignal does not automatically determine when a cart is abandoned.You decide when a cart becomes abandoned in your own code or system, and then notify OneSignal.
cart_abandoned means
The cart_abandoned event should represent a state transition - The cart was active → the user stopped engaging → the cart is now considered abandoned.
This event should be sent:
- After a meaningful period of inactivity (e.g. 1 hour)
- Only if the cart still contains items
How Journeys use abandonment signals
Once OneSignal receivescart_abandoned:
- The user becomes eligible to enter the Journey
- A wait period gives them time to return naturally
- A message is sent only if they do not exit
- The user exits immediately when
cart_emptiedis received
Journeys control timing and repetition — they do not determine abandonment.
Setup
Step 1. Plan your cart data and source
Decide what cart information you want to show and where that data comes from. Common cart data includes:- Product name, image, price, and quantity
- Number of items in the cart
- A deep link back to the cart
| Data source | Recommended method |
|---|---|
| App or website | OneSignal Frontend SDK |
| Backend or database | OneSignal REST API |
| Third-party platform | Integration-based Custom Events |
By the end of this step, you know what data you will send and how you will send it.
Step 2. Send cart state signals to OneSignal
You must send signals that represent cart state changes.| Signal | Purpose |
|---|---|
cart_abandoned | Cart activity detected and not resolved |
cart_updated | Cart contents change |
cart_emptied | Cart cleared or purchase completed |
- Frontend SDK
- REST API
- 3rd Party Integration
Use the OneSignal Web or Mobile SDKs to send Custom Events or Tags.
Custom Event exampleTag example
| SDK Method | Description |
|---|---|
trackEvent | Send a Custom Event (Mobile SDK, Web SDK) |
addTags | Add a Tag (Mobile SDK, Web SDK) |
removeTags | Remove a Tag (Mobile SDK, Web SDK) |
This example sets the
cart_updated tag to a Unix timestamp (in seconds) representing when the cart was last updated. You can also use a boolean value (true/false), but a timestamp provides more flexibility with Time Operators.Step 3. Create abandoned cart message templates
Create message templates that reference cart data dynamically. For more details on the concepts used in this section, see:- Custom Event Push Template
- Tag Push Template
Reference event properties using liquid syntax format:Message:Image:Launch URL:
Liquid
Liquid
Liquid
Liquid

Personalize messages with Custom Events
Complete guide to using Custom Events in Journeys. Includes event storage, Journey configuration, abandoned cart example, best practices, and troubleshooting.
Personalize messages with Properties
Complete guide to using Properties and Tags in Journeys. Includes event storage, Journey configuration, abandoned cart example, best practices, and troubleshooting.
Step 4. Create abandoned cart Segment (Tags only)
The Segment will determine who can enter the Journey. See Segments for more details. Select the User Tag filter to track users where thecart_updated tag exists AND select the Last Session filter is less than 7 days ago

We can now track users that update their cart and have visited the app or website in the last 7 days.Users will be automatically removed from the segment when either of the following conditions are met:
- After 7 days have passed since they last visited the app/website
- When the
cart_updatedtag is removed
Step 5. Create the abandoned cart Journey
Create a Journey that reacts to cart activity. See Journeys for more details.
Journey settings
Review the Journey Settings guide for more details on Entry, Exit, and Re-entry rules. Entry Rules:- Custom Event: Entry Rules
- Tag: Entry Rules
- Select Custom Event
- Custom Event Name:
cart_abandoned

- Custom Event: Exit Rules
- Tag: Exit Rules
- Select Meet a certain condition
- Check Exit when custom event condition occurs
- Custom Event Name:
cart_emptied

Users will exit the Journey when either:
- The
cart_emptiedevent (from step 3) is performed. - They complete the Journey.
- Select Yes, after a certain amount of time
- Set the re-entry time to
1day

If you have followed this guide completely so far, then users will:
- Enter the Journey when they abandon/update their cart
- Exit the Journey when they empty their cart or complete the Journey.
- Be eligible to re-enter the Journey:
- Custom Events: Each time the
cart_abandonedevent is performed - Tags: After 1 day has passed since they last exited the Journey and are in the segment.
- Custom Events: Each time the
Journey steps
Users will enter the Journey when they match the Segment. This typically happens within a few minutes after the event/tag is received. Users will flow through the Journey step by step until they reach the end or an exit rule is met. For a basic abandoned cart Journey, we want to do 2 things:- Give the user enough time to empty their cart (make a purchase or empty their cart manually)
- If they do not empty their cart, send them a message reminding them about the items in their cart
- Set the wait time to be as long as you want. We recommend setting it to
1hourso you can message them while they still have the intent to purchase.
- Select the Abandoned Cart Push Notification template you created in Step 4.

Basic Abandoned Cart Journey is now configured.When a user enters the Journey, they will wait for 1 hour. If they do not exit the Journey, they will receive the abandoned cart push notification.
Advanced Journey Setup
Using the knowledge you have gained from this guide, you can now extend the Journey to send more messages over time.Message Sequence
A best practice timing sequence for a very common high-performing cadence is:- Send the first message after 1 hour (completed in this guide).
- Add another Wait step for 1 day and send a second message (~24 hours since they updated their cart).
- Add another Wait step for 2 days and send a third message (~72 hours since they updated their cart).
- This guide shows how to send a push notification message after the first hour. This is used as a helpful reminder to try capturing the sale while the user may still be online.
- Consider using both a push and email for your 2nd message. Use this second message to highlight benefits and social proof with light urgency to encourage them to purchase.
- For the final message of the sequence, use an email or maybe an SMS (depending on the use case) as a “last call”. Consider using a discount code or other incentive to encourage them to purchase.
Fallback Messages
OneSignal’s Journeys provide Wait Until branching logic that you can use to check if a message was confirmed delivered, clicked or opened and if not performed within a certain time period, send a fallback message. This is extremely helpful for users who may have unsubscribed from a specific message channel. More details on how to setup fallback messages can be found in our Fallback Messages guide.Track performance
Journey analytics can be used to track how the Journey as a whole is performing. You can also track each message performance using Template analytics.Track revenue with Outcomes
To track revenue from this Journey, you can use Custom Outcomes. When a purchase is made, you can send the event as a “Custom Outcome” to track the revenue associated with the specific message sent. Custom Outcomes can be sent via the Mobile SDK or Web SDK.Example: Send purchase outcome via frontend SDK
Outcomes can attribute revenue to messages users clicked or were influenced by within a defined attribution window.
You have successfully implemented an abandoned cart Journey. When you are ready to start sending messages, select Set Live.
Need help?Chat with our Support team or email
support@onesignal.comPlease include:- Details of the issue you’re experiencing and steps to reproduce if available
- Your OneSignal App ID
- The External ID or Subscription ID if applicable
- The URL to the message you tested in the OneSignal Dashboard if applicable
- Any relevant logs or error messages


