OLD | NEW |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 library isolate_reconnect_element; | 5 library isolate_reconnect_element; |
6 | 6 |
7 import 'dart:html'; | 7 import 'dart:html'; |
8 import 'dart:async'; | 8 import 'dart:async'; |
9 import 'package:observatory/models.dart' as M; | 9 import 'package:observatory/models.dart' as M; |
10 import 'package:observatory/src/elements/helpers/nav_bar.dart'; | 10 import 'package:observatory/src/elements/helpers/nav_bar.dart'; |
11 import 'package:observatory/src/elements/helpers/rendering_scheduler.dart'; | 11 import 'package:observatory/src/elements/helpers/rendering_scheduler.dart'; |
12 import 'package:observatory/src/elements/helpers/tag.dart'; | 12 import 'package:observatory/src/elements/helpers/tag.dart'; |
13 import 'package:observatory/src/elements/helpers/uris.dart'; | 13 import 'package:observatory/src/elements/helpers/uris.dart'; |
14 import 'package:observatory/src/elements/nav/notify.dart'; | 14 import 'package:observatory/src/elements/nav/notify.dart'; |
15 import 'package:observatory/src/elements/nav/top_menu.dart'; | 15 import 'package:observatory/src/elements/nav/top_menu.dart'; |
16 import 'package:observatory/src/elements/view_footer.dart'; | 16 import 'package:observatory/src/elements/view_footer.dart'; |
17 | 17 |
18 class IsolateReconnectElement extends HtmlElement implements Renderable{ | 18 class IsolateReconnectElement extends HtmlElement implements Renderable { |
19 static const tag = const Tag<IsolateReconnectElement>('isolate-reconnect', | 19 static const tag = const Tag<IsolateReconnectElement>('isolate-reconnect', |
20 dependencies: const [NavTopMenuElement.tag, | 20 dependencies: const [ |
21 NavNotifyElement.tag, | 21 NavTopMenuElement.tag, |
22 ViewFooterElement.tag]); | 22 NavNotifyElement.tag, |
| 23 ViewFooterElement.tag |
| 24 ]); |
23 | 25 |
24 RenderingScheduler _r; | 26 RenderingScheduler _r; |
25 | 27 |
26 Stream<RenderedEvent<IsolateReconnectElement>> get onRendered => | 28 Stream<RenderedEvent<IsolateReconnectElement>> get onRendered => |
27 _r.onRendered; | 29 _r.onRendered; |
28 | 30 |
29 M.VM _vm; | 31 M.VM _vm; |
30 String _missing; | 32 String _missing; |
31 Uri _uri; | 33 Uri _uri; |
32 M.EventRepository _events; | 34 M.EventRepository _events; |
33 StreamSubscription _subscription; | 35 StreamSubscription _subscription; |
34 | 36 |
35 M.VM get vm => _vm; | 37 M.VM get vm => _vm; |
36 String get missing => _missing; | 38 String get missing => _missing; |
37 Uri get uri => _uri; | 39 Uri get uri => _uri; |
38 | 40 |
39 M.NotificationRepository _notifications; | 41 M.NotificationRepository _notifications; |
40 factory IsolateReconnectElement(M.VM vm, M.EventRepository events, | 42 factory IsolateReconnectElement(M.VM vm, M.EventRepository events, |
41 M.NotificationRepository notifications, String missing, Uri uri, | 43 M.NotificationRepository notifications, String missing, Uri uri, |
42 {RenderingQueue queue}) { | 44 {RenderingQueue queue}) { |
43 assert(vm != null); | 45 assert(vm != null); |
44 assert(events != null); | 46 assert(events != null); |
45 assert(missing != null); | 47 assert(missing != null); |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
78 void render() { | 80 void render() { |
79 children = [ | 81 children = [ |
80 navBar([ | 82 navBar([ |
81 new NavTopMenuElement(queue: _r.queue), | 83 new NavTopMenuElement(queue: _r.queue), |
82 new NavNotifyElement(_notifications, queue: _r.queue) | 84 new NavNotifyElement(_notifications, queue: _r.queue) |
83 ]), | 85 ]), |
84 new DivElement() | 86 new DivElement() |
85 ..classes = ['content-centered'] | 87 ..classes = ['content-centered'] |
86 ..children = [ | 88 ..children = [ |
87 new HeadingElement.h1()..text = 'Isolate $_missing no longer exists', | 89 new HeadingElement.h1()..text = 'Isolate $_missing no longer exists', |
88 new BRElement(), new HRElement(), | 90 new BRElement(), |
89 new DivElement()..classes = ['memberList'] | 91 new HRElement(), |
| 92 new DivElement() |
| 93 ..classes = ['memberList'] |
90 ..children = (_vm.isolates.map((isolate) { | 94 ..children = (_vm.isolates.map((isolate) { |
91 final query = new Map.from(_uri.queryParameters); | 95 final query = new Map.from(_uri.queryParameters); |
92 query['isolateId'] = isolate.id; | 96 query['isolateId'] = isolate.id; |
93 final href = new Uri(path: _uri.path, queryParameters: query); | 97 final href = new Uri(path: _uri.path, queryParameters: query); |
94 return new DivElement()..classes = ['memberItem', 'doubleSpaced'] | 98 return new DivElement() |
| 99 ..classes = ['memberItem', 'doubleSpaced'] |
95 ..children = [ | 100 ..children = [ |
96 new SpanElement()..text = 'Continue in ', | 101 new SpanElement()..text = 'Continue in ', |
97 new AnchorElement(href: '#$href')..classes = ['isolate-link'] | 102 new AnchorElement(href: '#$href') |
| 103 ..classes = ['isolate-link'] |
98 ..text = '${isolate.id} (${isolate.name})' | 104 ..text = '${isolate.id} (${isolate.name})' |
99 ]; | 105 ]; |
100 }).toList()..add( | 106 }).toList() |
101 new DivElement()..classes = ['memberItem', 'doubleSpaced'] | 107 ..add(new DivElement() |
| 108 ..classes = ['memberItem', 'doubleSpaced'] |
102 ..children = [ | 109 ..children = [ |
103 new SpanElement()..text = 'Go to ', | 110 new SpanElement()..text = 'Go to ', |
104 new AnchorElement(href: Uris.vm()) | 111 new AnchorElement(href: Uris.vm())..text = 'isolates summary', |
105 ..text = 'isolates summary', | 112 ])) |
106 ] | |
107 )) | |
108 ], | 113 ], |
109 new ViewFooterElement(queue: _r.queue) | 114 new ViewFooterElement(queue: _r.queue) |
110 ]; | 115 ]; |
111 } | 116 } |
112 } | 117 } |
OLD | NEW |