/usr/lib/x86_64-linux-gnu/qt5/qml/QtQuick/Controls.2/org.kde.desktop/MenuItem.qml is in qml-module-org-kde-qqc2desktopstyle 5.44.0-0ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 | /*
* Copyright 2017 Marco Martin <mart@kde.org>
* Copyright 2017 The Qt Company Ltd.
*
* GNU Lesser General Public License Usage
* Alternatively, this file may be used under the terms of the GNU Lesser
* General Public License version 3 as published by the Free Software
* Foundation and appearing in the file LICENSE.LGPLv3 included in the
* packaging of this file. Please review the following information to
* ensure the GNU Lesser General Public License version 3 requirements
* will be met: https://www.gnu.org/licenses/lgpl.html.
*
* GNU General Public License Usage
* Alternatively, this file may be used under the terms of the GNU
* General Public License version 2.0 or later as published by the Free
* Software Foundation and appearing in the file LICENSE.GPL included in
* the packaging of this file. Please review the following information to
* ensure the GNU General Public License version 2.0 requirements will be
* met: http://www.gnu.org/licenses/gpl-2.0.html.
*/
import QtQuick 2.6
import QtQuick.Layouts 1.2
import QtQuick.Templates 2.2 as T
import org.kde.kirigami 2.2 as Kirigami
T.MenuItem {
id: controlRoot
implicitWidth: Math.max(background ? background.implicitWidth : 0,
contentItem.implicitWidth + leftPadding + rightPadding)
implicitHeight: Math.max(background ? background.implicitHeight : 0,
Math.max(contentItem.implicitHeight,
indicator ? indicator.implicitHeight : 0) + topPadding + bottomPadding)
baselineOffset: contentItem.y + contentItem.baselineOffset
Layout.fillWidth: true
padding: 1
hoverEnabled: !Kirigami.Settings.isMobile
contentItem: RowLayout {
Item {
Layout.preferredWidth: controlRoot.ListView.view.hasCheckables || controlRoot.checkable ? controlRoot.indicator.width : 0
}
Kirigami.Icon {
Layout.alignment: Qt.AlignVCenter
visible: controlRoot.ListView.view.hasIcons || (controlRoot.icon != undefined && (controlRoot.icon.name.length > 0 || controlRoot.icon.source.length > 0))
source: controlRoot.icon ? (controlRoot.icon.name || controlRoot.icon.source) : ""
color: controlRoot.icon ? controlRoot.icon.color : "transparent"
//hovered is for retrocompatibility
selected: (controlRoot.highlighted || controlRoot.hovered)
Layout.preferredHeight: Math.max(label.height, Kirigami.Units.iconSizes.small)
Layout.preferredWidth: Layout.preferredHeight
}
Label {
id: label
Layout.alignment: Qt.AlignVCenter
Layout.fillWidth: true
text: controlRoot.text
font: controlRoot.font
color: (controlRoot.highlighted || controlRoot.hovered) ? Kirigami.Theme.highlightedTextColor : Kirigami.Theme.textColor
elide: Text.ElideRight
visible: controlRoot.text
horizontalAlignment: Text.AlignLeft
verticalAlignment: Text.AlignVCenter
}
}
//we can't use arrow: on old qqc2 releases
//Needs QtQuick.Controls 2.3 arrow: Kirigami.Icon {
//Needs QtQuick.Controls 2.3 x: controlRoot.mirrored ? controlRoot.padding : controlRoot.width - width - controlRoot.padding
//Needs QtQuick.Controls 2.3 y: controlRoot.topPadding + (controlRoot.availableHeight - height) / 2
//Needs QtQuick.Controls 2.3 source: controlRoot.mirrored ? "go-next-symbolic-rtl" : "go-next-symbolic"
//Needs QtQuick.Controls 2.3 selected: controlRoot.highlighted
//Needs QtQuick.Controls 2.3 width: Math.max(label.height, Kirigami.Units.iconSizes.small)
//Needs QtQuick.Controls 2.3 height: width
//Needs QtQuick.Controls 2.3 visible: controlRoot.subMenu
//Needs QtQuick.Controls 2.3 }
indicator: CheckIndicator {
x: controlRoot.mirrored ? controlRoot.width - width - controlRoot.rightPadding : controlRoot.leftPadding
y: controlRoot.topPadding + (controlRoot.availableHeight - height) / 2
visible: controlRoot.checkable
on: controlRoot.checked
control: controlRoot
}
background: Item {
anchors.fill: parent
implicitWidth: Kirigami.Units.gridUnit * 8
Rectangle {
anchors.fill: parent
color: Kirigami.Theme.highlightColor
opacity: ((controlRoot.highlighted || controlRoot.hovered) || controlRoot.hovered) ? 1 : 0
Behavior on opacity { NumberAnimation { duration: 150 } }
}
}
}
|