From 5d33c3db5c7d6cbb6cbd0d0b5e3ab7f115befc82 Mon Sep 17 00:00:00 2001 From: meilixie Date: Fri, 18 Sep 2015 12:04:17 +0800 Subject: [PATCH 1/5] plupload verison is the lastest --- .gitignore | 1 + demo/bower.json | 14 ++++++++++++++ demo/views/index.html | 5 ++++- 3 files changed, 19 insertions(+), 1 deletion(-) create mode 100644 demo/bower.json diff --git a/.gitignore b/.gitignore index 1adbf696..ee6b7a4a 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ .DS_Store Gruntfile.js node_modules +demo/bower_components diff --git a/demo/bower.json b/demo/bower.json new file mode 100644 index 00000000..ef3fbfc8 --- /dev/null +++ b/demo/bower.json @@ -0,0 +1,14 @@ +{ + "name": "plupload", + "version": "2.1.8", + "description": "plupload", + "license": "MIT", + "private": true, + "ignore": [ + "**/.*", + "bower_components" + ], + "devDependencies": { + "plupload": "~2.1.8" + } +} diff --git a/demo/views/index.html b/demo/views/index.html index b9d66dbc..a9b0d778 100644 --- a/demo/views/index.html +++ b/demo/views/index.html @@ -237,7 +237,10 @@ - + + + + From 6e85b214a0f51e2fe1d3ce0c80f2abe45512f1b7 Mon Sep 17 00:00:00 2001 From: meilixie Date: Fri, 18 Sep 2015 12:12:53 +0800 Subject: [PATCH 2/5] script url update --- demo/views/index.html | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/demo/views/index.html b/demo/views/index.html index a9b0d778..fe7c0dff 100644 --- a/demo/views/index.html +++ b/demo/views/index.html @@ -237,10 +237,7 @@ - - - - + From 4ee956f7dabb2c73a7c92dd35b346acea77134be Mon Sep 17 00:00:00 2001 From: meilixie Date: Fri, 18 Sep 2015 15:06:15 +0800 Subject: [PATCH 3/5] delete plupload other version --- demo/js/plupload/Moxie.swf | Bin 28902 -> 0 bytes demo/js/plupload/Moxie.xap | Bin 62535 -> 0 bytes demo/js/plupload/i18n/zh_CN.js | 2 - .../css/jquery.plupload.queue.css | 181 - .../jquery.plupload.queue/img/backgrounds.gif | Bin 2977 -> 0 bytes .../img/buttons-disabled.png | Bin 1292 -> 0 bytes .../jquery.plupload.queue/img/buttons.png | Bin 1439 -> 0 bytes .../jquery.plupload.queue/img/delete.gif | Bin 180 -> 0 bytes .../jquery.plupload.queue/img/done.gif | Bin 1024 -> 0 bytes .../jquery.plupload.queue/img/error.gif | Bin 994 -> 0 bytes .../jquery.plupload.queue/img/throbber.gif | Bin 1922 -> 0 bytes .../jquery.plupload.queue/img/transp50.png | Bin 399 -> 0 bytes .../jquery.plupload.queue.js | 424 - .../jquery.plupload.queue.min.js | 1 - .../css/jquery.ui.plupload.css | 362 - .../jquery.ui.plupload/img/loading.gif | Bin 4023 -> 0 bytes .../jquery.ui.plupload/img/plupload.png | Bin 6597 -> 0 bytes .../jquery.ui.plupload/jquery.ui.plupload.js | 1307 -- .../jquery.ui.plupload.min.js | 1 - demo/js/plupload/moxie.js | 10684 ---------------- demo/js/plupload/moxie.min.js | 15 - demo/js/plupload/plupload.dev.js | 2273 ---- demo/js/plupload/plupload.full.min.js | 28 - demo/js/plupload/plupload.min.js | 13 - demo/views/index.html | 2 +- 25 files changed, 1 insertion(+), 15292 deletions(-) delete mode 100644 demo/js/plupload/Moxie.swf delete mode 100644 demo/js/plupload/Moxie.xap delete mode 100644 demo/js/plupload/i18n/zh_CN.js delete mode 100644 demo/js/plupload/jquery.plupload.queue/css/jquery.plupload.queue.css delete mode 100644 demo/js/plupload/jquery.plupload.queue/img/backgrounds.gif delete mode 100644 demo/js/plupload/jquery.plupload.queue/img/buttons-disabled.png delete mode 100644 demo/js/plupload/jquery.plupload.queue/img/buttons.png delete mode 100644 demo/js/plupload/jquery.plupload.queue/img/delete.gif delete mode 100644 demo/js/plupload/jquery.plupload.queue/img/done.gif delete mode 100644 demo/js/plupload/jquery.plupload.queue/img/error.gif delete mode 100644 demo/js/plupload/jquery.plupload.queue/img/throbber.gif delete mode 100644 demo/js/plupload/jquery.plupload.queue/img/transp50.png delete mode 100644 demo/js/plupload/jquery.plupload.queue/jquery.plupload.queue.js delete mode 100644 demo/js/plupload/jquery.plupload.queue/jquery.plupload.queue.min.js delete mode 100644 demo/js/plupload/jquery.ui.plupload/css/jquery.ui.plupload.css delete mode 100644 demo/js/plupload/jquery.ui.plupload/img/loading.gif delete mode 100644 demo/js/plupload/jquery.ui.plupload/img/plupload.png delete mode 100644 demo/js/plupload/jquery.ui.plupload/jquery.ui.plupload.js delete mode 100644 demo/js/plupload/jquery.ui.plupload/jquery.ui.plupload.min.js delete mode 100644 demo/js/plupload/moxie.js delete mode 100644 demo/js/plupload/moxie.min.js delete mode 100644 demo/js/plupload/plupload.dev.js delete mode 100644 demo/js/plupload/plupload.full.min.js delete mode 100644 demo/js/plupload/plupload.min.js diff --git a/demo/js/plupload/Moxie.swf b/demo/js/plupload/Moxie.swf deleted file mode 100644 index 6493572bdf005ad7765d58f79f2ef65660fba931..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 28902 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 F8yMhWOBnzF diff --git a/demo/js/plupload/Moxie.xap b/demo/js/plupload/Moxie.xap deleted file mode 100644 index 3a9f389f43dce1bee4f6b7f57ceeb0f8cb7c123e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 62535 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

+p?963Pra@arCC{RFSeRk(D>&uB3dG=;f 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 J;oJYN{TIp_9ZvuN diff --git a/demo/js/plupload/i18n/zh_CN.js b/demo/js/plupload/i18n/zh_CN.js deleted file mode 100644 index f48e0c43..00000000 --- a/demo/js/plupload/i18n/zh_CN.js +++ /dev/null @@ -1,2 +0,0 @@ -// Chinese (China) (zh_CN) -plupload.addI18n({"Stop Upload":"停止上传","Upload URL might be wrong or doesn't exist.":"上传的URL可能是错误的或不存在。","tb":"tb","Size":"大小","Close":"关闭","Init error.":"初始化错误。","Add files to the upload queue and click the start button.":"将文件添加到上传队列,然后点击”开始上传“按钮。","Filename":"文件名","Image format either wrong or not supported.":"图片格式错误或者不支持。","Status":"状态","HTTP Error.":"HTTP 错误。","Start Upload":"开始上传","mb":"mb","kb":"kb","Duplicate file error.":"重复文件错误。","File size error.":"文件大小错误。","N/A":"N/A","gb":"gb","Error: Invalid file extension:":"错误:无效的文件扩展名:","Select files":"选择文件","%s already present in the queue.":"%s 已经在当前队列里。","File: %s":"文件: %s","b":"b","Uploaded %d/%d files":"已上传 %d/%d 个文件","Upload element accepts only %d file(s) at a time. Extra files were stripped.":"每次只接受同时上传 %d 个文件,多余的文件将会被删除。","%d files queued":"%d 个文件加入到队列","File: %s, size: %d, max file size: %d":"文件: %s, 大小: %d, 最大文件大小: %d","Drag files here.":"把文件拖到这里。","Runtime ran out of available memory.":"运行时已消耗所有可用内存。","File count error.":"文件数量错误。","File extension error.":"文件扩展名错误。","Error: File too large:":"错误: 文件太大:","Add Files":"增加文件"}); \ No newline at end of file diff --git a/demo/js/plupload/jquery.plupload.queue/css/jquery.plupload.queue.css b/demo/js/plupload/jquery.plupload.queue/css/jquery.plupload.queue.css deleted file mode 100644 index 1a23a3d8..00000000 --- a/demo/js/plupload/jquery.plupload.queue/css/jquery.plupload.queue.css +++ /dev/null @@ -1,181 +0,0 @@ -/* - Plupload -------------------------------------------------------------------- */ - -.plupload_button { - display: -moz-inline-box; /* FF < 3*/ - display: inline-block; - font: normal 12px sans-serif; - text-decoration: none; - color: #42454a; - border: 1px solid #bababa; - padding: 2px 8px 3px 20px; - margin-right: 4px; - background: #f3f3f3 url('../img/buttons.png') no-repeat 0 center; - outline: 0; - - /* Optional rounded corners for browsers that support it */ - -moz-border-radius: 3px; - -khtml-border-radius: 3px; - -webkit-border-radius: 3px; - border-radius: 3px; -} - -.plupload_button:hover { - color: #000; - text-decoration: none; -} - -.plupload_disabled, a.plupload_disabled:hover { - color: #737373; - border-color: #c5c5c5; - background: #ededed url('../img/buttons-disabled.png') no-repeat 0 center; - cursor: default; -} - -.plupload_add { - background-position: -181px center; -} - -.plupload_wrapper { - font: normal 11px Verdana,sans-serif; - width: 100%; -} - -.plupload_container { - padding: 8px; - background: url('../img/transp50.png'); - /*-moz-border-radius: 5px;*/ -} - -.plupload_container input { - border: 1px solid #DDD; - font: normal 11px Verdana,sans-serif; - width: 98%; -} - -.plupload_header {background: #2A2C2E url('../img/backgrounds.gif') repeat-x;} -.plupload_header_content { - background: url('../img/backgrounds.gif') no-repeat 0 -317px; - min-height: 56px; - padding-left: 60px; - color: #FFF; -} -.plupload_header_title { - font: normal 18px sans-serif; - padding: 6px 0 3px; -} -.plupload_header_text { - font: normal 12px sans-serif; -} - -.plupload_filelist { - margin: 0; - padding: 0; - list-style: none; -} - -.plupload_scroll .plupload_filelist { - height: 185px; - background: #F5F5F5; - overflow-y: scroll; -} - -.plupload_filelist li { - padding: 10px 8px; - background: #F5F5F5 url('../img/backgrounds.gif') repeat-x 0 -156px; - border-bottom: 1px solid #DDD; -} - -.plupload_filelist_header, .plupload_filelist_footer { - background: #DFDFDF; - padding: 8px 8px; - color: #42454A; -} -.plupload_filelist_header { - border-top: 1px solid #EEE; - border-bottom: 1px solid #CDCDCD; -} - -.plupload_filelist_footer {border-top: 1px solid #FFF; height: 22px; line-height: 20px; vertical-align: middle;} -.plupload_file_name {float: left; overflow: hidden} -.plupload_file_status {color: #777;} -.plupload_file_status span {color: #42454A;} -.plupload_file_size, .plupload_file_status, .plupload_progress { - float: right; - width: 80px; -} -.plupload_file_size, .plupload_file_status, .plupload_file_action {text-align: right;} - -.plupload_filelist .plupload_file_name { - width: 205px; - white-space: nowrap; - text-overflow: ellipsis; -} - -.plupload_file_action { - float: right; - width: 16px; - height: 16px; - margin-left: 15px; -} - -.plupload_file_action * { - display: none; - width: 16px; - height: 16px; -} - -li.plupload_uploading {background: #ECF3DC url('../img/backgrounds.gif') repeat-x 0 -238px;} -li.plupload_done {color:#AAA} - -li.plupload_delete a { - background: url('../img/delete.gif'); -} - -li.plupload_failed a { - background: url('../img/error.gif'); - cursor: default; -} - -li.plupload_done a { - background: url('../img/done.gif'); - cursor: default; -} - -.plupload_progress, .plupload_upload_status { - display: none; -} - -.plupload_progress_container { - margin-top: 3px; - border: 1px solid #CCC; - background: #FFF; - padding: 1px; -} -.plupload_progress_bar { - width: 0px; - height: 7px; - background: #CDEB8B; -} - -.plupload_scroll .plupload_filelist_header .plupload_file_action, .plupload_scroll .plupload_filelist_footer .plupload_file_action { - margin-right: 17px; -} - -/* Floats */ - -.plupload_clear,.plupload_clearer {clear: both;} -.plupload_clearer, .plupload_progress_bar { - display: block; - font-size: 0; - line-height: 0; -} - -li.plupload_droptext { - background: transparent; - text-align: center; - vertical-align: middle; - border: 0; - line-height: 165px; -} diff --git a/demo/js/plupload/jquery.plupload.queue/img/backgrounds.gif b/demo/js/plupload/jquery.plupload.queue/img/backgrounds.gif deleted file mode 100644 index 39e33ebc02114ebea6bb33dee2fb76af3a6dd4dc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2977 zcmdUu`#Tc~1II^hosi0dq?7P6w^9i&)fvJz8*&{RhTJ9Zdro+CGnWyPC?vVFx!;*f zwGhKxa!+DIj18M@Hka9Z&Y$sqpU=;q=kv?g24ZdUZyyK10});iz~_F@@$vEA-kwk> zWUv>uxr;|fM|?hCAQ0^D?{m4_!^1<~@jCbD7n4UhI5^ni{N(X?EIxH-Z^_Wu)X2ol z*z~rE*&WkcAhSE>w?TJr{b6~>-0BYtYxBEc3oEF(6+}nx3g>Wj_h4mDuy)tRmM^63 z9j{-xc7uPs!8!WHK3u(V(`0vlnSHRr6|5Otzp1NlaLv$I|LS!sFwD~0mM5fn`S^SL z224&(`}hT-eFHpw?t7yBP+q?7C~u^v4+81wfkL~vqg)Y47dMZI$th=7gf-M|Zti<} zMppFWX9%SCi|=rDf$WQq#?D zgPh%vgpRJ6*|~V^i^V0%>aR8G@(PVc1H&99{uWKoK;ZYjO-xQqOxioSZEtUXpa1b= z;U}F=FDWfYdikw;y?A6o;>FZf!&R1ropX!0hj#(0-1t9=3LlPOcu# zuI^4Q2(YcauYa)FZF6^|w}X?b4HOP@aGsu-wFX1)2Zq`?I6Jwx-?f1`IJw+&MmV}4 z?Cv?;G%>Zu$?>SjoLvDjCEv�TRS%oFI%_+CO)aErq(YYgtoB}8U3WF zxU8kMZGbe0!&i27eay}KP+e2IvAG!)^VB~m%-b(8^G!}b@PnP5otP)jqaQ#2O#HIA zv{Y7sfBY2F+4a%W#~#DtRV2e0sMdN^1he| z0MG-_`zQaOPXMHZfcTRt;D(|v@lxk>P^5<9-XuA7Xg;{HoMYfOln-gH78R4*5CMT0L8j?)9oQZ>#y<95h+wIowu@Y`U~O^ue~h?q^ptd-LZ7#e}8L zu_sRb4kI*Bdy@q*2r{8@WgtV{wgA?#yDXb~BXp76(Y!uZWSQDeE^gVF#5+}cjdZrs zXUlJr3gBIBTR#YY(icaNd)Osn{HaTJ-2~PODN8s??CxN%kC)mO+I{SNw5HS)x-|N+ zi?>7RO%+}$6vXYbX_M97W1l`A@|YvYT>HeWHHexh(^N#oszlPLNvc@ja7N1*G5}THRz94lQx_Q zT6t-*hF?j)wMSEb2^7;_&A6)&y!slfS-F~NK1x~5aG|GlROH65 z95hyYE%$zQhrd)%MdeyvSlh?+n$ae$G{ahFqwI}q$VPc?K-ES?e&pr`t_Z8Mi7(3z*{sA@RBcw(v~6xyH}ng2 z=rt`fA@o|pS{1#ndvB9oPn6JQH1sKiG8##m)r=;x5uMRIZmql3GUXb&)jAhYz16l5 zN#AOxV0E_%tJ$I39khz-?M_A;eY=aM@C8ieU|( zL^NucJ<`SuX0M!$9;;8@EsXV5DX@msuM)*z4O~!H-6d({gzXLjaW%U`dhLweVS@oZ zHra4Cze&Voy@ow{i^pJ(fh6@g<98JwaK3@HYB>{sT%~X(9c=WuQ_gM=xYLNhTJ8)g zYKuFIPV(fQxS#W2?|Trgc5gnceQWPW#DG3;Ay^B|`x(7n%UgWH6K?UAVkNKeDG7?< zd}^}RB2OgEc$>eHVRL1F^^IHj{;%A?y8X5MsO|mrEF0AWT3Jr`!3G{zcd%L0zI{M% z7og?UgkH5abet;F|1Uybg9w+xc_<{D=i3Csys`wzE(wf8Ie}1vJM_FooA&- zlUFWS5eM!ZuwKPVm#IoZNEXVOuXMp>YKns-Yt!A=8EIu2TJOM$h~3Owa+#*_;GkX1 zZdOsts+2Wk$T4sC4IWmm<2E?tn%*SdkXEi22pRU6-_0hF%dhxoW4sP_bBNLv21yXI zuQEHA1gp57GYIoBrMw$Yt1!etMnXK;d2{3nqxQj(@R+Q;b5b~y0m$fo^Vs<`7|wKd za5S=${efv1D6$3_i9JH*`3a1hpCmYKGXtLmdg9FJ_IV3@+N|d>HFucm~`>dP>EbjFC*m(Jf*b~}BpL0)g#m*`>RVLM2d7y+%KO3t!2z2n`d3rrfuB=AyQ913J`ZXe{HLQFSE-FVY+Uu03Bt zoS&()kc$vhgJz%-AB7e(rwCk8`N&};@W|rK)7nsjnR$0o6O|B#i2H9&HOd8$Q&V~| zJa{Ztk}O&zGxwlZvF%V?FM77CF(cHYYe<|f3XrCW$1BWqd3nXUo~#4vDwe(1)<~G{ z^d;3RRS}nt3w&h(vR3Zpu?g^tJ>3AQ__$tlqJ$YjJ~BB%ixQIz-xvAfM`9|~5vj6| zmt|EYBv68e%3+UL8DONPf@}A(BT4PF0ahIKu0h*WHCo2RD_$isE#+QDi7aSaJZu=6 z1pgUV?@7XB=H$n_^-%{Q$xUy{7g7j|XeSfU^{kxkRABV?lW5r+x$s6e6}0;>a#TcZ z8DyqI*cXlz6@Aqj>el|ze{(R{^-rC@sQy>SdK6lLjJG%a{n*#fe<1*`#hrfOr5u`a z#x%L5ObfmNHl|L%@hufvBgt^Ck7SW-E8a#X1ZIqx!Ye$wWHc>h;=rA5NWbaw5)`UV zI+&@)TB;jyF*Xa7S)y!P!$XHqb?L)7;NgX zz#PgCiflV!7_@yo`EY@X?ejHCJP(!Ykz}T~cmMi;jluaW^3#nk12OO5?=pVk$YG2%!@ek{6A(fmDJ+~!0gA49US+s%A`w3_&A z928;1Re?FHNg2HAAP3s9-?@pN8~g4YCGq9OW&Y7R=yd1!^U)XPe+4=*I>c0yiJS^E z!G^tL-@oRXwFP13=bi)OX4*%&b&Ax}d2?~kjNTUMYxJD80e8*M7DU==_?|jBFOSuD dje#jyoPHgVpsrRdX?b7mL?&^(OjHzL_CKvd+)Mxf diff --git a/demo/js/plupload/jquery.plupload.queue/img/buttons-disabled.png b/demo/js/plupload/jquery.plupload.queue/img/buttons-disabled.png deleted file mode 100644 index afa11af9b93bcbd261faa6a5b0835e82493712b2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1292 zcmdUu{ZrBh9LK*cyLmOMbKNd&>ujyJA?aEC~~zn}NBXR)7W|sN7p`Q5FZPn}b6cI@%6mmG6E;YBgxp`z{B(g5F$wZ=3sZ1s_ zSC&-JjgriDGG9<|+N|qMu@kQi3=5^!SOKSoDr|hcS(nIx$>w?Y_}6KwQisDq>&KG^ zi_0{bH8nN$L-@}5#{z*sBoaNE0dajON?%cxq_BD%E0@ccmzSCPYH$)y9xazhBp?Wy zUW~~c0*SrbXfep`0_;EzT}hj=j$8hk%pbhjWCDo>+~W2Ey6qa7OfJ*smgutVcDun~ zSlF7q(-W^)6e^WU)-+{gRXu4PhfzX}D_Sm>+tJZcA<4$~W(gggQWLMqNW>4`&XFa_ z$3!!>siGdV#WsysWemKMKU9@bO;z~byHZ;hcj8h1f)Le`$WYSm3XtfYt5+Vvb7jeO zgQY!|W}>X9N|sm9i>xpe2_0QhQ#Uw-4W|TER#r;we7>#?N(rLTXx4SJ)F8wtQZNc+ zSl!QEQw+)IQy!0}(P+9R8TIw`I2>+hXozZlz?dNiR|l%q>NIvj3=5*P3tQ*t1OkC* zC>b^D!|N|d=Q_pnJe5jCr_)(1R(WqW-@+bTl54fv#l^+eIYyo)oj2S@PH#7u!_Wj;T^_|aLmv2xXf1{tLw~Rol zMoUA@How0E1c$wV+ArX@;j{i*jAO|Id0fXo7lQ`5PGpH1zO4M(nl*Mp{}LWd`hK|i zC)z~qJL}3hPjh=E7oAdn6;@F-8hmB7-wWMnK5+UfQVc|-V<4srKAn&t+EJ{=mmYl2 zKcaDu*Oh7emN4xwv%H%>guu-^L(CJO)8q82H6!eRXGegq`lySYbVKCRBLA{94hZml z7C3$h9*J#@{i7xV;SvW5&ZiMh)pYp3e*Pw$un))vg(brQiLq|T00b-=`ZO%H@?V~M B8n^%e diff --git a/demo/js/plupload/jquery.plupload.queue/img/buttons.png b/demo/js/plupload/jquery.plupload.queue/img/buttons.png deleted file mode 100644 index 153e73885ac4a1fd1a98dccd5df73b8d72a2df10..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1439 zcmds$`CHNl0LH(md$h8mXU=DKYCYR>x|XZunH7j(vtnANdE^0}Q_%3q3ljwuNd0Px zXc>}1icY2+UgSJVML-S7gET2S?9e#8(;R=t-XGrM_s>g4UOcyB+n#Lz0POHUxOoA< zmMDEUGcnYAQk=_}J}hu>Uz|549CtG$0S%l*VM5WC9gwmupEox**VosVmzP&oR@TtHrkX-4q2s9uaXQg^SBNc4sxUG3Q2Gz~8cBP?UB&cROAb9#H0uYYyN|uyA#k zDkn-tl*8#=QP!E;(t2WArns5~b#fPK{N1zYdVd1%T6!M_Y{z4}!cdH>lD9p4X)U=W zrl1>tGItNNkCH7&BuEq83e1VT8#NM;B#fqXC!ZjHPZVGYyja%ryR7~^4C~b7dnI?8 z6<6(0DkYI*$=qqSL?O=Lg(yA_)hX_AdYPrqs8LmpSMS5w!!$Rl6Rf}?q19izq`pc& zlF}PfJy?t^@(@hd)4Q|67$-Y#GC}{yJCun2yayZqMuVix+6>$Pz;Xq?)cP6bX!#;N_ zM&L`A=G>9x^7#OMwe1(E#R%zSn0EYb9t^_rHAf6$xY*4IiB-fK&4Caqqw3c8R0C1aH>9E zo(0W2i4piUJ+E;lo#>bMJ$fxfGktK){>)xV@d%~kl`!*#;6hnh1`EDUrHPrlVu7bnk7vzs?(F%PW9p(Us@ByaDr1@N8id1 zq#EK|qf7fpp;hjA9jU`(GJHqGKZ7*?yVfBUmkUMdF;(`|w#2fh)Y<_s^1<(XG1r9( zp(&{7x-0IW1%HBtZ;hc0;q|=DlB{j?98clAE_&Up(=|^ z)y^4+k!d{)ayxq=5;3zqN@!&=e~dt&XdI2tZQl&^gc+E=1kFpxziBUw(u>+6B8ew{ zHT#4adb9s$)lNf5ZqWEWp|o~9mNBKZF@6n~4eLc`ZtQi) zEeZC+@YX2J-oQrPCqWJpanQl%fhgK|SHZ)!AkX2~Oo-gT(((Wk)zSW;rL3+K1a1L<0hS=shBh1KUx9VI6LTcP+1A$fTOVUSbj_}t^TxwA z>);uvlQWimVfuDfQ*;3A$LePE3n4Lk!TR4vFstfStKdAkc%W__W|RR{rpRfCtdE^o z^PM_}-KWf;<+}`y{((slzS?_8m0wvIoRWUWhih`I+Qw`E`olNIr-M})!19Q^wA?Y< zq@_nD!#8PWLw8%hgbQrU?2C`SIj|0x%a6XB8T34O-bxlYF*54+(^w#u7e+Q(Mw+~5 zI{4nmu`t>**kHfo1zn&9jdV!B)Ds3d11+CukDTL!Q1QOEPeFD(V%IO7$IQC+FIkzm e!^(pI%TA#Gq{YC>!%?W7RKNp%(X9a*ocSNer(gg8 diff --git a/demo/js/plupload/jquery.plupload.queue/img/delete.gif b/demo/js/plupload/jquery.plupload.queue/img/delete.gif deleted file mode 100644 index 78ca8b3b49e8f739df6ecfa4ef1119058b40e035..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 180 zcmZ?wbhEHb6krfw*v!H39|+Ez`G02S|CvCP_CGD{3a`TQPIW08y z+@NmXYwfboIA>eftmEx7PPc8lxOLj;wk@}o)$U1Kdw+KQj?7u7+G7q_7aUKWu%~bR zon_CzK797&@#5>#ChqKCeR=lWbKTo6Y;8YOwD9`W!0mdKC$n$9xnkdKU4N?J%dby0 zyHXy!eqg;&z4BnntSh~RJEP0@B-9|3oj-CkkZZ+PIz&iq4(r6)4xUz)J}=GOefiTPV2bGL_Yxw$lNYefFmh~ndE zIY+&>-d_`Q*w(b(@Zp<>wcFFSKin|$Y?u8^o3fLc-6tyEet(^I)N{&-{-V>Nn&qme z-|XLbclqX#$!XmLDils2^$_i=Vfo6|K!7s z$3S&5b~>3_CysS9Ff(!pa1CI4JIO94&@9fw!C(yl Dux)$+ diff --git a/demo/js/plupload/jquery.plupload.queue/img/error.gif b/demo/js/plupload/jquery.plupload.queue/img/error.gif deleted file mode 100644 index 4682b63007c89fae09f6640e1a968a073d98b90d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 994 zcmZ?wbhEHb6krfw_};*9b)oIQ-*5l@e)sRs`)iBszTS%X_xshqKVQDwin+ST?*G5P zzrQ^G_xt_f9Jc2NYJa}F{`Gdu&zDm^T?_qix&OnZo-emz|NVaR_t)1i*Zuzedh_v0 z>zAA1pKtV@Ea!c=%JBE6!+*Zrczrtj)3uOqx1+w?ivDyh;``H`|9*XZd!q2y`>j8o zPq{fm`Na;auQ!6uw~GD$_w&u+sDHnnzd8{2bbrVDb8TPluY7%O^{INT7l+$F-w1!O zT=&{!g-_QbzC1qg{l($GKi~d(fA!P#uus>+|9rjj_t&$3f4+Tvyzkqcn7=>n{r&m; z>&=i$lU?pF(SEVZ_4lV+Z%tCF$iDo6LW`p7(5<$N&HT8Aidtg@EEu7Dfh!1_m9F6F_-_fnz@dBd3hV zh6RoeTpun37Hm*p=S}!xB2%GsN>(9zl@H4iweC3*!Wlj#haUN`*h|{jWN<7##?Qpk zmawqs0!x>8vXF{_aD)HsCf8Xtia|ir6_cteb~+gFu`;I!>|qpOVG?4uVAFdM{QR&W zONNt2z@nss^K_X~eLR`cSvVIfMeSfTbmmr&58_**5um`{FC={>;XzVD=Tv()J_7-T ogaZvn8JQwxBtJeTEbH?rX5;20cPa5$D~HSgwKHzbjEoG{0NEsHRR910 diff --git a/demo/js/plupload/jquery.plupload.queue/img/throbber.gif b/demo/js/plupload/jquery.plupload.queue/img/throbber.gif deleted file mode 100644 index 4ae8b16a5a474c3da1e426afc20d2167ebd360f1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1922 zcma)-eM}Q~9LBG`Uf-_0UZFJTFt*nsTO5ueC8MQCX?YP5d8q^!#7gUiuF(Vv0y0uv zMJsO=7zu_gofyX-W+{m?E;Ac+grVzRB*kTp0b7W13o~jO6PL#Adz^qwjJtm>_sjk9 z`#jI{eZINdbKXqbPa-7ZMiBKT^}xA-;P=6WKNl)0E2eKxhaZKneR-`QzrcOMJvKfT zx)lmP4A1{QA9)h7lvsMZdqb029JH3~(nv`^VO`dQxDnc;-1oz!sEu0QJXhB~$nrssc=;5d6bWb>~J{i+O9hUE>s zy$3K&J8PlS3s zuf&l@@FJcg=@u`pfhDq)R}nk`!N({wk0c0{S65>YWU5;9TUls-qL>gRi_rR);{wgY zMVdw2=B8#K29K9L3s zc2K-aUfk?E&kByZwEo`KQU%&(ulDp;Rd2jF$4C4_mBa4FtT?M{W386p329VQR0mG+mdz;^%6}=b+X&!0PAJghY6b|U<(&T>?OpL^EQ|Dg8v(US+(!5}gNN>68C zjIJsuuSa13hEay{0=HqHA>PcGLdSs$kl{5DmyWOoKy3@Be5XpZZB{~bv-Rt+_KBtg z?I&+!J&28PB^xhXaT!{!c-ZpmN=~tqb8%>d`}1|A?BGOz>Q{U7drQo%qk+Jq)wF|Bjbw4$i)(?^O-2qNn1c<7SK zeh64nT!z?PU-wbRweq{O<*Cxk-%v+|o7P1Kr$(&P;`Dngu`P{NC&`fTITT02B_YRx zMm@NDi25Ks=~!vhsbn#_65^=UAs+Z>fLS&$h+rtQa@x?&qIF}sS{QcM$9 zyj8I_JtbX`?QWmL>a)qPxTV4W0{AhtaEw8J%zHgmpSG<=!@1xzkcC#tDkpClZTQ9T{9{ XMrH}sh*f7CD@Dcca7lI@6tMnZ`e4## diff --git a/demo/js/plupload/jquery.plupload.queue/img/transp50.png b/demo/js/plupload/jquery.plupload.queue/img/transp50.png deleted file mode 100644 index eb0efe104bdcc277ddcc3f6efdb54e1d533a5179..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 399 zcmeAS@N?(olHy`uVBq!ia0vp^(?FPm4M^HB7Cr(}Ea{HEjtmUzPnffIy#(?lOI#yL zg7ec#$`gxH85~pclTsBta}(23gHjVyDhp4h+AuIMDtfv&hE&{ob7`X>g8|2p4HHh@ z{1e$QDM;$zbFWMMeYKnhV#f|eBu!Qva;S;tqB;S44$rjF6*2UngC6Cic -

- - - -@example - // Retrieving a reference to plupload.Uploader object - var uploader = $('#uploader').pluploadQueue(); - - uploader.bind('FilesAdded', function() { - - // Autostart - setTimeout(uploader.start, 1); // "detach" from the main thread - }); - -@class pluploadQueue -@constructor -@param {Object} settings For detailed information about each option check documentation. - @param {String} settings.url URL of the server-side upload handler. - @param {Number|String} [settings.chunk_size=0] Chunk size in bytes to slice the file into. Shorcuts with b, kb, mb, gb, tb suffixes also supported. `e.g. 204800 or "204800b" or "200kb"`. By default - disabled. - @param {String} [settings.file_data_name="file"] Name for the file field in Multipart formated message. - @param {Array} [settings.filters=[]] Set of file type filters, each one defined by hash of title and extensions. `e.g. {title : "Image files", extensions : "jpg,jpeg,gif,png"}`. Dispatches `plupload.FILE_EXTENSION_ERROR` - @param {String} [settings.flash_swf_url] URL of the Flash swf. - @param {Object} [settings.headers] Custom headers to send with the upload. Hash of name/value pairs. - @param {Number|String} [settings.max_file_size] Maximum file size that the user can pick, in bytes. Optionally supports b, kb, mb, gb, tb suffixes. `e.g. "10mb" or "1gb"`. By default - not set. Dispatches `plupload.FILE_SIZE_ERROR`. - @param {Number} [settings.max_retries=0] How many times to retry the chunk or file, before triggering Error event. - @param {Boolean} [settings.multipart=true] Whether to send file and additional parameters as Multipart formated message. - @param {Object} [settings.multipart_params] Hash of key/value pairs to send with every file upload. - @param {Boolean} [settings.multi_selection=true] Enable ability to select multiple files at once in file dialog. - @param {Boolean} [settings.prevent_duplicates=false] Do not let duplicates into the queue. Dispatches `plupload.FILE_DUPLICATE_ERROR`. - @param {String|Object} [settings.required_features] Either comma-separated list or hash of required features that chosen runtime should absolutely possess. - @param {Object} [settings.resize] Enable resizng of images on client-side. Applies to `image/jpeg` and `image/png` only. `e.g. {width : 200, height : 200, quality : 90, crop: true}` - @param {Number} [settings.resize.width] If image is bigger, it will be resized. - @param {Number} [settings.resize.height] If image is bigger, it will be resized. - @param {Number} [settings.resize.quality=90] Compression quality for jpegs (1-100). - @param {Boolean} [settings.resize.crop=false] Whether to crop images to exact dimensions. By default they will be resized proportionally. - @param {String} [settings.runtimes="html5,flash,silverlight,html4"] Comma separated list of runtimes, that Plupload will try in turn, moving to the next if previous fails. - @param {String} [settings.silverlight_xap_url] URL of the Silverlight xap. - @param {Boolean} [settings.unique_names=false] If true will generate unique filenames for uploaded files. - - @param {Boolean} [settings.dragdrop=true] Enable ability to add file to the queue by drag'n'dropping them from the desktop. - @param {Boolean} [settings.rename=false] Enable ability to rename files in the queue. - @param {Boolean} [settings.multiple_queues=true] Re-activate the widget after each upload procedure. -*/ -(function($, o) { - var uploaders = {}; - - function _(str) { - return plupload.translate(str) || str; - } - - function renderUI(id, target) { - // Remove all existing non plupload items - target.contents().each(function(i, node) { - node = $(node); - - if (!node.is('.plupload')) { - node.remove(); - } - }); - - target.prepend( - '' - ); - } - - $.fn.pluploadQueue = function(settings) { - if (settings) { - this.each(function() { - var uploader, target, id, contents_bak; - - target = $(this); - id = target.attr('id'); - - if (!id) { - id = plupload.guid(); - target.attr('id', id); - } - - contents_bak = target.html(); - renderUI(id, target); - - settings = $.extend({ - dragdrop : true, - browse_button : id + '_browse', - container : id - }, settings); - - // Enable drag/drop (see PostInit handler as well) - if (settings.dragdrop) { - settings.drop_element = id + '_filelist'; - } - - uploader = new plupload.Uploader(settings); - - uploaders[id] = uploader; - - function handleStatus(file) { - var actionClass; - - if (file.status == plupload.DONE) { - actionClass = 'plupload_done'; - } - - if (file.status == plupload.FAILED) { - actionClass = 'plupload_failed'; - } - - if (file.status == plupload.QUEUED) { - actionClass = 'plupload_delete'; - } - - if (file.status == plupload.UPLOADING) { - actionClass = 'plupload_uploading'; - } - - var icon = $('#' + file.id).attr('class', actionClass).find('a').css('display', 'block'); - if (file.hint) { - icon.attr('title', file.hint); - } - } - - function updateTotalProgress() { - $('span.plupload_total_status', target).html(uploader.total.percent + '%'); - $('div.plupload_progress_bar', target).css('width', uploader.total.percent + '%'); - $('span.plupload_upload_status', target).html( - o.sprintf(_('Uploaded %d/%d files'), uploader.total.uploaded, uploader.files.length) - ); - } - - function updateList() { - var fileList = $('ul.plupload_filelist', target).html(''), inputCount = 0, inputHTML; - - $.each(uploader.files, function(i, file) { - inputHTML = ''; - - if (file.status == plupload.DONE) { - if (file.target_name) { - inputHTML += ''; - } - - inputHTML += ''; - inputHTML += ''; - - inputCount++; - - $('#' + id + '_count').val(inputCount); - } - - fileList.append( - '
  • ' + - '
    ' + file.name + '
    ' + - '
    ' + - '
    ' + file.percent + '%
    ' + - '
    ' + plupload.formatSize(file.size) + '
    ' + - '
     
    ' + - inputHTML + - '
  • ' - ); - - handleStatus(file); - - $('#' + file.id + '.plupload_delete a').click(function(e) { - $('#' + file.id).remove(); - uploader.removeFile(file); - - e.preventDefault(); - }); - }); - - $('span.plupload_total_file_size', target).html(plupload.formatSize(uploader.total.size)); - - if (uploader.total.queued === 0) { - $('span.plupload_add_text', target).html(_('Add Files')); - } else { - $('span.plupload_add_text', target).html(o.sprintf(_('%d files queued'), uploader.total.queued)); - } - - $('a.plupload_start', target).toggleClass('plupload_disabled', uploader.files.length == (uploader.total.uploaded + uploader.total.failed)); - - // Scroll to end of file list - fileList[0].scrollTop = fileList[0].scrollHeight; - - updateTotalProgress(); - - // Re-add drag message if there is no files - if (!uploader.files.length && uploader.features.dragdrop && uploader.settings.dragdrop) { - $('#' + id + '_filelist').append('
  • ' + _("Drag files here.") + '
  • '); - } - } - - function destroy() { - delete uploaders[id]; - uploader.destroy(); - target.html(contents_bak); - uploader = target = contents_bak = null; - } - - uploader.bind("UploadFile", function(up, file) { - $('#' + file.id).addClass('plupload_current_file'); - }); - - uploader.bind('Init', function(up, res) { - // Enable rename support - if (!settings.unique_names && settings.rename) { - target.on('click', '#' + id + '_filelist div.plupload_file_name span', function(e) { - var targetSpan = $(e.target), file, parts, name, ext = ""; - - // Get file name and split out name and extension - file = up.getFile(targetSpan.parents('li')[0].id); - name = file.name; - parts = /^(.+)(\.[^.]+)$/.exec(name); - if (parts) { - name = parts[1]; - ext = parts[2]; - } - - // Display input element - targetSpan.hide().after(''); - targetSpan.next().val(name).focus().blur(function() { - targetSpan.show().next().remove(); - }).keydown(function(e) { - var targetInput = $(this); - - if (e.keyCode == 13) { - e.preventDefault(); - - // Rename file and glue extension back on - file.name = targetInput.val() + ext; - targetSpan.html(file.name); - targetInput.blur(); - } - }); - }); - } - - $('#' + id + '_container').attr('title', 'Using runtime: ' + res.runtime); - - $('a.plupload_start', target).click(function(e) { - if (!$(this).hasClass('plupload_disabled')) { - uploader.start(); - } - - e.preventDefault(); - }); - - $('a.plupload_stop', target).click(function(e) { - e.preventDefault(); - uploader.stop(); - }); - - $('a.plupload_start', target).addClass('plupload_disabled'); - }); - - uploader.bind("Error", function(up, err) { - var file = err.file, message; - - if (file) { - message = err.message; - - if (err.details) { - message += " (" + err.details + ")"; - } - - if (err.code == plupload.FILE_SIZE_ERROR) { - alert(_("Error: File too large:") + " " + file.name); - } - - if (err.code == plupload.FILE_EXTENSION_ERROR) { - alert(_("Error: Invalid file extension:") + " " + file.name); - } - - file.hint = message; - $('#' + file.id).attr('class', 'plupload_failed').find('a').css('display', 'block').attr('title', message); - } - - if (err.code === plupload.INIT_ERROR) { - setTimeout(function() { - destroy(); - }, 1); - } - }); - - uploader.bind("PostInit", function(up) { - // features are populated only after input components are fully instantiated - if (up.settings.dragdrop && up.features.dragdrop) { - $('#' + id + '_filelist').append('
  • ' + _("Drag files here.") + '
  • '); - } - }); - - uploader.init(); - - uploader.bind('StateChanged', function() { - if (uploader.state === plupload.STARTED) { - $('li.plupload_delete a,div.plupload_buttons', target).hide(); - $('span.plupload_upload_status,div.plupload_progress,a.plupload_stop', target).css('display', 'block'); - $('span.plupload_upload_status', target).html('Uploaded ' + uploader.total.uploaded + '/' + uploader.files.length + ' files'); - - if (settings.multiple_queues) { - $('span.plupload_total_status,span.plupload_total_file_size', target).show(); - } - } else { - updateList(); - $('a.plupload_stop,div.plupload_progress', target).hide(); - $('a.plupload_delete', target).css('display', 'block'); - - if (settings.multiple_queues && uploader.total.uploaded + uploader.total.failed == uploader.files.length) { - $(".plupload_buttons,.plupload_upload_status", target).css("display", "inline"); - $(".plupload_start", target).addClass("plupload_disabled"); - $('span.plupload_total_status,span.plupload_total_file_size', target).hide(); - } - } - }); - - uploader.bind('FilesAdded', updateList); - - uploader.bind('FilesRemoved', function() { - // since the whole file list is redrawn for every change in the queue - // we need to scroll back to the file removal point to avoid annoying - // scrolling to the bottom bug (see #926) - var scrollTop = $('#' + id + '_filelist').scrollTop(); - updateList(); - $('#' + id + '_filelist').scrollTop(scrollTop); - }); - - uploader.bind('FileUploaded', function(up, file) { - handleStatus(file); - }); - - uploader.bind("UploadProgress", function(up, file) { - // Set file specific progress - $('#' + file.id + ' div.plupload_file_status', target).html(file.percent + '%'); - - handleStatus(file); - updateTotalProgress(); - }); - - // Call setup function - if (settings.setup) { - settings.setup(uploader); - } - }); - - return this; - } else { - // Get uploader instance for specified element - return uploaders[$(this[0]).attr('id')]; - } - }; -})(jQuery, mOxie); diff --git a/demo/js/plupload/jquery.plupload.queue/jquery.plupload.queue.min.js b/demo/js/plupload/jquery.plupload.queue/jquery.plupload.queue.min.js deleted file mode 100644 index a38f914a..00000000 --- a/demo/js/plupload/jquery.plupload.queue/jquery.plupload.queue.min.js +++ /dev/null @@ -1 +0,0 @@ -;(function(e,t){function r(e){return plupload.translate(e)||e}function i(t,n){n.contents().each(function(t,n){n=e(n),n.is(".plupload")||n.remove()}),n.prepend('
    '+'
    '+'
    '+'
    '+'
    '+r("Select files")+"
    "+'
    '+r("Add files to the upload queue and click the start button.")+"
    "+"
    "+"
    "+'
    '+'
    '+'
    '+r("Filename")+"
    "+'
     
    '+'
    '+r("Status")+"
    "+'
    '+r("Size")+"
    "+'
     
    '+"
    "+'
      '+'"+"
      "+"
      "+"
      "+''+"
      ")}var n={};e.fn.pluploadQueue=function(s){return s?(this.each(function(){function c(t){var n;t.status==plupload.DONE&&(n="plupload_done"),t.status==plupload.FAILED&&(n="plupload_failed"),t.status==plupload.QUEUED&&(n="plupload_delete"),t.status==plupload.UPLOADING&&(n="plupload_uploading");var r=e("#"+t.id).attr("class",n).find("a").css("display","block");t.hint&&r.attr("title",t.hint)}function h(){e("span.plupload_total_status",a).html(u.total.percent+"%"),e("div.plupload_progress_bar",a).css("width",u.total.percent+"%"),e("span.plupload_upload_status",a).html(t.sprintf(r("Uploaded %d/%d files"),u.total.uploaded,u.files.length))}function p(){var n=e("ul.plupload_filelist",a).html(""),i=0,s;e.each(u.files,function(t,r){s="",r.status==plupload.DONE&&(r.target_name&&(s+=''),s+='',s+='',i++,e("#"+f+"_count").val(i)),n.append('
    • '+'
      '+r.name+"
      "+'
      '+'
      '+r.percent+"%
      "+'
      '+plupload.formatSize(r.size)+"
      "+'
       
      '+s+"
    • "),c(r),e("#"+r.id+".plupload_delete a").click(function(t){e("#"+r.id).remove(),u.removeFile(r),t.preventDefault()})}),e("span.plupload_total_file_size",a).html(plupload.formatSize(u.total.size)),u.total.queued===0?e("span.plupload_add_text",a).html(r("Add Files")):e("span.plupload_add_text",a).html(t.sprintf(r("%d files queued"),u.total.queued)),e("a.plupload_start",a).toggleClass("plupload_disabled",u.files.length==u.total.uploaded+u.total.failed),n[0].scrollTop=n[0].scrollHeight,h(),!u.files.length&&u.features.dragdrop&&u.settings.dragdrop&&e("#"+f+"_filelist").append('
    • '+r("Drag files here.")+"
    • ")}function d(){delete n[f],u.destroy(),a.html(l),u=a=l=null}var u,a,f,l;a=e(this),f=a.attr("id"),f||(f=plupload.guid(),a.attr("id",f)),l=a.html(),i(f,a),s=e.extend({dragdrop:!0,browse_button:f+"_browse",container:f},s),s.dragdrop&&(s.drop_element=f+"_filelist"),u=new plupload.Uploader(s),n[f]=u,u.bind("UploadFile",function(t,n){e("#"+n.id).addClass("plupload_current_file")}),u.bind("Init",function(t,n){!s.unique_names&&s.rename&&a.on("click","#"+f+"_filelist div.plupload_file_name span",function(n){var r=e(n.target),i,s,o,u="";i=t.getFile(r.parents("li")[0].id),o=i.name,s=/^(.+)(\.[^.]+)$/.exec(o),s&&(o=s[1],u=s[2]),r.hide().after(''),r.next().val(o).focus().blur(function(){r.show().next().remove()}).keydown(function(t){var n=e(this);t.keyCode==13&&(t.preventDefault(),i.name=n.val()+u,r.html(i.name),n.blur())})}),e("#"+f+"_container").attr("title","Using runtime: "+n.runtime),e("a.plupload_start",a).click(function(t){e(this).hasClass("plupload_disabled")||u.start(),t.preventDefault()}),e("a.plupload_stop",a).click(function(e){e.preventDefault(),u.stop()}),e("a.plupload_start",a).addClass("plupload_disabled")}),u.bind("Error",function(t,n){var i=n.file,s;i&&(s=n.message,n.details&&(s+=" ("+n.details+")"),n.code==plupload.FILE_SIZE_ERROR&&alert(r("Error: File too large:")+" "+i.name),n.code==plupload.FILE_EXTENSION_ERROR&&alert(r("Error: Invalid file extension:")+" "+i.name),i.hint=s,e("#"+i.id).attr("class","plupload_failed").find("a").css("display","block").attr("title",s)),n.code===plupload.INIT_ERROR&&setTimeout(function(){d()},1)}),u.bind("PostInit",function(t){t.settings.dragdrop&&t.features.dragdrop&&e("#"+f+"_filelist").append('
    • '+r("Drag files here.")+"
    • ")}),u.init(),u.bind("StateChanged",function(){u.state===plupload.STARTED?(e("li.plupload_delete a,div.plupload_buttons",a).hide(),e("span.plupload_upload_status,div.plupload_progress,a.plupload_stop",a).css("display","block"),e("span.plupload_upload_status",a).html("Uploaded "+u.total.uploaded+"/"+u.files.length+" files"),s.multiple_queues&&e("span.plupload_total_status,span.plupload_total_file_size",a).show()):(p(),e("a.plupload_stop,div.plupload_progress",a).hide(),e("a.plupload_delete",a).css("display","block"),s.multiple_queues&&u.total.uploaded+u.total.failed==u.files.length&&(e(".plupload_buttons,.plupload_upload_status",a).css("display","inline"),e(".plupload_start",a).addClass("plupload_disabled"),e("span.plupload_total_status,span.plupload_total_file_size",a).hide()))}),u.bind("FilesAdded",p),u.bind("FilesRemoved",function(){var t=e("#"+f+"_filelist").scrollTop();p(),e("#"+f+"_filelist").scrollTop(t)}),u.bind("FileUploaded",function(e,t){c(t)}),u.bind("UploadProgress",function(t,n){e("#"+n.id+" div.plupload_file_status",a).html(n.percent+"%"),c(n),h()}),s.setup&&s.setup(u)}),this):n[e(this[0]).attr("id")]}})(jQuery,mOxie); \ No newline at end of file diff --git a/demo/js/plupload/jquery.ui.plupload/css/jquery.ui.plupload.css b/demo/js/plupload/jquery.ui.plupload/css/jquery.ui.plupload.css deleted file mode 100644 index 739894cf..00000000 --- a/demo/js/plupload/jquery.ui.plupload/css/jquery.ui.plupload.css +++ /dev/null @@ -1,362 +0,0 @@ -/* - Plupload -------------------------------------------------------------------- */ - -.plupload_button { - cursor: pointer; - outline: none; -} - -.plupload_wrapper { - font: normal 11px Verdana,sans-serif; - width: 100%; - min-width: 520px; -} - -.plupload_container { - _height: 300px; - min-height: 300px; - position: relative; -} - -.plupload_filelist_footer {border-width: 1px 0 0 0} -.plupload_file {border-width: 0 0 1px 0} -.plupload_container .plupload_header {border-width: 0 0 1px 0; position: relative;} - -.plupload_delete .ui-icon, -.plupload_done .ui-icon, -.plupload_failed .ui-icon { - cursor:pointer; -} - -.plupload_header_content { - height: 56px; - padding: 0 160px 0 60px; - position: relative; -} - -.plupload_logo { - width: 40px; - height: 40px; - background: url('../img/plupload.png') no-repeat 0 0; - position: absolute; - top: 8px; - left: 8px; -} - -.plupload_header_content_bw .plupload_logo { - background-position: -40px 0; -} - -.plupload_header_title { - font: normal 18px sans-serif; - padding: 6px 0 3px; -} - -.plupload_header_text { - font: normal 12px sans-serif; -} - -.plupload_view_switch { - position: absolute; - right: 16px; - bottom: 8px; - margin: 0; - display: none; -} - -.plupload_view_switch .ui-button { - margin-right: -0.31em; -} - -.plupload_content { - position: absolute; - top: 87px; - bottom: 44px; - left: 0; - right: 0; - overflow-y: auto; - width: 100%; -} - -.plupload_filelist { - border-collapse: collapse; - border-left: none; - border-right: none; - margin: 0; - padding: 0; - width: 100%; - -moz-user-select: none; - -webkit-user-select: none; - user-select: none; -} - -.plupload_filelist_content { - padding: 0; - margin: 0; -} - -.plupload_cell {padding: 8px 6px;} - -.plupload_file { - list-style: none; - display: block; - position: relative; - overflow: hidden; - width: 100%; -} - -.plupload_file_thumb { - position: absolute; - left: 6px; - top: 6px; - background: #eee url(../img/loading.gif) center no-repeat; -} - -.plupload_file_thumb_loaded .plupload_file_thumb { - background-image: none; -} - -.plupload_file_name { - overflow: hidden; - text-overflow: ellipsis; - white-space: nowrap; -} - -.plupload_filelist_header { - border-top: none; -} - -.plupload_filelist_footer { - position: absolute; - bottom: 0; - left: 0; - right: 0; -} - -.plupload_buttons { - position: relative; -} - -/* list view */ -.plupload_view_list .plupload_file { - border-left: none; - border-right: none; - border-top: none; - height: 29px; -} - -.plupload_view_list div.plupload_file_size, -.plupload_view_list div.plupload_file_status, -.plupload_view_list div.plupload_file_action { - padding: 8px 6px; - position: absolute; - top: 0; - right: 0; -} - -.plupload_view_list div.plupload_file_name { - margin-right: 156px; - padding: 8px 6px; - _width: 75%; -} - -.plupload_view_list div.plupload_file_size { - right: 28px; -} - -.plupload_view_list div.plupload_file_status { - right: 82px; -} - -.plupload_view_list .plupload_file_rename { - margin-left: -2px; -} - -.plupload_view_list .plupload_file_size, -.plupload_view_list .plupload_file_status, -.plupload_filelist_footer .plupload_file_size, -.plupload_filelist_footer .plupload_file_status { - text-align: right; - width: 52px; -} - -.plupload_view_list .plupload_file_thumb, -.plupload_view_list .plupload_file_dummy { - top: -999px; -} - -.plupload_view_list .plupload_file_progress { - display: none; -} - - -/* thumbs view */ -.plupload_view_thumbs .plupload_content { - top: 57px; -} - -.plupload_view_thumbs .plupload_filelist_header { - display: none; -} - -.plupload_view_thumbs .plupload_file { - width: 100px; - padding: 72px 6px 6px; - margin: 10px; - border: 1px solid #fff; - float: left; -} - -.plupload_view_thumbs .plupload_file_thumb, -.plupload_view_thumbs .plupload_file_dummy { - width: 100px; - height: 60px; - text-align: center; - overflow: hidden; -} - -.plupload_view_thumbs .plupload_file_dummy { - font-size: 21px; - font-weight: bold; - text-transform: lowercase; - overflow: hidden; - line-height: 60px; - border: none; -} - -.plupload_view_thumbs div.plupload_file_action { - position: absolute; - top: 0; - right: 0; -} - -.plupload_view_thumbs div.plupload_file_name { - padding: 0; - font-weight: bold; -} - -.plupload_view_thumbs .plupload_file_rename { - padding: 1px 0; - width: 100% !important; -} - -.plupload_view_thumbs div.plupload_file_size { - font-size: 0.8em; - font-weight: normal; -} - -.plupload_view_thumbs div.plupload_file_status { - position: absolute; - top: 67px; - left: 6px; - width: 100px; - height: 3px; - overflow: hidden; - text-indent: -999px; -} - -.plupload_view_thumbs div.plupload_file_progress { - border: none; - height: 100%; -} - -.plupload .ui-sortable-helper, -.plupload .ui-sortable .plupload_file { - cursor:move; -} - -.plupload_file_action {width: 16px;} -.plupload_file_name { - overflow: hidden; - padding-left: 10px; -} - -.plupload_file_rename { - border: none; - font: normal 11px Verdana, sans-serif; - padding: 1px 2px; - line-height: 11px; - height: 11px; -} - -.plupload_progress {width: 60px;} -.plupload_progress_container {padding: 1px;} - - -/* Floats */ - -.plupload_right {float: right;} -.plupload_left {float: left;} -.plupload_clear,.plupload_clearer {clear: both;} -.plupload_clearer, .plupload_progress_bar { - display: block; - font-size: 0; - line-height: 0; -} -.plupload_clearer {height: 0;} - -/* Misc */ -.plupload_hidden {display: none;} - -.plupload_droptext { - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: transparent; - text-align: center; - vertical-align: middle; - border: 0; - line-height: 160px; - display: none; -} - -.plupload_dropbox .plupload_droptext { - display: block; -} - -.plupload_buttons, .plupload_upload_status {float: left} - -.plupload_message { - position: absolute; - top: -1px; - left: -1px; - height: 100%; - width: 100%; -} - -.plupload_message p { - padding:0.7em; - margin:0; -} - -.plupload_message strong { - font-weight: bold; -} - -plupload_message i { - font-style: italic; -} - -.plupload_message p span.ui-icon { - float: left; - margin-right: 0.3em; -} - -.plupload_header_content .ui-state-error, -.plupload_header_content .ui-state-highlight { - border:none; -} - -.plupload_message_close { - position:absolute; - top:5px; - right:5px; - cursor:pointer; -} - -.plupload .ui-sortable-placeholder { - height:35px; -} diff --git a/demo/js/plupload/jquery.ui.plupload/img/loading.gif b/demo/js/plupload/jquery.ui.plupload/img/loading.gif deleted file mode 100644 index f0109d1706f7e1f26bbe6563a45e4146e5f02c45..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4023 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 Hz|{W&U89!W diff --git a/demo/js/plupload/jquery.ui.plupload/img/plupload.png b/demo/js/plupload/jquery.ui.plupload/img/plupload.png deleted file mode 100644 index 8ae0f90b5abcb54b3fe2c1f8c69aaeaff41d886e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6597 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 -
      -

      Your browser doesn't have Flash, Silverlight or HTML5 support.

      -
      - - - -@example - // Invoking methods: - $('#uploader').plupload(options); - - // Display welcome message in the notification area - $('#uploader').plupload('notify', 'info', "This might be obvious, but you need to click 'Add Files' to add some files."); - -@example - // Subscribing to the events... - // ... on initialization: - $('#uploader').plupload({ - ... - viewchanged: function(event, args) { - // stuff ... - } - }); - // ... or after initialization - $('#uploader').on("viewchanged", function(event, args) { - // stuff ... - }); - -@class UI.Plupload -@constructor -@param {Object} settings For detailed information about each option check documentation. - @param {String} settings.url URL of the server-side upload handler. - @param {Number|String} [settings.chunk_size=0] Chunk size in bytes to slice the file into. Shorcuts with b, kb, mb, gb, tb suffixes also supported. `e.g. 204800 or "204800b" or "200kb"`. By default - disabled. - @param {String} [settings.file_data_name="file"] Name for the file field in Multipart formated message. - @param {Array} [settings.filters=[]] Set of file type filters, each one defined by hash of title and extensions. `e.g. {title : "Image files", extensions : "jpg,jpeg,gif,png"}`. Dispatches `plupload.FILE_EXTENSION_ERROR` - @param {String} [settings.flash_swf_url] URL of the Flash swf. - @param {Object} [settings.headers] Custom headers to send with the upload. Hash of name/value pairs. - @param {Number|String} [settings.max_file_size] Maximum file size that the user can pick, in bytes. Optionally supports b, kb, mb, gb, tb suffixes. `e.g. "10mb" or "1gb"`. By default - not set. Dispatches `plupload.FILE_SIZE_ERROR`. - @param {Number} [settings.max_retries=0] How many times to retry the chunk or file, before triggering Error event. - @param {Boolean} [settings.multipart=true] Whether to send file and additional parameters as Multipart formated message. - @param {Object} [settings.multipart_params] Hash of key/value pairs to send with every file upload. - @param {Boolean} [settings.multi_selection=true] Enable ability to select multiple files at once in file dialog. - @param {Boolean} [settings.prevent_duplicates=false] Do not let duplicates into the queue. Dispatches `plupload.FILE_DUPLICATE_ERROR`. - @param {String|Object} [settings.required_features] Either comma-separated list or hash of required features that chosen runtime should absolutely possess. - @param {Object} [settings.resize] Enable resizng of images on client-side. Applies to `image/jpeg` and `image/png` only. `e.g. {width : 200, height : 200, quality : 90, crop: true}` - @param {Number} [settings.resize.width] If image is bigger, it will be resized. - @param {Number} [settings.resize.height] If image is bigger, it will be resized. - @param {Number} [settings.resize.quality=90] Compression quality for jpegs (1-100). - @param {Boolean} [settings.resize.crop=false] Whether to crop images to exact dimensions. By default they will be resized proportionally. - @param {String} [settings.runtimes="html5,flash,silverlight,html4"] Comma separated list of runtimes, that Plupload will try in turn, moving to the next if previous fails. - @param {String} [settings.silverlight_xap_url] URL of the Silverlight xap. - @param {Boolean} [settings.unique_names=false] If true will generate unique filenames for uploaded files. - - @param {Boolean} [settings.autostart=false] Whether to auto start uploading right after file selection. - @param {Boolean} [settings.dragdrop=true] Enable ability to add file to the queue by drag'n'dropping them from the desktop. - @param {Boolean} [settings.rename=false] Enable ability to rename files in the queue. - @param {Boolean} [settings.sortable=false] Enable ability to sort files in the queue, changing their uploading priority. - @param {Object} [settings.buttons] Control the visibility of functional buttons. - @param {Boolean} [settings.buttons.browse=true] Display browse button. - @param {Boolean} [settings.buttons.start=true] Display start button. - @param {Boolean} [settings.buttons.stop=true] Display stop button. - @param {Object} [settings.views] Control various views of the file queue. - @param {Boolean} [settings.views.list=true] Enable list view. - @param {Boolean} [settings.views.thumbs=false] Enable thumbs view. - @param {String} [settings.views.default='list'] Default view. - @param {Boolean} [settings.views.remember=true] Whether to remember the current view (requires jQuery Cookie plugin). - @param {Boolean} [settings.multiple_queues=true] Re-activate the widget after each upload procedure. - @param {Number} [settings.max_file_count=0] Limit the number of files user is able to upload in one go, autosets _multiple_queues_ to _false_ (default is 0 - no limit). -*/ -(function(window, document, plupload, o, $) { - -/** -Dispatched when the widget is initialized and ready. - -@event ready -@param {plupload.Uploader} uploader Uploader instance sending the event. -*/ - -/** -Dispatched when file dialog is closed. - -@event selected -@param {plupload.Uploader} uploader Uploader instance sending the event. -@param {Array} files Array of selected files represented by plupload.File objects -*/ - -/** -Dispatched when file dialog is closed. - -@event removed -@param {plupload.Uploader} uploader Uploader instance sending the event. -@param {Array} files Array of removed files represented by plupload.File objects -*/ - -/** -Dispatched when upload is started. - -@event start -@param {plupload.Uploader} uploader Uploader instance sending the event. -*/ - -/** -Dispatched when upload is stopped. - -@event stop -@param {plupload.Uploader} uploader Uploader instance sending the event. -*/ - -/** -Dispatched during the upload process. - -@event progress -@param {plupload.Uploader} uploader Uploader instance sending the event. -@param {plupload.File} file File that is being uploaded (includes loaded and percent properties among others). - @param {Number} size Total file size in bytes. - @param {Number} loaded Number of bytes uploaded of the files total size. - @param {Number} percent Number of percentage uploaded of the file. -*/ - -/** -Dispatched when file is uploaded. - -@event uploaded -@param {plupload.Uploader} uploader Uploader instance sending the event. -@param {plupload.File} file File that was uploaded. - @param {Enum} status Status constant matching the plupload states QUEUED, UPLOADING, FAILED, DONE. -*/ - -/** -Dispatched when upload of the whole queue is complete. - -@event complete -@param {plupload.Uploader} uploader Uploader instance sending the event. -@param {Array} files Array of uploaded files represented by plupload.File objects -*/ - -/** -Dispatched when the view is changed, e.g. from `list` to `thumbs` or vice versa. - -@event viewchanged -@param {plupload.Uploader} uploader Uploader instance sending the event. -@param {String} type Current view type. -*/ - -/** -Dispatched when error of some kind is detected. - -@event error -@param {plupload.Uploader} uploader Uploader instance sending the event. -@param {String} error Error message. -@param {plupload.File} file File that was uploaded. - @param {Enum} status Status constant matching the plupload states QUEUED, UPLOADING, FAILED, DONE. -*/ - -var uploaders = {}; - -function _(str) { - return plupload.translate(str) || str; -} - -function renderUI(obj) { - obj.id = obj.attr('id'); - - obj.html( - '
      ' + - '
      ' + - '
      ' + - '
      ' + - '' + - '
      ' + _('Select files') + '
      ' + - '
      ' + _('Add files to the upload queue and click the start button.') + '
      ' + - '
      ' + - '' + - '' + - '
      ' + - '
      ' + - '
      ' + - - '' + - '' + - '' + - '' + - '' + - '' + - '' + - '
      ' + _('Filename') + '' + _('Status') + '' + _('Size') + ' 
      ' + - - '
      ' + - '
      ' + _("Drag files here.") + '
      ' + - '
      ' + - '
       
      ' + - '
      ' + - - '' + - '' + - '' + - '' + - '' + - '' + - '' + - '' + - - '
      ' + - '' + - '
      ' - ); -} - - -$.widget("ui.plupload", { - - widgetEventPrefix: '', - - contents_bak: '', - - options: { - browse_button_hover: 'ui-state-hover', - browse_button_active: 'ui-state-active', - - // widget specific - dragdrop : true, - multiple_queues: true, // re-use widget by default - buttons: { - browse: true, - start: true, - stop: true - }, - views: { - list: true, - thumbs: false, - active: 'list', - remember: true // requires: https://github.com/carhartl/jquery-cookie, otherwise disabled even if set to true - }, - autostart: false, - sortable: false, - rename: false, - max_file_count: 0 // unlimited - }, - - FILE_COUNT_ERROR: -9001, - - _create: function() { - var id = this.element.attr('id'); - if (!id) { - id = plupload.guid(); - this.element.attr('id', id); - } - this.id = id; - - // backup the elements initial state - this.contents_bak = this.element.html(); - renderUI(this.element); - - // container, just in case - this.container = $('.plupload_container', this.element).attr('id', id + '_container'); - - this.content = $('.plupload_content', this.element); - - if ($.fn.resizable) { - this.container.resizable({ - handles: 's', - minHeight: 300 - }); - } - - // list of files, may become sortable - this.filelist = $('.plupload_filelist_content', this.container) - .attr({ - id: id + '_filelist', - unselectable: 'on' - }); - - - // buttons - this.browse_button = $('.plupload_add', this.container).attr('id', id + '_browse'); - this.start_button = $('.plupload_start', this.container).attr('id', id + '_start'); - this.stop_button = $('.plupload_stop', this.container).attr('id', id + '_stop'); - this.thumbs_switcher = $('#' + id + '_view_thumbs'); - this.list_switcher = $('#' + id + '_view_list'); - - if ($.ui.button) { - this.browse_button.button({ - icons: { primary: 'ui-icon-circle-plus' }, - disabled: true - }); - - this.start_button.button({ - icons: { primary: 'ui-icon-circle-arrow-e' }, - disabled: true - }); - - this.stop_button.button({ - icons: { primary: 'ui-icon-circle-close' } - }); - - this.list_switcher.button({ - text: false, - icons: { secondary: "ui-icon-grip-dotted-horizontal" } - }); - - this.thumbs_switcher.button({ - text: false, - icons: { secondary: "ui-icon-image" } - }); - } - - // progressbar - this.progressbar = $('.plupload_progress_container', this.container); - - if ($.ui.progressbar) { - this.progressbar.progressbar(); - } - - // counter - this.counter = $('.plupload_count', this.element) - .attr({ - id: id + '_count', - name: id + '_count' - }); - - // initialize uploader instance - this._initUploader(); - }, - - _initUploader: function() { - var self = this - , id = this.id - , uploader - , options = { - container: id + '_buttons', - browse_button: id + '_browse' - } - ; - - $('.plupload_buttons', this.element).attr('id', id + '_buttons'); - - if (self.options.dragdrop) { - this.filelist.parent().attr('id', this.id + '_dropbox'); - options.drop_element = this.id + '_dropbox'; - } - - uploader = this.uploader = uploaders[id] = new plupload.Uploader($.extend(this.options, options)); - - if (self.options.views.thumbs) { - uploader.settings.required_features.display_media = true; - } - - - uploader.bind('Error', function(up, err) { - var message, details = ""; - - message = '' + err.message + ''; - - switch (err.code) { - case plupload.FILE_EXTENSION_ERROR: - details = o.sprintf(_("File: %s"), err.file.name); - break; - - case plupload.FILE_SIZE_ERROR: - details = o.sprintf(_("File: %s, size: %d, max file size: %d"), err.file.name, err.file.size, plupload.parseSize(self.options.max_file_size)); - break; - - case plupload.FILE_DUPLICATE_ERROR: - details = o.sprintf(_("%s already present in the queue."), err.file.name); - break; - - case self.FILE_COUNT_ERROR: - details = o.sprintf(_("Upload element accepts only %d file(s) at a time. Extra files were stripped."), self.options.max_file_count); - break; - - case plupload.IMAGE_FORMAT_ERROR : - details = _("Image format either wrong or not supported."); - break; - - case plupload.IMAGE_MEMORY_ERROR : - details = _("Runtime ran out of available memory."); - break; - - /* // This needs a review - case plupload.IMAGE_DIMENSIONS_ERROR : - details = o.sprintf(_('Resoultion out of boundaries! %s runtime supports images only up to %wx%hpx.'), up.runtime, up.features.maxWidth, up.features.maxHeight); - break; */ - - case plupload.HTTP_ERROR: - details = _("Upload URL might be wrong or doesn't exist."); - break; - } - - message += "
      " + details + ""; - - self._trigger('error', null, { up: up, error: err } ); - - // do not show UI if no runtime can be initialized - if (err.code === plupload.INIT_ERROR) { - setTimeout(function() { - self.destroy(); - }, 1); - } else { - self.notify('error', message); - } - }); - - - uploader.bind('PostInit', function(up) { - // all buttons are optional, so they can be disabled and hidden - if (!self.options.buttons.browse) { - self.browse_button.button('disable').hide(); - up.disableBrowse(true); - } else { - self.browse_button.button('enable'); - } - - if (!self.options.buttons.start) { - self.start_button.button('disable').hide(); - } - - if (!self.options.buttons.stop) { - self.stop_button.button('disable').hide(); - } - - if (!self.options.unique_names && self.options.rename) { - self._enableRenaming(); - } - - if (self.options.dragdrop && up.features.dragdrop) { - self.filelist.parent().addClass('plupload_dropbox'); - } - - self._enableViewSwitcher(); - - self.start_button.click(function(e) { - if (!$(this).button('option', 'disabled')) { - self.start(); - } - e.preventDefault(); - }); - - self.stop_button.click(function(e) { - self.stop(); - e.preventDefault(); - }); - - self._trigger('ready', null, { up: up }); - }); - - - // check if file count doesn't exceed the limit - if (self.options.max_file_count) { - self.options.multiple_queues = false; // one go only - - uploader.bind('FilesAdded', function(up, selectedFiles) { - var selectedCount = selectedFiles.length - , extraCount = up.files.length + selectedCount - self.options.max_file_count - ; - - if (extraCount > 0) { - selectedFiles.splice(selectedCount - extraCount, extraCount); - - up.trigger('Error', { - code : self.FILE_COUNT_ERROR, - message : _('File count error.') - }); - } - }); - } - - // uploader internal events must run first - uploader.init(); - - uploader.bind('FileFiltered', function(up, file) { - self._addFiles(file); - }); - - uploader.bind('FilesAdded', function(up, files) { - self._trigger('selected', null, { up: up, files: files } ); - - // re-enable sortable - if (self.options.sortable && $.ui.sortable) { - self._enableSortingList(); - } - - self._trigger('updatelist', null, { filelist: self.filelist }); - - if (self.options.autostart) { - // set a little delay to make sure that QueueChanged triggered by the core has time to complete - setTimeout(function() { - self.start(); - }, 10); - } - }); - - uploader.bind('FilesRemoved', function(up, files) { - self._trigger('removed', null, { up: up, files: files } ); - }); - - uploader.bind('QueueChanged StateChanged', function() { - self._handleState(); - }); - - uploader.bind('UploadFile', function(up, file) { - self._handleFileStatus(file); - }); - - uploader.bind('FileUploaded', function(up, file) { - self._handleFileStatus(file); - self._trigger('uploaded', null, { up: up, file: file } ); - }); - - uploader.bind('UploadProgress', function(up, file) { - self._handleFileStatus(file); - self._updateTotalProgress(); - self._trigger('progress', null, { up: up, file: file } ); - }); - - uploader.bind('UploadComplete', function(up, files) { - self._addFormFields(); - self._trigger('complete', null, { up: up, files: files } ); - }); - }, - - - _setOption: function(key, value) { - var self = this; - - if (key == 'buttons' && typeof(value) == 'object') { - value = $.extend(self.options.buttons, value); - - if (!value.browse) { - self.browse_button.button('disable').hide(); - self.uploader.disableBrowse(true); - } else { - self.browse_button.button('enable').show(); - self.uploader.disableBrowse(false); - } - - if (!value.start) { - self.start_button.button('disable').hide(); - } else { - self.start_button.button('enable').show(); - } - - if (!value.stop) { - self.stop_button.button('disable').hide(); - } else { - self.start_button.button('enable').show(); - } - } - - self.uploader.settings[key] = value; - }, - - - /** - Start upload. Triggers `start` event. - - @method start - */ - start: function() { - this.uploader.start(); - this._trigger('start', null, { up: this.uploader }); - }, - - - /** - Stop upload. Triggers `stop` event. - - @method stop - */ - stop: function() { - this.uploader.stop(); - this._trigger('stop', null, { up: this.uploader }); - }, - - - /** - Enable browse button. - - @method enable - */ - enable: function() { - this.browse_button.button('enable'); - this.uploader.disableBrowse(false); - }, - - - /** - Disable browse button. - - @method disable - */ - disable: function() { - this.browse_button.button('disable'); - this.uploader.disableBrowse(true); - }, - - - /** - Retrieve file by it's unique id. - - @method getFile - @param {String} id Unique id of the file - @return {plupload.File} - */ - getFile: function(id) { - var file; - - if (typeof id === 'number') { - file = this.uploader.files[id]; - } else { - file = this.uploader.getFile(id); - } - return file; - }, - - /** - Return array of files currently in the queue. - - @method getFiles - @return {Array} Array of files in the queue represented by plupload.File objects - */ - getFiles: function() { - return this.uploader.files; - }, - - - /** - Remove the file from the queue. - - @method removeFile - @param {plupload.File|String} file File to remove, might be specified directly or by it's unique id - */ - removeFile: function(file) { - if (plupload.typeOf(file) === 'string') { - file = this.getFile(file); - } - this._removeFiles(file); - }, - - - /** - Clear the file queue. - - @method clearQueue - */ - clearQueue: function() { - this.uploader.splice(); - }, - - - /** - Retrieve internal plupload.Uploader object (usually not required). - - @method getUploader - @return {plupload.Uploader} - */ - getUploader: function() { - return this.uploader; - }, - - - /** - Trigger refresh procedure, specifically browse_button re-measure and re-position operations. - Might get handy, when UI Widget is placed within the popup, that is constantly hidden and shown - again - without calling this method after each show operation, dialog trigger might get displaced - and disfunctional. - - @method refresh - */ - refresh: function() { - this.uploader.refresh(); - }, - - - /** - Display a message in notification area. - - @method notify - @param {Enum} type Type of the message, either `error` or `info` - @param {String} message The text message to display. - */ - notify: function(type, message) { - var popup = $( - '
      ' + - '' + - '

      ' + message + '

      ' + - '
      ' - ); - - popup - .addClass('ui-state-' + (type === 'error' ? 'error' : 'highlight')) - .find('p .ui-icon') - .addClass('ui-icon-' + (type === 'error' ? 'alert' : 'info')) - .end() - .find('.plupload_message_close') - .click(function() { - popup.remove(); - }) - .end(); - - $('.plupload_header', this.container).append(popup); - }, - - - /** - Destroy the widget, the uploader, free associated resources and bring back original html. - - @method destroy - */ - destroy: function() { - this._removeFiles([].slice.call(this.uploader.files)); - - // destroy uploader instance - this.uploader.destroy(); - - // unbind all button events - $('.plupload_button', this.element).unbind(); - - // destroy buttons - if ($.ui.button) { - $('.plupload_add, .plupload_start, .plupload_stop', this.container) - .button('destroy'); - } - - // destroy progressbar - if ($.ui.progressbar) { - this.progressbar.progressbar('destroy'); - } - - // destroy sortable behavior - if ($.ui.sortable && this.options.sortable) { - $('tbody', this.filelist).sortable('destroy'); - } - - // restore the elements initial state - this.element - .empty() - .html(this.contents_bak); - this.contents_bak = ''; - - $.Widget.prototype.destroy.apply(this); - }, - - - _handleState: function() { - var up = this.uploader; - - if (up.state === plupload.STARTED) { - $(this.start_button).button('disable'); - - $([]) - .add(this.stop_button) - .add('.plupload_started') - .removeClass('plupload_hidden'); - - $('.plupload_upload_status', this.element).html(o.sprintf(_('Uploaded %d/%d files'), up.total.uploaded, up.files.length)); - $('.plupload_header_content', this.element).addClass('plupload_header_content_bw'); - } else if (up.state === plupload.STOPPED) { - $([]) - .add(this.stop_button) - .add('.plupload_started') - .addClass('plupload_hidden'); - - if (this.options.multiple_queues) { - $('.plupload_header_content', this.element).removeClass('plupload_header_content_bw'); - } else { - $([]) - .add(this.browse_button) - .add(this.start_button) - .button('disable'); - - up.disableBrowse(); - } - - if (up.files.length === (up.total.uploaded + up.total.failed)) { - this.start_button.button('disable'); - } else { - this.start_button.button('enable'); - } - - this._updateTotalProgress(); - } - - if (up.total.queued === 0) { - $('.ui-button-text', this.browse_button).html(_('Add Files')); - } else { - $('.ui-button-text', this.browse_button).html(o.sprintf(_('%d files queued'), up.total.queued)); - } - - up.refresh(); - }, - - - _handleFileStatus: function(file) { - var self = this, actionClass, iconClass; - - // since this method might be called asynchronously, file row might not yet be rendered - if (!$('#' + file.id).length) { - return; - } - - switch (file.status) { - case plupload.DONE: - actionClass = 'plupload_done'; - iconClass = 'ui-icon ui-icon-circle-check'; - break; - - case plupload.FAILED: - actionClass = 'ui-state-error plupload_failed'; - iconClass = 'ui-icon ui-icon-alert'; - break; - - case plupload.QUEUED: - actionClass = 'plupload_delete'; - iconClass = 'ui-icon ui-icon-circle-minus'; - break; - - case plupload.UPLOADING: - actionClass = 'ui-state-highlight plupload_uploading'; - iconClass = 'ui-icon ui-icon-circle-arrow-w'; - - // scroll uploading file into the view if its bottom boundary is out of it - var scroller = $('.plupload_scroll', this.container) - , scrollTop = scroller.scrollTop() - , scrollerHeight = scroller.height() - , rowOffset = $('#' + file.id).position().top + $('#' + file.id).height() - ; - - if (scrollerHeight < rowOffset) { - scroller.scrollTop(scrollTop + rowOffset - scrollerHeight); - } - - // Set file specific progress - $('#' + file.id) - .find('.plupload_file_percent') - .html(file.percent + '%') - .end() - .find('.plupload_file_progress') - .css('width', file.percent + '%') - .end() - .find('.plupload_file_size') - .html(plupload.formatSize(file.size)); - break; - } - actionClass += ' ui-state-default plupload_file'; - - $('#' + file.id) - .attr('class', actionClass) - .find('.ui-icon') - .attr('class', iconClass) - .end() - .filter('.plupload_delete, .plupload_done, .plupload_failed') - .find('.ui-icon') - .click(function(e) { - self._removeFiles(file); - e.preventDefault(); - }); - }, - - - _updateTotalProgress: function() { - var up = this.uploader; - - // Scroll to end of file list - this.filelist[0].scrollTop = this.filelist[0].scrollHeight; - - this.progressbar.progressbar('value', up.total.percent); - - this.element - .find('.plupload_total_status') - .html(up.total.percent + '%') - .end() - .find('.plupload_total_file_size') - .html(plupload.formatSize(up.total.size)) - .end() - .find('.plupload_upload_status') - .html(o.sprintf(_('Uploaded %d/%d files'), up.total.uploaded, up.files.length)); - }, - - - _displayThumbs: function() { - var self = this - , tw, th // thumb width/height - , cols - , num = 0 // number of simultaneously visible thumbs - , thumbs = [] // array of thumbs to preload at any given moment - , loading = false - ; - - if (!this.options.views.thumbs) { - return; - } - - - function onLast(el, eventName, cb) { - var timer; - - el.on(eventName, function() { - clearTimeout(timer); - timer = setTimeout(function() { - clearTimeout(timer); - cb(); - }, 300); - }); - } - - - // calculate number of simultaneously visible thumbs - function measure() { - if (!tw || !th) { - var wrapper = $('.plupload_file:eq(0)', self.filelist); - tw = wrapper.outerWidth(true); - th = wrapper.outerHeight(true); - } - - var aw = self.content.width(), ah = self.content.height(); - cols = Math.floor(aw / tw); - num = cols * (Math.ceil(ah / th) + 1); - } - - - function pickThumbsToLoad() { - // calculate index of virst visible thumb - var startIdx = Math.floor(self.content.scrollTop() / th) * cols; - // get potentially visible thumbs that are not yet visible - thumbs = $('.plupload_file', self.filelist) - .slice(startIdx, startIdx + num) - .filter(':not(.plupload_file_thumb_loaded)') - .get(); - } - - - function init() { - function mpl() { - if (self.view_mode !== 'thumbs') { - return; - } - measure(); - pickThumbsToLoad(); - lazyLoad(); - } - - if ($.fn.resizable) { - onLast(self.container, 'resize', mpl); - } - - onLast(self.window, 'resize', mpl); - onLast(self.content, 'scroll', mpl); - - self.element.on('viewchanged selected', mpl); - - mpl(); - } - - - function preloadThumb(file, cb) { - var img = new o.Image(); - - img.onload = function() { - var thumb = $('#' + file.id + ' .plupload_file_thumb', self.filelist).html(''); - this.embed(thumb[0], { - width: 100, - height: 60, - crop: true, - swf_url: o.resolveUrl(self.options.flash_swf_url), - xap_url: o.resolveUrl(self.options.silverlight_xap_url) - }); - }; - - img.bind("embedded error", function() { - $('#' + file.id, self.filelist).addClass('plupload_file_thumb_loaded'); - this.destroy(); - setTimeout(cb, 1); // detach, otherwise ui might hang (in SilverLight for example) - }); - - img.load(file.getSource()); - } - - - function lazyLoad() { - if (self.view_mode !== 'thumbs' || loading) { - return; - } - - pickThumbsToLoad(); - if (!thumbs.length) { - return; - } - - loading = true; - - preloadThumb(self.getFile($(thumbs.shift()).attr('id')), function() { - loading = false; - lazyLoad(); - }); - } - - // this has to run only once to measure structures and bind listeners - this.element.on('selected', function onselected() { - self.element.off('selected', onselected); - init(); - }); - }, - - - _addFiles: function(files) { - var self = this, file_html; - - file_html = '
    • ' + - '
      ' + - '
      %ext%
      ' + - '
      ' + - '
      %name%
      ' + - '
      ' + - '
      %size%
      ' + - '
      ' + - '
      ' + - '%percent% ' + - '
      ' + - '
      ' + - '
    • '; - - if (plupload.typeOf(files) !== 'array') { - files = [files]; - } - - $.each(files, function(i, file) { - var ext = o.Mime.getFileExtension(file.name) || 'none'; - - self.filelist.append(file_html.replace(/%(\w+)%/g, function($0, $1) { - if ('size' === $1) { - return plupload.formatSize(file.size); - } else if ('ext' === $1) { - return ext; - } else { - return file[$1] || ''; - } - })); - - self._handleFileStatus(file); - }); - }, - - - _removeFiles: function(files) { - var self = this, up = this.uploader; - - if (plupload.typeOf(files) !== 'array') { - files = [files]; - } - - // destroy sortable if enabled - if ($.ui.sortable && this.options.sortable) { - $('tbody', self.filelist).sortable('destroy'); - } - - $.each(files, function(i, file) { - $('#' + file.id).toggle("highlight", function() { - this.remove(); - }); - up.removeFile(file); - }); - - - if (up.files.length) { - // re-initialize sortable - if (this.options.sortable && $.ui.sortable) { - this._enableSortingList(); - } - } - - this._trigger('updatelist', null, { filelist: this.filelist }); - }, - - - _addFormFields: function() { - var self = this; - - // re-add from fresh - $('.plupload_file_fields', this.filelist).html(''); - - plupload.each(this.uploader.files, function(file, count) { - var fields = '' - , id = self.id + '_' + count - ; - - if (file.target_name) { - fields += ''; - } - fields += ''; - fields += ''; - - $('#' + file.id).find('.plupload_file_fields').html(fields); - }); - - this.counter.val(this.uploader.files.length); - }, - - - _viewChanged: function(view) { - // update or write a new cookie - if (this.options.views.remember && $.cookie) { - $.cookie('plupload_ui_view', view, { expires: 7, path: '/' }); - } - - // ugly fix for IE6 - make content area stretchable - if (o.Env.browser === 'IE' && o.Env.version < 7) { - this.content.attr('style', 'height:expression(document.getElementById("' + this.id + '_container' + '").clientHeight - ' + (view === 'list' ? 133 : 103) + ');'); - } - - this.container.removeClass('plupload_view_list plupload_view_thumbs').addClass('plupload_view_' + view); - this.view_mode = view; - this._trigger('viewchanged', null, { view: view }); - }, - - - _enableViewSwitcher: function() { - var self = this - , view - , switcher = $('.plupload_view_switch', this.container) - , buttons - , button - ; - - plupload.each(['list', 'thumbs'], function(view) { - if (!self.options.views[view]) { - switcher.find('[for="' + self.id + '_view_' + view + '"], #'+ self.id +'_view_' + view).remove(); - } - }); - - // check if any visible left - buttons = switcher.find('.plupload_button'); - - if (buttons.length === 1) { - switcher.hide(); - view = buttons.eq(0).data('view'); - this._viewChanged(view); - } else if ($.ui.button && buttons.length > 1) { - if (this.options.views.remember && $.cookie) { - view = $.cookie('plupload_ui_view'); - } - - // if wierd case, bail out to default - if (!~plupload.inArray(view, ['list', 'thumbs'])) { - view = this.options.views.active; - } - - switcher - .show() - .buttonset() - .find('.ui-button') - .click(function(e) { - view = $(this).data('view'); - self._viewChanged(view); - e.preventDefault(); // avoid auto scrolling to widget in IE and FF (see #850) - }); - - // if view not active - happens when switcher wasn't clicked manually - button = switcher.find('[for="' + self.id + '_view_'+view+'"]'); - if (button.length) { - button.trigger('click'); - } - } else { - switcher.show(); - this._viewChanged(this.options.views.active); - } - - // initialize thumb viewer if requested - if (this.options.views.thumbs) { - this._displayThumbs(); - } - }, - - - _enableRenaming: function() { - var self = this; - - this.filelist.dblclick(function(e) { - var nameSpan = $(e.target), nameInput, file, parts, name, ext = ""; - - if (!nameSpan.hasClass('plupload_file_namespan')) { - return; - } - - // Get file name and split out name and extension - file = self.uploader.getFile(nameSpan.closest('.plupload_file')[0].id); - name = file.name; - parts = /^(.+)(\.[^.]+)$/.exec(name); - if (parts) { - name = parts[1]; - ext = parts[2]; - } - - // Display input element - nameInput = $('').width(nameSpan.width()).insertAfter(nameSpan.hide()); - nameInput.val(name).blur(function() { - nameSpan.show().parent().scrollLeft(0).end().next().remove(); - }).keydown(function(e) { - var nameInput = $(this); - - if ($.inArray(e.keyCode, [13, 27]) !== -1) { - e.preventDefault(); - - // Rename file and glue extension back on - if (e.keyCode === 13) { - file.name = nameInput.val() + ext; - nameSpan.html(file.name); - } - nameInput.blur(); - } - })[0].focus(); - }); - }, - - - _enableSortingList: function() { - var self = this; - - if ($('.plupload_file', this.filelist).length < 2) { - return; - } - - // destroy sortable if enabled - $('tbody', this.filelist).sortable('destroy'); - - // enable - this.filelist.sortable({ - items: '.plupload_delete', - - cancel: 'object, .plupload_clearer', - - stop: function() { - var files = []; - - $.each($(this).sortable('toArray'), function(i, id) { - files[files.length] = self.uploader.getFile(id); - }); - - files.unshift(files.length); - files.unshift(0); - - // re-populate files array - Array.prototype.splice.apply(self.uploader.files, files); - } - }); - } -}); - -} (window, document, plupload, mOxie, jQuery)); diff --git a/demo/js/plupload/jquery.ui.plupload/jquery.ui.plupload.min.js b/demo/js/plupload/jquery.ui.plupload/jquery.ui.plupload.min.js deleted file mode 100644 index c7be0ece..00000000 --- a/demo/js/plupload/jquery.ui.plupload/jquery.ui.plupload.min.js +++ /dev/null @@ -1 +0,0 @@ -;(function(e,t,n,r,i){function o(e){return n.translate(e)||e}function u(e){e.id=e.attr("id"),e.html('
      '+o("Select files")+"
      "+'
      '+o("Add files to the upload queue and click the start button.")+"
      "+'
      '+'"+'"+"
      "+"
      "+"
      "+''+""+'"+'"+'"+''+""+"
      '+o("Filename")+"'+o("Status")+"'+o("Size")+" 
      "+'
      '+'
      '+o("Drag files here.")+"
      "+'
      '+'
       
      '+"
      "+''+""+'"+''+''+''+""+""+"
      "+''+"
      ")}var s={};i.widget("ui.plupload",{widgetEventPrefix:"",contents_bak:"",options:{browse_button_hover:"ui-state-hover",browse_button_active:"ui-state-active",dragdrop:!0,multiple_queues:!0,buttons:{browse:!0,start:!0,stop:!0},views:{list:!0,thumbs:!1,active:"list",remember:!0},autostart:!1,sortable:!1,rename:!1,max_file_count:0},FILE_COUNT_ERROR:-9001,_create:function(){var e=this.element.attr("id");e||(e=n.guid(),this.element.attr("id",e)),this.id=e,this.contents_bak=this.element.html(),u(this.element),this.container=i(".plupload_container",this.element).attr("id",e+"_container"),this.content=i(".plupload_content",this.element),i.fn.resizable&&this.container.resizable({handles:"s",minHeight:300}),this.filelist=i(".plupload_filelist_content",this.container).attr({id:e+"_filelist",unselectable:"on"}),this.browse_button=i(".plupload_add",this.container).attr("id",e+"_browse"),this.start_button=i(".plupload_start",this.container).attr("id",e+"_start"),this.stop_button=i(".plupload_stop",this.container).attr("id",e+"_stop"),this.thumbs_switcher=i("#"+e+"_view_thumbs"),this.list_switcher=i("#"+e+"_view_list"),i.ui.button&&(this.browse_button.button({icons:{primary:"ui-icon-circle-plus"},disabled:!0}),this.start_button.button({icons:{primary:"ui-icon-circle-arrow-e"},disabled:!0}),this.stop_button.button({icons:{primary:"ui-icon-circle-close"}}),this.list_switcher.button({text:!1,icons:{secondary:"ui-icon-grip-dotted-horizontal"}}),this.thumbs_switcher.button({text:!1,icons:{secondary:"ui-icon-image"}})),this.progressbar=i(".plupload_progress_container",this.container),i.ui.progressbar&&this.progressbar.progressbar(),this.counter=i(".plupload_count",this.element).attr({id:e+"_count",name:e+"_count"}),this._initUploader()},_initUploader:function(){var e=this,t=this.id,u,a={container:t+"_buttons",browse_button:t+"_browse"};i(".plupload_buttons",this.element).attr("id",t+"_buttons"),e.options.dragdrop&&(this.filelist.parent().attr("id",this.id+"_dropbox"),a.drop_element=this.id+"_dropbox"),u=this.uploader=s[t]=new n.Uploader(i.extend(this.options,a)),e.options.views.thumbs&&(u.settings.required_features.display_media=!0),u.bind("Error",function(t,i){var s,u="";s=""+i.message+"";switch(i.code){case n.FILE_EXTENSION_ERROR:u=r.sprintf(o("File: %s"),i.file.name);break;case n.FILE_SIZE_ERROR:u=r.sprintf(o("File: %s, size: %d, max file size: %d"),i.file.name,i.file.size,n.parseSize(e.options.max_file_size));break;case n.FILE_DUPLICATE_ERROR:u=r.sprintf(o("%s already present in the queue."),i.file.name);break;case e.FILE_COUNT_ERROR:u=r.sprintf(o("Upload element accepts only %d file(s) at a time. Extra files were stripped."),e.options.max_file_count);break;case n.IMAGE_FORMAT_ERROR:u=o("Image format either wrong or not supported.");break;case n.IMAGE_MEMORY_ERROR:u=o("Runtime ran out of available memory.");break;case n.HTTP_ERROR:u=o("Upload URL might be wrong or doesn't exist.")}s+="
      "+u+"",e._trigger("error",null,{up:t,error:i}),i.code===n.INIT_ERROR?setTimeout(function(){e.destroy()},1):e.notify("error",s)}),u.bind("PostInit",function(t){e.options.buttons.browse?e.browse_button.button("enable"):(e.browse_button.button("disable").hide(),t.disableBrowse(!0)),e.options.buttons.start||e.start_button.button("disable").hide(),e.options.buttons.stop||e.stop_button.button("disable").hide(),!e.options.unique_names&&e.options.rename&&e._enableRenaming(),e.options.dragdrop&&t.features.dragdrop&&e.filelist.parent().addClass("plupload_dropbox"),e._enableViewSwitcher(),e.start_button.click(function(t){i(this).button("option","disabled")||e.start(),t.preventDefault()}),e.stop_button.click(function(t){e.stop(),t.preventDefault()}),e._trigger("ready",null,{up:t})}),e.options.max_file_count&&(e.options.multiple_queues=!1,u.bind("FilesAdded",function(t,n){var r=n.length,i=t.files.length+r-e.options.max_file_count;i>0&&(n.splice(r-i,i),t.trigger("Error",{code:e.FILE_COUNT_ERROR,message:o("File count error.")}))})),u.init(),u.bind("FileFiltered",function(t,n){e._addFiles(n)}),u.bind("FilesAdded",function(t,n){e._trigger("selected",null,{up:t,files:n}),e.options.sortable&&i.ui.sortable&&e._enableSortingList(),e._trigger("updatelist",null,{filelist:e.filelist}),e.options.autostart&&setTimeout(function(){e.start()},10)}),u.bind("FilesRemoved",function(t,n){e._trigger("removed",null,{up:t,files:n})}),u.bind("QueueChanged StateChanged",function(){e._handleState()}),u.bind("UploadFile",function(t,n){e._handleFileStatus(n)}),u.bind("FileUploaded",function(t,n){e._handleFileStatus(n),e._trigger("uploaded",null,{up:t,file:n})}),u.bind("UploadProgress",function(t,n){e._handleFileStatus(n),e._updateTotalProgress(),e._trigger("progress",null,{up:t,file:n})}),u.bind("UploadComplete",function(t,n){e._addFormFields(),e._trigger("complete",null,{up:t,files:n})})},_setOption:function(e,t){var n=this;e=="buttons"&&typeof t=="object"&&(t=i.extend(n.options.buttons,t),t.browse?(n.browse_button.button("enable").show(),n.uploader.disableBrowse(!1)):(n.browse_button.button("disable").hide(),n.uploader.disableBrowse(!0)),t.start?n.start_button.button("enable").show():n.start_button.button("disable").hide(),t.stop?n.start_button.button("enable").show():n.stop_button.button("disable").hide()),n.uploader.settings[e]=t},start:function(){this.uploader.start(),this._trigger("start",null,{up:this.uploader})},stop:function(){this.uploader.stop(),this._trigger("stop",null,{up:this.uploader})},enable:function(){this.browse_button.button("enable"),this.uploader.disableBrowse(!1)},disable:function(){this.browse_button.button("disable"),this.uploader.disableBrowse(!0)},getFile:function(e){var t;return typeof e=="number"?t=this.uploader.files[e]:t=this.uploader.getFile(e),t},getFiles:function(){return this.uploader.files},removeFile:function(e){n.typeOf(e)==="string"&&(e=this.getFile(e)),this._removeFiles(e)},clearQueue:function(){this.uploader.splice()},getUploader:function(){return this.uploader},refresh:function(){this.uploader.refresh()},notify:function(e,t){var n=i('
      '+'

      '+t+"

      "+"
      ");n.addClass("ui-state-"+(e==="error"?"error":"highlight")).find("p .ui-icon").addClass("ui-icon-"+(e==="error"?"alert":"info")).end().find(".plupload_message_close").click(function(){n.remove()}).end(),i(".plupload_header",this.container).append(n)},destroy:function(){this._removeFiles([].slice.call(this.uploader.files)),this.uploader.destroy(),i(".plupload_button",this.element).unbind(),i.ui.button&&i(".plupload_add, .plupload_start, .plupload_stop",this.container).button("destroy"),i.ui.progressbar&&this.progressbar.progressbar("destroy"),i.ui.sortable&&this.options.sortable&&i("tbody",this.filelist).sortable("destroy"),this.element.empty().html(this.contents_bak),this.contents_bak="",i.Widget.prototype.destroy.apply(this)},_handleState:function(){var e=this.uploader;e.state===n.STARTED?(i(this.start_button).button("disable"),i([]).add(this.stop_button).add(".plupload_started").removeClass("plupload_hidden"),i(".plupload_upload_status",this.element).html(r.sprintf(o("Uploaded %d/%d files"),e.total.uploaded,e.files.length)),i(".plupload_header_content",this.element).addClass("plupload_header_content_bw")):e.state===n.STOPPED&&(i([]).add(this.stop_button).add(".plupload_started").addClass("plupload_hidden"),this.options.multiple_queues?i(".plupload_header_content",this.element).removeClass("plupload_header_content_bw"):(i([]).add(this.browse_button).add(this.start_button).button("disable"),e.disableBrowse()),e.files.length===e.total.uploaded+e.total.failed?this.start_button.button("disable"):this.start_button.button("enable"),this._updateTotalProgress()),e.total.queued===0?i(".ui-button-text",this.browse_button).html(o("Add Files")):i(".ui-button-text",this.browse_button).html(r.sprintf(o("%d files queued"),e.total.queued)),e.refresh()},_handleFileStatus:function(e){var t=this,r,s;if(!i("#"+e.id).length)return;switch(e.status){case n.DONE:r="plupload_done",s="ui-icon ui-icon-circle-check";break;case n.FAILED:r="ui-state-error plupload_failed",s="ui-icon ui-icon-alert";break;case n.QUEUED:r="plupload_delete",s="ui-icon ui-icon-circle-minus";break;case n.UPLOADING:r="ui-state-highlight plupload_uploading",s="ui-icon ui-icon-circle-arrow-w";var o=i(".plupload_scroll",this.container),u=o.scrollTop(),a=o.height(),f=i("#"+e.id).position().top+i("#"+e.id).height();a
      %ext%
      %name%
      %size%
      %percent%
      ',n.typeOf(e)!=="array"&&(e=[e]),i.each(e,function(e,i){var o=r.Mime.getFileExtension(i.name)||"none";t.filelist.append(s.replace(/%(\w+)%/g,function(e,t){return"size"===t?n.formatSize(i.size):"ext"===t?o:i[t]||""})),t._handleFileStatus(i)})},_removeFiles:function(e){var t=this,r=this.uploader;n.typeOf(e)!=="array"&&(e=[e]),i.ui.sortable&&this.options.sortable&&i("tbody",t.filelist).sortable("destroy"),i.each(e,function(e,t){i("#"+t.id).toggle("highlight",function(){this.remove()}),r.removeFile(t)}),r.files.length&&this.options.sortable&&i.ui.sortable&&this._enableSortingList(),this._trigger("updatelist",null,{filelist:this.filelist})},_addFormFields:function(){var e=this;i(".plupload_file_fields",this.filelist).html(""),n.each(this.uploader.files,function(t,r){var s="",o=e.id+"_"+r;t.target_name&&(s+=''),s+='',s+='',i("#"+t.id).find(".plupload_file_fields").html(s)}),this.counter.val(this.uploader.files.length)},_viewChanged:function(e){this.options.views.remember&&i.cookie&&i.cookie("plupload_ui_view",e,{expires:7,path:"/"}),r.Env.browser==="IE"&&r.Env.version<7&&this.content.attr("style",'height:expression(document.getElementById("'+this.id+"_container"+'").clientHeight - '+(e==="list"?133:103)+");"),this.container.removeClass("plupload_view_list plupload_view_thumbs").addClass("plupload_view_"+e),this.view_mode=e,this._trigger("viewchanged",null,{view:e})},_enableViewSwitcher:function(){var e=this,t,r=i(".plupload_view_switch",this.container),s,o;n.each(["list","thumbs"],function(t){e.options.views[t]||r.find('[for="'+e.id+"_view_"+t+'"], #'+e.id+"_view_"+t).remove()}),s=r.find(".plupload_button"),s.length===1?(r.hide(),t=s.eq(0).data("view"),this._viewChanged(t)):i.ui.button&&s.length>1?(this.options.views.remember&&i.cookie&&(t=i.cookie("plupload_ui_view")),~n.inArray(t,["list","thumbs"])||(t=this.options.views.active),r.show().buttonset().find(".ui-button").click(function(n){t=i(this).data("view"),e._viewChanged(t),n.preventDefault()}),o=r.find('[for="'+e.id+"_view_"+t+'"]'),o.length&&o.trigger("click")):(r.show(),this._viewChanged(this.options.views.active)),this.options.views.thumbs&&this._displayThumbs()},_enableRenaming:function(){var e=this;this.filelist.dblclick(function(t){var n=i(t.target),r,s,o,u,a="";if(!n.hasClass("plupload_file_namespan"))return;s=e.uploader.getFile(n.closest(".plupload_file")[0].id),u=s.name,o=/^(.+)(\.[^.]+)$/.exec(u),o&&(u=o[1],a=o[2]),r=i('').width(n.width()).insertAfter(n.hide()),r.val(u).blur(function(){n.show().parent().scrollLeft(0).end().next().remove()}).keydown(function(e){var t=i(this);i.inArray(e.keyCode,[13,27])!==-1&&(e.preventDefault(),e.keyCode===13&&(s.name=t.val()+a,n.html(s.name)),t.blur())})[0].focus()})},_enableSortingList:function(){var e=this;if(i(".plupload_file",this.filelist).length<2)return;i("tbody",this.filelist).sortable("destroy"),this.filelist.sortable({items:".plupload_delete",cancel:"object, .plupload_clearer",stop:function(){var t=[];i.each(i(this).sortable("toArray"),function(n,r){t[t.length]=e.uploader.getFile(r)}),t.unshift(t.length),t.unshift(0),Array.prototype.splice.apply(e.uploader.files,t)}})}})})(window,document,plupload,mOxie,jQuery); \ No newline at end of file diff --git a/demo/js/plupload/moxie.js b/demo/js/plupload/moxie.js deleted file mode 100644 index afd0aec4..00000000 --- a/demo/js/plupload/moxie.js +++ /dev/null @@ -1,10684 +0,0 @@ -/** - * mOxie - multi-runtime File API & XMLHttpRequest L2 Polyfill - * v1.2.0 - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - * - * Date: 2014-01-16 - */ -/** - * Compiled inline version. (Library mode) - */ - -/*jshint smarttabs:true, undef:true, latedef:true, curly:true, bitwise:true, camelcase:true */ -/*globals $code */ - -(function(exports, undefined) { - "use strict"; - - var modules = {}; - - function require(ids, callback) { - var module, defs = []; - - for (var i = 0; i < ids.length; ++i) { - module = modules[ids[i]] || resolve(ids[i]); - if (!module) { - throw 'module definition dependecy not found: ' + ids[i]; - } - - defs.push(module); - } - - callback.apply(null, defs); - } - - function define(id, dependencies, definition) { - if (typeof id !== 'string') { - throw 'invalid module definition, module id must be defined and be a string'; - } - - if (dependencies === undefined) { - throw 'invalid module definition, dependencies must be specified'; - } - - if (definition === undefined) { - throw 'invalid module definition, definition function must be specified'; - } - - require(dependencies, function() { - modules[id] = definition.apply(null, arguments); - }); - } - - function defined(id) { - return !!modules[id]; - } - - function resolve(id) { - var target = exports; - var fragments = id.split(/[.\/]/); - - for (var fi = 0; fi < fragments.length; ++fi) { - if (!target[fragments[fi]]) { - return; - } - - target = target[fragments[fi]]; - } - - return target; - } - - function expose(ids) { - for (var i = 0; i < ids.length; i++) { - var target = exports; - var id = ids[i]; - var fragments = id.split(/[.\/]/); - - for (var fi = 0; fi < fragments.length - 1; ++fi) { - if (target[fragments[fi]] === undefined) { - target[fragments[fi]] = {}; - } - - target = target[fragments[fi]]; - } - - target[fragments[fragments.length - 1]] = modules[id]; - } - } - -// Included from: src/javascript/core/utils/Basic.js - -/** - * Basic.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/core/utils/Basic', [], function() { - /** - Gets the true type of the built-in object (better version of typeof). - @author Angus Croll (http://javascriptweblog.wordpress.com/) - - @method typeOf - @for Utils - @static - @param {Object} o Object to check. - @return {String} Object [[Class]] - */ - var typeOf = function(o) { - var undef; - - if (o === undef) { - return 'undefined'; - } else if (o === null) { - return 'null'; - } else if (o.nodeType) { - return 'node'; - } - - // the snippet below is awesome, however it fails to detect null, undefined and arguments types in IE lte 8 - return ({}).toString.call(o).match(/\s([a-z|A-Z]+)/)[1].toLowerCase(); - }; - - /** - Extends the specified object with another object. - - @method extend - @static - @param {Object} target Object to extend. - @param {Object} [obj]* Multiple objects to extend with. - @return {Object} Same as target, the extended object. - */ - var extend = function(target) { - var undef; - - each(arguments, function(arg, i) { - if (i > 0) { - each(arg, function(value, key) { - if (value !== undef) { - if (typeOf(target[key]) === typeOf(value) && !!~inArray(typeOf(value), ['array', 'object'])) { - extend(target[key], value); - } else { - target[key] = value; - } - } - }); - } - }); - return target; - }; - - /** - Executes the callback function for each item in array/object. If you return false in the - callback it will break the loop. - - @method each - @static - @param {Object} obj Object to iterate. - @param {function} callback Callback function to execute for each item. - */ - var each = function(obj, callback) { - var length, key, i, undef; - - if (obj) { - try { - length = obj.length; - } catch(ex) { - length = undef; - } - - if (length === undef) { - // Loop object items - for (key in obj) { - if (obj.hasOwnProperty(key)) { - if (callback(obj[key], key) === false) { - return; - } - } - } - } else { - // Loop array items - for (i = 0; i < length; i++) { - if (callback(obj[i], i) === false) { - return; - } - } - } - } - }; - - /** - Checks if object is empty. - - @method isEmptyObj - @static - @param {Object} o Object to check. - @return {Boolean} - */ - var isEmptyObj = function(obj) { - var prop; - - if (!obj || typeOf(obj) !== 'object') { - return true; - } - - for (prop in obj) { - return false; - } - - return true; - }; - - /** - Recieve an array of functions (usually async) to call in sequence, each function - receives a callback as first argument that it should call, when it completes. Finally, - after everything is complete, main callback is called. Passing truthy value to the - callback as a first argument will interrupt the sequence and invoke main callback - immediately. - - @method inSeries - @static - @param {Array} queue Array of functions to call in sequence - @param {Function} cb Main callback that is called in the end, or in case of erro - */ - var inSeries = function(queue, cb) { - var i = 0, length = queue.length; - - if (typeOf(cb) !== 'function') { - cb = function() {}; - } - - if (!queue || !queue.length) { - cb(); - } - - function callNext(i) { - if (typeOf(queue[i]) === 'function') { - queue[i](function(error) { - /*jshint expr:true */ - ++i < length && !error ? callNext(i) : cb(error); - }); - } - } - callNext(i); - }; - - - /** - Recieve an array of functions (usually async) to call in parallel, each function - receives a callback as first argument that it should call, when it completes. After - everything is complete, main callback is called. Passing truthy value to the - callback as a first argument will interrupt the process and invoke main callback - immediately. - - @method inParallel - @static - @param {Array} queue Array of functions to call in sequence - @param {Function} cb Main callback that is called in the end, or in case of erro - */ - var inParallel = function(queue, cb) { - var count = 0, num = queue.length, cbArgs = new Array(num); - - each(queue, function(fn, i) { - fn(function(error) { - if (error) { - return cb(error); - } - - var args = [].slice.call(arguments); - args.shift(); // strip error - undefined or not - - cbArgs[i] = args; - count++; - - if (count === num) { - cbArgs.unshift(null); - cb.apply(this, cbArgs); - } - }); - }); - }; - - - /** - Find an element in array and return it's index if present, otherwise return -1. - - @method inArray - @static - @param {Mixed} needle Element to find - @param {Array} array - @return {Int} Index of the element, or -1 if not found - */ - var inArray = function(needle, array) { - if (array) { - if (Array.prototype.indexOf) { - return Array.prototype.indexOf.call(array, needle); - } - - for (var i = 0, length = array.length; i < length; i++) { - if (array[i] === needle) { - return i; - } - } - } - return -1; - }; - - - /** - Returns elements of first array if they are not present in second. And false - otherwise. - - @private - @method arrayDiff - @param {Array} needles - @param {Array} array - @return {Array|Boolean} - */ - var arrayDiff = function(needles, array) { - var diff = []; - - if (typeOf(needles) !== 'array') { - needles = [needles]; - } - - if (typeOf(array) !== 'array') { - array = [array]; - } - - for (var i in needles) { - if (inArray(needles[i], array) === -1) { - diff.push(needles[i]); - } - } - return diff.length ? diff : false; - }; - - - /** - Find intersection of two arrays. - - @private - @method arrayIntersect - @param {Array} array1 - @param {Array} array2 - @return {Array} Intersection of two arrays or null if there is none - */ - var arrayIntersect = function(array1, array2) { - var result = []; - each(array1, function(item) { - if (inArray(item, array2) !== -1) { - result.push(item); - } - }); - return result.length ? result : null; - }; - - - /** - Forces anything into an array. - - @method toArray - @static - @param {Object} obj Object with length field. - @return {Array} Array object containing all items. - */ - var toArray = function(obj) { - var i, arr = []; - - for (i = 0; i < obj.length; i++) { - arr[i] = obj[i]; - } - - return arr; - }; - - - /** - Generates an unique ID. This is 99.99% unique since it takes the current time and 5 random numbers. - The only way a user would be able to get the same ID is if the two persons at the same exact milisecond manages - to get 5 the same random numbers between 0-65535 it also uses a counter so each call will be guaranteed to be page unique. - It's more probable for the earth to be hit with an ansteriod. Y - - @method guid - @static - @param {String} prefix to prepend (by default 'o' will be prepended). - @method guid - @return {String} Virtually unique id. - */ - var guid = (function() { - var counter = 0; - - return function(prefix) { - var guid = new Date().getTime().toString(32), i; - - for (i = 0; i < 5; i++) { - guid += Math.floor(Math.random() * 65535).toString(32); - } - - return (prefix || 'o_') + guid + (counter++).toString(32); - }; - }()); - - - /** - Trims white spaces around the string - - @method trim - @static - @param {String} str - @return {String} - */ - var trim = function(str) { - if (!str) { - return str; - } - return String.prototype.trim ? String.prototype.trim.call(str) : str.toString().replace(/^\s*/, '').replace(/\s*$/, ''); - }; - - - /** - Parses the specified size string into a byte value. For example 10kb becomes 10240. - - @method parseSizeStr - @static - @param {String/Number} size String to parse or number to just pass through. - @return {Number} Size in bytes. - */ - var parseSizeStr = function(size) { - if (typeof(size) !== 'string') { - return size; - } - - var muls = { - t: 1099511627776, - g: 1073741824, - m: 1048576, - k: 1024 - }, - mul; - - size = /^([0-9]+)([mgk]?)$/.exec(size.toLowerCase().replace(/[^0-9mkg]/g, '')); - mul = size[2]; - size = +size[1]; - - if (muls.hasOwnProperty(mul)) { - size *= muls[mul]; - } - return size; - }; - - - return { - guid: guid, - typeOf: typeOf, - extend: extend, - each: each, - isEmptyObj: isEmptyObj, - inSeries: inSeries, - inParallel: inParallel, - inArray: inArray, - arrayDiff: arrayDiff, - arrayIntersect: arrayIntersect, - toArray: toArray, - trim: trim, - parseSizeStr: parseSizeStr - }; -}); - -// Included from: src/javascript/core/I18n.js - -/** - * I18n.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define("moxie/core/I18n", [ - "moxie/core/utils/Basic" -], function(Basic) { - var i18n = {}; - - return { - /** - * Extends the language pack object with new items. - * - * @param {Object} pack Language pack items to add. - * @return {Object} Extended language pack object. - */ - addI18n: function(pack) { - return Basic.extend(i18n, pack); - }, - - /** - * Translates the specified string by checking for the english string in the language pack lookup. - * - * @param {String} str String to look for. - * @return {String} Translated string or the input string if it wasn't found. - */ - translate: function(str) { - return i18n[str] || str; - }, - - /** - * Shortcut for translate function - * - * @param {String} str String to look for. - * @return {String} Translated string or the input string if it wasn't found. - */ - _: function(str) { - return this.translate(str); - }, - - /** - * Pseudo sprintf implementation - simple way to replace tokens with specified values. - * - * @param {String} str String with tokens - * @return {String} String with replaced tokens - */ - sprintf: function(str) { - var args = [].slice.call(arguments, 1); - - return str.replace(/%[a-z]/g, function() { - var value = args.shift(); - return Basic.typeOf(value) !== 'undefined' ? value : ''; - }); - } - }; -}); - -// Included from: src/javascript/core/utils/Mime.js - -/** - * Mime.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define("moxie/core/utils/Mime", [ - "moxie/core/utils/Basic", - "moxie/core/I18n" -], function(Basic, I18n) { - - var mimeData = "" + - "application/msword,doc dot," + - "application/pdf,pdf," + - "application/pgp-signature,pgp," + - "application/postscript,ps ai eps," + - "application/rtf,rtf," + - "application/vnd.ms-excel,xls xlb," + - "application/vnd.ms-powerpoint,ppt pps pot," + - "application/zip,zip," + - "application/x-shockwave-flash,swf swfl," + - "application/vnd.openxmlformats-officedocument.wordprocessingml.document,docx," + - "application/vnd.openxmlformats-officedocument.wordprocessingml.template,dotx," + - "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,xlsx," + - "application/vnd.openxmlformats-officedocument.presentationml.presentation,pptx," + - "application/vnd.openxmlformats-officedocument.presentationml.template,potx," + - "application/vnd.openxmlformats-officedocument.presentationml.slideshow,ppsx," + - "application/x-javascript,js," + - "application/json,json," + - "audio/mpeg,mp3 mpga mpega mp2," + - "audio/x-wav,wav," + - "audio/x-m4a,m4a," + - "audio/ogg,oga ogg," + - "audio/aiff,aiff aif," + - "audio/flac,flac," + - "audio/aac,aac," + - "audio/ac3,ac3," + - "audio/x-ms-wma,wma," + - "image/bmp,bmp," + - "image/gif,gif," + - "image/jpeg,jpg jpeg jpe," + - "image/photoshop,psd," + - "image/png,png," + - "image/svg+xml,svg svgz," + - "image/tiff,tiff tif," + - "text/plain,asc txt text diff log," + - "text/html,htm html xhtml," + - "text/css,css," + - "text/csv,csv," + - "text/rtf,rtf," + - "video/mpeg,mpeg mpg mpe m2v," + - "video/quicktime,qt mov," + - "video/mp4,mp4," + - "video/x-m4v,m4v," + - "video/x-flv,flv," + - "video/x-ms-wmv,wmv," + - "video/avi,avi," + - "video/webm,webm," + - "video/3gpp,3gpp 3gp," + - "video/3gpp2,3g2," + - "video/vnd.rn-realvideo,rv," + - "video/ogg,ogv," + - "video/x-matroska,mkv," + - "application/vnd.oasis.opendocument.formula-template,otf," + - "application/octet-stream,exe"; - - - var Mime = { - - mimes: {}, - - extensions: {}, - - // Parses the default mime types string into a mimes and extensions lookup maps - addMimeType: function (mimeData) { - var items = mimeData.split(/,/), i, ii, ext; - - for (i = 0; i < items.length; i += 2) { - ext = items[i + 1].split(/ /); - - // extension to mime lookup - for (ii = 0; ii < ext.length; ii++) { - this.mimes[ext[ii]] = items[i]; - } - // mime to extension lookup - this.extensions[items[i]] = ext; - } - }, - - - extList2mimes: function (filters, addMissingExtensions) { - var self = this, ext, i, ii, type, mimes = []; - - // convert extensions to mime types list - for (i = 0; i < filters.length; i++) { - ext = filters[i].extensions.split(/\s*,\s*/); - - for (ii = 0; ii < ext.length; ii++) { - - // if there's an asterisk in the list, then accept attribute is not required - if (ext[ii] === '*') { - return []; - } - - type = self.mimes[ext[ii]]; - if (!type) { - if (addMissingExtensions && /^\w+$/.test(ext[ii])) { - mimes.push('.' + ext[ii]); - } else { - return []; // accept all - } - } else if (Basic.inArray(type, mimes) === -1) { - mimes.push(type); - } - } - } - return mimes; - }, - - - mimes2exts: function(mimes) { - var self = this, exts = []; - - Basic.each(mimes, function(mime) { - if (mime === '*') { - exts = []; - return false; - } - - // check if this thing looks like mime type - var m = mime.match(/^(\w+)\/(\*|\w+)$/); - if (m) { - if (m[2] === '*') { - // wildcard mime type detected - Basic.each(self.extensions, function(arr, mime) { - if ((new RegExp('^' + m[1] + '/')).test(mime)) { - [].push.apply(exts, self.extensions[mime]); - } - }); - } else if (self.extensions[mime]) { - [].push.apply(exts, self.extensions[mime]); - } - } - }); - return exts; - }, - - - mimes2extList: function(mimes) { - var accept = [], exts = []; - - if (Basic.typeOf(mimes) === 'string') { - mimes = Basic.trim(mimes).split(/\s*,\s*/); - } - - exts = this.mimes2exts(mimes); - - accept.push({ - title: I18n.translate('Files'), - extensions: exts.length ? exts.join(',') : '*' - }); - - // save original mimes string - accept.mimes = mimes; - - return accept; - }, - - - getFileExtension: function(fileName) { - var matches = fileName && fileName.match(/\.([^.]+)$/); - if (matches) { - return matches[1].toLowerCase(); - } - return ''; - }, - - getFileMime: function(fileName) { - return this.mimes[this.getFileExtension(fileName)] || ''; - } - }; - - Mime.addMimeType(mimeData); - - return Mime; -}); - -// Included from: src/javascript/core/utils/Env.js - -/** - * Env.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define("moxie/core/utils/Env", [ - "moxie/core/utils/Basic" -], function(Basic) { - - // UAParser.js v0.6.2 - // Lightweight JavaScript-based User-Agent string parser - // https://github.com/faisalman/ua-parser-js - // - // Copyright © 2012-2013 Faisalman - // Dual licensed under GPLv2 & MIT - - var UAParser = (function (undefined) { - - ////////////// - // Constants - ///////////// - - - var EMPTY = '', - UNKNOWN = '?', - FUNC_TYPE = 'function', - UNDEF_TYPE = 'undefined', - OBJ_TYPE = 'object', - MAJOR = 'major', - MODEL = 'model', - NAME = 'name', - TYPE = 'type', - VENDOR = 'vendor', - VERSION = 'version', - ARCHITECTURE= 'architecture', - CONSOLE = 'console', - MOBILE = 'mobile', - TABLET = 'tablet'; - - - /////////// - // Helper - ////////// - - - var util = { - has : function (str1, str2) { - return str2.toLowerCase().indexOf(str1.toLowerCase()) !== -1; - }, - lowerize : function (str) { - return str.toLowerCase(); - } - }; - - - /////////////// - // Map helper - ////////////// - - - var mapper = { - - rgx : function () { - - // loop through all regexes maps - for (var result, i = 0, j, k, p, q, matches, match, args = arguments; i < args.length; i += 2) { - - var regex = args[i], // even sequence (0,2,4,..) - props = args[i + 1]; // odd sequence (1,3,5,..) - - // construct object barebones - if (typeof(result) === UNDEF_TYPE) { - result = {}; - for (p in props) { - q = props[p]; - if (typeof(q) === OBJ_TYPE) { - result[q[0]] = undefined; - } else { - result[q] = undefined; - } - } - } - - // try matching uastring with regexes - for (j = k = 0; j < regex.length; j++) { - matches = regex[j].exec(this.getUA()); - if (!!matches) { - for (p = 0; p < props.length; p++) { - match = matches[++k]; - q = props[p]; - // check if given property is actually array - if (typeof(q) === OBJ_TYPE && q.length > 0) { - if (q.length == 2) { - if (typeof(q[1]) == FUNC_TYPE) { - // assign modified match - result[q[0]] = q[1].call(this, match); - } else { - // assign given value, ignore regex match - result[q[0]] = q[1]; - } - } else if (q.length == 3) { - // check whether function or regex - if (typeof(q[1]) === FUNC_TYPE && !(q[1].exec && q[1].test)) { - // call function (usually string mapper) - result[q[0]] = match ? q[1].call(this, match, q[2]) : undefined; - } else { - // sanitize match using given regex - result[q[0]] = match ? match.replace(q[1], q[2]) : undefined; - } - } else if (q.length == 4) { - result[q[0]] = match ? q[3].call(this, match.replace(q[1], q[2])) : undefined; - } - } else { - result[q] = match ? match : undefined; - } - } - break; - } - } - - if(!!matches) break; // break the loop immediately if match found - } - return result; - }, - - str : function (str, map) { - - for (var i in map) { - // check if array - if (typeof(map[i]) === OBJ_TYPE && map[i].length > 0) { - for (var j = 0; j < map[i].length; j++) { - if (util.has(map[i][j], str)) { - return (i === UNKNOWN) ? undefined : i; - } - } - } else if (util.has(map[i], str)) { - return (i === UNKNOWN) ? undefined : i; - } - } - return str; - } - }; - - - /////////////// - // String map - ////////////// - - - var maps = { - - browser : { - oldsafari : { - major : { - '1' : ['/8', '/1', '/3'], - '2' : '/4', - '?' : '/' - }, - version : { - '1.0' : '/8', - '1.2' : '/1', - '1.3' : '/3', - '2.0' : '/412', - '2.0.2' : '/416', - '2.0.3' : '/417', - '2.0.4' : '/419', - '?' : '/' - } - } - }, - - device : { - sprint : { - model : { - 'Evo Shift 4G' : '7373KT' - }, - vendor : { - 'HTC' : 'APA', - 'Sprint' : 'Sprint' - } - } - }, - - os : { - windows : { - version : { - 'ME' : '4.90', - 'NT 3.11' : 'NT3.51', - 'NT 4.0' : 'NT4.0', - '2000' : 'NT 5.0', - 'XP' : ['NT 5.1', 'NT 5.2'], - 'Vista' : 'NT 6.0', - '7' : 'NT 6.1', - '8' : 'NT 6.2', - '8.1' : 'NT 6.3', - 'RT' : 'ARM' - } - } - } - }; - - - ////////////// - // Regex map - ///////////// - - - var regexes = { - - browser : [[ - - // Presto based - /(opera\smini)\/((\d+)?[\w\.-]+)/i, // Opera Mini - /(opera\s[mobiletab]+).+version\/((\d+)?[\w\.-]+)/i, // Opera Mobi/Tablet - /(opera).+version\/((\d+)?[\w\.]+)/i, // Opera > 9.80 - /(opera)[\/\s]+((\d+)?[\w\.]+)/i // Opera < 9.80 - - ], [NAME, VERSION, MAJOR], [ - - /\s(opr)\/((\d+)?[\w\.]+)/i // Opera Webkit - ], [[NAME, 'Opera'], VERSION, MAJOR], [ - - // Mixed - /(kindle)\/((\d+)?[\w\.]+)/i, // Kindle - /(lunascape|maxthon|netfront|jasmine|blazer)[\/\s]?((\d+)?[\w\.]+)*/i, - // Lunascape/Maxthon/Netfront/Jasmine/Blazer - - // Trident based - /(avant\s|iemobile|slim|baidu)(?:browser)?[\/\s]?((\d+)?[\w\.]*)/i, - // Avant/IEMobile/SlimBrowser/Baidu - /(?:ms|\()(ie)\s((\d+)?[\w\.]+)/i, // Internet Explorer - - // Webkit/KHTML based - /(rekonq)((?:\/)[\w\.]+)*/i, // Rekonq - /(chromium|flock|rockmelt|midori|epiphany|silk|skyfire|ovibrowser|bolt|iron)\/((\d+)?[\w\.-]+)/i - // Chromium/Flock/RockMelt/Midori/Epiphany/Silk/Skyfire/Bolt/Iron - ], [NAME, VERSION, MAJOR], [ - - /(trident).+rv[:\s]((\d+)?[\w\.]+).+like\sgecko/i // IE11 - ], [[NAME, 'IE'], VERSION, MAJOR], [ - - /(yabrowser)\/((\d+)?[\w\.]+)/i // Yandex - ], [[NAME, 'Yandex'], VERSION, MAJOR], [ - - /(comodo_dragon)\/((\d+)?[\w\.]+)/i // Comodo Dragon - ], [[NAME, /_/g, ' '], VERSION, MAJOR], [ - - /(chrome|omniweb|arora|[tizenoka]{5}\s?browser)\/v?((\d+)?[\w\.]+)/i - // Chrome/OmniWeb/Arora/Tizen/Nokia - ], [NAME, VERSION, MAJOR], [ - - /(dolfin)\/((\d+)?[\w\.]+)/i // Dolphin - ], [[NAME, 'Dolphin'], VERSION, MAJOR], [ - - /((?:android.+)crmo|crios)\/((\d+)?[\w\.]+)/i // Chrome for Android/iOS - ], [[NAME, 'Chrome'], VERSION, MAJOR], [ - - /((?:android.+))version\/((\d+)?[\w\.]+)\smobile\ssafari/i // Android Browser - ], [[NAME, 'Android Browser'], VERSION, MAJOR], [ - - /version\/((\d+)?[\w\.]+).+?mobile\/\w+\s(safari)/i // Mobile Safari - ], [VERSION, MAJOR, [NAME, 'Mobile Safari']], [ - - /version\/((\d+)?[\w\.]+).+?(mobile\s?safari|safari)/i // Safari & Safari Mobile - ], [VERSION, MAJOR, NAME], [ - - /webkit.+?(mobile\s?safari|safari)((\/[\w\.]+))/i // Safari < 3.0 - ], [NAME, [MAJOR, mapper.str, maps.browser.oldsafari.major], [VERSION, mapper.str, maps.browser.oldsafari.version]], [ - - /(konqueror)\/((\d+)?[\w\.]+)/i, // Konqueror - /(webkit|khtml)\/((\d+)?[\w\.]+)/i - ], [NAME, VERSION, MAJOR], [ - - // Gecko based - /(navigator|netscape)\/((\d+)?[\w\.-]+)/i // Netscape - ], [[NAME, 'Netscape'], VERSION, MAJOR], [ - /(swiftfox)/i, // Swiftfox - /(icedragon|iceweasel|camino|chimera|fennec|maemo\sbrowser|minimo|conkeror)[\/\s]?((\d+)?[\w\.\+]+)/i, - // IceDragon/Iceweasel/Camino/Chimera/Fennec/Maemo/Minimo/Conkeror - /(firefox|seamonkey|k-meleon|icecat|iceape|firebird|phoenix)\/((\d+)?[\w\.-]+)/i, - // Firefox/SeaMonkey/K-Meleon/IceCat/IceApe/Firebird/Phoenix - /(mozilla)\/((\d+)?[\w\.]+).+rv\:.+gecko\/\d+/i, // Mozilla - - // Other - /(uc\s?browser|polaris|lynx|dillo|icab|doris|amaya|w3m|netsurf|qqbrowser)[\/\s]?((\d+)?[\w\.]+)/i, - // UCBrowser/Polaris/Lynx/Dillo/iCab/Doris/Amaya/w3m/NetSurf/QQBrowser - /(links)\s\(((\d+)?[\w\.]+)/i, // Links - /(gobrowser)\/?((\d+)?[\w\.]+)*/i, // GoBrowser - /(ice\s?browser)\/v?((\d+)?[\w\._]+)/i, // ICE Browser - /(mosaic)[\/\s]((\d+)?[\w\.]+)/i // Mosaic - ], [NAME, VERSION, MAJOR] - ], - - engine : [[ - - /(presto)\/([\w\.]+)/i, // Presto - /(webkit|trident|netfront|netsurf|amaya|lynx|w3m)\/([\w\.]+)/i, // WebKit/Trident/NetFront/NetSurf/Amaya/Lynx/w3m - /(khtml|tasman|links)[\/\s]\(?([\w\.]+)/i, // KHTML/Tasman/Links - /(icab)[\/\s]([23]\.[\d\.]+)/i // iCab - ], [NAME, VERSION], [ - - /rv\:([\w\.]+).*(gecko)/i // Gecko - ], [VERSION, NAME] - ], - - os : [[ - - // Windows based - /(windows)\snt\s6\.2;\s(arm)/i, // Windows RT - /(windows\sphone(?:\sos)*|windows\smobile|windows)[\s\/]?([ntce\d\.\s]+\w)/i - ], [NAME, [VERSION, mapper.str, maps.os.windows.version]], [ - /(win(?=3|9|n)|win\s9x\s)([nt\d\.]+)/i - ], [[NAME, 'Windows'], [VERSION, mapper.str, maps.os.windows.version]], [ - - // Mobile/Embedded OS - /\((bb)(10);/i // BlackBerry 10 - ], [[NAME, 'BlackBerry'], VERSION], [ - /(blackberry)\w*\/?([\w\.]+)*/i, // Blackberry - /(tizen)\/([\w\.]+)/i, // Tizen - /(android|webos|palm\os|qnx|bada|rim\stablet\sos|meego)[\/\s-]?([\w\.]+)*/i - // Android/WebOS/Palm/QNX/Bada/RIM/MeeGo - ], [NAME, VERSION], [ - /(symbian\s?os|symbos|s60(?=;))[\/\s-]?([\w\.]+)*/i // Symbian - ], [[NAME, 'Symbian'], VERSION],[ - /mozilla.+\(mobile;.+gecko.+firefox/i // Firefox OS - ], [[NAME, 'Firefox OS'], VERSION], [ - - // Console - /(nintendo|playstation)\s([wids3portablevu]+)/i, // Nintendo/Playstation - - // GNU/Linux based - /(mint)[\/\s\(]?(\w+)*/i, // Mint - /(joli|[kxln]?ubuntu|debian|[open]*suse|gentoo|arch|slackware|fedora|mandriva|centos|pclinuxos|redhat|zenwalk)[\/\s-]?([\w\.-]+)*/i, - // Joli/Ubuntu/Debian/SUSE/Gentoo/Arch/Slackware - // Fedora/Mandriva/CentOS/PCLinuxOS/RedHat/Zenwalk - /(hurd|linux)\s?([\w\.]+)*/i, // Hurd/Linux - /(gnu)\s?([\w\.]+)*/i // GNU - ], [NAME, VERSION], [ - - /(cros)\s[\w]+\s([\w\.]+\w)/i // Chromium OS - ], [[NAME, 'Chromium OS'], VERSION],[ - - // Solaris - /(sunos)\s?([\w\.]+\d)*/i // Solaris - ], [[NAME, 'Solaris'], VERSION], [ - - // BSD based - /\s([frentopc-]{0,4}bsd|dragonfly)\s?([\w\.]+)*/i // FreeBSD/NetBSD/OpenBSD/PC-BSD/DragonFly - ], [NAME, VERSION],[ - - /(ip[honead]+)(?:.*os\s*([\w]+)*\slike\smac|;\sopera)/i // iOS - ], [[NAME, 'iOS'], [VERSION, /_/g, '.']], [ - - /(mac\sos\sx)\s?([\w\s\.]+\w)*/i // Mac OS - ], [NAME, [VERSION, /_/g, '.']], [ - - // Other - /(haiku)\s(\w+)/i, // Haiku - /(aix)\s((\d)(?=\.|\)|\s)[\w\.]*)*/i, // AIX - /(macintosh|mac(?=_powerpc)|plan\s9|minix|beos|os\/2|amigaos|morphos|risc\sos)/i, - // Plan9/Minix/BeOS/OS2/AmigaOS/MorphOS/RISCOS - /(unix)\s?([\w\.]+)*/i // UNIX - ], [NAME, VERSION] - ] - }; - - - ///////////////// - // Constructor - //////////////// - - - var UAParser = function (uastring) { - - var ua = uastring || ((window && window.navigator && window.navigator.userAgent) ? window.navigator.userAgent : EMPTY); - - this.getBrowser = function () { - return mapper.rgx.apply(this, regexes.browser); - }; - this.getEngine = function () { - return mapper.rgx.apply(this, regexes.engine); - }; - this.getOS = function () { - return mapper.rgx.apply(this, regexes.os); - }; - this.getResult = function() { - return { - ua : this.getUA(), - browser : this.getBrowser(), - engine : this.getEngine(), - os : this.getOS() - }; - }; - this.getUA = function () { - return ua; - }; - this.setUA = function (uastring) { - ua = uastring; - return this; - }; - this.setUA(ua); - }; - - return new UAParser().getResult(); - })(); - - - function version_compare(v1, v2, operator) { - // From: http://phpjs.org/functions - // + original by: Philippe Jausions (http://pear.php.net/user/jausions) - // + original by: Aidan Lister (http://aidanlister.com/) - // + reimplemented by: Kankrelune (http://www.webfaktory.info/) - // + improved by: Brett Zamir (http://brett-zamir.me) - // + improved by: Scott Baker - // + improved by: Theriault - // * example 1: version_compare('8.2.5rc', '8.2.5a'); - // * returns 1: 1 - // * example 2: version_compare('8.2.50', '8.2.52', '<'); - // * returns 2: true - // * example 3: version_compare('5.3.0-dev', '5.3.0'); - // * returns 3: -1 - // * example 4: version_compare('4.1.0.52','4.01.0.51'); - // * returns 4: 1 - - // Important: compare must be initialized at 0. - var i = 0, - x = 0, - compare = 0, - // vm maps textual PHP versions to negatives so they're less than 0. - // PHP currently defines these as CASE-SENSITIVE. It is important to - // leave these as negatives so that they can come before numerical versions - // and as if no letters were there to begin with. - // (1alpha is < 1 and < 1.1 but > 1dev1) - // If a non-numerical value can't be mapped to this table, it receives - // -7 as its value. - vm = { - 'dev': -6, - 'alpha': -5, - 'a': -5, - 'beta': -4, - 'b': -4, - 'RC': -3, - 'rc': -3, - '#': -2, - 'p': 1, - 'pl': 1 - }, - // This function will be called to prepare each version argument. - // It replaces every _, -, and + with a dot. - // It surrounds any nonsequence of numbers/dots with dots. - // It replaces sequences of dots with a single dot. - // version_compare('4..0', '4.0') == 0 - // Important: A string of 0 length needs to be converted into a value - // even less than an unexisting value in vm (-7), hence [-8]. - // It's also important to not strip spaces because of this. - // version_compare('', ' ') == 1 - prepVersion = function (v) { - v = ('' + v).replace(/[_\-+]/g, '.'); - v = v.replace(/([^.\d]+)/g, '.$1.').replace(/\.{2,}/g, '.'); - return (!v.length ? [-8] : v.split('.')); - }, - // This converts a version component to a number. - // Empty component becomes 0. - // Non-numerical component becomes a negative number. - // Numerical component becomes itself as an integer. - numVersion = function (v) { - return !v ? 0 : (isNaN(v) ? vm[v] || -7 : parseInt(v, 10)); - }; - - v1 = prepVersion(v1); - v2 = prepVersion(v2); - x = Math.max(v1.length, v2.length); - for (i = 0; i < x; i++) { - if (v1[i] == v2[i]) { - continue; - } - v1[i] = numVersion(v1[i]); - v2[i] = numVersion(v2[i]); - if (v1[i] < v2[i]) { - compare = -1; - break; - } else if (v1[i] > v2[i]) { - compare = 1; - break; - } - } - if (!operator) { - return compare; - } - - // Important: operator is CASE-SENSITIVE. - // "No operator" seems to be treated as "<." - // Any other values seem to make the function return null. - switch (operator) { - case '>': - case 'gt': - return (compare > 0); - case '>=': - case 'ge': - return (compare >= 0); - case '<=': - case 'le': - return (compare <= 0); - case '==': - case '=': - case 'eq': - return (compare === 0); - case '<>': - case '!=': - case 'ne': - return (compare !== 0); - case '': - case '<': - case 'lt': - return (compare < 0); - default: - return null; - } - } - - - var can = (function() { - var caps = { - define_property: (function() { - /* // currently too much extra code required, not exactly worth it - try { // as of IE8, getters/setters are supported only on DOM elements - var obj = {}; - if (Object.defineProperty) { - Object.defineProperty(obj, 'prop', { - enumerable: true, - configurable: true - }); - return true; - } - } catch(ex) {} - - if (Object.prototype.__defineGetter__ && Object.prototype.__defineSetter__) { - return true; - }*/ - return false; - }()), - - create_canvas: (function() { - // On the S60 and BB Storm, getContext exists, but always returns undefined - // so we actually have to call getContext() to verify - // github.com/Modernizr/Modernizr/issues/issue/97/ - var el = document.createElement('canvas'); - return !!(el.getContext && el.getContext('2d')); - }()), - - return_response_type: function(responseType) { - try { - if (Basic.inArray(responseType, ['', 'text', 'document']) !== -1) { - return true; - } else if (window.XMLHttpRequest) { - var xhr = new XMLHttpRequest(); - xhr.open('get', '/'); // otherwise Gecko throws an exception - if ('responseType' in xhr) { - xhr.responseType = responseType; - // as of 23.0.1271.64, Chrome switched from throwing exception to merely logging it to the console (why? o why?) - if (xhr.responseType !== responseType) { - return false; - } - return true; - } - } - } catch (ex) {} - return false; - }, - - // ideas for this heavily come from Modernizr (http://modernizr.com/) - use_data_uri: (function() { - var du = new Image(); - - du.onload = function() { - caps.use_data_uri = (du.width === 1 && du.height === 1); - }; - - setTimeout(function() { - du.src = ""; - }, 1); - return false; - }()), - - use_data_uri_over32kb: function() { // IE8 - return caps.use_data_uri && (Env.browser !== 'IE' || Env.version >= 9); - }, - - use_data_uri_of: function(bytes) { - return (caps.use_data_uri && bytes < 33000 || caps.use_data_uri_over32kb()); - }, - - use_fileinput: function() { - var el = document.createElement('input'); - el.setAttribute('type', 'file'); - return !el.disabled; - } - }; - - return function(cap) { - var args = [].slice.call(arguments); - args.shift(); // shift of cap - return Basic.typeOf(caps[cap]) === 'function' ? caps[cap].apply(this, args) : !!caps[cap]; - }; - }()); - - - var Env = { - can: can, - - browser: UAParser.browser.name, - version: parseFloat(UAParser.browser.major), - os: UAParser.os.name, // everybody intuitively types it in a lowercase for some reason - osVersion: UAParser.os.version, - - verComp: version_compare, - - swf_url: "../flash/Moxie.swf", - xap_url: "../silverlight/Moxie.xap", - global_event_dispatcher: "moxie.core.EventTarget.instance.dispatchEvent" - }; - - // for backward compatibility - // @deprecated Use `Env.os` instead - Env.OS = Env.os; - - return Env; -}); - -// Included from: src/javascript/core/utils/Dom.js - -/** - * Dom.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/core/utils/Dom', ['moxie/core/utils/Env'], function(Env) { - - /** - Get DOM Element by it's id. - - @method get - @for Utils - @param {String} id Identifier of the DOM Element - @return {DOMElement} - */ - var get = function(id) { - if (typeof id !== 'string') { - return id; - } - return document.getElementById(id); - }; - - /** - Checks if specified DOM element has specified class. - - @method hasClass - @static - @param {Object} obj DOM element like object to add handler to. - @param {String} name Class name - */ - var hasClass = function(obj, name) { - if (!obj.className) { - return false; - } - - var regExp = new RegExp("(^|\\s+)"+name+"(\\s+|$)"); - return regExp.test(obj.className); - }; - - /** - Adds specified className to specified DOM element. - - @method addClass - @static - @param {Object} obj DOM element like object to add handler to. - @param {String} name Class name - */ - var addClass = function(obj, name) { - if (!hasClass(obj, name)) { - obj.className = !obj.className ? name : obj.className.replace(/\s+$/, '') + ' ' + name; - } - }; - - /** - Removes specified className from specified DOM element. - - @method removeClass - @static - @param {Object} obj DOM element like object to add handler to. - @param {String} name Class name - */ - var removeClass = function(obj, name) { - if (obj.className) { - var regExp = new RegExp("(^|\\s+)"+name+"(\\s+|$)"); - obj.className = obj.className.replace(regExp, function($0, $1, $2) { - return $1 === ' ' && $2 === ' ' ? ' ' : ''; - }); - } - }; - - /** - Returns a given computed style of a DOM element. - - @method getStyle - @static - @param {Object} obj DOM element like object. - @param {String} name Style you want to get from the DOM element - */ - var getStyle = function(obj, name) { - if (obj.currentStyle) { - return obj.currentStyle[name]; - } else if (window.getComputedStyle) { - return window.getComputedStyle(obj, null)[name]; - } - }; - - - /** - Returns the absolute x, y position of an Element. The position will be returned in a object with x, y fields. - - @method getPos - @static - @param {Element} node HTML element or element id to get x, y position from. - @param {Element} root Optional root element to stop calculations at. - @return {object} Absolute position of the specified element object with x, y fields. - */ - var getPos = function(node, root) { - var x = 0, y = 0, parent, doc = document, nodeRect, rootRect; - - node = node; - root = root || doc.body; - - // Returns the x, y cordinate for an element on IE 6 and IE 7 - function getIEPos(node) { - var bodyElm, rect, x = 0, y = 0; - - if (node) { - rect = node.getBoundingClientRect(); - bodyElm = doc.compatMode === "CSS1Compat" ? doc.documentElement : doc.body; - x = rect.left + bodyElm.scrollLeft; - y = rect.top + bodyElm.scrollTop; - } - - return { - x : x, - y : y - }; - } - - // Use getBoundingClientRect on IE 6 and IE 7 but not on IE 8 in standards mode - if (node && node.getBoundingClientRect && Env.browser === 'IE' && (!doc.documentMode || doc.documentMode < 8)) { - nodeRect = getIEPos(node); - rootRect = getIEPos(root); - - return { - x : nodeRect.x - rootRect.x, - y : nodeRect.y - rootRect.y - }; - } - - parent = node; - while (parent && parent != root && parent.nodeType) { - x += parent.offsetLeft || 0; - y += parent.offsetTop || 0; - parent = parent.offsetParent; - } - - parent = node.parentNode; - while (parent && parent != root && parent.nodeType) { - x -= parent.scrollLeft || 0; - y -= parent.scrollTop || 0; - parent = parent.parentNode; - } - - return { - x : x, - y : y - }; - }; - - /** - Returns the size of the specified node in pixels. - - @method getSize - @static - @param {Node} node Node to get the size of. - @return {Object} Object with a w and h property. - */ - var getSize = function(node) { - return { - w : node.offsetWidth || node.clientWidth, - h : node.offsetHeight || node.clientHeight - }; - }; - - return { - get: get, - hasClass: hasClass, - addClass: addClass, - removeClass: removeClass, - getStyle: getStyle, - getPos: getPos, - getSize: getSize - }; -}); - -// Included from: src/javascript/core/Exceptions.js - -/** - * Exceptions.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/core/Exceptions', [ - 'moxie/core/utils/Basic' -], function(Basic) { - function _findKey(obj, value) { - var key; - for (key in obj) { - if (obj[key] === value) { - return key; - } - } - return null; - } - - return { - RuntimeError: (function() { - var namecodes = { - NOT_INIT_ERR: 1, - NOT_SUPPORTED_ERR: 9, - JS_ERR: 4 - }; - - function RuntimeError(code) { - this.code = code; - this.name = _findKey(namecodes, code); - this.message = this.name + ": RuntimeError " + this.code; - } - - Basic.extend(RuntimeError, namecodes); - RuntimeError.prototype = Error.prototype; - return RuntimeError; - }()), - - OperationNotAllowedException: (function() { - - function OperationNotAllowedException(code) { - this.code = code; - this.name = 'OperationNotAllowedException'; - } - - Basic.extend(OperationNotAllowedException, { - NOT_ALLOWED_ERR: 1 - }); - - OperationNotAllowedException.prototype = Error.prototype; - - return OperationNotAllowedException; - }()), - - ImageError: (function() { - var namecodes = { - WRONG_FORMAT: 1, - MAX_RESOLUTION_ERR: 2 - }; - - function ImageError(code) { - this.code = code; - this.name = _findKey(namecodes, code); - this.message = this.name + ": ImageError " + this.code; - } - - Basic.extend(ImageError, namecodes); - ImageError.prototype = Error.prototype; - - return ImageError; - }()), - - FileException: (function() { - var namecodes = { - NOT_FOUND_ERR: 1, - SECURITY_ERR: 2, - ABORT_ERR: 3, - NOT_READABLE_ERR: 4, - ENCODING_ERR: 5, - NO_MODIFICATION_ALLOWED_ERR: 6, - INVALID_STATE_ERR: 7, - SYNTAX_ERR: 8 - }; - - function FileException(code) { - this.code = code; - this.name = _findKey(namecodes, code); - this.message = this.name + ": FileException " + this.code; - } - - Basic.extend(FileException, namecodes); - FileException.prototype = Error.prototype; - return FileException; - }()), - - DOMException: (function() { - var namecodes = { - INDEX_SIZE_ERR: 1, - DOMSTRING_SIZE_ERR: 2, - HIERARCHY_REQUEST_ERR: 3, - WRONG_DOCUMENT_ERR: 4, - INVALID_CHARACTER_ERR: 5, - NO_DATA_ALLOWED_ERR: 6, - NO_MODIFICATION_ALLOWED_ERR: 7, - NOT_FOUND_ERR: 8, - NOT_SUPPORTED_ERR: 9, - INUSE_ATTRIBUTE_ERR: 10, - INVALID_STATE_ERR: 11, - SYNTAX_ERR: 12, - INVALID_MODIFICATION_ERR: 13, - NAMESPACE_ERR: 14, - INVALID_ACCESS_ERR: 15, - VALIDATION_ERR: 16, - TYPE_MISMATCH_ERR: 17, - SECURITY_ERR: 18, - NETWORK_ERR: 19, - ABORT_ERR: 20, - URL_MISMATCH_ERR: 21, - QUOTA_EXCEEDED_ERR: 22, - TIMEOUT_ERR: 23, - INVALID_NODE_TYPE_ERR: 24, - DATA_CLONE_ERR: 25 - }; - - function DOMException(code) { - this.code = code; - this.name = _findKey(namecodes, code); - this.message = this.name + ": DOMException " + this.code; - } - - Basic.extend(DOMException, namecodes); - DOMException.prototype = Error.prototype; - return DOMException; - }()), - - EventException: (function() { - function EventException(code) { - this.code = code; - this.name = 'EventException'; - } - - Basic.extend(EventException, { - UNSPECIFIED_EVENT_TYPE_ERR: 0 - }); - - EventException.prototype = Error.prototype; - - return EventException; - }()) - }; -}); - -// Included from: src/javascript/core/EventTarget.js - -/** - * EventTarget.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/core/EventTarget', [ - 'moxie/core/Exceptions', - 'moxie/core/utils/Basic' -], function(x, Basic) { - /** - Parent object for all event dispatching components and objects - - @class EventTarget - @constructor EventTarget - */ - function EventTarget() { - // hash of event listeners by object uid - var eventpool = {}; - - Basic.extend(this, { - - /** - Unique id of the event dispatcher, usually overriden by children - - @property uid - @type String - */ - uid: null, - - /** - Can be called from within a child in order to acquire uniqie id in automated manner - - @method init - */ - init: function() { - if (!this.uid) { - this.uid = Basic.guid('uid_'); - } - }, - - /** - Register a handler to a specific event dispatched by the object - - @method addEventListener - @param {String} type Type or basically a name of the event to subscribe to - @param {Function} fn Callback function that will be called when event happens - @param {Number} [priority=0] Priority of the event handler - handlers with higher priorities will be called first - @param {Object} [scope=this] A scope to invoke event handler in - */ - addEventListener: function(type, fn, priority, scope) { - var self = this, list; - - type = Basic.trim(type); - - if (/\s/.test(type)) { - // multiple event types were passed for one handler - Basic.each(type.split(/\s+/), function(type) { - self.addEventListener(type, fn, priority, scope); - }); - return; - } - - type = type.toLowerCase(); - priority = parseInt(priority, 10) || 0; - - list = eventpool[this.uid] && eventpool[this.uid][type] || []; - list.push({fn : fn, priority : priority, scope : scope || this}); - - if (!eventpool[this.uid]) { - eventpool[this.uid] = {}; - } - eventpool[this.uid][type] = list; - }, - - /** - Check if any handlers were registered to the specified event - - @method hasEventListener - @param {String} type Type or basically a name of the event to check - @return {Mixed} Returns a handler if it was found and false, if - not - */ - hasEventListener: function(type) { - return type ? !!(eventpool[this.uid] && eventpool[this.uid][type]) : !!eventpool[this.uid]; - }, - - /** - Unregister the handler from the event, or if former was not specified - unregister all handlers - - @method removeEventListener - @param {String} type Type or basically a name of the event - @param {Function} [fn] Handler to unregister - */ - removeEventListener: function(type, fn) { - type = type.toLowerCase(); - - var list = eventpool[this.uid] && eventpool[this.uid][type], i; - - if (list) { - if (fn) { - for (i = list.length - 1; i >= 0; i--) { - if (list[i].fn === fn) { - list.splice(i, 1); - break; - } - } - } else { - list = []; - } - - // delete event list if it has become empty - if (!list.length) { - delete eventpool[this.uid][type]; - - // and object specific entry in a hash if it has no more listeners attached - if (Basic.isEmptyObj(eventpool[this.uid])) { - delete eventpool[this.uid]; - } - } - } - }, - - /** - Remove all event handlers from the object - - @method removeAllEventListeners - */ - removeAllEventListeners: function() { - if (eventpool[this.uid]) { - delete eventpool[this.uid]; - } - }, - - /** - Dispatch the event - - @method dispatchEvent - @param {String/Object} Type of event or event object to dispatch - @param {Mixed} [...] Variable number of arguments to be passed to a handlers - @return {Boolean} true by default and false if any handler returned false - */ - dispatchEvent: function(type) { - var uid, list, args, tmpEvt, evt = {}, result = true, undef; - - if (Basic.typeOf(type) !== 'string') { - // we can't use original object directly (because of Silverlight) - tmpEvt = type; - - if (Basic.typeOf(tmpEvt.type) === 'string') { - type = tmpEvt.type; - - if (tmpEvt.total !== undef && tmpEvt.loaded !== undef) { // progress event - evt.total = tmpEvt.total; - evt.loaded = tmpEvt.loaded; - } - evt.async = tmpEvt.async || false; - } else { - throw new x.EventException(x.EventException.UNSPECIFIED_EVENT_TYPE_ERR); - } - } - - // check if event is meant to be dispatched on an object having specific uid - if (type.indexOf('::') !== -1) { - (function(arr) { - uid = arr[0]; - type = arr[1]; - }(type.split('::'))); - } else { - uid = this.uid; - } - - type = type.toLowerCase(); - - list = eventpool[uid] && eventpool[uid][type]; - - if (list) { - // sort event list by prority - list.sort(function(a, b) { return b.priority - a.priority; }); - - args = [].slice.call(arguments); - - // first argument will be pseudo-event object - args.shift(); - evt.type = type; - args.unshift(evt); - - // Dispatch event to all listeners - var queue = []; - Basic.each(list, function(handler) { - // explicitly set the target, otherwise events fired from shims do not get it - args[0].target = handler.scope; - // if event is marked as async, detach the handler - if (evt.async) { - queue.push(function(cb) { - setTimeout(function() { - cb(handler.fn.apply(handler.scope, args) === false); - }, 1); - }); - } else { - queue.push(function(cb) { - cb(handler.fn.apply(handler.scope, args) === false); // if handler returns false stop propagation - }); - } - }); - if (queue.length) { - Basic.inSeries(queue, function(err) { - result = !err; - }); - } - } - return result; - }, - - /** - Alias for addEventListener - - @method bind - @protected - */ - bind: function() { - this.addEventListener.apply(this, arguments); - }, - - /** - Alias for removeEventListener - - @method unbind - @protected - */ - unbind: function() { - this.removeEventListener.apply(this, arguments); - }, - - /** - Alias for removeAllEventListeners - - @method unbindAll - @protected - */ - unbindAll: function() { - this.removeAllEventListeners.apply(this, arguments); - }, - - /** - Alias for dispatchEvent - - @method trigger - @protected - */ - trigger: function() { - return this.dispatchEvent.apply(this, arguments); - }, - - - /** - Converts properties of on[event] type to corresponding event handlers, - is used to avoid extra hassle around the process of calling them back - - @method convertEventPropsToHandlers - @private - */ - convertEventPropsToHandlers: function(handlers) { - var h; - - if (Basic.typeOf(handlers) !== 'array') { - handlers = [handlers]; - } - - for (var i = 0; i < handlers.length; i++) { - h = 'on' + handlers[i]; - - if (Basic.typeOf(this[h]) === 'function') { - this.addEventListener(handlers[i], this[h]); - } else if (Basic.typeOf(this[h]) === 'undefined') { - this[h] = null; // object must have defined event properties, even if it doesn't make use of them - } - } - } - - }); - } - - EventTarget.instance = new EventTarget(); - - return EventTarget; -}); - -// Included from: src/javascript/core/utils/Encode.js - -/** - * Encode.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/core/utils/Encode', [], function() { - - /** - Encode string with UTF-8 - - @method utf8_encode - @for Utils - @static - @param {String} str String to encode - @return {String} UTF-8 encoded string - */ - var utf8_encode = function(str) { - return unescape(encodeURIComponent(str)); - }; - - /** - Decode UTF-8 encoded string - - @method utf8_decode - @static - @param {String} str String to decode - @return {String} Decoded string - */ - var utf8_decode = function(str_data) { - return decodeURIComponent(escape(str_data)); - }; - - /** - Decode Base64 encoded string (uses browser's default method if available), - from: https://raw.github.com/kvz/phpjs/master/functions/url/base64_decode.js - - @method atob - @static - @param {String} data String to decode - @return {String} Decoded string - */ - var atob = function(data, utf8) { - if (typeof(window.atob) === 'function') { - return utf8 ? utf8_decode(window.atob(data)) : window.atob(data); - } - - // http://kevin.vanzonneveld.net - // + original by: Tyler Akins (http://rumkin.com) - // + improved by: Thunder.m - // + input by: Aman Gupta - // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) - // + bugfixed by: Onno Marsman - // + bugfixed by: Pellentesque Malesuada - // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) - // + input by: Brett Zamir (http://brett-zamir.me) - // + bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) - // * example 1: base64_decode('S2V2aW4gdmFuIFpvbm5ldmVsZA=='); - // * returns 1: 'Kevin van Zonneveld' - // mozilla has this native - // - but breaks in 2.0.0.12! - //if (typeof this.window.atob == 'function') { - // return atob(data); - //} - var b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="; - var o1, o2, o3, h1, h2, h3, h4, bits, i = 0, - ac = 0, - dec = "", - tmp_arr = []; - - if (!data) { - return data; - } - - data += ''; - - do { // unpack four hexets into three octets using index points in b64 - h1 = b64.indexOf(data.charAt(i++)); - h2 = b64.indexOf(data.charAt(i++)); - h3 = b64.indexOf(data.charAt(i++)); - h4 = b64.indexOf(data.charAt(i++)); - - bits = h1 << 18 | h2 << 12 | h3 << 6 | h4; - - o1 = bits >> 16 & 0xff; - o2 = bits >> 8 & 0xff; - o3 = bits & 0xff; - - if (h3 == 64) { - tmp_arr[ac++] = String.fromCharCode(o1); - } else if (h4 == 64) { - tmp_arr[ac++] = String.fromCharCode(o1, o2); - } else { - tmp_arr[ac++] = String.fromCharCode(o1, o2, o3); - } - } while (i < data.length); - - dec = tmp_arr.join(''); - - return utf8 ? utf8_decode(dec) : dec; - }; - - /** - Base64 encode string (uses browser's default method if available), - from: https://raw.github.com/kvz/phpjs/master/functions/url/base64_encode.js - - @method btoa - @static - @param {String} data String to encode - @return {String} Base64 encoded string - */ - var btoa = function(data, utf8) { - if (utf8) { - utf8_encode(data); - } - - if (typeof(window.btoa) === 'function') { - return window.btoa(data); - } - - // http://kevin.vanzonneveld.net - // + original by: Tyler Akins (http://rumkin.com) - // + improved by: Bayron Guevara - // + improved by: Thunder.m - // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) - // + bugfixed by: Pellentesque Malesuada - // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) - // + improved by: Rafał Kukawski (http://kukawski.pl) - // * example 1: base64_encode('Kevin van Zonneveld'); - // * returns 1: 'S2V2aW4gdmFuIFpvbm5ldmVsZA==' - // mozilla has this native - // - but breaks in 2.0.0.12! - var b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="; - var o1, o2, o3, h1, h2, h3, h4, bits, i = 0, - ac = 0, - enc = "", - tmp_arr = []; - - if (!data) { - return data; - } - - do { // pack three octets into four hexets - o1 = data.charCodeAt(i++); - o2 = data.charCodeAt(i++); - o3 = data.charCodeAt(i++); - - bits = o1 << 16 | o2 << 8 | o3; - - h1 = bits >> 18 & 0x3f; - h2 = bits >> 12 & 0x3f; - h3 = bits >> 6 & 0x3f; - h4 = bits & 0x3f; - - // use hexets to index into b64, and append result to encoded string - tmp_arr[ac++] = b64.charAt(h1) + b64.charAt(h2) + b64.charAt(h3) + b64.charAt(h4); - } while (i < data.length); - - enc = tmp_arr.join(''); - - var r = data.length % 3; - - return (r ? enc.slice(0, r - 3) : enc) + '==='.slice(r || 3); - }; - - - return { - utf8_encode: utf8_encode, - utf8_decode: utf8_decode, - atob: atob, - btoa: btoa - }; -}); - -// Included from: src/javascript/runtime/Runtime.js - -/** - * Runtime.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/runtime/Runtime', [ - "moxie/core/utils/Basic", - "moxie/core/utils/Dom", - "moxie/core/EventTarget" -], function(Basic, Dom, EventTarget) { - var runtimeConstructors = {}, runtimes = {}; - - /** - Common set of methods and properties for every runtime instance - - @class Runtime - - @param {Object} options - @param {String} type Sanitized name of the runtime - @param {Object} [caps] Set of capabilities that differentiate specified runtime - @param {Object} [modeCaps] Set of capabilities that do require specific operational mode - @param {String} [preferredMode='browser'] Preferred operational mode to choose if no required capabilities were requested - */ - function Runtime(options, type, caps, modeCaps, preferredMode) { - /** - Dispatched when runtime is initialized and ready. - Results in RuntimeInit on a connected component. - - @event Init - */ - - /** - Dispatched when runtime fails to initialize. - Results in RuntimeError on a connected component. - - @event Error - */ - - var self = this - , _shim - , _uid = Basic.guid(type + '_') - , defaultMode = preferredMode || 'browser' - ; - - options = options || {}; - - // register runtime in private hash - runtimes[_uid] = this; - - /** - Default set of capabilities, which can be redifined later by specific runtime - - @private - @property caps - @type Object - */ - caps = Basic.extend({ - // Runtime can: - // provide access to raw binary data of the file - access_binary: false, - // provide access to raw binary data of the image (image extension is optional) - access_image_binary: false, - // display binary data as thumbs for example - display_media: false, - // make cross-domain requests - do_cors: false, - // accept files dragged and dropped from the desktop - drag_and_drop: false, - // filter files in selection dialog by their extensions - filter_by_extension: true, - // resize image (and manipulate it raw data of any file in general) - resize_image: false, - // periodically report how many bytes of total in the file were uploaded (loaded) - report_upload_progress: false, - // provide access to the headers of http response - return_response_headers: false, - // support response of specific type, which should be passed as an argument - // e.g. runtime.can('return_response_type', 'blob') - return_response_type: false, - // return http status code of the response - return_status_code: true, - // send custom http header with the request - send_custom_headers: false, - // pick up the files from a dialog - select_file: false, - // select whole folder in file browse dialog - select_folder: false, - // select multiple files at once in file browse dialog - select_multiple: true, - // send raw binary data, that is generated after image resizing or manipulation of other kind - send_binary_string: false, - // send cookies with http request and therefore retain session - send_browser_cookies: true, - // send data formatted as multipart/form-data - send_multipart: true, - // slice the file or blob to smaller parts - slice_blob: false, - // upload file without preloading it to memory, stream it out directly from disk - stream_upload: false, - // programmatically trigger file browse dialog - summon_file_dialog: false, - // upload file of specific size, size should be passed as argument - // e.g. runtime.can('upload_filesize', '500mb') - upload_filesize: true, - // initiate http request with specific http method, method should be passed as argument - // e.g. runtime.can('use_http_method', 'put') - use_http_method: true - }, caps); - - - // default to the mode that is compatible with preferred caps - if (options.preferred_caps) { - defaultMode = Runtime.getMode(modeCaps, options.preferred_caps, defaultMode); - } - - // small extension factory here (is meant to be extended with actual extensions constructors) - _shim = (function() { - var objpool = {}; - return { - exec: function(uid, comp, fn, args) { - if (_shim[comp]) { - if (!objpool[uid]) { - objpool[uid] = { - context: this, - instance: new _shim[comp]() - }; - } - if (objpool[uid].instance[fn]) { - return objpool[uid].instance[fn].apply(this, args); - } - } - }, - - removeInstance: function(uid) { - delete objpool[uid]; - }, - - removeAllInstances: function() { - var self = this; - Basic.each(objpool, function(obj, uid) { - if (Basic.typeOf(obj.instance.destroy) === 'function') { - obj.instance.destroy.call(obj.context); - } - self.removeInstance(uid); - }); - } - }; - }()); - - - // public methods - Basic.extend(this, { - /** - Specifies whether runtime instance was initialized or not - - @property initialized - @type {Boolean} - @default false - */ - initialized: false, // shims require this flag to stop initialization retries - - /** - Unique ID of the runtime - - @property uid - @type {String} - */ - uid: _uid, - - /** - Runtime type (e.g. flash, html5, etc) - - @property type - @type {String} - */ - type: type, - - /** - Runtime (not native one) may operate in browser or client mode. - - @property mode - @private - @type {String|Boolean} current mode or false, if none possible - */ - mode: Runtime.getMode(modeCaps, (options.required_caps), defaultMode), - - /** - id of the DOM container for the runtime (if available) - - @property shimid - @type {String} - */ - shimid: _uid + '_container', - - /** - Number of connected clients. If equal to zero, runtime can be destroyed - - @property clients - @type {Number} - */ - clients: 0, - - /** - Runtime initialization options - - @property options - @type {Object} - */ - options: options, - - /** - Checks if the runtime has specific capability - - @method can - @param {String} cap Name of capability to check - @param {Mixed} [value] If passed, capability should somehow correlate to the value - @param {Object} [refCaps] Set of capabilities to check the specified cap against (defaults to internal set) - @return {Boolean} true if runtime has such capability and false, if - not - */ - can: function(cap, value) { - var refCaps = arguments[2] || caps; - - // if cap var is a comma-separated list of caps, convert it to object (key/value) - if (Basic.typeOf(cap) === 'string' && Basic.typeOf(value) === 'undefined') { - cap = Runtime.parseCaps(cap); - } - - if (Basic.typeOf(cap) === 'object') { - for (var key in cap) { - if (!this.can(key, cap[key], refCaps)) { - return false; - } - } - return true; - } - - // check the individual cap - if (Basic.typeOf(refCaps[cap]) === 'function') { - return refCaps[cap].call(this, value); - } else { - return (value === refCaps[cap]); - } - }, - - /** - Returns container for the runtime as DOM element - - @method getShimContainer - @return {DOMElement} - */ - getShimContainer: function() { - var container, shimContainer = Dom.get(this.shimid); - - // if no container for shim, create one - if (!shimContainer) { - container = this.options.container ? Dom.get(this.options.container) : document.body; - - // create shim container and insert it at an absolute position into the outer container - shimContainer = document.createElement('div'); - shimContainer.id = this.shimid; - shimContainer.className = 'moxie-shim moxie-shim-' + this.type; - - Basic.extend(shimContainer.style, { - position: 'absolute', - top: '0px', - left: '0px', - width: '1px', - height: '1px', - overflow: 'hidden' - }); - - container.appendChild(shimContainer); - container = null; - } - - return shimContainer; - }, - - /** - Returns runtime as DOM element (if appropriate) - - @method getShim - @return {DOMElement} - */ - getShim: function() { - return _shim; - }, - - /** - Invokes a method within the runtime itself (might differ across the runtimes) - - @method shimExec - @param {Mixed} [] - @protected - @return {Mixed} Depends on the action and component - */ - shimExec: function(component, action) { - var args = [].slice.call(arguments, 2); - return self.getShim().exec.call(this, this.uid, component, action, args); - }, - - /** - Operaional interface that is used by components to invoke specific actions on the runtime - (is invoked in the scope of component) - - @method exec - @param {Mixed} []* - @protected - @return {Mixed} Depends on the action and component - */ - exec: function(component, action) { // this is called in the context of component, not runtime - var args = [].slice.call(arguments, 2); - - if (self[component] && self[component][action]) { - return self[component][action].apply(this, args); - } - return self.shimExec.apply(this, arguments); - }, - - /** - Destroys the runtime (removes all events and deletes DOM structures) - - @method destroy - */ - destroy: function() { - if (!self) { - return; // obviously already destroyed - } - - var shimContainer = Dom.get(this.shimid); - if (shimContainer) { - shimContainer.parentNode.removeChild(shimContainer); - } - - if (_shim) { - _shim.removeAllInstances(); - } - - this.unbindAll(); - delete runtimes[this.uid]; - this.uid = null; // mark this runtime as destroyed - _uid = self = _shim = shimContainer = null; - } - }); - - // once we got the mode, test against all caps - if (this.mode && options.required_caps && !this.can(options.required_caps)) { - this.mode = false; - } - } - - - /** - Default order to try different runtime types - - @property order - @type String - @static - */ - Runtime.order = 'html5,flash,silverlight,html4'; - - - /** - Retrieves runtime from private hash by it's uid - - @method getRuntime - @private - @static - @param {String} uid Unique identifier of the runtime - @return {Runtime|Boolean} Returns runtime, if it exists and false, if - not - */ - Runtime.getRuntime = function(uid) { - return runtimes[uid] ? runtimes[uid] : false; - }; - - - /** - Register constructor for the Runtime of new (or perhaps modified) type - - @method addConstructor - @static - @param {String} type Runtime type (e.g. flash, html5, etc) - @param {Function} construct Constructor for the Runtime type - */ - Runtime.addConstructor = function(type, constructor) { - constructor.prototype = EventTarget.instance; - runtimeConstructors[type] = constructor; - }; - - - /** - Get the constructor for the specified type. - - method getConstructor - @static - @param {String} type Runtime type (e.g. flash, html5, etc) - @return {Function} Constructor for the Runtime type - */ - Runtime.getConstructor = function(type) { - return runtimeConstructors[type] || null; - }; - - - /** - Get info about the runtime (uid, type, capabilities) - - @method getInfo - @static - @param {String} uid Unique identifier of the runtime - @return {Mixed} Info object or null if runtime doesn't exist - */ - Runtime.getInfo = function(uid) { - var runtime = Runtime.getRuntime(uid); - - if (runtime) { - return { - uid: runtime.uid, - type: runtime.type, - mode: runtime.mode, - can: function() { - return runtime.can.apply(runtime, arguments); - } - }; - } - return null; - }; - - - /** - Convert caps represented by a comma-separated string to the object representation. - - @method parseCaps - @static - @param {String} capStr Comma-separated list of capabilities - @return {Object} - */ - Runtime.parseCaps = function(capStr) { - var capObj = {}; - - if (Basic.typeOf(capStr) !== 'string') { - return capStr || {}; - } - - Basic.each(capStr.split(','), function(key) { - capObj[key] = true; // we assume it to be - true - }); - - return capObj; - }; - - /** - Test the specified runtime for specific capabilities. - - @method can - @static - @param {String} type Runtime type (e.g. flash, html5, etc) - @param {String|Object} caps Set of capabilities to check - @return {Boolean} Result of the test - */ - Runtime.can = function(type, caps) { - var runtime - , constructor = Runtime.getConstructor(type) - , mode - ; - if (constructor) { - runtime = new constructor({ - required_caps: caps - }); - mode = runtime.mode; - runtime.destroy(); - return !!mode; - } - return false; - }; - - - /** - Figure out a runtime that supports specified capabilities. - - @method thatCan - @static - @param {String|Object} caps Set of capabilities to check - @param {String} [runtimeOrder] Comma-separated list of runtimes to check against - @return {String} Usable runtime identifier or null - */ - Runtime.thatCan = function(caps, runtimeOrder) { - var types = (runtimeOrder || Runtime.order).split(/\s*,\s*/); - for (var i in types) { - if (Runtime.can(types[i], caps)) { - return types[i]; - } - } - return null; - }; - - - /** - Figure out an operational mode for the specified set of capabilities. - - @method getMode - @static - @param {Object} modeCaps Set of capabilities that depend on particular runtime mode - @param {Object} [requiredCaps] Supplied set of capabilities to find operational mode for - @param {String|Boolean} [defaultMode='browser'] Default mode to use - @return {String|Boolean} Compatible operational mode - */ - Runtime.getMode = function(modeCaps, requiredCaps, defaultMode) { - var mode = null; - - if (Basic.typeOf(defaultMode) === 'undefined') { // only if not specified - defaultMode = 'browser'; - } - - if (requiredCaps && !Basic.isEmptyObj(modeCaps)) { - // loop over required caps and check if they do require the same mode - Basic.each(requiredCaps, function(value, cap) { - if (modeCaps.hasOwnProperty(cap)) { - var capMode = modeCaps[cap](value); - - // make sure we always have an array - if (typeof(capMode) === 'string') { - capMode = [capMode]; - } - - if (!mode) { - mode = capMode; - } else if (!(mode = Basic.arrayIntersect(mode, capMode))) { - // if cap requires conflicting mode - runtime cannot fulfill required caps - return (mode = false); - } - } - }); - - if (mode) { - return Basic.inArray(defaultMode, mode) !== -1 ? defaultMode : mode[0]; - } else if (mode === false) { - return false; - } - } - return defaultMode; - }; - - - /** - Capability check that always returns true - - @private - @static - @return {True} - */ - Runtime.capTrue = function() { - return true; - }; - - /** - Capability check that always returns false - - @private - @static - @return {False} - */ - Runtime.capFalse = function() { - return false; - }; - - /** - Evaluate the expression to boolean value and create a function that always returns it. - - @private - @static - @param {Mixed} expr Expression to evaluate - @return {Function} Function returning the result of evaluation - */ - Runtime.capTest = function(expr) { - return function() { - return !!expr; - }; - }; - - return Runtime; -}); - -// Included from: src/javascript/runtime/RuntimeClient.js - -/** - * RuntimeClient.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/runtime/RuntimeClient', [ - 'moxie/core/Exceptions', - 'moxie/core/utils/Basic', - 'moxie/runtime/Runtime' -], function(x, Basic, Runtime) { - /** - Set of methods and properties, required by a component to acquire ability to connect to a runtime - - @class RuntimeClient - */ - return function RuntimeClient() { - var runtime; - - Basic.extend(this, { - /** - Connects to the runtime specified by the options. Will either connect to existing runtime or create a new one. - Increments number of clients connected to the specified runtime. - - @method connectRuntime - @param {Mixed} options Can be a runtme uid or a set of key-value pairs defining requirements and pre-requisites - */ - connectRuntime: function(options) { - var comp = this, ruid; - - function initialize(items) { - var type, constructor; - - // if we ran out of runtimes - if (!items.length) { - comp.trigger('RuntimeError', new x.RuntimeError(x.RuntimeError.NOT_INIT_ERR)); - runtime = null; - return; - } - - type = items.shift(); - constructor = Runtime.getConstructor(type); - if (!constructor) { - initialize(items); - return; - } - - // try initializing the runtime - runtime = new constructor(options); - - runtime.bind('Init', function() { - // mark runtime as initialized - runtime.initialized = true; - - // jailbreak ... - setTimeout(function() { - runtime.clients++; - // this will be triggered on component - comp.trigger('RuntimeInit', runtime); - }, 1); - }); - - runtime.bind('Error', function() { - runtime.destroy(); // runtime cannot destroy itself from inside at a right moment, thus we do it here - initialize(items); - }); - - /*runtime.bind('Exception', function() { });*/ - - // check if runtime managed to pick-up operational mode - if (!runtime.mode) { - runtime.trigger('Error'); - return; - } - - runtime.init(); - } - - // check if a particular runtime was requested - if (Basic.typeOf(options) === 'string') { - ruid = options; - } else if (Basic.typeOf(options.ruid) === 'string') { - ruid = options.ruid; - } - - if (ruid) { - runtime = Runtime.getRuntime(ruid); - if (runtime) { - runtime.clients++; - return runtime; - } else { - // there should be a runtime and there's none - weird case - throw new x.RuntimeError(x.RuntimeError.NOT_INIT_ERR); - } - } - - // initialize a fresh one, that fits runtime list and required features best - initialize((options.runtime_order || Runtime.order).split(/\s*,\s*/)); - }, - - /** - Returns the runtime to which the client is currently connected. - - @method getRuntime - @return {Runtime} Runtime or null if client is not connected - */ - getRuntime: function() { - if (runtime && runtime.uid) { - return runtime; - } - runtime = null; // make sure we do not leave zombies rambling around - return null; - }, - - /** - Disconnects from the runtime. Decrements number of clients connected to the specified runtime. - - @method disconnectRuntime - */ - disconnectRuntime: function() { - if (runtime && --runtime.clients <= 0) { - runtime.destroy(); - runtime = null; - } - } - - }); - }; - - -}); - -// Included from: src/javascript/file/Blob.js - -/** - * Blob.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/file/Blob', [ - 'moxie/core/utils/Basic', - 'moxie/core/utils/Encode', - 'moxie/runtime/RuntimeClient' -], function(Basic, Encode, RuntimeClient) { - - var blobpool = {}; - - /** - @class Blob - @constructor - @param {String} ruid Unique id of the runtime, to which this blob belongs to - @param {Object} blob Object "Native" blob object, as it is represented in the runtime - */ - function Blob(ruid, blob) { - - function _sliceDetached(start, end, type) { - var blob, data = blobpool[this.uid]; - - if (Basic.typeOf(data) !== 'string' || !data.length) { - return null; // or throw exception - } - - blob = new Blob(null, { - type: type, - size: end - start - }); - blob.detach(data.substr(start, blob.size)); - - return blob; - } - - RuntimeClient.call(this); - - if (ruid) { - this.connectRuntime(ruid); - } - - if (!blob) { - blob = {}; - } else if (Basic.typeOf(blob) === 'string') { // dataUrl or binary string - blob = { data: blob }; - } - - Basic.extend(this, { - - /** - Unique id of the component - - @property uid - @type {String} - */ - uid: blob.uid || Basic.guid('uid_'), - - /** - Unique id of the connected runtime, if falsy, then runtime will have to be initialized - before this Blob can be used, modified or sent - - @property ruid - @type {String} - */ - ruid: ruid, - - /** - Size of blob - - @property size - @type {Number} - @default 0 - */ - size: blob.size || 0, - - /** - Mime type of blob - - @property type - @type {String} - @default '' - */ - type: blob.type || '', - - /** - @method slice - @param {Number} [start=0] - */ - slice: function(start, end, type) { - if (this.isDetached()) { - return _sliceDetached.apply(this, arguments); - } - return this.getRuntime().exec.call(this, 'Blob', 'slice', this.getSource(), start, end, type); - }, - - /** - Returns "native" blob object (as it is represented in connected runtime) or null if not found - - @method getSource - @return {Blob} Returns "native" blob object or null if not found - */ - getSource: function() { - if (!blobpool[this.uid]) { - return null; - } - return blobpool[this.uid]; - }, - - /** - Detaches blob from any runtime that it depends on and initialize with standalone value - - @method detach - @protected - @param {DOMString} [data=''] Standalone value - */ - detach: function(data) { - if (this.ruid) { - this.getRuntime().exec.call(this, 'Blob', 'destroy', blobpool[this.uid]); - this.disconnectRuntime(); - this.ruid = null; - } - - data = data || ''; - - // if dataUrl, convert to binary string - var matches = data.match(/^data:([^;]*);base64,/); - if (matches) { - this.type = matches[1]; - data = Encode.atob(data.substring(data.indexOf('base64,') + 7)); - } - - this.size = data.length; - - blobpool[this.uid] = data; - }, - - /** - Checks if blob is standalone (detached of any runtime) - - @method isDetached - @protected - @return {Boolean} - */ - isDetached: function() { - return !this.ruid && Basic.typeOf(blobpool[this.uid]) === 'string'; - }, - - /** - Destroy Blob and free any resources it was using - - @method destroy - */ - destroy: function() { - this.detach(); - delete blobpool[this.uid]; - } - }); - - - if (blob.data) { - this.detach(blob.data); // auto-detach if payload has been passed - } else { - blobpool[this.uid] = blob; - } - } - - return Blob; -}); - -// Included from: src/javascript/file/File.js - -/** - * File.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/file/File', [ - 'moxie/core/utils/Basic', - 'moxie/core/utils/Mime', - 'moxie/file/Blob' -], function(Basic, Mime, Blob) { - /** - @class File - @extends Blob - @constructor - @param {String} ruid Unique id of the runtime, to which this blob belongs to - @param {Object} file Object "Native" file object, as it is represented in the runtime - */ - function File(ruid, file) { - var name, type; - - if (!file) { // avoid extra errors in case we overlooked something - file = {}; - } - - // figure out the type - if (file.type && file.type !== '') { - type = file.type; - } else { - type = Mime.getFileMime(file.name); - } - - // sanitize file name or generate new one - if (file.name) { - name = file.name.replace(/\\/g, '/'); - name = name.substr(name.lastIndexOf('/') + 1); - } else { - var prefix = type.split('/')[0]; - name = Basic.guid((prefix !== '' ? prefix : 'file') + '_'); - - if (Mime.extensions[type]) { - name += '.' + Mime.extensions[type][0]; // append proper extension if possible - } - } - - Blob.apply(this, arguments); - - Basic.extend(this, { - /** - File mime type - - @property type - @type {String} - @default '' - */ - type: type || '', - - /** - File name - - @property name - @type {String} - @default UID - */ - name: name || Basic.guid('file_'), - - /** - Date of last modification - - @property lastModifiedDate - @type {String} - @default now - */ - lastModifiedDate: file.lastModifiedDate || (new Date()).toLocaleString() // Thu Aug 23 2012 19:40:00 GMT+0400 (GET) - }); - } - - File.prototype = Blob.prototype; - - return File; -}); - -// Included from: src/javascript/file/FileInput.js - -/** - * FileInput.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/file/FileInput', [ - 'moxie/core/utils/Basic', - 'moxie/core/utils/Mime', - 'moxie/core/utils/Dom', - 'moxie/core/Exceptions', - 'moxie/core/EventTarget', - 'moxie/core/I18n', - 'moxie/file/File', - 'moxie/runtime/Runtime', - 'moxie/runtime/RuntimeClient' -], function(Basic, Mime, Dom, x, EventTarget, I18n, File, Runtime, RuntimeClient) { - /** - Provides a convenient way to create cross-browser file-picker. Generates file selection dialog on click, - converts selected files to _File_ objects, to be used in conjunction with _Image_, preloaded in memory - with _FileReader_ or uploaded to a server through _XMLHttpRequest_. - - @class FileInput - @constructor - @extends EventTarget - @uses RuntimeClient - @param {Object|String|DOMElement} options If options is string or node, argument is considered as _browse\_button_. - @param {String|DOMElement} options.browse_button DOM Element to turn into file picker. - @param {Array} [options.accept] Array of mime types to accept. By default accepts all. - @param {String} [options.file='file'] Name of the file field (not the filename). - @param {Boolean} [options.multiple=false] Enable selection of multiple files. - @param {Boolean} [options.directory=false] Turn file input into the folder input (cannot be both at the same time). - @param {String|DOMElement} [options.container] DOM Element to use as a container for file-picker. Defaults to parentNode - for _browse\_button_. - @param {Object|String} [options.required_caps] Set of required capabilities, that chosen runtime must support. - - @example -
      - Browse... -
      - - - */ - var dispatches = [ - /** - Dispatched when runtime is connected and file-picker is ready to be used. - - @event ready - @param {Object} event - */ - 'ready', - - /** - Dispatched right after [ready](#event_ready) event, and whenever [refresh()](#method_refresh) is invoked. - Check [corresponding documentation entry](#method_refresh) for more info. - - @event refresh - @param {Object} event - */ - - /** - Dispatched when selection of files in the dialog is complete. - - @event change - @param {Object} event - */ - 'change', - - 'cancel', // TODO: might be useful - - /** - Dispatched when mouse cursor enters file-picker area. Can be used to style element - accordingly. - - @event mouseenter - @param {Object} event - */ - 'mouseenter', - - /** - Dispatched when mouse cursor leaves file-picker area. Can be used to style element - accordingly. - - @event mouseleave - @param {Object} event - */ - 'mouseleave', - - /** - Dispatched when functional mouse button is pressed on top of file-picker area. - - @event mousedown - @param {Object} event - */ - 'mousedown', - - /** - Dispatched when functional mouse button is released on top of file-picker area. - - @event mouseup - @param {Object} event - */ - 'mouseup' - ]; - - function FileInput(options) { - var self = this, - container, browseButton, defaults; - - // if flat argument passed it should be browse_button id - if (Basic.inArray(Basic.typeOf(options), ['string', 'node']) !== -1) { - options = { browse_button : options }; - } - - // this will help us to find proper default container - browseButton = Dom.get(options.browse_button); - if (!browseButton) { - // browse button is required - throw new x.DOMException(x.DOMException.NOT_FOUND_ERR); - } - - // figure out the options - defaults = { - accept: [{ - title: I18n.translate('All Files'), - extensions: '*' - }], - name: 'file', - multiple: false, - required_caps: false, - container: browseButton.parentNode || document.body - }; - - options = Basic.extend({}, defaults, options); - - // convert to object representation - if (typeof(options.required_caps) === 'string') { - options.required_caps = Runtime.parseCaps(options.required_caps); - } - - // normalize accept option (could be list of mime types or array of title/extensions pairs) - if (typeof(options.accept) === 'string') { - options.accept = Mime.mimes2extList(options.accept); - } - - container = Dom.get(options.container); - // make sure we have container - if (!container) { - container = document.body; - } - - // make container relative, if it's not - if (Dom.getStyle(container, 'position') === 'static') { - container.style.position = 'relative'; - } - - container = browseButton = null; // IE - - RuntimeClient.call(self); - - Basic.extend(self, { - /** - Unique id of the component - - @property uid - @protected - @readOnly - @type {String} - @default UID - */ - uid: Basic.guid('uid_'), - - /** - Unique id of the connected runtime, if any. - - @property ruid - @protected - @type {String} - */ - ruid: null, - - /** - Unique id of the runtime container. Useful to get hold of it for various manipulations. - - @property shimid - @protected - @type {String} - */ - shimid: null, - - /** - Array of selected mOxie.File objects - - @property files - @type {Array} - @default null - */ - files: null, - - /** - Initializes the file-picker, connects it to runtime and dispatches event ready when done. - - @method init - */ - init: function() { - self.convertEventPropsToHandlers(dispatches); - - self.bind('RuntimeInit', function(e, runtime) { - self.ruid = runtime.uid; - self.shimid = runtime.shimid; - - self.bind("Ready", function() { - self.trigger("Refresh"); - }, 999); - - self.bind("Change", function() { - var files = runtime.exec.call(self, 'FileInput', 'getFiles'); - - self.files = []; - - Basic.each(files, function(file) { - // ignore empty files (IE10 for example hangs if you try to send them via XHR) - if (file.size === 0) { - return true; - } - self.files.push(new File(self.ruid, file)); - }); - }, 999); - - // re-position and resize shim container - self.bind('Refresh', function() { - var pos, size, browseButton, shimContainer; - - browseButton = Dom.get(options.browse_button); - shimContainer = Dom.get(runtime.shimid); // do not use runtime.getShimContainer(), since it will create container if it doesn't exist - - if (browseButton) { - pos = Dom.getPos(browseButton, Dom.get(options.container)); - size = Dom.getSize(browseButton); - - if (shimContainer) { - Basic.extend(shimContainer.style, { - top : pos.y + 'px', - left : pos.x + 'px', - width : size.w + 'px', - height : size.h + 'px' - }); - } - } - shimContainer = browseButton = null; - }); - - runtime.exec.call(self, 'FileInput', 'init', options); - }); - - // runtime needs: options.required_features, options.runtime_order and options.container - self.connectRuntime(Basic.extend({}, options, { - required_caps: { - select_file: true - } - })); - }, - - /** - Disables file-picker element, so that it doesn't react to mouse clicks. - - @method disable - @param {Boolean} [state=true] Disable component if - true, enable if - false - */ - disable: function(state) { - var runtime = this.getRuntime(); - if (runtime) { - runtime.exec.call(this, 'FileInput', 'disable', Basic.typeOf(state) === 'undefined' ? true : state); - } - }, - - - /** - Reposition and resize dialog trigger to match the position and size of browse_button element. - - @method refresh - */ - refresh: function() { - self.trigger("Refresh"); - }, - - - /** - Destroy component. - - @method destroy - */ - destroy: function() { - var runtime = this.getRuntime(); - if (runtime) { - runtime.exec.call(this, 'FileInput', 'destroy'); - this.disconnectRuntime(); - } - - if (Basic.typeOf(this.files) === 'array') { - // no sense in leaving associated files behind - Basic.each(this.files, function(file) { - file.destroy(); - }); - } - this.files = null; - } - }); - } - - FileInput.prototype = EventTarget.instance; - - return FileInput; -}); - -// Included from: src/javascript/file/FileDrop.js - -/** - * FileDrop.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/file/FileDrop', [ - 'moxie/core/I18n', - 'moxie/core/utils/Dom', - 'moxie/core/Exceptions', - 'moxie/core/utils/Basic', - 'moxie/file/File', - 'moxie/runtime/RuntimeClient', - 'moxie/core/EventTarget', - 'moxie/core/utils/Mime' -], function(I18n, Dom, x, Basic, File, RuntimeClient, EventTarget, Mime) { - /** - Turn arbitrary DOM element to a drop zone accepting files. Converts selected files to _File_ objects, to be used - in conjunction with _Image_, preloaded in memory with _FileReader_ or uploaded to a server through - _XMLHttpRequest_. - - @example -
      - Drop files here -
      -
      -
      - - - - @class FileDrop - @constructor - @extends EventTarget - @uses RuntimeClient - @param {Object|String} options If options has typeof string, argument is considered as options.drop_zone - @param {String|DOMElement} options.drop_zone DOM Element to turn into a drop zone - @param {Array} [options.accept] Array of mime types to accept. By default accepts all - @param {Object|String} [options.required_caps] Set of required capabilities, that chosen runtime must support - */ - var dispatches = [ - /** - Dispatched when runtime is connected and drop zone is ready to accept files. - - @event ready - @param {Object} event - */ - 'ready', - - /** - Dispatched when dragging cursor enters the drop zone. - - @event dragenter - @param {Object} event - */ - 'dragenter', - - /** - Dispatched when dragging cursor leaves the drop zone. - - @event dragleave - @param {Object} event - */ - 'dragleave', - - /** - Dispatched when file is dropped onto the drop zone. - - @event drop - @param {Object} event - */ - 'drop', - - /** - Dispatched if error occurs. - - @event error - @param {Object} event - */ - 'error' - ]; - - function FileDrop(options) { - var self = this, defaults; - - // if flat argument passed it should be drop_zone id - if (typeof(options) === 'string') { - options = { drop_zone : options }; - } - - // figure out the options - defaults = { - accept: [{ - title: I18n.translate('All Files'), - extensions: '*' - }], - required_caps: { - drag_and_drop: true - } - }; - - options = typeof(options) === 'object' ? Basic.extend({}, defaults, options) : defaults; - - // this will help us to find proper default container - options.container = Dom.get(options.drop_zone) || document.body; - - // make container relative, if it is not - if (Dom.getStyle(options.container, 'position') === 'static') { - options.container.style.position = 'relative'; - } - - // normalize accept option (could be list of mime types or array of title/extensions pairs) - if (typeof(options.accept) === 'string') { - options.accept = Mime.mimes2extList(options.accept); - } - - RuntimeClient.call(self); - - Basic.extend(self, { - uid: Basic.guid('uid_'), - - ruid: null, - - files: null, - - init: function() { - - self.convertEventPropsToHandlers(dispatches); - - self.bind('RuntimeInit', function(e, runtime) { - self.ruid = runtime.uid; - - self.bind("Drop", function() { - var files = runtime.exec.call(self, 'FileDrop', 'getFiles'); - - self.files = []; - - Basic.each(files, function(file) { - self.files.push(new File(self.ruid, file)); - }); - }, 999); - - runtime.exec.call(self, 'FileDrop', 'init', options); - - self.dispatchEvent('ready'); - }); - - // runtime needs: options.required_features, options.runtime_order and options.container - self.connectRuntime(options); // throws RuntimeError - }, - - destroy: function() { - var runtime = this.getRuntime(); - if (runtime) { - runtime.exec.call(this, 'FileDrop', 'destroy'); - this.disconnectRuntime(); - } - this.files = null; - } - }); - } - - FileDrop.prototype = EventTarget.instance; - - return FileDrop; -}); - -// Included from: src/javascript/runtime/RuntimeTarget.js - -/** - * RuntimeTarget.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/runtime/RuntimeTarget', [ - 'moxie/core/utils/Basic', - 'moxie/runtime/RuntimeClient', - "moxie/core/EventTarget" -], function(Basic, RuntimeClient, EventTarget) { - /** - Instance of this class can be used as a target for the events dispatched by shims, - when allowing them onto components is for either reason inappropriate - - @class RuntimeTarget - @constructor - @protected - @extends EventTarget - */ - function RuntimeTarget() { - this.uid = Basic.guid('uid_'); - - RuntimeClient.call(this); - - this.destroy = function() { - this.disconnectRuntime(); - this.unbindAll(); - }; - } - - RuntimeTarget.prototype = EventTarget.instance; - - return RuntimeTarget; -}); - -// Included from: src/javascript/file/FileReader.js - -/** - * FileReader.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/file/FileReader', [ - 'moxie/core/utils/Basic', - 'moxie/core/utils/Encode', - 'moxie/core/Exceptions', - 'moxie/core/EventTarget', - 'moxie/file/Blob', - 'moxie/file/File', - 'moxie/runtime/RuntimeTarget' -], function(Basic, Encode, x, EventTarget, Blob, File, RuntimeTarget) { - /** - Utility for preloading o.Blob/o.File objects in memory. By design closely follows [W3C FileReader](http://www.w3.org/TR/FileAPI/#dfn-filereader) - interface. Where possible uses native FileReader, where - not falls back to shims. - - @class FileReader - @constructor FileReader - @extends EventTarget - @uses RuntimeClient - */ - var dispatches = [ - - /** - Dispatched when the read starts. - - @event loadstart - @param {Object} event - */ - 'loadstart', - - /** - Dispatched while reading (and decoding) blob, and reporting partial Blob data (progess.loaded/progress.total). - - @event progress - @param {Object} event - */ - 'progress', - - /** - Dispatched when the read has successfully completed. - - @event load - @param {Object} event - */ - 'load', - - /** - Dispatched when the read has been aborted. For instance, by invoking the abort() method. - - @event abort - @param {Object} event - */ - 'abort', - - /** - Dispatched when the read has failed. - - @event error - @param {Object} event - */ - 'error', - - /** - Dispatched when the request has completed (either in success or failure). - - @event loadend - @param {Object} event - */ - 'loadend' - ]; - - function FileReader() { - var self = this, _fr; - - Basic.extend(this, { - /** - UID of the component instance. - - @property uid - @type {String} - */ - uid: Basic.guid('uid_'), - - /** - Contains current state of FileReader object. Can take values of FileReader.EMPTY, FileReader.LOADING - and FileReader.DONE. - - @property readyState - @type {Number} - @default FileReader.EMPTY - */ - readyState: FileReader.EMPTY, - - /** - Result of the successful read operation. - - @property result - @type {String} - */ - result: null, - - /** - Stores the error of failed asynchronous read operation. - - @property error - @type {DOMError} - */ - error: null, - - /** - Initiates reading of File/Blob object contents to binary string. - - @method readAsBinaryString - @param {Blob|File} blob Object to preload - */ - readAsBinaryString: function(blob) { - _read.call(this, 'readAsBinaryString', blob); - }, - - /** - Initiates reading of File/Blob object contents to dataURL string. - - @method readAsDataURL - @param {Blob|File} blob Object to preload - */ - readAsDataURL: function(blob) { - _read.call(this, 'readAsDataURL', blob); - }, - - /** - Initiates reading of File/Blob object contents to string. - - @method readAsText - @param {Blob|File} blob Object to preload - */ - readAsText: function(blob) { - _read.call(this, 'readAsText', blob); - }, - - /** - Aborts preloading process. - - @method abort - */ - abort: function() { - this.result = null; - - if (Basic.inArray(this.readyState, [FileReader.EMPTY, FileReader.DONE]) !== -1) { - return; - } else if (this.readyState === FileReader.LOADING) { - this.readyState = FileReader.DONE; - } - - if (_fr) { - _fr.getRuntime().exec.call(this, 'FileReader', 'abort'); - } - - this.trigger('abort'); - this.trigger('loadend'); - }, - - /** - Destroy component and release resources. - - @method destroy - */ - destroy: function() { - this.abort(); - - if (_fr) { - _fr.getRuntime().exec.call(this, 'FileReader', 'destroy'); - _fr.disconnectRuntime(); - } - - self = _fr = null; - } - }); - - - function _read(op, blob) { - _fr = new RuntimeTarget(); - - function error(err) { - self.readyState = FileReader.DONE; - self.error = err; - self.trigger('error'); - loadEnd(); - } - - function loadEnd() { - _fr.destroy(); - _fr = null; - self.trigger('loadend'); - } - - function exec(runtime) { - _fr.bind('Error', function(e, err) { - error(err); - }); - - _fr.bind('Progress', function(e) { - self.result = runtime.exec.call(_fr, 'FileReader', 'getResult'); - self.trigger(e); - }); - - _fr.bind('Load', function(e) { - self.readyState = FileReader.DONE; - self.result = runtime.exec.call(_fr, 'FileReader', 'getResult'); - self.trigger(e); - loadEnd(); - }); - - runtime.exec.call(_fr, 'FileReader', 'read', op, blob); - } - - this.convertEventPropsToHandlers(dispatches); - - if (this.readyState === FileReader.LOADING) { - return error(new x.DOMException(x.DOMException.INVALID_STATE_ERR)); - } - - this.readyState = FileReader.LOADING; - this.trigger('loadstart'); - - // if source is o.Blob/o.File - if (blob instanceof Blob) { - if (blob.isDetached()) { - var src = blob.getSource(); - switch (op) { - case 'readAsText': - case 'readAsBinaryString': - this.result = src; - break; - case 'readAsDataURL': - this.result = 'data:' + blob.type + ';base64,' + Encode.btoa(src); - break; - } - this.readyState = FileReader.DONE; - this.trigger('load'); - loadEnd(); - } else { - exec(_fr.connectRuntime(blob.ruid)); - } - } else { - error(new x.DOMException(x.DOMException.NOT_FOUND_ERR)); - } - } - } - - /** - Initial FileReader state - - @property EMPTY - @type {Number} - @final - @static - @default 0 - */ - FileReader.EMPTY = 0; - - /** - FileReader switches to this state when it is preloading the source - - @property LOADING - @type {Number} - @final - @static - @default 1 - */ - FileReader.LOADING = 1; - - /** - Preloading is complete, this is a final state - - @property DONE - @type {Number} - @final - @static - @default 2 - */ - FileReader.DONE = 2; - - FileReader.prototype = EventTarget.instance; - - return FileReader; -}); - -// Included from: src/javascript/core/utils/Url.js - -/** - * Url.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/core/utils/Url', [], function() { - /** - Parse url into separate components and fill in absent parts with parts from current url, - based on https://raw.github.com/kvz/phpjs/master/functions/url/parse_url.js - - @method parseUrl - @for Utils - @static - @param {String} url Url to parse (defaults to empty string if undefined) - @return {Object} Hash containing extracted uri components - */ - var parseUrl = function(url, currentUrl) { - var key = ['source', 'scheme', 'authority', 'userInfo', 'user', 'pass', 'host', 'port', 'relative', 'path', 'directory', 'file', 'query', 'fragment'] - , i = key.length - , ports = { - http: 80, - https: 443 - } - , uri = {} - , regex = /^(?:([^:\/?#]+):)?(?:\/\/()(?:(?:()(?:([^:@]*):?([^:@]*))?@)?([^:\/?#]*)(?::(\d*))?))?()(?:(()(?:(?:[^?#\/]*\/)*)()(?:[^?#]*))(?:\\?([^#]*))?(?:#(.*))?)/ - , m = regex.exec(url || '') - ; - - while (i--) { - if (m[i]) { - uri[key[i]] = m[i]; - } - } - - // when url is relative, we set the origin and the path ourselves - if (!uri.scheme) { - // come up with defaults - if (!currentUrl || typeof(currentUrl) === 'string') { - currentUrl = parseUrl(currentUrl || document.location.href); - } - - uri.scheme = currentUrl.scheme; - uri.host = currentUrl.host; - uri.port = currentUrl.port; - - var path = ''; - // for urls without trailing slash we need to figure out the path - if (/^[^\/]/.test(uri.path)) { - path = currentUrl.path; - // if path ends with a filename, strip it - if (!/(\/|\/[^\.]+)$/.test(path)) { - path = path.replace(/\/[^\/]+$/, '/'); - } else { - path += '/'; - } - } - uri.path = path + (uri.path || ''); // site may reside at domain.com or domain.com/subdir - } - - if (!uri.port) { - uri.port = ports[uri.scheme] || 80; - } - - uri.port = parseInt(uri.port, 10); - - if (!uri.path) { - uri.path = "/"; - } - - delete uri.source; - - return uri; - }; - - /** - Resolve url - among other things will turn relative url to absolute - - @method resolveUrl - @static - @param {String} url Either absolute or relative - @return {String} Resolved, absolute url - */ - var resolveUrl = function(url) { - var ports = { // we ignore default ports - http: 80, - https: 443 - } - , urlp = parseUrl(url) - ; - - return urlp.scheme + '://' + urlp.host + (urlp.port !== ports[urlp.scheme] ? ':' + urlp.port : '') + urlp.path + (urlp.query ? urlp.query : ''); - }; - - /** - Check if specified url has the same origin as the current document - - @method hasSameOrigin - @param {String|Object} url - @return {Boolean} - */ - var hasSameOrigin = function(url) { - function origin(url) { - return [url.scheme, url.host, url.port].join('/'); - } - - if (typeof url === 'string') { - url = parseUrl(url); - } - - return origin(parseUrl()) === origin(url); - }; - - return { - parseUrl: parseUrl, - resolveUrl: resolveUrl, - hasSameOrigin: hasSameOrigin - }; -}); - -// Included from: src/javascript/file/FileReaderSync.js - -/** - * FileReaderSync.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/file/FileReaderSync', [ - 'moxie/core/utils/Basic', - 'moxie/runtime/RuntimeClient', - 'moxie/core/utils/Encode' -], function(Basic, RuntimeClient, Encode) { - /** - Synchronous FileReader implementation. Something like this is available in WebWorkers environment, here - it can be used to read only preloaded blobs/files and only below certain size (not yet sure what that'd be, - but probably < 1mb). Not meant to be used directly by user. - - @class FileReaderSync - @private - @constructor - */ - return function() { - RuntimeClient.call(this); - - Basic.extend(this, { - uid: Basic.guid('uid_'), - - readAsBinaryString: function(blob) { - return _read.call(this, 'readAsBinaryString', blob); - }, - - readAsDataURL: function(blob) { - return _read.call(this, 'readAsDataURL', blob); - }, - - /*readAsArrayBuffer: function(blob) { - return _read.call(this, 'readAsArrayBuffer', blob); - },*/ - - readAsText: function(blob) { - return _read.call(this, 'readAsText', blob); - } - }); - - function _read(op, blob) { - if (blob.isDetached()) { - var src = blob.getSource(); - switch (op) { - case 'readAsBinaryString': - return src; - case 'readAsDataURL': - return 'data:' + blob.type + ';base64,' + Encode.btoa(src); - case 'readAsText': - var txt = ''; - for (var i = 0, length = src.length; i < length; i++) { - txt += String.fromCharCode(src[i]); - } - return txt; - } - } else { - var result = this.connectRuntime(blob.ruid).exec.call(this, 'FileReaderSync', 'read', op, blob); - this.disconnectRuntime(); - return result; - } - } - }; -}); - -// Included from: src/javascript/xhr/FormData.js - -/** - * FormData.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define("moxie/xhr/FormData", [ - "moxie/core/Exceptions", - "moxie/core/utils/Basic", - "moxie/file/Blob" -], function(x, Basic, Blob) { - /** - FormData - - @class FormData - @constructor - */ - function FormData() { - var _blob, _fields = []; - - Basic.extend(this, { - /** - Append another key-value pair to the FormData object - - @method append - @param {String} name Name for the new field - @param {String|Blob|Array|Object} value Value for the field - */ - append: function(name, value) { - var self = this, valueType = Basic.typeOf(value); - - // according to specs value might be either Blob or String - if (value instanceof Blob) { - _blob = { - name: name, - value: value // unfortunately we can only send single Blob in one FormData - }; - } else if ('array' === valueType) { - name += '[]'; - - Basic.each(value, function(value) { - self.append(name, value); - }); - } else if ('object' === valueType) { - Basic.each(value, function(value, key) { - self.append(name + '[' + key + ']', value); - }); - } else if ('null' === valueType || 'undefined' === valueType || 'number' === valueType && isNaN(value)) { - self.append(name, "false"); - } else { - _fields.push({ - name: name, - value: value.toString() - }); - } - }, - - /** - Checks if FormData contains Blob. - - @method hasBlob - @return {Boolean} - */ - hasBlob: function() { - return !!this.getBlob(); - }, - - /** - Retrieves blob. - - @method getBlob - @return {Object} Either Blob if found or null - */ - getBlob: function() { - return _blob && _blob.value || null; - }, - - /** - Retrieves blob field name. - - @method getBlobName - @return {String} Either Blob field name or null - */ - getBlobName: function() { - return _blob && _blob.name || null; - }, - - /** - Loop over the fields in FormData and invoke the callback for each of them. - - @method each - @param {Function} cb Callback to call for each field - */ - each: function(cb) { - Basic.each(_fields, function(field) { - cb(field.value, field.name); - }); - - if (_blob) { - cb(_blob.value, _blob.name); - } - }, - - destroy: function() { - _blob = null; - _fields = []; - } - }); - } - - return FormData; -}); - -// Included from: src/javascript/xhr/XMLHttpRequest.js - -/** - * XMLHttpRequest.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define("moxie/xhr/XMLHttpRequest", [ - "moxie/core/utils/Basic", - "moxie/core/Exceptions", - "moxie/core/EventTarget", - "moxie/core/utils/Encode", - "moxie/core/utils/Url", - "moxie/runtime/Runtime", - "moxie/runtime/RuntimeTarget", - "moxie/file/Blob", - "moxie/file/FileReaderSync", - "moxie/xhr/FormData", - "moxie/core/utils/Env", - "moxie/core/utils/Mime" -], function(Basic, x, EventTarget, Encode, Url, Runtime, RuntimeTarget, Blob, FileReaderSync, FormData, Env, Mime) { - - var httpCode = { - 100: 'Continue', - 101: 'Switching Protocols', - 102: 'Processing', - - 200: 'OK', - 201: 'Created', - 202: 'Accepted', - 203: 'Non-Authoritative Information', - 204: 'No Content', - 205: 'Reset Content', - 206: 'Partial Content', - 207: 'Multi-Status', - 226: 'IM Used', - - 300: 'Multiple Choices', - 301: 'Moved Permanently', - 302: 'Found', - 303: 'See Other', - 304: 'Not Modified', - 305: 'Use Proxy', - 306: 'Reserved', - 307: 'Temporary Redirect', - - 400: 'Bad Request', - 401: 'Unauthorized', - 402: 'Payment Required', - 403: 'Forbidden', - 404: 'Not Found', - 405: 'Method Not Allowed', - 406: 'Not Acceptable', - 407: 'Proxy Authentication Required', - 408: 'Request Timeout', - 409: 'Conflict', - 410: 'Gone', - 411: 'Length Required', - 412: 'Precondition Failed', - 413: 'Request Entity Too Large', - 414: 'Request-URI Too Long', - 415: 'Unsupported Media Type', - 416: 'Requested Range Not Satisfiable', - 417: 'Expectation Failed', - 422: 'Unprocessable Entity', - 423: 'Locked', - 424: 'Failed Dependency', - 426: 'Upgrade Required', - - 500: 'Internal Server Error', - 501: 'Not Implemented', - 502: 'Bad Gateway', - 503: 'Service Unavailable', - 504: 'Gateway Timeout', - 505: 'HTTP Version Not Supported', - 506: 'Variant Also Negotiates', - 507: 'Insufficient Storage', - 510: 'Not Extended' - }; - - function XMLHttpRequestUpload() { - this.uid = Basic.guid('uid_'); - } - - XMLHttpRequestUpload.prototype = EventTarget.instance; - - /** - Implementation of XMLHttpRequest - - @class XMLHttpRequest - @constructor - @uses RuntimeClient - @extends EventTarget - */ - var dispatches = ['loadstart', 'progress', 'abort', 'error', 'load', 'timeout', 'loadend']; // & readystatechange (for historical reasons) - - var NATIVE = 1, RUNTIME = 2; - - function XMLHttpRequest() { - var self = this, - // this (together with _p() @see below) is here to gracefully upgrade to setter/getter syntax where possible - props = { - /** - The amount of milliseconds a request can take before being terminated. Initially zero. Zero means there is no timeout. - - @property timeout - @type Number - @default 0 - */ - timeout: 0, - - /** - Current state, can take following values: - UNSENT (numeric value 0) - The object has been constructed. - - OPENED (numeric value 1) - The open() method has been successfully invoked. During this state request headers can be set using setRequestHeader() and the request can be made using the send() method. - - HEADERS_RECEIVED (numeric value 2) - All redirects (if any) have been followed and all HTTP headers of the final response have been received. Several response members of the object are now available. - - LOADING (numeric value 3) - The response entity body is being received. - - DONE (numeric value 4) - - @property readyState - @type Number - @default 0 (UNSENT) - */ - readyState: XMLHttpRequest.UNSENT, - - /** - True when user credentials are to be included in a cross-origin request. False when they are to be excluded - in a cross-origin request and when cookies are to be ignored in its response. Initially false. - - @property withCredentials - @type Boolean - @default false - */ - withCredentials: false, - - /** - Returns the HTTP status code. - - @property status - @type Number - @default 0 - */ - status: 0, - - /** - Returns the HTTP status text. - - @property statusText - @type String - */ - statusText: "", - - /** - Returns the response type. Can be set to change the response type. Values are: - the empty string (default), "arraybuffer", "blob", "document", "json", and "text". - - @property responseType - @type String - */ - responseType: "", - - /** - Returns the document response entity body. - - Throws an "InvalidStateError" exception if responseType is not the empty string or "document". - - @property responseXML - @type Document - */ - responseXML: null, - - /** - Returns the text response entity body. - - Throws an "InvalidStateError" exception if responseType is not the empty string or "text". - - @property responseText - @type String - */ - responseText: null, - - /** - Returns the response entity body (http://www.w3.org/TR/XMLHttpRequest/#response-entity-body). - Can become: ArrayBuffer, Blob, Document, JSON, Text - - @property response - @type Mixed - */ - response: null - }, - - _async = true, - _url, - _method, - _headers = {}, - _user, - _password, - _encoding = null, - _mimeType = null, - - // flags - _sync_flag = false, - _send_flag = false, - _upload_events_flag = false, - _upload_complete_flag = false, - _error_flag = false, - _same_origin_flag = false, - - // times - _start_time, - _timeoutset_time, - - _finalMime = null, - _finalCharset = null, - - _options = {}, - _xhr, - _responseHeaders = '', - _responseHeadersBag - ; - - - Basic.extend(this, props, { - /** - Unique id of the component - - @property uid - @type String - */ - uid: Basic.guid('uid_'), - - /** - Target for Upload events - - @property upload - @type XMLHttpRequestUpload - */ - upload: new XMLHttpRequestUpload(), - - - /** - Sets the request method, request URL, synchronous flag, request username, and request password. - - Throws a "SyntaxError" exception if one of the following is true: - - method is not a valid HTTP method. - url cannot be resolved. - url contains the "user:password" format in the userinfo production. - Throws a "SecurityError" exception if method is a case-insensitive match for CONNECT, TRACE or TRACK. - - Throws an "InvalidAccessError" exception if one of the following is true: - - Either user or password is passed as argument and the origin of url does not match the XMLHttpRequest origin. - There is an associated XMLHttpRequest document and either the timeout attribute is not zero, - the withCredentials attribute is true, or the responseType attribute is not the empty string. - - - @method open - @param {String} method HTTP method to use on request - @param {String} url URL to request - @param {Boolean} [async=true] If false request will be done in synchronous manner. Asynchronous by default. - @param {String} [user] Username to use in HTTP authentication process on server-side - @param {String} [password] Password to use in HTTP authentication process on server-side - */ - open: function(method, url, async, user, password) { - var urlp; - - // first two arguments are required - if (!method || !url) { - throw new x.DOMException(x.DOMException.SYNTAX_ERR); - } - - // 2 - check if any code point in method is higher than U+00FF or after deflating method it does not match the method - if (/[\u0100-\uffff]/.test(method) || Encode.utf8_encode(method) !== method) { - throw new x.DOMException(x.DOMException.SYNTAX_ERR); - } - - // 3 - if (!!~Basic.inArray(method.toUpperCase(), ['CONNECT', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT', 'TRACE', 'TRACK'])) { - _method = method.toUpperCase(); - } - - - // 4 - allowing these methods poses a security risk - if (!!~Basic.inArray(_method, ['CONNECT', 'TRACE', 'TRACK'])) { - throw new x.DOMException(x.DOMException.SECURITY_ERR); - } - - // 5 - url = Encode.utf8_encode(url); - - // 6 - Resolve url relative to the XMLHttpRequest base URL. If the algorithm returns an error, throw a "SyntaxError". - urlp = Url.parseUrl(url); - - _same_origin_flag = Url.hasSameOrigin(urlp); - - // 7 - manually build up absolute url - _url = Url.resolveUrl(url); - - // 9-10, 12-13 - if ((user || password) && !_same_origin_flag) { - throw new x.DOMException(x.DOMException.INVALID_ACCESS_ERR); - } - - _user = user || urlp.user; - _password = password || urlp.pass; - - // 11 - _async = async || true; - - if (_async === false && (_p('timeout') || _p('withCredentials') || _p('responseType') !== "")) { - throw new x.DOMException(x.DOMException.INVALID_ACCESS_ERR); - } - - // 14 - terminate abort() - - // 15 - terminate send() - - // 18 - _sync_flag = !_async; - _send_flag = false; - _headers = {}; - _reset.call(this); - - // 19 - _p('readyState', XMLHttpRequest.OPENED); - - // 20 - this.convertEventPropsToHandlers(['readystatechange']); // unify event handlers - this.dispatchEvent('readystatechange'); - }, - - /** - Appends an header to the list of author request headers, or if header is already - in the list of author request headers, combines its value with value. - - Throws an "InvalidStateError" exception if the state is not OPENED or if the send() flag is set. - Throws a "SyntaxError" exception if header is not a valid HTTP header field name or if value - is not a valid HTTP header field value. - - @method setRequestHeader - @param {String} header - @param {String|Number} value - */ - setRequestHeader: function(header, value) { - var uaHeaders = [ // these headers are controlled by the user agent - "accept-charset", - "accept-encoding", - "access-control-request-headers", - "access-control-request-method", - "connection", - "content-length", - "cookie", - "cookie2", - "content-transfer-encoding", - "date", - "expect", - "host", - "keep-alive", - "origin", - "referer", - "te", - "trailer", - "transfer-encoding", - "upgrade", - "user-agent", - "via" - ]; - - // 1-2 - if (_p('readyState') !== XMLHttpRequest.OPENED || _send_flag) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - // 3 - if (/[\u0100-\uffff]/.test(header) || Encode.utf8_encode(header) !== header) { - throw new x.DOMException(x.DOMException.SYNTAX_ERR); - } - - // 4 - /* this step is seemingly bypassed in browsers, probably to allow various unicode characters in header values - if (/[\u0100-\uffff]/.test(value) || Encode.utf8_encode(value) !== value) { - throw new x.DOMException(x.DOMException.SYNTAX_ERR); - }*/ - - header = Basic.trim(header).toLowerCase(); - - // setting of proxy-* and sec-* headers is prohibited by spec - if (!!~Basic.inArray(header, uaHeaders) || /^(proxy\-|sec\-)/.test(header)) { - return false; - } - - // camelize - // browsers lowercase header names (at least for custom ones) - // header = header.replace(/\b\w/g, function($1) { return $1.toUpperCase(); }); - - if (!_headers[header]) { - _headers[header] = value; - } else { - // http://tools.ietf.org/html/rfc2616#section-4.2 (last paragraph) - _headers[header] += ', ' + value; - } - return true; - }, - - /** - Returns all headers from the response, with the exception of those whose field name is Set-Cookie or Set-Cookie2. - - @method getAllResponseHeaders - @return {String} reponse headers or empty string - */ - getAllResponseHeaders: function() { - return _responseHeaders || ''; - }, - - /** - Returns the header field value from the response of which the field name matches header, - unless the field name is Set-Cookie or Set-Cookie2. - - @method getResponseHeader - @param {String} header - @return {String} value(s) for the specified header or null - */ - getResponseHeader: function(header) { - header = header.toLowerCase(); - - if (_error_flag || !!~Basic.inArray(header, ['set-cookie', 'set-cookie2'])) { - return null; - } - - if (_responseHeaders && _responseHeaders !== '') { - // if we didn't parse response headers until now, do it and keep for later - if (!_responseHeadersBag) { - _responseHeadersBag = {}; - Basic.each(_responseHeaders.split(/\r\n/), function(line) { - var pair = line.split(/:\s+/); - if (pair.length === 2) { // last line might be empty, omit - pair[0] = Basic.trim(pair[0]); // just in case - _responseHeadersBag[pair[0].toLowerCase()] = { // simply to retain header name in original form - header: pair[0], - value: Basic.trim(pair[1]) - }; - } - }); - } - if (_responseHeadersBag.hasOwnProperty(header)) { - return _responseHeadersBag[header].header + ': ' + _responseHeadersBag[header].value; - } - } - return null; - }, - - /** - Sets the Content-Type header for the response to mime. - Throws an "InvalidStateError" exception if the state is LOADING or DONE. - Throws a "SyntaxError" exception if mime is not a valid media type. - - @method overrideMimeType - @param String mime Mime type to set - */ - overrideMimeType: function(mime) { - var matches, charset; - - // 1 - if (!!~Basic.inArray(_p('readyState'), [XMLHttpRequest.LOADING, XMLHttpRequest.DONE])) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - // 2 - mime = Basic.trim(mime.toLowerCase()); - - if (/;/.test(mime) && (matches = mime.match(/^([^;]+)(?:;\scharset\=)?(.*)$/))) { - mime = matches[1]; - if (matches[2]) { - charset = matches[2]; - } - } - - if (!Mime.mimes[mime]) { - throw new x.DOMException(x.DOMException.SYNTAX_ERR); - } - - // 3-4 - _finalMime = mime; - _finalCharset = charset; - }, - - /** - Initiates the request. The optional argument provides the request entity body. - The argument is ignored if request method is GET or HEAD. - - Throws an "InvalidStateError" exception if the state is not OPENED or if the send() flag is set. - - @method send - @param {Blob|Document|String|FormData} [data] Request entity body - @param {Object} [options] Set of requirements and pre-requisities for runtime initialization - */ - send: function(data, options) { - if (Basic.typeOf(options) === 'string') { - _options = { ruid: options }; - } else if (!options) { - _options = {}; - } else { - _options = options; - } - - this.convertEventPropsToHandlers(dispatches); - this.upload.convertEventPropsToHandlers(dispatches); - - // 1-2 - if (this.readyState !== XMLHttpRequest.OPENED || _send_flag) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - // 3 - // sending Blob - if (data instanceof Blob) { - _options.ruid = data.ruid; - _mimeType = data.type || 'application/octet-stream'; - } - - // FormData - else if (data instanceof FormData) { - if (data.hasBlob()) { - var blob = data.getBlob(); - _options.ruid = blob.ruid; - _mimeType = blob.type || 'application/octet-stream'; - } - } - - // DOMString - else if (typeof data === 'string') { - _encoding = 'UTF-8'; - _mimeType = 'text/plain;charset=UTF-8'; - - // data should be converted to Unicode and encoded as UTF-8 - data = Encode.utf8_encode(data); - } - - // if withCredentials not set, but requested, set it automatically - if (!this.withCredentials) { - this.withCredentials = (_options.required_caps && _options.required_caps.send_browser_cookies) && !_same_origin_flag; - } - - // 4 - storage mutex - // 5 - _upload_events_flag = (!_sync_flag && this.upload.hasEventListener()); // DSAP - // 6 - _error_flag = false; - // 7 - _upload_complete_flag = !data; - // 8 - Asynchronous steps - if (!_sync_flag) { - // 8.1 - _send_flag = true; - // 8.2 - // this.dispatchEvent('loadstart'); // will be dispatched either by native or runtime xhr - // 8.3 - //if (!_upload_complete_flag) { - // this.upload.dispatchEvent('loadstart'); // will be dispatched either by native or runtime xhr - //} - } - // 8.5 - Return the send() method call, but continue running the steps in this algorithm. - _doXHR.call(this, data); - }, - - /** - Cancels any network activity. - - @method abort - */ - abort: function() { - _error_flag = true; - _sync_flag = false; - - if (!~Basic.inArray(_p('readyState'), [XMLHttpRequest.UNSENT, XMLHttpRequest.OPENED, XMLHttpRequest.DONE])) { - _p('readyState', XMLHttpRequest.DONE); - _send_flag = false; - - if (_xhr) { - _xhr.getRuntime().exec.call(_xhr, 'XMLHttpRequest', 'abort', _upload_complete_flag); - } else { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - _upload_complete_flag = true; - } else { - _p('readyState', XMLHttpRequest.UNSENT); - } - }, - - destroy: function() { - if (_xhr) { - if (Basic.typeOf(_xhr.destroy) === 'function') { - _xhr.destroy(); - } - _xhr = null; - } - - this.unbindAll(); - - if (this.upload) { - this.upload.unbindAll(); - this.upload = null; - } - } - }); - - /* this is nice, but maybe too lengthy - - // if supported by JS version, set getters/setters for specific properties - o.defineProperty(this, 'readyState', { - configurable: false, - - get: function() { - return _p('readyState'); - } - }); - - o.defineProperty(this, 'timeout', { - configurable: false, - - get: function() { - return _p('timeout'); - }, - - set: function(value) { - - if (_sync_flag) { - throw new x.DOMException(x.DOMException.INVALID_ACCESS_ERR); - } - - // timeout still should be measured relative to the start time of request - _timeoutset_time = (new Date).getTime(); - - _p('timeout', value); - } - }); - - // the withCredentials attribute has no effect when fetching same-origin resources - o.defineProperty(this, 'withCredentials', { - configurable: false, - - get: function() { - return _p('withCredentials'); - }, - - set: function(value) { - // 1-2 - if (!~o.inArray(_p('readyState'), [XMLHttpRequest.UNSENT, XMLHttpRequest.OPENED]) || _send_flag) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - // 3-4 - if (_anonymous_flag || _sync_flag) { - throw new x.DOMException(x.DOMException.INVALID_ACCESS_ERR); - } - - // 5 - _p('withCredentials', value); - } - }); - - o.defineProperty(this, 'status', { - configurable: false, - - get: function() { - return _p('status'); - } - }); - - o.defineProperty(this, 'statusText', { - configurable: false, - - get: function() { - return _p('statusText'); - } - }); - - o.defineProperty(this, 'responseType', { - configurable: false, - - get: function() { - return _p('responseType'); - }, - - set: function(value) { - // 1 - if (!!~o.inArray(_p('readyState'), [XMLHttpRequest.LOADING, XMLHttpRequest.DONE])) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - // 2 - if (_sync_flag) { - throw new x.DOMException(x.DOMException.INVALID_ACCESS_ERR); - } - - // 3 - _p('responseType', value.toLowerCase()); - } - }); - - o.defineProperty(this, 'responseText', { - configurable: false, - - get: function() { - // 1 - if (!~o.inArray(_p('responseType'), ['', 'text'])) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - // 2-3 - if (_p('readyState') !== XMLHttpRequest.DONE && _p('readyState') !== XMLHttpRequest.LOADING || _error_flag) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - return _p('responseText'); - } - }); - - o.defineProperty(this, 'responseXML', { - configurable: false, - - get: function() { - // 1 - if (!~o.inArray(_p('responseType'), ['', 'document'])) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - // 2-3 - if (_p('readyState') !== XMLHttpRequest.DONE || _error_flag) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - return _p('responseXML'); - } - }); - - o.defineProperty(this, 'response', { - configurable: false, - - get: function() { - if (!!~o.inArray(_p('responseType'), ['', 'text'])) { - if (_p('readyState') !== XMLHttpRequest.DONE && _p('readyState') !== XMLHttpRequest.LOADING || _error_flag) { - return ''; - } - } - - if (_p('readyState') !== XMLHttpRequest.DONE || _error_flag) { - return null; - } - - return _p('response'); - } - }); - - */ - - function _p(prop, value) { - if (!props.hasOwnProperty(prop)) { - return; - } - if (arguments.length === 1) { // get - return Env.can('define_property') ? props[prop] : self[prop]; - } else { // set - if (Env.can('define_property')) { - props[prop] = value; - } else { - self[prop] = value; - } - } - } - - /* - function _toASCII(str, AllowUnassigned, UseSTD3ASCIIRules) { - // TODO: http://tools.ietf.org/html/rfc3490#section-4.1 - return str.toLowerCase(); - } - */ - - - function _doXHR(data) { - var self = this; - - _start_time = new Date().getTime(); - - _xhr = new RuntimeTarget(); - - function loadEnd() { - _xhr.destroy(); - _xhr = null; - self.dispatchEvent('loadend'); - self = null; - } - - function exec(runtime) { - _xhr.bind('LoadStart', function(e) { - _p('readyState', XMLHttpRequest.LOADING); - self.dispatchEvent('readystatechange'); - - self.dispatchEvent(e); - - if (_upload_events_flag) { - self.upload.dispatchEvent(e); - } - }); - - _xhr.bind('Progress', function(e) { - if (_p('readyState') !== XMLHttpRequest.LOADING) { - _p('readyState', XMLHttpRequest.LOADING); // LoadStart unreliable (in Flash for example) - self.dispatchEvent('readystatechange'); - } - self.dispatchEvent(e); - }); - - _xhr.bind('UploadProgress', function(e) { - if (_upload_events_flag) { - self.upload.dispatchEvent({ - type: 'progress', - lengthComputable: false, - total: e.total, - loaded: e.loaded - }); - } - }); - - _xhr.bind('Load', function(e) { - _p('readyState', XMLHttpRequest.DONE); - _p('status', Number(runtime.exec.call(_xhr, 'XMLHttpRequest', 'getStatus') || 0)); - _p('statusText', httpCode[_p('status')] || ""); - - _p('response', runtime.exec.call(_xhr, 'XMLHttpRequest', 'getResponse', _p('responseType'))); - - if (!!~Basic.inArray(_p('responseType'), ['text', ''])) { - _p('responseText', _p('response')); - } else if (_p('responseType') === 'document') { - _p('responseXML', _p('response')); - } - - _responseHeaders = runtime.exec.call(_xhr, 'XMLHttpRequest', 'getAllResponseHeaders'); - - self.dispatchEvent('readystatechange'); - - if (_p('status') > 0) { // status 0 usually means that server is unreachable - if (_upload_events_flag) { - self.upload.dispatchEvent(e); - } - self.dispatchEvent(e); - } else { - _error_flag = true; - self.dispatchEvent('error'); - } - loadEnd(); - }); - - _xhr.bind('Abort', function(e) { - self.dispatchEvent(e); - loadEnd(); - }); - - _xhr.bind('Error', function(e) { - _error_flag = true; - _p('readyState', XMLHttpRequest.DONE); - self.dispatchEvent('readystatechange'); - _upload_complete_flag = true; - self.dispatchEvent(e); - loadEnd(); - }); - - runtime.exec.call(_xhr, 'XMLHttpRequest', 'send', { - url: _url, - method: _method, - async: _async, - user: _user, - password: _password, - headers: _headers, - mimeType: _mimeType, - encoding: _encoding, - responseType: self.responseType, - withCredentials: self.withCredentials, - options: _options - }, data); - } - - // clarify our requirements - if (typeof(_options.required_caps) === 'string') { - _options.required_caps = Runtime.parseCaps(_options.required_caps); - } - - _options.required_caps = Basic.extend({}, _options.required_caps, { - return_response_type: self.responseType - }); - - if (data instanceof FormData) { - _options.required_caps.send_multipart = true; - } - - if (!_same_origin_flag) { - _options.required_caps.do_cors = true; - } - - - if (_options.ruid) { // we do not need to wait if we can connect directly - exec(_xhr.connectRuntime(_options)); - } else { - _xhr.bind('RuntimeInit', function(e, runtime) { - exec(runtime); - }); - _xhr.bind('RuntimeError', function(e, err) { - self.dispatchEvent('RuntimeError', err); - }); - _xhr.connectRuntime(_options); - } - } - - - function _reset() { - _p('responseText', ""); - _p('responseXML', null); - _p('response', null); - _p('status', 0); - _p('statusText', ""); - _start_time = _timeoutset_time = null; - } - } - - XMLHttpRequest.UNSENT = 0; - XMLHttpRequest.OPENED = 1; - XMLHttpRequest.HEADERS_RECEIVED = 2; - XMLHttpRequest.LOADING = 3; - XMLHttpRequest.DONE = 4; - - XMLHttpRequest.prototype = EventTarget.instance; - - return XMLHttpRequest; -}); - -// Included from: src/javascript/runtime/Transporter.js - -/** - * Transporter.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define("moxie/runtime/Transporter", [ - "moxie/core/utils/Basic", - "moxie/core/utils/Encode", - "moxie/runtime/RuntimeClient", - "moxie/core/EventTarget" -], function(Basic, Encode, RuntimeClient, EventTarget) { - function Transporter() { - var mod, _runtime, _data, _size, _pos, _chunk_size; - - RuntimeClient.call(this); - - Basic.extend(this, { - uid: Basic.guid('uid_'), - - state: Transporter.IDLE, - - result: null, - - transport: function(data, type, options) { - var self = this; - - options = Basic.extend({ - chunk_size: 204798 - }, options); - - // should divide by three, base64 requires this - if ((mod = options.chunk_size % 3)) { - options.chunk_size += 3 - mod; - } - - _chunk_size = options.chunk_size; - - _reset.call(this); - _data = data; - _size = data.length; - - if (Basic.typeOf(options) === 'string' || options.ruid) { - _run.call(self, type, this.connectRuntime(options)); - } else { - // we require this to run only once - var cb = function(e, runtime) { - self.unbind("RuntimeInit", cb); - _run.call(self, type, runtime); - }; - this.bind("RuntimeInit", cb); - this.connectRuntime(options); - } - }, - - abort: function() { - var self = this; - - self.state = Transporter.IDLE; - if (_runtime) { - _runtime.exec.call(self, 'Transporter', 'clear'); - self.trigger("TransportingAborted"); - } - - _reset.call(self); - }, - - - destroy: function() { - this.unbindAll(); - _runtime = null; - this.disconnectRuntime(); - _reset.call(this); - } - }); - - function _reset() { - _size = _pos = 0; - _data = this.result = null; - } - - function _run(type, runtime) { - var self = this; - - _runtime = runtime; - - //self.unbind("RuntimeInit"); - - self.bind("TransportingProgress", function(e) { - _pos = e.loaded; - - if (_pos < _size && Basic.inArray(self.state, [Transporter.IDLE, Transporter.DONE]) === -1) { - _transport.call(self); - } - }, 999); - - self.bind("TransportingComplete", function() { - _pos = _size; - self.state = Transporter.DONE; - _data = null; // clean a bit - self.result = _runtime.exec.call(self, 'Transporter', 'getAsBlob', type || ''); - }, 999); - - self.state = Transporter.BUSY; - self.trigger("TransportingStarted"); - _transport.call(self); - } - - function _transport() { - var self = this, - chunk, - bytesLeft = _size - _pos; - - if (_chunk_size > bytesLeft) { - _chunk_size = bytesLeft; - } - - chunk = Encode.btoa(_data.substr(_pos, _chunk_size)); - _runtime.exec.call(self, 'Transporter', 'receive', chunk, _size); - } - } - - Transporter.IDLE = 0; - Transporter.BUSY = 1; - Transporter.DONE = 2; - - Transporter.prototype = EventTarget.instance; - - return Transporter; -}); - -// Included from: src/javascript/image/Image.js - -/** - * Image.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define("moxie/image/Image", [ - "moxie/core/utils/Basic", - "moxie/core/utils/Dom", - "moxie/core/Exceptions", - "moxie/file/FileReaderSync", - "moxie/xhr/XMLHttpRequest", - "moxie/runtime/Runtime", - "moxie/runtime/RuntimeClient", - "moxie/runtime/Transporter", - "moxie/core/utils/Env", - "moxie/core/EventTarget", - "moxie/file/Blob", - "moxie/file/File", - "moxie/core/utils/Encode" -], function(Basic, Dom, x, FileReaderSync, XMLHttpRequest, Runtime, RuntimeClient, Transporter, Env, EventTarget, Blob, File, Encode) { - /** - Image preloading and manipulation utility. Additionally it provides access to image meta info (Exif, GPS) and raw binary data. - - @class Image - @constructor - @extends EventTarget - */ - var dispatches = [ - 'progress', - - /** - Dispatched when loading is complete. - - @event load - @param {Object} event - */ - 'load', - - 'error', - - /** - Dispatched when resize operation is complete. - - @event resize - @param {Object} event - */ - 'resize', - - /** - Dispatched when visual representation of the image is successfully embedded - into the corresponsing container. - - @event embedded - @param {Object} event - */ - 'embedded' - ]; - - function Image() { - RuntimeClient.call(this); - - Basic.extend(this, { - /** - Unique id of the component - - @property uid - @type {String} - */ - uid: Basic.guid('uid_'), - - /** - Unique id of the connected runtime, if any. - - @property ruid - @type {String} - */ - ruid: null, - - /** - Name of the file, that was used to create an image, if available. If not equals to empty string. - - @property name - @type {String} - @default "" - */ - name: "", - - /** - Size of the image in bytes. Actual value is set only after image is preloaded. - - @property size - @type {Number} - @default 0 - */ - size: 0, - - /** - Width of the image. Actual value is set only after image is preloaded. - - @property width - @type {Number} - @default 0 - */ - width: 0, - - /** - Height of the image. Actual value is set only after image is preloaded. - - @property height - @type {Number} - @default 0 - */ - height: 0, - - /** - Mime type of the image. Currently only image/jpeg and image/png are supported. Actual value is set only after image is preloaded. - - @property type - @type {String} - @default "" - */ - type: "", - - /** - Holds meta info (Exif, GPS). Is populated only for image/jpeg. Actual value is set only after image is preloaded. - - @property meta - @type {Object} - @default {} - */ - meta: {}, - - /** - Alias for load method, that takes another mOxie.Image object as a source (see load). - - @method clone - @param {Image} src Source for the image - @param {Boolean} [exact=false] Whether to activate in-depth clone mode - */ - clone: function() { - this.load.apply(this, arguments); - }, - - /** - Loads image from various sources. Currently the source for new image can be: mOxie.Image, mOxie.Blob/mOxie.File, - native Blob/File, dataUrl or URL. Depending on the type of the source, arguments - differ. When source is URL, - Image will be downloaded from remote destination and loaded in memory. - - @example - var img = new mOxie.Image(); - img.onload = function() { - var blob = img.getAsBlob(); - - var formData = new mOxie.FormData(); - formData.append('file', blob); - - var xhr = new mOxie.XMLHttpRequest(); - xhr.onload = function() { - // upload complete - }; - xhr.open('post', 'upload.php'); - xhr.send(formData); - }; - img.load("http://www.moxiecode.com/images/mox-logo.jpg"); // notice file extension (.jpg) - - - @method load - @param {Image|Blob|File|String} src Source for the image - @param {Boolean|Object} [mixed] - */ - load: function() { - // this is here because to bind properly we need an uid first, which is created above - this.bind('Load Resize', function() { - _updateInfo.call(this); - }, 999); - - this.convertEventPropsToHandlers(dispatches); - - _load.apply(this, arguments); - }, - - /** - Downsizes the image to fit the specified width/height. If crop is supplied, image will be cropped to exact dimensions. - - @method downsize - @param {Number} width Resulting width - @param {Number} [height=width] Resulting height (optional, if not supplied will default to width) - @param {Boolean} [crop=false] Whether to crop the image to exact dimensions - @param {Boolean} [preserveHeaders=true] Whether to preserve meta headers (on JPEGs after resize) - */ - downsize: function(width, height, crop, preserveHeaders) { - try { - if (!this.size) { // only preloaded image objects can be used as source - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - // no way to reliably intercept the crash due to high resolution, so we simply avoid it - if (this.width > Image.MAX_RESIZE_WIDTH || this.height > Image.MAX_RESIZE_HEIGHT) { - throw new x.ImageError(x.ImageError.MAX_RESOLUTION_ERR); - } - - if (!width && !height || Basic.typeOf(crop) === 'undefined') { - crop = false; - } - - width = width || this.width; - height = height || this.height; - - preserveHeaders = (Basic.typeOf(preserveHeaders) === 'undefined' ? true : !!preserveHeaders); - - this.getRuntime().exec.call(this, 'Image', 'downsize', width, height, crop, preserveHeaders); - } catch(ex) { - // for now simply trigger error event - this.trigger('error', ex); - } - }, - - /** - Alias for downsize(width, height, true). (see downsize) - - @method crop - @param {Number} width Resulting width - @param {Number} [height=width] Resulting height (optional, if not supplied will default to width) - @param {Boolean} [preserveHeaders=true] Whether to preserve meta headers (on JPEGs after resize) - */ - crop: function(width, height, preserveHeaders) { - this.downsize(width, height, true, preserveHeaders); - }, - - getAsCanvas: function() { - if (!Env.can('create_canvas')) { - throw new x.RuntimeError(x.RuntimeError.NOT_SUPPORTED_ERR); - } - - var runtime = this.connectRuntime(this.ruid); - return runtime.exec.call(this, 'Image', 'getAsCanvas'); - }, - - /** - Retrieves image in it's current state as mOxie.Blob object. Cannot be run on empty or image in progress (throws - DOMException.INVALID_STATE_ERR). - - @method getAsBlob - @param {String} [type="image/jpeg"] Mime type of resulting blob. Can either be image/jpeg or image/png - @param {Number} [quality=90] Applicable only together with mime type image/jpeg - @return {Blob} Image as Blob - */ - getAsBlob: function(type, quality) { - if (!this.size) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - if (!type) { - type = 'image/jpeg'; - } - - if (type === 'image/jpeg' && !quality) { - quality = 90; - } - - return this.getRuntime().exec.call(this, 'Image', 'getAsBlob', type, quality); - }, - - /** - Retrieves image in it's current state as dataURL string. Cannot be run on empty or image in progress (throws - DOMException.INVALID_STATE_ERR). - - @method getAsDataURL - @param {String} [type="image/jpeg"] Mime type of resulting blob. Can either be image/jpeg or image/png - @param {Number} [quality=90] Applicable only together with mime type image/jpeg - @return {String} Image as dataURL string - */ - getAsDataURL: function(type, quality) { - if (!this.size) { - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - return this.getRuntime().exec.call(this, 'Image', 'getAsDataURL', type, quality); - }, - - /** - Retrieves image in it's current state as binary string. Cannot be run on empty or image in progress (throws - DOMException.INVALID_STATE_ERR). - - @method getAsBinaryString - @param {String} [type="image/jpeg"] Mime type of resulting blob. Can either be image/jpeg or image/png - @param {Number} [quality=90] Applicable only together with mime type image/jpeg - @return {String} Image as binary string - */ - getAsBinaryString: function(type, quality) { - var dataUrl = this.getAsDataURL(type, quality); - return Encode.atob(dataUrl.substring(dataUrl.indexOf('base64,') + 7)); - }, - - /** - Embeds the image, or better to say, it's visual representation into the specified node. Depending on the runtime - in use, might be a canvas, or image (actual ) element or shim object (Flash or SilverLight - very rare, used for - legacy browsers that do not have canvas or proper dataURI support). - - @method embed - @param {DOMElement} el DOM element to insert the image object into - @param {Object} options Set of key/value pairs controlling the mime type, dimensions and cropping factor of resulting - representation - */ - embed: function(el) { - var self = this - , imgCopy - , type, quality, crop - , options = arguments[1] || {} - , width = this.width - , height = this.height - , runtime // this has to be outside of all the closures to contain proper runtime - ; - - function onResize() { - // if possible, embed a canvas element directly - if (Env.can('create_canvas')) { - var canvas = imgCopy.getAsCanvas(); - if (canvas) { - el.appendChild(canvas); - canvas = null; - imgCopy.destroy(); - self.trigger('embedded'); - return; - } - } - - var dataUrl = imgCopy.getAsDataURL(type, quality); - if (!dataUrl) { - throw new x.ImageError(x.ImageError.WRONG_FORMAT); - } - - if (Env.can('use_data_uri_of', dataUrl.length)) { - el.innerHTML = ''; - imgCopy.destroy(); - self.trigger('embedded'); - } else { - var tr = new Transporter(); - - tr.bind("TransportingComplete", function() { - runtime = self.connectRuntime(this.result.ruid); - - self.bind("Embedded", function() { - // position and size properly - Basic.extend(runtime.getShimContainer().style, { - //position: 'relative', - top: '0px', - left: '0px', - width: imgCopy.width + 'px', - height: imgCopy.height + 'px' - }); - - // some shims (Flash/SilverLight) reinitialize, if parent element is hidden, reordered or it's - // position type changes (in Gecko), but since we basically need this only in IEs 6/7 and - // sometimes 8 and they do not have this problem, we can comment this for now - /*tr.bind("RuntimeInit", function(e, runtime) { - tr.destroy(); - runtime.destroy(); - onResize.call(self); // re-feed our image data - });*/ - - runtime = null; - }, 999); - - runtime.exec.call(self, "ImageView", "display", this.result.uid, width, height); - imgCopy.destroy(); - }); - - tr.transport(Encode.atob(dataUrl.substring(dataUrl.indexOf('base64,') + 7)), type, Basic.extend({}, options, { - required_caps: { - display_media: true - }, - runtime_order: 'flash,silverlight', - container: el - })); - } - } - - try { - if (!(el = Dom.get(el))) { - throw new x.DOMException(x.DOMException.INVALID_NODE_TYPE_ERR); - } - - if (!this.size) { // only preloaded image objects can be used as source - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - - if (this.width > Image.MAX_RESIZE_WIDTH || this.height > Image.MAX_RESIZE_HEIGHT) { - throw new x.ImageError(x.ImageError.MAX_RESOLUTION_ERR); - } - - type = options.type || this.type || 'image/jpeg'; - quality = options.quality || 90; - crop = Basic.typeOf(options.crop) !== 'undefined' ? options.crop : false; - - // figure out dimensions for the thumb - if (options.width) { - width = options.width; - height = options.height || width; - } else { - // if container element has > 0 dimensions, take them - var dimensions = Dom.getSize(el); - if (dimensions.w && dimensions.h) { // both should be > 0 - width = dimensions.w; - height = dimensions.h; - } - } - - imgCopy = new Image(); - - imgCopy.bind("Resize", function() { - onResize.call(self); - }); - - imgCopy.bind("Load", function() { - imgCopy.downsize(width, height, crop, false); - }); - - imgCopy.clone(this, false); - - return imgCopy; - } catch(ex) { - // for now simply trigger error event - this.trigger('error', ex); - } - }, - - /** - Properly destroys the image and frees resources in use. If any. Recommended way to dispose mOxie.Image object. - - @method destroy - */ - destroy: function() { - if (this.ruid) { - this.getRuntime().exec.call(this, 'Image', 'destroy'); - this.disconnectRuntime(); - } - this.unbindAll(); - } - }); - - - function _updateInfo(info) { - if (!info) { - info = this.getRuntime().exec.call(this, 'Image', 'getInfo'); - } - - this.size = info.size; - this.width = info.width; - this.height = info.height; - this.type = info.type; - this.meta = info.meta; - - // update file name, only if empty - if (this.name === '') { - this.name = info.name; - } - } - - - function _load(src) { - var srcType = Basic.typeOf(src); - - try { - // if source is Image - if (src instanceof Image) { - if (!src.size) { // only preloaded image objects can be used as source - throw new x.DOMException(x.DOMException.INVALID_STATE_ERR); - } - _loadFromImage.apply(this, arguments); - } - // if source is o.Blob/o.File - else if (src instanceof Blob) { - if (!~Basic.inArray(src.type, ['image/jpeg', 'image/png'])) { - throw new x.ImageError(x.ImageError.WRONG_FORMAT); - } - _loadFromBlob.apply(this, arguments); - } - // if native blob/file - else if (Basic.inArray(srcType, ['blob', 'file']) !== -1) { - _load.call(this, new File(null, src), arguments[1]); - } - // if String - else if (srcType === 'string') { - // if dataUrl String - if (/^data:[^;]*;base64,/.test(src)) { - _load.call(this, new Blob(null, { data: src }), arguments[1]); - } - // else assume Url, either relative or absolute - else { - _loadFromUrl.apply(this, arguments); - } - } - // if source seems to be an img node - else if (srcType === 'node' && src.nodeName.toLowerCase() === 'img') { - _load.call(this, src.src, arguments[1]); - } - else { - throw new x.DOMException(x.DOMException.TYPE_MISMATCH_ERR); - } - } catch(ex) { - // for now simply trigger error event - this.trigger('error', ex); - } - } - - - function _loadFromImage(img, exact) { - var runtime = this.connectRuntime(img.ruid); - this.ruid = runtime.uid; - runtime.exec.call(this, 'Image', 'loadFromImage', img, (Basic.typeOf(exact) === 'undefined' ? true : exact)); - } - - - function _loadFromBlob(blob, options) { - var self = this; - - self.name = blob.name || ''; - - function exec(runtime) { - self.ruid = runtime.uid; - runtime.exec.call(self, 'Image', 'loadFromBlob', blob); - } - - if (blob.isDetached()) { - this.bind('RuntimeInit', function(e, runtime) { - exec(runtime); - }); - - // convert to object representation - if (options && typeof(options.required_caps) === 'string') { - options.required_caps = Runtime.parseCaps(options.required_caps); - } - - this.connectRuntime(Basic.extend({ - required_caps: { - access_image_binary: true, - resize_image: true - } - }, options)); - } else { - exec(this.connectRuntime(blob.ruid)); - } - } - - - function _loadFromUrl(url, options) { - var self = this, xhr; - - xhr = new XMLHttpRequest(); - - xhr.open('get', url); - xhr.responseType = 'blob'; - - xhr.onprogress = function(e) { - self.trigger(e); - }; - - xhr.onload = function() { - _loadFromBlob.call(self, xhr.response, true); - }; - - xhr.onerror = function(e) { - self.trigger(e); - }; - - xhr.onloadend = function() { - xhr.destroy(); - }; - - xhr.bind('RuntimeError', function(e, err) { - self.trigger('RuntimeError', err); - }); - - xhr.send(null, options); - } - } - - // virtual world will crash on you if image has a resolution higher than this: - Image.MAX_RESIZE_WIDTH = 6500; - Image.MAX_RESIZE_HEIGHT = 6500; - - Image.prototype = EventTarget.instance; - - return Image; -}); - -// Included from: src/javascript/runtime/html5/Runtime.js - -/** - * Runtime.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/*global File:true */ - -/** -Defines constructor for HTML5 runtime. - -@class moxie/runtime/html5/Runtime -@private -*/ -define("moxie/runtime/html5/Runtime", [ - "moxie/core/utils/Basic", - "moxie/core/Exceptions", - "moxie/runtime/Runtime", - "moxie/core/utils/Env" -], function(Basic, x, Runtime, Env) { - - var type = "html5", extensions = {}; - - function Html5Runtime(options) { - var I = this - , Test = Runtime.capTest - , True = Runtime.capTrue - ; - - var caps = Basic.extend({ - access_binary: Test(window.FileReader || window.File && window.File.getAsDataURL), - access_image_binary: function() { - return I.can('access_binary') && !!extensions.Image; - }, - display_media: Test(Env.can('create_canvas') || Env.can('use_data_uri_over32kb')), - do_cors: Test(window.XMLHttpRequest && 'withCredentials' in new XMLHttpRequest()), - drag_and_drop: Test(function() { - // this comes directly from Modernizr: http://www.modernizr.com/ - var div = document.createElement('div'); - // IE has support for drag and drop since version 5, but doesn't support dropping files from desktop - return (('draggable' in div) || ('ondragstart' in div && 'ondrop' in div)) && (Env.browser !== 'IE' || Env.version > 9); - }()), - filter_by_extension: Test(function() { // if you know how to feature-detect this, please suggest - return (Env.browser === 'Chrome' && Env.version >= 28) || (Env.browser === 'IE' && Env.version >= 10); - }()), - return_response_headers: True, - return_response_type: function(responseType) { - if (responseType === 'json' && !!window.JSON) { // we can fake this one even if it's not supported - return true; - } - return Env.can('return_response_type', responseType); - }, - return_status_code: True, - report_upload_progress: Test(window.XMLHttpRequest && new XMLHttpRequest().upload), - resize_image: function() { - return I.can('access_binary') && Env.can('create_canvas'); - }, - select_file: function() { - return Env.can('use_fileinput') && window.File; - }, - select_folder: function() { - return I.can('select_file') && Env.browser === 'Chrome' && Env.version >= 21; - }, - select_multiple: function() { - // it is buggy on Safari Windows and iOS - return I.can('select_file') && - !(Env.browser === 'Safari' && Env.os === 'Windows') && - !(Env.os === 'iOS' && Env.verComp(Env.osVersion, "7.0.4", '<')); - }, - send_binary_string: Test(window.XMLHttpRequest && (new XMLHttpRequest().sendAsBinary || (window.Uint8Array && window.ArrayBuffer))), - send_custom_headers: Test(window.XMLHttpRequest), - send_multipart: function() { - return !!(window.XMLHttpRequest && new XMLHttpRequest().upload && window.FormData) || I.can('send_binary_string'); - }, - slice_blob: Test(window.File && (File.prototype.mozSlice || File.prototype.webkitSlice || File.prototype.slice)), - stream_upload: function(){ - return I.can('slice_blob') && I.can('send_multipart'); - }, - summon_file_dialog: Test(function() { // yeah... some dirty sniffing here... - return (Env.browser === 'Firefox' && Env.version >= 4) || - (Env.browser === 'Opera' && Env.version >= 12) || - (Env.browser === 'IE' && Env.version >= 10) || - !!~Basic.inArray(Env.browser, ['Chrome', 'Safari']); - }()), - upload_filesize: True - }, - arguments[2] - ); - - Runtime.call(this, options, (arguments[1] || type), caps); - - - Basic.extend(this, { - - init : function() { - this.trigger("Init"); - }, - - destroy: (function(destroy) { // extend default destroy method - return function() { - destroy.call(I); - destroy = I = null; - }; - }(this.destroy)) - }); - - Basic.extend(this.getShim(), extensions); - } - - Runtime.addConstructor(type, Html5Runtime); - - return extensions; -}); - -// Included from: src/javascript/runtime/html5/file/Blob.js - -/** - * Blob.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/file/Blob -@private -*/ -define("moxie/runtime/html5/file/Blob", [ - "moxie/runtime/html5/Runtime", - "moxie/file/Blob" -], function(extensions, Blob) { - - function HTML5Blob() { - function w3cBlobSlice(blob, start, end) { - var blobSlice; - - if (window.File.prototype.slice) { - try { - blob.slice(); // depricated version will throw WRONG_ARGUMENTS_ERR exception - return blob.slice(start, end); - } catch (e) { - // depricated slice method - return blob.slice(start, end - start); - } - // slice method got prefixed: https://bugzilla.mozilla.org/show_bug.cgi?id=649672 - } else if ((blobSlice = window.File.prototype.webkitSlice || window.File.prototype.mozSlice)) { - return blobSlice.call(blob, start, end); - } else { - return null; // or throw some exception - } - } - - this.slice = function() { - return new Blob(this.getRuntime().uid, w3cBlobSlice.apply(this, arguments)); - }; - } - - return (extensions.Blob = HTML5Blob); -}); - -// Included from: src/javascript/core/utils/Events.js - -/** - * Events.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -define('moxie/core/utils/Events', [ - 'moxie/core/utils/Basic' -], function(Basic) { - var eventhash = {}, uid = 'moxie_' + Basic.guid(); - - // IE W3C like event funcs - function preventDefault() { - this.returnValue = false; - } - - function stopPropagation() { - this.cancelBubble = true; - } - - /** - Adds an event handler to the specified object and store reference to the handler - in objects internal Plupload registry (@see removeEvent). - - @method addEvent - @for Utils - @static - @param {Object} obj DOM element like object to add handler to. - @param {String} name Name to add event listener to. - @param {Function} callback Function to call when event occurs. - @param {String} [key] that might be used to add specifity to the event record. - */ - var addEvent = function(obj, name, callback, key) { - var func, events; - - name = name.toLowerCase(); - - // Add event listener - if (obj.addEventListener) { - func = callback; - - obj.addEventListener(name, func, false); - } else if (obj.attachEvent) { - func = function() { - var evt = window.event; - - if (!evt.target) { - evt.target = evt.srcElement; - } - - evt.preventDefault = preventDefault; - evt.stopPropagation = stopPropagation; - - callback(evt); - }; - - obj.attachEvent('on' + name, func); - } - - // Log event handler to objects internal mOxie registry - if (!obj[uid]) { - obj[uid] = Basic.guid(); - } - - if (!eventhash.hasOwnProperty(obj[uid])) { - eventhash[obj[uid]] = {}; - } - - events = eventhash[obj[uid]]; - - if (!events.hasOwnProperty(name)) { - events[name] = []; - } - - events[name].push({ - func: func, - orig: callback, // store original callback for IE - key: key - }); - }; - - - /** - Remove event handler from the specified object. If third argument (callback) - is not specified remove all events with the specified name. - - @method removeEvent - @static - @param {Object} obj DOM element to remove event listener(s) from. - @param {String} name Name of event listener to remove. - @param {Function|String} [callback] might be a callback or unique key to match. - */ - var removeEvent = function(obj, name, callback) { - var type, undef; - - name = name.toLowerCase(); - - if (obj[uid] && eventhash[obj[uid]] && eventhash[obj[uid]][name]) { - type = eventhash[obj[uid]][name]; - } else { - return; - } - - for (var i = type.length - 1; i >= 0; i--) { - // undefined or not, key should match - if (type[i].orig === callback || type[i].key === callback) { - if (obj.removeEventListener) { - obj.removeEventListener(name, type[i].func, false); - } else if (obj.detachEvent) { - obj.detachEvent('on'+name, type[i].func); - } - - type[i].orig = null; - type[i].func = null; - type.splice(i, 1); - - // If callback was passed we are done here, otherwise proceed - if (callback !== undef) { - break; - } - } - } - - // If event array got empty, remove it - if (!type.length) { - delete eventhash[obj[uid]][name]; - } - - // If mOxie registry has become empty, remove it - if (Basic.isEmptyObj(eventhash[obj[uid]])) { - delete eventhash[obj[uid]]; - - // IE doesn't let you remove DOM object property with - delete - try { - delete obj[uid]; - } catch(e) { - obj[uid] = undef; - } - } - }; - - - /** - Remove all kind of events from the specified object - - @method removeAllEvents - @static - @param {Object} obj DOM element to remove event listeners from. - @param {String} [key] unique key to match, when removing events. - */ - var removeAllEvents = function(obj, key) { - if (!obj || !obj[uid]) { - return; - } - - Basic.each(eventhash[obj[uid]], function(events, name) { - removeEvent(obj, name, key); - }); - }; - - return { - addEvent: addEvent, - removeEvent: removeEvent, - removeAllEvents: removeAllEvents - }; -}); - -// Included from: src/javascript/runtime/html5/file/FileInput.js - -/** - * FileInput.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/file/FileInput -@private -*/ -define("moxie/runtime/html5/file/FileInput", [ - "moxie/runtime/html5/Runtime", - "moxie/core/utils/Basic", - "moxie/core/utils/Dom", - "moxie/core/utils/Events", - "moxie/core/utils/Mime", - "moxie/core/utils/Env" -], function(extensions, Basic, Dom, Events, Mime, Env) { - - function FileInput() { - var _files = [], _options; - - Basic.extend(this, { - init: function(options) { - var comp = this, I = comp.getRuntime(), input, shimContainer, mimes, browseButton, zIndex, top; - - _options = options; - _files = []; - - // figure out accept string - mimes = _options.accept.mimes || Mime.extList2mimes(_options.accept, I.can('filter_by_extension')); - - shimContainer = I.getShimContainer(); - - shimContainer.innerHTML = ''; - - input = Dom.get(I.uid); - - // prepare file input to be placed underneath the browse_button element - Basic.extend(input.style, { - position: 'absolute', - top: 0, - left: 0, - width: '100%', - height: '100%' - }); - - - browseButton = Dom.get(_options.browse_button); - - // Route click event to the input[type=file] element for browsers that support such behavior - if (I.can('summon_file_dialog')) { - if (Dom.getStyle(browseButton, 'position') === 'static') { - browseButton.style.position = 'relative'; - } - - zIndex = parseInt(Dom.getStyle(browseButton, 'z-index'), 10) || 1; - - browseButton.style.zIndex = zIndex; - shimContainer.style.zIndex = zIndex - 1; - - Events.addEvent(browseButton, 'click', function(e) { - var input = Dom.get(I.uid); - if (input && !input.disabled) { // for some reason FF (up to 8.0.1 so far) lets to click disabled input[type=file] - input.click(); - } - e.preventDefault(); - }, comp.uid); - } - - /* Since we have to place input[type=file] on top of the browse_button for some browsers, - browse_button loses interactivity, so we restore it here */ - top = I.can('summon_file_dialog') ? browseButton : shimContainer; - - Events.addEvent(top, 'mouseover', function() { - comp.trigger('mouseenter'); - }, comp.uid); - - Events.addEvent(top, 'mouseout', function() { - comp.trigger('mouseleave'); - }, comp.uid); - - Events.addEvent(top, 'mousedown', function() { - comp.trigger('mousedown'); - }, comp.uid); - - Events.addEvent(Dom.get(_options.container), 'mouseup', function() { - comp.trigger('mouseup'); - }, comp.uid); - - - input.onchange = function onChange() { // there should be only one handler for this - _files = []; - - if (_options.directory) { - // folders are represented by dots, filter them out (Chrome 11+) - Basic.each(this.files, function(file) { - if (file.name !== ".") { // if it doesn't looks like a folder - _files.push(file); - } - }); - } else { - _files = [].slice.call(this.files); - } - - // clearing the value enables the user to select the same file again if they want to - if (Env.browser !== 'IE') { - this.value = ''; - } else { - // in IE input[type="file"] is read-only so the only way to reset it is to re-insert it - var clone = this.cloneNode(true); - this.parentNode.replaceChild(clone, this); - clone.onchange = onChange; - } - comp.trigger('change'); - }; - - // ready event is perfectly asynchronous - comp.trigger({ - type: 'ready', - async: true - }); - - shimContainer = null; - }, - - getFiles: function() { - return _files; - }, - - disable: function(state) { - var I = this.getRuntime(), input; - - if ((input = Dom.get(I.uid))) { - input.disabled = !!state; - } - }, - - destroy: function() { - var I = this.getRuntime() - , shim = I.getShim() - , shimContainer = I.getShimContainer() - ; - - Events.removeAllEvents(shimContainer, this.uid); - Events.removeAllEvents(_options && Dom.get(_options.container), this.uid); - Events.removeAllEvents(_options && Dom.get(_options.browse_button), this.uid); - - if (shimContainer) { - shimContainer.innerHTML = ''; - } - - shim.removeInstance(this.uid); - - _files = _options = shimContainer = shim = null; - } - }); - } - - return (extensions.FileInput = FileInput); -}); - -// Included from: src/javascript/runtime/html5/file/FileDrop.js - -/** - * FileDrop.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/file/FileDrop -@private -*/ -define("moxie/runtime/html5/file/FileDrop", [ - "moxie/runtime/html5/Runtime", - "moxie/core/utils/Basic", - "moxie/core/utils/Dom", - "moxie/core/utils/Events", - "moxie/core/utils/Mime" -], function(extensions, Basic, Dom, Events, Mime) { - - function FileDrop() { - var _files = [], _allowedExts = [], _options; - - Basic.extend(this, { - init: function(options) { - var comp = this, dropZone; - - _options = options; - _allowedExts = _extractExts(_options.accept); - dropZone = _options.container; - - Events.addEvent(dropZone, 'dragover', function(e) { - e.preventDefault(); - e.stopPropagation(); - e.dataTransfer.dropEffect = 'copy'; - }, comp.uid); - - Events.addEvent(dropZone, 'drop', function(e) { - e.preventDefault(); - e.stopPropagation(); - - _files = []; - - // Chrome 21+ accepts folders via Drag'n'Drop - if (e.dataTransfer.items && e.dataTransfer.items[0].webkitGetAsEntry) { - _readItems(e.dataTransfer.items, function() { - comp.trigger("drop"); - }); - } else { - Basic.each(e.dataTransfer.files, function(file) { - if (_isAcceptable(file)) { - _files.push(file); - } - }); - comp.trigger("drop"); - } - }, comp.uid); - - Events.addEvent(dropZone, 'dragenter', function(e) { - e.preventDefault(); - e.stopPropagation(); - comp.trigger("dragenter"); - }, comp.uid); - - Events.addEvent(dropZone, 'dragleave', function(e) { - e.preventDefault(); - e.stopPropagation(); - comp.trigger("dragleave"); - }, comp.uid); - }, - - getFiles: function() { - return _files; - }, - - destroy: function() { - Events.removeAllEvents(_options && Dom.get(_options.container), this.uid); - _files = _allowedExts = _options = null; - } - }); - - - function _extractExts(accept) { - var exts = []; - for (var i = 0; i < accept.length; i++) { - [].push.apply(exts, accept[i].extensions.split(/\s*,\s*/)); - } - return Basic.inArray('*', exts) === -1 ? exts : []; - } - - - function _isAcceptable(file) { - var ext = Mime.getFileExtension(file.name); - return !ext || !_allowedExts.length || Basic.inArray(ext, _allowedExts) !== -1; - } - - - function _readItems(items, cb) { - var entries = []; - Basic.each(items, function(item) { - var entry = item.webkitGetAsEntry(); - // Address #998 (https://code.google.com/p/chromium/issues/detail?id=332579) - if (entry) { - // file() fails on OSX when the filename contains a special character (e.g. umlaut): see #61 - if (entry.isFile) { - var file = item.getAsFile(); - if (_isAcceptable(file)) { - _files.push(file); - } - } else { - entries.push(entry); - } - } - }); - - if (entries.length) { - _readEntries(entries, cb); - } else { - cb(); - } - } - - - function _readEntries(entries, cb) { - var queue = []; - Basic.each(entries, function(entry) { - queue.push(function(cbcb) { - _readEntry(entry, cbcb); - }); - }); - Basic.inSeries(queue, function() { - cb(); - }); - } - - function _readEntry(entry, cb) { - if (entry.isFile) { - entry.file(function(file) { - if (_isAcceptable(file)) { - _files.push(file); - } - cb(); - }, function() { - // fire an error event maybe - cb(); - }); - } else if (entry.isDirectory) { - _readDirEntry(entry, cb); - } else { - cb(); // not file, not directory? what then?.. - } - } - - function _readDirEntry(dirEntry, cb) { - var entries = [], dirReader = dirEntry.createReader(); - - // keep quering recursively till no more entries - function getEntries(cbcb) { - dirReader.readEntries(function(moreEntries) { - if (moreEntries.length) { - [].push.apply(entries, moreEntries); - getEntries(cbcb); - } else { - cbcb(); - } - }, cbcb); - } - - // ...and you thought FileReader was crazy... - getEntries(function() { - _readEntries(entries, cb); - }); - } - } - - return (extensions.FileDrop = FileDrop); -}); - -// Included from: src/javascript/runtime/html5/file/FileReader.js - -/** - * FileReader.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/file/FileReader -@private -*/ -define("moxie/runtime/html5/file/FileReader", [ - "moxie/runtime/html5/Runtime", - "moxie/core/utils/Encode", - "moxie/core/utils/Basic" -], function(extensions, Encode, Basic) { - - function FileReader() { - var _fr, _convertToBinary = false; - - Basic.extend(this, { - - read: function(op, blob) { - var target = this; - - _fr = new window.FileReader(); - - _fr.addEventListener('progress', function(e) { - target.trigger(e); - }); - - _fr.addEventListener('load', function(e) { - target.trigger(e); - }); - - _fr.addEventListener('error', function(e) { - target.trigger(e, _fr.error); - }); - - _fr.addEventListener('loadend', function() { - _fr = null; - }); - - if (Basic.typeOf(_fr[op]) === 'function') { - _convertToBinary = false; - _fr[op](blob.getSource()); - } else if (op === 'readAsBinaryString') { // readAsBinaryString is depricated in general and never existed in IE10+ - _convertToBinary = true; - _fr.readAsDataURL(blob.getSource()); - } - }, - - getResult: function() { - return _fr && _fr.result ? (_convertToBinary ? _toBinary(_fr.result) : _fr.result) : null; - }, - - abort: function() { - if (_fr) { - _fr.abort(); - } - }, - - destroy: function() { - _fr = null; - } - }); - - function _toBinary(str) { - return Encode.atob(str.substring(str.indexOf('base64,') + 7)); - } - } - - return (extensions.FileReader = FileReader); -}); - -// Included from: src/javascript/runtime/html5/xhr/XMLHttpRequest.js - -/** - * XMLHttpRequest.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/*global ActiveXObject:true */ - -/** -@class moxie/runtime/html5/xhr/XMLHttpRequest -@private -*/ -define("moxie/runtime/html5/xhr/XMLHttpRequest", [ - "moxie/runtime/html5/Runtime", - "moxie/core/utils/Basic", - "moxie/core/utils/Mime", - "moxie/core/utils/Url", - "moxie/file/File", - "moxie/file/Blob", - "moxie/xhr/FormData", - "moxie/core/Exceptions", - "moxie/core/utils/Env" -], function(extensions, Basic, Mime, Url, File, Blob, FormData, x, Env) { - - function XMLHttpRequest() { - var self = this - , _xhr - , _filename - ; - - Basic.extend(this, { - send: function(meta, data) { - var target = this - , isGecko2_5_6 = (Env.browser === 'Mozilla' && Env.version >= 4 && Env.version < 7) - , isAndroidBrowser = Env.browser === 'Android Browser' - , mustSendAsBinary = false - ; - - // extract file name - _filename = meta.url.replace(/^.+?\/([\w\-\.]+)$/, '$1').toLowerCase(); - - _xhr = _getNativeXHR(); - _xhr.open(meta.method, meta.url, meta.async, meta.user, meta.password); - - - // prepare data to be sent - if (data instanceof Blob) { - if (data.isDetached()) { - mustSendAsBinary = true; - } - data = data.getSource(); - } else if (data instanceof FormData) { - - if (data.hasBlob()) { - if (data.getBlob().isDetached()) { - data = _prepareMultipart.call(target, data); // _xhr must be instantiated and be in OPENED state - mustSendAsBinary = true; - } else if ((isGecko2_5_6 || isAndroidBrowser) && Basic.typeOf(data.getBlob().getSource()) === 'blob' && window.FileReader) { - // Gecko 2/5/6 can't send blob in FormData: https://bugzilla.mozilla.org/show_bug.cgi?id=649150 - // Android browsers (default one and Dolphin) seem to have the same issue, see: #613 - _preloadAndSend.call(target, meta, data); - return; // _preloadAndSend will reinvoke send() with transmutated FormData =%D - } - } - - // transfer fields to real FormData - if (data instanceof FormData) { // if still a FormData, e.g. not mangled by _prepareMultipart() - var fd = new window.FormData(); - data.each(function(value, name) { - if (value instanceof Blob) { - fd.append(name, value.getSource()); - } else { - fd.append(name, value); - } - }); - data = fd; - } - } - - - // if XHR L2 - if (_xhr.upload) { - if (meta.withCredentials) { - _xhr.withCredentials = true; - } - - _xhr.addEventListener('load', function(e) { - target.trigger(e); - }); - - _xhr.addEventListener('error', function(e) { - target.trigger(e); - }); - - // additionally listen to progress events - _xhr.addEventListener('progress', function(e) { - target.trigger(e); - }); - - _xhr.upload.addEventListener('progress', function(e) { - target.trigger({ - type: 'UploadProgress', - loaded: e.loaded, - total: e.total - }); - }); - // ... otherwise simulate XHR L2 - } else { - _xhr.onreadystatechange = function onReadyStateChange() { - - // fake Level 2 events - switch (_xhr.readyState) { - - case 1: // XMLHttpRequest.OPENED - // readystatechanged is fired twice for OPENED state (in IE and Mozilla) - neu - break; - - // looks like HEADERS_RECEIVED (state 2) is not reported in Opera (or it's old versions) - neu - case 2: // XMLHttpRequest.HEADERS_RECEIVED - break; - - case 3: // XMLHttpRequest.LOADING - // try to fire progress event for not XHR L2 - var total, loaded; - - try { - if (Url.hasSameOrigin(meta.url)) { // Content-Length not accessible for cross-domain on some browsers - total = _xhr.getResponseHeader('Content-Length') || 0; // old Safari throws an exception here - } - - if (_xhr.responseText) { // responseText was introduced in IE7 - loaded = _xhr.responseText.length; - } - } catch(ex) { - total = loaded = 0; - } - - target.trigger({ - type: 'progress', - lengthComputable: !!total, - total: parseInt(total, 10), - loaded: loaded - }); - break; - - case 4: // XMLHttpRequest.DONE - // release readystatechange handler (mostly for IE) - _xhr.onreadystatechange = function() {}; - - // usually status 0 is returned when server is unreachable, but FF also fails to status 0 for 408 timeout - if (_xhr.status === 0) { - target.trigger('error'); - } else { - target.trigger('load'); - } - break; - } - }; - } - - - // set request headers - if (!Basic.isEmptyObj(meta.headers)) { - Basic.each(meta.headers, function(value, header) { - _xhr.setRequestHeader(header, value); - }); - } - - // request response type - if ("" !== meta.responseType && 'responseType' in _xhr) { - if ('json' === meta.responseType && !Env.can('return_response_type', 'json')) { // we can fake this one - _xhr.responseType = 'text'; - } else { - _xhr.responseType = meta.responseType; - } - } - - // send ... - if (!mustSendAsBinary) { - _xhr.send(data); - } else { - if (_xhr.sendAsBinary) { // Gecko - _xhr.sendAsBinary(data); - } else { // other browsers having support for typed arrays - (function() { - // mimic Gecko's sendAsBinary - var ui8a = new Uint8Array(data.length); - for (var i = 0; i < data.length; i++) { - ui8a[i] = (data.charCodeAt(i) & 0xff); - } - _xhr.send(ui8a.buffer); - }()); - } - } - - target.trigger('loadstart'); - }, - - getStatus: function() { - // according to W3C spec it should return 0 for readyState < 3, but instead it throws an exception - try { - if (_xhr) { - return _xhr.status; - } - } catch(ex) {} - return 0; - }, - - getResponse: function(responseType) { - var I = this.getRuntime(); - - try { - switch (responseType) { - case 'blob': - var file = new File(I.uid, _xhr.response); - - // try to extract file name from content-disposition if possible (might be - not, if CORS for example) - var disposition = _xhr.getResponseHeader('Content-Disposition'); - if (disposition) { - // extract filename from response header if available - var match = disposition.match(/filename=([\'\"'])([^\1]+)\1/); - if (match) { - _filename = match[2]; - } - } - file.name = _filename; - - // pre-webkit Opera doesn't set type property on the blob response - if (!file.type) { - file.type = Mime.getFileMime(_filename); - } - return file; - - case 'json': - if (!Env.can('return_response_type', 'json')) { - return _xhr.status === 200 && !!window.JSON ? JSON.parse(_xhr.responseText) : null; - } - return _xhr.response; - - case 'document': - return _getDocument(_xhr); - - default: - return _xhr.responseText !== '' ? _xhr.responseText : null; // against the specs, but for consistency across the runtimes - } - } catch(ex) { - return null; - } - }, - - getAllResponseHeaders: function() { - try { - return _xhr.getAllResponseHeaders(); - } catch(ex) {} - return ''; - }, - - abort: function() { - if (_xhr) { - _xhr.abort(); - } - }, - - destroy: function() { - self = _filename = null; - } - }); - - - // here we go... ugly fix for ugly bug - function _preloadAndSend(meta, data) { - var target = this, blob, fr; - - // get original blob - blob = data.getBlob().getSource(); - - // preload blob in memory to be sent as binary string - fr = new window.FileReader(); - fr.onload = function() { - // overwrite original blob - data.append(data.getBlobName(), new Blob(null, { - type: blob.type, - data: fr.result - })); - // invoke send operation again - self.send.call(target, meta, data); - }; - fr.readAsBinaryString(blob); - } - - - function _getNativeXHR() { - if (window.XMLHttpRequest && !(Env.browser === 'IE' && Env.version < 8)) { // IE7 has native XHR but it's buggy - return new window.XMLHttpRequest(); - } else { - return (function() { - var progIDs = ['Msxml2.XMLHTTP.6.0', 'Microsoft.XMLHTTP']; // if 6.0 available, use it, otherwise failback to default 3.0 - for (var i = 0; i < progIDs.length; i++) { - try { - return new ActiveXObject(progIDs[i]); - } catch (ex) {} - } - })(); - } - } - - // @credits Sergey Ilinsky (http://www.ilinsky.com/) - function _getDocument(xhr) { - var rXML = xhr.responseXML; - var rText = xhr.responseText; - - // Try parsing responseText (@see: http://www.ilinsky.com/articles/XMLHttpRequest/#bugs-ie-responseXML-content-type) - if (Env.browser === 'IE' && rText && rXML && !rXML.documentElement && /[^\/]+\/[^\+]+\+xml/.test(xhr.getResponseHeader("Content-Type"))) { - rXML = new window.ActiveXObject("Microsoft.XMLDOM"); - rXML.async = false; - rXML.validateOnParse = false; - rXML.loadXML(rText); - } - - // Check if there is no error in document - if (rXML) { - if ((Env.browser === 'IE' && rXML.parseError !== 0) || !rXML.documentElement || rXML.documentElement.tagName === "parsererror") { - return null; - } - } - return rXML; - } - - - function _prepareMultipart(fd) { - var boundary = '----moxieboundary' + new Date().getTime() - , dashdash = '--' - , crlf = '\r\n' - , multipart = '' - , I = this.getRuntime() - ; - - if (!I.can('send_binary_string')) { - throw new x.RuntimeError(x.RuntimeError.NOT_SUPPORTED_ERR); - } - - _xhr.setRequestHeader('Content-Type', 'multipart/form-data; boundary=' + boundary); - - // append multipart parameters - fd.each(function(value, name) { - // Firefox 3.6 failed to convert multibyte characters to UTF-8 in sendAsBinary(), - // so we try it here ourselves with: unescape(encodeURIComponent(value)) - if (value instanceof Blob) { - // Build RFC2388 blob - multipart += dashdash + boundary + crlf + - 'Content-Disposition: form-data; name="' + name + '"; filename="' + unescape(encodeURIComponent(value.name || 'blob')) + '"' + crlf + - 'Content-Type: ' + (value.type || 'application/octet-stream') + crlf + crlf + - value.getSource() + crlf; - } else { - multipart += dashdash + boundary + crlf + - 'Content-Disposition: form-data; name="' + name + '"' + crlf + crlf + - unescape(encodeURIComponent(value)) + crlf; - } - }); - - multipart += dashdash + boundary + dashdash + crlf; - - return multipart; - } - } - - return (extensions.XMLHttpRequest = XMLHttpRequest); -}); - -// Included from: src/javascript/runtime/html5/utils/BinaryReader.js - -/** - * BinaryReader.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/utils/BinaryReader -@private -*/ -define("moxie/runtime/html5/utils/BinaryReader", [], function() { - return function() { - var II = false, bin; - - // Private functions - function read(idx, size) { - var mv = II ? 0 : -8 * (size - 1), sum = 0, i; - - for (i = 0; i < size; i++) { - sum |= (bin.charCodeAt(idx + i) << Math.abs(mv + i*8)); - } - - return sum; - } - - function putstr(segment, idx, length) { - length = arguments.length === 3 ? length : bin.length - idx - 1; - bin = bin.substr(0, idx) + segment + bin.substr(length + idx); - } - - function write(idx, num, size) { - var str = '', mv = II ? 0 : -8 * (size - 1), i; - - for (i = 0; i < size; i++) { - str += String.fromCharCode((num >> Math.abs(mv + i*8)) & 255); - } - - putstr(str, idx, size); - } - - // Public functions - return { - II: function(order) { - if (order === undefined) { - return II; - } else { - II = order; - } - }, - - init: function(binData) { - II = false; - bin = binData; - }, - - SEGMENT: function(idx, length, segment) { - switch (arguments.length) { - case 1: - return bin.substr(idx, bin.length - idx - 1); - case 2: - return bin.substr(idx, length); - case 3: - putstr(segment, idx, length); - break; - default: return bin; - } - }, - - BYTE: function(idx) { - return read(idx, 1); - }, - - SHORT: function(idx) { - return read(idx, 2); - }, - - LONG: function(idx, num) { - if (num === undefined) { - return read(idx, 4); - } else { - write(idx, num, 4); - } - }, - - SLONG: function(idx) { // 2's complement notation - var num = read(idx, 4); - - return (num > 2147483647 ? num - 4294967296 : num); - }, - - STRING: function(idx, size) { - var str = ''; - - for (size += idx; idx < size; idx++) { - str += String.fromCharCode(read(idx, 1)); - } - - return str; - } - }; - }; -}); - -// Included from: src/javascript/runtime/html5/image/JPEGHeaders.js - -/** - * JPEGHeaders.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/image/JPEGHeaders -@private -*/ -define("moxie/runtime/html5/image/JPEGHeaders", [ - "moxie/runtime/html5/utils/BinaryReader" -], function(BinaryReader) { - - return function JPEGHeaders(data) { - var headers = [], read, idx, marker, length = 0; - - read = new BinaryReader(); - read.init(data); - - // Check if data is jpeg - if (read.SHORT(0) !== 0xFFD8) { - return; - } - - idx = 2; - - while (idx <= data.length) { - marker = read.SHORT(idx); - - // omit RST (restart) markers - if (marker >= 0xFFD0 && marker <= 0xFFD7) { - idx += 2; - continue; - } - - // no headers allowed after SOS marker - if (marker === 0xFFDA || marker === 0xFFD9) { - break; - } - - length = read.SHORT(idx + 2) + 2; - - // APPn marker detected - if (marker >= 0xFFE1 && marker <= 0xFFEF) { - headers.push({ - hex: marker, - name: 'APP' + (marker & 0x000F), - start: idx, - length: length, - segment: read.SEGMENT(idx, length) - }); - } - - idx += length; - } - - read.init(null); // free memory - - return { - headers: headers, - - restore: function(data) { - var max, i; - - read.init(data); - - idx = read.SHORT(2) == 0xFFE0 ? 4 + read.SHORT(4) : 2; - - for (i = 0, max = headers.length; i < max; i++) { - read.SEGMENT(idx, 0, headers[i].segment); - idx += headers[i].length; - } - - data = read.SEGMENT(); - read.init(null); - return data; - }, - - strip: function(data) { - var headers, jpegHeaders, i; - - jpegHeaders = new JPEGHeaders(data); - headers = jpegHeaders.headers; - jpegHeaders.purge(); - - read.init(data); - - i = headers.length; - while (i--) { - read.SEGMENT(headers[i].start, headers[i].length, ''); - } - - data = read.SEGMENT(); - read.init(null); - return data; - }, - - get: function(name) { - var array = []; - - for (var i = 0, max = headers.length; i < max; i++) { - if (headers[i].name === name.toUpperCase()) { - array.push(headers[i].segment); - } - } - return array; - }, - - set: function(name, segment) { - var array = [], i, ii, max; - - if (typeof(segment) === 'string') { - array.push(segment); - } else { - array = segment; - } - - for (i = ii = 0, max = headers.length; i < max; i++) { - if (headers[i].name === name.toUpperCase()) { - headers[i].segment = array[ii]; - headers[i].length = array[ii].length; - ii++; - } - if (ii >= array.length) { - break; - } - } - }, - - purge: function() { - headers = []; - read.init(null); - read = null; - } - }; - }; -}); - -// Included from: src/javascript/runtime/html5/image/ExifParser.js - -/** - * ExifParser.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/image/ExifParser -@private -*/ -define("moxie/runtime/html5/image/ExifParser", [ - "moxie/core/utils/Basic", - "moxie/runtime/html5/utils/BinaryReader" -], function(Basic, BinaryReader) { - - return function ExifParser() { - // Private ExifParser fields - var data, tags, Tiff, offsets = {}, tagDescs; - - data = new BinaryReader(); - - tags = { - tiff : { - /* - The image orientation viewed in terms of rows and columns. - - 1 = The 0th row is at the visual top of the image, and the 0th column is the visual left-hand side. - 2 = The 0th row is at the visual top of the image, and the 0th column is the visual right-hand side. - 3 = The 0th row is at the visual bottom of the image, and the 0th column is the visual right-hand side. - 4 = The 0th row is at the visual bottom of the image, and the 0th column is the visual left-hand side. - 5 = The 0th row is the visual left-hand side of the image, and the 0th column is the visual top. - 6 = The 0th row is the visual right-hand side of the image, and the 0th column is the visual top. - 7 = The 0th row is the visual right-hand side of the image, and the 0th column is the visual bottom. - 8 = The 0th row is the visual left-hand side of the image, and the 0th column is the visual bottom. - */ - 0x0112: 'Orientation', - 0x010E: 'ImageDescription', - 0x010F: 'Make', - 0x0110: 'Model', - 0x0131: 'Software', - 0x8769: 'ExifIFDPointer', - 0x8825: 'GPSInfoIFDPointer' - }, - exif : { - 0x9000: 'ExifVersion', - 0xA001: 'ColorSpace', - 0xA002: 'PixelXDimension', - 0xA003: 'PixelYDimension', - 0x9003: 'DateTimeOriginal', - 0x829A: 'ExposureTime', - 0x829D: 'FNumber', - 0x8827: 'ISOSpeedRatings', - 0x9201: 'ShutterSpeedValue', - 0x9202: 'ApertureValue' , - 0x9207: 'MeteringMode', - 0x9208: 'LightSource', - 0x9209: 'Flash', - 0x920A: 'FocalLength', - 0xA402: 'ExposureMode', - 0xA403: 'WhiteBalance', - 0xA406: 'SceneCaptureType', - 0xA404: 'DigitalZoomRatio', - 0xA408: 'Contrast', - 0xA409: 'Saturation', - 0xA40A: 'Sharpness' - }, - gps : { - 0x0000: 'GPSVersionID', - 0x0001: 'GPSLatitudeRef', - 0x0002: 'GPSLatitude', - 0x0003: 'GPSLongitudeRef', - 0x0004: 'GPSLongitude' - } - }; - - tagDescs = { - 'ColorSpace': { - 1: 'sRGB', - 0: 'Uncalibrated' - }, - - 'MeteringMode': { - 0: 'Unknown', - 1: 'Average', - 2: 'CenterWeightedAverage', - 3: 'Spot', - 4: 'MultiSpot', - 5: 'Pattern', - 6: 'Partial', - 255: 'Other' - }, - - 'LightSource': { - 1: 'Daylight', - 2: 'Fliorescent', - 3: 'Tungsten', - 4: 'Flash', - 9: 'Fine weather', - 10: 'Cloudy weather', - 11: 'Shade', - 12: 'Daylight fluorescent (D 5700 - 7100K)', - 13: 'Day white fluorescent (N 4600 -5400K)', - 14: 'Cool white fluorescent (W 3900 - 4500K)', - 15: 'White fluorescent (WW 3200 - 3700K)', - 17: 'Standard light A', - 18: 'Standard light B', - 19: 'Standard light C', - 20: 'D55', - 21: 'D65', - 22: 'D75', - 23: 'D50', - 24: 'ISO studio tungsten', - 255: 'Other' - }, - - 'Flash': { - 0x0000: 'Flash did not fire.', - 0x0001: 'Flash fired.', - 0x0005: 'Strobe return light not detected.', - 0x0007: 'Strobe return light detected.', - 0x0009: 'Flash fired, compulsory flash mode', - 0x000D: 'Flash fired, compulsory flash mode, return light not detected', - 0x000F: 'Flash fired, compulsory flash mode, return light detected', - 0x0010: 'Flash did not fire, compulsory flash mode', - 0x0018: 'Flash did not fire, auto mode', - 0x0019: 'Flash fired, auto mode', - 0x001D: 'Flash fired, auto mode, return light not detected', - 0x001F: 'Flash fired, auto mode, return light detected', - 0x0020: 'No flash function', - 0x0041: 'Flash fired, red-eye reduction mode', - 0x0045: 'Flash fired, red-eye reduction mode, return light not detected', - 0x0047: 'Flash fired, red-eye reduction mode, return light detected', - 0x0049: 'Flash fired, compulsory flash mode, red-eye reduction mode', - 0x004D: 'Flash fired, compulsory flash mode, red-eye reduction mode, return light not detected', - 0x004F: 'Flash fired, compulsory flash mode, red-eye reduction mode, return light detected', - 0x0059: 'Flash fired, auto mode, red-eye reduction mode', - 0x005D: 'Flash fired, auto mode, return light not detected, red-eye reduction mode', - 0x005F: 'Flash fired, auto mode, return light detected, red-eye reduction mode' - }, - - 'ExposureMode': { - 0: 'Auto exposure', - 1: 'Manual exposure', - 2: 'Auto bracket' - }, - - 'WhiteBalance': { - 0: 'Auto white balance', - 1: 'Manual white balance' - }, - - 'SceneCaptureType': { - 0: 'Standard', - 1: 'Landscape', - 2: 'Portrait', - 3: 'Night scene' - }, - - 'Contrast': { - 0: 'Normal', - 1: 'Soft', - 2: 'Hard' - }, - - 'Saturation': { - 0: 'Normal', - 1: 'Low saturation', - 2: 'High saturation' - }, - - 'Sharpness': { - 0: 'Normal', - 1: 'Soft', - 2: 'Hard' - }, - - // GPS related - 'GPSLatitudeRef': { - N: 'North latitude', - S: 'South latitude' - }, - - 'GPSLongitudeRef': { - E: 'East longitude', - W: 'West longitude' - } - }; - - function extractTags(IFD_offset, tags2extract) { - var length = data.SHORT(IFD_offset), i, ii, - tag, type, count, tagOffset, offset, value, values = [], hash = {}; - - for (i = 0; i < length; i++) { - // Set binary reader pointer to beginning of the next tag - offset = tagOffset = IFD_offset + 12 * i + 2; - - tag = tags2extract[data.SHORT(offset)]; - - if (tag === undefined) { - continue; // Not the tag we requested - } - - type = data.SHORT(offset+=2); - count = data.LONG(offset+=2); - - offset += 4; - values = []; - - switch (type) { - case 1: // BYTE - case 7: // UNDEFINED - if (count > 4) { - offset = data.LONG(offset) + offsets.tiffHeader; - } - - for (ii = 0; ii < count; ii++) { - values[ii] = data.BYTE(offset + ii); - } - - break; - - case 2: // STRING - if (count > 4) { - offset = data.LONG(offset) + offsets.tiffHeader; - } - - hash[tag] = data.STRING(offset, count - 1); - - continue; - - case 3: // SHORT - if (count > 2) { - offset = data.LONG(offset) + offsets.tiffHeader; - } - - for (ii = 0; ii < count; ii++) { - values[ii] = data.SHORT(offset + ii*2); - } - - break; - - case 4: // LONG - if (count > 1) { - offset = data.LONG(offset) + offsets.tiffHeader; - } - - for (ii = 0; ii < count; ii++) { - values[ii] = data.LONG(offset + ii*4); - } - - break; - - case 5: // RATIONAL - offset = data.LONG(offset) + offsets.tiffHeader; - - for (ii = 0; ii < count; ii++) { - values[ii] = data.LONG(offset + ii*4) / data.LONG(offset + ii*4 + 4); - } - - break; - - case 9: // SLONG - offset = data.LONG(offset) + offsets.tiffHeader; - - for (ii = 0; ii < count; ii++) { - values[ii] = data.SLONG(offset + ii*4); - } - - break; - - case 10: // SRATIONAL - offset = data.LONG(offset) + offsets.tiffHeader; - - for (ii = 0; ii < count; ii++) { - values[ii] = data.SLONG(offset + ii*4) / data.SLONG(offset + ii*4 + 4); - } - - break; - - default: - continue; - } - - value = (count == 1 ? values[0] : values); - - if (tagDescs.hasOwnProperty(tag) && typeof value != 'object') { - hash[tag] = tagDescs[tag][value]; - } else { - hash[tag] = value; - } - } - - return hash; - } - - function getIFDOffsets() { - var idx = offsets.tiffHeader; - - // Set read order of multi-byte data - data.II(data.SHORT(idx) == 0x4949); - - // Check if always present bytes are indeed present - if (data.SHORT(idx+=2) !== 0x002A) { - return false; - } - - offsets.IFD0 = offsets.tiffHeader + data.LONG(idx += 2); - Tiff = extractTags(offsets.IFD0, tags.tiff); - - if ('ExifIFDPointer' in Tiff) { - offsets.exifIFD = offsets.tiffHeader + Tiff.ExifIFDPointer; - delete Tiff.ExifIFDPointer; - } - - if ('GPSInfoIFDPointer' in Tiff) { - offsets.gpsIFD = offsets.tiffHeader + Tiff.GPSInfoIFDPointer; - delete Tiff.GPSInfoIFDPointer; - } - return true; - } - - // At the moment only setting of simple (LONG) values, that do not require offset recalculation, is supported - function setTag(ifd, tag, value) { - var offset, length, tagOffset, valueOffset = 0; - - // If tag name passed translate into hex key - if (typeof(tag) === 'string') { - var tmpTags = tags[ifd.toLowerCase()]; - for (var hex in tmpTags) { - if (tmpTags[hex] === tag) { - tag = hex; - break; - } - } - } - offset = offsets[ifd.toLowerCase() + 'IFD']; - length = data.SHORT(offset); - - for (var i = 0; i < length; i++) { - tagOffset = offset + 12 * i + 2; - - if (data.SHORT(tagOffset) == tag) { - valueOffset = tagOffset + 8; - break; - } - } - - if (!valueOffset) { - return false; - } - - data.LONG(valueOffset, value); - return true; - } - - - // Public functions - return { - init: function(segment) { - // Reset internal data - offsets = { - tiffHeader: 10 - }; - - if (segment === undefined || !segment.length) { - return false; - } - - data.init(segment); - - // Check if that's APP1 and that it has EXIF - if (data.SHORT(0) === 0xFFE1 && data.STRING(4, 5).toUpperCase() === "EXIF\0") { - return getIFDOffsets(); - } - return false; - }, - - TIFF: function() { - return Tiff; - }, - - EXIF: function() { - var Exif; - - // Populate EXIF hash - Exif = extractTags(offsets.exifIFD, tags.exif); - - // Fix formatting of some tags - if (Exif.ExifVersion && Basic.typeOf(Exif.ExifVersion) === 'array') { - for (var i = 0, exifVersion = ''; i < Exif.ExifVersion.length; i++) { - exifVersion += String.fromCharCode(Exif.ExifVersion[i]); - } - Exif.ExifVersion = exifVersion; - } - - return Exif; - }, - - GPS: function() { - var GPS; - - GPS = extractTags(offsets.gpsIFD, tags.gps); - - // iOS devices (and probably some others) do not put in GPSVersionID tag (why?..) - if (GPS.GPSVersionID && Basic.typeOf(GPS.GPSVersionID) === 'array') { - GPS.GPSVersionID = GPS.GPSVersionID.join('.'); - } - - return GPS; - }, - - setExif: function(tag, value) { - // Right now only setting of width/height is possible - if (tag !== 'PixelXDimension' && tag !== 'PixelYDimension') {return false;} - - return setTag('exif', tag, value); - }, - - - getBinary: function() { - return data.SEGMENT(); - }, - - purge: function() { - data.init(null); - data = Tiff = null; - offsets = {}; - } - }; - }; -}); - -// Included from: src/javascript/runtime/html5/image/JPEG.js - -/** - * JPEG.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/image/JPEG -@private -*/ -define("moxie/runtime/html5/image/JPEG", [ - "moxie/core/utils/Basic", - "moxie/core/Exceptions", - "moxie/runtime/html5/image/JPEGHeaders", - "moxie/runtime/html5/utils/BinaryReader", - "moxie/runtime/html5/image/ExifParser" -], function(Basic, x, JPEGHeaders, BinaryReader, ExifParser) { - - function JPEG(binstr) { - var _binstr, _br, _hm, _ep, _info, hasExif; - - function _getDimensions() { - var idx = 0, marker, length; - - // examine all through the end, since some images might have very large APP segments - while (idx <= _binstr.length) { - marker = _br.SHORT(idx += 2); - - if (marker >= 0xFFC0 && marker <= 0xFFC3) { // SOFn - idx += 5; // marker (2 bytes) + length (2 bytes) + Sample precision (1 byte) - return { - height: _br.SHORT(idx), - width: _br.SHORT(idx += 2) - }; - } - length = _br.SHORT(idx += 2); - idx += length - 2; - } - return null; - } - - _binstr = binstr; - - _br = new BinaryReader(); - _br.init(_binstr); - - // check if it is jpeg - if (_br.SHORT(0) !== 0xFFD8) { - throw new x.ImageError(x.ImageError.WRONG_FORMAT); - } - - // backup headers - _hm = new JPEGHeaders(binstr); - - // extract exif info - _ep = new ExifParser(); - hasExif = !!_ep.init(_hm.get('app1')[0]); - - // get dimensions - _info = _getDimensions.call(this); - - Basic.extend(this, { - type: 'image/jpeg', - - size: _binstr.length, - - width: _info && _info.width || 0, - - height: _info && _info.height || 0, - - setExif: function(tag, value) { - if (!hasExif) { - return false; // or throw an exception - } - - if (Basic.typeOf(tag) === 'object') { - Basic.each(tag, function(value, tag) { - _ep.setExif(tag, value); - }); - } else { - _ep.setExif(tag, value); - } - - // update internal headers - _hm.set('app1', _ep.getBinary()); - }, - - writeHeaders: function() { - if (!arguments.length) { - // if no arguments passed, update headers internally - return (_binstr = _hm.restore(_binstr)); - } - return _hm.restore(arguments[0]); - }, - - stripHeaders: function(binstr) { - return _hm.strip(binstr); - }, - - purge: function() { - _purge.call(this); - } - }); - - if (hasExif) { - this.meta = { - tiff: _ep.TIFF(), - exif: _ep.EXIF(), - gps: _ep.GPS() - }; - } - - function _purge() { - if (!_ep || !_hm || !_br) { - return; // ignore any repeating purge requests - } - _ep.purge(); - _hm.purge(); - _br.init(null); - _binstr = _info = _hm = _ep = _br = null; - } - } - - return JPEG; -}); - -// Included from: src/javascript/runtime/html5/image/PNG.js - -/** - * PNG.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/image/PNG -@private -*/ -define("moxie/runtime/html5/image/PNG", [ - "moxie/core/Exceptions", - "moxie/core/utils/Basic", - "moxie/runtime/html5/utils/BinaryReader" -], function(x, Basic, BinaryReader) { - - function PNG(binstr) { - var _binstr, _br, _hm, _ep, _info; - - _binstr = binstr; - - _br = new BinaryReader(); - _br.init(_binstr); - - // check if it's png - (function() { - var idx = 0, i = 0 - , signature = [0x8950, 0x4E47, 0x0D0A, 0x1A0A] - ; - - for (i = 0; i < signature.length; i++, idx += 2) { - if (signature[i] != _br.SHORT(idx)) { - throw new x.ImageError(x.ImageError.WRONG_FORMAT); - } - } - }()); - - function _getDimensions() { - var chunk, idx; - - chunk = _getChunkAt.call(this, 8); - - if (chunk.type == 'IHDR') { - idx = chunk.start; - return { - width: _br.LONG(idx), - height: _br.LONG(idx += 4) - }; - } - return null; - } - - function _purge() { - if (!_br) { - return; // ignore any repeating purge requests - } - _br.init(null); - _binstr = _info = _hm = _ep = _br = null; - } - - _info = _getDimensions.call(this); - - Basic.extend(this, { - type: 'image/png', - - size: _binstr.length, - - width: _info.width, - - height: _info.height, - - purge: function() { - _purge.call(this); - } - }); - - // for PNG we can safely trigger purge automatically, as we do not keep any data for later - _purge.call(this); - - function _getChunkAt(idx) { - var length, type, start, CRC; - - length = _br.LONG(idx); - type = _br.STRING(idx += 4, 4); - start = idx += 4; - CRC = _br.LONG(idx + length); - - return { - length: length, - type: type, - start: start, - CRC: CRC - }; - } - } - - return PNG; -}); - -// Included from: src/javascript/runtime/html5/image/ImageInfo.js - -/** - * ImageInfo.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/image/ImageInfo -@private -*/ -define("moxie/runtime/html5/image/ImageInfo", [ - "moxie/core/utils/Basic", - "moxie/core/Exceptions", - "moxie/runtime/html5/image/JPEG", - "moxie/runtime/html5/image/PNG" -], function(Basic, x, JPEG, PNG) { - /** - Optional image investigation tool for HTML5 runtime. Provides the following features: - - ability to distinguish image type (JPEG or PNG) by signature - - ability to extract image width/height directly from it's internals, without preloading in memory (fast) - - ability to extract APP headers from JPEGs (Exif, GPS, etc) - - ability to replace width/height tags in extracted JPEG headers - - ability to restore APP headers, that were for example stripped during image manipulation - - @class ImageInfo - @constructor - @param {String} binstr Image source as binary string - */ - return function(binstr) { - var _cs = [JPEG, PNG], _img; - - // figure out the format, throw: ImageError.WRONG_FORMAT if not supported - _img = (function() { - for (var i = 0; i < _cs.length; i++) { - try { - return new _cs[i](binstr); - } catch (ex) { - // console.info(ex); - } - } - throw new x.ImageError(x.ImageError.WRONG_FORMAT); - }()); - - Basic.extend(this, { - /** - Image Mime Type extracted from it's depths - - @property type - @type {String} - @default '' - */ - type: '', - - /** - Image size in bytes - - @property size - @type {Number} - @default 0 - */ - size: 0, - - /** - Image width extracted from image source - - @property width - @type {Number} - @default 0 - */ - width: 0, - - /** - Image height extracted from image source - - @property height - @type {Number} - @default 0 - */ - height: 0, - - /** - Sets Exif tag. Currently applicable only for width and height tags. Obviously works only with JPEGs. - - @method setExif - @param {String} tag Tag to set - @param {Mixed} value Value to assign to the tag - */ - setExif: function() {}, - - /** - Restores headers to the source. - - @method writeHeaders - @param {String} data Image source as binary string - @return {String} Updated binary string - */ - writeHeaders: function(data) { - return data; - }, - - /** - Strip all headers from the source. - - @method stripHeaders - @param {String} data Image source as binary string - @return {String} Updated binary string - */ - stripHeaders: function(data) { - return data; - }, - - /** - Dispose resources. - - @method purge - */ - purge: function() {} - }); - - Basic.extend(this, _img); - - this.purge = function() { - _img.purge(); - _img = null; - }; - }; -}); - -// Included from: src/javascript/runtime/html5/image/MegaPixel.js - -/** -(The MIT License) - -Copyright (c) 2012 Shinichi Tomita ; - -Permission is hereby granted, free of charge, to any person obtaining -a copy of this software and associated documentation files (the -'Software'), to deal in the Software without restriction, including -without limitation the rights to use, copy, modify, merge, publish, -distribute, sublicense, and/or sell copies of the Software, and to -permit persons to whom the Software is furnished to do so, subject to -the following conditions: - -The above copyright notice and this permission notice shall be -included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, -EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -*/ - -/** - * Mega pixel image rendering library for iOS6 Safari - * - * Fixes iOS6 Safari's image file rendering issue for large size image (over mega-pixel), - * which causes unexpected subsampling when drawing it in canvas. - * By using this library, you can safely render the image with proper stretching. - * - * Copyright (c) 2012 Shinichi Tomita - * Released under the MIT license - */ - -/** -@class moxie/runtime/html5/image/MegaPixel -@private -*/ -define("moxie/runtime/html5/image/MegaPixel", [], function() { - - /** - * Rendering image element (with resizing) into the canvas element - */ - function renderImageToCanvas(img, canvas, options) { - var iw = img.naturalWidth, ih = img.naturalHeight; - var width = options.width, height = options.height; - var x = options.x || 0, y = options.y || 0; - var ctx = canvas.getContext('2d'); - if (detectSubsampling(img)) { - iw /= 2; - ih /= 2; - } - var d = 1024; // size of tiling canvas - var tmpCanvas = document.createElement('canvas'); - tmpCanvas.width = tmpCanvas.height = d; - var tmpCtx = tmpCanvas.getContext('2d'); - var vertSquashRatio = detectVerticalSquash(img, iw, ih); - var sy = 0; - while (sy < ih) { - var sh = sy + d > ih ? ih - sy : d; - var sx = 0; - while (sx < iw) { - var sw = sx + d > iw ? iw - sx : d; - tmpCtx.clearRect(0, 0, d, d); - tmpCtx.drawImage(img, -sx, -sy); - var dx = (sx * width / iw + x) << 0; - var dw = Math.ceil(sw * width / iw); - var dy = (sy * height / ih / vertSquashRatio + y) << 0; - var dh = Math.ceil(sh * height / ih / vertSquashRatio); - ctx.drawImage(tmpCanvas, 0, 0, sw, sh, dx, dy, dw, dh); - sx += d; - } - sy += d; - } - tmpCanvas = tmpCtx = null; - } - - /** - * Detect subsampling in loaded image. - * In iOS, larger images than 2M pixels may be subsampled in rendering. - */ - function detectSubsampling(img) { - var iw = img.naturalWidth, ih = img.naturalHeight; - if (iw * ih > 1024 * 1024) { // subsampling may happen over megapixel image - var canvas = document.createElement('canvas'); - canvas.width = canvas.height = 1; - var ctx = canvas.getContext('2d'); - ctx.drawImage(img, -iw + 1, 0); - // subsampled image becomes half smaller in rendering size. - // check alpha channel value to confirm image is covering edge pixel or not. - // if alpha value is 0 image is not covering, hence subsampled. - return ctx.getImageData(0, 0, 1, 1).data[3] === 0; - } else { - return false; - } - } - - - /** - * Detecting vertical squash in loaded image. - * Fixes a bug which squash image vertically while drawing into canvas for some images. - */ - function detectVerticalSquash(img, iw, ih) { - var canvas = document.createElement('canvas'); - canvas.width = 1; - canvas.height = ih; - var ctx = canvas.getContext('2d'); - ctx.drawImage(img, 0, 0); - var data = ctx.getImageData(0, 0, 1, ih).data; - // search image edge pixel position in case it is squashed vertically. - var sy = 0; - var ey = ih; - var py = ih; - while (py > sy) { - var alpha = data[(py - 1) * 4 + 3]; - if (alpha === 0) { - ey = py; - } else { - sy = py; - } - py = (ey + sy) >> 1; - } - canvas = null; - var ratio = (py / ih); - return (ratio === 0) ? 1 : ratio; - } - - return { - isSubsampled: detectSubsampling, - renderTo: renderImageToCanvas - }; -}); - -// Included from: src/javascript/runtime/html5/image/Image.js - -/** - * Image.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html5/image/Image -@private -*/ -define("moxie/runtime/html5/image/Image", [ - "moxie/runtime/html5/Runtime", - "moxie/core/utils/Basic", - "moxie/core/Exceptions", - "moxie/core/utils/Encode", - "moxie/file/File", - "moxie/runtime/html5/image/ImageInfo", - "moxie/runtime/html5/image/MegaPixel", - "moxie/core/utils/Mime", - "moxie/core/utils/Env" -], function(extensions, Basic, x, Encode, File, ImageInfo, MegaPixel, Mime, Env) { - - function HTML5Image() { - var me = this - , _img, _imgInfo, _canvas, _binStr, _blob - , _modified = false // is set true whenever image is modified - , _preserveHeaders = true - ; - - Basic.extend(this, { - loadFromBlob: function(blob) { - var comp = this, I = comp.getRuntime() - , asBinary = arguments.length > 1 ? arguments[1] : true - ; - - if (!I.can('access_binary')) { - throw new x.RuntimeError(x.RuntimeError.NOT_SUPPORTED_ERR); - } - - _blob = blob; - - if (blob.isDetached()) { - _binStr = blob.getSource(); - _preload.call(this, _binStr); - return; - } else { - _readAsDataUrl.call(this, blob.getSource(), function(dataUrl) { - if (asBinary) { - _binStr = _toBinary(dataUrl); - } - _preload.call(comp, dataUrl); - }); - } - }, - - loadFromImage: function(img, exact) { - this.meta = img.meta; - - _blob = new File(null, { - name: img.name, - size: img.size, - type: img.type - }); - - _preload.call(this, exact ? (_binStr = img.getAsBinaryString()) : img.getAsDataURL()); - }, - - getInfo: function() { - var I = this.getRuntime(), info; - - if (!_imgInfo && _binStr && I.can('access_image_binary')) { - _imgInfo = new ImageInfo(_binStr); - } - - info = { - width: _getImg().width || 0, - height: _getImg().height || 0, - type: _blob.type || Mime.getFileMime(_blob.name), - size: _binStr && _binStr.length || _blob.size || 0, - name: _blob.name || '', - meta: _imgInfo && _imgInfo.meta || this.meta || {} - }; - - return info; - }, - - downsize: function() { - _downsize.apply(this, arguments); - }, - - getAsCanvas: function() { - if (_canvas) { - _canvas.id = this.uid + '_canvas'; - } - return _canvas; - }, - - getAsBlob: function(type, quality) { - if (type !== this.type) { - // if different mime type requested prepare image for conversion - _downsize.call(this, this.width, this.height, false); - } - return new File(null, { - name: _blob.name || '', - type: type, - data: me.getAsBinaryString.call(this, type, quality) - }); - }, - - getAsDataURL: function(type) { - var quality = arguments[1] || 90; - - // if image has not been modified, return the source right away - if (!_modified) { - return _img.src; - } - - if ('image/jpeg' !== type) { - return _canvas.toDataURL('image/png'); - } else { - try { - // older Geckos used to result in an exception on quality argument - return _canvas.toDataURL('image/jpeg', quality/100); - } catch (ex) { - return _canvas.toDataURL('image/jpeg'); - } - } - }, - - getAsBinaryString: function(type, quality) { - // if image has not been modified, return the source right away - if (!_modified) { - // if image was not loaded from binary string - if (!_binStr) { - _binStr = _toBinary(me.getAsDataURL(type, quality)); - } - return _binStr; - } - - if ('image/jpeg' !== type) { - _binStr = _toBinary(me.getAsDataURL(type, quality)); - } else { - var dataUrl; - - // if jpeg - if (!quality) { - quality = 90; - } - - try { - // older Geckos used to result in an exception on quality argument - dataUrl = _canvas.toDataURL('image/jpeg', quality/100); - } catch (ex) { - dataUrl = _canvas.toDataURL('image/jpeg'); - } - - _binStr = _toBinary(dataUrl); - - if (_imgInfo) { - _binStr = _imgInfo.stripHeaders(_binStr); - - if (_preserveHeaders) { - // update dimensions info in exif - if (_imgInfo.meta && _imgInfo.meta.exif) { - _imgInfo.setExif({ - PixelXDimension: this.width, - PixelYDimension: this.height - }); - } - - // re-inject the headers - _binStr = _imgInfo.writeHeaders(_binStr); - } - - // will be re-created from fresh on next getInfo call - _imgInfo.purge(); - _imgInfo = null; - } - } - - _modified = false; - - return _binStr; - }, - - destroy: function() { - me = null; - _purge.call(this); - this.getRuntime().getShim().removeInstance(this.uid); - } - }); - - - function _getImg() { - if (!_canvas && !_img) { - throw new x.ImageError(x.DOMException.INVALID_STATE_ERR); - } - return _canvas || _img; - } - - - function _toBinary(str) { - return Encode.atob(str.substring(str.indexOf('base64,') + 7)); - } - - - function _toDataUrl(str, type) { - return 'data:' + (type || '') + ';base64,' + Encode.btoa(str); - } - - - function _preload(str) { - var comp = this; - - _img = new Image(); - _img.onerror = function() { - _purge.call(this); - comp.trigger('error', new x.ImageError(x.ImageError.WRONG_FORMAT)); - }; - _img.onload = function() { - comp.trigger('load'); - }; - - _img.src = /^data:[^;]*;base64,/.test(str) ? str : _toDataUrl(str, _blob.type); - } - - - function _readAsDataUrl(file, callback) { - var comp = this, fr; - - // use FileReader if it's available - if (window.FileReader) { - fr = new FileReader(); - fr.onload = function() { - callback(this.result); - }; - fr.onerror = function() { - comp.trigger('error', new x.FileException(x.FileException.NOT_READABLE_ERR)); - }; - fr.readAsDataURL(file); - } else { - return callback(file.getAsDataURL()); - } - } - - function _downsize(width, height, crop, preserveHeaders) { - var self = this - , scale - , mathFn - , x = 0 - , y = 0 - , img - , destWidth - , destHeight - , orientation - ; - - _preserveHeaders = preserveHeaders; // we will need to check this on export (see getAsBinaryString()) - - // take into account orientation tag - orientation = (this.meta && this.meta.tiff && this.meta.tiff.Orientation) || 1; - - if (Basic.inArray(orientation, [5,6,7,8]) !== -1) { // values that require 90 degree rotation - // swap dimensions - var tmp = width; - width = height; - height = tmp; - } - - img = _getImg(); - - // unify dimensions - mathFn = !crop ? Math.min : Math.max; - scale = mathFn(width/img.width, height/img.height); - - // we only downsize here - if (scale > 1 && (!crop || preserveHeaders)) { // when cropping one of dimensions may still exceed max, so process it anyway - this.trigger('Resize'); - return; - } - - // prepare canvas if necessary - if (!_canvas) { - _canvas = document.createElement("canvas"); - } - - // calculate dimensions of proportionally resized image - destWidth = Math.round(img.width * scale); - destHeight = Math.round(img.height * scale); - - - // scale image and canvas - if (crop) { - _canvas.width = width; - _canvas.height = height; - - // if dimensions of the resulting image still larger than canvas, center it - if (destWidth > width) { - x = Math.round((destWidth - width) / 2); - } - - if (destHeight > height) { - y = Math.round((destHeight - height) / 2); - } - } else { - _canvas.width = destWidth; - _canvas.height = destHeight; - } - - // rotate if required, according to orientation tag - if (!_preserveHeaders) { - _rotateToOrientaion(_canvas.width, _canvas.height, orientation); - } - - _drawToCanvas.call(this, img, _canvas, -x, -y, destWidth, destHeight); - - this.width = _canvas.width; - this.height = _canvas.height; - - _modified = true; - self.trigger('Resize'); - } - - - function _drawToCanvas(img, canvas, x, y, w, h) { - if (Env.OS === 'iOS') { - // avoid squish bug in iOS6 - MegaPixel.renderTo(img, canvas, { width: w, height: h, x: x, y: y }); - } else { - var ctx = canvas.getContext('2d'); - ctx.drawImage(img, x, y, w, h); - } - } - - - /** - * Transform canvas coordination according to specified frame size and orientation - * Orientation value is from EXIF tag - * @author Shinichi Tomita - */ - function _rotateToOrientaion(width, height, orientation) { - switch (orientation) { - case 5: - case 6: - case 7: - case 8: - _canvas.width = height; - _canvas.height = width; - break; - default: - _canvas.width = width; - _canvas.height = height; - } - - /** - 1 = The 0th row is at the visual top of the image, and the 0th column is the visual left-hand side. - 2 = The 0th row is at the visual top of the image, and the 0th column is the visual right-hand side. - 3 = The 0th row is at the visual bottom of the image, and the 0th column is the visual right-hand side. - 4 = The 0th row is at the visual bottom of the image, and the 0th column is the visual left-hand side. - 5 = The 0th row is the visual left-hand side of the image, and the 0th column is the visual top. - 6 = The 0th row is the visual right-hand side of the image, and the 0th column is the visual top. - 7 = The 0th row is the visual right-hand side of the image, and the 0th column is the visual bottom. - 8 = The 0th row is the visual left-hand side of the image, and the 0th column is the visual bottom. - */ - - var ctx = _canvas.getContext('2d'); - switch (orientation) { - case 2: - // horizontal flip - ctx.translate(width, 0); - ctx.scale(-1, 1); - break; - case 3: - // 180 rotate left - ctx.translate(width, height); - ctx.rotate(Math.PI); - break; - case 4: - // vertical flip - ctx.translate(0, height); - ctx.scale(1, -1); - break; - case 5: - // vertical flip + 90 rotate right - ctx.rotate(0.5 * Math.PI); - ctx.scale(1, -1); - break; - case 6: - // 90 rotate right - ctx.rotate(0.5 * Math.PI); - ctx.translate(0, -height); - break; - case 7: - // horizontal flip + 90 rotate right - ctx.rotate(0.5 * Math.PI); - ctx.translate(width, -height); - ctx.scale(-1, 1); - break; - case 8: - // 90 rotate left - ctx.rotate(-0.5 * Math.PI); - ctx.translate(-width, 0); - break; - } - } - - - function _purge() { - if (_imgInfo) { - _imgInfo.purge(); - _imgInfo = null; - } - _binStr = _img = _canvas = _blob = null; - _modified = false; - } - } - - return (extensions.Image = HTML5Image); -}); - -// Included from: src/javascript/runtime/flash/Runtime.js - -/** - * Runtime.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/*global ActiveXObject:true */ - -/** -Defines constructor for Flash runtime. - -@class moxie/runtime/flash/Runtime -@private -*/ -define("moxie/runtime/flash/Runtime", [ - "moxie/core/utils/Basic", - "moxie/core/utils/Env", - "moxie/core/utils/Dom", - "moxie/core/Exceptions", - "moxie/runtime/Runtime" -], function(Basic, Env, Dom, x, Runtime) { - - var type = 'flash', extensions = {}; - - /** - Get the version of the Flash Player - - @method getShimVersion - @private - @return {Number} Flash Player version - */ - function getShimVersion() { - var version; - - try { - version = navigator.plugins['Shockwave Flash']; - version = version.description; - } catch (e1) { - try { - version = new ActiveXObject('ShockwaveFlash.ShockwaveFlash').GetVariable('$version'); - } catch (e2) { - version = '0.0'; - } - } - version = version.match(/\d+/g); - return parseFloat(version[0] + '.' + version[1]); - } - - /** - Constructor for the Flash Runtime - - @class FlashRuntime - @extends Runtime - */ - function FlashRuntime(options) { - var I = this, initTimer; - - options = Basic.extend({ swf_url: Env.swf_url }, options); - - Runtime.call(this, options, type, { - access_binary: function(value) { - return value && I.mode === 'browser'; - }, - access_image_binary: function(value) { - return value && I.mode === 'browser'; - }, - display_media: Runtime.capTrue, - do_cors: Runtime.capTrue, - drag_and_drop: false, - report_upload_progress: function() { - return I.mode === 'client'; - }, - resize_image: Runtime.capTrue, - return_response_headers: false, - return_response_type: function(responseType) { - if (responseType === 'json' && !!window.JSON) { - return true; - } - return !Basic.arrayDiff(responseType, ['', 'text', 'document']) || I.mode === 'browser'; - }, - return_status_code: function(code) { - return I.mode === 'browser' || !Basic.arrayDiff(code, [200, 404]); - }, - select_file: Runtime.capTrue, - select_multiple: Runtime.capTrue, - send_binary_string: function(value) { - return value && I.mode === 'browser'; - }, - send_browser_cookies: function(value) { - return value && I.mode === 'browser'; - }, - send_custom_headers: function(value) { - return value && I.mode === 'browser'; - }, - send_multipart: Runtime.capTrue, - slice_blob: Runtime.capTrue, - stream_upload: function(value) { - return value && I.mode === 'browser'; - }, - summon_file_dialog: false, - upload_filesize: function(size) { - return Basic.parseSizeStr(size) <= 2097152 || I.mode === 'client'; - }, - use_http_method: function(methods) { - return !Basic.arrayDiff(methods, ['GET', 'POST']); - } - }, { - // capabilities that require specific mode - access_binary: function(value) { - return value ? 'browser' : 'client'; - }, - access_image_binary: function(value) { - return value ? 'browser' : 'client'; - }, - report_upload_progress: function(value) { - return value ? 'browser' : 'client'; - }, - return_response_type: function(responseType) { - return Basic.arrayDiff(responseType, ['', 'text', 'json', 'document']) ? 'browser' : ['client', 'browser']; - }, - return_status_code: function(code) { - return Basic.arrayDiff(code, [200, 404]) ? 'browser' : ['client', 'browser']; - }, - send_binary_string: function(value) { - return value ? 'browser' : 'client'; - }, - send_browser_cookies: function(value) { - return value ? 'browser' : 'client'; - }, - send_custom_headers: function(value) { - return value ? 'browser' : 'client'; - }, - stream_upload: function(value) { - return value ? 'client' : 'browser'; - }, - upload_filesize: function(size) { - return Basic.parseSizeStr(size) >= 2097152 ? 'client' : 'browser'; - } - }, 'client'); - - - // minimal requirement for Flash Player version - if (getShimVersion() < 10) { - this.mode = false; // with falsy mode, runtime won't operable, no matter what the mode was before - } - - - Basic.extend(this, { - - getShim: function() { - return Dom.get(this.uid); - }, - - shimExec: function(component, action) { - var args = [].slice.call(arguments, 2); - return I.getShim().exec(this.uid, component, action, args); - }, - - init: function() { - var html, el, container; - - container = this.getShimContainer(); - - // if not the minimal height, shims are not initialized in older browsers (e.g FF3.6, IE6,7,8, Safari 4.0,5.0, etc) - Basic.extend(container.style, { - position: 'absolute', - top: '-8px', - left: '-8px', - width: '9px', - height: '9px', - overflow: 'hidden' - }); - - // insert flash object - html = '' + - '' + - '' + - '' + - ''; - - if (Env.browser === 'IE') { - el = document.createElement('div'); - container.appendChild(el); - el.outerHTML = html; - el = container = null; // just in case - } else { - container.innerHTML = html; - } - - // Init is dispatched by the shim - initTimer = setTimeout(function() { - if (I && !I.initialized) { // runtime might be already destroyed by this moment - I.trigger("Error", new x.RuntimeError(x.RuntimeError.NOT_INIT_ERR)); - } - }, 5000); - }, - - destroy: (function(destroy) { // extend default destroy method - return function() { - destroy.call(I); - clearTimeout(initTimer); // initialization check might be still onwait - options = initTimer = destroy = I = null; - }; - }(this.destroy)) - - }, extensions); - } - - Runtime.addConstructor(type, FlashRuntime); - - return extensions; -}); - -// Included from: src/javascript/runtime/flash/file/Blob.js - -/** - * Blob.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/flash/file/Blob -@private -*/ -define("moxie/runtime/flash/file/Blob", [ - "moxie/runtime/flash/Runtime", - "moxie/file/Blob" -], function(extensions, Blob) { - - var FlashBlob = { - slice: function(blob, start, end, type) { - var self = this.getRuntime(); - - if (start < 0) { - start = Math.max(blob.size + start, 0); - } else if (start > 0) { - start = Math.min(start, blob.size); - } - - if (end < 0) { - end = Math.max(blob.size + end, 0); - } else if (end > 0) { - end = Math.min(end, blob.size); - } - - blob = self.shimExec.call(this, 'Blob', 'slice', start, end, type || ''); - - if (blob) { - blob = new Blob(self.uid, blob); - } - return blob; - } - }; - - return (extensions.Blob = FlashBlob); -}); - -// Included from: src/javascript/runtime/flash/file/FileInput.js - -/** - * FileInput.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/flash/file/FileInput -@private -*/ -define("moxie/runtime/flash/file/FileInput", [ - "moxie/runtime/flash/Runtime" -], function(extensions) { - - var FileInput = { - init: function(options) { - this.getRuntime().shimExec.call(this, 'FileInput', 'init', { - name: options.name, - accept: options.accept, - multiple: options.multiple - }); - this.trigger('ready'); - } - }; - - return (extensions.FileInput = FileInput); -}); - -// Included from: src/javascript/runtime/flash/file/FileReader.js - -/** - * FileReader.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/flash/file/FileReader -@private -*/ -define("moxie/runtime/flash/file/FileReader", [ - "moxie/runtime/flash/Runtime", - "moxie/core/utils/Encode" -], function(extensions, Encode) { - - var _result = ''; - - function _formatData(data, op) { - switch (op) { - case 'readAsText': - return Encode.atob(data, 'utf8'); - case 'readAsBinaryString': - return Encode.atob(data); - case 'readAsDataURL': - return data; - } - return null; - } - - var FileReader = { - read: function(op, blob) { - var target = this, self = target.getRuntime(); - - // special prefix for DataURL read mode - if (op === 'readAsDataURL') { - _result = 'data:' + (blob.type || '') + ';base64,'; - } - - target.bind('Progress', function(e, data) { - if (data) { - _result += _formatData(data, op); - } - }); - - return self.shimExec.call(this, 'FileReader', 'readAsBase64', blob.uid); - }, - - getResult: function() { - return _result; - }, - - destroy: function() { - _result = null; - } - }; - - return (extensions.FileReader = FileReader); -}); - -// Included from: src/javascript/runtime/flash/file/FileReaderSync.js - -/** - * FileReaderSync.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/flash/file/FileReaderSync -@private -*/ -define("moxie/runtime/flash/file/FileReaderSync", [ - "moxie/runtime/flash/Runtime", - "moxie/core/utils/Encode" -], function(extensions, Encode) { - - function _formatData(data, op) { - switch (op) { - case 'readAsText': - return Encode.atob(data, 'utf8'); - case 'readAsBinaryString': - return Encode.atob(data); - case 'readAsDataURL': - return data; - } - return null; - } - - var FileReaderSync = { - read: function(op, blob) { - var result, self = this.getRuntime(); - - result = self.shimExec.call(this, 'FileReaderSync', 'readAsBase64', blob.uid); - if (!result) { - return null; // or throw ex - } - - // special prefix for DataURL read mode - if (op === 'readAsDataURL') { - result = 'data:' + (blob.type || '') + ';base64,' + result; - } - - return _formatData(result, op, blob.type); - } - }; - - return (extensions.FileReaderSync = FileReaderSync); -}); - -// Included from: src/javascript/runtime/flash/xhr/XMLHttpRequest.js - -/** - * XMLHttpRequest.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/flash/xhr/XMLHttpRequest -@private -*/ -define("moxie/runtime/flash/xhr/XMLHttpRequest", [ - "moxie/runtime/flash/Runtime", - "moxie/core/utils/Basic", - "moxie/file/Blob", - "moxie/file/File", - "moxie/file/FileReaderSync", - "moxie/xhr/FormData", - "moxie/runtime/Transporter" -], function(extensions, Basic, Blob, File, FileReaderSync, FormData, Transporter) { - - var XMLHttpRequest = { - - send: function(meta, data) { - var target = this, self = target.getRuntime(); - - function send() { - meta.transport = self.mode; - self.shimExec.call(target, 'XMLHttpRequest', 'send', meta, data); - } - - - function appendBlob(name, blob) { - self.shimExec.call(target, 'XMLHttpRequest', 'appendBlob', name, blob.uid); - data = null; - send(); - } - - - function attachBlob(blob, cb) { - var tr = new Transporter(); - - tr.bind("TransportingComplete", function() { - cb(this.result); - }); - - tr.transport(blob.getSource(), blob.type, { - ruid: self.uid - }); - } - - // copy over the headers if any - if (!Basic.isEmptyObj(meta.headers)) { - Basic.each(meta.headers, function(value, header) { - self.shimExec.call(target, 'XMLHttpRequest', 'setRequestHeader', header, value.toString()); // Silverlight doesn't accept integers into the arguments of type object - }); - } - - // transfer over multipart params and blob itself - if (data instanceof FormData) { - var blobField; - data.each(function(value, name) { - if (value instanceof Blob) { - blobField = name; - } else { - self.shimExec.call(target, 'XMLHttpRequest', 'append', name, value); - } - }); - - if (!data.hasBlob()) { - data = null; - send(); - } else { - var blob = data.getBlob(); - if (blob.isDetached()) { - attachBlob(blob, function(attachedBlob) { - blob.destroy(); - appendBlob(blobField, attachedBlob); - }); - } else { - appendBlob(blobField, blob); - } - } - } else if (data instanceof Blob) { - if (data.isDetached()) { - attachBlob(data, function(attachedBlob) { - data.destroy(); - data = attachedBlob.uid; - send(); - }); - } else { - data = data.uid; - send(); - } - } else { - send(); - } - }, - - getResponse: function(responseType) { - var frs, blob, self = this.getRuntime(); - - blob = self.shimExec.call(this, 'XMLHttpRequest', 'getResponseAsBlob'); - - if (blob) { - blob = new File(self.uid, blob); - - if ('blob' === responseType) { - return blob; - } - - try { - frs = new FileReaderSync(); - - if (!!~Basic.inArray(responseType, ["", "text"])) { - return frs.readAsText(blob); - } else if ('json' === responseType && !!window.JSON) { - return JSON.parse(frs.readAsText(blob)); - } - } finally { - blob.destroy(); - } - } - return null; - }, - - abort: function(upload_complete_flag) { - var self = this.getRuntime(); - - self.shimExec.call(this, 'XMLHttpRequest', 'abort'); - - this.dispatchEvent('readystatechange'); - // this.dispatchEvent('progress'); - this.dispatchEvent('abort'); - - //if (!upload_complete_flag) { - // this.dispatchEvent('uploadprogress'); - //} - } - }; - - return (extensions.XMLHttpRequest = XMLHttpRequest); -}); - -// Included from: src/javascript/runtime/flash/runtime/Transporter.js - -/** - * Transporter.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/flash/runtime/Transporter -@private -*/ -define("moxie/runtime/flash/runtime/Transporter", [ - "moxie/runtime/flash/Runtime", - "moxie/file/Blob" -], function(extensions, Blob) { - - var Transporter = { - getAsBlob: function(type) { - var self = this.getRuntime() - , blob = self.shimExec.call(this, 'Transporter', 'getAsBlob', type) - ; - if (blob) { - return new Blob(self.uid, blob); - } - return null; - } - }; - - return (extensions.Transporter = Transporter); -}); - -// Included from: src/javascript/runtime/flash/image/Image.js - -/** - * Image.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/flash/image/Image -@private -*/ -define("moxie/runtime/flash/image/Image", [ - "moxie/runtime/flash/Runtime", - "moxie/core/utils/Basic", - "moxie/runtime/Transporter", - "moxie/file/Blob", - "moxie/file/FileReaderSync" -], function(extensions, Basic, Transporter, Blob, FileReaderSync) { - - var Image = { - loadFromBlob: function(blob) { - var comp = this, self = comp.getRuntime(); - - function exec(srcBlob) { - self.shimExec.call(comp, 'Image', 'loadFromBlob', srcBlob.uid); - comp = self = null; - } - - if (blob.isDetached()) { // binary string - var tr = new Transporter(); - tr.bind("TransportingComplete", function() { - exec(tr.result.getSource()); - }); - tr.transport(blob.getSource(), blob.type, { ruid: self.uid }); - } else { - exec(blob.getSource()); - } - }, - - loadFromImage: function(img) { - var self = this.getRuntime(); - return self.shimExec.call(this, 'Image', 'loadFromImage', img.uid); - }, - - getAsBlob: function(type, quality) { - var self = this.getRuntime() - , blob = self.shimExec.call(this, 'Image', 'getAsBlob', type, quality) - ; - if (blob) { - return new Blob(self.uid, blob); - } - return null; - }, - - getAsDataURL: function() { - var self = this.getRuntime() - , blob = self.Image.getAsBlob.apply(this, arguments) - , frs - ; - if (!blob) { - return null; - } - frs = new FileReaderSync(); - return frs.readAsDataURL(blob); - } - }; - - return (extensions.Image = Image); -}); - -// Included from: src/javascript/runtime/silverlight/Runtime.js - -/** - * RunTime.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/*global ActiveXObject:true */ - -/** -Defines constructor for Silverlight runtime. - -@class moxie/runtime/silverlight/Runtime -@private -*/ -define("moxie/runtime/silverlight/Runtime", [ - "moxie/core/utils/Basic", - "moxie/core/utils/Env", - "moxie/core/utils/Dom", - "moxie/core/Exceptions", - "moxie/runtime/Runtime" -], function(Basic, Env, Dom, x, Runtime) { - - var type = "silverlight", extensions = {}; - - function isInstalled(version) { - var isVersionSupported = false, control = null, actualVer, - actualVerArray, reqVerArray, requiredVersionPart, actualVersionPart, index = 0; - - try { - try { - control = new ActiveXObject('AgControl.AgControl'); - - if (control.IsVersionSupported(version)) { - isVersionSupported = true; - } - - control = null; - } catch (e) { - var plugin = navigator.plugins["Silverlight Plug-In"]; - - if (plugin) { - actualVer = plugin.description; - - if (actualVer === "1.0.30226.2") { - actualVer = "2.0.30226.2"; - } - - actualVerArray = actualVer.split("."); - - while (actualVerArray.length > 3) { - actualVerArray.pop(); - } - - while ( actualVerArray.length < 4) { - actualVerArray.push(0); - } - - reqVerArray = version.split("."); - - while (reqVerArray.length > 4) { - reqVerArray.pop(); - } - - do { - requiredVersionPart = parseInt(reqVerArray[index], 10); - actualVersionPart = parseInt(actualVerArray[index], 10); - index++; - } while (index < reqVerArray.length && requiredVersionPart === actualVersionPart); - - if (requiredVersionPart <= actualVersionPart && !isNaN(requiredVersionPart)) { - isVersionSupported = true; - } - } - } - } catch (e2) { - isVersionSupported = false; - } - - return isVersionSupported; - } - - /** - Constructor for the Silverlight Runtime - - @class SilverlightRuntime - @extends Runtime - */ - function SilverlightRuntime(options) { - var I = this, initTimer; - - options = Basic.extend({ xap_url: Env.xap_url }, options); - - Runtime.call(this, options, type, { - access_binary: Runtime.capTrue, - access_image_binary: Runtime.capTrue, - display_media: Runtime.capTrue, - do_cors: Runtime.capTrue, - drag_and_drop: false, - report_upload_progress: Runtime.capTrue, - resize_image: Runtime.capTrue, - return_response_headers: function(value) { - return value && I.mode === 'client'; - }, - return_response_type: function(responseType) { - if (responseType !== 'json') { - return true; - } else { - return !!window.JSON; - } - }, - return_status_code: function(code) { - return I.mode === 'client' || !Basic.arrayDiff(code, [200, 404]); - }, - select_file: Runtime.capTrue, - select_multiple: Runtime.capTrue, - send_binary_string: Runtime.capTrue, - send_browser_cookies: function(value) { - return value && I.mode === 'browser'; - }, - send_custom_headers: function(value) { - return value && I.mode === 'client'; - }, - send_multipart: Runtime.capTrue, - slice_blob: Runtime.capTrue, - stream_upload: true, - summon_file_dialog: false, - upload_filesize: Runtime.capTrue, - use_http_method: function(methods) { - return I.mode === 'client' || !Basic.arrayDiff(methods, ['GET', 'POST']); - } - }, { - // capabilities that require specific mode - return_response_headers: function(value) { - return value ? 'client' : 'browser'; - }, - return_status_code: function(code) { - return Basic.arrayDiff(code, [200, 404]) ? 'client' : ['client', 'browser']; - }, - send_browser_cookies: function(value) { - return value ? 'browser' : 'client'; - }, - send_custom_headers: function(value) { - return value ? 'client' : 'browser'; - }, - use_http_method: function(methods) { - return Basic.arrayDiff(methods, ['GET', 'POST']) ? 'client' : ['client', 'browser']; - } - }); - - - // minimal requirement - if (!isInstalled('2.0.31005.0') || Env.browser === 'Opera') { - this.mode = false; - } - - - Basic.extend(this, { - getShim: function() { - return Dom.get(this.uid).content.Moxie; - }, - - shimExec: function(component, action) { - var args = [].slice.call(arguments, 2); - return I.getShim().exec(this.uid, component, action, args); - }, - - init : function() { - var container; - - container = this.getShimContainer(); - - container.innerHTML = '' + - '' + - '' + - '' + - '' + - '' + - ''; - - // Init is dispatched by the shim - initTimer = setTimeout(function() { - if (I && !I.initialized) { // runtime might be already destroyed by this moment - I.trigger("Error", new x.RuntimeError(x.RuntimeError.NOT_INIT_ERR)); - } - }, Env.OS !== 'Windows'? 10000 : 5000); // give it more time to initialize in non Windows OS (like Mac) - }, - - destroy: (function(destroy) { // extend default destroy method - return function() { - destroy.call(I); - clearTimeout(initTimer); // initialization check might be still onwait - options = initTimer = destroy = I = null; - }; - }(this.destroy)) - - }, extensions); - } - - Runtime.addConstructor(type, SilverlightRuntime); - - return extensions; -}); - -// Included from: src/javascript/runtime/silverlight/file/Blob.js - -/** - * Blob.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/silverlight/file/Blob -@private -*/ -define("moxie/runtime/silverlight/file/Blob", [ - "moxie/runtime/silverlight/Runtime", - "moxie/core/utils/Basic", - "moxie/runtime/flash/file/Blob" -], function(extensions, Basic, Blob) { - return (extensions.Blob = Basic.extend({}, Blob)); -}); - -// Included from: src/javascript/runtime/silverlight/file/FileInput.js - -/** - * FileInput.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/silverlight/file/FileInput -@private -*/ -define("moxie/runtime/silverlight/file/FileInput", [ - "moxie/runtime/silverlight/Runtime" -], function(extensions) { - - var FileInput = { - init: function(options) { - - function toFilters(accept) { - var filter = ''; - for (var i = 0; i < accept.length; i++) { - filter += (filter !== '' ? '|' : '') + accept[i].title + " | *." + accept[i].extensions.replace(/,/g, ';*.'); - } - return filter; - } - - this.getRuntime().shimExec.call(this, 'FileInput', 'init', toFilters(options.accept), options.name, options.multiple); - this.trigger('ready'); - } - }; - - return (extensions.FileInput = FileInput); -}); - -// Included from: src/javascript/runtime/silverlight/file/FileDrop.js - -/** - * FileDrop.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/silverlight/file/FileDrop -@private -*/ -define("moxie/runtime/silverlight/file/FileDrop", [ - "moxie/runtime/silverlight/Runtime", - "moxie/core/utils/Dom", - "moxie/core/utils/Events" -], function(extensions, Dom, Events) { - - // not exactly useful, since works only in safari (...crickets...) - var FileDrop = { - init: function() { - var comp = this, self = comp.getRuntime(), dropZone; - - dropZone = self.getShimContainer(); - - Events.addEvent(dropZone, 'dragover', function(e) { - e.preventDefault(); - e.stopPropagation(); - e.dataTransfer.dropEffect = 'copy'; - }, comp.uid); - - Events.addEvent(dropZone, 'dragenter', function(e) { - e.preventDefault(); - var flag = Dom.get(self.uid).dragEnter(e); - // If handled, then stop propagation of event in DOM - if (flag) { - e.stopPropagation(); - } - }, comp.uid); - - Events.addEvent(dropZone, 'drop', function(e) { - e.preventDefault(); - var flag = Dom.get(self.uid).dragDrop(e); - // If handled, then stop propagation of event in DOM - if (flag) { - e.stopPropagation(); - } - }, comp.uid); - - return self.shimExec.call(this, 'FileDrop', 'init'); - } - }; - - return (extensions.FileDrop = FileDrop); -}); - -// Included from: src/javascript/runtime/silverlight/file/FileReader.js - -/** - * FileReader.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/silverlight/file/FileReader -@private -*/ -define("moxie/runtime/silverlight/file/FileReader", [ - "moxie/runtime/silverlight/Runtime", - "moxie/core/utils/Basic", - "moxie/runtime/flash/file/FileReader" -], function(extensions, Basic, FileReader) { - return (extensions.FileReader = Basic.extend({}, FileReader)); -}); - -// Included from: src/javascript/runtime/silverlight/file/FileReaderSync.js - -/** - * FileReaderSync.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/silverlight/file/FileReaderSync -@private -*/ -define("moxie/runtime/silverlight/file/FileReaderSync", [ - "moxie/runtime/silverlight/Runtime", - "moxie/core/utils/Basic", - "moxie/runtime/flash/file/FileReaderSync" -], function(extensions, Basic, FileReaderSync) { - return (extensions.FileReaderSync = Basic.extend({}, FileReaderSync)); -}); - -// Included from: src/javascript/runtime/silverlight/xhr/XMLHttpRequest.js - -/** - * XMLHttpRequest.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/silverlight/xhr/XMLHttpRequest -@private -*/ -define("moxie/runtime/silverlight/xhr/XMLHttpRequest", [ - "moxie/runtime/silverlight/Runtime", - "moxie/core/utils/Basic", - "moxie/runtime/flash/xhr/XMLHttpRequest" -], function(extensions, Basic, XMLHttpRequest) { - return (extensions.XMLHttpRequest = Basic.extend({}, XMLHttpRequest)); -}); - -// Included from: src/javascript/runtime/silverlight/runtime/Transporter.js - -/** - * Transporter.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/silverlight/runtime/Transporter -@private -*/ -define("moxie/runtime/silverlight/runtime/Transporter", [ - "moxie/runtime/silverlight/Runtime", - "moxie/core/utils/Basic", - "moxie/runtime/flash/runtime/Transporter" -], function(extensions, Basic, Transporter) { - return (extensions.Transporter = Basic.extend({}, Transporter)); -}); - -// Included from: src/javascript/runtime/silverlight/image/Image.js - -/** - * Image.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/silverlight/image/Image -@private -*/ -define("moxie/runtime/silverlight/image/Image", [ - "moxie/runtime/silverlight/Runtime", - "moxie/core/utils/Basic", - "moxie/runtime/flash/image/Image" -], function(extensions, Basic, Image) { - return (extensions.Image = Basic.extend({}, Image, { - - getInfo: function() { - var self = this.getRuntime() - , grps = ['tiff', 'exif', 'gps'] - , info = { meta: {} } - , rawInfo = self.shimExec.call(this, 'Image', 'getInfo') - ; - - if (rawInfo.meta) { - Basic.each(grps, function(grp) { - var meta = rawInfo.meta[grp] - , tag - , i - , length - , value - ; - if (meta && meta.keys) { - info.meta[grp] = {}; - for (i = 0, length = meta.keys.length; i < length; i++) { - tag = meta.keys[i]; - value = meta[tag]; - if (value) { - // convert numbers - if (/^(\d|[1-9]\d+)$/.test(value)) { // integer (make sure doesn't start with zero) - value = parseInt(value, 10); - } else if (/^\d*\.\d+$/.test(value)) { // double - value = parseFloat(value); - } - info.meta[grp][tag] = value; - } - } - } - }); - } - - info.width = parseInt(rawInfo.width, 10); - info.height = parseInt(rawInfo.height, 10); - info.size = parseInt(rawInfo.size, 10); - info.type = rawInfo.type; - info.name = rawInfo.name; - - return info; - } - })); -}); - -// Included from: src/javascript/runtime/html4/Runtime.js - -/** - * Runtime.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/*global File:true */ - -/** -Defines constructor for HTML4 runtime. - -@class moxie/runtime/html4/Runtime -@private -*/ -define("moxie/runtime/html4/Runtime", [ - "moxie/core/utils/Basic", - "moxie/core/Exceptions", - "moxie/runtime/Runtime", - "moxie/core/utils/Env" -], function(Basic, x, Runtime, Env) { - - var type = 'html4', extensions = {}; - - function Html4Runtime(options) { - var I = this - , Test = Runtime.capTest - , True = Runtime.capTrue - ; - - Runtime.call(this, options, type, { - access_binary: Test(window.FileReader || window.File && File.getAsDataURL), - access_image_binary: false, - display_media: Test(extensions.Image && (Env.can('create_canvas') || Env.can('use_data_uri_over32kb'))), - do_cors: false, - drag_and_drop: false, - filter_by_extension: Test(function() { // if you know how to feature-detect this, please suggest - return (Env.browser === 'Chrome' && Env.version >= 28) || (Env.browser === 'IE' && Env.version >= 10); - }()), - resize_image: function() { - return extensions.Image && I.can('access_binary') && Env.can('create_canvas'); - }, - report_upload_progress: false, - return_response_headers: false, - return_response_type: function(responseType) { - if (responseType === 'json' && !!window.JSON) { - return true; - } - return !!~Basic.inArray(responseType, ['text', 'document', '']); - }, - return_status_code: function(code) { - return !Basic.arrayDiff(code, [200, 404]); - }, - select_file: function() { - return Env.can('use_fileinput'); - }, - select_multiple: false, - send_binary_string: false, - send_custom_headers: false, - send_multipart: true, - slice_blob: false, - stream_upload: function() { - return I.can('select_file'); - }, - summon_file_dialog: Test(function() { // yeah... some dirty sniffing here... - return (Env.browser === 'Firefox' && Env.version >= 4) || - (Env.browser === 'Opera' && Env.version >= 12) || - !!~Basic.inArray(Env.browser, ['Chrome', 'Safari']); - }()), - upload_filesize: True, - use_http_method: function(methods) { - return !Basic.arrayDiff(methods, ['GET', 'POST']); - } - }); - - - Basic.extend(this, { - init : function() { - this.trigger("Init"); - }, - - destroy: (function(destroy) { // extend default destroy method - return function() { - destroy.call(I); - destroy = I = null; - }; - }(this.destroy)) - }); - - Basic.extend(this.getShim(), extensions); - } - - Runtime.addConstructor(type, Html4Runtime); - - return extensions; -}); - -// Included from: src/javascript/runtime/html4/file/FileInput.js - -/** - * FileInput.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html4/file/FileInput -@private -*/ -define("moxie/runtime/html4/file/FileInput", [ - "moxie/runtime/html4/Runtime", - "moxie/core/utils/Basic", - "moxie/core/utils/Dom", - "moxie/core/utils/Events", - "moxie/core/utils/Mime", - "moxie/core/utils/Env" -], function(extensions, Basic, Dom, Events, Mime, Env) { - - function FileInput() { - var _uid, _files = [], _mimes = [], _options; - - function addInput() { - var comp = this, I = comp.getRuntime(), shimContainer, browseButton, currForm, form, input, uid; - - uid = Basic.guid('uid_'); - - shimContainer = I.getShimContainer(); // we get new ref everytime to avoid memory leaks in IE - - if (_uid) { // move previous form out of the view - currForm = Dom.get(_uid + '_form'); - if (currForm) { - Basic.extend(currForm.style, { top: '100%' }); - } - } - - // build form in DOM, since innerHTML version not able to submit file for some reason - form = document.createElement('form'); - form.setAttribute('id', uid + '_form'); - form.setAttribute('method', 'post'); - form.setAttribute('enctype', 'multipart/form-data'); - form.setAttribute('encoding', 'multipart/form-data'); - - Basic.extend(form.style, { - overflow: 'hidden', - position: 'absolute', - top: 0, - left: 0, - width: '100%', - height: '100%' - }); - - input = document.createElement('input'); - input.setAttribute('id', uid); - input.setAttribute('type', 'file'); - input.setAttribute('name', _options.name || 'Filedata'); - input.setAttribute('accept', _mimes.join(',')); - - Basic.extend(input.style, { - fontSize: '999px', - opacity: 0 - }); - - form.appendChild(input); - shimContainer.appendChild(form); - - // prepare file input to be placed underneath the browse_button element - Basic.extend(input.style, { - position: 'absolute', - top: 0, - left: 0, - width: '100%', - height: '100%' - }); - - if (Env.browser === 'IE' && Env.version < 10) { - Basic.extend(input.style, { - filter : "progid:DXImageTransform.Microsoft.Alpha(opacity=0)" - }); - } - - input.onchange = function() { // there should be only one handler for this - var file; - - if (!this.value) { - return; - } - - if (this.files) { - file = this.files[0]; - } else { - file = { - name: this.value - }; - } - - _files = [file]; - - this.onchange = function() {}; // clear event handler - addInput.call(comp); - - // after file is initialized as o.File, we need to update form and input ids - comp.bind('change', function onChange() { - var input = Dom.get(uid), form = Dom.get(uid + '_form'), file; - - comp.unbind('change', onChange); - - if (comp.files.length && input && form) { - file = comp.files[0]; - - input.setAttribute('id', file.uid); - form.setAttribute('id', file.uid + '_form'); - - // set upload target - form.setAttribute('target', file.uid + '_iframe'); - } - input = form = null; - }, 998); - - input = form = null; - comp.trigger('change'); - }; - - - // route click event to the input - if (I.can('summon_file_dialog')) { - browseButton = Dom.get(_options.browse_button); - Events.removeEvent(browseButton, 'click', comp.uid); - Events.addEvent(browseButton, 'click', function(e) { - if (input && !input.disabled) { // for some reason FF (up to 8.0.1 so far) lets to click disabled input[type=file] - input.click(); - } - e.preventDefault(); - }, comp.uid); - } - - _uid = uid; - - shimContainer = currForm = browseButton = null; - } - - Basic.extend(this, { - init: function(options) { - var comp = this, I = comp.getRuntime(), shimContainer; - - // figure out accept string - _options = options; - _mimes = options.accept.mimes || Mime.extList2mimes(options.accept, I.can('filter_by_extension')); - - shimContainer = I.getShimContainer(); - - (function() { - var browseButton, zIndex, top; - - browseButton = Dom.get(options.browse_button); - - // Route click event to the input[type=file] element for browsers that support such behavior - if (I.can('summon_file_dialog')) { - if (Dom.getStyle(browseButton, 'position') === 'static') { - browseButton.style.position = 'relative'; - } - - zIndex = parseInt(Dom.getStyle(browseButton, 'z-index'), 10) || 1; - - browseButton.style.zIndex = zIndex; - shimContainer.style.zIndex = zIndex - 1; - } - - /* Since we have to place input[type=file] on top of the browse_button for some browsers, - browse_button loses interactivity, so we restore it here */ - top = I.can('summon_file_dialog') ? browseButton : shimContainer; - - Events.addEvent(top, 'mouseover', function() { - comp.trigger('mouseenter'); - }, comp.uid); - - Events.addEvent(top, 'mouseout', function() { - comp.trigger('mouseleave'); - }, comp.uid); - - Events.addEvent(top, 'mousedown', function() { - comp.trigger('mousedown'); - }, comp.uid); - - Events.addEvent(Dom.get(options.container), 'mouseup', function() { - comp.trigger('mouseup'); - }, comp.uid); - - browseButton = null; - }()); - - addInput.call(this); - - shimContainer = null; - - // trigger ready event asynchronously - comp.trigger({ - type: 'ready', - async: true - }); - }, - - getFiles: function() { - return _files; - }, - - disable: function(state) { - var input; - - if ((input = Dom.get(_uid))) { - input.disabled = !!state; - } - }, - - destroy: function() { - var I = this.getRuntime() - , shim = I.getShim() - , shimContainer = I.getShimContainer() - ; - - Events.removeAllEvents(shimContainer, this.uid); - Events.removeAllEvents(_options && Dom.get(_options.container), this.uid); - Events.removeAllEvents(_options && Dom.get(_options.browse_button), this.uid); - - if (shimContainer) { - shimContainer.innerHTML = ''; - } - - shim.removeInstance(this.uid); - - _uid = _files = _mimes = _options = shimContainer = shim = null; - } - }); - } - - return (extensions.FileInput = FileInput); -}); - -// Included from: src/javascript/runtime/html4/file/FileReader.js - -/** - * FileReader.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html4/file/FileReader -@private -*/ -define("moxie/runtime/html4/file/FileReader", [ - "moxie/runtime/html4/Runtime", - "moxie/runtime/html5/file/FileReader" -], function(extensions, FileReader) { - return (extensions.FileReader = FileReader); -}); - -// Included from: src/javascript/runtime/html4/xhr/XMLHttpRequest.js - -/** - * XMLHttpRequest.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html4/xhr/XMLHttpRequest -@private -*/ -define("moxie/runtime/html4/xhr/XMLHttpRequest", [ - "moxie/runtime/html4/Runtime", - "moxie/core/utils/Basic", - "moxie/core/utils/Dom", - "moxie/core/utils/Url", - "moxie/core/Exceptions", - "moxie/core/utils/Events", - "moxie/file/Blob", - "moxie/xhr/FormData" -], function(extensions, Basic, Dom, Url, x, Events, Blob, FormData) { - - function XMLHttpRequest() { - var _status, _response, _iframe; - - function cleanup(cb) { - var target = this, uid, form, inputs, i, hasFile = false; - - if (!_iframe) { - return; - } - - uid = _iframe.id.replace(/_iframe$/, ''); - - form = Dom.get(uid + '_form'); - if (form) { - inputs = form.getElementsByTagName('input'); - i = inputs.length; - - while (i--) { - switch (inputs[i].getAttribute('type')) { - case 'hidden': - inputs[i].parentNode.removeChild(inputs[i]); - break; - case 'file': - hasFile = true; // flag the case for later - break; - } - } - inputs = []; - - if (!hasFile) { // we need to keep the form for sake of possible retries - form.parentNode.removeChild(form); - } - form = null; - } - - // without timeout, request is marked as canceled (in console) - setTimeout(function() { - Events.removeEvent(_iframe, 'load', target.uid); - if (_iframe.parentNode) { // #382 - _iframe.parentNode.removeChild(_iframe); - } - - // check if shim container has any other children, if - not, remove it as well - var shimContainer = target.getRuntime().getShimContainer(); - if (!shimContainer.children.length) { - shimContainer.parentNode.removeChild(shimContainer); - } - - shimContainer = _iframe = null; - cb(); - }, 1); - } - - Basic.extend(this, { - send: function(meta, data) { - var target = this, I = target.getRuntime(), uid, form, input, blob; - - _status = _response = null; - - function createIframe() { - var container = I.getShimContainer() || document.body - , temp = document.createElement('div') - ; - - // IE 6 won't be able to set the name using setAttribute or iframe.name - temp.innerHTML = ''; - _iframe = temp.firstChild; - container.appendChild(_iframe); - - /* _iframe.onreadystatechange = function() { - console.info(_iframe.readyState); - };*/ - - Events.addEvent(_iframe, 'load', function() { // _iframe.onload doesn't work in IE lte 8 - var el; - - try { - el = _iframe.contentWindow.document || _iframe.contentDocument || window.frames[_iframe.id].document; - - // try to detect some standard error pages - if (/^4(0[0-9]|1[0-7]|2[2346])\s/.test(el.title)) { // test if title starts with 4xx HTTP error - _status = el.title.replace(/^(\d+).*$/, '$1'); - } else { - _status = 200; - // get result - _response = Basic.trim(el.body.innerHTML); - - // we need to fire these at least once - target.trigger({ - type: 'progress', - loaded: _response.length, - total: _response.length - }); - - if (blob) { // if we were uploading a file - target.trigger({ - type: 'uploadprogress', - loaded: blob.size || 1025, - total: blob.size || 1025 - }); - } - } - } catch (ex) { - if (Url.hasSameOrigin(meta.url)) { - // if response is sent with error code, iframe in IE gets redirected to res://ieframe.dll/http_x.htm - // which obviously results to cross domain error (wtf?) - _status = 404; - } else { - cleanup.call(target, function() { - target.trigger('error'); - }); - return; - } - } - - cleanup.call(target, function() { - target.trigger('load'); - }); - }, target.uid); - } // end createIframe - - // prepare data to be sent and convert if required - if (data instanceof FormData && data.hasBlob()) { - blob = data.getBlob(); - uid = blob.uid; - input = Dom.get(uid); - form = Dom.get(uid + '_form'); - if (!form) { - throw new x.DOMException(x.DOMException.NOT_FOUND_ERR); - } - } else { - uid = Basic.guid('uid_'); - - form = document.createElement('form'); - form.setAttribute('id', uid + '_form'); - form.setAttribute('method', meta.method); - form.setAttribute('enctype', 'multipart/form-data'); - form.setAttribute('encoding', 'multipart/form-data'); - form.setAttribute('target', uid + '_iframe'); - - I.getShimContainer().appendChild(form); - } - - if (data instanceof FormData) { - data.each(function(value, name) { - if (value instanceof Blob) { - if (input) { - input.setAttribute('name', name); - } - } else { - var hidden = document.createElement('input'); - - Basic.extend(hidden, { - type : 'hidden', - name : name, - value : value - }); - - // make sure that input[type="file"], if it's there, comes last - if (input) { - form.insertBefore(hidden, input); - } else { - form.appendChild(hidden); - } - } - }); - } - - // set destination url - form.setAttribute("action", meta.url); - - createIframe(); - form.submit(); - target.trigger('loadstart'); - }, - - getStatus: function() { - return _status; - }, - - getResponse: function(responseType) { - if ('json' === responseType) { - // strip off
      ..
      tags that might be enclosing the response - if (Basic.typeOf(_response) === 'string' && !!window.JSON) { - try { - return JSON.parse(_response.replace(/^\s*]*>/, '').replace(/<\/pre>\s*$/, '')); - } catch (ex) { - return null; - } - } - } else if ('document' === responseType) { - - } - return _response; - }, - - abort: function() { - var target = this; - - if (_iframe && _iframe.contentWindow) { - if (_iframe.contentWindow.stop) { // FireFox/Safari/Chrome - _iframe.contentWindow.stop(); - } else if (_iframe.contentWindow.document.execCommand) { // IE - _iframe.contentWindow.document.execCommand('Stop'); - } else { - _iframe.src = "about:blank"; - } - } - - cleanup.call(this, function() { - // target.dispatchEvent('readystatechange'); - target.dispatchEvent('abort'); - }); - } - }); - } - - return (extensions.XMLHttpRequest = XMLHttpRequest); -}); - -// Included from: src/javascript/runtime/html4/image/Image.js - -/** - * Image.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/** -@class moxie/runtime/html4/image/Image -@private -*/ -define("moxie/runtime/html4/image/Image", [ - "moxie/runtime/html4/Runtime", - "moxie/runtime/html5/image/Image" -], function(extensions, Image) { - return (extensions.Image = Image); -}); - -expose(["moxie/core/utils/Basic","moxie/core/I18n","moxie/core/utils/Mime","moxie/core/utils/Env","moxie/core/utils/Dom","moxie/core/Exceptions","moxie/core/EventTarget","moxie/core/utils/Encode","moxie/runtime/Runtime","moxie/runtime/RuntimeClient","moxie/file/Blob","moxie/file/File","moxie/file/FileInput","moxie/file/FileDrop","moxie/runtime/RuntimeTarget","moxie/file/FileReader","moxie/core/utils/Url","moxie/file/FileReaderSync","moxie/xhr/FormData","moxie/xhr/XMLHttpRequest","moxie/runtime/Transporter","moxie/image/Image","moxie/core/utils/Events"]); -})(this);/** - * o.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/*global moxie:true */ - -/** -Globally exposed namespace with the most frequently used public classes and handy methods. - -@class o -@static -@private -*/ -(function() { - "use strict"; - - var o = {}, inArray = moxie.core.utils.Basic.inArray; - - // directly add some public classes - // (we do it dynamically here, since for custom builds we cannot know beforehand what modules were included) - (function addAlias(ns) { - var name, itemType; - for (name in ns) { - itemType = typeof(ns[name]); - if (itemType === 'object' && !~inArray(name, ['Exceptions', 'Env', 'Mime'])) { - addAlias(ns[name]); - } else if (itemType === 'function') { - o[name] = ns[name]; - } - } - })(window.moxie); - - // add some manually - o.Env = window.moxie.core.utils.Env; - o.Mime = window.moxie.core.utils.Mime; - o.Exceptions = window.moxie.core.Exceptions; - - // expose globally - window.mOxie = o; - if (!window.o) { - window.o = o; - } - return o; -})(); diff --git a/demo/js/plupload/moxie.min.js b/demo/js/plupload/moxie.min.js deleted file mode 100644 index 99e119ef..00000000 --- a/demo/js/plupload/moxie.min.js +++ /dev/null @@ -1,15 +0,0 @@ -/** - * mOxie - multi-runtime File API & XMLHttpRequest L2 Polyfill - * v1.2.0 - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - * - * Date: 2014-01-16 - */ -!function(e,t){"use strict";function n(e,t){for(var n,i=[],r=0;r0&&n(o,function(n,o){n!==r&&(e(i[o])===e(n)&&~a(e(n),["array","object"])?t(i[o],n):i[o]=n)})}),i},n=function(e,t){var n,i,r,o;if(e){try{n=e.length}catch(a){n=o}if(n===o){for(i in e)if(e.hasOwnProperty(i)&&t(e[i],i)===!1)return}else for(r=0;n>r;r++)if(t(e[r],r)===!1)return}},i=function(t){var n;if(!t||"object"!==e(t))return!0;for(n in t)return!1;return!0},r=function(t,n){function i(r){"function"===e(t[r])&&t[r](function(e){++rn;n++)if(t[n]===e)return n}return-1},s=function(t,n){var i=[];"array"!==e(t)&&(t=[t]),"array"!==e(n)&&(n=[n]);for(var r in t)-1===a(t[r],n)&&i.push(t[r]);return i.length?i:!1},u=function(e,t){var i=[];return n(e,function(e){-1!==a(e,t)&&i.push(e)}),i.length?i:null},c=function(e){var t,n=[];for(t=0;ti;i++)n+=Math.floor(65535*Math.random()).toString(32);return(t||"o_")+n+(e++).toString(32)}}(),d=function(e){return e?String.prototype.trim?String.prototype.trim.call(e):e.toString().replace(/^\s*/,"").replace(/\s*$/,""):e},f=function(e){if("string"!=typeof e)return e;var t={t:1099511627776,g:1073741824,m:1048576,k:1024},n;return e=/^([0-9]+)([mgk]?)$/.exec(e.toLowerCase().replace(/[^0-9mkg]/g,"")),n=e[2],e=+e[1],t.hasOwnProperty(n)&&(e*=t[n]),e};return{guid:l,typeOf:e,extend:t,each:n,isEmptyObj:i,inSeries:r,inParallel:o,inArray:a,arrayDiff:s,arrayIntersect:u,toArray:c,trim:d,parseSizeStr:f}}),i(c,[u],function(e){var t={};return{addI18n:function(n){return e.extend(t,n)},translate:function(e){return t[e]||e},_:function(e){return this.translate(e)},sprintf:function(t){var n=[].slice.call(arguments,1);return t.replace(/%[a-z]/g,function(){var t=n.shift();return"undefined"!==e.typeOf(t)?t:""})}}}),i(l,[u,c],function(e,t){var n="application/msword,doc dot,application/pdf,pdf,application/pgp-signature,pgp,application/postscript,ps ai eps,application/rtf,rtf,application/vnd.ms-excel,xls xlb,application/vnd.ms-powerpoint,ppt pps pot,application/zip,zip,application/x-shockwave-flash,swf swfl,application/vnd.openxmlformats-officedocument.wordprocessingml.document,docx,application/vnd.openxmlformats-officedocument.wordprocessingml.template,dotx,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,xlsx,application/vnd.openxmlformats-officedocument.presentationml.presentation,pptx,application/vnd.openxmlformats-officedocument.presentationml.template,potx,application/vnd.openxmlformats-officedocument.presentationml.slideshow,ppsx,application/x-javascript,js,application/json,json,audio/mpeg,mp3 mpga mpega mp2,audio/x-wav,wav,audio/x-m4a,m4a,audio/ogg,oga ogg,audio/aiff,aiff aif,audio/flac,flac,audio/aac,aac,audio/ac3,ac3,audio/x-ms-wma,wma,image/bmp,bmp,image/gif,gif,image/jpeg,jpg jpeg jpe,image/photoshop,psd,image/png,png,image/svg+xml,svg svgz,image/tiff,tiff tif,text/plain,asc txt text diff log,text/html,htm html xhtml,text/css,css,text/csv,csv,text/rtf,rtf,video/mpeg,mpeg mpg mpe m2v,video/quicktime,qt mov,video/mp4,mp4,video/x-m4v,m4v,video/x-flv,flv,video/x-ms-wmv,wmv,video/avi,avi,video/webm,webm,video/3gpp,3gpp 3gp,video/3gpp2,3g2,video/vnd.rn-realvideo,rv,video/ogg,ogv,video/x-matroska,mkv,application/vnd.oasis.opendocument.formula-template,otf,application/octet-stream,exe",i={mimes:{},extensions:{},addMimeType:function(e){var t=e.split(/,/),n,i,r;for(n=0;ni;i++)if(e[i]!=t[i]){if(e[i]=u(e[i]),t[i]=u(t[i]),e[i]t[i]){o=1;break}}if(!n)return o;switch(n){case">":case"gt":return o>0;case">=":case"ge":return o>=0;case"<=":case"le":return 0>=o;case"==":case"=":case"eq":return 0===o;case"<>":case"!=":case"ne":return 0!==o;case"":case"<":case"lt":return 0>o;default:return null}}var n=function(e){var t="",n="?",i="function",r="undefined",o="object",a="major",s="model",u="name",c="type",l="vendor",d="version",f="architecture",p="console",h="mobile",m="tablet",g={has:function(e,t){return-1!==t.toLowerCase().indexOf(e.toLowerCase())},lowerize:function(e){return e.toLowerCase()}},v={rgx:function(){for(var t,n=0,a,s,u,c,l,d,f=arguments;n0?2==c.length?t[c[0]]=typeof c[1]==i?c[1].call(this,d):c[1]:3==c.length?t[c[0]]=typeof c[1]!==i||c[1].exec&&c[1].test?d?d.replace(c[1],c[2]):e:d?c[1].call(this,d,c[2]):e:4==c.length&&(t[c[0]]=d?c[3].call(this,d.replace(c[1],c[2])):e):t[c]=d?d:e;break}if(l)break}return t},str:function(t,i){for(var r in i)if(typeof i[r]===o&&i[r].length>0){for(var a=0;a=9)},use_data_uri_of:function(e){return t.use_data_uri&&33e3>e||t.use_data_uri_over32kb()},use_fileinput:function(){var e=document.createElement("input");return e.setAttribute("type","file"),!e.disabled}};return function(n){var i=[].slice.call(arguments);return i.shift(),"function"===e.typeOf(t[n])?t[n].apply(this,i):!!t[n]}}(),r={can:i,browser:n.browser.name,version:parseFloat(n.browser.major),os:n.os.name,osVersion:n.os.version,verComp:t,swf_url:"../flash/Moxie.swf",xap_url:"../silverlight/Moxie.xap",global_event_dispatcher:"moxie.core.EventTarget.instance.dispatchEvent"};return r.OS=r.os,r}),i(f,[d],function(e){var t=function(e){return"string"!=typeof e?e:document.getElementById(e)},n=function(e,t){if(!e.className)return!1;var n=new RegExp("(^|\\s+)"+t+"(\\s+|$)");return n.test(e.className)},i=function(e,t){n(e,t)||(e.className=e.className?e.className.replace(/\s+$/,"")+" "+t:t)},r=function(e,t){if(e.className){var n=new RegExp("(^|\\s+)"+t+"(\\s+|$)");e.className=e.className.replace(n,function(e,t,n){return" "===t&&" "===n?" ":""})}},o=function(e,t){return e.currentStyle?e.currentStyle[t]:window.getComputedStyle?window.getComputedStyle(e,null)[t]:void 0},a=function(t,n){function i(e){var t,n,i=0,r=0;return e&&(n=e.getBoundingClientRect(),t="CSS1Compat"===s.compatMode?s.documentElement:s.body,i=n.left+t.scrollLeft,r=n.top+t.scrollTop),{x:i,y:r}}var r=0,o=0,a,s=document,u,c;if(t=t,n=n||s.body,t&&t.getBoundingClientRect&&"IE"===e.browser&&(!s.documentMode||s.documentMode<8))return u=i(t),c=i(n),{x:u.x-c.x,y:u.y-c.y};for(a=t;a&&a!=n&&a.nodeType;)r+=a.offsetLeft||0,o+=a.offsetTop||0,a=a.offsetParent;for(a=t.parentNode;a&&a!=n&&a.nodeType;)r-=a.scrollLeft||0,o-=a.scrollTop||0,a=a.parentNode;return{x:r,y:o}},s=function(e){return{w:e.offsetWidth||e.clientWidth,h:e.offsetHeight||e.clientHeight}};return{get:t,hasClass:n,addClass:i,removeClass:r,getStyle:o,getPos:a,getSize:s}}),i(p,[u],function(e){function t(e,t){var n;for(n in e)if(e[n]===t)return n;return null}return{RuntimeError:function(){function n(e){this.code=e,this.name=t(i,e),this.message=this.name+": RuntimeError "+this.code}var i={NOT_INIT_ERR:1,NOT_SUPPORTED_ERR:9,JS_ERR:4};return e.extend(n,i),n.prototype=Error.prototype,n}(),OperationNotAllowedException:function(){function t(e){this.code=e,this.name="OperationNotAllowedException"}return e.extend(t,{NOT_ALLOWED_ERR:1}),t.prototype=Error.prototype,t}(),ImageError:function(){function n(e){this.code=e,this.name=t(i,e),this.message=this.name+": ImageError "+this.code}var i={WRONG_FORMAT:1,MAX_RESOLUTION_ERR:2};return e.extend(n,i),n.prototype=Error.prototype,n}(),FileException:function(){function n(e){this.code=e,this.name=t(i,e),this.message=this.name+": FileException "+this.code}var i={NOT_FOUND_ERR:1,SECURITY_ERR:2,ABORT_ERR:3,NOT_READABLE_ERR:4,ENCODING_ERR:5,NO_MODIFICATION_ALLOWED_ERR:6,INVALID_STATE_ERR:7,SYNTAX_ERR:8};return e.extend(n,i),n.prototype=Error.prototype,n}(),DOMException:function(){function n(e){this.code=e,this.name=t(i,e),this.message=this.name+": DOMException "+this.code}var i={INDEX_SIZE_ERR:1,DOMSTRING_SIZE_ERR:2,HIERARCHY_REQUEST_ERR:3,WRONG_DOCUMENT_ERR:4,INVALID_CHARACTER_ERR:5,NO_DATA_ALLOWED_ERR:6,NO_MODIFICATION_ALLOWED_ERR:7,NOT_FOUND_ERR:8,NOT_SUPPORTED_ERR:9,INUSE_ATTRIBUTE_ERR:10,INVALID_STATE_ERR:11,SYNTAX_ERR:12,INVALID_MODIFICATION_ERR:13,NAMESPACE_ERR:14,INVALID_ACCESS_ERR:15,VALIDATION_ERR:16,TYPE_MISMATCH_ERR:17,SECURITY_ERR:18,NETWORK_ERR:19,ABORT_ERR:20,URL_MISMATCH_ERR:21,QUOTA_EXCEEDED_ERR:22,TIMEOUT_ERR:23,INVALID_NODE_TYPE_ERR:24,DATA_CLONE_ERR:25};return e.extend(n,i),n.prototype=Error.prototype,n}(),EventException:function(){function t(e){this.code=e,this.name="EventException"}return e.extend(t,{UNSPECIFIED_EVENT_TYPE_ERR:0}),t.prototype=Error.prototype,t}()}}),i(h,[p,u],function(e,t){function n(){var n={};t.extend(this,{uid:null,init:function(){this.uid||(this.uid=t.guid("uid_"))},addEventListener:function(e,i,r,o){var a=this,s;return e=t.trim(e),/\s/.test(e)?(t.each(e.split(/\s+/),function(e){a.addEventListener(e,i,r,o)}),void 0):(e=e.toLowerCase(),r=parseInt(r,10)||0,s=n[this.uid]&&n[this.uid][e]||[],s.push({fn:i,priority:r,scope:o||this}),n[this.uid]||(n[this.uid]={}),n[this.uid][e]=s,void 0)},hasEventListener:function(e){return e?!(!n[this.uid]||!n[this.uid][e]):!!n[this.uid]},removeEventListener:function(e,i){e=e.toLowerCase();var r=n[this.uid]&&n[this.uid][e],o;if(r){if(i){for(o=r.length-1;o>=0;o--)if(r[o].fn===i){r.splice(o,1);break}}else r=[];r.length||(delete n[this.uid][e],t.isEmptyObj(n[this.uid])&&delete n[this.uid])}},removeAllEventListeners:function(){n[this.uid]&&delete n[this.uid]},dispatchEvent:function(i){var r,o,a,s,u={},c=!0,l;if("string"!==t.typeOf(i)){if(s=i,"string"!==t.typeOf(s.type))throw new e.EventException(e.EventException.UNSPECIFIED_EVENT_TYPE_ERR);i=s.type,s.total!==l&&s.loaded!==l&&(u.total=s.total,u.loaded=s.loaded),u.async=s.async||!1}if(-1!==i.indexOf("::")?function(e){r=e[0],i=e[1]}(i.split("::")):r=this.uid,i=i.toLowerCase(),o=n[r]&&n[r][i]){o.sort(function(e,t){return t.priority-e.priority}),a=[].slice.call(arguments),a.shift(),u.type=i,a.unshift(u);var d=[];t.each(o,function(e){a[0].target=e.scope,u.async?d.push(function(t){setTimeout(function(){t(e.fn.apply(e.scope,a)===!1)},1)}):d.push(function(t){t(e.fn.apply(e.scope,a)===!1)})}),d.length&&t.inSeries(d,function(e){c=!e})}return c},bind:function(){this.addEventListener.apply(this,arguments)},unbind:function(){this.removeEventListener.apply(this,arguments)},unbindAll:function(){this.removeAllEventListeners.apply(this,arguments)},trigger:function(){return this.dispatchEvent.apply(this,arguments)},convertEventPropsToHandlers:function(e){var n;"array"!==t.typeOf(e)&&(e=[e]);for(var i=0;i>16,o=255&d>>8,a=255&d,m[p++]=64==c?String.fromCharCode(r):64==l?String.fromCharCode(r,o):String.fromCharCode(r,o,a);while(f>18,u=63&d>>12,c=63&d>>6,l=63&d,m[p++]=i.charAt(s)+i.charAt(u)+i.charAt(c)+i.charAt(l);while(fa;a++)o+=String.fromCharCode(r[a]);return o}}t.call(this),e.extend(this,{uid:e.guid("uid_"),readAsBinaryString:function(e){return i.call(this,"readAsBinaryString",e)},readAsDataURL:function(e){return i.call(this,"readAsDataURL",e)},readAsText:function(e){return i.call(this,"readAsText",e)}})}}),i(S,[p,u,y],function(e,t,n){function i(){var e,i=[];t.extend(this,{append:function(r,o){var a=this,s=t.typeOf(o);o instanceof n?e={name:r,value:o}:"array"===s?(r+="[]",t.each(o,function(e){a.append(r,e)})):"object"===s?t.each(o,function(e,t){a.append(r+"["+t+"]",e)}):"null"===s||"undefined"===s||"number"===s&&isNaN(o)?a.append(r,"false"):i.push({name:r,value:o.toString()})},hasBlob:function(){return!!this.getBlob()},getBlob:function(){return e&&e.value||null},getBlobName:function(){return e&&e.name||null},each:function(n){t.each(i,function(e){n(e.value,e.name)}),e&&n(e.value,e.name)},destroy:function(){e=null,i=[]}})}return i}),i(A,[u,p,h,m,b,g,x,y,T,S,d,l],function(e,t,n,i,r,o,a,s,u,c,l,d){function f(){this.uid=e.guid("uid_")}function p(){function n(e,t){return y.hasOwnProperty(e)?1===arguments.length?l.can("define_property")?y[e]:v[e]:(l.can("define_property")?y[e]=t:v[e]=t,void 0):void 0}function u(t){function i(){k.destroy(),k=null,s.dispatchEvent("loadend"),s=null}function r(r){k.bind("LoadStart",function(e){n("readyState",p.LOADING),s.dispatchEvent("readystatechange"),s.dispatchEvent(e),I&&s.upload.dispatchEvent(e)}),k.bind("Progress",function(e){n("readyState")!==p.LOADING&&(n("readyState",p.LOADING),s.dispatchEvent("readystatechange")),s.dispatchEvent(e)}),k.bind("UploadProgress",function(e){I&&s.upload.dispatchEvent({type:"progress",lengthComputable:!1,total:e.total,loaded:e.loaded})}),k.bind("Load",function(t){n("readyState",p.DONE),n("status",Number(r.exec.call(k,"XMLHttpRequest","getStatus")||0)),n("statusText",h[n("status")]||""),n("response",r.exec.call(k,"XMLHttpRequest","getResponse",n("responseType"))),~e.inArray(n("responseType"),["text",""])?n("responseText",n("response")):"document"===n("responseType")&&n("responseXML",n("response")),U=r.exec.call(k,"XMLHttpRequest","getAllResponseHeaders"),s.dispatchEvent("readystatechange"),n("status")>0?(I&&s.upload.dispatchEvent(t),s.dispatchEvent(t)):(N=!0,s.dispatchEvent("error")),i()}),k.bind("Abort",function(e){s.dispatchEvent(e),i()}),k.bind("Error",function(e){N=!0,n("readyState",p.DONE),s.dispatchEvent("readystatechange"),D=!0,s.dispatchEvent(e),i()}),r.exec.call(k,"XMLHttpRequest","send",{url:E,method:_,async:w,user:R,password:b,headers:x,mimeType:S,encoding:T,responseType:s.responseType,withCredentials:s.withCredentials,options:P},t)}var s=this;M=(new Date).getTime(),k=new a,"string"==typeof P.required_caps&&(P.required_caps=o.parseCaps(P.required_caps)),P.required_caps=e.extend({},P.required_caps,{return_response_type:s.responseType}),t instanceof c&&(P.required_caps.send_multipart=!0),L||(P.required_caps.do_cors=!0),P.ruid?r(k.connectRuntime(P)):(k.bind("RuntimeInit",function(e,t){r(t)}),k.bind("RuntimeError",function(e,t){s.dispatchEvent("RuntimeError",t)}),k.connectRuntime(P))}function g(){n("responseText",""),n("responseXML",null),n("response",null),n("status",0),n("statusText",""),M=C=null}var v=this,y={timeout:0,readyState:p.UNSENT,withCredentials:!1,status:0,statusText:"",responseType:"",responseXML:null,responseText:null,response:null},w=!0,E,_,x={},R,b,T=null,S=null,A=!1,O=!1,I=!1,D=!1,N=!1,L=!1,M,C,F=null,H=null,P={},k,U="",B;e.extend(this,y,{uid:e.guid("uid_"),upload:new f,open:function(o,a,s,u,c){var l;if(!o||!a)throw new t.DOMException(t.DOMException.SYNTAX_ERR);if(/[\u0100-\uffff]/.test(o)||i.utf8_encode(o)!==o)throw new t.DOMException(t.DOMException.SYNTAX_ERR);if(~e.inArray(o.toUpperCase(),["CONNECT","DELETE","GET","HEAD","OPTIONS","POST","PUT","TRACE","TRACK"])&&(_=o.toUpperCase()),~e.inArray(_,["CONNECT","TRACE","TRACK"]))throw new t.DOMException(t.DOMException.SECURITY_ERR);if(a=i.utf8_encode(a),l=r.parseUrl(a),L=r.hasSameOrigin(l),E=r.resolveUrl(a),(u||c)&&!L)throw new t.DOMException(t.DOMException.INVALID_ACCESS_ERR);if(R=u||l.user,b=c||l.pass,w=s||!0,w===!1&&(n("timeout")||n("withCredentials")||""!==n("responseType")))throw new t.DOMException(t.DOMException.INVALID_ACCESS_ERR);A=!w,O=!1,x={},g.call(this),n("readyState",p.OPENED),this.convertEventPropsToHandlers(["readystatechange"]),this.dispatchEvent("readystatechange")},setRequestHeader:function(r,o){var a=["accept-charset","accept-encoding","access-control-request-headers","access-control-request-method","connection","content-length","cookie","cookie2","content-transfer-encoding","date","expect","host","keep-alive","origin","referer","te","trailer","transfer-encoding","upgrade","user-agent","via"];if(n("readyState")!==p.OPENED||O)throw new t.DOMException(t.DOMException.INVALID_STATE_ERR);if(/[\u0100-\uffff]/.test(r)||i.utf8_encode(r)!==r)throw new t.DOMException(t.DOMException.SYNTAX_ERR);return r=e.trim(r).toLowerCase(),~e.inArray(r,a)||/^(proxy\-|sec\-)/.test(r)?!1:(x[r]?x[r]+=", "+o:x[r]=o,!0)},getAllResponseHeaders:function(){return U||""},getResponseHeader:function(t){return t=t.toLowerCase(),N||~e.inArray(t,["set-cookie","set-cookie2"])?null:U&&""!==U&&(B||(B={},e.each(U.split(/\r\n/),function(t){var n=t.split(/:\s+/);2===n.length&&(n[0]=e.trim(n[0]),B[n[0].toLowerCase()]={header:n[0],value:e.trim(n[1])})})),B.hasOwnProperty(t))?B[t].header+": "+B[t].value:null},overrideMimeType:function(i){var r,o;if(~e.inArray(n("readyState"),[p.LOADING,p.DONE]))throw new t.DOMException(t.DOMException.INVALID_STATE_ERR);if(i=e.trim(i.toLowerCase()),/;/.test(i)&&(r=i.match(/^([^;]+)(?:;\scharset\=)?(.*)$/))&&(i=r[1],r[2]&&(o=r[2])),!d.mimes[i])throw new t.DOMException(t.DOMException.SYNTAX_ERR);F=i,H=o},send:function(n,r){if(P="string"===e.typeOf(r)?{ruid:r}:r?r:{},this.convertEventPropsToHandlers(m),this.upload.convertEventPropsToHandlers(m),this.readyState!==p.OPENED||O)throw new t.DOMException(t.DOMException.INVALID_STATE_ERR);if(n instanceof s)P.ruid=n.ruid,S=n.type||"application/octet-stream";else if(n instanceof c){if(n.hasBlob()){var o=n.getBlob();P.ruid=o.ruid,S=o.type||"application/octet-stream"}}else"string"==typeof n&&(T="UTF-8",S="text/plain;charset=UTF-8",n=i.utf8_encode(n));this.withCredentials||(this.withCredentials=P.required_caps&&P.required_caps.send_browser_cookies&&!L),I=!A&&this.upload.hasEventListener(),N=!1,D=!n,A||(O=!0),u.call(this,n)},abort:function(){if(N=!0,A=!1,~e.inArray(n("readyState"),[p.UNSENT,p.OPENED,p.DONE]))n("readyState",p.UNSENT);else{if(n("readyState",p.DONE),O=!1,!k)throw new t.DOMException(t.DOMException.INVALID_STATE_ERR);k.getRuntime().exec.call(k,"XMLHttpRequest","abort",D),D=!0}},destroy:function(){k&&("function"===e.typeOf(k.destroy)&&k.destroy(),k=null),this.unbindAll(),this.upload&&(this.upload.unbindAll(),this.upload=null)}})}var h={100:"Continue",101:"Switching Protocols",102:"Processing",200:"OK",201:"Created",202:"Accepted",203:"Non-Authoritative Information",204:"No Content",205:"Reset Content",206:"Partial Content",207:"Multi-Status",226:"IM Used",300:"Multiple Choices",301:"Moved Permanently",302:"Found",303:"See Other",304:"Not Modified",305:"Use Proxy",306:"Reserved",307:"Temporary Redirect",400:"Bad Request",401:"Unauthorized",402:"Payment Required",403:"Forbidden",404:"Not Found",405:"Method Not Allowed",406:"Not Acceptable",407:"Proxy Authentication Required",408:"Request Timeout",409:"Conflict",410:"Gone",411:"Length Required",412:"Precondition Failed",413:"Request Entity Too Large",414:"Request-URI Too Long",415:"Unsupported Media Type",416:"Requested Range Not Satisfiable",417:"Expectation Failed",422:"Unprocessable Entity",423:"Locked",424:"Failed Dependency",426:"Upgrade Required",500:"Internal Server Error",501:"Not Implemented",502:"Bad Gateway",503:"Service Unavailable",504:"Gateway Timeout",505:"HTTP Version Not Supported",506:"Variant Also Negotiates",507:"Insufficient Storage",510:"Not Extended"};f.prototype=n.instance;var m=["loadstart","progress","abort","error","load","timeout","loadend"],g=1,v=2;return p.UNSENT=0,p.OPENED=1,p.HEADERS_RECEIVED=2,p.LOADING=3,p.DONE=4,p.prototype=n.instance,p}),i(O,[u,m,v,h],function(e,t,n,i){function r(){function i(){l=d=0,c=this.result=null}function o(t,n){var i=this;u=n,i.bind("TransportingProgress",function(t){d=t.loaded,l>d&&-1===e.inArray(i.state,[r.IDLE,r.DONE])&&a.call(i)},999),i.bind("TransportingComplete",function(){d=l,i.state=r.DONE,c=null,i.result=u.exec.call(i,"Transporter","getAsBlob",t||"")},999),i.state=r.BUSY,i.trigger("TransportingStarted"),a.call(i)}function a(){var e=this,n,i=l-d;f>i&&(f=i),n=t.btoa(c.substr(d,f)),u.exec.call(e,"Transporter","receive",n,l)}var s,u,c,l,d,f;n.call(this),e.extend(this,{uid:e.guid("uid_"),state:r.IDLE,result:null,transport:function(t,n,r){var a=this;if(r=e.extend({chunk_size:204798},r),(s=r.chunk_size%3)&&(r.chunk_size+=3-s),f=r.chunk_size,i.call(this),c=t,l=t.length,"string"===e.typeOf(r)||r.ruid)o.call(a,n,this.connectRuntime(r));else{var u=function(e,t){a.unbind("RuntimeInit",u),o.call(a,n,t)};this.bind("RuntimeInit",u),this.connectRuntime(r)}},abort:function(){var e=this;e.state=r.IDLE,u&&(u.exec.call(e,"Transporter","clear"),e.trigger("TransportingAborted")),i.call(e)},destroy:function(){this.unbindAll(),u=null,this.disconnectRuntime(),i.call(this)}})}return r.IDLE=0,r.BUSY=1,r.DONE=2,r.prototype=i.instance,r}),i(I,[u,f,p,T,A,g,v,O,d,h,y,w,m],function(e,t,n,i,r,o,a,s,u,c,l,d,f){function p(){function i(e){e||(e=this.getRuntime().exec.call(this,"Image","getInfo")),this.size=e.size,this.width=e.width,this.height=e.height,this.type=e.type,this.meta=e.meta,""===this.name&&(this.name=e.name)}function c(t){var i=e.typeOf(t);try{if(t instanceof p){if(!t.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);m.apply(this,arguments)}else if(t instanceof l){if(!~e.inArray(t.type,["image/jpeg","image/png"]))throw new n.ImageError(n.ImageError.WRONG_FORMAT);g.apply(this,arguments)}else if(-1!==e.inArray(i,["blob","file"]))c.call(this,new d(null,t),arguments[1]);else if("string"===i)/^data:[^;]*;base64,/.test(t)?c.call(this,new l(null,{data:t}),arguments[1]):v.apply(this,arguments);else{if("node"!==i||"img"!==t.nodeName.toLowerCase())throw new n.DOMException(n.DOMException.TYPE_MISMATCH_ERR);c.call(this,t.src,arguments[1])}}catch(r){this.trigger("error",r)}}function m(t,n){var i=this.connectRuntime(t.ruid);this.ruid=i.uid,i.exec.call(this,"Image","loadFromImage",t,"undefined"===e.typeOf(n)?!0:n)}function g(t,n){function i(e){r.ruid=e.uid,e.exec.call(r,"Image","loadFromBlob",t)}var r=this;r.name=t.name||"",t.isDetached()?(this.bind("RuntimeInit",function(e,t){i(t)}),n&&"string"==typeof n.required_caps&&(n.required_caps=o.parseCaps(n.required_caps)),this.connectRuntime(e.extend({required_caps:{access_image_binary:!0,resize_image:!0}},n))):i(this.connectRuntime(t.ruid))}function v(e,t){var n=this,i;i=new r,i.open("get",e),i.responseType="blob",i.onprogress=function(e){n.trigger(e)},i.onload=function(){g.call(n,i.response,!0)},i.onerror=function(e){n.trigger(e)},i.onloadend=function(){i.destroy()},i.bind("RuntimeError",function(e,t){n.trigger("RuntimeError",t)}),i.send(null,t)}a.call(this),e.extend(this,{uid:e.guid("uid_"),ruid:null,name:"",size:0,width:0,height:0,type:"",meta:{},clone:function(){this.load.apply(this,arguments)},load:function(){this.bind("Load Resize",function(){i.call(this)},999),this.convertEventPropsToHandlers(h),c.apply(this,arguments)},downsize:function(t,i,r,o){try{if(!this.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);if(this.width>p.MAX_RESIZE_WIDTH||this.height>p.MAX_RESIZE_HEIGHT)throw new n.ImageError(n.ImageError.MAX_RESOLUTION_ERR);(!t&&!i||"undefined"===e.typeOf(r))&&(r=!1),t=t||this.width,i=i||this.height,o="undefined"===e.typeOf(o)?!0:!!o,this.getRuntime().exec.call(this,"Image","downsize",t,i,r,o)}catch(a){this.trigger("error",a)}},crop:function(e,t,n){this.downsize(e,t,!0,n)},getAsCanvas:function(){if(!u.can("create_canvas"))throw new n.RuntimeError(n.RuntimeError.NOT_SUPPORTED_ERR);var e=this.connectRuntime(this.ruid);return e.exec.call(this,"Image","getAsCanvas")},getAsBlob:function(e,t){if(!this.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);return e||(e="image/jpeg"),"image/jpeg"!==e||t||(t=90),this.getRuntime().exec.call(this,"Image","getAsBlob",e,t)},getAsDataURL:function(e,t){if(!this.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);return this.getRuntime().exec.call(this,"Image","getAsDataURL",e,t)},getAsBinaryString:function(e,t){var n=this.getAsDataURL(e,t);return f.atob(n.substring(n.indexOf("base64,")+7))},embed:function(i){function r(){if(u.can("create_canvas")){var t=a.getAsCanvas();if(t)return i.appendChild(t),t=null,a.destroy(),o.trigger("embedded"),void 0}var r=a.getAsDataURL(c,l);if(!r)throw new n.ImageError(n.ImageError.WRONG_FORMAT);if(u.can("use_data_uri_of",r.length))i.innerHTML='',a.destroy(),o.trigger("embedded");else{var d=new s;d.bind("TransportingComplete",function(){v=o.connectRuntime(this.result.ruid),o.bind("Embedded",function(){e.extend(v.getShimContainer().style,{top:"0px",left:"0px",width:a.width+"px",height:a.height+"px"}),v=null},999),v.exec.call(o,"ImageView","display",this.result.uid,m,g),a.destroy()}),d.transport(f.atob(r.substring(r.indexOf("base64,")+7)),c,e.extend({},h,{required_caps:{display_media:!0},runtime_order:"flash,silverlight",container:i}))}}var o=this,a,c,l,d,h=arguments[1]||{},m=this.width,g=this.height,v;try{if(!(i=t.get(i)))throw new n.DOMException(n.DOMException.INVALID_NODE_TYPE_ERR);if(!this.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);if(this.width>p.MAX_RESIZE_WIDTH||this.height>p.MAX_RESIZE_HEIGHT)throw new n.ImageError(n.ImageError.MAX_RESOLUTION_ERR);if(c=h.type||this.type||"image/jpeg",l=h.quality||90,d="undefined"!==e.typeOf(h.crop)?h.crop:!1,h.width)m=h.width,g=h.height||m;else{var y=t.getSize(i);y.w&&y.h&&(m=y.w,g=y.h)}return a=new p,a.bind("Resize",function(){r.call(o)}),a.bind("Load",function(){a.downsize(m,g,d,!1)}),a.clone(this,!1),a}catch(w){this.trigger("error",w)}},destroy:function(){this.ruid&&(this.getRuntime().exec.call(this,"Image","destroy"),this.disconnectRuntime()),this.unbindAll()}})}var h=["progress","load","error","resize","embedded"];return p.MAX_RESIZE_WIDTH=6500,p.MAX_RESIZE_HEIGHT=6500,p.prototype=c.instance,p}),i(D,[u,p,g,d],function(e,t,n,i){function r(t){var r=this,s=n.capTest,u=n.capTrue,c=e.extend({access_binary:s(window.FileReader||window.File&&window.File.getAsDataURL),access_image_binary:function(){return r.can("access_binary")&&!!a.Image},display_media:s(i.can("create_canvas")||i.can("use_data_uri_over32kb")),do_cors:s(window.XMLHttpRequest&&"withCredentials"in new XMLHttpRequest),drag_and_drop:s(function(){var e=document.createElement("div");return("draggable"in e||"ondragstart"in e&&"ondrop"in e)&&("IE"!==i.browser||i.version>9)}()),filter_by_extension:s(function(){return"Chrome"===i.browser&&i.version>=28||"IE"===i.browser&&i.version>=10}()),return_response_headers:u,return_response_type:function(e){return"json"===e&&window.JSON?!0:i.can("return_response_type",e)},return_status_code:u,report_upload_progress:s(window.XMLHttpRequest&&(new XMLHttpRequest).upload),resize_image:function(){return r.can("access_binary")&&i.can("create_canvas")},select_file:function(){return i.can("use_fileinput")&&window.File},select_folder:function(){return r.can("select_file")&&"Chrome"===i.browser&&i.version>=21},select_multiple:function(){return!(!r.can("select_file")||"Safari"===i.browser&&"Windows"===i.os||"iOS"===i.os&&i.verComp(i.osVersion,"7.0.4","<"))},send_binary_string:s(window.XMLHttpRequest&&((new XMLHttpRequest).sendAsBinary||window.Uint8Array&&window.ArrayBuffer)),send_custom_headers:s(window.XMLHttpRequest),send_multipart:function(){return!!(window.XMLHttpRequest&&(new XMLHttpRequest).upload&&window.FormData)||r.can("send_binary_string")},slice_blob:s(window.File&&(File.prototype.mozSlice||File.prototype.webkitSlice||File.prototype.slice)),stream_upload:function(){return r.can("slice_blob")&&r.can("send_multipart")},summon_file_dialog:s(function(){return"Firefox"===i.browser&&i.version>=4||"Opera"===i.browser&&i.version>=12||"IE"===i.browser&&i.version>=10||!!~e.inArray(i.browser,["Chrome","Safari"])}()),upload_filesize:u},arguments[2]);n.call(this,t,arguments[1]||o,c),e.extend(this,{init:function(){this.trigger("Init")},destroy:function(e){return function(){e.call(r),e=r=null}}(this.destroy)}),e.extend(this.getShim(),a)}var o="html5",a={};return n.addConstructor(o,r),a}),i(N,[D,y],function(e,t){function n(){function e(e,t,n){var i;if(!window.File.prototype.slice)return(i=window.File.prototype.webkitSlice||window.File.prototype.mozSlice)?i.call(e,t,n):null;try{return e.slice(),e.slice(t,n)}catch(r){return e.slice(t,n-t)}}this.slice=function(){return new t(this.getRuntime().uid,e.apply(this,arguments))}}return e.Blob=n}),i(L,[u],function(e){function t(){this.returnValue=!1}function n(){this.cancelBubble=!0}var i={},r="moxie_"+e.guid(),o=function(o,a,s,u){var c,l;a=a.toLowerCase(),o.addEventListener?(c=s,o.addEventListener(a,c,!1)):o.attachEvent&&(c=function(){var e=window.event;e.target||(e.target=e.srcElement),e.preventDefault=t,e.stopPropagation=n,s(e)},o.attachEvent("on"+a,c)),o[r]||(o[r]=e.guid()),i.hasOwnProperty(o[r])||(i[o[r]]={}),l=i[o[r]],l.hasOwnProperty(a)||(l[a]=[]),l[a].push({func:c,orig:s,key:u})},a=function(t,n,o){var a,s;if(n=n.toLowerCase(),t[r]&&i[t[r]]&&i[t[r]][n]){a=i[t[r]][n];for(var u=a.length-1;u>=0&&(a[u].orig!==o&&a[u].key!==o||(t.removeEventListener?t.removeEventListener(n,a[u].func,!1):t.detachEvent&&t.detachEvent("on"+n,a[u].func),a[u].orig=null,a[u].func=null,a.splice(u,1),o===s));u--);if(a.length||delete i[t[r]][n],e.isEmptyObj(i[t[r]])){delete i[t[r]];try{delete t[r]}catch(c){t[r]=s}}}},s=function(t,n){t&&t[r]&&e.each(i[t[r]],function(e,i){a(t,i,n)})};return{addEvent:o,removeEvent:a,removeAllEvents:s}}),i(M,[D,u,f,L,l,d],function(e,t,n,i,r,o){function a(){var e=[],a;t.extend(this,{init:function(s){var u=this,c=u.getRuntime(),l,d,f,p,h,m;a=s,e=[],f=a.accept.mimes||r.extList2mimes(a.accept,c.can("filter_by_extension")),d=c.getShimContainer(),d.innerHTML='",l=n.get(c.uid),t.extend(l.style,{position:"absolute",top:0,left:0,width:"100%",height:"100%"}),p=n.get(a.browse_button),c.can("summon_file_dialog")&&("static"===n.getStyle(p,"position")&&(p.style.position="relative"),h=parseInt(n.getStyle(p,"z-index"),10)||1,p.style.zIndex=h,d.style.zIndex=h-1,i.addEvent(p,"click",function(e){var t=n.get(c.uid);t&&!t.disabled&&t.click(),e.preventDefault()},u.uid)),m=c.can("summon_file_dialog")?p:d,i.addEvent(m,"mouseover",function(){u.trigger("mouseenter")},u.uid),i.addEvent(m,"mouseout",function(){u.trigger("mouseleave")},u.uid),i.addEvent(m,"mousedown",function(){u.trigger("mousedown")},u.uid),i.addEvent(n.get(a.container),"mouseup",function(){u.trigger("mouseup")},u.uid),l.onchange=function g(){if(e=[],a.directory?t.each(this.files,function(t){"."!==t.name&&e.push(t)}):e=[].slice.call(this.files),"IE"!==o.browser)this.value="";else{var n=this.cloneNode(!0);this.parentNode.replaceChild(n,this),n.onchange=g}u.trigger("change")},u.trigger({type:"ready",async:!0}),d=null},getFiles:function(){return e},disable:function(e){var t=this.getRuntime(),i;(i=n.get(t.uid))&&(i.disabled=!!e)},destroy:function(){var t=this.getRuntime(),r=t.getShim(),o=t.getShimContainer();i.removeAllEvents(o,this.uid),i.removeAllEvents(a&&n.get(a.container),this.uid),i.removeAllEvents(a&&n.get(a.browse_button),this.uid),o&&(o.innerHTML=""),r.removeInstance(this.uid),e=a=o=r=null}})}return e.FileInput=a}),i(C,[D,u,f,L,l],function(e,t,n,i,r){function o(){function e(e){for(var n=[],i=0;i=4&&u.version<7,f="Android Browser"===u.browser,m=!1;if(h=n.url.replace(/^.+?\/([\w\-\.]+)$/,"$1").toLowerCase(),p=c(),p.open(n.method,n.url,n.async,n.user,n.password),r instanceof o)r.isDetached()&&(m=!0),r=r.getSource();else if(r instanceof a){if(r.hasBlob())if(r.getBlob().isDetached())r=d.call(s,r),m=!0;else if((l||f)&&"blob"===t.typeOf(r.getBlob().getSource())&&window.FileReader)return e.call(s,n,r),void 0;if(r instanceof a){var g=new window.FormData;r.each(function(e,t){e instanceof o?g.append(t,e.getSource()):g.append(t,e)}),r=g}}p.upload?(n.withCredentials&&(p.withCredentials=!0),p.addEventListener("load",function(e){s.trigger(e)}),p.addEventListener("error",function(e){s.trigger(e)}),p.addEventListener("progress",function(e){s.trigger(e)}),p.upload.addEventListener("progress",function(e){s.trigger({type:"UploadProgress",loaded:e.loaded,total:e.total})})):p.onreadystatechange=function v(){switch(p.readyState){case 1:break;case 2:break;case 3:var e,t;try{i.hasSameOrigin(n.url)&&(e=p.getResponseHeader("Content-Length")||0),p.responseText&&(t=p.responseText.length)}catch(r){e=t=0}s.trigger({type:"progress",lengthComputable:!!e,total:parseInt(e,10),loaded:t});break;case 4:p.onreadystatechange=function(){},0===p.status?s.trigger("error"):s.trigger("load")}},t.isEmptyObj(n.headers)||t.each(n.headers,function(e,t){p.setRequestHeader(t,e)}),""!==n.responseType&&"responseType"in p&&(p.responseType="json"!==n.responseType||u.can("return_response_type","json")?n.responseType:"text"),m?p.sendAsBinary?p.sendAsBinary(r):function(){for(var e=new Uint8Array(r.length),t=0;ta;a++)i|=o.charCodeAt(e+a)<s;s++)o+=String.fromCharCode(255&t>>Math.abs(a+8*s));n(o,e,i)}var r=!1,o;return{II:function(e){return e===t?r:(r=e,void 0)},init:function(e){r=!1,o=e},SEGMENT:function(e,t,i){switch(arguments.length){case 1:return o.substr(e,o.length-e-1);case 2:return o.substr(e,t);case 3:n(i,e,t);break;default:return o}},BYTE:function(t){return e(t,1)},SHORT:function(t){return e(t,2)},LONG:function(n,r){return r===t?e(n,4):(i(n,r,4),void 0)},SLONG:function(t){var n=e(t,4);return n>2147483647?n-4294967296:n},STRING:function(t,n){var i="";for(n+=t;n>t;t++)i+=String.fromCharCode(e(t,1));return i}}}}),i(k,[P],function(e){return function t(n){var i=[],r,o,a,s=0;if(r=new e,r.init(n),65496===r.SHORT(0)){for(o=2;o<=n.length;)if(a=r.SHORT(o),a>=65488&&65495>=a)o+=2;else{if(65498===a||65497===a)break;s=r.SHORT(o+2)+2,a>=65505&&65519>=a&&i.push({hex:a,name:"APP"+(15&a),start:o,length:s,segment:r.SEGMENT(o,s)}),o+=s}return r.init(null),{headers:i,restore:function(e){var t,n;for(r.init(e),o=65504==r.SHORT(2)?4+r.SHORT(4):2,n=0,t=i.length;t>n;n++)r.SEGMENT(o,0,i[n].segment),o+=i[n].length;return e=r.SEGMENT(),r.init(null),e},strip:function(e){var n,i,o;for(i=new t(e),n=i.headers,i.purge(),r.init(e),o=n.length;o--;)r.SEGMENT(n[o].start,n[o].length,"");return e=r.SEGMENT(),r.init(null),e},get:function(e){for(var t=[],n=0,r=i.length;r>n;n++)i[n].name===e.toUpperCase()&&t.push(i[n].segment);return t},set:function(e,t){var n=[],r,o,a;for("string"==typeof t?n.push(t):n=t,r=o=0,a=i.length;a>r&&(i[r].name===e.toUpperCase()&&(i[r].segment=n[o],i[r].length=n[o].length,o++),!(o>=n.length));r++);},purge:function(){i=[],r.init(null),r=null}}}}}),i(U,[u,P],function(e,n){return function i(){function i(e,n){var i=a.SHORT(e),r,o,s,u,d,f,p,h,m=[],g={};for(r=0;i>r;r++)if(p=f=e+12*r+2,s=n[a.SHORT(p)],s!==t){switch(u=a.SHORT(p+=2),d=a.LONG(p+=2),p+=4,m=[],u){case 1:case 7:for(d>4&&(p=a.LONG(p)+c.tiffHeader),o=0;d>o;o++)m[o]=a.BYTE(p+o);break;case 2:d>4&&(p=a.LONG(p)+c.tiffHeader),g[s]=a.STRING(p,d-1);continue;case 3:for(d>2&&(p=a.LONG(p)+c.tiffHeader),o=0;d>o;o++)m[o]=a.SHORT(p+2*o);break;case 4:for(d>1&&(p=a.LONG(p)+c.tiffHeader),o=0;d>o;o++)m[o]=a.LONG(p+4*o);break;case 5:for(p=a.LONG(p)+c.tiffHeader,o=0;d>o;o++)m[o]=a.LONG(p+4*o)/a.LONG(p+4*o+4);break;case 9:for(p=a.LONG(p)+c.tiffHeader,o=0;d>o;o++)m[o]=a.SLONG(p+4*o);break;case 10:for(p=a.LONG(p)+c.tiffHeader,o=0;d>o;o++)m[o]=a.SLONG(p+4*o)/a.SLONG(p+4*o+4);break;default:continue}h=1==d?m[0]:m,g[s]=l.hasOwnProperty(s)&&"object"!=typeof h?l[s][h]:h}return g}function r(){var e=c.tiffHeader;return a.II(18761==a.SHORT(e)),42!==a.SHORT(e+=2)?!1:(c.IFD0=c.tiffHeader+a.LONG(e+=2),u=i(c.IFD0,s.tiff),"ExifIFDPointer"in u&&(c.exifIFD=c.tiffHeader+u.ExifIFDPointer,delete u.ExifIFDPointer),"GPSInfoIFDPointer"in u&&(c.gpsIFD=c.tiffHeader+u.GPSInfoIFDPointer,delete u.GPSInfoIFDPointer),!0)}function o(e,t,n){var i,r,o,u=0;if("string"==typeof t){var l=s[e.toLowerCase()];for(var d in l)if(l[d]===t){t=d;break}}i=c[e.toLowerCase()+"IFD"],r=a.SHORT(i);for(var f=0;r>f;f++)if(o=i+12*f+2,a.SHORT(o)==t){u=o+8;break}return u?(a.LONG(u,n),!0):!1}var a,s,u,c={},l;return a=new n,s={tiff:{274:"Orientation",270:"ImageDescription",271:"Make",272:"Model",305:"Software",34665:"ExifIFDPointer",34853:"GPSInfoIFDPointer"},exif:{36864:"ExifVersion",40961:"ColorSpace",40962:"PixelXDimension",40963:"PixelYDimension",36867:"DateTimeOriginal",33434:"ExposureTime",33437:"FNumber",34855:"ISOSpeedRatings",37377:"ShutterSpeedValue",37378:"ApertureValue",37383:"MeteringMode",37384:"LightSource",37385:"Flash",37386:"FocalLength",41986:"ExposureMode",41987:"WhiteBalance",41990:"SceneCaptureType",41988:"DigitalZoomRatio",41992:"Contrast",41993:"Saturation",41994:"Sharpness"},gps:{0:"GPSVersionID",1:"GPSLatitudeRef",2:"GPSLatitude",3:"GPSLongitudeRef",4:"GPSLongitude"}},l={ColorSpace:{1:"sRGB",0:"Uncalibrated"},MeteringMode:{0:"Unknown",1:"Average",2:"CenterWeightedAverage",3:"Spot",4:"MultiSpot",5:"Pattern",6:"Partial",255:"Other"},LightSource:{1:"Daylight",2:"Fliorescent",3:"Tungsten",4:"Flash",9:"Fine weather",10:"Cloudy weather",11:"Shade",12:"Daylight fluorescent (D 5700 - 7100K)",13:"Day white fluorescent (N 4600 -5400K)",14:"Cool white fluorescent (W 3900 - 4500K)",15:"White fluorescent (WW 3200 - 3700K)",17:"Standard light A",18:"Standard light B",19:"Standard light C",20:"D55",21:"D65",22:"D75",23:"D50",24:"ISO studio tungsten",255:"Other"},Flash:{0:"Flash did not fire.",1:"Flash fired.",5:"Strobe return light not detected.",7:"Strobe return light detected.",9:"Flash fired, compulsory flash mode",13:"Flash fired, compulsory flash mode, return light not detected",15:"Flash fired, compulsory flash mode, return light detected",16:"Flash did not fire, compulsory flash mode",24:"Flash did not fire, auto mode",25:"Flash fired, auto mode",29:"Flash fired, auto mode, return light not detected",31:"Flash fired, auto mode, return light detected",32:"No flash function",65:"Flash fired, red-eye reduction mode",69:"Flash fired, red-eye reduction mode, return light not detected",71:"Flash fired, red-eye reduction mode, return light detected",73:"Flash fired, compulsory flash mode, red-eye reduction mode",77:"Flash fired, compulsory flash mode, red-eye reduction mode, return light not detected",79:"Flash fired, compulsory flash mode, red-eye reduction mode, return light detected",89:"Flash fired, auto mode, red-eye reduction mode",93:"Flash fired, auto mode, return light not detected, red-eye reduction mode",95:"Flash fired, auto mode, return light detected, red-eye reduction mode"},ExposureMode:{0:"Auto exposure",1:"Manual exposure",2:"Auto bracket"},WhiteBalance:{0:"Auto white balance",1:"Manual white balance"},SceneCaptureType:{0:"Standard",1:"Landscape",2:"Portrait",3:"Night scene"},Contrast:{0:"Normal",1:"Soft",2:"Hard"},Saturation:{0:"Normal",1:"Low saturation",2:"High saturation"},Sharpness:{0:"Normal",1:"Soft",2:"Hard"},GPSLatitudeRef:{N:"North latitude",S:"South latitude"},GPSLongitudeRef:{E:"East longitude",W:"West longitude"}},{init:function(e){return c={tiffHeader:10},e!==t&&e.length?(a.init(e),65505===a.SHORT(0)&&"EXIF\0"===a.STRING(4,5).toUpperCase()?r():!1):!1 -},TIFF:function(){return u},EXIF:function(){var t;if(t=i(c.exifIFD,s.exif),t.ExifVersion&&"array"===e.typeOf(t.ExifVersion)){for(var n=0,r="";n=65472&&65475>=t)return e+=5,{height:c.SHORT(e),width:c.SHORT(e+=2)};n=c.SHORT(e+=2),e+=n-2}return null}function s(){d&&l&&c&&(d.purge(),l.purge(),c.init(null),u=f=l=d=c=null)}var u,c,l,d,f,p;if(u=o,c=new i,c.init(u),65496!==c.SHORT(0))throw new t.ImageError(t.ImageError.WRONG_FORMAT);l=new n(o),d=new r,p=!!d.init(l.get("app1")[0]),f=a.call(this),e.extend(this,{type:"image/jpeg",size:u.length,width:f&&f.width||0,height:f&&f.height||0,setExif:function(t,n){return p?("object"===e.typeOf(t)?e.each(t,function(e,t){d.setExif(t,e)}):d.setExif(t,n),l.set("app1",d.getBinary()),void 0):!1},writeHeaders:function(){return arguments.length?l.restore(arguments[0]):u=l.restore(u)},stripHeaders:function(e){return l.strip(e)},purge:function(){s.call(this)}}),p&&(this.meta={tiff:d.TIFF(),exif:d.EXIF(),gps:d.GPS()})}return o}),i(z,[p,u,P],function(e,t,n){function i(i){function r(){var e,t;return e=a.call(this,8),"IHDR"==e.type?(t=e.start,{width:u.LONG(t),height:u.LONG(t+=4)}):null}function o(){u&&(u.init(null),s=d=c=l=u=null)}function a(e){var t,n,i,r;return t=u.LONG(e),n=u.STRING(e+=4,4),i=e+=4,r=u.LONG(e+t),{length:t,type:n,start:i,CRC:r}}var s,u,c,l,d;s=i,u=new n,u.init(s),function(){var t=0,n=0,i=[35152,20039,3338,6666];for(n=0;ng;){for(var v=g+f>a?a-g:f,y=0;o>y;){var w=y+f>o?o-y:f;h.clearRect(0,0,f,f),h.drawImage(e,-y,-g);var E=y*s/o+c<<0,_=Math.ceil(w*s/o),x=g*u/a/m+l<<0,R=Math.ceil(v*u/a/m);d.drawImage(p,0,0,w,v,E,x,_,R),y+=f}g+=f}p=h=null}function t(e){var t=e.naturalWidth,n=e.naturalHeight;if(t*n>1048576){var i=document.createElement("canvas");i.width=i.height=1;var r=i.getContext("2d");return r.drawImage(e,-t+1,0),0===r.getImageData(0,0,1,1).data[3]}return!1}function n(e,t,n){var i=document.createElement("canvas");i.width=1,i.height=n;var r=i.getContext("2d");r.drawImage(e,0,0);for(var o=r.getImageData(0,0,1,n).data,a=0,s=n,u=n;u>a;){var c=o[4*(u-1)+3];0===c?s=u:a=u,u=s+a>>1}i=null;var l=u/n;return 0===l?1:l}return{isSubsampled:t,renderTo:e}}),i(X,[D,u,p,m,w,G,q,l,d],function(e,t,n,i,r,o,a,s,u){function c(){function e(){if(!E&&!y)throw new n.ImageError(n.DOMException.INVALID_STATE_ERR);return E||y}function c(e){return i.atob(e.substring(e.indexOf("base64,")+7))}function l(e,t){return"data:"+(t||"")+";base64,"+i.btoa(e)}function d(e){var t=this;y=new Image,y.onerror=function(){g.call(this),t.trigger("error",new n.ImageError(n.ImageError.WRONG_FORMAT))},y.onload=function(){t.trigger("load")},y.src=/^data:[^;]*;base64,/.test(e)?e:l(e,x.type)}function f(e,t){var i=this,r;return window.FileReader?(r=new FileReader,r.onload=function(){t(this.result)},r.onerror=function(){i.trigger("error",new n.FileException(n.FileException.NOT_READABLE_ERR))},r.readAsDataURL(e),void 0):t(e.getAsDataURL())}function p(n,i,r,o){var a=this,s,u,c=0,l=0,d,f,p,g;if(b=o,g=this.meta&&this.meta.tiff&&this.meta.tiff.Orientation||1,-1!==t.inArray(g,[5,6,7,8])){var v=n;n=i,i=v}return d=e(),u=r?Math.max:Math.min,s=u(n/d.width,i/d.height),s>1&&(!r||o)?(this.trigger("Resize"),void 0):(E||(E=document.createElement("canvas")),f=Math.round(d.width*s),p=Math.round(d.height*s),r?(E.width=n,E.height=i,f>n&&(c=Math.round((f-n)/2)),p>i&&(l=Math.round((p-i)/2))):(E.width=f,E.height=p),b||m(E.width,E.height,g),h.call(this,d,E,-c,-l,f,p),this.width=E.width,this.height=E.height,R=!0,a.trigger("Resize"),void 0)}function h(e,t,n,i,r,o){if("iOS"===u.OS)a.renderTo(e,t,{width:r,height:o,x:n,y:i});else{var s=t.getContext("2d");s.drawImage(e,n,i,r,o)}}function m(e,t,n){switch(n){case 5:case 6:case 7:case 8:E.width=t,E.height=e;break;default:E.width=e,E.height=t}var i=E.getContext("2d");switch(n){case 2:i.translate(e,0),i.scale(-1,1);break;case 3:i.translate(e,t),i.rotate(Math.PI);break;case 4:i.translate(0,t),i.scale(1,-1);break;case 5:i.rotate(.5*Math.PI),i.scale(1,-1);break;case 6:i.rotate(.5*Math.PI),i.translate(0,-t);break;case 7:i.rotate(.5*Math.PI),i.translate(e,-t),i.scale(-1,1);break;case 8:i.rotate(-.5*Math.PI),i.translate(-e,0)}}function g(){w&&(w.purge(),w=null),_=y=E=x=null,R=!1}var v=this,y,w,E,_,x,R=!1,b=!0;t.extend(this,{loadFromBlob:function(e){var t=this,i=t.getRuntime(),r=arguments.length>1?arguments[1]:!0;if(!i.can("access_binary"))throw new n.RuntimeError(n.RuntimeError.NOT_SUPPORTED_ERR);return x=e,e.isDetached()?(_=e.getSource(),d.call(this,_),void 0):(f.call(this,e.getSource(),function(e){r&&(_=c(e)),d.call(t,e)}),void 0)},loadFromImage:function(e,t){this.meta=e.meta,x=new r(null,{name:e.name,size:e.size,type:e.type}),d.call(this,t?_=e.getAsBinaryString():e.getAsDataURL())},getInfo:function(){var t=this.getRuntime(),n;return!w&&_&&t.can("access_image_binary")&&(w=new o(_)),n={width:e().width||0,height:e().height||0,type:x.type||s.getFileMime(x.name),size:_&&_.length||x.size||0,name:x.name||"",meta:w&&w.meta||this.meta||{}}},downsize:function(){p.apply(this,arguments)},getAsCanvas:function(){return E&&(E.id=this.uid+"_canvas"),E},getAsBlob:function(e,t){return e!==this.type&&p.call(this,this.width,this.height,!1),new r(null,{name:x.name||"",type:e,data:v.getAsBinaryString.call(this,e,t)})},getAsDataURL:function(e){var t=arguments[1]||90;if(!R)return y.src;if("image/jpeg"!==e)return E.toDataURL("image/png");try{return E.toDataURL("image/jpeg",t/100)}catch(n){return E.toDataURL("image/jpeg")}},getAsBinaryString:function(e,t){if(!R)return _||(_=c(v.getAsDataURL(e,t))),_;if("image/jpeg"!==e)_=c(v.getAsDataURL(e,t));else{var n;t||(t=90);try{n=E.toDataURL("image/jpeg",t/100)}catch(i){n=E.toDataURL("image/jpeg")}_=c(n),w&&(_=w.stripHeaders(_),b&&(w.meta&&w.meta.exif&&w.setExif({PixelXDimension:this.width,PixelYDimension:this.height}),_=w.writeHeaders(_)),w.purge(),w=null)}return R=!1,_},destroy:function(){v=null,g.call(this),this.getRuntime().getShim().removeInstance(this.uid)}})}return e.Image=c}),i(j,[u,d,f,p,g],function(e,t,n,i,r){function o(){var e;try{e=navigator.plugins["Shockwave Flash"],e=e.description}catch(t){try{e=new ActiveXObject("ShockwaveFlash.ShockwaveFlash").GetVariable("$version")}catch(n){e="0.0"}}return e=e.match(/\d+/g),parseFloat(e[0]+"."+e[1])}function a(a){var c=this,l;a=e.extend({swf_url:t.swf_url},a),r.call(this,a,s,{access_binary:function(e){return e&&"browser"===c.mode},access_image_binary:function(e){return e&&"browser"===c.mode},display_media:r.capTrue,do_cors:r.capTrue,drag_and_drop:!1,report_upload_progress:function(){return"client"===c.mode},resize_image:r.capTrue,return_response_headers:!1,return_response_type:function(t){return"json"===t&&window.JSON?!0:!e.arrayDiff(t,["","text","document"])||"browser"===c.mode},return_status_code:function(t){return"browser"===c.mode||!e.arrayDiff(t,[200,404])},select_file:r.capTrue,select_multiple:r.capTrue,send_binary_string:function(e){return e&&"browser"===c.mode},send_browser_cookies:function(e){return e&&"browser"===c.mode},send_custom_headers:function(e){return e&&"browser"===c.mode},send_multipart:r.capTrue,slice_blob:r.capTrue,stream_upload:function(e){return e&&"browser"===c.mode},summon_file_dialog:!1,upload_filesize:function(t){return e.parseSizeStr(t)<=2097152||"client"===c.mode},use_http_method:function(t){return!e.arrayDiff(t,["GET","POST"])}},{access_binary:function(e){return e?"browser":"client"},access_image_binary:function(e){return e?"browser":"client"},report_upload_progress:function(e){return e?"browser":"client"},return_response_type:function(t){return e.arrayDiff(t,["","text","json","document"])?"browser":["client","browser"]},return_status_code:function(t){return e.arrayDiff(t,[200,404])?"browser":["client","browser"]},send_binary_string:function(e){return e?"browser":"client"},send_browser_cookies:function(e){return e?"browser":"client"},send_custom_headers:function(e){return e?"browser":"client"},stream_upload:function(e){return e?"client":"browser"},upload_filesize:function(t){return e.parseSizeStr(t)>=2097152?"client":"browser"}},"client"),o()<10&&(this.mode=!1),e.extend(this,{getShim:function(){return n.get(this.uid)},shimExec:function(e,t){var n=[].slice.call(arguments,2);return c.getShim().exec(this.uid,e,t,n)},init:function(){var n,r,o;o=this.getShimContainer(),e.extend(o.style,{position:"absolute",top:"-8px",left:"-8px",width:"9px",height:"9px",overflow:"hidden"}),n=''+''+''+''+"","IE"===t.browser?(r=document.createElement("div"),o.appendChild(r),r.outerHTML=n,r=o=null):o.innerHTML=n,l=setTimeout(function(){c&&!c.initialized&&c.trigger("Error",new i.RuntimeError(i.RuntimeError.NOT_INIT_ERR))},5e3)},destroy:function(e){return function(){e.call(c),clearTimeout(l),a=l=e=c=null}}(this.destroy)},u)}var s="flash",u={};return r.addConstructor(s,a),u}),i(V,[j,y],function(e,t){var n={slice:function(e,n,i,r){var o=this.getRuntime();return 0>n?n=Math.max(e.size+n,0):n>0&&(n=Math.min(n,e.size)),0>i?i=Math.max(e.size+i,0):i>0&&(i=Math.min(i,e.size)),e=o.shimExec.call(this,"Blob","slice",n,i,r||""),e&&(e=new t(o.uid,e)),e}};return e.Blob=n}),i(W,[j],function(e){var t={init:function(e){this.getRuntime().shimExec.call(this,"FileInput","init",{name:e.name,accept:e.accept,multiple:e.multiple}),this.trigger("ready")}};return e.FileInput=t}),i(Y,[j,m],function(e,t){function n(e,n){switch(n){case"readAsText":return t.atob(e,"utf8");case"readAsBinaryString":return t.atob(e);case"readAsDataURL":return e}return null}var i="",r={read:function(e,t){var r=this,o=r.getRuntime();return"readAsDataURL"===e&&(i="data:"+(t.type||"")+";base64,"),r.bind("Progress",function(t,r){r&&(i+=n(r,e))}),o.shimExec.call(this,"FileReader","readAsBase64",t.uid)},getResult:function(){return i},destroy:function(){i=null}};return e.FileReader=r}),i($,[j,m],function(e,t){function n(e,n){switch(n){case"readAsText":return t.atob(e,"utf8");case"readAsBinaryString":return t.atob(e);case"readAsDataURL":return e}return null}var i={read:function(e,t){var i,r=this.getRuntime();return(i=r.shimExec.call(this,"FileReaderSync","readAsBase64",t.uid))?("readAsDataURL"===e&&(i="data:"+(t.type||"")+";base64,"+i),n(i,e,t.type)):null}};return e.FileReaderSync=i}),i(J,[j,u,y,w,T,S,O],function(e,t,n,i,r,o,a){var s={send:function(e,i){function r(){e.transport=l.mode,l.shimExec.call(c,"XMLHttpRequest","send",e,i)}function s(e,t){l.shimExec.call(c,"XMLHttpRequest","appendBlob",e,t.uid),i=null,r()}function u(e,t){var n=new a;n.bind("TransportingComplete",function(){t(this.result)}),n.transport(e.getSource(),e.type,{ruid:l.uid})}var c=this,l=c.getRuntime();if(t.isEmptyObj(e.headers)||t.each(e.headers,function(e,t){l.shimExec.call(c,"XMLHttpRequest","setRequestHeader",t,e.toString())}),i instanceof o){var d;if(i.each(function(e,t){e instanceof n?d=t:l.shimExec.call(c,"XMLHttpRequest","append",t,e)}),i.hasBlob()){var f=i.getBlob();f.isDetached()?u(f,function(e){f.destroy(),s(d,e)}):s(d,f)}else i=null,r()}else i instanceof n?i.isDetached()?u(i,function(e){i.destroy(),i=e.uid,r()}):(i=i.uid,r()):r()},getResponse:function(e){var n,o,a=this.getRuntime();if(o=a.shimExec.call(this,"XMLHttpRequest","getResponseAsBlob")){if(o=new i(a.uid,o),"blob"===e)return o;try{if(n=new r,~t.inArray(e,["","text"]))return n.readAsText(o);if("json"===e&&window.JSON)return JSON.parse(n.readAsText(o))}finally{o.destroy()}}return null},abort:function(e){var t=this.getRuntime();t.shimExec.call(this,"XMLHttpRequest","abort"),this.dispatchEvent("readystatechange"),this.dispatchEvent("abort")}};return e.XMLHttpRequest=s}),i(Z,[j,y],function(e,t){var n={getAsBlob:function(e){var n=this.getRuntime(),i=n.shimExec.call(this,"Transporter","getAsBlob",e);return i?new t(n.uid,i):null}};return e.Transporter=n}),i(K,[j,u,O,y,T],function(e,t,n,i,r){var o={loadFromBlob:function(e){function t(e){r.shimExec.call(i,"Image","loadFromBlob",e.uid),i=r=null}var i=this,r=i.getRuntime();if(e.isDetached()){var o=new n;o.bind("TransportingComplete",function(){t(o.result.getSource())}),o.transport(e.getSource(),e.type,{ruid:r.uid})}else t(e.getSource())},loadFromImage:function(e){var t=this.getRuntime();return t.shimExec.call(this,"Image","loadFromImage",e.uid)},getAsBlob:function(e,t){var n=this.getRuntime(),r=n.shimExec.call(this,"Image","getAsBlob",e,t);return r?new i(n.uid,r):null},getAsDataURL:function(){var e=this.getRuntime(),t=e.Image.getAsBlob.apply(this,arguments),n;return t?(n=new r,n.readAsDataURL(t)):null}};return e.Image=o}),i(Q,[u,d,f,p,g],function(e,t,n,i,r){function o(e){var t=!1,n=null,i,r,o,a,s,u=0;try{try{n=new ActiveXObject("AgControl.AgControl"),n.IsVersionSupported(e)&&(t=!0),n=null}catch(c){var l=navigator.plugins["Silverlight Plug-In"];if(l){for(i=l.description,"1.0.30226.2"===i&&(i="2.0.30226.2"),r=i.split(".");r.length>3;)r.pop();for(;r.length<4;)r.push(0);for(o=e.split(".");o.length>4;)o.pop();do a=parseInt(o[u],10),s=parseInt(r[u],10),u++;while(u=a&&!isNaN(a)&&(t=!0)}}}catch(d){t=!1}return t}function a(a){var c=this,l;a=e.extend({xap_url:t.xap_url},a),r.call(this,a,s,{access_binary:r.capTrue,access_image_binary:r.capTrue,display_media:r.capTrue,do_cors:r.capTrue,drag_and_drop:!1,report_upload_progress:r.capTrue,resize_image:r.capTrue,return_response_headers:function(e){return e&&"client"===c.mode},return_response_type:function(e){return"json"!==e?!0:!!window.JSON},return_status_code:function(t){return"client"===c.mode||!e.arrayDiff(t,[200,404])},select_file:r.capTrue,select_multiple:r.capTrue,send_binary_string:r.capTrue,send_browser_cookies:function(e){return e&&"browser"===c.mode},send_custom_headers:function(e){return e&&"client"===c.mode},send_multipart:r.capTrue,slice_blob:r.capTrue,stream_upload:!0,summon_file_dialog:!1,upload_filesize:r.capTrue,use_http_method:function(t){return"client"===c.mode||!e.arrayDiff(t,["GET","POST"])}},{return_response_headers:function(e){return e?"client":"browser"},return_status_code:function(t){return e.arrayDiff(t,[200,404])?"client":["client","browser"]},send_browser_cookies:function(e){return e?"browser":"client"},send_custom_headers:function(e){return e?"client":"browser"},use_http_method:function(t){return e.arrayDiff(t,["GET","POST"])?"client":["client","browser"]}}),o("2.0.31005.0")&&"Opera"!==t.browser||(this.mode=!1),e.extend(this,{getShim:function(){return n.get(this.uid).content.Moxie},shimExec:function(e,t){var n=[].slice.call(arguments,2);return c.getShim().exec(this.uid,e,t,n)},init:function(){var e;e=this.getShimContainer(),e.innerHTML=''+''+''+''+''+''+"",l=setTimeout(function(){c&&!c.initialized&&c.trigger("Error",new i.RuntimeError(i.RuntimeError.NOT_INIT_ERR))},"Windows"!==t.OS?1e4:5e3)},destroy:function(e){return function(){e.call(c),clearTimeout(l),a=l=e=c=null}}(this.destroy)},u)}var s="silverlight",u={};return r.addConstructor(s,a),u}),i(et,[Q,u,V],function(e,t,n){return e.Blob=t.extend({},n)}),i(tt,[Q],function(e){var t={init:function(e){function t(e){for(var t="",n=0;no;o++)n=t.keys[o],s=t[n],s&&(/^(\d|[1-9]\d+)$/.test(s)?s=parseInt(s,10):/^\d*\.\d+$/.test(s)&&(s=parseFloat(s)),i.meta[e][n]=s)}),i.width=parseInt(r.width,10),i.height=parseInt(r.height,10),i.size=parseInt(r.size,10),i.type=r.type,i.name=r.name,i}})}),i(ut,[u,p,g,d],function(e,t,n,i){function r(t){var r=this,s=n.capTest,u=n.capTrue;n.call(this,t,o,{access_binary:s(window.FileReader||window.File&&File.getAsDataURL),access_image_binary:!1,display_media:s(a.Image&&(i.can("create_canvas")||i.can("use_data_uri_over32kb"))),do_cors:!1,drag_and_drop:!1,filter_by_extension:s(function(){return"Chrome"===i.browser&&i.version>=28||"IE"===i.browser&&i.version>=10}()),resize_image:function(){return a.Image&&r.can("access_binary")&&i.can("create_canvas")},report_upload_progress:!1,return_response_headers:!1,return_response_type:function(t){return"json"===t&&window.JSON?!0:!!~e.inArray(t,["text","document",""])},return_status_code:function(t){return!e.arrayDiff(t,[200,404])},select_file:function(){return i.can("use_fileinput")},select_multiple:!1,send_binary_string:!1,send_custom_headers:!1,send_multipart:!0,slice_blob:!1,stream_upload:function(){return r.can("select_file")},summon_file_dialog:s(function(){return"Firefox"===i.browser&&i.version>=4||"Opera"===i.browser&&i.version>=12||!!~e.inArray(i.browser,["Chrome","Safari"])}()),upload_filesize:u,use_http_method:function(t){return!e.arrayDiff(t,["GET","POST"])}}),e.extend(this,{init:function(){this.trigger("Init")},destroy:function(e){return function(){e.call(r),e=r=null}}(this.destroy)}),e.extend(this.getShim(),a)}var o="html4",a={};return n.addConstructor(o,r),a}),i(ct,[ut,u,f,L,l,d],function(e,t,n,i,r,o){function a(){function e(){var r=this,l=r.getRuntime(),d,f,p,h,m,g;g=t.guid("uid_"),d=l.getShimContainer(),a&&(p=n.get(a+"_form"),p&&t.extend(p.style,{top:"100%"})),h=document.createElement("form"),h.setAttribute("id",g+"_form"),h.setAttribute("method","post"),h.setAttribute("enctype","multipart/form-data"),h.setAttribute("encoding","multipart/form-data"),t.extend(h.style,{overflow:"hidden",position:"absolute",top:0,left:0,width:"100%",height:"100%"}),m=document.createElement("input"),m.setAttribute("id",g),m.setAttribute("type","file"),m.setAttribute("name",c.name||"Filedata"),m.setAttribute("accept",u.join(",")),t.extend(m.style,{fontSize:"999px",opacity:0}),h.appendChild(m),d.appendChild(h),t.extend(m.style,{position:"absolute",top:0,left:0,width:"100%",height:"100%"}),"IE"===o.browser&&o.version<10&&t.extend(m.style,{filter:"progid:DXImageTransform.Microsoft.Alpha(opacity=0)"}),m.onchange=function(){var t;this.value&&(t=this.files?this.files[0]:{name:this.value},s=[t],this.onchange=function(){},e.call(r),r.bind("change",function i(){var e=n.get(g),t=n.get(g+"_form"),o;r.unbind("change",i),r.files.length&&e&&t&&(o=r.files[0],e.setAttribute("id",o.uid),t.setAttribute("id",o.uid+"_form"),t.setAttribute("target",o.uid+"_iframe")),e=t=null},998),m=h=null,r.trigger("change"))},l.can("summon_file_dialog")&&(f=n.get(c.browse_button),i.removeEvent(f,"click",r.uid),i.addEvent(f,"click",function(e){m&&!m.disabled&&m.click(),e.preventDefault()},r.uid)),a=g,d=p=f=null}var a,s=[],u=[],c;t.extend(this,{init:function(t){var o=this,a=o.getRuntime(),s;c=t,u=t.accept.mimes||r.extList2mimes(t.accept,a.can("filter_by_extension")),s=a.getShimContainer(),function(){var e,r,u;e=n.get(t.browse_button),a.can("summon_file_dialog")&&("static"===n.getStyle(e,"position")&&(e.style.position="relative"),r=parseInt(n.getStyle(e,"z-index"),10)||1,e.style.zIndex=r,s.style.zIndex=r-1),u=a.can("summon_file_dialog")?e:s,i.addEvent(u,"mouseover",function(){o.trigger("mouseenter")},o.uid),i.addEvent(u,"mouseout",function(){o.trigger("mouseleave")},o.uid),i.addEvent(u,"mousedown",function(){o.trigger("mousedown")},o.uid),i.addEvent(n.get(t.container),"mouseup",function(){o.trigger("mouseup")},o.uid),e=null}(),e.call(this),s=null,o.trigger({type:"ready",async:!0})},getFiles:function(){return s},disable:function(e){var t;(t=n.get(a))&&(t.disabled=!!e)},destroy:function(){var e=this.getRuntime(),t=e.getShim(),r=e.getShimContainer();i.removeAllEvents(r,this.uid),i.removeAllEvents(c&&n.get(c.container),this.uid),i.removeAllEvents(c&&n.get(c.browse_button),this.uid),r&&(r.innerHTML=""),t.removeInstance(this.uid),a=s=u=c=r=t=null}})}return e.FileInput=a}),i(lt,[ut,F],function(e,t){return e.FileReader=t}),i(dt,[ut,u,f,b,p,L,y,S],function(e,t,n,i,r,o,a,s){function u(){function e(e){var t=this,i,r,a,s,u=!1;if(l){if(i=l.id.replace(/_iframe$/,""),r=n.get(i+"_form")){for(a=r.getElementsByTagName("input"),s=a.length;s--;)switch(a[s].getAttribute("type")){case"hidden":a[s].parentNode.removeChild(a[s]);break;case"file":u=!0}a=[],u||r.parentNode.removeChild(r),r=null}setTimeout(function(){o.removeEvent(l,"load",t.uid),l.parentNode&&l.parentNode.removeChild(l);var n=t.getRuntime().getShimContainer();n.children.length||n.parentNode.removeChild(n),n=l=null,e()},1)}}var u,c,l;t.extend(this,{send:function(d,f){function p(){var n=m.getShimContainer()||document.body,r=document.createElement("div");r.innerHTML='',l=r.firstChild,n.appendChild(l),o.addEvent(l,"load",function(){var n;try{n=l.contentWindow.document||l.contentDocument||window.frames[l.id].document,/^4(0[0-9]|1[0-7]|2[2346])\s/.test(n.title)?u=n.title.replace(/^(\d+).*$/,"$1"):(u=200,c=t.trim(n.body.innerHTML),h.trigger({type:"progress",loaded:c.length,total:c.length}),w&&h.trigger({type:"uploadprogress",loaded:w.size||1025,total:w.size||1025}))}catch(r){if(!i.hasSameOrigin(d.url))return e.call(h,function(){h.trigger("error")}),void 0;u=404}e.call(h,function(){h.trigger("load")})},h.uid)}var h=this,m=h.getRuntime(),g,v,y,w;if(u=c=null,f instanceof s&&f.hasBlob()){if(w=f.getBlob(),g=w.uid,y=n.get(g),v=n.get(g+"_form"),!v)throw new r.DOMException(r.DOMException.NOT_FOUND_ERR)}else g=t.guid("uid_"),v=document.createElement("form"),v.setAttribute("id",g+"_form"),v.setAttribute("method",d.method),v.setAttribute("enctype","multipart/form-data"),v.setAttribute("encoding","multipart/form-data"),v.setAttribute("target",g+"_iframe"),m.getShimContainer().appendChild(v);f instanceof s&&f.each(function(e,n){if(e instanceof a)y&&y.setAttribute("name",n);else{var i=document.createElement("input");t.extend(i,{type:"hidden",name:n,value:e}),y?v.insertBefore(i,y):v.appendChild(i)}}),v.setAttribute("action",d.url),p(),v.submit(),h.trigger("loadstart")},getStatus:function(){return u},getResponse:function(e){if("json"===e&&"string"===t.typeOf(c)&&window.JSON)try{return JSON.parse(c.replace(/^\s*]*>/,"").replace(/<\/pre>\s*$/,""))}catch(n){return null}return c},abort:function(){var t=this;l&&l.contentWindow&&(l.contentWindow.stop?l.contentWindow.stop():l.contentWindow.document.execCommand?l.contentWindow.document.execCommand("Stop"):l.src="about:blank"),e.call(this,function(){t.dispatchEvent("abort")})}})}return e.XMLHttpRequest=u}),i(ft,[ut,X],function(e,t){return e.Image=t}),a([u,c,l,d,f,p,h,m,g,v,y,w,E,_,x,R,b,T,S,A,O,I,L])}(this);;(function(){"use strict";var e={},t=moxie.core.utils.Basic.inArray;return function n(r){var i,s;for(i in r)s=typeof r[i],s==="object"&&!~t(i,["Exceptions","Env","Mime"])?n(r[i]):s==="function"&&(e[i]=r[i])}(window.moxie),e.Env=window.moxie.core.utils.Env,e.Mime=window.moxie.core.utils.Mime,e.Exceptions=window.moxie.core.Exceptions,window.mOxie=e,window.o||(window.o=e),e})(); \ No newline at end of file diff --git a/demo/js/plupload/plupload.dev.js b/demo/js/plupload/plupload.dev.js deleted file mode 100644 index 95319896..00000000 --- a/demo/js/plupload/plupload.dev.js +++ /dev/null @@ -1,2273 +0,0 @@ -/** - * Plupload - multi-runtime File Uploader - * v2.1.1 - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - * - * Date: 2014-01-16 - */ -/** - * Plupload.js - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - */ - -/*global mOxie:true */ - -;(function(window, o, undef) { - -var delay = window.setTimeout -, fileFilters = {} -; - -// convert plupload features to caps acceptable by mOxie -function normalizeCaps(settings) { - var features = settings.required_features, caps = {}; - - function resolve(feature, value, strict) { - // Feature notation is deprecated, use caps (this thing here is required for backward compatibility) - var map = { - chunks: 'slice_blob', - jpgresize: 'send_binary_string', - pngresize: 'send_binary_string', - progress: 'report_upload_progress', - multi_selection: 'select_multiple', - dragdrop: 'drag_and_drop', - drop_element: 'drag_and_drop', - headers: 'send_custom_headers', - canSendBinary: 'send_binary', - triggerDialog: 'summon_file_dialog' - }; - - if (map[feature]) { - caps[map[feature]] = value; - } else if (!strict) { - caps[feature] = value; - } - } - - if (typeof(features) === 'string') { - plupload.each(features.split(/\s*,\s*/), function(feature) { - resolve(feature, true); - }); - } else if (typeof(features) === 'object') { - plupload.each(features, function(value, feature) { - resolve(feature, value); - }); - } else if (features === true) { - // check settings for required features - if (!settings.multipart) { // special care for multipart: false - caps.send_binary_string = true; - } - - if (settings.chunk_size > 0) { - caps.slice_blob = true; - } - - if (settings.resize.enabled) { - caps.send_binary_string = true; - } - - plupload.each(settings, function(value, feature) { - resolve(feature, !!value, true); // strict check - }); - } - - return caps; -} - -/** - * @module plupload - * @static - */ -var plupload = { - /** - * Plupload version will be replaced on build. - * - * @property VERSION - * @for Plupload - * @static - * @final - */ - VERSION : '2.1.1', - - /** - * Inital state of the queue and also the state ones it's finished all it's uploads. - * - * @property STOPPED - * @static - * @final - */ - STOPPED : 1, - - /** - * Upload process is running - * - * @property STARTED - * @static - * @final - */ - STARTED : 2, - - /** - * File is queued for upload - * - * @property QUEUED - * @static - * @final - */ - QUEUED : 1, - - /** - * File is being uploaded - * - * @property UPLOADING - * @static - * @final - */ - UPLOADING : 2, - - /** - * File has failed to be uploaded - * - * @property FAILED - * @static - * @final - */ - FAILED : 4, - - /** - * File has been uploaded successfully - * - * @property DONE - * @static - * @final - */ - DONE : 5, - - // Error constants used by the Error event - - /** - * Generic error for example if an exception is thrown inside Silverlight. - * - * @property GENERIC_ERROR - * @static - * @final - */ - GENERIC_ERROR : -100, - - /** - * HTTP transport error. For example if the server produces a HTTP status other than 200. - * - * @property HTTP_ERROR - * @static - * @final - */ - HTTP_ERROR : -200, - - /** - * Generic I/O error. For exampe if it wasn't possible to open the file stream on local machine. - * - * @property IO_ERROR - * @static - * @final - */ - IO_ERROR : -300, - - /** - * Generic I/O error. For exampe if it wasn't possible to open the file stream on local machine. - * - * @property SECURITY_ERROR - * @static - * @final - */ - SECURITY_ERROR : -400, - - /** - * Initialization error. Will be triggered if no runtime was initialized. - * - * @property INIT_ERROR - * @static - * @final - */ - INIT_ERROR : -500, - - /** - * File size error. If the user selects a file that is too large it will be blocked and an error of this type will be triggered. - * - * @property FILE_SIZE_ERROR - * @static - * @final - */ - FILE_SIZE_ERROR : -600, - - /** - * File extension error. If the user selects a file that isn't valid according to the filters setting. - * - * @property FILE_EXTENSION_ERROR - * @static - * @final - */ - FILE_EXTENSION_ERROR : -601, - - /** - * Duplicate file error. If prevent_duplicates is set to true and user selects the same file again. - * - * @property FILE_DUPLICATE_ERROR - * @static - * @final - */ - FILE_DUPLICATE_ERROR : -602, - - /** - * Runtime will try to detect if image is proper one. Otherwise will throw this error. - * - * @property IMAGE_FORMAT_ERROR - * @static - * @final - */ - IMAGE_FORMAT_ERROR : -700, - - /** - * While working on the image runtime will try to detect if the operation may potentially run out of memeory and will throw this error. - * - * @property IMAGE_MEMORY_ERROR - * @static - * @final - */ - IMAGE_MEMORY_ERROR : -701, - - /** - * Each runtime has an upper limit on a dimension of the image it can handle. If bigger, will throw this error. - * - * @property IMAGE_DIMENSIONS_ERROR - * @static - * @final - */ - IMAGE_DIMENSIONS_ERROR : -702, - - /** - * Mime type lookup table. - * - * @property mimeTypes - * @type Object - * @final - */ - mimeTypes : o.mimes, - - /** - * In some cases sniffing is the only way around :( - */ - ua: o.ua, - - /** - * Gets the true type of the built-in object (better version of typeof). - * @credits Angus Croll (http://javascriptweblog.wordpress.com/) - * - * @method typeOf - * @static - * @param {Object} o Object to check. - * @return {String} Object [[Class]] - */ - typeOf: o.typeOf, - - /** - * Extends the specified object with another object. - * - * @method extend - * @static - * @param {Object} target Object to extend. - * @param {Object..} obj Multiple objects to extend with. - * @return {Object} Same as target, the extended object. - */ - extend : o.extend, - - /** - * Generates an unique ID. This is 99.99% unique since it takes the current time and 5 random numbers. - * The only way a user would be able to get the same ID is if the two persons at the same exact milisecond manages - * to get 5 the same random numbers between 0-65535 it also uses a counter so each call will be guaranteed to be page unique. - * It's more probable for the earth to be hit with an ansteriod. You can also if you want to be 100% sure set the plupload.guidPrefix property - * to an user unique key. - * - * @method guid - * @static - * @return {String} Virtually unique id. - */ - guid : o.guid, - - /** - * Get array of DOM Elements by their ids. - * - * @method get - * @for Utils - * @param {String} id Identifier of the DOM Element - * @return {Array} - */ - get : function get(ids) { - var els = [], el; - - if (o.typeOf(ids) !== 'array') { - ids = [ids]; - } - - var i = ids.length; - while (i--) { - el = o.get(ids[i]); - if (el) { - els.push(el); - } - } - - return els.length ? els : null; - }, - - /** - * Executes the callback function for each item in array/object. If you return false in the - * callback it will break the loop. - * - * @method each - * @static - * @param {Object} obj Object to iterate. - * @param {function} callback Callback function to execute for each item. - */ - each : o.each, - - /** - * Returns the absolute x, y position of an Element. The position will be returned in a object with x, y fields. - * - * @method getPos - * @static - * @param {Element} node HTML element or element id to get x, y position from. - * @param {Element} root Optional root element to stop calculations at. - * @return {object} Absolute position of the specified element object with x, y fields. - */ - getPos : o.getPos, - - /** - * Returns the size of the specified node in pixels. - * - * @method getSize - * @static - * @param {Node} node Node to get the size of. - * @return {Object} Object with a w and h property. - */ - getSize : o.getSize, - - /** - * Encodes the specified string. - * - * @method xmlEncode - * @static - * @param {String} s String to encode. - * @return {String} Encoded string. - */ - xmlEncode : function(str) { - var xmlEncodeChars = {'<' : 'lt', '>' : 'gt', '&' : 'amp', '"' : 'quot', '\'' : '#39'}, xmlEncodeRegExp = /[<>&\"\']/g; - - return str ? ('' + str).replace(xmlEncodeRegExp, function(chr) { - return xmlEncodeChars[chr] ? '&' + xmlEncodeChars[chr] + ';' : chr; - }) : str; - }, - - /** - * Forces anything into an array. - * - * @method toArray - * @static - * @param {Object} obj Object with length field. - * @return {Array} Array object containing all items. - */ - toArray : o.toArray, - - /** - * Find an element in array and return it's index if present, otherwise return -1. - * - * @method inArray - * @static - * @param {mixed} needle Element to find - * @param {Array} array - * @return {Int} Index of the element, or -1 if not found - */ - inArray : o.inArray, - - /** - * Extends the language pack object with new items. - * - * @method addI18n - * @static - * @param {Object} pack Language pack items to add. - * @return {Object} Extended language pack object. - */ - addI18n : o.addI18n, - - /** - * Translates the specified string by checking for the english string in the language pack lookup. - * - * @method translate - * @static - * @param {String} str String to look for. - * @return {String} Translated string or the input string if it wasn't found. - */ - translate : o.translate, - - /** - * Checks if object is empty. - * - * @method isEmptyObj - * @static - * @param {Object} obj Object to check. - * @return {Boolean} - */ - isEmptyObj : o.isEmptyObj, - - /** - * Checks if specified DOM element has specified class. - * - * @method hasClass - * @static - * @param {Object} obj DOM element like object to add handler to. - * @param {String} name Class name - */ - hasClass : o.hasClass, - - /** - * Adds specified className to specified DOM element. - * - * @method addClass - * @static - * @param {Object} obj DOM element like object to add handler to. - * @param {String} name Class name - */ - addClass : o.addClass, - - /** - * Removes specified className from specified DOM element. - * - * @method removeClass - * @static - * @param {Object} obj DOM element like object to add handler to. - * @param {String} name Class name - */ - removeClass : o.removeClass, - - /** - * Returns a given computed style of a DOM element. - * - * @method getStyle - * @static - * @param {Object} obj DOM element like object. - * @param {String} name Style you want to get from the DOM element - */ - getStyle : o.getStyle, - - /** - * Adds an event handler to the specified object and store reference to the handler - * in objects internal Plupload registry (@see removeEvent). - * - * @method addEvent - * @static - * @param {Object} obj DOM element like object to add handler to. - * @param {String} name Name to add event listener to. - * @param {Function} callback Function to call when event occurs. - * @param {String} (optional) key that might be used to add specifity to the event record. - */ - addEvent : o.addEvent, - - /** - * Remove event handler from the specified object. If third argument (callback) - * is not specified remove all events with the specified name. - * - * @method removeEvent - * @static - * @param {Object} obj DOM element to remove event listener(s) from. - * @param {String} name Name of event listener to remove. - * @param {Function|String} (optional) might be a callback or unique key to match. - */ - removeEvent: o.removeEvent, - - /** - * Remove all kind of events from the specified object - * - * @method removeAllEvents - * @static - * @param {Object} obj DOM element to remove event listeners from. - * @param {String} (optional) unique key to match, when removing events. - */ - removeAllEvents: o.removeAllEvents, - - /** - * Cleans the specified name from national characters (diacritics). The result will be a name with only a-z, 0-9 and _. - * - * @method cleanName - * @static - * @param {String} s String to clean up. - * @return {String} Cleaned string. - */ - cleanName : function(name) { - var i, lookup; - - // Replace diacritics - lookup = [ - /[\300-\306]/g, 'A', /[\340-\346]/g, 'a', - /\307/g, 'C', /\347/g, 'c', - /[\310-\313]/g, 'E', /[\350-\353]/g, 'e', - /[\314-\317]/g, 'I', /[\354-\357]/g, 'i', - /\321/g, 'N', /\361/g, 'n', - /[\322-\330]/g, 'O', /[\362-\370]/g, 'o', - /[\331-\334]/g, 'U', /[\371-\374]/g, 'u' - ]; - - for (i = 0; i < lookup.length; i += 2) { - name = name.replace(lookup[i], lookup[i + 1]); - } - - // Replace whitespace - name = name.replace(/\s+/g, '_'); - - // Remove anything else - name = name.replace(/[^a-z0-9_\-\.]+/gi, ''); - - return name; - }, - - /** - * Builds a full url out of a base URL and an object with items to append as query string items. - * - * @method buildUrl - * @static - * @param {String} url Base URL to append query string items to. - * @param {Object} items Name/value object to serialize as a querystring. - * @return {String} String with url + serialized query string items. - */ - buildUrl : function(url, items) { - var query = ''; - - plupload.each(items, function(value, name) { - query += (query ? '&' : '') + encodeURIComponent(name) + '=' + encodeURIComponent(value); - }); - - if (query) { - url += (url.indexOf('?') > 0 ? '&' : '?') + query; - } - - return url; - }, - - /** - * Formats the specified number as a size string for example 1024 becomes 1 KB. - * - * @method formatSize - * @static - * @param {Number} size Size to format as string. - * @return {String} Formatted size string. - */ - formatSize : function(size) { - - if (size === undef || /\D/.test(size)) { - return plupload.translate('N/A'); - } - - function round(num, precision) { - return Math.round(num * Math.pow(10, precision)) / Math.pow(10, precision); - } - - var boundary = Math.pow(1024, 4); - - // TB - if (size > boundary) { - return round(size / boundary, 1) + " " + plupload.translate('tb'); - } - - // GB - if (size > (boundary/=1024)) { - return round(size / boundary, 1) + " " + plupload.translate('gb'); - } - - // MB - if (size > (boundary/=1024)) { - return round(size / boundary, 1) + " " + plupload.translate('mb'); - } - - // KB - if (size > 1024) { - return Math.round(size / 1024) + " " + plupload.translate('kb'); - } - - return size + " " + plupload.translate('b'); - }, - - - /** - * Parses the specified size string into a byte value. For example 10kb becomes 10240. - * - * @method parseSize - * @static - * @param {String|Number} size String to parse or number to just pass through. - * @return {Number} Size in bytes. - */ - parseSize : o.parseSizeStr, - - - /** - * A way to predict what runtime will be choosen in the current environment with the - * specified settings. - * - * @method predictRuntime - * @static - * @param {Object|String} config Plupload settings to check - * @param {String} [runtimes] Comma-separated list of runtimes to check against - * @return {String} Type of compatible runtime - */ - predictRuntime : function(config, runtimes) { - var up, runtime; - - up = new plupload.Uploader(config); - runtime = o.Runtime.thatCan(up.getOption().required_features, runtimes || config.runtimes); - up.destroy(); - return runtime; - }, - - /** - * Registers a filter that will be executed for each file added to the queue. - * If callback returns false, file will not be added. - * - * Callback receives two arguments: a value for the filter as it was specified in settings.filters - * and a file to be filtered. Callback is executed in the context of uploader instance. - * - * @method addFileFilter - * @static - * @param {String} name Name of the filter by which it can be referenced in settings.filters - * @param {String} cb Callback - the actual routine that every added file must pass - */ - addFileFilter: function(name, cb) { - fileFilters[name] = cb; - } -}; - - -plupload.addFileFilter('mime_types', function(filters, file, cb) { - if (filters.length && !filters.regexp.test(file.name)) { - this.trigger('Error', { - code : plupload.FILE_EXTENSION_ERROR, - message : plupload.translate('File extension error.'), - file : file - }); - cb(false); - } else { - cb(true); - } -}); - - -plupload.addFileFilter('max_file_size', function(maxSize, file, cb) { - var undef; - - maxSize = plupload.parseSize(maxSize); - - // Invalid file size - if (file.size !== undef && maxSize && file.size > maxSize) { - this.trigger('Error', { - code : plupload.FILE_SIZE_ERROR, - message : plupload.translate('File size error.'), - file : file - }); - cb(false); - } else { - cb(true); - } -}); - - -plupload.addFileFilter('prevent_duplicates', function(value, file, cb) { - if (value) { - var ii = this.files.length; - while (ii--) { - // Compare by name and size (size might be 0 or undefined, but still equivalent for both) - if (file.name === this.files[ii].name && file.size === this.files[ii].size) { - this.trigger('Error', { - code : plupload.FILE_DUPLICATE_ERROR, - message : plupload.translate('Duplicate file error.'), - file : file - }); - cb(false); - return; - } - } - } - cb(true); -}); - - -/** -@class Uploader -@constructor - -@param {Object} settings For detailed information about each option check documentation. - @param {String|DOMElement} settings.browse_button id of the DOM element or DOM element itself to use as file dialog trigger. - @param {String} settings.url URL of the server-side upload handler. - @param {Number|String} [settings.chunk_size=0] Chunk size in bytes to slice the file into. Shorcuts with b, kb, mb, gb, tb suffixes also supported. `e.g. 204800 or "204800b" or "200kb"`. By default - disabled. - @param {String} [settings.container] id of the DOM element to use as a container for uploader structures. Defaults to document.body. - @param {String|DOMElement} [settings.drop_element] id of the DOM element or DOM element itself to use as a drop zone for Drag-n-Drop. - @param {String} [settings.file_data_name="file"] Name for the file field in Multipart formated message. - @param {Object} [settings.filters={}] Set of file type filters. - @param {Array} [settings.filters.mime_types=[]] List of file types to accept, each one defined by title and list of extensions. `e.g. {title : "Image files", extensions : "jpg,jpeg,gif,png"}`. Dispatches `plupload.FILE_EXTENSION_ERROR` - @param {String|Number} [settings.filters.max_file_size=0] Maximum file size that the user can pick, in bytes. Optionally supports b, kb, mb, gb, tb suffixes. `e.g. "10mb" or "1gb"`. By default - not set. Dispatches `plupload.FILE_SIZE_ERROR`. - @param {Boolean} [settings.filters.prevent_duplicates=false] Do not let duplicates into the queue. Dispatches `plupload.FILE_DUPLICATE_ERROR`. - @param {String} [settings.flash_swf_url] URL of the Flash swf. - @param {Object} [settings.headers] Custom headers to send with the upload. Hash of name/value pairs. - @param {Number} [settings.max_retries=0] How many times to retry the chunk or file, before triggering Error event. - @param {Boolean} [settings.multipart=true] Whether to send file and additional parameters as Multipart formated message. - @param {Object} [settings.multipart_params] Hash of key/value pairs to send with every file upload. - @param {Boolean} [settings.multi_selection=true] Enable ability to select multiple files at once in file dialog. - @param {String|Object} [settings.required_features] Either comma-separated list or hash of required features that chosen runtime should absolutely possess. - @param {Object} [settings.resize] Enable resizng of images on client-side. Applies to `image/jpeg` and `image/png` only. `e.g. {width : 200, height : 200, quality : 90, crop: true}` - @param {Number} [settings.resize.width] If image is bigger, it will be resized. - @param {Number} [settings.resize.height] If image is bigger, it will be resized. - @param {Number} [settings.resize.quality=90] Compression quality for jpegs (1-100). - @param {Boolean} [settings.resize.crop=false] Whether to crop images to exact dimensions. By default they will be resized proportionally. - @param {String} [settings.runtimes="html5,flash,silverlight,html4"] Comma separated list of runtimes, that Plupload will try in turn, moving to the next if previous fails. - @param {String} [settings.silverlight_xap_url] URL of the Silverlight xap. - @param {Boolean} [settings.unique_names=false] If true will generate unique filenames for uploaded files. -*/ -plupload.Uploader = function(options) { - /** - * Fires when the current RunTime has been initialized. - * - * @event Init - * @param {plupload.Uploader} uploader Uploader instance sending the event. - */ - - /** - * Fires after the init event incase you need to perform actions there. - * - * @event PostInit - * @param {plupload.Uploader} uploader Uploader instance sending the event. - */ - - /** - * Fires when the option is changed in via uploader.setOption(). - * - * @event OptionChanged - * @since 2.1 - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {String} name Name of the option that was changed - * @param {Mixed} value New value for the specified option - * @param {Mixed} oldValue Previous value of the option - */ - - /** - * Fires when the silverlight/flash or other shim needs to move. - * - * @event Refresh - * @param {plupload.Uploader} uploader Uploader instance sending the event. - */ - - /** - * Fires when the overall state is being changed for the upload queue. - * - * @event StateChanged - * @param {plupload.Uploader} uploader Uploader instance sending the event. - */ - - /** - * Fires when a file is to be uploaded by the runtime. - * - * @event UploadFile - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {plupload.File} file File to be uploaded. - */ - - /** - * Fires when just before a file is uploaded. This event enables you to override settings - * on the uploader instance before the file is uploaded. - * - * @event BeforeUpload - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {plupload.File} file File to be uploaded. - */ - - /** - * Fires when the file queue is changed. In other words when files are added/removed to the files array of the uploader instance. - * - * @event QueueChanged - * @param {plupload.Uploader} uploader Uploader instance sending the event. - */ - - /** - * Fires while a file is being uploaded. Use this event to update the current file upload progress. - * - * @event UploadProgress - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {plupload.File} file File that is currently being uploaded. - */ - - /** - * Fires when file is removed from the queue. - * - * @event FilesRemoved - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {Array} files Array of files that got removed. - */ - - /** - * Fires for every filtered file before it is added to the queue. - * - * @event FileFiltered - * @since 2.1 - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {plupload.File} file Another file that has to be added to the queue. - */ - - /** - * Fires after files were filtered and added to the queue. - * - * @event FilesAdded - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {Array} files Array of file objects that were added to queue by the user. - */ - - /** - * Fires when a file is successfully uploaded. - * - * @event FileUploaded - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {plupload.File} file File that was uploaded. - * @param {Object} response Object with response properties. - */ - - /** - * Fires when file chunk is uploaded. - * - * @event ChunkUploaded - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {plupload.File} file File that the chunk was uploaded for. - * @param {Object} response Object with response properties. - */ - - /** - * Fires when all files in a queue are uploaded. - * - * @event UploadComplete - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {Array} files Array of file objects that was added to queue/selected by the user. - */ - - /** - * Fires when a error occurs. - * - * @event Error - * @param {plupload.Uploader} uploader Uploader instance sending the event. - * @param {Object} error Contains code, message and sometimes file and other details. - */ - - /** - * Fires when destroy method is called. - * - * @event Destroy - * @param {plupload.Uploader} uploader Uploader instance sending the event. - */ - var uid = plupload.guid() - , settings - , files = [] - , preferred_caps = {} - , fileInputs = [] - , fileDrops = [] - , startTime - , total - , disabled = false - , xhr - ; - - - // Private methods - function uploadNext() { - var file, count = 0, i; - - if (this.state == plupload.STARTED) { - // Find first QUEUED file - for (i = 0; i < files.length; i++) { - if (!file && files[i].status == plupload.QUEUED) { - file = files[i]; - if (this.trigger("BeforeUpload", file)) { - file.status = plupload.UPLOADING; - this.trigger("UploadFile", file); - } - } else { - count++; - } - } - - // All files are DONE or FAILED - if (count == files.length) { - if (this.state !== plupload.STOPPED) { - this.state = plupload.STOPPED; - this.trigger("StateChanged"); - } - this.trigger("UploadComplete", files); - } - } - } - - - function calcFile(file) { - file.percent = file.size > 0 ? Math.ceil(file.loaded / file.size * 100) : 100; - calc(); - } - - - function calc() { - var i, file; - - // Reset stats - total.reset(); - - // Check status, size, loaded etc on all files - for (i = 0; i < files.length; i++) { - file = files[i]; - - if (file.size !== undef) { - // We calculate totals based on original file size - total.size += file.origSize; - - // Since we cannot predict file size after resize, we do opposite and - // interpolate loaded amount to match magnitude of total - total.loaded += file.loaded * file.origSize / file.size; - } else { - total.size = undef; - } - - if (file.status == plupload.DONE) { - total.uploaded++; - } else if (file.status == plupload.FAILED) { - total.failed++; - } else { - total.queued++; - } - } - - // If we couldn't calculate a total file size then use the number of files to calc percent - if (total.size === undef) { - total.percent = files.length > 0 ? Math.ceil(total.uploaded / files.length * 100) : 0; - } else { - total.bytesPerSec = Math.ceil(total.loaded / ((+new Date() - startTime || 1) / 1000.0)); - total.percent = total.size > 0 ? Math.ceil(total.loaded / total.size * 100) : 0; - } - } - - - function getRUID() { - var ctrl = fileInputs[0] || fileDrops[0]; - if (ctrl) { - return ctrl.getRuntime().uid; - } - return false; - } - - - function runtimeCan(file, cap) { - if (file.ruid) { - var info = o.Runtime.getInfo(file.ruid); - if (info) { - return info.can(cap); - } - } - return false; - } - - - function bindEventListeners() { - this.bind('FilesAdded', onFilesAdded); - - this.bind('CancelUpload', onCancelUpload); - - this.bind('BeforeUpload', onBeforeUpload); - - this.bind('UploadFile', onUploadFile); - - this.bind('UploadProgress', onUploadProgress); - - this.bind('StateChanged', onStateChanged); - - this.bind('QueueChanged', calc); - - this.bind('Error', onError); - - this.bind('FileUploaded', onFileUploaded); - - this.bind('Destroy', onDestroy); - } - - - function initControls(settings, cb) { - var self = this, inited = 0, queue = []; - - // common settings - var options = { - accept: settings.filters.mime_types, - runtime_order: settings.runtimes, - required_caps: settings.required_features, - preferred_caps: preferred_caps, - swf_url: settings.flash_swf_url, - xap_url: settings.silverlight_xap_url - }; - - // add runtime specific options if any - plupload.each(settings.runtimes.split(/\s*,\s*/), function(runtime) { - if (settings[runtime]) { - options[runtime] = settings[runtime]; - } - }); - - // initialize file pickers - there can be many - if (settings.browse_button) { - plupload.each(settings.browse_button, function(el) { - queue.push(function(cb) { - var fileInput = new o.FileInput(plupload.extend({}, options, { - name: settings.file_data_name, - multiple: settings.multi_selection, - container: settings.container, - browse_button: el - })); - - fileInput.onready = function() { - var info = o.Runtime.getInfo(this.ruid); - - // for backward compatibility - o.extend(self.features, { - chunks: info.can('slice_blob'), - multipart: info.can('send_multipart'), - multi_selection: info.can('select_multiple') - }); - - inited++; - fileInputs.push(this); - cb(); - }; - - fileInput.onchange = function() { - self.addFile(this.files); - }; - - fileInput.bind('mouseenter mouseleave mousedown mouseup', function(e) { - if (!disabled) { - if (settings.browse_button_hover) { - if ('mouseenter' === e.type) { - o.addClass(el, settings.browse_button_hover); - } else if ('mouseleave' === e.type) { - o.removeClass(el, settings.browse_button_hover); - } - } - - if (settings.browse_button_active) { - if ('mousedown' === e.type) { - o.addClass(el, settings.browse_button_active); - } else if ('mouseup' === e.type) { - o.removeClass(el, settings.browse_button_active); - } - } - } - }); - - fileInput.bind('error runtimeerror', function() { - fileInput = null; - cb(); - }); - - fileInput.init(); - }); - }); - } - - // initialize drop zones - if (settings.drop_element) { - plupload.each(settings.drop_element, function(el) { - queue.push(function(cb) { - var fileDrop = new o.FileDrop(plupload.extend({}, options, { - drop_zone: el - })); - - fileDrop.onready = function() { - var info = o.Runtime.getInfo(this.ruid); - - self.features.dragdrop = info.can('drag_and_drop'); // for backward compatibility - - inited++; - fileDrops.push(this); - cb(); - }; - - fileDrop.ondrop = function() { - self.addFile(this.files); - }; - - fileDrop.bind('error runtimeerror', function() { - fileDrop = null; - cb(); - }); - - fileDrop.init(); - }); - }); - } - - - o.inSeries(queue, function() { - if (typeof(cb) === 'function') { - cb(inited); - } - }); - } - - - function resizeImage(blob, params, cb) { - var img = new o.Image(); - - try { - img.onload = function() { - img.downsize(params.width, params.height, params.crop, params.preserve_headers); - }; - - img.onresize = function() { - cb(this.getAsBlob(blob.type, params.quality)); - this.destroy(); - }; - - img.onerror = function() { - cb(blob); - }; - - img.load(blob); - } catch(ex) { - cb(blob); - } - } - - - function setOption(option, value, init) { - var self = this, reinitRequired = false; - - function _setOption(option, value, init) { - var oldValue = settings[option]; - - switch (option) { - case 'max_file_size': - if (option === 'max_file_size') { - settings.max_file_size = settings.filters.max_file_size = value; - } - break; - - case 'chunk_size': - if (value = plupload.parseSize(value)) { - settings[option] = value; - } - break; - - case 'filters': - // for sake of backward compatibility - if (plupload.typeOf(value) === 'array') { - value = { - mime_types: value - }; - } - - if (init) { - plupload.extend(settings.filters, value); - } else { - settings.filters = value; - } - - // if file format filters are being updated, regenerate the matching expressions - if (value.mime_types) { - settings.filters.mime_types.regexp = (function(filters) { - var extensionsRegExp = []; - - plupload.each(filters, function(filter) { - plupload.each(filter.extensions.split(/,/), function(ext) { - if (/^\s*\*\s*$/.test(ext)) { - extensionsRegExp.push('\\.*'); - } else { - extensionsRegExp.push('\\.' + ext.replace(new RegExp('[' + ('/^$.*+?|()[]{}\\'.replace(/./g, '\\$&')) + ']', 'g'), '\\$&')); - } - }); - }); - - return new RegExp('(' + extensionsRegExp.join('|') + ')$', 'i'); - }(settings.filters.mime_types)); - } - break; - - case 'resize': - if (init) { - plupload.extend(settings.resize, value, { - enabled: true - }); - } else { - settings.resize = value; - } - break; - - case 'prevent_duplicates': - settings.prevent_duplicates = settings.filters.prevent_duplicates = !!value; - break; - - case 'browse_button': - case 'drop_element': - value = plupload.get(value); - - case 'container': - case 'runtimes': - case 'multi_selection': - case 'flash_swf_url': - case 'silverlight_xap_url': - settings[option] = value; - if (!init) { - reinitRequired = true; - } - break; - - default: - settings[option] = value; - } - - if (!init) { - self.trigger('OptionChanged', option, value, oldValue); - } - } - - if (typeof(option) === 'object') { - plupload.each(option, function(value, option) { - _setOption(option, value, init); - }); - } else { - _setOption(option, value, init); - } - - if (init) { - // Normalize the list of required capabilities - settings.required_features = normalizeCaps(plupload.extend({}, settings)); - - // Come up with the list of capabilities that can affect default mode in a multi-mode runtimes - preferred_caps = normalizeCaps(plupload.extend({}, settings, { - required_features: true - })); - } else if (reinitRequired) { - self.trigger('Destroy'); - - initControls.call(self, settings, function(inited) { - if (inited) { - self.runtime = o.Runtime.getInfo(getRUID()).type; - self.trigger('Init', { runtime: self.runtime }); - self.trigger('PostInit'); - } else { - self.trigger('Error', { - code : plupload.INIT_ERROR, - message : plupload.translate('Init error.') - }); - } - }); - } - } - - - // Internal event handlers - function onFilesAdded(up, filteredFiles) { - // Add files to queue - [].push.apply(files, filteredFiles); - - up.trigger('QueueChanged'); - up.refresh(); - } - - - function onBeforeUpload(up, file) { - // Generate unique target filenames - if (settings.unique_names) { - var matches = file.name.match(/\.([^.]+)$/), ext = "part"; - if (matches) { - ext = matches[1]; - } - file.target_name = file.id + '.' + ext; - } - } - - - function onUploadFile(up, file) { - var url = up.settings.url - , chunkSize = up.settings.chunk_size - , retries = up.settings.max_retries - , features = up.features - , offset = 0 - , blob - ; - - // make sure we start at a predictable offset - if (file.loaded) { - offset = file.loaded = chunkSize * Math.floor(file.loaded / chunkSize); - } - - function handleError() { - if (retries-- > 0) { - delay(uploadNextChunk, 1000); - } else { - file.loaded = offset; // reset all progress - - up.trigger('Error', { - code : plupload.HTTP_ERROR, - message : plupload.translate('HTTP Error.'), - file : file, - response : xhr.responseText, - status : xhr.status, - responseHeaders: xhr.getAllResponseHeaders() - }); - } - } - - function uploadNextChunk() { - var chunkBlob, formData, args, curChunkSize; - - // File upload finished - if (file.status == plupload.DONE || file.status == plupload.FAILED || up.state == plupload.STOPPED) { - return; - } - - // Standard arguments - args = {name : file.target_name || file.name}; - - if (chunkSize && features.chunks && blob.size > chunkSize) { // blob will be of type string if it was loaded in memory - curChunkSize = Math.min(chunkSize, blob.size - offset); - chunkBlob = blob.slice(offset, offset + curChunkSize); - } else { - curChunkSize = blob.size; - chunkBlob = blob; - } - - // If chunking is enabled add corresponding args, no matter if file is bigger than chunk or smaller - if (chunkSize && features.chunks) { - // Setup query string arguments - if (up.settings.send_chunk_number) { - args.chunk = Math.ceil(offset / chunkSize); - args.chunks = Math.ceil(blob.size / chunkSize); - } else { // keep support for experimental chunk format, just in case - args.offset = offset; - args.total = blob.size; - } - } - - xhr = new o.XMLHttpRequest(); - - // Do we have upload progress support - if (xhr.upload) { - xhr.upload.onprogress = function(e) { - file.loaded = Math.min(file.size, offset + e.loaded); - up.trigger('UploadProgress', file); - }; - } - - xhr.onload = function() { - // check if upload made itself through - if (xhr.status >= 400) { - handleError(); - return; - } - - retries = up.settings.max_retries; // reset the counter - - // Handle chunk response - if (curChunkSize < blob.size) { - chunkBlob.destroy(); - - offset += curChunkSize; - file.loaded = Math.min(offset, blob.size); - - up.trigger('ChunkUploaded', file, { - offset : file.loaded, - total : blob.size, - response : xhr.responseText, - status : xhr.status, - responseHeaders: xhr.getAllResponseHeaders() - }); - - // stock Android browser doesn't fire upload progress events, but in chunking mode we can fake them - if (o.Env.browser === 'Android Browser') { - // doesn't harm in general, but is not required anywhere else - up.trigger('UploadProgress', file); - } - } else { - file.loaded = file.size; - } - - chunkBlob = formData = null; // Free memory - - // Check if file is uploaded - if (!offset || offset >= blob.size) { - // If file was modified, destory the copy - if (file.size != file.origSize) { - blob.destroy(); - blob = null; - } - - up.trigger('UploadProgress', file); - - file.status = plupload.DONE; - - up.trigger('FileUploaded', file, { - response : xhr.responseText, - status : xhr.status, - responseHeaders: xhr.getAllResponseHeaders() - }); - } else { - // Still chunks left - delay(uploadNextChunk, 1); // run detached, otherwise event handlers interfere - } - }; - - xhr.onerror = function() { - handleError(); - }; - - xhr.onloadend = function() { - this.destroy(); - xhr = null; - }; - - // Build multipart request - if (up.settings.multipart && features.multipart) { - - args.name = file.target_name || file.name; - - xhr.open("post", url, true); - - // Set custom headers - plupload.each(up.settings.headers, function(value, name) { - xhr.setRequestHeader(name, value); - }); - - formData = new o.FormData(); - - // Add multipart params - plupload.each(plupload.extend(args, up.settings.multipart_params), function(value, name) { - formData.append(name, value); - }); - - // Add file and send it - formData.append(up.settings.file_data_name, chunkBlob); - xhr.send(formData, { - runtime_order: up.settings.runtimes, - required_caps: up.settings.required_features, - preferred_caps: preferred_caps, - swf_url: up.settings.flash_swf_url, - xap_url: up.settings.silverlight_xap_url - }); - } else { - // if no multipart, send as binary stream - url = plupload.buildUrl(up.settings.url, plupload.extend(args, up.settings.multipart_params)); - - xhr.open("post", url, true); - - xhr.setRequestHeader('Content-Type', 'application/octet-stream'); // Binary stream header - - // Set custom headers - plupload.each(up.settings.headers, function(value, name) { - xhr.setRequestHeader(name, value); - }); - - xhr.send(chunkBlob, { - runtime_order: up.settings.runtimes, - required_caps: up.settings.required_features, - preferred_caps: preferred_caps, - swf_url: up.settings.flash_swf_url, - xap_url: up.settings.silverlight_xap_url - }); - } - } - - blob = file.getSource(); - - // Start uploading chunks - if (up.settings.resize.enabled && runtimeCan(blob, 'send_binary_string') && !!~o.inArray(blob.type, ['image/jpeg', 'image/png'])) { - // Resize if required - resizeImage.call(this, blob, up.settings.resize, function(resizedBlob) { - blob = resizedBlob; - file.size = resizedBlob.size; - uploadNextChunk(); - }); - } else { - uploadNextChunk(); - } - } - - - function onUploadProgress(up, file) { - calcFile(file); - } - - - function onStateChanged(up) { - if (up.state == plupload.STARTED) { - // Get start time to calculate bps - startTime = (+new Date()); - } else if (up.state == plupload.STOPPED) { - // Reset currently uploading files - for (var i = up.files.length - 1; i >= 0; i--) { - if (up.files[i].status == plupload.UPLOADING) { - up.files[i].status = plupload.QUEUED; - calc(); - } - } - } - } - - - function onCancelUpload() { - if (xhr) { - xhr.abort(); - } - } - - - function onFileUploaded(up) { - calc(); - - // Upload next file but detach it from the error event - // since other custom listeners might want to stop the queue - delay(function() { - uploadNext.call(up); - }, 1); - } - - - function onError(up, err) { - // Set failed status if an error occured on a file - if (err.file) { - err.file.status = plupload.FAILED; - calcFile(err.file); - - // Upload next file but detach it from the error event - // since other custom listeners might want to stop the queue - if (up.state == plupload.STARTED) { // upload in progress - up.trigger('CancelUpload'); - delay(function() { - uploadNext.call(up); - }, 1); - } - } - } - - - function onDestroy(up) { - up.stop(); - - // Purge the queue - plupload.each(files, function(file) { - file.destroy(); - }); - files = []; - - if (fileInputs.length) { - plupload.each(fileInputs, function(fileInput) { - fileInput.destroy(); - }); - fileInputs = []; - } - - if (fileDrops.length) { - plupload.each(fileDrops, function(fileDrop) { - fileDrop.destroy(); - }); - fileDrops = []; - } - - preferred_caps = {}; - disabled = false; - startTime = xhr = null; - total.reset(); - } - - - // Default settings - settings = { - runtimes: o.Runtime.order, - max_retries: 0, - chunk_size: 0, - multipart: true, - multi_selection: true, - file_data_name: 'file', - flash_swf_url: 'js/Moxie.swf', - silverlight_xap_url: 'js/Moxie.xap', - filters: { - mime_types: [], - prevent_duplicates: false, - max_file_size: 0 - }, - resize: { - enabled: false, - preserve_headers: true, - crop: false - }, - send_chunk_number: true // whether to send chunks and chunk numbers, or total and offset bytes - }; - - - setOption.call(this, options, null, true); - - // Inital total state - total = new plupload.QueueProgress(); - - // Add public methods - plupload.extend(this, { - - /** - * Unique id for the Uploader instance. - * - * @property id - * @type String - */ - id : uid, - uid : uid, // mOxie uses this to differentiate between event targets - - /** - * Current state of the total uploading progress. This one can either be plupload.STARTED or plupload.STOPPED. - * These states are controlled by the stop/start methods. The default value is STOPPED. - * - * @property state - * @type Number - */ - state : plupload.STOPPED, - - /** - * Map of features that are available for the uploader runtime. Features will be filled - * before the init event is called, these features can then be used to alter the UI for the end user. - * Some of the current features that might be in this map is: dragdrop, chunks, jpgresize, pngresize. - * - * @property features - * @type Object - */ - features : {}, - - /** - * Current runtime name. - * - * @property runtime - * @type String - */ - runtime : null, - - /** - * Current upload queue, an array of File instances. - * - * @property files - * @type Array - * @see plupload.File - */ - files : files, - - /** - * Object with name/value settings. - * - * @property settings - * @type Object - */ - settings : settings, - - /** - * Total progess information. How many files has been uploaded, total percent etc. - * - * @property total - * @type plupload.QueueProgress - */ - total : total, - - - /** - * Initializes the Uploader instance and adds internal event listeners. - * - * @method init - */ - init : function() { - var self = this; - - if (typeof(settings.preinit) == "function") { - settings.preinit(self); - } else { - plupload.each(settings.preinit, function(func, name) { - self.bind(name, func); - }); - } - - // Check for required options - if (!settings.browse_button || !settings.url) { - this.trigger('Error', { - code : plupload.INIT_ERROR, - message : plupload.translate('Init error.') - }); - return; - } - - bindEventListeners.call(this); - - initControls.call(this, settings, function(inited) { - if (typeof(settings.init) == "function") { - settings.init(self); - } else { - plupload.each(settings.init, function(func, name) { - self.bind(name, func); - }); - } - - if (inited) { - self.runtime = o.Runtime.getInfo(getRUID()).type; - self.trigger('Init', { runtime: self.runtime }); - self.trigger('PostInit'); - } else { - self.trigger('Error', { - code : plupload.INIT_ERROR, - message : plupload.translate('Init error.') - }); - } - }); - }, - - /** - * Set the value for the specified option(s). - * - * @method setOption - * @since 2.1 - * @param {String|Object} option Name of the option to change or the set of key/value pairs - * @param {Mixed} [value] Value for the option (is ignored, if first argument is object) - */ - setOption: function(option, value) { - setOption.call(this, option, value, !this.runtime); // until runtime not set we do not need to reinitialize - }, - - /** - * Get the value for the specified option or the whole configuration, if not specified. - * - * @method getOption - * @since 2.1 - * @param {String} [option] Name of the option to get - * @return {Mixed} Value for the option or the whole set - */ - getOption: function(option) { - if (!option) { - return settings; - } - return settings[option]; - }, - - /** - * Refreshes the upload instance by dispatching out a refresh event to all runtimes. - * This would for example reposition flash/silverlight shims on the page. - * - * @method refresh - */ - refresh : function() { - if (fileInputs.length) { - plupload.each(fileInputs, function(fileInput) { - fileInput.trigger('Refresh'); - }); - } - this.trigger('Refresh'); - }, - - /** - * Starts uploading the queued files. - * - * @method start - */ - start : function() { - if (this.state != plupload.STARTED) { - this.state = plupload.STARTED; - this.trigger('StateChanged'); - - uploadNext.call(this); - } - }, - - /** - * Stops the upload of the queued files. - * - * @method stop - */ - stop : function() { - if (this.state != plupload.STOPPED) { - this.state = plupload.STOPPED; - this.trigger('StateChanged'); - this.trigger('CancelUpload'); - } - }, - - - /** - * Disables/enables browse button on request. - * - * @method disableBrowse - * @param {Boolean} disable Whether to disable or enable (default: true) - */ - disableBrowse : function() { - disabled = arguments[0] !== undef ? arguments[0] : true; - - if (fileInputs.length) { - plupload.each(fileInputs, function(fileInput) { - fileInput.disable(disabled); - }); - } - - this.trigger('DisableBrowse', disabled); - }, - - /** - * Returns the specified file object by id. - * - * @method getFile - * @param {String} id File id to look for. - * @return {plupload.File} File object or undefined if it wasn't found; - */ - getFile : function(id) { - var i; - for (i = files.length - 1; i >= 0; i--) { - if (files[i].id === id) { - return files[i]; - } - } - }, - - /** - * Adds file to the queue programmatically. Can be native file, instance of Plupload.File, - * instance of mOxie.File, input[type="file"] element, or array of these. Fires FilesAdded, - * if any files were added to the queue. Otherwise nothing happens. - * - * @method addFile - * @since 2.0 - * @param {plupload.File|mOxie.File|File|Node|Array} file File or files to add to the queue. - * @param {String} [fileName] If specified, will be used as a name for the file - */ - addFile : function(file, fileName) { - var self = this - , queue = [] - , files = [] - , ruid - ; - - function filterFile(file, cb) { - var queue = []; - o.each(self.settings.filters, function(rule, name) { - if (fileFilters[name]) { - queue.push(function(cb) { - fileFilters[name].call(self, rule, file, function(res) { - cb(!res); - }); - }); - } - }); - o.inSeries(queue, cb); - } - - /** - * @method resolveFile - * @private - * @param {o.File|o.Blob|plupload.File|File|Blob|input[type="file"]} file - */ - function resolveFile(file) { - var type = o.typeOf(file); - - // o.File - if (file instanceof o.File) { - if (!file.ruid && !file.isDetached()) { - if (!ruid) { // weird case - return false; - } - file.ruid = ruid; - file.connectRuntime(ruid); - } - resolveFile(new plupload.File(file)); - } - // o.Blob - else if (file instanceof o.Blob) { - resolveFile(file.getSource()); - file.destroy(); - } - // plupload.File - final step for other branches - else if (file instanceof plupload.File) { - if (fileName) { - file.name = fileName; - } - - queue.push(function(cb) { - // run through the internal and user-defined filters, if any - filterFile(file, function(err) { - if (!err) { - files.push(file); - self.trigger("FileFiltered", file); - } - delay(cb, 1); // do not build up recursions or eventually we might hit the limits - }); - }); - } - // native File or blob - else if (o.inArray(type, ['file', 'blob']) !== -1) { - resolveFile(new o.File(null, file)); - } - // input[type="file"] - else if (type === 'node' && o.typeOf(file.files) === 'filelist') { - // if we are dealing with input[type="file"] - o.each(file.files, resolveFile); - } - // mixed array of any supported types (see above) - else if (type === 'array') { - fileName = null; // should never happen, but unset anyway to avoid funny situations - o.each(file, resolveFile); - } - } - - ruid = getRUID(); - - resolveFile(file); - - if (queue.length) { - o.inSeries(queue, function() { - // if any files left after filtration, trigger FilesAdded - if (files.length) { - self.trigger("FilesAdded", files); - } - }); - } - }, - - /** - * Removes a specific file. - * - * @method removeFile - * @param {plupload.File|String} file File to remove from queue. - */ - removeFile : function(file) { - var id = typeof(file) === 'string' ? file : file.id; - - for (var i = files.length - 1; i >= 0; i--) { - if (files[i].id === id) { - return this.splice(i, 1)[0]; - } - } - }, - - /** - * Removes part of the queue and returns the files removed. This will also trigger the FilesRemoved and QueueChanged events. - * - * @method splice - * @param {Number} start (Optional) Start index to remove from. - * @param {Number} length (Optional) Lengh of items to remove. - * @return {Array} Array of files that was removed. - */ - splice : function(start, length) { - // Splice and trigger events - var removed = files.splice(start === undef ? 0 : start, length === undef ? files.length : length); - - // if upload is in progress we need to stop it and restart after files are removed - var restartRequired = false; - if (this.state == plupload.STARTED) { // upload in progress - restartRequired = true; - this.stop(); - } - - this.trigger("FilesRemoved", removed); - - // Dispose any resources allocated by those files - plupload.each(removed, function(file) { - file.destroy(); - }); - - this.trigger("QueueChanged"); - this.refresh(); - - if (restartRequired) { - this.start(); - } - - return removed; - }, - - /** - * Dispatches the specified event name and it's arguments to all listeners. - * - * - * @method trigger - * @param {String} name Event name to fire. - * @param {Object..} Multiple arguments to pass along to the listener functions. - */ - - /** - * Check whether uploader has any listeners to the specified event. - * - * @method hasEventListener - * @param {String} name Event name to check for. - */ - - - /** - * Adds an event listener by name. - * - * @method bind - * @param {String} name Event name to listen for. - * @param {function} func Function to call ones the event gets fired. - * @param {Object} scope Optional scope to execute the specified function in. - */ - bind : function(name, func, scope) { - var self = this; - // adapt moxie EventTarget style to Plupload-like - plupload.Uploader.prototype.bind.call(this, name, function() { - var args = [].slice.call(arguments); - args.splice(0, 1, self); // replace event object with uploader instance - return func.apply(this, args); - }, 0, scope); - }, - - /** - * Removes the specified event listener. - * - * @method unbind - * @param {String} name Name of event to remove. - * @param {function} func Function to remove from listener. - */ - - /** - * Removes all event listeners. - * - * @method unbindAll - */ - - - /** - * Destroys Plupload instance and cleans after itself. - * - * @method destroy - */ - destroy : function() { - this.trigger('Destroy'); - settings = total = null; // purge these exclusively - this.unbindAll(); - } - }); -}; - -plupload.Uploader.prototype = o.EventTarget.instance; - -/** - * Constructs a new file instance. - * - * @class File - * @constructor - * - * @param {Object} file Object containing file properties - * @param {String} file.name Name of the file. - * @param {Number} file.size File size. - */ -plupload.File = (function() { - var filepool = {}; - - function PluploadFile(file) { - - plupload.extend(this, { - - /** - * File id this is a globally unique id for the specific file. - * - * @property id - * @type String - */ - id: plupload.guid(), - - /** - * File name for example "myfile.gif". - * - * @property name - * @type String - */ - name: file.name || file.fileName, - - /** - * File type, `e.g image/jpeg` - * - * @property type - * @type String - */ - type: file.type || '', - - /** - * File size in bytes (may change after client-side manupilation). - * - * @property size - * @type Number - */ - size: file.size || file.fileSize, - - /** - * Original file size in bytes. - * - * @property origSize - * @type Number - */ - origSize: file.size || file.fileSize, - - /** - * Number of bytes uploaded of the files total size. - * - * @property loaded - * @type Number - */ - loaded: 0, - - /** - * Number of percentage uploaded of the file. - * - * @property percent - * @type Number - */ - percent: 0, - - /** - * Status constant matching the plupload states QUEUED, UPLOADING, FAILED, DONE. - * - * @property status - * @type Number - * @see plupload - */ - status: plupload.QUEUED, - - /** - * Date of last modification. - * - * @property lastModifiedDate - * @type {String} - */ - lastModifiedDate: file.lastModifiedDate || (new Date()).toLocaleString(), // Thu Aug 23 2012 19:40:00 GMT+0400 (GET) - - /** - * Returns native window.File object, when it's available. - * - * @method getNative - * @return {window.File} or null, if plupload.File is of different origin - */ - getNative: function() { - var file = this.getSource().getSource(); - return o.inArray(o.typeOf(file), ['blob', 'file']) !== -1 ? file : null; - }, - - /** - * Returns mOxie.File - unified wrapper object that can be used across runtimes. - * - * @method getSource - * @return {mOxie.File} or null - */ - getSource: function() { - if (!filepool[this.id]) { - return null; - } - return filepool[this.id]; - }, - - /** - * Destroys plupload.File object. - * - * @method destroy - */ - destroy: function() { - var src = this.getSource(); - if (src) { - src.destroy(); - delete filepool[this.id]; - } - } - }); - - filepool[this.id] = file; - } - - return PluploadFile; -}()); - - -/** - * Constructs a queue progress. - * - * @class QueueProgress - * @constructor - */ - plupload.QueueProgress = function() { - var self = this; // Setup alias for self to reduce code size when it's compressed - - /** - * Total queue file size. - * - * @property size - * @type Number - */ - self.size = 0; - - /** - * Total bytes uploaded. - * - * @property loaded - * @type Number - */ - self.loaded = 0; - - /** - * Number of files uploaded. - * - * @property uploaded - * @type Number - */ - self.uploaded = 0; - - /** - * Number of files failed to upload. - * - * @property failed - * @type Number - */ - self.failed = 0; - - /** - * Number of files yet to be uploaded. - * - * @property queued - * @type Number - */ - self.queued = 0; - - /** - * Total percent of the uploaded bytes. - * - * @property percent - * @type Number - */ - self.percent = 0; - - /** - * Bytes uploaded per second. - * - * @property bytesPerSec - * @type Number - */ - self.bytesPerSec = 0; - - /** - * Resets the progress to it's initial values. - * - * @method reset - */ - self.reset = function() { - self.size = self.loaded = self.uploaded = self.failed = self.queued = self.percent = self.bytesPerSec = 0; - }; -}; - -window.plupload = plupload; - -}(window, mOxie)); diff --git a/demo/js/plupload/plupload.full.min.js b/demo/js/plupload/plupload.full.min.js deleted file mode 100644 index 69d6ad12..00000000 --- a/demo/js/plupload/plupload.full.min.js +++ /dev/null @@ -1,28 +0,0 @@ -/** - * mOxie - multi-runtime File API & XMLHttpRequest L2 Polyfill - * v1.2.0 - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - * - * Date: 2014-01-16 - */ -!function(e,t){"use strict";function n(e,t){for(var n,i=[],r=0;r0&&n(o,function(n,o){n!==r&&(e(i[o])===e(n)&&~a(e(n),["array","object"])?t(i[o],n):i[o]=n)})}),i},n=function(e,t){var n,i,r,o;if(e){try{n=e.length}catch(a){n=o}if(n===o){for(i in e)if(e.hasOwnProperty(i)&&t(e[i],i)===!1)return}else for(r=0;n>r;r++)if(t(e[r],r)===!1)return}},i=function(t){var n;if(!t||"object"!==e(t))return!0;for(n in t)return!1;return!0},r=function(t,n){function i(r){"function"===e(t[r])&&t[r](function(e){++rn;n++)if(t[n]===e)return n}return-1},s=function(t,n){var i=[];"array"!==e(t)&&(t=[t]),"array"!==e(n)&&(n=[n]);for(var r in t)-1===a(t[r],n)&&i.push(t[r]);return i.length?i:!1},u=function(e,t){var i=[];return n(e,function(e){-1!==a(e,t)&&i.push(e)}),i.length?i:null},c=function(e){var t,n=[];for(t=0;ti;i++)n+=Math.floor(65535*Math.random()).toString(32);return(t||"o_")+n+(e++).toString(32)}}(),d=function(e){return e?String.prototype.trim?String.prototype.trim.call(e):e.toString().replace(/^\s*/,"").replace(/\s*$/,""):e},f=function(e){if("string"!=typeof e)return e;var t={t:1099511627776,g:1073741824,m:1048576,k:1024},n;return e=/^([0-9]+)([mgk]?)$/.exec(e.toLowerCase().replace(/[^0-9mkg]/g,"")),n=e[2],e=+e[1],t.hasOwnProperty(n)&&(e*=t[n]),e};return{guid:l,typeOf:e,extend:t,each:n,isEmptyObj:i,inSeries:r,inParallel:o,inArray:a,arrayDiff:s,arrayIntersect:u,toArray:c,trim:d,parseSizeStr:f}}),i(c,[u],function(e){var t={};return{addI18n:function(n){return e.extend(t,n)},translate:function(e){return t[e]||e},_:function(e){return this.translate(e)},sprintf:function(t){var n=[].slice.call(arguments,1);return t.replace(/%[a-z]/g,function(){var t=n.shift();return"undefined"!==e.typeOf(t)?t:""})}}}),i(l,[u,c],function(e,t){var n="application/msword,doc dot,application/pdf,pdf,application/pgp-signature,pgp,application/postscript,ps ai eps,application/rtf,rtf,application/vnd.ms-excel,xls xlb,application/vnd.ms-powerpoint,ppt pps pot,application/zip,zip,application/x-shockwave-flash,swf swfl,application/vnd.openxmlformats-officedocument.wordprocessingml.document,docx,application/vnd.openxmlformats-officedocument.wordprocessingml.template,dotx,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,xlsx,application/vnd.openxmlformats-officedocument.presentationml.presentation,pptx,application/vnd.openxmlformats-officedocument.presentationml.template,potx,application/vnd.openxmlformats-officedocument.presentationml.slideshow,ppsx,application/x-javascript,js,application/json,json,audio/mpeg,mp3 mpga mpega mp2,audio/x-wav,wav,audio/x-m4a,m4a,audio/ogg,oga ogg,audio/aiff,aiff aif,audio/flac,flac,audio/aac,aac,audio/ac3,ac3,audio/x-ms-wma,wma,image/bmp,bmp,image/gif,gif,image/jpeg,jpg jpeg jpe,image/photoshop,psd,image/png,png,image/svg+xml,svg svgz,image/tiff,tiff tif,text/plain,asc txt text diff log,text/html,htm html xhtml,text/css,css,text/csv,csv,text/rtf,rtf,video/mpeg,mpeg mpg mpe m2v,video/quicktime,qt mov,video/mp4,mp4,video/x-m4v,m4v,video/x-flv,flv,video/x-ms-wmv,wmv,video/avi,avi,video/webm,webm,video/3gpp,3gpp 3gp,video/3gpp2,3g2,video/vnd.rn-realvideo,rv,video/ogg,ogv,video/x-matroska,mkv,application/vnd.oasis.opendocument.formula-template,otf,application/octet-stream,exe",i={mimes:{},extensions:{},addMimeType:function(e){var t=e.split(/,/),n,i,r;for(n=0;ni;i++)if(e[i]!=t[i]){if(e[i]=u(e[i]),t[i]=u(t[i]),e[i]t[i]){o=1;break}}if(!n)return o;switch(n){case">":case"gt":return o>0;case">=":case"ge":return o>=0;case"<=":case"le":return 0>=o;case"==":case"=":case"eq":return 0===o;case"<>":case"!=":case"ne":return 0!==o;case"":case"<":case"lt":return 0>o;default:return null}}var n=function(e){var t="",n="?",i="function",r="undefined",o="object",a="major",s="model",u="name",c="type",l="vendor",d="version",f="architecture",p="console",h="mobile",m="tablet",g={has:function(e,t){return-1!==t.toLowerCase().indexOf(e.toLowerCase())},lowerize:function(e){return e.toLowerCase()}},v={rgx:function(){for(var t,n=0,a,s,u,c,l,d,f=arguments;n0?2==c.length?t[c[0]]=typeof c[1]==i?c[1].call(this,d):c[1]:3==c.length?t[c[0]]=typeof c[1]!==i||c[1].exec&&c[1].test?d?d.replace(c[1],c[2]):e:d?c[1].call(this,d,c[2]):e:4==c.length&&(t[c[0]]=d?c[3].call(this,d.replace(c[1],c[2])):e):t[c]=d?d:e;break}if(l)break}return t},str:function(t,i){for(var r in i)if(typeof i[r]===o&&i[r].length>0){for(var a=0;a=9)},use_data_uri_of:function(e){return t.use_data_uri&&33e3>e||t.use_data_uri_over32kb()},use_fileinput:function(){var e=document.createElement("input");return e.setAttribute("type","file"),!e.disabled}};return function(n){var i=[].slice.call(arguments);return i.shift(),"function"===e.typeOf(t[n])?t[n].apply(this,i):!!t[n]}}(),r={can:i,browser:n.browser.name,version:parseFloat(n.browser.major),os:n.os.name,osVersion:n.os.version,verComp:t,swf_url:"../flash/Moxie.swf",xap_url:"../silverlight/Moxie.xap",global_event_dispatcher:"moxie.core.EventTarget.instance.dispatchEvent"};return r.OS=r.os,r}),i(f,[d],function(e){var t=function(e){return"string"!=typeof e?e:document.getElementById(e)},n=function(e,t){if(!e.className)return!1;var n=new RegExp("(^|\\s+)"+t+"(\\s+|$)");return n.test(e.className)},i=function(e,t){n(e,t)||(e.className=e.className?e.className.replace(/\s+$/,"")+" "+t:t)},r=function(e,t){if(e.className){var n=new RegExp("(^|\\s+)"+t+"(\\s+|$)");e.className=e.className.replace(n,function(e,t,n){return" "===t&&" "===n?" ":""})}},o=function(e,t){return e.currentStyle?e.currentStyle[t]:window.getComputedStyle?window.getComputedStyle(e,null)[t]:void 0},a=function(t,n){function i(e){var t,n,i=0,r=0;return e&&(n=e.getBoundingClientRect(),t="CSS1Compat"===s.compatMode?s.documentElement:s.body,i=n.left+t.scrollLeft,r=n.top+t.scrollTop),{x:i,y:r}}var r=0,o=0,a,s=document,u,c;if(t=t,n=n||s.body,t&&t.getBoundingClientRect&&"IE"===e.browser&&(!s.documentMode||s.documentMode<8))return u=i(t),c=i(n),{x:u.x-c.x,y:u.y-c.y};for(a=t;a&&a!=n&&a.nodeType;)r+=a.offsetLeft||0,o+=a.offsetTop||0,a=a.offsetParent;for(a=t.parentNode;a&&a!=n&&a.nodeType;)r-=a.scrollLeft||0,o-=a.scrollTop||0,a=a.parentNode;return{x:r,y:o}},s=function(e){return{w:e.offsetWidth||e.clientWidth,h:e.offsetHeight||e.clientHeight}};return{get:t,hasClass:n,addClass:i,removeClass:r,getStyle:o,getPos:a,getSize:s}}),i(p,[u],function(e){function t(e,t){var n;for(n in e)if(e[n]===t)return n;return null}return{RuntimeError:function(){function n(e){this.code=e,this.name=t(i,e),this.message=this.name+": RuntimeError "+this.code}var i={NOT_INIT_ERR:1,NOT_SUPPORTED_ERR:9,JS_ERR:4};return e.extend(n,i),n.prototype=Error.prototype,n}(),OperationNotAllowedException:function(){function t(e){this.code=e,this.name="OperationNotAllowedException"}return e.extend(t,{NOT_ALLOWED_ERR:1}),t.prototype=Error.prototype,t}(),ImageError:function(){function n(e){this.code=e,this.name=t(i,e),this.message=this.name+": ImageError "+this.code}var i={WRONG_FORMAT:1,MAX_RESOLUTION_ERR:2};return e.extend(n,i),n.prototype=Error.prototype,n}(),FileException:function(){function n(e){this.code=e,this.name=t(i,e),this.message=this.name+": FileException "+this.code}var i={NOT_FOUND_ERR:1,SECURITY_ERR:2,ABORT_ERR:3,NOT_READABLE_ERR:4,ENCODING_ERR:5,NO_MODIFICATION_ALLOWED_ERR:6,INVALID_STATE_ERR:7,SYNTAX_ERR:8};return e.extend(n,i),n.prototype=Error.prototype,n}(),DOMException:function(){function n(e){this.code=e,this.name=t(i,e),this.message=this.name+": DOMException "+this.code}var i={INDEX_SIZE_ERR:1,DOMSTRING_SIZE_ERR:2,HIERARCHY_REQUEST_ERR:3,WRONG_DOCUMENT_ERR:4,INVALID_CHARACTER_ERR:5,NO_DATA_ALLOWED_ERR:6,NO_MODIFICATION_ALLOWED_ERR:7,NOT_FOUND_ERR:8,NOT_SUPPORTED_ERR:9,INUSE_ATTRIBUTE_ERR:10,INVALID_STATE_ERR:11,SYNTAX_ERR:12,INVALID_MODIFICATION_ERR:13,NAMESPACE_ERR:14,INVALID_ACCESS_ERR:15,VALIDATION_ERR:16,TYPE_MISMATCH_ERR:17,SECURITY_ERR:18,NETWORK_ERR:19,ABORT_ERR:20,URL_MISMATCH_ERR:21,QUOTA_EXCEEDED_ERR:22,TIMEOUT_ERR:23,INVALID_NODE_TYPE_ERR:24,DATA_CLONE_ERR:25};return e.extend(n,i),n.prototype=Error.prototype,n}(),EventException:function(){function t(e){this.code=e,this.name="EventException"}return e.extend(t,{UNSPECIFIED_EVENT_TYPE_ERR:0}),t.prototype=Error.prototype,t}()}}),i(h,[p,u],function(e,t){function n(){var n={};t.extend(this,{uid:null,init:function(){this.uid||(this.uid=t.guid("uid_"))},addEventListener:function(e,i,r,o){var a=this,s;return e=t.trim(e),/\s/.test(e)?(t.each(e.split(/\s+/),function(e){a.addEventListener(e,i,r,o)}),void 0):(e=e.toLowerCase(),r=parseInt(r,10)||0,s=n[this.uid]&&n[this.uid][e]||[],s.push({fn:i,priority:r,scope:o||this}),n[this.uid]||(n[this.uid]={}),n[this.uid][e]=s,void 0)},hasEventListener:function(e){return e?!(!n[this.uid]||!n[this.uid][e]):!!n[this.uid]},removeEventListener:function(e,i){e=e.toLowerCase();var r=n[this.uid]&&n[this.uid][e],o;if(r){if(i){for(o=r.length-1;o>=0;o--)if(r[o].fn===i){r.splice(o,1);break}}else r=[];r.length||(delete n[this.uid][e],t.isEmptyObj(n[this.uid])&&delete n[this.uid])}},removeAllEventListeners:function(){n[this.uid]&&delete n[this.uid]},dispatchEvent:function(i){var r,o,a,s,u={},c=!0,l;if("string"!==t.typeOf(i)){if(s=i,"string"!==t.typeOf(s.type))throw new e.EventException(e.EventException.UNSPECIFIED_EVENT_TYPE_ERR);i=s.type,s.total!==l&&s.loaded!==l&&(u.total=s.total,u.loaded=s.loaded),u.async=s.async||!1}if(-1!==i.indexOf("::")?function(e){r=e[0],i=e[1]}(i.split("::")):r=this.uid,i=i.toLowerCase(),o=n[r]&&n[r][i]){o.sort(function(e,t){return t.priority-e.priority}),a=[].slice.call(arguments),a.shift(),u.type=i,a.unshift(u);var d=[];t.each(o,function(e){a[0].target=e.scope,u.async?d.push(function(t){setTimeout(function(){t(e.fn.apply(e.scope,a)===!1)},1)}):d.push(function(t){t(e.fn.apply(e.scope,a)===!1)})}),d.length&&t.inSeries(d,function(e){c=!e})}return c},bind:function(){this.addEventListener.apply(this,arguments)},unbind:function(){this.removeEventListener.apply(this,arguments)},unbindAll:function(){this.removeAllEventListeners.apply(this,arguments)},trigger:function(){return this.dispatchEvent.apply(this,arguments)},convertEventPropsToHandlers:function(e){var n;"array"!==t.typeOf(e)&&(e=[e]);for(var i=0;i>16,o=255&d>>8,a=255&d,m[p++]=64==c?String.fromCharCode(r):64==l?String.fromCharCode(r,o):String.fromCharCode(r,o,a);while(f>18,u=63&d>>12,c=63&d>>6,l=63&d,m[p++]=i.charAt(s)+i.charAt(u)+i.charAt(c)+i.charAt(l);while(fa;a++)o+=String.fromCharCode(r[a]);return o}}t.call(this),e.extend(this,{uid:e.guid("uid_"),readAsBinaryString:function(e){return i.call(this,"readAsBinaryString",e)},readAsDataURL:function(e){return i.call(this,"readAsDataURL",e)},readAsText:function(e){return i.call(this,"readAsText",e)}})}}),i(S,[p,u,y],function(e,t,n){function i(){var e,i=[];t.extend(this,{append:function(r,o){var a=this,s=t.typeOf(o);o instanceof n?e={name:r,value:o}:"array"===s?(r+="[]",t.each(o,function(e){a.append(r,e)})):"object"===s?t.each(o,function(e,t){a.append(r+"["+t+"]",e)}):"null"===s||"undefined"===s||"number"===s&&isNaN(o)?a.append(r,"false"):i.push({name:r,value:o.toString()})},hasBlob:function(){return!!this.getBlob()},getBlob:function(){return e&&e.value||null},getBlobName:function(){return e&&e.name||null},each:function(n){t.each(i,function(e){n(e.value,e.name)}),e&&n(e.value,e.name)},destroy:function(){e=null,i=[]}})}return i}),i(A,[u,p,h,m,b,g,x,y,T,S,d,l],function(e,t,n,i,r,o,a,s,u,c,l,d){function f(){this.uid=e.guid("uid_")}function p(){function n(e,t){return y.hasOwnProperty(e)?1===arguments.length?l.can("define_property")?y[e]:v[e]:(l.can("define_property")?y[e]=t:v[e]=t,void 0):void 0}function u(t){function i(){k.destroy(),k=null,s.dispatchEvent("loadend"),s=null}function r(r){k.bind("LoadStart",function(e){n("readyState",p.LOADING),s.dispatchEvent("readystatechange"),s.dispatchEvent(e),I&&s.upload.dispatchEvent(e)}),k.bind("Progress",function(e){n("readyState")!==p.LOADING&&(n("readyState",p.LOADING),s.dispatchEvent("readystatechange")),s.dispatchEvent(e)}),k.bind("UploadProgress",function(e){I&&s.upload.dispatchEvent({type:"progress",lengthComputable:!1,total:e.total,loaded:e.loaded})}),k.bind("Load",function(t){n("readyState",p.DONE),n("status",Number(r.exec.call(k,"XMLHttpRequest","getStatus")||0)),n("statusText",h[n("status")]||""),n("response",r.exec.call(k,"XMLHttpRequest","getResponse",n("responseType"))),~e.inArray(n("responseType"),["text",""])?n("responseText",n("response")):"document"===n("responseType")&&n("responseXML",n("response")),U=r.exec.call(k,"XMLHttpRequest","getAllResponseHeaders"),s.dispatchEvent("readystatechange"),n("status")>0?(I&&s.upload.dispatchEvent(t),s.dispatchEvent(t)):(N=!0,s.dispatchEvent("error")),i()}),k.bind("Abort",function(e){s.dispatchEvent(e),i()}),k.bind("Error",function(e){N=!0,n("readyState",p.DONE),s.dispatchEvent("readystatechange"),D=!0,s.dispatchEvent(e),i()}),r.exec.call(k,"XMLHttpRequest","send",{url:E,method:_,async:w,user:R,password:b,headers:x,mimeType:S,encoding:T,responseType:s.responseType,withCredentials:s.withCredentials,options:P},t)}var s=this;M=(new Date).getTime(),k=new a,"string"==typeof P.required_caps&&(P.required_caps=o.parseCaps(P.required_caps)),P.required_caps=e.extend({},P.required_caps,{return_response_type:s.responseType}),t instanceof c&&(P.required_caps.send_multipart=!0),L||(P.required_caps.do_cors=!0),P.ruid?r(k.connectRuntime(P)):(k.bind("RuntimeInit",function(e,t){r(t)}),k.bind("RuntimeError",function(e,t){s.dispatchEvent("RuntimeError",t)}),k.connectRuntime(P))}function g(){n("responseText",""),n("responseXML",null),n("response",null),n("status",0),n("statusText",""),M=C=null}var v=this,y={timeout:0,readyState:p.UNSENT,withCredentials:!1,status:0,statusText:"",responseType:"",responseXML:null,responseText:null,response:null},w=!0,E,_,x={},R,b,T=null,S=null,A=!1,O=!1,I=!1,D=!1,N=!1,L=!1,M,C,F=null,H=null,P={},k,U="",B;e.extend(this,y,{uid:e.guid("uid_"),upload:new f,open:function(o,a,s,u,c){var l;if(!o||!a)throw new t.DOMException(t.DOMException.SYNTAX_ERR);if(/[\u0100-\uffff]/.test(o)||i.utf8_encode(o)!==o)throw new t.DOMException(t.DOMException.SYNTAX_ERR);if(~e.inArray(o.toUpperCase(),["CONNECT","DELETE","GET","HEAD","OPTIONS","POST","PUT","TRACE","TRACK"])&&(_=o.toUpperCase()),~e.inArray(_,["CONNECT","TRACE","TRACK"]))throw new t.DOMException(t.DOMException.SECURITY_ERR);if(a=i.utf8_encode(a),l=r.parseUrl(a),L=r.hasSameOrigin(l),E=r.resolveUrl(a),(u||c)&&!L)throw new t.DOMException(t.DOMException.INVALID_ACCESS_ERR);if(R=u||l.user,b=c||l.pass,w=s||!0,w===!1&&(n("timeout")||n("withCredentials")||""!==n("responseType")))throw new t.DOMException(t.DOMException.INVALID_ACCESS_ERR);A=!w,O=!1,x={},g.call(this),n("readyState",p.OPENED),this.convertEventPropsToHandlers(["readystatechange"]),this.dispatchEvent("readystatechange")},setRequestHeader:function(r,o){var a=["accept-charset","accept-encoding","access-control-request-headers","access-control-request-method","connection","content-length","cookie","cookie2","content-transfer-encoding","date","expect","host","keep-alive","origin","referer","te","trailer","transfer-encoding","upgrade","user-agent","via"];if(n("readyState")!==p.OPENED||O)throw new t.DOMException(t.DOMException.INVALID_STATE_ERR);if(/[\u0100-\uffff]/.test(r)||i.utf8_encode(r)!==r)throw new t.DOMException(t.DOMException.SYNTAX_ERR);return r=e.trim(r).toLowerCase(),~e.inArray(r,a)||/^(proxy\-|sec\-)/.test(r)?!1:(x[r]?x[r]+=", "+o:x[r]=o,!0)},getAllResponseHeaders:function(){return U||""},getResponseHeader:function(t){return t=t.toLowerCase(),N||~e.inArray(t,["set-cookie","set-cookie2"])?null:U&&""!==U&&(B||(B={},e.each(U.split(/\r\n/),function(t){var n=t.split(/:\s+/);2===n.length&&(n[0]=e.trim(n[0]),B[n[0].toLowerCase()]={header:n[0],value:e.trim(n[1])})})),B.hasOwnProperty(t))?B[t].header+": "+B[t].value:null},overrideMimeType:function(i){var r,o;if(~e.inArray(n("readyState"),[p.LOADING,p.DONE]))throw new t.DOMException(t.DOMException.INVALID_STATE_ERR);if(i=e.trim(i.toLowerCase()),/;/.test(i)&&(r=i.match(/^([^;]+)(?:;\scharset\=)?(.*)$/))&&(i=r[1],r[2]&&(o=r[2])),!d.mimes[i])throw new t.DOMException(t.DOMException.SYNTAX_ERR);F=i,H=o},send:function(n,r){if(P="string"===e.typeOf(r)?{ruid:r}:r?r:{},this.convertEventPropsToHandlers(m),this.upload.convertEventPropsToHandlers(m),this.readyState!==p.OPENED||O)throw new t.DOMException(t.DOMException.INVALID_STATE_ERR);if(n instanceof s)P.ruid=n.ruid,S=n.type||"application/octet-stream";else if(n instanceof c){if(n.hasBlob()){var o=n.getBlob();P.ruid=o.ruid,S=o.type||"application/octet-stream"}}else"string"==typeof n&&(T="UTF-8",S="text/plain;charset=UTF-8",n=i.utf8_encode(n));this.withCredentials||(this.withCredentials=P.required_caps&&P.required_caps.send_browser_cookies&&!L),I=!A&&this.upload.hasEventListener(),N=!1,D=!n,A||(O=!0),u.call(this,n)},abort:function(){if(N=!0,A=!1,~e.inArray(n("readyState"),[p.UNSENT,p.OPENED,p.DONE]))n("readyState",p.UNSENT);else{if(n("readyState",p.DONE),O=!1,!k)throw new t.DOMException(t.DOMException.INVALID_STATE_ERR);k.getRuntime().exec.call(k,"XMLHttpRequest","abort",D),D=!0}},destroy:function(){k&&("function"===e.typeOf(k.destroy)&&k.destroy(),k=null),this.unbindAll(),this.upload&&(this.upload.unbindAll(),this.upload=null)}})}var h={100:"Continue",101:"Switching Protocols",102:"Processing",200:"OK",201:"Created",202:"Accepted",203:"Non-Authoritative Information",204:"No Content",205:"Reset Content",206:"Partial Content",207:"Multi-Status",226:"IM Used",300:"Multiple Choices",301:"Moved Permanently",302:"Found",303:"See Other",304:"Not Modified",305:"Use Proxy",306:"Reserved",307:"Temporary Redirect",400:"Bad Request",401:"Unauthorized",402:"Payment Required",403:"Forbidden",404:"Not Found",405:"Method Not Allowed",406:"Not Acceptable",407:"Proxy Authentication Required",408:"Request Timeout",409:"Conflict",410:"Gone",411:"Length Required",412:"Precondition Failed",413:"Request Entity Too Large",414:"Request-URI Too Long",415:"Unsupported Media Type",416:"Requested Range Not Satisfiable",417:"Expectation Failed",422:"Unprocessable Entity",423:"Locked",424:"Failed Dependency",426:"Upgrade Required",500:"Internal Server Error",501:"Not Implemented",502:"Bad Gateway",503:"Service Unavailable",504:"Gateway Timeout",505:"HTTP Version Not Supported",506:"Variant Also Negotiates",507:"Insufficient Storage",510:"Not Extended"};f.prototype=n.instance;var m=["loadstart","progress","abort","error","load","timeout","loadend"],g=1,v=2;return p.UNSENT=0,p.OPENED=1,p.HEADERS_RECEIVED=2,p.LOADING=3,p.DONE=4,p.prototype=n.instance,p}),i(O,[u,m,v,h],function(e,t,n,i){function r(){function i(){l=d=0,c=this.result=null}function o(t,n){var i=this;u=n,i.bind("TransportingProgress",function(t){d=t.loaded,l>d&&-1===e.inArray(i.state,[r.IDLE,r.DONE])&&a.call(i)},999),i.bind("TransportingComplete",function(){d=l,i.state=r.DONE,c=null,i.result=u.exec.call(i,"Transporter","getAsBlob",t||"")},999),i.state=r.BUSY,i.trigger("TransportingStarted"),a.call(i)}function a(){var e=this,n,i=l-d;f>i&&(f=i),n=t.btoa(c.substr(d,f)),u.exec.call(e,"Transporter","receive",n,l)}var s,u,c,l,d,f;n.call(this),e.extend(this,{uid:e.guid("uid_"),state:r.IDLE,result:null,transport:function(t,n,r){var a=this;if(r=e.extend({chunk_size:204798},r),(s=r.chunk_size%3)&&(r.chunk_size+=3-s),f=r.chunk_size,i.call(this),c=t,l=t.length,"string"===e.typeOf(r)||r.ruid)o.call(a,n,this.connectRuntime(r));else{var u=function(e,t){a.unbind("RuntimeInit",u),o.call(a,n,t)};this.bind("RuntimeInit",u),this.connectRuntime(r)}},abort:function(){var e=this;e.state=r.IDLE,u&&(u.exec.call(e,"Transporter","clear"),e.trigger("TransportingAborted")),i.call(e)},destroy:function(){this.unbindAll(),u=null,this.disconnectRuntime(),i.call(this)}})}return r.IDLE=0,r.BUSY=1,r.DONE=2,r.prototype=i.instance,r}),i(I,[u,f,p,T,A,g,v,O,d,h,y,w,m],function(e,t,n,i,r,o,a,s,u,c,l,d,f){function p(){function i(e){e||(e=this.getRuntime().exec.call(this,"Image","getInfo")),this.size=e.size,this.width=e.width,this.height=e.height,this.type=e.type,this.meta=e.meta,""===this.name&&(this.name=e.name)}function c(t){var i=e.typeOf(t);try{if(t instanceof p){if(!t.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);m.apply(this,arguments)}else if(t instanceof l){if(!~e.inArray(t.type,["image/jpeg","image/png"]))throw new n.ImageError(n.ImageError.WRONG_FORMAT);g.apply(this,arguments)}else if(-1!==e.inArray(i,["blob","file"]))c.call(this,new d(null,t),arguments[1]);else if("string"===i)/^data:[^;]*;base64,/.test(t)?c.call(this,new l(null,{data:t}),arguments[1]):v.apply(this,arguments);else{if("node"!==i||"img"!==t.nodeName.toLowerCase())throw new n.DOMException(n.DOMException.TYPE_MISMATCH_ERR);c.call(this,t.src,arguments[1])}}catch(r){this.trigger("error",r)}}function m(t,n){var i=this.connectRuntime(t.ruid);this.ruid=i.uid,i.exec.call(this,"Image","loadFromImage",t,"undefined"===e.typeOf(n)?!0:n)}function g(t,n){function i(e){r.ruid=e.uid,e.exec.call(r,"Image","loadFromBlob",t)}var r=this;r.name=t.name||"",t.isDetached()?(this.bind("RuntimeInit",function(e,t){i(t)}),n&&"string"==typeof n.required_caps&&(n.required_caps=o.parseCaps(n.required_caps)),this.connectRuntime(e.extend({required_caps:{access_image_binary:!0,resize_image:!0}},n))):i(this.connectRuntime(t.ruid))}function v(e,t){var n=this,i;i=new r,i.open("get",e),i.responseType="blob",i.onprogress=function(e){n.trigger(e)},i.onload=function(){g.call(n,i.response,!0)},i.onerror=function(e){n.trigger(e)},i.onloadend=function(){i.destroy()},i.bind("RuntimeError",function(e,t){n.trigger("RuntimeError",t)}),i.send(null,t)}a.call(this),e.extend(this,{uid:e.guid("uid_"),ruid:null,name:"",size:0,width:0,height:0,type:"",meta:{},clone:function(){this.load.apply(this,arguments)},load:function(){this.bind("Load Resize",function(){i.call(this)},999),this.convertEventPropsToHandlers(h),c.apply(this,arguments)},downsize:function(t,i,r,o){try{if(!this.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);if(this.width>p.MAX_RESIZE_WIDTH||this.height>p.MAX_RESIZE_HEIGHT)throw new n.ImageError(n.ImageError.MAX_RESOLUTION_ERR);(!t&&!i||"undefined"===e.typeOf(r))&&(r=!1),t=t||this.width,i=i||this.height,o="undefined"===e.typeOf(o)?!0:!!o,this.getRuntime().exec.call(this,"Image","downsize",t,i,r,o)}catch(a){this.trigger("error",a)}},crop:function(e,t,n){this.downsize(e,t,!0,n)},getAsCanvas:function(){if(!u.can("create_canvas"))throw new n.RuntimeError(n.RuntimeError.NOT_SUPPORTED_ERR);var e=this.connectRuntime(this.ruid);return e.exec.call(this,"Image","getAsCanvas")},getAsBlob:function(e,t){if(!this.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);return e||(e="image/jpeg"),"image/jpeg"!==e||t||(t=90),this.getRuntime().exec.call(this,"Image","getAsBlob",e,t)},getAsDataURL:function(e,t){if(!this.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);return this.getRuntime().exec.call(this,"Image","getAsDataURL",e,t)},getAsBinaryString:function(e,t){var n=this.getAsDataURL(e,t);return f.atob(n.substring(n.indexOf("base64,")+7))},embed:function(i){function r(){if(u.can("create_canvas")){var t=a.getAsCanvas();if(t)return i.appendChild(t),t=null,a.destroy(),o.trigger("embedded"),void 0}var r=a.getAsDataURL(c,l);if(!r)throw new n.ImageError(n.ImageError.WRONG_FORMAT);if(u.can("use_data_uri_of",r.length))i.innerHTML='',a.destroy(),o.trigger("embedded");else{var d=new s;d.bind("TransportingComplete",function(){v=o.connectRuntime(this.result.ruid),o.bind("Embedded",function(){e.extend(v.getShimContainer().style,{top:"0px",left:"0px",width:a.width+"px",height:a.height+"px"}),v=null},999),v.exec.call(o,"ImageView","display",this.result.uid,m,g),a.destroy()}),d.transport(f.atob(r.substring(r.indexOf("base64,")+7)),c,e.extend({},h,{required_caps:{display_media:!0},runtime_order:"flash,silverlight",container:i}))}}var o=this,a,c,l,d,h=arguments[1]||{},m=this.width,g=this.height,v;try{if(!(i=t.get(i)))throw new n.DOMException(n.DOMException.INVALID_NODE_TYPE_ERR);if(!this.size)throw new n.DOMException(n.DOMException.INVALID_STATE_ERR);if(this.width>p.MAX_RESIZE_WIDTH||this.height>p.MAX_RESIZE_HEIGHT)throw new n.ImageError(n.ImageError.MAX_RESOLUTION_ERR);if(c=h.type||this.type||"image/jpeg",l=h.quality||90,d="undefined"!==e.typeOf(h.crop)?h.crop:!1,h.width)m=h.width,g=h.height||m;else{var y=t.getSize(i);y.w&&y.h&&(m=y.w,g=y.h)}return a=new p,a.bind("Resize",function(){r.call(o)}),a.bind("Load",function(){a.downsize(m,g,d,!1)}),a.clone(this,!1),a}catch(w){this.trigger("error",w)}},destroy:function(){this.ruid&&(this.getRuntime().exec.call(this,"Image","destroy"),this.disconnectRuntime()),this.unbindAll()}})}var h=["progress","load","error","resize","embedded"];return p.MAX_RESIZE_WIDTH=6500,p.MAX_RESIZE_HEIGHT=6500,p.prototype=c.instance,p}),i(D,[u,p,g,d],function(e,t,n,i){function r(t){var r=this,s=n.capTest,u=n.capTrue,c=e.extend({access_binary:s(window.FileReader||window.File&&window.File.getAsDataURL),access_image_binary:function(){return r.can("access_binary")&&!!a.Image},display_media:s(i.can("create_canvas")||i.can("use_data_uri_over32kb")),do_cors:s(window.XMLHttpRequest&&"withCredentials"in new XMLHttpRequest),drag_and_drop:s(function(){var e=document.createElement("div");return("draggable"in e||"ondragstart"in e&&"ondrop"in e)&&("IE"!==i.browser||i.version>9)}()),filter_by_extension:s(function(){return"Chrome"===i.browser&&i.version>=28||"IE"===i.browser&&i.version>=10}()),return_response_headers:u,return_response_type:function(e){return"json"===e&&window.JSON?!0:i.can("return_response_type",e)},return_status_code:u,report_upload_progress:s(window.XMLHttpRequest&&(new XMLHttpRequest).upload),resize_image:function(){return r.can("access_binary")&&i.can("create_canvas")},select_file:function(){return i.can("use_fileinput")&&window.File},select_folder:function(){return r.can("select_file")&&"Chrome"===i.browser&&i.version>=21},select_multiple:function(){return!(!r.can("select_file")||"Safari"===i.browser&&"Windows"===i.os||"iOS"===i.os&&i.verComp(i.osVersion,"7.0.4","<"))},send_binary_string:s(window.XMLHttpRequest&&((new XMLHttpRequest).sendAsBinary||window.Uint8Array&&window.ArrayBuffer)),send_custom_headers:s(window.XMLHttpRequest),send_multipart:function(){return!!(window.XMLHttpRequest&&(new XMLHttpRequest).upload&&window.FormData)||r.can("send_binary_string")},slice_blob:s(window.File&&(File.prototype.mozSlice||File.prototype.webkitSlice||File.prototype.slice)),stream_upload:function(){return r.can("slice_blob")&&r.can("send_multipart")},summon_file_dialog:s(function(){return"Firefox"===i.browser&&i.version>=4||"Opera"===i.browser&&i.version>=12||"IE"===i.browser&&i.version>=10||!!~e.inArray(i.browser,["Chrome","Safari"])}()),upload_filesize:u},arguments[2]);n.call(this,t,arguments[1]||o,c),e.extend(this,{init:function(){this.trigger("Init")},destroy:function(e){return function(){e.call(r),e=r=null}}(this.destroy)}),e.extend(this.getShim(),a)}var o="html5",a={};return n.addConstructor(o,r),a}),i(N,[D,y],function(e,t){function n(){function e(e,t,n){var i;if(!window.File.prototype.slice)return(i=window.File.prototype.webkitSlice||window.File.prototype.mozSlice)?i.call(e,t,n):null;try{return e.slice(),e.slice(t,n)}catch(r){return e.slice(t,n-t)}}this.slice=function(){return new t(this.getRuntime().uid,e.apply(this,arguments))}}return e.Blob=n}),i(L,[u],function(e){function t(){this.returnValue=!1}function n(){this.cancelBubble=!0}var i={},r="moxie_"+e.guid(),o=function(o,a,s,u){var c,l;a=a.toLowerCase(),o.addEventListener?(c=s,o.addEventListener(a,c,!1)):o.attachEvent&&(c=function(){var e=window.event;e.target||(e.target=e.srcElement),e.preventDefault=t,e.stopPropagation=n,s(e)},o.attachEvent("on"+a,c)),o[r]||(o[r]=e.guid()),i.hasOwnProperty(o[r])||(i[o[r]]={}),l=i[o[r]],l.hasOwnProperty(a)||(l[a]=[]),l[a].push({func:c,orig:s,key:u})},a=function(t,n,o){var a,s;if(n=n.toLowerCase(),t[r]&&i[t[r]]&&i[t[r]][n]){a=i[t[r]][n];for(var u=a.length-1;u>=0&&(a[u].orig!==o&&a[u].key!==o||(t.removeEventListener?t.removeEventListener(n,a[u].func,!1):t.detachEvent&&t.detachEvent("on"+n,a[u].func),a[u].orig=null,a[u].func=null,a.splice(u,1),o===s));u--);if(a.length||delete i[t[r]][n],e.isEmptyObj(i[t[r]])){delete i[t[r]];try{delete t[r]}catch(c){t[r]=s}}}},s=function(t,n){t&&t[r]&&e.each(i[t[r]],function(e,i){a(t,i,n)})};return{addEvent:o,removeEvent:a,removeAllEvents:s}}),i(M,[D,u,f,L,l,d],function(e,t,n,i,r,o){function a(){var e=[],a;t.extend(this,{init:function(s){var u=this,c=u.getRuntime(),l,d,f,p,h,m;a=s,e=[],f=a.accept.mimes||r.extList2mimes(a.accept,c.can("filter_by_extension")),d=c.getShimContainer(),d.innerHTML='",l=n.get(c.uid),t.extend(l.style,{position:"absolute",top:0,left:0,width:"100%",height:"100%"}),p=n.get(a.browse_button),c.can("summon_file_dialog")&&("static"===n.getStyle(p,"position")&&(p.style.position="relative"),h=parseInt(n.getStyle(p,"z-index"),10)||1,p.style.zIndex=h,d.style.zIndex=h-1,i.addEvent(p,"click",function(e){var t=n.get(c.uid);t&&!t.disabled&&t.click(),e.preventDefault()},u.uid)),m=c.can("summon_file_dialog")?p:d,i.addEvent(m,"mouseover",function(){u.trigger("mouseenter")},u.uid),i.addEvent(m,"mouseout",function(){u.trigger("mouseleave")},u.uid),i.addEvent(m,"mousedown",function(){u.trigger("mousedown")},u.uid),i.addEvent(n.get(a.container),"mouseup",function(){u.trigger("mouseup")},u.uid),l.onchange=function g(){if(e=[],a.directory?t.each(this.files,function(t){"."!==t.name&&e.push(t)}):e=[].slice.call(this.files),"IE"!==o.browser)this.value="";else{var n=this.cloneNode(!0);this.parentNode.replaceChild(n,this),n.onchange=g}u.trigger("change")},u.trigger({type:"ready",async:!0}),d=null},getFiles:function(){return e},disable:function(e){var t=this.getRuntime(),i;(i=n.get(t.uid))&&(i.disabled=!!e)},destroy:function(){var t=this.getRuntime(),r=t.getShim(),o=t.getShimContainer();i.removeAllEvents(o,this.uid),i.removeAllEvents(a&&n.get(a.container),this.uid),i.removeAllEvents(a&&n.get(a.browse_button),this.uid),o&&(o.innerHTML=""),r.removeInstance(this.uid),e=a=o=r=null}})}return e.FileInput=a}),i(C,[D,u,f,L,l],function(e,t,n,i,r){function o(){function e(e){for(var n=[],i=0;i=4&&u.version<7,f="Android Browser"===u.browser,m=!1;if(h=n.url.replace(/^.+?\/([\w\-\.]+)$/,"$1").toLowerCase(),p=c(),p.open(n.method,n.url,n.async,n.user,n.password),r instanceof o)r.isDetached()&&(m=!0),r=r.getSource();else if(r instanceof a){if(r.hasBlob())if(r.getBlob().isDetached())r=d.call(s,r),m=!0;else if((l||f)&&"blob"===t.typeOf(r.getBlob().getSource())&&window.FileReader)return e.call(s,n,r),void 0;if(r instanceof a){var g=new window.FormData;r.each(function(e,t){e instanceof o?g.append(t,e.getSource()):g.append(t,e)}),r=g}}p.upload?(n.withCredentials&&(p.withCredentials=!0),p.addEventListener("load",function(e){s.trigger(e)}),p.addEventListener("error",function(e){s.trigger(e)}),p.addEventListener("progress",function(e){s.trigger(e)}),p.upload.addEventListener("progress",function(e){s.trigger({type:"UploadProgress",loaded:e.loaded,total:e.total})})):p.onreadystatechange=function v(){switch(p.readyState){case 1:break;case 2:break;case 3:var e,t;try{i.hasSameOrigin(n.url)&&(e=p.getResponseHeader("Content-Length")||0),p.responseText&&(t=p.responseText.length)}catch(r){e=t=0}s.trigger({type:"progress",lengthComputable:!!e,total:parseInt(e,10),loaded:t});break;case 4:p.onreadystatechange=function(){},0===p.status?s.trigger("error"):s.trigger("load")}},t.isEmptyObj(n.headers)||t.each(n.headers,function(e,t){p.setRequestHeader(t,e)}),""!==n.responseType&&"responseType"in p&&(p.responseType="json"!==n.responseType||u.can("return_response_type","json")?n.responseType:"text"),m?p.sendAsBinary?p.sendAsBinary(r):function(){for(var e=new Uint8Array(r.length),t=0;ta;a++)i|=o.charCodeAt(e+a)<s;s++)o+=String.fromCharCode(255&t>>Math.abs(a+8*s));n(o,e,i)}var r=!1,o;return{II:function(e){return e===t?r:(r=e,void 0)},init:function(e){r=!1,o=e},SEGMENT:function(e,t,i){switch(arguments.length){case 1:return o.substr(e,o.length-e-1);case 2:return o.substr(e,t);case 3:n(i,e,t);break;default:return o}},BYTE:function(t){return e(t,1)},SHORT:function(t){return e(t,2)},LONG:function(n,r){return r===t?e(n,4):(i(n,r,4),void 0)},SLONG:function(t){var n=e(t,4);return n>2147483647?n-4294967296:n},STRING:function(t,n){var i="";for(n+=t;n>t;t++)i+=String.fromCharCode(e(t,1));return i}}}}),i(k,[P],function(e){return function t(n){var i=[],r,o,a,s=0;if(r=new e,r.init(n),65496===r.SHORT(0)){for(o=2;o<=n.length;)if(a=r.SHORT(o),a>=65488&&65495>=a)o+=2;else{if(65498===a||65497===a)break;s=r.SHORT(o+2)+2,a>=65505&&65519>=a&&i.push({hex:a,name:"APP"+(15&a),start:o,length:s,segment:r.SEGMENT(o,s)}),o+=s}return r.init(null),{headers:i,restore:function(e){var t,n;for(r.init(e),o=65504==r.SHORT(2)?4+r.SHORT(4):2,n=0,t=i.length;t>n;n++)r.SEGMENT(o,0,i[n].segment),o+=i[n].length;return e=r.SEGMENT(),r.init(null),e},strip:function(e){var n,i,o;for(i=new t(e),n=i.headers,i.purge(),r.init(e),o=n.length;o--;)r.SEGMENT(n[o].start,n[o].length,"");return e=r.SEGMENT(),r.init(null),e},get:function(e){for(var t=[],n=0,r=i.length;r>n;n++)i[n].name===e.toUpperCase()&&t.push(i[n].segment);return t},set:function(e,t){var n=[],r,o,a;for("string"==typeof t?n.push(t):n=t,r=o=0,a=i.length;a>r&&(i[r].name===e.toUpperCase()&&(i[r].segment=n[o],i[r].length=n[o].length,o++),!(o>=n.length));r++);},purge:function(){i=[],r.init(null),r=null}}}}}),i(U,[u,P],function(e,n){return function i(){function i(e,n){var i=a.SHORT(e),r,o,s,u,d,f,p,h,m=[],g={};for(r=0;i>r;r++)if(p=f=e+12*r+2,s=n[a.SHORT(p)],s!==t){switch(u=a.SHORT(p+=2),d=a.LONG(p+=2),p+=4,m=[],u){case 1:case 7:for(d>4&&(p=a.LONG(p)+c.tiffHeader),o=0;d>o;o++)m[o]=a.BYTE(p+o);break;case 2:d>4&&(p=a.LONG(p)+c.tiffHeader),g[s]=a.STRING(p,d-1);continue;case 3:for(d>2&&(p=a.LONG(p)+c.tiffHeader),o=0;d>o;o++)m[o]=a.SHORT(p+2*o);break;case 4:for(d>1&&(p=a.LONG(p)+c.tiffHeader),o=0;d>o;o++)m[o]=a.LONG(p+4*o);break;case 5:for(p=a.LONG(p)+c.tiffHeader,o=0;d>o;o++)m[o]=a.LONG(p+4*o)/a.LONG(p+4*o+4);break;case 9:for(p=a.LONG(p)+c.tiffHeader,o=0;d>o;o++)m[o]=a.SLONG(p+4*o);break;case 10:for(p=a.LONG(p)+c.tiffHeader,o=0;d>o;o++)m[o]=a.SLONG(p+4*o)/a.SLONG(p+4*o+4);break;default:continue}h=1==d?m[0]:m,g[s]=l.hasOwnProperty(s)&&"object"!=typeof h?l[s][h]:h}return g}function r(){var e=c.tiffHeader;return a.II(18761==a.SHORT(e)),42!==a.SHORT(e+=2)?!1:(c.IFD0=c.tiffHeader+a.LONG(e+=2),u=i(c.IFD0,s.tiff),"ExifIFDPointer"in u&&(c.exifIFD=c.tiffHeader+u.ExifIFDPointer,delete u.ExifIFDPointer),"GPSInfoIFDPointer"in u&&(c.gpsIFD=c.tiffHeader+u.GPSInfoIFDPointer,delete u.GPSInfoIFDPointer),!0)}function o(e,t,n){var i,r,o,u=0;if("string"==typeof t){var l=s[e.toLowerCase()];for(var d in l)if(l[d]===t){t=d;break}}i=c[e.toLowerCase()+"IFD"],r=a.SHORT(i);for(var f=0;r>f;f++)if(o=i+12*f+2,a.SHORT(o)==t){u=o+8;break}return u?(a.LONG(u,n),!0):!1}var a,s,u,c={},l;return a=new n,s={tiff:{274:"Orientation",270:"ImageDescription",271:"Make",272:"Model",305:"Software",34665:"ExifIFDPointer",34853:"GPSInfoIFDPointer"},exif:{36864:"ExifVersion",40961:"ColorSpace",40962:"PixelXDimension",40963:"PixelYDimension",36867:"DateTimeOriginal",33434:"ExposureTime",33437:"FNumber",34855:"ISOSpeedRatings",37377:"ShutterSpeedValue",37378:"ApertureValue",37383:"MeteringMode",37384:"LightSource",37385:"Flash",37386:"FocalLength",41986:"ExposureMode",41987:"WhiteBalance",41990:"SceneCaptureType",41988:"DigitalZoomRatio",41992:"Contrast",41993:"Saturation",41994:"Sharpness"},gps:{0:"GPSVersionID",1:"GPSLatitudeRef",2:"GPSLatitude",3:"GPSLongitudeRef",4:"GPSLongitude"}},l={ColorSpace:{1:"sRGB",0:"Uncalibrated"},MeteringMode:{0:"Unknown",1:"Average",2:"CenterWeightedAverage",3:"Spot",4:"MultiSpot",5:"Pattern",6:"Partial",255:"Other"},LightSource:{1:"Daylight",2:"Fliorescent",3:"Tungsten",4:"Flash",9:"Fine weather",10:"Cloudy weather",11:"Shade",12:"Daylight fluorescent (D 5700 - 7100K)",13:"Day white fluorescent (N 4600 -5400K)",14:"Cool white fluorescent (W 3900 - 4500K)",15:"White fluorescent (WW 3200 - 3700K)",17:"Standard light A",18:"Standard light B",19:"Standard light C",20:"D55",21:"D65",22:"D75",23:"D50",24:"ISO studio tungsten",255:"Other"},Flash:{0:"Flash did not fire.",1:"Flash fired.",5:"Strobe return light not detected.",7:"Strobe return light detected.",9:"Flash fired, compulsory flash mode",13:"Flash fired, compulsory flash mode, return light not detected",15:"Flash fired, compulsory flash mode, return light detected",16:"Flash did not fire, compulsory flash mode",24:"Flash did not fire, auto mode",25:"Flash fired, auto mode",29:"Flash fired, auto mode, return light not detected",31:"Flash fired, auto mode, return light detected",32:"No flash function",65:"Flash fired, red-eye reduction mode",69:"Flash fired, red-eye reduction mode, return light not detected",71:"Flash fired, red-eye reduction mode, return light detected",73:"Flash fired, compulsory flash mode, red-eye reduction mode",77:"Flash fired, compulsory flash mode, red-eye reduction mode, return light not detected",79:"Flash fired, compulsory flash mode, red-eye reduction mode, return light detected",89:"Flash fired, auto mode, red-eye reduction mode",93:"Flash fired, auto mode, return light not detected, red-eye reduction mode",95:"Flash fired, auto mode, return light detected, red-eye reduction mode"},ExposureMode:{0:"Auto exposure",1:"Manual exposure",2:"Auto bracket"},WhiteBalance:{0:"Auto white balance",1:"Manual white balance"},SceneCaptureType:{0:"Standard",1:"Landscape",2:"Portrait",3:"Night scene"},Contrast:{0:"Normal",1:"Soft",2:"Hard"},Saturation:{0:"Normal",1:"Low saturation",2:"High saturation"},Sharpness:{0:"Normal",1:"Soft",2:"Hard"},GPSLatitudeRef:{N:"North latitude",S:"South latitude"},GPSLongitudeRef:{E:"East longitude",W:"West longitude"}},{init:function(e){return c={tiffHeader:10},e!==t&&e.length?(a.init(e),65505===a.SHORT(0)&&"EXIF\0"===a.STRING(4,5).toUpperCase()?r():!1):!1 -},TIFF:function(){return u},EXIF:function(){var t;if(t=i(c.exifIFD,s.exif),t.ExifVersion&&"array"===e.typeOf(t.ExifVersion)){for(var n=0,r="";n=65472&&65475>=t)return e+=5,{height:c.SHORT(e),width:c.SHORT(e+=2)};n=c.SHORT(e+=2),e+=n-2}return null}function s(){d&&l&&c&&(d.purge(),l.purge(),c.init(null),u=f=l=d=c=null)}var u,c,l,d,f,p;if(u=o,c=new i,c.init(u),65496!==c.SHORT(0))throw new t.ImageError(t.ImageError.WRONG_FORMAT);l=new n(o),d=new r,p=!!d.init(l.get("app1")[0]),f=a.call(this),e.extend(this,{type:"image/jpeg",size:u.length,width:f&&f.width||0,height:f&&f.height||0,setExif:function(t,n){return p?("object"===e.typeOf(t)?e.each(t,function(e,t){d.setExif(t,e)}):d.setExif(t,n),l.set("app1",d.getBinary()),void 0):!1},writeHeaders:function(){return arguments.length?l.restore(arguments[0]):u=l.restore(u)},stripHeaders:function(e){return l.strip(e)},purge:function(){s.call(this)}}),p&&(this.meta={tiff:d.TIFF(),exif:d.EXIF(),gps:d.GPS()})}return o}),i(z,[p,u,P],function(e,t,n){function i(i){function r(){var e,t;return e=a.call(this,8),"IHDR"==e.type?(t=e.start,{width:u.LONG(t),height:u.LONG(t+=4)}):null}function o(){u&&(u.init(null),s=d=c=l=u=null)}function a(e){var t,n,i,r;return t=u.LONG(e),n=u.STRING(e+=4,4),i=e+=4,r=u.LONG(e+t),{length:t,type:n,start:i,CRC:r}}var s,u,c,l,d;s=i,u=new n,u.init(s),function(){var t=0,n=0,i=[35152,20039,3338,6666];for(n=0;ng;){for(var v=g+f>a?a-g:f,y=0;o>y;){var w=y+f>o?o-y:f;h.clearRect(0,0,f,f),h.drawImage(e,-y,-g);var E=y*s/o+c<<0,_=Math.ceil(w*s/o),x=g*u/a/m+l<<0,R=Math.ceil(v*u/a/m);d.drawImage(p,0,0,w,v,E,x,_,R),y+=f}g+=f}p=h=null}function t(e){var t=e.naturalWidth,n=e.naturalHeight;if(t*n>1048576){var i=document.createElement("canvas");i.width=i.height=1;var r=i.getContext("2d");return r.drawImage(e,-t+1,0),0===r.getImageData(0,0,1,1).data[3]}return!1}function n(e,t,n){var i=document.createElement("canvas");i.width=1,i.height=n;var r=i.getContext("2d");r.drawImage(e,0,0);for(var o=r.getImageData(0,0,1,n).data,a=0,s=n,u=n;u>a;){var c=o[4*(u-1)+3];0===c?s=u:a=u,u=s+a>>1}i=null;var l=u/n;return 0===l?1:l}return{isSubsampled:t,renderTo:e}}),i(X,[D,u,p,m,w,G,q,l,d],function(e,t,n,i,r,o,a,s,u){function c(){function e(){if(!E&&!y)throw new n.ImageError(n.DOMException.INVALID_STATE_ERR);return E||y}function c(e){return i.atob(e.substring(e.indexOf("base64,")+7))}function l(e,t){return"data:"+(t||"")+";base64,"+i.btoa(e)}function d(e){var t=this;y=new Image,y.onerror=function(){g.call(this),t.trigger("error",new n.ImageError(n.ImageError.WRONG_FORMAT))},y.onload=function(){t.trigger("load")},y.src=/^data:[^;]*;base64,/.test(e)?e:l(e,x.type)}function f(e,t){var i=this,r;return window.FileReader?(r=new FileReader,r.onload=function(){t(this.result)},r.onerror=function(){i.trigger("error",new n.FileException(n.FileException.NOT_READABLE_ERR))},r.readAsDataURL(e),void 0):t(e.getAsDataURL())}function p(n,i,r,o){var a=this,s,u,c=0,l=0,d,f,p,g;if(b=o,g=this.meta&&this.meta.tiff&&this.meta.tiff.Orientation||1,-1!==t.inArray(g,[5,6,7,8])){var v=n;n=i,i=v}return d=e(),u=r?Math.max:Math.min,s=u(n/d.width,i/d.height),s>1&&(!r||o)?(this.trigger("Resize"),void 0):(E||(E=document.createElement("canvas")),f=Math.round(d.width*s),p=Math.round(d.height*s),r?(E.width=n,E.height=i,f>n&&(c=Math.round((f-n)/2)),p>i&&(l=Math.round((p-i)/2))):(E.width=f,E.height=p),b||m(E.width,E.height,g),h.call(this,d,E,-c,-l,f,p),this.width=E.width,this.height=E.height,R=!0,a.trigger("Resize"),void 0)}function h(e,t,n,i,r,o){if("iOS"===u.OS)a.renderTo(e,t,{width:r,height:o,x:n,y:i});else{var s=t.getContext("2d");s.drawImage(e,n,i,r,o)}}function m(e,t,n){switch(n){case 5:case 6:case 7:case 8:E.width=t,E.height=e;break;default:E.width=e,E.height=t}var i=E.getContext("2d");switch(n){case 2:i.translate(e,0),i.scale(-1,1);break;case 3:i.translate(e,t),i.rotate(Math.PI);break;case 4:i.translate(0,t),i.scale(1,-1);break;case 5:i.rotate(.5*Math.PI),i.scale(1,-1);break;case 6:i.rotate(.5*Math.PI),i.translate(0,-t);break;case 7:i.rotate(.5*Math.PI),i.translate(e,-t),i.scale(-1,1);break;case 8:i.rotate(-.5*Math.PI),i.translate(-e,0)}}function g(){w&&(w.purge(),w=null),_=y=E=x=null,R=!1}var v=this,y,w,E,_,x,R=!1,b=!0;t.extend(this,{loadFromBlob:function(e){var t=this,i=t.getRuntime(),r=arguments.length>1?arguments[1]:!0;if(!i.can("access_binary"))throw new n.RuntimeError(n.RuntimeError.NOT_SUPPORTED_ERR);return x=e,e.isDetached()?(_=e.getSource(),d.call(this,_),void 0):(f.call(this,e.getSource(),function(e){r&&(_=c(e)),d.call(t,e)}),void 0)},loadFromImage:function(e,t){this.meta=e.meta,x=new r(null,{name:e.name,size:e.size,type:e.type}),d.call(this,t?_=e.getAsBinaryString():e.getAsDataURL())},getInfo:function(){var t=this.getRuntime(),n;return!w&&_&&t.can("access_image_binary")&&(w=new o(_)),n={width:e().width||0,height:e().height||0,type:x.type||s.getFileMime(x.name),size:_&&_.length||x.size||0,name:x.name||"",meta:w&&w.meta||this.meta||{}}},downsize:function(){p.apply(this,arguments)},getAsCanvas:function(){return E&&(E.id=this.uid+"_canvas"),E},getAsBlob:function(e,t){return e!==this.type&&p.call(this,this.width,this.height,!1),new r(null,{name:x.name||"",type:e,data:v.getAsBinaryString.call(this,e,t)})},getAsDataURL:function(e){var t=arguments[1]||90;if(!R)return y.src;if("image/jpeg"!==e)return E.toDataURL("image/png");try{return E.toDataURL("image/jpeg",t/100)}catch(n){return E.toDataURL("image/jpeg")}},getAsBinaryString:function(e,t){if(!R)return _||(_=c(v.getAsDataURL(e,t))),_;if("image/jpeg"!==e)_=c(v.getAsDataURL(e,t));else{var n;t||(t=90);try{n=E.toDataURL("image/jpeg",t/100)}catch(i){n=E.toDataURL("image/jpeg")}_=c(n),w&&(_=w.stripHeaders(_),b&&(w.meta&&w.meta.exif&&w.setExif({PixelXDimension:this.width,PixelYDimension:this.height}),_=w.writeHeaders(_)),w.purge(),w=null)}return R=!1,_},destroy:function(){v=null,g.call(this),this.getRuntime().getShim().removeInstance(this.uid)}})}return e.Image=c}),i(j,[u,d,f,p,g],function(e,t,n,i,r){function o(){var e;try{e=navigator.plugins["Shockwave Flash"],e=e.description}catch(t){try{e=new ActiveXObject("ShockwaveFlash.ShockwaveFlash").GetVariable("$version")}catch(n){e="0.0"}}return e=e.match(/\d+/g),parseFloat(e[0]+"."+e[1])}function a(a){var c=this,l;a=e.extend({swf_url:t.swf_url},a),r.call(this,a,s,{access_binary:function(e){return e&&"browser"===c.mode},access_image_binary:function(e){return e&&"browser"===c.mode},display_media:r.capTrue,do_cors:r.capTrue,drag_and_drop:!1,report_upload_progress:function(){return"client"===c.mode},resize_image:r.capTrue,return_response_headers:!1,return_response_type:function(t){return"json"===t&&window.JSON?!0:!e.arrayDiff(t,["","text","document"])||"browser"===c.mode},return_status_code:function(t){return"browser"===c.mode||!e.arrayDiff(t,[200,404])},select_file:r.capTrue,select_multiple:r.capTrue,send_binary_string:function(e){return e&&"browser"===c.mode},send_browser_cookies:function(e){return e&&"browser"===c.mode},send_custom_headers:function(e){return e&&"browser"===c.mode},send_multipart:r.capTrue,slice_blob:r.capTrue,stream_upload:function(e){return e&&"browser"===c.mode},summon_file_dialog:!1,upload_filesize:function(t){return e.parseSizeStr(t)<=2097152||"client"===c.mode},use_http_method:function(t){return!e.arrayDiff(t,["GET","POST"])}},{access_binary:function(e){return e?"browser":"client"},access_image_binary:function(e){return e?"browser":"client"},report_upload_progress:function(e){return e?"browser":"client"},return_response_type:function(t){return e.arrayDiff(t,["","text","json","document"])?"browser":["client","browser"]},return_status_code:function(t){return e.arrayDiff(t,[200,404])?"browser":["client","browser"]},send_binary_string:function(e){return e?"browser":"client"},send_browser_cookies:function(e){return e?"browser":"client"},send_custom_headers:function(e){return e?"browser":"client"},stream_upload:function(e){return e?"client":"browser"},upload_filesize:function(t){return e.parseSizeStr(t)>=2097152?"client":"browser"}},"client"),o()<10&&(this.mode=!1),e.extend(this,{getShim:function(){return n.get(this.uid)},shimExec:function(e,t){var n=[].slice.call(arguments,2);return c.getShim().exec(this.uid,e,t,n)},init:function(){var n,r,o;o=this.getShimContainer(),e.extend(o.style,{position:"absolute",top:"-8px",left:"-8px",width:"9px",height:"9px",overflow:"hidden"}),n=''+''+''+''+"","IE"===t.browser?(r=document.createElement("div"),o.appendChild(r),r.outerHTML=n,r=o=null):o.innerHTML=n,l=setTimeout(function(){c&&!c.initialized&&c.trigger("Error",new i.RuntimeError(i.RuntimeError.NOT_INIT_ERR))},5e3)},destroy:function(e){return function(){e.call(c),clearTimeout(l),a=l=e=c=null}}(this.destroy)},u)}var s="flash",u={};return r.addConstructor(s,a),u}),i(V,[j,y],function(e,t){var n={slice:function(e,n,i,r){var o=this.getRuntime();return 0>n?n=Math.max(e.size+n,0):n>0&&(n=Math.min(n,e.size)),0>i?i=Math.max(e.size+i,0):i>0&&(i=Math.min(i,e.size)),e=o.shimExec.call(this,"Blob","slice",n,i,r||""),e&&(e=new t(o.uid,e)),e}};return e.Blob=n}),i(W,[j],function(e){var t={init:function(e){this.getRuntime().shimExec.call(this,"FileInput","init",{name:e.name,accept:e.accept,multiple:e.multiple}),this.trigger("ready")}};return e.FileInput=t}),i(Y,[j,m],function(e,t){function n(e,n){switch(n){case"readAsText":return t.atob(e,"utf8");case"readAsBinaryString":return t.atob(e);case"readAsDataURL":return e}return null}var i="",r={read:function(e,t){var r=this,o=r.getRuntime();return"readAsDataURL"===e&&(i="data:"+(t.type||"")+";base64,"),r.bind("Progress",function(t,r){r&&(i+=n(r,e))}),o.shimExec.call(this,"FileReader","readAsBase64",t.uid)},getResult:function(){return i},destroy:function(){i=null}};return e.FileReader=r}),i($,[j,m],function(e,t){function n(e,n){switch(n){case"readAsText":return t.atob(e,"utf8");case"readAsBinaryString":return t.atob(e);case"readAsDataURL":return e}return null}var i={read:function(e,t){var i,r=this.getRuntime();return(i=r.shimExec.call(this,"FileReaderSync","readAsBase64",t.uid))?("readAsDataURL"===e&&(i="data:"+(t.type||"")+";base64,"+i),n(i,e,t.type)):null}};return e.FileReaderSync=i}),i(J,[j,u,y,w,T,S,O],function(e,t,n,i,r,o,a){var s={send:function(e,i){function r(){e.transport=l.mode,l.shimExec.call(c,"XMLHttpRequest","send",e,i)}function s(e,t){l.shimExec.call(c,"XMLHttpRequest","appendBlob",e,t.uid),i=null,r()}function u(e,t){var n=new a;n.bind("TransportingComplete",function(){t(this.result)}),n.transport(e.getSource(),e.type,{ruid:l.uid})}var c=this,l=c.getRuntime();if(t.isEmptyObj(e.headers)||t.each(e.headers,function(e,t){l.shimExec.call(c,"XMLHttpRequest","setRequestHeader",t,e.toString())}),i instanceof o){var d;if(i.each(function(e,t){e instanceof n?d=t:l.shimExec.call(c,"XMLHttpRequest","append",t,e)}),i.hasBlob()){var f=i.getBlob();f.isDetached()?u(f,function(e){f.destroy(),s(d,e)}):s(d,f)}else i=null,r()}else i instanceof n?i.isDetached()?u(i,function(e){i.destroy(),i=e.uid,r()}):(i=i.uid,r()):r()},getResponse:function(e){var n,o,a=this.getRuntime();if(o=a.shimExec.call(this,"XMLHttpRequest","getResponseAsBlob")){if(o=new i(a.uid,o),"blob"===e)return o;try{if(n=new r,~t.inArray(e,["","text"]))return n.readAsText(o);if("json"===e&&window.JSON)return JSON.parse(n.readAsText(o))}finally{o.destroy()}}return null},abort:function(e){var t=this.getRuntime();t.shimExec.call(this,"XMLHttpRequest","abort"),this.dispatchEvent("readystatechange"),this.dispatchEvent("abort")}};return e.XMLHttpRequest=s}),i(Z,[j,y],function(e,t){var n={getAsBlob:function(e){var n=this.getRuntime(),i=n.shimExec.call(this,"Transporter","getAsBlob",e);return i?new t(n.uid,i):null}};return e.Transporter=n}),i(K,[j,u,O,y,T],function(e,t,n,i,r){var o={loadFromBlob:function(e){function t(e){r.shimExec.call(i,"Image","loadFromBlob",e.uid),i=r=null}var i=this,r=i.getRuntime();if(e.isDetached()){var o=new n;o.bind("TransportingComplete",function(){t(o.result.getSource())}),o.transport(e.getSource(),e.type,{ruid:r.uid})}else t(e.getSource())},loadFromImage:function(e){var t=this.getRuntime();return t.shimExec.call(this,"Image","loadFromImage",e.uid)},getAsBlob:function(e,t){var n=this.getRuntime(),r=n.shimExec.call(this,"Image","getAsBlob",e,t);return r?new i(n.uid,r):null},getAsDataURL:function(){var e=this.getRuntime(),t=e.Image.getAsBlob.apply(this,arguments),n;return t?(n=new r,n.readAsDataURL(t)):null}};return e.Image=o}),i(Q,[u,d,f,p,g],function(e,t,n,i,r){function o(e){var t=!1,n=null,i,r,o,a,s,u=0;try{try{n=new ActiveXObject("AgControl.AgControl"),n.IsVersionSupported(e)&&(t=!0),n=null}catch(c){var l=navigator.plugins["Silverlight Plug-In"];if(l){for(i=l.description,"1.0.30226.2"===i&&(i="2.0.30226.2"),r=i.split(".");r.length>3;)r.pop();for(;r.length<4;)r.push(0);for(o=e.split(".");o.length>4;)o.pop();do a=parseInt(o[u],10),s=parseInt(r[u],10),u++;while(u=a&&!isNaN(a)&&(t=!0)}}}catch(d){t=!1}return t}function a(a){var c=this,l;a=e.extend({xap_url:t.xap_url},a),r.call(this,a,s,{access_binary:r.capTrue,access_image_binary:r.capTrue,display_media:r.capTrue,do_cors:r.capTrue,drag_and_drop:!1,report_upload_progress:r.capTrue,resize_image:r.capTrue,return_response_headers:function(e){return e&&"client"===c.mode},return_response_type:function(e){return"json"!==e?!0:!!window.JSON},return_status_code:function(t){return"client"===c.mode||!e.arrayDiff(t,[200,404])},select_file:r.capTrue,select_multiple:r.capTrue,send_binary_string:r.capTrue,send_browser_cookies:function(e){return e&&"browser"===c.mode},send_custom_headers:function(e){return e&&"client"===c.mode},send_multipart:r.capTrue,slice_blob:r.capTrue,stream_upload:!0,summon_file_dialog:!1,upload_filesize:r.capTrue,use_http_method:function(t){return"client"===c.mode||!e.arrayDiff(t,["GET","POST"])}},{return_response_headers:function(e){return e?"client":"browser"},return_status_code:function(t){return e.arrayDiff(t,[200,404])?"client":["client","browser"]},send_browser_cookies:function(e){return e?"browser":"client"},send_custom_headers:function(e){return e?"client":"browser"},use_http_method:function(t){return e.arrayDiff(t,["GET","POST"])?"client":["client","browser"]}}),o("2.0.31005.0")&&"Opera"!==t.browser||(this.mode=!1),e.extend(this,{getShim:function(){return n.get(this.uid).content.Moxie},shimExec:function(e,t){var n=[].slice.call(arguments,2);return c.getShim().exec(this.uid,e,t,n)},init:function(){var e;e=this.getShimContainer(),e.innerHTML=''+''+''+''+''+''+"",l=setTimeout(function(){c&&!c.initialized&&c.trigger("Error",new i.RuntimeError(i.RuntimeError.NOT_INIT_ERR))},"Windows"!==t.OS?1e4:5e3)},destroy:function(e){return function(){e.call(c),clearTimeout(l),a=l=e=c=null}}(this.destroy)},u)}var s="silverlight",u={};return r.addConstructor(s,a),u}),i(et,[Q,u,V],function(e,t,n){return e.Blob=t.extend({},n)}),i(tt,[Q],function(e){var t={init:function(e){function t(e){for(var t="",n=0;no;o++)n=t.keys[o],s=t[n],s&&(/^(\d|[1-9]\d+)$/.test(s)?s=parseInt(s,10):/^\d*\.\d+$/.test(s)&&(s=parseFloat(s)),i.meta[e][n]=s)}),i.width=parseInt(r.width,10),i.height=parseInt(r.height,10),i.size=parseInt(r.size,10),i.type=r.type,i.name=r.name,i}})}),i(ut,[u,p,g,d],function(e,t,n,i){function r(t){var r=this,s=n.capTest,u=n.capTrue;n.call(this,t,o,{access_binary:s(window.FileReader||window.File&&File.getAsDataURL),access_image_binary:!1,display_media:s(a.Image&&(i.can("create_canvas")||i.can("use_data_uri_over32kb"))),do_cors:!1,drag_and_drop:!1,filter_by_extension:s(function(){return"Chrome"===i.browser&&i.version>=28||"IE"===i.browser&&i.version>=10}()),resize_image:function(){return a.Image&&r.can("access_binary")&&i.can("create_canvas")},report_upload_progress:!1,return_response_headers:!1,return_response_type:function(t){return"json"===t&&window.JSON?!0:!!~e.inArray(t,["text","document",""])},return_status_code:function(t){return!e.arrayDiff(t,[200,404])},select_file:function(){return i.can("use_fileinput")},select_multiple:!1,send_binary_string:!1,send_custom_headers:!1,send_multipart:!0,slice_blob:!1,stream_upload:function(){return r.can("select_file")},summon_file_dialog:s(function(){return"Firefox"===i.browser&&i.version>=4||"Opera"===i.browser&&i.version>=12||!!~e.inArray(i.browser,["Chrome","Safari"])}()),upload_filesize:u,use_http_method:function(t){return!e.arrayDiff(t,["GET","POST"])}}),e.extend(this,{init:function(){this.trigger("Init")},destroy:function(e){return function(){e.call(r),e=r=null}}(this.destroy)}),e.extend(this.getShim(),a)}var o="html4",a={};return n.addConstructor(o,r),a}),i(ct,[ut,u,f,L,l,d],function(e,t,n,i,r,o){function a(){function e(){var r=this,l=r.getRuntime(),d,f,p,h,m,g;g=t.guid("uid_"),d=l.getShimContainer(),a&&(p=n.get(a+"_form"),p&&t.extend(p.style,{top:"100%"})),h=document.createElement("form"),h.setAttribute("id",g+"_form"),h.setAttribute("method","post"),h.setAttribute("enctype","multipart/form-data"),h.setAttribute("encoding","multipart/form-data"),t.extend(h.style,{overflow:"hidden",position:"absolute",top:0,left:0,width:"100%",height:"100%"}),m=document.createElement("input"),m.setAttribute("id",g),m.setAttribute("type","file"),m.setAttribute("name",c.name||"Filedata"),m.setAttribute("accept",u.join(",")),t.extend(m.style,{fontSize:"999px",opacity:0}),h.appendChild(m),d.appendChild(h),t.extend(m.style,{position:"absolute",top:0,left:0,width:"100%",height:"100%"}),"IE"===o.browser&&o.version<10&&t.extend(m.style,{filter:"progid:DXImageTransform.Microsoft.Alpha(opacity=0)"}),m.onchange=function(){var t;this.value&&(t=this.files?this.files[0]:{name:this.value},s=[t],this.onchange=function(){},e.call(r),r.bind("change",function i(){var e=n.get(g),t=n.get(g+"_form"),o;r.unbind("change",i),r.files.length&&e&&t&&(o=r.files[0],e.setAttribute("id",o.uid),t.setAttribute("id",o.uid+"_form"),t.setAttribute("target",o.uid+"_iframe")),e=t=null},998),m=h=null,r.trigger("change"))},l.can("summon_file_dialog")&&(f=n.get(c.browse_button),i.removeEvent(f,"click",r.uid),i.addEvent(f,"click",function(e){m&&!m.disabled&&m.click(),e.preventDefault()},r.uid)),a=g,d=p=f=null}var a,s=[],u=[],c;t.extend(this,{init:function(t){var o=this,a=o.getRuntime(),s;c=t,u=t.accept.mimes||r.extList2mimes(t.accept,a.can("filter_by_extension")),s=a.getShimContainer(),function(){var e,r,u;e=n.get(t.browse_button),a.can("summon_file_dialog")&&("static"===n.getStyle(e,"position")&&(e.style.position="relative"),r=parseInt(n.getStyle(e,"z-index"),10)||1,e.style.zIndex=r,s.style.zIndex=r-1),u=a.can("summon_file_dialog")?e:s,i.addEvent(u,"mouseover",function(){o.trigger("mouseenter")},o.uid),i.addEvent(u,"mouseout",function(){o.trigger("mouseleave")},o.uid),i.addEvent(u,"mousedown",function(){o.trigger("mousedown")},o.uid),i.addEvent(n.get(t.container),"mouseup",function(){o.trigger("mouseup")},o.uid),e=null}(),e.call(this),s=null,o.trigger({type:"ready",async:!0})},getFiles:function(){return s},disable:function(e){var t;(t=n.get(a))&&(t.disabled=!!e)},destroy:function(){var e=this.getRuntime(),t=e.getShim(),r=e.getShimContainer();i.removeAllEvents(r,this.uid),i.removeAllEvents(c&&n.get(c.container),this.uid),i.removeAllEvents(c&&n.get(c.browse_button),this.uid),r&&(r.innerHTML=""),t.removeInstance(this.uid),a=s=u=c=r=t=null}})}return e.FileInput=a}),i(lt,[ut,F],function(e,t){return e.FileReader=t}),i(dt,[ut,u,f,b,p,L,y,S],function(e,t,n,i,r,o,a,s){function u(){function e(e){var t=this,i,r,a,s,u=!1;if(l){if(i=l.id.replace(/_iframe$/,""),r=n.get(i+"_form")){for(a=r.getElementsByTagName("input"),s=a.length;s--;)switch(a[s].getAttribute("type")){case"hidden":a[s].parentNode.removeChild(a[s]);break;case"file":u=!0}a=[],u||r.parentNode.removeChild(r),r=null}setTimeout(function(){o.removeEvent(l,"load",t.uid),l.parentNode&&l.parentNode.removeChild(l);var n=t.getRuntime().getShimContainer();n.children.length||n.parentNode.removeChild(n),n=l=null,e()},1)}}var u,c,l;t.extend(this,{send:function(d,f){function p(){var n=m.getShimContainer()||document.body,r=document.createElement("div");r.innerHTML='',l=r.firstChild,n.appendChild(l),o.addEvent(l,"load",function(){var n;try{n=l.contentWindow.document||l.contentDocument||window.frames[l.id].document,/^4(0[0-9]|1[0-7]|2[2346])\s/.test(n.title)?u=n.title.replace(/^(\d+).*$/,"$1"):(u=200,c=t.trim(n.body.innerHTML),h.trigger({type:"progress",loaded:c.length,total:c.length}),w&&h.trigger({type:"uploadprogress",loaded:w.size||1025,total:w.size||1025}))}catch(r){if(!i.hasSameOrigin(d.url))return e.call(h,function(){h.trigger("error")}),void 0;u=404}e.call(h,function(){h.trigger("load")})},h.uid)}var h=this,m=h.getRuntime(),g,v,y,w;if(u=c=null,f instanceof s&&f.hasBlob()){if(w=f.getBlob(),g=w.uid,y=n.get(g),v=n.get(g+"_form"),!v)throw new r.DOMException(r.DOMException.NOT_FOUND_ERR)}else g=t.guid("uid_"),v=document.createElement("form"),v.setAttribute("id",g+"_form"),v.setAttribute("method",d.method),v.setAttribute("enctype","multipart/form-data"),v.setAttribute("encoding","multipart/form-data"),v.setAttribute("target",g+"_iframe"),m.getShimContainer().appendChild(v);f instanceof s&&f.each(function(e,n){if(e instanceof a)y&&y.setAttribute("name",n);else{var i=document.createElement("input");t.extend(i,{type:"hidden",name:n,value:e}),y?v.insertBefore(i,y):v.appendChild(i)}}),v.setAttribute("action",d.url),p(),v.submit(),h.trigger("loadstart")},getStatus:function(){return u},getResponse:function(e){if("json"===e&&"string"===t.typeOf(c)&&window.JSON)try{return JSON.parse(c.replace(/^\s*]*>/,"").replace(/<\/pre>\s*$/,""))}catch(n){return null}return c},abort:function(){var t=this;l&&l.contentWindow&&(l.contentWindow.stop?l.contentWindow.stop():l.contentWindow.document.execCommand?l.contentWindow.document.execCommand("Stop"):l.src="about:blank"),e.call(this,function(){t.dispatchEvent("abort")})}})}return e.XMLHttpRequest=u}),i(ft,[ut,X],function(e,t){return e.Image=t}),a([u,c,l,d,f,p,h,m,g,v,y,w,E,_,x,R,b,T,S,A,O,I,L])}(this);;(function(){"use strict";var e={},t=moxie.core.utils.Basic.inArray;return function n(r){var i,s;for(i in r)s=typeof r[i],s==="object"&&!~t(i,["Exceptions","Env","Mime"])?n(r[i]):s==="function"&&(e[i]=r[i])}(window.moxie),e.Env=window.moxie.core.utils.Env,e.Mime=window.moxie.core.utils.Mime,e.Exceptions=window.moxie.core.Exceptions,window.mOxie=e,window.o||(window.o=e),e})(); -/** - * Plupload - multi-runtime File Uploader - * v2.1.1 - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - * - * Date: 2014-01-16 - */ -;(function(e,t,n){function s(e){function r(e,t,r){var i={chunks:"slice_blob",jpgresize:"send_binary_string",pngresize:"send_binary_string",progress:"report_upload_progress",multi_selection:"select_multiple",dragdrop:"drag_and_drop",drop_element:"drag_and_drop",headers:"send_custom_headers",canSendBinary:"send_binary",triggerDialog:"summon_file_dialog"};i[e]?n[i[e]]=t:r||(n[e]=t)}var t=e.required_features,n={};return typeof t=="string"?o.each(t.split(/\s*,\s*/),function(e){r(e,!0)}):typeof t=="object"?o.each(t,function(e,t){r(t,e)}):t===!0&&(e.multipart||(n.send_binary_string=!0),e.chunk_size>0&&(n.slice_blob=!0),e.resize.enabled&&(n.send_binary_string=!0),o.each(e,function(e,t){r(t,!!e,!0)})),n}var r=e.setTimeout,i={},o={VERSION:"2.1.1",STOPPED:1,STARTED:2,QUEUED:1,UPLOADING:2,FAILED:4,DONE:5,GENERIC_ERROR:-100,HTTP_ERROR:-200,IO_ERROR:-300,SECURITY_ERROR:-400,INIT_ERROR:-500,FILE_SIZE_ERROR:-600,FILE_EXTENSION_ERROR:-601,FILE_DUPLICATE_ERROR:-602,IMAGE_FORMAT_ERROR:-700,IMAGE_MEMORY_ERROR:-701,IMAGE_DIMENSIONS_ERROR:-702,mimeTypes:t.mimes,ua:t.ua,typeOf:t.typeOf,extend:t.extend,guid:t.guid,get:function(n){var r=[],i;t.typeOf(n)!=="array"&&(n=[n]);var s=n.length;while(s--)i=t.get(n[s]),i&&r.push(i);return r.length?r:null},each:t.each,getPos:t.getPos,getSize:t.getSize,xmlEncode:function(e){var t={"<":"lt",">":"gt","&":"amp",'"':"quot","'":"#39"},n=/[<>&\"\']/g;return e?(""+e).replace(n,function(e){return t[e]?"&"+t[e]+";":e}):e},toArray:t.toArray,inArray:t.inArray,addI18n:t.addI18n,translate:t.translate,isEmptyObj:t.isEmptyObj,hasClass:t.hasClass,addClass:t.addClass,removeClass:t.removeClass,getStyle:t.getStyle,addEvent:t.addEvent,removeEvent:t.removeEvent,removeAllEvents:t.removeAllEvents,cleanName:function(e){var t,n;n=[/[\300-\306]/g,"A",/[\340-\346]/g,"a",/\307/g,"C",/\347/g,"c",/[\310-\313]/g,"E",/[\350-\353]/g,"e",/[\314-\317]/g,"I",/[\354-\357]/g,"i",/\321/g,"N",/\361/g,"n",/[\322-\330]/g,"O",/[\362-\370]/g,"o",/[\331-\334]/g,"U",/[\371-\374]/g,"u"];for(t=0;t0?"&":"?")+n),e},formatSize:function(e){function t(e,t){return Math.round(e*Math.pow(10,t))/Math.pow(10,t)}if(e===n||/\D/.test(e))return o.translate("N/A");var r=Math.pow(1024,4);return e>r?t(e/r,1)+" "+o.translate("tb"):e>(r/=1024)?t(e/r,1)+" "+o.translate("gb"):e>(r/=1024)?t(e/r,1)+" "+o.translate("mb"):e>1024?Math.round(e/1024)+" "+o.translate("kb"):e+" "+o.translate("b")},parseSize:t.parseSizeStr,predictRuntime:function(e,n){var r,i;return r=new o.Uploader(e),i=t.Runtime.thatCan(r.getOption().required_features,n||e.runtimes),r.destroy(),i},addFileFilter:function(e,t){i[e]=t}};o.addFileFilter("mime_types",function(e,t,n){e.length&&!e.regexp.test(t.name)?(this.trigger("Error",{code:o.FILE_EXTENSION_ERROR,message:o.translate("File extension error."),file:t}),n(!1)):n(!0)}),o.addFileFilter("max_file_size",function(e,t,n){var r;e=o.parseSize(e),t.size!==r&&e&&t.size>e?(this.trigger("Error",{code:o.FILE_SIZE_ERROR,message:o.translate("File size error."),file:t}),n(!1)):n(!0)}),o.addFileFilter("prevent_duplicates",function(e,t,n){if(e){var r=this.files.length;while(r--)if(t.name===this.files[r].name&&t.size===this.files[r].size){this.trigger("Error",{code:o.FILE_DUPLICATE_ERROR,message:o.translate("Duplicate file error."),file:t}),n(!1);return}}n(!0)}),o.Uploader=function(e){function g(){var e,t=0,n;if(this.state==o.STARTED){for(n=0;n0?Math.ceil(e.loaded/e.size*100):100,b()}function b(){var e,t;d.reset();for(e=0;e0?Math.ceil(d.uploaded/f.length*100):0:(d.bytesPerSec=Math.ceil(d.loaded/((+(new Date)-p||1)/1e3)),d.percent=d.size>0?Math.ceil(d.loaded/d.size*100):0)}function w(){var e=c[0]||h[0];return e?e.getRuntime().uid:!1}function E(e,n){if(e.ruid){var r=t.Runtime.getInfo(e.ruid);if(r)return r.can(n)}return!1}function S(){this.bind("FilesAdded",C),this.bind("CancelUpload",M),this.bind("BeforeUpload",k),this.bind("UploadFile",L),this.bind("UploadProgress",A),this.bind("StateChanged",O),this.bind("QueueChanged",b),this.bind("Error",D),this.bind("FileUploaded",_),this.bind("Destroy",P)}function x(e,n){var r=this,i=0,s=[],u={accept:e.filters.mime_types,runtime_order:e.runtimes,required_caps:e.required_features,preferred_caps:l,swf_url:e.flash_swf_url,xap_url:e.silverlight_xap_url};o.each(e.runtimes.split(/\s*,\s*/),function(t){e[t]&&(u[t]=e[t])}),e.browse_button&&o.each(e.browse_button,function(n){s.push(function(s){var a=new t.FileInput(o.extend({},u,{name:e.file_data_name,multiple:e.multi_selection,container:e.container,browse_button:n}));a.onready=function(){var e=t.Runtime.getInfo(this.ruid);t.extend(r.features,{chunks:e.can("slice_blob"),multipart:e.can("send_multipart"),multi_selection:e.can("select_multiple")}),i++,c.push(this),s()},a.onchange=function(){r.addFile(this.files)},a.bind("mouseenter mouseleave mousedown mouseup",function(r){v||(e.browse_button_hover&&("mouseenter"===r.type?t.addClass(n,e.browse_button_hover):"mouseleave"===r.type&&t.removeClass(n,e.browse_button_hover)),e.browse_button_active&&("mousedown"===r.type?t.addClass(n,e.browse_button_active):"mouseup"===r.type&&t.removeClass(n,e.browse_button_active)))}),a.bind("error runtimeerror",function(){a=null,s()}),a.init()})}),e.drop_element&&o.each(e.drop_element,function(e){s.push(function(n){var s=new t.FileDrop(o.extend({},u,{drop_zone:e}));s.onready=function(){var e=t.Runtime.getInfo(this.ruid);r.features.dragdrop=e.can("drag_and_drop"),i++,h.push(this),n()},s.ondrop=function(){r.addFile(this.files)},s.bind("error runtimeerror",function(){s=null,n()}),s.init()})}),t.inSeries(s,function(){typeof n=="function"&&n(i)})}function T(e,n,r){var i=new t.Image;try{i.onload=function(){i.downsize(n.width,n.height,n.crop,n.preserve_headers)},i.onresize=function(){r(this.getAsBlob(e.type,n.quality)),this.destroy()},i.onerror=function(){r(e)},i.load(e)}catch(s){r(e)}}function N(e,n,r){function f(e,t,n){var r=a[e];switch(e){case"max_file_size":e==="max_file_size"&&(a.max_file_size=a.filters.max_file_size=t);break;case"chunk_size":if(t=o.parseSize(t))a[e]=t;break;case"filters":o.typeOf(t)==="array"&&(t={mime_types:t}),n?o.extend(a.filters,t):a.filters=t,t.mime_types&&(a.filters.mime_types.regexp=function(e){var t=[];return o.each(e,function(e){o.each(e.extensions.split(/,/),function(e){/^\s*\*\s*$/.test(e)?t.push("\\.*"):t.push("\\."+e.replace(new RegExp("["+"/^$.*+?|()[]{}\\".replace(/./g,"\\$&")+"]","g"),"\\$&"))})}),new RegExp("("+t.join("|")+")$","i")}(a.filters.mime_types));break;case"resize":n?o.extend(a.resize,t,{enabled:!0}):a.resize=t;break;case"prevent_duplicates":a.prevent_duplicates=a.filters.prevent_duplicates=!!t;break;case"browse_button":case"drop_element":t=o.get(t);case"container":case"runtimes":case"multi_selection":case"flash_swf_url":case"silverlight_xap_url":a[e]=t,n||(u=!0);break;default:a[e]=t}n||i.trigger("OptionChanged",e,t,r)}var i=this,u=!1;typeof e=="object"?o.each(e,function(e,t){f(t,e,r)}):f(e,n,r),r?(a.required_features=s(o.extend({},a)),l=s(o.extend({},a,{required_features:!0}))):u&&(i.trigger("Destroy"),x.call(i,a,function(e){e?(i.runtime=t.Runtime.getInfo(w()).type,i.trigger("Init",{runtime:i.runtime}),i.trigger("PostInit")):i.trigger("Error",{code:o.INIT_ERROR,message:o.translate("Init error.")})}))}function C(e,t){[].push.apply(f,t),e.trigger("QueueChanged"),e.refresh()}function k(e,t){if(a.unique_names){var n=t.name.match(/\.([^.]+)$/),r="part";n&&(r=n[1]),t.target_name=t.id+"."+r}}function L(e,n){function h(){u-->0?r(p,1e3):(n.loaded=f,e.trigger("Error",{code:o.HTTP_ERROR,message:o.translate("HTTP Error."),file:n,response:m.responseText,status:m.status,responseHeaders:m.getAllResponseHeaders()}))}function p(){var d,v,g,y;if(n.status==o.DONE||n.status==o.FAILED||e.state==o.STOPPED)return;g={name:n.target_name||n.name},s&&a.chunks&&c.size>s?(y=Math.min(s,c.size-f),d=c.slice(f,f+y)):(y=c.size,d=c),s&&a.chunks&&(e.settings.send_chunk_number?(g.chunk=Math.ceil(f/s),g.chunks=Math.ceil(c.size/s)):(g.offset=f,g.total=c.size)),m=new t.XMLHttpRequest,m.upload&&(m.upload.onprogress=function(t){n.loaded=Math.min(n.size,f+t.loaded),e.trigger("UploadProgress",n)}),m.onload=function(){if(m.status>=400){h();return}u=e.settings.max_retries,y=c.size?(n.size!=n.origSize&&(c.destroy(),c=null),e.trigger("UploadProgress",n),n.status=o.DONE,e.trigger("FileUploaded",n,{response:m.responseText,status:m.status,responseHeaders:m.getAllResponseHeaders()})):r(p,1)},m.onerror=function(){h()},m.onloadend=function(){this.destroy(),m=null},e.settings.multipart&&a.multipart?(g.name=n.target_name||n.name,m.open("post",i,!0),o.each(e.settings.headers,function(e,t){m.setRequestHeader(t,e)}),v=new t.FormData,o.each(o.extend(g,e.settings.multipart_params),function(e,t){v.append(t,e)}),v.append(e.settings.file_data_name,d),m.send(v,{runtime_order:e.settings.runtimes,required_caps:e.settings.required_features,preferred_caps:l,swf_url:e.settings.flash_swf_url,xap_url:e.settings.silverlight_xap_url})):(i=o.buildUrl(e.settings.url,o.extend(g,e.settings.multipart_params)),m.open("post",i,!0),m.setRequestHeader("Content-Type","application/octet-stream"),o.each(e.settings.headers,function(e,t){m.setRequestHeader(t,e)}),m.send(d,{runtime_order:e.settings.runtimes,required_caps:e.settings.required_features,preferred_caps:l,swf_url:e.settings.flash_swf_url,xap_url:e.settings.silverlight_xap_url}))}var i=e.settings.url,s=e.settings.chunk_size,u=e.settings.max_retries,a=e.features,f=0,c;n.loaded&&(f=n.loaded=s*Math.floor(n.loaded/s)),c=n.getSource(),e.settings.resize.enabled&&E(c,"send_binary_string")&&!!~t.inArray(c.type,["image/jpeg","image/png"])?T.call(this,c,e.settings.resize,function(e){c=e,n.size=e.size,p()}):p()}function A(e,t){y(t)}function O(e){if(e.state==o.STARTED)p=+(new Date);else if(e.state==o.STOPPED)for(var t=e.files.length-1;t>=0;t--)e.files[t].status==o.UPLOADING&&(e.files[t].status=o.QUEUED,b())}function M(){m&&m.abort()}function _(e){b(),r(function(){g.call(e)},1)}function D(e,t){t.file&&(t.file.status=o.FAILED,y(t.file),e.state==o.STARTED&&(e.trigger("CancelUpload"),r(function(){g.call(e)},1)))}function P(e){e.stop(),o.each(f,function(e){e.destroy()}),f=[],c.length&&(o.each(c,function(e){e.destroy()}),c=[]),h.length&&(o.each(h,function(e){e.destroy()}),h=[]),l={},v=!1,p=m=null,d.reset()}var u=o.guid(),a,f=[],l={},c=[],h=[],p,d,v=!1,m;a={runtimes:t.Runtime.order,max_retries:0,chunk_size:0,multipart:!0,multi_selection:!0,file_data_name:"file",flash_swf_url:"js/Moxie.swf",silverlight_xap_url:"js/Moxie.xap",filters:{mime_types:[],prevent_duplicates:!1,max_file_size:0},resize:{enabled:!1,preserve_headers:!0,crop:!1},send_chunk_number:!0},N.call(this,e,null,!0),d=new o.QueueProgress,o.extend(this,{id:u,uid:u,state:o.STOPPED,features:{},runtime:null,files:f,settings:a,total:d,init:function(){var e=this;typeof a.preinit=="function"?a.preinit(e):o.each(a.preinit,function(t,n){e.bind(n,t)});if(!a.browse_button||!a.url){this.trigger("Error",{code:o.INIT_ERROR,message:o.translate("Init error.")});return}S.call(this),x.call(this,a,function(n){typeof a.init=="function"?a.init(e):o.each(a.init,function(t,n){e.bind(n,t)}),n?(e.runtime=t.Runtime.getInfo(w()).type,e.trigger("Init",{runtime:e.runtime}),e.trigger("PostInit")):e.trigger("Error",{code:o.INIT_ERROR,message:o.translate("Init error.")})})},setOption:function(e,t){N.call(this,e,t,!this.runtime)},getOption:function(e){return e?a[e]:a},refresh:function(){c.length&&o.each(c,function(e){e.trigger("Refresh")}),this.trigger("Refresh")},start:function(){this.state!=o.STARTED&&(this.state=o.STARTED,this.trigger("StateChanged"),g.call(this))},stop:function(){this.state!=o.STOPPED&&(this.state=o.STOPPED,this.trigger("StateChanged"),this.trigger("CancelUpload"))},disableBrowse:function(){v=arguments[0]!==n?arguments[0]:!0,c.length&&o.each(c,function(e){e.disable(v)}),this.trigger("DisableBrowse",v)},getFile:function(e){var t;for(t=f.length-1;t>=0;t--)if(f[t].id===e)return f[t]},addFile:function(e,n){function l(e,n){var r=[];t.each(s.settings.filters,function(t,n){i[n]&&r.push(function(r){i[n].call(s,t,e,function(e){r(!e)})})}),t.inSeries(r,n)}function c(e){var i=t.typeOf(e);if(e instanceof t.File){if(!e.ruid&&!e.isDetached()){if(!f)return!1;e.ruid=f,e.connectRuntime(f)}c(new o.File(e))}else e instanceof t.Blob?(c(e.getSource()),e.destroy()):e instanceof o.File?(n&&(e.name=n),u.push(function(t){l(e,function(n){n||(a.push(e),s.trigger("FileFiltered",e)),r(t,1)})})):t.inArray(i,["file","blob"])!==-1?c(new t.File(null,e)):i==="node"&&t.typeOf(e.files)==="filelist"?t.each(e.files,c):i==="array"&&(n=null,t.each(e,c))}var s=this,u=[],a=[],f;f=w(),c(e),u.length&&t.inSeries(u,function(){a.length&&s.trigger("FilesAdded",a)})},removeFile:function(e){var t=typeof e=="string"?e:e.id;for(var n=f.length-1;n>=0;n--)if(f[n].id===t)return this.splice(n,1)[0]},splice:function(e,t){var r=f.splice(e===n?0:e,t===n?f.length:t),i=!1;return this.state==o.STARTED&&(i=!0,this.stop()),this.trigger("FilesRemoved",r),o.each(r,function(e){e.destroy()}),this.trigger("QueueChanged"),this.refresh(),i&&this.start(),r},bind:function(e,t,n){var r=this;o.Uploader.prototype.bind.call(this,e,function(){var e=[].slice.call(arguments);return e.splice(0,1,r),t.apply(this,e)},0,n)},destroy:function(){this.trigger("Destroy"),a=d=null,this.unbindAll()}})},o.Uploader.prototype=t.EventTarget.instance,o.File=function(){function n(n){o.extend(this,{id:o.guid(),name:n.name||n.fileName,type:n.type||"",size:n.size||n.fileSize,origSize:n.size||n.fileSize,loaded:0,percent:0,status:o.QUEUED,lastModifiedDate:n.lastModifiedDate||(new Date).toLocaleString(),getNative:function(){var e=this.getSource().getSource();return t.inArray(t.typeOf(e),["blob","file"])!==-1?e:null},getSource:function(){return e[this.id]?e[this.id]:null},destroy:function(){var t=this.getSource();t&&(t.destroy(),delete e[this.id])}}),e[this.id]=n}var e={};return n}(),o.QueueProgress=function(){var e=this;e.size=0,e.loaded=0,e.uploaded=0,e.failed=0,e.queued=0,e.percent=0,e.bytesPerSec=0,e.reset=function(){e.size=e.loaded=e.uploaded=e.failed=e.queued=e.percent=e.bytesPerSec=0}},e.plupload=o})(window,mOxie); \ No newline at end of file diff --git a/demo/js/plupload/plupload.min.js b/demo/js/plupload/plupload.min.js deleted file mode 100644 index 06bcd595..00000000 --- a/demo/js/plupload/plupload.min.js +++ /dev/null @@ -1,13 +0,0 @@ -/** - * Plupload - multi-runtime File Uploader - * v2.1.1 - * - * Copyright 2013, Moxiecode Systems AB - * Released under GPL License. - * - * License: http://www.plupload.com/license - * Contributing: http://www.plupload.com/contributing - * - * Date: 2014-01-16 - */ -;(function(e,t,n){function s(e){function r(e,t,r){var i={chunks:"slice_blob",jpgresize:"send_binary_string",pngresize:"send_binary_string",progress:"report_upload_progress",multi_selection:"select_multiple",dragdrop:"drag_and_drop",drop_element:"drag_and_drop",headers:"send_custom_headers",canSendBinary:"send_binary",triggerDialog:"summon_file_dialog"};i[e]?n[i[e]]=t:r||(n[e]=t)}var t=e.required_features,n={};return typeof t=="string"?o.each(t.split(/\s*,\s*/),function(e){r(e,!0)}):typeof t=="object"?o.each(t,function(e,t){r(t,e)}):t===!0&&(e.multipart||(n.send_binary_string=!0),e.chunk_size>0&&(n.slice_blob=!0),e.resize.enabled&&(n.send_binary_string=!0),o.each(e,function(e,t){r(t,!!e,!0)})),n}var r=e.setTimeout,i={},o={VERSION:"2.1.1",STOPPED:1,STARTED:2,QUEUED:1,UPLOADING:2,FAILED:4,DONE:5,GENERIC_ERROR:-100,HTTP_ERROR:-200,IO_ERROR:-300,SECURITY_ERROR:-400,INIT_ERROR:-500,FILE_SIZE_ERROR:-600,FILE_EXTENSION_ERROR:-601,FILE_DUPLICATE_ERROR:-602,IMAGE_FORMAT_ERROR:-700,IMAGE_MEMORY_ERROR:-701,IMAGE_DIMENSIONS_ERROR:-702,mimeTypes:t.mimes,ua:t.ua,typeOf:t.typeOf,extend:t.extend,guid:t.guid,get:function(n){var r=[],i;t.typeOf(n)!=="array"&&(n=[n]);var s=n.length;while(s--)i=t.get(n[s]),i&&r.push(i);return r.length?r:null},each:t.each,getPos:t.getPos,getSize:t.getSize,xmlEncode:function(e){var t={"<":"lt",">":"gt","&":"amp",'"':"quot","'":"#39"},n=/[<>&\"\']/g;return e?(""+e).replace(n,function(e){return t[e]?"&"+t[e]+";":e}):e},toArray:t.toArray,inArray:t.inArray,addI18n:t.addI18n,translate:t.translate,isEmptyObj:t.isEmptyObj,hasClass:t.hasClass,addClass:t.addClass,removeClass:t.removeClass,getStyle:t.getStyle,addEvent:t.addEvent,removeEvent:t.removeEvent,removeAllEvents:t.removeAllEvents,cleanName:function(e){var t,n;n=[/[\300-\306]/g,"A",/[\340-\346]/g,"a",/\307/g,"C",/\347/g,"c",/[\310-\313]/g,"E",/[\350-\353]/g,"e",/[\314-\317]/g,"I",/[\354-\357]/g,"i",/\321/g,"N",/\361/g,"n",/[\322-\330]/g,"O",/[\362-\370]/g,"o",/[\331-\334]/g,"U",/[\371-\374]/g,"u"];for(t=0;t0?"&":"?")+n),e},formatSize:function(e){function t(e,t){return Math.round(e*Math.pow(10,t))/Math.pow(10,t)}if(e===n||/\D/.test(e))return o.translate("N/A");var r=Math.pow(1024,4);return e>r?t(e/r,1)+" "+o.translate("tb"):e>(r/=1024)?t(e/r,1)+" "+o.translate("gb"):e>(r/=1024)?t(e/r,1)+" "+o.translate("mb"):e>1024?Math.round(e/1024)+" "+o.translate("kb"):e+" "+o.translate("b")},parseSize:t.parseSizeStr,predictRuntime:function(e,n){var r,i;return r=new o.Uploader(e),i=t.Runtime.thatCan(r.getOption().required_features,n||e.runtimes),r.destroy(),i},addFileFilter:function(e,t){i[e]=t}};o.addFileFilter("mime_types",function(e,t,n){e.length&&!e.regexp.test(t.name)?(this.trigger("Error",{code:o.FILE_EXTENSION_ERROR,message:o.translate("File extension error."),file:t}),n(!1)):n(!0)}),o.addFileFilter("max_file_size",function(e,t,n){var r;e=o.parseSize(e),t.size!==r&&e&&t.size>e?(this.trigger("Error",{code:o.FILE_SIZE_ERROR,message:o.translate("File size error."),file:t}),n(!1)):n(!0)}),o.addFileFilter("prevent_duplicates",function(e,t,n){if(e){var r=this.files.length;while(r--)if(t.name===this.files[r].name&&t.size===this.files[r].size){this.trigger("Error",{code:o.FILE_DUPLICATE_ERROR,message:o.translate("Duplicate file error."),file:t}),n(!1);return}}n(!0)}),o.Uploader=function(e){function g(){var e,t=0,n;if(this.state==o.STARTED){for(n=0;n0?Math.ceil(e.loaded/e.size*100):100,b()}function b(){var e,t;d.reset();for(e=0;e0?Math.ceil(d.uploaded/f.length*100):0:(d.bytesPerSec=Math.ceil(d.loaded/((+(new Date)-p||1)/1e3)),d.percent=d.size>0?Math.ceil(d.loaded/d.size*100):0)}function w(){var e=c[0]||h[0];return e?e.getRuntime().uid:!1}function E(e,n){if(e.ruid){var r=t.Runtime.getInfo(e.ruid);if(r)return r.can(n)}return!1}function S(){this.bind("FilesAdded",C),this.bind("CancelUpload",M),this.bind("BeforeUpload",k),this.bind("UploadFile",L),this.bind("UploadProgress",A),this.bind("StateChanged",O),this.bind("QueueChanged",b),this.bind("Error",D),this.bind("FileUploaded",_),this.bind("Destroy",P)}function x(e,n){var r=this,i=0,s=[],u={accept:e.filters.mime_types,runtime_order:e.runtimes,required_caps:e.required_features,preferred_caps:l,swf_url:e.flash_swf_url,xap_url:e.silverlight_xap_url};o.each(e.runtimes.split(/\s*,\s*/),function(t){e[t]&&(u[t]=e[t])}),e.browse_button&&o.each(e.browse_button,function(n){s.push(function(s){var a=new t.FileInput(o.extend({},u,{name:e.file_data_name,multiple:e.multi_selection,container:e.container,browse_button:n}));a.onready=function(){var e=t.Runtime.getInfo(this.ruid);t.extend(r.features,{chunks:e.can("slice_blob"),multipart:e.can("send_multipart"),multi_selection:e.can("select_multiple")}),i++,c.push(this),s()},a.onchange=function(){r.addFile(this.files)},a.bind("mouseenter mouseleave mousedown mouseup",function(r){v||(e.browse_button_hover&&("mouseenter"===r.type?t.addClass(n,e.browse_button_hover):"mouseleave"===r.type&&t.removeClass(n,e.browse_button_hover)),e.browse_button_active&&("mousedown"===r.type?t.addClass(n,e.browse_button_active):"mouseup"===r.type&&t.removeClass(n,e.browse_button_active)))}),a.bind("error runtimeerror",function(){a=null,s()}),a.init()})}),e.drop_element&&o.each(e.drop_element,function(e){s.push(function(n){var s=new t.FileDrop(o.extend({},u,{drop_zone:e}));s.onready=function(){var e=t.Runtime.getInfo(this.ruid);r.features.dragdrop=e.can("drag_and_drop"),i++,h.push(this),n()},s.ondrop=function(){r.addFile(this.files)},s.bind("error runtimeerror",function(){s=null,n()}),s.init()})}),t.inSeries(s,function(){typeof n=="function"&&n(i)})}function T(e,n,r){var i=new t.Image;try{i.onload=function(){i.downsize(n.width,n.height,n.crop,n.preserve_headers)},i.onresize=function(){r(this.getAsBlob(e.type,n.quality)),this.destroy()},i.onerror=function(){r(e)},i.load(e)}catch(s){r(e)}}function N(e,n,r){function f(e,t,n){var r=a[e];switch(e){case"max_file_size":e==="max_file_size"&&(a.max_file_size=a.filters.max_file_size=t);break;case"chunk_size":if(t=o.parseSize(t))a[e]=t;break;case"filters":o.typeOf(t)==="array"&&(t={mime_types:t}),n?o.extend(a.filters,t):a.filters=t,t.mime_types&&(a.filters.mime_types.regexp=function(e){var t=[];return o.each(e,function(e){o.each(e.extensions.split(/,/),function(e){/^\s*\*\s*$/.test(e)?t.push("\\.*"):t.push("\\."+e.replace(new RegExp("["+"/^$.*+?|()[]{}\\".replace(/./g,"\\$&")+"]","g"),"\\$&"))})}),new RegExp("("+t.join("|")+")$","i")}(a.filters.mime_types));break;case"resize":n?o.extend(a.resize,t,{enabled:!0}):a.resize=t;break;case"prevent_duplicates":a.prevent_duplicates=a.filters.prevent_duplicates=!!t;break;case"browse_button":case"drop_element":t=o.get(t);case"container":case"runtimes":case"multi_selection":case"flash_swf_url":case"silverlight_xap_url":a[e]=t,n||(u=!0);break;default:a[e]=t}n||i.trigger("OptionChanged",e,t,r)}var i=this,u=!1;typeof e=="object"?o.each(e,function(e,t){f(t,e,r)}):f(e,n,r),r?(a.required_features=s(o.extend({},a)),l=s(o.extend({},a,{required_features:!0}))):u&&(i.trigger("Destroy"),x.call(i,a,function(e){e?(i.runtime=t.Runtime.getInfo(w()).type,i.trigger("Init",{runtime:i.runtime}),i.trigger("PostInit")):i.trigger("Error",{code:o.INIT_ERROR,message:o.translate("Init error.")})}))}function C(e,t){[].push.apply(f,t),e.trigger("QueueChanged"),e.refresh()}function k(e,t){if(a.unique_names){var n=t.name.match(/\.([^.]+)$/),r="part";n&&(r=n[1]),t.target_name=t.id+"."+r}}function L(e,n){function h(){u-->0?r(p,1e3):(n.loaded=f,e.trigger("Error",{code:o.HTTP_ERROR,message:o.translate("HTTP Error."),file:n,response:m.responseText,status:m.status,responseHeaders:m.getAllResponseHeaders()}))}function p(){var d,v,g,y;if(n.status==o.DONE||n.status==o.FAILED||e.state==o.STOPPED)return;g={name:n.target_name||n.name},s&&a.chunks&&c.size>s?(y=Math.min(s,c.size-f),d=c.slice(f,f+y)):(y=c.size,d=c),s&&a.chunks&&(e.settings.send_chunk_number?(g.chunk=Math.ceil(f/s),g.chunks=Math.ceil(c.size/s)):(g.offset=f,g.total=c.size)),m=new t.XMLHttpRequest,m.upload&&(m.upload.onprogress=function(t){n.loaded=Math.min(n.size,f+t.loaded),e.trigger("UploadProgress",n)}),m.onload=function(){if(m.status>=400){h();return}u=e.settings.max_retries,y=c.size?(n.size!=n.origSize&&(c.destroy(),c=null),e.trigger("UploadProgress",n),n.status=o.DONE,e.trigger("FileUploaded",n,{response:m.responseText,status:m.status,responseHeaders:m.getAllResponseHeaders()})):r(p,1)},m.onerror=function(){h()},m.onloadend=function(){this.destroy(),m=null},e.settings.multipart&&a.multipart?(g.name=n.target_name||n.name,m.open("post",i,!0),o.each(e.settings.headers,function(e,t){m.setRequestHeader(t,e)}),v=new t.FormData,o.each(o.extend(g,e.settings.multipart_params),function(e,t){v.append(t,e)}),v.append(e.settings.file_data_name,d),m.send(v,{runtime_order:e.settings.runtimes,required_caps:e.settings.required_features,preferred_caps:l,swf_url:e.settings.flash_swf_url,xap_url:e.settings.silverlight_xap_url})):(i=o.buildUrl(e.settings.url,o.extend(g,e.settings.multipart_params)),m.open("post",i,!0),m.setRequestHeader("Content-Type","application/octet-stream"),o.each(e.settings.headers,function(e,t){m.setRequestHeader(t,e)}),m.send(d,{runtime_order:e.settings.runtimes,required_caps:e.settings.required_features,preferred_caps:l,swf_url:e.settings.flash_swf_url,xap_url:e.settings.silverlight_xap_url}))}var i=e.settings.url,s=e.settings.chunk_size,u=e.settings.max_retries,a=e.features,f=0,c;n.loaded&&(f=n.loaded=s*Math.floor(n.loaded/s)),c=n.getSource(),e.settings.resize.enabled&&E(c,"send_binary_string")&&!!~t.inArray(c.type,["image/jpeg","image/png"])?T.call(this,c,e.settings.resize,function(e){c=e,n.size=e.size,p()}):p()}function A(e,t){y(t)}function O(e){if(e.state==o.STARTED)p=+(new Date);else if(e.state==o.STOPPED)for(var t=e.files.length-1;t>=0;t--)e.files[t].status==o.UPLOADING&&(e.files[t].status=o.QUEUED,b())}function M(){m&&m.abort()}function _(e){b(),r(function(){g.call(e)},1)}function D(e,t){t.file&&(t.file.status=o.FAILED,y(t.file),e.state==o.STARTED&&(e.trigger("CancelUpload"),r(function(){g.call(e)},1)))}function P(e){e.stop(),o.each(f,function(e){e.destroy()}),f=[],c.length&&(o.each(c,function(e){e.destroy()}),c=[]),h.length&&(o.each(h,function(e){e.destroy()}),h=[]),l={},v=!1,p=m=null,d.reset()}var u=o.guid(),a,f=[],l={},c=[],h=[],p,d,v=!1,m;a={runtimes:t.Runtime.order,max_retries:0,chunk_size:0,multipart:!0,multi_selection:!0,file_data_name:"file",flash_swf_url:"js/Moxie.swf",silverlight_xap_url:"js/Moxie.xap",filters:{mime_types:[],prevent_duplicates:!1,max_file_size:0},resize:{enabled:!1,preserve_headers:!0,crop:!1},send_chunk_number:!0},N.call(this,e,null,!0),d=new o.QueueProgress,o.extend(this,{id:u,uid:u,state:o.STOPPED,features:{},runtime:null,files:f,settings:a,total:d,init:function(){var e=this;typeof a.preinit=="function"?a.preinit(e):o.each(a.preinit,function(t,n){e.bind(n,t)});if(!a.browse_button||!a.url){this.trigger("Error",{code:o.INIT_ERROR,message:o.translate("Init error.")});return}S.call(this),x.call(this,a,function(n){typeof a.init=="function"?a.init(e):o.each(a.init,function(t,n){e.bind(n,t)}),n?(e.runtime=t.Runtime.getInfo(w()).type,e.trigger("Init",{runtime:e.runtime}),e.trigger("PostInit")):e.trigger("Error",{code:o.INIT_ERROR,message:o.translate("Init error.")})})},setOption:function(e,t){N.call(this,e,t,!this.runtime)},getOption:function(e){return e?a[e]:a},refresh:function(){c.length&&o.each(c,function(e){e.trigger("Refresh")}),this.trigger("Refresh")},start:function(){this.state!=o.STARTED&&(this.state=o.STARTED,this.trigger("StateChanged"),g.call(this))},stop:function(){this.state!=o.STOPPED&&(this.state=o.STOPPED,this.trigger("StateChanged"),this.trigger("CancelUpload"))},disableBrowse:function(){v=arguments[0]!==n?arguments[0]:!0,c.length&&o.each(c,function(e){e.disable(v)}),this.trigger("DisableBrowse",v)},getFile:function(e){var t;for(t=f.length-1;t>=0;t--)if(f[t].id===e)return f[t]},addFile:function(e,n){function l(e,n){var r=[];t.each(s.settings.filters,function(t,n){i[n]&&r.push(function(r){i[n].call(s,t,e,function(e){r(!e)})})}),t.inSeries(r,n)}function c(e){var i=t.typeOf(e);if(e instanceof t.File){if(!e.ruid&&!e.isDetached()){if(!f)return!1;e.ruid=f,e.connectRuntime(f)}c(new o.File(e))}else e instanceof t.Blob?(c(e.getSource()),e.destroy()):e instanceof o.File?(n&&(e.name=n),u.push(function(t){l(e,function(n){n||(a.push(e),s.trigger("FileFiltered",e)),r(t,1)})})):t.inArray(i,["file","blob"])!==-1?c(new t.File(null,e)):i==="node"&&t.typeOf(e.files)==="filelist"?t.each(e.files,c):i==="array"&&(n=null,t.each(e,c))}var s=this,u=[],a=[],f;f=w(),c(e),u.length&&t.inSeries(u,function(){a.length&&s.trigger("FilesAdded",a)})},removeFile:function(e){var t=typeof e=="string"?e:e.id;for(var n=f.length-1;n>=0;n--)if(f[n].id===t)return this.splice(n,1)[0]},splice:function(e,t){var r=f.splice(e===n?0:e,t===n?f.length:t),i=!1;return this.state==o.STARTED&&(i=!0,this.stop()),this.trigger("FilesRemoved",r),o.each(r,function(e){e.destroy()}),this.trigger("QueueChanged"),this.refresh(),i&&this.start(),r},bind:function(e,t,n){var r=this;o.Uploader.prototype.bind.call(this,e,function(){var e=[].slice.call(arguments);return e.splice(0,1,r),t.apply(this,e)},0,n)},destroy:function(){this.trigger("Destroy"),a=d=null,this.unbindAll()}})},o.Uploader.prototype=t.EventTarget.instance,o.File=function(){function n(n){o.extend(this,{id:o.guid(),name:n.name||n.fileName,type:n.type||"",size:n.size||n.fileSize,origSize:n.size||n.fileSize,loaded:0,percent:0,status:o.QUEUED,lastModifiedDate:n.lastModifiedDate||(new Date).toLocaleString(),getNative:function(){var e=this.getSource().getSource();return t.inArray(t.typeOf(e),["blob","file"])!==-1?e:null},getSource:function(){return e[this.id]?e[this.id]:null},destroy:function(){var t=this.getSource();t&&(t.destroy(),delete e[this.id])}}),e[this.id]=n}var e={};return n}(),o.QueueProgress=function(){var e=this;e.size=0,e.loaded=0,e.uploaded=0,e.failed=0,e.queued=0,e.percent=0,e.bytesPerSec=0,e.reset=function(){e.size=e.loaded=e.uploaded=e.failed=e.queued=e.percent=e.bytesPerSec=0}},e.plupload=o})(window,mOxie); \ No newline at end of file diff --git a/demo/views/index.html b/demo/views/index.html index fe7c0dff..a1db27cd 100644 --- a/demo/views/index.html +++ b/demo/views/index.html @@ -238,7 +238,7 @@ - + From 9f262b7df4c8bb306b4330989bacfd667e8b9f56 Mon Sep 17 00:00:00 2001 From: meilixie Date: Fri, 18 Sep 2015 15:12:30 +0800 Subject: [PATCH 4/5] readme update version --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 5fbfc348..12363fe4 100644 --- a/README.md +++ b/README.md @@ -24,7 +24,7 @@ qiniu-js-sdk * pipeline (管道,可对imageView2、imageMogr2、watermark进行链式处理) ### SDK构成介绍 -* Plupload ,建议 2.1.1 及以上版本 +* Plupload ,建议 2.1.8 及以上版本 * qiniu.js,SDK主体文件,上传功能\数据处理实现 @@ -45,7 +45,7 @@ qiniu-js-sdk ``` * 引入Plupload - * [Plupload下载](http://plupload.com/download),建议 2.1.1 及以上版本 + * [Plupload下载](http://plupload.com/download),建议 2.1.8 及以上版本 * 引入`plupload.full.min.js`(产品环境)或 引入`plupload.dev.js`和`moxie.js`(开发调试) From 38b88ae5c6f60ad8d550c7f503dc0f5b2cbfdefd Mon Sep 17 00:00:00 2001 From: meilixie Date: Fri, 18 Sep 2015 15:15:49 +0800 Subject: [PATCH 5/5] update description for qiniu-jssdk --- demo/bower.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/demo/bower.json b/demo/bower.json index ef3fbfc8..77413884 100644 --- a/demo/bower.json +++ b/demo/bower.json @@ -1,7 +1,7 @@ { "name": "plupload", "version": "2.1.8", - "description": "plupload", + "description": "qiniu-jssdk for upload files", "license": "MIT", "private": true, "ignore": [