Use CSS templates to display Apple Pay buttons in Safari
You don’t have to design your own buttons for Apple Pay. You can use CSS templates to display Apple Pay buttons in Safari. Apple Pay provides a variety of Apple Pay buttons that you can use on your website to initiate a transaction. You can specify which button type to display and edit its appearance and size to fit your webpage.
Button Types
The following Apple Pay button values are available starting with Apple Pay on the Web version 2:
buy
- A button with the text “Buy with” and the Apple Pay logo.donate
- A button with the text “Donate with” and the Apple Pay logo. Available in iOS 10.2 and later.plain
- A button with the Apple Pay logo only.set-up
- A button prompting the user to set up a card. See openPaymentSetup for an example of code to display the Set up Apple Pay button.
The following Apple Pay button values are available starting with Apple Pay on the Web version 4:
book
- A button with the text “Book with” and the Apple Pay logo.check-out
- A button with the text “Check out with” and the Apple Pay logo.subscribe
- A button with the text “Subscribe with” and the Apple Pay logo.
The following Apple Pay button values are available starting with Apple Pay on the Web version 10:
add-money
- A button with the text “Add money with” and the Apple Pay logo.contribute
- A button with the text “Contribute with” and the Apple Pay logo.order
- A button with the text “Order with” and the Apple Pay logo.reload
- A button with the text “Reload with” and the Apple Pay logo.rent
- A button with the text “Rent with” and the Apple Pay logo.support
- A button with the text “Support with” and the Apple Pay logo.tip
- A button with the text “Tip with” and the Apple Pay logo.top-up
- A button with the text “Top Up with” and the Apple Pay logo.
The following Apple Pay button values are available starting with Apple Pay on the Web version 12:
continue
- A button with the text “Continue with Apple Pay” and the Apple Pay logo.
Button Examples
This code example using the CSS @supports
feature to determine if the -webkit-appearance: -apple-pay-button
property is available.
/* HTML */
<div class="apple-pay-button apple-pay-button-black">
</div>
/* CSS */
.apple-pay-button {
display: inline-block;
-webkit-appearance: -apple-pay-button;
-apple-pay-button-type: donate; /* Use any supported button type. */
}
.apple-pay-button-black {
-apple-pay-button-style: black;
}
.apple-pay-button-white {
-apple-pay-button-style: white;
}
.apple-pay-button-white-with-line {
-apple-pay-button-style: white-outline;
}
For older versions of macOS and iOS where Safari doesn’t support the -webkit-appearance: -apple-pay-button
property, you must draw the Apple Pay button. This code example displays a plain Apple Pay button.
/* HTML */
<div class="apple-pay-button apple-pay-button-white"></div>
/* CSS */
@supports (-webkit-appearance: -apple-pay-button) {
.apple-pay-button {
display: inline-block;
-webkit-appearance: -apple-pay-button;
}
.apple-pay-button-black {
-apple-pay-button-style: black;
}
.apple-pay-button-white {
-apple-pay-button-style: white;
}
.apple-pay-button-white-with-line {
-apple-pay-button-style: white-outline;
}
}
@supports not (-webkit-appearance: -apple-pay-button) {
.apple-pay-button {
display: inline-block;
background-size: 100% 60%;
background-repeat: no-repeat;
background-position: 50% 50%;
border-radius: 5px;
padding: 0px;
box-sizing: border-box;
min-width: 200px;
min-height: 32px;
max-height: 64px;
}
.apple-pay-button-black {
background-image: -webkit-named-image(apple-pay-logo-white);
background-color: black;
}
.apple-pay-button-white {
background-image: -webkit-named-image(apple-pay-logo-black);
background-color: white;
}
.apple-pay-button-white-with-line {
background-image: -webkit-named-image(apple-pay-logo-black);
background-color: white;
border: .5px solid black;
}
}
This code example displays a Buy with Apple Pay button.
/* HTML */
<div class="apple-pay-button-with-text apple-pay-button-white-with-text">
<span class="text">Buy with</span>
<span class="logo"></span>
</div>
/* CSS */
@supports (-webkit-appearance: -apple-pay-button) {
.apple-pay-button-with-text {
display: inline-block;
-webkit-appearance: -apple-pay-button;
-apple-pay-button-type: buy;
}
.apple-pay-button-with-text > * {
display: none;
}
.apple-pay-button-black-with-text {
-apple-pay-button-style: black;
}
.apple-pay-button-white-with-text {
-apple-pay-button-style: white;
}
.apple-pay-button-white-with-line-with-text {
-apple-pay-button-style: white-outline;
}
}
@supports not (-webkit-appearance: -apple-pay-button) {
.apple-pay-button-with-text {
--apple-pay-scale: 1; /* (height / 32) */
display: inline-flex;
justify-content: center;
font-size: 12px;
border-radius: 5px;
padding: 0px;
box-sizing: border-box;
min-width: 200px;
min-height: 32px;
max-height: 64px;
}
.apple-pay-button-black-with-text {
background-color: black;
color: white;
}
.apple-pay-button-white-with-text {
background-color: white;
color: black;
}
.apple-pay-button-white-with-line-with-text {
background-color: white;
color: black;
border: .5px solid black;
}
.apple-pay-button-with-text.apple-pay-button-black-with-text > .logo {
background-image: -webkit-named-image(apple-pay-logo-white);
background-color: black;
}
.apple-pay-button-with-text.apple-pay-button-white-with-text > .logo {
background-image: -webkit-named-image(apple-pay-logo-black);
background-color: white;
}
.apple-pay-button-with-text.apple-pay-button-white-with-line-with-text > .logo {
background-image: -webkit-named-image(apple-pay-logo-black);
background-color: white;
}
.apple-pay-button-with-text > .text {
font-family: -apple-system;
font-size: calc(1em * var(--apple-pay-scale));
font-weight: 300;
align-self: center;
margin-right: calc(2px * var(--apple-pay-scale));
}
.apple-pay-button-with-text > .logo {
width: calc(35px * var(--scale));
height: 100%;
background-size: 100% 60%;
background-repeat: no-repeat;
background-position: 0 50%;
margin-left: calc(2px * var(--apple-pay-scale));
border: none;
}
}
Comments
Reply on Bluesky here to join the conversation.