From 985f06ce0019c937db516e1e45893a918b7c2d95 Mon Sep 17 00:00:00 2001 From: Barsnes Date: Mon, 6 Jan 2025 14:53:07 +0100 Subject: [PATCH 1/3] docs: write `useCheckboxGroup` --- .../useCheckboxGroup/useCheckboxGroup.mdx | 44 +++++++++- .../useCheckboxGroup.stories.tsx | 81 ++++++++++++++++--- 2 files changed, 111 insertions(+), 14 deletions(-) diff --git a/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx b/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx index db40b4a781..3e31492ea6 100644 --- a/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx +++ b/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx @@ -1,9 +1,47 @@ -import { Meta } from '@storybook/blocks'; +import { Meta, Primary, Controls, Canvas, ArgTypes } from '@storybook/blocks'; +/* import { ArgsTable } from '@storybook/addon-essentials'; */ import * as useCheckboxGroupStories from './useCheckboxGroup.stories'; +import { useCheckboxGroup } from './useCheckboxGroup'; # useCheckboxGroup -Information coming. -See Checkbox in the meantime. +En react hook for å koble sammen en gruppe av checkboxer. + + + + +## Bruk + +Fra `useCheckboxGroup` henter du ut `getCheckboxProps` som du sprer på checkboxene dine. +Du kan også hente ut `validationMessageProps`, `value` og `setValue`. + +I `getCheckboxProps` denne funksjonen er første parameter `value` som er en unik identifikator for checkboxen, eller eit objekt med alt som kan legges på en checkbox. +Dersom du sender inn eit object, så må du passe på å sette `value`. + +```tsx +const { getCheckboxProps, validationMessageProps } = useCheckboxGroup({ + value: ['epost'], + ...args, +}); + +return ( +
+ + + + +
+); +``` + +## Tillat indeterminate + +Når du sprer `getCheckboxProps` på Checkboxen din, så kan du sende inn `allowIndeterminate: true` for å tillate at checkboxen kan være i en indeterminate tilstand. + + + +## Props + + diff --git a/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.stories.tsx b/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.stories.tsx index 3e305694ec..e0d304be45 100644 --- a/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.stories.tsx +++ b/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.stories.tsx @@ -1,15 +1,18 @@ -import type { Meta } from '@storybook/react'; -import { Checkbox } from '../../../components'; -import type { UseCheckboxGroupProps } from './useCheckboxGroup'; +import type { Meta, StoryFn } from '@storybook/react'; +import { + Checkbox, + Fieldset, + Table, + ValidationMessage, +} from '../../../components'; +import { + type UseCheckboxGroupProps, + useCheckboxGroup, +} from './useCheckboxGroup'; -export const UseCheckboxGroup = (_props: UseCheckboxGroupProps) => ( - -); - -export default { +const meta: Meta = { title: 'Utilities/useCheckboxGroup', - tags: ['!dev'], // Hide from sidebar as documented in https://storybook.js.org/docs/writing-stories/tags - component: UseCheckboxGroup, + parameters: { chromatic: { disableSnapshot: true } }, argTypes: { name: { table: { type: { summary: 'string' } }, @@ -58,4 +61,60 @@ export default { description: 'Set required state of all checkboxes', }, }, -} as Meta; +}; + +export default meta; + +export const Default: StoryFn = (args) => { + const { getCheckboxProps, validationMessageProps } = useCheckboxGroup({ + value: ['epost'], + ...args, + }); + + return ( +
+ + + + +
+ ); +}; + +export const AllowIndeterminate: StoryFn = (args) => { + const { getCheckboxProps } = useCheckboxGroup({ + name: 'my-checkbox', + ...args, + }); + return ( + + + + + + + Header + + + + {[1, 2].map((row) => ( + + + + + Content + + ))} + +
+ ); +}; From c5c40df531cef0d806ab030df496cd536fb7a0f7 Mon Sep 17 00:00:00 2001 From: Barsnes Date: Mon, 6 Jan 2025 14:53:36 +0100 Subject: [PATCH 2/3] remove controls --- .../src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx | 1 - 1 file changed, 1 deletion(-) diff --git a/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx b/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx index 3e31492ea6..71987b732c 100644 --- a/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx +++ b/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx @@ -10,7 +10,6 @@ import { useCheckboxGroup } from './useCheckboxGroup'; En react hook for å koble sammen en gruppe av checkboxer. - ## Bruk From 83022123775562d8d8391d8de893f6c4be0b36ac Mon Sep 17 00:00:00 2001 From: Barsnes Date: Wed, 8 Jan 2025 10:00:37 +0100 Subject: [PATCH 3/3] add warning --- .../src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx | 2 ++ 1 file changed, 2 insertions(+) diff --git a/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx b/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx index 71987b732c..345b12c5c1 100644 --- a/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx +++ b/packages/react/src/utilities/hooks/useCheckboxGroup/useCheckboxGroup.mdx @@ -19,6 +19,8 @@ Du kan også hente ut `validationMessageProps`, `value` og `setValue`. I `getCheckboxProps` denne funksjonen er første parameter `value` som er en unik identifikator for checkboxen, eller eit objekt med alt som kan legges på en checkbox. Dersom du sender inn eit object, så må du passe på å sette `value`. +**Det er viktig at du sender inn props i `getCheckboxProps`, slik at du ikke overskriver vår funksjonalitet.** + ```tsx const { getCheckboxProps, validationMessageProps } = useCheckboxGroup({ value: ['epost'],