forked from qt-creator/qt-creator
We combine width and height in the property editor. Change-Id: I5f0dd9c887fd57d492222d521e54f267e12a5048 Reviewed-by: Thomas Hartmann <Thomas.Hartmann@theqtcompany.com>
400 lines
9.3 KiB
QML
400 lines
9.3 KiB
QML
/****************************************************************************
|
|
**
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
** Contact: https://www.qt.io/licensing/
|
|
**
|
|
** This file is part of Qt Creator.
|
|
**
|
|
** Commercial License Usage
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
** accordance with the commercial license agreement provided with the
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
|
**
|
|
** GNU General Public License Usage
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
** General Public License version 3 as published by the Free Software
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
** included in the packaging of this file. Please review the following
|
|
** information to ensure the GNU General Public License requirements will
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
|
**
|
|
****************************************************************************/
|
|
|
|
import QtQuick 2.0
|
|
import HelperWidgets 2.0
|
|
import QtQuick.Layouts 1.0
|
|
import QtQuick.Controls 1.0 as Controls
|
|
|
|
SectionLayout {
|
|
property bool isInModel: backendValue.isInModel;
|
|
property bool isInSubState: backendValue.isInSubState;
|
|
property variant valueFromBackend: backendValue.value
|
|
property variant backendValue: backendValues.Layout_alignment
|
|
property bool blockAlignment: false
|
|
|
|
onIsInModelChanged: evaluateAlignment()
|
|
onIsInSubStateChanged: evaluateAlignment()
|
|
onBackendValueChanged: evaluateAlignment()
|
|
onValueFromBackendChanged: evaluateAlignment()
|
|
|
|
Connections {
|
|
target: modelNodeBackend
|
|
onSelectionChanged: {
|
|
evaluateAlignment()
|
|
}
|
|
}
|
|
|
|
Component.onCompleted: evaluateAlignment()
|
|
|
|
function indexOfVerticalAlignment() {
|
|
if (backendValue.expression === undefined)
|
|
return 0;
|
|
|
|
if (backendValue.expression.indexOf("AlignVCenter") !== -1)
|
|
return 0;
|
|
|
|
if (backendValue.expression.indexOf("AlignTop") !== -1)
|
|
return 1;
|
|
|
|
if (backendValue.expression.indexOf("AlignBottom") !== -1)
|
|
return 2;
|
|
|
|
if (backendValue.expression.indexOf("AlignBaseline") !== -1)
|
|
return 3;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
function indexOfHorizontalAlignment() {
|
|
|
|
if (backendValue.expression === undefined)
|
|
return 0;
|
|
|
|
if (backendValue.expression.indexOf("AlignLeft") !== -1)
|
|
return 0;
|
|
|
|
if (backendValue.expression.indexOf("AlignHCenter") !== -1)
|
|
return 1;
|
|
|
|
if (backendValue.expression.indexOf("AlignRight") !== -1)
|
|
return 2;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
function evaluateAlignment() {
|
|
|
|
blockAlignment = true
|
|
|
|
verticalAlignmentComboBox.currentIndex = indexOfVerticalAlignment();
|
|
horizontalAlignmentComboBox.currentIndex = indexOfHorizontalAlignment();
|
|
|
|
blockAlignment = false
|
|
}
|
|
|
|
function composeExpressionString() {
|
|
if (blockAlignment)
|
|
return;
|
|
|
|
var expressionStr = "";
|
|
if (horizontalAlignmentComboBox.currentIndex !== 0
|
|
|| verticalAlignmentComboBox.currentIndex !== 0) {
|
|
expressionStr = "Qt." + horizontalAlignmentComboBox.currentText
|
|
+ " | "
|
|
+ "Qt." + verticalAlignmentComboBox.currentText
|
|
|
|
backendValue.expression = expressionStr
|
|
} else {
|
|
expressionStr = "Qt.AlignLeft | Qt.AlignVCenter";
|
|
backendValue.expression = expressionStr
|
|
backendValue.resetValue();
|
|
}
|
|
|
|
}
|
|
|
|
|
|
Label {
|
|
text: qsTr("Alignment")
|
|
tooltip: qsTr("Alignment of an item within the cells it occupies.")
|
|
}
|
|
|
|
SecondColumnLayout {
|
|
|
|
Controls.ComboBox {
|
|
ColorLogic {
|
|
id: colorLogic
|
|
}
|
|
|
|
id: horizontalAlignmentComboBox
|
|
|
|
property bool __isCompleted: false
|
|
property color textColor: currentIndex === 0 ? colorLogic.__defaultTextColor : colorLogic.__changedTextColor
|
|
|
|
model: ["AlignLeft", "AlignHCenter", "AlignRight"]
|
|
|
|
onCurrentIndexChanged: {
|
|
if (!horizontalAlignmentComboBox.__isCompleted)
|
|
return;
|
|
|
|
composeExpressionString();
|
|
}
|
|
|
|
style: CustomComboBoxStyle {
|
|
textColor: horizontalAlignmentComboBox.textColor
|
|
}
|
|
|
|
Component.onCompleted: {
|
|
horizontalAlignmentComboBox.__isCompleted = true;
|
|
}
|
|
|
|
}
|
|
|
|
ExpandingSpacer {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Label {
|
|
|
|
}
|
|
|
|
SecondColumnLayout {
|
|
|
|
Controls.ComboBox {
|
|
id: verticalAlignmentComboBox
|
|
|
|
property bool __isCompleted: false
|
|
property color textColor: currentIndex === 0 ? colorLogic.__defaultTextColor : colorLogic.__changedTextColor
|
|
|
|
model: ["AlignVCenter", "AlignTop","AlignBottom","AlignBaseline"]
|
|
|
|
onCurrentIndexChanged: {
|
|
if (!verticalAlignmentComboBox.__isCompleted)
|
|
return;
|
|
|
|
composeExpressionString();
|
|
}
|
|
|
|
style: CustomComboBoxStyle {
|
|
textColor: verticalAlignmentComboBox.textColor
|
|
}
|
|
|
|
Component.onCompleted: {
|
|
verticalAlignmentComboBox.__isCompleted = true;
|
|
}
|
|
|
|
}
|
|
|
|
ExpandingSpacer {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Label {
|
|
text: qsTr("Fill layout")
|
|
tooltip: qsTr("The item will expand as much as possible while respecting the given constraints if true.")
|
|
}
|
|
|
|
SecondColumnLayout {
|
|
CheckBox {
|
|
backendValue: backendValues.Layout_fillWidth
|
|
text: qsTr("Fill width")
|
|
}
|
|
|
|
Item {
|
|
width: 10
|
|
height: 10
|
|
|
|
}
|
|
|
|
CheckBox {
|
|
backendValue: backendValues.Layout_fillHeight
|
|
text: qsTr("Fill height")
|
|
}
|
|
|
|
ExpandingSpacer {
|
|
|
|
}
|
|
}
|
|
|
|
Label {
|
|
text: qsTr("Preferred size")
|
|
tooltip: qsTr("Preferred size of an item in a layout. If the preferred height or width is -1, it is ignored.")
|
|
}
|
|
|
|
SecondColumnLayout {
|
|
Layout.fillWidth: true
|
|
|
|
Label {
|
|
text: "W"
|
|
width: 12
|
|
}
|
|
|
|
SpinBox {
|
|
backendValue: backendValues.Layout_preferredWidth
|
|
maximumValue: 0xffff
|
|
minimumValue: -1
|
|
decimals: 0
|
|
}
|
|
|
|
Item {
|
|
width: 4
|
|
height: 4
|
|
}
|
|
|
|
Label {
|
|
text: "H"
|
|
width: 12
|
|
}
|
|
|
|
SpinBox {
|
|
backendValue: backendValues.Layout_preferredHeight
|
|
maximumValue: 0xffff
|
|
minimumValue: -1
|
|
decimals: 0
|
|
}
|
|
ExpandingSpacer {
|
|
|
|
}
|
|
}
|
|
|
|
Label {
|
|
text: qsTr("Minimum size")
|
|
tooltip: qsTr("Minimum size of an item in a layout.")
|
|
}
|
|
|
|
SecondColumnLayout {
|
|
Layout.fillWidth: true
|
|
|
|
Label {
|
|
text: "W"
|
|
width: 12
|
|
}
|
|
|
|
SpinBox {
|
|
backendValue: backendValues.Layout_minimumWidth
|
|
maximumValue: 0xffff
|
|
minimumValue: 0
|
|
decimals: 0
|
|
}
|
|
|
|
Item {
|
|
width: 4
|
|
height: 4
|
|
}
|
|
|
|
Label {
|
|
text: "H"
|
|
width: 12
|
|
}
|
|
|
|
SpinBox {
|
|
backendValue: backendValues.Layout_minimumHeight
|
|
maximumValue: 0xffff
|
|
minimumValue: 0
|
|
decimals: 0
|
|
}
|
|
ExpandingSpacer {
|
|
|
|
}
|
|
}
|
|
|
|
Label {
|
|
text: qsTr("Maximum size")
|
|
tooltip: qsTr("Maximum size of an item in a layout.")
|
|
}
|
|
|
|
SecondColumnLayout {
|
|
Layout.fillWidth: true
|
|
|
|
Label {
|
|
text: "W"
|
|
width: 12
|
|
}
|
|
|
|
SpinBox {
|
|
backendValue: backendValues.Layout_maximumWidth
|
|
maximumValue: 0xffff
|
|
minimumValue: 0
|
|
decimals: 0
|
|
}
|
|
|
|
Item {
|
|
width: 4
|
|
height: 4
|
|
}
|
|
|
|
Label {
|
|
text: "H"
|
|
width: 12
|
|
}
|
|
|
|
SpinBox {
|
|
backendValue: backendValues.Layout_maximumHeight
|
|
maximumValue: 0xffff
|
|
minimumValue: 0
|
|
decimals: 0
|
|
}
|
|
ExpandingSpacer {
|
|
|
|
}
|
|
}
|
|
|
|
Label {
|
|
text: qsTr("Row span")
|
|
tooltip: qsTr("Row span of an item in a GridLayout.")
|
|
}
|
|
|
|
SecondColumnLayout {
|
|
Layout.fillWidth: true
|
|
|
|
Item {
|
|
height: 4
|
|
width: 12
|
|
}
|
|
|
|
SpinBox {
|
|
backendValue: backendValues.Layout_rowSpan
|
|
maximumValue: 0xffff
|
|
minimumValue: 0
|
|
decimals: 0
|
|
}
|
|
|
|
ExpandingSpacer {
|
|
|
|
}
|
|
}
|
|
|
|
Label {
|
|
text: qsTr("Column span")
|
|
tooltip: qsTr("Column span of an item in a GridLayout.")
|
|
}
|
|
|
|
SecondColumnLayout {
|
|
Layout.fillWidth: true
|
|
|
|
Item {
|
|
height: 4
|
|
width: 12
|
|
}
|
|
|
|
SpinBox {
|
|
backendValue: backendValues.Layout_columnSpan
|
|
maximumValue: 0xffff
|
|
minimumValue: 0
|
|
decimals: 0
|
|
}
|
|
|
|
ExpandingSpacer {
|
|
|
|
}
|
|
}
|
|
}
|