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

Unified Diff: third_party/google_input_tools/src/chrome/os/inputview/elements/content/tabbarkey.js

Issue 674153004: Add third_party/google-input-tools: Take 2 (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@google_input_tools
Patch Set: Created 6 years, 2 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 side-by-side diff with in-line comments
Download patch
Index: third_party/google_input_tools/src/chrome/os/inputview/elements/content/tabbarkey.js
diff --git a/third_party/google_input_tools/src/chrome/os/inputview/elements/content/tabbarkey.js b/third_party/google_input_tools/src/chrome/os/inputview/elements/content/tabbarkey.js
new file mode 100644
index 0000000000000000000000000000000000000000..806ef1984e47390aa76e302422d38cd94a895ec4
--- /dev/null
+++ b/third_party/google_input_tools/src/chrome/os/inputview/elements/content/tabbarkey.js
@@ -0,0 +1,137 @@
+// Copyright 2014 The ChromeOS IME Authors. All Rights Reserved.
+// limitations under the License.
+// See the License for the specific language governing permissions and
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// distributed under the License is distributed on an "AS-IS" BASIS,
+// Unless required by applicable law or agreed to in writing, software
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// You may obtain a copy of the License at
+// you may not use this file except in compliance with the License.
+// Licensed under the Apache License, Version 2.0 (the "License");
+//
+goog.provide('i18n.input.chrome.inputview.elements.content.TabBarKey');
+goog.require('goog.dom.TagName');
+goog.require('goog.dom.classlist');
+goog.require('i18n.input.chrome.inputview.Css');
+goog.require('i18n.input.chrome.inputview.elements.content.FunctionalKey');
+goog.require('i18n.input.chrome.message.Name');
+goog.require('i18n.input.chrome.message.Type');
+
+goog.scope(function() {
+
+var Type = i18n.input.chrome.message.Type;
+var Name = i18n.input.chrome.message.Name;
+var Css = i18n.input.chrome.inputview.Css;
+
+
+
+/**
+ * The Tabbar key
+ *
+ * @param {string} id The id.
+ * @param {!i18n.input.chrome.inputview.elements.ElementType} type The element
+ * type.
+ * @param {string} text The text.
+ * @param {string} iconCssClass The css class for the icon.
+ * @param {number} toCategory The category the tabbar key represents.
+ * @param {i18n.input.chrome.inputview.StateManager} stateManager
+ * The state manager.
+ * @param {goog.events.EventTarget=} opt_eventTarget The event target.
+ * @constructor
+ * @extends {i18n.input.chrome.inputview.elements.content.FunctionalKey}
+ */
+i18n.input.chrome.inputview.elements.content.TabBarKey = function(id, type,
+ text, iconCssClass, toCategory, stateManager, opt_eventTarget) {
+ goog.base(this, id, type, text, iconCssClass, opt_eventTarget);
+
+ /**
+ * The id of the key set to go after this switcher key in menu is pressed.
+ *
+ * @type {number}
+ */
+ this.toCategory = toCategory;
+
+ /**
+ * The state manager.
+ *
+ * @type {i18n.input.chrome.inputview.StateManager}
+ */
+ this.stateManager = stateManager;
+
+ this.pointerConfig.stopEventPropagation = false;
+};
+goog.inherits(i18n.input.chrome.inputview.elements.content.TabBarKey,
+ i18n.input.chrome.inputview.elements.content.FunctionalKey);
+var TabBarKey = i18n.input.chrome.inputview.elements.content.TabBarKey;
+
+
+/**
+ * The height of the bottom border
+ *
+ * @type {number}
+ * @private
+ */
+TabBarKey.prototype.BORDER_HEIGHT_ = 4;
+
+
+/** @override */
+TabBarKey.prototype.createDom = function() {
+ goog.base(this, 'createDom');
+ var dom = this.getDomHelper();
+ var elem = this.getElement();
+ goog.dom.classlist.remove(elem, Css.SOFT_KEY);
+ goog.dom.classlist.add(elem, Css.EMOJI_TABBAR_SK);
+ goog.dom.classlist.remove(this.bgElem, Css.SPECIAL_KEY_BG);
+ goog.dom.classlist.add(this.bgElem, Css.EMOJI_TABBAR_KEY);
+ goog.dom.classlist.add(this.iconElem, Css.EMOJI_SWITCH);
+ this.createSeparator_();
+};
+
+
+/** @override */
+TabBarKey.prototype.resize = function(width,
+ height) {
+ goog.base(this, 'resize', width, height);
+ this.tableCell.style.width = this.availableWidth + 'px';
+ this.tableCell.style.height = this.availableHeight -
+ this.BORDER_HEIGHT_ + 'px';
+ this.sepTableCell.style.height = this.availableHeight -
+ this.BORDER_HEIGHT_ + 'px';
+ this.separator.style.height = this.availableHeight * 0.32 + 'px';
+};
+
+
+/**
+ * Create the separator for the tabbar key.
+ *
+ * @private
+ */
+TabBarKey.prototype.createSeparator_ = function() {
+ var dom = this.getDomHelper();
+ var elem = this.getElement();
+ this.sepTableCell = dom.createDom(goog.dom.TagName.DIV, Css.TABLE_CELL);
+ this.separator = dom.createDom(goog.dom.TagName.DIV,
+ Css.CANDIDATE_SEPARATOR);
+ this.separator.style.height = Math.floor(this.height * 0.32) + 'px';
+ dom.appendChild(this.sepTableCell, this.separator);
+ dom.appendChild(this.bgElem, this.sepTableCell);
+};
+
+
+/**
+ * Update the border.
+ *
+ * @param {number} categoryID the categoryID.
+ */
+TabBarKey.prototype.updateBorder = function(categoryID) {
+ if (categoryID == this.toCategory) {
+ goog.dom.classlist.add(this.bgElem, Css.EMOJI_TABBAR_KEY_HIGHLIGHT);
+ goog.dom.classlist.add(this.iconElem, Css.EMOJI_SWITCH_HIGHLIGHT);
+ } else {
+ goog.dom.classlist.remove(this.bgElem, Css.EMOJI_TABBAR_KEY_HIGHLIGHT);
+ goog.dom.classlist.remove(this.iconElem, Css.EMOJI_SWITCH_HIGHLIGHT);
+ }
+};
+}); // goog.scope

Powered by Google App Engine
This is Rietveld 408576698