Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(109)

Side by Side Diff: runtime/observatory/lib/src/elements/nav/isolate_menu.dart

Issue 2168463004: Converted Observatory isolate-nav-menu element (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Added sources to observatory_sources.gypi Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file
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.
4
5 import 'dart:html';
6 import 'dart:async';
7 import 'package:observatory/models.dart' as M
8 show IsolateRef, IsolateUpdateEvent;
9 import 'package:observatory/src/elements/helpers/tag.dart';
10 import 'package:observatory/src/elements/helpers/rendering_scheduler.dart';
11 import 'package:observatory/src/elements/nav/menu.dart';
12 import 'package:observatory/src/elements/nav/menu_item.dart';
13
14 class NavIsolateMenuElement extends HtmlElement implements Renderable {
15 static const tag = const Tag<NavIsolateMenuElement>('nav-isolate-menu',
16 dependencies: const [NavMenuElement.tag,
17 NavMenuItemElement.tag]);
18
19 RenderingScheduler _r;
20
21 Stream<RenderedEvent<NavIsolateMenuElement>> get onRendered => _r.onRendered;
22
23 Stream<M.IsolateUpdateEvent> _updates;
24 StreamSubscription _updatesSubscription;
25
26 bool _last;
27 M.IsolateRef _isolate;
28 bool get last => _last;
29 M.IsolateRef get isolate => _isolate;
30 set last(bool value) {
31 if (_last != value) {
32 _last = value;
Cutch 2016/07/20 13:55:25 this block of code for setting a bool (and marking
cbernaschina 2016/07/20 20:01:42 Done.
33 _r.dirty();
34 } else {
35 _r.scheduleNotification();
36 }
37 }
38
39 factory NavIsolateMenuElement(M.IsolateRef isolate,
40 Stream<M.IsolateUpdateEvent> updates, {bool last: false,
Cutch 2016/07/20 13:55:25 indentation is wrong here
cbernaschina 2016/07/20 20:01:42 Done.
41 RenderingQueue queue}) {
42 assert(isolate != null);
43 assert(last != null);
44 NavIsolateMenuElement e = document.createElement(tag.name);
45 e._r = new RenderingScheduler(e, queue: queue);
46 e._isolate = isolate;
47 e._last = last;
48 e._updates = updates;
49 return e;
50 }
51
52 NavIsolateMenuElement.created() : super.created() {
53 _r = new RenderingScheduler(this);
54 createShadowRoot();
55 }
56
57 @override
58 void attached() {
59 super.attached();
60 assert(_isolate != null);
61 assert(_updates != null);
62 _r.enable();
63 _updatesSubscription = _updates
64 .where((M.IsolateUpdateEvent e) => e.isolate.id == isolate.id)
65 .listen((M.IsolateUpdateEvent e) { _isolate = e.isolate; _r.dirty(); });
66 }
67
68 @override
69 void detached() {
70 super.detached();
71 _r.disable(notify: true);
72 shadowRoot.children = [];
73 assert(_updatesSubscription != null);
74 _updatesSubscription.cancel();
75 _updatesSubscription = null;
76 }
77
78 void render() {
79 var url_tail = '?isolateId=${Uri.encodeComponent(isolate.id)}';
Cutch 2016/07/20 13:55:25 Consider using the Uri class to build your uris.
cbernaschina 2016/07/20 20:01:42 Done.
80 shadowRoot.children = [
81 new NavMenuElement(isolate.name, last: last, queue: _r.queue,
82 link: '/inspect$url_tail')
83 ..children = [
84 new NavMenuItemElement('debugger', queue: _r.queue,
85 link: '/debugger$url_tail'),
Cutch 2016/07/20 13:55:25 Use the Uri class instead of hand written concaten
cbernaschina 2016/07/20 20:01:42 Done.
86 new NavMenuItemElement('class hierarchy', queue: _r.queue,
87 link: '/class-tree$url_tail'),
88 new NavMenuItemElement('cpu profile', queue: _r.queue,
89 link: '/profiler$url_tail'),
90 new NavMenuItemElement('cpu profile (table)', queue: _r.queue,
91 link: '/profiler-table$url_tail'),
92 new NavMenuItemElement('allocation profile', queue: _r.queue,
93 link: '/allocation-profiler$url_tail'),
94 new NavMenuItemElement('heap map', queue: _r.queue,
95 link: '/heap-map$url_tail'),
96 new NavMenuItemElement('metrics', queue: _r.queue,
97 link: '/metrics$url_tail'),
98 new NavMenuItemElement('heap snapshot', queue: _r.queue,
99 link: '/heap-snapshot$url_tail'),
100 new NavMenuItemElement('persistent handles', queue: _r.queue,
101 link: '/persistent-handles$url_tail'),
102 new NavMenuItemElement('ports', queue: _r.queue,
103 link: '/ports$url_tail'),
104 new NavMenuItemElement('logging', queue: _r.queue,
105 link: '/logging$url_tail'),
106 new ContentElement()
107 ]
108 ];
109 }
110 }
OLDNEW
« no previous file with comments | « runtime/observatory/lib/service.dart ('k') | runtime/observatory/lib/src/elements/nav/isolate_menu_wrapper.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698