author | zautrix <zautrix> | 2004-10-28 11:03:42 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2004-10-28 11:03:42 (UTC) |
commit | 01cd4ef94b8604532181c390e9abd560aebaf372 (patch) (unidiff) | |
tree | 96ca1a524512ae2e2868f0bd3df03e4da5c445f9 | |
parent | 61d9eb436349a841410559f51e2601a34ceb5794 (diff) | |
download | kdepimpi-01cd4ef94b8604532181c390e9abd560aebaf372.zip kdepimpi-01cd4ef94b8604532181c390e9abd560aebaf372.tar.gz kdepimpi-01cd4ef94b8604532181c390e9abd560aebaf372.tar.bz2 |
added howto to menus
-rw-r--r-- | kaddressbook/kabcore.cpp | 32 | ||||
-rw-r--r-- | kaddressbook/kabcore.h | 4 | ||||
-rw-r--r-- | korganizer/calendarview.cpp | 12 | ||||
-rw-r--r-- | korganizer/mainwindow.cpp | 48 | ||||
-rw-r--r-- | korganizer/mainwindow.h | 2 | ||||
-rw-r--r-- | libkdepim/ksyncmanager.cpp | 4 |
6 files changed, 74 insertions, 28 deletions
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp index 5ebd3a4..bdc5bd8 100644 --- a/kaddressbook/kabcore.cpp +++ b/kaddressbook/kabcore.cpp | |||
@@ -1817,335 +1817,343 @@ void KABCore::initActions() | |||
1817 | } | 1817 | } |
1818 | 1818 | ||
1819 | mActionDelete = new KAction( i18n( "&Delete Contact" ), "editdelete", | 1819 | mActionDelete = new KAction( i18n( "&Delete Contact" ), "editdelete", |
1820 | Key_Delete, this, SLOT( deleteContacts() ), | 1820 | Key_Delete, this, SLOT( deleteContacts() ), |
1821 | actionCollection(), "edit_delete" ); | 1821 | actionCollection(), "edit_delete" ); |
1822 | 1822 | ||
1823 | mActionUndo->setEnabled( false ); | 1823 | mActionUndo->setEnabled( false ); |
1824 | mActionRedo->setEnabled( false ); | 1824 | mActionRedo->setEnabled( false ); |
1825 | 1825 | ||
1826 | // settings menu | 1826 | // settings menu |
1827 | #ifdef KAB_EMBEDDED | 1827 | #ifdef KAB_EMBEDDED |
1828 | //US special menuentry to configure the addressbook resources. On KDE | 1828 | //US special menuentry to configure the addressbook resources. On KDE |
1829 | // you do that through the control center !!! | 1829 | // you do that through the control center !!! |
1830 | mActionConfigResources = new KAction( i18n( "Configure &Resources..." ), "configure_resources", 0, this, | 1830 | mActionConfigResources = new KAction( i18n( "Configure &Resources..." ), "configure_resources", 0, this, |
1831 | SLOT( configureResources() ), actionCollection(), | 1831 | SLOT( configureResources() ), actionCollection(), |
1832 | "kaddressbook_configure_resources" ); | 1832 | "kaddressbook_configure_resources" ); |
1833 | #endif //KAB_EMBEDDED | 1833 | #endif //KAB_EMBEDDED |
1834 | 1834 | ||
1835 | if ( mIsPart ) { | 1835 | if ( mIsPart ) { |
1836 | mActionConfigKAddressbook = new KAction( i18n( "&Configure KAddressBook..." ), "configure", 0, this, | 1836 | mActionConfigKAddressbook = new KAction( i18n( "&Configure KAddressBook..." ), "configure", 0, this, |
1837 | SLOT( openConfigDialog() ), actionCollection(), | 1837 | SLOT( openConfigDialog() ), actionCollection(), |
1838 | "kaddressbook_configure" ); | 1838 | "kaddressbook_configure" ); |
1839 | 1839 | ||
1840 | //US not implemented yet | 1840 | //US not implemented yet |
1841 | //mActionConfigShortcuts = new KAction( i18n( "Configure S&hortcuts..." ), "configure_shortcuts", 0, | 1841 | //mActionConfigShortcuts = new KAction( i18n( "Configure S&hortcuts..." ), "configure_shortcuts", 0, |
1842 | // this, SLOT( configureKeyBindings() ), actionCollection(), | 1842 | // this, SLOT( configureKeyBindings() ), actionCollection(), |
1843 | // "kaddressbook_configure_shortcuts" ); | 1843 | // "kaddressbook_configure_shortcuts" ); |
1844 | #ifdef KAB_EMBEDDED | 1844 | #ifdef KAB_EMBEDDED |
1845 | mActionConfigureToolbars = KStdAction::configureToolbars( this, SLOT( mMainWindow->configureToolbars() ), actionCollection() ); | 1845 | mActionConfigureToolbars = KStdAction::configureToolbars( this, SLOT( mMainWindow->configureToolbars() ), actionCollection() ); |
1846 | mActionConfigureToolbars->setEnabled( false ); | 1846 | mActionConfigureToolbars->setEnabled( false ); |
1847 | #endif //KAB_EMBEDDED | 1847 | #endif //KAB_EMBEDDED |
1848 | 1848 | ||
1849 | } else { | 1849 | } else { |
1850 | mActionConfigKAddressbook = KStdAction::preferences( this, SLOT( openConfigDialog() ), actionCollection() ); | 1850 | mActionConfigKAddressbook = KStdAction::preferences( this, SLOT( openConfigDialog() ), actionCollection() ); |
1851 | 1851 | ||
1852 | //US not implemented yet | 1852 | //US not implemented yet |
1853 | //mActionKeyBindings = KStdAction::keyBindings( this, SLOT( configureKeyBindings() ), actionCollection() ); | 1853 | //mActionKeyBindings = KStdAction::keyBindings( this, SLOT( configureKeyBindings() ), actionCollection() ); |
1854 | } | 1854 | } |
1855 | 1855 | ||
1856 | mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0, | 1856 | mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0, |
1857 | actionCollection(), "options_show_jump_bar" ); | 1857 | actionCollection(), "options_show_jump_bar" ); |
1858 | connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBarVisible( bool ) ) ); | 1858 | connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBarVisible( bool ) ) ); |
1859 | 1859 | ||
1860 | mActionDetails = new KToggleAction( i18n( "Show Details" ), "listview", 0, | 1860 | mActionDetails = new KToggleAction( i18n( "Show Details" ), "listview", 0, |
1861 | actionCollection(), "options_show_details" ); | 1861 | actionCollection(), "options_show_details" ); |
1862 | connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) ); | 1862 | connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) ); |
1863 | 1863 | ||
1864 | 1864 | ||
1865 | mActionBR = new KToggleAction( i18n( "Beam receive enabled" ), "beam", 0, this, | 1865 | mActionBR = new KToggleAction( i18n( "Beam receive enabled" ), "beam", 0, this, |
1866 | SLOT( toggleBeamReceive() ), actionCollection(), | 1866 | SLOT( toggleBeamReceive() ), actionCollection(), |
1867 | "kaddressbook_beam_rec" ); | 1867 | "kaddressbook_beam_rec" ); |
1868 | 1868 | ||
1869 | 1869 | ||
1870 | // misc | 1870 | // misc |
1871 | // only enable LDAP lookup if we can handle the protocol | 1871 | // only enable LDAP lookup if we can handle the protocol |
1872 | #ifndef KAB_EMBEDDED | 1872 | #ifndef KAB_EMBEDDED |
1873 | if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) { | 1873 | if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) { |
1874 | new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0, | 1874 | new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0, |
1875 | this, SLOT( openLDAPDialog() ), actionCollection(), | 1875 | this, SLOT( openLDAPDialog() ), actionCollection(), |
1876 | "ldap_lookup" ); | 1876 | "ldap_lookup" ); |
1877 | } | 1877 | } |
1878 | #else //KAB_EMBEDDED | 1878 | #else //KAB_EMBEDDED |
1879 | //qDebug("KABCore::initActions() LDAP has to be implemented"); | 1879 | //qDebug("KABCore::initActions() LDAP has to be implemented"); |
1880 | #endif //KAB_EMBEDDED | 1880 | #endif //KAB_EMBEDDED |
1881 | 1881 | ||
1882 | 1882 | ||
1883 | mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this, | 1883 | mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this, |
1884 | SLOT( setWhoAmI() ), actionCollection(), | 1884 | SLOT( setWhoAmI() ), actionCollection(), |
1885 | "set_personal" ); | 1885 | "set_personal" ); |
1886 | 1886 | ||
1887 | 1887 | ||
1888 | 1888 | ||
1889 | 1889 | ||
1890 | mActionCategories = new KAction( i18n( "Set Categories" ), 0, this, | 1890 | mActionCategories = new KAction( i18n( "Set Categories" ), 0, this, |
1891 | SLOT( setCategories() ), actionCollection(), | 1891 | SLOT( setCategories() ), actionCollection(), |
1892 | "edit_set_categories" ); | 1892 | "edit_set_categories" ); |
1893 | 1893 | ||
1894 | mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this, | 1894 | mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this, |
1895 | SLOT( removeVoice() ), actionCollection(), | 1895 | SLOT( removeVoice() ), actionCollection(), |
1896 | "remove_voice" ); | 1896 | "remove_voice" ); |
1897 | mActionImportOL = new KAction( i18n( "Import from Outlook..." ), 0, this, | 1897 | mActionImportOL = new KAction( i18n( "Import from Outlook..." ), 0, this, |
1898 | SLOT( importFromOL() ), actionCollection(), | 1898 | SLOT( importFromOL() ), actionCollection(), |
1899 | "import_OL" ); | 1899 | "import_OL" ); |
1900 | #ifdef KAB_EMBEDDED | 1900 | #ifdef KAB_EMBEDDED |
1901 | mActionLicence = new KAction( i18n( "Licence" ), 0, | 1901 | mActionLicence = new KAction( i18n( "Licence" ), 0, |
1902 | this, SLOT( showLicence() ), actionCollection(), | 1902 | this, SLOT( showLicence() ), actionCollection(), |
1903 | "licence_about_data" ); | 1903 | "licence_about_data" ); |
1904 | mActionFaq = new KAction( i18n( "Faq" ), 0, | 1904 | mActionFaq = new KAction( i18n( "Faq" ), 0, |
1905 | this, SLOT( faq() ), actionCollection(), | 1905 | this, SLOT( faq() ), actionCollection(), |
1906 | "faq_about_data" ); | 1906 | "faq_about_data" ); |
1907 | mActionWN = new KAction( i18n( "What's New?" ), 0, | 1907 | mActionWN = new KAction( i18n( "What's New?" ), 0, |
1908 | this, SLOT( whatsnew() ), actionCollection(), | 1908 | this, SLOT( whatsnew() ), actionCollection(), |
1909 | "wn" ); | 1909 | "wn" ); |
1910 | mActionSyncHowto = new KAction( i18n( "Sync HowTo" ), 0, | 1910 | mActionSyncHowto = new KAction( i18n( "Sync HowTo" ), 0, |
1911 | this, SLOT( synchowto() ), actionCollection(), | 1911 | this, SLOT( synchowto() ), actionCollection(), |
1912 | "sync" ); | 1912 | "sync" ); |
1913 | mActionKdeSyncHowto = new KAction( i18n( "Kde Sync HowTo" ), 0, | ||
1914 | this, SLOT( kdesynchowto() ), actionCollection(), | ||
1915 | "kdesync" ); | ||
1916 | mActionMultiSyncHowto = new KAction( i18n( "Multi Sync HowTo" ), 0, | ||
1917 | this, SLOT( multisynchowto() ), actionCollection(), | ||
1918 | "multisync" ); | ||
1913 | 1919 | ||
1914 | mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0, | 1920 | mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0, |
1915 | this, SLOT( createAboutData() ), actionCollection(), | 1921 | this, SLOT( createAboutData() ), actionCollection(), |
1916 | "kaddressbook_about_data" ); | 1922 | "kaddressbook_about_data" ); |
1917 | #endif //KAB_EMBEDDED | 1923 | #endif //KAB_EMBEDDED |
1918 | 1924 | ||
1919 | clipboardDataChanged(); | 1925 | clipboardDataChanged(); |
1920 | connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); | 1926 | connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); |
1921 | connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); | 1927 | connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); |
1922 | } | 1928 | } |
1923 | 1929 | ||
1924 | //US we need this function, to plug all actions into the correct menues. | 1930 | //US we need this function, to plug all actions into the correct menues. |
1925 | // KDE uses a XML format to plug the actions, but we work her without this overhead. | 1931 | // KDE uses a XML format to plug the actions, but we work her without this overhead. |
1926 | void KABCore::addActionsManually() | 1932 | void KABCore::addActionsManually() |
1927 | { | 1933 | { |
1928 | //US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); | 1934 | //US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); |
1929 | 1935 | ||
1930 | #ifdef KAB_EMBEDDED | 1936 | #ifdef KAB_EMBEDDED |
1931 | QPopupMenu *fileMenu = new QPopupMenu( this ); | 1937 | QPopupMenu *fileMenu = new QPopupMenu( this ); |
1932 | QPopupMenu *editMenu = new QPopupMenu( this ); | 1938 | QPopupMenu *editMenu = new QPopupMenu( this ); |
1933 | QPopupMenu *helpMenu = new QPopupMenu( this ); | 1939 | QPopupMenu *helpMenu = new QPopupMenu( this ); |
1934 | 1940 | ||
1935 | KToolBar* tb = mMainWindow->toolBar(); | 1941 | KToolBar* tb = mMainWindow->toolBar(); |
1936 | 1942 | ||
1937 | #ifndef DESKTOP_VERSION | 1943 | #ifndef DESKTOP_VERSION |
1938 | if ( KABPrefs::instance()->mFullMenuBarVisible ) { | 1944 | if ( KABPrefs::instance()->mFullMenuBarVisible ) { |
1939 | #endif | 1945 | #endif |
1940 | QMenuBar* mb = mMainWindow->menuBar(); | 1946 | QMenuBar* mb = mMainWindow->menuBar(); |
1941 | 1947 | ||
1942 | //US setup menubar. | 1948 | //US setup menubar. |
1943 | //Disable the following block if you do not want to have a menubar. | 1949 | //Disable the following block if you do not want to have a menubar. |
1944 | mb->insertItem( "&File", fileMenu ); | 1950 | mb->insertItem( "&File", fileMenu ); |
1945 | mb->insertItem( "&Edit", editMenu ); | 1951 | mb->insertItem( "&Edit", editMenu ); |
1946 | mb->insertItem( "&View", viewMenu ); | 1952 | mb->insertItem( "&View", viewMenu ); |
1947 | mb->insertItem( "&Settings", settingsMenu ); | 1953 | mb->insertItem( "&Settings", settingsMenu ); |
1948 | mb->insertItem( i18n("Synchronize"), syncMenu ); | 1954 | mb->insertItem( i18n("Synchronize"), syncMenu ); |
1949 | mb->insertItem( "&Change selected", changeMenu ); | 1955 | mb->insertItem( "&Change selected", changeMenu ); |
1950 | mb->insertItem( "&Help", helpMenu ); | 1956 | mb->insertItem( "&Help", helpMenu ); |
1951 | mIncSearchWidget = new IncSearchWidget( tb ); | 1957 | mIncSearchWidget = new IncSearchWidget( tb ); |
1952 | // tb->insertWidget(-1, 0, mIncSearchWidget); | 1958 | // tb->insertWidget(-1, 0, mIncSearchWidget); |
1953 | #ifndef DESKTOP_VERSION | 1959 | #ifndef DESKTOP_VERSION |
1954 | } else { | 1960 | } else { |
1955 | //US setup toolbar | 1961 | //US setup toolbar |
1956 | QPEMenuBar *menuBarTB = new QPEMenuBar( tb ); | 1962 | QPEMenuBar *menuBarTB = new QPEMenuBar( tb ); |
1957 | QPopupMenu *popupBarTB = new QPopupMenu( this ); | 1963 | QPopupMenu *popupBarTB = new QPopupMenu( this ); |
1958 | menuBarTB->insertItem( "ME", popupBarTB); | 1964 | menuBarTB->insertItem( "ME", popupBarTB); |
1959 | tb->insertWidget(-1, 0, menuBarTB); | 1965 | tb->insertWidget(-1, 0, menuBarTB); |
1960 | mIncSearchWidget = new IncSearchWidget( tb ); | 1966 | mIncSearchWidget = new IncSearchWidget( tb ); |
1961 | 1967 | ||
1962 | tb->enableMoving(false); | 1968 | tb->enableMoving(false); |
1963 | popupBarTB->insertItem( "&File", fileMenu ); | 1969 | popupBarTB->insertItem( "&File", fileMenu ); |
1964 | popupBarTB->insertItem( "&Edit", editMenu ); | 1970 | popupBarTB->insertItem( "&Edit", editMenu ); |
1965 | popupBarTB->insertItem( "&View", viewMenu ); | 1971 | popupBarTB->insertItem( "&View", viewMenu ); |
1966 | popupBarTB->insertItem( "&Settings", settingsMenu ); | 1972 | popupBarTB->insertItem( "&Settings", settingsMenu ); |
1967 | popupBarTB->insertItem( i18n("Synchronize"), syncMenu ); | 1973 | popupBarTB->insertItem( i18n("Synchronize"), syncMenu ); |
1968 | mViewManager->getFilterAction()->plug ( popupBarTB); | 1974 | mViewManager->getFilterAction()->plug ( popupBarTB); |
1969 | popupBarTB->insertItem( "&Change selected", changeMenu ); | 1975 | popupBarTB->insertItem( "&Change selected", changeMenu ); |
1970 | popupBarTB->insertItem( "&Help", helpMenu ); | 1976 | popupBarTB->insertItem( "&Help", helpMenu ); |
1971 | if (QApplication::desktop()->width() > 320 ) { | 1977 | if (QApplication::desktop()->width() > 320 ) { |
1972 | // mViewManager->getFilterAction()->plug ( tb); | 1978 | // mViewManager->getFilterAction()->plug ( tb); |
1973 | } | 1979 | } |
1974 | } | 1980 | } |
1975 | #endif | 1981 | #endif |
1976 | // mActionQuit->plug ( mMainWindow->toolBar()); | 1982 | // mActionQuit->plug ( mMainWindow->toolBar()); |
1977 | 1983 | ||
1978 | 1984 | ||
1979 | 1985 | ||
1980 | //US Now connect the actions with the menue entries. | 1986 | //US Now connect the actions with the menue entries. |
1981 | mActionPrint->plug( fileMenu ); | 1987 | mActionPrint->plug( fileMenu ); |
1982 | mActionMail->plug( fileMenu ); | 1988 | mActionMail->plug( fileMenu ); |
1983 | fileMenu->insertSeparator(); | 1989 | fileMenu->insertSeparator(); |
1984 | 1990 | ||
1985 | mActionNewContact->plug( fileMenu ); | 1991 | mActionNewContact->plug( fileMenu ); |
1986 | mActionNewContact->plug( tb ); | 1992 | mActionNewContact->plug( tb ); |
1987 | 1993 | ||
1988 | mActionEditAddressee->plug( fileMenu ); | 1994 | mActionEditAddressee->plug( fileMenu ); |
1989 | // if ((KGlobal::getDesktopSize() > KGlobal::Small ) || | 1995 | // if ((KGlobal::getDesktopSize() > KGlobal::Small ) || |
1990 | // (!KABPrefs::instance()->mMultipleViewsAtOnce )) | 1996 | // (!KABPrefs::instance()->mMultipleViewsAtOnce )) |
1991 | mActionEditAddressee->plug( tb ); | 1997 | mActionEditAddressee->plug( tb ); |
1992 | 1998 | ||
1993 | fileMenu->insertSeparator(); | 1999 | fileMenu->insertSeparator(); |
1994 | mActionSave->plug( fileMenu ); | 2000 | mActionSave->plug( fileMenu ); |
1995 | fileMenu->insertItem( "&Import", ImportMenu ); | 2001 | fileMenu->insertItem( "&Import", ImportMenu ); |
1996 | fileMenu->insertItem( "&Export", ExportMenu ); | 2002 | fileMenu->insertItem( "&Export", ExportMenu ); |
1997 | fileMenu->insertSeparator(); | 2003 | fileMenu->insertSeparator(); |
1998 | mActionMailVCard->plug( fileMenu ); | 2004 | mActionMailVCard->plug( fileMenu ); |
1999 | #ifndef DESKTOP_VERSION | 2005 | #ifndef DESKTOP_VERSION |
2000 | if ( Ir::supported() ) mActionBeamVCard->plug( fileMenu ); | 2006 | if ( Ir::supported() ) mActionBeamVCard->plug( fileMenu ); |
2001 | if ( Ir::supported() ) mActionBeam->plug(fileMenu ); | 2007 | if ( Ir::supported() ) mActionBeam->plug(fileMenu ); |
2002 | #endif | 2008 | #endif |
2003 | fileMenu->insertSeparator(); | 2009 | fileMenu->insertSeparator(); |
2004 | mActionQuit->plug( fileMenu ); | 2010 | mActionQuit->plug( fileMenu ); |
2005 | #ifdef _WIN32_ | 2011 | #ifdef _WIN32_ |
2006 | mActionImportOL->plug( ImportMenu ); | 2012 | mActionImportOL->plug( ImportMenu ); |
2007 | #endif | 2013 | #endif |
2008 | // edit menu | 2014 | // edit menu |
2009 | mActionUndo->plug( editMenu ); | 2015 | mActionUndo->plug( editMenu ); |
2010 | mActionRedo->plug( editMenu ); | 2016 | mActionRedo->plug( editMenu ); |
2011 | editMenu->insertSeparator(); | 2017 | editMenu->insertSeparator(); |
2012 | mActionCut->plug( editMenu ); | 2018 | mActionCut->plug( editMenu ); |
2013 | mActionCopy->plug( editMenu ); | 2019 | mActionCopy->plug( editMenu ); |
2014 | mActionPaste->plug( editMenu ); | 2020 | mActionPaste->plug( editMenu ); |
2015 | mActionDelete->plug( editMenu ); | 2021 | mActionDelete->plug( editMenu ); |
2016 | editMenu->insertSeparator(); | 2022 | editMenu->insertSeparator(); |
2017 | mActionSelectAll->plug( editMenu ); | 2023 | mActionSelectAll->plug( editMenu ); |
2018 | 2024 | ||
2019 | mActionRemoveVoice->plug( changeMenu ); | 2025 | mActionRemoveVoice->plug( changeMenu ); |
2020 | // settings menu | 2026 | // settings menu |
2021 | //US special menuentry to configure the addressbook resources. On KDE | 2027 | //US special menuentry to configure the addressbook resources. On KDE |
2022 | // you do that through the control center !!! | 2028 | // you do that through the control center !!! |
2023 | mActionConfigResources->plug( settingsMenu ); | 2029 | mActionConfigResources->plug( settingsMenu ); |
2024 | settingsMenu->insertSeparator(); | 2030 | settingsMenu->insertSeparator(); |
2025 | 2031 | ||
2026 | mActionConfigKAddressbook->plug( settingsMenu ); | 2032 | mActionConfigKAddressbook->plug( settingsMenu ); |
2027 | 2033 | ||
2028 | if ( mIsPart ) { | 2034 | if ( mIsPart ) { |
2029 | //US not implemented yet | 2035 | //US not implemented yet |
2030 | //mActionConfigShortcuts->plug( settingsMenu ); | 2036 | //mActionConfigShortcuts->plug( settingsMenu ); |
2031 | //mActionConfigureToolbars->plug( settingsMenu ); | 2037 | //mActionConfigureToolbars->plug( settingsMenu ); |
2032 | 2038 | ||
2033 | } else { | 2039 | } else { |
2034 | //US not implemented yet | 2040 | //US not implemented yet |
2035 | //mActionKeyBindings->plug( settingsMenu ); | 2041 | //mActionKeyBindings->plug( settingsMenu ); |
2036 | } | 2042 | } |
2037 | 2043 | ||
2038 | settingsMenu->insertSeparator(); | 2044 | settingsMenu->insertSeparator(); |
2039 | 2045 | ||
2040 | mActionJumpBar->plug( settingsMenu ); | 2046 | mActionJumpBar->plug( settingsMenu ); |
2041 | mActionDetails->plug( settingsMenu ); | 2047 | mActionDetails->plug( settingsMenu ); |
2042 | //if (!KABPrefs::instance()->mMultipleViewsAtOnce || KGlobal::getDesktopSize() == KGlobal::Desktop ) | 2048 | //if (!KABPrefs::instance()->mMultipleViewsAtOnce || KGlobal::getDesktopSize() == KGlobal::Desktop ) |
2043 | mActionDetails->plug( tb ); | 2049 | mActionDetails->plug( tb ); |
2044 | settingsMenu->insertSeparator(); | 2050 | settingsMenu->insertSeparator(); |
2045 | mActionBR->plug(settingsMenu ); | 2051 | mActionBR->plug(settingsMenu ); |
2046 | settingsMenu->insertSeparator(); | 2052 | settingsMenu->insertSeparator(); |
2047 | 2053 | ||
2048 | mActionWhoAmI->plug( settingsMenu ); | 2054 | mActionWhoAmI->plug( settingsMenu ); |
2049 | mActionCategories->plug( settingsMenu ); | 2055 | mActionCategories->plug( settingsMenu ); |
2050 | 2056 | ||
2051 | 2057 | ||
2052 | mActionWN->plug( helpMenu ); | 2058 | mActionWN->plug( helpMenu ); |
2053 | mActionSyncHowto->plug( helpMenu ); | 2059 | mActionSyncHowto->plug( helpMenu ); |
2054 | mActionLicence->plug( helpMenu ); | 2060 | mActionKdeSyncHowto->plug( helpMenu ); |
2061 | mActionMultiSyncHowto->plug( helpMenu ); | ||
2055 | mActionFaq->plug( helpMenu ); | 2062 | mActionFaq->plug( helpMenu ); |
2063 | mActionLicence->plug( helpMenu ); | ||
2056 | mActionAboutKAddressbook->plug( helpMenu ); | 2064 | mActionAboutKAddressbook->plug( helpMenu ); |
2057 | 2065 | ||
2058 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { | 2066 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { |
2059 | 2067 | ||
2060 | mActionSave->plug( tb ); | 2068 | mActionSave->plug( tb ); |
2061 | mViewManager->getFilterAction()->plug ( tb); | 2069 | mViewManager->getFilterAction()->plug ( tb); |
2062 | if (KGlobal::getDesktopSize() == KGlobal::Desktop ) { | 2070 | if (KGlobal::getDesktopSize() == KGlobal::Desktop ) { |
2063 | mActionUndo->plug( tb ); | 2071 | mActionUndo->plug( tb ); |
2064 | mActionDelete->plug( tb ); | 2072 | mActionDelete->plug( tb ); |
2065 | mActionRedo->plug( tb ); | 2073 | mActionRedo->plug( tb ); |
2066 | } | 2074 | } |
2067 | } else { | 2075 | } else { |
2068 | mActionSave->plug( tb ); | 2076 | mActionSave->plug( tb ); |
2069 | tb->enableMoving(false); | 2077 | tb->enableMoving(false); |
2070 | } | 2078 | } |
2071 | //mActionQuit->plug ( tb ); | 2079 | //mActionQuit->plug ( tb ); |
2072 | // tb->insertWidget(-1, 0, mIncSearchWidget, 6); | 2080 | // tb->insertWidget(-1, 0, mIncSearchWidget, 6); |
2073 | 2081 | ||
2074 | //US link the searchwidget first to this. | 2082 | //US link the searchwidget first to this. |
2075 | // The real linkage to the toolbar happens later. | 2083 | // The real linkage to the toolbar happens later. |
2076 | //US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE); | 2084 | //US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE); |
2077 | //US tb->insertItem( mIncSearchWidget ); | 2085 | //US tb->insertItem( mIncSearchWidget ); |
2078 | /*US | 2086 | /*US |
2079 | mIncSearchWidget = new IncSearchWidget( tb ); | 2087 | mIncSearchWidget = new IncSearchWidget( tb ); |
2080 | connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), | 2088 | connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), |
2081 | SLOT( incrementalSearch( const QString& ) ) ); | 2089 | SLOT( incrementalSearch( const QString& ) ) ); |
2082 | 2090 | ||
2083 | mJumpButtonBar = new JumpButtonBar( this, this ); | 2091 | mJumpButtonBar = new JumpButtonBar( this, this ); |
2084 | 2092 | ||
2085 | //US topLayout->addWidget( mJumpButtonBar ); | 2093 | //US topLayout->addWidget( mJumpButtonBar ); |
2086 | this->layout()->add( mJumpButtonBar ); | 2094 | this->layout()->add( mJumpButtonBar ); |
2087 | */ | 2095 | */ |
2088 | 2096 | ||
2089 | #endif //KAB_EMBEDDED | 2097 | #endif //KAB_EMBEDDED |
2090 | 2098 | ||
2091 | mActionExport2phone->plug( ExportMenu ); | 2099 | mActionExport2phone->plug( ExportMenu ); |
2092 | connect ( syncMenu, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) ); | 2100 | connect ( syncMenu, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) ); |
2093 | syncManager->fillSyncMenu(); | 2101 | syncManager->fillSyncMenu(); |
2094 | 2102 | ||
2095 | } | 2103 | } |
2096 | void KABCore::showLicence() | 2104 | void KABCore::showLicence() |
2097 | { | 2105 | { |
2098 | KApplication::showLicence(); | 2106 | KApplication::showLicence(); |
2099 | } | 2107 | } |
2100 | void KABCore::removeVoice() | 2108 | void KABCore::removeVoice() |
2101 | { | 2109 | { |
2102 | if ( KMessageBox::questionYesNo( this, i18n("After importing, phone numbers\nmay have two or more types.\n(E.g. work+voice)\nThese numbers are shown as \"other\".\nClick Yes to remove the voice type\nfrom numbers with more than one type.\n\nRemove voice type?") ) == KMessageBox::No ) | 2110 | if ( KMessageBox::questionYesNo( this, i18n("After importing, phone numbers\nmay have two or more types.\n(E.g. work+voice)\nThese numbers are shown as \"other\".\nClick Yes to remove the voice type\nfrom numbers with more than one type.\n\nRemove voice type?") ) == KMessageBox::No ) |
2103 | return; | 2111 | return; |
2104 | KABC::Addressee::List list = mViewManager->selectedAddressees(); | 2112 | KABC::Addressee::List list = mViewManager->selectedAddressees(); |
2105 | KABC::Addressee::List::Iterator it; | 2113 | KABC::Addressee::List::Iterator it; |
2106 | for ( it = list.begin(); it != list.end(); ++it ) { | 2114 | for ( it = list.begin(); it != list.end(); ++it ) { |
2107 | 2115 | ||
2108 | if ( (*it).removeVoice() ) | 2116 | if ( (*it).removeVoice() ) |
2109 | contactModified((*it) ); | 2117 | contactModified((*it) ); |
2110 | } | 2118 | } |
2111 | } | 2119 | } |
2112 | 2120 | ||
2113 | 2121 | ||
2114 | 2122 | ||
2115 | void KABCore::clipboardDataChanged() | 2123 | void KABCore::clipboardDataChanged() |
2116 | { | 2124 | { |
2117 | 2125 | ||
2118 | if ( mReadWrite ) | 2126 | if ( mReadWrite ) |
2119 | mActionPaste->setEnabled( !QApplication::clipboard()->text().isEmpty() ); | 2127 | mActionPaste->setEnabled( !QApplication::clipboard()->text().isEmpty() ); |
2120 | 2128 | ||
2121 | } | 2129 | } |
2122 | 2130 | ||
2123 | void KABCore::updateActionMenu() | 2131 | void KABCore::updateActionMenu() |
2124 | { | 2132 | { |
2125 | UndoStack *undo = UndoStack::instance(); | 2133 | UndoStack *undo = UndoStack::instance(); |
2126 | RedoStack *redo = RedoStack::instance(); | 2134 | RedoStack *redo = RedoStack::instance(); |
2127 | 2135 | ||
2128 | if ( undo->isEmpty() ) | 2136 | if ( undo->isEmpty() ) |
2129 | mActionUndo->setText( i18n( "Undo" ) ); | 2137 | mActionUndo->setText( i18n( "Undo" ) ); |
2130 | else | 2138 | else |
2131 | mActionUndo->setText( i18n( "Undo %1" ).arg( undo->top()->name() ) ); | 2139 | mActionUndo->setText( i18n( "Undo %1" ).arg( undo->top()->name() ) ); |
2132 | 2140 | ||
2133 | mActionUndo->setEnabled( !undo->isEmpty() ); | 2141 | mActionUndo->setEnabled( !undo->isEmpty() ); |
2134 | 2142 | ||
2135 | if ( !redo->top() ) | 2143 | if ( !redo->top() ) |
2136 | mActionRedo->setText( i18n( "Redo" ) ); | 2144 | mActionRedo->setText( i18n( "Redo" ) ); |
2137 | else | 2145 | else |
2138 | mActionRedo->setText( i18n( "Redo %1" ).arg( redo->top()->name() ) ); | 2146 | mActionRedo->setText( i18n( "Redo %1" ).arg( redo->top()->name() ) ); |
2139 | 2147 | ||
2140 | mActionRedo->setEnabled( !redo->isEmpty() ); | 2148 | mActionRedo->setEnabled( !redo->isEmpty() ); |
2141 | } | 2149 | } |
2142 | 2150 | ||
2143 | void KABCore::configureKeyBindings() | 2151 | void KABCore::configureKeyBindings() |
2144 | { | 2152 | { |
2145 | #ifndef KAB_EMBEDDED | 2153 | #ifndef KAB_EMBEDDED |
2146 | KKeyDialog::configure( actionCollection(), true ); | 2154 | KKeyDialog::configure( actionCollection(), true ); |
2147 | #else //KAB_EMBEDDED | 2155 | #else //KAB_EMBEDDED |
2148 | qDebug("KABCore::configureKeyBindings() not implemented"); | 2156 | qDebug("KABCore::configureKeyBindings() not implemented"); |
2149 | #endif //KAB_EMBEDDED | 2157 | #endif //KAB_EMBEDDED |
2150 | } | 2158 | } |
2151 | 2159 | ||
@@ -2257,193 +2265,200 @@ void KABCore::requestForDetails(const QString& sourceChannel, const QString& ses | |||
2257 | { | 2265 | { |
2258 | qDebug("KABCore::requestForDetails %s %s %s %s %s", sourceChannel.latin1(), sessionuid.latin1(), name.latin1(), email.latin1(), uid.latin1()); | 2266 | qDebug("KABCore::requestForDetails %s %s %s %s %s", sourceChannel.latin1(), sessionuid.latin1(), name.latin1(), email.latin1(), uid.latin1()); |
2259 | 2267 | ||
2260 | QString foundUid = QString::null; | 2268 | QString foundUid = QString::null; |
2261 | if ( ! uid.isEmpty() ) { | 2269 | if ( ! uid.isEmpty() ) { |
2262 | Addressee adrr = mAddressBook->findByUid( uid ); | 2270 | Addressee adrr = mAddressBook->findByUid( uid ); |
2263 | if ( !adrr.isEmpty() ) { | 2271 | if ( !adrr.isEmpty() ) { |
2264 | foundUid = uid; | 2272 | foundUid = uid; |
2265 | } | 2273 | } |
2266 | if ( email == "sendbacklist" ) { | 2274 | if ( email == "sendbacklist" ) { |
2267 | //qDebug("ssssssssssssssssssssssend "); | 2275 | //qDebug("ssssssssssssssssssssssend "); |
2268 | QStringList nameList; | 2276 | QStringList nameList; |
2269 | QStringList emailList; | 2277 | QStringList emailList; |
2270 | QStringList uidList; | 2278 | QStringList uidList; |
2271 | nameList.append(adrr.realName()); | 2279 | nameList.append(adrr.realName()); |
2272 | emailList = adrr.emails(); | 2280 | emailList = adrr.emails(); |
2273 | uidList.append( adrr.preferredEmail()); | 2281 | uidList.append( adrr.preferredEmail()); |
2274 | bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI("QPE/Application/ompi", uid, nameList, emailList, uidList); | 2282 | bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI("QPE/Application/ompi", uid, nameList, emailList, uidList); |
2275 | return; | 2283 | return; |
2276 | } | 2284 | } |
2277 | 2285 | ||
2278 | } | 2286 | } |
2279 | 2287 | ||
2280 | if ( email == "sendbacklist" ) | 2288 | if ( email == "sendbacklist" ) |
2281 | return; | 2289 | return; |
2282 | if (foundUid.isEmpty()) | 2290 | if (foundUid.isEmpty()) |
2283 | { | 2291 | { |
2284 | //find the uid of the person first | 2292 | //find the uid of the person first |
2285 | Addressee::List namelist; | 2293 | Addressee::List namelist; |
2286 | Addressee::List emaillist; | 2294 | Addressee::List emaillist; |
2287 | 2295 | ||
2288 | if (!name.isEmpty()) | 2296 | if (!name.isEmpty()) |
2289 | namelist = mAddressBook->findByName( name ); | 2297 | namelist = mAddressBook->findByName( name ); |
2290 | 2298 | ||
2291 | if (!email.isEmpty()) | 2299 | if (!email.isEmpty()) |
2292 | emaillist = mAddressBook->findByEmail( email ); | 2300 | emaillist = mAddressBook->findByEmail( email ); |
2293 | qDebug("count %d %d ", namelist.count(),emaillist.count() ); | 2301 | qDebug("count %d %d ", namelist.count(),emaillist.count() ); |
2294 | //check if we have a match in Namelist and Emaillist | 2302 | //check if we have a match in Namelist and Emaillist |
2295 | if ((namelist.count() == 0) && (emaillist.count() > 0)) { | 2303 | if ((namelist.count() == 0) && (emaillist.count() > 0)) { |
2296 | foundUid = emaillist[0].uid(); | 2304 | foundUid = emaillist[0].uid(); |
2297 | } | 2305 | } |
2298 | else if ((namelist.count() > 0) && (emaillist.count() == 0)) | 2306 | else if ((namelist.count() > 0) && (emaillist.count() == 0)) |
2299 | foundUid = namelist[0].uid(); | 2307 | foundUid = namelist[0].uid(); |
2300 | else | 2308 | else |
2301 | { | 2309 | { |
2302 | for (int i = 0; i < namelist.count(); i++) | 2310 | for (int i = 0; i < namelist.count(); i++) |
2303 | { | 2311 | { |
2304 | for (int j = 0; j < emaillist.count(); j++) | 2312 | for (int j = 0; j < emaillist.count(); j++) |
2305 | { | 2313 | { |
2306 | if (namelist[i] == emaillist[j]) | 2314 | if (namelist[i] == emaillist[j]) |
2307 | { | 2315 | { |
2308 | foundUid = namelist[i].uid(); | 2316 | foundUid = namelist[i].uid(); |
2309 | } | 2317 | } |
2310 | } | 2318 | } |
2311 | } | 2319 | } |
2312 | } | 2320 | } |
2313 | } | 2321 | } |
2314 | else | 2322 | else |
2315 | { | 2323 | { |
2316 | foundUid = uid; | 2324 | foundUid = uid; |
2317 | } | 2325 | } |
2318 | 2326 | ||
2319 | if (!foundUid.isEmpty()) | 2327 | if (!foundUid.isEmpty()) |
2320 | { | 2328 | { |
2321 | 2329 | ||
2322 | // raise Ka/Pi if it is in the background | 2330 | // raise Ka/Pi if it is in the background |
2323 | #ifndef DESKTOP_VERSION | 2331 | #ifndef DESKTOP_VERSION |
2324 | #ifndef KORG_NODCOP | 2332 | #ifndef KORG_NODCOP |
2325 | //QCopEnvelope e("QPE/Application/kapi", "raise()"); | 2333 | //QCopEnvelope e("QPE/Application/kapi", "raise()"); |
2326 | #endif | 2334 | #endif |
2327 | #endif | 2335 | #endif |
2328 | 2336 | ||
2329 | mMainWindow->showMaximized(); | 2337 | mMainWindow->showMaximized(); |
2330 | mMainWindow-> raise(); | 2338 | mMainWindow-> raise(); |
2331 | 2339 | ||
2332 | mViewManager->setSelected( "", false); | 2340 | mViewManager->setSelected( "", false); |
2333 | mViewManager->refreshView( "" ); | 2341 | mViewManager->refreshView( "" ); |
2334 | mViewManager->setSelected( foundUid, true ); | 2342 | mViewManager->setSelected( foundUid, true ); |
2335 | mViewManager->refreshView( foundUid ); | 2343 | mViewManager->refreshView( foundUid ); |
2336 | 2344 | ||
2337 | if ( !mMultipleViewsAtOnce ) | 2345 | if ( !mMultipleViewsAtOnce ) |
2338 | { | 2346 | { |
2339 | setDetailsVisible( true ); | 2347 | setDetailsVisible( true ); |
2340 | mActionDetails->setChecked(true); | 2348 | mActionDetails->setChecked(true); |
2341 | } | 2349 | } |
2342 | } | 2350 | } |
2343 | } | 2351 | } |
2344 | 2352 | ||
2345 | void KABCore::whatsnew() | 2353 | void KABCore::whatsnew() |
2346 | { | 2354 | { |
2347 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); | 2355 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); |
2348 | } | 2356 | } |
2349 | void KABCore::synchowto() | 2357 | void KABCore::synchowto() |
2350 | { | 2358 | { |
2351 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); | 2359 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); |
2352 | } | 2360 | } |
2353 | 2361 | void KABCore::kdesynchowto() | |
2362 | { | ||
2363 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" ); | ||
2364 | } | ||
2365 | void KABCore::multisynchowto() | ||
2366 | { | ||
2367 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" ); | ||
2368 | } | ||
2354 | void KABCore::faq() | 2369 | void KABCore::faq() |
2355 | { | 2370 | { |
2356 | KApplication::showFile( "KA/Pi FAQ", "kdepim/kaddressbook/kapiFAQ.txt" ); | 2371 | KApplication::showFile( "KA/Pi FAQ", "kdepim/kaddressbook/kapiFAQ.txt" ); |
2357 | } | 2372 | } |
2358 | 2373 | ||
2359 | #include <libkcal/syncdefines.h> | 2374 | #include <libkcal/syncdefines.h> |
2360 | 2375 | ||
2361 | KABC::Addressee KABCore::getLastSyncAddressee() | 2376 | KABC::Addressee KABCore::getLastSyncAddressee() |
2362 | { | 2377 | { |
2363 | Addressee lse; | 2378 | Addressee lse; |
2364 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); | 2379 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); |
2365 | 2380 | ||
2366 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); | 2381 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); |
2367 | lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice ); | 2382 | lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice ); |
2368 | if (lse.isEmpty()) { | 2383 | if (lse.isEmpty()) { |
2369 | qDebug("Creating new last-syncAddressee "); | 2384 | qDebug("Creating new last-syncAddressee "); |
2370 | lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice ); | 2385 | lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice ); |
2371 | QString sum = ""; | 2386 | QString sum = ""; |
2372 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) | 2387 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) |
2373 | sum = "E: "; | 2388 | sum = "E: "; |
2374 | lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event")); | 2389 | lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event")); |
2375 | lse.setRevision( mLastAddressbookSync ); | 2390 | lse.setRevision( mLastAddressbookSync ); |
2376 | lse.setCategories( i18n("SyncEvent") ); | 2391 | lse.setCategories( i18n("SyncEvent") ); |
2377 | mAddressBook->insertAddressee( lse ); | 2392 | mAddressBook->insertAddressee( lse ); |
2378 | } | 2393 | } |
2379 | return lse; | 2394 | return lse; |
2380 | } | 2395 | } |
2381 | int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) | 2396 | int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) |
2382 | { | 2397 | { |
2383 | 2398 | ||
2384 | //void setZaurusId(int id); | 2399 | //void setZaurusId(int id); |
2385 | // int zaurusId() const; | 2400 | // int zaurusId() const; |
2386 | // void setZaurusUid(int id); | 2401 | // void setZaurusUid(int id); |
2387 | // int zaurusUid() const; | 2402 | // int zaurusUid() const; |
2388 | // void setZaurusStat(int id); | 2403 | // void setZaurusStat(int id); |
2389 | // int zaurusStat() const; | 2404 | // int zaurusStat() const; |
2390 | // 0 equal | 2405 | // 0 equal |
2391 | // 1 take local | 2406 | // 1 take local |
2392 | // 2 take remote | 2407 | // 2 take remote |
2393 | // 3 cancel | 2408 | // 3 cancel |
2394 | QDateTime lastSync = mLastAddressbookSync; | 2409 | QDateTime lastSync = mLastAddressbookSync; |
2395 | QDateTime localMod = local->revision(); | 2410 | QDateTime localMod = local->revision(); |
2396 | QDateTime remoteMod = remote->revision(); | 2411 | QDateTime remoteMod = remote->revision(); |
2397 | 2412 | ||
2398 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); | 2413 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); |
2399 | 2414 | ||
2400 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 2415 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
2401 | bool remCh, locCh; | 2416 | bool remCh, locCh; |
2402 | remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); | 2417 | remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); |
2403 | 2418 | ||
2404 | //qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); | 2419 | //qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); |
2405 | locCh = ( localMod > mLastAddressbookSync ); | 2420 | locCh = ( localMod > mLastAddressbookSync ); |
2406 | if ( !remCh && ! locCh ) { | 2421 | if ( !remCh && ! locCh ) { |
2407 | //qDebug("both not changed "); | 2422 | //qDebug("both not changed "); |
2408 | lastSync = localMod.addDays(1); | 2423 | lastSync = localMod.addDays(1); |
2409 | if ( mode <= SYNC_PREF_ASK ) | 2424 | if ( mode <= SYNC_PREF_ASK ) |
2410 | return 0; | 2425 | return 0; |
2411 | } else { | 2426 | } else { |
2412 | if ( locCh ) { | 2427 | if ( locCh ) { |
2413 | //qDebug("loc changed %s %s", localMod.toString().latin1(), mLastAddressbookSync.toString().latin1()); | 2428 | //qDebug("loc changed %s %s", localMod.toString().latin1(), mLastAddressbookSync.toString().latin1()); |
2414 | lastSync = localMod.addDays( -1 ); | 2429 | lastSync = localMod.addDays( -1 ); |
2415 | if ( !remCh ) | 2430 | if ( !remCh ) |
2416 | remoteMod =( lastSync.addDays( -1 ) ); | 2431 | remoteMod =( lastSync.addDays( -1 ) ); |
2417 | } else { | 2432 | } else { |
2418 | //qDebug(" not loc changed "); | 2433 | //qDebug(" not loc changed "); |
2419 | lastSync = localMod.addDays( 1 ); | 2434 | lastSync = localMod.addDays( 1 ); |
2420 | if ( remCh ) | 2435 | if ( remCh ) |
2421 | remoteMod =( lastSync.addDays( 1 ) ); | 2436 | remoteMod =( lastSync.addDays( 1 ) ); |
2422 | 2437 | ||
2423 | } | 2438 | } |
2424 | } | 2439 | } |
2425 | full = true; | 2440 | full = true; |
2426 | if ( mode < SYNC_PREF_ASK ) | 2441 | if ( mode < SYNC_PREF_ASK ) |
2427 | mode = SYNC_PREF_ASK; | 2442 | mode = SYNC_PREF_ASK; |
2428 | } else { | 2443 | } else { |
2429 | if ( localMod == remoteMod ) | 2444 | if ( localMod == remoteMod ) |
2430 | return 0; | 2445 | return 0; |
2431 | 2446 | ||
2432 | } | 2447 | } |
2433 | // qDebug(" %d %d conflict on %s %s ", mode, full, local->summary().latin1(), remote->summary().latin1() ); | 2448 | // qDebug(" %d %d conflict on %s %s ", mode, full, local->summary().latin1(), remote->summary().latin1() ); |
2434 | 2449 | ||
2435 | //qDebug("%s %d %s %d", local->lastModified().toString().latin1() , localMod, remote->lastModified().toString().latin1(), remoteMod); | 2450 | //qDebug("%s %d %s %d", local->lastModified().toString().latin1() , localMod, remote->lastModified().toString().latin1(), remoteMod); |
2436 | //qDebug("%d %d %d %d ", local->lastModified().time().second(), local->lastModified().time().msec(), remote->lastModified().time().second(), remote->lastModified().time().msec() ); | 2451 | //qDebug("%d %d %d %d ", local->lastModified().time().second(), local->lastModified().time().msec(), remote->lastModified().time().second(), remote->lastModified().time().msec() ); |
2437 | //full = true; //debug only | 2452 | //full = true; //debug only |
2438 | if ( full ) { | 2453 | if ( full ) { |
2439 | bool equ = ( (*local) == (*remote) ); | 2454 | bool equ = ( (*local) == (*remote) ); |
2440 | if ( equ ) { | 2455 | if ( equ ) { |
2441 | //qDebug("equal "); | 2456 | //qDebug("equal "); |
2442 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 2457 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
2443 | local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); | 2458 | local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); |
2444 | } | 2459 | } |
2445 | if ( mode < SYNC_PREF_FORCE_LOCAL ) | 2460 | if ( mode < SYNC_PREF_FORCE_LOCAL ) |
2446 | return 0; | 2461 | return 0; |
2447 | 2462 | ||
2448 | }//else //debug only | 2463 | }//else //debug only |
2449 | //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); | 2464 | //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); |
@@ -2685,271 +2700,276 @@ bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBo | |||
2685 | inR.setRevision( modifiedCalendar ); | 2700 | inR.setRevision( modifiedCalendar ); |
2686 | remote->insertAddressee( inR, false ); | 2701 | remote->insertAddressee( inR, false ); |
2687 | inR.setResource( 0 ); | 2702 | inR.setResource( 0 ); |
2688 | local->insertAddressee( inR, false ); | 2703 | local->insertAddressee( inR, false ); |
2689 | ++addedAddressee; | 2704 | ++addedAddressee; |
2690 | } else { | 2705 | } else { |
2691 | // pending checkExternSyncAddressee(addresseeRSyncSharp, inR); | 2706 | // pending checkExternSyncAddressee(addresseeRSyncSharp, inR); |
2692 | remote->removeAddressee( inR ); | 2707 | remote->removeAddressee( inR ); |
2693 | ++deletedAddresseeR; | 2708 | ++deletedAddresseeR; |
2694 | } | 2709 | } |
2695 | } | 2710 | } |
2696 | } | 2711 | } |
2697 | } | 2712 | } |
2698 | ++incCounter; | 2713 | ++incCounter; |
2699 | } | 2714 | } |
2700 | er.clear(); | 2715 | er.clear(); |
2701 | QStringList el = local->uidList(); | 2716 | QStringList el = local->uidList(); |
2702 | modulo = (el.count()/10)+1; | 2717 | modulo = (el.count()/10)+1; |
2703 | 2718 | ||
2704 | syncManager->showProgressBar(0, i18n("Add / remove addressees"), el.count()); | 2719 | syncManager->showProgressBar(0, i18n("Add / remove addressees"), el.count()); |
2705 | incCounter = 0; | 2720 | incCounter = 0; |
2706 | while ( incCounter < el.count()) { | 2721 | while ( incCounter < el.count()) { |
2707 | qApp->processEvents(); | 2722 | qApp->processEvents(); |
2708 | if (syncManager->isProgressBarCanceled()) | 2723 | if (syncManager->isProgressBarCanceled()) |
2709 | return false; | 2724 | return false; |
2710 | if ( incCounter % modulo == 0 ) | 2725 | if ( incCounter % modulo == 0 ) |
2711 | syncManager->showProgressBar(incCounter); | 2726 | syncManager->showProgressBar(incCounter); |
2712 | uid = el[ incCounter ]; | 2727 | uid = el[ incCounter ]; |
2713 | bool skipIncidence = false; | 2728 | bool skipIncidence = false; |
2714 | if ( uid.left(19) == QString("last-syncAddressee-") ) | 2729 | if ( uid.left(19) == QString("last-syncAddressee-") ) |
2715 | skipIncidence = true; | 2730 | skipIncidence = true; |
2716 | if ( !skipIncidence ) { | 2731 | if ( !skipIncidence ) { |
2717 | inL = local->findByUid( uid ); | 2732 | inL = local->findByUid( uid ); |
2718 | if ( !inL.resource() || inL.resource()->includeInSync() ) { | 2733 | if ( !inL.resource() || inL.resource()->includeInSync() ) { |
2719 | inR = remote->findByUid( uid ); | 2734 | inR = remote->findByUid( uid ); |
2720 | if ( inR.isEmpty() ) { | 2735 | if ( inR.isEmpty() ) { |
2721 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 2736 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
2722 | if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { | 2737 | if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { |
2723 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); | 2738 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); |
2724 | local->removeAddressee( inL ); | 2739 | local->removeAddressee( inL ); |
2725 | ++deletedAddresseeL; | 2740 | ++deletedAddresseeL; |
2726 | } else { | 2741 | } else { |
2727 | if ( ! syncManager->mWriteBackExistingOnly ) { | 2742 | if ( ! syncManager->mWriteBackExistingOnly ) { |
2728 | inL.removeID(mCurrentSyncDevice ); | 2743 | inL.removeID(mCurrentSyncDevice ); |
2729 | ++addedAddresseeR; | 2744 | ++addedAddresseeR; |
2730 | inL.setRevision( modifiedCalendar ); | 2745 | inL.setRevision( modifiedCalendar ); |
2731 | local->insertAddressee( inL, false ); | 2746 | local->insertAddressee( inL, false ); |
2732 | inR = inL; | 2747 | inR = inL; |
2733 | inR.setTempSyncStat( SYNC_TEMPSTATE_ADDED_EXTERNAL ); | 2748 | inR.setTempSyncStat( SYNC_TEMPSTATE_ADDED_EXTERNAL ); |
2734 | inR.setResource( 0 ); | 2749 | inR.setResource( 0 ); |
2735 | remote->insertAddressee( inR, false ); | 2750 | remote->insertAddressee( inR, false ); |
2736 | } | 2751 | } |
2737 | } | 2752 | } |
2738 | } else { | 2753 | } else { |
2739 | if ( inL.revision() < mLastAddressbookSync && mode != 4 ) { | 2754 | if ( inL.revision() < mLastAddressbookSync && mode != 4 ) { |
2740 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); | 2755 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); |
2741 | local->removeAddressee( inL ); | 2756 | local->removeAddressee( inL ); |
2742 | ++deletedAddresseeL; | 2757 | ++deletedAddresseeL; |
2743 | } else { | 2758 | } else { |
2744 | if ( ! syncManager->mWriteBackExistingOnly ) { | 2759 | if ( ! syncManager->mWriteBackExistingOnly ) { |
2745 | ++addedAddresseeR; | 2760 | ++addedAddresseeR; |
2746 | inL.setRevision( modifiedCalendar ); | 2761 | inL.setRevision( modifiedCalendar ); |
2747 | local->insertAddressee( inL, false ); | 2762 | local->insertAddressee( inL, false ); |
2748 | inR = inL; | 2763 | inR = inL; |
2749 | inR.setResource( 0 ); | 2764 | inR.setResource( 0 ); |
2750 | remote->insertAddressee( inR, false ); | 2765 | remote->insertAddressee( inR, false ); |
2751 | } | 2766 | } |
2752 | } | 2767 | } |
2753 | } | 2768 | } |
2754 | } | 2769 | } |
2755 | } | 2770 | } |
2756 | } | 2771 | } |
2757 | ++incCounter; | 2772 | ++incCounter; |
2758 | } | 2773 | } |
2759 | el.clear(); | 2774 | el.clear(); |
2760 | syncManager->hideProgressBar(); | 2775 | syncManager->hideProgressBar(); |
2761 | mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); | 2776 | mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); |
2762 | // get rid of micro seconds | 2777 | // get rid of micro seconds |
2763 | QTime t = mLastAddressbookSync.time(); | 2778 | QTime t = mLastAddressbookSync.time(); |
2764 | mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); | 2779 | mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); |
2765 | addresseeLSync.setRevision( mLastAddressbookSync ); | 2780 | addresseeLSync.setRevision( mLastAddressbookSync ); |
2766 | addresseeRSync.setRevision( mLastAddressbookSync ); | 2781 | addresseeRSync.setRevision( mLastAddressbookSync ); |
2767 | addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ; | 2782 | addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ; |
2768 | addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName ); | 2783 | addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName ); |
2769 | addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ; | 2784 | addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ; |
2770 | addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") ); | 2785 | addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") ); |
2771 | addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ; | 2786 | addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ; |
2772 | addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() ); | 2787 | addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() ); |
2773 | addresseeRSync.setNote( "" ) ; | 2788 | addresseeRSync.setNote( "" ) ; |
2774 | addresseeLSync.setNote( "" ); | 2789 | addresseeLSync.setNote( "" ); |
2775 | 2790 | ||
2776 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) | 2791 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) |
2777 | remote->insertAddressee( addresseeRSync, false ); | 2792 | remote->insertAddressee( addresseeRSync, false ); |
2778 | local->insertAddressee( addresseeLSync, false ); | 2793 | local->insertAddressee( addresseeLSync, false ); |
2779 | QString mes; | 2794 | QString mes; |
2780 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n"),addedAddressee, addedAddresseeR, changedLocal, changedRemote, deletedAddresseeL, deletedAddresseeR ); | 2795 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n"),addedAddressee, addedAddresseeR, changedLocal, changedRemote, deletedAddresseeL, deletedAddresseeR ); |
2781 | if ( syncManager->mShowSyncSummary ) { | ||
2782 | KMessageBox::information(this, mes, i18n("KA/Pi Synchronization") ); | ||
2783 | } | ||
2784 | qDebug( mes ); | 2796 | qDebug( mes ); |
2797 | if ( syncManager->mShowSyncSummary ) { | ||
2798 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, | ||
2799 | i18n("KA/Pi Synchronization"),i18n("Write back"))) { | ||
2800 | qDebug("cancelled "); | ||
2801 | return false; | ||
2802 | } | ||
2803 | } | ||
2785 | return syncOK; | 2804 | return syncOK; |
2786 | } | 2805 | } |
2787 | 2806 | ||
2788 | 2807 | ||
2789 | //this is a overwritten callbackmethods from the syncinterface | 2808 | //this is a overwritten callbackmethods from the syncinterface |
2790 | bool KABCore::sync(KSyncManager* manager, QString filename, int mode) | 2809 | bool KABCore::sync(KSyncManager* manager, QString filename, int mode) |
2791 | { | 2810 | { |
2792 | 2811 | ||
2793 | //pending prepare addresseeview for output | 2812 | //pending prepare addresseeview for output |
2794 | //pending detect, if remote file has REV field. if not switch to external sync | 2813 | //pending detect, if remote file has REV field. if not switch to external sync |
2795 | mGlobalSyncMode = SYNC_MODE_NORMAL; | 2814 | mGlobalSyncMode = SYNC_MODE_NORMAL; |
2796 | QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); | 2815 | QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); |
2797 | 2816 | ||
2798 | AddressBook abLocal(filename,"syncContact"); | 2817 | AddressBook abLocal(filename,"syncContact"); |
2799 | bool syncOK = false; | 2818 | bool syncOK = false; |
2800 | if ( abLocal.load() ) { | 2819 | if ( abLocal.load() ) { |
2801 | qDebug("AB loaded %s,sync mode %d",filename.latin1(), mode ); | 2820 | qDebug("AB loaded %s,sync mode %d",filename.latin1(), mode ); |
2802 | bool external = false; | 2821 | bool external = false; |
2803 | bool isXML = false; | 2822 | bool isXML = false; |
2804 | if ( filename.right(4) == ".xml") { | 2823 | if ( filename.right(4) == ".xml") { |
2805 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 2824 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
2806 | isXML = true; | 2825 | isXML = true; |
2807 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); | 2826 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); |
2808 | } else { | 2827 | } else { |
2809 | external = !manager->mIsKapiFile; | 2828 | external = !manager->mIsKapiFile; |
2810 | if ( external ) { | 2829 | if ( external ) { |
2811 | qDebug("Setting vcf mode to external "); | 2830 | qDebug("Setting vcf mode to external "); |
2812 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 2831 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
2813 | AddressBook::Iterator it; | 2832 | AddressBook::Iterator it; |
2814 | for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { | 2833 | for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { |
2815 | (*it).setID( mCurrentSyncDevice, (*it).uid() ); | 2834 | (*it).setID( mCurrentSyncDevice, (*it).uid() ); |
2816 | (*it).computeCsum( mCurrentSyncDevice ); | 2835 | (*it).computeCsum( mCurrentSyncDevice ); |
2817 | } | 2836 | } |
2818 | } | 2837 | } |
2819 | } | 2838 | } |
2820 | //AddressBook::Iterator it; | 2839 | //AddressBook::Iterator it; |
2821 | //QStringList vcards; | 2840 | //QStringList vcards; |
2822 | //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { | 2841 | //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { |
2823 | // qDebug("Name %s ", (*it).familyName().latin1()); | 2842 | // qDebug("Name %s ", (*it).familyName().latin1()); |
2824 | //} | 2843 | //} |
2825 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode ); | 2844 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode ); |
2826 | if ( syncOK ) { | 2845 | if ( syncOK ) { |
2827 | if ( syncManager->mWriteBackFile ) | 2846 | if ( syncManager->mWriteBackFile ) |
2828 | { | 2847 | { |
2829 | if ( external ) | 2848 | if ( external ) |
2830 | abLocal.removeSyncAddressees( !isXML); | 2849 | abLocal.removeSyncAddressees( !isXML); |
2831 | qDebug("Saving remote AB "); | 2850 | qDebug("Saving remote AB "); |
2832 | if ( ! abLocal.saveAB()) | 2851 | if ( ! abLocal.saveAB()) |
2833 | qDebug("Error writing back AB to file "); | 2852 | qDebug("Error writing back AB to file "); |
2834 | if ( external ) { | 2853 | if ( external ) { |
2835 | // afterwrite processing | 2854 | // afterwrite processing |
2836 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice ,isXML); | 2855 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice ,isXML); |
2837 | } | 2856 | } |
2838 | } | 2857 | } |
2839 | } | 2858 | } |
2840 | setModified(); | 2859 | setModified(); |
2841 | 2860 | ||
2842 | } | 2861 | } |
2843 | if ( syncOK ) | 2862 | if ( syncOK ) |
2844 | mViewManager->refreshView(); | 2863 | mViewManager->refreshView(); |
2845 | return syncOK; | 2864 | return syncOK; |
2846 | 2865 | ||
2847 | } | 2866 | } |
2848 | void KABCore::removeSyncInfo( QString syncProfile) | 2867 | void KABCore::removeSyncInfo( QString syncProfile) |
2849 | { | 2868 | { |
2850 | qDebug("AB:removeSyncInfo for profile %s ", syncProfile.latin1()); | 2869 | qDebug("AB:removeSyncInfo for profile %s ", syncProfile.latin1()); |
2851 | mAddressBook->removeSyncInfo( syncProfile ); | 2870 | mAddressBook->removeSyncInfo( syncProfile ); |
2852 | setModified(); | 2871 | setModified(); |
2853 | } | 2872 | } |
2854 | 2873 | ||
2855 | 2874 | ||
2856 | //this is a overwritten callbackmethods from the syncinterface | 2875 | //this is a overwritten callbackmethods from the syncinterface |
2857 | bool KABCore::syncExternal(KSyncManager* manager, QString resource) | 2876 | bool KABCore::syncExternal(KSyncManager* manager, QString resource) |
2858 | { | 2877 | { |
2859 | if ( resource == "phone" ) | 2878 | if ( resource == "phone" ) |
2860 | return syncPhone(); | 2879 | return syncPhone(); |
2861 | disableBR( true ); | 2880 | disableBR( true ); |
2862 | QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); | 2881 | QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); |
2863 | 2882 | ||
2864 | AddressBook abLocal( resource,"syncContact"); | 2883 | AddressBook abLocal( resource,"syncContact"); |
2865 | bool syncOK = false; | 2884 | bool syncOK = false; |
2866 | if ( abLocal.load() ) { | 2885 | if ( abLocal.load() ) { |
2867 | qDebug("AB sharp loaded ,sync device %s",mCurrentSyncDevice.latin1()); | 2886 | qDebug("AB sharp loaded ,sync device %s",mCurrentSyncDevice.latin1()); |
2868 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 2887 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
2869 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, false ); | 2888 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, false ); |
2870 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); | 2889 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); |
2871 | if ( syncOK ) { | 2890 | if ( syncOK ) { |
2872 | if ( syncManager->mWriteBackFile ) { | 2891 | if ( syncManager->mWriteBackFile ) { |
2873 | abLocal.removeSyncAddressees( false ); | 2892 | abLocal.removeSyncAddressees( false ); |
2874 | abLocal.saveAB(); | 2893 | abLocal.saveAB(); |
2875 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); | 2894 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); |
2876 | } | 2895 | } |
2877 | } | 2896 | } else |
2897 | message( i18n("Sync cancelled or failed.") ); | ||
2878 | setModified(); | 2898 | setModified(); |
2879 | } | 2899 | } |
2880 | if ( syncOK ) | 2900 | if ( syncOK ) |
2881 | mViewManager->refreshView(); | 2901 | mViewManager->refreshView(); |
2882 | disableBR( false ); | 2902 | disableBR( false ); |
2883 | return syncOK; | 2903 | return syncOK; |
2884 | 2904 | ||
2885 | } | 2905 | } |
2886 | void KABCore::message( QString m ) | 2906 | void KABCore::message( QString m ) |
2887 | { | 2907 | { |
2888 | topLevelWidget()->setCaption( m ); | 2908 | topLevelWidget()->setCaption( m ); |
2889 | mMessageTimer->start( 15000, true ); | 2909 | mMessageTimer->start( 15000, true ); |
2890 | } | 2910 | } |
2891 | bool KABCore::syncPhone() | 2911 | bool KABCore::syncPhone() |
2892 | { | 2912 | { |
2893 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); | 2913 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); |
2894 | QString fileName = getPhoneFile(); | 2914 | QString fileName = getPhoneFile(); |
2895 | if ( !PhoneAccess::readFromPhone( fileName) ) { | 2915 | if ( !PhoneAccess::readFromPhone( fileName) ) { |
2896 | message(i18n("Phone access failed!")); | 2916 | message(i18n("Phone access failed!")); |
2897 | return false; | 2917 | return false; |
2898 | } | 2918 | } |
2899 | AddressBook abLocal( fileName,"syncContact"); | 2919 | AddressBook abLocal( fileName,"syncContact"); |
2900 | bool syncOK = false; | 2920 | bool syncOK = false; |
2901 | { | 2921 | { |
2902 | abLocal.importFromFile( fileName ); | 2922 | abLocal.importFromFile( fileName ); |
2903 | qDebug("AB phone loaded ,sync device %s",mCurrentSyncDevice.latin1()); | 2923 | qDebug("AB phone loaded ,sync device %s",mCurrentSyncDevice.latin1()); |
2904 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 2924 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
2905 | abLocal.preparePhoneSync( mCurrentSyncDevice, true ); | 2925 | abLocal.preparePhoneSync( mCurrentSyncDevice, true ); |
2906 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); | 2926 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); |
2907 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); | 2927 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); |
2908 | if ( syncOK ) { | 2928 | if ( syncOK ) { |
2909 | if ( syncManager->mWriteBackFile ) { | 2929 | if ( syncManager->mWriteBackFile ) { |
2910 | abLocal.removeSyncAddressees( true ); | 2930 | abLocal.removeSyncAddressees( true ); |
2911 | abLocal.saveABphone( fileName ); | 2931 | abLocal.saveABphone( fileName ); |
2912 | abLocal.findNewExtIds( fileName, mCurrentSyncDevice ); | 2932 | abLocal.findNewExtIds( fileName, mCurrentSyncDevice ); |
2913 | //abLocal.preparePhoneSync( mCurrentSyncDevice, false ); | 2933 | //abLocal.preparePhoneSync( mCurrentSyncDevice, false ); |
2914 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); | 2934 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); |
2915 | } | 2935 | } |
2916 | } | 2936 | } |
2917 | setModified(); | 2937 | setModified(); |
2918 | } | 2938 | } |
2919 | if ( syncOK ) | 2939 | if ( syncOK ) |
2920 | mViewManager->refreshView(); | 2940 | mViewManager->refreshView(); |
2921 | return syncOK; | 2941 | return syncOK; |
2922 | } | 2942 | } |
2923 | void KABCore::getFile( bool success ) | 2943 | void KABCore::getFile( bool success ) |
2924 | { | 2944 | { |
2925 | if ( ! success ) { | 2945 | if ( ! success ) { |
2926 | message( i18n("Error receiving file. Nothing changed!") ); | 2946 | message( i18n("Error receiving file. Nothing changed!") ); |
2927 | return; | 2947 | return; |
2928 | } | 2948 | } |
2929 | int count = mAddressBook->importFromFile( sentSyncFile() , false, true ); | 2949 | int count = mAddressBook->importFromFile( sentSyncFile() , false, true ); |
2930 | if ( count ) | 2950 | if ( count ) |
2931 | setModified( true ); | 2951 | setModified( true ); |
2932 | message( i18n("Pi-Sync successful!") ); | 2952 | message( i18n("Pi-Sync successful!") ); |
2933 | mViewManager->refreshView(); | 2953 | mViewManager->refreshView(); |
2934 | } | 2954 | } |
2935 | void KABCore::syncFileRequest() | 2955 | void KABCore::syncFileRequest() |
2936 | { | 2956 | { |
2937 | if ( KABPrefs::instance()->mPassiveSyncWithDesktop ) { | 2957 | if ( KABPrefs::instance()->mPassiveSyncWithDesktop ) { |
2938 | syncManager->slotSyncMenu( 999 ); | 2958 | syncManager->slotSyncMenu( 999 ); |
2939 | } | 2959 | } |
2940 | mAddressBook->export2File( sentSyncFile() ); | 2960 | mAddressBook->export2File( sentSyncFile() ); |
2941 | } | 2961 | } |
2942 | QString KABCore::sentSyncFile() | 2962 | QString KABCore::sentSyncFile() |
2943 | { | 2963 | { |
2944 | #ifdef DESKTOP_VERSION | 2964 | #ifdef DESKTOP_VERSION |
2945 | return locateLocal( "tmp", "copysyncab.vcf" ); | 2965 | return locateLocal( "tmp", "copysyncab.vcf" ); |
2946 | #else | 2966 | #else |
2947 | return QString( "/tmp/copysyncab.vcf" ); | 2967 | return QString( "/tmp/copysyncab.vcf" ); |
2948 | #endif | 2968 | #endif |
2949 | } | 2969 | } |
2950 | 2970 | ||
2951 | void KABCore::setCaptionBack() | 2971 | void KABCore::setCaptionBack() |
2952 | { | 2972 | { |
2953 | mMessageTimer->stop(); | 2973 | mMessageTimer->stop(); |
2954 | topLevelWidget()->setCaption( i18n("KAddressbook/Pi") ); | 2974 | topLevelWidget()->setCaption( i18n("KAddressbook/Pi") ); |
2955 | } | 2975 | } |
diff --git a/kaddressbook/kabcore.h b/kaddressbook/kabcore.h index 6831ec9..c01d598 100644 --- a/kaddressbook/kabcore.h +++ b/kaddressbook/kabcore.h | |||
@@ -59,192 +59,194 @@ class XXPortManager; | |||
59 | class JumpButtonBar; | 59 | class JumpButtonBar; |
60 | class IncSearchWidget; | 60 | class IncSearchWidget; |
61 | class KDGanttMinimizeSplitter; | 61 | class KDGanttMinimizeSplitter; |
62 | class KAction; | 62 | class KAction; |
63 | class KActionCollection; | 63 | class KActionCollection; |
64 | class KToggleAction; | 64 | class KToggleAction; |
65 | class KSyncProfile; | 65 | class KSyncProfile; |
66 | 66 | ||
67 | class QAction; | 67 | class QAction; |
68 | class QMenuBar; | 68 | class QMenuBar; |
69 | class QSplitter; | 69 | class QSplitter; |
70 | class ViewContainer; | 70 | class ViewContainer; |
71 | class ViewManager; | 71 | class ViewManager; |
72 | class AddresseeEditorDialog; | 72 | class AddresseeEditorDialog; |
73 | class Ir; | 73 | class Ir; |
74 | 74 | ||
75 | class KABCore : public QWidget, public KSyncInterface | 75 | class KABCore : public QWidget, public KSyncInterface |
76 | { | 76 | { |
77 | Q_OBJECT | 77 | Q_OBJECT |
78 | 78 | ||
79 | public: | 79 | public: |
80 | KABCore( KAddressBookMain *client, bool readWrite, QWidget *parent, const char *name = 0 ); | 80 | KABCore( KAddressBookMain *client, bool readWrite, QWidget *parent, const char *name = 0 ); |
81 | 81 | ||
82 | 82 | ||
83 | ~KABCore(); | 83 | ~KABCore(); |
84 | 84 | ||
85 | 85 | ||
86 | #ifdef KAB_EMBEDDED | 86 | #ifdef KAB_EMBEDDED |
87 | //US added functionality | 87 | //US added functionality |
88 | QPopupMenu* getViewMenu() {return viewMenu;} | 88 | QPopupMenu* getViewMenu() {return viewMenu;} |
89 | QPopupMenu* getFilterMenu() {return filterMenu;} | 89 | QPopupMenu* getFilterMenu() {return filterMenu;} |
90 | QPopupMenu* getSettingsMenu() {return settingsMenu;} | 90 | QPopupMenu* getSettingsMenu() {return settingsMenu;} |
91 | void addActionsManually(); | 91 | void addActionsManually(); |
92 | #endif //KAB_EMBEDDED | 92 | #endif //KAB_EMBEDDED |
93 | /** | 93 | /** |
94 | Restores the global settings. | 94 | Restores the global settings. |
95 | */ | 95 | */ |
96 | void restoreSettings(); | 96 | void restoreSettings(); |
97 | 97 | ||
98 | /** | 98 | /** |
99 | Saves the global settings. | 99 | Saves the global settings. |
100 | */ | 100 | */ |
101 | void saveSettings(); | 101 | void saveSettings(); |
102 | 102 | ||
103 | /** | 103 | /** |
104 | Returns a pointer to the StdAddressBook of the application. | 104 | Returns a pointer to the StdAddressBook of the application. |
105 | */ | 105 | */ |
106 | KABC::AddressBook *addressBook() const; | 106 | KABC::AddressBook *addressBook() const; |
107 | 107 | ||
108 | /** | 108 | /** |
109 | Returns a pointer to the KConfig object of the application. | 109 | Returns a pointer to the KConfig object of the application. |
110 | */ | 110 | */ |
111 | static KConfig *config(); | 111 | static KConfig *config(); |
112 | 112 | ||
113 | /** | 113 | /** |
114 | Returns a pointer to the global KActionCollection object. So | 114 | Returns a pointer to the global KActionCollection object. So |
115 | other classes can register their actions easily. | 115 | other classes can register their actions easily. |
116 | */ | 116 | */ |
117 | KActionCollection *actionCollection() const; | 117 | KActionCollection *actionCollection() const; |
118 | 118 | ||
119 | /** | 119 | /** |
120 | Returns the current search field of the Incremental Search Widget. | 120 | Returns the current search field of the Incremental Search Widget. |
121 | */ | 121 | */ |
122 | KABC::Field *currentSearchField() const; | 122 | KABC::Field *currentSearchField() const; |
123 | 123 | ||
124 | /** | 124 | /** |
125 | Returns the uid list of the currently selected contacts. | 125 | Returns the uid list of the currently selected contacts. |
126 | */ | 126 | */ |
127 | QStringList selectedUIDs() const; | 127 | QStringList selectedUIDs() const; |
128 | 128 | ||
129 | /** | 129 | /** |
130 | Displays the ResourceSelectDialog and returns the selected | 130 | Displays the ResourceSelectDialog and returns the selected |
131 | resource or a null pointer if no resource was selected by | 131 | resource or a null pointer if no resource was selected by |
132 | the user. | 132 | the user. |
133 | */ | 133 | */ |
134 | KABC::Resource *requestResource( QWidget *parent ); | 134 | KABC::Resource *requestResource( QWidget *parent ); |
135 | 135 | ||
136 | #ifndef KAB_EMBEDDED | 136 | #ifndef KAB_EMBEDDED |
137 | static KAboutData *createAboutData(); | 137 | static KAboutData *createAboutData(); |
138 | #endif //KAB_EMBEDDED | 138 | #endif //KAB_EMBEDDED |
139 | 139 | ||
140 | #ifdef KAB_EMBEDDED | 140 | #ifdef KAB_EMBEDDED |
141 | inline QPopupMenu* getImportMenu() { return ImportMenu;} | 141 | inline QPopupMenu* getImportMenu() { return ImportMenu;} |
142 | inline QPopupMenu* getExportMenu() { return ExportMenu;} | 142 | inline QPopupMenu* getExportMenu() { return ExportMenu;} |
143 | #endif //KAB_EMBEDDED | 143 | #endif //KAB_EMBEDDED |
144 | 144 | ||
145 | public slots: | 145 | public slots: |
146 | #ifdef KAB_EMBEDDED | 146 | #ifdef KAB_EMBEDDED |
147 | void createAboutData(); | 147 | void createAboutData(); |
148 | #endif //KAB_EMBEDDED | 148 | #endif //KAB_EMBEDDED |
149 | void setDetailsToggle(); | 149 | void setDetailsToggle(); |
150 | 150 | ||
151 | void showLicence(); | 151 | void showLicence(); |
152 | void faq(); | 152 | void faq(); |
153 | void whatsnew() ; | 153 | void whatsnew() ; |
154 | void synchowto() ; | 154 | void synchowto() ; |
155 | void multisynchowto() ; | ||
156 | void kdesynchowto() ; | ||
155 | void writeToPhone(); | 157 | void writeToPhone(); |
156 | 158 | ||
157 | /** | 159 | /** |
158 | Is called whenever a contact is selected in the view. | 160 | Is called whenever a contact is selected in the view. |
159 | */ | 161 | */ |
160 | void setContactSelected( const QString &uid ); | 162 | void setContactSelected( const QString &uid ); |
161 | 163 | ||
162 | /** | 164 | /** |
163 | Opens the preferred mail composer with all selected contacts as | 165 | Opens the preferred mail composer with all selected contacts as |
164 | arguments. | 166 | arguments. |
165 | */ | 167 | */ |
166 | void sendMail(); | 168 | void sendMail(); |
167 | 169 | ||
168 | /** | 170 | /** |
169 | Opens the preferred mail composer with the given contacts as | 171 | Opens the preferred mail composer with the given contacts as |
170 | arguments. | 172 | arguments. |
171 | */ | 173 | */ |
172 | void sendMail( const QString& email ); | 174 | void sendMail( const QString& email ); |
173 | 175 | ||
174 | 176 | ||
175 | void mailVCard(); | 177 | void mailVCard(); |
176 | void mailVCard(const QStringList& uids); | 178 | void mailVCard(const QStringList& uids); |
177 | 179 | ||
178 | /** | 180 | /** |
179 | Beams the "WhoAmI contact. | 181 | Beams the "WhoAmI contact. |
180 | */ | 182 | */ |
181 | void beamMySelf(); | 183 | void beamMySelf(); |
182 | 184 | ||
183 | void beamVCard(); | 185 | void beamVCard(); |
184 | void export2phone(); | 186 | void export2phone(); |
185 | void beamVCard(const QStringList& uids); | 187 | void beamVCard(const QStringList& uids); |
186 | void beamDone( Ir *ir ); | 188 | void beamDone( Ir *ir ); |
187 | 189 | ||
188 | 190 | ||
189 | /** | 191 | /** |
190 | Starts the preferred web browser with the given URL as argument. | 192 | Starts the preferred web browser with the given URL as argument. |
191 | */ | 193 | */ |
192 | void browse( const QString& url ); | 194 | void browse( const QString& url ); |
193 | 195 | ||
194 | /** | 196 | /** |
195 | Select all contacts in the view. | 197 | Select all contacts in the view. |
196 | */ | 198 | */ |
197 | void selectAllContacts(); | 199 | void selectAllContacts(); |
198 | 200 | ||
199 | /** | 201 | /** |
200 | Deletes all selected contacts from the address book. | 202 | Deletes all selected contacts from the address book. |
201 | */ | 203 | */ |
202 | void deleteContacts(); | 204 | void deleteContacts(); |
203 | 205 | ||
204 | /** | 206 | /** |
205 | Deletes given contacts from the address book. | 207 | Deletes given contacts from the address book. |
206 | 208 | ||
207 | @param uids The uids of the contacts, which shall be deleted. | 209 | @param uids The uids of the contacts, which shall be deleted. |
208 | */ | 210 | */ |
209 | void deleteContacts( const QStringList &uids ); | 211 | void deleteContacts( const QStringList &uids ); |
210 | 212 | ||
211 | /** | 213 | /** |
212 | Copys the selected contacts into clipboard for later pasting. | 214 | Copys the selected contacts into clipboard for later pasting. |
213 | */ | 215 | */ |
214 | void copyContacts(); | 216 | void copyContacts(); |
215 | 217 | ||
216 | /** | 218 | /** |
217 | Cuts the selected contacts and stores them for later pasting. | 219 | Cuts the selected contacts and stores them for later pasting. |
218 | */ | 220 | */ |
219 | void cutContacts(); | 221 | void cutContacts(); |
220 | 222 | ||
221 | /** | 223 | /** |
222 | Paste contacts from clipboard into the address book. | 224 | Paste contacts from clipboard into the address book. |
223 | */ | 225 | */ |
224 | void pasteContacts(); | 226 | void pasteContacts(); |
225 | 227 | ||
226 | /** | 228 | /** |
227 | Paste given contacts into the address book. | 229 | Paste given contacts into the address book. |
228 | 230 | ||
229 | @param list The list of addressee, which shall be pasted. | 231 | @param list The list of addressee, which shall be pasted. |
230 | */ | 232 | */ |
231 | void pasteContacts( KABC::Addressee::List &list ); | 233 | void pasteContacts( KABC::Addressee::List &list ); |
232 | 234 | ||
233 | /** | 235 | /** |
234 | Sets the whoAmI contact, that is used by many other programs to | 236 | Sets the whoAmI contact, that is used by many other programs to |
235 | get personal information about the current user. | 237 | get personal information about the current user. |
236 | */ | 238 | */ |
237 | void setWhoAmI(); | 239 | void setWhoAmI(); |
238 | 240 | ||
239 | /** | 241 | /** |
240 | Displays the category dialog and applies the result to all | 242 | Displays the category dialog and applies the result to all |
241 | selected contacts. | 243 | selected contacts. |
242 | */ | 244 | */ |
243 | void setCategories(); | 245 | void setCategories(); |
244 | 246 | ||
245 | /** | 247 | /** |
246 | Sets the field list of the Incremental Search Widget. | 248 | Sets the field list of the Incremental Search Widget. |
247 | */ | 249 | */ |
248 | void setSearchFields( const KABC::Field::List &fields ); | 250 | void setSearchFields( const KABC::Field::List &fields ); |
249 | 251 | ||
250 | /** | 252 | /** |
@@ -361,144 +363,146 @@ class KABCore : public QWidget, public KSyncInterface | |||
361 | void disableBR(bool); | 363 | void disableBR(bool); |
362 | void setJumpButtonBarVisible( bool visible ); | 364 | void setJumpButtonBarVisible( bool visible ); |
363 | void setCaptionBack(); | 365 | void setCaptionBack(); |
364 | void importFromOL(); | 366 | void importFromOL(); |
365 | void extensionModified( const KABC::Addressee::List &list ); | 367 | void extensionModified( const KABC::Addressee::List &list ); |
366 | void extensionChanged( int id ); | 368 | void extensionChanged( int id ); |
367 | void clipboardDataChanged(); | 369 | void clipboardDataChanged(); |
368 | void updateActionMenu(); | 370 | void updateActionMenu(); |
369 | void configureKeyBindings(); | 371 | void configureKeyBindings(); |
370 | void removeVoice(); | 372 | void removeVoice(); |
371 | #ifdef KAB_EMBEDDED | 373 | #ifdef KAB_EMBEDDED |
372 | void configureResources(); | 374 | void configureResources(); |
373 | #endif //KAB_EMBEDDED | 375 | #endif //KAB_EMBEDDED |
374 | 376 | ||
375 | void slotEditorDestroyed( const QString &uid ); | 377 | void slotEditorDestroyed( const QString &uid ); |
376 | void configurationChanged(); | 378 | void configurationChanged(); |
377 | void addressBookChanged(); | 379 | void addressBookChanged(); |
378 | 380 | ||
379 | private: | 381 | private: |
380 | bool mBRdisabled; | 382 | bool mBRdisabled; |
381 | #ifndef DESKTOP_VERSION | 383 | #ifndef DESKTOP_VERSION |
382 | QCopChannel* infrared; | 384 | QCopChannel* infrared; |
383 | #endif | 385 | #endif |
384 | QTimer *mMessageTimer; | 386 | QTimer *mMessageTimer; |
385 | void initGUI(); | 387 | void initGUI(); |
386 | void initActions(); | 388 | void initActions(); |
387 | QString getPhoneFile(); | 389 | QString getPhoneFile(); |
388 | 390 | ||
389 | AddresseeEditorDialog *createAddresseeEditorDialog( QWidget *parent, | 391 | AddresseeEditorDialog *createAddresseeEditorDialog( QWidget *parent, |
390 | const char *name = 0 ); | 392 | const char *name = 0 ); |
391 | 393 | ||
392 | KXMLGUIClient *mGUIClient; | 394 | KXMLGUIClient *mGUIClient; |
393 | 395 | ||
394 | KABC::AddressBook *mAddressBook; | 396 | KABC::AddressBook *mAddressBook; |
395 | 397 | ||
396 | ViewManager *mViewManager; | 398 | ViewManager *mViewManager; |
397 | // QSplitter *mDetailsSplitter; | 399 | // QSplitter *mDetailsSplitter; |
398 | KDGanttMinimizeSplitter *mExtensionBarSplitter; | 400 | KDGanttMinimizeSplitter *mExtensionBarSplitter; |
399 | ViewContainer *mDetails; | 401 | ViewContainer *mDetails; |
400 | KDGanttMinimizeSplitter* mMiniSplitter; | 402 | KDGanttMinimizeSplitter* mMiniSplitter; |
401 | XXPortManager *mXXPortManager; | 403 | XXPortManager *mXXPortManager; |
402 | JumpButtonBar *mJumpButtonBar; | 404 | JumpButtonBar *mJumpButtonBar; |
403 | IncSearchWidget *mIncSearchWidget; | 405 | IncSearchWidget *mIncSearchWidget; |
404 | ExtensionManager *mExtensionManager; | 406 | ExtensionManager *mExtensionManager; |
405 | 407 | ||
406 | KCMultiDialog *mConfigureDialog; | 408 | KCMultiDialog *mConfigureDialog; |
407 | 409 | ||
408 | #ifndef KAB_EMBEDDED | 410 | #ifndef KAB_EMBEDDED |
409 | LDAPSearchDialog *mLdapSearchDialog; | 411 | LDAPSearchDialog *mLdapSearchDialog; |
410 | #endif //KAB_EMBEDDED | 412 | #endif //KAB_EMBEDDED |
411 | // QDict<AddresseeEditorDialog> mEditorDict; | 413 | // QDict<AddresseeEditorDialog> mEditorDict; |
412 | AddresseeEditorDialog *mEditorDialog; | 414 | AddresseeEditorDialog *mEditorDialog; |
413 | bool mReadWrite; | 415 | bool mReadWrite; |
414 | bool mModified; | 416 | bool mModified; |
415 | bool mIsPart; | 417 | bool mIsPart; |
416 | bool mMultipleViewsAtOnce; | 418 | bool mMultipleViewsAtOnce; |
417 | 419 | ||
418 | 420 | ||
419 | //US file menu | 421 | //US file menu |
420 | KAction *mActionMail; | 422 | KAction *mActionMail; |
421 | KAction *mActionBeam; | 423 | KAction *mActionBeam; |
422 | KToggleAction *mActionBR; | 424 | KToggleAction *mActionBR; |
423 | KAction *mActionExport2phone; | 425 | KAction *mActionExport2phone; |
424 | KAction* mActionPrint; | 426 | KAction* mActionPrint; |
425 | KAction* mActionNewContact; | 427 | KAction* mActionNewContact; |
426 | KAction *mActionSave; | 428 | KAction *mActionSave; |
427 | KAction *mActionEditAddressee; | 429 | KAction *mActionEditAddressee; |
428 | KAction *mActionMailVCard; | 430 | KAction *mActionMailVCard; |
429 | KAction *mActionBeamVCard; | 431 | KAction *mActionBeamVCard; |
430 | 432 | ||
431 | KAction *mActionQuit; | 433 | KAction *mActionQuit; |
432 | 434 | ||
433 | //US edit menu | 435 | //US edit menu |
434 | KAction *mActionCopy; | 436 | KAction *mActionCopy; |
435 | KAction *mActionCut; | 437 | KAction *mActionCut; |
436 | KAction *mActionPaste; | 438 | KAction *mActionPaste; |
437 | KAction *mActionSelectAll; | 439 | KAction *mActionSelectAll; |
438 | KAction *mActionUndo; | 440 | KAction *mActionUndo; |
439 | KAction *mActionRedo; | 441 | KAction *mActionRedo; |
440 | KAction *mActionDelete; | 442 | KAction *mActionDelete; |
441 | 443 | ||
442 | //US settings menu | 444 | //US settings menu |
443 | KAction *mActionConfigResources; | 445 | KAction *mActionConfigResources; |
444 | KAction *mActionConfigKAddressbook; | 446 | KAction *mActionConfigKAddressbook; |
445 | KAction *mActionConfigShortcuts; | 447 | KAction *mActionConfigShortcuts; |
446 | KAction *mActionConfigureToolbars; | 448 | KAction *mActionConfigureToolbars; |
447 | KAction *mActionKeyBindings; | 449 | KAction *mActionKeyBindings; |
448 | KToggleAction *mActionJumpBar; | 450 | KToggleAction *mActionJumpBar; |
449 | KToggleAction *mActionDetails; | 451 | KToggleAction *mActionDetails; |
450 | KAction *mActionWhoAmI; | 452 | KAction *mActionWhoAmI; |
451 | KAction *mActionCategories; | 453 | KAction *mActionCategories; |
452 | KAction *mActionAboutKAddressbook; | 454 | KAction *mActionAboutKAddressbook; |
453 | KAction *mActionLicence; | 455 | KAction *mActionLicence; |
454 | KAction *mActionFaq; | 456 | KAction *mActionFaq; |
455 | KAction *mActionWN; | 457 | KAction *mActionWN; |
456 | KAction *mActionSyncHowto; | 458 | KAction *mActionSyncHowto; |
459 | KAction *mActionKdeSyncHowto; | ||
460 | KAction *mActionMultiSyncHowto; | ||
457 | 461 | ||
458 | KAction *mActionDeleteView; | 462 | KAction *mActionDeleteView; |
459 | 463 | ||
460 | QPopupMenu *viewMenu; | 464 | QPopupMenu *viewMenu; |
461 | QPopupMenu *filterMenu; | 465 | QPopupMenu *filterMenu; |
462 | QPopupMenu *settingsMenu; | 466 | QPopupMenu *settingsMenu; |
463 | QPopupMenu *changeMenu; | 467 | QPopupMenu *changeMenu; |
464 | //US QAction *mActionSave; | 468 | //US QAction *mActionSave; |
465 | QPopupMenu *ImportMenu; | 469 | QPopupMenu *ImportMenu; |
466 | QPopupMenu *ExportMenu; | 470 | QPopupMenu *ExportMenu; |
467 | //LR additional methods | 471 | //LR additional methods |
468 | KAction *mActionRemoveVoice; | 472 | KAction *mActionRemoveVoice; |
469 | KAction * mActionImportOL; | 473 | KAction * mActionImportOL; |
470 | 474 | ||
471 | #ifndef KAB_EMBEDDED | 475 | #ifndef KAB_EMBEDDED |
472 | KAddressBookService *mAddressBookService; | 476 | KAddressBookService *mAddressBookService; |
473 | #endif //KAB_EMBEDDED | 477 | #endif //KAB_EMBEDDED |
474 | 478 | ||
475 | class KABCorePrivate; | 479 | class KABCorePrivate; |
476 | KABCorePrivate *d; | 480 | KABCorePrivate *d; |
477 | //US bool mBlockSaveFlag; | 481 | //US bool mBlockSaveFlag; |
478 | 482 | ||
479 | #ifdef KAB_EMBEDDED | 483 | #ifdef KAB_EMBEDDED |
480 | KAddressBookMain *mMainWindow; // should be the same like mGUIClient | 484 | KAddressBookMain *mMainWindow; // should be the same like mGUIClient |
481 | #endif //KAB_EMBEDDED | 485 | #endif //KAB_EMBEDDED |
482 | 486 | ||
483 | //this are the overwritten callbackmethods from the syncinterface | 487 | //this are the overwritten callbackmethods from the syncinterface |
484 | virtual bool sync(KSyncManager* manager, QString filename, int mode); | 488 | virtual bool sync(KSyncManager* manager, QString filename, int mode); |
485 | virtual bool syncExternal(KSyncManager* manager, QString resource); | 489 | virtual bool syncExternal(KSyncManager* manager, QString resource); |
486 | virtual void removeSyncInfo( QString syncProfile); | 490 | virtual void removeSyncInfo( QString syncProfile); |
487 | bool syncPhone(); | 491 | bool syncPhone(); |
488 | void message( QString m ); | 492 | void message( QString m ); |
489 | 493 | ||
490 | // LR ******************************* | 494 | // LR ******************************* |
491 | // sync stuff! | 495 | // sync stuff! |
492 | QString sentSyncFile(); | 496 | QString sentSyncFile(); |
493 | QPopupMenu *syncMenu; | 497 | QPopupMenu *syncMenu; |
494 | KSyncManager* syncManager; | 498 | KSyncManager* syncManager; |
495 | int mGlobalSyncMode; | 499 | int mGlobalSyncMode; |
496 | bool synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode); | 500 | bool synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode); |
497 | KABC::Addressee getLastSyncAddressee(); | 501 | KABC::Addressee getLastSyncAddressee(); |
498 | QDateTime mLastAddressbookSync; | 502 | QDateTime mLastAddressbookSync; |
499 | int takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ); | 503 | int takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ); |
500 | // ********************* | 504 | // ********************* |
501 | 505 | ||
502 | }; | 506 | }; |
503 | 507 | ||
504 | #endif | 508 | #endif |
diff --git a/korganizer/calendarview.cpp b/korganizer/calendarview.cpp index 6e61351..4667918 100644 --- a/korganizer/calendarview.cpp +++ b/korganizer/calendarview.cpp | |||
@@ -1101,310 +1101,316 @@ bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int | |||
1101 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1101 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1102 | skipIncidence = true; | 1102 | skipIncidence = true; |
1103 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->type() == "Journal" ) | 1103 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->type() == "Journal" ) |
1104 | skipIncidence = true; | 1104 | skipIncidence = true; |
1105 | if ( !skipIncidence ) { | 1105 | if ( !skipIncidence ) { |
1106 | inR = remote->incidence( uid ); | 1106 | inR = remote->incidence( uid ); |
1107 | if ( ! inR ) { | 1107 | if ( ! inR ) { |
1108 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1108 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1109 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { | 1109 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { |
1110 | checkExternSyncEvent(eventLSyncSharp, inL); | 1110 | checkExternSyncEvent(eventLSyncSharp, inL); |
1111 | local->deleteIncidence( inL ); | 1111 | local->deleteIncidence( inL ); |
1112 | ++deletedEventL; | 1112 | ++deletedEventL; |
1113 | } else { | 1113 | } else { |
1114 | if ( ! mSyncManager->mWriteBackExistingOnly ) { | 1114 | if ( ! mSyncManager->mWriteBackExistingOnly ) { |
1115 | inL->removeID(mCurrentSyncDevice ); | 1115 | inL->removeID(mCurrentSyncDevice ); |
1116 | ++addedEventR; | 1116 | ++addedEventR; |
1117 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); | 1117 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); |
1118 | inL->setLastModified( modifiedCalendar ); | 1118 | inL->setLastModified( modifiedCalendar ); |
1119 | inR = inL->clone(); | 1119 | inR = inL->clone(); |
1120 | inR->setIDStr( ":" ); | 1120 | inR->setIDStr( ":" ); |
1121 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1121 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1122 | remote->addIncidence( inR ); | 1122 | remote->addIncidence( inR ); |
1123 | } | 1123 | } |
1124 | } | 1124 | } |
1125 | } else { | 1125 | } else { |
1126 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { | 1126 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { |
1127 | checkExternSyncEvent(eventLSyncSharp, inL); | 1127 | checkExternSyncEvent(eventLSyncSharp, inL); |
1128 | local->deleteIncidence( inL ); | 1128 | local->deleteIncidence( inL ); |
1129 | ++deletedEventL; | 1129 | ++deletedEventL; |
1130 | } else { | 1130 | } else { |
1131 | if ( ! mSyncManager->mWriteBackExistingOnly ) { | 1131 | if ( ! mSyncManager->mWriteBackExistingOnly ) { |
1132 | ++addedEventR; | 1132 | ++addedEventR; |
1133 | inL->setLastModified( modifiedCalendar ); | 1133 | inL->setLastModified( modifiedCalendar ); |
1134 | inR = inL->clone(); | 1134 | inR = inL->clone(); |
1135 | inR->setIDStr( ":" ); | 1135 | inR->setIDStr( ":" ); |
1136 | remote->addIncidence( inR ); | 1136 | remote->addIncidence( inR ); |
1137 | } | 1137 | } |
1138 | } | 1138 | } |
1139 | } | 1139 | } |
1140 | } | 1140 | } |
1141 | } | 1141 | } |
1142 | inL = el.next(); | 1142 | inL = el.next(); |
1143 | } | 1143 | } |
1144 | int delFut = 0; | 1144 | int delFut = 0; |
1145 | int remRem = 0; | 1145 | int remRem = 0; |
1146 | if ( mSyncManager->mWriteBackInFuture ) { | 1146 | if ( mSyncManager->mWriteBackInFuture ) { |
1147 | er = remote->rawIncidences(); | 1147 | er = remote->rawIncidences(); |
1148 | remRem = er.count(); | 1148 | remRem = er.count(); |
1149 | inR = er.first(); | 1149 | inR = er.first(); |
1150 | QDateTime dt; | 1150 | QDateTime dt; |
1151 | QDateTime cur = QDateTime::currentDateTime().addDays( -7 ); | 1151 | QDateTime cur = QDateTime::currentDateTime().addDays( -7 ); |
1152 | QDateTime end = cur.addDays( (mSyncManager->mWriteBackInFuture +1 ) *7 ); | 1152 | QDateTime end = cur.addDays( (mSyncManager->mWriteBackInFuture +1 ) *7 ); |
1153 | while ( inR ) { | 1153 | while ( inR ) { |
1154 | if ( inR->type() == "Todo" ) { | 1154 | if ( inR->type() == "Todo" ) { |
1155 | Todo * t = (Todo*)inR; | 1155 | Todo * t = (Todo*)inR; |
1156 | if ( t->hasDueDate() ) | 1156 | if ( t->hasDueDate() ) |
1157 | dt = t->dtDue(); | 1157 | dt = t->dtDue(); |
1158 | else | 1158 | else |
1159 | dt = cur.addSecs( 62 ); | 1159 | dt = cur.addSecs( 62 ); |
1160 | } | 1160 | } |
1161 | else if (inR->type() == "Event" ) { | 1161 | else if (inR->type() == "Event" ) { |
1162 | bool ok; | 1162 | bool ok; |
1163 | dt = inR->getNextOccurence( cur, &ok ); | 1163 | dt = inR->getNextOccurence( cur, &ok ); |
1164 | if ( !ok ) | 1164 | if ( !ok ) |
1165 | dt = cur.addSecs( -62 ); | 1165 | dt = cur.addSecs( -62 ); |
1166 | } | 1166 | } |
1167 | else | 1167 | else |
1168 | dt = inR->dtStart(); | 1168 | dt = inR->dtStart(); |
1169 | if ( dt < cur || dt > end ) { | 1169 | if ( dt < cur || dt > end ) { |
1170 | remote->deleteIncidence( inR ); | 1170 | remote->deleteIncidence( inR ); |
1171 | ++delFut; | 1171 | ++delFut; |
1172 | } | 1172 | } |
1173 | inR = er.next(); | 1173 | inR = er.next(); |
1174 | } | 1174 | } |
1175 | } | 1175 | } |
1176 | bar.hide(); | 1176 | bar.hide(); |
1177 | mLastCalendarSync = QDateTime::currentDateTime().addSecs( 1 ); | 1177 | mLastCalendarSync = QDateTime::currentDateTime().addSecs( 1 ); |
1178 | eventLSync->setReadOnly( false ); | 1178 | eventLSync->setReadOnly( false ); |
1179 | eventLSync->setDtStart( mLastCalendarSync ); | 1179 | eventLSync->setDtStart( mLastCalendarSync ); |
1180 | eventRSync->setDtStart( mLastCalendarSync ); | 1180 | eventRSync->setDtStart( mLastCalendarSync ); |
1181 | eventLSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); | 1181 | eventLSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); |
1182 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); | 1182 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); |
1183 | eventRSync->setLocation( i18n("Remote from: ")+mCurrentSyncName ) ; | 1183 | eventRSync->setLocation( i18n("Remote from: ")+mCurrentSyncName ) ; |
1184 | eventLSync->setLocation(i18n("Local from: ") + mCurrentSyncName ); | 1184 | eventLSync->setLocation(i18n("Local from: ") + mCurrentSyncName ); |
1185 | eventLSync->setReadOnly( true ); | 1185 | eventLSync->setReadOnly( true ); |
1186 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL && !mSyncManager->syncWithDesktop()) // kde is abnormal... | 1186 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL && !mSyncManager->syncWithDesktop()) // kde is abnormal... |
1187 | remote->addEvent( eventRSync ); | 1187 | remote->addEvent( eventRSync ); |
1188 | else | 1188 | else |
1189 | delete eventRSync; | 1189 | delete eventRSync; |
1190 | QString mes; | 1190 | QString mes; |
1191 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n"),addedEvent, addedEventR, changedLocal, changedRemote, deletedEventL, deletedEventR ); | 1191 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n"),addedEvent, addedEventR, changedLocal, changedRemote, deletedEventL, deletedEventR ); |
1192 | QString delmess; | 1192 | QString delmess; |
1193 | if ( delFut ) { | 1193 | if ( delFut ) { |
1194 | delmess.sprintf( i18n("%d items skipped on remote,\nbecause they are in the past or\nmore than %d weeks in the future.\nAfter skipping, remote has\n%d calendar/todo items."), delFut,mSyncManager->mWriteBackInFuture, remRem-delFut); | 1194 | delmess.sprintf( i18n("%d items skipped on remote,\nbecause they are in the past or\nmore than %d weeks in the future.\nAfter skipping, remote has\n%d calendar/todo items."), delFut,mSyncManager->mWriteBackInFuture, remRem-delFut); |
1195 | mes += delmess; | 1195 | mes += delmess; |
1196 | } | 1196 | } |
1197 | mCalendar->checkAlarmForIncidence( 0, true ); | ||
1198 | qDebug( mes ); | ||
1197 | if ( mSyncManager->mShowSyncSummary ) { | 1199 | if ( mSyncManager->mShowSyncSummary ) { |
1198 | KMessageBox::information(this, mes, i18n("KO/Pi Synchronization") ); | 1200 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, |
1201 | i18n("KO/Pi Synchronization"),i18n("Write back"))) { | ||
1202 | qDebug("cancelled "); | ||
1203 | return false; | ||
1204 | } | ||
1199 | } | 1205 | } |
1200 | qDebug( mes ); | ||
1201 | mCalendar->checkAlarmForIncidence( 0, true ); | ||
1202 | return syncOK; | 1206 | return syncOK; |
1203 | } | 1207 | } |
1204 | 1208 | ||
1205 | void CalendarView::setSyncDevice( QString s ) | 1209 | void CalendarView::setSyncDevice( QString s ) |
1206 | { | 1210 | { |
1207 | mCurrentSyncDevice= s; | 1211 | mCurrentSyncDevice= s; |
1208 | } | 1212 | } |
1209 | void CalendarView::setSyncName( QString s ) | 1213 | void CalendarView::setSyncName( QString s ) |
1210 | { | 1214 | { |
1211 | mCurrentSyncName= s; | 1215 | mCurrentSyncName= s; |
1212 | } | 1216 | } |
1213 | bool CalendarView::syncCalendar(QString filename, int mode) | 1217 | bool CalendarView::syncCalendar(QString filename, int mode) |
1214 | { | 1218 | { |
1215 | //qDebug("syncCalendar %s ", filename.latin1()); | 1219 | //qDebug("syncCalendar %s ", filename.latin1()); |
1216 | mGlobalSyncMode = SYNC_MODE_NORMAL; | 1220 | mGlobalSyncMode = SYNC_MODE_NORMAL; |
1217 | CalendarLocal* calendar = new CalendarLocal(); | 1221 | CalendarLocal* calendar = new CalendarLocal(); |
1218 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 1222 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
1219 | FileStorage* storage = new FileStorage( calendar ); | 1223 | FileStorage* storage = new FileStorage( calendar ); |
1220 | bool syncOK = false; | 1224 | bool syncOK = false; |
1221 | storage->setFileName( filename ); | 1225 | storage->setFileName( filename ); |
1222 | // qDebug("loading ... "); | 1226 | // qDebug("loading ... "); |
1223 | if ( storage->load() ) { | 1227 | if ( storage->load() ) { |
1224 | getEventViewerDialog()->setSyncMode( true ); | 1228 | getEventViewerDialog()->setSyncMode( true ); |
1225 | syncOK = synchronizeCalendar( mCalendar, calendar, mode ); | 1229 | syncOK = synchronizeCalendar( mCalendar, calendar, mode ); |
1226 | getEventViewerDialog()->setSyncMode( false ); | 1230 | getEventViewerDialog()->setSyncMode( false ); |
1227 | if ( syncOK ) { | 1231 | if ( syncOK ) { |
1228 | if ( mSyncManager->mWriteBackFile ) | 1232 | if ( mSyncManager->mWriteBackFile ) |
1229 | { | 1233 | { |
1230 | storage->setSaveFormat( new ICalFormat() ); | 1234 | storage->setSaveFormat( new ICalFormat() ); |
1231 | storage->save(); | 1235 | storage->save(); |
1232 | } | 1236 | } |
1233 | } | 1237 | } |
1234 | setModified( true ); | 1238 | setModified( true ); |
1235 | } | 1239 | } |
1236 | delete storage; | 1240 | delete storage; |
1237 | delete calendar; | 1241 | delete calendar; |
1238 | if ( syncOK ) | 1242 | if ( syncOK ) |
1239 | updateView(); | 1243 | updateView(); |
1240 | return syncOK; | 1244 | return syncOK; |
1241 | } | 1245 | } |
1242 | 1246 | ||
1243 | void CalendarView::syncExternal( int mode ) | 1247 | void CalendarView::syncExternal( int mode ) |
1244 | { | 1248 | { |
1245 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 1249 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
1246 | 1250 | ||
1247 | qApp->processEvents(); | 1251 | qApp->processEvents(); |
1248 | CalendarLocal* calendar = new CalendarLocal(); | 1252 | CalendarLocal* calendar = new CalendarLocal(); |
1249 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 1253 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
1250 | bool syncOK = false; | 1254 | bool syncOK = false; |
1251 | bool loadSuccess = false; | 1255 | bool loadSuccess = false; |
1252 | PhoneFormat* phoneFormat = 0; | 1256 | PhoneFormat* phoneFormat = 0; |
1253 | emit tempDisableBR(true); | 1257 | emit tempDisableBR(true); |
1254 | #ifndef DESKTOP_VERSION | 1258 | #ifndef DESKTOP_VERSION |
1255 | SharpFormat* sharpFormat = 0; | 1259 | SharpFormat* sharpFormat = 0; |
1256 | if ( mode == 0 ) { // sharp | 1260 | if ( mode == 0 ) { // sharp |
1257 | sharpFormat = new SharpFormat () ; | 1261 | sharpFormat = new SharpFormat () ; |
1258 | loadSuccess = sharpFormat->load( calendar, mCalendar ); | 1262 | loadSuccess = sharpFormat->load( calendar, mCalendar ); |
1259 | 1263 | ||
1260 | } else | 1264 | } else |
1261 | #endif | 1265 | #endif |
1262 | if ( mode == 1 ) { // phone | 1266 | if ( mode == 1 ) { // phone |
1263 | phoneFormat = new PhoneFormat (mCurrentSyncDevice, | 1267 | phoneFormat = new PhoneFormat (mCurrentSyncDevice, |
1264 | mSyncManager->mPhoneDevice, | 1268 | mSyncManager->mPhoneDevice, |
1265 | mSyncManager->mPhoneConnection, | 1269 | mSyncManager->mPhoneConnection, |
1266 | mSyncManager->mPhoneModel); | 1270 | mSyncManager->mPhoneModel); |
1267 | loadSuccess = phoneFormat->load( calendar,mCalendar); | 1271 | loadSuccess = phoneFormat->load( calendar,mCalendar); |
1268 | 1272 | ||
1269 | } else { | 1273 | } else { |
1270 | emit tempDisableBR(false); | 1274 | emit tempDisableBR(false); |
1271 | return; | 1275 | return; |
1272 | } | 1276 | } |
1273 | if ( loadSuccess ) { | 1277 | if ( loadSuccess ) { |
1274 | getEventViewerDialog()->setSyncMode( true ); | 1278 | getEventViewerDialog()->setSyncMode( true ); |
1275 | syncOK = synchronizeCalendar( mCalendar, calendar, mSyncManager->mSyncAlgoPrefs ); | 1279 | syncOK = synchronizeCalendar( mCalendar, calendar, mSyncManager->mSyncAlgoPrefs ); |
1276 | getEventViewerDialog()->setSyncMode( false ); | 1280 | getEventViewerDialog()->setSyncMode( false ); |
1277 | qApp->processEvents(); | 1281 | qApp->processEvents(); |
1278 | if ( syncOK ) { | 1282 | if ( syncOK ) { |
1279 | if ( mSyncManager->mWriteBackFile ) | 1283 | if ( mSyncManager->mWriteBackFile ) |
1280 | { | 1284 | { |
1281 | QPtrList<Incidence> iL = mCalendar->rawIncidences(); | 1285 | QPtrList<Incidence> iL = mCalendar->rawIncidences(); |
1282 | Incidence* inc = iL.first(); | 1286 | Incidence* inc = iL.first(); |
1283 | if ( phoneFormat ) { | 1287 | if ( phoneFormat ) { |
1284 | while ( inc ) { | 1288 | while ( inc ) { |
1285 | inc->removeID(mCurrentSyncDevice); | 1289 | inc->removeID(mCurrentSyncDevice); |
1286 | inc = iL.next(); | 1290 | inc = iL.next(); |
1287 | } | 1291 | } |
1288 | } | 1292 | } |
1289 | #ifndef DESKTOP_VERSION | 1293 | #ifndef DESKTOP_VERSION |
1290 | if ( sharpFormat ) | 1294 | if ( sharpFormat ) |
1291 | sharpFormat->save(calendar); | 1295 | sharpFormat->save(calendar); |
1292 | #endif | 1296 | #endif |
1293 | if ( phoneFormat ) | 1297 | if ( phoneFormat ) |
1294 | phoneFormat->save(calendar); | 1298 | phoneFormat->save(calendar); |
1295 | iL = calendar->rawIncidences(); | 1299 | iL = calendar->rawIncidences(); |
1296 | inc = iL.first(); | 1300 | inc = iL.first(); |
1297 | Incidence* loc; | 1301 | Incidence* loc; |
1298 | while ( inc ) { | 1302 | while ( inc ) { |
1299 | if ( inc->tempSyncStat() == SYNC_TEMPSTATE_NEW_ID ) { | 1303 | if ( inc->tempSyncStat() == SYNC_TEMPSTATE_NEW_ID ) { |
1300 | loc = mCalendar->incidence(inc->uid() ); | 1304 | loc = mCalendar->incidence(inc->uid() ); |
1301 | if ( loc ) { | 1305 | if ( loc ) { |
1302 | loc->setID(mCurrentSyncDevice, inc->getID(mCurrentSyncDevice) ); | 1306 | loc->setID(mCurrentSyncDevice, inc->getID(mCurrentSyncDevice) ); |
1303 | loc->setCsum( mCurrentSyncDevice, inc->getCsum(mCurrentSyncDevice) ); | 1307 | loc->setCsum( mCurrentSyncDevice, inc->getCsum(mCurrentSyncDevice) ); |
1304 | } | 1308 | } |
1305 | } | 1309 | } |
1306 | inc = iL.next(); | 1310 | inc = iL.next(); |
1307 | } | 1311 | } |
1308 | Incidence* lse = getLastSyncEvent(); | 1312 | Incidence* lse = getLastSyncEvent(); |
1309 | if ( lse ) { | 1313 | if ( lse ) { |
1310 | lse->setReadOnly( false ); | 1314 | lse->setReadOnly( false ); |
1311 | lse->setDescription( "" ); | 1315 | lse->setDescription( "" ); |
1312 | lse->setReadOnly( true ); | 1316 | lse->setReadOnly( true ); |
1313 | } | 1317 | } |
1314 | } | 1318 | } |
1319 | } else { | ||
1320 | topLevelWidget()->setCaption( i18n("Sync cancelled or failed.") ); | ||
1315 | } | 1321 | } |
1316 | setModified( true ); | 1322 | setModified( true ); |
1317 | } else { | 1323 | } else { |
1318 | QString question = i18n("Sorry, the database access\ncommand failed!\n\nNothing synced!\n") ; | 1324 | QString question = i18n("Sorry, the database access\ncommand failed!\n\nNothing synced!\n") ; |
1319 | QMessageBox::information( 0, i18n("KO/Pi Import - ERROR"), | 1325 | QMessageBox::information( 0, i18n("KO/Pi Import - ERROR"), |
1320 | question, i18n("Ok")) ; | 1326 | question, i18n("Ok")) ; |
1321 | 1327 | ||
1322 | } | 1328 | } |
1323 | delete calendar; | 1329 | delete calendar; |
1324 | updateView(); | 1330 | updateView(); |
1325 | emit tempDisableBR(false); | 1331 | emit tempDisableBR(false); |
1326 | return ;//syncOK; | 1332 | return ;//syncOK; |
1327 | 1333 | ||
1328 | } | 1334 | } |
1329 | 1335 | ||
1330 | bool CalendarView::importBday() | 1336 | bool CalendarView::importBday() |
1331 | { | 1337 | { |
1332 | #ifndef KORG_NOKABC | 1338 | #ifndef KORG_NOKABC |
1333 | 1339 | ||
1334 | #ifdef DESKTOP_VERSION | 1340 | #ifdef DESKTOP_VERSION |
1335 | KABC::StdAddressBook* AddressBook = KABC::StdAddressBook::self( true ); | 1341 | KABC::StdAddressBook* AddressBook = KABC::StdAddressBook::self( true ); |
1336 | KABC::AddressBook::Iterator it; | 1342 | KABC::AddressBook::Iterator it; |
1337 | int count = 0; | 1343 | int count = 0; |
1338 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { | 1344 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { |
1339 | ++count; | 1345 | ++count; |
1340 | } | 1346 | } |
1341 | QProgressBar bar(count,0 ); | 1347 | QProgressBar bar(count,0 ); |
1342 | int w = 300; | 1348 | int w = 300; |
1343 | if ( QApplication::desktop()->width() < 320 ) | 1349 | if ( QApplication::desktop()->width() < 320 ) |
1344 | w = 220; | 1350 | w = 220; |
1345 | int h = bar.sizeHint().height() ; | 1351 | int h = bar.sizeHint().height() ; |
1346 | int dw = QApplication::desktop()->width(); | 1352 | int dw = QApplication::desktop()->width(); |
1347 | int dh = QApplication::desktop()->height(); | 1353 | int dh = QApplication::desktop()->height(); |
1348 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1354 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
1349 | bar.show(); | 1355 | bar.show(); |
1350 | bar.setCaption (i18n("Reading addressbook - close to abort!") ); | 1356 | bar.setCaption (i18n("Reading addressbook - close to abort!") ); |
1351 | qApp->processEvents(); | 1357 | qApp->processEvents(); |
1352 | count = 0; | 1358 | count = 0; |
1353 | int addCount = 0; | 1359 | int addCount = 0; |
1354 | KCal::Attendee* a = 0; | 1360 | KCal::Attendee* a = 0; |
1355 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { | 1361 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { |
1356 | if ( ! bar.isVisible() ) | 1362 | if ( ! bar.isVisible() ) |
1357 | return false; | 1363 | return false; |
1358 | bar.setProgress( count++ ); | 1364 | bar.setProgress( count++ ); |
1359 | qApp->processEvents(); | 1365 | qApp->processEvents(); |
1360 | //qDebug("add BDay %s %s", (*it).realName().latin1(),(*it).birthday().date().toString().latin1() ); | 1366 | //qDebug("add BDay %s %s", (*it).realName().latin1(),(*it).birthday().date().toString().latin1() ); |
1361 | if ( (*it).birthday().date().isValid() ){ | 1367 | if ( (*it).birthday().date().isValid() ){ |
1362 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; | 1368 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; |
1363 | if ( addAnniversary( (*it).birthday().date(), (*it).assembledName(), a, true ) ) | 1369 | if ( addAnniversary( (*it).birthday().date(), (*it).assembledName(), a, true ) ) |
1364 | ++addCount; | 1370 | ++addCount; |
1365 | } | 1371 | } |
1366 | QDate anni = KGlobal::locale()->readDate( (*it).custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); | 1372 | QDate anni = KGlobal::locale()->readDate( (*it).custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); |
1367 | if ( anni.isValid() ){ | 1373 | if ( anni.isValid() ){ |
1368 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; | 1374 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; |
1369 | if ( addAnniversary( anni, (*it).assembledName(), a, false ) ) | 1375 | if ( addAnniversary( anni, (*it).assembledName(), a, false ) ) |
1370 | ++addCount; | 1376 | ++addCount; |
1371 | } | 1377 | } |
1372 | } | 1378 | } |
1373 | updateView(); | 1379 | updateView(); |
1374 | topLevelWidget()->setCaption(QString::number( addCount )+ i18n(" birthdays/anniversaries added!")); | 1380 | topLevelWidget()->setCaption(QString::number( addCount )+ i18n(" birthdays/anniversaries added!")); |
1375 | #else //DESKTOP_VERSION | 1381 | #else //DESKTOP_VERSION |
1376 | 1382 | ||
1377 | ExternalAppHandler::instance()->requestBirthdayListFromKAPI("QPE/Application/kopi", this->name() /* name is here the unique uid*/); | 1383 | ExternalAppHandler::instance()->requestBirthdayListFromKAPI("QPE/Application/kopi", this->name() /* name is here the unique uid*/); |
1378 | // the result should now arrive through method insertBirthdays | 1384 | // the result should now arrive through method insertBirthdays |
1379 | 1385 | ||
1380 | #endif //DESKTOP_VERSION | 1386 | #endif //DESKTOP_VERSION |
1381 | 1387 | ||
1382 | #endif //KORG_NOKABC | 1388 | #endif //KORG_NOKABC |
1383 | 1389 | ||
1384 | 1390 | ||
1385 | return true; | 1391 | return true; |
1386 | } | 1392 | } |
1387 | 1393 | ||
1388 | // This method will be called from Ka/Pi as a response to requestBirthdayListFromKAPI | 1394 | // This method will be called from Ka/Pi as a response to requestBirthdayListFromKAPI |
1389 | void CalendarView::insertBirthdays(const QString& uid, const QStringList& birthdayList, | 1395 | void CalendarView::insertBirthdays(const QString& uid, const QStringList& birthdayList, |
1390 | const QStringList& anniversaryList, const QStringList& realNameList, | 1396 | const QStringList& anniversaryList, const QStringList& realNameList, |
1391 | const QStringList& emailList, const QStringList& assembledNameList, | 1397 | const QStringList& emailList, const QStringList& assembledNameList, |
1392 | const QStringList& uidList) | 1398 | const QStringList& uidList) |
1393 | { | 1399 | { |
1394 | qDebug("CalendarView::insertBirthdays"); | 1400 | qDebug("CalendarView::insertBirthdays"); |
1395 | if (uid == this->name()) | 1401 | if (uid == this->name()) |
1396 | { | 1402 | { |
1397 | int count = birthdayList.count(); | 1403 | int count = birthdayList.count(); |
1398 | int addCount = 0; | 1404 | int addCount = 0; |
1399 | KCal::Attendee* a = 0; | 1405 | KCal::Attendee* a = 0; |
1400 | 1406 | ||
1401 | qDebug("CalView 1 %i", count); | 1407 | qDebug("CalView 1 %i", count); |
1402 | 1408 | ||
1403 | QProgressBar bar(count,0 ); | 1409 | QProgressBar bar(count,0 ); |
1404 | int w = 300; | 1410 | int w = 300; |
1405 | if ( QApplication::desktop()->width() < 320 ) | 1411 | if ( QApplication::desktop()->width() < 320 ) |
1406 | w = 220; | 1412 | w = 220; |
1407 | int h = bar.sizeHint().height() ; | 1413 | int h = bar.sizeHint().height() ; |
1408 | int dw = QApplication::desktop()->width(); | 1414 | int dw = QApplication::desktop()->width(); |
1409 | int dh = QApplication::desktop()->height(); | 1415 | int dh = QApplication::desktop()->height(); |
1410 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1416 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
diff --git a/korganizer/mainwindow.cpp b/korganizer/mainwindow.cpp index fc2d59b..65566b5 100644 --- a/korganizer/mainwindow.cpp +++ b/korganizer/mainwindow.cpp | |||
@@ -756,234 +756,241 @@ void MainWindow::initActions() | |||
756 | action->addTo( importMenu ); | 756 | action->addTo( importMenu ); |
757 | connect( action, SIGNAL( activated() ), SLOT( quickImportIcal() ) ); | 757 | connect( action, SIGNAL( activated() ), SLOT( quickImportIcal() ) ); |
758 | importMenu->insertSeparator(); | 758 | importMenu->insertSeparator(); |
759 | action = new QAction( "import_bday", i18n("Import Birthdays (KA/Pi)"), 0, | 759 | action = new QAction( "import_bday", i18n("Import Birthdays (KA/Pi)"), 0, |
760 | this ); | 760 | this ); |
761 | action->addTo( importMenu ); | 761 | action->addTo( importMenu ); |
762 | connect( action, SIGNAL( activated() ), SLOT( importBday() ) ); | 762 | connect( action, SIGNAL( activated() ), SLOT( importBday() ) ); |
763 | #ifndef DESKTOP_VERSION | 763 | #ifndef DESKTOP_VERSION |
764 | importMenu->insertSeparator(); | 764 | importMenu->insertSeparator(); |
765 | action = new QAction( "import_qtopia", i18n("Import Opie/Qtopia Cal."), 0, | 765 | action = new QAction( "import_qtopia", i18n("Import Opie/Qtopia Cal."), 0, |
766 | this ); | 766 | this ); |
767 | action->addTo( importMenu ); | 767 | action->addTo( importMenu ); |
768 | connect( action, SIGNAL( activated() ), SLOT( importQtopia() ) ); | 768 | connect( action, SIGNAL( activated() ), SLOT( importQtopia() ) ); |
769 | #else | 769 | #else |
770 | #ifdef _WIN32_ | 770 | #ifdef _WIN32_ |
771 | importMenu->insertSeparator(); | 771 | importMenu->insertSeparator(); |
772 | action = new QAction( "import_ol", i18n("Import from OL"), 0, | 772 | action = new QAction( "import_ol", i18n("Import from OL"), 0, |
773 | this ); | 773 | this ); |
774 | action->addTo( importMenu ); | 774 | action->addTo( importMenu ); |
775 | connect( action, SIGNAL( activated() ), SLOT( importOL() ) ); | 775 | connect( action, SIGNAL( activated() ), SLOT( importOL() ) ); |
776 | #endif | 776 | #endif |
777 | #endif | 777 | #endif |
778 | 778 | ||
779 | importMenu->insertSeparator(); | 779 | importMenu->insertSeparator(); |
780 | action = new QAction( "load_cal", i18n("Load Calendar Backup"), 0, | 780 | action = new QAction( "load_cal", i18n("Load Calendar Backup"), 0, |
781 | this ); | 781 | this ); |
782 | action->addTo( importMenu ); | 782 | action->addTo( importMenu ); |
783 | connect( action, SIGNAL( activated() ), SLOT( loadCalendar() ) ); | 783 | connect( action, SIGNAL( activated() ), SLOT( loadCalendar() ) ); |
784 | 784 | ||
785 | action = new QAction( "save_cal", i18n("Save Calendar Backup"), 0, | 785 | action = new QAction( "save_cal", i18n("Save Calendar Backup"), 0, |
786 | this ); | 786 | this ); |
787 | action->addTo( importMenu ); | 787 | action->addTo( importMenu ); |
788 | connect( action, SIGNAL( activated() ), SLOT( saveCalendar() ) ); | 788 | connect( action, SIGNAL( activated() ), SLOT( saveCalendar() ) ); |
789 | 789 | ||
790 | importMenu->insertSeparator(); | 790 | importMenu->insertSeparator(); |
791 | action = new QAction( "import_qtopia", i18n("Export VCalendar"), 0, | 791 | action = new QAction( "import_qtopia", i18n("Export VCalendar"), 0, |
792 | this ); | 792 | this ); |
793 | action->addTo( importMenu ); connect( action, SIGNAL( activated() ), SLOT( exportVCalendar() ) ); | 793 | action->addTo( importMenu ); connect( action, SIGNAL( activated() ), SLOT( exportVCalendar() ) ); |
794 | 794 | ||
795 | 795 | ||
796 | //LR | 796 | //LR |
797 | QPopupMenu *ex2phone = new QPopupMenu( this ); | 797 | QPopupMenu *ex2phone = new QPopupMenu( this ); |
798 | ex2phone->insertItem(i18n("Complete calendar..."), 1 ); | 798 | ex2phone->insertItem(i18n("Complete calendar..."), 1 ); |
799 | ex2phone->insertItem(i18n("Filtered calendar..."), 2 ); | 799 | ex2phone->insertItem(i18n("Filtered calendar..."), 2 ); |
800 | connect( ex2phone, SIGNAL( activated(int) ), this, SLOT( exportToPhone( int)) ); | 800 | connect( ex2phone, SIGNAL( activated(int) ), this, SLOT( exportToPhone( int)) ); |
801 | importMenu->insertItem( i18n("Export to phone"), ex2phone ); | 801 | importMenu->insertItem( i18n("Export to phone"), ex2phone ); |
802 | 802 | ||
803 | importMenu->insertSeparator(); | 803 | importMenu->insertSeparator(); |
804 | action = new QAction( "manage cat", i18n("Manage new categories..."), 0, | 804 | action = new QAction( "manage cat", i18n("Manage new categories..."), 0, |
805 | this ); | 805 | this ); |
806 | action->addTo( importMenu ); | 806 | action->addTo( importMenu ); |
807 | connect( action, SIGNAL( activated() ), mView, SLOT( manageCategories() ) ); | 807 | connect( action, SIGNAL( activated() ), mView, SLOT( manageCategories() ) ); |
808 | #ifndef DESKTOP_VERSION | 808 | #ifndef DESKTOP_VERSION |
809 | importMenu->insertSeparator(); | 809 | importMenu->insertSeparator(); |
810 | brAction = new QAction( "beam toggle", i18n("Beam receive enabled"), 0, | 810 | brAction = new QAction( "beam toggle", i18n("Beam receive enabled"), 0, |
811 | this ); | 811 | this ); |
812 | brAction->addTo( importMenu ); | 812 | brAction->addTo( importMenu ); |
813 | brAction->setToggleAction (true ) ; | 813 | brAction->setToggleAction (true ) ; |
814 | connect( brAction, SIGNAL( activated() ), this, SLOT( toggleBeamReceive() ) ); | 814 | connect( brAction, SIGNAL( activated() ), this, SLOT( toggleBeamReceive() ) ); |
815 | 815 | ||
816 | action = new QAction( "beam all", i18n("Beam complete calendar..."), 0, | 816 | action = new QAction( "beam all", i18n("Beam complete calendar..."), 0, |
817 | this ); | 817 | this ); |
818 | action->addTo( importMenu ); | 818 | action->addTo( importMenu ); |
819 | connect( action, SIGNAL( activated() ), mView, SLOT( beamCalendar() ) ); | 819 | connect( action, SIGNAL( activated() ), mView, SLOT( beamCalendar() ) ); |
820 | 820 | ||
821 | action = new QAction( "beam all", i18n("Beam filtered calendar..."), 0, | 821 | action = new QAction( "beam all", i18n("Beam filtered calendar..."), 0, |
822 | this ); | 822 | this ); |
823 | action->addTo( importMenu ); | 823 | action->addTo( importMenu ); |
824 | connect( action, SIGNAL( activated() ), mView, SLOT( beamFilteredCalendar()) ); | 824 | connect( action, SIGNAL( activated() ), mView, SLOT( beamFilteredCalendar()) ); |
825 | #else | 825 | #else |
826 | importMenu->insertSeparator(); | 826 | importMenu->insertSeparator(); |
827 | icon = loadPixmap( pathString + "print" ); | 827 | icon = loadPixmap( pathString + "print" ); |
828 | action = new QAction( i18n("Print calendar..."),icon,i18n("Print calendar..."), 0, this ); | 828 | action = new QAction( i18n("Print calendar..."),icon,i18n("Print calendar..."), 0, this ); |
829 | action->addTo( importMenu ); | 829 | action->addTo( importMenu ); |
830 | connect( action, SIGNAL( activated() ), | 830 | connect( action, SIGNAL( activated() ), |
831 | this, SLOT( printCal() ) ); | 831 | this, SLOT( printCal() ) ); |
832 | 832 | ||
833 | icon = loadPixmap( pathString + "print" ); | 833 | icon = loadPixmap( pathString + "print" ); |
834 | action = new QAction( i18n("Print agenda selection..."),icon,i18n("Print agenda selection..."), 0, this ); | 834 | action = new QAction( i18n("Print agenda selection..."),icon,i18n("Print agenda selection..."), 0, this ); |
835 | action->addTo( importMenu ); | 835 | action->addTo( importMenu ); |
836 | connect( action, SIGNAL( activated() ), | 836 | connect( action, SIGNAL( activated() ), |
837 | this, SLOT( printSel() ) ); | 837 | this, SLOT( printSel() ) ); |
838 | #endif | 838 | #endif |
839 | importMenu->insertSeparator(); | 839 | importMenu->insertSeparator(); |
840 | action = new QAction( "beam all", i18n("Save"), 0, | 840 | action = new QAction( "beam all", i18n("Save"), 0, |
841 | this ); | 841 | this ); |
842 | action->addTo( importMenu ); | 842 | action->addTo( importMenu ); |
843 | connect( action, SIGNAL( activated() ), this, SLOT( save() ) ); | 843 | connect( action, SIGNAL( activated() ), this, SLOT( save() ) ); |
844 | action = new QAction( "beam all", i18n("Exit (+save)"), 0, | 844 | action = new QAction( "beam all", i18n("Exit (+save)"), 0, |
845 | this ); | 845 | this ); |
846 | action->addTo( importMenu ); | 846 | action->addTo( importMenu ); |
847 | connect( action, SIGNAL( activated() ), this, SLOT( close() ) ); | 847 | connect( action, SIGNAL( activated() ), this, SLOT( close() ) ); |
848 | 848 | ||
849 | //menuBar->insertItem( "Configure",configureMenu ); | 849 | //menuBar->insertItem( "Configure",configureMenu ); |
850 | //configureMenu->insertItem( "Toolbar",configureToolBarMenu ); | 850 | //configureMenu->insertItem( "Toolbar",configureToolBarMenu ); |
851 | icon = loadPixmap( "korganizer/korganizer" ); | 851 | icon = loadPixmap( "korganizer/korganizer" ); |
852 | action = new QAction( "Keys + Colors", i18n("Keys + Colors..."), 0, this ); | 852 | |
853 | action = new QAction( "Whats New", i18n("What's new?"), 0,this ); | ||
853 | action->addTo( helpMenu ); | 854 | action->addTo( helpMenu ); |
854 | connect( action, SIGNAL( activated() ), | 855 | connect( action, SIGNAL( activated() ), |
855 | SLOT( keyBindings() ) ); | 856 | SLOT( whatsNew() ) ); |
856 | action = new QAction( "featureHowto", i18n("Features + hints..."), 0,this ); | 857 | action = new QAction( "featureHowto", i18n("Features + hints..."), 0,this ); |
857 | action->addTo( helpMenu ); | 858 | action->addTo( helpMenu ); |
858 | connect( action, SIGNAL( activated() ), | 859 | connect( action, SIGNAL( activated() ), |
859 | SLOT( features() ) ); | 860 | SLOT( features() ) ); |
861 | action = new QAction( "Keys + Colors", i18n("Keys + Colors..."), 0, this ); | ||
862 | action->addTo( helpMenu ); | ||
863 | connect( action, SIGNAL( activated() ), | ||
864 | SLOT( keyBindings() ) ); | ||
865 | action = new QAction( "Sync Howto", i18n("Sync HowTo..."), 0,this ); | ||
866 | action->addTo( helpMenu ); | ||
867 | connect( action, SIGNAL( activated() ), | ||
868 | SLOT( synchowto() ) ); | ||
869 | action = new QAction( "KDE Sync Howto", i18n("KDE Sync HowTo..."), 0,this ); | ||
870 | action->addTo( helpMenu ); | ||
871 | connect( action, SIGNAL( activated() ), | ||
872 | SLOT( kdesynchowto() ) ); | ||
873 | action = new QAction( "Multi Sync Howto", i18n("Multi Sync HowTo..."), 0,this ); | ||
874 | action->addTo( helpMenu ); | ||
875 | connect( action, SIGNAL( activated() ), | ||
876 | SLOT( multisynchowto() ) ); | ||
860 | action = new QAction( "Auto saving", i18n("Auto saving..."), 0, this ); | 877 | action = new QAction( "Auto saving", i18n("Auto saving..."), 0, this ); |
861 | action->addTo( helpMenu ); | 878 | action->addTo( helpMenu ); |
862 | connect( action, SIGNAL( activated() ), | 879 | connect( action, SIGNAL( activated() ), |
863 | SLOT( aboutAutoSaving() ) ); | 880 | SLOT( aboutAutoSaving() ) ); |
864 | action = new QAction( "Problemd", i18n("Known Problems..."), 0,this ); | 881 | action = new QAction( "Problemd", i18n("Known Problems..."), 0,this ); |
865 | action->addTo( helpMenu ); | 882 | action->addTo( helpMenu ); |
866 | connect( action, SIGNAL( activated() ), | 883 | connect( action, SIGNAL( activated() ), |
867 | SLOT( aboutKnownBugs() ) ); | 884 | SLOT( aboutKnownBugs() ) ); |
868 | action = new QAction( "Translate Howto", i18n("User translation..."), 0,this ); | 885 | action = new QAction( "Translate Howto", i18n("User translation..."), 0,this ); |
869 | action->addTo( helpMenu ); | 886 | action->addTo( helpMenu ); |
870 | connect( action, SIGNAL( activated() ), | 887 | connect( action, SIGNAL( activated() ), |
871 | SLOT( usertrans() ) ); | 888 | SLOT( usertrans() ) ); |
872 | action = new QAction( "Sync Howto", i18n("Sync HowTo..."), 0,this ); | ||
873 | action->addTo( helpMenu ); | ||
874 | connect( action, SIGNAL( activated() ), | ||
875 | SLOT( synchowto() ) ); | ||
876 | action = new QAction( "Whats New", i18n("What's new?"), 0,this ); | ||
877 | action->addTo( helpMenu ); | ||
878 | connect( action, SIGNAL( activated() ), | ||
879 | SLOT( whatsNew() ) ); | ||
880 | action = new QAction( "Frequently asked questions", i18n("FAQ..."), 0,this ); | 889 | action = new QAction( "Frequently asked questions", i18n("FAQ..."), 0,this ); |
881 | action->addTo( helpMenu ); | 890 | action->addTo( helpMenu ); |
882 | connect( action, SIGNAL( activated() ), | 891 | connect( action, SIGNAL( activated() ), |
883 | SLOT( faq() ) ); | 892 | SLOT( faq() ) ); |
884 | |||
885 | |||
886 | action = new QAction( "about", i18n("About..."), 0, this ); | ||
887 | action->addTo( helpMenu ); | ||
888 | connect( action, SIGNAL( activated() ), | ||
889 | SLOT( about() ) ); | ||
890 | action = new QAction( "licence", i18n("Licence..."), 0, this ); | 893 | action = new QAction( "licence", i18n("Licence..."), 0, this ); |
891 | action->addTo( helpMenu ); | 894 | action->addTo( helpMenu ); |
892 | connect( action, SIGNAL( activated() ), | 895 | connect( action, SIGNAL( activated() ), |
893 | SLOT( licence() ) ); | 896 | SLOT( licence() ) ); |
897 | action = new QAction( "about", i18n("About..."), 0, this ); | ||
898 | action->addTo( helpMenu ); | ||
899 | connect( action, SIGNAL( activated() ), | ||
900 | SLOT( about() ) ); | ||
894 | //menuBar->insertSeparator(); | 901 | //menuBar->insertSeparator(); |
895 | 902 | ||
896 | // ****************************************************** | 903 | // ****************************************************** |
897 | // menubar icons | 904 | // menubar icons |
898 | 905 | ||
899 | 906 | ||
900 | iconToolBar->setHorizontalStretchable (true ); | 907 | iconToolBar->setHorizontalStretchable (true ); |
901 | //menuBar->insertItem( iconToolBar ); | 908 | //menuBar->insertItem( iconToolBar ); |
902 | //xdays_action | 909 | //xdays_action |
903 | if (p-> mShowIconNewEvent) | 910 | if (p-> mShowIconNewEvent) |
904 | ne_action->addTo( iconToolBar ); | 911 | ne_action->addTo( iconToolBar ); |
905 | if (p->mShowIconNewTodo ) | 912 | if (p->mShowIconNewTodo ) |
906 | nt_action->addTo( iconToolBar ); | 913 | nt_action->addTo( iconToolBar ); |
907 | if (p-> mShowIconSearch) | 914 | if (p-> mShowIconSearch) |
908 | search_action->addTo( iconToolBar ); | 915 | search_action->addTo( iconToolBar ); |
909 | if (p-> mShowIconNext) | 916 | if (p-> mShowIconNext) |
910 | whatsnext_action->addTo( iconToolBar ); | 917 | whatsnext_action->addTo( iconToolBar ); |
911 | if (p-> mShowIconNextDays) | 918 | if (p-> mShowIconNextDays) |
912 | xdays_action->addTo( iconToolBar ); | 919 | xdays_action->addTo( iconToolBar ); |
913 | if (p-> mShowIconList) | 920 | if (p-> mShowIconList) |
914 | showlist_action->addTo( iconToolBar ); | 921 | showlist_action->addTo( iconToolBar ); |
915 | if (p-> mShowIconDay1) | 922 | if (p-> mShowIconDay1) |
916 | day1_action->addTo( iconToolBar ); | 923 | day1_action->addTo( iconToolBar ); |
917 | if (p-> mShowIconDay5) | 924 | if (p-> mShowIconDay5) |
918 | day5_action->addTo( iconToolBar ); | 925 | day5_action->addTo( iconToolBar ); |
919 | if (p-> mShowIconDay7) | 926 | if (p-> mShowIconDay7) |
920 | day7_action->addTo( iconToolBar ); | 927 | day7_action->addTo( iconToolBar ); |
921 | if (p-> mShowIconMonth) | 928 | if (p-> mShowIconMonth) |
922 | month_action->addTo( iconToolBar ); | 929 | month_action->addTo( iconToolBar ); |
923 | if (p-> mShowIconTodoview) | 930 | if (p-> mShowIconTodoview) |
924 | todoview_action->addTo( iconToolBar ); | 931 | todoview_action->addTo( iconToolBar ); |
925 | if (p-> mShowIconJournal) | 932 | if (p-> mShowIconJournal) |
926 | viewjournal_action->addTo( iconToolBar ); | 933 | viewjournal_action->addTo( iconToolBar ); |
927 | icon = loadPixmap( pathString + "2leftarrowB" ); | 934 | icon = loadPixmap( pathString + "2leftarrowB" ); |
928 | configureToolBarMenu->insertItem(icon, i18n("Prev. month"), 200, 14); | 935 | configureToolBarMenu->insertItem(icon, i18n("Prev. month"), 200, 14); |
929 | if (p-> mShowIconBackFast) { | 936 | if (p-> mShowIconBackFast) { |
930 | action = new QAction( i18n("Prev. month"), icon, i18n("Prev. month"),0 , this ); | 937 | action = new QAction( i18n("Prev. month"), icon, i18n("Prev. month"),0 , this ); |
931 | connect( action, SIGNAL( activated() ), | 938 | connect( action, SIGNAL( activated() ), |
932 | mView, SLOT( goPreviousMonth() ) ); | 939 | mView, SLOT( goPreviousMonth() ) ); |
933 | action->addTo( iconToolBar ); | 940 | action->addTo( iconToolBar ); |
934 | } | 941 | } |
935 | icon = loadPixmap( pathString + "1leftarrowB" ); | 942 | icon = loadPixmap( pathString + "1leftarrowB" ); |
936 | configureToolBarMenu->insertItem(icon, i18n("Go backward"), 210,15); | 943 | configureToolBarMenu->insertItem(icon, i18n("Go backward"), 210,15); |
937 | if (p-> mShowIconBack) { | 944 | if (p-> mShowIconBack) { |
938 | action = new QAction( i18n("Go backward"), icon, i18n("Go backward"),0 , this ); | 945 | action = new QAction( i18n("Go backward"), icon, i18n("Go backward"),0 , this ); |
939 | connect( action, SIGNAL( activated() ), | 946 | connect( action, SIGNAL( activated() ), |
940 | mView, SLOT( goPrevious() ) ); | 947 | mView, SLOT( goPrevious() ) ); |
941 | action->addTo( iconToolBar ); | 948 | action->addTo( iconToolBar ); |
942 | } | 949 | } |
943 | if (p-> mShowIconToday) | 950 | if (p-> mShowIconToday) |
944 | today_action->addTo( iconToolBar ); | 951 | today_action->addTo( iconToolBar ); |
945 | icon = loadPixmap( pathString + "1rightarrowB" ); | 952 | icon = loadPixmap( pathString + "1rightarrowB" ); |
946 | configureToolBarMenu->insertItem(icon, i18n("Go forward"), 220); | 953 | configureToolBarMenu->insertItem(icon, i18n("Go forward"), 220); |
947 | if (p-> mShowIconForward) { | 954 | if (p-> mShowIconForward) { |
948 | action = new QAction( i18n("Go forward"), icon, i18n("Go forward"),0 , this ); | 955 | action = new QAction( i18n("Go forward"), icon, i18n("Go forward"),0 , this ); |
949 | connect( action, SIGNAL( activated() ), | 956 | connect( action, SIGNAL( activated() ), |
950 | mView, SLOT( goNext() ) ); | 957 | mView, SLOT( goNext() ) ); |
951 | action->addTo( iconToolBar ); | 958 | action->addTo( iconToolBar ); |
952 | } | 959 | } |
953 | icon = loadPixmap( pathString + "2rightarrowB" ); | 960 | icon = loadPixmap( pathString + "2rightarrowB" ); |
954 | configureToolBarMenu->insertItem(icon, i18n("Next month"), 230); | 961 | configureToolBarMenu->insertItem(icon, i18n("Next month"), 230); |
955 | if (p-> mShowIconForwardFast) { | 962 | if (p-> mShowIconForwardFast) { |
956 | action = new QAction( i18n("Next month"), icon, i18n("Next month"),0 , this ); | 963 | action = new QAction( i18n("Next month"), icon, i18n("Next month"),0 , this ); |
957 | connect( action, SIGNAL( activated() ), | 964 | connect( action, SIGNAL( activated() ), |
958 | mView, SLOT( goNextMonth() ) ); | 965 | mView, SLOT( goNextMonth() ) ); |
959 | action->addTo( iconToolBar ); | 966 | action->addTo( iconToolBar ); |
960 | } | 967 | } |
961 | 968 | ||
962 | 969 | ||
963 | configureToolBarMenu->insertItem(i18n("What's This?"), 300); | 970 | configureToolBarMenu->insertItem(i18n("What's This?"), 300); |
964 | 971 | ||
965 | if (p-> mShowIconNewEvent) | 972 | if (p-> mShowIconNewEvent) |
966 | configureToolBarMenu->setItemChecked( 10, true ); | 973 | configureToolBarMenu->setItemChecked( 10, true ); |
967 | if (p->mShowIconNewTodo ) | 974 | if (p->mShowIconNewTodo ) |
968 | configureToolBarMenu->setItemChecked( 20, true ); | 975 | configureToolBarMenu->setItemChecked( 20, true ); |
969 | if (p-> mShowIconSearch) | 976 | if (p-> mShowIconSearch) |
970 | configureToolBarMenu->setItemChecked( 120, true ); | 977 | configureToolBarMenu->setItemChecked( 120, true ); |
971 | if (p-> mShowIconList) | 978 | if (p-> mShowIconList) |
972 | configureToolBarMenu->setItemChecked( 30, true ); | 979 | configureToolBarMenu->setItemChecked( 30, true ); |
973 | if (p-> mShowIconDay1) | 980 | if (p-> mShowIconDay1) |
974 | configureToolBarMenu->setItemChecked( 40, true ); | 981 | configureToolBarMenu->setItemChecked( 40, true ); |
975 | if (p-> mShowIconDay5) | 982 | if (p-> mShowIconDay5) |
976 | configureToolBarMenu->setItemChecked( 50, true ); | 983 | configureToolBarMenu->setItemChecked( 50, true ); |
977 | if (p-> mShowIconDay7) | 984 | if (p-> mShowIconDay7) |
978 | configureToolBarMenu->setItemChecked( 60, true ); | 985 | configureToolBarMenu->setItemChecked( 60, true ); |
979 | if (p-> mShowIconMonth) | 986 | if (p-> mShowIconMonth) |
980 | configureToolBarMenu->setItemChecked( 70, true ); | 987 | configureToolBarMenu->setItemChecked( 70, true ); |
981 | if (p-> mShowIconTodoview) | 988 | if (p-> mShowIconTodoview) |
982 | configureToolBarMenu->setItemChecked( 80, true ); | 989 | configureToolBarMenu->setItemChecked( 80, true ); |
983 | if (p-> mShowIconBackFast) | 990 | if (p-> mShowIconBackFast) |
984 | configureToolBarMenu->setItemChecked( 200, true ); | 991 | configureToolBarMenu->setItemChecked( 200, true ); |
985 | if (p-> mShowIconBack) | 992 | if (p-> mShowIconBack) |
986 | configureToolBarMenu->setItemChecked( 210, true ); | 993 | configureToolBarMenu->setItemChecked( 210, true ); |
987 | if (p-> mShowIconToday) | 994 | if (p-> mShowIconToday) |
988 | configureToolBarMenu->setItemChecked( 130, true ); | 995 | configureToolBarMenu->setItemChecked( 130, true ); |
989 | if (p-> mShowIconForward) | 996 | if (p-> mShowIconForward) |
@@ -1054,195 +1061,202 @@ void MainWindow::exportToPhone( int mode ) | |||
1054 | QDateTime dt; | 1061 | QDateTime dt; |
1055 | if ( incidence->type() == "Todo" ) { | 1062 | if ( incidence->type() == "Todo" ) { |
1056 | Todo * t = (Todo*)incidence; | 1063 | Todo * t = (Todo*)incidence; |
1057 | if ( t->hasDueDate() ) | 1064 | if ( t->hasDueDate() ) |
1058 | dt = t->dtDue(); | 1065 | dt = t->dtDue(); |
1059 | else | 1066 | else |
1060 | dt = cur.addSecs( 62 ); | 1067 | dt = cur.addSecs( 62 ); |
1061 | } | 1068 | } |
1062 | else { | 1069 | else { |
1063 | bool ok; | 1070 | bool ok; |
1064 | dt = incidence->getNextOccurence( cur, &ok ); | 1071 | dt = incidence->getNextOccurence( cur, &ok ); |
1065 | if ( !ok ) | 1072 | if ( !ok ) |
1066 | dt = cur.addSecs( -62 ); | 1073 | dt = cur.addSecs( -62 ); |
1067 | } | 1074 | } |
1068 | if ( dt < cur || dt > end ) { | 1075 | if ( dt < cur || dt > end ) { |
1069 | add = false; | 1076 | add = false; |
1070 | } | 1077 | } |
1071 | } | 1078 | } |
1072 | if ( add ) { | 1079 | if ( add ) { |
1073 | Incidence *in = incidence->clone(); | 1080 | Incidence *in = incidence->clone(); |
1074 | cal->addIncidence( in ); | 1081 | cal->addIncidence( in ); |
1075 | } | 1082 | } |
1076 | } | 1083 | } |
1077 | incidence = delSel.next(); | 1084 | incidence = delSel.next(); |
1078 | } | 1085 | } |
1079 | PhoneAccess::writeConfig( KPimGlobalPrefs::instance()->mEx2PhoneDevice, | 1086 | PhoneAccess::writeConfig( KPimGlobalPrefs::instance()->mEx2PhoneDevice, |
1080 | KPimGlobalPrefs::instance()->mEx2PhoneConnection, | 1087 | KPimGlobalPrefs::instance()->mEx2PhoneConnection, |
1081 | KPimGlobalPrefs::instance()->mEx2PhoneModel ); | 1088 | KPimGlobalPrefs::instance()->mEx2PhoneModel ); |
1082 | 1089 | ||
1083 | setCaption( i18n("Writing to phone...")); | 1090 | setCaption( i18n("Writing to phone...")); |
1084 | if ( PhoneFormat::writeToPhone( cal ) ) | 1091 | if ( PhoneFormat::writeToPhone( cal ) ) |
1085 | setCaption( i18n("Export to phone successful!")); | 1092 | setCaption( i18n("Export to phone successful!")); |
1086 | else | 1093 | else |
1087 | setCaption( i18n("Error exporting to phone!")); | 1094 | setCaption( i18n("Error exporting to phone!")); |
1088 | delete cal; | 1095 | delete cal; |
1089 | } | 1096 | } |
1090 | 1097 | ||
1091 | 1098 | ||
1092 | void MainWindow::setDefaultPreferences() | 1099 | void MainWindow::setDefaultPreferences() |
1093 | { | 1100 | { |
1094 | KOPrefs *p = KOPrefs::instance(); | 1101 | KOPrefs *p = KOPrefs::instance(); |
1095 | 1102 | ||
1096 | p->mCompactDialogs = true; | 1103 | p->mCompactDialogs = true; |
1097 | p->mConfirm = true; | 1104 | p->mConfirm = true; |
1098 | // p->mEnableQuickTodo = false; | 1105 | // p->mEnableQuickTodo = false; |
1099 | 1106 | ||
1100 | } | 1107 | } |
1101 | 1108 | ||
1102 | QString MainWindow::resourcePath() | 1109 | QString MainWindow::resourcePath() |
1103 | { | 1110 | { |
1104 | return KGlobal::iconLoader()->iconPath(); | 1111 | return KGlobal::iconLoader()->iconPath(); |
1105 | } | 1112 | } |
1106 | 1113 | ||
1107 | void MainWindow::displayText( QString text ,QString cap ) | 1114 | void MainWindow::displayText( QString text ,QString cap ) |
1108 | { | 1115 | { |
1109 | QDialog dia( this, "name", true ); ; | 1116 | QDialog dia( this, "name", true ); ; |
1110 | dia.setCaption( cap ); | 1117 | dia.setCaption( cap ); |
1111 | QVBoxLayout* lay = new QVBoxLayout( &dia ); | 1118 | QVBoxLayout* lay = new QVBoxLayout( &dia ); |
1112 | lay->setSpacing( 3 ); | 1119 | lay->setSpacing( 3 ); |
1113 | lay->setMargin( 3 ); | 1120 | lay->setMargin( 3 ); |
1114 | QTextBrowser tb ( &dia ); | 1121 | QTextBrowser tb ( &dia ); |
1115 | lay->addWidget( &tb ); | 1122 | lay->addWidget( &tb ); |
1116 | tb.setText( text ); | 1123 | tb.setText( text ); |
1117 | #ifdef DESKTOP_VERSION | 1124 | #ifdef DESKTOP_VERSION |
1118 | dia.resize( 640, 480); | 1125 | dia.resize( 640, 480); |
1119 | #else | 1126 | #else |
1120 | dia.showMaximized(); | 1127 | dia.showMaximized(); |
1121 | #endif | 1128 | #endif |
1122 | dia.exec(); | 1129 | dia.exec(); |
1123 | } | 1130 | } |
1124 | void MainWindow::displayFile( QString fn, QString cap ) | 1131 | void MainWindow::displayFile( QString fn, QString cap ) |
1125 | { | 1132 | { |
1126 | QString fileName = resourcePath() + fn; | 1133 | QString fileName = resourcePath() + fn; |
1127 | QString text; | 1134 | QString text; |
1128 | QFile file( fileName ); | 1135 | QFile file( fileName ); |
1129 | if (!file.open( IO_ReadOnly ) ) { | 1136 | if (!file.open( IO_ReadOnly ) ) { |
1130 | return ; | 1137 | return ; |
1131 | 1138 | ||
1132 | } | 1139 | } |
1133 | QTextStream ts( &file ); | 1140 | QTextStream ts( &file ); |
1134 | text = ts.read(); | 1141 | text = ts.read(); |
1135 | file.close(); | 1142 | file.close(); |
1136 | displayText( text, cap); | 1143 | displayText( text, cap); |
1137 | } | 1144 | } |
1138 | void MainWindow::features() | 1145 | void MainWindow::features() |
1139 | { | 1146 | { |
1140 | 1147 | ||
1141 | displayFile( "featuresKOPI.txt",i18n("KO/Pi Features and hints") ); | 1148 | displayFile( "featuresKOPI.txt",i18n("KO/Pi Features and hints") ); |
1142 | } | 1149 | } |
1143 | 1150 | ||
1144 | void MainWindow::usertrans() | 1151 | void MainWindow::usertrans() |
1145 | { | 1152 | { |
1146 | 1153 | ||
1147 | displayFile( "usertranslationHOWTO.txt",i18n("KO/Pi User translation HowTo") ); | 1154 | displayFile( "usertranslationHOWTO.txt",i18n("KO/Pi User translation HowTo") ); |
1148 | } | 1155 | } |
1149 | 1156 | ||
1157 | void MainWindow::kdesynchowto() | ||
1158 | { | ||
1159 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" ); | ||
1160 | } | ||
1161 | void MainWindow::multisynchowto() | ||
1162 | { | ||
1163 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" ); | ||
1164 | } | ||
1150 | void MainWindow::synchowto() | 1165 | void MainWindow::synchowto() |
1151 | { | 1166 | { |
1152 | |||
1153 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); | 1167 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); |
1154 | } | 1168 | } |
1155 | void MainWindow::faq() | 1169 | void MainWindow::faq() |
1156 | { | 1170 | { |
1157 | displayFile( "kopiFAQ.txt",i18n("KO/Pi FAQ") ); | 1171 | displayFile( "kopiFAQ.txt",i18n("KO/Pi FAQ") ); |
1158 | 1172 | ||
1159 | } | 1173 | } |
1160 | void MainWindow::whatsNew() | 1174 | void MainWindow::whatsNew() |
1161 | { | 1175 | { |
1162 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); | 1176 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); |
1163 | 1177 | ||
1164 | } | 1178 | } |
1165 | void MainWindow::licence() | 1179 | void MainWindow::licence() |
1166 | { | 1180 | { |
1167 | KApplication::showLicence(); | 1181 | KApplication::showLicence(); |
1168 | 1182 | ||
1169 | } | 1183 | } |
1170 | void MainWindow::about() | 1184 | void MainWindow::about() |
1171 | { | 1185 | { |
1172 | QString version; | 1186 | QString version; |
1173 | #include <../version> | 1187 | #include <../version> |
1174 | QMessageBox::about( this, i18n("About KOrganizer/Pi"), | 1188 | QMessageBox::about( this, i18n("About KOrganizer/Pi"), |
1175 | i18n("KOrganizer/Platform-independent\n") + | 1189 | i18n("KOrganizer/Platform-independent\n") + |
1176 | "(KO/Pi) " + version + " - " + | 1190 | "(KO/Pi) " + version + " - " + |
1177 | 1191 | ||
1178 | #ifdef DESKTOP_VERSION | 1192 | #ifdef DESKTOP_VERSION |
1179 | i18n("Desktop Edition\n") + | 1193 | i18n("Desktop Edition\n") + |
1180 | #else | 1194 | #else |
1181 | i18n("PDA-Edition\nfor: Zaurus 5x00 / 7x0 / 8x0\n") + | 1195 | i18n("PDA-Edition\nfor: Zaurus 5x00 / 7x0 / 8x0\n") + |
1182 | #endif | 1196 | #endif |
1183 | i18n("(c) 2004 Lutz Rogowski\nEmail:lutz@pi-sync.net\nKO/Pi is based on KOrganizer\n(c) 2002,2003 Cornelius Schumacher\nEmail: schumacher@kde.org\nKOrganizer/Pi is licensed\nunder the GPL.\nKO/Pi can be compiled for\nLinux, Zaurus-PDA and Windows\nwww.korganizer.org\nwww.pi-sync.net\n") ); | 1197 | i18n("(c) 2004 Lutz Rogowski\nEmail:lutz@pi-sync.net\nKO/Pi is based on KOrganizer\n(c) 2002,2003 Cornelius Schumacher\nEmail: schumacher@kde.org\nKOrganizer/Pi is licensed\nunder the GPL.\nKO/Pi can be compiled for\nLinux, Zaurus-PDA and Windows\nwww.korganizer.org\nwww.pi-sync.net\n") ); |
1184 | } | 1198 | } |
1185 | void MainWindow::keyBindings() | 1199 | void MainWindow::keyBindings() |
1186 | { | 1200 | { |
1187 | QString cap = i18n("Key bindings KOrganizer/Pi"); | 1201 | QString cap = i18n("Key bindings KOrganizer/Pi"); |
1188 | QString text = i18n("<p><h2>KO/Pi key shortcuts:</h2></p>\n") + | 1202 | QString text = i18n("<p><h2>KO/Pi key shortcuts:</h2></p>\n") + |
1189 | i18n("<p><b>H</b>: This help dialog | <b>S</b>: Search dialog</p>\n")+ | 1203 | i18n("<p><b>H</b>: This help dialog | <b>S</b>: Search dialog</p>\n")+ |
1190 | i18n("<p><b>I</b>: Show info for selected event/todo</p>\n") + | 1204 | i18n("<p><b>I</b>: Show info for selected event/todo</p>\n") + |
1191 | i18n("<p><b>Space</b>: Toggle fullscreen | <b>P</b>: Date picker</p>\n")+ | 1205 | i18n("<p><b>Space</b>: Toggle fullscreen | <b>P</b>: Date picker</p>\n")+ |
1192 | i18n("<p><b>F</b>: Toggle filterview |<b>F+ctrl</b>: Edit filter </p>\n")+ | 1206 | i18n("<p><b>F</b>: Toggle filterview |<b>F+ctrl</b>: Edit filter </p>\n")+ |
1193 | i18n("<p><b>O</b>: Filter On/Off | <b>J</b>: Journal view</p>\n")+ | 1207 | i18n("<p><b>O</b>: Filter On/Off | <b>J</b>: Journal view</p>\n")+ |
1194 | i18n("<p><b>1-0</b> (+<b>ctrl</b>): Select filter 1-10 (11-20)</p>\n")+ | 1208 | i18n("<p><b>1-0</b> (+<b>ctrl</b>): Select filter 1-10 (11-20)</p>\n")+ |
1195 | i18n("<p><b>N</b>: Next days view| <b>W</b>: What's next view\n ")+ | 1209 | i18n("<p><b>N</b>: Next days view| <b>W</b>: What's next view\n ")+ |
1196 | i18n("<p><b>V</b>: Todo view | <b>L</b>: Event list view</p>\n")+ | 1210 | i18n("<p><b>V</b>: Todo view | <b>L</b>: Event list view</p>\n")+ |
1197 | i18n("<p><b>Z,Y</b>: Work week view | <b>U</b>: Week view</p>\n")+ | 1211 | i18n("<p><b>Z,Y</b>: Work week view | <b>U</b>: Week view</p>\n")+ |
1198 | i18n("<p><b>D</b>: One day view | <b>M</b>: Month view</p>\n")+ | 1212 | i18n("<p><b>D</b>: One day view | <b>M</b>: Month view</p>\n")+ |
1199 | i18n("<p><b>E</b>: Edit selected item |<b> E+ctrl</b>: New Event</p>\n")+ | 1213 | i18n("<p><b>E</b>: Edit selected item |<b> E+ctrl</b>: New Event</p>\n")+ |
1200 | i18n("<p><b>T</b>: Goto today | <b>T+ctrl</b>: New Todo</p>\n")+ | 1214 | i18n("<p><b>T</b>: Goto today | <b>T+ctrl</b>: New Todo</p>\n")+ |
1201 | i18n("<p><b>S+ctrl</b>: Add sub-todo | <b>X</b>: Toggle datenavigator</p>\n")+ | 1215 | i18n("<p><b>S+ctrl</b>: Add sub-todo | <b>X</b>: Toggle datenavigator</p>\n")+ |
1202 | i18n("<p><b>+,-</b> : Zoom in/out agenda | <b>A</b>: Toggle allday agenda height</p>\n")+ | 1216 | i18n("<p><b>+,-</b> : Zoom in/out agenda | <b>A</b>: Toggle allday agenda height</p>\n")+ |
1203 | i18n("<p><b>C</b>: Show current time in agenda view</p>\n")+ | 1217 | i18n("<p><b>C</b>: Show current time in agenda view</p>\n")+ |
1204 | i18n("<p><b>B</b>: Edit description (details) of selected item</p>\n")+ | 1218 | i18n("<p><b>B</b>: Edit description (details) of selected item</p>\n")+ |
1205 | i18n("<p><b>right</b>: Next week | <b>right+ctrl</b>: Next month</p>\n")+ | 1219 | i18n("<p><b>right</b>: Next week | <b>right+ctrl</b>: Next month</p>\n")+ |
1206 | i18n("<p><b>left</b>: Prev. week | <b>left+ctrl</b>: Prev. month</p>\n")+ | 1220 | i18n("<p><b>left</b>: Prev. week | <b>left+ctrl</b>: Prev. month</p>\n")+ |
1207 | i18n("<p><b>del,backspace</b>: Delete selected item</p>\n")+ | 1221 | i18n("<p><b>del,backspace</b>: Delete selected item</p>\n")+ |
1208 | i18n("<p><h3>In agenda view:</h3></p>\n") + | 1222 | i18n("<p><h3>In agenda view:</h3></p>\n") + |
1209 | i18n("<p><b>up/down</b>: Scroll agenda view</p>\n")+ | 1223 | i18n("<p><b>up/down</b>: Scroll agenda view</p>\n")+ |
1210 | i18n("<p><b>ctrl+up/down</b>: Scroll small todo view</p>\n")+ | 1224 | i18n("<p><b>ctrl+up/down</b>: Scroll small todo view</p>\n")+ |
1211 | i18n("<p><h3>In todo view:</h3></p>\n") + | 1225 | i18n("<p><h3>In todo view:</h3></p>\n") + |
1212 | i18n("<p><b>shift+U</b>: <b>U</b>nparent todo (make root todo)</p>\n")+ | 1226 | i18n("<p><b>shift+U</b>: <b>U</b>nparent todo (make root todo)</p>\n")+ |
1213 | i18n("<p><b>shift+S</b>: Make <b>S</b>ubtodo (reparent todo)</p>\n")+ | 1227 | i18n("<p><b>shift+S</b>: Make <b>S</b>ubtodo (reparent todo)</p>\n")+ |
1214 | i18n("<p><b>shift+P</b>: Make new <b>P</b>arent for todo selected with shift+S</p>\n")+ | 1228 | i18n("<p><b>shift+P</b>: Make new <b>P</b>arent for todo selected with shift+S</p>\n")+ |
1215 | i18n("<p><b>Q</b>: Toggle quick todo line edit.</p>\n")+ | 1229 | i18n("<p><b>Q</b>: Toggle quick todo line edit.</p>\n")+ |
1216 | i18n("<p><b>I</b>: Show info of current item+one step down.</p>\n")+ | 1230 | i18n("<p><b>I</b>: Show info of current item+one step down.</p>\n")+ |
1217 | i18n("<p><b>return</b>: Mark item as completed+one step down.</p>\n")+ | 1231 | i18n("<p><b>return</b>: Mark item as completed+one step down.</p>\n")+ |
1218 | i18n("<p><b>return+shift</b>: Mark item as not completed+one step down</p>\n")+ | 1232 | i18n("<p><b>return+shift</b>: Mark item as not completed+one step down</p>\n")+ |
1219 | i18n("<p><h3>In list view:</h3></p>\n") + | 1233 | i18n("<p><h3>In list view:</h3></p>\n") + |
1220 | i18n("<p><b>I</b>: Show info of current item+one step down.</p>\n")+ | 1234 | i18n("<p><b>I</b>: Show info of current item+one step down.</p>\n")+ |
1221 | i18n("<p><b>return</b>: Select item+one step down</p>\n")+ | 1235 | i18n("<p><b>return</b>: Select item+one step down</p>\n")+ |
1222 | i18n("<p><b>return+shift</b>: Deselect item+one step down</p>\n")+ | 1236 | i18n("<p><b>return+shift</b>: Deselect item+one step down</p>\n")+ |
1223 | i18n("<p><b>up/down</b>: Next/prev item</p>\n")+ | 1237 | i18n("<p><b>up/down</b>: Next/prev item</p>\n")+ |
1224 | i18n("<p><b>ctrl+up/down</b>: Goto up/down by 20% of items</p>\n")+ | 1238 | i18n("<p><b>ctrl+up/down</b>: Goto up/down by 20% of items</p>\n")+ |
1225 | i18n("<p><b>shift+up/down</b>: Goto first/last item</p>\n")+ | 1239 | i18n("<p><b>shift+up/down</b>: Goto first/last item</p>\n")+ |
1226 | i18n("<p><h3>In event/todo viewer:</h3></p>\n") + | 1240 | i18n("<p><h3>In event/todo viewer:</h3></p>\n") + |
1227 | i18n("<p><b>I,C</b>: Close dialog.</p>\n")+ | 1241 | i18n("<p><b>I,C</b>: Close dialog.</p>\n")+ |
1228 | i18n("<p><b>A</b>: Show agenda view.</p>\n")+ | 1242 | i18n("<p><b>A</b>: Show agenda view.</p>\n")+ |
1229 | i18n("<p><b>E</b>: Edit item</p>\n") + | 1243 | i18n("<p><b>E</b>: Edit item</p>\n") + |
1230 | i18n("<p><h2>KO/Pi icon colors:</h2></p>\n") + | 1244 | i18n("<p><h2>KO/Pi icon colors:</h2></p>\n") + |
1231 | i18n("<p><b>(for square icons in agenda and month view)</b></p>\n") + | 1245 | i18n("<p><b>(for square icons in agenda and month view)</b></p>\n") + |
1232 | i18n("<p><b>Cross</b>: Item cancelled.([c] in Whats'Next view)</p>\n")+ | 1246 | i18n("<p><b>Cross</b>: Item cancelled.([c] in Whats'Next view)</p>\n")+ |
1233 | i18n("<p><b>Red</b>: Alarm set.([a] in Whats'Next view)</p>\n")+ | 1247 | i18n("<p><b>Red</b>: Alarm set.([a] in Whats'Next view)</p>\n")+ |
1234 | i18n("<p><b>Blue</b>: Recurrent event.([r] in Whats'Next view)</p>\n")+ | 1248 | i18n("<p><b>Blue</b>: Recurrent event.([r] in Whats'Next view)</p>\n")+ |
1235 | i18n("<p><b>Dark green</b>: Information(description) available.([i] in WN view)</p>\n")+ | 1249 | i18n("<p><b>Dark green</b>: Information(description) available.([i] in WN view)</p>\n")+ |
1236 | i18n("<p><b>Black</b>: Event/todo with attendees. You are the organizer!</p>\n")+ | 1250 | i18n("<p><b>Black</b>: Event/todo with attendees. You are the organizer!</p>\n")+ |
1237 | i18n("<p><b>Dark yellow</b>: Event/todo with attendees.</p>\n") + | 1251 | i18n("<p><b>Dark yellow</b>: Event/todo with attendees.</p>\n") + |
1238 | i18n("<p><b>White</b>: Item readonly</p>\n"); | 1252 | i18n("<p><b>White</b>: Item readonly</p>\n"); |
1239 | displayText( text, cap); | 1253 | displayText( text, cap); |
1240 | 1254 | ||
1241 | } | 1255 | } |
1242 | void MainWindow::aboutAutoSaving() | 1256 | void MainWindow::aboutAutoSaving() |
1243 | { | 1257 | { |
1244 | QMessageBox* msg; | 1258 | QMessageBox* msg; |
1245 | msg = new QMessageBox( i18n("Auto Saving in KOrganizer/Pi"), | 1259 | msg = new QMessageBox( i18n("Auto Saving in KOrganizer/Pi"), |
1246 | i18n("After changing something, the data is\nautomatically saved to the file\n~/kdepim/apps/korganizer/mycalendar.ics\nafter (configureable) three minutes.\nFor safety reasons there is one autosaving\nafter 10 minutes (of idle time) again. The \ndata is saved automatically when closing KO/Pi\nYou can create a backup file \nwith: File - Save Calendar Backup\n"), QMessageBox::NoIcon, | 1260 | i18n("After changing something, the data is\nautomatically saved to the file\n~/kdepim/apps/korganizer/mycalendar.ics\nafter (configureable) three minutes.\nFor safety reasons there is one autosaving\nafter 10 minutes (of idle time) again. The \ndata is saved automatically when closing KO/Pi\nYou can create a backup file \nwith: File - Save Calendar Backup\n"), QMessageBox::NoIcon, |
1247 | QMessageBox::Ok, | 1261 | QMessageBox::Ok, |
1248 | QMessageBox::NoButton, | 1262 | QMessageBox::NoButton, |
diff --git a/korganizer/mainwindow.h b/korganizer/mainwindow.h index 0926313..ed65d36 100644 --- a/korganizer/mainwindow.h +++ b/korganizer/mainwindow.h | |||
@@ -1,138 +1,140 @@ | |||
1 | #ifndef KORGE_MAINWINDOW_H | 1 | #ifndef KORGE_MAINWINDOW_H |
2 | #define KORGE_MAINWINDOW_H | 2 | #define KORGE_MAINWINDOW_H |
3 | 3 | ||
4 | #include <qmainwindow.h> | 4 | #include <qmainwindow.h> |
5 | #include <qtimer.h> | 5 | #include <qtimer.h> |
6 | #include <qdict.h> | 6 | #include <qdict.h> |
7 | #include <qfile.h> | 7 | #include <qfile.h> |
8 | #include <qtextstream.h> | 8 | #include <qtextstream.h> |
9 | #include <qregexp.h> | 9 | #include <qregexp.h> |
10 | 10 | ||
11 | #include <libkcal/incidence.h> | 11 | #include <libkcal/incidence.h> |
12 | #include "simplealarmclient.h" | 12 | #include "simplealarmclient.h" |
13 | #include <ksyncmanager.h> | 13 | #include <ksyncmanager.h> |
14 | #ifndef DESKTOP_VERSION | 14 | #ifndef DESKTOP_VERSION |
15 | #include <qcopchannel_qws.h> | 15 | #include <qcopchannel_qws.h> |
16 | #endif | 16 | #endif |
17 | class QAction; | 17 | class QAction; |
18 | class CalendarView; | 18 | class CalendarView; |
19 | class KSyncProfile; | 19 | class KSyncProfile; |
20 | #ifdef DESKTOP_VERSION | 20 | #ifdef DESKTOP_VERSION |
21 | 21 | ||
22 | #define QPEToolBar QToolBar | 22 | #define QPEToolBar QToolBar |
23 | #define QPEMenuBar QMenuBar | 23 | #define QPEMenuBar QMenuBar |
24 | #endif | 24 | #endif |
25 | class QPEToolBar; | 25 | class QPEToolBar; |
26 | 26 | ||
27 | 27 | ||
28 | namespace KCal { | 28 | namespace KCal { |
29 | class CalendarLocal; | 29 | class CalendarLocal; |
30 | } | 30 | } |
31 | 31 | ||
32 | using namespace KCal; | 32 | using namespace KCal; |
33 | 33 | ||
34 | class MainWindow : public QMainWindow | 34 | class MainWindow : public QMainWindow |
35 | { | 35 | { |
36 | Q_OBJECT | 36 | Q_OBJECT |
37 | public: | 37 | public: |
38 | MainWindow( QWidget *parent = 0, const char *name = 0, QString command = ""); | 38 | MainWindow( QWidget *parent = 0, const char *name = 0, QString command = ""); |
39 | ~MainWindow(); | 39 | ~MainWindow(); |
40 | bool beamReceiveEnabled(); | 40 | bool beamReceiveEnabled(); |
41 | public slots: | 41 | public slots: |
42 | virtual void showMaximized (); | 42 | virtual void showMaximized (); |
43 | void configureAgenda( int ); | 43 | void configureAgenda( int ); |
44 | void recieve( const QCString& msg, const QByteArray& data ); | 44 | void recieve( const QCString& msg, const QByteArray& data ); |
45 | static QString defaultFileName(); | 45 | static QString defaultFileName(); |
46 | static QString syncFileName(); | 46 | static QString syncFileName(); |
47 | static QString resourcePath(); | 47 | static QString resourcePath(); |
48 | protected slots: | 48 | protected slots: |
49 | void setCaptionToDates(); | 49 | void setCaptionToDates(); |
50 | void about(); | 50 | void about(); |
51 | void licence(); | 51 | void licence(); |
52 | void faq(); | 52 | void faq(); |
53 | void usertrans(); | 53 | void usertrans(); |
54 | void features(); | 54 | void features(); |
55 | void synchowto(); | 55 | void synchowto(); |
56 | void kdesynchowto(); | ||
57 | void multisynchowto(); | ||
56 | void whatsNew(); | 58 | void whatsNew(); |
57 | void keyBindings(); | 59 | void keyBindings(); |
58 | void aboutAutoSaving();; | 60 | void aboutAutoSaving();; |
59 | void aboutKnownBugs(); | 61 | void aboutKnownBugs(); |
60 | 62 | ||
61 | void processIncidenceSelection( Incidence * ); | 63 | void processIncidenceSelection( Incidence * ); |
62 | 64 | ||
63 | void importQtopia(); | 65 | void importQtopia(); |
64 | void importBday(); | 66 | void importBday(); |
65 | void importOL(); | 67 | void importOL(); |
66 | void importIcal(); | 68 | void importIcal(); |
67 | void importFile( QString, bool ); | 69 | void importFile( QString, bool ); |
68 | void quickImportIcal(); | 70 | void quickImportIcal(); |
69 | 71 | ||
70 | void slotModifiedChanged( bool ); | 72 | void slotModifiedChanged( bool ); |
71 | 73 | ||
72 | void save(); | 74 | void save(); |
73 | void configureToolBar( int ); | 75 | void configureToolBar( int ); |
74 | void printSel(); | 76 | void printSel(); |
75 | void printCal(); | 77 | void printCal(); |
76 | void saveCalendar(); | 78 | void saveCalendar(); |
77 | void loadCalendar(); | 79 | void loadCalendar(); |
78 | void exportVCalendar(); | 80 | void exportVCalendar(); |
79 | void fillFilterMenu(); | 81 | void fillFilterMenu(); |
80 | void selectFilter( int ); | 82 | void selectFilter( int ); |
81 | void exportToPhone( int ); | 83 | void exportToPhone( int ); |
82 | void toggleBeamReceive(); | 84 | void toggleBeamReceive(); |
83 | void disableBR(bool); | 85 | void disableBR(bool); |
84 | 86 | ||
85 | 87 | ||
86 | protected: | 88 | protected: |
87 | void displayText( QString, QString); | 89 | void displayText( QString, QString); |
88 | void displayFile( QString, QString); | 90 | void displayFile( QString, QString); |
89 | 91 | ||
90 | void enableIncidenceActions( bool ); | 92 | void enableIncidenceActions( bool ); |
91 | 93 | ||
92 | private slots: | 94 | private slots: |
93 | QSocket* piSocket; | 95 | QSocket* piSocket; |
94 | QString piFileString; | 96 | QString piFileString; |
95 | QTime piTime; | 97 | QTime piTime; |
96 | void getFile( bool ); | 98 | void getFile( bool ); |
97 | void syncFileRequest(); | 99 | void syncFileRequest(); |
98 | private: | 100 | private: |
99 | bool mBRdisabled; | 101 | bool mBRdisabled; |
100 | #ifndef DESKTOP_VERSION | 102 | #ifndef DESKTOP_VERSION |
101 | QCopChannel* infrared; | 103 | QCopChannel* infrared; |
102 | #endif | 104 | #endif |
103 | QAction* brAction; | 105 | QAction* brAction; |
104 | KSyncManager* mSyncManager; | 106 | KSyncManager* mSyncManager; |
105 | bool mClosed; | 107 | bool mClosed; |
106 | void saveOnClose(); | 108 | void saveOnClose(); |
107 | bool mFlagKeyPressed; | 109 | bool mFlagKeyPressed; |
108 | bool mBlockAtStartup; | 110 | bool mBlockAtStartup; |
109 | QPEToolBar *iconToolBar; | 111 | QPEToolBar *iconToolBar; |
110 | void initActions(); | 112 | void initActions(); |
111 | void setDefaultPreferences(); | 113 | void setDefaultPreferences(); |
112 | void keyPressEvent ( QKeyEvent * ) ; | 114 | void keyPressEvent ( QKeyEvent * ) ; |
113 | void keyReleaseEvent ( QKeyEvent * ) ; | 115 | void keyReleaseEvent ( QKeyEvent * ) ; |
114 | QPopupMenu *configureToolBarMenu; | 116 | QPopupMenu *configureToolBarMenu; |
115 | QPopupMenu *selectFilterMenu; | 117 | QPopupMenu *selectFilterMenu; |
116 | QPopupMenu *configureAgendaMenu, *syncMenu; | 118 | QPopupMenu *configureAgendaMenu, *syncMenu; |
117 | CalendarLocal *mCalendar; | 119 | CalendarLocal *mCalendar; |
118 | CalendarView *mView; | 120 | CalendarView *mView; |
119 | QAction *mNewSubTodoAction; | 121 | QAction *mNewSubTodoAction; |
120 | 122 | ||
121 | QAction *mShowAction; | 123 | QAction *mShowAction; |
122 | QAction *mEditAction; | 124 | QAction *mEditAction; |
123 | QAction *mDeleteAction; | 125 | QAction *mDeleteAction; |
124 | QAction *mCloneAction; | 126 | QAction *mCloneAction; |
125 | QAction *mMoveAction; | 127 | QAction *mMoveAction; |
126 | QAction *mBeamAction; | 128 | QAction *mBeamAction; |
127 | QAction *mCancelAction; | 129 | QAction *mCancelAction; |
128 | 130 | ||
129 | void closeEvent( QCloseEvent* ce ); | 131 | void closeEvent( QCloseEvent* ce ); |
130 | SimpleAlarmClient mAlarmClient; | 132 | SimpleAlarmClient mAlarmClient; |
131 | QTimer mSaveTimer; | 133 | QTimer mSaveTimer; |
132 | //bool mBlockSaveFlag; | 134 | //bool mBlockSaveFlag; |
133 | bool mCalendarModifiedFlag; | 135 | bool mCalendarModifiedFlag; |
134 | QPixmap loadPixmap( QString ); | 136 | QPixmap loadPixmap( QString ); |
135 | }; | 137 | }; |
136 | 138 | ||
137 | 139 | ||
138 | #endif | 140 | #endif |
diff --git a/libkdepim/ksyncmanager.cpp b/libkdepim/ksyncmanager.cpp index 17e6c75..9857e3e 100644 --- a/libkdepim/ksyncmanager.cpp +++ b/libkdepim/ksyncmanager.cpp | |||
@@ -387,227 +387,227 @@ void KSyncManager::enableQuick( bool ask ) | |||
387 | } | 387 | } |
388 | } | 388 | } |
389 | else | 389 | else |
390 | autoStart = mPrefs->mPassiveSyncAutoStart; | 390 | autoStart = mPrefs->mPassiveSyncAutoStart; |
391 | if ( autoStart != mPrefs->mPassiveSyncAutoStart ) | 391 | if ( autoStart != mPrefs->mPassiveSyncAutoStart ) |
392 | changed = true; | 392 | changed = true; |
393 | bool ok; | 393 | bool ok; |
394 | mPrefs->mPassiveSyncAutoStart = false; | 394 | mPrefs->mPassiveSyncAutoStart = false; |
395 | Q_UINT16 port = mPrefs->mPassiveSyncPort.toUInt(&ok); | 395 | Q_UINT16 port = mPrefs->mPassiveSyncPort.toUInt(&ok); |
396 | if ( ! ok ) { | 396 | if ( ! ok ) { |
397 | KMessageBox::information( 0, i18n("No valid port")); | 397 | KMessageBox::information( 0, i18n("No valid port")); |
398 | return; | 398 | return; |
399 | } | 399 | } |
400 | //qDebug("port %d ", port); | 400 | //qDebug("port %d ", port); |
401 | mServerSocket = new KServerSocket ( mPrefs->mPassiveSyncPw, port ,1 ); | 401 | mServerSocket = new KServerSocket ( mPrefs->mPassiveSyncPw, port ,1 ); |
402 | mServerSocket->setFileName( defaultFileName() ); | 402 | mServerSocket->setFileName( defaultFileName() ); |
403 | //qDebug("connected "); | 403 | //qDebug("connected "); |
404 | if ( !mServerSocket->ok() ) { | 404 | if ( !mServerSocket->ok() ) { |
405 | KMessageBox::information( 0, i18n("Failed to bind or\nlisten to the port!")); | 405 | KMessageBox::information( 0, i18n("Failed to bind or\nlisten to the port!")); |
406 | delete mServerSocket; | 406 | delete mServerSocket; |
407 | mServerSocket = 0; | 407 | mServerSocket = 0; |
408 | return; | 408 | return; |
409 | } | 409 | } |
410 | mPrefs->mPassiveSyncAutoStart = autoStart; | 410 | mPrefs->mPassiveSyncAutoStart = autoStart; |
411 | if ( changed ) { | 411 | if ( changed ) { |
412 | mPrefs->writeConfig(); | 412 | mPrefs->writeConfig(); |
413 | } | 413 | } |
414 | connect( mServerSocket, SIGNAL ( request_file() ),this, SIGNAL ( request_file() ) ); | 414 | connect( mServerSocket, SIGNAL ( request_file() ),this, SIGNAL ( request_file() ) ); |
415 | connect( mServerSocket, SIGNAL ( file_received( bool ) ), this, SIGNAL ( getFile( bool ) ) ); | 415 | connect( mServerSocket, SIGNAL ( file_received( bool ) ), this, SIGNAL ( getFile( bool ) ) ); |
416 | } | 416 | } |
417 | 417 | ||
418 | void KSyncManager::syncLocalFile() | 418 | void KSyncManager::syncLocalFile() |
419 | { | 419 | { |
420 | 420 | ||
421 | QString fn =mPrefs->mLastSyncedLocalFile; | 421 | QString fn =mPrefs->mLastSyncedLocalFile; |
422 | QString ext; | 422 | QString ext; |
423 | 423 | ||
424 | switch(mTargetApp) | 424 | switch(mTargetApp) |
425 | { | 425 | { |
426 | case (KAPI): | 426 | case (KAPI): |
427 | ext = "(*.vcf)"; | 427 | ext = "(*.vcf)"; |
428 | break; | 428 | break; |
429 | case (KOPI): | 429 | case (KOPI): |
430 | ext = "(*.ics/*.vcs)"; | 430 | ext = "(*.ics/*.vcs)"; |
431 | break; | 431 | break; |
432 | case (PWMPI): | 432 | case (PWMPI): |
433 | ext = "(*.pwm)"; | 433 | ext = "(*.pwm)"; |
434 | break; | 434 | break; |
435 | default: | 435 | default: |
436 | qDebug("KSyncManager::syncLocalFile: invalid apptype selected"); | 436 | qDebug("KSyncManager::syncLocalFile: invalid apptype selected"); |
437 | break; | 437 | break; |
438 | 438 | ||
439 | } | 439 | } |
440 | 440 | ||
441 | fn =KFileDialog:: getOpenFileName( fn, i18n("Sync filename"+ext), mParent ); | 441 | fn =KFileDialog:: getOpenFileName( fn, i18n("Sync filename"+ext), mParent ); |
442 | if ( fn == "" ) | 442 | if ( fn == "" ) |
443 | return; | 443 | return; |
444 | if ( syncWithFile( fn, false ) ) { | 444 | if ( syncWithFile( fn, false ) ) { |
445 | qDebug("syncLocalFile() successful "); | 445 | qDebug("syncLocalFile() successful "); |
446 | } | 446 | } |
447 | 447 | ||
448 | } | 448 | } |
449 | 449 | ||
450 | bool KSyncManager::syncWithFile( QString fn , bool quick ) | 450 | bool KSyncManager::syncWithFile( QString fn , bool quick ) |
451 | { | 451 | { |
452 | bool ret = false; | 452 | bool ret = false; |
453 | QFileInfo info; | 453 | QFileInfo info; |
454 | info.setFile( fn ); | 454 | info.setFile( fn ); |
455 | QString mess; | 455 | QString mess; |
456 | bool loadbup = true; | 456 | bool loadbup = true; |
457 | if ( !info. exists() ) { | 457 | if ( !info. exists() ) { |
458 | mess = i18n( "Sync file \n...%1\ndoes not exist!\nNothing synced!\n").arg(fn.right( 30) ); | 458 | mess = i18n( "Sync file \n...%1\ndoes not exist!\nNothing synced!\n").arg(fn.right( 30) ); |
459 | int result = QMessageBox::warning( mParent, i18n("Warning!"), | 459 | int result = QMessageBox::warning( mParent, i18n("Warning!"), |
460 | mess ); | 460 | mess ); |
461 | return ret; | 461 | return ret; |
462 | } | 462 | } |
463 | int result = 0; | 463 | int result = 0; |
464 | if ( !quick ) { | 464 | if ( !quick ) { |
465 | mess = i18n("Sync with file \n...%1\nfrom:\n%2\n").arg(fn.right( 25)).arg(KGlobal::locale()->formatDateTime(info.lastModified (), true, false )); | 465 | mess = i18n("Sync with file \n...%1\nfrom:\n%2\n").arg(fn.right( 25)).arg(KGlobal::locale()->formatDateTime(info.lastModified (), true, false )); |
466 | result = QMessageBox::warning( mParent, i18n("Warning!"), | 466 | result = QMessageBox::warning( mParent, i18n("Warning!"), |
467 | mess, | 467 | mess, |
468 | i18n("Sync"), i18n("Cancel"), 0, | 468 | i18n("Sync"), i18n("Cancel"), 0, |
469 | 0, 1 ); | 469 | 0, 1 ); |
470 | if ( result ) | 470 | if ( result ) |
471 | return false; | 471 | return false; |
472 | } | 472 | } |
473 | if ( mAskForPreferences ) | 473 | if ( mAskForPreferences ) |
474 | if ( !edit_sync_options()) { | 474 | if ( !edit_sync_options()) { |
475 | mParent->topLevelWidget()->setCaption( i18n("Syncing aborted. Nothing synced.") ); | 475 | mParent->topLevelWidget()->setCaption( i18n("Syncing aborted. Nothing synced.") ); |
476 | return false; | 476 | return false; |
477 | } | 477 | } |
478 | if ( result == 0 ) { | 478 | if ( result == 0 ) { |
479 | //qDebug("Now sycing ... "); | 479 | //qDebug("Now sycing ... "); |
480 | if ( ret = mImplementation->sync( this, fn, mSyncAlgoPrefs ) ) | 480 | if ( ret = mImplementation->sync( this, fn, mSyncAlgoPrefs ) ) |
481 | mParent->topLevelWidget()->setCaption( i18n("Synchronization successful") ); | 481 | mParent->topLevelWidget()->setCaption( i18n("Synchronization successful") ); |
482 | else | 482 | else |
483 | mParent->topLevelWidget()->setCaption( i18n("Sync cancelled or failed. Nothing synced.") ); | 483 | mParent->topLevelWidget()->setCaption( i18n("Sync cancelled or failed.") ); |
484 | if ( ! quick ) | 484 | if ( ! quick ) |
485 | mPrefs->mLastSyncedLocalFile = fn; | 485 | mPrefs->mLastSyncedLocalFile = fn; |
486 | } | 486 | } |
487 | return ret; | 487 | return ret; |
488 | } | 488 | } |
489 | 489 | ||
490 | void KSyncManager::quickSyncLocalFile() | 490 | void KSyncManager::quickSyncLocalFile() |
491 | { | 491 | { |
492 | 492 | ||
493 | if ( syncWithFile( mPrefs->mLastSyncedLocalFile, true ) ) { | 493 | if ( syncWithFile( mPrefs->mLastSyncedLocalFile, true ) ) { |
494 | qDebug("quick syncLocalFile() successful "); | 494 | qDebug("quick syncLocalFile() successful "); |
495 | 495 | ||
496 | } | 496 | } |
497 | } | 497 | } |
498 | 498 | ||
499 | void KSyncManager::multiSync( bool askforPrefs ) | 499 | void KSyncManager::multiSync( bool askforPrefs ) |
500 | { | 500 | { |
501 | if (blockSave()) | 501 | if (blockSave()) |
502 | return; | 502 | return; |
503 | setBlockSave(true); | 503 | setBlockSave(true); |
504 | QString question = i18n("Do you really want\nto multiple sync\nwith all checked profiles?\nSyncing takes some\ntime - all profiles\nare synced twice!"); | 504 | QString question = i18n("Do you really want\nto multiple sync\nwith all checked profiles?\nSyncing takes some\ntime - all profiles\nare synced twice!"); |
505 | if ( QMessageBox::information( mParent, i18n("KDE-Pim Sync"), | 505 | if ( QMessageBox::information( mParent, i18n("KDE-Pim Sync"), |
506 | question, | 506 | question, |
507 | i18n("Yes"), i18n("No"), | 507 | i18n("Yes"), i18n("No"), |
508 | 0, 0 ) != 0 ) { | 508 | 0, 0 ) != 0 ) { |
509 | setBlockSave(false); | 509 | setBlockSave(false); |
510 | mParent->topLevelWidget()->setCaption(i18n("Aborted! Nothing synced!")); | 510 | mParent->topLevelWidget()->setCaption(i18n("Aborted! Nothing synced!")); |
511 | return; | 511 | return; |
512 | } | 512 | } |
513 | mCurrentSyncDevice = i18n("Multiple profiles") ; | 513 | mCurrentSyncDevice = i18n("Multiple profiles") ; |
514 | mSyncAlgoPrefs = mPrefs->mRingSyncAlgoPrefs; | 514 | mSyncAlgoPrefs = mPrefs->mRingSyncAlgoPrefs; |
515 | if ( askforPrefs ) { | 515 | if ( askforPrefs ) { |
516 | if ( !edit_sync_options()) { | 516 | if ( !edit_sync_options()) { |
517 | mParent->topLevelWidget()->setCaption( i18n("Syncing aborted. Nothing synced.") ); | 517 | mParent->topLevelWidget()->setCaption( i18n("Syncing aborted.") ); |
518 | return; | 518 | return; |
519 | } | 519 | } |
520 | mPrefs->mRingSyncAlgoPrefs = mSyncAlgoPrefs; | 520 | mPrefs->mRingSyncAlgoPrefs = mSyncAlgoPrefs; |
521 | } | 521 | } |
522 | mParent->topLevelWidget()->setCaption(i18n("Multiple sync started.") ); | 522 | mParent->topLevelWidget()->setCaption(i18n("Multiple sync started.") ); |
523 | qApp->processEvents(); | 523 | qApp->processEvents(); |
524 | int num = ringSync() ; | 524 | int num = ringSync() ; |
525 | if ( num > 1 ) | 525 | if ( num > 1 ) |
526 | ringSync(); | 526 | ringSync(); |
527 | setBlockSave(false); | 527 | setBlockSave(false); |
528 | if ( num ) | 528 | if ( num ) |
529 | emit save(); | 529 | emit save(); |
530 | if ( num ) | 530 | if ( num ) |
531 | mParent->topLevelWidget()->setCaption(i18n("%1 profiles synced. Multiple sync complete!").arg(num) ); | 531 | mParent->topLevelWidget()->setCaption(i18n("%1 profiles synced. Multiple sync complete!").arg(num) ); |
532 | else | 532 | else |
533 | mParent->topLevelWidget()->setCaption(i18n("Nothing synced! No profiles defined for multisync!")); | 533 | mParent->topLevelWidget()->setCaption(i18n("Nothing synced! No profiles defined for multisync!")); |
534 | return; | 534 | return; |
535 | } | 535 | } |
536 | 536 | ||
537 | int KSyncManager::ringSync() | 537 | int KSyncManager::ringSync() |
538 | { | 538 | { |
539 | int syncedProfiles = 0; | 539 | int syncedProfiles = 0; |
540 | unsigned int i; | 540 | unsigned int i; |
541 | QTime timer; | 541 | QTime timer; |
542 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); | 542 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); |
543 | QStringList syncProfileNames = mSyncProfileNames; | 543 | QStringList syncProfileNames = mSyncProfileNames; |
544 | KSyncProfile* temp = new KSyncProfile (); | 544 | KSyncProfile* temp = new KSyncProfile (); |
545 | mAskForPreferences = false; | 545 | mAskForPreferences = false; |
546 | for ( i = 0; i < syncProfileNames.count(); ++i ) { | 546 | for ( i = 0; i < syncProfileNames.count(); ++i ) { |
547 | mCurrentSyncProfile = i; | 547 | mCurrentSyncProfile = i; |
548 | temp->setName(syncProfileNames[mCurrentSyncProfile]); | 548 | temp->setName(syncProfileNames[mCurrentSyncProfile]); |
549 | temp->readConfig(&config); | 549 | temp->readConfig(&config); |
550 | 550 | ||
551 | bool includeInRingSync; | 551 | bool includeInRingSync; |
552 | switch(mTargetApp) | 552 | switch(mTargetApp) |
553 | { | 553 | { |
554 | case (KAPI): | 554 | case (KAPI): |
555 | includeInRingSync = temp->getIncludeInRingSyncAB(); | 555 | includeInRingSync = temp->getIncludeInRingSyncAB(); |
556 | break; | 556 | break; |
557 | case (KOPI): | 557 | case (KOPI): |
558 | includeInRingSync = temp->getIncludeInRingSync(); | 558 | includeInRingSync = temp->getIncludeInRingSync(); |
559 | break; | 559 | break; |
560 | case (PWMPI): | 560 | case (PWMPI): |
561 | includeInRingSync = temp->getIncludeInRingSyncPWM(); | 561 | includeInRingSync = temp->getIncludeInRingSyncPWM(); |
562 | break; | 562 | break; |
563 | default: | 563 | default: |
564 | qDebug("KSyncManager::ringSync: invalid apptype selected"); | 564 | qDebug("KSyncManager::ringSync: invalid apptype selected"); |
565 | break; | 565 | break; |
566 | 566 | ||
567 | } | 567 | } |
568 | 568 | ||
569 | 569 | ||
570 | if ( includeInRingSync && ( i < 1 || i > 2 )) { | 570 | if ( includeInRingSync && ( i < 1 || i > 2 )) { |
571 | mParent->topLevelWidget()->setCaption(i18n("Profile ")+syncProfileNames[mCurrentSyncProfile]+ i18n(" is synced ... ")); | 571 | mParent->topLevelWidget()->setCaption(i18n("Profile ")+syncProfileNames[mCurrentSyncProfile]+ i18n(" is synced ... ")); |
572 | ++syncedProfiles; | 572 | ++syncedProfiles; |
573 | // mAskForPreferences = temp->getAskForPreferences(); | 573 | // mAskForPreferences = temp->getAskForPreferences(); |
574 | mWriteBackFile = temp->getWriteBackFile(); | 574 | mWriteBackFile = temp->getWriteBackFile(); |
575 | mWriteBackExistingOnly = temp->getWriteBackExisting(); | 575 | mWriteBackExistingOnly = temp->getWriteBackExisting(); |
576 | mWriteBackInFuture = 0; | 576 | mWriteBackInFuture = 0; |
577 | if ( temp->getWriteBackFuture() ) | 577 | if ( temp->getWriteBackFuture() ) |
578 | mWriteBackInFuture = temp->getWriteBackFutureWeeks( ); | 578 | mWriteBackInFuture = temp->getWriteBackFutureWeeks( ); |
579 | mShowSyncSummary = false; | 579 | mShowSyncSummary = false; |
580 | mCurrentSyncDevice = syncProfileNames[i] ; | 580 | mCurrentSyncDevice = syncProfileNames[i] ; |
581 | mCurrentSyncName = mLocalMachineName; | 581 | mCurrentSyncName = mLocalMachineName; |
582 | if ( i == 0 ) { | 582 | if ( i == 0 ) { |
583 | #ifdef DESKTOP_VERSION | 583 | #ifdef DESKTOP_VERSION |
584 | syncKDE(); | 584 | syncKDE(); |
585 | #else | 585 | #else |
586 | syncSharp(); | 586 | syncSharp(); |
587 | #endif | 587 | #endif |
588 | } else { | 588 | } else { |
589 | if ( temp->getIsLocalFileSync() ) { | 589 | if ( temp->getIsLocalFileSync() ) { |
590 | switch(mTargetApp) | 590 | switch(mTargetApp) |
591 | { | 591 | { |
592 | case (KAPI): | 592 | case (KAPI): |
593 | if ( syncWithFile( temp->getRemoteFileNameAB( ), false ) ) | 593 | if ( syncWithFile( temp->getRemoteFileNameAB( ), false ) ) |
594 | mPrefs->mLastSyncedLocalFile = temp->getRemoteFileNameAB(); | 594 | mPrefs->mLastSyncedLocalFile = temp->getRemoteFileNameAB(); |
595 | break; | 595 | break; |
596 | case (KOPI): | 596 | case (KOPI): |
597 | if ( syncWithFile( temp->getRemoteFileName( ), false ) ) | 597 | if ( syncWithFile( temp->getRemoteFileName( ), false ) ) |
598 | mPrefs->mLastSyncedLocalFile = temp->getRemoteFileName(); | 598 | mPrefs->mLastSyncedLocalFile = temp->getRemoteFileName(); |
599 | break; | 599 | break; |
600 | case (PWMPI): | 600 | case (PWMPI): |
601 | if ( syncWithFile( temp->getRemoteFileNamePWM( ), false ) ) | 601 | if ( syncWithFile( temp->getRemoteFileNamePWM( ), false ) ) |
602 | mPrefs->mLastSyncedLocalFile = temp->getRemoteFileNamePWM(); | 602 | mPrefs->mLastSyncedLocalFile = temp->getRemoteFileNamePWM(); |
603 | break; | 603 | break; |
604 | default: | 604 | default: |
605 | qDebug("KSyncManager::slotSyncMenu: invalid apptype selected"); | 605 | qDebug("KSyncManager::slotSyncMenu: invalid apptype selected"); |
606 | break; | 606 | break; |
607 | } | 607 | } |
608 | } else { | 608 | } else { |
609 | if ( temp->getIsPhoneSync() ) { | 609 | if ( temp->getIsPhoneSync() ) { |
610 | mPhoneDevice = temp->getPhoneDevice( ) ; | 610 | mPhoneDevice = temp->getPhoneDevice( ) ; |
611 | mPhoneConnection = temp->getPhoneConnection( ); | 611 | mPhoneConnection = temp->getPhoneConnection( ); |
612 | mPhoneModel = temp->getPhoneModel( ); | 612 | mPhoneModel = temp->getPhoneModel( ); |
613 | syncPhone(); | 613 | syncPhone(); |