diff --git a/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricEditPopover/AdhocMetricEditPopover.test.tsx b/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricEditPopover/AdhocMetricEditPopover.test.tsx index 3614e7222ce2b..78add7781469f 100644 --- a/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricEditPopover/AdhocMetricEditPopover.test.tsx +++ b/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricEditPopover/AdhocMetricEditPopover.test.tsx @@ -162,6 +162,16 @@ test('Clicking on "Save" should call onChange and onClose for new metric', () => expect(props.onClose).toBeCalledTimes(1); }); +test('Clicking on "Save" should call onChange and onClose for new title', () => { + const props = createProps(); + render(); + expect(props.onChange).toBeCalledTimes(0); + expect(props.onClose).toBeCalledTimes(0); + userEvent.click(screen.getByRole('button', { name: 'Save' })); + expect(props.onChange).toBeCalledTimes(1); + expect(props.onClose).toBeCalledTimes(1); +}); + test('Should switch to tab:Simple', () => { const props = createProps(); props.getCurrentTab.mockImplementation(tab => { diff --git a/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricEditPopover/index.jsx b/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricEditPopover/index.jsx index c824d1e929790..9ed817f283955 100644 --- a/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricEditPopover/index.jsx +++ b/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricEditPopover/index.jsx @@ -62,6 +62,7 @@ const propTypes = { savedMetric: savedMetricType, datasource: PropTypes.object, isNewMetric: PropTypes.bool, + isLabelModified: PropTypes.bool, }; const defaultProps = { @@ -299,6 +300,7 @@ export default class AdhocMetricEditPopover extends React.PureComponent { onResize, datasource, isNewMetric, + isLabelModified, ...popoverProps } = this.props; const { adhocMetric, savedMetric } = this.state; @@ -345,6 +347,7 @@ export default class AdhocMetricEditPopover extends React.PureComponent { const stateIsValid = adhocMetric.isValid() || savedMetric?.metric_name; const hasUnsavedChanges = + isLabelModified || isNewMetric || !adhocMetric.equals(propsAdhocMetric) || (!( diff --git a/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricPopoverTrigger.tsx b/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricPopoverTrigger.tsx index c593cc2ee878c..f423c2651a3e4 100644 --- a/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricPopoverTrigger.tsx +++ b/superset-frontend/src/explore/components/controls/MetricControl/AdhocMetricPopoverTrigger.tsx @@ -225,6 +225,10 @@ class AdhocMetricPopoverTrigger extends React.PureComponent< getCurrentTab={this.getCurrentTab} getCurrentLabel={this.getCurrentLabel} isNewMetric={this.props.isNew} + isLabelModified={ + this.state.labelModified && + adhocMetricLabel !== this.state.title.label + } /> );