From dab926d75fe64086c45477628c35745095ff20f5 Mon Sep 17 00:00:00 2001 From: david0xd Date: Wed, 11 Dec 2024 13:01:12 +0100 Subject: [PATCH] Add backgroundColor property to Container component Minor refactoring Update manifest shasum --- packages/snaps-sdk/src/jsx/components/Box.ts | 2 ++ packages/snaps-sdk/src/jsx/components/Container.test.tsx | 3 ++- packages/snaps-sdk/src/jsx/components/Container.ts | 9 ++++++++- packages/snaps-sdk/src/jsx/validation.test.tsx | 6 ++++++ packages/snaps-sdk/src/jsx/validation.ts | 3 +++ 5 files changed, 21 insertions(+), 2 deletions(-) diff --git a/packages/snaps-sdk/src/jsx/components/Box.ts b/packages/snaps-sdk/src/jsx/components/Box.ts index f9d1742268..44b8fc3e1d 100644 --- a/packages/snaps-sdk/src/jsx/components/Box.ts +++ b/packages/snaps-sdk/src/jsx/components/Box.ts @@ -8,6 +8,7 @@ import { createSnapComponent } from '../component'; * @property direction - The direction to stack the components within the box. Defaults to `vertical`. * @property alignment - The alignment mode to use within the box. Defaults to `start`. * @property center - Whether to center the children within the box. Defaults to `false`. + * @property backgroundColor - Whether the Box needs color adjustments. Defaults to undefined. */ export type BoxProps = { // We can't use `JSXElement` because it causes a circular reference. @@ -21,6 +22,7 @@ export type BoxProps = { | 'space-around' | undefined; center?: boolean | undefined; + backgroundColor?: string | undefined; }; const TYPE = 'Box'; diff --git a/packages/snaps-sdk/src/jsx/components/Container.test.tsx b/packages/snaps-sdk/src/jsx/components/Container.test.tsx index ad27289175..f8cf3ee651 100644 --- a/packages/snaps-sdk/src/jsx/components/Container.test.tsx +++ b/packages/snaps-sdk/src/jsx/components/Container.test.tsx @@ -7,7 +7,7 @@ import { Text } from './Text'; describe('Container', () => { it('renders a container element with a box', () => { const result = ( - + Hello world! @@ -18,6 +18,7 @@ describe('Container', () => { type: 'Container', key: null, props: { + backgroundColor: 'alternative', children: { type: 'Box', key: null, diff --git a/packages/snaps-sdk/src/jsx/components/Container.ts b/packages/snaps-sdk/src/jsx/components/Container.ts index 4277fcab54..6b2500663a 100644 --- a/packages/snaps-sdk/src/jsx/components/Container.ts +++ b/packages/snaps-sdk/src/jsx/components/Container.ts @@ -2,6 +2,11 @@ import type { GenericSnapElement } from '../component'; import { createSnapComponent } from '../component'; import type { FooterElement } from './Footer'; +/** + * Definition of container background colors. + */ +export type ContainerBackgroundColor = 'default' | 'alternative'; + /** * The props of the {@link Container} component. * @@ -9,6 +14,7 @@ import type { FooterElement } from './Footer'; */ export type ContainerProps = { children: [GenericSnapElement, FooterElement] | GenericSnapElement; + backgroundColor?: ContainerBackgroundColor | undefined; }; const TYPE = 'Container'; @@ -17,10 +23,11 @@ const TYPE = 'Container'; * A container component, which is used to create a container with a box and a footer. * * @param props - The props of the component. + * @param props.backgroundColor - The color of the background. * @param props.children - The Box and the Footer or the Box element. * @returns A container element. * @example - * + * * * Hello world! * diff --git a/packages/snaps-sdk/src/jsx/validation.test.tsx b/packages/snaps-sdk/src/jsx/validation.test.tsx index 60466eadbf..125210dba0 100644 --- a/packages/snaps-sdk/src/jsx/validation.test.tsx +++ b/packages/snaps-sdk/src/jsx/validation.test.tsx @@ -756,6 +756,12 @@ describe('ContainerStruct', () => { Hello world! , + + Hello world! + , + + Hello world! + , Hello world!