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.
		
		
		
		
		
			
		
			
				
					
					
						
							92 lines
						
					
					
						
							3.1 KiB
						
					
					
				
			
		
		
	
	
							92 lines
						
					
					
						
							3.1 KiB
						
					
					
				# frozen_string_literal: true
 | 
						|
 | 
						|
module TemplateFolders
 | 
						|
  module_function
 | 
						|
 | 
						|
  def filter_by_full_name(template_folders, name)
 | 
						|
    return template_folders.none if name.blank?
 | 
						|
 | 
						|
    parent_name, name = name.to_s.split(' / ', 2).map(&:squish)
 | 
						|
 | 
						|
    if name.present?
 | 
						|
      parent_folder = template_folders.where(parent_folder_id: nil).find_by(name: parent_name)
 | 
						|
    else
 | 
						|
      name = parent_name
 | 
						|
    end
 | 
						|
 | 
						|
    template_folders.where(name:, parent_folder:)
 | 
						|
  end
 | 
						|
 | 
						|
  def search(folders, keyword)
 | 
						|
    return folders if keyword.blank?
 | 
						|
 | 
						|
    folders.where(TemplateFolder.arel_table[:name].lower.matches("%#{keyword.downcase}%"))
 | 
						|
  end
 | 
						|
 | 
						|
  def filter_active_folders(template_folders, templates)
 | 
						|
    folder_exists =
 | 
						|
      templates.active.where(TemplateFolder.arel_table[:id].eq(Template.arel_table[:folder_id]))
 | 
						|
               .select(1).limit(1).arel.exists
 | 
						|
 | 
						|
    subfolders_arel = TemplateFolder.arel_table.alias('subfolders')
 | 
						|
 | 
						|
    subfolder_exists =
 | 
						|
      TemplateFolder.from(subfolders_arel)
 | 
						|
                    .where(subfolders_arel[:parent_folder_id].eq(TemplateFolder.arel_table[:id]))
 | 
						|
                    .where(
 | 
						|
                      templates.active.where(Template.arel_table[:folder_id].eq(subfolders_arel[:id])).arel.exists
 | 
						|
                    ).select(1).limit(1).arel.exists
 | 
						|
 | 
						|
    template_folders.where(folder_exists).or(template_folders.where(subfolder_exists))
 | 
						|
  end
 | 
						|
 | 
						|
  def sort(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
 | 
						|
 | 
						|
  def find_or_create_by_name(author, name)
 | 
						|
    return author.account.default_template_folder if name.blank? || name == TemplateFolder::DEFAULT_NAME
 | 
						|
 | 
						|
    parent_name, name = name.to_s.split(' / ', 2).map(&:squish)
 | 
						|
 | 
						|
    if name.present?
 | 
						|
      parent_folder = author.account.template_folders.create_with(author:)
 | 
						|
                            .find_or_create_by(name: parent_name, parent_folder_id: nil)
 | 
						|
    else
 | 
						|
      name = parent_name
 | 
						|
    end
 | 
						|
 | 
						|
    author.account.template_folders.create_with(author:).find_or_create_by(name:, parent_folder:)
 | 
						|
  end
 | 
						|
end
 |