Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #ifndef CHROME_BROWSER_CHROMEOS_LOCK_SCREEN_APPS_APP_MANAGER_H_ | |
| 6 #define CHROME_BROWSER_CHROMEOS_LOCK_SCREEN_APPS_APP_MANAGER_H_ | |
| 7 | |
| 8 #include <string> | |
| 9 | |
| 10 class Profile; | |
| 11 | |
| 12 namespace lock_screen_apps { | |
| 13 | |
| 14 // Interface for managing lock screen enabled action handler apps in the lock | |
| 15 // screen enabled profile. Initially, it will be used primarily to manage lock | |
| 16 // screen note taking apps. | |
| 17 class AppManager { | |
| 18 public: | |
| 19 class Observer { | |
| 20 public: | |
| 21 virtual ~Observer() {} | |
| 22 | |
| 23 // Called when note taking availability status changes while the | |
| 24 // |AppManager| is active. | |
| 25 virtual void OnNoteTakingAvailabilityChanged() = 0; | |
| 26 }; | |
| 27 | |
| 28 virtual ~AppManager() {} | |
| 29 | |
| 30 // Initializes the manager. | |
| 31 // |primary_profile| - the profile which is the source of the lock screen | |
| 32 // action handler app (if one is set). This is the profile whose | |
| 33 // settings are used to determine whether and for which app lock screen | |
| 34 // action is enabled. | |
| 35 // |lock_screen_profile| - the profile in which lock screen apps should be | |
| 36 // installed and launched. | |
| 37 virtual void Initialize(Profile* primary_profile, | |
| 38 Profile* lock_screen_profile) = 0; | |
| 39 | |
| 40 // Activates the manager - this should ensure that lock screen enabled note | |
| 41 // taking app, if available, is loaded and enabled in the lock screen profile. | |
| 42 // |observer| - used to notify the user when the note taking app availability | |
| 43 // changes. It's cleared when the |AppManager| is stopped. | |
| 44 virtual void Start(Observer* observer) = 0; | |
|
xiyuan
2017/05/26 22:44:52
Prefer to use a Callback than using an interface p
tbarzic
2017/05/27 00:48:35
Done.
| |
| 45 | |
| 46 // Stops the manager. After this is called, the app can be unloaded from the | |
| 47 // lock screen enabled profile. Subsequent launch requests should not be | |
| 48 // allowed. | |
| 49 virtual void Stop() = 0; | |
| 50 | |
| 51 // If lock screen note taking app is available, launches the app with lock | |
| 52 // screen note taking action. | |
| 53 // Returns whether the app launch was attempted. | |
| 54 virtual bool LaunchNoteTaking() = 0; | |
| 55 | |
| 56 // Returns whether a lock screen note taking is enabled and ready to launch. | |
| 57 virtual bool IsNoteTakingAppAvailable() const = 0; | |
| 58 | |
| 59 // Returns the lock screen enabled lock screen note taking app, if a note | |
| 60 // taking app is enabled on lock screen (for primary profile). | |
| 61 virtual std::string GetNoteTakingAppId() const = 0; | |
| 62 }; | |
| 63 | |
| 64 } // namespace lock_screen_apps | |
| 65 | |
| 66 #endif // CHROME_BROWSER_CHROMEOS_LOCK_SCREEN_APPS_APP_MANAGER_H_ | |
| OLD | NEW |