UNPKG

@synergycodes/overflow-ui

Version:

A React library for creating node-based UIs and diagram-driven applications. Perfect for React Flow users, providing ready-to-use node templates and components that work seamlessly with React Flow's ecosystem.

152 lines (103 loc) β€’ 4.39 kB
# @synergycodes/overflow-ui A React library for creating node-based user interfaces and diagram-driven apps. Built to work seamlessly with React Flow, it provides a collection of ready-to-use components and templates that simplify the development of visual editors, workflows, and interactive diagrams. Developed and maintained by **[Synergy Codes](https://www.synergycodes.com/)**. ## Quick Start: 3-Minute Guide ### πŸ“¦ Installation Use one of the commands below to add **Overflow UI** to your project: ```bash npm install @synergycodes/overflow-ui ``` ```bash pnpm add @synergycodes/overflow-ui ``` ```bash yarn add @synergycodes/overflow-ui ``` ### 🎨 Import styles Add to your style sheet or component: ```css @import '@synergycodes/overflow-ui/tokens.css'; ``` ```tsx import '@synergycodes/overflow-ui/tokens.css'; ``` ### πŸŽ›οΈ Apply the Theme To make the styles use proper variables, include data-theme (light or dark) attribute in <html>: ```html <html data-theme="light"> ``` ### 🧱 Use components ```tsx import { Input } from '@synergycodes/overflow-ui'; // … <Input value={value} onChange={onChange} />; ``` ## Overview Forget cobbling together UI kits with diagram libraries. Overflow UI provides a unified set of designed, ready-to-use components: buttons, inputs, accordions, node templates, and more β€” all built to work seamlessly together. ## Features - Unified Component System: Seamlessly integrated UI and diagram components - Ready-to-use Components: Comprehensive set of pre-built components - Token-based Customization: Easy theming through CSS variables - Developer-friendly: Focus on developer experience and productivity - React Flow Compatible: Perfect for React Flow users with pre-built node templates that match React Flow's styling ## Customization Each Overflow UI component uses CSS variables that are derived from primitive values. You can override them: ```css :root { --ax-ui-bg-primary-default: #40ba12; } ``` or a derived value used by the selected component: ```css :root { --ax-public-date-picker-dropdown-background: #40ba12; } ``` ### Overflow UI css layers Overflow UI uses [CSS layers](https://developer.mozilla.org/en-US/docs/Web/CSS/@layer) to separate its styles from yours. By default, CSS styles outside of any layer take precedence over what Overflow UI defines, so your styles will always win the specificity war. You can customize Overflow UI components with simple `input {}`. ```css @layer ui.component { .separator { /* … */ } } ``` Default Overflow UI order: ```css @layer ui.base, ui.component; ``` # πŸ› οΈ Development To develop and test components, follow these steps in monorepo root: 1. Install dependencies: ```bash pnpm i ``` 2. Build UI: ```bash pnpm ui build ``` 3. Run preview page: ```bash pnpm ui preview ``` Now visit `localhost:3000` to see every change in components reflected in the preview page. Edit `ui/preview-page/preview-page.tsx` to display desired components. ### πŸ“£ Important Note on Underlying Technology > **Overflow UI is built on top of [MUI Base](https://v6.mui.com/base-ui/getting-started/), a headless component library that focuses on accessibility and logic, while leaving the styling up to us.** > > Thanks to MUI Base, Overflow UI provides components that are **accessible by default** and **fully customizable** through our design tokens. > > We are aware that **MUI Base has been deprecated**, and the MUI team recommends migrating to [Base UI](https://base-ui.com). > However, after careful evaluation, we've chosen to **stay with MUI Base** for now because: > > * βœ… **Base UI is not yet mature enough** for our needs. > * βœ… We want to ensure a stable, well-tested experience for Overflow UI users. > > This is a **conscious and informed decision**. > We will continue to monitor Base UI's progress and will consider migrating when we feel it's the right time, ensuring a smooth and thoughtful transition for Overflow UI users. > > If you have any questions or concerns, feel free to reach out β€” we’re happy to share our reasoning and plans in more detail! ## Showcase **[Workflow Builder](https://www.workflowbuilder.io/)** is a frontend-focused starter app for building workflows, offering core features, best practices, and easy backend integration for faster client delivery. https://www.workflowbuilder.io/