standalone structure data component

This commit is contained in:
thomas.ekstrand 2024-02-13 21:47:23 -06:00
parent 384aa87d06
commit 3299ed0fb1
3 changed files with 58 additions and 59 deletions

View file

@ -6,6 +6,7 @@ sidebar_position: 3
---
import { FaqAccordion } from "/src/components/FaqAccordion";
import { FaqStructuredData } from "/src/components/FaqStructuredData";
export const Faq = {
"general": [
@ -184,10 +185,11 @@ export const Faq = {
],
};
<FaqStructuredData faqs={Faq} />
## Overview
{<FaqAccordion rows={Faq.general} slug="general" />}
<FaqAccordion rows={Faq.general} slug="general" />
## Android Client

View file

@ -67,32 +67,10 @@ export const FaqAccordion = ({
rows,
slug,
}: { rows: Faq[]; slug: string }): JSX.Element => {
// Set the faq structured data
const faqStructuredData = {
"@context": "https://schema.org",
"@type": "FAQPage",
mainEntity: rows.map((row) => ({
"@type": "Question",
name: row.title,
acceptedAnswer: {
"@type": "Answer",
text: row.content,
},
})),
};
return (
<BrowserOnly fallback={<div>Loading FAQ's...</div>}>
{() => {
return (
<>
<script
type="application/ld+json"
// biome-ignore lint: we need dangerouslySetInnerHTML here, and since we're the ones setting the content it's should be safe
dangerouslySetInnerHTML={{
__html: JSON.stringify(faqStructuredData),
}}
/>
<Accordion
allowMultipleExpanded={true}
allowZeroExpanded={true}
@ -113,7 +91,6 @@ export const FaqAccordion = ({
</AccordionItem>
))}
</Accordion>
</>
);
}}
</BrowserOnly>

View file

@ -0,0 +1,20 @@
export const FaqStructuredData = ({ faqs }) => {
const allFaqs = Object.values(faqs).flat();
const structuredData = {
"@context": "https://schema.org",
"@type": "FAQPage",
mainEntity: allFaqs.map((faq) => ({
"@type": "Question",
name: faq.title,
acceptedAnswer: {
"@type": "Answer",
text: faq.content,
},
})),
};
return (
<script type="application/ld+json">{JSON.stringify(structuredData)}</script>
);
};