// 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. #include "ash/shell/shell_delegate_impl.h" #include "ash/accessibility_delegate.h" #include "ash/default_accessibility_delegate.h" #include "ash/default_user_wallpaper_delegate.h" #include "ash/gpu_support_stub.h" #include "ash/media_delegate.h" #include "ash/new_window_delegate.h" #include "ash/session/session_state_delegate.h" #include "ash/shell/context_menu.h" #include "ash/shell/example_factory.h" #include "ash/shell/keyboard_controller_proxy_stub.h" #include "ash/shell/shelf_delegate_impl.h" #include "ash/shell/toplevel_window.h" #include "ash/shell_window_ids.h" #include "ash/system/tray/default_system_tray_delegate.h" #include "ash/wm/window_state.h" #include "base/message_loop/message_loop.h" #include "base/strings/utf_string_conversions.h" #include "components/user_manager/user_info_impl.h" #include "ui/aura/window.h" #include "ui/wm/core/input_method_event_filter.h" namespace ash { namespace shell { namespace { class NewWindowDelegateImpl : public NewWindowDelegate { public: NewWindowDelegateImpl() {} virtual ~NewWindowDelegateImpl() {} // NewWindowDelegate: virtual void NewTab() OVERRIDE {} virtual void NewWindow(bool incognito) OVERRIDE { ash::shell::ToplevelWindow::CreateParams create_params; create_params.can_resize = true; create_params.can_maximize = true; ash::shell::ToplevelWindow::CreateToplevelWindow(create_params); } virtual void OpenFileManager() OVERRIDE {} virtual void OpenCrosh() OVERRIDE {} virtual void RestoreTab() OVERRIDE {} virtual void ShowKeyboardOverlay() OVERRIDE {} virtual void ShowTaskManager() OVERRIDE {} virtual void OpenFeedbackPage() OVERRIDE {} private: DISALLOW_COPY_AND_ASSIGN(NewWindowDelegateImpl); }; class MediaDelegateImpl : public MediaDelegate { public: MediaDelegateImpl() {} virtual ~MediaDelegateImpl() {} // MediaDelegate: virtual void HandleMediaNextTrack() OVERRIDE {} virtual void HandleMediaPlayPause() OVERRIDE {} virtual void HandleMediaPrevTrack() OVERRIDE {} virtual MediaCaptureState GetMediaCaptureState( content::BrowserContext* context) OVERRIDE { return MEDIA_CAPTURE_VIDEO; } private: DISALLOW_COPY_AND_ASSIGN(MediaDelegateImpl); }; class SessionStateDelegateImpl : public SessionStateDelegate { public: SessionStateDelegateImpl() : screen_locked_(false), user_info_(new user_manager::UserInfoImpl()) {} virtual ~SessionStateDelegateImpl() {} // SessionStateDelegate: virtual content::BrowserContext* GetBrowserContextByIndex( MultiProfileIndex index) OVERRIDE { return Shell::GetInstance()->delegate()->GetActiveBrowserContext(); } virtual content::BrowserContext* GetBrowserContextForWindow( aura::Window* window) OVERRIDE { return Shell::GetInstance()->delegate()->GetActiveBrowserContext(); } virtual int GetMaximumNumberOfLoggedInUsers() const OVERRIDE { return 3; } virtual int NumberOfLoggedInUsers() const OVERRIDE { // ash_shell has 2 users. return 2; } virtual bool IsActiveUserSessionStarted() const OVERRIDE { return true; } virtual bool CanLockScreen() const OVERRIDE { return true; } virtual bool IsScreenLocked() const OVERRIDE { return screen_locked_; } virtual bool ShouldLockScreenBeforeSuspending() const OVERRIDE { return false; } virtual void LockScreen() OVERRIDE { shell::CreateLockScreen(); screen_locked_ = true; Shell::GetInstance()->UpdateShelfVisibility(); } virtual void UnlockScreen() OVERRIDE { screen_locked_ = false; Shell::GetInstance()->UpdateShelfVisibility(); } virtual bool IsUserSessionBlocked() const OVERRIDE { return !IsActiveUserSessionStarted() || IsScreenLocked(); } virtual SessionState GetSessionState() const OVERRIDE { // Assume that if session is not active we're at login. return IsActiveUserSessionStarted() ? SESSION_STATE_ACTIVE : SESSION_STATE_LOGIN_PRIMARY; } virtual const user_manager::UserInfo* GetUserInfo( MultiProfileIndex index) const OVERRIDE { return user_info_.get(); } virtual const user_manager::UserInfo* GetUserInfo( content::BrowserContext* context) const OVERRIDE { return user_info_.get(); } virtual bool ShouldShowAvatar(aura::Window* window) const OVERRIDE { return !user_info_->GetImage().isNull(); } virtual void SwitchActiveUser(const std::string& user_id) OVERRIDE {} virtual void CycleActiveUser(CycleUser cycle_user) OVERRIDE {} virtual bool IsMultiProfileAllowedByPrimaryUserPolicy() const OVERRIDE { return true; } virtual void AddSessionStateObserver( ash::SessionStateObserver* observer) OVERRIDE {} virtual void RemoveSessionStateObserver( ash::SessionStateObserver* observer) OVERRIDE {} private: bool screen_locked_; // A pseudo user info. scoped_ptr user_info_; DISALLOW_COPY_AND_ASSIGN(SessionStateDelegateImpl); }; } // namespace ShellDelegateImpl::ShellDelegateImpl() : watcher_(NULL), shelf_delegate_(NULL), browser_context_(NULL) { } ShellDelegateImpl::~ShellDelegateImpl() { } void ShellDelegateImpl::SetWatcher(WindowWatcher* watcher) { watcher_ = watcher; if (shelf_delegate_) shelf_delegate_->set_watcher(watcher); } bool ShellDelegateImpl::IsFirstRunAfterBoot() const { return false; } bool ShellDelegateImpl::IsIncognitoAllowed() const { return true; } bool ShellDelegateImpl::IsMultiProfilesEnabled() const { return false; } bool ShellDelegateImpl::IsRunningInForcedAppMode() const { return false; } bool ShellDelegateImpl::IsMultiAccountEnabled() const { return false; } void ShellDelegateImpl::PreInit() { } void ShellDelegateImpl::PreShutdown() { } void ShellDelegateImpl::Exit() { base::MessageLoopForUI::current()->Quit(); } keyboard::KeyboardControllerProxy* ShellDelegateImpl::CreateKeyboardControllerProxy() { return new KeyboardControllerProxyStub(); } void ShellDelegateImpl::VirtualKeyboardActivated(bool activated) { } void ShellDelegateImpl::AddVirtualKeyboardStateObserver( VirtualKeyboardStateObserver* observer) { } void ShellDelegateImpl::RemoveVirtualKeyboardStateObserver( VirtualKeyboardStateObserver* observer) { } content::BrowserContext* ShellDelegateImpl::GetActiveBrowserContext() { return browser_context_; } app_list::AppListViewDelegate* ShellDelegateImpl::CreateAppListViewDelegate() { return ash::shell::CreateAppListViewDelegate(); } ShelfDelegate* ShellDelegateImpl::CreateShelfDelegate(ShelfModel* model) { shelf_delegate_ = new ShelfDelegateImpl(watcher_); return shelf_delegate_; } ash::SystemTrayDelegate* ShellDelegateImpl::CreateSystemTrayDelegate() { return new DefaultSystemTrayDelegate; } ash::UserWallpaperDelegate* ShellDelegateImpl::CreateUserWallpaperDelegate() { return new DefaultUserWallpaperDelegate(); } ash::SessionStateDelegate* ShellDelegateImpl::CreateSessionStateDelegate() { return new SessionStateDelegateImpl; } ash::AccessibilityDelegate* ShellDelegateImpl::CreateAccessibilityDelegate() { return new DefaultAccessibilityDelegate; } ash::NewWindowDelegate* ShellDelegateImpl::CreateNewWindowDelegate() { return new NewWindowDelegateImpl; } ash::MediaDelegate* ShellDelegateImpl::CreateMediaDelegate() { return new MediaDelegateImpl; } ui::MenuModel* ShellDelegateImpl::CreateContextMenu( aura::Window* root, ash::ShelfItemDelegate* item_delegate, ash::ShelfItem* item) { return new ContextMenu(root); } GPUSupport* ShellDelegateImpl::CreateGPUSupport() { // Real GPU support depends on src/content, so just use a stub. return new GPUSupportStub; } base::string16 ShellDelegateImpl::GetProductName() const { return base::string16(); } } // namespace shell } // namespace ash