| // Copyright 2013 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_ACCELERATORS_EXIT_WARNING_HANDLER_H_ |
| #define ASH_ACCELERATORS_EXIT_WARNING_HANDLER_H_ |
| |
| #include "ash/ash_export.h" |
| #include "base/memory/scoped_ptr.h" |
| #include "base/timer/timer.h" |
| #include "ui/base/accelerators/accelerator.h" |
| |
| namespace views { |
| class Widget; |
| } |
| |
| namespace ash { |
| |
| // In order to avoid accidental exits when the user presses the exit |
| // shortcut by mistake, we require the user press it twice within a |
| // period of time. During that time we show a popup informing the |
| // user of this. |
| // |
| // Notes: |
| // |
| // The corresponding accelerator must be non-repeatable (see |
| // kNonrepeatableActions in accelerator_table.cc). Otherwise the "Double Press |
| // Exit" will be activated just by holding it down, i.e. probably every time. |
| // |
| // State Transition Diagrams: |
| // |
| // IDLE |
| // | Press |
| // WAIT_FOR_DOUBLE_PRESS action: show ui & start timers |
| // | Press (before time limit ) |
| // EXITING action: hide ui, stop timer, exit |
| // |
| // IDLE |
| // | Press |
| // WAIT_FOR_DOUBLE_PRESS action: show ui & start timers |
| // | T timer expires |
| // IDLE action: hide ui |
| // |
| |
| class AcceleratorControllerTest; |
| |
| class ASH_EXPORT ExitWarningHandler { |
| public: |
| ExitWarningHandler(); |
| |
| ~ExitWarningHandler(); |
| |
| // Handles accelerator for exit (Ctrl-Shift-Q). |
| void HandleAccelerator(); |
| |
| private: |
| friend class AcceleratorControllerTest; |
| |
| enum State { |
| IDLE, |
| WAIT_FOR_DOUBLE_PRESS, |
| EXITING |
| }; |
| |
| // Performs actions when the time limit is exceeded. |
| void TimerAction(); |
| |
| void StartTimer(); |
| void CancelTimer(); |
| |
| void Show(); |
| void Hide(); |
| |
| State state_; |
| scoped_ptr<views::Widget> widget_; |
| base::OneShotTimer<ExitWarningHandler> timer_; |
| |
| // Flag to suppress starting the timer for testing. For test we call |
| // TimerAction() directly to simulate the expiration of the timer. |
| bool stub_timer_for_test_; |
| |
| DISALLOW_COPY_AND_ASSIGN(ExitWarningHandler); |
| }; |
| |
| } // namespace ash |
| |
| #endif // ASH_ACCELERATORS_EXIT_WARNING_HANDLER_H_ |