scinote-web/app/models/report.rb

139 lines
4 KiB
Ruby
Raw Normal View History

2020-10-14 18:12:32 +08:00
# frozen_string_literal: true
2017-06-23 21:19:08 +08:00
class Report < ApplicationRecord
ID_PREFIX = 'RP'
include PrefixedIdModel
SEARCHABLE_ATTRIBUTES = ['reports.name', 'reports.description', PREFIXED_ID_SQL].freeze
2021-04-08 23:40:16 +08:00
include SettingsModel
include Assignable
include PermissionCheckableModel
2016-02-12 23:52:43 +08:00
include SearchableModel
include SearchableByNameModel
2016-02-12 23:52:43 +08:00
enum pdf_file_status: { pdf_empty: 0, pdf_processing: 1, pdf_ready: 2, pdf_error: 3 }
enum docx_file_status: { docx_empty: 0, docx_processing: 1, docx_ready: 2, docx_error: 3 }
# ActiveStorage configuration
has_one_attached :pdf_file
has_one_attached :docx_file
has_one_attached :docx_preview_file
auto_strip_attributes :name, :description, nullify: false
2016-02-12 23:52:43 +08:00
validates :name,
length: { minimum: Constants::NAME_MIN_LENGTH,
2021-05-12 20:56:22 +08:00
maximum: Constants::NAME_MAX_LENGTH }
validates :description, length: { maximum: Constants::TEXT_MAX_LENGTH }
2016-02-12 23:52:43 +08:00
validates :project, presence: true
validates :user, presence: true
belongs_to :project, inverse_of: :reports
belongs_to :user, inverse_of: :reports
belongs_to :team, inverse_of: :reports
2017-06-28 21:21:32 +08:00
belongs_to :last_modified_by,
foreign_key: 'last_modified_by_id',
class_name: 'User',
optional: true
has_many :users, through: :user_assignments
has_many :report_template_values, dependent: :destroy
2016-02-12 23:52:43 +08:00
# Report either has many report elements (if grouped by timestamp),
# or many module elements (if grouped by module)
2021-05-27 22:31:41 +08:00
has_many :report_elements, inverse_of: :report, dependent: :delete_all
2016-02-12 23:52:43 +08:00
2021-04-08 23:40:16 +08:00
DEFAULT_SETTINGS = {
all_tasks: true,
task: {
protocol: {
description: true,
completed_steps: true,
uncompleted_steps: true,
step_texts: true,
2021-04-08 23:40:16 +08:00
step_checklists: true,
step_files: true,
step_tables: true,
step_comments: true,
step_well_plates: true
2021-04-08 23:40:16 +08:00
},
file_results: true,
2021-04-08 23:40:16 +08:00
file_results_previews: false,
table_results: true,
text_results: true,
result_comments: true,
result_order: 'new',
activities: true,
repositories: []
2021-04-08 23:40:16 +08:00
}
}.freeze
2016-02-12 23:52:43 +08:00
def self.search(
user,
include_archived,
query = nil,
2017-05-05 22:41:23 +08:00
page = 1,
_current_team = nil,
options = {}
2016-02-12 23:52:43 +08:00
)
project_ids = Project.search(user, include_archived, nil, Constants::SEARCH_NO_LIMIT)
.pluck(:id)
2016-02-12 23:52:43 +08:00
new_query = Report.distinct
.where(reports: { project_id: project_ids })
.where_attributes_like(SEARCHABLE_ATTRIBUTES, query, options)
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)
with_granted_permissions(user, ReportPermissions::READ)
.where(project: Project.viewable_by_user(user, teams))
end
def self.filter_by_teams(teams = [])
teams.blank? ? self : where(team: teams)
end
def created_by
user
end
def permission_parent
team
end
2016-02-12 23:52:43 +08:00
def root_elements
2021-05-27 22:31:41 +08:00
report_elements.active.where(parent: nil).order(:position)
2016-02-12 23:52:43 +08:00
end
def self.generate_whole_project_report(project, current_user, current_team)
2021-05-24 19:16:43 +08:00
content = {
'experiments' => [],
'repositories' => project.assigned_repositories_and_snapshots.pluck(:id)
2021-05-24 19:16:43 +08:00
}
project.experiments.includes(:my_modules).each do |experiment|
content['experiments'].push(
{ id: experiment.id, my_module_ids: experiment.my_module_ids }
)
2021-05-24 19:16:43 +08:00
end
report = Report.new(skip_user_assignments: true)
report.name = loop do
dummy_name = SecureRandom.hex(10)
break dummy_name unless Report.exists?(name: dummy_name)
end
report.project = project
report.user = current_user
report.team = current_team
report.last_modified_by = current_user
report.settings[:task][:repositories] = content['repositories']
2021-05-24 19:16:43 +08:00
ReportActions::ReportContent.new(report, content, {}, current_user).save_with_content
report
end
2016-02-12 23:52:43 +08:00
end