-rw-r--r-- | korganizer/koeventpopupmenu.cpp | 173 | ||||
-rw-r--r-- | korganizer/koeventpopupmenu.h | 3 | ||||
-rw-r--r-- | korganizer/kolistview.cpp | 20 | ||||
-rw-r--r-- | korganizer/searchdialog.cpp | 4 |
4 files changed, 121 insertions, 79 deletions
diff --git a/korganizer/koeventpopupmenu.cpp b/korganizer/koeventpopupmenu.cpp index 90caaf4..41d331a 100644 --- a/korganizer/koeventpopupmenu.cpp +++ b/korganizer/koeventpopupmenu.cpp @@ -1,22 +1,22 @@ /* - This file is part of KOrganizer. - Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> - - 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, 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. + This file is part of KOrganizer. + Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> + + 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, 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. */ @@ -36,30 +36,35 @@ KOEventPopupMenu::KOEventPopupMenu(): QPopupMenu() { - mCurrentIncidence = 0; - mHasAdditionalItems = false; + mCurrentIncidence = 0; + mHasAdditionalItems = false; - mSingleOnlyItems.append( insertItem (i18n("&Show"),this,SLOT(popupShow()))); - mEditOnlyItems.append(insertItem (i18n("&Edit..."),this,SLOT(popupEdit()))); - mEditOnlyItems.append(insertItem (i18n("&Delete"), - this,SLOT(popupDelete()))); - mEditOnlyItems.append(insertItem (i18n("&Clone..."), - this,SLOT(popupClone()))); - mEditOnlyItems.append(insertItem (i18n("&Move..."), - this,SLOT(popupMove()))); + mSingleOnlyItems.append( insertItem (i18n("&Show"),this,SLOT(popupShow()))); + mEditOnlyItems.append(insertItem (i18n("&Edit..."),this,SLOT(popupEdit()))); + mEditOnlyItems.append(insertItem (i18n("&Delete"), + this,SLOT(popupDelete()))); + mEditOnlyItems.append(insertItem (i18n("&Clone..."), + this,SLOT(popupClone()))); + mEditOnlyItems.append(insertItem (i18n("&Move..."), + this,SLOT(popupMove()))); #ifndef DESKTOP_VERSION - mEditOnlyItems.append(insertItem (i18n("&Beam..."), - this,SLOT(popupBeam()))); + mEditOnlyItems.append(insertItem (i18n("&Beam..."), + this,SLOT(popupBeam()))); #endif - mEditOnlyItems.append(insertItem (i18n("&Toggle Cancel"), - this,SLOT(popupCancel()))); - isDisabled = false; - mCatPopup = new QPopupMenu ( this ); - mCatPopup->setCheckable (true); - connect(mCatPopup,SIGNAL( aboutToShow ()), this ,SLOT( fillCatPopup())); - connect(mCatPopup,SIGNAL( activated ( int ) ), this ,SLOT( computeCatPopup( int ))); - mEditOnlyItems.append(insertItem (i18n("Categories"),mCatPopup )); - QValueList<int>::Iterator it; - for( it = mEditOnlyItems.begin(); it != mEditOnlyItems.end(); ++it ) { - mSingleOnlyItems.append(*it); - } + mEditOnlyItems.append(insertItem (i18n("&Toggle Cancel"), + this,SLOT(popupCancel()))); + isDisabled = false; + mCatPopup = new QPopupMenu ( this ); + mCatPopup->setCheckable (true); + connect(mCatPopup,SIGNAL( aboutToShow ()), this ,SLOT( fillCatPopup())); + connect(mCatPopup,SIGNAL( activated ( int ) ), this ,SLOT( computeCatPopup( int ))); + mCalPopup = new QPopupMenu ( this ); + mCalPopup->setCheckable (true); + connect(mCalPopup,SIGNAL( aboutToShow ()), this ,SLOT( fillCalPopup())); + connect(mCalPopup,SIGNAL( activated ( int ) ), this ,SLOT( computeCalPopup( int ))); + mEditOnlyItems.append(insertItem (i18n("Categories"),mCatPopup )); + mEditOnlyItems.append(insertItem (i18n("Calendar"),mCalPopup )); + QValueList<int>::Iterator it; + for( it = mEditOnlyItems.begin(); it != mEditOnlyItems.end(); ++it ) { + mSingleOnlyItems.append(*it); + } @@ -76,2 +81,21 @@ void KOEventPopupMenu::enableDefault( bool enable ) +void KOEventPopupMenu::fillCalPopup() // CAL +{ + mCalPopup->clear(); + if (!mCurrentIncidence) return; + KopiCalendarFile * kkf = KOPrefs::instance()->mCalendars.first(); + while ( kkf ) { + int index = mCalPopup->insertItem( kkf->mName, kkf->mCalNumber); + if ( kkf->mErrorOnLoad || kkf->isReadOnly ) + mCalPopup->setItemEnabled( index, false ); + mCalPopup->setItemChecked (index, kkf->mCalNumber == mCurrentIncidence->calID()); + kkf = KOPrefs::instance()->mCalendars.next(); + } +} +void KOEventPopupMenu::computeCalPopup( int index ) // CAL +{ + if (!mCurrentIncidence) return; + mCurrentIncidence->setCalID( index ); + emit categoryChanged( mCurrentIncidence ); +} void KOEventPopupMenu::fillCatPopup() @@ -79,2 +103,3 @@ void KOEventPopupMenu::fillCatPopup() mCatPopup->clear(); + if (!mCurrentIncidence) return; QStringList checkedCategories = mCurrentIncidence->categories(); @@ -92,3 +117,4 @@ void KOEventPopupMenu::fillCatPopup() void KOEventPopupMenu::computeCatPopup( int index ) -{ +{ + if (!mCurrentIncidence) return; QStringList categories = mCurrentIncidence->categories(); @@ -96,3 +122,3 @@ void KOEventPopupMenu::computeCatPopup( int index ) if (categories.find (KOPrefs::instance()->mCustomCategories[index]) != categories.end ()) - categories.remove (KOPrefs::instance()->mCustomCategories[index]); + categories.remove (KOPrefs::instance()->mCustomCategories[index]); else @@ -106,3 +132,3 @@ void KOEventPopupMenu::computeCatPopup( int index ) } - mCurrentIncidence->setCategories( categories ); + mCurrentIncidence->setCategories( categories ); emit categoryChanged( mCurrentIncidence ); @@ -111,14 +137,15 @@ void KOEventPopupMenu::showIncidencePopup(Incidence *incidence) { - mCurrentIncidence = incidence; + if ( !incidence) return; + mCurrentIncidence = incidence; - if (mCurrentIncidence) { - // Enable/Disabled menu items only valid for editable events. - if ( !isDisabled ) { - QValueList<int>::Iterator it; - for( it = mEditOnlyItems.begin(); it != mEditOnlyItems.end(); ++it ) { - setItemEnabled(*it,!mCurrentIncidence->isReadOnly()); - } - } - popup(QCursor::pos()); - } + if (mCurrentIncidence) { + // Enable/Disabled menu items only valid for editable events. + if ( !isDisabled ) { + QValueList<int>::Iterator it; + for( it = mEditOnlyItems.begin(); it != mEditOnlyItems.end(); ++it ) { + setItemEnabled(*it,!mCurrentIncidence->isReadOnly()); + } + } + popup(QCursor::pos()); + } } @@ -126,11 +153,11 @@ void KOEventPopupMenu::showIncidencePopup(Incidence *incidence) void KOEventPopupMenu::addAdditionalItem(const QIconSet &icon,const QString &text, - const QObject *receiver, const char *member, - bool editOnly) + const QObject *receiver, const char *member, + bool editOnly) { - if (!mHasAdditionalItems) { - mHasAdditionalItems = true; - insertSeparator(); - } - int id = insertItem(icon,text,receiver,member); - if (editOnly) mEditOnlyItems.append(id); + if (!mHasAdditionalItems) { + mHasAdditionalItems = true; + insertSeparator(); + } + int id = insertItem(icon,text,receiver,member); + if (editOnly) mEditOnlyItems.append(id); } @@ -139,3 +166,3 @@ void KOEventPopupMenu::popupShow() { - if (mCurrentIncidence) emit showIncidenceSignal(mCurrentIncidence); + if (mCurrentIncidence) emit showIncidenceSignal(mCurrentIncidence); } @@ -144,3 +171,3 @@ void KOEventPopupMenu::popupEdit() { - if (mCurrentIncidence) emit editIncidenceSignal(mCurrentIncidence); + if (mCurrentIncidence) emit editIncidenceSignal(mCurrentIncidence); } @@ -149,3 +176,3 @@ void KOEventPopupMenu::popupDelete() { - if (mCurrentIncidence) emit deleteIncidenceSignal(mCurrentIncidence); + if (mCurrentIncidence) emit deleteIncidenceSignal(mCurrentIncidence); } @@ -153,3 +180,3 @@ void KOEventPopupMenu::popupClone() { - if (mCurrentIncidence) emit cloneIncidenceSignal(mCurrentIncidence); + if (mCurrentIncidence) emit cloneIncidenceSignal(mCurrentIncidence); } @@ -157,3 +184,3 @@ void KOEventPopupMenu::popupCancel() { - if (mCurrentIncidence) emit cancelIncidenceSignal(mCurrentIncidence); + if (mCurrentIncidence) emit cancelIncidenceSignal(mCurrentIncidence); } @@ -161,3 +188,3 @@ void KOEventPopupMenu::popupMove() { - if (mCurrentIncidence) emit moveIncidenceSignal(mCurrentIncidence); + if (mCurrentIncidence) emit moveIncidenceSignal(mCurrentIncidence); } @@ -166,3 +193,3 @@ void KOEventPopupMenu::popupBeam() { - if (mCurrentIncidence) emit beamIncidenceSignal(mCurrentIncidence); + if (mCurrentIncidence) emit beamIncidenceSignal(mCurrentIncidence); } diff --git a/korganizer/koeventpopupmenu.h b/korganizer/koeventpopupmenu.h index 3d8b595..e28745b 100644 --- a/korganizer/koeventpopupmenu.h +++ b/korganizer/koeventpopupmenu.h @@ -58,2 +58,4 @@ class KOEventPopupMenu : public QPopupMenu { void computeCatPopup( int ); + void fillCalPopup(); + void computeCalPopup( int ); @@ -77,2 +79,3 @@ class KOEventPopupMenu : public QPopupMenu { QPopupMenu *mCatPopup; + QPopupMenu *mCalPopup; }; diff --git a/korganizer/kolistview.cpp b/korganizer/kolistview.cpp index db3f802..cdcbbf0 100644 --- a/korganizer/kolistview.cpp +++ b/korganizer/kolistview.cpp @@ -306,4 +306,5 @@ KOListView::KOListView(Calendar *calendar, QWidget *parent, - mPopupMenu->insertSeparator(); + selPopup->insertSeparator(); #ifdef DESKTOP_VERSION + mPopupMenu->insertSeparator(); mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), @@ -311,7 +312,11 @@ KOListView::KOListView(Calendar *calendar, QWidget *parent, SLOT(printList()),true); - mPopupMenu->insertSeparator(); #endif mCalPopup = new QPopupMenu ( this ); - mPopupMenu->insertItem( i18n("Set Calendar"), mCalPopup ); + selPopup->insertItem( i18n("Set Calendar"), mCalPopup ); + selPopup->insertItem(i18n("Set categories")+"...",this, + SLOT(setCat()) ); + selPopup->insertItem( i18n("Set alarm..."),this, + SLOT(setAlarm())); +#if 0 mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), @@ -322,2 +327,3 @@ KOListView::KOListView(Calendar *calendar, QWidget *parent, SLOT(setAlarm()),true); +#endif QObject::connect(mCalPopup,SIGNAL(aboutToShow()),this, @@ -329,3 +335,3 @@ KOListView::KOListView(Calendar *calendar, QWidget *parent, QPopupMenu * exportPO = new QPopupMenu ( this ); - mPopupMenu->insertItem( i18n("Export"), exportPO ); + selPopup->insertItem( i18n("Export"), exportPO ); exportPO->insertItem( i18n("As iCal (ics) file..."),this, @@ -342,3 +348,6 @@ KOListView::KOListView(Calendar *calendar, QWidget *parent, #ifndef DESKTOP_VERSION - mPopupMenu->insertSeparator(); + selPopup->insertSeparator(); + selPopup->insertItem( i18n("Beam via IR"),this, + SLOT(beamSelected())); +#if 0 mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), @@ -347,2 +356,3 @@ KOListView::KOListView(Calendar *calendar, QWidget *parent, #endif +#endif /* diff --git a/korganizer/searchdialog.cpp b/korganizer/searchdialog.cpp index d0865c3..efe8774 100644 --- a/korganizer/searchdialog.cpp +++ b/korganizer/searchdialog.cpp @@ -126,3 +126,5 @@ SearchDialog::SearchDialog(Calendar *calendar,CalendarView *parent) QWidget *rangeWidget = new QWidget(topFrame); - QHBoxLayout *rangeLayout = new QHBoxLayout(rangeWidget,0,KDialog::spacingHint()-3); + int space = KDialog::spacingHint(); + if ( QApplication::desktop()->width() <= 240 ) space = 1; + QHBoxLayout *rangeLayout = new QHBoxLayout(rangeWidget,0,space); rangeLayout->addWidget(new QLabel(i18n("From:"),rangeWidget)); |