From 69aa5c13053c8921f727dd66fd1145de99f662dd Mon Sep 17 00:00:00 2001 From: Lukas Date: Wed, 30 Oct 2024 10:44:23 +0100 Subject: [PATCH 1/2] feat(ceremony): update time format --- ceremony/src/lib/utils/utils.ts | 34 +++++++++++++++++++++++++++------ 1 file changed, 28 insertions(+), 6 deletions(-) diff --git a/ceremony/src/lib/utils/utils.ts b/ceremony/src/lib/utils/utils.ts index 1982d286fc..424b6be2b6 100644 --- a/ceremony/src/lib/utils/utils.ts +++ b/ceremony/src/lib/utils/utils.ts @@ -94,16 +94,38 @@ export function msToTimeString(ms: number): string { } export function formatWaitTime(minutes: number) { - const hours = Math.floor(minutes / 60) + const weeks = Math.floor(minutes / (7 * 24 * 60)) + const days = Math.floor((minutes % (7 * 24 * 60)) / (24 * 60)) + const hours = Math.floor((minutes % (24 * 60)) / 60) const remainingMinutes = Math.round(minutes % 60) - if (hours === 0) { - return `${remainingMinutes} minute${remainingMinutes !== 1 ? "s" : ""}` + const parts = [] + + if (weeks > 0) { + parts.push(`${weeks} week${weeks !== 1 ? "s" : ""}`) + } + + if (days > 0) { + parts.push(`${days} day${days !== 1 ? "s" : ""}`) + } + + if (hours > 0 && weeks === 0) { + // Only show hours if less than a week + parts.push(`${hours} hour${hours !== 1 ? "s" : ""}`) + } + + if (remainingMinutes > 0 && weeks === 0 && days === 0) { + // Only show minutes if less than a day + parts.push(`${remainingMinutes} minute${remainingMinutes !== 1 ? "s" : ""}`) + } + + if (parts.length === 0) { + return "0 minutes" } - if (remainingMinutes === 0) { - return `${hours} hour${hours !== 1 ? "s" : ""}` + if (parts.length === 1) { + return parts[0] } - return `${hours} hour${hours !== 1 ? "s" : ""} and ${remainingMinutes} minute${remainingMinutes !== 1 ? "s" : ""}` + return `${parts.slice(0, -1).join(", ")} and ${parts[parts.length - 1]}` } From b8ef7642aa4421b133e687b985b9f581f293287d Mon Sep 17 00:00:00 2001 From: Lukas Date: Wed, 30 Oct 2024 10:56:58 +0100 Subject: [PATCH 2/2] chore(ceremony): lint --- ceremony/src/lib/utils/utils.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ceremony/src/lib/utils/utils.ts b/ceremony/src/lib/utils/utils.ts index 424b6be2b6..d07b855fa1 100644 --- a/ceremony/src/lib/utils/utils.ts +++ b/ceremony/src/lib/utils/utils.ts @@ -99,7 +99,7 @@ export function formatWaitTime(minutes: number) { const hours = Math.floor((minutes % (24 * 60)) / 60) const remainingMinutes = Math.round(minutes % 60) - const parts = [] + const parts: Array = [] if (weeks > 0) { parts.push(`${weeks} week${weeks !== 1 ? "s" : ""}`)