Zip Widget
Zip Widget (North America)
Integration Guide
Before You Start
Use these instructions to integrate the newest version of the Zip Widget. The new version of this widget offers a number of improvements present today and planned for the immediate future while maintaining all existing widget functionality. Upgrading to our latest widget will provide the most stable experience.
Highlights:
- No more versioning: Merchants will always be on the most up-to-date version of the widget without having to make any code changes; this means new features will automatically become available to merchants who have integrated the new widget.
- Hosted from quadpay.js: The quadpay.js library offers a number of client-side tools for merchants, so now you only need one library for all of your Zip frontend needs.
- ADA compliance: Although this was present in some previous versions of the widget, now it is available for all merchants using the new widget.
- Internationalization for verbiage and currency: Internationalization allows for widget support across multiple languages. The widget language is set by the primary language of the user's browser. Currently supported languages are English, French, and Spanish. We also offer the ability to tie the widget language to the global language of the site, if available, by passing in an attribute. If not defined, the language used is the customer's default browser language. Read more here: languageSelector.
- Configuration-driven properties: Some properties of the widget can be pulled from merchant configuration by passing in the merchant ID.
- Tooltip color matching: The color of the widget tooltip will match the color of the widget copy. This helps if your site has a dark background and light-colored copy.
Example Widget
Please use the following steps to integrate the Zip Widget.
1. Enable display of the widget and modal
Paste this snippet which renders the Zip Widget and informational modal in the store's theme or global file.
<!-- quadpay.js Library -->
<script src="https://cdn.us.zip.co/v1/quadpay.js"></script>
2. Place the widget
Paste this snippet where the Zip Widget should appear. We recommend the following:
- Beneath the product price on the Product Detail Page
- Beneath the cart total on the Cart page
- Beneath the cart total on the Mini Cart page
For each placement, update the amount attribute (e.g. for Shopify use {{ current_variant.price }}) with the variable for the product price or cart total.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100"></quadpay-widget-v3>
Update Existing Widget Integration
To easily update your existing widget integration to the newest version of the widget, especially if you have implemented any customizations, feel free to append your existing widget tag name to the quadpay.js library in the store’s theme or global file. In doing so, you will only need to change the JavaScript reference and can leave the widget DOM elements as is.
Custom Widget Tag
When adding the custom widget tag name to quadpay.js as a query param,
tagname
, you must remove all other instances of quadpay.js library in order to avoid errors.
tagname
has three requirements:
- Must be hyphenated
- Must be all lowercase
- Cannot include special characters, such as numbers
The following examples include quadpay-widget
as the custom widget tag name for the JavaScript reference: https://cdn.us.zip.co/v1/quadpay.js?tagname=quadpay-widget.
Enable display of the widget and modal - custom tag name
<!-- With the custom widget tag name -->
<script src="https://cdn.us.zip.co/v1/quadpay.js?tagname=quadpay-widget"></script>
Place the widget - custom tag name
<!-- With the custom widget tag name -->
<quadpay-widget amount="100"></quadpay-widget>
Preview
In certain instances, adjustments like spacing and alignment are necessary. Be sure to preview the widget at desktop and mobile screen widths.
Also, take note that the Zip informational modal appears when the user clicks on the Zip logo or information "i" link. To customize the styling of this modal, select the element by ID and add insert CSS styling accordingly.
Customization
The Zip Widget supports the following optional customizations.
Available attributes
Attribute name | Value type | Details |
---|---|---|
alignment | left, center, right | Default alignment is left-aligned |
amountSelector | css selector | Product price changes |
breakpointAlignment | string | Alignment by breakpoint |
customMargins | string | Overwrites margin around widget. Attribute value must be a valid CSS value for margin. e.g. "0px 0px 10px 0px" or "20px 0px" or "5px" |
disableAdaCompliance | boolean | Disable ADA compliance styling |
displayMode | string | "logoFirst" |
hideLogo | boolean | Hides logo and replaces it with a plain text link of Zip. |
installmentServiceFeeAmount | number | Dependent on isMFPPMerchant="true". This value reflects the installment fee amount. |
isMFPPMerchant | boolean | Set to "true" if utilizing the Merchant Fee For Payment Plan structure. Will add verbiage to the info modal that says "[Merchant Name] may charge you an additional fee to use Zip." |
languageSelector | string | Ties the widget language to the global language of the site, if available. If not defined, the language used is the customer's default browser language. |
learnMoreUrl | string | Optional url link to be added to the informational modal. |
logoAlignment | number | e.g. -1px |
logoOption | string | Our default logo is displayed with a transparent background. Other options are - 'secondary' which displays a dark background for the Zip logo. 'secondary-light' displays a white background for the Zip logo. 'black-white' displays the logo in all black and white. |
logoSize | percent value | 60% to 120% |
max | number | Default is $1500 |
merchantId* | string — Required | A merchant unique Id provided by Zip. |
min | number | Default is $35 |
minModal | number | Dependent on isMFPPMerchant="true". This will add "Only available for purchases over {minimumOrderValue} to the modal, without affecting the same verbiage on the widget itself. |
priceColor | hex color | #990000 |
size | percent value | e.g. - 90%, 120% |
widgetVerbiage | string | '4-easy-payments'. This will change text in the widget to "4 easy payments". The default is "4 interest-free payments". |
> Adjust Alignment
The default alignment of the widget is left-aligned. To change the widget’s alignment, add alignment="center"
or alignment="right"
to the quadpay-widget-v3
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" alignment="center"></quadpay-widget-v3>
> Handle Changes to Price or Cart Total
QA Tip
Test that Zip installment amount updates on products with variable prices and when quantities are changed in the cart.
The Zip installment amount should update when the product price changes. To use this feature, add amountSelector="{SELECTOR (ID, CLASS) FOR PRICE OR TOTAL}"
to the quadpay-widget-v3
tag:
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" amountSelector=".price"></quadpay-widget-v3>
> Adjust Alignment on a Breakpoint
The default alignment of the widget is always left-aligned. Often, the layout of a site changes as the viewport width changes. To adjust the alignment of the widget based on a breakpoint, add breakpointAlignment="{BREAKPOINT (VIEWPORT PIXEL WIDTH) ALIGNMENT}"
to the quadpay-widget-v3
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" breakpointAlignment="768, right"></quadpay-widget-v3>
> Disable ADA Compliance Styling
You can disable ADA compliance styling with the attribute disableAdaCompliance="true" on the quadpay-widget-v3 element.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" disableAdaCompliance="true"></quadpay-widget-v3>
> Adjust Display Mode
This value enables you to adjust the UX of the widget such that it shows the Zip logo at the beginning of the text, rather than the standard, which is shown at the end.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" displayMode="logoFirst"></quadpay-widget-v3>
> Hide Logo
This value removes the Zip logo on the widget and replaces it with a plain text link of 'Zip'.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" hideLogo="true"></quadpay-widget-v3>
> Set If Utilizing Merchant Fee For Payment Plan
This value is set to "true" if you are utilizing the Merchant Fee For Payment Plan. If "true" is passed in for this value, the installment price is set to include an additional $1 by default.
!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" isMFPPMerchant="true"></quadpay-widget-v3>
> Set Installment Service Fee Amount
This value is contingent on isMFPPMerchant. The service fee is assumed to be $1 if a merchant has a service fee (so 4 payments of 26 on a 100 order) but if it's higher the value can be passed in to calculate the payment.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" isMFPPMerchant="true" installmentServiceFeeAmount="2"></quadpay-widget-v3>
> Set Widget Language to Global Language of the Site
An optional attribute to tie the widget language to the global language of the site.
The element must contain a lang attribute. The widget will default to the HTML root tag if the languageSelector is used
<html lang="fr-CA">
<span id="language-identifier" lang="fr-CA">French</span>
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" languageSelector="#language-identifier"></quadpay-widget-v3>
> Add a Learn More URL to the Info Modal
An optional url to pass, to be included as a "learn more" link in the info modal. If no url is passed the text will not show in the modal.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" learnMoreURL="https://www.quadpay.com/how-it-works/"></quadpay-widget-v3>
> Adjust Logo Alignment
If the logo does not appear vertically aligned in the widget, add logoAlignment="{PIXELS UP OR DOWN}"
to the quadpay-widget-v3
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" logoAlignment="-1px"></quadpay-widget-v3>
> Choose Logo Option
The default option for the widget logo is the standard Zip logo on a transparent background. To choose a dark background add logoOption="secondary"
to the quadpay-widget-v3
tag. To choose a white background with a black border around the Zip logo add 'logoOption='secondary-light' to the quadpay-widget-v3
tag. To choose a black and white version of the logo add 'logoOption="black-white"' to the quadpay-widget-v3
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" logoOption="secondary"></quadpay-widget-v3>
Secondary Example
Secondary Light Example
Black and White Example
> Adjust Logo Size
To increase or decrease the size of the Zip logo inside the widget, add logoSize="{PERCENTAGE}"
to the quadpay-widget-v3
tag. The logo size must be between 60% and 120%.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" logoSize="95%"></quadpay-widget-v3>
> Adjust Maximum Price
The default maximum amount is $1500. On occasion, a merchant has agreed to a different maximum with Zip. In these cases, the widget should reflect the agreed-to maximum amount allowed by adding max="{MAXIMUM PRICE}"
to the quadpay-widget-v3
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" max="1600" ></quadpay-widget-v3>
> Merchant ID
Directly inject merchant ID by setting it in the attribute.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100"
merchantId="44444444-4444-4444-4444-444444444444"></quadpay-widget-v3>
> Adjust Minimum Price
The default minimum amount is $35. On occasion, a merchant has agreed to a different minimum price with Zip. In these cases, the widget should reflect the agreed-to minimum purchase price by adding min="{MINIMUM PRICE}"
to the quadpay-widget-v3
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" min="35" ></quadpay-widget-v3>
> Set Minimum on Modal
This value is contingent on isMFPPMerchant set to 'true.' Our default minimum order value is $35, but at times, this can be adjusted. If isMFPPMerchant is set to 'true' and your minimum order value is something other than $35, please set this value to your minimum order value. This will be reflected on the info modal line 'Only available for purchases over ${minimum order value}.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" isMFPPMerchant="true" installmentServiceFeeAmount="1" merchantId="c5b74e9a-9c6c-4640-9bcb-fe3c63208f15" minModal="50"></quadpay-widget-v3>
> Set Price Color
The default color for the installment price is the same as the surrounding text. To adjust the color of the installment price, add priceColor="{HEX COLOR}"
to the quadpay-widget-v3
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" priceColor="#990000"></quadpay-widget-v3>
> Adjust Text Size
To increase or decrease the size of the text inside the widget, add size="{PERCENTAGE}"
to the quadpay-widget-v3
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" size="110%"></quadpay-widget-v3>
> Adjust Layout Spacing
To adjust the space around the widget, wrap the widget in a div and adjust the style="margin: {TOP, RIGHT, BOTTOM, LEFT PIXELS};
attributes to achieve the desired spacing.
<!-- Insert Zip Widget -->
<div style="margin: 0 0 10px 0;">
<quadpay-widget-v3 amount="100"></quadpay-widget-v3>
</div>
> Adjust Widget Margins Directly
The default margin value is simply 0. To change the widget's margins, add customMargins="20px 10px"
(whatever suits your needs and follows proper CSS margin guidelines) to the quadpay-widget
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" customMargins="10px"></quadpay-widget-v3>
> Adjust Widget Verbiage
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100" widgetVerbiage="4-easy-payments" ></quadpay-widget-v3>
> Combine Customizations
Many customizations can be included in the quadpay-widget
tag.
<!-- Insert Zip Widget -->
<quadpay-widget-v3 amount="100"
min="35"
max="1500"
alignment="center"
breakpointAlignment="768, right"
size="110%"
logoColor="#666666"
logoAlignment="-1px"
amountSelector=".price"
merchantId="44444444-4444-4444-4444-444444444444">
</quadpay-widget-v3>
Advanced Customizations
If you would like to talk about more advanced customizations or have any questions, please email our Partner Support team.
Updated over 2 years ago