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
  // 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]));

    // re-register documentation if location changed
Matthias Möller's avatar
Matthias Möller committed
113
    if (helpFiles.indexOf(registredFilename) != -1)
114
115
116
117
      documentationFiles.push_back( registredFilename );
    else
      helpEngine_->unregisterDocumentation(registeredNamespaces[i]);
  }
118
119

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

    // 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;
129
      std::cerr << helpFiles[i].toStdString() << " :" << helpEngine_->error().toStdString() << std::endl;
130
131
132
    }

  }
133

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

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

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

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

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

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

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

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

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


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

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

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

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

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

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

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

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

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

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

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

  QStringList tmp = helpEngine_->registeredDocumentations ();

197
  #ifdef DEBUG_HELP_CONTENTS
198
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
  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;
    }


  }
224
  #endif
225

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

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

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

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

245
246
void HelpWidget::startSearch() {

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

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

252
  homeSite_ = _homeSite;
253
254
}

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

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

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

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

  //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 );
274
275
276
277
}

void HelpWidget::goForward() {

278
  textWindow_->forward();
279

280
  tabWidget_->setCurrentIndex(homeIndex_);
281

282
  updateButtons();
283
284
285
286
}

void HelpWidget::goBack() {

287
  textWindow_->backward();
288

289
  tabWidget_->setCurrentIndex(homeIndex_);
290

291
  updateButtons();
292
293
}

294
295
void HelpWidget::goHome() {

296
  textWindow_->open(homeSite_);
297

298
  tabWidget_->setCurrentIndex(homeIndex_);
299

300
  updateButtons();
301
302
}

303
304
void HelpWidget::updateButtons() {

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

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

318
void HelpWidget::showSearchWidget() {
319

320
  searchWidget_->show();
321
}
322

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

325
  searchWidget_->hide();
326

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

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

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

HelpWidget::~HelpWidget() {

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