app/models/label/base.rb

Summary

Maintainability
A
0 mins
Test Coverage
# encoding: UTF-8

# 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.

class Label::Base < ApplicationRecord
  self.table_name = 'labels'

  # ********** Associations

  has_many :labelings,
           foreign_key: 'target_id',
           class_name: 'Labeling::Base',
           inverse_of: :target

  has_many :concepts,
           through: :labelings,
           source: :owner

  has_many :pref_labelings,
           foreign_key: 'target_id',
           class_name: Iqvoc::Concept.pref_labeling_class_name,
           inverse_of: :target

  has_many :pref_labeled_concepts,
           through: :pref_labelings,
           source: :owner

  has_many :alt_labelings,
           foreign_key: 'target_id',
           class_name: Iqvoc::Concept.alt_labeling_class_name,
           inverse_of: :target

  has_many :alt_labeled_concepts,
           through: :alt_labelings,
           source: :owner

  # ********* Scopes

  def self.by_language(lang_code)
    lang_code = nil if lang_code.to_s == 'none'
    if (lang_code.is_a?(Array) && lang_code.include?('none'))
      where(arel_table[:language].eq(nil).or(arel_table[:language].in(lang_code.compact)))
    elsif lang_code.blank?
      where(arel_table[:language].eq(nil))
    else
      where(language: lang_code)
    end
  end

  def self.begins_with(prefix)
    prefix = prefix.to_s
    table = Label::Base.table_name
    where("LOWER(SUBSTR(#{table}.value, 1, :length)) = :prefix",
        length: prefix.length, prefix: prefix.downcase)
  end

  def self.missing_translation(lang, main_lang)
    joins(:concepts).
    joins(sanitize_sql(["LEFT OUTER JOIN labelings pref_labelings ON
        pref_labelings.id <> labelings.id AND
        pref_labelings.owner_id = concepts.id AND
        pref_labelings.type = '%s'", Iqvoc::Concept.pref_labeling_class_name])).
    joins(sanitize_sql(["LEFT OUTER JOIN labels pref_labels ON
        pref_labels.id = pref_labelings.target_id AND
        pref_labels.language = '%s'", lang])).
    where('labelings.type = :class_name', class_name: Iqvoc::Concept.pref_labeling_class_name).
    where('pref_labels.id IS NULL').
    where('labels.language = :lang', lang: main_lang).
    includes(:pref_labeled_concepts)
  end

  def self.by_query_value(query)
    where(["#{table_name}.value ILIKE ?", query.mb_chars.downcase.to_s])
  end

  # Attention: This means that even label classes without version controll will also
  # have to set the published_at flag to be recognized as published!
  def self.published
    where(arel_table[:published_at].not_eq(nil))
  end

  def self.unpublished
    where(arel_table[:published_at].eq(nil))
  end

  # ********* Methods

  def published?
    true
  end

  def expired?
    self.expired_at && self.expired_at < Date.today
  end

  def <=>(other)
    self.to_s.downcase <=> other.to_s.downcase
  end

  def ==(other)
    language == other.try(:language) && value == other.try(:value)
  end

  def eql?(other)
    self == other
  end

  def hash
    [value, language].hash
  end

  def to_literal
    "\"#{value}\"@#{language}"
  end

  def to_s
      value.to_s
  end
end