manage 1.3.22 → 1.3.24

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 (81) hide show
  1. checksums.yaml +4 -4
  2. data/MIT-LICENSE +20 -20
  3. data/README.rdoc +96 -96
  4. data/Rakefile +31 -31
  5. data/app/assets/javascripts/manage/collection_actions.js.coffee +30 -30
  6. data/app/assets/javascripts/manage/handlers.js.coffee +46 -46
  7. data/app/assets/javascripts/manage/table_checkboxes.js.coffee +11 -11
  8. data/app/controllers/manage/application_controller.rb +13 -13
  9. data/app/controllers/manage/dashboards_controller.rb +4 -4
  10. data/app/controllers/manage/resource_controller.rb +10 -1
  11. data/app/controllers/manage/responder.rb +11 -11
  12. data/app/controllers/manage/sessions_controller.rb +11 -11
  13. data/app/helpers/manage/application_helper.rb +42 -42
  14. data/app/helpers/manage/form_helper.rb +21 -21
  15. data/app/helpers/manage/resource_helper.rb +77 -77
  16. data/app/models/admin_user.rb +4 -4
  17. data/app/views/layouts/manage/_main_menu.html.slim +52 -52
  18. data/app/views/layouts/manage/application.html.slim +39 -39
  19. data/app/views/layouts/manage/sign_in.html.slim +30 -30
  20. data/app/views/manage/resource/_form.html.slim +4 -4
  21. data/app/views/manage/resource/index/_collection_actions.html.slim +2 -2
  22. data/app/views/manage/resource/index/_count.html.slim +6 -6
  23. data/app/views/manage/resource/index/_table.html.slim +25 -25
  24. data/app/views/manage/resource/index.html.slim +18 -18
  25. data/app/views/manage/resource/show.html.slim +10 -10
  26. data/app/views/manage/sessions/new.html.slim +10 -10
  27. data/config/initializers/devise.rb +247 -247
  28. data/config/initializers/session_store.rb +3 -3
  29. data/config/initializers/simple_form.rb +145 -145
  30. data/config/initializers/simple_form_foundation.rb +26 -26
  31. data/config/locales/devise.en.yml +59 -59
  32. data/config/locales/en.yml +20 -20
  33. data/config/routes.rb +10 -10
  34. data/db/migrate/20131204142720_create_admin_users.rb +24 -24
  35. data/lib/manage/engine.rb +21 -21
  36. data/lib/manage/fields/reader.rb +57 -57
  37. data/lib/manage/fields.rb +6 -6
  38. data/lib/manage/version.rb +1 -1
  39. data/lib/manage.rb +5 -5
  40. data/lib/tasks/manage_tasks.rake +15 -15
  41. data/lib/templates/erb/scaffold/_form.html.erb +13 -13
  42. data/spec/controllers/manage/resource_controller_spec.rb +29 -29
  43. data/spec/dummy/README.rdoc +28 -28
  44. data/spec/dummy/Rakefile +6 -6
  45. data/spec/dummy/app/assets/javascripts/application.js +13 -13
  46. data/spec/dummy/app/assets/stylesheets/application.css +13 -13
  47. data/spec/dummy/app/controllers/application_controller.rb +5 -5
  48. data/spec/dummy/app/controllers/manage/posts_controller.rb +4 -4
  49. data/spec/dummy/app/helpers/application_helper.rb +2 -2
  50. data/spec/dummy/app/models/post.rb +3 -3
  51. data/spec/dummy/app/models/user.rb +5 -5
  52. data/spec/dummy/app/views/layouts/application.html.erb +14 -14
  53. data/spec/dummy/bin/bundle +3 -3
  54. data/spec/dummy/bin/rails +4 -4
  55. data/spec/dummy/bin/rake +4 -4
  56. data/spec/dummy/config/application.rb +24 -24
  57. data/spec/dummy/config/boot.rb +5 -5
  58. data/spec/dummy/config/database.yml +25 -25
  59. data/spec/dummy/config/environment.rb +5 -5
  60. data/spec/dummy/config/environments/development.rb +29 -29
  61. data/spec/dummy/config/environments/production.rb +80 -80
  62. data/spec/dummy/config/environments/test.rb +36 -36
  63. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -7
  64. data/spec/dummy/config/initializers/filter_parameter_logging.rb +4 -4
  65. data/spec/dummy/config/initializers/inflections.rb +16 -16
  66. data/spec/dummy/config/initializers/mime_types.rb +5 -5
  67. data/spec/dummy/config/initializers/secret_token.rb +12 -12
  68. data/spec/dummy/config/initializers/session_store.rb +3 -3
  69. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -14
  70. data/spec/dummy/config/locales/en.yml +23 -23
  71. data/spec/dummy/config/routes.rb +10 -10
  72. data/spec/dummy/config.ru +4 -4
  73. data/spec/dummy/db/migrate/20130716083410_init_migration.rb +21 -21
  74. data/spec/dummy/db/schema.rb +53 -53
  75. data/spec/dummy/log/test.log +0 -0
  76. data/spec/dummy/public/404.html +58 -58
  77. data/spec/dummy/public/422.html +58 -58
  78. data/spec/dummy/public/500.html +57 -57
  79. data/spec/fields/reader_spec.rb +79 -79
  80. data/spec/spec_helper.rb +24 -24
  81. metadata +90 -88
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 80ddb3f33e8c26c57deb60f1eae3ad8470601c35
4
- data.tar.gz: a4c557c81b2a8c491c5bc369cbf545355dda8358
3
+ metadata.gz: b6bb8c9ec8f622c72e4ae1a628a871da337a21b5
4
+ data.tar.gz: a0b1c94f6c08ca2a9df613b8bef8318eaf39407c
5
5
  SHA512:
6
- metadata.gz: b7b579db7b3ba7aaf89e4cb32b9540563a11dcdef91d061812c060286a1b5ff86f483cd9f460a8b03f779f167fb1357ccef4986969f0da1451eb9cf08f31a70a
7
- data.tar.gz: 4cf49d981a924481c665541ef7d9643d20704d9c6e8bb923e0c8d6dc301a6133d6fcd993b0d38feca878a4d04f98df0081fdeb4323f5e575ee5122872b8ef492
6
+ metadata.gz: 2f782af3065f41ef235bc8e4f6aafebcf66e2031330b6326ecc4b7f735ce5b9da447799d28a3554fbdb729bf05c63ffe8f8b2dd0cf316d54af9aa6909bab2461
7
+ data.tar.gz: 8ada45b2fa2537c361fb4dec1d0ab6db1012bb96e14b60c4f56d97a9a0e01188438ec49258841ffafa59c49ee8262a75179194100b1de4148f27c0415780a3da
data/MIT-LICENSE CHANGED
@@ -1,20 +1,20 @@
1
- Copyright 2013 YOURNAME
2
-
3
- Permission is hereby granted, free of charge, to any person obtaining
4
- a copy of this software and associated documentation files (the
5
- "Software"), to deal in the Software without restriction, including
6
- without limitation the rights to use, copy, modify, merge, publish,
7
- distribute, sublicense, and/or sell copies of the Software, and to
8
- permit persons to whom the Software is furnished to do so, subject to
9
- the following conditions:
10
-
11
- The above copyright notice and this permission notice shall be
12
- included in all copies or substantial portions of the Software.
13
-
14
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
- EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
- NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
- LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
- OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
- WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
1
+ Copyright 2013 YOURNAME
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.rdoc CHANGED
@@ -1,97 +1,97 @@
1
- = Manage
2
-
3
- Admin backend started from http://iain.nl/backends-in-rails-3-1
4
-
5
- Based on inherit_resources, slim, kaminari
6
-
7
- == Installing
8
-
9
- Add the engine
10
-
11
- to Gemfile
12
-
13
- gem 'manage'
14
-
15
-
16
- to routes.rb yourapp/config/routes.rb:
17
-
18
- mount Manage::Engine, at: "/manage"
19
-
20
-
21
- if you want to have custom design in your app for the manage engine add in application.rb:
22
-
23
- config.assets.precompile += [
24
- 'manage/custom.css'
25
- ]
26
-
27
- == Defining resource for administration
28
-
29
-
30
- Add the resource to your app routes.rb yourapp/config/routes.rb:
31
-
32
- Manage::Engine.routes.draw do
33
- resources :cities
34
- end
35
-
36
-
37
- Create controller in your application yourapp/app/controllers/manage/cities_controller.rb
38
-
39
- class Manage::CitiesController < Manage::ResourceController
40
- @@per_page = 10 # optional
41
-
42
- # optional
43
- def collection_actions collection
44
- [
45
- view_context.button_to(t('manage.views.winners.export_as_bank_file'), [:export_as_bank_file, resource_class], method: :post, data: {handler: 'CollectionActions'}, class: 'button')
46
- ].join('').html_safe
47
- end
48
-
49
- # optional
50
- def resource_actions resource
51
- [
52
- '',
53
- view_context.link_to('Login as', login_as_user_path(resource.id)),
54
- ].join('&nbsp;'.html_safe).html_safe
55
- end
56
-
57
- end
58
-
59
-
60
- === View overriding
61
- You can overrede the views in
62
-
63
- app/views/manage/countries
64
-
65
- * _index.html.slim
66
- * _form.html_slim
67
- * edit.html.slim
68
- * new.html.slim
69
- * show.html.slim
70
-
71
-
72
-
73
-
74
- == Authorization
75
- In your app do
76
-
77
- rails generate devise AdminUser
78
-
79
- delete "devise_for :admin_users" from routes.rb
80
-
81
-
82
- Create an admin user. The users benefit from the devise password validation/generation but doesn't use the devise controllers.
83
-
84
-
85
- AdminUser.create(email: 'admin@example.com', password: '11223344', password_confirmation: '11223344')
86
-
87
-
88
- = TODO
89
-
90
- * Make it work with devise session controllers
91
- * add filters
92
- * add search
93
- * make nice layout
94
-
95
- == License
96
-
1
+ = Manage
2
+
3
+ Admin backend started from http://iain.nl/backends-in-rails-3-1
4
+
5
+ Based on inherit_resources, slim, kaminari
6
+
7
+ == Installing
8
+
9
+ Add the engine
10
+
11
+ to Gemfile
12
+
13
+ gem 'manage'
14
+
15
+
16
+ to routes.rb yourapp/config/routes.rb:
17
+
18
+ mount Manage::Engine, at: "/manage"
19
+
20
+
21
+ if you want to have custom design in your app for the manage engine add in application.rb:
22
+
23
+ config.assets.precompile += [
24
+ 'manage/custom.css'
25
+ ]
26
+
27
+ == Defining resource for administration
28
+
29
+
30
+ Add the resource to your app routes.rb yourapp/config/routes.rb:
31
+
32
+ Manage::Engine.routes.draw do
33
+ resources :cities
34
+ end
35
+
36
+
37
+ Create controller in your application yourapp/app/controllers/manage/cities_controller.rb
38
+
39
+ class Manage::CitiesController < Manage::ResourceController
40
+ @@per_page = 10 # optional
41
+
42
+ # optional
43
+ def collection_actions collection
44
+ [
45
+ view_context.button_to(t('manage.views.winners.export_as_bank_file'), [:export_as_bank_file, resource_class], method: :post, data: {handler: 'CollectionActions'}, class: 'button')
46
+ ].join('').html_safe
47
+ end
48
+
49
+ # optional
50
+ def resource_actions resource
51
+ [
52
+ '',
53
+ view_context.link_to('Login as', login_as_user_path(resource.id)),
54
+ ].join('&nbsp;'.html_safe).html_safe
55
+ end
56
+
57
+ end
58
+
59
+
60
+ === View overriding
61
+ You can overrede the views in
62
+
63
+ app/views/manage/countries
64
+
65
+ * _index.html.slim
66
+ * _form.html_slim
67
+ * edit.html.slim
68
+ * new.html.slim
69
+ * show.html.slim
70
+
71
+
72
+
73
+
74
+ == Authorization
75
+ In your app do
76
+
77
+ rails generate devise AdminUser
78
+
79
+ delete "devise_for :admin_users" from routes.rb
80
+
81
+
82
+ Create an admin user. The users benefit from the devise password validation/generation but doesn't use the devise controllers.
83
+
84
+
85
+ AdminUser.create(email: 'admin@example.com', password: '11223344', password_confirmation: '11223344')
86
+
87
+
88
+ = TODO
89
+
90
+ * Make it work with devise session controllers
91
+ * add filters
92
+ * add search
93
+ * make nice layout
94
+
95
+ == License
96
+
97
97
  This project rocks and uses MIT license
data/Rakefile CHANGED
@@ -1,31 +1,31 @@
1
- begin
2
- require 'bundler/setup'
3
- rescue LoadError
4
- puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
5
- end
6
-
7
- require 'rdoc/task'
8
-
9
- RDoc::Task.new(:rdoc) do |rdoc|
10
- rdoc.rdoc_dir = 'rdoc'
11
- rdoc.title = 'Manage'
12
- rdoc.options << '--line-numbers'
13
- rdoc.rdoc_files.include('README.rdoc')
14
- rdoc.rdoc_files.include('lib/**/*.rb')
15
- end
16
-
17
- APP_RAKEFILE = File.expand_path("../spec/dummy/Rakefile", __FILE__)
18
- load 'rails/tasks/engine.rake'
19
-
20
-
21
- Bundler::GemHelper.install_tasks
22
-
23
- Dir[File.join(File.dirname(__FILE__), 'tasks/**/*.rake')].each {|f| load f }
24
-
25
- require 'rspec/core'
26
- require 'rspec/core/rake_task'
27
-
28
- desc "Run all specs in spec directory (excluding plugin specs)"
29
- RSpec::Core::RakeTask.new(:spec => 'app:db:test:prepare')
30
-
31
- task default: :spec
1
+ begin
2
+ require 'bundler/setup'
3
+ rescue LoadError
4
+ puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
5
+ end
6
+
7
+ require 'rdoc/task'
8
+
9
+ RDoc::Task.new(:rdoc) do |rdoc|
10
+ rdoc.rdoc_dir = 'rdoc'
11
+ rdoc.title = 'Manage'
12
+ rdoc.options << '--line-numbers'
13
+ rdoc.rdoc_files.include('README.rdoc')
14
+ rdoc.rdoc_files.include('lib/**/*.rb')
15
+ end
16
+
17
+ APP_RAKEFILE = File.expand_path("../spec/dummy/Rakefile", __FILE__)
18
+ load 'rails/tasks/engine.rake'
19
+
20
+
21
+ Bundler::GemHelper.install_tasks
22
+
23
+ Dir[File.join(File.dirname(__FILE__), 'tasks/**/*.rake')].each {|f| load f }
24
+
25
+ require 'rspec/core'
26
+ require 'rspec/core/rake_task'
27
+
28
+ desc "Run all specs in spec directory (excluding plugin specs)"
29
+ RSpec::Core::RakeTask.new(:spec => 'app:db:test:prepare')
30
+
31
+ task default: :spec
@@ -1,30 +1,30 @@
1
- class CollectionActions
2
- constructor: (el) ->
3
- $el = $(el)
4
-
5
- $form = $el.closest('form')
6
-
7
- $el.on 'click', (e) ->
8
- e.stopPropagation()
9
- e.preventDefault()
10
-
11
- checkedCheckboxes = $('.rs:checked')
12
- unless checkedCheckboxes.length
13
- alert 'Select Items'
14
- return false
15
-
16
- # clear all hidden fields with class .hidden_selected_ids
17
- $form.find('input[type="hidden"]').remove()
18
-
19
- checkedCheckboxes.each ->
20
- # create a new hidden
21
- hidden_input = $('<input>').attr({
22
- type: 'hidden',
23
- name: 'selected_ids[]',
24
- value: $(@).val()
25
- }).appendTo($form)
26
-
27
- $form.submit()
28
-
29
-
30
- Handlers.register 'CollectionActions', CollectionActions
1
+ class CollectionActions
2
+ constructor: (el) ->
3
+ $el = $(el)
4
+
5
+ $form = $el.closest('form')
6
+
7
+ $el.on 'click', (e) ->
8
+ e.stopPropagation()
9
+ e.preventDefault()
10
+
11
+ checkedCheckboxes = $('.rs:checked')
12
+ unless checkedCheckboxes.length
13
+ alert 'Select Items'
14
+ return false
15
+
16
+ # clear all hidden fields with class .hidden_selected_ids
17
+ $form.find('input[type="hidden"]').remove()
18
+
19
+ checkedCheckboxes.each ->
20
+ # create a new hidden
21
+ hidden_input = $('<input>').attr({
22
+ type: 'hidden',
23
+ name: 'selected_ids[]',
24
+ value: $(@).val()
25
+ }).appendTo($form)
26
+
27
+ $form.submit()
28
+
29
+
30
+ Handlers.register 'CollectionActions', CollectionActions
@@ -1,46 +1,46 @@
1
- class @Handlers
2
- @handlers = {}
3
-
4
- @register: (handler, registeredClass) ->
5
- throw "No constructor on " + handler unless registeredClass.constructor
6
- @handlers[handler] = registeredClass
7
-
8
- @instantiate: (handlers, element) ->
9
- handlers = handlers.replace(/\s/g, '').split(',')
10
- element.handlers = []
11
- $.each handlers, (index, handler) =>
12
- if @handlers[handler]
13
- instance = new @handlers[handler](element)
14
- element.handlers.push instance
15
- else
16
- throw "Unknown handler " + handler
17
-
18
- @destroy: (instances) ->
19
- $.each instances, (index, instance) ->
20
- instance.destroy() if instance.destroy
21
-
22
- @unregisterAll: ->
23
- @handlers = {}
24
-
25
- $(document).on 'handlers:pageChanged', ->
26
- $('[data-handler]').each ->
27
- Handlers.instantiate $(this).attr('data-handler'), this
28
-
29
- $(document).on 'handlers:pageUpdated', (event, scope) ->
30
- $(scope).find('[data-handler]').each ->
31
- Handlers.instantiate $(this).attr('data-handler'), this
32
-
33
- $(document).on 'handlers:pageUpdating', (event, scope) ->
34
- $(scope).find('[data-handler]').each ->
35
- Handlers.destroy @handlers if @handlers
36
- delete @handlers if @handlers
37
-
38
- if typeof(Turbolinks) != undefined
39
- $(document).on 'page:fetch', ->
40
- $(document).trigger 'handlers:pageUpdating', 'body'
41
-
42
- $(document).on 'page:change', ->
43
- $(document).trigger 'handlers:pageUpdated', 'body'
44
-
45
- $ ->
46
- $(document).trigger 'handlers:pageChanged'
1
+ class @Handlers
2
+ @handlers = {}
3
+
4
+ @register: (handler, registeredClass) ->
5
+ throw "No constructor on " + handler unless registeredClass.constructor
6
+ @handlers[handler] = registeredClass
7
+
8
+ @instantiate: (handlers, element) ->
9
+ handlers = handlers.replace(/\s/g, '').split(',')
10
+ element.handlers = []
11
+ $.each handlers, (index, handler) =>
12
+ if @handlers[handler]
13
+ instance = new @handlers[handler](element)
14
+ element.handlers.push instance
15
+ else
16
+ throw "Unknown handler " + handler
17
+
18
+ @destroy: (instances) ->
19
+ $.each instances, (index, instance) ->
20
+ instance.destroy() if instance.destroy
21
+
22
+ @unregisterAll: ->
23
+ @handlers = {}
24
+
25
+ $(document).on 'handlers:pageChanged', ->
26
+ $('[data-handler]').each ->
27
+ Handlers.instantiate $(this).attr('data-handler'), this
28
+
29
+ $(document).on 'handlers:pageUpdated', (event, scope) ->
30
+ $(scope).find('[data-handler]').each ->
31
+ Handlers.instantiate $(this).attr('data-handler'), this
32
+
33
+ $(document).on 'handlers:pageUpdating', (event, scope) ->
34
+ $(scope).find('[data-handler]').each ->
35
+ Handlers.destroy @handlers if @handlers
36
+ delete @handlers if @handlers
37
+
38
+ if typeof(Turbolinks) != undefined
39
+ $(document).on 'page:fetch', ->
40
+ $(document).trigger 'handlers:pageUpdating', 'body'
41
+
42
+ $(document).on 'page:change', ->
43
+ $(document).trigger 'handlers:pageUpdated', 'body'
44
+
45
+ $ ->
46
+ $(document).trigger 'handlers:pageChanged'
@@ -1,12 +1,12 @@
1
- class TableCheckboxes
2
- constructor: (el) ->
3
- $el = $(el)
4
- $mainContainer = $el.closest('table')
5
-
6
- $el.on 'click', (event, element)->
7
- check = if $el.is(':checked') then true else false
8
-
9
- $mainContainer.find('.rs').each ->
10
- $(@).prop('checked', check)
11
-
1
+ class TableCheckboxes
2
+ constructor: (el) ->
3
+ $el = $(el)
4
+ $mainContainer = $el.closest('table')
5
+
6
+ $el.on 'click', (event, element)->
7
+ check = if $el.is(':checked') then true else false
8
+
9
+ $mainContainer.find('.rs').each ->
10
+ $(@).prop('checked', check)
11
+
12
12
  Handlers.register 'TableCheckboxes', TableCheckboxes
@@ -1,13 +1,13 @@
1
- class Manage::ApplicationController < ActionController::Base
2
- before_filter :auth_user!
3
-
4
- def auth_user!
5
- redirect_to new_admin_user_session_path unless admin_user_signed_in?
6
- end
7
-
8
- helper_method :current_user
9
- def current_user
10
- current_admin_user
11
- end
12
-
13
- end
1
+ class Manage::ApplicationController < ActionController::Base
2
+ before_filter :auth_user!
3
+
4
+ def auth_user!
5
+ redirect_to new_admin_user_session_path unless admin_user_signed_in?
6
+ end
7
+
8
+ helper_method :current_user
9
+ def current_user
10
+ current_admin_user
11
+ end
12
+
13
+ end
@@ -1,4 +1,4 @@
1
- class Manage::DashboardsController < Manage::ApplicationController
2
- def index
3
- end
4
- end
1
+ class Manage::DashboardsController < Manage::ApplicationController
2
+ def index
3
+ end
4
+ end
@@ -36,8 +36,17 @@ class Manage::ResourceController < Manage::ApplicationController
36
36
  search_params
37
37
  end
38
38
 
39
+ def self.collection_scope lambda
40
+ @@collection_scope = lambda
41
+ end
42
+
39
43
  def collection
40
- assocation = end_of_association_chain.page(params[:page] || 1)
44
+ filtered_collection = end_of_association_chain
45
+ if @@collection_scope
46
+ filtered_collection = @@collection_scope.call(filtered_collection)
47
+ end
48
+
49
+ assocation = filtered_collection.page(params[:page] || 1)
41
50
  per_page ? assocation.per(per_page) : assocation
42
51
  end
43
52
 
@@ -1,12 +1,12 @@
1
- # app/controllers/backend/responder.rb
2
- class Manage::Responder < ::ActionController::Responder
3
-
4
- include Responders::FlashResponder
5
- include Responders::HttpCacheResponder
6
-
7
- def initialize(*)
8
- super
9
- @flash_now = :on_failure
10
- end
11
-
1
+ # app/controllers/backend/responder.rb
2
+ class Manage::Responder < ::ActionController::Responder
3
+
4
+ include Responders::FlashResponder
5
+ include Responders::HttpCacheResponder
6
+
7
+ def initialize(*)
8
+ super
9
+ @flash_now = :on_failure
10
+ end
11
+
12
12
  end
@@ -1,11 +1,11 @@
1
- module Manage
2
- class SessionsController < ::Devise::SessionsController
3
- layout "manage/sign_in"
4
-
5
- def destroy
6
- p 'what?'
7
- super
8
- end
9
- end
10
- end
11
-
1
+ module Manage
2
+ class SessionsController < ::Devise::SessionsController
3
+ layout "manage/sign_in"
4
+
5
+ def destroy
6
+ p 'what?'
7
+ super
8
+ end
9
+ end
10
+ end
11
+