160 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
			
		
		
	
	
			160 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="webuploader.aspx.cs" Inherits="FineUIPro.Web.AttachFile.webuploader" %>
 | ||
| <!DOCTYPE html>
 | ||
| <html>
 | ||
| <head runat="server">
 | ||
|     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 | ||
|     <title></title>
 | ||
|     <link href="../res/css/common.css" rel="stylesheet" type="text/css" />
 | ||
|     <meta name="sourcefiles" content="~/AttachFile/fileupload.ashx" />
 | ||
|     <style type="text/css">        
 | ||
|         .webuploader-element-invisible {
 | ||
|             position: absolute !important;
 | ||
|             clip: rect(1px,1px,1px,1px);
 | ||
|         }
 | ||
| 
 | ||
|         .webuploader-pick-disable {
 | ||
|             opacity: 0.6;
 | ||
|             pointer-events: none;
 | ||
|         }
 | ||
|     </style>
 | ||
| </head>
 | ||
| <body>
 | ||
|     <form id="form1" runat="server">
 | ||
|         <f:PageManager ID="PageManager1" runat="server" AutoSizePanelID="SimpleForm1"/>
 | ||
|         <f:Grid ID="Grid1" runat="server" ShowHeader="false" ShowBorder="true" Title="文件上传"
 | ||
|             Width="650px" Height="360px" EnableColumnLines="true"
 | ||
|             EnableCollapse="false" EnableCheckBoxSelect="false" EmptyText="尚未上传文件"
 | ||
|             DataIDField="id" OnRowCommand="Grid1_RowCommand">
 | ||
|             <Toolbars>
 | ||
|                 <f:Toolbar runat="server"  ID="toolBar" Hidden="true" ToolbarAlign="Right">
 | ||
|                     <Items>
 | ||
|                         <f:Button ID="btnImageMagnify" runat="server" IconFont="Inbox" Text="扫描" 
 | ||
|                             ToolTip="扫描文件"  OnClick="btnImageMagnify_Click"></f:Button>  
 | ||
|                         <f:Button ID="btnOnlineEdit" runat="server" IconFont="Edit" ToolTip="文档编辑"  Text="文档编辑"   OnClick="btnOnlineEdit_OnClick" ></f:Button>    
 | ||
| 
 | ||
|                         <f:ToolbarFill runat="server">
 | ||
|                          </f:ToolbarFill>
 | ||
|                         <f:Button ID="btnSelectFiles" Text="上传" ToolTip="选择文件上传" IconFont="Upload" runat="server" EnablePostBack="false">
 | ||
|                         </f:Button>
 | ||
|                         <f:ToolbarSeparator runat="server"></f:ToolbarSeparator>
 | ||
|                         <f:Button ID="btnDelete" Text="删除" ToolTip="删除选中文件" IconFont="Trash" runat="server" OnClick="btnDelete_Click">
 | ||
|                         </f:Button>
 | ||
|                          <f:ToolbarSeparator ID="ToolbarSeparator2" runat="server"></f:ToolbarSeparator>
 | ||
|                         <f:Button ID="btnSave" Text="保存" ToolTip="保存" IconFont="Save" runat="server" OnClick="btnSave_Click">
 | ||
|                     </f:Button>
 | ||
|                     </Items>
 | ||
|                 </f:Toolbar>
 | ||
|             </Toolbars>
 | ||
|             <Columns>
 | ||
|                 <f:LinkButtonField ColumnID="FileName" DataTextField="name" DataToolTipField="name" HeaderText="文件名" 
 | ||
|                     ExpandUnusedSpace="True" CommandName="Attach" EnableAjax="false" />
 | ||
|                 <f:BoundField ColumnID="FileType" DataField="type" HeaderText="类型" Width="100px" />
 | ||
|                 <f:RenderField ColumnID="FileSize" DataField="size" HeaderText="大小" Renderer="FileSize" Width="90px" />
 | ||
|                 <f:BoundField ColumnID='FileStatus' DataField="status" NullDisplayText="已完成" HeaderText="状态" Width="90px" />    
 | ||
|                 <f:LinkButtonField  CommandName="Preview" Width="60px" Text="预览" />
 | ||
|                 <f:LinkButtonField Width="60px" ConfirmText="你确定要删除这个文件吗?" ConfirmTarget="Parent" Text="删除"
 | ||
|                    HeaderText="删除"  CommandName="Delete" IconUrl="~/res/icon/delete.png" Hidden="true"/>
 | ||
|             </Columns>
 | ||
|         </f:Grid>
 | ||
|         <br />
 | ||
|         注:本多附件上传支持的浏览器版本为:Chrome、Firefox、Safari、IE10+ 。
 | ||
|       <f:Window ID="Window1" Title="播放" Hidden="true" EnableIFrame="true" EnableMaximize="true"
 | ||
|         Target="Parent" EnableResize="false" runat="server"  IsModal="true"
 | ||
|         Width="1024px" Height="650px">
 | ||
|     </f:Window>
 | ||
|     </form>
 | ||
|     <script src="res/webuploader/webuploader.nolog.js" type="text/javascript"></script>
 | ||
|     <script type="text/javascript">
 | ||
|         var btnDeleteClientID = '<%= btnDelete.ClientID %>';
 | ||
|         var btnSelectFilesClientID = '<%= btnSelectFiles.ClientID %>';
 | ||
|         var gridClientID = '<%= Grid1.ClientID %>';
 | ||
|         var BASE_URL = '<%= ResolveUrl("~/") %>';
 | ||
|         var SERVER_URL = BASE_URL + 'AttachFile/fileupload.ashx';
 | ||
|         F.ready(function () {
 | ||
|             var grid = F(gridClientID);
 | ||
|             var uploader = WebUploader.create({
 | ||
|                 // swf文件路径
 | ||
|                 swf: BASE_URL + 'AttachFile/res/webuploader/Uploader.swf',
 | ||
|                 // 文件接收服务端。
 | ||
|                 server: SERVER_URL,
 | ||
|                 // 选择文件的按钮。可选。
 | ||
|                 // 内部根据当前运行是创建,可能是input元素,也可能是flash.
 | ||
|                 pick: '#' + btnSelectFilesClientID,
 | ||
|                 // 不压缩image, 默认如果是jpeg,文件上传前会压缩一把再上传!
 | ||
|                 resize: false,
 | ||
|                 // 自动上传
 | ||
|                 auto: true,
 | ||
|                 // 文件上传参数表,用来标记文件的所有者(如果是一篇文章的附件,就是文章的ID)
 | ||
|                 formData: {
 | ||
|                     owner: '<%= ParamStr%>'
 | ||
|                 },
 | ||
|                 // 单个文件大小限制(单位:byte),这里限制为 800M
 | ||
|                 fileSingleSizeLimit: 6000 * 1024 * 1024                
 | ||
| 
 | ||
|             });
 | ||
| 
 | ||
|             // 添加到上传队列
 | ||
|             uploader.on('fileQueued', function (file) {
 | ||
|                 grid.addNewRecord(file.id, {
 | ||
|                     'FileName': file.name,
 | ||
|                     'FileType': file.ext,
 | ||
|                     'FileSize': file.size,
 | ||
|                     'FileStatus': '等待上传'
 | ||
|                 }, true);
 | ||
|             });
 | ||
| 
 | ||
|             uploader.on('uploadProgress', function (file, percentage) {
 | ||
|                 var cellEl = grid.getCellEl(file.id, 'FileStatus').find('.f-grid-cell-inner');                
 | ||
|                 var barEl = cellEl.find('.ui-progressbar-value');
 | ||
|                 // 避免重复创建
 | ||
|                 if (!barEl.length) {
 | ||
|                     cellEl.html('<div class="ui-progressbar ui-widget ui-widget-content ui-corner-all" style="height:12px;">' +
 | ||
|                       '<div class="ui-progressbar-value ui-widget-header ui-corner-left" style="width:0%">' +
 | ||
|                       '</div></div>');
 | ||
|                     barEl = cellEl.find('.ui-progressbar-value');
 | ||
|                 }
 | ||
| 
 | ||
|                 barEl.css('width', percentage * 100 + '%');
 | ||
|             });
 | ||
| 
 | ||
|             uploader.on('uploadSuccess', function (file) {
 | ||
|                 var cellEl = grid.getCellEl(file.id, 'FileStatus').find('.f-grid-cell-inner');
 | ||
|                 cellEl.text('上传成功');
 | ||
|             });
 | ||
| 
 | ||
|             uploader.on('uploadError', function (file) {
 | ||
|                 var cellEl = grid.getCellEl(file.id, 'FileStatus').find('.f-grid-cell-inner');
 | ||
|                 cellEl.text('上传出错');
 | ||
|             });
 | ||
| 
 | ||
|             // 不管上传成功还是失败,都会触发 uploadComplete 事件
 | ||
|             uploader.on('uploadComplete', function (file) {
 | ||
|                 uploader.removeFile(file, true);
 | ||
|             });
 | ||
| 
 | ||
| 
 | ||
|             // 当开始上传流程时触发
 | ||
|             uploader.on('startUpload', function () {
 | ||
|                 // 禁用删除按钮
 | ||
|                 F(btnDeleteClientID).disable();
 | ||
|             });
 | ||
| 
 | ||
|             // 当所有文件上传结束时触发
 | ||
|             uploader.on('uploadFinished', function () {
 | ||
|                 // 启用删除按钮
 | ||
|                 F(btnDeleteClientID).enable();
 | ||
| 
 | ||
|                 // 回发页面,重新绑定表格数据
 | ||
|                 __doPostBack('', 'RebindGrid');
 | ||
|             });
 | ||
|             
 | ||
|             uploader.on('error', function (type, arg, file) {
 | ||
|                 if (type === 'F_EXCEED_SIZE') {
 | ||
|                     F.alert('文件[' + file.name + ']大小超出限制值(' + F.format.fileSize(arg) + ')');
 | ||
|                 }
 | ||
|             });
 | ||
|         });
 | ||
|     </script>
 | ||
| </body>
 | ||
| </html>
 |