From c227598ae2b7a78cb9b2b33884fdd5f50b1f04c4 Mon Sep 17 00:00:00 2001
From: Thomas Leese
Date: Thu, 14 Dec 2023 10:47:47 +0000
Subject: [PATCH] Use GOV.UK Design System task list
This upgrades our task lists to use the new one that is included as
part of the GOV.UK Design System.
---
app/assets/stylesheets/_task_list.scss | 70 ----------------
app/assets/stylesheets/application.sass.scss | 1 -
app/components/task_list/component.html.erb | 33 --------
app/components/task_list/component.rb | 42 ----------
...further_information_request_view_object.rb | 37 ++++-----
.../application_forms/show.html.erb | 12 ++-
.../assessments/review.html.erb | 81 +++++++++----------
.../show.html.erb | 76 ++++++++---------
.../qualification_requests/index.html.erb | 26 +++---
.../reference_requests/index.html.erb | 24 +++---
.../application_forms/show/_draft.html.erb | 10 ++-
.../show.html.erb | 11 ++-
.../qualification_requests/index.html.erb | 10 ++-
spec/components/task_list_spec.rb | 27 -------
.../assessor_interface/application.rb | 42 +++++-----
.../professional_standing_request.rb | 2 +-
.../qualification_requests.rb | 5 +-
.../assessor_interface/reference_requests.rb | 2 +-
.../review_verifications.rb | 2 +-
.../autoload/page_objects/govuk_task_list.rb | 20 +++++
.../autoload/page_objects/task_list.rb | 13 ---
.../autoload/page_objects/task_list_item.rb | 9 ---
.../page_objects/task_list_section.rb | 6 --
.../teacher_interface/application.rb | 24 +++---
.../further_information_requested.rb | 4 +-
.../qualification_requests.rb | 2 +-
.../checking_submitted_details_spec.rb | 6 --
.../pre_assessment_tasks_spec.rb | 4 +-
.../reverse_decision_spec.rb | 4 +-
.../reviewing_further_information_spec.rb | 2 +-
.../reviewing_professional_standing_spec.rb | 2 +-
.../reviewing_qualifications_spec.rb | 2 +-
.../verifying_professional_standing_spec.rb | 2 +-
.../verifying_qualifications_spec.rb | 8 +-
.../verifying_references_spec.rb | 30 ++-----
.../view_application_form_spec.rb | 6 +-
.../withdraw_application_spec.rb | 6 +-
.../further_information_spec.rb | 6 +-
.../qualification_consent_spec.rb | 24 ++----
...er_information_request_view_object_spec.rb | 50 ++++++------
40 files changed, 270 insertions(+), 473 deletions(-)
delete mode 100644 app/assets/stylesheets/_task_list.scss
delete mode 100644 app/components/task_list/component.html.erb
delete mode 100644 app/components/task_list/component.rb
delete mode 100644 spec/components/task_list_spec.rb
create mode 100644 spec/support/autoload/page_objects/govuk_task_list.rb
delete mode 100644 spec/support/autoload/page_objects/task_list.rb
delete mode 100644 spec/support/autoload/page_objects/task_list_item.rb
delete mode 100644 spec/support/autoload/page_objects/task_list_section.rb
diff --git a/app/assets/stylesheets/_task_list.scss b/app/assets/stylesheets/_task_list.scss
deleted file mode 100644
index dca012f558..0000000000
--- a/app/assets/stylesheets/_task_list.scss
+++ /dev/null
@@ -1,70 +0,0 @@
-.app-task-list {
- list-style-type: none;
- padding-left: 0;
- margin-top: 0;
- margin-bottom: 0;
- @include govuk-media-query($from: tablet) {
- min-width: 550px;
- }
-}
-
-.app-task-list__section {
- display: table;
- @include govuk-font($size: 24, $weight: bold);
-}
-
-.app-task-list__section-number {
- display: table-cell;
-
- @include govuk-media-query($from: tablet) {
- min-width: govuk-spacing(6);
- padding-right: 0;
- }
-}
-
-.app-task-list__items-no-indentation {
- @include govuk-font($size: 19);
- @include govuk-responsive-margin(9, "bottom");
- list-style: none;
- padding-left: 0;
-}
-
-.app-task-list__items {
- @include govuk-font($size: 19);
- @include govuk-responsive-margin(9, "bottom");
- list-style: none;
- padding-left: 0;
- @include govuk-media-query($from: tablet) {
- padding-left: govuk-spacing(6);
- }
-}
-
-.app-task-list__item {
- border-bottom: 1px solid $govuk-border-colour;
- margin-bottom: 0 !important;
- padding-top: govuk-spacing(2);
- padding-bottom: govuk-spacing(2);
- @include govuk-clearfix;
-}
-
-.app-task-list__item:first-child {
- border-top: 1px solid $govuk-border-colour;
-}
-
-.app-task-list__task-name {
- display: block;
- @include govuk-media-query($from: 450px) {
- float: left;
- }
-}
-
-.app-task-list__tag {
- margin-top: govuk-spacing(2);
- margin-bottom: govuk-spacing(1);
-
- @include govuk-media-query($from: 450px) {
- float: right;
- margin-top: 0;
- margin-bottom: 0;
- }
-}
diff --git a/app/assets/stylesheets/application.sass.scss b/app/assets/stylesheets/application.sass.scss
index eb30b93f04..7ad54209ad 100644
--- a/app/assets/stylesheets/application.sass.scss
+++ b/app/assets/stylesheets/application.sass.scss
@@ -16,7 +16,6 @@ $moj-images-path: "/";
@import "_environments";
@import "_search_results";
@import "_support";
-@import "_task_list";
ul.autocomplete__menu {
li {
diff --git a/app/components/task_list/component.html.erb b/app/components/task_list/component.html.erb
deleted file mode 100644
index a5b35fe21b..0000000000
--- a/app/components/task_list/component.html.erb
+++ /dev/null
@@ -1,33 +0,0 @@
-
- <% sections.each do |section| %>
- -
- <% if (title = section[:title]).present? %>
-
- <% if sections.count > 1 %>
- <%= section[:number] %>.
- <% end %>
-
- <%= title %>
-
- <% end %>
-
-
- <% section[:items].each do |item| %>
- -
- <% status_id = "#{section[:number]}-#{section[:key]}-#{item[:key]}-status" %>
-
-
- <% if (link = item[:link]).present? %>
- <%= govuk_link_to item[:name], link %>
- <% else %>
- <%= item[:name] %>
- <% end %>
-
-
- <%= render(StatusTag::Component.new(item[:status], id: status_id, class_context: "app-task-list")) %>
-
- <% end %>
-
-
- <% end %>
-
diff --git a/app/components/task_list/component.rb b/app/components/task_list/component.rb
deleted file mode 100644
index ac12461ce6..0000000000
--- a/app/components/task_list/component.rb
+++ /dev/null
@@ -1,42 +0,0 @@
-# frozen_string_literal: true
-
-module TaskList
- class Component < ViewComponent::Base
- ##
- # Renders a task list from the following data structure:
- #
- # sections: [
- # {
- # title: "Title",
- # items: [
- # {
- # name: "Do this thing",
- # link: "/do-this-thing",
- # status: "not_started"
- # }
- # ]
- # }
- # ]
-
- def initialize(sections)
- super
- @sections = sections
- end
-
- def sections
- @sections
- .filter { |section| section[:items].present? }
- .each_with_index
- .map do |section, index|
- section.merge(
- number: index + 1,
- key: section[:title]&.parameterize,
- items:
- section[:items].map do |item|
- item.merge(key: item[:name].parameterize)
- end,
- )
- end
- end
- end
-end
diff --git a/app/view_objects/teacher_interface/further_information_request_view_object.rb b/app/view_objects/teacher_interface/further_information_request_view_object.rb
index 2708f1be76..04fe743939 100644
--- a/app/view_objects/teacher_interface/further_information_request_view_object.rb
+++ b/app/view_objects/teacher_interface/further_information_request_view_object.rb
@@ -15,26 +15,23 @@ def further_information_request
.find(params[:id])
end
- def task_list_sections
- items =
- further_information_request
- .items
- .order(:created_at)
- .map do |item|
- {
- name: item_name(item),
- link: [
- :edit,
- :teacher_interface,
- :application_form,
- further_information_request,
- item,
- ],
- status: item.state,
- }
- end
-
- [{ title: "Further information requested", items: }]
+ def task_list_items
+ further_information_request
+ .items
+ .order(:created_at)
+ .map do |item|
+ {
+ title: item_name(item),
+ href: [
+ :edit,
+ :teacher_interface,
+ :application_form,
+ further_information_request,
+ item,
+ ],
+ status: item.state,
+ }
+ end
end
def can_check_answers?
diff --git a/app/views/assessor_interface/application_forms/show.html.erb b/app/views/assessor_interface/application_forms/show.html.erb
index e9b268d84f..8dd236bd2e 100644
--- a/app/views/assessor_interface/application_forms/show.html.erb
+++ b/app/views/assessor_interface/application_forms/show.html.erb
@@ -30,4 +30,14 @@
Task list
-<%= render(TaskList::Component.new(@view_object.task_list_sections)) %>
+<% @view_object.task_list_sections.each do |section| %>
+ <% if (items = section[:items]).present? %>
+ <%= section[:title] %>
+
+ <%= govuk_task_list(id_prefix: section[:title].parameterize) do |task_list|
+ items.each do |item|
+ task_list.with_item(title: item[:name], href: item[:link], status: render(StatusTag::Component.new(item[:status])))
+ end
+ end %>
+ <% end %>
+<% end %>
diff --git a/app/views/assessor_interface/assessments/review.html.erb b/app/views/assessor_interface/assessments/review.html.erb
index 4e409b7bf8..fbc8ccc7e9 100644
--- a/app/views/assessor_interface/assessments/review.html.erb
+++ b/app/views/assessor_interface/assessments/review.html.erb
@@ -7,48 +7,41 @@
The following verification tasks have been flagged for review:
-<%= render(TaskList::Component.new([
- if @professional_standing_request.present?
- {
- title: "LoPS",
- indentation: false,
- items: [
- {
- name: region_teaching_authority_name(@application_form.region, context: :assessor).upcase_first,
- link: [:review, :assessor_interface, @application_form, @assessment, :professional_standing_request],
- status: @professional_standing_request.review_status,
- }
- ],
- }
- end,
- if @qualification_requests.present?
- {
- title: "Qualifications",
- indentation: false,
- items: @qualification_requests.map do |qualification_request|
- {
- name: qualification_title(qualification_request.qualification),
- link: [:review, :assessor_interface, @application_form, @assessment, qualification_request],
- status: qualification_request.review_status,
- }
- end
- }
- end,
- if @reference_requests.present?
- {
- title: "References",
- indentation: false,
- items: @reference_requests.map do |reference_request|
- {
- name: work_history_name(reference_request.work_history),
- link: [:review, :assessor_interface, @application_form, @assessment, reference_request],
- status: reference_request.review_status,
- }
- end
- }
- end
-].compact)) %>
+<% if @professional_standing_request.present? %>
+
- <%= govuk_button_link_to "Back to overview", [:assessor_interface, @application_form] %>
-
+<% if @qualification_requests.present? %>
+
<% if view_object.can_submit? %>
diff --git a/app/views/teacher_interface/further_information_requests/show.html.erb b/app/views/teacher_interface/further_information_requests/show.html.erb
index fb3242a210..fd8cad0baf 100644
--- a/app/views/teacher_interface/further_information_requests/show.html.erb
+++ b/app/views/teacher_interface/further_information_requests/show.html.erb
@@ -3,12 +3,17 @@
Apply for qualified teacher status (QTS)
-<%= render TaskList::Component.new(@view_object.task_list_sections) %>
+
Further information requested
+
+<%= govuk_task_list do |task_list|
+ @view_object.task_list_items.each do |item|
+ task_list.with_item(title: item[:title], href: item[:href], status: render(StatusTag::Component.new(item[:status])))
+ end
+end %>
<% if @view_object.can_check_answers? %>
Once you’ve checked your response on the next screen, you’ll be able to submit it.
- <%= govuk_button_link_to t("teacher_interface.further_information_request.show.check"), edit_teacher_interface_application_form_further_information_request_path(@view_object.further_information_request) %>
+ <%= govuk_button_link_to t("teacher_interface.further_information_request.show.check"), [:edit, :teacher_interface, :application_form, @view_object.further_information_request] %>
<% end %>
-
<%= govuk_button_link_to t("teacher_interface.application_forms.show.draft.save"), destroy_teacher_session_path, secondary: true %>
diff --git a/app/views/teacher_interface/qualification_requests/index.html.erb b/app/views/teacher_interface/qualification_requests/index.html.erb
index 96cc62cd37..18e38d3688 100644
--- a/app/views/teacher_interface/qualification_requests/index.html.erb
+++ b/app/views/teacher_interface/qualification_requests/index.html.erb
@@ -3,7 +3,15 @@
Consent documents overview
-<%= render(TaskList::Component.new(@view_object.task_list_sections)) %>
+<% @view_object.task_list_sections.each do |section| %>
+
<%= section[:title] %>
+
+ <%= govuk_task_list(id_prefix: section[:title].parameterize) do |task_list|
+ section[:items].each do |item|
+ task_list.with_item(title: item[:name], href: item[:link], status: render(StatusTag::Component.new(item[:status])))
+ end
+ end %>
+<% end %>
<% if @view_object.can_submit? %>
diff --git a/spec/components/task_list_spec.rb b/spec/components/task_list_spec.rb
deleted file mode 100644
index 66d413b8de..0000000000
--- a/spec/components/task_list_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-# frozen_string_literal: true
-
-require "rails_helper"
-
-RSpec.describe TaskList::Component, type: :component do
- subject(:component) { render_inline(described_class.new(sections)) }
-
- let(:sections) do
- [
- {
- title: "Section A",
- items: [{ name: "Item A", href: "/item-a", status: "not_started" }],
- },
- { title: "Section B", items: [{ name: "Item B", status: "completed" }] },
- ]
- end
-
- it "numbers the section titles" do
- expect(component.text.squish).to include("1. Section A")
- expect(component.text.squish).to include("2. Section B")
- end
-
- it "shows the item statuses" do
- expect(component.text.squish).to include("Item A Not started")
- expect(component.text.squish).to include("Item B Completed")
- end
-end
diff --git a/spec/support/autoload/page_objects/assessor_interface/application.rb b/spec/support/autoload/page_objects/assessor_interface/application.rb
index c9cfe323e3..b464abb922 100644
--- a/spec/support/autoload/page_objects/assessor_interface/application.rb
+++ b/spec/support/autoload/page_objects/assessor_interface/application.rb
@@ -10,11 +10,7 @@ class Application < SitePrism::Page
element :add_note_button, ".app-inline-action .govuk-button"
section :summary_list, GovukSummaryList, ".govuk-summary-list"
- section :task_list, TaskList, ".app-task-list"
-
- section :management_tasks, ".app-task-list + .govuk-warning-text" do
- elements :links, ".govuk-link"
- end
+ sections :task_lists, GovukTaskList, ".govuk-task-list"
def name_summary
summary_list.find_row(key: "Name")
@@ -32,68 +28,72 @@ def status_summary
summary_list.find_row(key: "Status")
end
+ def find_task_list_item(name)
+ task_lists.map { |task_list| task_list.find_item(name) }.compact.first
+ end
+
def preliminary_check_task
- task_list.find_item("Preliminary check (qualifications)")
+ find_task_list_item("Preliminary check (qualifications)")
end
def awaiting_professional_standing_task
- task_list.find_item("Awaiting third-party professional standing")
+ find_task_list_item("Awaiting third-party professional standing")
end
def personal_information_task
- task_list.find_item("Check personal information")
+ find_task_list_item("Check personal information")
end
def qualifications_task
- task_list.find_item("Check qualifications")
+ find_task_list_item("Check qualifications")
end
def age_range_subjects_task
- task_list.find_item("Verify age range and subjects")
+ find_task_list_item("Verify age range and subjects")
end
def english_language_proficiency_task
- task_list.find_item("Check English language proficiency")
+ find_task_list_item("Check English language proficiency")
end
def work_history_task
- task_list.find_item("Check work history")
+ find_task_list_item("Check work history")
end
def professional_standing_task
- task_list.find_item("Check professional standing")
+ find_task_list_item("Check professional standing")
end
def review_requested_information_task
- task_list.find_item("Review requested information from applicant")
+ find_task_list_item("Review requested information from applicant")
end
def record_qualification_requests_task
- task_list.find_item("Record qualifications responses")
+ find_task_list_item("Record qualifications responses")
end
def review_qualification_requests_task
- task_list.find_item("Review qualifications responses")
+ find_task_list_item("Review qualifications responses")
end
def verify_references_task
- task_list.find_item("Verify references")
+ find_task_list_item("Verify references")
end
def verify_professional_standing_task
- task_list.find_item("Verify LoPS")
+ find_task_list_item("Verify LoPS")
end
def assessment_decision_task
- task_list.find_item("Assessment decision")
+ find_task_list_item("Assessment decision")
end
def review_verifications_task
- task_list.find_item("Review verifications")
+ find_task_list_item("Review verifications")
end
def verification_decision_task
- task_list.find_item("Verification decision")
+ find_task_list_item("Verification decision")
end
end
end
diff --git a/spec/support/autoload/page_objects/assessor_interface/professional_standing_request.rb b/spec/support/autoload/page_objects/assessor_interface/professional_standing_request.rb
index c8c2af925b..84cab78b33 100644
--- a/spec/support/autoload/page_objects/assessor_interface/professional_standing_request.rb
+++ b/spec/support/autoload/page_objects/assessor_interface/professional_standing_request.rb
@@ -6,7 +6,7 @@ class ProfessionalStandingRequest < SitePrism::Page
set_url "/assessor/applications/{reference}/assessments/{assessment_id}" \
"/professional-standing-request"
- section :task_list, TaskList, ".app-task-list"
+ section :task_list, GovukTaskList, ".govuk-task-list"
element :status_tag, ".govuk-tag"
def request_lops_verification_task
diff --git a/spec/support/autoload/page_objects/assessor_interface/qualification_requests.rb b/spec/support/autoload/page_objects/assessor_interface/qualification_requests.rb
index 9972942a15..982ed9522d 100644
--- a/spec/support/autoload/page_objects/assessor_interface/qualification_requests.rb
+++ b/spec/support/autoload/page_objects/assessor_interface/qualification_requests.rb
@@ -6,10 +6,7 @@ class QualificationRequests < SitePrism::Page
set_url "/assessor/applications/{reference}/assessments/{assessment_id}" \
"/qualification-requests"
- section :task_list, ".app-task-list__item" do
- elements :qualification_requests, ".app-task-list__task-name a"
- elements :status_tags, ".app-task-list__tag"
- end
+ section :task_list, GovukTaskList, ".govuk-task-list"
element :continue_button, ".govuk-button:not(.govuk-button--secondary)"
end
diff --git a/spec/support/autoload/page_objects/assessor_interface/reference_requests.rb b/spec/support/autoload/page_objects/assessor_interface/reference_requests.rb
index 12559cb438..0d72788eea 100644
--- a/spec/support/autoload/page_objects/assessor_interface/reference_requests.rb
+++ b/spec/support/autoload/page_objects/assessor_interface/reference_requests.rb
@@ -6,7 +6,7 @@ class ReferenceRequests < SitePrism::Page
set_url "/assessor/applications/{reference}/assessments/{assessment_id}" \
"/reference-requests"
- section :task_list, TaskList, ".app-task-list"
+ section :task_list, GovukTaskList, ".govuk-task-list"
element :continue_button, ".govuk-button:not(.govuk-button--secondary)"
end
diff --git a/spec/support/autoload/page_objects/assessor_interface/review_verifications.rb b/spec/support/autoload/page_objects/assessor_interface/review_verifications.rb
index a3b6f3b4fe..f0b0c7c24a 100644
--- a/spec/support/autoload/page_objects/assessor_interface/review_verifications.rb
+++ b/spec/support/autoload/page_objects/assessor_interface/review_verifications.rb
@@ -5,7 +5,7 @@ module AssessorInterface
class ReviewVerifications < SitePrism::Page
set_url "/assessor/applications/{reference}/assessments/{assessment_id}/review"
- section :task_list, TaskList, ".app-task-list"
+ section :task_list, GovukTaskList, ".govuk-task-list"
element :back_to_overview_button, ".govuk-button"
end
diff --git a/spec/support/autoload/page_objects/govuk_task_list.rb b/spec/support/autoload/page_objects/govuk_task_list.rb
new file mode 100644
index 0000000000..d18eaa9973
--- /dev/null
+++ b/spec/support/autoload/page_objects/govuk_task_list.rb
@@ -0,0 +1,20 @@
+# frozen_string_literal: true
+
+module PageObjects
+ class GovukTaskList < SitePrism::Section
+ sections :items, ".govuk-task-list__item" do
+ section :name_and_hint, ".govuk-task-list__name-and-hint" do
+ element :link, "a"
+ end
+ element :status_tag, ".govuk-tag"
+ end
+
+ def find_item(text)
+ items.find { |item| item.name_and_hint.text == text }
+ end
+
+ def click_item(link_text)
+ find_item(link_text).click
+ end
+ end
+end
diff --git a/spec/support/autoload/page_objects/task_list.rb b/spec/support/autoload/page_objects/task_list.rb
deleted file mode 100644
index 1a342923ca..0000000000
--- a/spec/support/autoload/page_objects/task_list.rb
+++ /dev/null
@@ -1,13 +0,0 @@
-module PageObjects
- class TaskList < SitePrism::Section
- sections :sections, TaskListSection, ".app-task-list > li"
-
- def find_item(text)
- sections.flat_map(&:items).find { |item| item.name.text == text }
- end
-
- def click_item(link_text)
- find_item(link_text).click
- end
- end
-end
diff --git a/spec/support/autoload/page_objects/task_list_item.rb b/spec/support/autoload/page_objects/task_list_item.rb
deleted file mode 100644
index a4ba2c2d8a..0000000000
--- a/spec/support/autoload/page_objects/task_list_item.rb
+++ /dev/null
@@ -1,9 +0,0 @@
-module PageObjects
- class TaskListItem < SitePrism::Section
- element :name, "span"
- element :link, "a"
- element :status_tag, ".govuk-tag"
-
- def_delegator :link, :click
- end
-end
diff --git a/spec/support/autoload/page_objects/task_list_section.rb b/spec/support/autoload/page_objects/task_list_section.rb
deleted file mode 100644
index 08981f2f9f..0000000000
--- a/spec/support/autoload/page_objects/task_list_section.rb
+++ /dev/null
@@ -1,6 +0,0 @@
-module PageObjects
- class TaskListSection < SitePrism::Section
- element :heading, "h2"
- sections :items, TaskListItem, ".app-task-list__item"
- end
-end
diff --git a/spec/support/autoload/page_objects/teacher_interface/application.rb b/spec/support/autoload/page_objects/teacher_interface/application.rb
index 5a9469baac..9007708179 100644
--- a/spec/support/autoload/page_objects/teacher_interface/application.rb
+++ b/spec/support/autoload/page_objects/teacher_interface/application.rb
@@ -11,42 +11,46 @@ class Application < SitePrism::Page
element :save_and_sign_out, ".govuk-button.govuk-button--secondary"
element :start_now_button, ".govuk-button:not(.govuk-button--secondary)"
- section :task_list, TaskList, ".app-task-list"
+ sections :task_lists, GovukTaskList, ".govuk-task-list"
+
+ def find_task_list_item(name)
+ task_lists.map { |task_list| task_list.find_item(name) }.compact.first
+ end
def personal_information_task_item
- task_list.find_item("Enter your personal information")
+ find_task_list_item("Enter your personal information")
end
def qualifications_task_item
- task_list.find_item("Add your teaching qualifications")
+ find_task_list_item("Add your teaching qualifications")
end
def age_range_task_item
- task_list.find_item("Enter the age range you can teach")
+ find_task_list_item("Enter the age range you can teach")
end
def subjects_task_item
- task_list.find_item("Enter the subjects you can teach")
+ find_task_list_item("Enter the subjects you can teach")
end
def english_language_task_item
- task_list.find_item("Verify your English language proficiency")
+ find_task_list_item("Verify your English language proficiency")
end
def work_history_task_item
- task_list.find_item("Add your work history")
+ find_task_list_item("Add your work history")
end
def registration_number_task_item
- task_list.find_item("Enter your registration number")
+ find_task_list_item("Enter your registration number")
end
def upload_written_statement_task_item
- task_list.find_item("Upload your written statement")
+ find_task_list_item("Upload your written statement")
end
def provide_written_statement_task_item
- task_list.find_item("Provide your written statement")
+ find_task_list_item("Provide your written statement")
end
end
end
diff --git a/spec/support/autoload/page_objects/teacher_interface/further_information_requested.rb b/spec/support/autoload/page_objects/teacher_interface/further_information_requested.rb
index d4b445209a..b25f0f48b5 100644
--- a/spec/support/autoload/page_objects/teacher_interface/further_information_requested.rb
+++ b/spec/support/autoload/page_objects/teacher_interface/further_information_requested.rb
@@ -1,10 +1,12 @@
+# frozen_string_literal: true
+
module PageObjects
module TeacherInterface
class FurtherInformationRequested < SitePrism::Page
set_url "/teacher/application/further_information_requests/{request_id}"
element :heading, ".govuk-heading-l"
- section :task_list, TaskList, ".app-task-list"
+ section :task_list, GovukTaskList, ".govuk-task-list"
element :check_your_answers_button,
".govuk-button:not(.govuk-button--secondary)"
diff --git a/spec/support/autoload/page_objects/teacher_interface/qualification_requests.rb b/spec/support/autoload/page_objects/teacher_interface/qualification_requests.rb
index 53db529dbe..56d28a8970 100644
--- a/spec/support/autoload/page_objects/teacher_interface/qualification_requests.rb
+++ b/spec/support/autoload/page_objects/teacher_interface/qualification_requests.rb
@@ -5,7 +5,7 @@ module TeacherInterface
class QualificationRequests < SitePrism::Page
set_url "/teacher/application/qualification-requests"
- section :task_list, TaskList, ".app-task-list"
+ sections :task_lists, GovukTaskList, ".govuk-task-list"
element :check_your_answers_button,
".govuk-button:not(.govuk-button--secondary)"
diff --git a/spec/system/assessor_interface/checking_submitted_details_spec.rb b/spec/system/assessor_interface/checking_submitted_details_spec.rb
index cfa7b8817c..15d4dc4a5f 100644
--- a/spec/system/assessor_interface/checking_submitted_details_spec.rb
+++ b/spec/system/assessor_interface/checking_submitted_details_spec.rb
@@ -257,12 +257,6 @@ def when_i_choose_check_personal_information_yes
assessor_check_personal_information_page.form.continue_button.click
end
- def personal_information_task_item
- assessor_application_page.task_list.tasks.first.items.find do |item|
- item.link.text == "Check personal information"
- end
- end
-
def and_i_see_check_personal_information_completed
expect(
assessor_application_page.personal_information_task.status_tag.text,
diff --git a/spec/system/assessor_interface/pre_assessment_tasks_spec.rb b/spec/system/assessor_interface/pre_assessment_tasks_spec.rb
index 4e03de2322..2833614e59 100644
--- a/spec/system/assessor_interface/pre_assessment_tasks_spec.rb
+++ b/spec/system/assessor_interface/pre_assessment_tasks_spec.rb
@@ -71,7 +71,7 @@ def and_i_see_a_waiting_on_status
end
def and_i_see_an_unstarted_preliminary_check_task
- expect(assessor_application_page.task_list).to have_content(
+ expect(assessor_application_page.task_lists.first).to have_content(
"Preliminary check (qualifications)",
)
expect(assessor_application_page.preliminary_check_task).to have_content(
@@ -145,7 +145,7 @@ def and_the_assessor_is_unassigned
end
def and_i_click_awaiting_professional_standing
- assessor_application_page.awaiting_professional_standing_task.link.click
+ assessor_application_page.awaiting_professional_standing_task.click
end
def when_i_fill_in_the_locate_form
diff --git a/spec/system/assessor_interface/reverse_decision_spec.rb b/spec/system/assessor_interface/reverse_decision_spec.rb
index 468685aa1e..a48cec98bb 100644
--- a/spec/system/assessor_interface/reverse_decision_spec.rb
+++ b/spec/system/assessor_interface/reverse_decision_spec.rb
@@ -39,13 +39,13 @@ def given_there_is_an_application_form
end
def and_i_see_the_reverse_decision_link
- expect(assessor_application_page.task_list).to have_content(
+ expect(assessor_application_page.task_lists.last).to have_content(
"Reverse decision",
)
end
def when_i_click_on_reverse_decision
- assessor_application_page.task_list.click_on("Reverse decision")
+ assessor_application_page.task_lists.last.click_on("Reverse decision")
end
def when_i_confirm_the_reversal
diff --git a/spec/system/assessor_interface/reviewing_further_information_spec.rb b/spec/system/assessor_interface/reviewing_further_information_spec.rb
index 38569fd7e5..46f647858f 100644
--- a/spec/system/assessor_interface/reviewing_further_information_spec.rb
+++ b/spec/system/assessor_interface/reviewing_further_information_spec.rb
@@ -69,7 +69,7 @@ def given_there_is_further_information_received
end
def and_i_click_review_requested_information
- assessor_application_page.review_requested_information_task.link.click
+ assessor_application_page.review_requested_information_task.click
end
def and_i_see_the_check_your_answers_items
diff --git a/spec/system/assessor_interface/reviewing_professional_standing_spec.rb b/spec/system/assessor_interface/reviewing_professional_standing_spec.rb
index 2f15e9921b..f025e7f5c6 100644
--- a/spec/system/assessor_interface/reviewing_professional_standing_spec.rb
+++ b/spec/system/assessor_interface/reviewing_professional_standing_spec.rb
@@ -106,7 +106,7 @@ def when_i_click_on_assessment_decision
end
def when_i_click_on_lops
- assessor_application_page.task_list.click_item(
+ assessor_review_verifications_page.task_list.click_item(
"Relevant competent authority",
)
end
diff --git a/spec/system/assessor_interface/reviewing_qualifications_spec.rb b/spec/system/assessor_interface/reviewing_qualifications_spec.rb
index 88cd6105aa..c4460b441d 100644
--- a/spec/system/assessor_interface/reviewing_qualifications_spec.rb
+++ b/spec/system/assessor_interface/reviewing_qualifications_spec.rb
@@ -106,7 +106,7 @@ def when_i_click_on_assessment_decision
end
def when_i_click_on_the_qualification
- assessor_application_page.task_list.click_item("BSc Teaching")
+ assessor_review_verifications_page.task_list.click_item("BSc Teaching")
end
def when_i_submit_yes_on_the_review_form
diff --git a/spec/system/assessor_interface/verifying_professional_standing_spec.rb b/spec/system/assessor_interface/verifying_professional_standing_spec.rb
index a5a05b0665..40724fe5e4 100644
--- a/spec/system/assessor_interface/verifying_professional_standing_spec.rb
+++ b/spec/system/assessor_interface/verifying_professional_standing_spec.rb
@@ -179,7 +179,7 @@ def given_the_professional_standing_request_has_expired
end
def and_i_click_professional_standing_task
- assessor_application_page.verify_professional_standing_task.link.click
+ assessor_application_page.verify_professional_standing_task.click
end
def when_i_click_request_lops_verification
diff --git a/spec/system/assessor_interface/verifying_qualifications_spec.rb b/spec/system/assessor_interface/verifying_qualifications_spec.rb
index 6fd6c77ba9..59c9cc57a1 100644
--- a/spec/system/assessor_interface/verifying_qualifications_spec.rb
+++ b/spec/system/assessor_interface/verifying_qualifications_spec.rb
@@ -86,7 +86,7 @@ def and_i_see_a_waiting_on_status
end
def and_i_click_record_qualifications_task
- assessor_application_page.record_qualification_requests_task.link.click
+ assessor_application_page.record_qualification_requests_task.click
end
def when_i_click_review_qualifications_task
@@ -94,11 +94,7 @@ def when_i_click_review_qualifications_task
end
def when_i_select_the_first_qualification_request
- assessor_qualification_requests_page
- .task_list
- .qualification_requests
- .first
- .click
+ assessor_qualification_requests_page.task_list.items.first.click
end
def when_the_request_is_received_and_passed
diff --git a/spec/system/assessor_interface/verifying_references_spec.rb b/spec/system/assessor_interface/verifying_references_spec.rb
index df3b5a86d0..19c1a2c2c1 100644
--- a/spec/system/assessor_interface/verifying_references_spec.rb
+++ b/spec/system/assessor_interface/verifying_references_spec.rb
@@ -115,15 +115,17 @@ def and_i_see_a_waiting_on_status
end
def and_i_click_verify_references
- assessor_application_page.verify_references_task.link.click
+ assessor_application_page.verify_references_task.click
end
def and_the_reference_request_status_is(status)
- expect(reference_request_task_item.status_tag.text).to eq(status)
+ expect(
+ assessor_reference_requests_page.task_list.items.first.status_tag.text,
+ ).to eq(status)
end
def when_i_click_on_the_reference_request
- reference_request_task_item.click
+ assessor_reference_requests_page.task_list.items.first.click
end
def and_i_see_the_reference_summary
@@ -203,14 +205,7 @@ def and_i_submit_an_internal_note
def then_i_see_the_reference_request_status_is_accepted
expect(
- assessor_reference_requests_page
- .task_list
- .sections
- .first
- .items
- .first
- .status_tag
- .text,
+ assessor_reference_requests_page.task_list.items.first.status_tag.text,
).to eq("Completed")
end
@@ -220,21 +215,10 @@ def when_i_verify_that_all_references_are_accepted
def then_i_see_the_verify_references_task_is_completed
expect(
- assessor_reference_requests_page
- .task_list
- .sections
- .first
- .items
- .first
- .status_tag
- .text,
+ assessor_application_page.verify_references_task.status_tag.text,
).to eq("Completed")
end
- def reference_request_task_item
- assessor_reference_requests_page.task_list.sections.first.items.first
- end
-
def application_form
@application_form ||=
begin
diff --git a/spec/system/assessor_interface/view_application_form_spec.rb b/spec/system/assessor_interface/view_application_form_spec.rb
index 68018628a7..f077ed4ede 100644
--- a/spec/system/assessor_interface/view_application_form_spec.rb
+++ b/spec/system/assessor_interface/view_application_form_spec.rb
@@ -31,11 +31,11 @@ def then_i_see_the_application
end
def and_i_see_the_assessment_tasks
- expect(assessor_application_page.task_list.sections.count).to eq(1)
+ expect(assessor_application_page.task_lists.count).to eq(1)
section_links =
- assessor_application_page.task_list.sections.first.items.map do |item|
- item.name.text
+ assessor_application_page.task_lists.first.items.map do |item|
+ item.name_and_hint.text
end
expect(section_links).to eq(
diff --git a/spec/system/assessor_interface/withdraw_application_spec.rb b/spec/system/assessor_interface/withdraw_application_spec.rb
index ffd3d1822c..81445af236 100644
--- a/spec/system/assessor_interface/withdraw_application_spec.rb
+++ b/spec/system/assessor_interface/withdraw_application_spec.rb
@@ -39,11 +39,13 @@ def given_there_is_an_application_form
end
def and_i_see_the_withdraw_link
- expect(assessor_application_page.task_list).to have_content("Withdraw")
+ expect(assessor_application_page.task_lists.last).to have_content(
+ "Withdraw",
+ )
end
def when_i_click_on_withdraw
- assessor_application_page.task_list.click_on("Withdraw")
+ assessor_application_page.task_lists.last.click_on("Withdraw")
end
def when_i_confirm_the_withdrawal
diff --git a/spec/system/teacher_interface/further_information_spec.rb b/spec/system/teacher_interface/further_information_spec.rb
index ebec37c7b2..cd8cc38ebd 100644
--- a/spec/system/teacher_interface/further_information_spec.rb
+++ b/spec/system/teacher_interface/further_information_spec.rb
@@ -101,15 +101,15 @@ def and_i_see_the_completed_work_history_contact_list_item
end
def when_i_click_the_text_task_list_item
- text_task_list_item.link.click
+ text_task_list_item.click
end
def when_i_click_the_work_history_contact_task_list_item
- work_history_task_list_item.link.click
+ work_history_task_list_item.click
end
def when_i_click_the_document_task_list_item
- document_task_list_item.link.click
+ document_task_list_item.click
end
def when_i_fill_in_the_response
diff --git a/spec/system/teacher_interface/qualification_consent_spec.rb b/spec/system/teacher_interface/qualification_consent_spec.rb
index f1e106f43b..a6f87cf8a0 100644
--- a/spec/system/teacher_interface/qualification_consent_spec.rb
+++ b/spec/system/teacher_interface/qualification_consent_spec.rb
@@ -86,21 +86,15 @@ def and_i_see_qualification_consent_sign_out_content
end
def and_i_see_the_download_and_upload_tasks
- task_list = teacher_qualification_requests_page.task_list
- expect(task_list.sections.count).to eq(1)
+ task_lists = teacher_qualification_requests_page.task_lists
+ expect(task_lists.count).to eq(1)
- task_list_section = task_list.sections.first
- expect(task_list_section.items.count).to eq(2)
+ task_list = task_lists.first
+ expect(task_list.items.count).to eq(2)
end
def when_i_click_the_download_task
- teacher_qualification_requests_page
- .task_list
- .sections
- .first
- .items
- .first
- .click
+ teacher_qualification_requests_page.task_lists.first.items.first.click
end
def when_i_check_the_downloaded_checkbox
@@ -109,13 +103,7 @@ def when_i_check_the_downloaded_checkbox
end
def when_i_click_the_upload_task
- teacher_qualification_requests_page
- .task_list
- .sections
- .first
- .items
- .second
- .click
+ teacher_qualification_requests_page.task_lists.first.items.second.click
end
def when_i_upload_a_file
diff --git a/spec/view_objects/teacher_interface/further_information_request_view_object_spec.rb b/spec/view_objects/teacher_interface/further_information_request_view_object_spec.rb
index 9abb7322ff..bce261cf73 100644
--- a/spec/view_objects/teacher_interface/further_information_request_view_object_spec.rb
+++ b/spec/view_objects/teacher_interface/further_information_request_view_object_spec.rb
@@ -26,8 +26,8 @@
}
end
- describe "#task_list_sections" do
- subject(:task_list_sections) { view_object.task_list_sections }
+ describe "#task_list_items" do
+ subject(:task_list_items) { view_object.task_list_items }
let!(:text_item) do
create(
@@ -46,32 +46,34 @@
end
it do
- is_expected.to include_task_list_item(
- "Further information requested",
- "Tell us more about the subjects you can teach",
- link: [
- :edit,
- :teacher_interface,
- :application_form,
- further_information_request,
- text_item,
- ],
- status: :not_started,
+ is_expected.to include(
+ {
+ title: "Tell us more about the subjects you can teach",
+ href: [
+ :edit,
+ :teacher_interface,
+ :application_form,
+ further_information_request,
+ text_item,
+ ],
+ status: :not_started,
+ },
)
end
it do
- is_expected.to include_task_list_item(
- "Further information requested",
- "Upload your identity document",
- link: [
- :edit,
- :teacher_interface,
- :application_form,
- further_information_request,
- document_item,
- ],
- status: :not_started,
+ is_expected.to include(
+ {
+ title: "Upload your identity document",
+ href: [
+ :edit,
+ :teacher_interface,
+ :application_form,
+ further_information_request,
+ document_item,
+ ],
+ status: :not_started,
+ },
)
end
end