123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798 |
- // Copyright 2007 The Closure Library Authors. All Rights Reserved.
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS-IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- /**
- * @fileoverview Emoji Picker implementation. This provides a UI widget for
- * choosing an emoji from a grid of possible choices.
- *
- * @see ../demos/popupemojipicker.html for an example of how to instantiate
- * an emoji picker.
- *
- * Based on goog.ui.ColorPicker (colorpicker.js).
- *
- * @see ../../demos/popupemojipicker.html
- */
- goog.provide('goog.ui.emoji.EmojiPicker');
- goog.require('goog.dom.TagName');
- goog.require('goog.style');
- goog.require('goog.ui.Component');
- goog.require('goog.ui.TabPane');
- goog.require('goog.ui.emoji.Emoji');
- goog.require('goog.ui.emoji.EmojiPalette');
- goog.require('goog.ui.emoji.EmojiPaletteRenderer');
- goog.require('goog.ui.emoji.ProgressiveEmojiPaletteRenderer');
- /**
- * Creates a new, empty emoji picker. An emoji picker is a grid of emoji, each
- * cell of the grid containing a single emoji. The picker may contain multiple
- * pages of emoji.
- *
- * When a user selects an emoji, by either clicking or pressing enter, the
- * picker fires a goog.ui.Component.EventType.ACTION event with the id. The
- * client listens on this event and in the handler can retrieve the id of the
- * selected emoji and do something with it, for instance, inserting an image
- * tag into a rich text control. An emoji picker does not maintain state. That
- * is, once an emoji is selected, the emoji picker does not remember which emoji
- * was selected.
- *
- * The emoji picker is implemented as a tabpane with each tabpage being a table.
- * Each of the tables are the same size to prevent jittering when switching
- * between pages.
- *
- * @param {string} defaultImgUrl Url of the img that should be used to fill up
- * the cells in the emoji table, to prevent jittering. Should be the same
- * size as the emoji.
- * @param {goog.dom.DomHelper=} opt_domHelper Optional DOM helper.
- * @extends {goog.ui.Component}
- * @constructor
- */
- goog.ui.emoji.EmojiPicker = function(defaultImgUrl, opt_domHelper) {
- goog.ui.Component.call(this, opt_domHelper);
- this.defaultImgUrl_ = defaultImgUrl;
- /**
- * Emoji that this picker displays.
- *
- * @type {Array<Object>}
- * @private
- */
- this.emoji_ = [];
- /**
- * Pages of this emoji picker.
- *
- * @type {Array<goog.ui.emoji.EmojiPalette>}
- * @private
- */
- this.pages_ = [];
- /**
- * Keeps track of which pages in the picker have been loaded. Used for delayed
- * loading of tabs.
- *
- * @type {Array<boolean>}
- * @private
- */
- this.pageLoadStatus_ = [];
- /**
- * Tabpane to hold the pages of this emojipicker.
- *
- * @type {goog.ui.TabPane}
- * @private
- */
- this.tabPane_ = null;
- this.getHandler().listen(
- this, goog.ui.Component.EventType.ACTION, this.onEmojiPaletteAction_);
- };
- goog.inherits(goog.ui.emoji.EmojiPicker, goog.ui.Component);
- /**
- * Default number of rows per grid of emoji.
- *
- * @type {number}
- */
- goog.ui.emoji.EmojiPicker.DEFAULT_NUM_ROWS = 5;
- /**
- * Default number of columns per grid of emoji.
- *
- * @type {number}
- */
- goog.ui.emoji.EmojiPicker.DEFAULT_NUM_COLS = 10;
- /**
- * Default location of the tabs in relation to the emoji grids.
- *
- * @type {goog.ui.TabPane.TabLocation}
- */
- goog.ui.emoji.EmojiPicker.DEFAULT_TAB_LOCATION =
- goog.ui.TabPane.TabLocation.TOP;
- /** @private {goog.ui.emoji.Emoji} */
- goog.ui.emoji.EmojiPicker.prototype.selectedEmoji_;
- /** @private {goog.ui.emoji.EmojiPaletteRenderer} */
- goog.ui.emoji.EmojiPicker.prototype.renderer_;
- /**
- * Number of rows per grid of emoji.
- *
- * @type {number}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.numRows_ =
- goog.ui.emoji.EmojiPicker.DEFAULT_NUM_ROWS;
- /**
- * Number of columns per grid of emoji.
- *
- * @type {number}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.numCols_ =
- goog.ui.emoji.EmojiPicker.DEFAULT_NUM_COLS;
- /**
- * Whether the number of rows in the picker should be automatically determined
- * by the specified number of columns so as to minimize/eliminate jitter when
- * switching between tabs.
- *
- * @type {boolean}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.autoSizeByColumnCount_ = true;
- /**
- * Location of the tabs for the picker tabpane.
- *
- * @type {goog.ui.TabPane.TabLocation}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.tabLocation_ =
- goog.ui.emoji.EmojiPicker.DEFAULT_TAB_LOCATION;
- /**
- * Whether the component is focusable.
- * @type {boolean}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.focusable_ = true;
- /**
- * Url of the img that should be used for cells in the emoji picker that are
- * not filled with emoji, i.e., after all the emoji have already been placed
- * on a page.
- *
- * @type {string}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.defaultImgUrl_;
- /**
- * If present, indicates a prefix that should be prepended to all URLs
- * of images in this emojipicker. This provides an optimization if the URLs
- * are long, so that the client does not have to send a long string for each
- * emoji.
- *
- * @type {string|undefined}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.urlPrefix_;
- /**
- * If true, delay loading the images for the emojipalettes until after
- * construction. This gives a better user experience before the images are in
- * the cache, since other widgets waiting for construction of the emojipalettes
- * won't have to wait for all the images (which may be a substantial amount) to
- * load.
- *
- * @type {boolean}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.delayedLoad_ = false;
- /**
- * Whether to use progressive rendering in the emojipicker's palette, if using
- * sprited imgs. If true, then uses img tags, which most browsers render
- * progressively (i.e., as the data comes in). If false, then uses div tags
- * with the background-image, which some newer browsers render progressively
- * but older ones do not.
- *
- * @type {boolean}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.progressiveRender_ = false;
- /**
- * Whether to require the caller to manually specify when to start loading
- * animated emoji. This is primarily for unittests to be able to test the
- * structure of the emojipicker palettes before and after the animated emoji
- * have been loaded.
- *
- * @type {boolean}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.manualLoadOfAnimatedEmoji_ = false;
- /**
- * Index of the active page in the picker.
- *
- * @type {number}
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.activePage_ = -1;
- /**
- * Adds a group of emoji to the picker.
- *
- * @param {string|Element} title Title for the group.
- * @param {Array<Array<string>>} emojiGroup A new group of emoji to be added
- * Each internal array contains [emojiUrl, emojiId].
- */
- goog.ui.emoji.EmojiPicker.prototype.addEmojiGroup = function(
- title, emojiGroup) {
- this.emoji_.push({title: title, emoji: emojiGroup});
- };
- /**
- * Gets the number of rows per grid in the emoji picker.
- *
- * @return {number} number of rows per grid.
- */
- goog.ui.emoji.EmojiPicker.prototype.getNumRows = function() {
- return this.numRows_;
- };
- /**
- * Gets the number of columns per grid in the emoji picker.
- *
- * @return {number} number of columns per grid.
- */
- goog.ui.emoji.EmojiPicker.prototype.getNumColumns = function() {
- return this.numCols_;
- };
- /**
- * Sets the number of rows per grid in the emoji picker. This should only be
- * called before the picker has been rendered.
- *
- * @param {number} numRows Number of rows per grid.
- */
- goog.ui.emoji.EmojiPicker.prototype.setNumRows = function(numRows) {
- this.numRows_ = numRows;
- };
- /**
- * Sets the number of columns per grid in the emoji picker. This should only be
- * called before the picker has been rendered.
- *
- * @param {number} numCols Number of columns per grid.
- */
- goog.ui.emoji.EmojiPicker.prototype.setNumColumns = function(numCols) {
- this.numCols_ = numCols;
- };
- /**
- * Sets whether to automatically size the emojipicker based on the number of
- * columns and the number of emoji in each group, so as to reduce jitter.
- *
- * @param {boolean} autoSize Whether to automatically size the picker.
- */
- goog.ui.emoji.EmojiPicker.prototype.setAutoSizeByColumnCount = function(
- autoSize) {
- this.autoSizeByColumnCount_ = autoSize;
- };
- /**
- * Sets the location of the tabs in relation to the emoji grids. This should
- * only be called before the picker has been rendered.
- *
- * @param {goog.ui.TabPane.TabLocation} tabLocation The location of the tabs.
- */
- goog.ui.emoji.EmojiPicker.prototype.setTabLocation = function(tabLocation) {
- this.tabLocation_ = tabLocation;
- };
- /**
- * Sets whether loading of images should be delayed until after dom creation.
- * Thus, this function must be called before {@link #createDom}. If set to true,
- * the client must call {@link #loadImages} when they wish the images to be
- * loaded.
- *
- * @param {boolean} shouldDelay Whether to delay loading the images.
- */
- goog.ui.emoji.EmojiPicker.prototype.setDelayedLoad = function(shouldDelay) {
- this.delayedLoad_ = shouldDelay;
- };
- /**
- * Sets whether to require the caller to manually specify when to start loading
- * animated emoji. This is primarily for unittests to be able to test the
- * structure of the emojipicker palettes before and after the animated emoji
- * have been loaded. This only affects sprited emojipickers with sprite data
- * for animated emoji.
- *
- * @param {boolean} manual Whether to load animated emoji manually.
- */
- goog.ui.emoji.EmojiPicker.prototype.setManualLoadOfAnimatedEmoji = function(
- manual) {
- this.manualLoadOfAnimatedEmoji_ = manual;
- };
- /**
- * Returns true if the component is focusable, false otherwise. The default
- * is true. Focusable components always have a tab index and allocate a key
- * handler to handle keyboard events while focused.
- * @return {boolean} Whether the component is focusable.
- */
- goog.ui.emoji.EmojiPicker.prototype.isFocusable = function() {
- return this.focusable_;
- };
- /**
- * Sets whether the component is focusable. The default is true.
- * Focusable components always have a tab index and allocate a key handler to
- * handle keyboard events while focused.
- * @param {boolean} focusable Whether the component is focusable.
- */
- goog.ui.emoji.EmojiPicker.prototype.setFocusable = function(focusable) {
- this.focusable_ = focusable;
- for (var i = 0; i < this.pages_.length; i++) {
- if (this.pages_[i]) {
- this.pages_[i].setSupportedState(
- goog.ui.Component.State.FOCUSED, focusable);
- }
- }
- };
- /**
- * Sets the URL prefix for the emoji URLs.
- *
- * @param {string} urlPrefix Prefix that should be prepended to all URLs.
- */
- goog.ui.emoji.EmojiPicker.prototype.setUrlPrefix = function(urlPrefix) {
- this.urlPrefix_ = urlPrefix;
- };
- /**
- * Sets the progressive rendering aspect of this emojipicker. Must be called
- * before createDom to have an effect.
- *
- * @param {boolean} progressive Whether this picker should render progressively.
- */
- goog.ui.emoji.EmojiPicker.prototype.setProgressiveRender = function(
- progressive) {
- this.progressiveRender_ = progressive;
- };
- /**
- * Adjusts the number of rows to be the maximum row count out of all the emoji
- * groups, in order to prevent jitter in switching among the tabs.
- *
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.adjustNumRowsIfNecessary_ = function() {
- var currentMax = 0;
- for (var i = 0; i < this.emoji_.length; i++) {
- var numEmoji = this.emoji_[i].emoji.length;
- var rowsNeeded = Math.ceil(numEmoji / this.numCols_);
- if (rowsNeeded > currentMax) {
- currentMax = rowsNeeded;
- }
- }
- this.setNumRows(currentMax);
- };
- /**
- * Causes the emoji imgs to be loaded into the picker. Used for delayed loading.
- * No-op if delayed loading is not set.
- */
- goog.ui.emoji.EmojiPicker.prototype.loadImages = function() {
- if (!this.delayedLoad_) {
- return;
- }
- // Load the first page only
- this.loadPage_(0);
- this.activePage_ = 0;
- };
- /**
- * @override
- * @suppress {deprecated} Using deprecated goog.ui.TabPane.
- */
- goog.ui.emoji.EmojiPicker.prototype.createDom = function() {
- this.setElementInternal(this.getDomHelper().createDom(goog.dom.TagName.DIV));
- if (this.autoSizeByColumnCount_) {
- this.adjustNumRowsIfNecessary_();
- }
- if (this.emoji_.length == 0) {
- throw Error('Must add some emoji to the picker');
- }
- // If there is more than one group of emoji, we construct a tabpane
- if (this.emoji_.length > 1) {
- // Give the tabpane a div to use as its content element, since tabpane
- // overwrites the CSS class of the element it's passed
- var div = this.getDomHelper().createDom(goog.dom.TagName.DIV);
- this.getElement().appendChild(div);
- this.tabPane_ = new goog.ui.TabPane(
- div, this.tabLocation_, this.getDomHelper(), true /* use MOUSEDOWN */);
- }
- this.renderer_ = this.progressiveRender_ ?
- new goog.ui.emoji.ProgressiveEmojiPaletteRenderer(this.defaultImgUrl_) :
- new goog.ui.emoji.EmojiPaletteRenderer(this.defaultImgUrl_);
- for (var i = 0; i < this.emoji_.length; i++) {
- var emoji = this.emoji_[i].emoji;
- var page = this.delayedLoad_ ? this.createPlaceholderEmojiPage_(emoji) :
- this.createEmojiPage_(emoji, i);
- this.pages_.push(page);
- }
- this.activePage_ = 0;
- this.getElement().tabIndex = 0;
- };
- /**
- * Used by unittests to manually load the animated emoji for this picker.
- */
- goog.ui.emoji.EmojiPicker.prototype.manuallyLoadAnimatedEmoji = function() {
- for (var i = 0; i < this.pages_.length; i++) {
- this.pages_[i].loadAnimatedEmoji();
- }
- };
- /**
- * Creates a page if it has not already been loaded. This has the side effects
- * of setting the load status of the page to true.
- *
- * @param {Array<Array<string>>} emoji Emoji for this page. See
- * {@link addEmojiGroup} for more details.
- * @param {number} index Index of the page in the emojipicker.
- * @return {goog.ui.emoji.EmojiPalette} the emoji page.
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.createEmojiPage_ = function(emoji, index) {
- // Safeguard against trying to create the same page twice
- if (this.pageLoadStatus_[index]) {
- return null;
- }
- var palette = new goog.ui.emoji.EmojiPalette(
- emoji, this.urlPrefix_, this.renderer_, this.getDomHelper());
- if (!this.manualLoadOfAnimatedEmoji_) {
- palette.loadAnimatedEmoji();
- }
- palette.setSize(this.numCols_, this.numRows_);
- palette.setSupportedState(goog.ui.Component.State.FOCUSED, this.focusable_);
- palette.createDom();
- palette.setParent(this);
- this.pageLoadStatus_[index] = true;
- return palette;
- };
- /**
- * Returns an array of emoji whose real URLs have been replaced with the
- * default img URL. Used for delayed loading.
- *
- * @param {Array<Array<string>>} emoji Original emoji array.
- * @return {!Array<!Array<string>>} emoji array with all emoji pointing to the
- * default img.
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.getPlaceholderEmoji_ = function(emoji) {
- var placeholderEmoji = [];
- for (var i = 0; i < emoji.length; i++) {
- placeholderEmoji.push([this.defaultImgUrl_, emoji[i][1]]);
- }
- return placeholderEmoji;
- };
- /**
- * Creates an emoji page using placeholder emoji pointing to the default
- * img instead of the real emoji. Used for delayed loading.
- *
- * @param {Array<Array<string>>} emoji Emoji for this page. See
- * {@link addEmojiGroup} for more details.
- * @return {!goog.ui.emoji.EmojiPalette} the emoji page.
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.createPlaceholderEmojiPage_ = function(
- emoji) {
- var placeholderEmoji = this.getPlaceholderEmoji_(emoji);
- var palette = new goog.ui.emoji.EmojiPalette(
- placeholderEmoji,
- null, // no url prefix
- this.renderer_, this.getDomHelper());
- palette.setSize(this.numCols_, this.numRows_);
- palette.setSupportedState(goog.ui.Component.State.FOCUSED, this.focusable_);
- palette.createDom();
- palette.setParent(this);
- return palette;
- };
- /**
- * EmojiPickers cannot be used to decorate pre-existing html, since the
- * structure they build is fairly complicated.
- * @param {Element} element Element to decorate.
- * @return {boolean} Returns always false.
- * @override
- */
- goog.ui.emoji.EmojiPicker.prototype.canDecorate = function(element) {
- return false;
- };
- /**
- * @override
- * @suppress {deprecated} Using deprecated goog.ui.TabPane.
- */
- goog.ui.emoji.EmojiPicker.prototype.enterDocument = function() {
- goog.ui.emoji.EmojiPicker.superClass_.enterDocument.call(this);
- for (var i = 0; i < this.pages_.length; i++) {
- this.pages_[i].enterDocument();
- var pageElement = this.pages_[i].getElement();
- // Add a new tab to the tabpane if there's more than one group of emoji.
- // If there is just one group of emoji, then we simply use the single
- // page's element as the content for the picker
- if (this.pages_.length > 1) {
- // Create a simple default title containg the page number if the title
- // was not provided in the emoji group params
- var title = this.emoji_[i].title || (i + 1);
- this.tabPane_.addPage(
- new goog.ui.TabPane.TabPage(pageElement, title, this.getDomHelper()));
- } else {
- this.getElement().appendChild(pageElement);
- }
- }
- // Initialize listeners. Note that we need to initialize this listener
- // after createDom, because addPage causes the goog.ui.TabPane.Events.CHANGE
- // event to fire, but we only want the handler (which loads delayed images)
- // to run after the picker has been constructed.
- if (this.tabPane_) {
- this.getHandler().listen(
- this.tabPane_, goog.ui.TabPane.Events.CHANGE, this.onPageChanged_);
- // Make the tabpane unselectable so that changing tabs doesn't disturb the
- // cursor
- goog.style.setUnselectable(this.tabPane_.getElement(), true);
- }
- this.getElement().unselectable = 'on';
- };
- /** @override */
- goog.ui.emoji.EmojiPicker.prototype.exitDocument = function() {
- goog.ui.emoji.EmojiPicker.superClass_.exitDocument.call(this);
- for (var i = 0; i < this.pages_.length; i++) {
- this.pages_[i].exitDocument();
- }
- };
- /** @override */
- goog.ui.emoji.EmojiPicker.prototype.disposeInternal = function() {
- goog.ui.emoji.EmojiPicker.superClass_.disposeInternal.call(this);
- if (this.tabPane_) {
- this.tabPane_.dispose();
- this.tabPane_ = null;
- }
- for (var i = 0; i < this.pages_.length; i++) {
- this.pages_[i].dispose();
- }
- this.pages_.length = 0;
- };
- /**
- * @return {string} CSS class for the root element of EmojiPicker.
- */
- goog.ui.emoji.EmojiPicker.prototype.getCssClass = function() {
- return goog.getCssName('goog-ui-emojipicker');
- };
- /**
- * Returns the currently selected emoji from this picker. If the picker is
- * using the URL prefix optimization, allocates a new emoji object with the
- * full URL. This method is meant to be used by clients of the emojipicker,
- * e.g., in a listener on goog.ui.component.EventType.ACTION that wants to use
- * the just-selected emoji.
- *
- * @return {goog.ui.emoji.Emoji} The currently selected emoji from this picker.
- */
- goog.ui.emoji.EmojiPicker.prototype.getSelectedEmoji = function() {
- return this.urlPrefix_ ?
- new goog.ui.emoji.Emoji(
- this.urlPrefix_ + this.selectedEmoji_.getId(),
- this.selectedEmoji_.getId()) :
- this.selectedEmoji_;
- };
- /**
- * Returns the number of emoji groups in this picker.
- *
- * @return {number} The number of emoji groups in this picker.
- */
- goog.ui.emoji.EmojiPicker.prototype.getNumEmojiGroups = function() {
- return this.emoji_.length;
- };
- /**
- * Returns a page from the picker. This should be considered protected, and is
- * ONLY FOR TESTING.
- *
- * @param {number} index Index of the page to return.
- * @return {goog.ui.emoji.EmojiPalette?} the page at the specified index or null
- * if none exists.
- */
- goog.ui.emoji.EmojiPicker.prototype.getPage = function(index) {
- return this.pages_[index];
- };
- /**
- * Returns all the pages from the picker. This should be considered protected,
- * and is ONLY FOR TESTING.
- *
- * @return {Array<goog.ui.emoji.EmojiPalette>?} the pages in the picker or
- * null if none exist.
- */
- goog.ui.emoji.EmojiPicker.prototype.getPages = function() {
- return this.pages_;
- };
- /**
- * Returns the tabpane if this is a multipage picker. This should be considered
- * protected, and is ONLY FOR TESTING.
- *
- * @return {goog.ui.TabPane} the tabpane if it is a multipage picker,
- * or null if it does not exist or is a single page picker.
- */
- goog.ui.emoji.EmojiPicker.prototype.getTabPane = function() {
- return this.tabPane_;
- };
- /**
- * @return {goog.ui.emoji.EmojiPalette} The active page of the emoji picker.
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.getActivePage_ = function() {
- return this.pages_[this.activePage_];
- };
- /**
- * Handles actions from the EmojiPalettes that this picker contains.
- *
- * @param {goog.ui.Component.EventType} e The event object.
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.onEmojiPaletteAction_ = function(e) {
- this.selectedEmoji_ = this.getActivePage_().getSelectedEmoji();
- };
- /**
- * Handles changes in the active page in the tabpane.
- *
- * @param {goog.ui.TabPaneEvent} e The event object.
- * @private
- */
- goog.ui.emoji.EmojiPicker.prototype.onPageChanged_ = function(e) {
- var index = /** @type {number} */ (e.page.getIndex());
- this.loadPage_(index);
- this.activePage_ = index;
- };
- /**
- * Loads a page into the picker if it has not yet been loaded.
- *
- * @param {number} index Index of the page to load.
- * @private
- * @suppress {deprecated} Using deprecated goog.ui.TabPane.
- */
- goog.ui.emoji.EmojiPicker.prototype.loadPage_ = function(index) {
- if (index < 0 || index > this.pages_.length) {
- throw Error('Index out of bounds');
- }
- if (!this.pageLoadStatus_[index]) {
- var oldPage = this.pages_[index];
- this.pages_[index] = this.createEmojiPage_(this.emoji_[index].emoji, index);
- this.pages_[index].enterDocument();
- var pageElement = this.pages_[index].getElement();
- if (this.pages_.length > 1) {
- this.tabPane_.removePage(index);
- var title = this.emoji_[index].title || (index + 1);
- this.tabPane_.addPage(
- new goog.ui.TabPane.TabPage(pageElement, title, this.getDomHelper()),
- index);
- this.tabPane_.setSelectedIndex(index);
- } else {
- var el = this.getElement();
- el.appendChild(pageElement);
- }
- if (oldPage) {
- oldPage.dispose();
- }
- }
- };
|