WindowBuilder.st
author claus
Sat, 09 Sep 1995 04:30:16 +0200
changeset 100 0300e64bb883
parent 99 a656b0c9dd21
child 114 e577a2f332d0
permissions -rw-r--r--
.
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
claus
parents: 86
diff changeset
    39
"
100
claus
parents: 99
diff changeset
    40
$Header: /cvs/stx/stx/libview2/WindowBuilder.st,v 1.8 1995-09-09 02:30:16 claus Exp $
89
claus
parents: 86
diff changeset
    41
"
claus
parents: 86
diff changeset
    42
!
claus
parents: 86
diff changeset
    43
66
claus
parents:
diff changeset
    44
documentation
claus
parents:
diff changeset
    45
"
69
claus
parents: 66
diff changeset
    46
    a no-op class, for systems which do not use the UIBuilder.
66
claus
parents:
diff changeset
    47
    Concrete subclasses know how to create a view (with components) from
claus
parents:
diff changeset
    48
    some interface spec. Currently, an experimantal version of UIBuilder exists,
claus
parents:
diff changeset
    49
    and more may be added in the future (for example, to parse different UI
claus
parents:
diff changeset
    50
    specs - thinking of motifs UIL specs etc).
claus
parents:
diff changeset
    51
"
claus
parents:
diff changeset
    52
! !
claus
parents:
diff changeset
    53
claus
parents:
diff changeset
    54
!WindowBuilder methodsFor:'accessing'!
claus
parents:
diff changeset
    55
100
claus
parents: 99
diff changeset
    56
window
claus
parents: 99
diff changeset
    57
    ^ topView
66
claus
parents:
diff changeset
    58
!
claus
parents:
diff changeset
    59
100
claus
parents: 99
diff changeset
    60
application
claus
parents: 99
diff changeset
    61
    ^ application
66
claus
parents:
diff changeset
    62
!
claus
parents:
diff changeset
    63
claus
parents:
diff changeset
    64
focusSequence 
claus
parents:
diff changeset
    65
    ^ focusSequence
claus
parents:
diff changeset
    66
!
claus
parents:
diff changeset
    67
claus
parents:
diff changeset
    68
aspectAt:aSymbol
claus
parents:
diff changeset
    69
    aspects isNil ifTrue:[^ nil].
claus
parents:
diff changeset
    70
    ^ aspects at:aSymbol ifAbsent:nil
claus
parents:
diff changeset
    71
!
claus
parents:
diff changeset
    72
100
claus
parents: 99
diff changeset
    73
application:anApplicationModel
claus
parents: 99
diff changeset
    74
    application := anApplicationModel
claus
parents: 99
diff changeset
    75
!
claus
parents: 99
diff changeset
    76
claus
parents: 99
diff changeset
    77
window:aView
claus
parents: 99
diff changeset
    78
    topView := aView
claus
parents: 99
diff changeset
    79
!
claus
parents: 99
diff changeset
    80
claus
parents: 99
diff changeset
    81
bindings
claus
parents: 99
diff changeset
    82
    ^ bindings
claus
parents: 99
diff changeset
    83
!
claus
parents: 99
diff changeset
    84
claus
parents: 99
diff changeset
    85
bindings:aDictionary
claus
parents: 99
diff changeset
    86
    bindings := aDictionary
claus
parents: 99
diff changeset
    87
!
claus
parents: 99
diff changeset
    88
claus
parents: 99
diff changeset
    89
componentAt:name put:aComponent
claus
parents: 99
diff changeset
    90
    bindings isNil ifTrue:[
claus
parents: 99
diff changeset
    91
	bindings := IdentityDictionary new.
claus
parents: 99
diff changeset
    92
    ].
claus
parents: 99
diff changeset
    93
    bindings at:name put:aComponent
claus
parents: 99
diff changeset
    94
!
claus
parents: 99
diff changeset
    95
66
claus
parents:
diff changeset
    96
aspectAt:aSymbol put:aModel
claus
parents:
diff changeset
    97
    aspects isNil ifTrue:[
claus
parents:
diff changeset
    98
	aspects := IdentityDictionary new
claus
parents:
diff changeset
    99
    ].
claus
parents:
diff changeset
   100
    ^ aspects at:aSymbol put:aModel
claus
parents:
diff changeset
   101
!
claus
parents:
diff changeset
   102
86
claus
parents: 80
diff changeset
   103
namedComponents
claus
parents: 80
diff changeset
   104
    ^ bindings
claus
parents: 80
diff changeset
   105
!
claus
parents: 80
diff changeset
   106
66
claus
parents:
diff changeset
   107
componentAt:name
86
claus
parents: 80
diff changeset
   108
    bindings isNil ifTrue:[^ nil].
75
claus
parents: 69
diff changeset
   109
    ^ bindings at:name ifAbsent:nil
66
claus
parents:
diff changeset
   110
!
claus
parents:
diff changeset
   111
claus
parents:
diff changeset
   112
windowGroup
claus
parents:
diff changeset
   113
    ^ topView windowGroup
claus
parents:
diff changeset
   114
!
claus
parents:
diff changeset
   115
claus
parents:
diff changeset
   116
source:anApplicationModel
claus
parents:
diff changeset
   117
    application := anApplicationModel
claus
parents:
diff changeset
   118
! !
claus
parents:
diff changeset
   119
claus
parents:
diff changeset
   120
!WindowBuilder methodsFor:'operation'!
claus
parents:
diff changeset
   121
80
claus
parents: 75
diff changeset
   122
openWithExtent:aPoint
claus
parents: 75
diff changeset
   123
    "open my topView, as previously created, but override
claus
parents: 75
diff changeset
   124
     the extent."
claus
parents: 75
diff changeset
   125
claus
parents: 75
diff changeset
   126
    self openWithExtent:aPoint andType:#normal 
claus
parents: 75
diff changeset
   127
!
claus
parents: 75
diff changeset
   128
66
claus
parents:
diff changeset
   129
openWithExtent:ext andType:type
80
claus
parents: 75
diff changeset
   130
    "open my topView, as previously created. The type argument
claus
parents: 75
diff changeset
   131
     may be #dialog or #normal, and specifies if the view should
claus
parents: 75
diff changeset
   132
     be opened as a modal view, blocking interaction to the currently 
claus
parents: 75
diff changeset
   133
     active view, or as a normal view."
claus
parents: 75
diff changeset
   134
66
claus
parents:
diff changeset
   135
    ext notNil ifTrue:[
claus
parents:
diff changeset
   136
	topView extent:ext
claus
parents:
diff changeset
   137
    ].
claus
parents:
diff changeset
   138
    type == #dialog ifTrue:[
claus
parents:
diff changeset
   139
	topView openModal.
claus
parents:
diff changeset
   140
	^ self
claus
parents:
diff changeset
   141
    ].
claus
parents:
diff changeset
   142
claus
parents:
diff changeset
   143
    type == #normal ifTrue:[
claus
parents:
diff changeset
   144
	topView open.
claus
parents:
diff changeset
   145
	^ self
claus
parents:
diff changeset
   146
    ].
80
claus
parents: 75
diff changeset
   147
    "
claus
parents: 75
diff changeset
   148
     if ST-80 supports more types - these may be added later
claus
parents: 75
diff changeset
   149
    "
66
claus
parents:
diff changeset
   150
    self halt:'unimplemented'
claus
parents:
diff changeset
   151
!
claus
parents:
diff changeset
   152
100
claus
parents: 99
diff changeset
   153
buildFromSpec:aSpec
claus
parents: 99
diff changeset
   154
    self subclassResponsibility
claus
parents: 99
diff changeset
   155
!
claus
parents: 99
diff changeset
   156
claus
parents: 99
diff changeset
   157
open
claus
parents: 99
diff changeset
   158
    "open my topView, as previously created"
claus
parents: 99
diff changeset
   159
claus
parents: 99
diff changeset
   160
    self openWithExtent:nil andType:#normal 
claus
parents: 99
diff changeset
   161
!
claus
parents: 99
diff changeset
   162
claus
parents: 99
diff changeset
   163
openDialog
claus
parents: 99
diff changeset
   164
    "open my topView, as previously created as a modal view,
claus
parents: 99
diff changeset
   165
     blocking interaction to the currently active view."
claus
parents: 99
diff changeset
   166
claus
parents: 99
diff changeset
   167
    self openWithExtent:nil andType:#dialog
claus
parents: 99
diff changeset
   168
!
claus
parents: 99
diff changeset
   169
claus
parents: 99
diff changeset
   170
openDialogWithExtent:ext
claus
parents: 99
diff changeset
   171
    "open my topView, as previously created as a modal view,
claus
parents: 99
diff changeset
   172
     blocking interaction to the currently active view."
claus
parents: 99
diff changeset
   173
claus
parents: 99
diff changeset
   174
    self openWithExtent:ext andType:#dialog
claus
parents: 99
diff changeset
   175
!
claus
parents: 99
diff changeset
   176
66
claus
parents:
diff changeset
   177
closeRequest
claus
parents:
diff changeset
   178
    topView destroy
claus
parents:
diff changeset
   179
! !
100
claus
parents: 99
diff changeset
   180
claus
parents: 99
diff changeset
   181
!WindowBuilder methodsFor:'spec creation callbacks'!
claus
parents: 99
diff changeset
   182
claus
parents: 99
diff changeset
   183
createdComponent:aView forSpec:spec
claus
parents: 99
diff changeset
   184
claus
parents: 99
diff changeset
   185
    "Modified: 5.9.1995 / 21:42:54 / claus"
claus
parents: 99
diff changeset
   186
! !
claus
parents: 99
diff changeset
   187