stencil-storybook-wrapper
v1.3.2
Published
A node module to update a stencil and storybook/html project to make it compatible
Downloads
4
Maintainers
Readme
Stencil Storybook Wrapper
This module provides a wrapper to interoperate stencil created app with storybook.
It works by hooking into the stencil dev server during development, listenig to the websocket during HMR(Hot Module Replacement) and showing the errors or reloading the stencil generated resources.
During production builds for storybook, the output of the stencil build is moved to the storybook-static
folder and resources requests updated so that the storybook can be deployed.
NOTE: TO BE USED WITH VANNILA STENCIL COMPONENT PROJECT
Using this with a stencil project already modifed by you could lead to un-necessary side effects.
Prerequisites
Create a stencil project of the type component using the getting started docs.
Installation
Install it globally
$ npm i -g stencil-storybook-wrapper
$ cd my-awesome-stencil-app
$ stencil-storybook-wrapper
OR
Use it via NPX
$ cd my-awesome-stencil-app
npx stencil-storybook-wrapper
Usage
Start Storybook
$ npm run start
Build Stencil & Storybook
- Stencil built to
dist
folder - Storybook built to
storybook-static
folder
$ npm run build
Create component
The wrapper adds a tiny plopjs component generator which can be used to create new stencil components. Components created by the generator have all the necessary scaffolding and story file to get to started.
$ npm run generate
and follow the instructions. Modify the plopfile.js
and the add/update plop/templates
to create atoms
, molecules
or organism
type components.
Build Stencil
- Storybook built to
storybook-static
folder
$ npm run build:stencil
The following npm scrips are added to your package.json
{
// Delete output folders
"clean": "del-cli dist storybook-static",
// Build stencil and storybook
"build": "npm-run-all clean build:stencil build:storybook",
// Build only stencil components
"build:stencil": "STENCIL_ENV=prod stencil build --docs",
// Build only storybook
// Always use this after `build:stencil`
"build:storybook": "build-storybook",
// Start the dev server for both stencil and storybook
"start": "npm-run-all --parallel stencil storybook",
// Start only stencil dev server
"stencil": "cross-env STENCIL_ENV=dev stencil build --dev --watch --serve --docs",
// Start only storybook dev server
// Always use this after `stencil`
"storybook": "start-storybook -p 6007 -s ./stencil-utilities/public-assets",
// Run initial build before starting the dev server
// Needed for readme addon
"prestart": "npm run build:stencil",
// Component generator for stencil components
"generate": "plop"
}
Configure Stencil Dev Server
The wrapper adds a dev server config object to the package.json
file. You can use it to configure how the dev server launches.
"stencil": {
// The protocol used by the dev server
"protocol": "http",
// The host or IP address
"host": "localhost",
// The port where the dev server is launched
"port": 3333,
// The buildDir as per https://stenciljs.com/docs/config#www
"buildDir": "build"
},
Please raise any issues you have while using this wrapper. Any help would also be appreciated.