An error occurred while loading the file. Please try again.
-
J-P Nurmi authored
There are three ways to add tabs: - declare 'static' Tab { } child elements - call addTab() / insertTab() - Component::createObject(tabView) => Do not rely on the calling order of Component.onCompleted() and make sure that the same tabs are not accidentally re-inserted. Task-number: QTBUG-30873 Change-Id: Ib30cfb676debbb302c5e9f7d757f66aab6fcc684 Reviewed-by:
Caroline Chao <caroline.chao@digia.com>
a6deb27b
import QtQuick 2.0
import "../components/plugin"
MenuBase {
property ListModel model
property string selectedText: itemTextAt(selectedIndex)
property string hoveredText: itemTextAt(hoveredIndex)
// 'centerSelectedText' means that the menu will be positioned
// so that the selected text' top left corner will be at x, y.
property bool centerSelectedText: true
// Show, or hide, the popup by setting the 'visible' property:
visible: false
onMenuClosed: visible = false
onModelChanged: if (Component.status === Component.Ready) rebuildMenu()
Component.onCompleted: rebuildMenu()
onHoveredIndexChanged: {
if (hoveredIndex < menuItems.length)
menuItems[hoveredIndex].emitHovered()
}
onSelectedIndexChanged: {
if (hoveredIndex < menuItems.length)
menuItems[hoveredIndex].emitSelected()
}
onVisibleChanged: {
if (visible) {
var globalPos = parent.mapToItem(null, x, y)
showPopup(globalPos.x, globalPos.y, centerSelectedText ? selectedIndex : 0)
} else {
closePopup()
}
}
function rebuildMenu()
{
clearMenuItems();
for (var i=0; i<menuItems.length; ++i)
addMenuItem(menuItems[i].text)
if (model != undefined) {
for (var j=0; j<model.count; ++j)
addMenuItem(model.get(j).text)
}
}
}