diff --git a/adminSiteClient/DimensionCard.tsx b/adminSiteClient/DimensionCard.tsx
index d812d2ba16..87f69dbcdb 100644
--- a/adminSiteClient/DimensionCard.tsx
+++ b/adminSiteClient/DimensionCard.tsx
@@ -51,8 +51,8 @@ export class DimensionCard<
this.onChange()
}
- @action.bound onIsConnected(value: boolean) {
- this.props.dimension.display.isConnected = value
+ @action.bound onPlotMarkersOnly(value: boolean) {
+ this.props.dimension.display.plotMarkersOnlyInLineChart = value
this.onChange()
}
@@ -259,9 +259,12 @@ export class DimensionCard<
)}
{grapher.isLineChart && (
)}
diff --git a/packages/@ourworldindata/grapher/src/lineCharts/LineChart.tsx b/packages/@ourworldindata/grapher/src/lineCharts/LineChart.tsx
index 5033d637d3..8a87922921 100644
--- a/packages/@ourworldindata/grapher/src/lineCharts/LineChart.tsx
+++ b/packages/@ourworldindata/grapher/src/lineCharts/LineChart.tsx
@@ -172,17 +172,17 @@ class Lines extends React.Component {
return totalPoints < 500
}
- @computed private get hasDisconnectedSeries(): boolean {
- return this.props.series.some((series) => !series.isConnected)
+ @computed private get hasMarkersOnlySeries(): boolean {
+ return this.props.series.some((series) => series.plotMarkersOnly)
}
private seriesHasMarkers(series: RenderLineChartSeries): boolean {
if (
series.hover.background ||
series.isProjection ||
- // if the series is connected, but there is another one that isn't connected,
- // don't show markers since the connected series is likely a smoothed version
- (this.hasDisconnectedSeries && series.isConnected)
+ // if the series has a line, but there is another one that hasn't, then
+ // don't show markers since the plotted line is likely a smoothed version
+ (this.hasMarkersOnlySeries && !series.plotMarkersOnly)
)
return false
return !series.focus.background || series.hover.active
@@ -193,7 +193,7 @@ class Lines extends React.Component {
): React.ReactElement | void {
const { hover, focus } = series
- if (!series.isConnected) return
+ if (series.plotMarkersOnly) return
const seriesColor = series.placedPoints[0]?.color ?? DEFAULT_LINE_COLOR
const color =
@@ -262,7 +262,7 @@ class Lines extends React.Component {
// show a marker/circle because we can't draw a line.
series.placedPoints.length === 1 ||
// If no line is plotted, we'll always want to show markers
- !series.isConnected
+ series.plotMarkersOnly
// check if we should hide markers on the chart and series level
const hideMarkers = !this.hasMarkers || !this.seriesHasMarkers(series)
@@ -272,8 +272,12 @@ class Lines extends React.Component {
const opacity =
hover.background && !focus.background ? GRAPHER_OPACITY_MUTE : 1
- const outlineColor = !series.isConnected ? this.outlineColor : undefined
- const outlineWidth = !series.isConnected ? this.outlineWidth : undefined
+ const outlineColor = series.plotMarkersOnly
+ ? this.outlineColor
+ : undefined
+ const outlineWidth = series.plotMarkersOnly
+ ? this.outlineWidth
+ : undefined
return (
@@ -548,7 +552,7 @@ export class LineChart
}
@computed private get markerRadius(): number {
- if (this.hasDisconnectedSeries) return DISCONNECTED_DOTS_MARKER_RADIUS
+ if (this.hasMarkersOnlySeries) return DISCONNECTED_DOTS_MARKER_RADIUS
if (this.hasColorScale) return VARIABLE_COLOR_MARKER_RADIUS
return DEFAULT_MARKER_RADIUS
}
@@ -1316,7 +1320,7 @@ export class LineChart
points,
seriesName,
isProjection: column.isProjection,
- isConnected: column.display?.isConnected ?? true,
+ plotMarkersOnly: column.display?.plotMarkersOnlyInLineChart,
color: seriesColor,
}
}
@@ -1330,8 +1334,8 @@ export class LineChart
)
}
- @computed private get hasDisconnectedSeries(): boolean {
- return this.series.some((series) => !series.isConnected)
+ @computed private get hasMarkersOnlySeries(): boolean {
+ return this.series.some((series) => series.plotMarkersOnly)
}
// TODO: remove, seems unused
@@ -1387,8 +1391,8 @@ export class LineChart
}
)
- // draw connected series on top of disconnected ones
- series = sortBy(series, (series) => series.isConnected)
+ // draw lines on top of markers-only series
+ series = sortBy(series, (series) => !series.plotMarkersOnly)
// sort by interaction state so that foreground series
// are drawn on top of background series
diff --git a/packages/@ourworldindata/grapher/src/lineCharts/LineChartConstants.ts b/packages/@ourworldindata/grapher/src/lineCharts/LineChartConstants.ts
index 0da51b6884..749da005d8 100644
--- a/packages/@ourworldindata/grapher/src/lineCharts/LineChartConstants.ts
+++ b/packages/@ourworldindata/grapher/src/lineCharts/LineChartConstants.ts
@@ -23,7 +23,7 @@ export interface PlacedPoint {
export interface LineChartSeries extends ChartSeries {
isProjection?: boolean
- isConnected?: boolean
+ plotMarkersOnly?: boolean
points: LinePoint[]
}
diff --git a/packages/@ourworldindata/grapher/src/schema/grapher-schema.006.yaml b/packages/@ourworldindata/grapher/src/schema/grapher-schema.006.yaml
index 4d47e18d50..18cc124752 100644
--- a/packages/@ourworldindata/grapher/src/schema/grapher-schema.006.yaml
+++ b/packages/@ourworldindata/grapher/src/schema/grapher-schema.006.yaml
@@ -266,11 +266,11 @@ properties:
description: |
Indicates if this time series is a forward projection (if yes then this is rendered
differently in e.g. line charts)
- isConnected:
+ plotMarkersOnlyInLineChart:
type: boolean
default: false
description: |
- Indicates if this time series should be connected with a line. Only relevant for line charts.
+ Indicates if data points should be connected with a line in a line chart
name:
type: string
description: The display string for this variable
diff --git a/packages/@ourworldindata/types/src/OwidVariableDisplayConfigInterface.ts b/packages/@ourworldindata/types/src/OwidVariableDisplayConfigInterface.ts
index f44feaf8f9..6c7c0a182c 100644
--- a/packages/@ourworldindata/types/src/OwidVariableDisplayConfigInterface.ts
+++ b/packages/@ourworldindata/types/src/OwidVariableDisplayConfigInterface.ts
@@ -21,7 +21,7 @@ export interface OwidVariableDisplayConfigInterface {
includeInTable?: boolean
tableDisplay?: OwidVariableDataTableConfigInterface
color?: string
- isConnected?: boolean
+ plotMarkersOnlyInLineChart?: boolean
}
// todo: flatten onto the above
diff --git a/packages/@ourworldindata/utils/src/OwidVariable.ts b/packages/@ourworldindata/utils/src/OwidVariable.ts
index 74201954b6..7ffbb8e894 100644
--- a/packages/@ourworldindata/utils/src/OwidVariable.ts
+++ b/packages/@ourworldindata/utils/src/OwidVariable.ts
@@ -29,7 +29,7 @@ class OwidVariableDisplayConfigDefaults {
@observable includeInTable? = true
@observable tableDisplay?: OwidVariableDataTableConfigInterface
@observable color?: string = undefined
- @observable isConnected?: boolean = undefined
+ @observable plotMarkersOnlyInLineChart?: boolean = undefined
}
export class OwidVariableDisplayConfig