browsercms 3.5.7 → 4.0.0.alpha
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/COPYRIGHT.txt +2 -1
- data/README.markdown +3 -3
- data/app/assets/fonts/icomoon.dev.svg +61 -0
- data/app/assets/fonts/icomoon.eot +0 -0
- data/app/assets/fonts/icomoon.svg +61 -0
- data/app/assets/fonts/icomoon.ttf +0 -0
- data/app/assets/fonts/icomoon.woff +0 -0
- data/app/assets/images/ckeditor/plugins/delete_content/icons/deletecontent.png +0 -0
- data/app/assets/images/ckeditor/plugins/edit_content/icons/editcontent.png +0 -0
- data/app/assets/images/ckeditor/plugins/move_content/icons/movecontentdown.png +0 -0
- data/app/assets/images/ckeditor/plugins/move_content/icons/movecontentup.png +0 -0
- data/app/assets/images/cms/arrow-down.png +0 -0
- data/app/assets/images/cms/arrow-up.png +0 -0
- data/app/assets/images/cms/cogs.png +0 -0
- data/app/assets/images/cms/dashboard/home.png +0 -0
- data/app/assets/images/cms/home.png +0 -0
- data/app/assets/images/cms/logo.png +0 -0
- data/app/assets/images/cms/pencil.png +0 -0
- data/app/assets/images/cms/plus.png +0 -0
- data/app/assets/images/cms/user.png +0 -0
- data/app/assets/javascripts/bcms/ckeditor_inline.js +23 -0
- data/app/assets/javascripts/bcms/ckeditor_standard_config.js +1 -1
- data/app/assets/javascripts/ckeditor/plugins/delete_content/plugin.js +36 -0
- data/app/assets/javascripts/ckeditor/plugins/edit_content/plugin.js +24 -0
- data/app/assets/javascripts/ckeditor/plugins/move_content/plugin.js +25 -0
- data/app/assets/javascripts/cms/ajax.js +60 -0
- data/app/assets/javascripts/cms/application.js +6 -1
- data/app/assets/javascripts/cms/attachment_manager.js.erb +3 -10
- data/app/assets/javascripts/cms/content_library.js +31 -12
- data/app/assets/javascripts/cms/core_library.js.erb +68 -36
- data/app/assets/javascripts/cms/form_builder.js +250 -0
- data/app/assets/javascripts/cms/namespace.js +2 -0
- data/app/assets/javascripts/cms/new_content_button.js +27 -0
- data/app/assets/javascripts/cms/page_editor.js +188 -0
- data/app/assets/javascripts/cms/page_toolbar.js +13 -0
- data/app/assets/javascripts/cms/site.js +2 -0
- data/app/assets/javascripts/cms/sitemap.js +219 -0
- data/app/assets/javascripts/cms/toolbar.js +17 -1
- data/app/assets/javascripts/cms/user.js +40 -0
- data/app/assets/javascripts/jquery.exists.js +5 -0
- data/app/assets/javascripts/jquery.taglist.js +37 -23
- data/app/assets/stylesheets/cms/_assets.css.scss +55 -0
- data/app/assets/stylesheets/cms/_base.css.scss +42 -0
- data/app/assets/stylesheets/cms/_cms-buttons.css.scss +73 -0
- data/app/assets/stylesheets/cms/_cms-forms.css.scss +70 -0
- data/app/assets/stylesheets/cms/_colors.css.scss +20 -0
- data/app/assets/stylesheets/cms/_dashboard.css.scss +25 -0
- data/app/assets/stylesheets/cms/_glyph.css.scss +60 -0
- data/app/assets/stylesheets/cms/_main-area.css.scss +62 -0
- data/app/assets/stylesheets/cms/_nav.css.scss +197 -0
- data/app/assets/stylesheets/cms/_sidebar.css.scss +64 -0
- data/app/assets/stylesheets/cms/_sitemap.css.scss +196 -0
- data/app/assets/stylesheets/cms/_submenu.css.scss +48 -0
- data/app/assets/stylesheets/cms/application.css.scss +49 -0
- data/app/assets/stylesheets/cms/core.css.scss +96 -0
- data/app/assets/stylesheets/cms/default-forms.css.scss +3 -0
- data/app/assets/stylesheets/cms/includes/_animation.css.scss +2 -0
- data/app/assets/stylesheets/cms/includes/_rem.css.scss +120 -0
- data/app/assets/stylesheets/cms/includes/animation/_animate.css.scss +31 -0
- data/app/assets/stylesheets/cms/includes/animation/_core.css.scss +127 -0
- data/app/assets/stylesheets/cms/includes/animation/_shared.css.scss +22 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_attention-seekers.css.scss +152 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_bouncing.css.scss +3 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_classes.css.scss +21 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_fading.css.scss +3 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_flippers.css.scss +87 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_lightspeed.css.scss +24 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_rotating.css.scss +3 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_specials.css.scss +42 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/bouncing/_bouncing-entrances.css.scss +68 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/bouncing/_bouncing-exits.css.scss +60 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/fading/_fading-entrances.css.scss +86 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/fading/_fading-exits.css.scss +86 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/rotating/_rotating-entrances.css.scss +58 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/rotating/_rotating-exits.css.scss +58 -0
- data/app/assets/stylesheets/cms/page_content_editing.css.scss +4 -0
- data/app/assets/stylesheets/cms/page_editor.css.scss +4 -0
- data/app/assets/stylesheets/cms/style.css.scss +138 -0
- data/app/assets/stylesheets/cms/styles/_alerts.css.scss +150 -0
- data/app/assets/stylesheets/cms/styles/_base-grid.css.scss +299 -0
- data/app/assets/stylesheets/cms/styles/_buttons.css.scss +247 -0
- data/app/assets/stylesheets/cms/styles/_dropdown.css.scss +155 -0
- data/app/assets/stylesheets/cms/styles/_forms.css.scss +728 -0
- data/app/assets/stylesheets/cms/styles/_glyph.css.scss +86 -0
- data/app/assets/stylesheets/cms/styles/_images.css.scss +75 -0
- data/app/assets/stylesheets/cms/styles/_lists.css.scss +115 -0
- data/app/assets/stylesheets/cms/styles/_modal.css.scss +174 -0
- data/app/assets/stylesheets/cms/styles/_progress.css.scss +43 -0
- data/app/assets/stylesheets/cms/styles/_tables.css.scss +141 -0
- data/app/assets/stylesheets/cms/styles/_text.css.scss +134 -0
- data/app/controllers/cms/application_controller.rb +3 -68
- data/app/controllers/cms/attachments_controller.rb +5 -5
- data/app/controllers/cms/base_controller.rb +20 -13
- data/app/controllers/cms/cache_controller.rb +16 -17
- data/app/controllers/cms/category_types_controller.rb +6 -1
- data/app/controllers/cms/connectors_controller.rb +12 -7
- data/app/controllers/cms/content_block_controller.rb +128 -71
- data/app/controllers/cms/content_controller.rb +54 -56
- data/app/controllers/cms/dashboard_controller.rb +5 -6
- data/app/controllers/cms/dynamic_views_controller.rb +12 -9
- data/app/controllers/cms/email_messages_controller.rb +18 -13
- data/app/controllers/cms/form_entries_controller.rb +119 -0
- data/app/controllers/cms/form_fields_controller.rb +74 -0
- data/app/controllers/cms/forms_controller.rb +35 -0
- data/app/controllers/cms/groups_controller.rb +13 -16
- data/app/controllers/cms/html_blocks_controller.rb +2 -2
- data/app/controllers/cms/inline_content_controller.rb +48 -0
- data/app/controllers/cms/links_controller.rb +58 -46
- data/app/controllers/cms/page_components_controller.rb +20 -0
- data/app/controllers/cms/page_routes_controller.rb +44 -40
- data/app/controllers/cms/pages_controller.rb +111 -97
- data/app/controllers/cms/passwords_controller.rb +17 -0
- data/app/controllers/cms/portlet_controller.rb +0 -1
- data/app/controllers/cms/portlets_controller.rb +20 -27
- data/app/controllers/cms/redirects_controller.rb +13 -9
- data/app/controllers/cms/resource_controller.rb +15 -4
- data/app/controllers/cms/routes_controller.rb +2 -4
- data/app/controllers/cms/section_nodes_controller.rb +6 -37
- data/app/controllers/cms/sections_controller.rb +13 -8
- data/app/controllers/cms/sessions_controller.rb +8 -66
- data/app/controllers/cms/sites/passwords_controller.rb +27 -0
- data/app/controllers/cms/sites/sessions_controller.rb +20 -0
- data/app/controllers/cms/tags_controller.rb +12 -12
- data/app/controllers/cms/tasks_controller.rb +45 -46
- data/app/controllers/cms/user_controller.rb +8 -0
- data/app/controllers/cms/users_controller.rb +91 -68
- data/app/helpers/cms/application_helper.rb +58 -52
- data/app/helpers/cms/content_block_helper.rb +8 -7
- data/app/helpers/cms/form_tag_helper.rb +21 -25
- data/app/helpers/cms/menu_helper.rb +1 -3
- data/app/helpers/cms/mobile_helper.rb +12 -2
- data/app/helpers/cms/nav_menu_helper.rb +23 -0
- data/app/helpers/cms/page_helper.rb +72 -30
- data/app/helpers/cms/path_helper.rb +46 -70
- data/app/helpers/cms/rendering_helper.rb +68 -12
- data/app/helpers/cms/section_nodes_helper.rb +92 -31
- data/app/helpers/cms/sites/authentication_helper.rb +25 -0
- data/app/helpers/cms/sites/devise_shim_helper.rb +31 -0
- data/app/helpers/cms/template_support.rb +1 -7
- data/app/helpers/cms/ui_elements_helper.rb +147 -6
- data/app/helpers/forgot_password_portlet_helper.rb +9 -0
- data/app/helpers/login_portlet_helper.rb +10 -0
- data/app/inputs/attachments_input.rb +14 -0
- data/app/inputs/cms_text_area_input.rb +10 -0
- data/app/inputs/cms_text_field_input.rb +29 -0
- data/app/inputs/date_picker_input.rb +8 -0
- data/app/inputs/file_picker_input.rb +75 -0
- data/app/inputs/path_input.rb +18 -0
- data/app/inputs/tag_list_input.rb +3 -0
- data/app/inputs/template_editor_input.rb +24 -0
- data/app/inputs/text_editor_input.rb +19 -0
- data/app/models/cms/abstract_file_block.rb +10 -6
- data/app/models/cms/attachment.rb +20 -27
- data/app/models/cms/category.rb +17 -7
- data/app/models/cms/category_type.rb +8 -4
- data/app/models/cms/connector.rb +32 -20
- data/app/models/cms/content.rb +31 -0
- data/app/models/cms/content_type.rb +114 -62
- data/app/models/cms/dynamic_view.rb +19 -45
- data/app/models/cms/email_message.rb +32 -2
- data/app/models/cms/external_user.rb +60 -0
- data/app/models/cms/file_block.rb +1 -0
- data/app/models/cms/form.rb +47 -0
- data/app/models/cms/form_entry.rb +71 -0
- data/app/models/cms/form_field.rb +78 -0
- data/app/models/cms/group.rb +19 -9
- data/app/models/cms/group_permission.rb +1 -1
- data/app/models/cms/group_section.rb +1 -1
- data/app/models/cms/group_type.rb +5 -5
- data/app/models/cms/group_type_permission.rb +1 -1
- data/app/models/cms/html_block.rb +14 -19
- data/app/models/cms/image_block.rb +1 -0
- data/app/models/cms/link.rb +8 -6
- data/app/models/cms/page.rb +156 -59
- data/app/models/cms/page_component.rb +43 -0
- data/app/models/cms/page_partial.rb +16 -8
- data/app/models/cms/page_route.rb +1 -1
- data/app/models/cms/page_route_condition.rb +1 -1
- data/app/models/cms/page_route_option.rb +1 -1
- data/app/models/cms/page_route_requirement.rb +1 -1
- data/app/models/cms/page_template.rb +14 -9
- data/app/models/cms/permission.rb +4 -2
- data/app/models/cms/persistent_user.rb +208 -0
- data/app/models/cms/portlet.rb +56 -9
- data/app/models/cms/redirect.rb +1 -1
- data/app/models/cms/search_filter.rb +18 -0
- data/app/models/cms/section.rb +39 -28
- data/app/models/cms/section_node.rb +32 -5
- data/app/models/cms/site.rb +3 -3
- data/app/models/cms/tag.rb +14 -12
- data/app/models/cms/tagging.rb +2 -2
- data/app/models/cms/task.rb +14 -21
- data/app/models/cms/templates.rb +1 -2
- data/app/models/cms/user.rb +21 -160
- data/app/models/cms/user_group_membership.rb +2 -2
- data/app/portlets/deprecated_placeholder.rb +12 -0
- data/app/portlets/dynamic_portlet.rb +1 -1
- data/app/portlets/email_page_portlet.rb +10 -3
- data/app/portlets/forgot_password_portlet.rb +9 -28
- data/app/portlets/login_portlet.rb +8 -5
- data/app/portlets/tag_cloud_portlet.rb +3 -1
- data/app/presenters/cms/user_presenter.rb +24 -0
- data/app/views/cms/application/_add_content_modal.html.erb +3 -0
- data/app/views/cms/application/_buttons.html.erb +7 -0
- data/app/views/cms/{shared → application}/_exception.html.erb +0 -0
- data/app/views/cms/application/_form_errors.html.erb +7 -0
- data/app/views/cms/application/_form_with_buttons.html.erb +10 -0
- data/app/views/cms/application/_main_content.html.erb +3 -0
- data/app/views/cms/application/_main_with_sidebar.html.erb +8 -0
- data/app/views/cms/application/_mobile_toolbar.html.erb +16 -0
- data/app/views/cms/application/_page_title.html.erb +5 -0
- data/app/views/cms/application/_pagination.html.erb +26 -0
- data/app/views/cms/application/_row.html.erb +1 -0
- data/app/views/cms/application/_save_buttons.html.erb +7 -0
- data/app/views/cms/application/_sidebar_layout.html.erb +3 -0
- data/app/views/cms/application/_version.html.erb +23 -0
- data/app/views/cms/{shared → application}/_version_conflict_diff.html.erb +0 -0
- data/app/views/cms/{shared → application}/_version_conflict_error.html.erb +0 -0
- data/app/views/cms/attachments/_attachment_manager.html.erb +22 -0
- data/app/views/cms/attachments/_no_attachments_defined.html.erb +1 -0
- data/app/views/cms/cache/show.html.erb +5 -10
- data/app/views/cms/categories/_form.html.erb +15 -24
- data/app/views/cms/category_types/_form.html.erb +1 -1
- data/app/views/cms/connectors/new.html.erb +33 -64
- data/app/views/cms/content/editing_frame.html.erb +1 -0
- data/app/views/cms/content/no_page.html.erb +9 -27
- data/app/views/cms/content/show.html.erb +14 -15
- data/app/views/cms/content_block/_block_form.html.erb +15 -0
- data/app/views/cms/content_block/_buttonbar.html.erb +29 -0
- data/app/views/cms/content_block/_buttons.html.erb +13 -0
- data/app/views/cms/content_block/_hidden_fields.html.erb +13 -0
- data/app/views/cms/content_block/_sidebar.html.erb +35 -0
- data/app/views/cms/content_block/edit.html.erb +3 -0
- data/app/views/cms/content_block/index.html.erb +87 -0
- data/app/views/cms/content_block/new.html.erb +3 -0
- data/app/views/cms/content_block/render_block_in_main_container.html.erb +10 -0
- data/app/views/cms/content_block/show.html.erb +1 -0
- data/app/views/cms/content_block/show_in_isolation.html.erb +15 -0
- data/app/views/cms/content_block/versions.html.erb +24 -0
- data/app/views/cms/dashboard/_page_drafts.html.erb +12 -22
- data/app/views/cms/dashboard/_tasks.html.erb +32 -45
- data/app/views/cms/dashboard/index.html.erb +11 -13
- data/app/views/cms/dynamic_views/_form.html.erb +8 -10
- data/app/views/cms/dynamic_views/edit.html.erb +2 -3
- data/app/views/cms/dynamic_views/index.html.erb +22 -44
- data/app/views/cms/dynamic_views/new.html.erb +2 -3
- data/app/views/cms/email_messages/index.html.erb +31 -34
- data/app/views/cms/email_messages/show.html.erb +45 -52
- data/app/views/cms/file_blocks/_form.html.erb +2 -4
- data/app/views/cms/form_entries/_buttons.html.erb +2 -0
- data/app/views/cms/form_entries/_form.html.erb +7 -0
- data/app/views/cms/form_entries/_internal_form.html.erb +9 -0
- data/app/views/cms/form_entries/edit.html.erb +5 -0
- data/app/views/cms/form_entries/error.html.erb +3 -0
- data/app/views/cms/form_entries/index.html.erb +4 -0
- data/app/views/cms/form_entries/new.html.erb +5 -0
- data/app/views/cms/form_entries/show.html.erb +13 -0
- data/app/views/cms/form_entries/submit.html.erb +1 -0
- data/app/views/cms/form_fields/_form.html.erb +8 -0
- data/app/views/cms/form_fields/_select.html.erb +3 -0
- data/app/views/cms/form_fields/_text_area.html.erb +3 -0
- data/app/views/cms/form_fields/_text_field.html.erb +3 -0
- data/app/views/cms/form_fields/edit.html.erb +0 -0
- data/app/views/cms/form_fields/new.html.erb +26 -0
- data/app/views/cms/form_fields/preview.html.erb +16 -0
- data/app/views/cms/forms/_form.html.erb +66 -0
- data/app/views/cms/forms/render.html.erb +15 -0
- data/app/views/cms/forms/show.html.erb +6 -0
- data/app/views/cms/groups/_form.html.erb +32 -38
- data/app/views/cms/groups/_permissions.html.erb +11 -34
- data/app/views/cms/groups/_sections.html.erb +11 -17
- data/app/views/cms/groups/edit.html.erb +1 -3
- data/app/views/cms/groups/index.html.erb +10 -32
- data/app/views/cms/groups/new.html.erb +2 -4
- data/app/views/cms/html_blocks/_form.html.erb +2 -2
- data/app/views/cms/html_blocks/render.html.erb +1 -1
- data/app/views/cms/image_blocks/_form.html.erb +3 -3
- data/app/views/cms/links/_form.html.erb +6 -11
- data/app/views/cms/links/edit.html.erb +3 -12
- data/app/views/cms/links/new.html.erb +4 -13
- data/app/views/cms/page_components/_content.html.erb +18 -0
- data/app/views/cms/page_components/new.html.erb +12 -0
- data/app/views/cms/page_routes/_form.html.erb +11 -10
- data/app/views/cms/page_routes/edit.html.erb +2 -3
- data/app/views/cms/page_routes/index.html.erb +25 -48
- data/app/views/cms/page_routes/new.html.erb +2 -3
- data/app/views/cms/pages/_edit_content.html.erb +28 -0
- data/app/views/cms/pages/_form.html.erb +20 -37
- data/app/views/cms/pages/_main_form.html.erb +23 -0
- data/app/views/cms/pages/_simple_container.html.erb +8 -0
- data/app/views/cms/pages/edit.html.erb +2 -23
- data/app/views/cms/pages/new.html.erb +2 -16
- data/app/views/cms/pages/versions.html.erb +18 -87
- data/app/views/cms/redirects/_form.html.erb +6 -14
- data/app/views/cms/redirects/edit.html.erb +2 -3
- data/app/views/cms/redirects/index.html.erb +24 -50
- data/app/views/cms/redirects/new.html.erb +2 -3
- data/app/views/cms/routes/index.html.erb +15 -20
- data/app/views/cms/section_nodes/_children.html.erb +3 -0
- data/app/views/cms/section_nodes/_row_buttons.html.erb +11 -0
- data/app/views/cms/section_nodes/_section_node.html.erb +24 -10
- data/app/views/cms/section_nodes/_sitemap_buttons.html.erb +47 -0
- data/app/views/cms/section_nodes/_status.html.erb +5 -0
- data/app/views/cms/section_nodes/show.html.erb +9 -0
- data/app/views/cms/sections/_buttons.html.erb +6 -0
- data/app/views/cms/sections/_form.html.erb +22 -49
- data/app/views/cms/sections/edit.html.erb +3 -8
- data/app/views/cms/sections/new.html.erb +4 -20
- data/app/views/cms/sessions/new.html.erb +16 -31
- data/app/views/cms/shared/access_denied.html.erb +1 -2
- data/app/views/cms/shared/error.html.erb +5 -5
- data/app/views/cms/sites/_flash.html.erb +8 -0
- data/app/views/cms/sites/passwords/new.html.erb +2 -0
- data/app/views/cms/sites/sessions/new.html.erb +2 -0
- data/app/views/cms/tags/_form.html.erb +1 -1
- data/app/views/cms/tags/render.html.erb +0 -1
- data/app/views/cms/tasks/new.html.erb +18 -32
- data/app/views/cms/toolbar/_new_pages_menu.html.erb +10 -0
- data/app/views/cms/users/_form.html.erb +8 -11
- data/app/views/cms/users/_password.html.erb +2 -8
- data/app/views/cms/users/_user_fields.html.erb +7 -20
- data/app/views/cms/users/change_password.html.erb +12 -21
- data/app/views/cms/users/edit.html.erb +1 -15
- data/app/views/cms/users/index.html.erb +61 -58
- data/app/views/cms/users/new.html.erb +1 -12
- data/app/views/devise/confirmations/new.html.erb +16 -0
- data/app/views/devise/mailer/confirmation_instructions.html.erb +5 -0
- data/app/views/devise/mailer/reset_password_instructions.html.erb +8 -0
- data/app/views/devise/mailer/unlock_instructions.html.erb +7 -0
- data/app/views/devise/passwords/edit.html.erb +19 -0
- data/app/views/devise/passwords/new.html.erb +15 -0
- data/app/views/devise/registrations/edit.html.erb +28 -0
- data/app/views/devise/registrations/new.html.erb +18 -0
- data/app/views/devise/shared/_links.erb +25 -0
- data/app/views/devise/unlocks/new.html.erb +16 -0
- data/app/views/layouts/cms/_content_types.html.erb +13 -0
- data/app/views/layouts/cms/_footer.erb +2 -2
- data/app/views/layouts/cms/_head.html.erb +8 -18
- data/app/views/layouts/cms/_main_menu.html.erb +78 -0
- data/app/views/layouts/cms/application.html.erb +19 -24
- data/app/views/layouts/cms/content_page.html.erb +5 -0
- data/app/views/layouts/cms/page_editor.html.erb +90 -0
- data/app/views/portlets/deprecated_placeholders/_form.html.erb +1 -0
- data/app/views/portlets/deprecated_placeholders/render.html.erb +8 -0
- data/app/views/portlets/dynamic/_form.html.erb +3 -3
- data/app/views/portlets/email_page/_form.html.erb +5 -6
- data/app/views/portlets/forgot_password/_form.html.erb +2 -3
- data/app/views/portlets/forgot_password/render.html.erb +2 -14
- data/app/views/portlets/login/_form.html.erb +4 -6
- data/app/views/portlets/login/render.html.erb +8 -27
- data/app/views/portlets/portlets/_form.html.erb +7 -6
- data/app/views/portlets/tag_cloud/_form.html.erb +4 -4
- data/app/views/tests/pretend/open_with_layout.html.erb +1 -1
- data/bin/bcms +13 -16
- data/config/routes.rb +58 -29
- data/db/browsercms.seeds.rb +0 -6
- data/db/migrate/{20080815014337_browsercms_3_0_0.rb → 20080815014337_browsercms300.rb} +94 -73
- data/db/migrate/20130327184912_browsercms400.rb +90 -0
- data/db/migrate/20131206214021_devise_create_users.rb +47 -0
- data/db/migrate/20131211223908_kill_reset_password.rb +5 -0
- data/db/migrate/20131218222005_create_cms_external_users.rb +10 -0
- data/doc/features/design_integration.md +45 -0
- data/doc/features/external_user.md +7 -0
- data/doc/features/form_builder.md +40 -0
- data/doc/features/simple_form_refactor.md +60 -0
- data/doc/release_notes.md +224 -10
- data/lib/acts_as_list.rb +72 -71
- data/lib/browsercms.rb +41 -1
- data/lib/cms/acts/content_block.rb +12 -2
- data/lib/cms/acts/content_page.rb +3 -4
- data/lib/cms/admin_tab.rb +15 -0
- data/lib/cms/attachments/configuration.rb +1 -1
- data/lib/cms/authentication/controller.rb +83 -177
- data/lib/cms/authentication/test_password_strategy.rb +19 -0
- data/lib/cms/behaviors.rb +1 -0
- data/lib/cms/behaviors/archiving.rb +2 -2
- data/lib/cms/behaviors/attaching.rb +21 -45
- data/lib/cms/behaviors/connecting.rb +14 -4
- data/lib/cms/behaviors/dynamic_attributes.rb +3 -3
- data/lib/cms/behaviors/hiding.rb +2 -2
- data/lib/cms/behaviors/namespacing.rb +6 -36
- data/lib/cms/behaviors/publishing.rb +92 -45
- data/lib/cms/behaviors/rendering.rb +15 -7
- data/lib/cms/behaviors/searching.rb +5 -4
- data/lib/cms/behaviors/soft_deleting.rb +13 -16
- data/lib/cms/behaviors/taggable.rb +17 -10
- data/lib/cms/behaviors/versioning.rb +12 -16
- data/lib/cms/commands/to_version400.rb +10 -0
- data/lib/cms/concerns.rb +7 -0
- data/lib/cms/concerns/can_be_addressable.rb +326 -0
- data/lib/cms/concerns/has_content_type.rb +46 -0
- data/lib/cms/concerns/ignores_publishing.rb +9 -0
- data/lib/cms/configuration.rb +14 -4
- data/lib/cms/configuration/configurable_template.rb +24 -0
- data/lib/cms/configuration/devise.rb +256 -0
- data/lib/cms/configure_simple_form.rb +142 -0
- data/lib/cms/configure_simple_form_bootstrap.rb +49 -0
- data/lib/cms/content_filter.rb +18 -0
- data/lib/cms/content_page.rb +77 -0
- data/lib/cms/content_rendering_support.rb +25 -16
- data/lib/cms/controllers/admin_controller.rb +78 -0
- data/lib/cms/data_loader.rb +30 -11
- data/lib/cms/default_accessible.rb +6 -6
- data/lib/cms/domain_support.rb +0 -4
- data/lib/cms/engine.rb +52 -20
- data/lib/cms/engine_helper.rb +41 -51
- data/{app/controllers → lib}/cms/error_handling.rb +11 -5
- data/lib/cms/extensions.rb +2 -1
- data/lib/cms/extensions/active_model/name.rb +13 -0
- data/lib/cms/extensions/active_record/connection_adapters/abstract/schema_statements.rb +49 -89
- data/lib/cms/extensions/hash.rb +0 -12
- data/lib/cms/form_builder/content_block_form_builder.rb +45 -0
- data/lib/cms/form_builder/default_input.rb +13 -0
- data/lib/cms/form_builder/deprecated_inputs.rb +40 -0
- data/lib/cms/form_builder/workflow_buttons.rb +38 -0
- data/lib/cms/module.rb +1 -7
- data/lib/cms/polymorphic_single_table_inheritance.rb +19 -0
- data/lib/cms/publish_workflow.rb +26 -0
- data/lib/cms/responders/content_responder.rb +14 -0
- data/lib/cms/route_extensions.rb +112 -20
- data/lib/cms/version.rb +1 -1
- data/lib/generators/browser_cms/demo_site/templates/demo.seeds.rb +0 -2
- data/lib/generators/cms/content_block/content_block_generator.rb +19 -46
- data/lib/generators/cms/content_block/templates/_form.html.erb +22 -28
- data/lib/generators/cms/project/templates/devise.rb.erb +7 -0
- metadata +383 -150
- data/app/assets/javascripts/cms/sitemap.js.erb +0 -464
- data/app/assets/stylesheets/browsercms/application.css +0 -7
- data/app/assets/stylesheets/cms/administration.css.erb +0 -91
- data/app/assets/stylesheets/cms/application.css.erb +0 -171
- data/app/assets/stylesheets/cms/attachment_manager.css.scss +0 -28
- data/app/assets/stylesheets/cms/block.css +0 -26
- data/app/assets/stylesheets/cms/buttons.css.erb +0 -120
- data/app/assets/stylesheets/cms/content_library.css.erb +0 -139
- data/app/assets/stylesheets/cms/content_types.css +0 -4
- data/app/assets/stylesheets/cms/dashboard.css.erb +0 -118
- data/app/assets/stylesheets/cms/data_table.css.erb.erb +0 -156
- data/app/assets/stylesheets/cms/date_picker.css.erb +0 -82
- data/app/assets/stylesheets/cms/form_layout.css.erb +0 -282
- data/app/assets/stylesheets/cms/login.css.erb +0 -78
- data/app/assets/stylesheets/cms/menu.css.erb +0 -116
- data/app/assets/stylesheets/cms/nav.css.erb +0 -99
- data/app/assets/stylesheets/cms/page_toolbar.css.erb +0 -135
- data/app/assets/stylesheets/cms/reset.css +0 -46
- data/app/assets/stylesheets/cms/selectbox.css.erb +0 -56
- data/app/assets/stylesheets/cms/sitemap.css.erb +0 -390
- data/app/assets/stylesheets/cms/taglist.css +0 -18
- data/app/controllers/application_controller.rb +0 -14
- data/app/controllers/cms/content_types_controller.rb +0 -9
- data/app/helpers/application_helper.rb +0 -5
- data/app/helpers/cms/form_builder.rb +0 -241
- data/app/models/cms/content_type_group.rb +0 -15
- data/app/models/cms/forgot_password_mailer.rb +0 -14
- data/app/portlets/reset_password_portlet.rb +0 -28
- data/app/views/cms/blocks/_hidden_fields.html.erb +0 -10
- data/app/views/cms/blocks/_toolbar.html.erb +0 -9
- data/app/views/cms/blocks/_toolbar_for_collection.html.erb +0 -23
- data/app/views/cms/blocks/_toolbar_for_member.html.erb +0 -36
- data/app/views/cms/blocks/edit.html.erb +0 -28
- data/app/views/cms/blocks/index.html.erb +0 -86
- data/app/views/cms/blocks/new.html.erb +0 -19
- data/app/views/cms/blocks/show.html.erb +0 -43
- data/app/views/cms/blocks/usages.html.erb +0 -44
- data/app/views/cms/blocks/versions.html.erb +0 -90
- data/app/views/cms/content_types/index.html.erb +0 -14
- data/app/views/cms/form_builder/_cms_attachment_manager.html.erb +0 -27
- data/app/views/cms/form_builder/_cms_check_box.html.erb +0 -7
- data/app/views/cms/form_builder/_cms_date_picker.html.erb +0 -12
- data/app/views/cms/form_builder/_cms_datetime_select.html.erb +0 -12
- data/app/views/cms/form_builder/_cms_drop_down.html.erb +0 -12
- data/app/views/cms/form_builder/_cms_fancy_drop_down.html.erb +0 -9
- data/app/views/cms/form_builder/_cms_file_field.html.erb +0 -28
- data/app/views/cms/form_builder/_cms_instructions.html.erb +0 -4
- data/app/views/cms/form_builder/_cms_tag_list.html.erb +0 -15
- data/app/views/cms/form_builder/_cms_template_editor.html.erb +0 -9
- data/app/views/cms/form_builder/_cms_text_area.html.erb +0 -10
- data/app/views/cms/form_builder/_cms_text_editor.html.erb +0 -19
- data/app/views/cms/form_builder/_cms_text_field.html.erb +0 -12
- data/app/views/cms/links/destroy.js.rjs +0 -2
- data/app/views/cms/page_routes/show.html.erb +0 -10
- data/app/views/cms/pages/_edit_connector.html.erb +0 -19
- data/app/views/cms/pages/_edit_container.html.erb +0 -11
- data/app/views/cms/section_nodes/_link.html.erb +0 -14
- data/app/views/cms/section_nodes/_node.html.erb +0 -44
- data/app/views/cms/section_nodes/_page.html.erb +0 -20
- data/app/views/cms/section_nodes/_section.html.erb +0 -28
- data/app/views/cms/section_nodes/index.html.erb +0 -43
- data/app/views/cms/sections/_page.html.erb +0 -4
- data/app/views/cms/sections/_section.html.erb +0 -8
- data/app/views/cms/sections/destroy.js.rjs +0 -2
- data/app/views/cms/sections/index.html.erb +0 -23
- data/app/views/cms/shared/_admin_sidebar.html.erb +0 -36
- data/app/views/cms/shared/_pagination.html.erb +0 -31
- data/app/views/cms/toolbar/_mobile_toggle.html.erb +0 -33
- data/app/views/cms/toolbar/index.html.erb +0 -1
- data/app/views/cms/users/_groups.html.erb +0 -12
- data/app/views/cms/users/_toolbar.html.erb +0 -24
- data/app/views/cms/users/show.html.erb +0 -50
- data/app/views/layouts/_cms_toolbar.html.erb +0 -54
- data/app/views/layouts/_page_toolbar.html.erb +0 -119
- data/app/views/layouts/cms/administration.html.erb +0 -51
- data/app/views/layouts/cms/content_library.html.erb +0 -96
- data/app/views/layouts/cms/dashboard.html.erb +0 -16
- data/app/views/layouts/cms/login.html.erb +0 -31
- data/app/views/layouts/cms/section_nodes.html.erb +0 -20
- data/app/views/layouts/cms/toolbar.html.erb +0 -23
- data/app/views/portlets/reset_password/_form.html.erb +0 -3
- data/app/views/portlets/reset_password/render.html.erb +0 -22
- data/bin/bcms-upgrade +0 -332
- data/db/migrate/20091109175123_browsercms_3_0_5.rb +0 -9
- data/db/migrate/20100117144038_browsercms314.rb +0 -20
- data/db/migrate/20100117144039_browsercms315.rb +0 -95
- data/db/migrate/20100705083859_browsercms_3_3_0.rb +0 -56
- data/db/migrate/20111130221145_browsercms340.rb +0 -56
- data/db/migrate/20120329144406_browsercms350.rb +0 -32
- data/db/migrate/20120717182827_browsercms353.rb +0 -19
- data/db/migrate/20120813180110_browsercms354.rb +0 -9
- data/lib/cms/addressable.rb +0 -93
- data/lib/cms/authentication/model.rb +0 -116
- data/lib/cms/behaviors/pagination.rb +0 -212
- data/lib/cms/upgrades/v3_4_0.rb +0 -31
- data/lib/cms/upgrades/v3_5_0.rb +0 -227
@@ -1,24 +1,23 @@
|
|
1
1
|
module Cms
|
2
|
-
class CacheController < Cms::BaseController
|
3
|
-
layout 'cms/administration'
|
4
|
-
|
5
|
-
check_permissions :administrate
|
6
|
-
before_filter :set_menu_section
|
2
|
+
class CacheController < Cms::BaseController
|
7
3
|
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
4
|
+
include Cms::AdminTab
|
5
|
+
check_permissions :administrate
|
6
|
+
|
7
|
+
def show
|
8
|
+
|
9
|
+
end
|
10
|
+
|
11
|
+
def destroy
|
12
|
+
Cms::Cache.flush
|
13
|
+
flash[:notice] = "Page Cache Flushed"
|
14
|
+
redirect_to :action => "show"
|
15
|
+
end
|
16
|
+
|
17
|
+
private
|
19
18
|
def set_menu_section
|
20
19
|
@menu_section = 'caching'
|
21
20
|
end
|
22
21
|
|
23
|
-
end
|
22
|
+
end
|
24
23
|
end
|
@@ -1,7 +1,12 @@
|
|
1
1
|
module Cms
|
2
2
|
class CategoryTypesController < Cms::ContentBlockController
|
3
3
|
def show
|
4
|
-
redirect_to
|
4
|
+
redirect_to edit_category_type_path(id: params[:id])
|
5
|
+
end
|
6
|
+
|
7
|
+
def create
|
8
|
+
params[:_redirect_to] = category_types_path
|
9
|
+
super
|
5
10
|
end
|
6
11
|
end
|
7
12
|
end
|
@@ -1,14 +1,13 @@
|
|
1
1
|
module Cms
|
2
2
|
class ConnectorsController < Cms::BaseController
|
3
3
|
|
4
|
-
before_filter :set_toolbar_tab
|
5
4
|
before_filter :load_page, :only => [:new, :create]
|
6
5
|
|
7
6
|
def new
|
8
7
|
@block_type = ContentType.find_by_key(params[:block_type] || session[:last_block_type] || 'html_block')
|
9
8
|
@container = params[:container]
|
10
9
|
@connector = @page.connectors.build(:container => @container)
|
11
|
-
@blocks = @block_type.model_class.
|
10
|
+
@blocks = @block_type.model_class.where(["deleted = ?", false]).order("name")
|
12
11
|
end
|
13
12
|
|
14
13
|
def create
|
@@ -32,7 +31,10 @@ class ConnectorsController < Cms::BaseController
|
|
32
31
|
else
|
33
32
|
flash[:error] = "Failed to remove '#{@connectable.name}' from the '#{@connector.container}' container"
|
34
33
|
end
|
35
|
-
|
34
|
+
respond_to do |format|
|
35
|
+
format.html { redirect_to @page.path }
|
36
|
+
format.json { render :json => @connector }
|
37
|
+
end
|
36
38
|
end
|
37
39
|
|
38
40
|
{ #Define actions for moving connectors around
|
@@ -50,7 +52,12 @@ class ConnectorsController < Cms::BaseController
|
|
50
52
|
else
|
51
53
|
flash[:error] = "Failed to move '#{@connectable.name}' #{where} the '#{@connector.container}' container"
|
52
54
|
end
|
53
|
-
|
55
|
+
|
56
|
+
respond_to do |format|
|
57
|
+
format.html { redirect_to @page.path }
|
58
|
+
format.json { render :json => @connector }
|
59
|
+
end
|
60
|
+
|
54
61
|
end
|
55
62
|
end
|
56
63
|
|
@@ -58,8 +65,6 @@ class ConnectorsController < Cms::BaseController
|
|
58
65
|
def load_page
|
59
66
|
@page = Page.find(params[:page_id])
|
60
67
|
end
|
61
|
-
|
62
|
-
@toolbar_tab = :content_library
|
63
|
-
end
|
68
|
+
|
64
69
|
end
|
65
70
|
end
|
@@ -3,29 +3,72 @@ require 'cms/category_type'
|
|
3
3
|
# This is the base class for other content blocks
|
4
4
|
module Cms
|
5
5
|
class ContentBlockController < Cms::BaseController
|
6
|
+
include Cms::ContentRenderingSupport
|
6
7
|
|
7
|
-
|
8
|
+
allow_guests_to [:show_via_slug]
|
8
9
|
|
9
|
-
|
10
|
-
|
11
|
-
helper_method :block_form, :new_block_path, :block_path, :blocks_path, :content_type
|
10
|
+
helper_method :block_form, :content_type
|
12
11
|
helper Cms::RenderingHelper
|
13
|
-
|
12
|
+
helper do
|
13
|
+
|
14
|
+
# Addressable content types don't allow for Mobile Optimized templates.
|
15
|
+
def mobile_template_exists?(block)
|
16
|
+
false
|
17
|
+
end
|
18
|
+
end
|
19
|
+
include Cms::PublishWorkflow
|
14
20
|
|
15
21
|
def index
|
16
22
|
load_blocks
|
17
|
-
render "#{template_directory}/index"
|
18
23
|
end
|
19
24
|
|
25
|
+
def bulk_update
|
26
|
+
ids = params[:content_id] || []
|
27
|
+
models = ids.collect do |id|
|
28
|
+
model_class.find(id.to_i)
|
29
|
+
end
|
30
|
+
if params[:commit] == 'Delete'
|
31
|
+
deleted = models.select do |m|
|
32
|
+
m.destroy
|
33
|
+
end
|
34
|
+
flash[:notice] = "Deleted #{deleted.size} records."
|
35
|
+
else
|
36
|
+
# Need to do these one at a time since the code logic is more complex than single UPDATE.
|
37
|
+
published = models.select do |m|
|
38
|
+
m.publish!
|
39
|
+
end
|
40
|
+
|
41
|
+
flash[:notice] = "Published #{published.size} records."
|
42
|
+
end
|
43
|
+
|
44
|
+
redirect_to action: :index
|
45
|
+
end
|
46
|
+
|
47
|
+
# Getting content by its path (i.e. /products/:slug)
|
48
|
+
def show_via_slug
|
49
|
+
@block = model_class.with_slug(params[:slug])
|
50
|
+
unless @block
|
51
|
+
raise Cms::Errors::ContentNotFound.new("No Content at #{model_class.calculate_path(params[:slug])}")
|
52
|
+
end
|
53
|
+
render_block_in_main_container
|
54
|
+
end
|
55
|
+
|
56
|
+
# Getting content by its id (i.e. /products/:id)
|
57
|
+
# Logged in editors will get the editing frame.
|
20
58
|
def show
|
21
59
|
load_block_draft
|
22
|
-
|
60
|
+
render_editing_frame_or_block_in_main_container
|
61
|
+
end
|
62
|
+
|
63
|
+
# Getting the content for the editing frame.
|
64
|
+
def inline
|
65
|
+
load_block_draft
|
66
|
+
render_block_in_main_container
|
23
67
|
end
|
24
68
|
|
25
69
|
def new
|
26
70
|
build_block
|
27
71
|
set_default_category
|
28
|
-
render "#{template_directory}/new"
|
29
72
|
end
|
30
73
|
|
31
74
|
def create
|
@@ -41,7 +84,6 @@ module Cms
|
|
41
84
|
|
42
85
|
def edit
|
43
86
|
load_block_draft
|
44
|
-
render "#{template_directory}/edit"
|
45
87
|
end
|
46
88
|
|
47
89
|
def update
|
@@ -59,21 +101,25 @@ module Cms
|
|
59
101
|
|
60
102
|
def destroy
|
61
103
|
do_command("deleted") { @block.destroy }
|
62
|
-
|
104
|
+
respond_to do |format|
|
105
|
+
format.html { redirect_to_first params[:_redirect_to], engine_aware_path(@block.class) }
|
106
|
+
format.json { render :json => {:success => true} }
|
107
|
+
end
|
108
|
+
|
63
109
|
end
|
64
110
|
|
65
111
|
# Additional CMS Action
|
66
112
|
|
67
113
|
def publish
|
68
114
|
do_command("published") { @block.publish! }
|
69
|
-
redirect_to_first params[:_redirect_to],
|
115
|
+
redirect_to_first params[:_redirect_to], engine_aware_path(@block, nil)
|
70
116
|
end
|
71
117
|
|
72
118
|
def revert_to
|
73
119
|
do_command("reverted to version #{params[:version]}") do
|
74
120
|
revert_block(params[:version])
|
75
121
|
end
|
76
|
-
redirect_to_first params[:_redirect_to],
|
122
|
+
redirect_to_first params[:_redirect_to], engine_aware_path(@block, nil)
|
77
123
|
end
|
78
124
|
|
79
125
|
def version
|
@@ -81,26 +127,22 @@ module Cms
|
|
81
127
|
if params[:version]
|
82
128
|
@block = @block.as_of_version(params[:version])
|
83
129
|
end
|
84
|
-
render "
|
130
|
+
render "show_in_isolation"
|
85
131
|
end
|
86
132
|
|
87
133
|
def versions
|
88
134
|
if model_class.versioned?
|
89
135
|
load_block
|
90
|
-
render "#{template_directory}/versions"
|
91
136
|
else
|
92
137
|
render :text => "Not Implemented", :status => :not_implemented
|
93
138
|
end
|
94
139
|
end
|
95
140
|
|
96
|
-
def
|
97
|
-
|
98
|
-
@pages = @block.connected_pages.all(:order => 'name')
|
99
|
-
render "#{template_directory}/usages"
|
141
|
+
def new_button_path
|
142
|
+
new_engine_aware_path(content_type)
|
100
143
|
end
|
101
144
|
|
102
145
|
protected
|
103
|
-
# methods that are used to detemine what content block type we are dealing with
|
104
146
|
|
105
147
|
def content_type_name
|
106
148
|
self.class.name.sub(/Controller/, '').singularize
|
@@ -115,55 +157,55 @@ module Cms
|
|
115
157
|
end
|
116
158
|
|
117
159
|
def model_form_name
|
118
|
-
content_type.
|
160
|
+
content_type.param_key
|
161
|
+
end
|
162
|
+
alias :resource_param :model_form_name
|
163
|
+
|
164
|
+
def resource
|
165
|
+
@block ||= find_block
|
119
166
|
end
|
120
167
|
|
121
168
|
# methods for loading one or a collection of blocks
|
122
169
|
|
123
170
|
def load_blocks
|
171
|
+
@search_filter = SearchFilter.build(params[:search_filter], model_class)
|
172
|
+
|
124
173
|
options = {}
|
125
|
-
|
126
|
-
options[:include] = {:attachments => :section_node}
|
127
|
-
options[:conditions] = ["#{Namespacing.prefix("section_nodes")}.ancestry = ?", Section.find(params[:section_id]).ancestry_path]
|
128
|
-
end
|
174
|
+
|
129
175
|
options[:page] = params[:page]
|
130
176
|
options[:order] = model_class.default_order if model_class.respond_to?(:default_order)
|
131
177
|
options[:order] = params[:order] unless params[:order].blank?
|
132
178
|
|
133
179
|
scope = model_class.respond_to?(:list) ? model_class.list : model_class
|
134
|
-
|
180
|
+
if scope.searchable?
|
181
|
+
scope = scope.search(@search_filter.term)
|
182
|
+
end
|
183
|
+
if params[:section_id] && model_class.respond_to?(:with_parent_id)
|
184
|
+
scope = scope.with_parent_id(params[:section_id])
|
185
|
+
end
|
186
|
+
@total_number_of_items = scope.count
|
187
|
+
@blocks = scope.paginate(options)
|
135
188
|
check_permissions
|
189
|
+
|
136
190
|
end
|
137
191
|
|
138
192
|
def load_block
|
139
|
-
|
193
|
+
find_block
|
140
194
|
check_permissions
|
141
195
|
end
|
142
196
|
|
143
|
-
def
|
197
|
+
def find_block
|
144
198
|
@block = model_class.find(params[:id])
|
199
|
+
end
|
200
|
+
|
201
|
+
def load_block_draft
|
202
|
+
find_block
|
145
203
|
@block = @block.as_of_draft_version if model_class.versioned?
|
146
204
|
check_permissions
|
147
205
|
end
|
148
206
|
|
149
207
|
# path related methods - available in the view as helpers
|
150
208
|
|
151
|
-
def new_block_path(block, options={})
|
152
|
-
cms_new_path_for(block, options)
|
153
|
-
end
|
154
|
-
|
155
|
-
def block_path(block, action=nil)
|
156
|
-
path = []
|
157
|
-
path << engine_for(block)
|
158
|
-
path << action if action
|
159
|
-
path.concat path_elements_for(block)
|
160
|
-
path
|
161
|
-
end
|
162
|
-
|
163
|
-
def blocks_path(options={})
|
164
|
-
cms_index_path_for(@content_type.model_class, options)
|
165
|
-
end
|
166
|
-
|
167
209
|
# This is the partial that will be used in the form
|
168
210
|
def block_form
|
169
211
|
@content_type.form
|
@@ -171,10 +213,9 @@ module Cms
|
|
171
213
|
|
172
214
|
|
173
215
|
def build_block
|
174
|
-
|
175
|
-
@block = model_class.new(
|
176
|
-
|
177
|
-
# Recover from an Exception thrown during binding of parameters to model class
|
216
|
+
if params[model_form_name]
|
217
|
+
@block = model_class.new(model_params)
|
218
|
+
else
|
178
219
|
# Need to make sure @block exists for form helpers to correctly generate paths
|
179
220
|
@block = model_class.new unless @block
|
180
221
|
end
|
@@ -198,12 +239,12 @@ module Cms
|
|
198
239
|
if @block.class.connectable? && @block.connected_page
|
199
240
|
redirect_to @block.connected_page.path
|
200
241
|
else
|
201
|
-
redirect_to_first params[:_redirect_to],
|
242
|
+
redirect_to_first params[:_redirect_to], engine_aware_path(@block)
|
202
243
|
end
|
203
244
|
end
|
204
245
|
|
205
246
|
def after_create_on_failure
|
206
|
-
render "
|
247
|
+
render "new"
|
207
248
|
end
|
208
249
|
|
209
250
|
def after_create_on_error
|
@@ -216,26 +257,28 @@ module Cms
|
|
216
257
|
after_update_on_failure
|
217
258
|
end
|
218
259
|
|
219
|
-
# Print the underlying stack trace to the logs for debugging.
|
220
|
-
# Should be human readable (i.e. line breaks)
|
221
|
-
# See http://stackoverflow.com/questions/228441/how-do-i-log-the-entire-trace-back-of-a-ruby-exception-using-the-default-rails-l for discussion of implementation
|
222
|
-
def log_complete_stacktrace(exception)
|
223
|
-
logger.error "#{exception.message}\n#{exception.backtrace.join("\n")}"
|
224
|
-
end
|
225
260
|
|
226
261
|
# update related methods
|
227
262
|
def update_block
|
228
263
|
load_block
|
229
|
-
@block.update_attributes(
|
264
|
+
@block.update_attributes(model_params())
|
265
|
+
end
|
266
|
+
|
267
|
+
# Returns the parameters for the block to be saved.
|
268
|
+
# Handles defaults as well as eventually 'strong_params'
|
269
|
+
def model_params
|
270
|
+
defaults = {"publish_on_save" => false}
|
271
|
+
model_params = params[model_form_name]
|
272
|
+
defaults.merge(model_params)
|
230
273
|
end
|
231
274
|
|
232
275
|
def after_update_on_success
|
233
276
|
flash[:notice] = "#{content_type_name.demodulize.titleize} '#{@block.name}' was updated"
|
234
|
-
redirect_to_first params[:_redirect_to],
|
277
|
+
redirect_to_first params[:_redirect_to], engine_aware_path(@block)
|
235
278
|
end
|
236
279
|
|
237
280
|
def after_update_on_failure
|
238
|
-
render "
|
281
|
+
render "edit"
|
239
282
|
end
|
240
283
|
|
241
284
|
def after_update_on_edit_conflict
|
@@ -244,18 +287,17 @@ module Cms
|
|
244
287
|
end
|
245
288
|
|
246
289
|
|
247
|
-
# methods for other actions
|
248
|
-
|
249
290
|
# A "command" is when you want to perform an action on a content block
|
250
291
|
# You pass a ruby block to this method, this calls it
|
251
292
|
# and then sets a flash message based on success or failure
|
252
293
|
def do_command(result)
|
253
294
|
load_block
|
254
295
|
if yield
|
255
|
-
flash[:notice] = "#{content_type_name.demodulize.titleize} '#{@block.name}' was #{result}"
|
296
|
+
flash[:notice] = "#{content_type_name.demodulize.titleize} '#{@block.name}' was #{result}" unless request.xhr?
|
256
297
|
else
|
257
|
-
flash[:error] = "#{content_type_name.demodulize.titleize} '#{@block.name}' could not be #{result}"
|
298
|
+
flash[:error] = "#{content_type_name.demodulize.titleize} '#{@block.name}' could not be #{result}" unless request.xhr?
|
258
299
|
end
|
300
|
+
|
259
301
|
end
|
260
302
|
|
261
303
|
def revert_block(to_version)
|
@@ -274,9 +316,9 @@ module Cms
|
|
274
316
|
# are connected to.
|
275
317
|
def check_permissions
|
276
318
|
case action_name
|
277
|
-
when "index", "show", "new", "create", "version", "versions"
|
319
|
+
when "index", "show", "new", "create", "version", "versions"
|
278
320
|
# Allow
|
279
|
-
when "edit", "update"
|
321
|
+
when "edit", "update", "inline"
|
280
322
|
raise Cms::Errors::AccessDenied unless current_user.able_to_edit?(@block)
|
281
323
|
when "destroy", "publish", "revert_to"
|
282
324
|
raise Cms::Errors::AccessDenied unless current_user.able_to_publish?(@block)
|
@@ -285,19 +327,34 @@ module Cms
|
|
285
327
|
end
|
286
328
|
end
|
287
329
|
|
288
|
-
|
330
|
+
private
|
289
331
|
|
290
|
-
def
|
291
|
-
@
|
332
|
+
def render_block_in_main_container
|
333
|
+
ensure_current_user_can_view(@block)
|
334
|
+
show_content_as_page(@block)
|
335
|
+
render 'render_block_in_main_container', layout: @block.class.layout
|
292
336
|
end
|
293
337
|
|
294
|
-
def
|
295
|
-
'
|
338
|
+
def render_block_in_content_library
|
339
|
+
render 'show_in_isolation'
|
296
340
|
end
|
297
341
|
|
298
|
-
def
|
299
|
-
|
342
|
+
def render_editing_frame_or_block_in_main_container
|
343
|
+
if @block.class.addressable?
|
344
|
+
if current_user.able_to_edit?(@block)
|
345
|
+
render_toolbar_and_iframe
|
346
|
+
else
|
347
|
+
render_block_in_main_container
|
348
|
+
end
|
349
|
+
else
|
350
|
+
render_block_in_content_library
|
351
|
+
end
|
300
352
|
end
|
301
353
|
|
354
|
+
def render_toolbar_and_iframe
|
355
|
+
@page = @block
|
356
|
+
@page_title = @block.page_title
|
357
|
+
render "show", :layout => 'cms/page_editor'
|
358
|
+
end
|
302
359
|
end
|
303
360
|
end
|