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