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