diff --git a/packages/@ourworldindata/grapher/src/core/Grapher.tsx b/packages/@ourworldindata/grapher/src/core/Grapher.tsx index de63eb0408e..12855174dd6 100644 --- a/packages/@ourworldindata/grapher/src/core/Grapher.tsx +++ b/packages/@ourworldindata/grapher/src/core/Grapher.tsx @@ -1446,24 +1446,48 @@ export class Grapher ]) } - @computed get columnsWithSources(): CoreColumn[] { + @computed get columnsWithSourcesExtensive(): CoreColumn[] { const { yColumnSlugs, xColumnSlug, sizeColumnSlug, colorColumnSlug } = this + const columnSlugs = excludeUndefined([ + ...yColumnSlugs, + xColumnSlug, + sizeColumnSlug, + colorColumnSlug, + ]) + + return this.inputTable + .getColumns(uniq(columnSlugs)) + .filter( + (column) => !!column.source.name || !isEmpty(column.def.origins) + ) + } + + getColumnSlugsForCondensedSources(): string[] { + const { xColumnSlug, sizeColumnSlug, colorColumnSlug, isMarimekko } = + this + const columnSlugs: string[] = [] + // "Countries Continent" const isContinentsVariableId = (id: string): boolean => id === "123" + // exclude "Countries Continent" if it's used as the color dimension in a scatter plot, slope chart etc. + if ( + colorColumnSlug !== undefined && + !isContinentsVariableId(colorColumnSlug) + ) + columnSlugs.push(colorColumnSlug) + const isPopulationVariableId = (id: string): boolean => id === "525709" || // "Population (historical + projections), Gapminder, HYDE & UN" id === "525711" || // "Population (historical estimates), Gapminder, HYDE & UN" id === "597929" || // "Population (various sources, 2023.1)" id === "597930" // "Population (various sources, 2023.1)" - const columnSlugs = [...yColumnSlugs] - if (xColumnSlug !== undefined) { // exclude population variable if it's used as the x dimension in a marimekko - if (!isPopulationVariableId(xColumnSlug) || !this.isMarimekko) + if (!isMarimekko || !isPopulationVariableId(xColumnSlug)) columnSlugs.push(xColumnSlug) } @@ -1473,13 +1497,14 @@ export class Grapher !isPopulationVariableId(sizeColumnSlug) ) columnSlugs.push(sizeColumnSlug) + return columnSlugs + } - // exclude "Countries Continent" if it's used as the color dimension in a scatter plot, slope chart etc. - if ( - colorColumnSlug !== undefined && - !isContinentsVariableId(colorColumnSlug) - ) - columnSlugs.push(colorColumnSlug) + @computed get columnsWithSourcesCondensed(): CoreColumn[] { + const { yColumnSlugs } = this + + const columnSlugs = [...yColumnSlugs] + columnSlugs.push(...this.getColumnSlugsForCondensedSources()) return this.inputTable .getColumns(uniq(columnSlugs)) @@ -1489,22 +1514,24 @@ export class Grapher } @computed private get defaultSourcesLine(): string { - const attributions = this.columnsWithSources.flatMap((column) => { - // if the variable metadata specifies an attribution on the - // variable level then this is preferred over assembling it from - // the source and origins - if ( - column.def.attribution !== undefined && - column.def.attribution !== "" - ) - return [column.def.attribution] - else { - const originFragments = getOriginAttributionFragments( - column.def.origins + const attributions = this.columnsWithSourcesCondensed.flatMap( + (column) => { + // if the variable metadata specifies an attribution on the + // variable level then this is preferred over assembling it from + // the source and origins + if ( + column.def.attribution !== undefined && + column.def.attribution !== "" ) - return [column.source.name, ...originFragments] + return [column.def.attribution] + else { + const originFragments = getOriginAttributionFragments( + column.def.origins + ) + return [column.source.name, ...originFragments] + } } - }) + ) const uniqueAttributions = uniq(compact(attributions)) diff --git a/packages/@ourworldindata/grapher/src/modal/SourcesModal.stories.tsx b/packages/@ourworldindata/grapher/src/modal/SourcesModal.stories.tsx index ffdd7e1124e..77265545a49 100644 --- a/packages/@ourworldindata/grapher/src/modal/SourcesModal.stories.tsx +++ b/packages/@ourworldindata/grapher/src/modal/SourcesModal.stories.tsx @@ -9,9 +9,11 @@ export default { export const WithSources = (): JSX.Element => ( ) export const NoSources = (): JSX.Element => ( - + ) diff --git a/packages/@ourworldindata/grapher/src/modal/SourcesModal.tsx b/packages/@ourworldindata/grapher/src/modal/SourcesModal.tsx index 2033f6ec7a4..95b771330d6 100644 --- a/packages/@ourworldindata/grapher/src/modal/SourcesModal.tsx +++ b/packages/@ourworldindata/grapher/src/modal/SourcesModal.tsx @@ -16,7 +16,7 @@ import { Modal } from "./Modal" export interface SourcesModalManager { adminBaseUrl?: string - columnsWithSources: CoreColumn[] + columnsWithSourcesExtensive: CoreColumn[] showAdminControls?: boolean isSourcesModalOpen?: boolean tabBounds?: Bounds @@ -268,7 +268,7 @@ export class SourcesModal extends React.Component<{ } render(): JSX.Element { - const cols = this.manager.columnsWithSources + const cols = this.manager.columnsWithSourcesExtensive return (