import { html, css } from '@design.estate/dees-element'; import '@design.estate/dees-wcctools/demotools'; import '../dees-panel.js'; import './dees-input-profilepicture.js'; import type { DeesInputProfilePicture } from './dees-input-profilepicture.js'; export const demoFunc = () => html`
{ // Basic demo with round profile picture const roundProfile = elementArg.querySelector('dees-input-profilepicture[shape="round"]'); if (roundProfile) { roundProfile.addEventListener('change', (event: CustomEvent) => { const target = event.target as DeesInputProfilePicture; console.log('Round profile picture changed:', target.value?.substring(0, 50) + '...'); }); } }}>
{ // Different sizes demo const profiles = elementArg.querySelectorAll('dees-input-profilepicture'); profiles.forEach((profile) => { profile.addEventListener('change', (event: CustomEvent) => { const target = event.target as DeesInputProfilePicture; console.log(`Profile (size ${target.size}) changed`); }); }); }}>
{ // Pre-filled profile with placeholder const sampleImageUrl = ''; const prefilledProfile = elementArg.querySelector('#prefilled-profile') as DeesInputProfilePicture; if (prefilledProfile) { prefilledProfile.value = sampleImageUrl; prefilledProfile.addEventListener('change', (event: CustomEvent) => { const target = event.target as DeesInputProfilePicture; const output = elementArg.querySelector('#prefilled-output'); if (output) { output.textContent = target.value ? `Image data: ${target.value.substring(0, 80)}...` : 'No image selected'; } }); } }}>
Image data will appear here when changed
{ // Disabled state demo const disabledProfile = elementArg.querySelector('#disabled-profile') as DeesInputProfilePicture; if (disabledProfile) { disabledProfile.value = ''; } }}>
  • Image Upload: Click to upload or drag & drop images
  • Image Cropping: Interactive crop tool with resize handles
  • Shape Support: Round or square profile pictures
  • Size Customization: Adjustable dimensions
  • Preview & Edit: Hover overlay with edit and delete options
  • File Validation: Format and size restrictions
  • Responsive Design: Works on desktop and mobile devices
  • Form Integration: Standard form value binding and validation
  • Accessibility: Keyboard navigation and screen reader support
  • Z-Index Management: Proper modal stacking with registry
Supported Formats: JPEG, PNG, WebP
Max File Size: 5MB (configurable)
Output Format: Base64 encoded JPEG
`;