]> git.saurik.com Git - wxWidgets.git/blob - src/html/helpfrm.cpp
XRC spec: document the "focused" window property.
[wxWidgets.git] / src / html / helpfrm.cpp
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: src/html/helpfrm.cpp
3 // Purpose: wxHtmlHelpFrame
4 // Notes: Based on htmlhelp.cpp, implementing a monolithic
5 // HTML Help controller class, by Vaclav Slavik
6 // Author: Harm van der Heijden and Vaclav Slavik
7 // Copyright: (c) Harm van der Heijden and Vaclav Slavik
8 // Licence: wxWindows licence
9 /////////////////////////////////////////////////////////////////////////////
10
11 // For compilers that support precompilation, includes "wx.h"
12
13 #include "wx/wxprec.h"
14
15 #ifdef __BORLANDC__
16 #pragma hdrstop
17 #endif
18
19 #if wxUSE_WXHTML_HELP
20
21 #ifndef WX_PRECOMP
22 #include "wx/object.h"
23 #include "wx/dynarray.h"
24 #include "wx/intl.h"
25 #include "wx/log.h"
26 #if wxUSE_STREAMS
27 #include "wx/stream.h"
28 #endif
29
30 #include "wx/sizer.h"
31
32 #include "wx/bmpbuttn.h"
33 #include "wx/statbox.h"
34 #include "wx/radiobox.h"
35 #include "wx/menu.h"
36 #include "wx/settings.h"
37 #include "wx/msgdlg.h"
38 #include "wx/textctrl.h"
39 #include "wx/toolbar.h"
40 #include "wx/choicdlg.h"
41 #include "wx/filedlg.h"
42 #endif // WX_PRECOMP
43
44 #include "wx/html/helpfrm.h"
45 #include "wx/html/helpctrl.h"
46 #include "wx/notebook.h"
47 #include "wx/imaglist.h"
48 #include "wx/treectrl.h"
49 #include "wx/tokenzr.h"
50 #include "wx/wfstream.h"
51 #include "wx/html/htmlwin.h"
52 #include "wx/busyinfo.h"
53 #include "wx/progdlg.h"
54 #include "wx/fontenum.h"
55 #include "wx/artprov.h"
56 #include "wx/spinctrl.h"
57
58 IMPLEMENT_DYNAMIC_CLASS(wxHtmlHelpFrame, wxFrame)
59
60 BEGIN_EVENT_TABLE(wxHtmlHelpFrame, wxFrame)
61 EVT_ACTIVATE(wxHtmlHelpFrame::OnActivate)
62 EVT_CLOSE(wxHtmlHelpFrame::OnCloseWindow)
63 #ifdef __WXMAC__
64 EVT_MENU(wxID_CLOSE, wxHtmlHelpFrame::OnClose)
65 EVT_MENU(wxID_ABOUT, wxHtmlHelpFrame::OnAbout)
66 EVT_MENU(wxID_HELP_CONTENTS, wxHtmlHelpFrame::OnAbout)
67 #endif
68 END_EVENT_TABLE()
69
70 wxHtmlHelpFrame::wxHtmlHelpFrame(wxWindow* parent, wxWindowID id, const wxString& title,
71 int style, wxHtmlHelpData* data
72 #if wxUSE_CONFIG
73 , wxConfigBase *config, const wxString& rootpath
74 #endif // wxUSE_CONFIG
75 )
76 {
77 Init(data);
78 Create(parent, id, title, style
79 #if wxUSE_CONFIG
80 , config, rootpath
81 #endif // wxUSE_CONFIG
82 );
83 }
84
85 void wxHtmlHelpFrame::Init(wxHtmlHelpData* data)
86 {
87 // Simply pass the pointer on to the help window
88 m_Data = data;
89 m_HtmlHelpWin = NULL;
90 m_helpController = NULL;
91 m_shouldPreventAppExit = false;
92 }
93
94 void wxHtmlHelpFrame::SetController(wxHtmlHelpController* controller)
95 {
96 m_helpController = controller;
97 if ( m_HtmlHelpWin )
98 m_HtmlHelpWin->SetController(controller);
99 }
100
101 // Create: builds the GUI components.
102 bool wxHtmlHelpFrame::Create(wxWindow* parent, wxWindowID id,
103 const wxString& WXUNUSED(title), int style
104 #if wxUSE_CONFIG
105 , wxConfigBase *config, const wxString& rootpath
106 #endif // wxUSE_CONFIG
107 )
108 {
109 m_HtmlHelpWin = new wxHtmlHelpWindow(m_Data);
110 m_HtmlHelpWin->SetController(m_helpController);
111 #if wxUSE_CONFIG
112 if ( config )
113 m_HtmlHelpWin->UseConfig(config, rootpath);
114 #endif // wxUSE_CONFIG
115
116 wxFrame::Create(parent, id, _("Help"),
117 wxPoint(m_HtmlHelpWin->GetCfgData().x, m_HtmlHelpWin->GetCfgData().y),
118 wxSize(m_HtmlHelpWin->GetCfgData().w, m_HtmlHelpWin->GetCfgData().h),
119 wxDEFAULT_FRAME_STYLE, wxT("wxHtmlHelp"));
120 #if wxUSE_STATUSBAR
121 CreateStatusBar();
122 #endif
123 m_HtmlHelpWin->Create(this, wxID_ANY, wxDefaultPosition, wxDefaultSize,
124 wxTAB_TRAVERSAL|wxNO_BORDER, style);
125
126 GetPosition(& (m_HtmlHelpWin->GetCfgData().x), & (m_HtmlHelpWin->GetCfgData()).y);
127
128 SetIcons(wxArtProvider::GetIconBundle(wxART_HELP, wxART_FRAME_ICON));
129
130 // On the Mac, each modeless frame must have a menubar.
131 // TODO: add more menu items, and perhaps add a style to show
132 // the menubar: compulsory on the Mac, optional elsewhere.
133 #ifdef __WXMAC__
134 wxMenuBar* menuBar = new wxMenuBar;
135
136 wxMenu* fileMenu = new wxMenu;
137 fileMenu->Append(wxID_HTML_OPENFILE, _("&Open..."));
138 fileMenu->AppendSeparator();
139 fileMenu->Append(wxID_CLOSE, _("&Close"));
140
141 wxMenu* helpMenu = new wxMenu;
142 helpMenu->Append(wxID_ABOUT, _("&About"));
143 // Ensures we don't get an empty help menu
144 helpMenu->Append(wxID_HELP_CONTENTS, _("&About"));
145
146 menuBar->Append(fileMenu,_("&File"));
147 menuBar->Append(helpMenu,_("&Help"));
148 SetMenuBar(menuBar);
149 #endif
150
151 m_HtmlHelpWin->GetHtmlWindow()->SetRelatedFrame(this, m_TitleFormat);
152 #if wxUSE_STATUSBAR
153 m_HtmlHelpWin->GetHtmlWindow()->SetRelatedStatusBar(0);
154 #endif
155 return true;
156 }
157
158 wxHtmlHelpFrame::~wxHtmlHelpFrame()
159 {
160 }
161
162 void wxHtmlHelpFrame::SetTitleFormat(const wxString& format)
163 {
164 if (GetHelpWindow() && GetHelpWindow()->GetHtmlWindow())
165 GetHelpWindow()->GetHtmlWindow()->SetRelatedFrame(this, format);
166 m_TitleFormat = format;
167 }
168
169 /*
170 EVENT HANDLING :
171 */
172
173
174 void wxHtmlHelpFrame::OnActivate(wxActivateEvent& event)
175 {
176 // This saves one mouse click when using the
177 // wxHTML for context sensitive help systems
178 #ifndef __WXGTK__
179 // NB: wxActivateEvent is a bit broken in wxGTK
180 // and is sometimes sent when it should not be
181 if (event.GetActive() && m_HtmlHelpWin)
182 m_HtmlHelpWin->GetHtmlWindow()->SetFocus();
183 #endif
184
185 event.Skip();
186 }
187
188 void wxHtmlHelpFrame::OnCloseWindow(wxCloseEvent& evt)
189 {
190 if (!IsIconized())
191 {
192 GetSize(& (m_HtmlHelpWin->GetCfgData().w), &(m_HtmlHelpWin->GetCfgData().h));
193 GetPosition(& (m_HtmlHelpWin->GetCfgData().x), & (m_HtmlHelpWin->GetCfgData().y));
194 }
195
196 #ifdef __WXGTK__
197 if (IsGrabbed())
198 {
199 RemoveGrab();
200 }
201 #endif
202
203 if (m_HtmlHelpWin->GetSplitterWindow() && m_HtmlHelpWin->GetCfgData().navig_on)
204 m_HtmlHelpWin->GetCfgData().sashpos = m_HtmlHelpWin->GetSplitterWindow()->GetSashPosition();
205
206 if (m_helpController && wxDynamicCast(m_helpController, wxHtmlHelpController))
207 {
208 ((wxHtmlHelpController*) m_helpController)->OnCloseFrame(evt);
209 }
210
211 evt.Skip();
212 }
213
214 // Make the help controller's frame 'modal' if
215 // needed
216 void wxHtmlHelpFrame::AddGrabIfNeeded()
217 {
218 // So far, wxGTK only
219 #ifdef __WXGTK__
220 bool needGrab = false;
221
222 // Check if there are any modal windows present,
223 // in which case we need to add a grab.
224 for ( wxWindowList::iterator it = wxTopLevelWindows.begin();
225 it != wxTopLevelWindows.end();
226 ++it )
227 {
228 wxWindow *win = *it;
229 wxDialog *dialog = wxDynamicCast(win, wxDialog);
230
231 if (dialog && dialog->IsModal())
232 needGrab = true;
233 }
234
235 if (needGrab)
236 AddGrab();
237 #endif // __WXGTK__
238 }
239
240 #if wxUSE_CONFIG
241 // For compatibility
242 void wxHtmlHelpFrame::UseConfig(wxConfigBase *config, const wxString& rootPath)
243 {
244 if (m_HtmlHelpWin)
245 m_HtmlHelpWin->UseConfig(config, rootPath);
246 }
247 #endif // wxUSE_CONFIG
248
249 void wxHtmlHelpFrame::SetShouldPreventAppExit(bool enable)
250 {
251 m_shouldPreventAppExit = enable;
252 }
253
254 #ifdef __WXMAC__
255 void wxHtmlHelpFrame::OnClose(wxCommandEvent& WXUNUSED(event))
256 {
257 Close(true);
258 }
259
260 void wxHtmlHelpFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
261 {
262 wxMessageBox(wxT("wxWidgets HTML Help Viewer (c) 1998-2006, Vaclav Slavik et al"), wxT("HelpView"),
263 wxICON_INFORMATION|wxOK, this);
264 }
265 #endif
266
267 #endif // wxUSE_WXHTML_HELP