From e86fc71711be68537071d7aa4e8d60bd62a347fb Mon Sep 17 00:00:00 2001 From: Maurizio Casimirri Date: Mon, 13 Nov 2023 11:04:58 +0100 Subject: [PATCH] fix(stage-wizard): remove field selector from $count (#5097) * fix(stage-wizard): remove field selector from $count * clean up value when count is selected * test description --- .../group/group-with-statistics.spec.tsx | 28 +++++++++++++ .../group/group-with-statistics.tsx | 39 +++++++++++++------ 2 files changed, 55 insertions(+), 12 deletions(-) diff --git a/packages/compass-aggregations/src/components/aggregation-side-panel/stage-wizard-use-cases/group/group-with-statistics.spec.tsx b/packages/compass-aggregations/src/components/aggregation-side-panel/stage-wizard-use-cases/group/group-with-statistics.spec.tsx index 8a9150ebf50..1a06d8e9b82 100644 --- a/packages/compass-aggregations/src/components/aggregation-side-panel/stage-wizard-use-cases/group/group-with-statistics.spec.tsx +++ b/packages/compass-aggregations/src/components/aggregation-side-panel/stage-wizard-use-cases/group/group-with-statistics.spec.tsx @@ -150,5 +150,33 @@ describe('group with statistics', function () { expect(onChange.lastCall.args[1]).to.be.null; }); }); + + context('$count', function () { + it('adds a "count" field with the $count accumulator to the generated stage', function () { + setSelectValue(/select accumulator/i, 'count'); + expect(onChange.lastCall.args[0]).to.equal( + JSON.stringify({ + _id: null, + count: { $count: {} }, + }) + ); + }); + + it('clears the field selection', function () { + setSelectValue(/select accumulator/i, 'sum'); + setComboboxValue(new RegExp(SINGLE_SELECT_LABEL, 'i'), 'orders'); + setSelectValue(/select accumulator/i, 'count'); + + // re-select sum, we expect the field to be gone, and the new accumulator to + // be invalid (not present in the result) + setSelectValue(/select accumulator/i, 'sum'); + + expect(onChange.lastCall.args[0]).to.equal( + JSON.stringify({ + _id: null, + }) + ); + }); + }); }); }); diff --git a/packages/compass-aggregations/src/components/aggregation-side-panel/stage-wizard-use-cases/group/group-with-statistics.tsx b/packages/compass-aggregations/src/components/aggregation-side-panel/stage-wizard-use-cases/group/group-with-statistics.tsx index e14c34f0a60..3492bb64635 100644 --- a/packages/compass-aggregations/src/components/aggregation-side-panel/stage-wizard-use-cases/group/group-with-statistics.tsx +++ b/packages/compass-aggregations/src/components/aggregation-side-panel/stage-wizard-use-cases/group/group-with-statistics.tsx @@ -90,6 +90,10 @@ type GroupWithStatisticsFormData = { const _getGroupAccumulatorKey = ({ field, accumulator }: GroupAccumulators) => { // we will always prepend an accumulator to the key as user // can choose to calculate values of the same field in a document. + if (accumulator === '$count') { + return 'count'; + } + const prefix = accumulator.replace(/\$/g, ''); const propertyName = mapFieldToPropertyName(field); const underscore = propertyName.startsWith('_') ? '' : '_'; @@ -110,7 +114,7 @@ const mapGroupFormStateToStageValue = ( ): Document => { const values = Object.fromEntries( data.groupAccumulators - .filter((x) => x.accumulator && x.field) + .filter((x) => x.accumulator && (x.accumulator === '$count' || x.field)) .map((x) => [_getGroupAccumulatorKey(x), _getGroupAccumulatorValue(x)]) ); return { @@ -138,8 +142,13 @@ const GroupAccumulatorForm = ({ if (!value) { return; } + const newData = [...data]; newData[index][key] = value; + if (key === 'accumulator' && value === '$count') { + newData[index].field = ''; + } + onChange(newData); }; @@ -203,15 +212,19 @@ const GroupAccumulatorForm = ({ ); })} - of - - onChangeGroup(index, 'field', value) - } - fields={fields} - /> + {item.accumulator !== '$count' && ( + <> + of + + onChangeGroup(index, 'field', value) + } + fields={fields} + /> + + )} ); }} @@ -247,8 +260,10 @@ export const GroupWithStatistics = ({ setFormData(newData); const isValuesEmpty = - newData.groupAccumulators.filter((x) => x.accumulator && x.field) - .length === 0; + newData.groupAccumulators.filter( + (x) => x.accumulator && (x.accumulator === '$count' || x.field) + ).length === 0; + onChange( JSON.stringify(mapGroupFormStateToStageValue(newData)), isValuesEmpty ? new Error('Select one group accumulator') : null