Merge pull request #12640 from dacook/bulk-invoice-polling-12215

Poll to check when invoice file finished
This commit is contained in:
Maikel
2024-07-05 10:05:56 +10:00
committed by GitHub
6 changed files with 71 additions and 5 deletions

View File

@@ -15,6 +15,8 @@ module Spree
invoice_pdf = filepath(invoice_id)
send_file(invoice_pdf, type: 'application/pdf', disposition: :inline)
rescue ActionController::MissingFile
render "errors/not_found", status: :not_found, formats: :html
end
def generate

View File

@@ -37,9 +37,12 @@ module Admin
return if notify_if_abn_related_issue(visible_orders)
file_id = "#{Time.zone.now.to_i}-#{SecureRandom.hex(2)}"
cable_ready.append(
selector: "#orders-index",
html: render(partial: "spree/admin/orders/bulk/invoice_modal")
html: render(partial: "spree/admin/orders/bulk/invoice_modal",
locals: { invoice_url: "/admin/orders/invoices/#{file_id}" })
).broadcast
# Preserve order of bulk_ids.
@@ -49,7 +52,7 @@ module Admin
BulkInvoiceJob.perform_later(
visible_order_ids,
"tmp/invoices/#{Time.zone.now.to_i}-#{SecureRandom.hex(2)}.pdf",
"tmp/invoices/#{file_id}.pdf",
channel: SessionChannel.for_request(request),
current_user_id: current_user.id
)

View File

@@ -3,5 +3,5 @@
%br
%a.button.primary{ target: '_blank', href: invoice_url }
%a.button.primary{ target: '_blank', href: invoice_url, 'data-file-loading-target': "link"}
= t('js.admin.orders.index.view_file')

View File

@@ -1,4 +1,4 @@
%div{ id: "bulk_invoices_modal", "data-controller": "modal", "data-modal-instant-value": true, "data-action": "keyup@document->modal#closeIfEscapeKey" }
%div{ id: "bulk_invoices_modal", "data-controller": "modal file-loading", "data-modal-instant-value": true, "data-action": "keyup@document->modal#closeIfEscapeKey" }
.reveal-modal-bg.fade{ "data-modal-target": "background", "data-action": "click->modal#remove" }
.reveal-modal.fade.tiny.modal-component{ "data-modal-target": "modal" }
%div.fullwidth.align-center
@@ -7,9 +7,11 @@
%br
%br
.modal-content
.modal-loading
.modal-loading{ 'data-file-loading-target': "loading" }
%img.spinner{ src: image_path("/spinning-circles.svg") }
%br
%br
%p= t('js.admin.orders.index.please_wait')
%br
%div.hidden{ 'data-file-loading-target': "loaded" }
= render partial: "spree/admin/orders/bulk/invoice_link", locals: { invoice_url: }

View File

@@ -0,0 +1,38 @@
import { Controller } from "stimulus";
const NOTIFICATION_TIME = 5000; // 5 seconds
const HIDE_CLASS = "hidden";
export default class extends Controller {
static targets = ["loading", "loaded", "link"];
connect() {
this.setTimeout();
}
disconnect() {
this.clearTimeout();
}
checkFile() {
if (!this.loadedTarget.classList.contains(HIDE_CLASS)) {
// If link already loaded successfully, we don't need to check anymore.
return;
}
const response = fetch(this.linkTarget.href).then((response) => {
if (response.status == 200) {
this.loadingTarget.classList.add(HIDE_CLASS);
this.loadedTarget.classList.remove(HIDE_CLASS);
} else {
this.setTimeout();
}
});
}
setTimeout(){
this.timeout = setTimeout(this.checkFile.bind(this), NOTIFICATION_TIME);
}
clearTimeout(){
clearTimeout(this.timeout);
}
}

View File

@@ -287,6 +287,27 @@ RSpec.describe '
it_behaves_like "can bulk print invoices from 2 orders"
end
context "when cable_ready fails" do
# The backup polling is slower. Let's wait for it.
around do |example|
polling_interval = 5 # seconds
wait_time = Capybara.default_max_wait_time + polling_interval
using_wait_time(wait_time) do
example.run
end
end
# Don't send anything via web sockets.
before do
expect_any_instance_of(BulkInvoiceJob)
.to receive(:broadcast)
.and_return(nil) # do nothing
end
it_behaves_like "can bulk print invoices from 2 orders"
end
context "one of the two orders is not invoiceable" do
before do
order4.cancel!