File: DFBrowser_AttributePaneStack.hxx

package info (click to toggle)
opencascade 7.9.2%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 301,924 kB
  • sloc: cpp: 1,523,264; tcl: 10,159; cs: 5,173; java: 1,554; sh: 1,342; ansic: 827; xml: 699; makefile: 30; javascript: 22
file content (94 lines) | stat: -rw-r--r-- 3,757 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
// Created on: 2017-06-16
// Created by: Natalia ERMOLAEVA
// Copyright (c) 2017 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and/or modify it under
// the terms of the GNU Lesser General Public License version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.

#ifndef DFBrowser_AttributePaneStack_H
#define DFBrowser_AttributePaneStack_H

#include <inspector/DFBrowser_AttributePaneType.hxx>
#include <inspector/TreeModel_ItemBase.hxx>

#include <Standard.hxx>

#include <Standard_WarningsDisable.hxx>
#include <QMap>
#include <QItemSelection>
#include <QStackedWidget>
#include <QWidget>
#include <Standard_WarningsRestore.hxx>

class DFBrowserPane_AttributePaneAPI;
class DFBrowserPane_AttributePaneSelector;
class DFBrowser_Module;
class DFBrowser_SearchView;
class DFBrowser_TreeLevelView;

class QStackedWidget;
class QWidget;

//! \class DFBrowser_AttributePaneStack
//! \brief Provides work to stacked widget where the current attribute pane is shown.
class DFBrowser_AttributePaneStack : public QObject
{
public:
  //! Constructor
  Standard_EXPORT DFBrowser_AttributePaneStack(QObject* theParent);

  //! Destructor
  virtual ~DFBrowser_AttributePaneStack() {}

  //! Creates a stacked widget
  //! \param theParent a parent widget
  Standard_EXPORT virtual void CreateWidget(QWidget* theParent);

  //! \return the stacked widget
  QWidget* GetWidget() const { return myAttributesStack; }

  //! Fills stack with the information
  //! \param theAttributeTypes a map of attribute type name to information pane
  void SetModule(DFBrowser_Module* theModule) { myModule = theModule; }

  //! Sets the current widget in the stacked control either attribute pane or search view
  //! \param theMode an active mode
  Standard_EXPORT void SetPaneMode(const DFBrowser_AttributePaneType& theMode);

  //! \return an attribute pane, which corresponds the current widget of the stacked widget control
  DFBrowserPane_AttributePaneAPI* GetCurrentPane() const { return myCurrentPane; }

  //! \return tree level view
  DFBrowser_TreeLevelView* GetTreeLevelView() const { return myTreeLevelView; }

  //! \return the search view
  DFBrowser_SearchView* GetSearchView() const { return mySearchView; }

  //! \return the pane selector
  DFBrowserPane_AttributePaneSelector* GetPaneSelector() const { return myPaneSelector; }

  //! Sets an active widget of attribute pane if the pane mode is item view mode.
  //! Gets selection models of this pane and set the models into pane selector
  Standard_EXPORT void SetCurrentItem(const QModelIndex& theIndex);

protected:
  DFBrowserPane_AttributePaneAPI*      myCurrentPane;  //!< active pane if mode is item view mode
  DFBrowserPane_AttributePaneSelector* myPaneSelector; //!< pane selector filled by the active pane
  QStackedWidget*                      myAttributesStack; //!< container of already created panes
  DFBrowser_Module*                    myModule;          //!< the current module
  DFBrowser_TreeLevelView* myTreeLevelView; //!< view of objects from one level of tree view
  DFBrowser_SearchView*    mySearchView;    //!< view of search control
  QWidget*                 myEmptyWidget; //!< an empty widget when nothing is selected in tree view
  DFBrowser_AttributePaneType
    myPaneMode; //!< the current pane mode, either item view or search view
};

#endif