d5233a6b6f
The decoration button configuration interface is merged into the QML part using two list views (left buttons, right buttons) and a grid view for all the available buttons.
188 lines
7.2 KiB
QML
188 lines
7.2 KiB
QML
/*
|
|
* Copyright 2014 Martin Gräßlin <mgraesslin@kde.org>
|
|
*
|
|
* 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) version 3 or any later version
|
|
* accepted by the membership of KDE e.V. (or its successor approved
|
|
* by the membership of KDE e.V.), which shall act as a proxy
|
|
* defined in Section 14 of version 3 of the license.
|
|
*
|
|
* 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 1.2
|
|
import QtQuick.Layouts 1.1
|
|
import org.kde.kwin.private.kdecoration 1.0 as KDecoration
|
|
import org.kde.kquickcontrolsaddons 2.0 as KQuickControlsAddons;
|
|
|
|
Item {
|
|
Layout.preferredHeight: layout.height
|
|
KDecoration.Bridge {
|
|
id: bridgeItem
|
|
plugin: "org.kde.breeze"
|
|
}
|
|
KDecoration.Settings {
|
|
id: settingsItem
|
|
bridge: bridgeItem
|
|
}
|
|
ColumnLayout {
|
|
id: layout
|
|
width: parent.width
|
|
height: buttonPreviewRow.height + availableGrid.height
|
|
RowLayout {
|
|
id: buttonPreviewRow
|
|
height: 32
|
|
width: parent.width
|
|
ButtonGroup {
|
|
id: leftButtonsView
|
|
height: buttonPreviewRow.height
|
|
model: configurationModule.leftButtons
|
|
key: "decoButtonLeft"
|
|
}
|
|
Item {
|
|
Layout.fillWidth: true
|
|
Label {
|
|
anchors.centerIn: parent
|
|
text: i18n("Drag to re-position buttons")
|
|
}
|
|
}
|
|
ButtonGroup {
|
|
id: rightButtonsView
|
|
height: buttonPreviewRow.height
|
|
model: configurationModule.rightButtons
|
|
key: "decoButtonRight"
|
|
}
|
|
DropArea {
|
|
anchors.fill: parent
|
|
keys: [ "decoButtonAdd", "decoButtonRight", "decoButtonLeft" ]
|
|
onEntered: {
|
|
drag.accept();
|
|
}
|
|
onDropped: {
|
|
var view = undefined;
|
|
var left = drag.x - (leftButtonsView.x + leftButtonsView.width);
|
|
var right = drag.x - rightButtonsView.x;
|
|
if (Math.abs(left) <= Math.abs(right)) {
|
|
view = leftButtonsView;
|
|
} else {
|
|
view = rightButtonsView;
|
|
}
|
|
if (!view) {
|
|
return;
|
|
}
|
|
var point = mapToItem(view, drag.x, drag.y);
|
|
var index = view.indexAt(point.x, point.y);
|
|
if (index == -1 && (view.x + view.width <= drag.x)) {
|
|
index = view.count - 1;
|
|
}
|
|
if (drop.keys.indexOf("decoButtonAdd") != -1) {
|
|
view.model.add(index, drag.source.type);
|
|
} else if (drop.keys.indexOf("decoButtonLeft") != -1) {
|
|
if (view == leftButtonsView) {
|
|
// move in same view
|
|
if (index != drag.source.itemIndex) {
|
|
drag.source.buttonsModel.move(drag.source.itemIndex, index);
|
|
}
|
|
} else {
|
|
// move to right view
|
|
view.model.add(index, drag.source.type);
|
|
drag.source.buttonsModel.remove(drag.source.itemIndex);
|
|
}
|
|
} else if (drop.keys.indexOf("decoButtonRight") != -1) {
|
|
if (view == rightButtonsView) {
|
|
// move in same view
|
|
if (index != drag.source.itemIndex) {
|
|
drag.source.buttonsModel.move(drag.source.itemIndex, index);
|
|
}
|
|
} else {
|
|
// move to right view
|
|
view.model.add(index, drag.source.type);
|
|
drag.source.buttonsModel.remove(drag.source.itemIndex);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
GridView {
|
|
id: availableGrid
|
|
Layout.fillWidth: true
|
|
model: configurationModule.availableButtons
|
|
cellWidth: 96
|
|
cellHeight: 96
|
|
height: cellHeight * 2.5
|
|
opacity: (leftButtonsView.dragging || rightButtonsView.dragging) ? 0.25 : 1.0
|
|
delegate: Item {
|
|
width: availableGrid.cellWidth
|
|
height: availableGrid.cellHeight
|
|
KDecoration.Button {
|
|
anchors.centerIn: Drag.active ? undefined : parent
|
|
id: availableButton
|
|
bridge: bridgeItem
|
|
settings: settingsItem
|
|
type: model["button"]
|
|
width: 32
|
|
height: 32
|
|
Drag.keys: [ "decoButtonAdd" ]
|
|
Drag.active: dragArea.drag.active
|
|
}
|
|
Label {
|
|
text: model["display"]
|
|
horizontalAlignment: Text.AlignHCenter
|
|
anchors.bottom: parent.bottom
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
elide: Text.ElideRight
|
|
wrapMode: Text.Wrap
|
|
}
|
|
MouseArea {
|
|
id: dragArea
|
|
anchors.fill: parent
|
|
drag.target: availableButton
|
|
onReleased: {
|
|
if (availableButton.Drag.target) {
|
|
availableButton.Drag.drop();
|
|
} else {
|
|
availableButton.Drag.cancel();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
DropArea {
|
|
anchors.fill: availableGrid
|
|
keys: [ "decoButtonRemove" ]
|
|
onEntered: {
|
|
drag.accept();
|
|
}
|
|
onDropped: {
|
|
drag.source.buttonsModel.remove(drag.source.itemIndex);
|
|
}
|
|
ColumnLayout {
|
|
anchors.centerIn: parent
|
|
visible: leftButtonsView.dragging || rightButtonsView.dragging
|
|
Label {
|
|
text: i18n("Drop here to remove button")
|
|
font.bold: true
|
|
}
|
|
KQuickControlsAddons.QIconItem {
|
|
id: icon
|
|
width: 64
|
|
height: 64
|
|
icon: "list-remove"
|
|
Layout.alignment: Qt.AlignHCenter
|
|
}
|
|
Item {
|
|
Layout.fillHeight: true
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|