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