You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
246 lines
8.8 KiB
246 lines
8.8 KiB
/* |
|
* Copyright 2013 Marco Martin <mart@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) 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, write to the Free Software |
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 2.010-1301, USA. |
|
*/ |
|
|
|
import QtQuick 2.0 |
|
import QtQuick.Controls 1.0 as QtControls |
|
import QtQuick.Layouts 1.0 |
|
import org.kde.plasma.configuration 2.0 |
|
|
|
|
|
//TODO: all of this will be done with desktop components |
|
Rectangle { |
|
id: root |
|
|
|
property int _m: theme.defaultFont.pointSize |
|
|
|
//BEGIN properties |
|
color: syspal.window |
|
width: 640 |
|
height: 480 |
|
//END properties |
|
|
|
//BEGIN model |
|
property ConfigModel globalConfigModel: globalAppletConfigModel |
|
|
|
ConfigModel { |
|
id: globalAppletConfigModel |
|
ConfigCategory { |
|
name: "Keyboard shortcuts" |
|
icon: "preferences-desktop-keyboard" |
|
source: "ConfigurationShortcuts.qml" |
|
} |
|
} |
|
//END model |
|
|
|
//BEGIN functions |
|
function saveConfig() { |
|
for (var key in plasmoid.configuration) { |
|
if (main.currentItem["cfg_"+key] !== undefined) { |
|
plasmoid.configuration[key] = main.currentItem["cfg_"+key] |
|
} |
|
} |
|
} |
|
|
|
function restoreConfig() { |
|
for (var key in plasmoid.configuration) { |
|
if (main.currentItem["cfg_"+key] !== undefined) { |
|
main.currentItem["cfg_"+key] = plasmoid.configuration[key] |
|
} |
|
} |
|
} |
|
//END functions |
|
|
|
|
|
//BEGIN connections |
|
Component.onCompleted: { |
|
if (configDialog.configModel && configDialog.configModel.count > 0) { |
|
main.sourceFile = configDialog.configModel.get(0).source |
|
} else { |
|
main.sourceFile = globalConfigModel.get(0).source |
|
} |
|
root.restoreConfig() |
|
// root.width = mainColumn.implicitWidth |
|
// root.height = mainColumn.implicitHeight |
|
} |
|
//END connections |
|
|
|
//BEGIN UI components |
|
SystemPalette {id: syspal} |
|
|
|
ColumnLayout { |
|
id: mainColumn |
|
anchors.fill: parent |
|
property int implicitWidth: Math.max(contentRow.implicitWidth, buttonsRow.implicitWidth) + 8 |
|
property int implicitHeight: contentRow.implicitHeight + buttonsRow.implicitHeight + 8 |
|
|
|
RowLayout { |
|
id: contentRow |
|
anchors { |
|
left: parent.left |
|
right: parent.right |
|
} |
|
Layout.fillHeight: true |
|
Layout.preferredHeight: parent.height - buttonsRow.height |
|
|
|
QtControls.ScrollView { |
|
id: categoriesScroll |
|
frameVisible: true |
|
anchors { |
|
top: parent.top |
|
bottom: parent.bottom |
|
} |
|
visible: (configDialog.configModel ? configDialog.configModel.count : 0) + globalConfigModel.count > 1 |
|
width: visible ? 100 : 0 |
|
implicitWidth: width |
|
Flickable { |
|
id: categoriesView |
|
contentWidth: width |
|
contentHeight: childrenRect.height |
|
anchors.fill: parent |
|
|
|
property Item currentItem: categoriesColumn.children[1] |
|
|
|
Item { |
|
id: categories |
|
width: parent.width |
|
height: categoriesColumn.height |
|
|
|
Item { |
|
width: parent.width |
|
height: categoriesView.currentItem.height |
|
y: categoriesView.currentItem.y |
|
Rectangle { |
|
color: syspal.highlight |
|
radius: 3 |
|
anchors { |
|
fill: parent |
|
margins: 2 |
|
} |
|
} |
|
Behavior on y { |
|
NumberAnimation { |
|
duration: 250 |
|
easing.type: "InOutQuad" |
|
} |
|
} |
|
} |
|
Column { |
|
id: categoriesColumn |
|
width: parent.width |
|
Repeater { |
|
model: configDialog.configModel |
|
delegate: ConfigCategoryDelegate { |
|
onClicked: categoriesView.currentIndex = index |
|
|
|
} |
|
} |
|
Repeater { |
|
model: globalConfigModel |
|
delegate: ConfigCategoryDelegate {} |
|
} |
|
} |
|
} |
|
} |
|
} |
|
QtControls.ScrollView { |
|
id: pageScroll |
|
anchors { |
|
top: parent.top |
|
bottom: parent.bottom |
|
} |
|
Layout.fillWidth: true |
|
Flickable { |
|
contentWidth: width |
|
contentHeight: main.height |
|
Item { |
|
width: parent.width |
|
height: childrenRect.height |
|
QtControls.StackView { |
|
id: main |
|
anchors { |
|
left: parent.left |
|
right: parent.right |
|
} |
|
height: Math.max(pageScroll.height, currentItem.implicitHeight) |
|
property string sourceFile |
|
Timer { |
|
id: pageSizeSync |
|
interval: 100 |
|
onTriggered: { |
|
// root.width = mainColumn.implicitWidth |
|
// root.height = mainColumn.implicitHeight |
|
} |
|
} |
|
onImplicitWidthChanged: pageSizeSync.restart() |
|
onImplicitHeightChanged: pageSizeSync.restart() |
|
onSourceFileChanged: { |
|
print("Source file changed in flickable" + sourceFile); |
|
replace(Qt.resolvedUrl(sourceFile)) |
|
/* |
|
* This is not needed on a desktop shell that has ok/apply/cancel buttons, i'll leave it here only for future reference until we have a prototype for the active shell. |
|
* root.pageChanged will start a timer, that in turn will call saveConfig() when triggered |
|
|
|
for (var prop in currentPage) { |
|
if (prop.indexOf("cfg_") === 0) { |
|
currentPage[prop+"Changed"].connect(root.pageChanged) |
|
} |
|
}*/ |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} |
|
RowLayout { |
|
id: buttonsRow |
|
anchors { |
|
right: parent.right |
|
rightMargin: spacing |
|
} |
|
QtControls.Button { |
|
iconName: "dialog-ok" |
|
text: "Ok" |
|
onClicked: { |
|
if (main.currentItem.saveConfig !== undefined) { |
|
main.currentItem.saveConfig() |
|
} else { |
|
root.saveConfig() |
|
} |
|
configDialog.close() |
|
} |
|
} |
|
QtControls.Button { |
|
iconName: "dialog-ok-apply" |
|
text: "Apply" |
|
onClicked: { |
|
if (main.currentItem.saveConfig !== undefined) { |
|
main.currentItem.saveConfig() |
|
} else { |
|
root.saveConfig() |
|
} |
|
} |
|
} |
|
QtControls.Button { |
|
iconName: "dialog-cancel" |
|
text: "Cancel" |
|
onClicked: configDialog.close() |
|
} |
|
} |
|
} |
|
//END UI components |
|
}
|
|
|