scinote-web/app/controllers/teams_controller.rb

142 lines
4 KiB
Ruby

# frozen_string_literal: true
class TeamsController < ApplicationController
include ProjectsHelper
include CardsViewHelper
attr_reader :current_folder
helper_method :current_folder
before_action :load_vars, only: %i(sidebar export_projects export_projects_modal)
before_action :load_current_folder, only: :sidebar
before_action :check_read_permissions, except: :view_type
before_action :check_export_projects_permissions, only: %i(export_projects_modal export_projects)
def sidebar
render json: {
html: render_to_string(
partial: 'shared/sidebar/projects',
locals: { team: current_team, sort: params[:sort] },
formats: :html
)
}
end
def export_projects
if current_user.has_available_exports?
current_user.increase_daily_exports_counter!
generate_export_projects_zip
Activities::CreateActivityService
.call(activity_type: :export_projects,
owner: current_user,
subject: @team,
team: @team,
message_items: {
team: @team.id,
projects: @exp_projects.map(&:name).join(', ')
})
render json: {
flash: t('projects.export_projects.success_flash')
}, status: :ok
end
end
def export_projects_modal
if @exp_projects.present?
if current_user.has_available_exports?
render json: {
html: render_to_string(
partial: 'projects/export/modal',
locals: { num_projects: @exp_projects.size,
limit: TeamZipExport.exports_limit,
num_of_requests_left: current_user.exports_left - 1 },
formats: :html
),
title: t('projects.export_projects.modal_title')
}
else
render json: {
html: render_to_string(
partial: 'projects/export/error',
locals: { limit: TeamZipExport.exports_limit },
formats: :html
),
title: t('projects.export_projects.error_title'),
status: 'error'
}
end
else
render json: { flash: I18n.t('projects.export_projects.zero_projects_flash') }, status: :unprocessable_entity
end
end
def routing_error(error = 'Routing error', status = :not_found, exception=nil)
redirect_to root_path
end
def view_type
view_state = current_team.current_view_state(current_user)
view_state.state['projects']['view_type'] = view_type_params
view_state.save!
render json: { cards_view_type_class: cards_view_type_class(view_type_params) }, status: :ok
end
private
def load_vars
@team = current_user.teams.find_by(id: params[:id])
render_404 unless @team
end
def export_projects_params
params.permit(:id, project_ids: [], project_folder_ids: [])
end
def view_type_params
params.require(:projects).require(:view_type)
end
def check_read_permissions
render_403 unless can_read_team?(@team)
end
def load_current_folder
if current_team && params[:project_folder_id].present?
@current_folder = current_team.project_folders.find_by(id: params[:project_folder_id])
end
end
def check_export_projects_permissions
@exp_projects = []
if export_projects_params[:project_ids]
@exp_projects = @team.projects.where(id: export_projects_params[:project_ids]).to_a
end
if export_projects_params[:project_folder_ids]
folders = @team.project_folders.where(id: export_projects_params[:project_folder_ids])
folders.each do |folder|
@exp_projects += folder.inner_projects.visible_to(current_user, @team)
end
end
@exp_projects.each do |project|
return render_403 unless can_export_project?(current_user, project)
end
end
def generate_export_projects_zip
ids = @exp_projects.index_by(&:id)
options = { team: @team }
zip = TeamZipExport.create(user: current_user)
zip.generate_exportable_zip(
current_user.id,
ids,
:teams,
options
)
ids
end
end