diff --git a/src/components/Dimmer/Dimmer.props.ts b/src/components/Dimmer/Dimmer.props.ts new file mode 100644 index 00000000..c95fc69e --- /dev/null +++ b/src/components/Dimmer/Dimmer.props.ts @@ -0,0 +1,5 @@ +import { DimmerConfig } from './Dimmer.styles'; + +export type DimmerProps = { + custom?: DimmerConfig; +}; diff --git a/src/components/Dimmer/Dimmer.stories.tsx b/src/components/Dimmer/Dimmer.stories.tsx new file mode 100644 index 00000000..78179c19 --- /dev/null +++ b/src/components/Dimmer/Dimmer.stories.tsx @@ -0,0 +1,98 @@ +import type { Meta, StoryObj } from '@storybook/react'; + +import { Dimmer } from './Dimmer'; +import { Badge } from '../Badge'; +import { Card } from '../Card'; + +import { DimmerDocs } from '@/docs-components/DimmerDocs'; +import { TetDocs } from '@/docs-components/TetDocs'; +import { tet } from '@/tetrisly'; + +const meta = { + title: 'Dimmer', + component: Dimmer, + tags: ['autodocs'], + args: {}, + parameters: { + backgrounds: {}, + docs: { + description: { + component: + 'An overlay that darkens the background content to focus the users attention on another specific element or interaction, such as a Modal or Side Panel.', + }, + page: () => ( + + + + ), + }, + }, +} satisfies Meta; + +export default meta; +type Story = StoryObj; + +export const Default: Story = { + args: {}, +}; + +export const WithCardComponent: Story = { + render: () => ( + <> + + + + + + + + Task: + + + Creating React components + + + + + + Created + + + Mon, 14 Feb 2023 + + + + + Last modified + + + Today, 5:23 am + + + + + + + + ), +}; diff --git a/src/components/Dimmer/Dimmer.styles.ts b/src/components/Dimmer/Dimmer.styles.ts new file mode 100644 index 00000000..ff470cef --- /dev/null +++ b/src/components/Dimmer/Dimmer.styles.ts @@ -0,0 +1,17 @@ +import type { BaseProps } from '@/types/BaseProps'; + +export type DimmerConfig = BaseProps; + +export const defaultConfig = { + w: '100%', + h: '100%', + backgroundColor: '$color-interaction-background-dimmer', + top: 0, + left: 0, + position: 'absolute', + zIndex: 3, +} satisfies DimmerConfig; + +export const dimmerStyles = { + defaultConfig, +}; diff --git a/src/components/Dimmer/Dimmer.test.tsx b/src/components/Dimmer/Dimmer.test.tsx new file mode 100644 index 00000000..1fd9ed78 --- /dev/null +++ b/src/components/Dimmer/Dimmer.test.tsx @@ -0,0 +1,19 @@ +import { Dimmer } from './Dimmer'; +import { render } from '../../tests/render'; + +const getDimmer = (jsx: JSX.Element) => { + const { getByTestId } = render(jsx); + return getByTestId('dimmer'); +}; + +describe('Dimmer', () => { + it('should render the dimmer', () => { + const dimmer = getDimmer(); + expect(dimmer).toBeInTheDocument(); + }); + + it('should render correct color', () => { + const dimmer = getDimmer(); + expect(dimmer).toHaveStyle('background-color: rgba(25, 39, 58, 0.741)'); + }); +}); diff --git a/src/components/Dimmer/Dimmer.tsx b/src/components/Dimmer/Dimmer.tsx new file mode 100644 index 00000000..71a389f3 --- /dev/null +++ b/src/components/Dimmer/Dimmer.tsx @@ -0,0 +1,16 @@ +import { type FC, useMemo } from 'react'; + +import type { DimmerProps } from './Dimmer.props'; +import { stylesBuilder } from './stylesBuilder'; + +import { tet } from '@/tetrisly'; +import type { MarginProps } from '@/types'; + +export const Dimmer: FC = ({ + custom, + ...restProps +}) => { + const styles = useMemo(() => stylesBuilder({ custom }), [custom]); + + return ; +}; diff --git a/src/components/Dimmer/index.ts b/src/components/Dimmer/index.ts new file mode 100644 index 00000000..1e412629 --- /dev/null +++ b/src/components/Dimmer/index.ts @@ -0,0 +1,3 @@ +export { Dimmer } from './Dimmer'; +export type { DimmerProps } from './Dimmer.props'; +export { dimmerStyles } from './Dimmer.styles'; diff --git a/src/components/Dimmer/stylesBuilder.ts b/src/components/Dimmer/stylesBuilder.ts new file mode 100644 index 00000000..6dc2bb9d --- /dev/null +++ b/src/components/Dimmer/stylesBuilder.ts @@ -0,0 +1,27 @@ +import { DimmerProps } from './Dimmer.props'; +import { defaultConfig } from './Dimmer.styles'; + +import { mergeConfigWithCustom } from '@/services'; +import { BaseProps } from '@/types/BaseProps'; + +type StylesBuilderParams = { + custom: DimmerProps['custom']; +}; + +type DimmerStylesBuilder = { + container: BaseProps; +}; + +export const stylesBuilder = ({ + custom, +}: StylesBuilderParams): DimmerStylesBuilder => { + const config = mergeConfigWithCustom({ defaultConfig, custom }); + + const { ...restStyles } = config; + + return { + container: { + ...restStyles, + }, + }; +}; diff --git a/src/components/Dimmer/types/index.ts b/src/components/Dimmer/types/index.ts new file mode 100644 index 00000000..fd74e7a6 --- /dev/null +++ b/src/components/Dimmer/types/index.ts @@ -0,0 +1 @@ +export type { StatusDotAppearance } from './StatusDotAppearance.type'; diff --git a/src/docs-components/DimmerDocs.tsx b/src/docs-components/DimmerDocs.tsx new file mode 100644 index 00000000..1801dee2 --- /dev/null +++ b/src/docs-components/DimmerDocs.tsx @@ -0,0 +1,14 @@ +import { Dimmer } from '@/components/Dimmer/Dimmer'; +import { tet } from '@/tetrisly'; + +export const DimmerDocs = () => ( + + + + + + + + + +); diff --git a/src/index.ts b/src/index.ts index fcc44c65..77bb95d1 100644 --- a/src/index.ts +++ b/src/index.ts @@ -7,6 +7,7 @@ export * from './components/Checkbox'; export * from './components/CheckboxGroup'; export * from './components/CornerDialog'; export * from './components/Counter'; +export * from './components/Dimmer'; export * from './components/Divider'; export * from './components/FileItem'; export * from './components/HelperText';