Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore(j-s): Indictment Case Arrignment Date #16156

Merged
merged 7 commits into from
Sep 27, 2024
Original file line number Diff line number Diff line change
Expand Up @@ -1143,15 +1143,29 @@ export class CaseService {
private addMessagesForNewCourtDateToQueue(
theCase: Case,
user: TUser,
arraignmentDateChanged: boolean,
): Promise<void> {
return this.messageService.sendMessagesToQueue([
const messages: Message[] = [
{
type: MessageType.NOTIFICATION,
user,
caseId: theCase.id,
body: { type: NotificationType.COURT_DATE },
},
])
]

if (arraignmentDateChanged) {
theCase.defendants?.forEach((defendant) => {
messages.push({
type: MessageType.DELIVERY_TO_POLICE_SUBPOENA,
user,
caseId: theCase.id,
elementId: defendant.id,
})
})
}

return this.messageService.sendMessagesToQueue(messages)
}

private async addMessagesForUpdatedCaseToQueue(
Expand Down Expand Up @@ -1310,11 +1324,27 @@ export class CaseService {
}

// This only applies to indictments
const courtDate = DateLog.courtDate(theCase.dateLogs)
const updatedCourtDate = DateLog.courtDate(updatedCase.dateLogs)
if (updatedCourtDate && updatedCourtDate.date !== courtDate?.date) {
// New court date
await this.addMessagesForNewCourtDateToQueue(updatedCase, user)
if (isIndictment) {
const arraignmentDate = DateLog.arraignmentDate(theCase.dateLogs)
const updatedArraignmentDate = DateLog.arraignmentDate(
updatedCase.dateLogs,
)
const arraignmentDateChanged =
updatedArraignmentDate &&
updatedArraignmentDate.date !== arraignmentDate?.date
const courtDate = DateLog.courtDate(theCase.dateLogs)
const updatedCourtDate = DateLog.courtDate(updatedCase.dateLogs)
const courtDateChanged =
updatedCourtDate && updatedCourtDate.date !== courtDate?.date

gudjong marked this conversation as resolved.
Show resolved Hide resolved
if (arraignmentDateChanged || courtDateChanged) {
// New arraignment date or new court date
await this.addMessagesForNewCourtDateToQueue(
updatedCase,
user,
Boolean(arraignmentDateChanged),
)
}
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -69,15 +69,6 @@ export class NotificationService {
]
} else {
messages = [this.getNotificationMessage(type, user, theCase)]
theCase.defendants?.forEach((defendant) => {
// TODO: move this elsewhere when we know exactly where the trigger should be
messages.push({
type: MessageType.DELIVERY_TO_POLICE_SUBPOENA,
user,
caseId: theCase.id,
elementId: defendant.id,
})
})
}
break
case NotificationType.HEADS_UP:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,7 @@ export class SubpoenaService {
return { delivered: false }
}

// TODO: Improve error handling by checking how many rows were affected and posting error event
await this.subpoenaModel.update(
{ subpoenaId: createdSubpoena.subpoenaId },
{ where: { id: subpoena.id } },
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,14 +19,9 @@ import {
SectionHeading,
useCourtArrangements,
} from '@island.is/judicial-system-web/src/components'
import { NotificationType } from '@island.is/judicial-system-web/src/graphql/schema'
import { SubpoenaType } from '@island.is/judicial-system-web/src/routes/Court/components'
import type { stepValidationsType } from '@island.is/judicial-system-web/src/utils/formHelper'
import {
useCase,
useDefendants,
} from '@island.is/judicial-system-web/src/utils/hooks'
import { hasSentNotification } from '@island.is/judicial-system-web/src/utils/stepHelper'
import { useDefendants } from '@island.is/judicial-system-web/src/utils/hooks'
import { isSubpoenaStepValid } from '@island.is/judicial-system-web/src/utils/validate'

import { subpoena as strings } from './Subpoena.strings'
Expand All @@ -39,18 +34,16 @@ const Subpoena: FC = () => {
const { formatMessage } = useIntl()
const {
courtDate,
courtDateHasChanged,
handleCourtDateChange,
handleCourtRoomChange,
sendCourtDateToServer,
} = useCourtArrangements(workingCase, setWorkingCase, 'arraignmentDate')
const { sendNotification } = useCase()

const isArraignmentDone = Boolean(workingCase.indictmentDecision)
const isArraignmentScheduled = Boolean(workingCase.arraignmentDate)

const handleNavigationTo = useCallback(
async (destination: keyof stepValidationsType) => {
if (isArraignmentDone) {
if (isArraignmentScheduled) {
router.push(`${destination}/${workingCase.id}`)
return
}
Expand All @@ -69,18 +62,6 @@ const Subpoena: FC = () => {
})
}

if (
!hasSentNotification(
NotificationType.COURT_DATE,
workingCase.notifications,
).hasSent ||
courtDateHasChanged
) {
promises.push(
sendNotification(workingCase.id, NotificationType.COURT_DATE),
)
}

const allDataSentToServer = await Promise.all(promises)
if (!allDataSentToServer.every((result) => result)) {
return
Expand All @@ -89,14 +70,11 @@ const Subpoena: FC = () => {
router.push(`${destination}/${workingCase.id}`)
},
[
isArraignmentDone,
isArraignmentScheduled,
sendCourtDateToServer,
workingCase.defendants,
workingCase.notifications,
workingCase.id,
courtDateHasChanged,
updateDefendant,
sendNotification,
],
)

Expand Down Expand Up @@ -134,8 +112,8 @@ const Subpoena: FC = () => {
handleCourtDateChange={handleCourtDateChange}
handleCourtRoomChange={handleCourtRoomChange}
courtDate={workingCase.arraignmentDate}
dateTimeDisabled={isArraignmentDone}
courtRoomDisabled={isArraignmentDone}
dateTimeDisabled={isArraignmentScheduled}
courtRoomDisabled={isArraignmentScheduled}
courtRoomRequired
/>
</Box>
Expand Down Expand Up @@ -169,14 +147,14 @@ const Subpoena: FC = () => {
previousUrl={`${constants.INDICTMENTS_RECEPTION_AND_ASSIGNMENT_ROUTE}/${workingCase.id}`}
nextIsLoading={isLoadingWorkingCase}
onNextButtonClick={() => {
if (isArraignmentDone) {
if (isArraignmentScheduled) {
router.push(
`${constants.INDICTMENTS_DEFENDER_ROUTE}/${workingCase.id}`,
)
} else setNavigateTo(constants.INDICTMENTS_DEFENDER_ROUTE)
}}
nextButtonText={
isArraignmentDone
isArraignmentScheduled
? undefined
: formatMessage(strings.nextButtonText)
}
Expand Down
Loading