Class: Collection::Base
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.
Instance Attribute Summary
#reverse_match_service
Class Method Summary
collapse
Instance Method Summary
collapse
#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
#distinct_versions
#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
|
.edit_link_partial_name ⇒ Object
59
60
61
|
# File 'app/models/collection/base.rb', line 59
def self.edit_link_partial_name
'partials/collection/edit_link_base'
end
|
.new_link_partial_name ⇒ Object
63
64
65
|
# File 'app/models/collection/base.rb', line 63
def self.new_link_partial_name
'partials/collection/new_link_base'
end
|
.tops ⇒ Object
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_info ⇒ Object
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_subcollections ⇒ Object
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
|
#concepts ⇒ Object
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_origins ⇒ Object
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_collections ⇒ Object
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_origins ⇒ Object
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_concepts ⇒ Object
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
|
#label ⇒ Object
83
84
85
|
# File 'app/models/collection/base.rb', line 83
def label
pref_label
end
|
#regenerate_collection_members ⇒ Object
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_members ⇒ Object
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? 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
|
#subcollections ⇒ Object
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_param ⇒ Object
79
80
81
|
# File 'app/models/collection/base.rb', line 79
def to_param
origin
end
|