/**************************************************************************** ** ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). ** Contact: Nokia Corporation (qt-info@nokia.com) ** ** This file is part of the Qt Designer of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** No Commercial Usage ** This file contains pre-release code and may not be distributed. ** You may use this file in accordance with the terms and conditions ** contained in the either Technology Preview License Agreement or the ** Beta Release License Agreement. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Nokia gives you certain ** additional rights. These rights are described in the Nokia Qt LGPL ** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this ** package. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3.0 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 3.0 requirements will be ** met: http://www.gnu.org/copyleft/gpl.html. ** ** If you are unsure which license is appropriate for your use, please ** contact the sales department at http://www.qtsoftware.com/contact. ** $QT_END_LICENSE$ ** ****************************************************************************/ // // W A R N I N G // ------------- // // This file is not part of the Qt API. It exists for the convenience // of Qt Designer. This header // file may change from version to version without notice, or even be removed. // // We mean it. // #ifndef ACTIONEDITOR_H #define ACTIONEDITOR_H #include "shared_global_p.h" #include #include QT_BEGIN_NAMESPACE class QDesignerPropertyEditorInterface; class QDesignerSettingsInterface; class QMenu; class QActionGroup; class QSignalMapper; class QItemSelection; class QListWidget; class QPushButton; class QLineEdit; class QToolButton; namespace qdesigner_internal { class ActionView; class ResourceMimeData; class QDESIGNER_SHARED_EXPORT ActionEditor: public QDesignerActionEditorInterface { Q_OBJECT public: explicit ActionEditor(QDesignerFormEditorInterface *core, QWidget *parent = 0, Qt::WindowFlags flags = 0); virtual ~ActionEditor(); QDesignerFormWindowInterface *formWindow() const; virtual void setFormWindow(QDesignerFormWindowInterface *formWindow); virtual QDesignerFormEditorInterface *core() const; QAction *actionNew() const; QAction *actionDelete() const; QString filter() const; virtual void manageAction(QAction *action); virtual void unmanageAction(QAction *action); static QString actionTextToName(const QString &text, const QString &prefix = QLatin1String("action")); // Utility to create a configure button with menu for usage on toolbars static QToolButton *createConfigureMenuButton(const QString &t, QMenu **ptrToMenu); public slots: void setFilter(const QString &filter); void mainContainerChanged(); private slots: void slotCurrentItemChanged(QAction *item); void slotSelectionChanged(const QItemSelection& selected, const QItemSelection& deselected); void editAction(QAction *item); void editCurrentAction(); void navigateToSlotCurrentAction(); void slotActionChanged(); void slotNewAction(); void slotDelete(); void resourceImageDropped(const QString &path, QAction *action); void slotContextMenuRequested(QContextMenuEvent *, QAction *); void slotViewMode(QAction *a); void slotSelectAssociatedWidget(QWidget *w); void slotCopy(); void slotCut(); void slotPaste(); signals: void itemActivated(QAction *item); // Context menu for item or global menu if item == 0. void contextMenuRequested(QMenu *menu, QAction *item); private: typedef QList ActionList; void deleteActions(QDesignerFormWindowInterface *formWindow, const ActionList &); void copyActions(QDesignerFormWindowInterface *formWindow, const ActionList &); void restoreSettings(); void saveSettings(); void updateViewModeActions(); QDesignerFormEditorInterface *m_core; QPointer m_formWindow; QListWidget *m_actionGroups; ActionView *m_actionView; QAction *m_actionNew; QAction *m_actionEdit; QAction *m_actionNavigateToSlot; QAction *m_actionCopy; QAction *m_actionCut; QAction *m_actionPaste; QAction *m_actionSelectAll; QAction *m_actionDelete; QActionGroup *m_viewModeGroup; QAction *m_iconViewAction; QAction *m_listViewAction; QString m_filter; QWidget *m_filterWidget; QSignalMapper *m_selectAssociatedWidgetsMapper; }; } // namespace qdesigner_internal QT_END_NAMESPACE #endif // ACTIONEDITOR_H