mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-17 21:30:31 +00:00
Merge pull request #689 from bigcapitalhq/download-payment-link-invoice-pdf
feat: Download invoice pdf of the payment link
This commit is contained in:
@@ -1,10 +1,14 @@
|
||||
import { Text, Classes, Button, Intent, Tag } from '@blueprintjs/core';
|
||||
import { Text, Classes, Button, Intent } from '@blueprintjs/core';
|
||||
import clsx from 'classnames';
|
||||
import { AppToaster, Box, Group, Stack } from '@/components';
|
||||
import { usePaymentPortalBoot } from './PaymentPortalBoot';
|
||||
import { useDrawerActions } from '@/hooks/state';
|
||||
import { useCreateStripeCheckoutSession } from '@/hooks/query/payment-link';
|
||||
import {
|
||||
useCreateStripeCheckoutSession,
|
||||
useGeneratePaymentLinkInvoicePdf,
|
||||
} from '@/hooks/query/payment-link';
|
||||
import { DRAWERS } from '@/constants/drawers';
|
||||
import { downloadFile } from '@/hooks/useDownloadFile';
|
||||
import styles from './PaymentPortal.module.scss';
|
||||
|
||||
export function PaymentPortal() {
|
||||
@@ -15,10 +19,34 @@ export function PaymentPortal() {
|
||||
isLoading: isStripeCheckoutLoading,
|
||||
} = useCreateStripeCheckoutSession();
|
||||
|
||||
const {
|
||||
mutateAsync: generatePaymentLinkInvoice,
|
||||
isLoading: isInvoiceGenerating,
|
||||
} = useGeneratePaymentLinkInvoicePdf();
|
||||
|
||||
// Handles invoice preview button click.
|
||||
const handleInvoicePreviewBtnClick = () => {
|
||||
openDrawer(DRAWERS.PAYMENT_INVOICE_PREVIEW);
|
||||
};
|
||||
|
||||
// Handles invoice download button click.
|
||||
const handleInvoiceDownloadBtnClick = () => {
|
||||
generatePaymentLinkInvoice({ paymentLinkId: linkId })
|
||||
.then((data) => {
|
||||
downloadFile(
|
||||
data,
|
||||
`Invoice ${sharableLinkMeta?.invoiceNo}`,
|
||||
'application/pdf',
|
||||
);
|
||||
})
|
||||
.catch(() => {
|
||||
AppToaster.show({
|
||||
intent: Intent.DANGER,
|
||||
message: 'Something went wrong.',
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
// handles the pay button click.
|
||||
const handlePayButtonClick = () => {
|
||||
createStripeCheckoutSession({ linkId })
|
||||
@@ -125,6 +153,8 @@ export function PaymentPortal() {
|
||||
<Button
|
||||
minimal
|
||||
className={clsx(styles.footerButton, styles.downloadInvoiceButton)}
|
||||
onClick={handleInvoiceDownloadBtnClick}
|
||||
loading={isInvoiceGenerating}
|
||||
>
|
||||
Download Invoice
|
||||
</Button>
|
||||
|
||||
Reference in New Issue
Block a user