From c7573663557b0db778a2907eaf2fd1918ced4914 Mon Sep 17 00:00:00 2001 From: Dan J Miller Date: Tue, 5 Mar 2019 12:15:01 -0330 Subject: Metametrics (#6171) * Add metametrics provider and util. * Add backend api and state for participating in metametrics. * Add frontend action for participating in metametrics. * Add metametrics opt-in screen. * Add metametrics events to first time flow. * Add metametrics events for route changes * Add metametrics events for send and confirm screens * Add metametrics events to dropdowns, transactions, log in and out, settings, sig requests and main screen * Ensures each log in is measured as a new visit by metametrics. * Ensure metametrics is called with an empty string for dimensions params if specified * Adds opt in metametrics modal after unlock for existing users * Adds settings page toggle for opting in and out of MetaMetrics * Switch metametrics dimensions to page level scope * Lint, test and translation fixes for metametrics. * Update design for metametrics opt-in screen * Complete responsive styling of metametrics-opt-in modal * Use new chart image on metrics opt in screens * Incorporate the metametrics opt-in screen into the new onboarding flow * Update e2e tests to accomodate metametrics changes * Mock out metametrics network requests in integration tests * Fix tx-list integration test to support metametrics provider. * Send number of tokens and accounts data with every metametrics event. * Update metametrics event descriptor schema and add new events. * Fix import tos bug and send gas button bug due to metametrics changes. * Various small fixes on the metametrics branch. * Add origin custom variable type to metametrics.util * Fix names of onboarding complete actions (metametrics). * Fix names of Metrics Options actions (metametrics). * Clean up code related to metametrics. * Fix bad merge conflict resolution and improve promise handling in sendMetaMetrics event and confrim tx base * Don't send a second metrics event if user has gone back during first time flow. * Collect metametrics on going back from onboarding create/import. * Add missing custom variable constants for metametrics * Fix metametrics provider * Make height of opt-in modal responsive. * Adjust text content for opt-in modal. * Update metametrics event names and clean up code in opt-in-modal * Put phishing warning step next to last in onboarding flow * Link terms of service on create and import screens of first time flow * Add subtext to options on the onboarding select action screen. * Fix styling of bullet points on end of onboarding screen. * Combine phishing warning and congratulations screens. * Fix placement of users if unlocking after an incomplete onboarding import flow. * Fix capitalization in opt-in screen * Fix last onboarding screen translations * Add link to 'Learn More' on the last screen of onboarding * Code clean up: metametrics branch * Update e2e tests for phishing warning step removal * e2e tests passing on metametrics branch * Different tracking urls for metametrics on development and prod --- .../create-password/create-password.component.js | 17 +-- .../import-with-seed-phrase.component.js | 37 ++++- .../new-account/new-account.component.js | 39 ++++- .../unique-image/unique-image.component.js | 19 ++- .../end-of-flow/end-of-flow.component.js | 37 ++++- .../end-of-flow/end-of-flow.container.js | 16 +- .../pages/first-time-flow/end-of-flow/index.scss | 14 +- .../first-time-flow-switch.component.js | 9 +- .../first-time-flow-switch.container.js | 2 + .../first-time-flow/first-time-flow.component.js | 12 +- .../first-time-flow/first-time-flow.container.js | 2 + .../first-time-flow/first-time-flow.selectors.js | 26 ++++ ui/app/components/pages/first-time-flow/index.scss | 7 + .../first-time-flow/metametrics-opt-in/index.js | 1 + .../first-time-flow/metametrics-opt-in/index.scss | 136 +++++++++++++++++ .../metametrics-opt-in.component.js | 169 +++++++++++++++++++++ .../metametrics-opt-in.container.js | 27 ++++ .../confirm-seed-phrase.component.js | 13 +- .../reveal-seed-phrase.component.js | 20 ++- .../pages/first-time-flow/select-action/index.js | 2 +- .../pages/first-time-flow/select-action/index.scss | 3 +- .../select-action/select-action.component.js | 22 ++- .../select-action/select-action.container.js | 23 +++ .../first-time-flow/welcome/welcome.component.js | 12 +- .../first-time-flow/welcome/welcome.container.js | 3 +- 25 files changed, 609 insertions(+), 59 deletions(-) create mode 100644 ui/app/components/pages/first-time-flow/first-time-flow.selectors.js create mode 100644 ui/app/components/pages/first-time-flow/metametrics-opt-in/index.js create mode 100644 ui/app/components/pages/first-time-flow/metametrics-opt-in/index.scss create mode 100644 ui/app/components/pages/first-time-flow/metametrics-opt-in/metametrics-opt-in.component.js create mode 100644 ui/app/components/pages/first-time-flow/metametrics-opt-in/metametrics-opt-in.container.js (limited to 'ui/app/components/pages/first-time-flow') diff --git a/ui/app/components/pages/first-time-flow/create-password/create-password.component.js b/ui/app/components/pages/first-time-flow/create-password/create-password.component.js index 7cca82ca6..3faaa3764 100644 --- a/ui/app/components/pages/first-time-flow/create-password/create-password.component.js +++ b/ui/app/components/pages/first-time-flow/create-password/create-password.component.js @@ -3,18 +3,16 @@ import PropTypes from 'prop-types' import { Switch, Route } from 'react-router-dom' import NewAccount from './new-account' import ImportWithSeedPhrase from './import-with-seed-phrase' -import UniqueImage from './unique-image' import { INITIALIZE_CREATE_PASSWORD_ROUTE, INITIALIZE_IMPORT_WITH_SEED_PHRASE_ROUTE, - INITIALIZE_UNIQUE_IMAGE_ROUTE, + INITIALIZE_END_OF_FLOW_ROUTE, } from '../../../../routes' export default class CreatePassword extends PureComponent { static propTypes = { history: PropTypes.object, isInitialized: PropTypes.bool, - isImportedKeyring: PropTypes.bool, onCreateNewAccount: PropTypes.func, onCreateNewAccountFromSeed: PropTypes.func, } @@ -23,12 +21,12 @@ export default class CreatePassword extends PureComponent { const { isInitialized, history } = this.props if (isInitialized) { - history.push(INITIALIZE_UNIQUE_IMAGE_ROUTE) + history.push(INITIALIZE_END_OF_FLOW_ROUTE) } } render () { - const { onCreateNewAccount, onCreateNewAccountFromSeed, isImportedKeyring } = this.props + const { onCreateNewAccount, onCreateNewAccountFromSeed } = this.props return (
@@ -46,15 +44,6 @@ export default class CreatePassword extends PureComponent { />
- ( - - )} - /> { + this.context.metricsEvent({ + eventOpts: { + category: 'Onboarding', + action: 'Import Seed Phrase', + name: 'Check ToS', + }, + }) + this.setState((prevState) => ({ termsChecked: !prevState.termsChecked, })) @@ -150,6 +166,13 @@ export default class ImportWithSeedPhrase extends PureComponent { { e.preventDefault() + this.context.metricsEvent({ + eventOpts: { + category: 'Onboarding', + action: 'Import Seed Phrase', + name: 'Go Back from Onboarding Import', + }, + }) this.props.history.push(INITIALIZE_SELECT_ACTION_ROUTE) }} href="#" @@ -208,7 +231,15 @@ export default class ImportWithSeedPhrase extends PureComponent { {termsChecked ? : null} - { t('agreeTermsOfService') } + I have read and agree to the + + { 'Terms of Use' } + +