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

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

Issue 2169313002: Converted Observatory vm-connect-target element (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: 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:async';
6 import 'dart:html';
7 import 'package:observatory/models.dart' as M show Target;
8 import 'package:observatory/src/elements/helpers/tag.dart';
9 import 'package:observatory/src/elements/helpers/rendering_scheduler.dart';
10
11 class TargetEvent {
12 final M.Target target;
13
14 TargetEvent(this.target);
15 }
16
17 class VMConnectTargetElement extends HtmlElement implements Renderable{
18
19 static const tag =
20 const Tag<VMConnectTargetElement>('vm-connect-target-wrapped');
21
22 RenderingScheduler<VMConnectTargetElement> _r;
23
24 Stream<RenderedEvent<VMConnectTargetElement>> get onRendered => _r.onRendered;
25
26 final StreamController<TargetEvent> _onConnect =
27 new StreamController<TargetEvent>.broadcast();
28 Stream<TargetEvent> get onConnect => _onConnect.stream;
29 final StreamController<TargetEvent> _onDelete =
30 new StreamController<TargetEvent>.broadcast();
31 Stream<TargetEvent> get onDelete => _onDelete.stream;
32
33 M.Target _target;
34 bool _current;
35
36 M.Target get target => _target;
37 bool get current => _current;
38
39 factory VMConnectTargetElement(M.Target target, {bool current: false,
40 RenderingQueue queue}) {
41 assert(target != null);
42 assert(current != null);
43 VMConnectTargetElement e = document.createElement(tag.name);
44 e._r = new RenderingScheduler(e, queue: queue);
45 e._target = target;
46 e._current = current;
47 return e;
48 }
49
50 VMConnectTargetElement.created() : super.created();
51
52 @override
53 void attached() {
54 super.attached();
55 _r.enable();
56 }
57
58 @override
59 void detached() {
60 super.detached();
61 children = [];
62 _r.disable(notify: true);
63 }
64
65 void connect() {
66 _connect(new TargetEvent(target));
67 }
68
69 void delete() {
70 _delete(new TargetEvent(target));
71 }
72
73 void render() {
74 children = [
75 new AnchorElement(href: '#/vm')
76 ..text = current ? '${target.name} (Connected)' : '${target.name}'
77 ..onClick.where(_filter).map(_toEvent).listen(_connect),
78 new ButtonElement()
79 ..text = '✖ Remove' ..classes = ['delete-button']
80 ..onClick.map(_toEvent).listen(_delete)
81 ];
82 }
83
84 void _connect(TargetEvent e) {
85 _onConnect.add(e);
86 }
87
88 void _delete(TargetEvent e) {
89 _onDelete.add(e);
90 }
91
92 TargetEvent _toEvent(_) {
93 return new TargetEvent(target);
94 }
95
96 static bool _filter(MouseEvent event) {
97 return !(event.button > 0 || event.metaKey || event.ctrlKey ||
98 event.shiftKey || event.altKey);
99 }
100 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698