WinBuilder.st
author Claus Gittinger <cg@exept.de>
Sat, 11 Nov 1995 17:05:49 +0100
changeset 114 e577a2f332d0
parent 100 0300e64bb883
child 125 fa5b5e4336bf
permissions -rw-r--r--
uff - version methods changed to return stings
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
89
claus
parents: 86
diff changeset
     1
"
claus
parents: 86
diff changeset
     2
 COPYRIGHT (c) 1995 by Claus Gittinger
99
claus
parents: 89
diff changeset
     3
	      All Rights Reserved
89
claus
parents: 86
diff changeset
     4
claus
parents: 86
diff changeset
     5
 This software is furnished under a license and may be used
claus
parents: 86
diff changeset
     6
 only in accordance with the terms of that license and with the
claus
parents: 86
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
claus
parents: 86
diff changeset
     8
 be provided or otherwise made available to, or used by, any
claus
parents: 86
diff changeset
     9
 other person.  No title to or ownership of the software is
claus
parents: 86
diff changeset
    10
 hereby transferred.
claus
parents: 86
diff changeset
    11
"
claus
parents: 86
diff changeset
    12
100
claus
parents: 99
diff changeset
    13
'From Smalltalk/X, Version:2.10.7 on 7-sep-1995 at 10:06:38 pm'                 !
89
claus
parents: 86
diff changeset
    14
100
claus
parents: 99
diff changeset
    15
Object subclass:#WindowBuilder
75
claus
parents: 69
diff changeset
    16
	 instanceVariableNames:'topView application bindings aspects focusSequence'
66
claus
parents:
diff changeset
    17
	 classVariableNames:''
claus
parents:
diff changeset
    18
	 poolDictionaries:''
80
claus
parents: 75
diff changeset
    19
	 category:'Interface-Support-UI'
66
claus
parents:
diff changeset
    20
!
claus
parents:
diff changeset
    21
claus
parents:
diff changeset
    22
!WindowBuilder class methodsFor:'documentation'!
claus
parents:
diff changeset
    23
89
claus
parents: 86
diff changeset
    24
copyright
claus
parents: 86
diff changeset
    25
"
claus
parents: 86
diff changeset
    26
 COPYRIGHT (c) 1995 by Claus Gittinger
99
claus
parents: 89
diff changeset
    27
	      All Rights Reserved
89
claus
parents: 86
diff changeset
    28
claus
parents: 86
diff changeset
    29
 This software is furnished under a license and may be used
claus
parents: 86
diff changeset
    30
 only in accordance with the terms of that license and with the
claus
parents: 86
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
claus
parents: 86
diff changeset
    32
 be provided or otherwise made available to, or used by, any
claus
parents: 86
diff changeset
    33
 other person.  No title to or ownership of the software is
claus
parents: 86
diff changeset
    34
 hereby transferred.
claus
parents: 86
diff changeset
    35
"
claus
parents: 86
diff changeset
    36
!
claus
parents: 86
diff changeset
    37
claus
parents: 86
diff changeset
    38
version
114
e577a2f332d0 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 100
diff changeset
    39
    ^ '$Header: /cvs/stx/stx/libview2/Attic/WinBuilder.st,v 1.9 1995-11-11 16:05:30 cg Exp $'
89
claus
parents: 86
diff changeset
    40
!
claus
parents: 86
diff changeset
    41
66
claus
parents:
diff changeset
    42
documentation
claus
parents:
diff changeset
    43
"
69
claus
parents: 66
diff changeset
    44
    a no-op class, for systems which do not use the UIBuilder.
66
claus
parents:
diff changeset
    45
    Concrete subclasses know how to create a view (with components) from
claus
parents:
diff changeset
    46
    some interface spec. Currently, an experimantal version of UIBuilder exists,
claus
parents:
diff changeset
    47
    and more may be added in the future (for example, to parse different UI
claus
parents:
diff changeset
    48
    specs - thinking of motifs UIL specs etc).
claus
parents:
diff changeset
    49
"
claus
parents:
diff changeset
    50
! !
claus
parents:
diff changeset
    51
claus
parents:
diff changeset
    52
!WindowBuilder methodsFor:'accessing'!
claus
parents:
diff changeset
    53
100
claus
parents: 99
diff changeset
    54
window
claus
parents: 99
diff changeset
    55
    ^ topView
66
claus
parents:
diff changeset
    56
!
claus
parents:
diff changeset
    57
100
claus
parents: 99
diff changeset
    58
application
claus
parents: 99
diff changeset
    59
    ^ application
66
claus
parents:
diff changeset
    60
!
claus
parents:
diff changeset
    61
claus
parents:
diff changeset
    62
focusSequence 
claus
parents:
diff changeset
    63
    ^ focusSequence
claus
parents:
diff changeset
    64
!
claus
parents:
diff changeset
    65
claus
parents:
diff changeset
    66
aspectAt:aSymbol
claus
parents:
diff changeset
    67
    aspects isNil ifTrue:[^ nil].
claus
parents:
diff changeset
    68
    ^ aspects at:aSymbol ifAbsent:nil
claus
parents:
diff changeset
    69
!
claus
parents:
diff changeset
    70
100
claus
parents: 99
diff changeset
    71
application:anApplicationModel
claus
parents: 99
diff changeset
    72
    application := anApplicationModel
claus
parents: 99
diff changeset
    73
!
claus
parents: 99
diff changeset
    74
claus
parents: 99
diff changeset
    75
window:aView
claus
parents: 99
diff changeset
    76
    topView := aView
claus
parents: 99
diff changeset
    77
!
claus
parents: 99
diff changeset
    78
claus
parents: 99
diff changeset
    79
bindings
claus
parents: 99
diff changeset
    80
    ^ bindings
claus
parents: 99
diff changeset
    81
!
claus
parents: 99
diff changeset
    82
claus
parents: 99
diff changeset
    83
bindings:aDictionary
claus
parents: 99
diff changeset
    84
    bindings := aDictionary
claus
parents: 99
diff changeset
    85
!
claus
parents: 99
diff changeset
    86
claus
parents: 99
diff changeset
    87
componentAt:name put:aComponent
claus
parents: 99
diff changeset
    88
    bindings isNil ifTrue:[
claus
parents: 99
diff changeset
    89
	bindings := IdentityDictionary new.
claus
parents: 99
diff changeset
    90
    ].
claus
parents: 99
diff changeset
    91
    bindings at:name put:aComponent
claus
parents: 99
diff changeset
    92
!
claus
parents: 99
diff changeset
    93
66
claus
parents:
diff changeset
    94
aspectAt:aSymbol put:aModel
claus
parents:
diff changeset
    95
    aspects isNil ifTrue:[
claus
parents:
diff changeset
    96
	aspects := IdentityDictionary new
claus
parents:
diff changeset
    97
    ].
claus
parents:
diff changeset
    98
    ^ aspects at:aSymbol put:aModel
claus
parents:
diff changeset
    99
!
claus
parents:
diff changeset
   100
86
claus
parents: 80
diff changeset
   101
namedComponents
claus
parents: 80
diff changeset
   102
    ^ bindings
claus
parents: 80
diff changeset
   103
!
claus
parents: 80
diff changeset
   104
66
claus
parents:
diff changeset
   105
componentAt:name
86
claus
parents: 80
diff changeset
   106
    bindings isNil ifTrue:[^ nil].
75
claus
parents: 69
diff changeset
   107
    ^ bindings at:name ifAbsent:nil
66
claus
parents:
diff changeset
   108
!
claus
parents:
diff changeset
   109
claus
parents:
diff changeset
   110
windowGroup
claus
parents:
diff changeset
   111
    ^ topView windowGroup
claus
parents:
diff changeset
   112
!
claus
parents:
diff changeset
   113
claus
parents:
diff changeset
   114
source:anApplicationModel
claus
parents:
diff changeset
   115
    application := anApplicationModel
claus
parents:
diff changeset
   116
! !
claus
parents:
diff changeset
   117
claus
parents:
diff changeset
   118
!WindowBuilder methodsFor:'operation'!
claus
parents:
diff changeset
   119
80
claus
parents: 75
diff changeset
   120
openWithExtent:aPoint
claus
parents: 75
diff changeset
   121
    "open my topView, as previously created, but override
claus
parents: 75
diff changeset
   122
     the extent."
claus
parents: 75
diff changeset
   123
claus
parents: 75
diff changeset
   124
    self openWithExtent:aPoint andType:#normal 
claus
parents: 75
diff changeset
   125
!
claus
parents: 75
diff changeset
   126
66
claus
parents:
diff changeset
   127
openWithExtent:ext andType:type
80
claus
parents: 75
diff changeset
   128
    "open my topView, as previously created. The type argument
claus
parents: 75
diff changeset
   129
     may be #dialog or #normal, and specifies if the view should
claus
parents: 75
diff changeset
   130
     be opened as a modal view, blocking interaction to the currently 
claus
parents: 75
diff changeset
   131
     active view, or as a normal view."
claus
parents: 75
diff changeset
   132
66
claus
parents:
diff changeset
   133
    ext notNil ifTrue:[
claus
parents:
diff changeset
   134
	topView extent:ext
claus
parents:
diff changeset
   135
    ].
claus
parents:
diff changeset
   136
    type == #dialog ifTrue:[
claus
parents:
diff changeset
   137
	topView openModal.
claus
parents:
diff changeset
   138
	^ self
claus
parents:
diff changeset
   139
    ].
claus
parents:
diff changeset
   140
claus
parents:
diff changeset
   141
    type == #normal ifTrue:[
claus
parents:
diff changeset
   142
	topView open.
claus
parents:
diff changeset
   143
	^ self
claus
parents:
diff changeset
   144
    ].
80
claus
parents: 75
diff changeset
   145
    "
claus
parents: 75
diff changeset
   146
     if ST-80 supports more types - these may be added later
claus
parents: 75
diff changeset
   147
    "
66
claus
parents:
diff changeset
   148
    self halt:'unimplemented'
claus
parents:
diff changeset
   149
!
claus
parents:
diff changeset
   150
100
claus
parents: 99
diff changeset
   151
buildFromSpec:aSpec
claus
parents: 99
diff changeset
   152
    self subclassResponsibility
claus
parents: 99
diff changeset
   153
!
claus
parents: 99
diff changeset
   154
claus
parents: 99
diff changeset
   155
open
claus
parents: 99
diff changeset
   156
    "open my topView, as previously created"
claus
parents: 99
diff changeset
   157
claus
parents: 99
diff changeset
   158
    self openWithExtent:nil andType:#normal 
claus
parents: 99
diff changeset
   159
!
claus
parents: 99
diff changeset
   160
claus
parents: 99
diff changeset
   161
openDialog
claus
parents: 99
diff changeset
   162
    "open my topView, as previously created as a modal view,
claus
parents: 99
diff changeset
   163
     blocking interaction to the currently active view."
claus
parents: 99
diff changeset
   164
claus
parents: 99
diff changeset
   165
    self openWithExtent:nil andType:#dialog
claus
parents: 99
diff changeset
   166
!
claus
parents: 99
diff changeset
   167
claus
parents: 99
diff changeset
   168
openDialogWithExtent:ext
claus
parents: 99
diff changeset
   169
    "open my topView, as previously created as a modal view,
claus
parents: 99
diff changeset
   170
     blocking interaction to the currently active view."
claus
parents: 99
diff changeset
   171
claus
parents: 99
diff changeset
   172
    self openWithExtent:ext andType:#dialog
claus
parents: 99
diff changeset
   173
!
claus
parents: 99
diff changeset
   174
66
claus
parents:
diff changeset
   175
closeRequest
claus
parents:
diff changeset
   176
    topView destroy
claus
parents:
diff changeset
   177
! !
100
claus
parents: 99
diff changeset
   178
claus
parents: 99
diff changeset
   179
!WindowBuilder methodsFor:'spec creation callbacks'!
claus
parents: 99
diff changeset
   180
claus
parents: 99
diff changeset
   181
createdComponent:aView forSpec:spec
claus
parents: 99
diff changeset
   182
claus
parents: 99
diff changeset
   183
    "Modified: 5.9.1995 / 21:42:54 / claus"
claus
parents: 99
diff changeset
   184
! !
claus
parents: 99
diff changeset
   185