@bosonprotocol/react-kit 0.36.0-alpha.9 → 0.36.1-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/components/form/Field.styles.d.ts +1 -0
- package/dist/cjs/components/form/Field.styles.d.ts.map +1 -1
- package/dist/cjs/components/form/Field.styles.js +8 -5
- package/dist/cjs/components/form/Field.styles.js.map +1 -1
- package/dist/cjs/components/form/Upload/BaseUpload.d.ts +2 -0
- package/dist/cjs/components/form/Upload/BaseUpload.d.ts.map +1 -1
- package/dist/cjs/components/image/Image.js +1 -1
- package/dist/cjs/components/image/Image.js.map +1 -1
- package/dist/cjs/components/image/Image.styles.d.ts +1 -1
- package/dist/cjs/components/image/Image.styles.d.ts.map +1 -1
- package/dist/cjs/components/image/Image.styles.js +2 -2
- package/dist/cjs/components/image/Image.styles.js.map +1 -1
- package/dist/cjs/components/modal/components/SellerFinance/FinanceWithdraw.js +1 -1
- package/dist/cjs/components/modal/components/SellerFinance/FinanceWithdraw.js.map +1 -1
- package/dist/cjs/components/modal/components/SellerFinance/FinancesStyles.d.ts.map +1 -1
- package/dist/cjs/components/modal/components/SellerFinance/FinancesStyles.js +37 -8
- package/dist/cjs/components/modal/components/SellerFinance/FinancesStyles.js.map +1 -1
- package/dist/cjs/components/ui/IpfsImage.d.ts.map +1 -1
- package/dist/cjs/components/ui/IpfsImage.js +41 -31
- package/dist/cjs/components/ui/IpfsImage.js.map +1 -1
- package/dist/cjs/components/ui/SvgImage.d.ts.map +1 -1
- package/dist/cjs/components/ui/SvgImage.js +2 -1
- package/dist/cjs/components/ui/SvgImage.js.map +1 -1
- package/dist/cjs/components/widgets/commit/CommitWidgetProviders.d.ts +2 -2
- package/dist/cjs/components/widgets/commit/CommitWidgetProviders.d.ts.map +1 -1
- package/dist/cjs/components/widgets/commit/CommitWidgetProviders.js +3 -3
- package/dist/cjs/components/widgets/commit/CommitWidgetProviders.js.map +1 -1
- package/dist/cjs/components/widgets/finance/FinanceWidgetProviders.d.ts +3 -1
- package/dist/cjs/components/widgets/finance/FinanceWidgetProviders.d.ts.map +1 -1
- package/dist/cjs/components/widgets/finance/FinanceWidgetProviders.js +17 -12
- package/dist/cjs/components/widgets/finance/FinanceWidgetProviders.js.map +1 -1
- package/dist/cjs/components/widgets/finance/useSellerRoles.d.ts +1 -8
- package/dist/cjs/components/widgets/finance/useSellerRoles.d.ts.map +1 -1
- package/dist/cjs/components/widgets/finance/useSellerRoles.js +3 -25
- package/dist/cjs/components/widgets/finance/useSellerRoles.js.map +1 -1
- package/dist/cjs/components/widgets/index.d.ts +2 -0
- package/dist/cjs/components/widgets/index.d.ts.map +1 -1
- package/dist/cjs/components/widgets/index.js +4 -1
- package/dist/cjs/components/widgets/index.js.map +1 -1
- package/dist/cjs/components/widgets/redemption/RedemptionWidgetProviders.d.ts +3 -1
- package/dist/cjs/components/widgets/redemption/RedemptionWidgetProviders.d.ts.map +1 -1
- package/dist/cjs/components/widgets/redemption/RedemptionWidgetProviders.js +22 -17
- package/dist/cjs/components/widgets/redemption/RedemptionWidgetProviders.js.map +1 -1
- package/dist/cjs/hooks/connection/useSwitchChain.d.ts.map +1 -1
- package/dist/cjs/hooks/connection/useSwitchChain.js +2 -2
- package/dist/cjs/hooks/connection/useSwitchChain.js.map +1 -1
- package/dist/cjs/hooks/contracts/BlockNumberProvider.d.ts +12 -0
- package/dist/cjs/hooks/contracts/BlockNumberProvider.d.ts.map +1 -0
- package/dist/cjs/hooks/contracts/BlockNumberProvider.js +93 -0
- package/dist/cjs/hooks/contracts/BlockNumberProvider.js.map +1 -0
- package/dist/cjs/hooks/contracts/useBlockNumber.d.ts +0 -5
- package/dist/cjs/hooks/contracts/useBlockNumber.d.ts.map +1 -1
- package/dist/cjs/hooks/contracts/useBlockNumber.js +4 -91
- package/dist/cjs/hooks/contracts/useBlockNumber.js.map +1 -1
- package/dist/cjs/index.d.ts +2 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +2 -0
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/lib/chains/getNativeLogoURI.d.ts.map +1 -1
- package/dist/cjs/lib/chains/getNativeLogoURI.js +2 -1
- package/dist/cjs/lib/chains/getNativeLogoURI.js.map +1 -1
- package/dist/cjs/lib/const/chainInfo.d.ts.map +1 -1
- package/dist/cjs/lib/const/chainInfo.js +2 -2
- package/dist/cjs/lib/const/chainInfo.js.map +1 -1
- package/dist/cjs/lib/const/networks.d.ts.map +1 -1
- package/dist/cjs/lib/const/networks.js +7 -6
- package/dist/cjs/lib/const/networks.js.map +1 -1
- package/dist/cjs/lib/const/providers.d.ts +1 -1
- package/dist/cjs/lib/const/providers.d.ts.map +1 -1
- package/dist/cjs/lib/const/providers.js +3 -1
- package/dist/cjs/lib/const/providers.js.map +1 -1
- package/dist/cjs/lib/const/routing.d.ts.map +1 -1
- package/dist/cjs/lib/const/routing.js +10 -0
- package/dist/cjs/lib/const/routing.js.map +1 -1
- package/dist/cjs/lib/const/tokens.d.ts +3 -3
- package/dist/cjs/lib/const/tokens.d.ts.map +1 -1
- package/dist/cjs/lib/const/tokens.js +5 -3
- package/dist/cjs/lib/const/tokens.js.map +1 -1
- package/dist/esm/components/form/Field.styles.d.ts +1 -0
- package/dist/esm/components/form/Field.styles.d.ts.map +1 -1
- package/dist/esm/components/form/Field.styles.js +7 -5
- package/dist/esm/components/form/Field.styles.js.map +1 -1
- package/dist/esm/components/form/Upload/BaseUpload.d.ts +2 -0
- package/dist/esm/components/form/Upload/BaseUpload.d.ts.map +1 -1
- package/dist/esm/components/image/Image.js +2 -2
- package/dist/esm/components/image/Image.js.map +1 -1
- package/dist/esm/components/image/Image.styles.d.ts +1 -1
- package/dist/esm/components/image/Image.styles.d.ts.map +1 -1
- package/dist/esm/components/image/Image.styles.js +1 -1
- package/dist/esm/components/image/Image.styles.js.map +1 -1
- package/dist/esm/components/modal/components/SellerFinance/FinanceWithdraw.js +1 -1
- package/dist/esm/components/modal/components/SellerFinance/FinanceWithdraw.js.map +1 -1
- package/dist/esm/components/modal/components/SellerFinance/FinancesStyles.d.ts.map +1 -1
- package/dist/esm/components/modal/components/SellerFinance/FinancesStyles.js +4 -5
- package/dist/esm/components/modal/components/SellerFinance/FinancesStyles.js.map +1 -1
- package/dist/esm/components/ui/IpfsImage.d.ts.map +1 -1
- package/dist/esm/components/ui/IpfsImage.js +41 -31
- package/dist/esm/components/ui/IpfsImage.js.map +1 -1
- package/dist/esm/components/ui/SvgImage.d.ts.map +1 -1
- package/dist/esm/components/ui/SvgImage.js +2 -1
- package/dist/esm/components/ui/SvgImage.js.map +1 -1
- package/dist/esm/components/widgets/commit/CommitWidgetProviders.d.ts +2 -2
- package/dist/esm/components/widgets/commit/CommitWidgetProviders.d.ts.map +1 -1
- package/dist/esm/components/widgets/commit/CommitWidgetProviders.js +2 -2
- package/dist/esm/components/widgets/commit/CommitWidgetProviders.js.map +1 -1
- package/dist/esm/components/widgets/finance/FinanceWidgetProviders.d.ts +3 -1
- package/dist/esm/components/widgets/finance/FinanceWidgetProviders.d.ts.map +1 -1
- package/dist/esm/components/widgets/finance/FinanceWidgetProviders.js +17 -12
- package/dist/esm/components/widgets/finance/FinanceWidgetProviders.js.map +1 -1
- package/dist/esm/components/widgets/finance/useSellerRoles.d.ts +1 -8
- package/dist/esm/components/widgets/finance/useSellerRoles.d.ts.map +1 -1
- package/dist/esm/components/widgets/finance/useSellerRoles.js +3 -24
- package/dist/esm/components/widgets/finance/useSellerRoles.js.map +1 -1
- package/dist/esm/components/widgets/index.d.ts +2 -0
- package/dist/esm/components/widgets/index.d.ts.map +1 -1
- package/dist/esm/components/widgets/index.js +2 -0
- package/dist/esm/components/widgets/index.js.map +1 -1
- package/dist/esm/components/widgets/redemption/RedemptionWidgetProviders.d.ts +3 -1
- package/dist/esm/components/widgets/redemption/RedemptionWidgetProviders.d.ts.map +1 -1
- package/dist/esm/components/widgets/redemption/RedemptionWidgetProviders.js +22 -17
- package/dist/esm/components/widgets/redemption/RedemptionWidgetProviders.js.map +1 -1
- package/dist/esm/hooks/connection/useSwitchChain.d.ts.map +1 -1
- package/dist/esm/hooks/connection/useSwitchChain.js +3 -3
- package/dist/esm/hooks/connection/useSwitchChain.js.map +1 -1
- package/dist/esm/hooks/contracts/BlockNumberProvider.d.ts +12 -0
- package/dist/esm/hooks/contracts/BlockNumberProvider.d.ts.map +1 -0
- package/dist/esm/hooks/contracts/BlockNumberProvider.js +86 -0
- package/dist/esm/hooks/contracts/BlockNumberProvider.js.map +1 -0
- package/dist/esm/hooks/contracts/useBlockNumber.d.ts +0 -5
- package/dist/esm/hooks/contracts/useBlockNumber.d.ts.map +1 -1
- package/dist/esm/hooks/contracts/useBlockNumber.js +2 -85
- package/dist/esm/hooks/contracts/useBlockNumber.js.map +1 -1
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +2 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/chains/getNativeLogoURI.d.ts.map +1 -1
- package/dist/esm/lib/chains/getNativeLogoURI.js +2 -1
- package/dist/esm/lib/chains/getNativeLogoURI.js.map +1 -1
- package/dist/esm/lib/const/chainInfo.d.ts.map +1 -1
- package/dist/esm/lib/const/chainInfo.js +3 -3
- package/dist/esm/lib/const/chainInfo.js.map +1 -1
- package/dist/esm/lib/const/networks.d.ts.map +1 -1
- package/dist/esm/lib/const/networks.js +7 -6
- package/dist/esm/lib/const/networks.js.map +1 -1
- package/dist/esm/lib/const/providers.d.ts +1 -1
- package/dist/esm/lib/const/providers.d.ts.map +1 -1
- package/dist/esm/lib/const/providers.js +4 -2
- package/dist/esm/lib/const/providers.js.map +1 -1
- package/dist/esm/lib/const/routing.d.ts.map +1 -1
- package/dist/esm/lib/const/routing.js +11 -1
- package/dist/esm/lib/const/routing.js.map +1 -1
- package/dist/esm/lib/const/tokens.d.ts +3 -3
- package/dist/esm/lib/const/tokens.d.ts.map +1 -1
- package/dist/esm/lib/const/tokens.js +5 -2
- package/dist/esm/lib/const/tokens.js.map +1 -1
- package/dist/tsconfig.cjs.tsbuildinfo +1 -1
- package/package.json +4 -4
- package/src/components/form/Field.styles.ts +8 -5
- package/src/components/image/Image.styles.ts +1 -1
- package/src/components/image/Image.tsx +2 -2
- package/src/components/modal/components/SellerFinance/FinanceWithdraw.tsx +1 -1
- package/src/components/modal/components/SellerFinance/FinancesStyles.tsx +4 -5
- package/src/components/ui/IpfsImage.tsx +58 -53
- package/src/components/ui/SvgImage.tsx +3 -1
- package/src/components/widgets/commit/CommitWidgetProviders.tsx +5 -5
- package/src/components/widgets/finance/FinanceWidgetProviders.tsx +44 -28
- package/src/components/widgets/finance/useSellerRoles.ts +4 -38
- package/src/components/widgets/index.tsx +2 -0
- package/src/components/widgets/redemption/RedemptionWidgetProviders.tsx +56 -40
- package/src/hooks/connection/useSwitchChain.ts +8 -3
- package/src/hooks/contracts/BlockNumberProvider.tsx +126 -0
- package/src/hooks/contracts/useBlockNumber.tsx +2 -127
- package/src/index.tsx +2 -0
- package/src/lib/chains/getNativeLogoURI.ts +2 -1
- package/src/lib/const/chainInfo.ts +9 -3
- package/src/lib/const/networks.ts +7 -6
- package/src/lib/const/providers.ts +10 -3
- package/src/lib/const/routing.ts +12 -1
- package/src/lib/const/tokens.ts +24 -7
- package/src/stories/ConnectWallet.stories.tsx +1 -1
- package/src/stories/buttons/Upload.stories.tsx +8 -1
|
@@ -1,27 +1,5 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
createContext,
|
|
5
|
-
ReactNode,
|
|
6
|
-
useCallback,
|
|
7
|
-
useContext,
|
|
8
|
-
useEffect,
|
|
9
|
-
useMemo,
|
|
10
|
-
useState
|
|
11
|
-
} from "react";
|
|
12
|
-
import { useIsWindowVisible } from "../uniswap/useIsWindowVisible";
|
|
13
|
-
import { RPC_PROVIDERS } from "../../lib/const/providers";
|
|
14
|
-
import { useChainId, useProvider } from "../connection/connection";
|
|
15
|
-
|
|
16
|
-
const MISSING_PROVIDER = Symbol();
|
|
17
|
-
const BlockNumberContext = createContext<
|
|
18
|
-
| {
|
|
19
|
-
fastForward(block: number): void;
|
|
20
|
-
block?: number;
|
|
21
|
-
mainnetBlock?: number;
|
|
22
|
-
}
|
|
23
|
-
| typeof MISSING_PROVIDER
|
|
24
|
-
>(MISSING_PROVIDER);
|
|
1
|
+
import { useContext } from "react";
|
|
2
|
+
import { BlockNumberContext, MISSING_PROVIDER } from "./BlockNumberProvider";
|
|
25
3
|
|
|
26
4
|
function useBlockNumberContext() {
|
|
27
5
|
const blockNumber = useContext(BlockNumberContext);
|
|
@@ -41,106 +19,3 @@ export function useBlockNumber(): number | undefined {
|
|
|
41
19
|
export function useMainnetBlockNumber(): number | undefined {
|
|
42
20
|
return useBlockNumberContext().mainnetBlock;
|
|
43
21
|
}
|
|
44
|
-
|
|
45
|
-
export function BlockNumberProvider({ children }: { children: ReactNode }) {
|
|
46
|
-
const activeChainId = useChainId();
|
|
47
|
-
const provider = useProvider();
|
|
48
|
-
|
|
49
|
-
const [{ chainId, block, mainnetBlock }, setChainBlock] = useState<{
|
|
50
|
-
chainId?: number;
|
|
51
|
-
block?: number;
|
|
52
|
-
mainnetBlock?: number;
|
|
53
|
-
}>({
|
|
54
|
-
chainId: activeChainId
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
const onChainBlock = useCallback((chainId: number, block: number) => {
|
|
58
|
-
setChainBlock((chainBlock) => {
|
|
59
|
-
if (chainBlock.chainId === chainId) {
|
|
60
|
-
if (!chainBlock.block || chainBlock.block < block) {
|
|
61
|
-
return {
|
|
62
|
-
chainId,
|
|
63
|
-
block,
|
|
64
|
-
mainnetBlock:
|
|
65
|
-
chainId === ChainId.MAINNET ? block : chainBlock.mainnetBlock
|
|
66
|
-
};
|
|
67
|
-
}
|
|
68
|
-
} else if (chainId === ChainId.MAINNET) {
|
|
69
|
-
if (!chainBlock.mainnetBlock || chainBlock.mainnetBlock < block) {
|
|
70
|
-
return { ...chainBlock, mainnetBlock: block };
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
return chainBlock;
|
|
74
|
-
});
|
|
75
|
-
}, []);
|
|
76
|
-
|
|
77
|
-
const windowVisible = useIsWindowVisible();
|
|
78
|
-
useEffect(() => {
|
|
79
|
-
let stale = false;
|
|
80
|
-
|
|
81
|
-
if (provider && activeChainId && windowVisible) {
|
|
82
|
-
// If chainId hasn't changed, don't clear the block. This prevents re-fetching still valid data.
|
|
83
|
-
setChainBlock((chainBlock) =>
|
|
84
|
-
chainBlock.chainId === activeChainId
|
|
85
|
-
? chainBlock
|
|
86
|
-
: { chainId: activeChainId, mainnetBlock: chainBlock.mainnetBlock }
|
|
87
|
-
);
|
|
88
|
-
|
|
89
|
-
provider
|
|
90
|
-
.getBlockNumber()
|
|
91
|
-
.then((block) => {
|
|
92
|
-
if (!stale) onChainBlock(activeChainId, block);
|
|
93
|
-
})
|
|
94
|
-
.catch((error) => {
|
|
95
|
-
console.error(
|
|
96
|
-
`Failed to get block number for chainId ${activeChainId}`,
|
|
97
|
-
error
|
|
98
|
-
);
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
const onBlock = (block: number) => onChainBlock(activeChainId, block);
|
|
102
|
-
provider.on("block", onBlock);
|
|
103
|
-
return () => {
|
|
104
|
-
stale = true;
|
|
105
|
-
provider.removeListener("block", onBlock);
|
|
106
|
-
};
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
return void 0;
|
|
110
|
-
}, [activeChainId, provider, windowVisible, onChainBlock]);
|
|
111
|
-
|
|
112
|
-
useEffect(() => {
|
|
113
|
-
if (mainnetBlock === undefined) {
|
|
114
|
-
RPC_PROVIDERS[ChainId.MAINNET]
|
|
115
|
-
.getBlockNumber()
|
|
116
|
-
.then((block) => {
|
|
117
|
-
onChainBlock(ChainId.MAINNET, block);
|
|
118
|
-
})
|
|
119
|
-
// swallow errors - it's ok if this fails, as we'll try again if we activate mainnet
|
|
120
|
-
.catch(() => undefined);
|
|
121
|
-
}
|
|
122
|
-
}, [mainnetBlock, onChainBlock]);
|
|
123
|
-
|
|
124
|
-
const value = useMemo(
|
|
125
|
-
() => ({
|
|
126
|
-
fastForward: (update: number) => {
|
|
127
|
-
if (block && update > block) {
|
|
128
|
-
setChainBlock({
|
|
129
|
-
chainId: activeChainId,
|
|
130
|
-
block: update,
|
|
131
|
-
mainnetBlock:
|
|
132
|
-
activeChainId === ChainId.MAINNET ? update : mainnetBlock
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
},
|
|
136
|
-
block: chainId === activeChainId ? block : undefined,
|
|
137
|
-
mainnetBlock
|
|
138
|
-
}),
|
|
139
|
-
[activeChainId, block, chainId, mainnetBlock]
|
|
140
|
-
);
|
|
141
|
-
return (
|
|
142
|
-
<BlockNumberContext.Provider value={value}>
|
|
143
|
-
{children}
|
|
144
|
-
</BlockNumberContext.Provider>
|
|
145
|
-
);
|
|
146
|
-
}
|
package/src/index.tsx
CHANGED
|
@@ -82,6 +82,7 @@ export * from "./lib/bundle/const";
|
|
|
82
82
|
export * from "./lib/bundle/filter";
|
|
83
83
|
export * from "./lib/bytes/bytesToSize";
|
|
84
84
|
export * from "./lib/const/networks";
|
|
85
|
+
export * from "./lib/copy/copyToClipboard";
|
|
85
86
|
export * from "./lib/errors/transactions";
|
|
86
87
|
export * from "./lib/ipfs/ipfs";
|
|
87
88
|
export * from "./lib/magicLink/logout";
|
|
@@ -92,6 +93,7 @@ export * from "./lib/opensea/getOpenSeaUrl";
|
|
|
92
93
|
export * from "./lib/promises/promises";
|
|
93
94
|
export * from "./lib/url/url";
|
|
94
95
|
export * from "./theme";
|
|
96
|
+
export * from "./colors";
|
|
95
97
|
export * from "./types/helpers";
|
|
96
98
|
export { AuthTokenType } from "@bosonprotocol/common";
|
|
97
99
|
export * from "@bosonprotocol/core-sdk";
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { ChainId } from "@uniswap/sdk-core";
|
|
2
2
|
import EthereumLogo from "../../assets/svg/ethereum_square_logo.svg";
|
|
3
3
|
import MaticLogo from "../../assets/svg/matic-token-icon.svg";
|
|
4
|
+
import { ChainId_POLYGON_AMOY } from "../const/chains";
|
|
4
5
|
|
|
5
6
|
export function getNativeLogoURI(
|
|
6
7
|
chainId: ChainId | number = ChainId.MAINNET
|
|
@@ -8,7 +9,7 @@ export function getNativeLogoURI(
|
|
|
8
9
|
switch (chainId) {
|
|
9
10
|
case ChainId.POLYGON:
|
|
10
11
|
case ChainId.POLYGON_MUMBAI:
|
|
11
|
-
case
|
|
12
|
+
case ChainId_POLYGON_AMOY:
|
|
12
13
|
return MaticLogo;
|
|
13
14
|
default:
|
|
14
15
|
return EthereumLogo;
|
|
@@ -5,7 +5,13 @@ import polygonMaticLogo from "../../assets/svg/polygon-matic-logo.svg";
|
|
|
5
5
|
import polygonSquareLogoUrl from "../../assets/svg/polygon_square_logo.svg";
|
|
6
6
|
import ms from "ms";
|
|
7
7
|
|
|
8
|
-
import {
|
|
8
|
+
import {
|
|
9
|
+
LocalChainId,
|
|
10
|
+
SupportedL1ChainId,
|
|
11
|
+
SupportedL2ChainId,
|
|
12
|
+
ChainId_POLYGON_AMOY,
|
|
13
|
+
ChainId_BASE_SEPOLIA
|
|
14
|
+
} from "./chains";
|
|
9
15
|
|
|
10
16
|
export const AVERAGE_L1_BLOCK_TIME = ms(`12s`);
|
|
11
17
|
|
|
@@ -99,7 +105,7 @@ const CHAIN_INFO: ChainInfoMap = {
|
|
|
99
105
|
decimals: 18
|
|
100
106
|
}
|
|
101
107
|
},
|
|
102
|
-
|
|
108
|
+
[ChainId_POLYGON_AMOY]: {
|
|
103
109
|
networkType: NetworkType.L1,
|
|
104
110
|
blockWaitMsBeforeWarning: ms(`10m`),
|
|
105
111
|
bridge: "https://wallet.polygon.technology/polygon/bridge/deposit",
|
|
@@ -130,7 +136,7 @@ const CHAIN_INFO: ChainInfoMap = {
|
|
|
130
136
|
},
|
|
131
137
|
defaultListUrl: ""
|
|
132
138
|
},
|
|
133
|
-
|
|
139
|
+
[ChainId_BASE_SEPOLIA]: {
|
|
134
140
|
networkType: NetworkType.L2,
|
|
135
141
|
blockWaitMsBeforeWarning: ms(`10m`),
|
|
136
142
|
bridge: "https://testnets.superbridge.app/base-sepolia",
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ChainId } from "@uniswap/sdk-core";
|
|
2
|
+
import { ChainId_BASE_SEPOLIA, ChainId_POLYGON_AMOY } from "./chains";
|
|
2
3
|
|
|
3
4
|
// TODO: comment out?
|
|
4
5
|
// const QUICKNODE_BNB_RPC_URL = process.env.REACT_APP_BNB_RPC_URL;
|
|
@@ -71,7 +72,7 @@ export const FALLBACK_URLS = {
|
|
|
71
72
|
"https://rpc-mumbai.maticvigil.com",
|
|
72
73
|
"https://matic-testnet-archive-rpc.bwarelabs.com"
|
|
73
74
|
],
|
|
74
|
-
|
|
75
|
+
[ChainId_POLYGON_AMOY]: [
|
|
75
76
|
// "Safe" URLs
|
|
76
77
|
"https://rpc-amoy.polygon.technology"
|
|
77
78
|
],
|
|
@@ -136,7 +137,7 @@ export const FALLBACK_URLS = {
|
|
|
136
137
|
"https://base-goerli.blastapi.io/b5a802d8-151d-4443-90a7-699108dc4e01",
|
|
137
138
|
"https://svc.blockdaemon.com/base/testnet/native?apiKey=zpka_1334e7c450464d06b6e33a972a7a4e57_75320f43"
|
|
138
139
|
],
|
|
139
|
-
|
|
140
|
+
[ChainId_BASE_SEPOLIA]: [
|
|
140
141
|
// "Safe" URLs
|
|
141
142
|
"https://sepolia.base.org"
|
|
142
143
|
]
|
|
@@ -183,10 +184,10 @@ export const getRpcUrls = (infuraKey: string) => ({
|
|
|
183
184
|
`https://polygon-mumbai.infura.io/v3/${infuraKey}`,
|
|
184
185
|
...FALLBACK_URLS[ChainId.POLYGON_MUMBAI]
|
|
185
186
|
],
|
|
186
|
-
|
|
187
|
+
[ChainId_POLYGON_AMOY]: [
|
|
187
188
|
// AMOY
|
|
188
189
|
`https://polygon-amoy.infura.io/v3/${infuraKey}`,
|
|
189
|
-
...FALLBACK_URLS[
|
|
190
|
+
...FALLBACK_URLS[ChainId_POLYGON_AMOY]
|
|
190
191
|
],
|
|
191
192
|
[ChainId.CELO]: FALLBACK_URLS[ChainId.CELO],
|
|
192
193
|
[ChainId.CELO_ALFAJORES]: FALLBACK_URLS[ChainId.CELO_ALFAJORES],
|
|
@@ -205,10 +206,10 @@ export const getRpcUrls = (infuraKey: string) => ({
|
|
|
205
206
|
`https://base-goerli.infura.io/v3/${infuraKey}`,
|
|
206
207
|
...FALLBACK_URLS[ChainId.BASE_GOERLI]
|
|
207
208
|
],
|
|
208
|
-
|
|
209
|
+
[ChainId_BASE_SEPOLIA]: [
|
|
209
210
|
// BASE_SEPOLIA
|
|
210
211
|
`https://base-sepolia.infura.io/v3/${infuraKey}`,
|
|
211
|
-
...FALLBACK_URLS[
|
|
212
|
+
...FALLBACK_URLS[ChainId_BASE_SEPOLIA]
|
|
212
213
|
],
|
|
213
214
|
31337: [
|
|
214
215
|
`https://mainnet.infura.io/v3/${infuraKey}`,
|
|
@@ -3,10 +3,15 @@ import { deepCopy } from "@ethersproject/properties";
|
|
|
3
3
|
// eslint-disable-next-line @typescript-eslint/no-restricted-imports
|
|
4
4
|
import { StaticJsonRpcProvider } from "@ethersproject/providers";
|
|
5
5
|
import { isPlain } from "@reduxjs/toolkit";
|
|
6
|
-
import { ChainId
|
|
6
|
+
import { ChainId } from "@uniswap/sdk-core";
|
|
7
7
|
|
|
8
8
|
import { AVERAGE_L1_BLOCK_TIME } from "./chainInfo";
|
|
9
|
-
import {
|
|
9
|
+
import {
|
|
10
|
+
CHAIN_IDS_TO_NAMES,
|
|
11
|
+
ChainId_BASE_SEPOLIA,
|
|
12
|
+
ChainId_POLYGON_AMOY,
|
|
13
|
+
SupportedChainsType
|
|
14
|
+
} from "./chains";
|
|
10
15
|
import { CONFIG } from "../config/config";
|
|
11
16
|
const RPC_URLS = CONFIG.rpcUrls;
|
|
12
17
|
|
|
@@ -81,10 +86,12 @@ export const RPC_PROVIDERS: {
|
|
|
81
86
|
[ChainId.ARBITRUM_GOERLI]: new AppJsonRpcProvider(ChainId.ARBITRUM_GOERLI),
|
|
82
87
|
[ChainId.POLYGON]: new AppJsonRpcProvider(ChainId.POLYGON),
|
|
83
88
|
[ChainId.POLYGON_MUMBAI]: new AppJsonRpcProvider(ChainId.POLYGON_MUMBAI),
|
|
89
|
+
[ChainId_POLYGON_AMOY]: new AppJsonRpcProvider(ChainId_POLYGON_AMOY),
|
|
84
90
|
[ChainId.CELO]: new AppJsonRpcProvider(ChainId.CELO),
|
|
85
91
|
[ChainId.CELO_ALFAJORES]: new AppJsonRpcProvider(ChainId.CELO_ALFAJORES),
|
|
86
92
|
[ChainId.BNB]: new AppJsonRpcProvider(ChainId.BNB),
|
|
87
93
|
[ChainId.AVALANCHE]: new AppJsonRpcProvider(ChainId.AVALANCHE),
|
|
88
94
|
[ChainId.BASE]: new AppJsonRpcProvider(ChainId.BASE),
|
|
89
|
-
[ChainId.BASE_GOERLI]: new AppJsonRpcProvider(ChainId.BASE_GOERLI)
|
|
95
|
+
[ChainId.BASE_GOERLI]: new AppJsonRpcProvider(ChainId.BASE_GOERLI),
|
|
96
|
+
[ChainId_BASE_SEPOLIA]: new AppJsonRpcProvider(ChainId_BASE_SEPOLIA)
|
|
90
97
|
};
|
package/src/lib/const/routing.ts
CHANGED
|
@@ -42,8 +42,10 @@ import {
|
|
|
42
42
|
WETH_AVALANCHE,
|
|
43
43
|
WETH_POLYGON,
|
|
44
44
|
WETH_POLYGON_MUMBAI,
|
|
45
|
-
WRAPPED_NATIVE_CURRENCY
|
|
45
|
+
WRAPPED_NATIVE_CURRENCY,
|
|
46
|
+
WETH_POLYGON_AMOY
|
|
46
47
|
} from "./tokens";
|
|
48
|
+
import { ChainId_BASE_SEPOLIA, ChainId_POLYGON_AMOY } from "./chains";
|
|
47
49
|
|
|
48
50
|
type ChainTokenList = {
|
|
49
51
|
readonly [chainId: number]: Token[];
|
|
@@ -111,6 +113,10 @@ export const COMMON_BASES: ChainCurrencyList = {
|
|
|
111
113
|
nativeOnChain(ChainId.BASE_GOERLI),
|
|
112
114
|
WRAPPED_NATIVE_CURRENCY[ChainId.BASE_GOERLI] as Token
|
|
113
115
|
],
|
|
116
|
+
[ChainId_BASE_SEPOLIA]: [
|
|
117
|
+
nativeOnChain(ChainId_BASE_SEPOLIA),
|
|
118
|
+
WRAPPED_NATIVE_CURRENCY[ChainId_BASE_SEPOLIA] as Token
|
|
119
|
+
],
|
|
114
120
|
[ChainId.POLYGON]: [
|
|
115
121
|
nativeOnChain(ChainId.POLYGON),
|
|
116
122
|
WETH_POLYGON,
|
|
@@ -124,6 +130,11 @@ export const COMMON_BASES: ChainCurrencyList = {
|
|
|
124
130
|
WRAPPED_NATIVE_CURRENCY[ChainId.POLYGON_MUMBAI] as Token,
|
|
125
131
|
WETH_POLYGON_MUMBAI
|
|
126
132
|
],
|
|
133
|
+
[ChainId_POLYGON_AMOY]: [
|
|
134
|
+
nativeOnChain(ChainId_POLYGON_AMOY),
|
|
135
|
+
WRAPPED_NATIVE_CURRENCY[ChainId_POLYGON_AMOY] as Token,
|
|
136
|
+
WETH_POLYGON_AMOY
|
|
137
|
+
],
|
|
127
138
|
|
|
128
139
|
[ChainId.CELO]: [
|
|
129
140
|
nativeOnChain(ChainId.CELO),
|
package/src/lib/const/tokens.ts
CHANGED
|
@@ -7,6 +7,7 @@ import {
|
|
|
7
7
|
WETH9
|
|
8
8
|
} from "@uniswap/sdk-core";
|
|
9
9
|
import invariant from "tiny-invariant";
|
|
10
|
+
import { ChainId_BASE_SEPOLIA, ChainId_POLYGON_AMOY } from "./chains";
|
|
10
11
|
|
|
11
12
|
export const NATIVE_CHAIN_ID = "NATIVE";
|
|
12
13
|
|
|
@@ -193,6 +194,14 @@ export const WETH_POLYGON_MUMBAI = new Token(
|
|
|
193
194
|
"Wrapped Ether"
|
|
194
195
|
);
|
|
195
196
|
|
|
197
|
+
export const WETH_POLYGON_AMOY = new Token(
|
|
198
|
+
ChainId_POLYGON_AMOY,
|
|
199
|
+
"0x52eF3d68BaB452a294342DC3e5f464d7f610f72E",
|
|
200
|
+
18,
|
|
201
|
+
"WETH",
|
|
202
|
+
"Wrapped Ether"
|
|
203
|
+
);
|
|
204
|
+
|
|
196
205
|
export const WETH_POLYGON = new Token(
|
|
197
206
|
ChainId.POLYGON,
|
|
198
207
|
"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",
|
|
@@ -376,6 +385,13 @@ export const WRAPPED_NATIVE_CURRENCY: { [chainId: number]: Token | undefined } =
|
|
|
376
385
|
"WETH",
|
|
377
386
|
"Wrapped Ether"
|
|
378
387
|
),
|
|
388
|
+
[ChainId_BASE_SEPOLIA]: new Token(
|
|
389
|
+
ChainId_BASE_SEPOLIA,
|
|
390
|
+
"0x4200000000000000000000000000000000000006",
|
|
391
|
+
18,
|
|
392
|
+
"WETH",
|
|
393
|
+
"Wrapped Ether"
|
|
394
|
+
),
|
|
379
395
|
[ChainId.ARBITRUM_ONE]: new Token(
|
|
380
396
|
ChainId.ARBITRUM_ONE,
|
|
381
397
|
"0x82aF49447D8a07e3bd95BD0d56f35241523fBab1",
|
|
@@ -411,9 +427,9 @@ export const WRAPPED_NATIVE_CURRENCY: { [chainId: number]: Token | undefined } =
|
|
|
411
427
|
"WMATIC",
|
|
412
428
|
"Wrapped MATIC"
|
|
413
429
|
),
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
"
|
|
430
|
+
[ChainId_POLYGON_AMOY]: new Token(
|
|
431
|
+
ChainId_POLYGON_AMOY,
|
|
432
|
+
"0x778f1b662a461695633791d03a77d992c24b588a",
|
|
417
433
|
18,
|
|
418
434
|
"WMATIC",
|
|
419
435
|
"Wrapped MATIC"
|
|
@@ -465,15 +481,16 @@ function getCeloNativeCurrency(chainId: number) {
|
|
|
465
481
|
}
|
|
466
482
|
}
|
|
467
483
|
|
|
468
|
-
type NewType = 80002;
|
|
469
|
-
|
|
470
484
|
export function isMatic(
|
|
471
485
|
chainId: number
|
|
472
|
-
): chainId is
|
|
486
|
+
): chainId is
|
|
487
|
+
| ChainId.POLYGON
|
|
488
|
+
| ChainId.POLYGON_MUMBAI
|
|
489
|
+
| typeof ChainId_POLYGON_AMOY {
|
|
473
490
|
return (
|
|
474
491
|
chainId === ChainId.POLYGON_MUMBAI ||
|
|
475
492
|
chainId === ChainId.POLYGON ||
|
|
476
|
-
chainId ===
|
|
493
|
+
chainId === ChainId_POLYGON_AMOY
|
|
477
494
|
);
|
|
478
495
|
}
|
|
479
496
|
|
|
@@ -20,7 +20,7 @@ import { bosonButtonThemeKeys } from "../components/ui/ThemedButton";
|
|
|
20
20
|
import { CSSProperties, createGlobalStyle } from "styled-components";
|
|
21
21
|
import { Wallet } from "phosphor-react";
|
|
22
22
|
import { ReduxProvider } from "../components/widgets/ReduxProvider";
|
|
23
|
-
import { BlockNumberProvider } from "../hooks/contracts/
|
|
23
|
+
import { BlockNumberProvider } from "../hooks/contracts/BlockNumberProvider";
|
|
24
24
|
|
|
25
25
|
const successButtonTheme: ConnectWalletProps["connectWalletButtonTheme"] =
|
|
26
26
|
bosonButtonThemes()["primary"];
|
|
@@ -70,7 +70,14 @@ const BASE_ARGS = {
|
|
|
70
70
|
name,
|
|
71
71
|
placeholder: "",
|
|
72
72
|
withEditor: false,
|
|
73
|
-
saveButtonTheme: undefined
|
|
73
|
+
saveButtonTheme: undefined,
|
|
74
|
+
theme: {
|
|
75
|
+
triggerTheme: {
|
|
76
|
+
media: {
|
|
77
|
+
objectFit: "cover"
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
74
81
|
} as const satisfies UploadProps;
|
|
75
82
|
|
|
76
83
|
// More on args: https://storybook.js.org/docs/react/writing-stories/args
|