2012-10-02 09:12:39 +02:00
|
|
|
/****************************************************************************
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2014-01-07 13:27:11 +01:00
|
|
|
** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
|
2012-10-02 09:12:39 +02:00
|
|
|
** Contact: http://www.qt-project.org/legal
|
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
|
|
|
|
|
** a written agreement between you and Digia. For licensing terms and
|
2014-10-01 13:21:18 +02:00
|
|
|
** conditions see http://www.qt.io/licensing. For further information
|
|
|
|
|
** use the contact form at http://www.qt.io/contact-us.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** GNU Lesser General Public License Usage
|
2012-10-02 09:12:39 +02:00
|
|
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
2014-10-01 13:21:18 +02:00
|
|
|
** General Public License version 2.1 or version 3 as published by the Free
|
|
|
|
|
** Software Foundation and appearing in the file LICENSE.LGPLv21 and
|
|
|
|
|
** LICENSE.LGPLv3 included in the packaging of this file. Please review the
|
|
|
|
|
** following information to ensure the GNU Lesser General Public License
|
|
|
|
|
** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
|
|
|
|
|
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** In addition, as a special exception, Digia gives you certain additional
|
|
|
|
|
** rights. These rights are described in the Digia Qt LGPL Exception
|
2010-12-17 16:01:08 +01:00
|
|
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
|
|
|
|
**
|
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:
|
2012-09-18 10:05:09 +02:00
|
|
|
void unregisterOldQtCreatorDocumentation();
|
|
|
|
|
|
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();
|
2008-12-02 12:01:29 +01:00
|
|
|
void switchToHelpMode(const QUrl &source);
|
|
|
|
|
void slotHideRightPane();
|
|
|
|
|
|
2009-06-02 16:30:56 +02:00
|
|
|
void updateSideBarSource();
|
|
|
|
|
void updateSideBarSource(const QUrl &newUrl);
|
|
|
|
|
|
2009-06-25 17:16:16 +02:00
|
|
|
void fontChanged();
|
2010-07-23 16:36:08 +02:00
|
|
|
|
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();
|
2014-06-20 17:24:18 +02:00
|
|
|
Core::HelpManager::HelpViewerLocation contextHelpOption() const;
|
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;
|
2010-03-23 18:11:43 +01:00
|
|
|
GeneralSettingsPage *m_generalSettingsPage;
|
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
|