| Index: ash/shelf/shelf_layout_manager.cc
|
| diff --git a/ash/shelf/shelf_layout_manager.cc b/ash/shelf/shelf_layout_manager.cc
|
| index c9bfdf346abd36986ff90d985b084893c0d96b9a..830f0740a3b58247a18e609a87782c6844b96f36 100644
|
| --- a/ash/shelf/shelf_layout_manager.cc
|
| +++ b/ash/shelf/shelf_layout_manager.cc
|
| @@ -174,6 +174,11 @@ ShelfLayoutManager::~ShelfLayoutManager() {
|
| ShellPort::Get()->RemoveLockStateObserver(this);
|
| }
|
|
|
| +void ShelfLayoutManager::OnAppListIsActive(bool is_active) {
|
| + app_list_is_active_ = is_active;
|
| + MaybeUpdateShelfBackground(AnimationChangeType::IMMEDIATE);
|
| +}
|
| +
|
| void ShelfLayoutManager::PrepareForShutdown() {
|
| in_shutdown_ = true;
|
| // Stop observing changes to avoid updating a partially destructed shelf.
|
| @@ -469,6 +474,10 @@ ShelfBackgroundType ShelfLayoutManager::GetShelfBackgroundType() const {
|
| if (state_.session_state != session_manager::SessionState::ACTIVE)
|
| return SHELF_BACKGROUND_OVERLAP;
|
|
|
| + // If the app list is active, hide the shelf background to prevent overlap.
|
| + if (app_list_is_active_)
|
| + return SHELF_BACKGROUND_DEFAULT;
|
| +
|
| if (state_.visibility_state != SHELF_AUTO_HIDE &&
|
| state_.window_state == wm::WORKSPACE_WINDOW_STATE_MAXIMIZED) {
|
| return SHELF_BACKGROUND_MAXIMIZED;
|
|
|