Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(266)

Side by Side Diff: chrome/browser/ui/ash/chrome_launcher_prefs.h

Issue 2684853002: Discard pinning an app with non-empty launcher id. (Closed)
Patch Set: Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_UI_ASH_CHROME_LAUNCHER_PREFS_H_ 5 #ifndef CHROME_BROWSER_UI_ASH_CHROME_LAUNCHER_PREFS_H_
6 #define CHROME_BROWSER_UI_ASH_CHROME_LAUNCHER_PREFS_H_ 6 #define CHROME_BROWSER_UI_ASH_CHROME_LAUNCHER_PREFS_H_
7 7
8 #include <memory> 8 #include <memory>
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
11 11
12 #include "ash/public/cpp/shelf_types.h" 12 #include "ash/public/cpp/shelf_types.h"
13 #include "base/macros.h" 13 #include "base/macros.h"
14 #include "components/sync_preferences/pref_service_syncable_observer.h" 14 #include "components/sync_preferences/pref_service_syncable_observer.h"
15 15
16 class LauncherControllerHelper; 16 class LauncherControllerHelper;
17 class PrefService; 17 class PrefService;
18 class Profile; 18 class Profile;
19 19
20 namespace base {
21 class DictionaryValue;
22 }
23
24 namespace sync_preferences { 20 namespace sync_preferences {
25 class PrefServiceSyncable; 21 class PrefServiceSyncable;
26 } 22 }
27 23
28 namespace user_prefs { 24 namespace user_prefs {
29 class PrefRegistrySyncable; 25 class PrefRegistrySyncable;
30 } 26 }
31 27
32 namespace ash { 28 namespace ash {
33 namespace launcher { 29 namespace launcher {
(...skipping 10 matching lines...) Expand all
44 40
45 // Values used for prefs::kShelfAutoHideBehavior. 41 // Values used for prefs::kShelfAutoHideBehavior.
46 extern const char kShelfAutoHideBehaviorAlways[]; 42 extern const char kShelfAutoHideBehaviorAlways[];
47 extern const char kShelfAutoHideBehaviorNever[]; 43 extern const char kShelfAutoHideBehaviorNever[];
48 44
49 // Values used for prefs::kShelfAlignment. 45 // Values used for prefs::kShelfAlignment.
50 extern const char kShelfAlignmentBottom[]; 46 extern const char kShelfAlignmentBottom[];
51 extern const char kShelfAlignmentLeft[]; 47 extern const char kShelfAlignmentLeft[];
52 extern const char kShelfAlignmentRight[]; 48 extern const char kShelfAlignmentRight[];
53 49
54 // A unique chrome launcher id used to identify a shelf item. This class is a
55 // wrapper for the chrome launcher identifier. |app_launcher_id_| includes the
56 // |app_id| and the |launch_id|. The |app_id| is the application id associated
57 // with a set of windows. The |launch_id| is an id that can be passed to an app
58 // when launched in order to support multiple shelf items per app. This id is
59 // used together with the |app_id| to uniquely identify each shelf item that
60 // has the same |app_id|. The |app_id| must not be empty.
61 class AppLauncherId {
62 public:
63 AppLauncherId(const std::string& app_id, const std::string& launch_id);
64 // Creates an AppLauncherId with an empty |launch_id|.
65 explicit AppLauncherId(const std::string& app_id);
66 // Empty constructor for pre-allocating.
67 AppLauncherId();
68 ~AppLauncherId();
69
70 AppLauncherId(const AppLauncherId& app_launcher_id) = default;
71 AppLauncherId(AppLauncherId&& app_launcher_id) = default;
72 AppLauncherId& operator=(const AppLauncherId& other) = default;
73
74 std::string ToString() const;
75 const std::string& app_id() const { return app_id_; }
76 const std::string& launch_id() const { return launch_id_; }
77
78 bool operator<(const AppLauncherId& other) const;
79
80 private:
81 // The application id associated with a set of windows.
82 std::string app_id_;
83 // An id that can be passed to an app when launched in order to support
84 // multiple shelf items per app.
85 std::string launch_id_;
86 };
87
88 void RegisterChromeLauncherUserPrefs( 50 void RegisterChromeLauncherUserPrefs(
89 user_prefs::PrefRegistrySyncable* registry); 51 user_prefs::PrefRegistrySyncable* registry);
90 52
91 std::unique_ptr<base::DictionaryValue> CreateAppDict(
khmel 2017/02/08 16:43:43 This is actually helper that can be moved to names
92 const AppLauncherId& app_launcher_id);
93
94 // Get or set the shelf auto hide behavior preference for a particular display. 53 // Get or set the shelf auto hide behavior preference for a particular display.
95 ShelfAutoHideBehavior GetShelfAutoHideBehaviorPref(PrefService* prefs, 54 ShelfAutoHideBehavior GetShelfAutoHideBehaviorPref(PrefService* prefs,
96 int64_t display_id); 55 int64_t display_id);
97 void SetShelfAutoHideBehaviorPref(PrefService* prefs, 56 void SetShelfAutoHideBehaviorPref(PrefService* prefs,
98 int64_t display_id, 57 int64_t display_id,
99 ShelfAutoHideBehavior behavior); 58 ShelfAutoHideBehavior behavior);
100 59
101 // Get or set the shelf alignment preference for a particular display. 60 // Get or set the shelf alignment preference for a particular display.
102 ShelfAlignment GetShelfAlignmentPref(PrefService* prefs, int64_t display_id); 61 ShelfAlignment GetShelfAlignmentPref(PrefService* prefs, int64_t display_id);
103 void SetShelfAlignmentPref(PrefService* prefs, 62 void SetShelfAlignmentPref(PrefService* prefs,
104 int64_t display_id, 63 int64_t display_id,
105 ShelfAlignment alignment); 64 ShelfAlignment alignment);
106 65
107 // Get the list of pinned apps from preferences. 66 // Get the list of pinned apps from preferences.
108 std::vector<AppLauncherId> GetPinnedAppsFromPrefs( 67 std::vector<std::string> GetPinnedAppsFromPrefs(
109 const PrefService* prefs, 68 const PrefService* prefs,
110 LauncherControllerHelper* helper); 69 LauncherControllerHelper* helper);
111 70
112 // Removes information about pin position from sync model for the app. 71 // Removes information about pin position from sync model for the app.
113 void RemovePinPosition(Profile* profile, const AppLauncherId& app_launcher_id); 72 void RemovePinPosition(Profile* profile, const std::string& app_id);
114 73
115 // Updates information about pin position in sync model for the app 74 // Updates information about pin position in sync model for the app |app_id|.
116 // |app_launcher_id|. |app_launcher_id_before| optionally specifies an app that 75 // |app_id_before| optionally specifies an app that exists right before the
117 // exists right before the target app. |app_launcher_ids_after| optionally 76 // target app. |app_ids_after| optionally specifies sorted by position apps that
118 // specifies sorted by position apps that exist right after the target app. 77 // exist right after the target app.
119 void SetPinPosition(Profile* profile, 78 void SetPinPosition(Profile* profile,
120 const AppLauncherId& app_launcher_id, 79 const std::string& app_id,
121 const AppLauncherId& app_launcher_id_before, 80 const std::string& app_id_before,
122 const std::vector<AppLauncherId>& app_launcher_ids_after); 81 const std::vector<std::string>& app_ids_after);
123 82
124 // Used to propagate remote preferences to local during the first run. 83 // Used to propagate remote preferences to local during the first run.
125 class ChromeLauncherPrefsObserver 84 class ChromeLauncherPrefsObserver
126 : public sync_preferences::PrefServiceSyncableObserver { 85 : public sync_preferences::PrefServiceSyncableObserver {
127 public: 86 public:
128 // Creates and returns an instance of ChromeLauncherPrefsObserver if the 87 // Creates and returns an instance of ChromeLauncherPrefsObserver if the
129 // profile prefs do not contain all the necessary local settings for the 88 // profile prefs do not contain all the necessary local settings for the
130 // shelf. If the local settings are present, returns null. 89 // shelf. If the local settings are present, returns null.
131 static std::unique_ptr<ChromeLauncherPrefsObserver> CreateIfNecessary( 90 static std::unique_ptr<ChromeLauncherPrefsObserver> CreateIfNecessary(
132 Profile* profile); 91 Profile* profile);
(...skipping 10 matching lines...) Expand all
143 // Profile prefs. Not owned. 102 // Profile prefs. Not owned.
144 sync_preferences::PrefServiceSyncable* prefs_; 103 sync_preferences::PrefServiceSyncable* prefs_;
145 104
146 DISALLOW_COPY_AND_ASSIGN(ChromeLauncherPrefsObserver); 105 DISALLOW_COPY_AND_ASSIGN(ChromeLauncherPrefsObserver);
147 }; 106 };
148 107
149 } // namespace launcher 108 } // namespace launcher
150 } // namespace ash 109 } // namespace ash
151 110
152 #endif // CHROME_BROWSER_UI_ASH_CHROME_LAUNCHER_PREFS_H_ 111 #endif // CHROME_BROWSER_UI_ASH_CHROME_LAUNCHER_PREFS_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698