/* * messagewin.h - displays an alarm message * Program: kalarm * Copyright © 2001-2007 by David Jarvie <software@astrojar.org.uk> * * 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 MESSAGEWIN_H #define MESSAGEWIN_H /** @file messagewin.h - displays an alarm message */ #include <tqmap.h> #include "mainwindowbase.h" #include "alarmevent.h" class TQPushButton; class KPushButton; class TQLabel; class TQTimer; class KWinModule; class AlarmTimeWidget; class DeferAlarmDlg; class KArtsDispatcher; namespace KDE { class PlayObject; } /** * MessageWin: A window to display an alarm message */ class MessageWin : public MainWindowBase { Q_OBJECT public: MessageWin(); // for session management restoration only MessageWin(const KAEvent&, const KAAlarm&, bool reschedule_event = true, bool allowDefer = true); MessageWin(const KAEvent&, const DateTime& alarmDateTime, const TQStringList& errmsgs); ~MessageWin(); void repeat(const KAAlarm&); void setRecreating() { mRecreating = true; } const DateTime& dateTime() { return mDateTime; } KAAlarm::Type alarmType() const { return mAlarmType; } bool hasDefer() const { return !!mDeferButton; } bool isValid() const { return !mInvalid; } virtual void show(); virtual TQSize sizeHint() const; static int instanceCount() { return mWindowList.count(); } static MessageWin* findEvent(const TQString& eventID); protected: virtual void showEvent(TQShowEvent*); virtual void moveEvent(TQMoveEvent*); virtual void resizeEvent(TQResizeEvent*); virtual void closeEvent(TQCloseEvent*); virtual void saveProperties(TDEConfig*); virtual void readProperties(TDEConfig*); private slots: void slotEdit(); void slotDefer(); void checkDeferralLimit(); void displayMainWindow(); void slotShowKMailMessage(); void slotSpeak(); void slotPlayAudio(); void checkAudioPlay(); void stopPlay(); void slotFade(); void enableButtons(); void setRemainingTextDay(); void setRemainingTextMinute(); void setMaxSize(); private: void initView(); #ifndef WITHOUT_ARTS void initAudio(bool firstTime); int getKMixVolume(); void setKMixVolume(int percent); #endif void displayComplete(); void playAudio(); void setDeferralLimit(const KAEvent&); bool haveErrorMessage(unsigned msg) const; void clearErrorMessage(unsigned msg) const; static TQValueList<MessageWin*> mWindowList; // list of existing message windows static TQMap<TQString, unsigned> mErrorMessages; // error messages currently displayed, by event ID // Properties needed by readProperties() TQString mMessage; TQFont mFont; TQColor mBgColour, mFgColour; DateTime mDateTime; // date/time displayed in the message window TQDateTime mCloseTime; // time at which window should be auto-closed TQString mEventID; TQString mAudioFile; float mVolume; float mFadeVolume; int mFadeSeconds; int mDefaultDeferMinutes; KAAlarm::Type mAlarmType; KAEvent::Action mAction; unsigned long mKMailSerialNumber; // if email text, message's KMail serial number, else 0 TQStringList mErrorMsgs; int mRestoreHeight; bool mAudioRepeat; bool mConfirmAck; bool mShowEdit; // display the Edit button bool mNoDefer; // don't display a Defer option bool mInvalid; // restored window is invalid // Sound file playing KArtsDispatcher* mArtsDispatcher; KDE::PlayObject* mPlayObject; TQCString mKMixName; // DCOP name for KMix TQString mKMixError; // error message starting KMix TQTimer* mPlayTimer; // timer for repeating the sound file TQTimer* mFadeTimer; // timer for fading the sound volume float mOldVolume; // volume before volume was set for sound file TQString mLocalAudioFile; // local copy of audio file TQTime mAudioFileStart; // time when audio file loading first started, or when play first started int mAudioFileLoadSecs; // how many seconds it took to load audio file bool mPlayedOnce; // the sound file has started playing at least once bool mPlayed; // the PlayObject->play() has been called // Miscellaneous KAEvent mEvent; // the whole event, for updating the calendar file TQLabel* mRemainingText; // the remaining time (for a reminder window) KPushButton* mOkButton; TQPushButton* mEditButton; TQPushButton* mDeferButton; TQPushButton* mSilenceButton; TQPushButton* mKAlarmButton; TQPushButton* mKMailButton; DeferAlarmDlg* mDeferDlg; TQDateTime mDeferLimit; // last time to which the message can currently be deferred mutable KWinModule* mWinModule; int mFlags; int mLateCancel; int mButtonDelay; // delay (ms) after window is shown before buttons are enabled bool mErrorWindow; // the window is simply an error message bool mNoPostAction; // don't execute any post-alarm action bool mRecreating; // window is about to be deleted and immediately recreated bool mBeep; bool mSpeak; // the message should be spoken via kttsd bool mRescheduleEvent; // true to delete event after message has been displayed bool mShown; // true once the window has been displayed bool mPositioning; // true when the window is being positioned initially bool mNoCloseConfirm; // the Defer or Edit button is closing the dialog bool mUsingKMix; // master volume is being set using kmix bool mDisableDeferral; // true if past deferral limit, so don't enable Defer button }; #endif // MESSAGEWIN_H