[kcmkwin] Move effects model into a shared library
Summary:
The main motivation for moving it into a shared library is to share the
model between Desktop Effects and Virtual Desktops KCM.
The extracted model is quite the same as the one in Desktop Effects KCM,
except some minor changes, e.g. rename loadEffect and syncConfig to more
convenient names, add comments, some whitespace changes, fix coding
style in some parts, etc.
Test Plan: effectModelTest passes, Desktop Effects KCM works.
Reviewers: #kwin, davidedmundson
Reviewed By: #kwin, davidedmundson
Subscribers: hein, kwin
Tags: #kwin
Differential Revision: https://phabricator.kde.org/D17765
2018-12-22 10:50:28 +00:00
|
|
|
/********************************************************************
|
|
|
|
KWin - the KDE window manager
|
|
|
|
This file is part of the KDE project.
|
|
|
|
|
|
|
|
Copyright (C) 2013 Antonis Tsiapaliokas <kok3rs@gmail.com>
|
|
|
|
Copyright (C) 2018 Vlad Zagorodniy <vladzzag@gmail.com>
|
|
|
|
|
|
|
|
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, see <http://www.gnu.org/licenses/>.
|
|
|
|
*********************************************************************/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <kwin_export.h>
|
|
|
|
|
|
|
|
#include <KPluginInfo>
|
|
|
|
#include <KSharedConfig>
|
|
|
|
|
|
|
|
#include <QAbstractItemModel>
|
|
|
|
#include <QString>
|
|
|
|
#include <QUrl>
|
2019-02-03 15:18:42 +00:00
|
|
|
#include <QWindow>
|
[kcmkwin] Move effects model into a shared library
Summary:
The main motivation for moving it into a shared library is to share the
model between Desktop Effects and Virtual Desktops KCM.
The extracted model is quite the same as the one in Desktop Effects KCM,
except some minor changes, e.g. rename loadEffect and syncConfig to more
convenient names, add comments, some whitespace changes, fix coding
style in some parts, etc.
Test Plan: effectModelTest passes, Desktop Effects KCM works.
Reviewers: #kwin, davidedmundson
Reviewed By: #kwin, davidedmundson
Subscribers: hein, kwin
Tags: #kwin
Differential Revision: https://phabricator.kde.org/D17765
2018-12-22 10:50:28 +00:00
|
|
|
|
|
|
|
namespace KWin
|
|
|
|
{
|
|
|
|
|
|
|
|
class KWIN_EXPORT EffectModel : public QAbstractItemModel
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* This enum type is used to specify data roles.
|
|
|
|
**/
|
|
|
|
enum AdditionalRoles {
|
|
|
|
/**
|
|
|
|
* The user-friendly name of the effect.
|
|
|
|
**/
|
|
|
|
NameRole = Qt::UserRole + 1,
|
|
|
|
/**
|
|
|
|
* The description of the effect.
|
|
|
|
**/
|
|
|
|
DescriptionRole,
|
|
|
|
/**
|
|
|
|
* The name of the effect's author. If there are several authors, they
|
|
|
|
* will be comma separated.
|
|
|
|
**/
|
|
|
|
AuthorNameRole,
|
|
|
|
/**
|
|
|
|
* The email of the effect's author. If there are several authors, the
|
|
|
|
* emails will be comma separated.
|
|
|
|
**/
|
|
|
|
AuthorEmailRole,
|
|
|
|
/**
|
|
|
|
* The license of the effect.
|
|
|
|
**/
|
|
|
|
LicenseRole,
|
|
|
|
/**
|
|
|
|
* The version of the effect.
|
|
|
|
**/
|
|
|
|
VersionRole,
|
|
|
|
/**
|
|
|
|
* The category of the effect.
|
|
|
|
**/
|
|
|
|
CategoryRole,
|
|
|
|
/**
|
|
|
|
* The service name(plugin name) of the effect.
|
|
|
|
**/
|
|
|
|
ServiceNameRole,
|
|
|
|
/**
|
|
|
|
* The icon name of the effect.
|
|
|
|
**/
|
|
|
|
IconNameRole,
|
|
|
|
/**
|
|
|
|
* Whether the effect is enabled or disabled.
|
|
|
|
**/
|
2019-02-03 17:19:16 +00:00
|
|
|
StatusRole,
|
[kcmkwin] Move effects model into a shared library
Summary:
The main motivation for moving it into a shared library is to share the
model between Desktop Effects and Virtual Desktops KCM.
The extracted model is quite the same as the one in Desktop Effects KCM,
except some minor changes, e.g. rename loadEffect and syncConfig to more
convenient names, add comments, some whitespace changes, fix coding
style in some parts, etc.
Test Plan: effectModelTest passes, Desktop Effects KCM works.
Reviewers: #kwin, davidedmundson
Reviewed By: #kwin, davidedmundson
Subscribers: hein, kwin
Tags: #kwin
Differential Revision: https://phabricator.kde.org/D17765
2018-12-22 10:50:28 +00:00
|
|
|
/**
|
|
|
|
* Link to a video demonstration of the effect.
|
|
|
|
**/
|
|
|
|
VideoRole,
|
|
|
|
/**
|
|
|
|
* Link to the home page of the effect.
|
|
|
|
**/
|
|
|
|
WebsiteRole,
|
|
|
|
/**
|
|
|
|
* Whether the effect is supported.
|
|
|
|
**/
|
|
|
|
SupportedRole,
|
|
|
|
/**
|
|
|
|
* The exclusive group of the effect.
|
|
|
|
**/
|
|
|
|
ExclusiveRole,
|
|
|
|
/**
|
|
|
|
* Whether the effect is internal.
|
|
|
|
**/
|
|
|
|
InternalRole,
|
|
|
|
/**
|
|
|
|
* Whether the effect has a KCM.
|
|
|
|
**/
|
|
|
|
ConfigurableRole,
|
|
|
|
/**
|
|
|
|
* Whether this is a scripted effect.
|
|
|
|
**/
|
|
|
|
ScriptedRole,
|
|
|
|
/**
|
|
|
|
* Whether the effect is enabled by default.
|
|
|
|
**/
|
|
|
|
EnabledByDefaultRole
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This enum type is used to specify the status of a given effect.
|
|
|
|
**/
|
|
|
|
enum class Status {
|
|
|
|
/**
|
|
|
|
* The effect is disabled.
|
|
|
|
**/
|
|
|
|
Disabled = Qt::Unchecked,
|
|
|
|
/**
|
|
|
|
* An enable function is used to determine whether the effect is enabled.
|
|
|
|
* For example, such function can be useful to disable the blur effect
|
|
|
|
* when running in a virtual machine.
|
|
|
|
**/
|
|
|
|
EnabledUndeterminded = Qt::PartiallyChecked,
|
|
|
|
/**
|
|
|
|
* The effect is enabled.
|
|
|
|
**/
|
|
|
|
Enabled = Qt::Checked
|
|
|
|
};
|
|
|
|
|
|
|
|
explicit EffectModel(QObject *parent = nullptr);
|
|
|
|
|
|
|
|
// Reimplemented from QAbstractItemModel.
|
|
|
|
QHash<int, QByteArray> roleNames() const override;
|
|
|
|
QModelIndex index(int row, int column, const QModelIndex &parent = {}) const override;
|
|
|
|
QModelIndex parent(const QModelIndex &child) const override;
|
|
|
|
int rowCount(const QModelIndex &parent = {}) const override;
|
|
|
|
int columnCount(const QModelIndex &parent = {}) const override;
|
|
|
|
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
|
|
|
|
bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole) override;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Changes the status of a given effect.
|
|
|
|
*
|
|
|
|
* @param rowIndex An effect represented by the given index.
|
|
|
|
* @param effectState The new state.
|
|
|
|
* @note In order to actually apply the change, you have to call save().
|
|
|
|
**/
|
|
|
|
void updateEffectStatus(const QModelIndex &rowIndex, Status effectState);
|
|
|
|
|
2019-02-03 16:06:05 +00:00
|
|
|
/**
|
|
|
|
* This enum type is used to specify load options.
|
|
|
|
**/
|
|
|
|
enum class LoadOptions {
|
|
|
|
None,
|
|
|
|
/**
|
|
|
|
* Do not discard unsaved changes when reloading the model.
|
|
|
|
**/
|
|
|
|
KeepDirty
|
|
|
|
};
|
|
|
|
|
[kcmkwin] Move effects model into a shared library
Summary:
The main motivation for moving it into a shared library is to share the
model between Desktop Effects and Virtual Desktops KCM.
The extracted model is quite the same as the one in Desktop Effects KCM,
except some minor changes, e.g. rename loadEffect and syncConfig to more
convenient names, add comments, some whitespace changes, fix coding
style in some parts, etc.
Test Plan: effectModelTest passes, Desktop Effects KCM works.
Reviewers: #kwin, davidedmundson
Reviewed By: #kwin, davidedmundson
Subscribers: hein, kwin
Tags: #kwin
Differential Revision: https://phabricator.kde.org/D17765
2018-12-22 10:50:28 +00:00
|
|
|
/**
|
|
|
|
* Loads effects.
|
|
|
|
*
|
|
|
|
* You have to call this method in order to populate the model.
|
|
|
|
**/
|
2019-02-03 16:06:05 +00:00
|
|
|
void load(LoadOptions options = LoadOptions::None);
|
[kcmkwin] Move effects model into a shared library
Summary:
The main motivation for moving it into a shared library is to share the
model between Desktop Effects and Virtual Desktops KCM.
The extracted model is quite the same as the one in Desktop Effects KCM,
except some minor changes, e.g. rename loadEffect and syncConfig to more
convenient names, add comments, some whitespace changes, fix coding
style in some parts, etc.
Test Plan: effectModelTest passes, Desktop Effects KCM works.
Reviewers: #kwin, davidedmundson
Reviewed By: #kwin, davidedmundson
Subscribers: hein, kwin
Tags: #kwin
Differential Revision: https://phabricator.kde.org/D17765
2018-12-22 10:50:28 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves status of each modified effect.
|
|
|
|
**/
|
|
|
|
void save();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Resets the status of each effect to the default state.
|
|
|
|
*
|
|
|
|
* @note In order to actually apply the change, you have to call save().
|
|
|
|
**/
|
|
|
|
void defaults();
|
|
|
|
|
2019-02-02 20:49:38 +00:00
|
|
|
/**
|
|
|
|
* Whether the model has unsaved changes.
|
|
|
|
**/
|
|
|
|
bool needsSave() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Finds an effect with the given plugin id.
|
|
|
|
**/
|
|
|
|
QModelIndex findByPluginId(const QString &pluginId) const;
|
|
|
|
|
2019-02-03 15:18:42 +00:00
|
|
|
/**
|
|
|
|
* Shows a configuration dialog for a given effect.
|
|
|
|
*
|
|
|
|
* @param index An effect represented by the given index.
|
|
|
|
* @param transientParent The transient parent of the configuration dialog.
|
|
|
|
**/
|
|
|
|
void requestConfigure(const QModelIndex &index, QWindow *transientParent);
|
|
|
|
|
[kcmkwin] Move effects model into a shared library
Summary:
The main motivation for moving it into a shared library is to share the
model between Desktop Effects and Virtual Desktops KCM.
The extracted model is quite the same as the one in Desktop Effects KCM,
except some minor changes, e.g. rename loadEffect and syncConfig to more
convenient names, add comments, some whitespace changes, fix coding
style in some parts, etc.
Test Plan: effectModelTest passes, Desktop Effects KCM works.
Reviewers: #kwin, davidedmundson
Reviewed By: #kwin, davidedmundson
Subscribers: hein, kwin
Tags: #kwin
Differential Revision: https://phabricator.kde.org/D17765
2018-12-22 10:50:28 +00:00
|
|
|
protected:
|
|
|
|
enum class Kind {
|
|
|
|
BuiltIn,
|
|
|
|
Binary,
|
|
|
|
Scripted
|
|
|
|
};
|
|
|
|
|
|
|
|
struct EffectData {
|
|
|
|
QString name;
|
|
|
|
QString description;
|
|
|
|
QString authorName;
|
|
|
|
QString authorEmail;
|
|
|
|
QString license;
|
|
|
|
QString version;
|
|
|
|
QString untranslatedCategory;
|
|
|
|
QString category;
|
|
|
|
QString serviceName;
|
|
|
|
QString iconName;
|
2019-02-03 17:19:16 +00:00
|
|
|
Status status;
|
2019-02-02 20:49:38 +00:00
|
|
|
Status originalStatus;
|
[kcmkwin] Move effects model into a shared library
Summary:
The main motivation for moving it into a shared library is to share the
model between Desktop Effects and Virtual Desktops KCM.
The extracted model is quite the same as the one in Desktop Effects KCM,
except some minor changes, e.g. rename loadEffect and syncConfig to more
convenient names, add comments, some whitespace changes, fix coding
style in some parts, etc.
Test Plan: effectModelTest passes, Desktop Effects KCM works.
Reviewers: #kwin, davidedmundson
Reviewed By: #kwin, davidedmundson
Subscribers: hein, kwin
Tags: #kwin
Differential Revision: https://phabricator.kde.org/D17765
2018-12-22 10:50:28 +00:00
|
|
|
bool enabledByDefault;
|
|
|
|
bool enabledByDefaultFunction;
|
|
|
|
QUrl video;
|
|
|
|
QUrl website;
|
|
|
|
bool supported;
|
|
|
|
QString exclusiveGroup;
|
|
|
|
bool internal;
|
|
|
|
bool configurable;
|
|
|
|
Kind kind;
|
|
|
|
bool changed = false;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns whether the given effect should be stored in the model.
|
|
|
|
*
|
|
|
|
* @param data The effect.
|
|
|
|
* @returns @c true if the effect should be stored, otherwise @c false.
|
|
|
|
**/
|
|
|
|
virtual bool shouldStore(const EffectData &data) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
void loadBuiltInEffects(const KConfigGroup &kwinConfig, const KPluginInfo::List &configs);
|
|
|
|
void loadJavascriptEffects(const KConfigGroup &kwinConfig);
|
|
|
|
void loadPluginEffects(const KConfigGroup &kwinConfig, const KPluginInfo::List &configs);
|
|
|
|
|
|
|
|
QVector<EffectData> m_effectsList;
|
|
|
|
|
|
|
|
Q_DISABLE_COPY(EffectModel)
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|