Skip to content

Commit

Permalink
Add loading variant for Snaps UI Button
Browse files Browse the repository at this point in the history
Update manifest shasum

Add loading variant to old button
  • Loading branch information
david0xd committed Dec 9, 2024
1 parent 9d8915b commit 86c7aef
Show file tree
Hide file tree
Showing 6 changed files with 13 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
"url": "https://github.com/MetaMask/snaps.git"
},
"source": {
"shasum": "d1js9Y4zJwk7n/e47V5fdMreo1FBtVKl4GtPhfckZrs=",
"shasum": "w8ZPchwG+LqlFzbmkqVQ5nDqt5GDFkZsU8dUm1b5NXo=",
"location": {
"npm": {
"filePath": "dist/bundle.js",
Expand Down
2 changes: 1 addition & 1 deletion packages/snaps-sdk/src/jsx/components/form/Button.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ export type ButtonProps = {
children: SnapsChildren<StringElement | IconElement | ImageElement>;
name?: string | undefined;
type?: 'button' | 'submit' | undefined;
variant?: 'primary' | 'destructive' | undefined;
variant?: 'primary' | 'destructive' | 'loading' | undefined;
disabled?: boolean | undefined;
form?: string | undefined;
};
Expand Down
1 change: 1 addition & 0 deletions packages/snaps-sdk/src/jsx/validation.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,7 @@ describe('ButtonStruct', () => {
<Button name="foo">bar</Button>,
<Button type="submit">foo</Button>,
<Button variant="destructive">foo</Button>,
<Button variant="loading">foo</Button>,
<Button disabled={true}>foo</Button>,
<Button key="button">foo</Button>,
<Button>
Expand Down
4 changes: 3 additions & 1 deletion packages/snaps-sdk/src/jsx/validation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -243,7 +243,9 @@ export const ButtonStruct: Describe<ButtonElement> = element('Button', {
children: children([StringElementStruct, ImageStruct, IconStruct]),
name: optional(string()),
type: optional(nullUnion([literal('button'), literal('submit')])),
variant: optional(nullUnion([literal('primary'), literal('destructive')])),
variant: optional(
nullUnion([literal('primary'), literal('destructive'), literal('loading')]),
),
disabled: optional(boolean()),
form: optional(string()),
});
Expand Down
2 changes: 2 additions & 0 deletions packages/snaps-sdk/src/ui/components/button.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import { LiteralStruct, NodeType } from '../nodes';
export enum ButtonVariant {
Primary = 'primary',
Secondary = 'secondary',
Loading = 'loading',
}

export enum ButtonType {
Expand All @@ -31,6 +32,7 @@ export const ButtonStruct = assign(
union([
enumValue(ButtonVariant.Primary),
enumValue(ButtonVariant.Secondary),
enumValue(ButtonVariant.Loading),
]),
),
buttonType: optional(
Expand Down
6 changes: 5 additions & 1 deletion packages/snaps-utils/src/ui.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -51,12 +51,16 @@ const ALLOWED_PROTOCOLS = ['https:', 'mailto:', 'metamask:'];
* @param variant - The legacy button component variant.
* @returns The button variant.
*/
function getButtonVariant(variant?: 'primary' | 'secondary' | undefined) {
function getButtonVariant(
variant?: 'primary' | 'secondary' | 'loading' | undefined,
) {
switch (variant) {
case 'primary':
return 'primary';
case 'secondary':
return 'destructive';
case 'loading':
return 'loading';
default:
return undefined;
}
Expand Down

0 comments on commit 86c7aef

Please sign in to comment.