]> git.saurik.com Git - wxWidgets.git/blame - src/osx/dialog_osx.cpp
Call Dismiss rather than Show(false) on the infobar to correct the layout.
[wxWidgets.git] / src / osx / dialog_osx.cpp
CommitLineData
3ccc5735
SC
1/////////////////////////////////////////////////////////////////////////////
2// Name: src/osx/dialog_osx.cpp
3// Purpose: wxDialog class
4// Author: Stefan Csomor
5// Modified by:
6// Created: 1998-01-01
b5b208a1 7// RCS-ID: $Id$
3ccc5735
SC
8// Copyright: (c) Stefan Csomor
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12#include "wx/wxprec.h"
13
14#include "wx/dialog.h"
62068535 15#include "wx/evtloop.h"
3ccc5735
SC
16
17#ifndef WX_PRECOMP
18 #include "wx/app.h"
19 #include "wx/utils.h"
20 #include "wx/frame.h"
21 #include "wx/settings.h"
22#endif // WX_PRECOMP
23
24#include "wx/osx/private.h"
25
445e564f
SC
26static int s_openDialogs = 0;
27bool wxDialog::OSXHasModalDialogsOpen()
28{
29 return s_openDialogs > 0;
30}
31
32void wxDialog::OSXBeginModalDialog()
33{
34 s_openDialogs++;
35}
36
37void wxDialog::OSXEndModalDialog()
38{
39 wxASSERT_MSG( s_openDialogs > 0, "incorrect internal modal dialog count");
40 s_openDialogs--;
41}
3ccc5735 42
3ccc5735
SC
43void wxDialog::Init()
44{
4d572a2c 45 m_modality = wxDIALOG_MODALITY_NONE;
62068535 46 m_eventLoop = NULL;
3ccc5735
SC
47}
48
49bool wxDialog::Create( wxWindow *parent,
50 wxWindowID id,
51 const wxString& title,
52 const wxPoint& pos,
53 const wxSize& size,
54 long style,
55 const wxString& name )
56{
57 SetExtraStyle( GetExtraStyle() | wxTOPLEVEL_EX_DIALOG );
58
59 // All dialogs should really have this style...
60 style |= wxTAB_TRAVERSAL;
61
62 // ...but not these styles
63 style &= ~(wxYES | wxOK | wxNO); // | wxCANCEL
64
65 if ( !wxTopLevelWindow::Create( parent, id, title, pos, size, style, name ) )
66 return false;
67
68 return true;
69}
70
3ccc5735
SC
71wxDialog::~wxDialog()
72{
c6212a0c 73 SendDestroyEvent();
3ccc5735
SC
74
75 // if the dialog is modal, this will end its event loop
76 Show(false);
77}
78
79// On mac command-stop does the same thing as Esc, let the base class know
80// about it
81bool wxDialog::IsEscapeKey(const wxKeyEvent& event)
82{
83 if ( event.GetKeyCode() == '.' && event.GetModifiers() == wxMOD_CMD )
84 return true;
85
86 return wxDialogBase::IsEscapeKey(event);
87}
88
89bool wxDialog::IsModal() const
90{
4d572a2c 91 return m_modality != wxDIALOG_MODALITY_NONE;
3ccc5735
SC
92}
93
3ccc5735
SC
94bool wxDialog::Show(bool show)
95{
4d572a2c
SC
96 if ( m_modality == wxDIALOG_MODALITY_WINDOW_MODAL )
97 {
98 if ( !wxWindow::Show(show) )
99 // nothing to do
100 return false;
101 }
ce00f59b 102 else
4d572a2c
SC
103 {
104 if ( !wxDialogBase::Show(show) )
105 // nothing to do
106 return false;
107 }
3ccc5735
SC
108
109 if (show && CanDoLayoutAdaptation())
110 DoLayoutAdaptation();
111
112 if ( show )
113 // usually will result in TransferDataToWindow() being called
114 InitDialog();
115
4d572a2c 116 if ( !show )
3ccc5735 117 {
4d572a2c 118 switch( m_modality )
3ccc5735 119 {
4d572a2c
SC
120 case wxDIALOG_MODALITY_WINDOW_MODAL:
121 EndWindowModal(); // OS X implementation method for cleanup
ce00f59b 122 SendWindowModalDialogEvent ( wxEVT_WINDOW_MODAL_DIALOG_CLOSED );
4d572a2c
SC
123 break;
124 default:
125 break;
3ccc5735 126 }
4d572a2c 127 m_modality = wxDIALOG_MODALITY_NONE;
3ccc5735 128 }
ce00f59b 129
3ccc5735
SC
130 return true;
131}
132
133// Replacement for Show(true) for modal dialogs - returns return code
134int wxDialog::ShowModal()
135{
bfa92264 136 m_modality = wxDIALOG_MODALITY_APP_MODAL;
ce00f59b 137
4d572a2c 138 Show();
3ccc5735 139
62068535
SC
140 wxModalEventLoop modalLoop(this);
141 m_eventLoop = &modalLoop;
ce00f59b 142
445e564f 143 wxDialog::OSXBeginModalDialog();
62068535 144 modalLoop.Run();
445e564f 145 wxDialog::OSXEndModalDialog();
ce00f59b 146
62068535 147 m_eventLoop = NULL;
ce00f59b 148
3ccc5735
SC
149 return GetReturnCode();
150}
151
4d572a2c
SC
152void wxDialog::ShowWindowModal()
153{
154 m_modality = wxDIALOG_MODALITY_WINDOW_MODAL;
ce00f59b 155
4d572a2c 156 Show();
ce00f59b 157
4d572a2c
SC
158 DoShowWindowModal();
159}
160
161wxDialogModality wxDialog::GetModality() const
162{
163 return m_modality;
164}
165
cbab1556 166// NB: this function (surprisingly) may be called for both modal and modeless
3ccc5735
SC
167// dialogs and should work for both of them
168void wxDialog::EndModal(int retCode)
169{
62068535
SC
170 if ( m_eventLoop )
171 m_eventLoop->Exit(retCode);
ce00f59b 172
3ccc5735
SC
173 SetReturnCode(retCode);
174 Show(false);
3ccc5735
SC
175}
176