2023-12-19 12:51:30 +01:00
|
|
|
|
= render partial: 'administrateurs/breadcrumbs',
|
|
|
|
|
locals: { steps: [['Démarches', admin_procedures_path],
|
|
|
|
|
[@procedure.libelle.truncate_words(10), admin_procedure_path(@procedure)],
|
|
|
|
|
['Attestation']] }
|
|
|
|
|
|
2023-12-22 14:13:20 +01:00
|
|
|
|
= render NestedForms::FormOwnerComponent.new
|
2023-12-22 14:24:39 +01:00
|
|
|
|
= form_for @attestation_template, url: admin_procedure_attestation_template_v2_path(@procedure), html: { multipart: true },
|
|
|
|
|
data: { turbo: 'true',
|
|
|
|
|
controller: 'autosubmit attestation',
|
2024-02-01 18:55:41 +01:00
|
|
|
|
autosubmit_debounce_delay_value: 1000,
|
2023-12-22 14:24:39 +01:00
|
|
|
|
attestation_logo_attachment_official_label_value: AttestationTemplate.human_attribute_name(:logo_additional),
|
|
|
|
|
attestation_logo_attachment_free_label_value: AttestationTemplate.human_attribute_name(:logo) } do |f|
|
|
|
|
|
|
2024-02-13 14:16:33 +01:00
|
|
|
|
#attestation-edit.fr-container.fr-my-4w{ data: { controller: 'tiptap', tiptap_insert_after_tag_value: ' ' } }
|
2024-01-12 12:20:06 +01:00
|
|
|
|
.fr-mb-6w
|
|
|
|
|
= render Dsfr::AlertComponent.new(state: :info, title: "Nouvel éditeur d’attestation", heading_level: 'h3') do |c|
|
|
|
|
|
- c.with_body do
|
|
|
|
|
Cette page permet la mise en forme de l’attestation avec un nouvel éditeur plus flexible
|
|
|
|
|
tout en respectant la charte de l’état. Essayez-la et donnez-nous votre avis
|
|
|
|
|
en nous envoyant un email à #{mail_to(CONTACT_EMAIL, subject: "Feedback attestation v2")}.
|
|
|
|
|
%br
|
|
|
|
|
%strong Les attestations délivrées suivent encore l’ancien format :
|
|
|
|
|
l’activation des attestations basées sur ce format sera bientôt disponible.
|
|
|
|
|
%br
|
|
|
|
|
|
|
|
|
|
= link_to("Suivez ce lien pour revenir aux attestations actuellement délivrées", edit_admin_procedure_attestation_template_path(@procedure))
|
|
|
|
|
|
2023-12-22 14:24:39 +01:00
|
|
|
|
.fr-grid-row.fr-grid-row--gutters
|
2024-02-13 14:16:33 +01:00
|
|
|
|
.fr-col-12.fr-col-lg-7
|
2023-12-19 12:51:30 +01:00
|
|
|
|
%fieldset.fr-fieldset{ aria: { labelledby: 'edit-attestation' } }
|
|
|
|
|
%legend.fr-fieldset__legend#edit-attestation
|
|
|
|
|
%h1.fr-h2 Attestation
|
|
|
|
|
%p.fr-text--regular
|
|
|
|
|
L’attestation est émise au moment où un dossier est accepté, elle est jointe à l’email d’accusé d’acceptation.
|
|
|
|
|
Elle est également disponible au téléchargement depuis l’espace personnel de l’usager.
|
|
|
|
|
|
2024-01-25 13:20:43 +01:00
|
|
|
|
.fr-fieldset__element
|
|
|
|
|
%h2.fr-h4 En-tête
|
|
|
|
|
|
2023-12-22 14:24:39 +01:00
|
|
|
|
.fr-fieldset__element
|
|
|
|
|
.fr-toggle
|
|
|
|
|
= f.check_box :official_layout, class: "fr-toggle-input", id: dom_id(@attestation_template, :official_layout), data: { "attestation-target": "layoutToggle"}
|
|
|
|
|
%label.fr-toggle__label{ for: dom_id(@attestation_template, :official_layout), data: { fr_checked_label: "Activé", fr_unchecked_label: "Désactivé" } }
|
|
|
|
|
Je souhaite générer une attestation à la charte de l’état (logo avec Marianne)
|
|
|
|
|
|
|
|
|
|
.fr-fieldset__element{ class: class_names("hidden" => !@attestation_template.official_layout?), data: { "attestation-target": 'logoMarianneLabelFieldset'} }
|
2024-02-19 16:22:40 +01:00
|
|
|
|
= render Dsfr::InputComponent.new(form: f, attribute: :label_logo, input_type: :text_area, required: @attestation_template.official_layout?, opts: { rows: 3, data: { controller: :textarea, textarea_max_rows_value: 5 } }) do |c|
|
|
|
|
|
- c.with_hint { "Exemple: Ministère de la Mer. 5 lignes maximum" }
|
2023-12-19 12:51:30 +01:00
|
|
|
|
|
2023-12-22 14:24:39 +01:00
|
|
|
|
.fr-fieldset__element{ data: { attestation_target: 'logoAttachmentFieldset' } }
|
|
|
|
|
%label.fr-label{ for: field_id(@attestation_template, :logo) }
|
|
|
|
|
- if @attestation_template.official_layout?
|
|
|
|
|
= AttestationTemplate.human_attribute_name(:logo_additional)
|
|
|
|
|
- else
|
|
|
|
|
= AttestationTemplate.human_attribute_name(:logo)
|
|
|
|
|
|
|
|
|
|
%span.fr-hint-text
|
|
|
|
|
Dimensions conseillées : au minimum 500px de largeur ou de hauteur.
|
|
|
|
|
|
2023-12-22 14:13:20 +01:00
|
|
|
|
%div{ id: dom_id(@attestation_template, :logo_attachment) }
|
|
|
|
|
= render Attachment::EditComponent.new(attached_file: @attestation_template.logo, direct_upload: false)
|
|
|
|
|
|
2023-12-19 12:51:30 +01:00
|
|
|
|
.fr-fieldset__element
|
2024-01-10 17:24:36 +01:00
|
|
|
|
= render Dsfr::InputComponent.new(form: f, attribute: :label_direction, input_type: :text_area, required: false, opts: { rows: 2, data: { controller: :textarea, textarea_max_rows_value: 2 } }) do |c|
|
2023-12-19 12:51:30 +01:00
|
|
|
|
- c.with_hint { "Exemple: Direction interministérielle du numérique. 2 lignes maximum" }
|
|
|
|
|
|
2024-02-13 10:43:42 +01:00
|
|
|
|
.fr-fieldset__element.fr-mt-3w
|
2024-02-01 18:55:41 +01:00
|
|
|
|
.fr-input-group{ class: class_names("fr-input-group--error" => f.object.errors.include?(:json_body)) }
|
|
|
|
|
%label.fr-label.fr-h4
|
|
|
|
|
= AttestationTemplate.human_attribute_name :body
|
|
|
|
|
= render EditableChamp::AsteriskMandatoryComponent.new
|
2023-12-19 12:51:30 +01:00
|
|
|
|
|
2024-02-13 10:43:42 +01:00
|
|
|
|
.flex.flex-gap-2.fr-mb-2w
|
|
|
|
|
- @buttons.each do |buttons|
|
|
|
|
|
.flex.flex-gap-1
|
|
|
|
|
- buttons.each do |(label, action, icon)|
|
|
|
|
|
%button.fr-btn.fr-btn--secondary.fr-btn--sm{ type: 'button', title: label, class: icon == :hidden ? "hidden" : "fr-icon-#{icon}", data: { action: 'click->tiptap#menuButton', tiptap_target: 'button', tiptap_action: action } }
|
|
|
|
|
= label
|
|
|
|
|
|
2024-02-01 18:55:41 +01:00
|
|
|
|
#editor.editor{ data: { tiptap_target: 'editor' }, aria: { describedby: dom_id(f.object, "json-body-messages")} }
|
|
|
|
|
= f.hidden_field :tiptap_body, data: { tiptap_target: 'input' }
|
|
|
|
|
|
|
|
|
|
.fr-error-text{ id: dom_id(f.object, "json-body-messages"), class: class_names("hidden" => !f.object.errors.include?(:json_body)) }
|
|
|
|
|
- if f.object.errors.include?(:json_body)
|
|
|
|
|
= render partial: "shared/errors_list", locals: { object: f.object, attribute: :json_body }
|
2023-12-19 12:51:30 +01:00
|
|
|
|
|
|
|
|
|
.fr-fieldset__element
|
2024-01-19 10:14:14 +01:00
|
|
|
|
%p.fr-hint-text
|
2024-01-25 13:20:43 +01:00
|
|
|
|
Tapez le caractère
|
|
|
|
|
%strong.fr-text-title--grey @
|
|
|
|
|
suivi du nom de la balise, ou cliquez sur les boutons ci-dessous. Les champs conditionnés ne sont pas disponibles.
|
2023-12-19 12:51:30 +01:00
|
|
|
|
|
2024-01-19 10:14:14 +01:00
|
|
|
|
= render TagsButtonListComponent.new(tags: @attestation_template.tags_categorized)
|
2024-01-18 13:12:09 +01:00
|
|
|
|
|
2023-12-19 12:51:30 +01:00
|
|
|
|
.fr-fieldset__element.fr-mt-2w
|
2024-01-19 10:14:14 +01:00
|
|
|
|
%h2.fr-h4 Pied de page
|
2023-12-19 12:51:30 +01:00
|
|
|
|
|
|
|
|
|
.fr-fieldset__element
|
|
|
|
|
%label.fr-label{ for: field_id(@attestation_template, :signature) } Tampon ou signature
|
|
|
|
|
%span.fr-hint-text
|
|
|
|
|
Dimensions conseillées : au minimum 500px de largeur ou de hauteur.
|
2023-12-22 14:13:20 +01:00
|
|
|
|
|
|
|
|
|
%div{ id: dom_id(@attestation_template, :signature_attachment) }
|
|
|
|
|
= render Attachment::EditComponent.new(attached_file: @attestation_template.signature, direct_upload: false)
|
2023-12-19 12:51:30 +01:00
|
|
|
|
|
|
|
|
|
.fr-fieldset__element
|
2024-01-10 17:24:36 +01:00
|
|
|
|
= render Dsfr::InputComponent.new(form: f, attribute: :footer, input_type: :text_area, required: false, opts: { rows: 3, data: { controller: :textarea, textarea_max_rows_value: 3 } }) do |c|
|
2023-12-19 12:51:30 +01:00
|
|
|
|
- c.with_hint { "Exemple: 20 avenue de Ségur, 75007 Paris" }
|
|
|
|
|
|
2024-02-13 14:16:33 +01:00
|
|
|
|
#preview-column.fr-col-12.fr-col-lg-5.fr-background-alt--blue-france
|
|
|
|
|
.sticky--top.fr-px-1w
|
|
|
|
|
.flex.justify-between.align-center
|
|
|
|
|
%h2.fr-h4 Aperçu
|
|
|
|
|
%p= link_to 'Prévisualiser en taille réelle', admin_procedure_attestation_template_v2_path(@procedure, format: :pdf), class: 'fr-link', target: '_blank', rel: 'noopener'
|
|
|
|
|
%iframe.attestation-preview{ title: "Aperçu", src: admin_procedure_attestation_template_v2_path(@procedure, format: :pdf), data: { attestation_target: 'preview' } }
|
|
|
|
|
%p.fr-hint-text
|
|
|
|
|
L’aperçu est mis à jour automatiquement après chaque modification.
|
|
|
|
|
Pour générer un aperçu fidèle avec tous les champs et les dates, créez-vous un dossier et acceptez-le : l’aperçu l’utilisera.
|
2023-12-22 14:14:41 +01:00
|
|
|
|
|
|
|
|
|
.padded-fixed-footer
|
|
|
|
|
.fixed-footer
|
|
|
|
|
.fr-container
|
|
|
|
|
.fr-grid-row
|
2024-01-25 14:17:01 +01:00
|
|
|
|
.fr-col-12.fr-col-md-7
|
2023-12-22 14:14:41 +01:00
|
|
|
|
%ul.fr-btns-group.fr-btns-group--inline-md
|
|
|
|
|
%li
|
2024-01-25 14:17:01 +01:00
|
|
|
|
= link_to admin_procedure_path(id: @procedure), class: 'fr-btn fr-btn--secondary' do
|
|
|
|
|
%span.fr-icon-arrow-go-back-line.fr-icon--sm.fr-mr-1v
|
|
|
|
|
Revenir à la démarche
|
|
|
|
|
|
|
|
|
|
.fr-col-12.fr-col-md-5
|
2024-01-12 12:20:06 +01:00
|
|
|
|
-# .fr-toggle
|
|
|
|
|
-# = f.check_box :activated, class: "fr-toggle-input", disabled: true, id: dom_id(@attestation_template, :activated)
|
|
|
|
|
-# %label.fr-toggle__label{ for: dom_id(@attestation_template, :activated), data: { fr_checked_label: "Attestation activée", fr_unchecked_label: "Attestation désactivée" } }
|
2024-01-25 14:17:01 +01:00
|
|
|
|
.text-right
|
|
|
|
|
%span#autosave-notice
|
|
|
|
|
%p.fr-hint-text L’activation de cette attestation sera bientôt disponible.
|