UNPKG

senangwebs-buy

Version:

Lightweight JavaScript library that that enables easy implementation of e-commerce functionality through HTML attributes

407 lines (356 loc) 7.83 kB
/* Common styles for interactive elements */ .swb-checkout-form { display: flex; flex-direction: column; gap: 8px; padding: 16px; } .swb-checkout-form h2 { font-size: 12px; font-weight: bold; } .swb-sort-button, .swb-cart-button, .swb-add-to-cart, .swb-checkout-form button { background: var(--swb-color-primary, #007bff); color: white; padding: 0.5rem 1rem; border: none; border-radius: 8px; cursor: pointer; transition: background-color 0.2s ease; display: inline-flex; align-items: center; gap: 0.5rem; justify-content: center; } .swb-sort-button:hover, .swb-cart-button:hover, .swb-add-to-cart:hover, .swb-checkout-form button:hover { opacity: 0.8; } /* Common styles for form inputs */ .swb-search-input, .swb-sort-select, .swb-checkout-form input, .swb-checkout-form textarea { padding: 0.5rem 1rem; border: 1px solid #ddd; border-radius: 8px; font-size: 1rem; } .swb-search-input:focus, .swb-sort-select:focus, .swb-checkout-form input:focus, .swb-checkout-form textarea:focus { outline: none; border-color: var(--swb-color-primary, #007bff); box-shadow: 0 0 0 2px rgba(var(--swb-color-primary-rgb, 0, 123, 255), 0.2); } .swb-custom-field { display: grid; } /* Catalog Header */ .swb-catalog-header { display: flex; gap: 1rem; margin-bottom: 2rem; align-items: center; } .swb-catalog-header-control { display: flex; align-items: center; gap: 1rem; } .swb-search-input { flex: 1; width: 100%; } /* Sort Select */ .swb-sort-select { min-width: 200px; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23666666'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.75rem center; background-size: 1em; padding-right: 2.5rem; } /* Cart Button and Icon */ .swb-cart-button, .swb-cart-icon { position: relative; height: 2.5rem; } .swb-cart-button svg { width: 1.5rem; height: 1.5rem; } .swb-cart-button-floating { position: fixed !important; height: 2.5rem; width: 2.5rem; bottom: 1rem; right: 1rem; padding: 0.5rem; border-radius: 50%; z-index: 99; } .swb-cart-icon { background: var(--swb-color-primary, #007bff); position: fixed; bottom: 20px; right: 20px; padding: 10px; border-radius: 50%; z-index: 1000; color: white; cursor: pointer; } .swb-cart-icon:hover { opacity: 0.8; } .swb-cart-count { position: absolute; top: -8px; right: -8px; background: var(--swb-color-secondary, #dc3545); color: white; border-radius: 50%; font-size: 12px; display: flex; min-width: 24px; width: fit-content; height: 24px; align-items: center; justify-content: center; } /* Cart Modal */ .swb-cart-modal { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); z-index: 1001; } .swb-modal-content { position: relative; background: white; margin: 32px auto; width: 90%; max-width: 600px; border-radius: 12px; border: 1px solid #e5e5e5; } .swb-modal-close { position: absolute; right: 16px; top: 10px; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; font-size: 16px; cursor: pointer; border: none; background: none; z-index: 10; } .swb-cart-header { display: flex; justify-content: space-between; align-items: center; padding: 8px 16px; border-bottom: 1px solid #e5e5e5; } .swb-cart-header h2 { margin: 0; font-size: 18px; font-weight: 700; } .swb-cart-subheader { display: flex; justify-content: space-between; align-items: center; padding: 8px 16px; border-bottom: 1px solid #e5e5e5; } .swb-cart-subheader p { margin: 0; color: #666; font-size: 0.875rem; } .swb-clear-cart { color: var(--swb-color-primary, #007bff); border: none; cursor: pointer; font-size: 0.875rem; transition: color 0.2s ease; background: none; } .swb-clear-cart:hover { opacity: 0.8; } /* Cart Items */ .swb-cart-items { padding: 8px 16px; } .swb-cart-item { display: grid; grid-template-columns: 2fr 1fr 1fr auto; gap: 8px; align-items: center; padding: 8px 0; } .swb-item-quantity { display: flex; align-items: center; gap: 8px; } .swb-item-quantity button { width: 24px; height: 24px; padding: 0; background: var(--swb-color-primary, #007bff); color: white; border: none; border-radius: 50%; cursor: pointer; justify-content: center; align-items: center; display: flex; } .swb-item-quantity span { width: 24px; height: 24px; text-align: center; } .swb-remove-item { color: #dc3545; background: transparent; border-radius: 50%; width: 24px; height: 24px; cursor: pointer; transition: all 0.2s ease; display: flex; align-items: center; justify-content: center; padding: 0; } .swb-remove-item:hover { background: #dc3545; color: white; } .swb-cart-total { padding: 8px 16px; font-weight: bold; font-size: 18px; text-align: center; border-bottom: 1px solid #e5e5e5; border-top: 1px solid #e5e5e5; } /* Product Buttons */ .swb-external-link { background: transparent; color: var(--swb-color-primary, #007bff); padding: 0.5rem 1rem; border: 2px solid var(--swb-color-primary, #007bff); border-radius: 8px; cursor: pointer; transition: all 0.2s ease; display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none; justify-content: center; } .swb-external-link:hover { background: var(--swb-color-primary, #007bff); color: white; } [data-swb-product-buttons] { margin-top: 1rem; display: flex; gap: 0.5rem; flex-wrap: wrap; } [data-swb-product-buttons] > * { flex: 1; } [data-swb-product-buttons] .swb-add-to-cart { width: 100%; margin-top: 0; } /* Responsive Design */ @media (max-width: 640px) { .swb-catalog-header { flex-direction: column; } .swb-catalog-header-control, .swb-sort-select { width: 100%; } } .senangwebs-buy-products { display: grid; grid-template-columns: repeat(1, minmax(0, 1fr)); gap: 1rem; } .senangwebs-buy-products > [data-swb-product] { border-radius: 0.75rem; border: 1px solid #ddd; background-color: white; overflow: hidden; padding: 0.5rem; display: flex; flex-direction: column; gap: 0.5rem; } .senangwebs-buy-products > [data-swb-product] img { width: 100%; height: auto; display: block; border-radius: 0.5rem; } .senangwebs-buy-products [data-swb-product-details] { flex-grow: 1; display: flex; flex-direction: column; } .senangwebs-buy-products [data-swb-product-name] > h4 { font-size: 1.25rem; font-weight: bold; } .senangwebs-buy-products [data-swb-product-description] { flex-grow: 1; margin-bottom: 0.5rem; } .senangwebs-buy-products [data-swb-product-description] > * { opacity: 0.75; } .senangwebs-buy-products [data-swb-product-price] > p { font-weight: bold; margin-top: auto; } @media (min-width: 640px) { .senangwebs-buy-products { grid-template-columns: repeat(2, minmax(0, 1fr)); } } @media (min-width: 1024px) { .senangwebs-buy-products { grid-template-columns: repeat(3, minmax(0, 1fr)); } } @media (min-width: 1280px) { .senangwebs-buy-products { column-gap: 2rem; } }