Skip to content

Commit

Permalink
Show indicator always above the field block content
Browse files Browse the repository at this point in the history
  • Loading branch information
tujoworker committed Nov 15, 2024
1 parent 1471830 commit 9f690f5
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 76 deletions.
52 changes: 19 additions & 33 deletions packages/dnb-eufemia/src/extensions/forms/FieldBlock/FieldBlock.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ import { Ul, Li } from '../../../elements'
import {
convertJsxToString,
findElementInChildren,
warn,
} from '../../../shared/component-helper'
import useId from '../../../shared/helpers/useId'
import {
Expand Down Expand Up @@ -526,12 +525,6 @@ function FieldBlock(props: Props) {
return null
}

if (fieldState && typeof label === 'undefined') {
warn(
'Provide a label when using an async validator or onChange event.'
)
}

const hasLabelDescription = isFragment(labelDescription)
? fragmentHasChildren(labelDescription) &&
!fragmentHasOnlyUndefinedChildren(labelDescription)
Expand Down Expand Up @@ -569,26 +562,21 @@ function FieldBlock(props: Props) {
<div className={gridClasses}>
{(label || labelDescription || hasHelp) && (
<FormLabel {...labelProps}>
<SubmitIndicator
state={fieldState}
className="vertical-indicator"
>
{label && (
<span className="dnb-forms-field-block__label__content">
{label}
</span>
)}

{hasLabelDescription && (
<span className="dnb-forms-field-block__label__description">
{labelDescription}
</span>
)}

{hasHelp && (
<HelpButtonInline contentId={`${id}-help`} help={help} />
)}
</SubmitIndicator>
{label && (
<span className="dnb-forms-field-block__label__content">
{label}
</span>
)}

{hasLabelDescription && (
<span className="dnb-forms-field-block__label__description">
{labelDescription}
</span>
)}

{hasHelp && (
<HelpButtonInline contentId={`${id}-help`} help={help} />
)}
</FormLabel>
)}

Expand Down Expand Up @@ -632,12 +620,10 @@ function FieldBlock(props: Props) {
{children}
</div>

{layout === 'horizontal' && label && (
<SubmitIndicator
state={fieldState}
className="horizontal-indicator"
/>
)}
<SubmitIndicator
state={fieldState}
className="dnb-forms-field-block__indicator dnb-forms-submit-indicator--inline-wrap"
/>
</div>
</Space>
</FieldBlockContext.Provider>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -882,49 +882,6 @@ describe('FieldBlock', () => {
})
})

it('should warn when formStatus is given, but no label', async () => {
const log = jest.spyOn(console, 'log').mockImplementation()

const asyncValidator = async () => {
return null
}

const { rerender } = render(
<Form.Handler>
<Field.String
label="Has a label"
value="bar"
path="/foo"
validator={asyncValidator}
/>
<Form.SubmitButton />
</Form.Handler>
)

const buttonElement = document.querySelector('button')

await userEvent.click(buttonElement)

expect(log).toHaveBeenCalledTimes(0)

rerender(
<Form.Handler>
<Field.String value="bar" path="/foo" validator={asyncValidator} />
<Form.SubmitButton />
</Form.Handler>
)

await userEvent.click(buttonElement)

expect(log).toHaveBeenLastCalledWith(
expect.any(String),
expect.any(String),
'Provide a label when using an async validator or onChange event.'
)

log.mockRestore()
})

it('should summarize errors in one FormStatus components', () => {
const MockComponent = () => {
useFieldProps({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ fieldset.dnb-forms-field-block {
'label'
'help'
'contents'
'indicator'
'status';
}

Expand Down

0 comments on commit 9f690f5

Please sign in to comment.