Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 | 2x 2x 2x 2x 2x 7x 7x 7x 7x 7x 7x 2x 19x 19x 19x 19x 2x 7x 7x 7x 2x 5x 5x 5x 2x 7x 7x 7x 7x 7x 2x 26x 26x 26x 19x 19x 19x 7x 2x 2x 19x 19x 2x | /* Copyright 2009 University of Toronto Copyright 2009 University of California, Berkeley Copyright 2010-2011 OCAD University Copyright 2011 Lucendo Development Ltd. Copyright 2013 Raising the Floor - US Copyright 2015 Raising the Floor - International Licensed under the Educational Community License (ECL), Version 2.0 or the New BSD license. You may not use this file except in compliance with one these Licenses. You may obtain a copy of the ECL 2.0 License and BSD License at https://github.com/fluid-project/infusion/raw/master/Infusion-LICENSE.txt */ var fluid_3_0_0 = fluid_3_0_0 || {}; (function ($, fluid) { "use strict"; fluid.registerNamespace("fluid.uploader.demo"); fluid.defaults("fluid.uploader.demo", { distributeOptions: { record: "fluid.uploader.demo.remote", target: "{that strategy remote}.type" } }); fluid.uploader.demo.uploadNextFile = function (that) { // Reset our upload stats for each new file. that.demoState.currentFile = that.queue.files[that.demoState.fileIdx]; that.demoState.chunksForCurrentFile = Math.ceil(that.demoState.currentFile / that.demoState.chunkSize); that.demoState.bytesUploaded = 0; that.queue.isUploading = true; that.events.onFileStart.fire(that.demoState.currentFile); fluid.uploader.demo.simulateUpload(that); }; fluid.uploader.demo.updateProgress = function (file, events, demoState, isUploading) { Iif (!isUploading) { return; } var chunk = Math.min(demoState.chunkSize, file.size); demoState.bytesUploaded = Math.min(demoState.bytesUploaded + chunk, file.size); events.onFileProgress.fire(file, demoState.bytesUploaded, file.size); }; fluid.uploader.demo.finishAndContinueOrCleanup = function (that, file) { // TODO: it appears that this duplicates handlers in Uploader.js onFileComplete - // which this component does not fire that.queue.finishFile(file); that.events.afterFileComplete.fire(file); if (that.queue.shouldUploadNextFile()) { fluid.uploader.demo.uploadNextFile(that); } else { that.events.afterUploadComplete.fire(that.queue.currentBatch.files); Eif (file.status !== fluid.uploader.fileStatusConstants.CANCELLED) { that.queue.clearCurrentBatch(); // Only clear the current batch if we're actually done the batch. } } }; fluid.uploader.demo.finishUploading = function (that) { Iif (!that.queue.isUploading) { return; } var file = that.demoState.currentFile; that.events.onFileSuccess.fire(file); that.demoState.fileIdx++; fluid.uploader.demo.finishAndContinueOrCleanup(that, file); }; fluid.uploader.demo.simulateUpload = function (that) { Iif (!that.queue.isUploading) { return; } var file = that.demoState.currentFile; if (that.demoState.bytesUploaded < file.size) { fluid.invokeAfterRandomDelay(function () { fluid.uploader.demo.updateProgress(file, that.events, that.demoState, that.queue.isUploading); fluid.uploader.demo.simulateUpload(that); }); } else { fluid.uploader.demo.finishUploading(that); } }; fluid.uploader.demo.stop = function (that) { var file = that.demoState.currentFile; file.filestatus = fluid.uploader.fileStatusConstants.CANCELLED; that.queue.shouldStop = true; // Legacy from the SWFUpload implementation, where pausing is a combination of an UPLOAD_STOPPED error and a complete. that.events.onFileError.fire(file, fluid.uploader.errorConstants.UPLOAD_STOPPED, "The demo upload was paused by the user."); fluid.uploader.demo.finishAndContinueOrCleanup(that, file); that.events.onUploadStop.fire(); }; /** * Invokes a function after a random delay by using setTimeout. * @param {Function} fn - the function to invoke */ fluid.invokeAfterRandomDelay = function (fn) { var delay = Math.floor(Math.random() * 200 + 100); setTimeout(fn, delay); }; /** * The demo remote pretends to upload files to the server, firing all the appropriate events * but without sending anything over the network or requiring a server to be running. * * @param {Object} configuration options */ fluid.defaults("fluid.uploader.demo.remote", { gradeNames: ["fluid.uploader.remote"], members: { demoState: { fileIdx: 0, chunkSize: 200000 } }, invokers: { uploadNextFile: { funcName: "fluid.uploader.demo.uploadNextFile", args: "{that}" }, stop: { funcName: "fluid.uploader.demo.stop", args: "{that}" } } }); })(jQuery, fluid_3_0_0); |