mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-22 10:21:36 +03:00
864 lines
18 KiB
JavaScript
864 lines
18 KiB
JavaScript
/* eslint indent: warn, no-irregular-whitespace: warn */
|
||
module.exports = ({post, site}) => {
|
||
const date = new Date();
|
||
return `<!doctype html>
|
||
<html>
|
||
|
||
<head>
|
||
<meta name="viewport" content="width=device-width" />
|
||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
||
<title>${post.title}</title>
|
||
<style>
|
||
/* -------------------------------------
|
||
GLOBAL RESETS
|
||
------------------------------------- */
|
||
|
||
/*All the styling goes here*/
|
||
|
||
img {
|
||
border: none;
|
||
-ms-interpolation-mode: bicubic;
|
||
max-width: 100%;
|
||
}
|
||
|
||
body {
|
||
background-color: #fff;
|
||
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';
|
||
-webkit-font-smoothing: antialiased;
|
||
font-size: 18px;
|
||
line-height: 1.4;
|
||
margin: 0;
|
||
padding: 0;
|
||
-ms-text-size-adjust: 100%;
|
||
-webkit-text-size-adjust: 100%;
|
||
color: #15212A;
|
||
}
|
||
|
||
table {
|
||
border-collapse: separate;
|
||
mso-table-lspace: 0pt;
|
||
mso-table-rspace: 0pt;
|
||
width: 100%;
|
||
}
|
||
|
||
table td {
|
||
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';
|
||
font-size: 18px;
|
||
vertical-align: top;
|
||
color: #15212A;
|
||
}
|
||
|
||
/* -------------------------------------
|
||
BODY & CONTAINER
|
||
------------------------------------- */
|
||
.body {
|
||
background-color: #fff;
|
||
width: 100%;
|
||
}
|
||
|
||
/* Set a max-width, and make it display as block so it will automatically stretch to that width, but will also shrink down on a phone or something */
|
||
.container {
|
||
display: block;
|
||
margin: 0 auto !important;
|
||
/* makes it centered */
|
||
max-width: 600px;
|
||
width: 600px;
|
||
}
|
||
|
||
/* This should also be a block element, so that it will fill 100% of the .container */
|
||
.content {
|
||
box-sizing: border-box;
|
||
display: block;
|
||
margin: 0 auto;
|
||
max-width: 600px;
|
||
}
|
||
|
||
/* -------------------------------------
|
||
POST CONTENT
|
||
------------------------------------- */
|
||
hr {
|
||
position: relative;
|
||
display: block;
|
||
width: 100%;
|
||
margin: 3em 0;
|
||
padding: 0;
|
||
height: 1px;
|
||
border: 0;
|
||
border-top: 1px solid #e5eff5;
|
||
}
|
||
|
||
p,
|
||
ul,
|
||
ol,
|
||
dl,
|
||
blockquote {
|
||
margin: 0 0 1.5em 0;
|
||
}
|
||
|
||
ol,
|
||
ul {
|
||
padding-left: 1.3em;
|
||
padding-right: 1.5em;
|
||
}
|
||
|
||
ol ol,
|
||
ul ul,
|
||
ul ol,
|
||
ol ul {
|
||
margin: 0.5em 0 1em;
|
||
}
|
||
|
||
ul {
|
||
list-style: disc;
|
||
}
|
||
|
||
ol {
|
||
list-style: decimal;
|
||
}
|
||
|
||
ul,
|
||
ol {
|
||
max-width: 100%;
|
||
}
|
||
|
||
li {
|
||
margin: 0.5em 0;
|
||
padding-left: 0.3em;
|
||
line-height: 1.6em;
|
||
}
|
||
|
||
dt {
|
||
float: left;
|
||
margin: 0 20px 0 0;
|
||
width: 120px;
|
||
color: #15212A;
|
||
font-weight: 500;
|
||
text-align: right;
|
||
}
|
||
|
||
dd {
|
||
margin: 0 0 5px 0;
|
||
text-align: left;
|
||
}
|
||
|
||
blockquote {
|
||
margin: 2em 0;
|
||
padding: 0 1.6em 0 1.2em;
|
||
border-left: #15212A 2px solid;
|
||
font-style: italic;
|
||
font-size: 22px;
|
||
line-height: 1.75em;
|
||
letter-spacing: -0.2px;
|
||
}
|
||
|
||
blockquote p {
|
||
margin: 0.8em 0;
|
||
font-size: 1.2em;
|
||
font-weight: 300;
|
||
}
|
||
|
||
blockquote small {
|
||
display: inline-block;
|
||
margin: 0.8em 0 0.8em 1.5em;
|
||
font-size: 0.9em;
|
||
opacity: 0.8;
|
||
}
|
||
|
||
blockquote cite {
|
||
font-weight: bold;
|
||
}
|
||
blockquote cite a {
|
||
font-weight: normal;
|
||
}
|
||
|
||
a {
|
||
color: #15212A;
|
||
text-decoration: none;
|
||
}
|
||
|
||
h1,
|
||
h2,
|
||
h3,
|
||
h4,
|
||
h5,
|
||
h6 {
|
||
margin-top: 0;
|
||
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';
|
||
line-height: 1.15em;
|
||
font-weight: 600;
|
||
text-rendering: optimizeLegibility;
|
||
}
|
||
|
||
h1 {
|
||
margin: 1.5em 0 0.5em 0;
|
||
font-size: 46px;
|
||
font-weight: 600;
|
||
}
|
||
|
||
h2 {
|
||
margin: 1.5em 0 0.5em 0;
|
||
font-size: 32px;
|
||
line-height: 1.22em;
|
||
}
|
||
|
||
h3 {
|
||
margin: 1.5em 0 0.5em 0;
|
||
font-size: 26px;
|
||
line-height: 1.25em;
|
||
}
|
||
|
||
h4 {
|
||
margin: 1.8em 0 0.5em 0;
|
||
font-size: 21px;
|
||
line-height: 1.3em;
|
||
}
|
||
|
||
h5 {
|
||
margin: 2em 0 0.5em 0;
|
||
font-size: 19px;
|
||
line-height: 1.4em;
|
||
}
|
||
|
||
h6 {
|
||
margin: 2em 0 0.5em 0;
|
||
font-size: 19px;
|
||
line-height: 1.4em;
|
||
font-weight: 700;
|
||
}
|
||
|
||
strong {
|
||
font-weight: 700;
|
||
}
|
||
|
||
figure {
|
||
margin: 0 0 1.5em;
|
||
padding: 0;
|
||
}
|
||
|
||
figcaption {
|
||
text-align: center;
|
||
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';
|
||
font-size: 14px;
|
||
}
|
||
|
||
code {
|
||
font-size: 0.9em;
|
||
}
|
||
|
||
pre {
|
||
white-space: pre-wrap;
|
||
background: #15212A;
|
||
padding: 15px;
|
||
border-radius: 3px;
|
||
line-height: 1.2em;
|
||
color: #ffffff;
|
||
}
|
||
|
||
p code {
|
||
background: #F2F7FA;
|
||
word-break: break-all;
|
||
padding: 1px 7px;
|
||
border-radius: 3px;
|
||
}
|
||
|
||
figure blockquote p {
|
||
font-size: 1em;
|
||
}
|
||
|
||
.site-icon {
|
||
padding-bottom: 4px;
|
||
padding-top: 20px;
|
||
text-align: center;
|
||
border-radius: 3px;
|
||
}
|
||
|
||
.site-icon img {
|
||
width: 48px;
|
||
height: 48px;
|
||
border-radius: 3px;
|
||
}
|
||
|
||
.site-info {
|
||
padding-top: 15px;
|
||
padding-bottom: 60px;
|
||
}
|
||
|
||
.site-url {
|
||
color: #15212A;
|
||
font-size: 16px;
|
||
letter-spacing: -0.1px;
|
||
font-weight: 700;
|
||
text-transform: uppercase;
|
||
text-align: center;
|
||
border-bottom: 1px solid #e5eff5;
|
||
padding-bottom: 15px;
|
||
}
|
||
|
||
.post-title {
|
||
padding-bottom: 0px;
|
||
font-size: 48px;
|
||
line-height: 1.18em;
|
||
font-weight: 600;
|
||
text-align: center;
|
||
}
|
||
|
||
.post-title-link {
|
||
color: #15212A;
|
||
}
|
||
|
||
.post-meta,
|
||
.view-online {
|
||
padding-top: 6px;
|
||
padding-bottom: 80px;
|
||
white-space: nowrap;
|
||
color: #738a94;
|
||
font-size: 13px;
|
||
letter-spacing: 0.2px;
|
||
text-transform: uppercase;
|
||
text-align: center;
|
||
}
|
||
|
||
.view-online {
|
||
text-align: right;
|
||
}
|
||
|
||
.view-online-link {
|
||
word-wrap: none;
|
||
white-space: nowrap;
|
||
color: #15212A;
|
||
}
|
||
|
||
.feature-image {
|
||
padding-bottom: 30px;
|
||
width: 100%;
|
||
}
|
||
|
||
.post-content {
|
||
max-width: 600px !important;
|
||
font-family: Georgia, serif;
|
||
font-size: 18px;
|
||
line-height: 1.5em;
|
||
color: #23323D;
|
||
}
|
||
|
||
.post-content a {
|
||
color: #08121A;
|
||
text-decoration: underline;
|
||
}
|
||
|
||
.kg-bookmark-card {
|
||
width: 100%;
|
||
background: #ffffff;
|
||
}
|
||
|
||
.kg-bookmark-card a {
|
||
text-decoration: none;
|
||
}
|
||
|
||
.kg-card + .kg-bookmark-card {
|
||
margin-top: 0;
|
||
}
|
||
|
||
.kg-bookmark-container {
|
||
display: flex;
|
||
min-height: 148px;
|
||
color: #15212A;
|
||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
|
||
text-decoration: none;
|
||
border-radius: 3px;
|
||
border: 1px solid #e5eff5;
|
||
}
|
||
|
||
.kg-bookmark-content {
|
||
flex-grow: 1;
|
||
padding: 20px;
|
||
}
|
||
|
||
.kg-bookmark-title {
|
||
color: #15212A;
|
||
font-size: 15px;
|
||
line-height: 1.5em;
|
||
font-weight: 600;
|
||
}
|
||
|
||
.kg-bookmark-description {
|
||
display: -webkit-box;
|
||
overflow-y: hidden;
|
||
margin-top: 12px;
|
||
max-height: 40px;
|
||
color: #738a94;
|
||
font-size: 13px;
|
||
line-height: 1.5em;
|
||
font-weight: 400;
|
||
|
||
-webkit-line-clamp: 2;
|
||
-webkit-box-orient: vertical;
|
||
}
|
||
|
||
.kg-bookmark-thumbnail {
|
||
position: relative;
|
||
min-width: 140px;
|
||
max-width: 180px;
|
||
max-height: 100%;
|
||
}
|
||
|
||
.kg-bookmark-thumbnail img {
|
||
position: absolute;
|
||
top: 0;
|
||
left: 0;
|
||
width: 100%;
|
||
height: 100%;
|
||
border-radius: 0 3px 3px 0;
|
||
|
||
object-fit: cover;
|
||
}
|
||
|
||
.kg-bookmark-metadata {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
align-items: center;
|
||
margin-top: 14px;
|
||
color: #15212A;
|
||
font-size: 13px;
|
||
font-weight: 400;
|
||
}
|
||
|
||
.kg-bookmark-icon {
|
||
margin-right: 8px;
|
||
width: 22px;
|
||
height: 22px;
|
||
}
|
||
|
||
.kg-bookmark-author {
|
||
line-height: 1.5em;
|
||
}
|
||
|
||
.kg-bookmark-author:after {
|
||
content: "•";
|
||
margin: 0 6px;
|
||
}
|
||
|
||
.kg-bookmark-publisher {
|
||
overflow: hidden;
|
||
max-width: 240px;
|
||
line-height: 1.5em;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
}
|
||
|
||
.kg-gallery-image img {
|
||
width: 100% !important;
|
||
height: 100% !important;
|
||
}
|
||
|
||
|
||
/* -------------------------------------
|
||
HEADER, FOOTER, MAIN
|
||
------------------------------------- */
|
||
.main {
|
||
background: #ffffff;
|
||
border-radius: 3px;
|
||
width: 100%;
|
||
}
|
||
|
||
.wrapper {
|
||
box-sizing: border-box;
|
||
padding: 20px;
|
||
}
|
||
|
||
.content-block {
|
||
padding-bottom: 10px;
|
||
padding-top: 10px;
|
||
}
|
||
|
||
.footer {
|
||
color: #738a94;
|
||
margin-top: 20px;
|
||
text-align: center;
|
||
border-top: 1px solid #e5eff5;
|
||
font-size: 13px;
|
||
padding-bottom: 40px;
|
||
padding-top: 20px;
|
||
}
|
||
|
||
/* -------------------------------------
|
||
BUTTONS
|
||
------------------------------------- */
|
||
.btn {
|
||
box-sizing: border-box;
|
||
width: 100%;
|
||
}
|
||
|
||
.btn>tbody>tr>td {
|
||
padding-bottom: 15px;
|
||
}
|
||
|
||
.btn table {
|
||
width: auto;
|
||
}
|
||
|
||
.btn table td {
|
||
background-color: #ffffff;
|
||
border-radius: 5px;
|
||
text-align: center;
|
||
}
|
||
|
||
.btn a {
|
||
background-color: #ffffff;
|
||
border: solid 1px #3498db;
|
||
border-radius: 5px;
|
||
box-sizing: border-box;
|
||
color: #3498db;
|
||
cursor: pointer;
|
||
display: inline-block;
|
||
font-size: 14px;
|
||
font-weight: bold;
|
||
margin: 0;
|
||
padding: 12px 25px;
|
||
text-decoration: none;
|
||
text-transform: capitalize;
|
||
}
|
||
|
||
.btn-primary table td {
|
||
background-color: #3498db;
|
||
}
|
||
|
||
.btn-primary a {
|
||
background-color: #3498db;
|
||
border-color: #3498db;
|
||
color: #ffffff;
|
||
}
|
||
|
||
/* -------------------------------------
|
||
OTHER STYLES THAT MIGHT BE USEFUL
|
||
------------------------------------- */
|
||
.last {
|
||
margin-bottom: 0;
|
||
}
|
||
|
||
.first {
|
||
margin-top: 0;
|
||
}
|
||
|
||
.align-center {
|
||
text-align: center;
|
||
}
|
||
|
||
.align-right {
|
||
text-align: right;
|
||
}
|
||
|
||
.align-left {
|
||
text-align: left;
|
||
}
|
||
|
||
.clear {
|
||
clear: both;
|
||
}
|
||
|
||
.mt0 {
|
||
margin-top: 0;
|
||
}
|
||
|
||
.mb0 {
|
||
margin-bottom: 0;
|
||
}
|
||
|
||
.preheader {
|
||
color: transparent;
|
||
display: none;
|
||
height: 0;
|
||
max-height: 0;
|
||
max-width: 0;
|
||
opacity: 0;
|
||
overflow: hidden;
|
||
mso-hide: all;
|
||
visibility: hidden;
|
||
width: 0;
|
||
}
|
||
|
||
/* -------------------------------------
|
||
RESPONSIVE AND MOBILE FRIENDLY STYLES
|
||
------------------------------------- */
|
||
@media only screen and (max-width: 620px) {
|
||
|
||
table[class=body] p,
|
||
table[class=body] ul,
|
||
table[class=body] ol,
|
||
table[class=body] td,
|
||
table[class=body] span,
|
||
table[class=body] a {
|
||
font-size: 16px !important;
|
||
}
|
||
|
||
table[class=body] pre {
|
||
white-space: pre-wrap !important;
|
||
word-break: break-word !important;
|
||
width: 80vw !important;
|
||
}
|
||
|
||
table[class=body] .wrapper,
|
||
table[class=body] .article {
|
||
padding: 10px !important;
|
||
}
|
||
|
||
table[class=body] .content {
|
||
padding: 0 !important;
|
||
}
|
||
|
||
table[class=body] .container {
|
||
padding: 0 !important;
|
||
width: 100% !important;
|
||
}
|
||
|
||
table[class=body] .main {
|
||
border-left-width: 0 !important;
|
||
border-radius: 0 !important;
|
||
border-right-width: 0 !important;
|
||
}
|
||
|
||
table[class=body] .btn table {
|
||
width: 100% !important;
|
||
}
|
||
|
||
table[class=body] .btn a {
|
||
width: 100% !important;
|
||
}
|
||
|
||
table[class=body] .img-responsive {
|
||
height: auto !important;
|
||
max-width: 100% !important;
|
||
width: auto !important;
|
||
}
|
||
|
||
table[class=body] .site-icon img {
|
||
width: 40px !important;
|
||
height: 40px !important;
|
||
}
|
||
|
||
table[class=body] .site-info {
|
||
padding-top: 15px !important;
|
||
padding-bottom: 60px !important;
|
||
}
|
||
|
||
table[class=body] .site-url a {
|
||
font-size: 14px !important;
|
||
padding-bottom: 15px !important;
|
||
}
|
||
|
||
table[class=body] .post-meta {
|
||
white-space: normal !important;
|
||
font-size: 12px !important;
|
||
line-height: 1.5em;
|
||
}
|
||
|
||
table[class=body] .view-online-link,
|
||
table[class=body] .footer,
|
||
table[class=body] .footer a {
|
||
font-size: 12px !important;
|
||
}
|
||
|
||
table[class=body] .post-title a {
|
||
font-size: 32px !important;
|
||
line-height: 1.3em !important;
|
||
}
|
||
|
||
table[class=body] .kg-bookmark-card {
|
||
width: 90vw !important;
|
||
}
|
||
|
||
table[class=body] .kg-bookmark-thumbnail {
|
||
display: none !important;
|
||
}
|
||
|
||
table[class=body] .kg-bookmark-metadata span {
|
||
font-size: 13px !important;
|
||
}
|
||
|
||
table[class=body] .kg-embed-card {
|
||
max-width: 90vw !important;
|
||
}
|
||
|
||
table[class=body] h1 {
|
||
font-size: 32px !important;
|
||
line-height: 1.3em !important;
|
||
}
|
||
|
||
table[class=body] h2 {
|
||
font-size: 26px !important;
|
||
line-height: 1.22em !important;
|
||
}
|
||
|
||
table[class=body] h3 {
|
||
font-size: 21px !important;
|
||
line-height: 1.25em !important;
|
||
}
|
||
|
||
table[class=body] h4 {
|
||
font-size: 19px !important;
|
||
line-height: 1.3em !important;
|
||
}
|
||
|
||
table[class=body] h5 {
|
||
font-size: 16px !important;
|
||
line-height: 1.4em !important;
|
||
}
|
||
|
||
table[class=body] h6 {
|
||
font-size: 16px !important;
|
||
line-height: 1.4em !important;
|
||
}
|
||
|
||
table[class=body] blockquote {
|
||
font-size: 19px !important;
|
||
line-height: 1.6em !important;
|
||
margin: 1.5em 0 !important;
|
||
}
|
||
|
||
table[class=body] hr {
|
||
margin: 2em 0 !important;
|
||
}
|
||
|
||
table[class=body] figcaption,
|
||
table[class=body] figcaption a {
|
||
font-size: 13px !important;
|
||
}
|
||
|
||
}
|
||
|
||
/* -------------------------------------
|
||
PRESERVE THESE STYLES IN THE HEAD
|
||
------------------------------------- */
|
||
@media all {
|
||
.ExternalClass {
|
||
width: 100%;
|
||
}
|
||
|
||
.ExternalClass,
|
||
.ExternalClass p,
|
||
.ExternalClass span,
|
||
.ExternalClass font,
|
||
.ExternalClass td,
|
||
.ExternalClass div {
|
||
line-height: 100%;
|
||
}
|
||
|
||
.apple-link a {
|
||
color: inherit !important;
|
||
font-family: inherit !important;
|
||
font-size: inherit !important;
|
||
font-weight: inherit !important;
|
||
line-height: inherit !important;
|
||
text-decoration: none !important;
|
||
}
|
||
|
||
#MessageViewBody a {
|
||
color: inherit;
|
||
text-decoration: none;
|
||
font-size: inherit;
|
||
font-family: inherit;
|
||
font-weight: inherit;
|
||
line-height: inherit;
|
||
}
|
||
|
||
.btn-primary table td:hover {
|
||
background-color: #34495e !important;
|
||
}
|
||
|
||
.btn-primary a:hover {
|
||
background-color: #34495e !important;
|
||
border-color: #34495e !important;
|
||
}
|
||
}
|
||
</style>
|
||
</head>
|
||
|
||
<body class="">
|
||
<span class="preheader">${ post.excerpt ? post.excerpt : `${post.title} – ` }</span>
|
||
<table role="presentation" border="0" cellpadding="0" cellspacing="0" class="body">
|
||
<tr>
|
||
<td> </td>
|
||
<td class="container">
|
||
<div class="content">
|
||
|
||
<!-- START CENTERED WHITE CONTAINER -->
|
||
<table role="presentation" class="main">
|
||
|
||
<!-- START MAIN CONTENT AREA -->
|
||
<tr>
|
||
<td class="wrapper">
|
||
<table role="presentation" border="0" cellpadding="0" cellspacing="0">
|
||
<tr>
|
||
<td class="site-info">
|
||
<table role="presentation" border="0" cellpadding="0" cellspacing="0">
|
||
${ site.icon ? `
|
||
<tr>
|
||
<td class="site-icon"><a href="${site.url}"><img src="${site.url}${site.icon}" border="0"></a></td>
|
||
</tr>
|
||
` : ``}
|
||
<tr>
|
||
<td class="site-url"><a href="${site.url}">${site.title}</a></td>
|
||
</tr>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="post-title"><a href="${post.url}" class="post-title-link">${post.title}</a></td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<table role="presentation" border="0" cellpadding="0" cellspacing="0">
|
||
<tr>
|
||
<td class="post-meta">
|
||
By ${post.authors} –
|
||
${post.published_at} –
|
||
<a href="${post.url}" class="view-online-link">View online →</a>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
|
||
</td>
|
||
</tr>
|
||
${
|
||
post.feature_image ? `
|
||
<tr>
|
||
<td class="feature-image"><img src="${post.feature_image}"></td>
|
||
</tr>
|
||
` : ``
|
||
}
|
||
<tr>
|
||
<td class="post-content">
|
||
|
||
<!-- POST CONTENT START -->
|
||
${post.html}
|
||
<!-- POST CONTENT END -->
|
||
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
|
||
<!-- END MAIN CONTENT AREA -->
|
||
|
||
<tr>
|
||
<td class="wrapper">
|
||
<table role="presentation" border="0" cellpadding="0" cellspacing="0">
|
||
<tr>
|
||
<td class="footer">${site.title} © ${date.getFullYear()} – <a href="%recipient.unsubscribe_url%">Unsubscribe</a></td>
|
||
</tr>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
|
||
</table>
|
||
<!-- END CENTERED WHITE CONTAINER -->
|
||
</div>
|
||
</td>
|
||
<td> </td>
|
||
</tr>
|
||
</table>
|
||
</body>
|
||
|
||
</html>`;
|
||
} |