| // 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 COMPONENTS_APP_MODAL_APP_MODAL_DIALOG_QUEUE_H_ | 
 | #define COMPONENTS_APP_MODAL_APP_MODAL_DIALOG_QUEUE_H_ | 
 |  | 
 | #include "base/containers/circular_deque.h" | 
 | #include "base/macros.h" | 
 |  | 
 | namespace base { | 
 | template <typename T> struct DefaultSingletonTraits; | 
 | } | 
 |  | 
 | namespace app_modal { | 
 |  | 
 | class JavaScriptAppModalDialog; | 
 |  | 
 | // Keeps a queue of JavaScriptAppModalDialogs, making sure only one app modal | 
 | // dialog is shown at a time. | 
 | // This class is a singleton. | 
 | class AppModalDialogQueue { | 
 |  public: | 
 |   typedef base::circular_deque<JavaScriptAppModalDialog*>::iterator iterator; | 
 |  | 
 |   // Returns the singleton instance. | 
 |   static AppModalDialogQueue* GetInstance(); | 
 |  | 
 |   // 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. | 
 |   // Note: The JavaScriptAppModalDialog |dialog| must be window modal before it | 
 |   // can be added as app modal. | 
 |   void AddDialog(JavaScriptAppModalDialog* 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() const; | 
 |  | 
 |   JavaScriptAppModalDialog* active_dialog() { return active_dialog_; } | 
 |  | 
 |   // Iterators to walk the queue. The queue does not include the currently | 
 |   // active app modal dialog box. | 
 |   iterator begin() { return app_modal_dialog_queue_.begin(); } | 
 |   iterator end() { return app_modal_dialog_queue_.end(); } | 
 |  | 
 |  private: | 
 |   friend struct base::DefaultSingletonTraits<AppModalDialogQueue>; | 
 |  | 
 |   AppModalDialogQueue(); | 
 |   ~AppModalDialogQueue(); | 
 |  | 
 |   // Shows |dialog| and notifies the BrowserList that a modal dialog is showing. | 
 |   void ShowModalDialog(JavaScriptAppModalDialog* 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 nullptr if there are no more dialogs, or all the dialogs in the | 
 |   // queue are not valid. | 
 |   JavaScriptAppModalDialog* GetNextDialog(); | 
 |  | 
 |   // Contains all app modal dialogs which are waiting to be shown. The currently | 
 |   // active modal dialog is not included. | 
 |   base::circular_deque<JavaScriptAppModalDialog*> app_modal_dialog_queue_; | 
 |  | 
 |   // The currently active app-modal dialog box. nullptr if there is no active | 
 |   // app-modal dialog box. | 
 |   JavaScriptAppModalDialog* active_dialog_; | 
 |  | 
 |   // Stores if |ShowModalDialog()| is currently being called on an app-modal | 
 |   // dialog. | 
 |   bool showing_modal_dialog_; | 
 |  | 
 |   DISALLOW_COPY_AND_ASSIGN(AppModalDialogQueue); | 
 | }; | 
 |  | 
 | }  // namespace app_modal | 
 |  | 
 | #endif  // COMPONENTS_APP_MODAL_APP_MODAL_DIALOG_QUEUE_H_ |