Sha256: b9bb3c753a46919bddfb64dcfa7c439243897494c861181973d4fee07a9af3fa
Contents?: true
Size: 1.47 KB
Versions: 6
Compression:
Stored size: 1.47 KB
Contents
module ActiveAdmin class Scope attr_reader :name, :scope_method, :id, :scope_block, :display_if_block # Create a Scope # # Examples: # # Scope.new(:published) # # => Scope with name 'Published' and scope method :published # # Scope.new('Published', :public) # # => Scope with name 'Published' and scope method :public # # Scope.new('Published', :public, :if => proc { current_admin_user.can?( :manage, active_admin_config.resource_class ) } ) { |articles| articles.where(:published => true) } # # => Scope with name 'Published' and scope method :public, optionally displaying the scope per the :if block, using a block # # Scope.new('Published') { |articles| articles.where(:published => true) } # # => Scope with name 'Published' using a block to scope # def initialize(name, method = nil, options = {}, &block) @name = name.is_a?( String ) ? name : name.to_s.titleize @scope_method = method # Scope ':all' means no scoping @scope_method ||= name.to_sym unless name.to_sym == :all @id = @name.gsub(' ', '').underscore if block_given? @scope_method = nil @scope_block = block end @display_if_block = options[:if] end # Returns the display if block. If the block was not explicitly defined # a default block always returning true will be returned. def display_if_block @display_if_block || proc{ true } end end end
Version data entries
6 entries across 6 versions & 2 rubygems