Skip to content

Commit

Permalink
feat(cms): update case stats with new stages
Browse files Browse the repository at this point in the history
Jira: PWNN-1528
  • Loading branch information
EdwinKruglov committed Sep 6, 2023
1 parent 11d3871 commit 4dc0fee
Show file tree
Hide file tree
Showing 11 changed files with 207 additions and 96 deletions.
1 change: 1 addition & 0 deletions app/controllers/support/concerns/filter_parameters.rb
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ def permitted_params
:agent,
:state,
:tower,
:procurement_stage,
:level,
:sort_by,
:sort_order,
Expand Down
4 changes: 0 additions & 4 deletions app/helpers/support/filter_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -36,10 +36,6 @@ def available_agents
)
end

def available_stages
I18nOption.from("support.case_statistics.stages.%%key%%", Support::TowerCase.stages.keys)
end

def available_procurement_stages
CheckboxOption
.from(
Expand Down
2 changes: 1 addition & 1 deletion app/models/support/tower_case.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@ module Support
class TowerCase < ApplicationRecord
UNSPECIFIED_VALUE = 99
enum state: Case.states, _prefix: :state
enum stage: Procurement.stages.merge(unspecified: UNSPECIFIED_VALUE), _prefix: :stage
enum support_level: Case.support_levels.merge(unspecified: UNSPECIFIED_VALUE), _prefix: :support_level
belongs_to :support_tower, class_name: "Support::Tower", foreign_key: :tower_id
belongs_to :procurement_stage, class_name: "Support::ProcurementStage"
end
end
53 changes: 35 additions & 18 deletions app/models/support/tower_statistics.rb
Original file line number Diff line number Diff line change
Expand Up @@ -15,32 +15,49 @@ def open_cases = @tower_overview.open_cases
def on_hold_cases = @tower_overview.on_hold_cases
def new_cases = @tower_overview.new_cases
def missing_level_cases = TowerCase.where(tower_slug:, support_level: TowerCase::UNSPECIFIED_VALUE).count
def missing_stage_cases = TowerCase.where(tower_slug:, procurement_stage: TowerCase::UNSPECIFIED_VALUE).count
def missing_stage_cases = TowerCase.where(tower_slug:, procurement_stage_id: nil).count
def missing_value_cases = TowerCase.where(tower_slug:, value: nil).count
def missing_org_cases = TowerCase.where(tower_slug:, organisation_id: nil).count

def breakdown_of_cases_by_stage
sql = <<-SQL
SELECT
procurement_stage.stage,
SUM(CASE WHEN support_tower_cases.state = 1 THEN 1 ELSE 0 END) AS open_cases,
SUM(CASE WHEN support_tower_cases.state = 3 THEN 1 ELSE 0 END) AS on_hold_cases,
SUM(CASE WHEN support_tower_cases.state = 0 THEN 1 ELSE 0 END) AS new_cases,
SUM(COALESCE(support_tower_cases.value, 0.0)) AS live_value,
'' AS id
SELECT sub.procurement_stage_id, sub.procurement_stage_title, sub.open_cases, sub.on_hold_cases, sub.new_cases, sub.live_value, sub.id
FROM (
SELECT * FROM GENERATE_SERIES(0, 6) AS stage
UNION SELECT :unspecified AS stage
ORDER BY stage
) procurement_stage
LEFT JOIN support_tower_cases
ON support_tower_cases.procurement_stage = procurement_stage.stage
AND support_tower_cases.tower_slug = :tower_slug
GROUP BY procurement_stage.stage
ORDER BY procurement_stage.stage
SELECT
sps.id::text AS procurement_stage_id,
sps.title AS procurement_stage_title,
sps.stage AS procurement_stage_stage,
sps.updated_at AS procurement_stage_updated_at,
SUM(CASE WHEN stc.state = 1 THEN 1 ELSE 0 END) AS open_cases,
SUM(CASE WHEN stc.state = 3 THEN 1 ELSE 0 END) AS on_hold_cases,
SUM(CASE WHEN stc.state = 0 THEN 1 ELSE 0 END) AS new_cases,
SUM(COALESCE(stc.value, 0.0)) AS live_value,
'' AS id
FROM support_tower_cases stc
RIGHT JOIN support_procurement_stages sps
ON stc.procurement_stage_id = sps.id::text
AND stc.tower_slug = :tower_slug
GROUP BY sps.id
UNION
SELECT
'unspecified' AS procurement_stage_id,
'Unspecified' AS procurement_stage_title,
NULL AS procurement_stage_stage,
NULL AS procurement_stage_updated_at,
SUM(CASE WHEN stc.state = 1 THEN 1 ELSE 0 END) AS open_cases,
SUM(CASE WHEN stc.state = 3 THEN 1 ELSE 0 END) AS on_hold_cases,
SUM(CASE WHEN stc.state = 0 THEN 1 ELSE 0 END) AS new_cases,
SUM(COALESCE(stc.value, 0.0)) AS live_value,
'' AS id
FROM support_tower_cases stc
WHERE stc.procurement_stage_id IS NULL AND stc.tower_slug = :tower_slug
) AS sub
ORDER BY sub.procurement_stage_stage, sub.procurement_stage_updated_at
SQL

TowerCase.find_by_sql([sql, { tower_slug:, unspecified: TowerCase::UNSPECIFIED_VALUE }])
TowerCase.find_by_sql([sql, { tower_slug: }])
end

def breakdown_of_cases_by_level
Expand Down
10 changes: 5 additions & 5 deletions app/views/support/case_statistics/towers/show.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -77,10 +77,10 @@
<tbody class="govuk-table__body">
<% @tower_statistics.breakdown_of_cases_by_stage.each do |stage| %>
<tr class="govuk-table__row">
<th scope="row" class="govuk-table__header"><%= link_to I18n.t("support.case_statistics.stages.#{stage.stage}"), filtered_tower_path(@tower, stage: stage.stage, state: "live"), class: "govuk-link govuk-link--no-visited-state" %></th>
<td class="govuk-table__cell result-value"><%= link_to stage.open_cases, filtered_tower_path(@tower, stage: stage.stage, state: "opened"), class: "govuk-link govuk-link--no-visited-state" %></td>
<td class="govuk-table__cell result-value"><%= link_to stage.on_hold_cases, filtered_tower_path(@tower, stage: stage.stage, state: "on_hold"), class: "govuk-link govuk-link--no-visited-state" %></td>
<td class="govuk-table__cell result-value"><%= link_to stage.new_cases, filtered_tower_path(@tower, stage: stage.stage, state: "initial"), class: "govuk-link govuk-link--no-visited-state" %></td>
<th scope="row" class="govuk-table__header"><%= link_to stage.procurement_stage_title, filtered_tower_path(@tower, procurement_stage: stage.procurement_stage_id, state: "live"), class: "govuk-link govuk-link--no-visited-state" %></th>
<td class="govuk-table__cell result-value"><%= link_to stage.open_cases, filtered_tower_path(@tower, procurement_stage: stage.procurement_stage_id, state: "opened"), class: "govuk-link govuk-link--no-visited-state" %></td>
<td class="govuk-table__cell result-value"><%= link_to stage.on_hold_cases, filtered_tower_path(@tower, procurement_stage: stage.procurement_stage_id, state: "on_hold"), class: "govuk-link govuk-link--no-visited-state" %></td>
<td class="govuk-table__cell result-value"><%= link_to stage.new_cases, filtered_tower_path(@tower, procurement_stage: stage.procurement_stage_id, state: "initial"), class: "govuk-link govuk-link--no-visited-state" %></td>
<%
=begin%>
# TODO: uncomment when ready to do case value work
Expand Down Expand Up @@ -137,6 +137,6 @@
<p><%= link_to I18n.t("support.case_statistics.missing_data.no_value", count: @tower_statistics.missing_value_cases), "#", class: "govuk-link govuk-link--no-visited-state" %></p>
<%
=end%>
<p><%= link_to I18n.t("support.case_statistics.missing_data.no_stage", count: @tower_statistics.missing_stage_cases).html_safe, filtered_tower_path(@tower, stage: :unspecified, state: "live"), class: "govuk-link govuk-link--no-visited-state" %></p>
<p><%= link_to I18n.t("support.case_statistics.missing_data.no_stage", count: @tower_statistics.missing_stage_cases).html_safe, filtered_tower_path(@tower, procurement_stage: :unspecified, state: "live"), class: "govuk-link govuk-link--no-visited-state" %></p>
<p><%= link_to I18n.t("support.case_statistics.missing_data.no_level", count: @tower_statistics.missing_level_cases).html_safe, filtered_tower_path(@tower, level: :unspecified, state: "live"), class: "govuk-link govuk-link--no-visited-state" %></p>
<p><%= link_to I18n.t("support.case_statistics.missing_data.no_org", count: @tower_statistics.missing_org_cases).html_safe, filtered_tower_path(@tower, has_org: :false, state: "live"), class: "govuk-link govuk-link--no-visited-state" %></p>
10 changes: 5 additions & 5 deletions app/views/support/cases/case_list/_filters.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@

<% unless tab == "new-cases" %>
<%= expander title: I18n.t("support.case.label.status"),
subtitle: I18n.t("support.case.filter.labels.selected", count: form.object.state.length),
subtitle: I18n.t("support.case.filter.labels.selected", count: Array(form.object.state).length),
expanded: true do %>
<%= form.govuk_check_boxes_fieldset :state, legend: nil, small: true, form_group: { class: "govuk-!-margin-bottom-0" } do %>
<% available_states.each do |state| %>
Expand All @@ -28,7 +28,7 @@
<% end %>

<%= expander title: I18n.t("support.case.label.sub_category"),
subtitle: I18n.t("support.case.filter.labels.selected", count: form.object.category&.length),
subtitle: I18n.t("support.case.filter.labels.selected", count: Array(form.object.category).length),
expanded: true do %>
<%= form.govuk_check_boxes_fieldset :category, legend: nil, small: true, form_group: { class: "govuk-!-margin-bottom-0" } do %>
<% available_categories(form.object.tower).each do |category| %>
Expand All @@ -39,7 +39,7 @@

<% unless tab == "my-cases" %>
<%= expander title: I18n.t("support.case.label.assignee"),
subtitle: I18n.t("support.case.filter.labels.selected", count: form.object.agent&.length),
subtitle: I18n.t("support.case.filter.labels.selected", count: Array(form.object.agent).length),
expanded: true do %>
<%= form.govuk_check_boxes_fieldset :agent, legend: nil, small: true, form_group: { class: "govuk-!-margin-bottom-0" } do %>
<% available_agents.each do |agent| %>
Expand All @@ -50,7 +50,7 @@
<% end %>

<%= expander title: I18n.t("support.case.label.stage"),
subtitle: I18n.t("support.case.filter.labels.selected", count: form.object.procurement_stage&.length),
subtitle: I18n.t("support.case.filter.labels.selected", count: Array(form.object.procurement_stage).length),
expanded: true do %>
<%= form.govuk_check_boxes_fieldset :procurement_stage, legend: nil, small: true, form_group: { class: "govuk-!-margin-bottom-0" } do %>
<% available_procurement_stages.each do |stage| %>
Expand All @@ -60,7 +60,7 @@
<% end %>

<%= expander title: I18n.t("support.case.label.level"),
subtitle: I18n.t("support.case.filter.labels.selected", count: form.object.level&.length),
subtitle: I18n.t("support.case.filter.labels.selected", count: Array(form.object.level).length),
expanded: true do %>
<%= form.govuk_check_boxes_fieldset :level, legend: nil, small: true, form_group: { class: "govuk-!-margin-bottom-0" } do %>
<% available_levels.each do |level| %>
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
class UpdateSupportTowerCasesToVersion4 < ActiveRecord::Migration[7.0]
def change
update_view :support_tower_cases, version: 4, revert_to_version: 3
end
end
7 changes: 3 additions & 4 deletions db/schema.rb
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.

ActiveRecord::Schema[7.0].define(version: 2023_08_25_101049) do
ActiveRecord::Schema[7.0].define(version: 2023_08_30_101649) do
# These are extensions that must be enabled in order to support this database
enable_extension "citext"
enable_extension "pg_trgm"
Expand Down Expand Up @@ -995,15 +995,14 @@
sc.value,
sc.procurement_id,
sc.organisation_id,
COALESCE(sp.stage, 99) AS procurement_stage,
(sc.procurement_stage_id)::text AS procurement_stage_id,
COALESCE(sc.support_level, 99) AS support_level,
COALESCE(tow.title, 'No Tower'::character varying) AS tower_name,
lower(replace((COALESCE(tow.title, 'No Tower'::character varying))::text, ' '::text, '-'::text)) AS tower_slug,
tow.id AS tower_id,
sc.created_at,
sc.updated_at
FROM (((support_cases sc
JOIN support_procurements sp ON ((sp.id = sc.procurement_id)))
FROM ((support_cases sc
LEFT JOIN support_categories cat ON ((sc.category_id = cat.id)))
LEFT JOIN support_towers tow ON ((cat.support_tower_id = tow.id)))
WHERE (sc.state = ANY (ARRAY[0, 1, 3]));
Expand Down
16 changes: 16 additions & 0 deletions db/views/support_tower_cases_v04.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
SELECT sc.id,
sc.state,
sc.value,
sc.procurement_id,
sc.organisation_id,
sc.procurement_stage_id::text AS procurement_stage_id,
COALESCE(sc.support_level, 99) AS support_level,
COALESCE(tow.title, 'No Tower') AS tower_name,
LOWER(REPLACE(COALESCE(tow.title, 'No Tower'), ' ', '-')) AS tower_slug,
tow.id AS tower_id,
sc.created_at,
sc.updated_at
FROM support_cases sc
LEFT JOIN support_categories AS cat ON sc.category_id = cat.id
LEFT JOIN support_towers AS tow ON cat.support_tower_id = tow.id
WHERE sc.state IN (0, 1, 3) -- new, opened, on-hold
7 changes: 4 additions & 3 deletions spec/features/support/towers_spec.rb
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
RSpec.feature "Case statistics tower page" do
let(:services_tower) { create(:support_tower, title: "Services") }
let(:category) { create(:support_category, title: "Books", tower: services_tower) }
let(:need_stage) { create(:support_procurement_stage, title: "Need") }

before do
create(:support_case, :initial, category:)
create(:support_case, :opened, category:)
create(:support_case, :initial, category:, procurement_stage: need_stage)
create(:support_case, :opened, category:, procurement_stage: need_stage)
create(:support_case, :resolved, category:)
create(:support_case, :closed, category:)
create(:support_case, :on_hold, category:)
create(:support_case, :on_hold, category:, procurement_stage: need_stage)
create(:support_case, :initial, category: nil) # no tower
end

Expand Down
Loading

0 comments on commit 4dc0fee

Please sign in to comment.