additionals/app/controllers/dashboard_async_blocks_controller.rb

65 lines
1.6 KiB
Ruby
Raw Normal View History

2020-07-27 11:49:23 +03:00
require 'open-uri'
class DashboardAsyncBlocksController < ApplicationController
before_action :find_dashboard
before_action :find_block
helper :additionals_routes
helper :additionals_queries
helper :additionals_tag
helper :queries
helper :issues
helper :activities
helper :dashboards
include DashboardsHelper
def show
partial_locals = build_dashboard_partial_locals @block, @block_definition, @settings, @dashboard
respond_to do |format|
format.js do
render partial: partial_locals[:async][:partial],
content_type: 'text/html',
locals: partial_locals
end
end
end
private
def find_dashboard
@dashboard = Dashboard.find params[:dashboard_id]
raise ::Unauthorized unless @dashboard.visible?
if @dashboard.dashboard_type == DashboardContentProject::TYPE_NAME && @dashboard.project.nil?
@dashboard.content_project = find_project_by_project_id
else
@project = @dashboard.project
deny_access if @project.present? && !User.current.allowed_to?(:view_project, @project)
end
@can_edit = @dashboard&.editable?
rescue ActiveRecord::RecordNotFound
render_404
end
def find_block
@block = params['block']
@block_definition = @dashboard.content.find_block @block
render_404 if @block.blank?
render_403 if @block_definition.blank?
@settings = @dashboard.layout_settings @block
end
def find_project_by_project_id
begin
@project = Project.find params[:project_id]
rescue ActiveRecord::RecordNotFound
render_404
end
deny_access unless User.current.allowed_to?(:view_project, @project)
end
end