Gradio Button is a Svelte-based UI component library that provides versatile button functionality for Gradio applications. It offers comprehensive button capabilities with support for multiple variants, sizes, custom icons, link integration, and extensive styling options.
npm install @gradio/buttonimport Button from "@gradio/button";
import { BaseButton } from "@gradio/button";For standalone usage without Gradio integration:
import { BaseButton } from "@gradio/button";// Gradio-integrated button component
<script lang="ts">
import Button from "@gradio/button";
import type { Gradio } from "@gradio/utils";
export let gradio: Gradio<{ click: never }>;
</script>
<Button
value="Click me"
variant="primary"
size="lg"
{gradio}
on:click={() => console.log("Button clicked")}
/>
// Standalone button without Gradio integration
<script lang="ts">
import { BaseButton } from "@gradio/button";
</script>
<BaseButton
value="Standalone Button"
variant="secondary"
size="md"
on:click={() => console.log("BaseButton clicked")}
/>The @gradio/button package provides two main components:
<a>) when a URL is providedMain Gradio-integrated button component with automatic event dispatching.
/**
* Gradio-integrated button component
* @component Button (default export)
*/
interface ButtonProps {
/** HTML element ID */
elem_id?: string;
/** Array of CSS classes to apply */
elem_classes?: string[];
/** Controls button visibility */
visible?: boolean;
/** Button text content */
value: string | null;
/** Visual style variant */
variant?: "primary" | "secondary" | "stop";
/** Whether the button is interactive */
interactive: boolean;
/** Button size */
size?: "sm" | "lg";
/** Flex grow scale factor */
scale?: number | null;
/** Button icon */
icon?: FileData | null;
/** Link URL (renders as anchor if provided) */
link?: string | null;
/** Minimum width constraint */
min_width?: number | undefined;
/** Gradio integration object */
gradio: Gradio<{ click: never }>;
}Events:
click - Automatically dispatched through gradio.dispatch("click")Standalone button component without Gradio integration.
/**
* Standalone button component without Gradio integration
* @component BaseButton
*/
interface BaseButtonProps {
/** HTML element ID */
elem_id?: string;
/** Array of CSS classes to apply */
elem_classes?: string[];
/** Controls button visibility */
visible?: boolean;
/** Visual style variant */
variant?: "primary" | "secondary" | "stop" | "huggingface";
/** Button size */
size?: "sm" | "md" | "lg";
/** Button text content */
value?: string | null;
/** Link URL (renders as anchor if provided) */
link?: string | null;
/** Button icon */
icon?: FileData | null;
/** Whether the button is disabled */
disabled?: boolean;
/** Flex grow scale factor */
scale?: number | null;
/** Minimum width constraint */
min_width?: number | undefined;
}Events:
click - Standard Svelte click event forwarded via on:clickSlots:
type ButtonVariant = "primary" | "secondary" | "stop" | "huggingface";primary - Primary button styling with brand colorssecondary - Default secondary button stylingstop - Stop/cancel button styling with warning colorshuggingface - Hugging Face branded styling (BaseButton only)type ButtonSize = "sm" | "md" | "lg";sm - Small button with compact padding and textmd - Medium button (BaseButton only)lg - Large button (default size)When the link prop is provided, the button renders as an anchor element (<a>) instead of a button element:
<BaseButton
link="https://example.com"
value="Visit Site"
variant="primary"
/>
// Renders: <a href="https://example.com" rel="noopener noreferrer">Visit Site</a>Link Security:
rel="noopener noreferrer" for external linksaria-disabled attributeIcons are rendered using the Gradio Image component and support the FileData format:
interface FileData {
/** File path - required for FileData class implementation */
path: string;
/** File URL for web access */
url?: string;
/** Original file name */
orig_name?: string;
/** File size in bytes */
size?: number;
/** File blob object */
blob?: File;
/** Whether this is a streaming file */
is_stream?: boolean;
/** MIME type */
mime_type?: string;
/** Alt text for accessibility */
alt_text?: string;
/** Base64 encoded data */
b64?: string;
/** Type metadata */
readonly meta?: { _type: "gradio.FileData" };
}Icon Usage:
const iconData: FileData = {
path: "save-icon.svg",
url: "...",
mime_type: "image/svg+xml"
};
<BaseButton
value="Save"
icon={iconData}
variant="primary"
/>interface ScalingOptions {
/** Flex grow factor (null = no flex growth) */
scale: number | null;
/** Minimum width in pixels (with responsive calc) */
min_width: number | undefined;
}Scaling Behavior:
scale = null - No flex growth (default)scale = 0 - Width set to fit-contentscale > 0 - Flex grow with specified factormin_width - Generates min-width: calc(min(${min_width}px, 100%))interface Gradio<T extends Record<string, any> = Record<string, any>> {
/** Dispatch events to the Gradio framework */
dispatch<E extends keyof T>(event_name: E, data?: T[E]): void;
}
type GradioButtonEvents = {
click: never;
};Integration Usage:
// The gradio object automatically handles event dispatching
gradio.dispatch("click"); // Called automatically on button clickinterface ButtonState {
/** Whether button accepts interactions */
interactive: boolean; // Gradio Button only
/** Whether button is disabled */
disabled: boolean; // BaseButton only
/** Whether button is visible */
visible: boolean;
}State Effects:
disabled = true - Adds opacity, grayscale filter, prevents interactionsvisible = false - Hides button with display: noneinteractive = false - Same effect as disabled = true (Gradio Button)<script lang="ts">
import { BaseButton } from "@gradio/button";
function handleClick() {
console.log("Button was clicked!");
}
</script>
<BaseButton
value="Click Me"
variant="primary"
size="lg"
on:click={handleClick}
/><script lang="ts">
import { BaseButton } from "@gradio/button";
const saveIcon = {
path: "save.svg",
url: "...",
mime_type: "image/svg+xml"
};
</script>
<BaseButton
value="Save Document"
icon={saveIcon}
variant="primary"
size="md"
/><BaseButton
value="Learn More"
link="https://gradio.app/docs"
variant="secondary"
size="lg"
/><BaseButton
value="Flexible Button"
scale={1}
min_width={120}
variant="primary"
/><BaseButton value="Primary" variant="primary" />
<BaseButton value="Secondary" variant="secondary" />
<BaseButton value="Stop" variant="stop" />
<BaseButton value="Hugging Face" variant="huggingface" /><BaseButton
value="Cannot Click"
variant="primary"
disabled={true}
/><script lang="ts">
import Button from "@gradio/button";
import type { Gradio } from "@gradio/utils";
export let gradio: Gradio<{ click: never }>;
// Click events automatically dispatched to Gradio
</script>
<Button
value="Submit"
variant="primary"
size="lg"
interactive={true}
{gradio}
/>