scinote-web/app/services/experiments/table_view_service.rb
G-Chubinidze 2d04357ba8
Merge pull request #4668 from G-Chubinidze/gc_SCI_7494
Archived table view filters update [SCI-7494]
2022-12-01 12:32:41 +04:00

201 lines
5.1 KiB
Ruby

# frozen_string_literal: true
module Experiments
class TableViewService
include Rails.application.routes.url_helpers
include ActionView::Helpers::DateHelper
include CommentHelper
include ProjectsHelper
include InputSanitizeHelper
include Canaid::Helpers::PermissionsHelper
COLUMNS = %i(
task_name
id
due_date
age
results
status
archived
assigned
tags
comments
)
PRELOAD = {
results: {},
my_module_status: {},
tags: {},
task_comments: {},
user_assignments: :user,
designated_users: {},
experiment: :project
}
def initialize(my_modules, user, params)
@my_modules = my_modules
@page = params[:page] || 1
@user = user
@filters = params[:filters] || []
end
def call
result = {}
my_module_list = @my_modules
@filters.each do |name, value|
my_module_list = __send__("#{name}_filter", my_module_list, value) if value.present?
end
my_module_list = my_module_list.includes(PRELOAD)
.select('my_modules.*')
.group('my_modules.id')
.page(@page || 1)
.per(Constants::DEFAULT_ELEMENTS_PER_PAGE)
my_module_list.each do |my_module|
prepared_my_module = []
COLUMNS.each do |col|
column_data = {
column_type: col
}
column_data[:data] = __send__("#{col}_presenter", my_module)
prepared_my_module.push(column_data)
end
experiment = my_module.experiment
project = experiment.project
result[my_module.id] = {
columns: prepared_my_module,
urls: {
permissions: permissions_my_module_path(my_module),
actions_dropdown: actions_dropdown_my_module_path(my_module),
name_update: my_module_path(my_module),
access: edit_access_permissions_project_experiment_my_module_path(project, experiment, my_module)
}
}
end
{
next_page: my_module_list.next_page,
data: result
}
end
private
def task_name_presenter(my_module)
{
id: my_module.id,
name: my_module.name,
url: protocols_my_module_path(my_module)
}
end
def id_presenter(my_module)
{
id: my_module.id
}
end
def due_date_presenter(my_module)
if my_module.due_date
I18n.l(my_module.due_date, format: :full_date)
else
''
end
end
def archived_presenter(my_module)
if my_module.archived?
I18n.l(my_module.archived_on, format: :full_date)
else
''
end
end
def age_presenter(my_module)
time_ago_in_words(my_module.created_at)
end
def results_presenter(my_module)
{
count: my_module.results.active.length,
url: results_my_module_path(my_module)
}
end
def status_presenter(my_module)
{
name: my_module.my_module_status.name,
color: my_module.my_module_status.color
}
end
def assigned_presenter(my_module)
users = my_module.designated_users
result = {
count: users.length,
users: []
}
users[0..3].each do |user|
result[:users].push({
image_url: avatar_path(user, :icon_small),
title: user.full_name
})
end
result[:more_users_title] = users[4..].map(&:full_name).join('
') if users.length > 4
result[:list_url] = search_my_module_user_my_module_path(my_module, my_module_id: my_module.id)
if can_manage_my_module_users?(@user, my_module)
result[:create_url] = my_module_user_my_modules_path(my_module_id: my_module.id)
end
result
end
def tags_presenter(my_module)
{
my_module_id: my_module.id,
tags: my_module.tags.length,
edit_url: my_module_tags_edit_path(my_module, format: :json)
}
end
def comments_presenter(my_module)
{
id: my_module.id,
count: my_module.comments.count,
count_unseen: count_unseen_comments(my_module, @user)
}
end
def name_filter(my_modules, value)
my_modules.where_attributes_like('my_modules.name', value)
end
def due_date_from_filter(my_modules, value)
my_modules.where('my_modules.due_date >= ?', value)
end
def due_date_to_filter(my_modules, value)
my_modules.where('my_modules.due_date <= ?', value)
end
def archived_on_from_filter(my_modules, value)
my_modules.where('my_modules.archived_on >= ?', value)
end
def archived_on_to_filter(my_modules, value)
my_modules.where('my_modules.archived_on <= ?', value)
end
def assigned_users_filter(my_modules, value)
my_modules.joins(:user_my_modules).where(user_my_modules: { user_id: value })
end
def statuses_filter(my_modules, value)
my_modules.where('my_module_status_id IN (?)', value)
end
end
end