blob: 615b7cd6125a83ddc97b936b471ec7a0d8d3172e [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ASH_SHELL_OBSERVER_H_
#define ASH_SHELL_OBSERVER_H_
#include "ash/ash_export.h"
#include "ash/login_status.h"
namespace aura {
class Window;
}
class PrefService;
namespace ash {
class ASH_EXPORT ShellObserver {
public:
// Called when the AppList is shown or dismissed.
virtual void OnAppListVisibilityChanged(bool shown,
aura::Window* root_window) {}
// Called when a casting session is started or stopped.
virtual void OnCastingSessionStartedOrStopped(bool started) {}
// Invoked after a non-primary root window is created.
virtual void OnRootWindowAdded(aura::Window* root_window) {}
// Invoked when the shelf alignment in |root_window| is changed.
virtual void OnShelfAlignmentChanged(aura::Window* root_window) {}
// Invoked when the shelf auto-hide behavior in |root_window| is changed.
virtual void OnShelfAutoHideBehaviorChanged(aura::Window* root_window) {}
// Invoked when entering or exiting fullscreen mode in |root_window|.
virtual void OnFullscreenStateChanged(bool is_fullscreen,
aura::Window* root_window) {}
// Invoked when |pinned_window| enter or exit pinned mode.
virtual void OnPinnedStateChanged(aura::Window* pinned_window) {}
// Called when the overview mode is about to be started (before the windows
// get re-arranged).
virtual void OnOverviewModeStarting() {}
// Called after the animations that happen when overview mode is started are
// complete. If |canceled| it means overview was quit before the start
// animations were finished.
virtual void OnOverviewModeStartingAnimationComplete(bool canceled) {}
// Called when the overview mode is about to end (bofore the windows restore
// themselves).
virtual void OnOverviewModeEnding() {}
// Called after overview mode has ended.
virtual void OnOverviewModeEnded() {}
// Called after the animations that happen when overview mode is ended are
// complete. If |canceled| it means overview was reentered before the exit
// animations were finished.
virtual void OnOverviewModeEndingAnimationComplete(bool canceled) {}
// Called when the split view mode is about to be started before the window
// gets snapped and activated).
virtual void OnSplitViewModeStarting() {}
// Called when the split view mode has been started.
virtual void OnSplitViewModeStarted() {}
// Called after split view mode has ended.
virtual void OnSplitViewModeEnded() {}
// Called when dictation is activated.
virtual void OnDictationStarted() {}
// Called when dicatation is ended.
virtual void OnDictationEnded() {}
// Called at the end of Shell::Init.
virtual void OnShellInitialized() {}
// Called near the end of ~Shell. Shell::Get() still returns the Shell, but
// most of Shell's state has been deleted.
virtual void OnShellDestroyed() {}
// Called when local state prefs are available. This occurs an arbitrary
// amount of time after Shell initialization. Only called once.
virtual void OnLocalStatePrefServiceInitialized(PrefService* pref_service) {}
protected:
virtual ~ShellObserver() {}
};
} // namespace ash
#endif // ASH_SHELL_OBSERVER_H_