Index: chrome/browser/app_modal_dialog_queue.h |
=================================================================== |
--- chrome/browser/app_modal_dialog_queue.h (revision 67887) |
+++ chrome/browser/app_modal_dialog_queue.h (working copy) |
@@ -1,85 +0,0 @@ |
-// Copyright (c) 2006-2008 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 CHROME_BROWSER_APP_MODAL_DIALOG_QUEUE_H_ |
-#define CHROME_BROWSER_APP_MODAL_DIALOG_QUEUE_H_ |
-#pragma once |
- |
-#include <queue> |
- |
-#include "base/singleton.h" |
-#include "chrome/browser/app_modal_dialog.h" |
- |
-// Keeps a queue of AppModalDialogs, making sure only one app modal |
-// dialog is shown at a time. |
-// This class is a singleton. |
-class AppModalDialogQueue { |
- public: |
- // Adds a modal dialog to the queue, if there are no other dialogs in the |
- // queue, the dialog will be shown immediately. Once it is shown, the |
- // most recently active browser window (or whichever is currently active) |
- // will be app modal, meaning it will be activated if the user tries to |
- // activate any other browser windows. So the dialog being shown should |
- // assure it is the child of BrowserList::GetLastActive() so that it is |
- // activated as well. See browser_list.h for more notes about our somewhat |
- // sloppy app modality. |
- // Note: The AppModalDialog |dialog| must be window modal before it |
- // can be added as app modal. |
- void AddDialog(AppModalDialog* dialog); |
- |
- // Removes the current dialog in the queue (the one that is being shown). |
- // Shows the next dialog in the queue, if any is present. This does not |
- // ensure that the currently showing dialog is closed, it just makes it no |
- // longer app modal. |
- void ShowNextDialog(); |
- |
- // Activates and shows the current dialog, if the user clicks on one of the |
- // windows disabled by the presence of an app modal dialog. This forces |
- // the window to be visible on the display even if desktop manager software |
- // opened the dialog on another virtual desktop. Assumes there is currently a |
- // dialog being shown. (Call BrowserList::IsShowingAppModalDialog to test |
- // this condition). |
- void ActivateModalDialog(); |
- |
- // Returns true if there is currently an active app modal dialog box. |
- bool HasActiveDialog() { |
- return active_dialog_ != NULL; |
- } |
- |
- // Accessor for |active_dialog_|. |
- AppModalDialog* active_dialog() { |
- return active_dialog_; |
- } |
- |
- private: |
- friend struct DefaultSingletonTraits<AppModalDialogQueue>; |
- |
- AppModalDialogQueue(); |
- ~AppModalDialogQueue(); |
- |
- // Shows |dialog| and notifies the BrowserList that a modal dialog is showing. |
- void ShowModalDialog(AppModalDialog* dialog); |
- |
- // Returns the next dialog to show. This removes entries from |
- // app_modal_dialog_queue_ until one is valid or the queue is empty. This |
- // returns NULL if there are no more dialogs, or all the dialogs in the queue |
- // are not valid. |
- AppModalDialog* GetNextDialog(); |
- |
- // Contains all app modal dialogs which are waiting to be shown, with the |
- // currently modal dialog at the front of the queue. |
- std::queue<AppModalDialog*> app_modal_dialog_queue_; |
- |
- // The currently active app-modal dialog box's delegate. NULL if there is no |
- // active app-modal dialog box. |
- AppModalDialog* active_dialog_; |
- |
- // Stores if |ShowModalDialog()| is currently being called on an app-modal |
- // dialog. |
- bool showing_modal_dialog_; |
- |
- DISALLOW_COPY_AND_ASSIGN(AppModalDialogQueue); |
-}; |
- |
-#endif // CHROME_BROWSER_APP_MODAL_DIALOG_QUEUE_H_ |