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
@@ -120,12 +120,7 @@ en:
120
120
  mailer:
121
121
  # The mail the user gets after registering for alchemy
122
122
  new_user_mail:
123
- subject: 'Your credentials for my site'
124
- welcome: 'Welcome to my site'
125
- login_url_explanation: 'To login just click this link'
126
- username: 'Your username is'
127
- password_notice: "(For security reasons we do not show your password here. If you forgot your password or this is your first login, please goto: %{url})"
128
- greeting: 'Have a nice day'
123
+ subject: 'Your user credentials'
129
124
 
130
125
  # == Translated language names for translation select
131
126
  translations:
@@ -231,6 +226,7 @@ en:
231
226
  delete_user: "Delete this user"
232
227
  document: "File"
233
228
  documents: "Files"
229
+ download_csv: "Download CSV"
234
230
  download_file: "Download file '%{filename}'"
235
231
  "Drag an element over to the element window to restore it": "Drag an element over to the element window to restore it."
236
232
  drag_to_sort: "Drag'n'Drop to sort images"
@@ -345,10 +341,6 @@ en:
345
341
  pages:
346
342
  update:
347
343
  comma_seperated: "Separate by comma"
348
- pagination:
349
- next_page: "next page »"
350
- previous_page: "« previous page"
351
- truncate: '...'
352
344
  password: "Password"
353
345
  picture_gallery_editor: 'Pictures'
354
346
  "Picture uploaded succesfully": "Picture %{name} uploaded succesfully"
@@ -375,6 +367,9 @@ en:
375
367
  '1024': '1024px (iPad - Landscape)'
376
368
  '1280': '1280px (Desktop)'
377
369
  rename_file: "Rename this file."
370
+ resources:
371
+ relation_select:
372
+ blank: '- none -'
378
373
  robot_follow: "robot may follow links."
379
374
  robot_index: "allow robot to index."
380
375
  saved_link: "Link saved."
@@ -608,6 +603,9 @@ en:
608
603
  activerecord:
609
604
 
610
605
  models:
606
+ acts_as_taggable_on/tag:
607
+ one: Tag
608
+ other: Tags
611
609
 
612
610
  alchemy/attachment:
613
611
  one: File
@@ -683,3 +681,10 @@ en:
683
681
 
684
682
  errors:
685
683
  <<: *errors
684
+
685
+ views:
686
+ pagination:
687
+ first: "First Page"
688
+ previous_page: "Previous Page"
689
+ next_page: "Next Page"
690
+ last: "Last Page"
@@ -29,6 +29,7 @@ de:
29
29
  updated: 'Ihr Passwort wurde geändert. Sie sind jetzt angemeldet.'
30
30
  updated_not_active: 'Ihr Passwort wurde geändert.'
31
31
  send_paranoid_instructions: "Falls Ihre E-Mail-Adresse in unserer Datenbank existiert erhalten Sie in wenigen Minuten eine E-Mail mit der Anleitung, wie Sie Ihr Passwort zurücksetzen können."
32
+ no_token: "Es wurde nicht alle benötigten Parameter übergeben. Bitte überprüfen Sie, ob die komplette URL aus der E-Mail benutzt wurde."
32
33
  confirmations:
33
34
  send_instructions: 'Sie erhalten in wenigen Minuten eine E-Mail, mit der Sie Ihre Registrierung bestätigen können.'
34
35
  send_paranoid_instructions: 'Falls Ihre E-Mail-Adresse in unserer Datenbank existiert erhalten Sie in wenigen Minuten eine E-Mail mit der die Sie Ihre Registrierung bestätigen können.'
@@ -20,7 +20,7 @@ Alchemy::Engine.routes.draw do
20
20
  get '/admin/dashboard' => 'admin/dashboard#index', :as => :user_root
21
21
  get '/admin/leave' => 'user_sessions#leave', :as => :leave_admin
22
22
  get '/admin/passwords' => 'passwords#new', :as => :new_password
23
- get '/admin/passwords/:id/edit' => 'passwords#edit', :as => :edit_password
23
+ get '/admin/passwords/:id/edit/:reset_password_token' => 'passwords#edit', :as => :edit_password
24
24
  post '/admin/passwords' => 'passwords#create', :as => :password
25
25
  put '/admin/passwords' => 'passwords#update', :as => :password
26
26
  end
@@ -110,7 +110,7 @@ Alchemy::Engine.routes.draw do
110
110
  get :edit_multiple
111
111
  end
112
112
  member do
113
- get :show_in_window, :info
113
+ get :info
114
114
  delete :remove
115
115
  end
116
116
  end
@@ -169,7 +169,7 @@ Alchemy::Engine.routes.draw do
169
169
  :as => :show_language_root
170
170
 
171
171
  # The page show action has to be last route
172
- match '(/:lang)(/:level1(/:level2(/:level3)))/:urlname(.:format)' => 'pages#show',
172
+ match '(/:lang)/*urlname(.:format)' => 'pages#show',
173
173
  :constraints => {:lang => /[a-z]{2}(-[a-z]{2})?/},
174
174
  :as => :show_page
175
175
 
@@ -1,11 +1,11 @@
1
- # This is a compressed migration for creating all Alchemy 2.4 tables at once.
1
+ # This is a compressed migration for creating all Alchemy 2.5 tables at once.
2
2
  #
3
3
  # === Notice
4
4
  #
5
5
  # In order to upgrade from an old version of Alchemy, you have to run all migrations from
6
6
  # each version you missed up to the version you want to upgrade to, before running this migration.
7
7
  #
8
- class AlchemyTwoPointFour < ActiveRecord::Migration
8
+ class AlchemyTwoPointFive < ActiveRecord::Migration
9
9
  def up
10
10
  # Do not run if Alchemy tables are already present
11
11
  return if table_exists?(:alchemy_pages)
@@ -184,10 +184,21 @@ class AlchemyTwoPointFour < ActiveRecord::Migration
184
184
  t.integer "updater_id"
185
185
  t.boolean "default", :default => false
186
186
  t.string "country_code", :default => "", :null => false
187
+ t.integer "site_id"
187
188
  end
188
189
 
189
190
  add_index "alchemy_languages", ["language_code", "country_code"], :name => "index_alchemy_languages_on_language_code_and_country_code"
190
191
  add_index "alchemy_languages", ["language_code"], :name => "index_alchemy_languages_on_language_code"
192
+ add_index "alchemy_languages", ["site_id"], :name => "index_alchemy_languages_on_site_id"
193
+
194
+ create_table "alchemy_legacy_page_urls", :force => true do |t|
195
+ t.string "urlname", :null => false
196
+ t.integer "page_id", :null => false
197
+ t.datetime "created_at", :null => false
198
+ t.datetime "updated_at", :null => false
199
+ end
200
+
201
+ add_index "alchemy_legacy_page_urls", ["urlname"], :name => "index_alchemy_legacy_page_urls_on_urlname"
191
202
 
192
203
  create_table "alchemy_pages", :force => true do |t|
193
204
  t.string "name"
@@ -225,59 +236,61 @@ class AlchemyTwoPointFour < ActiveRecord::Migration
225
236
 
226
237
  create_table "alchemy_pictures", :force => true do |t|
227
238
  t.string "name"
228
- t.string "image_filename"
229
- t.integer "image_width"
230
- t.integer "image_height"
231
- t.datetime "created_at", :null => false
232
- t.datetime "updated_at", :null => false
239
+ t.string "image_file_name"
240
+ t.integer "image_file_width"
241
+ t.integer "image_file_height"
242
+ t.datetime "created_at", :null => false
243
+ t.datetime "updated_at", :null => false
233
244
  t.integer "creator_id"
234
245
  t.integer "updater_id"
235
246
  t.string "upload_hash"
236
247
  t.text "cached_tag_list"
248
+ t.string "image_file_uid"
249
+ t.integer "image_file_size"
237
250
  end
238
251
 
252
+ create_table "alchemy_sites", :force => true do |t|
253
+ t.string "host"
254
+ t.string "name"
255
+ t.datetime "created_at", :null => false
256
+ t.datetime "updated_at", :null => false
257
+ t.boolean "public", :default => false
258
+ t.text "aliases"
259
+ t.boolean "redirect_to_primary_host"
260
+ end
261
+
262
+ add_index "alchemy_sites", ["host", "public"], :name => "alchemy_sites_public_hosts_idx"
263
+ add_index "alchemy_sites", ["host"], :name => "index_alchemy_sites_on_host"
264
+
239
265
  create_table "alchemy_users", :force => true do |t|
240
266
  t.string "firstname"
241
267
  t.string "lastname"
242
268
  t.string "login"
243
269
  t.string "email"
244
270
  t.string "gender"
245
- t.string "role", :default => "registered"
271
+ t.string "role", :default => "registered"
246
272
  t.string "language"
247
- t.string "crypted_password", :limit => 128, :default => "", :null => false
248
- t.string "password_salt", :limit => 128, :default => "", :null => false
249
- t.integer "login_count", :default => 0, :null => false
250
- t.integer "failed_login_count", :default => 0, :null => false
273
+ t.string "encrypted_password", :limit => 128, :default => "", :null => false
274
+ t.string "password_salt", :limit => 128, :default => "", :null => false
275
+ t.integer "sign_in_count", :default => 0, :null => false
276
+ t.integer "failed_attempts", :default => 0, :null => false
251
277
  t.datetime "last_request_at"
252
- t.datetime "current_login_at"
253
- t.datetime "last_login_at"
254
- t.string "current_login_ip"
255
- t.string "last_login_ip"
256
- t.string "persistence_token", :null => false
257
- t.string "single_access_token", :null => false
258
- t.string "perishable_token", :null => false
259
- t.datetime "created_at", :null => false
260
- t.datetime "updated_at", :null => false
278
+ t.datetime "current_sign_in_at"
279
+ t.datetime "last_sign_in_at"
280
+ t.string "current_sign_in_ip"
281
+ t.string "last_sign_in_ip"
282
+ t.datetime "created_at", :null => false
283
+ t.datetime "updated_at", :null => false
261
284
  t.integer "creator_id"
262
285
  t.integer "updater_id"
263
286
  t.text "cached_tag_list"
287
+ t.string "reset_password_token"
288
+ t.datetime "reset_password_sent_at"
264
289
  end
265
290
 
266
- add_index "alchemy_users", ["perishable_token"], :name => "index_users_on_perishable_token"
267
-
268
- create_table "events", :force => true do |t|
269
- t.string "name"
270
- t.string "hidden_name"
271
- t.datetime "starts_at"
272
- t.datetime "ends_at"
273
- t.text "description"
274
- t.decimal "entrance_fee", :precision => 6, :scale => 2
275
- t.boolean "published"
276
- t.integer "location_id"
277
- t.integer "organizer_id"
278
- t.datetime "created_at", :null => false
279
- t.datetime "updated_at", :null => false
280
- end
291
+ add_index "alchemy_users", ["email"], :name => "index_alchemy_users_on_email", :unique => true
292
+ add_index "alchemy_users", ["login"], :name => "index_alchemy_users_on_login", :unique => true
293
+ add_index "alchemy_users", ["reset_password_token"], :name => "index_alchemy_users_on_reset_password_token", :unique => true
281
294
 
282
295
  create_table "taggings", :force => true do |t|
283
296
  t.integer "tag_id"
@@ -295,5 +308,6 @@ class AlchemyTwoPointFour < ActiveRecord::Migration
295
308
  create_table "tags", :force => true do |t|
296
309
  t.string "name"
297
310
  end
311
+
298
312
  end
299
313
  end
@@ -0,0 +1,21 @@
1
+ class MigrateAttachmentsToDragonfly < ActiveRecord::Migration
2
+ def up
3
+ change_table :alchemy_attachments do |t|
4
+ t.string :file_uid
5
+ t.index :file_uid
6
+ t.rename :filename, :file_name
7
+ t.rename :content_type, :file_mime_type
8
+ t.rename :size, :file_size
9
+ end
10
+ end
11
+
12
+ def down
13
+ change_table :alchemy_attachments do |t|
14
+ t.remove :file_uid
15
+ t.rename :file_name, :filename
16
+ t.rename :file_mime_type, :content_type
17
+ t.rename :file_size, :size
18
+ t.remove_index :file_uid
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,11 @@
1
+ class ChangeAlchemyUsersRoleToRoles < ActiveRecord::Migration
2
+ def up
3
+ rename_column :alchemy_users, :role, :roles
4
+ add_index :alchemy_users, :roles
5
+ end
6
+
7
+ def down
8
+ remove_index :alchemy_users, :roles
9
+ rename_column :alchemy_users, :roles, :role
10
+ end
11
+ end
@@ -37,23 +37,25 @@ require 'fileutils'
37
37
 
38
38
  desc "Upgrades production database to current Alchemy CMS version"
39
39
  task :upgrade do
40
- run "cd #{current_path} && RAILS_ENV=#{fetch(:rails_env, 'production')} #{rake} alchemy:upgrade"
40
+ run "cd #{current_path} && #{rake} RAILS_ENV=#{fetch(:rails_env, 'production')} alchemy:upgrade"
41
41
  end
42
42
 
43
43
  namespace :database_yml do
44
44
 
45
45
  desc "Creates the database.yml file"
46
46
  task :create do
47
- db_adapter = Capistrano::CLI.ui.ask("\nPlease enter database adapter (Options: mysql2, or postgresql. Default mysql2): ")
47
+ environment = Capistrano::CLI.ui.ask("\nPlease enter the environment (Default: #{fetch(:rails_env, 'production')})")
48
+ environment = fetch(:rails_env, 'production') if environment.empty?
49
+ db_adapter = Capistrano::CLI.ui.ask("Please enter database adapter (Options: mysql2, or postgresql. Default mysql2): ")
48
50
  db_adapter = db_adapter.empty? ? 'mysql2' : db_adapter.gsub(/^mysql$/, 'mysql2')
49
51
  db_name = Capistrano::CLI.ui.ask("Please enter database name: ")
50
52
  db_username = Capistrano::CLI.ui.ask("Please enter database username: ")
51
- db_password = Capistrano::CLI.ui.ask("Please enter database password: ")
53
+ db_password = Capistrano::CLI.password_prompt("Please enter database password: ")
52
54
  default_db_host = db_adapter == 'mysql2' ? 'localhost' : '127.0.0.1'
53
55
  db_host = Capistrano::CLI.ui.ask("Please enter database host (Default: #{default_db_host}): ")
54
56
  db_host = db_host.empty? ? default_db_host : db_host
55
57
  db_config = ERB.new <<-EOF
56
- production:
58
+ #{environment}:
57
59
  adapter: #{ db_adapter }
58
60
  encoding: utf8
59
61
  reconnect: false
@@ -78,12 +80,12 @@ EOF
78
80
 
79
81
  desc "Seeds the database with essential data."
80
82
  task :seed, :roles => :db do
81
- run "cd #{current_path} && RAILS_ENV=#{fetch(:rails_env, 'production')} #{rake} alchemy:db:seed"
83
+ run "cd #{current_path} && #{rake} RAILS_ENV=#{fetch(:rails_env, 'production')} alchemy:db:seed"
82
84
  end
83
85
 
84
86
  desc "Dumps the database into 'db/dumps'"
85
87
  task :dump, :roles => :db do
86
- run "cd #{current_path} && RAILS_ENV=#{fetch(:rails_env, 'production')} #{rake} alchemy:db:dump"
88
+ run "cd #{current_path} && #{rake} RAILS_ENV=#{fetch(:rails_env, 'production')} alchemy:db:dump"
87
89
  end
88
90
 
89
91
  end
@@ -100,7 +102,7 @@ EOF
100
102
  desc "Imports the database into your local development machine."
101
103
  task :database, :roles => [:db], :only => {:primary => true} do
102
104
  server = find_servers_for_task(current_task).first
103
- dump_cmd = "cd #{current_path} && RAILS_ENV=#{fetch(:rails_env, 'production')} #{rake} alchemy:db:dump"
105
+ dump_cmd = "cd #{current_path} && #{rake} RAILS_ENV=#{fetch(:rails_env, 'production')} alchemy:db:dump"
104
106
  sql_stream = "ssh -p #{fetch(:port, 22)} #{user}@#{server} '#{dump_cmd}'"
105
107
  mysql_credentials = ["--user='#{database_config['username']}'"]
106
108
  if database_config['password']
@@ -148,7 +150,7 @@ EOF
148
150
  # It uses the +alchemy:rebuild_index+ rake task found in +vendor/plugins/alchemy/lib/tasks+.
149
151
  desc "Rebuild the ferret index. Call before deploy:restart"
150
152
  task :rebuild_index, :roles => :app do
151
- run "cd #{current_path} && RAILS_ENV=#{fetch(:rails_env, 'production')} #{rake} ferret:rebuild_index"
153
+ run "cd #{current_path} && #{rake} RAILS_ENV=#{fetch(:rails_env, 'production')} ferret:rebuild_index"
152
154
  end
153
155
 
154
156
  end
@@ -49,4 +49,11 @@ module Alchemy
49
49
  end
50
50
  end
51
51
 
52
+ class MissingActiveRecordAssociation < StandardError
53
+ # Raised if a resource_relation is defined without proper ActiveRecord association
54
+ def message
55
+ "You need to define proper ActiveRecord associations, if you want to use resource_relations."
56
+ end
57
+ end
58
+
52
59
  end
@@ -0,0 +1,33 @@
1
+ module Alchemy
2
+ module Filetypes
3
+
4
+ ARCHIVE_FILE_TYPES = ["application/zip", "application/x-rar"]
5
+
6
+ AUDIO_FILE_TYPES = [
7
+ "audio/mpeg",
8
+ "audio/mp4",
9
+ "audio/wav",
10
+ "audio/x-wav"
11
+ ]
12
+
13
+ IMAGE_FILE_TYPES = [
14
+ "image/gif",
15
+ "image/jpeg",
16
+ "image/png",
17
+ "image/tiff"
18
+ ]
19
+
20
+ VCARD_FILE_TYPES = ["text/x-vcard", "application/vcard"]
21
+
22
+ VIDEO_FILE_TYPES = [
23
+ "application/x-flash-video",
24
+ "video/x-flv",
25
+ "video/mp4",
26
+ "video/mpeg",
27
+ "video/quicktime",
28
+ "video/x-msvideo",
29
+ "video/x-ms-wmv"
30
+ ]
31
+
32
+ end
33
+ end
@@ -31,7 +31,7 @@ module Alchemy
31
31
  #
32
32
  def self.t(msg, *args)
33
33
  options = args.extract_options!
34
- options[:default] = options[:default] ? options[:default] : msg.to_s.humanize
34
+ humanize_default_string!(msg, options)
35
35
  scope = ['alchemy']
36
36
  case options[:scope].class.name
37
37
  when "Array"
@@ -52,5 +52,13 @@ module Alchemy
52
52
  Dir.glob(File.join(File.dirname(__FILE__), '../../config/locales/alchemy.*.yml'))
53
53
  end
54
54
 
55
+ private
56
+
57
+ def self.humanize_default_string!(msg, options)
58
+ if options[:default].blank?
59
+ options[:default] = msg.is_a?(Symbol) ? msg.to_s.humanize : msg
60
+ end
61
+ end
62
+
55
63
  end
56
64
  end
@@ -0,0 +1,28 @@
1
+ # encoding: utf-8
2
+
3
+ module Alchemy
4
+ # Provides methods for converting names into urlnames and vice versa.
5
+ #
6
+ module NameConversions
7
+
8
+ # Converts a given name into url save and readable urlanme.
9
+ # Uses rails parameterize, but converts german umlauts before.
10
+ #
11
+ # @returns String
12
+ def convert_to_urlname(name)
13
+ name
14
+ .gsub(/[äÄ]/, 'ae')
15
+ .gsub(/[üÜ]/, 'ue')
16
+ .gsub(/[öÖ]/, 'oe')
17
+ .gsub(/[ß]/, 'ss')
18
+ .parameterize
19
+ end
20
+
21
+ # Converts a filename and suffix into a human readable name.
22
+ #
23
+ def convert_to_humanized_name(name, suffix)
24
+ name.gsub(/\.#{::Regexp.quote(suffix)}$/i, '').gsub(/_/, ' ').strip
25
+ end
26
+
27
+ end
28
+ end
@@ -54,13 +54,15 @@ module Alchemy
54
54
 
55
55
  # Returns page layouts ready for Rails' select form helper.
56
56
  def layouts_for_select(language_id, layoutpage = false)
57
- map_layouts(selectable_layouts(language_id, layoutpage), [[I18n.t("Please choose"), ""]])
57
+ map_layouts(selectable_layouts(language_id, layoutpage), [[I18n.t('Please choose'), '']])
58
58
  end
59
59
 
60
60
  def layouts_with_own_for_select(own_layout, language_id, layoutpage)
61
61
  layouts = selectable_layouts(language_id, layoutpage)
62
62
  if layouts.detect { |l| l['name'] == own_layout } == nil
63
- map_array = [[I18n.t(own_layout, :scope => 'page_layout_names'), own_layout]]
63
+ map_array = [
64
+ [I18n.t(own_layout, scope: 'page_layout_names', default: own_layout.to_s.humanize), own_layout]
65
+ ]
64
66
  else
65
67
  map_array = []
66
68
  end
@@ -71,7 +73,7 @@ module Alchemy
71
73
  def map_layouts(layouts, map_array = [])
72
74
  layouts.each do |layout|
73
75
  map_array << [
74
- I18n.t(layout['name'], :scope => 'page_layout_names'),
76
+ I18n.t(layout['name'], scope: 'page_layout_names', default: layout['name'].to_s.humanize),
75
77
  layout["name"]
76
78
  ]
77
79
  end