| Index: mash/wm/shelf_layout_manager.cc
|
| diff --git a/mash/wm/shelf_layout.cc b/mash/wm/shelf_layout_manager.cc
|
| similarity index 45%
|
| copy from mash/wm/shelf_layout.cc
|
| copy to mash/wm/shelf_layout_manager.cc
|
| index a62dfea55d82632f135a87dfa85ec0097ffb0d1b..f26522d53f5e6b4d0abb79a1a9a4e5655e422ec4 100644
|
| --- a/mash/wm/shelf_layout.cc
|
| +++ b/mash/wm/shelf_layout_manager.cc
|
| @@ -2,11 +2,9 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| -#include "mash/wm/shelf_layout.h"
|
| +#include "mash/wm/shelf_layout_manager.h"
|
|
|
| -#include "components/mus/public/cpp/property_type_converters.h"
|
| #include "components/mus/public/cpp/window.h"
|
| -#include "components/mus/public/cpp/window_property.h"
|
| #include "mash/wm/property_util.h"
|
| #include "mash/wm/public/interfaces/ash_window_type.mojom.h"
|
| #include "ui/gfx/geometry/rect.h"
|
| @@ -14,64 +12,40 @@
|
| namespace mash {
|
| namespace wm {
|
|
|
| -namespace {
|
| -
|
| -mojom::AshWindowType GetAshWindowType(const mus::Window* window) {
|
| - if (!window->HasSharedProperty(mojom::kAshWindowType_Property))
|
| - return mojom::AshWindowType::COUNT;
|
| -
|
| - return static_cast<mojom::AshWindowType>(
|
| - window->GetSharedProperty<int32_t>(mojom::kAshWindowType_Property));
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -ShelfLayout::ShelfLayout(mus::Window* owner)
|
| +ShelfLayoutManager::ShelfLayoutManager(mus::Window* owner)
|
| : LayoutManager(owner),
|
| alignment_(mash::shelf::mojom::Alignment::BOTTOM),
|
| auto_hide_behavior_(mash::shelf::mojom::AutoHideBehavior::NEVER) {
|
| AddLayoutProperty(mus::mojom::WindowManager::kPreferredSize_Property);
|
| }
|
|
|
| -ShelfLayout::~ShelfLayout() {}
|
| +ShelfLayoutManager::~ShelfLayoutManager() {}
|
|
|
| // We explicitly don't make assertions about the number of children in this
|
| // layout as the number of children can vary when the application providing the
|
| // shelf restarts.
|
|
|
| -void ShelfLayout::LayoutWindow(mus::Window* window) {
|
| - const mojom::AshWindowType ash_window_type = GetAshWindowType(window);
|
| +void ShelfLayoutManager::LayoutWindow(mus::Window* window) {
|
| + if (GetAshWindowType(window) != mojom::AshWindowType::SHELF) {
|
| + NOTREACHED() << "Unknown window in USER_SHELF container.";
|
| + return;
|
| + }
|
| gfx::Size size = GetWindowPreferredSize(window);
|
|
|
| if (alignment_ == mash::shelf::mojom::Alignment::BOTTOM) {
|
| const int y = owner()->bounds().height() - size.height();
|
| - if (ash_window_type == mojom::AshWindowType::SHELF) {
|
| - size.set_width(owner()->bounds().width());
|
| - window->SetBounds(gfx::Rect(0, y, size.width(), size.height()));
|
| - } else if (ash_window_type == mojom::AshWindowType::STATUS_AREA) {
|
| - // TODO(msw): Place the status area on the left for RTL UIs.
|
| - window->SetBounds(gfx::Rect(owner()->bounds().width() - size.width(), y,
|
| - size.width(), size.height()));
|
| - } else {
|
| - NOTREACHED() << "Unknown window in USER_SHELF container.";
|
| - }
|
| + size.set_width(owner()->bounds().width());
|
| + window->SetBounds(gfx::Rect(0, y, size.width(), size.height()));
|
| } else {
|
| const int x = (alignment_ == mash::shelf::mojom::Alignment::LEFT)
|
| ? 0
|
| : (owner()->bounds().width() - size.width());
|
| - if (ash_window_type == mojom::AshWindowType::SHELF) {
|
| - size.set_height(owner()->bounds().height());
|
| - window->SetBounds(gfx::Rect(x, 0, size.width(), size.height()));
|
| - } else if (ash_window_type == mojom::AshWindowType::STATUS_AREA) {
|
| - window->SetBounds(gfx::Rect(x, owner()->bounds().height() - size.height(),
|
| - size.width(), size.height()));
|
| - } else {
|
| - NOTREACHED() << "Unknown window in USER_SHELF container.";
|
| - }
|
| + size.set_height(owner()->bounds().height());
|
| + window->SetBounds(gfx::Rect(x, 0, size.width(), size.height()));
|
| }
|
| }
|
|
|
| -void ShelfLayout::SetAlignment(mash::shelf::mojom::Alignment alignment) {
|
| +void ShelfLayoutManager::SetAlignment(mash::shelf::mojom::Alignment alignment) {
|
| if (alignment_ == alignment)
|
| return;
|
|
|
| @@ -80,7 +54,7 @@ void ShelfLayout::SetAlignment(mash::shelf::mojom::Alignment alignment) {
|
| LayoutWindow(window);
|
| }
|
|
|
| -void ShelfLayout::SetAutoHideBehavior(
|
| +void ShelfLayoutManager::SetAutoHideBehavior(
|
| mash::shelf::mojom::AutoHideBehavior auto_hide) {
|
| if (auto_hide_behavior_ == auto_hide)
|
| return;
|
|
|