Integrate the Buy with Prime Cartridge into your Storefront
Buy with Prime API is now available for early access
Sign up for early access to the Buy with Prime API using the 'Sign Up' button below. The API may change as Amazon receives feedback and iterates on it.
This topic describes how to integrate the Buy with Prime cartridge into a site based on the Storefront Reference Architecture (SFRA) structure, and provides a list of affected controllers, models, scripts, and templates.
To combine the Buy with Prime functionality with your storefront, you can start with the int_buywithprime_sfra
cartridge for Buy with Prime, which overrides SFRA functionality, and reapply your existing customizations. Alternatively, you can omit the int_buywithprime_sfra
cartridge and selectively copy relevant code for Buy with Prime from int_buywithprime_sfra
into your own custom cartridge.
For details about installing the Buy with Prime cartridge, see Install the Buy With Prime Cartridge.
Custom code overrides
This topic shows code overridden by the int_buywithprime_sfra
cartridge for Buy with Prime, which can overwrite customizations that you made to the same controllers, models, scripts, and templates in other cartridges.
If you've heavily customized your storefront, consider selectively copying relevant code from this topic into your storefront cartridge instead of using int_buywithprime_sfra
as a starting point.
Controllers
The int_buywithprime_sfra
cartridge overrides the following controller routes with server.replace
, which overrides any existing logic for the same routes, including server.append
and server.prepend
, in cartridges to the right of int_buywithprime_sfra
in the cartridge path.
Cart-UpdateQuantity
CheckoutServices-PlaceOrder
For the controller route, add the custom logic that you want to preserve to a cartridge that has priority by being to the left of int_buywithprime_sfra
in the cartridge path.
Models
The int_buywithprime_sfra
cartridge doesn't override any models. Each model properly inherits functionality from its respective base superModule
model.
Scripts
The int_buywithprime_sfra
cartridge overrides the following script helper functions. In a cartridge that has priority by being to the left in the cartridge path, update the helper functions to combine the Buy with Prime logic with any of your own custom logic that you want to preserve. You can combine the logic either in the int_buywithprime_sfra
cartridge if you use the cartridge, or in your own custom cartridge if you don't use int_buywithprime_sfra
.
Path | Helper function | Required logic |
---|---|---|
cart/cartHelpers.js | addProductToCart | Account for Buy with Prime inventory as well as standard inventory. |
checkout/checkoutHelpers.js | placeOrder | Clear the Buy with Prime session data and add the hook and error handling after order placement. |
checkout/shippingHelpers.js | getApplicableShippingMethods | Account for custom logic in the Buy with Prime shipping method. |
helpers/basketValidationHelpers.js | validateProducts | Account for Buy with Prime inventory as well as standard inventory. |
renderTemplateHelper.js | getRenderedHtml | Extend the base superModule to add Buy with Prime attributes to the templateContext . |
cart/cartHelpers.js
In addProductToCart
, account for Buy with Prime inventory as well as standard inventory.
Code
data:image/s3,"s3://crabby-images/7bccd/7bccd120ffa32f796a4031942c2c28bbfecd04de" alt="Code for addProductToCart"
Code (continued)
data:image/s3,"s3://crabby-images/8f1ce/8f1ce87d66c1623fc609ebf13e721475c9d1a187" alt="Code for addProductToCart continued"
checkout/checkoutHelpers.js
In placeOrder
, clear the Buy with Prime session data and add the hook and error handling after order placement.
Code
data:image/s3,"s3://crabby-images/24f87/24f87700f1686ad0b2d4bee90cfafff08a81dad6" alt="Code for placeOrder"
checkout/shippingHelpers.js
In getApplicableShippingMethods
, account for custom logic in the Buy with Prime shipping method.
Code
data:image/s3,"s3://crabby-images/66c65/66c65ec62dc66d3b97ee3f5f6da50c40f35c2a39" alt="Code for getApplicableShippingMethods"
Code (continued)
data:image/s3,"s3://crabby-images/7c549/7c549b5577a13f0d27dbfe31e0c9b4eb177c2cfb" alt="Code for getApplicableShippingMethods continued"
helpers/basketValidationHelpers.js
In validateProducts
, account for Buy with Prime inventory as well as standard inventory.
Code
data:image/s3,"s3://crabby-images/07a65/07a65da84ffebf4afd166a1e7f9444b0240a48c5" alt="Code for validateProducts"
renderTemplateHelper.js
In getRenderedHtml
, extend the base superModule
to add Buy with Prime attributes to the templateContext
.
Code
data:image/s3,"s3://crabby-images/c580a/c580a715548a52f0324b842a251e05ca92355c36" alt="Code for getRenderedHtml"
Templates
The int_buywithprime_sfra
cartridge overrides the following templates. If you heavily customized a template from the version in app_storefront_base
, consider copying the relevant custom code for Buy with Prime into your storefront template override.
Template | Required logic |
---|---|
cart/productCard/cartProductCardEdit.isml | Wrap a conditional statement to only show an Edit link next to a line item if the line item is for a variation product. |
cart/productCard/cartProductCardProductPrice.isml | Add two div elements for Buy with Prime to each product line item. |
cart/cartApproachingDiscount.isml | Add messaging for the shipping discount. |
cart/cartShippingMethodSelection.isml | Wrap a conditional statement to only show the shipping method selection for items not eligible for Buy with Prime. |
cart/checkoutButtons.isml | Override both the app_storefront_base and Amazon Pay versions, add the Buy with Prime button, and edit the markup for the standard checkout button. |
checkout/billing/paymentOptions/creditCardSummary.isml | Wrap a conditional statement to only display the expiration date if both expirationMonth and expirationYear exist. |
checkout/billing/paymentOptions/paymentOptionsSummary.isml | Override both the app_storefront_base and Amazon Pay versions, and add displays for both the Adyen and Amazon Pay payment methods. |
checkout/cart/miniCart.isml | Override both the app_storefront_base and Amazon Pay versions to override the change from the Amazon Pay cartridge that includes miniCartButtons instead of checkoutButtons . |
checkout/confirmation/confirmationDetails.isml | Keep this template identical to app_storefront_base . |
checkout/customer/customerCard.isml | Add a Buy with Prime sign-in widget to the checkout login. |
checkout/customer/customerSummary.isml | Add a conditional statement if the checkout is a Buy with Prime checkout to use the email address from the order. |
checkout/productCard/productCard.isml | Add attributes to the .product-line-item div, and add the Prime checkmark logo and Prime Day deal promotions. |
checkout/productCard/productCardSummary.isml | Add this new file, which doesn't exist in app_storefront_base . |
checkout/shipping/shipmentCard.isml | Add a sign-in card for Buy with Prime. |
checkout/shipping/shippingCard.isml | Suppress the display for Buy with Prime or multi-channel fulfillment orders, add the selected-shipping-method-X attribute to the .leading-lines div, and edit the display to allow for strikethrough shipping pricing. |
checkout/shipping/shippingSummary.isml | Edit the shipping summary display. |
checkout/checkout.isml | Override both the app_storefront_base and Amazon Pay versions. |
checkout/orderProductSummary.isml | Edit the product summary display. |
common/layout/checkout.isml | Override both the app_storefront_base and Amazon Pay versions. |
product/components/addToCartButtonExtension.isml | Add the Buy with Prime button to the cart. The app_storefront_base version of this template is empty. |
product/components/productAvailability.isml | Add bwpCard above product availability. |
product/gridTile.isml | Add the productTile.js asset to the page, and add amzn-sku to the .product div. |
product/productTileFooter.isml | Add the Prime checkmark logo to the bottom of the product tile. |
product/quickView.isml | Add attributes to .product-quickview , and add bwpCard below product availability. |
search/refinements/attributes/boolean.isml | Add the ability to use the Prime checkmark logo next to the refinement check box instead of text. |
cart/productCard/cartProductCardEdit.isml
Wrap a conditional statement to only show an Edit link next to a line item if the line item is for a variation product.
Code
data:image/s3,"s3://crabby-images/e1fb0/e1fb029bbbbe0f57f53d278a8205937cab0a418f" alt="Code for cartProductCardEdit"
cart/productCard/cartProductCardProductPrice.isml
Add two div elements for Buy with Prime to each product line item.
Code
data:image/s3,"s3://crabby-images/044ee/044ee806d97f9abaed30db01f2bd9ffe63e506c2" alt="Code for cartProductCardProductPrice"
cart/cartApproachingDiscount.isml
Add messaging for the shipping discount.
Code
data:image/s3,"s3://crabby-images/764fc/764fcb658f2cb99f05eaa9baee9f6816234536a1" alt="Code for cartApproachingDiscount"
cart/cartShippingMethodSelection.isml
Wrap a conditional statement to only show the shipping method selection for items not eligible for Buy with Prime.
Code
data:image/s3,"s3://crabby-images/f5a0e/f5a0ef05e5944f7a701c97e62fa7dc32c9633ced" alt="Code for cartShippingMethodSelection"
cart/checkoutButtons.isml
Override both the app_storefront_base
and Amazon Pay versions, add the Buy with Prime button, and edit the markup for the standard checkout button.
Code
data:image/s3,"s3://crabby-images/608cd/608cdf8df6c994ab010fe932aa6a0fbf79087e9a" alt="Code for checkoutButtons"
checkout/billing/paymentOptions/creditCardSummary.isml
Wrap a conditional statement to only display the expiration date if both expirationMonth
and expirationYear
exist.
Code
data:image/s3,"s3://crabby-images/72df4/72df451a4b80a838fbd4b481edbc9856f76b642c" alt="Code for creditCardSummary"
checkout/billing/paymentOptions/paymentOptionsSummary.isml
Override both the app_storefront_base
and Amazon Pay versions, and add displays for both the Adyen and Amazon Pay payment methods.
Code
data:image/s3,"s3://crabby-images/8fd22/8fd22325b1d3fee41e3225fc312d30dc80ca57ea" alt="Code for paymentOptionsSummary"
checkout/cart/miniCart.isml
Override this template to include cart/checkoutButtons.isml
, like in app_storefront_base
. Don't include cart/miniCartButtons
, like in int_amazonpay_sfra
.
checkout/confirmation/confirmationDetails.isml
Keep this template similar to the template in app_storefront_base
, relying on the includes checkout/shipping/shippingSummary.isml
and checkout/orderProductSummary.isml
.
checkout/customer/customerCard.isml
Add a Buy with Prime sign-in widget to the checkout login.
Code
data:image/s3,"s3://crabby-images/3dd50/3dd506f422b5cd4a88381ddf0ed3d027fbd31f5f" alt="Code for customerCard"
checkout/customer/customerSummary.isml
Add a conditional statement if the checkout is a Buy with Prime checkout to use the email address from the order.
Code
data:image/s3,"s3://crabby-images/65cb1/65cb1e74ca28716d10c691e99a96560af8adc935" alt="Code for customerSummary"
checkout/productCard/productCard.isml
Add attributes to the .product-line-item
div.
Code
data:image/s3,"s3://crabby-images/1cdb2/1cdb2c4cbe85bc81fd0f642becd46ee0d188d9d8" alt="Code for productCard"
Add the Prime checkmark logo and Prime Day deal promotions.
Code
data:image/s3,"s3://crabby-images/37d06/37d06d32f949f3f39927a2f30a51c818d88ac0ab" alt="Code for productCard continued"
checkout/productCard/productCardSummary.isml
Add this new file from int_buywithprime_sfra
. The file doesn't exist in app_storefront_base
.
checkout/shipping/shipmentCard.isml
Add a sign-in card for Buy with Prime.
Code
data:image/s3,"s3://crabby-images/4dd2e/4dd2e2de02287ff536fe95ebd45f90fc26e90963" alt="Code for shipmentCard"
checkout/shipping/shippingCard.isml
Suppress the display for Buy with Prime or multi-channel fulfillment orders, add the selected-shipping-method-X
attribute to the .leading-lines
div, and edit the display to allow for strikethrough shipping pricing.
Code
data:image/s3,"s3://crabby-images/2f553/2f55340ead07373b2558b1c262e1a53f5a0295f8" alt="Code for shippingCard"
checkout/shipping/shippingSummary.isml
Edit the shipping summary display.
Code
data:image/s3,"s3://crabby-images/cd228/cd2282ae74fc9f3469ec16e674a3b09abe4bdd40" alt="Code for shippingSummary"
checkout/checkout.isml
Override both the app_storefront_base
and Amazon Pay versions.
Code
data:image/s3,"s3://crabby-images/df2b5/df2b5d8d48d211f554f541520e02dfe777ff5361" alt="Code for checkout"
Code (continued)
data:image/s3,"s3://crabby-images/78fd7/78fd7b8f9621bab5a4ccf447594395fc2c519357" alt="Code for checkout continued"
Code (continued, again)
data:image/s3,"s3://crabby-images/5c31d/5c31de0a64b6f4e082da47ebff46578e3feb8ab7" alt="Code for checkout continued, again"
checkout/orderProductSummary.isml
Edit the product summary display.
Code
data:image/s3,"s3://crabby-images/5fcf4/5fcf4a93eaf197c868875e0aa346a7c7f644e0a8" alt="Code for orderProductSummary"
common/layout/checkout.isml
Override both the app_storefront_base
and Amazon Pay versions.
Code
data:image/s3,"s3://crabby-images/d418e/d418e2e3bafa0361083193292c30b9f1da6856a9" alt="Code for checkout"
product/components/addToCartButtonExtension.isml
Add the Buy with Prime button to the cart. The app_storefront_base
version of this template is empty.
Code
data:image/s3,"s3://crabby-images/b007b/b007b17d27230aef8436787e43ba65f0284234a4" alt="Code for addToCartButtonExtension"
product/components/productAvailability.isml
Add bwpCard
above product availability.
Code
data:image/s3,"s3://crabby-images/bdf24/bdf24424b19550877e6470f24104961fe2e4033c" alt="Code for productAvailability"
product/gridTile.isml
Add the productTile.js
asset to the page, and add amzn-sku
to the .product
div.
Code
data:image/s3,"s3://crabby-images/f42e8/f42e8657d4974a797368437526cc166a37840b62" alt="Code for gridTile"
product/productTileFooter.isml
Add the Prime checkmark logo to the bottom of the product tile.
Code
data:image/s3,"s3://crabby-images/a7350/a735026b2136d970f832ff24a98f39933d6674b4" alt="Code for productTileFooter"
product/quickView.isml
Add attributes to .product-quickview
.
Code
data:image/s3,"s3://crabby-images/c3cd4/c3cd49adf3a07098ee256ca1eb0086c259a31ce9" alt="Code for quickView"
Add bwpCard
below product availability.
Code
data:image/s3,"s3://crabby-images/9c598/9c598511d16fb4377fc6bf5de0fda98656e55ec4" alt="Code for quickView continued"
search/refinements/attributes/boolean.isml
Add the ability to use the Prime checkmark logo next to the refinement check box instead of text.
Code
data:image/s3,"s3://crabby-images/4b07e/4b07eb81ea700305781935dda04a2c628dc5ec4b" alt="Code for boolean"
Related topics
Updated 5 days ago