Skip to content

Commit aad7fb3

Browse files
ci(release): publish latest release
1 parent 29c499f commit aad7fb3

File tree

867 files changed

+31622
-10623
lines changed

Some content is hidden

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

867 files changed

+31622
-10623
lines changed

CODEOWNERS

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
* @uniswap/web-admins

RELEASE

+69-7
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,72 @@
1-
We are back with some new updates! Here’s the latest:
1+
IPFS hash of the deployment:
2+
- CIDv0: `QmNhWv1wsYtTeENpAN7Niquy4TMJ6JzEh8ZZqPGCoeYcGH`
3+
- CIDv1: `bafybeiaflbrdbl3olcods3uy3feg64eaepg736m7aoiwuw3ctsyla36iri`
24

3-
Report Spam NFTs - You can now report spam NFTs and hide them from your feed and activity.
5+
The latest release is always mirrored at [app.uniswap.org](https://app.uniswap.org).
6+
7+
You can also access the Uniswap Interface from an IPFS gateway.
8+
**BEWARE**: The Uniswap interface uses [`localStorage`](https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage) to remember your settings, such as which tokens you have imported.
9+
**You should always use an IPFS gateway that enforces origin separation**, or our hosted deployment of the latest release at [app.uniswap.org](https://app.uniswap.org).
10+
Your Uniswap settings are never remembered across different URLs.
11+
12+
IPFS gateways:
13+
- https://bafybeiaflbrdbl3olcods3uy3feg64eaepg736m7aoiwuw3ctsyla36iri.ipfs.dweb.link/
14+
- https://bafybeiaflbrdbl3olcods3uy3feg64eaepg736m7aoiwuw3ctsyla36iri.ipfs.cf-ipfs.com/
15+
- [ipfs://QmNhWv1wsYtTeENpAN7Niquy4TMJ6JzEh8ZZqPGCoeYcGH/](ipfs://QmNhWv1wsYtTeENpAN7Niquy4TMJ6JzEh8ZZqPGCoeYcGH/)
16+
17+
## 5.50.0 (2024-10-04)
18+
19+
20+
### Features
21+
22+
* **web:** add the review screen modal to the add liquidity flow (#12210) a43a6cd
23+
* **web:** avoid duplicate swap steps upon closing/reopening review modal (#12232) 7613047
24+
* **web:** call Trading API for increase/decrease/create LP actions (#12280) b563835
25+
* **web:** generate steps for increasing position (#12339) 08fddec
26+
* **web:** handle swap saga cancellation / interruption (#12115) e78fe1f
27+
* **web:** move routing diagram to uniswap (#12244) 7cc63c4
28+
* **web:** move web swap settings to popover (#12118) 0be1d91
29+
* **web:** setting up backend for create position range (#12193) 0ddb961
30+
* **web:** single swap step UI state (#12410) 6132c6c
31+
* **web:** step-specific swap review button text (#12117) 1327c62
32+
* **web:** swap detail line items (#12169) 1eb5c93
33+
* **web:** universal swap bridge link banners + across bridging promo banner (#12378) d3d2641
34+
* **web:** v2 position details data (#12216) 67f8087
35+
* **web:** v3 position detail page API integration (#12217) 4328bdf
36+
* **web:** v4 PosDP improvements (#12255) 83e7a77
37+
38+
39+
### Bug Fixes
40+
41+
* **web:** add requestId and quoteId to post /order request (#12614) 562361b
42+
* **web:** deadline input field focus (#12405) 9ace591
43+
* **web:** disabled button states (#12509) 0dc3f11
44+
* **web:** disallow non numerical input on deadline (#12265) 36d1d33
45+
* **web:** dont respect url flag overrides on prod - staging (#12549) 69f3780
46+
* **web:** fix token warnings on URL query prefill (#12329) e951732
47+
* **web:** Fix/top tokens cache staging (#12570) 70ac444
48+
* **web:** only clear amount input on swap success in shared flow (#12231) 1f28931
49+
* **web:** priority orders only enabled on base (#12437) 4902650
50+
* **web:** remove hardcoded web saga var (#12520) 8d87977
51+
* **web:** reset inputs after trade, no rogue data (#12335) b2a2710
52+
* **web:** rm prod arb+eth quicknode urls [staging] (#12647) 9d2d765
53+
* **web:** segmented control flashing and off by 1px (#12319) 2d88b56
54+
* **web:** suggested tokens height (#12454) 64ffee3
55+
* **web:** swap review screen ux/ui fixes (#12267) b76218d
56+
* **web:** swap tabs from pathname (#12126) 1c25507
57+
* **web:** swap UI nits (#12448) 3777948
58+
* **web:** swap warning tooltip width (#12125) 89130ab
59+
* **web:** switch chain in wrap saga (#12263) 7f81f76
60+
* **web:** testlio polish - limit form button color + hidden header should not prevent clicks (#12413) 4bb70f9
61+
* **web:** ui fixes part 1 (#12279) 8b3abdc
62+
* **web:** uniswapx toasts/polling [staging] (#12659) 7a14094
63+
* **web:** universal swap flow on tdp and pdp (#12257) c296cd1
64+
* **web:** update simulation param for async swap step (#12490) 06dc81d
65+
* **web:** use proper arb+eth urls [staging] (#12674) dd4b6b5
66+
67+
68+
### Continuous Integration
69+
70+
* **web:** update sitemaps 1f57186
471

5-
Other changes:
672

7-
- Added explainers for hidden tokens, popular tokens, and hidden NFTs
8-
- Removed activity feed items related to any hidden NFTs
9-
- More optimized keyboard functionality across the app
10-
- Various bug fixes and performance improvements

VERSION

+1-1
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
mobile/1.36
1+
web/5.50.0

apps/extension/jest-setup.js

+3
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@ import { AppearanceSettingType } from 'wallet/src/features/appearance/slice'
55
import { TextEncoder, TextDecoder } from 'util'
66
import { mockSharedPersistQueryClientProvider } from 'uniswap/src/test/mocks/mockSharedPersistQueryClientProvider'
77
import { mockUIAssets } from 'ui/src/test/mocks/mockUIAssets'
8+
import { mockLocalizationContext } from 'uniswap/src/test/mocks/locale'
89

910
process.env.IS_UNISWAP_EXTENSION = true
1011

@@ -72,6 +73,8 @@ jest.mock('wallet/src/features/appearance/hooks', () => {
7273
}
7374
})
7475

76+
jest.mock('uniswap/src/features/language/LocalizationContext', () => mockLocalizationContext({}))
77+
7578
jest.mock('uniswap/src/data/apiClients/SharedPersistQueryClientProvider', () => mockSharedPersistQueryClientProvider)
7679

7780
mockUIAssets()

apps/extension/package.json

+4-4
Original file line numberDiff line numberDiff line change
@@ -13,8 +13,8 @@
1313
"@svgr/webpack": "8.0.1",
1414
"@tamagui/core": "1.108.4",
1515
"@types/uuid": "9.0.1",
16-
"@uniswap/analytics-events": "2.36.0",
17-
"@uniswap/uniswapx-sdk": "^2.1.0-beta.8",
16+
"@uniswap/analytics-events": "2.37.0",
17+
"@uniswap/uniswapx-sdk": "^2.1.0-beta.14",
1818
"@uniswap/universal-router-sdk": "2.2.0",
1919
"@uniswap/v3-sdk": "3.14.0",
2020
"dotenv-webpack": "8.0.1",
@@ -26,7 +26,7 @@
2626
"react-dom": "18.2.0",
2727
"react-i18next": "14.1.0",
2828
"react-native": "0.73.6",
29-
"react-native-gesture-handler": "2.15.0",
29+
"react-native-gesture-handler": "2.19.0",
3030
"react-native-reanimated": "3.15.0",
3131
"react-native-svg": "15.1.0",
3232
"react-native-web": "0.19.10",
@@ -84,7 +84,7 @@
8484
"private": true,
8585
"scripts": {
8686
"build:production": "webpack --node-env=production --env BUILD_ENV=prod BUILD_NUM=${BUILD_NUM:-0}",
87-
"check:circular": "concurrently \"../../scripts/check-circular-imports.sh ./src/sidebar/sidebar.tsx 1\" \"../../scripts/check-circular-imports.sh ./src/onboarding/onboarding.tsx 1\"",
87+
"check:circular": "concurrently \"../../scripts/check-circular-imports.sh ./src/entry/sidebar.tsx 1\" \"../../scripts/check-circular-imports.sh ./src/entry/onboarding.tsx 1\" \"../../scripts/check-circular-imports.sh ./src/entry/unitagClaim.tsx 1\"",
8888
"check:deps:usage": "depcheck",
8989
"env:local:download": "bash ../../scripts/downloadEnvLocal.sh web-local-envs ../../.env",
9090
"env:local:upload": "bash ../../scripts/uploadEnvLocal.sh web-local-envs ../../.env",

apps/extension/src/app/OnboardingApp.tsx

+16-6
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,7 @@ import { PersistGate } from 'redux-persist/integration/react'
99
import { ExtensionStatsigProvider } from 'src/app/StatsigProvider'
1010
import { GraphqlProvider } from 'src/app/apollo'
1111
import { ErrorElement } from 'src/app/components/ErrorElement'
12+
import { ClaimUnitagScreen } from 'src/app/features/onboarding/ClaimUnitagScreen'
1213
import { Complete } from 'src/app/features/onboarding/Complete'
1314
import {
1415
CreateOnboardingSteps,
@@ -55,6 +56,14 @@ const unsupportedRoute: RouteObject = {
5556
element: <UnsupportedBrowserScreen />,
5657
}
5758

59+
const createSteps = {
60+
[CreateOnboardingSteps.Password]: <PasswordCreate />,
61+
[CreateOnboardingSteps.ViewMnemonic]: <ViewMnemonic />,
62+
[CreateOnboardingSteps.TestMnemonic]: <TestMnemonic />,
63+
[CreateOnboardingSteps.Naming]: <NameWallet />,
64+
[CreateOnboardingSteps.Complete]: <Complete flow={ExtensionOnboardingFlow.New} />,
65+
}
66+
5867
const allRoutes = [
5968
{
6069
path: '',
@@ -66,15 +75,16 @@ const allRoutes = [
6675
},
6776
{
6877
path: OnboardingRoutes.Create,
78+
element: <OnboardingStepsProvider key={OnboardingRoutes.Create} steps={createSteps} />,
79+
},
80+
{
81+
path: OnboardingRoutes.Claim,
6982
element: (
7083
<OnboardingStepsProvider
71-
key={OnboardingRoutes.Create}
84+
key={OnboardingRoutes.Claim}
7285
steps={{
73-
[CreateOnboardingSteps.Password]: <PasswordCreate />,
74-
[CreateOnboardingSteps.ViewMnemonic]: <ViewMnemonic />,
75-
[CreateOnboardingSteps.TestMnemonic]: <TestMnemonic />,
76-
[CreateOnboardingSteps.Naming]: <NameWallet />,
77-
[CreateOnboardingSteps.Complete]: <Complete flow={ExtensionOnboardingFlow.New} />,
86+
[CreateOnboardingSteps.ClaimUnitag]: <ClaimUnitagScreen />,
87+
...createSteps,
7888
}}
7989
/>
8090
),
+106
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,106 @@
1+
import '@tamagui/core/reset.css'
2+
import 'src/app/Global.css'
3+
4+
import { useEffect } from 'react'
5+
import { I18nextProvider } from 'react-i18next'
6+
import { Outlet, RouterProvider } from 'react-router-dom'
7+
import { PersistGate } from 'redux-persist/integration/react'
8+
import { ExtensionStatsigProvider } from 'src/app/StatsigProvider'
9+
import { GraphqlProvider } from 'src/app/apollo'
10+
import { ErrorElement } from 'src/app/components/ErrorElement'
11+
import { TraceUserProperties } from 'src/app/components/Trace/TraceUserProperties'
12+
import { ClaimUnitagSteps, OnboardingStepsProvider } from 'src/app/features/onboarding/OnboardingSteps'
13+
import { UnitagChooseProfilePicScreen } from 'src/app/features/unitags/UnitagChooseProfilePicScreen'
14+
import { UnitagClaimContextProvider } from 'src/app/features/unitags/UnitagClaimContext'
15+
import { UnitagCreateUsernameScreen } from 'src/app/features/unitags/UnitagCreateUsernameScreen'
16+
import { UnitagIntroScreen } from 'src/app/features/unitags/UnitagIntroScreen'
17+
import { setRouter, setRouterState } from 'src/app/navigation/state'
18+
import { SentryAppNameTag, initializeSentry, sentryCreateHashRouter } from 'src/app/sentry'
19+
import { initExtensionAnalytics } from 'src/app/utils/analytics'
20+
import { getLocalUserId } from 'src/app/utils/storage'
21+
import { getReduxPersistor, getReduxStore } from 'src/store/store'
22+
import { Flex } from 'ui/src'
23+
import { LocalizationContextProvider } from 'uniswap/src/features/language/LocalizationContext'
24+
import Trace from 'uniswap/src/features/telemetry/Trace'
25+
import { UnitagUpdaterContextProvider } from 'uniswap/src/features/unitags/context'
26+
import i18n from 'uniswap/src/i18n/i18n'
27+
import { logger } from 'utilities/src/logger/logger'
28+
import { ErrorBoundary } from 'wallet/src/components/ErrorBoundary/ErrorBoundary'
29+
import { SharedWalletProvider } from 'wallet/src/providers/SharedWalletProvider'
30+
31+
getLocalUserId()
32+
.then((userId) => {
33+
initializeSentry(SentryAppNameTag.UnitagClaim, userId)
34+
})
35+
.catch((error) => {
36+
logger.error(error, {
37+
tags: { file: 'UnitagClaimApp.tsx', function: 'getLocalUserId' },
38+
})
39+
})
40+
41+
const router = sentryCreateHashRouter([
42+
{
43+
path: '',
44+
element: <UnitagClaimAppInner />,
45+
errorElement: <ErrorElement />,
46+
},
47+
])
48+
49+
/**
50+
* Note: we are using a pattern here to avoid circular dependencies, because
51+
* this is the root of the app and it imports all sub-pages, we need to push the
52+
* router/router state to a different file so it can be imported by those pages
53+
*/
54+
router.subscribe((state) => {
55+
setRouterState(state)
56+
})
57+
58+
setRouter(router)
59+
60+
function UnitagClaimAppInner(): JSX.Element {
61+
return (
62+
<Flex alignItems="center" justifyContent="center" minHeight="100vh" width="100%">
63+
<OnboardingStepsProvider
64+
disableRedirect
65+
steps={{
66+
[ClaimUnitagSteps.Intro]: <UnitagIntroScreen />,
67+
[ClaimUnitagSteps.CreateUsername]: <UnitagCreateUsernameScreen />,
68+
[ClaimUnitagSteps.ChooseProfilePic]: <UnitagChooseProfilePicScreen />,
69+
}}
70+
ContainerComponent={UnitagClaimContextProvider}
71+
/>
72+
<Outlet />
73+
</Flex>
74+
)
75+
}
76+
77+
// TODO WALL-4876 combine this with `PopupApp`
78+
export default function UnitagClaimApp(): JSX.Element {
79+
// initialize analytics on load
80+
useEffect(() => {
81+
initExtensionAnalytics().catch(() => undefined)
82+
}, [])
83+
84+
return (
85+
<Trace>
86+
<PersistGate persistor={getReduxPersistor()}>
87+
<ExtensionStatsigProvider>
88+
<I18nextProvider i18n={i18n}>
89+
<SharedWalletProvider reduxStore={getReduxStore()}>
90+
<ErrorBoundary>
91+
<GraphqlProvider>
92+
<LocalizationContextProvider>
93+
<UnitagUpdaterContextProvider>
94+
<TraceUserProperties />
95+
<RouterProvider router={router} />
96+
</UnitagUpdaterContextProvider>
97+
</LocalizationContextProvider>
98+
</GraphqlProvider>
99+
</ErrorBoundary>
100+
</SharedWalletProvider>
101+
</I18nextProvider>
102+
</ExtensionStatsigProvider>
103+
</PersistGate>
104+
</Trace>
105+
)
106+
}

apps/extension/src/app/components/tabs/NftsTab.tsx

+7-64
Original file line numberDiff line numberDiff line change
@@ -1,18 +1,11 @@
11
import { SharedEventName } from '@uniswap/analytics-events'
22
import { memo, useCallback } from 'react'
3-
import { useSelector } from 'react-redux'
4-
import { ContextMenu, Flex } from 'ui/src'
5-
import { fromGraphQLChain } from 'uniswap/src/features/chains/utils'
6-
import { selectNftsVisibility } from 'uniswap/src/features/favorites/selectors'
3+
import { Flex } from 'ui/src'
74
import { ElementName, SectionName } from 'uniswap/src/features/telemetry/constants'
85
import { sendAnalyticsEvent } from 'uniswap/src/features/telemetry/send'
9-
import { UniverseChainId } from 'uniswap/src/types/chains'
6+
import { NftViewWithContextMenu } from 'wallet/src/components/nfts/NftViewWithContextMenu'
107
import { NftsList } from 'wallet/src/components/nfts/NftsList'
11-
import { NFTViewer } from 'wallet/src/features/images/NFTViewer'
12-
import { ESTIMATED_NFT_LIST_ITEM_SIZE } from 'wallet/src/features/nfts/constants'
138
import { NFTItem } from 'wallet/src/features/nfts/types'
14-
import { useNFTContextMenu } from 'wallet/src/features/nfts/useNftContextMenu'
15-
import { getIsNftHidden } from 'wallet/src/features/nfts/utils'
169

1710
export const NftsTab = memo(function _NftsTab({ owner }: { owner: Address }): JSX.Element {
1811
const renderNFTItem = useCallback(
@@ -24,7 +17,11 @@ export const NftsTab = memo(function _NftsTab({ owner }: { owner: Address }): JS
2417
})
2518
}
2619

27-
return <NftView item={item} owner={owner} onPress={onPress} />
20+
return (
21+
<Flex fill m="$spacing4">
22+
<NftViewWithContextMenu item={item} owner={owner} onPress={onPress} />
23+
</Flex>
24+
)
2825
},
2926
[owner],
3027
)
@@ -39,60 +36,6 @@ export const NftsTab = memo(function _NftsTab({ owner }: { owner: Address }): JS
3936
)
4037
})
4138

42-
function NftView({ owner, item, onPress }: { owner: Address; item: NFTItem; onPress: () => void }): JSX.Element {
43-
const { menuActions } = useNFTContextMenu({
44-
contractAddress: item.contractAddress,
45-
tokenId: item.tokenId,
46-
owner,
47-
isSpam: item.isSpam,
48-
chainId: fromGraphQLChain(item.chain) ?? UniverseChainId.Mainnet,
49-
})
50-
51-
const menuOptions = menuActions.map((action) => ({
52-
label: action.title,
53-
onPress: action.onPress,
54-
Icon: action.Icon,
55-
destructive: action.destructive,
56-
}))
57-
58-
const nftVisibility = useSelector(selectNftsVisibility)
59-
const hidden = getIsNftHidden({
60-
contractAddress: item.contractAddress,
61-
tokenId: item.tokenId,
62-
isSpam: item.isSpam,
63-
nftVisibility,
64-
})
65-
66-
const itemId = `${item.chain}-${item.contractAddress}-${item.tokenId}-${hidden}`
67-
68-
return (
69-
<Flex grow shrink p="$spacing4">
70-
<ContextMenu itemId={itemId} menuOptions={menuOptions}>
71-
<Flex
72-
alignItems="center"
73-
aspectRatio={1}
74-
backgroundColor="$surface3"
75-
borderRadius="$rounded12"
76-
overflow="hidden"
77-
width="100%"
78-
onPress={onPress}
79-
>
80-
<NFTViewer
81-
showSvgPreview
82-
contractAddress={item.contractAddress}
83-
imageDimensions={item.imageDimensions}
84-
limitGIFSize={ESTIMATED_NFT_LIST_ITEM_SIZE}
85-
placeholderContent={item.name || item.collectionName}
86-
squareGridView={true}
87-
tokenId={item.tokenId}
88-
uri={item.imageUrl ?? ''}
89-
/>
90-
</Flex>
91-
</ContextMenu>
92-
</Flex>
93-
)
94-
}
95-
9639
const defaultEmptyStyle = {
9740
minHeight: 100,
9841
paddingVertical: '$spacing12',

0 commit comments

Comments
 (0)