mirror of
https://github.com/simple-login/app.git
synced 2024-09-20 06:55:59 +08:00
Use partner emails when the user has used alias from a partner (#2136)
* Update base templates based on the parter user * Update template * Fix missing check * Check if the user is set * Hide flag usage
This commit is contained in:
parent
3fd9884c56
commit
faae37b6bc
|
@ -33,6 +33,7 @@ from flanker.addresslib import address
|
||||||
from flanker.addresslib.address import EmailAddress
|
from flanker.addresslib.address import EmailAddress
|
||||||
from jinja2 import Environment, FileSystemLoader
|
from jinja2 import Environment, FileSystemLoader
|
||||||
from sqlalchemy import func
|
from sqlalchemy import func
|
||||||
|
from flask_login import current_user
|
||||||
|
|
||||||
from app import config
|
from app import config
|
||||||
from app.db import Session
|
from app.db import Session
|
||||||
|
@ -74,11 +75,16 @@ def render(template_name, **kwargs) -> str:
|
||||||
|
|
||||||
template = env.get_template(template_name)
|
template = env.get_template(template_name)
|
||||||
|
|
||||||
|
use_partner_template = False
|
||||||
|
if current_user and current_user.is_authenticated:
|
||||||
|
use_partner_template = current_user.has_used_alias_from_partner()
|
||||||
|
|
||||||
return template.render(
|
return template.render(
|
||||||
MAX_NB_EMAIL_FREE_PLAN=config.MAX_NB_EMAIL_FREE_PLAN,
|
MAX_NB_EMAIL_FREE_PLAN=config.MAX_NB_EMAIL_FREE_PLAN,
|
||||||
URL=config.URL,
|
URL=config.URL,
|
||||||
LANDING_PAGE_URL=config.LANDING_PAGE_URL,
|
LANDING_PAGE_URL=config.LANDING_PAGE_URL,
|
||||||
YEAR=arrow.now().year,
|
YEAR=arrow.now().year,
|
||||||
|
USE_PARTNER_TEMPLATE=use_partner_template,
|
||||||
**kwargs,
|
**kwargs,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -330,6 +330,7 @@ class User(Base, ModelMixin, UserMixin, PasswordOracle):
|
||||||
FLAG_FREE_DISABLE_CREATE_ALIAS = 1 << 0
|
FLAG_FREE_DISABLE_CREATE_ALIAS = 1 << 0
|
||||||
FLAG_CREATED_FROM_PARTNER = 1 << 1
|
FLAG_CREATED_FROM_PARTNER = 1 << 1
|
||||||
FLAG_FREE_OLD_ALIAS_LIMIT = 1 << 2
|
FLAG_FREE_OLD_ALIAS_LIMIT = 1 << 2
|
||||||
|
FLAG_CREATED_ALIAS_FROM_PARTNER = 1 << 3
|
||||||
|
|
||||||
email = sa.Column(sa.String(256), unique=True, nullable=False)
|
email = sa.Column(sa.String(256), unique=True, nullable=False)
|
||||||
|
|
||||||
|
@ -1153,6 +1154,13 @@ class User(Base, ModelMixin, UserMixin, PasswordOracle):
|
||||||
return True
|
return True
|
||||||
return not config.DISABLE_CREATE_CONTACTS_FOR_FREE_USERS
|
return not config.DISABLE_CREATE_CONTACTS_FOR_FREE_USERS
|
||||||
|
|
||||||
|
def has_used_alias_from_partner(self) -> bool:
|
||||||
|
return (
|
||||||
|
self.flags
|
||||||
|
& (User.FLAG_CREATED_ALIAS_FROM_PARTNER | User.FLAG_CREATED_FROM_PARTNER)
|
||||||
|
> 0
|
||||||
|
)
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return f"<User {self.id} {self.name} {self.email}>"
|
return f"<User {self.id} {self.name} {self.email}>"
|
||||||
|
|
||||||
|
@ -1646,6 +1654,12 @@ class Alias(Base, ModelMixin):
|
||||||
)
|
)
|
||||||
EventDispatcher.send_event(user, EventContent(alias_created=event))
|
EventDispatcher.send_event(user, EventContent(alias_created=event))
|
||||||
|
|
||||||
|
if (
|
||||||
|
new_alias.flags & cls.FLAG_PARTNER_CREATED > 0
|
||||||
|
and new_alias.user.flags & User.FLAG_CREATED_ALIAS_FROM_PARTNER == 0
|
||||||
|
):
|
||||||
|
user.flags = user.flags | User.FLAG_CREATED_ALIAS_FROM_PARTNER
|
||||||
|
|
||||||
if commit:
|
if commit:
|
||||||
Session.commit()
|
Session.commit()
|
||||||
|
|
||||||
|
|
55
oneshot/recalculate_user_flag_alias_create_from_partner.py
Normal file
55
oneshot/recalculate_user_flag_alias_create_from_partner.py
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
import argparse
|
||||||
|
import time
|
||||||
|
|
||||||
|
from sqlalchemy import func
|
||||||
|
from app.models import Alias, User
|
||||||
|
from app.db import Session
|
||||||
|
|
||||||
|
parser = argparse.ArgumentParser(
|
||||||
|
prog="Backfill alias", description="Backfill user flags for partner alias created"
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"-s", "--start_user_id", default=0, type=int, help="Initial user_id"
|
||||||
|
)
|
||||||
|
parser.add_argument("-e", "--end_user_id", default=0, type=int, help="Last user_id")
|
||||||
|
|
||||||
|
args = parser.parse_args()
|
||||||
|
user_id_start = args.start_user_id
|
||||||
|
max_user_id = args.end_user_id
|
||||||
|
if max_user_id == 0:
|
||||||
|
max_user_id = Session.query(func.max(User.id)).scalar()
|
||||||
|
|
||||||
|
print(f"Checking user {user_id_start} to {max_user_id}")
|
||||||
|
step = 1000
|
||||||
|
el_query = "SELECT user_id, count(id) from alias where user_id>=:start AND user_id < :end AND flags & :alias_flag > 0 GROUP BY user_id"
|
||||||
|
user_update_query = "UPDATE users set flags = flags | :user_flag where id = :user_id"
|
||||||
|
updated = 0
|
||||||
|
start_time = time.time()
|
||||||
|
for batch_start in range(user_id_start, max_user_id, step):
|
||||||
|
rows = Session.execute(
|
||||||
|
el_query,
|
||||||
|
{
|
||||||
|
"start": batch_start,
|
||||||
|
"end": batch_start + step,
|
||||||
|
"alias_flag": Alias.FLAG_PARTNER_CREATED,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
for row in rows:
|
||||||
|
if row[1] > 0:
|
||||||
|
Session.execute(
|
||||||
|
user_update_query,
|
||||||
|
{"user_id": row[0], "user_flag": User.FLAG_CREATED_ALIAS_FROM_PARTNER},
|
||||||
|
)
|
||||||
|
Session.commit()
|
||||||
|
updated += 1
|
||||||
|
elapsed = time.time() - start_time
|
||||||
|
time_per_alias = elapsed / (updated + 1)
|
||||||
|
last_batch_id = batch_start + step
|
||||||
|
remaining = max_user_id - last_batch_id
|
||||||
|
time_remaining = (max_user_id - last_batch_id) * time_per_alias
|
||||||
|
hours_remaining = time_remaining / 3600.0
|
||||||
|
print(
|
||||||
|
f"\rUser {batch_start}/{max_user_id} {updated} {hours_remaining:.2f}hrs remaining"
|
||||||
|
)
|
||||||
|
print("")
|
BIN
static/logo-proton.png
vendored
Normal file
BIN
static/logo-proton.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.2 KiB |
|
@ -1,623 +1,8 @@
|
||||||
{% from "_emailhelpers.html" import render_text, text, render_button, raw_url, grey_section, section %}
|
{% if USE_PARTNER_TEMPLATE %}
|
||||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
||||||
<html xmlns="http://www.w3.org/1999/xhtml" lang="en">
|
|
||||||
<head>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
||||||
<meta name="x-apple-disable-message-reformatting" />
|
|
||||||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
|
||||||
<style type="text/css" rel="stylesheet" media="all">
|
|
||||||
/* Base ------------------------------ */
|
|
||||||
body {
|
|
||||||
width: 100% !important;
|
|
||||||
height: 100%;
|
|
||||||
margin: 0;
|
|
||||||
-webkit-text-size-adjust: none;
|
|
||||||
line-height: 1.6;
|
|
||||||
}
|
|
||||||
|
|
||||||
img {
|
{% extends "base_partner.html" %}
|
||||||
max-width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
a {
|
{% else %}
|
||||||
color: #3869D4;
|
{% extends "base_sl.html" %}
|
||||||
}
|
|
||||||
|
|
||||||
a img {
|
{% endif %}
|
||||||
border: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
td {
|
|
||||||
word-break: break-word;
|
|
||||||
}
|
|
||||||
|
|
||||||
.preheader {
|
|
||||||
display: none !important;
|
|
||||||
visibility: hidden;
|
|
||||||
mso-hide: all;
|
|
||||||
font-size: 1px;
|
|
||||||
line-height: 1px;
|
|
||||||
max-height: 0;
|
|
||||||
max-width: 0;
|
|
||||||
opacity: 0;
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
/* Type ------------------------------ */
|
|
||||||
|
|
||||||
body,
|
|
||||||
td,
|
|
||||||
th {
|
|
||||||
font-family: "Nunito Sans", Helvetica, Arial, sans-serif;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
margin-top: 0;
|
|
||||||
color: #333333;
|
|
||||||
font-size: 22px;
|
|
||||||
font-weight: bold;
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2 {
|
|
||||||
margin-top: 0;
|
|
||||||
color: #333333;
|
|
||||||
font-size: 16px;
|
|
||||||
font-weight: bold;
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3 {
|
|
||||||
margin-top: 0;
|
|
||||||
color: #333333;
|
|
||||||
font-size: 14px;
|
|
||||||
font-weight: bold;
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
td,
|
|
||||||
th {
|
|
||||||
font-size: 16px;
|
|
||||||
}
|
|
||||||
|
|
||||||
p,
|
|
||||||
ul,
|
|
||||||
ol,
|
|
||||||
blockquote {
|
|
||||||
margin: .4em 0 1.1875em;
|
|
||||||
font-size: 16px;
|
|
||||||
line-height: 1.625;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.sub {
|
|
||||||
font-size: 13px;
|
|
||||||
}
|
|
||||||
/* Utilities ------------------------------ */
|
|
||||||
|
|
||||||
.align-right {
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-left {
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-center {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
/* Buttons ------------------------------ */
|
|
||||||
|
|
||||||
.button {
|
|
||||||
background-color: #3869D4;
|
|
||||||
border-top: 10px solid #3869D4;
|
|
||||||
border-right: 18px solid #3869D4;
|
|
||||||
border-bottom: 10px solid #3869D4;
|
|
||||||
border-left: 18px solid #3869D4;
|
|
||||||
display: inline-block;
|
|
||||||
color: #FFF;
|
|
||||||
text-decoration: none;
|
|
||||||
border-radius: 3px;
|
|
||||||
box-shadow: 0 2px 3px rgba(0, 0, 0, 0.16);
|
|
||||||
-webkit-text-size-adjust: none;
|
|
||||||
box-sizing: border-box;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button--green {
|
|
||||||
background-color: #22BC66;
|
|
||||||
border-top: 10px solid #22BC66;
|
|
||||||
border-right: 18px solid #22BC66;
|
|
||||||
border-bottom: 10px solid #22BC66;
|
|
||||||
border-left: 18px solid #22BC66;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button--red {
|
|
||||||
background-color: #FF6136;
|
|
||||||
border-top: 10px solid #FF6136;
|
|
||||||
border-right: 18px solid #FF6136;
|
|
||||||
border-bottom: 10px solid #FF6136;
|
|
||||||
border-left: 18px solid #FF6136;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media only screen and (max-width: 500px) {
|
|
||||||
.button {
|
|
||||||
width: 100% !important;
|
|
||||||
text-align: center !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* Attribute list ------------------------------ */
|
|
||||||
|
|
||||||
.attributes {
|
|
||||||
margin: 0 0 21px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.attributes_content {
|
|
||||||
background-color: #F4F4F7;
|
|
||||||
padding: 16px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.attributes_item {
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
/* Related Items ------------------------------ */
|
|
||||||
|
|
||||||
.related {
|
|
||||||
width: 100%;
|
|
||||||
margin: 0;
|
|
||||||
padding: 25px 0 0 0;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.related_item {
|
|
||||||
padding: 10px 0;
|
|
||||||
color: #CBCCCF;
|
|
||||||
font-size: 15px;
|
|
||||||
line-height: 18px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.related_item-title {
|
|
||||||
display: block;
|
|
||||||
margin: .5em 0 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.related_item-thumb {
|
|
||||||
display: block;
|
|
||||||
padding-bottom: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.related_heading {
|
|
||||||
border-top: 1px solid #CBCCCF;
|
|
||||||
text-align: center;
|
|
||||||
padding: 25px 0 10px;
|
|
||||||
}
|
|
||||||
/* Discount Code ------------------------------ */
|
|
||||||
|
|
||||||
.discount {
|
|
||||||
width: 100%;
|
|
||||||
margin: 0;
|
|
||||||
padding: 24px;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
background-color: #F4F4F7;
|
|
||||||
border: 2px dashed #CBCCCF;
|
|
||||||
}
|
|
||||||
|
|
||||||
.discount_heading {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.discount_body {
|
|
||||||
text-align: center;
|
|
||||||
font-size: 15px;
|
|
||||||
}
|
|
||||||
/* Social Icons ------------------------------ */
|
|
||||||
|
|
||||||
.social {
|
|
||||||
width: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.social td {
|
|
||||||
padding: 0;
|
|
||||||
width: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.social_icon {
|
|
||||||
height: 20px;
|
|
||||||
margin: 0 8px 10px 8px;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
/* Data table ------------------------------ */
|
|
||||||
|
|
||||||
.purchase {
|
|
||||||
width: 100%;
|
|
||||||
margin: 0;
|
|
||||||
padding: 35px 0;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purchase_content {
|
|
||||||
width: 100%;
|
|
||||||
margin: 0;
|
|
||||||
padding: 25px 0 0 0;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purchase_item {
|
|
||||||
padding: 10px 0;
|
|
||||||
color: #51545E;
|
|
||||||
font-size: 15px;
|
|
||||||
line-height: 18px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purchase_heading {
|
|
||||||
padding-bottom: 8px;
|
|
||||||
border-bottom: 1px solid #EAEAEC;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purchase_heading p {
|
|
||||||
margin: 0;
|
|
||||||
color: #85878E;
|
|
||||||
font-size: 12px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purchase_footer {
|
|
||||||
padding-top: 15px;
|
|
||||||
border-top: 1px solid #EAEAEC;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purchase_total {
|
|
||||||
margin: 0;
|
|
||||||
text-align: right;
|
|
||||||
font-weight: bold;
|
|
||||||
color: #333333;
|
|
||||||
}
|
|
||||||
|
|
||||||
.purchase_total--label {
|
|
||||||
padding: 0 15px 0 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
body {
|
|
||||||
background-color: #F2F4F6;
|
|
||||||
color: #51545E;
|
|
||||||
}
|
|
||||||
|
|
||||||
p {
|
|
||||||
color: #51545E;
|
|
||||||
}
|
|
||||||
|
|
||||||
.email-wrapper {
|
|
||||||
width: 100%;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
background-color: #F2F4F6;
|
|
||||||
}
|
|
||||||
|
|
||||||
.email-content {
|
|
||||||
width: 100%;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
}
|
|
||||||
/* Masthead ----------------------- */
|
|
||||||
|
|
||||||
.email-masthead {
|
|
||||||
padding: 25px 0;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.email-masthead_logo {
|
|
||||||
width: 94px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.email-masthead_name {
|
|
||||||
font-size: 16px;
|
|
||||||
font-weight: bold;
|
|
||||||
color: #A8AAAF;
|
|
||||||
text-decoration: none;
|
|
||||||
text-shadow: 0 1px 0 white;
|
|
||||||
}
|
|
||||||
/* Body ------------------------------ */
|
|
||||||
|
|
||||||
.email-body {
|
|
||||||
width: 100%;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.email-body_inner {
|
|
||||||
width: 750px;
|
|
||||||
margin: 0 auto;
|
|
||||||
padding: 0;
|
|
||||||
-premailer-width: 750px;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
background-color: #FFFFFF;
|
|
||||||
}
|
|
||||||
|
|
||||||
.email-footer {
|
|
||||||
width: 750px;
|
|
||||||
margin: 0 auto;
|
|
||||||
padding: 0;
|
|
||||||
-premailer-width: 750px;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.email-footer p {
|
|
||||||
color: #A8AAAF;
|
|
||||||
}
|
|
||||||
|
|
||||||
.body-action {
|
|
||||||
width: 100%;
|
|
||||||
margin: 30px auto;
|
|
||||||
padding: 0;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.body-sub {
|
|
||||||
margin-top: 25px;
|
|
||||||
padding-top: 25px;
|
|
||||||
border-top: 1px solid #EAEAEC;
|
|
||||||
}
|
|
||||||
|
|
||||||
.content-cell {
|
|
||||||
padding: 30px;
|
|
||||||
}
|
|
||||||
/*Media Queries ------------------------------ */
|
|
||||||
|
|
||||||
@media only screen and (max-width: 600px) {
|
|
||||||
.email-body_inner,
|
|
||||||
.email-footer {
|
|
||||||
width: 100% !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (prefers-color-scheme: dark) {
|
|
||||||
body,
|
|
||||||
.email-body,
|
|
||||||
.email-body_inner,
|
|
||||||
.email-content,
|
|
||||||
.email-wrapper,
|
|
||||||
.email-masthead,
|
|
||||||
.email-footer {
|
|
||||||
background-color: #333333 !important;
|
|
||||||
color: #FFF !important;
|
|
||||||
}
|
|
||||||
p,
|
|
||||||
ul,
|
|
||||||
ol,
|
|
||||||
blockquote,
|
|
||||||
h1,
|
|
||||||
h2,
|
|
||||||
h3 {
|
|
||||||
color: #FFF !important;
|
|
||||||
}
|
|
||||||
.attributes_content,
|
|
||||||
.discount {
|
|
||||||
background-color: #222 !important;
|
|
||||||
}
|
|
||||||
.email-masthead_name {
|
|
||||||
text-shadow: none !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
<!--[if mso]>
|
|
||||||
<style type="text/css">
|
|
||||||
.f-fallback {
|
|
||||||
font-family: Arial, sans-serif;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
<![endif]-->
|
|
||||||
<style type="text/css" rel="stylesheet" media="all">
|
|
||||||
body {
|
|
||||||
width: 100% !important;
|
|
||||||
height: 100%;
|
|
||||||
margin: 0;
|
|
||||||
-webkit-text-size-adjust: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
body {
|
|
||||||
font-family: "Nunito Sans", Helvetica, Arial, sans-serif;
|
|
||||||
}
|
|
||||||
|
|
||||||
body {
|
|
||||||
background-color: #F2F4F6;
|
|
||||||
color: #51545E;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body style="width: 100% !important;
|
|
||||||
height: 100%;
|
|
||||||
-webkit-text-size-adjust: none;
|
|
||||||
font-family: Helvetica, Arial, sans-serif;
|
|
||||||
background-color: #F2F4F6;
|
|
||||||
color: #51545E;
|
|
||||||
margin: 0;"
|
|
||||||
bgcolor="#F2F4F6">
|
|
||||||
<span class="preheader"
|
|
||||||
style="display: none !important;
|
|
||||||
visibility: hidden;
|
|
||||||
mso-hide: all;
|
|
||||||
font-size: 1px;
|
|
||||||
line-height: 1px;
|
|
||||||
max-height: 0;
|
|
||||||
max-width: 0;
|
|
||||||
opacity: 0;
|
|
||||||
overflow: hidden;">{{ pre_header }}</span>
|
|
||||||
<table class="email-wrapper"
|
|
||||||
width="100%"
|
|
||||||
cellpadding="0"
|
|
||||||
cellspacing="0"
|
|
||||||
role="presentation"
|
|
||||||
style="width: 100%;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
background-color: #F2F4F6;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;"
|
|
||||||
bgcolor="#F2F4F6">
|
|
||||||
<tr>
|
|
||||||
<td align="center"
|
|
||||||
style="word-break: break-word;
|
|
||||||
font-family: Helvetica, Arial, sans-serif;
|
|
||||||
font-size: 16px;">
|
|
||||||
<table class="email-content"
|
|
||||||
width="100%"
|
|
||||||
cellpadding="0"
|
|
||||||
cellspacing="0"
|
|
||||||
role="presentation"
|
|
||||||
style="width: 100%;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;">
|
|
||||||
<tr>
|
|
||||||
<td class="email-masthead"
|
|
||||||
style="word-break: break-word;
|
|
||||||
font-family: Helvetica, Arial, sans-serif;
|
|
||||||
font-size: 16px;
|
|
||||||
text-align: center;
|
|
||||||
padding: 25px 0;"
|
|
||||||
align="center">
|
|
||||||
<a href="{{ LANDING_PAGE_URL }}"
|
|
||||||
class="f-fallback email-masthead_name"
|
|
||||||
style="color: #A8AAAF;
|
|
||||||
font-size: 16px;
|
|
||||||
font-weight: bold;
|
|
||||||
text-decoration: none;
|
|
||||||
text-shadow: 0 1px 0 white;">
|
|
||||||
{% block logo %}<img src="{{ URL }}/static/logo.png" style="width: 150px; margin: auto">{% endblock %}
|
|
||||||
</a>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<!-- Email Body -->
|
|
||||||
<tr>
|
|
||||||
<td class="email-body"
|
|
||||||
width="750"
|
|
||||||
cellpadding="0"
|
|
||||||
cellspacing="0"
|
|
||||||
style="word-break: break-word;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
font-family: Helvetica, Arial, sans-serif;
|
|
||||||
font-size: 16px;
|
|
||||||
width: 100%;
|
|
||||||
-premailer-width: 100%;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;">
|
|
||||||
<table class="email-body_inner"
|
|
||||||
align="center"
|
|
||||||
width="750"
|
|
||||||
cellpadding="0"
|
|
||||||
cellspacing="0"
|
|
||||||
role="presentation"
|
|
||||||
style="width: 750px;
|
|
||||||
-premailer-width: 750px;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
background-color: #FFFFFF;
|
|
||||||
margin: 0 auto;
|
|
||||||
padding: 0;"
|
|
||||||
bgcolor="#FFFFFF">
|
|
||||||
<!-- Body content -->
|
|
||||||
<tr>
|
|
||||||
<td class="content-cell"
|
|
||||||
style="word-break: break-word;
|
|
||||||
font-family: Helvetica, Arial, sans-serif;
|
|
||||||
font-size: 16px;
|
|
||||||
padding: 30px;">
|
|
||||||
<div class="f-fallback">
|
|
||||||
{% block greeting %}{% endblock %}
|
|
||||||
{% block content %}{% endblock %}
|
|
||||||
<!-- Sub copy -->
|
|
||||||
{% block sub_copy %}{% endblock %}
|
|
||||||
</div>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td style="word-break: break-word;
|
|
||||||
font-family: Helvetica, Arial, sans-serif;
|
|
||||||
font-size: 16px;">
|
|
||||||
<table class="email-footer"
|
|
||||||
align="center"
|
|
||||||
width="750"
|
|
||||||
cellpadding="0"
|
|
||||||
cellspacing="0"
|
|
||||||
role="presentation"
|
|
||||||
style="width: 750px;
|
|
||||||
-premailer-width: 750px;
|
|
||||||
-premailer-cellpadding: 0;
|
|
||||||
-premailer-cellspacing: 0;
|
|
||||||
text-align: center;
|
|
||||||
margin: 0 auto;
|
|
||||||
padding: 0;">
|
|
||||||
<tr>
|
|
||||||
<td class="content-cell"
|
|
||||||
align="center"
|
|
||||||
style="word-break: break-word;
|
|
||||||
font-family: Helvetica, Arial, sans-serif;
|
|
||||||
font-size: 16px;
|
|
||||||
padding: 30px;">
|
|
||||||
<p class="f-fallback sub align-center"
|
|
||||||
style="font-size: 13px;
|
|
||||||
line-height: 1.625;
|
|
||||||
text-align: center;
|
|
||||||
color: #A8AAAF;
|
|
||||||
margin: .4em 0 1.1875em;"
|
|
||||||
align="center">
|
|
||||||
© {{ YEAR }} SimpleLogin - a Proton product. All rights reserved.
|
|
||||||
<br />
|
|
||||||
{% block footer %}{% endblock %}
|
|
||||||
</p>
|
|
||||||
{% if unsubscribe_oneclick is defined %}
|
|
||||||
|
|
||||||
<p class="f-fallback sub align-center"
|
|
||||||
style="font-size: 13px;
|
|
||||||
line-height: 1.625;
|
|
||||||
text-align: center;
|
|
||||||
margin: .4em 0 1.1875em;">
|
|
||||||
<a href="{{ unsubscribe_oneclick }}">Unsubscribe from our newsletter</a>
|
|
||||||
</p>
|
|
||||||
{% endif %}
|
|
||||||
<p class="f-fallback sub align-center"
|
|
||||||
style="font-size: 13px;
|
|
||||||
line-height: 1.625;
|
|
||||||
text-align: center;
|
|
||||||
color: #A8AAAF;
|
|
||||||
margin: .4em 0 1.1875em;"
|
|
||||||
align="center">
|
|
||||||
<a href="https://app.simplelogin.io/dashboard/support">Do you have a question?</a>
|
|
||||||
</p>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
|
|
646
templates/emails/base_partner.html
Normal file
646
templates/emails/base_partner.html
Normal file
|
@ -0,0 +1,646 @@
|
||||||
|
{% from "_emailhelpers.html" import render_text, text, render_button, raw_url, grey_section, section %}
|
||||||
|
<!doctype html>
|
||||||
|
<html xmlns="http://www.w3.org/1999/xhtml"
|
||||||
|
xmlns:v="urn:schemas-microsoft-com:vml"
|
||||||
|
xmlns:o="urn:schemas-microsoft-com:office:office">
|
||||||
|
<head>
|
||||||
|
<!-- NAME: 1 COLUMN -->
|
||||||
|
<!--[if gte mso 15]>
|
||||||
|
<xml>
|
||||||
|
<o:OfficeDocumentSettings>
|
||||||
|
<o:AllowPNG/>
|
||||||
|
<o:PixelsPerInch>96</o:PixelsPerInch>
|
||||||
|
</o:OfficeDocumentSettings>
|
||||||
|
</xml>
|
||||||
|
<![endif]-->
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="x-apple-disable-message-reformatting">
|
||||||
|
<meta name="format-detection"
|
||||||
|
content="telephone=no, date=no, address=no, email=no, url=no">
|
||||||
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta name="author" content="Proton">
|
||||||
|
<style type="text/css">
|
||||||
|
p {
|
||||||
|
margin: 12px 0;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
table {
|
||||||
|
border-collapse: collapse;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1,
|
||||||
|
h2,
|
||||||
|
h3,
|
||||||
|
h4,
|
||||||
|
h5,
|
||||||
|
h6 {
|
||||||
|
display: block;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
img,
|
||||||
|
a img {
|
||||||
|
border: 0;
|
||||||
|
height: auto;
|
||||||
|
outline: none;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
body,
|
||||||
|
#bodyTable,
|
||||||
|
#bodyCell {
|
||||||
|
height: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnPreviewText {
|
||||||
|
display: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
#outlook a {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
img {
|
||||||
|
-ms-interpolation-mode: bicubic;
|
||||||
|
}
|
||||||
|
|
||||||
|
table {
|
||||||
|
mso-table-lspace: 0pt;
|
||||||
|
mso-table-rspace: 0pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ReadMsgBody {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ExternalClass {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
p,
|
||||||
|
a,
|
||||||
|
li,
|
||||||
|
td,
|
||||||
|
blockquote {
|
||||||
|
mso-line-height-rule: exactly;
|
||||||
|
}
|
||||||
|
|
||||||
|
a[href^=tel],
|
||||||
|
a[href^=sms] {
|
||||||
|
color: inherit;
|
||||||
|
cursor: default;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
p,
|
||||||
|
a,
|
||||||
|
li,
|
||||||
|
td,
|
||||||
|
body,
|
||||||
|
table,
|
||||||
|
blockquote {
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ExternalClass,
|
||||||
|
.ExternalClass p,
|
||||||
|
.ExternalClass td,
|
||||||
|
.ExternalClass div,
|
||||||
|
.ExternalClass span,
|
||||||
|
.ExternalClass font {
|
||||||
|
line-height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.no-link a,
|
||||||
|
a[x-apple-data-detectors],
|
||||||
|
a[href^="x-apple-data-detectors:"] {
|
||||||
|
color: inherit !important;
|
||||||
|
text-decoration: none !important;
|
||||||
|
font-size: inherit !important;
|
||||||
|
font-family: inherit !important;
|
||||||
|
font-weight: inherit !important;
|
||||||
|
line-height: inherit !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
#bodyCell {
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.templateContainer {
|
||||||
|
max-width: 600px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
a.mcnButton {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnImage,
|
||||||
|
.mcnRetinaImage {
|
||||||
|
vertical-align: bottom;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnTextContent {
|
||||||
|
word-break: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnTextContent img {
|
||||||
|
height: auto !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnDividerBlock {
|
||||||
|
table-layout: fixed !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnHalfTextRight {
|
||||||
|
border: 1px solid red;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media only screen and (min-width:768px) {
|
||||||
|
.templateContainer {
|
||||||
|
width: 600px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media only screen and (max-width: 480px) {
|
||||||
|
|
||||||
|
body,
|
||||||
|
table,
|
||||||
|
td,
|
||||||
|
p,
|
||||||
|
a,
|
||||||
|
li,
|
||||||
|
blockquote {
|
||||||
|
-webkit-text-size-adjust: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
width: 100% !important;
|
||||||
|
min-width: 100% !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnRetinaImage {
|
||||||
|
max-width: 100% !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnImage {
|
||||||
|
width: 100% !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnCaptionLeftImageContent .mcnImage,
|
||||||
|
.mcnCaptionRightImageContent .mcnImage {
|
||||||
|
width: 176px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnHalfCaptionLeftImageContent .mcnImage,
|
||||||
|
.mcnHalfCaptionRightImageContent .mcnImage {
|
||||||
|
width: 268px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnBoxContentColumnBoxed {
|
||||||
|
padding: 8px !important;
|
||||||
|
margin: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnButtonContentContainer,
|
||||||
|
.mcnCartContainer,
|
||||||
|
.mcnCaptionTopContent,
|
||||||
|
.mcnRecContentContainer,
|
||||||
|
.mcnCaptionBottomContent,
|
||||||
|
.mcnTextContentContainer,
|
||||||
|
.mcnBoxedTextContentContainer,
|
||||||
|
.mcnImageGroupContentContainer,
|
||||||
|
.mcnCaptionLeftTextContentContainer,
|
||||||
|
.mcnCaptionRightTextContentContainer,
|
||||||
|
.mcnCaptionLeftImageContentContainer,
|
||||||
|
.mcnCaptionRightImageContentContainer,
|
||||||
|
.mcnImageCardLeftTextContentContainer,
|
||||||
|
.mcnImageCardRightTextContentContainer,
|
||||||
|
.mcnImageCardLeftImageContentContainer,
|
||||||
|
.mcnImageCardRightImageContentContainer {
|
||||||
|
max-width: 100% !important;
|
||||||
|
width: 100% !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnBoxedTextContentContainer {
|
||||||
|
min-width: 100% !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnImageGroupContent {
|
||||||
|
padding: 16px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnCaptionLeftContentOuter .mcnTextContent,
|
||||||
|
.mcnCaptionRightContentOuter .mcnTextContent {
|
||||||
|
padding-top: 16px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnImageCardTopImageContent,
|
||||||
|
.mcnCaptionBottomContent:last-child .mcnCaptionBottomImageContent,
|
||||||
|
.mcnCaptionBlockInner .mcnCaptionTopContent:last-child .mcnTextContent {
|
||||||
|
padding-top: 32px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnHalfCaptionLeftImageContent,
|
||||||
|
.mcnHalfCaptionRightImageContent {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnImageCardBottomImageContent {
|
||||||
|
padding-bottom: 16px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnImageGroupBlockInner {
|
||||||
|
padding-top: 0 !important;
|
||||||
|
padding-bottom: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnImageGroupBlockOuter {
|
||||||
|
padding-top: 16px !important;
|
||||||
|
padding-bottom: 16px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnTextContent,
|
||||||
|
.mcnBoxedTextContentColumn {
|
||||||
|
padding-right: 32px !important;
|
||||||
|
padding-left: 32px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnCaptionBottomContent .mcnTextContent {
|
||||||
|
padding-left: 16px !important;
|
||||||
|
padding-right: 16px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnCaptionLeftTextContentContainer .mcnTextContent,
|
||||||
|
.mcnCaptionRightTextContentContainer .mcnTextContent {
|
||||||
|
padding-right: 0 !important;
|
||||||
|
padding-left: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnImageCardLeftImageContent,
|
||||||
|
.mcnImageCardRightImageContent {
|
||||||
|
padding-right: 32px !important;
|
||||||
|
padding-bottom: 0 !important;
|
||||||
|
padding-left: 32px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnTextContent ul,
|
||||||
|
.mcnTextContent ol {
|
||||||
|
padding-inline-start: 24px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnButtonContent {
|
||||||
|
padding-left: 24px !important;
|
||||||
|
padding-right: 24px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnButtonHint {
|
||||||
|
padding-left: 16px !important;
|
||||||
|
padding-right: 16px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcnButtonHint,
|
||||||
|
.mcnButtonHint * {
|
||||||
|
text-align: center !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mcpreview-image-uploader {
|
||||||
|
display: none !important;
|
||||||
|
width: 100% !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hide-on-mobile {
|
||||||
|
display: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-stack-on-mobile {
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-stack-on-mobile .mcnCaptionBottomContent,
|
||||||
|
.flex-stack-on-mobile .mcnBoxContentContainer {
|
||||||
|
height: auto !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Heading 1
|
||||||
|
@tip Make the first-level headings larger in size for better readability on small screens.
|
||||||
|
*/
|
||||||
|
h1 {
|
||||||
|
font-size: 22px !important;
|
||||||
|
line-height: 1.25em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Heading 2
|
||||||
|
@tip Make the second-level headings larger in size for better readability on small screens.
|
||||||
|
*/
|
||||||
|
h2 {
|
||||||
|
font-size: 20px !important;
|
||||||
|
line-height: 1.25em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Heading 3
|
||||||
|
@tip Make the third-level headings larger in size for better readability on small screens.
|
||||||
|
*/
|
||||||
|
h3 {
|
||||||
|
font-size: 18px !important;
|
||||||
|
line-height: 1.25em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Heading 4
|
||||||
|
@tip Make the fourth-level headings larger in size for better readability on small screens.
|
||||||
|
*/
|
||||||
|
h4 {
|
||||||
|
font-size: 16px !important;
|
||||||
|
line-height: 1.5em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Boxed Text
|
||||||
|
@tip Make the boxed text larger in size for better readability on small screens. We recommend a font size of at least 16px.
|
||||||
|
*/
|
||||||
|
.mcnBoxedTextContentContainer .mcnTextContent,
|
||||||
|
.mcnBoxedTextContentContainer .mcnTextContent p {
|
||||||
|
font-size: 14px !important;
|
||||||
|
line-height: 1.5em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Preheader Visibility
|
||||||
|
@tip Set the visibility of the email's preheader on small screens. You can hide it to save space.
|
||||||
|
*/
|
||||||
|
#templatePreheader {
|
||||||
|
display: block !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Preheader Text
|
||||||
|
@tip Make the preheader text larger in size for better readability on small screens.
|
||||||
|
*/
|
||||||
|
#templatePreheader .mcnTextContent,
|
||||||
|
#templatePreheader .mcnTextContent p,
|
||||||
|
#templateBody .templatePreheader .mcnTextContent,
|
||||||
|
#templateBody .templatePreheader .mcnTextContent p {
|
||||||
|
font-size: 13px !important;
|
||||||
|
line-height: 1.5em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Header Text
|
||||||
|
@tip Make the header text larger in size for better readability on small screens.
|
||||||
|
*/
|
||||||
|
#templateHeader .mcnTextContent,
|
||||||
|
#templateHeader .mcnTextContent p {
|
||||||
|
font-size: 16px !important;
|
||||||
|
line-height: 1.5em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Body Text
|
||||||
|
@tip Make the body text larger in size for better readability on small screens. We recommend a font size of at least 16px.
|
||||||
|
*/
|
||||||
|
#templateBody .mcnTextContent,
|
||||||
|
#templateBody .mcnTextContent p {
|
||||||
|
font-size: 16px !important;
|
||||||
|
line-height: 1.5em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Body Caption Text
|
||||||
|
@tip Make the body text larger in size for better readability on small screens. We recommend a font size of at least 16px.
|
||||||
|
*/
|
||||||
|
#templateBody .templateBodyCaption,
|
||||||
|
#templateBody .templateBodyCaption p {
|
||||||
|
font-size: 14px !important;
|
||||||
|
line-height: 1.5em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Footer Text
|
||||||
|
@tip Make the footer content text larger in size for better readability on small screens.
|
||||||
|
*/
|
||||||
|
#templateFooter .mcnTextContent,
|
||||||
|
#templateFooter .mcnTextContent p {
|
||||||
|
font-size: 14px !important;
|
||||||
|
line-height: 1.5em !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Footer Follow icons
|
||||||
|
@tip Reduce the spacing between the footer icons to avoid a line-break them on small screens.
|
||||||
|
*/
|
||||||
|
#templateFooter .mcnFollowContentItemContainer {
|
||||||
|
padding-left: 2px !important;
|
||||||
|
padding-right: 2px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Footer Follow icons
|
||||||
|
@tip Reduce the spacing between the footer icons to avoid a line-break them on small screens.
|
||||||
|
*/
|
||||||
|
#templateFooter .mcnFollowContentItemContainerSmall {
|
||||||
|
padding-left: 8px !important;
|
||||||
|
padding-right: 8px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@text Mobile Style
|
||||||
|
*/
|
||||||
|
.mcnCaptionRightImageContent,
|
||||||
|
.mcnCaptionLeftImageContent {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media only screen and (max-width: 352px) {
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Footer Follow icons
|
||||||
|
@tip Reduce the icon size on very small screens.
|
||||||
|
*/
|
||||||
|
.mcnFollowIconContent,
|
||||||
|
.mcnFollowIconContent img.social-icon {
|
||||||
|
width: 38px !important;
|
||||||
|
height: 38px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@tab Mobile Styles
|
||||||
|
@section Footer Follow icons
|
||||||
|
@tip Remove the spacing between the footer icons to avoid a line-break them on very small screens.
|
||||||
|
*/
|
||||||
|
#templateFooter .mcnFollowContentItemContainer {
|
||||||
|
padding-left: 0 !important;
|
||||||
|
padding-right: 0 !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body style="height: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
width: 100%;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;">
|
||||||
|
<!--[if !gte mso 9]><!----><span class="mcnPreviewText"
|
||||||
|
style="display:none;
|
||||||
|
font-size:0px;
|
||||||
|
line-height:0px;
|
||||||
|
max-height:0px;
|
||||||
|
max-width:0px;
|
||||||
|
opacity:0;
|
||||||
|
overflow:hidden;
|
||||||
|
visibility:hidden;
|
||||||
|
mso-hide:all;"></span><!--<![endif]-->
|
||||||
|
<center>
|
||||||
|
<table align="center"
|
||||||
|
border="0"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
height="100%"
|
||||||
|
width="100%"
|
||||||
|
id="bodyTable"
|
||||||
|
style="border-collapse: collapse;
|
||||||
|
mso-table-lspace: 0pt;
|
||||||
|
mso-table-rspace: 0pt;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;
|
||||||
|
height: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
width: 100%;">
|
||||||
|
<tr>
|
||||||
|
<td align="center"
|
||||||
|
valign="top"
|
||||||
|
id="bodyCell"
|
||||||
|
style="mso-line-height-rule: exactly;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;
|
||||||
|
height: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 8px;
|
||||||
|
width: 100%;">
|
||||||
|
<!-- BEGIN TEMPLATE // -->
|
||||||
|
<!--[if (gte mso 9)|(IE)]>
|
||||||
|
<table align="center" border="0" cellspacing="0" cellpadding="0" width="600" style="width:600px;"><tr><td align="center" valign="top" width="600" style="width:600px;">
|
||||||
|
<![endif]-->
|
||||||
|
<table border="0"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
width="100%"
|
||||||
|
class="templateContainer"
|
||||||
|
style="border-collapse: collapse;
|
||||||
|
mso-table-lspace: 0pt;
|
||||||
|
mso-table-rspace: 0pt;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;
|
||||||
|
max-width: 600px !important;">
|
||||||
|
<tr>
|
||||||
|
<td valign="top"
|
||||||
|
id="templateHeader"
|
||||||
|
style="mso-line-height-rule: exactly;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;">
|
||||||
|
<table border="0"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
width="100%"
|
||||||
|
class="mcnImageBlock"
|
||||||
|
style="min-width: 100%;
|
||||||
|
border-collapse: collapse;
|
||||||
|
mso-table-lspace: 0pt;
|
||||||
|
mso-table-rspace: 0pt;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;">
|
||||||
|
<tbody class="mcnImageBlockOuter">
|
||||||
|
<tr>
|
||||||
|
<td valign="top"
|
||||||
|
style="padding: 16px;
|
||||||
|
mso-line-height-rule: exactly;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;"
|
||||||
|
class="mcnImageBlockInner">
|
||||||
|
<table align="left"
|
||||||
|
width="100%"
|
||||||
|
border="0"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
class="mcnImageContentContainer"
|
||||||
|
style="min-width: 100%;
|
||||||
|
border-collapse: collapse;
|
||||||
|
mso-table-lspace: 0pt;
|
||||||
|
mso-table-rspace: 0pt;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;">
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td class="mcnImageContent"
|
||||||
|
valign="top"
|
||||||
|
style="padding: 16px;
|
||||||
|
text-align: center;
|
||||||
|
mso-line-height-rule: exactly;
|
||||||
|
-ms-text-size-adjust: 100%;
|
||||||
|
-webkit-text-size-adjust: 100%;">
|
||||||
|
<a href="https://proton.me/" target="_blank" style="">
|
||||||
|
<img align="center"
|
||||||
|
alt="Proton"
|
||||||
|
src="{{ URL }}/static/logo-proton.png"
|
||||||
|
width="190"
|
||||||
|
style="width:35.4477%; max-width: 380px; padding-bottom: 0; display: inline !important; vertical-align: bottom; border: 0; height: auto; outline: none; text-decoration: none; -ms-interpolation-mode: bicubic; ">
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td valign="top"
|
||||||
|
id="templateBody"
|
||||||
|
style="mso-line-height-rule: exactly; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%; ">
|
||||||
|
{% block greeting %}{% endblock %}
|
||||||
|
{% block content %}{% endblock %}
|
||||||
|
<!-- Sub copy -->
|
||||||
|
{% block sub_copy %}{% endblock %}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
<!--[if (gte mso 9)|(IE)]>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
<![endif]-->
|
||||||
|
<!-- // END TEMPLATE -->
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</center>
|
||||||
|
</body>
|
||||||
|
</html>
|
623
templates/emails/base_sl.html
Normal file
623
templates/emails/base_sl.html
Normal file
|
@ -0,0 +1,623 @@
|
||||||
|
{% from "_emailhelpers.html" import render_text, text, render_button, raw_url, grey_section, section %}
|
||||||
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||||||
|
<html xmlns="http://www.w3.org/1999/xhtml" lang="en">
|
||||||
|
<head>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
|
<meta name="x-apple-disable-message-reformatting" />
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
||||||
|
<style type="text/css" rel="stylesheet" media="all">
|
||||||
|
/* Base ------------------------------ */
|
||||||
|
body {
|
||||||
|
width: 100% !important;
|
||||||
|
height: 100%;
|
||||||
|
margin: 0;
|
||||||
|
-webkit-text-size-adjust: none;
|
||||||
|
line-height: 1.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
img {
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: #3869D4;
|
||||||
|
}
|
||||||
|
|
||||||
|
a img {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
td {
|
||||||
|
word-break: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
.preheader {
|
||||||
|
display: none !important;
|
||||||
|
visibility: hidden;
|
||||||
|
mso-hide: all;
|
||||||
|
font-size: 1px;
|
||||||
|
line-height: 1px;
|
||||||
|
max-height: 0;
|
||||||
|
max-width: 0;
|
||||||
|
opacity: 0;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
/* Type ------------------------------ */
|
||||||
|
|
||||||
|
body,
|
||||||
|
td,
|
||||||
|
th {
|
||||||
|
font-family: "Nunito Sans", Helvetica, Arial, sans-serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
margin-top: 0;
|
||||||
|
color: #333333;
|
||||||
|
font-size: 22px;
|
||||||
|
font-weight: bold;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
margin-top: 0;
|
||||||
|
color: #333333;
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: bold;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
h3 {
|
||||||
|
margin-top: 0;
|
||||||
|
color: #333333;
|
||||||
|
font-size: 14px;
|
||||||
|
font-weight: bold;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
td,
|
||||||
|
th {
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
p,
|
||||||
|
ul,
|
||||||
|
ol,
|
||||||
|
blockquote {
|
||||||
|
margin: .4em 0 1.1875em;
|
||||||
|
font-size: 16px;
|
||||||
|
line-height: 1.625;
|
||||||
|
}
|
||||||
|
|
||||||
|
p.sub {
|
||||||
|
font-size: 13px;
|
||||||
|
}
|
||||||
|
/* Utilities ------------------------------ */
|
||||||
|
|
||||||
|
.align-right {
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
|
||||||
|
.align-left {
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.align-center {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
/* Buttons ------------------------------ */
|
||||||
|
|
||||||
|
.button {
|
||||||
|
background-color: #3869D4;
|
||||||
|
border-top: 10px solid #3869D4;
|
||||||
|
border-right: 18px solid #3869D4;
|
||||||
|
border-bottom: 10px solid #3869D4;
|
||||||
|
border-left: 18px solid #3869D4;
|
||||||
|
display: inline-block;
|
||||||
|
color: #FFF;
|
||||||
|
text-decoration: none;
|
||||||
|
border-radius: 3px;
|
||||||
|
box-shadow: 0 2px 3px rgba(0, 0, 0, 0.16);
|
||||||
|
-webkit-text-size-adjust: none;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button--green {
|
||||||
|
background-color: #22BC66;
|
||||||
|
border-top: 10px solid #22BC66;
|
||||||
|
border-right: 18px solid #22BC66;
|
||||||
|
border-bottom: 10px solid #22BC66;
|
||||||
|
border-left: 18px solid #22BC66;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button--red {
|
||||||
|
background-color: #FF6136;
|
||||||
|
border-top: 10px solid #FF6136;
|
||||||
|
border-right: 18px solid #FF6136;
|
||||||
|
border-bottom: 10px solid #FF6136;
|
||||||
|
border-left: 18px solid #FF6136;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media only screen and (max-width: 500px) {
|
||||||
|
.button {
|
||||||
|
width: 100% !important;
|
||||||
|
text-align: center !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Attribute list ------------------------------ */
|
||||||
|
|
||||||
|
.attributes {
|
||||||
|
margin: 0 0 21px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.attributes_content {
|
||||||
|
background-color: #F4F4F7;
|
||||||
|
padding: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.attributes_item {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
/* Related Items ------------------------------ */
|
||||||
|
|
||||||
|
.related {
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 25px 0 0 0;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.related_item {
|
||||||
|
padding: 10px 0;
|
||||||
|
color: #CBCCCF;
|
||||||
|
font-size: 15px;
|
||||||
|
line-height: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.related_item-title {
|
||||||
|
display: block;
|
||||||
|
margin: .5em 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.related_item-thumb {
|
||||||
|
display: block;
|
||||||
|
padding-bottom: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.related_heading {
|
||||||
|
border-top: 1px solid #CBCCCF;
|
||||||
|
text-align: center;
|
||||||
|
padding: 25px 0 10px;
|
||||||
|
}
|
||||||
|
/* Discount Code ------------------------------ */
|
||||||
|
|
||||||
|
.discount {
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 24px;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
background-color: #F4F4F7;
|
||||||
|
border: 2px dashed #CBCCCF;
|
||||||
|
}
|
||||||
|
|
||||||
|
.discount_heading {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.discount_body {
|
||||||
|
text-align: center;
|
||||||
|
font-size: 15px;
|
||||||
|
}
|
||||||
|
/* Social Icons ------------------------------ */
|
||||||
|
|
||||||
|
.social {
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.social td {
|
||||||
|
padding: 0;
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.social_icon {
|
||||||
|
height: 20px;
|
||||||
|
margin: 0 8px 10px 8px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
/* Data table ------------------------------ */
|
||||||
|
|
||||||
|
.purchase {
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 35px 0;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.purchase_content {
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 25px 0 0 0;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.purchase_item {
|
||||||
|
padding: 10px 0;
|
||||||
|
color: #51545E;
|
||||||
|
font-size: 15px;
|
||||||
|
line-height: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.purchase_heading {
|
||||||
|
padding-bottom: 8px;
|
||||||
|
border-bottom: 1px solid #EAEAEC;
|
||||||
|
}
|
||||||
|
|
||||||
|
.purchase_heading p {
|
||||||
|
margin: 0;
|
||||||
|
color: #85878E;
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.purchase_footer {
|
||||||
|
padding-top: 15px;
|
||||||
|
border-top: 1px solid #EAEAEC;
|
||||||
|
}
|
||||||
|
|
||||||
|
.purchase_total {
|
||||||
|
margin: 0;
|
||||||
|
text-align: right;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #333333;
|
||||||
|
}
|
||||||
|
|
||||||
|
.purchase_total--label {
|
||||||
|
padding: 0 15px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
background-color: #F2F4F6;
|
||||||
|
color: #51545E;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
color: #51545E;
|
||||||
|
}
|
||||||
|
|
||||||
|
.email-wrapper {
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
background-color: #F2F4F6;
|
||||||
|
}
|
||||||
|
|
||||||
|
.email-content {
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
}
|
||||||
|
/* Masthead ----------------------- */
|
||||||
|
|
||||||
|
.email-masthead {
|
||||||
|
padding: 25px 0;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.email-masthead_logo {
|
||||||
|
width: 94px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.email-masthead_name {
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #A8AAAF;
|
||||||
|
text-decoration: none;
|
||||||
|
text-shadow: 0 1px 0 white;
|
||||||
|
}
|
||||||
|
/* Body ------------------------------ */
|
||||||
|
|
||||||
|
.email-body {
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.email-body_inner {
|
||||||
|
width: 750px;
|
||||||
|
margin: 0 auto;
|
||||||
|
padding: 0;
|
||||||
|
-premailer-width: 750px;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
background-color: #FFFFFF;
|
||||||
|
}
|
||||||
|
|
||||||
|
.email-footer {
|
||||||
|
width: 750px;
|
||||||
|
margin: 0 auto;
|
||||||
|
padding: 0;
|
||||||
|
-premailer-width: 750px;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.email-footer p {
|
||||||
|
color: #A8AAAF;
|
||||||
|
}
|
||||||
|
|
||||||
|
.body-action {
|
||||||
|
width: 100%;
|
||||||
|
margin: 30px auto;
|
||||||
|
padding: 0;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.body-sub {
|
||||||
|
margin-top: 25px;
|
||||||
|
padding-top: 25px;
|
||||||
|
border-top: 1px solid #EAEAEC;
|
||||||
|
}
|
||||||
|
|
||||||
|
.content-cell {
|
||||||
|
padding: 30px;
|
||||||
|
}
|
||||||
|
/*Media Queries ------------------------------ */
|
||||||
|
|
||||||
|
@media only screen and (max-width: 600px) {
|
||||||
|
.email-body_inner,
|
||||||
|
.email-footer {
|
||||||
|
width: 100% !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (prefers-color-scheme: dark) {
|
||||||
|
body,
|
||||||
|
.email-body,
|
||||||
|
.email-body_inner,
|
||||||
|
.email-content,
|
||||||
|
.email-wrapper,
|
||||||
|
.email-masthead,
|
||||||
|
.email-footer {
|
||||||
|
background-color: #333333 !important;
|
||||||
|
color: #FFF !important;
|
||||||
|
}
|
||||||
|
p,
|
||||||
|
ul,
|
||||||
|
ol,
|
||||||
|
blockquote,
|
||||||
|
h1,
|
||||||
|
h2,
|
||||||
|
h3 {
|
||||||
|
color: #FFF !important;
|
||||||
|
}
|
||||||
|
.attributes_content,
|
||||||
|
.discount {
|
||||||
|
background-color: #222 !important;
|
||||||
|
}
|
||||||
|
.email-masthead_name {
|
||||||
|
text-shadow: none !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<!--[if mso]>
|
||||||
|
<style type="text/css">
|
||||||
|
.f-fallback {
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<![endif]-->
|
||||||
|
<style type="text/css" rel="stylesheet" media="all">
|
||||||
|
body {
|
||||||
|
width: 100% !important;
|
||||||
|
height: 100%;
|
||||||
|
margin: 0;
|
||||||
|
-webkit-text-size-adjust: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
font-family: "Nunito Sans", Helvetica, Arial, sans-serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
background-color: #F2F4F6;
|
||||||
|
color: #51545E;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body style="width: 100% !important;
|
||||||
|
height: 100%;
|
||||||
|
-webkit-text-size-adjust: none;
|
||||||
|
font-family: Helvetica, Arial, sans-serif;
|
||||||
|
background-color: #F2F4F6;
|
||||||
|
color: #51545E;
|
||||||
|
margin: 0;"
|
||||||
|
bgcolor="#F2F4F6">
|
||||||
|
<span class="preheader"
|
||||||
|
style="display: none !important;
|
||||||
|
visibility: hidden;
|
||||||
|
mso-hide: all;
|
||||||
|
font-size: 1px;
|
||||||
|
line-height: 1px;
|
||||||
|
max-height: 0;
|
||||||
|
max-width: 0;
|
||||||
|
opacity: 0;
|
||||||
|
overflow: hidden;">{{ pre_header }}</span>
|
||||||
|
<table class="email-wrapper"
|
||||||
|
width="100%"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
role="presentation"
|
||||||
|
style="width: 100%;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
background-color: #F2F4F6;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;"
|
||||||
|
bgcolor="#F2F4F6">
|
||||||
|
<tr>
|
||||||
|
<td align="center"
|
||||||
|
style="word-break: break-word;
|
||||||
|
font-family: Helvetica, Arial, sans-serif;
|
||||||
|
font-size: 16px;">
|
||||||
|
<table class="email-content"
|
||||||
|
width="100%"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
role="presentation"
|
||||||
|
style="width: 100%;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;">
|
||||||
|
<tr>
|
||||||
|
<td class="email-masthead"
|
||||||
|
style="word-break: break-word;
|
||||||
|
font-family: Helvetica, Arial, sans-serif;
|
||||||
|
font-size: 16px;
|
||||||
|
text-align: center;
|
||||||
|
padding: 25px 0;"
|
||||||
|
align="center">
|
||||||
|
<a href="{{ LANDING_PAGE_URL }}"
|
||||||
|
class="f-fallback email-masthead_name"
|
||||||
|
style="color: #A8AAAF;
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: bold;
|
||||||
|
text-decoration: none;
|
||||||
|
text-shadow: 0 1px 0 white;">
|
||||||
|
{% block logo %}<img src="{{ URL }}/static/logo.png" style="width: 150px; margin: auto">{% endblock %}
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<!-- Email Body -->
|
||||||
|
<tr>
|
||||||
|
<td class="email-body"
|
||||||
|
width="750"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
style="word-break: break-word;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
font-family: Helvetica, Arial, sans-serif;
|
||||||
|
font-size: 16px;
|
||||||
|
width: 100%;
|
||||||
|
-premailer-width: 100%;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;">
|
||||||
|
<table class="email-body_inner"
|
||||||
|
align="center"
|
||||||
|
width="750"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
role="presentation"
|
||||||
|
style="width: 750px;
|
||||||
|
-premailer-width: 750px;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
background-color: #FFFFFF;
|
||||||
|
margin: 0 auto;
|
||||||
|
padding: 0;"
|
||||||
|
bgcolor="#FFFFFF">
|
||||||
|
<!-- Body content -->
|
||||||
|
<tr>
|
||||||
|
<td class="content-cell"
|
||||||
|
style="word-break: break-word;
|
||||||
|
font-family: Helvetica, Arial, sans-serif;
|
||||||
|
font-size: 16px;
|
||||||
|
padding: 30px;">
|
||||||
|
<div class="f-fallback">
|
||||||
|
{% block greeting %}{% endblock %}
|
||||||
|
{% block content %}{% endblock %}
|
||||||
|
<!-- Sub copy -->
|
||||||
|
{% block sub_copy %}{% endblock %}
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td style="word-break: break-word;
|
||||||
|
font-family: Helvetica, Arial, sans-serif;
|
||||||
|
font-size: 16px;">
|
||||||
|
<table class="email-footer"
|
||||||
|
align="center"
|
||||||
|
width="750"
|
||||||
|
cellpadding="0"
|
||||||
|
cellspacing="0"
|
||||||
|
role="presentation"
|
||||||
|
style="width: 750px;
|
||||||
|
-premailer-width: 750px;
|
||||||
|
-premailer-cellpadding: 0;
|
||||||
|
-premailer-cellspacing: 0;
|
||||||
|
text-align: center;
|
||||||
|
margin: 0 auto;
|
||||||
|
padding: 0;">
|
||||||
|
<tr>
|
||||||
|
<td class="content-cell"
|
||||||
|
align="center"
|
||||||
|
style="word-break: break-word;
|
||||||
|
font-family: Helvetica, Arial, sans-serif;
|
||||||
|
font-size: 16px;
|
||||||
|
padding: 30px;">
|
||||||
|
<p class="f-fallback sub align-center"
|
||||||
|
style="font-size: 13px;
|
||||||
|
line-height: 1.625;
|
||||||
|
text-align: center;
|
||||||
|
color: #A8AAAF;
|
||||||
|
margin: .4em 0 1.1875em;"
|
||||||
|
align="center">
|
||||||
|
© {{ YEAR }} SimpleLogin - a Proton product. All rights reserved.
|
||||||
|
<br />
|
||||||
|
{% block footer %}{% endblock %}
|
||||||
|
</p>
|
||||||
|
{% if unsubscribe_oneclick is defined %}
|
||||||
|
|
||||||
|
<p class="f-fallback sub align-center"
|
||||||
|
style="font-size: 13px;
|
||||||
|
line-height: 1.625;
|
||||||
|
text-align: center;
|
||||||
|
margin: .4em 0 1.1875em;">
|
||||||
|
<a href="{{ unsubscribe_oneclick }}">Unsubscribe from our newsletter</a>
|
||||||
|
</p>
|
||||||
|
{% endif %}
|
||||||
|
<p class="f-fallback sub align-center"
|
||||||
|
style="font-size: 13px;
|
||||||
|
line-height: 1.625;
|
||||||
|
text-align: center;
|
||||||
|
color: #A8AAAF;
|
||||||
|
margin: .4em 0 1.1875em;"
|
||||||
|
align="center">
|
||||||
|
<a href="https://app.simplelogin.io/dashboard/support">Do you have a question?</a>
|
||||||
|
</p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -1,5 +1,5 @@
|
||||||
from app.db import Session
|
from app.db import Session
|
||||||
from app.models import Alias, Mailbox, AliasMailbox
|
from app.models import Alias, Mailbox, AliasMailbox, User
|
||||||
from tests.utils import create_new_user, random_email
|
from tests.utils import create_new_user, random_email
|
||||||
|
|
||||||
|
|
||||||
|
@ -15,3 +15,17 @@ def test_duplicated_mailbox_is_returned_only_once():
|
||||||
alias_mailbox_id = [mailbox.id for mailbox in alias_mailboxes]
|
alias_mailbox_id = [mailbox.id for mailbox in alias_mailboxes]
|
||||||
assert user.default_mailbox_id in alias_mailbox_id
|
assert user.default_mailbox_id in alias_mailbox_id
|
||||||
assert other_mailbox.id in alias_mailbox_id
|
assert other_mailbox.id in alias_mailbox_id
|
||||||
|
|
||||||
|
|
||||||
|
def test_alias_create_from_partner_flags_also_the_user():
|
||||||
|
user = create_new_user()
|
||||||
|
Session.flush()
|
||||||
|
email = random_email()
|
||||||
|
alias = Alias.create(
|
||||||
|
user_id=user.id,
|
||||||
|
email=email,
|
||||||
|
mailbox_id=user.default_mailbox_id,
|
||||||
|
flags=Alias.FLAG_PARTNER_CREATED,
|
||||||
|
flush=True,
|
||||||
|
)
|
||||||
|
assert alias.user.flags & User.FLAG_CREATED_ALIAS_FROM_PARTNER > 0
|
||||||
|
|
Loading…
Reference in a new issue