From 3ae281fc1f05f18fbfaef73eada17c9d6d492bf6 Mon Sep 17 00:00:00 2001
From: Sam Najian
Date: Tue, 27 Dec 2022 22:25:55 +0100
Subject: [PATCH] Add functionality to refresh mss key status in preview modal
[MAILPOET-4633]
---
mailpoet/assets/css/src/generic/_helpers.scss | 18 +++++++
mailpoet/assets/js/src/common/index.ts | 1 +
mailpoet/assets/js/src/common/utils.ts | 1 -
.../src/newsletter_editor/components/save.js | 49 ++++++++++++++++---
.../newsletter_editor/components/save.spec.js | 2 +-
mailpoet/views/newsletter/editor.html | 1 +
.../components/newsletterPreview.hbs | 5 +-
7 files changed, 66 insertions(+), 11 deletions(-)
diff --git a/mailpoet/assets/css/src/generic/_helpers.scss b/mailpoet/assets/css/src/generic/_helpers.scss
index 9280a82782..c705e611b5 100644
--- a/mailpoet/assets/css/src/generic/_helpers.scss
+++ b/mailpoet/assets/css/src/generic/_helpers.scss
@@ -67,3 +67,21 @@ span.mailpoet-gap-half {
.not-small-screen {
@include respond-to(small-screen) { display: none !important; }
}
+
+.with-spinner {
+ pointer-events: none;
+ touch-action: none;
+
+ &:after {
+ background: rgba(#fff, .8) no-repeat center;
+ background-image: url('');
+ background-size: 24px 24px;
+ border-radius: 2px;
+ content: '';
+ height: calc(100% + 2px);
+ left: -1px;
+ position: absolute;
+ top: -1px;
+ width: calc(100% + 2px);
+ }
+}
diff --git a/mailpoet/assets/js/src/common/index.ts b/mailpoet/assets/js/src/common/index.ts
index 326f7b1d1e..8e7d0c4d0f 100644
--- a/mailpoet/assets/js/src/common/index.ts
+++ b/mailpoet/assets/js/src/common/index.ts
@@ -11,3 +11,4 @@ export * from './listings';
export * from './error_boundary';
export * from './functions';
export * from './utils';
+export * from './thumbnail';
diff --git a/mailpoet/assets/js/src/common/utils.ts b/mailpoet/assets/js/src/common/utils.ts
index 9790a3fe58..49313b2c28 100644
--- a/mailpoet/assets/js/src/common/utils.ts
+++ b/mailpoet/assets/js/src/common/utils.ts
@@ -1,4 +1,3 @@
export const getLinkRegex = () => /\[link\](.*?)\[\/link\]/g;
export const isTruthy = (value: string | number | boolean) =>
[1, '1', true, 'true'].includes(value);
-
diff --git a/mailpoet/assets/js/src/newsletter_editor/components/save.js b/mailpoet/assets/js/src/newsletter_editor/components/save.js
index ccc051bff6..e02724f617 100644
--- a/mailpoet/assets/js/src/newsletter_editor/components/save.js
+++ b/mailpoet/assets/js/src/newsletter_editor/components/save.js
@@ -6,7 +6,7 @@ import Marionette from 'backbone.marionette';
import $ from 'jquery';
import Blob from 'blob';
import FileSaver from 'file-saver';
-import * as Thumbnail from 'common/thumbnail.ts';
+import { isTruthy, fromNewsletter } from 'common';
import _ from 'underscore';
import SuperModel from 'backbone.supermodel/build/backbone.supermodel';
@@ -99,7 +99,7 @@ Module.save = function () {
};
Module.saveTemplate = function (options) {
- return Thumbnail.fromNewsletter(App.toJSON()).then(function (thumbnail) {
+ return fromNewsletter(App.toJSON()).then(function (thumbnail) {
var data = _.extend(options || {}, {
thumbnail_data: thumbnail,
body: JSON.stringify(App.getBody()),
@@ -116,7 +116,7 @@ Module.saveTemplate = function (options) {
};
Module.exportTemplate = function (options) {
- return Thumbnail.fromNewsletter(App.toJSON()).then(function (thumbnail) {
+ return fromNewsletter(App.toJSON()).then(function (thumbnail) {
var data = _.extend(options || {}, {
thumbnail_data: thumbnail,
body: App.getBody(),
@@ -573,6 +573,9 @@ Module.NewsletterPreviewModel = SuperModel.extend({
previewSendingError: false,
previewSendingSuccess: false,
sendingPreview: false,
+ mssPendingApproval: window.mailpoet_mss_key_pending_approval,
+ mssKeyPendingApprovalRefreshMessage: true,
+ awaitingKeyCheck: false,
},
});
@@ -588,6 +591,7 @@ Module.NewsletterPreviewView = Marionette.View.extend({
return {
'change .mailpoet_browser_preview_type': 'changeBrowserPreviewType',
'click #mailpoet_send_preview': 'sendPreview',
+ 'click #refresh-mss-key-status': 'refreshMssKeyStatus',
};
},
initialize: function (options) {
@@ -606,7 +610,11 @@ Module.NewsletterPreviewView = Marionette.View.extend({
this.$('#mailpoet_preview_to_email').val() || window.currentUserEmail,
previewSendingError: this.model.get('previewSendingError'),
sendingPreview: this.model.get('sendingPreview'),
- mssKeyPendingApproval: window.mailpoet_mss_key_pending_approval,
+ mssKeyPendingApproval: this.model.get('mssPendingApproval'),
+ mssKeyPendingApprovalRefreshMessage: this.model.get(
+ 'mssKeyPendingApprovalRefreshMessage',
+ ),
+ awaitingKeyCheck: this.model.get('awaitingKeyCheck'),
};
},
changeBrowserPreviewType: function (event) {
@@ -712,11 +720,11 @@ Module.NewsletterPreviewView = Marionette.View.extend({
)}
${MailPoet.I18n.t(
'newsletterPreviewErrorSignUpForSendingService',
@@ -744,6 +752,31 @@ Module.NewsletterPreviewView = Marionette.View.extend({
});
return undefined;
},
+ refreshMssKeyStatus: function () {
+ this.model.set('awaitingKeyCheck', true);
+
+ return MailPoet.Ajax.post({
+ api_version: window.mailpoet_api_version,
+ endpoint: 'services',
+ action: 'checkMSSKey',
+ data: {
+ key: window.mailpoet_api_key,
+ },
+ })
+ .done((response) => {
+ this.model.set('awaitingKeyCheck', false);
+ if (response.data && response.data.result.code === 200) {
+ this.model.set(
+ 'mssPendingApproval',
+ !isTruthy(response.data.result.data.is_approved),
+ );
+ this.model.set('mssKeyPendingApprovalRefreshMessage', false);
+ }
+ })
+ .fail(() => {
+ this.model.set('awaitingKeyCheck', false);
+ });
+ },
});
App.on('before:start', function (BeforeStartApp) {
diff --git a/mailpoet/tests/javascript_newsletter_editor/newsletter_editor/components/save.spec.js b/mailpoet/tests/javascript_newsletter_editor/newsletter_editor/components/save.spec.js
index 6f0934a94c..0015ced7df 100644
--- a/mailpoet/tests/javascript_newsletter_editor/newsletter_editor/components/save.spec.js
+++ b/mailpoet/tests/javascript_newsletter_editor/newsletter_editor/components/save.spec.js
@@ -278,7 +278,7 @@ describe('Save', function () {
},
},
'newsletter_editor/App': { App },
- 'common/thumbnail.ts': {
+ common: {
fromNewsletter: function () {
return promiseMock;
},
diff --git a/mailpoet/views/newsletter/editor.html b/mailpoet/views/newsletter/editor.html
index d19fed0b4b..1e0b95eaf7 100644
--- a/mailpoet/views/newsletter/editor.html
+++ b/mailpoet/views/newsletter/editor.html
@@ -374,6 +374,7 @@
var mailpoet_email_editor_tutorial_seen = '<%= editor_tutorial_seen %>';
var mailpoet_email_editor_tutorial_url = '<%= cdn_url('newsletter-editor/editor-drag-demo.20190226-1505.mp4') %>';
var mailpoet_installed_at = '<%= settings.installed_at %>';
+ var mailpoet_api_key = '<%= settings.mta.mailpoet_api_key %>';
<% endblock %>
diff --git a/mailpoet/views/newsletter/templates/components/newsletterPreview.hbs b/mailpoet/views/newsletter/templates/components/newsletterPreview.hbs
index 785cbafd2e..a80dc0df3c 100644
--- a/mailpoet/views/newsletter/templates/components/newsletterPreview.hbs
+++ b/mailpoet/views/newsletter/templates/components/newsletterPreview.hbs
@@ -57,8 +57,11 @@
{{#if mssKeyPendingApproval }}
-
+
<%= __('You’ll soon be able to send once our team reviews your account. In the meantime, you can send previews to [link]your authorized emails[/link].')|replaceLinkTags('https://account.mailpoet.com/authorization', {'target': '_blank', 'rel': 'noopener noreferrer'})|raw %>
+ {{#if mssKeyPendingApprovalRefreshMessage }}
+ <%= __('If you have already received approval email, click [link]here[/link] to update the status.')|replaceLinkTags('#', {'id': 'refresh-mss-key-status'})|raw %>
+ {{/if}}
{{/if}}