2019-07-08 13:52:41 +10:00
|
|
|
// Copyright 2019 miruka
|
|
|
|
// This file is part of harmonyqml, licensed under LGPLv3.
|
|
|
|
|
2019-04-28 08:00:28 +10:00
|
|
|
import QtQuick 2.7
|
2019-04-29 05:45:42 +10:00
|
|
|
import QtQuick.Layouts 1.3
|
2019-04-28 08:00:28 +10:00
|
|
|
|
|
|
|
HScalingBox {
|
|
|
|
id: interfaceBox
|
|
|
|
|
|
|
|
property alias title: interfaceTitle.text
|
|
|
|
property alias buttonModel: interfaceButtonsRepeater.model
|
|
|
|
property var buttonCallbacks: []
|
|
|
|
property string enterButtonTarget: ""
|
|
|
|
|
|
|
|
default property alias body: interfaceBody.children
|
|
|
|
|
|
|
|
function clickEnterButtonTarget() {
|
|
|
|
for (var i = 0; i < buttonModel.length; i++) {
|
|
|
|
var btn = interfaceButtonsRepeater.itemAt(i)
|
|
|
|
if (btn.name === enterButtonTarget) { btn.clicked() }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-29 02:47:51 +10:00
|
|
|
HColumnLayout {
|
2019-04-28 08:00:28 +10:00
|
|
|
anchors.fill: parent
|
|
|
|
id: mainColumn
|
|
|
|
|
|
|
|
HRowLayout {
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
|
|
|
Layout.margins: interfaceBox.margins
|
|
|
|
|
|
|
|
HLabel {
|
|
|
|
id: interfaceTitle
|
2019-07-07 07:50:55 +10:00
|
|
|
font.pixelSize: theme.fontSize.big
|
2019-04-28 08:00:28 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-29 05:22:53 +10:00
|
|
|
HSpacer {}
|
2019-04-28 11:07:20 +10:00
|
|
|
|
2019-04-29 02:47:51 +10:00
|
|
|
HColumnLayout { id: interfaceBody }
|
2019-04-28 08:00:28 +10:00
|
|
|
|
2019-04-29 05:22:53 +10:00
|
|
|
HSpacer {}
|
2019-04-28 11:07:20 +10:00
|
|
|
|
2019-04-28 08:00:28 +10:00
|
|
|
HRowLayout {
|
|
|
|
Repeater {
|
|
|
|
id: interfaceButtonsRepeater
|
|
|
|
model: []
|
|
|
|
|
|
|
|
HButton {
|
|
|
|
property string name: modelData.name
|
|
|
|
|
|
|
|
id: button
|
|
|
|
text: modelData.text
|
|
|
|
iconName: modelData.iconName || ""
|
|
|
|
onClicked: buttonCallbacks[modelData.name](button)
|
|
|
|
|
|
|
|
Layout.fillWidth: true
|
2019-07-07 07:50:55 +10:00
|
|
|
Layout.preferredHeight: theme.avatar.size
|
2019-04-28 08:00:28 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|