Class: AdminIt::Resource

Inherits:
Object
  • Object
show all
Extended by:
ExtendIt::Class, ExtendIt::Dsl
Includes:
FieldsHolder, FiltersHolder, ExtendIt::Asserts, ExtendIt::Callbacks
Defined in:
lib/admin_it/resource.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

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] }]

    @menu = menu == true
    @destroyable = destroyable == true
    @plural = name.to_s.pluralize # !POTABLE
    @default_context = nil
  end
end

Instance Attribute Details

#entity_classObject (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

Returns the value of attribute menu.



54
55
56
# File 'lib/admin_it/resource.rb', line 54

def menu
  @menu
end

#nameObject (readonly)

Returns the value of attribute name.



54
55
56
# File 'lib/admin_it/resource.rb', line 54

def name
  @name
end

#pluralObject (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_pathObject



188
189
190
# File 'lib/admin_it/resource.rb', line 188

def collection_path
  AdminIt::Engine.routes.url_helpers.send("#{plural}_path")
end

#collectionsObject



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

#contextsObject



131
132
133
# File 'lib/admin_it/resource.rb', line 131

def contexts
  @contexts.values
end

#contexts_namesObject



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_controllerObject



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

Returns:

  • (Boolean)


184
185
186
# File 'lib/admin_it/resource.rb', line 184

def destroyable?
  @destroyable
end

#display_nameObject



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

#singlesObject



200
201
202
# File 'lib/admin_it/resource.rb', line 200

def singles
  contexts.select { |c| c.single? }
end