Class GroupElementHandle
- Direct Known Subclasses:
- EmptyGroupElementHandle,- SimpleGroupElementHandle
For our ease-of-use purpose, we support multiple selections across type. Given a collection of elements, user can ask for their common properties(including user property definitions). Also, return a list of values that are identical for all items. Finally, return an indication of whether all elements are of the same type.
 This class also supports a collection of elements contains some objects that
 are not a DesignElementHandle or its subclass. For this case,
 getCommonProperties always returns an empty list.
 
For BIRT UI usage, the attributes view will go blank if the providing elements are not of the same type, the property sheet will show the common properties(including user property definitions).
This handle is mutable, it can be kept. The query results changed as the given elements themselves changed.
Note that the Model special handling of the case where all elements are the same type: in this case, by definition, all BIRT-defined properties are the same. (User-defined properties may differ.)
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected abstract booleanChecks if all elements have extends parents or virtual parents.abstract voidClears values of all common properties(except the extends property) for the given collection of elements.abstract voidClears values of all common properties(except the extends property) for the given collection of elements.final voidclearProperty(String propName) Clears the value of a property on the given collection of elements if the property is a common property shared by each element.abstract ListReturns the common properties shared by the given group of elements(including user properties).final StringgetDisplayProperty(String propName) If the given property is a common property, value will be returned as a display value if all values within the group of elements are equal.abstract ListReturns the list that contains the group of design elements.final StringgetLocalStringProperty(String propName) If the given property is a common property, value will be returned as a string if all values within the group of elements are equal and one of them has a local value.abstract org.eclipse.birt.report.model.core.ModuleReturns the module.abstract ModuleHandleReturns the handle of module.abstract GroupPropertyHandlegetPropertyHandle(String propName) If property is shared by the group of elements, return the correspondingGroupPropertyHandle, otherwise, returnnull.final StringgetStringProperty(String propName) If the given property is a common property, value will be returned as a string if all values within the group of elements are equal.final booleanThis method returnttruein following condition:final booleanThis method returnttruein following condition:protected booleanhasLocalPropertiesIncludeSubElement(DesignElementHandle elementHandle) return true if the Element or subElement has local propertiesabstract booleanReturnstrueif each of the given collection of element extends has a parent.protected abstract booleanisInGroup(DesignElementHandle element) Checks whether theelementis a member ofGroupElementHandle.protected abstract booleanisPropertyReadOnly(String propName) Checks whether a property is read-only in the property sheet.protected abstract booleanisPropertyVisible(String propName) Checks whether a property is visible in the property sheet.abstract booleanIndicates that if the given elements are of the same definition.final IteratorReturns an iterator over the common properties.final voidsetProperty(String propName, Object value) Set the value of a property on the given collection of elements.final voidsetStringProperty(String propName, String value) Set the value of a property to a string .final booleanshareSameValue(String propName) Indicates whether the group of element share the same value for this property.abstract IteratorReturns an iterator over the common properties that are visible.
- 
Constructor Details- 
GroupElementHandlepublic GroupElementHandle()Default constructor.
 
- 
- 
Method Details- 
getElementsReturns the list that contains the group of design elements. Contents of it isDesignElementHandle- Returns:
- the list that contains the group of design elements.
 
- 
getModulepublic abstract org.eclipse.birt.report.model.core.Module getModule()Returns the module.- Returns:
- the module
 
- 
getModuleHandleReturns the handle of module.- Returns:
- the handle of module
 
- 
isSameTypepublic abstract boolean isSameType()Indicates that if the given elements are of the same definition. Elements are considered of same type if their element definitions are identical.If elements have different definitions. Even the same element type, the return value is false. For example, if the list contains anOdaDataSourceand aOdaDataSource, this method returnsfalse.- Returns:
- trueif the given elements are of the same type; return- falseif elements are of different element types, or the given list is empty, or the list contains any object that is not an instance of- DesignElementHandle.
 
- 
getCommonPropertiesReturns the common properties shared by the given group of elements(including user properties). Contents of the list is element property definitions. If elements do not share any common property, return an empty list.- Returns:
- the common properties shared by the given group of elements. If
         elements do not share any common property, or the given list is
         empty, or the list contains any item that is not an instance of
         DesignElementHandle, return an empty list.
 
- 
propertyIteratorReturns an iterator over the common properties. Contents of the iterator are handles to the common properties, type of them isGroupPropertyHandle. Note: remove is not support for the iterator.- Returns:
- an iterator over the common properties. Contents of the iterator are
         handles to the common properties, type of them is
         GroupPropertyHandle
 
- 
visiblePropertyIteratorReturns an iterator over the common properties that are visible. Contents of the iterator are handles to the common properties, type of them isGroupPropertyHandle. Note: remove is not support for the iterator.- Returns:
- an iterator over the common properties. Contents of the iterator are
         handles to the common properties, type of them is
         GroupPropertyHandle
 
- 
isPropertyVisibleChecks whether a property is visible in the property sheet. The visible property is visible in allelements.- Parameters:
- propName- the property name
- Returns:
- trueif it is visible. Otherwise- false.
 
- 
clearLocalPropertiesClears values of all common properties(except the extends property) for the given collection of elements. Clearing a property removes any value set for the property on this element. After this, the element will now inherit the property from its parent element, style, or from the default value for the property. Note: this method clear the values of local properties ( not include sub element)- Throws:
- SemanticException- if the property is not defined on this element
 
- 
clearLocalPropertiesIncludeSubElementClears values of all common properties(except the extends property) for the given collection of elements. Clearing a property removes any value set for the property on this element. After this, the element will now inherit the property from its parent element, style, or from the default value for the property. Note: this method clear all the values of local properties (include sub element)- Throws:
- SemanticException- if the property is not defined on this element
 
- 
isExtendedElementspublic abstract boolean isExtendedElements()Returnstrueif each of the given collection of element extends has a parent. Returnsfalseotherwise. If the collection has no elements, also returnfalse- Returns:
- trueif each of the given collection of element extends has a parent. Returns- falseotherwise. If the collection has no elements, also return- false
 
- 
hasLocalPropertiesForExtendedElementspublic final boolean hasLocalPropertiesForExtendedElements()This method returnttruein following condition:1. The multi selected elements are same type. 2. And the multi selected elements have extends. 3. If any of the given elements has local properties. - Returns:
- trueif the conditions is met.
 
- 
hasLocalPropertiesIncludeSubElementpublic final boolean hasLocalPropertiesIncludeSubElement()This method returnttruein following condition:1. The multi selected elements are same type. 2. And the multi selected elements have extends. 3. If any of the given elements or their subElement has local properties. - Returns:
- trueif the conditions is met.
 
- 
hasLocalPropertiesIncludeSubElementreturn true if the Element or subElement has local properties- Parameters:
- elementHandle-
- Returns:
- true if the Element or his subElement has local properties
 
- 
allExtendedElementsprotected abstract boolean allExtendedElements()Checks if all elements have extends parents or virtual parents.- Returns:
- trueIf all elements have extend parents or virtual parents. Otherwise- false;
 
- 
isPropertyReadOnlyChecks whether a property is read-only in the property sheet. The visible property is read-only in allelements.- Parameters:
- propName- the property name
- Returns:
- trueif it is read-only. Otherwise- false.
 
- 
getPropertyHandleIf property is shared by the group of elements, return the correspondingGroupPropertyHandle, otherwise, returnnull.- Parameters:
- propName- name of the property needs to be handled.
- Returns:
- If the property is a common property among the elements, return the
         corresponding GroupPropertyHandle; Otherwise returnnull.
 
- 
getStringPropertyIf the given property is a common property, value will be returned as a string if all values within the group of elements are equal. If the property is not a common property, returnnull.- Parameters:
- propName- name of the property.
- Returns:
- the value as a string if the property is a common property and all the elements have the same value. Return null if the property is not a common property or elements have different values for this property.
- See Also:
 
- 
getDisplayPropertyIf the given property is a common property, value will be returned as a display value if all values within the group of elements are equal. If the property is not a common property, returnnull.- Parameters:
- propName- name of the property.
- Returns:
- the value as a display value if the property is a common property and all the elements have the same value. Return null if the property is not a common property or elements have different values for this property.
- See Also:
- 
- GroupPropertyHandle#getDisplayProperty()
 
 
- 
getLocalStringPropertyIf the given property is a common property, value will be returned as a string if all values within the group of elements are equal and one of them has a local value. If the property is not a common property or none of them has a local value, returnnull.- Parameters:
- propName- name of the property.
- Returns:
- the value as a string if the property is a common property, all the elements have the same value and one of them has a local value. Return null if the property is not a common property or elements have different values for this property or none of them has a local value.
- See Also:
 
- 
setPropertySet the value of a property on the given collection of elements. If the property provided is not a common property then this method simply return; Otherwise, the value will be set on the group of elements.- Parameters:
- propName- name of the property.
- value- value needs to set.
- Throws:
- SemanticException- if the value is invalid for the property, or the property is undefined on the elements.
- See Also:
 
- 
clearPropertyClears the value of a property on the given collection of elements if the property is a common property shared by each element. Clearing a property removes any value set for the property on this element. After this, the element will now inherit the property from its parent element, style, or from the default value for the property.If the property provided is not a common property then this method simply return, else, the value will be cleared on the group of elements. - Parameters:
- propName- the name of the property to clear.
- Throws:
- SemanticException- if the property is not defined on this element
 
- 
setStringPropertySet the value of a property to a string . If the property provided is not a common property then this method simply return; Else, the string value will be set on the group of element.- Parameters:
- propName- name of the property.
- value- value needs to set.
- Throws:
- SemanticException- if the value is invalid for the property, or the property is undefined on the elements.
 
- 
isInGroupChecks whether theelementis a member ofGroupElementHandle.- Parameters:
- element- the element to check
- Returns:
- trueif the element is in the list, otherwise- false.
 
 
-