activeadmin 2.6.1 → 2.9.0

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.
Files changed (145) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +119 -8
  3. data/CONTRIBUTING.md +8 -24
  4. data/README.md +4 -4
  5. data/app/assets/javascripts/active_admin/base.js +14 -16
  6. data/app/assets/stylesheets/active_admin/_header.scss +37 -3
  7. data/app/assets/stylesheets/active_admin/components/_comments.scss +2 -2
  8. data/app/assets/stylesheets/active_admin/mixins/_variables.scss +3 -0
  9. data/app/javascript/active_admin/initializers/per-page.js +1 -1
  10. data/app/javascript/active_admin/lib/checkbox-toggler.js +3 -3
  11. data/app/javascript/active_admin/lib/dropdown-menu.js +1 -1
  12. data/app/javascript/active_admin/lib/modal-dialog.js +7 -7
  13. data/app/javascript/active_admin/lib/per-page.js +1 -1
  14. data/app/javascript/active_admin/lib/table-checkbox-toggler.js +1 -1
  15. data/app/views/active_admin/devise/mailer/reset_password_instructions.html.erb +1 -1
  16. data/app/views/active_admin/devise/mailer/unlock_instructions.html.erb +2 -2
  17. data/app/views/layouts/active_admin_logged_out.html.erb +15 -5
  18. data/config/locales/ar.yml +6 -6
  19. data/config/locales/es-MX.yml +2 -1
  20. data/config/locales/es.yml +2 -2
  21. data/config/locales/it.yml +18 -0
  22. data/config/locales/ja.yml +3 -3
  23. data/config/locales/vi.yml +5 -5
  24. data/docs/0-installation.md +26 -2
  25. data/docs/11-decorators.md +16 -5
  26. data/docs/2-resource-customization.md +10 -1
  27. data/docs/5-forms.md +6 -1
  28. data/docs/6-show-pages.md +12 -0
  29. data/docs/Gemfile +2 -2
  30. data/docs/Gemfile.lock +52 -41
  31. data/docs/_includes/top-menu.html +1 -1
  32. data/docs/documentation.md +1 -1
  33. data/docs/index.html +6 -6
  34. data/lib/active_admin.rb +59 -60
  35. data/lib/active_admin/application.rb +13 -13
  36. data/lib/active_admin/application_settings.rb +3 -3
  37. data/lib/active_admin/authorization_adapter.rb +3 -3
  38. data/lib/active_admin/base_controller.rb +4 -4
  39. data/lib/active_admin/base_controller/authorization.rb +13 -12
  40. data/lib/active_admin/batch_actions/controller.rb +3 -3
  41. data/lib/active_admin/batch_actions/resource_extension.rb +9 -8
  42. data/lib/active_admin/batch_actions/views/batch_action_form.rb +3 -3
  43. data/lib/active_admin/batch_actions/views/batch_action_selector.rb +6 -6
  44. data/lib/active_admin/batch_actions/views/selection_cells.rb +3 -3
  45. data/lib/active_admin/cancan_adapter.rb +1 -1
  46. data/lib/active_admin/collection_decorator.rb +31 -0
  47. data/lib/active_admin/csv_builder.rb +4 -4
  48. data/lib/active_admin/dependency.rb +11 -11
  49. data/lib/active_admin/devise.rb +5 -5
  50. data/lib/active_admin/dsl.rb +1 -1
  51. data/lib/active_admin/dynamic_settings_node.rb +2 -2
  52. data/lib/active_admin/engine.rb +10 -8
  53. data/lib/active_admin/error.rb +0 -2
  54. data/lib/active_admin/filters.rb +7 -7
  55. data/lib/active_admin/filters/active.rb +1 -1
  56. data/lib/active_admin/filters/active_filter.rb +5 -6
  57. data/lib/active_admin/filters/active_sidebar.rb +5 -5
  58. data/lib/active_admin/filters/forms.rb +6 -6
  59. data/lib/active_admin/filters/formtastic_addons.rb +1 -6
  60. data/lib/active_admin/filters/resource_extension.rb +1 -1
  61. data/lib/active_admin/form_builder.rb +24 -20
  62. data/lib/active_admin/generators/boilerplate.rb +1 -1
  63. data/lib/active_admin/helpers/optional_display.rb +2 -2
  64. data/lib/active_admin/inputs/datepicker_input.rb +1 -1
  65. data/lib/active_admin/inputs/filters/base.rb +1 -1
  66. data/lib/active_admin/inputs/filters/base/search_method_select.rb +4 -4
  67. data/lib/active_admin/inputs/filters/boolean_input.rb +1 -1
  68. data/lib/active_admin/inputs/filters/check_boxes_input.rb +1 -1
  69. data/lib/active_admin/inputs/filters/select_input.rb +2 -2
  70. data/lib/active_admin/localizers.rb +1 -1
  71. data/lib/active_admin/localizers/resource_localizer.rb +3 -3
  72. data/lib/active_admin/menu.rb +6 -3
  73. data/lib/active_admin/menu_item.rb +7 -7
  74. data/lib/active_admin/namespace.rb +12 -12
  75. data/lib/active_admin/namespace_settings.rb +8 -5
  76. data/lib/active_admin/order_clause.rb +1 -1
  77. data/lib/active_admin/orm/active_record.rb +1 -1
  78. data/lib/active_admin/orm/active_record/comments.rb +19 -19
  79. data/lib/active_admin/orm/active_record/comments/comment.rb +3 -3
  80. data/lib/active_admin/orm/active_record/comments/views.rb +2 -2
  81. data/lib/active_admin/orm/active_record/comments/views/active_admin_comments.rb +19 -19
  82. data/lib/active_admin/page.rb +1 -1
  83. data/lib/active_admin/pundit_adapter.rb +5 -5
  84. data/lib/active_admin/resource.rb +17 -17
  85. data/lib/active_admin/resource/action_items.rb +5 -5
  86. data/lib/active_admin/resource/attributes.rb +1 -1
  87. data/lib/active_admin/resource/belongs_to.rb +2 -2
  88. data/lib/active_admin/resource/controllers.rb +1 -1
  89. data/lib/active_admin/resource/menu.rb +4 -4
  90. data/lib/active_admin/resource/naming.rb +4 -4
  91. data/lib/active_admin/resource/routes.rb +5 -7
  92. data/lib/active_admin/resource/scope_to.rb +7 -7
  93. data/lib/active_admin/resource/sidebars.rb +1 -1
  94. data/lib/active_admin/resource_controller.rb +12 -11
  95. data/lib/active_admin/resource_controller/data_access.rb +1 -1
  96. data/lib/active_admin/resource_controller/decorators.rb +6 -28
  97. data/lib/active_admin/resource_controller/streaming.rb +7 -6
  98. data/lib/active_admin/resource_dsl.rb +5 -5
  99. data/lib/active_admin/scope.rb +6 -6
  100. data/lib/active_admin/version.rb +1 -1
  101. data/lib/active_admin/view_factory.rb +17 -17
  102. data/lib/active_admin/view_helpers.rb +1 -1
  103. data/lib/active_admin/view_helpers/breadcrumb_helper.rb +3 -3
  104. data/lib/active_admin/view_helpers/display_helper.rb +5 -5
  105. data/lib/active_admin/view_helpers/download_format_links_helper.rb +1 -1
  106. data/lib/active_admin/view_helpers/fields_for.rb +2 -2
  107. data/lib/active_admin/views.rb +1 -1
  108. data/lib/active_admin/views/components/active_admin_form.rb +5 -5
  109. data/lib/active_admin/views/components/attributes_table.rb +5 -5
  110. data/lib/active_admin/views/components/blank_slate.rb +1 -1
  111. data/lib/active_admin/views/components/dropdown_menu.rb +8 -8
  112. data/lib/active_admin/views/components/index_list.rb +3 -3
  113. data/lib/active_admin/views/components/menu.rb +1 -1
  114. data/lib/active_admin/views/components/menu_item.rb +4 -4
  115. data/lib/active_admin/views/components/paginated_collection.rb +18 -18
  116. data/lib/active_admin/views/components/panel.rb +1 -1
  117. data/lib/active_admin/views/components/scopes.rb +7 -5
  118. data/lib/active_admin/views/components/site_title.rb +1 -1
  119. data/lib/active_admin/views/components/status_tag.rb +11 -11
  120. data/lib/active_admin/views/components/table_for.rb +17 -17
  121. data/lib/active_admin/views/components/tabs.rb +3 -3
  122. data/lib/active_admin/views/footer.rb +2 -1
  123. data/lib/active_admin/views/header.rb +2 -2
  124. data/lib/active_admin/views/index_as_blog.rb +1 -1
  125. data/lib/active_admin/views/index_as_grid.rb +1 -1
  126. data/lib/active_admin/views/index_as_table.rb +16 -16
  127. data/lib/active_admin/views/pages/base.rb +10 -8
  128. data/lib/active_admin/views/pages/index.rb +14 -13
  129. data/lib/active_admin/views/tabbed_navigation.rb +2 -2
  130. data/lib/active_admin/views/title_bar.rb +1 -1
  131. data/lib/activeadmin.rb +1 -1
  132. data/lib/generators/active_admin/assets/assets_generator.rb +2 -2
  133. data/lib/generators/active_admin/assets/templates/active_admin.scss +2 -2
  134. data/lib/generators/active_admin/devise/devise_generator.rb +5 -5
  135. data/lib/generators/active_admin/install/install_generator.rb +14 -8
  136. data/lib/generators/active_admin/install/templates/active_admin.rb.erb +9 -2
  137. data/lib/generators/active_admin/page/page_generator.rb +1 -1
  138. data/lib/generators/active_admin/resource/resource_generator.rb +3 -3
  139. data/lib/generators/active_admin/webpacker/plugins/jquery.js +7 -0
  140. data/lib/generators/active_admin/webpacker/templates/active_admin.js +5 -0
  141. data/lib/generators/active_admin/webpacker/templates/active_admin.scss +17 -0
  142. data/lib/generators/active_admin/webpacker/templates/print.scss +2 -0
  143. data/lib/generators/active_admin/webpacker/webpacker_generator.rb +26 -0
  144. data/lib/ransack_ext.rb +8 -8
  145. metadata +22 -44
@@ -1,6 +1,6 @@
1
- require 'active_admin/router'
2
- require 'active_admin/application_settings'
3
- require 'active_admin/namespace_settings'
1
+ require "active_admin/router"
2
+ require "active_admin/application_settings"
3
+ require "active_admin/namespace_settings"
4
4
 
5
5
  module ActiveAdmin
6
6
  class Application
@@ -45,8 +45,8 @@ module ActiveAdmin
45
45
  include AssetRegistration
46
46
 
47
47
  # Event that gets triggered on load of Active Admin
48
- BeforeLoadEvent = 'active_admin.application.before_load'.freeze
49
- AfterLoadEvent = 'active_admin.application.after_load'.freeze
48
+ BeforeLoadEvent = "active_admin.application.before_load".freeze
49
+ AfterLoadEvent = "active_admin.application.after_load".freeze
50
50
 
51
51
  # Runs before the app's AA initializer
52
52
  def setup!
@@ -112,9 +112,9 @@ module ActiveAdmin
112
112
  def load!
113
113
  unless loaded?
114
114
  ActiveSupport::Notifications.publish BeforeLoadEvent, self # before_load hook
115
- files.each { |file| load file } # load files
116
- namespace(default_namespace) # init AA resources
117
- ActiveSupport::Notifications.publish AfterLoadEvent, self # after_load hook
115
+ files.each { |file| load file } # load files
116
+ namespace(default_namespace) # init AA resources
117
+ ActiveSupport::Notifications.publish AfterLoadEvent, self # after_load hook
118
118
  @@loaded = true
119
119
  end
120
120
  end
@@ -125,7 +125,7 @@ module ActiveAdmin
125
125
 
126
126
  # Returns ALL the files to be loaded
127
127
  def files
128
- load_paths.flatten.compact.uniq.flat_map { |path| Dir["#{path}/**/*.rb"] }
128
+ load_paths.flatten.compact.uniq.flat_map { |path| Dir["#{path}/**/*.rb"] }.sort
129
129
  end
130
130
 
131
131
  # Creates all the necessary routes for the ActiveAdmin configurations
@@ -164,9 +164,9 @@ module ActiveAdmin
164
164
  private
165
165
 
166
166
  def register_default_assets
167
- register_stylesheet 'active_admin.css', media: 'screen'
168
- register_stylesheet 'active_admin/print.css', media: 'print'
169
- register_javascript 'active_admin.js'
167
+ register_stylesheet "active_admin.css", media: "screen"
168
+ register_stylesheet "active_admin/print.css", media: "print"
169
+ register_javascript "active_admin.js"
170
170
  end
171
171
 
172
172
  # Since app/admin is alphabetically before app/models, we have to remove it
@@ -176,7 +176,7 @@ module ActiveAdmin
176
176
  # files from being loaded twice in production.
177
177
  def remove_active_admin_load_paths_from_rails_autoload_and_eager_load
178
178
  ActiveSupport::Dependencies.autoload_paths -= load_paths
179
- Rails.application.config.eager_load_paths -= load_paths
179
+ Rails.application.config.eager_load_paths -= load_paths
180
180
  end
181
181
 
182
182
  # Hook into the Rails code reloading mechanism so that things are reloaded
@@ -1,4 +1,4 @@
1
- require 'active_admin/settings_node'
1
+ require "active_admin/settings_node"
2
2
 
3
3
  module ActiveAdmin
4
4
  class ApplicationSettings < SettingsNode
@@ -15,7 +15,7 @@ module ActiveAdmin
15
15
  # Load paths for admin configurations. Add folders to this load path
16
16
  # to load up other resources for administration. External gems can
17
17
  # include their paths in this load path to provide active_admin UIs
18
- register :load_paths, [File.expand_path('app/admin', Rails.root)]
18
+ register :load_paths, [File.expand_path("app/admin", Rails.root)]
19
19
 
20
20
  # Set default localize format for Date/Time values
21
21
  register :localize_format, :long
@@ -34,7 +34,7 @@ module ActiveAdmin
34
34
  :to_s ]
35
35
 
36
36
  # To make debugging easier, by default don't stream in development
37
- register :disable_streaming_in, ['development']
37
+ register :disable_streaming_in, ["development"]
38
38
 
39
39
  # Remove sensitive attributes from being displayed, made editable, or exported by default
40
40
  register :filter_attributes, [:encrypted_password, :password, :password_confirmation]
@@ -2,9 +2,9 @@ module ActiveAdmin
2
2
 
3
3
  # Default Authorization permissions for Active Admin
4
4
  module Authorization
5
- READ = :read
6
- CREATE = :create
7
- UPDATE = :update
5
+ READ = :read
6
+ CREATE = :create
7
+ UPDATE = :update
8
8
  DESTROY = :destroy
9
9
  end
10
10
 
@@ -1,5 +1,5 @@
1
- require 'active_admin/base_controller/authorization'
2
- require 'active_admin/base_controller/menu'
1
+ require "active_admin/base_controller/authorization"
2
+ require "active_admin/base_controller/menu"
3
3
 
4
4
  module ActiveAdmin
5
5
  # BaseController for ActiveAdmin.
@@ -69,11 +69,11 @@ module ActiveAdmin
69
69
  # 2. If we're rendering a custom action, we'll use the active_admin layout so
70
70
  # that users can render any template inside Active Admin.
71
71
  def determine_active_admin_layout
72
- ACTIVE_ADMIN_ACTIONS.include?(params[:action].to_sym) ? false : 'active_admin'
72
+ ACTIVE_ADMIN_ACTIONS.include?(params[:action].to_sym) ? false : "active_admin"
73
73
  end
74
74
 
75
75
  def active_admin_root
76
- controller, action = active_admin_namespace.root_to.split '#'
76
+ controller, action = active_admin_namespace.root_to.split "#"
77
77
  { controller: controller, action: action }
78
78
  end
79
79
 
@@ -4,12 +4,12 @@ module ActiveAdmin
4
4
  extend ActiveSupport::Concern
5
5
 
6
6
  ACTIONS_DICTIONARY = {
7
- index: ActiveAdmin::Authorization::READ,
8
- show: ActiveAdmin::Authorization::READ,
9
- new: ActiveAdmin::Authorization::CREATE,
10
- create: ActiveAdmin::Authorization::CREATE,
11
- edit: ActiveAdmin::Authorization::UPDATE,
12
- update: ActiveAdmin::Authorization::UPDATE,
7
+ index: ActiveAdmin::Authorization::READ,
8
+ show: ActiveAdmin::Authorization::READ,
9
+ new: ActiveAdmin::Authorization::CREATE,
10
+ create: ActiveAdmin::Authorization::CREATE,
11
+ edit: ActiveAdmin::Authorization::UPDATE,
12
+ update: ActiveAdmin::Authorization::UPDATE,
13
13
  destroy: ActiveAdmin::Authorization::DESTROY
14
14
  }
15
15
 
@@ -52,9 +52,10 @@ module ActiveAdmin
52
52
  # an ActiveAdmin::AccessDenied.
53
53
  def authorize!(action, subject = nil)
54
54
  unless authorized? action, subject
55
- raise ActiveAdmin::AccessDenied.new(current_active_admin_user,
56
- action,
57
- subject)
55
+ raise ActiveAdmin::AccessDenied.new(
56
+ current_active_admin_user,
57
+ action,
58
+ subject)
58
59
  end
59
60
  end
60
61
 
@@ -112,9 +113,9 @@ module ActiveAdmin
112
113
  redirect_backwards_or_to_root
113
114
  end
114
115
 
115
- format.csv { render body: error, status: :unauthorized }
116
- format.json { render json: { error: error }, status: :unauthorized }
117
- format.xml { render xml: "<error>#{error}</error>", status: :unauthorized }
116
+ format.csv { render body: error, status: :unauthorized }
117
+ format.json { render json: { error: error }, status: :unauthorized }
118
+ format.xml { render xml: "<error>#{error}</error>", status: :unauthorized }
118
119
  end
119
120
  end
120
121
 
@@ -5,10 +5,10 @@ module ActiveAdmin
5
5
  # Controller action that is called when submitting the batch action form
6
6
  def batch_action
7
7
  if action_present?
8
- selection = params[:collection_selection] || []
9
- inputs = JSON.parse params[:batch_action_inputs] || '{}'
8
+ selection = params[:collection_selection] || []
9
+ inputs = JSON.parse params[:batch_action_inputs] || "{}"
10
10
  valid_keys = MethodOrProcHelper.render_in_context(self, current_batch_action.inputs).try(:keys)
11
- inputs = inputs.with_indifferent_access.slice *valid_keys
11
+ inputs = inputs.with_indifferent_access.slice *valid_keys
12
12
  instance_exec selection, inputs, &current_batch_action.block
13
13
  else
14
14
  raise "Couldn't find batch action \"#{params[:batch_action]}\""
@@ -57,21 +57,22 @@ module ActiveAdmin
57
57
  def add_default_batch_action
58
58
  destroy_options = {
59
59
  priority: 100,
60
- confirm: proc { I18n.t('active_admin.batch_actions.delete_confirmation', plural_model: active_admin_config.plural_resource_label.downcase) },
61
- if: proc { controller.action_methods.include?('destroy') && authorized?(ActiveAdmin::Auth::DESTROY, active_admin_config.resource_class) }
60
+ confirm: proc { I18n.t("active_admin.batch_actions.delete_confirmation", plural_model: active_admin_config.plural_resource_label.downcase) },
61
+ if: proc { controller.action_methods.include?("destroy") && authorized?(ActiveAdmin::Auth::DESTROY, active_admin_config.resource_class) }
62
62
  }
63
63
 
64
- add_batch_action :destroy, proc { I18n.t('active_admin.delete') }, destroy_options do |selected_ids|
64
+ add_batch_action :destroy, proc { I18n.t("active_admin.delete") }, destroy_options do |selected_ids|
65
65
  batch_action_collection.find(selected_ids).each do |record|
66
66
  authorize! ActiveAdmin::Auth::DESTROY, record
67
67
  destroy_resource(record)
68
68
  end
69
69
 
70
70
  redirect_to active_admin_config.route_collection_path(params),
71
- notice: I18n.t("active_admin.batch_actions.succesfully_destroyed",
72
- count: selected_ids.count,
73
- model: active_admin_config.resource_label.downcase,
74
- plural_model: active_admin_config.plural_resource_label(count: selected_ids.count).downcase)
71
+ notice: I18n.t(
72
+ "active_admin.batch_actions.succesfully_destroyed",
73
+ count: selected_ids.count,
74
+ model: active_admin_config.resource_label.downcase,
75
+ plural_model: active_admin_config.plural_resource_label(count: selected_ids.count).downcase)
75
76
  end
76
77
  end
77
78
 
@@ -84,7 +85,7 @@ module ActiveAdmin
84
85
 
85
86
  attr_reader :block, :title, :sym
86
87
 
87
- DEFAULT_CONFIRM_MESSAGE = proc { I18n.t 'active_admin.batch_actions.default_confirmation' }
88
+ DEFAULT_CONFIRM_MESSAGE = proc { I18n.t "active_admin.batch_actions.default_confirmation" }
88
89
 
89
90
  # Create a Batch Action
90
91
  #
@@ -1,4 +1,4 @@
1
- require 'active_admin/component'
1
+ require "active_admin/component"
2
2
 
3
3
  module ActiveAdmin
4
4
  module BatchActions
@@ -16,7 +16,7 @@ module ActiveAdmin
16
16
  # batch_action => name of the specific action called
17
17
  # batch_action_inputs => a JSON string of any requested confirmation values
18
18
  text_node form_tag active_admin_config.route_batch_action_path(params, url_options), id: options[:id]
19
- input name: :batch_action, id: :batch_action, type: :hidden
19
+ input name: :batch_action, id: :batch_action, type: :hidden
20
20
  input name: :batch_action_inputs, id: :batch_action_inputs, type: :hidden
21
21
 
22
22
  super(options)
@@ -30,7 +30,7 @@ module ActiveAdmin
30
30
  private
31
31
 
32
32
  def closing_form_tag
33
- '</form>'.html_safe
33
+ "</form>".html_safe
34
34
  end
35
35
 
36
36
  end
@@ -1,4 +1,4 @@
1
- require 'active_admin/component'
1
+ require "active_admin/component"
2
2
 
3
3
  module ActiveAdmin
4
4
  module BatchActions
@@ -31,17 +31,17 @@ module ActiveAdmin
31
31
  confirmation_text = render_or_call_method_or_proc_on(self, batch_action.confirm)
32
32
 
33
33
  options = {
34
- :class => "batch_action",
35
- "data-action" => batch_action.sym,
36
- "data-confirm" => confirmation_text,
37
- "data-inputs" => render_in_context(self, batch_action.inputs).to_json
34
+ class: "batch_action",
35
+ "data-action": batch_action.sym,
36
+ "data-confirm": confirmation_text,
37
+ "data-inputs": render_in_context(self, batch_action.inputs).to_json
38
38
  }
39
39
 
40
40
  default_title = render_or_call_method_or_proc_on(self, batch_action.title)
41
41
  title = I18n.t("active_admin.batch_actions.labels.#{batch_action.sym}", default: default_title)
42
42
  label = I18n.t("active_admin.batch_actions.action_label", title: title)
43
43
 
44
- item label, "#", options
44
+ item label, "#", **options
45
45
  end
46
46
  end
47
47
  end
@@ -1,4 +1,4 @@
1
- require 'active_admin/component'
1
+ require "active_admin/component"
2
2
 
3
3
  module ActiveAdmin
4
4
  module BatchActions
@@ -7,7 +7,7 @@ module ActiveAdmin
7
7
  class ResourceSelectionToggleCell < ActiveAdmin::Component
8
8
  builder_method :resource_selection_toggle_cell
9
9
 
10
- def build(label_text = '')
10
+ def build(label_text = "")
11
11
  label do
12
12
  input type: "checkbox", id: "collection_selection_toggle_all", name: "collection_selection_toggle_all", class: "toggle_all"
13
13
  text_node label_text if label_text.present?
@@ -30,7 +30,7 @@ module ActiveAdmin
30
30
 
31
31
  def build
32
32
  super(id: "collection_selection_toggle_panel")
33
- resource_selection_toggle_cell(I18n.t('active_admin.batch_actions.selection_toggle_explanation', default: "(Toggle Selection)"))
33
+ resource_selection_toggle_cell(I18n.t("active_admin.batch_actions.selection_toggle_explanation", default: "(Toggle Selection)"))
34
34
  end
35
35
  end
36
36
 
@@ -2,7 +2,7 @@ unless ActiveAdmin::Dependency.cancan? || ActiveAdmin::Dependency.cancancan?
2
2
  ActiveAdmin::Dependency.cancan!
3
3
  end
4
4
 
5
- require 'cancan'
5
+ require "cancan"
6
6
 
7
7
  # Add a setting to the application to configure the ability
8
8
  ActiveAdmin::Application.inheritable_setting :cancan_ability_class, "Ability"
@@ -0,0 +1,31 @@
1
+ module ActiveAdmin
2
+ # This class decorates a collection of objects delegating
3
+ # mehods to behave like an Array. It's used to decouple ActiveAdmin
4
+ # from Draper and thus being able to use PORO decorators as well.
5
+ #
6
+ # It's implementation is heavily based on the Draper::CollectionDecorator
7
+ # https://github.com/drapergem/draper/blob/aaa06bd2f1e219838b241a5534e7ca513edd1fe2/lib/draper/collection_decorator.rb
8
+ class CollectionDecorator
9
+ # @return the collection being decorated.
10
+ attr_reader :object
11
+
12
+ # @return [Class] the decorator class used to decorate each item, as set by {#initialize}.
13
+ attr_reader :decorator_class
14
+
15
+ array_methods = Array.instance_methods - Object.instance_methods
16
+ delegate :==, :as_json, *array_methods, to: :decorated_collection
17
+
18
+ def initialize(object, with:)
19
+ @object = object
20
+ @decorator_class = with
21
+ end
22
+
23
+ class << self
24
+ alias_method :decorate, :new
25
+ end
26
+
27
+ def decorated_collection
28
+ @decorated_collection ||= object.map { |item| decorator_class.new(item) }
29
+ end
30
+ end
31
+ end
@@ -42,11 +42,11 @@ module ActiveAdmin
42
42
  end
43
43
 
44
44
  def build(controller, csv)
45
- @collection = controller.send :find_collection, except: :pagination
46
- columns = exec_columns controller.view_context
47
- bom = options.delete :byte_order_mark
45
+ @collection = controller.send :find_collection, except: :pagination
46
+ columns = exec_columns controller.view_context
47
+ bom = options.delete :byte_order_mark
48
48
  column_names = options.delete(:column_names) { true }
49
- csv_options = options.except :encoding_options, :humanize_name
49
+ csv_options = options.except :encoding_options, :humanize_name
50
50
 
51
51
  csv << bom if bom
52
52
 
@@ -1,27 +1,27 @@
1
1
  module ActiveAdmin
2
2
  module Dependency
3
3
  module Requirements
4
- DEVISE = '>= 4.0', '< 5'
4
+ DEVISE = ">= 4.0", "< 5"
5
5
  end
6
6
 
7
7
  # Provides a clean interface to check for gem dependencies at runtime.
8
8
  #
9
- # ActiveAdmin::Dependency.draper
10
- # => #<ActiveAdmin::Dependency::Matcher for draper 1.2.1>
9
+ # ActiveAdmin::Dependency.rails
10
+ # => #<ActiveAdmin::Dependency::Matcher for rails 6.0.3.2>
11
11
  #
12
- # ActiveAdmin::Dependency.draper?
12
+ # ActiveAdmin::Dependency.rails?
13
13
  # => true
14
14
  #
15
- # ActiveAdmin::Dependency.draper? '>= 1.5.0'
15
+ # ActiveAdmin::Dependency.rails? '>= 6.1'
16
16
  # => false
17
17
  #
18
- # ActiveAdmin::Dependency.draper? '= 1.2.1'
18
+ # ActiveAdmin::Dependency.rails? '= 6.0.3.2'
19
19
  # => true
20
20
  #
21
- # ActiveAdmin::Dependency.draper? '~> 1.2.0'
21
+ # ActiveAdmin::Dependency.rails? '~> 6.0.3'
22
22
  # => true
23
23
  #
24
- # ActiveAdmin::Dependency.rails? '>= 4.2.7', '<= 5.0.2'
24
+ # ActiveAdmin::Dependency.rails? '>= 6.0.3', '<= 6.1.0'
25
25
  # => true
26
26
  #
27
27
  # ActiveAdmin::Dependency.rails! '5'
@@ -42,9 +42,9 @@ module ActiveAdmin
42
42
  # => false
43
43
  #
44
44
  def self.method_missing(name, *args)
45
- if name[-1] == '?'
45
+ if name[-1] == "?"
46
46
  Matcher.new(name[0..-2]).match? args
47
- elsif name[-1] == '!'
47
+ elsif name[-1] == "!"
48
48
  Matcher.new(name[0..-2]).match! args
49
49
  else
50
50
  Matcher.new name.to_s
@@ -91,7 +91,7 @@ module ActiveAdmin
91
91
  end
92
92
 
93
93
  def inspect
94
- info = spec ? "#{spec.name} #{spec.version}" : '(missing)'
94
+ info = spec ? "#{spec.name} #{spec.version}" : "(missing)"
95
95
  "<ActiveAdmin::Dependency::Matcher for #{info}>"
96
96
  end
97
97
  end
@@ -1,6 +1,6 @@
1
1
  ActiveAdmin::Dependency.devise! ActiveAdmin::Dependency::Requirements::DEVISE
2
2
 
3
- require 'devise'
3
+ require "devise"
4
4
 
5
5
  module ActiveAdmin
6
6
  module Devise
@@ -9,7 +9,7 @@ module ActiveAdmin
9
9
  {
10
10
  path: ActiveAdmin.application.default_namespace || "/",
11
11
  controllers: ActiveAdmin::Devise.controllers,
12
- path_names: { sign_in: 'login', sign_out: "logout" },
12
+ path_names: { sign_in: "login", sign_out: "logout" },
13
13
  sign_out_via: [*::Devise.sign_out_via, ActiveAdmin.application.logout_link_method].uniq
14
14
  }
15
15
  end
@@ -27,14 +27,14 @@ module ActiveAdmin
27
27
  module Controller
28
28
  extend ::ActiveSupport::Concern
29
29
  included do
30
- layout 'active_admin_logged_out'
30
+ layout "active_admin_logged_out"
31
31
  helper ::ActiveAdmin::ViewHelpers
32
32
  end
33
33
 
34
34
  # Redirect to the default namespace on logout
35
35
  def root_path
36
36
  namespace = ActiveAdmin.application.default_namespace.presence
37
- root_path_method = [namespace, :root_path].compact.join('_')
37
+ root_path_method = [namespace, :root_path].compact.join("_")
38
38
 
39
39
  path = if Helpers::Routes.respond_to? root_path_method
40
40
  Helpers::Routes.send root_path_method
@@ -45,7 +45,7 @@ module ActiveAdmin
45
45
 
46
46
  # NOTE: `relative_url_root` is deprecated by Rails.
47
47
  # Remove prefix here if it is removed completely.
48
- prefix = Rails.configuration.action_controller[:relative_url_root] || ''
48
+ prefix = Rails.configuration.action_controller[:relative_url_root] || ""
49
49
  prefix + path
50
50
  end
51
51
  end