| // Copyright 2023 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_USER_EDUCATION_USER_EDUCATION_TUTORIAL_CONTROLLER_H_ |
| #define ASH_USER_EDUCATION_USER_EDUCATION_TUTORIAL_CONTROLLER_H_ |
| |
| #include <optional> |
| |
| #include "ash/ash_export.h" |
| #include "base/functional/callback_forward.h" |
| #include "base/memory/raw_ptr.h" |
| |
| namespace ui { |
| class ElementContext; |
| } // namespace ui |
| |
| namespace user_education { |
| struct TutorialDescription; |
| } // namespace user_education |
| |
| namespace ash { |
| |
| class UserEducationDelegate; |
| class UserEducationPrivateApiKey; |
| enum class TutorialId; |
| |
| // The singleton controller, owned by the `UserEducationController`, responsible |
| // for creation/management of tutorials. |
| class ASH_EXPORT UserEducationTutorialController { |
| public: |
| explicit UserEducationTutorialController(UserEducationDelegate* delegate); |
| UserEducationTutorialController(const UserEducationTutorialController&) = |
| delete; |
| UserEducationTutorialController& operator=( |
| const UserEducationTutorialController&) = delete; |
| ~UserEducationTutorialController(); |
| |
| // Returns the singleton instance owned by the `UserEducationController`. |
| // NOTE: Exists if and only if user education features are enabled. |
| static UserEducationTutorialController* Get(); |
| |
| // Returns whether a tutorial is registered for the specified `tutorial_id`. |
| // NOTE: Currently only the primary user profile is supported. |
| bool IsTutorialRegistered(TutorialId tutorial_id) const; |
| |
| // Registers the tutorial with the specified `tutorial_id`. |
| // NOTE: Currently only the primary user profile is supported. |
| void RegisterTutorial( |
| UserEducationPrivateApiKey, |
| TutorialId tutorial_id, |
| user_education::TutorialDescription tutorial_description); |
| |
| // Starts the tutorial previously registered with the specified `tutorial_id`. |
| // Any running tutorial is cancelled. One of either `completed_callback` or |
| // `aborted_callback` will be run on tutorial finish. |
| // NOTE: Currently only the primary user profile is supported. |
| void StartTutorial(UserEducationPrivateApiKey, |
| TutorialId tutorial_id, |
| ui::ElementContext element_context, |
| base::OnceClosure completed_callback, |
| base::OnceClosure aborted_callback); |
| |
| // Aborts the currently running tutorial. If `tutorial_id` is given, will only |
| // abort the tutorial if it matches the id. If no `tutorial_id` is given, it |
| // aborts any running tutorial whether it was started by this controller or |
| // not. Any `aborted_callback` passed in at the time of start will be called. |
| // NOTE: Currently only the primary user profile is supported. |
| void AbortTutorial(UserEducationPrivateApiKey, |
| std::optional<TutorialId> tutorial_id = std::nullopt); |
| |
| private: |
| // The delegate owned by the `UserEducationController` which facilitates |
| // communication between Ash and user education services in the browser. |
| const raw_ptr<UserEducationDelegate> delegate_; |
| }; |
| |
| } // namespace ash |
| |
| #endif // ASH_USER_EDUCATION_USER_EDUCATION_TUTORIAL_CONTROLLER_H_ |