blob: f2de56d76a7e7b236bdf4d2a0b8e64d345f77161 [file] [log] [blame]
// Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
import 'dart:html';
import 'dart:async';
import 'package:observatory_2/models.dart' as M show IsolateRef, EventRepository;
import 'package:observatory_2/src/elements/helpers/nav_menu.dart';
import 'package:observatory_2/src/elements/helpers/rendering_scheduler.dart';
import 'package:observatory_2/src/elements/helpers/custom_element.dart';
import 'package:observatory_2/src/elements/helpers/uris.dart';
import 'package:observatory_2/src/elements/nav/menu_item.dart';
class NavIsolateMenuElement extends CustomElement implements Renderable {
RenderingScheduler<NavIsolateMenuElement> _r;
Stream<RenderedEvent<NavIsolateMenuElement>> get onRendered => _r.onRendered;
M.IsolateRef _isolate;
M.EventRepository _events;
StreamSubscription _updatesSubscription;
Iterable<Element> _content = const [];
M.IsolateRef get isolate => _isolate;
Iterable<Element> get content => _content;
set content(Iterable<Element> value) {
_content = value.toList();
_r.dirty();
}
factory NavIsolateMenuElement(M.IsolateRef isolate, M.EventRepository events,
{RenderingQueue queue}) {
assert(isolate != null);
assert(events != null);
NavIsolateMenuElement e = new NavIsolateMenuElement.created();
e._r = new RenderingScheduler<NavIsolateMenuElement>(e, queue: queue);
e._isolate = isolate;
e._events = events;
return e;
}
NavIsolateMenuElement.created() : super.created('nav-isolate-menu');
@override
void attached() {
super.attached();
_updatesSubscription = _events.onIsolateUpdate
.where((e) => e.isolate.id == isolate.id)
.listen((e) {
_isolate = e.isolate;
_r.dirty();
});
_r.enable();
}
@override
void detached() {
super.detached();
children = <Element>[];
_r.disable(notify: true);
assert(_updatesSubscription != null);
_updatesSubscription.cancel();
_updatesSubscription = null;
}
void render() {
final content = <Element>[
new NavMenuItemElement('debugger',
queue: _r.queue, link: Uris.debugger(isolate))
.element,
new NavMenuItemElement('class hierarchy',
queue: _r.queue, link: Uris.classTree(isolate))
.element,
new NavMenuItemElement('cpu profile',
queue: _r.queue, link: Uris.cpuProfiler(isolate))
.element,
new NavMenuItemElement('cpu profile (table)',
queue: _r.queue, link: Uris.cpuProfilerTable(isolate))
.element,
new NavMenuItemElement('allocation profile',
queue: _r.queue, link: Uris.allocationProfiler(isolate))
.element,
new NavMenuItemElement('heap snapshot',
queue: _r.queue, link: Uris.heapSnapshot(isolate))
.element,
new NavMenuItemElement('heap map',
queue: _r.queue, link: Uris.heapMap(isolate))
.element,
new NavMenuItemElement('metrics',
queue: _r.queue, link: Uris.metrics(isolate))
.element,
new NavMenuItemElement('persistent handles',
queue: _r.queue, link: Uris.persistentHandles(isolate))
.element,
new NavMenuItemElement('ports',
queue: _r.queue, link: Uris.ports(isolate))
.element,
new NavMenuItemElement('logging',
queue: _r.queue, link: Uris.logging(isolate))
.element,
]..addAll(_content);
children = <Element>[
navMenu(isolate.name, content: content, link: Uris.inspect(isolate))
];
}
}