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