From ae3cd6f0ae1b43980d28b0a74c8b5c42eea717d4 Mon Sep 17 00:00:00 2001 From: Marcel Gerber Date: Thu, 10 Oct 2024 12:42:20 +0200 Subject: [PATCH] enhance: centralize `columnsToIgnore` --- functions/_common/grapherRenderer.ts | 35 +++++++++++----------------- 1 file changed, 13 insertions(+), 22 deletions(-) diff --git a/functions/_common/grapherRenderer.ts b/functions/_common/grapherRenderer.ts index 867440f30c8..4dd28fceb3a 100644 --- a/functions/_common/grapherRenderer.ts +++ b/functions/_common/grapherRenderer.ts @@ -317,7 +317,7 @@ async function initGrapher( return grapher } -function assembleMetadata(grapher: Grapher, searchParams: URLSearchParams) { +const getColumnsForMetadata = (grapher: Grapher) => { const columnsToIgnore = new Set( [ OwidTableSlugs.entityId, @@ -330,12 +330,19 @@ function assembleMetadata(grapher: Grapher, searchParams: URLSearchParams) { ].map((slug) => slug.toString()) ) - const columnsToGet = grapher.inputTable.columnSlugs.filter( + const colsToGet = grapher.inputTable.columnSlugs.filter( (col) => !columnsToIgnore.has(col) ) + + return grapher.inputTable.getColumns(colsToGet) +} + +function assembleMetadata(grapher: Grapher, searchParams: URLSearchParams) { const useShortNames = searchParams.get("useColumnShortNames") === "true" console.log("useShortNames", useShortNames) + const metadataCols = getColumnsForMetadata(grapher) + const columns: [ string, { @@ -366,7 +373,7 @@ function assembleMetadata(grapher: Grapher, searchParams: URLSearchParams) { >[] shortName: string }, - ][] = grapher.inputTable.getColumns(columnsToGet).map((col) => { + ][] = metadataCols.map((col) => { console.log("mapping col", col.name) const { descriptionShort, @@ -630,26 +637,10 @@ export async function fetchReadmeForGrapher( } function assembleReadme(grapher: Grapher): string { - const columnsToIgnore = new Set( - [ - OwidTableSlugs.entityId, - OwidTableSlugs.time, - OwidTableSlugs.entityColor, - OwidTableSlugs.entityName, - OwidTableSlugs.entityCode, - OwidTableSlugs.year, - OwidTableSlugs.day, - ].map((slug) => slug.toString()) - ) - - const columnsToGet = grapher.inputTable.columnSlugs.filter( - (col) => !columnsToIgnore.has(col) - ) - - const columns = grapher.inputTable.getColumns(columnsToGet) - - return constructReadme(grapher, columns) + const metadataCols = getColumnsForMetadata(grapher) + return constructReadme(grapher, metadataCols) } + async function fetchAndRenderGrapherToSvg( identifier: GrapherIdentifier, options: ImageOptions,