Storybook Addon TYPO3 Fluid
Render TYPO3 Fluid templates in Storybook.
Requirements
- installed and configured TYPO3 instance with
typo3fluid-api
extension installed
Installation
Install with npm
npm i storybook-typo3fluid
Create a .env
file in your Storybook folder and add the following environment variables which should match with the typo3fluid-api
extension settings in your TYPO3 instance.
STORYBOOK_TYPO3FLUID_API_URL="<absolute path to typo3 typo3fluid-api endpoint>"
STORYBOOK_TYPO3FLUID_API_PASSWORD=""
Usage
Stories for TYPO3 Fluid templates are similar to html stories. The only difference is how you create the component template inside the story. Use the FluidTemplate
function to indicate which TYPO3 Fluid template you want to render. The passed arguments args
contain all defined arguments from your story which will be made available in the TYPO3 Fluid template you want to use.
import { FluidTemplate } from "storybook-typo3fluid";
const Template = (args) => FluidTemplate({
extension: '<extension name>',
template: '<template name>',
partial: '<partial name>',
section: '<(optional) section name>',
args
});
Compare this to an official html template from storybook.
import { createButton } from './Button';
const Template = ({ label, ...args }) => {
return createButton({ label, ...args });
};
Builder differences
Storybook uses the webpack builder by default which storybook-typo3fluid
also supports by default. With some changes to your code you can also use @storybook/builder-vite
with this package.
-
Add the
STORYBOOK_
Prefix as an additional envPrefix in yourvite.config.js
.export default { envPrefix: [ 'VITE_', 'STORYBOOK_' ] }
-
Import the Vite entrypoint file in your stories as such:
import { FluidTemplate } from "storybook-typo3fluid/dist/vite";
Limitations
- In stories defined callback functions are not yet supported.
Static Storybook build
If you want to use a static build of Storybook with access to a different TYPO3 instance you need to add the environment variables to the build process as such:
STORYBOOK_TYPO3FLUID_API_URL="" STORYBOOK_TYPO3FLUID_API_PASSWORD="" npm run build-storybook