Class: AdminIt::Filter
Constant Summary
collapse
- REGEXP =
/
(?<=\A|[,;|])\s*
(?<full>
(?<action>[!+\-])?
(?<name>[a-zA-Z_][a-zA-Z0-9_]*)
(?:\((?<params>[^)]*)\))?
)
\s*(?=[,;|]|\z)
/x
- ARGUMENT_REGEXP =
/
(?<=\A|[,;|])\s*
(?:
(?:(?<action>[+\-])|(?:(?<option>[a-zA-Z_][a-zA-Z0-9_]*)\s*:\s*))?
(?<token>
(?:'(?:[^\\']|\\.)*')|
(?:"(?:[^\\"]|\\.)*")|
(?:[^,;|\s]+)
)
)
\s*(?=[,;|]|\z)
/x
Class Attribute Summary collapse
Class Method Summary
collapse
Instance Method Summary
collapse
Constructor Details
#initialize ⇒ Filter
Returns a new instance of Filter.
95
96
97
|
# File 'lib/admin_it/filters/filter.rb', line 95
def initialize
run_callbacks :initialize
end
|
Class Attribute Details
.filter_name ⇒ Object
Returns the value of attribute filter_name.
44
45
46
|
# File 'lib/admin_it/filters/filter.rb', line 44
def filter_name
@filter_name
end
|
.resource ⇒ Object
Returns the value of attribute resource.
44
45
46
|
# File 'lib/admin_it/filters/filter.rb', line 44
def resource
@resource
end
|
Class Method Details
.apply(str, filters, filter_classes) ⇒ Object
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
# File 'lib/admin_it/filters/filter.rb', line 78
def self.apply(str, filters, filter_classes)
list = str.scan(Filter::REGEXP)
filters.clear if list.all? { |_, act, _, _| act.nil? || act.empty? }
list.each do |full, action, name, params|
name = name.to_sym
if action == '-'
filters.delete(name)
elsif action == '!'
filters[name].load(params) if filters.key?(name)
else
filters[name] = Filter.load(full, filter_classes)
end
end
end
|
.attr_checker(*names) ⇒ Object
Originally defined in module
ExtendIt::Base
.call_inherited(method_name, *args, base_first: false, &block) ⇒ Object
Originally defined in module
ExtendIt::Base
.class_attr_reader(*attrs) ⇒ Object
Originally defined in module
ExtendIt::Base
.create(name, _resource) ⇒ Object
63
64
65
|
# File 'lib/admin_it/filters/filter.rb', line 63
def self.create(name, _resource)
create_class(name, _resource)
end
|
.display_name=(value) ⇒ Object
Originally defined in module
DisplayableName
.dsl_eval(&block) ⇒ Object
Originally defined in module
ExtendIt::Dsl
.inherited_class_reader(*names) ⇒ Object
Originally defined in module
ExtendIt::Base
.load(str, filter_classes) ⇒ Object
67
68
69
70
71
72
73
74
75
76
|
# File 'lib/admin_it/filters/filter.rb', line 67
def self.load(str, filter_classes)
m = REGEXP.match(str)
return nil if m.nil? || m[:action] == '-'
name = m[:name].to_sym
filter_class = filter_classes.find { |f| f.filter_name == name }
return nil if filter_class.nil?
filter = filter_class.new
filter.load(m[:params])
filter
end
|
Instance Method Details
#apply(collection) ⇒ Object
126
127
128
|
# File 'lib/admin_it/filters/filter.rb', line 126
def apply(collection)
collection
end
|
#dump ⇒ Object
103
104
105
106
107
108
109
110
111
112
113
114
115
|
# File 'lib/admin_it/filters/filter.rb', line 103
def dump
args = []
opts = {}
result = ''
run_callbacks :save, arguments: { arguments: args, options: opts } do
result = "#{name}"
unless args.empty? && opts.empty?
args.concat(opts.map { |k, v| "#{k}:#{v}" })
result << "(#{args.join(',')})"
end
end
result
end
|
#load(str) ⇒ Object
117
118
119
120
121
122
123
124
|
# File 'lib/admin_it/filters/filter.rb', line 117
def load(str)
return if str.nil?
args = parse_arguments(str)
unless args.empty?
opts = args.
run_callbacks :load, arguments: { arguments: args, options: opts }
end
end
|
#name ⇒ Object
99
100
101
|
# File 'lib/admin_it/filters/filter.rb', line 99
def name
@name ||= self.class.filter_name
end
|
#run_callbacks(*names, arguments: [], original_context: false) ⇒ Object
Originally defined in module
ExtendIt::Callbacks