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.
		
		
		
		
		
			
		
			
				
					
					
						
							157 lines
						
					
					
						
							5.4 KiB
						
					
					
				
			
		
		
	
	
							157 lines
						
					
					
						
							5.4 KiB
						
					
					
				# frozen_string_literal: true
 | 
						|
 | 
						|
class TemplatesController < ApplicationController
 | 
						|
  load_and_authorize_resource :template
 | 
						|
 | 
						|
  before_action :load_base_template, only: %i[new create]
 | 
						|
 | 
						|
  def show
 | 
						|
    submissions = @template.submissions.accessible_by(current_ability)
 | 
						|
    submissions = submissions.active if @template.archived_at.blank?
 | 
						|
    submissions = Submissions.search(submissions, params[:q], search_values: true)
 | 
						|
    submissions = Submissions::Filter.call(submissions, current_user, params.except(:status))
 | 
						|
 | 
						|
    @base_submissions = submissions
 | 
						|
 | 
						|
    submissions = Submissions::Filter.filter_by_status(submissions, params)
 | 
						|
 | 
						|
    submissions = if params[:completed_at_from].present? || params[:completed_at_to].present?
 | 
						|
                    submissions.order(Submitter.arel_table[:completed_at].maximum.desc)
 | 
						|
                  else
 | 
						|
                    submissions.order(id: :desc)
 | 
						|
                  end
 | 
						|
 | 
						|
    @pagy, @submissions = pagy(submissions.preload(:template_accesses, submitters: :start_form_submission_events))
 | 
						|
  rescue ActiveRecord::RecordNotFound
 | 
						|
    redirect_to root_path
 | 
						|
  end
 | 
						|
 | 
						|
  def new
 | 
						|
    @template.name = "#{@base_template.name} (#{I18n.t('clone')})" if @base_template
 | 
						|
  end
 | 
						|
 | 
						|
  def edit
 | 
						|
    ActiveRecord::Associations::Preloader.new(
 | 
						|
      records: [@template],
 | 
						|
      associations: [schema_documents: [:blob, { preview_images_attachments: :blob }]]
 | 
						|
    ).call
 | 
						|
 | 
						|
    @template_data =
 | 
						|
      @template.as_json.merge(
 | 
						|
        documents: @template.schema_documents.as_json(
 | 
						|
          methods: %i[metadata signed_uuid],
 | 
						|
          include: { preview_images: { methods: %i[url metadata filename] } }
 | 
						|
        )
 | 
						|
      ).to_json
 | 
						|
 | 
						|
    render :edit, layout: 'plain'
 | 
						|
  end
 | 
						|
 | 
						|
  def create
 | 
						|
    if @base_template
 | 
						|
      ActiveRecord::Associations::Preloader.new(
 | 
						|
        records: [@base_template],
 | 
						|
        associations: [schema_documents: :preview_images_attachments]
 | 
						|
      ).call
 | 
						|
 | 
						|
      @template = Templates::Clone.call(@base_template, author: current_user,
 | 
						|
                                                        name: params.dig(:template, :name),
 | 
						|
                                                        folder_name: params[:folder_name])
 | 
						|
    else
 | 
						|
      @template.author = current_user
 | 
						|
      @template.folder = TemplateFolders.find_or_create_by_name(current_user, params[:folder_name])
 | 
						|
    end
 | 
						|
 | 
						|
    if params[:account_id].present? && authorized_clone_account_id?(params[:account_id])
 | 
						|
      @template.account_id = params[:account_id]
 | 
						|
      @template.folder = @template.account.default_template_folder if @template.account_id != current_account.id
 | 
						|
    else
 | 
						|
      @template.account = current_account
 | 
						|
    end
 | 
						|
 | 
						|
    if @template.save
 | 
						|
      Templates::CloneAttachments.call(template: @template, original_template: @base_template) if @base_template
 | 
						|
 | 
						|
      enqueue_template_created_webhooks(@template)
 | 
						|
 | 
						|
      maybe_redirect_to_template(@template)
 | 
						|
    else
 | 
						|
      render turbo_stream: turbo_stream.replace(:modal, template: 'templates/new'), status: :unprocessable_entity
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def update
 | 
						|
    @template.update!(template_params)
 | 
						|
 | 
						|
    enqueue_template_updated_webhooks(@template)
 | 
						|
 | 
						|
    head :ok
 | 
						|
  end
 | 
						|
 | 
						|
  def destroy
 | 
						|
    notice =
 | 
						|
      if params[:permanently].in?(['true', true])
 | 
						|
        @template.destroy!
 | 
						|
 | 
						|
        I18n.t('template_has_been_removed')
 | 
						|
      else
 | 
						|
        @template.update!(archived_at: Time.current)
 | 
						|
 | 
						|
        I18n.t('template_has_been_archived')
 | 
						|
      end
 | 
						|
 | 
						|
    redirect_back(fallback_location: root_path, notice:)
 | 
						|
  end
 | 
						|
 | 
						|
  private
 | 
						|
 | 
						|
  def template_params
 | 
						|
    params.require(:template).permit(
 | 
						|
      :name,
 | 
						|
      { schema: [[:attachment_uuid, :name, { conditions: [%i[field_uuid value action operation]] }]],
 | 
						|
        submitters: [%i[name uuid is_requester linked_to_uuid invite_by_uuid optional_invite_by_uuid email]],
 | 
						|
        fields: [[:uuid, :submitter_uuid, :name, :type,
 | 
						|
                  :required, :readonly, :default_value,
 | 
						|
                  :title, :description,
 | 
						|
                  { preferences: {},
 | 
						|
                    conditions: [%i[field_uuid value action operation]],
 | 
						|
                    options: [%i[value uuid]],
 | 
						|
                    validation: %i[message pattern],
 | 
						|
                    areas: [%i[x y w h cell_w attachment_uuid option_uuid page]] }]] }
 | 
						|
    )
 | 
						|
  end
 | 
						|
 | 
						|
  def authorized_clone_account_id?(account_id)
 | 
						|
    true_user.account_id.to_s == account_id.to_s ||
 | 
						|
      true_user.account.linked_accounts.accessible_by(current_ability).exists?(id: account_id)
 | 
						|
  end
 | 
						|
 | 
						|
  def maybe_redirect_to_template(template)
 | 
						|
    if template.account == current_account
 | 
						|
      redirect_to(edit_template_path(@template))
 | 
						|
    else
 | 
						|
      redirect_back(fallback_location: root_path, notice: I18n.t('template_has_been_cloned'))
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def enqueue_template_created_webhooks(template)
 | 
						|
    WebhookUrls.for_account_id(template.account_id, 'template.created').each do |webhook_url|
 | 
						|
      SendTemplateCreatedWebhookRequestJob.perform_async('template_id' => template.id,
 | 
						|
                                                         'webhook_url_id' => webhook_url.id)
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def enqueue_template_updated_webhooks(template)
 | 
						|
    WebhookUrls.for_account_id(template.account_id, 'template.updated').each do |webhook_url|
 | 
						|
      SendTemplateUpdatedWebhookRequestJob.perform_async('template_id' => template.id,
 | 
						|
                                                         'webhook_url_id' => webhook_url.id)
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def load_base_template
 | 
						|
    return if params[:base_template_id].blank?
 | 
						|
 | 
						|
    @base_template = Template.accessible_by(current_ability).find_by(id: params[:base_template_id])
 | 
						|
  end
 | 
						|
end
 |