/* This file is part of KOrganizer. Copyright (c) 1997, 1998, 1999 Preston Brown Fester Zigterman Ian Dawes Laszlo Boloni Copyright (c) 2000-2003 Cornelius Schumacher Copyright (C) 2003-2004 Reinhold Kainhofer 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. As a special exception, permission is given to link this program with any edition of Qt, and distribute the resulting executable, without including the source code for Qt in the source distribution. */ #ifndef KORG_KORGANIZER_H #define KORG_KORGANIZER_H #include "korganizer/mainwindow.h" #include "korganizer/part.h" #include class CalendarView; // Workaround for moc workaround for visual c++ 6.0 sucking typedef KOrg::MainWindow KOrgMainWindow; typedef KParts::MainWindow KPartsMainWindow; /** This is the main class for KOrganizer. It extends the KDE KMainWindow. it provides the main view that the user sees upon startup, as well as menus, buttons, etc. etc. @short constructs a new main window for korganizer @author Preston Brown */ class KOrganizer : public KPartsMainWindow, public KOrgMainWindow { Q_OBJECT public: KOrganizer(); virtual ~KOrganizer(); void init( bool hasDocument ); KOrg::CalendarViewBase *view() const; ActionManager *actionManager() { return mActionManager; } KActionCollection *getActionCollection() const { return actionCollection(); } /** Open calendar file from URL. Merge into current calendar, if \a merge is true. @param url The URL to open @param merge true if the incidences in URL should be imported into the current calendar (default resource or calendar file), false if the URL should be added as a new resource. @return true on success, false if an error occurred */ bool openURL( const KUrl &url, bool merge = false ); /** Save calendar file to URL of current calendar */ bool saveURL(); /** Save calendar file to URL */ bool saveAsURL( const KUrl &kurl ); /** Get current URL */ KUrl getCurrentURL() const; virtual KXMLGUIFactory *mainGuiFactory() { return factory(); } virtual KXMLGUIClient *mainGuiClient() { return this; } virtual QWidget *topLevelWidget() { return this; } public slots: /** show status message */ void showStatusMessage( const QString & ); protected slots: /** using the KConfig associated with the kapp variable, read in the * settings from the config file. */ void readSettings(); /** write current state to config file. */ void writeSettings(); void statusBarPressed( int id ); /** Sets title of window according to filename and modification state */ void setTitle(); void newMainWindow( const KUrl & ); void slotEditKeys(); protected: void initActions(); // void initViews(); /** supplied so that close events close calendar properly.*/ bool queryClose(); /* Session management */ void saveProperties( KConfigGroup & ); void readProperties( const KConfigGroup & ); private: CalendarView *mCalendarView; // Main view widget KOrg::Part::List mParts; // List of parts loaded // status bar ids enum { ID_HISTORY, ID_GENERAL, ID_ACTIVE, ID_MESSAGES_IN, ID_MESSAGES_OUT }; ActionManager *mActionManager; }; #endif