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