Skip to content

Commit

Permalink
feat: osi list shows officials' name with email as fallback (#137)
Browse files Browse the repository at this point in the history
  • Loading branch information
mathcolo authored Sep 17, 2024
1 parent 1b485bf commit c21aa79
Show file tree
Hide file tree
Showing 6 changed files with 66 additions and 12 deletions.
2 changes: 1 addition & 1 deletion js/components/operatorSignIn/list.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ export const List = ({ line }: { line: HeavyRailLine }): ReactElement => {
.replace(/ /g, "")}
</td>
<td className="fs-mask border-y md:border-x p-1 break-words [hyphenate-character:'']">
{si.signed_in_by_user.replace(
{si.signed_in_by.replace(
/@/g,
// 173 is a soft hyphen, which here acts as a breaking suggestion
// We are hiding the hyphen above with CSS
Expand Down
2 changes: 1 addition & 1 deletion js/models/signin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { z } from "zod";
export const SignIn = z.object({
rail_line: z.enum(["blue", "orange", "red"]),
signed_in_at: z.string(),
signed_in_by_user: z.string(),
signed_in_by: z.string(),
signed_in_employee: z.string(),
});

Expand Down
2 changes: 1 addition & 1 deletion js/test/components/operatorSignIn/list.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ jest.mock("../../../hooks/useSignIns", () => ({
signed_in_at: DateTime.fromISO("2024-07-22T12:45:52.000-04:00", {
zone: "America/New_York",
}),
signed_in_by_user: "user@example.com",
signed_in_by: "user@example.com",
signed_in_employee: EMPLOYEES[0].badge,
},
],
Expand Down
2 changes: 1 addition & 1 deletion js/test/hooks/useSignins.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ const TEST_DATA = {
{
rail_line: "blue",
signed_in_at: "2024-07-22T16:42:32Z",
signed_in_by_user: "user@example.com",
signed_in_by: "user@example.com",
signed_in_employee: "123",
},
],
Expand Down
27 changes: 20 additions & 7 deletions lib/orbit_web/controllers/sign_in_controller.ex
Original file line number Diff line number Diff line change
Expand Up @@ -31,16 +31,29 @@ defmodule OrbitWeb.SignInController do
^start_datetime <= si.signed_in_at and
si.signed_in_at < ^end_datetime and
si.rail_line == ^rail_line,
preload: [:signed_in_employee, :signed_in_by_user],
order_by: [desc: :signed_in_at]
join: e in assoc(si, :signed_in_employee),
join: u in assoc(si, :signed_in_by_user),
preload: [signed_in_employee: e, signed_in_by_user: u],
left_join: signed_in_by_employee in Employee,
on: u.email == signed_in_by_employee.email,
order_by: [desc: :signed_in_at],
select: %{
signin: si,
signed_in_by_employee: signed_in_by_employee
}
)
)
|> Enum.map(fn si ->
|> Enum.map(fn i ->
%{
rail_line: si.rail_line,
signed_in_at: DateTime.to_iso8601(si.signed_in_at),
signed_in_by_user: si.signed_in_by_user.email,
signed_in_employee: si.signed_in_employee.badge_number
rail_line: i.signin.rail_line,
signed_in_at: DateTime.to_iso8601(i.signin.signed_in_at),
signed_in_by:
if i.signed_in_by_employee do
Employee.display_name(i.signed_in_by_employee)
else
i.signin.signed_in_by_user.email
end,
signed_in_employee: i.signin.signed_in_employee.badge_number
}
end)
}
Expand Down
43 changes: 42 additions & 1 deletion test/orbit_web/controllers/sign_in_controller_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ defmodule OrbitWeb.SignInControllerTest do
%{
"rail_line" => "blue",
"signed_in_at" => _date,
"signed_in_by_user" => _user,
"signed_in_by" => _user,
"signed_in_employee" => _badge
}
]
Expand Down Expand Up @@ -64,6 +64,47 @@ defmodule OrbitWeb.SignInControllerTest do
} = json_response(conn, 200)
end

@tag :authenticated
test "shows officials' names if available", %{conn: conn} do
insert(:employee, email: "test@example.com")

insert(:operator_sign_in,
signed_in_at: DateTime.new!(~D[2024-07-21], ~T[12:00:00], @timezone),
signed_in_by_user: build(:user, email: "test@example.com")
)

conn = get(conn, ~p"/api/signin", %{"line" => "blue", "service_date" => "2024-07-21"})

assert %{
"data" => [
%{
"signed_in_by" => "Preferredy Person"
}
]
} = json_response(conn, 200)
end

@tag :authenticated
test "shows official's email address if name is unavailable", %{conn: conn} do
insert(:operator_sign_in,
signed_in_at: DateTime.new!(~D[2024-07-21], ~T[12:00:00], @timezone),
signed_in_by_user:
build(:user, %{
email: "does_not_exist_im_fairly_certain@example.com"
})
)

conn = get(conn, ~p"/api/signin", %{"line" => "blue", "service_date" => "2024-07-21"})

assert %{
"data" => [
%{
"signed_in_by" => "does_not_exist_im_fairly_certain@example.com"
}
]
} = json_response(conn, 200)
end

@tag :authenticated
test "sorted by signed_in_at descending (recent first)", %{conn: conn} do
insert(:operator_sign_in,
Expand Down

0 comments on commit c21aa79

Please sign in to comment.