sunrise-widgets 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (268) hide show
  1. data/Gemfile +34 -0
  2. data/MIT-LICENSE +20 -0
  3. data/README.rdoc +21 -0
  4. data/Rakefile +27 -0
  5. data/app/controllers/manage/widgets_controller.rb +33 -0
  6. data/app/views/manage/widgets/_form.html.erb +21 -0
  7. data/app/views/manage/widgets/_model_filter.html.erb +40 -0
  8. data/app/views/manage/widgets/_widget.html.erb +41 -0
  9. data/app/views/manage/widgets/edit.html.erb +6 -0
  10. data/app/views/manage/widgets/index.html.erb +30 -0
  11. data/app/views/manage/widgets/new.html.erb +6 -0
  12. data/app/views/manage/widgets/show.html.erb +29 -0
  13. data/config/locales/ru.yml +18 -0
  14. data/config/locales/uk.yml +18 -0
  15. data/config/routes.rb +5 -0
  16. data/lib/generators/sunrise/widgets/USAGE +12 -0
  17. data/lib/generators/sunrise/widgets/install_generator.rb +40 -0
  18. data/lib/generators/sunrise/widgets/templates/create_widgets.rb +24 -0
  19. data/lib/generators/sunrise/widgets/templates/widget.rb +6 -0
  20. data/lib/generators/sunrise/widgets/templates/widget_position.rb +14 -0
  21. data/lib/generators/sunrise/widgets/templates/widget_sweeper.rb +21 -0
  22. data/lib/generators/sunrise/widgets/templates/widget_type.rb +15 -0
  23. data/lib/sunrise/models/widget.rb +39 -0
  24. data/lib/sunrise/widgets/engine.rb +18 -0
  25. data/lib/sunrise/widgets/version.rb +5 -0
  26. data/lib/sunrise/widgets.rb +12 -0
  27. data/lib/sunrise-widgets.rb +1 -0
  28. data/spec/controllers/manage/widgets_controller_spec.rb +95 -0
  29. data/spec/dummy/Rakefile +7 -0
  30. data/spec/dummy/app/controllers/application_controller.rb +3 -0
  31. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  32. data/spec/dummy/app/helpers/manage/assets_helper.rb +2 -0
  33. data/spec/dummy/app/helpers/manage/base_helper.rb +81 -0
  34. data/spec/dummy/app/helpers/manage/pages_helper.rb +2 -0
  35. data/spec/dummy/app/helpers/manage/settings_helper.rb +2 -0
  36. data/spec/dummy/app/helpers/manage/structures_helper.rb +12 -0
  37. data/spec/dummy/app/helpers/manage/users_helper.rb +6 -0
  38. data/spec/dummy/app/models/defaults/ability.rb +39 -0
  39. data/spec/dummy/app/models/defaults/asset.rb +7 -0
  40. data/spec/dummy/app/models/defaults/attachment_file.rb +33 -0
  41. data/spec/dummy/app/models/defaults/avatar.rb +37 -0
  42. data/spec/dummy/app/models/defaults/header.rb +5 -0
  43. data/spec/dummy/app/models/defaults/page.rb +5 -0
  44. data/spec/dummy/app/models/defaults/picture.rb +35 -0
  45. data/spec/dummy/app/models/defaults/position_type.rb +7 -0
  46. data/spec/dummy/app/models/defaults/role.rb +20 -0
  47. data/spec/dummy/app/models/defaults/role_type.rb +8 -0
  48. data/spec/dummy/app/models/defaults/structure.rb +16 -0
  49. data/spec/dummy/app/models/defaults/structure_type.rb +9 -0
  50. data/spec/dummy/app/models/defaults/user.rb +47 -0
  51. data/spec/dummy/app/views/layouts/application.html.erb +37 -0
  52. data/spec/dummy/app/views/pages/show.html.erb +2 -0
  53. data/spec/dummy/app/views/shared/_notice.html.erb +17 -0
  54. data/spec/dummy/config/application.rb +47 -0
  55. data/spec/dummy/config/application.yml.sample +4 -0
  56. data/spec/dummy/config/boot.rb +10 -0
  57. data/spec/dummy/config/database.yml +22 -0
  58. data/spec/dummy/config/database.yml.sample +34 -0
  59. data/spec/dummy/config/environment.rb +5 -0
  60. data/spec/dummy/config/environments/development.rb +26 -0
  61. data/spec/dummy/config/environments/production.rb +49 -0
  62. data/spec/dummy/config/environments/test.rb +35 -0
  63. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
  64. data/spec/dummy/config/initializers/devise.rb +204 -0
  65. data/spec/dummy/config/initializers/inflections.rb +10 -0
  66. data/spec/dummy/config/initializers/mime_types.rb +5 -0
  67. data/spec/dummy/config/initializers/secret_token.rb +7 -0
  68. data/spec/dummy/config/initializers/session_store.rb +8 -0
  69. data/spec/dummy/config/initializers/simple_form.rb +93 -0
  70. data/spec/dummy/config/initializers/sunrise.rb +7 -0
  71. data/spec/dummy/config/locales/devise.en.yml +53 -0
  72. data/spec/dummy/config/locales/en.yml +5 -0
  73. data/spec/dummy/config/locales/simple_form.en.yml +24 -0
  74. data/spec/dummy/config/logrotate-config.sample +9 -0
  75. data/spec/dummy/config/nginx-config-passenger.sample +51 -0
  76. data/spec/dummy/config/routes.rb +64 -0
  77. data/spec/dummy/config.ru +4 -0
  78. data/spec/dummy/db/migrate/20110801124809_sunrise_create_users.rb +29 -0
  79. data/spec/dummy/db/migrate/20110801124909_sunrise_create_roles.rb +16 -0
  80. data/spec/dummy/db/migrate/20110801125009_sunrise_create_structures.rb +27 -0
  81. data/spec/dummy/db/migrate/20110801125109_sunrise_create_pages.rb +17 -0
  82. data/spec/dummy/db/migrate/20110801125209_sunrise_create_assets.rb +28 -0
  83. data/spec/dummy/db/migrate/20110801125309_sunrise_create_headers.rb +20 -0
  84. data/spec/dummy/db/migrate/20110801161138_sunrise_create_widgets.rb +24 -0
  85. data/spec/dummy/db/seeds.rb +25 -0
  86. data/spec/dummy/db/test.sqlite3 +0 -0
  87. data/spec/dummy/lib/templates/erb/scaffold/_form.html.erb +13 -0
  88. data/spec/dummy/log/development.log +5 -0
  89. data/spec/dummy/log/production.log +0 -0
  90. data/spec/dummy/log/server.log +0 -0
  91. data/spec/dummy/log/test.log +2324 -0
  92. data/spec/dummy/public/404.html +26 -0
  93. data/spec/dummy/public/422.html +26 -0
  94. data/spec/dummy/public/500.html +26 -0
  95. data/spec/dummy/public/favicon.ico +0 -0
  96. data/spec/dummy/public/images/manage/add_post_bot.gif +0 -0
  97. data/spec/dummy/public/images/manage/add_post_top.gif +0 -0
  98. data/spec/dummy/public/images/manage/add_white_bot.gif +0 -0
  99. data/spec/dummy/public/images/manage/add_white_top.gif +0 -0
  100. data/spec/dummy/public/images/manage/arrow.png +0 -0
  101. data/spec/dummy/public/images/manage/back_but_lc.gif +0 -0
  102. data/spec/dummy/public/images/manage/back_but_rc.gif +0 -0
  103. data/spec/dummy/public/images/manage/bot_corn.gif +0 -0
  104. data/spec/dummy/public/images/manage/bot_duo_corn.gif +0 -0
  105. data/spec/dummy/public/images/manage/but_bg.png +0 -0
  106. data/spec/dummy/public/images/manage/but_block_lc.gif +0 -0
  107. data/spec/dummy/public/images/manage/but_block_rc.gif +0 -0
  108. data/spec/dummy/public/images/manage/but_freze_lc.gif +0 -0
  109. data/spec/dummy/public/images/manage/but_freze_rc.gif +0 -0
  110. data/spec/dummy/public/images/manage/but_gr.gif +0 -0
  111. data/spec/dummy/public/images/manage/but_gr_l.gif +0 -0
  112. data/spec/dummy/public/images/manage/but_gr_r.gif +0 -0
  113. data/spec/dummy/public/images/manage/but_search.gif +0 -0
  114. data/spec/dummy/public/images/manage/but_unfreze_lc.gif +0 -0
  115. data/spec/dummy/public/images/manage/but_unfreze_rc.gif +0 -0
  116. data/spec/dummy/public/images/manage/button_add_foto.gif +0 -0
  117. data/spec/dummy/public/images/manage/button_add_foto_ru.gif +0 -0
  118. data/spec/dummy/public/images/manage/button_add_foto_ua.gif +0 -0
  119. data/spec/dummy/public/images/manage/button_add_foto_uk.gif +0 -0
  120. data/spec/dummy/public/images/manage/cancelbutton.gif +0 -0
  121. data/spec/dummy/public/images/manage/dark_arr.gif +0 -0
  122. data/spec/dummy/public/images/manage/dark_arr_left.gif +0 -0
  123. data/spec/dummy/public/images/manage/dark_cross_ico.gif +0 -0
  124. data/spec/dummy/public/images/manage/dot.gif +0 -0
  125. data/spec/dummy/public/images/manage/duo_bg.gif +0 -0
  126. data/spec/dummy/public/images/manage/duo_bg_small.gif +0 -0
  127. data/spec/dummy/public/images/manage/duo_bg_small_blocked.gif +0 -0
  128. data/spec/dummy/public/images/manage/duo_bg_small_frozed.gif +0 -0
  129. data/spec/dummy/public/images/manage/duo_bg_small_notact.gif +0 -0
  130. data/spec/dummy/public/images/manage/duo_bot_small.gif +0 -0
  131. data/spec/dummy/public/images/manage/duo_bot_small_blocked.gif +0 -0
  132. data/spec/dummy/public/images/manage/duo_bot_small_frozed.gif +0 -0
  133. data/spec/dummy/public/images/manage/duo_bot_small_notact.gif +0 -0
  134. data/spec/dummy/public/images/manage/duo_top_small.gif +0 -0
  135. data/spec/dummy/public/images/manage/duo_top_small_blocked.gif +0 -0
  136. data/spec/dummy/public/images/manage/duo_top_small_frozed.gif +0 -0
  137. data/spec/dummy/public/images/manage/duo_top_small_notact.gif +0 -0
  138. data/spec/dummy/public/images/manage/edit_white_top.gif +0 -0
  139. data/spec/dummy/public/images/manage/empty.gif +0 -0
  140. data/spec/dummy/public/images/manage/filter_bot_bg.gif +0 -0
  141. data/spec/dummy/public/images/manage/filter_top_bg.gif +0 -0
  142. data/spec/dummy/public/images/manage/flag_en.gif +0 -0
  143. data/spec/dummy/public/images/manage/flag_en_nonact.gif +0 -0
  144. data/spec/dummy/public/images/manage/flag_ru.gif +0 -0
  145. data/spec/dummy/public/images/manage/flag_ru_nonact.gif +0 -0
  146. data/spec/dummy/public/images/manage/flag_ua.gif +0 -0
  147. data/spec/dummy/public/images/manage/flag_ua_nonact.gif +0 -0
  148. data/spec/dummy/public/images/manage/foto.jpg +0 -0
  149. data/spec/dummy/public/images/manage/ico_add.gif +0 -0
  150. data/spec/dummy/public/images/manage/ico_del.gif +0 -0
  151. data/spec/dummy/public/images/manage/ico_down.gif +0 -0
  152. data/spec/dummy/public/images/manage/ico_edit.gif +0 -0
  153. data/spec/dummy/public/images/manage/ico_settings.gif +0 -0
  154. data/spec/dummy/public/images/manage/ico_up.gif +0 -0
  155. data/spec/dummy/public/images/manage/input_bg.gif +0 -0
  156. data/spec/dummy/public/images/manage/l_but_corn.gif +0 -0
  157. data/spec/dummy/public/images/manage/minimise_but.gif +0 -0
  158. data/spec/dummy/public/images/manage/mp3.png +0 -0
  159. data/spec/dummy/public/images/manage/page_arr_hover.png +0 -0
  160. data/spec/dummy/public/images/manage/page_next_arr.gif +0 -0
  161. data/spec/dummy/public/images/manage/page_num_hover.gif +0 -0
  162. data/spec/dummy/public/images/manage/page_prev_arr.gif +0 -0
  163. data/spec/dummy/public/images/manage/panel/l_but_corn.gif +0 -0
  164. data/spec/dummy/public/images/manage/panel/maximise_but.gif +0 -0
  165. data/spec/dummy/public/images/manage/panel/r_but_corn.gif +0 -0
  166. data/spec/dummy/public/images/manage/panel/top_menu_arr.gif +0 -0
  167. data/spec/dummy/public/images/manage/panel/user_pic.gif +0 -0
  168. data/spec/dummy/public/images/manage/preloader.gif +0 -0
  169. data/spec/dummy/public/images/manage/r_but_corn.gif +0 -0
  170. data/spec/dummy/public/images/manage/select_bg.gif +0 -0
  171. data/spec/dummy/public/images/manage/select_corn.gif +0 -0
  172. data/spec/dummy/public/images/manage/struct_corn_lg.gif +0 -0
  173. data/spec/dummy/public/images/manage/struct_corn_llg.gif +0 -0
  174. data/spec/dummy/public/images/manage/struct_corn_lw.gif +0 -0
  175. data/spec/dummy/public/images/manage/struct_corn_rg.gif +0 -0
  176. data/spec/dummy/public/images/manage/struct_corn_rlg.gif +0 -0
  177. data/spec/dummy/public/images/manage/struct_corn_rw.gif +0 -0
  178. data/spec/dummy/public/images/manage/tab_gl.gif +0 -0
  179. data/spec/dummy/public/images/manage/tab_gr.gif +0 -0
  180. data/spec/dummy/public/images/manage/tab_wl.gif +0 -0
  181. data/spec/dummy/public/images/manage/tab_wr.gif +0 -0
  182. data/spec/dummy/public/images/manage/top_corn.gif +0 -0
  183. data/spec/dummy/public/images/manage/top_duo_corn.gif +0 -0
  184. data/spec/dummy/public/images/manage/top_menu_arr.gif +0 -0
  185. data/spec/dummy/public/images/manage/transp_cross.png +0 -0
  186. data/spec/dummy/public/images/manage/upload_progress.gif +0 -0
  187. data/spec/dummy/public/images/manage/user_act_lc.gif +0 -0
  188. data/spec/dummy/public/images/manage/user_act_rc.gif +0 -0
  189. data/spec/dummy/public/images/manage/user_ico.gif +0 -0
  190. data/spec/dummy/public/images/manage/user_pic.gif +0 -0
  191. data/spec/dummy/public/images/manage/user_pic_small.gif +0 -0
  192. data/spec/dummy/public/images/manage/user_pic_thumb.gif +0 -0
  193. data/spec/dummy/public/javascripts/application.js +2 -0
  194. data/spec/dummy/public/javascripts/controls.js +965 -0
  195. data/spec/dummy/public/javascripts/datepicker/jquery-ui-i18n.js +1176 -0
  196. data/spec/dummy/public/javascripts/datepicker/jquery.ui.datepicker-ru.js +37 -0
  197. data/spec/dummy/public/javascripts/datepicker/jquery.ui.datepicker-uk.js +37 -0
  198. data/spec/dummy/public/javascripts/dragdrop.js +974 -0
  199. data/spec/dummy/public/javascripts/effects.js +1123 -0
  200. data/spec/dummy/public/javascripts/fileupload/fileuploader-input.js +217 -0
  201. data/spec/dummy/public/javascripts/fileupload/fileuploader.css +31 -0
  202. data/spec/dummy/public/javascripts/fileupload/fileuploader.js +1288 -0
  203. data/spec/dummy/public/javascripts/jquery-ui-timepicker-addon.js +911 -0
  204. data/spec/dummy/public/javascripts/jquery.cookie.js +97 -0
  205. data/spec/dummy/public/javascripts/jquery.fancybox-1.3.4.pack.js +46 -0
  206. data/spec/dummy/public/javascripts/jquery.tmpl.min.js +10 -0
  207. data/spec/dummy/public/javascripts/manage-fileuploader.js +182 -0
  208. data/spec/dummy/public/javascripts/manage.js +294 -0
  209. data/spec/dummy/public/javascripts/preloader.js +47 -0
  210. data/spec/dummy/public/javascripts/prototype.js +6001 -0
  211. data/spec/dummy/public/javascripts/rails.js +331 -0
  212. data/spec/dummy/public/stylesheets/application.css +1 -0
  213. data/spec/dummy/public/stylesheets/fancybox/images/blank.gif +0 -0
  214. data/spec/dummy/public/stylesheets/fancybox/images/fancy_close.png +0 -0
  215. data/spec/dummy/public/stylesheets/fancybox/images/fancy_loading.png +0 -0
  216. data/spec/dummy/public/stylesheets/fancybox/images/fancy_nav_left.png +0 -0
  217. data/spec/dummy/public/stylesheets/fancybox/images/fancy_nav_right.png +0 -0
  218. data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_e.png +0 -0
  219. data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_n.png +0 -0
  220. data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_ne.png +0 -0
  221. data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_nw.png +0 -0
  222. data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_s.png +0 -0
  223. data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_se.png +0 -0
  224. data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_sw.png +0 -0
  225. data/spec/dummy/public/stylesheets/fancybox/images/fancy_shadow_w.png +0 -0
  226. data/spec/dummy/public/stylesheets/fancybox/images/fancy_title_left.png +0 -0
  227. data/spec/dummy/public/stylesheets/fancybox/images/fancy_title_main.png +0 -0
  228. data/spec/dummy/public/stylesheets/fancybox/images/fancy_title_over.png +0 -0
  229. data/spec/dummy/public/stylesheets/fancybox/images/fancy_title_right.png +0 -0
  230. data/spec/dummy/public/stylesheets/fancybox/images/fancybox-x.png +0 -0
  231. data/spec/dummy/public/stylesheets/fancybox/images/fancybox-y.png +0 -0
  232. data/spec/dummy/public/stylesheets/fancybox/images/fancybox.png +0 -0
  233. data/spec/dummy/public/stylesheets/fancybox/jquery.fancybox-1.3.4.css +359 -0
  234. data/spec/dummy/public/stylesheets/manage/buttons.css +42 -0
  235. data/spec/dummy/public/stylesheets/manage/ie.css +16 -0
  236. data/spec/dummy/public/stylesheets/manage/main.css +1108 -0
  237. data/spec/dummy/public/stylesheets/manage/panel.css +126 -0
  238. data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
  239. data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_flat_75_ffffff_40x100.png +0 -0
  240. data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_55_fbf9ee_1x400.png +0 -0
  241. data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_65_ffffff_1x400.png +0 -0
  242. data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_75_dadada_1x400.png +0 -0
  243. data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_75_e6e6e6_1x400.png +0 -0
  244. data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_glass_95_fef1ec_1x400.png +0 -0
  245. data/spec/dummy/public/stylesheets/smoothness/images/ui-bg_highlight-soft_75_cccccc_1x100.png +0 -0
  246. data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_222222_256x240.png +0 -0
  247. data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_2e83ff_256x240.png +0 -0
  248. data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_454545_256x240.png +0 -0
  249. data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_888888_256x240.png +0 -0
  250. data/spec/dummy/public/stylesheets/smoothness/images/ui-icons_cd0a0a_256x240.png +0 -0
  251. data/spec/dummy/public/stylesheets/smoothness/jquery-ui-1.8.13.custom.css +578 -0
  252. data/spec/dummy/script/rails +6 -0
  253. data/spec/factories/structure_factory.rb +22 -0
  254. data/spec/factories/user_factory.rb +48 -0
  255. data/spec/factories/widget_factory.rb +12 -0
  256. data/spec/generators/install_generator_spec.rb +27 -0
  257. data/spec/integration/navigation_spec.rb +9 -0
  258. data/spec/models/widget_spec.rb +30 -0
  259. data/spec/spec.opts +2 -0
  260. data/spec/spec_helper.rb +57 -0
  261. data/spec/sunrise_widgets_spec.rb +7 -0
  262. data/spec/support/helpers/controller_macros.rb +40 -0
  263. data/spec/tmp/app/models/widget.rb +6 -0
  264. data/spec/tmp/app/models/widget_position.rb +14 -0
  265. data/spec/tmp/app/models/widget_type.rb +15 -0
  266. data/spec/tmp/app/sweepers/widget_sweeper.rb +21 -0
  267. data/spec/tmp/db/migrate/20110818113026_sunrise_create_widgets.rb +24 -0
  268. 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;}