Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/retyui/react-native-stylex
Better styling for react-native
https://github.com/retyui/react-native-stylex
react-native react-native-media-queries react-native-style react-native-theme
Last synced: 10 days ago
JSON representation
Better styling for react-native
- Host: GitHub
- URL: https://github.com/retyui/react-native-stylex
- Owner: retyui
- License: mit
- Created: 2020-01-10T19:52:19.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-02-25T22:15:35.000Z (11 months ago)
- Last Synced: 2025-01-07T01:58:55.845Z (14 days ago)
- Topics: react-native, react-native-media-queries, react-native-style, react-native-theme
- Language: TypeScript
- Homepage: https://snack.expo.io/@retyui/react-native-stylex
- Size: 2.14 MB
- Stars: 106
- Watchers: 6
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# react-native-stylex
Better styling for react-native
[![react-native-stylex on npm](https://badgen.net/npm/v/react-native-stylex)](http://www.npmjs.com/package/react-native-stylex)
[![react-native-stylex downloads](https://badgen.net/npm/dm/react-native-stylex)](https://www.npmtrends.com/react-native-stylex)
[![react-native-stylex install size](https://packagephobia.com/badge?p=react-native-stylex)](https://packagephobia.com/result?p=react-native-stylex)
[![CI status](https://github.com/retyui/react-native-stylex/workflows/Node.js%20CI/badge.svg)](https://github.com/retyui/react-native-stylex/actions)### Module features:
- 📦 Very light and simple;
- ⚡️ Hooks \ HoC support;
- 🔋 Theming support;
- ⛱️ [Typescript support](docs/ts.md);
- 📝 [Easy integrated with Jest](docs/testting.md).### Integrations
- 🛡️ [react-native-safe-area-view](docs/safe-area.md);
- 🗺 [i18n](docs/i18n.md);
- 🕳️ [Appearance (a.k.a Dark mode)](docs/appearance.md);
- 📐 [Dimensions](docs/dimensions.md);
- 📲 [Orientation](docs/orientation.md);
- 💉 [Media Queries](docs/media-query.md) support.### Links
- [Documentation](docs/api.md);
- [Live demo](https://snack.expo.io/@retyui/react-native-stylex);
- [Example app](example/AppStyleX).## Install
`react-native-stylex` requires react-native 0.59.0 or later.
#### 1️⃣ Add module
```sh
yarn add react-native-stylex# or npm install react-native-stylex
```#### 2️⃣ Add theme ``
Stylex provides component, which makes the theme available to the rest of your app:
```js
import { ThemeProvider } from "react-native-stylex";
import {
createBreakpointsMatcher,
createBreakpoints,
maxWidth,
} from "react-native-stylex/media-query";const breakpoints = {
xs: 360,
sm: 600,
md: 960,
lg: 1280,
xl: 1920,
};
const { up, down, only, between } = createBreakpoints(breakpoints);
const applyBreakpoints = createBreakpointsMatcher(breakpoints, maxWidth);const theme = {
palette: { textColor: "black" },
breakpoints: { up, down, only, between, apply: applyBreakpoints },
utils: {
fade: (color, value) => {},
},
};const Root = () => (
);export default Root;
```#### 3️⃣ Create styles `makeUseStyles(...)`
Stylex provides a helper function to inject styles to your component.
Normally, you’ll use it in this way:
```js
import { makeUseStyles } from "react-native-stylex";
import { maxWidth } from "react-native-stylex/media-query";export const useStyles = makeUseStyles(({ palette, utils, breakpoints }) => ({
root: {
color: utils.fade(palette.textColor, 0.5),
height: 100,
// On screens that are 320 or less, set the height to 69
...maxWidth(320, { height: 69 }),
},text: {
fontSize: 16, // default value
...breakpoints.down("lg", { fontSize: 18 }), // if window width 0..1280
...breakpoints.down("sm", { fontSize: 20 }), // if window width 0..600
},// The same example that you see above but unsing a 'applyBreakpoints'
title: {
fontSize: breakpoints.apply({
sm: 20, // if window width 0....600
lg: 18, // if window width 601..1280
default: 16, // if window width 1281...
}),
},
}));
```#### 4️⃣ Inject styles `useStyles(...)` & `withStyles(...)`
And finally just use in component:
```js
import React, { Component } from "react";
import useStyles from "./styles";// Functional component (hooks variant)
const Root = () => {
const styles = useStyles();return ;
};export default Root;
//--------------------------------
// Class component (HOC variant)
class Root extends Component {
render() {
const { styles } = this.props;return ;
}
}export default withStyles(useStyles)(Root);
```### 5️⃣ Do you use a Typescript ?
- Look at [typescript](docs/ts.md) guide
### Alternative solutions
- [@emotion/native
](https://emotion.sh/docs/@emotion/native) [![react-native-stylex downloads](https://badgen.net/npm/dm/@emotion/native)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [nativewind](https://nativewind.dev/) [![react-native-stylex downloads](https://badgen.net/npm/dm/nativewind)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [@shopify/restyle](https://shopify.github.io/restyle/) [![react-native-stylex downloads](https://badgen.net/npm/dm/@shopify/restyle)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [tamagui](https://tamagui.dev/) [![react-native-stylex downloads](https://badgen.net/npm/dm/tamagui)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [twrnc](https://github.com/jaredh159/tailwind-react-native-classnames) [![react-native-stylex downloads](https://badgen.net/npm/dm/twrnc)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [tailwind-rn](https://github.com/vadimdemedes/tailwind-rn) [![react-native-stylex downloads](https://badgen.net/npm/dm/tailwind-rn)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [dripsy](https://www.dripsy.xyz/) [![react-native-stylex downloads](https://badgen.net/npm/dm/dripsy)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [react-native-unistyles](https://reactnativeunistyles.vercel.app/) [![react-native-stylex downloads](https://badgen.net/npm/dm/react-native-unistyles)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [react-native-zephyr](https://formidable.com/open-source/react-native-zephyr/) [![react-native-stylex downloads](https://badgen.net/npm/dm/react-native-zephyr)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)
- [@fast-styles/react](https://fedemartinm.github.io/fast-styles/) [![react-native-stylex downloads](https://badgen.net/npm/dm/@fast-styles/react)](https://npmtrends.com/@emotion/native-vs-@fast-styles/react-vs-@shopify/restyle-vs-dripsy-vs-nativewind-vs-react-native-unistyles-vs-react-native-zephyr-vs-tailwind-rn-vs-tamagui-vs-twrnc)