1
0
Fork 0
mirror of https://git.jami.net/savoirfairelinux/jami-client-qt.git synced 2025-08-24 16:53:51 +02:00
jami-client-qt/src/commoncomponents/Scaffold.qml
Andreas Traczyk b334ed370b misc: bump QML modules versions to x.15
Change-Id: Ia80632cf2e217e8dd6844a6a8c0d0d8c0f6e1baf
2021-08-23 19:14:06 -04:00

87 lines
2.5 KiB
QML

/*
* Copyright (C) 2020 by Savoir-faire Linux
* Author: Andreas Traczyk <andreas.traczyk@savoirfairelinux.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 3 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 <https://www.gnu.org/licenses/>.
*/
import QtQuick 2.15
import QtQuick.Controls 2.15
// UI dev tool to visualize components/layouts
Rectangle {
property alias name: label.text
property bool stretchParent: false
property string tag: this.toString()
signal moveX(real dx)
signal moveY(real dy)
property real ox: 0
property real oy: 0
property real step: 0.5
border.width: 1
color: {
var r = Math.random() * 0.5 + 0.5;
var g = Math.random() * 0.5 + 0.5;
var b = Math.random() * 0.5 + 0.5;
Qt.rgba(r, g, b, 0.5);
}
anchors.fill: parent
focus: false
Keys.onPressed: {
if (event.key === Qt.Key_Left)
moveX(-step)
else if (event.key === Qt.Key_Right)
moveX(step)
else if (event.key === Qt.Key_Down)
moveY(step)
else if (event.key === Qt.Key_Up)
moveY(-step)
console.log(tag, ox, oy)
event.accepted = true;
}
Component.onCompleted: {
// fallback to some description of the object
if (label.text === "")
label.text = this.toString();
// force the parent to be at least the dimensions of children
if (stretchParent) {
parent.width = Math.max(parent.width, parent.childrenRect.width);
parent.height = Math.max(parent.height, parent.childrenRect.height);
}
}
onMoveX: {
parent.anchors.leftMargin += dx
parent.x += dx
ox += dx;
}
onMoveY: {
parent.anchors.topMargin += dy
parent.y += dy
oy += dy
}
Label {
id: label
anchors.centerIn: parent
}
MouseArea {
anchors.fill: parent
onPressed: parent.forceActiveFocus()
}
}