356 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			356 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { html, css, cssManager } from '@design.estate/dees-element';
 | |
| import { DeesModal } from './dees-modal.js';
 | |
| 
 | |
| export const demoFunc = () => html`
 | |
|   <style>
 | |
|     ${css`
 | |
|       .demo-container {
 | |
|         display: flex;
 | |
|         flex-direction: column;
 | |
|         gap: 24px;
 | |
|         padding: 24px;
 | |
|         max-width: 1200px;
 | |
|         margin: 0 auto;
 | |
|       }
 | |
|       
 | |
|       .demo-section {
 | |
|         background: ${cssManager.bdTheme('#f8f9fa', '#1a1a1a')};
 | |
|         border-radius: 8px;
 | |
|         padding: 24px;
 | |
|         border: 1px solid ${cssManager.bdTheme('#e0e0e0', '#333')};
 | |
|       }
 | |
|       
 | |
|       .demo-section h3 {
 | |
|         margin-top: 0;
 | |
|         margin-bottom: 16px;
 | |
|         color: ${cssManager.bdTheme('#333', '#fff')};
 | |
|       }
 | |
|       
 | |
|       .demo-section p {
 | |
|         color: ${cssManager.bdTheme('#666', '#999')};
 | |
|         margin-bottom: 16px;
 | |
|       }
 | |
|       
 | |
|       .button-grid {
 | |
|         display: grid;
 | |
|         grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
 | |
|         gap: 16px;
 | |
|       }
 | |
|     `}
 | |
|   </style>
 | |
|   
 | |
|   <div class="demo-container">
 | |
|     <div class="demo-section">
 | |
|       <h3>Header Buttons</h3>
 | |
|       <p>Modals can have optional header buttons for help and closing.</p>
 | |
|       <div class="button-grid">
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'With Help Button',
 | |
|             showHelpButton: true,
 | |
|             onHelp: async () => {
 | |
|               const helpModal = await DeesModal.createAndShow({
 | |
|                 heading: 'Help',
 | |
|                 width: 'small',
 | |
|                 showCloseButton: true,
 | |
|                 showHelpButton: false,
 | |
|                 content: html`
 | |
|                   <p>This is the help content for the modal.</p>
 | |
|                   <p>You can provide context-specific help here.</p>
 | |
|                 `,
 | |
|                 menuOptions: [{
 | |
|                   name: 'Got it',
 | |
|                   action: async (modal) => modal.destroy()
 | |
|                 }],
 | |
|               });
 | |
|             },
 | |
|             content: html`
 | |
|               <p>This modal has a help button in the header. Click it to see help content.</p>
 | |
|               <p>The close button is also visible by default.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'OK',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>With Help Button</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'No Close Button',
 | |
|             showCloseButton: false,
 | |
|             content: html`
 | |
|               <p>This modal has no close button in the header.</p>
 | |
|               <p>You must use the action buttons or click outside to close it.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Close',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>No Close Button</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Both Buttons',
 | |
|             showHelpButton: true,
 | |
|             showCloseButton: true,
 | |
|             onHelp: () => alert('Help clicked!'),
 | |
|             content: html`
 | |
|               <p>This modal has both help and close buttons.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Done',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Both Buttons</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Clean Header',
 | |
|             showCloseButton: false,
 | |
|             showHelpButton: false,
 | |
|             content: html`
 | |
|               <p>This modal has a clean header with no buttons.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Close',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Clean Header</dees-button>
 | |
|       </div>
 | |
|     </div>
 | |
|     
 | |
|     <div class="demo-section">
 | |
|       <h3>Modal Width Variations</h3>
 | |
|       <p>Modals can have different widths: small, medium, large, fullscreen, or custom pixel values.</p>
 | |
|       <div class="button-grid">
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Small Modal',
 | |
|             width: 'small',
 | |
|             content: html`
 | |
|               <p>This is a small modal with a width of 380px. Perfect for simple confirmations or brief messages.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Cancel',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }, {
 | |
|               name: 'OK',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Small Modal</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Medium Modal (Default)',
 | |
|             width: 'medium',
 | |
|             content: html`
 | |
|               <dees-form>
 | |
|                 <dees-input-text .label=${'Username'}></dees-input-text>
 | |
|                 <dees-input-text .label=${'Email'} .inputType=${'email'}></dees-input-text>
 | |
|                 <dees-input-text .label=${'Password'} .inputType=${'password'}></dees-input-text>
 | |
|               </dees-form>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Cancel',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }, {
 | |
|               name: 'Sign Up',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Medium Modal</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Large Modal',
 | |
|             width: 'large',
 | |
|             content: html`
 | |
|               <h4>Wide Content Area</h4>
 | |
|               <p>This large modal is 800px wide and perfect for displaying more complex content like forms with multiple columns, tables, or detailed information.</p>
 | |
|               <div style="display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 16px;">
 | |
|                 <dees-input-text .label=${'First Name'}></dees-input-text>
 | |
|                 <dees-input-text .label=${'Last Name'}></dees-input-text>
 | |
|                 <dees-input-text .label=${'Company'}></dees-input-text>
 | |
|                 <dees-input-text .label=${'Position'}></dees-input-text>
 | |
|               </div>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Cancel',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }, {
 | |
|               name: 'Save',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Large Modal</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Fullscreen Editor',
 | |
|             width: 'fullscreen',
 | |
|             showHelpButton: true,
 | |
|             onHelp: async () => {
 | |
|               alert('In a real app, this would show editor documentation');
 | |
|             },
 | |
|             content: html`
 | |
|               <h4>Fullscreen Experience with Header Controls</h4>
 | |
|               <p>This modal takes up almost the entire viewport with a 20px margin on all sides. The header buttons are particularly useful in fullscreen mode.</p>
 | |
|               <p>The content area can be as tall as needed and will scroll if necessary.</p>
 | |
|               <div style="height: 200px; background: ${cssManager.bdTheme('#f0f0f0', '#2a2a2a')}; border-radius: 8px; display: flex; align-items: center; justify-content: center; margin-top: 16px;">
 | |
|                 <span style="color: ${cssManager.bdTheme('#999', '#666')}">Large content area</span>
 | |
|               </div>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Save',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }, {
 | |
|               name: 'Cancel',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Fullscreen Modal</dees-button>
 | |
|       </div>
 | |
|     </div>
 | |
|     
 | |
|     <div class="demo-section">
 | |
|       <h3>Custom Width & Constraints</h3>
 | |
|       <p>You can also set custom pixel widths and min/max constraints.</p>
 | |
|       <div class="button-grid">
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Custom Width (700px)',
 | |
|             width: 700,
 | |
|             content: html`
 | |
|               <p>This modal has a custom width of exactly 700 pixels.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Close',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Custom 700px</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'With Max Width',
 | |
|             width: 'large',
 | |
|             maxWidth: 600,
 | |
|             content: html`
 | |
|               <p>This modal is set to 'large' but constrained by a maxWidth of 600px.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Got it',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Max Width 600px</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'With Min Width',
 | |
|             width: 300,
 | |
|             minWidth: 400,
 | |
|             content: html`
 | |
|               <p>This modal width is set to 300px but has a minWidth of 400px, so it will be 400px wide.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'OK',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Min Width 400px</dees-button>
 | |
|       </div>
 | |
|     </div>
 | |
|     
 | |
|     <div class="demo-section">
 | |
|       <h3>Button Variations</h3>
 | |
|       <p>Modals can have different button configurations with proper spacing.</p>
 | |
|       <div class="button-grid">
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Multiple Actions',
 | |
|             content: html`
 | |
|               <p>This modal demonstrates multiple buttons with proper spacing between them.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Delete',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }, {
 | |
|               name: 'Cancel',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }, {
 | |
|               name: 'Save Changes',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Three Buttons</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Single Action',
 | |
|             content: html`
 | |
|               <p>Sometimes you just need one button.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Acknowledge',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Single Button</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'No Actions',
 | |
|             content: html`
 | |
|               <p>This modal has no bottom buttons. Use the X button or click outside to close.</p>
 | |
|               <p style="margin-top: 16px; color: ${cssManager.bdTheme('#666', '#999')};">This is useful for informational modals that don't require user action.</p>
 | |
|             `,
 | |
|             menuOptions: [],
 | |
|           });
 | |
|         }}>No Buttons</dees-button>
 | |
|         
 | |
|         <dees-button @click=${() => {
 | |
|           DeesModal.createAndShow({
 | |
|             heading: 'Long Button Labels',
 | |
|             content: html`
 | |
|               <p>Testing button layout with longer labels.</p>
 | |
|             `,
 | |
|             menuOptions: [{
 | |
|               name: 'Discard All Changes',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }, {
 | |
|               name: 'Save and Continue Editing',
 | |
|               action: async (modal) => modal.destroy()
 | |
|             }],
 | |
|           });
 | |
|         }}>Long Labels</dees-button>
 | |
|       </div>
 | |
|     </div>
 | |
|     
 | |
|     <div class="demo-section">
 | |
|       <h3>Responsive Behavior</h3>
 | |
|       <p>All modals automatically become full-width on mobile devices (< 768px viewport width) for better usability.</p>
 | |
|       <dees-button @click=${() => {
 | |
|         DeesModal.createAndShow({
 | |
|           heading: 'Responsive Modal',
 | |
|           width: 'large',
 | |
|           showHelpButton: true,
 | |
|           onHelp: () => console.log('Help requested for responsive modal'),
 | |
|           content: html`
 | |
|             <p>Resize your browser window to see how this modal adapts. On mobile viewports, it will automatically take the full width minus margins.</p>
 | |
|             <p>The header buttons remain accessible at all viewport sizes.</p>
 | |
|           `,
 | |
|           menuOptions: [{
 | |
|             name: 'Close',
 | |
|             action: async (modal) => modal.destroy()
 | |
|           }],
 | |
|         });
 | |
|       }}>Test Responsive</dees-button>
 | |
|     </div>
 | |
|   </div>
 | |
| ` |