-rw-r--r-- | korganizer/koeventpopupmenu.cpp | 27 | ||||
-rw-r--r-- | korganizer/koeventpopupmenu.h | 3 | ||||
-rw-r--r-- | korganizer/kolistview.cpp | 12 | ||||
-rw-r--r-- | korganizer/kolistview.h | 1 |
4 files changed, 38 insertions, 5 deletions
diff --git a/korganizer/koeventpopupmenu.cpp b/korganizer/koeventpopupmenu.cpp index b274810..17ef81e 100644 --- a/korganizer/koeventpopupmenu.cpp +++ b/korganizer/koeventpopupmenu.cpp | |||
@@ -23,58 +23,75 @@ | |||
23 | 23 | ||
24 | #include <qcursor.h> | 24 | #include <qcursor.h> |
25 | 25 | ||
26 | #include <klocale.h> | 26 | #include <klocale.h> |
27 | #include <kdebug.h> | 27 | #include <kdebug.h> |
28 | #include <kiconloader.h> | 28 | #include <kiconloader.h> |
29 | 29 | ||
30 | #include <libkcal/event.h> | 30 | #include <libkcal/event.h> |
31 | 31 | ||
32 | #include "koeventpopupmenu.h" | 32 | #include "koeventpopupmenu.h" |
33 | 33 | ||
34 | KOEventPopupMenu::KOEventPopupMenu() | 34 | KOEventPopupMenu::KOEventPopupMenu() |
35 | { | 35 | { |
36 | mCurrentIncidence = 0; | 36 | mCurrentIncidence = 0; |
37 | mHasAdditionalItems = false; | 37 | mHasAdditionalItems = false; |
38 | 38 | ||
39 | insertItem (i18n("&Show"),this,SLOT(popupShow())); | 39 | |
40 | mSingleOnlyItems.append( insertItem (i18n("&Show"),this,SLOT(popupShow()))); | ||
40 | mEditOnlyItems.append(insertItem (i18n("&Edit..."),this,SLOT(popupEdit()))); | 41 | mEditOnlyItems.append(insertItem (i18n("&Edit..."),this,SLOT(popupEdit()))); |
41 | mEditOnlyItems.append(insertItem (i18n("&Delete"), | 42 | mEditOnlyItems.append(insertItem (i18n("&Delete"), |
42 | this,SLOT(popupDelete()))); | 43 | this,SLOT(popupDelete()))); |
43 | mEditOnlyItems.append(insertItem (i18n("&Clone..."), | 44 | mEditOnlyItems.append(insertItem (i18n("&Clone..."), |
44 | this,SLOT(popupClone()))); | 45 | this,SLOT(popupClone()))); |
45 | mEditOnlyItems.append(insertItem (i18n("&Move..."), | 46 | mEditOnlyItems.append(insertItem (i18n("&Move..."), |
46 | this,SLOT(popupMove()))); | 47 | this,SLOT(popupMove()))); |
47 | #ifndef DESKTOP_VERSION | 48 | #ifndef DESKTOP_VERSION |
48 | mEditOnlyItems.append(insertItem (i18n("&Beam..."), | 49 | mEditOnlyItems.append(insertItem (i18n("&Beam..."), |
49 | this,SLOT(popupBeam()))); | 50 | this,SLOT(popupBeam()))); |
50 | #endif | 51 | #endif |
51 | mEditOnlyItems.append(insertItem (i18n("&Toggle Cancel"), | 52 | mEditOnlyItems.append(insertItem (i18n("&Toggle Cancel"), |
52 | this,SLOT(popupCancel()))); | 53 | this,SLOT(popupCancel()))); |
54 | isDisabled = false; | ||
55 | QValueList<int>::Iterator it; | ||
56 | for( it = mEditOnlyItems.begin(); it != mEditOnlyItems.end(); ++it ) { | ||
57 | mSingleOnlyItems.append(*it); | ||
58 | } | ||
59 | } | ||
60 | void KOEventPopupMenu::enableDefault( bool enable ) | ||
61 | { | ||
62 | isDisabled = !enable; | ||
63 | QValueList<int>::Iterator it; | ||
64 | for( it = mSingleOnlyItems.begin(); it != mSingleOnlyItems.end(); ++it ) { | ||
65 | setItemEnabled(*it,enable); | ||
66 | } | ||
67 | |||
53 | } | 68 | } |
54 | 69 | ||
55 | void KOEventPopupMenu::showIncidencePopup(Incidence *incidence) | 70 | void KOEventPopupMenu::showIncidencePopup(Incidence *incidence) |
56 | { | 71 | { |
57 | mCurrentIncidence = incidence; | 72 | mCurrentIncidence = incidence; |
58 | 73 | ||
59 | if (mCurrentIncidence) { | 74 | if (mCurrentIncidence) { |
60 | // Enable/Disabled menu items only valid for editable events. | 75 | // Enable/Disabled menu items only valid for editable events. |
61 | QValueList<int>::Iterator it; | 76 | if ( !isDisabled ) { |
62 | for( it = mEditOnlyItems.begin(); it != mEditOnlyItems.end(); ++it ) { | 77 | QValueList<int>::Iterator it; |
63 | setItemEnabled(*it,!mCurrentIncidence->isReadOnly()); | 78 | for( it = mEditOnlyItems.begin(); it != mEditOnlyItems.end(); ++it ) { |
64 | } | 79 | setItemEnabled(*it,!mCurrentIncidence->isReadOnly()); |
80 | } | ||
81 | } | ||
65 | popup(QCursor::pos()); | 82 | popup(QCursor::pos()); |
66 | } else { | 83 | } else { |
67 | kdDebug() << "KOEventPopupMenu::showEventPopup(): No event selected" << endl; | 84 | kdDebug() << "KOEventPopupMenu::showEventPopup(): No event selected" << endl; |
68 | } | 85 | } |
69 | } | 86 | } |
70 | 87 | ||
71 | void KOEventPopupMenu::addAdditionalItem(const QIconSet &icon,const QString &text, | 88 | void KOEventPopupMenu::addAdditionalItem(const QIconSet &icon,const QString &text, |
72 | const QObject *receiver, const char *member, | 89 | const QObject *receiver, const char *member, |
73 | bool editOnly) | 90 | bool editOnly) |
74 | { | 91 | { |
75 | if (!mHasAdditionalItems) { | 92 | if (!mHasAdditionalItems) { |
76 | mHasAdditionalItems = true; | 93 | mHasAdditionalItems = true; |
77 | insertSeparator(); | 94 | insertSeparator(); |
78 | } | 95 | } |
79 | int id = insertItem(icon,text,receiver,member); | 96 | int id = insertItem(icon,text,receiver,member); |
80 | if (editOnly) mEditOnlyItems.append(id); | 97 | if (editOnly) mEditOnlyItems.append(id); |
diff --git a/korganizer/koeventpopupmenu.h b/korganizer/koeventpopupmenu.h index 6993899..8fb51fa 100644 --- a/korganizer/koeventpopupmenu.h +++ b/korganizer/koeventpopupmenu.h | |||
@@ -31,43 +31,46 @@ | |||
31 | #include <libkcal/incidence.h> | 31 | #include <libkcal/incidence.h> |
32 | 32 | ||
33 | using namespace KCal; | 33 | using namespace KCal; |
34 | 34 | ||
35 | class KOEventPopupMenu : public QPopupMenu { | 35 | class KOEventPopupMenu : public QPopupMenu { |
36 | Q_OBJECT | 36 | Q_OBJECT |
37 | public: | 37 | public: |
38 | KOEventPopupMenu(); | 38 | KOEventPopupMenu(); |
39 | 39 | ||
40 | void addAdditionalItem(const QIconSet &icon,const QString &text, | 40 | void addAdditionalItem(const QIconSet &icon,const QString &text, |
41 | const QObject *receiver, const char *member, | 41 | const QObject *receiver, const char *member, |
42 | bool editOnly=false); | 42 | bool editOnly=false); |
43 | 43 | ||
44 | 44 | ||
45 | public slots: | 45 | public slots: |
46 | void showIncidencePopup(Incidence *); | 46 | void showIncidencePopup(Incidence *); |
47 | void enableDefault( bool ); | ||
47 | 48 | ||
48 | protected slots: | 49 | protected slots: |
49 | void popupShow(); | 50 | void popupShow(); |
50 | void popupEdit(); | 51 | void popupEdit(); |
51 | void popupDelete(); | 52 | void popupDelete(); |
52 | void popupClone(); | 53 | void popupClone(); |
53 | void popupCancel(); | 54 | void popupCancel(); |
54 | void popupMove(); | 55 | void popupMove(); |
55 | void popupBeam(); | 56 | void popupBeam(); |
56 | 57 | ||
57 | signals: | 58 | signals: |
58 | void editIncidenceSignal(Incidence *); | 59 | void editIncidenceSignal(Incidence *); |
59 | void showIncidenceSignal(Incidence *); | 60 | void showIncidenceSignal(Incidence *); |
60 | void deleteIncidenceSignal(Incidence *); | 61 | void deleteIncidenceSignal(Incidence *); |
61 | void cloneIncidenceSignal(Incidence *); | 62 | void cloneIncidenceSignal(Incidence *); |
62 | void cancelIncidenceSignal(Incidence *); | 63 | void cancelIncidenceSignal(Incidence *); |
63 | void moveIncidenceSignal(Incidence *); | 64 | void moveIncidenceSignal(Incidence *); |
64 | void beamIncidenceSignal(Incidence *); | 65 | void beamIncidenceSignal(Incidence *); |
65 | 66 | ||
66 | private: | 67 | private: |
67 | Incidence *mCurrentIncidence; | 68 | Incidence *mCurrentIncidence; |
68 | 69 | ||
69 | bool mHasAdditionalItems; | 70 | bool mHasAdditionalItems; |
70 | QValueList<int> mEditOnlyItems; | 71 | QValueList<int> mEditOnlyItems; |
72 | QValueList<int> mSingleOnlyItems; | ||
73 | bool isDisabled; | ||
71 | }; | 74 | }; |
72 | 75 | ||
73 | #endif | 76 | #endif |
diff --git a/korganizer/kolistview.cpp b/korganizer/kolistview.cpp index b94916a..02247c8 100644 --- a/korganizer/kolistview.cpp +++ b/korganizer/kolistview.cpp | |||
@@ -990,32 +990,33 @@ KOListViewItem *KOListView::getItemForEvent(Event *event) | |||
990 | } | 990 | } |
991 | return 0; | 991 | return 0; |
992 | } | 992 | } |
993 | 993 | ||
994 | void KOListView::defaultItemAction(QListViewItem *i) | 994 | void KOListView::defaultItemAction(QListViewItem *i) |
995 | { | 995 | { |
996 | KOListViewItem *item = static_cast<KOListViewItem *>( i ); | 996 | KOListViewItem *item = static_cast<KOListViewItem *>( i ); |
997 | if ( item ) defaultAction( item->data() ); | 997 | if ( item ) defaultAction( item->data() ); |
998 | 998 | ||
999 | } | 999 | } |
1000 | 1000 | ||
1001 | void KOListView::popupMenu(QListViewItem *item,const QPoint &,int) | 1001 | void KOListView::popupMenu(QListViewItem *item,const QPoint &,int) |
1002 | { | 1002 | { |
1003 | mActiveItem = (KOListViewItem *)item; | 1003 | mActiveItem = (KOListViewItem *)item; |
1004 | if (mActiveItem) { | 1004 | if (mActiveItem) { |
1005 | Incidence *incidence = mActiveItem->data(); | 1005 | Incidence *incidence = mActiveItem->data(); |
1006 | mPopupMenu->enableDefault( !mListView->hasMultiSelection( item ) ); | ||
1006 | mPopupMenu->showIncidencePopup(incidence); | 1007 | mPopupMenu->showIncidencePopup(incidence); |
1007 | 1008 | ||
1008 | /* | 1009 | /* |
1009 | if ( incidence && incidence->type() == "Event" ) { | 1010 | if ( incidence && incidence->type() == "Event" ) { |
1010 | Event *event = static_cast<Event *>( incidence ); | 1011 | Event *event = static_cast<Event *>( incidence ); |
1011 | mPopupMenu->showEventPopup(event); | 1012 | mPopupMenu->showEventPopup(event); |
1012 | } | 1013 | } |
1013 | */ | 1014 | */ |
1014 | } | 1015 | } |
1015 | } | 1016 | } |
1016 | 1017 | ||
1017 | void KOListView::readSettings(KConfig *config, QString setting) | 1018 | void KOListView::readSettings(KConfig *config, QString setting) |
1018 | { | 1019 | { |
1019 | // qDebug("KOListView::readSettings "); | 1020 | // qDebug("KOListView::readSettings "); |
1020 | mListView->restoreLayout(config,setting); | 1021 | mListView->restoreLayout(config,setting); |
1021 | } | 1022 | } |
@@ -1182,32 +1183,43 @@ void KOListViewListView::keyPressEvent ( QKeyEvent *e) | |||
1182 | default: | 1183 | default: |
1183 | e->ignore(); | 1184 | e->ignore(); |
1184 | } | 1185 | } |
1185 | } | 1186 | } |
1186 | KOListViewListView::KOListViewListView(KOListView * lv ) | 1187 | KOListViewListView::KOListViewListView(KOListView * lv ) |
1187 | : KListView( lv, "kolistlistview", false ) | 1188 | : KListView( lv, "kolistlistview", false ) |
1188 | { | 1189 | { |
1189 | mYMousePos = 0; | 1190 | mYMousePos = 0; |
1190 | mPopupTimer = new QTimer(this); | 1191 | mPopupTimer = new QTimer(this); |
1191 | connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); | 1192 | connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); |
1192 | #ifndef DESKTOP_VERSION | 1193 | #ifndef DESKTOP_VERSION |
1193 | //QPEApplication::setStylusOperation(viewport(), QPEApplication::RightOnHold ); | 1194 | //QPEApplication::setStylusOperation(viewport(), QPEApplication::RightOnHold ); |
1194 | #endif | 1195 | #endif |
1195 | setSelectionMode( QListView::Multi ); | 1196 | setSelectionMode( QListView::Multi ); |
1196 | setMultiSelection( true); | 1197 | setMultiSelection( true); |
1197 | } | 1198 | } |
1199 | bool KOListViewListView::hasMultiSelection(QListViewItem* item) | ||
1200 | { | ||
1201 | int selCount = 0; | ||
1202 | QListViewItem *qitem = firstChild (); | ||
1203 | while ( qitem ) { | ||
1204 | if ( qitem->isSelected() && item != qitem ) | ||
1205 | return true; | ||
1206 | qitem = qitem->nextSibling(); | ||
1207 | } | ||
1208 | return false; | ||
1209 | } | ||
1198 | void KOListViewListView::contentsMouseDoubleClickEvent(QMouseEvent *e) | 1210 | void KOListViewListView::contentsMouseDoubleClickEvent(QMouseEvent *e) |
1199 | { | 1211 | { |
1200 | if (!e) return; | 1212 | if (!e) return; |
1201 | QPoint vp = contentsToViewport(e->pos()); | 1213 | QPoint vp = contentsToViewport(e->pos()); |
1202 | QListViewItem *item = itemAt(vp); | 1214 | QListViewItem *item = itemAt(vp); |
1203 | if (!item) { | 1215 | if (!item) { |
1204 | emit newEvent(); | 1216 | emit newEvent(); |
1205 | return; | 1217 | return; |
1206 | } | 1218 | } |
1207 | KListView::contentsMouseDoubleClickEvent(e); | 1219 | KListView::contentsMouseDoubleClickEvent(e); |
1208 | } | 1220 | } |
1209 | #if 0 | 1221 | #if 0 |
1210 | void KOListViewListView::contentsMousePressEvent(QMouseEvent *e) | 1222 | void KOListViewListView::contentsMousePressEvent(QMouseEvent *e) |
1211 | { | 1223 | { |
1212 | //qDebug("contentsMousePressEvent++++ "); | 1224 | //qDebug("contentsMousePressEvent++++ "); |
1213 | KListView::contentsMousePressEvent( e ); | 1225 | KListView::contentsMousePressEvent( e ); |
diff --git a/korganizer/kolistview.h b/korganizer/kolistview.h index 2051d60..dee69f6 100644 --- a/korganizer/kolistview.h +++ b/korganizer/kolistview.h | |||
@@ -202,32 +202,33 @@ class ListItemVisitor : public Incidence::Visitor | |||
202 | This class provides a multi-column list view of events. It can | 202 | This class provides a multi-column list view of events. It can |
203 | display events from one particular day or several days, it doesn't | 203 | display events from one particular day or several days, it doesn't |
204 | matter. To use a view that only handles one day at a time, use | 204 | matter. To use a view that only handles one day at a time, use |
205 | KODayListView. | 205 | KODayListView. |
206 | 206 | ||
207 | @short multi-column list view of various events. | 207 | @short multi-column list view of various events. |
208 | @author Preston Brown <pbrown@kde.org> | 208 | @author Preston Brown <pbrown@kde.org> |
209 | @see KOBaseView, KODayListView | 209 | @see KOBaseView, KODayListView |
210 | */ | 210 | */ |
211 | class KOListView; | 211 | class KOListView; |
212 | 212 | ||
213 | class KOListViewListView : public KListView | 213 | class KOListViewListView : public KListView |
214 | { | 214 | { |
215 | Q_OBJECT | 215 | Q_OBJECT |
216 | public: | 216 | public: |
217 | KOListViewListView(KOListView * lv ); | 217 | KOListViewListView(KOListView * lv ); |
218 | bool hasMultiSelection(QListViewItem*); | ||
218 | signals: | 219 | signals: |
219 | void newEvent(); | 220 | void newEvent(); |
220 | void showIncidence( Incidence* ); | 221 | void showIncidence( Incidence* ); |
221 | public slots: | 222 | public slots: |
222 | void popupMenu(); | 223 | void popupMenu(); |
223 | private: | 224 | private: |
224 | QPoint mEventPos; | 225 | QPoint mEventPos; |
225 | QPoint mEventGlobalPos; | 226 | QPoint mEventGlobalPos; |
226 | QTimer* mPopupTimer; | 227 | QTimer* mPopupTimer; |
227 | int mYMousePos; | 228 | int mYMousePos; |
228 | void keyPressEvent ( QKeyEvent * ) ; | 229 | void keyPressEvent ( QKeyEvent * ) ; |
229 | void contentsMouseDoubleClickEvent(QMouseEvent *e); | 230 | void contentsMouseDoubleClickEvent(QMouseEvent *e); |
230 | void contentsMousePressEvent(QMouseEvent *e); | 231 | void contentsMousePressEvent(QMouseEvent *e); |
231 | void contentsMouseReleaseEvent(QMouseEvent *e); | 232 | void contentsMouseReleaseEvent(QMouseEvent *e); |
232 | void contentsMouseMoveEvent(QMouseEvent *e); | 233 | void contentsMouseMoveEvent(QMouseEvent *e); |
233 | bool mMouseDown; | 234 | bool mMouseDown; |