| 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 |