locomotive_cms 2.0.3 → 2.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +15 -0
- data/Gemfile +3 -3
- data/README.textile +7 -7
- data/app/assets/images/locomotive/icons/flags/ja.png +0 -0
- data/app/assets/javascripts/locomotive/aloha.js.coffee +3 -0
- data/app/assets/javascripts/locomotive/models/page.js.coffee +1 -1
- data/app/assets/javascripts/locomotive/models/site.js.coffee +16 -6
- data/app/assets/javascripts/locomotive/utils/aloha_settings.js.coffee +1 -1
- data/app/assets/javascripts/locomotive/views/content_entries/_form_view.js.coffee +5 -0
- data/app/assets/javascripts/locomotive/views/my_account/edit_view.js.coffee +14 -0
- data/app/assets/javascripts/locomotive/views/pages/_form_view.js.coffee +1 -1
- data/app/assets/javascripts/locomotive/views/pages/edit_view.js.coffee +2 -1
- data/app/assets/javascripts/tinymce/plugins/locomotive_media/langs/de.js +1 -0
- data/app/assets/stylesheets/locomotive.css +1 -0
- data/app/assets/stylesheets/locomotive/backoffice/formtastic_changes.css.scss +18 -3
- data/app/assets/stylesheets/locomotive/backoffice/layout.css.scss +1 -1
- data/app/assets/stylesheets/locomotive/backoffice/menu/main.css.scss +7 -3
- data/app/assets/stylesheets/locomotive/backoffice/pagination.css.scss +37 -0
- data/app/assets/stylesheets/locomotive/backoffice/tagit_changes.css.scss +49 -0
- data/app/cells/locomotive/content_locale_picker/show.html.haml +1 -1
- data/app/cells/locomotive/global_actions_cell.rb +8 -8
- data/app/cells/locomotive/main_menu/show.html.haml +2 -2
- data/app/cells/locomotive/main_menu_cell.rb +2 -2
- data/app/cells/locomotive/menu_cell.rb +6 -6
- data/app/cells/locomotive/partials_cell.rb +21 -0
- data/app/cells/locomotive/settings_menu_cell.rb +4 -4
- data/app/cells/locomotive/sub_menu/show.html.haml +2 -2
- data/app/cells/locomotive/sub_menu_cell.rb +1 -1
- data/app/controllers/locomotive/accounts_controller.rb +4 -4
- data/app/controllers/locomotive/api/accounts_controller.rb +1 -0
- data/app/controllers/locomotive/api/content_assets_controller.rb +1 -1
- data/app/controllers/locomotive/api/content_entries_controller.rb +1 -1
- data/app/controllers/locomotive/api/content_types_controller.rb +2 -2
- data/app/controllers/locomotive/api/pages_controller.rb +1 -1
- data/app/controllers/locomotive/api/snippets_controller.rb +1 -1
- data/app/controllers/locomotive/api/theme_assets_controller.rb +47 -0
- data/app/controllers/locomotive/api/tokens_controller.rb +2 -2
- data/app/controllers/locomotive/base_controller.rb +5 -2
- data/app/controllers/locomotive/content_assets_controller.rb +1 -1
- data/app/controllers/locomotive/content_entries_controller.rb +22 -9
- data/app/controllers/locomotive/content_types_controller.rb +6 -6
- data/app/controllers/locomotive/current_site_controller.rb +6 -6
- data/app/controllers/locomotive/installation_controller.rb +11 -3
- data/app/controllers/locomotive/memberships_controller.rb +6 -6
- data/app/controllers/locomotive/my_account_controller.rb +9 -3
- data/app/controllers/locomotive/pages_controller.rb +10 -6
- data/app/controllers/locomotive/passwords_controller.rb +1 -1
- data/app/controllers/locomotive/public/content_entries_controller.rb +1 -1
- data/app/controllers/locomotive/public/pages_controller.rb +5 -5
- data/app/controllers/locomotive/public/robots_controller.rb +1 -1
- data/app/controllers/locomotive/public/sitemaps_controller.rb +1 -1
- data/app/controllers/locomotive/sessions_controller.rb +1 -1
- data/app/controllers/locomotive/sites_controller.rb +5 -5
- data/app/controllers/locomotive/snippets_controller.rb +6 -6
- data/app/controllers/locomotive/theme_assets_controller.rb +6 -6
- data/app/controllers/locomotive/translations_controller.rb +1 -1
- data/app/helpers/locomotive/accounts_helper.rb +1 -1
- data/app/helpers/locomotive/base_helper.rb +13 -21
- data/app/helpers/locomotive/content_types_helper.rb +3 -3
- data/app/helpers/locomotive/custom_fields_helper.rb +5 -5
- data/app/helpers/locomotive/installation_helper.rb +1 -1
- data/app/helpers/locomotive/pages_helper.rb +5 -5
- data/app/helpers/locomotive/snippets_helper.rb +1 -1
- data/app/helpers/locomotive/theme_assets_helper.rb +1 -1
- data/app/helpers/locomotive/translations_helper.rb +2 -2
- data/app/inputs/locomotive/api_key_input.rb +40 -0
- data/app/inputs/locomotive/code_input.rb +5 -5
- data/app/inputs/locomotive/file_input.rb +6 -6
- data/app/inputs/locomotive/locale_input.rb +5 -5
- data/app/inputs/locomotive/locales_input.rb +4 -4
- data/app/inputs/locomotive/rte_input.rb +1 -1
- data/app/inputs/locomotive/small_code_input.rb +1 -1
- data/app/inputs/locomotive/subdomain_input.rb +1 -1
- data/app/mailers/locomotive/devise_mailer.rb +1 -1
- data/app/mailers/locomotive/notifications.rb +3 -3
- data/app/models/locomotive/ability.rb +10 -11
- data/app/models/locomotive/account.rb +61 -26
- data/app/models/locomotive/content_asset.rb +8 -8
- data/app/models/locomotive/content_entry.rb +8 -7
- data/app/models/locomotive/content_type.rb +12 -7
- data/app/models/locomotive/editable_control.rb +2 -2
- data/app/models/locomotive/editable_element.rb +13 -8
- data/app/models/locomotive/editable_file.rb +5 -3
- data/app/models/locomotive/editable_short_text.rb +3 -3
- data/app/models/locomotive/extensions/asset/types.rb +2 -2
- data/app/models/locomotive/extensions/content_entry/csv.rb +78 -0
- data/app/models/locomotive/extensions/content_type/item_template.rb +3 -3
- data/app/models/locomotive/extensions/content_type/sync.rb +4 -4
- data/app/models/locomotive/extensions/page/editable_elements.rb +1 -1
- data/app/models/locomotive/extensions/page/parse.rb +2 -2
- data/app/models/locomotive/extensions/page/render.rb +7 -1
- data/app/models/locomotive/extensions/page/templatized.rb +20 -15
- data/app/models/locomotive/extensions/page/tree.rb +4 -4
- data/app/models/locomotive/extensions/shared/seo.rb +3 -3
- data/app/models/locomotive/extensions/site/first_installation.rb +5 -2
- data/app/models/locomotive/extensions/site/locales.rb +9 -6
- data/app/models/locomotive/extensions/site/subdomain_domains.rb +8 -8
- data/app/models/locomotive/membership.rb +6 -6
- data/app/models/locomotive/page.rb +30 -23
- data/app/models/locomotive/site.rb +19 -15
- data/app/models/locomotive/snippet.rb +5 -5
- data/app/models/locomotive/theme_asset.rb +17 -6
- data/app/models/locomotive/translation.rb +21 -16
- data/app/presenters/locomotive/account_presenter.rb +1 -1
- data/app/presenters/locomotive/content_entry_presenter.rb +2 -2
- data/app/presenters/locomotive/content_field_presenter.rb +2 -2
- data/app/presenters/locomotive/content_type_presenter.rb +6 -1
- data/app/presenters/locomotive/theme_asset_presenter.rb +2 -2
- data/app/uploaders/locomotive/editable_file_uploader.rb +1 -1
- data/app/uploaders/locomotive/theme_asset_uploader.rb +1 -1
- data/app/views/locomotive/accounts/new.html.haml +6 -6
- data/app/views/locomotive/content_assets/_asset.html.haml +3 -3
- data/app/views/locomotive/content_assets/_picker.html.haml +12 -12
- data/app/views/locomotive/content_entries/_form.html.haml +9 -8
- data/app/views/locomotive/content_entries/_list.html.haml +8 -5
- data/app/views/locomotive/content_entries/edit.html.haml +6 -6
- data/app/views/locomotive/content_entries/index.html.haml +8 -6
- data/app/views/locomotive/content_entries/new.html.haml +5 -5
- data/app/views/locomotive/content_types/_form.html.haml +16 -16
- data/app/views/locomotive/content_types/edit.html.haml +5 -5
- data/app/views/locomotive/content_types/new.html.haml +3 -3
- data/app/views/locomotive/current_site/_form.html.haml +12 -12
- data/app/views/locomotive/current_site/edit.html.haml +5 -5
- data/app/views/locomotive/custom_fields/_form.html.haml +23 -19
- data/app/views/locomotive/custom_fields/_select_templates.html.haml +5 -5
- data/app/views/locomotive/custom_fields/types/_belongs_to.html.haml +4 -4
- data/app/views/locomotive/custom_fields/types/_boolean.html.haml +3 -3
- data/app/views/locomotive/custom_fields/types/_date.html.haml +4 -4
- data/app/views/locomotive/custom_fields/types/_email.html.haml +4 -0
- data/app/views/locomotive/custom_fields/types/_file.html.haml +3 -3
- data/app/views/locomotive/custom_fields/types/_float.html.haml +6 -0
- data/app/views/locomotive/custom_fields/types/_has_many.html.haml +10 -10
- data/app/views/locomotive/custom_fields/types/_integer.html.haml +5 -0
- data/app/views/locomotive/custom_fields/types/_many_to_many.html.haml +10 -10
- data/app/views/locomotive/custom_fields/types/_select.html.haml +10 -10
- data/app/views/locomotive/custom_fields/types/_string.html.haml +3 -3
- data/app/views/locomotive/custom_fields/types/_tags.html.haml +4 -0
- data/app/views/locomotive/custom_fields/types/_text.html.haml +4 -4
- data/app/views/locomotive/devise_mailer/reset_password_instructions.html.haml +1 -1
- data/app/views/locomotive/installation/step_1.html.haml +5 -5
- data/app/views/locomotive/installation/step_2.html.haml +6 -6
- data/app/views/locomotive/kaminari/_first_page.html.haml +2 -0
- data/app/views/locomotive/kaminari/_gap.html.haml +2 -0
- data/app/views/locomotive/kaminari/_last_page.html.haml +2 -0
- data/app/views/locomotive/kaminari/_next_page.html.haml +2 -0
- data/app/views/locomotive/kaminari/_page.html.haml +2 -0
- data/app/views/locomotive/kaminari/_paginator.html.haml +11 -0
- data/app/views/locomotive/kaminari/_prev_page.html.haml +2 -0
- data/app/views/locomotive/layouts/application.html.haml +2 -2
- data/app/views/locomotive/layouts/not_logged_in.html.haml +3 -3
- data/app/views/locomotive/memberships/new.html.haml +4 -4
- data/app/views/locomotive/my_account/edit.html.haml +14 -13
- data/app/views/locomotive/notifications/new_content_entry.html.haml +2 -2
- data/app/views/locomotive/pages/_editable_elements.html.haml +20 -20
- data/app/views/locomotive/pages/_form.html.haml +23 -27
- data/app/views/locomotive/pages/_page.html.haml +6 -6
- data/app/views/locomotive/pages/edit.html.haml +5 -5
- data/app/views/locomotive/pages/index.html.haml +2 -2
- data/app/views/locomotive/pages/new.html.haml +4 -4
- data/app/views/locomotive/passwords/edit.html.haml +3 -3
- data/app/views/locomotive/passwords/new.html.haml +2 -2
- data/app/views/locomotive/public/pages/show_toolbar.html.haml +15 -15
- data/app/views/locomotive/sessions/new.html.haml +4 -4
- data/app/views/locomotive/shared/_footer.html.haml +1 -1
- data/app/views/locomotive/shared/_head.html.haml +7 -7
- data/app/views/locomotive/shared/_header.html.haml +2 -2
- data/app/views/locomotive/shared/_locale_picker_link.html.haml +1 -1
- data/app/views/locomotive/shared/_site_picker.html.haml +2 -2
- data/app/views/locomotive/shared/actions/_contents.html.haml +1 -1
- data/app/views/locomotive/shared/menu/_contents.html.haml +5 -5
- data/app/views/locomotive/sites/_domains.html.haml +7 -7
- data/app/views/locomotive/sites/_form.html.haml +6 -1
- data/app/views/locomotive/sites/_memberships.html.haml +3 -3
- data/app/views/locomotive/sites/new.html.haml +3 -3
- data/app/views/locomotive/snippets/_form.html.haml +6 -6
- data/app/views/locomotive/snippets/_snippet.html.haml +2 -2
- data/app/views/locomotive/snippets/edit.html.haml +5 -5
- data/app/views/locomotive/snippets/new.html.haml +3 -3
- data/app/views/locomotive/theme_assets/_asset.html.haml +2 -2
- data/app/views/locomotive/theme_assets/_form.html.haml +10 -10
- data/app/views/locomotive/theme_assets/_list.html.haml +3 -3
- data/app/views/locomotive/theme_assets/_picker.html.haml +8 -8
- data/app/views/locomotive/theme_assets/edit.html.haml +7 -7
- data/app/views/locomotive/theme_assets/index.html.haml +6 -6
- data/app/views/locomotive/theme_assets/new.html.haml +3 -3
- data/app/views/locomotive/translations/_form.html.haml +3 -3
- data/app/views/locomotive/translations/edit.html.haml +6 -6
- data/app/views/locomotive/translations/index.html.haml +2 -0
- data/app/views/locomotive/translations/new.html.haml +2 -2
- data/config/initializers/csv_renderer.rb +10 -0
- data/config/locales/admin_ui.de.yml +1 -0
- data/config/locales/admin_ui.en.yml +12 -0
- data/config/locales/admin_ui.es.yml +1 -0
- data/config/locales/admin_ui.et.yml +1 -0
- data/config/locales/admin_ui.fr.yml +12 -0
- data/config/locales/admin_ui.it.yml +1 -0
- data/config/locales/admin_ui.ja.yml +335 -0
- data/config/locales/admin_ui.nb.yml +1 -0
- data/config/locales/admin_ui.nl.yml +1 -0
- data/config/locales/admin_ui.pl.yml +1 -0
- data/config/locales/admin_ui.pt-BR.yml +8 -0
- data/config/locales/admin_ui.ru.yml +1 -0
- data/config/locales/carrierwave.ja.yml +4 -0
- data/config/locales/default.de.yml +1 -1
- data/config/locales/default.en.yml +1 -1
- data/config/locales/default.es.yml +3 -0
- data/config/locales/default.et.yml +2 -2
- data/config/locales/default.fr.yml +1 -1
- data/config/locales/default.it.yml +3 -0
- data/config/locales/default.ja.yml +94 -0
- data/config/locales/default.nb.yml +1 -1
- data/config/locales/default.nl.yml +5 -0
- data/config/locales/default.pl.yml +2 -2
- data/config/locales/default.pt-BR.yml +3 -2
- data/config/locales/default.ru.yml +19 -16
- data/config/locales/devise.ja.yml +63 -0
- data/config/locales/flash.ja.yml +115 -0
- data/config/locales/formtastic.en.yml +7 -0
- data/config/locales/formtastic.fr.yml +9 -0
- data/config/locales/formtastic.ja.yml +103 -0
- data/config/locales/formtastic.pt-BR.yml +1 -1
- data/config/routes.rb +5 -2
- data/features/api/authentication.feature +24 -2
- data/features/api/authorization/pages.feature +3 -1
- data/features/api/entries_custom_fields.feature +2 -2
- data/features/backoffice/authorization/pages.feature +7 -7
- data/features/backoffice/content_types/email.feature +26 -0
- data/features/backoffice/content_types/has_many.feature +20 -0
- data/features/backoffice/content_types/integer.feature +26 -0
- data/features/backoffice/content_types/many_to_many.feature +29 -1
- data/features/backoffice/content_types/tags.feature +22 -0
- data/features/backoffice/content_types/uniqueness.feature +29 -0
- data/features/backoffice/contents.feature +16 -0
- data/features/backoffice/installation.feature +33 -0
- data/features/backoffice/my_account.feature +21 -0
- data/features/backoffice/pages.feature +21 -1
- data/features/backoffice/site.feature +59 -40
- data/features/backoffice/snippets.feature +1 -1
- data/features/backoffice/translations.feature +7 -1
- data/features/public/basic.feature +1 -1
- data/features/public/pages.feature +92 -0
- data/features/public/session.feature +40 -0
- data/features/public/tags.feature +45 -0
- data/features/step_definitions/backoffice_steps.rb +4 -0
- data/features/step_definitions/content_types_steps.rb +16 -3
- data/features/step_definitions/more_web_steps.rb +35 -4
- data/features/step_definitions/page_steps.rb +52 -35
- data/features/step_definitions/pagination_steps.rb +4 -4
- data/features/step_definitions/site_steps.rb +22 -10
- data/features/step_definitions/snippet_steps.rb +1 -1
- data/features/step_definitions/theme_asset_steps.rb +2 -2
- data/features/step_definitions/translation_steps.rb +1 -1
- data/features/step_definitions/web_steps.rb +1 -1
- data/features/support/http.rb +1 -1
- data/features/support/locales.rb +5 -0
- data/lib/generators/locomotive/install/install_generator.rb +1 -6
- data/lib/generators/locomotive/install/templates/carrierwave.rb +4 -4
- data/lib/generators/locomotive/install/templates/locomotive.rb +12 -7
- data/lib/locomotive.rb +4 -4
- data/lib/locomotive/action_controller.rb +1 -0
- data/lib/locomotive/action_controller/responder.rb +9 -10
- data/lib/locomotive/action_controller/section_helpers.rb +1 -1
- data/lib/locomotive/action_controller/ssl.rb +11 -0
- data/lib/locomotive/action_controller/url_helpers.rb +9 -5
- data/lib/locomotive/carrierwave/asset.rb +6 -6
- data/lib/locomotive/configuration.rb +28 -26
- data/lib/locomotive/core_ext.rb +1 -2
- data/lib/locomotive/custom_fields.rb +12 -6
- data/lib/locomotive/dependencies.rb +1 -0
- data/lib/locomotive/dragonfly.rb +1 -1
- data/lib/locomotive/engine.rb +3 -3
- data/lib/locomotive/formtastic.rb +1 -1
- data/lib/locomotive/httparty/webservice.rb +1 -1
- data/lib/locomotive/kaminari.rb +28 -13
- data/lib/locomotive/liquid.rb +1 -0
- data/lib/locomotive/liquid/drops/content_entry.rb +1 -1
- data/lib/locomotive/liquid/drops/content_types.rb +27 -2
- data/lib/locomotive/liquid/drops/page.rb +14 -2
- data/lib/locomotive/liquid/drops/proxy_collection.rb +4 -0
- data/lib/locomotive/liquid/drops/session_proxy.rb +16 -0
- data/lib/locomotive/liquid/drops/site.rb +11 -3
- data/lib/locomotive/liquid/drops/uploader.rb +1 -1
- data/lib/locomotive/liquid/filters/base.rb +1 -1
- data/lib/locomotive/liquid/filters/date.rb +2 -2
- data/lib/locomotive/liquid/filters/html.rb +12 -12
- data/lib/locomotive/liquid/filters/translate.rb +21 -3
- data/lib/locomotive/liquid/tags/consume.rb +50 -19
- data/lib/locomotive/liquid/tags/editable/base.rb +9 -9
- data/lib/locomotive/liquid/tags/editable/control.rb +1 -1
- data/lib/locomotive/liquid/tags/editable/file.rb +1 -1
- data/lib/locomotive/liquid/tags/editable/short_text.rb +1 -1
- data/lib/locomotive/liquid/tags/fetch_page.rb +28 -0
- data/lib/locomotive/liquid/tags/hybrid.rb +25 -0
- data/lib/locomotive/liquid/tags/inherited_block.rb +2 -2
- data/lib/locomotive/liquid/tags/inline_editor.rb +4 -4
- data/lib/locomotive/liquid/tags/javascript.rb +16 -0
- data/lib/locomotive/liquid/tags/link_to.rb +42 -0
- data/lib/locomotive/liquid/tags/locale_switcher.rb +1 -1
- data/lib/locomotive/liquid/tags/nav.rb +2 -2
- data/lib/locomotive/liquid/tags/paginate.rb +2 -2
- data/lib/locomotive/liquid/tags/session_assign.rb +39 -0
- data/lib/locomotive/liquid/tags/snippet.rb +1 -1
- data/lib/locomotive/liquid/tags/with_scope.rb +6 -2
- data/lib/locomotive/logger.rb +1 -1
- data/lib/locomotive/middlewares/cache.rb +1 -1
- data/lib/locomotive/middlewares/fonts.rb +1 -1
- data/lib/locomotive/middlewares/inline_editor.rb +1 -1
- data/lib/locomotive/middlewares/permalink.rb +1 -1
- data/lib/locomotive/middlewares/seo_trailing_slash.rb +1 -1
- data/lib/locomotive/mongoid/patches.rb +21 -21
- data/lib/locomotive/rails/action_view.rb +20 -4
- data/lib/locomotive/regexps.rb +1 -1
- data/lib/locomotive/render.rb +4 -2
- data/lib/locomotive/routing/default_constraint.rb +1 -1
- data/lib/locomotive/routing/site_dispatcher.rb +1 -1
- data/lib/locomotive/session_store.rb +7 -7
- data/lib/locomotive/version.rb +1 -1
- data/lib/tasks/development.rake +11 -9
- data/lib/tasks/locomotive.rake +11 -11
- data/mongodb/migrate/20130204072721_make_editable_elements_consistent.rb +3 -1
- data/mongodb/migrate/20130326201349_rename_entry_to_content_entry.rb +6 -6
- data/mongodb/migrate/20130511121956_generate_checksum_for_theme_assets.rb +14 -0
- data/mongodb/migrate/20130530162559_api_key_for_all_accounts.rb +10 -0
- data/spec/cells/locomotive/global_actions_spec.rb +11 -11
- data/spec/cells/locomotive/main_menu_cell_spec.rb +9 -9
- data/spec/cells/locomotive/settings_menu_cell_spec.rb +11 -11
- data/spec/dummy/config/environments/development.rb +1 -1
- data/spec/dummy/config/initializers/locomotive.rb +16 -11
- data/spec/dummy/config/mongoid.yml +99 -18
- data/spec/lib/action_view_spec.rb +19 -0
- data/spec/lib/core_ext_spec.rb +2 -2
- data/spec/lib/locomotive/configuration_spec.rb +1 -1
- data/spec/lib/locomotive/httparty/webservice_spec.rb +6 -6
- data/spec/lib/locomotive/liquid/drops/content_entry_spec.rb +1 -1
- data/spec/lib/locomotive/liquid/drops/current_user.rb +3 -3
- data/spec/lib/locomotive/liquid/drops/page_spec.rb +63 -14
- data/spec/lib/locomotive/liquid/drops/site_spec.rb +3 -3
- data/spec/lib/locomotive/liquid/filters/html_spec.rb +22 -7
- data/spec/lib/locomotive/liquid/filters/resize_spec.rb +3 -3
- data/spec/lib/locomotive/liquid/filters/translate_spec.rb +26 -12
- data/spec/lib/locomotive/liquid/tags/consume_spec.rb +26 -2
- data/spec/lib/locomotive/liquid/tags/csrf_spec.rb +3 -3
- data/spec/lib/locomotive/liquid/tags/editable/short_text_spec.rb +1 -1
- data/spec/lib/locomotive/liquid/tags/extends_spec.rb +5 -5
- data/spec/lib/locomotive/liquid/tags/javascript_spec.rb +18 -0
- data/spec/lib/locomotive/liquid/tags/locale_switcher_spec.rb +23 -13
- data/spec/lib/locomotive/liquid/tags/nav_spec.rb +11 -11
- data/spec/lib/locomotive/liquid/tags/paginate_spec.rb +13 -13
- data/spec/lib/locomotive/liquid/tags/seo_spec.rb +8 -8
- data/spec/lib/locomotive/liquid/tags/with_scope_spec.rb +8 -2
- data/spec/lib/locomotive/presentable_spec.rb +10 -10
- data/spec/lib/locomotive/render_spec.rb +14 -14
- data/spec/mailers/locomotive/notifications_spec.rb +3 -3
- data/spec/models/locomotive/ability_spec.rb +23 -9
- data/spec/models/locomotive/account_spec.rb +30 -8
- data/spec/models/locomotive/content_asset_spec.rb +1 -1
- data/spec/models/locomotive/content_entry_spec.rb +57 -2
- data/spec/models/locomotive/content_type_spec.rb +42 -41
- data/spec/models/locomotive/editable_control_spec.rb +5 -5
- data/spec/models/locomotive/editable_file_spec.rb +21 -5
- data/spec/models/locomotive/editable_long_text_spec.rb +3 -3
- data/spec/models/locomotive/editable_short_text_spec.rb +8 -8
- data/spec/models/locomotive/extensions/page/editable_elements_spec.rb +9 -9
- data/spec/models/locomotive/extensions/page/redirect_spec.rb +1 -1
- data/spec/models/locomotive/extensions/page/render_spec.rb +4 -8
- data/spec/models/locomotive/extensions/site/locales_spec.rb +2 -2
- data/spec/models/locomotive/membership_spec.rb +5 -5
- data/spec/models/locomotive/page_spec.rb +10 -1
- data/spec/models/locomotive/site_spec.rb +19 -19
- data/spec/models/locomotive/snippet_spec.rb +9 -9
- data/spec/models/locomotive/theme_asset_spec.rb +91 -57
- data/spec/requests/admin_ssl_spec.rb +25 -0
- data/spec/support/factories.rb +32 -27
- data/spec/support/locomotive.rb +2 -0
- data/vendor/assets/javascripts/locomotive/backbone.sync.js +1 -1
- data/vendor/assets/javascripts/locomotive/tag-it.min.js +16 -0
- data/vendor/assets/stylesheets/locomotive/jquery.tagit.css +67 -0
- metadata +108 -138
@@ -13,20 +13,23 @@ module Locomotive
|
|
13
13
|
field :height, type: Integer
|
14
14
|
field :size, type: Integer
|
15
15
|
field :folder, default: nil
|
16
|
+
field :checksum
|
17
|
+
|
16
18
|
mount_uploader :source, ThemeAssetUploader, mount_on: :source_filename, validate_integrity: true
|
17
19
|
|
18
20
|
## associations ##
|
19
|
-
belongs_to :site, class_name: 'Locomotive::Site'
|
21
|
+
belongs_to :site, class_name: 'Locomotive::Site', autosave: false
|
20
22
|
|
21
23
|
## indexes ##
|
22
|
-
index :
|
23
|
-
index
|
24
|
+
index site_id: 1
|
25
|
+
index site_id: 1, local_path: 1
|
24
26
|
|
25
27
|
## callbacks ##
|
26
28
|
before_validation :check_for_folder_changes
|
27
29
|
before_validation :store_plain_text
|
28
30
|
before_validation :sanitize_folder
|
29
31
|
before_validation :build_local_path
|
32
|
+
before_save :calculate_checksum
|
30
33
|
|
31
34
|
## validations ##
|
32
35
|
validates_presence_of :site
|
@@ -104,7 +107,7 @@ module Locomotive
|
|
104
107
|
end
|
105
108
|
|
106
109
|
def self.all_grouped_by_folder(site)
|
107
|
-
assets = site.theme_assets.order_by(
|
110
|
+
assets = site.theme_assets.order_by(:slug.asc)
|
108
111
|
assets.group_by { |a| a.folder.split('/').first.to_sym }
|
109
112
|
end
|
110
113
|
|
@@ -141,7 +144,7 @@ module Locomotive
|
|
141
144
|
def escape_shortcut_urls(text)
|
142
145
|
return if text.blank?
|
143
146
|
|
144
|
-
text.gsub(/[("'](\/(stylesheets|javascripts|images|media|others)\/(([^;.]+)\/)*([a-zA-Z_\-0-9]+)\.[a-z]{2,3})[)"']/) do |path|
|
147
|
+
text.gsub(/[("'](\/(stylesheets|javascripts|images|media|others)\/(([^;.]+)\/)*([a-zA-Z_\-0-9]+)\.[a-z]{2,3})(\?[0-9]+)?[)"']/) do |path|
|
145
148
|
|
146
149
|
sanitized_path = path.gsub(/[("')]/, '').gsub(/^\//, '')
|
147
150
|
|
@@ -156,7 +159,7 @@ module Locomotive
|
|
156
159
|
def check_for_folder_changes
|
157
160
|
# https://github.com/jnicklas/carrierwave/issues/330
|
158
161
|
# https://github.com/jnicklas/carrierwave-mongoid/issues/23
|
159
|
-
if self.persisted? && self.folder_changed? && !self.
|
162
|
+
if self.persisted? && self.folder_changed? && !self.changed_attributes.key?('source_filename')
|
160
163
|
# a simple way to rename a file
|
161
164
|
old_asset = self.class.where(_id: self._id).first # bypass memoization by mongoid
|
162
165
|
file = old_asset.source.file
|
@@ -170,5 +173,13 @@ module Locomotive
|
|
170
173
|
self.errors.add(:source, :extname_changed) if self.persisted? && self.content_type_changed?
|
171
174
|
end
|
172
175
|
|
176
|
+
def calculate_checksum
|
177
|
+
begin
|
178
|
+
self.checksum = Digest::MD5.hexdigest(self.source.read)
|
179
|
+
rescue Errno::ENOENT => e
|
180
|
+
# no file
|
181
|
+
end
|
182
|
+
end
|
183
|
+
|
173
184
|
end
|
174
185
|
end
|
@@ -11,25 +11,30 @@ class Locomotive::Translation
|
|
11
11
|
|
12
12
|
## validations ##
|
13
13
|
validates_uniqueness_of :key, scope: :site_id
|
14
|
-
validates_presence_of
|
14
|
+
validates_presence_of :site, :key
|
15
15
|
|
16
16
|
## scopes ##
|
17
|
-
scope :ordered,
|
17
|
+
scope :ordered, order_by(key: :asc)
|
18
18
|
|
19
19
|
## callbacks ##
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
20
|
+
before_validation :underscore_key
|
21
|
+
before_validation :remove_blanks
|
22
|
+
|
23
|
+
## methods ##
|
24
|
+
|
25
|
+
protected
|
26
|
+
|
27
|
+
# Make sure the translation key is underscored
|
28
|
+
# since it is the unique way to use it in a liquid template.
|
29
|
+
#
|
30
|
+
def underscore_key
|
31
|
+
if self.key
|
32
|
+
self.key = self.key.permalink.underscore
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def remove_blanks
|
37
|
+
self.values.delete_if { |k,v| v.blank? }
|
38
|
+
end
|
34
39
|
|
35
40
|
end
|
@@ -7,7 +7,7 @@ module Locomotive
|
|
7
7
|
|
8
8
|
property :_slug
|
9
9
|
|
10
|
-
|
10
|
+
properties :_position, :_visible, required: false
|
11
11
|
|
12
12
|
properties :seo_title, :meta_keywords, :meta_description, required: false
|
13
13
|
|
@@ -37,7 +37,7 @@ module Locomotive
|
|
37
37
|
end
|
38
38
|
|
39
39
|
def safe_attributes
|
40
|
-
self.__source.custom_fields_safe_setters + %w(_slug seo_title meta_keywords meta_description)
|
40
|
+
self.__source.custom_fields_safe_setters + %w(_slug _visible seo_title meta_keywords meta_description)
|
41
41
|
end
|
42
42
|
|
43
43
|
## other methods ##
|
@@ -5,7 +5,7 @@ module Locomotive
|
|
5
5
|
|
6
6
|
properties :name, :label, :type
|
7
7
|
|
8
|
-
properties :required, :localized, type: 'Boolean'
|
8
|
+
properties :required, :localized, :unique, type: 'Boolean'
|
9
9
|
|
10
10
|
properties :hint, :position, required: false
|
11
11
|
|
@@ -49,7 +49,7 @@ module Locomotive
|
|
49
49
|
end
|
50
50
|
|
51
51
|
def class_slug
|
52
|
-
self.content_type.class_name_to_content_type(self.__source.class_name).try(:slug)
|
52
|
+
self.content_type.class_name_to_content_type(self.__source.class_name).try(:slug) rescue ::Mongoid::Errors::DocumentNotFound
|
53
53
|
end
|
54
54
|
|
55
55
|
def class_name=(value)
|
@@ -6,7 +6,7 @@ module Locomotive
|
|
6
6
|
properties :name, :slug
|
7
7
|
|
8
8
|
# must to be declared before the others
|
9
|
-
|
9
|
+
property :entries_custom_fields, alias: :fields
|
10
10
|
|
11
11
|
property :description, required: false
|
12
12
|
|
@@ -24,6 +24,11 @@ module Locomotive
|
|
24
24
|
|
25
25
|
## other getters / setters ##
|
26
26
|
|
27
|
+
def entries_custom_fields
|
28
|
+
list = self.__source.ordered_entries_custom_fields
|
29
|
+
list ? list.map(&:as_json) : []
|
30
|
+
end
|
31
|
+
|
27
32
|
def entries_custom_fields=(fields)
|
28
33
|
destroyed_fields = []
|
29
34
|
|
@@ -3,8 +3,8 @@ module Locomotive
|
|
3
3
|
|
4
4
|
## properties ##
|
5
5
|
|
6
|
-
properties :content_type,
|
7
|
-
property :plain_text, allow_nil: false
|
6
|
+
properties :content_type, :folder, :checksum
|
7
|
+
property :plain_text, allow_nil: false, description: 'Only returned after an update'
|
8
8
|
|
9
9
|
with_options only_setter: true do |presenter|
|
10
10
|
presenter.properties :plain_text_name, :plain_text_type, :performing_plain_text, :source
|
@@ -18,7 +18,7 @@ module Locomotive
|
|
18
18
|
end
|
19
19
|
|
20
20
|
def self.build(site, path)
|
21
|
-
asset = site.theme_assets.build(:
|
21
|
+
asset = site.theme_assets.build(folder: File.dirname(path))
|
22
22
|
uploader = ThemeAssetUploader.new(asset)
|
23
23
|
uploader.retrieve_from_store!(File.basename(path))
|
24
24
|
uploader
|
@@ -5,17 +5,17 @@
|
|
5
5
|
|
6
6
|
%p!= t('.help')
|
7
7
|
|
8
|
-
= semantic_form_for @account, :
|
8
|
+
= semantic_form_for @account, url: accounts_url do |f|
|
9
9
|
|
10
|
-
= f.inputs :
|
10
|
+
= f.inputs name: :information do
|
11
11
|
= f.input :name
|
12
12
|
- unless f.object.respond_to?(:password)
|
13
13
|
= f.input :email
|
14
14
|
|
15
15
|
- if f.object.respond_to?(:password)
|
16
|
-
= f.inputs :
|
16
|
+
= f.inputs name: :credentials do
|
17
17
|
= f.input :email
|
18
|
-
= f.input :password, :
|
19
|
-
= f.input :password_confirmation, :
|
18
|
+
= f.input :password, input_html: { autocomplete: "off" }
|
19
|
+
= f.input :password_confirmation, input_html: { autocomplete: "off" }
|
20
20
|
|
21
|
-
= render 'locomotive/shared/form_actions', :
|
21
|
+
= render 'locomotive/shared/form_actions', back_url: edit_current_site_url, button_label: :create
|
@@ -1,5 +1,5 @@
|
|
1
|
-
%li{ :
|
2
|
-
%h4= link_to truncate(asset.name, :
|
1
|
+
%li{ id: "asset-#{asset.id}", class: "asset #{'last' if (asset_counter + 1) % 6 == 0}"}
|
2
|
+
%h4= link_to truncate(asset.name, length: 17), edit_admin_asset_path(asset)
|
3
3
|
= vignette_tag(asset)
|
4
4
|
.actions
|
5
|
-
= link_to_icon :trash, '#', :
|
5
|
+
= link_to_icon :trash, '#', class: 'remove', data: { confirm: t('locomotive.messages.confirm') }, title: t('locomotive.buttons.delete')
|
@@ -1,33 +1,33 @@
|
|
1
|
-
%script{ :
|
1
|
+
%script{ type: 'text/html', id: 'content_asset_picker' }
|
2
2
|
|
3
3
|
%h2!= t('.title')
|
4
4
|
|
5
|
-
%p.no-items{ :
|
5
|
+
%p.no-items{ style: 'display: none' }!= t('.no_items')
|
6
6
|
|
7
|
-
%ul.list.content-assets{ :
|
7
|
+
%ul.list.content-assets{ style: 'display: none' }
|
8
8
|
%li.clear
|
9
9
|
|
10
10
|
.dialog-actions
|
11
|
-
= link_to t('locomotive.buttons.close'), '#', :
|
11
|
+
= link_to t('locomotive.buttons.close'), '#', id: 'close-link'
|
12
12
|
|
13
13
|
.button-wrapper.upload
|
14
|
-
= form_tag content_assets_url(:json), :
|
15
|
-
= file_field_tag 'content_asset[source]', :
|
16
|
-
= link_to t('locomotive.content_assets.image_picker.upload'), content_assets_url(:json), :
|
14
|
+
= form_tag content_assets_url(:json), class: 'quick-upload' do
|
15
|
+
= file_field_tag 'content_asset[source]', multiple: 'multiple'
|
16
|
+
= link_to t('locomotive.content_assets.image_picker.upload'), content_assets_url(:json), class: 'new', id: 'upload-link'
|
17
17
|
|
18
|
-
%script{ :
|
18
|
+
%script{ type: 'text/html', id: 'content_asset' }
|
19
19
|
|
20
20
|
%h4
|
21
|
-
= link_to '{{filename}}', '{{url}}', :
|
21
|
+
= link_to '{{filename}}', '{{url}}', alt: '{{full_filename}}', title: '{{full_filename}}'
|
22
22
|
{{#if image}}
|
23
23
|
.image
|
24
24
|
.inside
|
25
|
-
%img{ :
|
25
|
+
%img{ src: '{{vignette_url}}' }
|
26
26
|
{{else}}
|
27
|
-
.icon{ :
|
27
|
+
.icon{ class: '{{content_type}}' }
|
28
28
|
.inside
|
29
29
|
{{content_type_text}}
|
30
30
|
{{/if}}
|
31
31
|
|
32
32
|
.actions
|
33
|
-
= link_to_icon :trash, '#', :
|
33
|
+
= link_to_icon :trash, '#', class: 'remove', :'data-confirm' => t('locomotive.messages.confirm')
|
@@ -3,20 +3,21 @@
|
|
3
3
|
|
4
4
|
- content_for :backbone_view_data do
|
5
5
|
:plain
|
6
|
-
content_entry: #{
|
7
|
-
content_type: #{
|
6
|
+
content_entry: #{escape_json to_json(@content_entry)},
|
7
|
+
content_type: #{escape_json to_json(@content_type)}
|
8
8
|
|
9
|
-
= f.inputs :
|
9
|
+
= f.inputs name: :attributes do
|
10
10
|
- @content_type.ordered_entries_custom_fields.each_with_index do |field, index|
|
11
11
|
= render "locomotive/custom_fields/types/#{field.type}",
|
12
|
-
:
|
13
|
-
:
|
14
|
-
:
|
15
|
-
:
|
12
|
+
f: f,
|
13
|
+
name: field.name.to_sym,
|
14
|
+
field: field,
|
15
|
+
highlighted: field._id == @content_type.label_field_id
|
16
16
|
|
17
|
-
= f.inputs :
|
17
|
+
= f.inputs name: :advanced_options, class: "inputs foldable #{'folded' if inputs_folded?(@content_entry)}" do
|
18
18
|
|
19
19
|
= f.input :_slug
|
20
|
+
= f.input :_visible, as: :'Locomotive::Toggle'
|
20
21
|
= f.input :seo_title
|
21
22
|
= f.input :meta_keywords
|
22
23
|
= f.input :meta_description
|
@@ -1,9 +1,9 @@
|
|
1
1
|
- if entries.empty?
|
2
|
-
%p.no-items!= t('.no_items', :
|
2
|
+
%p.no-items!= t('.no_items', url: new_content_entry_url(content_type.slug))
|
3
3
|
- else
|
4
|
-
%ul{ :
|
4
|
+
%ul{ id: 'entries-list', class: "#{'list' unless content_type.groupable?} #{'sortable' if content_type.order_manually?}", :'data-url' => sort_content_entries_url(content_type.slug, :json) }
|
5
5
|
- entries.each do |entry|
|
6
|
-
%li.item{ :
|
6
|
+
%li.item{ id: "entry-#{entry._id}" }
|
7
7
|
%span.handle
|
8
8
|
|
9
9
|
%strong= link_to entry_label(content_type, entry), edit_content_entry_url(content_type.slug, entry)
|
@@ -13,6 +13,9 @@
|
|
13
13
|
.more
|
14
14
|
%span
|
15
15
|
!= t('locomotive.content_entries.index.updated_at')
|
16
|
-
= l entry.updated_at, :
|
16
|
+
= l entry.updated_at, format: :short rescue 'n/a'
|
17
17
|
|
18
|
-
= link_to_icon :trash, content_entry_url(content_type.slug, entry), :
|
18
|
+
= link_to_icon :trash, content_entry_url(content_type.slug, entry), title: t('locomotive.buttons.delete'), class: 'remove', data: { confirm: t('locomotive.messages.confirm') }, method: :delete
|
19
|
+
|
20
|
+
- if entries.respond_to?(:current_page)
|
21
|
+
= paginate entries, namespace: 'locomotive'
|
@@ -1,4 +1,4 @@
|
|
1
|
-
- title t('.title', :
|
1
|
+
- title t('.title', type: @content_type.name.capitalize)
|
2
2
|
|
3
3
|
- content_for :submenu do
|
4
4
|
= render 'locomotive/shared/menu/contents'
|
@@ -8,17 +8,17 @@
|
|
8
8
|
|
9
9
|
- content_for :buttons do
|
10
10
|
- if can?(:manage, Locomotive::ContentType)
|
11
|
-
= local_action_button t('locomotive.content_entries.index.edit'), edit_content_type_url(@content_type), :
|
11
|
+
= local_action_button t('locomotive.content_entries.index.edit'), edit_content_type_url(@content_type), icon: 'icon-pencil'
|
12
12
|
|
13
|
-
= local_action_button t('locomotive.content_entries.index.new'), new_content_entry_url(@content_type.slug), :
|
13
|
+
= local_action_button t('locomotive.content_entries.index.new'), new_content_entry_url(@content_type.slug), icon: 'icon-plus'
|
14
14
|
|
15
15
|
%p= @content_type.description
|
16
16
|
|
17
|
-
= semantic_form_for @content_entry, :
|
17
|
+
= semantic_form_for @content_entry, as: :content_entry, url: content_entry_url(@content_type.slug, @content_entry), html: { multipart: true } do |form|
|
18
18
|
|
19
|
-
= render 'form', :
|
19
|
+
= render 'form', f: form
|
20
20
|
|
21
|
-
= render 'locomotive/shared/form_actions', :
|
21
|
+
= render 'locomotive/shared/form_actions', back_url: content_entries_url(@content_type.slug), button_label: :update
|
22
22
|
|
23
23
|
- content_for :foot do
|
24
24
|
= render_has_many_forms
|
@@ -1,13 +1,15 @@
|
|
1
|
-
- title t('.title', :
|
1
|
+
- title t('.title', type: @content_type.name.capitalize)
|
2
2
|
|
3
3
|
- content_for :actions do
|
4
4
|
= render 'locomotive/shared/actions/contents'
|
5
5
|
|
6
6
|
- content_for :buttons do
|
7
7
|
- if can?(:manage, Locomotive::ContentType)
|
8
|
-
= local_action_button :edit, edit_content_type_url(@content_type), :
|
8
|
+
= local_action_button :edit, edit_content_type_url(@content_type), icon: 'icon-pencil'
|
9
9
|
|
10
|
-
= local_action_button :
|
10
|
+
= local_action_button :export, export_content_entries_url(@content_type.slug, :csv), icon: 'icon-download'
|
11
|
+
|
12
|
+
= local_action_button :new, new_content_entry_url(@content_type.slug), icon: 'icon-plus'
|
11
13
|
|
12
14
|
- if @content_type.description.present?
|
13
15
|
%p= @content_type.description
|
@@ -17,9 +19,9 @@
|
|
17
19
|
.box
|
18
20
|
%h3= group[:name] || t('.category_noname')
|
19
21
|
.inner
|
20
|
-
= render 'list', :
|
22
|
+
= render 'list', content_type: @content_type, entries: group[:entries]
|
21
23
|
- else
|
22
|
-
= render 'list', :
|
24
|
+
= render 'list', content_type: @content_type, entries: @content_entries
|
23
25
|
|
24
26
|
- # Note: submenu has to be here in order to have the previous entries correctly rendered since we do not return
|
25
27
|
- # all the attributes of the content types in the following code (causing stale documents)
|
@@ -29,4 +31,4 @@
|
|
29
31
|
- if can?(:manage, Locomotive::ContentType)
|
30
32
|
#local-actions-bottom-bar
|
31
33
|
%p.tleft
|
32
|
-
= link_to t('.destroy'), content_type_url(@content_type), :
|
34
|
+
= link_to t('.destroy'), content_type_url(@content_type), data: { confirm: t('locomotive.messages.confirm') }, method: :delete, class: 'button remove'
|
@@ -1,4 +1,4 @@
|
|
1
|
-
- title t('.title', :
|
1
|
+
- title t('.title', type: @content_type.name.capitalize)
|
2
2
|
|
3
3
|
- content_for :submenu do
|
4
4
|
= render 'locomotive/shared/menu/contents'
|
@@ -8,15 +8,15 @@
|
|
8
8
|
|
9
9
|
- if can?(:manage, Locomotive::ContentType)
|
10
10
|
- content_for :buttons do
|
11
|
-
= local_action_button t('locomotive.content_entries.index.edit'), edit_content_type_url(@content_type), :
|
11
|
+
= local_action_button t('locomotive.content_entries.index.edit'), edit_content_type_url(@content_type), icon: 'icon-pencil'
|
12
12
|
|
13
13
|
%p= @content_type.description
|
14
14
|
|
15
|
-
= semantic_form_for @content_entry, :
|
15
|
+
= semantic_form_for @content_entry, as: :content_entry, url: content_entries_url(@content_type.slug), html: { multipart: true } do |form|
|
16
16
|
|
17
|
-
= render 'form', :
|
17
|
+
= render 'form', f: form
|
18
18
|
|
19
|
-
= render 'locomotive/shared/form_actions', :
|
19
|
+
= render 'locomotive/shared/form_actions', back_url: content_entries_url(@content_type.slug), button_label: :create
|
20
20
|
|
21
21
|
- content_for :foot do
|
22
22
|
= render_has_many_forms
|