pqProxyGroupMenuManager.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: ParaView
4  Module: pqProxyGroupMenuManager.h
5 
6  Copyright (c) 2005,2006 Sandia Corporation, Kitware Inc.
7  All rights reserved.
8 
9  ParaView is a free software; you can redistribute it and/or modify it
10  under the terms of the ParaView license version 1.2.
11 
12  See License_v1.2.txt for the full ParaView license.
13  A copy of this license can be obtained by contacting
14  Kitware Inc.
15  28 Corporate Drive
16  Clifton Park, NY 12065
17  USA
18 
19 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR
23 CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
26 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
27 LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
28 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
29 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 
31 ========================================================================*/
32 #ifndef pqProxyGroupMenuManager_h
33 #define pqProxyGroupMenuManager_h
34 
36 #include <QMenu>
37 
38 class vtkPVXMLElement;
39 class vtkSMProxy;
40 
47 {
48  Q_OBJECT
49  typedef QObject Superclass;
50 
51 public:
61  QMenu* menu, const QString& resourceTagName, bool supportsQuickLaunch = true);
62  ~pqProxyGroupMenuManager() override;
63 
67  QMenu* menu() const { return static_cast<QMenu*>(this->parent()); }
68 
73  void setRecentlyUsedMenuSize(unsigned int val) { this->RecentlyUsedMenuSize = val; }
74 
75  unsigned int recentlyUsedMenuSize() const { return this->RecentlyUsedMenuSize; }
76 
80  QWidget* widgetActionsHolder() const;
81 
85  QList<QAction*> actions() const;
86 
90  vtkSMProxy* getPrototype(QAction* action) const;
91 
95  void addProxy(const QString& xmlgroup, const QString& xmlname);
96 
100  void removeProxy(const QString& xmlgroup, const QString& xmlname);
101 
106  QStringList getToolbarCategories() const;
107 
111  QList<QAction*> actions(const QString& category);
112 
116  QList<QAction*> actionsInToolbars();
117 
121  bool hideForTests(const QString& category) const;
122 
131  void addProxyDefinitionUpdateListener(const QString& proxyGroupName);
132  void removeProxyDefinitionUpdateListener(const QString& proxyGroupName);
133 
138  bool supportsQuickLaunch() const { return this->SupportsQuickLaunch; }
139 
140  void setEnableFavorites(bool enable) { this->EnableFavorites = enable; }
141 
142  QMenu* getFavoritesMenu();
143 
147  QString categoryLabel(const QString& category);
148 
149 public Q_SLOTS:
156  void loadConfiguration(vtkPVXMLElement*);
157 
161  void lookForNewDefinitions();
162 
166  void removeProxyDefinitionUpdateObservers();
167 
171  void addProxyDefinitionUpdateObservers();
172 
176  void setEnabled(bool enable);
177 
182  void populateMenu();
183 
184 Q_SIGNALS:
185  void triggered(const QString& group, const QString& name);
186 
191  void menuPopulated();
192 
193 protected Q_SLOTS:
194  void triggered();
195  void quickLaunch();
196  void switchActiveServer();
197  void updateMenuStyle();
198 
203  void populateRecentlyUsedMenu();
204 
209  void populateFavoritesMenu();
210 
211 protected:
215  bool Enabled;
217 
218  void loadRecentlyUsedItems();
219  void saveRecentlyUsedItems();
220 
224  void loadFavoritesItems();
225 
229  QAction* getAction(const QString& pgroup, const QString& proxyname);
230 
231  QAction* getAddToCategoryAction(const QString& path);
232 
233 private:
234  Q_DISABLE_COPY(pqProxyGroupMenuManager)
235 
236  class pqInternal;
237  pqInternal* Internal;
238  bool SupportsQuickLaunch;
239 };
240 
241 #endif
unsigned int recentlyUsedMenuSize() const
void setRecentlyUsedMenuSize(unsigned int val)
When size>0 a recently used category will be added to the menu.
pqProxyGroupMenuManager is a menu-populator that fills up a menu with proxies defined in an XML confi...
void setEnableFavorites(bool enable)
bool supportsQuickLaunch() const
Returns true if the pqProxyGroupMenuManager has been registered with quick-launch mechanism maintaine...
#define PQAPPLICATIONCOMPONENTS_EXPORT
name
proxy for a VTK object(s) on a server
Definition: vtkSMProxy.h:152
This is used by vtkPVXMLParser to represent an XML document starting at the root element.
QMenu * menu() const
Access the menu.