The Design System for the Interchain
Interchain UI is a foundation library for UI elements used in cosmos-kit and other packages. It provides developers with pre-built components and a foundation for creating user interfaces across different frameworks, such as VueJS, React, Angular, Svelte, SolidJS, and Web Components, enabling developers to customize UI elements and themes. This gives us the ability to code a component once, and it will compile to all framework targets.
# If you use react
yarn add @interchain-ui/react
# If you use vue
yarn add @interchain-ui/vue
To see how to use with react, see our react documentation
We are using Lerna + PNPM to bootstrap the monorepo. First make sure you install PNPM locally first, then run these commands:
pnpm install
to bootstrap the repopnpm run dev
to watch the repo for changes and then recompilepnpm run compile
to compile from mitosis components to other packages, you can give it a flag-p
or--platforms
.iepnpm run compile -p react vue
pnpm run c:react
orpnpm run c:vue
to compile specifically to react or vuepnpm run clear
to clean.node_modules
orpnpm run clear:assets
to clean build/compile outputpnpm run clear:cache
to clean cache folder used by bundlers
We create components inside a single source of truth folder <root>/src
with Lite JSX format (.lite.tsx
), then through our compiler, it's going to compile our components and build it in sub packages' src
and dist
.
To know more about the inner workings of our compiler, check Compiler to explore.
Check Icon guide to know how to add more icons
Check Customizing guide to know how to customize the default theme.
t:<target>
to compile target framework (t is short for transpile)b:<target>
to bundle target frameworkc:<target>
to compile and bundle target framework, it's equivalent to sequentially runningpnpm run t:<target> && pnpm run b:<target>
-
Component file names must end with
*.lite.tsx
-
Style sheets must be in
*.css.ts
files, this is because we use a styling solution calledvanilla-extract
to have a CSS-in-JS API across all frameworks. -
For a component, you must use default export, not named export. This is a limitation of Mitosis
-
There are more rules and limitations, please read more about Mitosis here
-
To quickly test to see the compilation result from one Mitosis to any framework source code, please use mitosis sandbox. It's similar to TS playground but for Mitosis testing purpose.
-
[Vue specifics] Event handlers
- Event handlers in
<template>
must be prefixed withon
- Event handlers must be defined in
useStore
hook with a getter functionget eventHandlers()
with exact name. A template for this is as below:
get eventHandlers() { const handlers: Record<string, (event: any) => void> = {}; const eventProps = [ "onClick", "onDoubleClick", // Add other event names here ] eventProps.forEach((eventName) => { if (props[eventName]) { handlers[eventName] = (event: any) => props[eventName](event); } }); return handlers; }
- You can then attach the event handlers to the JSX tag with spread attribute
{...state.eventHandlers}
, this will be transformed to be av-on
directive in Vue
- Event handlers in
Checkout these related projects:
- telescope Your Frontend Companion for Building with TypeScript with Cosmos SDK Modules.
- @cosmwasm/ts-codegen Convert your CosmWasm smart contracts into dev-friendly TypeScript classes.
- chain-registry Everything from token symbols, logos, and IBC denominations for all assets you want to support in your application.
- cosmos-kit Experience the convenience of connecting with a variety of web3 wallets through a single, streamlined interface.
- create-cosmos-app Set up a modern Cosmos app by running one command.
- interchain-ui The Interchain Design System, empowering developers with a flexible, easy-to-use UI kit.
- starship Unified Testing and Development for the Interchain.
Checkout mitosis
from BuilderIO to compile lite JSX.
🛠 Built by Hyperweb (formerly Cosmology) — if you like our tools, please checkout and contribute to our github ⚛️