Button

Similar to a Badge, the Button component uses the same syntax as a hyperlink, but is prefixed with a !button identifier.

Demo
Source
[!button Button](button.md)

[Normal link](button.md)

Variant

// Text only (default Primary variant)
[!button My Button]

// Text with variant
[!button text="My Button" variant="success"]

Using text|variant shorthand notation 
[!button My Button|success]

// With link and variant
[!button text="My Button" variant="success"](https://retype.com/)
Variant Text only With link
base Base Base
primary (default) Primary Primary
secondary Secondary Secondary
success Success Success
question Question Question
danger Danger Danger
warning Warning Warning
info Info Info
light Light Light
dark Dark Dark
ghost Ghost Ghost
contrast Contrast Contrast
clean Clean Clean

Corners

[!button text="Default"](button.md)
[!button corners="square" text="Square"](button.md)
[!button corners="pill" text="Button Pill"](button.md)
Size Example
round (default) Default
square Square
pill Button Pill

Size

[!button size="m" text="Medium"](button.md)
Size Example
xs XSmall
s Small
m (default) Medium
l Large
xl XLarge
2xl 2XLarge
3xl 3XLarge

Width

Use width to set the rendered width of a Button. Use maxWidth to cap how wide the Button can grow.

Numeric-only width and maxWidth values are rendered as pixel values. For example, width="240" is rendered as width: 240px.

Set width="full" to stretch the Button to the full width of its container. This is equivalent to width="100%".

Demo
Source

Fixed width

Full width

Full width capped

[!button text="Fixed width" width="240"]

[!button text="Full width" width="full"]

[!button text="Full width capped" width="full" maxWidth="320"]

CSS length and percentage values are also supported.

[!button text="Half width" width="50%"]
[!button text="Capped width" width="100%" maxWidth="24rem"]

Target

Sets the target attribute of the button and specifies which window or tab to open the link into.

Retype

[!button target="blank" text="Retype"](https://retype.com/)

If no target is configured, the link will open in the current tab.

The target can be set to any value, although blank is common and will open the link in a new tab. Retype will automatically transform the value blank into _blank which is the actual value required by the browser to indicate that a hyperlink should be opened in a new tab.

There are several other values that may be prefixed with an _ character, including self, parent, and top. The following table demonstrates some common scenarios and naming convention used by Retype to normalize the target values.

Config target value Runtime target value
blank _blank
parent _parent
top _top
self _self
news1 news1
nEWs2 news2
recent NEWS recent-news

See also the links.target configuration.


Icon and Emoji

Octicons

Octicons can be used as an icon by settiing the icon property with the name of the Octicon.

[!button variant="info" icon="person" text="User"](button.md)
[!button variant="primary" icon="paper-airplane" iconAlign="right" text="Send"](button.md)

User Send

Emoji

Emoji :shortcodes: can be used for the icon. Please see Mojee for a full list of supported Emoji shortcodes.

[!button variant="light" icon=":heart:" text="Like"](button.md)
[!button variant="info" icon=":rocket:" iconAlign="right" text="Rocket"](button.md)

❤️ Like Rocket 🚀

Custom icon

Project icons can be used by setting the icon property to the custom icon name.

[!button variant="light" icon="brand-printer" text="Print" action="print-page"]

[!button variant="clean" icon="brand-printer" text="Print" action="print-page" corners="pill"] 

Image file

Any image file can be used as the icon.

[!button icon="../static/retype-icon.svg"](button.md)

SVG image

The icon can also be set with an inline <svg> element.

[!button icon="<svg width=&quot;24&quot; height=&quot;24&quot;><path fill-rule=&quot;evenodd&quot; d=&quot;M12 16.5a4.5 4.5 0 100-9 4.5 4.5 0 000 9zm0 1.5a6 6 0 100-12 6 6 0 000 12z&quot;></path></svg>" text="Visit website"](button.md)

Visit website


Theme variables

Retype gives you full control over the look and feel of your button components through customizable theme variables.

You can override any of theme variable in your retype.yml configuration file using the theme.base and theme.dark settings.

For example, to change the primary button color and text color for all instances of the primary button within your project, add the following to your project's retype.yml file:

theme:
  base:
    # Revise the primary variant base color
    # across all components within the project
    # primary: "#209fb5" 

    # Or, adjust button only theme variables
    button-primary: "#209fb5"
    button-primary-text: "#eff1f5"

To learn more about theme variables and how they work across Retype, check out the Themes Guide, the Theme Variables documentation, and theme Project settings.


Action

A Button can run an Action instead of navigating to a link. This is useful for built-in actions such as print-page and Custom Actions.

[!button action="print-page" text="Print page"]

[!button Print page](action:print-page)

Custom actions in _components/actions/ can also return Button properties. The following action builds an Edit on GitHub link and updates the Button text, variant, corners, and icon during the build.

_components/actions/edit-on-github.md
---
steps:
  - with:
      link: https://github.com/retypeapp/retype/edit/main{{ page.filePath }}
      text: Edit on GitHub
      variant: success
      corners: pill
      icon: mark-github
---
[!button Edit](action:edit-on-github)
component