import { defineWebComponent } from './define';
import { FileUpload, FileUploadTrigger } from '../components/file-upload';
import { Upload } from 'lucide-solid';

interface Props extends Record<string, unknown> {
  /** Allow selecting multiple files (default true). */
  multiple?: boolean;
  /** `accept` attribute for the file picker (e.g. `image/*`). */
  accept?: string;
  /** Disable the dropzone — no clicking, no drag-and-drop. */
  disabled?: boolean;
  /** Default dropzone label (overridable via the default slot). */
  label?: string;
}

/** Events fired by `<kc-file-upload>`. */
interface Events {
  /** Files were picked or dropped. */
  'kc-files-added': { files: File[] };
}

/**
 * `<kc-file-upload>` — a click/drag-drop dropzone. Emits `filesadded`. The
 * default dropzone label can be replaced with your own markup via the default
 * `<slot>` (a "Route 2" custom-content slot).
 */
defineWebComponent<Props, Events>('kc-file-upload', {
  multiple: true,
  accept: undefined,
  disabled: false,
  label: 'Click or drop files to upload',
}, (props, { dispatch, flag }) => (
  <FileUpload
    multiple={flag('multiple')}
    accept={props.accept}
    disabled={flag('disabled')}
    onFilesAdded={(files) => dispatch('kc-files-added', { files })}
  >
    <FileUploadTrigger class="border-border bg-muted/30 hover:bg-muted/60 text-muted-foreground flex w-full cursor-pointer flex-col items-center justify-center gap-2 rounded-xl border border-dashed px-6 py-8 text-sm transition-colors">
      <Upload class="size-5" />
      <slot>{props.label}</slot>
    </FileUploadTrigger>
  </FileUpload>
));
