UNPKG

@nguyenmv2/buy-button

Version:

BuyButton.js allows merchants to build Shopify interfaces into any website

866 lines (752 loc) 21.6 kB
html, body, h1, h2, h3, h4, h5, p { padding: 0; margin: 0; } * { box-sizing: border-box; } body, html { min-height: 100%; } html { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 14px; line-height: 1.2; color: #4c4c4c; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } ul { list-style: none; padding-left: 0; margin: 0; } img { display: block; max-width: 100%; } input { -webkit-appearance: textfield; margin: 0; } .clearfix:after { content: ""; display: table; clear: both; } .visuallyhidden { border: 0; height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; } .component-container { overflow: hidden; } .shopify-buy__type--center { text-align: center; } .shopify-buy__quantity-decrement, .shopify-buy__quantity-increment { color: #4c4c4c; display: block; height: 30px; float: left; line-height: 16px; font-family: monospace; width: 26px; padding: 0; border: none; background: transparent; box-shadow: none; cursor: pointer; font-size: 18px; text-align: center; font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; border: 1px solid #767676; position: relative; } .shopify-buy__quantity-decrement svg, .shopify-buy__quantity-increment svg { width: 14px; height: 14px; position: absolute; top: 50%; left: 50%; margin-top: -6px; margin-left: -7px; fill: currentColor; } .shopify-buy__quantity-decrement { border-radius: 3px 0 0 3px; } .shopify-buy__quantity-increment { border-radius: 0 3px 3px 0; } .shopify-buy__quantity { color: black; width: 45px; height: 30px; font-size: 16px; border: none; text-align: center; -moz-appearance: textfield; -webkit-appearance: none; display: inline-block; padding: 0; border-radius: 0; border-top: 1px solid #767676; border-bottom: 1px solid #767676; } input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; } .shopify-buy__quantity-container.shopify-buy__quantity-with-btns { overflow: hidden; } .shopify-buy__quantity-container.shopify-buy__quantity-with-btns .shopify-buy__quantity { border-left: 0; border-right: 0; float: left; } .shopify-buy__btn { color: #fff; font-size: 15px; background-color: #78b657; padding: 12px 40px; letter-spacing: .3px; display: block; border-radius: 3px; cursor: pointer; transition: background 200ms ease; max-width: 100%; text-overflow: ellipsis; overflow: hidden; line-height: 1.2; border: 0; -moz-appearance: none; -webkit-appearance: none; } .shopify-buy__btn:hover, .shopify-buy__btn:focus { background-color: #5f9d3e; } .shopify-buy__btn--parent { background-color: transparent; border: 0; padding: 0; cursor: pointer; } .shopify-buy__btn--parent:hover .product__variant-img, .shopify-buy__btn--parent:focus .product__variant-img { opacity: .7; } .shopify-buy__btn--cart-tab { padding: 5px 11px; border-radius: 3px 0 0 3px; position: fixed; right: 0; top: 50%; transform: translate(100%, -50%); opacity: 0; min-width: inherit; width: auto; height: auto; z-index: 2147483647; } .shopify-buy__btn--cart-tab.is-active { transform: translateY(-50%); opacity: 1; } .shopify-buy__btn__counter { display: block; margin: 0 auto 10px auto; font-size: 18px; } .shopify-buy__icon-cart--side { height: 20px; width: 20px; } .shopify-buy__btn[disabled] { background-color: #999; pointer-events: none; } .shopify-buy__btn--close { position: absolute; right: 9px; top: 8px; font-size: 35px; color: #767676; border: none; background-color: transparent; transition: transform 100ms ease; cursor: pointer; font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; padding-right: 9px; } .shopify-buy__btn--close:hover { transform: scale(1.2); color: dimgray; } .shopify-buy__option-select-wrapper { border: 1px solid #d3dbe2; border-radius: 3px; box-sizing: border-box; position: relative; background: #fff; overflow: hidden; vertical-align: bottom; } .shopify-buy__select-icon { cursor: pointer; display: block; fill: #798c9c; position: absolute; right: 10px; top: 50%; margin-top: -6px; pointer-events: none; width: 12px; height: 12px; vertical-align: middle; } .shopify-buy__option-select + .shopify-buy__option-select { margin-top: 7.5px; } .shopify-buy__option-select__label { display: block; font-size: 14px; margin-top: 15px; margin-bottom: 5px; } .shopify-buy__btn--parent .shopify-buy__option-select__label { cursor: pointer; } .shopify-buy__option-select__select { font-size: inherit; padding: 7px 10px; padding-right: 32px; border: 0; width: 100%; background: transparent; -webkit-appearance: none; -moz-appearance: none; } .shopify-buy__btn--parent .shopify-buy__option-select__select { cursor: pointer; } .shopify-buy__option-select__select::-ms-expand { display: none; } .shopify-buy__product { overflow: hidden; width: 100%; } .shopify-buy__product__variant-img { margin: 0 auto 15px auto; transition: opacity 0.3s ease; opacity: 1; } .shopify-buy__product__variant-img.is-transitioning { opacity: 0; } .shopify-buy__is-button { cursor: pointer; } .shopify-buy__no-image .shopify-buy__product__variant-img { display: none; } .shopify-buy__product__title { font-size: 18px; line-height: 1.2; color: #4a4a4a; margin-bottom: 15px; font-weight: 700; } .shopify-buy__layout-horizontal .shopify-buy__product__title { margin-top: 10px; } .shopify-buy__product__variant-title { font-size: 18px; color: #666; font-weight: 400; text-align: center; margin-bottom: 15px; } .shopify-buy__product__price { margin-bottom: 15px; } .shopify-buy__product-description { margin-top: 30px; line-height: 1.65; color: #4a4a4a; } .shopify-buy__product-description p, .shopify-buy__product-description ul, .shopify-buy__product-description ol, .shopify-buy__product-description img { margin-bottom: 10px; } .shopify-buy__product-description p:last-child, .shopify-buy__product-description ul:last-child, .shopify-buy__product-description ol:last-child, .shopify-buy__product-description img:last-child { margin-bottom: 0; } .shopify-buy__product-description a { color: inherit; } .shopify-buy__product-description img { max-width: 100%; } .shopify-buy__product-description h1 { font-size: 20px; } .shopify-buy__product-description h2 { font-size: 18px; } .shopify-buy__product-description h3 { font-size: 17px; } .shopify-buy__product-description ul, .shopify-buy__product-description ol { margin-left: 2em; } .shopify-buy__product-description ul { list-style-type: disc; } .shopify-buy__layout-vertical { text-align: center; } .shopify-buy__product__actual-price, .shopify-buy__product__compare-price { color: #4a4a4a; display: inline-block; } .shopify-buy__product__actual-price { font-size: 14px; } .shopify-buy__product__compare-price { font-size: 12px; text-decoration: line-through; padding-left: 5px; opacity: 0.65; } .shopify-buy__product__variant-selectors { text-align: left; font-size: 14px; } .shopify-buy__layout-vertical .shopify-buy__product__variant-selectors { width: 100%; max-width: 280px; display: inline-block; } .shopify-buy__quantity { border-left: 1px solid; border-right: 1px solid; border-radius: 3px; } .shopify-buy__quantity, .shopify-buy__quantity-increment, .shopify-buy__quantity-decrement { border-color: #d3dbe2; line-height: 1.2; font-size: 15px; height: auto; padding-top: 12px; padding-bottom: 12px; } .shopify-buy__btn { display: inline-block; } .shopify-buy__btn-wrapper { margin-top: 20px; } .shopify-buy__btn.shopify-buy__beside-quantity { display: inline-block; vertical-align: top; border-top-left-radius: 0; border-bottom-left-radius: 0; border: 1px solid transparent; } .shopify-buy__btn-and-quantity .shopify-buy__quantity { border-right: 0; border-top-right-radius: 0; border-bottom-right-radius: 0; background: #fff; } .shopify-buy__btn-and-quantity .shopify-buy__quantity-container { display: inline-block; vertical-align: top; } .shopify-buy__btn-and-quantity .shopify-buy__btn-wrapper { display: inline-block; vertical-align: top; margin: 0; } .shopify-buy__cart-item__quantity-container { margin-top: 20px; display: inline-block; } .shopify-buy__layout-vertical .shopify-buy__btn, .shopify-buy__layout-vertical .shopify-buy__quantity-container, .shopify-buy__layout-horizontal .shopify-buy__btn, .shopify-buy__layout-horizontal .shopify-buy__quantity-container { margin: 20px auto 0; } .shopify-buy__layout-vertical .shopify-buy__btn:first-child, .shopify-buy__layout-horizontal .shopify-buy__btn:first-child { margin-top: 0; } .shopify-buy__layout-vertical .shopify-buy__btn-and-quantity, .shopify-buy__layout-horizontal .shopify-buy__btn-and-quantity { margin: 20px auto 0; } .shopify-buy__layout-vertical .shopify-buy__btn-and-quantity .shopify-buy__btn, .shopify-buy__layout-vertical .shopify-buy__btn-and-quantity .shopify-buy__quantity-container, .shopify-buy__layout-horizontal .shopify-buy__btn-and-quantity .shopify-buy__btn, .shopify-buy__layout-horizontal .shopify-buy__btn-and-quantity .shopify-buy__quantity-container { margin: 0 auto; } .shopify-buy__layout-vertical .shopify-buy__btn-and-quantity:first-child, .shopify-buy__layout-horizontal .shopify-buy__btn-and-quantity:first-child { margin: 0 auto; } .shopify-buy__layout-vertical .shopify-buy__product__variant-img, .shopify-buy__layout-horizontal .shopify-buy__product__variant-img { max-width: 100%; } @media (min-width: 500px) { .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product-img-wrapper { float: left; width: 40%; } .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__variant-title { text-align: left; } .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__title, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__variant-title, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__price, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product-description, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__btn-and-quantity, .shopify-buy__layout-horizontal:not(.no-image) > .shopify-buy__btn-wrapper, .shopify-buy__layout-horizontal:not(.no-image) > .shopify-buy__quantity-container, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__variant-selectors { margin-left: calc(40% + 25px); } } @media (min-width: 680px) { .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product-img-wrapper { float: left; width: 60%; } .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__title, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__variant-title, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__price, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product-description, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__btn-and-quantity, .shopify-buy__layout-horizontal:not(.no-image) > .shopify-buy__btn-wrapper, .shopify-buy__layout-horizontal:not(.no-image) > .shopify-buy__quantity-container, .shopify-buy__layout-horizontal:not(.no-image) .shopify-buy__product__variant-selectors { margin-left: calc(60% + 25px); } } @keyframes dash { to { stroke-dashoffset: 0; } } .shopify-buy__btn--close { right: 0px; font-size: 45px; font-weight: 100; z-index: 2147483647; padding: 0 10px; } .shopify-buy__modal { background: #fff; width: calc(100% - 20px); position: absolute; left: 0; right: 0; z-index: 2147483646; } .shopify-buy__product { text-align: left; } .shopify-buy__product__title, .shopify-buy__product__price, .shopify-buy__product__variant-title { text-align: left; } .shopify-buy__product__title { font-size: 26px; font-weight: 700; line-height: 1.4; } .shopify-buy__product__compare-price { display: inline-block; margin-right: 5px; } .shopify-buy__product__actual-price { display: inline-block; } .shopify-buy__modal .shopify-buy__modal-product-wrapper { width: 100%; } .shopify-buy__product__variant-image { margin: 0; } @media (max-width: 499px) { body.is-active { overflow: hidden; position: fixed; height: 100vh; transition: all 0s; } .shopify-buy__modal { width: 100%; min-height: 100vh; position: fixed; overflow-y: auto; } .shopify-buy__product { padding: 15px; position: absolute; top: 0; left: 0; } .shopify-buy__product__variant-img { max-height: 60vh; margin: 0 auto; width: auto; max-width: 100%; } .shopify-buy__btn--close { position: fixed; top: 0; right: 0; } } @keyframes slideIn { from { opacity: 0; transform: translateY(-200px); -webkit-transform: translateY(-200px); } to { opacity: 1; transform: translateY(0); -webkit-transform: translateY(0); } } @media (min-width: 500px) { html, body.is-active { height: 100%; } .shopify-buy__modal-overlay { width: 100%; height: 100%; position: fixed; overflow-y: scroll; } .shopify-buy__modal { margin: 100px auto 40px auto; opacity: 0; border-radius: 2px; border: 1px solid rgba(0, 0, 0, 0.72); transform: translateY(-200px); max-width: 1000px; animation-name: slideOut; animation-duration: 200ms; animation-fill-mode: forwards; } .is-active .shopify-buy__modal { animation-name: slideIn; animation-duration: 200ms; animation-fill-mode: forwards; } .shopify-buy__product { padding: 30px; } .shopify-buy__product-img-wrapper { height: 100%; padding-right: 30px; max-height: 570px; } .shopify-buy__product-img-wrapper { height: 100%; max-height: 570px; } .shopify-buy__product__variant-img { max-height: 100%; } .shopify-buy__btn--close { top: -60px; color: white; } .shopify-buy__btn--close:hover { color: #fff; } } @media (min-width: 680px) { .shopify-buy__product { padding: 45px; } } @keyframes flipIn { from { max-height: 0; transform: rotatex(90deg) translatey(-50%); margin-bottom: -65px; opacity: 0; } to { max-height: none; transform: none; margin-bottom: 20px; opacity: 1; } } @keyframes flipOut { from { max-height: none; transform: none; margin-bottom: 20px; opacity: 1; } to { max-height: 0; transform: rotatex(90deg) translatey(-50%); margin-bottom: -65px; opacity: 0; } } .shopify-buy__cart-wrapper { height: 100%; padding-left: 10px; } .shopify-buy__cart { height: 100%; background-color: #fff; width: calc(100% - 10px); position: absolute; right: 0; box-shadow: -5px 0 5px rgba(0, 0, 0, 0.1); } .shopify-buy__cart__header { padding: 20px; padding-right: 40px; position: relative; z-index: 2147483647; } .shopify-buy__cart__title { font-size: 18px; color: #767676; font-weight: normal; overflow: hidden; text-overflow: ellipsis; } .shopify-buy__cart-scroll { padding: 70px 0 135px 0; position: absolute; top: 0; height: 100%; width: 100%; } .shopify-buy__cart-items { overflow: hidden; overflow-y: auto; height: 100%; position: relative; padding: 0 20px 20px; -webkit-overflow-scrolling: touch; perspective: 400px; perspective-origin: 50% 0px; } .shopify-buy__cart-item { min-height: 65px; margin-bottom: 20px; overflow: hidden; position: relative; backface-visibility: visible; animation: 200ms flipIn forwards; } .shopify-buy__cart-item.is-hidden { animation-name: flipOut; } .shopify-buy__cart-item__image { width: 65px; height: 65px; background-size: contain; background-repeat: no-repeat; background-position: center center; background-color: transparent; position: absolute; left: 0; top: 0; } .shopify-buy__cart-item__title { font-size: 14px; margin-left: 80px; display: block; margin-bottom: 10px; } .shopify-buy__cart-item__price { float: right; font-size: 14px; font-weight: bold; line-height: 26px; } .shopify-buy__cart-item__variant-title { float: right; color: #4c4c4c; font-size: 11px; font-weight: bold; max-width: 220px; overflow: hidden; text-overflow: ellipsis; } .shopify-buy__cart-bottom { background-color: #fff; position: absolute; width: 100%; bottom: 0; padding: 20px; } .shopify-buy__cart__subtotal__text { text-transform: uppercase; float: left; font-size: 11px; color: #4c4c4c; } .shopify-buy__cart__subtotal__price { float: right; } .shopify-buy__cart__currency { font-size: 12px; } .shopify-buy__cart__notice { font-size: 11px; clear: both; padding-top: 10px; text-align: center; color: #4c4c4c; } .shopify-buy__cart-empty-text { padding: 10px 15px; text-align: center; } .shopify-buy__btn--cart-checkout { clear: both; margin-top: 15px; width: 100%; padding: 10px 5px; font-size: 16px; } .shopify-buy__quantity-container { margin-left: 80px; height: 26px; line-height: 26px; } .shopify-buy__cart-item__quantity-input { float: left; background: transparent; } .shopify-buy__cart-toggle-wrapper { display: inline-block; } .shopify-buy__cart-toggle { background-color: #78b657; color: #fff; border-radius: 3px 0 0 3px; padding: 8px 10px; text-align: center; display: inline-block; min-width: 46px; margin-right: 0; cursor: pointer; transition: background 200ms ease; } .shopify-buy__cart-toggle:hover { background-color: #5f9d3e; } .shopify-buy__cart-toggle__count { font-size: 18px; margin-bottom: 10px; } .shopify-buy__icon-cart__group { fill: #fff; } .is-inline .shopify-buy__icon-cart, .is-inline .shopify-buy__cart-toggle__title, .is-inline .shopify-buy__cart-toggle__count { display: inline-block; vertical-align: middle; } .is-inline .shopify-buy__icon-cart { margin-right: 5px; } .is-inline .shopify-buy__cart-toggle__title { font-size: 16px; font-weight: normal; } .is-inline .shopify-buy__cart-toggle__count { margin-left: 21px; margin-bottom: 0; position: relative; } .is-inline .shopify-buy__cart-toggle__count:before { content: ""; display: block; position: absolute; left: -12px; height: 100%; width: 1px; background-color: #fff; opacity: 0.3; } .is-inline.shopify-buy__cart-toggle { border-radius: 3px; padding: 5px 10px; } .shopify-buy__collection { overflow: hidden; } .shopify-buy__collection-products { display: -webkit-box; display: flex; justify-content: center; flex-wrap: wrap; margin-left: -15px; text-align: center; } .shopify-buy__product { margin-left: 15px; margin-bottom: 15px; flex: 0 0 auto; display: inline-block; vertical-align: top; max-width: 250px; width: auto; } .shopify-buy__btn.shopify-buy__collection-pagination-button { display: none; margin: 15px auto; } .shopify-buy__btn.shopify-buy__collection-pagination-button.is-active { display: block; } .shopify-buy-frame { display: inline-block; } .shopify-buy-frame iframe { width: 100%; display: block; height: 0; overflow: hidden; } .shopify-buy-frame--cart { width: 100%; max-width: 350px; position: fixed; top: 0; right: 0; height: 100%; z-index: 2147483647; transform: translateX(100%); -webkit-transform: translateX(100%); } .shopify-buy-frame--cart iframe { height: 100%; } .shopify-buy-frame--cart.is-initialized { transition: all 250ms cubic-bezier(0.165, 0.84, 0.44, 1); } .shopify-buy-frame--cart.is-active { transform: translateX(0); -webkit-transform: translateX(0); } .shopify-buy-frame--product { display: block; } .shopify-buy-frame--product.shopify-buy__layout-horizontal { display: block; margin-left: auto; margin-right: auto; } .shopify-buy-frame--product.shopify-buy__layout-horizontal iframe { max-width: 100%; } @media (min-width: 950px) { .shopify-buy-frame--product.shopify-buy__layout-horizontal iframe { max-width: 950px; margin-left: auto; margin-right: auto; } } .shopify-buy-frame--toggle { display: inline-block; } .shopify-buy-frame--toggle:not(.is-sticky) { overflow: hidden; padding: 5px; } .shopify-buy-frame--toggle.is-sticky { display: none; position: fixed; right: 0; top: 50%; transform: translateY(-50%); -webkit-transform: translateY(-50%); z-index: 2147483645; } .shopify-buy-frame--toggle.is-active.is-sticky { display: block; } .shopify-buy-frame--toggle iframe { height: auto; } .is-active .shopify-buy-frame--toggle iframe { min-height: 67px; } .shopify-buy-frame--productSet { width: 100%; } .shopify-buy-frame--modal { position: fixed; width: 100%; height: 100%; top: 0; left: 0; z-index: 2147483646; display: none; transition: background 300ms ease; } .shopify-buy-frame--modal iframe { height: 100%; width: 100%; max-width: none; } .shopify-buy-frame--modal.is-active { background: rgba(0, 0, 0, 0.6); } .shopify-buy-frame--modal.is-block { display: block; }