diff --git a/assets/js/src/common/set_from_address_modal.tsx b/assets/js/src/common/set_from_address_modal.tsx
index 3d1d63c462..6d28ca32da 100644
--- a/assets/js/src/common/set_from_address_modal.tsx
+++ b/assets/js/src/common/set_from_address_modal.tsx
@@ -1,8 +1,8 @@
-import React from 'react';
-import ReactDOMServer from 'react-dom/server';
+import React, { useState } from 'react';
import ReactStringReplace from 'react-string-replace';
import jQuery from 'jquery';
import MailPoet from 'mailpoet';
+import Modal from 'common/modal/modal.jsx';
const mailPoetApiVersion = (window as any).mailpoet_api_version as string;
@@ -35,10 +35,29 @@ const getSuccessMessage = (): string => MailPoet.I18n.t('setFromAddressEmailSucc
'$1'
);
-const showSetFromAddressModal = async () => {
- MailPoet.Modal.popup({
- title: MailPoet.I18n.t('setFromAddressModalTitle'),
- template: ReactDOMServer.renderToString(
+const removeUnauthorizedEmailNotices = () => {
+ const unauthorizedEmailNotice = document.querySelector('[data-notice="unauthorized-email-addresses-notice"]');
+ if (unauthorizedEmailNotice) {
+ unauthorizedEmailNotice.remove();
+ }
+ const unauthorizedEmailInNewsletterNotice = document.querySelector('[data-notice="unauthorized-email-in-newsletters-addresses-notice"]');
+ if (unauthorizedEmailInNewsletterNotice) {
+ unauthorizedEmailInNewsletterNotice.remove();
+ }
+};
+
+type Props = {
+ onRequestClose: () => void,
+};
+
+const SetFromAddressModal = ({ onRequestClose }: Props) => {
+ const [address, setAddress] = useState(null);
+
+ return (
+
- ),
- onInit: () => {
- const saveButton = document.getElementById('mailpoet_set_from_address_modal_save') as HTMLInputElement;
- const addressInput = document.getElementById('mailpoet_set_from_address_modal_address') as HTMLInputElement;
- const addressValidator = jQuery(addressInput).parsley();
-
- saveButton.addEventListener('click', async () => {
- addressValidator.validate();
- if (!addressValidator.isValid()) {
- return;
- }
-
- const address = addressInput.value.trim() || null;
- if (!address) {
- return;
- }
- try {
- await handleSave(address);
- MailPoet.Modal.close();
-
- // remove unauthorized email notices
- const unauthorizedEmailNotice = document.querySelector('[data-notice="unauthorized-email-addresses-notice"]');
- if (unauthorizedEmailNotice) {
- unauthorizedEmailNotice.remove();
- }
- const unauthorizedEmailInNewsletterNotice = document.querySelector('[data-notice="unauthorized-email-in-newsletters-addresses-notice"]');
- if (unauthorizedEmailInNewsletterNotice) {
- unauthorizedEmailInNewsletterNotice.remove();
- }
- 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');
- });
- },
- });
+
+ );
};
-export default showSetFromAddressModal;
+export default SetFromAddressModal;
diff --git a/assets/js/src/old_settings/premium_tab/premium_tab.jsx b/assets/js/src/old_settings/premium_tab/premium_tab.jsx
index 5f4daa850d..3ed17f80bb 100644
--- a/assets/js/src/old_settings/premium_tab/premium_tab.jsx
+++ b/assets/js/src/old_settings/premium_tab/premium_tab.jsx
@@ -2,7 +2,7 @@ import PropTypes from 'prop-types';
import React, { useMemo, useState } from 'react';
import ReactDOM from 'react-dom';
import MailPoet from 'mailpoet';
-import showSetFromAddressModal from 'common/set_from_address_modal.tsx';
+import SetFromAddressModal from 'common/set_from_address_modal.tsx';
import KeyMessages from 'old_settings/premium_tab/messages/key_messages.jsx';
import { MssStatus, MssMessages } from 'old_settings/premium_tab/messages/mss_messages.jsx';
import { PremiumStatus, PremiumMessages } from 'old_settings/premium_tab/messages/premium_messages.jsx';
@@ -50,6 +50,7 @@ const PremiumTab = (props) => {
const [premiumInstallationStatus, setPremiumInstallationStatus] = useState(null);
const [mssStatus, setMssStatus] = useState(key ? props.mssStatus : null);
const [mssKeyMessage, setMssKeyMessage] = useState(null);
+ const [showSetFromAddressModal, setShowSetFromAddressModal] = useState(false);
// key is considered valid if either Premium or MSS check passes
const keyValid = useMemo(() => {
@@ -142,95 +143,102 @@ const PremiumTab = (props) => {
}
return (
-
-
-
-
-
-
- {MailPoet.I18n.t('premiumTabDescription')}
-
- |
-
-
- {
- setKey(event.target.value.trim() || null);
- setPremiumStatus(null);
- setPremiumInstallationStatus(null);
- setMssStatus(null);
- }}
- />
- |
+
+
+
+ { showSetFromAddressModal && (
+ setShowSetFromAddressModal(false)}
+ />
+ )}
+ >
);
};