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

Unified Diff: sky/framework/sky-button/sky-button.sky

Issue 809233002: Add super-basic sky widgets. (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: fix typos Created 6 years 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « sky/framework/sky-box/sky-box.sky ('k') | sky/framework/sky-checkbox/sky-checkbox.sky » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sky/framework/sky-button/sky-button.sky
diff --git a/sky/framework/sky-button/sky-button.sky b/sky/framework/sky-button/sky-button.sky
new file mode 100644
index 0000000000000000000000000000000000000000..2c747b4c8a40b10e87a1212652d41c8ea6d15701
--- /dev/null
+++ b/sky/framework/sky-button/sky-button.sky
@@ -0,0 +1,49 @@
+<!--
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+-->
+<import src="/sky/framework/sky-element/sky-element.sky" as="SkyElement" />
+
+<sky-element name="sky-button">
+<template>
+ <style>
+ :host {
+ display: inline-flex;
+ border-radius: 4px;
+ justify-content: center;
+ align-items: center;
+ border: 1px solid blue;
+ -webkit-user-select: none;
+ margin: 5px;
+ }
+ :host([highlight=true]) {
+ background-color: orange;
+ }
+ </style>
+ <content></content>
+</template>
+<script>
+module.exports = class extends SkyElement {
+ created() {
+ this.tabIndex = 0; // Make focusable.
+ this.setHighlight(false);
+
+ this.addEventListener("mousedown", function() {
+ this.setHighlight(true);
+ });
+ this.addEventListener("mouseup", function() {
+ this.setHighlight(false);
+ });
+ this.addEventListener("mouseout", function() {
+ this.setHighlight(false);
+ });
+ }
+ setHighlight(newValue) {
+ // Set both a property and an attribute to keep both parents happy.
+ this.setAttribute('highlight', newValue);
+ this.highlight = newValue;
+ }
+}.register();
+</script>
+</sky-element>
« no previous file with comments | « sky/framework/sky-box/sky-box.sky ('k') | sky/framework/sky-checkbox/sky-checkbox.sky » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698