From 79ed0e3b769b4927a3ba9e1fb0fd495a54634104 Mon Sep 17 00:00:00 2001 From: Jeremy Lee <37092291+yogurtandjam@users.noreply.github.com> Date: Mon, 23 Sep 2024 11:07:39 -0400 Subject: [PATCH] feat: phantom noti + positioning (#1052) --- package.json | 2 +- pnpm-lock.yaml | 8 ++++---- src/constants/notifications.ts | 1 + src/hooks/useDisplayedWallets.ts | 14 +++++++++----- src/hooks/useNotificationTypes.tsx | 20 +++++++++++++++++++- 5 files changed, 34 insertions(+), 11 deletions(-) diff --git a/package.json b/package.json index 316f9786f..887f6b7e2 100644 --- a/package.json +++ b/package.json @@ -57,7 +57,7 @@ "@datadog/browser-logs": "^5.23.3", "@dydxprotocol/v4-abacus": "1.11.6", "@dydxprotocol/v4-client-js": "1.3.7", - "@dydxprotocol/v4-localization": "^1.1.200", + "@dydxprotocol/v4-localization": "^1.1.203", "@dydxprotocol/v4-proto": "^6.0.1", "@emotion/is-prop-valid": "^1.3.0", "@ethersproject/providers": "^5.7.2", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index b2d757179..af62ffe6b 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -39,8 +39,8 @@ dependencies: specifier: 1.3.7 version: 1.3.7 '@dydxprotocol/v4-localization': - specifier: ^1.1.200 - version: 1.1.200 + specifier: ^1.1.203 + version: 1.1.203 '@dydxprotocol/v4-proto': specifier: ^6.0.1 version: 6.0.1 @@ -3110,8 +3110,8 @@ packages: - utf-8-validate dev: false - /@dydxprotocol/v4-localization@1.1.200: - resolution: {integrity: sha512-JNMpoMigJTSLiyVmDWjpovQYg5P6HDNZzVUUJJG3RuSnpRiHq9dLActkW6+00IrwmE7lzMBc6NsaJKe4t1sAbA==} + /@dydxprotocol/v4-localization@1.1.203: + resolution: {integrity: sha512-U9l0gzM9A/MvzSVh0iy7yjqzdzuO+VVDakoPltgqTU6/b/0wDrjIJpuoxn8Tr2AKVx/ZkJdChGM8EiJwueaicA==} dev: false /@dydxprotocol/v4-proto@6.0.1: diff --git a/src/constants/notifications.ts b/src/constants/notifications.ts index fe97cc975..bf9eccf5a 100644 --- a/src/constants/notifications.ts +++ b/src/constants/notifications.ts @@ -229,6 +229,7 @@ export enum ReleaseUpdateNotificationIds { Twitter200BVolume = 'twitter-200b-volume', IncentivesS6Ended = 'incentives-s6-ended', KeplrSupport = 'keplr-support', + PhantomSupport = 'phantom-support', } // Incentives Season diff --git a/src/hooks/useDisplayedWallets.ts b/src/hooks/useDisplayedWallets.ts index 5dd43ad8c..2ce6eb341 100644 --- a/src/hooks/useDisplayedWallets.ts +++ b/src/hooks/useDisplayedWallets.ts @@ -51,6 +51,15 @@ export const useDisplayedWallets = (): WalletInfo[] => { }) as WalletInfo ); + // If Phantom wallet is detected, it must be in the 2nd slot. + // If there are no injected wallets, splice will just put it as the only item in the array. + if (phantomDetected) { + enabledInjectedWallets.splice(1, 0, { + connectorType: ConnectorType.PhantomSolana, + name: WalletType.Phantom, + }); + } + return [ // If the user does not have any injected wallets installed, show Metamask as the first option // with a download link since it the recommended wallet @@ -62,11 +71,6 @@ export const useDisplayedWallets = (): WalletInfo[] => { ...enabledInjectedWallets, - phantomDetected && { - connectorType: ConnectorType.PhantomSolana, - name: WalletType.Phantom, - }, - keplrEnabled && { connectorType: ConnectorType.Cosmos, name: CosmosWalletType.KEPLR, diff --git a/src/hooks/useNotificationTypes.tsx b/src/hooks/useNotificationTypes.tsx index 0bbd09866..9689eb409 100644 --- a/src/hooks/useNotificationTypes.tsx +++ b/src/hooks/useNotificationTypes.tsx @@ -35,7 +35,7 @@ import { DydxChainAsset } from '@/constants/wallets'; import { useLocalNotifications } from '@/hooks/useLocalNotifications'; -import { KeplrIcon } from '@/icons'; +import { KeplrIcon, PhantomIcon } from '@/icons'; import { AssetIcon } from '@/components/AssetIcon'; import { Icon, IconName } from '@/components/Icon'; @@ -369,6 +369,24 @@ export const notificationTypes: NotificationTypeConfig[] = [ [] ); } + + const phantomNotificationExpirationDate = new Date('2024-10-07T15:00:29.517926238Z'); + + if (currentDate < phantomNotificationExpirationDate) { + trigger( + ReleaseUpdateNotificationIds.PhantomSupport, + { + icon: , + title: stringGetter({ key: STRING_KEYS.PHANTOM_SUPPORT_TITLE }), + body: stringGetter({ + key: STRING_KEYS.PHANTOM_SUPPORT_BODY, + }), + toastSensitivity: 'foreground', + groupKey: ReleaseUpdateNotificationIds.KeplrSupport, + }, + [] + ); + } }, [stringGetter]); const { dydxAddress } = useAccounts();