Skip to content

Commit

Permalink
feat: add estimated-duration column to frontend detours list
Browse files Browse the repository at this point in the history
  • Loading branch information
firestack committed Jan 15, 2025
1 parent eb4f28a commit 55c6ab2
Show file tree
Hide file tree
Showing 9 changed files with 106 additions and 9 deletions.
8 changes: 8 additions & 0 deletions assets/src/components/detoursTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,9 @@ export const DetoursTable = ({
<th className="px-3 py-4 u-hide-for-mobile">
{timestampLabelFromStatus(status)}
</th>
{status === DetourStatus.Active && (
<th className="px-3 py-4 u-hide-for-mobile">Est. Duration</th>
)}
</tr>
</thead>
<tbody>
Expand Down Expand Up @@ -102,6 +105,11 @@ const PopulatedDetourRows = ({
? timeAgoLabelFromDate(detour.activatedAt, epochNow)
: timeAgoLabel(epochNowInSeconds, detour.updatedAt)}
</td>
{detour.estimatedDuration && (
<td className="align-middle p-3 u-hide-for-mobile">
{detour.estimatedDuration}
</td>
)}
</tr>
))}
</>
Expand Down
3 changes: 3 additions & 0 deletions assets/src/models/detoursList.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ export interface SimpleDetour {
intersection: string
updatedAt: number
activatedAt?: Date
estimatedDuration?: string
}

export const detourId = number()
Expand All @@ -32,6 +33,7 @@ export const SimpleDetourData = type({

export const ActivatedDetourData = type({
activated_at: coerce(date(), string(), (dateStr) => new Date(dateStr)),
estimated_duration: string(),
details: SimpleDetourData,
})

Expand Down Expand Up @@ -68,6 +70,7 @@ export const groupedDetoursFromData = (
active: groupedDetours.active?.map((detour) => ({
...simpleDetourFromData(detour.details),
activatedAt: detour.activated_at,
estimatedDuration: detour.estimated_duration,
})),
draft: groupedDetours.draft?.map((detour) => simpleDetourFromData(detour)),
past: groupedDetours.past?.map((detour) => simpleDetourFromData(detour)),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,11 @@ exports[`DetourListPage renders detour list page for dispatchers 1`] = `
>
On detour since
</th>
<th
class="px-3 py-4 u-hide-for-mobile"
>
Est. Duration
</th>
</tr>
</thead>
<tbody>
Expand Down Expand Up @@ -123,6 +128,11 @@ exports[`DetourListPage renders detour list page for dispatchers 1`] = `
>
26 hours ago
</td>
<td
class="align-middle p-3 u-hide-for-mobile"
>
2 hours
</td>
</tr>
<tr>
<td
Expand Down Expand Up @@ -162,6 +172,11 @@ exports[`DetourListPage renders detour list page for dispatchers 1`] = `
>
29 hours ago
</td>
<td
class="align-middle p-3 u-hide-for-mobile"
>
3 hours
</td>
</tr>
</tbody>
</table>
Expand Down Expand Up @@ -453,6 +468,11 @@ exports[`DetourListPage renders limited detour list page for non-dispatchers 1`]
>
On detour since
</th>
<th
class="px-3 py-4 u-hide-for-mobile"
>
Est. Duration
</th>
</tr>
</thead>
<tbody>
Expand Down Expand Up @@ -494,6 +514,11 @@ exports[`DetourListPage renders limited detour list page for non-dispatchers 1`]
>
26 hours ago
</td>
<td
class="align-middle p-3 u-hide-for-mobile"
>
4 hours
</td>
</tr>
<tr>
<td
Expand Down Expand Up @@ -533,6 +558,11 @@ exports[`DetourListPage renders limited detour list page for non-dispatchers 1`]
>
29 hours ago
</td>
<td
class="align-middle p-3 u-hide-for-mobile"
>
Until end of service
</td>
</tr>
</tbody>
</table>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,11 @@ exports[`Detours Page: Open a Detour renders detour details in an open drawer on
>
On detour since
</th>
<th
class="px-3 py-4 u-hide-for-mobile"
>
Est. Duration
</th>
</tr>
</thead>
<tbody>
Expand Down Expand Up @@ -126,6 +131,11 @@ exports[`Detours Page: Open a Detour renders detour details in an open drawer on
>
Just now
</td>
<td
class="align-middle p-3 u-hide-for-mobile"
>
2 hours
</td>
</tr>
<tr>
<td
Expand Down Expand Up @@ -165,6 +175,11 @@ exports[`Detours Page: Open a Detour renders detour details in an open drawer on
>
Just now
</td>
<td
class="align-middle p-3 u-hide-for-mobile"
>
2 hours
</td>
</tr>
</tbody>
</table>
Expand Down Expand Up @@ -932,6 +947,11 @@ exports[`Detours Page: Open a Detour renders detour details modal to match mocke
>
On detour since
</th>
<th
class="px-3 py-4 u-hide-for-mobile"
>
Est. Duration
</th>
</tr>
</thead>
<tbody>
Expand Down Expand Up @@ -973,6 +993,11 @@ exports[`Detours Page: Open a Detour renders detour details modal to match mocke
>
Just now
</td>
<td
class="align-middle p-3 u-hide-for-mobile"
>
2 hours
</td>
</tr>
<tr>
<td
Expand Down Expand Up @@ -1012,6 +1037,11 @@ exports[`Detours Page: Open a Detour renders detour details modal to match mocke
>
Just now
</td>
<td
class="align-middle p-3 u-hide-for-mobile"
>
2 hours
</td>
</tr>
</tbody>
</table>
Expand Down
4 changes: 4 additions & 0 deletions assets/tests/components/detours/detourListPage.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ describe("DetourListPage", () => {
intersection: "Street A & Avenue B",
updatedAt: 1724866392,
activatedAt: new Date(1724866392000),
estimatedDuration: "2 hours",
},
{
id: 8,
Expand All @@ -51,6 +52,7 @@ describe("DetourListPage", () => {
intersection: "Street C & Avenue D",
updatedAt: 1724856392,
activatedAt: new Date(1724856392000),
estimatedDuration: "3 hours",
},
],
draft: undefined,
Expand Down Expand Up @@ -102,6 +104,7 @@ describe("DetourListPage", () => {
intersection: "Street A & Avenue B",
updatedAt: 1724866392,
activatedAt: new Date(1724866392000),
estimatedDuration: "4 hours",
},
{
id: 8,
Expand All @@ -111,6 +114,7 @@ describe("DetourListPage", () => {
intersection: "Street C & Avenue D",
updatedAt: 1724856392,
activatedAt: new Date(1724856392000),
estimatedDuration: "Until end of service",
},
],
draft: undefined,
Expand Down
1 change: 1 addition & 0 deletions assets/tests/factories/detourListFactory.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,4 +26,5 @@ const simpleDetourFactory = Factory.define<SimpleDetour>(({ sequence }) => ({

const activeDetourFactory = simpleDetourFactory.params({
activatedAt: new Date(),
estimatedDuration: "2 hours",
})
2 changes: 2 additions & 0 deletions lib/skate/detours/detour.ex
Original file line number Diff line number Diff line change
Expand Up @@ -74,13 +74,15 @@ defmodule Skate.Detours.Detour do

@type t :: %__MODULE__{
activated_at: DateTime.t(),
estimated_duration: String.t(),
details: Detailed.t()
}

@derive Jason.Encoder

defstruct [
:activated_at,
:estimated_duration,
:details
]
end
Expand Down
6 changes: 5 additions & 1 deletion lib/skate/detours/detours.ex
Original file line number Diff line number Diff line change
Expand Up @@ -72,13 +72,17 @@ defmodule Skate.Detours.Detours do

def db_detour_to_detour(
:active,
%Detour{activated_at: activated_at} = db_detour
%Detour{
activated_at: activated_at,
state: %{"context" => %{"selectedDuration" => estimated_duration}}
} = db_detour
) do
details = DetailedDetour.from(:active, db_detour)

details &&
%ActivatedDetourDetails{
activated_at: activated_at,
estimated_duration: estimated_duration,
details: details
}
end
Expand Down
31 changes: 23 additions & 8 deletions test/support/factories/detour_factory.ex
Original file line number Diff line number Diff line change
Expand Up @@ -61,22 +61,37 @@ defmodule Skate.DetourFactory do
with_id(detour, id)
end

def activated(update_arg, activated_at \\ DateTime.utc_now())
def activated(
update_arg,
activated_at \\ DateTime.utc_now(),
estimated_duration \\ "1 hour"
)

def activated(%Skate.Detours.Db.Detour{} = detour, activated_at) do
def activated(%Skate.Detours.Db.Detour{} = detour, activated_at, estimated_duration) do
activated_at = Skate.DetourFactory.browser_date(activated_at)
%{detour | state: activated(detour.state, activated_at), activated_at: activated_at}

%{
detour
| state: activated(detour.state, activated_at, estimated_duration),
activated_at: activated_at
}
end

def activated(%{"value" => %{}, "context" => %{}} = state, activated_at) do
def activated(%{"value" => %{}, "context" => %{}} = state, activated_at, estimated_duration) do
state =
put_in(state["value"], %{"Detour Drawing" => %{"Active" => "Reviewing"}})

state =
put_in(
state["context"]["activatedAt"],
activated_at
|> Skate.DetourFactory.browser_date()
|> DateTime.to_iso8601()
)

put_in(
state["context"]["activatedAt"],
activated_at
|> Skate.DetourFactory.browser_date()
|> DateTime.to_iso8601()
state["context"]["selectedDuration"],
estimated_duration
)
end

Expand Down

0 comments on commit 55c6ab2

Please sign in to comment.