kdutify-loader
will automatically import all Kdutify components as you use them
// webpack.config.js
const { KdutifyLoaderPlugin } = require('kdutify-loader')
exports.plugins.push(
new KdutifyLoaderPlugin()
)
You can also provide a custom match function to import your own project's components too:
// webpack.config.js
const { KdutifyLoaderPlugin } = require('kdutify-loader')
exports.plugins.push(
new KdutifyLoaderPlugin({
/**
* This function will be called for every tag used in each kdu component
* It should return an array, the first element will be inserted into the
* components array, the second should be a corresponding import
*
* originalTag - the tag as it was originally used in the template
* kebabTag - the tag normalised to kebab-case
* camelTag - the tag normalised to PascalCase
* path - a relative path to the current .kdu file
* component - a parsed representation of the current component
*/
match (originalTag, { kebabTag, camelTag, path, component }) {
if (kebabTag.startsWith('core-')) {
return [camelTag, `import ${camelTag} from '@/components/core/${camelTag.substring(4)}.kdu'`]
}
}
})
)
or if you're using Kdu CLI:
// kdu.config.js
module.exports = {
chainWebpack: config => {
config.plugin('KdutifyLoaderPlugin').tap(args => [{
match (originalTag, { kebabTag, camelTag, path, component }) {
if (kebabTag.startsWith('core-')) {
return [camelTag, `import ${camelTag} from '@/components/core/${camelTag.substring(4)}.kdu'`]
}
}
}])
}
}
<template>
<core-form>
<k-card>
...
</k-card>
</core-form>
</template>
<script>
export default {
...
}
</script>
Will be compiled into:
<template>
<core-form>
<k-card>
...
</k-card>
</core-form>
</template>
<script>
import { KCard } from 'kdutify/lib'
import CoreForm from '@/components/core/Form.kdu'
export default {
components: {
KCard,
CoreForm
},
...
}
</script>
kdutify-loader
can automatically generate low-res placeholders for the k-img
component
NOTE: You must have ImageMagick, GraphicsMagick, or sharp installed for this to work
Add progressiveImages
to the plugin options:
exports.plugins.push(
new KdutifyLoaderPlugin({
progressiveImages: true
})
)
// kdu-cli
module.exports = {
chainWebpack: config => {
config.plugin('KdutifyLoaderPlugin').tap(args => [{
progressiveImages: true
}])
}
}
And away you go!
<k-img src="@/assets/some-image.jpg"></k-img>
NOTE: The src must follow kdu-loader's transform rules
progressiveImages
only works on static paths, for use in a loop you have to require
the image yourself:
<k-img k-for="i in 10" :src="require(`@/images/image-${i}.jpg?kdutify-preload`)" :key="i">
progressiveImages: true
can be replaced with an object for advanced configuration
new KdutifyLoaderPlugin({
progressiveImages: {
size: 12, // Use higher-resolution previews
sharp: true // Use sharp instead of ImageMagick
}
})
Type: Number
Default: 9
The minimum dimensions of the generated preview images in pixels
Type: RegExp
Default: /kdutify-preload/
Override the resource qury to match k-img URLs
If you only want some images to have placeholders, add ?lazy
to the end of the request:
<k-img src="@/assets/some-image.jpg?lazy"></k-img>
And modify the regex to match:
new KdutifyLoaderPlugin({
progressiveImages: {
resourceQuery: /lazy\?kdutify-preload/
}
})
Type: Boolean
Default: false
Use sharp instead of GM for environments without ImageMagick. This will result in lower-quality images
Type: Boolean
Default: false
Use GraphicsMagic instead of ImageMagick
Type: Boolean
Default: false
Register Kdutify styles in kdu-style-loader
.
This fixes styles not being loaded when doing SSR (for example when using @dtwojs/kdutify
).
As Kdutify imports styles with JS, without this option, they do not get picked up by SSR.
manualInject
set to true
in kdu-style-loader
config.