+ /// Return the attribute values wrapped in a list of viewer presentations
+ /// \return a list of viewer presentations, which contains an attribute result and
+ /// a shape. If the attribute do not uses the shape, it is empty
+ virtual QList<ModuleBase_ViewerPrs> getAttributeSelection() const;
+
+ /// Fills the list control by the attribute values
+ void updateSelectionList();
+
+ /// Converts the XML defined type choice to the validator type
+ /// For example, the "Edges" is converted to "edge"
+ std::string validatorType(const QString& theType) const;
+
+protected:
+ /// Returns attribute indices selected in the widget selection list
+ /// \param theIndices a list of indices
+ void getSelectedAttributeIndices(std::set<int>& theIndices);
+
+ /// Gets the feature attribute and fill a list of viewer presentation for the attribute
+ /// indices. If the the container of indices is empty, it returns all objects.
+ /// \param theAttributeIds indices in attribute list to be returned
+ /// \param theValues the result presentations, filled with object and shape of an attribute item
+ void convertIndicesToViewerSelection(std::set<int> theAttributeIds,
+ QList<ModuleBase_ViewerPrs>& theValues) const;
+protected:
+ /// List control
+ QListWidget* myListControl;
+
+ /// Combobox of types
+ QComboBox* myTypeCombo;