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

Bal 1644 - report in case management #2343

Closed
wants to merge 109 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
109 commits
Select commit Hold shift + click to select a range
a229547
feat: add new controller for busniess report get api
liorzblrn Apr 15, 2024
6fe5693
feat: add seed and new get alerts api
liorzblrn Apr 15, 2024
1888d2e
fix: remove executionDetails from alert reponse
liorzblrn Apr 16, 2024
d657ee4
feat: added initial onboarding alerts table & implemented Filters com…
chesterkmr Apr 16, 2024
2c03c6e
feat: updated callback to ongoing to format response for each report
Blokh Apr 21, 2024
fa0dd21
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh Apr 21, 2024
e849d29
feat: updated report return logic
Blokh Apr 21, 2024
9de6f37
Merge branch 'blokh/feat/add-business-report-report-id' of github.com…
Blokh Apr 21, 2024
35abd78
feat: added validation via zod
Blokh Apr 21, 2024
89d3169
feat: removed optional report id
Blokh Apr 21, 2024
fa8935c
feat(backoffice): business ongoing monitoring
alonp99 Apr 23, 2024
cfe515d
feat(backoffice): business ongoing monitoring
alonp99 Apr 23, 2024
dc05878
merged with dev
Blokh Apr 24, 2024
924ccaf
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh Apr 24, 2024
0d1ed0b
updated ongoing service
Blokh Apr 24, 2024
76cefc9
feat: updated business report logic and added business list fetching
Blokh Apr 25, 2024
549cb7d
updated callback handler hook
Blokh Apr 25, 2024
1d15b8c
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh Apr 25, 2024
e72ae5f
merged with dev
Blokh Apr 25, 2024
203f583
updated previousReport to previousReportSummary
Blokh Apr 30, 2024
0af4256
updated ongoing formats
Blokh Apr 30, 2024
5c21784
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh Apr 30, 2024
8d32745
merged with dev
Blokh Apr 30, 2024
8344bf7
feat: fixed generating filesync
Blokh Apr 30, 2024
1e976f2
fix: horrible merge
liorzblrn May 1, 2024
7b6347d
fix: merge
liorzblrn May 1, 2024
51cfc96
fix: merge 2
liorzblrn May 1, 2024
b5f36b4
fix: merge - fix lint
liorzblrn May 1, 2024
ae9c95f
fix: merge - fix tests
liorzblrn May 1, 2024
a8e1a1b
fix: rename config for jest
liorzblrn May 1, 2024
8ed47e5
chore(tm): adding mappings, brand names
alonp99 May 1, 2024
ba93150
Merge pull request #2330 from ballerine-io/bal-1880-ongoing-moitoring…
liorzam May 1, 2024
9f8d3c5
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh May 1, 2024
7c4055a
fix: alert def for ongoing merchant _ merge
liorzblrn May 1, 2024
a6eca5b
Merge branch 'bal-1880-ongoing-moitoring-alerts-merge' into bal-1880-…
liorzblrn May 1, 2024
13f68bb
fix: eslint
liorzblrn May 1, 2024
e2f6810
Merge branch 'dev' into bal-1880-ongoing-moitoring-alerts
Blokh May 2, 2024
610d9f7
added additionalInfo to Data analytics
Blokh May 2, 2024
36361bc
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh May 2, 2024
55cfca6
Merge branch 'dev' into bal-1644
chesterkmr May 5, 2024
4828e8c
Merge branch 'bal-1644-ongoing-alon' into bal-1644
chesterkmr May 5, 2024
ca2c60e
feat: update business report logic
Blokh May 5, 2024
7b672f3
Merge branch 'blokh/feat/add-business-report-report-id' into feature/…
Blokh May 5, 2024
b19d4a7
merged with blokh/feat/add-business-report-report-id
Blokh May 5, 2024
3fee08e
fix: cleanup & fixed layout
chesterkmr May 5, 2024
2c43c5d
feat: finished logic of merchant monitoring creation
Blokh May 5, 2024
5e7d0da
feat: business alerts boilerplate
chesterkmr May 6, 2024
9b843c2
Merge branch 'bal-1656-epic-reports-in-case-management' into bal-1644
chesterkmr May 6, 2024
41ce263
fix: types
chesterkmr May 6, 2024
11dd0f5
Merge remote-tracking branch 'origin' into bal-1656-epic-reports-in-c…
liorzblrn May 6, 2024
4cb5e8e
Merge branch 'bal-1656-epic-reports-in-case-management' into bal-1644
chesterkmr May 6, 2024
49ec5b6
feat: added business reports seed & ongoing monitoring table
chesterkmr May 6, 2024
6b303a9
feat: sync
chesterkmr May 6, 2024
4d68f6a
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh May 6, 2024
abcb568
Merge branch 'blokh/feat/add-business-report-report-id' into feature/…
Blokh May 6, 2024
e4edf2c
feat: finalized hook callback handler
Blokh May 6, 2024
5a309a3
feat: fixed ts issues
Blokh May 6, 2024
f14efa1
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh May 7, 2024
07be97d
Merge branch 'blokh/feat/add-business-report-report-id' into feature/…
Blokh May 7, 2024
0dc86f6
feat: updated alert logic and added testing
Blokh May 7, 2024
d73bcb0
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh May 7, 2024
7bf63b7
Merge branch 'blokh/feat/add-business-report-report-id' into feature/…
Blokh May 7, 2024
7fb50ab
fix(workflows-service): fixed bad import in zod-schemas.ts
Omri-Levy May 7, 2024
ff572dc
feat: revereted jest changes
Blokh May 8, 2024
6a1cc16
feat: added nest requirements and updated tests
Blokh May 8, 2024
1f65d71
feat: updated controller logic for processing
Blokh May 8, 2024
6e0bf69
feat: added zod validation and changes in alert logic
Blokh May 9, 2024
6da9f1d
Merge remote-tracking branch 'origin/feature/implement_ongoing_report…
chesterkmr May 9, 2024
5b8e07f
Feature/implement ongoing report alert #1959 #1656 (#2341)
Blokh May 9, 2024
ce8bf38
feat: finalized business alerts table
chesterkmr May 12, 2024
7443d11
feat: fixed alert service intg test
Blokh May 16, 2024
5181498
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh May 16, 2024
066f538
feat: merged wit hdev
Blokh May 16, 2024
4a34fe1
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh May 16, 2024
26aefad
Merge branch 'blokh/feat/add-business-report-report-id' into bal-1644
chesterkmr May 16, 2024
b1e4392
fixed imports
Blokh May 16, 2024
d0844c9
fix: post merge fixes
chesterkmr May 16, 2024
bce1800
feat: fix onboarding completion
Blokh May 16, 2024
330341d
fix: removed log
chesterkmr May 20, 2024
7ef11bb
fix: fixed missing alerts analysis page
chesterkmr May 20, 2024
33be864
feat: added on clear to useFilter
chesterkmr May 20, 2024
ab45535
feat: refactorted filters context
chesterkmr May 20, 2024
a0f7969
feat: refactored filters
chesterkmr May 21, 2024
6f4b1aa
fix: removed ts ignore
chesterkmr May 21, 2024
f074b33
feat: reverted filters
chesterkmr May 21, 2024
30ac7f4
feat: added transaction to handle pglocking
Blokh May 21, 2024
b721fa6
Merge branch 'bal-1644' of github.com:ballerine-io/ballerine into bal…
Blokh May 21, 2024
5fca5b1
fix: cleaned code duplicates & refactor
chesterkmr May 21, 2024
e0df50f
feat: refactored business alerts table
chesterkmr May 21, 2024
9452a57
fix: div to p
chesterkmr May 21, 2024
419de02
feat: merged with dev - fixed conflicts
Blokh May 21, 2024
05aaf9e
Merge branch 'dev' into blokh/feat/add-business-report-report-id
Blokh May 21, 2024
8747e79
feat: merged with dev
Blokh May 21, 2024
2a47598
feat: updated check alerts logic
Blokh May 21, 2024
fcbcca3
feat: updated executin details
Blokh May 21, 2024
2030bdb
Merge branch 'blokh/feat/add-business-report-report-id' into bal-1644
Blokh May 21, 2024
c446fc8
feat: fixed merge conflicts
Blokh May 21, 2024
5b02205
Merge remote-tracking branch 'origin/dev' into bal-1644
Blokh May 22, 2024
48bf1d3
feat: fixed conflicts with dev
Blokh May 22, 2024
410de81
feat: fixed report generation logic
Blokh May 22, 2024
45f1ebb
feat: updated create alert logic
Blokh May 23, 2024
521c48f
fix(*): pr comments
Omri-Levy May 23, 2024
c6c998d
fix(*): resolved conflicts
Omri-Levy May 23, 2024
ced6237
fix(backoffice-v2): wrong props type name
Omri-Levy May 23, 2024
4d9660b
fix(backoffice-v2): fixed type
Omri-Levy May 23, 2024
842ac68
refactor(*): removed uintentional commited code
Omri-Levy May 23, 2024
6aaceaf
refactor(backoffice-v2): no longer using the same accessor multiple t…
Omri-Levy May 23, 2024
fb9810b
fix(*): small fixes
Omri-Levy May 23, 2024
c6a0f23
fix: seed
chesterkmr May 28, 2024
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
56 changes: 39 additions & 17 deletions apps/backoffice-v2/src/Router/Router.tsx
Original file line number Diff line number Diff line change
@@ -1,28 +1,31 @@
import React, { FunctionComponent } from 'react';
import { env } from '@/common/env/env';
import { createBrowserRouter, RouterProvider } from 'react-router-dom';
import { RootError } from '@/pages/Root/Root.error';
import { Root } from '@/pages/Root/Root.page';
import { SignIn } from '@/pages/SignIn/SignIn.page';
import { Entity } from '@/pages/Entity/Entity.page';
import { Entities } from '@/pages/Entities/Entities.page';
import { RouteError } from '@/common/components/atoms/RouteError/RouteError';
import { CaseManagement } from '@/pages/CaseManagement/CaseManagement.page';
import { rootLoader } from '@/pages/Root/Root.loader';
import { entitiesLoader } from '@/pages/Entities/Entities.loader';
import { authenticatedLayoutLoader } from '@/domains/auth/components/AuthenticatedLayout/AuthenticatedLayout.loader';
import { entityLoader } from '@/pages/Entity/Entity.loader';
import { env } from '@/common/env/env';
import { AuthenticatedLayout } from '@/domains/auth/components/AuthenticatedLayout';
import { authenticatedLayoutLoader } from '@/domains/auth/components/AuthenticatedLayout/AuthenticatedLayout.loader';
import { UnauthenticatedLayout } from '@/domains/auth/components/UnauthenticatedLayout';
import { Locale } from '@/pages/Locale/Locale.page';
import { unauthenticatedLayoutLoader } from '@/domains/auth/components/UnauthenticatedLayout/UnauthenticatedLayout.loader';
import { Businesses } from '@/pages/Businesses/Businesses';
import { BusinessesAlerts } from '@/pages/BusinessesAlerts/BusinessesAlerts.page';
import { BusinessesAlertsAnalysisPage } from '@/pages/BusinessesAlertsAnalysis/BusinessesAlertsAnalysis.page';
import { CaseManagement } from '@/pages/CaseManagement/CaseManagement.page';
import { Document } from '@/pages/Document/Document.page';
import { entitiesLoader } from '@/pages/Entities/Entities.loader';
import { Entities } from '@/pages/Entities/Entities.page';
import { entityLoader } from '@/pages/Entity/Entity.loader';
import { Entity } from '@/pages/Entity/Entity.page';
import { Locale } from '@/pages/Locale/Locale.page';
import { NotFoundRedirect } from '@/pages/NotFound/NotFound';
import { TransactionMonitoringAlerts } from '@/pages/TransactionMonitoringAlerts/TransactionMonitoringAlerts.page';
import { Individuals } from '@/pages/Profiles/Individuals/Individuals.page';
import { Profiles } from '@/pages/Profiles/Profiles.page';
import { RootError } from '@/pages/Root/Root.error';
import { rootLoader } from '@/pages/Root/Root.loader';
import { Root } from '@/pages/Root/Root.page';
import { SignIn } from '@/pages/SignIn/SignIn.page';
import { TransactionMonitoring } from '@/pages/TransactionMonitoring/TransactionMonitoring';
import { TransactionMonitoringAlerts } from '@/pages/TransactionMonitoringAlerts/TransactionMonitoringAlerts.page';
import { TransactionMonitoringAlertsAnalysisPage } from '@/pages/TransactionMonitoringAlertsAnalysis/TransactionMonitoringAlertsAnalysis.page';
import { Profiles } from '@/pages/Profiles/Profiles.page';
import { Individuals } from '@/pages/Profiles/Individuals/Individuals.page';
import { FunctionComponent } from 'react';
import { RouterProvider, createBrowserRouter } from 'react-router-dom';

const router = createBrowserRouter([
{
Expand Down Expand Up @@ -121,6 +124,25 @@ const router = createBrowserRouter([
},
],
},
{
path: '/:locale/businesses',
element: <Businesses />,
errorElement: <RouteError />,
children: [
{
path: '/:locale/businesses/alerts',
element: <BusinessesAlerts />,
errorElement: <RouteError />,
children: [
{
path: '/:locale/businesses/alerts/:alertId',
element: <BusinessesAlertsAnalysisPage />,
errorElement: <RouteError />,
},
],
},
],
},
],
},
],
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { ReactNode, useCallback, useState } from 'react';
import { Separator } from '@/common/components/atoms/Separator/Separator';
import {
Badge,
Button,
Expand All @@ -15,7 +15,7 @@ import {
PopoverTrigger,
} from '@ballerine/ui';
import { CheckIcon, PlusCircledIcon } from '@radix-ui/react-icons';
import { Separator } from '@/common/components/atoms/Separator/Separator';
import { ReactNode, useCallback, useState } from 'react';

interface IMultiSelectProps<
TOption extends {
Expand Down Expand Up @@ -63,7 +63,7 @@ export const MultiSelect = <
<Popover>
<PopoverTrigger asChild>
<Button variant="outline" size="sm" className="h-8 border">
<PlusCircledIcon className="mr-2 h-4 w-4" />
<PlusCircledIcon className="mr-2 d-4" />
{title}
{selected?.length > 0 && (
<>
Expand Down Expand Up @@ -107,13 +107,13 @@ export const MultiSelect = <
<CommandItem key={option.value} onSelect={() => onSelectChange(option.value)}>
<div
className={ctw(
'mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary',
'mr-2 flex items-center justify-center rounded-sm border border-primary d-4',
isSelected
? 'bg-primary text-primary-foreground'
: 'opacity-50 [&_svg]:invisible',
)}
>
<CheckIcon className={ctw('h-4 w-4')} />
<CheckIcon className={ctw('d-4')} />
</div>
{option.icon}
<span>{option.label}</span>
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import { ExternalLink } from 'lucide-react';
import { ComponentProps, FunctionComponent } from 'react';
import { buttonVariants } from '@/common/components/atoms/Button/Button';
import { ctw } from '@/common/utils/ctw/ctw';

export const OpenUrlInNewTabButton: FunctionComponent<ComponentProps<'a'>> = ({
href,
...props
}) => {
return (
<a
href={href}
target={'_blank'}
rel={'noopener noreferrer'}
aria-disabled={!href}
{...props}
className={ctw(
buttonVariants({
variant: 'ghost',
size: 'icon',
className: 'p-1 d-9',
}),
{
'pointer-events-none opacity-50': !href,
},
)}
>
<ExternalLink className="text-blue-500" />
</a>
);
};
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,9 @@ export interface IDataTableProps<TData, TValue = any> {

// Component props
props?: {
scroll?: Partial<ComponentProps<typeof ScrollArea>>;
container?: ComponentProps<'div'>;
scroll?: Omit<ComponentProps<typeof ScrollArea>, 'orientation'> &
Partial<Pick<ComponentProps<typeof ScrollArea>, 'orientation'>>;
table?: ComponentProps<typeof Table>;
header?: ComponentProps<typeof TableHeader>;
head?: ComponentProps<typeof TableHead>;
Expand Down Expand Up @@ -186,7 +188,13 @@ export const DataTable = <TData extends RowData, TValue = any>({
});

return (
<div className="relative overflow-auto rounded-md border bg-white shadow">
<div
{...props?.container}
className={ctw(
'relative overflow-auto rounded-md border bg-white shadow',
props?.container?.className,
)}
>
<ScrollArea orientation="both" {...props?.scroll}>
<Table {...props?.table}>
{caption && (
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import { useFiltersQuery } from '@/domains/filters/hooks/queries/useFiltersQuery/useFiltersQuery';
import { TRouteWithChildren, TRoutes } from '@/Router/types';
import { useFilterId } from '@/common/hooks/useFilterId/useFilterId';
import { useCallback, useMemo } from 'react';
import { useFiltersQuery } from '@/domains/filters/hooks/queries/useFiltersQuery/useFiltersQuery';
import { Building, Goal, Users } from 'lucide-react';
import { TRoutes, TRouteWithChildren } from '@/Router/types';
import { useCallback, useMemo } from 'react';
import { useLocation } from 'react-router-dom';

export const useNavbarLogic = () => {
Expand All @@ -20,13 +20,19 @@ export const useNavbarLogic = () => {
{
text: 'Businesses',
icon: <Building size={20} />,
children:
businessesFilters?.map(({ id, name }) => ({
children: [
...(businessesFilters?.map(({ id, name }) => ({
filterId: id,
text: name,
href: `/en/case-management/entities?filterId=${id}`,
key: `nav-item-${id}`,
})) ?? [],
})) ?? []),
{
text: 'Ongoing Moniotring',
href: `/en/businesses/alerts`,
key: 'nav-item-business-alerts',
},
],
key: 'nav-item-businesses',
},
{
Expand Down
13 changes: 12 additions & 1 deletion apps/backoffice-v2/src/common/hooks/useFilter/useFilter.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { useCallback } from 'react';
import { useSerializedSearchParams } from '@/common/hooks/useSerializedSearchParams/useSerializedSearchParams';
import { useCallback } from 'react';

export const useFilter = () => {
const [{ filter }, setSearchParams] = useSerializedSearchParams();
Expand All @@ -19,8 +19,19 @@ export const useFilter = () => {
[filter, setSearchParams],
);

const onClear = useCallback((accessor: string) => {
setSearchParams({
filter: {
...filter,
[accessor]: [],
},
page: '1',
});
}, []);

return {
filter,
onClear,
onFilter,
};
};
57 changes: 29 additions & 28 deletions apps/backoffice-v2/src/domains/alerts/fetchers.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import qs from 'qs';
import { apiClient } from '@/common/api-client/api-client';
import { Method } from '@/common/enums';
import { z } from 'zod';
import { ObjectWithIdSchema } from '@/lib/zod/utils/object-with-id/object-with-id';
import { handleZodError } from '@/common/utils/handle-zod-error/handle-zod-error';
import { env } from '@/common/env/env';
import { TObjectValues } from '@/common/types';
import { getOriginUrl } from '@/common/utils/get-origin-url/get-url-origin';
import { env } from '@/common/env/env';
import { handleZodError } from '@/common/utils/handle-zod-error/handle-zod-error';
import { ObjectWithIdSchema } from '@/lib/zod/utils/object-with-id/object-with-id';
import qs from 'qs';
import { z } from 'zod';

export const AlertSeverity = {
CRITICAL: 'critical',
Expand Down Expand Up @@ -72,32 +72,33 @@ export type TAlertState = (typeof AlertStates)[number];

export type TAlertStates = typeof AlertStates;

export const AlertsListSchema = z.array(
ObjectWithIdSchema.extend({
dataTimestamp: z.string().datetime(),
updatedAt: z.string().datetime(),
subject: ObjectWithIdSchema.extend({
name: z.string(),
correlationId: z.string(),
type: z.enum(['business', 'counterparty']),
}),
severity: z.enum(AlertSeverities),
export const AlertSchema = ObjectWithIdSchema.extend({
dataTimestamp: z.string().datetime(),
updatedAt: z.string().datetime(),
subject: ObjectWithIdSchema.extend({
name: z.string(),
correlationId: z.string(),
alertDetails: z.string(),
// amountOfTxs: z.number(),
assignee: ObjectWithIdSchema.extend({
fullName: z.string(),
avatarUrl: z.string().nullable().optional(),
})
.nullable()
.default(null),
status: z.enum(AlertStatuses),
decision: z.enum(AlertStates).nullable().default(null),
counterpartyId: z.string().nullable().default(null),
type: z.enum(['business', 'counterparty']),
}),
);
severity: z.enum(AlertSeverities),
correlationId: z.string(),
alertDetails: z.string(),
// amountOfTxs: z.number(),
assignee: ObjectWithIdSchema.extend({
fullName: z.string(),
avatarUrl: z.string().nullable().optional(),
})
.nullable()
.default(null),
status: z.enum(AlertStatuses),
decision: z.enum(AlertStates).nullable().default(null),
counterpartyId: z.string().nullable().default(null),
});

Comment on lines +75 to +96
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The alert fetching functions are well-implemented, correctly using async/await and error handling. Consider breaking down fetchAlerts into smaller functions for better maintainability.

export const AlertsListSchema = z.array(AlertSchema);

export type TAlertsList = z.output<typeof AlertsListSchema>;
export type TAlert = z.output<typeof AlertSchema>;
export type TAlerts = z.output<typeof AlertsListSchema>;

export const fetchAlerts = async (params: {
orderBy: string;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
import { BaseSearchSchema } from '@/common/hooks/useSearchParamsByEntity/validation-schemas';
import { z } from 'zod';
import { AlertStatus, AlertStatuses, TAlertsList } from '@/domains/alerts/fetchers';
import { AlertStatus, AlertStatuses, TAlert } from '@/domains/alerts/fetchers';
import { BooleanishSchema } from '@/lib/zod/utils/checkers';
export const getAlertsSearchSchema = (authenticatedUserId: string | undefined) =>
import { z } from 'zod';

export const getAlertsSearchSchema = () =>
BaseSearchSchema.extend({
sortBy: z
.enum(['dataTimestamp', 'status'] as const satisfies ReadonlyArray<
Extract<keyof TAlertsList[number], 'dataTimestamp' | 'status'>
Extract<keyof TAlert, 'dataTimestamp' | 'status'>
>)
.catch('dataTimestamp'),
filter: z
Expand All @@ -25,4 +26,5 @@ export const getAlertsSearchSchema = (authenticatedUserId: string | undefined) =
selected: BooleanishSchema.optional(),
businessId: z.string().optional(),
counterpartyId: z.string().optional(),
type: z.string().optional(),
});
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { alertsQueryKeys } from '@/domains/alerts/query-keys';
import { useIsAuthenticated } from '@/domains/auth/context/AuthProvider/hooks/useIsAuthenticated/useIsAuthenticated';
import { useQuery } from '@tanstack/react-query';
import { alertsQueryKeys } from '@/domains/alerts/query-keys';

export const useAlertsQuery = ({
sortBy,
Expand Down
17 changes: 15 additions & 2 deletions apps/backoffice-v2/src/domains/alerts/query-keys.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,25 @@
import { createQueryKeys } from '@lukemorales/query-key-factory';
import {
fetchAlertDefinitionByAlertId,
fetchAlertCorrelationIds,
fetchAlertDefinitionByAlertId,
fetchAlerts,
} from '@/domains/alerts/fetchers';

export const alertsQueryKeys = createQueryKeys('alerts', {
list: ({ sortBy, sortDir, page, pageSize, ...params }) => {
list: ({
sortBy,
sortDir,
page,
pageSize,
...params
}: {
sortBy: string;
sortDir: string;
page: number;
pageSize: number;
search: string;
filter: Record<string, unknown>;
}) => {
const data = {
...params,
orderBy: `${sortBy}:${sortDir}`,
Expand Down
Loading
Loading