All Projects β†’ elderfo β†’ React Native Storybook Loader

elderfo / React Native Storybook Loader

Licence: mit
An automatic story loader for react-native-storybooks

Programming Languages

javascript
184084 projects - #8 most used programming language
typescript
32286 projects

Projects that are alternatives of or similar to React Native Storybook Loader

2019 12
🎟 κΈ‰μ¦ν•˜λŠ” νŠΈλž˜ν”½μ—λ„ μ•ˆμ •μ μΈ μ˜ˆμ•½ μ„œλΉ„μŠ€, Atomic Pattern을 μ μš©ν•œ μž¬μ‚¬μš© κ°€λŠ₯ν•œ μ»΄ν¬λ„ŒνŠΈ, μ‹€μš©μ μΈ Testing을 주제둜 ν•˜λŠ” 이벀트 μ„œλΉ„μŠ€
Stars: ✭ 169 (-26.2%)
Mutual labels:  storybook
Lerna Yarn Workspaces Monorepo
πŸ‰ A Monorepo with multiple packages and a shared build, test, and release process.
Stars: ✭ 201 (-12.23%)
Mutual labels:  storybook
Backpack Ui
All the tools you need to build the Lonely Planet UI experience.
Stars: ✭ 216 (-5.68%)
Mutual labels:  storybook
Crna Recipe
Step-by-step guide to bootstrap a React Native app from scratch
Stars: ✭ 174 (-24.02%)
Mutual labels:  storybook
Assistant
✏️ Generate human quality code from your design. supports flutter, react, vue, figma, sketch, xd
Stars: ✭ 199 (-13.1%)
Mutual labels:  storybook
Svelte Storybook Tailwind
A starter template for Svelte, TailwindCSS and Storybook. You can easily start your project with this template, instead of wasting time figuring out configurations for each integration.
Stars: ✭ 204 (-10.92%)
Mutual labels:  storybook
Qui
A Vue.js design-system for Web.
Stars: ✭ 165 (-27.95%)
Mutual labels:  storybook
Awesome Design Systems
A curated list of bookmarks, resources and articles about design systems focused on developers.
Stars: ✭ 222 (-3.06%)
Mutual labels:  storybook
Koa Vue Notes Web
πŸ€“ This is a simple SPA built using Koa as the backend, Vue as the first frontend, and React as the second frontend. Features MySQL integration, user authentication, CRUD note actions, and Vuex store modules.
Stars: ✭ 200 (-12.66%)
Mutual labels:  storybook
Testing React
Testing utilities that allow you to reuse your Storybook stories in your React unit tests!
Stars: ✭ 171 (-25.33%)
Mutual labels:  storybook
Gatsby Wordpress Themes
🎨 Gatsby WordPress Theme
Stars: ✭ 175 (-23.58%)
Mutual labels:  storybook
Learnstorybook.com
Static site and content for Storybook tutorials
Stars: ✭ 2,291 (+900.44%)
Mutual labels:  storybook
Addon Jsx
This Storybook addon show you the JSX / template of the story
Stars: ✭ 209 (-8.73%)
Mutual labels:  storybook
Storybook Addon Vue Info
Info addon for Vue components
Stars: ✭ 174 (-24.02%)
Mutual labels:  storybook
Govuk React
An implementation of the GOV.UK Design System in React using CSSinJS
Stars: ✭ 219 (-4.37%)
Mutual labels:  storybook
Storybook Addon Styled Component Theme
storybook addon
Stars: ✭ 168 (-26.64%)
Mutual labels:  storybook
Vuesion
Vuesion is a boilerplate that helps product teams build faster than ever with fewer headaches and modern best practices across engineering & design.
Stars: ✭ 2,510 (+996.07%)
Mutual labels:  storybook
React Native
πŸ““ Storybook for React Native!
Stars: ✭ 222 (-3.06%)
Mutual labels:  storybook
Storybook Dark Mode
A storybook addon that lets your users toggle between dark and light mode.
Stars: ✭ 218 (-4.8%)
Mutual labels:  storybook
Addon Smart Knobs
🧠 This Storybook plugin uses @storybook/addon-knobs but creates the knobs automatically based on PropTypes.
Stars: ✭ 215 (-6.11%)
Mutual labels:  storybook

React Native Storybook Loader

A CLI for dynamically importing stories into Storybook for React Native.

Build Status Known Vulnerabilities AppVeyor codecov

Purpose

While using storybook for React Native, I repeatedly found myself manually creating a file with imports for all my stories.

react native storybook-loader solves this by searching directories, matching files to patterns and generating a story loader that Storybook can use to load all of your stories.

Installation

yarn add react-native-storybook-loader -D

Quick Start

  1. Create a React Native project using create-react-native-app

    yarn create react-native-app
    
  2. Add Storybook for React Native to the project and follow instructions to finalize setup.

    cd <project name>
    npx -p @storybook/cli sb init --type react_native
    
  3. Install react-native-storybook-loader

    yarn add react-native-storybook-loader -D
    
  4. Add the rnstl cli to the scripts tag of the package.json

    {
      "scripts": {
        "prestorybook": "rnstl"
      }
    }
    
  5. Update index.js file in the ./storybook directory to point to storyLoader.js

    import { AppRegistry } from 'react-native';
    import { getStorybookUI, configure } from '@storybook/react-native';
    
    import { loadStories } from './storyLoader';
    
    import './rn-addons';
    
    // import stories
    configure(() => {
      loadStories();
    }, module);
    
    // Refer to https://github.com/storybookjs/storybook/tree/master/app/react-native#start-command-parameters
    // To find allowed options for getStorybookUI
    const StorybookUIRoot = getStorybookUI({});
    
    // If you are using React Native vanilla and after installation you don't see your app name here, write it manually.
    // If you use Expo you can safely remove this line.
    AppRegistry.registerComponent('%APP_NAME%', () => StorybookUIRoot);
    
    export default StorybookUIRoot;
    

    Note: Step 4 ensures storyLoader.js will be created

  6. Start Storybook

    yarn storybook
    
  7. Run react native app in targeted platform

    yarn android
    

    Or

    yarn ios
    

    Note: If you have problems connecting from your device to Storybook using Android issue the following command: adb reverse tcp:7007 tcp:7007.

Configuration

Story loading is controlled by the react-native-storybook-loader section of the project's package.json.

Options

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

Examples:

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": "awesome-project",
  "scripts": {
    "prestorybook": "rnstl"
  },
  "config": {
    "react-native-storybook-loader": {
      "searchDir": ["./src", "./packages"],
      "pattern": "**/*.stories.js",
      "outputFile": "./storybook/storyLoader.js"
    }
  }
}

Story Loader API

A story loader is the file generated by rnstl used to load story files from your project in to Storybook.

storyLoader.loadStores()

Loads the located stories

Returns: void

storyLoader.stories

An array of the stories that are loaded.

Returns: string[]

Story Loader Formatting

To ensure the formatting of your story loader is on par with the rest of your code base, rnstl uses Prettier to format the generated story loaders. It will travese up the tree looking for a Prettier configuration file. If none is found, the defaul Prettier settings will be used.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].