mirror of https://github.com/docusealco/docuseal
				
				
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							97 lines
						
					
					
						
							3.4 KiB
						
					
					
				
			
		
		
	
	
							97 lines
						
					
					
						
							3.4 KiB
						
					
					
				# frozen_string_literal: true
 | 
						|
 | 
						|
class TemplatesDashboardController < ApplicationController
 | 
						|
  load_and_authorize_resource :template_folder, parent: false
 | 
						|
  load_and_authorize_resource :template, parent: false
 | 
						|
 | 
						|
  SHOW_TEMPLATES_FOLDERS_THRESHOLD = 9
 | 
						|
  TEMPLATES_PER_PAGE = 12
 | 
						|
  FOLDERS_PER_PAGE = 18
 | 
						|
 | 
						|
  def index
 | 
						|
    @template_folders = @template_folders.where(id: @templates.active.select(:folder_id))
 | 
						|
 | 
						|
    @template_folders = TemplateFolders.search(@template_folders, params[:q])
 | 
						|
    @template_folders = sort_template_folders(@template_folders, current_user,
 | 
						|
                                              cookies.permanent[:dashboard_templates_order])
 | 
						|
 | 
						|
    @pagy, @template_folders = pagy(
 | 
						|
      @template_folders,
 | 
						|
      limit: FOLDERS_PER_PAGE,
 | 
						|
      page: @template_folders.count > SHOW_TEMPLATES_FOLDERS_THRESHOLD ? params[:page] : 1
 | 
						|
    )
 | 
						|
 | 
						|
    if @pagy.count > SHOW_TEMPLATES_FOLDERS_THRESHOLD
 | 
						|
      @templates = @templates.none
 | 
						|
    else
 | 
						|
      @template_folders = @template_folders.reject { |e| e.name == TemplateFolder::DEFAULT_NAME }
 | 
						|
      @templates = filter_templates(@templates)
 | 
						|
      @templates = Templates::Order.call(@templates, current_user, cookies.permanent[:dashboard_templates_order])
 | 
						|
 | 
						|
      limit =
 | 
						|
        if @template_folders.size < 4
 | 
						|
          TEMPLATES_PER_PAGE
 | 
						|
        else
 | 
						|
          (@template_folders.size < 7 ? 9 : 6)
 | 
						|
        end
 | 
						|
 | 
						|
      @pagy, @templates = pagy_auto(@templates, limit:)
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  private
 | 
						|
 | 
						|
  def filter_templates(templates)
 | 
						|
    rel = templates.active.preload(:author, :template_accesses)
 | 
						|
 | 
						|
    if params[:q].blank?
 | 
						|
      if Docuseal.multitenant? ? current_account.testing? : current_account.linked_account_account
 | 
						|
        shared_account_ids = [current_user.account_id]
 | 
						|
        shared_account_ids << TemplateSharing::ALL_ID if !Docuseal.multitenant? && !current_account.testing?
 | 
						|
 | 
						|
        shared_template_ids = TemplateSharing.where(account_id: shared_account_ids).select(:template_id)
 | 
						|
 | 
						|
        rel = rel.where(folder_id: current_account.default_template_folder.id).or(rel.where(id: shared_template_ids))
 | 
						|
      else
 | 
						|
        rel = rel.where(folder_id: current_account.default_template_folder.id)
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    Templates.search(rel, params[:q])
 | 
						|
  end
 | 
						|
 | 
						|
  def sort_template_folders(template_folders, current_user, order)
 | 
						|
    case order
 | 
						|
    when 'used_at'
 | 
						|
      subquery =
 | 
						|
        Template.left_joins(:submissions)
 | 
						|
                .group(:folder_id)
 | 
						|
                .where(account_id: current_user.account_id)
 | 
						|
                .select(
 | 
						|
                  :folder_id,
 | 
						|
                  Template.arel_table[:updated_at].maximum.as('updated_at_max'),
 | 
						|
                  Submission.arel_table[:created_at].maximum.as('submission_created_at_max')
 | 
						|
                )
 | 
						|
 | 
						|
      template_folders = template_folders.joins(
 | 
						|
        Template.arel_table
 | 
						|
                .join(subquery.arel.as('templates'), Arel::Nodes::OuterJoin)
 | 
						|
                .on(TemplateFolder.arel_table[:id].eq(Template.arel_table[:folder_id]))
 | 
						|
                .join_sources
 | 
						|
      )
 | 
						|
 | 
						|
      template_folders.order(
 | 
						|
        Arel::Nodes::Case.new
 | 
						|
                         .when(Template.arel_table[:submission_created_at_max].gt(Template.arel_table[:updated_at_max]))
 | 
						|
                         .then(Template.arel_table[:submission_created_at_max])
 | 
						|
                         .else(Template.arel_table[:updated_at_max])
 | 
						|
                         .desc
 | 
						|
      )
 | 
						|
    when 'name'
 | 
						|
      template_folders.order(name: :asc)
 | 
						|
    else
 | 
						|
      template_folders.order(id: :desc)
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |