Skip to content

Commit

Permalink
🔨 (slope) clean up
Browse files Browse the repository at this point in the history
  • Loading branch information
sophiamersmann committed Dec 6, 2024
1 parent f4b494e commit a96f0a2
Show file tree
Hide file tree
Showing 5 changed files with 25 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,9 @@ export class TextWrapGroup {
return max(this.textWraps.map((textWrap) => textWrap.width)) ?? 0
}

// split concatenated fragments into lines for rendering. a line may have
// multiple fragments since each fragment comes with its own style and
// is therefore rendered into a separate tspan.
@computed get lines(): {
fragments: Omit<TextWrapFragment, "newLine">[]
textWrap: TextWrap
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -881,7 +881,7 @@ export class LineChart

// only pass props that are required to calculate
// the width to avoid circular dependencies
return LineLegend.width({
return LineLegend.stableWidth({
labelSeries: this.lineLegendSeries,
maxWidth: this.maxLineLegendWidth,
fontSize: this.fontSize,
Expand Down
14 changes: 11 additions & 3 deletions packages/@ourworldindata/grapher/src/lineLegend/LineLegend.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -354,9 +354,9 @@ export class LineLegend extends React.Component<LineLegendProps> {
* This is partly due to a circular dependency (in line and stacked area
* charts), partly to avoid jumpy layout changes (slope charts).
*/
static width(props: LineLegendProps): number {
static stableWidth(props: LineLegendProps): number {
const test = new LineLegend(props)
return test.maxLabelWidth + DEFAULT_CONNECTOR_LINE_WIDTH + MARKER_MARGIN
return test.stableWidth
}

static fontSize(props: Partial<LineLegendProps>): number {
Expand All @@ -371,7 +371,7 @@ export class LineLegend extends React.Component<LineLegendProps> {

static visibleSeriesNames(props: LineLegendProps): SeriesName[] {
const test = new LineLegend(props as LineLegendProps)
return test.partialInitialSeries.map((series) => series.seriesName)
return test.visibleSeriesNames
}

@computed private get fontSize(): number {
Expand Down Expand Up @@ -445,6 +445,10 @@ export class LineLegend extends React.Component<LineLegendProps> {
return max(sizedLabels.map((d) => d.width)) ?? 0
}

@computed get stableWidth(): number {
return this.maxLabelWidth + DEFAULT_CONNECTOR_LINE_WIDTH + MARKER_MARGIN
}

@computed get onMouseOver(): any {
return this.props.onMouseOver ?? noop
}
Expand Down Expand Up @@ -755,6 +759,10 @@ export class LineLegend extends React.Component<LineLegendProps> {
}
}

@computed get visibleSeriesNames(): SeriesName[] {
return this.partialInitialSeries.map((series) => series.seriesName)
}

@computed private get backgroundSeries(): PlacedSeries[] {
const { focusedSeriesNames } = this
const { isFocusMode } = this
Expand Down
25 changes: 9 additions & 16 deletions packages/@ourworldindata/grapher/src/slopeCharts/SlopeChart.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -411,10 +411,6 @@ export class SlopeChart
)
}

@computed get seriesByName(): Map<SeriesName, SlopeChartSeries> {
return new Map(this.series.map((series) => [series.seriesName, series]))
}

@computed private get placedSeries(): PlacedSlopeChartSeries[] {
const { yAxis, startX, endX } = this

Expand Down Expand Up @@ -595,31 +591,28 @@ export class SlopeChart

@computed get lineLegendWidthLeft(): number {
if (!this.manager.showLegend) return 0
return LineLegend.width({
return LineLegend.stableWidth({
labelSeries: this.lineLegendSeriesLeft,
...this.lineLegendPropsCommon,
...this.lineLegendPropsLeft,
})
}

@computed get lineLegendWidthRight(): number {
if (!this.manager.showLegend) return 0
return LineLegend.width({
@computed get lineLegendRight(): LineLegend | undefined {
if (!this.manager.showLegend) return undefined
return new LineLegend({
labelSeries: this.lineLegendSeriesRight,
...this.lineLegendPropsCommon,
...this.lineLegendPropsRight,
})
}

@computed get lineLegendWidthRight(): number {
return this.lineLegendRight?.stableWidth ?? 0
}

@computed get visibleLineLegendLabelsRight(): Set<SeriesName> {
if (!this.manager.showLegend) return new Set()
return new Set(
LineLegend.visibleSeriesNames({
labelSeries: this.lineLegendSeriesRight,
...this.lineLegendPropsCommon,
...this.lineLegendPropsRight,
})
)
return new Set(this.lineLegendRight?.visibleSeriesNames ?? [])
}

@computed get seriesSortedByImportanceForLineLegendLeft(): SeriesName[] {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -317,7 +317,7 @@ export class StackedAreaChart extends AbstractStackedChart {

// only pass props that are required to calculate
// the width to avoid circular dependencies
return LineLegend.width({
return LineLegend.stableWidth({
labelSeries: this.lineLegendSeries,
maxWidth: this.maxLineLegendWidth,
fontSize: this.fontSize,
Expand Down

0 comments on commit a96f0a2

Please sign in to comment.