* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
+ ***************************************************************************
+ * Parts of this implementation are taken from KDE's kaction.cpp *
***************************************************************************/
+
+#include <QApplication>
+
+#include "action.h"
+
+Action::Action(QObject *parent) : QWidgetAction(parent) {
+ init();
+}
+
+Action::Action(const QString &text, QObject *parent) : QWidgetAction(parent) {
+ init();
+ setText(text);
+}
+
+Action::Action(const QIcon &icon, const QString &text, QObject *parent) : QWidgetAction(parent) {
+ init();
+ setIcon(icon);
+ setText(text);
+}
+
+void Action::init() {
+ connect(this, SIGNAL(triggered(bool)), this, SLOT(slotTriggered()));
+
+ setProperty("isShortcutConfigurable", true);
+}
+
+void Action::slotTriggered() {
+ emit triggered(QApplication::mouseButtons(), QApplication::keyboardModifiers());
+}
+
+bool Action::isShortcutConfigurable() const {
+ return property("isShortcutConfigurable").toBool();
+}
+
+void Action::setShortcutConfigurable(bool b) {
+ setProperty("isShortcutConfigurable", b);
+}
+
+QKeySequence Action::shortcut(ShortcutTypes type) const {
+ Q_ASSERT(type);
+ if(type == DefaultShortcut)
+ return property("defaultShortcut").value<QKeySequence>();
+
+ if(shortcuts().count()) return shortcuts().value(0);
+ return QKeySequence();
+}
+
+void Action::setShortcut(const QShortcut &shortcut, ShortcutTypes type) {
+ setShortcut(shortcut.key(), type);
+}
+
+void Action::setShortcut(const QKeySequence &key, ShortcutTypes type) {
+ Q_ASSERT(type);
+
+ if(type & DefaultShortcut)
+ setProperty("defaultShortcut", key);
+
+ if(type & ActiveShortcut)
+ QAction::setShortcut(key);
+}
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
+ ***************************************************************************
+ * Parts of this API have been shamelessly stolen from KDE's kaction.h *
***************************************************************************/
#ifndef ACTION_H_
#define ACTION_H_
+#include <QShortcut>
#include <QWidgetAction>
+/// A specialized QWidgetAction, enhanced by some KDE features
+/** This declares/implements a subset of KAction's API (notably we've left out global shortcuts
+ * for now), which should make it easy to plug in KDE support later on.
+ */
class Action : public QWidgetAction {
Q_OBJECT
- Q_PROPERTY(QShortcut shortcut READ shortcut WRITE setShortcut)
+ Q_PROPERTY(QKeySequence shortcut READ shortcut WRITE setShortcut)
Q_PROPERTY(bool shortcutConfigurable READ isShortcutConfigurable WRITE setShortcutConfigurable)
Q_FLAGS(ShortcutType)
Action(const QString &text, QObject *parent);
Action(const QIcon &icon, const QString &text, QObject *parent);
- QShortcut shortcut(ShortcutTypes types = ActiveShortcut) const;
- void setShortcut(const QShortcut &shortcut, ShortcutTypes type = ActiveShortcut);
- void setShortcut(const QKeySequence &shortcut, ShortcutTypes type = ActiveShortcut);
+ QKeySequence shortcut(ShortcutTypes types = ActiveShortcut) const;
+ void setShortcut(const QShortcut &shortcut, ShortcutTypes type = ShortcutTypes(ActiveShortcut | DefaultShortcut));
+ void setShortcut(const QKeySequence &shortcut, ShortcutTypes type = ShortcutTypes(ActiveShortcut | DefaultShortcut));
+ bool isShortcutConfigurable() const;
+ void setShortcutConfigurable(bool configurable);
+
+ signals:
+ void triggered(Qt::MouseButtons buttons, Qt::KeyboardModifiers modifiers);
+
+ private:
+ void init();
+
+ private slots:
+ void slotTriggered();
};
-Q_DECLARE_OPERATORS_FOR_FLAGS(ShortcutTypes)
+Q_DECLARE_OPERATORS_FOR_FLAGS(Action::ShortcutTypes)
+
+#endif