aboutsummaryrefslogtreecommitdiff
path: root/lumina-desktop/desktop-plugins/LDPlugin.h
blob: 0e1f68476d1e70e5658d536683a85d8f3ce8c737 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
//===========================================
//  Lumina-DE source code
//  Copyright (c) 2014, Ken Moore
//  Available under the 3-clause BSD license
//  See the LICENSE file for full details
//===========================================
//  This class is the generic container layout for all desktop plugins
//  Simply subclass this when creating a new plugin to enable correct
//    visibility and usage within the desktop window
//===========================================
//  WARNING: Do *not* setup a custom context menu for plugins!
//     This can prevent access to the general desktop context menu if
//     the plugin was maximized to fill the desktop area!
//===========================================
#ifndef _LUMINA_DESKTOP_DESKTOP_PLUGIN_H
#define _LUMINA_DESKTOP_DESKTOP_PLUGIN_H

#include <QObject>
#include <QFrame>
#include <QWidget>
#include <QString>
#include <QDebug>
#include <QSettings>
#include <QMoveEvent>
#include <QResizeEvent>

class LDPlugin : public QFrame{
	Q_OBJECT
	
private:
	QString PLUGID;
	
public:
	QSettings *settings;

	LDPlugin(QWidget *parent = 0, QString id="unknown", bool opaque = false) : QFrame(parent){
	  PLUGID=id;
	  settings = new QSettings("desktop-plugins",PLUGID);
	  if(opaque){ this->setObjectName("LuminaDesktopPluginVisible"); }
	  else{ this->setObjectName("LuminaDesktopPlugin"); }
	}
	
	~LDPlugin(){
	  delete settings;
	}
	
	QString ID(){
	  return PLUGID;
	}
	
	void setInitialSize(int width, int height){
	    //Note: Only run this in the plugin initization routine:
	    //  if the plugin is completely new (first time used), it will be this size
	    if(settings->allKeys().isEmpty()){
		//Brand new plugin: set initial size
		settings->setValue("location/width",width);
		settings->setValue("location/height",height);
		settings->sync();
	    }
	}
	
public slots:
	virtual void LocaleChange(){
	  //This needs to be re-implemented in the subclassed plugin
	    //This is where all text is set/translated
	}
	virtual void ThemeChange(){
	  //This needs to be re-implemented in the subclassed plugin
	    //This is where all the visuals are set if using Theme-dependant icons.
	}
};

#endif
bgstack15