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
@@ -9,17 +9,24 @@
9
9
  :options => @options
10
10
  ),
11
11
  {
12
- :title => _t('upload_file'),
12
+ :title => _t(:upload_file),
13
13
  :size => '540x550'
14
14
  },
15
- :title => _t('upload_file'),
15
+ :title => _t(:upload_file),
16
16
  :class => 'icon_button'
17
17
  ) %>
18
- <label><%= _t('upload_file') %></label>
18
+ <label><%= _t(:upload_file) %></label>
19
+ </div>
20
+ <%= render 'alchemy/admin/partials/remote_search_form' %>
21
+ </div>
22
+ <div id="assign_file_list" class="with_padding<%= params[:tagged_with].present? ? ' filtered' : '' %>">
23
+ <div id="library_sidebar">
24
+ <div id="tag_list">
25
+ <%= render 'tag_list' %>
26
+ </div>
27
+ </div>
28
+ <div id="overlay_file_list">
29
+ <%= render 'overlay_file_list' %>
19
30
  </div>
20
- <%= js_filter_field(:onkeyup => "Alchemy.ListFilter('.assign_file_file')") %>
21
31
  </div>
22
- <ul id="assign_file_list" class="with_padding">
23
- <%= render :partial => 'file_to_assign', :collection => @attachments %>
24
- </ul>
25
32
  </div>
@@ -3,34 +3,39 @@
3
3
  <%= render_icon attachment.icon_css_class %>
4
4
  </td>
5
5
  <td class="name">
6
- <% if permitted_to?(:show, :attachments) %>
7
- <%= link_to(
6
+ <% if permitted_to?(:show, :alchemy_attachments) && %w(audio image video flash pdf text).include?(attachment.icon_css_class) %>
7
+ <%= link_to_overlay_window(
8
8
  attachment.name,
9
9
  alchemy.admin_attachment_path(attachment),
10
- :target => '_blank',
11
- :title => _t('View File')
10
+ {
11
+ :title => attachment.name,
12
+ :size => "fullscreen"
13
+ },
14
+ {
15
+ :title => _t('View File')
16
+ }
12
17
  ) %>
13
18
  <% else %>
14
19
  <%= attachment.name %>
15
20
  <% end %>
16
21
  </td>
17
- <td class="file_name"><%= attachment.filename %></td>
18
- <td class="file_type"><%= mime_to_human(attachment.content_type) %></td>
19
- <td class="file_size"><%= number_to_human_size(attachment.size) %></td>
22
+ <td class="file_name"><%= attachment.file_name %></td>
23
+ <td class="file_type"><%= mime_to_human(attachment.file_mime_type) %></td>
24
+ <td class="file_size"><%= number_to_human_size(attachment.file_size) %></td>
20
25
  <td class="date"><%= l(attachment.created_at, :format => :short) %></td>
21
26
  <td class="tools long">
22
27
  <% permitted_to?(:download, :alchemy_attachments) do %>
23
28
  <%= link_to(
24
29
  "",
25
30
  alchemy.download_admin_attachment_path(attachment),
26
- :title => _t("download_file", :filename => attachment.filename),
31
+ :title => _t("download_file", :filename => attachment.file_name),
27
32
  :class => "icon file_download"
28
33
  ) %>
29
34
  <% end %>
30
35
  <% permitted_to?(:destroy, :alchemy_admin_attachments) do %>
31
36
  <%= link_to_confirmation_window(
32
37
  "",
33
- _t("confirm_to_delete_file"),
38
+ _t(:confirm_to_delete_file),
34
39
  alchemy.admin_attachment_path(
35
40
  :id => attachment,
36
41
  :query => params[:query],
@@ -39,7 +44,7 @@
39
44
  ),
40
45
  {
41
46
  :class => 'icon file_delete',
42
- :title => _t('delete_file')
47
+ :title => _t(:delete_file)
43
48
  }
44
49
  ) %>
45
50
  <% end %>
@@ -47,11 +52,11 @@
47
52
  <%= link_to_overlay_window("",
48
53
  alchemy.edit_admin_attachment_path(attachment, :query => params[:query], :page => params[:page]),
49
54
  {
50
- :title => _t('rename_file'),
55
+ :title => _t(:rename_file),
51
56
  :size => '380x220'
52
57
  },
53
58
  :class => 'icon file_edit',
54
- :title => _t('rename_file')
59
+ :title => _t(:rename_file)
55
60
  ) %>
56
61
  <% end %>
57
62
  </td>
@@ -1,11 +1,6 @@
1
- <%-
2
- prefix = "<div class=\"assign_file_file_icon\">"
3
- suffix = "</div><div class=\"assign_file_file_name\">#{file_to_assign.filename}</div>"
4
- -%>
5
- <%- img_tag = "#{prefix}#{render_icon(file_to_assign.icon_css_class)}#{suffix}".html_safe -%>
6
- <li class="assign_file_file <%= cycle('even', 'odd') %>" name="<%= file_to_assign.filename %>">
1
+ <li class="assign_file_file <%= cycle('even', 'odd') %>">
7
2
  <%= link_to(
8
- img_tag,
3
+ render_icon(file_to_assign.icon_css_class) + file_to_assign.name,
9
4
  {
10
5
  :controller => :essence_files,
11
6
  :action => :assign,
@@ -15,6 +10,6 @@
15
10
  },
16
11
  :remote => true,
17
12
  :method => 'put',
18
- :title => file_to_assign.filename
13
+ :title => file_to_assign.name
19
14
  ) %>
20
15
  </li>
@@ -1,26 +1,34 @@
1
- <%- if @attachments.blank? && params[:query].nil? -%>
1
+ <% if @attachments.blank? && params[:query].nil? %>
2
2
  <div class="info" id="no_files_notice">
3
3
  <%= render_icon('info') %>
4
- <%= _t("no_files_in_archive") %>
4
+ <%= _t(:no_files_in_archive) %>
5
5
  </div>
6
- <%- elsif @attachments.blank? -%>
6
+ <% elsif @attachments.blank? %>
7
7
  <div class="info">
8
8
  <%= render_icon('info') %>
9
- <%= _t("no_search_results") %>
9
+ <%= _t(:no_search_results) %>
10
10
  </div>
11
- <%- end -%>
11
+ <% end %>
12
12
  <table id="all_files" class="list">
13
- <%- unless @attachments.blank? -%>
13
+ <% unless @attachments.blank? %>
14
14
  <tr>
15
15
  <th class="icon"></th>
16
- <th class="name"><%= Alchemy::Attachment.human_attribute_name('name') %></th>
17
- <th class="file_name"><%= Alchemy::Attachment.human_attribute_name('filename') %></th>
18
- <th class="file_type"><%= Alchemy::Attachment.human_attribute_name('content_type') %></th>
19
- <th class="file_size"><%= Alchemy::Attachment.human_attribute_name('size') %></th>
20
- <th class="date"><%= Alchemy::Attachment.human_attribute_name('created_at') %></th>
16
+ <th class="name">
17
+ <%= sortable_column(Alchemy::Attachment.human_attribute_name('name'), :column => :name) %>
18
+ </th>
19
+ <th class="file_name">
20
+ <%= sortable_column(Alchemy::Attachment.human_attribute_name('file_name'), :column => :file_name) %>
21
+ </th>
22
+ <th class="file_type"><%= Alchemy::Attachment.human_attribute_name('file_mime_type') %></th>
23
+ <th class="file_size">
24
+ <%= sortable_column(Alchemy::Attachment.human_attribute_name('file_size'), :column => :file_size) %>
25
+ </th>
26
+ <th class="date">
27
+ <%= sortable_column(Alchemy::Attachment.human_attribute_name('created_at'), :column => :created_at) %>
28
+ </th>
21
29
  <th class="tools"></th>
22
30
  </tr>
23
- <%- end -%>
31
+ <% end %>
24
32
  <%= render :partial => 'alchemy/admin/attachments/attachment', :collection => @attachments %>
25
33
  </table>
26
34
 
@@ -0,0 +1,11 @@
1
+ <% if @attachments.empty? %>
2
+ <div class="info">
3
+ <%= render_icon('info') %>
4
+ <%= _t(:no_files_in_archive) %>
5
+ </div>
6
+ <% else %>
7
+ <ul class="with_padding">
8
+ <%= render :partial => 'file_to_assign', :collection => @attachments %>
9
+ </ul>
10
+ <%= paginate @attachments, :remote => true %>
11
+ <% end %>
@@ -0,0 +1,31 @@
1
+ <% p = params.dup %>
2
+ <% if Alchemy::Attachment.tag_counts.any? %>
3
+ <h2><%= _t("Filter by tag") %></h2>
4
+ <%= js_filter_field '#tag_list li' %>
5
+ <ul>
6
+ <% Alchemy::Attachment.tag_counts.each do |t| %>
7
+ <% attachment_tags = filtered_by_tag?(t) ? tag_filter(remove: t) : tag_filter(add: t) %>
8
+ <%= content_tag 'li', name: t.name, class: p[:tagged_with].try(:split, ',').try(:include?, t.name) ? 'active' : nil do %>
9
+ <%= link_to(
10
+ "#{t.name} (#{t.count})",
11
+ url_for(
12
+ p.delete_if { |k, v| k == "page" }.merge(
13
+ action: 'index',
14
+ tagged_with: attachment_tags
15
+ )
16
+ ),
17
+ remote: request.xhr?,
18
+ class: 'please_wait'
19
+ ) %>
20
+ <% end %>
21
+ <% end %>
22
+ </ul>
23
+ <% if p[:tagged_with].present? %>
24
+ <%= link_to(
25
+ render_icon('delete-small') + _t('Remove tag filter'),
26
+ url_for(p.delete_if { |k, v| k == "tagged_with" }.merge(action: 'index')),
27
+ remote: request.xhr?,
28
+ class: 'button small with_icon please_wait'
29
+ ) %>
30
+ <% end %>
31
+ <% end %>
@@ -0,0 +1,4 @@
1
+ jQuery('#alchemy_window_body').replaceWith('<%= escape_javascript(render(:partial => "archive_overlay")) %>');
2
+ Alchemy.SelectBox('#filter_bar');
3
+ Alchemy.overlayObserver('#alchemy_window_body');
4
+ Alchemy.ListFilter('#alchemy_window_body');
@@ -1,25 +1,26 @@
1
- <%= form_for([:admin, @attachment], :url => {:action => :update, :query => params[:query], :page => params[:page]}) do |f| -%>
1
+ <%= form_for([:admin, @attachment], :url => {:action => :update, :query => params[:query], :page => params[:page]}, :remote => true) do |f| -%>
2
+ <div id="errors"></div>
2
3
  <table>
3
4
  <tr>
4
- <td class="label"><%= f.label 'name' %></td>
5
- <td class="input"><%= f.text_field 'name', :class => 'thin_border long', :autofocus => true %></td>
5
+ <td class="label"><%= f.label :name %></td>
6
+ <td class="input"><%= f.text_field :name, :class => 'thin_border long', :autofocus => true %></td>
6
7
  </tr>
7
8
  <tr>
8
- <td class="label"><%= f.label 'filename' %>*</td>
9
+ <td class="label"><%= f.label :file_name %>*</td>
9
10
  <td class="input">
10
- <%= f.text_field 'filename', :class => 'thin_border long' %>
11
+ <%= f.text_field :file_name, :class => 'thin_border long' %>
11
12
  <p class="foot_note"><%= _t(:attachment_filename_notice) %></p>
12
13
  </td>
13
14
  </tr>
14
15
  <tr>
15
- <td class="label"><%= f.label 'tag_list' %></td>
16
+ <td class="label"><%= f.label :tag_list %></td>
16
17
  <td class="input">
17
18
  <%= render 'alchemy/admin/partials/autocomplete_tag_list', :object => @attachment, :f => f %>
18
19
  </td>
19
20
  </tr>
20
21
  <tr>
21
22
  <td colspan="2" class="submit">
22
- <%= f.button _t('save'), :class => 'button' %>
23
+ <%= f.button _t(:save), :class => 'button' %>
23
24
  </td>
24
25
  </tr>
25
26
  </table>
@@ -1,19 +1,26 @@
1
1
  <%= toolbar(
2
- :buttons => [
2
+ buttons: [
3
3
  {
4
- :icon => 'upload',
5
- :url => alchemy.new_admin_attachment_path,
6
- :overlay_options => {
7
- :title => _t('upload_file'),
8
- :size => '540x550'
4
+ icon: 'upload',
5
+ url: alchemy.new_admin_attachment_path,
6
+ hotkey: 'alt-n',
7
+ overlay_options: {
8
+ title: _t(:upload_file),
9
+ size: '540x550'
9
10
  },
10
- :title => _t('upload_file'),
11
- :class => 'icon_button',
12
- :label => _t('upload_file'),
13
- :if_permitted_to => [:new, :alchemy_admin_attachments]
11
+ title: _t(:upload_file),
12
+ class: 'icon_button',
13
+ label: _t(:upload_file),
14
+ if_permitted_to: [:new, :alchemy_admin_attachments]
14
15
  }
15
16
  ]
16
17
  ) %>
17
- <div id="archive_all">
18
- <%= render :partial => 'files_list' %>
18
+ <div id="archive_all" class="with_tag_filter">
19
+ <%= resources_header %>
20
+ <%= render partial: 'files_list' %>
21
+ <div id="library_sidebar">
22
+ <div id="tag_list" class="<%= params[:tagged_with].present? ? 'filtered' : '' %>">
23
+ <%= render partial: 'tag_list' %>
24
+ </div>
25
+ </div>
19
26
  </div>
@@ -3,9 +3,9 @@
3
3
  :partial => "alchemy/admin/partials/upload_form",
4
4
  :locals => {
5
5
  :file_types => configuration(:uploader)['allowed_filetypes']['attachments'],
6
- :file_types_description => _t('documents'),
6
+ :file_types_description => _t(:documents),
7
7
  :model_name => 'attachment',
8
- :item_type => _t('files')
8
+ :item_type => _t(:files)
9
9
  }
10
10
  ) %>
11
11
  <% end %>
@@ -0,0 +1,3 @@
1
+ <iframe src="<%= alchemy.show_attachment_path(@attachment) %>" frameborder=0 style="width: 100%; min-height: 90%">
2
+ Your browser does not support frames.
3
+ </iframe>
@@ -1,17 +1,17 @@
1
1
  <div class="content_editor missing" id="element_<%= element.id %>_content_missing">
2
- <label><%= Alchemy::I18n.t("content_names.#{element.name}.#{name}", :default => ["content_names.#{name}".to_sym, name.capitalize]) %></label>
2
+ <label><%= Alchemy::Content.translated_label_for(name, element.name) %></label>
3
3
  <p>
4
4
  <%= render_icon('warning') %>
5
- <%= _t('content_not_found') %>
5
+ <%= _t(:content_not_found) %>
6
6
  <%= link_to(
7
- _t('create'),
7
+ _t(:create),
8
8
  alchemy.admin_contents_path(
9
9
  :content => {
10
10
  :element_id => element.id,
11
11
  :name => name
12
12
  },
13
13
  :was_missing => true,
14
- :options => options
14
+ :options => options.to_json
15
15
  ),
16
16
  :method => 'post',
17
17
  :remote => true,
@@ -40,7 +40,7 @@
40
40
 
41
41
  <% elsif @content.essence_type == "Alchemy::EssenceDate" %>
42
42
 
43
- Alchemy.Datepicker('#element_<%= @element.id %> input.date');
43
+ Alchemy.Datepicker('#element_<%= @element.id %>');
44
44
 
45
45
  <% elsif @content.essence_type == "Alchemy::EssenceRichtext" %>
46
46
 
@@ -3,10 +3,13 @@
3
3
  <%= f.hidden_field :element_id %>
4
4
  <table>
5
5
  <tr>
6
- <td class="label"><%= f.label :name, _t('name') %></td>
6
+ <td class="label"><%= f.label :name %></td>
7
7
  <td class="select">
8
- <%= f.select('name', @contents.map { |a|
9
- [_t("content_names.#{a['name']}"), a['name']]
8
+ <%= f.select('name', @contents.map { |content|
9
+ [
10
+ _t(content['name'], scope: 'content_names', default: content['name'].humanize),
11
+ content['name']
12
+ ]
10
13
  }, {}, {:class => 'alchemy_selectbox'}) %>
11
14
  </td>
12
15
  </tr>
@@ -17,7 +17,7 @@
17
17
  </td>
18
18
  <td>
19
19
  <%= form_tag(alchemy.unlock_admin_page_path(page, :redirect_to => alchemy.admin_dashboard_url)) do %>
20
- <button class="icon_button small" title="<%= _t('explain_unlocking') %>">
20
+ <button class="icon_button small" title="<%= _t(:explain_unlocking) %>">
21
21
  <%= render_icon('close small') %>
22
22
  </button>
23
23
  <% end %>
@@ -10,7 +10,7 @@
10
10
  <tr class="<%= cycle('even', 'odd') %>">
11
11
  <td><%= user.name %></td>
12
12
  <td>
13
- <small><%= user.human_role_name %></small>
13
+ <small><%= user.human_roles_string %></small>
14
14
  </td>
15
15
  </tr>
16
16
  <% end %>
@@ -2,11 +2,11 @@
2
2
  :buttons => [
3
3
  {
4
4
  :icon => 'info',
5
- :label => _t('info'),
5
+ :label => _t(:info),
6
6
  :url => alchemy.dashboard_info_path,
7
- :title => _t('info'),
7
+ :title => _t(:info),
8
8
  :overlay_options => {
9
- :title => _t('info'),
9
+ :title => _t(:info),
10
10
  :size => "420x360"
11
11
  },
12
12
  :if_permitted_to => [:info, :alchemy_admin_dashboard]
@@ -3,7 +3,6 @@
3
3
  <%= _t("Version") %>: <%= @alchemy_version %>
4
4
  </h2>
5
5
  <p class="center with_margin" id="update_check">
6
- <%= image_tag('alchemy/ajax_loader.gif', :id => 'load_info') %>
7
6
  <span id="update_available">
8
7
  <%= render_icon('warn') %>
9
8
  <%= _t 'Update available' %>
@@ -42,16 +41,20 @@
42
41
  </ul>
43
42
  </div>
44
43
  <script type="text/javascript">
45
- $('#load_info').show();
46
- $.get('/admin/dashboard/update_check', function(data, textStatus, jqXHR) {
47
- if (data == 'true') {
48
- $('#update_available').show();
49
- } else {
50
- $('#up_to_date').show();
51
- }
52
- }).fail(function(jqXHR, textStatus, errorThrown) {
53
- $('#error').show();
54
- }).always(function() {
55
- $('#load_info').hide();
56
- });
44
+ (function() {
45
+ var el = $('#update_check');
46
+ var spinner = Alchemy.Spinner.small();
47
+ spinner.spin(el[0]);
48
+ $.get('<%= alchemy.update_check_path %>', function(data, textStatus, jqXHR) {
49
+ if (data == 'true') {
50
+ $('#update_available').show();
51
+ } else {
52
+ $('#up_to_date').show();
53
+ }
54
+ }).fail(function(jqXHR, textStatus, errorThrown) {
55
+ $('#error').show();
56
+ }).always(function() {
57
+ spinner.stop();
58
+ });
59
+ })();
57
60
  </script>
@@ -6,7 +6,7 @@
6
6
  :options => options
7
7
  ),
8
8
  {
9
- :title => _t('add_image_to_element'),
9
+ :title => _t(:add_image_to_element),
10
10
  :size => '780x580',
11
11
  :resizable => true
12
12
  }