-
Notifications
You must be signed in to change notification settings - Fork 806
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: Merge branch 'main' into feature/deduplication-v2
- Loading branch information
Showing
18 changed files
with
4,975 additions
and
750 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
node_modules |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
.copilotKitInput { | ||
@apply sticky bottom-0 bg-white !important; | ||
@apply flex items-center outline-none rounded-tremor-default px-3 py-2 mx-2 text-tremor-default focus:ring-2 transition duration-100 border shadow-tremor-input focus:border-tremor-brand-subtle focus:ring-tremor-brand-muted dark:shadow-dark-tremor-input focus:dark:border-dark-tremor-brand-subtle focus:dark:ring-dark-tremor-brand-muted bg-tremor-background dark:bg-dark-tremor-background hover:bg-tremor-background-muted dark:hover:bg-dark-tremor-background-muted text-tremor-content-emphasis dark:text-dark-tremor-content-emphasis border-tremor-border dark:border-dark-tremor-border placeholder:text-tremor-content dark:placeholder:text-dark-tremor-content !important; | ||
} | ||
|
||
.copilotKitInput:hover textarea { | ||
@apply bg-tremor-background-muted dark:bg-dark-tremor-background-muted transition duration-100 !important; | ||
} | ||
|
||
.copilotKitInput textarea { | ||
height: unset !important; | ||
max-height: unset !important; | ||
} | ||
|
||
.copilotKitMessages { | ||
@apply px-4 !important; | ||
} | ||
|
||
.copilotKitMessages .suggestion { | ||
@apply bg-white text-black scale-100 border-tremor-border border-2 hover:border-tremor-brand hover:text-tremor-brand hover:bg-tremor-brand-muted dark:border-dark-tremor-brand dark:hover:bg-dark-tremor-brand-muted transition !important; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,132 @@ | ||
import { | ||
CopilotChat, | ||
CopilotKitCSSProperties, | ||
useCopilotChatSuggestions, | ||
} from "@copilotkit/react-ui"; | ||
import { IncidentDto } from "../models"; | ||
import { | ||
useIncident, | ||
useIncidentAlerts, | ||
useIncidents, | ||
} from "utils/hooks/useIncidents"; | ||
import { EmptyStateCard } from "@/components/ui/EmptyStateCard"; | ||
import { useRouter } from "next/navigation"; | ||
import "./incident-chat.css"; | ||
import Loading from "app/loading"; | ||
import { useCopilotAction, useCopilotReadable } from "@copilotkit/react-core"; | ||
import { updateIncidentRequest } from "../create-or-update-incident"; | ||
import { useSession } from "next-auth/react"; | ||
import { toast } from "react-toastify"; | ||
|
||
export default function IncidentChat({ incident }: { incident: IncidentDto }) { | ||
const router = useRouter(); | ||
const { mutate } = useIncidents(true, 20); | ||
const { mutate: mutateIncident } = useIncident(incident.id); | ||
const { data: alerts, isLoading: alertsLoading } = useIncidentAlerts( | ||
incident.id | ||
); | ||
const { data: session } = useSession(); | ||
|
||
useCopilotReadable({ | ||
description: "incidentDetails", | ||
value: incident, | ||
}); | ||
useCopilotReadable({ | ||
description: "alerts", | ||
value: alerts?.items, | ||
}); | ||
|
||
useCopilotChatSuggestions({ | ||
instructions: `The following incident is on going: ${JSON.stringify( | ||
incident | ||
)}. Provide good question suggestions for the incident responder team.`, | ||
}); | ||
|
||
useCopilotAction({ | ||
name: "gotoAlert", | ||
description: "Select an alert and filter the feed by the alert fingerprint", | ||
parameters: [ | ||
{ | ||
name: "fingerprint", | ||
type: "string", | ||
description: | ||
"The fingerprint of the alert. You can extract it using the alert name as well.", | ||
required: true, | ||
}, | ||
], | ||
handler: async ({ fingerprint }) => { | ||
window.open(`/alerts/feed?fingerprint=${fingerprint}`, "_blank"); | ||
}, | ||
}); | ||
|
||
useCopilotAction({ | ||
name: "updateIncidentNameAndSummary", | ||
description: "Update incident name and summary", | ||
parameters: [ | ||
{ | ||
name: "name", | ||
type: "string", | ||
description: "The new name for the incident", | ||
}, | ||
{ | ||
name: "summary", | ||
type: "string", | ||
description: "The new summary for the incident", | ||
}, | ||
], | ||
handler: async ({ name, summary }) => { | ||
const response = await updateIncidentRequest( | ||
session, | ||
incident.id, | ||
name, | ||
summary, | ||
incident.assignee | ||
); | ||
if (response.ok) { | ||
mutate(); | ||
mutateIncident(); | ||
toast.success("Incident updated successfully"); | ||
} | ||
}, | ||
}); | ||
|
||
if (alertsLoading) return <Loading />; | ||
if (!alerts?.items || alerts.items.length === 0) | ||
return ( | ||
<EmptyStateCard | ||
title="Chat not available" | ||
description="No alerts found for this incident. Go to the alerts feed and assign alerts to interact with the incident." | ||
buttonText="Assign alerts to this incident" | ||
onClick={() => router.push("/alerts/feed")} | ||
/> | ||
); | ||
|
||
return ( | ||
<div | ||
style={ | ||
{ | ||
"--copilot-kit-primary-color": | ||
"rgb(249 115 22 / var(--tw-bg-opacity))", | ||
} as CopilotKitCSSProperties | ||
} | ||
> | ||
<CopilotChat | ||
className="-mx-2" | ||
instructions={`You now act as an expert incident responder. | ||
You are responsible for resolving incidents and helping the incident responding team. | ||
The information you are provided with is a JSON representing all the data about the incident and a list of alerts that are related to the incident. | ||
Your job is to help the incident responder team to resolve the incident as soon as possible by providing insights and recommendations. | ||
Use the incident details and alerts context to give good, meaningful answers. | ||
If you do not know the answer or lack context, share that with the end user and ask for more context.`} | ||
labels={{ | ||
title: "Incident Assitant", | ||
initial: | ||
"Hi! 👋 Lets work together to resolve this incident! Ask me anything", | ||
placeholder: | ||
"For example: What do you think the root cause of this incident might be?", | ||
}} | ||
/> | ||
</div> | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.