https://github.com/kristerkari/react-native-stylus-transformer
Use Stylus to style your React Native apps.
https://github.com/kristerkari/react-native-stylus-transformer
loader react-native stylus transform
Last synced: 29 days ago
JSON representation
Use Stylus to style your React Native apps.
- Host: GitHub
- URL: https://github.com/kristerkari/react-native-stylus-transformer
- Owner: kristerkari
- License: mit
- Created: 2018-04-02T20:41:35.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-05-16T09:01:07.000Z (11 months ago)
- Last Synced: 2025-03-17T10:40:19.516Z (about 1 month ago)
- Topics: loader, react-native, stylus, transform
- Language: JavaScript
- Homepage:
- Size: 337 KB
- Stars: 13
- Watchers: 2
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# react-native-stylus-transformer [](https://www.npmjs.org/package/react-native-stylus-transformer) [](http://npmcharts.com/compare/react-native-stylus-transformer?periodLength=30) [](https://egghead.io/courses/how-to-contribute-to-an-open-source-project-on-github)
Use [Stylus](https://github.com/stylus/stylus) to style your React Native apps.
Behind the scenes the `.styl` files are transformed to [react native style objects](https://facebook.github.io/react-native/docs/style.html) (look at the examples).
> This transformer can be used together with [React Native CSS modules](https://github.com/kristerkari/react-native-css-modules).
## How does it work?
Your `App.styl` file might look like this:
```css
.myClass {
color: blue;
}
.myOtherClass {
color: red;
}
.my-dashed-class {
color: green;
}
```When you import your stylesheet:
```js
import styles from "./App.styl";
```Your imported styles will look like this:
```js
var styles = {
myClass: {
color: "blue"
},
myOtherClass: {
color: "red"
},
"my-dashed-class": {
color: "green"
}
};
```You can then use that style object with an element:
**Plain React Native:**
```jsx
```
**[React Native CSS modules](https://github.com/kristerkari/react-native-css-modules) using [className](https://github.com/kristerkari/babel-plugin-react-native-classname-to-style) property:**
```jsx
```
**[React Native CSS modules](https://github.com/kristerkari/react-native-css-modules) using [styleName](https://github.com/kristerkari/babel-plugin-react-native-stylename-to-style) property:**
```jsx
```
## Installation and configuration
### Step 1: Install
```sh
npm install --save-dev react-native-stylus-transformer stylus
```or
```sh
yarn add --dev react-native-stylus-transformer stylus
```### Step 2: Configure the react native packager
#### For Expo SDK v41.0.0 or newer
Merge the contents from your project's `metro.config.js` file with this config (create the file if it does not exist already).
`metro.config.js`:
```js
const { getDefaultConfig } = require("expo/metro-config");module.exports = (() => {
const config = getDefaultConfig(__dirname);const { transformer, resolver } = config;
config.transformer = {
...transformer,
babelTransformerPath: require.resolve("react-native-stylus-transformer")
};
config.resolver = {
...resolver,
sourceExts: [...sourceExts, "styl"]
};return config;
})();
```---
#### For React Native v0.72.1 or newer
Merge the contents from your project's `metro.config.js` file with this config (create the file if it does not exist already).
`metro.config.js`:
```js
const { getDefaultConfig, mergeConfig } = require("@react-native/metro-config");const defaultConfig = getDefaultConfig(__dirname);
const { assetExts, sourceExts } = defaultConfig.resolver;/**
* Metro configuration
* https://reactnative.dev/docs/metro
*
* @type {import('metro-config').MetroConfig}
*/
const config = {
transformer: {
babelTransformerPath: require.resolve("react-native-stylus-transformer")
},
resolver: {
sourceExts: [...sourceExts, "styl"]
}
};module.exports = mergeConfig(defaultConfig, config);
```## CSS Custom Properties (CSS variables)
_You need version 1.2.0 or newer_
```css
:root {
--text-color: blue;
}.blue {
color: var(--text-color);
}
```CSS variables are not supported by default, but you can add support for them by using [PostCSS](https://postcss.org/) and [postcss-css-variables](https://github.com/MadLittleMods/postcss-css-variables#readme) plugin.
Start by installing dependencies:
```sh
npm install postcss postcss-css-variables react-native-postcss-transformer --save-dev
```or
```sh
yarn add postcss postcss-css-variables react-native-postcss-transformer --dev
```Add `postcss-css-variables` to your PostCSS configuration with [one of the supported config formats](https://github.com/michael-ciniawsky/postcss-load-config), e.g. `package.json`, `.postcssrc`, `postcss.config.js`, etc.
After that create a `transformer.js` file and do the following:
```js
const upstreamTransformer = require("@react-native/metro-babel-transformer");
const stylusTransformer = require("react-native-stylus-transformer");
const postCSSTransformer = require("react-native-postcss-transformer");module.exports.transform = function({ src, filename, ...rest }) {
if (filename.endsWith(".styl")) {
return stylusTransformer
.renderToCSS({ src, filename, options })
.then(css =>
postCSSTransformer.transform({ src: css, filename, ...rest })
);
} else {
return upstreamTransformer.transform({ src, filename, ...rest });
}
};
```After that in `metro.config.js` point the `babelTransformerPath` to that file:
```diff
-require.resolve("react-native-stylus-transformer")
+require.resolve("./transformer.js")
```## Dependencies
This library has the following Node.js modules as dependencies:
- [css-to-react-native-transform](https://github.com/kristerkari/css-to-react-native-transform)