How to customize previews for Google Wallet passes


Richard Grundy

Updated October 21, 2025 09:55

Overview

In this article, we'll go over the different preview customizations (aka top-level items) that are possible for each of the supported pass template types for Google Wallet passes. We'll cover what information is put into the preview for:

  1. Loyalty passes
  2. Ticket passes
  3. Generic passes
  4. Offer passes
  5. Transit passes

This tutorial serves as a valuable resource for developers looking to optimize their digital pass offerings in Google Wallet. Let's dive in!

Loyalty passes

This is how previews or top-level items look for loyalty passes in Google Wallet: loyalty pass preview

They take information from 3 places:

  1. LoyaltyClass's localizedIssuerName ("Starbucks Rewards" in the screenshot)
  2. LoyaltyClass's localizedProgramName ("20% off on $30" in the screenshot)
  3. LoyaltyClass's programLogo (the mermaid in the screenshot)

If no programLogo is provided, the device will take the first letter of the localizedIssuerName and use that in place of the logo.

Ticket passes

This is how previews or top-level items look for ticket passes in Google Wallet: ticket pass preview

They take information from 3 places:

  1. EventTicketClass's eventName ("MEN'S FW24" in the screenshot)
  2. EventTicketClass's dateTime.start or dateTime.doorsOpen ("Jan 13, 2024" in the screenshot)
  3. EventTicketClass's logo (MSGM in the screenshot)

If no logo is provided, the device will take the first letter of the eventName and use that in place of the logo.

Generic passes

This is how previews or top-level items look for generic passes in Google Wallet: generic pass preview

They take information from 3 places:

  1. GenericObject's cardTitle ("Facegym" in the screenshot)
  2. GenericObject's header ("Richard Grundo" in the screenshot)
  3. GenericObject's logo (F in the screenshot)

If no logo is provided, the device will take the first letter of the cardTitle and use that in place of the logo.

Offer passes

This is how previews or top-level items look for offer (aka coupon) passes in Google Wallet: loyalty pass preview

They take information from 3 places:

  1. OfferClass's localizedProvider ("Starbucks Rewards" in the screenshot)
  2. OfferClass's localizedTitle ("20% off on $30" in the screenshot)
  3. OfferClass's titleImage (The mermaid in the screenshot)

If no titleImage is provided, the device will take the first letter of the localizedProvider and use that in place of the logo.

Transit passes

This is how previews or top-level items look for transit passes in Google Wallet: transit pass preview

They take information from 3 places:

  1. FlightClass's origin.airportIataCode and destination.airportIataCode ("SGN to HND" in the screenshot)
  2. FlightClass's localScheduledDepartureDateTime ("Mar 5" in the screenshot)
  3. FlightClass's flightHeader.carrier.airlineLogo (Ninja in the screenshot)

Issuing Google passes easily with PassNinja

With PassNinja, you create a custom API to meet your needs, use our ready-made SDKs in your favorite language, and just send an create call to issue a new Google pass that customizes your preview.

If you're ready to move at ninja speed and ship product, go sign up. It's free to get started, just click the "Get Started for Free" button in the top right of this website and fill out the form - we'll give you $10 in free credits!

Conclusion

This guide thoroughly explains the customization options available for Google Wallet passes, demonstrating how strategic use of information and visuals can significantly improve the user interface of digital passes. By focusing on the unique aspects of each pass type, developers can design passes that not only meet the functional needs of users but also enhance the overall user experience.

If you have any feedback on this article, let us know!

Was this article helpful?
Yes No