From 48a3159d3df437e22fe745a237aecf7815cb346e Mon Sep 17 00:00:00 2001
From: Sanne de Vries
Date: Fri, 17 Mar 2023 15:57:32 +0100
Subject: [PATCH] Added mobile feedback buttons to email template
Refs https://github.com/TryGhost/Team/issues/2740
---
.../modals/newsletters/edit/preview.hbs | 2 +-
ghost/admin/app/styles/layouts/members.css | 4 +
.../__snapshots__/email-previews.test.js.snap | 100 ++++-
.../admin/__snapshots__/stats.test.js.snap | 8 +-
.../__snapshots__/batch-sending.test.js.snap | 368 ++++++++++++++++--
ghost/email-service/lib/email-renderer.js | 3 +
.../partials/feedback-button-mobile.hbs | 6 +
.../partials/feedback-button.hbs | 2 +-
.../lib/email-templates/partials/styles.hbs | 35 +-
.../lib/email-templates/template.hbs | 23 +-
10 files changed, 490 insertions(+), 61 deletions(-)
create mode 100644 ghost/email-service/lib/email-templates/partials/feedback-button-mobile.hbs
diff --git a/ghost/admin/app/components/modals/newsletters/edit/preview.hbs b/ghost/admin/app/components/modals/newsletters/edit/preview.hbs
index abab2aff79..92741a4f0a 100644
--- a/ghost/admin/app/components/modals/newsletters/edit/preview.hbs
+++ b/ghost/admin/app/components/modals/newsletters/edit/preview.hbs
@@ -36,7 +36,7 @@
{{/if}}
- View in browser
+ View in browser
diff --git a/ghost/admin/app/styles/layouts/members.css b/ghost/admin/app/styles/layouts/members.css
index ee65e3a302..77b176f46c 100644
--- a/ghost/admin/app/styles/layouts/members.css
+++ b/ghost/admin/app/styles/layouts/members.css
@@ -2067,6 +2067,10 @@ p.gh-members-import-errordetail:first-of-type {
flex-direction: column;
}
+.gh-members-emailpreview-meta.center-aligned .gh-members-emailpreview-view-online {
+ text-decoration: underline;
+}
+
.gh-members-emailpreview-title p {
margin: 0;
padding: 0 0 10px;
diff --git a/ghost/core/test/e2e-api/admin/__snapshots__/email-previews.test.js.snap b/ghost/core/test/e2e-api/admin/__snapshots__/email-previews.test.js.snap
index b0b0214ed0..56365cf354 100644
--- a/ghost/core/test/e2e-api/admin/__snapshots__/email-previews.test.js.snap
+++ b/ghost/core/test/e2e-api/admin/__snapshots__/email-previews.test.js.snap
@@ -258,6 +258,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -419,10 +431,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 1970
|
-
+ |
View in browser
|
@@ -448,7 +460,7 @@ table.body figcaption a {
-
+
@@ -617,7 +629,7 @@ exports[`Email Preview API Read can read post email preview with email card and
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
- "content-length": "20097",
+ "content-length": "20381",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
@@ -789,6 +801,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -950,10 +974,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 2015
|
-
+ |
View in browser
|
@@ -983,7 +1007,7 @@ table.body figcaption a {
-
+
@@ -1168,7 +1192,7 @@ exports[`Email Preview API Read can read post email preview with fields 4: [head
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
- "content-length": "24920",
+ "content-length": "25204",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
@@ -1371,6 +1395,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -1532,10 +1568,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 1970
|
-
+ |
View in browser
|
@@ -1561,7 +1597,7 @@ table.body figcaption a {
-
+
@@ -1737,7 +1773,7 @@ exports[`Email Preview API Read has custom content transformations for email com
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
- "content-length": "19863",
+ "content-length": "20147",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
@@ -2269,6 +2305,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -2435,10 +2483,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 1970
|
-
+ |
View in browser
|
@@ -2464,7 +2512,7 @@ table.body figcaption a {
-
+
@@ -2645,7 +2693,7 @@ exports[`Email Preview API Read uses the newsletter provided through ?newsletter
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
- "content-length": "20355",
+ "content-length": "20639",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
@@ -3203,6 +3251,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -3369,10 +3429,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 1970
|
-
+ |
View in browser
|
@@ -3398,7 +3458,7 @@ table.body figcaption a {
-
+
@@ -3579,7 +3639,7 @@ exports[`Email Preview API Read uses the posts newsletter by default 4: [headers
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
- "content-length": "20355",
+ "content-length": "20639",
"content-type": "application/json; charset=utf-8",
"content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/,
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
diff --git a/ghost/core/test/e2e-api/admin/__snapshots__/stats.test.js.snap b/ghost/core/test/e2e-api/admin/__snapshots__/stats.test.js.snap
index 889157ee88..64cde87e06 100644
--- a/ghost/core/test/e2e-api/admin/__snapshots__/stats.test.js.snap
+++ b/ghost/core/test/e2e-api/admin/__snapshots__/stats.test.js.snap
@@ -242,7 +242,7 @@ Object {
"totals": Array [
Object {
"cadence": "month",
- "count": 3,
+ "count": 2,
"tier": StringMatching /\\[a-f0-9\\]\\{24\\}/,
},
],
@@ -251,11 +251,11 @@ Object {
Object {
"cadence": "month",
"cancellations": 0,
- "count": 3,
+ "count": 2,
"date": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}/,
"negative_delta": 1,
- "positive_delta": 6,
- "signups": 6,
+ "positive_delta": 5,
+ "signups": 5,
"tier": StringMatching /\\[a-f0-9\\]\\{24\\}/,
},
Object {
diff --git a/ghost/core/test/integration/services/email-service/__snapshots__/batch-sending.test.js.snap b/ghost/core/test/integration/services/email-service/__snapshots__/batch-sending.test.js.snap
index d987bfcdf9..b191c72045 100644
--- a/ghost/core/test/integration/services/email-service/__snapshots__/batch-sending.test.js.snap
+++ b/ghost/core/test/integration/services/email-service/__snapshots__/batch-sending.test.js.snap
@@ -151,6 +151,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -317,10 +329,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 2023
|
-
+ |
View in browser
|
@@ -354,7 +366,7 @@ table.body figcaption a {
-
+
@@ -662,6 +674,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -828,10 +852,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 2023
|
-
+ |
View in browser
|
@@ -853,13 +877,43 @@ table.body figcaption a {
+
+
+
+
+ |
+
-
+
-
+
@@ -983,7 +1037,49 @@ Hello world
-Ghost © 2023 – Unsubscribe [unsubscribe_url]
+
+http://127.0.0.1:2369/#/feedback/post-id/1/?uuid=member-uuid
+
+
+
+http://127.0.0.1:2369/#/feedback/post-id/0/?uuid=member-uuid
+
+
+
+
+
+
+
+
+
+
+
+More like this
+
+
+[http://127.0.0.1:2369/#/feedback/post-id/1/?uuid=member-uuid]
+
+
+
+
+
+Less like this
+
+
+[http://127.0.0.1:2369/#/feedback/post-id/0/?uuid=member-uuid]
+
+
+
+
+
+
+
+
+
+
+
+
+Ghost © 2023 – Unsubscribe [http://127.0.0.1:2369/unsubscribe/?uuid=member-uuid&newsletter=requested-newsletter-uuid]
@@ -1159,6 +1255,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -1325,10 +1433,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 2023
|
-
+ |
View in browser
|
@@ -1350,13 +1458,43 @@ table.body figcaption a {
+
+
+
+
+ |
+
-
+
-
+
@@ -1480,7 +1618,49 @@ Hello world
-Ghost © 2023 – Unsubscribe [unsubscribe_url]
+
+http://127.0.0.1:2369/this-is-a-test-post-title-6/#/feedback/post-id/1/?uuid=member-uuid
+
+
+
+http://127.0.0.1:2369/this-is-a-test-post-title-6/#/feedback/post-id/0/?uuid=member-uuid
+
+
+
+
+
+
+
+
+
+
+
+More like this
+
+
+[http://127.0.0.1:2369/this-is-a-test-post-title-6/#/feedback/post-id/1/?uuid=member-uuid]
+
+
+
+
+
+Less like this
+
+
+[http://127.0.0.1:2369/this-is-a-test-post-title-6/#/feedback/post-id/0/?uuid=member-uuid]
+
+
+
+
+
+
+
+
+
+
+
+
+Ghost © 2023 – Unsubscribe [http://127.0.0.1:2369/unsubscribe/?uuid=member-uuid&newsletter=requested-newsletter-uuid]
@@ -1656,6 +1836,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -1822,10 +2014,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 2023
|
-
+ |
View in browser
|
@@ -1847,13 +2039,43 @@ table.body figcaption a {
+
+
+
+
+ |
+
-
+
-
+
@@ -1977,7 +2199,49 @@ Hello world
-Ghost © 2023 – Unsubscribe [unsubscribe_url]
+
+http://127.0.0.1:2369/this-is-a-test-post-title-7/#/feedback/post-id/1/?uuid=member-uuid
+
+
+
+http://127.0.0.1:2369/this-is-a-test-post-title-7/#/feedback/post-id/0/?uuid=member-uuid
+
+
+
+
+
+
+
+
+
+
+
+More like this
+
+
+[http://127.0.0.1:2369/this-is-a-test-post-title-7/#/feedback/post-id/1/?uuid=member-uuid]
+
+
+
+
+
+Less like this
+
+
+[http://127.0.0.1:2369/this-is-a-test-post-title-7/#/feedback/post-id/0/?uuid=member-uuid]
+
+
+
+
+
+
+
+
+
+
+
+
+Ghost © 2023 – Unsubscribe [http://127.0.0.1:2369/unsubscribe/?uuid=member-uuid&newsletter=requested-newsletter-uuid]
@@ -2153,6 +2417,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -2329,7 +2605,7 @@ table.body figcaption a {
-
+
@@ -2608,6 +2884,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -2774,10 +3062,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 2023
|
-
+ |
View in browser
|
@@ -2803,7 +3091,7 @@ table.body figcaption a {
-
+
@@ -4708,6 +4996,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -4874,10 +5174,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 2023
|
-
+ |
View in browser
|
@@ -4903,7 +5203,7 @@ table.body figcaption a {
-
+
@@ -5207,6 +5507,18 @@ table.body .footer a {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
@@ -5373,10 +5685,10 @@ table.body figcaption a {
-
+ |
By Joe Bloggs • 1 Jan 2023
|
-
+ |
View in browser
|
@@ -5402,7 +5714,7 @@ table.body figcaption a {
-
+
diff --git a/ghost/email-service/lib/email-renderer.js b/ghost/email-service/lib/email-renderer.js
index 47e53d42f3..f1032e0410 100644
--- a/ghost/email-service/lib/email-renderer.js
+++ b/ghost/email-service/lib/email-renderer.js
@@ -509,6 +509,9 @@ class EmailRenderer {
const feedbackButtonPartial = await fs.readFile(path.join(__dirname, './email-templates/partials/', `feedback-button.hbs`), 'utf8');
this.#handlebars.registerPartial('feedbackButton', feedbackButtonPartial);
+ const feedbackButtonMobilePartial = await fs.readFile(path.join(__dirname, './email-templates/partials/', `feedback-button-mobile.hbs`), 'utf8');
+ this.#handlebars.registerPartial('feedbackButtonMobile', feedbackButtonMobilePartial);
+
// Actual template
const htmlTemplateSource = await fs.readFile(path.join(__dirname, './email-templates/', `template.hbs`), 'utf8');
this.#renderTemplate = this.#handlebars.compile(Buffer.from(htmlTemplateSource).toString());
diff --git a/ghost/email-service/lib/email-templates/partials/feedback-button-mobile.hbs b/ghost/email-service/lib/email-templates/partials/feedback-button-mobile.hbs
new file mode 100644
index 0000000000..dd97ea94b7
--- /dev/null
+++ b/ghost/email-service/lib/email-templates/partials/feedback-button-mobile.hbs
@@ -0,0 +1,6 @@
+
+
+
+ {{buttonText}}
+
+ |
\ No newline at end of file
diff --git a/ghost/email-service/lib/email-templates/partials/feedback-button.hbs b/ghost/email-service/lib/email-templates/partials/feedback-button.hbs
index c26ccd1a94..232f2f7f99 100644
--- a/ghost/email-service/lib/email-templates/partials/feedback-button.hbs
+++ b/ghost/email-service/lib/email-templates/partials/feedback-button.hbs
@@ -1,5 +1,5 @@
-
+
|
\ No newline at end of file
diff --git a/ghost/email-service/lib/email-templates/partials/styles.hbs b/ghost/email-service/lib/email-templates/partials/styles.hbs
index 206bd9a2b7..40b85148af 100644
--- a/ghost/email-service/lib/email-templates/partials/styles.hbs
+++ b/ghost/email-service/lib/email-templates/partials/styles.hbs
@@ -372,10 +372,14 @@ figure blockquote p {
.post-meta-center,
.post-meta-center.view-online {
display: inline-block;
- width: 100%;
+ width: 100% !important;
text-align: center;
}
+.post-meta-center.view-online {
+ text-decoration: underline;
+}
+
.post-meta-date {
white-space: nowrap;
}
@@ -420,6 +424,23 @@ figure blockquote p {
color: #738a94;
}
+.feedback-buttons {
+ width: auto !important;
+ margin: auto;
+}
+
+.feedback-buttons-mobile {
+ display: none !important;
+ width: auto !important;
+ margin: auto !important;
+}
+
+.feedback-button-mobile-text {
+ color: #15212A;
+ font-size: 13px !important;
+ font-weight: 500;
+}
+
.post-content {
max-width: 600px !important;
font-family: Georgia, serif;
@@ -1034,6 +1055,18 @@ a[data-flickr-embed] img {
line-height: 1.15em !important;
}
+ table.feedback-buttons {
+ display: none !important;
+ }
+
+ table.feedback-buttons-mobile {
+ display: block !important;
+ }
+
+ table.body .feedback-button-mobile-text {
+ font-size: 13px !important;
+ }
+
table.body .kg-bookmark-card {
width: 90vw;
}
diff --git a/ghost/email-service/lib/email-templates/template.hbs b/ghost/email-service/lib/email-templates/template.hbs
index 97cf6a2e77..62f8772e36 100644
--- a/ghost/email-service/lib/email-templates/template.hbs
+++ b/ghost/email-service/lib/email-templates/template.hbs
@@ -139,15 +139,26 @@
{{#if (or feedbackButtons newsletter.showCommentCta) }}
-
-
+
+
+
@@ -170,7 +181,7 @@
|
-
+
{{#if footerContent }}
{{/if}}
| | | | | | | | | | | | | | | | | | | | | | | | | | |