/*************************************************************************** * Copyright (C) 2002 by Wilco Greven * * Copyright (C) 2003 by Benjamin Meyer * * Copyright (C) 2003 by Laurent Montel * * Copyright (C) 2003 by Luboš Luňák * * Copyright (C) 2004 by Christophe Devriese * * * * Copyright (C) 2004 by Albert Astals Cid * * * * 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. * ***************************************************************************/ #ifndef _OKULAR_SHELL_H_ #define _OKULAR_SHELL_H_ #include #include #include class KRecentFilesAction; class KToggleAction; class KTabWidget; class KPluginFactory; class KDocumentViewer; class Part; /** * This is the application "Shell". It has a menubar and a toolbar * but relies on the "Part" to do all the real work. * * @short Application Shell * @author Wilco Greven * @version 0.1 */ class Shell : public KParts::MainWindow { Q_OBJECT Q_CLASSINFO("D-Bus Interface", "org.kde.okular") friend class MainShellTest; public: /** * Constructor */ explicit Shell( const QString &serializedOptions = QString() ); /** * Default Destructor */ virtual ~Shell(); QSize sizeHint() const; /** * Returns false if Okular component wasn't found **/ bool isValid() const; public slots: void slotQuit(); Q_SCRIPTABLE void tryRaise(); Q_SCRIPTABLE bool openDocument( const QString& url, const QString &serializedOptions = QString() ); Q_SCRIPTABLE bool canOpenDocs( int numDocs, int desktop ); protected: /** * This method is called when it is time for the app to save its * properties for session management purposes. */ void saveProperties(KConfigGroup&); /** * This method is called when this app is restored. The KConfig * object points to the session management config file that was saved * with @ref saveProperties */ void readProperties(const KConfigGroup&); void readSettings(); void writeSettings(); void setFullScreen( bool ); bool queryClose(); void showEvent(QShowEvent *event); private slots: void fileOpen(); void slotUpdateFullScreen(); void slotShowMenubar(); void openUrl( const KUrl & url, const QString &serializedOptions = QString() ); void showOpenRecentMenu(); void closeUrl(); void print(); void setPrintEnabled( bool enabled ); void setCloseEnabled( bool enabled ); void setTabIcon( KMimeType::Ptr mimeType ); void handleDroppedUrls( const KUrl::List& urls ); // Tab event handlers void setActiveTab( int tab ); void closeTab( int tab ); void activateNextTab(); void activatePrevTab(); void testTabDrop( const QDragMoveEvent* event, bool& accept ); void handleTabDrop( QDropEvent* event ); void moveTabData( int from, int to ); signals: void restoreDocument(const KConfigGroup &group); void saveDocumentRestoreInfo(KConfigGroup &group); private: void setupAccel(); void setupActions(); QStringList fileFormats() const; void openNewTab( const KUrl& url, const QString &serializedOptions ); void applyOptionsToPart( QObject* part, const QString &serializedOptions ); void connectPart( QObject* part ); int findTabIndex( QObject* sender ); private: KPluginFactory* m_partFactory; KRecentFilesAction* m_recent; QStringList m_fileformats; bool m_fileformatsscanned; KAction* m_printAction; KAction* m_closeAction; KToggleAction* m_fullScreenAction; KToggleAction* m_showMenuBarAction; bool m_menuBarWasShown, m_toolBarWasShown; bool m_unique; KTabWidget* m_tabWidget; KToggleAction* m_openInTab; struct TabState { TabState( KParts::ReadWritePart* p ) : part(p), printEnabled(false), closeEnabled(false) {} KParts::ReadWritePart* part; bool printEnabled; bool closeEnabled; }; QList m_tabs; KAction* m_nextTabAction; KAction* m_prevTabAction; bool m_isValid; }; #endif // vim:ts=2:sw=2:tw=78:et