You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
3.6 KiB
115 lines
3.6 KiB
/*
|
|
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
As a special exception, permission is given to link this program
|
|
with any edition of TQt, and distribute the resulting executable,
|
|
without including the source code for TQt in the source distribution.
|
|
*/
|
|
|
|
#include <tdeconfig.h>
|
|
#include <tdelocale.h>
|
|
#include <tdeglobal.h>
|
|
#include <kstandarddirs.h>
|
|
|
|
#include <float.h>
|
|
|
|
#include "geo_xxport.h"
|
|
|
|
class FlagInfo
|
|
{
|
|
public:
|
|
double latitude;
|
|
double longitude;
|
|
TQColor color;
|
|
};
|
|
|
|
K_EXPORT_KADDRESSBOOK_XXFILTER_CATALOG( libkaddrbk_geo_xxport, GeoXXPort, "libkaddrbk_geo_xxport" )
|
|
|
|
GeoXXPort::GeoXXPort( TDEABC::AddressBook *ab, TQWidget *parent, const char *name )
|
|
: KAB::XXPort( ab, parent, name )
|
|
{
|
|
createExportAction( i18n( "Export Geo Data..." ) );
|
|
}
|
|
|
|
bool GeoXXPort::exportContacts( const TDEABC::AddresseeList &list, const TQString& )
|
|
{
|
|
TDEConfig config( "kworldclockrc" );
|
|
|
|
// At first we read all exiting flags and compare it with ours to
|
|
// avoid duplicated flags
|
|
int flags = config.readNumEntry( "Flags", 0 );
|
|
TQValueList<FlagInfo> availableFlags;
|
|
|
|
if ( flags != 0 ) {
|
|
for ( int i = 0; i < flags; ++i ) {
|
|
FlagInfo info;
|
|
info.latitude = config.readDoubleNumEntry( TQString( "Flag_%1_Latitude" ).arg( i ) );
|
|
info.longitude = config.readDoubleNumEntry( TQString( "Flag_%1_Longitude" ).arg( i ) );
|
|
info.color = config.readColorEntry( TQString( "Flag_%1_Color" ).arg( i ) );
|
|
|
|
availableFlags.append( info );
|
|
}
|
|
}
|
|
|
|
|
|
TQValueList<FlagInfo> flagList;
|
|
TDEABC::AddresseeList::ConstIterator addrIt;
|
|
for ( addrIt = list.begin(); addrIt != list.end(); ++addrIt ) {
|
|
TDEABC::Geo geo( (*addrIt).geo() );
|
|
if ( !geo.isValid() )
|
|
continue;
|
|
|
|
bool available = false;
|
|
TQValueList<FlagInfo>::Iterator it;
|
|
for ( it = availableFlags.begin(); it != availableFlags.end(); ++it ) {
|
|
if ( !( KABS( (*it).latitude - geo.latitude() ) > DBL_EPSILON ) &&
|
|
!( KABS( (*it).longitude - geo.longitude() ) > DBL_EPSILON ) ) {
|
|
available = true;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if ( !available ) {
|
|
FlagInfo info;
|
|
info.latitude = geo.latitude();
|
|
info.longitude = geo.longitude();
|
|
info.color = TQColor( 0, 255, 0 );
|
|
|
|
flagList.append( info );
|
|
}
|
|
}
|
|
|
|
if ( flagList.count() == 0 ) // nothing to export
|
|
return true;
|
|
|
|
flagList += availableFlags;
|
|
|
|
int startVal = 0;
|
|
TQValueList<FlagInfo>::Iterator it;
|
|
for ( it = flagList.begin(); it != flagList.end(); ++it, ++startVal ) {
|
|
config.writeEntry( TQString( "Flag_%1_Color" ).arg( startVal ), (*it).color );
|
|
config.writeEntry( TQString( "Flag_%1_Latitude" ).arg( startVal ), (*it).latitude );
|
|
config.writeEntry( TQString( "Flag_%1_Longitude" ).arg( startVal ), (*it).longitude );
|
|
}
|
|
config.writeEntry( "Flags", startVal );
|
|
|
|
return true;
|
|
}
|
|
|
|
#include "geo_xxport.moc"
|