diff --git a/package.json b/package.json
index 6fb1ad3..630b0cf 100644
--- a/package.json
+++ b/package.json
@@ -42,7 +42,7 @@
"@cosmjs/tendermint-rpc": "^0.32.1",
"@dydxprotocol/v4-abacus": "^1.4.9",
"@dydxprotocol/v4-client-js": "^1.0.20",
- "@dydxprotocol/v4-localization": "^1.1.34",
+ "@dydxprotocol/v4-localization": "^1.1.35",
"@ethersproject/providers": "^5.7.2",
"@js-joda/core": "^5.5.3",
"@radix-ui/react-accordion": "^1.1.2",
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 53d658a..d34951e 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -36,8 +36,8 @@ dependencies:
specifier: ^1.0.20
version: 1.0.20
'@dydxprotocol/v4-localization':
- specifier: ^1.1.34
- version: 1.1.34
+ specifier: ^1.1.35
+ version: 1.1.35
'@ethersproject/providers':
specifier: ^5.7.2
version: 5.7.2
@@ -1323,8 +1323,8 @@ packages:
- utf-8-validate
dev: false
- /@dydxprotocol/v4-localization@1.1.34:
- resolution: {integrity: sha512-I7zivjv8gS+6b9n7/wh7PY9QEUDIIyLx9ugZ5K6ybar0xT/06yupOVdVE6iLivQ/IAsVi/RFHkD8bQd0DWCetg==}
+ /@dydxprotocol/v4-localization@1.1.35:
+ resolution: {integrity: sha512-q5JFYoL/QanHXOtFqRa2owBZJibi1sMpSm3dAcxs9x0/xe8mo6fWcnbQfhl8k7g0/tv7PsBc+e3rbWD0EfvGiA==}
dev: false
/@dydxprotocol/v4-proto@4.0.0-dev.0:
diff --git a/src/constants/notifications.ts b/src/constants/notifications.ts
index b876815..e9af10f 100644
--- a/src/constants/notifications.ts
+++ b/src/constants/notifications.ts
@@ -5,6 +5,7 @@ export enum NotificationType {
AbacusGenerated = 'AbacusGenerated',
SquidTransfer = 'SquidTransfer',
ReleaseUpdates = 'ReleaseUpdates',
+ ChaosLabs = 'ChaosLabs',
}
export enum NotificationComponentType {}
diff --git a/src/hooks/useNotificationTypes.tsx b/src/hooks/useNotificationTypes.tsx
index 3063a84..c581bb1 100644
--- a/src/hooks/useNotificationTypes.tsx
+++ b/src/hooks/useNotificationTypes.tsx
@@ -5,7 +5,7 @@ import { isEqual, groupBy } from 'lodash';
import { useNavigate } from 'react-router-dom';
import { DialogTypes } from '@/constants/dialogs';
-import { AppRoute } from '@/constants/routes';
+import { AppRoute, TokenRoute } from '@/constants/routes';
import { DydxChainAsset } from '@/constants/wallets';
import {
@@ -22,7 +22,7 @@ import {
TransferNotificationTypes,
} from '@/constants/notifications';
-import { useStringGetter } from '@/hooks';
+import { useStringGetter, useTokenConfigs } from '@/hooks';
import { useLocalNotifications } from '@/hooks/useLocalNotifications';
import { AssetIcon } from '@/components/AssetIcon';
@@ -280,6 +280,43 @@ export const notificationTypes: NotificationTypeConfig[] = [
return () => {};
},
},
+ {
+ type: NotificationType.ChaosLabs,
+ useTrigger: ({ trigger }) => {
+ const stringGetter = useStringGetter();
+ const expirationDate = new Date('2024-03-08T23:59:59');
+ const currentDate = new Date();
+ useEffect(() => {
+ if (currentDate > expirationDate) return;
+ trigger(
+ 'chaos-labs-s3',
+ {
+ icon: ,
+ title: stringGetter({ key: 'NOTIFICATIONS.INCENTIVES_SEASON_BEGUN.TITLE' }),
+ body: stringGetter({
+ key: 'NOTIFICATIONS.INCENTIVES_SEASON_BEGUN.BODY',
+ params: {
+ SEASON_NUMBER: '3',
+ PREV_SEASON_NUMBER: '1',
+ DYDX_AMOUNT: '34',
+ USDC_AMOUNT: '100',
+ },
+ }),
+ toastSensitivity: 'foreground',
+ groupKey: NotificationType.ChaosLabs,
+ },
+ []
+ );
+ }, [stringGetter]);
+ },
+ useNotificationAction: () => {
+ const { chainTokenLabel } = useTokenConfigs();
+ const navigate = useNavigate();
+ return () => {
+ navigate(`${chainTokenLabel}/${TokenRoute.TradingRewards}`);
+ };
+ },
+ },
];
const $Icon = styled.img`
diff --git a/src/hooks/useNotifications.tsx b/src/hooks/useNotifications.tsx
index 863d0df..e24f43b 100644
--- a/src/hooks/useNotifications.tsx
+++ b/src/hooks/useNotifications.tsx
@@ -1,5 +1,6 @@
import { createContext, useCallback, useContext, useEffect, useMemo, useState } from 'react';
+import { AnalyticsEvent } from '@/constants/analytics';
import { LOCAL_STORAGE_VERSIONS, LocalStorageKey } from '@/constants/localStorage';
import {
type Notification,
@@ -13,6 +14,7 @@ import {
import { useLocalStorage } from './useLocalStorage';
import { notificationTypes } from './useNotificationTypes';
+import { track } from '@/lib/analytics';
import { renderSvgToDataUrl } from '../lib/renderSvgToDataUrl';
type NotificationsContextType = ReturnType;
@@ -82,6 +84,7 @@ const useNotificationsContext = () => {
[NotificationType.AbacusGenerated]: true,
[NotificationType.SquidTransfer]: true,
[NotificationType.ReleaseUpdates]: true,
+ [NotificationType.ChaosLabs]: true,
version: LOCAL_STORAGE_VERSIONS[LocalStorageKey.NotificationPreferences],
});
}
@@ -176,8 +179,10 @@ const useNotificationsContext = () => {
)
);
- const onNotificationAction = async (notification: Notification) =>
- await actions[notification.type]?.(notification.id);
+ const onNotificationAction = async (notification: Notification) => {
+ track(AnalyticsEvent.NotificationAction, { type: notification.type, id: notification.id });
+ return await actions[notification.type]?.(notification.id);
+ };
// Push notifications
const [hasEnabledPush, setHasEnabledPush] = useLocalStorage({