// 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 DFBrowserPane_TNamingUsedShapes_H #define DFBrowserPane_TNamingUsedShapes_H #include #include #include #include class QWidget; //! \class DFBrowserPane_TNamingUsedShapes //! \brief The class to manipulate of TNaming_UsedShapes attribute class DFBrowserPane_TNamingUsedShapes : public DFBrowserPane_AttributePane { public: //! Constructor Standard_EXPORT DFBrowserPane_TNamingUsedShapes(); //! Destructor virtual ~DFBrowserPane_TNamingUsedShapes() {} //! Sets cache of sorted references. If it exists, table view values are obtained not from the attibute //! \param theAttributeRefs container of references void SetSortedReferences (NCollection_DataMap >& theAttributeRefs) { myAttributeRefs = theAttributeRefs; } //! Clears cache container of sorted references void ClearSortedReferences() { myAttributeRefs.Clear(); } //! Returns values to fill the table view model //! \param theAttribute a current attribute //! \param theValues a container of values Standard_EXPORT virtual void GetValues (const Handle(TDF_Attribute)& theAttribute, QList& theValues) Standard_OVERRIDE; //! Returns brief attribute information. In general case, it returns GetValues() result. //! \param theAttribute a current attribute //! \param theValues a result list of values Standard_EXPORT virtual void GetShortAttributeInfo (const Handle(TDF_Attribute)& theAttribute, QList& theValues) Standard_OVERRIDE; //! Returns information for the given attribute //! \param theAttribute a current attribute //! \param theRole a role of information, used by tree model (e.g. DisplayRole, icon, background and so on) //! \param theColumnId a tree model column //! \return value, interpreted by tree model depending on the role Standard_EXPORT virtual QVariant GetAttributeInfo (const Handle(TDF_Attribute)& theAttribute, int theRole, int theColumnId) Standard_OVERRIDE; //! Returns container of Attribute references to the attribute //! \param theAttribute a current attribute //! \param theRefAttributes a container of attribute references, to be selected in tree view //! \param theRefPresentation handle of presentation for the references, to be visualized Standard_EXPORT virtual void GetAttributeReferences (const Handle(TDF_Attribute)& theAttribute, NCollection_List& theRefAttributes, Handle(Standard_Transient)& theRefPresentation) Standard_OVERRIDE; protected: //! Defines widths of table columns //! \return container of widths Standard_EXPORT virtual QMap getTableColumnWidths() const; private: NCollection_DataMap > myAttributeRefs; }; #endif