Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ export interface AssessmentTaskTemplatePreviewProps {
export function AssessmentTaskTemplatePreview({
taskTemplatePreview,
}: AssessmentTaskTemplatePreviewProps) {
const { title } = taskTemplatePreview;
const { title, estimatedTime } = taskTemplatePreview;
return (
<div className="flex h-full w-full flex-col gap-2 px-6 py-4">
<div className="inline-flex flex-col items-start gap-1 self-stretch pl-3">
Expand All @@ -21,8 +21,9 @@ export function AssessmentTaskTemplatePreview({
</h2>
<div className="inline-flex items-center justify-start gap-2 self-stretch">
<AlarmClock className="h-5 w-5 text-neutral-700" />
{/* TODO: add task template time limit field here */}
<p className="text-body-s font-medium text-neutral-800"> Coming Soon... </p>
<p className="text-body-s font-medium text-neutral-800">
{estimatedTime} minutes
</p>
</div>
</div>
<div>
Expand Down
2 changes: 1 addition & 1 deletion src/lib/components/templates/AssessmentTemplateItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ export default function AssessmentTemplateItem({
</div>

{estimatedTime > 0 && (
<span className="text-label-xs ml-2 shrink-0">{estimatedTime}min</span>
<span className="text-label-xs ml-2 shrink-0">{estimatedTime} minutes</span>
)}
</div>
</div>
Expand Down
2 changes: 1 addition & 1 deletion src/lib/hooks/useAssessment.ts
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ export default function useAssessment(assessmentId: string) {

// the timer is in seconds however our model is in minutes
const totalEstimatedMinutes = sections.reduce(
(sum, s) => sum + (s.taskTemplate.estimatedTime ?? 0),
(sum, s) => sum + s.taskTemplate.estimatedTime,
0
);
const totalTimeSeconds = totalEstimatedMinutes * 60;
Expand Down
21 changes: 19 additions & 2 deletions src/lib/services/email.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,21 @@ export async function sendAssessmentInvitationEmail(
include: {
applications: {
include: {
assessment: true,
assessment: {
include: {
assessmentTemplate: {
include: {
tasks: {
include: {
taskTemplate: {
select: { estimatedTime: true },
},
},
},
},
},
},
},
position: true,
},
},
Expand Down Expand Up @@ -51,7 +65,10 @@ export async function sendAssessmentInvitationEmail(
const logoUrl = `${baseUrl}/Sarge_logo.svg`;

//placeholder duration and expiration
const durationMinutes = 120;
const durationMinutes = assessment.assessmentTemplate.tasks.reduce(
(sum, task) => sum + task.taskTemplate.estimatedTime,
0
);
const expirationDate = 'April 12, 2026 11:59PM EST';
const htmlContent = generateAssessmentInvitationHTML({
candidateName: candidate.name,
Expand Down
Loading