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

Side by Side Diff: sky/framework/sky-button/sky-button.sky

Issue 845283003: Allow on-* event handlers on <sky-element>. (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: s p a c i n g Created 5 years, 11 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
« no previous file with comments | « no previous file | sky/framework/sky-checkbox/sky-checkbox.sky » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 <!-- 1 <!--
2 // Copyright 2014 The Chromium Authors. All rights reserved. 2 // Copyright 2014 The Chromium Authors. All rights reserved.
3 // Use of this source code is governed by a BSD-style license that can be 3 // Use of this source code is governed by a BSD-style license that can be
4 // found in the LICENSE file. 4 // found in the LICENSE file.
5 --> 5 -->
6 <import src="/sky/framework/sky-element/sky-element.sky" as="SkyElement" /> 6 <import src="/sky/framework/sky-element/sky-element.sky" as="SkyElement" />
7 7
8 <sky-element name="sky-button" attributes="highlight:boolean"> 8 <sky-element
9 name="sky-button"
10 attributes="highlight:boolean"
11 on-mousedown="handleMouseDown"
12 on-mouseup="handleMouseUp"
13 on-mouseout="handleMouseOut">
9 <template> 14 <template>
10 <style> 15 <style>
11 :host { 16 :host {
12 display: inline-flex; 17 display: inline-flex;
13 border-radius: 4px; 18 border-radius: 4px;
14 justify-content: center; 19 justify-content: center;
15 align-items: center; 20 align-items: center;
16 border: 1px solid blue; 21 border: 1px solid blue;
17 -webkit-user-select: none; 22 -webkit-user-select: none;
18 margin: 5px; 23 margin: 5px;
19 } 24 }
20 :host([highlight=true]) { 25 :host([highlight=true]) {
21 background-color: orange; 26 background-color: orange;
22 } 27 }
23 </style> 28 </style>
24 <content /> 29 <content />
25 </template> 30 </template>
26 <script> 31 <script>
27 module.exports = class extends SkyElement { 32 module.exports = class extends SkyElement {
28 created() { 33 created() {
34 super.created();
35
29 this.tabIndex = 0; // Make focusable. 36 this.tabIndex = 0; // Make focusable.
30 37 }
31 this.addEventListener('mousedown', function() { 38 handleMouseDown() {
32 this.highlight = true; 39 this.highlight = true;
33 }); 40 }
34 this.addEventListener('mouseup', function() { 41 handleMouseUp() {
35 this.highlight = false; 42 this.highlight = false;
36 }); 43 }
37 this.addEventListener('mouseout', function() { 44 handleMouseOut() {
38 this.highlight = false; 45 this.highlight = false;
39 });
40 } 46 }
41 }.register(); 47 }.register();
42 </script> 48 </script>
43 </sky-element> 49 </sky-element>
OLDNEW
« no previous file with comments | « no previous file | sky/framework/sky-checkbox/sky-checkbox.sky » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698