/*/*
* Unobstrusive swf upload widget using jQuery.
*example : $(':file.uo_widget_form_input_file_swf_upload').uoWidgetFormInputFileSwfUpload({});
*
* @author François Béliveau <francois.beliveau@my-labz.com>
**/
var uo_widget_form_input_file_swf_upload_config = {};
var uo_widget_form_input_file_swf_upload_count = 0;
(function($) { $.fn.uoWidgetFormInputFileSwfUpload = function(customConfiguration)
{
// default configuration
var configuration = {
labels: {
browse: 'browse'
},
images: {
browse: '/sf_unobstrusive_widget/images/default/uo_widget_form_input_file_swf_upload/folder_explore.png'
},
upload_auto: false,
upload_url: false,
file_post_name: 'swf_upload_file', // Flash file settings
file_size_limit: '10240', //10 MB
file_types: '*.*',
file_types_description: 'All files',
file_upload_limit: '0',
file_queue_limit: '1', // Button Settings
button_width: 16,
button_height: 16, // Flash Settings
flash_url : "/sf_unobstrusive_widget/vendor/swf_upload/swfupload.swf", // Debug settings
debug: false
}; $.extend(true, configuration, customConfiguration); return this.each(function(index)
{
var $widget = $(this);
var $widgetId = $widget.attr('id');
var $widgetName = $widget.attr('name');
var $widgetFileName = false;
var $swfUpload = false;
var $index = uo_widget_form_input_file_swf_upload_count;
var handlers = {
swfupload_loaded_handler: false,
file_dialog_start_handler: false,
file_queue_error_handler: false,
file_dialog_complete_handler: false,
upload_start_handler: false,
upload_progress_handler: false,
upload_error_handler: false,
upload_success_handler: false,
upload_complete_handler: false,
file_queued_handler: false,
swfupload_loaded_handler: false,
swfupload_loaded_handler: false
}; // merge default and custom configuration
if (typeof(uo_widget_form_input_file_swf_upload_config[$widgetId]) == 'object')
{
for (handlerName in handlers)
{
if (typeof(uo_widget_form_input_file_swf_upload_config[$widgetId][handlerName]) == 'function')
{
handlers[handlerName] = uo_widget_form_input_file_swf_upload_config[$widgetId][handlerName];
}
}
} /**
* Initialize widget
*/
function init()
{
// prevent initialize twice
if ($widget.hasClass('uo_widget_form_input_file_swf_upload_ON'))
{
return $widget;
} if (typeof(SWFUpload) != "function")
{
alert('Unable to initialize SWFUpload widget: SWFUpload is not defined');
return $widget;
} $widget.removeClass('uo_widget_form_input_file_swf_upload');
$widget.addClass('uo_widget_form_input_file_swf_upload_ON'); config = getConfiguration();
if (config.upload_url)
{
$widget.after(getHtmlTemplate(config))
var newWidget = $widget.next();
$widget.remove(); $widget = newWidget;
$widgetFileName = $('#'+$widgetId); $swfUpload = new SWFUpload(config);
uo_widget_form_input_file_swf_upload_count++;
}
else
{
alert('Unable to initialize SWFUpload widget: invalid upload url');
}
} /**
* Return widget's specific configuration
*/
function getConfiguration()
{
var result = uo_widget_form_input_file_swf_upload_config[$widgetId] || {};
result = $.extend(true, configuration, result); // Event handler settings
result.swfupload_loaded_handler = swfUploadLoaded,
result.file_dialog_start_handler = fileDialogStart;
result.file_queue_error_handler = fileQueueError;
result.file_dialog_complete_handler = fileDialogComplete;
result.upload_start_handler = uploadStart;
result.upload_progress_handler = uploadProgress;
result.upload_error_handler = uploadError;
result.upload_success_handler = uploadSuccess;
result.upload_complete_handler = uploadComplete; if (undefined == result.custom_settings)
{
result.custom_settings = {};
}
result.custom_settings.progress_target = $widgetId+'_flash',
result.custom_settings.upload_successful = false; result.button_window_mode = SWFUpload.WINDOW_MODE.TRANSPARENT; result.button_placeholder_id = $widgetId+'_browse';
if (result.images.browse)
{
result.button_image_url = result.images.browse;
}
else
{
result.button_text = result.labels.browse;
} if (result.upload_auto)
{
result.file_queued_handler = fileQueuedAutoUpload;
}
else
{
result.file_queued_handler = fileQueued;
} return result
} /**
* Return widget's HTML template
*/
function getHtmlTemplate(config)
{
result = '<div class="uo_widget_form_input_file_swf_upload_ON_container">'
+ ' <div class="field">'
+ ' <input id="'+$widgetId+'" type="text" class="text" readonly="readonly" />'
+ ' <span id="'+$widgetId+'_browse">'+config.labels.browse+'</span>'
+ ' </div>'
//This is where the file progress gets shown
+ ' <div class="flash" id="'+$widgetId+'_flash"></div>'
//This is where the file ID is stored after SWFUpload uploads the file and gets the ID back from upload PHP script
+ ' <input type="hidden" name="'+$widgetName+'" value="" />'
+ '</div>' return $(result);
} /**
* Start upload
*/
function doUpload(e)
{
try
{
$swfUpload.startUpload();
}
catch(ex){} return false;
} /**
* Called by the queue complete handler to submit the form
*/
function uploadDone()
{
try
{
$swfUpload.destroy();
$widget.parents('form:first')
.unbind('submit', doUpload)
.submit();
}
catch(ex)
{
alert("Error submitting form");
}
} /**
* Cancel upload if allready start
*/
function fileDialogStart()
{
$swfUpload.cancelUpload(); if (typeof(handlers.file_dialog_start_handler) == 'function')
{
handlers.file_dialog_start_handler();
}
} /**
* Handle this error separately because we don't want to create a FileProgress element for it.
*/
function fileQueueError(file, errorCode, message)
{
try
{
switch (errorCode)
{
case SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED:
alert("You have attempted to queue too many files.\n" + (message === 0 ? "You have reached the upload limit." : "You may select " + (message > 1 ? "up to " + message + " files." : "one file.")));
return false;
case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT:
alert("The file you selected is too big.");
this.debug("Error Code: File too big, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
return false;
case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:
alert("The file you selected is empty. Please select another file.");
this.debug("Error Code: Zero byte file, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
return false;
case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE:
alert("The file you choose is not an allowed file type.");
this.debug("Error Code: Invalid File Type, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
return false;
default:
alert("An error occurred in the upload. Try again later.");
this.debug("Error Code: " + errorCode + ", File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
return false;
}
}
catch(e){} if (typeof(handlers.file_queue_error_handler) == 'function')
{
handlers.file_queue_error_handler(file, errorCode, message);
}
} function fileQueued(file)
{
$widget.parents('form:first')
.unbind('submit', doUpload)
.submit(doUpload);
$widgetFileName.val(file.name); if (typeof(handlers.file_queued_handler) == 'function')
{
handlers.file_queued_handler(file);
}
} function fileQueuedAutoUpload(file)
{
$widgetFileName.val(file.name);
doUpload(); if (typeof(handlers.file_queued_handler) == 'function')
{
handlers.file_queued_handler(file);
}
} function uploadProgress(file, bytesLoaded, totalBytes)
{
try
{
var percent = Math.ceil((bytesLoaded / bytesTotal) * 100); file.id = "singlefile"; // This makes it so FileProgress only makes a single UI element, instead of one for each file
var progress = new FileProgress(file, this.customSettings.progress_target);
progress.setProgress(percent);
progress.setStatus("Uploading...");
}
catch(e){} if (typeof(handlers.upload_progress_handler) == 'function')
{
handlers.upload_progress_handler(file, bytesLoaded, totalBytes);
}
} function uploadSuccess(file, serverData, receivedResponse)
{
try
{
file.id = "singlefile"; // This makes it so FileProgress only makes a single UI element, instead of one for each file
var progress = new FileProgress(file, this.customSettings.progress_target);
progress.setComplete();
progress.setStatus("Complete.");
progress.toggleCancel(false); if (serverData === " ")
{
this.customSettings.upload_successful = false;
}
else
{
this.customSettings.upload_successful = true;
$('input[name="'+$widgetName+'"]', $widget).val(serverData);
}
}
catch(e){} if (typeof(handlers.upload_success_handler) == 'function')
{
handlers.upload_success_handler(file, serverData, receivedResponse);
}
} function uploadComplete(file)
{
try
{
if (this.customSettings.upload_successful)
{
var config = getConfiguration();
if (!config.upload_auto)
{
uploadDone();
}
}
else
{
file.id = "singlefile"; // This makes it so FileProgress only makes a single UI element, instead of one for each file
var progress = new FileProgress(file, this.customSettings.progress_target);
progress.setError();
progress.setStatus("File rejected");
progress.toggleCancel(false); $widgetFileName.val(''); alert("There was a problem with the upload.\nThe server did not accept it.");
}
}
catch(e){} if (typeof(handlers.upload_complete_handler) == 'function')
{
handlers.upload_complete_handler(file);
}
} function uploadError(file, errorCode, message)
{
try
{
if (errorCode === SWFUpload.UPLOAD_ERROR.FILE_CANCELLED)
{
// Don't show cancelled error boxes
return;
} $widgetFileName.val(''); // Handle this error separately because we don't want to create a FileProgress element for it.
switch (errorCode)
{
case SWFUpload.UPLOAD_ERROR.MISSING_UPLOAD_URL:
alert("There was a configuration error. You will not be able to upload a resume at this time.");
this.debug("Error Code: No backend file, File name: " + file.name + ", Message: " + message);
return;
case SWFUpload.UPLOAD_ERROR.UPLOAD_LIMIT_EXCEEDED:
alert("You may only upload 1 file.");
this.debug("Error Code: Upload Limit Exceeded, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
return;
case SWFUpload.UPLOAD_ERROR.FILE_CANCELLED:
case SWFUpload.UPLOAD_ERROR.UPLOAD_STOPPED:
break;
default:
alert("An error occurred in the upload. Try again later.");
this.debug("Error Code: " + errorCode + ", File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
return;
} file.id = "singlefile"; // This makes it so FileProgress only makes a single UI element, instead of one for each file
var progress = new FileProgress(file, this.customSettings.progress_target);
progress.setError();
progress.toggleCancel(false); switch (errorCode)
{
case SWFUpload.UPLOAD_ERROR.HTTP_ERROR:
progress.setStatus("Upload Error");
this.debug("Error Code: HTTP Error, File name: " + file.name + ", Message: " + message);
break;
case SWFUpload.UPLOAD_ERROR.UPLOAD_FAILED:
progress.setStatus("Upload Failed.");
this.debug("Error Code: Upload Failed, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
break;
case SWFUpload.UPLOAD_ERROR.IO_ERROR:
progress.setStatus("Server (IO) Error");
this.debug("Error Code: IO Error, File name: " + file.name + ", Message: " + message);
break;
case SWFUpload.UPLOAD_ERROR.SECURITY_ERROR:
progress.setStatus("Security Error");
this.debug("Error Code: Security Error, File name: " + file.name + ", Message: " + message);
break;
case SWFUpload.UPLOAD_ERROR.FILE_CANCELLED:
progress.setStatus("Upload Cancelled");
this.debug("Error Code: Upload Cancelled, File name: " + file.name + ", Message: " + message);
break;
case SWFUpload.UPLOAD_ERROR.UPLOAD_STOPPED:
progress.setStatus("Upload Stopped");
this.debug("Error Code: Upload Stopped, File name: " + file.name + ", Message: " + message);
break;
}
}
catch(ex){} if (typeof(handlers.upload_error_handler) == 'function')
{
handlers.upload_error_handler(file, errorCode, message);
}

  

上传文件swfUploadConfig.js的更多相关文章

  1. OSS阿里云上传文件 前端js下载url跨域问题

    场景: 1.后端上传文件至阿里云OSS,返回得到一个URL. 2.前端用这个URL下载文件,ajax请求异常:No 'Access-Control-Allow-Origin' header is pr ...

  2. C# asp:FileUpload上传文件使用JS实现预览效果

    js代码: <script type="text/javascript"> //下面用于图片上传预览功能 function setImagePreview() { va ...

  3. fromdata上传文件,ajax上传文件, 纯js上传文件,html5文件异步上传

    前端代码: 上传附件(如支付凭证等) <input type="file" name="fileUpload" id="fileUpload&q ...

  4. JavaScript Ajax上传文件miniupload.js

    用到jquery和layer.js (function ($) { $.fn.miniupload = function (options, callback) { var jqDom = $(thi ...

  5. 阿里云 oss 上传文件,js直传,.net 签名,回调

    后台签名 添加引用 string dir = string.Format("{0:yyyy-MM-dd}", date) + "/"; OssClient cl ...

  6. 前端之web上传文件的方式

    前端之web上传文件的方式 本节内容 web上传文件方式介绍 form上传文件 原生js实现ajax上传文件 jquery实现ajax上传文件 form+iframe构造请求上传文件 1. web上传 ...

  7. 第九篇:web之前端之web上传文件的方式

    前端之web上传文件的方式   前端之web上传文件的方式 本节内容 web上传文件方式介绍 form上传文件 原生js实现ajax上传文件 jquery实现ajax上传文件 form+iframe构 ...

  8. Juploader 1.0 谷歌(chrome)浏览器中成功上传文件后返回信息异常

    在项目中使用了Juploader 1.0无刷新上传文件的js组件,在IE8以上没有问题,代码如下: function InitialUploadDirectly(OnUploadFunc, butto ...

  9. 上传文件调用webapi方式

    选择文件 <div> <label for="fileUpload"> 选择文件 </label> <br/> <input ...

随机推荐

  1. 手机版web相关meta配置

    若页面需默认用ie兼容内核,增加标签: 若页面需默认用ie标准内核,增加标签: --> 页面标题

  2. 通过php下载文件并重命名

    $filename = dirname(__FILE__) . '/oldfilename.jpg'; $out_filename = 'newfilename.jpg'; if( ! file_ex ...

  3. MVC5+EF6 入门完整教程六

    本篇我们谈谈分部视图(Partial View). 上篇文章提到过Partial和Action这两个helper, 本篇文章主要就结合这两个helper来讲解分部视图(Partial View)的应用 ...

  4. java selenium (九) 常见web UI 元素操作 及API使用

    本篇介绍我们如何利用selenium 来操作各种页面元素 阅读目录  链接(link) <div> <p>链接 link</p> <a href=" ...

  5. C语言模块化编译介绍

    C语言模块化编译介绍 模块化编程的概念 所谓模块化变成(多文件开发),就是多文件(.c文件)编程,一个.c文件和一个.h文件可以被称为一个模块. 头文件开发的注意事项: 1)头文件中可以和C程序一样引 ...

  6. MVB设备分类

    连接在MVB上的设备按性能可以分为5类 MVB上的设备应具备下面六个性能中的一个或多个. MVB设备的性能 性能 说明 分类 设备状态 设备被轮询时能够发送出其设备状态 1,2,3,4,5 过程数据 ...

  7. java中的反射机制在Android开发中的用处

    JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反 ...

  8. Haskell Platform (windows)

    一.下载地址:https://www.haskell.org/platform/windows.html Haskell Platform 整合了 Glasgow Haskell Compiler,W ...

  9. HTML5 History API 实现无刷新跳转

     在HTML5中, 1. 新增了通过JS在浏览器历史记录中添加项目的功能. 2. 在不刷新页面的前提下显示改变浏览器地址栏中的URL. 3. 添加了当用户单击浏览器的后退按钮时触发的事件. 通过以上三 ...

  10. 基本ASP的语法规则

    1.ASP 文件能够包含服务器端脚本,这些脚本被分隔符 <% 和%> 包围起来. 服务器脚本在服务器上执行,可包含合法的表达式.语句.或者运算符. 向浏览器写输出,用命令response. ...