src/cm/media/js/lib/yui/yui_3.10.3/docs/uploader/uploader-dd.html
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 525 89ef5ed3c48b
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
525
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     1
<!DOCTYPE html>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     2
<html lang="en">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     3
<head>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     4
    <meta charset="utf-8">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     5
    <title>Example: Multiple Files Uploader with HTML5 Drag-and-Drop Support</title>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     6
    <link rel="stylesheet" href="http://fonts.googleapis.com/css?family=PT+Sans:400,700,400italic,700italic">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     7
    <link rel="stylesheet" href="../../build/cssgrids/cssgrids-min.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     8
    <link rel="stylesheet" href="../assets/css/main.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     9
    <link rel="stylesheet" href="../assets/vendor/prettify/prettify-min.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    10
    <link rel="shortcut icon" type="image/png" href="../assets/favicon.png">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    11
    <script src="../../build/yui/yui-min.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
</head>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
<body>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    15
<!--
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    16
<a href="https://github.com/yui/yui3"><img style="position: absolute; top: 0; right: 0; border: 0;" src="https://s3.amazonaws.com/github/ribbons/forkme_right_darkblue_121621.png" alt="Fork me on GitHub"></a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    17
-->
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
<div id="doc">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
    <div id="hd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
        <h1><img src="http://yuilibrary.com/img/yui-logo.png"></h1>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
            <h1>Example: Multiple Files Uploader with HTML5 Drag-and-Drop Support</h1>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
    <div class="yui3-g">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
        <div class="yui3-u-3-4">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
            <div id="main">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
                <div class="content"><div class="intro">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
<p>In this example, the Uploader is used to send multiple images or videos to the server and monitor
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
   their upload progress with individual counters. If the Uploader is used in a browser with HTML5
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
   support, it is progressively enhanced to enable dragging-and-dropping files into the browser window.</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
   
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
<p><strong>Please note:</strong> This example will not work when run from a local filesystem because of security restrictions in the transport protocols used. If you’d like to run this example locally, set up a local web server and launch it from there.</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
<p><strong>Also note:</strong> The uploader is not supported on iOS devices (iPhone and iPad), because they lack file upload capability. This example provides a graceful degradation message for all such systems.</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
<p><strong>Also note:</strong> The backend script used in these examples does not store any information it receives. Nevertheless, do not submit any sensitive or private data and keep
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
your tests to a few small files to avoid overloading the system.</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
<div class="example yui3-skin-sam">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
    <style>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
#filelist {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
    margin-top: 15px;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
#uploadFilesButtonContainer, #selectFilesButtonContainer, #overallProgress {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
    display: inline-block;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
#overallProgress {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
    float: right;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
.yellowBackground {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
  background: #F2E699;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
</style>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
<div id="exampleContainer">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
<div id="uploaderContainer">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
    <div id="selectFilesButtonContainer">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
    <div id="uploadFilesButtonContainer">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
      <button type="button" id="uploadFilesButton"
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
              class="yui3-button" style="width:250px; height:35px;">Upload Files</button>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
    <div id="overallProgress">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    69
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    70
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    71
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
<div id="filelist">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
  <table id="filenames">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
    <thead>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
       <tr><th>File name</th><th>File size</th><th>Percent uploaded</th></tr>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
       <tr id="nofiles">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
        <td colspan="3" id="ddmessage">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
            <strong>No files selected.</strong>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
        </td>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
       </tr>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
    </thead>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
    <tbody>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
    </tbody>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
  </table>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
<script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
YUI({filter:"raw"}).use("uploader", function(Y) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
Y.one("#overallProgress").set("text", "Uploader type: " + Y.Uploader.TYPE);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    92
   if (Y.Uploader.TYPE != "none" && !Y.UA.ios) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
       var uploader = new Y.Uploader({width: "250px",
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
                                      height: "35px",
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
                                      multipleFiles: true,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
                                      swfURL: "../../build/uploader/assets/flashuploader.swf?t=" + Math.random(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
                                      uploadURL: "http://yuilibrary.com/sandbox/upload/",
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
                                      simLimit: 2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
                                      withCredentials: false
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
                                     });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
       var uploadDone = false;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
       if (Y.Uploader.TYPE == "html5") {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
          uploader.set("dragAndDropArea", "body");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   106
          Y.one("#ddmessage").setHTML("<strong>Drag and drop files here.</strong>");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
          uploader.on(["dragenter", "dragover"], function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
              var ddmessage = Y.one("#ddmessage");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   110
              if (ddmessage) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   111
                ddmessage.setHTML("<strong>Files detected, drop them here!</strong>");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   112
                ddmessage.addClass("yellowBackground");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
              }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
           });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
           uploader.on(["dragleave", "drop"], function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
              var ddmessage = Y.one("#ddmessage");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
              if (ddmessage) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
                ddmessage.setHTML("<strong>Drag and drop files here.</strong>");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
                ddmessage.removeClass("yellowBackground");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
              }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   122
           });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   123
       }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   124
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   125
       uploader.render("#selectFilesButtonContainer");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
       uploader.after("fileselect", function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   128
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   129
          var fileList = event.fileList;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   130
          var fileTable = Y.one("#filenames tbody");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
          if (fileList.length > 0 && Y.one("#nofiles")) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
            Y.one("#nofiles").remove();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
          }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
          if (uploadDone) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
            uploadDone = false;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
            fileTable.setHTML("");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   138
          }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
          Y.each(fileList, function (fileInstance) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
              fileTable.append("<tr id='" + fileInstance.get("id") + "_row" + "'>" +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
                                    "<td class='filename'>" + fileInstance.get("name") + "</td>" +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
                                    "<td class='filesize'>" + fileInstance.get("size") + "</td>" +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
                                    "<td class='percentdone'>Hasn't started yet</td>");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
                             });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
       uploader.on("uploadprogress", function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
            var fileRow = Y.one("#" + event.file.get("id") + "_row");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
                fileRow.one(".percentdone").set("text", event.percentLoaded + "%");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   153
       uploader.on("uploadstart", function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
            uploader.set("enabled", false);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
            Y.one("#uploadFilesButton").addClass("yui3-button-disabled");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
            Y.one("#uploadFilesButton").detach("click");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
       uploader.on("uploadcomplete", function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
            var fileRow = Y.one("#" + event.file.get("id") + "_row");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
                fileRow.one(".percentdone").set("text", "Finished!");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
       uploader.on("totaluploadprogress", function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
                Y.one("#overallProgress").setHTML("Total uploaded: <strong>" +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
                                                     event.percentLoaded + "%" +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   167
                                                     "</strong>");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   168
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   169
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
       uploader.on("alluploadscomplete", function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   171
                     uploader.set("enabled", true);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   172
                     uploader.set("fileList", []);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   173
                     Y.one("#uploadFilesButton").removeClass("yui3-button-disabled");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   174
                     Y.one("#uploadFilesButton").on("click", function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   175
                          if (!uploadDone && uploader.get("fileList").length > 0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   176
                             uploader.uploadAll();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   177
                          }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   178
                     });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   179
                     Y.one("#overallProgress").set("text", "Uploads complete!");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   180
                     uploadDone = true;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   181
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   182
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   183
       Y.one("#uploadFilesButton").on("click", function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   184
         if (!uploadDone && uploader.get("fileList").length > 0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   185
            uploader.uploadAll();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   186
         }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   187
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   188
   }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   189
   else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   190
       Y.one("#uploaderContainer").set("text", "We are sorry, but to use the uploader, you either need a browser that support HTML5 or have the Flash player installed on your computer.");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   191
   }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   192
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   193
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   194
});
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   195
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   196
</script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   197
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   198
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   199
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   200
<h2>Progressive Enhancement with a Drag-and-Drop Area</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   201
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   202
<p>The base functionality in this example is the same as in the <a href="uploader-multiple.html">Simple Multiple Files Uploader</a>, but we are conditionally adding support for a
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   203
   drag-and-drop area for cases where the HTML5 uploader is being used:<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   204
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   205
<pre class="code prettyprint">if (Y.Uploader.TYPE == &quot;html5&quot;) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   206
   uploader.set(&quot;dragAndDropArea&quot;, &quot;body&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   207
   Y.one(&quot;#ddmessage&quot;).setHTML(&quot;&lt;strong&gt;Drag and drop files here.&lt;&#x2F;strong&gt;&quot;);   
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   208
 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   209
   uploader.on([&quot;dragenter&quot;, &quot;dragover&quot;], function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   210
       var ddmessage = Y.one(&quot;#ddmessage&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   211
       if (ddmessage) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   212
         ddmessage.setHTML(&quot;&lt;strong&gt;Files detected, drop them here!&lt;&#x2F;strong&gt;&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   213
         ddmessage.addClass(&quot;yellowBackground&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   214
       }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   215
    });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   216
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   217
    uploader.on([&quot;dragleave&quot;, &quot;drop&quot;], function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   218
       var ddmessage = Y.one(&quot;#ddmessage&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   219
       if (ddmessage) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   220
         ddmessage.setHTML(&quot;&lt;strong&gt;Drag and drop files here.&lt;&#x2F;strong&gt;&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   221
         ddmessage.removeClass(&quot;yellowBackground&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   222
       }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   223
    });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   224
}</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   225
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   226
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   227
<p>Note that we are setting the entire page <code>&lt;body&gt;</code> as the drag-and-drop area, so the user can drop the files anywhere onto the page. We also add a visual response to the files
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   228
   being dragged over the page by listening to the <code>dragenter</code>, <code>dragover</code>, <code>dragleave</code> and <code>drop</code> events.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   229
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   230
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   231
<h2>Full Source Code For this Example</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   232
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   233
<pre class="code prettyprint">&lt;style&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   234
#filelist {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   235
    margin-top: 15px;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   236
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   237
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   238
#uploadFilesButtonContainer, #selectFilesButtonContainer, #overallProgress {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   239
    display: inline-block;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   240
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   241
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   242
#overallProgress {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   243
    float: right;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   244
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   245
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   246
.yellowBackground {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   247
  background: #F2E699;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   248
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   249
&lt;&#x2F;style&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   250
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   251
&lt;div id=&quot;exampleContainer&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   252
&lt;div id=&quot;uploaderContainer&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   253
    &lt;div id=&quot;selectFilesButtonContainer&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   254
    &lt;&#x2F;div&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   255
    &lt;div id=&quot;uploadFilesButtonContainer&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   256
      &lt;button type=&quot;button&quot; id=&quot;uploadFilesButton&quot;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   257
              class=&quot;yui3-button&quot; style=&quot;width:250px; height:35px;&quot;&gt;Upload Files&lt;&#x2F;button&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   258
    &lt;&#x2F;div&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   259
    &lt;div id=&quot;overallProgress&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   260
    &lt;&#x2F;div&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   261
&lt;&#x2F;div&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   262
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   263
&lt;div id=&quot;filelist&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   264
  &lt;table id=&quot;filenames&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   265
    &lt;thead&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   266
       &lt;tr&gt;&lt;th&gt;File name&lt;&#x2F;th&gt;&lt;th&gt;File size&lt;&#x2F;th&gt;&lt;th&gt;Percent uploaded&lt;&#x2F;th&gt;&lt;&#x2F;tr&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   267
       &lt;tr id=&quot;nofiles&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   268
        &lt;td colspan=&quot;3&quot; id=&quot;ddmessage&quot;&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   269
            &lt;strong&gt;No files selected.&lt;&#x2F;strong&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   270
        &lt;&#x2F;td&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   271
       &lt;&#x2F;tr&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   272
    &lt;&#x2F;thead&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   273
    &lt;tbody&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   274
    &lt;&#x2F;tbody&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   275
  &lt;&#x2F;table&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   276
&lt;&#x2F;div&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   277
&lt;&#x2F;div&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   278
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   279
&lt;script&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   280
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   281
YUI({filter:&quot;raw&quot;}).use(&quot;uploader&quot;, function(Y) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   282
Y.one(&quot;#overallProgress&quot;).set(&quot;text&quot;, &quot;Uploader type: &quot; + Y.Uploader.TYPE);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   283
   if (Y.Uploader.TYPE != &quot;none&quot; &amp;&amp; !Y.UA.ios) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   284
       var uploader = new Y.Uploader({width: &quot;250px&quot;,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   285
                                      height: &quot;35px&quot;,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   286
                                      multipleFiles: true,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   287
                                      swfURL: &quot;..&#x2F;..&#x2F;build&#x2F;uploader&#x2F;assets&#x2F;flashuploader.swf?t=&quot; + Math.random(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   288
                                      uploadURL: &quot;http:&#x2F;&#x2F;yuilibrary.com&#x2F;sandbox&#x2F;upload&#x2F;&quot;,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   289
                                      simLimit: 2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   290
                                      withCredentials: false
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   291
                                     });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   292
       var uploadDone = false;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   293
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   294
       if (Y.Uploader.TYPE == &quot;html5&quot;) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   295
          uploader.set(&quot;dragAndDropArea&quot;, &quot;body&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   296
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   297
          Y.one(&quot;#ddmessage&quot;).setHTML(&quot;&lt;strong&gt;Drag and drop files here.&lt;&#x2F;strong&gt;&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   298
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   299
          uploader.on([&quot;dragenter&quot;, &quot;dragover&quot;], function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   300
              var ddmessage = Y.one(&quot;#ddmessage&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   301
              if (ddmessage) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   302
                ddmessage.setHTML(&quot;&lt;strong&gt;Files detected, drop them here!&lt;&#x2F;strong&gt;&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   303
                ddmessage.addClass(&quot;yellowBackground&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   304
              }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   305
           });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   306
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   307
           uploader.on([&quot;dragleave&quot;, &quot;drop&quot;], function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   308
              var ddmessage = Y.one(&quot;#ddmessage&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   309
              if (ddmessage) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   310
                ddmessage.setHTML(&quot;&lt;strong&gt;Drag and drop files here.&lt;&#x2F;strong&gt;&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   311
                ddmessage.removeClass(&quot;yellowBackground&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   312
              }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   313
           });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   314
       }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   315
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   316
       uploader.render(&quot;#selectFilesButtonContainer&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   317
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   318
       uploader.after(&quot;fileselect&quot;, function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   319
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   320
          var fileList = event.fileList;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   321
          var fileTable = Y.one(&quot;#filenames tbody&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   322
          if (fileList.length &gt; 0 &amp;&amp; Y.one(&quot;#nofiles&quot;)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   323
            Y.one(&quot;#nofiles&quot;).remove();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   324
          }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   325
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   326
          if (uploadDone) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   327
            uploadDone = false;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   328
            fileTable.setHTML(&quot;&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   329
          }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   330
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   331
          Y.each(fileList, function (fileInstance) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   332
              fileTable.append(&quot;&lt;tr id=&#x27;&quot; + fileInstance.get(&quot;id&quot;) + &quot;_row&quot; + &quot;&#x27;&gt;&quot; +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   333
                                    &quot;&lt;td class=&#x27;filename&#x27;&gt;&quot; + fileInstance.get(&quot;name&quot;) + &quot;&lt;&#x2F;td&gt;&quot; +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   334
                                    &quot;&lt;td class=&#x27;filesize&#x27;&gt;&quot; + fileInstance.get(&quot;size&quot;) + &quot;&lt;&#x2F;td&gt;&quot; +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   335
                                    &quot;&lt;td class=&#x27;percentdone&#x27;&gt;Hasn&#x27;t started yet&lt;&#x2F;td&gt;&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   336
                             });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   337
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   338
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   339
       uploader.on(&quot;uploadprogress&quot;, function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   340
            var fileRow = Y.one(&quot;#&quot; + event.file.get(&quot;id&quot;) + &quot;_row&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   341
                fileRow.one(&quot;.percentdone&quot;).set(&quot;text&quot;, event.percentLoaded + &quot;%&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   342
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   343
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   344
       uploader.on(&quot;uploadstart&quot;, function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   345
            uploader.set(&quot;enabled&quot;, false);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   346
            Y.one(&quot;#uploadFilesButton&quot;).addClass(&quot;yui3-button-disabled&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   347
            Y.one(&quot;#uploadFilesButton&quot;).detach(&quot;click&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   348
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   349
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   350
       uploader.on(&quot;uploadcomplete&quot;, function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   351
            var fileRow = Y.one(&quot;#&quot; + event.file.get(&quot;id&quot;) + &quot;_row&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   352
                fileRow.one(&quot;.percentdone&quot;).set(&quot;text&quot;, &quot;Finished!&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   353
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   354
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   355
       uploader.on(&quot;totaluploadprogress&quot;, function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   356
                Y.one(&quot;#overallProgress&quot;).setHTML(&quot;Total uploaded: &lt;strong&gt;&quot; +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   357
                                                     event.percentLoaded + &quot;%&quot; +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   358
                                                     &quot;&lt;&#x2F;strong&gt;&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   359
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   360
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   361
       uploader.on(&quot;alluploadscomplete&quot;, function (event) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   362
                     uploader.set(&quot;enabled&quot;, true);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   363
                     uploader.set(&quot;fileList&quot;, []);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   364
                     Y.one(&quot;#uploadFilesButton&quot;).removeClass(&quot;yui3-button-disabled&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   365
                     Y.one(&quot;#uploadFilesButton&quot;).on(&quot;click&quot;, function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   366
                          if (!uploadDone &amp;&amp; uploader.get(&quot;fileList&quot;).length &gt; 0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   367
                             uploader.uploadAll();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   368
                          }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   369
                     });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   370
                     Y.one(&quot;#overallProgress&quot;).set(&quot;text&quot;, &quot;Uploads complete!&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   371
                     uploadDone = true;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   372
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   373
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   374
       Y.one(&quot;#uploadFilesButton&quot;).on(&quot;click&quot;, function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   375
         if (!uploadDone &amp;&amp; uploader.get(&quot;fileList&quot;).length &gt; 0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   376
            uploader.uploadAll();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   377
         }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   378
       });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   379
   }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   380
   else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   381
       Y.one(&quot;#uploaderContainer&quot;).set(&quot;text&quot;, &quot;We are sorry, but to use the uploader, you either need a browser that support HTML5 or have the Flash player installed on your computer.&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   382
   }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   383
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   384
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   385
});
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   386
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   387
&lt;&#x2F;script&gt;</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   388
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   389
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   390
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   391
            </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   392
        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   393
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   394
        <div class="yui3-u-1-4">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   395
            <div class="sidebar">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   396
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   397
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   398
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   399
                    <div class="sidebox">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   400
                        <div class="hd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   401
                            <h2 class="no-toc">Examples</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   402
                        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   403
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   404
                        <div class="bd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   405
                            <ul class="examples">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   406
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   407
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   408
                                        <li data-description="A simple multiple file uploader with progress tracking">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   409
                                            <a href="uploader-multiple.html">Simple Multiple Files Uploader with Progress Tracking</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   410
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   411
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   412
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   413
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   414
                                        <li data-description="A multiple file uploader with HTML5 Drag-and-Drop Support">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   415
                                            <a href="uploader-dd.html">Multiple Files Uploader with HTML5 Drag-and-Drop Support</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   416
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   417
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   418
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   419
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   420
                                        <li data-description="A multiple file uploader that submits additional POST vars with each file and receives data from the server">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   421
                                            <a href="uploader-data.html">Multiple Files Uploader with POST Variables and Server Data Retrieval</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   422
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   423
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   424
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   425
                            </ul>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   426
                        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   427
                    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   428
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   429
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   430
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   431
            </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   432
        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   433
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   434
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   435
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   436
<script src="../assets/vendor/prettify/prettify-min.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   437
<script>prettyPrint();</script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   438
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   439
<script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   440
YUI.Env.Tests = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   441
    examples: [],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   442
    project: '../assets',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   443
    assets: '../assets/uploader',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   444
    name: 'uploader-dd',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   445
    title: 'Multiple Files Uploader with HTML5 Drag-and-Drop Support',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   446
    newWindow: '',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   447
    auto:  false 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   448
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   449
YUI.Env.Tests.examples.push('uploader-multiple');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   450
YUI.Env.Tests.examples.push('uploader-dd');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   451
YUI.Env.Tests.examples.push('uploader-data');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   452
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   453
</script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   454
<script src="../assets/yui/test-runner.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   455
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   456
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   457
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   458
</body>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   459
</html>