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
8 // Copyright: (c) Harm van der Heijden and Vaclav Slavik
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 // For compilers that support precompilation, includes "wx.h"
14 #include "wx/wxprec.h"
23 #include "wx/object.h"
24 #include "wx/dynarray.h"
28 #include "wx/stream.h"
33 #include "wx/bmpbuttn.h"
34 #include "wx/statbox.h"
35 #include "wx/radiobox.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"
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"
59 IMPLEMENT_DYNAMIC_CLASS(wxHtmlHelpFrame
, wxFrame
)
61 BEGIN_EVENT_TABLE(wxHtmlHelpFrame
, wxFrame
)
62 EVT_ACTIVATE(wxHtmlHelpFrame::OnActivate
)
63 EVT_CLOSE(wxHtmlHelpFrame::OnCloseWindow
)
65 EVT_MENU(wxID_CLOSE
, wxHtmlHelpFrame::OnClose
)
66 EVT_MENU(wxID_ABOUT
, wxHtmlHelpFrame::OnAbout
)
67 EVT_MENU(wxID_HELP_CONTENTS
, wxHtmlHelpFrame::OnAbout
)
71 wxHtmlHelpFrame::wxHtmlHelpFrame(wxWindow
* parent
, wxWindowID id
, const wxString
& title
,
72 int style
, wxHtmlHelpData
* data
,
73 wxConfigBase
*config
, const wxString
& rootpath
)
76 Create(parent
, id
, title
, style
, config
, rootpath
);
79 void wxHtmlHelpFrame::Init(wxHtmlHelpData
* data
)
81 // Simply pass the pointer on to the help window
84 m_helpController
= (wxHtmlHelpController
*) NULL
;
87 // Create: builds the GUI components.
88 bool wxHtmlHelpFrame::Create(wxWindow
* parent
, wxWindowID id
,
89 const wxString
& WXUNUSED(title
), int style
,
90 wxConfigBase
*config
, const wxString
& rootpath
)
92 m_HtmlHelpWin
= new wxHtmlHelpWindow(m_Data
);
94 m_HtmlHelpWin
->UseConfig(config
, rootpath
);
96 wxFrame::Create(parent
, id
, _("Help"),
97 wxPoint(m_HtmlHelpWin
->GetCfgData().x
, m_HtmlHelpWin
->GetCfgData().y
),
98 wxSize(m_HtmlHelpWin
->GetCfgData().w
, m_HtmlHelpWin
->GetCfgData().h
),
99 wxDEFAULT_FRAME_STYLE
, wxT("wxHtmlHelp"));
103 m_HtmlHelpWin
->Create(this, wxID_ANY
, wxDefaultPosition
, wxDefaultSize
,
104 wxTAB_TRAVERSAL
|wxNO_BORDER
, style
);
106 GetPosition(& (m_HtmlHelpWin
->GetCfgData().x
), & (m_HtmlHelpWin
->GetCfgData()).y
);
108 SetIcon(wxArtProvider::GetIcon(wxART_HELP
, wxART_HELP_BROWSER
));
110 // On the Mac, each modeless frame must have a menubar.
111 // TODO: add more menu items, and perhaps add a style to show
112 // the menubar: compulsory on the Mac, optional elsewhere.
114 wxMenuBar
* menuBar
= new wxMenuBar
;
116 wxMenu
* fileMenu
= new wxMenu
;
117 fileMenu
->Append(wxID_HTML_OPENFILE
, _("&Open..."));
118 fileMenu
->AppendSeparator();
119 fileMenu
->Append(wxID_CLOSE
, _("&Close"));
121 wxMenu
* helpMenu
= new wxMenu
;
122 helpMenu
->Append(wxID_ABOUT
, _("&About..."));
123 // Ensures we don't get an empty help menu
124 helpMenu
->Append(wxID_HELP_CONTENTS
, _("&About..."));
126 menuBar
->Append(fileMenu
,_("&File"));
127 menuBar
->Append(helpMenu
,_("&Help"));
131 m_HtmlHelpWin
->GetHtmlWindow()->SetRelatedFrame(this, m_TitleFormat
);
133 m_HtmlHelpWin
->GetHtmlWindow()->SetRelatedStatusBar(0);
138 wxHtmlHelpFrame::~wxHtmlHelpFrame()
142 void wxHtmlHelpFrame::SetTitleFormat(const wxString
& format
)
144 if (GetHelpWindow() && GetHelpWindow()->GetHtmlWindow())
145 GetHelpWindow()->GetHtmlWindow()->SetRelatedFrame(this, format
);
146 m_TitleFormat
= format
;
154 void wxHtmlHelpFrame::OnActivate(wxActivateEvent
& event
)
156 // This saves one mouse click when using the
157 // wxHTML for context sensitive help systems
159 // NB: wxActivateEvent is a bit broken in wxGTK
160 // and is sometimes sent when it should not be
161 if (event
.GetActive() && m_HtmlHelpWin
)
162 m_HtmlHelpWin
->GetHtmlWindow()->SetFocus();
168 void wxHtmlHelpFrame::OnCloseWindow(wxCloseEvent
& evt
)
172 GetSize(& (m_HtmlHelpWin
->GetCfgData().w
), &(m_HtmlHelpWin
->GetCfgData().h
));
173 GetPosition(& (m_HtmlHelpWin
->GetCfgData().x
), & (m_HtmlHelpWin
->GetCfgData().y
));
183 if (m_HtmlHelpWin
->GetSplitterWindow() && m_HtmlHelpWin
->GetCfgData().navig_on
)
184 m_HtmlHelpWin
->GetCfgData().sashpos
= m_HtmlHelpWin
->GetSplitterWindow()->GetSashPosition();
186 if (m_helpController
&& m_helpController
->IsKindOf(CLASSINFO(wxHtmlHelpController
)))
188 ((wxHtmlHelpController
*) m_helpController
)->OnCloseFrame(evt
);
194 // Make the help controller's frame 'modal' if
196 void wxHtmlHelpFrame::AddGrabIfNeeded()
198 // So far, wxGTK only
200 bool needGrab
= false;
202 // Check if there are any modal windows present,
203 // in which case we need to add a grab.
204 for ( wxWindowList::iterator it
= wxTopLevelWindows
.begin();
205 it
!= wxTopLevelWindows
.end();
209 wxDialog
*dialog
= wxDynamicCast(win
, wxDialog
);
211 if (dialog
&& dialog
->IsModal())
221 void wxHtmlHelpFrame::UseConfig(wxConfigBase
*config
, const wxString
& rootPath
)
224 m_HtmlHelpWin
->UseConfig(config
, rootPath
);
228 void wxHtmlHelpFrame::OnClose(wxCommandEvent
& event
)
233 void wxHtmlHelpFrame::OnAbout(wxCommandEvent
& event
)
235 wxMessageBox(wxT("wxWidgets HTML Help Viewer (c) 1998-2006, Vaclav Slavik et al"), wxT("HelpView"),
236 wxICON_INFORMATION
|wxOK
, this);
240 #endif // wxUSE_WXHTML_HELP