status-desktop/ui/shared/PopupMenu.qml

150 lines
5.3 KiB
QML
Raw Normal View History

2020-06-17 15:31:01 -04:00
import QtQuick 2.13
import QtQuick.Controls 2.13
import QtGraphicalEffects 1.13
import "../imports"
import "../shared"
Menu {
2020-08-04 17:09:24 -04:00
// This is to add icons to submenu items. QML doesn't have a way to add icons to those sadly so this is a workaround
property var subMenuIcons: []
2020-07-09 14:26:50 -04:00
property int paddingSize: 8
property bool hasArrow: true
2020-07-09 13:47:36 -04:00
closePolicy: Popup.CloseOnPressOutside | Popup.CloseOnReleaseOutside | Popup.CloseOnEscape
id: popupMenu
2020-10-09 13:56:42 -04:00
topPadding: paddingSize
2020-07-09 14:26:50 -04:00
bottomPadding: paddingSize
delegate: MenuItem {
2020-08-04 17:09:24 -04:00
property color textColor: (this.action.icon.color != "#00000000" ? this.action.icon.color : Style.current.textColor)
property int subMenuIndex: {
if (!this.subMenu) {
return -1
}
let child;
let index = 0;
for (let i = 0; i < popupMenu.count; i++) {
child = popupMenu.itemAt(i)
if (child.subMenu) {
if (child === this) {
return index
} else {
index++;
}
}
}
return index
}
action: Action{} // Meant to be overwritten
id: popupMenuItem
implicitWidth: 200
2020-07-09 14:26:50 -04:00
implicitHeight: 34
font.pixelSize: 13
2020-10-09 13:56:42 -04:00
font.weight: checked ? Font.Medium : Font.Normal
icon.color: popupMenuItem.action.icon.color != "#00000000" ? popupMenuItem.action.icon.color : Style.current.blue
2020-08-04 17:09:24 -04:00
icon.source: this.subMenu ? subMenuIcons[subMenuIndex].source : popupMenuItem.action.icon.source
icon.width: this.subMenu ? subMenuIcons[subMenuIndex].width : popupMenuItem.action.icon.width
icon.height: this.subMenu ? subMenuIcons[subMenuIndex].height : popupMenuItem.action.icon.height
2020-10-09 13:56:42 -04:00
visible: popupMenuItem.action.enabled && !!popupMenuItem.text
height: visible ? popupMenuItem.implicitHeight : 0
2020-07-09 14:26:50 -04:00
2020-08-04 17:09:24 -04:00
arrow: SVGImage {
source: "../app/img/caret.svg"
rotation: -90
anchors.verticalCenter: parent.verticalCenter
anchors.right: parent.right
anchors.rightMargin: 12
width: 9
fillMode: Image.PreserveAspectFit
visible: popupMenuItem.subMenu
2020-08-04 17:09:24 -04:00
ColorOverlay {
anchors.fill: parent
source: parent
color: popupMenuItem.highlighted ? Style.current.white : popupMenuItem.textColor
2020-07-09 14:26:50 -04:00
}
2020-08-04 17:09:24 -04:00
}
// FIXME the icons looks very pixelated on Linux for some reason. Using smooth, mipmap, etc doesn't fix it
indicator: Item {
2020-08-04 17:09:24 -04:00
visible: !!popupMenuItem.icon.source.toString()
width: !isNaN(popupMenuItem.icon.width) ? popupMenuItem.icon.width : 25
height: !isNaN(popupMenuItem.icon.height) ? popupMenuItem.icon.height : 25
anchors.left: parent.left
anchors.leftMargin: Style.current.padding
anchors.verticalCenter: parent.verticalCenter
Image {
id: menuIcon
source: popupMenuItem.icon.source
visible: false
width: parent.width
height: parent.width
sourceSize.width: width
sourceSize.height: height
}
2020-07-09 14:26:50 -04:00
ColorOverlay {
anchors.fill: menuIcon
source: menuIcon
smooth: true
2020-07-09 14:26:50 -04:00
color: popupMenuItem.highlighted ?
Style.current.primaryMenuItemTextHover :
(popupMenuItem.action.icon.color != "#00000000" ? popupMenuItem.action.icon.color : Style.current.primaryMenuItemHover)
}
}
2020-08-04 17:09:24 -04:00
contentItem: StyledText {
anchors.left: popupMenuItem.indicator.right
anchors.leftMargin: popupMenu.paddingSize
text: popupMenuItem.text
font: popupMenuItem.font
color: popupMenuItem.highlighted ? Style.current.primaryMenuItemTextHover : popupMenuItem.textColor
2020-08-04 17:09:24 -04:00
horizontalAlignment: Text.AlignLeft
verticalAlignment: Text.AlignVCenter
opacity: enabled ? 1.0 : 0.3
elide: Text.ElideRight
}
background: Rectangle {
implicitWidth: 220
2020-07-09 14:26:50 -04:00
implicitHeight: 24
color: popupMenuItem.highlighted ? popupMenuItem.icon.color : "transparent"
}
}
2020-08-04 17:09:24 -04:00
background: Item {
id: bgPopupMenu
implicitWidth: 220
Rectangle {
id: bgPopupMenuContent
implicitWidth: bgPopupMenu.width
implicitHeight: bgPopupMenu.height
color: Style.current.modalBackground
radius: 8
layer.enabled: true
layer.effect: DropShadow{
width: bgPopupMenuContent.width
height: bgPopupMenuContent.height
x: bgPopupMenuContent.x
visible: bgPopupMenuContent.visible
source: bgPopupMenuContent
horizontalOffset: 0
verticalOffset: 4
radius: 12
samples: 25
spread: 0.2
color: "#22000000"
}
}
}
}
2020-06-04 10:53:10 -04:00
/*##^##
Designer {
D{i:0;autoSize:true;height:480;width:640}
}
##^##*/