@jlaf/storyblok-cac
v0.0.12
Published
StoryBlok Components as Code
Downloads
120
Readme
StoryBlok Components as Code
Define StoryBlok components using the typesafety of TypeScript!
Installation
npm install --save @jlaf/storyblok-cac
Usage
First define your components:
// src/components.ts
import { type StoryblokComponent, arrayToStoryBlokOptions } from '@jlaf/storyblok-cac'
export default [
{
name: 'page',
schema: {
body: {
type: 'bloks',
},
},
is_root: true,
is_nestable: false,
},
{
name: 'content',
schema: {
content: {
type: 'richtext',
},
textAlign: {
type: 'option',
options: arrayToStoryBlokOptions(['left', 'center', 'right']),
default_value: 'left',
},
}
},
] as StoryblokComponent[]
Component generation
Now you can generate the components using:
yarn run storyblok-cac components --input-file src/components.ts
This will output a components.json
file which can be uploaded to Storyblok using the Storyblok CLI
CLI Parameters
| Parameter | Default | Description | Example |
|-----------------|-------------------|--------------------------------|-----------------------|
| --input-file
| - | File containing the components | src/components.ts
|
| --output-path
| components.json
| Output of the json file | src/components.json
|
Presets generation
Now you can generate the presets using:
yarn run storyblok-cac presets --input-file src/components.ts --space-id 12345 --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
CLI Parameters
| Parameter | Default | Description | Example |
|-----------------|----------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------|
| --input-file
| - | File containing the components | src/components.ts
|
| --space-id
| - | Storyblok Space ID | 12234
|
| --token
| - | Personal access token. See storyblok | xxxxxxxxxxxxxxxxxxxxxxxxxxxx
|
| --output-path
| presets.json
| Output of the json file | src/presets.json
|
Helpers
arrayToStoryBlokOptions
This function creates an array which can be used by the Storyblok CLI. See usage above.
Starter
The starter used is antfu/starter-ts