0.2.26 β€’ Published 5 months ago

rn-stylewind v0.2.26

Weekly downloads
-
License
MIT
Repository
github
Last release
5 months ago

React Native Stylewind

Ever wished you had the flexibility of utility-first styling in React Native, but with better maintainability, type-safety, and more developer freedom? Well, that's exactly what React Native Stylewind delivers! πŸŽ‰ With this library, you can enjoy dynamic style generation based on your custom theme, and still keep your styles clean, reusable, and highly maintainable.

Use utility styles for quick styling or leverage createStyle for more structured, theme-based styles. With full TypeScript support, you get the best of both worldsβ€”ease of use and robust, type-safe development.

✨ Features

  • 🎨 Dynamic Theming – Utility styles are generated on the fly based on your theme.config.ts.
  • ⚑ Tailwind-Like Styling – Use familiar utility styles for a seamless styling experience.
  • πŸ› οΈ Highly Customizable – Define your own colors, utilities, spacing, typography.
  • πŸ” Type-Safe – Full TypeScript support ensures your styles are always correct.
  • πŸš€ Real-Time Updates – Styles regenerate automatically when your theme changes.
  • πŸ›† Tree-Shaking for Performance – Unused styles get kicked out, keeping your bundle lean.
  • πŸ’‘ Flexible Usage – Use utility-first styles or createStyle with theme configurations.

πŸ‘₯ Installation

First, install the package via npm or yarn:

npm install rn-stylewind
# or
yarn add rn-stylewind

πŸ› οΈ Setup

Before diving in, wrap your Metro bundler config to enable dynamic style generation.

1️⃣ Add to metro.config.js

const { getDefaultConfig } = require('expo/metro-config');
const withRNStylewind = require('rn-stylewind/metro');

const defaultConfig = getDefaultConfig(__dirname);

module.exports = withRNStylewind(defaultConfig);

2️⃣ Initialize Default Theme Configuration

To initialize and create the default theme.config.mjs file, run the following command:

npx init-rn-stylewind

This will generate a theme.config.mjs file in the root directory of your project as below. You can customize this file to define your theme colors, spacing, typography, utilities.

// theme.config.mjs
import { createTheme } from 'rn-stylewind';

export default await createTheme({
  mode:'light',
  colors: {
    primary: {
      default: '#1D4ED8',
      light: '#93C5FD',
      dark: '#1E3A8A',
    },
  },
  spacing: {
    default: 8,
  },
  // Modify other theme settings if needed
});

🎯 Usage

Wrap your application with ThemeProvider to ensure your styles and theme configurations are accessible throughout the project:

import { ThemeProvider } from 'rn-stylewind';
import MyComponent from './MyComponent';

function App() {
  return (
    <ThemeProvider>
      <MyComponent />
    </ThemeProvider>
  );
}

Here’s how simple and powerful stylewind is:

import { Text, Pressable } from 'react-native';
import {  styles } from 'rn-stylewind';

// πŸš€ Utility-first styling at its finest!
export const Button = ({ title, ...rest }) => {
  return (
    <Pressable style={styles(['bgError', 'p-5'])} {...rest}>
      <Text style={styles(['textWhite', 'text-lg'])}>{title}</Text>
    </Pressable>
  );
};

Using styles Function

The styles function allows developers to apply utility styles easily. If a color-based utility class does not specify a Dark or Light mode variant, styles will automatically pick the appropriate color based on the current theme mode.

<View style={styles(['bgPrimary'])}> // if mode is `light`, `bgPrimary` will return `bgPrimaryLight` color
  <Text style={styles(['textBase'])}>Dynamic Themed Text</Text> 
</View>

Using createStyle

The createStyle function enables structured, reusable styles with full TypeScript support and theme-based values.

import { createStyle, styles } from 'rn-stylewind';

const useMyStyles = createStyle({
  container: (theme) => ({
    padding: theme.spacing.md,
    backgroundColor: theme.utilities.bgBackground.backgroundColor,
    ...theme.utilities['p-1'] // using utility style
  }),
  text: {
    padding: 4
  },
});

function MyComponent() {
  const myStyles = useMyStyles();
  return (
    <View style={styles([myStyles.container])}>
      <Text style={styles([myStyles.text])}>Hello, world!</Text>
    </View>
  );
}

Using useTheme Hook

To access the theme context, use the useTheme hook:

import { useTheme,styles } from 'rn-stylewind';

export const MyComponent = () => {
  const { theme, isDarkMode, toggleMode } = useTheme();
  
  return (
    <View style={styles([isDarkMode ? 'bgBlack' : 'bgWhite'])}>
      <Text style={styles(['textPrimary'])}>Current Theme: {theme.mode}</Text>
      <Button title="Toggle Theme" onPress={toggleMode} />
    </View>
  );
}

Now, you can use useTheme() in your components to access the theme and utilities dynamically.

πŸ“š Documentation

For full documentation, visit React Native Stylewind.

Platform Support

supports Expo supports iOS supports Android supports web

React Native Stylewind is 100% compatible with the Expo Framework and works with both Expo Go and in the bare workflow.

πŸ”₯ Why You'll Love It

βœ… No more inline styles cluttering your components\ βœ… Faster development with utility-driven styling\ βœ… Built for performance with tree-shaking\ βœ… Theming that just makes sense\ βœ… Flexibility to use utility styles or structured styles

Now go forth and style like a boss! πŸš€

0.2.26

5 months ago

0.2.25

6 months ago

0.2.24

6 months ago

0.2.23

6 months ago

0.2.22

6 months ago

0.2.21

6 months ago

0.2.20

6 months ago

0.2.17

6 months ago

0.2.16

6 months ago

0.2.15

6 months ago

0.2.14

6 months ago

0.2.13

6 months ago

0.2.12

6 months ago

1.0.11

6 months ago

1.0.10

6 months ago

1.0.9

6 months ago

1.0.8

6 months ago

1.0.7

6 months ago

1.0.6

6 months ago

1.0.5

6 months ago

1.0.4

6 months ago

1.0.3

6 months ago

1.0.2

6 months ago

1.0.1

6 months ago

1.0.0

6 months ago