update
This commit is contained in:
		| @@ -5,45 +5,63 @@ import './dees-form.js'; | ||||
| import './dees-form-submit.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; | ||||
|         } | ||||
|          | ||||
|         dees-panel { | ||||
|           margin-bottom: 24px; | ||||
|         } | ||||
|          | ||||
|         dees-panel:last-child { | ||||
|           margin-bottom: 0; | ||||
|         } | ||||
|          | ||||
|         .horizontal-group { | ||||
|           display: flex; | ||||
|           align-items: center; | ||||
|           gap: 16px; | ||||
|           flex-wrap: wrap; | ||||
|         } | ||||
|          | ||||
|         .spacer { | ||||
|           height: 200px; | ||||
|           display: flex; | ||||
|           align-items: center; | ||||
|           justify-content: center; | ||||
|           color: #999; | ||||
|           font-size: 14px; | ||||
|         } | ||||
|       `} | ||||
|     </style> | ||||
|      | ||||
|     <div class="demo-container"> | ||||
|   <style> | ||||
|     ${css` | ||||
|       .demo-container { | ||||
|         display: flex; | ||||
|         flex-direction: column; | ||||
|         gap: 24px; | ||||
|         padding: 24px; | ||||
|         max-width: 1200px; | ||||
|         margin: 0 auto; | ||||
|       } | ||||
|        | ||||
|       dees-panel { | ||||
|         margin-bottom: 24px; | ||||
|       } | ||||
|        | ||||
|       dees-panel:last-child { | ||||
|         margin-bottom: 0; | ||||
|       } | ||||
|        | ||||
|       .horizontal-group { | ||||
|         display: flex; | ||||
|         align-items: center; | ||||
|         gap: 16px; | ||||
|         flex-wrap: wrap; | ||||
|       } | ||||
|        | ||||
|       .spacer { | ||||
|         height: 200px; | ||||
|         display: flex; | ||||
|         align-items: center; | ||||
|         justify-content: center; | ||||
|         color: #999; | ||||
|         font-size: 14px; | ||||
|       } | ||||
|     `} | ||||
|   </style> | ||||
|    | ||||
|   <div class="demo-container"> | ||||
|     <dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => { | ||||
|       // Demonstrate programmatic interaction with basic dropdowns | ||||
|       const countryDropdown = elementArg.querySelector('dees-input-dropdown[label="Select Country"]'); | ||||
|       const roleDropdown = elementArg.querySelector('dees-input-dropdown[label="Select Role"]'); | ||||
|        | ||||
|       // Log when country changes | ||||
|       if (countryDropdown) { | ||||
|         countryDropdown.addEventListener('selectedOption', (event: CustomEvent) => { | ||||
|           console.log('Country selected:', event.detail); | ||||
|         }); | ||||
|       } | ||||
|        | ||||
|       // Log when role changes | ||||
|       if (roleDropdown) { | ||||
|         roleDropdown.addEventListener('selectedOption', (event: CustomEvent) => { | ||||
|           console.log('Role selected:', event.detail); | ||||
|         }); | ||||
|       } | ||||
|     }}> | ||||
|       <dees-panel .title=${'1. Basic Dropdowns'} .subtitle=${'Standard dropdown with search functionality and various options'}> | ||||
|         <dees-input-dropdown | ||||
|           .label=${'Select Country'} | ||||
| @@ -70,7 +88,18 @@ export const demoFunc = () => html` | ||||
|           ]} | ||||
|         ></dees-input-dropdown> | ||||
|       </dees-panel> | ||||
|     </dees-demowrapper> | ||||
|      | ||||
|     <dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => { | ||||
|       // Demonstrate simpler dropdown without search | ||||
|       const priorityDropdown = elementArg.querySelector('dees-input-dropdown'); | ||||
|        | ||||
|       if (priorityDropdown) { | ||||
|         priorityDropdown.addEventListener('selectedOption', (event: CustomEvent) => { | ||||
|           console.log(`Priority changed to: ${event.detail.option}`); | ||||
|         }); | ||||
|       } | ||||
|     }}> | ||||
|       <dees-panel .title=${'2. Without Search'} .subtitle=${'Dropdown with search functionality disabled for simpler selection'}> | ||||
|         <dees-input-dropdown | ||||
|           .label=${'Priority Level'} | ||||
| @@ -83,7 +112,20 @@ export const demoFunc = () => html` | ||||
|           .selectedOption=${{ option: 'Medium', key: 'medium' }} | ||||
|         ></dees-input-dropdown> | ||||
|       </dees-panel> | ||||
|     </dees-demowrapper> | ||||
|      | ||||
|     <dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => { | ||||
|       // Demonstrate horizontal layout with multiple dropdowns | ||||
|       const dropdowns = elementArg.querySelectorAll('dees-input-dropdown'); | ||||
|        | ||||
|       // Log all changes from horizontal dropdowns | ||||
|       dropdowns.forEach((dropdown) => { | ||||
|         dropdown.addEventListener('selectedOption', (event: CustomEvent) => { | ||||
|           const label = dropdown.getAttribute('label'); | ||||
|           console.log(`${label}: ${event.detail.option}`); | ||||
|         }); | ||||
|       }); | ||||
|     }}> | ||||
|       <dees-panel .title=${'3. Horizontal Layout'} .subtitle=${'Multiple dropdowns in a horizontal layout for compact forms'}> | ||||
|         <div class="horizontal-group"> | ||||
|           <dees-input-dropdown | ||||
| @@ -120,7 +162,19 @@ export const demoFunc = () => html` | ||||
|           ></dees-input-dropdown> | ||||
|         </div> | ||||
|       </dees-panel> | ||||
|     </dees-demowrapper> | ||||
|      | ||||
|     <dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => { | ||||
|       // Demonstrate state handling | ||||
|       const requiredDropdown = elementArg.querySelector('dees-input-dropdown[required]'); | ||||
|        | ||||
|       if (requiredDropdown) { | ||||
|         // Show validation state changes | ||||
|         requiredDropdown.addEventListener('blur', () => { | ||||
|           console.log('Required dropdown lost focus'); | ||||
|         }); | ||||
|       } | ||||
|     }}> | ||||
|       <dees-panel .title=${'4. States'} .subtitle=${'Different states and configurations'}> | ||||
|         <dees-input-dropdown | ||||
|           .label=${'Required Field'} | ||||
| @@ -141,11 +195,25 @@ export const demoFunc = () => html` | ||||
|           .selectedOption=${{ option: 'Cannot Select', key: 'disabled' }} | ||||
|         ></dees-input-dropdown> | ||||
|       </dees-panel> | ||||
|     </dees-demowrapper> | ||||
|      | ||||
|     <div class="spacer"> | ||||
|       (Spacer to test dropdown positioning) | ||||
|     </div> | ||||
|      | ||||
|     <dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => { | ||||
|       // This dropdown demonstrates automatic positioning | ||||
|       const dropdown = elementArg.querySelector('dees-input-dropdown'); | ||||
|        | ||||
|       <div class="spacer"> | ||||
|         (Spacer to test dropdown positioning) | ||||
|       </div> | ||||
|        | ||||
|       if (dropdown) { | ||||
|         dropdown.addEventListener('selectedOption', (event: CustomEvent) => { | ||||
|           console.log('Bottom dropdown selected:', event.detail); | ||||
|         }); | ||||
|          | ||||
|         // Note: The dropdown automatically detects available space | ||||
|         // and opens upward when near the bottom of the viewport | ||||
|       } | ||||
|     }}> | ||||
|       <dees-panel .title=${'5. Bottom Positioning'} .subtitle=${'Dropdown that opens upward when near bottom of viewport'}> | ||||
|         <dees-input-dropdown | ||||
|           .label=${'Opens Upward'} | ||||
| @@ -158,7 +226,30 @@ export const demoFunc = () => html` | ||||
|           ]} | ||||
|         ></dees-input-dropdown> | ||||
|       </dees-panel> | ||||
|     </dees-demowrapper> | ||||
|  | ||||
|     <dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => { | ||||
|       // Setup the interactive payload display | ||||
|       const dropdown = elementArg.querySelector('dees-input-dropdown'); | ||||
|       const output = elementArg.querySelector('#selection-output'); | ||||
|        | ||||
|       if (dropdown && output) { | ||||
|         // Initialize output | ||||
|         output.innerHTML = '<em>Select a product to see details...</em>'; | ||||
|          | ||||
|         // Handle dropdown changes | ||||
|         dropdown.addEventListener('change', (event: CustomEvent) => { | ||||
|           if (event.detail.value) { | ||||
|             output.innerHTML = ` | ||||
|               <strong>Selected:</strong> ${event.detail.value.option}<br> | ||||
|               <strong>Key:</strong> ${event.detail.value.key}<br> | ||||
|               <strong>Price:</strong> $${event.detail.value.payload?.price || 'N/A'}<br> | ||||
|               <strong>Features:</strong> ${event.detail.value.payload?.features?.join(', ') || 'N/A'} | ||||
|             `; | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     }}> | ||||
|       <dees-panel .title=${'6. Event Handling & Payload'} .subtitle=${'Dropdown with payload data and change event handling'}> | ||||
|         <dees-input-dropdown | ||||
|           .label=${'Select Product'} | ||||
| @@ -167,24 +258,35 @@ export const demoFunc = () => html` | ||||
|             { option: 'Pro Plan', key: 'pro', payload: { price: 19.99, features: ['Feature A', 'Feature B'] } }, | ||||
|             { option: 'Enterprise Plan', key: 'enterprise', payload: { price: 49.99, features: ['Feature A', 'Feature B', 'Feature C'] } } | ||||
|           ]} | ||||
|           @change=${(e: CustomEvent) => { | ||||
|             const output = document.querySelector('#selection-output'); | ||||
|             if (output && e.detail.value) { | ||||
|               output.innerHTML = ` | ||||
|                 <strong>Selected:</strong> ${e.detail.value.option}<br> | ||||
|                 <strong>Key:</strong> ${e.detail.value.key}<br> | ||||
|                 <strong>Price:</strong> $${e.detail.value.payload?.price || 'N/A'}<br> | ||||
|                 <strong>Features:</strong> ${e.detail.value.payload?.features?.join(', ') || 'N/A'} | ||||
|               `; | ||||
|             } | ||||
|           }} | ||||
|         ></dees-input-dropdown> | ||||
|          | ||||
|         <div id="selection-output" style="margin-top: 16px; padding: 12px; background: rgba(0, 105, 242, 0.1); border-radius: 4px; font-size: 14px;"> | ||||
|           <em>Select a product to see details...</em> | ||||
|         </div> | ||||
|         <div id="selection-output" style="margin-top: 16px; padding: 12px; background: rgba(0, 105, 242, 0.1); border-radius: 4px; font-size: 14px;"></div> | ||||
|       </dees-panel> | ||||
|     </dees-demowrapper> | ||||
|  | ||||
|     <dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => { | ||||
|       // Demonstrate form integration and validation | ||||
|       const form = elementArg.querySelector('dees-form'); | ||||
|       const projectTypeDropdown = elementArg.querySelector('dees-input-dropdown[key="projectType"]'); | ||||
|       const frameworkDropdown = elementArg.querySelector('dees-input-dropdown[key="framework"]'); | ||||
|        | ||||
|       if (form) { | ||||
|         form.addEventListener('formData', (event: CustomEvent) => { | ||||
|           console.log('Form submitted with data:', event.detail.data); | ||||
|         }); | ||||
|       } | ||||
|        | ||||
|       if (projectTypeDropdown && frameworkDropdown) { | ||||
|         // Filter frameworks based on project type | ||||
|         projectTypeDropdown.addEventListener('selectedOption', (event: CustomEvent) => { | ||||
|           const selectedType = event.detail.key; | ||||
|           console.log(`Project type changed to: ${selectedType}`); | ||||
|            | ||||
|           // In a real app, you could filter the framework options based on project type | ||||
|           // For demo purposes, we just log the change | ||||
|         }); | ||||
|       } | ||||
|     }}> | ||||
|       <dees-panel .title=${'7. Form Integration'} .subtitle=${'Dropdown working within a form with validation'}> | ||||
|         <dees-form> | ||||
|           <dees-input-dropdown | ||||
| @@ -216,6 +318,6 @@ export const demoFunc = () => html` | ||||
|           <dees-form-submit .text=${'Create Project'}></dees-form-submit> | ||||
|         </dees-form> | ||||
|       </dees-panel> | ||||
|     </div> | ||||
|   </dees-demowrapper> | ||||
|     </dees-demowrapper> | ||||
|   </div> | ||||
| ` | ||||
		Reference in New Issue
	
	Block a user