glimmer-dsl-swt 4.22.2.4 → 4.22.2.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +5 -0
- data/README.md +15 -7
- data/VERSION +1 -1
- data/docs/reference/GLIMMER_COMMAND.md +3 -1
- data/docs/reference/GLIMMER_SAMPLES.md +2 -9
- data/glimmer-dsl-swt.gemspec +0 -0
- data/lib/glimmer/launcher.rb +7 -4
- data/lib/glimmer/rake_task/scaffold.rb +25 -13
- data/samples/elaborate/calculator.rb +12 -12
- data/samples/elaborate/contact_manager.rb +26 -14
- data/samples/elaborate/game_of_life.rb +8 -8
- data/samples/elaborate/klondike_solitaire/view/action_panel.rb +2 -2
- data/samples/elaborate/klondike_solitaire/view/klondike_solitaire_menu_bar.rb +15 -10
- data/samples/elaborate/login.rb +16 -10
- data/samples/elaborate/mandelbrot_fractal.rb +26 -20
- data/samples/elaborate/meta_sample.rb +6 -6
- data/samples/elaborate/metronome.rb +4 -4
- data/samples/elaborate/stock_ticker.rb +12 -12
- data/samples/elaborate/tetris.rb +4 -4
- data/samples/elaborate/timer.rb +36 -26
- data/samples/elaborate/user_profile.rb +53 -14
- data/samples/elaborate/weather.rb +2 -2
- data/samples/hello/hello_button.rb +3 -3
- data/samples/hello/hello_canvas_animation.rb +2 -2
- data/samples/hello/hello_color_dialog.rb +4 -4
- data/samples/hello/hello_custom_shell.rb +2 -2
- data/samples/hello/hello_dialog.rb +4 -4
- data/samples/hello/hello_directory_dialog.rb +2 -2
- data/samples/hello/hello_expand_bar.rb +4 -5
- data/samples/hello/hello_file_dialog.rb +2 -2
- data/samples/hello/hello_font_dialog.rb +2 -2
- data/samples/hello/hello_link.rb +5 -4
- data/samples/hello/hello_list_multi_selection.rb +3 -1
- data/samples/hello/hello_list_single_selection.rb +3 -1
- data/samples/hello/hello_menu_bar.rb +28 -28
- data/samples/hello/hello_message_box.rb +2 -2
- data/samples/hello/hello_pop_up_context_menu.rb +18 -8
- data/samples/hello/hello_shell.rb +16 -16
- data/samples/hello/hello_styled_text.rb +2 -2
- data/samples/hello/hello_table.rb +4 -4
- data/samples/hello/hello_tray_item.rb +2 -2
- metadata +2 -2
@@ -186,10 +186,10 @@ class MandelbrotFractal
|
|
186
186
|
minimum_size mandelbrot.width + 29, mandelbrot.height + 77
|
187
187
|
image @mandelbrot_image
|
188
188
|
|
189
|
-
on_shell_closed
|
189
|
+
on_shell_closed do
|
190
190
|
@thread.kill # should not be dangerous in this case
|
191
191
|
puts "Mandelbrot background calculation stopped!"
|
192
|
-
|
192
|
+
end
|
193
193
|
|
194
194
|
progress_bar {
|
195
195
|
layout_data :fill, :center, true, false
|
@@ -205,27 +205,27 @@ class MandelbrotFractal
|
|
205
205
|
image @mandelbrot_image
|
206
206
|
cursor :no
|
207
207
|
|
208
|
-
on_mouse_down
|
208
|
+
on_mouse_down do
|
209
209
|
@drag_detected = false
|
210
210
|
@canvas.cursor = :hand
|
211
|
-
|
211
|
+
end
|
212
212
|
|
213
|
-
on_drag_detected
|
213
|
+
on_drag_detected do |drag_detect_event|
|
214
214
|
@drag_detected = true
|
215
215
|
@drag_start_x = drag_detect_event.x
|
216
216
|
@drag_start_y = drag_detect_event.y
|
217
|
-
|
217
|
+
end
|
218
218
|
|
219
|
-
on_mouse_move
|
219
|
+
on_mouse_move do |mouse_event|
|
220
220
|
if @drag_detected
|
221
221
|
origin = @scrolled_composite.origin
|
222
222
|
new_x = origin.x - (mouse_event.x - @drag_start_x)
|
223
223
|
new_y = origin.y - (mouse_event.y - @drag_start_y)
|
224
224
|
@scrolled_composite.set_origin(new_x, new_y)
|
225
225
|
end
|
226
|
-
|
226
|
+
end
|
227
227
|
|
228
|
-
on_mouse_up
|
228
|
+
on_mouse_up do |mouse_event|
|
229
229
|
if !@drag_detected
|
230
230
|
origin = @scrolled_composite.origin
|
231
231
|
@location_x = mouse_event.x
|
@@ -238,7 +238,7 @@ class MandelbrotFractal
|
|
238
238
|
end
|
239
239
|
@canvas.cursor = can_zoom_in? ? :cross : :no
|
240
240
|
@drag_detected = false
|
241
|
-
|
241
|
+
end
|
242
242
|
|
243
243
|
}
|
244
244
|
}
|
@@ -251,27 +251,33 @@ class MandelbrotFractal
|
|
251
251
|
text 'Zoom &In'
|
252
252
|
accelerator COMMAND, '+'
|
253
253
|
|
254
|
-
on_widget_selected
|
254
|
+
on_widget_selected do
|
255
|
+
zoom_in
|
256
|
+
end
|
255
257
|
}
|
256
258
|
|
257
259
|
menu_item {
|
258
260
|
text 'Zoom &Out'
|
259
261
|
accelerator COMMAND, '-'
|
260
262
|
|
261
|
-
on_widget_selected
|
263
|
+
on_widget_selected do
|
264
|
+
zoom_out
|
265
|
+
end
|
262
266
|
}
|
263
267
|
|
264
268
|
menu_item {
|
265
269
|
text '&Reset Zoom'
|
266
270
|
accelerator COMMAND, '0'
|
267
271
|
|
268
|
-
on_widget_selected
|
272
|
+
on_widget_selected do
|
273
|
+
perform_zoom(mandelbrot_zoom: 1.0)
|
274
|
+
end
|
269
275
|
}
|
270
276
|
}
|
271
277
|
menu {
|
272
278
|
text '&Cores'
|
273
279
|
|
274
|
-
Concurrent.physical_processor_count.times
|
280
|
+
Concurrent.physical_processor_count.times do |n|
|
275
281
|
processor_number = n + 1
|
276
282
|
menu_item(:radio) {
|
277
283
|
text "&#{processor_number}"
|
@@ -287,11 +293,11 @@ class MandelbrotFractal
|
|
287
293
|
|
288
294
|
selection true if processor_number == Concurrent.physical_processor_count
|
289
295
|
|
290
|
-
on_widget_selected
|
296
|
+
on_widget_selected do
|
291
297
|
Mandelbrot.processor_count = processor_number
|
292
|
-
|
298
|
+
end
|
293
299
|
}
|
294
|
-
|
300
|
+
end
|
295
301
|
}
|
296
302
|
menu {
|
297
303
|
text '&Help'
|
@@ -300,9 +306,9 @@ class MandelbrotFractal
|
|
300
306
|
text '&Instructions'
|
301
307
|
accelerator COMMAND, :shift, :i
|
302
308
|
|
303
|
-
on_widget_selected
|
309
|
+
on_widget_selected do
|
304
310
|
display_help_instructions
|
305
|
-
|
311
|
+
end
|
306
312
|
}
|
307
313
|
}
|
308
314
|
}
|
@@ -352,7 +358,7 @@ class MandelbrotFractal
|
|
352
358
|
def color_palette
|
353
359
|
if @color_palette.nil?
|
354
360
|
@color_palette = [[0, 0, 0]] + 40.times.map { |i| [255 - i*5, 255 - i*5, 55 + i*5] }
|
355
|
-
@color_palette = @color_palette.map {|color_data| rgb(*color_data).swt_color}
|
361
|
+
@color_palette = @color_palette.map { |color_data| rgb(*color_data).swt_color }
|
356
362
|
end
|
357
363
|
@color_palette
|
358
364
|
end
|
@@ -253,22 +253,22 @@ class MetaSampleApplication
|
|
253
253
|
font height: 25
|
254
254
|
enabled <= [SampleDirectory, 'selected_sample.launchable']
|
255
255
|
|
256
|
-
on_widget_selected
|
256
|
+
on_widget_selected do
|
257
257
|
begin
|
258
258
|
SampleDirectory.selected_sample.launch(@code_text.text)
|
259
259
|
rescue LoadError, StandardError, SyntaxError => launch_error
|
260
260
|
error_dialog(message: launch_error.full_message).open
|
261
261
|
end
|
262
|
-
|
262
|
+
end
|
263
263
|
}
|
264
264
|
button {
|
265
265
|
text 'Reset'
|
266
266
|
font height: 25
|
267
267
|
enabled <= [SampleDirectory, 'selected_sample.editable']
|
268
268
|
|
269
|
-
on_widget_selected
|
269
|
+
on_widget_selected do
|
270
270
|
SampleDirectory.selected_sample.reset_code!
|
271
|
-
|
271
|
+
end
|
272
272
|
}
|
273
273
|
}
|
274
274
|
}
|
@@ -319,9 +319,9 @@ class MetaSampleApplication
|
|
319
319
|
button {
|
320
320
|
text 'Close'
|
321
321
|
|
322
|
-
on_widget_selected
|
322
|
+
on_widget_selected do
|
323
323
|
dialog_proxy.close
|
324
|
-
|
324
|
+
end
|
325
325
|
}
|
326
326
|
}
|
327
327
|
end
|
@@ -101,13 +101,13 @@ class Metronome
|
|
101
101
|
|
102
102
|
@beat_container = beat_container
|
103
103
|
|
104
|
-
on_swt_show
|
104
|
+
on_swt_show do
|
105
105
|
start_metronome
|
106
|
-
|
106
|
+
end
|
107
107
|
|
108
|
-
on_widget_disposed
|
108
|
+
on_widget_disposed do
|
109
109
|
stop_metronome
|
110
|
-
|
110
|
+
end
|
111
111
|
}
|
112
112
|
}
|
113
113
|
|
@@ -170,42 +170,42 @@ class StockTicker
|
|
170
170
|
}
|
171
171
|
end
|
172
172
|
|
173
|
-
on_mouse_down
|
173
|
+
on_mouse_down do
|
174
174
|
@drag_detected = false
|
175
|
-
|
175
|
+
end
|
176
176
|
|
177
|
-
on_drag_detected
|
177
|
+
on_drag_detected do |drag_detect_event|
|
178
178
|
@drag_detected = true
|
179
179
|
@drag_start_x = drag_detect_event.x
|
180
180
|
@drag_start_y = drag_detect_event.y
|
181
|
-
|
181
|
+
end
|
182
182
|
|
183
|
-
on_mouse_move
|
183
|
+
on_mouse_move do |mouse_event|
|
184
184
|
if @drag_detected
|
185
185
|
origin = tab[:scrolled_composite].origin
|
186
186
|
new_x = origin.x - (mouse_event.x - @drag_start_x)
|
187
187
|
new_y = origin.y - (mouse_event.y - @drag_start_y)
|
188
188
|
tab[:scrolled_composite].set_origin(new_x, new_y)
|
189
189
|
end
|
190
|
-
|
190
|
+
end
|
191
191
|
|
192
|
-
on_mouse_up
|
192
|
+
on_mouse_up do |mouse_event|
|
193
193
|
@drag_detected = false
|
194
|
-
|
194
|
+
end
|
195
195
|
}
|
196
196
|
}
|
197
197
|
}
|
198
198
|
end
|
199
199
|
}
|
200
200
|
|
201
|
-
on_swt_show
|
201
|
+
on_swt_show do
|
202
202
|
Stock.price_min = 25
|
203
203
|
Stock.price_max = @tabs.first[:canvas].bounds.height - 6
|
204
|
-
|
204
|
+
end
|
205
205
|
|
206
|
-
on_widget_disposed
|
206
|
+
on_widget_disposed do
|
207
207
|
@thread.kill # safe to kill as data is in memory only
|
208
|
-
|
208
|
+
end
|
209
209
|
}
|
210
210
|
}
|
211
211
|
end
|
data/samples/elaborate/tetris.rb
CHANGED
@@ -150,15 +150,15 @@ class Tetris
|
|
150
150
|
icon_size = 8
|
151
151
|
icon_pixel_size = icon_block_size * icon_size
|
152
152
|
image(icon_pixel_size, icon_pixel_size) {
|
153
|
-
icon_size.times
|
154
|
-
icon_size.times
|
153
|
+
icon_size.times do |row|
|
154
|
+
icon_size.times do |column|
|
155
155
|
colored = row >= 1 && column.between?(1, 6)
|
156
156
|
color = colored ? color(([:white] + Model::Tetromino::LETTER_COLORS.values).sample) : color(:white)
|
157
157
|
x = column * icon_block_size
|
158
158
|
y = row * icon_block_size
|
159
159
|
bevel(x: x, y: y, base_color: color, size: icon_block_size)
|
160
|
-
|
161
|
-
|
160
|
+
end
|
161
|
+
end
|
162
162
|
}
|
163
163
|
end
|
164
164
|
|
data/samples/elaborate/timer.rb
CHANGED
@@ -24,12 +24,13 @@ class Timer
|
|
24
24
|
Display.setAppName('Glimmer Timer')
|
25
25
|
|
26
26
|
@display = display {
|
27
|
-
on_about
|
27
|
+
on_about do
|
28
28
|
display_about_dialog
|
29
|
-
|
30
|
-
|
29
|
+
end
|
30
|
+
|
31
|
+
on_preferences do
|
31
32
|
display_about_dialog
|
32
|
-
|
33
|
+
end
|
33
34
|
}
|
34
35
|
|
35
36
|
@min = 0
|
@@ -43,7 +44,7 @@ class Timer
|
|
43
44
|
loop do
|
44
45
|
sleep(1)
|
45
46
|
if @countdown
|
46
|
-
sync_exec
|
47
|
+
sync_exec do
|
47
48
|
@countdown_time = Time.new(1, 1, 1, 0, min, sec)
|
48
49
|
@countdown_time -= 1
|
49
50
|
self.min = @countdown_time.min
|
@@ -52,7 +53,7 @@ class Timer
|
|
52
53
|
stop_countdown
|
53
54
|
play_countdown_done_sound
|
54
55
|
end
|
55
|
-
|
56
|
+
end
|
56
57
|
end
|
57
58
|
end
|
58
59
|
end
|
@@ -85,31 +86,34 @@ class Timer
|
|
85
86
|
accelerator COMMAND_KEY, 's'
|
86
87
|
enabled <= [self, :countdown, on_read: :!]
|
87
88
|
|
88
|
-
on_widget_selected
|
89
|
+
on_widget_selected do
|
89
90
|
start_countdown
|
90
|
-
|
91
|
+
end
|
91
92
|
}
|
93
|
+
|
92
94
|
menu_item {
|
93
95
|
text 'St&op'
|
94
96
|
enabled <= [self, :countdown]
|
95
97
|
accelerator COMMAND_KEY, 'o'
|
96
98
|
|
97
|
-
on_widget_selected
|
99
|
+
on_widget_selected do
|
98
100
|
stop_countdown
|
99
|
-
|
101
|
+
end
|
100
102
|
}
|
103
|
+
|
101
104
|
unless OS.mac?
|
102
105
|
menu_item(:separator)
|
103
106
|
menu_item {
|
104
107
|
text 'E&xit'
|
105
108
|
accelerator :alt, :f4
|
106
109
|
|
107
|
-
on_widget_selected
|
110
|
+
on_widget_selected do
|
108
111
|
exit(0)
|
109
|
-
|
112
|
+
end
|
110
113
|
}
|
111
114
|
end
|
112
115
|
}
|
116
|
+
|
113
117
|
menu {
|
114
118
|
text '&Help'
|
115
119
|
|
@@ -117,9 +121,9 @@ class Timer
|
|
117
121
|
text '&About'
|
118
122
|
accelerator COMMAND_KEY, :shift, 'a'
|
119
123
|
|
120
|
-
on_widget_selected
|
124
|
+
on_widget_selected do
|
121
125
|
display_about_dialog
|
122
|
-
|
126
|
+
end
|
123
127
|
}
|
124
128
|
}
|
125
129
|
}
|
@@ -149,9 +153,10 @@ class Timer
|
|
149
153
|
maximum 59
|
150
154
|
selection <=> [self, :min]
|
151
155
|
enabled <= [self, :countdown, on_read: :!]
|
152
|
-
|
156
|
+
|
157
|
+
on_widget_default_selected do
|
153
158
|
start_countdown
|
154
|
-
|
159
|
+
end
|
155
160
|
}
|
156
161
|
label {
|
157
162
|
text ':'
|
@@ -163,9 +168,10 @@ class Timer
|
|
163
168
|
maximum 59
|
164
169
|
selection <=> [self, :sec]
|
165
170
|
enabled <= [self, :countdown, on_read: :!]
|
166
|
-
|
171
|
+
|
172
|
+
on_widget_default_selected do
|
167
173
|
start_countdown
|
168
|
-
|
174
|
+
end
|
169
175
|
}
|
170
176
|
}
|
171
177
|
end
|
@@ -179,22 +185,26 @@ class Timer
|
|
179
185
|
@start_button = button {
|
180
186
|
text '&Start'
|
181
187
|
enabled <= [self, :countdown, on_read: :!]
|
182
|
-
|
188
|
+
|
189
|
+
on_widget_selected do
|
183
190
|
start_countdown
|
184
|
-
|
185
|
-
|
191
|
+
end
|
192
|
+
|
193
|
+
on_key_pressed do |event|
|
186
194
|
start_countdown if event.keyCode == swt(:cr)
|
187
|
-
|
195
|
+
end
|
188
196
|
}
|
189
197
|
@stop_button = button {
|
190
198
|
text 'St&op'
|
191
199
|
enabled <= [self, :countdown]
|
192
|
-
|
200
|
+
|
201
|
+
on_widget_selected do
|
193
202
|
stop_countdown
|
194
|
-
|
195
|
-
|
203
|
+
end
|
204
|
+
|
205
|
+
on_key_pressed do |event|
|
196
206
|
stop_countdown if event.keyCode == swt(:cr)
|
197
|
-
|
207
|
+
end
|
198
208
|
}
|
199
209
|
}
|
200
210
|
end
|
@@ -32,49 +32,88 @@ shell { |shell_proxy|
|
|
32
32
|
grid_layout 2, false
|
33
33
|
|
34
34
|
group {
|
35
|
-
text "Name"
|
36
35
|
grid_layout 2, false
|
36
|
+
|
37
37
|
layout_data :fill, :fill, true, true
|
38
|
-
|
39
|
-
|
38
|
+
text "Name"
|
39
|
+
|
40
|
+
label {
|
41
|
+
text "First"
|
42
|
+
}
|
43
|
+
text {
|
44
|
+
text "Bullet"
|
45
|
+
}
|
46
|
+
|
47
|
+
label {
|
48
|
+
text "Last"
|
49
|
+
}
|
50
|
+
text {
|
51
|
+
text "Tooth"
|
52
|
+
}
|
40
53
|
}
|
41
54
|
|
42
55
|
group {
|
43
56
|
layout_data :fill, :fill, true, true
|
44
57
|
text "Gender"
|
45
|
-
|
46
|
-
radio {
|
58
|
+
|
59
|
+
radio {
|
60
|
+
text "Male"
|
61
|
+
selection true
|
62
|
+
}
|
63
|
+
|
64
|
+
radio {
|
65
|
+
text "Female"
|
66
|
+
}
|
47
67
|
}
|
48
68
|
|
49
69
|
group {
|
50
70
|
layout_data :fill, :fill, true, true
|
51
71
|
text "Role"
|
52
|
-
|
53
|
-
check {
|
72
|
+
|
73
|
+
check {
|
74
|
+
text "Student"
|
75
|
+
selection true
|
76
|
+
}
|
77
|
+
|
78
|
+
check {
|
79
|
+
text "Employee"
|
80
|
+
selection true
|
81
|
+
}
|
54
82
|
}
|
55
83
|
|
56
84
|
group {
|
57
|
-
text "Experience"
|
58
85
|
row_layout
|
86
|
+
|
59
87
|
layout_data :fill, :fill, true, true
|
60
|
-
|
88
|
+
text "Experience"
|
89
|
+
|
90
|
+
spinner {
|
91
|
+
selection 5
|
92
|
+
}
|
93
|
+
label {
|
94
|
+
text "years"
|
95
|
+
}
|
61
96
|
}
|
62
97
|
|
63
98
|
button {
|
64
|
-
text "save"
|
65
99
|
layout_data :right, :center, true, true
|
66
|
-
|
100
|
+
text "save"
|
101
|
+
|
102
|
+
on_widget_selected do
|
67
103
|
message_box {
|
68
104
|
text 'Profile Saved!'
|
69
105
|
message 'User profile has been saved!'
|
70
106
|
}.open
|
71
|
-
|
107
|
+
end
|
72
108
|
}
|
73
109
|
|
74
110
|
button {
|
75
|
-
text "close"
|
76
111
|
layout_data :left, :center, true, true
|
77
|
-
|
112
|
+
text "close"
|
113
|
+
|
114
|
+
on_widget_selected do
|
115
|
+
shell_proxy.close
|
116
|
+
end
|
78
117
|
}
|
79
118
|
}
|
80
119
|
}.open
|
@@ -27,7 +27,7 @@ class HelloButton
|
|
27
27
|
attr_accessor :count
|
28
28
|
|
29
29
|
before_body do
|
30
|
-
|
30
|
+
self.count = 0
|
31
31
|
end
|
32
32
|
|
33
33
|
body {
|
@@ -37,9 +37,9 @@ class HelloButton
|
|
37
37
|
button {
|
38
38
|
text <= [self, :count, on_read: ->(value) { "Click To Increment: #{value} " }]
|
39
39
|
|
40
|
-
on_widget_selected
|
40
|
+
on_widget_selected do
|
41
41
|
self.count += 1
|
42
|
-
|
42
|
+
end
|
43
43
|
}
|
44
44
|
}
|
45
45
|
}
|
@@ -123,12 +123,12 @@ class HelloCanvasAnimation
|
|
123
123
|
started <=> [self, :animation_started]
|
124
124
|
finished <=> [self, :animation_finished]
|
125
125
|
|
126
|
-
frame
|
126
|
+
frame do |index|
|
127
127
|
background rgb(index%100, index%100 + 100, index%55 + 200)
|
128
128
|
oval(index*3%300, index*3%300, 20, 20) {
|
129
129
|
background :yellow
|
130
130
|
}
|
131
|
-
|
131
|
+
end
|
132
132
|
}
|
133
133
|
}
|
134
134
|
}
|
@@ -47,18 +47,18 @@ class HelloColorDialog
|
|
47
47
|
layout_data :center, :center, true, false
|
48
48
|
background <=> [self, :selected_color]
|
49
49
|
|
50
|
-
on_mouse_up
|
50
|
+
on_mouse_up do
|
51
51
|
self.selected_color = color_dialog.open
|
52
|
-
|
52
|
+
end
|
53
53
|
}
|
54
54
|
|
55
55
|
button {
|
56
56
|
layout_data :center, :center, true, false
|
57
57
|
text "Choose Color..."
|
58
58
|
|
59
|
-
on_widget_selected
|
59
|
+
on_widget_selected do
|
60
60
|
self.selected_color = color_dialog.open
|
61
|
-
|
61
|
+
end
|
62
62
|
}
|
63
63
|
|
64
64
|
}
|
@@ -140,7 +140,7 @@ class HelloCustomShell
|
|
140
140
|
|
141
141
|
items <=> [@email_system, :emails, column_properties: [:date, :subject, :from]]
|
142
142
|
|
143
|
-
on_mouse_up
|
143
|
+
on_mouse_up do |event|
|
144
144
|
email = event.table_item.get_data
|
145
145
|
|
146
146
|
# open a custom email shell
|
@@ -151,7 +151,7 @@ class HelloCustomShell
|
|
151
151
|
from: email.from,
|
152
152
|
message: email.message
|
153
153
|
).open
|
154
|
-
|
154
|
+
end
|
155
155
|
}
|
156
156
|
}.open
|
157
157
|
end
|
@@ -38,7 +38,7 @@ shell { |shell_proxy|
|
|
38
38
|
}
|
39
39
|
text "Dialog #{dialog_number}"
|
40
40
|
|
41
|
-
on_widget_selected
|
41
|
+
on_widget_selected do
|
42
42
|
# pass the shell proxy as a parent to make the dialog support hitting the escape button for closing alone without closing app
|
43
43
|
dialog(shell_proxy) { |dialog_proxy|
|
44
44
|
row_layout(:vertical) {
|
@@ -70,12 +70,12 @@ shell { |shell_proxy|
|
|
70
70
|
button {
|
71
71
|
text 'Close'
|
72
72
|
|
73
|
-
on_widget_selected
|
73
|
+
on_widget_selected do
|
74
74
|
dialog_proxy.close
|
75
|
-
|
75
|
+
end
|
76
76
|
}
|
77
77
|
}.open
|
78
|
-
|
78
|
+
end
|
79
79
|
}
|
80
80
|
}
|
81
81
|
}.open
|
@@ -96,14 +96,13 @@ class HelloExpandBar
|
|
96
96
|
composite # just filler
|
97
97
|
}
|
98
98
|
|
99
|
-
on_item_expanded
|
99
|
+
on_item_expanded do |expand_event|
|
100
100
|
@status_label.text = "#{expand_event.item.text} Expanded!"
|
101
|
-
|
101
|
+
end
|
102
102
|
|
103
|
-
on_item_collapsed
|
103
|
+
on_item_collapsed do |expand_event|
|
104
104
|
@status_label.text = "#{expand_event.item.text} Collapsed!"
|
105
|
-
|
106
|
-
|
105
|
+
end
|
107
106
|
}
|
108
107
|
}
|
109
108
|
}
|