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

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: Fixed CSS leak on firefox 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 'helpers/tag.dart';
9
10 class WebSocketVMTargetEvent {
11 final WebSocketVMTarget target;
12
13 WebSocketVMTargetEvent(this.target);
14 }
15
16 class VmConnectTargetElement extends HtmlElement {
17 static final StyleElement _style = () {
18 var style = new StyleElement();
19 style.text = '.delete-button {'
20 ' padding: 4px;'
21 ' background: transparent;'
22 ' border: none !important;'
23 '}'
24 '.delete-button:hover {'
25 ' background: #ff0000;'
26 '}';
27 return style;
28 }();
29
30 static const tag =
31 const Tag<VmConnectTargetElement>('vm-connect-target-wrapped');
32
33 final StreamController<WebSocketVMTargetEvent> _onConnect =
34 new StreamController<WebSocketVMTargetEvent>();
35 Stream<WebSocketVMTargetEvent> get onConnect => _onConnect.stream;
36 final StreamController<WebSocketVMTargetEvent> _onDelete =
37 new StreamController<WebSocketVMTargetEvent>();
38 Stream<WebSocketVMTargetEvent> get onDelete => _onDelete.stream;
39
40 WebSocketVMTarget _target;
41 bool _current;
42
43 WebSocketVMTarget get target => _target;
44 bool get current => _current;
45
46 factory VmConnectTargetElement(WebSocketVMTarget target,
47 {bool current: false}) {
48 assert(target != null);
49 assert(current is bool);
50 VmConnectTargetElement e = document.createElement(tag.name);
51 e._target = target;
52 e._current = current;
53 return e;
54 }
55
56 VmConnectTargetElement.created() : super.created() {
57 createShadowRoot();
58 }
59
60 @override
61 void attached() {
62 super.attached();
63 assert(target != null);
64 render();
65 }
66
67 void connect() {
68 _connect(new WebSocketVMTargetEvent(target));
69 }
70
71 void delete() {
72 _delete(new WebSocketVMTargetEvent(target));
73 }
74
75 void render() {
76 shadowRoot.children = [
77 _style.clone(true),
78 new AnchorElement(href: '#/vm')
79 ..text = current ? '${target.name} (Connected)' : '${target.name}'
80 ..onClick.where(_filter).map(_toEvent).listen(_connect),
81 new ButtonElement()
82 ..text = '✖ Remove' ..classes = ['delete-button']
83 ..onClick.map(_toEvent).listen(_delete)
84 ];
85 }
86
87 void _connect(WebSocketVMTargetEvent e) {
88 if (_onConnect.hasListener) {
89 _onConnect.add(e);
90 }
91 }
92
93 void _delete(WebSocketVMTargetEvent e) {
94 if (_onDelete.hasListener) {
95 _onDelete.add(e);
96 }
97 }
98
99 WebSocketVMTargetEvent _toEvent(_) {
100 return new WebSocketVMTargetEvent(target);
101 }
102
103 static bool _filter(MouseEvent event) {
104 return !(event.button > 0 || event.metaKey || event.ctrlKey ||
105 event.shiftKey || event.altKey);
106 }
107 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698