blob: ee4a7c0e290103b6d2005b1cacef8d7c732d921e [file] [log] [blame] [edit]
// 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 ASH_SCANNER_SCANNER_DISCLAIMER_H_
#define ASH_SCANNER_SCANNER_DISCLAIMER_H_
#include "ash/ash_export.h"
class PrefService;
namespace ash {
// The type of Scanner disclaimer that should be shown.
enum class ASH_EXPORT ScannerDisclaimerType {
// No disclaimer should be shown.
kNone,
// The reminder disclaimer should be shown.
kReminder,
// The full non-reminder disclaimer should be shown.
kFull,
};
// The type of entry-point that a user can use to see Scanner.
enum class ASH_EXPORT ScannerEntryPoint {
// The smart actions button from a `BehaviorType::kDefault` capture mode
// session.
kSmartActionsButton,
// The start of a `BehaviorType::kSunfish` capture mode session.
kSunfishSession,
};
// Returns the type of Scanner disclaimer that should be shown for an
// `entry_point` according to the given `PrefService`.
// Does NOT check whether Scanner-related UI can be shown
// (`ScannerController::CanShowUiForShell()`).
ASH_EXPORT ScannerDisclaimerType
GetScannerDisclaimerType(const PrefService& prefs,
ScannerEntryPoint entry_point);
// Sets the Scanner disclaimer for `entry_point` as acknowledged by the user in
// the given `PrefService`.
ASH_EXPORT void SetScannerDisclaimerAcked(PrefService& prefs,
ScannerEntryPoint entry_point);
// Sets all Scanner disclaimers for all entry-points as unacknowledged by the
// user in the given `PrefService` for testing purposes.
ASH_EXPORT void SetAllScannerDisclaimersUnackedForTest(PrefService& prefs);
} // namespace ash
#endif // ASH_SCANNER_SCANNER_DISCLAIMER_H_