summaryrefslogtreecommitdiffstats
path: root/libtdepim/resourceabc.h
diff options
context:
space:
mode:
Diffstat (limited to 'libtdepim/resourceabc.h')
-rw-r--r--libtdepim/resourceabc.h116
1 files changed, 116 insertions, 0 deletions
diff --git a/libtdepim/resourceabc.h b/libtdepim/resourceabc.h
new file mode 100644
index 000000000..b6ef3ec98
--- /dev/null
+++ b/libtdepim/resourceabc.h
@@ -0,0 +1,116 @@
+/*
+ This file is part of libtdepim.
+
+ Copyright (c) 2004 Bo Thorsen <bo@sonofthor.dk>
+
+ 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.
+*/
+
+#ifndef RESOURCEABC_H
+#define RESOURCEABC_H
+
+#include <kabc/resource.h>
+#include <tqmap.h>
+#include <tdepimmacros.h>
+
+// This is here because it can't go to kdelibs/kabc yet, but ultimately
+// it should probably go there (maybe redesigned to have a real object
+// for subresources).
+
+namespace KPIM {
+
+/**
+ * This class is the implementation of subfolder resources for KABC.
+ * More methods will be added to give KAddressBook the possibility to
+ * handle subresources.
+ */
+
+class KDE_EXPORT ResourceABC : public KABC::Resource
+{
+ Q_OBJECT
+ TQ_OBJECT
+
+public:
+ ResourceABC( const KConfig* );
+ virtual ~ResourceABC();
+
+ /**
+ * Get the UID to subresource map. This is necessary to implement
+ * the search order.
+ * The returned map has the UID as key and the resource it's in as
+ * the data.
+ */
+ virtual TQMap<TQString, TQString> uidToResourceMap() const = 0;
+
+ /**
+ * If this resource has subresources, return a TQStringList of them.
+ * In most cases, resources do not have subresources, so this is
+ * by default just empty.
+ */
+ virtual TQStringList subresources() const { return TQStringList(); }
+
+ /**
+ * Is this subresource active or not?
+ */
+ virtual bool subresourceActive( const TQString& ) const { return true; }
+
+ /**
+ * Is the given subresource writable?
+ */
+ virtual bool subresourceWritable( const TQString& ) const = 0;
+
+ /**
+ * Completion weight for a given subresource
+ */
+ virtual int subresourceCompletionWeight( const TQString& ) const = 0;
+
+ /**
+ * Label for a given subresource
+ */
+ virtual TQString subresourceLabel( const TQString& ) const = 0;
+
+public slots:
+ /**
+ * (De-)activate a subresource.
+ */
+ virtual void setSubresourceActive( const TQString &, bool active ) = 0;
+
+ /**
+ * Set completion weight for a given subresource
+ */
+ virtual void setSubresourceCompletionWeight( const TQString&, int weight ) = 0;
+
+signals:
+ /**
+ * This signal is emitted when a subresource is added.
+ */
+ void signalSubresourceAdded( KPIM::ResourceABC *, const TQString &type,
+ const TQString &subResource );
+
+ /**
+ * This signal is emitted when a subresource is removed.
+ */
+ void signalSubresourceRemoved( KPIM::ResourceABC *, const TQString &type,
+ const TQString &subResource );
+
+};
+
+}
+
+#endif // RESOURCEABC_H