Manny Dinssa
4 weeks ago
7 changed files with 115 additions and 108 deletions
@ -0,0 +1,85 @@ |
|||||||
|
module CollectionDeadlineHelper |
||||||
|
include CollectionTimeHelper |
||||||
|
|
||||||
|
QUARTERLY_DEADLINES = { |
||||||
|
2024 => { |
||||||
|
first_quarter_deadline: Time.zone.local(2024, 7, 12), |
||||||
|
second_quarter_deadline: Time.zone.local(2024, 10, 11), |
||||||
|
third_quarter_deadline: Time.zone.local(2025, 1, 10), |
||||||
|
fourth_quarter_deadline: Time.zone.local(2025, 6, 6), # Same as submission deadline |
||||||
|
}, |
||||||
|
2025 => { |
||||||
|
first_quarter_deadline: Time.zone.local(2025, 7, 11), |
||||||
|
second_quarter_deadline: Time.zone.local(2025, 10, 10), |
||||||
|
third_quarter_deadline: Time.zone.local(2026, 1, 16), |
||||||
|
fourth_quarter_deadline: Time.zone.local(2026, 6, 5), # Same as submission deadline |
||||||
|
}, |
||||||
|
}.freeze |
||||||
|
|
||||||
|
def quarterly_cutoff_date(quarter, year) |
||||||
|
send("#{quarter}_quarter", year)[:cutoff_date].strftime("%A %-d %B %Y") |
||||||
|
end |
||||||
|
|
||||||
|
def formatted_deadline |
||||||
|
quarterly_cutoff_date("fourth", current_collection_start_year) |
||||||
|
end |
||||||
|
|
||||||
|
def quarter_deadlines_for_year(year) |
||||||
|
QUARTERLY_DEADLINES[year] |
||||||
|
end |
||||||
|
|
||||||
|
def first_quarter(year) |
||||||
|
{ |
||||||
|
cutoff_date: quarter_deadlines_for_year(year)[:first_quarter_deadline], |
||||||
|
start_date: Time.zone.local(year, 4, 1), |
||||||
|
end_date: Time.zone.local(year, 6, 30), |
||||||
|
} |
||||||
|
end |
||||||
|
|
||||||
|
def second_quarter(year) |
||||||
|
{ |
||||||
|
cutoff_date: quarter_deadlines_for_year(year)[:second_quarter_deadline], |
||||||
|
start_date: Time.zone.local(year, 7, 1), |
||||||
|
end_date: Time.zone.local(year, 9, 30), |
||||||
|
} |
||||||
|
end |
||||||
|
|
||||||
|
def third_quarter(year) |
||||||
|
{ |
||||||
|
cutoff_date: quarter_deadlines_for_year(year)[:third_quarter_deadline], |
||||||
|
start_date: Time.zone.local(year, 10, 1), |
||||||
|
end_date: Time.zone.local(year, 12, 31), |
||||||
|
} |
||||||
|
end |
||||||
|
|
||||||
|
def fourth_quarter(year) |
||||||
|
{ |
||||||
|
cutoff_date: quarter_deadlines_for_year(year)[:fourth_quarter_deadline], |
||||||
|
start_date: Time.zone.local(year + 1, 1, 1), |
||||||
|
end_date: Time.zone.local(year + 1, 3, 31), |
||||||
|
} |
||||||
|
end |
||||||
|
|
||||||
|
def quarter_dates(year) |
||||||
|
[ |
||||||
|
first_quarter(year).merge(quarter: "Q1"), |
||||||
|
second_quarter(year).merge(quarter: "Q2"), |
||||||
|
third_quarter(year).merge(quarter: "Q3"), |
||||||
|
] |
||||||
|
end |
||||||
|
|
||||||
|
def quarter_for_date(date: Time.zone.now) |
||||||
|
quarters = quarter_dates(current_collection_start_year) |
||||||
|
|
||||||
|
quarter = quarters.find { |q| date.between?(q[:start_date], q[:cutoff_date] + 1.day) } |
||||||
|
|
||||||
|
return unless quarter |
||||||
|
|
||||||
|
OpenStruct.new( |
||||||
|
quarter: quarter[:quarter], |
||||||
|
cutoff_date: quarter[:cutoff_date], |
||||||
|
quarter_start_date: quarter[:start_date], |
||||||
|
quarter_end_date: quarter[:end_date], |
||||||
|
) |
||||||
|
end |
||||||
|
end |
@ -1,9 +0,0 @@ |
|||||||
module HomeHelper |
|
||||||
def quarterly_cutoff_date(quarter, year) |
|
||||||
send("#{quarter}_quarter", year)[:cutoff_date].strftime("%A %-d %B %Y") |
|
||||||
end |
|
||||||
|
|
||||||
def formatted_deadline |
|
||||||
quarterly_cutoff_date("fourth", current_collection_start_year) |
|
||||||
end |
|
||||||
end |
|
@ -0,0 +1,29 @@ |
|||||||
|
require "rails_helper" |
||||||
|
|
||||||
|
RSpec.describe CollectionDeadlineHelper do |
||||||
|
let(:current_user) { create(:user, :data_coordinator) } |
||||||
|
let(:user) { create(:user, :data_coordinator) } |
||||||
|
|
||||||
|
describe "#quarter_for_date" do |
||||||
|
it "returns correct cutoff date for the first quarter of 2024/25" do |
||||||
|
quarter = quarter_for_date(date: Time.zone.local(2024, 4, 1)) |
||||||
|
expect(quarter.cutoff_date).to eq(Time.zone.local(2024, 7, 12)) |
||||||
|
expect(quarter.quarter_start_date).to eq(Time.zone.local(2024, 4, 1)) |
||||||
|
expect(quarter.quarter_end_date).to eq(Time.zone.local(2024, 6, 30)) |
||||||
|
end |
||||||
|
|
||||||
|
it "returns correct cutoff date for the second quarter of 2024/25" do |
||||||
|
quarter = quarter_for_date(date: Time.zone.local(2024, 9, 30)) |
||||||
|
expect(quarter.cutoff_date).to eq(Time.zone.local(2024, 10, 11)) |
||||||
|
expect(quarter.quarter_start_date).to eq(Time.zone.local(2024, 7, 1)) |
||||||
|
expect(quarter.quarter_end_date).to eq(Time.zone.local(2024, 9, 30)) |
||||||
|
end |
||||||
|
|
||||||
|
it "returns correct cutoff date for the third quarter of 2024/25" do |
||||||
|
quarter = quarter_for_date(date: Time.zone.local(2024, 10, 25)) |
||||||
|
expect(quarter.cutoff_date).to eq(Time.zone.local(2025, 1, 10)) |
||||||
|
expect(quarter.quarter_start_date).to eq(Time.zone.local(2024, 10, 1)) |
||||||
|
expect(quarter.quarter_end_date).to eq(Time.zone.local(2024, 12, 31)) |
||||||
|
end |
||||||
|
end |
||||||
|
end |
Loading…
Reference in new issue