Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vinpac/windstitch
Windstitch is a 1.4kB, Simple Styling Library that helps you set when a className should be applied to a component.
https://github.com/vinpac/windstitch
design react styled tailwindcss variants
Last synced: 4 days ago
JSON representation
Windstitch is a 1.4kB, Simple Styling Library that helps you set when a className should be applied to a component.
- Host: GitHub
- URL: https://github.com/vinpac/windstitch
- Owner: vinpac
- License: mit
- Created: 2022-04-17T02:09:48.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2023-08-02T14:34:07.000Z (over 1 year ago)
- Last Synced: 2025-02-07T05:08:05.245Z (14 days ago)
- Topics: design, react, styled, tailwindcss, variants
- Language: TypeScript
- Homepage: https://windstitch.vercel.app
- Size: 1.11 MB
- Stars: 255
- Watchers: 2
- Forks: 6
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/d267e/d267e8879442950e3f7c31a5d964c3e0060fd3d2" alt="Windstitch"
# Windstitch
Windstitch is a **1.4kB**, Simple Styling Library that helps you set **when** a className should be applied to a component.
By providing Powerful Types through forward declarations, Windstitch aims to be simple yet powerful by limiting itself to be a organizer API, letting Tailwind handle the styling part.
data:image/s3,"s3://crabby-images/dec7d/dec7dcfb714edffb45e97a1c243bf6c550ce5036" alt="Usage"
# Install
Install Windstitch from your terminal via npm or yarn.
```bash
# With npm
npm install windstitch# With yarn
yarn add windstitch
```### Import it
Import `styled` from `windstitch`.
```js
import { styled } from 'windstitch';
```You can also import `w`, which works as an alias for `styled`
```typescript
import { w } from 'windstitch';
```### Use it
Use the `w` function to create a component and add styles to it.
```jsx line=3-11
import { w } from '@wind/react';const Button = w.button('text-sm', {
variants: {
color: {
red: 'text-red-500',
blue: 'text-blue-500',
},
size: {
small: 'text-sm',
large: 'text-lg',
},
},
defaultVariants: {
size: 'small',
},
});
type ButtonProps = W.infer;
// { color: 'red' | 'blue', size?: 'small' | 'large' }
```