Components Book Module for Nuxt
data:image/s3,"s3://crabby-images/91e91/91e910b068e875699406d524f8ddc1fc8a7b8928" alt="header"
Overview
This module provides a Storybook-like experience for Nuxt components, allowing you to document and test your Vue components using .stories.vue
files. It automatically scans a specified directory for story files, generates dynamic routes, and creates an interactive UI for viewing and testing components.
Unlike Storybook, which can be complex and heavy, this module is lightweight and seamlessly integrates into Nuxt, making it easy to set up and use. All stories are written as standard Vue components, ensuring a smooth and intuitive development experience.
data:image/s3,"s3://crabby-images/559ba/559bac13c12470a146e6804b45442a3dd80103d5" alt="img2"
Features
- 📦 Automatic scanning of
.stories.vue
files and registration as pages. - ⚡ Live reloading with file-watching support.
- 🛠 Extracts and displays component props dynamically.
- 🏗 Nuxt DevTools Integration for quick access.
- 📋 Built-in component previewing with
EnhancedPreview
. - 🔄 Supports dynamic prop manipulation and slot usage.
- 🚀 Flexible component embedding with event handling support.
Installation
npm install --save-dev nuxt-componentsbook-module
or
yarn add --dev nuxt-componentsbook-module
Setup
1. Register the Module
Add the module to your nuxt.config.ts
:
export default defineNuxtConfig({
modules: [
'nuxt-componentsbook-module',
],
componentsBook: {
componentsDir: 'components',
disabled: false,
cache: true,
},
})
2. Creating a Story
To document a component, create a .stories.vue
file in your components directory:
MyInput.stories.vue (Example with EnhancedPreview
)
<script setup>
import { ref } from '#imports'
import CustomInput from './MyInput.vue'
const modelValue = ref('')
const label = ref('Enter Text')
const type = ref<'text' | 'password' | 'email' | 'number'>('text')
const placeholder = ref('Type something...')
const disabled = ref(false)
const readonly = ref(false)
const helperText = ref('This is a helper text.')
const size = ref<'sm' | 'md' | 'lg'>('md')
</script>
<template>
<h1>🟢 CustomInput Component</h1>
<p>
The <code>CustomInput</code> component is a versatile input field with multiple configurations.
</p>
<h2>🛠 Interactive Controls</h2>
<div class="controls">
<label>
Label:
<input v-model="label" type="text">
</label>
<label>
Type:
<select v-model="type">
<option value="text">Text</option>
<option value="password">Password</option>
<option value="email">Email</option>
<option value="number">Number</option>
</select>
</label>
</div>
<h2>🔹 Preview</h2>
<EnhancedPreview
v-model="modelValue"
:component="CustomInput"
:props="{ label, type, placeholder, disabled, readonly, 'helper-text': helperText, size }"
:emits="['click']"
@click="console.log('Clicked!')"
/>
</template>
3. Running the Components Book
Start your Nuxt development server:
npm run dev
Visit /componentsbook
in your browser to see the list of stories.
📌 Using EnhancedPreview
The EnhancedPreview
component is the recommended way to embed and test your components interactively. It allows for dynamic prop manipulation, event handling, and slot usage.
Example Usage
<EnhancedPreview
v-model="modelValue"
:component="CustomInput"
:props="{
label: 'Enter Text',
type: 'text',
placeholder: 'Type something...',
disabled: false,
readonly: false,
'helper-text': 'This is a helper text.',
size: 'md',
}"
:emits="['click']"
@click="handleClick"
>
<template #append>
test slot
</template>
</EnhancedPreview>
Key Features of EnhancedPreview
- Supports
v-model
: Automatically binds v-model
values. - Handles events dynamically: Passes events such as
@click
, @hover
, and custom events. - Slot support: Allows injecting content into component slots.
- Live preview: Updates props and re-renders instantly.
- Code generation: Displays and copies usage examples.
How It Works
- The module scans the specified
componentsDir
for .stories.vue
files. - Generates dynamic Vue pages for each story and registers them with Nuxt.
- Provides a UI layout for previewing and testing components interactively.
- Supports real-time editing with automatic updates when files are modified.
- Enhances DevTools, adding a new tab called Components Book.
🛠 DevTools Integration
When running in development mode, a Components Book tab appears in Nuxt DevTools, providing an iframe-based UI for exploring stories.
🤝 Contributing
Feel free to submit issues and pull requests to improve the module.
📜 License
MIT License