Fixed broken content pages if missing fields
This commit is contained in:
parent
6082e83f54
commit
e675a90ed6
|
@ -65,7 +65,7 @@ export default function ThumbnailHeader(
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="grid grid-flow-col gap-8">
|
<div className="grid grid-flow-col gap-8">
|
||||||
{content.type && (
|
{content.type.data && (
|
||||||
<div className="flex flex-col place-items-center gap-2">
|
<div className="flex flex-col place-items-center gap-2">
|
||||||
<h3 className="text-xl">{langui.type}</h3>
|
<h3 className="text-xl">{langui.type}</h3>
|
||||||
<div className="flex flex-row flex-wrap">
|
<div className="flex flex-row flex-wrap">
|
||||||
|
|
|
@ -65,6 +65,31 @@ export default function ContentIndex(props: ContentIndexProps): JSX.Element {
|
||||||
</ContentPanel>
|
</ContentPanel>
|
||||||
);
|
);
|
||||||
|
|
||||||
|
let description = "";
|
||||||
|
if (content.type.data) {
|
||||||
|
description += `${langui.type}: `;
|
||||||
|
if (content.type.data.attributes.titles.length > 0) {
|
||||||
|
description += content.type.data.attributes.titles[0].title;
|
||||||
|
} else {
|
||||||
|
description += prettySlug(content.type.data.attributes.slug);
|
||||||
|
}
|
||||||
|
description += "\n";
|
||||||
|
}
|
||||||
|
if (content.categories.data.length > 0) {
|
||||||
|
description += `${langui.categories}: `;
|
||||||
|
description += content.categories.data
|
||||||
|
.map((category) => {
|
||||||
|
return category.attributes.short;
|
||||||
|
})
|
||||||
|
.join(" | ");
|
||||||
|
description += "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (content.titles.length > 0 && content.titles[0].description) {
|
||||||
|
description += "\n";
|
||||||
|
description += content.titles[0].description;
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<AppLayout
|
<AppLayout
|
||||||
navTitle="Contents"
|
navTitle="Contents"
|
||||||
|
@ -80,22 +105,7 @@ export default function ContentIndex(props: ContentIndexProps): JSX.Element {
|
||||||
thumbnail={content.thumbnail.data?.attributes}
|
thumbnail={content.thumbnail.data?.attributes}
|
||||||
contentPanel={contentPanel}
|
contentPanel={contentPanel}
|
||||||
subPanel={subPanel}
|
subPanel={subPanel}
|
||||||
description={`${langui.type}: ${
|
description={description}
|
||||||
content.type.data.attributes.titles.length > 0
|
|
||||||
? content.type.data.attributes.titles[0].title
|
|
||||||
: prettySlug(content.type.data.attributes.slug)
|
|
||||||
}
|
|
||||||
${langui.categories}: ${
|
|
||||||
content.categories.data.length > 0 &&
|
|
||||||
content.categories.data
|
|
||||||
.map((category) => {
|
|
||||||
return category.attributes.short;
|
|
||||||
})
|
|
||||||
.join(" | ")
|
|
||||||
}
|
|
||||||
|
|
||||||
${content.titles.length > 0 ? content.titles[0].description : undefined}
|
|
||||||
`}
|
|
||||||
{...props}
|
{...props}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
|
|
|
@ -49,7 +49,7 @@ export default function ContentRead(props: ContentReadProps): JSX.Element {
|
||||||
horizontalLine
|
horizontalLine
|
||||||
/>
|
/>
|
||||||
|
|
||||||
{content.text_set.length > 0 && (
|
{content.text_set.length > 0 && content.text_set[0].source_language.data && (
|
||||||
<div className="grid gap-5">
|
<div className="grid gap-5">
|
||||||
<h2 className="text-xl">
|
<h2 className="text-xl">
|
||||||
{content.text_set[0].source_language.data.attributes.code ===
|
{content.text_set[0].source_language.data.attributes.code ===
|
||||||
|
@ -175,6 +175,26 @@ export default function ContentRead(props: ContentReadProps): JSX.Element {
|
||||||
</ContentPanel>
|
</ContentPanel>
|
||||||
);
|
);
|
||||||
|
|
||||||
|
let description = "";
|
||||||
|
if (content.type.data) {
|
||||||
|
description += `${langui.type}: `;
|
||||||
|
if (content.type.data.attributes.titles.length > 0) {
|
||||||
|
description += content.type.data.attributes.titles[0].title;
|
||||||
|
} else {
|
||||||
|
description += prettySlug(content.type.data.attributes.slug);
|
||||||
|
}
|
||||||
|
description += "\n";
|
||||||
|
}
|
||||||
|
if (content.categories.data.length > 0) {
|
||||||
|
description += `${langui.categories}: `;
|
||||||
|
description += content.categories.data
|
||||||
|
.map((category) => {
|
||||||
|
return category.attributes.short;
|
||||||
|
})
|
||||||
|
.join(" | ");
|
||||||
|
description += "\n";
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<AppLayout
|
<AppLayout
|
||||||
navTitle="Contents"
|
navTitle="Contents"
|
||||||
|
@ -190,22 +210,7 @@ export default function ContentRead(props: ContentReadProps): JSX.Element {
|
||||||
thumbnail={content.thumbnail.data?.attributes}
|
thumbnail={content.thumbnail.data?.attributes}
|
||||||
contentPanel={contentPanel}
|
contentPanel={contentPanel}
|
||||||
subPanel={subPanel}
|
subPanel={subPanel}
|
||||||
description={`${langui.type}: ${
|
description={description}
|
||||||
content.type.data.attributes.titles.length > 0
|
|
||||||
? content.type.data.attributes.titles[0].title
|
|
||||||
: prettySlug(content.type.data.attributes.slug)
|
|
||||||
}
|
|
||||||
${langui.categories}: ${
|
|
||||||
content.categories.data.length > 0 &&
|
|
||||||
content.categories.data
|
|
||||||
.map((category) => {
|
|
||||||
return category.attributes.short;
|
|
||||||
})
|
|
||||||
.join(" | ")
|
|
||||||
}
|
|
||||||
|
|
||||||
${content.titles.length > 0 ? content.titles[0].description : undefined}
|
|
||||||
`}
|
|
||||||
{...props}
|
{...props}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
|
@ -308,42 +313,43 @@ export function useTesting(props: ContentReadProps) {
|
||||||
["content", "text_set"],
|
["content", "text_set"],
|
||||||
contentURL
|
contentURL
|
||||||
);
|
);
|
||||||
}
|
|
||||||
if (textset.source_language.data.attributes.code === router.locale) {
|
|
||||||
// This is a transcript
|
|
||||||
if (textset.transcribers.data.length === 0) {
|
|
||||||
prettyTestError(
|
|
||||||
router,
|
|
||||||
"Missing transcribers attribution",
|
|
||||||
["content", "text_set"],
|
|
||||||
contentURL
|
|
||||||
);
|
|
||||||
}
|
|
||||||
if (textset.translators.data.length > 0) {
|
|
||||||
prettyTestError(
|
|
||||||
router,
|
|
||||||
"Transcripts shouldn't have translators",
|
|
||||||
["content", "text_set"],
|
|
||||||
contentURL
|
|
||||||
);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
// This is a translation
|
if (textset.source_language.data.attributes.code === router.locale) {
|
||||||
if (textset.translators.data.length === 0) {
|
// This is a transcript
|
||||||
prettyTestError(
|
if (textset.transcribers.data.length === 0) {
|
||||||
router,
|
prettyTestError(
|
||||||
"Missing translators attribution",
|
router,
|
||||||
["content", "text_set"],
|
"Missing transcribers attribution",
|
||||||
contentURL
|
["content", "text_set"],
|
||||||
);
|
contentURL
|
||||||
}
|
);
|
||||||
if (textset.transcribers.data.length > 0) {
|
}
|
||||||
prettyTestError(
|
if (textset.translators.data.length > 0) {
|
||||||
router,
|
prettyTestError(
|
||||||
"Translations shouldn't have transcribers",
|
router,
|
||||||
["content", "text_set"],
|
"Transcripts shouldn't have translators",
|
||||||
contentURL
|
["content", "text_set"],
|
||||||
);
|
contentURL
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// This is a translation
|
||||||
|
if (textset.translators.data.length === 0) {
|
||||||
|
prettyTestError(
|
||||||
|
router,
|
||||||
|
"Missing translators attribution",
|
||||||
|
["content", "text_set"],
|
||||||
|
contentURL
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if (textset.transcribers.data.length > 0) {
|
||||||
|
prettyTestError(
|
||||||
|
router,
|
||||||
|
"Translations shouldn't have transcribers",
|
||||||
|
["content", "text_set"],
|
||||||
|
contentURL
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue