File size: 2,498 Bytes
0ad74ed
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<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 size compared to adjacent Components. For example if Components A and B are in a Row, and A has scale=2, and B has scale=1, A will be twice as wide as B. Should be an integer. Only applies in Rows, or top-level Components in Blocks where fill_height=True. ",
			control: { type: "select" }
		}
	}}
/>

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

<Story
	name="Primary"
	args={{ variant: "primary", size: "lg", scale: 1, interactive: true }}
/>
<Story
	name="Secondary"
	args={{ variant: "secondary", size: "lg", interactive: true }}
/>
<Story name="Stop" args={{ variant: "stop", size: "lg", interactive: true }} />
<Story
	name="Button with link"
	args={{ link: "https://huggingface.co/welcome", interactive: true }}
/>
<Story
	name="Button with external image icon"
	args={{
		interactive: true,
		icon: {
			url: "https://huggingface.co/front/assets/huggingface_logo-noborder.svg",
			path: "https://huggingface.co/front/assets/huggingface_logo-noborder.svg"
		}
	}}
/>
<Story
	name="Button with external image icon and no text"
	args={{
		interactive: true,
		icon: {
			url: "https://huggingface.co/front/assets/huggingface_logo-noborder.svg",
			path: "https://huggingface.co/front/assets/huggingface_logo-noborder.svg"
		},
		value: ""
	}}
/>

<Story
	name="Button with visible equal to false"
	args={{
		visible: false
	}}
/>