import type { Dispatch } from '../../../types.js'; import type { Snippet } from 'svelte'; import type { HTMLButtonAttributes } from 'svelte/elements'; /** * IconButton component - Button specifically designed for icon-only content. * * @packageDocumentation * * @example * ```svelte * * * * * * * * * * * * * * * ``` */ interface IconButtonProps extends Omit { /** * Visual variant. */ variant?: 'default' | 'primary' | 'secondary' | 'destructive' | 'outline' | 'ghost'; /** * Size of the button. */ size?: 'sm' | 'md' | 'lg'; /** * Disabled state. */ disabled?: boolean; /** * Loading state. */ loading?: boolean; /** * Reducer action to dispatch on click. */ action?: Action; /** * Dispatch function from store. */ dispatch?: Dispatch; /** * Additional CSS classes. */ class?: string; /** * Icon content (must provide aria-label for accessibility). */ children: Snippet; } declare function $$render(): { props: IconButtonProps; exports: {}; bindings: ""; slots: {}; events: {}; }; declare class __sveltets_Render { props(): ReturnType>['props']; events(): ReturnType>['events']; slots(): ReturnType>['slots']; bindings(): ""; exports(): {}; } interface $$IsomorphicComponent { new (options: import('svelte').ComponentConstructorOptions['props']>>): import('svelte').SvelteComponent['props']>, ReturnType<__sveltets_Render['events']>, ReturnType<__sveltets_Render['slots']>> & { $$bindings?: ReturnType<__sveltets_Render['bindings']>; } & ReturnType<__sveltets_Render['exports']>; (internal: unknown, props: ReturnType<__sveltets_Render['props']> & {}): ReturnType<__sveltets_Render['exports']>; z_$$bindings?: ReturnType<__sveltets_Render['bindings']>; } declare const IconButton: $$IsomorphicComponent; type IconButton = InstanceType>; export default IconButton; //# sourceMappingURL=IconButton.svelte.d.ts.map