author | Anthony Ly <anthonyly.com@gmail.com> |
Tue, 12 Mar 2013 18:21:39 +0100 | |
changeset 206 | 919b4ddb13fa |
parent 194 | 32102edaa81b |
permissions | -rw-r--r-- |
136 | 1 |
/* |
2 |
SWFUpload.SWFObject Plugin |
|
3 |
||
4 |
Summary: |
|
5 |
This plugin uses SWFObject to embed SWFUpload dynamically in the page. SWFObject provides accurate Flash Player detection and DOM Ready loading. |
|
6 |
This plugin replaces the Graceful Degradation plugin. |
|
7 |
||
8 |
Features: |
|
9 |
* swfupload_load_failed_hander event |
|
10 |
* swfupload_pre_load_handler event |
|
11 |
* minimum_flash_version setting (default: "9.0.28") |
|
12 |
* SWFUpload.onload event for early loading |
|
13 |
||
14 |
Usage: |
|
15 |
Provide handlers and settings as needed. When using the SWFUpload.SWFObject plugin you should initialize SWFUploading |
|
16 |
in SWFUpload.onload rather than in window.onload. When initialized this way SWFUpload can load earlier preventing the UI flicker |
|
17 |
that was seen using the Graceful Degradation plugin. |
|
18 |
||
19 |
<script type="text/javascript"> |
|
20 |
var swfu; |
|
21 |
SWFUpload.onload = function () { |
|
22 |
swfu = new SWFUpload({ |
|
23 |
minimum_flash_version: "9.0.28", |
|
24 |
swfupload_pre_load_handler: swfuploadPreLoad, |
|
25 |
swfupload_load_failed_handler: swfuploadLoadFailed |
|
26 |
}); |
|
27 |
}; |
|
28 |
</script> |
|
29 |
|
|
30 |
Notes: |
|
31 |
You must provide set minimum_flash_version setting to "8" if you are using SWFUpload for Flash Player 8. |
|
32 |
The swfuploadLoadFailed event is only fired if the minimum version of Flash Player is not met. Other issues such as missing SWF files, browser bugs |
|
33 |
or corrupt Flash Player installations will not trigger this event. |
|
34 |
The swfuploadPreLoad event is fired as soon as the minimum version of Flash Player is found. It does not wait for SWFUpload to load and can |
|
35 |
be used to prepare the SWFUploadUI and hide alternate content. |
|
36 |
swfobject's onDomReady event is cross-browser safe but will default to the window.onload event when DOMReady is not supported by the browser. |
|
37 |
Early DOM Loading is supported in major modern browsers but cannot be guaranteed for every browser ever made. |
|
38 |
*/ |
|
39 |
||
40 |
||
41 |
// SWFObject v2.1 must be loaded |
|
42 |
|
|
43 |
var SWFUpload; |
|
44 |
if (typeof(SWFUpload) === "function") { |
|
45 |
SWFUpload.onload = function () {}; |
|
194
32102edaa81b
MAJ wordpress et ajout de plugin
Anthony Ly <anthonyly.com@gmail.com>
parents:
136
diff
changeset
|
46 |
|
136 | 47 |
swfobject.addDomLoadEvent(function () { |
48 |
if (typeof(SWFUpload.onload) === "function") { |
|
194
32102edaa81b
MAJ wordpress et ajout de plugin
Anthony Ly <anthonyly.com@gmail.com>
parents:
136
diff
changeset
|
49 |
setTimeout(function(){SWFUpload.onload.call(window);}, 200); |
136 | 50 |
} |
51 |
}); |
|
194
32102edaa81b
MAJ wordpress et ajout de plugin
Anthony Ly <anthonyly.com@gmail.com>
parents:
136
diff
changeset
|
52 |
|
136 | 53 |
SWFUpload.prototype.initSettings = (function (oldInitSettings) { |
54 |
return function () { |
|
55 |
if (typeof(oldInitSettings) === "function") { |
|
56 |
oldInitSettings.call(this); |
|
57 |
} |
|
58 |
||
59 |
this.ensureDefault = function (settingName, defaultValue) { |
|
60 |
this.settings[settingName] = (this.settings[settingName] == undefined) ? defaultValue : this.settings[settingName]; |
|
61 |
}; |
|
62 |
||
63 |
this.ensureDefault("minimum_flash_version", "9.0.28"); |
|
64 |
this.ensureDefault("swfupload_pre_load_handler", null); |
|
65 |
this.ensureDefault("swfupload_load_failed_handler", null); |
|
66 |
||
67 |
delete this.ensureDefault; |
|
68 |
||
69 |
}; |
|
70 |
})(SWFUpload.prototype.initSettings); |
|
71 |
||
72 |
||
73 |
SWFUpload.prototype.loadFlash = function (oldLoadFlash) { |
|
74 |
return function () { |
|
75 |
var hasFlash = swfobject.hasFlashPlayerVersion(this.settings.minimum_flash_version); |
|
76 |
|
|
77 |
if (hasFlash) { |
|
78 |
this.queueEvent("swfupload_pre_load_handler"); |
|
79 |
if (typeof(oldLoadFlash) === "function") { |
|
80 |
oldLoadFlash.call(this); |
|
81 |
} |
|
82 |
} else { |
|
83 |
this.queueEvent("swfupload_load_failed_handler"); |
|
84 |
} |
|
85 |
}; |
|
86 |
|
|
87 |
}(SWFUpload.prototype.loadFlash); |
|
88 |
|
|
89 |
SWFUpload.prototype.displayDebugInfo = function (oldDisplayDebugInfo) { |
|
90 |
return function () { |
|
91 |
if (typeof(oldDisplayDebugInfo) === "function") { |
|
92 |
oldDisplayDebugInfo.call(this); |
|
93 |
} |
|
94 |
|
|
95 |
this.debug( |
|
96 |
[ |
|
97 |
"SWFUpload.SWFObject Plugin settings:", "\n", |
|
98 |
"\t", "minimum_flash_version: ", this.settings.minimum_flash_version, "\n", |
|
99 |
"\t", "swfupload_pre_load_handler assigned: ", (typeof(this.settings.swfupload_pre_load_handler) === "function").toString(), "\n", |
|
100 |
"\t", "swfupload_load_failed_handler assigned: ", (typeof(this.settings.swfupload_load_failed_handler) === "function").toString(), "\n", |
|
101 |
].join("") |
|
102 |
); |
|
103 |
}; |
|
104 |
}(SWFUpload.prototype.displayDebugInfo); |
|
105 |
} |