Don't duplicate background resizing to contents
The code in Button is panel.implicitWidth: max(label+borders, backgroundImplicitSize) by setting the background implicitSize to be max(size, labels+borders) we just duplicate the functionality. This worked, but icon only buttons became smaller because we weren't setting the implicitHeight of the label properly. (two wrongs were making a right) We need to move the RowLayout inside an Item as we are modiyfing the preferredHeight of RowLayout, but this doesn't sync back to updating the implicitHeight which Button.qml uses. This fixes all binding loops and the rather broken icon only flat button. Change-Id: Id2f9c2ab37b2280ee69dc1473f388fe686e3327e
This commit is contained in:
parent
b2a5ebc926
commit
8a70067e8c
@ -34,72 +34,84 @@ QtQuickControlStyle.ButtonStyle {
|
|||||||
property int minimumWidth
|
property int minimumWidth
|
||||||
property int minimumHeight
|
property int minimumHeight
|
||||||
|
|
||||||
label: RowLayout {
|
label: Item {
|
||||||
id: buttonContent
|
//wrapper is needed as we are adjusting the preferredHeight of the layout from the default
|
||||||
spacing: units.smallSpacing
|
//and the implicitHeight is implicitly read only
|
||||||
Layout.preferredHeight: Math.max(units.iconSizes.small, label.implicitHeight)
|
implicitHeight: buttonContent.Layout.preferredHeight
|
||||||
|
implicitWidth: buttonContent.implicitWidth
|
||||||
|
RowLayout {
|
||||||
|
id: buttonContent
|
||||||
|
anchors.fill: parent
|
||||||
|
spacing: units.smallSpacing
|
||||||
|
|
||||||
property real minimumWidth: Layout.minimumWidth + style.padding.left + style.padding.right
|
Layout.preferredHeight: Math.max(units.iconSizes.small, label.implicitHeight)
|
||||||
onMinimumWidthChanged: {
|
|
||||||
if (control.minimumWidth !== undefined) {
|
property real minimumWidth: Layout.minimumWidth + style.padding.left + style.padding.right
|
||||||
style.minimumWidth = minimumWidth;
|
onMinimumWidthChanged: {
|
||||||
control.minimumWidth = minimumWidth;
|
if (control.minimumWidth !== undefined) {
|
||||||
|
style.minimumWidth = minimumWidth;
|
||||||
|
control.minimumWidth = minimumWidth;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
property real minimumHeight: Layout.preferredHeight + style.padding.top + style.padding.bottom
|
property real minimumHeight: Layout.preferredHeight + style.padding.top + style.padding.bottom
|
||||||
onMinimumHeightChanged: {
|
onMinimumHeightChanged: {
|
||||||
if (control.minimumHeight !== undefined) {
|
if (control.minimumHeight !== undefined) {
|
||||||
style.minimumHeight = minimumHeight;
|
style.minimumHeight = minimumHeight;
|
||||||
control.minimumHeight = minimumHeight;
|
control.minimumHeight = minimumHeight;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
PlasmaCore.IconItem {
|
PlasmaCore.IconItem {
|
||||||
id: icon
|
id: icon
|
||||||
source: control.iconName || control.iconSource
|
source: control.iconName || control.iconSource
|
||||||
anchors.verticalCenter: parent.verticalCenter
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
Layout.minimumWidth: valid ? parent.height: 0
|
|
||||||
Layout.maximumWidth: Layout.minimumWidth
|
|
||||||
visible: valid
|
|
||||||
Layout.minimumHeight: Layout.minimumWidth
|
|
||||||
Layout.maximumHeight: Layout.minimumWidth
|
|
||||||
active: control.hovered
|
|
||||||
colorGroup: control.hovered || !control.flat ? PlasmaCore.Theme.ButtonColorGroup : PlasmaCore.Theme.NormalColorGroup
|
|
||||||
}
|
|
||||||
|
|
||||||
PlasmaComponents.Label {
|
implicitHeight: label.implicitHeight
|
||||||
id: label
|
implicitWidth: implicitHeight
|
||||||
Layout.minimumWidth: implicitWidth
|
|
||||||
text: control.text
|
|
||||||
font: control.font
|
|
||||||
visible: control.text != ""
|
|
||||||
Layout.fillWidth: true
|
|
||||||
height: parent.height
|
|
||||||
color: control.hovered || !control.flat ? theme.buttonTextColor : theme.textColor
|
|
||||||
horizontalAlignment: icon.valid ? Text.AlignLeft : Text.AlignHCenter
|
|
||||||
verticalAlignment: Text.AlignVCenter
|
|
||||||
elide: Text.ElideRight
|
|
||||||
}
|
|
||||||
|
|
||||||
PlasmaExtras.ConditionalLoader {
|
Layout.minimumWidth: valid ? parent.height: 0
|
||||||
id: arrow
|
Layout.maximumWidth: Layout.minimumWidth
|
||||||
when: control.menu !== null
|
visible: valid
|
||||||
visible: when
|
Layout.minimumHeight: Layout.minimumWidth
|
||||||
Layout.minimumWidth: units.iconSizes.small
|
Layout.maximumHeight: Layout.minimumWidth
|
||||||
Layout.maximumWidth: Layout.minimumWidth
|
active: control.hovered
|
||||||
Layout.alignment: Qt.AlignVCenter
|
colorGroup: control.hovered || !control.flat ? PlasmaCore.Theme.ButtonColorGroup : PlasmaCore.Theme.NormalColorGroup
|
||||||
height: width
|
}
|
||||||
|
|
||||||
source: Component {
|
PlasmaComponents.Label {
|
||||||
PlasmaCore.SvgItem {
|
id: label
|
||||||
visible: control.menu !== null
|
Layout.minimumWidth: implicitWidth
|
||||||
anchors.fill: parent
|
text: control.text
|
||||||
svg: PlasmaCore.Svg {
|
font: control.font
|
||||||
imagePath: "widgets/arrows"
|
visible: control.text != ""
|
||||||
colorGroup: control.hovered || !control.flat ? PlasmaCore.Theme.ButtonColorGroup : PlasmaCore.Theme.NormalColorGroup
|
Layout.fillWidth: true
|
||||||
|
height: parent.height
|
||||||
|
color: control.hovered || !control.flat ? theme.buttonTextColor : theme.textColor
|
||||||
|
horizontalAlignment: icon.valid ? Text.AlignLeft : Text.AlignHCenter
|
||||||
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
elide: Text.ElideRight
|
||||||
|
}
|
||||||
|
|
||||||
|
PlasmaExtras.ConditionalLoader {
|
||||||
|
id: arrow
|
||||||
|
when: control.menu !== null
|
||||||
|
visible: when
|
||||||
|
Layout.minimumWidth: units.iconSizes.small
|
||||||
|
Layout.maximumWidth: Layout.minimumWidth
|
||||||
|
Layout.alignment: Qt.AlignVCenter
|
||||||
|
height: width
|
||||||
|
|
||||||
|
source: Component {
|
||||||
|
PlasmaCore.SvgItem {
|
||||||
|
visible: control.menu !== null
|
||||||
|
anchors.fill: parent
|
||||||
|
svg: PlasmaCore.Svg {
|
||||||
|
imagePath: "widgets/arrows"
|
||||||
|
colorGroup: control.hovered || !control.flat ? PlasmaCore.Theme.ButtonColorGroup : PlasmaCore.Theme.NormalColorGroup
|
||||||
|
}
|
||||||
|
elementId: "down-arrow"
|
||||||
}
|
}
|
||||||
elementId: "down-arrow"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -117,7 +129,9 @@ QtQuickControlStyle.ButtonStyle {
|
|||||||
id: roundButtonComponent
|
id: roundButtonComponent
|
||||||
Item {
|
Item {
|
||||||
id: roundButtonDelegate
|
id: roundButtonDelegate
|
||||||
anchors.fill: parent
|
implicitHeight: Math.floor(theme.mSize(theme.defaultFont).height*1.6)
|
||||||
|
implicitWidth: implicitHeight
|
||||||
|
|
||||||
property QtObject margins: QtObject {
|
property QtObject margins: QtObject {
|
||||||
property int left: control.width/8
|
property int left: control.width/8
|
||||||
property int top: control.width/8
|
property int top: control.width/8
|
||||||
@ -166,13 +180,13 @@ QtQuickControlStyle.ButtonStyle {
|
|||||||
id: buttonComponent
|
id: buttonComponent
|
||||||
Item {
|
Item {
|
||||||
id: buttonSurface
|
id: buttonSurface
|
||||||
implicitHeight: Math.floor(Math.max(theme.mSize(theme.defaultFont).height*1.6, style.minimumHeight))
|
implicitHeight: Math.floor(theme.mSize(theme.defaultFont).height*1.6)
|
||||||
|
|
||||||
implicitWidth: {
|
implicitWidth: {
|
||||||
if (control.text.length == 0) {
|
if (control.text.length == 0) {
|
||||||
implicitHeight;
|
implicitHeight;
|
||||||
} else {
|
} else {
|
||||||
Math.max(theme.mSize(theme.defaultFont).width*12, style.minimumWidth);
|
Math.floor(theme.mSize(theme.defaultFont).width*12);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Connections {
|
Connections {
|
||||||
|
Loading…
Reference in New Issue
Block a user