ditch the model, support a repeater for items

add menu items when a child that is a menuitem is added, this lets us to not deviate too much from the standard api
This commit is contained in:
Marco Martin 2011-12-29 15:09:58 +01:00
parent ecc105c564
commit 98e7440620
4 changed files with 45 additions and 56 deletions

View File

@ -40,7 +40,7 @@ QMenuProxy::~QMenuProxy()
delete m_menu; delete m_menu;
} }
QDeclarativeListProperty<QMenuItem> QMenuProxy::items() QDeclarativeListProperty<QMenuItem> QMenuProxy::content()
{ {
return QDeclarativeListProperty<QMenuItem>(this, m_items); return QDeclarativeListProperty<QMenuItem>(this, m_items);
} }
@ -75,6 +75,37 @@ void QMenuProxy::setVisualParent(QDeclarativeItem *parent)
emit visualParentChanged(); emit visualParentChanged();
} }
bool QMenuProxy::event(QEvent *event)
{
switch (event->type()) {
case QEvent::ChildAdded: {
QChildEvent *ce = static_cast<QChildEvent *>(event);
QMenuItem *mi = qobject_cast<QMenuItem *>(ce->child());
//FIXME: linear complexity here
if (mi && !m_items.contains(mi)) {
m_items << mi;
}
break;
}
case QEvent::ChildRemoved: {
QChildEvent *ce = static_cast<QChildEvent *>(event);
QMenuItem *mi = qobject_cast<QMenuItem *>(ce->child());
//FIXME: linear complexity here
if (mi) {
m_items.removeAll(mi);
}
break;
}
default:
break;
}
return QObject::event(event);
}
void QMenuProxy::clearMenuItems() void QMenuProxy::clearMenuItems()
{ {
qDeleteAll(m_items); qDeleteAll(m_items);
@ -88,6 +119,11 @@ void QMenuProxy::addMenuItem(const QString &text)
m_items << item; m_items << item;
} }
void QMenuProxy::addMenuItem(QMenuItem *item)
{
m_items << item;
}
void QMenuProxy::itemTriggered(QAction *action) void QMenuProxy::itemTriggered(QAction *action)
{ {
QMenuItem *item = qobject_cast<QMenuItem *>(action); QMenuItem *item = qobject_cast<QMenuItem *>(action);

View File

@ -32,8 +32,8 @@ class QMenuProxy : public QObject
{ {
Q_OBJECT Q_OBJECT
Q_PROPERTY(QDeclarativeListProperty<QMenuItem> items READ items CONSTANT) Q_PROPERTY(QDeclarativeListProperty<QMenuItem> content READ content CONSTANT)
Q_CLASSINFO("DefaultProperty", "items") Q_CLASSINFO("DefaultProperty", "content")
Q_PROPERTY(QDeclarativeItem *visualParent READ visualParent WRITE setVisualParent NOTIFY visualParentChanged()) Q_PROPERTY(QDeclarativeItem *visualParent READ visualParent WRITE setVisualParent NOTIFY visualParentChanged())
Q_PROPERTY(DialogStatus::Status status READ status NOTIFY statusChanged) Q_PROPERTY(DialogStatus::Status status READ status NOTIFY statusChanged)
@ -41,7 +41,7 @@ public:
QMenuProxy(QObject *parent = 0); QMenuProxy(QObject *parent = 0);
~QMenuProxy(); ~QMenuProxy();
QDeclarativeListProperty<QMenuItem> items(); QDeclarativeListProperty<QMenuItem> content();
int actionCount() const; int actionCount() const;
QMenuItem *action(int) const; QMenuItem *action(int) const;
DialogStatus::Status status() const; DialogStatus::Status status() const;
@ -54,6 +54,10 @@ public:
Q_INVOKABLE void close(); Q_INVOKABLE void close();
Q_INVOKABLE void clearMenuItems(); Q_INVOKABLE void clearMenuItems();
Q_INVOKABLE void addMenuItem(const QString &text); Q_INVOKABLE void addMenuItem(const QString &text);
Q_INVOKABLE void addMenuItem(QMenuItem *item);
protected:
bool event(QEvent *event);
Q_SIGNALS: Q_SIGNALS:
void statusChanged(); void statusChanged();

View File

@ -27,6 +27,7 @@ class QMenuItem : public QAction
{ {
Q_OBJECT Q_OBJECT
Q_PROPERTY(QObject *parent READ parent WRITE setParent)
Q_PROPERTY(bool separator READ isSeparator WRITE setSeparator) Q_PROPERTY(bool separator READ isSeparator WRITE setSeparator)
public: public:

View File

@ -67,56 +67,4 @@ import org.kde.plasma.components 0.1
Menu { Menu {
id: root id: root
property variant model
onModelChanged: rebuildMenu()
Component.onCompleted: if (model != undefined) rebuildMenu()
function rebuildMenu()
{
clearMenuItems();
for (var i = 0; i < items.length; ++i) {
addMenuItem(items[i].text)
}
//it's a model
if (model != undefined && model.count) {
for (var j = 0; j < model.count; ++j) {
var data = model.get(j)
var text = data.text
if (!text) {
text = data.display
}
addMenuItem(text)
//enabled property must be present -and- be false
if (data.enabled === false) {
items[items.length-1].enabled = false
}
if (data.separator === true) {
items[items.length-1].separator = true
}
}
//it's a list
} else if (model != undefined && model.length) {
for (var j = 0; j < model.length; ++j) {
var data = model[j]
var text = data.text
if (!text) {
text = data.display
}
addMenuItem(text)
//enabled property must be present -and- be false
if (data.enabled === false) {
items[items.length-1].enabled = false
}
if (data.separator === true) {
items[items.length-1].separator = true
}
}
}
}
} }