VUE transformer for Gridsome
- Create documentation for your vue components
- Preview your components and build interactive demos with them
Supports (vuese comments)[https://vuese.org/cli/#about-comments] for detailing extra information within your components.
yarn add gridsome-transformer-vue
npm install gridsome-transformer-vue
Feel free to use the Starter that already includes some examples on how to use this.
// gridsome.config.js
module.exports = {
plugins: [
{
use: '@gridsome/source-filesystem',
options: {
baseDir: './src/library',
path: '**/*.vue',
typeName: 'VueComponent'
}
}
]
}
<page-query>
query VueComponent ($id: String!) {
comp: vueComponent (id: $id) {
id
name
mockData
source
fileInfo {
path
directory
}
props {
name
describe
type
required
default
}
slots {
name
describe
}
methods {
name
describe
argumentsDesc
}
}
}
</page-query>
For each prop on a component you can define a (faker)[https://www.npmjs.com/package/faker] function that will be used to generate fake data and store it as a JSON string in mockData
Example
<script>
export default {
// faker.commerce.productName
title: {
type: String,
required: true
},
// faker.lorem.paragraph
excerpt: {
type: String
},
// Image
image: {
type: [Object, String],
required: true
}
}
</script>
Get an unsplash image url in the mock data by adding // Image
as a comment to a prop.