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

Side by Side Diff: chrome/browser/ui/ash/launcher/extension_app_window_launcher_controller.h

Issue 1914993002: Enhance chrome.app.window API with better shelf integration (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase + Fixes v10 Created 4 years, 5 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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_LAUNCHER_EXTENSION_APP_WINDOW_LAUNCHER_CONTROLLER_ H_ 5 #ifndef CHROME_BROWSER_UI_ASH_LAUNCHER_EXTENSION_APP_WINDOW_LAUNCHER_CONTROLLER_ H_
6 #define CHROME_BROWSER_UI_ASH_LAUNCHER_EXTENSION_APP_WINDOW_LAUNCHER_CONTROLLER_ H_ 6 #define CHROME_BROWSER_UI_ASH_LAUNCHER_EXTENSION_APP_WINDOW_LAUNCHER_CONTROLLER_ H_
7 7
8 #include <list> 8 #include <list>
9 #include <map> 9 #include <map>
10 #include <string> 10 #include <string>
11 11
12 #include "ash/shelf/shelf_util.h"
12 #include "base/macros.h" 13 #include "base/macros.h"
13 #include "chrome/browser/ui/ash/launcher/app_window_launcher_controller.h" 14 #include "chrome/browser/ui/ash/launcher/app_window_launcher_controller.h"
14 #include "extensions/browser/app_window/app_window_registry.h" 15 #include "extensions/browser/app_window/app_window_registry.h"
15 #include "ui/aura/window_observer.h" 16 #include "ui/aura/window_observer.h"
16 17
17 namespace aura { 18 namespace aura {
18 19
19 class Window; 20 class Window;
20 } 21 }
21 22
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 // Unregisters a app window with the shelf and this object. 61 // Unregisters a app window with the shelf and this object.
61 void UnregisterApp(aura::Window* window); 62 void UnregisterApp(aura::Window* window);
62 63
63 // Check if a given window is known to the launcher controller. 64 // Check if a given window is known to the launcher controller.
64 bool IsRegisteredApp(aura::Window* window); 65 bool IsRegisteredApp(aura::Window* window);
65 66
66 private: 67 private:
67 using AppControllerMap = 68 using AppControllerMap =
68 std::map<std::string, ExtensionAppWindowLauncherItemController*>; 69 std::map<std::string, ExtensionAppWindowLauncherItemController*>;
69 using WindowToAppShelfIdMap = std::map<aura::Window*, std::string>; 70 using WindowToAppShelfIdMap = std::map<aura::Window*, std::string>;
71 using AppShelfIdToShelfIdMap = std::map<std::string, ash::ShelfID>;
70 72
71 // A set of unowned AppWindowRegistry pointers for loaded users. 73 // A set of unowned AppWindowRegistry pointers for loaded users.
72 // Note that this will only be used with multiple users in the side by side 74 // Note that this will only be used with multiple users in the side by side
73 // mode. 75 // mode.
74 std::set<extensions::AppWindowRegistry*> registry_; 76 std::set<extensions::AppWindowRegistry*> registry_;
75 77
76 // Map of app launcher id to controller. 78 // Map of app launcher id to controller.
77 AppControllerMap app_controller_map_; 79 AppControllerMap app_controller_map_;
78 80
79 // Allows us to get from an aura::Window to the app shelf id. 81 // Allows us to get from an aura::Window to the app shelf id.
80 WindowToAppShelfIdMap window_to_app_shelf_id_map_; 82 WindowToAppShelfIdMap window_to_app_shelf_id_map_;
81 83
84 // Map of app shelf id to shelf id.
85 AppShelfIdToShelfIdMap app_shelf_id_to_shelf_id_map_;
86
82 DISALLOW_COPY_AND_ASSIGN(ExtensionAppWindowLauncherController); 87 DISALLOW_COPY_AND_ASSIGN(ExtensionAppWindowLauncherController);
83 }; 88 };
84 89
85 #endif // CHROME_BROWSER_UI_ASH_LAUNCHER_EXTENSION_APP_WINDOW_LAUNCHER_CONTROLL ER_H_ 90 #endif // CHROME_BROWSER_UI_ASH_LAUNCHER_EXTENSION_APP_WINDOW_LAUNCHER_CONTROLL ER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698