Class: Queries::Documentation::Filter
- Inherits:
-
Query::Filter
- Object
- Query
- Query::Filter
- Queries::Documentation::Filter
- Includes:
- Concerns::Polymorphic
- Defined in:
- lib/queries/documentation/filter.rb
Constant Summary collapse
- PARAMS =
[ *::Documentation..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
-
#documentation_id ⇒ Object
Returns the value of attribute documentation_id.
-
#documentation_object_id ⇒ Object
Returns the value of attribute documentation_object_id.
-
#documentation_object_type ⇒ Object
Returns the value of attribute documentation_object_type.
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, #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
Instance Method Summary collapse
-
#and_clauses ⇒ Object
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.
- #documentation_object_id_facet ⇒ Object
- #documentation_object_type_facet ⇒ Object
-
#initialize(query_params) ⇒ Filter
constructor
A new instance of Filter.
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_id ⇒ Object
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_id ⇒ Object
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_type ⇒ Object
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_clauses ⇒ Object
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_facet ⇒ Object
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_facet ⇒ Object
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 |