2012-10-02 09:12:39 +02:00
|
|
|
/****************************************************************************
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** This file is part of Qt Creator.
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** Commercial License Usage
|
|
|
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
|
|
|
** accordance with the commercial license agreement provided with the
|
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
2016-01-15 14:57:40 +01:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** GNU General Public License Usage
|
|
|
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
|
|
|
** General Public License version 3 as published by the Free Software
|
|
|
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
|
|
|
** included in the packaging of this file. Please review the following
|
|
|
|
|
** information to ensure the GNU General Public License requirements will
|
|
|
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
2010-12-17 16:01:08 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
****************************************************************************/
|
2010-03-30 17:44:28 +02:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#ifndef HELPPLUGIN_H
|
|
|
|
|
#define HELPPLUGIN_H
|
|
|
|
|
|
2014-06-18 17:42:01 +02:00
|
|
|
#include "helpwidget.h"
|
|
|
|
|
|
2014-06-20 17:24:18 +02:00
|
|
|
#include <coreplugin/helpmanager.h>
|
2014-06-18 17:42:01 +02:00
|
|
|
#include <coreplugin/icontext.h>
|
2008-12-02 12:01:29 +01:00
|
|
|
#include <extensionsystem/iplugin.h>
|
2014-06-18 17:42:01 +02:00
|
|
|
|
2012-02-15 10:42:41 +01:00
|
|
|
#include <QMap>
|
|
|
|
|
#include <QStringList>
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2012-07-17 16:37:01 +02:00
|
|
|
QT_BEGIN_NAMESPACE
|
|
|
|
|
class QAction;
|
|
|
|
|
class QMenu;
|
|
|
|
|
class QToolButton;
|
|
|
|
|
class QUrl;
|
|
|
|
|
QT_END_NAMESPACE
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
namespace Core {
|
|
|
|
|
class IMode;
|
2010-03-23 18:11:43 +01:00
|
|
|
class MiniSplitter;
|
2008-12-02 12:01:29 +01:00
|
|
|
class SideBar;
|
|
|
|
|
class SideBarItem;
|
2010-02-02 14:25:22 +01:00
|
|
|
} // Core
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2014-02-11 21:55:42 +02:00
|
|
|
namespace Utils { class StyledBar; }
|
2010-10-05 14:18:18 +02:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
namespace Help {
|
|
|
|
|
namespace Internal {
|
2010-02-02 14:25:22 +01:00
|
|
|
class CentralWidget;
|
2008-12-02 12:01:29 +01:00
|
|
|
class DocSettingsPage;
|
|
|
|
|
class FilterSettingsPage;
|
2010-03-16 14:47:27 +01:00
|
|
|
class GeneralSettingsPage;
|
2010-03-30 17:44:28 +02:00
|
|
|
class HelpMode;
|
|
|
|
|
class HelpViewer;
|
2010-06-11 13:11:37 +02:00
|
|
|
class LocalHelpManager;
|
2010-03-30 17:44:28 +02:00
|
|
|
class OpenPagesManager;
|
2008-12-02 12:01:29 +01:00
|
|
|
class SearchWidget;
|
2014-03-18 22:50:44 +02:00
|
|
|
class SearchTaskHandler;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
class HelpPlugin : public ExtensionSystem::IPlugin
|
|
|
|
|
{
|
|
|
|
|
Q_OBJECT
|
2012-02-21 16:52:28 +01:00
|
|
|
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QtCreatorPlugin" FILE "Help.json")
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
HelpPlugin();
|
|
|
|
|
virtual ~HelpPlugin();
|
|
|
|
|
|
2011-09-21 13:05:15 +02:00
|
|
|
bool initialize(const QStringList &arguments, QString *errorMessage);
|
2008-12-02 12:01:29 +01:00
|
|
|
void extensionsInitialized();
|
2010-07-13 13:36:47 +02:00
|
|
|
ShutdownFlag aboutToShutdown();
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2014-05-02 16:54:28 +02:00
|
|
|
static HelpViewer *createHelpViewer(qreal zoom);
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
private slots:
|
2010-07-21 14:54:02 +02:00
|
|
|
void modeChanged(Core::IMode *mode, Core::IMode *old);
|
2010-03-30 17:44:28 +02:00
|
|
|
|
2014-07-01 09:50:10 +02:00
|
|
|
void showContextHelp();
|
2008-12-02 12:01:29 +01:00
|
|
|
void activateIndex();
|
|
|
|
|
void activateContents();
|
2010-03-30 17:44:28 +02:00
|
|
|
|
2014-06-18 17:42:01 +02:00
|
|
|
void saveExternalWindowSettings();
|
2014-10-23 14:49:57 +02:00
|
|
|
void showLinkInHelpMode(const QUrl &source);
|
|
|
|
|
void showLinksInHelpMode(const QMap<QString, QUrl> &links, const QString &key);
|
2008-12-02 12:01:29 +01:00
|
|
|
void slotHideRightPane();
|
|
|
|
|
|
2009-06-02 16:30:56 +02:00
|
|
|
void updateSideBarSource();
|
|
|
|
|
void updateSideBarSource(const QUrl &newUrl);
|
|
|
|
|
|
2010-03-23 18:11:43 +01:00
|
|
|
void setupHelpEngineIfNeeded();
|
2009-06-25 17:16:16 +02:00
|
|
|
|
2014-06-04 13:41:32 +02:00
|
|
|
void highlightSearchTermsInContextHelp();
|
2014-06-20 17:24:18 +02:00
|
|
|
void handleHelpRequest(const QUrl &url, Core::HelpManager::HelpViewerLocation location);
|
2010-04-28 15:04:39 +02:00
|
|
|
|
2010-11-11 16:49:17 +01:00
|
|
|
void slotOpenSupportPage();
|
2011-07-26 18:38:27 +02:00
|
|
|
void slotReportBug();
|
2010-08-25 11:40:44 +02:00
|
|
|
|
2010-02-02 11:40:45 +01:00
|
|
|
private:
|
2010-03-16 15:28:31 +01:00
|
|
|
void resetFilter();
|
2009-01-28 13:57:42 +01:00
|
|
|
void activateHelpMode();
|
2014-06-20 17:24:18 +02:00
|
|
|
bool canShowHelpSideBySide() const;
|
|
|
|
|
HelpViewer *viewerForHelpViewerLocation(Core::HelpManager::HelpViewerLocation location);
|
|
|
|
|
HelpViewer *viewerForContextHelp();
|
2014-06-18 17:42:01 +02:00
|
|
|
HelpWidget *createHelpWidget(const Core::Context &context, HelpWidget::WidgetStyle style);
|
2010-03-23 18:11:43 +01:00
|
|
|
void createRightPaneContextViewer();
|
2014-06-18 17:42:01 +02:00
|
|
|
HelpViewer *externalHelpViewer();
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2010-08-25 16:18:52 +02:00
|
|
|
void doSetupIfNeeded();
|
2010-07-23 12:44:22 +02:00
|
|
|
|
2010-03-23 18:11:43 +01:00
|
|
|
private:
|
|
|
|
|
HelpMode *m_mode;
|
2010-02-02 14:25:22 +01:00
|
|
|
CentralWidget *m_centralWidget;
|
2014-06-17 18:14:37 +02:00
|
|
|
HelpWidget *m_rightPaneSideBarWidget;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
DocSettingsPage *m_docSettingsPage;
|
|
|
|
|
FilterSettingsPage *m_filterSettingsPage;
|
2014-03-18 22:50:44 +02:00
|
|
|
SearchTaskHandler *m_searchTaskHandler;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2014-10-01 17:52:57 +02:00
|
|
|
bool m_setupNeeded;
|
2010-06-11 13:11:37 +02:00
|
|
|
LocalHelpManager *m_helpManager;
|
2010-03-30 17:44:28 +02:00
|
|
|
OpenPagesManager *m_openPagesManager;
|
|
|
|
|
|
2014-06-04 13:41:32 +02:00
|
|
|
QString m_contextHelpHighlightId;
|
2010-07-23 16:36:08 +02:00
|
|
|
|
2014-06-18 17:42:01 +02:00
|
|
|
QPointer<HelpWidget> m_externalWindow;
|
|
|
|
|
QRect m_externalWindowState;
|
2008-12-02 12:01:29 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace Internal
|
|
|
|
|
} // namespace Help
|
|
|
|
|
|
|
|
|
|
#endif // HELPPLUGIN_H
|