*/
#include <iostream>
+#include <sigc++/bind.h>
#include <gtkmm2ext/doi.h>
#include "ardour_dialog.h"
-#include "keyboard.h"
#include "ardour_ui.h"
-
-
-ArdourDialog::ArdourDialog (string name)
- : Dialog (name),
- KeyboardTarget (*this, name)
-{
- session = 0;
- kbd_input = false;
- running = false;
- _run_status = 0;
- _within_hiding = false;
- hide_on_stop = true;
-}
-
-ArdourDialog::~ArdourDialog ()
+#include "keyboard.h"
+#include "splash.h"
+#include "utils.h"
+#include "window_manager.h"
+
+using namespace std;
+using namespace Gtk;
+using namespace Gtkmm2ext;
+using namespace ARDOUR_UI_UTILS;
+
+ArdourDialog::ArdourDialog (string title, bool modal, bool use_seperator)
+ : Dialog (title, modal, use_seperator)
+ , proxy (0)
+ , _splash_pushed (false)
{
+ init ();
+ set_position (Gtk::WIN_POS_MOUSE);
}
-bool
-ArdourDialog::on_enter_notify_event (GdkEventCrossing *ev)
+ArdourDialog::ArdourDialog (Gtk::Window& parent, string title, bool modal, bool use_seperator)
+ : Dialog (title, parent, modal, use_seperator)
+ , _splash_pushed (false)
{
- if (ev->detail != GDK_NOTIFY_INFERIOR) {
- Keyboard::the_keyboard().set_current_dialog (this);
- }
- return FALSE;
+ init ();
+ set_position (Gtk::WIN_POS_CENTER_ON_PARENT);
}
-bool
-ArdourDialog::on_leave_notify_event (GdkEventCrossing *ev)
+ArdourDialog::~ArdourDialog ()
{
- if (ev->detail != GDK_NOTIFY_INFERIOR) {
- Keyboard::the_keyboard().set_current_dialog (0);
- }
- return FALSE;
+ pop_splash ();
+ Keyboard::the_keyboard().focus_out_window (0, this);
+ WM::Manager::instance().remove (proxy);
}
void
-ArdourDialog::on_unmap ()
+ArdourDialog::on_response (int response_id)
{
- _within_hiding = true;
- Hiding (); /* EMIT_SIGNAL */
- _within_hiding = false;
- Dialog::on_unmap ();
+ pop_splash ();
+ hide ();
+ ARDOUR::GUIIdle ();
+ Gtk::Dialog::on_response (response_id);
}
void
-ArdourDialog::set_hide_on_stop (bool yn)
+ArdourDialog::close_self ()
{
- hide_on_stop = yn;
+ /* Don't call Idle, don't pop splash.
+ * This is used at exit and session-close and invoked
+ * via close_all_dialogs.
+ */
+ hide ();
+ Gtk::Dialog::on_response (RESPONSE_CANCEL);
}
void
-ArdourDialog::stop (int rr)
+ArdourDialog::pop_splash ()
{
- if (hide_on_stop) {
- Hiding (); /* EMIT_SIGNAL */
- hide_all ();
+ if (_splash_pushed) {
+ Splash* spl = Splash::instance();
- if (kbd_input) {
- ARDOUR_UI::instance()->allow_focus (false);
+ if (spl) {
+ spl->pop_front();
}
+ _splash_pushed = false;
}
+}
- if (running) {
- if (rr == 0) {
- response (GTK_RESPONSE_ACCEPT);
- } else {
- response (GTK_RESPONSE_CANCEL);
- }
- running = false;
+bool
+ArdourDialog::on_focus_in_event (GdkEventFocus *ev)
+{
+ Keyboard::the_keyboard().focus_in_window (ev, this);
+ return Dialog::on_focus_in_event (ev);
+}
+
+bool
+ArdourDialog::on_focus_out_event (GdkEventFocus *ev)
+{
+ if (!get_modal()) {
+ Keyboard::the_keyboard().focus_out_window (ev, this);
}
+ return Dialog::on_focus_out_event (ev);
}
void
-ArdourDialog::run ()
+ArdourDialog::on_unmap ()
{
- show_all ();
+ Keyboard::the_keyboard().leave_window (0, this);
+ Dialog::on_unmap ();
+}
- if (kbd_input) {
- ARDOUR_UI::instance()->allow_focus (true);
- }
+void
+ArdourDialog::on_show ()
+{
+ Dialog::on_show ();
- running = true;
- switch (Dialog::run ()) {
- case GTK_RESPONSE_ACCEPT:
- _run_status = 0;
- break;
-
- case GTK_RESPONSE_DELETE_EVENT:
- _run_status = -1;
- break;
-
- default:
- _run_status = -1;
- }
+ // never allow the splash screen to obscure any dialog
- hide_all ();
+ Splash* spl = Splash::instance();
- if (kbd_input) {
- ARDOUR_UI::instance()->allow_focus (false);
+ if (spl && spl->is_visible()) {
+ spl->pop_back_for (*this);
+ _splash_pushed = true;
}
}
-void
-ArdourDialog::set_keyboard_input (bool yn)
+bool
+ArdourDialog::on_delete_event (GdkEventAny*)
{
- kbd_input = yn;
+ hide ();
+ return false;
}
-int
-ArdourDialog::run_status ()
+void
+ArdourDialog::init ()
{
- return _run_status;
+ set_border_width (10);
+ add_events (Gdk::FOCUS_CHANGE_MASK);
+ set_type_hint (Gdk::WINDOW_TYPE_HINT_DIALOG);
+
+ Gtk::Window* parent = WM::Manager::instance().transient_parent();
+
+ if (parent) {
+ set_transient_for (*parent);
+ }
+
+ ARDOUR_UI::CloseAllDialogs.connect (sigc::mem_fun (*this, &ArdourDialog::close_self)); /* send a RESPONSE_CANCEL to self */
+
+ proxy = new WM::ProxyTemporary (get_title(), this);
+ WM::Manager::instance().register_window (proxy);
}