From 86a9adb89b045b680ca4818a6ba94a9dacb5d12f Mon Sep 17 00:00:00 2001 From: sophiamersmann Date: Thu, 12 Oct 2023 08:40:17 +0000 Subject: [PATCH 1/3] enhance(grapher): respect base font size for thumbnail generation --- packages/@ourworldindata/grapher/src/core/Grapher.tsx | 2 ++ packages/@ourworldindata/grapher/src/footer/Footer.tsx | 4 ++++ .../grapher/src/footer/FooterManager.ts | 2 ++ packages/@ourworldindata/grapher/src/header/Header.tsx | 10 +++++++--- .../grapher/src/header/HeaderManager.ts | 2 ++ 5 files changed, 17 insertions(+), 3 deletions(-) diff --git a/packages/@ourworldindata/grapher/src/core/Grapher.tsx b/packages/@ourworldindata/grapher/src/core/Grapher.tsx index 900ad7d8ab4..c14b46a3a7b 100644 --- a/packages/@ourworldindata/grapher/src/core/Grapher.tsx +++ b/packages/@ourworldindata/grapher/src/core/Grapher.tsx @@ -760,6 +760,8 @@ export class Grapher } @observable.ref isExportingtoSvgOrPng = false + @observable.ref isGeneratingThumbnail = false + tooltips?: TooltipManager["tooltips"] = observable.map({}, { deep: false }) @observable isPlaying = false @observable.ref isSelectingData = false diff --git a/packages/@ourworldindata/grapher/src/footer/Footer.tsx b/packages/@ourworldindata/grapher/src/footer/Footer.tsx index bd061caef16..bf5ffae8b66 100644 --- a/packages/@ourworldindata/grapher/src/footer/Footer.tsx +++ b/packages/@ourworldindata/grapher/src/footer/Footer.tsx @@ -649,6 +649,10 @@ export class StaticFooter extends Footer { } @computed protected get fontSize(): number { + // respect base font size for thumbnails + if (this.manager.isGeneratingThumbnail) { + return (13 / 16) * (this.manager.fontSize ?? 16) + } return 13 } diff --git a/packages/@ourworldindata/grapher/src/footer/FooterManager.ts b/packages/@ourworldindata/grapher/src/footer/FooterManager.ts index 13c1f86cb08..85462ee8aba 100644 --- a/packages/@ourworldindata/grapher/src/footer/FooterManager.ts +++ b/packages/@ourworldindata/grapher/src/footer/FooterManager.ts @@ -14,4 +14,6 @@ export interface FooterManager extends TooltipManager, ActionButtonsManager { isSmall?: boolean isMedium?: boolean framePaddingHorizontal?: number + isGeneratingThumbnail?: boolean + fontSize?: number } diff --git a/packages/@ourworldindata/grapher/src/header/Header.tsx b/packages/@ourworldindata/grapher/src/header/Header.tsx index b66bb699e1b..5322f100014 100644 --- a/packages/@ourworldindata/grapher/src/header/Header.tsx +++ b/packages/@ourworldindata/grapher/src/header/Header.tsx @@ -99,7 +99,9 @@ export class Header< } @computed get subtitle(): MarkdownTextWrap { - const fontSize = this.manager.isSmall + const fontSize = this.manager.isGeneratingThumbnail + ? (14 / 16) * (this.manager.fontSize ?? 16) // respect base font size for thumbnails + : this.manager.isSmall ? 12 : this.manager.isMedium ? 13 @@ -205,7 +207,7 @@ interface StaticHeaderProps extends HeaderProps { @observer export class StaticHeader extends Header { @computed get title(): TextWrap { - const { logoWidth, titleText } = this + const { logoWidth, titleText, manager } = this const makeTitle = (fontSize: number): TextWrap => new TextWrap({ @@ -217,7 +219,9 @@ export class StaticHeader extends Header { }) // try to fit the title into a single line if possible-- but not if it would make the text too small - const initialFontSize = 24 + const initialFontSize = manager.isGeneratingThumbnail + ? (24 / 16) * (manager.fontSize ?? 16) // respect base font size for thumbnails + : 24 let title = makeTitle(initialFontSize) const originalLineCount = title.lines.length // decrease the initial font size by no more than 2px using 0.5px steps diff --git a/packages/@ourworldindata/grapher/src/header/HeaderManager.ts b/packages/@ourworldindata/grapher/src/header/HeaderManager.ts index d68d3428bb4..dfd7f385a09 100644 --- a/packages/@ourworldindata/grapher/src/header/HeaderManager.ts +++ b/packages/@ourworldindata/grapher/src/header/HeaderManager.ts @@ -18,4 +18,6 @@ export interface HeaderManager { framePaddingVertical?: number isOnCanonicalUrl?: boolean isInIFrame?: boolean + isGeneratingThumbnail?: boolean + fontSize?: number } From 3f96e2510d67007cda1e103bb047997a77c23591 Mon Sep 17 00:00:00 2001 From: Marcel Gerber Date: Thu, 12 Oct 2023 11:29:36 +0200 Subject: [PATCH 2/3] feat(thumbnails): use `isGeneratingThumbnail` --- functions/_common/grapherRenderer.ts | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/functions/_common/grapherRenderer.ts b/functions/_common/grapherRenderer.ts index 61d7bc57bf2..a5a5028d463 100644 --- a/functions/_common/grapherRenderer.ts +++ b/functions/_common/grapherRenderer.ts @@ -46,7 +46,7 @@ const TWITTER_OPTIONS: ImageOptions = { svgWidth: 800, svgHeight: 418, details: false, - fontSize: 24, + fontSize: 21, } const OPEN_GRAPH_OPTIONS: ImageOptions = { @@ -56,7 +56,7 @@ const OPEN_GRAPH_OPTIONS: ImageOptions = { svgWidth: 800, svgHeight: 418, details: false, - fontSize: 24, + fontSize: 21, } let initialized = false @@ -160,6 +160,7 @@ async function fetchAndRenderGrapherToSvg({ queryStr: "?" + searchParams.toString(), bounds, }) + grapher.isGeneratingThumbnail = true grapher.shouldIncludeDetailsInStaticExport = options.details grapher.baseFontSize = options.fontSize From 0a312618ad9df3f802b74246580e2caec9e084da Mon Sep 17 00:00:00 2001 From: Marcel Gerber Date: Thu, 12 Oct 2023 11:33:04 +0200 Subject: [PATCH 3/3] enhance(grapher): reduce title font size by up to 20% even if that doesn't reduce the number of lines --- .../grapher/src/header/Header.tsx | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/packages/@ourworldindata/grapher/src/header/Header.tsx b/packages/@ourworldindata/grapher/src/header/Header.tsx index 5322f100014..d2a9650e866 100644 --- a/packages/@ourworldindata/grapher/src/header/Header.tsx +++ b/packages/@ourworldindata/grapher/src/header/Header.tsx @@ -223,11 +223,15 @@ export class StaticHeader extends Header { ? (24 / 16) * (manager.fontSize ?? 16) // respect base font size for thumbnails : 24 let title = makeTitle(initialFontSize) + + // if the title is already a single line, no need to decrease font size + if (title.lines.length <= 1) return title + const originalLineCount = title.lines.length - // decrease the initial font size by no more than 2px using 0.5px steps + // decrease the initial font size by no more than 20% using 0.5px steps const potentialFontSizes = range( initialFontSize, - initialFontSize - 2.5, + initialFontSize * 0.8, -0.5 ) for (const fontSize of potentialFontSizes) { @@ -236,12 +240,8 @@ export class StaticHeader extends Header { if (currentLineCount <= 1 || currentLineCount < originalLineCount) break } - - // if decreasing the font size didn't make a difference, use the initial font size - if (title.lines.length === originalLineCount) { - return makeTitle(initialFontSize) - } - + // return the title at the new font size: either it now fits into a single line, or + // its size has been reduced so the multi-line title doesn't take up quite that much space return title }