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