Hoppa till huvudinnehåll

Button

Knapp

Knappar används när användaren vill utföra en handling t.ex. spara ifylld information eller öppna ett formulär.

Installation och användning

npm install @midas-ds/button
import { Button } from '@midas-ds/button'

Primärknapp

Den primära knapp används för den primära/positiva handlingar i ett flöde (OK ,Skicka, Nästa). Det bör endast finnas en primärknapp per sida/sektion/tydligt avgränsad yta.

Sekundär knapp

Sekundär knapp används för underordnade handlingar i ett flöde (Avbryt, Tillbaka).

Tertiär knapp

Den tertiära knappen kan användas tillsammans med primär- och sekundärknapp där det finns behov av ett ytterligare val

Om den tertiära knappen används fristående från andra knappar ska den ha en ikon. Ikonen läggs till via icon. Du kan välja vilken sida av texten ikonen ska vara på med iconPlacement.

Grupp av knappar

För att få korrekt layout på flertalet knappar kan komponenten ButtonGroup användas.

Riktlinjer

Val av komponent

Se mönstret Knappar och länkar

Generella riktlinjer

  • Undvik inaktiva knappar. Alla knappar i externa system ska gå att interagera med. Om användaren inte uppfyllt kraven, t.ex för att gå till nästa sida i en e-tjänst, ska ett felmeddelande visas som påtalar vad som krävs för att kunna gå vidare.
  • Undvik att ha för många knappar på samma sida.

Placering och ordning

Knappar placeras i regel i nedre vänstra hörnet. Vi sätter alltid den primära knappen till vänster.

API

Button

NamnTypStandardBeskrivning
variant "icon" | "primary" | "secondary" | "tertiary" | "danger"primaryPrimary button is used as a positive action in a flow. Always use one primary button and never a seconday button on it's own. When using just an icon you must pass an aria-label
fullwidth boolean-
size "small"-
icon LucideIcon-
iconSize number-
iconPlacement "left" | "right"-
children (ReactNode | ((values: ButtonRenderProps & { defaultChildren: ReactNode; }) => ReactNode)) & (ReactNode | ((values: ButtonRenderProps & { ...; }) => ReactNode))-The children of the component. A function may be provided to alter the children based on component state.
form string-The `<form>` element to associate the button with. The value of this attribute must be the id of a `<form>` in the same document.
formAction string-The URL that processes the information submitted by the button. Overrides the action attribute of the button's form owner.
formEncType string-Indicates how to encode the form data that is submitted.
formMethod string-Indicates the HTTP method used to submit the form.
formNoValidate boolean-Indicates that the form is not to be validated when it is submitted.
formTarget string-Overrides the target attribute of the button's form owner.
name string-Submitted as a pair with the button's value as part of the form data.
value string-The value associated with the button's name when it's submitted with the form data.
isPending boolean-Whether the button is in a pending state. This disables press and hover events while retaining focusability, and announces the pending state to screen readers.
type "button" | "submit" | "reset"'button'The behavior of the button when used in an HTML form.
isDisabled boolean-Whether the button is disabled.
autoFocus boolean-Whether the element should receive focus on render.
preventFocusOnPress boolean-Whether to prevent focus from moving to the button when pressing it. Caution, this can make the button inaccessible and should only be used when alternative keyboard interaction is provided, such as ComboBox's MenuTrigger or a NumberField's increment/decrement control.
excludeFromTabOrder boolean-Whether to exclude the element from the sequential tab order. If true, the element will not be focusable via the keyboard by tabbing. This should be avoided except in rare scenarios where an alternative means of accessing the element or its functionality via the keyboard is available.
id string-The element's unique identifier. See [MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/id).
slot string-A slot name for the component. Slots allow the component to receive props from a parent component. An explicit `null` value indicates that the local props completely override all props received from a parent.
className string | ((values: ButtonRenderProps & { defaultClassName: string; }) => string)-The CSS [className](https://developer.mozilla.org/en-US/docs/Web/API/Element/className) for the element. A function may be provided to compute the class based on component state.
style CSSProperties | ((values: ButtonRenderProps & { defaultStyle: CSSProperties; }) => CSSProperties)-The inline [style](https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/style) for the element. A function may be provided to compute the style based on component state.

ButtonGroup

Beroenden

  • @midas-ds/theme@^0.5.23
  • react@^18.2.0