vueless
Version:
Vue Styleless UI Component Library, powered by Tailwind CSS.
101 lines (82 loc) • 1.52 kB
text/typescript
import defaultConfig from "./config.ts";
import type { ComponentConfig } from "../types.ts";
export type Config = typeof defaultConfig;
export interface Props {
/**
* Button variant.
*/
variant?: "solid" | "outlined" | "subtle" | "soft" | "ghost";
/**
* Button color.
*/
color?:
| "primary"
| "secondary"
| "error"
| "warning"
| "success"
| "info"
| "notice"
| "neutral"
| "grayscale";
/**
* Button size.
*/
size?: "2xs" | "xs" | "sm" | "md" | "lg" | "xl";
/**
* Button label.
*/
label?: string;
/**
* Allows changing button html tag.
*/
tag?: string;
/**
* Icon name (appears instead of the label).
*/
icon?: string;
/**
* Left icon name.
*/
leftIcon?: string;
/**
* Right icon name.
*/
rightIcon?: string;
/**
* Controls the keyboard “Tab” focus order of elements.
*/
tabindex?: string | number;
/**
* Disable the button.
*/
disabled?: boolean;
/**
* Make the Button expand to fill the entire width of its container.
*/
block?: boolean;
/**
* Set button corners rounded.
*/
round?: boolean;
/**
* Set the same paddings for the button.
*/
square?: boolean;
/**
* Enable loader.
*/
loading?: boolean;
/**
* Unique element id.
*/
id?: string;
/**
* Component config object.
*/
config?: ComponentConfig<Config>;
/**
* Data-test attribute for automated testing.
*/
dataTest?: string | null;
}