sunrise-widgets 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile +34 -0
- data/MIT-LICENSE +20 -0
- data/README.rdoc +21 -0
- data/Rakefile +27 -0
- data/app/controllers/manage/widgets_controller.rb +33 -0
- data/app/views/manage/widgets/_form.html.erb +21 -0
- data/app/views/manage/widgets/_model_filter.html.erb +40 -0
- data/app/views/manage/widgets/_widget.html.erb +41 -0
- data/app/views/manage/widgets/edit.html.erb +6 -0
- data/app/views/manage/widgets/index.html.erb +30 -0
- data/app/views/manage/widgets/new.html.erb +6 -0
- data/app/views/manage/widgets/show.html.erb +29 -0
- data/config/locales/ru.yml +18 -0
- data/config/locales/uk.yml +18 -0
- data/config/routes.rb +5 -0
- data/lib/generators/sunrise/widgets/USAGE +12 -0
- data/lib/generators/sunrise/widgets/install_generator.rb +40 -0
- data/lib/generators/sunrise/widgets/templates/create_widgets.rb +24 -0
- data/lib/generators/sunrise/widgets/templates/widget.rb +6 -0
- data/lib/generators/sunrise/widgets/templates/widget_position.rb +14 -0
- data/lib/generators/sunrise/widgets/templates/widget_sweeper.rb +21 -0
- data/lib/generators/sunrise/widgets/templates/widget_type.rb +15 -0
- data/lib/sunrise/models/widget.rb +39 -0
- data/lib/sunrise/widgets/engine.rb +18 -0
- data/lib/sunrise/widgets/version.rb +5 -0
- data/lib/sunrise/widgets.rb +12 -0
- data/lib/sunrise-widgets.rb +1 -0
- data/spec/controllers/manage/widgets_controller_spec.rb +95 -0
- data/spec/dummy/Rakefile +7 -0
- data/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/helpers/manage/assets_helper.rb +2 -0
- data/spec/dummy/app/helpers/manage/base_helper.rb +81 -0
- data/spec/dummy/app/helpers/manage/pages_helper.rb +2 -0
- data/spec/dummy/app/helpers/manage/settings_helper.rb +2 -0
- data/spec/dummy/app/helpers/manage/structures_helper.rb +12 -0
- data/spec/dummy/app/helpers/manage/users_helper.rb +6 -0
- data/spec/dummy/app/models/defaults/ability.rb +39 -0
- data/spec/dummy/app/models/defaults/asset.rb +7 -0
- data/spec/dummy/app/models/defaults/attachment_file.rb +33 -0
- data/spec/dummy/app/models/defaults/avatar.rb +37 -0
- data/spec/dummy/app/models/defaults/header.rb +5 -0
- data/spec/dummy/app/models/defaults/page.rb +5 -0
- data/spec/dummy/app/models/defaults/picture.rb +35 -0
- data/spec/dummy/app/models/defaults/position_type.rb +7 -0
- data/spec/dummy/app/models/defaults/role.rb +20 -0
- data/spec/dummy/app/models/defaults/role_type.rb +8 -0
- data/spec/dummy/app/models/defaults/structure.rb +16 -0
- data/spec/dummy/app/models/defaults/structure_type.rb +9 -0
- data/spec/dummy/app/models/defaults/user.rb +47 -0
- data/spec/dummy/app/views/layouts/application.html.erb +37 -0
- data/spec/dummy/app/views/pages/show.html.erb +2 -0
- data/spec/dummy/app/views/shared/_notice.html.erb +17 -0
- data/spec/dummy/config/application.rb +47 -0
- data/spec/dummy/config/application.yml.sample +4 -0
- data/spec/dummy/config/boot.rb +10 -0
- data/spec/dummy/config/database.yml +22 -0
- data/spec/dummy/config/database.yml.sample +34 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +26 -0
- data/spec/dummy/config/environments/production.rb +49 -0
- data/spec/dummy/config/environments/test.rb +35 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/devise.rb +204 -0
- data/spec/dummy/config/initializers/inflections.rb +10 -0
- data/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/spec/dummy/config/initializers/session_store.rb +8 -0
- data/spec/dummy/config/initializers/simple_form.rb +93 -0
- data/spec/dummy/config/initializers/sunrise.rb +7 -0
- data/spec/dummy/config/locales/devise.en.yml +53 -0
- data/spec/dummy/config/locales/en.yml +5 -0
- data/spec/dummy/config/locales/simple_form.en.yml +24 -0
- data/spec/dummy/config/logrotate-config.sample +9 -0
- data/spec/dummy/config/nginx-config-passenger.sample +51 -0
- data/spec/dummy/config/routes.rb +64 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/db/migrate/20110801124809_sunrise_create_users.rb +29 -0
- data/spec/dummy/db/migrate/20110801124909_sunrise_create_roles.rb +16 -0
- data/spec/dummy/db/migrate/20110801125009_sunrise_create_structures.rb +27 -0
- data/spec/dummy/db/migrate/20110801125109_sunrise_create_pages.rb +17 -0
- data/spec/dummy/db/migrate/20110801125209_sunrise_create_assets.rb +28 -0
- data/spec/dummy/db/migrate/20110801125309_sunrise_create_headers.rb +20 -0
- data/spec/dummy/db/migrate/20110801161138_sunrise_create_widgets.rb +24 -0
- data/spec/dummy/db/seeds.rb +25 -0
- data/spec/dummy/db/test.sqlite3 +0 -0
- data/spec/dummy/lib/templates/erb/scaffold/_form.html.erb +13 -0
- data/spec/dummy/log/development.log +5 -0
- data/spec/dummy/log/production.log +0 -0
- data/spec/dummy/log/server.log +0 -0
- data/spec/dummy/log/test.log +2324 -0
- data/spec/dummy/public/404.html +26 -0
- data/spec/dummy/public/422.html +26 -0
- data/spec/dummy/public/500.html +26 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/public/images/manage/add_post_bot.gif +0 -0
- data/spec/dummy/public/images/manage/add_post_top.gif +0 -0
- data/spec/dummy/public/images/manage/add_white_bot.gif +0 -0
- data/spec/dummy/public/images/manage/add_white_top.gif +0 -0
- data/spec/dummy/public/images/manage/arrow.png +0 -0
- data/spec/dummy/public/images/manage/back_but_lc.gif +0 -0
- data/spec/dummy/public/images/manage/back_but_rc.gif +0 -0
- data/spec/dummy/public/images/manage/bot_corn.gif +0 -0
- data/spec/dummy/public/images/manage/bot_duo_corn.gif +0 -0
- data/spec/dummy/public/images/manage/but_bg.png +0 -0
- data/spec/dummy/public/images/manage/but_block_lc.gif +0 -0
- data/spec/dummy/public/images/manage/but_block_rc.gif +0 -0
- data/spec/dummy/public/images/manage/but_freze_lc.gif +0 -0
- data/spec/dummy/public/images/manage/but_freze_rc.gif +0 -0
- data/spec/dummy/public/images/manage/but_gr.gif +0 -0
- data/spec/dummy/public/images/manage/but_gr_l.gif +0 -0
- data/spec/dummy/public/images/manage/but_gr_r.gif +0 -0
- data/spec/dummy/public/images/manage/but_search.gif +0 -0
- data/spec/dummy/public/images/manage/but_unfreze_lc.gif +0 -0
- data/spec/dummy/public/images/manage/but_unfreze_rc.gif +0 -0
- data/spec/dummy/public/images/manage/button_add_foto.gif +0 -0
- data/spec/dummy/public/images/manage/button_add_foto_ru.gif +0 -0
- data/spec/dummy/public/images/manage/button_add_foto_ua.gif +0 -0
- data/spec/dummy/public/images/manage/button_add_foto_uk.gif +0 -0
- data/spec/dummy/public/images/manage/cancelbutton.gif +0 -0
- data/spec/dummy/public/images/manage/dark_arr.gif +0 -0
- data/spec/dummy/public/images/manage/dark_arr_left.gif +0 -0
- data/spec/dummy/public/images/manage/dark_cross_ico.gif +0 -0
- data/spec/dummy/public/images/manage/dot.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bg.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bg_small.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bg_small_blocked.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bg_small_frozed.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bg_small_notact.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bot_small.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bot_small_blocked.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bot_small_frozed.gif +0 -0
- data/spec/dummy/public/images/manage/duo_bot_small_notact.gif +0 -0
- data/spec/dummy/public/images/manage/duo_top_small.gif +0 -0
- data/spec/dummy/public/images/manage/duo_top_small_blocked.gif +0 -0
- data/spec/dummy/public/images/manage/duo_top_small_frozed.gif +0 -0
- data/spec/dummy/public/images/manage/duo_top_small_notact.gif +0 -0
- data/spec/dummy/public/images/manage/edit_white_top.gif +0 -0
- data/spec/dummy/public/images/manage/empty.gif +0 -0
- data/spec/dummy/public/images/manage/filter_bot_bg.gif +0 -0
- data/spec/dummy/public/images/manage/filter_top_bg.gif +0 -0
- data/spec/dummy/public/images/manage/flag_en.gif +0 -0
- data/spec/dummy/public/images/manage/flag_en_nonact.gif +0 -0
- data/spec/dummy/public/images/manage/flag_ru.gif +0 -0
- data/spec/dummy/public/images/manage/flag_ru_nonact.gif +0 -0
- data/spec/dummy/public/images/manage/flag_ua.gif +0 -0
- data/spec/dummy/public/images/manage/flag_ua_nonact.gif +0 -0
- data/spec/dummy/public/images/manage/foto.jpg +0 -0
- data/spec/dummy/public/images/manage/ico_add.gif +0 -0
- data/spec/dummy/public/images/manage/ico_del.gif +0 -0
- data/spec/dummy/public/images/manage/ico_down.gif +0 -0
- data/spec/dummy/public/images/manage/ico_edit.gif +0 -0
- data/spec/dummy/public/images/manage/ico_settings.gif +0 -0
- data/spec/dummy/public/images/manage/ico_up.gif +0 -0
- data/spec/dummy/public/images/manage/input_bg.gif +0 -0
- data/spec/dummy/public/images/manage/l_but_corn.gif +0 -0
- data/spec/dummy/public/images/manage/minimise_but.gif +0 -0
- data/spec/dummy/public/images/manage/mp3.png +0 -0
- data/spec/dummy/public/images/manage/page_arr_hover.png +0 -0
- data/spec/dummy/public/images/manage/page_next_arr.gif +0 -0
- data/spec/dummy/public/images/manage/page_num_hover.gif +0 -0
- data/spec/dummy/public/images/manage/page_prev_arr.gif +0 -0
- data/spec/dummy/public/images/manage/panel/l_but_corn.gif +0 -0
- data/spec/dummy/public/images/manage/panel/maximise_but.gif +0 -0
- data/spec/dummy/public/images/manage/panel/r_but_corn.gif +0 -0
- data/spec/dummy/public/images/manage/panel/top_menu_arr.gif +0 -0
- data/spec/dummy/public/images/manage/panel/user_pic.gif +0 -0
- data/spec/dummy/public/images/manage/preloader.gif +0 -0
- data/spec/dummy/public/images/manage/r_but_corn.gif +0 -0
- data/spec/dummy/public/images/manage/select_bg.gif +0 -0
- data/spec/dummy/public/images/manage/select_corn.gif +0 -0
- data/spec/dummy/public/images/manage/struct_corn_lg.gif +0 -0
- data/spec/dummy/public/images/manage/struct_corn_llg.gif +0 -0
- data/spec/dummy/public/images/manage/struct_corn_lw.gif +0 -0
- data/spec/dummy/public/images/manage/struct_corn_rg.gif +0 -0
- data/spec/dummy/public/images/manage/struct_corn_rlg.gif +0 -0
- data/spec/dummy/public/images/manage/struct_corn_rw.gif +0 -0
- data/spec/dummy/public/images/manage/tab_gl.gif +0 -0
- data/spec/dummy/public/images/manage/tab_gr.gif +0 -0
- data/spec/dummy/public/images/manage/tab_wl.gif +0 -0
- data/spec/dummy/public/images/manage/tab_wr.gif +0 -0
- data/spec/dummy/public/images/manage/top_corn.gif +0 -0
- data/spec/dummy/public/images/manage/top_duo_corn.gif +0 -0
- data/spec/dummy/public/images/manage/top_menu_arr.gif +0 -0
- data/spec/dummy/public/images/manage/transp_cross.png +0 -0
- data/spec/dummy/public/images/manage/upload_progress.gif +0 -0
- data/spec/dummy/public/images/manage/user_act_lc.gif +0 -0
- data/spec/dummy/public/images/manage/user_act_rc.gif +0 -0
- data/spec/dummy/public/images/manage/user_ico.gif +0 -0
- data/spec/dummy/public/images/manage/user_pic.gif +0 -0
- data/spec/dummy/public/images/manage/user_pic_small.gif +0 -0
- data/spec/dummy/public/images/manage/user_pic_thumb.gif +0 -0
- data/spec/dummy/public/javascripts/application.js +2 -0
- data/spec/dummy/public/javascripts/controls.js +965 -0
- data/spec/dummy/public/javascripts/datepicker/jquery-ui-i18n.js +1176 -0
- data/spec/dummy/public/javascripts/datepicker/jquery.ui.datepicker-ru.js +37 -0
- data/spec/dummy/public/javascripts/datepicker/jquery.ui.datepicker-uk.js +37 -0
- data/spec/dummy/public/javascripts/dragdrop.js +974 -0
- data/spec/dummy/public/javascripts/effects.js +1123 -0
- data/spec/dummy/public/javascripts/fileupload/fileuploader-input.js +217 -0
- data/spec/dummy/public/javascripts/fileupload/fileuploader.css +31 -0
- data/spec/dummy/public/javascripts/fileupload/fileuploader.js +1288 -0
- data/spec/dummy/public/javascripts/jquery-ui-timepicker-addon.js +911 -0
- data/spec/dummy/public/javascripts/jquery.cookie.js +97 -0
- data/spec/dummy/public/javascripts/jquery.fancybox-1.3.4.pack.js +46 -0
- data/spec/dummy/public/javascripts/jquery.tmpl.min.js +10 -0
- data/spec/dummy/public/javascripts/manage-fileuploader.js +182 -0
- data/spec/dummy/public/javascripts/manage.js +294 -0
- data/spec/dummy/public/javascripts/preloader.js +47 -0
- data/spec/dummy/public/javascripts/prototype.js +6001 -0
- data/spec/dummy/public/javascripts/rails.js +331 -0
- data/spec/dummy/public/stylesheets/application.css +1 -0
- data/spec/dummy/public/stylesheets/fancybox/images/blank.gif +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_close.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_loading.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_nav_left.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_nav_right.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_e.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_n.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_ne.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_nw.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_s.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_se.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_sw.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_w.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_title_left.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_title_main.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_title_over.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancy_title_right.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancybox-x.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancybox-y.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/images/fancybox.png +0 -0
- data/spec/dummy/public/stylesheets/fancybox/jquery.fancybox-1.3.4.css +359 -0
- data/spec/dummy/public/stylesheets/manage/buttons.css +42 -0
- data/spec/dummy/public/stylesheets/manage/ie.css +16 -0
- data/spec/dummy/public/stylesheets/manage/main.css +1108 -0
- data/spec/dummy/public/stylesheets/manage/panel.css +126 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_flat_75_ffffff_40x100.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_55_fbf9ee_1x400.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_75_dadada_1x400.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_75_e6e6e6_1x400.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_95_fef1ec_1x400.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_highlight-soft_75_cccccc_1x100.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_222222_256x240.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_2e83ff_256x240.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_454545_256x240.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_888888_256x240.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_cd0a0a_256x240.png +0 -0
- data/spec/dummy/public/stylesheets/smoothness/jquery-ui-1.8.13.custom.css +578 -0
- data/spec/dummy/script/rails +6 -0
- data/spec/factories/structure_factory.rb +22 -0
- data/spec/factories/user_factory.rb +48 -0
- data/spec/factories/widget_factory.rb +12 -0
- data/spec/generators/install_generator_spec.rb +27 -0
- data/spec/integration/navigation_spec.rb +9 -0
- data/spec/models/widget_spec.rb +30 -0
- data/spec/spec.opts +2 -0
- data/spec/spec_helper.rb +57 -0
- data/spec/sunrise_widgets_spec.rb +7 -0
- data/spec/support/helpers/controller_macros.rb +40 -0
- data/spec/tmp/app/models/widget.rb +6 -0
- data/spec/tmp/app/models/widget_position.rb +14 -0
- data/spec/tmp/app/models/widget_type.rb +15 -0
- data/spec/tmp/app/sweepers/widget_sweeper.rb +21 -0
- data/spec/tmp/db/migrate/20110818113026_sunrise_create_widgets.rb +24 -0
- metadata +587 -0
@@ -0,0 +1,217 @@
|
|
1
|
+
// Collection of all instances on page
|
2
|
+
qq.FileUploader.instances = new Object();
|
3
|
+
|
4
|
+
/**
|
5
|
+
* Class that creates upload widget with drag-and-drop and file list
|
6
|
+
* @inherits qq.FileUploaderBasic
|
7
|
+
*/
|
8
|
+
qq.FileUploaderInput = function(o){
|
9
|
+
// call parent constructor
|
10
|
+
qq.FileUploaderBasic.apply(this, arguments);
|
11
|
+
|
12
|
+
// additional options
|
13
|
+
qq.extend(this._options, {
|
14
|
+
element: null,
|
15
|
+
// if set, will be used instead of qq-upload-list in template
|
16
|
+
listElement: null,
|
17
|
+
|
18
|
+
template_id: '#fileupload_tmpl',
|
19
|
+
|
20
|
+
// template for one item in file list
|
21
|
+
fileTemplate: '<li>' +
|
22
|
+
'<span class="fileupload-file"></span>' +
|
23
|
+
'<span class="fileupload-spinner"></span>' +
|
24
|
+
'<span class="fileupload-size"></span>' +
|
25
|
+
'<a class="fileupload-cancel" href="#">Cancel</a>' +
|
26
|
+
'<span class="fileupload-failed-text">Failed</span>' +
|
27
|
+
'</li>',
|
28
|
+
|
29
|
+
classes: {
|
30
|
+
// used to get elements from templates
|
31
|
+
button: 'fileupload-button',
|
32
|
+
drop: 'fileupload-drop-area',
|
33
|
+
dropActive: 'fileupload-drop-area-active',
|
34
|
+
list: 'fileupload-list',
|
35
|
+
preview: 'fileupload-preview',
|
36
|
+
|
37
|
+
file: 'fileupload-file',
|
38
|
+
spinner: 'fileupload-spinner',
|
39
|
+
size: 'fileupload-size',
|
40
|
+
cancel: 'fileupload-cancel',
|
41
|
+
|
42
|
+
// added to list item when upload completes
|
43
|
+
// used in css to hide progress spinner
|
44
|
+
success: 'fileupload-success',
|
45
|
+
fail: 'fileupload-fail'
|
46
|
+
}
|
47
|
+
});
|
48
|
+
// overwrite options with user supplied
|
49
|
+
qq.extend(this._options, o);
|
50
|
+
|
51
|
+
this._element = document.getElementById(this._options.element);
|
52
|
+
this._element.innerHTML = $(this._options.template_id).tmpl(this._options).html();
|
53
|
+
this._listElement = this._options.listElement || this._find(this._element, 'list');
|
54
|
+
|
55
|
+
this._classes = this._options.classes;
|
56
|
+
|
57
|
+
this._button = this._createUploadButton(this._find(this._element, 'button'));
|
58
|
+
|
59
|
+
this._bindCancelEvent();
|
60
|
+
//this._setupDragDrop();
|
61
|
+
|
62
|
+
qq.FileUploader.instances[this._element.id] = this;
|
63
|
+
};
|
64
|
+
|
65
|
+
// inherit from Basic Uploader
|
66
|
+
qq.extend(qq.FileUploaderInput.prototype, qq.FileUploaderBasic.prototype);
|
67
|
+
|
68
|
+
qq.extend(qq.FileUploaderInput.prototype, {
|
69
|
+
/**
|
70
|
+
* Gets one of the elements listed in this._options.classes
|
71
|
+
**/
|
72
|
+
_find: function(parent, type){
|
73
|
+
var element = qq.getByClass(parent, this._options.classes[type])[0];
|
74
|
+
if (!element){
|
75
|
+
throw new Error('element not found ' + type);
|
76
|
+
}
|
77
|
+
|
78
|
+
return element;
|
79
|
+
},
|
80
|
+
_setupDragDrop: function(){
|
81
|
+
var self = this,
|
82
|
+
dropArea = this._find(this._element, 'drop');
|
83
|
+
|
84
|
+
var dz = new qq.UploadDropZone({
|
85
|
+
element: dropArea,
|
86
|
+
onEnter: function(e){
|
87
|
+
qq.addClass(dropArea, self._classes.dropActive);
|
88
|
+
e.stopPropagation();
|
89
|
+
},
|
90
|
+
onLeave: function(e){
|
91
|
+
e.stopPropagation();
|
92
|
+
},
|
93
|
+
onLeaveNotDescendants: function(e){
|
94
|
+
qq.removeClass(dropArea, self._classes.dropActive);
|
95
|
+
},
|
96
|
+
onDrop: function(e){
|
97
|
+
dropArea.style.display = 'none';
|
98
|
+
qq.removeClass(dropArea, self._classes.dropActive);
|
99
|
+
self._uploadFileList(e.dataTransfer.files);
|
100
|
+
}
|
101
|
+
});
|
102
|
+
|
103
|
+
dropArea.style.display = 'none';
|
104
|
+
|
105
|
+
qq.attach(document, 'dragenter', function(e){
|
106
|
+
if (!dz._isValidFileDrag(e)) return;
|
107
|
+
|
108
|
+
dropArea.style.display = 'block';
|
109
|
+
});
|
110
|
+
qq.attach(document, 'dragleave', function(e){
|
111
|
+
if (!dz._isValidFileDrag(e)) return;
|
112
|
+
|
113
|
+
var relatedTarget = document.elementFromPoint(e.clientX, e.clientY);
|
114
|
+
// only fire when leaving document out
|
115
|
+
if ( ! relatedTarget || relatedTarget.nodeName == "HTML"){
|
116
|
+
dropArea.style.display = 'none';
|
117
|
+
}
|
118
|
+
});
|
119
|
+
},
|
120
|
+
_onSubmit: function(id, fileName){
|
121
|
+
qq.FileUploaderBasic.prototype._onSubmit.apply(this, arguments);
|
122
|
+
this._addToList(id, fileName);
|
123
|
+
},
|
124
|
+
_onProgress: function(id, fileName, loaded, total){
|
125
|
+
qq.FileUploaderBasic.prototype._onProgress.apply(this, arguments);
|
126
|
+
|
127
|
+
var item = this._getItemByFileId(id);
|
128
|
+
var size = this._find(item, 'size');
|
129
|
+
size.style.display = 'inline';
|
130
|
+
|
131
|
+
var text;
|
132
|
+
if (loaded != total){
|
133
|
+
text = Math.round(loaded / total * 100) + '% from ' + this._formatSize(total);
|
134
|
+
} else {
|
135
|
+
text = this._formatSize(total);
|
136
|
+
}
|
137
|
+
|
138
|
+
qq.setText(size, text);
|
139
|
+
},
|
140
|
+
_onComplete: function(id, fileName, result){
|
141
|
+
qq.FileUploaderBasic.prototype._onComplete.apply(this, arguments);
|
142
|
+
|
143
|
+
var item = this._getItemByFileId(id);
|
144
|
+
var asset = result.asset;
|
145
|
+
|
146
|
+
// mark completed
|
147
|
+
qq.remove(this._find(item, 'cancel'));
|
148
|
+
qq.remove(this._find(item, 'spinner'));
|
149
|
+
|
150
|
+
if (asset && asset.id){
|
151
|
+
qq.addClass(item, this._classes.success);
|
152
|
+
this._updatePreview(result);
|
153
|
+
} else {
|
154
|
+
qq.addClass(item, this._classes.fail);
|
155
|
+
}
|
156
|
+
},
|
157
|
+
_addToList: function(id, fileName){
|
158
|
+
if (this._listElement) {
|
159
|
+
var item = qq.toElement(this._options.fileTemplate);
|
160
|
+
item.qqFileId = id;
|
161
|
+
|
162
|
+
var fileElement = this._find(item, 'file');
|
163
|
+
qq.setText(fileElement, this._formatFileName(fileName));
|
164
|
+
this._find(item, 'size').style.display = 'none';
|
165
|
+
|
166
|
+
this._listElement.appendChild(item);
|
167
|
+
}
|
168
|
+
},
|
169
|
+
_getItemByFileId: function(id){
|
170
|
+
var item = this._listElement.firstChild;
|
171
|
+
|
172
|
+
// there can't be txt nodes in dynamically created list
|
173
|
+
// and we can use nextSibling
|
174
|
+
while (item){
|
175
|
+
if (item.qqFileId == id) return item;
|
176
|
+
item = item.nextSibling;
|
177
|
+
}
|
178
|
+
},
|
179
|
+
/**
|
180
|
+
* delegate click event for cancel link
|
181
|
+
**/
|
182
|
+
_bindCancelEvent: function(){
|
183
|
+
var self = this,
|
184
|
+
list = this._listElement;
|
185
|
+
|
186
|
+
if (list) {
|
187
|
+
qq.attach(list, 'click', function(e){
|
188
|
+
e = e || window.event;
|
189
|
+
var target = e.target || e.srcElement;
|
190
|
+
|
191
|
+
if (qq.hasClass(target, self._classes.cancel)){
|
192
|
+
qq.preventDefault(e);
|
193
|
+
|
194
|
+
var item = target.parentNode;
|
195
|
+
self._handler.cancel(item.qqFileId);
|
196
|
+
qq.remove(item);
|
197
|
+
}
|
198
|
+
});
|
199
|
+
}
|
200
|
+
},
|
201
|
+
|
202
|
+
_updatePreview: function(result) {
|
203
|
+
var preview = this._find(this._element, 'preview'),
|
204
|
+
asset = result.asset || result;
|
205
|
+
img = null;
|
206
|
+
|
207
|
+
if (preview && asset) {
|
208
|
+
img = document.createElement('img');
|
209
|
+
img.src = asset.thumb_url;
|
210
|
+
img.alt = asset.filename;
|
211
|
+
img.setAttribute('data-url', asset.url);
|
212
|
+
|
213
|
+
preview.innerHTML = '';
|
214
|
+
preview.appendChild(img);
|
215
|
+
}
|
216
|
+
}
|
217
|
+
});
|
@@ -0,0 +1,31 @@
|
|
1
|
+
.qq-uploader { position:relative; width: 100%;}
|
2
|
+
|
3
|
+
.qq-upload-button {
|
4
|
+
display:block; /* or inline-block */
|
5
|
+
width: 105px; padding: 7px 0; text-align:center;
|
6
|
+
background:#880000; border-bottom:1px solid #ddd;color:#fff;
|
7
|
+
}
|
8
|
+
.qq-upload-button-hover {background:#cc0000;}
|
9
|
+
.qq-upload-button-focus {outline:1px dotted black;}
|
10
|
+
|
11
|
+
.qq-upload-drop-area {
|
12
|
+
position:absolute; top:0; left:0; width:100%; height:100%; min-height: 70px; z-index:2;
|
13
|
+
background:#FF9797; text-align:center;
|
14
|
+
}
|
15
|
+
.qq-upload-drop-area span {
|
16
|
+
display:block; position:absolute; top: 50%; width:100%; margin-top:-8px; font-size:16px;
|
17
|
+
}
|
18
|
+
.qq-upload-drop-area-active {background:#FF7171;}
|
19
|
+
|
20
|
+
.qq-upload-list {margin:15px 35px; padding:0; list-style:disc;}
|
21
|
+
.qq-upload-list li { margin:0; padding:0; line-height:15px; font-size:12px;}
|
22
|
+
.qq-upload-file, .qq-upload-spinner, .qq-upload-size, .qq-upload-cancel, .qq-upload-failed-text {
|
23
|
+
margin-right: 7px;
|
24
|
+
}
|
25
|
+
|
26
|
+
.qq-upload-file {}
|
27
|
+
.qq-upload-spinner {display:inline-block; background: url("loading.gif"); width:15px; height:15px; vertical-align:text-bottom;}
|
28
|
+
.qq-upload-size,.qq-upload-cancel {font-size:11px;}
|
29
|
+
|
30
|
+
.qq-upload-failed-text {display:none;}
|
31
|
+
.qq-upload-fail .qq-upload-failed-text {display:inline;}
|