Class Treecol
- java.lang.Object
-
- All Implemented Interfaces:
java.io.Serializable
,java.lang.Cloneable
,Component
,Scope
,ComponentCtrl
public class Treecol extends HeaderElement
A treecol.Default
getZclass()
: z-treecol (since 5.0.0)- Author:
- tomyeh
- See Also:
- Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.zkoss.zul.impl.LabelImageElement
LabelImageElement.ExtraCtrl
-
Nested classes/interfaces inherited from class org.zkoss.zk.ui.AbstractComponent
AbstractComponent.Children, AbstractComponent.ForwardInfo, AbstractComponent.TargetInfo
-
-
Field Summary
-
Fields inherited from class org.zkoss.zk.ui.HtmlBasedComponent
_zclass
-
Fields inherited from interface org.zkoss.zk.ui.Component
APPLICATION_SCOPE, COMPONENT_SCOPE, DESKTOP_SCOPE, PAGE_SCOPE, REQUEST_SCOPE, SESSION_SCOPE, SPACE_SCOPE
-
Fields inherited from interface org.zkoss.zk.ui.sys.ComponentCtrl
AFTER_CHILD_ADDED, AFTER_CHILD_REMOVED, AFTER_PAGE_ATTACHED, AFTER_PAGE_DETACHED, AFTER_PARENT_CHANGED, CE_BUSY_IGNORE, CE_DUPLICATE_IGNORE, CE_IMPORTANT, CE_NON_DEFERRABLE, CE_REPEAT_IGNORE
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
beforeParentChanged(Component parent)
Default: If parent is null, execute the @Destroy method if any.java.lang.Object
clone()
Clones the component.int
getColumnIndex()
Returns the column index, starting from 0.int
getMaxlength()
Returns the maximal length of each item's label.java.util.Comparator<?>
getSortAscending()
Returns the ascending sorter, or null if not available.java.util.Comparator<?>
getSortDescending()
Returns the descending sorter, or null if not available.java.lang.String
getSortDirection()
Returns the sort direction.Tree
getTree()
Returns the tree that it belongs to.java.lang.String
getZclass()
Returns the ZK Cascading Style class for this component.void
onSort()
It invokessort(boolean)
to sort list items and maintaingetSortDirection()
.protected void
renderProperties(ContentRenderer renderer)
Renders the content of this component, excluding the enclosing tags and children.void
setMaxlength(int maxlength)
Sets the maximal length of each item's label.void
setSort(java.lang.String type)
Sets the type of the sorter.void
setSortAscending(java.lang.String clsnm)
Sets the ascending sorter with the class name, or null for no sorter for the ascending order.void
setSortAscending(java.util.Comparator<?> sorter)
Sets the ascending sorter, or null for no sorter for the ascending order.void
setSortDescending(java.lang.String clsnm)
Sets the descending sorter with the class name, or null for no sorter for the descending order.void
setSortDescending(java.util.Comparator<?> sorter)
Sets the descending sorter, or null for no sorter for the descending order.void
setSortDirection(java.lang.String sortDir)
Sets the sort direction.boolean
sort(boolean ascending)
Sorts the treechildren (Treeitem
) based ongetSortAscending()
andgetSortDescending()
, ifgetSortDirection()
doesn't matches the ascending argument.boolean
sort(boolean ascending, boolean force)
-
Methods inherited from class org.zkoss.zul.impl.HeaderElement
evalCSSFlex, getAlign, getValign, setAlign, setValign
-
Methods inherited from class org.zkoss.zul.impl.LabelImageElement
getExtraCtrl, getHoverImage, getHoverImageContent, getIconSclass, getIconSclasses, getIconTooltip, getIconTooltips, getImage, getImageContent, getPropertyAccess, isImageAssigned, setHoverImage, setHoverImageContent, setHoverImageContent, setIconSclass, setIconSclasses, setIconTooltip, setIconTooltips, setImage, setImageContent, setImageContent
-
Methods inherited from class org.zkoss.zul.impl.LabelElement
getLabel, renderCrawlable, setLabel
-
Methods inherited from class org.zkoss.zul.impl.XulElement
getContext, getCtrlKeys, getPopup, getTooltip, setContext, setContext, setContextAttributes, setCtrlKeys, setPopup, setPopup, setPopupAttributes, setTooltip, setTooltip, setTooltipAttributes
-
Methods inherited from class org.zkoss.zk.ui.HtmlBasedComponent
addSclass, focus, getAction, getClientAction, getDraggable, getDroppable, getHeight, getHflex, getLeft, getRenderdefer, getSclass, getStyle, getTabindex, getTabindexInteger, getTooltiptext, getTop, getVflex, getWidth, getZindex, getZIndex, removeSclass, removeSclass, service, setAction, setClass, setClientAction, setDraggable, setDroppable, setFocus, setHeight, setHeight0, setHeightDirectly, setHflex, setHflex0, setHflexDirectly, setLeft, setLeftDirectly, setRenderdefer, setSclass, setStyle, setTabindex, setTabindex, setTooltiptext, setTop, setTopDirectly, setVflex, setVflex0, setVflexDirectly, setWidth, setWidth0, setWidthDirectly, setZclass, setZindex, setZIndex, setZIndexDirectly
-
Methods inherited from class org.zkoss.zk.ui.AbstractComponent
addAnnotation, addCallback, addClientEvent, addEventHandler, addEventListener, addEventListener, addForward, addForward, addForward, addForward, addMoved, addRedrawCallback, addScopeListener, addShadowRoot, addShadowRootBefore, addSharedEventHandlerMap, appendChild, applyProperties, beforeChildAdded, beforeChildRemoved, destroyIndexCacheMap, detach, didActivate, didActivate, didDeserialize, didDeserialize, disableBindingAnnotation, disableClientUpdate, disableHostChanged, enableBindingAnnotation, enableHostChanged, getAnnotatedProperties, getAnnotatedPropertiesBy, getAnnotation, getAnnotations, getAnnotations, getAttribute, getAttribute, getAttribute, getAttributeOrFellow, getAttributes, getAttributes, getAuService, getAutag, getCallback, getChildren, getClientAttribute, getClientDataAttribute, getClientEvents, getDefaultMold, getDefinition, getDesktop, getEventHandler, getEventHandlerNames, getEventListenerMap, getEventListeners, getFellow, getFellow, getFellowIfAny, getFellowIfAny, getFellows, getFirstChild, getForwards, getId, getIndexCacheMap, getLastChild, getMold, getNextSibling, getPage, getParent, getPreviousSibling, getRedrawCallback, getRoot, getShadowFellowIfAny, getShadowRoots, getShadowVariable, getShadowVariable, getShadowVariable0, getSpaceOwner, getSpecialRendererOutput, getStubonly, getSubBindingAnnotationCount, getTemplate, getTemplateNames, getUuid, getWidgetAttributeNames, getWidgetClass, getWidgetListener, getWidgetListenerNames, getWidgetOverride, getWidgetOverrideNames, hasAttribute, hasAttribute, hasAttribute, hasAttributeOrFellow, hasBindingAnnotation, hasFellow, hasFellow, hasSubBindingAnnotation, initIndexCacheMap, insertBefore, invalidate, isChildable, isDisabledHostChanged, isInitialized, isInvalidated, isListenerAvailable, isVisible, onChildAdded, onChildRemoved, onPageAttached, onPageDetached, onParentChanged, onWrongValue, query, queryAll, redraw, redrawChildren, removeAttribute, removeAttribute, removeAttribute, removeCallback, removeChild, removeEventListener, removeForward, removeForward, removeRedrawCallback, removeScopeListener, removeShadowRoot, render, render, render, renderPropertiesOnly, replace, response, response, response, service, sessionDidActivate, sessionWillPassivate, setAttribute, setAttribute, setAttribute, setAuService, setAutag, setClientAttribute, setClientDataAttribute, setDefinition, setDefinition, setId, setMold, setPage, setPageBefore, setParent, setStubonly, setStubonly, setSubBindingAnnotationCount, setTemplate, setVisible, setVisibleDirectly, setWidgetClass, setWidgetListener, setWidgetOverride, smartUpdate, smartUpdate, smartUpdate, smartUpdate, smartUpdate, smartUpdate, smartUpdate, smartUpdate, smartUpdate, smartUpdateWidgetListener, smartUpdateWidgetOverride, toString, updateByClient, updateSubBindingAnnotationCount, willPassivate, willPassivate, willSerialize, willSerialize
-
-
-
-
Method Detail
-
getTree
public Tree getTree()
Returns the tree that it belongs to.
-
getSortDirection
public java.lang.String getSortDirection()
Returns the sort direction.- Since:
- 5.0.6
Default: "natural".
-
setSortDirection
public void setSortDirection(java.lang.String sortDir) throws WrongValueException
Sets the sort direction. This does not sort the data, it only serves as an indicator as to how the tree is sorted. (unless the tree has "autosort" attribute)If you use
sort(boolean)
to sort treechildren (Treeitem
), the sort direction is maintained automatically. If you want to sort it in customized way, you have to set the sort direction manually.- Parameters:
sortDir
- one of "ascending", "descending" and "natural"- Throws:
WrongValueException
- Since:
- 5.0.6
-
setSort
public void setSort(java.lang.String type) throws java.lang.ClassNotFoundException, java.lang.InstantiationException, java.lang.IllegalAccessException
Sets the type of the sorter. You might specify either "auto", "auto(FIELD_NAME1[,FIELD_NAME2] ...)", "auto(number)" or "none".If "client" or "client(number)" is specified, the sort functionality will be done by Javascript at client without notifying to server, that is, the order of the component in the row is out of sync.
- "client" : it is treated by a string
- "client(number)" : it is treated by a number
Note: client sorting cannot work in model case.
If "auto" is specified,
setSortAscending(java.util.Comparator<?>)
and/orsetSortDescending(java.util.Comparator<?>)
are called withTreeitemComparator
, ifgetSortDescending()
and/orgetSortAscending()
are null. If you assigned a comparator to them, it won't be affected. The auto created comparator is case-insensitive.If "auto(FIELD_NAME1, FIELD_NAME2, ...)" is specified,
setSortAscending(java.util.Comparator<?>)
and/orsetSortDescending(java.util.Comparator<?>)
are called withFieldComparator
, ifgetSortDescending()
and/orgetSortAscending()
are null. If you assigned a comparator to them, it won't be affected. The auto created comparator is case-sensitive.If "auto(LOWER(FIELD_NAME))" or "auto(UPPER(FIELD_NAME))" is specified,
setSortAscending(java.util.Comparator<?>)
and/orsetSortDescending(java.util.Comparator<?>)
are called withFieldComparator
, ifgetSortDescending()
and/orgetSortAscending()
are null. If you assigned a comparator to them, it won't be affected. The auto created comparator is case-insensitive.If "auto(number)" is specified,
setSortAscending(java.util.Comparator<?>)
and/orsetSortDescending(java.util.Comparator<?>)
are called withArrayComparator
. Notice that the data must be an array and the number-th element must be comparable (Comparable
).If "none" is specified, both
setSortAscending(java.util.Comparator<?>)
andsetSortDescending(java.util.Comparator<?>)
are called with null. Therefore, no more sorting is available to users for this column.- Throws:
java.lang.IllegalAccessException
java.lang.InstantiationException
java.lang.ClassNotFoundException
- Since:
- 5.0.6
-
getSortAscending
public java.util.Comparator<?> getSortAscending()
Returns the ascending sorter, or null if not available.- Since:
- 5.0.6
-
setSortAscending
public void setSortAscending(java.util.Comparator<?> sorter)
Sets the ascending sorter, or null for no sorter for the ascending order.- Parameters:
sorter
- the comparator used to sort the ascending order.- Since:
- 5.0.6
-
setSortAscending
public void setSortAscending(java.lang.String clsnm) throws java.lang.ClassNotFoundException, java.lang.InstantiationException, java.lang.IllegalAccessException
Sets the ascending sorter with the class name, or null for no sorter for the ascending order.- Throws:
java.lang.ClassNotFoundException
java.lang.InstantiationException
java.lang.IllegalAccessException
- Since:
- 5.0.6
-
getSortDescending
public java.util.Comparator<?> getSortDescending()
Returns the descending sorter, or null if not available.- Since:
- 5.0.6
-
setSortDescending
public void setSortDescending(java.util.Comparator<?> sorter)
Sets the descending sorter, or null for no sorter for the descending order.- Parameters:
sorter
- the comparator used to sort the ascending order.- Since:
- 5.0.6
-
setSortDescending
public void setSortDescending(java.lang.String clsnm) throws java.lang.ClassNotFoundException, java.lang.InstantiationException, java.lang.IllegalAccessException
Sets the descending sorter with the class name, or null for no sorter for the descending order.- Throws:
java.lang.ClassNotFoundException
java.lang.InstantiationException
java.lang.IllegalAccessException
- Since:
- 5.0.6
-
getMaxlength
public int getMaxlength()
Returns the maximal length of each item's label.Default: 0 (no limit).
-
setMaxlength
public void setMaxlength(int maxlength)
Sets the maximal length of each item's label.Default: 0 (no limit).
Notice that maxlength will be applied to this header and all listcell of the same column.
-
getColumnIndex
public int getColumnIndex()
Returns the column index, starting from 0.
-
sort
public boolean sort(boolean ascending)
Sorts the treechildren (Treeitem
) based ongetSortAscending()
andgetSortDescending()
, ifgetSortDirection()
doesn't matches the ascending argument.It checks
getSortDirection()
to see whether sorting is required, and updatesetSortDirection(java.lang.String)
after sorted. For example, ifgetSortDirection()
returns "ascending" and the ascending argument is false, nothing happens. To enforce the sorting, you can invokesetSortDirection(java.lang.String)
with "natural" before invoking this method. Alternatively, you can invokesort(boolean, boolean)
instead.It sorts the rows by use of
Components.sort(java.util.List<? extends org.zkoss.zk.ui.Component>, java.util.Comparator<? super org.zkoss.zk.ui.Component>)
, if not live data (i.e.,Tree.getModel()
is null).On the other hand, it invokes
Sortable.sort(java.util.Comparator<T>, boolean)
to sort the treechildren, if live data (i.e.,Tree.getModel()
is not null). In other words, if you use the live data, you have to implementSortable
to sort the live data explicitly.- Parameters:
ascending
- whether to usegetSortAscending()
. If the corresponding comparator is not set, it returns false and does nothing.- Returns:
- whether the rows are sorted.
- Throws:
UiException
- ifTree.getModel()
is not null butSortable
is not implemented.- Since:
- 5.0.6
-
sort
public boolean sort(boolean ascending, boolean force)
- Parameters:
ascending
- whether to usegetSortAscending()
. If the corresponding comparator is not set, it returns false and does nothing.force
- whether to enforce the sorting no matter what the sort direction (getSortDirection()
) is. If false, this method is the same assort(boolean)
.- Returns:
- whether the treechildren are sorted.
- Since:
- 5.0.6
-
onSort
public void onSort()
It invokessort(boolean)
to sort list items and maintaingetSortDirection()
.- Since:
- 5.0.6
-
getZclass
public java.lang.String getZclass()
Description copied from class:HtmlBasedComponent
Returns the ZK Cascading Style class for this component. It usually depends on the implementation of the mold (AbstractComponent.getMold()
).Default: null (the default value depends on element).
HtmlBasedComponent.setZclass(java.lang.String)
) will completely replace the default style of a component. In other words, the default style of a component is associated with the default value ofHtmlBasedComponent.getZclass()
. Once it is changed, the default style won't be applied at all. If you want to perform small adjustments, useHtmlBasedComponent.setSclass(java.lang.String)
instead.- Overrides:
getZclass
in classHtmlBasedComponent
- See Also:
HtmlBasedComponent.getSclass()
-
renderProperties
protected void renderProperties(ContentRenderer renderer) throws java.io.IOException
Description copied from class:HtmlBasedComponent
Renders the content of this component, excluding the enclosing tags and children.- Overrides:
renderProperties
in classHeaderElement
- Throws:
java.io.IOException
-
beforeParentChanged
public void beforeParentChanged(Component parent)
Description copied from class:AbstractComponent
Default: If parent is null, execute the @Destroy method if any.- Specified by:
beforeParentChanged
in interfaceComponentCtrl
- Overrides:
beforeParentChanged
in classAbstractComponent
- Parameters:
parent
- the new parent. If null, it means detachment.- See Also:
ComponentCtrl.beforeParentChanged(org.zkoss.zk.ui.Component)
-
clone
public java.lang.Object clone()
Description copied from interface:Component
Clones the component. All of its children and descendants are cloned. Also, ID are preserved.- Specified by:
clone
in interfaceComponent
- Overrides:
clone
in classLabelImageElement
- Returns:
- the new component. Notice that it doesn't belong to any page, nor desktop. It doesn't have a parent, either.
-
-