EditField.st
author claus
Tue, 06 Jun 1995 06:16:07 +0200
changeset 130 338e856bddc9
parent 128 06a050529335
child 131 208fa92f434d
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     1
"
5
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1990 by Claus Gittinger
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
     3
	      All Rights Reserved
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     4
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    11
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    12
125
claus
parents: 122
diff changeset
    13
'From Smalltalk/X, Version:2.10.5 on 9-may-1995 at 12:09:38 pm'!
105
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
    14
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    15
EditTextView subclass:#EditField
125
claus
parents: 122
diff changeset
    16
	 instanceVariableNames:'leaveAction enabled enableAction crAction tabAction converter
127
claus
parents: 125
diff changeset
    17
		leaveKeys immediateAccept acceptOnLeave acceptOnReturn
claus
parents: 125
diff changeset
    18
		lengthLimit'
105
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
    19
	 classVariableNames:'DefaultForegroundColor DefaultBackgroundColor
127
claus
parents: 125
diff changeset
    20
		DefaultSelectionForegroundColor DefaultSelectionBackgroundColor
claus
parents: 125
diff changeset
    21
		DefaultFont'
105
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
    22
	 poolDictionaries:''
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
    23
	 category:'Views-Text'
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    24
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    25
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    26
EditField comment:'
5
claus
parents: 3
diff changeset
    27
COPYRIGHT (c) 1990 by Claus Gittinger
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
    28
	      All Rights Reserved
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    29
130
claus
parents: 128
diff changeset
    30
$Header: /cvs/stx/stx/libwidg/EditField.st,v 1.24 1995-06-06 04:13:12 claus Exp $
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
    31
'!
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
    32
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
    33
!EditField class methodsFor:'documentation'!
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
    34
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    35
copyright
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    36
"
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    37
 COPYRIGHT (c) 1990 by Claus Gittinger
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
    38
	      All Rights Reserved
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    39
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    40
 This software is furnished under a license and may be used
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    41
 only in accordance with the terms of that license and with the
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    42
 inclusion of the above copyright notice.   This software may not
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    43
 be provided or otherwise made available to, or used by, any
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    44
 other person.  No title to or ownership of the software is
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    45
 hereby transferred.
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    46
"
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    47
!
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    48
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    49
version
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    50
"
130
claus
parents: 128
diff changeset
    51
$Header: /cvs/stx/stx/libwidg/EditField.st,v 1.24 1995-06-06 04:13:12 claus Exp $
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    52
"
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    53
!
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    54
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
    55
documentation
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
    56
"
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    57
    an editable text-field. Realized by using an EditTextView,
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    58
    and forcing its size to 1 line - disabling cursor movement
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
    59
    in the vertical direction.
121
claus
parents: 120
diff changeset
    60
claus
parents: 120
diff changeset
    61
    Instance variables:
claus
parents: 120
diff changeset
    62
claus
parents: 120
diff changeset
    63
      leaveAction    <Block | nil>              if non-nil, this is evaluated with
claus
parents: 120
diff changeset
    64
						the key (#Return, #CursorUp etc.) when
claus
parents: 120
diff changeset
    65
						the field is left via keyboard keys.
claus
parents: 120
diff changeset
    66
						(fieldGroups use this to decide which
claus
parents: 120
diff changeset
    67
						 field has to be enabled next)
claus
parents: 120
diff changeset
    68
claus
parents: 120
diff changeset
    69
      enabled        <Boolean>                  if false, input is ignored.
claus
parents: 120
diff changeset
    70
125
claus
parents: 122
diff changeset
    71
      enableAction   <Block | nil>              action performed if the field is
claus
parents: 122
diff changeset
    72
						enabled via an explicit click.
claus
parents: 122
diff changeset
    73
						(this is used by the group to
claus
parents: 122
diff changeset
    74
						 set the active field to the clicked upon field)
121
claus
parents: 120
diff changeset
    75
claus
parents: 120
diff changeset
    76
      crAction       <Block | nil>              if non-nil, keyboard input of a cr are not
claus
parents: 120
diff changeset
    77
						handled specially, instead this block is evaluated
claus
parents: 120
diff changeset
    78
						(however, this block can perform additional checks and send
claus
parents: 120
diff changeset
    79
						 a #accept then)
claus
parents: 120
diff changeset
    80
claus
parents: 120
diff changeset
    81
      tabAction      <Block | nil>              if non-nil, keyboard input of a tab character
claus
parents: 120
diff changeset
    82
						is not entered into the text, instead this block
claus
parents: 120
diff changeset
    83
						is evaluated.
claus
parents: 120
diff changeset
    84
claus
parents: 120
diff changeset
    85
      converter      <PrintConverter | nil>     if non-nil, this is supposed to convert between
claus
parents: 120
diff changeset
    86
						the object and its printed representation.
claus
parents: 120
diff changeset
    87
						Defaults to nil i.e. assume that strings are edited.
claus
parents: 120
diff changeset
    88
claus
parents: 120
diff changeset
    89
      leaveKeys      <Collection>               keys which are interpreted as 'leving the field'
122
claus
parents: 121
diff changeset
    90
125
claus
parents: 122
diff changeset
    91
      immediateAccept   <Boolean>               if true, every change of the text is immediately
claus
parents: 122
diff changeset
    92
						forwarded to the model/acceptBlock. If false,
claus
parents: 122
diff changeset
    93
						the changed value is only stored in the model
claus
parents: 122
diff changeset
    94
						if the field is left or accepted.
claus
parents: 122
diff changeset
    95
						Default is false.
122
claus
parents: 121
diff changeset
    96
claus
parents: 121
diff changeset
    97
      acceptOnLeave  <Boolean>                  if true, leaving the field (via cursor keys)
claus
parents: 121
diff changeset
    98
						automatically accepts the value into the model.
130
claus
parents: 128
diff changeset
    99
						Default is true.
122
claus
parents: 121
diff changeset
   100
claus
parents: 121
diff changeset
   101
      acceptOnReturn <Boolean>                  if true, leaving the field via return
claus
parents: 121
diff changeset
   102
						automatically accepts the value into the model.
130
claus
parents: 128
diff changeset
   103
						Default is true.
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
   104
"
120
claus
parents: 118
diff changeset
   105
!
claus
parents: 118
diff changeset
   106
claus
parents: 118
diff changeset
   107
examples 
claus
parents: 118
diff changeset
   108
"
122
claus
parents: 121
diff changeset
   109
    see more examples in EnterFieldGroup>>examples.
claus
parents: 121
diff changeset
   110
claus
parents: 121
diff changeset
   111
claus
parents: 121
diff changeset
   112
    basic field in a view:
120
claus
parents: 118
diff changeset
   113
claus
parents: 118
diff changeset
   114
	|top field|
claus
parents: 118
diff changeset
   115
claus
parents: 118
diff changeset
   116
	top := StandardSystemView new.
claus
parents: 118
diff changeset
   117
	top extent:200@100.
claus
parents: 118
diff changeset
   118
claus
parents: 118
diff changeset
   119
	field := EditField origin:0.0@0.0 in:top.
claus
parents: 118
diff changeset
   120
	field width:1.0.        'let its height as-is'.
claus
parents: 118
diff changeset
   121
claus
parents: 118
diff changeset
   122
	top open
claus
parents: 118
diff changeset
   123
122
claus
parents: 121
diff changeset
   124
125
claus
parents: 122
diff changeset
   125
    forward input in topView to the field:
claus
parents: 122
diff changeset
   126
    (currently, the field does not know this - therefore,
claus
parents: 122
diff changeset
   127
     its been told here ... this may change)
122
claus
parents: 121
diff changeset
   128
claus
parents: 121
diff changeset
   129
	|top field|
claus
parents: 121
diff changeset
   130
claus
parents: 121
diff changeset
   131
	top := StandardSystemView new.
claus
parents: 121
diff changeset
   132
	top extent:200@100.
claus
parents: 121
diff changeset
   133
claus
parents: 121
diff changeset
   134
	field := EditField origin:0.0@0.0 in:top.
claus
parents: 121
diff changeset
   135
	field width:1.0.        'let its height as-is'.
claus
parents: 121
diff changeset
   136
claus
parents: 121
diff changeset
   137
	top delegate:(KeyboardForwarder toView:field).
125
claus
parents: 122
diff changeset
   138
	field hasKeyboardFocus:true.
122
claus
parents: 121
diff changeset
   139
	top open
claus
parents: 121
diff changeset
   140
claus
parents: 121
diff changeset
   141
125
claus
parents: 122
diff changeset
   142
    to make it look better: set some inset:
120
claus
parents: 118
diff changeset
   143
claus
parents: 118
diff changeset
   144
	|top field|
claus
parents: 118
diff changeset
   145
claus
parents: 118
diff changeset
   146
	top := StandardSystemView new.
claus
parents: 118
diff changeset
   147
	top extent:200@100.
claus
parents: 118
diff changeset
   148
claus
parents: 118
diff changeset
   149
	field := EditField origin:0.0@ViewSpacing in:top.
claus
parents: 118
diff changeset
   150
	field width:1.0.        'let its height as-is'.
claus
parents: 118
diff changeset
   151
	field leftInset:ViewSpacing;
claus
parents: 118
diff changeset
   152
	      rightInset:ViewSpacing.
claus
parents: 118
diff changeset
   153
claus
parents: 118
diff changeset
   154
	top open
claus
parents: 118
diff changeset
   155
122
claus
parents: 121
diff changeset
   156
120
claus
parents: 118
diff changeset
   157
    give it an initial contents:
claus
parents: 118
diff changeset
   158
claus
parents: 118
diff changeset
   159
	|top field|
claus
parents: 118
diff changeset
   160
claus
parents: 118
diff changeset
   161
	top := StandardSystemView new.
claus
parents: 118
diff changeset
   162
	top extent:200@100.
claus
parents: 118
diff changeset
   163
claus
parents: 118
diff changeset
   164
	field := EditField origin:0.0@ViewSpacing in:top.
claus
parents: 118
diff changeset
   165
	field width:1.0.       
claus
parents: 118
diff changeset
   166
	field leftInset:ViewSpacing;
claus
parents: 118
diff changeset
   167
	      rightInset:ViewSpacing.
121
claus
parents: 120
diff changeset
   168
	field editValue:'hello world'.
120
claus
parents: 118
diff changeset
   169
claus
parents: 118
diff changeset
   170
	top open
claus
parents: 118
diff changeset
   171
122
claus
parents: 121
diff changeset
   172
125
claus
parents: 122
diff changeset
   173
    have it preselected:
120
claus
parents: 118
diff changeset
   174
claus
parents: 118
diff changeset
   175
	|top field|
claus
parents: 118
diff changeset
   176
claus
parents: 118
diff changeset
   177
	top := StandardSystemView new.
claus
parents: 118
diff changeset
   178
	top extent:200@100.
claus
parents: 118
diff changeset
   179
claus
parents: 118
diff changeset
   180
	field := EditField origin:0.0@ViewSpacing in:top.
claus
parents: 118
diff changeset
   181
	field width:1.0.     
claus
parents: 118
diff changeset
   182
	field leftInset:ViewSpacing;
claus
parents: 118
diff changeset
   183
	      rightInset:ViewSpacing.
121
claus
parents: 120
diff changeset
   184
	field editValue:'hello world' selected:true.
120
claus
parents: 118
diff changeset
   185
claus
parents: 118
diff changeset
   186
	top open
claus
parents: 118
diff changeset
   187
122
claus
parents: 121
diff changeset
   188
120
claus
parents: 118
diff changeset
   189
    have part of it preselected:
claus
parents: 118
diff changeset
   190
claus
parents: 118
diff changeset
   191
	|top field|
claus
parents: 118
diff changeset
   192
claus
parents: 118
diff changeset
   193
	top := StandardSystemView new.
claus
parents: 118
diff changeset
   194
	top extent:200@100.
claus
parents: 118
diff changeset
   195
claus
parents: 118
diff changeset
   196
	field := EditField origin:0.0@ViewSpacing in:top.
claus
parents: 118
diff changeset
   197
	field width:1.0.     
claus
parents: 118
diff changeset
   198
	field leftInset:ViewSpacing;
claus
parents: 118
diff changeset
   199
	      rightInset:ViewSpacing.
121
claus
parents: 120
diff changeset
   200
	field editValue:'hello world';
120
claus
parents: 118
diff changeset
   201
	      selectFromCharacterPosition:1 to:5.
claus
parents: 118
diff changeset
   202
claus
parents: 118
diff changeset
   203
	top open
claus
parents: 118
diff changeset
   204
122
claus
parents: 121
diff changeset
   205
125
claus
parents: 122
diff changeset
   206
    set a size limit:
claus
parents: 122
diff changeset
   207
claus
parents: 122
diff changeset
   208
	|top field|
claus
parents: 122
diff changeset
   209
claus
parents: 122
diff changeset
   210
	top := StandardSystemView new.
claus
parents: 122
diff changeset
   211
	top extent:200@100.
claus
parents: 122
diff changeset
   212
claus
parents: 122
diff changeset
   213
	field := EditField origin:0.0@ViewSpacing in:top.
claus
parents: 122
diff changeset
   214
	field width:1.0.     
claus
parents: 122
diff changeset
   215
	field leftInset:ViewSpacing;
claus
parents: 122
diff changeset
   216
	      rightInset:ViewSpacing.
claus
parents: 122
diff changeset
   217
	field editValue:'hello';
claus
parents: 122
diff changeset
   218
	      maxChars:8.
claus
parents: 122
diff changeset
   219
claus
parents: 122
diff changeset
   220
	top open
claus
parents: 122
diff changeset
   221
claus
parents: 122
diff changeset
   222
121
claus
parents: 120
diff changeset
   223
    use a converter:
125
claus
parents: 122
diff changeset
   224
      - numbers (default to 0):
121
claus
parents: 120
diff changeset
   225
claus
parents: 120
diff changeset
   226
	|top field|
claus
parents: 120
diff changeset
   227
claus
parents: 120
diff changeset
   228
	top := StandardSystemView new.
claus
parents: 120
diff changeset
   229
	top extent:200@100.
claus
parents: 120
diff changeset
   230
claus
parents: 120
diff changeset
   231
	field := EditField origin:0.0@ViewSpacing in:top.
claus
parents: 120
diff changeset
   232
	field width:1.0.
claus
parents: 120
diff changeset
   233
	field leftInset:ViewSpacing;
claus
parents: 120
diff changeset
   234
	      rightInset:ViewSpacing.
claus
parents: 120
diff changeset
   235
claus
parents: 120
diff changeset
   236
	field converter:(PrintConverter new initForNumber).
claus
parents: 120
diff changeset
   237
	field editValue:1234.
claus
parents: 120
diff changeset
   238
	field acceptAction:[:value | Transcript showCr:value].
claus
parents: 120
diff changeset
   239
	field crAction:[field accept. top destroy].
claus
parents: 120
diff changeset
   240
	top open.
claus
parents: 120
diff changeset
   241
claus
parents: 120
diff changeset
   242
      - dates:
claus
parents: 120
diff changeset
   243
claus
parents: 120
diff changeset
   244
	|top field|
claus
parents: 120
diff changeset
   245
claus
parents: 120
diff changeset
   246
	top := StandardSystemView new.
claus
parents: 120
diff changeset
   247
	top extent:200@100.
claus
parents: 120
diff changeset
   248
claus
parents: 120
diff changeset
   249
	field := EditField origin:0.0@ViewSpacing in:top.
claus
parents: 120
diff changeset
   250
	field width:1.0.
claus
parents: 120
diff changeset
   251
	field leftInset:ViewSpacing;
claus
parents: 120
diff changeset
   252
	      rightInset:ViewSpacing.
claus
parents: 120
diff changeset
   253
claus
parents: 120
diff changeset
   254
	field converter:(PrintConverter new initForDate).
claus
parents: 120
diff changeset
   255
	field editValue:Date today.
125
claus
parents: 122
diff changeset
   256
	field acceptAction:[:value | Transcript showCr:value class name , ' ' , value printString].
121
claus
parents: 120
diff changeset
   257
	field crAction:[field accept. top destroy].
claus
parents: 120
diff changeset
   258
	top open.
claus
parents: 120
diff changeset
   259
122
claus
parents: 121
diff changeset
   260
125
claus
parents: 122
diff changeset
   261
    setting immediateAccept, makes the field update with every key:
claus
parents: 122
diff changeset
   262
claus
parents: 122
diff changeset
   263
      - immediate accept numbers, defaulting to nil:
121
claus
parents: 120
diff changeset
   264
claus
parents: 120
diff changeset
   265
	|top field|
claus
parents: 120
diff changeset
   266
claus
parents: 120
diff changeset
   267
	top := StandardSystemView new.
claus
parents: 120
diff changeset
   268
	top extent:200@100.
claus
parents: 120
diff changeset
   269
claus
parents: 120
diff changeset
   270
	field := EditField origin:0.0@ViewSpacing in:top.
claus
parents: 120
diff changeset
   271
	field width:1.0.
claus
parents: 120
diff changeset
   272
	field leftInset:ViewSpacing;
claus
parents: 120
diff changeset
   273
	      rightInset:ViewSpacing.
claus
parents: 120
diff changeset
   274
125
claus
parents: 122
diff changeset
   275
	field converter:(PrintConverter new initForNumberOrNil).
claus
parents: 122
diff changeset
   276
	field immediateAccept:true.
121
claus
parents: 120
diff changeset
   277
	field editValue:1234.
claus
parents: 120
diff changeset
   278
	field acceptAction:[:value | Transcript showCr:value].
claus
parents: 120
diff changeset
   279
	field crAction:[field accept. top destroy].
claus
parents: 120
diff changeset
   280
	top open.
claus
parents: 120
diff changeset
   281
122
claus
parents: 121
diff changeset
   282
127
claus
parents: 125
diff changeset
   283
claus
parents: 125
diff changeset
   284
120
claus
parents: 118
diff changeset
   285
    use a model:
claus
parents: 118
diff changeset
   286
    (see changing model value in inspector when return is pressed in the field)
claus
parents: 118
diff changeset
   287
claus
parents: 118
diff changeset
   288
	|top field model|
claus
parents: 118
diff changeset
   289
claus
parents: 118
diff changeset
   290
	model := 'hello world' asValue.
claus
parents: 118
diff changeset
   291
claus
parents: 118
diff changeset
   292
	top := StandardSystemView new.
claus
parents: 118
diff changeset
   293
	top extent:200@100.
claus
parents: 118
diff changeset
   294
claus
parents: 118
diff changeset
   295
	field := EditField origin:0.0@ViewSpacing in:top.
121
claus
parents: 120
diff changeset
   296
	field width:1.0.
120
claus
parents: 118
diff changeset
   297
	field leftInset:ViewSpacing;
claus
parents: 118
diff changeset
   298
	      rightInset:ViewSpacing.
claus
parents: 118
diff changeset
   299
	field model:model.
128
claus
parents: 127
diff changeset
   300
	field acceptOnReturn:true.
120
claus
parents: 118
diff changeset
   301
claus
parents: 118
diff changeset
   302
	top open.
121
claus
parents: 120
diff changeset
   303
	model inspect.
claus
parents: 120
diff changeset
   304
122
claus
parents: 121
diff changeset
   305
127
claus
parents: 125
diff changeset
   306
    two views on the same model (each accepts on return):
121
claus
parents: 120
diff changeset
   307
claus
parents: 120
diff changeset
   308
	|top1 top2 field1 field2 model|
claus
parents: 120
diff changeset
   309
claus
parents: 120
diff changeset
   310
	model := 'hello world' asValue.
claus
parents: 120
diff changeset
   311
claus
parents: 120
diff changeset
   312
	top1 := StandardSystemView new.
claus
parents: 120
diff changeset
   313
	top1 extent:200@100.
claus
parents: 120
diff changeset
   314
	field1 := EditField origin:0.0@ViewSpacing in:top1.
claus
parents: 120
diff changeset
   315
	field1 width:1.0.
claus
parents: 120
diff changeset
   316
	field1 leftInset:ViewSpacing;
claus
parents: 120
diff changeset
   317
	      rightInset:ViewSpacing.
claus
parents: 120
diff changeset
   318
	field1 model:model.
128
claus
parents: 127
diff changeset
   319
	field1 acceptOnReturn:true.
121
claus
parents: 120
diff changeset
   320
	top1 open.
claus
parents: 120
diff changeset
   321
claus
parents: 120
diff changeset
   322
	top2 := StandardSystemView new.
claus
parents: 120
diff changeset
   323
	top2 extent:200@100.
claus
parents: 120
diff changeset
   324
	field2 := EditField origin:0.0@ViewSpacing in:top2.
claus
parents: 120
diff changeset
   325
	field2 width:1.0.
claus
parents: 120
diff changeset
   326
	field2 leftInset:ViewSpacing;
claus
parents: 120
diff changeset
   327
	      rightInset:ViewSpacing.
claus
parents: 120
diff changeset
   328
	field2 model:model.
128
claus
parents: 127
diff changeset
   329
	field2 acceptOnReturn:true.
121
claus
parents: 120
diff changeset
   330
	top2 open.
claus
parents: 120
diff changeset
   331
127
claus
parents: 125
diff changeset
   332
    two views on the same model (no accept on return):
claus
parents: 125
diff changeset
   333
claus
parents: 125
diff changeset
   334
	|top1 top2 field1 field2 model|
claus
parents: 125
diff changeset
   335
claus
parents: 125
diff changeset
   336
	model := 'hello world' asValue.
claus
parents: 125
diff changeset
   337
claus
parents: 125
diff changeset
   338
	top1 := StandardSystemView new.
claus
parents: 125
diff changeset
   339
	top1 extent:200@100.
claus
parents: 125
diff changeset
   340
	field1 := EditField origin:0.0@ViewSpacing in:top1.
claus
parents: 125
diff changeset
   341
	field1 width:1.0.
claus
parents: 125
diff changeset
   342
	field1 leftInset:ViewSpacing;
claus
parents: 125
diff changeset
   343
	      rightInset:ViewSpacing.
claus
parents: 125
diff changeset
   344
	field1 model:model; acceptOnReturn:false.
claus
parents: 125
diff changeset
   345
	top1 open.
claus
parents: 125
diff changeset
   346
claus
parents: 125
diff changeset
   347
	top2 := StandardSystemView new.
claus
parents: 125
diff changeset
   348
	top2 extent:200@100.
claus
parents: 125
diff changeset
   349
	field2 := EditField origin:0.0@ViewSpacing in:top2.
claus
parents: 125
diff changeset
   350
	field2 width:1.0.
claus
parents: 125
diff changeset
   351
	field2 leftInset:ViewSpacing;
claus
parents: 125
diff changeset
   352
	      rightInset:ViewSpacing.
claus
parents: 125
diff changeset
   353
	field2 model:model; acceptOnReturn:false.
claus
parents: 125
diff changeset
   354
	top2 open.
claus
parents: 125
diff changeset
   355
125
claus
parents: 122
diff changeset
   356
    with immediate accept:
claus
parents: 122
diff changeset
   357
claus
parents: 122
diff changeset
   358
	|top1 top2 field1 field2 model|
claus
parents: 122
diff changeset
   359
claus
parents: 122
diff changeset
   360
	model := 'hello world' asValue.
claus
parents: 122
diff changeset
   361
claus
parents: 122
diff changeset
   362
	top1 := StandardSystemView new.
claus
parents: 122
diff changeset
   363
	top1 extent:200@100.
claus
parents: 122
diff changeset
   364
	field1 := EditField origin:0.0@ViewSpacing in:top1.
claus
parents: 122
diff changeset
   365
	field1 width:1.0.
claus
parents: 122
diff changeset
   366
	field1 leftInset:ViewSpacing; rightInset:ViewSpacing.
claus
parents: 122
diff changeset
   367
	field1 model:model; immediateAccept:true.
claus
parents: 122
diff changeset
   368
	top1 open.
claus
parents: 122
diff changeset
   369
claus
parents: 122
diff changeset
   370
	top2 := StandardSystemView new.
claus
parents: 122
diff changeset
   371
	top2 extent:200@100.
claus
parents: 122
diff changeset
   372
	field2 := EditField origin:0.0@ViewSpacing in:top2.
claus
parents: 122
diff changeset
   373
	field2 width:1.0.
claus
parents: 122
diff changeset
   374
	field2 leftInset:ViewSpacing; rightInset:ViewSpacing.
claus
parents: 122
diff changeset
   375
	field2 model:model; immediateAccept:true.
claus
parents: 122
diff changeset
   376
	top2 open.
122
claus
parents: 121
diff changeset
   377
121
claus
parents: 120
diff changeset
   378
    just an example; a checkBox and an editField on the same model:
claus
parents: 120
diff changeset
   379
claus
parents: 120
diff changeset
   380
	|top1 top2 field1 box model|
claus
parents: 120
diff changeset
   381
claus
parents: 120
diff changeset
   382
	model := false asValue.
claus
parents: 120
diff changeset
   383
claus
parents: 120
diff changeset
   384
	top1 := StandardSystemView new.
claus
parents: 120
diff changeset
   385
	top1 extent:200@100.
claus
parents: 120
diff changeset
   386
	field1 := EditField origin:0.0@ViewSpacing in:top1.
claus
parents: 120
diff changeset
   387
	field1 width:1.0.
claus
parents: 120
diff changeset
   388
	field1 leftInset:ViewSpacing;
claus
parents: 120
diff changeset
   389
	      rightInset:ViewSpacing.
claus
parents: 120
diff changeset
   390
	field1 converter:(PrintConverter new initForYesNo).
claus
parents: 120
diff changeset
   391
	field1 model:model.
claus
parents: 120
diff changeset
   392
	top1 open.
claus
parents: 120
diff changeset
   393
claus
parents: 120
diff changeset
   394
	top2 := StandardSystemView new.
claus
parents: 120
diff changeset
   395
	top2 extent:200@100.
claus
parents: 120
diff changeset
   396
	box := CheckBox on:model.
claus
parents: 120
diff changeset
   397
	box label:'on/off'.
claus
parents: 120
diff changeset
   398
	top2 add:box.
claus
parents: 120
diff changeset
   399
	top2 open.
claus
parents: 120
diff changeset
   400
120
claus
parents: 118
diff changeset
   401
	model inspect.
125
claus
parents: 122
diff changeset
   402
claus
parents: 122
diff changeset
   403
claus
parents: 122
diff changeset
   404
    connecting fields:
claus
parents: 122
diff changeset
   405
    update field2 wehenever field1 is changed.
claus
parents: 122
diff changeset
   406
    (normally, the processing below (xChanged) is done in your application
claus
parents: 122
diff changeset
   407
     class, or in a complex model. For the demonstration below, we use
claus
parents: 122
diff changeset
   408
     a Plug to simulate the protocol.)
claus
parents: 122
diff changeset
   409
claus
parents: 122
diff changeset
   410
	|application top field1 field2 value1 value2|
claus
parents: 122
diff changeset
   411
claus
parents: 122
diff changeset
   412
	application := Plug new.
claus
parents: 122
diff changeset
   413
	application respondTo:#value1Changed
claus
parents: 122
diff changeset
   414
			 with:[value2 value:(value1 value isNil ifTrue:[nil]
claus
parents: 122
diff changeset
   415
								ifFalse:[value1 value squared])].
claus
parents: 122
diff changeset
   416
claus
parents: 122
diff changeset
   417
	value1 := 1 asValue.
claus
parents: 122
diff changeset
   418
	value2 := 1 asValue.
claus
parents: 122
diff changeset
   419
claus
parents: 122
diff changeset
   420
	top := Dialog new.
claus
parents: 122
diff changeset
   421
	top extent:200@200.
claus
parents: 122
diff changeset
   422
claus
parents: 122
diff changeset
   423
	(top addTextLabel:'some number:') layout:#left.
claus
parents: 122
diff changeset
   424
	top addVerticalSpace.
claus
parents: 122
diff changeset
   425
claus
parents: 122
diff changeset
   426
	(top addInputFieldOn:value1 tabable:false) 
claus
parents: 122
diff changeset
   427
	    converter:(PrintConverter new initForNumberOrNil);
claus
parents: 122
diff changeset
   428
	    immediateAccept:true.
claus
parents: 122
diff changeset
   429
	top addVerticalSpace.
claus
parents: 122
diff changeset
   430
claus
parents: 122
diff changeset
   431
	(top addTextLabel:'squared:') layout:#left.
claus
parents: 122
diff changeset
   432
	top addVerticalSpace.
claus
parents: 122
diff changeset
   433
	(top addInputFieldOn:value2 tabable:false) 
claus
parents: 122
diff changeset
   434
	    converter:(PrintConverter new initForNumberOrNil).
claus
parents: 122
diff changeset
   435
claus
parents: 122
diff changeset
   436
	value1 onChangeSend:#value1Changed to:application.
claus
parents: 122
diff changeset
   437
claus
parents: 122
diff changeset
   438
	top openModeless.
claus
parents: 122
diff changeset
   439
claus
parents: 122
diff changeset
   440
claus
parents: 122
diff changeset
   441
    two-way connect:
claus
parents: 122
diff changeset
   442
    each field updates the other (notice, that we have to turn off
claus
parents: 122
diff changeset
   443
    onChange: notification, to avoid an endless notification cycle)
claus
parents: 122
diff changeset
   444
claus
parents: 122
diff changeset
   445
	|application top field1 field2 value1 value2|
claus
parents: 122
diff changeset
   446
claus
parents: 122
diff changeset
   447
	application := Plug new.
claus
parents: 122
diff changeset
   448
	application respondTo:#value1Changed
claus
parents: 122
diff changeset
   449
			 with:[value2 retractInterrestFor:application.
claus
parents: 122
diff changeset
   450
			       value2 value:(value1 value isNil ifTrue:[nil]
claus
parents: 122
diff changeset
   451
								ifFalse:[value1 value squared]).
claus
parents: 122
diff changeset
   452
			       value2 onChangeSend:#value2Changed to:application.
claus
parents: 122
diff changeset
   453
			      ].
claus
parents: 122
diff changeset
   454
	application respondTo:#value2Changed
claus
parents: 122
diff changeset
   455
			 with:[value1 retractInterrestFor:application.
claus
parents: 122
diff changeset
   456
			       value1 value:(value2 value isNil ifTrue:[nil]
claus
parents: 122
diff changeset
   457
								ifFalse:[value2 value sqrt]).
claus
parents: 122
diff changeset
   458
			       value1 onChangeSend:#value1Changed to:application.
claus
parents: 122
diff changeset
   459
			      ].
claus
parents: 122
diff changeset
   460
claus
parents: 122
diff changeset
   461
	value1 := 1 asValue.
claus
parents: 122
diff changeset
   462
	value2 := 1 asValue.
claus
parents: 122
diff changeset
   463
claus
parents: 122
diff changeset
   464
	top := Dialog new.
claus
parents: 122
diff changeset
   465
	top extent:200@200.
claus
parents: 122
diff changeset
   466
claus
parents: 122
diff changeset
   467
	(top addTextLabel:'some number:') layout:#left.
claus
parents: 122
diff changeset
   468
	top addVerticalSpace.
claus
parents: 122
diff changeset
   469
claus
parents: 122
diff changeset
   470
	(top addInputFieldOn:value1 tabable:false) 
claus
parents: 122
diff changeset
   471
	    converter:(PrintConverter new initForNumberOrNil);
claus
parents: 122
diff changeset
   472
	    immediateAccept:true.
claus
parents: 122
diff changeset
   473
	top addVerticalSpace.
claus
parents: 122
diff changeset
   474
claus
parents: 122
diff changeset
   475
	(top addTextLabel:'squared:') layout:#left.
claus
parents: 122
diff changeset
   476
	top addVerticalSpace.
claus
parents: 122
diff changeset
   477
	(top addInputFieldOn:value2 tabable:false) 
127
claus
parents: 125
diff changeset
   478
	    converter:(PrintConverter new initForNumberOrNil);
claus
parents: 125
diff changeset
   479
	    immediateAccept:true.
125
claus
parents: 122
diff changeset
   480
claus
parents: 122
diff changeset
   481
	value1 onChangeSend:#value1Changed to:application.
claus
parents: 122
diff changeset
   482
	value2 onChangeSend:#value2Changed to:application.
claus
parents: 122
diff changeset
   483
claus
parents: 122
diff changeset
   484
	top openModeless.
120
claus
parents: 118
diff changeset
   485
"
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
   486
! !
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   487
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   488
!EditField class methodsFor:'defaults'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   489
125
claus
parents: 122
diff changeset
   490
defaultLeaveKeys
128
claus
parents: 127
diff changeset
   491
    "return the set of keys which are taken as leave-keys.
claus
parents: 127
diff changeset
   492
     If the field is in an enterFieldGroup, all leave keys will be
claus
parents: 127
diff changeset
   493
     forwarded to the group and possible step to the next/previous field.
claus
parents: 127
diff changeset
   494
     Also, if acceptOnLeave is true, leave keys will store the current
claus
parents: 127
diff changeset
   495
     value into their model (if any)"
claus
parents: 127
diff changeset
   496
125
claus
parents: 122
diff changeset
   497
    ^ #(Return CursorUp CursorDown Next Previous Accept)
claus
parents: 122
diff changeset
   498
!
claus
parents: 122
diff changeset
   499
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   500
updateStyleCache
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   501
    DefaultForegroundColor := StyleSheet colorAt:'editFieldForegroundColor' default:Black.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   502
    DefaultBackgroundColor := StyleSheet colorAt:'editFieldBackgroundColor' default:White.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   503
    DefaultSelectionForegroundColor := StyleSheet colorAt:'editFieldSelectionForegroundColor' default:DefaultBackgroundColor.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   504
    DefaultSelectionBackgroundColor := StyleSheet colorAt:'editFieldSelectionBackgroundColor' default:DefaultForegroundColor.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   505
    DefaultFont := StyleSheet fontAt:'editFieldFont' default:nil.
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   506
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   507
    "
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   508
     self updateStyleCache
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   509
    "
105
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
   510
!
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
   511
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
   512
defaultNumberOfLines
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
   513
    "the number of lines in the field"
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
   514
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
   515
    ^ 1
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   516
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   517
125
claus
parents: 122
diff changeset
   518
!EditField methodsFor:'private'!
claus
parents: 122
diff changeset
   519
claus
parents: 122
diff changeset
   520
textChanged
claus
parents: 122
diff changeset
   521
    "this is sent by mySelf (somewhere in a superclass) whenever
claus
parents: 122
diff changeset
   522
     my contents has changed. 
claus
parents: 122
diff changeset
   523
     A good place to add immediateAccept functionality and check for the
claus
parents: 122
diff changeset
   524
     lengthLimit."
claus
parents: 122
diff changeset
   525
claus
parents: 122
diff changeset
   526
    |string|
claus
parents: 122
diff changeset
   527
claus
parents: 122
diff changeset
   528
    super textChanged.
claus
parents: 122
diff changeset
   529
    string := self contents.
claus
parents: 122
diff changeset
   530
    lengthLimit notNil ifTrue:[
claus
parents: 122
diff changeset
   531
	string size > lengthLimit ifTrue:[
claus
parents: 122
diff changeset
   532
	    self contents:(string := string copyTo:lengthLimit).
claus
parents: 122
diff changeset
   533
	    self flash.
claus
parents: 122
diff changeset
   534
	]
claus
parents: 122
diff changeset
   535
    ].
claus
parents: 122
diff changeset
   536
    immediateAccept ifTrue:[
claus
parents: 122
diff changeset
   537
	self accept
claus
parents: 122
diff changeset
   538
    ]
claus
parents: 122
diff changeset
   539
!
claus
parents: 122
diff changeset
   540
claus
parents: 122
diff changeset
   541
getListFromModel
claus
parents: 122
diff changeset
   542
    "redefined to aquire the text via the aspectMsg - not the listMsg,
claus
parents: 122
diff changeset
   543
     and to ignore updates resulting from my own change."
claus
parents: 122
diff changeset
   544
claus
parents: 122
diff changeset
   545
    "
claus
parents: 122
diff changeset
   546
     ignore updates from my own change
claus
parents: 122
diff changeset
   547
    "
claus
parents: 122
diff changeset
   548
    lockUpdates ifTrue:[
claus
parents: 122
diff changeset
   549
	lockUpdates := false.
claus
parents: 122
diff changeset
   550
	^ self
claus
parents: 122
diff changeset
   551
    ].
claus
parents: 122
diff changeset
   552
claus
parents: 122
diff changeset
   553
    (model notNil and:[aspectMsg notNil]) ifTrue:[
claus
parents: 122
diff changeset
   554
	self editValue:(model perform:aspectMsg).
claus
parents: 122
diff changeset
   555
    ]
claus
parents: 122
diff changeset
   556
!
claus
parents: 122
diff changeset
   557
127
claus
parents: 125
diff changeset
   558
argForChangeMessage
claus
parents: 125
diff changeset
   559
    "redefined to send use converted value (if I have one)"
claus
parents: 125
diff changeset
   560
claus
parents: 125
diff changeset
   561
    ^ self editValue
claus
parents: 125
diff changeset
   562
!
claus
parents: 125
diff changeset
   563
125
claus
parents: 122
diff changeset
   564
startAutoScrollUp:y
claus
parents: 122
diff changeset
   565
    "no vertical scrolling in editfields"
claus
parents: 122
diff changeset
   566
claus
parents: 122
diff changeset
   567
    ^ self
claus
parents: 122
diff changeset
   568
!
claus
parents: 122
diff changeset
   569
claus
parents: 122
diff changeset
   570
startAutoScrollDown:y
claus
parents: 122
diff changeset
   571
    "no vertical scrolling in editfields"
claus
parents: 122
diff changeset
   572
claus
parents: 122
diff changeset
   573
    ^ self
claus
parents: 122
diff changeset
   574
! !
claus
parents: 122
diff changeset
   575
claus
parents: 122
diff changeset
   576
!EditField methodsFor:'accessing'!
claus
parents: 122
diff changeset
   577
claus
parents: 122
diff changeset
   578
contents
claus
parents: 122
diff changeset
   579
    "return contents as a string
claus
parents: 122
diff changeset
   580
     - redefined since EditFields hold only one line of text.
claus
parents: 122
diff changeset
   581
    In your application, please use #editValue; 
claus
parents: 122
diff changeset
   582
    it uses a converter (if any) and is compatible to ST-80."
claus
parents: 122
diff changeset
   583
claus
parents: 122
diff changeset
   584
    list isNil ifTrue:[^ ''].
claus
parents: 122
diff changeset
   585
    (list size == 0) ifTrue:[^ ''].
claus
parents: 122
diff changeset
   586
    ^ list at:1
claus
parents: 122
diff changeset
   587
!
claus
parents: 122
diff changeset
   588
claus
parents: 122
diff changeset
   589
leaveAction:aBlock
claus
parents: 122
diff changeset
   590
    "define an action to be evaluated when field is left by return key"
claus
parents: 122
diff changeset
   591
claus
parents: 122
diff changeset
   592
    leaveAction := aBlock
claus
parents: 122
diff changeset
   593
!
claus
parents: 122
diff changeset
   594
claus
parents: 122
diff changeset
   595
list:someText
claus
parents: 122
diff changeset
   596
    "redefined to force text to 1 line, and notify dependents
claus
parents: 122
diff changeset
   597
     of any changed extent-wishes."
claus
parents: 122
diff changeset
   598
claus
parents: 122
diff changeset
   599
    |l oldWidth|
claus
parents: 122
diff changeset
   600
claus
parents: 122
diff changeset
   601
    l := someText.
claus
parents: 122
diff changeset
   602
    l size > 1 ifTrue:[
claus
parents: 122
diff changeset
   603
	l := OrderedCollection with:(l at:1)
claus
parents: 122
diff changeset
   604
    ].
claus
parents: 122
diff changeset
   605
    oldWidth := self widthOfContents.
claus
parents: 122
diff changeset
   606
    super list:l.
claus
parents: 122
diff changeset
   607
    self widthOfContents ~~ oldWidth ifTrue:[
130
claus
parents: 128
diff changeset
   608
	self changed:#preferredExtent
125
claus
parents: 122
diff changeset
   609
    ]
claus
parents: 122
diff changeset
   610
!
claus
parents: 122
diff changeset
   611
claus
parents: 122
diff changeset
   612
contents:someText
claus
parents: 122
diff changeset
   613
    "set the contents from a string
claus
parents: 122
diff changeset
   614
     - redefined to place the cursor to the end.
claus
parents: 122
diff changeset
   615
    In your application, please use #editValue:; 
claus
parents: 122
diff changeset
   616
    it uses a converter (if any) and is compatible to ST-80."
claus
parents: 122
diff changeset
   617
claus
parents: 122
diff changeset
   618
    super contents:someText.
claus
parents: 122
diff changeset
   619
    self cursorCol:(someText size + 1).
claus
parents: 122
diff changeset
   620
!
claus
parents: 122
diff changeset
   621
claus
parents: 122
diff changeset
   622
enable
claus
parents: 122
diff changeset
   623
    "enable the field; show cursor and allow input"
claus
parents: 122
diff changeset
   624
claus
parents: 122
diff changeset
   625
    enabled ifFalse:[
claus
parents: 122
diff changeset
   626
"/        enableAction notNil ifTrue:[
claus
parents: 122
diff changeset
   627
"/            enableAction value
claus
parents: 122
diff changeset
   628
"/        ].
claus
parents: 122
diff changeset
   629
	enabled := true.
claus
parents: 122
diff changeset
   630
	super showCursor
claus
parents: 122
diff changeset
   631
    ]
claus
parents: 122
diff changeset
   632
!
claus
parents: 122
diff changeset
   633
claus
parents: 122
diff changeset
   634
immediateAccept:aBoolean
claus
parents: 122
diff changeset
   635
    "set/clear the immediateAccept flag. The default is false."
claus
parents: 122
diff changeset
   636
claus
parents: 122
diff changeset
   637
     immediateAccept := aBoolean
claus
parents: 122
diff changeset
   638
!
claus
parents: 122
diff changeset
   639
claus
parents: 122
diff changeset
   640
editValue
claus
parents: 122
diff changeset
   641
    "if the field edits a string, this is a name alias for #contents.
claus
parents: 122
diff changeset
   642
     Otherwise, if there is a converter, return the edited string
claus
parents: 122
diff changeset
   643
     converted to an appropriate object."
claus
parents: 122
diff changeset
   644
claus
parents: 122
diff changeset
   645
    |string|
claus
parents: 122
diff changeset
   646
claus
parents: 122
diff changeset
   647
    string := self contents.
claus
parents: 122
diff changeset
   648
    converter isNil ifTrue:[^ string].
claus
parents: 122
diff changeset
   649
    string isNil ifTrue:[string := ''].
claus
parents: 122
diff changeset
   650
    ^ converter readValueFrom:string 
claus
parents: 122
diff changeset
   651
!
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   652
125
claus
parents: 122
diff changeset
   653
leaveKeys:aCollectionOfKeySymbols 
claus
parents: 122
diff changeset
   654
    "define the set of keys which are interpreted as leaveKeys.
claus
parents: 122
diff changeset
   655
     I.e. those that make the field inactive and accept (if acceptOnLeave is true).
claus
parents: 122
diff changeset
   656
     The default is a set of #CursorUp, #CursorDown, #Next, #Prior and #Return."
claus
parents: 122
diff changeset
   657
claus
parents: 122
diff changeset
   658
    leaveKeys := aCollectionOfKeySymbols
claus
parents: 122
diff changeset
   659
!
claus
parents: 122
diff changeset
   660
claus
parents: 122
diff changeset
   661
initialText:aString selected:aBoolean
claus
parents: 122
diff changeset
   662
    "set the initialText and select it if aBoolean is true"
claus
parents: 122
diff changeset
   663
claus
parents: 122
diff changeset
   664
    |len s|
claus
parents: 122
diff changeset
   665
claus
parents: 122
diff changeset
   666
    leftOffset := 0.
claus
parents: 122
diff changeset
   667
    aString isNil ifTrue:[
claus
parents: 122
diff changeset
   668
	s := nil
claus
parents: 122
diff changeset
   669
    ] ifFalse:[
claus
parents: 122
diff changeset
   670
	s := aString asString
claus
parents: 122
diff changeset
   671
    ].
claus
parents: 122
diff changeset
   672
    self contents:s.
claus
parents: 122
diff changeset
   673
    aBoolean ifTrue:[
claus
parents: 122
diff changeset
   674
	(len := s size) ~~ 0 ifTrue:[
claus
parents: 122
diff changeset
   675
	    self selectFromLine:1 col:1 toLine:1 col:len
claus
parents: 122
diff changeset
   676
	]
claus
parents: 122
diff changeset
   677
    ]
claus
parents: 122
diff changeset
   678
!
claus
parents: 122
diff changeset
   679
claus
parents: 122
diff changeset
   680
crAction:aBlock
claus
parents: 122
diff changeset
   681
    "define an action to be evaluated when the return key is pressed."
claus
parents: 122
diff changeset
   682
claus
parents: 122
diff changeset
   683
    crAction := aBlock
claus
parents: 122
diff changeset
   684
!
claus
parents: 122
diff changeset
   685
claus
parents: 122
diff changeset
   686
tabAction:aBlock
claus
parents: 122
diff changeset
   687
    "define an action to be evaluated when the tabulator key is pressed."
claus
parents: 122
diff changeset
   688
claus
parents: 122
diff changeset
   689
    tabAction := aBlock
claus
parents: 122
diff changeset
   690
!
claus
parents: 122
diff changeset
   691
claus
parents: 122
diff changeset
   692
acceptOnReturn:aBoolean
128
claus
parents: 127
diff changeset
   693
    "set/clear the acceptOnReturn flag. The default is false."
125
claus
parents: 122
diff changeset
   694
claus
parents: 122
diff changeset
   695
     acceptOnReturn := aBoolean
claus
parents: 122
diff changeset
   696
!
claus
parents: 122
diff changeset
   697
claus
parents: 122
diff changeset
   698
initialText:aString
claus
parents: 122
diff changeset
   699
    "set the initialText and select it"
claus
parents: 122
diff changeset
   700
claus
parents: 122
diff changeset
   701
    self initialText:aString selected:true
claus
parents: 122
diff changeset
   702
!
claus
parents: 122
diff changeset
   703
claus
parents: 122
diff changeset
   704
editValue:aStringOrObject
claus
parents: 122
diff changeset
   705
    "set the contents. If there is a converter, use it to convert
claus
parents: 122
diff changeset
   706
     the object into a printed representation.
claus
parents: 122
diff changeset
   707
     Otherwise, the argument is supposed to be a string like object,
claus
parents: 122
diff changeset
   708
     and used directly (i.e. this is equivalent to sending #contents:)."
claus
parents: 122
diff changeset
   709
claus
parents: 122
diff changeset
   710
    self editValue:aStringOrObject selected:false
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   711
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   712
125
claus
parents: 122
diff changeset
   713
disable
claus
parents: 122
diff changeset
   714
    "disable the field; hide cursor and ignore input"
claus
parents: 122
diff changeset
   715
claus
parents: 122
diff changeset
   716
    enabled ifTrue:[
claus
parents: 122
diff changeset
   717
	enabled := false.
claus
parents: 122
diff changeset
   718
	self hideCursor
claus
parents: 122
diff changeset
   719
    ]
claus
parents: 122
diff changeset
   720
!
claus
parents: 122
diff changeset
   721
claus
parents: 122
diff changeset
   722
editValue:aStringOrObject selected:aBoolean
claus
parents: 122
diff changeset
   723
    "set the contents. If there is a converter, use it to convert
claus
parents: 122
diff changeset
   724
     the object into a printed representation.
claus
parents: 122
diff changeset
   725
     Otherwise, the argument is supposed to be a string like object,
claus
parents: 122
diff changeset
   726
     and used directly (i.e. this is equivalent to sending #contents:)."
claus
parents: 122
diff changeset
   727
claus
parents: 122
diff changeset
   728
    |string|
claus
parents: 122
diff changeset
   729
claus
parents: 122
diff changeset
   730
    converter notNil ifTrue:[
claus
parents: 122
diff changeset
   731
	string := converter printStringFor:aStringOrObject
claus
parents: 122
diff changeset
   732
    ] ifFalse:[
claus
parents: 122
diff changeset
   733
	string :=  aStringOrObject.
claus
parents: 122
diff changeset
   734
    ].
claus
parents: 122
diff changeset
   735
    self contents:string.
claus
parents: 122
diff changeset
   736
    aBoolean ifTrue:[
claus
parents: 122
diff changeset
   737
	self selectFromLine:1 col:1 toLine:1 col:string size
claus
parents: 122
diff changeset
   738
    ]
claus
parents: 122
diff changeset
   739
!
claus
parents: 122
diff changeset
   740
claus
parents: 122
diff changeset
   741
acceptOnLeave:aBoolean
claus
parents: 122
diff changeset
   742
    "set/clear the acceptOnLeave flag. The default is false."
claus
parents: 122
diff changeset
   743
claus
parents: 122
diff changeset
   744
     acceptOnLeave := aBoolean
claus
parents: 122
diff changeset
   745
!
claus
parents: 122
diff changeset
   746
claus
parents: 122
diff changeset
   747
converter:aConverter
claus
parents: 122
diff changeset
   748
    "set the converter. If non-nil,
claus
parents: 122
diff changeset
   749
     the converter is applied to the text to convert from the string
claus
parents: 122
diff changeset
   750
     representation to the actual object value and vice versa.
claus
parents: 122
diff changeset
   751
     The default converter is nil, meaning no-conversion
claus
parents: 122
diff changeset
   752
     (i.e. the edited object is the string itself."
claus
parents: 122
diff changeset
   753
claus
parents: 122
diff changeset
   754
    converter := aConverter
claus
parents: 122
diff changeset
   755
!
claus
parents: 122
diff changeset
   756
claus
parents: 122
diff changeset
   757
enableAction:aBlock
claus
parents: 122
diff changeset
   758
    "define an action to be evaluated when enabled by clicking upon"
claus
parents: 122
diff changeset
   759
claus
parents: 122
diff changeset
   760
    enableAction := aBlock
claus
parents: 122
diff changeset
   761
!
claus
parents: 122
diff changeset
   762
claus
parents: 122
diff changeset
   763
converter
claus
parents: 122
diff changeset
   764
    "return the converter (if any)."
claus
parents: 122
diff changeset
   765
claus
parents: 122
diff changeset
   766
    ^ converter
claus
parents: 122
diff changeset
   767
!
claus
parents: 122
diff changeset
   768
claus
parents: 122
diff changeset
   769
maxChars:aNumberOrNil
claus
parents: 122
diff changeset
   770
    "set the maximum number of characters that are allowed in
claus
parents: 122
diff changeset
   771
     the field. Additional input will be ignored by the field.
claus
parents: 122
diff changeset
   772
     A limit of nil means: unlimited. This is the default.
claus
parents: 122
diff changeset
   773
     This method has been renamed from #lengthLimit: for ST-80
claus
parents: 122
diff changeset
   774
     compatibility."
claus
parents: 122
diff changeset
   775
claus
parents: 122
diff changeset
   776
    lengthLimit := aNumberOrNil
claus
parents: 122
diff changeset
   777
!
claus
parents: 122
diff changeset
   778
claus
parents: 122
diff changeset
   779
stringValue
claus
parents: 122
diff changeset
   780
    "alias for #contents - for ST-80 compatibility"
claus
parents: 122
diff changeset
   781
claus
parents: 122
diff changeset
   782
    ^ self contents
claus
parents: 122
diff changeset
   783
! !
claus
parents: 122
diff changeset
   784
claus
parents: 122
diff changeset
   785
!EditField methodsFor:'initialization'!
claus
parents: 122
diff changeset
   786
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   787
initStyle
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   788
    super initStyle.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   789
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   790
    DefaultBackgroundColor notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   791
	bgColor := DefaultBackgroundColor on:device.
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   792
	self viewBackground:bgColor.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   793
    ].
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   794
    fgColor := DefaultForegroundColor.
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   795
    selectionFgColor := DefaultSelectionForegroundColor.
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   796
    selectionBgColor := DefaultSelectionBackgroundColor.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   797
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   798
    DefaultFont notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   799
	font := DefaultFont on:device
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   800
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   801
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   802
125
claus
parents: 122
diff changeset
   803
initialize
claus
parents: 122
diff changeset
   804
    super initialize.
claus
parents: 122
diff changeset
   805
    self height:(font height + font descent + (topMargin * 2)).
claus
parents: 122
diff changeset
   806
    enabled := true.
claus
parents: 122
diff changeset
   807
    fixedSize := true.
claus
parents: 122
diff changeset
   808
    nFullLinesShown := 1.
claus
parents: 122
diff changeset
   809
    nLinesShown := 1.
130
claus
parents: 128
diff changeset
   810
    immediateAccept := false.
claus
parents: 128
diff changeset
   811
"/    acceptOnLeave := false.
claus
parents: 128
diff changeset
   812
"/    acceptOnReturn := false.
claus
parents: 128
diff changeset
   813
    acceptOnLeave := acceptOnReturn := true.
125
claus
parents: 122
diff changeset
   814
    cursorShown := true.
claus
parents: 122
diff changeset
   815
    leaveKeys := self class defaultLeaveKeys.
claus
parents: 122
diff changeset
   816
!
claus
parents: 122
diff changeset
   817
97
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   818
editMenu
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   819
    |labels selectors m|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   820
97
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   821
    labels := #(
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   822
		'copy'
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   823
		'cut'
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   824
		'paste'
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
   825
"
97
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   826
		'replace'
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
   827
"
97
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   828
		'-'
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   829
		'accept'
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   830
	       ).
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   831
97
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   832
     selectors := #(
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   833
		 copySelection
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   834
		 cut
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   835
		 paste
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   836
"
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   837
		 replace
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
   838
"
97
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   839
		 nil
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   840
		 accept
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   841
		).
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   842
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   843
    m := PopUpMenu 
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   844
	  labels:(resources array:labels)
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   845
	  selectors:selectors.
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   846
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   847
    self hasSelection ifFalse:[
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   848
	m disable:#copySelection.
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   849
	m disable:#cut
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   850
    ].
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   851
cbf495fe3b64 *** empty log message ***
claus
parents: 77
diff changeset
   852
    ^ m
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   853
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   854
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   855
!EditField methodsFor:'realization'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   856
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   857
realize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   858
    "scroll back to beginning when realized"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   859
    leftOffset := 0.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   860
    super realize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   861
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   862
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   863
!EditField methodsFor:'queries'!
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   864
130
claus
parents: 128
diff changeset
   865
preferredExtent
claus
parents: 128
diff changeset
   866
    "return the preferred extent of this view.
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   867
     That is the width of the string plus some extra, 
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   868
     but not wider than half of the screen"
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   869
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   870
    |string w|
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   871
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   872
    string := self contents.
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   873
    (string isNil or:[string isBlank]) ifTrue:[
130
claus
parents: 128
diff changeset
   874
	string := '          ' "/ just any string is ok ^ super preferredExtent
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   875
    ].
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   876
    w := (((font on:device) widthOf:string) * 1.5) rounded.
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   877
    w := w min:(device width // 2).
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   878
    ^ w @ self height
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   879
! !
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   880
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   881
!EditField methodsFor:'cursor drawing'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   882
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   883
showCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   884
    "make cursor visible if currently invisible - but only if this
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   885
     EditField is enabled"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   886
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   887
    enabled ifTrue:[super showCursor]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   888
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   889
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   890
!EditField methodsFor:'cursor movement'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   891
125
claus
parents: 122
diff changeset
   892
cursorCol:col
claus
parents: 122
diff changeset
   893
    "redefined to lock the cursor at the end, if I have a lngthLimit"
claus
parents: 122
diff changeset
   894
claus
parents: 122
diff changeset
   895
    |c sz|
claus
parents: 122
diff changeset
   896
claus
parents: 122
diff changeset
   897
    c := col.
claus
parents: 122
diff changeset
   898
    lengthLimit notNil ifTrue:[
claus
parents: 122
diff changeset
   899
	sz := lengthLimit.
claus
parents: 122
diff changeset
   900
	c > sz ifTrue:[
claus
parents: 122
diff changeset
   901
	    c := sz+1.
claus
parents: 122
diff changeset
   902
	]
claus
parents: 122
diff changeset
   903
    ].
claus
parents: 122
diff changeset
   904
    super cursorCol:c
claus
parents: 122
diff changeset
   905
!
claus
parents: 122
diff changeset
   906
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   907
cursorLine:line col:col
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   908
    "catch cursor movement"
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   909
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 19
diff changeset
   910
    super cursorLine:1 col:col
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   911
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   912
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   913
cursorDown
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   914
    "catch cursor movement"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   915
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   916
    (cursorVisibleLine == nLinesShown) ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
   917
	super cursorDown
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   918
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   919
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   920
70
14443a9ea4ec *** empty log message ***
claus
parents: 62
diff changeset
   921
!EditField methodsFor:'event handling'!
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
   922
125
claus
parents: 122
diff changeset
   923
keyPress:key x:x y:y
claus
parents: 122
diff changeset
   924
    "if keyHandler is defined, pass input; otherwise check for leave
claus
parents: 122
diff changeset
   925
     keys"
claus
parents: 122
diff changeset
   926
claus
parents: 122
diff changeset
   927
    |leave xCol newOffset oldWidth newWidth|
claus
parents: 122
diff changeset
   928
claus
parents: 122
diff changeset
   929
    enabled ifFalse:[
127
claus
parents: 125
diff changeset
   930
	^ self
125
claus
parents: 122
diff changeset
   931
    ].
claus
parents: 122
diff changeset
   932
claus
parents: 122
diff changeset
   933
    (key == #DeleteLine) ifTrue:[
127
claus
parents: 125
diff changeset
   934
	Smalltalk at:#CopyBuffer put:(self contents).
claus
parents: 125
diff changeset
   935
	self contents:''. ^ self
125
claus
parents: 122
diff changeset
   936
    ].
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
   937
125
claus
parents: 122
diff changeset
   938
    (key == #Tab) ifTrue:[
127
claus
parents: 125
diff changeset
   939
	tabAction notNil ifTrue:[tabAction value. ^ self].
125
claus
parents: 122
diff changeset
   940
    ].
claus
parents: 122
diff changeset
   941
    (key == #Return) ifTrue:[
127
claus
parents: 125
diff changeset
   942
	crAction notNil ifTrue:[crAction value. ^ self].
125
claus
parents: 122
diff changeset
   943
    ].
claus
parents: 122
diff changeset
   944
    leave := leaveKeys includes:key.
claus
parents: 122
diff changeset
   945
    leave ifTrue:[
127
claus
parents: 125
diff changeset
   946
	leaveAction notNil ifTrue:[
claus
parents: 125
diff changeset
   947
	    leaveAction value:key
claus
parents: 125
diff changeset
   948
	].
121
claus
parents: 120
diff changeset
   949
127
claus
parents: 125
diff changeset
   950
	((key == #Return and:[acceptOnReturn])
claus
parents: 125
diff changeset
   951
	or:[key ~~ #Return and:[acceptOnLeave]]) ifTrue:[
claus
parents: 125
diff changeset
   952
	    self accept.
claus
parents: 125
diff changeset
   953
	].
125
claus
parents: 122
diff changeset
   954
127
claus
parents: 125
diff changeset
   955
	x >= 0 ifTrue:[
claus
parents: 125
diff changeset
   956
	    "
claus
parents: 125
diff changeset
   957
	     let superview know about the leave ...
claus
parents: 125
diff changeset
   958
	     This is a temporary kludge for the tableWidget -
claus
parents: 125
diff changeset
   959
	     it is no clean coding style. Should make the tableWidget
claus
parents: 125
diff changeset
   960
	     a proper model and handle it via the changed mechanism ....
claus
parents: 125
diff changeset
   961
	    "
claus
parents: 125
diff changeset
   962
	    (superView notNil and:[superView canHandle:key from:self]) ifTrue:[
claus
parents: 125
diff changeset
   963
		superView keyPress:key x:x y:y.
claus
parents: 125
diff changeset
   964
	    ].
claus
parents: 125
diff changeset
   965
	].
claus
parents: 125
diff changeset
   966
	^ self
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
   967
    ].
121
claus
parents: 120
diff changeset
   968
125
claus
parents: 122
diff changeset
   969
    "
claus
parents: 122
diff changeset
   970
     ignore some keys (if not a leaveKey) ...
claus
parents: 122
diff changeset
   971
    "
claus
parents: 122
diff changeset
   972
    (key == #Find) ifTrue:[^self].
claus
parents: 122
diff changeset
   973
    (key == #FindNext) ifTrue:[^self].
claus
parents: 122
diff changeset
   974
    (key == #FindPrev) ifTrue:[^self].
claus
parents: 122
diff changeset
   975
    (key == #GotoLine) ifTrue:[^self].
claus
parents: 122
diff changeset
   976
claus
parents: 122
diff changeset
   977
    "
claus
parents: 122
diff changeset
   978
     a normal key - let superclass's method insert it
claus
parents: 122
diff changeset
   979
    "
claus
parents: 122
diff changeset
   980
    oldWidth := self widthOfContents.
claus
parents: 122
diff changeset
   981
    super keyPress:key x:x y:y.
claus
parents: 122
diff changeset
   982
claus
parents: 122
diff changeset
   983
    "
claus
parents: 122
diff changeset
   984
     for end-of-text, also move to end-of-line
claus
parents: 122
diff changeset
   985
    "
claus
parents: 122
diff changeset
   986
    key == #EndOfText ifTrue:[
127
claus
parents: 125
diff changeset
   987
	super keyPress:#EndOfLine x:x y:y.
125
claus
parents: 122
diff changeset
   988
    ].
claus
parents: 122
diff changeset
   989
    newWidth := self widthOfContents.
claus
parents: 122
diff changeset
   990
claus
parents: 122
diff changeset
   991
    "
claus
parents: 122
diff changeset
   992
     should (& can) we resize ?
claus
parents: 122
diff changeset
   993
    "
claus
parents: 122
diff changeset
   994
    xCol := (self xOfCol:cursorCol inVisibleLine:cursorLine) - leftOffset.
claus
parents: 122
diff changeset
   995
    (xCol > (width * (5/6))) ifTrue:[
130
claus
parents: 128
diff changeset
   996
	self changed:#preferredExtent
125
claus
parents: 122
diff changeset
   997
    ] ifFalse:[
127
claus
parents: 125
diff changeset
   998
	newWidth < (width * (1/6)) ifTrue:[
130
claus
parents: 128
diff changeset
   999
	    self changed:#preferredExtent
127
claus
parents: 125
diff changeset
  1000
	]
125
claus
parents: 122
diff changeset
  1001
    ].
claus
parents: 122
diff changeset
  1002
claus
parents: 122
diff changeset
  1003
    "
claus
parents: 122
diff changeset
  1004
     did someone react ?
claus
parents: 122
diff changeset
  1005
     (if not, we scroll horizontally)
claus
parents: 122
diff changeset
  1006
    "
claus
parents: 122
diff changeset
  1007
    xCol := (self xOfCol:cursorCol inVisibleLine:cursorLine) - leftOffset.
claus
parents: 122
diff changeset
  1008
    (xCol > (width * (5/6))) ifTrue:[
127
claus
parents: 125
diff changeset
  1009
	newOffset := leftOffset + (width // 2).
125
claus
parents: 122
diff changeset
  1010
    ] ifFalse:[
127
claus
parents: 125
diff changeset
  1011
	(xCol < (width * (1/6))) ifTrue:[
claus
parents: 125
diff changeset
  1012
	    newOffset := 0 max: leftOffset - (width // 2).
claus
parents: 125
diff changeset
  1013
	] ifFalse:[
claus
parents: 125
diff changeset
  1014
	    newOffset := leftOffset
claus
parents: 125
diff changeset
  1015
	]
125
claus
parents: 122
diff changeset
  1016
    ].
claus
parents: 122
diff changeset
  1017
    newOffset ~~ leftOffset ifTrue:[
127
claus
parents: 125
diff changeset
  1018
	leftOffset := newOffset.
claus
parents: 125
diff changeset
  1019
	self clear.
claus
parents: 125
diff changeset
  1020
	self redraw
125
claus
parents: 122
diff changeset
  1021
    ]
19
a696fb528758 *** empty log message ***
claus
parents: 7
diff changeset
  1022
!
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1023
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1024
buttonPress:button x:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1025
    "enable myself on mouse click"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1026
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1027
    enabled ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
  1028
	enabled := true.
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
  1029
	super buttonPress:button x:x y:y.
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
  1030
	enableAction notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
  1031
	    enableAction value
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
  1032
	]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1033
    ] ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 47
diff changeset
  1034
	super buttonPress:button x:x y:y
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1035
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1036
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1037
125
claus
parents: 122
diff changeset
  1038
focusIn
claus
parents: 122
diff changeset
  1039
    "got the explicit focus"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1040
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1041
    enabled ifFalse:[
125
claus
parents: 122
diff changeset
  1042
	enabled := true.
claus
parents: 122
diff changeset
  1043
	super focusIn.
claus
parents: 122
diff changeset
  1044
	enableAction notNil ifTrue:[
claus
parents: 122
diff changeset
  1045
	    enableAction value
claus
parents: 122
diff changeset
  1046
	]
claus
parents: 122
diff changeset
  1047
    ] ifTrue:[
claus
parents: 122
diff changeset
  1048
	super focusIn
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1049
    ].
105
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1050
!
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1051
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1052
canHandle:aKey
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1053
    "return true, if the receiver would like to handle aKey
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1054
     (usually from another view, when the receiver is part of
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1055
      a more complex dialog box).
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1056
     We do return true here, since the editfield will handle
125
claus
parents: 122
diff changeset
  1057
     all keys.
claus
parents: 122
diff changeset
  1058
     OBSOLETE: dont use this anymore - its a leftover for the tableWidget"
105
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1059
3d064ba4a0cc *** empty log message ***
claus
parents: 97
diff changeset
  1060
    ^ true
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1061
! !
125
claus
parents: 122
diff changeset
  1062
claus
parents: 122
diff changeset
  1063
!EditField methodsFor:'editing'!
claus
parents: 122
diff changeset
  1064
claus
parents: 122
diff changeset
  1065
paste:someText
claus
parents: 122
diff changeset
  1066
    "redefined to force text to 1 line"
claus
parents: 122
diff changeset
  1067
claus
parents: 122
diff changeset
  1068
    super paste:someText.
claus
parents: 122
diff changeset
  1069
    list size > 1 ifTrue:[
claus
parents: 122
diff changeset
  1070
	self deleteFromLine:2 toLine:(list size)
claus
parents: 122
diff changeset
  1071
    ]
claus
parents: 122
diff changeset
  1072
! !