Skip to main content

Design System Components

When building components, the NEAR VM provides a complete set of Radix primitives to simplify UI development.

Radix UI​

Using embedded Radix primitives on the NEAR VM is simple and straight-forward. You don't need to import any files:

return (
<Label.Root className="LabelRoot">
Hello World!
</Label.Root>
);
Limitations

Currently, NEAR VM impose some limitations on the Radix UI framework:

  • Form component is not available.
  • You can't use .Portal definitions.
  • Using CSS is different. You'll have to use a styled.div wrapper.

Using CSS​

Here is an example on how to use CSS through the styled.div wrapper:

const Wrapper = styled.div`
.SwitchRoot {
...
}
.SwitchThumb {
...
}
`;

return (
<Wrapper>
<Switch.Root className="SwitchRoot">
<Switch.Thumb className="SwitchThumb" />
</Switch.Root>
</Wrapper>
);

Using styled-components​

You can use styled-components in combination with Radix UI primitives. Here's an example:

const SwitchRoot = styled("Switch.Root")`
all: unset;
display: block;
width: 42px;
height: 25px;
background-color: var(--blackA9);
border-radius: 9999px;
position: relative;
box-shadow: 0 2px 10px var(--blackA7);

&[data-state="checked"] {
background-color: black;
}
`;

const SwitchThumb = styled("Switch.Thumb")`
all: unset;
display: block;
width: 21px;
height: 21px;
background-color: white;
border-radius: 9999px;
box-shadow: 0 2px 2px var(--blackA7);
transition: transform 100ms;
transform: translateX(2px);
will-change: transform;

&[data-state="checked"] {
transform: translateX(19px);
}
`;

return (
<SwitchRoot>
<SwitchThumb />
</SwitchRoot>
);

Forward references​

The NEAR VM re-implements React's forwardRef as ref="forwardedRef".

You can use ref="forwardedRef" to forward references through <Widget /> to support Radix's asChild property:

Dialog.jsx
<AlertDialog.Trigger asChild>
<Widget
src="near/widget/TestButton"
props={{ label: "Click Me" }}
/>
</AlertDialog.Trigger>
TestButton.jsx
const Button = styled.button`
background: #f00;
`;

return (
<Button type="button" ref="forwardedRef">
{props.label}: Forwarded
</Button>
);

UI is Near​

UI is Near is community-built library offering a comprehensive collection of UI components providing a solid foundation for creating intuitive and visually appealing user interfaces for dApps, wallets or other Web3 solutions.

tip

You can find the documentation, available components, and code examples following this this link.

DIG components​

These are the Decentralized Interface Guidelines (DIG) components available on the NEAR VM:

tip

If you want to see working demos of these components, check the DIG Overview page.


DIG.Accordion​

An accordion built with the Radix primitive.

Loading...
DIG.Accordion properties

Click here for properties and details.


DIG.Avatar​

This component renders an avatar.

Loading...
DIG.Avatar properties

Click here for properties and details.


DIG.Badge​

This component renders a badge. Badges are not meant to be clickable. Refer to DIG.Button or DIG.Chip for clickable alternatives.

Loading...
DIG.Badge properties

Click here for properties and details.


DIG.Button​

A fully featured button component that can act as a <button> or <a> tag.

Loading...
DIG.Button properties

DIG.Checkbox​

A checkbox built with the Radix primitive.

Loading...
DIG.Checkbox properties

Click here for properties and details.


DIG.Chip​

A fully featured chip component that can act as a <button> or <a> tag.

Loading...
DIG.Chip properties

Click here for properties and details.


DIG.Dialog​

This Dialog component is built with the Radix primitive.

Loading...
DIG.Dialog properties

Click here for properties and details.


DIG.DropdownMenu​

This dropdown menu is built with the Radix primitive.

Loading...
DIG.DropdownMenu properties

Click here for properties and details.


DIG.Input​

A text input component.

Loading...
DIG.Input properties

Click here for properties and details.


DIG.InputSearch​

An input component for typing a search query.

Loading...
DIG.InputSearch properties

Click here for properties and details.


DIG.InputSelect​

A select input component built with the Radix primitive.

Loading...
DIG.InputSelect properties

Click here for properties and details.


DIG.InputTags​

An input component that handles adding and removing tags.

Loading...
DIG.InputTags properties

Click here for properties and details.


DIG.InputTextarea​

A textarea input component.

Loading...
DIG.InputTextarea properties

Click here for properties and details.


DIG.Tabs​

This tabs component is built with the Radix primitive.

Loading...
DIG.Tabs properties

Click here for properties and details.


DIG.Theme​

This component wraps all of NEAR Components so you don't need to render it yourself.

tip

You can use any of the CSS variables defined inside DIG.Theme.


DIG.Toast​

This toast component is built with Radix primitive.

Loading...
DIG.Toast properties

Click here for properties and details.


DIG.Tooltip​

A tooltip built with the Radix primitive.

Loading...
DIG.Tooltip properties

Click here for properties and details.

Was this page helpful?