Skip to content

Commit

Permalink
Add newsletter form to nothing-personal page (Fixes #15218) (#15223)
Browse files Browse the repository at this point in the history
  • Loading branch information
alexgibson authored and reemhamz committed Oct 10, 2024
1 parent f8b5c0d commit e8b1055
Show file tree
Hide file tree
Showing 10 changed files with 60 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,12 @@
#}

{% macro browser_border(
id=None,
class=None,
heading=None,
aria_label=None
) -%}
<div class="c-browser {% if class %} {{ class }}{% endif %}">
<div {% if id %}id="{{ id }}" {% endif %}class="c-browser{% if class %} {{ class }}{% endif %}">
<div class="c-browser-bar {% if heading %} c-bar-with-heading{% endif %}">
{% if heading and aria_label %}
<h3 aria-label="{{ aria_label }}">{{ heading }}</h3>
Expand Down
18 changes: 18 additions & 0 deletions bedrock/firefox/templates/firefox/nothing-personal/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@

{% block page_css %}
{{ css_bundle('firefox-nothing-personal') }}
{{ css_bundle('protocol-newsletter') }}
{% endblock %}

{% block page_title_prefix %}Nothing Personal{% endblock %}
Expand Down Expand Up @@ -181,6 +182,22 @@ <h5>Ok, what’s the privacy-catch?</h5>

</div>
{% endcall %}

{% call browser_border(id="newsletter-signup", class='mzp-l-content mzp-t-content-md mzp-t-content-nospace', heading='Newsletter') %}
<div class="c-browser-window-top">
<h4><span aria-hidden="true">[</span>Sign up for our newsletter<span aria-hidden="true">]</span></h4>

{{ email_newsletter_form(
include_title=False,
include_language=False,
include_country=False,
newsletters='mozilla-and-you, nothing-personal-college-interest',
multi_opt_in_required=True
)}}

<p>By subscribing, you’ll receive Mozilla updates, plus exclusive college-related content if you opt in. You may unsubscribe from either at any time.</p>
</div>
{% endcall %}
</div>

<div class="c-sticky-note c-detached-sticky">
Expand Down Expand Up @@ -219,4 +236,5 @@ <h5>Ok, what’s the privacy-catch?</h5>

{% block js %}
{{ js_bundle('firefox-nothing-personal') }}
{{ js_bundle('newsletter') }}
{% endblock %}
11 changes: 9 additions & 2 deletions bedrock/newsletter/forms.py
Original file line number Diff line number Diff line change
Expand Up @@ -175,6 +175,7 @@ class NewsletterFooterForm(forms.Form):
choice_labels = {
"mozilla-foundation": ftl("multi-newsletter-form-checkboxes-label-mozilla"),
"mozilla-and-you": ftl("multi-newsletter-form-checkboxes-label-firefox"),
"nothing-personal-college-interest": "Exclusive college-related content", # issue 15218.
}

email = forms.EmailField(widget=EmailInput(attrs={"required": "required", "data-testid": "newsletter-email-input"}))
Expand All @@ -188,7 +189,7 @@ class NewsletterFooterForm(forms.Form):

# has to take a newsletters argument so it can figure
# out which languages to list in the form.
def __init__(self, newsletters, locale, data=None, *args, **kwargs):
def __init__(self, newsletters, locale, data=None, multi_opt_in_required=False, *args, **kwargs):
regions = product_details.get_regions(locale)
regions = sorted(iter(regions.items()), key=itemgetter(1))

Expand All @@ -201,6 +202,7 @@ def __init__(self, newsletters, locale, data=None, *args, **kwargs):
# form validation will work with submitted data
newsletters = ["mozilla-and-you"]

is_multi_newsletter = len(newsletters) > 1
lang = locale.lower()
if "-" in lang:
lang, country = lang.split("-", 1)
Expand Down Expand Up @@ -231,7 +233,12 @@ def __init__(self, newsletters, locale, data=None, *args, **kwargs):
lang_label = ftl_lazy("newsletter-form-select-language", fallback="newsletter-form-available-languages")
self.fields["lang"] = forms.TypedChoiceField(widget=lang_widget, choices=lang_choices, initial=lang, required=False, label=lang_label)
self.fields["newsletters"].choices = [(n, self.choice_labels.get(n, n)) for n in newsletters]
self.fields["newsletters"].initial = newsletters

# Automatically check newsletter choices unless opt-in is explicitly required.
if is_multi_newsletter and multi_opt_in_required:
self.fields["newsletters"].initial = None
else:
self.fields["newsletters"].initial = newsletters

def clean_newsletters(self):
return validate_newsletters(self.cleaned_data["newsletters"])
Expand Down
3 changes: 2 additions & 1 deletion bedrock/newsletter/templatetags/helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ def email_newsletter_form(
spinner_color=None,
email_label=None,
email_placeholder=None,
multi_opt_in_required=False, # switches multi-newsletter forms to be opt-in rather than pre-checked.
):
request = ctx["request"]
context = ctx.get_all()
Expand All @@ -49,7 +50,7 @@ def email_newsletter_form(

form = ctx.get("newsletter_form", None)
if not form:
form = NewsletterFooterForm(newsletters, get_locale(request))
form = NewsletterFooterForm(newsletters, get_locale(request), multi_opt_in_required=multi_opt_in_required)

if isinstance(newsletters, list):
newsletters = ", ".join(newsletters)
Expand Down
17 changes: 17 additions & 0 deletions bedrock/newsletter/tests/test_footer_form.py
Original file line number Diff line number Diff line change
Expand Up @@ -60,3 +60,20 @@ def test_language_selected(self):
resp = self.client.get(reverse(self.view_name))
doc = pq(resp.content)
assert doc('#id_lang option[selected="selected"]').val() == ""

@override_settings(DEV=True)
def test_newsletters_selected(self):
"""
By default both newsletters should be checked.
"""
with self.activate_locale("en-US"):
resp = self.client.get(reverse(self.view_name))
doc = pq(resp.content)
assert doc('#id_newsletters_0[checked="checked"]').length == 1
assert doc('#id_newsletters_1[checked="checked"]').length == 1

with self.activate_locale("en-US"):
resp = self.client.get(reverse("firefox.nothing-personal.index"))
doc = pq(resp.content)
assert doc('#id_newsletters_0[checked="checked"]').length == 0
assert doc('#id_newsletters_1[checked="checked"]').length == 0
2 changes: 1 addition & 1 deletion media/css/firefox/nothing-personal/_browser.scss
Original file line number Diff line number Diff line change
Expand Up @@ -102,10 +102,10 @@

.c-browser-window-top {
h2 {
@include text-title-xl;
line-height: 1;
margin: 0;
padding-right: $spacing-lg;
@include text-title-xl;
}

&::after {
Expand Down
8 changes: 7 additions & 1 deletion media/css/firefox/nothing-personal/_header.scss
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,12 @@
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at https://mozilla.org/MPL/2.0/.

@media (prefers-reduced-motion: no-preference) {
html {
scroll-padding-top: 120px; /* height of sticky header */
}
}

.c-page-header {
background-color: $browser-background;
border-bottom: $border-black;
Expand Down Expand Up @@ -56,11 +62,11 @@
justify-self: end;

p {
@include text-body-lg;
display: block;
font-family: 'Fira Mono', 'Andale Mono', monospace;
font-weight: 500;
margin: 0 $spacing-md 0 0;
@include text-body-lg;
}
}
}
Expand Down
2 changes: 1 addition & 1 deletion media/css/firefox/nothing-personal/_primary-cta.scss
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,6 @@ html.android {

.mzp-c-button,
#protocol-nav-download-firefox > .mzp-c-button {
@include text-body-lg;
padding: $spacing-sm $spacing-lg;
background-color: $color-yellow-20;
background-image: linear-gradient(to right,$color-yellow-20, $color-orange-50, $color-yellow-20, $color-yellow-20);
Expand All @@ -130,6 +129,7 @@ html.android {
color: $color-black;
border-color: $color-black;
transition: all 0.3s ease-out;
@include text-body-lg;

@media (prefers-reduced-motion: reduce) {
background-image: linear-gradient(to right,$color-yellow-20, $color-orange-50);
Expand Down
4 changes: 2 additions & 2 deletions media/css/firefox/nothing-personal/_sticky-note.scss
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
// file, You can obtain one at https://mozilla.org/MPL/2.0/.

.c-sticky-note {
@include text-body-lg;
background-image: url('/media/img/firefox/nothing-personal/sticky-note-bg.svg');
background-repeat: no-repeat;
background-size: contain;
Expand All @@ -13,6 +12,7 @@
padding: $spacing-xl;
transform: rotate(11deg);
text-align: center;
@include text-body-lg;

&.c-detached-sticky {
position: relative;
Expand Down Expand Up @@ -67,11 +67,11 @@
margin-bottom: 0;

a {
@include text-body-lg;
border: 0;
background: transparent;
color: $color-black;
padding: 0;
@include text-body-lg;

&:hover,
&:focus,
Expand Down
2 changes: 1 addition & 1 deletion media/css/firefox/nothing-personal/styles.scss
Original file line number Diff line number Diff line change
Expand Up @@ -86,8 +86,8 @@ $mq-tad-smaller-sm: 455px;
}

.c-sign-off {
@include text-title-xs;
margin: $layout-lg 0;
@include text-title-xs;

.c-nothing-personal {
padding: 12px;
Expand Down

0 comments on commit e8b1055

Please sign in to comment.