208 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			208 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { html, css, cssManager } from '@design.estate/dees-element';
 | |
| import './dees-shopping-productcard.js';
 | |
| 
 | |
| export const demoFunc = () => html`
 | |
|   <dees-demowrapper>
 | |
|     <style>
 | |
|       ${css`
 | |
|         .demo-container {
 | |
|           display: flex;
 | |
|           flex-direction: column;
 | |
|           gap: 24px;
 | |
|           padding: 24px;
 | |
|           max-width: 1200px;
 | |
|           margin: 0 auto;
 | |
|         }
 | |
|         
 | |
|         .shopping-grid {
 | |
|           display: grid;
 | |
|           grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
 | |
|           gap: 20px;
 | |
|         }
 | |
| 
 | |
|         .cart-summary {
 | |
|           margin-top: 24px;
 | |
|           padding: 20px;
 | |
|           background: ${cssManager.bdTheme('hsl(210 40% 96.1%)', 'hsl(215 20.2% 16.8%)')};
 | |
|           border: 1px solid ${cssManager.bdTheme('hsl(214.3 31.8% 91.4%)', 'hsl(215 20.2% 21.8%)')};
 | |
|           border-radius: 8px;
 | |
|         }
 | |
| 
 | |
|         .cart-summary-title {
 | |
|           font-size: 18px;
 | |
|           font-weight: 600;
 | |
|           margin-bottom: 16px;
 | |
|           color: ${cssManager.bdTheme('hsl(0 0% 9%)', 'hsl(0 0% 95%)')};
 | |
|         }
 | |
| 
 | |
|         .cart-item {
 | |
|           display: flex;
 | |
|           justify-content: space-between;
 | |
|           align-items: center;
 | |
|           padding: 8px 0;
 | |
|           font-size: 14px;
 | |
|           color: ${cssManager.bdTheme('hsl(215.3 25% 26.7%)', 'hsl(217.9 10.6% 74.9%)')};
 | |
|         }
 | |
| 
 | |
|         .cart-total {
 | |
|           display: flex;
 | |
|           justify-content: space-between;
 | |
|           align-items: center;
 | |
|           padding-top: 16px;
 | |
|           margin-top: 16px;
 | |
|           border-top: 2px solid ${cssManager.bdTheme('hsl(0 0% 89.8%)', 'hsl(0 0% 14.9%)')};
 | |
|           font-size: 18px;
 | |
|           font-weight: 600;
 | |
|           color: ${cssManager.bdTheme('hsl(0 0% 9%)', 'hsl(0 0% 95%)')};
 | |
|         }
 | |
|       `}
 | |
|     </style>
 | |
|     
 | |
|     <div class="demo-container">
 | |
|       <dees-panel .title=${'Basic Quantity Selector'} .subtitle=${'Simple quantity input with increment/decrement buttons'}>
 | |
|         <dees-input-quantityselector
 | |
|           .label=${'Quantity'}
 | |
|           .description=${'Select the desired quantity'}
 | |
|           .value=${1}
 | |
|         ></dees-input-quantityselector>
 | |
|         
 | |
|         <dees-input-quantityselector
 | |
|           .label=${'Items in Cart'}
 | |
|           .description=${'Adjust the quantity of items'}
 | |
|           .value=${3}
 | |
|         ></dees-input-quantityselector>
 | |
|       </dees-panel>
 | |
|       
 | |
|       <dees-panel .title=${'Shopping Cart'} .subtitle=${'Modern e-commerce product cards with interactive quantity selectors'} .runAfterRender=${async (elementArg: HTMLElement) => {
 | |
|         const updateCartSummary = () => {
 | |
|           const card1 = elementArg.querySelector('#headphones-qty') as any;
 | |
|           const card2 = elementArg.querySelector('#mouse-qty') as any;
 | |
|           const card3 = elementArg.querySelector('#keyboard-qty') as any;
 | |
|           
 | |
|           const qty1 = card1?.quantity || 0;
 | |
|           const qty2 = card2?.quantity || 0;
 | |
|           const qty3 = card3?.quantity || 0;
 | |
|           
 | |
|           const price1 = 349.99 * qty1;
 | |
|           const price2 = 99.99 * qty2;
 | |
|           const price3 = 79.99 * qty3;
 | |
|           const total = price1 + price2 + price3;
 | |
|           
 | |
|           const summary = elementArg.querySelector('#cart-summary-content');
 | |
|           if (summary) {
 | |
|             summary.innerHTML = `
 | |
|               ${qty1 > 0 ? `<div class="cart-item">
 | |
|                 <span>Sony WH-1000XM5 (${qty1})</span>
 | |
|                 <span>$${price1.toFixed(2)}</span>
 | |
|               </div>` : ''}
 | |
|               ${qty2 > 0 ? `<div class="cart-item">
 | |
|                 <span>Logitech MX Master 3S (${qty2})</span>
 | |
|                 <span>$${price2.toFixed(2)}</span>
 | |
|               </div>` : ''}
 | |
|               ${qty3 > 0 ? `<div class="cart-item">
 | |
|                 <span>Keychron K2 (${qty3})</span>
 | |
|                 <span>$${price3.toFixed(2)}</span>
 | |
|               </div>` : ''}
 | |
|               ${total === 0 ? '<div class="cart-item" style="text-align: center; color: #999;">Your cart is empty</div>' : ''}
 | |
|               <div class="cart-total">
 | |
|                 <span>Total</span>
 | |
|                 <span>$${total.toFixed(2)}</span>
 | |
|               </div>
 | |
|             `;
 | |
|           }
 | |
|         };
 | |
|         
 | |
|         // Initial update
 | |
|         setTimeout(updateCartSummary, 100);
 | |
|         
 | |
|         // Set up listeners
 | |
|         elementArg.querySelectorAll('dees-shopping-productcard').forEach(card => {
 | |
|           card.addEventListener('quantityChange', updateCartSummary);
 | |
|         });
 | |
|       }}>
 | |
|         <div class="shopping-grid">
 | |
|           <dees-shopping-productcard
 | |
|             id="headphones-qty"
 | |
|             .productData=${{
 | |
|               name: 'Sony WH-1000XM5 Wireless Headphones',
 | |
|               category: 'Audio',
 | |
|               description: 'Industry-leading noise canceling with Auto NC Optimizer',
 | |
|               price: 349.99,
 | |
|               originalPrice: 399.99,
 | |
|               iconName: 'lucide:headphones'
 | |
|             }}
 | |
|             .quantity=${1}
 | |
|           ></dees-shopping-productcard>
 | |
|           
 | |
|           <dees-shopping-productcard
 | |
|             id="mouse-qty"
 | |
|             .productData=${{
 | |
|               name: 'Logitech MX Master 3S',
 | |
|               category: 'Accessories',
 | |
|               description: 'Performance wireless mouse with ultra-fast scrolling',
 | |
|               price: 99.99,
 | |
|               iconName: 'lucide:mouse-pointer'
 | |
|             }}
 | |
|             .quantity=${2}
 | |
|           ></dees-shopping-productcard>
 | |
|           
 | |
|           <dees-shopping-productcard
 | |
|             id="keyboard-qty"
 | |
|             .productData=${{
 | |
|               name: 'Keychron K2 Wireless Mechanical Keyboard',
 | |
|               category: 'Keyboards',
 | |
|               description: 'Compact 75% layout with hot-swappable switches',
 | |
|               price: 79.99,
 | |
|               originalPrice: 94.99,
 | |
|               iconName: 'lucide:keyboard'
 | |
|             }}
 | |
|             .quantity=${1}
 | |
|           ></dees-shopping-productcard>
 | |
|         </div>
 | |
| 
 | |
|         <div class="cart-summary">
 | |
|           <h3 class="cart-summary-title">Order Summary</h3>
 | |
|           <div id="cart-summary-content">
 | |
|             <!-- Content will be dynamically updated -->
 | |
|           </div>
 | |
|         </div>
 | |
|       </dees-panel>
 | |
|       
 | |
|       <dees-panel .title=${'Required & Disabled States'} .subtitle=${'Different states for validation and restrictions'}>
 | |
|         <dees-input-quantityselector
 | |
|           .label=${'Number of Licenses'}
 | |
|           .description=${'Select how many licenses you need'}
 | |
|           .required=${true}
 | |
|           .value=${1}
 | |
|         ></dees-input-quantityselector>
 | |
|         
 | |
|         <dees-input-quantityselector
 | |
|           .label=${'Fixed Quantity'}
 | |
|           .description=${'This quantity cannot be changed'}
 | |
|           .disabled=${true}
 | |
|           .value=${5}
 | |
|         ></dees-input-quantityselector>
 | |
|       </dees-panel>
 | |
|       
 | |
|       <dees-panel .title=${'Order Form'} .subtitle=${'Complete order form with quantity selection'}>
 | |
|         <dees-form>
 | |
|           <dees-input-text .label=${'Customer Name'} .required=${true}></dees-input-text>
 | |
|           <dees-input-dropdown
 | |
|             .label=${'Product'}
 | |
|             .options=${['Basic Plan', 'Pro Plan', 'Enterprise Plan']}
 | |
|             .required=${true}
 | |
|           ></dees-input-dropdown>
 | |
|           <dees-input-quantityselector
 | |
|             .label=${'Quantity'}
 | |
|             .description=${'Number of licenses'}
 | |
|             .value=${1}
 | |
|           ></dees-input-quantityselector>
 | |
|           <dees-input-text
 | |
|             .label=${'Special Instructions'}
 | |
|             .inputType=${'textarea'}
 | |
|           ></dees-input-text>
 | |
|         </dees-form>
 | |
|       </dees-panel>
 | |
|     </div>
 | |
|   </dees-demowrapper>
 | |
| `; |