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
|
|
|
|
2016-03-18 07:55:01 +01:00
|
|
|
#pragma once
|
2008-12-02 12:01:29 +01:00
|
|
|
|
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 QUrl;
|
|
|
|
|
QT_END_NAMESPACE
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
namespace Core {
|
|
|
|
|
class SideBar;
|
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-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;
|
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
|
|
|
|
2016-09-09 15:37:01 +02:00
|
|
|
static HelpViewer *viewerForHelpViewerLocation(Core::HelpManager::HelpViewerLocation location);
|
2017-07-11 17:05:40 +02:00
|
|
|
static void showInHelpViewer(const QUrl &url, HelpViewer *viewer);
|
2016-09-09 15:37:01 +02:00
|
|
|
|
2014-05-02 16:54:28 +02:00
|
|
|
static HelpViewer *createHelpViewer(qreal zoom);
|
|
|
|
|
|
2016-06-28 23:07:19 +03:00
|
|
|
private:
|
2016-04-12 14:47:15 +02:00
|
|
|
void modeChanged(Core::Id mode, Core::Id old);
|
2010-03-30 17:44:28 +02:00
|
|
|
|
2018-01-17 16:06:13 +01:00
|
|
|
void requestContextHelp();
|
|
|
|
|
void showContextHelp(const QString &contextHelpId);
|
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);
|
2017-07-20 07:41:05 +02:00
|
|
|
void showLinksInCurrentViewer(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(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
|
|
|
|
2016-08-31 15:39:52 +02:00
|
|
|
void slotSystemInformation();
|
2010-08-25 11:40:44 +02:00
|
|
|
|
2010-03-16 15:28:31 +01:00
|
|
|
void resetFilter();
|
2016-09-09 15:37:01 +02:00
|
|
|
static void activateHelpMode();
|
|
|
|
|
static bool canShowHelpSideBySide();
|
2014-06-20 17:24:18 +02:00
|
|
|
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();
|
2017-07-11 17:05:40 +02:00
|
|
|
HelpViewer *helpModeHelpViewer();
|
2017-07-20 07:41:05 +02:00
|
|
|
HelpWidget *helpWidgetForWindow(QWidget *window);
|
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
|
|
|
|
2016-11-29 15:15:31 +01:00
|
|
|
HelpMode *m_mode = nullptr;
|
|
|
|
|
CentralWidget *m_centralWidget = nullptr;
|
|
|
|
|
HelpWidget *m_rightPaneSideBarWidget = nullptr;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2016-11-29 15:15:31 +01:00
|
|
|
DocSettingsPage *m_docSettingsPage = nullptr;
|
|
|
|
|
FilterSettingsPage *m_filterSettingsPage = nullptr;
|
|
|
|
|
SearchTaskHandler *m_searchTaskHandler = nullptr;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2016-11-29 15:15:31 +01:00
|
|
|
bool m_setupNeeded = true;
|
|
|
|
|
LocalHelpManager *m_helpManager = nullptr;
|
|
|
|
|
OpenPagesManager *m_openPagesManager = nullptr;
|
2010-03-30 17:44:28 +02:00
|
|
|
|
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
|