From 557b6edf4f026ef57c8786b72e060d942ea97d36 Mon Sep 17 00:00:00 2001 From: Brad Decker Date: Wed, 16 Nov 2022 09:17:55 -0500 Subject: [PATCH] persist user traits for comparison (#16506) --- app/scripts/controllers/metametrics.js | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/app/scripts/controllers/metametrics.js b/app/scripts/controllers/metametrics.js index f8bfc527e..022577f2c 100644 --- a/app/scripts/controllers/metametrics.js +++ b/app/scripts/controllers/metametrics.js @@ -76,6 +76,8 @@ const exceptionsToFilter = { * @property {Array} [eventsBeforeMetricsOptIn] - Array of queued events added before * a user opts into metrics. * @property {object} [traits] - Traits that are not derived from other state keys. + * @property {Record} [previousUserTraits] - The user traits the last + * time they were computed. */ export default class MetaMetricsController { @@ -685,7 +687,7 @@ export default class MetaMetricsController { * @returns {MetaMetricsTraits | null} traits that have changed since last update */ _buildUserTraitsObject(metamaskState) { - const { traits } = this.store.getState(); + const { traits, previousUserTraits } = this.store.getState(); /** @type {MetaMetricsTraits} */ const currentTraits = { [TRAITS.ADDRESS_BOOK_ENTRIES]: sum( @@ -722,17 +724,17 @@ export default class MetaMetricsController { [TRAITS.TOKEN_DETECTION_ENABLED]: metamaskState.useTokenDetection, }; - if (!this.previousTraits) { - this.previousTraits = currentTraits; + if (!previousUserTraits) { + this.store.updateState({ previousUserTraits: currentTraits }); return currentTraits; } - if (this.previousTraits && !isEqual(this.previousTraits, currentTraits)) { + if (previousUserTraits && !isEqual(previousUserTraits, currentTraits)) { const updates = pickBy( currentTraits, - (v, k) => !isEqual(this.previousTraits[k], v), + (v, k) => !isEqual(previousUserTraits[k], v), ); - this.previousTraits = currentTraits; + this.store.updateState({ previousUserTraits: currentTraits }); return updates; }