Class: AdminIt::Resource
- Inherits:
-
Object
- Object
- AdminIt::Resource
- Extended by:
- ExtendIt::Class, ExtendIt::Dsl
- Includes:
- FieldsHolder, FiltersHolder, ExtendIt::Asserts, ExtendIt::Callbacks
- Defined in:
- lib/admin_it/resource.rb
Instance Attribute Summary collapse
-
#entity_class ⇒ Object
readonly
Returns the value of attribute entity_class.
-
#menu ⇒ Object
readonly
Returns the value of attribute menu.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
-
#plural ⇒ Object
readonly
Returns the value of attribute plural.
Class Method Summary collapse
- .call_inherited(method_name, *args, base_first: false, &block) ⇒ Object extended from ExtendIt::Class
- .class_attr_reader(*attrs) ⇒ Object extended from ExtendIt::Class
- .dsl_accessor(*names, default: nil, &setter) ⇒ Object extended from ExtendIt::Dsl
- .dsl_block(*names) ⇒ Object extended from ExtendIt::Dsl
- .dsl_boolean(*names, default: true) ⇒ Object extended from ExtendIt::Dsl
- .dsl_use_hash(hash_name) ⇒ Object extended from ExtendIt::Dsl
- .inherited_class_reader(*names) ⇒ Object extended from ExtendIt::Class
Instance Method Summary collapse
- #[](name) ⇒ Object
- #collection(&block) ⇒ Object
- #collection_path ⇒ Object
- #collections ⇒ Object
- #context(*names, context_class: nil, &block) ⇒ Object
- #contexts ⇒ Object
- #contexts_names ⇒ Object
- #default_context(value = nil) ⇒ Object
- #define_controller ⇒ Object
- #destroyable? ⇒ Boolean
- #display_name ⇒ Object
- #field(*names, field_class: nil, &block) ⇒ Object
- #fields(scope: :visible) ⇒ Object included from FieldsHolder
- #filter(name, filter_class: nil, &block) ⇒ Object
- #filters(scope: :all) ⇒ Object included from FiltersHolder
- #hide_fields(*names) ⇒ Object included from FieldsHolder
-
#initialize(name, entity_class = nil, menu: true, destroyable: true, auto_filters: true) ⇒ Resource
constructor
A new instance of Resource.
- #run_callbacks(*names, arguments: [], original_context: false) ⇒ Object included from ExtendIt::Callbacks
- #show_fields(*names) ⇒ Object included from FieldsHolder
- #single(&block) ⇒ Object
- #single_path(entity) ⇒ Object
- #singles ⇒ Object
Constructor Details
#initialize(name, entity_class = nil, menu: true, destroyable: true, auto_filters: true) ⇒ Resource
Returns a new instance of Resource.
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 |
# File 'lib/admin_it/resource.rb', line 61 def initialize( name, entity_class = nil, menu: true, destroyable: true, auto_filters: true ) assert_symbol(:name) @name, @entity_class = name, entity_class if @entity_class.nil? begin @entity_class = Object.const_get(name.to_s.camelize) # !PORTABLE rescue NameError fail ArgumentError, "Can't find entity class for #{name}" end end import_data_module run_callbacks :initialize do @fields = Hash[default_fields.map { |f| [f.field_name, f] }] @filters = if auto_filters Hash[default_filters.map { |f| [f.filter_name, f] }] else {} end @contexts = Hash[default_contexts.map { |c| [c.context_name, c] }] = == true @destroyable = destroyable == true @plural = name.to_s.pluralize # !POTABLE @default_context = nil end end |
Instance Attribute Details
#entity_class ⇒ Object (readonly)
Returns the value of attribute entity_class.
54 55 56 |
# File 'lib/admin_it/resource.rb', line 54 def entity_class @entity_class end |
#menu ⇒ Object (readonly)
Returns the value of attribute menu.
54 55 56 |
# File 'lib/admin_it/resource.rb', line 54 def end |
#name ⇒ Object (readonly)
Returns the value of attribute name.
54 55 56 |
# File 'lib/admin_it/resource.rb', line 54 def name @name end |
#plural ⇒ Object (readonly)
Returns the value of attribute plural.
54 55 56 |
# File 'lib/admin_it/resource.rb', line 54 def plural @plural end |
Class Method Details
.call_inherited(method_name, *args, base_first: false, &block) ⇒ Object Originally defined in module ExtendIt::Class
.class_attr_reader(*attrs) ⇒ Object Originally defined in module ExtendIt::Class
.dsl_accessor(*names, default: nil, &setter) ⇒ Object Originally defined in module ExtendIt::Dsl
.dsl_block(*names) ⇒ Object Originally defined in module ExtendIt::Dsl
.dsl_boolean(*names, default: true) ⇒ Object Originally defined in module ExtendIt::Dsl
.dsl_use_hash(hash_name) ⇒ Object Originally defined in module ExtendIt::Dsl
.inherited_class_reader(*names) ⇒ Object Originally defined in module ExtendIt::Class
Instance Method Details
#[](name) ⇒ Object
112 113 114 115 |
# File 'lib/admin_it/resource.rb', line 112 def [](name) assert_symbol(:name) @contexts[name] end |
#collection(&block) ⇒ Object
149 150 151 152 153 154 |
# File 'lib/admin_it/resource.rb', line 149 def collection(&block) return unless block_given? contexts.select { |c| c.collection? }.each do |c| c.instance_eval(&block) end end |
#collection_path ⇒ Object
188 189 190 |
# File 'lib/admin_it/resource.rb', line 188 def collection_path AdminIt::Engine.routes.url_helpers.send("#{plural}_path") end |
#collections ⇒ Object
196 197 198 |
# File 'lib/admin_it/resource.rb', line 196 def collections contexts.select { |c| c.collection? } end |
#context(*names, context_class: nil, &block) ⇒ Object
117 118 119 120 121 122 123 124 125 126 127 128 129 |
# File 'lib/admin_it/resource.rb', line 117 def context(*names, context_class: nil, &block) names.ensure_symbols.each do |name| if @contexts.key?(name) context = @contexts[name] else if context_class.nil? || !context_class <= Context context_class = Context end context = @contexts[name] = context_class.create(name, entity_class) end context.instance_eval(&block) if block_given? end end |
#contexts ⇒ Object
131 132 133 |
# File 'lib/admin_it/resource.rb', line 131 def contexts @contexts.values end |
#contexts_names ⇒ Object
176 177 178 |
# File 'lib/admin_it/resource.rb', line 176 def contexts_names @contexts.map(&:context_name) end |
#default_context(value = nil) ⇒ Object
163 164 165 166 167 168 169 170 171 172 173 174 |
# File 'lib/admin_it/resource.rb', line 163 def default_context(value = nil) if value.nil? return @default_context unless @default_context.nil? if collections.size > 0 @default_context = collections.first.context_name elsif singles.size > 0 @default_context = singles.first.context_name end else @default_context = @contexts.keys.include?(value) ? value : default_context end end |
#define_controller ⇒ Object
204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 |
# File 'lib/admin_it/resource.rb', line 204 def define_controller c_name = "#{name.to_s.camelize}Controller" # !POTABLE resource = self c_class = Class.new(AdminIt.config.controller) do @resource = resource include AdminIt::Controller resource.contexts.each do |_context| define_method(_context.context_name) { load_context(_context) } if _context < SavableSingleContext define_method _context.save_action do load_context(_context) { context.save_entity(self) } end end end if resource.destroyable? define_method :destroy do load_context(resource[:show]) { context.destroy_entity(self) } end end end AdminIt.const_set(c_name, c_class) contexts.each { |c| c.controller_class = c_class } end |
#destroyable? ⇒ Boolean
184 185 186 |
# File 'lib/admin_it/resource.rb', line 184 def destroyable? @destroyable end |
#display_name ⇒ Object
180 181 182 |
# File 'lib/admin_it/resource.rb', line 180 def display_name plural.split('_').map { |s| s.capitalize }.join(' ') end |
#field(*names, field_class: nil, &block) ⇒ Object
100 101 102 103 104 105 106 107 108 109 110 |
# File 'lib/admin_it/resource.rb', line 100 def field(*names, field_class: nil, &block) names.ensure_symbols.each do |name| if @fields.key?(name) field = @fields[name] else field_class = Field if field_class.nil? || !field_class <= Field field = @fields[name] = field_class.create(name, entity_class) end field.instance_eval(&block) if block_given? end end |
#fields(scope: :visible) ⇒ Object Originally defined in module FieldsHolder
#filter(name, filter_class: nil, &block) ⇒ Object
137 138 139 140 141 142 143 144 145 |
# File 'lib/admin_it/resource.rb', line 137 def filter(name, filter_class: nil, &block) assert_symbol(:name) filter = @filters[name] if filter.nil? filter_class = Filter if filter_class.nil? || !filter_class <= Filter filter = @filters[name] = filter_class.create(name, self) end filter.instance_eval(&block) if block_given? end |
#filters(scope: :all) ⇒ Object Originally defined in module FiltersHolder
#hide_fields(*names) ⇒ Object Originally defined in module FieldsHolder
#run_callbacks(*names, arguments: [], original_context: false) ⇒ Object Originally defined in module ExtendIt::Callbacks
#show_fields(*names) ⇒ Object Originally defined in module FieldsHolder
#single(&block) ⇒ Object
156 157 158 159 160 161 |
# File 'lib/admin_it/resource.rb', line 156 def single(&block) return unless block_given? contexts.select { |c| c.single? }.each do |c| c.instance_eval(&block) end end |
#single_path(entity) ⇒ Object
192 193 194 |
# File 'lib/admin_it/resource.rb', line 192 def single_path(entity) AdminIt::Engine.routes.url_helpers.send("#{name}_path", entity) end |
#singles ⇒ Object
200 201 202 |
# File 'lib/admin_it/resource.rb', line 200 def singles contexts.select { |c| c.single? } end |