Evoke UI is a modern, flexible, and highly customizable component library built with TypeScript and Vite. It is designed to help developers create beautiful, responsive, and accessible user interfaces with minimal effort.
- TypeScript Support: Built with TypeScript for a better development experience and type safety.
- Responsive Design: Components are designed to work seamlessly across different screen sizes.
- Accessible: Built with accessibility in mind ––to ensure your app is usable by everyone.
- Lightweight: Optimized for performance with minimal footprint.
- Dark Mode: Supports dark mode out of the box.
To install Evoke UI, you can use npm or yarn:
npm install @social-media/evoke-ui
or
yarn add @social-media/evoke-ui
After installing Evoke UI, you need to set up your project to use the components:
import React from "react";
import { Button } from "@social-media/evoke-ui";
import "@social-media/evoke-ui/dist/evoke-ui.css"; // Import default styles
const App = () => (
<div>
<Button variant="solid">Hello World</Button>
</div>
);
export default App;
- Button - A versatile button component with multiple variants and sizes (e.g., solid, outline, link).
- Input - A customizable input field for user data entry, supporting various types (text, password, email, etc.).
- Card - A card component for displaying content in a structured and visually appealing way.
- Modal - A dialog component for displaying content in an overlay above the main content.
- Tabs - A component for organizing content into tabs, with support for horizontal and vertical orientations.
- Scroll Area - A scrollable container component with customizable scroll behavior.
- Grid - A grid component for creating responsive layouts with rows and columns.
- Stack - A stack component for arranging elements in a vertical or horizontal stack.
- Container - A container component for organizing content within a fixed width or fluid layout.
- Box - A flexible container component for custom layout and styling.
- Divider - A divider component for separating content with a horizontal or vertical line.
- Avatar - An avatar component for displaying user profiles or icons.
- Toast - A toast component for temporary notifications that appear and disappear automatically.
- Tooltip - A tooltip component for displaying additional information on hover or focus.
- Progress - A progress bar component for visualizing the completion of tasks or processes.
- Skeleton - A Skeleton component is display a skeleton while content is fetching
We welcome contributions! Please follow these steps to contribute:
- Fork the repository.
- Create a new branch (git checkout -b branch-name).
- Make your changes and commit them (npm run commit).
- Push to the branch (git push origin branch-name).
- Open a pull request.
To set up a development environment:
git clone https://github.com/yourusername/evoke-ui.git
cd @social-media/evoke-ui
npm install
npm start
Published storybook link Click me
- React - A JavaScript library for building user interfaces
- TypeScript - Typed JavaScript at Any Scale
- Vite - The web framework used
- Storybook - A tool for building UI components and pages in isolation