trestle 0.9.0 → 0.9.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (203) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +15 -9
  3. data/Gemfile +3 -3
  4. data/README.md +4 -2
  5. data/app/assets/bundle/trestle/bundle.css +0 -0
  6. data/app/assets/bundle/trestle/bundle.js +0 -0
  7. data/app/assets/bundle/trestle/fa-brands-400.eot +0 -0
  8. data/app/assets/bundle/trestle/fa-brands-400.svg +0 -0
  9. data/app/assets/bundle/trestle/fa-brands-400.ttf +0 -0
  10. data/app/assets/bundle/trestle/fa-brands-400.woff +0 -0
  11. data/app/assets/bundle/trestle/fa-brands-400.woff2 +0 -0
  12. data/app/assets/bundle/trestle/fa-regular-400.eot +0 -0
  13. data/app/assets/bundle/trestle/fa-regular-400.svg +0 -0
  14. data/app/assets/bundle/trestle/fa-regular-400.ttf +0 -0
  15. data/app/assets/bundle/trestle/fa-regular-400.woff +0 -0
  16. data/app/assets/bundle/trestle/fa-regular-400.woff2 +0 -0
  17. data/app/assets/bundle/trestle/fa-solid-900.eot +0 -0
  18. data/app/assets/bundle/trestle/fa-solid-900.svg +0 -0
  19. data/app/assets/bundle/trestle/fa-solid-900.ttf +0 -0
  20. data/app/assets/bundle/trestle/fa-solid-900.woff +0 -0
  21. data/app/assets/bundle/trestle/fa-solid-900.woff2 +0 -0
  22. data/app/assets/bundle/trestle/flatpickr/ar.js +0 -0
  23. data/app/assets/bundle/trestle/flatpickr/at.js +0 -0
  24. data/app/assets/bundle/trestle/flatpickr/az.js +0 -0
  25. data/app/assets/bundle/trestle/flatpickr/be.js +0 -0
  26. data/app/assets/bundle/trestle/flatpickr/bg.js +0 -0
  27. data/app/assets/bundle/trestle/flatpickr/bn.js +0 -0
  28. data/app/assets/bundle/trestle/flatpickr/bs.js +0 -0
  29. data/app/assets/bundle/trestle/flatpickr/cat.js +0 -0
  30. data/app/assets/bundle/trestle/flatpickr/cs.js +0 -0
  31. data/app/assets/bundle/trestle/flatpickr/cy.js +0 -0
  32. data/app/assets/bundle/trestle/flatpickr/da.js +0 -0
  33. data/app/assets/bundle/trestle/flatpickr/de.js +0 -0
  34. data/app/assets/bundle/trestle/flatpickr/default.js +0 -0
  35. data/app/assets/bundle/trestle/flatpickr/eo.js +0 -0
  36. data/app/assets/bundle/trestle/flatpickr/es.js +0 -0
  37. data/app/assets/bundle/trestle/flatpickr/et.js +0 -0
  38. data/app/assets/bundle/trestle/flatpickr/fa.js +0 -0
  39. data/app/assets/bundle/trestle/flatpickr/fi.js +0 -0
  40. data/app/assets/bundle/trestle/flatpickr/fo.js +0 -0
  41. data/app/assets/bundle/trestle/flatpickr/fr.js +0 -0
  42. data/app/assets/bundle/trestle/flatpickr/ga.js +0 -0
  43. data/app/assets/bundle/trestle/flatpickr/gr.js +0 -0
  44. data/app/assets/bundle/trestle/flatpickr/he.js +0 -0
  45. data/app/assets/bundle/trestle/flatpickr/hi.js +0 -0
  46. data/app/assets/bundle/trestle/flatpickr/hr.js +0 -0
  47. data/app/assets/bundle/trestle/flatpickr/hu.js +0 -0
  48. data/app/assets/bundle/trestle/flatpickr/id.js +0 -0
  49. data/app/assets/bundle/trestle/flatpickr/is.js +0 -0
  50. data/app/assets/bundle/trestle/flatpickr/it.js +0 -0
  51. data/app/assets/bundle/trestle/flatpickr/ja.js +0 -0
  52. data/app/assets/bundle/trestle/flatpickr/ka.js +0 -0
  53. data/app/assets/bundle/trestle/flatpickr/km.js +0 -0
  54. data/app/assets/bundle/trestle/flatpickr/ko.js +0 -0
  55. data/app/assets/bundle/trestle/flatpickr/kz.js +0 -0
  56. data/app/assets/bundle/trestle/flatpickr/lt.js +0 -0
  57. data/app/assets/bundle/trestle/flatpickr/lv.js +0 -0
  58. data/app/assets/bundle/trestle/flatpickr/mk.js +0 -0
  59. data/app/assets/bundle/trestle/flatpickr/mn.js +0 -0
  60. data/app/assets/bundle/trestle/flatpickr/ms.js +0 -0
  61. data/app/assets/bundle/trestle/flatpickr/my.js +0 -0
  62. data/app/assets/bundle/trestle/flatpickr/nl.js +0 -0
  63. data/app/assets/bundle/trestle/flatpickr/no.js +0 -0
  64. data/app/assets/bundle/trestle/flatpickr/pa.js +0 -0
  65. data/app/assets/bundle/trestle/flatpickr/pl.js +0 -0
  66. data/app/assets/bundle/trestle/flatpickr/pt.js +0 -0
  67. data/app/assets/bundle/trestle/flatpickr/ro.js +0 -0
  68. data/app/assets/bundle/trestle/flatpickr/ru.js +0 -0
  69. data/app/assets/bundle/trestle/flatpickr/si.js +0 -0
  70. data/app/assets/bundle/trestle/flatpickr/sk.js +0 -0
  71. data/app/assets/bundle/trestle/flatpickr/sl.js +0 -0
  72. data/app/assets/bundle/trestle/flatpickr/sq.js +0 -0
  73. data/app/assets/bundle/trestle/flatpickr/sr-cyr.js +0 -0
  74. data/app/assets/bundle/trestle/flatpickr/sr.js +0 -0
  75. data/app/assets/bundle/trestle/flatpickr/sv.js +0 -0
  76. data/app/assets/bundle/trestle/flatpickr/th.js +0 -0
  77. data/app/assets/bundle/trestle/flatpickr/tr.js +0 -0
  78. data/app/assets/bundle/trestle/flatpickr/uk.js +0 -0
  79. data/app/assets/bundle/trestle/flatpickr/uz.js +0 -0
  80. data/app/assets/bundle/trestle/flatpickr/uz_latn.js +0 -0
  81. data/app/assets/bundle/trestle/flatpickr/vn.js +0 -0
  82. data/app/assets/bundle/trestle/flatpickr/zh-tw.js +0 -0
  83. data/app/assets/bundle/trestle/flatpickr/zh.js +0 -0
  84. data/app/assets/javascripts/trestle/admin.js +1 -0
  85. data/app/assets/javascripts/trestle/i18n.js.erb +8 -0
  86. data/{lib → app/controllers/concerns}/trestle/controller/breadcrumbs.rb +1 -1
  87. data/{lib → app/controllers/concerns}/trestle/controller/callbacks.rb +0 -0
  88. data/{lib → app/controllers/concerns}/trestle/controller/dialog.rb +0 -0
  89. data/{lib → app/controllers/concerns}/trestle/controller/helpers.rb +0 -0
  90. data/{lib → app/controllers/concerns}/trestle/controller/layout.rb +0 -0
  91. data/{lib → app/controllers/concerns}/trestle/controller/location.rb +0 -0
  92. data/app/controllers/concerns/trestle/controller/title.rb +20 -0
  93. data/app/controllers/concerns/trestle/controller/toolbars.rb +30 -0
  94. data/app/controllers/concerns/trestle/resource/controller/actions.rb +133 -0
  95. data/app/controllers/concerns/trestle/resource/controller/data_methods.rb +52 -0
  96. data/app/controllers/concerns/trestle/resource/controller/redirection.rb +23 -0
  97. data/app/controllers/concerns/trestle/resource/controller/toolbar.rb +11 -0
  98. data/app/controllers/trestle/admin_controller.rb +31 -0
  99. data/app/controllers/trestle/application_controller.rb +12 -0
  100. data/app/controllers/trestle/resource_controller.rb +6 -0
  101. data/app/helpers/trestle/grid_helper.rb +51 -7
  102. data/app/helpers/trestle/hook_helper.rb +1 -25
  103. data/app/helpers/trestle/i18n_helper.rb +8 -15
  104. data/app/helpers/trestle/layout_helper.rb +20 -0
  105. data/app/helpers/trestle/navigation_helper.rb +23 -0
  106. data/app/helpers/trestle/table_helper.rb +22 -3
  107. data/app/helpers/trestle/title_helper.rb +11 -0
  108. data/app/helpers/trestle/toolbars_helper.rb +0 -11
  109. data/app/views/layouts/trestle/admin.html.erb +6 -6
  110. data/app/views/trestle/application/_dialog.html.erb +1 -1
  111. data/app/views/trestle/application/_header.html.erb +1 -3
  112. data/app/views/trestle/resource/_scopes.html.erb +17 -8
  113. data/app/views/trestle/resource/edit.html.erb +2 -2
  114. data/app/views/trestle/resource/index.html.erb +3 -3
  115. data/app/views/trestle/resource/new.html.erb +1 -1
  116. data/app/views/trestle/resource/show.html.erb +2 -2
  117. data/app/views/trestle/shared/_sidebar.html.erb +5 -6
  118. data/app/views/trestle/table/_pagination.html.erb +1 -1
  119. data/config/locales/de.rb +18 -0
  120. data/config/locales/de.yml +101 -0
  121. data/config/locales/vi.rb +18 -0
  122. data/config/locales/vi.yml +101 -0
  123. data/frontend/css/components/_fields.scss +5 -0
  124. data/frontend/css/components/_scopes.scss +66 -21
  125. data/frontend/css/components/_table.scss +20 -0
  126. data/frontend/css/layout/_content.scss +5 -2
  127. data/frontend/css/layout/_sidebar.scss +6 -1
  128. data/frontend/css/variables/_trestle.scss +5 -5
  129. data/frontend/js/components/confirmation.js +4 -2
  130. data/frontend/js/components/dialog.js +7 -1
  131. data/frontend/js/components/form.js +9 -0
  132. data/frontend/js/components/navigation.js +63 -0
  133. data/frontend/js/components/pagination.js +51 -0
  134. data/frontend/js/components/sidebar.js +8 -11
  135. data/frontend/js/components/table.js +33 -2
  136. data/frontend/js/components/tabs.js +2 -2
  137. data/frontend/js/core/events.js +7 -3
  138. data/frontend/js/index.js +1 -0
  139. data/frontend/theme/trestle/theme/bootstrap/_buttons.scss +3 -0
  140. data/lib/generators/trestle/resource/resource_generator.rb +15 -1
  141. data/lib/generators/trestle/resource/templates/admin.rb.erb +15 -8
  142. data/lib/trestle.rb +33 -36
  143. data/lib/trestle/adapters.rb +1 -1
  144. data/lib/trestle/adapters/active_record_adapter.rb +1 -1
  145. data/lib/trestle/admin.rb +18 -8
  146. data/lib/trestle/admin/builder.rb +7 -3
  147. data/lib/trestle/configurable.rb +10 -0
  148. data/lib/trestle/configuration.rb +3 -3
  149. data/lib/trestle/engine.rb +3 -10
  150. data/lib/trestle/evaluation_context.rb +11 -3
  151. data/lib/trestle/form.rb +5 -7
  152. data/lib/trestle/form/automatic.rb +2 -2
  153. data/lib/trestle/form/builder.rb +2 -3
  154. data/lib/trestle/form/field.rb +44 -17
  155. data/lib/trestle/form/fields.rb +6 -38
  156. data/lib/trestle/form/fields/check_box_helpers.rb +1 -1
  157. data/lib/trestle/form/fields/collection_select.rb +1 -1
  158. data/lib/trestle/form/fields/date_picker.rb +9 -3
  159. data/lib/trestle/form/fields/date_select.rb +1 -1
  160. data/lib/trestle/form/fields/datetime_select.rb +1 -1
  161. data/lib/trestle/form/fields/file_field.rb +1 -1
  162. data/lib/trestle/form/fields/form_group.rb +18 -5
  163. data/lib/trestle/form/fields/grouped_collection_select.rb +1 -1
  164. data/lib/trestle/form/fields/range_field.rb +2 -4
  165. data/lib/trestle/form/fields/select.rb +2 -3
  166. data/lib/trestle/form/fields/static_field.rb +7 -3
  167. data/lib/trestle/form/fields/tag_select.rb +3 -1
  168. data/lib/trestle/form/fields/time_select.rb +1 -1
  169. data/lib/trestle/form/fields/time_zone_select.rb +1 -1
  170. data/lib/trestle/form/renderer.rb +7 -3
  171. data/lib/trestle/hook.rb +5 -31
  172. data/lib/trestle/hook/helpers.rb +33 -0
  173. data/lib/trestle/hook/set.rb +32 -0
  174. data/lib/trestle/navigation.rb +3 -6
  175. data/lib/trestle/navigation/group.rb +4 -0
  176. data/lib/trestle/navigation/item.rb +4 -0
  177. data/lib/trestle/reloader.rb +23 -11
  178. data/lib/trestle/resource.rb +8 -9
  179. data/lib/trestle/resource/builder.rb +4 -3
  180. data/lib/trestle/resource/collection.rb +1 -5
  181. data/lib/trestle/resource/toolbar.rb +42 -0
  182. data/lib/trestle/scopes.rb +38 -11
  183. data/lib/trestle/scopes/block.rb +9 -8
  184. data/lib/trestle/scopes/definition.rb +22 -0
  185. data/lib/trestle/scopes/scope.rb +6 -2
  186. data/lib/trestle/tab.rb +2 -0
  187. data/lib/trestle/table.rb +17 -12
  188. data/lib/trestle/table/actions_column.rb +6 -6
  189. data/lib/trestle/table/automatic.rb +3 -3
  190. data/lib/trestle/table/builder.rb +4 -4
  191. data/lib/trestle/table/column.rb +29 -24
  192. data/lib/trestle/table/row.rb +13 -13
  193. data/lib/trestle/table/select_column.rb +19 -7
  194. data/lib/trestle/toolbar.rb +4 -11
  195. data/lib/trestle/version.rb +1 -1
  196. data/package.json +8 -8
  197. data/trestle.gemspec +6 -6
  198. data/webpack.config.js +4 -1
  199. data/yarn.lock +1871 -1800
  200. metadata +56 -21
  201. data/lib/trestle/admin/controller.rb +0 -28
  202. data/lib/trestle/application_controller.rb +0 -12
  203. data/lib/trestle/resource/controller.rb +0 -174
@@ -55,6 +55,10 @@ module Trestle
55
55
  Badge.new(options[:badge]) if badge?
56
56
  end
57
57
 
58
+ def html_options
59
+ options.except(:admin, :badge, :group, :icon, :if, :label, :priority, :unless)
60
+ end
61
+
58
62
  def visible?(context)
59
63
  if options[:if]
60
64
  context.instance_exec(&options[:if])
@@ -1,17 +1,13 @@
1
1
  module Trestle
2
2
  class Reloader
3
- delegate :execute, :updated?, to: :updater
3
+ delegate :execute, :execute_if_updated, :updated?, to: :updater
4
4
 
5
- def execute_if_updated
6
- if defined?(@updater)
7
- updater.execute_if_updated
8
- else
9
- updater.execute
10
- end
5
+ def initialize(files, dirs = {})
6
+ @files, @dirs = files, dirs
11
7
  end
12
8
 
13
9
  def updater
14
- @updater ||= ActiveSupport::FileUpdateChecker.new([], compile_load_paths) do
10
+ @updater ||= ActiveSupport::FileUpdateChecker.new(@files, @dirs) do
15
11
  begin
16
12
  clear
17
13
 
@@ -37,9 +33,25 @@ module Trestle
37
33
  Trestle.config.load_paths.map { |path| path.respond_to?(:call) ? path.call : path }.flatten.map(&:to_s)
38
34
  end
39
35
 
40
- private
41
- def compile_load_paths
42
- Hash[*load_paths.map { |path| [path, "rb"] }.flatten]
36
+ def install(app)
37
+ reloader = self
38
+
39
+ app.reloaders << reloader
40
+
41
+ if app.respond_to?(:reloader)
42
+ # Rails >= 5.0
43
+ app.reloader.to_run do
44
+ reloader.execute_if_updated
45
+ true # Rails <= 5.1
46
+ end
47
+ else
48
+ # Rails 4.2
49
+ ActionDispatch::Reloader.to_prepare do
50
+ reloader.execute_if_updated
51
+ end
52
+ end
53
+
54
+ reloader.execute
43
55
  end
44
56
  end
45
57
  end
@@ -1,11 +1,9 @@
1
1
  module Trestle
2
2
  class Resource < Admin
3
- extend ActiveSupport::Autoload
4
-
5
- autoload :AdapterMethods
6
- autoload :Builder
7
- autoload :Collection
8
- autoload :Controller
3
+ require_relative "resource/adapter_methods"
4
+ require_relative "resource/builder"
5
+ require_relative "resource/collection"
6
+ require_relative "resource/toolbar"
9
7
 
10
8
  include AdapterMethods
11
9
 
@@ -50,9 +48,10 @@ module Trestle
50
48
  Collection.new(self, options).prepare(params)
51
49
  end
52
50
 
53
- # Evaluates the admin's scope block(s) and returns a hash of Scope objects keyed by the scope name
51
+ # Evaluates the admin's scope block(s) using the adapter context
52
+ # and returns a hash of Scope objects keyed by the scope name.
54
53
  def scopes
55
- @scopes ||= self.class.scopes.evaluate(@context)
54
+ @scopes ||= Scopes.new(self.class.scopes, adapter)
56
55
  end
57
56
 
58
57
  class << self
@@ -62,7 +61,7 @@ module Trestle
62
61
  end
63
62
 
64
63
  def scopes
65
- @scopes ||= Scopes.new(self)
64
+ @scopes ||= Scopes::Definition.new
66
65
  end
67
66
 
68
67
  def column_sorts
@@ -2,7 +2,7 @@ module Trestle
2
2
  class Resource
3
3
  class Builder < Admin::Builder
4
4
  self.admin_class = Resource
5
- self.controller = Controller
5
+ self.controller = -> { ResourceController }
6
6
 
7
7
  def adapter(&block)
8
8
  klass = admin.adapter_class
@@ -83,8 +83,9 @@ module Trestle
83
83
  admin.define_adapter_method(:count, &block)
84
84
  end
85
85
 
86
- def scopes(&block)
87
- admin.scopes.append(&block)
86
+ def scopes(options={}, &block)
87
+ admin.scopes.options.merge!(options)
88
+ admin.scopes.append(&block) if block_given?
88
89
  end
89
90
 
90
91
  def scope(name, scope=nil, options={}, &block)
@@ -42,15 +42,11 @@ module Trestle
42
42
  def apply_scopes(collection, params)
43
43
  unscoped = collection(params)
44
44
 
45
- active_scopes(params).reduce(collection) do |collection, scope|
45
+ scopes.active(params).reduce(collection) do |collection, scope|
46
46
  merge_scopes(collection, scope.apply(unscoped))
47
47
  end
48
48
  end
49
49
 
50
- def active_scopes(params)
51
- scopes.values.select { |s| s.active?(params) }
52
- end
53
-
54
50
  def apply_sorting(collection, params)
55
51
  return collection unless params[:sort]
56
52
 
@@ -0,0 +1,42 @@
1
+ module Trestle
2
+ class Resource
3
+ module Toolbar
4
+ class Builder < Trestle::Toolbar::Builder
5
+ delegate :admin, :instance, to: :@template
6
+ delegate :translate, :t, to: :admin
7
+
8
+ def new
9
+ link(t("buttons.new", default: "New %{model_name}"), action: :new, style: :light, icon: "fa fa-plus", class: "btn-new-resource") if action?(:new)
10
+ end
11
+
12
+ def save
13
+ button(t("buttons.save", default: "Save %{model_name}"), style: :success)
14
+ end
15
+
16
+ def delete
17
+ link(t("buttons.delete", default: "Delete %{model_name}"), instance, action: :destroy, method: :delete, style: :danger, icon: "fa fa-trash", data: { toggle: "confirm-delete", placement: "bottom" }) if action?(:destroy)
18
+ end
19
+
20
+ def dismiss
21
+ button(t("buttons.ok", default: "OK"), style: :light, data: { dismiss: "modal" }) if @template.dialog_request?
22
+ end
23
+ alias ok dismiss
24
+
25
+ def save_or_dismiss(action=:update)
26
+ if action?(action)
27
+ save
28
+ else
29
+ dismiss
30
+ end
31
+ end
32
+
33
+ builder_method :new, :save, :delete, :dismiss, :ok, :save_or_dismiss
34
+
35
+ protected
36
+ def action?(action)
37
+ admin.actions.include?(action)
38
+ end
39
+ end
40
+ end
41
+ end
42
+ end
@@ -1,23 +1,50 @@
1
1
  module Trestle
2
2
  class Scopes
3
- extend ActiveSupport::Autoload
3
+ require_relative "scopes/block"
4
+ require_relative "scopes/definition"
5
+ require_relative "scopes/scope"
4
6
 
5
- autoload :Block
6
- autoload :Scope
7
+ include Enumerable
7
8
 
8
- attr_reader :admin, :blocks
9
+ delegate :options, to: :@definition
9
10
 
10
- def initialize(admin)
11
- @admin = admin
12
- @blocks = []
11
+ def initialize(definition, context)
12
+ @definition = definition
13
+ @scopes = @definition.evaluate(context)
13
14
  end
14
15
 
15
- def append(&block)
16
- @blocks << Block.new(admin, &block)
16
+ def classes
17
+ [
18
+ 'scopes',
19
+ ('grouped' if grouped?),
20
+ layout_class,
21
+ options[:class]
22
+ ].compact
17
23
  end
18
24
 
19
- def evaluate(context)
20
- @blocks.map { |block| block.scopes(context) }.flatten.index_by(&:name)
25
+ def each(&block)
26
+ @scopes.values.each(&block)
27
+ end
28
+
29
+ def grouped?
30
+ options[:group] != false && any?(&:group)
31
+ end
32
+
33
+ def grouped
34
+ if grouped?
35
+ group_by(&:group)
36
+ else
37
+ { nil => @scopes.values.flatten }
38
+ end
39
+ end
40
+
41
+ def active(params)
42
+ select { |s| s.active?(params) }
43
+ end
44
+
45
+ private
46
+ def layout_class
47
+ "columns" if %w(column columns).include?(options[:layout].to_s)
21
48
  end
22
49
  end
23
50
  end
@@ -1,16 +1,17 @@
1
1
  module Trestle
2
2
  class Scopes
3
3
  class Block
4
- attr_reader :block, :admin
4
+ attr_reader :block
5
5
 
6
- def initialize(admin=nil, &block)
7
- @admin = admin
6
+ def initialize(&block)
8
7
  @block = block
9
8
  end
10
9
 
10
+ # Evaluates the scope block within the given admin context
11
+ # and returns an array of the scopes that were defined.
11
12
  def scopes(context)
12
- context = Evaluator.new(@admin, context)
13
- context.instance_exec(@admin, &block)
13
+ context = Evaluator.new(context)
14
+ context.instance_exec(context, &block)
14
15
  context.scopes
15
16
  end
16
17
 
@@ -19,8 +20,8 @@ module Trestle
19
20
 
20
21
  attr_reader :scopes
21
22
 
22
- def initialize(admin, context=nil)
23
- @admin, @context = admin, context
23
+ def initialize(context=nil)
24
+ @context = context
24
25
  @scopes = []
25
26
  end
26
27
 
@@ -30,7 +31,7 @@ module Trestle
30
31
  scope = nil
31
32
  end
32
33
 
33
- scopes << Scope.new(@admin, name, options, &(scope || block))
34
+ scopes << Scope.new(@context, name, options, &(scope || block))
34
35
  end
35
36
  end
36
37
  end
@@ -0,0 +1,22 @@
1
+ module Trestle
2
+ class Scopes
3
+ class Definition
4
+ attr_reader :blocks, :options
5
+
6
+ def initialize
7
+ @blocks = []
8
+ @options = {}
9
+ end
10
+
11
+ def append(&block)
12
+ @blocks << Block.new(&block)
13
+ end
14
+
15
+ # Evaluates each of the scope blocks within the given admin context
16
+ # and returns a hash of Scope objects keyed by the scope name.
17
+ def evaluate(context)
18
+ @blocks.map { |block| block.scopes(context) }.flatten.index_by(&:name)
19
+ end
20
+ end
21
+ end
22
+ end
@@ -8,11 +8,15 @@ module Trestle
8
8
  end
9
9
 
10
10
  def to_param
11
- name
11
+ name unless default?
12
12
  end
13
13
 
14
14
  def label
15
- @options[:label] || I18n.t("admin.scopes.#{name}", default: name.to_s.humanize.titleize)
15
+ @options[:label] || @admin.t("scopes.#{name}", default: name.to_s.humanize.titleize)
16
+ end
17
+
18
+ def group
19
+ @options[:group]
16
20
  end
17
21
 
18
22
  def default?
data/lib/trestle/tab.rb CHANGED
@@ -1,3 +1,5 @@
1
+ require "action_view/helpers"
2
+
1
3
  module Trestle
2
4
  class Tab
3
5
  include ActionView::Helpers::TagHelper
data/lib/trestle/table.rb CHANGED
@@ -1,22 +1,27 @@
1
1
  module Trestle
2
2
  class Table
3
- extend ActiveSupport::Autoload
4
-
5
- autoload :Automatic
6
- autoload :Builder
7
- autoload :Column
8
- autoload :ActionsColumn
9
- autoload :SelectColumn
10
- autoload :Row
11
-
12
- attr_reader :columns, :options
3
+ require_relative "table/automatic"
4
+ require_relative "table/builder"
5
+ require_relative "table/column"
6
+ require_relative "table/actions_column"
7
+ require_relative "table/select_column"
8
+ require_relative "table/row"
9
+
10
+ attr_reader :columns
13
11
  attr_writer :row
12
+ attr_accessor :options
14
13
 
15
14
  def initialize(options={})
16
15
  @options = options
17
16
  @columns = []
18
17
  end
19
18
 
19
+ def with_options(opts={})
20
+ dup.tap do |table|
21
+ table.options = options.merge(opts)
22
+ end
23
+ end
24
+
20
25
  def admin
21
26
  Trestle.lookup(options[:admin]) if options.key?(:admin)
22
27
  end
@@ -38,7 +43,7 @@ module Trestle
38
43
  end
39
44
 
40
45
  def row
41
- @row || Row.new(self)
46
+ @row || Row.new
42
47
  end
43
48
 
44
49
  class Renderer
@@ -49,7 +54,7 @@ module Trestle
49
54
  end
50
55
 
51
56
  def row
52
- @row ||= @table.row.renderer(@template)
57
+ @row ||= @table.row.renderer(table: @table, template: @template)
53
58
  end
54
59
 
55
60
  def columns
@@ -1,10 +1,10 @@
1
1
  module Trestle
2
2
  class Table
3
3
  class ActionsColumn
4
- attr_reader :table, :toolbar, :options
4
+ attr_reader :toolbar, :options
5
5
 
6
- def initialize(table, options={}, &block)
7
- @table, @options = table, options
6
+ def initialize(options={}, &block)
7
+ @options = options
8
8
  @toolbar = Toolbar.new(ActionsBuilder)
9
9
 
10
10
  if block_given?
@@ -14,8 +14,8 @@ module Trestle
14
14
  end
15
15
  end
16
16
 
17
- def renderer(template)
18
- Renderer.new(self, template)
17
+ def renderer(table:, template:)
18
+ Renderer.new(self, table: table, template: template)
19
19
  end
20
20
 
21
21
  def default_actions
@@ -71,7 +71,7 @@ module Trestle
71
71
  end
72
72
 
73
73
  def content(instance)
74
- @template.render_toolbar(@column.toolbar, instance, table.admin)
74
+ @template.render_toolbar(@column.toolbar, instance, @table.admin)
75
75
  end
76
76
  end
77
77
  end
@@ -13,15 +13,15 @@ module Trestle
13
13
  admin.default_table_attributes.map.with_index do |attribute, index|
14
14
  case attribute.type
15
15
  when :association
16
- Column.new(self, attribute.association_name, sort: false)
16
+ Column.new(attribute.association_name, sort: false)
17
17
  else
18
- Column.new(self, attribute.name, link: index.zero?, align: (:center if [:datetime, :boolean].include?(attribute.type)))
18
+ Column.new(attribute.name, link: index.zero?, align: (:center if [:datetime, :boolean].include?(attribute.type)))
19
19
  end
20
20
  end
21
21
  end
22
22
 
23
23
  def actions_column
24
- ActionsColumn.new(self)
24
+ ActionsColumn.new
25
25
  end
26
26
  end
27
27
  end