-rw-r--r-- | bin/kdepim/WhatsNew.txt | 5 | ||||
-rw-r--r-- | korganizer/calendarview.cpp | 3 | ||||
-rw-r--r-- | korganizer/mainwindow.cpp | 2 |
3 files changed, 6 insertions, 4 deletions
diff --git a/bin/kdepim/WhatsNew.txt b/bin/kdepim/WhatsNew.txt index 322c0e6..0ebd853 100644 --- a/bin/kdepim/WhatsNew.txt +++ b/bin/kdepim/WhatsNew.txt | |||
@@ -1,122 +1,123 @@ | |||
1 | Info about the changes in new versions of KDE-Pim/Pi | 1 | Info about the changes in new versions of KDE-Pim/Pi |
2 | 2 | ||
3 | 3 | ||
4 | ********** VERSION 2.1.8 ************ | 4 | ********** VERSION 2.1.8 ************ |
5 | 5 | ||
6 | KO/Pi: | 6 | KO/Pi: |
7 | Added info about the completion sate of a todo in the ListView/Searchdialog. | 7 | Added info about the completion state of a todo in the ListView/Searchdialog. |
8 | If in TodoView is selected "do not show compledted todos" then completed todos are not shown in the ListView as well. | 8 | If in TodoView is selected "do not show compledted todos" then completed todos are not shown in the ListView as well. |
9 | Fixed some updating problems when changing the filter. | ||
9 | 10 | ||
10 | KA/Pi: | 11 | KA/Pi: |
11 | In the addressee selection dialog now the formatted name is shown, if not empty. | 12 | In the addressee selection dialog now the formatted name is shown, if not empty. |
12 | 13 | ||
13 | Fixed in the file selector on the Zaurus the problem that symbolic links to files/dirs were ignored. | 14 | Fixed in the file selector on the Zaurus the problem that symbolic links to files/dirs were ignored. |
14 | Fixed the sorting for size in the file selector on the Z. | 15 | Fixed the sorting for size in the file selector on the Z. |
15 | 16 | ||
16 | Changed the color selection dialog on the Zaurus to a more user friendly version. | 17 | Changed the color selection dialog on the Zaurus to a more user friendly version. |
17 | 18 | ||
18 | ********** VERSION 2.1.7 ************ | 19 | ********** VERSION 2.1.7 ************ |
19 | 20 | ||
20 | KO/Pi: | 21 | KO/Pi: |
21 | Fixed several problems in the new Resource handling. | 22 | Fixed several problems in the new Resource handling. |
22 | Added more options to the search dialog. | 23 | Added more options to the search dialog. |
23 | Fixed a problem in the Month view. | 24 | Fixed a problem in the Month view. |
24 | Added more options to the dialog when setting a todo to stopped. | 25 | Added more options to the dialog when setting a todo to stopped. |
25 | 26 | ||
26 | Fixed two small problems in KO/PiAlarm applet. | 27 | Fixed two small problems in KO/Pi Alarm applet. |
27 | 28 | ||
28 | ********** VERSION 2.1.6 ************ | 29 | ********** VERSION 2.1.6 ************ |
29 | 30 | ||
30 | This release is for testing only. | 31 | This release is for testing only. |
31 | 32 | ||
32 | KO/Pi: | 33 | KO/Pi: |
33 | Added to the list view (the list view is used in search dialog as well) the possibility to print it. | 34 | Added to the list view (the list view is used in search dialog as well) the possibility to print it. |
34 | Added to the list view the possibility to hide entries, if you do not want to print all entries of the list view. | 35 | Added to the list view the possibility to hide entries, if you do not want to print all entries of the list view. |
35 | Added to the list view the possibility to add all subtodos of selected todos to an export/beam. | 36 | Added to the list view the possibility to add all subtodos of selected todos to an export/beam. |
36 | Added to the search dialog the possibility to make an additive search such that you can get a better list for export/printout. | 37 | Added to the search dialog the possibility to make an additive search such that you can get a better list for export/printout. |
37 | Added to the search dialog the possibility to hide the checkboxes such that there is more space for the list view on the Zaurus. | 38 | Added to the search dialog the possibility to hide the checkboxes such that there is more space for the list view on the Zaurus. |
38 | Fixed a problem in the AlarmTimer Applet: Now utf8 messages are displayed properly. | 39 | Fixed a problem in the AlarmTimer Applet: Now utf8 messages are displayed properly. |
39 | 40 | ||
40 | Added support for multiple calendar files in KO/Pi. Only local ical (*.ics) files are supported as calendars. | 41 | Added support for multiple calendar files in KO/Pi. Only local ical (*.ics) files are supported as calendars. |
41 | In the sync profile config it is still missing to specify a particular calendar to sync with this profile. That setting will be added later. | 42 | In the sync profile config it is still missing to specify a particular calendar to sync with this profile. That setting will be added later. |
42 | Now on every sync the set of calendars is synced which are enabled in the resource view. | 43 | Now on every sync the set of calendars is synced which are enabled in the resource view. |
43 | 44 | ||
44 | A calendar is enabled in the resource view if the "eye" column is checked. | 45 | A calendar is enabled in the resource view if the "eye" column is checked. |
45 | You can set a calendar to be the default for new items( "+" column ). | 46 | You can set a calendar to be the default for new items( "+" column ). |
46 | You can tell KO/Pi to ignore all alarm of a calendar ( "bell" column ) and you can set it readonly. | 47 | You can tell KO/Pi to ignore all alarm of a calendar ( "bell" column ) and you can set it readonly. |
47 | To find out how to add a new calendar and how to remove a calendar is left as an exercise to the reader ... | 48 | To find out how to add a new calendar and how to remove a calendar is left as an exercise to the reader ... |
48 | 49 | ||
49 | 50 | ||
50 | ********** VERSION 2.1.5 ************ | 51 | ********** VERSION 2.1.5 ************ |
51 | 52 | ||
52 | This is the new stable version. | 53 | This is the new stable version. |
53 | Bugfix: | 54 | Bugfix: |
54 | Fixed a problem with agenda popup on the desktop in KO/Pi. | 55 | Fixed a problem with agenda popup on the desktop in KO/Pi. |
55 | Fixed a crash when reloading file, e.g. after a passive pi-sync synchronization. | 56 | Fixed a crash when reloading file, e.g. after a passive pi-sync synchronization. |
56 | Added config option to not display completed todos in agenda view. | 57 | Added config option to not display completed todos in agenda view. |
57 | Addressee view is now using the formatted name, if defined. | 58 | Addressee view is now using the formatted name, if defined. |
58 | That makes it possible to display "lastname, firstname" in that view now. | 59 | That makes it possible to display "lastname, firstname" in that view now. |
59 | To set the formatted name for all contacts, please use menu: | 60 | To set the formatted name for all contacts, please use menu: |
60 | Edit->Change->Set formatted name. | 61 | Edit->Change->Set formatted name. |
61 | Fixed the bug in KA/Pi that is was not possible to add images to a contact on Windows. | 62 | Fixed the bug in KA/Pi that is was not possible to add images to a contact on Windows. |
62 | 63 | ||
63 | ********** VERSION 2.1.4 ************ | 64 | ********** VERSION 2.1.4 ************ |
64 | 65 | ||
65 | Fixed two more bugs in the KA/Pi CSV import dialog: | 66 | Fixed two more bugs in the KA/Pi CSV import dialog: |
66 | Made it possible to read multi-line fields and import it to the "Note" field. | 67 | Made it possible to read multi-line fields and import it to the "Note" field. |
67 | Fixed a problem in mapping custom fields, whatever a custem field is... | 68 | Fixed a problem in mapping custom fields, whatever a custem field is... |
68 | 69 | ||
69 | ********** VERSION 2.1.3 ************ | 70 | ********** VERSION 2.1.3 ************ |
70 | 71 | ||
71 | Changed the menu structure of the alarm applet: | 72 | Changed the menu structure of the alarm applet: |
72 | Moved "Simulate" to " Play Beeps" submenu and re-added "Todo List". | 73 | Moved "Simulate" to " Play Beeps" submenu and re-added "Todo List". |
73 | 74 | ||
74 | Fixed several problems in the KA/Pi CSV import dialog: | 75 | Fixed several problems in the KA/Pi CSV import dialog: |
75 | Added "Category", made codec configureable and made it possible to map many fields to the "Note" field. | 76 | Added "Category", made codec configureable and made it possible to map many fields to the "Note" field. |
76 | 77 | ||
77 | 78 | ||
78 | ********** VERSION 2.1.2 ************ | 79 | ********** VERSION 2.1.2 ************ |
79 | 80 | ||
80 | Fixed a problem closing the alarm dialog on Zaurus with "OK" button. | 81 | Fixed a problem closing the alarm dialog on Zaurus with "OK" button. |
81 | 82 | ||
82 | Fixed a problem when importing data from Outlook with mutiple categories set. | 83 | Fixed a problem when importing data from Outlook with mutiple categories set. |
83 | 84 | ||
84 | Changed display of days in datenavigator: | 85 | Changed display of days in datenavigator: |
85 | Birthdays are now blue, not dark green. | 86 | Birthdays are now blue, not dark green. |
86 | When todo view is shown, no birtdays are shown and days with due todos are shown blue. | 87 | When todo view is shown, no birtdays are shown and days with due todos are shown blue. |
87 | When journal view is shown, only holidays are shown and days with journals are blue. | 88 | When journal view is shown, only holidays are shown and days with journals are blue. |
88 | 89 | ||
89 | Added Backup options to global config: | 90 | Added Backup options to global config: |
90 | You can create now x-daily backups for KO/Pi, KA/Pi (for file resources only, file resource is the standard type) and PwM/Pi ( all files you will open ). | 91 | You can create now x-daily backups for KO/Pi, KA/Pi (for file resources only, file resource is the standard type) and PwM/Pi ( all files you will open ). |
91 | It is recommended to use another HDD/Memory card for the backup directory. If (very useful on the Zaurus) the specified backup directory does not exist you are asked if you want to try again to create a backup. That makes it possible to insert your memory card in the Zaurus and then trying again. | 92 | It is recommended to use another HDD/Memory card for the backup directory. If (very useful on the Zaurus) the specified backup directory does not exist you are asked if you want to try again to create a backup. That makes it possible to insert your memory card in the Zaurus and then trying again. |
92 | The backup is created when the application wants to save for the first time on a backup-day. You can specify the amount of backups and the day interval of backups. | 93 | The backup is created when the application wants to save for the first time on a backup-day. You can specify the amount of backups and the day interval of backups. |
93 | 94 | ||
94 | ********** VERSION 2.1.1 ************ | 95 | ********** VERSION 2.1.1 ************ |
95 | 96 | ||
96 | Stable release 2.1.1! | 97 | Stable release 2.1.1! |
97 | 98 | ||
98 | KO/Pi: | 99 | KO/Pi: |
99 | Fixed one problem in the layout of the edit dialogs on the Zaurus with 640x480 display. | 100 | Fixed one problem in the layout of the edit dialogs on the Zaurus with 640x480 display. |
100 | 101 | ||
101 | ********** VERSION 2.1.0 ************ | 102 | ********** VERSION 2.1.0 ************ |
102 | 103 | ||
103 | Stable release 2.1.0! | 104 | Stable release 2.1.0! |
104 | 105 | ||
105 | Summary of changes/fixes compared to version 2.0.6: | 106 | Summary of changes/fixes compared to version 2.0.6: |
106 | 107 | ||
107 | Many bugs of version 2.0.6 fixed. | 108 | Many bugs of version 2.0.6 fixed. |
108 | Most of them were small bugs, but some of them were important. | 109 | Most of them were small bugs, but some of them were important. |
109 | It is recommended to use version 2.1.0 and not version 2.0.6. | 110 | It is recommended to use version 2.1.0 and not version 2.0.6. |
110 | 111 | ||
111 | Important changes: | 112 | Important changes: |
112 | 113 | ||
113 | Added recurring todos to KO/Pi. | 114 | Added recurring todos to KO/Pi. |
114 | 115 | ||
115 | Added global application font settings (for all KDE-Pim/Pi apps) to the general settings. | 116 | Added global application font settings (for all KDE-Pim/Pi apps) to the general settings. |
116 | 117 | ||
117 | Made Passwordmanager PwM/Pi more userfriendly: Rearranged some toolbar icons, optimized setting of focus, fixed layout problems and more. | 118 | Made Passwordmanager PwM/Pi more userfriendly: Rearranged some toolbar icons, optimized setting of focus, fixed layout problems and more. |
118 | 119 | ||
119 | Datenavigator can now display many months. Very useful on the desktop. | 120 | Datenavigator can now display many months. Very useful on the desktop. |
120 | 121 | ||
121 | KO/Pi alarm applet changed: Made buttons in alarm dialog much bigger and other usebility enhancements. | 122 | KO/Pi alarm applet changed: Made buttons in alarm dialog much bigger and other usebility enhancements. |
122 | 123 | ||
diff --git a/korganizer/calendarview.cpp b/korganizer/calendarview.cpp index d25f632..08909ed 100644 --- a/korganizer/calendarview.cpp +++ b/korganizer/calendarview.cpp | |||
@@ -3924,255 +3924,256 @@ void CalendarView::processIncidenceSelection( Incidence *incidence ) | |||
3924 | emit todoSelected( true ); | 3924 | emit todoSelected( true ); |
3925 | Todo *event = static_cast<Todo *>( incidence ); | 3925 | Todo *event = static_cast<Todo *>( incidence ); |
3926 | if ( event->organizer() == KOPrefs::instance()->email() ) { | 3926 | if ( event->organizer() == KOPrefs::instance()->email() ) { |
3927 | emit organizerEventsSelected( true ); | 3927 | emit organizerEventsSelected( true ); |
3928 | } else { | 3928 | } else { |
3929 | emit organizerEventsSelected(false); | 3929 | emit organizerEventsSelected(false); |
3930 | } | 3930 | } |
3931 | if (event->attendeeByMails( KOPrefs::instance()->mAdditionalMails, | 3931 | if (event->attendeeByMails( KOPrefs::instance()->mAdditionalMails, |
3932 | KOPrefs::instance()->email() ) ) { | 3932 | KOPrefs::instance()->email() ) ) { |
3933 | emit groupEventsSelected( true ); | 3933 | emit groupEventsSelected( true ); |
3934 | } else { | 3934 | } else { |
3935 | emit groupEventsSelected(false); | 3935 | emit groupEventsSelected(false); |
3936 | } | 3936 | } |
3937 | return; | 3937 | return; |
3938 | } else { | 3938 | } else { |
3939 | emit todoSelected( false ); | 3939 | emit todoSelected( false ); |
3940 | emit organizerEventsSelected(false); | 3940 | emit organizerEventsSelected(false); |
3941 | emit groupEventsSelected(false); | 3941 | emit groupEventsSelected(false); |
3942 | } | 3942 | } |
3943 | return; | 3943 | return; |
3944 | } | 3944 | } |
3945 | 3945 | ||
3946 | /* if ( incidence && incidence->typeID() == todoID ) { | 3946 | /* if ( incidence && incidence->typeID() == todoID ) { |
3947 | emit todoSelected( true ); | 3947 | emit todoSelected( true ); |
3948 | } else { | 3948 | } else { |
3949 | emit todoSelected( false ); | 3949 | emit todoSelected( false ); |
3950 | }*/ | 3950 | }*/ |
3951 | } | 3951 | } |
3952 | 3952 | ||
3953 | 3953 | ||
3954 | void CalendarView::checkClipboard() | 3954 | void CalendarView::checkClipboard() |
3955 | { | 3955 | { |
3956 | #ifndef KORG_NODND | 3956 | #ifndef KORG_NODND |
3957 | if (ICalDrag::canDecode(QApplication::clipboard()->data())) { | 3957 | if (ICalDrag::canDecode(QApplication::clipboard()->data())) { |
3958 | emit pasteEnabled(true); | 3958 | emit pasteEnabled(true); |
3959 | } else { | 3959 | } else { |
3960 | emit pasteEnabled(false); | 3960 | emit pasteEnabled(false); |
3961 | } | 3961 | } |
3962 | #endif | 3962 | #endif |
3963 | } | 3963 | } |
3964 | 3964 | ||
3965 | void CalendarView::showDates(const DateList &selectedDates) | 3965 | void CalendarView::showDates(const DateList &selectedDates) |
3966 | { | 3966 | { |
3967 | // kdDebug() << "CalendarView::selectDates()" << endl; | 3967 | // kdDebug() << "CalendarView::selectDates()" << endl; |
3968 | 3968 | ||
3969 | 3969 | ||
3970 | if ( !mBlockShowDates ) { | 3970 | if ( !mBlockShowDates ) { |
3971 | if ( mViewManager->currentView() ) { | 3971 | if ( mViewManager->currentView() ) { |
3972 | updateView( selectedDates.first(), selectedDates.last() ); | 3972 | updateView( selectedDates.first(), selectedDates.last() ); |
3973 | } else { | 3973 | } else { |
3974 | mViewManager->showAgendaView(); | 3974 | mViewManager->showAgendaView(); |
3975 | } | 3975 | } |
3976 | } | 3976 | } |
3977 | 3977 | ||
3978 | QDate date = selectedDates.first(); | 3978 | QDate date = selectedDates.first(); |
3979 | if ( ! date.isValid() ) { | 3979 | if ( ! date.isValid() ) { |
3980 | topLevelWidget()->setCaption(""); | 3980 | topLevelWidget()->setCaption(""); |
3981 | return; | 3981 | return; |
3982 | } | 3982 | } |
3983 | 3983 | ||
3984 | QString selDates; | 3984 | QString selDates; |
3985 | selDates = KGlobal::locale()->formatDate( date, true); | 3985 | selDates = KGlobal::locale()->formatDate( date, true); |
3986 | if (selectedDates.first() < selectedDates.last() ) | 3986 | if (selectedDates.first() < selectedDates.last() ) |
3987 | selDates += " - " + KGlobal::locale()->formatDate( selectedDates.last(),true); | 3987 | selDates += " - " + KGlobal::locale()->formatDate( selectedDates.last(),true); |
3988 | else { | 3988 | else { |
3989 | QString addString; | 3989 | QString addString; |
3990 | if ( date == QDateTime::currentDateTime().date() ) | 3990 | if ( date == QDateTime::currentDateTime().date() ) |
3991 | addString = i18n("Today"); | 3991 | addString = i18n("Today"); |
3992 | else if ( date == QDateTime::currentDateTime().date().addDays(1) ) | 3992 | else if ( date == QDateTime::currentDateTime().date().addDays(1) ) |
3993 | addString = i18n("Tomorrow"); | 3993 | addString = i18n("Tomorrow"); |
3994 | else if ( date == QDateTime::currentDateTime().date().addDays(-1) ) | 3994 | else if ( date == QDateTime::currentDateTime().date().addDays(-1) ) |
3995 | addString = i18n("Yesterday"); | 3995 | addString = i18n("Yesterday"); |
3996 | else if ( date == QDateTime::currentDateTime().date().addDays(-2) ) | 3996 | else if ( date == QDateTime::currentDateTime().date().addDays(-2) ) |
3997 | addString = i18n("Day before yesterday"); | 3997 | addString = i18n("Day before yesterday"); |
3998 | else if ( date == QDateTime::currentDateTime().date().addDays(2) ) | 3998 | else if ( date == QDateTime::currentDateTime().date().addDays(2) ) |
3999 | addString = i18n("Day after tomorrow"); | 3999 | addString = i18n("Day after tomorrow"); |
4000 | if ( !addString.isEmpty() ) { | 4000 | if ( !addString.isEmpty() ) { |
4001 | topLevelWidget()->setCaption( addString+", " + selDates ); | 4001 | topLevelWidget()->setCaption( addString+", " + selDates ); |
4002 | return; | 4002 | return; |
4003 | } | 4003 | } |
4004 | } | 4004 | } |
4005 | topLevelWidget()->setCaption( i18n("Dates: ") + selDates ); | 4005 | topLevelWidget()->setCaption( i18n("Dates: ") + selDates ); |
4006 | 4006 | ||
4007 | } | 4007 | } |
4008 | 4008 | ||
4009 | QPtrList<CalFilter> CalendarView::filters() | 4009 | QPtrList<CalFilter> CalendarView::filters() |
4010 | { | 4010 | { |
4011 | return mFilters; | 4011 | return mFilters; |
4012 | 4012 | ||
4013 | } | 4013 | } |
4014 | void CalendarView::editFilters() | 4014 | void CalendarView::editFilters() |
4015 | { | 4015 | { |
4016 | // kdDebug() << "CalendarView::editFilters()" << endl; | 4016 | // kdDebug() << "CalendarView::editFilters()" << endl; |
4017 | 4017 | ||
4018 | CalFilter *filter = mFilters.first(); | 4018 | CalFilter *filter = mFilters.first(); |
4019 | while(filter) { | 4019 | while(filter) { |
4020 | kdDebug() << " Filter: " << filter->name() << endl; | ||
4021 | filter = mFilters.next(); | 4020 | filter = mFilters.next(); |
4022 | } | 4021 | } |
4023 | 4022 | ||
4024 | mDialogManager->showFilterEditDialog(&mFilters); | 4023 | mDialogManager->showFilterEditDialog(&mFilters); |
4025 | updateFilter(); | 4024 | updateFilter(); |
4026 | } | 4025 | } |
4027 | void CalendarView::toggleFilter() | 4026 | void CalendarView::toggleFilter() |
4028 | { | 4027 | { |
4029 | if ( mLeftFrame->isHidden() ) { | 4028 | if ( mLeftFrame->isHidden() ) { |
4030 | toggleExpand(); | 4029 | toggleExpand(); |
4031 | showFilter( true ); | 4030 | showFilter( true ); |
4032 | } else | 4031 | } else |
4033 | showFilter(! mCalEditView->isVisible()); | 4032 | showFilter(! mCalEditView->isVisible()); |
4034 | } | 4033 | } |
4035 | 4034 | ||
4036 | KOFilterView *CalendarView::filterView() | 4035 | KOFilterView *CalendarView::filterView() |
4037 | { | 4036 | { |
4038 | return mFilterView; | 4037 | return mFilterView; |
4039 | } | 4038 | } |
4040 | void CalendarView::selectFilter( int fil ) | 4039 | void CalendarView::selectFilter( int fil ) |
4041 | { | 4040 | { |
4042 | mFilterView->setSelectedFilter( fil ); | 4041 | mFilterView->setSelectedFilter( fil ); |
4042 | updateUnmanagedViews(); | ||
4043 | } | 4043 | } |
4044 | void CalendarView::showFilter(bool visible) | 4044 | void CalendarView::showFilter(bool visible) |
4045 | { | 4045 | { |
4046 | #if 1 | 4046 | #if 1 |
4047 | if (visible) { | 4047 | if (visible) { |
4048 | mCalEditView->readConfig(); | 4048 | mCalEditView->readConfig(); |
4049 | mCalEditView->show(); | 4049 | mCalEditView->show(); |
4050 | QValueList<int> sizes; | 4050 | QValueList<int> sizes; |
4051 | sizes = mLeftFrame->sizes(); | 4051 | sizes = mLeftFrame->sizes(); |
4052 | if ( sizes.count() == 4 && sizes[3] < 20 ) { | 4052 | if ( sizes.count() == 4 && sizes[3] < 20 ) { |
4053 | sizes.clear(); | 4053 | sizes.clear(); |
4054 | sizes << 100; | 4054 | sizes << 100; |
4055 | sizes << 0; | 4055 | sizes << 0; |
4056 | sizes << 0; | 4056 | sizes << 0; |
4057 | sizes << 100; | 4057 | sizes << 100; |
4058 | mLeftFrame->setSizes(sizes); | 4058 | mLeftFrame->setSizes(sizes); |
4059 | } | 4059 | } |
4060 | #if 0 | 4060 | #if 0 |
4061 | sizes = mLeftFrame->sizes(); | 4061 | sizes = mLeftFrame->sizes(); |
4062 | int ccc = 0; | 4062 | int ccc = 0; |
4063 | while ( ccc < sizes.count()) { | 4063 | while ( ccc < sizes.count()) { |
4064 | qDebug("size %d %d ", ccc, sizes[ccc]); | 4064 | qDebug("size %d %d ", ccc, sizes[ccc]); |
4065 | ++ccc; | 4065 | ++ccc; |
4066 | } | 4066 | } |
4067 | #endif | 4067 | #endif |
4068 | 4068 | ||
4069 | } | 4069 | } |
4070 | else { | 4070 | else { |
4071 | mCalEditView->hide(); | 4071 | mCalEditView->hide(); |
4072 | } | 4072 | } |
4073 | #else | 4073 | #else |
4074 | if (visible) mFilterView->show(); | 4074 | if (visible) mFilterView->show(); |
4075 | else mFilterView->hide(); | 4075 | else mFilterView->hide(); |
4076 | #endif | 4076 | #endif |
4077 | } | 4077 | } |
4078 | void CalendarView::toggleFilerEnabled( ) | 4078 | void CalendarView::toggleFilerEnabled( ) |
4079 | { | 4079 | { |
4080 | mFilterView->setFiltersEnabled ( !mFilterView->filtersEnabled() ); | 4080 | mFilterView->setFiltersEnabled ( !mFilterView->filtersEnabled() ); |
4081 | if ( !mFilterView->filtersEnabled() ) | 4081 | if ( !mFilterView->filtersEnabled() ) |
4082 | topLevelWidget()->setCaption( i18n("Filter disabled ") ); | 4082 | topLevelWidget()->setCaption( i18n("Filter disabled ") ); |
4083 | updateUnmanagedViews(); | ||
4083 | 4084 | ||
4084 | } | 4085 | } |
4085 | void CalendarView::updateFilter() | 4086 | void CalendarView::updateFilter() |
4086 | { | 4087 | { |
4087 | CalFilter *filter = mFilterView->selectedFilter(); | 4088 | CalFilter *filter = mFilterView->selectedFilter(); |
4088 | if (filter) { | 4089 | if (filter) { |
4089 | QString mess; | 4090 | QString mess; |
4090 | if (mFilterView->filtersEnabled()) { | 4091 | if (mFilterView->filtersEnabled()) { |
4091 | mess = i18n("Filter selected: ")+filter->name(); | 4092 | mess = i18n("Filter selected: ")+filter->name(); |
4092 | filter->setEnabled(true); | 4093 | filter->setEnabled(true); |
4093 | } | 4094 | } |
4094 | else filter->setEnabled(false); | 4095 | else filter->setEnabled(false); |
4095 | mCalendar->setFilter(filter); | 4096 | mCalendar->setFilter(filter); |
4096 | updateView(); | 4097 | updateView(); |
4097 | if ( !mess.isEmpty() ) | 4098 | if ( !mess.isEmpty() ) |
4098 | topLevelWidget()->setCaption( mess ); | 4099 | topLevelWidget()->setCaption( mess ); |
4099 | 4100 | ||
4100 | } | 4101 | } |
4101 | emit filtersUpdated(); | 4102 | emit filtersUpdated(); |
4102 | } | 4103 | } |
4103 | 4104 | ||
4104 | void CalendarView::filterEdited() | 4105 | void CalendarView::filterEdited() |
4105 | { | 4106 | { |
4106 | mFilterView->updateFilters(); | 4107 | mFilterView->updateFilters(); |
4107 | updateFilter(); | 4108 | updateFilter(); |
4108 | writeSettings(); | 4109 | writeSettings(); |
4109 | } | 4110 | } |
4110 | 4111 | ||
4111 | 4112 | ||
4112 | void CalendarView::takeOverEvent() | 4113 | void CalendarView::takeOverEvent() |
4113 | { | 4114 | { |
4114 | Incidence *incidence = currentSelection(); | 4115 | Incidence *incidence = currentSelection(); |
4115 | 4116 | ||
4116 | if (!incidence) return; | 4117 | if (!incidence) return; |
4117 | 4118 | ||
4118 | incidence->setOrganizer(KOPrefs::instance()->email()); | 4119 | incidence->setOrganizer(KOPrefs::instance()->email()); |
4119 | incidence->recreate(); | 4120 | incidence->recreate(); |
4120 | incidence->setReadOnly(false); | 4121 | incidence->setReadOnly(false); |
4121 | 4122 | ||
4122 | updateView(); | 4123 | updateView(); |
4123 | } | 4124 | } |
4124 | 4125 | ||
4125 | void CalendarView::takeOverCalendar() | 4126 | void CalendarView::takeOverCalendar() |
4126 | { | 4127 | { |
4127 | // TODO: Create Calendar::allIncidences() function and use it here | 4128 | // TODO: Create Calendar::allIncidences() function and use it here |
4128 | 4129 | ||
4129 | clearAllViews(); | 4130 | clearAllViews(); |
4130 | QPtrList<Event> events = mCalendar->events(); | 4131 | QPtrList<Event> events = mCalendar->events(); |
4131 | for(uint i=0; i<events.count(); ++i) { | 4132 | for(uint i=0; i<events.count(); ++i) { |
4132 | events.at(i)->setOrganizer(KOPrefs::instance()->email()); | 4133 | events.at(i)->setOrganizer(KOPrefs::instance()->email()); |
4133 | events.at(i)->recreate(); | 4134 | events.at(i)->recreate(); |
4134 | events.at(i)->setReadOnly(false); | 4135 | events.at(i)->setReadOnly(false); |
4135 | } | 4136 | } |
4136 | 4137 | ||
4137 | QPtrList<Todo> todos = mCalendar->todos(); | 4138 | QPtrList<Todo> todos = mCalendar->todos(); |
4138 | for(uint i=0; i<todos.count(); ++i) { | 4139 | for(uint i=0; i<todos.count(); ++i) { |
4139 | todos.at(i)->setOrganizer(KOPrefs::instance()->email()); | 4140 | todos.at(i)->setOrganizer(KOPrefs::instance()->email()); |
4140 | todos.at(i)->recreate(); | 4141 | todos.at(i)->recreate(); |
4141 | todos.at(i)->setReadOnly(false); | 4142 | todos.at(i)->setReadOnly(false); |
4142 | } | 4143 | } |
4143 | 4144 | ||
4144 | QPtrList<Journal> journals = mCalendar->journals(); | 4145 | QPtrList<Journal> journals = mCalendar->journals(); |
4145 | for(uint i=0; i<journals.count(); ++i) { | 4146 | for(uint i=0; i<journals.count(); ++i) { |
4146 | journals.at(i)->setOrganizer(KOPrefs::instance()->email()); | 4147 | journals.at(i)->setOrganizer(KOPrefs::instance()->email()); |
4147 | journals.at(i)->recreate(); | 4148 | journals.at(i)->recreate(); |
4148 | journals.at(i)->setReadOnly(false); | 4149 | journals.at(i)->setReadOnly(false); |
4149 | } | 4150 | } |
4150 | 4151 | ||
4151 | updateView(); | 4152 | updateView(); |
4152 | } | 4153 | } |
4153 | 4154 | ||
4154 | void CalendarView::showIntro() | 4155 | void CalendarView::showIntro() |
4155 | { | 4156 | { |
4156 | kdDebug() << "To be implemented." << endl; | 4157 | kdDebug() << "To be implemented." << endl; |
4157 | } | 4158 | } |
4158 | 4159 | ||
4159 | QWidgetStack *CalendarView::viewStack() | 4160 | QWidgetStack *CalendarView::viewStack() |
4160 | { | 4161 | { |
4161 | return mRightFrame; | 4162 | return mRightFrame; |
4162 | } | 4163 | } |
4163 | 4164 | ||
4164 | QWidget *CalendarView::leftFrame() | 4165 | QWidget *CalendarView::leftFrame() |
4165 | { | 4166 | { |
4166 | return ( QWidget *)mLeftFrame; | 4167 | return ( QWidget *)mLeftFrame; |
4167 | } | 4168 | } |
4168 | 4169 | ||
4169 | DateNavigator *CalendarView::dateNavigator() | 4170 | DateNavigator *CalendarView::dateNavigator() |
4170 | { | 4171 | { |
4171 | return mNavigator; | 4172 | return mNavigator; |
4172 | } | 4173 | } |
4173 | 4174 | ||
4174 | KDateNavigator* CalendarView::dateNavigatorWidget() | 4175 | KDateNavigator* CalendarView::dateNavigatorWidget() |
4175 | { | 4176 | { |
4176 | return mDateNavigator->navigatorView(); | 4177 | return mDateNavigator->navigatorView(); |
4177 | } | 4178 | } |
4178 | void CalendarView::toggleDateNavigatorWidget() | 4179 | void CalendarView::toggleDateNavigatorWidget() |
diff --git a/korganizer/mainwindow.cpp b/korganizer/mainwindow.cpp index 0367bea..48320a5 100644 --- a/korganizer/mainwindow.cpp +++ b/korganizer/mainwindow.cpp | |||
@@ -1992,193 +1992,193 @@ void MainWindow::keyPressEvent ( QKeyEvent * e ) | |||
1992 | case Qt::Key_S : | 1992 | case Qt::Key_S : |
1993 | if ( e->state() == Qt::ControlButton || e->state() == Qt::ShiftButton) | 1993 | if ( e->state() == Qt::ControlButton || e->state() == Qt::ShiftButton) |
1994 | mView->newSubTodo(); | 1994 | mView->newSubTodo(); |
1995 | else | 1995 | else |
1996 | mView->dialogManager()->showSearchDialog(); | 1996 | mView->dialogManager()->showSearchDialog(); |
1997 | break; | 1997 | break; |
1998 | case Qt::Key_Y : | 1998 | case Qt::Key_Y : |
1999 | case Qt::Key_Z : | 1999 | case Qt::Key_Z : |
2000 | mView->viewManager()->showWorkWeekView(); | 2000 | mView->viewManager()->showWorkWeekView(); |
2001 | showSelectedDates = true; | 2001 | showSelectedDates = true; |
2002 | break; | 2002 | break; |
2003 | case Qt::Key_U : | 2003 | case Qt::Key_U : |
2004 | mView->viewManager()->showWeekView(); | 2004 | mView->viewManager()->showWeekView(); |
2005 | showSelectedDates = true; | 2005 | showSelectedDates = true; |
2006 | break; | 2006 | break; |
2007 | case Qt::Key_H : | 2007 | case Qt::Key_H : |
2008 | keyBindings(); | 2008 | keyBindings(); |
2009 | break; | 2009 | break; |
2010 | case Qt::Key_W: | 2010 | case Qt::Key_W: |
2011 | mView->viewManager()->showWhatsNextView(); | 2011 | mView->viewManager()->showWhatsNextView(); |
2012 | break; | 2012 | break; |
2013 | case Qt::Key_L: | 2013 | case Qt::Key_L: |
2014 | mView->viewManager()->showListView(); | 2014 | mView->viewManager()->showListView(); |
2015 | break; | 2015 | break; |
2016 | case Qt::Key_N: | 2016 | case Qt::Key_N: |
2017 | mView->viewManager()->showNextView(); | 2017 | mView->viewManager()->showNextView(); |
2018 | break; | 2018 | break; |
2019 | case Qt::Key_V: | 2019 | case Qt::Key_V: |
2020 | mView->viewManager()->showTodoView(); | 2020 | mView->viewManager()->showTodoView(); |
2021 | break; | 2021 | break; |
2022 | case Qt::Key_C: | 2022 | case Qt::Key_C: |
2023 | mView->viewManager()->agendaView()->setStartHour( QTime::currentTime ().hour() ); | 2023 | mView->viewManager()->agendaView()->setStartHour( QTime::currentTime ().hour() ); |
2024 | break; | 2024 | break; |
2025 | case Qt::Key_P: | 2025 | case Qt::Key_P: |
2026 | mView->showDatePicker( ); | 2026 | mView->showDatePicker( ); |
2027 | break; | 2027 | break; |
2028 | case Qt::Key_F: | 2028 | case Qt::Key_F: |
2029 | mView->editFilters(); | 2029 | mView->editFilters(); |
2030 | break; | 2030 | break; |
2031 | case Qt::Key_R: | 2031 | case Qt::Key_R: |
2032 | mView->toggleFilter(); | 2032 | mView->toggleFilter(); |
2033 | break; | 2033 | break; |
2034 | case Qt::Key_X: | 2034 | case Qt::Key_X: |
2035 | if ( e->state() == Qt::ControlButton ) | 2035 | if ( e->state() == Qt::ControlButton ) |
2036 | mView->toggleDateNavigatorWidget(); | 2036 | mView->toggleDateNavigatorWidget(); |
2037 | else { | 2037 | else { |
2038 | mView->viewManager()->showNextXView(); | 2038 | mView->viewManager()->showNextXView(); |
2039 | showSelectedDates = true; | 2039 | showSelectedDates = true; |
2040 | } | 2040 | } |
2041 | break; | 2041 | break; |
2042 | case Qt::Key_Space: | 2042 | case Qt::Key_Space: |
2043 | mView->toggleExpand(); | 2043 | mView->toggleExpand(); |
2044 | break; | 2044 | break; |
2045 | case Qt::Key_A: | 2045 | case Qt::Key_A: |
2046 | if ( e->state() == Qt::ControlButton || e->state() == Qt::ShiftButton ) | 2046 | if ( e->state() == Qt::ControlButton || e->state() == Qt::ShiftButton ) |
2047 | mView->showNextAlarms(); | 2047 | mView->showNextAlarms(); |
2048 | else | 2048 | else |
2049 | mView->toggleAllDaySize(); | 2049 | mView->toggleAllDaySize(); |
2050 | break; | 2050 | break; |
2051 | case Qt::Key_T: | 2051 | case Qt::Key_T: |
2052 | if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) | 2052 | if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) |
2053 | mView->newTodo(); | 2053 | mView->newTodo(); |
2054 | else { | 2054 | else { |
2055 | mView->goToday(); | 2055 | mView->goToday(); |
2056 | showSelectedDates = true; | 2056 | showSelectedDates = true; |
2057 | } | 2057 | } |
2058 | break; | 2058 | break; |
2059 | case Qt::Key_J: | 2059 | case Qt::Key_J: |
2060 | mView->viewManager()->showJournalView(); | 2060 | mView->viewManager()->showJournalView(); |
2061 | break; | 2061 | break; |
2062 | case Qt::Key_B: | 2062 | case Qt::Key_B: |
2063 | mView->editIncidenceDescription();; | 2063 | mView->editIncidenceDescription();; |
2064 | break; | 2064 | break; |
2065 | // case Qt::Key_Return: | 2065 | // case Qt::Key_Return: |
2066 | case Qt::Key_E: | 2066 | case Qt::Key_E: |
2067 | if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) | 2067 | if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) |
2068 | mView->newEvent(); | 2068 | mView->newEvent(); |
2069 | else | 2069 | else |
2070 | mView->editIncidence(); | 2070 | mView->editIncidence(); |
2071 | break; | 2071 | break; |
2072 | case Qt::Key_Plus: | 2072 | case Qt::Key_Plus: |
2073 | size = p->mHourSize +2; | 2073 | size = p->mHourSize +2; |
2074 | if ( size <= 22 ) | 2074 | if ( size <= 22 ) |
2075 | configureAgenda( size ); | 2075 | configureAgenda( size ); |
2076 | break; | 2076 | break; |
2077 | case Qt::Key_Minus: | 2077 | case Qt::Key_Minus: |
2078 | size = p->mHourSize - 2; | 2078 | size = p->mHourSize - 2; |
2079 | if ( size >= 4 ) | 2079 | if ( size >= 4 ) |
2080 | configureAgenda( size ); | 2080 | configureAgenda( size ); |
2081 | break; | 2081 | break; |
2082 | 2082 | ||
2083 | 2083 | ||
2084 | default: | 2084 | default: |
2085 | e->ignore(); | 2085 | e->ignore(); |
2086 | } | 2086 | } |
2087 | if ( pro > 0 ) { | 2087 | if ( pro > 0 ) { |
2088 | mView->selectFilter( pro-1 ); | 2088 | selectFilter( pro+1 ); |
2089 | } | 2089 | } |
2090 | if ( showSelectedDates ) { | 2090 | if ( showSelectedDates ) { |
2091 | ;// setCaptionToDates(); | 2091 | ;// setCaptionToDates(); |
2092 | } | 2092 | } |
2093 | 2093 | ||
2094 | } | 2094 | } |
2095 | void MainWindow::fillFilterMenuTB() | 2095 | void MainWindow::fillFilterMenuTB() |
2096 | { | 2096 | { |
2097 | selectFilterMenuTB->clear(); | 2097 | selectFilterMenuTB->clear(); |
2098 | selectFilterMenuTB->insertItem(i18n ( "Edit Filters" ), 0 ); | 2098 | selectFilterMenuTB->insertItem(i18n ( "Edit Filters" ), 0 ); |
2099 | selectFilterMenuTB->insertSeparator(); | 2099 | selectFilterMenuTB->insertSeparator(); |
2100 | selectFilterMenuTB->insertItem(i18n ( "No Filter" ), 1 ); | 2100 | selectFilterMenuTB->insertItem(i18n ( "No Filter" ), 1 ); |
2101 | 2101 | ||
2102 | selectFilterMenuTB->insertSeparator(); | 2102 | selectFilterMenuTB->insertSeparator(); |
2103 | QPtrList<CalFilter> fili = mView->filters(); | 2103 | QPtrList<CalFilter> fili = mView->filters(); |
2104 | CalFilter *curfilter = mView->filterView()->selectedFilter(); | 2104 | CalFilter *curfilter = mView->filterView()->selectedFilter(); |
2105 | CalFilter *filter = fili.first(); | 2105 | CalFilter *filter = fili.first(); |
2106 | int iii = 2; | 2106 | int iii = 2; |
2107 | bool checkitem = mView->filterView()->filtersEnabled(); | 2107 | bool checkitem = mView->filterView()->filtersEnabled(); |
2108 | while(filter) { | 2108 | while(filter) { |
2109 | selectFilterMenuTB->insertItem( filter->name(), iii ); | 2109 | selectFilterMenuTB->insertItem( filter->name(), iii ); |
2110 | if ( filter == curfilter) | 2110 | if ( filter == curfilter) |
2111 | selectFilterMenuTB->setItemChecked( iii, checkitem ); | 2111 | selectFilterMenuTB->setItemChecked( iii, checkitem ); |
2112 | filter = fili.next(); | 2112 | filter = fili.next(); |
2113 | ++iii; | 2113 | ++iii; |
2114 | } | 2114 | } |
2115 | if ( !checkitem ) | 2115 | if ( !checkitem ) |
2116 | selectFilterMenuTB->setItemChecked( 1, true ); | 2116 | selectFilterMenuTB->setItemChecked( 1, true ); |
2117 | 2117 | ||
2118 | int x = 0; | 2118 | int x = 0; |
2119 | int y = iconToolBar->height(); | 2119 | int y = iconToolBar->height(); |
2120 | int dX = 0; | 2120 | int dX = 0; |
2121 | int dY = 0; | 2121 | int dY = 0; |
2122 | if ( iconToolBar->orientation () == Qt:: Horizontal ) { | 2122 | if ( iconToolBar->orientation () == Qt:: Horizontal ) { |
2123 | if ( iconToolBar->y() > height()/2 ) { | 2123 | if ( iconToolBar->y() > height()/2 ) { |
2124 | dY = selectFilterMenuTB->sizeHint().height()+8; | 2124 | dY = selectFilterMenuTB->sizeHint().height()+8; |
2125 | y = 0; | 2125 | y = 0; |
2126 | } | 2126 | } |
2127 | } else { | 2127 | } else { |
2128 | if ( iconToolBar->x() > width()/2 ) { // right side | 2128 | if ( iconToolBar->x() > width()/2 ) { // right side |
2129 | x=0; | 2129 | x=0; |
2130 | dX= selectFilterMenuTB->sizeHint().width()+8; | 2130 | dX= selectFilterMenuTB->sizeHint().width()+8; |
2131 | y = 0; | 2131 | y = 0; |
2132 | } else { | 2132 | } else { |
2133 | x= iconToolBar->width(); | 2133 | x= iconToolBar->width(); |
2134 | y = 0; | 2134 | y = 0; |
2135 | } | 2135 | } |
2136 | } | 2136 | } |
2137 | //qDebug("dax %d dy %d %d %d ", dX, dY, iconToolBar->x(), iconToolBar->y() ); | 2137 | //qDebug("dax %d dy %d %d %d ", dX, dY, iconToolBar->x(), iconToolBar->y() ); |
2138 | selectFilterMenuTB->popup(iconToolBar->mapToGlobal(QPoint(x,y)-QPoint( dX,dY))); | 2138 | selectFilterMenuTB->popup(iconToolBar->mapToGlobal(QPoint(x,y)-QPoint( dX,dY))); |
2139 | } | 2139 | } |
2140 | void MainWindow::fillFilterMenu() | 2140 | void MainWindow::fillFilterMenu() |
2141 | { | 2141 | { |
2142 | selectFilterMenu->clear(); | 2142 | selectFilterMenu->clear(); |
2143 | selectFilterMenu->insertItem(i18n ( "Edit Filters" ), 0 ); | 2143 | selectFilterMenu->insertItem(i18n ( "Edit Filters" ), 0 ); |
2144 | selectFilterMenu->insertSeparator(); | 2144 | selectFilterMenu->insertSeparator(); |
2145 | selectFilterMenu->insertItem(i18n ( "No Filter" ), 1 ); | 2145 | selectFilterMenu->insertItem(i18n ( "No Filter" ), 1 ); |
2146 | 2146 | ||
2147 | selectFilterMenu->insertSeparator(); | 2147 | selectFilterMenu->insertSeparator(); |
2148 | QPtrList<CalFilter> fili = mView->filters(); | 2148 | QPtrList<CalFilter> fili = mView->filters(); |
2149 | CalFilter *curfilter = mView->filterView()->selectedFilter(); | 2149 | CalFilter *curfilter = mView->filterView()->selectedFilter(); |
2150 | CalFilter *filter = fili.first(); | 2150 | CalFilter *filter = fili.first(); |
2151 | int iii = 2; | 2151 | int iii = 2; |
2152 | bool checkitem = mView->filterView()->filtersEnabled(); | 2152 | bool checkitem = mView->filterView()->filtersEnabled(); |
2153 | while(filter) { | 2153 | while(filter) { |
2154 | selectFilterMenu->insertItem( filter->name(), iii ); | 2154 | selectFilterMenu->insertItem( filter->name(), iii ); |
2155 | if ( filter == curfilter) | 2155 | if ( filter == curfilter) |
2156 | selectFilterMenu->setItemChecked( iii, checkitem ); | 2156 | selectFilterMenu->setItemChecked( iii, checkitem ); |
2157 | filter = fili.next(); | 2157 | filter = fili.next(); |
2158 | ++iii; | 2158 | ++iii; |
2159 | } | 2159 | } |
2160 | if ( !checkitem ) | 2160 | if ( !checkitem ) |
2161 | selectFilterMenu->setItemChecked( 1, true ); | 2161 | selectFilterMenu->setItemChecked( 1, true ); |
2162 | } | 2162 | } |
2163 | void MainWindow::fillFilterMenuPopup() | 2163 | void MainWindow::fillFilterMenuPopup() |
2164 | { | 2164 | { |
2165 | filterPopupMenu->clear(); | 2165 | filterPopupMenu->clear(); |
2166 | filterPopupMenu->insertItem(i18n ( "No Filter" ), 0 ); | 2166 | filterPopupMenu->insertItem(i18n ( "No Filter" ), 0 ); |
2167 | 2167 | ||
2168 | filterPopupMenu->insertSeparator(); | 2168 | filterPopupMenu->insertSeparator(); |
2169 | QPtrList<CalFilter> fili = mView->filters(); | 2169 | QPtrList<CalFilter> fili = mView->filters(); |
2170 | CalFilter *curfilter = mView->filterView()->selectedFilter(); | 2170 | CalFilter *curfilter = mView->filterView()->selectedFilter(); |
2171 | CalFilter *filter = fili.first(); | 2171 | CalFilter *filter = fili.first(); |
2172 | int iii = 1; | 2172 | int iii = 1; |
2173 | bool checkitem = mView->filterView()->filtersEnabled(); | 2173 | bool checkitem = mView->filterView()->filtersEnabled(); |
2174 | while(filter) { | 2174 | while(filter) { |
2175 | filterPopupMenu->insertItem( filter->name(), iii ); | 2175 | filterPopupMenu->insertItem( filter->name(), iii ); |
2176 | if ( filter == curfilter) | 2176 | if ( filter == curfilter) |
2177 | filterPopupMenu->setItemChecked( iii, checkitem ); | 2177 | filterPopupMenu->setItemChecked( iii, checkitem ); |
2178 | filter = fili.next(); | 2178 | filter = fili.next(); |
2179 | ++iii; | 2179 | ++iii; |
2180 | } | 2180 | } |
2181 | if ( !checkitem ) | 2181 | if ( !checkitem ) |
2182 | filterPopupMenu->setItemChecked( 0, true ); | 2182 | filterPopupMenu->setItemChecked( 0, true ); |
2183 | } | 2183 | } |
2184 | void MainWindow::selectFilter( int fil ) | 2184 | void MainWindow::selectFilter( int fil ) |