manage 1.3.41 → 1.3.42
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/MIT-LICENSE +20 -20
- data/README.rdoc +2 -0
- data/Rakefile +31 -31
- data/app/assets/javascripts/manage/collection_actions.js.coffee +30 -30
- data/app/assets/javascripts/manage/handlers.js.coffee +46 -46
- data/app/assets/javascripts/manage/table_checkboxes.js.coffee +11 -11
- data/app/controllers/manage/application_controller.rb +13 -13
- data/app/controllers/manage/dashboards_controller.rb +4 -4
- data/app/controllers/manage/responder.rb +11 -11
- data/app/controllers/manage/sessions_controller.rb +11 -11
- data/app/helpers/manage/application_helper.rb +42 -42
- data/app/helpers/manage/form_helper.rb +21 -21
- data/app/helpers/manage/resource_helper.rb +77 -77
- data/app/models/admin_user.rb +4 -4
- data/app/views/layouts/manage/_main_menu.html.slim +52 -52
- data/app/views/layouts/manage/sign_in.html.slim +30 -30
- data/app/views/manage/resource/_form.html.slim +4 -4
- data/app/views/manage/resource/index/_collection_actions.html.slim +2 -2
- data/app/views/manage/resource/index/_count.html.slim +6 -6
- data/app/views/manage/resource/show.html.slim +10 -10
- data/app/views/manage/sessions/new.html.slim +10 -10
- data/config/initializers/devise.rb +247 -247
- data/config/initializers/session_store.rb +1 -3
- data/config/initializers/simple_form.rb +145 -145
- data/config/initializers/simple_form_foundation.rb +26 -26
- data/config/locales/devise.en.yml +59 -59
- data/config/locales/en.yml +20 -20
- data/config/routes.rb +10 -10
- data/db/migrate/20131204142720_create_admin_users.rb +24 -24
- data/lib/manage.rb +5 -5
- data/lib/manage/engine.rb +21 -21
- data/lib/manage/fields.rb +6 -6
- data/lib/manage/version.rb +1 -1
- data/lib/tasks/manage_tasks.rake +15 -15
- data/lib/templates/erb/scaffold/_form.html.erb +13 -13
- data/spec/controllers/manage/resource_controller_spec.rb +29 -29
- data/spec/dummy/README.rdoc +28 -28
- data/spec/dummy/Rakefile +6 -6
- data/spec/dummy/app/assets/javascripts/application.js +13 -13
- data/spec/dummy/app/assets/stylesheets/application.css +13 -13
- data/spec/dummy/app/controllers/application_controller.rb +5 -5
- data/spec/dummy/app/controllers/manage/posts_controller.rb +4 -4
- data/spec/dummy/app/helpers/application_helper.rb +2 -2
- data/spec/dummy/app/models/post.rb +3 -3
- data/spec/dummy/app/models/user.rb +5 -5
- data/spec/dummy/app/views/layouts/application.html.erb +14 -14
- data/spec/dummy/bin/bundle +3 -3
- data/spec/dummy/bin/rails +4 -4
- data/spec/dummy/bin/rake +4 -4
- data/spec/dummy/config.ru +4 -4
- data/spec/dummy/config/application.rb +24 -24
- data/spec/dummy/config/boot.rb +5 -5
- data/spec/dummy/config/database.yml +25 -25
- data/spec/dummy/config/environment.rb +5 -5
- data/spec/dummy/config/environments/development.rb +29 -29
- data/spec/dummy/config/environments/production.rb +80 -80
- data/spec/dummy/config/environments/test.rb +36 -36
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -7
- data/spec/dummy/config/initializers/filter_parameter_logging.rb +4 -4
- data/spec/dummy/config/initializers/inflections.rb +16 -16
- data/spec/dummy/config/initializers/mime_types.rb +5 -5
- data/spec/dummy/config/initializers/secret_token.rb +12 -12
- data/spec/dummy/config/initializers/session_store.rb +3 -3
- data/spec/dummy/config/initializers/wrap_parameters.rb +14 -14
- data/spec/dummy/config/locales/en.yml +23 -23
- data/spec/dummy/config/routes.rb +10 -10
- data/spec/dummy/db/migrate/20130716083410_init_migration.rb +21 -21
- data/spec/dummy/db/schema.rb +53 -53
- data/spec/dummy/public/404.html +58 -58
- data/spec/dummy/public/422.html +58 -58
- data/spec/dummy/public/500.html +57 -57
- data/spec/fields/reader_spec.rb +79 -79
- data/spec/spec_helper.rb +24 -24
- metadata +24 -24
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 600df2656f6776742c5d837873d8c35dc119e377
|
4
|
+
data.tar.gz: 7aa7df1fb6579ae9d6376671ec59a06dffe331c1
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: d77228a39d11aaf2ab709e6f0d99e1663387ffbb7e861c86efc13101d7330176773279d5eb620c230d74ed9c6f67053ea0b28d4cfd9d48a10fe6a522c2e8c907
|
7
|
+
data.tar.gz: a6086453c068399ce406ebc203d63c90be1974d772f4849632431c175aa3bb109e5077cde2e77efa25550a564193e3c052bbfda8a8dfea9a87d822b7bc77fae2
|
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
@@ -98,6 +98,8 @@ Create an admin user. The users benefit from the devise password validation/gene
|
|
98
98
|
|
99
99
|
AdminUser.create(email: 'admin@example.com', password: '11223344', password_confirmation: '11223344')
|
100
100
|
|
101
|
+
[ ![Codeship Status for empowerunited/manage](https://www.codeship.io/projects/1c343f80-3084-0132-3465-0a5d7c3cc23a/status)](https://www.codeship.io/projects/39835)
|
102
|
+
|
101
103
|
= Graphics and art
|
102
104
|
|
103
105
|
Logo designed by Geri http://dribbble.com/gerystancheva
|
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
|
@@ -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
|
+
|
@@ -1,42 +1,42 @@
|
|
1
|
-
module Manage
|
2
|
-
module ApplicationHelper
|
3
|
-
|
4
|
-
def collection_table collection, resource_class, no_items_text
|
5
|
-
|
6
|
-
if collection.empty?
|
7
|
-
return content_tag(:h3, resource_class.model_name.human(count: 2)) + content_tag(:p, no_items_text)
|
8
|
-
else
|
9
|
-
rows = []
|
10
|
-
|
11
|
-
ths = resource_class.attribute_names.collect do |attr|
|
12
|
-
content_tag(:td, truncate(resource_class.human_attribute_name(attr).to_s, length: 50))
|
13
|
-
end.join('').html_safe
|
14
|
-
rows << content_tag(:tr, ths)
|
15
|
-
|
16
|
-
collection.each do |item|
|
17
|
-
tds = resource_class.attribute_names.collect do |attr|
|
18
|
-
content_tag(:td, truncate(item.public_send(attr).to_s, length: 50))
|
19
|
-
end.join('').html_safe
|
20
|
-
|
21
|
-
rows << content_tag(:tr, tds)
|
22
|
-
end
|
23
|
-
content_tag(:h3, resource_class.model_name.human(count: 2)) +
|
24
|
-
content_tag(:table, rows.join('').html_safe)
|
25
|
-
end
|
26
|
-
end
|
27
|
-
|
28
|
-
def condensed_table resource_class, cols=2
|
29
|
-
rows = []
|
30
|
-
resource_class.attribute_names.each_slice(cols).each do |slice|
|
31
|
-
row = slice.collect do |attr|
|
32
|
-
content_tag(:td, resource_class.human_attribute_name(attr)) +
|
33
|
-
content_tag(:td, resource.public_send(attr))
|
34
|
-
end
|
35
|
-
rows << content_tag(:tr, row.join('').html_safe)
|
36
|
-
end
|
37
|
-
|
38
|
-
content_tag :table, rows.join('').html_safe
|
39
|
-
end
|
40
|
-
|
41
|
-
end
|
42
|
-
end
|
1
|
+
module Manage
|
2
|
+
module ApplicationHelper
|
3
|
+
|
4
|
+
def collection_table collection, resource_class, no_items_text
|
5
|
+
|
6
|
+
if collection.empty?
|
7
|
+
return content_tag(:h3, resource_class.model_name.human(count: 2)) + content_tag(:p, no_items_text)
|
8
|
+
else
|
9
|
+
rows = []
|
10
|
+
|
11
|
+
ths = resource_class.attribute_names.collect do |attr|
|
12
|
+
content_tag(:td, truncate(resource_class.human_attribute_name(attr).to_s, length: 50))
|
13
|
+
end.join('').html_safe
|
14
|
+
rows << content_tag(:tr, ths)
|
15
|
+
|
16
|
+
collection.each do |item|
|
17
|
+
tds = resource_class.attribute_names.collect do |attr|
|
18
|
+
content_tag(:td, truncate(item.public_send(attr).to_s, length: 50))
|
19
|
+
end.join('').html_safe
|
20
|
+
|
21
|
+
rows << content_tag(:tr, tds)
|
22
|
+
end
|
23
|
+
content_tag(:h3, resource_class.model_name.human(count: 2)) +
|
24
|
+
content_tag(:table, rows.join('').html_safe)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def condensed_table resource_class, cols=2
|
29
|
+
rows = []
|
30
|
+
resource_class.attribute_names.each_slice(cols).each do |slice|
|
31
|
+
row = slice.collect do |attr|
|
32
|
+
content_tag(:td, resource_class.human_attribute_name(attr)) +
|
33
|
+
content_tag(:td, resource.public_send(attr))
|
34
|
+
end
|
35
|
+
rows << content_tag(:tr, row.join('').html_safe)
|
36
|
+
end
|
37
|
+
|
38
|
+
content_tag :table, rows.join('').html_safe
|
39
|
+
end
|
40
|
+
|
41
|
+
end
|
42
|
+
end
|