From 2f89c79f563d8a4c121cfa8bf8c2d2595a9453d4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Connor=20B=C3=A4r?= Date: Tue, 15 Oct 2024 09:52:40 +0200 Subject: [PATCH] Add hideLabel prop to ImageInput --- .changeset/happy-glasses-work.md | 5 +++++ .../components/Field/Field.module.css | 5 ++--- .../circuit-ui/components/Field/Field.tsx | 2 ++ .../components/ImageInput/ImageInput.spec.tsx | 4 +++- .../components/ImageInput/ImageInput.tsx | 21 +++++++++++++++++++ 5 files changed, 33 insertions(+), 4 deletions(-) create mode 100644 .changeset/happy-glasses-work.md diff --git a/.changeset/happy-glasses-work.md b/.changeset/happy-glasses-work.md new file mode 100644 index 0000000000..2883618e4e --- /dev/null +++ b/.changeset/happy-glasses-work.md @@ -0,0 +1,5 @@ +--- +'@sumup/circuit-ui': minor +--- + +Added a `hideLabel` prop to the ImageInput component. It defaults to `true` to match the existing behavior. diff --git a/packages/circuit-ui/components/Field/Field.module.css b/packages/circuit-ui/components/Field/Field.module.css index f74aeb7e08..c6137fd099 100644 --- a/packages/circuit-ui/components/Field/Field.module.css +++ b/packages/circuit-ui/components/Field/Field.module.css @@ -8,13 +8,12 @@ .label, .legend { display: block; - font-size: var(--cui-typography-body-two-font-size); - line-height: var(--cui-typography-body-two-line-height); } .label-text { - display: inline-block; margin-bottom: var(--cui-spacings-bit); + font-size: var(--cui-typography-body-two-font-size); + line-height: var(--cui-typography-body-two-line-height); } [disabled] .label-text, diff --git a/packages/circuit-ui/components/Field/Field.tsx b/packages/circuit-ui/components/Field/Field.tsx index 9d3d243c0b..b3c45154ab 100644 --- a/packages/circuit-ui/components/Field/Field.tsx +++ b/packages/circuit-ui/components/Field/Field.tsx @@ -122,6 +122,7 @@ export function FieldLabelText({ hideLabel, optionalLabel, required, + ...props }: FieldLabelTextProps) { return ( {label} {optionalLabel && !required ? ( diff --git a/packages/circuit-ui/components/ImageInput/ImageInput.spec.tsx b/packages/circuit-ui/components/ImageInput/ImageInput.spec.tsx index 07e5e08ded..ad8ca9878f 100644 --- a/packages/circuit-ui/components/ImageInput/ImageInput.spec.tsx +++ b/packages/circuit-ui/components/ImageInput/ImageInput.spec.tsx @@ -105,7 +105,9 @@ describe('ImageInput', () => { */ it('should support dragging and dropping an image', async () => { render(); - const labelEl = screen.getByText(defaultProps.label); + const labelEl = screen.getByText(defaultProps.label, { + ignore: '[aria-hidden="true"]', + }); fireEvent.drop(labelEl, { dataTransfer: { files: [file] } }); diff --git a/packages/circuit-ui/components/ImageInput/ImageInput.tsx b/packages/circuit-ui/components/ImageInput/ImageInput.tsx index 20d3be2dfc..9b57e87b8c 100644 --- a/packages/circuit-ui/components/ImageInput/ImageInput.tsx +++ b/packages/circuit-ui/components/ImageInput/ImageInput.tsx @@ -33,6 +33,7 @@ import { FieldWrapper, FieldLabel, FieldValidationHint, + FieldLabelText, } from '../Field/index.js'; import { IconButton } from '../Button/index.js'; import { Spinner } from '../Spinner/index.js'; @@ -89,6 +90,15 @@ export interface ImageInputProps * An information or error message, displayed below the input. */ validationHint?: string; + /** + * Label to indicate that the input is optional. Only displayed when the + * `required` prop is falsy. + */ + optionalLabel?: string; + /** + * Visually hide the label. Default: `true`. + */ + hideLabel?: boolean; } /** @@ -104,7 +114,10 @@ export const ImageInput = ({ disabled, validationHint, invalid = false, + required, + optionalLabel, loadingLabel, + hideLabel = true, 'component': Component, className, style, @@ -231,6 +244,13 @@ export const ImageInput = ({ return ( +