Pop splash on dialog response - not d'tor.
[ardour.git] / gtk2_ardour / ardour_dialog.cc
1 /*
2     Copyright (C) 2002 Paul Davis
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 #include <iostream>
21 #include <sigc++/bind.h>
22
23 #include <gtkmm2ext/doi.h>
24
25 #include "ardour_dialog.h"
26 #include "ardour_ui.h"
27 #include "keyboard.h"
28 #include "splash.h"
29 #include "utils.h"
30 #include "window_manager.h"
31
32 using namespace std;
33 using namespace Gtk;
34 using namespace Gtkmm2ext;
35 using namespace ARDOUR_UI_UTILS;
36
37 ArdourDialog::ArdourDialog (string title, bool modal, bool use_seperator)
38         : Dialog (title, modal, use_seperator)
39         , proxy (0)
40         , _splash_pushed (false)
41 {
42         init ();
43         set_position (Gtk::WIN_POS_MOUSE);
44 }
45
46 ArdourDialog::ArdourDialog (Gtk::Window& parent, string title, bool modal, bool use_seperator)
47         : Dialog (title, parent, modal, use_seperator)
48         , _splash_pushed (false)
49 {
50         init ();
51         set_position (Gtk::WIN_POS_CENTER_ON_PARENT);
52 }
53
54 ArdourDialog::~ArdourDialog ()
55 {
56         pop_splash ();
57         Keyboard::the_keyboard().focus_out_window (0, this);
58         WM::Manager::instance().remove (proxy);
59 }
60
61 void
62 ArdourDialog::on_response (int response_id)
63 {
64         pop_splash ();
65         hide ();
66         Gtk::Dialog::on_response (response_id);
67 }
68
69 void
70 ArdourDialog::pop_splash ()
71 {
72         if (_splash_pushed) {
73                 Splash* spl = Splash::instance();
74
75                 if (spl) {
76                         spl->pop_front();
77                 }
78                 _splash_pushed = false;
79         }
80 }
81
82 bool
83 ArdourDialog::on_focus_in_event (GdkEventFocus *ev)
84 {
85         Keyboard::the_keyboard().focus_in_window (ev, this);
86         return Dialog::on_focus_in_event (ev);
87 }
88
89 bool
90 ArdourDialog::on_focus_out_event (GdkEventFocus *ev)
91 {
92         if (!get_modal()) {
93                 Keyboard::the_keyboard().focus_out_window (ev, this);
94         }
95         return Dialog::on_focus_out_event (ev);
96 }
97
98 void
99 ArdourDialog::on_unmap ()
100 {
101         Keyboard::the_keyboard().leave_window (0, this);
102         Dialog::on_unmap ();
103 }
104
105 void
106 ArdourDialog::on_show ()
107 {
108         Dialog::on_show ();
109
110         // never allow the splash screen to obscure any dialog
111
112         Splash* spl = Splash::instance();
113
114         if (spl && spl->is_visible()) {
115                 spl->pop_back_for (*this);
116                 _splash_pushed = true;
117         }
118 }
119
120 bool
121 ArdourDialog::on_delete_event (GdkEventAny*)
122 {
123         hide ();
124         return false;
125 }
126
127 void
128 ArdourDialog::init ()
129 {
130         set_border_width (10);
131         add_events (Gdk::FOCUS_CHANGE_MASK);
132         set_type_hint (Gdk::WINDOW_TYPE_HINT_DIALOG);
133
134         Gtk::Window* parent = WM::Manager::instance().transient_parent();
135
136         if (parent) {
137                 set_transient_for (*parent);
138         }
139
140         ARDOUR_UI::CloseAllDialogs.connect (sigc::bind (sigc::mem_fun (*this, &ArdourDialog::response), RESPONSE_CANCEL));
141
142         proxy = new WM::ProxyTemporary (get_title(), this);
143         WM::Manager::instance().register_window (proxy);
144 }