Basic clickable component for handling user interaction.
There are two ways to display buttons:
ws-x attribute on a button element@@button marker to a label element<a> tags can also be displayed with a button style, but they will still act as anchors.
<div>
    Buttons with a couple of different variants and colors
</div>
<ws-grid ws-x="[$content] [gr.cols repeat(3, 1fr)]">
    <div ws-x="[col span 3]">Default Color / Disabled / Elevated</div>
    <button ws-x="[$color @default] [$flat]">Flat</button>
    <button ws-x="[$color @default] [$outline]">Outline</button>
    <button ws-x="[$color @default] [$fill]">Fill</button>
    <button disabled ws-x="[$color @default] [$flat]">Flat</button>
    <button disabled ws-x="[$color @default] [$outline]">Outline</button>
    <button disabled ws-x="[$color @default] [$fill]">Fill</button>
    <button ws-x="[$color @default] [$elevate] [$flat]">Flat</button>
    <button ws-x="[$color @default] [$elevate] [$outline]">Outline</button>
    <button ws-x="[$color @default] [$elevate] [$fill]">Fill</button>
    <div ws-x="[col span 3]">Plain Color / Disabled / Elevated</div>
    <button ws-x="[$color @plain] [$flat]">Flat</button>
    <button ws-x="[$color @plain] [$outline]">Outline</button>
    <button ws-x="[$color @plain] [$fill]">Fill</button>
    <button disabled ws-x="[$color @plain] [$flat]">Flat</button>
    <button disabled ws-x="[$color @plain] [$outline]">Outline</button>
    <button disabled ws-x="[$color @plain] [$fill]">Fill</button>
    <button ws-x="[$color @plain] [$elevate] [$flat]">Flat</button>
    <button ws-x="[$color @plain] [$elevate] [$outline]">Outline</button>
    <button ws-x="[$color @plain] [$elevate] [$fill]">Fill</button>
    <div ws-x="[col span 3]">Primary Color / Disabled / Elevated</div>
    <button ws-x="[$color @primary] [$flat]">Flat</button>
    <button ws-x="[$color @primary] [$outline]">Outline</button>
    <button ws-x="[$color @primary] [$fill]">Fill</button>
    <button disabled ws-x="[$color @primary] [$flat]">Flat</button>
    <button disabled ws-x="[$color @primary] [$outline]">Outline</button>
    <button disabled ws-x="[$color @primary] [$fill]">Fill</button>
    <button ws-x="[$color @primary] [$elevate] [$flat]">Flat</button>
    <button ws-x="[$color @primary] [$elevate] [$outline]">Outline</button>
    <button ws-x="[$color @primary] [$elevate] [$fill]">Fill</button>
    <div ws-x="[col span 3]">Secondary Color / Disabled / Elevated</div>
    <button ws-x="[$color @secondary] [$flat]">Flat</button>
    <button ws-x="[$color @secondary] [$outline]">Outline</button>
    <button ws-x="[$color @secondary] [$fill]">Fill</button>
    <button disabled ws-x="[$color @secondary] [$flat]">Flat</button>
    <button disabled ws-x="[$color @secondary] [$outline]">Outline</button>
    <button disabled ws-x="[$color @secondary] [$fill]" disabled>Fill</button>
    <button ws-x="[$color @secondary] [$elevate] [$flat]">Flat</button>
    <button ws-x="[$color @secondary] [$elevate] [$outline]">Outline</button>
    <button ws-x="[$color @secondary] [$elevate] [$fill]">Fill</button>
    <div ws-x="[col span 3]">Danger Color / Disabled / Elevated</div>
    <button ws-x="[$color @danger] [$flat]">Flat</button>
    <button ws-x="[$color @danger] [$outline]">Outline</button>
    <button ws-x="[$color @danger] [$fill]">Fill</button>
    <button disabled ws-x="[$color @danger] [$flat]">Flat</button>
    <button disabled ws-x="[$color @danger] [$outline]">Outline</button>
    <button disabled ws-x="[$color @danger] [$fill]">Fill</button>
    <button ws-x="[$color @danger] [$elevate] [$flat]">Flat</button>
    <button ws-x="[$color @danger] [$elevate] [$outline]">Outline</button>
    <button ws-x="[$color @danger] [$elevate] [$fill]">Fill</button>
    <div ws-x="[col span 3]">Warning Color / Disabled / Elevated</div>
    <button ws-x="[$color @warning] [$flat]">Flat</button>
    <button ws-x="[$color @warning] [$outline]">Outline</button>
    <button ws-x="[$color @warning] [$fill]">Fill</button>
    <button disabled ws-x="[$color @warning] [$flat]">Flat</button>
    <button disabled ws-x="[$color @warning] [$outline]">Outline</button>
    <button disabled ws-x="[$color @warning] [$fill]">Fill</button>
    <button ws-x="[$color @warning] [$elevate] [$flat]">Flat</button>
    <button ws-x="[$color @warning] [$elevate] [$outline]">Outline</button>
    <button ws-x="[$color @warning] [$elevate] [$fill]">Fill</button>
    <div ws-x="[col span 3]">Accent Color / Disabled / Elevated</div>
    <button ws-x="[$color @accent] [$flat]">Flat</button>
    <button ws-x="[$color @accent] [$outline]">Outline</button>
    <button ws-x="[$fill] [$color @accent]">Fill</button>
    <button disabled ws-x="[$color @accent] [$flat]">Flat</button>
    <button disabled ws-x="[$color @accent] [$outline]">Outline</button>
    <button disabled ws-x="[$fill] [$color @accent]">Fill</button>
    <button ws-x="[$color @accent] [$elevate] [$flat]">Flat</button>
    <button ws-x="[$color @accent] [$elevate] [$outline]">Outline</button>
    <button ws-x="[$color @accent] [$elevate] [$fill]">Fill</button>
</ws-grid>