feat: mark specific template as default

This commit is contained in:
Ahmed Bouhuolia
2024-09-14 16:19:06 +02:00
parent 411ac55986
commit df0f73f338
9 changed files with 229 additions and 2 deletions

View File

@@ -42,6 +42,11 @@ function BrandingTemplateTableRoot({
openDrawer(drawerName, { templateId, resource });
};
// Handle mark as default button click.
const handleMarkDefaultTemplate = (template) => {
openAlert('branding-template-mark-default', { templateId: template.id });
};
return (
<DataTable
columns={columns}
@@ -54,6 +59,7 @@ function BrandingTemplateTableRoot({
payload={{
onDeleteTemplate: handleDeleteTemplate,
onEditTemplate: handleEditTemplate,
onMarkDefaultTemplate: handleMarkDefaultTemplate,
}}
rowContextMenu={ActionsMenu}
onCellClick={handleCellClick}

View File

@@ -7,10 +7,19 @@ import { Intent, Menu, MenuDivider, MenuItem } from '@blueprintjs/core';
*/
export function ActionsMenu({
row: { original },
payload: { onDeleteTemplate, onEditTemplate },
payload: { onDeleteTemplate, onEditTemplate, onMarkDefaultTemplate },
}) {
return (
<Menu>
{!original.default && (
<>
<MenuItem
text={'Mark as Default'}
onClick={safeCallback(onMarkDefaultTemplate, original)}
/>
<MenuDivider />
</>
)}
<MenuItem
text={'Edit Template'}
onClick={safeCallback(onEditTemplate, original)}

View File

@@ -5,6 +5,14 @@ const DeleteBrandingTemplateAlert = React.lazy(
() => import('./DeleteBrandingTemplateAlert'),
);
const MarkDefaultBrandingTemplateAlert = React.lazy(
() => import('./MarkDefaultBrandingTemplateAlert'),
);
export const BrandingTemplatesAlerts = [
{ name: 'branding-template-delete', component: DeleteBrandingTemplateAlert },
{
name: 'branding-template-mark-default',
component: MarkDefaultBrandingTemplateAlert,
},
];

View File

@@ -0,0 +1,73 @@
// @ts-nocheck
import React from 'react';
import intl from 'react-intl-universal';
import { AppToaster } from '@/components';
import { Alert, Intent } from '@blueprintjs/core';
import { useAssignPdfTemplateAsDefault } from '@/hooks/query/pdf-templates';
import withAlertStoreConnect from '@/containers/Alert/withAlertStoreConnect';
import withAlertActions from '@/containers/Alert/withAlertActions';
import { compose } from '@/utils';
/**
* Mark default branding template alert.
*/
function MarkDefaultBrandingTemplateAlert({
// #ownProps
name,
// #withAlertStoreConnect
isOpen,
payload: { templateId },
// #withAlertActions
closeAlert,
}) {
const { mutateAsync: assignPdfTemplateAsDefault } =
useAssignPdfTemplateAsDefault();
const handleConfirmDelete = () => {
assignPdfTemplateAsDefault({ templateId })
.then(() => {
AppToaster.show({
message:
'The branding template has been marked as default successfully.',
intent: Intent.SUCCESS,
});
closeAlert(name);
})
.catch((error) => {
AppToaster.show({
message: 'Something went wrong.',
intent: Intent.DANGER,
});
closeAlert(name);
});
};
const handleCancel = () => {
closeAlert(name);
};
return (
<Alert
cancelButtonText={intl.get('cancel')}
confirmButtonText={'Mark as Default'}
intent={Intent.WARNING}
isOpen={isOpen}
onCancel={handleCancel}
onConfirm={handleConfirmDelete}
>
<p>
Are you sure want to mark the given branding template as default
template?
</p>
</Alert>
);
}
export default compose(
withAlertStoreConnect(),
withAlertActions,
)(MarkDefaultBrandingTemplateAlert);

View File

@@ -166,3 +166,40 @@ export const useGetPdfTemplates = (
options,
);
};
export interface AssignPdfTemplateAsDefaultValues {
templateId: number;
}
export interface AssignPdfTemplateAsDefaultResponse {}
export const useAssignPdfTemplateAsDefault = (
options?: UseMutationOptions<
AssignPdfTemplateAsDefaultResponse,
Error,
AssignPdfTemplateAsDefaultValues
>,
): UseMutationResult<
AssignPdfTemplateAsDefaultResponse,
Error,
AssignPdfTemplateAsDefaultValues
> => {
const apiRequest = useApiRequest();
const queryClient = useQueryClient();
return useMutation<
AssignPdfTemplateAsDefaultResponse,
Error,
AssignPdfTemplateAsDefaultValues
>(
({ templateId }) =>
apiRequest
.post(`/pdf-templates/${templateId}/assign_default`)
.then((res) => res.data),
{
onSuccess: () => {
queryClient.invalidateQueries([PdfTemplatesQueryKey]);
},
...options,
},
);
};