alchemy_cms 2.0.rc3 → 2.0.rc4
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +3 -1
- data/.rspec +1 -2
- data/.travis.yml +11 -0
- data/.yardopts +0 -1
- data/Gemfile +1 -2
- data/README.md +14 -0
- data/alchemy_cms.gemspec +4 -2
- data/app/controllers/admin/clipboard_controller.rb +8 -9
- data/app/controllers/admin/contents_controller.rb +4 -2
- data/app/controllers/admin/essence_pictures_controller.rb +2 -2
- data/app/controllers/admin/layoutpages_controller.rb +2 -0
- data/app/controllers/admin/pages_controller.rb +5 -5
- data/app/controllers/admin/pictures_controller.rb +2 -1
- data/app/controllers/admin/trash_controller.rb +2 -0
- data/app/controllers/alchemy_controller.rb +10 -4
- data/app/controllers/elements_controller.rb +1 -1
- data/app/helpers/admin/elements_helper.rb +32 -1
- data/app/helpers/alchemy_helper.rb +15 -818
- data/app/helpers/contents_helper.rb +69 -0
- data/app/helpers/elements_helper.rb +161 -0
- data/app/helpers/essences_helper.rb +167 -0
- data/app/helpers/pages_helper.rb +401 -19
- data/app/models/attachment.rb +4 -0
- data/app/models/element.rb +27 -14
- data/app/models/page.rb +75 -38
- data/app/views/admin/essence_pictures/destroy.js.erb +1 -1
- data/app/views/admin/pages/_create_language_form.html.erb +2 -1
- data/app/views/admin/pages/new.html.erb +1 -1
- data/app/views/admin/pages/update.js.erb +1 -1
- data/app/views/admin/partials/_upload_form.html.erb +2 -2
- data/app/views/admin/pictures/index.html.erb +7 -4
- data/app/views/essences/_essence_picture_editor.html.erb +1 -3
- data/app/views/layouts/alchemy.html.erb +59 -59
- data/app/views/layouts/pages.html.erb +2 -4
- data/app/views/{partials/_navigation_image_link.html.erb → navigation/_image_link.html.erb} +0 -0
- data/app/views/{partials/_navigation_link.html.erb → navigation/_link.html.erb} +1 -1
- data/app/views/{partials/_navigation_renderer.html.erb → navigation/_renderer.html.erb} +0 -0
- data/app/views/page_layouts/_contact.html.erb +1 -1
- data/app/views/page_layouts/_external.html.erb +0 -1
- data/app/views/page_layouts/_intro.html.erb +1 -1
- data/app/views/page_layouts/_news.html.erb +1 -1
- data/app/views/page_layouts/_search.html.erb +1 -1
- data/app/views/page_layouts/_standard.html.erb +1 -1
- data/assets/images/icons.png +0 -0
- data/assets/javascripts/tiny_mce/plugins/inlinepopups/skins/alchemy/window.css +49 -31
- data/assets/stylesheets/alchemy.css +111 -91
- data/assets/stylesheets/elements.css +12 -16
- data/bin/alchemy +1 -1
- data/config/alchemy/config.yml +4 -0
- data/config/initializers/tinymce_hammer.rb +1 -0
- data/config/locales/de.yml +3 -1
- data/config/locales/en.yml +2 -0
- data/config/routes.rb +6 -4
- data/lib/alchemy/capistrano.rb +4 -7
- data/lib/alchemy/page_layout.rb +12 -8
- data/lib/alchemy/version.rb +1 -1
- data/spec/controllers/admin/clipboard_controller_spec.rb +23 -0
- data/spec/dummy/db/schema.rb +9 -9
- data/spec/factories.rb +24 -6
- data/spec/helpers/admin/elements_helper_spec.rb +20 -0
- data/spec/helpers/alchemy_helper_spec.rb +41 -0
- data/spec/helpers/contents_helper_spec.rb +27 -0
- data/spec/helpers/elements_helper_spec.rb +39 -0
- data/spec/helpers/essences_helper_spec.rb +49 -0
- data/spec/helpers/pages_helper_spec.rb +140 -0
- data/spec/integration/security_spec.rb +1 -1
- data/spec/integration/standardset_spec.rb +29 -0
- data/spec/models/element_spec.rb +49 -0
- data/spec/{language_spec.rb → models/language_spec.rb} +0 -0
- data/spec/models/page_spec.rb +139 -0
- data/spec/{user_spec.rb → models/user_spec.rb} +0 -0
- data/spec/page_layout_spec.rb +21 -0
- data/spec/routing_spec.rb +53 -0
- data/spec/spec_helper.rb +12 -11
- metadata +54 -303
- data/spec/dummy/config/alchemy/config.yml +0 -199
- data/spec/dummy/config/alchemy/elements.yml +0 -91
- data/spec/dummy/config/alchemy/page_layouts.yml +0 -29
- data/spec/dummy/public/images/alchemy/ajax_loader.gif +0 -0
- data/spec/dummy/public/images/alchemy/alchemy-logo.png +0 -0
- data/spec/dummy/public/images/alchemy/flags.png +0 -0
- data/spec/dummy/public/images/alchemy/gui/navi-tab.png +0 -0
- data/spec/dummy/public/images/alchemy/gui/shading.png +0 -0
- data/spec/dummy/public/images/alchemy/gui/shading_90.png +0 -0
- data/spec/dummy/public/images/alchemy/gui/toggle.png +0 -0
- data/spec/dummy/public/images/alchemy/icons.png +0 -0
- data/spec/dummy/public/images/alchemy/jquery-sb/select_arrow.gif +0 -0
- data/spec/dummy/public/images/alchemy/jquery-sb/select_arrow_bg.gif +0 -0
- data/spec/dummy/public/images/alchemy/jquery-sb/select_arrow_bg_hover.gif +0 -0
- data/spec/dummy/public/images/alchemy/jquery-ui/ui-icons_666666_256x240.png +0 -0
- data/spec/dummy/public/images/alchemy/placeholder.png +0 -0
- data/spec/dummy/public/images/alchemy/swfupload/browse_button.png +0 -0
- data/spec/dummy/public/javascripts/alchemy/alchemy.element_editor_selector.js +0 -88
- data/spec/dummy/public/javascripts/alchemy/alchemy.growler.js +0 -44
- data/spec/dummy/public/javascripts/alchemy/alchemy.image_cropper.js +0 -56
- data/spec/dummy/public/javascripts/alchemy/alchemy.js +0 -892
- data/spec/dummy/public/javascripts/alchemy/alchemy.link_overlay.js +0 -221
- data/spec/dummy/public/javascripts/alchemy/alchemy.page_sorter.js +0 -42
- data/spec/dummy/public/javascripts/alchemy/alchemy.preview.js +0 -145
- data/spec/dummy/public/javascripts/alchemy/jquery-ui.js +0 -428
- data/spec/dummy/public/javascripts/alchemy/jquery.Jcrop.min.js +0 -246
- data/spec/dummy/public/javascripts/alchemy/jquery.dialogextend.min.js +0 -8
- data/spec/dummy/public/javascripts/alchemy/jquery.in-place-edit.js +0 -171
- data/spec/dummy/public/javascripts/alchemy/jquery.js +0 -18
- data/spec/dummy/public/javascripts/alchemy/jquery.rails.js +0 -315
- data/spec/dummy/public/javascripts/alchemy/jquery.sb.min.js +0 -14
- data/spec/dummy/public/javascripts/alchemy/jquery.scrollTo-1.4.2-min.js +0 -11
- data/spec/dummy/public/javascripts/alchemy/jquery.ui.nestedSortable.js +0 -291
- data/spec/dummy/public/javascripts/alchemy/jquery.ui.tabspaging.js +0 -281
- data/spec/dummy/public/javascripts/alchemy/swfupload/fileprogress.js +0 -203
- data/spec/dummy/public/javascripts/alchemy/swfupload/handlers.js +0 -171
- data/spec/dummy/public/javascripts/alchemy/swfupload/queue.js +0 -98
- data/spec/dummy/public/javascripts/alchemy/swfupload/swfupload.js +0 -980
- data/spec/dummy/public/javascripts/alchemy/swfupload/swfupload.swf +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/jquery.tinymce.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/langs/de.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/langs/en.js +0 -223
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/license.txt +0 -504
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/alchemy_link/editor_plugin.js +0 -43
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/alchemy_link/langs/de.js +0 -4
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/alchemy_link/langs/en.js +0 -4
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/fullscreen/editor_plugin.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/fullscreen/fullscreen.htm +0 -109
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/inlinepopups/editor_plugin.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/inlinepopups/skins/alchemy/window.css +0 -402
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/inlinepopups/template.htm +0 -387
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/lists/editor_plugin.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/paste/editor_plugin.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/paste/js/pastetext.js +0 -36
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/paste/js/pasteword.js +0 -51
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/paste/langs/de_dlg.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/paste/langs/en_dlg.js +0 -5
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/paste/pastetext.htm +0 -27
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/paste/pasteword.htm +0 -21
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/cell.htm +0 -180
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/css/cell.css +0 -17
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/css/row.css +0 -25
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/css/table.css +0 -13
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/editor_plugin.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/js/cell.js +0 -319
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/js/merge_cells.js +0 -27
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/js/row.js +0 -237
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/js/table.js +0 -450
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/langs/de_dlg.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/langs/en_dlg.js +0 -75
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/merge_cells.htm +0 -32
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/row.htm +0 -158
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/plugins/table/table.htm +0 -188
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/about.htm +0 -52
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/anchor.htm +0 -26
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/charmap.htm +0 -51
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/color_picker.htm +0 -74
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/editor_template.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/image.htm +0 -80
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/colorpicker.jpg +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/flash.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/icons.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/iframe.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/pagebreak.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/quicktime.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/realmedia.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/shockwave.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/trans.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/video.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/img/windowsmedia.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/js/about.js +0 -73
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/js/anchor.js +0 -42
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/js/charmap.js +0 -355
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/js/color_picker.js +0 -329
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/js/image.js +0 -247
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/js/link.js +0 -153
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/js/source_editor.js +0 -56
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/langs/de.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/langs/de_dlg.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/langs/en.js +0 -68
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/langs/en_dlg.js +0 -54
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/link.htm +0 -57
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/shortcuts.htm +0 -47
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/content.css +0 -47
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/dialog.css +0 -117
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/img/buttons.png +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/img/items.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/img/menu_arrow.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/img/menu_check.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/img/progress.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/img/tabs.gif +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/default/ui.css +0 -214
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/highcontrast/content.css +0 -23
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/highcontrast/dialog.css +0 -105
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/highcontrast/ui.css +0 -102
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/o2k7/content.css +0 -46
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/o2k7/dialog.css +0 -117
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/o2k7/img/button_bg.png +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/o2k7/img/button_bg_black.png +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/o2k7/img/button_bg_silver.png +0 -0
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/o2k7/ui.css +0 -217
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/o2k7/ui_black.css +0 -8
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/skins/o2k7/ui_silver.css +0 -5
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/advanced/source_editor.htm +0 -25
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/themes/simple/langs/de.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/tiny_mce.js +0 -1
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/tiny_mce_popup.js +0 -5
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/utils/editable_selects.js +0 -70
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/utils/form_utils.js +0 -210
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/utils/mctabs.js +0 -162
- data/spec/dummy/public/javascripts/alchemy/tiny_mce/utils/validate.js +0 -252
- data/spec/dummy/public/stylesheets/alchemy/Jcrop.gif +0 -0
- data/spec/dummy/public/stylesheets/alchemy/alchemy.css +0 -3653
- data/spec/dummy/public/stylesheets/alchemy/alchemy_tinymce_content.css +0 -94
- data/spec/dummy/public/stylesheets/alchemy/alchemy_tinymce_dialog.css +0 -415
- data/spec/dummy/public/stylesheets/alchemy/default/img/tabs.gif +0 -0
- data/spec/dummy/public/stylesheets/alchemy/elements.css +0 -900
- data/spec/dummy/public/stylesheets/alchemy/flags.css +0 -1
- data/spec/dummy/public/stylesheets/alchemy/ie6.css +0 -18
- data/spec/dummy/public/stylesheets/alchemy/jquery-ui-1.8.7.alchemy.css +0 -2023
- data/spec/dummy/public/stylesheets/alchemy/jquery.Jcrop.css +0 -35
- data/spec/dummy/public/stylesheets/alchemy/jquery.sb.css +0 -244
- data/spec/dummy/public/stylesheets/alchemy/standard_set.css +0 -374
- data/spec/page_spec.rb +0 -50
@@ -1,203 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
A simple class for displaying file information and progress
|
3
|
-
Note: This is a demonstration only and not part of SWFUpload.
|
4
|
-
Note: Some have had problems adapting this class in IE7. It may not be suitable for your application.
|
5
|
-
*/
|
6
|
-
|
7
|
-
// Constructor
|
8
|
-
// file is a SWFUpload file object
|
9
|
-
// targetID is the HTML element id attribute that the FileProgress HTML structure will be added to.
|
10
|
-
// Instantiating a new FileProgress object with an existing file will reuse/update the existing DOM elements
|
11
|
-
function FileProgress(file, targetID) {
|
12
|
-
this.fileProgressID = file.id;
|
13
|
-
|
14
|
-
this.opacity = 100;
|
15
|
-
this.height = 0;
|
16
|
-
|
17
|
-
|
18
|
-
this.fileProgressWrapper = document.getElementById(this.fileProgressID);
|
19
|
-
if (!this.fileProgressWrapper) {
|
20
|
-
this.fileProgressWrapper = document.createElement("div");
|
21
|
-
this.fileProgressWrapper.className = "progressWrapper";
|
22
|
-
this.fileProgressWrapper.id = this.fileProgressID;
|
23
|
-
|
24
|
-
this.fileProgressElement = document.createElement("div");
|
25
|
-
this.fileProgressElement.className = "progressContainer";
|
26
|
-
|
27
|
-
var progressCancel = document.createElement("a");
|
28
|
-
progressCancel.className = "progressCancel";
|
29
|
-
progressCancel.href = "#";
|
30
|
-
progressCancel.style.visibility = "hidden";
|
31
|
-
progressCancel.appendChild(document.createTextNode(" "));
|
32
|
-
|
33
|
-
var progressText = document.createElement("div");
|
34
|
-
progressText.className = "progressName";
|
35
|
-
progressText.appendChild(document.createTextNode(file.name));
|
36
|
-
|
37
|
-
var progressBarContainer = document.createElement("div");
|
38
|
-
progressBarContainer.className = "progressBarContainer";
|
39
|
-
|
40
|
-
var progressBar = document.createElement("div");
|
41
|
-
progressBar.className = "progressBarInProgress";
|
42
|
-
|
43
|
-
var progressStatus = document.createElement("div");
|
44
|
-
progressStatus.className = "progressBarStatus";
|
45
|
-
progressStatus.innerHTML = " ";
|
46
|
-
|
47
|
-
this.fileProgressElement.appendChild(progressCancel);
|
48
|
-
this.fileProgressElement.appendChild(progressText);
|
49
|
-
this.fileProgressElement.appendChild(progressStatus);
|
50
|
-
this.fileProgressElement.appendChild(progressBarContainer);
|
51
|
-
progressBarContainer.appendChild(progressBar);
|
52
|
-
|
53
|
-
this.fileProgressWrapper.appendChild(this.fileProgressElement);
|
54
|
-
|
55
|
-
document.getElementById(targetID).appendChild(this.fileProgressWrapper);
|
56
|
-
} else {
|
57
|
-
this.fileProgressElement = this.fileProgressWrapper.firstChild;
|
58
|
-
this.reset();
|
59
|
-
}
|
60
|
-
|
61
|
-
this.height = this.fileProgressWrapper.offsetHeight;
|
62
|
-
this.setTimer(null);
|
63
|
-
|
64
|
-
}
|
65
|
-
|
66
|
-
FileProgress.prototype.setTimer = function (timer) {
|
67
|
-
this.fileProgressElement["FP_TIMER"] = timer;
|
68
|
-
};
|
69
|
-
FileProgress.prototype.getTimer = function (timer) {
|
70
|
-
return this.fileProgressElement["FP_TIMER"] || null;
|
71
|
-
};
|
72
|
-
|
73
|
-
FileProgress.prototype.reset = function () {
|
74
|
-
this.fileProgressElement.className = "progressContainer";
|
75
|
-
this.fileProgressElement.childNodes[2].innerHTML = " ";
|
76
|
-
this.fileProgressElement.childNodes[2].className = "progressBarStatus";
|
77
|
-
this.fileProgressElement.childNodes[3].className = "progressBarContainer";
|
78
|
-
this.fileProgressElement.childNodes[3].childNodes[0].className = "progressBarInProgress";
|
79
|
-
this.fileProgressElement.childNodes[3].childNodes[0].style.width = "0%";
|
80
|
-
this.appear();
|
81
|
-
};
|
82
|
-
|
83
|
-
FileProgress.prototype.setProgress = function (percentage) {
|
84
|
-
this.fileProgressElement.className = "progressContainer";
|
85
|
-
this.fileProgressElement.childNodes[3].className = "progressBarContainer";
|
86
|
-
this.fileProgressElement.childNodes[3].childNodes[0].style.width = percentage + "%";
|
87
|
-
this.fileProgressElement.childNodes[3].childNodes[0].className = "progressBarInProgress";
|
88
|
-
this.appear();
|
89
|
-
};
|
90
|
-
|
91
|
-
FileProgress.prototype.setComplete = function () {
|
92
|
-
this.fileProgressElement.className = "progressContainer";
|
93
|
-
this.fileProgressElement.childNodes[3].className = "progressBarContainer";
|
94
|
-
this.fileProgressElement.childNodes[3].childNodes[0].style.width = "100%";
|
95
|
-
this.fileProgressElement.childNodes[3].childNodes[0].className = "progressBarComplete";
|
96
|
-
var oSelf = this;
|
97
|
-
this.setTimer(setTimeout(function () {
|
98
|
-
oSelf.disappear();
|
99
|
-
}, 1500));
|
100
|
-
};
|
101
|
-
|
102
|
-
FileProgress.prototype.setError = function () {
|
103
|
-
this.fileProgressElement.className = "progressContainer";
|
104
|
-
this.fileProgressElement.childNodes[3].className = "progressBarContainer";
|
105
|
-
this.fileProgressElement.childNodes[3].childNodes[0].style.width = "100%";
|
106
|
-
this.fileProgressElement.childNodes[3].childNodes[0].className = "progressBarError";
|
107
|
-
};
|
108
|
-
|
109
|
-
FileProgress.prototype.setCancelled = function () {
|
110
|
-
this.fileProgressElement.childNodes[3].className = "progressBarContainer";
|
111
|
-
this.fileProgressElement.childNodes[3].childNodes[0].style.width = "100%";
|
112
|
-
this.fileProgressElement.childNodes[3].childNodes[0].className = "progressBarCanceled";
|
113
|
-
var oSelf = this;
|
114
|
-
this.setTimer(setTimeout(function () {
|
115
|
-
oSelf.disappear();
|
116
|
-
}, 1500));
|
117
|
-
};
|
118
|
-
|
119
|
-
FileProgress.prototype.setStatus = function (status) {
|
120
|
-
this.fileProgressElement.childNodes[2].innerHTML = status;
|
121
|
-
};
|
122
|
-
|
123
|
-
// Show/Hide the cancel button
|
124
|
-
FileProgress.prototype.toggleCancel = function (show, swfUploadInstance) {
|
125
|
-
this.fileProgressElement.childNodes[0].style.visibility = show ? "visible" : "hidden";
|
126
|
-
if (swfUploadInstance) {
|
127
|
-
var fileID = this.fileProgressID;
|
128
|
-
this.fileProgressElement.childNodes[0].onclick = function () {
|
129
|
-
swfUploadInstance.cancelUpload(fileID);
|
130
|
-
return false;
|
131
|
-
};
|
132
|
-
}
|
133
|
-
};
|
134
|
-
|
135
|
-
FileProgress.prototype.appear = function () {
|
136
|
-
if (this.getTimer() !== null) {
|
137
|
-
clearTimeout(this.getTimer());
|
138
|
-
this.setTimer(null);
|
139
|
-
}
|
140
|
-
|
141
|
-
if (this.fileProgressWrapper.filters) {
|
142
|
-
try {
|
143
|
-
this.fileProgressWrapper.filters.item("DXImageTransform.Microsoft.Alpha").opacity = 100;
|
144
|
-
} catch (e) {
|
145
|
-
// If it is not set initially, the browser will throw an error. This will set it if it is not set yet.
|
146
|
-
this.fileProgressWrapper.style.filter = "progid:DXImageTransform.Microsoft.Alpha(opacity=100)";
|
147
|
-
}
|
148
|
-
} else {
|
149
|
-
this.fileProgressWrapper.style.opacity = 1;
|
150
|
-
}
|
151
|
-
|
152
|
-
this.fileProgressWrapper.style.height = "";
|
153
|
-
|
154
|
-
this.height = this.fileProgressWrapper.offsetHeight;
|
155
|
-
this.opacity = 100;
|
156
|
-
this.fileProgressWrapper.style.display = "";
|
157
|
-
|
158
|
-
};
|
159
|
-
|
160
|
-
// Fades out and clips away the FileProgress box.
|
161
|
-
FileProgress.prototype.disappear = function () {
|
162
|
-
|
163
|
-
var reduceOpacityBy = 15;
|
164
|
-
var reduceHeightBy = 8;
|
165
|
-
var rate = 30;// 15 fps
|
166
|
-
|
167
|
-
if (this.opacity > 0) {
|
168
|
-
this.opacity -= reduceOpacityBy;
|
169
|
-
if (this.opacity < 0) {
|
170
|
-
this.opacity = 0;
|
171
|
-
}
|
172
|
-
|
173
|
-
if (this.fileProgressWrapper.filters) {
|
174
|
-
try {
|
175
|
-
this.fileProgressWrapper.filters.item("DXImageTransform.Microsoft.Alpha").opacity = this.opacity;
|
176
|
-
} catch (e) {
|
177
|
-
// If it is not set initially, the browser will throw an error. This will set it if it is not set yet.
|
178
|
-
this.fileProgressWrapper.style.filter = "progid:DXImageTransform.Microsoft.Alpha(opacity=" + this.opacity + ")";
|
179
|
-
}
|
180
|
-
} else {
|
181
|
-
this.fileProgressWrapper.style.opacity = this.opacity / 100;
|
182
|
-
}
|
183
|
-
}
|
184
|
-
|
185
|
-
if (this.height > 0) {
|
186
|
-
this.height -= reduceHeightBy;
|
187
|
-
if (this.height < 0) {
|
188
|
-
this.height = 0;
|
189
|
-
}
|
190
|
-
|
191
|
-
this.fileProgressWrapper.style.height = this.height + "px";
|
192
|
-
}
|
193
|
-
|
194
|
-
if (this.height > 0 || this.opacity > 0) {
|
195
|
-
var oSelf = this;
|
196
|
-
this.setTimer(setTimeout(function () {
|
197
|
-
oSelf.disappear();
|
198
|
-
}, rate));
|
199
|
-
} else {
|
200
|
-
this.fileProgressWrapper.style.display = "none";
|
201
|
-
this.setTimer(null);
|
202
|
-
}
|
203
|
-
};
|
@@ -1,171 +0,0 @@
|
|
1
|
-
/* **********************
|
2
|
-
Alchemy SWFUpload Event Handlers
|
3
|
-
********************** */
|
4
|
-
function fileQueued(file) {
|
5
|
-
try {
|
6
|
-
var progress = new FileProgress(file, this.customSettings.progressTarget);
|
7
|
-
progress.setStatus("Pending...");
|
8
|
-
progress.toggleCancel(true, this);
|
9
|
-
|
10
|
-
} catch (ex) {
|
11
|
-
this.debug(ex);
|
12
|
-
}
|
13
|
-
|
14
|
-
}
|
15
|
-
|
16
|
-
function fileQueueError(file, errorCode, message) {
|
17
|
-
try {
|
18
|
-
if (errorCode === SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED) {
|
19
|
-
alert("You have attempted to queue too many files.\n" + (message === 0 ? "You have reached the upload limit." : "You may select " + (message > 1 ? "up to " + message + " files." : "one file.")));
|
20
|
-
return;
|
21
|
-
}
|
22
|
-
|
23
|
-
var progress = new FileProgress(file, this.customSettings.progressTarget);
|
24
|
-
progress.setError();
|
25
|
-
progress.toggleCancel(false);
|
26
|
-
|
27
|
-
switch (errorCode) {
|
28
|
-
case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT:
|
29
|
-
progress.setStatus("File is too big.");
|
30
|
-
this.debug("Error Code: File too big, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
|
31
|
-
break;
|
32
|
-
case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:
|
33
|
-
progress.setStatus("Cannot upload Zero Byte files.");
|
34
|
-
this.debug("Error Code: Zero byte file, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
|
35
|
-
break;
|
36
|
-
case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE:
|
37
|
-
progress.setStatus("Invalid File Type.");
|
38
|
-
this.debug("Error Code: Invalid File Type, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
|
39
|
-
break;
|
40
|
-
default:
|
41
|
-
if (file !== null) {
|
42
|
-
progress.setStatus("Unhandled Error");
|
43
|
-
}
|
44
|
-
this.debug("Error Code: " + errorCode + ", File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
|
45
|
-
break;
|
46
|
-
}
|
47
|
-
} catch (ex) {
|
48
|
-
this.debug(ex);
|
49
|
-
}
|
50
|
-
}
|
51
|
-
|
52
|
-
function fileDialogComplete(numFilesSelected, numFilesQueued) {
|
53
|
-
try {
|
54
|
-
if (numFilesSelected > 0) {
|
55
|
-
document.getElementById(this.customSettings.cancelButtonId).disabled = false;
|
56
|
-
}
|
57
|
-
/* I want auto start the upload and I can do that here */
|
58
|
-
this.startUpload();
|
59
|
-
} catch (ex) {
|
60
|
-
this.debug(ex);
|
61
|
-
}
|
62
|
-
}
|
63
|
-
|
64
|
-
function uploadStart(file) {
|
65
|
-
try {
|
66
|
-
jQuery('divFileProgressContainer').show();
|
67
|
-
/* I don't want to do any file validation or anything, I'll just update the UI and
|
68
|
-
return true to indicate that the upload should start.
|
69
|
-
It's important to update the UI here because in Linux no uploadProgress events are called. The best
|
70
|
-
we can do is say we are uploading.
|
71
|
-
*/
|
72
|
-
var progress = new FileProgress(file, this.customSettings.progressTarget);
|
73
|
-
progress.setStatus("Uploading...");
|
74
|
-
progress.toggleCancel(true, this);
|
75
|
-
}
|
76
|
-
catch (ex) {}
|
77
|
-
|
78
|
-
return true;
|
79
|
-
}
|
80
|
-
|
81
|
-
function uploadProgress(file, bytesLoaded, bytesTotal) {
|
82
|
-
try {
|
83
|
-
var percent = Math.ceil((bytesLoaded / bytesTotal) * 100);
|
84
|
-
|
85
|
-
var progress = new FileProgress(file, this.customSettings.progressTarget);
|
86
|
-
progress.setProgress(percent);
|
87
|
-
progress.setStatus("Uploading...");
|
88
|
-
} catch (ex) {
|
89
|
-
this.debug(ex);
|
90
|
-
}
|
91
|
-
}
|
92
|
-
|
93
|
-
function uploadSuccess(file, serverData) {
|
94
|
-
eval(serverData);
|
95
|
-
try {
|
96
|
-
var progress = new FileProgress(file, this.customSettings.progressTarget);
|
97
|
-
progress.setComplete();
|
98
|
-
progress.setStatus("Complete.");
|
99
|
-
progress.toggleCancel(false);
|
100
|
-
} catch (ex) {
|
101
|
-
this.debug(ex);
|
102
|
-
}
|
103
|
-
}
|
104
|
-
|
105
|
-
function uploadError(file, errorCode, message) {
|
106
|
-
try {
|
107
|
-
var progress = new FileProgress(file, this.customSettings.progressTarget);
|
108
|
-
progress.setError();
|
109
|
-
progress.toggleCancel(false);
|
110
|
-
|
111
|
-
switch (errorCode) {
|
112
|
-
case SWFUpload.UPLOAD_ERROR.HTTP_ERROR:
|
113
|
-
progress.setStatus("Upload Error: " + message);
|
114
|
-
this.debug("Error Code: HTTP Error, File name: " + file.name + ", Message: " + message);
|
115
|
-
break;
|
116
|
-
case SWFUpload.UPLOAD_ERROR.UPLOAD_FAILED:
|
117
|
-
progress.setStatus("Upload Failed.");
|
118
|
-
this.debug("Error Code: Upload Failed, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
|
119
|
-
break;
|
120
|
-
case SWFUpload.UPLOAD_ERROR.IO_ERROR:
|
121
|
-
progress.setStatus("Server (IO) Error");
|
122
|
-
this.debug("Error Code: IO Error, File name: " + file.name + ", Message: " + message);
|
123
|
-
break;
|
124
|
-
case SWFUpload.UPLOAD_ERROR.SECURITY_ERROR:
|
125
|
-
progress.setStatus("Security Error");
|
126
|
-
this.debug("Error Code: Security Error, File name: " + file.name + ", Message: " + message);
|
127
|
-
break;
|
128
|
-
case SWFUpload.UPLOAD_ERROR.UPLOAD_LIMIT_EXCEEDED:
|
129
|
-
progress.setStatus("Upload limit exceeded.");
|
130
|
-
this.debug("Error Code: Upload Limit Exceeded, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
|
131
|
-
break;
|
132
|
-
case SWFUpload.UPLOAD_ERROR.FILE_VALIDATION_FAILED:
|
133
|
-
progress.setStatus("Failed Validation. Upload skipped.");
|
134
|
-
this.debug("Error Code: File Validation Failed, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
|
135
|
-
break;
|
136
|
-
case SWFUpload.UPLOAD_ERROR.FILE_CANCELLED:
|
137
|
-
// If there aren't any files left (they were all cancelled) disable the cancel button
|
138
|
-
if (this.getStats().files_queued === 0) {
|
139
|
-
document.getElementById(this.customSettings.cancelButtonId).disabled = true;
|
140
|
-
}
|
141
|
-
progress.setStatus("Cancelled");
|
142
|
-
progress.setCancelled();
|
143
|
-
break;
|
144
|
-
case SWFUpload.UPLOAD_ERROR.UPLOAD_STOPPED:
|
145
|
-
progress.setStatus("Stopped");
|
146
|
-
break;
|
147
|
-
default:
|
148
|
-
progress.setStatus("Unhandled Error: " + errorCode);
|
149
|
-
this.debug("Error Code: " + errorCode + ", File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
|
150
|
-
break;
|
151
|
-
}
|
152
|
-
} catch (ex) {
|
153
|
-
this.debug(ex);
|
154
|
-
}
|
155
|
-
}
|
156
|
-
|
157
|
-
function uploadComplete(file) {
|
158
|
-
if (this.getStats().files_queued === 0) {
|
159
|
-
document.getElementById(this.customSettings.cancelButtonId).disabled = true;
|
160
|
-
}
|
161
|
-
}
|
162
|
-
|
163
|
-
function queueComplete(numFilesUploaded) {
|
164
|
-
var status = document.getElementById("divStatus");
|
165
|
-
jQuery(status).show();
|
166
|
-
status.innerHTML = numFilesUploaded + " file" + (numFilesUploaded === 1 ? "" : "s") + " uploaded.";
|
167
|
-
jQuery('#btnCancel').hide();
|
168
|
-
setTimeout(function () {
|
169
|
-
Alchemy.closeCurrentWindow();
|
170
|
-
}, 2500);
|
171
|
-
}
|
@@ -1,98 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
Queue Plug-in
|
3
|
-
|
4
|
-
Features:
|
5
|
-
*Adds a cancelQueue() method for cancelling the entire queue.
|
6
|
-
*All queued files are uploaded when startUpload() is called.
|
7
|
-
*If false is returned from uploadComplete then the queue upload is stopped.
|
8
|
-
If false is not returned (strict comparison) then the queue upload is continued.
|
9
|
-
*Adds a QueueComplete event that is fired when all the queued files have finished uploading.
|
10
|
-
Set the event handler with the queue_complete_handler setting.
|
11
|
-
|
12
|
-
*/
|
13
|
-
|
14
|
-
var SWFUpload;
|
15
|
-
if (typeof(SWFUpload) === "function") {
|
16
|
-
SWFUpload.queue = {};
|
17
|
-
|
18
|
-
SWFUpload.prototype.initSettings = (function (oldInitSettings) {
|
19
|
-
return function () {
|
20
|
-
if (typeof(oldInitSettings) === "function") {
|
21
|
-
oldInitSettings.call(this);
|
22
|
-
}
|
23
|
-
|
24
|
-
this.queueSettings = {};
|
25
|
-
|
26
|
-
this.queueSettings.queue_cancelled_flag = false;
|
27
|
-
this.queueSettings.queue_upload_count = 0;
|
28
|
-
|
29
|
-
this.queueSettings.user_upload_complete_handler = this.settings.upload_complete_handler;
|
30
|
-
this.queueSettings.user_upload_start_handler = this.settings.upload_start_handler;
|
31
|
-
this.settings.upload_complete_handler = SWFUpload.queue.uploadCompleteHandler;
|
32
|
-
this.settings.upload_start_handler = SWFUpload.queue.uploadStartHandler;
|
33
|
-
|
34
|
-
this.settings.queue_complete_handler = this.settings.queue_complete_handler || null;
|
35
|
-
};
|
36
|
-
})(SWFUpload.prototype.initSettings);
|
37
|
-
|
38
|
-
SWFUpload.prototype.startUpload = function (fileID) {
|
39
|
-
this.queueSettings.queue_cancelled_flag = false;
|
40
|
-
this.callFlash("StartUpload", [fileID]);
|
41
|
-
};
|
42
|
-
|
43
|
-
SWFUpload.prototype.cancelQueue = function () {
|
44
|
-
this.queueSettings.queue_cancelled_flag = true;
|
45
|
-
this.stopUpload();
|
46
|
-
|
47
|
-
var stats = this.getStats();
|
48
|
-
while (stats.files_queued > 0) {
|
49
|
-
this.cancelUpload();
|
50
|
-
stats = this.getStats();
|
51
|
-
}
|
52
|
-
};
|
53
|
-
|
54
|
-
SWFUpload.queue.uploadStartHandler = function (file) {
|
55
|
-
var returnValue;
|
56
|
-
if (typeof(this.queueSettings.user_upload_start_handler) === "function") {
|
57
|
-
returnValue = this.queueSettings.user_upload_start_handler.call(this, file);
|
58
|
-
}
|
59
|
-
|
60
|
-
// To prevent upload a real "FALSE" value must be returned, otherwise default to a real "TRUE" value.
|
61
|
-
returnValue = (returnValue === false) ? false : true;
|
62
|
-
|
63
|
-
this.queueSettings.queue_cancelled_flag = !returnValue;
|
64
|
-
|
65
|
-
return returnValue;
|
66
|
-
};
|
67
|
-
|
68
|
-
SWFUpload.queue.uploadCompleteHandler = function (file) {
|
69
|
-
var user_upload_complete_handler = this.queueSettings.user_upload_complete_handler;
|
70
|
-
var continueUpload;
|
71
|
-
|
72
|
-
if (file.filestatus === SWFUpload.FILE_STATUS.COMPLETE) {
|
73
|
-
this.queueSettings.queue_upload_count++;
|
74
|
-
}
|
75
|
-
|
76
|
-
if (typeof(user_upload_complete_handler) === "function") {
|
77
|
-
continueUpload = (user_upload_complete_handler.call(this, file) === false) ? false : true;
|
78
|
-
} else if (file.filestatus === SWFUpload.FILE_STATUS.QUEUED) {
|
79
|
-
// If the file was stopped and re-queued don't restart the upload
|
80
|
-
continueUpload = false;
|
81
|
-
} else {
|
82
|
-
continueUpload = true;
|
83
|
-
}
|
84
|
-
|
85
|
-
if (continueUpload) {
|
86
|
-
var stats = this.getStats();
|
87
|
-
if (stats.files_queued > 0 && this.queueSettings.queue_cancelled_flag === false) {
|
88
|
-
this.startUpload();
|
89
|
-
} else if (this.queueSettings.queue_cancelled_flag === false) {
|
90
|
-
this.queueEvent("queue_complete_handler", [this.queueSettings.queue_upload_count]);
|
91
|
-
this.queueSettings.queue_upload_count = 0;
|
92
|
-
} else {
|
93
|
-
this.queueSettings.queue_cancelled_flag = false;
|
94
|
-
this.queueSettings.queue_upload_count = 0;
|
95
|
-
}
|
96
|
-
}
|
97
|
-
};
|
98
|
-
}
|