Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
react-native-storybook-loader
Advanced tools
A CLI for dynamically importing stories into [react-native-storybook](https://github.com/storybooks/react-native-storybook).
A CLI for dynamically importing stories into react-native-storybook.
While using storybook for React Native, I repeatedly found myself manually creating a file with imports for all my stories. So I built an automated way to do it. react-native-storybook-loader
can be run using configuration in your package.json
or via the CLI interface and it generates a file with all the imports for you.
yarn add react-native-storybook-loader -D
Or
npm install react-native-storybook-loader --save-dev
Create a React Native project using create-react-native-app
create-react-native-app AwesomeProject
Add react-native-storybook to the project using getstorybook
cd AwesomeProject
getstorybook
Install react-native-storybook-loader
yarn add react-native-storybook-loader -D
Update index.js
file in the ./storybook
directory to point to storyLoader.js
(this file will be generated before launching Storybook).
import { getStorybookUI, configure } from '@storybook/react-native';
import { loadStories } from './storyLoader';
configure(() => {
loadStories()
}, module);
const StorybookUI = getStorybookUI({ port: 7007, host: 'localhost' });
export default StorybookUI;
Add the rnstl
cli to the scripts tag of the package.json
{
"scripts": {
"prestorybook": "rnstl"
}
}
Run Storybook
yarn storybook
Or
npm run storybook
Run react-native on the targeted platform
react-native run-android
Or
react-native run-ios
Note: If you have problems connecting from your device to Storybook using Android issue the following command: adb reverse tcp:7007 tcp:7007
.
Story loading is controlled by the react-native-storybook-loader
section of the project's package.json
.
Setting | CLI Option | Type | Description | Default |
---|---|---|---|---|
searchDir | --searchDir | string or string[] | The directory or directories, relative to the project root, to search for files in. | Project root |
outputFile | --outputFile | string | The output file that will be written. It is relative to the project directory. | ./storybook/storyLoader.js |
pattern | --pattern | string | The pattern of files to look at. It can be a specific file, or any valid glob. Note: if using the CLI, globs with **/*... must be escaped with quotes | ./storybook/stories/index.js (The default React Native storybook file) |
--silent | Silences output. This option is not supported in the package.json file. |
Note: When using the CLI, any of option passed will override the values in the
package.json
Both examples below will search src
and packages
directories recursively for files that end with .stories.js
and write the output to ./storybook/storyLoader.js
package.json
{
"name": "AwesomeProject",
"scripts": {
"prestorybook": "rnstl"
},
"config": {
"react-native-storybook-loader": {
"searchDir": ["./src", "./packages"],
"pattern": "**/*.stories.js",
"outputFile": "./storybook/storyLoader.js"
}
}
}
Breaking Change
CLI can now be accessed from a terminal
./node_modules/.bin/rnstl <options>
or in package.json
{
"scripts": {
"prestorybook": "rnstl <options>"
}
}
Note: When using a glob with **/*
it is required to be wrapped in quotes
There is no longer a need to use node ./node_modules/.bin/rnstl <options>
.
$ ./node_modules/.bin/rnstl --searchDir ./src ./packages --pattern "**/*.stories.js" --outputFile ./storybook/storyLoader.js
Please log issues
Coming Soon
FAQs
A CLI for dynamically importing stories into [Storybook for React Native](https://storybook.js.org/docs/guides/guide-react-native/).
The npm package react-native-storybook-loader receives a total of 54,456 weekly downloads. As such, react-native-storybook-loader popularity was classified as popular.
We found that react-native-storybook-loader demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
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.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.