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

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

Issue 2119733003: Wrapping leaf nodes in non polymer elements (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Converted error-ref tag 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/service_html.dart';
8 import 'package:observatory/src/elements/helpers/tag.dart';
9
10 class WebSocketVMTargetEvent {
11 final WebSocketVMTarget target;
12
13 WebSocketVMTargetEvent(this.target);
14 }
15
16 class VmConnectTargetElement extends HtmlElement {
17
18 static const tag =
19 const Tag<VmConnectTargetElement>('vm-connect-target-wrapped');
20
21 final StreamController<WebSocketVMTargetEvent> _onConnect =
22 new StreamController<WebSocketVMTargetEvent>();
23 Stream<WebSocketVMTargetEvent> get onConnect => _onConnect.stream;
24 final StreamController<WebSocketVMTargetEvent> _onDelete =
25 new StreamController<WebSocketVMTargetEvent>();
26 Stream<WebSocketVMTargetEvent> get onDelete => _onDelete.stream;
27
28 WebSocketVMTarget _target;
29 bool _current;
30
31 WebSocketVMTarget get target => _target;
32 bool get current => _current;
33
34 factory VmConnectTargetElement(WebSocketVMTarget target,
35 {bool current: false}) {
36 assert(target != null);
37 assert(current is bool);
38 VmConnectTargetElement e = document.createElement(tag.name);
39 e._target = target;
40 e._current = current;
41 return e;
42 }
43
44 VmConnectTargetElement.created() : super.created();
45
46 @override
47 void attached() {
48 super.attached();
49 assert(target != null);
50 render();
51 }
52
53 void connect() {
54 _connect(new WebSocketVMTargetEvent(target));
55 }
56
57 void delete() {
58 _delete(new WebSocketVMTargetEvent(target));
59 }
60
61 void render() {
62 children = [
63 new AnchorElement(href: '#/vm')
64 ..text = current ? '${target.name} (Connected)' : '${target.name}'
65 ..onClick.where(_filter).map(_toEvent).listen(_connect),
66 new ButtonElement()
67 ..text = '✖ Remove' ..classes = ['delete-button']
68 ..onClick.map(_toEvent).listen(_delete)
69 ];
70 }
71
72 void _connect(WebSocketVMTargetEvent e) {
73 if (_onConnect.hasListener) {
74 _onConnect.add(e);
75 }
76 }
77
78 void _delete(WebSocketVMTargetEvent e) {
79 if (_onDelete.hasListener) {
80 _onDelete.add(e);
81 }
82 }
83
84 WebSocketVMTargetEvent _toEvent(_) {
85 return new WebSocketVMTargetEvent(target);
86 }
87
88 static bool _filter(MouseEvent event) {
89 return !(event.button > 0 || event.metaKey || event.ctrlKey ||
90 event.shiftKey || event.altKey);
91 }
92 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698