Skip to content

Commit b18fcc0

Browse files
ci(release): publish latest release
1 parent 8f97706 commit b18fcc0

File tree

662 files changed

+10161
-9382
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

662 files changed

+10161
-9382
lines changed

.gitignore

-1
Original file line numberDiff line numberDiff line change
@@ -42,7 +42,6 @@ dist/out-tsc/*
4242

4343
# Locale backup/generated files
4444
packages/uniswap/src/i18n/locales/source/*_old.json
45-
packages/uniswap/src/i18n/locales/@types/resources.d.ts
4645

4746
# ci
4847
.ci-cache/

RELEASE

+55-7
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
IPFS hash of the deployment:
2-
- CIDv0: `QmdrE1xXozbrZCb5iS5iGpjWkdJh4y7iBGHqSC1rGPcH6i`
3-
- CIDv1: `bafybeihgolhp73f4twnioaonb2dvdyu2t44mxjdqx7pvnxfb7ibcosxcam`
2+
- CIDv0: `QmbKgKkW8gPc6Fc4CCbruxzdbgE968pGuSMwaFPPS57kdg`
3+
- CIDv1: `bafybeiga5awmbukdwmpf4jskzekpy76rzhk4blbqcmzvr745un6k6qulvm`
44

55
The latest release is always mirrored at [app.uniswap.org](https://app.uniswap.org).
66

@@ -10,15 +10,63 @@ You can also access the Uniswap Interface from an IPFS gateway.
1010
Your Uniswap settings are never remembered across different URLs.
1111

1212
IPFS gateways:
13-
- https://bafybeihgolhp73f4twnioaonb2dvdyu2t44mxjdqx7pvnxfb7ibcosxcam.ipfs.dweb.link/
14-
- https://bafybeihgolhp73f4twnioaonb2dvdyu2t44mxjdqx7pvnxfb7ibcosxcam.ipfs.cf-ipfs.com/
15-
- [ipfs://QmdrE1xXozbrZCb5iS5iGpjWkdJh4y7iBGHqSC1rGPcH6i/](ipfs://QmdrE1xXozbrZCb5iS5iGpjWkdJh4y7iBGHqSC1rGPcH6i/)
13+
- https://bafybeiga5awmbukdwmpf4jskzekpy76rzhk4blbqcmzvr745un6k6qulvm.ipfs.dweb.link/
14+
- https://bafybeiga5awmbukdwmpf4jskzekpy76rzhk4blbqcmzvr745un6k6qulvm.ipfs.cf-ipfs.com/
15+
- [ipfs://QmbKgKkW8gPc6Fc4CCbruxzdbgE968pGuSMwaFPPS57kdg/](ipfs://QmbKgKkW8gPc6Fc4CCbruxzdbgE968pGuSMwaFPPS57kdg/)
1616

17-
### 5.50.4 (2024-10-10)
17+
## 5.51.0 (2024-10-10)
18+
19+
20+
### Features
21+
22+
* **web:** add network costs to the addliquidity modal (#12557) 9beb5ce
23+
* **web:** add steps to the modal (#12431) 65639b4
24+
* **web:** add support for permit (#12575) b9d9579
25+
* **web:** add testnet modal (#12636) 350d97e
26+
* **web:** adding create modal (#12441) 3150f48
27+
* **web:** balance fetch switch on testnet mode (#12576) dfa44bd
28+
* **web:** call TradingAPI claim fees endpoint for v3/v4 (#12444) 8acafa7
29+
* **web:** deposit tokens step (#12377) 4c747d8
30+
* **web:** disable testnet on disconnect (#12750) 9f0bdbb
31+
* **web:** disable tx flows on explore pages (#12656) 6ed0b42
32+
* **web:** enable testnet mode on web with flag (#12505) dd7f272
33+
* **web:** hook up LP saga + confirm steps to the decrease flow (#12508) 3f0ff49
34+
* **web:** integrate with trading API for create flow (v2,v3) (#12434) 7283d2e
35+
* **web:** loading state for new PosDP (#12634) 688ea88
36+
* **web:** LP migrate page - update query and loading state (#12652) 88b336e
37+
* **web:** positions pagination and claim fees modal (#12341) 5f1eba2
38+
* **web:** testnet mode (#12566) abe823d
39+
* **web:** testnet portfolio row (#12616) ae5e5f5
40+
* **web:** unichain intro modal (#12554) 16fdb94
41+
* **web:** use single position query for PosDP (#12517) e242d90
42+
* **web:** use universe currency logo for testnets (#12607) d0767bd
43+
* **web:** use v3 uncollected fee values from Data API (#12555) 2a376be
44+
* **web:** v4 create position v2 (#12419) be27df2
45+
* **web:** v4 price range charts (#12525) cf9f515
1846

1947

2048
### Bug Fixes
2149

22-
* **web:** pass account to getSigner instead of using default [prod] (#12883) 688582d
50+
* **web:** 10 08 fix web log step and original error on web staging (#12825) c895745
51+
* **web:** add requestId and quoteId to post /order request (#12612) e08233f
52+
* **web:** astro chain ui info (#12671) 6923e48
53+
* **web:** default to crypto in send when on testnet (#12758) 5839f86
54+
* **web:** dont respect url flag overrides on prod (#12545) 3a68877
55+
* **web:** fix tick formatting + position details page (#12648) b606211
56+
* **web:** fixing v4 create bugs (#12514) 9da665d
57+
* **web:** hide gas for testnet unichain eth (#12759) 2dfd2d5
58+
* **web:** invalidate local activity cache for updates to transaction or signature state (#12650) f119f63
59+
* **web:** move connected wallet chain logic to universe (#12717) 5f78d74
60+
* **web:** native currency logo fetching on web (#12387) 81eb2ac
61+
* **web:** pass account to getSigner instead of using default [staging] (#12884) a11364b
62+
* **web:** rm prod arb+eth quicknode urls (#12646) d36d711
63+
* **web:** simplify/combine the liquidity saga logic (#12540) 5b72b61
64+
* **web:** ui nits and bugs (#12718) 6330bd4
65+
* **web:** uniswapx toasts/polling (#12658) 53dc7b1
66+
67+
68+
### Continuous Integration
69+
70+
* **web:** update sitemaps 82367d7
2371

2472

VERSION

+1-1
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
web/5.50.4
1+
web/5.51.0

apps/extension/package.json

+4-3
Original file line numberDiff line numberDiff line change
@@ -13,10 +13,11 @@
1313
"@svgr/webpack": "8.0.1",
1414
"@tamagui/core": "1.108.4",
1515
"@types/uuid": "9.0.1",
16-
"@uniswap/analytics-events": "2.37.0",
16+
"@uniswap/analytics-events": "2.38.0",
1717
"@uniswap/uniswapx-sdk": "^2.1.0-beta.14",
18-
"@uniswap/universal-router-sdk": "2.2.0",
19-
"@uniswap/v3-sdk": "3.14.0",
18+
"@uniswap/universal-router-sdk": "4.2.0",
19+
"@uniswap/v3-sdk": "3.17.0",
20+
"@uniswap/v4-sdk": "1.10.0",
2021
"dotenv-webpack": "8.0.1",
2122
"ethers": "5.7.2",
2223
"eventemitter3": "5.0.1",

apps/extension/src/app/PopupApp.tsx

+2
Original file line numberDiff line numberDiff line change
@@ -27,6 +27,7 @@ import i18n from 'uniswap/src/i18n/i18n'
2727
import { ExtensionScreens } from 'uniswap/src/types/screens/extension'
2828
import { logger } from 'utilities/src/logger/logger'
2929
import { ErrorBoundary } from 'wallet/src/components/ErrorBoundary/ErrorBoundary'
30+
import { useTestnetModeForLoggingAndAnalytics } from 'wallet/src/features/testnetMode/hooks'
3031
import { SharedWalletProvider } from 'wallet/src/providers/SharedWalletProvider'
3132

3233
getLocalUserId()
@@ -54,6 +55,7 @@ function PopupContent(): JSX.Element {
5455
useEffect(() => {
5556
dispatch(syncAppWithDeviceLanguage())
5657
}, [dispatch])
58+
useTestnetModeForLoggingAndAnalytics()
5759

5860
const searchParams = new URLSearchParams(window.location.search)
5961
const tabId = searchParams.get('tabId')

apps/extension/src/app/SidebarApp.tsx

+2
Original file line numberDiff line numberDiff line change
@@ -51,6 +51,7 @@ import { logger } from 'utilities/src/logger/logger'
5151
import { ONE_SECOND_MS } from 'utilities/src/time/time'
5252
import { useInterval } from 'utilities/src/time/timing'
5353
import { ErrorBoundary } from 'wallet/src/components/ErrorBoundary/ErrorBoundary'
54+
import { useTestnetModeForLoggingAndAnalytics } from 'wallet/src/features/testnetMode/hooks'
5455
import { SharedWalletProvider } from 'wallet/src/providers/SharedWalletProvider'
5556

5657
getLocalUserId()
@@ -202,6 +203,7 @@ function useDappRequestPortListener(): void {
202203
function SidebarWrapper(): JSX.Element {
203204
const dispatch = useDispatch()
204205
useDappRequestPortListener()
206+
useTestnetModeForLoggingAndAnalytics()
205207

206208
useEffect(() => {
207209
dispatch(syncAppWithDeviceLanguage())

apps/extension/src/app/UnitagClaimApp.tsx

+2
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,7 @@ import { UnitagUpdaterContextProvider } from 'uniswap/src/features/unitags/conte
2626
import i18n from 'uniswap/src/i18n/i18n'
2727
import { logger } from 'utilities/src/logger/logger'
2828
import { ErrorBoundary } from 'wallet/src/components/ErrorBoundary/ErrorBoundary'
29+
import { useTestnetModeForLoggingAndAnalytics } from 'wallet/src/features/testnetMode/hooks'
2930
import { SharedWalletProvider } from 'wallet/src/providers/SharedWalletProvider'
3031

3132
getLocalUserId()
@@ -58,6 +59,7 @@ router.subscribe((state) => {
5859
setRouter(router)
5960

6061
function UnitagClaimAppInner(): JSX.Element {
62+
useTestnetModeForLoggingAndAnalytics()
6163
return (
6264
<Flex alignItems="center" justifyContent="center" minHeight="100vh" width="100%">
6365
<OnboardingStepsProvider

apps/extension/src/app/features/dapp/DappContext.tsx

+2-2
Original file line numberDiff line numberDiff line change
@@ -8,14 +8,14 @@ import { extractBaseUrl } from 'src/app/features/dappRequests/utils'
88
import { closePopup, PopupName } from 'src/app/features/popups/slice'
99
import { backgroundToSidePanelMessageChannel } from 'src/background/messagePassing/messageChannels'
1010
import { BackgroundToSidePanelRequestType } from 'src/background/messagePassing/types/requests'
11-
import { WalletChainId } from 'uniswap/src/types/chains'
11+
import { UniverseChainId } from 'uniswap/src/types/chains'
1212
import { useActiveAccountAddress } from 'wallet/src/features/wallet/hooks'
1313

1414
type DappContextState = {
1515
dappUrl: string
1616
dappIconUrl?: string
1717
isConnected: boolean
18-
lastChainId?: WalletChainId
18+
lastChainId?: UniverseChainId
1919
}
2020

2121
const DappContext = createContext<DappContextState | undefined>(undefined)

apps/extension/src/app/features/dapp/actions.ts

+2-2
Original file line numberDiff line numberDiff line change
@@ -7,11 +7,11 @@ import {
77
UpdateConnectionRequest,
88
} from 'src/background/messagePassing/types/requests'
99
import { chainIdToHexadecimalString } from 'uniswap/src/features/chains/utils'
10-
import { WalletChainId } from 'uniswap/src/types/chains'
10+
import { UniverseChainId } from 'uniswap/src/types/chains'
1111
import { Account } from 'wallet/src/features/wallet/accounts/types'
1212
import { getProviderSync } from 'wallet/src/features/wallet/context'
1313

14-
export async function saveDappChain(dappUrl: string, chainId: WalletChainId): Promise<void> {
14+
export async function saveDappChain(dappUrl: string, chainId: UniverseChainId): Promise<void> {
1515
dappStore.updateDappLatestChainId(dappUrl, chainId)
1616
const provider = getProviderSync(chainId)
1717

apps/extension/src/app/features/dapp/changeChain.test.ts

+2-2
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ import { DappResponseType } from 'src/app/features/dappRequests/types/DappReques
66
import { chainIdToHexadecimalString } from 'uniswap/src/features/chains/utils'
77
import { ExtensionEventName } from 'uniswap/src/features/telemetry/constants'
88
import { sendAnalyticsEvent } from 'uniswap/src/features/telemetry/send'
9-
import { WalletChainId } from 'uniswap/src/types/chains'
9+
import { UniverseChainId } from 'uniswap/src/types/chains'
1010

1111
// Mock dependencies
1212
jest.mock('@ethersproject/providers')
@@ -18,7 +18,7 @@ jest.mock('uniswap/src/features/chains/utils')
1818
describe('changeChain', () => {
1919
const mockRequestId = 'test-request-id'
2020
const mockProviderUrl = 'http://localhost:8545'
21-
const mockChainId = 1 as WalletChainId
21+
const mockChainId = 1 as UniverseChainId
2222

2323
let mockProvider: JsonRpcProvider
2424

apps/extension/src/app/features/dapp/changeChain.ts

+2-2
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ import {
99
import { chainIdToHexadecimalString } from 'uniswap/src/features/chains/utils'
1010
import { ExtensionEventName } from 'uniswap/src/features/telemetry/constants'
1111
import { sendAnalyticsEvent } from 'uniswap/src/features/telemetry/send'
12-
import { WalletChainId } from 'uniswap/src/types/chains'
12+
import { UniverseChainId } from 'uniswap/src/types/chains'
1313

1414
export function changeChain({
1515
activeConnectedAddress,
@@ -22,7 +22,7 @@ export function changeChain({
2222
dappUrl: string | undefined
2323
provider: JsonRpcProvider | undefined | null
2424
requestId: string
25-
updatedChainId: WalletChainId | null
25+
updatedChainId: UniverseChainId | null
2626
}): ChangeChainResponse | ErrorResponse {
2727
if (!updatedChainId) {
2828
return {

apps/extension/src/app/features/dapp/hooks.ts

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
import { useEffect, useReducer, useState } from 'react'
22
import { DappInfo, DappStoreEvent, dappStore } from 'src/app/features/dapp/store'
3-
import { WalletChainId } from 'uniswap/src/types/chains'
3+
import { UniverseChainId } from 'uniswap/src/types/chains'
44
import { Account } from 'wallet/src/features/wallet/accounts/types'
55
import { useActiveAccountAddress } from 'wallet/src/features/wallet/hooks'
66

@@ -26,7 +26,7 @@ export function useDappInfo(dappUrl: string | undefined): DappInfo | undefined {
2626
return info
2727
}
2828

29-
export function useDappLastChainId(dappUrl: string | undefined): WalletChainId | undefined {
29+
export function useDappLastChainId(dappUrl: string | undefined): UniverseChainId | undefined {
3030
return useDappInfo(dappUrl)?.lastChainId
3131
}
3232

apps/extension/src/app/features/dapp/store.ts

+4-3
Original file line numberDiff line numberDiff line change
@@ -1,13 +1,13 @@
11
import { cloneDeep } from '@apollo/client/utilities'
22
import EventEmitter from 'eventemitter3'
33
import { getOrderedConnectedAddresses, isConnectedAccount } from 'src/app/features/dapp/utils'
4-
import { UniverseChainId, WalletChainId } from 'uniswap/src/types/chains'
4+
import { UniverseChainId } from 'uniswap/src/types/chains'
55
import { Account } from 'wallet/src/features/wallet/accounts/types'
66

77
const STATE_STORAGE_KEY = 'dappState'
88

99
export interface DappInfo {
10-
lastChainId: WalletChainId
10+
lastChainId: UniverseChainId
1111
connectedAccounts: Account[]
1212
activeConnectedAddress: Address
1313
iconUrl?: string
@@ -153,7 +153,7 @@ function updateDappIconUrl(dappUrl: string, newIconUrl?: string): void {
153153
}
154154

155155
// TODO(WALL-4643): if we migrate to immer, let's avoid iterating over the the object here
156-
function updateDappLatestChainId(dappUrl: string, chainId: WalletChainId): void {
156+
function updateDappLatestChainId(dappUrl: string, chainId: UniverseChainId): void {
157157
// Never directly mutate state, as some of its fields could have `writable: false`
158158
state = Object.fromEntries(
159159
Object.entries(state).map(([key, dappUrlState]) => {
@@ -172,6 +172,7 @@ function saveDappActiveAccount(dappUrl: string, account: Account, initialPropert
172172
...state,
173173
[dappUrl]: {
174174
...state[dappUrl],
175+
// TODO: WALL-4919: Remove hardcoded Mainnet
175176
lastChainId: state[dappUrl]?.lastChainId ?? UniverseChainId.Mainnet,
176177
activeConnectedAddress: account.address,
177178
connectedAccounts: ((): Account[] => {

apps/extension/src/app/features/dappRequests/DappRequestContent.tsx

+8-9
Original file line numberDiff line numberDiff line change
@@ -2,16 +2,16 @@ import { PropsWithChildren, useCallback } from 'react'
22
import { useTranslation } from 'react-i18next'
33
import { useDappLastChainId } from 'src/app/features/dapp/hooks'
44
import { useDappRequestQueueContext } from 'src/app/features/dappRequests/DappRequestQueueContext'
5-
import { NetworksFooter } from 'src/app/features/dappRequests/requestContent/NetworksFooter'
65
import { DappRequestStoreItem } from 'src/app/features/dappRequests/slice'
76
import { Anchor, AnimatePresence, Button, Flex, Text, UniversalImage, UniversalImageResizeMode, styled } from 'ui/src'
87
import { borderRadii, iconSizes } from 'ui/src/theme'
9-
import { useUSDValue } from 'uniswap/src/features/gas/hooks'
8+
import { useUSDValueOfGasFee } from 'uniswap/src/features/gas/hooks'
109
import { GasFeeResult } from 'uniswap/src/features/gas/types'
1110
import { hasSufficientFundsIncludingGas } from 'uniswap/src/features/gas/utils'
1211
import { useOnChainNativeCurrencyBalance } from 'uniswap/src/features/portfolio/api'
12+
import { useEnabledChains } from 'uniswap/src/features/settings/hooks'
1313
import { TransactionTypeInfo } from 'uniswap/src/features/transactions/types/transactionDetails'
14-
import { UniverseChainId, WalletChainId } from 'uniswap/src/types/chains'
14+
import { UniverseChainId } from 'uniswap/src/types/chains'
1515
import { extractNameFromUrl } from 'utilities/src/format/extractNameFromUrl'
1616
import { formatDappURL } from 'utilities/src/format/urls'
1717
import { logger } from 'utilities/src/logger/logger'
@@ -26,7 +26,7 @@ interface DappRequestHeaderProps {
2626
}
2727

2828
interface DappRequestFooterProps {
29-
chainId?: WalletChainId
29+
chainId?: UniverseChainId
3030
connectedAccountAddress?: string
3131
confirmText: string
3232
maybeCloseOnConfirm?: boolean
@@ -150,13 +150,13 @@ export function DappRequestFooter({
150150
maybeCloseOnConfirm,
151151
onCancel,
152152
onConfirm,
153-
showAllNetworks,
154153
showNetworkCost,
155154
transactionGasFeeResult,
156155
isUniswapX,
157156
}: DappRequestFooterProps): JSX.Element {
158157
const { t } = useTranslation()
159158
const activeAccount = useActiveAccountWithThrow()
159+
const { defaultChainId } = useEnabledChains()
160160
const {
161161
dappUrl,
162162
currentAccount,
@@ -174,8 +174,8 @@ export function DappRequestFooter({
174174
throw error
175175
}
176176

177-
const currentChainId = chainId || activeChain || UniverseChainId.Mainnet
178-
const gasFeeUSD = useUSDValue(currentChainId, transactionGasFeeResult?.value)
177+
const currentChainId = chainId || activeChain || defaultChainId
178+
const { value: gasFeeUSD } = useUSDValueOfGasFee(currentChainId, transactionGasFeeResult?.value)
179179
const { balance: nativeBalance } = useOnChainNativeCurrencyBalance(currentChainId, currentAccount.address)
180180

181181
const hasSufficientGas = hasSufficientFundsIncludingGas({
@@ -225,12 +225,11 @@ export function DappRequestFooter({
225225
{showNetworkCost && (
226226
<NetworkFeeFooter
227227
chainId={currentChainId}
228-
gasFeeUSD={transactionGasFeeResult ? gasFeeUSD : '0'}
228+
gasFee={transactionGasFeeResult}
229229
isUniswapX={isUniswapX}
230230
showNetworkLogo={!!transactionGasFeeResult}
231231
/>
232232
)}
233-
{showAllNetworks && <NetworksFooter />}
234233
<AddressFooter
235234
activeAccountAddress={activeAccount.address}
236235
connectedAccountAddress={connectedAccountAddress || currentAccount.address}

apps/extension/src/app/features/dappRequests/accounts.ts

+6-4
Original file line numberDiff line numberDiff line change
@@ -17,16 +17,17 @@ import { extractBaseUrl } from 'src/app/features/dappRequests/utils'
1717
import { dappResponseMessageChannel } from 'src/background/messagePassing/messageChannels'
1818
import { call, put, select } from 'typed-redux-saga'
1919
import { chainIdToHexadecimalString } from 'uniswap/src/features/chains/utils'
20+
import { getEnabledChainIdsSaga } from 'uniswap/src/features/settings/saga'
2021
import { ExtensionEventName } from 'uniswap/src/features/telemetry/constants'
2122
import { sendAnalyticsEvent } from 'uniswap/src/features/telemetry/send'
22-
import { UniverseChainId, WalletChainId } from 'uniswap/src/types/chains'
23+
import { UniverseChainId } from 'uniswap/src/types/chains'
2324
import { pushNotification } from 'wallet/src/features/notifications/slice'
2425
import { AppNotificationType } from 'wallet/src/features/notifications/types'
2526
import { getProvider } from 'wallet/src/features/wallet/context'
2627
import { selectActiveAccount } from 'wallet/src/features/wallet/selectors'
2728

2829
function getAccountResponse(
29-
chainId: WalletChainId,
30+
chainId: UniverseChainId,
3031
dappRequest: DappRequest,
3132
provider: JsonRpcProvider,
3233
dappInfo: DappInfo,
@@ -47,7 +48,7 @@ function getAccountResponse(
4748

4849
function sendAccountResponseAnalyticsEvent(
4950
senderUrl: string,
50-
chainId: WalletChainId,
51+
chainId: UniverseChainId,
5152
dappInfo: DappInfo,
5253
accountResponse: AccountResponse,
5354
): void {
@@ -86,6 +87,7 @@ export function* saveAccount({ url, favIconUrl }: SenderTabInfo) {
8687
const activeAccount = yield* select(selectActiveAccount)
8788
const dappUrl = extractBaseUrl(url)
8889
const dappInfo = yield* call(dappStore.getDappInfo, dappUrl)
90+
const { defaultChainId } = yield* call(getEnabledChainIdsSaga)
8991

9092
if (!dappUrl || !activeAccount) {
9193
return undefined
@@ -102,7 +104,7 @@ export function* saveAccount({ url, favIconUrl }: SenderTabInfo) {
102104
)
103105
}
104106

105-
const chainId = dappInfo?.lastChainId ?? UniverseChainId.Mainnet
107+
const chainId = dappInfo?.lastChainId ?? defaultChainId
106108
const provider = yield* call(getProvider, chainId)
107109
const connectedAddresses = (dappUrl && (yield* call(dappStore.getDappOrderedConnectedAddresses, dappUrl))) || []
108110

0 commit comments

Comments
 (0)