ViewVC Help
View File | Revision Log | Show Annotations | Download File | View Changeset | Root Listing
root/public/ibx/trunk/doc/readme.tibtreeview.xhtml
Revision: 21
Committed: Thu Feb 26 10:33:34 2015 UTC (9 years, 9 months ago) by tony
Content type: application/xhtml+xml
File size: 78283 byte(s)
Log Message:
Committing updates for Release R1-2-0

File Contents

# Content
1 <?xml version="1.0" encoding="UTF-8"?>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 plus MathML 2.0//EN" "http://www.w3.org/Math/DTD/mathml2/xhtml-math11-f.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><!--This file was converted to xhtml by LibreOffice - see http://cgit.freedesktop.org/libreoffice/core/tree/filter/source/xslt for the code.--><head profile="http://dublincore.org/documents/dcmi-terms/"><meta http-equiv="Content-Type" content="application/xhtml+xml; charset=utf-8"/><title xml:lang="en-US">- no title specified</title><meta name="DCTERMS.title" content="" xml:lang="en-US"/><meta name="DCTERMS.language" content="en-US" scheme="DCTERMS.RFC4646"/><meta name="DCTERMS.source" content="http://xml.openoffice.org/odf2xhtml"/><meta name="DCTERMS.creator" content="Tony Whyman"/><meta name="DCTERMS.issued" content="2015-02-23T16:07:44.511653697" scheme="DCTERMS.W3CDTF"/><meta name="DCTERMS.contributor" content="Tony Whyman"/><meta name="DCTERMS.modified" content="2015-02-25T12:07:28.373352370" scheme="DCTERMS.W3CDTF"/><meta name="DCTERMS.provenance" content="" xml:lang="en-US"/><meta name="DCTERMS.subject" content="," xml:lang="en-US"/><link rel="schema.DC" href="http://purl.org/dc/elements/1.1/" hreflang="en"/><link rel="schema.DCTERMS" href="http://purl.org/dc/terms/" hreflang="en"/><link rel="schema.DCTYPE" href="http://purl.org/dc/dcmitype/" hreflang="en"/><link rel="schema.DCAM" href="http://purl.org/dc/dcam/" hreflang="en"/><style type="text/css">
3 @page { }
4 table { border-collapse:collapse; border-spacing:0; empty-cells:show }
5 td, th { vertical-align:top; font-size:12pt;}
6 h1, h2, h3, h4, h5, h6 { clear:both }
7 ol, ul { margin:0; padding:0;}
8 li { list-style: none; margin:0; padding:0;}
9 <!-- "li span.odfLiEnd" - IE 7 issue-->
10 li span. { clear: both; line-height:0; width:0; height:0; margin:0; padding:0; }
11 span.footnodeNumber { padding-right:1em; }
12 span.annotation_style_by_filter { font-size:95%; font-family:Arial; background-color:#fff000; margin:0; border:0; padding:0; }
13 * { margin:0;}
14 .fr1 { border-style:none; font-size:12pt; margin-bottom:0in; margin-left:0in; margin-right:0in; margin-top:0in; padding:0in; font-family:Liberation Serif; text-align:center; vertical-align:top; writing-mode:lr-tb; }
15 .fr2 { font-size:12pt; font-family:Liberation Serif; text-align:center; vertical-align:top; writing-mode:lr-tb; margin-left:0in; margin-right:0in; margin-top:0in; margin-bottom:0in; padding:0in; border-style:none; }
16 .Heading_20_1 { font-size:130%; margin-bottom:0.0799in; margin-top:0in; font-family:Liberation Sans; writing-mode:page; font-weight:bold; }
17 .Illustration { font-size:12pt; font-style:italic; margin-bottom:0.0835in; margin-top:0.0835in; font-family:Liberation Serif; writing-mode:page; }
18 .P1 { font-size:12pt; margin-bottom:0.1701in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
19 .P10 { font-size:12pt; line-height:120%; margin-bottom:0.0972in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
20 .P11 { font-size:12pt; line-height:120%; margin-bottom:0.0972in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
21 .P12 { font-size:12pt; line-height:120%; margin-bottom:0.0972in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
22 .P13 { font-size:115%; font-style:italic; font-weight:bold; margin-bottom:0.0835in; margin-top:0.139in; font-family:Liberation Sans; writing-mode:page; }
23 .P14 { font-size:115%; font-style:italic; font-weight:bold; margin-bottom:0.0835in; margin-top:0.139in; font-family:Liberation Sans; writing-mode:page; }
24 .P2 { font-size:12pt; margin-bottom:0.1701in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
25 .P3 { font-size:12pt; margin-bottom:0.1701in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
26 .P4 { font-size:12pt; margin-bottom:0.1701in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
27 .P5 { font-size:12pt; margin-bottom:0.0799in; margin-top:0.0799in; font-family:Liberation Serif; writing-mode:page; }
28 .P6 { font-size:12pt; line-height:120%; margin-bottom:0.0972in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
29 .P7 { font-size:12pt; line-height:120%; margin-bottom:0.0972in; margin-top:0in; font-family:Liberation Serif; writing-mode:page; }
30 .P8_borderStart { background-color:#dddddd; font-size:10pt; margin-top:0in; font-family:Liberation Mono; writing-mode:page; padding-bottom:0in; border-bottom-style:none; }
31 .P8 { background-color:#dddddd; font-size:10pt; font-family:Liberation Mono; writing-mode:page; padding-bottom:0in; padding-top:0in; border-top-style:none; border-bottom-style:none; }
32 .P8_borderEnd { background-color:#dddddd; font-size:10pt; margin-bottom:0in; font-family:Liberation Mono; writing-mode:page; padding-top:0in; border-top-style:none;}
33 .P9_borderStart { background-color:#dddddd; font-size:10pt; margin-top:0in; font-family:Liberation Mono; writing-mode:page; padding-bottom:0.1701in; border-bottom-style:none; }
34 .P9 { background-color:#dddddd; font-size:10pt; font-family:Liberation Mono; writing-mode:page; padding-bottom:0.1701in; padding-top:0in; border-top-style:none; border-bottom-style:none; }
35 .P9_borderEnd { background-color:#dddddd; font-size:10pt; margin-bottom:0.1701in; font-family:Liberation Mono; writing-mode:page; padding-top:0in; border-top-style:none;}
36 .Standard { font-size:12pt; font-family:Liberation Serif; writing-mode:page; margin-top:0in; margin-bottom:0.1701in; }
37 .function_borderStart { font-size:10pt; margin-top:0in; font-family:Liberation Mono; writing-mode:page; background-color:#dddddd; padding-bottom:0.1701in; border-bottom-style:none; }
38 .function { font-size:10pt; font-family:Liberation Mono; writing-mode:page; background-color:#dddddd; padding-bottom:0.1701in; padding-top:0in; border-top-style:none; border-bottom-style:none; }
39 .function_borderEnd { font-size:10pt; margin-bottom:0.1701in; font-family:Liberation Mono; writing-mode:page; background-color:#dddddd; padding-top:0in; border-top-style:none;}
40 .Table1 { float:none; }
41 .Table1_A1 { padding:0.0382in; border-left-width:thin; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-width:thin; border-top-style:solid; border-top-color:#000000; border-bottom-width:thin; border-bottom-style:solid; border-bottom-color:#000000; }
42 .Table1_A2 { padding:0.0382in; border-left-width:thin; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-width:thin; border-bottom-style:solid; border-bottom-color:#000000; }
43 .Table1_C1 { padding:0.0382in; border-width:thin; border-style:solid; border-color:#000000; }
44 .Table1_C2 { padding:0.0382in; border-left-width:thin; border-left-style:solid; border-left-color:#000000; border-right-width:thin; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-width:thin; border-bottom-style:solid; border-bottom-color:#000000; }
45 .Bullet_20_Symbols { font-family:OpenSymbol; }
46 <!-- ODF styles with no properties representable as CSS -->
47 .Table1.A .Table1.B .Table1.C .T1 .T2 .T3 .T4 .T5 { }
48 </style></head><body dir="ltr" style="max-width:8.2681in;margin-top:0.7874in; margin-bottom:0.7874in; margin-left:0.7874in; margin-right:0.7874in; writing-mode:lr-tb; "><h1 class="Heading_20_1"><a id="a__TIBTreeView"><span/></a>TIBTreeView</h1><!--Next 'div' was a 'text:p'.--><div class="P1"><!--Next 'div' is emulating the top hight of a draw:frame.--><!--Next '
49 div' is a draw:frame.
50 --><div style="width:6.6929in; padding:0; float:left; position:relative; left:0cm; " class="fr1" id="Frame1"><!--Next 'div' was a 'draw:text-box'.--><div style="min-height:4.2102in;"><!--Next 'div' was a 'text:p'.--><div class="Illustration"><!--Next 'div' is emulating the top hight of a draw:frame.--><!--Next '
51 div' is a draw:frame.
52 --><div style="height:4.2102in;width:6.6929in; padding:0; float:left; position:relative; left:0cm; " class="fr2" id="Image1"><img style="height:10.6939cm;width:17cm;" alt="" src=""/></div><!--Next 'div' added for floating.--><div style="position:relative; left:0cm;">Illustration <a id="refIllustration0"/>1: TIBTreeView Example</div></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div></div></div></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="P2">TIBTreeView is a data aware descendent of a TCustomTreeView and is used to present a hierarchically organised data set in a tree view. <span class="T3">Tree Node </span>Insertion, Deletion and Modification are supported, as <span class="T3">is</span> moving (e.g. using drag and drop) nodes from one part of the tree to another. The underlying dataset cursor is always positioned to reflect the currently selected tree node. It can thus be used to select a row for detailed editing. <span class="T1">SQL Manipulation is used to load the tree as a series of separate queries.</span></p><p class="P2"><a href="#refIllustration0">Illustration 1</a> Is taken from ibx/examples/ibtreeview and uses the Firebird example “employee” database. This database contains a hierarchically organised table “DEPARTMENT” and which is used for the example.</p><p class="P2">To use a TIBTreeView, <span class="T1">simply drop it on to a form, set the DataSource property, and, as a minimum, the TextField, ParentField and KeyField properties as defined below.</span></p><p class="P3">The DataSet must have a single primary key field.</p><h2 class="P13"><a id="a__TIBTreeView_Properties"><span/></a>TIBTreeView Properties</h2><table border="0" cellspacing="0" cellpadding="0" class="Table1"><colgroup><col/><col/><col/></colgroup><tr><td style="text-align:left;" class="Table1_A1"><p class="P5">DataSource</p></td><td style="text-align:left;" class="Table1_A1"><p class="P5">TDataSource</p></td><td style="text-align:left;" class="Table1_C1"><p class="P5">Identifies the source of the data to present using the tree view</p></td></tr><tr><td style="text-align:left;" class="Table1_A2"><p class="P5">TextField</p></td><td style="text-align:left;" class="Table1_A2"><p class="P5">string</p></td><td style="text-align:left;" class="Table1_C2"><p class="P5">The field name of the column used to source each node's display text</p></td></tr><tr><td style="text-align:left;" class="Table1_A2"><p class="P5">KeyField</p></td><td style="text-align:left;" class="Table1_A2"><p class="P5">string</p></td><td style="text-align:left;" class="Table1_C2"><p class="P5">The field name of the column used to source each node's <span class="T4">primary </span>key.</p></td></tr><tr><td style="text-align:left;" class="Table1_A2"><p class="P5">ParentField</p></td><td style="text-align:left;" class="Table1_A2"><p class="P5">string</p></td><td style="text-align:left;" class="Table1_C2"><p class="P5">The field name of the column used to identify the primary key of the parent row. This field is null for a root element.</p></td></tr><tr><td style="text-align:left;" class="Table1_A2"><p class="P5">HasChildField</p></td><td style="text-align:left;" class="Table1_A2"><p class="P5">string</p></td><td style="text-align:left;" class="Table1_C2"><p class="P5">Optional. The field name of the column used to indicate whether or not the row has child nodes. When present, th<span class="T4">e field</span> should return an integer value with non-zero values implying that child nodes exist.</p></td></tr><tr><td style="text-align:left;" class="Table1_A2"><p class="P5">RelationName</p></td><td style="text-align:left;" class="Table1_A2"><p class="P5">string</p></td><td style="text-align:left;" class="Table1_C2"><p class="P5">Optional. The Child Field is typically the result of joining the table to itself and is a count of child rows. However, this can result in ambiguous column names when the SQL is <span class="T4">manipulated.</span> This property should contain the Table Alias used to <span class="T2">select</span> <span class="T2">the Key, Text and Parent Fields (see example).</span></p></td></tr></table><p class="P6"> </p><h2 class="P14"><a id="a__TIBTreeView_Methods"><span/></a>TIBTreeView Methods</h2><p class="function">function GetNodePath(Node: TTreeNode): T<span class="T3">V</span>ariantArray</p><p class="P7">Returns a Variant array containing the primary key values of the Node and its parents from the root node downwards.</p><p class="function">function FindNode(KeyValuePath: array of variant; SelectNode: boolean): TIBTreeNode; </p><p class="Standard">Returns the TTreeNode identified by the KeyValuePath. The KeyValuePath is an array comprising a list of primary key values walking the tree down from the root node to the requested node.</p><p class="Standard">If <span class="T3">SelectNode is true then the returned node is also selected.</span></p><p class="P4">This function can be used to select the tree node using the node path returned by an earlier cal<span class="T4">l </span>to the function GetNodePath.</p><p class="function">function FindNode(KeyValue: variant): TIBTreeNode; </p><p class="P7">Returns the tree node with the primary key given by KeyValue. Note: this forces the whole tree to be loaded by a call to TcustomTreeView.FullExpand.</p><h2 class="P14"><a id="a__Drag_and_Drop"><span/></a>Drag and Drop</h2><p class="P7">Drag and drop is supported by T<span class="T4">C</span>ustomTreeView without the need for additional support from TIBTreeView. In the example, drag and drop is enabled b<span class="T5">y</span>:</p><ul><li><p class="P10" style="margin-left:0cm;"><span class="Bullet_20_Symbols" style="display:block;float:left;min-width:0.635cm;"></span>DragMode set to automatic<span class="odfLiEnd"/> </p></li><li><p class="P11" style="margin-left:0cm;"><span class="Bullet_20_Symbols" style="display:block;float:left;min-width:0.635cm;"></span>The OnDragOver Event handled by:<span class="odfLiEnd"/> </p></li></ul><p class="P8_borderStart">procedure TForm1.IBTreeView1DragOver(Sender, Source: TObject; X, Y: Integer;</p><p class="P8">  State: TDragState; var Accept: Boolean);</p><p class="P8">begin</p><p class="P8">  Accept := Source = Sender</p><p class="P9_borderEnd">end; </p><ul><li><p class="P12" style="margin-left:0cm;"><span class="Bullet_20_Symbols" style="display:block;float:left;min-width:0.635cm;"></span>The OnDragDrop Event Handled by:<span class="odfLiEnd"/> </p></li></ul><p class="P8_borderStart">procedure TForm1.IBTreeView1DragDrop(Sender, Source: TObject; X, Y: Integer);</p><p class="P8">var Node: TTreeNode;</p><p class="P8">    tv: TTreeView;</p><p class="P8">begin</p><p class="P8">  if Source = Sender then {Dragging within Tree View}</p><p class="P8">  begin</p><p class="P8">    tv := TTreeView(Sender);;</p><p class="P8">    Node := tv.GetNodeAt(X,Y); {Drop Point}</p><p class="P8">    if assigned(tv.Selected) and (tv.Selected &lt;&gt; Node) then</p><p class="P8">    begin</p><p class="P8">      if Node = nil then</p><p class="P8">        tv.Selected.MoveTo(nil,naAdd) {Move to Top Level}</p><p class="P8">      else</p><p class="P8">      begin</p><p class="P8">        if ssCtrl in GetKeyShiftState then</p><p class="P8">        begin</p><p class="P8">          Node.Expand(false);</p><p class="P8">          tv.Selected.MoveTo(Node,naAddChildFirst)</p><p class="P8">        end</p><p class="P8">        else</p><p class="P8">          tv.Selected.MoveTo(Node,naInsertBehind)</p><p class="P8">      end;</p><p class="P8">    end;</p><p class="P8">  end;</p><p class="function_borderEnd">end;           </p><p class="Standard">Note that the above applies the convention that if the “control” key is held down while the node is “dropped” then it is added as a child node. Otherwise, it is added as a sibling.</p></body></html>