storyblok-rich-text-renderer
storyblok-rich-text-renderer copied to clipboard
Custom Component resolver + Nuxt console error even though component renders
"@marvr/storyblok-rich-text-vue-renderer": "^2.0.1",
"@vue/composition-api": "^1.2.1",
"nuxt": "^2.15.7",'
Using the resolver and custom component as seen below I get an error message "the client-side rendered virtual DOM tree is not matching server-rendered content".
The error is not consistent. Possibly I resolved it with mode: "client"
on the plugin and <client-only>
on the component. Ideally the resolver would work server & client side.
I believe on the server render I'm hitting line 7 of components.ts and the component is undefined
causing the program to load SbComponentFallback and render the error text. The client side seems to render fine so even when I get the console error, the component visually displays.
RESOLVER PLUGIN
import Vue from "vue";
import VueRichTextRenderer from "@marvr/storyblok-rich-text-vue-renderer";
import BlockQuote from "~/components/RichTextRender/BlockQuote";
Vue.use(VueRichTextRenderer, {
resolvers: {
components: {
rich_text_block_quote: BlockQuote,
},
},
});
NUXT CONFIG
plugins: ["~/plugins/composition-api.js", { src: "~/plugins/storyblok-rich-text-renderer.js", mode: "client" },
COMPONENT
<template>
<client-only>
<figure>
<blockquote>
<p>{{ body.quote }}</p>
</blockquote>
<figcaption class="paragraph-small">{{ body.credit }}</figcaption>
</figure>
</client-only>
</template>
<script>
export default {
name: "BlockQuote",
props: {
body: {
type: Object,
required: true,
},
},
};
Error Screenshot with BlockQuote component visually rendered:
data:image/s3,"s3://crabby-images/17c2e/17c2ec1ebd0c43863bf314af9b70ed4eff0d3263" alt="resolver-error"
Hey there, having the exact same issue right now, were you able to resolve it?
For me, the issue is that I have a resolver for a custom image block, and my custom component is a div element. Since it is rendered inside a p tag by the resolver, it is invalid HTML which the warning comes from. I think there should be a way to disable rendering custom elements inside p tags...