diff --git a/adminSiteClient/ColorSchemeDropdown.tsx b/adminSiteClient/ColorSchemeDropdown.tsx index bb10e8ca5dc..b4f0b0df570 100644 --- a/adminSiteClient/ColorSchemeDropdown.tsx +++ b/adminSiteClient/ColorSchemeDropdown.tsx @@ -1,7 +1,7 @@ import React from "react" import { computed, action } from "mobx" import Select from "react-select" -import { ChartTypeName } from "@ourworldindata/types" +import { GrapherChartOrMapType } from "@ourworldindata/types" import { ColorScheme, getColorSchemeForChartType, @@ -21,7 +21,7 @@ interface ColorSchemeDropdownProps { value?: string gradientColorCount: number invertedColorScheme: boolean - chartType: ChartTypeName + chartType: GrapherChartOrMapType onChange: (selected: ColorSchemeOption) => void onBlur?: () => void } diff --git a/adminSiteClient/EditorBasicTab.tsx b/adminSiteClient/EditorBasicTab.tsx index 3c506fa12e3..498fa1e2b8c 100644 --- a/adminSiteClient/EditorBasicTab.tsx +++ b/adminSiteClient/EditorBasicTab.tsx @@ -400,9 +400,7 @@ export class EditorBasicTab< render() { const { editor } = this.props const { grapher } = editor - const allChartTypes = Object.keys(ChartTypeName).filter( - (chartType) => chartType !== ChartTypeName.WorldMap - ) + const allChartTypes = Object.keys(ChartTypeName) const isIndicatorChart = isIndicatorChartEditorInstance(editor) diff --git a/adminSiteClient/EditorColorScaleSection.tsx b/adminSiteClient/EditorColorScaleSection.tsx index b04e6ea07b6..fe6753d1276 100644 --- a/adminSiteClient/EditorColorScaleSection.tsx +++ b/adminSiteClient/EditorColorScaleSection.tsx @@ -7,7 +7,7 @@ import { faPlus, faMinus } from "@fortawesome/free-solid-svg-icons" import { ColorSchemeName, BinningStrategy, - ChartTypeName, + GrapherChartOrMapType, Color, } from "@ourworldindata/types" import { @@ -43,7 +43,7 @@ interface EditorColorScaleSectionFeatures { @observer export class EditorColorScaleSection extends React.Component<{ scale: ColorScale - chartType: ChartTypeName + chartType: GrapherChartOrMapType features: EditorColorScaleSectionFeatures showLineChartColors: boolean onChange?: () => void @@ -132,7 +132,7 @@ class ColorLegendSection extends React.Component<{ @observer class ColorsSection extends React.Component<{ scale: ColorScale - chartType: ChartTypeName + chartType: GrapherChartOrMapType showLineChartColors: boolean onChange?: () => void }> { diff --git a/adminSiteClient/EditorMapTab.tsx b/adminSiteClient/EditorMapTab.tsx index c743e691ff2..51d5b2b689f 100644 --- a/adminSiteClient/EditorMapTab.tsx +++ b/adminSiteClient/EditorMapTab.tsx @@ -1,7 +1,7 @@ import { - ChartTypeName, GrapherInterface, MapProjectionName, + GRAPHER_MAP_TYPE, } from "@ourworldindata/types" import { ChartDimension, @@ -202,7 +202,7 @@ export class EditorMapTab< >"$.hasMapTab" = "true"`) tab = tab || GrapherTabOption.map } else { diff --git a/devTools/svgTester/chart-configurations.ts b/devTools/svgTester/chart-configurations.ts index 03a82a5f1c7..8b2841bdc4c 100644 --- a/devTools/svgTester/chart-configurations.ts +++ b/devTools/svgTester/chart-configurations.ts @@ -88,7 +88,6 @@ const VIEW_MATRIX_BY_CHART_TYPE: Record = { facet: facetOptions, uniformYAxis: booleanOptions, }, - [ChartTypeName.WorldMap]: {}, } // the above view matrix is used to generate all possible combinations of query params @@ -129,7 +128,6 @@ const EXCLUDE_VIEWS_BY_CHART_TYPE: Record< // sharing an axis only makes sense if a chart is faceted { facet: FacetStrategy.none, uniformYAxis: Boolean.true }, ], - [ChartTypeName.WorldMap]: [], } export const queryStringsByChartType = Object.fromEntries( diff --git a/devTools/svgTester/dump-chart-ids.ts b/devTools/svgTester/dump-chart-ids.ts index e824f5898f9..c712903ad35 100644 --- a/devTools/svgTester/dump-chart-ids.ts +++ b/devTools/svgTester/dump-chart-ids.ts @@ -5,7 +5,7 @@ import parseArgs from "minimist" import { TransactionCloseMode, knexReadonlyTransaction } from "../../db/db.js" import { getMostViewedGrapherIdsByChartType } from "../../db/model/Chart.js" -import { CHART_TYPES } from "./utils.js" +import { allChartTypes } from "./utils.js" const DEFAULT_OUT_FILE = "../owid-grapher-svgs/most-viewed-charts.txt" const CHART_COUNT_PER_TYPE = 25 @@ -15,7 +15,7 @@ async function main(parsedArgs: parseArgs.ParsedArgs) { const outFile = parsedArgs["o"] ?? DEFAULT_OUT_FILE const chartIds = await knexReadonlyTransaction(async (trx) => { - const promises = CHART_TYPES.flatMap((chartType) => + const promises = allChartTypes.flatMap((chartType) => getMostViewedGrapherIdsByChartType( trx, chartType, diff --git a/devTools/svgTester/utils.ts b/devTools/svgTester/utils.ts index 724a41a0492..21ac9162b4a 100644 --- a/devTools/svgTester/utils.ts +++ b/devTools/svgTester/utils.ts @@ -26,10 +26,7 @@ import { getHeapStatistics } from "v8" import { queryStringsByChartType } from "./chart-configurations.js" import * as d3 from "d3" -// ignore WorldMaps -export const CHART_TYPES = Object.values(ChartTypeName).filter( - (chartType) => chartType !== ChartTypeName.WorldMap -) +export const allChartTypes = Object.values(ChartTypeName) // the owid-grapher-svgs repo is usually cloned as a sibling to the owid-grapher repo export const DEFAULT_CONFIGS_DIR = "../owid-grapher-svgs/configs" @@ -303,14 +300,14 @@ export async function findValidChartIds( export function validateChartTypes(chartTypes: string[]): ChartTypeName[] { const validChartTypes = chartTypes.filter( (chartType): chartType is ChartTypeName => - CHART_TYPES.includes(chartType as any) + allChartTypes.includes(chartType as any) ) const invalidChartTypes = chartTypes.filter( - (chartType) => !CHART_TYPES.includes(chartType as any) + (chartType) => !allChartTypes.includes(chartType as any) ) if (invalidChartTypes.length) { console.warn( - `Invalid chart types given: ${invalidChartTypes}. Valid chart types are: ${CHART_TYPES}` + `Invalid chart types given: ${invalidChartTypes}. Valid chart types are: ${allChartTypes}` ) } return _.uniq(validChartTypes) diff --git a/packages/@ourworldindata/grapher/src/captionedChart/CaptionedChart.tsx b/packages/@ourworldindata/grapher/src/captionedChart/CaptionedChart.tsx index d7ba2a7f0b4..ec03ed8c7cb 100644 --- a/packages/@ourworldindata/grapher/src/captionedChart/CaptionedChart.tsx +++ b/packages/@ourworldindata/grapher/src/captionedChart/CaptionedChart.tsx @@ -35,10 +35,11 @@ import { EntityName, ChartTypeName, FacetStrategy, - GrapherTabOption, RelatedQuestionsConfig, Color, GrapherTabName, + GRAPHER_MAP_TYPE, + GrapherChartOrMapType, } from "@ourworldindata/types" import { DataTable, DataTableManager } from "../dataTable/DataTable" import { @@ -200,10 +201,10 @@ export class CaptionedChart extends React.Component { return !this.manager.isOnMapTab && hasStrategy } - @computed get activeChartType(): ChartTypeName | undefined { + @computed get activeChartOrMapType(): GrapherChartOrMapType | undefined { const { manager } = this if (manager.isOnTableTab) return undefined - if (manager.isOnMapTab) return ChartTypeName.WorldMap + if (manager.isOnMapTab) return GRAPHER_MAP_TYPE if (manager.isOnChartTab) { return manager.isLineChartThatTurnedIntoDiscreteBar ? ChartTypeName.DiscreteBar @@ -213,20 +214,21 @@ export class CaptionedChart extends React.Component { } renderChart(): React.ReactElement | void { - const { manager, activeChartType } = this + const { manager, activeChartOrMapType } = this - if (!activeChartType) return + if (!activeChartOrMapType) return const bounds = this.boundsForChartArea const ChartClass = - ChartComponentClassMap.get(activeChartType) ?? DefaultChartClass + ChartComponentClassMap.get(activeChartOrMapType) ?? + DefaultChartClass // Todo: make FacetChart a chart type name? - if (this.isFaceted) + if (this.isFaceted && activeChartOrMapType !== GRAPHER_MAP_TYPE) return ( ) @@ -235,7 +237,7 @@ export class CaptionedChart extends React.Component { ) } diff --git a/packages/@ourworldindata/grapher/src/chart/ChartTypeMap.tsx b/packages/@ourworldindata/grapher/src/chart/ChartTypeMap.tsx index 45a0eef3b5f..9fe6a92ef05 100644 --- a/packages/@ourworldindata/grapher/src/chart/ChartTypeMap.tsx +++ b/packages/@ourworldindata/grapher/src/chart/ChartTypeMap.tsx @@ -4,7 +4,11 @@ import { LineChart } from "../lineCharts/LineChart" import { StackedAreaChart } from "../stackedCharts/StackedAreaChart" import { DiscreteBarChart } from "../barCharts/DiscreteBarChart" import { StackedBarChart } from "../stackedCharts/StackedBarChart" -import { ChartTypeName } from "@ourworldindata/types" +import { + ChartTypeName, + GrapherChartOrMapType, + GRAPHER_MAP_TYPE, +} from "@ourworldindata/types" import { MapChart } from "../mapCharts/MapChart" import { ChartInterface } from "./ChartInterface" import { ChartManager } from "./ChartManager" @@ -24,7 +28,7 @@ interface ChartComponentClass extends ComponentClass { } export const ChartComponentClassMap = new Map< - ChartTypeName, + GrapherChartOrMapType, ChartComponentClass >([ [ChartTypeName.DiscreteBar, DiscreteBarChart], @@ -35,7 +39,7 @@ export const ChartComponentClassMap = new Map< [ChartTypeName.StackedDiscreteBar, StackedDiscreteBarChart], [ChartTypeName.ScatterPlot, ScatterPlotChart], [ChartTypeName.Marimekko, MarimekkoChart], - [ChartTypeName.WorldMap, MapChart], + [GRAPHER_MAP_TYPE, MapChart], ]) export const DefaultChartClass = LineChart as ChartComponentClass diff --git a/packages/@ourworldindata/grapher/src/color/ColorSchemes.ts b/packages/@ourworldindata/grapher/src/color/ColorSchemes.ts index ab213d91406..376a1829055 100644 --- a/packages/@ourworldindata/grapher/src/color/ColorSchemes.ts +++ b/packages/@ourworldindata/grapher/src/color/ColorSchemes.ts @@ -6,10 +6,14 @@ import { ChartTypeName, ColorSchemeInterface, ColorSchemeName, + GRAPHER_MAP_TYPE, + GrapherChartOrMapType, } from "@ourworldindata/types" import { getColorBrewerScheme } from "./ColorBrewerSchemes.js" -function getPreferredSchemesByType(type: ChartTypeName): ColorSchemeName[] { +function getPreferredSchemesByType( + type: GrapherChartOrMapType +): ColorSchemeName[] { // This function could also be a Map but // by doing it as a function usign ts-pattern.match we get compile // time safety that all enum cases in ChartTypeName are always handled here @@ -84,7 +88,7 @@ function getPreferredSchemesByType(type: ChartTypeName): ColorSchemeName[] { ColorSchemeName.SingleColorGradientDustyCoral, ColorSchemeName.SingleColorGradientDarkCopper, ]) - .with(ChartTypeName.WorldMap, () => [ + .with(GRAPHER_MAP_TYPE, () => [ ColorSchemeName.BinaryMapPaletteA, ColorSchemeName.BinaryMapPaletteB, ColorSchemeName.BinaryMapPaletteC, diff --git a/packages/@ourworldindata/grapher/src/controls/ChartIcons.tsx b/packages/@ourworldindata/grapher/src/controls/ChartIcons.tsx index 605c2f7fd7f..980c055edbf 100644 --- a/packages/@ourworldindata/grapher/src/controls/ChartIcons.tsx +++ b/packages/@ourworldindata/grapher/src/controls/ChartIcons.tsx @@ -107,7 +107,4 @@ export const chartIcons: Record = { ), - - // world map (will never be invoked but included for completeness) - [ChartTypeName.WorldMap]: , } diff --git a/packages/@ourworldindata/types/src/dbTypes/ChartConfigs.ts b/packages/@ourworldindata/types/src/dbTypes/ChartConfigs.ts index d6ad7227811..b6a6e29b936 100644 --- a/packages/@ourworldindata/types/src/dbTypes/ChartConfigs.ts +++ b/packages/@ourworldindata/types/src/dbTypes/ChartConfigs.ts @@ -11,7 +11,7 @@ export interface DbInsertChartConfig { full: JsonString fullMd5?: Base64String slug?: string | null - chartType?: ChartTypeName | null // TODO: exclude WorldMap + chartType?: ChartTypeName | null createdAt?: Date updatedAt?: Date | null } diff --git a/packages/@ourworldindata/types/src/grapherTypes/GrapherTypes.ts b/packages/@ourworldindata/types/src/grapherTypes/GrapherTypes.ts index 82b060b58b6..00fc9eb93c1 100644 --- a/packages/@ourworldindata/types/src/grapherTypes/GrapherTypes.ts +++ b/packages/@ourworldindata/types/src/grapherTypes/GrapherTypes.ts @@ -119,6 +119,10 @@ export enum ToleranceStrategy { backwards = "backwards", forwards = "forwards", } + +export const GRAPHER_MAP_TYPE = "WorldMap" +type GrapherMapType = typeof GRAPHER_MAP_TYPE + export enum ChartTypeName { LineChart = "LineChart", ScatterPlot = "ScatterPlot", @@ -128,10 +132,10 @@ export enum ChartTypeName { SlopeChart = "SlopeChart", StackedBar = "StackedBar", Marimekko = "Marimekko", - // special map type that can't be selected by authors - WorldMap = "WorldMap", } +export type GrapherChartOrMapType = ChartTypeName | GrapherMapType + export enum AxisMinMaxValueStr { auto = "auto", } diff --git a/packages/@ourworldindata/types/src/index.ts b/packages/@ourworldindata/types/src/index.ts index ea93c38d22b..1549a9e7851 100644 --- a/packages/@ourworldindata/types/src/index.ts +++ b/packages/@ourworldindata/types/src/index.ts @@ -75,6 +75,8 @@ export { ColorSchemeName, colorScaleConfigDefaults, ChartTypeName, + type GrapherChartOrMapType, + GRAPHER_MAP_TYPE, GrapherTabOption, GrapherTabName, GrapherTabQueryParam,