#include "ardour_ui.h"
-ArdourDialog::ArdourDialog (string name)
- : Gtk::Window (GTK_WINDOW_TOPLEVEL),
- KeyboardTarget (*this, name)
+ArdourDialog::ArdourDialog (string title, bool modal, bool use_seperator)
+ : Dialog (title, modal, use_seperator)
{
session = 0;
- kbd_input = false;
- running = false;
- _run_status = 0;
- _within_hiding = false;
- hide_on_stop = true;
+
+ set_type_hint(Gdk::WINDOW_TYPE_HINT_DIALOG);
}
ArdourDialog::~ArdourDialog ()
{
}
-gint
+bool
ArdourDialog::on_enter_notify_event (GdkEventCrossing *ev)
{
- if (ev->detail != GDK_NOTIFY_INFERIOR) {
- Keyboard::the_keyboard().set_current_dialog (this);
- }
- return FALSE;
+ Keyboard::the_keyboard().enter_window (ev, this);
+ return false;
}
-gint
+bool
ArdourDialog::on_leave_notify_event (GdkEventCrossing *ev)
{
- if (ev->detail != GDK_NOTIFY_INFERIOR) {
- Keyboard::the_keyboard().set_current_dialog (0);
- }
- return FALSE;
-}
-
-gint
-ArdourDialog:on_unmap (GdkEventAny *ev)
-{
- _within_hiding = true;
- Hiding (); /* EMIT_SIGNAL */
- _within_hiding = false;
- return Gtk::Window::on_unmap (ev);
-}
-
-void
-ArdourDialog::wm_close()
-{
- stop (-1);
- ARDOUR_UI::instance()->allow_focus(false);
-}
-
-void
-ArdourDialog::wm_doi ()
-{
- if (!hide_on_stop) {
- Hiding (); /* EMIT_SIGNAL */
- }
- stop (-1);
- delete_when_idle (this);
-}
-
-gint
-ArdourDialog::wm_close_event (GdkEventAny* ev)
-{
- wm_close ();
- return TRUE;
-}
-
-gint
-ArdourDialog::wm_doi_event (GdkEventAny* ev)
-{
- wm_doi ();
- return TRUE;
-}
-
-gint
-ArdourDialog::wm_doi_event_stop (GdkEventAny* ev)
-{
- stop (-1);
- return TRUE;
-}
-
-void
-ArdourDialog::set_hide_on_stop (bool yn)
-{
- hide_on_stop = yn;
-}
-
-void
-ArdourDialog::close ()
-{
- hide_all ();
-
- if (kbd_input) {
- ARDOUR_UI::instance()->allow_focus (false);
- }
+ Keyboard::the_keyboard().leave_window (ev, this);
+ return false;
}
void
-ArdourDialog::stop (int rr)
-{
- _run_status = rr;
-
- if (hide_on_stop) {
- Hiding (); /* EMIT_SIGNAL */
- hide_all ();
-
- if (kbd_input) {
- ARDOUR_UI::instance()->allow_focus (false);
- }
- }
-
- if (running) {
- Gtk::Main::quit ();
- running = false;
- }
-}
-
-void
-ArdourDialog::run ()
-{
- show_all ();
-
- if (kbd_input) {
- ARDOUR_UI::instance()->allow_focus (true);
- }
-
- running = true;
- Gtk::Main::run ();
-}
-
-void
-ArdourDialog::set_keyboard_input (bool yn)
-{
- kbd_input = yn;
-}
-
-int
-ArdourDialog::run_status ()
+ArdourDialog::on_unmap ()
{
- return _run_status;
+ Dialog::on_unmap ();
}