mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-17 15:03:25 +00:00
Fix #862 Upload multiple IE
This commit is contained in:
@@ -55,6 +55,20 @@ class Upload implements ControllerProviderInterface
|
|||||||
$controllers->get('/', $this->call('getUploadForm'))
|
$controllers->get('/', $this->call('getUploadForm'))
|
||||||
->bind('upload_form');
|
->bind('upload_form');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flash upload form route
|
||||||
|
*
|
||||||
|
* name : upload_flash_form
|
||||||
|
*
|
||||||
|
* description : Render the html flash upload form
|
||||||
|
*
|
||||||
|
* method : GET
|
||||||
|
*
|
||||||
|
* return : HTML Response
|
||||||
|
*/
|
||||||
|
$controllers->get('/flash-version/', $this->call('getFlashUploadForm'))
|
||||||
|
->bind('upload_flash_form');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* UPLOAD route
|
* UPLOAD route
|
||||||
*
|
*
|
||||||
@@ -79,6 +93,28 @@ class Upload implements ControllerProviderInterface
|
|||||||
return $controllers;
|
return $controllers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Render the flash upload form
|
||||||
|
*
|
||||||
|
* @param Application $app A Silex application
|
||||||
|
* @param Request $request The current request
|
||||||
|
*
|
||||||
|
* @return Response
|
||||||
|
*/
|
||||||
|
public function getFlashUploadForm(Application $app, Request $request)
|
||||||
|
{
|
||||||
|
$maxFileSize = $this->getUploadMaxFileSize();
|
||||||
|
|
||||||
|
return $app['Core']['Twig']->render(
|
||||||
|
'prod/upload/upload-flash.html.twig', array(
|
||||||
|
'sessionId' => session_id(),
|
||||||
|
'collections' => $this->getGrantedCollections($app['Core']->getAuthenticatedUser()),
|
||||||
|
'maxFileSize' => $maxFileSize,
|
||||||
|
'maxFileSizeReadable' => \p4string::format_octets($maxFileSize)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Render the html upload form
|
* Render the html upload form
|
||||||
*
|
*
|
||||||
@@ -89,44 +125,14 @@ class Upload implements ControllerProviderInterface
|
|||||||
*/
|
*/
|
||||||
public function getUploadForm(Application $app, Request $request)
|
public function getUploadForm(Application $app, Request $request)
|
||||||
{
|
{
|
||||||
$collections = array();
|
$maxFileSize = $this->getUploadMaxFileSize();
|
||||||
$rights = array('canaddrecord');
|
|
||||||
|
|
||||||
foreach ($app['Core']->getAuthenticatedUser()->ACL()->get_granted_base($rights) as $collection) {
|
return $app['Core']['Twig']->render(
|
||||||
$databox = $collection->get_databox();
|
'prod/upload/upload.html.twig', array(
|
||||||
if ( ! isset($collections[$databox->get_sbas_id()])) {
|
'collections' => $this->getGrantedCollections($app['Core']->getAuthenticatedUser()),
|
||||||
$collections[$databox->get_sbas_id()] = array(
|
'maxFileSize' => $maxFileSize,
|
||||||
'databox' => $databox,
|
'maxFileSizeReadable' => \p4string::format_octets($maxFileSize)
|
||||||
'databox_collections' => array()
|
)
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$collections[$databox->get_sbas_id()]['databox_collections'][] = $collection;
|
|
||||||
}
|
|
||||||
|
|
||||||
$postMaxSize = trim(ini_get('post_max_size'));
|
|
||||||
|
|
||||||
if ('' === $postMaxSize) {
|
|
||||||
$postMaxSize = PHP_INT_MAX;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (strtolower(substr($postMaxSize, -1))) {
|
|
||||||
case 'g':
|
|
||||||
$postMaxSize *= 1024;
|
|
||||||
case 'm':
|
|
||||||
$postMaxSize *= 1024;
|
|
||||||
case 'k':
|
|
||||||
$postMaxSize *= 1024;
|
|
||||||
}
|
|
||||||
|
|
||||||
$maxFileSize = min(UploadedFile::getMaxFilesize(), (int) $postMaxSize);
|
|
||||||
|
|
||||||
$html = $app['Core']['Twig']->render(
|
|
||||||
'prod/upload/upload.html.twig', array(
|
|
||||||
'collections' => $collections,
|
|
||||||
'maxFileSize' => $maxFileSize,
|
|
||||||
'maxFileSizeReadable' => \p4string::format_octets($maxFileSize)
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
return new Response($html);
|
return new Response($html);
|
||||||
@@ -151,7 +157,7 @@ class Upload implements ControllerProviderInterface
|
|||||||
'id' => '',
|
'id' => '',
|
||||||
);
|
);
|
||||||
|
|
||||||
if ( ! $request->files->get('files')) {
|
if (null === $request->files->get('files')) {
|
||||||
throw new \Exception_BadRequest('Missing file parameter');
|
throw new \Exception_BadRequest('Missing file parameter');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -293,4 +299,54 @@ class Upload implements ControllerProviderInterface
|
|||||||
{
|
{
|
||||||
return sprintf('%s::%s', __CLASS__, $method);
|
return sprintf('%s::%s', __CLASS__, $method);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get current user's granted collections where he can upload
|
||||||
|
*
|
||||||
|
* @param \User_Adapter $user
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
private function getGrantedCollections(\User_Adapter $user)
|
||||||
|
{
|
||||||
|
$collections = array();
|
||||||
|
|
||||||
|
foreach ($user->ACL()->get_granted_base(array('canaddrecord')) as $collection) {
|
||||||
|
$databox = $collection->get_databox();
|
||||||
|
if ( ! isset($collections[$databox->get_sbas_id()])) {
|
||||||
|
$collections[$databox->get_sbas_id()] = array(
|
||||||
|
'databox' => $databox,
|
||||||
|
'databox_collections' => array()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$collections[$databox->get_sbas_id()]['databox_collections'][] = $collection;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $collections;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get POST max file size
|
||||||
|
*
|
||||||
|
* @return integer
|
||||||
|
*/
|
||||||
|
private function getUploadMaxFileSize()
|
||||||
|
{
|
||||||
|
$postMaxSize = trim(ini_get('post_max_size'));
|
||||||
|
|
||||||
|
if ('' === $postMaxSize) {
|
||||||
|
$postMaxSize = PHP_INT_MAX;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (strtolower(substr($postMaxSize, -1))) {
|
||||||
|
case 'g':
|
||||||
|
$postMaxSize *= 1024;
|
||||||
|
case 'm':
|
||||||
|
$postMaxSize *= 1024;
|
||||||
|
case 'k':
|
||||||
|
$postMaxSize *= 1024;
|
||||||
|
}
|
||||||
|
|
||||||
|
return min(UploadedFile::getMaxFilesize(), (int) $postMaxSize);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -11,6 +11,7 @@
|
|||||||
require_once __DIR__ . '/../Alchemy/Phrasea/Core.php';
|
require_once __DIR__ . '/../Alchemy/Phrasea/Core.php';
|
||||||
|
|
||||||
use Alchemy\Phrasea\Core;
|
use Alchemy\Phrasea\Core;
|
||||||
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@@ -39,13 +40,22 @@ class bootstrap
|
|||||||
|
|
||||||
static::$core = new Core($env);
|
static::$core = new Core($env);
|
||||||
|
|
||||||
|
$request = Request::createFromGlobals();
|
||||||
|
|
||||||
|
if ( ! ! stripos($request->server->get('HTTP_USER_AGENT'), 'flash') && $request->getRequestUri() === '/prod/upload/') {
|
||||||
|
if (null !== $sessionId = $request->get('php_session_id')) {
|
||||||
|
session_id($sessionId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (static::$core->getConfiguration()->isInstalled()) {
|
if (static::$core->getConfiguration()->isInstalled()) {
|
||||||
static::$core->enableEvents();
|
static::$core->enableEvents();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (\setup::is_installed()) {
|
if (\setup::is_installed()) {
|
||||||
$gatekeeper = \gatekeeper::getInstance(static::$core);
|
$gatekeeper = \gatekeeper::getInstance(static::$core);
|
||||||
$gatekeeper->check_directory();
|
$gatekeeper->check_directory($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
return static::$core;
|
return static::$core;
|
||||||
|
@@ -9,6 +9,8 @@
|
|||||||
* file that was distributed with this source code.
|
* file that was distributed with this source code.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
@@ -71,9 +73,8 @@ class gatekeeper
|
|||||||
*
|
*
|
||||||
* @return Void
|
* @return Void
|
||||||
*/
|
*/
|
||||||
public function check_directory()
|
public function check_directory(Request $request)
|
||||||
{
|
{
|
||||||
$request = \Symfony\Component\HttpFoundation\Request::createFromGlobals();
|
|
||||||
$appbox = appbox::get_instance($this->Core);
|
$appbox = appbox::get_instance($this->Core);
|
||||||
$session = $appbox->get_session();
|
$session = $appbox->get_session();
|
||||||
|
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
<li class="span2">
|
<li class="span2">
|
||||||
<div class="upload-record thumbnail">
|
<div id="{{id}}"class="upload-record thumbnail">
|
||||||
<div class="canva-wrapper"></div>
|
<div class="canva-wrapper"></div>
|
||||||
<div class="caption">
|
<div class="caption">
|
||||||
<p class="name-doc">{{ name }}</p>
|
<p class="name-doc">{{ name }}</p>
|
||||||
|
@@ -1,11 +1,9 @@
|
|||||||
<li class="span2">
|
<li class="span2">
|
||||||
<div class="upload-record thumbnail">
|
<div class="upload-record thumbnail">
|
||||||
|
<p class="name-doc">{{ name }}</p>
|
||||||
|
|
||||||
<div class="alert-error">
|
<div class="alert-error">
|
||||||
<p>{{ error }}</p>
|
<p>{{ error }}</p>
|
||||||
|
|
||||||
<p class="name-doc">{{ name }}</p>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<button type="button" class="remove-element btn btn-inverse btn-mini">{{ language.cancel }}</button>
|
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
<li class="span2 upload-valid">
|
<li class="span2 upload-valid">
|
||||||
<div class="upload-record thumbnail">
|
<div id ="{{ id }}" class="upload-record thumbnail">
|
||||||
<div class="canva-wrapper"></div>
|
<div class="canva-wrapper"></div>
|
||||||
<div class="caption">
|
<div class="caption">
|
||||||
<p class="name-doc">{{ name }}</p>
|
<p class="name-doc">{{ name }}</p>
|
||||||
|
374
templates/web/prod/upload/upload-flash.html.twig
Normal file
374
templates/web/prod/upload/upload-flash.html.twig
Normal file
@@ -0,0 +1,374 @@
|
|||||||
|
<div id="uploadBox">
|
||||||
|
{# jQuery tab wrapper #}
|
||||||
|
<div class="upload-tabs">
|
||||||
|
{# tab nav bar #}
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
<a href="#tab-upload">
|
||||||
|
{% trans 'Upload' %}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
{# template prod/upload/lazaret.html.twig loaded via ajax #}
|
||||||
|
<a href="/prod/lazaret/" title="tab-lazaret">
|
||||||
|
{# <span> </span> element is required for the jQuery loading spinner appears && disappears properly #}
|
||||||
|
{% trans 'Quarantine' %}<span> </span>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
{# upload tab content #}
|
||||||
|
<div id="tab-upload">
|
||||||
|
<form id="fileupload" enctype="multipart/form-data" method="POST" action="/prod/upload/">
|
||||||
|
|
||||||
|
<div id="uploadBoxLeft" class="well ">
|
||||||
|
|
||||||
|
{# <h5 style="margin-top: 10px;">{% trans 'Choose files to add' %} :</h5> #}
|
||||||
|
{# action bar #}
|
||||||
|
<div id="addFileList">
|
||||||
|
<div class="btn-toolbar">
|
||||||
|
<span id="spanSWFUploadButton" class="span2"></span>
|
||||||
|
<br />
|
||||||
|
<span>
|
||||||
|
<a href="/prod/upload/" class="dialog full-dialog" title="{% trans 'Upload' %}"><span class="label label-info"><i>{% trans 'Switch to html5 uploader' %}</i></span></a>
|
||||||
|
</span>
|
||||||
|
<br />
|
||||||
|
<span class="comment">
|
||||||
|
({% trans %} maximum : {{ maxFileSizeReadable }} {% endtrans %})
|
||||||
|
</span>
|
||||||
|
{# <button type="button" class="upload-submitter btn btn-inverse input-medium">{% trans 'Send' %}</button> #}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{# settings box #}
|
||||||
|
<div class='settings-box'>
|
||||||
|
<h5>{% trans 'upload:: Destination (collection) :' %} :</h5>
|
||||||
|
{# collections list #}
|
||||||
|
{% if collections|length > 0 %}
|
||||||
|
<select name="base_id" class="span3" style="margin-left: 10px;">
|
||||||
|
{% for sbasId, availableCollections in collections %}
|
||||||
|
<optgroup label="{{ availableCollections['databox'].get_viewname() }}" class="select-label">
|
||||||
|
{% for collection in availableCollections['databox_collections'] %}
|
||||||
|
<option value="{{ collection.get_base_id() }}" class="select-row">{{ collection.get_name() }}</option>
|
||||||
|
{% endfor %}
|
||||||
|
</optgroup>
|
||||||
|
{% endfor %}
|
||||||
|
</select>
|
||||||
|
{# collections status #}
|
||||||
|
{% for availableCollections in collections %}
|
||||||
|
{% for collection in availableCollections['databox_collections'] %}
|
||||||
|
<div id="status-{{ collection.get_base_id() }}" class='collection-status' style='{{ loop.parent.loop.first and loop.first ? "display:block" :"display:none" }}'>
|
||||||
|
<h5>{% trans 'upload:: Status :' %} :</h5>
|
||||||
|
<table class="status-tab">
|
||||||
|
<tbody>
|
||||||
|
{% for bit, status in availableCollections['databox'].get_statusbits() %}
|
||||||
|
<tr>
|
||||||
|
<td colspan="2">
|
||||||
|
<h6>{{ status['name']|title }}</h6>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td class="status-tab-left">
|
||||||
|
{% if status['img_off'] is not empty %}
|
||||||
|
<img src="{{ status['img_off'] }}" width="16" height="16" />
|
||||||
|
{% endif %}
|
||||||
|
<span>{{ status['labeloff']|default('off') }}</span>
|
||||||
|
<input type="radio" name="status[{{ collection.get_base_id() }}][{{ bit }}]" value="0" checked="checked"/>
|
||||||
|
</td>
|
||||||
|
<td class="status-tab-right">
|
||||||
|
<input type="radio" name="status[{{ collection.get_base_id() }}][{{ bit }}]" value="1" />
|
||||||
|
<span for="labelon">{{ status['labelon']|default('on') }}</span>
|
||||||
|
{% if status['img_on'] is not empty %}
|
||||||
|
<img src="{{ status['img_on'] }}" width="16" height="16" />
|
||||||
|
{% endif %}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
{% endfor %}
|
||||||
|
{% endfor %}
|
||||||
|
{% else %}
|
||||||
|
{% trans 'You can not upload files' %}
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{# upload box #}
|
||||||
|
<div class='upload-box' style="display: none;">
|
||||||
|
<h5>{% trans 'Selected files' %} :</h5>
|
||||||
|
<button type="button" class="clear-queue btn btn-inverse input-medium" style="margin-bottom: 10px;">{% trans 'Clear list' %}</button>
|
||||||
|
<button type="button" class="upload-submitter btn btn-inverse input-medium" style="margin-bottom: 10px;">{% trans 'Send' %}</button>
|
||||||
|
<div class="clear"></div>
|
||||||
|
<div class='upload-box-addedfiles'></div>
|
||||||
|
<div class="clear"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="uploadBoxRight" class="well">
|
||||||
|
<div class='well-small'>
|
||||||
|
<button id="cancel-all" class="btn disabled" type="button" disabled="disabled">
|
||||||
|
{% trans "Cancel all" %}
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
{# download box #}
|
||||||
|
<div class="download-box"></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script type="text/javascript" src="/include/minify/g=uploadflash"></script>
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(document).ready(function(){
|
||||||
|
|
||||||
|
//Upload management
|
||||||
|
var UploaderManager = new p4.UploaderManager({
|
||||||
|
container: $('#uploadBox'),
|
||||||
|
uploadBox: $('#uploadBox .upload-box-addedfiles'),
|
||||||
|
settingsBox: $('#uploadBox .settings-box'),
|
||||||
|
downloadBox: $('#uploadBox .download-box')
|
||||||
|
});
|
||||||
|
|
||||||
|
{# Create tabs #}
|
||||||
|
$(".upload-tabs").tabs({
|
||||||
|
spinner: language.loading + '<img src="/skins/icons/loader404040.gif"/>',
|
||||||
|
ajaxOptions: {
|
||||||
|
success: function( xhr, status, index, anchor ) {
|
||||||
|
var lazaretBox = $("#lazaretBox");
|
||||||
|
|
||||||
|
$('.userTips', lazaretBox).tooltip();
|
||||||
|
},
|
||||||
|
error: function( xhr, status, index, anchor ) {
|
||||||
|
//display error message if ajax failed
|
||||||
|
$( anchor.hash ).html(language.error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
//Show the good collection status box
|
||||||
|
$('select[name="base_id"]', UploaderManager.getSettingsBox()).bind('change', function(){
|
||||||
|
var selectedCollId = $(this).find('option:selected').val();
|
||||||
|
|
||||||
|
$('#uploadBox .settings-box .collection-status').hide();
|
||||||
|
|
||||||
|
$('#uploadBox #status-' + selectedCollId).show();
|
||||||
|
});
|
||||||
|
|
||||||
|
var swfu = new SWFUpload({
|
||||||
|
upload_url : "/prod/upload/",
|
||||||
|
post_params: {"php_session_id" : "{{ sessionId }}"},
|
||||||
|
flash_url : "/include/jslibs/SWFUpload/swfupload.swf",
|
||||||
|
file_upload_limit : 0,
|
||||||
|
file_size_limit: "{{ maxFileSize ~ " B"}}",
|
||||||
|
requeue_on_error : true,
|
||||||
|
file_post_name : "files[]",
|
||||||
|
file_queue_limit : 0,
|
||||||
|
button_placeholder_id : "spanSWFUploadButton",
|
||||||
|
button_image_url : "/skins/icons/theme_button_background.png",
|
||||||
|
button_width : 170,
|
||||||
|
button_height : 40,
|
||||||
|
button_text : "<span class='btn'>{% trans 'Select files...' %}</span>",
|
||||||
|
button_text_style :
|
||||||
|
".btn {"
|
||||||
|
+ "font-family: verdana, Helvetica Neue, Helvetica, Arial, sans-serif; "
|
||||||
|
+ "color: #777777;"
|
||||||
|
+ "font-size: 12px; "
|
||||||
|
+ "font-weight: bold;"
|
||||||
|
+ "}",
|
||||||
|
button_text_left_padding : 5,
|
||||||
|
button_text_top_padding : 10,
|
||||||
|
button_window_mode:SWFUpload.WINDOW_MODE.TRANSPARENT,
|
||||||
|
button_cursor : SWFUpload.CURSOR.HAND,
|
||||||
|
file_queued_handler : function(file) {
|
||||||
|
var $this = this;
|
||||||
|
UploaderManager.getUploadBox().closest('.upload-box').show();
|
||||||
|
|
||||||
|
var formatedFile = {
|
||||||
|
id: file.id,
|
||||||
|
size: file.size != undefined ? UploaderManager.Formater.size(file.size) : '',
|
||||||
|
name: file.name,
|
||||||
|
type: file.type != undefined ? file.type : '',
|
||||||
|
uploadIndex: file.index,
|
||||||
|
language: language
|
||||||
|
}
|
||||||
|
|
||||||
|
p4.Mustache.Render('Upload-Items', formatedFile, function(html){
|
||||||
|
UploaderManager.getUploadBox().append(html);
|
||||||
|
$("#"+file.id).find('.canva-wrapper').remove();
|
||||||
|
$("#"+file.id).find(".remove-element").bind('click', function(){
|
||||||
|
$this.cancelUpload(file.id);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
file_queue_error_handler : function(file, errorCode, message) {
|
||||||
|
if (errorCode === SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED) {
|
||||||
|
alert(" {% trans "You have attempted to queue too many files" %}");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
var error = "{% trans "Unknow Error" %}";
|
||||||
|
|
||||||
|
switch (errorCode) {
|
||||||
|
case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT:
|
||||||
|
error = language.errorFileApiTooBig;
|
||||||
|
break;
|
||||||
|
case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:
|
||||||
|
error = "{% trans "Cannot upload Zero Byte files" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE:
|
||||||
|
error = "{% trans "Invalid file type" %}";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if (file !== null) {
|
||||||
|
error = "{% trans "Unhandled Error" %}";
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
var params = $.extend({}, file, {error: error, language: language});
|
||||||
|
p4.Mustache.Render('Upload-Items-Error', params, function(html){
|
||||||
|
UploaderManager.getUploadBox().append(html);
|
||||||
|
$("#"+file.id, UploaderManager.getDownloadBox()).find('.canva-wrapper').remove();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
file_dialog_complete_handler : function(numFilesSelected, numFilesQueued) {
|
||||||
|
if (numFilesQueued > 0) {
|
||||||
|
$("button.clear-queue", UploaderManager.getContainer()).attr("disabled", false).removeClass("disabled");
|
||||||
|
$("button.upload-submitter", UploaderManager.getContainer()).attr("disabled", false).removeClass("disabled");
|
||||||
|
}
|
||||||
|
},
|
||||||
|
upload_start_handler : function(file) {
|
||||||
|
var $this = this;
|
||||||
|
$("#cancel-all", UploaderManager.getContainer()).removeClass("disabled").attr("disabled", false);
|
||||||
|
|
||||||
|
$.each(UploaderManager.getSettingsBox().find('.collection-status:visible input, select').serializeArray(), function(index, param){
|
||||||
|
$this.addFileParam(file.id, param.name, param.value);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
upload_progress_handler : function(file, bytesLoaded, bytesTotal) {
|
||||||
|
var progressbar = $("#"+file.id, UploaderManager.getDownloadBox()).find('.progress-bar');
|
||||||
|
progressbar.width(Math.round(UploaderManager.Formater.pourcent(bytesLoaded, bytesTotal)) + '%');
|
||||||
|
},
|
||||||
|
upload_error_handler : function(file, errorCode, message) {
|
||||||
|
|
||||||
|
var reasons = "{% trans "Unknow reason" %}";
|
||||||
|
|
||||||
|
switch (errorCode) {
|
||||||
|
case SWFUpload.UPLOAD_ERROR.HTTP_ERROR:
|
||||||
|
reasons = "{% trans "Bad request, please contact an admin" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.MISSING_UPLOAD_URL:
|
||||||
|
reasons = "{% trans "Upload URL is not set, please contact an admin" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.IO_ERROR:
|
||||||
|
reasons = "{% trans "Connection terminates unexpetecdly, please retry" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.SECURITY_ERROR:
|
||||||
|
reasons = "{% trans "The upload violates a security restriction, please retry" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.UPLOAD_LIMIT_EXCEEDED:
|
||||||
|
reasons = "{% trans "File upload limit ({{ maxFileSizeReadable }}) has been reach" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.UPLOAD_FAILED:
|
||||||
|
reasons = "{% trans "Could not initiate upload, please retry" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.SPECIFIED_FILE_ID_NOT_FOUND:
|
||||||
|
reasons = "{% trans "Could not retrieve the file ID, please retry or contact an admin if problem persist" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.FILE_VALIDATION_FAILED:
|
||||||
|
reasons = "{% trans "File validation failed" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.FILE_CANCELLED:
|
||||||
|
reasons = "{% trans "File upload has been cancelled" %}";
|
||||||
|
break;
|
||||||
|
case SWFUpload.UPLOAD_ERROR.UPLOAD_STOPPED:
|
||||||
|
reasons = "{% trans "File upload has been stopped" %}";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
p4.Mustache.Render('Download-Finish', {heading:"{% trans "Error while uploading" %}", reasons: [reasons]}, function(html){
|
||||||
|
$("#"+file.id, UploaderManager.getDownloadBox()).find('p.error').append(html).show();
|
||||||
|
});
|
||||||
|
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
upload_success_handler : function(file, response) {
|
||||||
|
var response = $.parseJSON(response);
|
||||||
|
|
||||||
|
if(response.success){
|
||||||
|
//case record
|
||||||
|
if(response.element === 'record'){
|
||||||
|
p4.Mustache.Render('Download-Finish', {heading:response.message, reasons: response.reasons}, function(html){
|
||||||
|
$("#"+file.id, UploaderManager.getDownloadBox()).find('p.success').append(html).show();
|
||||||
|
});
|
||||||
|
} else { //case quarantine
|
||||||
|
p4.Mustache.Render('Download-Finish', {heading:response.message, reasons: response.reasons}, function(html){
|
||||||
|
$("#"+file.id, UploaderManager.getDownloadBox()).find('p.error').append(html).show();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
//fail
|
||||||
|
p4.Mustache.Render('Download-Finish', {heading:response.message, reasons: response.reasons}, function(html){
|
||||||
|
$("#"+file.id, UploaderManager.getDownloadBox()).find('p.error').append(html).show();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
upload_complete_handler: function(file) {
|
||||||
|
if (this.getStats().files_queued === 0) {
|
||||||
|
$("#cancel-all", UploaderManager.getContainer()).addClass("disabled").attr("disabled", true);
|
||||||
|
var dialog = p4.Dialog.get(1);
|
||||||
|
//unbind check before close event & disabled button for cancel all download
|
||||||
|
dialog.getDomElement().unbind("dialogbeforeclose");
|
||||||
|
}
|
||||||
|
|
||||||
|
$("#"+file.id, UploaderManager.getDownloadBox()).find('.progress-bar').width('100%');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$("button.upload-submitter", UploaderManager.getContainer()).bind("click", function(e){
|
||||||
|
|
||||||
|
//prevent dialog box from being closed while files are being downloaded
|
||||||
|
p4.Dialog.get(1).getDomElement().bind("dialogbeforeclose", function(event, ui) {
|
||||||
|
if ( swfu.getStats().files_queued > 0) {
|
||||||
|
p4.Alerts(language.warning, language.fileBeingDownloaded);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$(".upload-box-addedfiles ul:first li.upload-valid > div").each(function(index, element) {
|
||||||
|
var file = swfu.getFile($(this).attr("id"));
|
||||||
|
|
||||||
|
if (file !== null) {
|
||||||
|
p4.Mustache.Render('Download-Items', $.extend({}, file, {language: language}), function(html){
|
||||||
|
UploaderManager.getDownloadBox().append(html);
|
||||||
|
$("#"+file.id, UploaderManager.getDownloadBox()).find('.canva-wrapper').remove();
|
||||||
|
$("#"+file.id, UploaderManager.getDownloadBox()).find('.remove-element').bind('click', function(e){
|
||||||
|
swfu.cancelUpload(file.id);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$('ul', UploaderManager.getContainer().find('.upload-box')).empty();
|
||||||
|
$("button.clear-queue", UploaderManager.getContainer()).attr("disabled", true).addClass("disabled");
|
||||||
|
$("button.upload-submitter", UploaderManager.getContainer()).attr("disabled", true).addClass('disabled');
|
||||||
|
|
||||||
|
swfu.startUpload();
|
||||||
|
});
|
||||||
|
|
||||||
|
$("button.clear-queue", UploaderManager.getContainer()).bind("click", function(e){
|
||||||
|
swfu.cancelQueue();
|
||||||
|
$('ul', $(this).closest('.upload-box')).empty();
|
||||||
|
$(this).attr("disabled", true).addClass("disabled");
|
||||||
|
$("button.upload-submitter", UploaderManager.getContainer()).attr("disabled", true).addClass('disabled');
|
||||||
|
});
|
||||||
|
|
||||||
|
$("#cancel-all", UploaderManager.getContainer()).bind("click", function(){
|
||||||
|
swfu.cancelQueue();
|
||||||
|
$(this).addClass("disabled").attr("disabled", true);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
</script>
|
@@ -31,6 +31,10 @@
|
|||||||
<input type="file" name="files[]" multiple>
|
<input type="file" name="files[]" multiple>
|
||||||
</span>
|
</span>
|
||||||
<br />
|
<br />
|
||||||
|
<span>
|
||||||
|
<a href="/prod/upload/flash-version/" class="dialog full-dialog" title="{% trans 'Upload' %}"><span class="label label-info"><i>{% trans 'Switch to flash uploader' %}</i></span></a>
|
||||||
|
</span>
|
||||||
|
<br />
|
||||||
<span class="comment">
|
<span class="comment">
|
||||||
({% trans %} maximum : {{ maxFileSizeReadable }} {% endtrans %})
|
({% trans %} maximum : {{ maxFileSizeReadable }} {% endtrans %})
|
||||||
</span>
|
</span>
|
||||||
@@ -273,6 +277,7 @@ $(document).ready(function () {
|
|||||||
|
|
||||||
// Check support of file.size && file.type property
|
// Check support of file.size && file.type property
|
||||||
var formatedFile = {
|
var formatedFile = {
|
||||||
|
id: 'file-' + index,
|
||||||
size: file.size != undefined ? UploaderManager.Formater.size(file.size) : '',
|
size: file.size != undefined ? UploaderManager.Formater.size(file.size) : '',
|
||||||
name: file.name,
|
name: file.name,
|
||||||
type: file.type != undefined ? file.type : '',
|
type: file.type != undefined ? file.type : '',
|
||||||
@@ -347,7 +352,7 @@ $(document).ready(function () {
|
|||||||
|
|
||||||
//Set new context in download-box
|
//Set new context in download-box
|
||||||
$.each(data.files, function (index, file) {
|
$.each(data.files, function (index, file) {
|
||||||
var params = $.extend({}, file, {language: language});
|
var params = $.extend({}, file, {language: language, id:'file-'+index});
|
||||||
p4.Mustache.Render('Download-Items', params, function(html){
|
p4.Mustache.Render('Download-Items', params, function(html){
|
||||||
UploaderManager.getDownloadBox().append(html);
|
UploaderManager.getDownloadBox().append(html);
|
||||||
|
|
||||||
|
@@ -42,12 +42,23 @@ class UploadTest extends \PhraseanetWebTestCaseAuthenticatedAbstract
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers Alchemy\Phrasea\Controller\Prod\Upload::getUploadForm
|
* @covers Alchemy\Phrasea\Controller\Prod\Upload::getFlashUploadForm
|
||||||
* @covers Alchemy\Phrasea\Controller\Prod\Upload::call
|
* @covers Alchemy\Phrasea\Controller\Prod\Upload::call
|
||||||
*/
|
*/
|
||||||
|
public function testFlashUploadForm()
|
||||||
|
{
|
||||||
|
$this->client->request('GET', '/upload/flash-version/');
|
||||||
|
$response = $this->client->getResponse();
|
||||||
|
|
||||||
|
$this->assertEquals(200, $response->getStatusCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @covers Alchemy\Phrasea\Controller\Prod\Upload::getUploadForm
|
||||||
|
*/
|
||||||
public function testUploadForm()
|
public function testUploadForm()
|
||||||
{
|
{
|
||||||
$this->client->request('GET', '/upload/', array(), array(), array('HTTP_Accept' => 'application/json'));
|
$this->client->request('GET', '/upload/');
|
||||||
$response = $this->client->getResponse();
|
$response = $this->client->getResponse();
|
||||||
|
|
||||||
$this->assertEquals(200, $response->getStatusCode());
|
$this->assertEquals(200, $response->getStatusCode());
|
||||||
|
@@ -0,0 +1,4 @@
|
|||||||
|
/* SWFObject v2.0 rc4 <http://code.google.com/p/swfobject/>
|
||||||
|
Copyright (c) 2007 Geoff Stearns, Michael Williams, and Bobby van der Sluis
|
||||||
|
This software is released under the MIT License <http://www.opensource.org/licenses/mit-license.php>
|
||||||
|
*/
|
53
www/include/jslibs/SWFUpload/plugins/swfupload.cookies.js
Normal file
53
www/include/jslibs/SWFUpload/plugins/swfupload.cookies.js
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
Cookie Plug-in
|
||||||
|
|
||||||
|
This plug in automatically gets all the cookies for this site and adds them to the post_params.
|
||||||
|
Cookies are loaded only on initialization. The refreshCookies function can be called to update the post_params.
|
||||||
|
The cookies will override any other post params with the same name.
|
||||||
|
*/
|
||||||
|
|
||||||
|
var SWFUpload;
|
||||||
|
if (typeof(SWFUpload) === "function") {
|
||||||
|
SWFUpload.prototype.initSettings = function (oldInitSettings) {
|
||||||
|
return function () {
|
||||||
|
if (typeof(oldInitSettings) === "function") {
|
||||||
|
oldInitSettings.call(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.refreshCookies(false); // The false parameter must be sent since SWFUpload has not initialzed at this point
|
||||||
|
};
|
||||||
|
}(SWFUpload.prototype.initSettings);
|
||||||
|
|
||||||
|
// refreshes the post_params and updates SWFUpload. The sendToFlash parameters is optional and defaults to True
|
||||||
|
SWFUpload.prototype.refreshCookies = function (sendToFlash) {
|
||||||
|
if (sendToFlash === undefined) {
|
||||||
|
sendToFlash = true;
|
||||||
|
}
|
||||||
|
sendToFlash = !!sendToFlash;
|
||||||
|
|
||||||
|
// Get the post_params object
|
||||||
|
var postParams = this.settings.post_params;
|
||||||
|
|
||||||
|
// Get the cookies
|
||||||
|
var i, cookieArray = document.cookie.split(';'), caLength = cookieArray.length, c, eqIndex, name, value;
|
||||||
|
for (i = 0; i < caLength; i++) {
|
||||||
|
c = cookieArray[i];
|
||||||
|
|
||||||
|
// Left Trim spaces
|
||||||
|
while (c.charAt(0) === " ") {
|
||||||
|
c = c.substring(1, c.length);
|
||||||
|
}
|
||||||
|
eqIndex = c.indexOf("=");
|
||||||
|
if (eqIndex > 0) {
|
||||||
|
name = c.substring(0, eqIndex);
|
||||||
|
value = c.substring(eqIndex + 1);
|
||||||
|
postParams[name] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sendToFlash) {
|
||||||
|
this.setPostParams(postParams);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
98
www/include/jslibs/SWFUpload/plugins/swfupload.queue.js
Normal file
98
www/include/jslibs/SWFUpload/plugins/swfupload.queue.js
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
/*
|
||||||
|
Queue Plug-in
|
||||||
|
|
||||||
|
Features:
|
||||||
|
*Adds a cancelQueue() method for cancelling the entire queue.
|
||||||
|
*All queued files are uploaded when startUpload() is called.
|
||||||
|
*If false is returned from uploadComplete then the queue upload is stopped.
|
||||||
|
If false is not returned (strict comparison) then the queue upload is continued.
|
||||||
|
*Adds a QueueComplete event that is fired when all the queued files have finished uploading.
|
||||||
|
Set the event handler with the queue_complete_handler setting.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
var SWFUpload;
|
||||||
|
if (typeof(SWFUpload) === "function") {
|
||||||
|
SWFUpload.queue = {};
|
||||||
|
|
||||||
|
SWFUpload.prototype.initSettings = (function (oldInitSettings) {
|
||||||
|
return function () {
|
||||||
|
if (typeof(oldInitSettings) === "function") {
|
||||||
|
oldInitSettings.call(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.queueSettings = {};
|
||||||
|
|
||||||
|
this.queueSettings.queue_cancelled_flag = false;
|
||||||
|
this.queueSettings.queue_upload_count = 0;
|
||||||
|
|
||||||
|
this.queueSettings.user_upload_complete_handler = this.settings.upload_complete_handler;
|
||||||
|
this.queueSettings.user_upload_start_handler = this.settings.upload_start_handler;
|
||||||
|
this.settings.upload_complete_handler = SWFUpload.queue.uploadCompleteHandler;
|
||||||
|
this.settings.upload_start_handler = SWFUpload.queue.uploadStartHandler;
|
||||||
|
|
||||||
|
this.settings.queue_complete_handler = this.settings.queue_complete_handler || null;
|
||||||
|
};
|
||||||
|
})(SWFUpload.prototype.initSettings);
|
||||||
|
|
||||||
|
SWFUpload.prototype.startUpload = function (fileID) {
|
||||||
|
this.queueSettings.queue_cancelled_flag = false;
|
||||||
|
this.callFlash("StartUpload", [fileID]);
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.prototype.cancelQueue = function () {
|
||||||
|
this.queueSettings.queue_cancelled_flag = true;
|
||||||
|
this.stopUpload();
|
||||||
|
|
||||||
|
var stats = this.getStats();
|
||||||
|
while (stats.files_queued > 0) {
|
||||||
|
this.cancelUpload();
|
||||||
|
stats = this.getStats();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.queue.uploadStartHandler = function (file) {
|
||||||
|
var returnValue;
|
||||||
|
if (typeof(this.queueSettings.user_upload_start_handler) === "function") {
|
||||||
|
returnValue = this.queueSettings.user_upload_start_handler.call(this, file);
|
||||||
|
}
|
||||||
|
|
||||||
|
// To prevent upload a real "FALSE" value must be returned, otherwise default to a real "TRUE" value.
|
||||||
|
returnValue = (returnValue === false) ? false : true;
|
||||||
|
|
||||||
|
this.queueSettings.queue_cancelled_flag = !returnValue;
|
||||||
|
|
||||||
|
return returnValue;
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.queue.uploadCompleteHandler = function (file) {
|
||||||
|
var user_upload_complete_handler = this.queueSettings.user_upload_complete_handler;
|
||||||
|
var continueUpload;
|
||||||
|
|
||||||
|
if (file.filestatus === SWFUpload.FILE_STATUS.COMPLETE) {
|
||||||
|
this.queueSettings.queue_upload_count++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof(user_upload_complete_handler) === "function") {
|
||||||
|
continueUpload = (user_upload_complete_handler.call(this, file) === false) ? false : true;
|
||||||
|
} else if (file.filestatus === SWFUpload.FILE_STATUS.QUEUED) {
|
||||||
|
// If the file was stopped and re-queued don't restart the upload
|
||||||
|
continueUpload = false;
|
||||||
|
} else {
|
||||||
|
continueUpload = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (continueUpload) {
|
||||||
|
var stats = this.getStats();
|
||||||
|
if (stats.files_queued > 0 && this.queueSettings.queue_cancelled_flag === false) {
|
||||||
|
this.startUpload();
|
||||||
|
} else if (this.queueSettings.queue_cancelled_flag === false) {
|
||||||
|
this.queueEvent("queue_complete_handler", [this.queueSettings.queue_upload_count]);
|
||||||
|
this.queueSettings.queue_upload_count = 0;
|
||||||
|
} else {
|
||||||
|
this.queueSettings.queue_cancelled_flag = false;
|
||||||
|
this.queueSettings.queue_upload_count = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
342
www/include/jslibs/SWFUpload/plugins/swfupload.speed.js
Normal file
342
www/include/jslibs/SWFUpload/plugins/swfupload.speed.js
Normal file
@@ -0,0 +1,342 @@
|
|||||||
|
/*
|
||||||
|
Speed Plug-in
|
||||||
|
|
||||||
|
Features:
|
||||||
|
*Adds several properties to the 'file' object indicated upload speed, time left, upload time, etc.
|
||||||
|
- currentSpeed -- String indicating the upload speed, bytes per second
|
||||||
|
- averageSpeed -- Overall average upload speed, bytes per second
|
||||||
|
- movingAverageSpeed -- Speed over averaged over the last several measurements, bytes per second
|
||||||
|
- timeRemaining -- Estimated remaining upload time in seconds
|
||||||
|
- timeElapsed -- Number of seconds passed for this upload
|
||||||
|
- percentUploaded -- Percentage of the file uploaded (0 to 100)
|
||||||
|
- sizeUploaded -- Formatted size uploaded so far, bytes
|
||||||
|
|
||||||
|
*Adds setting 'moving_average_history_size' for defining the window size used to calculate the moving average speed.
|
||||||
|
|
||||||
|
*Adds several Formatting functions for formatting that values provided on the file object.
|
||||||
|
- SWFUpload.speed.formatBPS(bps) -- outputs string formatted in the best units (Gbps, Mbps, Kbps, bps)
|
||||||
|
- SWFUpload.speed.formatTime(seconds) -- outputs string formatted in the best units (x Hr y M z S)
|
||||||
|
- SWFUpload.speed.formatSize(bytes) -- outputs string formatted in the best units (w GB x MB y KB z B )
|
||||||
|
- SWFUpload.speed.formatPercent(percent) -- outputs string formatted with a percent sign (x.xx %)
|
||||||
|
- SWFUpload.speed.formatUnits(baseNumber, divisionArray, unitLabelArray, fractionalBoolean)
|
||||||
|
- Formats a number using the division array to determine how to apply the labels in the Label Array
|
||||||
|
- factionalBoolean indicates whether the number should be returned as a single fractional number with a unit (speed)
|
||||||
|
or as several numbers labeled with units (time)
|
||||||
|
*/
|
||||||
|
|
||||||
|
var SWFUpload;
|
||||||
|
if (typeof(SWFUpload) === "function") {
|
||||||
|
SWFUpload.speed = {};
|
||||||
|
|
||||||
|
SWFUpload.prototype.initSettings = (function (oldInitSettings) {
|
||||||
|
return function () {
|
||||||
|
if (typeof(oldInitSettings) === "function") {
|
||||||
|
oldInitSettings.call(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.ensureDefault = function (settingName, defaultValue) {
|
||||||
|
this.settings[settingName] = (this.settings[settingName] == undefined) ? defaultValue : this.settings[settingName];
|
||||||
|
};
|
||||||
|
|
||||||
|
// List used to keep the speed stats for the files we are tracking
|
||||||
|
this.fileSpeedStats = {};
|
||||||
|
this.speedSettings = {};
|
||||||
|
|
||||||
|
this.ensureDefault("moving_average_history_size", "10");
|
||||||
|
|
||||||
|
this.speedSettings.user_file_queued_handler = this.settings.file_queued_handler;
|
||||||
|
this.speedSettings.user_file_queue_error_handler = this.settings.file_queue_error_handler;
|
||||||
|
this.speedSettings.user_upload_start_handler = this.settings.upload_start_handler;
|
||||||
|
this.speedSettings.user_upload_error_handler = this.settings.upload_error_handler;
|
||||||
|
this.speedSettings.user_upload_progress_handler = this.settings.upload_progress_handler;
|
||||||
|
this.speedSettings.user_upload_success_handler = this.settings.upload_success_handler;
|
||||||
|
this.speedSettings.user_upload_complete_handler = this.settings.upload_complete_handler;
|
||||||
|
|
||||||
|
this.settings.file_queued_handler = SWFUpload.speed.fileQueuedHandler;
|
||||||
|
this.settings.file_queue_error_handler = SWFUpload.speed.fileQueueErrorHandler;
|
||||||
|
this.settings.upload_start_handler = SWFUpload.speed.uploadStartHandler;
|
||||||
|
this.settings.upload_error_handler = SWFUpload.speed.uploadErrorHandler;
|
||||||
|
this.settings.upload_progress_handler = SWFUpload.speed.uploadProgressHandler;
|
||||||
|
this.settings.upload_success_handler = SWFUpload.speed.uploadSuccessHandler;
|
||||||
|
this.settings.upload_complete_handler = SWFUpload.speed.uploadCompleteHandler;
|
||||||
|
|
||||||
|
delete this.ensureDefault;
|
||||||
|
};
|
||||||
|
})(SWFUpload.prototype.initSettings);
|
||||||
|
|
||||||
|
|
||||||
|
SWFUpload.speed.fileQueuedHandler = function (file) {
|
||||||
|
if (typeof this.speedSettings.user_file_queued_handler === "function") {
|
||||||
|
file = SWFUpload.speed.extendFile(file);
|
||||||
|
|
||||||
|
return this.speedSettings.user_file_queued_handler.call(this, file);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.speed.fileQueueErrorHandler = function (file, errorCode, message) {
|
||||||
|
if (typeof this.speedSettings.user_file_queue_error_handler === "function") {
|
||||||
|
file = SWFUpload.speed.extendFile(file);
|
||||||
|
|
||||||
|
return this.speedSettings.user_file_queue_error_handler.call(this, file, errorCode, message);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.speed.uploadStartHandler = function (file) {
|
||||||
|
if (typeof this.speedSettings.user_upload_start_handler === "function") {
|
||||||
|
file = SWFUpload.speed.extendFile(file, this.fileSpeedStats);
|
||||||
|
return this.speedSettings.user_upload_start_handler.call(this, file);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.speed.uploadErrorHandler = function (file, errorCode, message) {
|
||||||
|
file = SWFUpload.speed.extendFile(file, this.fileSpeedStats);
|
||||||
|
SWFUpload.speed.removeTracking(file, this.fileSpeedStats);
|
||||||
|
|
||||||
|
if (typeof this.speedSettings.user_upload_error_handler === "function") {
|
||||||
|
return this.speedSettings.user_upload_error_handler.call(this, file, errorCode, message);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
SWFUpload.speed.uploadProgressHandler = function (file, bytesComplete, bytesTotal) {
|
||||||
|
this.updateTracking(file, bytesComplete);
|
||||||
|
file = SWFUpload.speed.extendFile(file, this.fileSpeedStats);
|
||||||
|
|
||||||
|
if (typeof this.speedSettings.user_upload_progress_handler === "function") {
|
||||||
|
return this.speedSettings.user_upload_progress_handler.call(this, file, bytesComplete, bytesTotal);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.speed.uploadSuccessHandler = function (file, serverData) {
|
||||||
|
if (typeof this.speedSettings.user_upload_success_handler === "function") {
|
||||||
|
file = SWFUpload.speed.extendFile(file, this.fileSpeedStats);
|
||||||
|
return this.speedSettings.user_upload_success_handler.call(this, file, serverData);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
SWFUpload.speed.uploadCompleteHandler = function (file) {
|
||||||
|
file = SWFUpload.speed.extendFile(file, this.fileSpeedStats);
|
||||||
|
SWFUpload.speed.removeTracking(file, this.fileSpeedStats);
|
||||||
|
|
||||||
|
if (typeof this.speedSettings.user_upload_complete_handler === "function") {
|
||||||
|
return this.speedSettings.user_upload_complete_handler.call(this, file);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: extends the file object with the speed plugin values
|
||||||
|
SWFUpload.speed.extendFile = function (file, trackingList) {
|
||||||
|
var tracking;
|
||||||
|
|
||||||
|
if (trackingList) {
|
||||||
|
tracking = trackingList[file.id];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tracking) {
|
||||||
|
file.currentSpeed = tracking.currentSpeed;
|
||||||
|
file.averageSpeed = tracking.averageSpeed;
|
||||||
|
file.movingAverageSpeed = tracking.movingAverageSpeed;
|
||||||
|
file.timeRemaining = tracking.timeRemaining;
|
||||||
|
file.timeElapsed = tracking.timeElapsed;
|
||||||
|
file.percentUploaded = tracking.percentUploaded;
|
||||||
|
file.sizeUploaded = tracking.bytesUploaded;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
file.currentSpeed = 0;
|
||||||
|
file.averageSpeed = 0;
|
||||||
|
file.movingAverageSpeed = 0;
|
||||||
|
file.timeRemaining = 0;
|
||||||
|
file.timeElapsed = 0;
|
||||||
|
file.percentUploaded = 0;
|
||||||
|
file.sizeUploaded = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return file;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: Updates the speed tracking object, or creates it if necessary
|
||||||
|
SWFUpload.prototype.updateTracking = function (file, bytesUploaded) {
|
||||||
|
var tracking = this.fileSpeedStats[file.id];
|
||||||
|
if (!tracking) {
|
||||||
|
this.fileSpeedStats[file.id] = tracking = {};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sanity check inputs
|
||||||
|
bytesUploaded = bytesUploaded || tracking.bytesUploaded || 0;
|
||||||
|
if (bytesUploaded < 0) {
|
||||||
|
bytesUploaded = 0;
|
||||||
|
}
|
||||||
|
if (bytesUploaded > file.size) {
|
||||||
|
bytesUploaded = file.size;
|
||||||
|
}
|
||||||
|
|
||||||
|
var tickTime = (new Date()).getTime();
|
||||||
|
if (!tracking.startTime) {
|
||||||
|
tracking.startTime = (new Date()).getTime();
|
||||||
|
tracking.lastTime = tracking.startTime;
|
||||||
|
tracking.currentSpeed = 0;
|
||||||
|
tracking.averageSpeed = 0;
|
||||||
|
tracking.movingAverageSpeed = 0;
|
||||||
|
tracking.movingAverageHistory = [];
|
||||||
|
tracking.timeRemaining = 0;
|
||||||
|
tracking.timeElapsed = 0;
|
||||||
|
tracking.percentUploaded = bytesUploaded / file.size;
|
||||||
|
tracking.bytesUploaded = bytesUploaded;
|
||||||
|
} else if (tracking.startTime > tickTime) {
|
||||||
|
this.debug("When backwards in time");
|
||||||
|
} else {
|
||||||
|
// Get time and deltas
|
||||||
|
var now = (new Date()).getTime();
|
||||||
|
var lastTime = tracking.lastTime;
|
||||||
|
var deltaTime = now - lastTime;
|
||||||
|
var deltaBytes = bytesUploaded - tracking.bytesUploaded;
|
||||||
|
|
||||||
|
if (deltaBytes === 0 || deltaTime === 0) {
|
||||||
|
return tracking;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update tracking object
|
||||||
|
tracking.lastTime = now;
|
||||||
|
tracking.bytesUploaded = bytesUploaded;
|
||||||
|
|
||||||
|
// Calculate speeds
|
||||||
|
tracking.currentSpeed = (deltaBytes * 8 ) / (deltaTime / 1000);
|
||||||
|
tracking.averageSpeed = (tracking.bytesUploaded * 8) / ((now - tracking.startTime) / 1000);
|
||||||
|
|
||||||
|
// Calculate moving average
|
||||||
|
tracking.movingAverageHistory.push(tracking.currentSpeed);
|
||||||
|
if (tracking.movingAverageHistory.length > this.settings.moving_average_history_size) {
|
||||||
|
tracking.movingAverageHistory.shift();
|
||||||
|
}
|
||||||
|
|
||||||
|
tracking.movingAverageSpeed = SWFUpload.speed.calculateMovingAverage(tracking.movingAverageHistory);
|
||||||
|
|
||||||
|
// Update times
|
||||||
|
tracking.timeRemaining = (file.size - tracking.bytesUploaded) * 8 / tracking.movingAverageSpeed;
|
||||||
|
tracking.timeElapsed = (now - tracking.startTime) / 1000;
|
||||||
|
|
||||||
|
// Update percent
|
||||||
|
tracking.percentUploaded = (tracking.bytesUploaded / file.size * 100);
|
||||||
|
}
|
||||||
|
|
||||||
|
return tracking;
|
||||||
|
};
|
||||||
|
SWFUpload.speed.removeTracking = function (file, trackingList) {
|
||||||
|
try {
|
||||||
|
trackingList[file.id] = null;
|
||||||
|
delete trackingList[file.id];
|
||||||
|
} catch (ex) {
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.speed.formatUnits = function (baseNumber, unitDivisors, unitLabels, singleFractional) {
|
||||||
|
var i, unit, unitDivisor, unitLabel;
|
||||||
|
|
||||||
|
if (baseNumber === 0) {
|
||||||
|
return "0 " + unitLabels[unitLabels.length - 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (singleFractional) {
|
||||||
|
unit = baseNumber;
|
||||||
|
unitLabel = unitLabels.length >= unitDivisors.length ? unitLabels[unitDivisors.length - 1] : "";
|
||||||
|
for (i = 0; i < unitDivisors.length; i++) {
|
||||||
|
if (baseNumber >= unitDivisors[i]) {
|
||||||
|
unit = (baseNumber / unitDivisors[i]).toFixed(2);
|
||||||
|
unitLabel = unitLabels.length >= i ? " " + unitLabels[i] : "";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return unit + unitLabel;
|
||||||
|
} else {
|
||||||
|
var formattedStrings = [];
|
||||||
|
var remainder = baseNumber;
|
||||||
|
|
||||||
|
for (i = 0; i < unitDivisors.length; i++) {
|
||||||
|
unitDivisor = unitDivisors[i];
|
||||||
|
unitLabel = unitLabels.length > i ? " " + unitLabels[i] : "";
|
||||||
|
|
||||||
|
unit = remainder / unitDivisor;
|
||||||
|
if (i < unitDivisors.length -1) {
|
||||||
|
unit = Math.floor(unit);
|
||||||
|
} else {
|
||||||
|
unit = unit.toFixed(2);
|
||||||
|
}
|
||||||
|
if (unit > 0) {
|
||||||
|
remainder = remainder % unitDivisor;
|
||||||
|
|
||||||
|
formattedStrings.push(unit + unitLabel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return formattedStrings.join(" ");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.speed.formatBPS = function (baseNumber) {
|
||||||
|
var bpsUnits = [1073741824, 1048576, 1024, 1], bpsUnitLabels = ["Gbps", "Mbps", "Kbps", "bps"];
|
||||||
|
return SWFUpload.speed.formatUnits(baseNumber, bpsUnits, bpsUnitLabels, true);
|
||||||
|
|
||||||
|
};
|
||||||
|
SWFUpload.speed.formatTime = function (baseNumber) {
|
||||||
|
var timeUnits = [86400, 3600, 60, 1], timeUnitLabels = ["d", "h", "m", "s"];
|
||||||
|
return SWFUpload.speed.formatUnits(baseNumber, timeUnits, timeUnitLabels, false);
|
||||||
|
|
||||||
|
};
|
||||||
|
SWFUpload.speed.formatBytes = function (baseNumber) {
|
||||||
|
var sizeUnits = [1073741824, 1048576, 1024, 1], sizeUnitLabels = ["GB", "MB", "KB", "bytes"];
|
||||||
|
return SWFUpload.speed.formatUnits(baseNumber, sizeUnits, sizeUnitLabels, true);
|
||||||
|
|
||||||
|
};
|
||||||
|
SWFUpload.speed.formatPercent = function (baseNumber) {
|
||||||
|
return baseNumber.toFixed(2) + " %";
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.speed.calculateMovingAverage = function (history) {
|
||||||
|
var vals = [], size, sum = 0.0, mean = 0.0, varianceTemp = 0.0, variance = 0.0, standardDev = 0.0;
|
||||||
|
var i;
|
||||||
|
var mSum = 0, mCount = 0;
|
||||||
|
|
||||||
|
size = history.length;
|
||||||
|
|
||||||
|
// Check for sufficient data
|
||||||
|
if (size >= 8) {
|
||||||
|
// Clone the array and Calculate sum of the values
|
||||||
|
for (i = 0; i < size; i++) {
|
||||||
|
vals[i] = history[i];
|
||||||
|
sum += vals[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
mean = sum / size;
|
||||||
|
|
||||||
|
// Calculate variance for the set
|
||||||
|
for (i = 0; i < size; i++) {
|
||||||
|
varianceTemp += Math.pow((vals[i] - mean), 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
variance = varianceTemp / size;
|
||||||
|
standardDev = Math.sqrt(variance);
|
||||||
|
|
||||||
|
//Standardize the Data
|
||||||
|
for (i = 0; i < size; i++) {
|
||||||
|
vals[i] = (vals[i] - mean) / standardDev;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Calculate the average excluding outliers
|
||||||
|
var deviationRange = 2.0;
|
||||||
|
for (i = 0; i < size; i++) {
|
||||||
|
|
||||||
|
if (vals[i] <= deviationRange && vals[i] >= -deviationRange) {
|
||||||
|
mCount++;
|
||||||
|
mSum += history[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
// Calculate the average (not enough data points to remove outliers)
|
||||||
|
mCount = size;
|
||||||
|
for (i = 0; i < size; i++) {
|
||||||
|
mSum += history[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return mSum / mCount;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
111
www/include/jslibs/SWFUpload/plugins/swfupload.swfobject.js
Normal file
111
www/include/jslibs/SWFUpload/plugins/swfupload.swfobject.js
Normal file
File diff suppressed because one or more lines are too long
12
www/include/jslibs/SWFUpload/swfupload license.txt
Normal file
12
www/include/jslibs/SWFUpload/swfupload license.txt
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
/**
|
||||||
|
* SWFUpload: http://www.swfupload.org, http://swfupload.googlecode.com
|
||||||
|
*
|
||||||
|
* mmSWFUpload 1.0: Flash upload dialog - http://profandesign.se/swfupload/, http://www.vinterwebb.se/
|
||||||
|
*
|
||||||
|
* SWFUpload is (c) 2006-2007 Lars Huring, Olov Nilz<6C>n and Mammon Media and is released under the MIT License:
|
||||||
|
* http://www.opensource.org/licenses/mit-license.php
|
||||||
|
*
|
||||||
|
* SWFUpload 2 is (c) 2007-2008 Jake Roberts and is released under the MIT License:
|
||||||
|
* http://www.opensource.org/licenses/mit-license.php
|
||||||
|
*
|
||||||
|
*/
|
980
www/include/jslibs/SWFUpload/swfupload.js
Normal file
980
www/include/jslibs/SWFUpload/swfupload.js
Normal file
@@ -0,0 +1,980 @@
|
|||||||
|
/**
|
||||||
|
* SWFUpload: http://www.swfupload.org, http://swfupload.googlecode.com
|
||||||
|
*
|
||||||
|
* mmSWFUpload 1.0: Flash upload dialog - http://profandesign.se/swfupload/, http://www.vinterwebb.se/
|
||||||
|
*
|
||||||
|
* SWFUpload is (c) 2006-2007 Lars Huring, Olov Nilz<6C>n and Mammon Media and is released under the MIT License:
|
||||||
|
* http://www.opensource.org/licenses/mit-license.php
|
||||||
|
*
|
||||||
|
* SWFUpload 2 is (c) 2007-2008 Jake Roberts and is released under the MIT License:
|
||||||
|
* http://www.opensource.org/licenses/mit-license.php
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* ******************* */
|
||||||
|
/* Constructor & Init */
|
||||||
|
/* ******************* */
|
||||||
|
var SWFUpload;
|
||||||
|
|
||||||
|
if (SWFUpload == undefined) {
|
||||||
|
SWFUpload = function (settings) {
|
||||||
|
this.initSWFUpload(settings);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
SWFUpload.prototype.initSWFUpload = function (settings) {
|
||||||
|
try {
|
||||||
|
this.customSettings = {}; // A container where developers can place their own settings associated with this instance.
|
||||||
|
this.settings = settings;
|
||||||
|
this.eventQueue = [];
|
||||||
|
this.movieName = "SWFUpload_" + SWFUpload.movieCount++;
|
||||||
|
this.movieElement = null;
|
||||||
|
|
||||||
|
|
||||||
|
// Setup global control tracking
|
||||||
|
SWFUpload.instances[this.movieName] = this;
|
||||||
|
|
||||||
|
// Load the settings. Load the Flash movie.
|
||||||
|
this.initSettings();
|
||||||
|
this.loadFlash();
|
||||||
|
this.displayDebugInfo();
|
||||||
|
} catch (ex) {
|
||||||
|
delete SWFUpload.instances[this.movieName];
|
||||||
|
throw ex;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/* *************** */
|
||||||
|
/* Static Members */
|
||||||
|
/* *************** */
|
||||||
|
SWFUpload.instances = {};
|
||||||
|
SWFUpload.movieCount = 0;
|
||||||
|
SWFUpload.version = "2.2.0 2009-03-25";
|
||||||
|
SWFUpload.QUEUE_ERROR = {
|
||||||
|
QUEUE_LIMIT_EXCEEDED : -100,
|
||||||
|
FILE_EXCEEDS_SIZE_LIMIT : -110,
|
||||||
|
ZERO_BYTE_FILE : -120,
|
||||||
|
INVALID_FILETYPE : -130
|
||||||
|
};
|
||||||
|
SWFUpload.UPLOAD_ERROR = {
|
||||||
|
HTTP_ERROR : -200,
|
||||||
|
MISSING_UPLOAD_URL : -210,
|
||||||
|
IO_ERROR : -220,
|
||||||
|
SECURITY_ERROR : -230,
|
||||||
|
UPLOAD_LIMIT_EXCEEDED : -240,
|
||||||
|
UPLOAD_FAILED : -250,
|
||||||
|
SPECIFIED_FILE_ID_NOT_FOUND : -260,
|
||||||
|
FILE_VALIDATION_FAILED : -270,
|
||||||
|
FILE_CANCELLED : -280,
|
||||||
|
UPLOAD_STOPPED : -290
|
||||||
|
};
|
||||||
|
SWFUpload.FILE_STATUS = {
|
||||||
|
QUEUED : -1,
|
||||||
|
IN_PROGRESS : -2,
|
||||||
|
ERROR : -3,
|
||||||
|
COMPLETE : -4,
|
||||||
|
CANCELLED : -5
|
||||||
|
};
|
||||||
|
SWFUpload.BUTTON_ACTION = {
|
||||||
|
SELECT_FILE : -100,
|
||||||
|
SELECT_FILES : -110,
|
||||||
|
START_UPLOAD : -120
|
||||||
|
};
|
||||||
|
SWFUpload.CURSOR = {
|
||||||
|
ARROW : -1,
|
||||||
|
HAND : -2
|
||||||
|
};
|
||||||
|
SWFUpload.WINDOW_MODE = {
|
||||||
|
WINDOW : "window",
|
||||||
|
TRANSPARENT : "transparent",
|
||||||
|
OPAQUE : "opaque"
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: takes a URL, determines if it is relative and converts to an absolute URL
|
||||||
|
// using the current site. Only processes the URL if it can, otherwise returns the URL untouched
|
||||||
|
SWFUpload.completeURL = function(url) {
|
||||||
|
if (typeof(url) !== "string" || url.match(/^https?:\/\//i) || url.match(/^\//)) {
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
var currentURL = window.location.protocol + "//" + window.location.hostname + (window.location.port ? ":" + window.location.port : "");
|
||||||
|
|
||||||
|
var indexSlash = window.location.pathname.lastIndexOf("/");
|
||||||
|
if (indexSlash <= 0) {
|
||||||
|
path = "/";
|
||||||
|
} else {
|
||||||
|
path = window.location.pathname.substr(0, indexSlash) + "/";
|
||||||
|
}
|
||||||
|
|
||||||
|
return /*currentURL +*/ path + url;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* ******************** */
|
||||||
|
/* Instance Members */
|
||||||
|
/* ******************** */
|
||||||
|
|
||||||
|
// Private: initSettings ensures that all the
|
||||||
|
// settings are set, getting a default value if one was not assigned.
|
||||||
|
SWFUpload.prototype.initSettings = function () {
|
||||||
|
this.ensureDefault = function (settingName, defaultValue) {
|
||||||
|
this.settings[settingName] = (this.settings[settingName] == undefined) ? defaultValue : this.settings[settingName];
|
||||||
|
};
|
||||||
|
|
||||||
|
// Upload backend settings
|
||||||
|
this.ensureDefault("upload_url", "");
|
||||||
|
this.ensureDefault("preserve_relative_urls", false);
|
||||||
|
this.ensureDefault("file_post_name", "Filedata");
|
||||||
|
this.ensureDefault("post_params", {});
|
||||||
|
this.ensureDefault("use_query_string", false);
|
||||||
|
this.ensureDefault("requeue_on_error", false);
|
||||||
|
this.ensureDefault("http_success", []);
|
||||||
|
this.ensureDefault("assume_success_timeout", 0);
|
||||||
|
|
||||||
|
// File Settings
|
||||||
|
this.ensureDefault("file_types", "*.*");
|
||||||
|
this.ensureDefault("file_types_description", "All Files");
|
||||||
|
this.ensureDefault("file_size_limit", 0); // Default zero means "unlimited"
|
||||||
|
this.ensureDefault("file_upload_limit", 0);
|
||||||
|
this.ensureDefault("file_queue_limit", 0);
|
||||||
|
|
||||||
|
// Flash Settings
|
||||||
|
this.ensureDefault("flash_url", "swfupload.swf");
|
||||||
|
this.ensureDefault("prevent_swf_caching", true);
|
||||||
|
|
||||||
|
// Button Settings
|
||||||
|
this.ensureDefault("button_image_url", "");
|
||||||
|
this.ensureDefault("button_width", 1);
|
||||||
|
this.ensureDefault("button_height", 1);
|
||||||
|
this.ensureDefault("button_text", "");
|
||||||
|
this.ensureDefault("button_text_style", "color: #000000; font-size: 16pt;");
|
||||||
|
this.ensureDefault("button_text_top_padding", 0);
|
||||||
|
this.ensureDefault("button_text_left_padding", 0);
|
||||||
|
this.ensureDefault("button_action", SWFUpload.BUTTON_ACTION.SELECT_FILES);
|
||||||
|
this.ensureDefault("button_disabled", false);
|
||||||
|
this.ensureDefault("button_placeholder_id", "");
|
||||||
|
this.ensureDefault("button_placeholder", null);
|
||||||
|
this.ensureDefault("button_cursor", SWFUpload.CURSOR.ARROW);
|
||||||
|
this.ensureDefault("button_window_mode", SWFUpload.WINDOW_MODE.WINDOW);
|
||||||
|
|
||||||
|
// Debug Settings
|
||||||
|
this.ensureDefault("debug", false);
|
||||||
|
this.settings.debug_enabled = this.settings.debug; // Here to maintain v2 API
|
||||||
|
|
||||||
|
// Event Handlers
|
||||||
|
this.settings.return_upload_start_handler = this.returnUploadStart;
|
||||||
|
this.ensureDefault("swfupload_loaded_handler", null);
|
||||||
|
this.ensureDefault("file_dialog_start_handler", null);
|
||||||
|
this.ensureDefault("file_queued_handler", null);
|
||||||
|
this.ensureDefault("file_queue_error_handler", null);
|
||||||
|
this.ensureDefault("file_dialog_complete_handler", null);
|
||||||
|
|
||||||
|
this.ensureDefault("upload_start_handler", null);
|
||||||
|
this.ensureDefault("upload_progress_handler", null);
|
||||||
|
this.ensureDefault("upload_error_handler", null);
|
||||||
|
this.ensureDefault("upload_success_handler", null);
|
||||||
|
this.ensureDefault("upload_complete_handler", null);
|
||||||
|
|
||||||
|
this.ensureDefault("debug_handler", this.debugMessage);
|
||||||
|
|
||||||
|
this.ensureDefault("custom_settings", {});
|
||||||
|
|
||||||
|
// Other settings
|
||||||
|
this.customSettings = this.settings.custom_settings;
|
||||||
|
|
||||||
|
// Update the flash url if needed
|
||||||
|
if (!!this.settings.prevent_swf_caching) {
|
||||||
|
this.settings.flash_url = this.settings.flash_url + (this.settings.flash_url.indexOf("?") < 0 ? "?" : "&") + "preventswfcaching=" + new Date().getTime();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!this.settings.preserve_relative_urls) {
|
||||||
|
//this.settings.flash_url = SWFUpload.completeURL(this.settings.flash_url); // Don't need to do this one since flash doesn't look at it
|
||||||
|
this.settings.upload_url = SWFUpload.completeURL(this.settings.upload_url);
|
||||||
|
this.settings.button_image_url = SWFUpload.completeURL(this.settings.button_image_url);
|
||||||
|
}
|
||||||
|
|
||||||
|
delete this.ensureDefault;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: loadFlash replaces the button_placeholder element with the flash movie.
|
||||||
|
SWFUpload.prototype.loadFlash = function () {
|
||||||
|
var targetElement, tempParent;
|
||||||
|
|
||||||
|
// Make sure an element with the ID we are going to use doesn't already exist
|
||||||
|
if (document.getElementById(this.movieName) !== null) {
|
||||||
|
throw "ID " + this.movieName + " is already in use. The Flash Object could not be added";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the element where we will be placing the flash movie
|
||||||
|
targetElement = document.getElementById(this.settings.button_placeholder_id) || this.settings.button_placeholder;
|
||||||
|
|
||||||
|
if (targetElement == undefined) {
|
||||||
|
throw "Could not find the placeholder element: " + this.settings.button_placeholder_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Append the container and load the flash
|
||||||
|
tempParent = document.createElement("div");
|
||||||
|
tempParent.innerHTML = this.getFlashHTML(); // Using innerHTML is non-standard but the only sensible way to dynamically add Flash in IE (and maybe other browsers)
|
||||||
|
targetElement.parentNode.replaceChild(tempParent.firstChild, targetElement);
|
||||||
|
|
||||||
|
// Fix IE Flash/Form bug
|
||||||
|
if (window[this.movieName] == undefined) {
|
||||||
|
window[this.movieName] = this.getMovieElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: getFlashHTML generates the object tag needed to embed the flash in to the document
|
||||||
|
SWFUpload.prototype.getFlashHTML = function () {
|
||||||
|
// Flash Satay object syntax: http://www.alistapart.com/articles/flashsatay
|
||||||
|
return ['<object id="', this.movieName, '" type="application/x-shockwave-flash" data="', this.settings.flash_url, '" width="', this.settings.button_width, '" height="', this.settings.button_height, '" class="swfupload">',
|
||||||
|
'<param name="wmode" value="', this.settings.button_window_mode, '" />',
|
||||||
|
'<param name="movie" value="', this.settings.flash_url, '" />',
|
||||||
|
'<param name="quality" value="high" />',
|
||||||
|
'<param name="menu" value="false" />',
|
||||||
|
'<param name="allowScriptAccess" value="always" />',
|
||||||
|
'<param name="flashvars" value="' + this.getFlashVars() + '" />',
|
||||||
|
'</object>'].join("");
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: getFlashVars builds the parameter string that will be passed
|
||||||
|
// to flash in the flashvars param.
|
||||||
|
SWFUpload.prototype.getFlashVars = function () {
|
||||||
|
// Build a string from the post param object
|
||||||
|
var paramString = this.buildParamString();
|
||||||
|
var httpSuccessString = this.settings.http_success.join(",");
|
||||||
|
|
||||||
|
// Build the parameter string
|
||||||
|
return ["movieName=", encodeURIComponent(this.movieName),
|
||||||
|
"&uploadURL=", encodeURIComponent(this.settings.upload_url),
|
||||||
|
"&useQueryString=", encodeURIComponent(this.settings.use_query_string),
|
||||||
|
"&requeueOnError=", encodeURIComponent(this.settings.requeue_on_error),
|
||||||
|
"&httpSuccess=", encodeURIComponent(httpSuccessString),
|
||||||
|
"&assumeSuccessTimeout=", encodeURIComponent(this.settings.assume_success_timeout),
|
||||||
|
"&params=", encodeURIComponent(paramString),
|
||||||
|
"&filePostName=", encodeURIComponent(this.settings.file_post_name),
|
||||||
|
"&fileTypes=", encodeURIComponent(this.settings.file_types),
|
||||||
|
"&fileTypesDescription=", encodeURIComponent(this.settings.file_types_description),
|
||||||
|
"&fileSizeLimit=", encodeURIComponent(this.settings.file_size_limit),
|
||||||
|
"&fileUploadLimit=", encodeURIComponent(this.settings.file_upload_limit),
|
||||||
|
"&fileQueueLimit=", encodeURIComponent(this.settings.file_queue_limit),
|
||||||
|
"&debugEnabled=", encodeURIComponent(this.settings.debug_enabled),
|
||||||
|
"&buttonImageURL=", encodeURIComponent(this.settings.button_image_url),
|
||||||
|
"&buttonWidth=", encodeURIComponent(this.settings.button_width),
|
||||||
|
"&buttonHeight=", encodeURIComponent(this.settings.button_height),
|
||||||
|
"&buttonText=", encodeURIComponent(this.settings.button_text),
|
||||||
|
"&buttonTextTopPadding=", encodeURIComponent(this.settings.button_text_top_padding),
|
||||||
|
"&buttonTextLeftPadding=", encodeURIComponent(this.settings.button_text_left_padding),
|
||||||
|
"&buttonTextStyle=", encodeURIComponent(this.settings.button_text_style),
|
||||||
|
"&buttonAction=", encodeURIComponent(this.settings.button_action),
|
||||||
|
"&buttonDisabled=", encodeURIComponent(this.settings.button_disabled),
|
||||||
|
"&buttonCursor=", encodeURIComponent(this.settings.button_cursor)
|
||||||
|
].join("");
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: getMovieElement retrieves the DOM reference to the Flash element added by SWFUpload
|
||||||
|
// The element is cached after the first lookup
|
||||||
|
SWFUpload.prototype.getMovieElement = function () {
|
||||||
|
if (this.movieElement == undefined) {
|
||||||
|
this.movieElement = document.getElementById(this.movieName);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.movieElement === null) {
|
||||||
|
throw "Could not find Flash element";
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.movieElement;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: buildParamString takes the name/value pairs in the post_params setting object
|
||||||
|
// and joins them up in to a string formatted "name=value&name=value"
|
||||||
|
SWFUpload.prototype.buildParamString = function () {
|
||||||
|
var postParams = this.settings.post_params;
|
||||||
|
var paramStringPairs = [];
|
||||||
|
|
||||||
|
if (typeof(postParams) === "object") {
|
||||||
|
for (var name in postParams) {
|
||||||
|
if (postParams.hasOwnProperty(name)) {
|
||||||
|
paramStringPairs.push(encodeURIComponent(name.toString()) + "=" + encodeURIComponent(postParams[name].toString()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return paramStringPairs.join("&");
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: Used to remove a SWFUpload instance from the page. This method strives to remove
|
||||||
|
// all references to the SWF, and other objects so memory is properly freed.
|
||||||
|
// Returns true if everything was destroyed. Returns a false if a failure occurs leaving SWFUpload in an inconsistant state.
|
||||||
|
// Credits: Major improvements provided by steffen
|
||||||
|
SWFUpload.prototype.destroy = function () {
|
||||||
|
try {
|
||||||
|
// Make sure Flash is done before we try to remove it
|
||||||
|
this.cancelUpload(null, false);
|
||||||
|
|
||||||
|
|
||||||
|
// Remove the SWFUpload DOM nodes
|
||||||
|
var movieElement = null;
|
||||||
|
movieElement = this.getMovieElement();
|
||||||
|
|
||||||
|
if (movieElement && typeof(movieElement.CallFunction) === "unknown") { // We only want to do this in IE
|
||||||
|
// Loop through all the movie's properties and remove all function references (DOM/JS IE 6/7 memory leak workaround)
|
||||||
|
for (var i in movieElement) {
|
||||||
|
try {
|
||||||
|
if (typeof(movieElement[i]) === "function") {
|
||||||
|
movieElement[i] = null;
|
||||||
|
}
|
||||||
|
} catch (ex1) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Remove the Movie Element from the page
|
||||||
|
try {
|
||||||
|
movieElement.parentNode.removeChild(movieElement);
|
||||||
|
} catch (ex) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Remove IE form fix reference
|
||||||
|
window[this.movieName] = null;
|
||||||
|
|
||||||
|
// Destroy other references
|
||||||
|
SWFUpload.instances[this.movieName] = null;
|
||||||
|
delete SWFUpload.instances[this.movieName];
|
||||||
|
|
||||||
|
this.movieElement = null;
|
||||||
|
this.settings = null;
|
||||||
|
this.customSettings = null;
|
||||||
|
this.eventQueue = null;
|
||||||
|
this.movieName = null;
|
||||||
|
|
||||||
|
|
||||||
|
return true;
|
||||||
|
} catch (ex2) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// Public: displayDebugInfo prints out settings and configuration
|
||||||
|
// information about this SWFUpload instance.
|
||||||
|
// This function (and any references to it) can be deleted when placing
|
||||||
|
// SWFUpload in production.
|
||||||
|
SWFUpload.prototype.displayDebugInfo = function () {
|
||||||
|
this.debug(
|
||||||
|
[
|
||||||
|
"---SWFUpload Instance Info---\n",
|
||||||
|
"Version: ", SWFUpload.version, "\n",
|
||||||
|
"Movie Name: ", this.movieName, "\n",
|
||||||
|
"Settings:\n",
|
||||||
|
"\t", "upload_url: ", this.settings.upload_url, "\n",
|
||||||
|
"\t", "flash_url: ", this.settings.flash_url, "\n",
|
||||||
|
"\t", "use_query_string: ", this.settings.use_query_string.toString(), "\n",
|
||||||
|
"\t", "requeue_on_error: ", this.settings.requeue_on_error.toString(), "\n",
|
||||||
|
"\t", "http_success: ", this.settings.http_success.join(", "), "\n",
|
||||||
|
"\t", "assume_success_timeout: ", this.settings.assume_success_timeout, "\n",
|
||||||
|
"\t", "file_post_name: ", this.settings.file_post_name, "\n",
|
||||||
|
"\t", "post_params: ", this.settings.post_params.toString(), "\n",
|
||||||
|
"\t", "file_types: ", this.settings.file_types, "\n",
|
||||||
|
"\t", "file_types_description: ", this.settings.file_types_description, "\n",
|
||||||
|
"\t", "file_size_limit: ", this.settings.file_size_limit, "\n",
|
||||||
|
"\t", "file_upload_limit: ", this.settings.file_upload_limit, "\n",
|
||||||
|
"\t", "file_queue_limit: ", this.settings.file_queue_limit, "\n",
|
||||||
|
"\t", "debug: ", this.settings.debug.toString(), "\n",
|
||||||
|
|
||||||
|
"\t", "prevent_swf_caching: ", this.settings.prevent_swf_caching.toString(), "\n",
|
||||||
|
|
||||||
|
"\t", "button_placeholder_id: ", this.settings.button_placeholder_id.toString(), "\n",
|
||||||
|
"\t", "button_placeholder: ", (this.settings.button_placeholder ? "Set" : "Not Set"), "\n",
|
||||||
|
"\t", "button_image_url: ", this.settings.button_image_url.toString(), "\n",
|
||||||
|
"\t", "button_width: ", this.settings.button_width.toString(), "\n",
|
||||||
|
"\t", "button_height: ", this.settings.button_height.toString(), "\n",
|
||||||
|
"\t", "button_text: ", this.settings.button_text.toString(), "\n",
|
||||||
|
"\t", "button_text_style: ", this.settings.button_text_style.toString(), "\n",
|
||||||
|
"\t", "button_text_top_padding: ", this.settings.button_text_top_padding.toString(), "\n",
|
||||||
|
"\t", "button_text_left_padding: ", this.settings.button_text_left_padding.toString(), "\n",
|
||||||
|
"\t", "button_action: ", this.settings.button_action.toString(), "\n",
|
||||||
|
"\t", "button_disabled: ", this.settings.button_disabled.toString(), "\n",
|
||||||
|
|
||||||
|
"\t", "custom_settings: ", this.settings.custom_settings.toString(), "\n",
|
||||||
|
"Event Handlers:\n",
|
||||||
|
"\t", "swfupload_loaded_handler assigned: ", (typeof this.settings.swfupload_loaded_handler === "function").toString(), "\n",
|
||||||
|
"\t", "file_dialog_start_handler assigned: ", (typeof this.settings.file_dialog_start_handler === "function").toString(), "\n",
|
||||||
|
"\t", "file_queued_handler assigned: ", (typeof this.settings.file_queued_handler === "function").toString(), "\n",
|
||||||
|
"\t", "file_queue_error_handler assigned: ", (typeof this.settings.file_queue_error_handler === "function").toString(), "\n",
|
||||||
|
"\t", "upload_start_handler assigned: ", (typeof this.settings.upload_start_handler === "function").toString(), "\n",
|
||||||
|
"\t", "upload_progress_handler assigned: ", (typeof this.settings.upload_progress_handler === "function").toString(), "\n",
|
||||||
|
"\t", "upload_error_handler assigned: ", (typeof this.settings.upload_error_handler === "function").toString(), "\n",
|
||||||
|
"\t", "upload_success_handler assigned: ", (typeof this.settings.upload_success_handler === "function").toString(), "\n",
|
||||||
|
"\t", "upload_complete_handler assigned: ", (typeof this.settings.upload_complete_handler === "function").toString(), "\n",
|
||||||
|
"\t", "debug_handler assigned: ", (typeof this.settings.debug_handler === "function").toString(), "\n"
|
||||||
|
].join("")
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Note: addSetting and getSetting are no longer used by SWFUpload but are included
|
||||||
|
the maintain v2 API compatibility
|
||||||
|
*/
|
||||||
|
// Public: (Deprecated) addSetting adds a setting value. If the value given is undefined or null then the default_value is used.
|
||||||
|
SWFUpload.prototype.addSetting = function (name, value, default_value) {
|
||||||
|
if (value == undefined) {
|
||||||
|
return (this.settings[name] = default_value);
|
||||||
|
} else {
|
||||||
|
return (this.settings[name] = value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: (Deprecated) getSetting gets a setting. Returns an empty string if the setting was not found.
|
||||||
|
SWFUpload.prototype.getSetting = function (name) {
|
||||||
|
if (this.settings[name] != undefined) {
|
||||||
|
return this.settings[name];
|
||||||
|
}
|
||||||
|
|
||||||
|
return "";
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Private: callFlash handles function calls made to the Flash element.
|
||||||
|
// Calls are made with a setTimeout for some functions to work around
|
||||||
|
// bugs in the ExternalInterface library.
|
||||||
|
SWFUpload.prototype.callFlash = function (functionName, argumentArray) {
|
||||||
|
argumentArray = argumentArray || [];
|
||||||
|
|
||||||
|
var movieElement = this.getMovieElement();
|
||||||
|
var returnValue, returnString;
|
||||||
|
|
||||||
|
// Flash's method if calling ExternalInterface methods (code adapted from MooTools).
|
||||||
|
try {
|
||||||
|
returnString = movieElement.CallFunction('<invoke name="' + functionName + '" returntype="javascript">' + __flash__argumentsToXML(argumentArray, 0) + '</invoke>');
|
||||||
|
returnValue = eval(returnString);
|
||||||
|
} catch (ex) {
|
||||||
|
throw "Call to " + functionName + " failed";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unescape file post param values
|
||||||
|
if (returnValue != undefined && typeof returnValue.post === "object") {
|
||||||
|
returnValue = this.unescapeFilePostParams(returnValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
return returnValue;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* *****************************
|
||||||
|
-- Flash control methods --
|
||||||
|
Your UI should use these
|
||||||
|
to operate SWFUpload
|
||||||
|
***************************** */
|
||||||
|
|
||||||
|
// WARNING: this function does not work in Flash Player 10
|
||||||
|
// Public: selectFile causes a File Selection Dialog window to appear. This
|
||||||
|
// dialog only allows 1 file to be selected.
|
||||||
|
SWFUpload.prototype.selectFile = function () {
|
||||||
|
this.callFlash("SelectFile");
|
||||||
|
};
|
||||||
|
|
||||||
|
// WARNING: this function does not work in Flash Player 10
|
||||||
|
// Public: selectFiles causes a File Selection Dialog window to appear/ This
|
||||||
|
// dialog allows the user to select any number of files
|
||||||
|
// Flash Bug Warning: Flash limits the number of selectable files based on the combined length of the file names.
|
||||||
|
// If the selection name length is too long the dialog will fail in an unpredictable manner. There is no work-around
|
||||||
|
// for this bug.
|
||||||
|
SWFUpload.prototype.selectFiles = function () {
|
||||||
|
this.callFlash("SelectFiles");
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// Public: startUpload starts uploading the first file in the queue unless
|
||||||
|
// the optional parameter 'fileID' specifies the ID
|
||||||
|
SWFUpload.prototype.startUpload = function (fileID) {
|
||||||
|
this.callFlash("StartUpload", [fileID]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: cancelUpload cancels any queued file. The fileID parameter may be the file ID or index.
|
||||||
|
// If you do not specify a fileID the current uploading file or first file in the queue is cancelled.
|
||||||
|
// If you do not want the uploadError event to trigger you can specify false for the triggerErrorEvent parameter.
|
||||||
|
SWFUpload.prototype.cancelUpload = function (fileID, triggerErrorEvent) {
|
||||||
|
if (triggerErrorEvent !== false) {
|
||||||
|
triggerErrorEvent = true;
|
||||||
|
}
|
||||||
|
this.callFlash("CancelUpload", [fileID, triggerErrorEvent]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: stopUpload stops the current upload and requeues the file at the beginning of the queue.
|
||||||
|
// If nothing is currently uploading then nothing happens.
|
||||||
|
SWFUpload.prototype.stopUpload = function () {
|
||||||
|
this.callFlash("StopUpload");
|
||||||
|
};
|
||||||
|
|
||||||
|
/* ************************
|
||||||
|
* Settings methods
|
||||||
|
* These methods change the SWFUpload settings.
|
||||||
|
* SWFUpload settings should not be changed directly on the settings object
|
||||||
|
* since many of the settings need to be passed to Flash in order to take
|
||||||
|
* effect.
|
||||||
|
* *********************** */
|
||||||
|
|
||||||
|
// Public: getStats gets the file statistics object.
|
||||||
|
SWFUpload.prototype.getStats = function () {
|
||||||
|
return this.callFlash("GetStats");
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setStats changes the SWFUpload statistics. You shouldn't need to
|
||||||
|
// change the statistics but you can. Changing the statistics does not
|
||||||
|
// affect SWFUpload accept for the successful_uploads count which is used
|
||||||
|
// by the upload_limit setting to determine how many files the user may upload.
|
||||||
|
SWFUpload.prototype.setStats = function (statsObject) {
|
||||||
|
this.callFlash("SetStats", [statsObject]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: getFile retrieves a File object by ID or Index. If the file is
|
||||||
|
// not found then 'null' is returned.
|
||||||
|
SWFUpload.prototype.getFile = function (fileID) {
|
||||||
|
if (typeof(fileID) === "number") {
|
||||||
|
return this.callFlash("GetFileByIndex", [fileID]);
|
||||||
|
} else {
|
||||||
|
return this.callFlash("GetFile", [fileID]);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: addFileParam sets a name/value pair that will be posted with the
|
||||||
|
// file specified by the Files ID. If the name already exists then the
|
||||||
|
// exiting value will be overwritten.
|
||||||
|
SWFUpload.prototype.addFileParam = function (fileID, name, value) {
|
||||||
|
return this.callFlash("AddFileParam", [fileID, name, value]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: removeFileParam removes a previously set (by addFileParam) name/value
|
||||||
|
// pair from the specified file.
|
||||||
|
SWFUpload.prototype.removeFileParam = function (fileID, name) {
|
||||||
|
this.callFlash("RemoveFileParam", [fileID, name]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setUploadUrl changes the upload_url setting.
|
||||||
|
SWFUpload.prototype.setUploadURL = function (url) {
|
||||||
|
this.settings.upload_url = url.toString();
|
||||||
|
this.callFlash("SetUploadURL", [url]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setPostParams changes the post_params setting
|
||||||
|
SWFUpload.prototype.setPostParams = function (paramsObject) {
|
||||||
|
this.settings.post_params = paramsObject;
|
||||||
|
this.callFlash("SetPostParams", [paramsObject]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: addPostParam adds post name/value pair. Each name can have only one value.
|
||||||
|
SWFUpload.prototype.addPostParam = function (name, value) {
|
||||||
|
this.settings.post_params[name] = value;
|
||||||
|
this.callFlash("SetPostParams", [this.settings.post_params]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: removePostParam deletes post name/value pair.
|
||||||
|
SWFUpload.prototype.removePostParam = function (name) {
|
||||||
|
delete this.settings.post_params[name];
|
||||||
|
this.callFlash("SetPostParams", [this.settings.post_params]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setFileTypes changes the file_types setting and the file_types_description setting
|
||||||
|
SWFUpload.prototype.setFileTypes = function (types, description) {
|
||||||
|
this.settings.file_types = types;
|
||||||
|
this.settings.file_types_description = description;
|
||||||
|
this.callFlash("SetFileTypes", [types, description]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setFileSizeLimit changes the file_size_limit setting
|
||||||
|
SWFUpload.prototype.setFileSizeLimit = function (fileSizeLimit) {
|
||||||
|
this.settings.file_size_limit = fileSizeLimit;
|
||||||
|
this.callFlash("SetFileSizeLimit", [fileSizeLimit]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setFileUploadLimit changes the file_upload_limit setting
|
||||||
|
SWFUpload.prototype.setFileUploadLimit = function (fileUploadLimit) {
|
||||||
|
this.settings.file_upload_limit = fileUploadLimit;
|
||||||
|
this.callFlash("SetFileUploadLimit", [fileUploadLimit]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setFileQueueLimit changes the file_queue_limit setting
|
||||||
|
SWFUpload.prototype.setFileQueueLimit = function (fileQueueLimit) {
|
||||||
|
this.settings.file_queue_limit = fileQueueLimit;
|
||||||
|
this.callFlash("SetFileQueueLimit", [fileQueueLimit]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setFilePostName changes the file_post_name setting
|
||||||
|
SWFUpload.prototype.setFilePostName = function (filePostName) {
|
||||||
|
this.settings.file_post_name = filePostName;
|
||||||
|
this.callFlash("SetFilePostName", [filePostName]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setUseQueryString changes the use_query_string setting
|
||||||
|
SWFUpload.prototype.setUseQueryString = function (useQueryString) {
|
||||||
|
this.settings.use_query_string = useQueryString;
|
||||||
|
this.callFlash("SetUseQueryString", [useQueryString]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setRequeueOnError changes the requeue_on_error setting
|
||||||
|
SWFUpload.prototype.setRequeueOnError = function (requeueOnError) {
|
||||||
|
this.settings.requeue_on_error = requeueOnError;
|
||||||
|
this.callFlash("SetRequeueOnError", [requeueOnError]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setHTTPSuccess changes the http_success setting
|
||||||
|
SWFUpload.prototype.setHTTPSuccess = function (http_status_codes) {
|
||||||
|
if (typeof http_status_codes === "string") {
|
||||||
|
http_status_codes = http_status_codes.replace(" ", "").split(",");
|
||||||
|
}
|
||||||
|
|
||||||
|
this.settings.http_success = http_status_codes;
|
||||||
|
this.callFlash("SetHTTPSuccess", [http_status_codes]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setHTTPSuccess changes the http_success setting
|
||||||
|
SWFUpload.prototype.setAssumeSuccessTimeout = function (timeout_seconds) {
|
||||||
|
this.settings.assume_success_timeout = timeout_seconds;
|
||||||
|
this.callFlash("SetAssumeSuccessTimeout", [timeout_seconds]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setDebugEnabled changes the debug_enabled setting
|
||||||
|
SWFUpload.prototype.setDebugEnabled = function (debugEnabled) {
|
||||||
|
this.settings.debug_enabled = debugEnabled;
|
||||||
|
this.callFlash("SetDebugEnabled", [debugEnabled]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setButtonImageURL loads a button image sprite
|
||||||
|
SWFUpload.prototype.setButtonImageURL = function (buttonImageURL) {
|
||||||
|
if (buttonImageURL == undefined) {
|
||||||
|
buttonImageURL = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
this.settings.button_image_url = buttonImageURL;
|
||||||
|
this.callFlash("SetButtonImageURL", [buttonImageURL]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setButtonDimensions resizes the Flash Movie and button
|
||||||
|
SWFUpload.prototype.setButtonDimensions = function (width, height) {
|
||||||
|
this.settings.button_width = width;
|
||||||
|
this.settings.button_height = height;
|
||||||
|
|
||||||
|
var movie = this.getMovieElement();
|
||||||
|
if (movie != undefined) {
|
||||||
|
movie.style.width = width + "px";
|
||||||
|
movie.style.height = height + "px";
|
||||||
|
}
|
||||||
|
|
||||||
|
this.callFlash("SetButtonDimensions", [width, height]);
|
||||||
|
};
|
||||||
|
// Public: setButtonText Changes the text overlaid on the button
|
||||||
|
SWFUpload.prototype.setButtonText = function (html) {
|
||||||
|
this.settings.button_text = html;
|
||||||
|
this.callFlash("SetButtonText", [html]);
|
||||||
|
};
|
||||||
|
// Public: setButtonTextPadding changes the top and left padding of the text overlay
|
||||||
|
SWFUpload.prototype.setButtonTextPadding = function (left, top) {
|
||||||
|
this.settings.button_text_top_padding = top;
|
||||||
|
this.settings.button_text_left_padding = left;
|
||||||
|
this.callFlash("SetButtonTextPadding", [left, top]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setButtonTextStyle changes the CSS used to style the HTML/Text overlaid on the button
|
||||||
|
SWFUpload.prototype.setButtonTextStyle = function (css) {
|
||||||
|
this.settings.button_text_style = css;
|
||||||
|
this.callFlash("SetButtonTextStyle", [css]);
|
||||||
|
};
|
||||||
|
// Public: setButtonDisabled disables/enables the button
|
||||||
|
SWFUpload.prototype.setButtonDisabled = function (isDisabled) {
|
||||||
|
this.settings.button_disabled = isDisabled;
|
||||||
|
this.callFlash("SetButtonDisabled", [isDisabled]);
|
||||||
|
};
|
||||||
|
// Public: setButtonAction sets the action that occurs when the button is clicked
|
||||||
|
SWFUpload.prototype.setButtonAction = function (buttonAction) {
|
||||||
|
this.settings.button_action = buttonAction;
|
||||||
|
this.callFlash("SetButtonAction", [buttonAction]);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public: setButtonCursor changes the mouse cursor displayed when hovering over the button
|
||||||
|
SWFUpload.prototype.setButtonCursor = function (cursor) {
|
||||||
|
this.settings.button_cursor = cursor;
|
||||||
|
this.callFlash("SetButtonCursor", [cursor]);
|
||||||
|
};
|
||||||
|
|
||||||
|
/* *******************************
|
||||||
|
Flash Event Interfaces
|
||||||
|
These functions are used by Flash to trigger the various
|
||||||
|
events.
|
||||||
|
|
||||||
|
All these functions a Private.
|
||||||
|
|
||||||
|
Because the ExternalInterface library is buggy the event calls
|
||||||
|
are added to a queue and the queue then executed by a setTimeout.
|
||||||
|
This ensures that events are executed in a determinate order and that
|
||||||
|
the ExternalInterface bugs are avoided.
|
||||||
|
******************************* */
|
||||||
|
|
||||||
|
SWFUpload.prototype.queueEvent = function (handlerName, argumentArray) {
|
||||||
|
// Warning: Don't call this.debug inside here or you'll create an infinite loop
|
||||||
|
|
||||||
|
if (argumentArray == undefined) {
|
||||||
|
argumentArray = [];
|
||||||
|
} else if (!(argumentArray instanceof Array)) {
|
||||||
|
argumentArray = [argumentArray];
|
||||||
|
}
|
||||||
|
|
||||||
|
var self = this;
|
||||||
|
if (typeof this.settings[handlerName] === "function") {
|
||||||
|
// Queue the event
|
||||||
|
this.eventQueue.push(function () {
|
||||||
|
this.settings[handlerName].apply(this, argumentArray);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Execute the next queued event
|
||||||
|
setTimeout(function () {
|
||||||
|
self.executeNextEvent();
|
||||||
|
}, 0);
|
||||||
|
|
||||||
|
} else if (this.settings[handlerName] !== null) {
|
||||||
|
throw "Event handler " + handlerName + " is unknown or is not a function";
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: Causes the next event in the queue to be executed. Since events are queued using a setTimeout
|
||||||
|
// we must queue them in order to garentee that they are executed in order.
|
||||||
|
SWFUpload.prototype.executeNextEvent = function () {
|
||||||
|
// Warning: Don't call this.debug inside here or you'll create an infinite loop
|
||||||
|
|
||||||
|
var f = this.eventQueue ? this.eventQueue.shift() : null;
|
||||||
|
if (typeof(f) === "function") {
|
||||||
|
f.apply(this);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: unescapeFileParams is part of a workaround for a flash bug where objects passed through ExternalInterface cannot have
|
||||||
|
// properties that contain characters that are not valid for JavaScript identifiers. To work around this
|
||||||
|
// the Flash Component escapes the parameter names and we must unescape again before passing them along.
|
||||||
|
SWFUpload.prototype.unescapeFilePostParams = function (file) {
|
||||||
|
var reg = /[$]([0-9a-f]{4})/i;
|
||||||
|
var unescapedPost = {};
|
||||||
|
var uk;
|
||||||
|
|
||||||
|
if (file != undefined) {
|
||||||
|
for (var k in file.post) {
|
||||||
|
if (file.post.hasOwnProperty(k)) {
|
||||||
|
uk = k;
|
||||||
|
var match;
|
||||||
|
while ((match = reg.exec(uk)) !== null) {
|
||||||
|
uk = uk.replace(match[0], String.fromCharCode(parseInt("0x" + match[1], 16)));
|
||||||
|
}
|
||||||
|
unescapedPost[uk] = file.post[k];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
file.post = unescapedPost;
|
||||||
|
}
|
||||||
|
|
||||||
|
return file;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: Called by Flash to see if JS can call in to Flash (test if External Interface is working)
|
||||||
|
SWFUpload.prototype.testExternalInterface = function () {
|
||||||
|
try {
|
||||||
|
return this.callFlash("TestExternalInterface");
|
||||||
|
} catch (ex) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: This event is called by Flash when it has finished loading. Don't modify this.
|
||||||
|
// Use the swfupload_loaded_handler event setting to execute custom code when SWFUpload has loaded.
|
||||||
|
SWFUpload.prototype.flashReady = function () {
|
||||||
|
// Check that the movie element is loaded correctly with its ExternalInterface methods defined
|
||||||
|
var movieElement = this.getMovieElement();
|
||||||
|
|
||||||
|
if (!movieElement) {
|
||||||
|
this.debug("Flash called back ready but the flash movie can't be found.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.cleanUp(movieElement);
|
||||||
|
|
||||||
|
this.queueEvent("swfupload_loaded_handler");
|
||||||
|
};
|
||||||
|
|
||||||
|
// Private: removes Flash added fuctions to the DOM node to prevent memory leaks in IE.
|
||||||
|
// This function is called by Flash each time the ExternalInterface functions are created.
|
||||||
|
SWFUpload.prototype.cleanUp = function (movieElement) {
|
||||||
|
// Pro-actively unhook all the Flash functions
|
||||||
|
try {
|
||||||
|
if (this.movieElement && typeof(movieElement.CallFunction) === "unknown") { // We only want to do this in IE
|
||||||
|
this.debug("Removing Flash functions hooks (this should only run in IE and should prevent memory leaks)");
|
||||||
|
for (var key in movieElement) {
|
||||||
|
try {
|
||||||
|
if (typeof(movieElement[key]) === "function") {
|
||||||
|
movieElement[key] = null;
|
||||||
|
}
|
||||||
|
} catch (ex) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (ex1) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fix Flashes own cleanup code so if the SWFMovie was removed from the page
|
||||||
|
// it doesn't display errors.
|
||||||
|
window["__flash__removeCallback"] = function (instance, name) {
|
||||||
|
try {
|
||||||
|
if (instance) {
|
||||||
|
instance[name] = null;
|
||||||
|
}
|
||||||
|
} catch (flashEx) {
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* This is a chance to do something before the browse window opens */
|
||||||
|
SWFUpload.prototype.fileDialogStart = function () {
|
||||||
|
this.queueEvent("file_dialog_start_handler");
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* Called when a file is successfully added to the queue. */
|
||||||
|
SWFUpload.prototype.fileQueued = function (file) {
|
||||||
|
file = this.unescapeFilePostParams(file);
|
||||||
|
this.queueEvent("file_queued_handler", file);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* Handle errors that occur when an attempt to queue a file fails. */
|
||||||
|
SWFUpload.prototype.fileQueueError = function (file, errorCode, message) {
|
||||||
|
file = this.unescapeFilePostParams(file);
|
||||||
|
this.queueEvent("file_queue_error_handler", [file, errorCode, message]);
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Called after the file dialog has closed and the selected files have been queued.
|
||||||
|
You could call startUpload here if you want the queued files to begin uploading immediately. */
|
||||||
|
SWFUpload.prototype.fileDialogComplete = function (numFilesSelected, numFilesQueued, numFilesInQueue) {
|
||||||
|
this.queueEvent("file_dialog_complete_handler", [numFilesSelected, numFilesQueued, numFilesInQueue]);
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.prototype.uploadStart = function (file) {
|
||||||
|
file = this.unescapeFilePostParams(file);
|
||||||
|
this.queueEvent("return_upload_start_handler", file);
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.prototype.returnUploadStart = function (file) {
|
||||||
|
var returnValue;
|
||||||
|
if (typeof this.settings.upload_start_handler === "function") {
|
||||||
|
file = this.unescapeFilePostParams(file);
|
||||||
|
returnValue = this.settings.upload_start_handler.call(this, file);
|
||||||
|
} else if (this.settings.upload_start_handler != undefined) {
|
||||||
|
throw "upload_start_handler must be a function";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Convert undefined to true so if nothing is returned from the upload_start_handler it is
|
||||||
|
// interpretted as 'true'.
|
||||||
|
if (returnValue === undefined) {
|
||||||
|
returnValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
returnValue = !!returnValue;
|
||||||
|
|
||||||
|
this.callFlash("ReturnUploadStart", [returnValue]);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
SWFUpload.prototype.uploadProgress = function (file, bytesComplete, bytesTotal) {
|
||||||
|
file = this.unescapeFilePostParams(file);
|
||||||
|
this.queueEvent("upload_progress_handler", [file, bytesComplete, bytesTotal]);
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.prototype.uploadError = function (file, errorCode, message) {
|
||||||
|
file = this.unescapeFilePostParams(file);
|
||||||
|
this.queueEvent("upload_error_handler", [file, errorCode, message]);
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.prototype.uploadSuccess = function (file, serverData, responseReceived) {
|
||||||
|
file = this.unescapeFilePostParams(file);
|
||||||
|
this.queueEvent("upload_success_handler", [file, serverData, responseReceived]);
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.prototype.uploadComplete = function (file) {
|
||||||
|
file = this.unescapeFilePostParams(file);
|
||||||
|
this.queueEvent("upload_complete_handler", file);
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Called by SWFUpload JavaScript and Flash functions when debug is enabled. By default it writes messages to the
|
||||||
|
internal debug console. You can override this event and have messages written where you want. */
|
||||||
|
SWFUpload.prototype.debug = function (message) {
|
||||||
|
this.queueEvent("debug_handler", message);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* **********************************
|
||||||
|
Debug Console
|
||||||
|
The debug console is a self contained, in page location
|
||||||
|
for debug message to be sent. The Debug Console adds
|
||||||
|
itself to the body if necessary.
|
||||||
|
|
||||||
|
The console is automatically scrolled as messages appear.
|
||||||
|
|
||||||
|
If you are using your own debug handler or when you deploy to production and
|
||||||
|
have debug disabled you can remove these functions to reduce the file size
|
||||||
|
and complexity.
|
||||||
|
********************************** */
|
||||||
|
|
||||||
|
// Private: debugMessage is the default debug_handler. If you want to print debug messages
|
||||||
|
// call the debug() function. When overriding the function your own function should
|
||||||
|
// check to see if the debug setting is true before outputting debug information.
|
||||||
|
SWFUpload.prototype.debugMessage = function (message) {
|
||||||
|
if (this.settings.debug) {
|
||||||
|
var exceptionMessage, exceptionValues = [];
|
||||||
|
|
||||||
|
// Check for an exception object and print it nicely
|
||||||
|
if (typeof message === "object" && typeof message.name === "string" && typeof message.message === "string") {
|
||||||
|
for (var key in message) {
|
||||||
|
if (message.hasOwnProperty(key)) {
|
||||||
|
exceptionValues.push(key + ": " + message[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exceptionMessage = exceptionValues.join("\n") || "";
|
||||||
|
exceptionValues = exceptionMessage.split("\n");
|
||||||
|
exceptionMessage = "EXCEPTION: " + exceptionValues.join("\nEXCEPTION: ");
|
||||||
|
SWFUpload.Console.writeLine(exceptionMessage);
|
||||||
|
} else {
|
||||||
|
SWFUpload.Console.writeLine(message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SWFUpload.Console = {};
|
||||||
|
SWFUpload.Console.writeLine = function (message) {
|
||||||
|
var console, documentForm;
|
||||||
|
|
||||||
|
try {
|
||||||
|
console = document.getElementById("SWFUpload_Console");
|
||||||
|
|
||||||
|
if (!console) {
|
||||||
|
documentForm = document.createElement("form");
|
||||||
|
document.getElementsByTagName("body")[0].appendChild(documentForm);
|
||||||
|
|
||||||
|
console = document.createElement("textarea");
|
||||||
|
console.id = "SWFUpload_Console";
|
||||||
|
console.style.fontFamily = "monospace";
|
||||||
|
console.setAttribute("wrap", "off");
|
||||||
|
console.wrap = "off";
|
||||||
|
console.style.overflow = "auto";
|
||||||
|
console.style.width = "700px";
|
||||||
|
console.style.height = "350px";
|
||||||
|
console.style.margin = "5px";
|
||||||
|
documentForm.appendChild(console);
|
||||||
|
}
|
||||||
|
|
||||||
|
console.value += message + "\n";
|
||||||
|
|
||||||
|
console.scrollTop = console.scrollHeight - console.clientHeight;
|
||||||
|
} catch (ex) {
|
||||||
|
alert("Exception: " + ex.name + " Message: " + ex.message);
|
||||||
|
}
|
||||||
|
};
|
BIN
www/include/jslibs/SWFUpload/swfupload.swf
Normal file
BIN
www/include/jslibs/SWFUpload/swfupload.swf
Normal file
Binary file not shown.
@@ -140,6 +140,10 @@ $groups = array(
|
|||||||
, '//include/jquery.common.js'
|
, '//include/jquery.common.js'
|
||||||
, '//skins/lightbox/jquery.lightbox.ie6.js'
|
, '//skins/lightbox/jquery.lightbox.ie6.js'
|
||||||
, '//include/jslibs/flowplayer/flowplayer-3.2.11.min.js'
|
, '//include/jslibs/flowplayer/flowplayer-3.2.11.min.js'
|
||||||
|
),
|
||||||
|
'uploadflash' => array(
|
||||||
|
'//include/jslibs/SWFUpload/swfupload.js'
|
||||||
|
, '//include/jslibs/SWFUpload/plugins/swfupload.queue.js'
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
BIN
www/skins/icons/theme_button_background.png
Normal file
BIN
www/skins/icons/theme_button_background.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.3 KiB |
Reference in New Issue
Block a user