refactor(gallery): add attachment_gallery_item component
This commit is contained in:
parent
6b1c6a796a
commit
bae752f1aa
6 changed files with 96 additions and 39 deletions
22
app/components/attachment/gallery_item_component.rb
Normal file
22
app/components/attachment/gallery_item_component.rb
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class Attachment::GalleryItemComponent < ApplicationComponent
|
||||||
|
include GalleryHelper
|
||||||
|
attr_reader :attachment
|
||||||
|
|
||||||
|
def initialize(attachment:)
|
||||||
|
@attachment = attachment
|
||||||
|
end
|
||||||
|
|
||||||
|
def blob
|
||||||
|
attachment.blob
|
||||||
|
end
|
||||||
|
|
||||||
|
def libelle
|
||||||
|
attachment.record.class.in?([Champs::PieceJustificativeChamp, Champs::TitreIdentiteChamp]) ? attachment.record.libelle : 'Pièce jointe au message'
|
||||||
|
end
|
||||||
|
|
||||||
|
def title
|
||||||
|
"#{libelle} -- #{sanitize(blob.filename.to_s)}"
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,27 @@
|
||||||
|
.gallery-item
|
||||||
|
- if displayable_pdf?(blob)
|
||||||
|
= link_to blob.url, id: blob.id, data: { iframe: true, src: blob.url }, class: 'gallery-link', type: blob.content_type, title: title do
|
||||||
|
.thumbnail
|
||||||
|
= image_tag(preview_url_for(attachment), loading: :lazy)
|
||||||
|
.fr-btn.fr-btn--tertiary.fr-btn--icon-left.fr-icon-eye{ role: :button }
|
||||||
|
Visualiser
|
||||||
|
.champ-libelle
|
||||||
|
= libelle.truncate(25)
|
||||||
|
= render Attachment::ShowComponent.new(attachment: attachment, truncate: true)
|
||||||
|
|
||||||
|
- elsif displayable_image?(blob)
|
||||||
|
= link_to image_url(blob_url(attachment)), title: title, data: { src: blob.url }, class: 'gallery-link' do
|
||||||
|
.thumbnail
|
||||||
|
= image_tag(variant_url_for(attachment), loading: :lazy)
|
||||||
|
.fr-btn.fr-btn--tertiary.fr-btn--icon-left.fr-icon-eye{ role: :button }
|
||||||
|
Visualiser
|
||||||
|
.champ-libelle
|
||||||
|
= libelle.truncate(25)
|
||||||
|
= render Attachment::ShowComponent.new(attachment: attachment, truncate: true)
|
||||||
|
|
||||||
|
- else
|
||||||
|
.thumbnail
|
||||||
|
= image_tag('apercu-indisponible.png')
|
||||||
|
.champ-libelle
|
||||||
|
= libelle.truncate(25)
|
||||||
|
= render Attachment::ShowComponent.new(attachment: attachment, truncate: true)
|
|
@ -373,23 +373,18 @@ module Instructeurs
|
||||||
def pieces_jointes
|
def pieces_jointes
|
||||||
@dossier = current_instructeur.dossiers.find(params[:dossier_id])
|
@dossier = current_instructeur.dossiers.find(params[:dossier_id])
|
||||||
|
|
||||||
champs_attachments_and_libelles = @dossier
|
champs_attachments = @dossier
|
||||||
.champs
|
.champs
|
||||||
.filter { _1.class.in?([Champs::PieceJustificativeChamp, Champs::TitreIdentiteChamp]) }
|
.filter { _1.class.in?([Champs::PieceJustificativeChamp, Champs::TitreIdentiteChamp]) }
|
||||||
.flat_map do |c|
|
.flat_map(&:piece_justificative_file)
|
||||||
c.piece_justificative_file.map do |attachment|
|
|
||||||
[attachment, c.libelle]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
commentaires_attachments_and_libelles = @dossier
|
commentaires_attachments = @dossier
|
||||||
.commentaires
|
.commentaires
|
||||||
.map(&:piece_jointe)
|
.map(&:piece_jointe)
|
||||||
.map(&:attachments)
|
.map(&:attachments)
|
||||||
.flatten
|
.flatten
|
||||||
.map { [_1, 'Messagerie'] }
|
|
||||||
|
|
||||||
@attachments_and_libelles = champs_attachments_and_libelles + commentaires_attachments_and_libelles
|
@gallery_attachments = champs_attachments + commentaires_attachments
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
|
@ -4,32 +4,5 @@
|
||||||
|
|
||||||
.fr-container
|
.fr-container
|
||||||
.gallery.gallery-pieces-jointes{ "data-controller": "lightbox" }
|
.gallery.gallery-pieces-jointes{ "data-controller": "lightbox" }
|
||||||
- @attachments_and_libelles.each do |attachment, libelle|
|
- @gallery_attachments.each do |attachment|
|
||||||
.gallery-item
|
= render Attachment::GalleryItemComponent.new(attachment:)
|
||||||
- blob = attachment.blob
|
|
||||||
- if displayable_pdf?(blob)
|
|
||||||
= link_to blob.url, id: blob.id, data: { iframe: true, src: blob.url }, class: 'gallery-link', type: blob.content_type, title: "#{libelle} -- #{sanitize(blob.filename.to_s)}" do
|
|
||||||
.thumbnail
|
|
||||||
= image_tag(preview_url_for(attachment), loading: :lazy)
|
|
||||||
.fr-btn.fr-btn--tertiary.fr-btn--icon-left.fr-icon-eye{ role: :button }
|
|
||||||
Visualiser
|
|
||||||
.champ-libelle
|
|
||||||
= libelle.truncate(25)
|
|
||||||
= render Attachment::ShowComponent.new(attachment: attachment, truncate: true)
|
|
||||||
|
|
||||||
- elsif displayable_image?(blob)
|
|
||||||
= link_to image_url(blob_url(attachment)), title: "#{libelle} -- #{sanitize(blob.filename.to_s)}", data: { src: blob.url }, class: 'gallery-link' do
|
|
||||||
.thumbnail
|
|
||||||
= image_tag(variant_url_for(attachment), loading: :lazy)
|
|
||||||
.fr-btn.fr-btn--tertiary.fr-btn--icon-left.fr-icon-eye{ role: :button }
|
|
||||||
Visualiser
|
|
||||||
.champ-libelle
|
|
||||||
= libelle.truncate(25)
|
|
||||||
= render Attachment::ShowComponent.new(attachment: attachment, truncate: true)
|
|
||||||
|
|
||||||
- else
|
|
||||||
.thumbnail
|
|
||||||
= image_tag('apercu-indisponible.png')
|
|
||||||
.champ-libelle
|
|
||||||
= libelle.truncate(25)
|
|
||||||
= render Attachment::ShowComponent.new(attachment: attachment, truncate: true)
|
|
||||||
|
|
38
spec/components/attachment/gallery_item_component_spec.rb
Normal file
38
spec/components/attachment/gallery_item_component_spec.rb
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.describe Attachment::GalleryItemComponent, type: :component do
|
||||||
|
let(:procedure) { create(:procedure, :published, types_de_champ_public:) }
|
||||||
|
let(:types_de_champ_public) { [{ type: :piece_justificative }] }
|
||||||
|
let(:dossier) { create(:dossier, :with_populated_champs, :en_construction, procedure:) }
|
||||||
|
let(:filename) { attachment.blob.filename.to_s }
|
||||||
|
|
||||||
|
let(:component) { described_class.new(attachment: attachment) }
|
||||||
|
|
||||||
|
subject { render_inline(component).to_html }
|
||||||
|
|
||||||
|
context "when attachment is from a piece justificative champ" do
|
||||||
|
let(:champ) { dossier.champs.first }
|
||||||
|
let(:libelle) { champ.libelle }
|
||||||
|
let(:attachment) { champ.piece_justificative_file.attachments.first }
|
||||||
|
|
||||||
|
it "displays libelle, link and renders title" do
|
||||||
|
expect(subject).to have_text(libelle)
|
||||||
|
expect(subject).not_to have_text('Pièce jointe au message')
|
||||||
|
expect(subject).to have_link(filename)
|
||||||
|
expect(component.title).to eq("#{libelle} -- #{filename}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "when attachment is from a commentaire" do
|
||||||
|
let(:commentaire) { create(:commentaire, :with_file, dossier: dossier) }
|
||||||
|
let(:attachment) { commentaire.piece_jointe.first }
|
||||||
|
|
||||||
|
it "displays a generic libelle, link and renders title" do
|
||||||
|
expect(subject).to have_text('Pièce jointe au message')
|
||||||
|
expect(subject).to have_link(filename)
|
||||||
|
expect(component.title).to eq("Pièce jointe au message -- #{filename}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -1513,7 +1513,9 @@ describe Instructeurs::DossiersController, type: :controller do
|
||||||
expect(response.body).to include('Télécharger le fichier logo_test_procedure.png')
|
expect(response.body).to include('Télécharger le fichier logo_test_procedure.png')
|
||||||
expect(response.body).to include('Télécharger le fichier RIB.pdf')
|
expect(response.body).to include('Télécharger le fichier RIB.pdf')
|
||||||
expect(response.body).to include('Visualiser')
|
expect(response.body).to include('Visualiser')
|
||||||
expect(assigns(:attachments_and_libelles).count).to eq 3
|
expect(assigns(:gallery_attachments).count).to eq 3
|
||||||
|
expect(assigns(:gallery_attachments)).to all(be_a(ActiveStorage::Attachment))
|
||||||
|
expect([Champs::PieceJustificativeChamp, Champs::TitreIdentiteChamp, Commentaire]).to include(*assigns(:gallery_attachments).map { _1.record.class })
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue