feat(dossiers): bring back export all dossiers

This commit is contained in:
Paul Chavard 2022-05-17 17:54:41 +02:00
parent 4fe6ae1b79
commit 0dfc015690
8 changed files with 18 additions and 11 deletions

View file

@ -1,5 +1,5 @@
class Dossiers::ExportComponent < ApplicationComponent class Dossiers::ExportComponent < ApplicationComponent
def initialize(procedure:, exports:, statut:, count:) def initialize(procedure:, exports:, statut: nil, count: nil)
@procedure = procedure @procedure = procedure
@exports = exports @exports = exports
@statut = statut @statut = statut

View file

@ -7,6 +7,7 @@ en:
everything_short: Ask an export in format%{export_format} everything_short: Ask an export in format%{export_format}
everything_pending_html: Ask an export in format %{export_format} is being generated<br>(ask %{export_time} ago) everything_pending_html: Ask an export in format %{export_format} is being generated<br>(ask %{export_time} ago)
everything_ready_html: Download the export in format %{export_format}<br>(generated %{export_time} ago) everything_ready_html: Download the export in format %{export_format}<br>(generated %{export_time} ago)
download_all: Download all files
download: download:
one: Download a file one: Download a file
other: Download %{count} files other: Download %{count} files

View file

@ -7,6 +7,7 @@ fr:
everything_short: Demander un export au format %{export_format} everything_short: Demander un export au format %{export_format}
everything_pending_html: Un export au format %{export_format} est en train dêtre généré<br>(demandé il y a %{export_time}) everything_pending_html: Un export au format %{export_format} est en train dêtre généré<br>(demandé il y a %{export_time})
everything_ready_html: Télécharger lexport au format %{export_format}<br>(généré il y a %{export_time}) everything_ready_html: Télécharger lexport au format %{export_format}<br>(généré il y a %{export_time})
download_all: Télécharger tous les dossiers
download: download:
one: Télécharger un dossier one: Télécharger un dossier
other: Télécharger %{count} dossiers other: Télécharger %{count} dossiers

View file

@ -1,16 +1,15 @@
%span.dropdown{ data: { controller: 'menu-button' } } %span.dropdown{ data: { controller: 'menu-button' } }
%button.button.dropdown-button{ data: { menu_button_target: 'button' } } %button.button.dropdown-button{ data: { menu_button_target: 'button' } }
= t(".download", count: @count) - if @count.nil?
= t(".download_all")
- else
= t(".download", count: @count)
#download-menu.dropdown-content.fade-in-down{ style: 'width: 450px', data: { menu_button_target: 'menu' } } #download-menu.dropdown-content.fade-in-down{ style: 'width: 450px', data: { menu_button_target: 'menu' } }
%ul.dropdown-items{ 'data-turbo': 'true' } %ul.dropdown-items{ 'data-turbo': 'true' }
- exports.each do |item| - exports.each do |item|
- export = item[:export] - export = item[:export]
%li %li
- if export.nil? - if export.nil?
// i18n-tasks-use t('.everything_csv_html')
// i18n-tasks-use t('.everything_xlsx_html')
// i18n-tasks-use t('.everything_ods_html')
// i18n-tasks-use t('.everything_zip_html')
= link_to t(".everything_#{item[:format]}_html"), download_export_path(export_format: item[:format]), data: { turbo_method: :post } = link_to t(".everything_#{item[:format]}_html"), download_export_path(export_format: item[:format]), data: { turbo_method: :post }
- elsif export.ready? - elsif export.ready?
= link_to ready_link_label(export), export.file.service_url, target: "_blank", rel: "noopener" = link_to ready_link_label(export), export.file.service_url, target: "_blank", rel: "noopener"

View file

@ -49,9 +49,7 @@ class Export < ApplicationRecord
after_create_commit :compute_async after_create_commit :compute_async
FORMATS_WITH_TIME_SPAN = [:xlsx, :ods, :csv].flat_map do |format| FORMATS_WITH_TIME_SPAN = [:xlsx, :ods, :csv].flat_map do |format|
time_span_types.keys.map do |time_span_type| [{ format: format, time_span_type: 'everything' }]
{ format: format, time_span_type: time_span_type }
end
end end
FORMATS = [:xlsx, :ods, :csv, :zip].map do |format| FORMATS = [:xlsx, :ods, :csv, :zip].map do |format|
{ format: format } { format: format }

View file

@ -10,6 +10,8 @@
= render partial: 'header', locals: { procedure: @procedure, statut: @statut } = render partial: 'header', locals: { procedure: @procedure, statut: @statut }
.procedure-actions .procedure-actions
- if @can_download_dossiers
= render Dossiers::ExportComponent.new(procedure: @procedure, exports: @exports)
.container.flex= render partial: "tabs", locals: { procedure: @procedure, .container.flex= render partial: "tabs", locals: { procedure: @procedure,
statut: @statut, statut: @statut,

View file

@ -1,3 +1,7 @@
- if @can_download_dossiers - if @can_download_dossiers
= turbo_stream.update_all '.dossiers-export' do - if @statut.nil?
= render Dossiers::ExportComponent.new(procedure: @procedure, exports: @exports, statut: @statut, count: @dossiers_count) = turbo_stream.update_all '.procedure-actions' do
= render Dossiers::ExportComponent.new(procedure: @procedure, exports: @exports)
- else
= turbo_stream.update_all '.dossiers-export' do
= render Dossiers::ExportComponent.new(procedure: @procedure, exports: @exports, statut: @statut, count: @dossiers_count)

View file

@ -10,6 +10,8 @@
= render partial: 'header', locals: { procedure: @procedure, statut: @statut } = render partial: 'header', locals: { procedure: @procedure, statut: @statut }
.procedure-actions .procedure-actions
- if @can_download_dossiers
= render Dossiers::ExportComponent.new(procedure: @procedure, exports: @exports)
.container.flex= render partial: "tabs", locals: { procedure: @procedure, .container.flex= render partial: "tabs", locals: { procedure: @procedure,
statut: @statut, statut: @statut,