Add save functionality and success/error messages
[MAILPOET-2804]
This commit is contained in:
@@ -4,6 +4,37 @@ import ReactStringReplace from 'react-string-replace';
|
|||||||
import jQuery from 'jquery';
|
import jQuery from 'jquery';
|
||||||
import MailPoet from 'mailpoet';
|
import MailPoet from 'mailpoet';
|
||||||
|
|
||||||
|
const mailPoetApiVersion = (window as any).mailpoet_api_version as string;
|
||||||
|
|
||||||
|
const handleSave = async (address: string|null) => MailPoet.Ajax.post({
|
||||||
|
api_version: mailPoetApiVersion,
|
||||||
|
endpoint: 'settings',
|
||||||
|
action: 'setAuthorizedFromAddress',
|
||||||
|
data: {
|
||||||
|
address,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const getErrorMessage = (error: any|null): string => {
|
||||||
|
if (!error) {
|
||||||
|
return MailPoet.I18n.t('setFromAddressEmailUnknownError');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (error.error === 'unauthorized') {
|
||||||
|
return MailPoet.I18n.t('setFromAddressEmailNotAuthorized').replace(
|
||||||
|
/\[link\](.*?)\[\/link\]/g,
|
||||||
|
'<a href="https://account.mailpoet.com/authorization" target="_blank" rel="noopener noreferrer">$1</a>'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return error.message || MailPoet.I18n.t('setFromAddressEmailUnknownError');
|
||||||
|
};
|
||||||
|
|
||||||
|
const getSuccessMessage = (): string => MailPoet.I18n.t('setFromAddressEmailSuccess').replace(
|
||||||
|
/\[link\](.*?)\[\/link\]/g,
|
||||||
|
'<a href="?page=mailpoet-settings#basics" rel="noopener noreferrer">$1</a>'
|
||||||
|
);
|
||||||
|
|
||||||
const showSetFromAddressModal = async () => {
|
const showSetFromAddressModal = async () => {
|
||||||
MailPoet.Modal.popup({
|
MailPoet.Modal.popup({
|
||||||
title: MailPoet.I18n.t('setFromAddressModalTitle'),
|
title: MailPoet.I18n.t('setFromAddressModalTitle'),
|
||||||
@@ -59,6 +90,20 @@ const showSetFromAddressModal = async () => {
|
|||||||
if (!address) {
|
if (!address) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
try {
|
||||||
|
await handleSave(address);
|
||||||
|
MailPoet.Modal.close();
|
||||||
|
MailPoet.Notice.success(getSuccessMessage());
|
||||||
|
} catch (e) {
|
||||||
|
const error = e.errors && e.errors[0] ? e.errors[0] : null;
|
||||||
|
const message = getErrorMessage(error);
|
||||||
|
addressValidator.addError('saveError', { message });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
addressInput.addEventListener('input', () => {
|
||||||
|
addressValidator.removeError('saveError');
|
||||||
|
});
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
@@ -93,6 +93,9 @@ jQuery('.toplevel_page_mailpoet-newsletters.menu-top-last')
|
|||||||
'setFromAddressModalTitle': __('It’s time to set your default FROM address!', 'mailpoet'),
|
'setFromAddressModalTitle': __('It’s time to set your default FROM address!', 'mailpoet'),
|
||||||
'setFromAddressModalDescription': __('Set one of [link]your authorized email addresses[/link] as the default FROM email for your MailPoet emails.', 'mailpoet'),
|
'setFromAddressModalDescription': __('Set one of [link]your authorized email addresses[/link] as the default FROM email for your MailPoet emails.', 'mailpoet'),
|
||||||
'setFromAddressModalSave': __('Save', 'mailpoet'),
|
'setFromAddressModalSave': __('Save', 'mailpoet'),
|
||||||
|
'setFromAddressEmailSuccess': __('Excellent. Your authorized email was saved. You can change it in the [link]Basics tab of the MailPoet settings[/link].', 'mailpoet'),
|
||||||
|
'setFromAddressEmailNotAuthorized': __('Can’t use this email yet! [link]Please authorize it first[/link].', 'mailpoet'),
|
||||||
|
'setFromAddressEmailUnknownError': __('An error occured when saving FROM email address.', 'mailpoet'),
|
||||||
}) %>
|
}) %>
|
||||||
<% block translations %><% endblock %>
|
<% block translations %><% endblock %>
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user