From f14dbdb7e6428139c45e72278766564ba5f1db10 Mon Sep 17 00:00:00 2001 From: Georges Lebreton <102960844+Georges-GNM@users.noreply.github.com> Date: Thu, 9 Jan 2025 12:14:00 +0000 Subject: [PATCH] Add audio duration to card models and use in audio pill --- dotcom-rendering/src/components/Card/Card.stories.tsx | 1 + dotcom-rendering/src/components/Card/Card.tsx | 4 +++- dotcom-rendering/src/components/FrontCard.tsx | 1 + dotcom-rendering/src/model/enhanceCards.ts | 1 + dotcom-rendering/src/model/front-schema.json | 9 +++++++++ dotcom-rendering/src/model/tag-page-schema.json | 3 +++ dotcom-rendering/src/types/front.ts | 2 ++ 7 files changed, 20 insertions(+), 1 deletion(-) diff --git a/dotcom-rendering/src/components/Card/Card.stories.tsx b/dotcom-rendering/src/components/Card/Card.stories.tsx index 5491903db2..1e8b0490ae 100644 --- a/dotcom-rendering/src/components/Card/Card.stories.tsx +++ b/dotcom-rendering/src/components/Card/Card.stories.tsx @@ -46,6 +46,7 @@ const basicCardProps: CardProps = { showMainVideo: true, absoluteServerTimes: true, galleryCount: 8, + audioDuration: '20:25', }; const aBasicLink = { diff --git a/dotcom-rendering/src/components/Card/Card.tsx b/dotcom-rendering/src/components/Card/Card.tsx index bf023c0669..30607b4ef9 100644 --- a/dotcom-rendering/src/components/Card/Card.tsx +++ b/dotcom-rendering/src/components/Card/Card.tsx @@ -150,6 +150,7 @@ export type Props = { /** A kicker image is seperate to the main media and renders as part of the kicker */ showKickerImage?: boolean; galleryCount?: number; + audioDuration?: string; }; const starWrapper = (cardHasImage: boolean) => css` @@ -385,6 +386,7 @@ export const Card = ({ podcastImage, showKickerImage = false, galleryCount, + audioDuration, }: Props) => { const hasSublinks = supportingContent && supportingContent.length > 0; const sublinkPosition = decideSublinkPosition( @@ -464,7 +466,7 @@ export const Card = ({ > {mainMedia?.type === 'Audio' && ( } /> )} diff --git a/dotcom-rendering/src/components/FrontCard.tsx b/dotcom-rendering/src/components/FrontCard.tsx index 5191f5ce88..cfbefae7fa 100644 --- a/dotcom-rendering/src/components/FrontCard.tsx +++ b/dotcom-rendering/src/components/FrontCard.tsx @@ -57,6 +57,7 @@ export const FrontCard = (props: Props) => { showMainVideo: trail.showMainVideo, galleryCount: trail.galleryCount, podcastImage: trail.podcastImage, + audioDuration: trail.audioDuration, }; return Card({ ...defaultProps, ...cardProps }); diff --git a/dotcom-rendering/src/model/enhanceCards.ts b/dotcom-rendering/src/model/enhanceCards.ts index 9bf80a23db..e98b8035e6 100644 --- a/dotcom-rendering/src/model/enhanceCards.ts +++ b/dotcom-rendering/src/model/enhanceCards.ts @@ -329,5 +329,6 @@ export const enhanceCards = ( }), podcastImage, galleryCount: faciaCard.card.galleryCount, + audioDuration: faciaCard.card.audioDuration, }; }); diff --git a/dotcom-rendering/src/model/front-schema.json b/dotcom-rendering/src/model/front-schema.json index 83f8a1da22..4822ad7f37 100644 --- a/dotcom-rendering/src/model/front-schema.json +++ b/dotcom-rendering/src/model/front-schema.json @@ -1030,6 +1030,9 @@ }, "galleryCount": { "type": "number" + }, + "audioDuration": { + "type": "string" } }, "required": [ @@ -1781,6 +1784,9 @@ }, "galleryCount": { "type": "number" + }, + "audioDuration": { + "type": "string" } }, "required": [ @@ -2532,6 +2538,9 @@ }, "galleryCount": { "type": "number" + }, + "audioDuration": { + "type": "string" } }, "required": [ diff --git a/dotcom-rendering/src/model/tag-page-schema.json b/dotcom-rendering/src/model/tag-page-schema.json index be8da9d916..a6cb6711fa 100644 --- a/dotcom-rendering/src/model/tag-page-schema.json +++ b/dotcom-rendering/src/model/tag-page-schema.json @@ -555,6 +555,9 @@ }, "galleryCount": { "type": "number" + }, + "audioDuration": { + "type": "string" } }, "required": [ diff --git a/dotcom-rendering/src/types/front.ts b/dotcom-rendering/src/types/front.ts index a68347551a..32d9c86309 100644 --- a/dotcom-rendering/src/types/front.ts +++ b/dotcom-rendering/src/types/front.ts @@ -291,6 +291,7 @@ export type FEFrontCard = { group: string; isLive: boolean; galleryCount?: number; + audioDuration?: string; }; discussion: { isCommentable: boolean; @@ -350,6 +351,7 @@ export type DCRFrontCard = { showMainVideo?: boolean; galleryCount?: number; podcastImage?: PodcastSeriesImage; + audioDuration?: string; }; export type DCRSlideshowImage = {