Chromium Code Reviews| Index: ui/app_list/views/contents_view.h |
| diff --git a/ui/app_list/views/contents_view.h b/ui/app_list/views/contents_view.h |
| index e7df7bc0ccbf4b75207aaa04856e5a12c7561ebb..c85f0ef57c4ae4dae1b8943af5e9758d65d3a311 100644 |
| --- a/ui/app_list/views/contents_view.h |
| +++ b/ui/app_list/views/contents_view.h |
| @@ -5,6 +5,8 @@ |
| #ifndef UI_APP_LIST_VIEWS_CONTENTS_VIEW_H_ |
| #define UI_APP_LIST_VIEWS_CONTENTS_VIEW_H_ |
| +#include <map> |
| + |
| #include "base/basictypes.h" |
| #include "base/compiler_specific.h" |
| #include "base/memory/scoped_ptr.h" |
| @@ -33,13 +35,16 @@ class PaginationModel; |
| class SearchResultListView; |
| class StartPageView; |
| -// A view to manage sub views under the search box (apps grid view + page |
| -// switcher and search results). The two sets of sub views are mutually |
| -// exclusive. ContentsView manages a show state to choose one set to show |
| -// and animates the transition between show states. |
| +// A view to manage launcher pages within the Launcher (eg. start page, apps |
| +// grid view, search results). There can be any number of launcher pages, only |
| +// one of which can be active at a given time. ContentsView provides the user |
| +// interface for switching between launcher pages, and animates the transition |
| +// between them. |
| class APP_LIST_EXPORT ContentsView : public views::View { |
| public: |
| - enum ShowState { |
| + // Values of this enum denote special launcher pages that require hard-coding. |
| + // Launcher pages are not required to have a NamedPage enum value. |
| + enum NamedPage { |
| SHOW_APPS, |
|
benwells
2014/06/06 06:12:29
Nit: should be NAMED_PAGE_APPS, etc.
Matt Giuca
2014/06/10 04:01:19
Done.
benwells
2014/06/10 08:06:42
There seems to be a new style for enums; as your e
Matt Giuca
2014/06/10 08:45:08
OK, renamed again.
|
| SHOW_SEARCH_RESULTS, |
| SHOW_START_PAGE, |
| @@ -61,16 +66,23 @@ class APP_LIST_EXPORT ContentsView : public views::View { |
| void ShowSearchResults(bool show); |
| void ShowFolderContent(AppListFolderItem* folder); |
| - // Sets show state and animates the subviews to match the show state. |
| - void SetShowState(ShowState show_state); |
| + // Sets the active launcher page and animates the pages into place. |
| + void SetActivePage(int page_index); |
| + |
| + // The index of the currently active launcher page. |
| + int active_page() const { return active_page_; } |
|
benwells
2014/06/06 06:12:29
Nit: active_page -> active_page_index
Matt Giuca
2014/06/10 04:01:19
Done.
|
| + |
| + // True if |named_page| is the current active laucher page. |
| + bool IsNamedPageActive(NamedPage named_page) const; |
| + |
| + // Gets the index of a launcher page in |view_model_|, by NamedPage. |
| + int GetPageIndexForNamedPage(NamedPage named_page) const; |
| void Prerender(); |
| AppsContainerView* apps_container_view() { return apps_container_view_; } |
| StartPageView* start_page_view() { return start_page_view_; } |
| - ShowState show_state() const { return show_state_; } |
| - |
| // Overridden from views::View: |
| virtual gfx::Size GetPreferredSize() const OVERRIDE; |
| virtual void Layout() OVERRIDE; |
| @@ -78,12 +90,20 @@ class APP_LIST_EXPORT ContentsView : public views::View { |
| virtual bool OnMouseWheel(const ui::MouseWheelEvent& event) OVERRIDE; |
| private: |
| - // Invoked when show state is changed. |
| - void ShowStateChanged(); |
| + // Invoked when active view is changed. |
| + void ActivePageChanged(); |
| void CalculateIdealBounds(); |
| void AnimateToIdealBounds(); |
| + // Adds |view| as a child of the ContentsView. Also adds it to the view model, |
| + // having no named page associated with it. |
| + void AddLauncherPage(views::View* view); |
|
benwells
2014/06/06 06:12:29
Should these mention that it is added next in the
Matt Giuca
2014/06/10 04:01:19
Not sure what you mean -- the buttons along the bo
benwells
2014/06/10 08:06:42
I mean there is an ordering to the pages, and when
Matt Giuca
2014/06/10 08:45:08
Done.
|
| + |
| + // Adds |view| as a child of the ContentsView. Also adds it to the view model, |
| + // associating it with |named_page|. |
| + void AddLauncherPage(views::View* view, NamedPage named_page); |
| + |
| // Gets the PaginationModel owned by the AppsGridView. |
| PaginationModel* GetAppsPaginationModel(); |
| @@ -91,7 +111,8 @@ class APP_LIST_EXPORT ContentsView : public views::View { |
| virtual void OnGestureEvent(ui::GestureEvent* event) OVERRIDE; |
| virtual void OnScrollEvent(ui::ScrollEvent* event) OVERRIDE; |
| - ShowState show_state_; |
| + // Index into |view_model_| of the currently active page. |
| + int active_page_; |
| // Special sub views of the ContentsView. All owned by the views hierarchy. |
| AppsContainerView* apps_container_view_; |
| @@ -101,6 +122,8 @@ class APP_LIST_EXPORT ContentsView : public views::View { |
| AppListMainView* app_list_main_view_; // Parent view, owns this. |
| scoped_ptr<views::ViewModel> view_model_; |
| + // Maps NamedPage onto |view_model_| indices. |
| + std::map<NamedPage, int> named_page_to_view_; |
| scoped_ptr<views::BoundsAnimator> bounds_animator_; |
| DISALLOW_COPY_AND_ASSIGN(ContentsView); |