chromium/third_party/google-closure-library/closure/goog/demos/filedrophandler.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>goog.events.FileDropHandler Demo</title>
  <script src="../base.js"></script>
  <script>
    goog.require('goog.debug.DivConsole');
    goog.require('goog.dom');
    goog.require('goog.events.FileDropHandler');
    goog.require('goog.log');
  </script>
  <link rel="stylesheet" href="css/demo.css">
</head>
<body>
  <h2>Demo of goog.events.FileDropHandler</h2>

  <fieldset>
    <legend>Demo of the <strong>goog.events.FileDropHandler</strong>:</legend>
    <label>goog.events.FileDropHandler detects file drag and drop events in
    elements. Try dropping a file in the textarea below and watch the event
    log at the bottom of the page. Try dropping some text too.<br></label>
    <textarea id="drop-zone" rows="5" cols="50"></textarea>
  </fieldset>

  <fieldset class="goog-debug-panel">
    <legend>Event Log</legend>
    <div id="log" style="height: 400px;"></div>
  </fieldset>

  <script>
    var dropZone = goog.dom.getElement('drop-zone');
    var handler = new goog.events.FileDropHandler(dropZone, true);
    var logger = goog.log.getLogger('demo');

    goog.events.listen(handler, goog.events.FileDropHandler.EventType.DROP,
        function(e) {
          goog.log.log(logger, goog.log.Level.SHOUT, 'DROP event detected!');
          goog.log.info(logger, 'dataTransfer:\n' +
              goog.debug.deepExpose(e.getBrowserEvent().dataTransfer));
          var files = e.getBrowserEvent().dataTransfer.files;
          for (var i = 0; i < files.length; i++) {
            // If you want to access the filename you should try both
            // alternatives.
            var file = files[i];
            var fileName = file.name || file.fileName;
            goog.log.info(logger, 'File name: ' + fileName);
            // Sample code to upload the dropped files (commented out).
            // var xhr = goog.net.XmlHttp();
            // xhr.open('POST', 'http://www.myserver.com/upload');
            // xhr.send(file);
          }
        });

    goog.log.setLevel(goog.log.getRootLogger(), goog.log.Level.FINER);
    var logconsole = new goog.debug.DivConsole(goog.dom.getElement('log'));
    logconsole.setCapturing(true);
  </script>
</body>
</html>