Skip to content

Commit

Permalink
fix(FieldBlock): add asFieldset property to let the block use fieldse…
Browse files Browse the repository at this point in the history
…t/legend
  • Loading branch information
tujoworker committed Oct 23, 2023
1 parent a22fad5 commit 3dfab5e
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,9 @@ showTabs: true

## Properties

| Property | Type | Description |
| ---------------------------------------------------------------------------------------------------------------- | ------------------- | ------------------------------------------------------------------------------------------------------- |
| `width` | `string` or `false` | _(optional)_ `small`, `medium`, `large` or `false` for predefined standard widths. |
| `size` | `string` or `false` | _(optional)_ define one of the following [heading size](/uilib/elements/heading/): `medium` or `large`. |
| `FieldProps` such as [Value.String-properties](/uilib/extensions/forms/create-component/Value/String/properties) | Various | _(optional)_ `FieldProps` properties. |
| Property | Type | Description |
| ---------------------------------------------------------------------------------------------------------------- | ------------------- | ----------------------------------------------------------------------------------------------------------------------- |
| `asFieldset` | `boolean` | _(optional)_ use `true` when you have several form elements and a label. This way a `fieldset` with a `legend` is used. |
| `width` | `string` or `false` | _(optional)_ `small`, `medium`, `large` or `false` for predefined standard widths. |
| `size` | `string` or `false` | _(optional)_ define one of the following [heading size](/uilib/elements/heading/): `medium` or `large`. |
| `FieldProps` such as [Value.String-properties](/uilib/extensions/forms/create-component/Value/String/properties) | Various | _(optional)_ `FieldProps` properties. |
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ export type Props = Pick<
forId?: string
contentClassName?: string
children: React.ReactNode
/** Use true if you have more than one form element */
asFieldset?: boolean
/** Width of outer block element */
width?: false | 'small' | 'medium' | 'large'
/** Width of contents block, while label etc can be wider if space is available */
Expand All @@ -37,6 +39,7 @@ function FieldBlock(props: Props) {
label,
labelDescription,
labelSecondary,
asFieldset,
info,
warning,
error: errorProp,
Expand Down Expand Up @@ -127,11 +130,12 @@ function FieldBlock(props: Props) {
// A child component with a label was found, use fieldset/legend instead of div/label
const enableFieldset = useMemo(
() =>
!nestedFieldBlockContext &&
findElementInChildren(
children,
(child: React.ReactElement) => child.props.label
),
asFieldset ||
(!nestedFieldBlockContext &&
findElementInChildren(
children,
(child: React.ReactElement) => child.props.label
)),
[]
)

Expand All @@ -148,7 +152,7 @@ function FieldBlock(props: Props) {
return (
<FormLabel
element={enableFieldset ? 'legend' : 'label'}
for_id={forId}
for_id={enableFieldset ? undefined : forId}
space={{ top: 0, bottom: 'x-small' }}
size={size}
>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,21 @@ describe('FieldBlock', () => {
expect(labelElements[4]).toBe(undefined)
})

it('should use fieldset/legend when "asFieldset" is given', () => {
render(
<FieldBlock label="Legend" asFieldset>
content
</FieldBlock>
)

expect(document.querySelectorAll('fieldset')).toHaveLength(1)
expect(document.querySelectorAll('legend')).toHaveLength(1)
expect(document.querySelector('legend')).not.toHaveAttribute('for')
expect(document.querySelector('.dnb-forms-field-block').tagName).toBe(
'FIELDSET'
)
})

it('should render a FormStatus when "info" is given', () => {
render(<FieldBlock info="Info">content</FieldBlock>)

Expand Down

0 comments on commit 3dfab5e

Please sign in to comment.