helpWidget.cc 11.3 KB
Newer Older
1
/*===========================================================================*\
Jan Möbius's avatar
Jan Möbius committed
2
3
*                                                                            *
*                              OpenFlipper                                   *
Jan Möbius's avatar
Jan Möbius committed
4
*      Copyright (C) 2001-2011 by Computer Graphics Group, RWTH Aachen       *
Jan Möbius's avatar
Jan Möbius committed
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
*                           www.openflipper.org                              *
*                                                                            *
*--------------------------------------------------------------------------- *
*  This file is part of OpenFlipper.                                         *
*                                                                            *
*  OpenFlipper is free software: you can redistribute it and/or modify       *
*  it under the terms of the GNU Lesser General Public License as            *
*  published by the Free Software Foundation, either version 3 of            *
*  the License, or (at your option) any later version with the               *
*  following exceptions:                                                     *
*                                                                            *
*  If other files instantiate templates or use macros                        *
*  or inline functions from this file, or you compile this file and          *
*  link it with other files to produce an executable, this file does         *
*  not by itself cause the resulting executable to be covered by the         *
*  GNU Lesser General Public License. This exception does not however        *
*  invalidate any other reasons why the executable file might be             *
*  covered by the GNU Lesser General Public License.                         *
*                                                                            *
*  OpenFlipper is distributed in the hope that it will be useful,            *
*  but WITHOUT ANY WARRANTY; without even the implied warranty of            *
*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the             *
*  GNU Lesser General Public License for more details.                       *
*                                                                            *
*  You should have received a copy of the GNU LesserGeneral Public           *
*  License along with OpenFlipper. If not,                                   *
*  see <http://www.gnu.org/licenses/>.                                       *
*                                                                            *
33
34
35
\*===========================================================================*/

/*===========================================================================*\
Jan Möbius's avatar
Jan Möbius committed
36
37
38
39
40
*                                                                            *
*   $Revision$                                                       *
*   $LastChangedBy$                                                *
*   $Date$                     *
*                                                                            *
41
42
43
\*===========================================================================*/


44
45
46
47
48
49
50
51
52
53
54
55
56
57
/*
 * helpWidget.cc
 *
 *  Created on: Apr 7, 2009
 *      Author: kremer
 */

#include "helpWidget.hh"

#include <OpenFlipper/common/GlobalOptions.hh>

#include <iostream>

#include <QTextStream>
58
#include <QDir>
59

Jan Möbius's avatar
Typo    
Jan Möbius committed
60
//#define DEBUG_HELP_CONTENTS
61

62
HelpWidget::HelpWidget(QWidget* parent, const QString& _homeSite /*=""*/, const bool _loadHomeSite /*= true*/)
63
64
65
66
67
68
  : QMainWindow(parent),
  searchWidget_(0),
  tabWidget_(0),
  textWindow_(0),
  helpEngine_(0),
  searchEngine_(0) {
69

70
  setupUi(this);
71

72
  homeSite_ = _homeSite;
73

74
75
76
77
78
  QString filename = QString( OpenFlipper::Options::configDirStr() );
  filename += OpenFlipper::Options::dirSeparator();
  filename += "Help.qhc";
    
  QDir helpDir = QDir(OpenFlipper::Options::helpDirStr());
79

80
  QString iconPath = QString(OpenFlipper::Options::iconDirStr())+QString(OpenFlipper::Options::dirSeparator());
81

82
83
84
85
86
  // Set Buttons
  backButton_->setIcon(QIcon(iconPath+"arrow-left.png"));
  forwardButton_->setIcon(QIcon(iconPath+"arrow-right.png"));
  homeButton_->setIcon(QIcon(iconPath+"go-home.png"));
  searchButton_->setIcon(QIcon(iconPath+"edit-find.png"));
87

88
  tabWidget_ = new QTabWidget(this);
89

90
91
  // Generate the help engine. The filename is in the users home directory and
  // contains all registered help resources.
92
93
94
95
  helpEngine_ = new QHelpEngine(filename, this);
  
  helpEngine_->setupData();
  
96
97
98
99
100
  // Get all currently registered nameSpaces
  QStringList registeredNamespaces =helpEngine_->registeredDocumentations();

  QStringList documentationFiles;

101
102
  // Get a list of all loaded documentation files from the namespaces
  QStringList helpFiles = helpDir.entryList(QStringList("*.qch"),QDir::Files);
103

104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
  // Write absolute path into filenames
  for (QStringList::iterator iter = helpFiles.begin(); iter != helpFiles.end(); ++iter)
    *iter = helpDir.path()+ OpenFlipper::Options::dirSeparator() + *iter;

  for ( int i = 0; i < registeredNamespaces.size() ; ++i)
  {
    QString registredFilename (helpEngine_->documentationFileName(registeredNamespaces[i]));
    QStringList::iterator iter = std::find(helpFiles.begin(),helpFiles.end(),registredFilename);

    // re-register documentation if location changed
    if (iter != helpFiles.end())
      documentationFiles.push_back( registredFilename );
    else
      helpEngine_->unregisterDocumentation(registeredNamespaces[i]);
  }
119
120

  for ( int i = 0 ; i < helpFiles.size() ; ++i ) {
121
    const QString filename = helpFiles[i];
122
123
124
125
126
127
128
129

    // Don't register files twice (stored between multiple OpenFlipper executions)
    if (documentationFiles.contains(filename))
      continue;

    // Try to register the file
    if ( !helpEngine_->registerDocumentation( filename ) ) {
      std::cerr << "Error when trying to register file " << filename.toStdString() << std::endl;
130
      std::cerr << helpFiles[i].toStdString() << " :" << helpEngine_->error().toStdString() << std::endl;
131
132
133
    }

  }
134

135
  searchEngine_ = new QHelpSearchEngine(helpEngine_, this);
136

137
  textWindow_ = new HelpBrowser(helpEngine_, this);
138

139
  homeIndex_ = tabWidget_->addTab(textWindow_, tr("Home"));
140

141
142
  gridLayout_->addWidget(helpEngine_->contentWidget(), 1, 0);
  gridLayout_->addWidget(tabWidget_, 1, 1);
143

144
145
  gridLayout_->setColumnStretch(0, 1);
  gridLayout_->setColumnStretch(1, 3);
146

147
148
149
  // Search popup at bottom of window
  searchWidget_ = new QDockWidget(tr("Search results"), this);
  searchWidget_->setFeatures( QDockWidget::DockWidgetClosable );
150

151
  searchWidget_->resize(this->size().width(), floor( double(this->size().height() / 3)) );
152

153
154
  searchWidget_->setWidget(searchEngine_->queryWidget());
  //searchWidget_->setWidget(results_);
155

156
157
  searchWidget_->hide();
  addDockWidget(Qt::BottomDockWidgetArea, searchWidget_);
158
159


160
161
162
  // Entry in tree view has been clicked
  connect(helpEngine_->contentWidget(), SIGNAL(linkActivated(const QUrl&)),
          this, SLOT(linkActivated(const QUrl&)));
163

164
165
  // Search button
  connect(searchButton_, SIGNAL(clicked()), this, SLOT(showSearchWidget()));
166

167
168
  // Search button
  connect(searchEngine_->queryWidget(), SIGNAL(search()), this, SLOT(startSearch()));
169

170
171
  // Show results if search is finished
  connect(searchEngine_, SIGNAL(searchingFinished(int)), this, SLOT(showResults(int)));
172

173
174
175
  // Show results if search is finished
  connect(searchEngine_->resultWidget(), SIGNAL(requestShowLink(const QUrl&)),
              this, SLOT(showFoundSite(const QUrl&)));
176

177
178
  // Back button
  connect(backButton_, SIGNAL(clicked()), this, SLOT(goBack()));
179

180
181
  // Forward button
  connect(forwardButton_, SIGNAL(clicked()), this, SLOT(goForward()));
182

183
184
  // Forward button
  connect(homeButton_, SIGNAL(clicked()), this, SLOT(goHome()));
185

186
  // Source has been reloaded, so the buttons need an update and the modelview
187
  connect(textWindow_, SIGNAL(sourceChanged(const QUrl&)), this, SLOT(update(const QUrl&)));
188

189
190
191
  // the history has changed, so the buttons need an update
  connect(textWindow_, SIGNAL(historyChanged(const QUrl&)), this, SLOT(updateButtons()));

192
  // Register documentation
193
194
195
196
197
  // Seems to be an unneeded call!
  //helpEngine_->registerDocumentation(filename);

  QStringList tmp = helpEngine_->registeredDocumentations ();

198
  #ifdef DEBUG_HELP_CONTENTS
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
  for ( int i = 0 ; i < tmp.size(); ++i) {
    std::cerr << "=========================================================================================" << std::endl;
    std::cerr << "Registered namespace: " << tmp[i].toStdString() << std::endl;
    std::cerr << "From file : " << helpEngine_->documentationFileName(tmp[i]).toStdString() << std::endl;


    QList<QStringList> filterAttribs = helpEngine_->filterAttributeSets (tmp[i]);
//    std::cerr << "Filter attributes:" << std::endl;
//    for ( int j = 0 ; j < filterAttribs.size(); ++j) {
//      for ( int k = 0 ; k < filterAttribs[j].size(); ++k) {
//        std::cerr <<  filterAttribs[j][k].toStdString() << std::endl;
//      }
//    }

    // Print a list of all files included in this help file
    if ( !filterAttribs.empty() ) {
      QList<QUrl> list = helpEngine_->files ( tmp[i], filterAttribs[0]);
      for ( int j = 0 ; j < list.size(); ++j) {
        std::cerr << list[j].toString().toStdString() << std::endl;
      }
    } else {
      std::cerr << "Error, empty filter! Unable to get list of included files." << std::endl;
    }


  }
225
  #endif
226

227
228
229
230
231
  if (_loadHomeSite)
  {
    // Load main page
    textWindow_->open(QUrl(homeSite_));
  }
232
233
}

234
235
236
237
238
239
void HelpWidget::activateLink(const QUrl& _url)
{
	//open and show the url
	linkActivated(_url);
}

240
241
void HelpWidget::linkActivated(const QUrl& _url) {

242
243
  textWindow_->open(_url);
  tabWidget_->setCurrentIndex(homeIndex_);
244
245
}

246
247
void HelpWidget::startSearch() {

248
  searchEngine_->search(searchEngine_->queryWidget()->query());
249
250
251
252
}

void HelpWidget::setHomeSite(const QString& _homeSite) {

253
  homeSite_ = _homeSite;
254
255
}

256
257
void HelpWidget::showFoundSite(const QUrl& _url) {

258
259
  textWindow_->open(_url);
  tabWidget_->setCurrentIndex(homeIndex_);
260
261
}

262
void HelpWidget::update(const QUrl&  _url ) {
263

264
  updateButtons();
265
266
267
268
269
270
271
272
273
274

  //search for the entry and select the item in the contentWidget
  //in our case, it is the treeView on the left side
  QUrl newUrl = textWindow_->resolveUrl(_url);
  //search for the selected url
  QModelIndex modelIndex = helpEngine_->contentWidget()->indexOf(newUrl);

  //select this url in content widget
  if (modelIndex.isValid())
    helpEngine_->contentWidget()->setCurrentIndex( modelIndex );
275
276
277
278
}

void HelpWidget::goForward() {

279
  textWindow_->forward();
280

281
  tabWidget_->setCurrentIndex(homeIndex_);
282

283
  updateButtons();
284
285
286
287
}

void HelpWidget::goBack() {

288
  textWindow_->backward();
289

290
  tabWidget_->setCurrentIndex(homeIndex_);
291

292
  updateButtons();
293
294
}

295
296
void HelpWidget::goHome() {

297
  textWindow_->open(homeSite_);
298

299
  tabWidget_->setCurrentIndex(homeIndex_);
300

301
  updateButtons();
302
303
}

304
305
void HelpWidget::updateButtons() {

306
307
308
309
310
311
312
313
314
315
316
  if(!textWindow_->isBackwardAvailable()) {
          backButton_->setEnabled(false);
  } else {
          backButton_->setEnabled(true);
  }

  if(!textWindow_->isForwardAvailable()) {
          forwardButton_->setEnabled(false);
  } else {
          forwardButton_->setEnabled(true);
  }
317
318
}

319
void HelpWidget::showSearchWidget() {
320

321
  searchWidget_->show();
322
}
323

324
void HelpWidget::showResults(int /*_hits*/) {
325

326
  searchWidget_->hide();
327

328
329
  int resultsTabIndex_ = tabWidget_->addTab(searchEngine_->resultWidget(), tr("Results") );
  tabWidget_->setCurrentIndex(resultsTabIndex_);
330
331
}

Jan Möbius's avatar
Jan Möbius committed
332
void HelpWidget::openFoundSite(QListWidgetItem* /*_item*/) {
333
334

}
Mike Kremer's avatar
Mike Kremer committed
335
336
337

HelpWidget::~HelpWidget() {

338
339
  delete searchWidget_;
  delete textWindow_;
Mike Kremer's avatar
Mike Kremer committed
340
}