The new class 'ARDOUR::CoreSelection' needs to be exportable (since it gets used...
[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         ARDOUR::GUIIdle ();
67         Gtk::Dialog::on_response (response_id);
68 }
69
70 void
71 ArdourDialog::pop_splash ()
72 {
73         if (_splash_pushed) {
74                 Splash* spl = Splash::instance();
75
76                 if (spl) {
77                         spl->pop_front();
78                 }
79                 _splash_pushed = false;
80         }
81 }
82
83 bool
84 ArdourDialog::on_focus_in_event (GdkEventFocus *ev)
85 {
86         Keyboard::the_keyboard().focus_in_window (ev, this);
87         return Dialog::on_focus_in_event (ev);
88 }
89
90 bool
91 ArdourDialog::on_focus_out_event (GdkEventFocus *ev)
92 {
93         if (!get_modal()) {
94                 Keyboard::the_keyboard().focus_out_window (ev, this);
95         }
96         return Dialog::on_focus_out_event (ev);
97 }
98
99 void
100 ArdourDialog::on_unmap ()
101 {
102         Keyboard::the_keyboard().leave_window (0, this);
103         Dialog::on_unmap ();
104 }
105
106 void
107 ArdourDialog::on_show ()
108 {
109         Dialog::on_show ();
110
111         // never allow the splash screen to obscure any dialog
112
113         Splash* spl = Splash::instance();
114
115         if (spl && spl->is_visible()) {
116                 spl->pop_back_for (*this);
117                 _splash_pushed = true;
118         }
119 }
120
121 bool
122 ArdourDialog::on_delete_event (GdkEventAny*)
123 {
124         hide ();
125         return false;
126 }
127
128 void
129 ArdourDialog::init ()
130 {
131         set_border_width (10);
132         add_events (Gdk::FOCUS_CHANGE_MASK);
133         set_type_hint (Gdk::WINDOW_TYPE_HINT_DIALOG);
134
135         Gtk::Window* parent = WM::Manager::instance().transient_parent();
136
137         if (parent) {
138                 set_transient_for (*parent);
139         }
140
141         ARDOUR_UI::CloseAllDialogs.connect (sigc::bind (sigc::mem_fun (*this, &ArdourDialog::response), RESPONSE_CANCEL));
142
143         proxy = new WM::ProxyTemporary (get_title(), this);
144         WM::Manager::instance().register_window (proxy);
145 }