Convert bulk action to await

MAILPOET-5395
This commit is contained in:
John Oleksowicz
2024-03-07 13:43:05 -06:00
committed by Aschepikov
parent 9a8d6de626
commit d429f538af

View File

@@ -5,7 +5,7 @@ import { __, _n, sprintf } from '@wordpress/i18n';
import { DynamicSegment, DynamicSegmentAction } from '../types';
import { MailPoet } from '../../../mailpoet';
import { storeName } from '../store';
import { DynamicSegmentResponse } from '../../../ajax';
import { DynamicSegmentResponse, isErrorResponse } from '../../../ajax';
async function bulkAction(
action: DynamicSegmentAction,
@@ -14,7 +14,8 @@ async function bulkAction(
if (!action) {
return;
}
void MailPoet.Ajax.post({
try {
const response: DynamicSegmentResponse = await MailPoet.Ajax.post({
api_version: 'v1',
endpoint: 'dynamic_segments',
action: 'bulk_action',
@@ -24,14 +25,14 @@ async function bulkAction(
selection: segments.map((segment) => segment.id),
},
},
})
.then((response: DynamicSegmentResponse) => {
});
if (response.meta.errors && response.meta.errors.length > 0) {
response.meta.errors.forEach(
(error: string) =>
void dispatch(noticesStore).createErrorNotice(error),
(error: string) => void dispatch(noticesStore).createErrorNotice(error),
);
}
const count = response.meta.count;
if (count > 0) {
let successMessage = '';
@@ -63,12 +64,7 @@ async function bulkAction(
case 'restore':
successMessage = sprintf(
/* translators: %d - number of segments */
_n(
'Segment restored.',
'%d segments restored.',
count,
'mailpoet',
),
_n('Segment restored.', '%d segments restored.', count, 'mailpoet'),
count,
);
break;
@@ -78,11 +74,11 @@ async function bulkAction(
void dispatch(noticesStore).createSuccessNotice(successMessage);
void dispatch(storeName).loadDynamicSegments();
}
})
.fail((response: ErrorResponse) => {
} catch (errorResponse: unknown) {
if (isErrorResponse(errorResponse)) {
let errorMessage = '';
if (response.errors) {
response.errors.forEach(
if (errorResponse.errors) {
errorResponse.errors.forEach(
(error) =>
void dispatch(noticesStore).createErrorNotice(error.message),
{ explicitDismiss: true },
@@ -105,7 +101,8 @@ async function bulkAction(
explicitDismiss: true,
});
}
});
}
}
}
type ActionConfirmProps = {
@@ -113,6 +110,7 @@ type ActionConfirmProps = {
selected: DynamicSegment[];
onClose: () => void;
};
export function ActionConfirm({
action,
selected,