MetabaseTreeCombo

Inheritance Hierarchy

          IComponent

          IControl

          ITreeControl

          ITreeCombo

          IMetabaseTreeCombo

          MetabaseTreeCombo

Description

The MetabaseTreeCombo component is used to display the repository object tree as a drop-down list.

Working with the Component

The component display nothing by default. To set the directory, which contents is displayed in the component, use the Root property. The list of displayed objects can be changed by setting up filtering in the Filters property. Each tree element is a link to the corresponding repository object. To get information on corresponding object, cast the tree node to the IMetabaseTreeListNode interface (transform the object using the As keyword) and get the ObjectDescriptor property.

The main list of properties and methods of this component is inherited from TreeCombo, therefore working with this component is identical to working with the tree of the TreeCombo component. The methods that are used to change the element hierarchy are not supported in this component.

The button can be used to reset tree elements selection.

NOTE. The drop-down list of elements can be resized by dragging its right, left or bottom border with the mouse. The minimum width of the drop-down list equals to the component width.

Element Search

The following types of search are available in the expanded drop-down list:

If the search has been successful, the cursor will focus on the found element. Selection state depends on value of the FindMode property. Depending on the  chosen multiple selection mode an element is added to selection either by selecting it using the SPACE key or selecting it with the mouse cursor while holding down the CTRL key.

It is also available to search for elements on the collapsed component drop-down list. When the component is focused, entering a set of characters creates a list of elements, which names contain this set of characters:

Elements are selected using the above-given method, depending on the value specified in the SelectionMode property. Closing this dialog box applies the selection to the component.

It is available to search for one or several words based on segments in any mode. To do this, separate the search combinations with whitespace character. The word order in the names of search elements is ignored.

Data Sorting

Data sorting is available if the ShowColumnHeaders, Sorted and ColumnClick properties are set to True, and the SortType property has a value other than None.

In the form execution mode, click the header of the appropriate column to sort data by it. The data is sorted in the ascending direction. Double-clicking changes the sorting direction. To sort data by multiple columns, click the headers of the required columns while holding down CTRL key. The sorting order is as follows: the column, which header is clicked last, is sorted last.

Sorting can also be set up in the Sorting specialized dialog box:

This dialog box opens when selecting the appropriate item if the context menu opened from the column header area.

NOTE. The context menu item is available if the ShowColumnHeaders and Sorted properties are set to True, and the SortType property has a value other than None.

Move the columns that are used to sort by to the selection list. The and buttons are used to change sorting direction by the selected column. The and buttons are used to change the sorting order. Columns at the top of the list are sorted first.

In the Fore language, to apply sorting, set the Sorted property to True, and set the SortType property to the value other than None. The column, which data is sorted, is specified in the SortColumn property. Sorting direction is determined in the SortAscending property of the corresponding column.

Sorting can also be managed by the Sort and SortDefault methods.

Component Filters

To set up filtering for objects displayed in the component tree, execute one of the following operations:

This dialog box contains a list of filters applied to the component.

The list is displayed as a table made up of two columns:

The dialog box can be used to create new filters, or edit and delete existing filters. Multiple filters can be selected in the table, these selected filters can only be deleted.

Filter description can be edited. To do this, select the required filter and click the description with the mouse. After a few seconds a dialog box for editing a description opens. The F2 key can also be used for this purpose.

Creating an Object Filter

To create a new object filter, execute one of the following operations:

In the dialog box that opens, select the type of the created filter. The available types are:

In the class tree, select object classes, which are available when this filter is used. Use the Show Subclasses checkbox to disable displaying of additional object classes in the tree.

In the Create the Following Type of Filter box specify how you want the filter to be saved:

Clicking the OK button creates a new filter (filters) for the selected object classes.

Editing Object Filter

To edit a filter, execute one of the following operations:

Depending on the type of created filter (a separate filter for a class (subclass) or a composite filter), the dialog box for filter editing opens:

Separate filter for the class (subclass).

Composite filter

The dialog box can be used to change the object class (subclass or their combination for a composite filter), for which the filter is created, or modify filter description. Clicking the OK button saves the changes.

Deleting Filter

To delete a filter (filters), select it in the table and execute one of the following operations:

The filter is deleted.

Example

Properties of the MetabaseTreeCombo Component

  Property name Brief description
The Align property determines behavior of the component when its parent component is resized.
The AllowDrag property determines whether an object can be dragged from the component.
The AllowDrop property determines whether the component can accept a dragged object.
Outdated. Use  SelectionMode.
The Anchors property returns settings that determine the percentage of the size change for the current component when the parent component is resized.
The AnimationType property determines a type of animation to be used when component's list is expanded.
The AutoCheckParent property determines whether the parent nodes of the component automatically receive an indefinite state if not all of the child elements are selected.
The AutoUpdateInfo property determines whether information on selection is automatically refreshed in the component editor.
The BorderStyle property determines a component border style.
The Brush property determines the brush that is used to fill component area.
The CancelOnEscape property determines whether selection is canceled, and the list is closed when the ESCAPE key is pressed.
The Checkboxes property determines whether elements have checkboxes.
The CheckedObjects property returns the collection of descriptions for objects, which checkboxes are set in the component.
The ClientHeight property is used to receive or specify the height of the component’s client area.
The ClientWidth property is used to receive or specify the width of the component’s client area.
The CloseOnClick property determines whether the list is automatically closed when one of the elements is selected with a mouse click.
The CloseOnEnter property determines whether the list is closed, and the selection is saved when the ENTER key is pressed.
The Color property determines a component background color.
The ColumnClick property determines whether column headers can be displayed as buttons.
The Columns property returns the component columns collection.
The ComponentCount property returns the number of child components.
The Components property returns the child component.
The Cursor property determines the look of the cursor over the component.
The Data property is used to store any custom data.
The DelayedFill property determines how an object tree is built in a component.
The DisplayMode property determines how objects are displayed in a component tree.
The Dropped property returns the status of the drop-down list.
The DroppedListHeight property determines height of the component's drop-down list.
The DroppedListWidth property determines width of the component's drop-down list.
The DroppedPopupMenu property determines the context menu, which is opened in the area of the components's drop-down list.
The DropTargetNode property determines the component node, over which the user is currently dragging another node.
The Enabled property determines whether the component is available for the user.
The EnableFindDialog property determines whether the standard element search dialog box is opened on pressing CTRL+F or F3.
The EnableInfotips property determines whether object information is displayed in a tooltip.
The FindEditVisible property determines whether a search field is displayed when the component drop-down list is expanded.
The FindMode property determines a mode of marking found elements.
The Filters property returns the collection of filters that are used to filter objects displayed in the component.
The FilterStyle property determines a mode of creating a tree of filtered elements.
The Focused property returns True if the focus is set on the component.
The FocusedNode property determines the node, which is currently focused.
The Font property determines the set of characteristics describing the font that is used to display text.
The GridLines property determines whether a grid is displayed.
The HeaderMenu property determines the context menu, which is called by clicking the header of the component column using the additional mouse button.
The Height property determines component height.
The HelpContext property determines a unique index for the context help section for this component.
The HideSelection property determines whether the selected component element remains selected when the focus moves to another component element.
The HighlightTrack property determines whether to highlight element on mouseover.
The Hint property determines a component tooltip text.
The HotTrack property determines whether the elements are underlined on mouseover.
The HotTrackAutoExpand property determines whether the state of child elements tree is changed on clicking the selected element.
The Images property contains a list of images used for nodes rendering.
The InnerRoot property returns parameters of inner root node of the tree.
The Left property determines the coordinate of the left border of the component.
The Locked property determines whether it is possible to change selection and edit component elements.
The Metabase property determines a repository associated with a component.
Outdated. Use SelectionMode.
The Name property determines a component name.
The Nodes property returns the component elements collection.
The Parent property determines a parent component.
The ParentColor property determines whether the component inherits the color of the parent component.
The ParentFont property determines whether the component uses the font of the parent component.
The ParentShowHint property determines whether a tooltip is displayed.
The PopupMenu property determines the context menu to be displayed on right-click on the component.
The ReadOnly property determines whether elements are available for editing.
The Root property determines the root directory, which contents is displayed in the component.
The RowSelect property determines whether the whole row is highlighted when an element is selected.
The Scrolls property returns parameters of component's scrollbars.
The Selected property determines the last selected tree element.
The SelectedObjects property returns the collection of descriptions for objects selected in the component.
The Selection property returns the tree element selection.
The SelectionMode property determines a mode of selecting component elements.
The ShowButtons property determines whether expand/collapse child elements buttons are displayed.
The ShowColumnHeaders property determines whether column headers are displayed.
The ShowEditImage property determines whether the icon element is displayed in the component editor.
The ShowEmptyFolders property determines whether empty folders are displayed.
The ShowHint property enables and disables showing a component tooltip.
The ShowHints property determines whether tooltips are displayed when the mouse cursor hovers over elements.
The ShowInternalObjects property determines whether internal objects are displayed in the repository object tree.
The ShowLines property determines whether the line connecting a node with its children is displayed.
The ShowShortCuts property determines whether labels are displayed in the component element tree.
The SortColumn property determines index of the column, by which sorting is executed.
The Sorted property determines whether it is possible to execute sorting by the column specified in the SortColumn property.
The SortType property determines a component sorting type.
The StateImages property determines a source of icons for the selected elements.
The TabOrder property determines the component position in the tab order.
The TabStop property determines whether the component is focused when the TAB key is pressed.
The Tag property is not used by the compiler. The user can change the value of the Tag property and use it as he wishes.
The Text property determines the row identifying a component for the user.
The Top property determines the coordinate of the top border of the component.
The Visible property determines visibility of the component during execution.
The Width property determines component width.

Methods of the MetabaseTreeCombo Component

  Method name Brief description
The AdjustDroppedListWidth property adjusts width of the component's drop-down list.
The AdjustWidth method is used to automatically fit a column based on its contents.
The BringToFront method brings a component to front.
The ClientToScreen method converts the coordinates of a point specified relative to the component coordinate system into screen coordinates.
The DoDragDrop method enables to start dragging operation.
The DropDown method expands the drop-down list.
The FindByDescriptor method is used to search for a node of the component tree matching the specified repository object.
The FindItemByKey method is used to find a node in a component tree based on a repository object key.
The GetImage method returns a graphic presentation of a component together with all child components.
The GetItemAt method enables the user to get the component element in the specified point.
The GetItemObject method returns description of the repository object corresponding to the specified tree node.
The HitTest method is an enhanced version of the GetItemAt method.
The RollUp method collapses the drop-down list.
The ScreenToClient method converts screen coordinates of a point into coordinates specified relative to the component coordinate system.
The SelectElem method selects the tree node corresponding to the specified repository object.
The SelectElemKey method selects the tree node corresponding to a repository object with the specified key.
The SendToBack method sends a component to back.
The SetFocus method sets focus to this component.
The Sort method sorts by the values of the specified column.
The SortDefault method executes sorting by the contents of the column, which index is specified in the SortColumn property.
The UpdateInfo method updates data.

Events of the MetabaseTreeCombo Component

  Event name Brief description
The OnAdded event occurs when a new element is added.
The OnBeginDrag event occurs for a component when the user starts to drag an object from the component.
The OnBeginFilter event occurs at the start of filtering of component elements list.
The OnBeginSearch event occurs when elements are started to be searched in the component.
The OnCheckToAddElem event occurs on adding elements to the tree.
The OnChecked event occurs when the element checkbox is selected.
The OnChecking event occurs when the element checkbox is selected.
The OnClick event occurs if the user clicks the component area with the main mouse button.
The OnCollapsed event occurs after collapsing the hierarchy of the tree node children.
The OnCollapsing event occurs before collapsing the hierarchy of tree node children.
The OnColumnClick event occurs on mouse click on the component column header.
The OnCompareItems event occurs during comparison of two elements during custom element sorting.
The OnDblClick event occurs if the user double-clicks a component area with the mouse button.
The OnDeleting event occurs when the element is deleted.
The OnDragDrop event occurs for the component if the user drops a dragged object over it.
The OnDragEnter event occurs when a dragged object crosses the borders of this component.
The OnDragLeave event occurs when a dragged object leaves the borders of this component.
The OnDragOver event occurs for the component when the user drags an object over it.
The OnDropDown event occurs on expanding the component list.
The OnEdited event occurs on exiting the mode of editing the contents of the component current record field.
The OnEditing event occurs when switching to the mode of editing the field contents of the current component record.
The OnEnter event occurs when the component receives focus.
The OnExit event occurs when the component loses focus.
The OnExpanded event occurs after expanding the hierarchy of tree node children.
The OnExpanding event occurs directly before expanding the tree node children hierarchy.
The OnFilter event occurs after the components list is filtered.
The OnFocusedChanged event occurs when the focus is moved to another component element.
The OnFocusedChanged event occurs before the focus is moved to another component node.
The OnGetElementPopup event occurs when on calling a context menu for a tree element.
The OnGetHint event occurs when a tooltip is displayed over the element, over which the mouse cursor is hovered.
The OnGetNodeImage event occurs on determining an image near the tree element.
The OnGetNodeStateImage event occurs on determining the state images near the tree element.
The OnHover event occurs when the mouse cursor hovers over the element and this component element is underlined.
The OnHScroll event occurs when horizontal scrollbar slider changes its position.
The OnIsBrowseableElem event is used to set whether an element is displayed in a tree.
The OnIsDynamicElem event is used to set whether a tree of folder child elements is dynamically built.
The OnIsEmptyFolder event is used to set whether a folder is empty.
The OnIsFolderElem event is used to set whether elements displayed in the component tree are set as folders.
The OnKeyDown event occurs if the component is focused and the keyboard key is pressed.
The OnKeyPress event occurs if the component is focused when the user presses a character key.
The OnKeyPreview event occurs prior to each event related to key pressing.
The OnKeyUp event occurs if the component is focused and the user releases any button previously pressed.
The OnMouseDown event occurs if the pointer is in component's area and a mouse key is pressed.
The OnMouseEnter event occurs when mouse cursor enters the component area.
The OnMouseHover event occurs when mouse cursor is held in the component area.
The OnMouseLeave event occurs when mouse cursor leaves the component area.
The OnMouseMove event occurs on moving the cursor over component.
The OnMouseUp event occurs on releasing mouse button when the cursor is in component area.
The OnMouseWheel event occurs if the component is focused when the mouse wheel is rotated.
The OnRollUp event occurs when the component list is collapsed.
The OnSearch event occurs after the element search in the component is finished.
The OnSelected event occurs after selecting a node.
The OnSelecting event occurs before selecting a node.
The OnSelectionChanged event occurs when the component element selection is changed.
The OnUnselected event occurs after deselecting a node.
The OnUnselecting event occurs before deselecting an element.
The OnVScroll event occurs when vertical scrollbar slider changes its position.

See also:

Additional Components