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 
35 class TDEAboutData;
36 
37 class KABUniqueAppHandler : public Kontact::UniqueAppHandler
38 {
39 public:
40  KABUniqueAppHandler( Kontact::Plugin* plugin ) : Kontact::UniqueAppHandler( plugin ) {}
41  virtual void loadCommandLineOptions();
42  virtual int newInstance();
43 };
44 
45 class 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 KParts::ReadOnlyPart * createPart()=0
Reimplement and return the part here.
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 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,...