Class: Collection::Base

Inherits:
Concept::Base show all
Defined in:
app/models/collection/base.rb

Overview

Copyright 2011-2013 innoQ Deutschland GmbH

Licensed under the Apache License, Version 2.0 (the “License”); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Direct Known Subclasses

SKOS::Base

Instance Attribute Summary

Attributes inherited from Concept::Base

#reverse_match_service

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Concept::Base

#associated_objects_in_editing_mode, broader_tops, #concept_relations_by_id, #concept_relations_by_id=, #concept_relations_by_id_and_rank, for_dashboard, inline_partial_name, #labelings_by_text, #labelings_by_text=, #labels_for_labeling_class_and_language, #matches_for_class, #notations_for_class, #notes_for_class, #pref_label, #related_concepts_for_relation_class, #to_s, with_associations, with_pref_labels

Methods included from FirstLevelObjectValidations

#distinct_versions

Methods included from Concept::Validations

#exclusive_top_term, #pref_label_in_primary_thesaurus_language, #rooted_top_terms, #unique_pref_label, #unique_pref_label_language, #valid_rank_for_ranked_relations

Methods included from Versioning

#branch, #disable_validations_for_publishing, #editor_selectable?, #enable_validations_for_publishing, #in_review?, #lock_by_user, #locked?, #publish, #publish!, #publishable?, #published?, #state, #to_review, #unlock, #unpublish, #validatable_for_publishing?, #with_validations_for_publishing

Class Method Details

.by_label_value(val) ⇒ Object



45
46
47
# File 'app/models/collection/base.rb', line 45

def self.by_label_value(val)
  includes(:labels).merge(Label::Base.by_query_value(val))
end

.by_origin(origin) ⇒ Object



41
42
43
# File 'app/models/collection/base.rb', line 41

def self.by_origin(origin)
  where(origin: origin)
end

.by_parent_id(parent_id) ⇒ Object



54
55
56
57
# File 'app/models/collection/base.rb', line 54

def self.by_parent_id(parent_id)
  includes(:parent_collection_members).
      where(Collection::Member::Base.arel_table[:collection_id].eq(parent_id))
end


59
60
61
# File 'app/models/collection/base.rb', line 59

def self.edit_link_partial_name
  'partials/collection/edit_link_base'
end


63
64
65
# File 'app/models/collection/base.rb', line 63

def self.new_link_partial_name
  'partials/collection/new_link_base'
end

.topsObject



49
50
51
52
# File 'app/models/collection/base.rb', line 49

def self.tops
  includes(:parent_collection_members).
      where("#{Collection::Member::Base.table_name}.target_id IS NULL")
end

Instance Method Details

#additional_infoObject



75
76
77
# File 'app/models/collection/base.rb', line 75

def additional_info
  concepts.count
end

#build_rdf_subject(&block) ⇒ Object



87
88
89
# File 'app/models/collection/base.rb', line 87

def build_rdf_subject(&block)
  IqRdf.build_uri(self.origin, IqRdf::Skos::build_uri('Collection'), &block)
end

#circular_subcollectionsObject

This only prevent circles of length 2. TODO: This should be a real circle detector (but still performant) or be removed (seems to me like the better idea).



160
161
162
163
164
165
166
167
# File 'app/models/collection/base.rb', line 160

def circular_subcollections
  Iqvoc::Collection.base_class.by_origin(@member_collection_origins).includes(members: :target).each do |subcollection|
    if subcollection.subcollections.include?(self)
      errors.add(:base,
        I18n.t('txt.controllers.collections.circular_error', label: subcollection.pref_label))
    end
  end
end

#conceptsObject



71
72
73
# File 'app/models/collection/base.rb', line 71

def concepts
  members.map(&:target).select { |m| !m.is_a?(::Collection::Base) }
end

#inline_member_collection_originsObject



113
114
115
# File 'app/models/collection/base.rb', line 113

def inline_member_collection_origins
  @member_collection_origins || subcollections.map(&:origin).uniq
end

#inline_member_collection_origins=(origins) ⇒ Object



108
109
110
111
# File 'app/models/collection/base.rb', line 108

def inline_member_collection_origins=(origins)
  @member_collection_origins = origins.to_s.
      split(Iqvoc::InlineDataHelper::SPLITTER).map(&:strip)
end

#inline_member_collectionsObject



117
118
119
120
121
122
123
# File 'app/models/collection/base.rb', line 117

def inline_member_collections
  if @member_collection_origins
    Collection::Base.where(origin: @member_collection_origins)
  else
    subcollections
  end
end

#inline_member_concept_originsObject



96
97
98
# File 'app/models/collection/base.rb', line 96

def inline_member_concept_origins
  @member_concept_origins || concepts.map { |m| m.origin }.uniq
end

#inline_member_concept_origins=(origins) ⇒ Object



91
92
93
94
# File 'app/models/collection/base.rb', line 91

def inline_member_concept_origins=(origins)
  @member_concept_origins = origins.to_s.
      split(Iqvoc::InlineDataHelper::SPLITTER).map(&:strip)
end

#inline_member_conceptsObject



100
101
102
103
104
105
106
# File 'app/models/collection/base.rb', line 100

def inline_member_concepts
  if @member_concept_origins
    Concept::Base.editor_selectable.where(origin: @member_concept_origins)
  else
    concepts.select{ |c| c.editor_selectable? }
  end
end

#labelObject



83
84
85
# File 'app/models/collection/base.rb', line 83

def label
  pref_label
end

#regenerate_collection_membersObject



151
152
153
# File 'app/models/collection/base.rb', line 151

def regenerate_collection_members
  regenerate_members(Collection::Base, @member_collection_origins)
end

#regenerate_concept_membersObject



147
148
149
# File 'app/models/collection/base.rb', line 147

def regenerate_concept_members
  regenerate_members(Concept::Base, @member_concept_origins)
end

#regenerate_members(target_class, target_origins) ⇒ Object



125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
# File 'app/models/collection/base.rb', line 125

def regenerate_members(target_class, target_origins)
  return if target_origins.nil? # There is nothing to do
  existing = self.members.includes(:target)
  existing = if target_class <= Collection::Base
    existing.select { |m| m.target.is_a?(Collection::Base) }
  else
    existing.reject { |m| m.target.is_a?(Collection::Base) }
  end
  new = []
  target_origins.each do |new_origin|
    member = existing.find{ |m| m.target.origin == new_origin }
    unless member
      c = target_class.by_origin(new_origin).first
      member = Iqvoc::Collection.member_class.create(collection: self, target: c) if c
    end
    new << member if member
  end
  (existing - new).each do |m|
    m.destroy
  end
end

#subcollectionsObject



67
68
69
# File 'app/models/collection/base.rb', line 67

def subcollections
  members.map(&:target).select { |m| m.is_a?(::Collection::Base) }
end

#to_paramObject



79
80
81
# File 'app/models/collection/base.rb', line 79

def to_param
  origin
end