How to use React Native Storybook Server with webpack 5
This is a quick guide for the prerelease version (6.5.0-rc.6) with a stable release coming out soon for React Native Storybook 6.5.
The React Native Storybook Server is an optional companion app for react native storybook that lets you control the storybook on your mobile device via a web interface. Until recently webpack 5 was not supported in the react native storybook server. Recently that support was added by a contributor @leonardo-fc and is now available in the release candidate version of the server.
The Guide
First bootstrap an app with react native storybook
yarn create expo-app --template expo-template-storybook AwesomeStorybook1
Go to the directory of the new app
cd AwesomeStorybook1
Add the react native storybook server package and some webpack5 dependencies to your project
yarn add -D @storybook/react-native-server@next webpack @storybook/builder-webpack5 @storybook/manager-webpack5
Make sure you add all of these packages otherwise it won’t work.
Add the following script to your package.json
file
{
"scripts": {
"start-server": "react-native-storybook-server"
}
}
Create a folder called .storybook_server
and add a main.js file with the following content
module.exports = {
stories: [
"../components/**/*.stories.mdx",
"../components/**/*.stories.@(js|jsx|ts|tsx)",
],
env: () => ({}),
core: {
builder: "webpack5",
},
addons: ["@storybook/addon-essentials"],
};
By setting the builder to webpack5
we are telling the storybook server to use webpack 5 instead of the default webpack 4.
In this bootstrapped project the ondevice storybook is configured in the .ondevice
folder.
In the index.tsx file we need to update some options so that websockets are enabled.
const StorybookUIRoot = getStorybookUI({
enableWebsockets: true,
});
Now you can start the server with yarn start-server
and open the storybook on your mobile device with yarn storybook
.
Make sure you restart the app on your device so that the server can pick up the stories sent over the websockets (sent on app startup).
At this point you should be running the react native server with webpack 5.
Thanks for reading. If you have any questions or feedback please tweet or send me a message @Danny_H_W.