Skip to content

Button

ButtonButtonButton

Buttons are clickable elements primarily used to perform an action, as they communicate the call-to-action and their style calls for users' attention. Buttons can also be used to allow navigation in some cases, such as for the “Next” or “Back” buttons that help users navigate through a form.

UX/UI Guidelines

Check the design documentation of the component in ZeroHeight.

Implementations

The component Button is available in the following technologies:

CSS Components
cssreactvue
Web Components
webreactvueangular

Parameters

Parameters

Make sure you have read about the parameters in here.

The parametrization of the component can be done with the following custom params or properties:

NameTypeSlotDescription
configstring

The main string chained parameter has three components following the pattern:

<?type><?:size><?:round>

Where the components are:

  • type: (optional) defines the type of button that is going to be shown up. The possible values are: primary, secondary, positive, negative, and link.

    ts
    export type ZButton_Type =
      | 'primary'
      | 'secondary'
      | 'positive'
      | 'negative'
      | 'link';
  • size: (optional) defines de size of the button. The default value is m, being omitted from the param. The possible values are: xs, s, or l. Check the sizes section.

    ts
    export type ZButton_Size = 'xs' | 's' | 'm' | 'l';
  • round: (optional) if we define the value round, the button will take a round shape.

iconstring

The name of the icon that will be shown up inside the button. Check the icon list

contentstringThe text that will be shown up inside the button.
icon-rightboolean

Defines the position of the icon. The default value is true, being omitted.

disabledbooleanBlocks the interaction with the component.
loadingbooleanShows a loading animation inside the button.
wideboolean  stringExpands the button to the full width of its parent.
hrefstringTransform the button into a link.
targetstringThe target attribute specifies where to open the linked document.
popover-target⚠️string

Refers to the popover element with the specified id, and toggle between showing and hiding it. Check the official docs

as-submit⚠️booleanTransform the button into a submit input.
customobject

A record of key-value pairs to set the CSS custom tokens. It's a complex attribute set as an JS object in stringified JSON format.

Example:

html
<z-button custom='{"fill":"#06e7a3"}' />

Check the available values in the customization section.

custom-strstring

The stringified version of the custom property. It follows the pattern key:value;key:value;, with the possibility of setting multiple values and spaces between the punctuation characters.

Example:

html
<z-button custom-str="fill:#06e7a3" />
z-themestring

Sets the theme of the component. The possible values are light and dark.

html
<z-button z-theme="dark" />

From Figma to code

You can check the Figma implementation here.

Customization

INFO

Check everything about the customization mechanics in the "How it works" documentation.

CSS VariableTypeDescription
--z-button--bgcolorBackground color
--z-button--colorcolorForeground color
--z-button--radiusdistanceRadius of the button
--z-button--backdropcolorPopover's backdrop color
--z-button--popover-radiusdistancePopover's radius
--z-button--popover-paddingdistancePopover's padding

Both, background and foreground color can be customized using the --z-button--bg and --z-button--color or the custom attribute. You can use the --z-button--radius token to change the border-radius of the button.

Button Button

Accessibility

...