summaryrefslogtreecommitdiffabout
path: root/kaddressbook/xxport/sharpdtm
authorulf69 <ulf69>2004-07-17 00:37:00 (UTC)
committer ulf69 <ulf69>2004-07-17 00:37:00 (UTC)
commit2439711b1ac7ee38269baff704293eb37a27f6c9 (patch) (side-by-side diff)
tree706d4a329b557b28db14442b41229d11fede854b /kaddressbook/xxport/sharpdtm
parentb306ee8c93dd563f42a32a1ee2c63eacc6050604 (diff)
downloadkdepimpi-2439711b1ac7ee38269baff704293eb37a27f6c9.zip
kdepimpi-2439711b1ac7ee38269baff704293eb37a27f6c9.tar.gz
kdepimpi-2439711b1ac7ee38269baff704293eb37a27f6c9.tar.bz2
implementation of sharp import and export
Diffstat (limited to 'kaddressbook/xxport/sharpdtm') (more/less context) (ignore whitespace changes)
-rw-r--r--kaddressbook/xxport/sharpdtm/sharpdtmE.pro2
-rw-r--r--kaddressbook/xxport/sharpdtm/sharpdtm_xxport.cpp103
2 files changed, 49 insertions, 56 deletions
diff --git a/kaddressbook/xxport/sharpdtm/sharpdtmE.pro b/kaddressbook/xxport/sharpdtm/sharpdtmE.pro
index 6e83853..0425c42 100644
--- a/kaddressbook/xxport/sharpdtm/sharpdtmE.pro
+++ b/kaddressbook/xxport/sharpdtm/sharpdtmE.pro
@@ -1,27 +1,27 @@
TEMPLATE = lib
CONFIG += qt warn_on
TARGET = microkaddrbk_sharpdtm_xxport
OBJECTS_DIR = obj/$(PLATFORM)
MOC_DIR = moc/$(PLATFORM)
DESTDIR = $(QPEDIR)/lib
DEFINES += KAB_EMBEDDED
-INCLUDEPATH += ../.. ../../../external/sharpdtm/include ../../.. ../../../kabc ../../../kabc/converter/qtopia ../../../microkde ../../../microkde/kdeui ../../../microkde/kdecore ../../../microkde/kio/kfile ../../../qtcompat $(QPEDIR)/include
+INCLUDEPATH += ../.. ../../../external/sharpdtm/include ../../.. ../../../kabc ../../../kabc/converter/sharpdtm ../../../microkde ../../../microkde/kdeui ../../../microkde/kdecore ../../../microkde/kio/kfile ../../../qtcompat $(QPEDIR)/include
LIBS += -L$(QPEDIR)/lib
LIBS += -lmicrokde
LIBS += -lmicrokabc
LIBS += -lqpe
LIBS += -lqte
LIBS += -lzdtm
LIBS += -lmicrokabc_sharpdtmconverter
INTERFACES = \
HEADERS = \
sharpdtm_xxport.h \
SOURCES = \
sharpdtm_xxport.cpp \
diff --git a/kaddressbook/xxport/sharpdtm/sharpdtm_xxport.cpp b/kaddressbook/xxport/sharpdtm/sharpdtm_xxport.cpp
index 4e6a504..8593814 100644
--- a/kaddressbook/xxport/sharpdtm/sharpdtm_xxport.cpp
+++ b/kaddressbook/xxport/sharpdtm/sharpdtm_xxport.cpp
@@ -1,206 +1,199 @@
/*
This file is part of KAddressbook.
Copyright (c) 2003 Tobias Koenig <tokoe@kde.org>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
As a special exception, permission is given to link this program
with any edition of Qt, and distribute the resulting executable,
without including the source code for Qt in the source distribution.
*/
/*
Enhanced Version of the file for platform independent KDE tools.
Copyright (c) 2004 Ulf Schenk
$Id$
*/
#include <qdir.h>
#include <kfiledialog.h>
#include <kmessagebox.h>
#include <sl/slzdb.h>
#include "stdaddressbook.h"
/*US
#include <qfile.h>
#include <qtextstream.h>
#include <kabc/vcardconverter.h>
#ifndef KAB_EMBEDDED
#include <kio/netaccess.h>
#endif //KAB_EMBEDDED
#include <klocale.h>
#include <kmessagebox.h>
#include <ktempfile.h>
#include <kurl.h>
*/
#include "xxportmanager.h"
-//#include "qtopiaconverter.h"
+#include "sharpdtmconverter.h"
#include "sharpdtm_xxport.h"
class SharpDTMXXPortFactory : public XXPortFactory
{
public:
XXPortObject *xxportObject( KABC::AddressBook *ab, QWidget *parent, const char *name )
{
return new SharpDTMXXPort( ab, parent, name );
}
};
extern "C"
{
void *init_microkaddrbk_sharpdtm_xxport()
{
return ( new SharpDTMXXPortFactory() );
}
}
SharpDTMXXPort::SharpDTMXXPort( KABC::AddressBook *ab, QWidget *parent, const char *name )
: XXPortObject( ab, parent, name )
{
createImportAction( i18n( "Import Sharp..." ) );
createExportAction( i18n( "Export Sharp..." ) );
}
bool SharpDTMXXPort::exportContacts( const KABC::AddresseeList &list, const QString &data )
{
// we can not choose the filename. Therefore use the default to display
QString fileName = SlZDataBase::addressbookFileName();
SlZDataBase* access = new SlZDataBase(fileName,
- SlZDataBase::addressbookItems());
-
+ SlZDataBase::addressbookItems());
+
if ( !access ) {
QString text( i18n( "Unable to access file '%1'." ).arg( fileName ) );
qDebug(text.latin1());
KMessageBox::error( parentWidget(), text );
addressBook()->error( text );
return false;
}
-// KABC::QtopiaConverter mConverter;
-
-// bool res = mConverter.init();
- bool res = true;
+ KABC::SharpDTMConverter mConverter;
+
+ bool res = mConverter.init();
if (!res)
{
QString text( i18n( "Unable to initialize sharpdtm converter.<br>Most likely a problem with the category file." ) );
qDebug(text);
KMessageBox::error( parentWidget(), text );
delete access;
- return false;
+ return false;
}
-
+
//Now check if the file has already entries, and ask the user if he wants to delete them first.
-/*US
- { //create a new scope
- AddressBookIterator it(*access);
- const PimContact* firstcontact = it.toFirst();
- if (firstcontact)
- {
- QString text( i18n( "Do you want to remove<br>all existing entries from<br>%1<br>before exporting.?" ) );
- if ( KMessageBox::questionYesNo( parentWidget(), text.arg( fileName ) ) == KMessageBox::Yes ) {
- // Clean the database..
-
- AddressBookIterator it2(*access);
- for (it2.toFirst(); it2.current(); ++it2) {
- access->removeContact(*it2.current());
- }
- }
+ if (access->count() > 0)
+ {
+ QString text( i18n( "Do you want to remove<br>all existing entries from<br>%1<br>before exporting.?" ) );
+ if ( KMessageBox::questionYesNo( parentWidget(), text.arg( fileName ) ) == KMessageBox::Yes ) {
+ // Clean the database..
+ access->deleteCard(0, SlZDataBase::AllCard );
}
}
-
+
KABC::Addressee::List::ConstIterator it;
for ( it = list.begin(); it != list.end(); ++it ) {
- PimContact c;
- KABC::Addressee addressee = (*it);
-
- res = mConverter.addresseeToQtopia( *it, c );
+ CardId c;
+ res = access->editNewCard();
+
if (res == true)
{
- access->addContact(c);
- }
+ res = mConverter.addresseeToSharp( *it, access, c );
+
+ if (res == true)
+ access->finishEditCard(&c);
+ else
+ access->cancelEditCard();
+ }
}
-*/
+
delete access;
-
+
return true;
}
KABC::AddresseeList SharpDTMXXPort::importContacts( const QString& ) const
{
KABC::AddresseeList adrlst;
-
+
QString fileName = SlZDataBase::addressbookFileName();
-
+
+ // the last parameter in the SlZDataBase constructor means "readonly"
SlZDataBase* access = new SlZDataBase(fileName,
- SlZDataBase::addressbookItems());
+ SlZDataBase::addressbookItems(), NULL, true);
+
-
if ( !access ) {
QString text( i18n( "Unable to access file '%1'." ).arg( fileName ) );
qDebug(text.latin1());
addressBook()->error( text );
KMessageBox::error( parentWidget(), text );
return KABC::AddresseeList();
}
-/*US
- KABC::QtopiaConverter mConverter;
+
+ KABC::SharpDTMConverter mConverter;
bool res = mConverter.init();
if (!res)
{
QString text( i18n( "Unable to initialize sharp converter.<br>Most likely a problem with the category file." ) );
qDebug(text);
KMessageBox::error( parentWidget(), text );
delete access;
return KABC::AddresseeList();
}
-
-
-
- { //create a new scope
- AddressBookIterator it(*access);
-
- for (it.toFirst(); it.current(); ++it) {
- const PimContact*contact = it.current();
-
+
+
+ { //create a new scope
+ CardId id;
+
+ for (bool res=access->first(); res == true; res=access->next()) {
+ id = access->cardId();
+
KABC::Addressee addressee;
-
- res = mConverter.qtopiaToAddressee( (*contact), addressee );
-
+
+ res = mConverter.sharpToAddressee( id, access, addressee );
+
if ( !addressee.isEmpty() && res )
{
adrlst.append( addressee );
}
}
}
-*/
-
+
delete access;
-
+
return adrlst;
-
+
}