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 () {};
|
---|
46 |
|
---|
47 | swfobject.addDomLoadEvent(function () {
|
---|
48 | if (typeof(SWFUpload.onload) === "function") {
|
---|
49 | SWFUpload.onload.call(window);
|
---|
50 | }
|
---|
51 | });
|
---|
52 |
|
---|
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 | }
|
---|