alchemy_cms 2.5.3.1 → 2.6.0.rc5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (331) hide show
  1. data/.gitignore +1 -1
  2. data/.travis.yml +5 -13
  3. data/Gemfile +6 -3
  4. data/README.md +3 -2
  5. data/alchemy_cms.gemspec +22 -22
  6. data/app/assets/fonts/alchemy-icons.eot +0 -0
  7. data/app/assets/fonts/alchemy-icons.svg +54 -0
  8. data/app/assets/fonts/alchemy-icons.ttf +0 -0
  9. data/app/assets/fonts/alchemy-icons.woff +0 -0
  10. data/app/assets/images/alchemy/icons.png +0 -0
  11. data/app/assets/javascripts/alchemy/alchemy.base.js.coffee +151 -0
  12. data/app/assets/javascripts/alchemy/alchemy.buttons.js.coffee +3 -2
  13. data/app/assets/javascripts/alchemy/alchemy.datepicker.js.coffee +31 -0
  14. data/app/assets/javascripts/alchemy/alchemy.dragndrop.js +1 -1
  15. data/app/assets/javascripts/alchemy/alchemy.element_editors.js.coffee +98 -0
  16. data/app/assets/javascripts/alchemy/alchemy.elements_window.js.coffee +23 -24
  17. data/app/assets/javascripts/alchemy/alchemy.growler.js.coffee +27 -0
  18. data/app/assets/javascripts/alchemy/alchemy.gui.js.coffee +11 -8
  19. data/app/assets/javascripts/alchemy/alchemy.hotkeys.js.coffee +32 -0
  20. data/app/assets/javascripts/alchemy/alchemy.image_cropper.js.coffee +46 -0
  21. data/app/assets/javascripts/alchemy/alchemy.js +8 -2
  22. data/app/assets/javascripts/alchemy/alchemy.link_overlay.js.coffee +5 -4
  23. data/app/assets/javascripts/alchemy/alchemy.list_filter.js.coffee +49 -0
  24. data/app/assets/javascripts/alchemy/alchemy.onload.js.coffee +3 -0
  25. data/app/assets/javascripts/alchemy/alchemy.preview_window.js.coffee +71 -0
  26. data/app/assets/javascripts/alchemy/alchemy.sitemap.js.coffee +61 -0
  27. data/app/assets/javascripts/alchemy/alchemy.spinner.js.coffee +35 -0
  28. data/app/assets/javascripts/alchemy/alchemy.string_extension.js.coffee +11 -0
  29. data/app/assets/javascripts/alchemy/alchemy.windows.js.coffee +278 -0
  30. data/app/assets/stylesheets/alchemy/admin.css.scss +2 -0
  31. data/app/assets/stylesheets/alchemy/archive.scss +109 -65
  32. data/app/assets/stylesheets/alchemy/base.scss +16 -188
  33. data/app/assets/stylesheets/alchemy/dashboard.scss +2 -2
  34. data/app/assets/stylesheets/alchemy/defaults.scss +2 -1
  35. data/app/assets/stylesheets/alchemy/elements.scss +58 -94
  36. data/app/assets/stylesheets/alchemy/errors.scss +2 -2
  37. data/app/assets/stylesheets/alchemy/{mixins.scss → extends.scss} +104 -80
  38. data/app/assets/stylesheets/alchemy/flash.scss +4 -6
  39. data/app/assets/stylesheets/alchemy/fonts.scss +46 -0
  40. data/app/assets/stylesheets/alchemy/form_elements.scss +46 -45
  41. data/app/assets/stylesheets/alchemy/frame.scss +20 -15
  42. data/app/assets/stylesheets/alchemy/icons.scss +22 -9
  43. data/app/assets/stylesheets/alchemy/jquery-ui.scss +476 -399
  44. data/app/assets/stylesheets/alchemy/login.scss +1 -1
  45. data/app/assets/stylesheets/alchemy/menubar.css.scss +1 -1
  46. data/app/assets/stylesheets/alchemy/notices.scss +5 -5
  47. data/app/assets/stylesheets/alchemy/pagination.scss +25 -13
  48. data/app/assets/stylesheets/alchemy/search.scss +29 -17
  49. data/app/assets/stylesheets/alchemy/sitemap.scss +41 -36
  50. data/app/assets/stylesheets/alchemy/tables.scss +102 -50
  51. data/app/assets/stylesheets/alchemy/tinymce_dialog.css.scss +18 -16
  52. data/app/assets/stylesheets/alchemy/toolbar.scss +84 -24
  53. data/app/assets/stylesheets/alchemy/upload.scss +14 -9
  54. data/app/assets/stylesheets/alchemy/variables.scss +1 -0
  55. data/app/assets/stylesheets/tiny_mce/plugins/inlinepopups/skins/alchemy/window.css.scss +18 -21
  56. data/app/controllers/alchemy/admin/attachments_controller.rb +29 -39
  57. data/app/controllers/alchemy/admin/base_controller.rb +3 -9
  58. data/app/controllers/alchemy/admin/clipboard_controller.rb +1 -1
  59. data/app/controllers/alchemy/admin/contents_controller.rb +1 -1
  60. data/app/controllers/alchemy/admin/dashboard_controller.rb +1 -1
  61. data/app/controllers/alchemy/admin/elements_controller.rb +3 -3
  62. data/app/controllers/alchemy/admin/essence_files_controller.rb +1 -1
  63. data/app/controllers/alchemy/admin/essence_pictures_controller.rb +5 -5
  64. data/app/controllers/alchemy/admin/languages_controller.rb +1 -1
  65. data/app/controllers/alchemy/admin/pages_controller.rb +18 -16
  66. data/app/controllers/alchemy/admin/pictures_controller.rb +11 -10
  67. data/app/controllers/alchemy/admin/resources_controller.rb +87 -14
  68. data/app/controllers/alchemy/admin/tags_controller.rb +3 -3
  69. data/app/controllers/alchemy/admin/trash_controller.rb +3 -3
  70. data/app/controllers/alchemy/admin/users_controller.rb +6 -11
  71. data/app/controllers/alchemy/attachments_controller.rb +8 -9
  72. data/app/controllers/alchemy/base_controller.rb +17 -10
  73. data/app/controllers/alchemy/pages_controller.rb +7 -19
  74. data/app/controllers/alchemy/passwords_controller.rb +15 -3
  75. data/app/controllers/alchemy/user_sessions_controller.rb +5 -4
  76. data/app/controllers/alchemy/users_controller.rb +1 -1
  77. data/app/helpers/alchemy/admin/attachments_helper.rb +2 -2
  78. data/app/helpers/alchemy/admin/base_helper.rb +62 -90
  79. data/app/helpers/alchemy/admin/elements_helper.rb +13 -5
  80. data/app/helpers/alchemy/admin/essences_helper.rb +3 -5
  81. data/app/helpers/alchemy/admin/pages_helper.rb +6 -3
  82. data/app/helpers/alchemy/admin/tags_helper.rb +60 -0
  83. data/app/helpers/alchemy/base_helper.rb +16 -20
  84. data/app/helpers/alchemy/elements_helper.rb +7 -11
  85. data/app/helpers/alchemy/essences_helper.rb +2 -2
  86. data/app/helpers/alchemy/pages_helper.rb +31 -69
  87. data/app/helpers/alchemy/url_helper.rb +11 -3
  88. data/app/models/alchemy/attachment.rb +73 -45
  89. data/app/models/alchemy/cell.rb +1 -1
  90. data/app/models/alchemy/content.rb +20 -9
  91. data/app/models/alchemy/element.rb +9 -7
  92. data/app/models/alchemy/page.rb +15 -248
  93. data/app/models/alchemy/page/cells.rb +71 -0
  94. data/app/models/alchemy/page/elements.rb +147 -0
  95. data/app/models/alchemy/page/naming.rb +90 -0
  96. data/app/models/alchemy/picture.rb +18 -13
  97. data/app/models/alchemy/tag.rb +1 -1
  98. data/app/models/alchemy/user.rb +38 -6
  99. data/app/views/alchemy/admin/attachments/_archive_overlay.html.erb +14 -7
  100. data/app/views/alchemy/admin/attachments/_attachment.html.erb +17 -12
  101. data/app/views/alchemy/admin/attachments/_file_to_assign.html.erb +3 -8
  102. data/app/views/alchemy/admin/attachments/_files_list.html.erb +20 -12
  103. data/app/views/alchemy/admin/attachments/_overlay_file_list.html.erb +11 -0
  104. data/app/views/alchemy/admin/attachments/_tag_list.html.erb +31 -0
  105. data/app/views/alchemy/admin/attachments/archive_overlay.js.erb +4 -0
  106. data/app/views/alchemy/admin/attachments/edit.html.erb +8 -7
  107. data/app/views/alchemy/admin/attachments/index.html.erb +19 -12
  108. data/app/views/alchemy/admin/attachments/new.html.erb +2 -2
  109. data/app/views/alchemy/admin/attachments/show.html.erb +3 -0
  110. data/app/views/alchemy/admin/contents/_missing.html.erb +4 -4
  111. data/app/views/alchemy/admin/contents/create.js.erb +1 -1
  112. data/app/views/alchemy/admin/contents/new.html.erb +6 -3
  113. data/app/views/alchemy/admin/dashboard/_locked_pages.html.erb +1 -1
  114. data/app/views/alchemy/admin/dashboard/_users.html.erb +1 -1
  115. data/app/views/alchemy/admin/dashboard/index.html.erb +3 -3
  116. data/app/views/alchemy/admin/dashboard/info.html.erb +16 -13
  117. data/app/views/alchemy/admin/elements/_add_picture.html.erb +1 -1
  118. data/app/views/alchemy/admin/elements/_element_foot.html.erb +4 -4
  119. data/app/views/alchemy/admin/elements/_element_head.html.erb +1 -7
  120. data/app/views/alchemy/admin/elements/_elements_select.html.erb +2 -2
  121. data/app/views/alchemy/admin/elements/_new_element_form.html.erb +4 -4
  122. data/app/views/alchemy/admin/elements/_picture_gallery_editor.html.erb +1 -1
  123. data/app/views/alchemy/admin/elements/create.js.erb +2 -2
  124. data/app/views/alchemy/admin/elements/fold.js.erb +3 -6
  125. data/app/views/alchemy/admin/elements/new.html.erb +1 -1
  126. data/app/views/alchemy/admin/elements/order.js.erb +1 -1
  127. data/app/views/alchemy/admin/elements/trash.js.erb +1 -1
  128. data/app/views/alchemy/admin/elements/update.js.erb +2 -2
  129. data/app/views/alchemy/admin/essence_files/edit.html.erb +4 -4
  130. data/app/views/alchemy/admin/essence_pictures/crop.html.erb +17 -18
  131. data/app/views/alchemy/admin/essence_pictures/edit.html.erb +2 -2
  132. data/app/views/alchemy/admin/essence_pictures/update.js.erb +1 -0
  133. data/app/views/alchemy/admin/languages/_form.html.erb +12 -10
  134. data/app/views/alchemy/admin/languages/_language.html.erb +2 -1
  135. data/app/views/alchemy/admin/languages/_table.html.erb +3 -3
  136. data/app/views/alchemy/admin/languages/index.html.erb +15 -15
  137. data/app/views/alchemy/admin/layoutpages/_layoutpage.html.erb +6 -6
  138. data/app/views/alchemy/admin/layoutpages/index.html.erb +41 -40
  139. data/app/views/alchemy/admin/pages/_contactform_links.html.erb +4 -4
  140. data/app/views/alchemy/admin/pages/_create_language_form.html.erb +6 -6
  141. data/app/views/alchemy/admin/pages/_external_link.html.erb +2 -2
  142. data/app/views/alchemy/admin/pages/_file_link.html.erb +3 -3
  143. data/app/views/alchemy/admin/pages/_internal_link.html.erb +1 -1
  144. data/app/views/alchemy/admin/pages/_new_page_form.html.erb +1 -1
  145. data/app/views/alchemy/admin/pages/_page.html.erb +13 -13
  146. data/app/views/alchemy/admin/pages/_page_for_links.html.erb +2 -4
  147. data/app/views/alchemy/admin/pages/_sitemap.html.erb +5 -0
  148. data/app/views/alchemy/admin/pages/configure.html.erb +7 -7
  149. data/app/views/alchemy/admin/pages/configure_external.html.erb +4 -4
  150. data/app/views/alchemy/admin/pages/edit.html.erb +23 -30
  151. data/app/views/alchemy/admin/pages/index.html.erb +34 -23
  152. data/app/views/alchemy/admin/pages/new.html.erb +1 -1
  153. data/app/views/alchemy/admin/pages/sort.js.erb +1 -1
  154. data/app/views/alchemy/admin/partials/_flash_upload.html.erb +2 -3
  155. data/app/views/alchemy/admin/partials/_remote_search_form.html.erb +2 -2
  156. data/app/views/alchemy/admin/partials/_search_form.html.erb +3 -3
  157. data/app/views/alchemy/admin/partials/_upload_form.html.erb +2 -2
  158. data/app/views/alchemy/admin/pictures/_archive.html.erb +7 -7
  159. data/app/views/alchemy/admin/pictures/_archive_overlay.html.erb +1 -1
  160. data/app/views/alchemy/admin/pictures/_filter_and_size_bar.html.erb +6 -6
  161. data/app/views/alchemy/admin/pictures/_filter_bar.html.erb +4 -4
  162. data/app/views/alchemy/admin/pictures/_overlay_picture_list.html.erb +1 -1
  163. data/app/views/alchemy/admin/pictures/_picture.html.erb +3 -8
  164. data/app/views/alchemy/admin/pictures/_picture_to_assign.html.erb +9 -14
  165. data/app/views/alchemy/admin/pictures/_tag_list.html.erb +27 -25
  166. data/app/views/alchemy/admin/pictures/archive_overlay.js.erb +3 -1
  167. data/app/views/alchemy/admin/pictures/index.html.erb +49 -42
  168. data/app/views/alchemy/admin/pictures/new.html.erb +2 -2
  169. data/app/views/alchemy/admin/pictures/show.html.erb +11 -0
  170. data/app/views/alchemy/admin/resources/_boolean.html.erb +2 -2
  171. data/app/views/alchemy/admin/resources/_datetime.html.erb +2 -2
  172. data/app/views/alchemy/admin/resources/_form.html.erb +9 -8
  173. data/app/views/alchemy/admin/resources/_resource.html.erb +15 -21
  174. data/app/views/alchemy/admin/resources/_string.html.erb +2 -2
  175. data/app/views/alchemy/admin/resources/_table.html.erb +11 -13
  176. data/app/views/alchemy/admin/resources/_text.html.erb +2 -2
  177. data/app/views/alchemy/admin/resources/index.csv.erb +13 -0
  178. data/app/views/alchemy/admin/resources/index.html.erb +24 -15
  179. data/app/views/alchemy/admin/sites/index.html.erb +23 -0
  180. data/app/views/alchemy/admin/tags/_radio_tag.html.erb +1 -1
  181. data/app/views/alchemy/admin/tags/_tag.html.erb +2 -1
  182. data/app/views/alchemy/admin/tags/edit.html.erb +1 -1
  183. data/app/views/alchemy/admin/tags/index.html.erb +16 -11
  184. data/app/views/alchemy/admin/tags/new.html.erb +3 -3
  185. data/app/views/alchemy/admin/trash/clear.js.coffee +1 -1
  186. data/app/views/alchemy/admin/users/_table.html.erb +12 -5
  187. data/app/views/alchemy/admin/users/_user.html.erb +16 -16
  188. data/app/views/alchemy/admin/users/index.html.erb +28 -16
  189. data/app/views/alchemy/breadcrumb/_page.html.erb +15 -0
  190. data/app/views/alchemy/breadcrumb/_spacer.html.erb +1 -0
  191. data/app/views/alchemy/elements/_editor_not_found.html.erb +1 -1
  192. data/app/views/alchemy/essences/_essence_file_editor.html.erb +16 -16
  193. data/app/views/alchemy/essences/_essence_file_view.html.erb +8 -9
  194. data/app/views/alchemy/essences/_essence_picture_editor.html.erb +3 -6
  195. data/app/views/alchemy/essences/_essence_picture_tools.html.erb +9 -8
  196. data/app/views/alchemy/essences/_essence_richtext_editor.html.erb +0 -5
  197. data/app/views/alchemy/essences/_linkable_essence_tools.html.erb +2 -2
  198. data/app/views/alchemy/navigation/_link.html.erb +7 -7
  199. data/app/views/alchemy/navigation/_renderer.html.erb +29 -36
  200. data/app/views/alchemy/notifications/admin_user_created.de.text.erb +5 -1
  201. data/app/views/alchemy/notifications/admin_user_created.en.text.erb +5 -1
  202. data/app/views/alchemy/notifications/registered_user_created.de.text.erb +13 -0
  203. data/app/views/alchemy/notifications/registered_user_created.en.text.erb +13 -0
  204. data/app/views/alchemy/search/_result.html.erb +4 -6
  205. data/app/views/alchemy/search/_results.html.erb +4 -5
  206. data/app/views/alchemy/user_sessions/leave.html.erb +1 -1
  207. data/app/views/alchemy/user_sessions/new.html.erb +2 -2
  208. data/app/views/kaminari/_first_page.html.erb +11 -0
  209. data/app/views/kaminari/_gap.html.erb +1 -1
  210. data/app/views/kaminari/_last_page.html.erb +11 -0
  211. data/app/views/kaminari/_next_page.html.erb +2 -2
  212. data/app/views/kaminari/_page.html.erb +1 -1
  213. data/app/views/kaminari/_paginator.html.erb +2 -0
  214. data/app/views/kaminari/_prev_page.html.erb +2 -2
  215. data/app/views/layouts/alchemy/admin.html.erb +4 -5
  216. data/config/alchemy/config.yml +8 -12
  217. data/config/authorization_rules.rb +4 -3
  218. data/config/initializers/dragonfly.rb +20 -12
  219. data/config/locales/alchemy.de.yml +20 -15
  220. data/config/locales/alchemy.en.yml +15 -10
  221. data/config/locales/devise.de.yml +1 -0
  222. data/config/routes.rb +3 -3
  223. data/{spec/dummy/db/migrate/20121118000000_alchemy_two_point_four.rb → db/migrate/20130214233001_alchemy_two_point_five.rb} +50 -36
  224. data/db/migrate/20130221200514_migrate_attachments_to_dragonfly.rb +21 -0
  225. data/db/migrate/20130312205327_change_alchemy_users_role_to_roles.rb +11 -0
  226. data/lib/alchemy/capistrano.rb +10 -8
  227. data/lib/alchemy/errors.rb +7 -0
  228. data/lib/alchemy/filetypes.rb +33 -0
  229. data/lib/alchemy/i18n.rb +9 -1
  230. data/lib/alchemy/name_conversions.rb +28 -0
  231. data/lib/alchemy/page_layout.rb +5 -3
  232. data/lib/alchemy/resource.rb +132 -29
  233. data/lib/alchemy/resources_helper.rb +81 -12
  234. data/lib/alchemy/upgrader.rb +14 -276
  235. data/lib/alchemy/version.rb +1 -1
  236. data/lib/alchemy_cms.rb +17 -2
  237. data/lib/rails/generators/alchemy/deploy_script/templates/deploy.rb.tt +1 -1
  238. data/lib/rails/generators/alchemy/scaffold/scaffold_generator.rb +1 -1
  239. data/lib/tasks/alchemy/convert.rake +39 -0
  240. data/lib/tasks/alchemy/install.rake +4 -6
  241. data/lib/tasks/alchemy/upgrade.rake +18 -1
  242. data/spec/controllers/admin/clipboard_controller_spec.rb +4 -4
  243. data/spec/controllers/admin/elements_controller_spec.rb +23 -23
  244. data/spec/controllers/admin/pages_controller_spec.rb +15 -0
  245. data/spec/controllers/admin/resources_controller_spec.rb +1 -11
  246. data/spec/controllers/admin/trash_controller_spec.rb +9 -9
  247. data/spec/controllers/attachments_controller_spec.rb +3 -3
  248. data/spec/controllers/elements_controller_spec.rb +2 -2
  249. data/spec/controllers/pages_controller_spec.rb +160 -129
  250. data/spec/controllers/pictures_controller_spec.rb +2 -2
  251. data/spec/controllers/user_sessions_controller_spec.rb +3 -3
  252. data/spec/controllers/users_controller_spec.rb +2 -2
  253. data/spec/dummy/app/models/event.rb +2 -2
  254. data/spec/dummy/app/models/location.rb +4 -0
  255. data/spec/dummy/app/views/layouts/application.html.erb +6 -42
  256. data/spec/dummy/config/routes.rb +1 -1
  257. data/spec/dummy/db/migrate/20121026104128_create_events.rb +0 -1
  258. data/{db/migrate/20121118000000_alchemy_two_point_four.rb → spec/dummy/db/migrate/20130214233001_alchemy_two_point_five.rb} +50 -36
  259. data/spec/dummy/db/migrate/20130221200514_migrate_attachments_to_dragonfly.rb +21 -0
  260. data/spec/dummy/db/migrate/20130312205327_change_alchemy_users_role_to_roles.rb +11 -0
  261. data/spec/dummy/db/migrate/20130328101418_create_locations.rb +9 -0
  262. data/spec/dummy/db/schema.rb +15 -6
  263. data/spec/factories.rb +4 -4
  264. data/spec/{integration → features}/admin/link_overlay_spec.rb +0 -0
  265. data/spec/{integration → features}/admin/modules_integration_spec.rb +1 -1
  266. data/spec/{integration → features}/admin/pages_controller_spec.rb +9 -4
  267. data/spec/{integration → features}/admin/picture_library_integration_spec.rb +5 -5
  268. data/spec/{integration → features}/admin/resources_integration_spec.rb +1 -1
  269. data/spec/{integration → features}/navigation_spec.rb +0 -0
  270. data/spec/{integration → features}/pages_controller_spec.rb +42 -112
  271. data/spec/{integration → features}/picture_security_spec.rb +2 -2
  272. data/spec/{integration → features}/security_spec.rb +7 -7
  273. data/spec/{integration → features}/translation_integration_spec.rb +0 -0
  274. data/spec/helpers/admin/base_helper_spec.rb +0 -50
  275. data/spec/helpers/admin/tags_helper_spec.rb +53 -0
  276. data/spec/helpers/base_helper_spec.rb +19 -3
  277. data/spec/helpers/pages_helper_spec.rb +92 -44
  278. data/spec/{url_helpers_spec.rb → helpers/picture_url_helpers_spec.rb} +7 -7
  279. data/spec/helpers/url_helper_spec.rb +92 -72
  280. data/spec/{config_spec.rb → libraries/config_spec.rb} +0 -0
  281. data/spec/libraries/resource_spec.rb +215 -76
  282. data/spec/libraries/resources_helper_spec.rb +70 -28
  283. data/spec/models/attachment_spec.rb +75 -9
  284. data/spec/models/clipboard_spec.rb +1 -1
  285. data/spec/models/element_spec.rb +7 -0
  286. data/spec/models/page_spec.rb +144 -25
  287. data/spec/models/picture_spec.rb +5 -5
  288. data/spec/models/resource_spec.rb +47 -10
  289. data/spec/models/user_spec.rb +115 -3
  290. data/spec/{routing_spec.rb → routing/routing_spec.rb} +8 -20
  291. data/spec/spec_helper.rb +5 -6
  292. data/spec/support/alchemy/specs_helpers.rb +1 -1
  293. data/spec/support/ci/install_phantomjs +1 -1
  294. data/spec/support/image with spaces.png +0 -0
  295. data/vendor/assets/javascripts/jquery_plugins/jquery.Jcrop.min.js +18 -18
  296. data/vendor/assets/javascripts/jquery_plugins/{jquery.dialogextend.1_0_1.js → jquery.dialogextend.js} +25 -17
  297. data/vendor/assets/javascripts/jquery_plugins/jquery.scrollTo.min.js +7 -0
  298. data/vendor/assets/javascripts/jquery_plugins/jquery.ui.tabspaging.js +7 -7
  299. data/vendor/assets/javascripts/keymage.min.js +6 -0
  300. data/vendor/assets/javascripts/spin.min.js +1 -0
  301. metadata +122 -124
  302. data/app/assets/images/alchemy/ajax_loader.gif +0 -0
  303. data/app/assets/images/alchemy/gui/toggle.png +0 -0
  304. data/app/assets/images/alchemy/image_loader.gif +0 -0
  305. data/app/assets/images/alchemy/shading.png +0 -0
  306. data/app/assets/images/alchemy/tabs.gif +0 -0
  307. data/app/assets/javascripts/alchemy/alchemy.base.js +0 -172
  308. data/app/assets/javascripts/alchemy/alchemy.datepicker.js +0 -47
  309. data/app/assets/javascripts/alchemy/alchemy.element_editor_selector.js +0 -91
  310. data/app/assets/javascripts/alchemy/alchemy.growler.js +0 -46
  311. data/app/assets/javascripts/alchemy/alchemy.image_cropper.js +0 -60
  312. data/app/assets/javascripts/alchemy/alchemy.js_extensions.js +0 -15
  313. data/app/assets/javascripts/alchemy/alchemy.preview_window.js +0 -97
  314. data/app/assets/javascripts/alchemy/alchemy.windows.js +0 -321
  315. data/app/models/alchemy/clipboard_spec.rb +0 -0
  316. data/app/views/alchemy/admin/pictures/show_in_window.html.erb +0 -8
  317. data/app/views/alchemy/notifications/registered_user_created.text.erb +0 -11
  318. data/db/migrate/20121121162313_switch_from_fleximage_to_dragonfly.rb +0 -21
  319. data/db/migrate/20121205155004_create_alchemy_sites.rb +0 -14
  320. data/db/migrate/20121211163003_add_public_to_alchemy_sites.rb +0 -6
  321. data/db/migrate/20121220102223_add_aliases_to_site.rb +0 -6
  322. data/db/migrate/20130110212411_create_alchemy_legacy_page_urls.rb +0 -11
  323. data/db/migrate/20130121092645_migrate_to_devise.rb +0 -24
  324. data/spec/alchemy_spec.rb +0 -7
  325. data/spec/dummy/db/migrate/20121121162313_switch_from_fleximage_to_dragonfly.rb +0 -21
  326. data/spec/dummy/db/migrate/20121205155004_create_alchemy_sites.rb +0 -14
  327. data/spec/dummy/db/migrate/20121211163003_add_public_to_alchemy_sites.rb +0 -6
  328. data/spec/dummy/db/migrate/20121220102223_add_aliases_to_site.rb +0 -6
  329. data/spec/dummy/db/migrate/20130110212411_create_alchemy_legacy_page_urls.rb +0 -11
  330. data/spec/dummy/db/migrate/20130121092645_migrate_to_devise.rb +0 -24
  331. data/vendor/assets/javascripts/jquery_plugins/jquery.scrollTo-1.4.2-min.js +0 -11
@@ -27,7 +27,7 @@ a {
27
27
  }
28
28
 
29
29
  &:focus {
30
- @include default-focus-style(rgba(white, 0.5), none);
30
+ @extend %white-focus-style;
31
31
  color: black;
32
32
  }
33
33
  }
@@ -67,7 +67,7 @@ input.invalid {
67
67
  }
68
68
 
69
69
  textarea {
70
- @include default-input-style;
70
+ @extend %default-input-style;
71
71
  margin: 0;
72
72
  resize: none;
73
73
  outline: none;
@@ -94,7 +94,7 @@ input.checkbox {
94
94
  /* Buttons */
95
95
 
96
96
  #insert, #cancel, input.button, .updateButton {
97
- @include default-button-style;
97
+ @extend %button-defaults;
98
98
  }
99
99
 
100
100
  /* Browse */
@@ -188,7 +188,6 @@ td.charmap, #charmap a {
188
188
 
189
189
  #codeN {
190
190
  font-size: 10px;
191
- font-family: "Lucida Grande", Arial, sans-serif;
192
191
  text-align: center
193
192
  }
194
193
 
@@ -216,7 +215,7 @@ td.charmap, #charmap a {
216
215
 
217
216
  .tabs {
218
217
  width: 100%;
219
- height: 18px;
218
+ height: 27px;
220
219
  line-height: normal;
221
220
  }
222
221
 
@@ -228,14 +227,14 @@ td.charmap, #charmap a {
228
227
 
229
228
  .tabs li {
230
229
  float: left;
231
- background: url('shading.png') repeat-x 0 0;
232
230
  margin: 0 2px 0 0;
233
- padding: 0 0 0 10px;
231
+ padding: 4px 12px;
234
232
  line-height: 17px;
235
233
  height: 18px;
236
234
  display: block;
237
235
  border: 1px solid #9a9a9a;
238
236
  border-bottom-style: none;
237
+ @extend .top-rounded-border;
239
238
  }
240
239
 
241
240
  .tabs li.current {
@@ -247,18 +246,15 @@ td.charmap, #charmap a {
247
246
  .tabs span {
248
247
  float: left;
249
248
  display: block;
250
- background: image-url('tiny_mce/themes/advanced/skins/default/img/tabs.gif') no-repeat right -36px;
251
- padding: 0px 10px 0 0;
249
+ padding: 0;
252
250
  }
253
251
 
254
252
  .tabs .current span {
255
- background: image-url('tiny_mce/themes/advanced/skins/default/img/tabs.gif') no-repeat right -54px;
253
+
256
254
  }
257
255
 
258
256
  .tabs a {
259
257
  text-decoration: none;
260
- font-family: "Lucida Grande", Arial, sans-serif;
261
- font-size: 10px;
262
258
  }
263
259
 
264
260
  .tabs a:link, .tabs a:visited, .tabs a:hover {
@@ -274,11 +270,11 @@ td.charmap, #charmap a {
274
270
  .panel_wrapper div.current {
275
271
  display: block;
276
272
  width: 100%;
277
- height: 300px;
273
+ height: 287px;
278
274
  overflow: visible;
279
275
  }
280
276
 
281
- div#general_panel { height: 245px }
277
+ div#general_panel { height: 287px }
282
278
 
283
279
  div#advanced_panel { height: 300px }
284
280
 
@@ -324,7 +320,7 @@ h3 {
324
320
 
325
321
  .title {
326
322
  font-size: 12px;
327
- font-weight: bold;
323
+ font-weight: normal;
328
324
  color: $text-color;
329
325
  }
330
326
 
@@ -413,6 +409,12 @@ h3 {
413
409
  }
414
410
 
415
411
  #iframecontainer iframe#iframe {
416
- @include default-input-style;
412
+ @extend %default-input-style;
417
413
  padding: 0;
418
414
  }
415
+
416
+ #htmlSource {
417
+ margin-top: 1em;
418
+ height: 496px !important;
419
+ margin-bottom: 4px;
420
+ }
@@ -2,25 +2,18 @@
2
2
  z-index: 10;
3
3
  padding: 4px;
4
4
  height: 44px;
5
- background: $medium-gray url('shading.png') repeat-x 0 -40px;
5
+ @extend %gradiated-toolbar;
6
6
  margin-right: 0px;
7
7
  border: $default-border;
8
8
  border-top-style: none;
9
9
  border-right-style: none;
10
- @include bottom-left-rounded-border;
10
+ @extend .bottom-left-rounded-border;
11
11
  position: relative;
12
12
  margin-left: 5px;
13
13
 
14
- form {
15
- margin: 0 8px;
16
- float: right;
17
- text-align: center;
18
- }
19
-
20
14
  div.button_with_label {
21
15
 
22
16
  form {
23
- float: none;
24
17
  margin: 0;
25
18
  @include inline-block;
26
19
  line-height: 5px;
@@ -39,16 +32,75 @@
39
32
  padding: 0;
40
33
  }
41
34
 
42
- div.toolbar_spacer {
43
- float: left;
44
- width: 1px;
45
- height: 37px;
46
- border-right-style: dotted;
47
- border-right-width: 1px;
35
+ a.button {
36
+ width: 25px;
37
+ height: 21px;
38
+ text-decoration: none;
39
+ float: right;
40
+ border-width: 0;
41
+ border-style: none;
42
+ font-size: 0;
43
+ padding: 0;
44
+ background-repeat: no-repeat;
45
+ background-position: 0 0;
46
+
47
+ &:active {
48
+ text-decoration: none;
49
+ background-position: 0 -21px;
50
+ }
51
+ }
52
+
53
+ .js_filter_field {
54
+ @include border-radius(15px);
55
+ }
56
+
57
+ .js_filter_field_box {
48
58
  margin-right: 2*$default-margin;
49
- margin-left: $default-margin;
59
+
60
+ label {
61
+ margin: 0;
62
+ }
50
63
  }
51
64
 
65
+ .search_form {
66
+ position: absolute;
67
+ top: 4px;
68
+ right: 8px;
69
+ text-align: center;
70
+ }
71
+ }
72
+
73
+ .toolbar_buttons {
74
+ margin-right: 8px;
75
+ white-space: nowrap;
76
+
77
+ &.right {
78
+ position: absolute;
79
+ right: 8px;
80
+ top: 4px;
81
+ margin-left: 8px;
82
+ }
83
+ }
84
+
85
+ .toolbar_spacer {
86
+ @include inline-block;
87
+ width: 1px;
88
+ height: 37px;
89
+ border-right-style: dotted;
90
+ border-right-width: 1px;
91
+ margin-right: 2*$default-margin;
92
+ margin-left: $default-margin;
93
+ }
94
+
95
+ #overlay_toolbar {
96
+ @extend %gradiated-toolbar;
97
+ border: $default-border;
98
+ height: 44px;
99
+ border-top-style: none;
100
+ border-left-style: none;
101
+ border-right-style: none;
102
+ padding: $default-padding;
103
+
52
104
  a.button {
53
105
  width: 25px;
54
106
  height: 21px;
@@ -66,14 +118,22 @@
66
118
  background-position: 0 -21px;
67
119
  }
68
120
  }
69
- }
70
121
 
71
- div#toolbar_buttons {
72
- float: left;
73
- margin-right: 6px;
74
- }
122
+ .search_field {
123
+ width: 225px;
124
+ }
125
+
126
+ form {
127
+ float: right;
128
+ width: 310px;
129
+ margin-top: 2px;
130
+ padding: 0 !important;
131
+ margin-right: 0;
75
132
 
76
- div#toolbar_buttons_right {
77
- float: right;
78
- margin-left: 8px;
133
+ .button {
134
+ position: absolute;
135
+ top: 2px;
136
+ right: 4px;
137
+ }
138
+ }
79
139
  }
@@ -14,7 +14,7 @@ a#uploadswitcher, a.underline {
14
14
  position: relative;
15
15
  margin-bottom: 8px;
16
16
  border: 1px solid #9e9e9e;
17
- @include rounded-corner;
17
+ @extend .rounded-border;
18
18
  }
19
19
 
20
20
  #uploadProgressContainer .progressName,
@@ -31,34 +31,39 @@ a#uploadswitcher, a.underline {
31
31
  }
32
32
 
33
33
  #uploadProgressContainer .progressBarContainer {
34
- background: #F9F9F9 url('shading.png') repeat-x 0 0;
34
+ background-color: #F9F9F9;
35
+ @include background-image(linear-gradient(top, darken($medium-gray, 10) 5%, $light-gray 35%, lighten($light-gray, 10) 90%));
35
36
  border: 1px solid #9E9E9E;
36
- @include rounded-corner;
37
+ @extend .rounded-border;
37
38
  height: 16px;
38
39
  overflow: hidden;
39
40
  width: 100%;
40
41
  }
41
42
 
42
43
  #uploadProgressContainer .progressBarInProgress {
43
- background: #77AAD5 url('shading.png') repeat-x 0 -75px;
44
+ background-color: #77AAD5;
45
+ @extend %progressbar;
44
46
  height: 16px;
45
47
  width: 0;
46
48
  }
47
49
 
48
50
  #uploadProgressContainer .progressBarComplete {
49
- background: #00D827 url('shading.png') repeat-x 0 -75px;
51
+ background-color: #00D827;
52
+ @extend %progressbar;
50
53
  height: 16px;
51
54
  width: 0;
52
55
  }
53
56
 
54
57
  #uploadProgressContainer .progressBarError {
55
- background: #F00 url('shading.png') repeat-x 0 -75px;
58
+ background-color: #F00;
59
+ @extend %progressbar;
56
60
  height: 16px;
57
61
  width: 0;
58
62
  }
59
63
 
60
64
  #uploadProgressContainer .progressBarCanceled {
61
- background: #E4E4E4 url('shading.png') repeat-x 0 -75px;
65
+ background-color: #E4E4E4;
66
+ @extend %progressbar;
62
67
  height: 16px;
63
68
  width: 0;
64
69
  }
@@ -66,7 +71,7 @@ a#uploadswitcher, a.underline {
66
71
  #uploadProgressContainer .progressCancel {
67
72
  background: #f1f1f1 url('icons.png') no-repeat -1px -72px;
68
73
  border: 1px solid #9e9e9e;
69
- @include rounded-corner;
74
+ @extend .rounded-border;
70
75
  width: 15px;
71
76
  height: 16px;
72
77
  position: absolute;
@@ -92,7 +97,7 @@ object.swfupload {
92
97
  #dropbox {
93
98
  background: $medium-gray;
94
99
  border: $default-border;
95
- @include rounded-corner;
100
+ @extend .rounded-border;
96
101
  padding: $default-padding;
97
102
  margin-bottom: 2*$default-padding;
98
103
  text-align: center;
@@ -6,6 +6,7 @@ $light-gray: #EDEDED;
6
6
  $medium-gray: #E3E3E3;
7
7
  $dark-gray: #666666;
8
8
  $light_yellow: #ffffdc;
9
+ $linked-color: #ffd77a;
9
10
 
10
11
  $default-padding: 4px;
11
12
  $default-margin: $default-padding;
@@ -26,7 +26,7 @@
26
26
  position: absolute;
27
27
  direction: ltr;
28
28
  border: $default-border;
29
- @include rounded-corner;
29
+ @extend .rounded-border;
30
30
  }
31
31
 
32
32
  .alchemy .mceWrapper {
@@ -199,12 +199,13 @@ a.mceMove {
199
199
  }
200
200
 
201
201
  .alchemy .mceClose {
202
- right: 8px;
203
- background: image-url("alchemy/ui-icons_666666_256x240.png") -96px -128px;
202
+ @extend .icon-cancel;
204
203
  width: 16px;
205
204
  height: 16px;
206
- top: 6px;
207
-
205
+ top: 7px;
206
+ right: 8px;
207
+ text-align: center;
208
+ &:before { font-size: 16px }
208
209
  }
209
210
 
210
211
  .alchemy .mceMin {
@@ -217,8 +218,9 @@ a.mceMove {
217
218
  right: 28px;
218
219
  width: 16px;
219
220
  height: 16px;
220
- background: image-url("alchemy/ui-icons_666666_256x240.png") -49px -80px;
221
+ @extend .icon-exit-fullscreen;
221
222
  top: 6px;
223
+ padding-top: 3px;
222
224
  }
223
225
 
224
226
  .alchemy .mceMax {
@@ -226,14 +228,16 @@ a.mceMove {
226
228
  right: 28px;
227
229
  width: 16px;
228
230
  height: 16px;
229
- background: image-url("alchemy/ui-icons_666666_256x240.png") -32px -80px;
231
+ @extend .icon-fullscreen;
230
232
  top: 6px;
233
+ padding-top: 3px;
231
234
  }
232
235
 
233
236
  .alchemy .mceClose, .alchemy .mceMin, .alchemy .mceMed, .alchemy .mceMax {
237
+
234
238
  &:hover {
235
239
  border: 1px solid $button-hover-border-color;
236
- @include rounded-corner;
240
+ @extend .rounded-border;
237
241
  background-color: $button-hover-bg-color;
238
242
  color: $text-color;
239
243
  font-weight: normal;
@@ -242,22 +246,15 @@ a.mceMove {
242
246
 
243
247
  .alchemy .mceClose {
244
248
  &:hover {
245
- background-position: -97px -129px;
246
- right: 6px;
249
+ top: 6px;
250
+ right: 7px;
247
251
  }
248
252
  }
249
253
 
250
- .alchemy .mceMax {
251
- &:hover {
252
- background-position: -33px -81px;
253
- right: 26px;
254
- }
255
- }
256
-
257
- .alchemy .mceMed {
254
+ .alchemy .mceMax, .alchemy .mceMed {
258
255
  &:hover {
259
- background-position: -50px -81px;
260
- right: 26px;
256
+ top: 5px;
257
+ right: 27px;
261
258
  }
262
259
  }
263
260
 
@@ -370,7 +367,7 @@ a.mceMove {
370
367
  /* Alert/Confirm */
371
368
 
372
369
  .alchemy .mceButton {
373
- @include default-button-style;
370
+ @extend %button-defaults;
374
371
  bottom: 10px;
375
372
  // width: 80px;
376
373
  // height: 25px;
@@ -1,14 +1,18 @@
1
1
  module Alchemy
2
2
  module Admin
3
- class AttachmentsController < Alchemy::Admin::BaseController
3
+ class AttachmentsController < ResourcesController
4
+ helper 'alchemy/admin/tags'
4
5
 
5
6
  protect_from_forgery :except => [:create]
6
7
 
7
8
  def index
9
+ @attachments = Attachment.scoped
10
+ @attachments = @attachments.tagged_with(params[:tagged_with]) if params[:tagged_with].present?
11
+ @attachments = @attachments.find_paginated(params, 15, sort_order)
8
12
  if in_overlay?
9
13
  archive_overlay
10
14
  else
11
- @attachments = Attachment.find_paginated(params, per_page_value_for_screen_size)
15
+ # render index.html.erb
12
16
  end
13
17
  end
14
18
 
@@ -24,17 +28,14 @@ module Alchemy
24
28
  end
25
29
 
26
30
  def create
27
- @attachment = Attachment.create(
28
- :uploaded_data => params[:Filedata],
29
- :name => params[:Filedata].original_filename
30
- )
31
+ @attachment = Attachment.create!(:file => params[:Filedata])
31
32
  if in_overlay?
32
33
  @while_assigning = true
33
34
  @content = Content.find(params[:content_id], :select => 'id') if !params[:content_id].blank?
34
35
  @swap = params[:swap]
35
36
  @options = hashified_options
36
37
  end
37
- @attachments = Attachment.find_paginated(params, per_page_value_for_screen_size)
38
+ @attachments = Attachment.find_paginated(params, per_page_value_for_screen_size, sort_order)
38
39
  @message = _t('File %{name} uploaded succesfully', :name => @attachment.name)
39
40
  # Are we using the Flash uploader? Or the plain html file uploader?
40
41
  if params[Rails.application.config.session_options[:key]].blank?
@@ -45,18 +46,18 @@ module Alchemy
45
46
 
46
47
  def edit
47
48
  @attachment = Attachment.find(params[:id])
48
- render :layout => false
49
+ render layout: !request.xhr?
49
50
  end
50
51
 
51
52
  def update
52
53
  @attachment = Attachment.find(params[:id])
53
54
  oldname = @attachment.name
54
- if @attachment.update_attributes(params[:attachment])
55
- flash[:notice] = _t("File renamed successfully from: '%{from}' to '%{to}'", :from => oldname, :to => @attachment.name)
56
- else
57
- render :action => "edit"
58
- end
59
- redirect_to admin_attachments_path(:page => params[:page], :query => params[:query], :per_page => params[:per_page])
55
+ @attachment.update_attributes(params[:attachment])
56
+ render_errors_or_redirect(
57
+ @attachment,
58
+ admin_attachments_path(:page => params[:page], :query => params[:query], :per_page => params[:per_page]),
59
+ _t("File successfully updated")
60
+ )
60
61
  end
61
62
 
62
63
  def destroy
@@ -68,23 +69,15 @@ module Alchemy
68
69
 
69
70
  def show
70
71
  @attachment = Attachment.find(params[:id])
71
- send_file(
72
- @attachment.public_filename,
73
- {
74
- :name => @attachment.filename,
75
- :type => @attachment.content_type,
76
- :disposition => 'inline'
77
- }
78
- )
72
+ render layout: !request.xhr?
79
73
  end
80
74
 
81
75
  def download
82
76
  @attachment = Attachment.find(params[:id])
83
- send_file(
84
- @attachment.full_filename, {
85
- :name => @attachment.filename,
86
- :type => @attachment.content_type,
87
- :disposition => 'attachment'
77
+ send_data(
78
+ @attachment.file.data, {
79
+ :filename => @attachment.file_name,
80
+ :type => @attachment.file_mime_type
88
81
  }
89
82
  )
90
83
  end
@@ -92,22 +85,19 @@ module Alchemy
92
85
  private
93
86
 
94
87
  def in_overlay?
95
- !params[:content_id].blank?
88
+ params[:content_id].present?
96
89
  end
97
90
 
98
91
  def archive_overlay
99
- @content = Content.find(params[:content_id])
100
- @options = params[:options]
101
- if !params[:only].blank?
102
- condition = "filename LIKE '%.#{params[:only].join("' OR filename LIKE '%.")}'"
103
- elsif !params[:except].blank?
104
- condition = "filename NOT LIKE '%.#{params[:except].join("' OR filename NOT LIKE '%.")}'"
105
- else
106
- condition = ""
107
- end
108
- @attachments = Attachment.where(condition).order(:name)
92
+ @content = Content.find(params[:content_id], select: 'id')
93
+ @options = hashified_options
109
94
  respond_to do |format|
110
- format.html { render :partial => 'archive_overlay' }
95
+ format.html {
96
+ render partial: 'archive_overlay'
97
+ }
98
+ format.js {
99
+ render action: 'archive_overlay'
100
+ }
111
101
  end
112
102
  end
113
103