1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
// Copyright 2025 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_AUTOFILL_IOS_BROWSER_CREDIT_CARD_SAVE_METRICS_IOS_H_
#define COMPONENTS_AUTOFILL_IOS_BROWSER_CREDIT_CARD_SAVE_METRICS_IOS_H_
#import <stddef.h>
#import <string>
#import <string_view>
#import "components/autofill/core/browser/payments/payments_autofill_client.h"
namespace autofill::autofill_metrics {
// Metrics to track events when a credit card dialog (banner, modal or
// bottomsheet) is offered on iOS. These values are persisted to logs. Entries
// should not be renumbered and numeric values should never be reused.
// LINT.IfChange(SaveCreditCardPromptResultIOS)
enum class SaveCreditCardPromptResultIOS {
// Dialog shown to user.
kShown = 0,
// Dialog accepted.
kAccepted = 1,
// User explicitly denied the modal by tapping the `Close` button or the
// bottomsheet by tapping the `No thanks` button.
kDenied = 2,
// Banner swiped away.
kSwiped = 3,
// Banner timed out.
KTimedOut = 4,
// User clicked a link on the modal or the bottomsheet, which caused the
// dialog to close.
kLinkClicked = 5,
// User did not interact with the modal.
kIgnored = 6,
// Dialog not shown to user.
kNotShown = 7,
kMaxValue = kNotShown,
};
// LINT.ThenChange(//tools/metrics/histograms/metadata/autofill/enums.xml:SaveCreditCardPromptResultIOS)
// Enum describing the types of overlays displayed for saving a card on iOS.
enum class SaveCreditCardPromptOverlayType {
kBanner,
kBottomSheet,
kModal,
};
// Logs events that happen when the prompt to save a credit card (locally or to
// the server) is shown and user's subsequent action for that prompt. The logged
// histogram also records the number of strikes (i.e number of times the card
// has previously been rejected to be saved) and whether a fix flow was required
// due to missing information (e.g., cardholder name or expiration date).
void LogSaveCreditCardPromptResultIOS(
SaveCreditCardPromptResultIOS metric,
bool is_uploading,
const payments::PaymentsAutofillClient::SaveCreditCardOptions& options,
SaveCreditCardPromptOverlayType overlay_type);
} // namespace autofill::autofill_metrics
#endif // COMPONENTS_AUTOFILL_IOS_BROWSER_CREDIT_CARD_SAVE_METRICS_IOS_H_
|