Class: Queries::Documentation::Filter

Inherits:
Query::Filter show all
Includes:
Concerns::Polymorphic
Defined in:
lib/queries/documentation/filter.rb

Constant Summary collapse

PARAMS =
[
  *::Documentation.related_foreign_keys.map(&:to_sym), 
  :documentation_id,
  :documentation_object_id,
  :documentation_object_type,
  documentation_id: [],
].freeze

Constants inherited from Query::Filter

Query::Filter::FILTER_QUERIES, Query::Filter::SUBQUERIES

Instance Attribute Summary collapse

Attributes inherited from Query::Filter

#api, #asserted_distribution_query, #biological_association_query, #biological_associations_graph_query, #collecting_event_query, #collection_object_query, #content_query, #controlled_vocabulary_term_query, #data_attribute_query, #depiction_query, #descriptor_query, #document_query, #dwc_occurrence_query, #extract_query, #field_occurrence_query, #image_query, #loan_query, #object_global_id, #observation_query, #order_by, #otu_query, #page, #paginate, #params, #per, #person_query, #project_id, #recent, #recent_target, #taxon_name_query, #venn, #venn_mode

Attributes inherited from Query

#query_string, #terms

Instance Method Summary collapse

Methods inherited from Query::Filter

#all, #all_and_clauses, #all_merge_clauses, #annotator_and_clauses, #annotator_merge_clauses, annotator_params, api_except_params, api_excluded_params, #apply_venn, #attribute_exact_facet, base_filter, base_query_name, base_query_to_h, #deep_permit, included_annotator_facets, instantiated_base_filter, inverted_subqueries, #merge_clauses, #model_id_facet, #object_global_id_facet, #only_project?, params, #permitted_params, #process_url_into_params, #project_id_facet, query_name, #query_name, #set_nested_queries, #shared_and_clauses, #subquery_vector, #target_and_clauses, #venn_query

Methods inherited from Query

#alphabetic_strings, #alphanumeric_strings, base_name, #base_name, #base_query, #build_terms, #cached_facet, #end_wildcard, #levenshtein_distance, #match_ordered_wildcard_pieces_in_cached, #no_terms?, referenced_klass, #referenced_klass, #referenced_klass_except, #referenced_klass_intersection, #referenced_klass_union, #start_and_end_wildcard, #start_wildcard, #table, #wildcard_pieces

Constructor Details

#initialize(query_params) ⇒ Filter

Returns a new instance of Filter.



23
24
25
26
27
28
29
30
# File 'lib/queries/documentation/filter.rb', line 23

def initialize(query_params)
  super
  @documentation_id = params[:documentation_id]
  @documentation_object_id = params[:documentation_object_id]
  @documentation_object_type = params[:documentation_object_type]

  set_polymorphic_params(params)
end

Instance Attribute Details

#documentation_idObject

Returns the value of attribute documentation_id.



16
17
18
# File 'lib/queries/documentation/filter.rb', line 16

def documentation_id
  @documentation_id
end

#documentation_object_idObject

Returns the value of attribute documentation_object_id.



18
19
20
# File 'lib/queries/documentation/filter.rb', line 18

def documentation_object_id
  @documentation_object_id
end

#documentation_object_typeObject

Returns the value of attribute documentation_object_type.



20
21
22
# File 'lib/queries/documentation/filter.rb', line 20

def documentation_object_type
  @documentation_object_type
end

Instance Method Details

#and_clausesObject

If we add merge_clauses then we likely have to deal with excluding the ‘xml` field from distinct+intersection calls via a custom base_query field.



58
59
60
61
62
63
# File 'lib/queries/documentation/filter.rb', line 58

def and_clauses
  [
    documentation_object_id_facet,
    documentation_object_type_facet
  ]
end

#documentation_object_id_facetObject



49
50
51
52
# File 'lib/queries/documentation/filter.rb', line 49

def documentation_object_id_facet
  return nil if documentation_object_id.empty?
  table[:documentation_object_id].in(documentation_object_id)
end

#documentation_object_type_facetObject



44
45
46
47
# File 'lib/queries/documentation/filter.rb', line 44

def documentation_object_type_facet
  return nil if documentation_object_type.empty?
  table[:documentation_object_type].in(documentation_object_type)
end