From 7b275d0c803b309095ba7c425bb6bf04630775a9 Mon Sep 17 00:00:00 2001 From: Vincent Smedinga Date: Wed, 6 Nov 2024 11:41:01 +0100 Subject: [PATCH] feat!: Use new Button features for SearchField (#1695) Co-authored-by: Aram <37216945+alimpens@users.noreply.github.com> --- .../components/search-field/search-field.scss | 26 ------------------- .../src/SearchField/SearchField.test.tsx | 2 +- .../src/SearchField/SearchFieldButton.tsx | 22 ++++++---------- .../components/ams/search-field.tokens.json | 10 ------- 4 files changed, 9 insertions(+), 51 deletions(-) diff --git a/packages/css/src/components/search-field/search-field.scss b/packages/css/src/components/search-field/search-field.scss index d914fb2ee1..76ac9a79b1 100644 --- a/packages/css/src/components/search-field/search-field.scss +++ b/packages/css/src/components/search-field/search-field.scss @@ -68,29 +68,3 @@ inline-size: var(--ams-search-field-input-cancel-button-inline-size); margin-inline-start: 0.5rem; } - -@mixin reset-button { - border: 0; - margin-block: 0; // [1] - margin-inline: 0; // [1] - - // [1] Remove the margin in older Safari. -} - -.ams-search-field__button { - background-color: var(--ams-search-field-button-background-color); - color: var(--ams-search-field-button-color); - cursor: pointer; - outline-offset: var(--ams-search-field-button-outline-offset); - - // TODO Check if these paddings are necessary - padding-block: var(--ams-search-field-button-padding-block); - padding-inline: var(--ams-search-field-button-padding-inline); - touch-action: manipulation; - - @include reset-button; - - &:hover { - background-color: var(--ams-search-field-button-hover-background-color); - } -} diff --git a/packages/react/src/SearchField/SearchField.test.tsx b/packages/react/src/SearchField/SearchField.test.tsx index 4187fd95fc..bd5fa276eb 100644 --- a/packages/react/src/SearchField/SearchField.test.tsx +++ b/packages/react/src/SearchField/SearchField.test.tsx @@ -32,7 +32,7 @@ describe('Search field', () => { }) it('renders the button with a label', () => { - render() + render(Search) const component = screen.getByRole('button', { name: 'Search' }) diff --git a/packages/react/src/SearchField/SearchFieldButton.tsx b/packages/react/src/SearchField/SearchFieldButton.tsx index e91ee9918a..ba379157fd 100644 --- a/packages/react/src/SearchField/SearchFieldButton.tsx +++ b/packages/react/src/SearchField/SearchFieldButton.tsx @@ -4,24 +4,18 @@ */ import { SearchIcon } from '@amsterdam/design-system-react-icons' -import clsx from 'clsx' import { forwardRef } from 'react' -import type { ForwardedRef, HTMLAttributes } from 'react' -import { Icon } from '../Icon' +import type { ForwardedRef } from 'react' +import { Button } from '../Button' +import type { ButtonProps } from '../Button' -type SearchFieldButtonProps = { - /** Describes the field for screen readers. */ - label?: string -} & HTMLAttributes +type SearchFieldButtonProps = Omit -// TODO: replace this with IconButton when that's done -// TODO: discuss if IconButton is the right component to replace this export const SearchFieldButton = forwardRef( - ({ label = 'Zoeken', className, ...restProps }: SearchFieldButtonProps, ref: ForwardedRef) => ( - + ({ children = 'Zoeken', ...restProps }: SearchFieldButtonProps, ref: ForwardedRef) => ( + ), ) diff --git a/proprietary/tokens/src/components/ams/search-field.tokens.json b/proprietary/tokens/src/components/ams/search-field.tokens.json index 52ec22ad3d..e5f24de100 100644 --- a/proprietary/tokens/src/components/ams/search-field.tokens.json +++ b/proprietary/tokens/src/components/ams/search-field.tokens.json @@ -1,16 +1,6 @@ { "ams": { "search-field": { - "button": { - "background-color": { "value": "{ams.color.primary-blue}" }, - "color": { "value": "{ams.color.primary-white}" }, - "outline-offset": { "value": "{ams.focus.outline-offset}" }, - "padding-block": { "value": "{ams.space.sm}" }, - "padding-inline": { "value": "{ams.space.sm}" }, - "hover": { - "background-color": { "value": "{ams.color.dark-blue}" } - } - }, "input": { "background-color": { "value": "{ams.color.primary-white}" }, "box-shadow": { "value": "inset 0 0 0 {ams.border.width.sm} {ams.color.primary-black}" },