Socket
Book a DemoInstallSign in
Socket

rn-stylewind

Package Overview
Dependencies
Maintainers
0
Versions
25
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

rn-stylewind

A utility-first styling library for React Native with dynamic theming

0.2.26
latest
Source
npmnpm
Version published
Weekly downloads
10
11.11%
Maintainers
0
Weekly downloads
Β 
Created
Source

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! πŸš€

Keywords

react-native

FAQs

Package last updated on 12 Mar 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

About

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.

  • Terms
  • Privacy
  • Security

Made with ⚑️ by Socket Inc

U.S. Patent No. 12,346,443 & 12,314,394. Other pending.