diff --git a/config/environments/production.rb b/config/environments/production.rb
index fee6352c..36b0bfaa 100644
--- a/config/environments/production.rb
+++ b/config/environments/production.rb
@@ -134,7 +134,15 @@ Rails.application.configure do
{}
end
+ resource = controller.instance_variable_get(:@submitter) ||
+ controller.instance_variable_get(:@submission) ||
+ controller.instance_variable_get(:@template) ||
+ controller.instance_variable_get(:@record)
+
+ current_user = controller.instance_variable_get(:@current_user)
+
{
+ host: controller.request.host,
fwd: controller.request.remote_ip,
params: {
id: params[:id],
@@ -148,8 +156,10 @@ Rails.application.configure do
params[:submit_form_slug] ||
params[:template_slug]).to_s.first(5)
}.compact_blank,
- host: controller.request.host,
- uid: controller.instance_variable_get(:@current_user).try(:id)
+ uid: current_user.try(:id),
+ aid: current_user.try(:account_id),
+ rid: resource.try(:id),
+ raid: resource.try(:account_id)
}
end
end
diff --git a/config/locales/i18n.yml b/config/locales/i18n.yml
index d5845178..893fe39c 100644
--- a/config/locales/i18n.yml
+++ b/config/locales/i18n.yml
@@ -21,6 +21,7 @@ en: &en
language_ja: 日本語
hi_there: Hi there
thanks: Thanks
+ private: Private
bcc_recipients: BCC recipients
resend_pending: Re-send pending
always_enforce_signing_order: Always enforce the signing order
@@ -597,6 +598,7 @@ en: &en
not_invited_yet: Not invited yet
not_completed_yet: Not completed yet
declined_on_time: 'Declined on %{time}'
+ expire_on_time: 'Expire on %{time}'
sign_in_person: Sign In-person
create_a_new_template_document_form_or_submit_the_existing_one_html:
Create a new template document form or
submit the existing one
send_email_copy_with_completed_documents_to_a_specified_bcc_address: Send email copy with completed documents to a specified BCC address.
@@ -717,6 +719,25 @@ en: &en
name_a_z: Name A-Z
recently_used: Recently used
newest_first: Newest first
+ none: None
+ default_expiration: Default expiration
+ specified_date: Specified date
+ one_day: 1 day
+ two_days: 2 days
+ three_days: 3 days
+ four_days: 4 days
+ five_days: 5 days
+ six_days: 6 days
+ seven_days: 7 days
+ eight_days: 8 days
+ nine_days: 9 days
+ ten_days: 10 days
+ two_weeks: 2 weeks
+ three_weeks: 3 weeks
+ four_weeks: 4 weeks
+ one_month: 1 month
+ two_months: 2 months
+ three_months: 3 months
submission_sources:
api: API
bulk: Bulk Send
@@ -725,6 +746,8 @@ en: &en
link: Link
submission_event_names:
send_email_to_html: '
Email sent to %{submitter_name}'
+ bounce_email_html: '
Email bounced %{submitter_name}'
+ complaint_email_html: '
Spam complaint %{submitter_name}'
send_reminder_email_to_html: '
Reminder email sent to %{submitter_name}'
send_sms_to_html: '
SMS sent to %{submitter_name}'
send_2fa_sms_to_html: '
Verification SMS sent to %{submitter_name}'
@@ -760,11 +783,11 @@ en: &en
previous: Previous
next: Next
template_and_submissions: 'Templates and Submissions'
- template_and_submissions_description: "You can select the view that best suits your workflow. Choose the 'Templates' view if you create reusable document templates, or the 'Submissions' view when you sign individual documents or review the status of each signing request."
+ template_and_submissions_description: "You can select the view that best suits your workflow. Choose the 'Templates' view to create reusable document templates, or the 'Submissions' view to sign individual documents or review the status of each signature request."
upload_a_pdf_file: 'Upload a PDF file'
- upload_a_pdf_file_description: 'Upload a document to use it for creating a signing form template.'
+ upload_a_pdf_file_description: 'Upload a PDF document to create a signing form template.'
select_a_signer_party: 'Select a signer party'
- select_a_signer_party_description: 'This dropdown allows you to select a signing party role or add a new party to the document when it needs to be signed by two or more parties.'
+ select_a_signer_party_description: 'This dropdown allows you to select a signing party role or add a new party to the document if it requires 2 or more signatures.'
available_parties: 'Available parties'
available_parties_description: 'This list contains all available parties with their role names. Once selected, you can add and configure fields for the signer party.'
available_field_types: 'Available field types'
@@ -772,7 +795,7 @@ en: &en
text_input_field: 'Text input field'
text_input_field_description: 'This field allows users to enter text-based information, such as names or emails.'
signature_field: 'Signature field'
- signature_field_description: 'This field allows for collecting signatures from the signers.'
+ signature_field_description: 'This field is used to collect signatures from the signers.'
added_fields: 'Added fields'
added_fields_description: 'This list displays all fields added to the document. You can reorder, edit, or remove them.'
open_field_settings: 'Open field settings'
@@ -786,10 +809,10 @@ en: &en
copy_and_share_link: 'Copy & share link'
copy_and_share_link_description: 'Copy this link to share the document. Anyone with the link can sign it after entering their email.'
sign_the_document: 'Sign the document'
- sign_the_document_description: 'If you are one of the signers signer, this button allows you to sign the document yourself.'
+ sign_the_document_description: 'If you are one of the signers, this button allows you to sign the document.'
send_for_signing: 'Send for signing'
add_recipients: 'Add recipients'
- add_recipients_description: 'Add new recipients for the document to be signed. You can enter their email addresses or phone numbers.'
+ add_recipients_description: 'Add new recipients for the document to be signed by entering their email addresses or phone numbers.'
settings: 'Settings'
settings_account_description: 'With comprehensive account settings, you can customize the eSigning experience and invite more users.'
support: 'Support'
@@ -801,6 +824,7 @@ en: &en
read: Read your data
es: &es
+ private: Privado
resend_pending: Reenviar pendiente
ensure_unique_recipients: Asegurar destinatarios únicos
require_phone_2fa_to_open: Requiere 2FA por teléfono para abrir
@@ -1379,6 +1403,7 @@ es: &es
not_invited_yet: Aún no invitado
not_completed_yet: Aún no completado
declined_on_time: 'Rechazado el %{time}'
+ expire_on_time: 'Expira el %{time}'
sign_in_person: Firma en persona
create_a_new_template_document_form_or_submit_the_existing_one_html:
Crear una nueva plantilla de documento o
enviar el existente
send_email_copy_with_completed_documents_to_a_specified_bcc_address: Enviar una copia del correo electrónico con los documentos completados a una dirección BCC especificada.
@@ -1499,6 +1524,25 @@ es: &es
name_a_z: Nombre A-Z
recently_used: Usado recientemente
newest_first: Más reciente primero
+ none: Ninguno
+ default_expiration: Vencimiento predeterminado
+ specified_date: Fecha especificada
+ one_day: 1 día
+ two_days: 2 días
+ three_days: 3 días
+ four_days: 4 días
+ five_days: 5 días
+ six_days: 6 días
+ seven_days: 7 días
+ eight_days: 8 días
+ nine_days: 9 días
+ ten_days: 10 días
+ two_weeks: 2 semanas
+ three_weeks: 3 semanas
+ four_weeks: 4 semanas
+ one_month: 1 mes
+ two_months: 2 meses
+ three_months: 3 meses
submission_sources:
api: API
bulk: Envío masivo
@@ -1507,6 +1551,8 @@ es: &es
link: Enlace
submission_event_names:
send_email_to_html: '
Correo electrónico enviado a %{submitter_name}'
+ bounce_email_html: '
Correo electrónico rebotado %{submitter_name}'
+ complaint_email_html: '
Queja de spam %{submitter_name}'
send_reminder_email_to_html: '
Correo de recordatorio enviado a %{submitter_name}'
send_sms_to_html: '
SMS enviado a %{submitter_name}'
send_2fa_sms_to_html: '
SMS de verificación enviado a %{submitter_name}'
@@ -1542,11 +1588,11 @@ es: &es
previous: Anterior
next: Siguiente
template_and_submissions: 'Plantillas y Envíos'
- template_and_submissions_description: "Puedes seleccionar la vista que mejor se adapte a tu flujo de trabajo. Elige la vista de 'Plantillas' si creas plantillas reutilizables de documentos, o la vista de 'Envíos' cuando firmas documentos individuales o revisas el estado de cada solicitud de firma."
+ template_and_submissions_description: "Puedes seleccionar la vista que mejor se adapte a tu flujo de trabajo. Elige la vista 'Plantillas' para crear plantillas reutilizables de documentos, o la vista 'Envíos' para firmar documentos individuales o revisar el estado de cada solicitud de firma."
upload_a_pdf_file: 'Subir un archivo PDF'
- upload_a_pdf_file_description: 'Sube un documento para usarlo como plantilla de formulario de firma.'
+ upload_a_pdf_file_description: 'Sube un documento PDF para crear una plantilla de formulario de firma.'
select_a_signer_party: 'Seleccionar parte firmante'
- select_a_signer_party_description: 'Este menú desplegable te permite seleccionar un rol de firmante o agregar una nueva parte al documento cuando debe ser firmado por dos o más partes.'
+ select_a_signer_party_description: 'Este menú desplegable te permite seleccionar un rol de firmante o agregar una nueva parte al documento si requiere 2 o más firmas.'
available_parties: 'Partes disponibles'
available_parties_description: 'Esta lista contiene todas las partes disponibles con sus roles. Una vez seleccionada, puedes añadir y configurar campos para esa parte.'
available_field_types: 'Tipos de campo disponibles'
@@ -1554,7 +1600,7 @@ es: &es
text_input_field: 'Campo de texto'
text_input_field_description: 'Este campo permite a los usuarios introducir información de texto, como nombres o correos electrónicos.'
signature_field: 'Campo de firma'
- signature_field_description: 'Este campo permite recopilar firmas de los firmantes.'
+ signature_field_description: 'Este campo se utiliza para recopilar las firmas de los firmantes.'
added_fields: 'Campos añadidos'
added_fields_description: 'Esta lista muestra todos los campos añadidos al documento. Puedes reordenarlos, editarlos o eliminarlos.'
open_field_settings: 'Abrir configuración del campo'
@@ -1568,10 +1614,10 @@ es: &es
copy_and_share_link: 'Copiar y compartir enlace'
copy_and_share_link_description: 'Copia este enlace para compartir el documento. Cualquiera con el enlace puede firmarlo tras ingresar su correo electrónico.'
sign_the_document: 'Firmar el documento'
- sign_the_document_description: 'Si eres uno de los firmantes, este botón te permite firmar el documento tú mismo.'
+ sign_the_document_description: 'Si eres uno de los firmantes, este botón te permite firmar el documento.'
send_for_signing: 'Enviar para firma'
add_recipients: 'Agregar destinatarios'
- add_recipients_description: 'Agrega nuevos destinatarios para que el documento sea firmado. Puedes ingresar sus correos electrónicos o números de teléfono.'
+ add_recipients_description: 'Agrega nuevos destinatarios para que firmen el documento ingresando sus correos electrónicos o números de teléfono.'
settings: 'Configuración'
settings_account_description: 'Con una configuración completa de la cuenta, puedes personalizar la experiencia de firma y añadir más usuarios.'
support: 'Soporte'
@@ -1583,6 +1629,7 @@ es: &es
read: Leer tus datos
it: &it
+ private: Privato
resend_pending: Reinvia in sospeso
ensure_unique_recipients: Assicurarsi destinatari unici
require_phone_2fa_to_open: Richiedi l'autenticazione a due fattori tramite telefono per aprire
@@ -2160,6 +2207,7 @@ it: &it
not_invited_yet: Non ancora invitato
not_completed_yet: Non ancora completato
declined_on_time: 'Rifiutato il %{time}'
+ expire_on_time: 'Scade il %{time}'
sign_in_person: Firma di persona
create_a_new_template_document_form_or_submit_the_existing_one_html:
Crea un nuovo modello di documento o
invia quello esistente
send_email_copy_with_completed_documents_to_a_specified_bcc_address: Invia una copia dell'email con i documenti completati a un indirizzo BCC specificato.
@@ -2280,6 +2328,25 @@ it: &it
name_a_z: Nome A-Z
recently_used: Recentemente usato
newest_first: Più recenti prima
+ none: Nessuno
+ default_expiration: Scadenza predefinita
+ specified_date: Data specificata
+ one_day: 1 giorno
+ two_days: 2 giorni
+ three_days: 3 giorni
+ four_days: 4 giorni
+ five_days: 5 giorni
+ six_days: 6 giorni
+ seven_days: 7 giorni
+ eight_days: 8 giorni
+ nine_days: 9 giorni
+ ten_days: 10 giorni
+ two_weeks: 2 settimane
+ three_weeks: 3 settimane
+ four_weeks: 4 settimane
+ one_month: 1 mese
+ two_months: 2 mesi
+ three_months: 3 mesi
submission_sources:
api: API
bulk: Invio massivo
@@ -2287,7 +2354,9 @@ it: &it
invite: Invito
link: Link
submission_event_names:
- send_email_to_html: '
E-mail inviato a %{submitter_name}'
+ send_email_to_html: '
Email inviata a %{submitter_name}'
+ bounce_email_html: '
Email respinta %{submitter_name}'
+ complaint_email_html: '
Segnalazione spam %{submitter_name}'
send_reminder_email_to_html: '
E-mail di promemoria inviato a %{submitter_name}'
send_sms_to_html: '
SMS inviato a %{submitter_name}'
send_2fa_sms_to_html: '
SMS di verifica inviato a %{submitter_name}'
@@ -2323,11 +2392,11 @@ it: &it
previous: Precedente
next: Successivo
template_and_submissions: 'Modelli e Invii'
- template_and_submissions_description: "Puoi selezionare la vista che meglio si adatta al tuo flusso di lavoro. Scegli la vista 'Modelli' se crei modelli riutilizzabili di documenti, oppure la vista 'Invii' quando firmi documenti singoli o controlli lo stato di ogni richiesta di firma."
+ template_and_submissions_description: "Puoi selezionare la visualizzazione più adatta al tuo flusso di lavoro. Scegli la visualizzazione 'Modelli' per creare modelli di documenti riutilizzabili o 'Invii' per firmare documenti singoli o controllare lo stato di ciascuna richiesta di firma."
upload_a_pdf_file: 'Carica un file PDF'
- upload_a_pdf_file_description: 'Carica un documento da utilizzare per creare un modello di modulo di firma.'
+ upload_a_pdf_file_description: 'Carica un documento PDF per creare un modello di modulo di firma.'
select_a_signer_party: 'Seleziona una parte firmataria'
- select_a_signer_party_description: 'Questo menu a discesa consente di selezionare un ruolo di firmatario o aggiungere una nuova parte al documento quando deve essere firmato da due o più parti.'
+ select_a_signer_party_description: 'Questo menu a discesa consente di selezionare un ruolo di firmatario o aggiungere una nuova parte al documento se richiede 2 o più firme.'
available_parties: 'Parti disponibili'
available_parties_description: 'Questo elenco contiene tutte le parti disponibili con i relativi ruoli. Una volta selezionata, puoi aggiungere e configurare i campi per la parte firmataria.'
available_field_types: 'Tipi di campo disponibili'
@@ -2335,7 +2404,7 @@ it: &it
text_input_field: 'Campo di testo'
text_input_field_description: 'Questo campo consente agli utenti di inserire informazioni testuali, come nomi o email.'
signature_field: 'Campo firma'
- signature_field_description: 'Questo campo consente di raccogliere firme dai firmatari.'
+ signature_field_description: 'Questo campo viene utilizzato per raccogliere le firme dei firmatari.'
added_fields: 'Campi aggiunti'
added_fields_description: 'Questo elenco mostra tutti i campi aggiunti al documento. Puoi riordinarli, modificarli o rimuoverli.'
open_field_settings: 'Apri le impostazioni del campo'
@@ -2349,10 +2418,10 @@ it: &it
copy_and_share_link: 'Copia e condividi il link'
copy_and_share_link_description: 'Copia questo link per condividere il documento. Chiunque abbia il link potrà firmarlo dopo aver inserito la propria email.'
sign_the_document: 'Firma il documento'
- sign_the_document_description: 'Se sei uno dei firmatari, questo pulsante ti consente di firmare il documento personalmente.'
+ sign_the_document_description: 'Se sei uno dei firmatari, questo pulsante ti consente di firmare il documento.'
send_for_signing: 'Invia per la firma'
add_recipients: 'Aggiungi destinatari'
- add_recipients_description: 'Aggiungi nuovi destinatari per la firma del documento. Puoi inserire il loro indirizzo email o numero di telefono.'
+ add_recipients_description: 'Aggiungi nuovi destinatari inserendo i loro indirizzi email o numeri di telefono per far firmare il documento.'
settings: 'Impostazioni'
settings_account_description: "Con impostazioni complete dell'account, puoi personalizzare l'esperienza di firma elettronica e invitare altri utenti."
support: 'Supporto'
@@ -2364,6 +2433,7 @@ it: &it
read: Leggi i tuoi dati
fr: &fr
+ private: Privé
resend_pending: Renvoyer en attente
ensure_unique_recipients: Assurer l'unicité des destinataires
require_phone_2fa_to_open: Requiert une 2FA par téléphone pour ouvrir
@@ -2943,6 +3013,7 @@ fr: &fr
not_invited_yet: Pas encore invité
not_completed_yet: Pas encore terminé
declined_on_time: 'Refusé le %{time}'
+ expire_on_time: 'Expire le %{time}'
sign_in_person: Signature en personne
create_a_new_template_document_form_or_submit_the_existing_one_html: "
Créer un nouveau modèle de document ou
soumettre l'existant"
send_email_copy_with_completed_documents_to_a_specified_bcc_address: Envoyer une copie de l'e-mail avec les documents complétés à une adresse BCC spécifiée.
@@ -3056,13 +3127,32 @@ fr: &fr
submission_created_via_source_html: '
Soumission créée via %{source}'
pro_user_seats_used: Places utilisateur Pro en cours d'utilisation
manage_plan: Gérer le plan
- this_submission_has_multiple_signers_which_prevents_the_use_of_a_sharing_link_html: 'Cette soumission comporte plusieurs signataires, ce qui empêche l’utilisation d’un lien de partage, car il n’est pas clair quel signataire est responsable de quels champs. Pour résoudre ce problème, suivez ce
guide pour définir les détails du signataire par défaut.'
+ this_submission_has_multiple_signers_which_prevents_the_use_of_a_sharing_link_html: "Cette soumission comporte plusieurs signataires, ce qui empêche l'utilisation d'un lien de partage, car il n'est pas clair quel signataire est responsable de quels champs. Pour résoudre ce problème, suivez ce
guide pour définir les détails du signataire par défaut."
welcome_to_docuseal: Bienvenue sur DocuSeal
start_a_quick_tour_to_learn_how_to_create_an_send_your_first_document: Lancez une visite rapide pour apprendre à créer et envoyer votre premier document.
start_tour: Démarrer
name_a_z: Nom A-Z
recently_used: Récemment utilisé
newest_first: Le plus récent d'abord
+ none: Aucun
+ default_expiration: Expiration par défaut
+ specified_date: Date spécifiée
+ one_day: 1 jour
+ two_days: 2 jours
+ three_days: 3 jours
+ four_days: 4 jours
+ five_days: 5 jours
+ six_days: 6 jours
+ seven_days: 7 jours
+ eight_days: 8 jours
+ nine_days: 9 jours
+ ten_days: 10 jours
+ two_weeks: 2 semaines
+ three_weeks: 3 semaines
+ four_weeks: 4 semaines
+ one_month: 1 mois
+ two_months: 2 mois
+ three_months: 3 mois
submission_sources:
api: API
bulk: Envoi en masse
@@ -3071,6 +3161,8 @@ fr: &fr
link: Lien
submission_event_names:
send_email_to_html: '
E-mail envoyé à %{submitter_name}'
+ bounce_email_html: '
Email non distribué %{submitter_name}'
+ complaint_email_html: '
Réclamation de spam %{submitter_name}'
send_reminder_email_to_html: '
E-mail de rappel envoyé à %{submitter_name}'
send_sms_to_html: '
SMS envoyé à %{submitter_name}'
send_2fa_sms_to_html: '
SMS de vérification envoyé à %{submitter_name}'
@@ -3106,11 +3198,11 @@ fr: &fr
previous: Précédent
next: Suivant
template_and_submissions: 'Modèles et Soumissions'
- template_and_submissions_description: "Vous pouvez sélectionner la vue qui correspond le mieux à votre flux de travail. Choisissez la vue 'Modèles' si vous créez des modèles de documents réutilisables, ou la vue 'Soumissions' lorsque vous signez des documents individuels ou vérifiez l'état de chaque demande de signature."
+ template_and_submissions_description: "Vous pouvez sélectionner la vue qui correspond le mieux à votre flux de travail. Choisissez la vue 'Modèles' pour créer des modèles de documents réutilisables ou la vue 'Soumissions' pour signer des documents individuels ou vérifier l'état de chaque demande de signature."
upload_a_pdf_file: 'Téléverser un fichier PDF'
- upload_a_pdf_file_description: "Téléversez un document pour l'utiliser comme modèle de formulaire de signature."
+ upload_a_pdf_file_description: 'Téléversez un document PDF pour créer un modèle de formulaire de signature.'
select_a_signer_party: 'Sélectionner une partie signataire'
- select_a_signer_party_description: "Ce menu déroulant vous permet de sélectionner un rôle de signataire ou d'ajouter une nouvelle partie au document lorsqu'il doit être signé par deux parties ou plus."
+ select_a_signer_party_description: "Ce menu déroulant vous permet de sélectionner un rôle de signataire ou d'ajouter une nouvelle partie au document s'il nécessite 2 signatures ou plus."
available_parties: 'Parties disponibles'
available_parties_description: 'Cette liste contient toutes les parties disponibles avec leurs rôles. Une fois sélectionnée, vous pouvez ajouter et configurer les champs pour cette partie.'
available_field_types: 'Types de champs disponibles'
@@ -3118,7 +3210,7 @@ fr: &fr
text_input_field: 'Champ de texte'
text_input_field_description: 'Ce champ permet aux utilisateurs de saisir des informations textuelles telles que des noms ou des adresses e-mail.'
signature_field: 'Champ de signature'
- signature_field_description: 'Ce champ permet de collecter les signatures des signataires.'
+ signature_field_description: 'Ce champ est utilisé pour recueillir les signatures des signataires.'
added_fields: 'Champs ajoutés'
added_fields_description: 'Cette liste affiche tous les champs ajoutés au document. Vous pouvez les réorganiser, les modifier ou les supprimer.'
open_field_settings: 'Ouvrir les paramètres du champ'
@@ -3132,10 +3224,10 @@ fr: &fr
copy_and_share_link: 'Copier et partager le lien'
copy_and_share_link_description: 'Copiez ce lien pour partager le document. Toute personne disposant du lien pourra le signer après avoir saisi son e-mail.'
sign_the_document: 'Signer le document'
- sign_the_document_description: 'Si vous êtes l’un des signataires, ce bouton vous permet de signer le document vous-même.'
+ sign_the_document_description: "Si vous êtes l'n des signataires, ce bouton vous permet de signer le document."
send_for_signing: 'Envoyer pour signature'
add_recipients: 'Ajouter des destinataires'
- add_recipients_description: 'Ajoutez de nouveaux destinataires pour que le document soit signé. Vous pouvez saisir leur adresse e-mail ou leur numéro de téléphone.'
+ add_recipients_description: "Ajoutez de nouveaux destinataires en saisissant leurs adresses e-mail ou numéros de téléphone pour faire signer le document."
settings: 'Paramètres'
settings_account_description: "Grâce à des paramètres de compte complets, vous pouvez personnaliser l'expérience de signature électronique et inviter d'autres utilisateurs."
support: 'Assistance'
@@ -3147,6 +3239,7 @@ fr: &fr
read: Lire vos données
pt: &pt
+ private: Privado
resend_pending: Re-enviar pendente
ensure_unique_recipients: Garantir destinatários únicos
require_phone_2fa_to_open: Necessário autenticação de dois fatores via telefone para abrir
@@ -3725,6 +3818,7 @@ pt: &pt
not_invited_yet: Ainda não convidado
not_completed_yet: Ainda não concluído
declined_on_time: 'Recusado em %{time}'
+ expire_on_time: 'Expira em %{time}'
sign_in_person: Assinar pessoalmente
create_a_new_template_document_form_or_submit_the_existing_one_html: '
Criar um novo modelo de documento ou
submeter o existente'
send_email_copy_with_completed_documents_to_a_specified_bcc_address: Envie uma cópia do e-mail com documentos concluídos para um endereço BCC especificado.
@@ -3845,6 +3939,25 @@ pt: &pt
name_a_z: Nome A-Z
recently_used: Recentemente usado
newest_first: Mais recente primeiro
+ none: Nenhum
+ default_expiration: Expiração padrão
+ specified_date: Data especificada
+ one_day: 1 dia
+ two_days: 2 dias
+ three_days: 3 dias
+ four_days: 4 dias
+ five_days: 5 dias
+ six_days: 6 dias
+ seven_days: 7 dias
+ eight_days: 8 dias
+ nine_days: 9 dias
+ ten_days: 10 dias
+ two_weeks: 2 semanas
+ three_weeks: 3 semanas
+ four_weeks: 4 semanas
+ one_month: 1 mês
+ two_months: 2 meses
+ three_months: 3 meses
submission_sources:
api: API
bulk: Envio em massa
@@ -3852,8 +3965,10 @@ pt: &pt
invite: Convite
link: Link
submission_event_names:
- send_email_to_html: '
E-mail enviado para %{submitter_name}'
- send_reminder_email_to_html: '
E-mail de lembrete enviado para %{submitter_name}'
+ send_email_to_html: '
Email enviado para %{submitter_name}'
+ bounce_email_html: '
Email não entregue %{submitter_name}'
+ complaint_email_html: '
Reclamação de spam %{submitter_name}'
+ send_reminder_email_to_html: '
Email de lembrete enviado para %{submitter_name}'
send_sms_to_html: '
SMS enviado para %{submitter_name}'
send_2fa_sms_to_html: '
SMS de verificação enviado para %{submitter_name}'
open_email_by_html: '
E-mail aberto por %{submitter_name}'
@@ -3888,11 +4003,11 @@ pt: &pt
previous: Anterior
next: Próximo
template_and_submissions: 'Modelos e Envios'
- template_and_submissions_description: "Você pode selecionar a visualização que melhor se adapta ao seu fluxo de trabalho. Escolha a visualização 'Modelos' se criar modelos de documentos reutilizáveis, ou 'Envios' ao assinar documentos individuais ou revisar o status de cada solicitação de assinatura."
+ template_and_submissions_description: "Você pode selecionar a visualização que melhor se adapta ao seu fluxo de trabalho. Escolha a visualização 'Modelos' para criar modelos reutilizáveis de documentos ou 'Envios' para assinar documentos individuais ou verificar o status de cada solicitação de assinatura."
upload_a_pdf_file: 'Enviar um arquivo PDF'
- upload_a_pdf_file_description: 'Envie um documento para usá-lo como modelo de formulário de assinatura.'
+ upload_a_pdf_file_description: 'Envie um documento PDF para criar um modelo de formulário de assinatura.'
select_a_signer_party: 'Selecionar parte assinante'
- select_a_signer_party_description: 'Este menu suspenso permite selecionar um papel de assinante ou adicionar uma nova parte ao documento quando ele precisa ser assinado por duas ou mais partes.'
+ select_a_signer_party_description: 'Este menu suspenso permite selecionar um papel de assinante ou adicionar uma nova parte ao documento, se forem necessárias 2 ou mais assinaturas.'
available_parties: 'Partes disponíveis'
available_parties_description: 'Esta lista contém todas as partes disponíveis com seus respectivos papéis. Após selecionar, você poderá adicionar e configurar os campos para essa parte.'
available_field_types: 'Tipos de campo disponíveis'
@@ -3900,7 +4015,7 @@ pt: &pt
text_input_field: 'Campo de texto'
text_input_field_description: 'Este campo permite que os usuários insiram informações baseadas em texto, como nomes ou e-mails.'
signature_field: 'Campo de assinatura'
- signature_field_description: 'Este campo permite coletar assinaturas dos signatários.'
+ signature_field_description: 'Este campo é usado para coletar assinaturas dos signatários.'
added_fields: 'Campos adicionados'
added_fields_description: 'Esta lista exibe todos os campos adicionados ao documento. Você pode reordená-los, editá-los ou removê-los.'
open_field_settings: 'Abrir configurações do campo'
@@ -3917,7 +4032,7 @@ pt: &pt
sign_the_document_description: 'Se você for um dos signatários, este botão permite que você assine o documento.'
send_for_signing: 'Enviar para assinatura'
add_recipients: 'Adicionar destinatários'
- add_recipients_description: 'Adicione novos destinatários para que o documento seja assinado. Você pode inserir seus e-mails ou números de telefone.'
+ add_recipients_description: 'Adicione novos destinatários inserindo seus endereços de e-mail ou números de telefone para assinar o documento.'
settings: 'Configurações'
settings_account_description: 'Com configurações completas de conta, você pode personalizar a experiência de assinatura eletrônica e convidar mais usuários.'
support: 'Suporte'
@@ -3930,6 +4045,7 @@ pt: &pt
read: Ler seus dados
de: &de
+ private: Privat
resend_pending: Ausstehende erneut senden
ensure_unique_recipients: Stellen Sie einzigartige Empfänger sicher
require_phone_2fa_to_open: Telefon-2FA zum Öffnen erforderlich
@@ -4508,6 +4624,7 @@ de: &de
not_invited_yet: Noch nicht eingeladen
not_completed_yet: Noch nicht abgeschlossen
declined_on_time: 'Abgelehnt am %{time}'
+ expire_on_time: 'Ablauf am %{time}'
sign_in_person: Persönlich unterschreiben
create_a_new_template_document_form_or_submit_the_existing_one_html: '
Neue Vorlage erstellen oder
vorhandene einreichen'
send_email_copy_with_completed_documents_to_a_specified_bcc_address: Senden Sie eine E-Mail-Kopie mit abgeschlossenen Dokumenten an eine angegebene BCC-Adresse.
@@ -4628,6 +4745,25 @@ de: &de
name_a_z: Name A-Z
recently_used: Kürzlich verwendet
newest_first: Neueste zuerst
+ none: Keine
+ default_expiration: Standardablauf
+ specified_date: Angegebenes Datum
+ one_day: 1 Tag
+ two_days: 2 Tage
+ three_days: 3 Tage
+ four_days: 4 Tage
+ five_days: 5 Tage
+ six_days: 6 Tage
+ seven_days: 7 Tage
+ eight_days: 8 Tage
+ nine_days: 9 Tage
+ ten_days: 10 Tage
+ two_weeks: 2 Wochen
+ three_weeks: 3 Wochen
+ four_weeks: 4 Wochen
+ one_month: 1 Monat
+ two_months: 2 Monate
+ three_months: 3 Monate
submission_sources:
api: API
bulk: Massenversand
@@ -4636,6 +4772,8 @@ de: &de
link: Link
submission_event_names:
send_email_to_html: '
E-Mail gesendet an %{submitter_name}'
+ bounce_email_html: '
E-Mail zurückgesendet %{submitter_name}'
+ complaint_email_html: '
Spam-Beschwerde %{submitter_name}'
send_reminder_email_to_html: '
Erinnerungs-E-Mail gesendet an %{submitter_name}'
send_sms_to_html: '
SMS gesendet an %{submitter_name}'
send_2fa_sms_to_html: '
Verifizierungs-SMS gesendet an %{submitter_name}'
@@ -4671,11 +4809,11 @@ de: &de
previous: Zurück
next: Weiter
template_and_submissions: 'Vorlagen und Übermittlungen'
- template_and_submissions_description: "Du kannst die Ansicht wählen, die am besten zu deinem Arbeitsablauf passt. Wähle die Ansicht 'Vorlagen', wenn du wiederverwendbare Dokumentenvorlagen erstellst, oder 'Übermittlungen', wenn du einzelne Dokumente unterschreibst oder den Status jeder Signaturanfrage überprüfen möchtest."
+ template_and_submissions_description: "Du kannst die Ansicht wählen, die am besten zu deinem Arbeitsablauf passt. Wähle die Ansicht 'Vorlagen', um wiederverwendbare Dokumentvorlagen zu erstellen, oder 'Übermittlungen', um einzelne Dokumente zu unterschreiben oder den Status jeder Signaturanfrage zu überprüfen."
upload_a_pdf_file: 'PDF-Datei hochladen'
- upload_a_pdf_file_description: 'Lade ein Dokument hoch, um es als Vorlage für ein Signaturformular zu verwenden.'
+ upload_a_pdf_file_description: 'Lade ein PDF-Dokument hoch, um eine Vorlage für ein Signaturformular zu erstellen.'
select_a_signer_party: 'Signaturpartei auswählen'
- select_a_signer_party_description: 'Dieses Dropdown-Menü ermöglicht es dir, eine Signaturrolle auszuwählen oder eine neue Partei zum Dokument hinzuzufügen, wenn es von zwei oder mehr Parteien unterzeichnet werden muss.'
+ select_a_signer_party_description: 'Dieses Dropdown-Menü ermöglicht es dir, eine Signaturrolle auszuwählen oder eine neue Partei zum Dokument hinzuzufügen, wenn es 2 oder mehr Unterschriften erfordert.'
available_parties: 'Verfügbare Parteien'
available_parties_description: 'Diese Liste enthält alle verfügbaren Parteien mit ihren Rollennamen. Nach der Auswahl kannst du Felder für die Partei hinzufügen und konfigurieren.'
available_field_types: 'Verfügbare Feldtypen'
@@ -4683,7 +4821,7 @@ de: &de
text_input_field: 'Textfeld'
text_input_field_description: 'Dieses Feld ermöglicht es Benutzern, textbasierte Informationen wie Namen oder E-Mails einzugeben.'
signature_field: 'Signaturfeld'
- signature_field_description: 'Dieses Feld dient der Erfassung von Signaturen der Unterzeichner.'
+ signature_field_description: 'Dieses Feld wird verwendet, um die Unterschriften der Unterzeichner zu erfassen.'
added_fields: 'Hinzugefügte Felder'
added_fields_description: 'Diese Liste zeigt alle dem Dokument hinzugefügten Felder. Du kannst sie neu anordnen, bearbeiten oder entfernen.'
open_field_settings: 'Feld-Einstellungen öffnen'
@@ -4697,10 +4835,10 @@ de: &de
copy_and_share_link: 'Link kopieren und teilen'
copy_and_share_link_description: 'Kopiere diesen Link, um das Dokument zu teilen. Jeder mit dem Link kann es unterschreiben, nachdem er seine E-Mail-Adresse eingegeben hat.'
sign_the_document: 'Dokument unterschreiben'
- sign_the_document_description: 'Wenn du einer der Unterzeichner bist, kannst du das Dokument mit diesem Button selbst unterschreiben.'
+ sign_the_document_description: 'Wenn du einer der Unterzeichner bist, kannst du das Dokument mit diesem Button unterschreiben.'
send_for_signing: 'Zum Unterschreiben senden'
add_recipients: 'Empfänger hinzufügen'
- add_recipients_description: 'Füge neue Empfänger hinzu, damit das Dokument unterschrieben werden kann. Du kannst deren E-Mail-Adressen oder Telefonnummern eingeben.'
+ add_recipients_description: 'Füge neue Empfänger hinzu, indem du ihre E-Mail-Adressen oder Telefonnummern eingibst, damit sie das Dokument unterschreiben können.'
settings: 'Einstellungen'
settings_account_description: 'Mit umfangreichen Kontoeinstellungen kannst du das Signiererlebnis anpassen und weitere Benutzer einladen.'
support: 'Support'
diff --git a/config/routes.rb b/config/routes.rb
index f5672d4f..ba05e364 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -97,6 +97,7 @@ Rails.application.routes.draw do
resources :templates, only: %i[new create edit update show destroy] do
resource :debug, only: %i[show], controller: 'templates_debug' if Rails.env.development?
resources :documents, only: %i[create], controller: 'template_documents'
+ resources :clone_and_replace, only: %i[create], controller: 'templates_clone_and_replace'
resources :restore, only: %i[create], controller: 'templates_restore'
resources :archived, only: %i[index], controller: 'templates_archived_submissions'
resources :submissions, only: %i[new create]
diff --git a/lib/abilities/template_conditions.rb b/lib/abilities/template_conditions.rb
index 4a7ebf04..e39019b2 100644
--- a/lib/abilities/template_conditions.rb
+++ b/lib/abilities/template_conditions.rb
@@ -5,26 +5,31 @@ module Abilities
module_function
def collection(user, ability: nil)
- template_ids = Template.where(account_id: user.account_id).select(:id)
+ templates = Template.where(account_id: user.account_id)
+
+ return templates unless user.account.testing?
shared_ids =
- TemplateSharing.where({ ability:,
- account_id: [user.account_id, TemplateSharing::ALL_ID] }.compact)
+ TemplateSharing.where({ ability:, account_id: [user.account_id, TemplateSharing::ALL_ID] }.compact)
.select(:template_id)
- join_query = Template.arel_table
- .join(Arel::Nodes::TableAlias.new(template_ids.arel.union(shared_ids.arel), 'union_ids'))
- .on(Template.arel_table[:id].eq(Arel::Table.new(:union_ids)[:id]))
+ join_query =
+ Template.arel_table
+ .join(Arel::Nodes::TableAlias.new(templates.select(:id).arel.union(shared_ids.arel), 'union_ids'))
+ .on(Template.arel_table[:id].eq(Arel::Table.new(:union_ids)[:id]))
Template.joins(join_query.join_sources.first)
end
def entity(template, user:, ability: nil)
+ return true if template.account_id.blank?
return true if template.account_id == user.account_id
+ return false unless user.account.linked_account_account
+ return false if template.template_sharings.to_a.blank?
account_ids = [user.account_id, TemplateSharing::ALL_ID]
- template.template_sharings.any? do |e|
+ template.template_sharings.to_a.any? do |e|
e.account_id.in?(account_ids) && (ability.nil? || e.ability == 'manage' || e.ability == ability)
end
end
diff --git a/lib/ability.rb b/lib/ability.rb
index 960a8beb..a721e089 100644
--- a/lib/ability.rb
+++ b/lib/ability.rb
@@ -4,13 +4,11 @@ class Ability
include CanCan::Ability
def initialize(user)
- can :manage, Template, account_id: user.account_id
-
- can %i[read update create], Template,
- Abilities::TemplateConditions.collection(user) do |template|
+ can %i[read create update], Template, Abilities::TemplateConditions.collection(user) do |template|
Abilities::TemplateConditions.entity(template, user:, ability: 'manage')
end
+ can :destroy, Template, account_id: user.account_id
can :manage, TemplateFolder, account_id: user.account_id
can :manage, TemplateSharing, template: { account_id: user.account_id }
can :manage, Submission, account_id: user.account_id
diff --git a/lib/docuseal.rb b/lib/docuseal.rb
index 15db4be0..3c11deda 100644
--- a/lib/docuseal.rb
+++ b/lib/docuseal.rb
@@ -55,6 +55,10 @@ module Docuseal
ENV['MULTITENANT'] == 'true'
end
+ def advanced_formats?
+ multitenant?
+ end
+
def demo?
ENV['DEMO'] == 'true'
end
diff --git a/lib/replace_email_variables.rb b/lib/replace_email_variables.rb
index ac7732ae..8ad9111b 100644
--- a/lib/replace_email_variables.rb
+++ b/lib/replace_email_variables.rb
@@ -15,6 +15,7 @@ module ReplaceEmailVariables
SUBMITTER_SLUG = /\{+submitter\.slug\}+/i
SUBMISSION_LINK = /\{+submission\.link\}+/i
SUBMISSION_ID = /\{+submission\.id\}+/i
+ SUBMISSION_EXPIRE_AT = /\{+submission\.expire_at\}+/i
SUBMITTERS = /\{+(?:submission\.)?submitters\}+/i
SUBMITTERS_N_EMAIL = /\{+submitters\[(?
\d+)\]\.email\}+/i
SUBMITTERS_N_NAME = /\{+submitters\[(?\d+)\]\.name\}+/i
@@ -48,6 +49,13 @@ module ReplaceEmailVariables
text = replace(text, SENDER_NAME, html_escape:) { submitter.submission.created_by_user&.full_name }
text = replace(text, SENDER_FIRST_NAME, html_escape:) { submitter.submission.created_by_user&.first_name }
+ text = replace(text, SUBMISSION_EXPIRE_AT, html_escape:) do
+ if submitter.submission.expire_at
+ I18n.l(submitter.submission.expire_at.in_time_zone(submitter.submission.account.timezone),
+ format: :short, locale: submitter.submission.account.locale)
+ end
+ end
+
text = replace(text, SUBMITTERS_N_NAME, html_escape:) do |match|
build_submitters_n_field(submitter.submission, match[:index].to_i - 1, :name)
end
diff --git a/lib/submissions.rb b/lib/submissions.rb
index ddb4c3f8..ada1d320 100644
--- a/lib/submissions.rb
+++ b/lib/submissions.rb
@@ -59,10 +59,13 @@ module Submissions
def create_from_emails(template:, user:, emails:, source:, mark_as_sent: false, params: {})
preferences = Submitters.normalize_preferences(user.account, user, params)
+ expire_at = params[:expire_at].presence || Templates.build_default_expire_at(template)
+
parse_emails(emails, user).uniq.map do |email|
submission = template.submissions.new(created_by_user: user,
account_id: user.account_id,
source:,
+ expire_at:,
template_submitters: template.submitters)
submission.submitters.new(email: normalize_email(email),
diff --git a/lib/submissions/create_from_submitters.rb b/lib/submissions/create_from_submitters.rb
index a0c274fa..44adf95e 100644
--- a/lib/submissions/create_from_submitters.rb
+++ b/lib/submissions/create_from_submitters.rb
@@ -16,11 +16,12 @@ module Submissions
set_submission_preferences = submission_preferences.slice('send_email', 'bcc_completed')
set_submission_preferences['send_email'] = true if params['send_completed_email']
+ expire_at = attrs[:expire_at] || Templates.build_default_expire_at(template)
submission = template.submissions.new(created_by_user: user, source:,
account_id: user.account_id,
preferences: set_submission_preferences,
- expire_at: attrs[:expire_at],
+ expire_at:,
template_submitters: [], submitters_order:)
template_submitters = template.submitters.deep_dup
diff --git a/lib/submissions/generate_audit_trail.rb b/lib/submissions/generate_audit_trail.rb
index e1febb51..ecfe9b84 100644
--- a/lib/submissions/generate_audit_trail.rb
+++ b/lib/submissions/generate_audit_trail.rb
@@ -379,7 +379,9 @@ module Submissions
composer.text(I18n.t('event_log'), font_size: 12, padding: [10, 0, 20, 0])
- events_data = submission.submission_events.sort_by(&:event_timestamp).map do |event|
+ events_data = submission.submission_events.sort_by(&:event_timestamp).filter_map do |event|
+ next if event.event_type.in?(%w[bounce_email complaint_email])
+
submitter = submission.submitters.find { |e| e.id == event.submitter_id }
submitter_name =
if event.event_type.include?('sms') || event.event_type.include?('phone')
diff --git a/lib/submissions/generate_result_attachments.rb b/lib/submissions/generate_result_attachments.rb
index 87c04402..5414ff22 100644
--- a/lib/submissions/generate_result_attachments.rb
+++ b/lib/submissions/generate_result_attachments.rb
@@ -209,7 +209,7 @@ module Submissions
font_size = preferences_font_size
font_size ||= (([page.box.width, page.box.height].min / A4_SIZE[0].to_f) * FONT_SIZE).to_i
- fill_color = field.dig('preferences', 'color').presence
+ fill_color = field.dig('preferences', 'color').to_s.delete_prefix('#').presence
font_name = field.dig('preferences', 'font')
font_variant = (field.dig('preferences', 'font_type').presence || 'none').to_sym
diff --git a/lib/submissions/timestamp_handler.rb b/lib/submissions/timestamp_handler.rb
index 03b45d43..a152a97f 100644
--- a/lib/submissions/timestamp_handler.rb
+++ b/lib/submissions/timestamp_handler.rb
@@ -2,7 +2,7 @@
module Submissions
class TimestampHandler
- HASH_ALGORITHM = 'SHA512'
+ HASH_ALGORITHM = 'SHA256'
TimestampError = Class.new(StandardError)
@@ -20,6 +20,7 @@ module Submissions
signature[:SubFilter] = :'ETSI.RFC3161'
end
+ # rubocop:disable Metrics
def sign(io, byte_range)
digest = OpenSSL::Digest.new(HASH_ALGORITHM)
@@ -34,7 +35,7 @@ module Submissions
c.basic_auth(uri.user, uri.password) if uri.password.present?
end
- response = conn.post(uri.path, build_payload(digest.digest),
+ response = conn.post(uri.request_uri, build_payload(digest.digest),
'content-type' => 'application/timestamp-query')
if response.status != 200 || response.body.blank?
@@ -49,7 +50,13 @@ module Submissions
end
OpenSSL::Timestamp::Response.new(response.body).token.to_der
+ rescue StandardError => e
+ Rollbar.error(e) if defined?(Rollbar)
+ Rails.logger.error(e)
+
+ OpenSSL::ASN1::GeneralizedTime.new(Time.now.utc).to_der
end
+ # rubocop:enable Metrics
def build_payload(digest)
req = OpenSSL::Timestamp::Request.new
diff --git a/lib/submitters/serialize_for_api.rb b/lib/submitters/serialize_for_api.rb
index 01f1246d..ee5046c1 100644
--- a/lib/submitters/serialize_for_api.rb
+++ b/lib/submitters/serialize_for_api.rb
@@ -27,6 +27,10 @@ module Submitters
additional_attrs['fields'] = SerializeForWebhook.build_fields_array(submitter)
end
+ if with_template
+ additional_attrs['template'] = submitter.submission.template.as_json(only: %i[id name created_at updated_at])
+ end
+
additional_attrs['values'] = SerializeForWebhook.build_values_array(submitter) if with_values
additional_attrs['documents'] = SerializeForWebhook.build_documents_array(submitter) if with_documents
additional_attrs['preferences'] = submitter.preferences.except('default_values')
@@ -41,10 +45,7 @@ module Submitters
Rails.application.routes.url_helpers.submit_form_url(slug: submitter.slug, **Docuseal.default_url_options)
end
- include_params = {}
- include_params[:template] = { only: %i[id name created_at updated_at] } if with_template
-
- submitter.as_json(SERIALIZE_PARAMS.merge(include: include_params)).merge(additional_attrs)
+ submitter.as_json(SERIALIZE_PARAMS).merge(additional_attrs)
end
def serialize_events(events)
diff --git a/lib/submitters/serialize_for_webhook.rb b/lib/submitters/serialize_for_webhook.rb
index f856a086..9e897ef3 100644
--- a/lib/submitters/serialize_for_webhook.rb
+++ b/lib/submitters/serialize_for_webhook.rb
@@ -34,8 +34,10 @@ module Submitters
'audit_log_url' => submitter.submission.audit_log_url,
'submission_url' => r.submissions_preview_url(submitter.submission.slug,
**Docuseal.default_url_options),
- 'template' => submitter.template.as_json(only: %i[id name external_id created_at updated_at],
- methods: %i[folder_name]),
+ 'template' => submitter.submission.template.as_json(
+ only: %i[id name external_id created_at updated_at],
+ methods: %i[folder_name]
+ ),
'submission' => {
**submitter.submission.slice(:id, :audit_log_url, :combined_document_url, :created_at),
status: build_submission_status(submitter.submission),
diff --git a/lib/templates.rb b/lib/templates.rb
index 48407d51..35651634 100644
--- a/lib/templates.rb
+++ b/lib/templates.rb
@@ -1,6 +1,25 @@
# frozen_string_literal: true
module Templates
+ EXPIRATION_DURATIONS = {
+ one_day: 1.day,
+ two_days: 2.days,
+ three_days: 3.days,
+ four_days: 4.days,
+ five_days: 5.days,
+ six_days: 6.days,
+ seven_days: 7.days,
+ eight_days: 8.days,
+ nine_days: 9.days,
+ ten_days: 10.days,
+ two_weeks: 14.days,
+ three_weeks: 21.days,
+ four_weeks: 28.days,
+ one_month: 1.month,
+ two_months: 2.months,
+ three_months: 3.months
+ }.with_indifferent_access.freeze
+
module_function
def build_field_areas_index(fields)
@@ -30,4 +49,17 @@ module Templates
item['linked_to_uuid'].blank? && item['is_requester'].blank? && item['email'].blank?
end
end
+
+ def build_default_expire_at(template)
+ default_expire_at_duration = template.preferences['default_expire_at_duration'].presence
+ default_expire_at = template.preferences['default_expire_at'].presence
+
+ return if default_expire_at_duration.blank?
+
+ if default_expire_at_duration == 'specified_date' && default_expire_at.present?
+ Time.zone.parse(default_expire_at)
+ elsif EXPIRATION_DURATIONS[default_expire_at_duration]
+ Time.current + EXPIRATION_DURATIONS[default_expire_at_duration]
+ end
+ end
end
diff --git a/lib/templates/clone.rb b/lib/templates/clone.rb
index 2c15858f..0fe3b91b 100644
--- a/lib/templates/clone.rb
+++ b/lib/templates/clone.rb
@@ -4,6 +4,7 @@ module Templates
module Clone
module_function
+ # rubocop:disable Metrics, Style/CombinableLoops
def call(original_template, author:, external_id: nil, name: nil, folder_name: nil)
template = original_template.account.templates.new
@@ -29,10 +30,13 @@ module Templates
template.schema.first['name'] = template.name
end
+ original_template.template_accesses.each do |template_access|
+ template.template_accesses.new(user_id: template_access.user_id)
+ end
+
template
end
- # rubocop:disable Metrics, Style/CombinableLoops
def update_submitters_and_fields_and_schema(cloned_submitters, cloned_fields, cloned_schema, cloned_preferences)
submitter_uuids_replacements = {}
field_uuids_replacements = {}
diff --git a/lib/templates/clone_attachments.rb b/lib/templates/clone_attachments.rb
index 8b08735d..2cbcb3b3 100644
--- a/lib/templates/clone_attachments.rb
+++ b/lib/templates/clone_attachments.rb
@@ -4,10 +4,12 @@ module Templates
module CloneAttachments
module_function
- def call(template:, original_template:, documents: [])
+ def call(template:, original_template:, documents: [], excluded_attachment_uuids: [])
schema_uuids_replacements = {}
template.schema.each_with_index do |schema_item, index|
+ next if excluded_attachment_uuids.include?(schema_item['attachment_uuid'])
+
new_schema_item_uuid = SecureRandom.uuid
schema_uuids_replacements[schema_item['attachment_uuid']] = new_schema_item_uuid
@@ -22,17 +24,22 @@ module Templates
next if field['areas'].blank?
field['areas'].each do |area|
- area['attachment_uuid'] = schema_uuids_replacements[area['attachment_uuid']]
+ new_attachment_uuid = schema_uuids_replacements[area['attachment_uuid']]
+ area['attachment_uuid'] = new_attachment_uuid if new_attachment_uuid
end
end
template.save!
- original_template.schema_documents.map do |document|
+ original_template.schema_documents.filter_map do |document|
+ new_attachment_uuid = schema_uuids_replacements[document.uuid]
+
+ next unless new_attachment_uuid
+
new_document =
ApplicationRecord.no_touching do
template.documents_attachments.create!(
- uuid: schema_uuids_replacements[document.uuid],
+ uuid: new_attachment_uuid,
blob_id: document.blob_id
)
end
diff --git a/lib/templates/find_acro_fields.rb b/lib/templates/find_acro_fields.rb
index b9fcc3d8..b02bbdfc 100644
--- a/lib/templates/find_acro_fields.rb
+++ b/lib/templates/find_acro_fields.rb
@@ -161,7 +161,7 @@ module Templates
options: build_options(field.allowed_values, 'radio'),
default_value: selected_option
}
- elsif field.field_type == :Btn && field.concrete_field_type == :check_box
+ elsif field.field_type == :Btn && %i[check_box radio_button].include?(field.concrete_field_type)
{
**attrs,
type: 'checkbox',
diff --git a/lib/templates/replace_attachments.rb b/lib/templates/replace_attachments.rb
new file mode 100644
index 00000000..0333d897
--- /dev/null
+++ b/lib/templates/replace_attachments.rb
@@ -0,0 +1,65 @@
+# frozen_string_literal: true
+
+module Templates
+ module ReplaceAttachments
+ module_function
+
+ # rubocop:disable Metrics
+ def call(template, params = {}, extract_fields: false)
+ documents = Templates::CreateAttachments.call(template, params, extract_fields:)
+ submitter = template.submitters.first
+
+ documents.each_with_index do |document, index|
+ replaced_document_schema = template.schema[index]
+
+ template.schema[index] = { attachment_uuid: document.uuid, name: document.filename.base }
+
+ if replaced_document_schema
+ template.fields.each do |field|
+ next if field['areas'].blank?
+
+ field['areas'].each do |area|
+ if area['attachment_uuid'] == replaced_document_schema['attachment_uuid']
+ area['attachment_uuid'] = document.uuid
+ end
+ end
+ end
+ end
+
+ next if template.fields.any? { |f| f['areas']&.any? { |a| a['attachment_uuid'] == document.uuid } }
+ next if submitter.blank? || document.metadata.dig('pdf', 'fields').blank?
+
+ pdf_fields = document.metadata['pdf'].delete('fields').to_a
+ pdf_fields.each { |f| f['submitter_uuid'] = submitter['uuid'] }
+
+ if index.positive? && pdf_fields.present?
+ preview_document = template.schema[index - 1]
+ preview_document_last_field = template.fields.reverse.find do |f|
+ f['areas']&.any? do |a|
+ a['attachment_uuid'] == preview_document[:attachment_uuid]
+ end
+ end
+
+ if preview_document_last_field
+ last_preview_document_field_index = template.fields.find_index do |f|
+ f['uuid'] == preview_document_last_field['uuid']
+ end
+ end
+
+ if last_preview_document_field_index
+ template.fields.insert(index, *pdf_fields)
+ else
+ template.fields += pdf_fields
+ end
+ elsif pdf_fields.present?
+ template.fields += pdf_fields
+
+ template.schema[index]['pending_fields'] = true
+ end
+ end
+
+ documents
+ end
+ # rubocop:enable Metrics
+ end
+end
diff --git a/spec/signing_form_helper.rb b/spec/signing_form_helper.rb
index b00d5f8b..a0b05a2a 100644
--- a/spec/signing_form_helper.rb
+++ b/spec/signing_form_helper.rb
@@ -47,7 +47,7 @@ module SigningFormHelper
drawStep();
JS
- sleep 0.5
+ sleep 0.1
end
def field_value(submitter, field_name)