activeadministration 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.gitignore +47 -0
- data/.travis.yml +19 -0
- data/.yardopts +9 -0
- data/CHANGELOG.md +1074 -0
- data/CONTRIBUTING.md +139 -0
- data/Gemfile +52 -0
- data/Guardfile +7 -0
- data/LICENSE +25 -0
- data/README.md +8 -0
- data/Rakefile +33 -0
- data/activeadministration.gemspec +34 -0
- data/app/assets/images/active_admin/admin_notes_icon.png +0 -0
- data/app/assets/images/active_admin/datepicker/datepicker-header-bg.png +0 -0
- data/app/assets/images/active_admin/datepicker/datepicker-input-icon.png +0 -0
- data/app/assets/images/active_admin/datepicker/datepicker-next-link-icon.png +0 -0
- data/app/assets/images/active_admin/datepicker/datepicker-nipple.png +0 -0
- data/app/assets/images/active_admin/datepicker/datepicker-prev-link-icon.png +0 -0
- data/app/assets/images/active_admin/index_list_icons/block_icon.svg +10 -0
- data/app/assets/images/active_admin/index_list_icons/blog_icon.svg +4 -0
- data/app/assets/images/active_admin/index_list_icons/grid_icon.svg +13 -0
- data/app/assets/images/active_admin/index_list_icons/table_icon.svg +3 -0
- data/app/assets/images/active_admin/loading.gif +0 -0
- data/app/assets/images/active_admin/nested_menu_arrow.gif +0 -0
- data/app/assets/images/active_admin/nested_menu_arrow_dark.gif +0 -0
- data/app/assets/images/active_admin/orderable.png +0 -0
- data/app/assets/javascripts/active_admin/application.js.coffee +30 -0
- data/app/assets/javascripts/active_admin/base.js.coffee +14 -0
- data/app/assets/javascripts/active_admin/ext/jquery-ui.js.coffee +6 -0
- data/app/assets/javascripts/active_admin/ext/jquery.js.coffee +7 -0
- data/app/assets/javascripts/active_admin/lib/batch_actions.js.coffee +39 -0
- data/app/assets/javascripts/active_admin/lib/checkbox-toggler.js.coffee +36 -0
- data/app/assets/javascripts/active_admin/lib/dropdown-menu.js.coffee +85 -0
- data/app/assets/javascripts/active_admin/lib/has_many.js.coffee +75 -0
- data/app/assets/javascripts/active_admin/lib/modal_dialog.js.coffee +36 -0
- data/app/assets/javascripts/active_admin/lib/popover.js.coffee +68 -0
- data/app/assets/javascripts/active_admin/lib/table-checkbox-toggler.js.coffee +24 -0
- data/app/assets/stylesheets/active_admin/_base.css.scss +42 -0
- data/app/assets/stylesheets/active_admin/_forms.css.scss +329 -0
- data/app/assets/stylesheets/active_admin/_header.css.scss +156 -0
- data/app/assets/stylesheets/active_admin/_mixins.css.scss +1 -0
- data/app/assets/stylesheets/active_admin/_typography.css.scss +100 -0
- data/app/assets/stylesheets/active_admin/components/_batch_actions.css.scss +11 -0
- data/app/assets/stylesheets/active_admin/components/_blank_slates.scss +31 -0
- data/app/assets/stylesheets/active_admin/components/_breadcrumbs.scss +20 -0
- data/app/assets/stylesheets/active_admin/components/_buttons.scss +11 -0
- data/app/assets/stylesheets/active_admin/components/_columns.scss +3 -0
- data/app/assets/stylesheets/active_admin/components/_comments.css.scss +41 -0
- data/app/assets/stylesheets/active_admin/components/_date_picker.css.scss +127 -0
- data/app/assets/stylesheets/active_admin/components/_dropdown_menu.scss +151 -0
- data/app/assets/stylesheets/active_admin/components/_flash_messages.css.scss +39 -0
- data/app/assets/stylesheets/active_admin/components/_grid.scss +9 -0
- data/app/assets/stylesheets/active_admin/components/_index_list.scss +12 -0
- data/app/assets/stylesheets/active_admin/components/_links.scss +5 -0
- data/app/assets/stylesheets/active_admin/components/_modal_dialog.scss +31 -0
- data/app/assets/stylesheets/active_admin/components/_pagination.scss +34 -0
- data/app/assets/stylesheets/active_admin/components/_panels.scss +6 -0
- data/app/assets/stylesheets/active_admin/components/_popovers.css.scss +123 -0
- data/app/assets/stylesheets/active_admin/components/_scopes.scss +10 -0
- data/app/assets/stylesheets/active_admin/components/_status_tags.scss +16 -0
- data/app/assets/stylesheets/active_admin/components/_table_tools.css.scss +65 -0
- data/app/assets/stylesheets/active_admin/components/_tables.css.scss +111 -0
- data/app/assets/stylesheets/active_admin/mixins/_all.css.scss +11 -0
- data/app/assets/stylesheets/active_admin/mixins/_buttons.css.scss +66 -0
- data/app/assets/stylesheets/active_admin/mixins/_gradients.css.scss +38 -0
- data/app/assets/stylesheets/active_admin/mixins/_icons.css.scss +20 -0
- data/app/assets/stylesheets/active_admin/mixins/_reset.css.scss +165 -0
- data/app/assets/stylesheets/active_admin/mixins/_rounded.css.scss +43 -0
- data/app/assets/stylesheets/active_admin/mixins/_sections.css.scss +36 -0
- data/app/assets/stylesheets/active_admin/mixins/_shadows.css.scss +22 -0
- data/app/assets/stylesheets/active_admin/mixins/_typography.scss +3 -0
- data/app/assets/stylesheets/active_admin/mixins/_utilities.scss +26 -0
- data/app/assets/stylesheets/active_admin/mixins/_variables.css.scss +34 -0
- data/app/assets/stylesheets/active_admin/pages/_logged_out.scss +44 -0
- data/app/assets/stylesheets/active_admin/print.css.scss +284 -0
- data/app/assets/stylesheets/active_admin/structure/_footer.scss +14 -0
- data/app/assets/stylesheets/active_admin/structure/_main_structure.scss +29 -0
- data/app/assets/stylesheets/active_admin/structure/_title_bar.scss +46 -0
- data/app/views/active_admin/dashboard/index.html.arb +1 -0
- data/app/views/active_admin/devise/confirmations/new.html.erb +14 -0
- data/app/views/active_admin/devise/mailer/reset_password_instructions.html.erb +8 -0
- data/app/views/active_admin/devise/mailer/unlock_instructions.html.erb +7 -0
- data/app/views/active_admin/devise/passwords/edit.html.erb +19 -0
- data/app/views/active_admin/devise/passwords/new.html.erb +14 -0
- data/app/views/active_admin/devise/registrations/new.html.erb +22 -0
- data/app/views/active_admin/devise/sessions/new.html.erb +20 -0
- data/app/views/active_admin/devise/shared/_links.erb +27 -0
- data/app/views/active_admin/devise/unlocks/new.html.erb +14 -0
- data/app/views/active_admin/page/index.html.arb +1 -0
- data/app/views/active_admin/resource/edit.html.arb +1 -0
- data/app/views/active_admin/resource/index.csv.erb +17 -0
- data/app/views/active_admin/resource/index.html.arb +1 -0
- data/app/views/active_admin/resource/new.html.arb +1 -0
- data/app/views/active_admin/resource/show.html.arb +1 -0
- data/app/views/kaminari/active_admin/_first_page.html.erb +11 -0
- data/app/views/kaminari/active_admin/_gap.html.erb +8 -0
- data/app/views/kaminari/active_admin/_last_page.html.erb +11 -0
- data/app/views/kaminari/active_admin/_next_page.html.erb +11 -0
- data/app/views/kaminari/active_admin/_page.html.erb +12 -0
- data/app/views/kaminari/active_admin/_paginator.html.erb +23 -0
- data/app/views/kaminari/active_admin/_prev_page.html.erb +11 -0
- data/app/views/layouts/active_admin.html.arb +1 -0
- data/app/views/layouts/active_admin_logged_out.html.erb +37 -0
- data/config/locales/bg.yml +102 -0
- data/config/locales/bs.yml +121 -0
- data/config/locales/ca.yml +102 -0
- data/config/locales/cs.yml +106 -0
- data/config/locales/da.yml +103 -0
- data/config/locales/de-CH.yml +118 -0
- data/config/locales/de.yml +143 -0
- data/config/locales/el.yml +111 -0
- data/config/locales/en-GB.yml +95 -0
- data/config/locales/en.yml +117 -0
- data/config/locales/es.yml +127 -0
- data/config/locales/es_MX.yml +110 -0
- data/config/locales/fi.yml +110 -0
- data/config/locales/fr.yml +109 -0
- data/config/locales/he.yml +92 -0
- data/config/locales/hr.yml +121 -0
- data/config/locales/hu.yml +96 -0
- data/config/locales/it.yml +114 -0
- data/config/locales/ja.yml +114 -0
- data/config/locales/ko.yml +85 -0
- data/config/locales/lt.yml +118 -0
- data/config/locales/lv.yml +90 -0
- data/config/locales/nl.yml +94 -0
- data/config/locales/no-NB.yml +111 -0
- data/config/locales/pl.yml +100 -0
- data/config/locales/pt-BR.yml +117 -0
- data/config/locales/pt-PT.yml +90 -0
- data/config/locales/ro.yml +94 -0
- data/config/locales/ru.yml +121 -0
- data/config/locales/sv-SE.yml +90 -0
- data/config/locales/tr.yml +94 -0
- data/config/locales/uk.yml +121 -0
- data/config/locales/vi.yml +91 -0
- data/config/locales/zh-CN.yml +112 -0
- data/config/locales/zh-TW.yml +94 -0
- data/cucumber.yml +3 -0
- data/docs/0-installation.md +84 -0
- data/docs/1-general-configuration.md +138 -0
- data/docs/10-custom-pages.md +84 -0
- data/docs/11-decorators.md +50 -0
- data/docs/12-arbre-components.md +150 -0
- data/docs/13-authorization-adapter.md +239 -0
- data/docs/2-resource-customization.md +359 -0
- data/docs/3-index-pages.md +245 -0
- data/docs/3-index-pages/create-an-index.md +31 -0
- data/docs/3-index-pages/index-as-block.md +21 -0
- data/docs/3-index-pages/index-as-blog.md +71 -0
- data/docs/3-index-pages/index-as-grid.md +29 -0
- data/docs/3-index-pages/index-as-table.md +163 -0
- data/docs/4-csv-format.md +39 -0
- data/docs/5-forms.md +118 -0
- data/docs/6-show-pages.md +77 -0
- data/docs/7-sidebars.md +63 -0
- data/docs/8-custom-actions.md +159 -0
- data/docs/9-batch-actions.md +233 -0
- data/features/action_item.feature +73 -0
- data/features/authorization.feature +64 -0
- data/features/authorization_cancan.feature +52 -0
- data/features/authorization_pundit.feature +37 -0
- data/features/belongs_to.feature +66 -0
- data/features/breadcrumb.feature +75 -0
- data/features/comments/commenting.feature +159 -0
- data/features/comments/viewing_index.feature +19 -0
- data/features/dashboard.feature +16 -0
- data/features/decorators.feature +41 -0
- data/features/development_reloading.feature +31 -0
- data/features/edit_page.feature +114 -0
- data/features/favicon.feature +20 -0
- data/features/first_boot.feature +16 -0
- data/features/global_navigation.feature +29 -0
- data/features/i18n.feature +43 -0
- data/features/index/batch_actions.feature +123 -0
- data/features/index/filters.feature +138 -0
- data/features/index/format_as_csv.feature +117 -0
- data/features/index/formats.feature +66 -0
- data/features/index/index_as_block.feature +15 -0
- data/features/index/index_as_blog.feature +69 -0
- data/features/index/index_as_grid.feature +45 -0
- data/features/index/index_as_table.feature +208 -0
- data/features/index/index_blank_slate.feature +83 -0
- data/features/index/index_parameters.feature +75 -0
- data/features/index/index_scope_to.feature +56 -0
- data/features/index/index_scopes.feature +251 -0
- data/features/index/page_title.feature +41 -0
- data/features/index/pagination.feature +59 -0
- data/features/index/switch_index_view.feature +73 -0
- data/features/menu.feature +53 -0
- data/features/new_page.feature +106 -0
- data/features/registering_assets.feature +35 -0
- data/features/registering_pages.feature +148 -0
- data/features/registering_resources.feature +33 -0
- data/features/root_to.feature +17 -0
- data/features/show/default_content.feature +43 -0
- data/features/show/page_title.feature +58 -0
- data/features/sidebar_sections.feature +210 -0
- data/features/site_title.feature +47 -0
- data/features/specifying_actions.feature +93 -0
- data/features/step_definitions/action_item_steps.rb +7 -0
- data/features/step_definitions/action_link_steps.rb +7 -0
- data/features/step_definitions/additional_web_steps.rb +82 -0
- data/features/step_definitions/asset_steps.rb +15 -0
- data/features/step_definitions/attribute_steps.rb +18 -0
- data/features/step_definitions/batch_action_steps.rb +55 -0
- data/features/step_definitions/breadcrumb_steps.rb +3 -0
- data/features/step_definitions/comment_steps.rb +12 -0
- data/features/step_definitions/configuration_steps.rb +100 -0
- data/features/step_definitions/dashboard_steps.rb +15 -0
- data/features/step_definitions/factory_steps.rb +34 -0
- data/features/step_definitions/filter_steps.rb +17 -0
- data/features/step_definitions/flash_steps.rb +11 -0
- data/features/step_definitions/format_steps.rb +45 -0
- data/features/step_definitions/i18n_steps.rb +3 -0
- data/features/step_definitions/index_scope_steps.rb +21 -0
- data/features/step_definitions/index_views_steps.rb +3 -0
- data/features/step_definitions/layout_steps.rb +3 -0
- data/features/step_definitions/member_link_steps.rb +7 -0
- data/features/step_definitions/menu_steps.rb +11 -0
- data/features/step_definitions/pagination_steps.rb +8 -0
- data/features/step_definitions/sidebar_steps.rb +12 -0
- data/features/step_definitions/site_title_steps.rb +15 -0
- data/features/step_definitions/symbol_leak_steps.rb +3 -0
- data/features/step_definitions/tab_steps.rb +3 -0
- data/features/step_definitions/table_steps.rb +119 -0
- data/features/step_definitions/user_steps.rb +41 -0
- data/features/step_definitions/web_steps.rb +86 -0
- data/features/sti_resource.feature +65 -0
- data/features/strong_parameters.feature +72 -0
- data/features/support/env.rb +119 -0
- data/features/support/paths.rb +71 -0
- data/features/support/selectors.rb +45 -0
- data/features/symbol_leak.feature +35 -0
- data/features/users/logging_in.feature +34 -0
- data/features/users/logging_out.feature +13 -0
- data/features/users/resetting_password.feature +34 -0
- data/lib/active_admin.rb +135 -0
- data/lib/active_admin/abstract_view_factory.rb +86 -0
- data/lib/active_admin/application.rb +250 -0
- data/lib/active_admin/asset_registration.rb +29 -0
- data/lib/active_admin/authorization_adapter.rb +132 -0
- data/lib/active_admin/base_controller.rb +78 -0
- data/lib/active_admin/base_controller/authorization.rb +151 -0
- data/lib/active_admin/base_controller/menu.rb +34 -0
- data/lib/active_admin/batch_actions.rb +17 -0
- data/lib/active_admin/batch_actions/controller.rb +29 -0
- data/lib/active_admin/batch_actions/resource_extension.rb +154 -0
- data/lib/active_admin/batch_actions/views/batch_action_form.rb +38 -0
- data/lib/active_admin/batch_actions/views/batch_action_popover.rb +28 -0
- data/lib/active_admin/batch_actions/views/batch_action_selector.rb +57 -0
- data/lib/active_admin/batch_actions/views/selection_cells.rb +37 -0
- data/lib/active_admin/callbacks.rb +84 -0
- data/lib/active_admin/cancan_adapter.rb +40 -0
- data/lib/active_admin/component.rb +5 -0
- data/lib/active_admin/controller_action.rb +12 -0
- data/lib/active_admin/csv_builder.rb +70 -0
- data/lib/active_admin/dependencies.rb +38 -0
- data/lib/active_admin/deprecation.rb +35 -0
- data/lib/active_admin/devise.rb +80 -0
- data/lib/active_admin/dsl.rb +165 -0
- data/lib/active_admin/engine.rb +7 -0
- data/lib/active_admin/error.rb +22 -0
- data/lib/active_admin/event.rb +33 -0
- data/lib/active_admin/filters.rb +9 -0
- data/lib/active_admin/filters/dsl.rb +21 -0
- data/lib/active_admin/filters/forms.rb +87 -0
- data/lib/active_admin/filters/formtastic_addons.rb +73 -0
- data/lib/active_admin/filters/resource_extension.rb +135 -0
- data/lib/active_admin/form_builder.rb +185 -0
- data/lib/active_admin/helpers/collection.rb +23 -0
- data/lib/active_admin/helpers/i18n.rb +7 -0
- data/lib/active_admin/helpers/optional_display.rb +38 -0
- data/lib/active_admin/helpers/scope_chain.rb +23 -0
- data/lib/active_admin/helpers/settings.rb +106 -0
- data/lib/active_admin/iconic.rb +54 -0
- data/lib/active_admin/iconic/icons.rb +142 -0
- data/lib/active_admin/inputs.rb +15 -0
- data/lib/active_admin/inputs/datepicker_input.rb +20 -0
- data/lib/active_admin/inputs/filter_base.rb +40 -0
- data/lib/active_admin/inputs/filter_base/search_method_select.rb +73 -0
- data/lib/active_admin/inputs/filter_boolean_input.rb +32 -0
- data/lib/active_admin/inputs/filter_check_boxes_input.rb +48 -0
- data/lib/active_admin/inputs/filter_date_range_input.rb +34 -0
- data/lib/active_admin/inputs/filter_numeric_input.rb +10 -0
- data/lib/active_admin/inputs/filter_select_input.rb +53 -0
- data/lib/active_admin/inputs/filter_string_input.rb +24 -0
- data/lib/active_admin/menu.rb +107 -0
- data/lib/active_admin/menu_collection.rb +96 -0
- data/lib/active_admin/menu_item.rb +97 -0
- data/lib/active_admin/namespace.rb +231 -0
- data/lib/active_admin/order_clause.rb +26 -0
- data/lib/active_admin/orm/active_record.rb +3 -0
- data/lib/active_admin/orm/active_record/comments.rb +84 -0
- data/lib/active_admin/orm/active_record/comments/comment.rb +49 -0
- data/lib/active_admin/orm/active_record/comments/namespace_helper.rb +14 -0
- data/lib/active_admin/orm/active_record/comments/resource_helper.rb +17 -0
- data/lib/active_admin/orm/active_record/comments/show_page_helper.rb +23 -0
- data/lib/active_admin/orm/active_record/comments/views.rb +2 -0
- data/lib/active_admin/orm/active_record/comments/views/active_admin_comments.rb +75 -0
- data/lib/active_admin/orm/mongoid.rb +1 -0
- data/lib/active_admin/orm/mongoid/.gitkeep +0 -0
- data/lib/active_admin/page.rb +88 -0
- data/lib/active_admin/page_controller.rb +29 -0
- data/lib/active_admin/page_dsl.rb +28 -0
- data/lib/active_admin/page_presenter.rb +32 -0
- data/lib/active_admin/pundit_adapter.rb +42 -0
- data/lib/active_admin/resource.rb +156 -0
- data/lib/active_admin/resource/action_items.rb +91 -0
- data/lib/active_admin/resource/belongs_to.rb +36 -0
- data/lib/active_admin/resource/controllers.rb +18 -0
- data/lib/active_admin/resource/menu.rb +64 -0
- data/lib/active_admin/resource/naming.rb +84 -0
- data/lib/active_admin/resource/page_presenters.rb +82 -0
- data/lib/active_admin/resource/pagination.rb +19 -0
- data/lib/active_admin/resource/routes.rb +99 -0
- data/lib/active_admin/resource/scope_to.rb +74 -0
- data/lib/active_admin/resource/scopes.rb +50 -0
- data/lib/active_admin/resource/sidebars.rb +28 -0
- data/lib/active_admin/resource_collection.rb +70 -0
- data/lib/active_admin/resource_controller.rb +50 -0
- data/lib/active_admin/resource_controller/action_builder.rb +21 -0
- data/lib/active_admin/resource_controller/data_access.rb +284 -0
- data/lib/active_admin/resource_controller/decorators.rb +100 -0
- data/lib/active_admin/resource_controller/resource_class_methods.rb +24 -0
- data/lib/active_admin/resource_controller/scoping.rb +31 -0
- data/lib/active_admin/resource_controller/sidebars.rb +18 -0
- data/lib/active_admin/resource_dsl.rb +171 -0
- data/lib/active_admin/router.rb +106 -0
- data/lib/active_admin/scope.rb +57 -0
- data/lib/active_admin/sidebar_section.rb +45 -0
- data/lib/active_admin/version.rb +3 -0
- data/lib/active_admin/view_factory.rb +27 -0
- data/lib/active_admin/view_helpers.rb +21 -0
- data/lib/active_admin/view_helpers/active_admin_application_helper.rb +12 -0
- data/lib/active_admin/view_helpers/assigns_with_indifferent_access_helper.rb +7 -0
- data/lib/active_admin/view_helpers/auto_link_helper.rb +37 -0
- data/lib/active_admin/view_helpers/breadcrumb_helper.rb +27 -0
- data/lib/active_admin/view_helpers/display_helper.rb +64 -0
- data/lib/active_admin/view_helpers/download_format_links_helper.rb +49 -0
- data/lib/active_admin/view_helpers/fields_for.rb +50 -0
- data/lib/active_admin/view_helpers/flash_helper.rb +13 -0
- data/lib/active_admin/view_helpers/form_helper.rb +21 -0
- data/lib/active_admin/view_helpers/icon_helper.rb +12 -0
- data/lib/active_admin/view_helpers/method_or_proc_helper.rb +93 -0
- data/lib/active_admin/view_helpers/sidebar_helper.rb +15 -0
- data/lib/active_admin/view_helpers/title_helper.rb +11 -0
- data/lib/active_admin/view_helpers/view_factory_helper.rb +11 -0
- data/lib/active_admin/views.rb +8 -0
- data/lib/active_admin/views/action_items.rb +17 -0
- data/lib/active_admin/views/components/action_list_popover.rb +29 -0
- data/lib/active_admin/views/components/attributes_table.rb +105 -0
- data/lib/active_admin/views/components/blank_slate.rb +17 -0
- data/lib/active_admin/views/components/columns.rb +157 -0
- data/lib/active_admin/views/components/dropdown_menu.rb +73 -0
- data/lib/active_admin/views/components/index_list.rb +68 -0
- data/lib/active_admin/views/components/paginated_collection.rb +126 -0
- data/lib/active_admin/views/components/panel.rb +34 -0
- data/lib/active_admin/views/components/popover.rb +27 -0
- data/lib/active_admin/views/components/scopes.rb +66 -0
- data/lib/active_admin/views/components/sidebar_section.rb +29 -0
- data/lib/active_admin/views/components/site_title.rb +55 -0
- data/lib/active_admin/views/components/status_tag.rb +67 -0
- data/lib/active_admin/views/components/table_for.rb +212 -0
- data/lib/active_admin/views/footer.rb +20 -0
- data/lib/active_admin/views/header.rb +32 -0
- data/lib/active_admin/views/index_as_block.rb +36 -0
- data/lib/active_admin/views/index_as_blog.rb +156 -0
- data/lib/active_admin/views/index_as_grid.rb +80 -0
- data/lib/active_admin/views/index_as_table.rb +277 -0
- data/lib/active_admin/views/pages/base.rb +139 -0
- data/lib/active_admin/views/pages/form.rb +51 -0
- data/lib/active_admin/views/pages/index.rb +163 -0
- data/lib/active_admin/views/pages/layout.rb +26 -0
- data/lib/active_admin/views/pages/page.rb +30 -0
- data/lib/active_admin/views/pages/show.rb +59 -0
- data/lib/active_admin/views/tabbed_navigation.rb +62 -0
- data/lib/active_admin/views/title_bar.rb +55 -0
- data/lib/activeadmin.rb +1 -0
- data/lib/generators/active_admin/assets/assets_generator.rb +16 -0
- data/lib/generators/active_admin/assets/templates/active_admin.css.scss +17 -0
- data/lib/generators/active_admin/assets/templates/active_admin.js.coffee +1 -0
- data/lib/generators/active_admin/devise/devise_generator.rb +66 -0
- data/lib/generators/active_admin/install/install_generator.rb +46 -0
- data/lib/generators/active_admin/install/templates/active_admin.rb.erb +243 -0
- data/lib/generators/active_admin/install/templates/admin_user.rb.erb +30 -0
- data/lib/generators/active_admin/install/templates/dashboard.rb +33 -0
- data/lib/generators/active_admin/install/templates/migrations/create_active_admin_comments.rb +19 -0
- data/lib/generators/active_admin/resource/resource_generator.rb +16 -0
- data/lib/generators/active_admin/resource/templates/admin.rb +17 -0
- data/lib/ransack_ext.rb +12 -0
- data/script/local +44 -0
- data/script/use_rails +53 -0
- data/spec/integration/default_namespace_spec.rb +61 -0
- data/spec/integration/javascript_spec.rb +20 -0
- data/spec/integration/memory_spec.rb +29 -0
- data/spec/integration/stylesheets_spec.rb +18 -0
- data/spec/javascripts/coffeescripts/jquery.aa.checkbox-toggler-spec.js.coffee +50 -0
- data/spec/javascripts/coffeescripts/jquery.aa.popover-spec.js.coffee +82 -0
- data/spec/javascripts/coffeescripts/jquery.aa.table-checkbox-toggler-spec.js.coffee +34 -0
- data/spec/javascripts/compiled/jquery.aa.checkbox-toggler-spec.js +60 -0
- data/spec/javascripts/compiled/jquery.aa.popover-spec.js +106 -0
- data/spec/javascripts/compiled/jquery.aa.table-checkbox-toggler-spec.js +37 -0
- data/spec/javascripts/fixtures/checkboxes.html +9 -0
- data/spec/javascripts/fixtures/table_checkboxes.html +17 -0
- data/spec/javascripts/helpers/SpecHelper.js +3 -0
- data/spec/javascripts/helpers/vendor/jasmine-fixture-0.0.5.js +108 -0
- data/spec/javascripts/helpers/vendor/jasmine-jquery.js +288 -0
- data/spec/javascripts/helpers/vendor/sinon-1.2.0.js +2915 -0
- data/spec/javascripts/support/jasmine.yml +74 -0
- data/spec/javascripts/support/jasmine_config.rb +23 -0
- data/spec/javascripts/support/jasmine_runner.rb +32 -0
- data/spec/javascripts/support/jquery-ui-1.8.16.custom.min.js +34 -0
- data/spec/javascripts/support/jquery.min.js +4 -0
- data/spec/spec_helper.rb +182 -0
- data/spec/spec_helper_without_rails.rb +16 -0
- data/spec/support/deferred_garbage_collection.rb +19 -0
- data/spec/support/detect_rails_version.rb +42 -0
- data/spec/support/integration_example_group.rb +31 -0
- data/spec/support/jslint.yml +80 -0
- data/spec/support/rails_template.rb +117 -0
- data/spec/support/rails_template_with_data.rb +59 -0
- data/spec/support/templates/admin/stores.rb +11 -0
- data/spec/support/templates/cucumber.rb +24 -0
- data/spec/support/templates/cucumber_with_reloading.rb +5 -0
- data/spec/support/templates/en.yml +8 -0
- data/spec/support/templates/policies/active_admin/comment_policy.rb +9 -0
- data/spec/support/templates/policies/active_admin/page_policy.rb +18 -0
- data/spec/support/templates/policies/admin_user_policy.rb +11 -0
- data/spec/support/templates/policies/application_policy.rb +45 -0
- data/spec/support/templates/policies/category_policy.rb +7 -0
- data/spec/support/templates/policies/post_policy.rb +15 -0
- data/spec/support/templates/policies/store_policy.rb +11 -0
- data/spec/support/templates/policies/user_policy.rb +11 -0
- data/spec/support/templates/post_decorator.rb +11 -0
- data/spec/unit/abstract_view_factory_spec.rb +79 -0
- data/spec/unit/action_builder_spec.rb +126 -0
- data/spec/unit/active_admin_spec.rb +11 -0
- data/spec/unit/application_spec.rb +140 -0
- data/spec/unit/asset_registration_spec.rb +52 -0
- data/spec/unit/authorization/authorization_adapter_spec.rb +61 -0
- data/spec/unit/authorization/controller_authorization_spec.rb +39 -0
- data/spec/unit/auto_link_spec.rb +34 -0
- data/spec/unit/batch_actions/resource_spec.rb +92 -0
- data/spec/unit/batch_actions/settings_spec.rb +61 -0
- data/spec/unit/belongs_to_spec.rb +42 -0
- data/spec/unit/cancan_adapter_spec.rb +43 -0
- data/spec/unit/comments_spec.rb +144 -0
- data/spec/unit/component_spec.rb +18 -0
- data/spec/unit/config_shared_examples.rb +59 -0
- data/spec/unit/controller_filters_spec.rb +37 -0
- data/spec/unit/csv_builder_spec.rb +134 -0
- data/spec/unit/devise_spec.rb +116 -0
- data/spec/unit/dsl_spec.rb +61 -0
- data/spec/unit/event_spec.rb +47 -0
- data/spec/unit/filters/filter_form_builder_spec.rb +418 -0
- data/spec/unit/filters/resource_spec.rb +121 -0
- data/spec/unit/form_builder_spec.rb +576 -0
- data/spec/unit/generators/install_spec.rb +23 -0
- data/spec/unit/helpers/collection_spec.rb +65 -0
- data/spec/unit/helpers/scope_chain_spec.rb +36 -0
- data/spec/unit/helpers/settings_spec.rb +30 -0
- data/spec/unit/menu_collection_spec.rb +62 -0
- data/spec/unit/menu_item_spec.rb +143 -0
- data/spec/unit/menu_spec.rb +71 -0
- data/spec/unit/namespace/authorization_spec.rb +27 -0
- data/spec/unit/namespace/register_page_spec.rb +74 -0
- data/spec/unit/namespace/register_resource_spec.rb +163 -0
- data/spec/unit/namespace_spec.rb +103 -0
- data/spec/unit/order_clause_spec.rb +57 -0
- data/spec/unit/page_controller_spec.rb +5 -0
- data/spec/unit/page_spec.rb +72 -0
- data/spec/unit/pretty_format_spec.rb +63 -0
- data/spec/unit/pundit_adapter_spec.rb +36 -0
- data/spec/unit/resource/action_items_spec.rb +62 -0
- data/spec/unit/resource/menu_spec.rb +18 -0
- data/spec/unit/resource/naming_spec.rb +122 -0
- data/spec/unit/resource/page_presenters_spec.rb +44 -0
- data/spec/unit/resource/pagination_spec.rb +38 -0
- data/spec/unit/resource/routes_spec.rb +73 -0
- data/spec/unit/resource/scopes_spec.rb +50 -0
- data/spec/unit/resource/sidebars_spec.rb +43 -0
- data/spec/unit/resource_collection_spec.rb +158 -0
- data/spec/unit/resource_controller/data_access_spec.rb +73 -0
- data/spec/unit/resource_controller/decorators_spec.rb +86 -0
- data/spec/unit/resource_controller/sidebars_spec.rb +46 -0
- data/spec/unit/resource_controller_spec.rb +265 -0
- data/spec/unit/resource_registration_spec.rb +56 -0
- data/spec/unit/resource_spec.rb +263 -0
- data/spec/unit/routing_spec.rb +172 -0
- data/spec/unit/scope_spec.rb +114 -0
- data/spec/unit/settings_spec.rb +88 -0
- data/spec/unit/view_factory_spec.rb +21 -0
- data/spec/unit/view_helpers/breadcrumbs_spec.rb +180 -0
- data/spec/unit/view_helpers/display_name_spec.rb +68 -0
- data/spec/unit/view_helpers/download_format_links_helper_spec.rb +39 -0
- data/spec/unit/view_helpers/fields_for_spec.rb +50 -0
- data/spec/unit/view_helpers/form_helper_spec.rb +42 -0
- data/spec/unit/view_helpers/method_or_proc_helper_spec.rb +97 -0
- data/spec/unit/views/components/action_list_popover_spec.rb +29 -0
- data/spec/unit/views/components/attributes_table_spec.rb +259 -0
- data/spec/unit/views/components/batch_action_popover_spec.rb +33 -0
- data/spec/unit/views/components/blank_slate_spec.rb +17 -0
- data/spec/unit/views/components/columns_spec.rb +172 -0
- data/spec/unit/views/components/index_list_spec.rb +32 -0
- data/spec/unit/views/components/paginated_collection_spec.rb +229 -0
- data/spec/unit/views/components/panel_spec.rb +51 -0
- data/spec/unit/views/components/popover_spec.rb +33 -0
- data/spec/unit/views/components/sidebar_section_spec.rb +47 -0
- data/spec/unit/views/components/site_title_spec.rb +78 -0
- data/spec/unit/views/components/status_tag_spec.rb +102 -0
- data/spec/unit/views/components/table_for_spec.rb +242 -0
- data/spec/unit/views/pages/form_spec.rb +35 -0
- data/spec/unit/views/pages/layout_spec.rb +63 -0
- data/spec/unit/views/pages/show_spec.rb +20 -0
- data/spec/unit/views/tabbed_navigation_spec.rb +149 -0
- data/tasks/docs.rake +37 -0
- data/tasks/js.rake +32 -0
- data/tasks/parallel_tests.rake +60 -0
- data/tasks/test.rake +79 -0
- data/tasks/yard.rake +7 -0
- metadata +741 -0
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
# Arbre Components
|
|
2
|
+
|
|
3
|
+
Arbre allows the creation of shareable and extendable HTML components and is
|
|
4
|
+
used throughout Active Admin to create view components.
|
|
5
|
+
|
|
6
|
+
## Text Node
|
|
7
|
+
|
|
8
|
+
Sometimes it makes sense to insert something into a registered resource like a
|
|
9
|
+
non-breaking space or some text. The text_node method can be used to insert
|
|
10
|
+
these elements into the page inside of other Arbre components or resource
|
|
11
|
+
controller functions.
|
|
12
|
+
|
|
13
|
+
```ruby
|
|
14
|
+
ActiveAdmin.register Post do
|
|
15
|
+
show do
|
|
16
|
+
panel "Post Details" do
|
|
17
|
+
attributes_table_for post do
|
|
18
|
+
row :id
|
|
19
|
+
row 'Tags' do
|
|
20
|
+
post.tags.each do |tag|
|
|
21
|
+
a tag, href: admin_post_path(q: {tagged_with_contains: tag})
|
|
22
|
+
text_node " ".html_safe
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
end
|
|
28
|
+
end
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
## Panels
|
|
32
|
+
|
|
33
|
+
A panel is a component that takes up all available horizontal space and takes a
|
|
34
|
+
title and a hash of attributes as arguments. If a sidebar is present, a panel
|
|
35
|
+
will take up the remaining space.
|
|
36
|
+
|
|
37
|
+
This will create two stacked panels:
|
|
38
|
+
|
|
39
|
+
```ruby
|
|
40
|
+
show do
|
|
41
|
+
panel "Post Details" do
|
|
42
|
+
render partial: "details", locals: {post: post}
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
panel "Post Tags" do
|
|
46
|
+
render partial: "tags", locals: {post: post}
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
## Columns
|
|
52
|
+
|
|
53
|
+
The Columns component allows you draw content into scalable columns. All you
|
|
54
|
+
need to do is define the number of columns and the component will take care of
|
|
55
|
+
the rest.
|
|
56
|
+
|
|
57
|
+
#### Simple Columns
|
|
58
|
+
|
|
59
|
+
To create simple columnns, use the `columns` method. Within the block, call
|
|
60
|
+
the #column method to create a new column.
|
|
61
|
+
|
|
62
|
+
```ruby
|
|
63
|
+
columns do
|
|
64
|
+
column do
|
|
65
|
+
span "Column #1"
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
column do
|
|
69
|
+
span "Column #2"
|
|
70
|
+
end
|
|
71
|
+
end
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
### Spanning Multiple Columns
|
|
75
|
+
|
|
76
|
+
To create columns that have multiple spans, pass the :span option to the column
|
|
77
|
+
method.
|
|
78
|
+
|
|
79
|
+
```ruby
|
|
80
|
+
columns do
|
|
81
|
+
column span: 2 do
|
|
82
|
+
span "Column # 1"
|
|
83
|
+
end
|
|
84
|
+
column do
|
|
85
|
+
span "Column # 2"
|
|
86
|
+
end
|
|
87
|
+
end
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
By default, each column spans 1 column. The above layout would have 2 columns,
|
|
91
|
+
the first being twice as large as the second.
|
|
92
|
+
|
|
93
|
+
### Custom Column Widths
|
|
94
|
+
|
|
95
|
+
Active Admin uses a fluid width layout, causing column width to be defined
|
|
96
|
+
using percentages. Due to using this style of layout, columns can shrink or
|
|
97
|
+
expand past points that may not be desirable. To overcome this issue,
|
|
98
|
+
columns provide `:max_width` and `:min_width` options.
|
|
99
|
+
|
|
100
|
+
```ruby
|
|
101
|
+
columns do
|
|
102
|
+
column max_width: "200px", min_width: "100px" do
|
|
103
|
+
span "Column # 1"
|
|
104
|
+
end
|
|
105
|
+
column do
|
|
106
|
+
span "Column # 2"
|
|
107
|
+
end
|
|
108
|
+
end
|
|
109
|
+
```
|
|
110
|
+
|
|
111
|
+
In the above example, the first column will not grow larger than 200px and will
|
|
112
|
+
not shrink less than 100px.
|
|
113
|
+
|
|
114
|
+
## Table For
|
|
115
|
+
|
|
116
|
+
Table For provides the ability to create tables like those present
|
|
117
|
+
in `index_as_table`. It takes a collection and a hash of options and then
|
|
118
|
+
uses `column` to build the fields to show with the table.
|
|
119
|
+
|
|
120
|
+
```ruby
|
|
121
|
+
table_for order.payments do
|
|
122
|
+
column(:payment_type) { |payment| payment.payment_type.titleize }
|
|
123
|
+
column "Received On", :created_at
|
|
124
|
+
column "Details & Notes", :payment_details
|
|
125
|
+
column "Amount", :amount_in_dollars
|
|
126
|
+
end
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
the `column` method can take a title as its first argument and data
|
|
130
|
+
(`:your_method`) as its second (or first if no title provided). Column also
|
|
131
|
+
takes a block.
|
|
132
|
+
|
|
133
|
+
## Status tag
|
|
134
|
+
|
|
135
|
+
Status tags provide convenient syntactic sugar for styling items that have
|
|
136
|
+
status. A common example of where the status tag could be useful is for orders
|
|
137
|
+
that are complete or in progress. `status_tag` takes a status, like
|
|
138
|
+
"In Progress", a type, which defaults to nil, and a hash of options. The
|
|
139
|
+
status_tag will generate html markup that Active Admin css uses in styling.
|
|
140
|
+
|
|
141
|
+
```ruby
|
|
142
|
+
status_tag 'In Progress'
|
|
143
|
+
# => <span class='status_tag in_progress'>In Progress</span>
|
|
144
|
+
|
|
145
|
+
status_tag 'active', :ok
|
|
146
|
+
# => <span class='status_tag active ok'>Active</span>
|
|
147
|
+
|
|
148
|
+
status_tag 'active', :ok, class: 'important', id: 'status_123', label: 'on'
|
|
149
|
+
# => <span class='status_tag active ok important' id='status_123'>on</span>
|
|
150
|
+
```
|
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
# Authorization Adapter
|
|
2
|
+
|
|
3
|
+
Active Admin offers the ability to define and use your own authorization
|
|
4
|
+
adapter. If implemented, the '#authorized?' will be called when an action is
|
|
5
|
+
taken. By default, '#authorized?' returns true.
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
## Setting up your own AuthorizationAdapter
|
|
9
|
+
|
|
10
|
+
Setting up your own `AuthorizationAdapter` is easy! The following example shows
|
|
11
|
+
how to set up and tie your authorization adapter class to Active Admin:
|
|
12
|
+
|
|
13
|
+
# app/models/only_authors_authorization.rb
|
|
14
|
+
class OnlyAuthorsAuthorization < ActiveAdmin::AuthorizationAdapter
|
|
15
|
+
|
|
16
|
+
def authorized?(action, subject = nil)
|
|
17
|
+
case subject
|
|
18
|
+
when normalized(Post)
|
|
19
|
+
|
|
20
|
+
# Only let the author update and delete posts
|
|
21
|
+
if action == :update || action == :destroy
|
|
22
|
+
subject.author == user
|
|
23
|
+
|
|
24
|
+
# If it's not an update or destroy, anyone can view it
|
|
25
|
+
else
|
|
26
|
+
true
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
else
|
|
30
|
+
true
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
In order to hook up `OnlyAuthorsAuthorization` to Active Admin, go to your
|
|
37
|
+
application's `config/initializers/active_admin.rb` and add/modify the line:
|
|
38
|
+
|
|
39
|
+
config.authorization_adapter = "OnlyAuthorsAuthorization"
|
|
40
|
+
|
|
41
|
+
Authorization adapters can be configured per ActiveAdmin namespace as well, for example:
|
|
42
|
+
|
|
43
|
+
ActiveAdmin.setup do |config|
|
|
44
|
+
config.namespace :admin do |ns|
|
|
45
|
+
ns.authorization_adapter = "AdminAuthorization"
|
|
46
|
+
end
|
|
47
|
+
config.namespace :my do |ns|
|
|
48
|
+
ns.authorization_adapter = "DashboardAuthorization"
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
Now, whenever a controller action is performed, the `OnlyAuthorsAuthorization`'s
|
|
53
|
+
`#authorized?` method will be called.
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
## Getting Access to the Current User
|
|
57
|
+
|
|
58
|
+
From within your authorization adapter, you can call the `#user` method to
|
|
59
|
+
retrieve the current user.
|
|
60
|
+
|
|
61
|
+
class OnlyAdmins < ActiveAdmin::AuthorizationAdapter
|
|
62
|
+
|
|
63
|
+
def authorized?(action, subject = nil)
|
|
64
|
+
user.admin?
|
|
65
|
+
end
|
|
66
|
+
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
## Scoping Collections in Authorization Adapters
|
|
71
|
+
|
|
72
|
+
`ActiveAdmin::AuthorizationAdapter` also provides a hook method (`#scope_collection`)
|
|
73
|
+
for the adapter to scope the resource's collection. For example, you may want to
|
|
74
|
+
centralize the scoping:
|
|
75
|
+
|
|
76
|
+
class OnlyMyAccount < ActiveAdmin::AuthorizationAdapter
|
|
77
|
+
|
|
78
|
+
def authorized?(action, subject = nil)
|
|
79
|
+
subject.account == user.account
|
|
80
|
+
end
|
|
81
|
+
|
|
82
|
+
def scope_collection(collection, action = Auth::READ)
|
|
83
|
+
collection.where(:account_id => user.account_id)
|
|
84
|
+
end
|
|
85
|
+
|
|
86
|
+
end
|
|
87
|
+
|
|
88
|
+
All collections presented on Index Screens will be passed through this method
|
|
89
|
+
and will be scoped accordingly.
|
|
90
|
+
|
|
91
|
+
|
|
92
|
+
## Managing Access to Pages
|
|
93
|
+
|
|
94
|
+
Pages, just like resources, get authorized also. When authorization a page, the
|
|
95
|
+
subject will be an instance of `ActiveAdmin::Page`.
|
|
96
|
+
|
|
97
|
+
class OnlyDashboard < ActiveAdmin::AuthorizationAdapter
|
|
98
|
+
def authorized?(action, subject = nil)
|
|
99
|
+
case subject
|
|
100
|
+
when ActiveAdmin::Page
|
|
101
|
+
if action == :read && subject.name == "Dashboard"
|
|
102
|
+
true
|
|
103
|
+
else
|
|
104
|
+
false
|
|
105
|
+
end
|
|
106
|
+
else
|
|
107
|
+
false
|
|
108
|
+
end
|
|
109
|
+
end
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
## Action Types
|
|
114
|
+
|
|
115
|
+
By default Active Admin simplifies the controller actions into 4 actions:
|
|
116
|
+
|
|
117
|
+
* `:read` - This controls if the user can view the menu item as well as the
|
|
118
|
+
index and show screens.
|
|
119
|
+
* `:create` - This controls if the user can view the new screen and submit
|
|
120
|
+
the form to the create action.
|
|
121
|
+
* `:update` - This controls if the user can view the edit screen and submit
|
|
122
|
+
the form to the update action.
|
|
123
|
+
* `:destroy` - This controls if the user can delete a resource.
|
|
124
|
+
|
|
125
|
+
Each of these actions is available as a constant. Eg: `:read` is available as
|
|
126
|
+
`ActiveAdmin::Authorization::READ`.
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
## Checking for Authorization in Controllers and Views
|
|
130
|
+
|
|
131
|
+
Active Admin provides a helper method to check if the current user is
|
|
132
|
+
authorized to perform an action on a subject.
|
|
133
|
+
|
|
134
|
+
Simply use the `#authorized?(action, subject) method to check.
|
|
135
|
+
|
|
136
|
+
ActiveAdmin.register Post do
|
|
137
|
+
|
|
138
|
+
index do
|
|
139
|
+
column :title
|
|
140
|
+
column "" do |post|
|
|
141
|
+
if authorized?(:update, post)
|
|
142
|
+
link_to("Edit", admin_post_path(post))
|
|
143
|
+
end
|
|
144
|
+
end
|
|
145
|
+
|
|
146
|
+
end
|
|
147
|
+
|
|
148
|
+
end
|
|
149
|
+
|
|
150
|
+
If you are implementing a custom controller action, you can use the
|
|
151
|
+
`#authorize!` method to raise an `ActiveAdmin::AccessDenied` exception.
|
|
152
|
+
|
|
153
|
+
ActiveAdmin.register Post do
|
|
154
|
+
|
|
155
|
+
member_action :publish, :method => :post do
|
|
156
|
+
post = Post.find(params[:id])
|
|
157
|
+
|
|
158
|
+
authorize! :publish, post
|
|
159
|
+
post.publish!
|
|
160
|
+
|
|
161
|
+
flash[:notice] = "Post has been published"
|
|
162
|
+
redirect_to [:admin, post]
|
|
163
|
+
end
|
|
164
|
+
|
|
165
|
+
action_item :only => :show do
|
|
166
|
+
if !post.published? && authorized?(:publish, post)
|
|
167
|
+
link_to("Publish", publish_admin_post_path(post), :method => :post)
|
|
168
|
+
end
|
|
169
|
+
end
|
|
170
|
+
|
|
171
|
+
end
|
|
172
|
+
|
|
173
|
+
|
|
174
|
+
## Using the CanCan Adapter
|
|
175
|
+
|
|
176
|
+
Sub-classing `ActiveAdmin::AuthorizationAdapter` is fairly low level. Many times
|
|
177
|
+
it's nicer to have a simpler DSL for managing authorization. Active Admin
|
|
178
|
+
provides an adapter out of the box for [CanCan](https://github.com/ryanb/cancan).
|
|
179
|
+
|
|
180
|
+
To use the CanCan adapter, simply update the configuration in the Active Admin
|
|
181
|
+
initializer:
|
|
182
|
+
|
|
183
|
+
config.authorization_adapter = ActiveAdmin::CanCanAdapter
|
|
184
|
+
|
|
185
|
+
You can also specify a method to be called on unauthorized access. This is necessary
|
|
186
|
+
in order to prevent a redirect loop that can happen if a user tries to access a page
|
|
187
|
+
they don't have permissions for (see [#2081](https://github.com/gregbell/active_admin/issues/2081)).
|
|
188
|
+
```ruby
|
|
189
|
+
config.on_unauthorized_access = :access_denied
|
|
190
|
+
```
|
|
191
|
+
The method `access_denied` would be defined in `application_controller.rb`. Here is one
|
|
192
|
+
example that redirects the user from the page they don't have permission to
|
|
193
|
+
access to a resource they have permission to access (organizations in this case), and
|
|
194
|
+
also displays the error message in the browser:
|
|
195
|
+
|
|
196
|
+
```ruby
|
|
197
|
+
class ApplicationController < ActionController::Base
|
|
198
|
+
protect_from_forgery
|
|
199
|
+
|
|
200
|
+
def access_denied(exception)
|
|
201
|
+
redirect_to admin_organizations_path, :alert => exception.message
|
|
202
|
+
end
|
|
203
|
+
end
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
By default this will use the ability class named "Ability". This can also be
|
|
207
|
+
changed from the initializer:
|
|
208
|
+
|
|
209
|
+
config.cancan_ability_class = "MyCustomAbility"
|
|
210
|
+
|
|
211
|
+
Now you can simply use CanCan the way that you would expect and Active Admin
|
|
212
|
+
will use it for authorization:
|
|
213
|
+
|
|
214
|
+
# app/models/ability.rb
|
|
215
|
+
class Ability
|
|
216
|
+
include CanCan::Ability
|
|
217
|
+
|
|
218
|
+
def initialize(user)
|
|
219
|
+
can :manage, Post
|
|
220
|
+
can :read, User
|
|
221
|
+
can :manage, User, :id => user.id
|
|
222
|
+
can :read, ActiveAdmin::Page, :name => "Dashboard"
|
|
223
|
+
end
|
|
224
|
+
|
|
225
|
+
end
|
|
226
|
+
|
|
227
|
+
To view more details about the CanCan API, visit [https://github.com/ryanb/cancan](https://github.com/ryanb/cancan).
|
|
228
|
+
|
|
229
|
+
## Using the Pundit Adapter
|
|
230
|
+
|
|
231
|
+
Active Admin provides an adapter out of the box also for [Pundit](https://github.com/elabs/pundit).
|
|
232
|
+
|
|
233
|
+
To use the Pundit adapter, simply update the configuration in the Active Admin
|
|
234
|
+
initializer:
|
|
235
|
+
|
|
236
|
+
config.authorization_adapter = ActiveAdmin::PunditAdapter
|
|
237
|
+
|
|
238
|
+
You can simply use Pundit the way that you would expect and Active Admin will use it for authorization. Check Pundit's documentation to [set up Pundit in your application](https://github.com/elabs/pundit#installation). If you want to use batch actions just ensure that `destroy_all?` method is defined in your policy class. You can use this [template policy](spec/support/templates/policies/application_policy.rb) in your application instead of default one generated by Pundit's `rails g pundit:install` command.
|
|
239
|
+
|
|
@@ -0,0 +1,359 @@
|
|
|
1
|
+
# Working with Resources
|
|
2
|
+
|
|
3
|
+
Every Active Admin resource corresponds to a Rails model. So before creating a
|
|
4
|
+
resource you must first create a Rails model for it.
|
|
5
|
+
|
|
6
|
+
## Create a Resource
|
|
7
|
+
|
|
8
|
+
The basic command for creating a resource is `rails g active_admin:resource Post`.
|
|
9
|
+
The generator will produce an empty `app/admin/post.rb` file like so:
|
|
10
|
+
|
|
11
|
+
```ruby
|
|
12
|
+
ActiveAdmin.register Post do
|
|
13
|
+
# everything happens here :D
|
|
14
|
+
end
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
## Setting up Strong Parameters
|
|
18
|
+
|
|
19
|
+
Rails 4 replaces `attr_accessible` with [Strong Parameters](https://github.com/rails/strong_parameters),
|
|
20
|
+
which moves attribute whitelisting from the model to the controller.
|
|
21
|
+
|
|
22
|
+
Use the `permit_params` method to define which attributes may be changed:
|
|
23
|
+
|
|
24
|
+
```ruby
|
|
25
|
+
ActiveAdmin.register Post do
|
|
26
|
+
permit_params :title, :content, :publisher_id
|
|
27
|
+
end
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
For nested associations in your form, this is how you define their attributes:
|
|
31
|
+
|
|
32
|
+
```ruby
|
|
33
|
+
ActiveAdmin.register Post do
|
|
34
|
+
permit_params :title, :content, :publisher_id,
|
|
35
|
+
tags_attributes: [:id, :name, :description, :_destroy]
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
# Note that `accepts_nested_attributes_for` is still required:
|
|
39
|
+
class Post < ActiveRecord::Base
|
|
40
|
+
accepts_nested_attributes_for :tags, allow_destroy: true
|
|
41
|
+
end
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
If you want to dynamically choose which attributes can be set, pass a block:
|
|
45
|
+
|
|
46
|
+
```ruby
|
|
47
|
+
ActiveAdmin.register Post do
|
|
48
|
+
permit_params do
|
|
49
|
+
params = [:title, :content, :publisher_id]
|
|
50
|
+
params.push :author_id if current_user.admin?
|
|
51
|
+
params
|
|
52
|
+
end
|
|
53
|
+
end
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
## Disabling Actions on a Resource
|
|
57
|
+
|
|
58
|
+
All CRUD actions are enabled by default. These can be disabled for a given resource:
|
|
59
|
+
|
|
60
|
+
```ruby
|
|
61
|
+
ActiveAdmin.register Post do
|
|
62
|
+
actions :all, except: [:update, :destroy]
|
|
63
|
+
end
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
## Rename the Resource
|
|
67
|
+
|
|
68
|
+
By default, any references to the resource (menu, routes, buttons, etc) in the
|
|
69
|
+
interface will use the name of the class. You can rename the resource by using
|
|
70
|
+
the `:as` option.
|
|
71
|
+
|
|
72
|
+
```ruby
|
|
73
|
+
ActiveAdmin.register Post, as: "Article"
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
The resource will then be available at `/admin/articles`.
|
|
77
|
+
|
|
78
|
+
## Customize the Namespace
|
|
79
|
+
|
|
80
|
+
We use the `admin` namespace by default, but you can use anything:
|
|
81
|
+
|
|
82
|
+
```ruby
|
|
83
|
+
# Available at /today/posts
|
|
84
|
+
ActiveAdmin.register Post, namespace: :today
|
|
85
|
+
|
|
86
|
+
# Available at /posts
|
|
87
|
+
ActiveAdmin.register Post, namespace: false
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
## Customize the Menu
|
|
91
|
+
|
|
92
|
+
The resource will be displayed in the global navigation by default. To disable
|
|
93
|
+
the resource from being displayed in the global navigation:
|
|
94
|
+
|
|
95
|
+
```ruby
|
|
96
|
+
ActiveAdmin.register Post do
|
|
97
|
+
menu false
|
|
98
|
+
end
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
The menu method accepts a hash with the following options:
|
|
102
|
+
|
|
103
|
+
* `:label` - The string or proc label to display in the menu. If it's a proc, it
|
|
104
|
+
will be called each time the menu is rendered.
|
|
105
|
+
* `:parent` - The string id (or label) of the parent used for this menu
|
|
106
|
+
* `:if` - A block or a symbol of a method to call to decide if the menu item
|
|
107
|
+
should be displayed
|
|
108
|
+
* `:priority` - The integer value of the priority, which defaults to `10`
|
|
109
|
+
|
|
110
|
+
### Labels
|
|
111
|
+
|
|
112
|
+
To change the name of the label in the menu:
|
|
113
|
+
|
|
114
|
+
```ruby
|
|
115
|
+
ActiveAdmin.register Post do
|
|
116
|
+
menu label: "My Posts"
|
|
117
|
+
end
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
If you want something more dynamic, pass a proc instead:
|
|
121
|
+
|
|
122
|
+
```ruby
|
|
123
|
+
ActiveAdmin.register Post do
|
|
124
|
+
menu label: proc{ I18n.t "mypost" }
|
|
125
|
+
end
|
|
126
|
+
```
|
|
127
|
+
|
|
128
|
+
### Menu Priority
|
|
129
|
+
|
|
130
|
+
Menu items are sorted first by their numeric priority, then alphabetically. Since
|
|
131
|
+
every menu by default has a priority of `10`, the menu is normally alphabetical.
|
|
132
|
+
|
|
133
|
+
You can easily customize this:
|
|
134
|
+
|
|
135
|
+
```ruby
|
|
136
|
+
ActiveAdmin.register Post do
|
|
137
|
+
menu priority: 1 # so it's on the very left
|
|
138
|
+
end
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
### Conditionally Showing / Hiding Menu Items
|
|
142
|
+
|
|
143
|
+
Menu items can be shown or hidden at runtime using the `:if` option.
|
|
144
|
+
```ruby
|
|
145
|
+
ActiveAdmin.register Post do
|
|
146
|
+
menu if: proc{ current_user.can_edit_posts? }
|
|
147
|
+
end
|
|
148
|
+
```
|
|
149
|
+
|
|
150
|
+
The proc will be called in the context of the view, so you have access to all
|
|
151
|
+
your helpers and current user session information.
|
|
152
|
+
|
|
153
|
+
### Drop Down Menus
|
|
154
|
+
|
|
155
|
+
In many cases, a single level navigation will not be enough to manage a large
|
|
156
|
+
application. In that case, you can group your menu items under a parent menu item.
|
|
157
|
+
|
|
158
|
+
```ruby
|
|
159
|
+
ActiveAdmin.register Post do
|
|
160
|
+
menu parent: "Blog"
|
|
161
|
+
end
|
|
162
|
+
```
|
|
163
|
+
|
|
164
|
+
Note that the "Blog" parent menu item doesn't even have to exist yet; it can be
|
|
165
|
+
dynamically generated for you.
|
|
166
|
+
|
|
167
|
+
### Customizing Parent Menu Items
|
|
168
|
+
|
|
169
|
+
All of the options given to a standard menu item are also available to
|
|
170
|
+
parent menu items. In the case of complex parent menu items, you should
|
|
171
|
+
configure them in the Active Admin initializer.
|
|
172
|
+
|
|
173
|
+
```ruby
|
|
174
|
+
# config/initializers/active_admin.rb
|
|
175
|
+
config.namespace :admin do |admin|
|
|
176
|
+
admin.build_menu do |menu|
|
|
177
|
+
menu.add label: 'Blog', priority: 0
|
|
178
|
+
end
|
|
179
|
+
end
|
|
180
|
+
|
|
181
|
+
# app/admin/post.rb
|
|
182
|
+
ActiveAdmin.register Post do
|
|
183
|
+
menu parent: 'Blog'
|
|
184
|
+
end
|
|
185
|
+
```
|
|
186
|
+
|
|
187
|
+
### Dynamic Parent Menu Items
|
|
188
|
+
|
|
189
|
+
While the above works fine, what if you want a parent menu item with a dynamic
|
|
190
|
+
name? Well, you have to refer to it by its `:id`.
|
|
191
|
+
|
|
192
|
+
```ruby
|
|
193
|
+
# config/initializers/active_admin.rb
|
|
194
|
+
config.namespace :admin do |admin
|
|
195
|
+
admin.build_menu do |menu|
|
|
196
|
+
menu.add id: 'blog', label: proc{"Something dynamic"}, priority: 0
|
|
197
|
+
end
|
|
198
|
+
end
|
|
199
|
+
|
|
200
|
+
# app/admin/post.rb
|
|
201
|
+
ActiveAdmin.register Post do
|
|
202
|
+
menu parent: 'blog'
|
|
203
|
+
end
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
### Adding Custom Menu Items
|
|
207
|
+
|
|
208
|
+
Sometimes it's not enough to just customize the menu label. In this case, you
|
|
209
|
+
can customize the menu for the namespace within the Active Admin initializer.
|
|
210
|
+
|
|
211
|
+
```ruby
|
|
212
|
+
# config/initializers/active_admin.rb
|
|
213
|
+
config.namespace :admin do |admin|
|
|
214
|
+
admin.build_menu do |menu|
|
|
215
|
+
menu.add label: "The Application", url: "/", priority: 0
|
|
216
|
+
|
|
217
|
+
menu.add label: "Sites" do |sites|
|
|
218
|
+
sites.add label: "Google", url: "http://google.com", html_options: { target: :blank }
|
|
219
|
+
sites.add label: "Facebook", url: "http://facebook.com"
|
|
220
|
+
sites.add label: "Github", url: "http://github.com"
|
|
221
|
+
end
|
|
222
|
+
end
|
|
223
|
+
end
|
|
224
|
+
```
|
|
225
|
+
|
|
226
|
+
This will be registered on application start before your resources are loaded.
|
|
227
|
+
|
|
228
|
+
## Scoping the queries
|
|
229
|
+
|
|
230
|
+
If your administrators have different access levels, you may sometimes want to
|
|
231
|
+
scope what they have access to. Assuming your User model has the proper
|
|
232
|
+
has_many relationships, you can simply scope the listings and finders like so:
|
|
233
|
+
|
|
234
|
+
```ruby
|
|
235
|
+
ActiveAdmin.register Post do
|
|
236
|
+
scope_to :current_user # limits the accessible posts to `current_user.posts`
|
|
237
|
+
|
|
238
|
+
# Or if the association doesn't have the default name:
|
|
239
|
+
scope_to :current_user, association_method: :blog_posts
|
|
240
|
+
|
|
241
|
+
# Finally, you can pass a block to be called:
|
|
242
|
+
scope_to do
|
|
243
|
+
User.most_popular_posts
|
|
244
|
+
end
|
|
245
|
+
end
|
|
246
|
+
```
|
|
247
|
+
|
|
248
|
+
You can also conditionally apply the scope:
|
|
249
|
+
|
|
250
|
+
```ruby
|
|
251
|
+
ActiveAdmin.register Post do
|
|
252
|
+
scope_to :current_user, if: proc{ current_user.limited_access? }
|
|
253
|
+
scope_to :current_user, unless: proc{ current_user.admin? }
|
|
254
|
+
end
|
|
255
|
+
```
|
|
256
|
+
|
|
257
|
+
## Customizing resource retrieval
|
|
258
|
+
|
|
259
|
+
A common way to increase page performance is to elimate N+1 queries by eager loading associations:
|
|
260
|
+
|
|
261
|
+
```ruby
|
|
262
|
+
ActiveAdmin.register Post do
|
|
263
|
+
controller do
|
|
264
|
+
def scoped_collection
|
|
265
|
+
super.includes :author, :categories
|
|
266
|
+
end
|
|
267
|
+
end
|
|
268
|
+
end
|
|
269
|
+
```
|
|
270
|
+
|
|
271
|
+
If you need to completely replace the record retrieving code (e.g., you have a custom
|
|
272
|
+
`to_param` implementation in your models), override the `resource` method on the controller:
|
|
273
|
+
|
|
274
|
+
```ruby
|
|
275
|
+
ActiveAdmin.register Post do
|
|
276
|
+
controller do
|
|
277
|
+
def find_resource
|
|
278
|
+
Post.where(id: params[:id]).first!
|
|
279
|
+
end
|
|
280
|
+
end
|
|
281
|
+
end
|
|
282
|
+
```
|
|
283
|
+
|
|
284
|
+
Our controllers are built on [Inherited Resources](https://github.com/josevalim/inherited_resources),
|
|
285
|
+
so you can use [all of its features](https://github.com/josevalim/inherited_resources#overwriting-defaults).
|
|
286
|
+
|
|
287
|
+
## Belongs To
|
|
288
|
+
|
|
289
|
+
It's common to want to scope a series of resources to a relationship. For
|
|
290
|
+
example a Project may have many Milestones and Tickets. To nest the resource
|
|
291
|
+
within another, you can use the `belongs_to` method:
|
|
292
|
+
|
|
293
|
+
```ruby
|
|
294
|
+
ActiveAdmin.register Project
|
|
295
|
+
ActiveAdmin.register Ticket do
|
|
296
|
+
belongs_to :project
|
|
297
|
+
end
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
Projects will be available as usual and tickets will be availble by visiting
|
|
301
|
+
`/admin/projects/1/tickets` assuming that a Project with the id of 1 exists.
|
|
302
|
+
Active Admin does not add "Tickets" to the global navigation because the routes
|
|
303
|
+
can only be generated when there is a project id.
|
|
304
|
+
|
|
305
|
+
To create links to the resource, you can add them to a sidebar (one of the many
|
|
306
|
+
possibilities for how you may with to handle your user interface):
|
|
307
|
+
|
|
308
|
+
```ruby
|
|
309
|
+
ActiveAdmin.register Project do
|
|
310
|
+
|
|
311
|
+
sidebar "Project Details", only: [:show, :edit] do
|
|
312
|
+
ul do
|
|
313
|
+
li link_to "Tickets", admin_project_tickets_path(project)
|
|
314
|
+
li link_to "Milestones", admin_project_milestones_path(project)
|
|
315
|
+
end
|
|
316
|
+
end
|
|
317
|
+
end
|
|
318
|
+
|
|
319
|
+
ActiveAdmin.register Ticket do
|
|
320
|
+
belongs_to :project
|
|
321
|
+
end
|
|
322
|
+
|
|
323
|
+
ActiveAdmin.register Milestone do
|
|
324
|
+
belongs_to :project
|
|
325
|
+
end
|
|
326
|
+
```
|
|
327
|
+
|
|
328
|
+
In some cases (like Projects), there are many sub resources and you would
|
|
329
|
+
actually like the global navigation to switch when the user navigates "into" a
|
|
330
|
+
project. To accomplish this, Active Admin stores the `belongs_to` resources in a
|
|
331
|
+
seperate menu which you can use if you so wish. To use:
|
|
332
|
+
|
|
333
|
+
```ruby
|
|
334
|
+
ActiveAdmin.register Ticket do
|
|
335
|
+
belongs_to :project
|
|
336
|
+
navigation_menu :project
|
|
337
|
+
end
|
|
338
|
+
|
|
339
|
+
ActiveAdmin.register Milestone do
|
|
340
|
+
belongs_to :project
|
|
341
|
+
navigation_menu :project
|
|
342
|
+
end
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
Now, when you navigate to the tickets section, the global navigation will
|
|
346
|
+
only display "Tickets" and "Milestones". When you navigate back to a
|
|
347
|
+
non-belongs_to resource, it will switch back to the default menu.
|
|
348
|
+
|
|
349
|
+
You can also defer the menu lookup until runtime so that you can dynamically show
|
|
350
|
+
different menus, say perhaps based on user permissions. For example:
|
|
351
|
+
|
|
352
|
+
```ruby
|
|
353
|
+
ActiveAdmin.register Ticket do
|
|
354
|
+
belongs_to: :project
|
|
355
|
+
navigation_menu do
|
|
356
|
+
authorized?(:manage, SomeResource) ? :project : :restricted_menu
|
|
357
|
+
end
|
|
358
|
+
end
|
|
359
|
+
```
|