You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
216 lines
6.4 KiB
216 lines
6.4 KiB
/* |
|
Copyright 2006-2008 by Robert Knight <robertknight@gmail.com> |
|
|
|
This program is free software; you can redistribute it and/or modify |
|
it under the terms of the GNU General Public License as published by |
|
the Free Software Foundation; either version 2 of the License, or |
|
(at your option) any later version. |
|
|
|
This program 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 General Public License for more details. |
|
|
|
You should have received a copy of the GNU General Public License |
|
along with this program; if not, write to the Free Software |
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA |
|
02110-1301 USA. |
|
*/ |
|
|
|
#ifndef MAINWINDOW_H |
|
#define MAINWINDOW_H |
|
|
|
// Qt |
|
#include <QtCore/QPointer> |
|
|
|
// KDE |
|
#include <KXmlGuiWindow> |
|
#include <KUrl> |
|
|
|
// Konsole |
|
#include "Profile.h" |
|
|
|
class KAction; |
|
class KActionMenu; |
|
class KToggleAction; |
|
|
|
namespace Konsole |
|
{ |
|
class IncrementalSearchBar; |
|
class ViewManager; |
|
class ViewProperties; |
|
class Session; |
|
class SessionController; |
|
class ProfileList; |
|
class BookmarkHandler; |
|
|
|
/** |
|
* The main window. This contains the menus and an area which contains the terminal displays. |
|
* |
|
* The main window does not create the views or the container widgets which hold the views. |
|
* This is done by the ViewManager class. When a MainWindow is instantiated, it creates |
|
* a new ViewManager. The ViewManager can then be used to create new terminal displays |
|
* inside the window. |
|
* |
|
* Do not construct new main windows directly, use Application's newMainWindow() method. |
|
*/ |
|
class MainWindow : public KXmlGuiWindow |
|
{ |
|
Q_OBJECT |
|
|
|
public: |
|
/** |
|
* Constructs a new main window. Do not create new main windows directly, use Application's |
|
* newMainWindow() method instead. |
|
*/ |
|
MainWindow(); |
|
|
|
/** |
|
* Returns the view manager associated with this window. The view manager can be used to |
|
* create new views on particular session objects inside this window. |
|
*/ |
|
ViewManager* viewManager() const; |
|
|
|
/** |
|
* Create a new session. |
|
* |
|
* @param profile The profile to use to create the new session. |
|
* @param directory Initial working directory for the new session or empty |
|
* if the default working directory associated with the profile should be used. |
|
*/ |
|
Session* createSession(Profile::Ptr profile, const QString& directory); |
|
|
|
/** |
|
* create a new SSH session. |
|
* |
|
* @param profile The profile to use to create the new session. |
|
* @param url the URL representing the new SSH connection |
|
*/ |
|
Session* createSSHSession(Profile::Ptr profile, const KUrl& url); |
|
|
|
/** |
|
* create view for the specified session |
|
*/ |
|
void createView(Session* session); |
|
|
|
/** |
|
* Helper method to make this window get input focus |
|
*/ |
|
void setFocus(); |
|
|
|
/** |
|
* Set the initial visibility of the menubar. |
|
*/ |
|
void setMenuBarInitialVisibility(bool visible); |
|
|
|
void setNavigationVisibility(int visibility); |
|
void setNavigationPosition(int position); |
|
void setNavigationStyleSheet(const QString& stylesheet); |
|
void setNavigationStyleSheetFromFile(const KUrl& stylesheetfile); |
|
void setNavigationBehavior(int behavior); |
|
void setShowQuickButtons(bool show); |
|
|
|
signals: |
|
|
|
/** |
|
* Emitted by the main window to request the creation of a |
|
* new session in a new window. |
|
* |
|
* @param profile The profile to use to create the |
|
* first session in the new window. |
|
* @param directory Initial working directory for the new window or empty |
|
* if the default working directory associated with the profile should |
|
* be used. |
|
*/ |
|
void newWindowRequest(Profile::Ptr profile, |
|
const QString& directory); |
|
|
|
/** |
|
* Emitted when a view for one session is detached from this window |
|
*/ |
|
void viewDetached(Session* session); |
|
|
|
protected: |
|
// Reimplemented for internal reasons. |
|
virtual void showEvent(QShowEvent* event); |
|
|
|
// reimplemented from KMainWindow |
|
virtual bool queryClose(); |
|
virtual void saveProperties(KConfigGroup& group); |
|
virtual void readProperties(const KConfigGroup& group); |
|
virtual void saveGlobalProperties(KConfig* config); |
|
virtual void readGlobalProperties(KConfig* config); |
|
|
|
// reimplemented from QWidget |
|
virtual bool focusNextPrevChild(bool next); |
|
|
|
private slots: |
|
void newTab(); |
|
void cloneTab(); |
|
void newWindow(); |
|
void showManageProfilesDialog(); |
|
void activateMenuBar(); |
|
void showSettingsDialog(); |
|
void showShortcutsDialog(); |
|
void newFromProfile(Profile::Ptr profile); |
|
void activeViewChanged(SessionController* controller); |
|
void disconnectController(SessionController* controller); |
|
void activeViewTitleChanged(ViewProperties*); |
|
|
|
void profileListChanged(const QList<QAction*>& actions); |
|
void configureNotifications(); |
|
|
|
void updateWindowIcon(); |
|
void updateWindowCaption(); |
|
void openUrls(const QList<QUrl>& urls); |
|
|
|
// Sets the list of profiles to be displayed under the "New Tab" action |
|
void setProfileList(ProfileList* list); |
|
|
|
void applyKonsoleSettings(); |
|
|
|
void updateUseTransparency(); |
|
|
|
public slots: |
|
void viewFullScreen(bool fullScreen); |
|
|
|
private: |
|
void correctStandardShortcuts(); |
|
void rememberMenuAccelerators(); |
|
void removeMenuAccelerators(); |
|
void restoreMenuAccelerators(); |
|
void setupActions(); |
|
void setupMainWidget(); |
|
QString activeSessionDir() const; |
|
|
|
/** |
|
* Returns the search bar. |
|
* |
|
* This is a convenience method. The search bar is actually owned by |
|
* ViewManager, or more precisely, by ViewContainer. |
|
*/ |
|
IncrementalSearchBar* searchBar() const; |
|
|
|
/** |
|
* Returns the bookmark handler associated with this window. |
|
*/ |
|
BookmarkHandler* bookmarkHandler() const; |
|
|
|
// sets the active shortcuts of actions in 'dest' to the shortcuts of actions |
|
// with the same name in 'source' (see KAction::ActiveShortcut) |
|
static void syncActiveShortcuts(KActionCollection* dest, const KActionCollection* source); |
|
|
|
private: |
|
ViewManager* _viewManager; |
|
BookmarkHandler* _bookmarkHandler; |
|
KToggleAction* _toggleMenuBarAction; |
|
KActionMenu* _newTabMenuAction; |
|
|
|
QPointer<SessionController> _pluggedController; |
|
|
|
bool _menuBarInitialVisibility; |
|
bool _menuBarInitialVisibilityApplied; |
|
}; |
|
} |
|
|
|
#endif // MAINWINDOW_H
|
|
|