scinote-web/app/models/result.rb

106 lines
3.1 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2017-06-23 21:19:08 +08:00
class Result < ApplicationRecord
include ArchivableModel
include SearchableModel
include SearchableByNameModel
2016-02-12 23:52:43 +08:00
auto_strip_attributes :name, nullify: false
2016-02-12 23:52:43 +08:00
validates :user, :my_module, presence: true
validates :name, length: { maximum: Constants::NAME_MAX_LENGTH }
2016-02-12 23:52:43 +08:00
2019-06-10 18:19:10 +08:00
belongs_to :user, inverse_of: :results
belongs_to :last_modified_by, foreign_key: 'last_modified_by_id', class_name: 'User', optional: true
belongs_to :archived_by, foreign_key: 'archived_by_id', class_name: 'User', optional: true
belongs_to :restored_by, foreign_key: 'restored_by_id', class_name: 'User', optional: true
belongs_to :my_module, inverse_of: :results
has_one :result_asset, inverse_of: :result, dependent: :destroy
2016-02-12 23:52:43 +08:00
has_one :asset, through: :result_asset
has_one :result_table, inverse_of: :result, dependent: :destroy
2016-02-12 23:52:43 +08:00
has_one :table, through: :result_table
has_one :result_text, inverse_of: :result, dependent: :destroy
has_many :result_comments, foreign_key: :associated_id, dependent: :destroy
2016-02-12 23:52:43 +08:00
has_many :report_elements, inverse_of: :result, dependent: :destroy
accepts_nested_attributes_for :result_text
accepts_nested_attributes_for :asset
accepts_nested_attributes_for :table
2017-05-05 22:41:23 +08:00
def self.search(user,
include_archived,
query = nil,
page = 1,
_current_team = nil,
options = {})
module_ids = MyModule.search(user, include_archived, nil, Constants::SEARCH_NO_LIMIT).pluck(:id)
2016-02-12 23:52:43 +08:00
2017-05-05 22:41:23 +08:00
new_query =
Result
2016-07-21 19:11:15 +08:00
.distinct
2017-05-05 22:41:23 +08:00
.joins('LEFT JOIN result_texts ON results.id = result_texts.result_id')
.where(results: { my_module_id: module_ids })
.where_attributes_like(['results.name', 'result_texts.text'], query, options)
2016-07-21 19:11:15 +08:00
new_query = new_query.active unless include_archived
2016-02-12 23:52:43 +08:00
# Show all results if needed
if page == Constants::SEARCH_NO_LIMIT
2016-02-12 23:52:43 +08:00
new_query
else
new_query.limit(Constants::SEARCH_LIMIT).offset((page - 1) * Constants::SEARCH_LIMIT)
2016-02-12 23:52:43 +08:00
end
end
def self.viewable_by_user(user, teams)
where(my_module: MyModule.viewable_by_user(user, teams))
end
def navigable?
!my_module.archived? && my_module.navigable?
end
2016-02-12 23:52:43 +08:00
def space_taken
is_asset ? result_asset.space_taken : 0
end
def last_comments(last_id = 1, per_page = Constants::COMMENTS_SEARCH_LIMIT)
last_id = Constants::INFINITY if last_id <= 1
comments = ResultComment.joins(:result)
.where(results: { id: id })
.where('comments.id < ?', last_id)
.order(created_at: :desc)
.limit(per_page)
ResultComment.from(comments, :comments).order(created_at: :asc)
2016-02-12 23:52:43 +08:00
end
def is_text
result_text.present?
2016-02-12 23:52:43 +08:00
end
def is_table
table.present?
2016-02-12 23:52:43 +08:00
end
def is_asset
asset.present?
2016-02-12 23:52:43 +08:00
end
def unlocked?(result)
if result.is_asset
!result.asset.locked?
else
true
end
end
def editable?
return false if is_asset && asset.file.metadata['asset_type'] == 'marvinjs'
true
end
2020-11-20 19:29:40 +08:00
def comments
result_comments
end
2016-02-12 23:52:43 +08:00
end