File: SvgPlasmaInterface.h

package info (click to toggle)
qtop 2.3.4-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster
  • size: 3,980 kB
  • sloc: cpp: 40,477; makefile: 7
file content (157 lines) | stat: -rw-r--r-- 3,515 bytes parent folder | download | duplicates (2)
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
#ifndef SvgPlasmaInterface_h
#define SvgPlasmaInterface_h

/******************************************************************************
*
* Copyright (C) 2002 Hugo PEREIRA <mailto: hugo.pereira@free.fr>
*
* This 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 software 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, see <http://www.gnu.org/licenses/>.
*
*******************************************************************************/

#include "File.h"

#include <QBasicTimer>
#include <QFileSystemWatcher>
#include <QObject>
#include <QPalette>
#include <QString>
#include <QTimerEvent>

namespace Svg
{

  //* kde specific interface to plasma to load matching Svg background
  class SvgPlasmaInterface: public QObject
  {

    Q_OBJECT

    public:

    //* constructor
    explicit SvgPlasmaInterface( QObject* = nullptr );

    //*@name accessors
    //@{

    //* image path
    enum ImagePath
    {
        DialogBackground,
        WidgetBackground,
        WidgetTranslucentBackground
    };

    //* validity
    bool isValid() const
    { return valid_; }

    //* filename
    QString fileName() const
    { return filename_; }

    //* theme palette
    bool hasThemePalette() const
    { return !themePaletteFilename_.isEmpty() && themePaletteFilename_.exists(); }

    //* theme palette
    QPalette themePalette() const;

    //@}}

    //*@name modifiers
    //@{

    //* image path
    bool setImagePath( ImagePath );

    //* get default theme from configuration file
    /** returns true if changed */
    bool loadTheme();

    //* load svg filename
    /** returns true if changed */
    bool loadFile();

    //@}

    Q_SIGNALS:

    //* emitted when svg file changed
    void themeChanged();

    protected Q_SLOTS:

    //* configuration file modified
    void _configurationFileChanged( const QString& );

    protected:

    //* timer event
    void timerEvent( QTimerEvent* ) override;

    private:

    //* validity
    bool _setValid( bool value )
    {
      if( valid_ == value ) return false;
      valid_ = value;
      return true;
    }

    //* set theme
    bool _setTheme( const QString& );

    //* set path matching theme
    bool _setPath( const File& );

    //* set filename
    /** returns true when changed */
    bool _setFileName( const File& );

    //* return image path matching id
    File _imagePath( ImagePath ) const;

    //* return image path matching id
    File _findImage( const File&, ImagePath ) const;

    //* validity
    bool valid_ = false;

    //* type of svg to be loaded
    ImagePath imagePath_ = WidgetBackground;

    //* path to file name
    /** loaded from plasma configuration */
    File path_;

    //* theme color file name
    File themePaletteFilename_;

    //* filename
    File filename_;

    //* file system watcher
    /** needed to track modifications of kde configuration file */
    QFileSystemWatcher* fileSystemWatcher_ = nullptr;

    //* timer needed to prevent repeated calls to file change
    QBasicTimer timer_;

  };
};

#endif