Module: Concept::Validations
Instance Method Summary collapse
-
#exclusive_top_term ⇒ Object
top term and broader relations are mutually exclusive.
- #pref_label_in_primary_thesaurus_language ⇒ Object
-
#rooted_top_terms ⇒ Object
top terms must never be used as descendants (narrower relation targets) NB: for top terms themselves, this is covered by ‘ensure_exclusive_top_term`.
- #unique_pref_label ⇒ Object
- #unique_pref_label_language ⇒ Object
- #valid_rank_for_ranked_relations ⇒ Object
Instance Method Details
#exclusive_top_term ⇒ Object
top term and broader relations are mutually exclusive
17 18 19 20 21 22 23 |
# File 'app/models/concept/validations.rb', line 17 def exclusive_top_term if validatable_for_publishing? if top_term && broader_relations.any? errors.add :base, I18n.t('txt.models.concept.top_term_exclusive_error') end end end |
#pref_label_in_primary_thesaurus_language ⇒ Object
36 37 38 39 40 41 42 43 44 45 |
# File 'app/models/concept/validations.rb', line 36 def pref_label_in_primary_thesaurus_language if validatable_for_publishing? labels = pref_labels.select{ |l| l.published? } if labels.none? errors.add :base, I18n.t('txt.models.concept.no_pref_label_error') elsif not labels.map(&:language).map(&:to_s).include?(Iqvoc::Concept.pref_labeling_languages.first.to_s) errors.add :base, I18n.t('txt.models.concept.main_pref_label_language_missing_error') end end end |
#rooted_top_terms ⇒ Object
top terms must never be used as descendants (narrower relation targets) NB: for top terms themselves, this is covered by ‘ensure_exclusive_top_term`
27 28 29 30 31 32 33 34 |
# File 'app/models/concept/validations.rb', line 27 def rooted_top_terms if validatable_for_publishing? if narrower_relations.includes(:target). # XXX: inefficient? select { |rel| rel.target && rel.target.top_term? }.any? errors.add :base, I18n.t('txt.models.concept.top_term_rooted_error') end end end |
#unique_pref_label ⇒ Object
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 |
# File 'app/models/concept/validations.rb', line 63 def unique_pref_label if validatable_for_publishing? # checks if there are any existing pref labels with the same # language and value conflicting_pref_labels = pref_labels.select do |l| Labeling::SKOS::PrefLabel. joins(:owner, :target). where(labels: { value: l.value, language: l.language }). where('labelings.owner_id != ?', id). where('concepts.origin != ?', origin). any? end if conflicting_pref_labels.any? if conflicting_pref_labels.one? errors.add :base, I18n.t('txt.models.concept.pref_label_not_unique', label: conflicting_pref_labels.last.value) else errors.add :base, I18n.t('txt.models.concept.pref_labels_not_unique', label: conflicting_pref_labels.map(&:value).join(', ')) end end end end |
#unique_pref_label_language ⇒ Object
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'app/models/concept/validations.rb', line 47 def unique_pref_label_language # We have many sources a prefLabel can be defined in pls = pref_labelings.map(&:target) + send(Iqvoc::Concept.pref_labeling_class_name.to_relation_name).map(&:target) + labelings.select{ |l| l.is_a?(Iqvoc::Concept.pref_labeling_class) }.map(&:target) languages = {} pls.compact.each do |pref_label| lang = pref_label.language.to_s origin = (pref_label.origin || pref_label.id || pref_label.value).to_s if (languages.keys.include?(lang) && languages[lang] != origin) errors.add :pref_labelings, I18n.t('txt.models.concept.pref_labels_with_same_languages_error') end languages[lang] = origin end end |
#valid_rank_for_ranked_relations ⇒ Object
90 91 92 93 94 95 96 97 98 99 100 |
# File 'app/models/concept/validations.rb', line 90 def valid_rank_for_ranked_relations if validatable_for_publishing? relations.each do |relation| if relation.class.rankable? && !(0..100).include?(relation.rank) errors.add :base, I18n.t('txt.models.concept.invalid_rank_for_ranked_relations', relation: relation.class.model_name.human.downcase, relation_target_label: relation.target.pref_label.to_s) end end end end |