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