Index: third_party/google_input_tools/src/chrome/os/inputview/elements/content/altdataview.js |
diff --git a/third_party/google_input_tools/src/chrome/os/inputview/elements/content/altdataview.js b/third_party/google_input_tools/src/chrome/os/inputview/elements/content/altdataview.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..3dd9499b43b4afe042c40f388452baaedef5ce48 |
--- /dev/null |
+++ b/third_party/google_input_tools/src/chrome/os/inputview/elements/content/altdataview.js |
@@ -0,0 +1,340 @@ |
+// 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.AltDataView'); |
+ |
+goog.require('goog.array'); |
+goog.require('goog.dom'); |
+goog.require('goog.dom.TagName'); |
+goog.require('goog.dom.classlist'); |
+goog.require('goog.style'); |
+goog.require('i18n.input.chrome.inputview.Css'); |
+goog.require('i18n.input.chrome.inputview.elements.Element'); |
+goog.require('i18n.input.chrome.inputview.elements.ElementType'); |
+goog.require('i18n.input.chrome.inputview.util'); |
+ |
+ |
+ |
+goog.scope(function() { |
+ |
+ |
+ |
+/** |
+ * The view for alt data. |
+ * |
+ * @param {goog.events.EventTarget=} opt_eventTarget The parent event target. |
+ * @constructor |
+ * @extends {i18n.input.chrome.inputview.elements.Element} |
+ */ |
+i18n.input.chrome.inputview.elements.content.AltDataView = function( |
+ opt_eventTarget) { |
+ goog.base(this, '', i18n.input.chrome.inputview.elements.ElementType. |
+ ALTDATA_VIEW, opt_eventTarget); |
+ |
+ /** |
+ * The alternative elements. |
+ * |
+ * @type {!Array.<!Element>} |
+ * @private |
+ */ |
+ this.altdataElements_ = []; |
+}; |
+goog.inherits(i18n.input.chrome.inputview.elements.content.AltDataView, |
+ i18n.input.chrome.inputview.elements.Element); |
+var AltDataView = i18n.input.chrome.inputview.elements.content.AltDataView; |
+ |
+ |
+/** |
+ * The padding between the alt data view and the key. |
+ * |
+ * @type {number} |
+ * @private |
+ */ |
+AltDataView.PADDING_ = 6; |
+ |
+ |
+/** |
+ * The distance between finger to altdata view which will cancel the altdata |
+ * view. |
+ * |
+ * @type {number} |
+ * @private |
+ */ |
+AltDataView.FINGER_DISTANCE_TO_CANCEL_ALTDATA_ = 100; |
+ |
+ |
+/** |
+ * The cover element. |
+ * Note: The reason we use a separate cover element instead of the view is |
+ * because of the opacity. We can not reassign the opacity in child element. |
+ * |
+ * @type {!Element} |
+ * @private |
+ */ |
+AltDataView.prototype.coverElement_; |
+ |
+ |
+/** |
+ * The index of the alternative element which is highlighted. |
+ * |
+ * @type {number} |
+ * @private |
+ */ |
+AltDataView.prototype.highlightIndex_ = 0; |
+ |
+ |
+/** |
+ * The key which trigger this alternative data view. |
+ * |
+ * @type {!i18n.input.chrome.inputview.elements.content.SoftKey} |
+ */ |
+AltDataView.prototype.triggeredBy; |
+ |
+ |
+/** @override */ |
+AltDataView.prototype.createDom = function() { |
+ goog.base(this, 'createDom'); |
+ |
+ var dom = this.getDomHelper(); |
+ var elem = this.getElement(); |
+ goog.dom.classlist.add(elem, i18n.input.chrome.inputview.Css.ALTDATA_VIEW); |
+ this.coverElement_ = dom.createDom(goog.dom.TagName.DIV, |
+ i18n.input.chrome.inputview.Css.ALTDATA_COVER); |
+ dom.appendChild(document.body, this.coverElement_); |
+ goog.style.setElementShown(this.coverElement_, false); |
+ |
+ this.coverElement_['view'] = this; |
+}; |
+ |
+ |
+/** @override */ |
+AltDataView.prototype.enterDocument = function() { |
+ goog.base(this, 'enterDocument'); |
+ |
+ goog.style.setElementShown(this.getElement(), false); |
+}; |
+ |
+ |
+/** |
+ * Shows the alt data viwe. |
+ * |
+ * @param {!i18n.input.chrome.inputview.elements.content.SoftKey} key The key |
+ * triggerred this altdata view. |
+ * @param {boolean} isRTL Whether to show the key characters as RTL. |
+ */ |
+AltDataView.prototype.show = function(key, isRTL) { |
+ this.triggeredBy = key; |
+ var coordinate = goog.style.getClientPosition(key.getElement()); |
+ var x = coordinate.x; |
+ var y = coordinate.y; |
+ var width = key.availableWidth; |
+ var height = key.availableHeight; |
+ var ElementType = i18n.input.chrome.inputview.elements.ElementType; |
+ var characters; |
+ if (key.type == ElementType.CHARACTER_KEY) { |
+ key = /** @type {!i18n.input.chrome.inputview.elements.content. |
+ CharacterKey} */ (key); |
+ characters = key.getAltCharacters(); |
+ } else if (key.type == ElementType.COMPACT_KEY) { |
+ key = /** @type {!i18n.input.chrome.inputview.elements.content. |
+ CompactKey} */ (key); |
+ characters = key.getMoreCharacters(); |
+ if (key.hintText) { |
+ goog.array.insertAt(characters, key.hintText, 0); |
+ } |
+ } |
+ if (!characters || characters.length == 0) { |
+ return; |
+ } |
+ |
+ goog.style.setElementShown(this.getElement(), true); |
+ this.getDomHelper().removeChildren(this.getElement()); |
+ // The total width of the characters + the separators, every separator has |
+ // width = 1. |
+ var altDataWidth = width * characters.length; |
+ var showingLeft = (x + altDataWidth) > screen.width; |
+ if (showingLeft) { |
+ characters.reverse(); |
+ } |
+ for (var i = 0; i < characters.length; i++) { |
+ var keyElem = this.addKey_(characters[i], isRTL); |
+ goog.style.setSize(keyElem, width, height); |
+ this.altdataElements_.push(keyElem); |
+ if (i != characters.length - 1) { |
+ this.addSeparator_(height); |
+ } |
+ } |
+ var left = x; |
+ if (showingLeft) { |
+ // If no enough space at the right, then make it to the left. |
+ left = x + width - altDataWidth; |
+ this.highlightIndex_ = this.altdataElements_.length - 1; |
+ this.setElementBackground_(this.altdataElements_[this.highlightIndex_], |
+ true); |
+ } else { |
+ this.setElementBackground_(this.altdataElements_[0], true); |
+ } |
+ var elemTop = y - height - AltDataView.PADDING_; |
+ if (elemTop < 0) { |
+ elemTop = y + height + AltDataView.PADDING_; |
+ } |
+ goog.style.setPosition(this.getElement(), left, elemTop); |
+ goog.style.setElementShown(this.coverElement_, true); |
+ this.triggeredBy.setHighlighted(true); |
+}; |
+ |
+ |
+/** |
+ * Hides the alt data view. |
+ */ |
+AltDataView.prototype.hide = function() { |
+ this.altdataElements_ = []; |
+ this.highlightIndex_ = 0; |
+ goog.style.setElementShown(this.getElement(), false); |
+ goog.style.setElementShown(this.coverElement_, false); |
+ this.triggeredBy.setHighlighted(false); |
+}; |
+ |
+ |
+/** |
+ * Highlights the item according to the current coordinate of the finger. |
+ * |
+ * @param {number} x . |
+ * @param {number} y . |
+ */ |
+AltDataView.prototype.highlightItem = function(x, y) { |
+ for (var i = 0; i < this.altdataElements_.length; i++) { |
+ var elem = this.altdataElements_[i]; |
+ var coordinate = goog.style.getClientPosition(elem); |
+ var size = goog.style.getSize(elem); |
+ if (coordinate.x < x && (coordinate.x + size.width) > x) { |
+ this.highlightIndex_ = i; |
+ this.clearAllHighlights_(); |
+ this.setElementBackground_(elem, true); |
+ } |
+ var verticalDist = Math.min(Math.abs(y - coordinate.y), |
+ Math.abs(y - coordinate.y - size.height)); |
+ if (verticalDist > AltDataView. |
+ FINGER_DISTANCE_TO_CANCEL_ALTDATA_) { |
+ this.hide(); |
+ return; |
+ } |
+ } |
+}; |
+ |
+ |
+/** |
+ * Clears all the highlights. |
+ * |
+ * @private |
+ */ |
+AltDataView.prototype.clearAllHighlights_ = |
+ function() { |
+ for (var i = 0; i < this.altdataElements_.length; i++) { |
+ this.setElementBackground_(this.altdataElements_[i], false); |
+ } |
+}; |
+ |
+ |
+/** |
+ * Sets the background style of the element. |
+ * |
+ * @param {!Element} element The element. |
+ * @param {boolean} highlight True to highlight the element. |
+ * @private |
+ */ |
+AltDataView.prototype.setElementBackground_ = |
+ function(element, highlight) { |
+ if (highlight) { |
+ goog.dom.classlist.add(element, i18n.input.chrome.inputview.Css. |
+ ELEMENT_HIGHLIGHT); |
+ } else { |
+ goog.dom.classlist.remove(element, i18n.input.chrome.inputview.Css. |
+ ELEMENT_HIGHLIGHT); |
+ } |
+}; |
+ |
+ |
+/** |
+ * Gets the highlighted character. |
+ * |
+ * @return {string} The character. |
+ */ |
+AltDataView.prototype.getHighlightedCharacter = function() { |
+ return goog.dom.getTextContent(this.altdataElements_[this.highlightIndex_]); |
+}; |
+ |
+ |
+/** |
+ * Adds a alt data key into the view. |
+ * |
+ * @param {string} character The alt character. |
+ * @param {boolean} isRTL Whether to show the character as RTL. |
+ * @return {!Element} The create key element. |
+ * @private |
+ */ |
+AltDataView.prototype.addKey_ = function(character, isRTL) { |
+ var dom = this.getDomHelper(); |
+ var keyElem = dom.createDom(goog.dom.TagName.DIV, |
+ i18n.input.chrome.inputview.Css.ALTDATA_KEY, |
+ i18n.input.chrome.inputview.util.getVisibleCharacter(character)); |
+ keyElem.style.direction = isRTL ? 'rtl' : 'ltr'; |
+ dom.appendChild(this.getElement(), keyElem); |
+ return keyElem; |
+}; |
+ |
+ |
+/** |
+ * Adds a separator. |
+ * |
+ * @param {number} height . |
+ * @private |
+ */ |
+AltDataView.prototype.addSeparator_ = function(height) { |
+ var dom = this.getDomHelper(); |
+ var tableCell = dom.createDom(goog.dom.TagName.DIV, |
+ i18n.input.chrome.inputview.Css.TABLE_CELL); |
+ tableCell.style.height = height + 'px'; |
+ var separator = dom.createDom(goog.dom.TagName.DIV, |
+ i18n.input.chrome.inputview.Css.ALTDATA_SEPARATOR); |
+ dom.appendChild(tableCell, separator); |
+ dom.appendChild(this.getElement(), tableCell); |
+}; |
+ |
+ |
+/** |
+ * Gets the cover element. |
+ * |
+ * @return {!Element} The cover element. |
+ */ |
+AltDataView.prototype.getCoverElement = function() { |
+ return this.coverElement_; |
+}; |
+ |
+ |
+/** @override */ |
+AltDataView.prototype.resize = function(width, height) { |
+ goog.base(this, 'resize', width, height); |
+ |
+ goog.style.setSize(this.coverElement_, width, height); |
+}; |
+ |
+ |
+/** @override */ |
+AltDataView.prototype.disposeInternal = function() { |
+ this.getElement()['view'] = null; |
+ |
+ goog.base(this, 'disposeInternal'); |
+}; |
+ |
+}); // goog.scope |