kaddressbook_plugin.h
1/*
2 This file is part of Kontact.
3
4 Copyright (c) 2001 Matthias Hoelzer-Kluepfel <mhk@kde.org>
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19
20 As a special exception, permission is given to link this program
21 with any edition of TQt, and distribute the resulting executable,
22 without including the source code for TQt in the source distribution.
23*/
24
25#ifndef KADDRESSBOOK_PLUGIN_H
26#define KADDRESSBOOK_PLUGIN_H
27
28#include <tdelocale.h>
29#include <tdeparts/part.h>
30
31#include "kaddressbookiface_stub.h"
32#include "plugin.h"
33#include <uniqueapphandler.h>
34
35class TDEAboutData;
36
37class KABUniqueAppHandler : public Kontact::UniqueAppHandler
38{
39public:
40 KABUniqueAppHandler( Kontact::Plugin* plugin ) : Kontact::UniqueAppHandler( plugin ) {}
41 virtual void loadCommandLineOptions();
42 virtual int newInstance();
43};
44
45class KAddressbookPlugin : public Kontact::Plugin
46{
47 TQ_OBJECT
48
49 public:
50 KAddressbookPlugin( Kontact::Core *core, const char *name, const TQStringList& );
51 virtual ~KAddressbookPlugin();
52
53 virtual bool createDCOPInterface( const TQString &serviceType );
54 virtual bool isRunningStandalone();
55 int weight() const { return 300; }
56
57 bool canDecodeDrag( TQMimeSource * );
58 void processDropEvent( TQDropEvent * );
59
60 virtual TQStringList configModules() const;
61
62 virtual TQStringList invisibleToolbarActions() const;
63
64 virtual void configUpdated();
65
66 KAddressBookIface_stub *interface();
67
68 //override
69 void loadProfile( const TQString& directory );
70
71 //override
72 void saveToProfile( const TQString& directory ) const;
73
74 protected:
75 KParts::ReadOnlyPart *createPart();
76 private slots:
77 void slotNewContact();
78 void slotNewDistributionList();
79 void slotSyncContacts();
80
81 private:
82 KAddressBookIface_stub *mStub;
83 Kontact::UniqueAppWatcher *mUniqueAppWatcher;
84};
85
86#endif
This class provides the interface to the Kontact core for the plugins.
Definition: core.h:42
Base class for all Plugins in Kontact.
Definition: plugin.h:59
virtual TQStringList invisibleToolbarActions() const
Returns a list of action name which shall be hidden in the main toolbar.
Definition: plugin.h:233
virtual bool isRunningStandalone()
Reimplement this method and return whether a standalone application is still running This is only req...
Definition: plugin.h:131
virtual bool createDCOPInterface(const TQString &)
Create the DCOP interface for the given serviceType, if this plugin provides it.
Definition: plugin.h:125
virtual bool canDecodeDrag(TQMimeSource *)
Return, if the plugin can handle the drag object of the given mime type.
Definition: plugin.h:238
virtual void processDropEvent(TQDropEvent *)
Process drop event.
Definition: plugin.h:243
virtual int weight() const
Return the weight of the plugin.
Definition: plugin.h:208
virtual KParts::ReadOnlyPart * createPart()=0
Reimplement and return the part here.
virtual void configUpdated()
This function is called whenever the config dialog has been closed successfully.
Definition: plugin.cpp:205
DCOP Object that has the name of the standalone application (e.g.
virtual void loadCommandLineOptions()=0
This must be reimplemented so that app-specific command line options can be parsed.
virtual int newInstance()
We can't use k_dcop and dcopidl here, because the data passed to newInstance can't be expressed in te...
If the standalone application is running by itself, we need to watch for when the user closes it,...