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/vueTo 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 installto bootstrap the repo
- pnpm run devto watch the repo for changes and then recompile
- pnpm run compileto compile from mitosis components to other packages, you can give it a flag- -por- --platforms.ie- pnpm run compile -p react vue
- pnpm run c:reactor- pnpm run c:vueto compile specifically to react or vue
- pnpm run clearto clean- .node_modulesor- pnpm run clear:assetsto clean build/compile output
- pnpm run clear:cacheto clean cache folder used by bundlers
 We create components inside a single source of truth folder
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 framework
- c:<target>to compile and bundle target framework, it's equivalent to sequentially running- pnpm run t:<target> && pnpm run b:<target>
- 
Component file names must end with *.lite.tsx
- 
Style sheets must be in *.css.tsfiles, this is because we use a styling solution calledvanilla-extractto 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 useStorehook 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-ondirective in Vue
 
- Event handlers in 
A unified toolkit for building applications and smart contracts in the Interchain ecosystem
| Category | Tools | Description | 
|---|---|---|
| Chain Information | Chain Registry, Utils, Client | Everything from token symbols, logos, and IBC denominations for all assets you want to support in your application. | 
| Wallet Connectors | Interchain Kitbeta, Cosmos Kit | Experience the convenience of connecting with a variety of web3 wallets through a single, streamlined interface. | 
| Signing Clients | InterchainJSbeta, CosmJS | A single, universal signing interface for any network | 
| SDK Clients | Telescope | Your Frontend Companion for Building with TypeScript with Cosmos SDK Modules. | 
| Starter Kits | Create Interchain Appbeta, Create Cosmos App | Set up a modern Interchain app by running one command. | 
| UI Kits | Interchain UI | The Interchain Design System, empowering developers with a flexible, easy-to-use UI kit. | 
| Testing Frameworks | Starship | Unified Testing and Development for the Interchain. | 
| TypeScript Smart Contracts | Create Hyperweb App | Build and deploy full-stack blockchain applications with TypeScript | 
| CosmWasm Contracts | CosmWasm TS Codegen | Convert your CosmWasm smart contracts into dev-friendly TypeScript classes. | 
🛠 Built by Hyperweb (formerly Cosmology) — if you like our tools, please checkout and contribute to our github ⚛️
Checkout mitosis from BuilderIO to compile lite JSX.
AS DESCRIBED IN THE LICENSES, THE SOFTWARE IS PROVIDED “AS IS”, AT YOUR OWN RISK, AND WITHOUT WARRANTIES OF ANY KIND.
No developer or entity involved in creating this software will be liable for any claims or damages whatsoever associated with your use, inability to use, or your interaction with other users of the code, including any direct, indirect, incidental, special, exemplary, punitive or consequential damages, or loss of profits, cryptocurrencies, tokens, or anything else of value.