TreeItem.st
author Claus Gittinger <cg@exept.de>
Fri, 13 Oct 2006 13:01:49 +0200
changeset 3123 8912a9a3bc01
parent 2930 6c5b7065dd15
child 3361 5b0ba50df077
permissions -rw-r--r--
code cleanup: use #contains instead of explicit loop
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     1
"
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     2
 COPYRIGHT (c) 1997 by eXept Software AG / Claus Gittinger
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     3
              All Rights Reserved
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     4
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     5
 This software is furnished under a license and may be used
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    10
 hereby transferred.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    11
"
1818
fe99c5c721e9 category changes
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
    12
"{ Package: 'stx:libwidg2' }"
fe99c5c721e9 category changes
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
    13
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    14
Object subclass:#TreeItem
795
d36f94d682bf #changed: bug fixed
tz
parents: 786
diff changeset
    15
	instanceVariableNames:'name tree parent children contents hide readChildren'
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    16
	classVariableNames:'UnknownContents'
795
d36f94d682bf #changed: bug fixed
tz
parents: 786
diff changeset
    17
	poolDictionaries:''
d36f94d682bf #changed: bug fixed
tz
parents: 786
diff changeset
    18
	category:'Interface-Support'
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    19
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    20
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    21
!TreeItem class methodsFor:'documentation'!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    22
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    23
copyright
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    24
"
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    25
 COPYRIGHT (c) 1997 by eXept Software AG / Claus Gittinger
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    26
              All Rights Reserved
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    27
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    28
 This software is furnished under a license and may be used
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    29
 only in accordance with the terms of that license and with the
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    31
 be provided or otherwise made available to, or used by, any
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    32
 other person.  No title to or ownership of the software is
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    33
 hereby transferred.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    34
"
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    35
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    36
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    37
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    38
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    39
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    40
documentation
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    41
"
2452
e7e440d4ca0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
    42
    class to build up tree-like structures to represent file-trees, class tress etc.
e7e440d4ca0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
    43
e7e440d4ca0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
    44
    Especially suited for use with SelectionInTree and SelectionInTreeView.
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    45
2452
e7e440d4ca0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
    46
    NOTICE: 
e7e440d4ca0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
    47
        this class has been obsoleted by HierarchicalItem with its corresponding
e7e440d4ca0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
    48
        view class HierarchicalListView. Please use these new ones.
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    49
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    50
    [Author:]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    51
        W. Olberding
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    52
        Claus Atzkern
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    53
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    54
    [See also:]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    55
        SelectionInTree
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    56
        SelectionInTreeView
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    57
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    58
"
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    59
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    60
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    61
!TreeItem class methodsFor:'instance creation'!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    62
768
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
    63
contents:aContents
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
    64
    |node|
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
    65
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
    66
    node := self new.
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
    67
    node contents:aContents.
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
    68
  ^ node
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
    69
!
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
    70
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
    71
name:aName
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
    72
    ^ self name:aName contents:nil
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
    73
!
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
    74
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    75
name:aName contents:aContents
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    76
    |node|
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    77
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    78
    node := self new.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    79
    node name:aName.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    80
    node contents:aContents.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    81
  ^ node
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    82
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    83
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
    84
name:aName value:aContents
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
    85
    ^ self name:aName contents:aContents
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
    86
!
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
    87
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    88
new
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    89
    ^ self basicNew initialize
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    90
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
    91
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    92
!TreeItem class methodsFor:'class initialization'!
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    93
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    94
initialize
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    95
    UnknownContents isNil ifTrue:[
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    96
        UnknownContents := Object new.
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    97
    ]
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    98
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
    99
    "
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   100
     self initialize
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   101
    "
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   102
! !
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   103
786
ca
parents: 784
diff changeset
   104
!TreeItem class methodsFor:'default icons'!
ca
parents: 784
diff changeset
   105
ca
parents: 784
diff changeset
   106
keysAndIcons
ca
parents: 784
diff changeset
   107
    "returns an IdentityDictionary containing a list of images and keys used
ca
parents: 784
diff changeset
   108
     by any file entry; could be redefined by subclass
ca
parents: 784
diff changeset
   109
    "
ca
parents: 784
diff changeset
   110
    ^ nil
ca
parents: 784
diff changeset
   111
ca
parents: 784
diff changeset
   112
! !
ca
parents: 784
diff changeset
   113
2512
c7087ddb4508 category
Claus Gittinger <cg@exept.de>
parents: 2501
diff changeset
   114
!TreeItem class methodsFor:'example-instance creation'!
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   115
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   116
newAsTreeFromSmalltalkClass:aClass
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   117
    "create a tree of nodes with aClass and all its
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   118
     subclasses as contents. Set the initial level as given."
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   119
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   120
    |newInst clsName|
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   121
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   122
    aClass isNil ifTrue:[
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   123
        "/ nil subclasses requested
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   124
        clsName := 'nil'
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   125
    ] ifFalse:[
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   126
        "/ regular tree requested
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   127
        clsName := aClass name
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   128
    ].
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   129
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   130
    newInst := super new initialize.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   131
    newInst name:clsName.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   132
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   133
    aClass isNil ifTrue:[
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   134
        ((Smalltalk allClasses select:[:cls | cls superclass isNil])
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   135
            asSortedCollection:[:a :b | a name < b name])
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   136
        do:[:aSubClass |
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   137
            newInst add:(self newAsTreeFromSmalltalkClass:aSubClass).
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   138
        ]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   139
    ] ifFalse:[
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   140
        (aClass subclasses asSortedCollection:[:a :b | a name < b name])
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   141
        do:[:aSubClass |
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   142
            newInst add:(self newAsTreeFromSmalltalkClass:aSubClass).
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   143
        ]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   144
    ].
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   145
    ^newInst
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   146
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   147
"
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   148
      |top model sel root|
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   149
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   150
      root  := TreeItem newAsTreeFromSmalltalkClass:ByteArray.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   151
      root expand.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   152
      model := SelectionInTree new root:root.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   153
      top := StandardSystemView new.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   154
      top extent:300@300.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   155
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   156
      sel := SelectionInTreeView new.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   157
      sel model: model.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   158
      sel action:[:nr | Transcript show:'selected:'; showCR:nr].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   159
      top add:(ScrollableView forView:sel) in:((0.0 @ 0.0 ) corner:( 1.0 @ 1.0)).
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   160
      top open.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   161
"
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   162
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   163
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   164
!TreeItem methodsFor:'accessing'!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   165
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   166
contents
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   167
    "get the contents; 
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   168
     usually, the contents is computed lazily i.e. #retrieveContents
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   169
     is invoked when the contents has not yet been set.
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   170
    "
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   171
    contents == UnknownContents ifTrue:[        
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   172
        self retrieveContents
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   173
    ].
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   174
    ^contents
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   175
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   176
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   177
contents:something 
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   178
    "set contents
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   179
    "
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   180
    contents := something
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   181
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   182
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   183
editor
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   184
    "returns an editor on the editable value or nil
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   185
    "
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   186
    ^ nil
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   187
!
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   188
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   189
hide
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   190
    ^ hide
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   191
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   192
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   193
hide:aBoolean
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   194
   "set hide flag
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   195
   "    
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   196
   hide:= aBoolean
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   197
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   198
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   199
icon
786
ca
parents: 784
diff changeset
   200
    "get the icon
766
c37798a729eb in #expand and #collapse icon has to be retrieved
tz
parents: 761
diff changeset
   201
    "        
772
9ae43992a603 do not cache icons because TreeItems are models
tz
parents: 768
diff changeset
   202
    ^self retrieveAndEvaluate: #iconAction
9ae43992a603 do not cache icons because TreeItems are models
tz
parents: 768
diff changeset
   203
    
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   204
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   205
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   206
level
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   207
    "get level
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   208
    "
786
ca
parents: 784
diff changeset
   209
    |p
ca
parents: 784
diff changeset
   210
     lv "{ Class:SmallInteger }"
ca
parents: 784
diff changeset
   211
    |
ca
parents: 784
diff changeset
   212
    lv := 1.
ca
parents: 784
diff changeset
   213
    p  := self.
ca
parents: 784
diff changeset
   214
ca
parents: 784
diff changeset
   215
    [ (p := p parent) notNil ] whileTrue:[ lv := lv + 1 ].
ca
parents: 784
diff changeset
   216
    ^ lv
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   217
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   218
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   219
middleButtonMenu
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   220
    "returns the middleButtonMenu of the item or nil
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   221
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   222
    ^ nil
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   223
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   224
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   225
name
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   226
    "get name
772
9ae43992a603 do not cache icons because TreeItems are models
tz
parents: 768
diff changeset
   227
    "   
786
ca
parents: 784
diff changeset
   228
    name isNil ifTrue:[    
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   229
        self retrieveLabel
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   230
    ].
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   231
    ^name
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   232
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   233
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   234
name:aString
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   235
    "set name
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   236
    "      
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   237
    name := aString.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   238
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   239
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   240
parent
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   241
    "get parent
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   242
    "
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   243
    ^ parent
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   244
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   245
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   246
parent:something
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   247
    "set parent
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   248
    "
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   249
    parent := something.
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   250
!
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   251
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   252
value
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   253
    "get contents
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   254
    "
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   255
    ^ self contents
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   256
!
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   257
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   258
value:something 
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   259
    "set contents
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   260
    "
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   261
    self contents:something
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   262
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   263
1818
fe99c5c721e9 category changes
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   264
!TreeItem methodsFor:'accessing-children'!
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   265
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   266
basicLastChild
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   267
    "returns the last child without checking for valid sequence
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   268
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   269
    ^ children last
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   270
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   271
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   272
children
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   273
    "get list of children
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   274
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   275
    (readChildren and:[children isEmpty]) ifTrue:[       
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   276
        self retrieveChildren
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   277
    ].
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   278
    ^children
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   279
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   280
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   281
children:aCollection 
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   282
    "set children
1208
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   283
    "
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   284
    aCollection isNil ifTrue:[
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   285
        children removeAll
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   286
    ] ifFalse:[
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   287
        aCollection notNil ifTrue:[
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   288
            aCollection do:[:child| child parent:self ].
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   289
            readChildren := false
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   290
        ].
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   291
        children := aCollection
2f9d74cead2f children:
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
   292
    ]
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   293
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   294
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   295
firstChild
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   296
    "returns first child in sequence
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   297
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   298
    self children notEmpty ifTrue:[
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   299
        ^ children at:1
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   300
    ].
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   301
    ^ nil
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   302
        
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   303
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   304
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   305
lastChild
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   306
    "returns last child in sequence
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   307
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   308
    self children notEmpty ifTrue:[
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   309
        ^ children last
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   310
    ].
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   311
    ^ nil
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   312
        
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   313
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   314
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   315
readChildren:aBoolean
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   316
   "set read children flag
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   317
   "    
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   318
   readChildren:= aBoolean
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   319
! !
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   320
1818
fe99c5c721e9 category changes
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   321
!TreeItem methodsFor:'accessing-dimensions'!
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   322
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   323
childrenWidthOn:aDevice
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   324
    "returns the maximum name length of my children
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   325
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   326
    |max name|
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   327
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   328
    max := 0.
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   329
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   330
    children do:[:aChild|
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   331
        (name := aChild name) notNil ifTrue:[
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   332
            max := max max:(name widthOn:aDevice)
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   333
        ]
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   334
    ].
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   335
    ^ max
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   336
! !
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   337
1818
fe99c5c721e9 category changes
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   338
!TreeItem methodsFor:'accessing-hierarchy'!
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   339
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   340
collapse 
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   341
    "hide all my children
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   342
    "
772
9ae43992a603 do not cache icons because TreeItems are models
tz
parents: 768
diff changeset
   343
    hide := true
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   344
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   345
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   346
collapseAll 
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   347
    "hide all my children and sub children
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   348
    "
841
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   349
    hide := true.
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   350
841
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   351
    children notEmpty ifTrue:[
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   352
        children do:[:aChild| aChild collapseAll]
834
8729c234f95d add new queries
ca
parents: 795
diff changeset
   353
    ]
8729c234f95d add new queries
ca
parents: 795
diff changeset
   354
!
8729c234f95d add new queries
ca
parents: 795
diff changeset
   355
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   356
expand
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   357
    "show all my children
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   358
    "
772
9ae43992a603 do not cache icons because TreeItems are models
tz
parents: 768
diff changeset
   359
    hide := false
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   360
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   361
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   362
expandAll 
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   363
    "show all my children and sub children
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   364
    "
841
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   365
    hide := false.
834
8729c234f95d add new queries
ca
parents: 795
diff changeset
   366
841
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   367
    self children notEmpty ifTrue:[
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   368
        children do:[:aChild| aChild expandAll ]
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   369
    ]
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   370
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   371
2404
2b7591c982ac category change
Claus Gittinger <cg@exept.de>
parents: 2102
diff changeset
   372
!TreeItem methodsFor:'accessing-mvc'!
786
ca
parents: 784
diff changeset
   373
ca
parents: 784
diff changeset
   374
model
ca
parents: 784
diff changeset
   375
    "get my model (an instance of selection in tree) or nil
ca
parents: 784
diff changeset
   376
    "    
ca
parents: 784
diff changeset
   377
    ^ parent notNil ifTrue:[parent model] ifFalse:[tree]
ca
parents: 784
diff changeset
   378
!
ca
parents: 784
diff changeset
   379
ca
parents: 784
diff changeset
   380
model:aSelectionInTree
ca
parents: 784
diff changeset
   381
    "set my model (an instance of selection in tree) or nil
ca
parents: 784
diff changeset
   382
    "    
ca
parents: 784
diff changeset
   383
    tree:= aSelectionInTree
ca
parents: 784
diff changeset
   384
!
ca
parents: 784
diff changeset
   385
ca
parents: 784
diff changeset
   386
tree
ca
parents: 784
diff changeset
   387
    "get my model (an instance of selection in tree) or nil
ca
parents: 784
diff changeset
   388
    "    
ca
parents: 784
diff changeset
   389
    ^ self model
ca
parents: 784
diff changeset
   390
!
ca
parents: 784
diff changeset
   391
ca
parents: 784
diff changeset
   392
tree:aSelectionInTree
ca
parents: 784
diff changeset
   393
    "set my model (an instance of selection in tree) or nil
ca
parents: 784
diff changeset
   394
    "    
ca
parents: 784
diff changeset
   395
    self model:aSelectionInTree
ca
parents: 784
diff changeset
   396
! !
ca
parents: 784
diff changeset
   397
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   398
!TreeItem methodsFor:'adding & removing'!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   399
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   400
add:something
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   401
    "add a child or collection of children add end
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   402
    "
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   403
    self add:something beforeIndex:(self children size + 1)
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   404
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   405
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   406
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   407
add:something after:aChild
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   408
    "add a child or collection of children add end
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   409
    "
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   410
    self add:something afterIndex:(self indexOfChild:aChild)
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   411
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   412
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   413
add:something afterIndex:anIndex
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   414
    "add a child or collection after an index
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   415
    "
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   416
    self add:something beforeIndex:(anIndex + 1)
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   417
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   418
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   419
add:something before:aChild
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   420
    "add a child or collection of children add end
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   421
    "
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   422
    self add:something beforeIndex:(self indexOfChild:aChild)
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   423
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   424
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   425
add:something beforeIndex:anIndex
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   426
    "add a child or collection before an index
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   427
    "
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   428
    |idx children|
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   429
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   430
    children := self children.
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   431
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   432
    (idx := anIndex) > children size ifTrue:[
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   433
        idx := children size + 1
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   434
    ] ifFalse:[
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   435
        idx == 0 ifTrue:[idx := 1]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   436
    ].
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   437
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   438
    self each:something do:[:el|
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   439
        children add:el beforeIndex:idx.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   440
        el parent:self.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   441
        el allWithParentAndChildrenDo:[:aParent :aChild| aChild parent:aParent ].
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   442
        idx := idx + 1.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   443
    ]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   444
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   445
909
b2930fedcbe8 checkin from browser
tz
parents: 858
diff changeset
   446
addFirst: something
b2930fedcbe8 checkin from browser
tz
parents: 858
diff changeset
   447
    "add a child at the beginning
b2930fedcbe8 checkin from browser
tz
parents: 858
diff changeset
   448
    "
b2930fedcbe8 checkin from browser
tz
parents: 858
diff changeset
   449
    self add:something beforeIndex:1
b2930fedcbe8 checkin from browser
tz
parents: 858
diff changeset
   450
!
b2930fedcbe8 checkin from browser
tz
parents: 858
diff changeset
   451
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   452
remove:something 
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   453
    "remove a child or collection of children
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   454
    "
858
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   455
    self each:something do:[:aChild| self removeChild:aChild ].
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   456
  ^ something
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   457
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   458
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   459
removeAll
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   460
    "remove all children
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   461
    "
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   462
    self childrenDo:[:aChild| aChild parent:nil ].
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   463
    self children removeAll.
858
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   464
!
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   465
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   466
removeChild:aChild
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   467
    "remove a aChild
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   468
    "
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   469
    |item|
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   470
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   471
    (item := self children remove:aChild ifAbsent:nil) notNil ifTrue:[
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   472
        item parent:nil
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   473
    ].
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   474
    ^ item
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   475
!
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   476
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   477
removeIndex:anIndex
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   478
    "remove child at index
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   479
    "
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   480
    ^ self removeChild:(self childAt:anIndex)
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   481
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   482
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   483
!TreeItem methodsFor:'change & update'!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   484
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   485
changed
786
ca
parents: 784
diff changeset
   486
    "node changed; raise notification to model
ca
parents: 784
diff changeset
   487
    "
ca
parents: 784
diff changeset
   488
    self changed:#value
784
f521b359ec84 #changed: mechanism extented
tz
parents: 777
diff changeset
   489
!
f521b359ec84 #changed: mechanism extented
tz
parents: 777
diff changeset
   490
786
ca
parents: 784
diff changeset
   491
changed:what
ca
parents: 784
diff changeset
   492
    "node changed; raise notification to model
ca
parents: 784
diff changeset
   493
    "
ca
parents: 784
diff changeset
   494
    |model|
784
f521b359ec84 #changed: mechanism extented
tz
parents: 777
diff changeset
   495
795
d36f94d682bf #changed: bug fixed
tz
parents: 786
diff changeset
   496
    what == #value 
982
d94684e7fe9f sending #changed to a tree item should not invoke retrieving children
tz
parents: 909
diff changeset
   497
        ifTrue:  [self retrieveLabel]
795
d36f94d682bf #changed: bug fixed
tz
parents: 786
diff changeset
   498
        ifFalse: [what == #children ifTrue: [self retrieveChildren]].
786
ca
parents: 784
diff changeset
   499
ca
parents: 784
diff changeset
   500
    (model := self model) notNil ifTrue:[
795
d36f94d682bf #changed: bug fixed
tz
parents: 786
diff changeset
   501
        model update:what with:nil from:self
786
ca
parents: 784
diff changeset
   502
    ]
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   503
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   504
2038
81b3b590c9d8 *** empty log message ***
ca
parents: 1825
diff changeset
   505
changedSelected
81b3b590c9d8 *** empty log message ***
ca
parents: 1825
diff changeset
   506
    "called if the node is selected
81b3b590c9d8 *** empty log message ***
ca
parents: 1825
diff changeset
   507
    "
81b3b590c9d8 *** empty log message ***
ca
parents: 1825
diff changeset
   508
!
81b3b590c9d8 *** empty log message ***
ca
parents: 1825
diff changeset
   509
786
ca
parents: 784
diff changeset
   510
update:something with:aParameter from:anItem
ca
parents: 784
diff changeset
   511
    "raise change notification to my model
ca
parents: 784
diff changeset
   512
    "
ca
parents: 784
diff changeset
   513
    |m|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   514
786
ca
parents: 784
diff changeset
   515
    (m := self model) notNil ifTrue:[
ca
parents: 784
diff changeset
   516
        m update:something with:aParameter from:anItem
ca
parents: 784
diff changeset
   517
    ]
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   518
! !
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   519
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   520
!TreeItem methodsFor:'converting'!
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   521
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   522
fromLiteralArrayEncoding:aLiteralEncodedArray
786
ca
parents: 784
diff changeset
   523
    "read my contents from a aLiteralEncodedArray.
ca
parents: 784
diff changeset
   524
    "
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   525
    |narg|
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   526
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   527
    (     (aLiteralEncodedArray size > 0)
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   528
     and:[(name := aLiteralEncodedArray at:1) isString]) ifFalse:[
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   529
        ^ nil
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   530
    ].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   531
    narg := aLiteralEncodedArray at:2 ifAbsent:nil.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   532
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   533
    name isSymbol ifTrue:[
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   534
        (narg isArray and:[aLiteralEncodedArray size == 2]) ifTrue:[
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   535
            ^ self fromLiteralArrayEncoding:narg
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   536
        ].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   537
        ^ nil
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   538
    ].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   539
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   540
    narg isArray ifFalse:[
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   541
        contents := narg.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   542
        narg := aLiteralEncodedArray at:3 ifAbsent:nil.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   543
    ].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   544
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   545
    narg isArray ifTrue:[
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   546
        children := OrderedCollection new.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   547
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   548
        narg do:[:aSubArray||aChild|
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   549
            children add:(aChild := TreeItem new).
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   550
            aChild fromLiteralArrayEncoding:aSubArray.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   551
            aChild parent:self.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   552
        ]
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   553
    ]
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   554
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   555
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   556
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   557
!
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   558
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   559
literalArrayEncoding
786
ca
parents: 784
diff changeset
   560
    "return myself encoded as a literal array
ca
parents: 784
diff changeset
   561
    "
ca
parents: 784
diff changeset
   562
    |array childs size noChld|
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   563
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   564
    contents isString ifTrue:[size := 2]
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   565
                     ifFalse:[size := 1].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   566
786
ca
parents: 784
diff changeset
   567
    noChld := self numberOfChildren.
ca
parents: 784
diff changeset
   568
ca
parents: 784
diff changeset
   569
    noChld == 0 ifTrue:[
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   570
        array := Array new:size
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   571
    ] ifFalse:[
786
ca
parents: 784
diff changeset
   572
        array  := Array new:size + 1.
ca
parents: 784
diff changeset
   573
        childs := Array new:noChld.
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   574
        array at:(size + 1) put:childs.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   575
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   576
        self children keysAndValuesDo:[:i :aChild|
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   577
            childs at:i put:(aChild literalArrayEncoding)
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   578
        ]
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   579
    ].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   580
    array at:1 put:(name ? '').
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   581
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   582
    contents isString ifTrue:[
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   583
        array at:2 put:contents
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   584
    ].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   585
    parent isNil ifTrue:[
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   586
        array := Array with:#TreeItem with:array.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   587
    ].
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   588
    ^ array
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   589
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   590
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   591
! !
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   592
2102
aa58c7d922fe category change
Claus Gittinger <cg@exept.de>
parents: 2071
diff changeset
   593
!TreeItem methodsFor:'copying'!
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   594
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   595
copy
2102
aa58c7d922fe category change
Claus Gittinger <cg@exept.de>
parents: 2071
diff changeset
   596
    |node newContents|
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   597
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   598
    node := self species new.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   599
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   600
    contents ~~ UnknownContents ifTrue:[
2102
aa58c7d922fe category change
Claus Gittinger <cg@exept.de>
parents: 2071
diff changeset
   601
        newContents := contents copy.
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   602
    ] ifFalse:[
2102
aa58c7d922fe category change
Claus Gittinger <cg@exept.de>
parents: 2071
diff changeset
   603
        newContents := UnknownContents
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   604
    ].
2102
aa58c7d922fe category change
Claus Gittinger <cg@exept.de>
parents: 2071
diff changeset
   605
    node name:name copy.
aa58c7d922fe category change
Claus Gittinger <cg@exept.de>
parents: 2071
diff changeset
   606
    node contents:newContents.
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   607
    node children:(self children collect:[:c| c copy]).
786
ca
parents: 784
diff changeset
   608
    node readChildren:readChildren.
2102
aa58c7d922fe category change
Claus Gittinger <cg@exept.de>
parents: 2071
diff changeset
   609
    ^ node
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   610
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   611
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   612
!TreeItem methodsFor:'enumerating'!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   613
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   614
allChildrenDo:aOneArgBlock
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   615
    "evaluate a block on each children and subchildren
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   616
    "
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   617
    self children do:[:aChild|
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   618
        aOneArgBlock value:aChild.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   619
        aChild allChildrenDo:aOneArgBlock
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   620
    ]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   621
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   622
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   623
allWithParentAndChildrenDo:aTwoArgBlock
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   624
    self childrenDo:[:aChild|
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   625
        aTwoArgBlock value:self value:aChild.
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   626
        aChild allWithParentAndChildrenDo:aTwoArgBlock
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   627
    ]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   628
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   629
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   630
childrenDo:aOneArgBlock
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   631
    "evaluate a block on each children( excluding  sub-children )
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   632
    "
837
5d437be03bcf optimize evaluation of block
ca
parents: 834
diff changeset
   633
    self children do:aOneArgBlock
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   634
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   635
1241
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   636
detectParent:aBlock
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   637
    "evaluate aBlock for my parent-chain; return the parent for which it returns true"
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   638
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   639
    |p|
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   640
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   641
    p := parent.
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   642
    [p notNil] whileTrue:[
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   643
        (aBlock value:p) ifTrue:[^ p].
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   644
        p := p parent
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   645
    ].
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   646
    ^ nil
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   647
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   648
!
11749610046e added #detectParent:
tm
parents: 1208
diff changeset
   649
837
5d437be03bcf optimize evaluation of block
ca
parents: 834
diff changeset
   650
each:something do:aOneArgBlock
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   651
    "evaluate a block for something or in case of a collection for each
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   652
     element in the collection
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   653
    "
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   654
    something notNil ifTrue:[
837
5d437be03bcf optimize evaluation of block
ca
parents: 834
diff changeset
   655
        something isCollection ifTrue:[something do:aOneArgBlock]
5d437be03bcf optimize evaluation of block
ca
parents: 834
diff changeset
   656
                              ifFalse:[aOneArgBlock value:something]
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   657
    ]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   658
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   659
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   660
2501
832cbac295b8 method category rename
Claus Gittinger <cg@exept.de>
parents: 2498
diff changeset
   661
!TreeItem methodsFor:'initialization & release'!
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   662
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   663
initialize
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   664
    "setup defaults
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   665
    "
506
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   666
    super initialize.
6a56843fb354 encodeing decoding
ca
parents: 479
diff changeset
   667
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   668
    children := OrderedCollection new.
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   669
    readChildren := hide := true.
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   670
    contents := UnknownContents.
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   671
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   672
1825
962390f1b499 category change
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
   673
!TreeItem methodsFor:'printing & storing'!
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   674
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   675
asString
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   676
    "sometimes used by the SelectionInListView to get the name
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   677
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   678
    ^ name notNil ifTrue:[name] ifFalse:[self name]
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   679
        
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   680
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   681
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   682
displayString
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   683
    ^ self class name , '(' , self printString , ')'
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   684
!
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   685
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   686
printString
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   687
    "sometimes used by the SelectionInListView to get the name
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   688
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   689
    ^ name notNil ifTrue:[name] ifFalse:[self name]
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   690
        
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   691
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   692
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   693
printableEditValue
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   694
    "returns the printable edit value or nil
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   695
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   696
    ^ nil
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   697
! !
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   698
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   699
!TreeItem methodsFor:'queries'!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   700
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   701
canEdit
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   702
    "returns true if field is editable
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   703
    "
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   704
    ^ false
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   705
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   706
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   707
hasChildren
786
ca
parents: 784
diff changeset
   708
    "returns true if any child exists
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   709
    "
786
ca
parents: 784
diff changeset
   710
    ^ self children notEmpty
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   711
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   712
834
8729c234f95d add new queries
ca
parents: 795
diff changeset
   713
hasChildrenWithSubChildren
2930
6c5b7065dd15 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2512
diff changeset
   714
    "returns true if any child exists and has children too"
834
8729c234f95d add new queries
ca
parents: 795
diff changeset
   715
2930
6c5b7065dd15 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2512
diff changeset
   716
    self children contains:[:aChild| aChild hasChildren]
834
8729c234f95d add new queries
ca
parents: 795
diff changeset
   717
!
8729c234f95d add new queries
ca
parents: 795
diff changeset
   718
8729c234f95d add new queries
ca
parents: 795
diff changeset
   719
hasExpandedChildren
8729c234f95d add new queries
ca
parents: 795
diff changeset
   720
    "returns true if any of my children is expanded
8729c234f95d add new queries
ca
parents: 795
diff changeset
   721
    "
3123
8912a9a3bc01 code cleanup: use #contains instead of explicit loop
Claus Gittinger <cg@exept.de>
parents: 2930
diff changeset
   722
    ^ children contains:[:aChild | aChild hidden not].
8912a9a3bc01 code cleanup: use #contains instead of explicit loop
Claus Gittinger <cg@exept.de>
parents: 2930
diff changeset
   723
8912a9a3bc01 code cleanup: use #contains instead of explicit loop
Claus Gittinger <cg@exept.de>
parents: 2930
diff changeset
   724
    "Modified: / 13-10-2006 / 13:00:05 / cg"
834
8729c234f95d add new queries
ca
parents: 795
diff changeset
   725
!
8729c234f95d add new queries
ca
parents: 795
diff changeset
   726
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   727
hidden
786
ca
parents: 784
diff changeset
   728
    "returns true if node is not visible
ca
parents: 784
diff changeset
   729
    "
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   730
    ^ hide
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   731
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   732
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   733
isCollapsable
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   734
    "is collabsable; children existing and shown
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   735
    "
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   736
    ^ (self hasChildren and:[hide == false])
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   737
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   738
569
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   739
isContainedByParent:aParent
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   740
    "returns true if contained in subtree of a parent
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   741
    "
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   742
    |p|
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   743
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   744
    p := parent.
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   745
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   746
    [p notNil] whileTrue:[
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   747
        p == aParent ifTrue:[^ true ].
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   748
        p := p parent
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   749
    ].
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   750
    ^ false
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   751
!
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   752
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   753
isExpandable
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   754
    "is expandable; children existing and hidden
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   755
    "
469
d3537bee9988 accessing children through message
ca
parents: 457
diff changeset
   756
    ^ (self hasChildren and:[hide == true])
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   757
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   758
!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   759
1205
98175b161f98 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1196
diff changeset
   760
isExpanded
98175b161f98 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1196
diff changeset
   761
    "return true if I am expanded"
98175b161f98 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1196
diff changeset
   762
    ^ hide not
98175b161f98 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1196
diff changeset
   763
98175b161f98 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1196
diff changeset
   764
!
98175b161f98 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1196
diff changeset
   765
472
ca
parents: 469
diff changeset
   766
numberOfChildren
786
ca
parents: 784
diff changeset
   767
    "returns number of children
ca
parents: 784
diff changeset
   768
    "
472
ca
parents: 469
diff changeset
   769
    ^ self children size
ca
parents: 469
diff changeset
   770
!
ca
parents: 469
diff changeset
   771
841
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   772
showIndicator
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   773
    "returns true if children exists
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   774
    "
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   775
    ^ self hasChildren
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   776
!
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   777
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   778
shown
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   779
    "returns true if node is visible
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   780
    "
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   781
    ^ hide not
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   782
! !
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   783
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   784
!TreeItem methodsFor:'recomputation'!
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   785
858
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   786
addVisibleChildrenTo:aList
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   787
    "add all visible children and sub-children to the list
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   788
    "  
838
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   789
    |item
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   790
     size "{ Class: SmallInteger }"
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   791
     idx  "{ Class: SmallInteger }"
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   792
    |
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   793
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   794
    hide ifFalse:[
841
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   795
        readChildren ifTrue:[
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   796
            self children
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   797
        ].
849
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   798
        (size := children size) ~~ 0 ifTrue:[
838
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   799
            idx := 1.
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   800
            size timesRepeat:[
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   801
                aList add:(item := children at:idx).
858
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   802
                item addVisibleChildrenTo:aList.
838
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   803
                idx := idx + 1.
d15daece0c54 optimize algorithm to get list from model and to
ca
parents: 837
diff changeset
   804
            ]
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   805
        ]
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   806
    ]
841
163dc6648f02 add more functionality
ca
parents: 838
diff changeset
   807
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   808
569
2a1014d6697c checkin from browser
ca
parents: 545
diff changeset
   809
858
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   810
!
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   811
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   812
numberOfAllVisibleChildren
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   813
    "returns number of all visible children including all the children of children
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   814
    "
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   815
    |total "{ Class: SmallInteger }"|
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   816
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   817
    hide ifTrue:[
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   818
        ^ 0
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   819
    ].
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   820
    readChildren ifTrue:[ self children ].
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   821
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   822
    (total := children size) ~~ 0 ifTrue:[
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   823
        children do:[:aChild| total := total + aChild numberOfAllVisibleChildren ].
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   824
    ].
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   825
    ^ total
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   826
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   827
0bfbe5be0541 add more functionality
ca
parents: 849
diff changeset
   828
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   829
! !
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
   830
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   831
!TreeItem methodsFor:'retrieving'!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   832
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   833
childrenAction
786
ca
parents: 784
diff changeset
   834
    "get children action block
ca
parents: 784
diff changeset
   835
    "
ca
parents: 784
diff changeset
   836
    |m|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   837
786
ca
parents: 784
diff changeset
   838
    ^ (m := self model) notNil ifTrue:[m childrenAction] ifFalse:[nil]
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   839
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   840
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   841
contentsAction
786
ca
parents: 784
diff changeset
   842
    "get contents action block
ca
parents: 784
diff changeset
   843
    "
ca
parents: 784
diff changeset
   844
    |m|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   845
786
ca
parents: 784
diff changeset
   846
    ^ (m := self model) notNil ifTrue:[m contentsAction] ifFalse:[nil]
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   847
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   848
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   849
iconAction
786
ca
parents: 784
diff changeset
   850
    "get icon action block
ca
parents: 784
diff changeset
   851
    "
ca
parents: 784
diff changeset
   852
    |m|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   853
786
ca
parents: 784
diff changeset
   854
    ^ (m := self model) notNil ifTrue:[m iconAction] ifFalse:[nil]
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   855
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   856
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   857
labelAction
786
ca
parents: 784
diff changeset
   858
    "get label action block
ca
parents: 784
diff changeset
   859
    "
ca
parents: 784
diff changeset
   860
    |m|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   861
786
ca
parents: 784
diff changeset
   862
    ^ (m := self model) notNil ifTrue:[m labelAction] ifFalse:[nil]
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   863
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   864
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   865
retrieveAll
786
ca
parents: 784
diff changeset
   866
    "retrieve all values from model
ca
parents: 784
diff changeset
   867
    "
784
f521b359ec84 #changed: mechanism extented
tz
parents: 777
diff changeset
   868
    self "retrieveContents;" retrieveLabel; retrieveChildren
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   869
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   870
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   871
retrieveAndEvaluate: aBlockSymbol
1279
2fe9b64b04b1 comment
Claus Gittinger <cg@exept.de>
parents: 1241
diff changeset
   872
    "retrieve a specific value from model; if no model exists, nil is returned
786
ca
parents: 784
diff changeset
   873
    "
2071
7c58c73eff49 use new #valueWithOptionalArg
Claus Gittinger <cg@exept.de>
parents: 2038
diff changeset
   874
    |arg model|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   875
786
ca
parents: 784
diff changeset
   876
    (model := self model) isNil ifTrue:[
ca
parents: 784
diff changeset
   877
        ^ nil
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   878
    ].
786
ca
parents: 784
diff changeset
   879
    arg := model perform:aBlockSymbol.
ca
parents: 784
diff changeset
   880
ca
parents: 784
diff changeset
   881
    arg isBlock ifFalse:[
ca
parents: 784
diff changeset
   882
        ^ arg value
ca
parents: 784
diff changeset
   883
    ].
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   884
2071
7c58c73eff49 use new #valueWithOptionalArg
Claus Gittinger <cg@exept.de>
parents: 2038
diff changeset
   885
    ^ arg valueWithOptionalArgument:self
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   886
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   887
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   888
retrieveChildren
786
ca
parents: 784
diff changeset
   889
    "retrieve children from model
ca
parents: 784
diff changeset
   890
    "
ca
parents: 784
diff changeset
   891
    |retChildren cls|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   892
786
ca
parents: 784
diff changeset
   893
    retChildren := self retrieveAndEvaluate:#childrenAction.
ca
parents: 784
diff changeset
   894
ca
parents: 784
diff changeset
   895
    retChildren notNil ifTrue:[
ca
parents: 784
diff changeset
   896
        retChildren isCollection ifFalse: [retChildren := OrderedCollection with:retChildren].
ca
parents: 784
diff changeset
   897
        cls := self class.
ca
parents: 784
diff changeset
   898
ca
parents: 784
diff changeset
   899
        self children: (retChildren collect: 
768
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
   900
        [:obj|      
786
ca
parents: 784
diff changeset
   901
            (obj isKindOf:cls) ifTrue:[obj]
ca
parents: 784
diff changeset
   902
                              ifFalse:[cls new contents:obj]       
768
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
   903
        ]). 
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
   904
        readChildren := false.
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
   905
    ].     
5fa51db3bdb5 set read children flag to false only if retrieving succeeded
tz
parents: 766
diff changeset
   906
786
ca
parents: 784
diff changeset
   907
    ^ children
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   908
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   909
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   910
retrieveContents
786
ca
parents: 784
diff changeset
   911
    "retrieve contents value from model;
ca
parents: 784
diff changeset
   912
    "
ca
parents: 784
diff changeset
   913
    |cont|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   914
786
ca
parents: 784
diff changeset
   915
    (cont := self retrieveAndEvaluate: #contentsAction) isNil ifTrue:[
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   916
        contents == UnknownContents ifTrue:[
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   917
            cont := ''
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
   918
        ]
786
ca
parents: 784
diff changeset
   919
    ].
ca
parents: 784
diff changeset
   920
    ^ contents := cont
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   921
!
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   922
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   923
retrieveLabel
786
ca
parents: 784
diff changeset
   924
    "retrieve label from model
ca
parents: 784
diff changeset
   925
    "
ca
parents: 784
diff changeset
   926
    |n|
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   927
786
ca
parents: 784
diff changeset
   928
    (n := self retrieveAndEvaluate:#labelAction) isNil ifTrue:[
ca
parents: 784
diff changeset
   929
        n := name ? ''
ca
parents: 784
diff changeset
   930
    ].
ca
parents: 784
diff changeset
   931
    ^ name := n
761
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   932
! !
d0cf8f76f1b6 supports dynamic read behavior for contents, label, children, and icon
tz
parents: 569
diff changeset
   933
479
ca
parents: 472
diff changeset
   934
!TreeItem methodsFor:'searching'!
ca
parents: 472
diff changeset
   935
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   936
childAt:anIndex
1551
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   937
    "get child at an index or nil"
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   938
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   939
    ^ self children at:anIndex ifAbsent:nil
1172
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   940
!
ab035d2357b3 add editable value and menu
ca
parents: 983
diff changeset
   941
479
ca
parents: 472
diff changeset
   942
detectChild:aOneArgBlock
1551
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   943
    "evaluate the block on each child; 
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   944
     returns the child's node or nil.
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   945
     This searches my children only - not walking down sublevels.
479
ca
parents: 472
diff changeset
   946
    "
1551
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   947
479
ca
parents: 472
diff changeset
   948
    ^ self children detect:aOneArgBlock ifNone:nil
ca
parents: 472
diff changeset
   949
ca
parents: 472
diff changeset
   950
!
ca
parents: 472
diff changeset
   951
849
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   952
detectChild:aTwoArgBlock arguments:args
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   953
    "detect a child the evaluation of the block returns true. The
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   954
     first argument to the block is the item, the second argument
1551
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   955
     the value derived from the argument list at node-level ...
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   956
     I.e. for each sublevel, a different block arg can be specified.
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   957
     The number of arguments also defines the search level.
1552
e3ad6557a3c3 comments
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
   958
     i.e. if you pass (1 to:10) as args, the block will get the sub-level
e3ad6557a3c3 comments
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
   959
     as second argument and stop the search after 10 levels.
849
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   960
    "
1551
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   961
849
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   962
    ^ self detectChild:aTwoArgBlock arguments:args index:1
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   963
!
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   964
1551
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   965
detectFirstChild:anOneArgBlock
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   966
    "detect the first child which evaluation of anOneArgBlock returns true.
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   967
     Recursively walks down the node-tree.
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   968
    "
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   969
    |node children|
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   970
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   971
    (anOneArgBlock value:self) ifTrue:[
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   972
        ^ self.
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   973
    ].
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   974
    (children := self children) notEmpty ifTrue:[
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   975
        children do:[:aChild |
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   976
            (node := aChild detectFirstChild:anOneArgBlock) notNil ifTrue:[
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   977
                ^ node
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   978
            ]
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   979
        ]
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   980
    ].  
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   981
    ^ nil
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   982
!
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   983
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   984
indexOfChild:aChild
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   985
    "get index of a child or 0
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   986
    "
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   987
    ^ aChild notNil ifTrue:[self children identityIndexOf:aChild]
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   988
                   ifFalse:[0]
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   989
! !
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   990
2498
4b4f91e57dd0 method category rename
Claus Gittinger <cg@exept.de>
parents: 2452
diff changeset
   991
!TreeItem methodsFor:'searching-private'!
1551
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   992
849
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   993
detectChild:aTwoArgBlock arguments:args index:idxArgs
1552
e3ad6557a3c3 comments
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
   994
    "helper for limited search.
e3ad6557a3c3 comments
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
   995
     detect a child the evaluation of the block returns true. The
849
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   996
     first argument to the block is the item, the second argument
1551
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   997
     the value derived from the argument list at an index.
2163ee51cb72 comments
Claus Gittinger <cg@exept.de>
parents: 1465
diff changeset
   998
     This one recursively walks down the tree searching for a node.
849
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
   999
    "
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1000
    |num node|
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1001
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1002
    (num := args size) >= idxArgs ifTrue:[
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1003
        (aTwoArgBlock value:self value:(args at:idxArgs)) ifFalse:[
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1004
            ^ nil
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1005
        ].
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1006
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1007
        idxArgs == num ifTrue:[
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1008
            ^ self
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1009
        ].
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1010
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1011
        self children notEmpty ifTrue:[
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1012
            num := idxArgs + 1.
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1013
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1014
            children do:[:aChild|
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1015
                node := aChild detectChild:aTwoArgBlock arguments:args index:num.
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1016
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1017
                node notNil ifTrue:[
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1018
                    ^ node
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1019
                ]
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1020
            ]
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1021
        ]
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1022
    ].
f7d8363fc24f support more detectItem mechanisms
ca
parents: 845
diff changeset
  1023
    ^ nil
479
ca
parents: 472
diff changeset
  1024
! !
ca
parents: 472
diff changeset
  1025
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
  1026
!TreeItem class methodsFor:'documentation'!
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
  1027
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
  1028
version
3123
8912a9a3bc01 code cleanup: use #contains instead of explicit loop
Claus Gittinger <cg@exept.de>
parents: 2930
diff changeset
  1029
    ^ '$Header: /cvs/stx/stx/libwidg2/TreeItem.st,v 1.47 2006-10-13 11:01:49 cg Exp $'
457
c0f108c6d05f intitial checkin
ca
parents:
diff changeset
  1030
! !
2404
2b7591c982ac category change
Claus Gittinger <cg@exept.de>
parents: 2102
diff changeset
  1031
1196
8f9a3c273eff use UnknownContents special object instead of nil.
Claus Gittinger <cg@exept.de>
parents: 1172
diff changeset
  1032
TreeItem initialize!