2211a951e7
Summary: A while ago desktop effects and compositing settings lived under the same roof {F6584639} {F6584642} but time has passed and now those two have their own kcms. This causes some issues: * for newcomers it's harder to find code of the Desktop Effects KCM; * git history doesn't look good, e.g. "[kcmkwin/compositing] Add some bugs to Desktop Effects KCM to fix later"; * in general, the mix of two doesn't look good in the code. This change splits out the Desktop Effects KCM. Unfortunately, in order to have more nicer code I had to refactor EffectModel a little bit. Before: {F6584669} After: {F6587570} Reviewers: #kwin, davidedmundson Reviewed By: #kwin, davidedmundson Subscribers: davidedmundson, ltoscano, mart, ngraham, kwin Tags: #kwin Differential Revision: https://phabricator.kde.org/D18703
140 lines
4 KiB
QML
140 lines
4 KiB
QML
/*
|
|
* Copyright (C) 2013 Antonis Tsiapaliokas <kok3rs@gmail.com>
|
|
* Copyright (C) 2019 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/>.
|
|
*
|
|
*/
|
|
|
|
import QtQuick 2.1
|
|
import QtQuick.Controls 2.5 as QtControls
|
|
import QtQuick.Layouts 1.0
|
|
import org.kde.kirigami 2.5 as Kirigami
|
|
|
|
Rectangle {
|
|
height: row.implicitHeight
|
|
|
|
Kirigami.Theme.inherit: false
|
|
Kirigami.Theme.colorSet: Kirigami.Theme.View
|
|
color: index % 2 ? Kirigami.Theme.backgroundColor : palette.alternateBase
|
|
|
|
RowLayout {
|
|
id: row
|
|
|
|
x: spacing
|
|
width: parent.width - 2 * spacing
|
|
|
|
QtControls.RadioButton {
|
|
property bool _exclusive: model.ExclusiveRole != ""
|
|
property bool _toggled: false
|
|
|
|
checked: model.EffectStatusRole
|
|
visible: _exclusive
|
|
QtControls.ButtonGroup.group: _exclusive ? effectsList.findButtonGroup(model.ExclusiveRole) : null
|
|
|
|
onToggled: {
|
|
model.EffectStatusRole = checked ? Qt.Checked : Qt.Unchecked;
|
|
_toggled = true;
|
|
}
|
|
onClicked: {
|
|
// Uncheck the radio button if it's clicked.
|
|
if (checked && !_toggled) {
|
|
model.EffectStatusRole = Qt.Unchecked;
|
|
}
|
|
_toggled = false;
|
|
}
|
|
}
|
|
|
|
QtControls.CheckBox {
|
|
checkState: model.EffectStatusRole
|
|
visible: model.ExclusiveRole == ""
|
|
|
|
onToggled: model.EffectStatusRole = checkState
|
|
}
|
|
|
|
ColumnLayout {
|
|
QtControls.Label {
|
|
Layout.fillWidth: true
|
|
|
|
font.weight: Font.Bold
|
|
text: model.NameRole
|
|
wrapMode: Text.Wrap
|
|
}
|
|
|
|
QtControls.Label {
|
|
Layout.fillWidth: true
|
|
|
|
text: model.DescriptionRole
|
|
wrapMode: Text.Wrap
|
|
}
|
|
|
|
QtControls.Label {
|
|
id: aboutItem
|
|
|
|
Layout.fillWidth: true
|
|
|
|
font.weight: Font.Bold
|
|
text: i18n("Author: %1\nLicense: %2", model.AuthorNameRole, model.LicenseRole)
|
|
visible: false
|
|
wrapMode: Text.Wrap
|
|
}
|
|
|
|
Loader {
|
|
id: videoItem
|
|
|
|
active: false
|
|
source: "Video.qml"
|
|
visible: false
|
|
|
|
function showHide() {
|
|
if (!videoItem.active) {
|
|
videoItem.active = true;
|
|
videoItem.visible = true;
|
|
} else {
|
|
videoItem.active = false;
|
|
videoItem.visible = false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
QtControls.Button {
|
|
icon.name: "video"
|
|
visible: model.VideoRole.toString() !== ""
|
|
|
|
onClicked: videoItem.showHide()
|
|
}
|
|
|
|
QtControls.Button {
|
|
enabled: model.EffectStatusRole != Qt.Unchecked
|
|
icon.name: "configure"
|
|
visible: model.ConfigurableRole
|
|
|
|
onClicked: kcm.configure(model.ServiceNameRole, this)
|
|
}
|
|
|
|
QtControls.Button {
|
|
icon.name: "dialog-information"
|
|
|
|
onClicked: aboutItem.visible = !aboutItem.visible;
|
|
}
|
|
}
|
|
|
|
// Kirigami.Theme doesn't provide alternate color.
|
|
SystemPalette {
|
|
id: palette
|
|
|
|
colorGroup: SystemPalette.Active
|
|
}
|
|
}
|