Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / third_party / google_input_tools / src / chrome / os / inputview / elements / element.js
blob48e7f8ba9bf325e65273e8175d70d6cd2bc20785
1 // Copyright 2014 The ChromeOS IME Authors. All Rights Reserved.
2 // limitations under the License.
3 // See the License for the specific language governing permissions and
4 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
5 // distributed under the License is distributed on an "AS-IS" BASIS,
6 // Unless required by applicable law or agreed to in writing, software
7 //
8 // http://www.apache.org/licenses/LICENSE-2.0
9 //
10 // You may obtain a copy of the License at
11 // you may not use this file except in compliance with the License.
12 // Licensed under the Apache License, Version 2.0 (the "License");
14 goog.provide('i18n.input.chrome.inputview.elements.Element');
16 goog.require('goog.dom.classlist');
17 goog.require('goog.events.EventHandler');
18 goog.require('goog.style');
19 goog.require('goog.ui.Component');
20 goog.require('i18n.input.chrome.inputview.Css');
21 goog.require('i18n.input.chrome.inputview.PointerConfig');
24 goog.scope(function() {
28 /**
29 * The abstract class for element in input view keyboard.
31 * @param {string} id The id.
32 * @param {!i18n.input.chrome.inputview.elements.ElementType} type The element
33 * type.
34 * @param {goog.events.EventTarget=} opt_eventTarget The event target.
35 * @constructor
36 * @extends {goog.ui.Component}
38 i18n.input.chrome.inputview.elements.Element = function(id, type,
39 opt_eventTarget) {
40 goog.base(this);
41 this.setParentEventTarget(opt_eventTarget || null);
43 /**
44 * The id of the element.
46 * @type {string}
48 this.id = id;
50 /**
51 * The type of the element.
53 * @type {!i18n.input.chrome.inputview.elements.ElementType}
55 this.type = type;
57 /**
58 * The display of the element.
60 * @type {string}
61 * @private
63 this.display_ = '';
65 /**
66 * The event handler.
68 * @type {!goog.events.EventHandler}
70 this.handler = new goog.events.EventHandler(this);
72 /**
73 * The configuration for the pointer.
75 * @type {!i18n.input.chrome.inputview.PointerConfig}
77 this.pointerConfig = new i18n.input.chrome.inputview.PointerConfig(false,
78 false, false);
80 goog.inherits(i18n.input.chrome.inputview.elements.Element, goog.ui.Component);
81 var Element = i18n.input.chrome.inputview.elements.Element;
84 /**
85 * The width of the element.
87 * @type {number}
89 Element.prototype.width;
92 /**
93 * The height of the element.
95 * @type {number}
97 Element.prototype.height;
101 * Resizes the element.
103 * @param {number} width The total width.
104 * @param {number} height The total height.
106 Element.prototype.resize = function(width, height) {
107 this.width = width;
108 this.height = height;
112 /** @override */
113 Element.prototype.createDom = function() {
114 goog.base(this, 'createDom');
116 this.getElement().id = this.id;
117 this.getElement()['view'] = this;
121 /** @override */
122 Element.prototype.enterDocument = function() {
123 goog.base(this, 'enterDocument');
125 this.display_ = this.getElement().style.display;
130 * Whether the element is visible.
132 * @return {boolean} True if the element is visible.
134 Element.prototype.isVisible = function() {
135 return goog.style.isElementShown(this.getElement());
140 * Sets the visibility of the element.
142 * @param {boolean} visibility True if the element is visible.
144 Element.prototype.setVisible = function(visibility) {
145 // TODO: Figure out why element can be null.
146 var element = this.getElement();
147 if (element)
148 element.style.display = visibility ? this.display_ : 'none';
153 * Updates the element.
155 Element.prototype.update = function() {
156 this.setHighlighted(false);
157 for (var i = 0; i < this.getChildCount(); i++) {
158 var child = /** @type {!Element} */ (
159 this.getChildAt(i));
160 child.update();
166 * Sets the highlight of the soft key.
168 * @param {boolean} highlight True to set it to be highlighted.
170 Element.prototype.setHighlighted = function(
171 highlight) {
172 if (highlight) {
173 goog.dom.classlist.add(this.getElement(),
174 i18n.input.chrome.inputview.Css.ELEMENT_HIGHLIGHT);
175 } else {
176 goog.dom.classlist.remove(this.getElement(),
177 i18n.input.chrome.inputview.Css.ELEMENT_HIGHLIGHT);
182 /** @override */
183 Element.prototype.disposeInternal = function() {
184 this.getElement()['view'] = null;
185 goog.dispose(this.handler);
187 goog.base(this, 'disposeInternal');
190 }); // goog.scope