1 ///////////////////////////////////////////////////////////////////////////// 
   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 #ifndef _WX_HELPFRM_H_ 
  13 #define _WX_HELPFRM_H_ 
  23 #include "wx/html/helpdata.h" 
  24 #include "wx/window.h" 
  26 #include "wx/config.h" 
  27 #include "wx/splitter.h" 
  28 #include "wx/notebook.h" 
  29 #include "wx/listbox.h" 
  30 #include "wx/choice.h" 
  31 #include "wx/combobox.h" 
  32 #include "wx/checkbox.h" 
  33 #include "wx/stattext.h" 
  34 #include "wx/html/htmlwin.h" 
  35 #include "wx/html/htmprint.h" 
  38 // style flags for the Help Frame 
  39 #define wxHF_TOOLBAR      0x0001 
  40 #define wxHF_CONTENTS     0x0002 
  41 #define wxHF_INDEX        0x0004 
  42 #define wxHF_SEARCH       0x0008 
  43 #define wxHF_BOOKMARKS    0x0010 
  44 #define wxHF_OPENFILES    0x0020 
  45 #define wxHF_PRINT        0x0040 
  46 #define wxHF_DEFAULTSTYLE (wxHF_TOOLBAR | wxHF_CONTENTS | wxHF_INDEX | wxHF_SEARCH | wxHF_BOOKMARKS | wxHF_PRINT) 
  52     wxID_HTML_PANEL 
= wxID_HIGHEST 
+ 1, 
  61     wxID_HTML_BOOKMARKSLIST
, 
  62     wxID_HTML_BOOKMARKSADD
, 
  63     wxID_HTML_BOOKMARKSREMOVE
, 
  68     wxID_HTML_INDEXBUTTON
, 
  69     wxID_HTML_INDEXBUTTONALL
, 
  74     wxID_HTML_SEARCHBUTTON
, 
  75     wxID_HTML_SEARCHCHOICE
, 
  77     wxID_HTML_HELPFRAME 
// the id of wxHtmlHelpController's helpframe 
  92 class WXDLLEXPORT wxHtmlHelpFrame 
: public wxFrame
 
  94         DECLARE_DYNAMIC_CLASS(wxHtmlHelpFrame
) 
  97         wxHtmlHelpFrame(wxHtmlHelpData
* data 
= NULL
) { Init(data
); } 
  98         wxHtmlHelpFrame(wxWindow
* parent
, int wxWindowID
, 
  99                         const wxString
& title 
= wxEmptyString
, 
 100                         int style 
= wxHF_DEFAULTSTYLE
, wxHtmlHelpData
* data 
= NULL
); 
 101         bool Create(wxWindow
* parent
, wxWindowID id
, const wxString
& title 
= wxEmptyString
, 
 102                     int style 
= wxHF_DEFAULTSTYLE
); 
 105         wxHtmlHelpData
* GetData() { return m_Data
; } 
 107         void SetTitleFormat(const wxString
& format
); 
 108         // Sets format of title of the frame. Must contain exactly one "%s" 
 109         // (for title of displayed HTML page) 
 111         bool Display(const wxString
& x
); 
 112         // Displays page x. If not found it will offect the user a choice of 
 114         // Looking for the page runs in these steps: 
 115         // 1. try to locate file named x (if x is for example "doc/howto.htm") 
 116         // 2. try to open starting page of book x 
 117         // 3. try to find x in contents (if x is for example "How To ...") 
 118         // 4. try to find x in index (if x is for example "How To ...") 
 119         bool Display(const int id
); 
 120         // Alternative version that works with numeric ID. 
 121         // (uses extension to MS format, <param name="ID" value=id>, see docs) 
 123         bool DisplayContents(); 
 124         // Displays help window and focuses contents. 
 127         // Displays help window and focuses index. 
 129         bool KeywordSearch(const wxString
& keyword
); 
 130         // Searches for keyword. Returns TRUE and display page if found, return 
 132         // Syntax of keyword is Altavista-like: 
 133         // * words are separated by spaces 
 134         //   (but "\"hello world\"" is only one world "hello world") 
 135         // * word may be pretended by + or - 
 136         //   (+ : page must contain the word ; - : page can't contain the word) 
 137         // * if there is no + or - before the word, + is default 
 139         void UseConfig(wxConfigBase 
*config
, const wxString
& rootpath 
= wxEmptyString
) 
 142                 m_ConfigRoot 
= rootpath
; 
 143                 ReadCustomization(config
, rootpath
); 
 146         void ReadCustomization(wxConfigBase 
*cfg
, const wxString
& path 
= wxEmptyString
); 
 147         // saves custom settings into cfg config. it will use the path 'path' 
 148         // if given, otherwise it will save info into currently selected path. 
 149         // saved values : things set by SetFonts, SetBorders. 
 150         void WriteCustomization(wxConfigBase 
*cfg
, const wxString
& path 
= wxEmptyString
); 
 153         void NotifyPageChanged(); 
 154         // call this to let wxHtmlHelpFrame know page changed 
 157         void Init(wxHtmlHelpData
* data 
= NULL
); 
 160         // Refreshes Contents and Index tabs 
 162         void CreateContents(); 
 163         // Adds items to m_Contents tree control 
 166         // Adds items to m_IndexList 
 169         // Add books to search choice panel 
 171         virtual void AddToolbarButtons(wxToolBar 
*toolBar
, int style
); 
 172         // Add custom buttons to toolbar 
 174         virtual void OptionsDialog(); 
 175         // Displays options dialog (fonts etc.) 
 177         void OnToolbar(wxCommandEvent
& event
); 
 178         void OnContentsSel(wxTreeEvent
& event
); 
 179         void OnIndexSel(wxCommandEvent
& event
); 
 180         void OnIndexFind(wxCommandEvent
& event
); 
 181         void OnIndexAll(wxCommandEvent
& event
); 
 182         void OnSearchSel(wxCommandEvent
& event
); 
 183         void OnSearch(wxCommandEvent
& event
); 
 184         void OnBookmarksSel(wxCommandEvent
& event
); 
 185         void OnCloseWindow(wxCloseEvent
& event
); 
 196         wxHtmlHelpData
* m_Data
; 
 197         bool m_DataCreated
;  // m_Data created by frame, or supplied? 
 198         wxString m_TitleFormat
;  // title of the help frame 
 199         // below are various pointers to GUI components 
 200         wxHtmlWindow 
*m_HtmlWin
; 
 201         wxSplitterWindow 
*m_Splitter
; 
 202         wxNotebook 
*m_NavigPan
; 
 203         wxTreeCtrl 
*m_ContentsBox
; 
 204         wxImageList 
*m_ContentsImageList
; 
 205         wxTextCtrl 
*m_IndexText
; 
 206         wxButton 
*m_IndexButton
; 
 207         wxButton 
*m_IndexButtonAll
; 
 208         wxListBox 
*m_IndexList
; 
 209         wxTextCtrl 
*m_SearchText
; 
 210         wxButton 
*m_SearchButton
; 
 211         wxListBox 
*m_SearchList
; 
 212         wxChoice 
*m_SearchChoice
; 
 213         wxStaticText 
*m_IndexCountInfo
; 
 214         wxCheckBox 
*m_SearchCaseSensitive
; 
 215         wxCheckBox 
*m_SearchWholeWords
; 
 217         wxComboBox 
*m_Bookmarks
; 
 218         wxArrayString m_BookmarksNames
, m_BookmarksPages
; 
 220         wxHtmlHelpFrameCfg m_Cfg
; 
 222         wxConfigBase 
*m_Config
; 
 223         wxString m_ConfigRoot
; 
 225         // pagenumbers of controls in notebook (usually 0,1,2) 
 230         // lists of available fonts (used in options dialog) 
 231         wxArrayString 
*m_NormalFonts
, *m_FixedFonts
; 
 232         int m_FontSize
; // 0,1,2 = small,medium,big 
 233         wxString m_NormalFace
, m_FixedFace
; 
 235         bool m_UpdateContents
; 
 237 #if wxUSE_PRINTING_ARCHITECTURE 
 238         wxHtmlEasyPrinting 
*m_Printer
; 
 240         wxHashTable 
*m_PagesHash
; 
 242         DECLARE_EVENT_TABLE()