View.st
author claus
Tue, 09 May 1995 02:23:52 +0200
changeset 140 0db355079dc4
parent 135 cf8e46015072
child 143 b237b9013f51
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
48194c26a46c Initial revision
claus
parents:
diff changeset
     1
"
6
7ee0cfde237d *** empty log message ***
claus
parents: 5
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
72
3e84121988c3 *** empty log message ***
claus
parents: 60
diff changeset
     3
	      All Rights Reserved
0
48194c26a46c Initial revision
claus
parents:
diff changeset
     4
48194c26a46c Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
48194c26a46c Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
48194c26a46c Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
48194c26a46c Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
48194c26a46c Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
48194c26a46c Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
48194c26a46c Initial revision
claus
parents:
diff changeset
    11
"
48194c26a46c Initial revision
claus
parents:
diff changeset
    12
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
    13
'From Smalltalk/X, Version:2.10.5 on 14-mar-1995 at 11:02:34 am'!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
    14
135
claus
parents: 133
diff changeset
    15
SimpleView subclass:#View
claus
parents: 133
diff changeset
    16
	 instanceVariableNames:'model aspectMsg changeMsg menuMsg'
claus
parents: 133
diff changeset
    17
	 classVariableNames:''
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
    18
	 poolDictionaries:''
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
    19
	 category:'Views-Basic'
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    20
!
48194c26a46c Initial revision
claus
parents:
diff changeset
    21
48194c26a46c Initial revision
claus
parents:
diff changeset
    22
View comment:'
135
claus
parents: 133
diff changeset
    23
COPYRIGHT (c) 1995 by Claus Gittinger
72
3e84121988c3 *** empty log message ***
claus
parents: 60
diff changeset
    24
	      All Rights Reserved
3e84121988c3 *** empty log message ***
claus
parents: 60
diff changeset
    25
140
claus
parents: 135
diff changeset
    26
$Header: /cvs/stx/stx/libview/View.st,v 1.42 1995-05-09 00:23:01 claus Exp $
2
b35336ab0de3 *** empty log message ***
claus
parents: 0
diff changeset
    27
'!
b35336ab0de3 *** empty log message ***
claus
parents: 0
diff changeset
    28
b35336ab0de3 *** empty log message ***
claus
parents: 0
diff changeset
    29
!View class methodsFor:'documentation'!
41
08a32edcaaa0 *** empty log message ***
claus
parents: 36
diff changeset
    30
46
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    31
copyright
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    32
"
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    33
 COPYRIGHT (c) 1989 by Claus Gittinger
72
3e84121988c3 *** empty log message ***
claus
parents: 60
diff changeset
    34
	      All Rights Reserved
46
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    35
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    36
 This software is furnished under a license and may be used
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    37
 only in accordance with the terms of that license and with the
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    38
 inclusion of the above copyright notice.   This software may not
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    39
 be provided or otherwise made available to, or used by, any
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    40
 other person.  No title to or ownership of the software is
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    41
 hereby transferred.
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    42
"
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    43
!
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    44
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    45
version
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    46
"
140
claus
parents: 135
diff changeset
    47
$Header: /cvs/stx/stx/libview/View.st,v 1.42 1995-05-09 00:23:01 claus Exp $
46
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    48
"
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    49
!
7b331e9012fd *** empty log message ***
claus
parents: 42
diff changeset
    50
41
08a32edcaaa0 *** empty log message ***
claus
parents: 36
diff changeset
    51
documentation
2
b35336ab0de3 *** empty log message ***
claus
parents: 0
diff changeset
    52
"
135
claus
parents: 133
diff changeset
    53
    this class adds provisions for views which show or work on a model.
claus
parents: 133
diff changeset
    54
    This functionality used to be in View, but has been extracted into SimpleView and
claus
parents: 133
diff changeset
    55
    this new View class, to take some of the stuff out of views which do not need
claus
parents: 133
diff changeset
    56
    this functionality (i.e. all views which do only geometry management).
82
98a70bce6d51 *** empty log message ***
claus
parents: 81
diff changeset
    57
    Instances of View are seldom used, most views in the system inherit 
98a70bce6d51 *** empty log message ***
claus
parents: 81
diff changeset
    58
    from this class. 
41
08a32edcaaa0 *** empty log message ***
claus
parents: 36
diff changeset
    59
08a32edcaaa0 *** empty log message ***
claus
parents: 36
diff changeset
    60
    Instance variables:
08a32edcaaa0 *** empty log message ***
claus
parents: 36
diff changeset
    61
135
claus
parents: 133
diff changeset
    62
	model           <nil | any>         the model (if any)
140
claus
parents: 135
diff changeset
    63
135
claus
parents: 133
diff changeset
    64
	aspectMsg       <nil | Symbol>      the aspect; typically
claus
parents: 133
diff changeset
    65
					    dependentViews react on changes
claus
parents: 133
diff changeset
    66
					    of this aspect and update their contents.
140
claus
parents: 135
diff changeset
    67
135
claus
parents: 133
diff changeset
    68
	changeMsg       <nil | Symbol>      the changeMessage; typically
claus
parents: 133
diff changeset
    69
					    dependentViews send this message to
claus
parents: 133
diff changeset
    70
					    the model to tell it about changes.
140
claus
parents: 135
diff changeset
    71
135
claus
parents: 133
diff changeset
    72
	menuMsg         <nil | Symbol>      the menuMessage; typically
claus
parents: 133
diff changeset
    73
					    dependentViews send this message to
claus
parents: 133
diff changeset
    74
					    the model to ask for a popup menu.
140
claus
parents: 135
diff changeset
    75
					    Some classes allow setting an explicit
claus
parents: 135
diff changeset
    76
					    menuHolder and menuPerformer.
2
b35336ab0de3 *** empty log message ***
claus
parents: 0
diff changeset
    77
"
b35336ab0de3 *** empty log message ***
claus
parents: 0
diff changeset
    78
! !
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    79
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
    80
!View class methodsFor:'instance creation'!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
    81
140
claus
parents: 135
diff changeset
    82
on:aModel aspect:aspectMsg
claus
parents: 135
diff changeset
    83
    "st-80 style view creation: create a new view, set its model
claus
parents: 135
diff changeset
    84
     and selectors for aspect"
claus
parents: 135
diff changeset
    85
claus
parents: 135
diff changeset
    86
    ^ self new 
claus
parents: 135
diff changeset
    87
	on:aModel
claus
parents: 135
diff changeset
    88
	aspect:aspectMsg
claus
parents: 135
diff changeset
    89
!
claus
parents: 135
diff changeset
    90
claus
parents: 135
diff changeset
    91
on:aModel aspect:aspectMsg change:changeMsg
claus
parents: 135
diff changeset
    92
    "st-80 style view creation: create a new view, set its model
claus
parents: 135
diff changeset
    93
     and selectors for aspect and change"
claus
parents: 135
diff changeset
    94
claus
parents: 135
diff changeset
    95
    ^ self new 
claus
parents: 135
diff changeset
    96
	on:aModel
claus
parents: 135
diff changeset
    97
	aspect:aspectMsg
claus
parents: 135
diff changeset
    98
	change:changeMsg
claus
parents: 135
diff changeset
    99
!
claus
parents: 135
diff changeset
   100
claus
parents: 135
diff changeset
   101
on:aModel aspect:aspectMsg menu:menuMsg
claus
parents: 135
diff changeset
   102
    "st-80 style view creation: create a new view, set its model
claus
parents: 135
diff changeset
   103
     and selectors for aspect and menu"
claus
parents: 135
diff changeset
   104
claus
parents: 135
diff changeset
   105
    ^ self new 
claus
parents: 135
diff changeset
   106
	on:aModel
claus
parents: 135
diff changeset
   107
	aspect:aspectMsg
claus
parents: 135
diff changeset
   108
	menu:menuMsg
claus
parents: 135
diff changeset
   109
!
claus
parents: 135
diff changeset
   110
135
claus
parents: 133
diff changeset
   111
on:aModel aspect:aspectMsg change:changeMsg menu:menuMsg
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   112
    "st-80 style view creation: create a new view, set its model
140
claus
parents: 135
diff changeset
   113
     and selectors for aspect, change and menu"
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   114
135
claus
parents: 133
diff changeset
   115
    ^ self new 
claus
parents: 133
diff changeset
   116
	on:aModel
claus
parents: 133
diff changeset
   117
	aspect:aspectMsg
claus
parents: 133
diff changeset
   118
	change:changeMsg
claus
parents: 133
diff changeset
   119
	menu:menuMsg
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   120
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   121
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   122
model:aModel
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   123
    "st-80 style view creation: create a new view and set its model"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   124
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   125
    ^ self new model:aModel
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   126
! !
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   127
123
9f8c7f20fdb2 *** empty log message ***
claus
parents: 121
diff changeset
   128
!View class methodsFor:'defaults'!
9f8c7f20fdb2 *** empty log message ***
claus
parents: 121
diff changeset
   129
140
claus
parents: 135
diff changeset
   130
defaultAspectMessage   
135
claus
parents: 133
diff changeset
   131
    "subclasses which by default do NOT want to be informed about changed
claus
parents: 133
diff changeset
   132
     models should redefine this to return nil"
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   133
135
claus
parents: 133
diff changeset
   134
    ^ #value
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   135
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   136
140
claus
parents: 135
diff changeset
   137
defaultChangeMessage   
135
claus
parents: 133
diff changeset
   138
    "subclasses which by default do NOT want to inform the model
claus
parents: 133
diff changeset
   139
     should redefine this to return nil"
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   140
135
claus
parents: 133
diff changeset
   141
    ^ #value:
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   142
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
   143
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   144
!View methodsFor:'accessing-mvc'!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   145
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   146
sendChangeMessageWith:arg
135
claus
parents: 133
diff changeset
   147
    "tell the model about a change"
claus
parents: 133
diff changeset
   148
claus
parents: 133
diff changeset
   149
    self sendChangeMessage:changeMsg with:arg
claus
parents: 133
diff changeset
   150
!
claus
parents: 133
diff changeset
   151
claus
parents: 133
diff changeset
   152
sendChangeMessage:aSelector with:arg
claus
parents: 133
diff changeset
   153
    "tell the model about a change"
claus
parents: 133
diff changeset
   154
claus
parents: 133
diff changeset
   155
    |n selector|
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   156
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   157
    "/
135
claus
parents: 133
diff changeset
   158
    "/ MVC way of doing it:
claus
parents: 133
diff changeset
   159
    "/ if the model is a block, evaluate it, optionally
claus
parents: 133
diff changeset
   160
    "/ passing the arg and the receiver as arguments.
140
claus
parents: 135
diff changeset
   161
    "/
135
claus
parents: 133
diff changeset
   162
    "/ otherwise (the common case) send it a changeMsg message
claus
parents: 133
diff changeset
   163
    "/ also with arg and the receiver (depending on the number of arguments
140
claus
parents: 135
diff changeset
   164
    "/ as defined by the selector).
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   165
    "/
135
claus
parents: 133
diff changeset
   166
    (model notNil and:[aSelector notNil]) ifTrue:[
claus
parents: 133
diff changeset
   167
	n := aSelector numArgs.
claus
parents: 133
diff changeset
   168
	model isBlock ifTrue:[
claus
parents: 133
diff changeset
   169
	    n := model numArgs.
claus
parents: 133
diff changeset
   170
	    n == 0 ifTrue:[
claus
parents: 133
diff changeset
   171
		selector := #value
claus
parents: 133
diff changeset
   172
	    ] ifFalse:[
claus
parents: 133
diff changeset
   173
		n == 1 ifTrue:[
claus
parents: 133
diff changeset
   174
		    selector := #value:
claus
parents: 133
diff changeset
   175
		] ifFalse:[
claus
parents: 133
diff changeset
   176
		    selector := #value:value:
claus
parents: 133
diff changeset
   177
		]
claus
parents: 133
diff changeset
   178
	    ]
claus
parents: 133
diff changeset
   179
	] ifFalse:[
claus
parents: 133
diff changeset
   180
	    selector := aSelector
claus
parents: 133
diff changeset
   181
	].
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   182
	n == 0 ifTrue:[
135
claus
parents: 133
diff changeset
   183
	    model perform:selector 
107
ef48048a8b34 *** empty log message ***
claus
parents: 98
diff changeset
   184
	] ifFalse:[
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   185
	    n == 1 ifTrue:[
135
claus
parents: 133
diff changeset
   186
		model perform:selector with:arg
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   187
	    ] ifFalse:[
135
claus
parents: 133
diff changeset
   188
		model perform:selector with:arg with:self 
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   189
	    ]
72
3e84121988c3 *** empty log message ***
claus
parents: 60
diff changeset
   190
	]
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   191
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   192
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   193
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   194
model
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   195
    "return the model, for non-MVC views,
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   196
     this is nil or the receiver"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   197
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   198
    ^ model
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   199
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   200
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   201
model:aModel
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   202
    "set the model"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   203
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   204
    model notNil ifTrue:[
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   205
	model removeDependent:self
89
ea2bf46eb669 *** empty log message ***
claus
parents: 87
diff changeset
   206
    ].
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   207
    model := aModel.
135
claus
parents: 133
diff changeset
   208
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   209
    model notNil ifTrue:[
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   210
	aModel addDependent:self
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   211
    ].
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   212
    controller notNil ifTrue:[
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   213
	controller model:aModel
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   214
    ]
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   215
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   216
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   217
controller:aController
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   218
    "set the controller"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   219
135
claus
parents: 133
diff changeset
   220
    super controller:aController.
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   221
    controller notNil ifTrue:[
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   222
	controller model:model
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   223
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   224
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   225
135
claus
parents: 133
diff changeset
   226
on:aModel aspect:aspectSymbol
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   227
    "ST-80 compatibility: set model and aspect
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   228
     messages - needs a view which uses these"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   229
135
claus
parents: 133
diff changeset
   230
    aspectMsg := aspectSymbol.
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   231
    self model:aModel.
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   232
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   233
135
claus
parents: 133
diff changeset
   234
on:aModel aspect:aspectSymbol menu:menuSymbol
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   235
    "ST-80 compatibility: set model, aspect and menu
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   236
     messages - needs a view which uses these"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   237
135
claus
parents: 133
diff changeset
   238
    aspectMsg := aspectSymbol.
claus
parents: 133
diff changeset
   239
    menuMsg := menuSymbol.
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   240
    self model:aModel.
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   241
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   242
140
claus
parents: 135
diff changeset
   243
on:aModel aspect:aspectSymbol change:changeSymbol
claus
parents: 135
diff changeset
   244
    "ST-80 compatibility: set model, aspect and change
claus
parents: 135
diff changeset
   245
     messages - needs a view which uses these"
claus
parents: 135
diff changeset
   246
claus
parents: 135
diff changeset
   247
    aspectMsg := aspectSymbol.
claus
parents: 135
diff changeset
   248
    changeMsg := changeSymbol.
claus
parents: 135
diff changeset
   249
    self model:aModel.
claus
parents: 135
diff changeset
   250
!
claus
parents: 135
diff changeset
   251
135
claus
parents: 133
diff changeset
   252
on:aModel aspect:aspectSymbol change:changeSymbol menu:menuSymbol
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   253
    "ST-80 compatibility: set model, aspect, change and menu
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   254
     messages - needs a view which uses these"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   255
135
claus
parents: 133
diff changeset
   256
    aspectMsg := aspectSymbol.
claus
parents: 133
diff changeset
   257
    changeMsg := changeSymbol.
claus
parents: 133
diff changeset
   258
    menuMsg := menuSymbol.
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   259
    self model:aModel.
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   260
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   261
140
claus
parents: 135
diff changeset
   262
menuMessage:aSymbol
claus
parents: 135
diff changeset
   263
    "ST-80 style menus: If a views menuSymbol is nonNil, it
claus
parents: 135
diff changeset
   264
     will send it to its model when the middleButton is pressed.
claus
parents: 135
diff changeset
   265
     That method should return nil or the menu to be shown.
claus
parents: 135
diff changeset
   266
     This is useful for very dynamic menus, where it does not
claus
parents: 135
diff changeset
   267
     make sense to define an initial menu.
claus
parents: 135
diff changeset
   268
     This is the same as #menu: which was added for ST-80 compatibility."
claus
parents: 135
diff changeset
   269
claus
parents: 135
diff changeset
   270
    menuMsg := aSymbol
claus
parents: 135
diff changeset
   271
!
claus
parents: 135
diff changeset
   272
claus
parents: 135
diff changeset
   273
menuMessage
claus
parents: 135
diff changeset
   274
    "Return the symbol sent to the model to aquire the menu"
claus
parents: 135
diff changeset
   275
claus
parents: 135
diff changeset
   276
    ^ menuMsg
claus
parents: 135
diff changeset
   277
!
claus
parents: 135
diff changeset
   278
135
claus
parents: 133
diff changeset
   279
menu:menuSymbol
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   280
    "ST-80 style menus: If a views menuSymbol is nonNil, it
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   281
     will send it to its model when the middleButton is pressed.
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   282
     That method should return nil or the menu to be shown.
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   283
     This is useful for very dynamic menus, where it does not
140
claus
parents: 135
diff changeset
   284
     make sense to define an initial menu.
claus
parents: 135
diff changeset
   285
     Alias for #menuMessage:, for ST-80 compatibility."
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   286
135
claus
parents: 133
diff changeset
   287
    menuMsg := menuSymbol
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   288
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   289
140
claus
parents: 135
diff changeset
   290
changeMessage:aSymbol
claus
parents: 135
diff changeset
   291
    "ST-80 style change notification: If a views changeSymbol is nonNil, 
claus
parents: 135
diff changeset
   292
     it will send it to its model when something changes.
claus
parents: 135
diff changeset
   293
     This is the same as change: which was added for ST-80 compatibility."
claus
parents: 135
diff changeset
   294
claus
parents: 135
diff changeset
   295
    changeMsg := aSymbol
claus
parents: 135
diff changeset
   296
!
claus
parents: 135
diff changeset
   297
claus
parents: 135
diff changeset
   298
changeMessage
claus
parents: 135
diff changeset
   299
    "Return the symbol sent to the model if nonNil when something changes."
claus
parents: 135
diff changeset
   300
claus
parents: 135
diff changeset
   301
    ^ changeMsg
claus
parents: 135
diff changeset
   302
!
claus
parents: 135
diff changeset
   303
135
claus
parents: 133
diff changeset
   304
change:changeSymbol
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   305
    "ST-80 style change notification: If a views changeSymbol is nonNil, 
140
claus
parents: 135
diff changeset
   306
     it will send it to its model when something changes.
claus
parents: 135
diff changeset
   307
     Alias for changeMessage: for ST-80 compatibility."
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   308
135
claus
parents: 133
diff changeset
   309
    changeMsg := changeSymbol
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   310
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   311
135
claus
parents: 133
diff changeset
   312
aspect:aspectSymbol
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   313
    "ST-80 style updating: If a views aspectSymbol is nonNil, 
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   314
     it will respond to changes of this aspect from the model."
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   315
135
claus
parents: 133
diff changeset
   316
    aspectMsg := aspectSymbol
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   317
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   318
140
claus
parents: 135
diff changeset
   319
aspect
claus
parents: 135
diff changeset
   320
    "Return the aspect used with changes from/to the model"
72
3e84121988c3 *** empty log message ***
claus
parents: 60
diff changeset
   321
140
claus
parents: 135
diff changeset
   322
    ^ aspectMsg
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   323
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   324
135
claus
parents: 133
diff changeset
   325
aspectMessage
claus
parents: 133
diff changeset
   326
    "Return the aspect used with changes from/to the model"
60
d7e4d835cbaf new openAutonomous for subviews in own group
claus
parents: 54
diff changeset
   327
135
claus
parents: 133
diff changeset
   328
    ^ aspectMsg
140
claus
parents: 135
diff changeset
   329
!
claus
parents: 135
diff changeset
   330
claus
parents: 135
diff changeset
   331
addModelInterfaceTo:aDictionary
claus
parents: 135
diff changeset
   332
    "this adds entries for all messages sent to my model
claus
parents: 135
diff changeset
   333
     to aDictionary"
claus
parents: 135
diff changeset
   334
claus
parents: 135
diff changeset
   335
    aDictionary at:#aspectMessage put:aspectMsg.
claus
parents: 135
diff changeset
   336
    aDictionary at:#changeMessage put:changeMsg.
claus
parents: 135
diff changeset
   337
    aDictionary at:#menuMessage put:menuMsg.
claus
parents: 135
diff changeset
   338
claus
parents: 135
diff changeset
   339
    "
claus
parents: 135
diff changeset
   340
     Button new modelInterface 
claus
parents: 135
diff changeset
   341
    "
claus
parents: 135
diff changeset
   342
!
claus
parents: 135
diff changeset
   343
claus
parents: 135
diff changeset
   344
modelInterface
claus
parents: 135
diff changeset
   345
    "this returns a dictionary of messages sent to my model.
claus
parents: 135
diff changeset
   346
     It can be used for builders and wrappers to get information
claus
parents: 135
diff changeset
   347
     about the messages sent to my model.
claus
parents: 135
diff changeset
   348
     The returned dictionary contains one entry for each get-Msg,
claus
parents: 135
diff changeset
   349
     and the recevier will implement corresponding messages (with a colon)
claus
parents: 135
diff changeset
   350
     to set the message symbol."
claus
parents: 135
diff changeset
   351
claus
parents: 135
diff changeset
   352
    |d|
claus
parents: 135
diff changeset
   353
claus
parents: 135
diff changeset
   354
    d := IdentityDictionary new.
claus
parents: 135
diff changeset
   355
    self addModelInterfaceTo:d.
claus
parents: 135
diff changeset
   356
    ^ d
claus
parents: 135
diff changeset
   357
claus
parents: 135
diff changeset
   358
    "
claus
parents: 135
diff changeset
   359
     Button new modelInterface
claus
parents: 135
diff changeset
   360
     Label new modelInterface 
claus
parents: 135
diff changeset
   361
    "
claus
parents: 135
diff changeset
   362
claus
parents: 135
diff changeset
   363
    "
claus
parents: 135
diff changeset
   364
     does the view support setting the menuMessage ?
claus
parents: 135
diff changeset
   365
claus
parents: 135
diff changeset
   366
     SelectionInListView new modelInterface includesKey:#menuMessage 
claus
parents: 135
diff changeset
   367
    "
claus
parents: 135
diff changeset
   368
claus
parents: 135
diff changeset
   369
    "
claus
parents: 135
diff changeset
   370
     turn off all interaction to the model:
claus
parents: 135
diff changeset
   371
claus
parents: 135
diff changeset
   372
     |m v if|
claus
parents: 135
diff changeset
   373
claus
parents: 135
diff changeset
   374
     m := SelectionInList new.
claus
parents: 135
diff changeset
   375
     m list:#('one' 'two' 'tree' 'four') asValue.
claus
parents: 135
diff changeset
   376
     m selection:1 asValue.
claus
parents: 135
diff changeset
   377
     v := SelectionInListView on:m.
claus
parents: 135
diff changeset
   378
     v open.
claus
parents: 135
diff changeset
   379
     v inspect.
claus
parents: 135
diff changeset
   380
claus
parents: 135
diff changeset
   381
     if := v modelInterface.
claus
parents: 135
diff changeset
   382
     if inspect.
claus
parents: 135
diff changeset
   383
claus
parents: 135
diff changeset
   384
     if keysAndValuesDo:[:what :msg |
claus
parents: 135
diff changeset
   385
	 v perform:(what , ':') asSymbol with:nil.
claus
parents: 135
diff changeset
   386
     ].
claus
parents: 135
diff changeset
   387
    "
72
3e84121988c3 *** empty log message ***
claus
parents: 60
diff changeset
   388
! !
3e84121988c3 *** empty log message ***
claus
parents: 60
diff changeset
   389
135
claus
parents: 133
diff changeset
   390
!View methodsFor:'accessing-menus'!
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   391
135
claus
parents: 133
diff changeset
   392
menuHolder
claus
parents: 133
diff changeset
   393
    "who has the menu ? 
claus
parents: 133
diff changeset
   394
     By default, its the model if I have one."
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   395
135
claus
parents: 133
diff changeset
   396
    model notNil ifTrue:[^ model].
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   397
    ^ self
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   398
!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   399
135
claus
parents: 133
diff changeset
   400
menuPerformer
claus
parents: 133
diff changeset
   401
    "who should perform the menu actions ? 
claus
parents: 133
diff changeset
   402
     By default, its the model if I have one."
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   403
135
claus
parents: 133
diff changeset
   404
    model notNil ifTrue:[^ model].
claus
parents: 133
diff changeset
   405
    ^ self
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   406
! !
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   407
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   408
!View methodsFor:'initialization'!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   409
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   410
initialize
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   411
    super initialize.
140
claus
parents: 135
diff changeset
   412
claus
parents: 135
diff changeset
   413
    aspectMsg := self class defaultAspectMessage.
claus
parents: 135
diff changeset
   414
    changeMsg := self class defaultChangeMessage.
claus
parents: 135
diff changeset
   415
135
claus
parents: 133
diff changeset
   416
    model notNil ifTrue:[
claus
parents: 133
diff changeset
   417
	controller notNil ifTrue:[
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   418
	    controller model:model
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   419
	]
81
4ba554473294 *** empty log message ***
claus
parents: 78
diff changeset
   420
    ].
118
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   421
! !
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   422
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   423
!View methodsFor:'drawing'!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   424
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   425
redraw
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   426
    "redraw myself
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   427
     if there is a model, this one shall redraw itself,
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   428
     otherwise we cannot do much here - has to be redefined in subclasses"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   429
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   430
    model notNil ifTrue:[
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   431
	model update:self
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   432
    ]
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   433
! !
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   434
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   435
!View methodsFor:'realization'!
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   436
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   437
destroy
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   438
    "unrealize & destroy - make me invisible, destroy subviews then
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   439
     make me unknown to the device"
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   440
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   441
    model notNil ifTrue:[
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   442
	model removeDependent:self.
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   443
	model := nil.
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   444
    ].
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   445
    super destroy.
25e775072a89 *** empty log message ***
claus
parents: 116
diff changeset
   446
! !