Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

EL-1431: Search page - Update styling #229

Merged
merged 32 commits into from
Apr 19, 2024
Merged
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
87c9f15
update view based on flag
MazOneTwoOne Apr 5, 2024
af53557
make feature flag live in staging
MazOneTwoOne Apr 5, 2024
8ca5a07
update
MazOneTwoOne Apr 8, 2024
ccf2605
update to stylings and layout
MazOneTwoOne Apr 9, 2024
4b4dcfd
updates from review comments
MazOneTwoOne Apr 11, 2024
9980598
updates from review comments
MazOneTwoOne Apr 11, 2024
95e08be
last bits of from review commets
MazOneTwoOne Apr 11, 2024
9f9e501
remove duplicates
MazOneTwoOne Apr 11, 2024
9f0c704
removing more duplicaation and addng in extra CSS
MazOneTwoOne Apr 11, 2024
ef0d4e6
typo
MazOneTwoOne Apr 11, 2024
6202cbb
update views.py
MazOneTwoOne Apr 11, 2024
eb58ed1
update to stylings
MazOneTwoOne Apr 12, 2024
01db105
Update to test and template
MazOneTwoOne Apr 16, 2024
4d3aaaf
remove results template
MazOneTwoOne Apr 16, 2024
e8bc793
update tests
MazOneTwoOne Apr 16, 2024
15b4450
test update
MazOneTwoOne Apr 16, 2024
40f9c77
revert changes
MazOneTwoOne Apr 16, 2024
0a9a19a
add `LAALAA_API_HOST` variable in CircleCi config
MazOneTwoOne Apr 17, 2024
d7d3eba
Merge branch 'master' into EL-1431-search-page
MazOneTwoOne Apr 17, 2024
96fbb44
refactor test's
MazOneTwoOne Apr 17, 2024
548de25
refactor of tests - chaneg the scope.
MazOneTwoOne Apr 17, 2024
0821056
typo in test method
MazOneTwoOne Apr 17, 2024
0e5b15b
use `LiveServerTestCase` class
MazOneTwoOne Apr 17, 2024
fc196b6
reformatted views, test, and base.py
MazOneTwoOne Apr 17, 2024
b76e2e3
Merge branch 'master' into EL-1431-search-page
MazOneTwoOne Apr 17, 2024
c36a629
revert change to `urls.py` as `adviser` already installed in `base.py`
MazOneTwoOne Apr 17, 2024
f980038
update to the way we populate a form filed via a feature flag - based…
MazOneTwoOne Apr 18, 2024
37f65b6
switch around what is shown on conditional
MazOneTwoOne Apr 18, 2024
571026d
update on comment, on where to find documentation
MazOneTwoOne Apr 19, 2024
45736f7
Merge branch 'master' into EL-1431-search-page
MazOneTwoOne Apr 19, 2024
f85d460
update CSS
MazOneTwoOne Apr 19, 2024
0a60189
update CSS
MazOneTwoOne Apr 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,8 @@ jobs:
command: |
source env/bin/activate
python manage.py test
environment:
LAALAA_API_HOST: "https://laa-legal-adviser-api-staging.apps.live-1.cloud-platform.service.justice.gov.uk"

build:
executor: aws-ecr/default # use the aws-ecr/default executor to start the docker daemon
Expand Down
28 changes: 22 additions & 6 deletions fala/apps/adviser/forms.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
# coding=utf-8
from django import forms
from django.utils.translation import gettext_lazy as _
from django.utils.safestring import mark_safe
from django.conf import settings

import laalaa.api as laalaa
import re
Expand All @@ -26,16 +28,30 @@ def __init__(self, attrs={}):
class AdviserSearchForm(forms.Form):
page = forms.IntegerField(required=False, widget=forms.HiddenInput())

postcode = forms.CharField(
label=_("Enter postcode"),
max_length=30,
help_text=_("For example, <span class='notranslate' translate='no'>SW1H 9AJ</span>"),
if settings.FEATURE_FLAG_NO_MAP:
MazOneTwoOne marked this conversation as resolved.
Show resolved Hide resolved
postcode = forms.CharField(
label=_("Postcode"),
max_length=30,
help_text=_(mark_safe("For example, <span class='notranslate' translate='no'>SW1H</span>")),
required=False,
widget=FalaTextInput(),
)
else:
postcode = forms.CharField(
label=_("Enter postcode"),
max_length=30,
help_text=_("For example, <span class='notranslate' translate='no'>SW1H 9AJ</span>"),
required=False,
widget=FalaTextInput(),
)

name = forms.CharField(
label=_("Organisation name"),
max_length=100,
required=False,
widget=FalaTextInput(),
)

name = forms.CharField(label=_("Organisation name"), max_length=100, required=False, widget=FalaTextInput())

type = forms.MultipleChoiceField(
label=_("Organisation type"),
choices=ORGANISATION_TYPES_CHOICES,
Expand Down
33 changes: 33 additions & 0 deletions fala/apps/adviser/tests/test_search_view_function.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
from django.test import SimpleTestCase, Client, override_settings
from django.urls import reverse


@override_settings(FEATURE_FLAG_NO_MAP=True)
class SearchViewFunctionTest(SimpleTestCase):
client = Client()

url = reverse("adviser")

def test_postcode_search(self):
response = self.client.get(self.url, {"postcode": "PE31"})
self.assertEqual(200, response.status_code)

def test_invalid_postcode_generates_error(self):
response = self.client.get(self.url, {"postcode": "ZZZ"})
self.assertEqual({"postcode": ["Postcode not found"]}, response.context_data["form"].errors)


@override_settings(FEATURE_FLAG_NO_MAP=True)
class NewSearchViewTemplate(SimpleTestCase):
client = Client()

def test_template_link_and_css(self):
response = self.client.get(reverse("adviser"))

self.assertEqual(response.status_code, 200)

# Ensure URL link is in response content
self.assertContains(response, "https://www.gov.uk/check-legal-aid")

# Ensure CSS class is in response content
self.assertContains(response, "laa-fala__grey-box")
10 changes: 9 additions & 1 deletion fala/apps/adviser/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,14 @@


class AdviserView(TemplateView):
template_name = "adviser/search.html"
# https://docs.djangoproject.com/en/5.0/topics/class-based-views/#usage-in-your-urlconf - this is how `template_name`

def get_template_names(self) -> list[str]:
if settings.FEATURE_FLAG_NO_MAP:
template_name = "adviser/search.html"
else:
template_name = "adviser/search_old.html"
return [template_name]

def get(self, request, *args, **kwargs):
context = self.get_context_data(**kwargs)
Expand All @@ -22,6 +29,7 @@ def get(self, request, *args, **kwargs):
"current_url": current_url,
"GOOGLE_MAPS_API_KEY": settings.GOOGLE_MAPS_API_KEY,
"LAALAA_API_HOST": settings.LAALAA_API_HOST,
"CHECK_LEGAL_AID_URL": settings.CHECK_LEGAL_AID_URL,
}
)

Expand Down
18 changes: 16 additions & 2 deletions fala/assets-src/sass/main.scss
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,6 @@ body.govuk-template__body {
height: auto;
height: initial;
display: block;
font-family: GDS Transport, Arial, sans-serif; /*temp - remove when all classes updated*/
}

.govuk-footer__copyright-logo,
Expand Down Expand Up @@ -91,6 +90,14 @@ body.govuk-template__body {

.fala-tickbox-columns .govuk-checkboxes__item label.govuk-checkboxes__label {
min-width:100%;
inline-size: 150px;
overflow-wrap: break-word;
}

.govuk-checkboxes__label {
&::before {
background-color: govuk-colour("white");
}
}

/*below override for archaic class*/
Expand Down Expand Up @@ -183,7 +190,14 @@ body.fala-dev {
max-width: 140px;
}

.laa-fala__search {
.laa-fala {
&__search {
margin-top:1em;
clear:both;
}

&__grey-box {
background-color: govuk-colour("light-grey");
padding: 1em;
}
}
2 changes: 2 additions & 0 deletions fala/settings/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -228,6 +228,8 @@ def root(*x):

GOOGLE_MAPS_API_KEY = os.environ.get("GOOGLE_MAPS_API_KEY", "")

CHECK_LEGAL_AID_URL = "https://www.gov.uk/check-legal-aid"

# .local.py overrides all the common settings.
try:
from .local import * # noqa: F401,F403
Expand Down
138 changes: 79 additions & 59 deletions fala/templates/adviser/search.html
Original file line number Diff line number Diff line change
Expand Up @@ -7,70 +7,90 @@
{% import "macros/element.html" as Element %}
{% import "macros/forms.html" as Form %}

{% block search_form %}
<form action="" class="laa-fala__search" novalidate>
<div
class="govuk-form-group
{% if (form.errors and form.errors['__all__']) %}
govuk-form-group--error
{% endif %}
"
id="fala_questions">
{% block content %}
<div class="govuk-grid-column-two-thirds">
<div id="google_translate_element" class="govuk-!-margin-bottom-6"></div>
<h1 class="govuk-heading-xl"> Find a legal aid adviser or family mediator </h1>
<p class="govuk-body">You need to provide information about your finances to find out if you qualify for legal aid.</p>
<p class="govuk-body"><a class="govuk-link" href="{{ CHECK_LEGAL_AID_URL }}" target="_blank" rel="noopener">Check if you qualify for legal aid (opens in a new tab)</a></p>
</div>

{% set errorMessage = {'err': ""} %}
{% block search_form %}
<div class="govuk-grid-column-full">
<div class="laa-fala__grey-box">
<form action="" novalidate>
<div
class="govuk-form-group
{% if (form.errors and form.errors['__all__']) %}
govuk-form-group--error
{% endif %}
"
id="fala_questions">

{% if form.errors and form.errors['__all__'] %}
{% call Element.errorText() %}
{% for k, error in form.errors.items() %}
{% if errorMessage.update({'err': error | striptags}) %}{% endif %}
{% endfor %}
{% endcall %}
{% endif %}
{% set errorMessage = {'err': ""} %}

{% if (form.errors and form.errors['__all__']) %}
{% call Form.group(form.postcode, 'govuk-form-group', {'class':'govuk-input--error'}, hide_optional=True, global_error=errorMessage.err) %}
{% endcall %}
{% call Form.group(form.name, 'govuk-form-group', {'class':'govuk-input--error'}, hide_optional=True, max_length='100', global_error_hidden=errorMessage.err) %}
{% endcall %}
{% else %}
{% call Form.group(form.postcode, 'govuk-form-group', hide_optional=True) %}
{% endcall %}
{% call Form.group(form.name, 'govuk-form-group', hide_optional=True, max_length='100') %}
{% endcall %}
{% endif %}
</div>
<button type="submit" class="govuk-button" id="searchButton" name="search">Search</button>
{% if form.errors and form.errors['__all__'] %}
{% call Element.errorText() %}
{% for k, error in form.errors.items() %}
{% if errorMessage.update({'err': error | striptags}) %}{% endif %}
{% endfor %}
{% endcall %}
{% endif %}

<div class="form-group filters">
<div class="govuk-form-group">
<fieldset class="govuk-fieldset">
<legend class="govuk-fieldset__legend govuk-fieldset__legend--m">
<h2 class="govuk-fieldset__heading">
Filter by category
</h2>
</legend>
<div class="govuk-checkboxes govuk-checkboxes--small fala-tickbox-columns">
{% for value, label_text in form.categories.field.choices %}
<div class="govuk-checkboxes__item">
<input
class="govuk-checkboxes__input"
id="id_categories_{{ loop.index0 }}"
name="categories"
type="checkbox"
value="{{ value }}"
{% if value in request.GET.getlist('categories','') %}
checked
{% endif %}
>
<label class="govuk-label govuk-checkboxes__label" for="id_categories_{{ loop.index0 }}">
{{ label_text }}
</label>
{% if (form.errors and form.errors['__all__']) %}
{% call Form.group(form.postcode, 'govuk-form-group', {'class':'govuk-input--error'}, hide_optional=True, global_error=errorMessage.err) %}
{% endcall %}
<p class="govuk-body">Or</p>
{% call Form.group(form.name, 'govuk-form-group', {'class':'govuk-input--error'}, hide_optional=True, max_length='100', global_error_hidden=errorMessage.err) %}
{% endcall %}
{% else %}
{% call Form.group(form.postcode, 'govuk-form-group', hide_optional=True) %}
{% endcall %}
<p class="govuk-body">Or</p>
{% call Form.group(form.name, 'govuk-form-group', hide_optional=True, max_length='100') %}
{% endcall %}
{% endif %}
</div>

<div class="form-group filters">
<div class="govuk-form-group">
<fieldset class="govuk-fieldset">
<legend class="govuk-fieldset__legend govuk-fieldset__legend--m">
<label class="govuk-label govuk-label--s">
Catgories of law (optional)
</label>
</legend>
<div class="govuk-checkboxes govuk-checkboxes--small fala-tickbox-columns">
{% for value, label_text in form.categories.field.choices %}
<div class="govuk-checkboxes__item">
<input
class="govuk-checkboxes__input"
id="id_categories_{{ loop.index0 }}"
name="categories"
type="checkbox"
value="{{ value }}"
{% if value in request.GET.getlist('categories','') %}
checked
{% endif %}
>
<label class="govuk-label govuk-checkboxes__label" for="id_categories_{{ loop.index0 }}">
{{ label_text }}
</label>
</div>
{% endfor %}
</div>
</fieldset>
</div>
{% endfor %}
</div>
</fieldset>
<button type="submit" class="govuk-button govuk-!-margin-bottom-2" id="searchButton" name="search">Search</button>
</div>
</form>
</div>
</div>
<button type="submit" class="govuk-button govuk-button--secondary" name="filter">Apply filter</button>
{% endblock %}

<div class="govuk-grid-column-full">
<p class="govuk-body govuk-!-margin-top-5">If you are a provider and your details are incorrect, please contact your contract manager.</p>
</div>
</form>
{% endblock %}


76 changes: 76 additions & 0 deletions fala/templates/adviser/search_old.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
{% if request.headers.get('x-requested-with') == 'XMLHttpRequest' %}
{% extends 'ajax-base.html' %}
{% else %}
{% extends 'base.html' %}
{% endif %}

{% import "macros/element.html" as Element %}
{% import "macros/forms.html" as Form %}

{% block search_form %}
<form action="" class="laa-fala__search" novalidate>
<div
class="govuk-form-group
{% if (form.errors and form.errors['__all__']) %}
govuk-form-group--error
{% endif %}
"
id="fala_questions">

{% set errorMessage = {'err': ""} %}

{% if form.errors and form.errors['__all__'] %}
{% call Element.errorText() %}
{% for k, error in form.errors.items() %}
{% if errorMessage.update({'err': error | striptags}) %}{% endif %}
{% endfor %}
{% endcall %}
{% endif %}

{% if (form.errors and form.errors['__all__']) %}
{% call Form.group(form.postcode, 'govuk-form-group', {'class':'govuk-input--error'}, hide_optional=True, global_error=errorMessage.err) %}
{% endcall %}
{% call Form.group(form.name, 'govuk-form-group', {'class':'govuk-input--error'}, hide_optional=True, max_length='100', global_error_hidden=errorMessage.err) %}
{% endcall %}
{% else %}
{% call Form.group(form.postcode, 'govuk-form-group', hide_optional=True) %}
{% endcall %}
{% call Form.group(form.name, 'govuk-form-group', hide_optional=True, max_length='100') %}
{% endcall %}
{% endif %}
</div>
<button type="submit" class="govuk-button" id="searchButton" name="search">Search</button>

<div class="form-group filters">
<div class="govuk-form-group">
<fieldset class="govuk-fieldset">
<legend class="govuk-fieldset__legend govuk-fieldset__legend--m">
<h2 class="govuk-fieldset__heading">
Filter by category
</h2>
</legend>
<div class="govuk-checkboxes govuk-checkboxes--small fala-tickbox-columns">
{% for value, label_text in form.categories.field.choices %}
<div class="govuk-checkboxes__item">
<input
class="govuk-checkboxes__input"
id="id_categories_{{ loop.index0 }}"
name="categories"
type="checkbox"
value="{{ value }}"
{% if value in request.GET.getlist('categories','') %}
checked
{% endif %}
>
<label class="govuk-label govuk-checkboxes__label" for="id_categories_{{ loop.index0 }}">
{{ label_text }}
</label>
</div>
{% endfor %}
</div>
</fieldset>
</div>
<button type="submit" class="govuk-button govuk-button--secondary" name="filter">Apply filter</button>
</div>
</form>
{% endblock %}
2 changes: 1 addition & 1 deletion fala/templates/generic-py-base.html
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@
<div class="govuk-width-container">
{% block global_subheader %}{% endblock %}
<main id="main-content" class="govuk-main-wrapper" role="main">
<div class="container govuk-grid-row">
<div class="govuk-grid-row">
{% block content %}{% endblock %}
</div>
</main>
Expand Down
Loading