Skip to content

Commit

Permalink
feat: Refactor inverseColor stories (#1179)
Browse files Browse the repository at this point in the history
Co-authored-by: Vincent Smedinga <[email protected]>
  • Loading branch information
dlnr and VincentSmedinga authored Apr 12, 2024
1 parent 1f4e4bf commit 104ee42
Show file tree
Hide file tree
Showing 8 changed files with 31 additions and 97 deletions.
19 changes: 3 additions & 16 deletions storybook/src/components/Blockquote/Blockquote.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

import { Blockquote } from '@amsterdam/design-system-react/src'
import { Meta, StoryObj } from '@storybook/react'
import { inverseColorDecorator } from '../shared/decorators'
import { exampleQuote } from '../shared/exampleContent'

const quote = exampleQuote()
Expand All @@ -21,31 +22,17 @@ const meta = {
table: { disable: false },
},
},
decorators: [inverseColorDecorator],
} satisfies Meta<typeof Blockquote>

export default meta

type Story = StoryObj<typeof meta>

export const Default: Story = {
decorators: [
(Story, context) => (
<div className={context.args.inverseColor ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
}
export const Default: Story = {}

export const InvertedColor: Story = {
args: {
inverseColor: true,
},
decorators: [
(Story, context) => (
<div className={context.args.inverseColor ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,20 +5,15 @@

import { DescriptionList } from '@amsterdam/design-system-react'
import { Meta, StoryObj } from '@storybook/react'
import { inverseColorDecorator } from '../shared/decorators'
import { exampleParagraph } from '../shared/exampleContent'

const paragraph = exampleParagraph()

const meta = {
title: 'Components/Text/Description List',
component: DescriptionList,
decorators: [
(Story, context) => (
<div className={context.args['inverseColor'] ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
decorators: [inverseColorDecorator],
args: {
children: [
<DescriptionList.Term key={1}>Gebied</DescriptionList.Term>,
Expand Down
19 changes: 3 additions & 16 deletions storybook/src/components/Heading/Heading.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

import { Heading } from '@amsterdam/design-system-react/src'
import { Meta, StoryObj } from '@storybook/react'
import { inverseColorDecorator } from '../shared/decorators'
import { exampleHeading } from '../shared/exampleContent'

const heading = exampleHeading()
Expand All @@ -21,21 +22,14 @@ const meta = {
table: { disable: false },
},
},
decorators: [inverseColorDecorator],
} satisfies Meta<typeof Heading>

export default meta

type Story = StoryObj<typeof meta>

export const Default: Story = {
decorators: [
(Story, context) => (
<div className={context.args.inverseColor ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
}
export const Default: Story = {}

export const Heading1: Story = {}

Expand All @@ -61,11 +55,4 @@ export const InvertedColor: Story = {
args: {
inverseColor: true,
},
decorators: [
(Story, context) => (
<div className={context.args.inverseColor ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
}
9 changes: 2 additions & 7 deletions storybook/src/components/OrderedList/OrderedList.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

import { Heading, OrderedList, Paragraph } from '@amsterdam/design-system-react/src'
import type { Meta, StoryObj } from '@storybook/react'
import { inverseColorDecorator } from '../shared/decorators'
import { exampleOrderedList } from '../shared/exampleContent'

const orderedListItems = exampleOrderedList().map((text, index) => (
Expand All @@ -25,13 +26,7 @@ const meta = {
reversed: { control: 'boolean' },
start: { control: 'number' },
},
decorators: [
(Story, context) => (
<div className={context.args.inverseColor ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
decorators: [inverseColorDecorator],
} satisfies Meta<typeof OrderedList>

export default meta
Expand Down
31 changes: 3 additions & 28 deletions storybook/src/components/PageHeading/PageHeading.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

import { PageHeading } from '@amsterdam/design-system-react/src'
import { Meta, StoryObj } from '@storybook/react'
import { inverseColorDecorator } from '../shared/decorators'

const meta = {
title: 'Components/Text/Page Heading',
Expand All @@ -18,43 +19,17 @@ const meta = {
table: { disable: false },
},
},
decorators: [inverseColorDecorator],
} satisfies Meta<typeof PageHeading>

export default meta

type Story = StoryObj<typeof meta>

export const Default: Story = {
decorators: [
(Story, context) => (
<div
style={{
background: context.args.inverseColor ? '#004699' : 'transparent',
margin: context.args.inverseColor ? -16 : 0,
padding: context.args.inverseColor ? 16 : 0,
}}
>
<Story />
</div>
),
],
}
export const Default: Story = {}

export const InvertedColor: Story = {
args: {
inverseColor: true,
},
decorators: [
(Story) => (
<div
style={{
background: '#004699',
margin: -16,
padding: 16,
}}
>
<Story />
</div>
),
],
}
19 changes: 3 additions & 16 deletions storybook/src/components/Paragraph/Paragraph.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

import { Paragraph } from '@amsterdam/design-system-react/src'
import { Meta, StoryObj } from '@storybook/react'
import { inverseColorDecorator } from '../shared/decorators'
import { exampleParagraph } from '../shared/exampleContent'

const paragraph = exampleParagraph()
Expand All @@ -28,21 +29,14 @@ const meta = {
options: ['small', undefined, 'large'],
},
},
decorators: [inverseColorDecorator],
} satisfies Meta<typeof Paragraph>

export default meta

type Story = StoryObj<typeof meta>

export const Default: Story = {
decorators: [
(Story, context) => (
<div className={context.args.inverseColor ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
}
export const Default: Story = {}

export const Large: Story = {
args: {
Expand All @@ -60,11 +54,4 @@ export const InvertedColor: Story = {
args: {
inverseColor: true,
},
decorators: [
(Story, context) => (
<div className={context.args.inverseColor ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
}
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import {
TrashBinIcon,
} from '@amsterdam/design-system-react-icons'
import type { Meta, StoryObj } from '@storybook/react'
import { inverseColorDecorator } from '../shared/decorators'
import { exampleUnorderedList } from '../shared/exampleContent'

const unorderedListItems = exampleUnorderedList().map((text, index) => (
Expand All @@ -29,13 +30,7 @@ const meta = {
inverseColor: false,
markers: undefined,
},
decorators: [
(Story, context) => (
<div className={context.args.inverseColor ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
),
],
decorators: [inverseColorDecorator],
} satisfies Meta<typeof UnorderedList>

export default meta
Expand Down
13 changes: 13 additions & 0 deletions storybook/src/components/shared/decorators.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
/**
* @license EUPL-1.2+
* Copyright Gemeente Amsterdam
*/

import type { StoryContext, StoryFn } from '@storybook/react'

/** Applies a dark background colour if the `inverseColor` arg is true. */
export const inverseColorDecorator = (Story: StoryFn, context: StoryContext) => (
<div className={context.args['inverseColor'] ? 'ams-docs-dark-background' : undefined}>
<Story />
</div>
)

0 comments on commit 104ee42

Please sign in to comment.