PlasmoidHeader: Make it based on T.ToolBar, deprecate location
PlasmoidHeader was probably based on T.Frame because of a mistake. T.Frame doesn't do anything different from T.Pane and PlasmoidHeader was duplicating the function of T.ToolBar's position property with the location property.
This commit is contained in:
parent
815ddd3fc3
commit
65360e9841
@ -14,12 +14,14 @@ import "private" as Private
|
|||||||
/**
|
/**
|
||||||
* Item to be used as a header or footer in plasmoids
|
* Item to be used as a header or footer in plasmoids
|
||||||
*
|
*
|
||||||
* @inherit QtQuick.Templates.Frame
|
* @inherit QtQuick.Templates.ToolBar
|
||||||
*/
|
*/
|
||||||
T.Frame {
|
T.ToolBar {
|
||||||
id: control
|
id: control
|
||||||
/**
|
/**
|
||||||
* Possible positions of the heading element
|
* Possible positions of the heading element
|
||||||
|
*
|
||||||
|
* @deprecated since 5.85
|
||||||
*/
|
*/
|
||||||
enum Location {
|
enum Location {
|
||||||
/**
|
/**
|
||||||
@ -36,29 +38,32 @@ import "private" as Private
|
|||||||
* location: int
|
* location: int
|
||||||
*
|
*
|
||||||
* Indicates the position of the heading. The default is PlasmoidHeading.Location.Header.
|
* Indicates the position of the heading. The default is PlasmoidHeading.Location.Header.
|
||||||
|
*
|
||||||
|
* @deprecated since 5.85, use position from QtQuick.Templates.ToolBar instead
|
||||||
*/
|
*/
|
||||||
property int location: PlasmoidHeading.Location.Header
|
property int location: PlasmoidHeading.Location.Header
|
||||||
|
position: location
|
||||||
|
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
bottomPadding: location == PlasmoidHeading.Location.Footer ? 0 : -backgroundMetrics.getMargin("bottom")
|
bottomPadding: position == T.ToolBar.Footer ? 0 : -backgroundMetrics.getMargin("bottom")
|
||||||
topPadding: location == PlasmoidHeading.Location.Footer ? -backgroundMetrics.getMargin("top") : 0
|
topPadding: position == T.ToolBar.Footer ? -backgroundMetrics.getMargin("top") : 0
|
||||||
|
|
||||||
implicitHeight: Math.max(implicitBackgroundHeight + topInset + bottomInset, implicitContentHeight + topPadding + bottomPadding)
|
implicitHeight: Math.max(implicitBackgroundHeight + topInset + bottomInset, contentHeight + topPadding + bottomPadding)
|
||||||
implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset, implicitContentWidth + leftPadding + rightPadding)
|
implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset, contentWidth + leftPadding + rightPadding)
|
||||||
|
|
||||||
leftInset: backgroundMetrics.getMargin("left")
|
leftInset: backgroundMetrics.getMargin("left")
|
||||||
rightInset: backgroundMetrics.getMargin("right")
|
rightInset: backgroundMetrics.getMargin("right")
|
||||||
topInset: location == PlasmoidHeading.Location.Footer ? 0 : backgroundMetrics.getMargin("top")
|
topInset: position == T.ToolBar.Footer ? 0 : backgroundMetrics.getMargin("top")
|
||||||
bottomInset: location == PlasmoidHeading.Location.Footer ? backgroundMetrics.getMargin("bottom") : 0
|
bottomInset: position == T.ToolBar.Footer ? backgroundMetrics.getMargin("bottom") : 0
|
||||||
|
|
||||||
PlasmaCore.ColorScope.colorGroup: location == PlasmoidHeading.Location.Header ? PlasmaCore.Theme.HeaderColorGroup : PlasmaCore.Theme.NormalColorGroup
|
PlasmaCore.ColorScope.colorGroup: position == T.ToolBar.Header ? PlasmaCore.Theme.HeaderColorGroup : PlasmaCore.Theme.NormalColorGroup
|
||||||
PlasmaCore.ColorScope.inherit: false
|
PlasmaCore.ColorScope.inherit: false
|
||||||
|
|
||||||
background: PlasmaCore.FrameSvgItem {
|
background: PlasmaCore.FrameSvgItem {
|
||||||
id: headingSvg
|
id: headingSvg
|
||||||
visible: fromCurrentTheme
|
visible: fromCurrentTheme
|
||||||
imagePath: "widgets/plasmoidheading"
|
imagePath: "widgets/plasmoidheading"
|
||||||
prefix: location == PlasmoidHeading.Location.Header? 'header' : 'footer'
|
prefix: position == T.ToolBar.Header ? 'header' : 'footer'
|
||||||
|
|
||||||
colorGroup: control.PlasmaCore.ColorScope.colorGroup
|
colorGroup: control.PlasmaCore.ColorScope.colorGroup
|
||||||
PlasmaCore.ColorScope.inherit: false
|
PlasmaCore.ColorScope.inherit: false
|
||||||
@ -67,23 +72,13 @@ import "private" as Private
|
|||||||
var borders = 0
|
var borders = 0
|
||||||
borders |= PlasmaCore.FrameSvg.LeftBorder
|
borders |= PlasmaCore.FrameSvg.LeftBorder
|
||||||
borders |= PlasmaCore.FrameSvg.RightBorder
|
borders |= PlasmaCore.FrameSvg.RightBorder
|
||||||
if (plasmoid.location !== PlasmaCore.Types.TopEdge || location != PlasmoidHeading.Location.Header) {
|
if (plasmoid.position !== PlasmaCore.Types.TopEdge || position != T.ToolBar.Header) {
|
||||||
borders |= PlasmaCore.FrameSvg.TopBorder
|
borders |= PlasmaCore.FrameSvg.TopBorder
|
||||||
}
|
}
|
||||||
if (plasmoid.location !== PlasmaCore.Types.BottomEdge || location != PlasmoidHeading.Location.Footer) {
|
if (plasmoid.position !== PlasmaCore.Types.BottomEdge || position != T.ToolBar.Footer) {
|
||||||
borders |= PlasmaCore.FrameSvg.BottomBorder
|
borders |= PlasmaCore.FrameSvg.BottomBorder
|
||||||
}
|
}
|
||||||
return borders
|
return borders
|
||||||
}
|
}
|
||||||
Private.BackgroundMetrics {
|
|
||||||
id: backgroundMetrics
|
|
||||||
function getMargin(margin) {
|
|
||||||
if (!hasInset) {
|
|
||||||
return -headingSvg.fixedMargins[margin];
|
|
||||||
} else {
|
|
||||||
return -backgroundMetrics.fixedMargins[margin] + backgroundMetrics.inset[margin]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user