diff --git a/src/components/Credits.astro b/src/components/Credits.astro
index eb4a3ee..d75ca8f 100644
--- a/src/components/Credits.astro
+++ b/src/components/Credits.astro
@@ -30,6 +30,7 @@ const { getLocalizedMatch, getLocalizedUrl } = await getI18n(Astro.locals.curren
);
})
}
+
{/* ------------------------------------------- CSS -------------------------------------------- */}
@@ -37,6 +38,6 @@ const { getLocalizedMatch, getLocalizedUrl } = await getI18n(Astro.locals.curren
diff --git a/src/components/InlineCredits.astro b/src/components/InlineCredits.astro
index fc5514f..2361a43 100644
--- a/src/components/InlineCredits.astro
+++ b/src/components/InlineCredits.astro
@@ -23,6 +23,7 @@ const { getLocalizedMatch } = await getI18n(Astro.locals.currentLocale);
/>
))
}
+
{/* ------------------------------------------- CSS -------------------------------------------- */}
diff --git a/src/components/Metadata.astro b/src/components/Metadata.astro
index c9d93d5..a6d8464 100644
--- a/src/components/Metadata.astro
+++ b/src/components/Metadata.astro
@@ -1,6 +1,7 @@
---
import type { Attribute } from "src/utils/attributes";
import TitleIcon from "./TitleIcon.astro";
+import { isExternalLink } from "src/utils/urls";
interface Props extends Attribute {}
@@ -15,15 +16,23 @@ if (values.length === 0) return;
{
- values.map(({ name, href, lang }) =>
- href ? (
-
- {name}
-
- ) : (
-
{name}
- )
- )
+ values.map(({ name, href, lang }) => {
+ if (!href) {
+ return
{name}
;
+ } else {
+ const newTab = isExternalLink(href);
+ return (
+
+ {name}
+
+ );
+ }
+ })
}
diff --git a/src/i18n/i18n.ts b/src/i18n/i18n.ts
index de42ef2..c2b9e63 100644
--- a/src/i18n/i18n.ts
+++ b/src/i18n/i18n.ts
@@ -255,9 +255,9 @@ export const getI18n = async (locale: string) => {
switch (relation.type) {
case "url":
return {
- href: relation.url,
+ href: relation.value.url,
typeLabel: t("global.sources.typeLabel.url"),
- label: relation.label,
+ label: relation.value.label,
target: "_blank",
rel: "noopener noreferrer",
};
diff --git a/src/i18n/wordings-keys.ts b/src/i18n/wordings-keys.ts
index e523cf7..ed5938e 100644
--- a/src/i18n/wordings-keys.ts
+++ b/src/i18n/wordings-keys.ts
@@ -184,4 +184,6 @@ export type WordingKey =
| "global.relationPage.folders"
| "global.relationPage.collectibles"
| "global.relationPage.timelineEvents"
- | "global.relationPage.title";
+ | "global.relationPage.title"
+ | "pages.credits.sources";
+
diff --git a/src/pages/[locale]/api/pages/_components/PageCredits.astro b/src/pages/[locale]/api/pages/_components/PageCredits.astro
index 575cff1..d1d2683 100644
--- a/src/pages/[locale]/api/pages/_components/PageCredits.astro
+++ b/src/pages/[locale]/api/pages/_components/PageCredits.astro
@@ -2,34 +2,34 @@
import Card from "components/Card.astro";
import Credits from "components/Credits.astro";
import InlineCredits from "components/InlineCredits.astro";
+import InlineMetadata from "components/InlineMetadata.astro";
import MasoActor from "components/Maso/MasoActor.astro";
+import Metadata from "components/Metadata.astro";
import { getI18n } from "src/i18n/i18n";
-import type { EndpointCredit, EndpointPage } from "src/shared/payload/endpoint-types";
+import type { EndpointPage } from "src/shared/payload/endpoint-types";
import { formatLocale } from "src/utils/format";
interface Props {
slug: string;
- currentLocale: string;
- sourceLanguage: string;
- credits: EndpointCredit[];
+ activeTranslation: EndpointPage["translations"][number];
otherTranslations: EndpointPage["translations"];
}
-const { slug, currentLocale, sourceLanguage, credits, otherTranslations } = Astro.props;
+const { slug, activeTranslation, otherTranslations } = Astro.props;
-const { t, getLocalizedUrl } = await getI18n(currentLocale);
+const { t, getLocalizedUrl } = await getI18n(activeTranslation.language);
---
{t("pages.credits.currentLocale")}
- {formatLocale(currentLocale)}
+ {formatLocale(activeTranslation.language)}
{
- sourceLanguage !== currentLocale && (
+ activeTranslation.sourceLanguage !== activeTranslation.language && (
{t("pages.credits.translationLabel", {
- locale: formatLocale(sourceLanguage),
+ locale: formatLocale(activeTranslation.sourceLanguage),
})}
)
@@ -37,9 +37,18 @@ const { t, getLocalizedUrl } = await getI18n(currentLocale);
{
- credits.length > 0 && (
+ (activeTranslation.credits.length > 0 || activeTranslation.sourceUrls.length > 0) && (
-
+
+ ({
+ name: label,
+ href: url,
+ }))}
+ />
+
)
}
@@ -65,7 +74,18 @@ const { t, getLocalizedUrl } = await getI18n(currentLocale);
)}
- {translation.credits.length > 0 && }
+ {(translation.credits.length > 0 || translation.sourceUrls.length > 0) && (
+
+ ({
+ name: label,
+ href: url,
+ }))}
+ />
+
+ )}
))}
diff --git a/src/pages/[locale]/api/pages/partial.astro b/src/pages/[locale]/api/pages/partial.astro
index 42c4f52..0d11b7c 100644
--- a/src/pages/[locale]/api/pages/partial.astro
+++ b/src/pages/[locale]/api/pages/partial.astro
@@ -38,8 +38,9 @@ const { translations, thumbnail, createdAt, updatedAt, updatedBy, attributes } =
const { getLocalizedUrl, t, formatDate } = await getI18n(Astro.locals.currentLocale);
const { getLocalizedMatch } = await getI18n(lang);
-const { pretitle, title, subtitle, summary, content, credits, toc, language, sourceLanguage } =
- getLocalizedMatch(translations);
+const activeTranslation = getLocalizedMatch(translations);
+
+const { pretitle, title, subtitle, summary, content, toc, language } = activeTranslation;
const metaAttributes: Attribute[] = [
{
@@ -107,9 +108,7 @@ if (updatedBy) {
otherTranslation.language !== language
)}
diff --git a/src/shared b/src/shared
index 63d1733..c2702ea 160000
--- a/src/shared
+++ b/src/shared
@@ -1 +1 @@
-Subproject commit 63d17331a17a5ab7874599d1df4ecf6b45ac89f3
+Subproject commit c2702ea508dde59264ee66100054bacc0834c029
diff --git a/src/utils/urls.ts b/src/utils/urls.ts
new file mode 100644
index 0000000..42bd404
--- /dev/null
+++ b/src/utils/urls.ts
@@ -0,0 +1,3 @@
+export const isExternalLink = (url: string): boolean => {
+ return url.startsWith("http");
+};