Skip to content

Commit

Permalink
feat: implement cumulative values DHIS2-5497
Browse files Browse the repository at this point in the history
  • Loading branch information
edoardo committed Aug 25, 2023
1 parent 3b7302d commit 1d1f3f2
Show file tree
Hide file tree
Showing 2 changed files with 89 additions and 1 deletion.
40 changes: 40 additions & 0 deletions src/__demo__/PivotTable.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -784,6 +784,26 @@ storiesOf('PivotTable', module).add(
}
)

storiesOf('PivotTable', module).add(
'cumulative + empty columns (weekly) - shown',
(_, { pivotTableOptions }) => {
const visualization = {
...weeklyColumnsVisualization,
...pivotTableOptions,
hideEmptyColumns: false,
cumulativeValues: true,
}
return (
<div style={{ width: 800, height: 600 }}>
<PivotTable
data={weeklyColumnsData}
visualization={visualization}
/>
</div>
)
}
)

storiesOf('PivotTable', module).add(
'empty columns (weekly) - hidden',
(_, { pivotTableOptions }) => {
Expand All @@ -803,6 +823,26 @@ storiesOf('PivotTable', module).add(
}
)

storiesOf('PivotTable', module).add(
'cumulative + empty columns (weekly) - hidden',
(_, { pivotTableOptions }) => {
const visualization = {
...weeklyColumnsVisualization,
...pivotTableOptions,
hideEmptyColumns: true,
cumulativeValues: true,
}
return (
<div style={{ width: 800, height: 600 }}>
<PivotTable
data={weeklyColumnsData}
visualization={visualization}
/>
</div>
)
}
)

storiesOf('PivotTable', module).add(
'empty columns + assigned cats (shown)',
(_, { pivotTableOptions }) => {
Expand Down
50 changes: 49 additions & 1 deletion src/modules/pivotTable/PivotTableEngine.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ const defaultOptions = {
showColumnSubtotals: false,
fixColumnHeaders: false,
fixRowHeaders: false,
cumulativeValues: false,
}

const defaultVisualizationProps = {
Expand Down Expand Up @@ -266,6 +267,7 @@ export class PivotTableEngine {
data = []
rowMap = []
columnMap = []
accumulators = { rows: {} }

constructor(visualization, data, legendSets) {
this.visualization = Object.assign(
Expand Down Expand Up @@ -304,6 +306,7 @@ export class PivotTableEngine {
fixRowHeaders: this.dimensionLookup.rows.length
? visualization.fixRowHeaders
: false,
cumulativeValues: visualization.cumulativeValues,
}

this.adaptiveClippingController = new AdaptiveClippingController(this)
Expand Down Expand Up @@ -395,6 +398,10 @@ export class PivotTableEngine {
}
}

getCumulative({ row, column }) {
return this.accumulators.rows[row][column]
}

get({ row, column }) {
const mappedRow = this.rowMap[row],
mappedColumn = this.columnMap[column]
Expand All @@ -405,7 +412,27 @@ export class PivotTableEngine {
return undefined
}

return this.getRaw({ row: mappedRow, column: mappedColumn })
const value = this.getRaw({ row: mappedRow, column: mappedColumn })

// XXX cannot be done directly in getRaw because of the resetAccumulators function
if (this.options.cumulativeValues) {
// some duplicated code here, see if there's a better way
const dxDimension = this.getRawCellDxDimension({ row, column })

// XXX this doesn't make much sense, it has to be numeric for accumulation
value.valueType = dxDimension?.valueType || VALUE_TYPE_TEXT
value.empty = false
value.renderedValue = renderValue(
this.getCumulative({
row: mappedRow,
column: mappedColumn,
}),
value.valueType,
this.visualization
)
}

return value
}

getRawCellType({ row, column }) {
Expand Down Expand Up @@ -957,6 +984,25 @@ export class PivotTableEngine {
: times(this.dataWidth, (n) => n)
}

resetAccumulators() {
if (this.options.cumulativeValues) {
this.rowMap.forEach((row) => {
this.accumulators.rows[row] = {}
this.columnMap.reduce((acc, column) => {
const value = this.getRaw({ row, column })

acc += value.empty ? 0 : value.rawValue

this.accumulators.rows[row][column] = acc

return acc
}, 0)
})
} else {
this.accumulators = { rows: {} }
}
}

get cellPadding() {
switch (this.visualization.displayDensity) {
case DISPLAY_DENSITY_OPTION_COMPACT:
Expand Down Expand Up @@ -1062,6 +1108,8 @@ export class PivotTableEngine {
this.resetRowMap()
this.resetColumnMap()

this.resetAccumulators()

this.height = this.rowMap.length
this.width = this.columnMap.length

Expand Down

0 comments on commit 1d1f3f2

Please sign in to comment.