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
`;