chromium/third_party/google-closure-library/closure/goog/demos/popupemojipicker.html

<!DOCTYPE html>
<html>
<!--
Copyright The Closure Library Authors. All Rights Reserved.

Use of this source code is governed by the Apache License, Version 2.0.
See the COPYING file for details.
-->
<head>
  <title>Popup Emoji Picker</title>
  <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
  <script type="text/javascript" src="../base.js"></script>
  <script type="text/javascript">
    goog.require('goog.dom.classlist');
    goog.require('goog.ui.emoji.PopupEmojiPicker');
    goog.require('goog.ui.emoji.EmojiPicker');
    goog.require('goog.ui.emoji.SpriteInfo');
  </script>
  <link rel="stylesheet" href="css/demo.css">
  <link rel="stylesheet" href="css/emojipicker.css">
  <link rel="stylesheet" href="css/emojisprite.css">
  <style type="text/css">
    /* TabPane styles */
    .goog-tabpane {
      background: threedface;
      padding-left: 1px;
    }

    .goog-tabpane-tabs {
      list-style: none;
      margin: 0px;
      padding: 0px;
    }

    .goog-tabpane-cont {
      overflow: auto;
      clear: both;
      background: threedface;
      border: 1px solid;
      border-color: threedhighlight threedshadow threedshadow threedhighlight;
      padding: 2px;
    }

    .goog-tabpane-tab, .goog-tabpane-tab-selected {
      display: block;
      float: left;
      padding: 0px 3ex;
      background: threedface;
      border: 1px solid;
      border-color: threedhighlight threedshadow threedface threedhighlight;
      margin: 0px;
    }

    .goog-tabpane-tab {
      margin-top: 0px;
    }

    .goog-tabpane-tab-selected {
      padding-bottom: 2px;
      padding-top: 2px;
      position: relative;
      top: 1px;
      font-weight: bold;
    }

    /* Emojipicker styles */
    .singlePagePicker .goog-palette {
      border: 1px solid black;
    }

    .popupButton {
      display: block;
      width: 100px;
      text-align: center;
      padding: 10px;
      font: normal 0.8em verdana,sans-serif;
      border: 1px solid #000;
    }
  </style>
</head>
<body>
<h3>Popup Emoji Picker Demo</h3>
This is a demo of popupemojipickers and docked emoji pickers. Selecting an
emoji inserts a pseudo image tag into the text area with the id of that emoji.

<h4>Sprited Emojipicker (contains a mix of sprites and non-sprites):</h4>
<div id="spriteDock1" class="singlePagePicker"></div>

<h4>Sprited Progressively-rendered Emojipicker (contains a mix of sprites and
  non-sprites):</h4>
<div id="spriteDock2" class="singlePagePicker"></div>
<h4>Popup Emoji:</h4>
<a href="javascript:void(0)" class="popupButton" id="button1">Gimme some emoji</a>
<hr>

<h4>Fast-load Progressive Sprited Emojipicker</h4>
<div id="fastLoad1" class="singlePagePicker"></div>

<h4>Fast-load Non-progressive Sprited Emojipicker</h4>
<div id="fastLoad2" class="singlePagePicker"></div>

<div id="spriteDock3" class="singlePagePicker"></div>

<h4>Docked emoji:</h4>
<div id="emojiDock"></div>

<h4>Single Page of Emoji</h4>
<div id="singlePageEmojiPicker" class="singlePagePicker"></div>

<h4>Delayed load popup picker:</h4>
<a href="javascript:void(0)" class="popupButton" id="button2">More emoji</a>

<h4>Delayed load docked picker:</h4>
<a href="javascript:void(0)" id="delayedLoadDockDiv" class="popupButton"
   onclick="loadPicker()">
  Click to load
</a>
<div id="delayedLoadDock" class="singlePagePicker"></div>

<textarea rows="20" cols="200" id="text">

</textarea>

<script type="text/javascript">
  var emojiGroup1 = [
      'Emoji 1',
      [
          ['emoji/200.gif', 'std.200'],
          ['emoji/201.gif', 'std.201'],
          ['emoji/202.gif', 'std.202'],
          ['emoji/203.gif', 'std.203'],
          ['emoji/204.gif', 'std.204'],
          ['emoji/205.gif', 'std.205'],
          ['emoji/206.gif', 'std.206'],
          ['emoji/2BC.gif', 'std.2BC'],
          ['emoji/2BD.gif', 'std.2BD'],
          ['emoji/2BE.gif', 'std.2BE'],
          ['emoji/2BF.gif', 'std.2BF'],
          ['emoji/2C0.gif', 'std.2C0'],
          ['emoji/2C1.gif', 'std.2C1'],
          ['emoji/2C2.gif', 'std.2C2'],
          ['emoji/2C3.gif', 'std.2C3'],
          ['emoji/2C4.gif', 'std.2C4'],
          ['emoji/2C5.gif', 'std.2C5'],
          ['emoji/2C6.gif', 'std.2C6'],
          ['emoji/2C7.gif', 'std.2C7'],
          ['emoji/2C8.gif', 'std.2C8'],
          ['emoji/2C9.gif', 'std.2C9'],
          ['emoji/2CA.gif', 'std.2CA'],
          ['emoji/2CB.gif', 'std.2CB'],
          ['emoji/2CC.gif', 'std.2CC'],
          ['emoji/2CD.gif', 'std.2CD'],
          ['emoji/2CE.gif', 'std.2CE']
          ]];

  var emojiGroup2 = [
      'Emoji 2',
      [
          ['emoji/2D0.gif', 'std.2D0'],
          ['emoji/2D1.gif', 'std.2D1'],
          ['emoji/2D2.gif', 'std.2D2'],
          ['emoji/2D3.gif', 'std.2D3'],
          ['emoji/2D4.gif', 'std.2D4'],
          ['emoji/2D5.gif', 'std.2D5'],
          ['emoji/2D6.gif', 'std.2D6'],
          ['emoji/2D7.gif', 'std.2D7'],
          ['emoji/2D8.gif', 'std.2D8'],
          ['emoji/2D9.gif', 'std.2D9'],
          ['emoji/2DA.gif', 'std.2DA'],
          ['emoji/2DB.gif', 'std.2DB'],
          ['emoji/2DC.gif', 'std.2DC'],
          ['emoji/2DD.gif', 'std.2DD'],
          ['emoji/2DE.gif', 'std.2DE'],
          ['emoji/2DF.gif', 'std.2DF'],
          ['emoji/2E0.gif', 'std.2E0'],
          ['emoji/2E1.gif', 'std.2E1'],
          ['emoji/2E2.gif', 'std.2E2'],
          ['emoji/2E3.gif', 'std.2E3']
          ]];

  var emojiGroup3 = [
      'Emoji 3',
      [
          ['emoji/2E4.gif', 'std.2E4'],
          ['emoji/2E5.gif', 'std.2E5'],
          ['emoji/2E6.gif', 'std.2E6'],
          ['emoji/2E7.gif', 'std.2E7'],
          ['emoji/2E8.gif', 'std.2E8'],
          ['emoji/2E9.gif', 'std.2E9'],
          ['emoji/2EA.gif', 'std.2EA'],
          ['emoji/2EB.gif', 'std.2EB'],
          ['emoji/2EC.gif', 'std.2EC'],
          ['emoji/2ED.gif', 'std.2ED'],
          ['emoji/2EE.gif', 'std.2EE'],
          ['emoji/2EF.gif', 'std.2EF'],
          ['emoji/2F0.gif', 'std.2F0'],
          ['emoji/2F1.gif', 'std.2F1'],
          ['emoji/2F2.gif', 'std.2F2'],
          ['emoji/2F3.gif', 'std.2F3'],
          ['emoji/2F4.gif', 'std.2F4'],
          ['emoji/2F5.gif', 'std.2F5'],
          ['emoji/2F6.gif', 'std.2F6'],
          ['emoji/2F7.gif', 'std.2F7']
          ]
      ];

  var sprite = 'emoji/sprite.png';
  var sprite2 = 'emoji/sprite2.png';

/**
 * Creates a SpriteInfo object with the specified properties. If the image is
 * sprited via CSS, then only the first parameter needs a value. If the image
 * is sprited via metadata, then the first parameter should be left null.
 *
 * @param {?string} cssClass CSS class to properly display the sprited image.
 * @param {string=} opt_url Url of the sprite image.
 * @param {number=} opt_width Width of the image being sprited.
 * @param {number=} opt_height Height of the image being sprited.
 * @param {number=} opt_xOffset Positive x offset of the image being sprited
 *     within the sprite.
 * @param {number=} opt_yOffset Positive y offset of the image being sprited
 *     within the sprite.
 * @param {boolean=} opt_animated Whether the sprite info is for an animated
 *     emoji.
 */
  function si(cssClass, opt_url, opt_width, opt_height, opt_xOffset,
              opt_yOffset, opt_animated) {
    return new goog.ui.emoji.SpriteInfo(cssClass, opt_url, opt_width,
        opt_height, opt_xOffset, opt_yOffset, opt_animated);
  }

  // This group contains a mix of sprited emoji via css, sprited emoji via
  // metadata, and non-sprited emoji.
  var spritedEmoji1 = [
      'Emoji 1',
      [
          ['emoji/200.gif', 'std.200', si('SPRITE_200')],
          ['emoji/201.gif', 'std.201', si('SPRITE_201')],
          ['emoji/202.gif', 'std.202', si('SPRITE_202')],
          ['emoji/203.gif', 'std.203', si('SPRITE_203')],
          ['emoji/204.gif', 'std.204', si('SPRITE_204')],
          ['emoji/205.gif', 'std.205', si('SPRITE_205')],
          ['emoji/206.gif', 'std.206', si('SPRITE_206')],
          ['emoji/2BC.gif', 'std.2BC', si('SPRITE_2BC')],
          ['emoji/2BD.gif', 'std.2BD', si('SPRITE_2BD')],
          ['emoji/2BE.gif', 'std.2BE', si(null, sprite, 18, 18, 36, 54)],
          ['emoji/2BF.gif', 'std.2BF', si(null, sprite, 18, 18, 0, 126)],
          ['emoji/2C0.gif', 'std.2C0', si(null, sprite, 18, 18, 18, 305)],
          ['emoji/2C1.gif', 'std.2C1', si(null, sprite, 18, 18, 0, 287)],
          ['emoji/2C2.gif', 'std.2C2', si(null, sprite, 18, 18, 18, 126)],
          ['emoji/2C3.gif', 'std.2C3', si(null, sprite, 18, 18, 36, 234)],
          ['emoji/2C4.gif', 'std.2C4', si(null, sprite, 18, 18, 36, 72)],
          ['emoji/2C5.gif', 'std.2C5', si(null, sprite, 18, 18, 54, 54)],
          ['emoji/2C6.gif', 'std.2C6'],
          ['emoji/2C7.gif', 'std.2C7'],
          ['emoji/2C8.gif', 'std.2C8'],
          ['emoji/2C9.gif', 'std.2C9'],
          ['emoji/2CA.gif', 'std.2CA'],
          ['emoji/2CB.gif', 'std.2CB'],
          ['emoji/2CC.gif', 'std.2CC'],
          ['emoji/2CD.gif', 'std.2CD'],
          ['emoji/2CE.gif', 'std.2CE']
          ]];

  // This group contains a mix of sprited emoji via css, sprited emoji via
  // metadata, and non-sprited emoji.
  var spritedEmoji2 = [
      'Emoji 1',
      [
          ['emoji/200.gif', 'std.200', si('SPRITE_200')],
          ['emoji/201.gif', 'std.201', si('SPRITE_201')],
          ['emoji/202.gif', 'std.202', si('SPRITE_202')],
          ['emoji/203.gif', 'std.203', si('SPRITE_203')],
          ['emoji/204.gif', 'std.204', si('SPRITE_204')],
          ['emoji/205.gif', 'std.205', si('SPRITE_205')],
          ['emoji/206.gif', 'std.206', si('SPRITE_206')],
          ['emoji/2BC.gif', 'std.2BC', si('SPRITE_2BC')],
          ['emoji/2BD.gif', 'std.2BD', si('SPRITE_2BD')],
          ['emoji/2BE.gif', 'std.2BE', si(null, sprite, 18, 18, 36, 54)],
          ['emoji/2BF.gif', 'std.2BF', si(null, sprite, 18, 18, 0, 126)],
          ['emoji/2C0.gif', 'std.2C0', si(null, sprite, 18, 18, 18, 305)],
          ['emoji/2C1.gif', 'std.2C1', si(null, sprite, 18, 18, 0, 287)],
          ['emoji/2C2.gif', 'std.2C2', si(null, sprite, 18, 18, 18, 126)],
          ['emoji/2C3.gif', 'std.2C3', si(null, sprite, 18, 18, 36, 234)],
          ['emoji/2C4.gif', 'std.2C4', si(null, sprite, 18, 18, 36, 72)],
          ['emoji/2C5.gif', 'std.2C5', si(null, sprite, 18, 18, 54, 54)],
          ['emoji/2C6.gif', 'std.2C6'],
          ['emoji/2C7.gif', 'std.2C7'],
          ['emoji/2C8.gif', 'std.2C8'],
          ['emoji/2C9.gif', 'std.2C9'],
          ['emoji/2CA.gif', 'std.2CA', si(null, sprite2, 18, 20, 36, 72, 1)],
          ['emoji/2E3.gif', 'std.2E3', si(null, sprite2, 18, 18, 0, 0, 1)],
          ['emoji/2EF.gif', 'std.2EF', si(null, sprite2, 18, 20, 0, 300, 1)],
          ['emoji/2F1.gif', 'std.2F1', si(null, sprite2, 18, 18, 0, 320, 1)]
          ]];

  var emojiGroups = [emojiGroup1, emojiGroup2, emojiGroup3]
  var defaultImgUrl = 'emoji/none.gif';

  // Handles clicking on an emoji.
  function onEmojiSelected(e) {
    var text = goog.dom.getElement('text');
    var emoji = this.getSelectedEmoji();
    text.value = text.value + '<img src="' + emoji.getUrl() + '" goomoji="' +
        emoji.getId() + '">\n';
  }

  /**
   * Creates a new emoji picker according to the desired specifications.
   *
   * @param {boolean} popup Whether the emojipicker should be a popup.
   * @param {Array.<Object>} emojiGroups Emoji groups to add to the picker.
   * @param {string} defaultImgUrl URL of the default image for the picker.
   * @param {string} elementId Id of the element to attach the popup picker to,
   *     or to append the docked picker to.
   * @param {boolean=} opt_delayedLoad Whether the emojipicker should use
   *     delayed image loading.
   * @param {number=} opt_numRows Optional number of rows to specify for the
   *     emojipicker's palette.
   * @param {number=} opt_numCols Optional number of columns to specify for the
   *     emojipicker's palette.
   * @param {boolean=} opt_progressiveRender Whether to render the sprited
   *     emojipicker progressively.
   * @return {goog.ui.emoji.EmojiPicker|goog.ui.emoji.PopupEmojiPicker} The
   *     constructed and rendered emojipicker.
   */
  function createEmojiPicker(popup, emojiGroups, defaultImgUrl, elementId,
                             opt_delayedLoad, opt_numRows, opt_numCols,
                             opt_progressiveRender) {
    var picker = popup ? new goog.ui.emoji.PopupEmojiPicker(defaultImgUrl) :
                 new goog.ui.emoji.EmojiPicker(defaultImgUrl);
    for (var i = 0; i < emojiGroups.length; i++) {
      picker.addEmojiGroup(emojiGroups[i][0], emojiGroups[i][1]);
    }
    if (!popup) {
      picker.setTabLocation(goog.ui.TabPane.TabLocation.BOTTOM);
    }
    if (opt_delayedLoad) {
      picker.setDelayedLoad(opt_delayedLoad);
    }
    if (opt_numRows) {
      picker.setNumRows(opt_numRows);
    }
    if (opt_numCols) {
      picker.setNumColumns(opt_numCols);
    }
    if (opt_progressiveRender) {
      picker.setProgressiveRender(true);
    }
    picker.render();
    var elem = document.getElementById(elementId);
    if (popup) {
      picker.attach(elem);
    } else {
      elem.appendChild(picker.getElement());
    }
    goog.events.listen(
        picker, goog.ui.Component.EventType.ACTION, onEmojiSelected);
    return picker;
  }

  // Normal popup non-delayed load emojipicker.
  createEmojiPicker(true, emojiGroups, defaultImgUrl, 'button1');

  // Docked non-delayed load emojipicker.
  createEmojiPicker(false, emojiGroups, defaultImgUrl, 'emojiDock', false,
      3, 20);

  // Single page non-delayed load emojipicker.
  createEmojiPicker(false, [emojiGroup1], defaultImgUrl,
      'singlePageEmojiPicker');

  // Delayed load popup emojipicker.
  var delayedPopupPicker = createEmojiPicker(true, emojiGroups, defaultImgUrl,
      'button2', true);
  delayedPopupPicker.loadImages();

  // Delayed load single page docked picker. Loaded by clicking on a button.
  var delayedSinglePagePicker = createEmojiPicker(false, [emojiGroup1],
      defaultImgUrl, 'delayedLoadDock', true);

  // Non-delayed load sprited docked picker.
  var spritedDockedPicker = createEmojiPicker(false, [spritedEmoji1],
      defaultImgUrl, 'spriteDock1', false, 3, 6);

  // Non-delayed load sprited docked picker.
  var spritedDockedPicker2 = createEmojiPicker(false, [spritedEmoji1],
      defaultImgUrl, 'spriteDock2', false, 2, 10, true);

  // Fast-loading progressive sprited docked picker.
  var fastLoadPicker1 = createEmojiPicker(false, [spritedEmoji2],
      defaultImgUrl, 'fastLoad1', false, 2, 10, true);

  // Fast-loading non-progressive sprited docked picker.
  var fastLoadPicker2 = createEmojiPicker(false, [spritedEmoji2],
      defaultImgUrl, 'fastLoad2', false, 2, 10, false);

  function loadPicker() {
    goog.style.setStyle(document.getElementById('delayedLoadDockDiv'),
                        'display',
                        'none');
    delayedSinglePagePicker.loadImages();
    goog.dom.classlist.add(delayedSinglePagePicker.getElement(),
                        'goog-ui-emojipicker');
  }
</script>
</body>
</html>