File size: 1,940 Bytes
a03b3ba
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<script>
	import { Meta, Template, Story } from "@storybook/addon-svelte-csf";
	import Button from "./Index.svelte";
</script>

<Meta
	title="Components/Button"
	component={Button}
	argTypes={{
		label: {
			control: "text",
			description: "The text to display on the button",
			name: "label",
			value: "Gradio Button"
		},
		variant: {
			options: ["primary", "secondary", "stop"],
			description: "The variant of the button",
			control: { type: "select" },
			defaultValue: "primary"
		},
		size: {
			options: ["sm", "lg"],
			description: "The size of the button",
			control: { type: "select" },
			defaultValue: "lg"
		},
		visible: {
			options: [true, false],
			description: "Sets the visibility of the button",
			control: { type: "boolean" },
			defaultValue: true
		},
		interactive: {
			options: [true, false],
			description: "If false, the button will be in a disabled state",
			control: { type: "boolean" },
			defaultValue: true
		},
		disabled: {
			options: [true, false],
			control: { type: "boolean" },
			defaultValue: false
		},
		scale: {
			options: [null, 0.5, 1, 2],
			description:
				"relative width compared to adjacent Components in a Row. For example, if Component A has scale=2, and Component B has scale=1, A will be twice as wide as B. Should be an integer.",
			control: { type: "select" }
		}
	}}
/>

<Template let:args>
	<Button value="Gradio Button" {...args} />
</Template>

<Story name="Primary" args={{ variant: "primary", size: "lg", scale: 1 }} />
<Story name="Secondary" args={{ variant: "secondary", size: "lg" }} />
<Story name="Stop" args={{ variant: "stop", size: "lg" }} />
<Story
	name="Button with link"
	args={{ link: "https://huggingface.co/welcome" }}
/>
<Story
	name="Button with external image icon"
	args={{
		icon: "https://huggingface.co/front/assets/huggingface_logo-noborder.svg"
	}}
/>
<Story
	name="Button with visible equal to false"
	args={{
		visible: false
	}}
/>