-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Expand file tree
/
Copy pathroute.tsx
More file actions
70 lines (63 loc) · 2.23 KB
/
route.tsx
File metadata and controls
70 lines (63 loc) · 2.23 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
import { type MetaFunction } from "@remix-run/react";
import type { LoaderFunctionArgs } from "@remix-run/server-runtime";
import { typedjson, useTypedLoaderData } from "remix-typedjson";
import {
MainHorizontallyCenteredContainer,
PageBody,
PageContainer,
} from "~/components/layout/AppLayout";
import { Header2 } from "~/components/primitives/Headers";
import { NavBar, PageTitle } from "~/components/primitives/PageHeader";
import { requireUser } from "~/services/session.server";
import {
getAllowedSessionOptions,
getEffectiveSessionDuration,
} from "~/services/sessionDuration.server";
import { MfaSetup } from "../resources.account.mfa.setup/route";
import { SessionDurationSetting } from "../resources.account.session-duration/SessionDurationSetting";
export const meta: MetaFunction = () => {
return [
{
title: `Security | Trigger.dev`,
},
];
};
export async function loader({ request }: LoaderFunctionArgs) {
const user = await requireUser(request);
const { durationSeconds, orgCapSeconds } = await getEffectiveSessionDuration(user.id);
const sessionDurationOptions = getAllowedSessionOptions(orgCapSeconds, durationSeconds);
return typedjson({
user,
sessionDuration: durationSeconds,
sessionDurationOptions,
orgCapSeconds,
});
}
export default function Page() {
const { user, sessionDuration, sessionDurationOptions, orgCapSeconds } =
useTypedLoaderData<typeof loader>();
return (
<PageContainer>
<NavBar>
<PageTitle title="Security" />
</NavBar>
<PageBody>
<MainHorizontallyCenteredContainer className="max-w-[37.5rem] overflow-visible">
<div className="w-full border-b border-grid-dimmed pb-3">
<Header2>Security</Header2>
</div>
<div className="w-full border-b border-grid-dimmed py-4">
<MfaSetup isEnabled={!!user.mfaEnabledAt} />
</div>
<div className="w-full border-b border-grid-dimmed py-4">
<SessionDurationSetting
currentValue={sessionDuration}
options={sessionDurationOptions}
orgCapSeconds={orgCapSeconds}
/>
</div>
</MainHorizontallyCenteredContainer>
</PageBody>
</PageContainer>
);
}