ActiveHelp.st
author Claus Gittinger <cg@exept.de>
Thu, 25 Apr 1996 13:09:36 +0200
changeset 216 a5f97668e99a
parent 138 492fb73ca439
child 221 ea942fe5dc04
permissions -rw-r--r--
commentary
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     1
"
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1995 by Claus Gittinger
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     3
	      All Rights Reserved
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     4
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    11
"
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    12
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    13
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    14
EventListener subclass:#ActiveHelp
216
a5f97668e99a commentary
Claus Gittinger <cg@exept.de>
parents: 138
diff changeset
    15
	instanceVariableNames:'currentView currentHelpView currentFrame showProcess closeProcess'
a5f97668e99a commentary
Claus Gittinger <cg@exept.de>
parents: 138
diff changeset
    16
	classVariableNames:'DelayTime ShowTime TheOneAndOnlyHelpListener'
a5f97668e99a commentary
Claus Gittinger <cg@exept.de>
parents: 138
diff changeset
    17
	poolDictionaries:''
a5f97668e99a commentary
Claus Gittinger <cg@exept.de>
parents: 138
diff changeset
    18
	category:'Interface-Help'
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    19
!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    20
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    21
!ActiveHelp class methodsFor:'documentation'!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    22
138
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    23
copyright
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    24
"
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    25
 COPYRIGHT (c) 1995 by Claus Gittinger
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    26
	      All Rights Reserved
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    27
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    28
 This software is furnished under a license and may be used
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    29
 only in accordance with the terms of that license and with the
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    31
 be provided or otherwise made available to, or used by, any
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    32
 other person.  No title to or ownership of the software is
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    33
 hereby transferred.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    34
"
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    35
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    36
!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    37
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    38
documentation
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
    39
"
98
claus
parents: 97
diff changeset
    40
    The active help listener.
claus
parents: 97
diff changeset
    41
    The one and only instance of myself intercepts incoming mouse & keyboard 
claus
parents: 97
diff changeset
    42
    events for the display device, being especially interested in view-enter/
100
claus
parents: 98
diff changeset
    43
    leave enents. When such an event arrives, it asks the corresponding view
98
claus
parents: 97
diff changeset
    44
    or its model for a help message and display it via an ActiveHelpView.
100
claus
parents: 98
diff changeset
    45
    This query is repeated along the views superView chain, until any model or
claus
parents: 98
diff changeset
    46
    view returns a nonNil answer for the #helpTextFor:at or #helpTextFor
claus
parents: 98
diff changeset
    47
    message.
claus
parents: 98
diff changeset
    48
98
claus
parents: 97
diff changeset
    49
    All I need for automatic help is some model/view/applicationModel along
claus
parents: 97
diff changeset
    50
    the superview chain of the entered component, which responds to the
claus
parents: 97
diff changeset
    51
    #helpTextFor: message with a non-nil (string-) answer.
claus
parents: 97
diff changeset
    52
    I close down the help view after a while, if a key is pressed or the mouse
claus
parents: 97
diff changeset
    53
    moved to another view.
100
claus
parents: 98
diff changeset
    54
claus
parents: 98
diff changeset
    55
    Who should provide the helpText:
claus
parents: 98
diff changeset
    56
claus
parents: 98
diff changeset
    57
	the best place is the application object (an instance of ApplicationModel)
claus
parents: 98
diff changeset
    58
	or the topView, if its a derived class of StandardSystemView.
claus
parents: 98
diff changeset
    59
	This should know about its components and return the string
claus
parents: 98
diff changeset
    60
	when asked via #helpTextFor:aComponent.
claus
parents: 98
diff changeset
    61
	See examples in FileBrowser, NewLauncher etc.
claus
parents: 98
diff changeset
    62
claus
parents: 98
diff changeset
    63
    Be aware, that for applicationModels, there must be a link from the
claus
parents: 98
diff changeset
    64
    topView to this applicationModel 
claus
parents: 98
diff changeset
    65
    (set via: aTopView application:anApplicationModel)
claus
parents: 98
diff changeset
    66
    otherwise, the helpManager has no means of finding the application which
claus
parents: 98
diff changeset
    67
    corresponds to a view.
claus
parents: 98
diff changeset
    68
claus
parents: 98
diff changeset
    69
    Who should display the helpText:
claus
parents: 98
diff changeset
    70
claus
parents: 98
diff changeset
    71
	by default, the helpListener opens a little popup view, which displays the
claus
parents: 98
diff changeset
    72
	returned help message. However, a nice trick which can be used by applications
claus
parents: 98
diff changeset
    73
	is to create an infoLabel as a subview of the topFrame (a la windows)
claus
parents: 98
diff changeset
    74
	and display the text right in the #helpTextFor: method. To cheat the
claus
parents: 98
diff changeset
    75
	help listener, this method should then return nil, to keep it silent.
claus
parents: 98
diff changeset
    76
"
claus
parents: 98
diff changeset
    77
!
claus
parents: 98
diff changeset
    78
claus
parents: 98
diff changeset
    79
examples
claus
parents: 98
diff changeset
    80
"
claus
parents: 98
diff changeset
    81
    (make certain that activeHelp is turned on ...)
claus
parents: 98
diff changeset
    82
claus
parents: 98
diff changeset
    83
    the following example uses a Plug as a model replacement.
claus
parents: 98
diff changeset
    84
    In concrete application, you would create a method to implement the helpText
claus
parents: 98
diff changeset
    85
    query message.
claus
parents: 98
diff changeset
    86
claus
parents: 98
diff changeset
    87
	|app top button1 button2|
claus
parents: 98
diff changeset
    88
claus
parents: 98
diff changeset
    89
	app := Plug new.
claus
parents: 98
diff changeset
    90
	app respondTo:#helpTextFor:
claus
parents: 98
diff changeset
    91
		 with:[:view | 
claus
parents: 98
diff changeset
    92
			       view == button1 ifTrue:[
claus
parents: 98
diff changeset
    93
				 'this is button1'
claus
parents: 98
diff changeset
    94
			       ] ifFalse:[
claus
parents: 98
diff changeset
    95
				 view == button2 ifTrue:[
claus
parents: 98
diff changeset
    96
				   'some help for button2'
claus
parents: 98
diff changeset
    97
				 ] ifFalse:[
claus
parents: 98
diff changeset
    98
				   nil
claus
parents: 98
diff changeset
    99
				 ]
claus
parents: 98
diff changeset
   100
			       ]
claus
parents: 98
diff changeset
   101
		      ].
claus
parents: 98
diff changeset
   102
claus
parents: 98
diff changeset
   103
	top := StandardSystemView new.
claus
parents: 98
diff changeset
   104
	top extent:300@100.
claus
parents: 98
diff changeset
   105
	button1 := Button label:'b1' in:top.
claus
parents: 98
diff changeset
   106
	button1 origin:0.0@0.0 corner:0.5@30. 
claus
parents: 98
diff changeset
   107
	button2 := Button label:'b2' in:top.
claus
parents: 98
diff changeset
   108
	button2 origin:0.5@0.0 corner:1.0@30.
claus
parents: 98
diff changeset
   109
	top model:app. '<-- normally this would be: top application:app'.
claus
parents: 98
diff changeset
   110
	top open
claus
parents: 98
diff changeset
   111
claus
parents: 98
diff changeset
   112
    alternative, display of the helpMessage in a local, private view:
claus
parents: 98
diff changeset
   113
claus
parents: 98
diff changeset
   114
	|app top button1 button2 infoView|
claus
parents: 98
diff changeset
   115
claus
parents: 98
diff changeset
   116
	app := Plug new.
claus
parents: 98
diff changeset
   117
	app respondTo:#helpTextFor:
claus
parents: 98
diff changeset
   118
		 with:[:view | infoView label:'info ...'.
claus
parents: 98
diff changeset
   119
			       view == button1 ifTrue:[
claus
parents: 98
diff changeset
   120
				 infoView label:'this is button1'
claus
parents: 98
diff changeset
   121
			       ].
claus
parents: 98
diff changeset
   122
			       view == button2 ifTrue:[
claus
parents: 98
diff changeset
   123
				 infoView label:'some help for button2'
claus
parents: 98
diff changeset
   124
			       ].
claus
parents: 98
diff changeset
   125
			       nil
claus
parents: 98
diff changeset
   126
		      ].
claus
parents: 98
diff changeset
   127
claus
parents: 98
diff changeset
   128
	top := StandardSystemView new.
claus
parents: 98
diff changeset
   129
	top extent:300@100.
claus
parents: 98
diff changeset
   130
	button1 := Button label:'b1' in:top.
claus
parents: 98
diff changeset
   131
	button1 origin:0.0@0.0 corner:0.5@30. 
claus
parents: 98
diff changeset
   132
	button2 := Button label:'b2' in:top.
claus
parents: 98
diff changeset
   133
	button2 origin:0.5@0.0 corner:1.0@30.
claus
parents: 98
diff changeset
   134
	infoView := Label label:'info ...' in:top.
claus
parents: 98
diff changeset
   135
	infoView level:-1; origin:0.0@1.0 corner:1.0@1.0.
claus
parents: 98
diff changeset
   136
	infoView topInset:(infoView preferredExtent y negated - 3);
claus
parents: 98
diff changeset
   137
		 leftInset:3; 
claus
parents: 98
diff changeset
   138
		 rightInset:3; 
claus
parents: 98
diff changeset
   139
		 bottomInset:3;
claus
parents: 98
diff changeset
   140
		 adjust:#left.
claus
parents: 98
diff changeset
   141
	top model:app. '<-- normally this would be: top application:app'.
claus
parents: 98
diff changeset
   142
	top open
claus
parents: 98
diff changeset
   143
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   144
"
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   145
! !
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   146
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   147
!ActiveHelp class methodsFor:'initialization'!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   148
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   149
initialize
92
claus
parents: 59
diff changeset
   150
    ShowTime := 15.
100
claus
parents: 98
diff changeset
   151
    DelayTime := 2.
92
claus
parents: 59
diff changeset
   152
claus
parents: 59
diff changeset
   153
    "
claus
parents: 59
diff changeset
   154
     ActiveHelp initialize
claus
parents: 59
diff changeset
   155
    "
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   156
! !
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   157
138
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   158
!ActiveHelp class methodsFor:'startup'!
100
claus
parents: 98
diff changeset
   159
138
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   160
isActive 
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   161
    ^ TheOneAndOnlyHelpListener notNil
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   162
!
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   163
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   164
start
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   165
    TheOneAndOnlyHelpListener isNil ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   166
	TheOneAndOnlyHelpListener := self new.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   167
    ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   168
    TheOneAndOnlyHelpListener listen
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   169
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   170
    "
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   171
     ActiveHelp start
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   172
    "
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   173
!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   174
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   175
stop
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   176
    TheOneAndOnlyHelpListener notNil ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   177
	TheOneAndOnlyHelpListener unlisten.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   178
    ].
92
claus
parents: 59
diff changeset
   179
    TheOneAndOnlyHelpListener := nil
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   180
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   181
    "
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   182
     ActiveHelp stop
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   183
    "
138
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   184
! !
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   185
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   186
!ActiveHelp class methodsFor:'times'!
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   187
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   188
delayTime:numberOfSeconds
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   189
    "set the delay (the time, the cursor has to be in the view
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   190
     before help is shown). The default is 2 seconds."
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   191
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   192
    DelayTime := numberOfSeconds
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   193
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   194
    "
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   195
     ActiveHelp delayTime:0.5
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   196
     ActiveHelp delayTime:2
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   197
     ActiveHelp delayTime:10
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   198
    "
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   199
!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   200
138
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   201
showTime:numberOfSeconds
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   202
    "set the number of seconds, a help messages is to be shown.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   203
     The default is 15 seconds."
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   204
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   205
    ShowTime := numberOfSeconds
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   206
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   207
    "
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   208
     ActiveHelp showTime:10
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   209
     ActiveHelp showTime:99999 
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   210
     ActiveHelp showTime:30
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   211
    "
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   212
! !
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   213
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   214
!ActiveHelp methodsFor:'listening'!
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   215
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   216
buttonMotion:state x:x y:y view:view
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   217
    self hideIfPointerLeft:view.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   218
    ^ false
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   219
!
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   220
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   221
buttonPress:state x:x y:y view:view
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   222
    self hideHelp.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   223
    ^ false
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   224
!
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   225
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   226
keyPress:state x:x y:y view:view
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   227
    self hideHelp.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   228
    ^ false
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   229
!
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   230
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   231
pointerEnter:state x:x y:y view:aView
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   232
    |text p|
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   233
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   234
    showProcess notNil ifTrue:[
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   235
	p := showProcess. showProcess := nil.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   236
	p terminate.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   237
    ].
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   238
    self hideIfPointerLeft:aView.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   239
    aView topView == currentHelpView ifTrue:[
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   240
	^ true
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   241
    ].
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   242
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   243
    self initiateHelpFor:aView atX:x y:y.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   244
    ^ false
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   245
!
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   246
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   247
pointerLeave:state view:view
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   248
    self hideIfPointerLeft:view.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   249
    ^ false
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   250
! !
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   251
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   252
!ActiveHelp methodsFor:'private'!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   253
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   254
helpTextFor:aView atX:x y:y
100
claus
parents: 98
diff changeset
   255
    "pointer entered aView; 
claus
parents: 98
diff changeset
   256
     walk along the views superView chain,
claus
parents: 98
diff changeset
   257
     asking models and views encountered while walking.
claus
parents: 98
diff changeset
   258
     The first one who understands and returns a nonNil answer to the
claus
parents: 98
diff changeset
   259
     #helpTextFor:at: or #helpTextFor: message ends this walk and the
claus
parents: 98
diff changeset
   260
     returned string is returned."
claus
parents: 98
diff changeset
   261
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   262
    |model text view org found v sv|
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   263
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   264
    view := aView.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   265
    (model := aView model) notNil ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   266
	(model respondsTo:#helpTextFor:at:) ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   267
	    text := model helpTextFor:aView at:x@y.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   268
	    text notNil ifTrue:[^ text].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   269
	].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   270
	(model respondsTo:#helpTextFor:) ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   271
	    text := model helpTextFor:aView.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   272
	    text notNil ifTrue:[^ text].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   273
	]
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   274
    ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   275
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   276
    (aView respondsTo:#helpText) ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   277
	text := aView helpText.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   278
	text notNil ifTrue:[^ text].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   279
    ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   280
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   281
    "walk up the chain - maybe someone knows about its subview ..."
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   282
    v := aView.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   283
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   284
    [(sv := v superView) notNil] whileTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   285
	(model := sv model) notNil ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   286
	    (model respondsTo:#helpTextFor:at:) ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   287
		text := model helpTextFor:aView at:x@y.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   288
		text notNil ifTrue:[^ text].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   289
	    ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   290
	    (model respondsTo:#helpTextFor:) ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   291
		text := model helpTextFor:aView.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   292
		text notNil ifTrue:[^ text].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   293
	    ]
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   294
	].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   295
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   296
	(sv respondsTo:#helpTextFor:) ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   297
	    text := sv helpTextFor:aView.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   298
	    text notNil ifTrue:[^ text].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   299
	    text := sv helpTextFor:v.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   300
	    text notNil ifTrue:[^ text].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   301
	 ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   302
	 v := sv.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   303
    ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   304
100
claus
parents: 98
diff changeset
   305
    (v notNil and:[v respondsTo:#application]) ifTrue:[
claus
parents: 98
diff changeset
   306
	(model := v application) notNil ifTrue:[
claus
parents: 98
diff changeset
   307
	    (model respondsTo:#helpTextFor:at:) ifTrue:[
claus
parents: 98
diff changeset
   308
		text := model helpTextFor:aView at:x@y.
claus
parents: 98
diff changeset
   309
		text notNil ifTrue:[^ text].
claus
parents: 98
diff changeset
   310
	    ].
claus
parents: 98
diff changeset
   311
	    (model respondsTo:#helpTextFor:) ifTrue:[
claus
parents: 98
diff changeset
   312
		text := model helpTextFor:aView.
claus
parents: 98
diff changeset
   313
		text notNil ifTrue:[^ text].
claus
parents: 98
diff changeset
   314
	    ]
claus
parents: 98
diff changeset
   315
	]
claus
parents: 98
diff changeset
   316
    ].
claus
parents: 98
diff changeset
   317
    (v notNil and:[v respondsTo:#model]) ifTrue:[
claus
parents: 98
diff changeset
   318
	(model := v model) notNil ifTrue:[
claus
parents: 98
diff changeset
   319
	    (model respondsTo:#helpTextFor:at:) ifTrue:[
claus
parents: 98
diff changeset
   320
		text := model helpTextFor:aView at:x@y.
claus
parents: 98
diff changeset
   321
		text notNil ifTrue:[^ text].
claus
parents: 98
diff changeset
   322
	    ].
claus
parents: 98
diff changeset
   323
	    (model respondsTo:#helpTextFor:) ifTrue:[
claus
parents: 98
diff changeset
   324
		text := model helpTextFor:aView.
claus
parents: 98
diff changeset
   325
		text notNil ifTrue:[^ text].
claus
parents: 98
diff changeset
   326
	    ]
claus
parents: 98
diff changeset
   327
	]
claus
parents: 98
diff changeset
   328
    ].
claus
parents: 98
diff changeset
   329
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   330
    (view class respondsTo:#helpText) ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   331
	text := view class helpText.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   332
	text notNil ifTrue:[^ text].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   333
    ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   334
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   335
    ^ nil
100
claus
parents: 98
diff changeset
   336
claus
parents: 98
diff changeset
   337
    "Modified: 31.8.1995 / 20:38:00 / claus"
claus
parents: 98
diff changeset
   338
!
claus
parents: 98
diff changeset
   339
138
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   340
hideIfPointerLeft:aView
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   341
    |whereOnScreen p|
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   342
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   343
"/    showProcess notNil ifTrue:[
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   344
"/        p := showProcess. showProcess := nil.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   345
"/        p terminate.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   346
"/    ].
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   347
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   348
    whereOnScreen := aView device pointerPosition.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   349
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   350
    (currentFrame notNil
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   351
    and:[(currentFrame insetBy:1@1) containsPoint:whereOnScreen]) ifFalse:[
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   352
	self hideHelp.
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   353
	currentView := nil
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   354
    ].
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   355
!
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   356
100
claus
parents: 98
diff changeset
   357
initiateHelpFor:aView atX:x y:y
claus
parents: 98
diff changeset
   358
    |text p|
claus
parents: 98
diff changeset
   359
claus
parents: 98
diff changeset
   360
    text := self helpTextFor:aView atX:x y:y.
claus
parents: 98
diff changeset
   361
claus
parents: 98
diff changeset
   362
    text notNil ifTrue:[
claus
parents: 98
diff changeset
   363
	DelayTime > 0 ifTrue:[
claus
parents: 98
diff changeset
   364
	    showProcess notNil ifTrue:[
claus
parents: 98
diff changeset
   365
		p := showProcess. showProcess := nil.
claus
parents: 98
diff changeset
   366
		p terminate.
claus
parents: 98
diff changeset
   367
	    ].
claus
parents: 98
diff changeset
   368
	    showProcess := [
claus
parents: 98
diff changeset
   369
		    (Delay forSeconds:DelayTime) wait.
claus
parents: 98
diff changeset
   370
		    showProcess := nil.
claus
parents: 98
diff changeset
   371
		    self showHelp:text for:aView
claus
parents: 98
diff changeset
   372
	    ] forkAt:(Processor userSchedulingPriority + 1).
claus
parents: 98
diff changeset
   373
	] ifFalse:[
claus
parents: 98
diff changeset
   374
	    self showHelp:text for:aView
claus
parents: 98
diff changeset
   375
	]
claus
parents: 98
diff changeset
   376
    ].
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   377
! !
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   378
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   379
!ActiveHelp methodsFor:'show / hide help'!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   380
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   381
hideHelp
98
claus
parents: 97
diff changeset
   382
    |p|
claus
parents: 97
diff changeset
   383
92
claus
parents: 59
diff changeset
   384
    showProcess notNil ifTrue:[
98
claus
parents: 97
diff changeset
   385
	p := showProcess. showProcess := nil.
claus
parents: 97
diff changeset
   386
	p terminate.
92
claus
parents: 59
diff changeset
   387
    ].
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   388
    currentHelpView notNil ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   389
	[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   390
	    currentHelpView destroy.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   391
	    currentHelpView := nil.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   392
	    currentView := nil.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   393
	] valueUninterruptably
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   394
    ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   395
    currentFrame := nil.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   396
    closeProcess notNil ifTrue:[
98
claus
parents: 97
diff changeset
   397
	p := closeProcess. closeProcess := nil.
claus
parents: 97
diff changeset
   398
	p terminate.
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   399
    ]
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   400
!
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   401
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   402
showHelp:aHelpText for:view
100
claus
parents: 98
diff changeset
   403
    |org p v|
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   404
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   405
    view == currentView ifTrue:[^ self].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   406
92
claus
parents: 59
diff changeset
   407
    closeProcess notNil ifTrue:[
98
claus
parents: 97
diff changeset
   408
	p := closeProcess. closeProcess := nil.
claus
parents: 97
diff changeset
   409
	p terminate.
92
claus
parents: 59
diff changeset
   410
    ].
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   411
    currentHelpView notNil ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   412
	self hideHelp
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   413
    ].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   414
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   415
    org := view originRelativeTo:nil.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   416
    currentFrame := org extent:view extent.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   417
    org :=org + (view extent // 2).
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   418
100
claus
parents: 98
diff changeset
   419
    v := ActiveHelpView for:aHelpText withCRs.
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   420
92
claus
parents: 59
diff changeset
   421
    org := view device pointerPosition.
100
claus
parents: 98
diff changeset
   422
    org := org + (10@10).
claus
parents: 98
diff changeset
   423
    (org x + v width) > view device width ifTrue:[
claus
parents: 98
diff changeset
   424
	org := (org x - v width) @ org y
92
claus
parents: 59
diff changeset
   425
    ].
100
claus
parents: 98
diff changeset
   426
    (org y + v height) > view device height ifTrue:[
claus
parents: 98
diff changeset
   427
	org := org x @ (org y - v height).
92
claus
parents: 59
diff changeset
   428
    ].
claus
parents: 59
diff changeset
   429
100
claus
parents: 98
diff changeset
   430
    v origin:org.
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   431
"/    currentHelpView open.
100
claus
parents: 98
diff changeset
   432
    v realize.
claus
parents: 98
diff changeset
   433
    v enableButtonMotionEvents.
claus
parents: 98
diff changeset
   434
    v enableMotionEvents.
claus
parents: 98
diff changeset
   435
    currentHelpView := v.
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   436
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   437
    currentView := view.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   438
    closeProcess := [
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   439
	Process terminateSignal handle:[:ex |
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   440
	    closeProcess := nil.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   441
	] do:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   442
	    (Delay forSeconds:ShowTime) wait.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   443
	    [
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   444
		currentHelpView notNil ifTrue:[
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   445
		    currentHelpView destroy.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   446
		    currentHelpView := nil.
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   447
		]
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   448
	    ] valueUninterruptably
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   449
	].
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   450
    ] forkAt:(Processor userSchedulingPriority + 1).
100
claus
parents: 98
diff changeset
   451
claus
parents: 98
diff changeset
   452
    "Modified: 31.8.1995 / 19:20:45 / claus"
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   453
! !
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   454
138
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   455
!ActiveHelp class methodsFor:'documentation'!
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   456
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   457
version
216
a5f97668e99a commentary
Claus Gittinger <cg@exept.de>
parents: 138
diff changeset
   458
    ^ '$Header: /cvs/stx/stx/libview2/ActiveHelp.st,v 1.9 1996-04-25 11:08:32 cg Exp $'
138
492fb73ca439 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   459
! !
59
98a4d38cfc96 Initial revision
claus
parents:
diff changeset
   460
ActiveHelp initialize!