alchemy_cms 3.2.1 → 3.3.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.codeclimate.yml +28 -0
- data/.gitignore +2 -2
- data/.travis.yml +11 -3
- data/CHANGELOG.md +100 -0
- data/CONTRIBUTING.md +1 -1
- data/Gemfile +12 -1
- data/README.md +25 -7
- data/Rakefile +1 -3
- data/alchemy_cms.gemspec +7 -15
- data/app/assets/fonts/alchemy/icons.eot +0 -0
- data/app/assets/fonts/alchemy/icons.svg +28 -66
- data/app/assets/fonts/alchemy/icons.ttf +0 -0
- data/app/assets/fonts/alchemy/icons.woff +0 -0
- data/app/assets/images/alchemy/icons.png +0 -0
- data/app/assets/javascripts/alchemy/alchemy.base.js.coffee +10 -3
- data/app/assets/javascripts/alchemy/alchemy.buttons.js.coffee +15 -6
- data/app/assets/javascripts/alchemy/alchemy.char_counter.js.coffee +1 -1
- data/app/assets/javascripts/alchemy/alchemy.datepicker.js.coffee +1 -1
- data/app/assets/javascripts/alchemy/alchemy.dialog.js.coffee +10 -4
- data/app/assets/javascripts/alchemy/alchemy.dirty.js.coffee +16 -22
- data/app/assets/javascripts/alchemy/alchemy.dragndrop.js.coffee +69 -32
- data/app/assets/javascripts/alchemy/alchemy.element_editors.js.coffee +147 -83
- data/app/assets/javascripts/alchemy/alchemy.file_progress.js.coffee +14 -14
- data/app/assets/javascripts/alchemy/alchemy.hotkeys.js.coffee +1 -1
- data/app/assets/javascripts/alchemy/alchemy.i18n.js.coffee +1 -1
- data/app/assets/javascripts/alchemy/alchemy.image_overlay.coffee +55 -0
- data/app/assets/javascripts/alchemy/alchemy.initializer.js.coffee +8 -1
- data/app/assets/javascripts/alchemy/alchemy.js +3 -1
- data/app/assets/javascripts/alchemy/alchemy.link_dialog.js.coffee +36 -31
- data/app/assets/javascripts/alchemy/alchemy.preview.js.coffee +35 -29
- data/app/assets/javascripts/alchemy/alchemy.sitemap.js.coffee +51 -5
- data/app/assets/javascripts/alchemy/alchemy.tinymce.js.coffee +26 -10
- data/app/assets/javascripts/alchemy/{alchemy.windows.js.coffee → alchemy.trash_window.js.coffee} +1 -13
- data/app/assets/javascripts/alchemy/alchemy.uploader.js.coffee +15 -17
- data/app/assets/javascripts/tinymce/plugins/alchemy_link/plugin.min.js +3 -3
- data/app/assets/stylesheets/alchemy/_extends.scss +1 -1
- data/app/assets/stylesheets/alchemy/_mixins.scss +27 -0
- data/app/assets/stylesheets/alchemy/_variables.scss +1 -0
- data/app/assets/stylesheets/alchemy/admin.scss +1 -0
- data/app/assets/stylesheets/alchemy/archive.scss +0 -57
- data/app/assets/stylesheets/alchemy/base.scss +1 -18
- data/app/assets/stylesheets/alchemy/buttons.scss +30 -25
- data/app/assets/stylesheets/alchemy/dialogs.scss +25 -9
- data/app/assets/stylesheets/alchemy/elements.scss +182 -126
- data/app/assets/stylesheets/alchemy/form_fields.scss +14 -8
- data/app/assets/stylesheets/alchemy/forms.scss +10 -1
- data/app/assets/stylesheets/alchemy/frame.scss +3 -10
- data/app/assets/stylesheets/alchemy/icon-font.scss +13 -6
- data/app/assets/stylesheets/alchemy/icons.scss +16 -0
- data/app/assets/stylesheets/alchemy/image_library.scss +269 -0
- data/app/assets/stylesheets/alchemy/selects.scss +1 -0
- data/app/assets/stylesheets/alchemy/sitemap.scss +12 -1
- data/app/assets/stylesheets/alchemy/toolbar.scss +2 -2
- data/app/assets/stylesheets/alchemy/upload.scss +97 -87
- data/app/assets/stylesheets/alchemy/welcome.sass +49 -0
- data/app/controllers/alchemy/admin/attachments_controller.rb +21 -29
- data/app/controllers/alchemy/admin/base_controller.rb +23 -4
- data/app/controllers/alchemy/admin/clipboard_controller.rb +0 -1
- data/app/controllers/alchemy/admin/contents_controller.rb +2 -4
- data/app/controllers/alchemy/admin/dashboard_controller.rb +4 -4
- data/app/controllers/alchemy/admin/elements_controller.rb +20 -11
- data/app/controllers/alchemy/admin/essence_files_controller.rb +2 -2
- data/app/controllers/alchemy/admin/essence_pictures_controller.rb +10 -9
- data/app/controllers/alchemy/admin/languages_controller.rb +0 -1
- data/app/controllers/alchemy/admin/layoutpages_controller.rb +0 -2
- data/app/controllers/alchemy/admin/legacy_page_urls_controller.rb +0 -1
- data/app/controllers/alchemy/admin/pages_controller.rb +46 -29
- data/app/controllers/alchemy/admin/pictures_controller.rb +44 -55
- data/app/controllers/alchemy/admin/resources_controller.rb +8 -75
- data/app/controllers/alchemy/admin/tags_controller.rb +10 -8
- data/app/controllers/alchemy/admin/trash_controller.rb +0 -6
- data/app/controllers/alchemy/api/contents_controller.rb +0 -1
- data/app/controllers/alchemy/api/elements_controller.rb +0 -1
- data/app/controllers/alchemy/api/pages_controller.rb +4 -1
- data/app/controllers/alchemy/attachments_controller.rb +4 -5
- data/app/controllers/alchemy/base_controller.rb +6 -5
- data/app/controllers/alchemy/elements_controller.rb +1 -1
- data/app/controllers/alchemy/messages_controller.rb +9 -4
- data/app/controllers/alchemy/pages_controller.rb +133 -137
- data/app/controllers/alchemy/pictures_controller.rb +12 -10
- data/app/controllers/concerns/alchemy/admin/uploader_responses.rb +41 -0
- data/app/controllers/concerns/alchemy/legacy_page_redirects.rb +56 -0
- data/app/controllers/concerns/alchemy/locale_redirects.rb +38 -0
- data/app/controllers/concerns/alchemy/page_redirects.rb +80 -0
- data/app/controllers/concerns/alchemy/site_redirects.rb +22 -0
- data/app/helpers/alchemy/admin/attachments_helper.rb +1 -2
- data/app/helpers/alchemy/admin/base_helper.rb +36 -62
- data/app/helpers/alchemy/admin/contents_helper.rb +6 -80
- data/app/helpers/alchemy/admin/elements_helper.rb +36 -15
- data/app/helpers/alchemy/admin/essences_helper.rb +15 -8
- data/app/helpers/alchemy/admin/form_helper.rb +6 -10
- data/app/helpers/alchemy/admin/navigation_helper.rb +4 -7
- data/app/helpers/alchemy/admin/pages_helper.rb +14 -35
- data/app/helpers/alchemy/admin/pictures_helper.rb +12 -14
- data/app/helpers/alchemy/admin/tags_helper.rb +5 -7
- data/app/helpers/alchemy/base_helper.rb +9 -17
- data/app/helpers/alchemy/elements_block_helper.rb +5 -13
- data/app/helpers/alchemy/elements_helper.rb +6 -6
- data/app/helpers/alchemy/essences_helper.rb +3 -16
- data/app/helpers/alchemy/pages_helper.rb +32 -25
- data/app/helpers/alchemy/url_helper.rb +14 -16
- data/app/mailers/alchemy/messages.rb +0 -2
- data/app/models/alchemy.rb +0 -2
- data/app/models/alchemy/attachment.rb +45 -56
- data/app/models/alchemy/cell.rb +7 -8
- data/app/models/alchemy/content.rb +39 -24
- data/app/models/alchemy/content/factory.rb +27 -44
- data/app/models/alchemy/element.rb +101 -267
- data/app/models/alchemy/element/definitions.rb +9 -8
- data/app/models/alchemy/element/element_contents.rb +150 -0
- data/app/models/alchemy/element/element_essences.rb +109 -0
- data/app/models/alchemy/element/presenters.rb +18 -7
- data/app/models/alchemy/essence_date.rb +1 -2
- data/app/models/alchemy/essence_file.rb +10 -6
- data/app/models/alchemy/essence_html.rb +0 -1
- data/app/models/alchemy/essence_picture.rb +12 -4
- data/app/models/alchemy/essence_richtext.rb +6 -3
- data/app/models/alchemy/language.rb +48 -21
- data/app/models/alchemy/language/code.rb +1 -4
- data/app/models/alchemy/page.rb +33 -35
- data/app/models/alchemy/page/page_cells.rb +6 -10
- data/app/models/alchemy/page/page_elements.rb +130 -100
- data/app/models/alchemy/page/page_naming.rb +2 -3
- data/app/models/alchemy/page/page_natures.rb +50 -16
- data/app/models/alchemy/page/page_scopes.rb +7 -7
- data/app/models/alchemy/page/page_users.rb +3 -3
- data/app/models/alchemy/picture.rb +48 -33
- data/app/models/alchemy/picture/transformations.rb +8 -9
- data/app/models/alchemy/site.rb +19 -17
- data/app/models/alchemy/site/layout.rb +9 -9
- data/app/models/alchemy/tag.rb +0 -2
- data/app/models/alchemy/tree_node.rb +5 -4
- data/app/serializers/alchemy/attachment_serializer.rb +0 -1
- data/app/serializers/alchemy/base_serializer.rb +30 -0
- data/app/serializers/alchemy/cell_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_boolean_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_date_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_file_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_html_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_link_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_picture_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_richtext_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_select_serializer.rb +0 -1
- data/app/serializers/alchemy/essence_text_serializer.rb +0 -1
- data/app/serializers/alchemy/legacy_element_serializer.rb +0 -1
- data/app/serializers/alchemy/page_serializer.rb +0 -1
- data/app/serializers/alchemy/page_tree_serializer.rb +90 -0
- data/app/serializers/alchemy/picture_serializer.rb +0 -1
- data/app/views/alchemy/_menubar.html.erb +3 -3
- data/app/views/alchemy/admin/attachments/_archive_overlay.html.erb +11 -16
- data/app/views/alchemy/admin/attachments/_attachment.html.erb +9 -9
- data/app/views/alchemy/admin/attachments/_files_list.html.erb +7 -15
- data/app/views/alchemy/admin/attachments/_overlay_file_list.html.erb +1 -1
- data/app/views/alchemy/admin/attachments/_tag_list.html.erb +2 -2
- data/app/views/alchemy/admin/attachments/edit.html.erb +3 -3
- data/app/views/alchemy/admin/attachments/index.html.erb +10 -17
- data/app/views/alchemy/admin/clipboard/clear.js.erb +1 -1
- data/app/views/alchemy/admin/clipboard/index.html.erb +3 -3
- data/app/views/alchemy/admin/clipboard/insert.js.erb +3 -3
- data/app/views/alchemy/admin/clipboard/remove.js.erb +2 -2
- data/app/views/alchemy/admin/contents/_missing.html.erb +5 -7
- data/app/views/alchemy/admin/contents/create.js.erb +1 -1
- data/app/views/alchemy/admin/contents/new.html.erb +2 -2
- data/app/views/alchemy/admin/dashboard/_locked_pages.html.erb +6 -6
- data/app/views/alchemy/admin/dashboard/_recent_pages.html.erb +2 -2
- data/app/views/alchemy/admin/dashboard/_users.html.erb +2 -2
- data/app/views/alchemy/admin/dashboard/help.html.erb +15 -15
- data/app/views/alchemy/admin/dashboard/index.html.erb +6 -6
- data/app/views/alchemy/admin/dashboard/info.html.erb +5 -5
- data/app/views/alchemy/admin/elements/_add_picture.html.erb +1 -1
- data/app/views/alchemy/admin/elements/_element.html.erb +52 -18
- data/app/views/alchemy/admin/elements/_element_footer.html.erb +11 -0
- data/app/views/alchemy/admin/elements/{_element_head.html.erb → _element_header.html.erb} +8 -8
- data/app/views/alchemy/admin/elements/_element_toolbar.html.erb +49 -0
- data/app/views/alchemy/admin/elements/_new_element_form.html.erb +7 -6
- data/app/views/alchemy/admin/elements/_picture_gallery_editor.html.erb +1 -1
- data/app/views/alchemy/admin/elements/_refresh_editor.js.erb +1 -1
- data/app/views/alchemy/admin/elements/create.js.erb +13 -8
- data/app/views/alchemy/admin/elements/fold.js.erb +12 -7
- data/app/views/alchemy/admin/elements/index.html.erb +12 -8
- data/app/views/alchemy/admin/elements/list.html.erb +3 -3
- data/app/views/alchemy/admin/elements/new.html.erb +4 -4
- data/app/views/alchemy/admin/elements/order.js.erb +3 -4
- data/app/views/alchemy/admin/elements/publish.js.erb +15 -0
- data/app/views/alchemy/admin/elements/trash.js.erb +3 -3
- data/app/views/alchemy/admin/elements/update.js.erb +7 -8
- data/app/views/alchemy/admin/essence_files/edit.html.erb +16 -13
- data/app/views/alchemy/admin/essence_pictures/crop.html.erb +3 -3
- data/app/views/alchemy/admin/essence_pictures/edit.html.erb +8 -8
- data/app/views/alchemy/admin/languages/_form.html.erb +12 -3
- data/app/views/alchemy/admin/languages/_language.html.erb +8 -2
- data/app/views/alchemy/admin/languages/_table.html.erb +11 -5
- data/app/views/alchemy/admin/languages/index.html.erb +1 -1
- data/app/views/alchemy/admin/layoutpages/_layoutpage.html.erb +8 -8
- data/app/views/alchemy/admin/layoutpages/edit.html.erb +2 -2
- data/app/views/alchemy/admin/layoutpages/index.html.erb +6 -13
- data/app/views/alchemy/admin/leave.html.erb +5 -5
- data/app/views/alchemy/admin/legacy_page_urls/_form.html.erb +1 -1
- data/app/views/alchemy/admin/legacy_page_urls/_legacy_page_url.html.erb +4 -4
- data/app/views/alchemy/admin/legacy_page_urls/_new.html.erb +1 -1
- data/app/views/alchemy/admin/pages/_create_language_form.html.erb +9 -9
- data/app/views/alchemy/admin/pages/_external_link.html.erb +6 -6
- data/app/views/alchemy/admin/pages/_file_link.html.erb +6 -6
- data/app/views/alchemy/admin/pages/_form.html.erb +6 -6
- data/app/views/alchemy/admin/pages/_internal_link.html.erb +9 -11
- data/app/views/alchemy/admin/pages/_legacy_urls.html.erb +3 -3
- data/app/views/alchemy/admin/pages/_locked_page.html.erb +4 -4
- data/app/views/alchemy/admin/pages/_new_page_form.html.erb +2 -2
- data/app/views/alchemy/admin/pages/_page.html.erb +95 -80
- data/app/views/alchemy/admin/pages/_page_for_links.html.erb +22 -22
- data/app/views/alchemy/admin/pages/_page_infos.html.erb +12 -0
- data/app/views/alchemy/admin/pages/_page_status.html.erb +7 -9
- data/app/views/alchemy/admin/pages/_sitemap.html.erb +35 -6
- data/app/views/alchemy/admin/pages/_tinymce_custom_config.html.erb +0 -3
- data/app/views/alchemy/admin/pages/configure.html.erb +1 -1
- data/app/views/alchemy/admin/pages/configure_external.html.erb +4 -4
- data/app/views/alchemy/admin/pages/edit.html.erb +39 -44
- data/app/views/alchemy/admin/pages/flush.js.erb +1 -1
- data/app/views/alchemy/admin/pages/fold.js.erb +2 -3
- data/app/views/alchemy/admin/pages/index.html.erb +15 -22
- data/app/views/alchemy/admin/pages/info.html.erb +8 -8
- data/app/views/alchemy/admin/pages/link.html.erb +3 -3
- data/app/views/alchemy/admin/pages/locked.html.erb +1 -1
- data/app/views/alchemy/admin/pages/new.html.erb +4 -4
- data/app/views/alchemy/admin/pages/sort.js.erb +1 -2
- data/app/views/alchemy/admin/pages/unlock.js.erb +1 -1
- data/app/views/alchemy/admin/pages/update.js.erb +3 -3
- data/app/views/alchemy/admin/partials/_autocomplete_tag_list.html.erb +1 -1
- data/app/views/alchemy/admin/partials/_language_tree_select.html.erb +1 -1
- data/app/views/alchemy/admin/partials/_main_navigation_entry.html.erb +1 -1
- data/app/views/alchemy/admin/partials/_remote_search_form.html.erb +9 -15
- data/app/views/alchemy/admin/partials/_search_form.html.erb +14 -13
- data/app/views/alchemy/admin/partials/_sub_navigation.html.erb +1 -1
- data/app/views/alchemy/admin/pictures/_archive.html.erb +14 -14
- data/app/views/alchemy/admin/pictures/_filter_and_size_bar.html.erb +30 -36
- data/app/views/alchemy/admin/pictures/_filter_bar.html.erb +5 -5
- data/app/views/alchemy/admin/pictures/{edit.html.erb → _form.html.erb} +7 -6
- data/app/views/alchemy/admin/pictures/_infos.html.erb +50 -0
- data/app/views/alchemy/admin/pictures/_overlay_picture_list.html.erb +1 -1
- data/app/views/alchemy/admin/pictures/_picture.html.erb +17 -51
- data/app/views/alchemy/admin/pictures/_picture_to_assign.html.erb +1 -1
- data/app/views/alchemy/admin/pictures/_tag_list.html.erb +2 -2
- data/app/views/alchemy/admin/pictures/edit_multiple.html.erb +6 -6
- data/app/views/alchemy/admin/pictures/index.html.erb +28 -36
- data/app/views/alchemy/admin/pictures/show.html.erb +46 -9
- data/app/views/alchemy/admin/pictures/update.js.erb +6 -0
- data/app/views/alchemy/admin/resources/_form.html.erb +3 -3
- data/app/views/alchemy/admin/resources/_resource.html.erb +4 -4
- data/app/views/alchemy/admin/resources/_table.html.erb +5 -6
- data/app/views/alchemy/admin/resources/index.csv.erb +12 -10
- data/app/views/alchemy/admin/resources/index.html.erb +4 -4
- data/app/views/alchemy/admin/sites/index.html.erb +1 -1
- data/app/views/alchemy/admin/tags/_tag.html.erb +4 -4
- data/app/views/alchemy/admin/tags/edit.html.erb +5 -5
- data/app/views/alchemy/admin/tags/index.html.erb +8 -8
- data/app/views/alchemy/admin/tags/new.html.erb +2 -2
- data/app/views/alchemy/admin/trash/clear.js.erb +1 -1
- data/app/views/alchemy/admin/trash/index.html.erb +8 -6
- data/app/views/alchemy/admin/uploader/_button.html.erb +39 -0
- data/app/views/alchemy/admin/uploader/_setup.html.erb +13 -0
- data/app/views/alchemy/base/500.html.erb +4 -4
- data/app/views/alchemy/elements/_editor_not_found.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_boolean_editor.html.erb +3 -4
- data/app/views/alchemy/essences/_essence_boolean_view.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_date_editor.html.erb +2 -6
- data/app/views/alchemy/essences/_essence_date_view.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_file_editor.html.erb +9 -11
- data/app/views/alchemy/essences/_essence_file_view.html.erb +11 -5
- data/app/views/alchemy/essences/_essence_html_editor.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_link_editor.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_link_view.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_picture_editor.html.erb +47 -52
- data/app/views/alchemy/essences/_essence_richtext_editor.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_richtext_view.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_select_editor.html.erb +23 -13
- data/app/views/alchemy/essences/_essence_text_editor.html.erb +1 -1
- data/app/views/alchemy/essences/_essence_text_view.html.erb +1 -1
- data/app/views/alchemy/essences/shared/_essence_picture_tools.html.erb +29 -36
- data/app/views/alchemy/essences/shared/_linkable_essence_tools.html.erb +5 -5
- data/app/views/alchemy/language_links/_language.html.erb +15 -9
- data/app/views/alchemy/messages/contact_form_mail.de.text.erb +1 -1
- data/app/views/alchemy/messages/contact_form_mail.en.text.erb +1 -1
- data/app/views/alchemy/messages/contact_form_mail.es.text.erb +1 -1
- data/app/views/alchemy/navigation/_link.html.erb +0 -1
- data/app/views/alchemy/pages/show.rss.builder +6 -4
- data/app/views/alchemy/welcome.html.erb +28 -0
- data/app/views/layouts/alchemy/admin.html.erb +14 -10
- data/bin/alchemy +3 -4
- data/bin/rspec +7 -0
- data/bin/spring +15 -0
- data/config/alchemy/config.yml +16 -17
- data/config/initializers/assets.rb +13 -0
- data/config/locales/alchemy.de.yml +27 -29
- data/config/locales/alchemy.en.yml +23 -29
- data/config/locales/alchemy.es.yml +23 -29
- data/config/locales/alchemy.fr.yml +19 -28
- data/config/locales/alchemy.nl.yml +19 -27
- data/config/locales/alchemy.ru.yml +19 -28
- data/config/routes.rb +53 -54
- data/config/spring.rb +2 -0
- data/db/migrate/20130827094554_alchemy_two_point_six.rb +1 -3
- data/db/migrate/20150608204610_add_parent_element_id_to_alchemy_elements.rb +6 -0
- data/db/migrate/20150729151825_add_link_text_to_alchemy_essence_files.rb +5 -0
- data/db/migrate/20150906195818_add_locale_to_alchemy_languages.rb +7 -0
- data/lib/alchemy/auth_accessors.rb +1 -1
- data/lib/alchemy/cache_digests/template_tracker.rb +7 -13
- data/lib/alchemy/config.rb +5 -7
- data/lib/alchemy/configuration_methods.rb +11 -1
- data/lib/alchemy/controller_actions.rb +9 -12
- data/lib/alchemy/engine.rb +11 -28
- data/lib/alchemy/errors.rb +0 -1
- data/lib/alchemy/essence.rb +20 -20
- data/lib/alchemy/filetypes.rb +1 -3
- data/lib/alchemy/forms/builder.rb +0 -2
- data/lib/alchemy/hints.rb +1 -3
- data/lib/alchemy/i18n.rb +81 -53
- data/lib/alchemy/kaminari/scoped_pagination_url_helper.rb +0 -2
- data/lib/alchemy/locale.rb +0 -1
- data/lib/alchemy/logger.rb +1 -3
- data/lib/alchemy/modules.rb +3 -3
- data/lib/alchemy/mount_point.rb +0 -2
- data/lib/alchemy/name_conversions.rb +1 -3
- data/lib/alchemy/on_page_layout.rb +37 -23
- data/lib/alchemy/on_page_layout/callbacks_runner.rb +34 -0
- data/lib/alchemy/page_layout.rb +23 -24
- data/lib/alchemy/paths.rb +32 -0
- data/lib/alchemy/permissions.rb +20 -20
- data/lib/alchemy/picture_attributes.rb +0 -3
- data/lib/alchemy/resource.rb +66 -22
- data/lib/alchemy/resources_helper.rb +48 -11
- data/lib/alchemy/routing_constraints.rb +4 -5
- data/lib/alchemy/seeder.rb +1 -4
- data/lib/alchemy/shell.rb +12 -14
- data/lib/alchemy/tasks/helpers.rb +5 -7
- data/lib/alchemy/test_support/essence_shared_examples.rb +24 -24
- data/lib/alchemy/test_support/factories.rb +2 -146
- data/lib/alchemy/test_support/factories/attachment_factory.rb +9 -0
- data/lib/alchemy/test_support/factories/cell_factory.rb +9 -0
- data/lib/alchemy/test_support/factories/content_factory.rb +10 -0
- data/lib/alchemy/test_support/factories/dummy_user_factory.rb +21 -0
- data/lib/alchemy/test_support/factories/element_factory.rb +21 -0
- data/lib/alchemy/test_support/factories/essence_file_factory.rb +8 -0
- data/lib/alchemy/test_support/factories/essence_picture_factory.rb +8 -0
- data/lib/alchemy/test_support/factories/essence_text_factory.rb +7 -0
- data/lib/alchemy/test_support/factories/language_factory.rb +28 -0
- data/lib/alchemy/test_support/factories/page_factory.rb +45 -0
- data/lib/alchemy/test_support/factories/picture_factory.rb +10 -0
- data/lib/alchemy/test_support/factories/site_factory.rb +12 -0
- data/lib/alchemy/test_support/integration_helpers.rb +0 -3
- data/lib/alchemy/tinymce.rb +24 -35
- data/lib/alchemy/touching.rb +5 -6
- data/lib/alchemy/upgrader.rb +3 -5
- data/lib/alchemy/upgrader/tasks/available_contents_upgrader.rb +155 -0
- data/lib/alchemy/upgrader/tasks/nestable_elements_migration.rb +71 -0
- data/lib/alchemy/upgrader/tasks/three_point_two_task.rb +31 -0
- data/lib/alchemy/upgrader/three_point_three.rb +50 -0
- data/lib/alchemy/upgrader/three_point_two.rb +3 -32
- data/lib/alchemy/upgrader/three_point_zero.rb +0 -1
- data/lib/alchemy/version.rb +1 -1
- data/lib/rails/generators/alchemy/base.rb +1 -1
- data/lib/rails/generators/alchemy/elements/elements_generator.rb +1 -7
- data/lib/rails/generators/alchemy/elements/templates/editor.html.erb +5 -7
- data/lib/rails/generators/alchemy/elements/templates/editor.html.haml +6 -8
- data/lib/rails/generators/alchemy/elements/templates/editor.html.slim +6 -7
- data/lib/rails/generators/alchemy/elements/templates/view.html.erb +4 -4
- data/lib/rails/generators/alchemy/elements/templates/view.html.haml +3 -3
- data/lib/rails/generators/alchemy/elements/templates/view.html.slim +3 -3
- data/lib/rails/generators/alchemy/essence/essence_generator.rb +2 -3
- data/lib/rails/generators/alchemy/essence/templates/editor.html.erb +1 -1
- data/lib/rails/generators/alchemy/install/files/alchemy.de.yml +2 -2
- data/lib/rails/generators/alchemy/install/files/alchemy.en.yml +2 -2
- data/lib/rails/generators/alchemy/install/files/alchemy.es.yml +3 -3
- data/lib/rails/generators/alchemy/install/install_generator.rb +0 -1
- data/lib/rails/generators/alchemy/install/templates/elements.yml.tt +2 -2
- data/lib/rails/generators/alchemy/install/templates/page_layouts.yml.tt +1 -1
- data/lib/rails/generators/alchemy/module/module_generator.rb +1 -1
- data/lib/rails/templates/alchemy.rb +2 -2
- data/lib/tasks/alchemy/convert.rake +4 -8
- data/lib/tasks/alchemy/db.rake +2 -3
- data/lib/tasks/alchemy/install.rake +3 -4
- data/lib/tasks/alchemy/tidy.rake +4 -5
- data/lib/tasks/alchemy/upgrade.rake +2 -4
- data/spec/controllers/{admin → alchemy/admin}/attachments_controller_spec.rb +26 -44
- data/spec/controllers/{admin → alchemy/admin}/base_controller_spec.rb +14 -1
- data/spec/controllers/{admin → alchemy/admin}/clipboard_controller_spec.rb +3 -3
- data/spec/controllers/{admin → alchemy/admin}/contents_controller_spec.rb +4 -4
- data/spec/controllers/{admin → alchemy/admin}/dashboard_controller_spec.rb +11 -6
- data/spec/controllers/{admin → alchemy/admin}/elements_controller_spec.rb +54 -31
- data/spec/controllers/{admin → alchemy/admin}/essence_files_controller_spec.rb +8 -3
- data/spec/controllers/{admin → alchemy/admin}/essence_pictures_controller_spec.rb +3 -3
- data/spec/controllers/{admin → alchemy/admin}/languages_controller_spec.rb +13 -1
- data/spec/controllers/{admin → alchemy/admin}/layoutpages_controller_spec.rb +0 -6
- data/spec/controllers/{admin → alchemy/admin}/pages_controller_spec.rb +103 -35
- data/spec/controllers/{admin → alchemy/admin}/pictures_controller_spec.rb +133 -108
- data/spec/controllers/alchemy/admin/resources_controller_spec.rb +81 -0
- data/spec/controllers/{admin → alchemy/admin}/trash_controller_spec.rb +12 -13
- data/spec/controllers/alchemy/api/contents_controller_spec.rb +12 -13
- data/spec/controllers/alchemy/api/elements_controller_spec.rb +8 -9
- data/spec/controllers/alchemy/api/pages_controller_spec.rb +40 -7
- data/spec/controllers/{attachments_controller_spec.rb → alchemy/attachments_controller_spec.rb} +7 -7
- data/spec/controllers/alchemy/base_controller_spec.rb +106 -0
- data/spec/controllers/{elements_controller_spec.rb → alchemy/elements_controller_spec.rb} +4 -4
- data/spec/controllers/{messages_controller_spec.rb → alchemy/messages_controller_spec.rb} +14 -9
- data/spec/controllers/alchemy/on_page_layout_mixin_spec.rb +330 -0
- data/spec/controllers/{pages_controller_spec.rb → alchemy/pages_controller_spec.rb} +167 -89
- data/spec/controllers/{pictures_controller_spec.rb → alchemy/pictures_controller_spec.rb} +42 -20
- data/spec/dummy/app/models/dummy_user.rb +4 -0
- data/spec/dummy/app/views/alchemy/elements/_all_you_can_eat_view.html.erb +31 -0
- data/spec/dummy/app/views/alchemy/elements/_article_editor.html.erb +6 -10
- data/spec/dummy/app/views/alchemy/elements/_article_view.html.erb +9 -24
- data/spec/dummy/app/views/alchemy/elements/_bild_editor.html.erb +3 -0
- data/spec/dummy/app/views/alchemy/elements/_bild_view.html.erb +5 -0
- data/spec/dummy/app/views/alchemy/elements/_contactform_editor.html.erb +6 -0
- data/spec/dummy/app/views/alchemy/elements/_contactform_view.html.erb +16 -0
- data/spec/dummy/app/views/alchemy/elements/_download_editor.html.erb +3 -0
- data/spec/dummy/app/views/alchemy/elements/_download_view.html.erb +5 -0
- data/spec/dummy/app/views/alchemy/elements/_erb_element_editor.html.erb +3 -0
- data/spec/dummy/app/views/alchemy/elements/_erb_element_view.html.erb +5 -0
- data/spec/dummy/app/views/alchemy/elements/_header_editor.html.erb +3 -0
- data/spec/dummy/app/views/alchemy/elements/_header_view.html.erb +5 -0
- data/spec/dummy/app/views/alchemy/elements/_news_editor.html.erb +5 -0
- data/spec/dummy/app/views/alchemy/elements/_search_editor.html.erb +1 -0
- data/spec/dummy/app/views/alchemy/elements/_search_view.html.erb +4 -0
- data/spec/dummy/app/views/alchemy/elements/_slide_editor.html.erb +3 -0
- data/spec/dummy/app/views/alchemy/elements/_slide_view.html.erb +5 -0
- data/spec/dummy/app/views/alchemy/elements/_slider_editor.html.erb +2 -0
- data/spec/dummy/app/views/alchemy/elements/_slider_view.html.erb +4 -0
- data/spec/dummy/app/views/alchemy/elements/_text_editor.html.erb +3 -0
- data/spec/dummy/app/views/alchemy/elements/_text_view.html.erb +5 -0
- data/spec/dummy/app/views/alchemy/page_layouts/_standard.html.erb +1 -0
- data/spec/dummy/config/alchemy/elements.yml +10 -13
- data/spec/dummy/config/alchemy/page_layouts.yml +1 -1
- data/spec/dummy/config/initializers/alchemy.rb +1 -0
- data/spec/dummy/config/locales/kl.yml +2 -0
- data/spec/dummy/db/migrate/20150608204610_add_parent_element_id_to_alchemy_elements.rb +1 -0
- data/spec/dummy/db/migrate/20150729151825_add_link_text_to_alchemy_essence_files.rb +1 -0
- data/spec/dummy/db/migrate/20150906195818_add_locale_to_alchemy_languages.rb +1 -0
- data/spec/dummy/db/schema.rb +10 -6
- data/spec/factories.rb +13 -0
- data/spec/features/admin/admin_layout_spec.rb +14 -0
- data/spec/features/admin/dashboard_spec.rb +1 -2
- data/spec/features/admin/edit_elements_feature_spec.rb +36 -0
- data/spec/features/admin/language_tree_feature_spec.rb +7 -8
- data/spec/features/admin/languages_features_spec.rb +65 -0
- data/spec/features/admin/legacy_page_url_management_spec.rb +3 -3
- data/spec/features/admin/link_overlay_spec.rb +16 -17
- data/spec/features/admin/locale_select_feature_spec.rb +1 -1
- data/spec/features/admin/modules_integration_spec.rb +0 -1
- data/spec/features/admin/navigation_feature_spec.rb +11 -2
- data/spec/features/admin/page_creation_feature_spec.rb +5 -5
- data/spec/features/admin/page_editing_feature_spec.rb +6 -6
- data/spec/features/admin/picture_library_integration_spec.rb +3 -3
- data/spec/features/admin/resources_integration_spec.rb +7 -12
- data/spec/features/admin/site_select_feature_spec.rb +1 -2
- data/spec/features/admin/tinymce_feature_spec.rb +0 -1
- data/spec/features/page_feature_spec.rb +57 -158
- data/spec/features/page_redirects_spec.rb +358 -0
- data/spec/features/picture_security_spec.rb +1 -7
- data/spec/fixtures/animated.gif +0 -0
- data/spec/helpers/{admin → alchemy/admin}/attachments_helper_spec.rb +0 -0
- data/spec/helpers/{admin → alchemy/admin}/base_helper_spec.rb +39 -29
- data/spec/helpers/{admin → alchemy/admin}/contents_helper_spec.rb +4 -23
- data/spec/helpers/{admin → alchemy/admin}/elements_helper_spec.rb +141 -5
- data/spec/helpers/{admin → alchemy/admin}/essences_helper_spec.rb +69 -8
- data/spec/helpers/{admin → alchemy/admin}/navigation_helper_spec.rb +43 -37
- data/spec/helpers/{admin → alchemy/admin}/pages_helper_spec.rb +6 -38
- data/spec/helpers/{admin → alchemy/admin}/pictures_helper_spec.rb +0 -1
- data/spec/helpers/{admin → alchemy/admin}/tags_helper_spec.rb +1 -3
- data/spec/helpers/{base_helper_spec.rb → alchemy/base_helper_spec.rb} +1 -2
- data/spec/helpers/{elements_block_helper_spec.rb → alchemy/elements_block_helper_spec.rb} +3 -3
- data/spec/helpers/{elements_helper_spec.rb → alchemy/elements_helper_spec.rb} +18 -19
- data/spec/helpers/alchemy/essences_helper_spec.rb +85 -0
- data/spec/helpers/{pages_helper_spec.rb → alchemy/pages_helper_spec.rb} +125 -39
- data/spec/helpers/alchemy/picture_url_helpers_spec.rb +78 -0
- data/spec/helpers/{url_helper_spec.rb → alchemy/url_helper_spec.rb} +66 -40
- data/spec/libraries/config_spec.rb +2 -3
- data/spec/libraries/controller_actions_spec.rb +18 -18
- data/spec/libraries/i18n_spec.rb +7 -0
- data/spec/libraries/page_layout_spec.rb +13 -7
- data/spec/libraries/paths_spec.rb +15 -0
- data/spec/libraries/permissions_spec.rb +6 -7
- data/spec/libraries/resource_spec.rb +48 -75
- data/spec/libraries/resources_helper_spec.rb +55 -6
- data/spec/libraries/shell_spec.rb +0 -4
- data/spec/libraries/template_tracker_spec.rb +4 -13
- data/spec/libraries/tinymce_spec.rb +53 -9
- data/spec/mailers/{messages_spec.rb → alchemy/messages_spec.rb} +0 -2
- data/spec/models/{attachment_spec.rb → alchemy/attachment_spec.rb} +43 -20
- data/spec/models/{cell_spec.rb → alchemy/cell_spec.rb} +2 -3
- data/spec/models/{content_spec.rb → alchemy/content_spec.rb} +179 -70
- data/spec/models/{element_spec.rb → alchemy/element_spec.rb} +315 -70
- data/spec/models/{element_to_page_spec.rb → alchemy/element_to_page_spec.rb} +0 -1
- data/spec/models/{essence_boolean_spec.rb → alchemy/essence_boolean_spec.rb} +0 -0
- data/spec/models/{essence_date_spec.rb → alchemy/essence_date_spec.rb} +2 -3
- data/spec/models/{essence_file_spec.rb → alchemy/essence_file_spec.rb} +2 -5
- data/spec/models/{essence_html_spec.rb → alchemy/essence_html_spec.rb} +1 -1
- data/spec/models/{essence_link_spec.rb → alchemy/essence_link_spec.rb} +0 -0
- data/spec/models/{essence_picture_spec.rb → alchemy/essence_picture_spec.rb} +101 -29
- data/spec/models/{essence_richtext_spec.rb → alchemy/essence_richtext_spec.rb} +7 -2
- data/spec/models/{essence_select_spec.rb → alchemy/essence_select_spec.rb} +0 -0
- data/spec/models/{essence_text_spec.rb → alchemy/essence_text_spec.rb} +4 -8
- data/spec/models/alchemy/language_spec.rb +243 -0
- data/spec/models/{legacy_page_url_spec.rb → alchemy/legacy_page_url_spec.rb} +1 -1
- data/spec/models/{message_spec.rb → alchemy/message_spec.rb} +0 -0
- data/spec/models/{page_spec.rb → alchemy/page_spec.rb} +460 -248
- data/spec/models/{picture_spec.rb → alchemy/picture_spec.rb} +118 -30
- data/spec/models/{site_spec.rb → alchemy/site_spec.rb} +19 -84
- data/spec/models/{tag_spec.rb → alchemy/tag_spec.rb} +1 -3
- data/spec/models/dummy_model_spec.rb +1 -2
- data/spec/requests/alchemy/admin/resources_requests_spec.rb +26 -0
- data/spec/requests/alchemy/admin/site_requests_spec.rb +19 -0
- data/spec/requests/alchemy/site_requests_spec.rb +18 -0
- data/spec/requests/alchemy/sitemap_spec.rb +56 -0
- data/spec/routing/api_routing_spec.rb +1 -1
- data/spec/routing/routing_spec.rb +121 -15
- data/spec/spec_helper.rb +2 -1
- data/spec/support/hint_examples.rb +1 -3
- data/spec/support/test_tweaks.rb +3 -3
- data/spec/support/transformation_examples.rb +6 -7
- data/spec/tasks/helpers_spec.rb +2 -4
- data/spec/views/admin/pictures/show_spec.rb +43 -0
- data/spec/views/essences/essence_boolean_editor_spec.rb +0 -1
- data/spec/views/essences/essence_boolean_view_spec.rb +2 -4
- data/spec/views/essences/essence_date_view_spec.rb +0 -1
- data/spec/views/essences/essence_file_editor_spec.rb +4 -6
- data/spec/views/essences/essence_file_view_spec.rb +56 -3
- data/spec/views/essences/essence_link_view_spec.rb +1 -1
- data/spec/views/essences/essence_picture_editor_spec.rb +80 -0
- data/spec/views/essences/essence_picture_view_spec.rb +0 -1
- data/spec/views/essences/essence_select_view_spec.rb +0 -1
- data/spec/views/essences/essence_text_view_spec.rb +0 -1
- data/vendor/assets/javascripts/handlebars.js +4608 -0
- data/vendor/assets/javascripts/tinymce/langs/de.js +19 -0
- data/vendor/assets/javascripts/tinymce/langs/es.js +19 -0
- data/vendor/assets/javascripts/tinymce/langs/fr.js +23 -4
- data/vendor/assets/javascripts/tinymce/langs/nl.js +22 -3
- data/vendor/assets/javascripts/tinymce/langs/ru.js +22 -3
- data/vendor/assets/javascripts/tinymce/plugins/paste/plugin.min.js +1 -1
- data/vendor/assets/javascripts/tinymce/plugins/table/plugin.min.js +1 -1
- data/vendor/assets/javascripts/tinymce/themes/modern/theme.min.js +1 -1
- data/vendor/assets/javascripts/tinymce/tinymce.min.js +12 -13
- metadata +274 -256
- data/app/views/alchemy/admin/attachments/create.js.erb +0 -11
- data/app/views/alchemy/admin/attachments/new.html.erb +0 -14
- data/app/views/alchemy/admin/elements/_element_foot.html.erb +0 -36
- data/app/views/alchemy/admin/partials/_upload_form.html.erb +0 -67
- data/app/views/alchemy/admin/pictures/info.html.erb +0 -38
- data/app/views/alchemy/admin/pictures/new.html.erb +0 -16
- data/lib/alchemy/middleware/rescue_old_cookies.rb +0 -27
- data/spec/controllers/admin/resources_controller_spec.rb +0 -53
- data/spec/controllers/base_controller_spec.rb +0 -51
- data/spec/helpers/essences_helper_spec.rb +0 -156
- data/spec/helpers/picture_url_helpers_spec.rb +0 -35
- data/spec/libraries/on_page_layout_spec.rb +0 -112
- data/spec/models/language_spec.rb +0 -123
@@ -1,42 +1,39 @@
|
|
1
1
|
module Alchemy
|
2
2
|
module Admin
|
3
|
-
class PicturesController < Alchemy::Admin::
|
3
|
+
class PicturesController < Alchemy::Admin::ResourcesController
|
4
|
+
include UploaderResponses
|
5
|
+
|
4
6
|
helper 'alchemy/admin/tags'
|
5
7
|
|
6
|
-
before_action :
|
7
|
-
only: [:show, :edit, :update, :
|
8
|
+
before_action :load_resource,
|
9
|
+
only: [:show, :edit, :update, :destroy, :info]
|
8
10
|
|
9
11
|
authorize_resource class: Alchemy::Picture
|
10
12
|
|
11
13
|
def index
|
12
14
|
@size = params[:size].present? ? params[:size] : 'medium'
|
13
|
-
@
|
15
|
+
@query = Picture.ransack(params[:q])
|
16
|
+
@pictures = Picture.search_by(params, @query, pictures_per_page_for_size(@size))
|
17
|
+
|
14
18
|
if in_overlay?
|
15
19
|
archive_overlay
|
16
20
|
end
|
17
21
|
end
|
18
22
|
|
19
|
-
def
|
20
|
-
@
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
end
|
23
|
+
def show
|
24
|
+
@previous = @picture.previous(params)
|
25
|
+
@next = @picture.next(params)
|
26
|
+
@pages = @picture.essence_pictures.group_by(&:page)
|
27
|
+
render action: 'show'
|
25
28
|
end
|
26
29
|
|
27
30
|
def create
|
28
31
|
@picture = Picture.new(picture_params)
|
29
32
|
@picture.name = @picture.humanized_name
|
30
33
|
if @picture.save
|
31
|
-
|
32
|
-
if in_overlay?
|
33
|
-
set_instance_variables
|
34
|
-
end
|
35
|
-
message = _t('Picture uploaded succesfully', name: @picture.name)
|
36
|
-
render json: {files: [@picture.to_jq_upload], growl_message: message}, status: :created
|
34
|
+
render succesful_uploader_response(file: @picture)
|
37
35
|
else
|
38
|
-
|
39
|
-
render json: {files: [@picture.to_jq_upload], growl_message: message}, status: :unprocessable_entity
|
36
|
+
render failed_uploader_response(file: @picture)
|
40
37
|
end
|
41
38
|
end
|
42
39
|
|
@@ -46,12 +43,18 @@ module Alchemy
|
|
46
43
|
end
|
47
44
|
|
48
45
|
def update
|
49
|
-
if @picture.
|
50
|
-
|
46
|
+
if @picture.update(picture_params)
|
47
|
+
@message = {
|
48
|
+
body: Alchemy.t(:picture_updated_successfully, name: @picture.name),
|
49
|
+
type: 'notice'
|
50
|
+
}
|
51
51
|
else
|
52
|
-
|
52
|
+
@message = {
|
53
|
+
body: Alchemy.t(:picture_update_failed),
|
54
|
+
type: 'error'
|
55
|
+
}
|
53
56
|
end
|
54
|
-
|
57
|
+
render :update
|
55
58
|
end
|
56
59
|
|
57
60
|
def update_multiple
|
@@ -59,7 +62,7 @@ module Alchemy
|
|
59
62
|
@pictures.each do |picture|
|
60
63
|
picture.update_name_and_tag_list!(params)
|
61
64
|
end
|
62
|
-
flash[:notice] =
|
65
|
+
flash[:notice] = Alchemy.t("Pictures updated successfully")
|
63
66
|
redirect_to_index
|
64
67
|
end
|
65
68
|
|
@@ -77,14 +80,17 @@ module Alchemy
|
|
77
80
|
end
|
78
81
|
end
|
79
82
|
if not_deletable.any?
|
80
|
-
flash[:warn] =
|
83
|
+
flash[:warn] = Alchemy.t(
|
84
|
+
"These pictures could not be deleted, because they were in use",
|
85
|
+
names: not_deletable.to_sentence
|
86
|
+
)
|
81
87
|
else
|
82
|
-
flash[:notice] =
|
88
|
+
flash[:notice] = Alchemy.t("Pictures deleted successfully", names: names.to_sentence)
|
83
89
|
end
|
84
90
|
else
|
85
|
-
flash[:warn] =
|
91
|
+
flash[:warn] = Alchemy.t("Could not delete Pictures")
|
86
92
|
end
|
87
|
-
rescue
|
93
|
+
rescue => e
|
88
94
|
flash[:error] = e.message
|
89
95
|
ensure
|
90
96
|
redirect_to_index
|
@@ -93,24 +99,20 @@ module Alchemy
|
|
93
99
|
def destroy
|
94
100
|
name = @picture.name
|
95
101
|
@picture.destroy
|
96
|
-
flash[:notice] =
|
97
|
-
rescue
|
102
|
+
flash[:notice] = Alchemy.t("Picture deleted successfully", name: name)
|
103
|
+
rescue => e
|
98
104
|
flash[:error] = e.message
|
99
105
|
ensure
|
100
|
-
|
106
|
+
redirect_to_index
|
101
107
|
end
|
102
108
|
|
103
109
|
def flush
|
104
110
|
FileUtils.rm_rf Rails.root.join('public', Alchemy::MountPoint.get, 'pictures')
|
105
|
-
@notice =
|
111
|
+
@notice = Alchemy.t('Picture cache flushed')
|
106
112
|
end
|
107
113
|
|
108
114
|
private
|
109
115
|
|
110
|
-
def load_picture
|
111
|
-
@picture = Picture.find(params[:id])
|
112
|
-
end
|
113
|
-
|
114
116
|
def pictures_per_page_for_size(size)
|
115
117
|
case size
|
116
118
|
when 'small'
|
@@ -120,7 +122,7 @@ module Alchemy
|
|
120
122
|
else
|
121
123
|
per_page = in_overlay? ? 9 : (per_page_value_for_screen_size / 1.0).ceil + 4
|
122
124
|
end
|
123
|
-
|
125
|
+
per_page
|
124
126
|
end
|
125
127
|
|
126
128
|
def in_overlay?
|
@@ -138,31 +140,18 @@ module Alchemy
|
|
138
140
|
end
|
139
141
|
|
140
142
|
def redirect_to_index
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
143
|
+
do_redirect_to admin_pictures_path(
|
144
|
+
filter: params[:filter].presence,
|
145
|
+
page: params[:page].presence,
|
146
|
+
q: params[:q].presence,
|
147
|
+
size: params[:size].presence,
|
148
|
+
tagged_with: params[:tagged_with].presence
|
146
149
|
)
|
147
150
|
end
|
148
151
|
|
149
152
|
def picture_params
|
150
153
|
params.require(:picture).permit(:image_file, :upload_hash, :name, :tag_list)
|
151
154
|
end
|
152
|
-
|
153
|
-
def set_size_or_default
|
154
|
-
@size = params[:size] || 'medium'
|
155
|
-
end
|
156
|
-
|
157
|
-
def set_instance_variables
|
158
|
-
@while_assigning = true
|
159
|
-
@content = Content.select('id').find_by(id: params[:content_id])
|
160
|
-
@element = Element.select('id').find_by(id: params[:element_id])
|
161
|
-
@options = options_from_params
|
162
|
-
@page = params[:page] || 1
|
163
|
-
@per_page = pictures_per_page_for_size(@size)
|
164
|
-
end
|
165
|
-
|
166
155
|
end
|
167
156
|
end
|
168
157
|
end
|
@@ -1,7 +1,6 @@
|
|
1
1
|
require 'csv'
|
2
2
|
require 'alchemy/resource'
|
3
3
|
require 'alchemy/resources_helper'
|
4
|
-
require 'handles_sortable_columns'
|
5
4
|
|
6
5
|
module Alchemy
|
7
6
|
module Admin
|
@@ -18,22 +17,12 @@ module Alchemy
|
|
18
17
|
authorize!(action_name.to_sym, resource_instance_variable || resource_handler.model)
|
19
18
|
end
|
20
19
|
|
21
|
-
handles_sortable_columns do |c|
|
22
|
-
c.default_sort_value = :name
|
23
|
-
c.link_class = 'sortable'
|
24
|
-
c.indicator_class = {:asc => "sorted asc", :desc => "sorted desc"}
|
25
|
-
c.indicator_text = {:asc => "<i> ↓ </i>", :desc => "<i> ↑ </i>"}
|
26
|
-
end
|
27
|
-
|
28
20
|
def index
|
29
|
-
|
21
|
+
@query = resource_handler.model.ransack(params[:q])
|
22
|
+
items = @query.result
|
30
23
|
if contains_relations?
|
31
24
|
items = items.includes(*resource_relations_names)
|
32
25
|
end
|
33
|
-
if params[:query].present?
|
34
|
-
items = query_items(items)
|
35
|
-
end
|
36
|
-
items = items.order(sort_order)
|
37
26
|
respond_to do |format|
|
38
27
|
format.html {
|
39
28
|
items = items.page(params[:page] || 1).per(per_page_value_for_screen_size)
|
@@ -60,7 +49,7 @@ module Alchemy
|
|
60
49
|
resource_instance_variable.save
|
61
50
|
render_errors_or_redirect(
|
62
51
|
resource_instance_variable,
|
63
|
-
resources_path,
|
52
|
+
resources_path(resource_handler.resources_name, current_location_params),
|
64
53
|
flash_notice_for_resource_action
|
65
54
|
)
|
66
55
|
end
|
@@ -69,7 +58,7 @@ module Alchemy
|
|
69
58
|
resource_instance_variable.update_attributes(resource_params)
|
70
59
|
render_errors_or_redirect(
|
71
60
|
resource_instance_variable,
|
72
|
-
resources_path,
|
61
|
+
resources_path(resource_handler.resources_name, current_location_params),
|
73
62
|
flash_notice_for_resource_action
|
74
63
|
)
|
75
64
|
end
|
@@ -77,7 +66,7 @@ module Alchemy
|
|
77
66
|
def destroy
|
78
67
|
resource_instance_variable.destroy
|
79
68
|
flash_notice_for_resource_action
|
80
|
-
do_redirect_to resource_url_proxy.url_for(action: 'index')
|
69
|
+
do_redirect_to resource_url_proxy.url_for(current_location_params.merge(action: 'index'))
|
81
70
|
end
|
82
71
|
|
83
72
|
def resource_handler
|
@@ -98,76 +87,21 @@ module Alchemy
|
|
98
87
|
when :destroy
|
99
88
|
verb = "removed"
|
100
89
|
end
|
101
|
-
flash[:notice] =
|
90
|
+
flash[:notice] = Alchemy.t("#{resource_handler.resource_name.classify} successfully #{verb}", default: Alchemy.t("Succesfully #{verb}"))
|
102
91
|
end
|
103
92
|
|
104
93
|
def is_alchemy_module?
|
105
|
-
|
94
|
+
!alchemy_module.nil? && !alchemy_module['engine_name'].nil?
|
106
95
|
end
|
107
96
|
|
108
97
|
def alchemy_module
|
109
|
-
@alchemy_module ||= module_definition_for(:
|
98
|
+
@alchemy_module ||= module_definition_for(controller: params[:controller], action: 'index')
|
110
99
|
end
|
111
100
|
|
112
101
|
def load_resource
|
113
102
|
instance_variable_set("@#{resource_handler.resource_name}", resource_handler.model.find(params[:id]))
|
114
103
|
end
|
115
104
|
|
116
|
-
# Returns a sort order for AR#sort method
|
117
|
-
#
|
118
|
-
# Falls back to fallback_sort_order, if the requested column is not a column of model.
|
119
|
-
#
|
120
|
-
# If the column is a tablename and column combination that matches any resource relations, than this order will be taken.
|
121
|
-
#
|
122
|
-
def sort_order
|
123
|
-
sortable_column_order do |column, direction|
|
124
|
-
if resource_handler.model_associations.present? && column.match(/\./)
|
125
|
-
table, column = column.split('.')
|
126
|
-
if resource_handler.model_associations.detect { |a| a.table_name == table }
|
127
|
-
"#{table}.#{column} #{direction}"
|
128
|
-
else
|
129
|
-
fallback_sort_order(direction)
|
130
|
-
end
|
131
|
-
elsif resource_handler.model.column_names.include?(column.to_s)
|
132
|
-
"#{resource_handler.model.table_name}.#{column} #{direction}"
|
133
|
-
else
|
134
|
-
fallback_sort_order(direction)
|
135
|
-
end
|
136
|
-
end
|
137
|
-
end
|
138
|
-
|
139
|
-
# Default sort order fallback
|
140
|
-
#
|
141
|
-
# Overwrite this in your controller to define custom fallback
|
142
|
-
#
|
143
|
-
def fallback_sort_order(direction)
|
144
|
-
"#{resource_handler.model.table_name}.id #{direction}"
|
145
|
-
end
|
146
|
-
|
147
|
-
# Returns an activerecord object that contains items matching params[:query]
|
148
|
-
#
|
149
|
-
def query_items(items)
|
150
|
-
query = params[:query].downcase.split(' ').join('%')
|
151
|
-
query = ActiveRecord::Base.sanitize("%#{query}%")
|
152
|
-
items.eager_load(resource_handler.model_association_names).where(search_query(query))
|
153
|
-
end
|
154
|
-
|
155
|
-
# Returns a search query string
|
156
|
-
#
|
157
|
-
# It queries all searchable attributes from resource model via LIKE and joins them via OR.
|
158
|
-
#
|
159
|
-
# If the attribute is a relation it builds the query for the associated table.
|
160
|
-
#
|
161
|
-
def search_query(search_terms)
|
162
|
-
resource_handler.searchable_attributes.map do |attribute|
|
163
|
-
if relation = attribute[:relation]
|
164
|
-
"LOWER(#{relation[:model_association].klass.table_name}.#{relation[:attr_method]}) LIKE #{search_terms}"
|
165
|
-
else
|
166
|
-
"LOWER(#{resource_handler.model.table_name}.#{attribute[:name]}) LIKE #{search_terms}"
|
167
|
-
end
|
168
|
-
end.join(" OR ")
|
169
|
-
end
|
170
|
-
|
171
105
|
# Permits all parameters as default!
|
172
106
|
#
|
173
107
|
# THIS IS INSECURE! Although only signed in admin users can send requests anyway, but we should change this.
|
@@ -179,7 +113,6 @@ module Alchemy
|
|
179
113
|
def resource_params
|
180
114
|
params.require(resource_handler.namespaced_resource_name).permit!
|
181
115
|
end
|
182
|
-
|
183
116
|
end
|
184
117
|
end
|
185
118
|
end
|
@@ -4,9 +4,12 @@ module Alchemy
|
|
4
4
|
before_filter :load_tag, only: [:edit, :update, :destroy]
|
5
5
|
|
6
6
|
def index
|
7
|
-
@
|
8
|
-
|
9
|
-
|
7
|
+
@query = ActsAsTaggableOn::Tag.ransack(params[:q])
|
8
|
+
@tags = @query
|
9
|
+
.result
|
10
|
+
.page(params[:page] || 1)
|
11
|
+
.per(per_page_value_for_screen_size)
|
12
|
+
.order("name ASC")
|
10
13
|
end
|
11
14
|
|
12
15
|
def new
|
@@ -15,7 +18,7 @@ module Alchemy
|
|
15
18
|
|
16
19
|
def create
|
17
20
|
@tag = ActsAsTaggableOn::Tag.create(tag_params)
|
18
|
-
render_errors_or_redirect @tag, admin_tags_path,
|
21
|
+
render_errors_or_redirect @tag, admin_tags_path, Alchemy.t('New Tag Created')
|
19
22
|
end
|
20
23
|
|
21
24
|
def edit
|
@@ -26,12 +29,12 @@ module Alchemy
|
|
26
29
|
if tag_params[:merge_to]
|
27
30
|
@new_tag = ActsAsTaggableOn::Tag.find(tag_params[:merge_to])
|
28
31
|
Tag.replace(@tag, @new_tag)
|
29
|
-
operation_text =
|
32
|
+
operation_text = Alchemy.t('Replaced Tag') % {old_tag: @tag.name, new_tag: @new_tag.name}
|
30
33
|
@tag.destroy
|
31
34
|
else
|
32
35
|
@tag.update_attributes(tag_params)
|
33
36
|
@tag.save
|
34
|
-
operation_text =
|
37
|
+
operation_text = Alchemy.t(:successfully_updated_tag)
|
35
38
|
end
|
36
39
|
render_errors_or_redirect @tag, admin_tags_path, operation_text
|
37
40
|
end
|
@@ -39,7 +42,7 @@ module Alchemy
|
|
39
42
|
def destroy
|
40
43
|
if request.delete?
|
41
44
|
@tag.destroy
|
42
|
-
flash[:notice] =
|
45
|
+
flash[:notice] = Alchemy.t(:successfully_deleted_tag)
|
43
46
|
end
|
44
47
|
do_redirect_to admin_tags_path
|
45
48
|
end
|
@@ -70,7 +73,6 @@ module Alchemy
|
|
70
73
|
{id: value, text: value}
|
71
74
|
end
|
72
75
|
end
|
73
|
-
|
74
76
|
end
|
75
77
|
end
|
76
78
|
end
|
@@ -1,7 +1,6 @@
|
|
1
1
|
module Alchemy
|
2
2
|
module Admin
|
3
3
|
class TrashController < Alchemy::Admin::BaseController
|
4
|
-
|
5
4
|
helper "alchemy/admin/elements"
|
6
5
|
|
7
6
|
authorize_resource class: false
|
@@ -10,10 +9,6 @@ module Alchemy
|
|
10
9
|
@elements = Element.trashed
|
11
10
|
@page = Page.find(params[:page_id])
|
12
11
|
@allowed_elements = @page.available_element_definitions
|
13
|
-
@draggable_trash_items = {}
|
14
|
-
@elements.each do |element|
|
15
|
-
@draggable_trash_items["element_#{element.id}"] = element.available_page_cell_names(@page)
|
16
|
-
end
|
17
12
|
end
|
18
13
|
|
19
14
|
def clear
|
@@ -21,7 +16,6 @@ module Alchemy
|
|
21
16
|
@elements = Element.trashed
|
22
17
|
@elements.map(&:destroy)
|
23
18
|
end
|
24
|
-
|
25
19
|
end
|
26
20
|
end
|
27
21
|
end
|
@@ -25,7 +25,10 @@ module Alchemy
|
|
25
25
|
|
26
26
|
def load_page
|
27
27
|
@page = Page.find_by(id: params[:id]) ||
|
28
|
-
|
28
|
+
Language.current.pages.find_by(
|
29
|
+
urlname: params[:urlname],
|
30
|
+
language_code: params[:locale] || Language.current.code
|
31
|
+
) ||
|
29
32
|
raise(ActiveRecord::RecordNotFound)
|
30
33
|
end
|
31
34
|
end
|
@@ -5,8 +5,8 @@ module Alchemy
|
|
5
5
|
|
6
6
|
# sends file inline. i.e. for viewing pdfs/movies in browser
|
7
7
|
def show
|
8
|
-
|
9
|
-
@attachment.file.
|
8
|
+
send_file(
|
9
|
+
@attachment.file.path,
|
10
10
|
{
|
11
11
|
filename: @attachment.file_name,
|
12
12
|
type: @attachment.file_mime_type,
|
@@ -17,8 +17,8 @@ module Alchemy
|
|
17
17
|
|
18
18
|
# sends file as attachment. aka download
|
19
19
|
def download
|
20
|
-
|
21
|
-
@attachment.file.
|
20
|
+
send_file(
|
21
|
+
@attachment.file.path, {
|
22
22
|
filename: @attachment.file_name,
|
23
23
|
type: @attachment.file_mime_type
|
24
24
|
}
|
@@ -30,6 +30,5 @@ module Alchemy
|
|
30
30
|
def load_attachment
|
31
31
|
@attachment = Attachment.find(params[:id])
|
32
32
|
end
|
33
|
-
|
34
33
|
end
|
35
34
|
end
|