thirdweb 5.64.0 → 5.64.2
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/auth/core/generate-login-payload.js +1 -1
- package/dist/cjs/auth/core/generate-login-payload.js.map +1 -1
- package/dist/cjs/extensions/prebuilts/deploy-vote.js +13 -13
- package/dist/cjs/extensions/prebuilts/deploy-vote.js.map +1 -1
- package/dist/cjs/react/core/utils/walletIcon.js +7 -7
- package/dist/cjs/react/core/utils/walletIcon.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/MenuButton.js +0 -3
- package/dist/cjs/react/web/ui/ConnectWallet/MenuButton.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/WalletSelector.js +2 -2
- package/dist/cjs/react/web/ui/ConnectWallet/WalletSelector.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/WalletTypeRowButton.js +1 -4
- package/dist/cjs/react/web/ui/ConnectWallet/WalletTypeRowButton.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/icons/EmailIcon.js +12 -0
- package/dist/cjs/react/web/ui/ConnectWallet/icons/EmailIcon.js.map +1 -0
- package/dist/cjs/react/web/ui/ConnectWallet/icons/FingerPrintIcon.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/icons/FingerPrintIcon.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/icons/GuestIcon.js +12 -0
- package/dist/cjs/react/web/ui/ConnectWallet/icons/GuestIcon.js.map +1 -0
- package/dist/cjs/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/icons/PhoneIcon.js +12 -0
- package/dist/cjs/react/web/ui/ConnectWallet/icons/PhoneIcon.js.map +1 -0
- package/dist/cjs/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +5 -2
- package/dist/cjs/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/components/WalletImage.js +34 -9
- package/dist/cjs/react/web/ui/components/WalletImage.js.map +1 -1
- package/dist/cjs/react/web/wallets/in-app/WalletAuth.js +9 -2
- package/dist/cjs/react/web/wallets/in-app/WalletAuth.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +11 -6
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/esm/auth/core/generate-login-payload.js +1 -1
- package/dist/esm/auth/core/generate-login-payload.js.map +1 -1
- package/dist/esm/extensions/prebuilts/deploy-vote.js +13 -13
- package/dist/esm/extensions/prebuilts/deploy-vote.js.map +1 -1
- package/dist/esm/react/core/utils/walletIcon.js +3 -3
- package/dist/esm/react/core/utils/walletIcon.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/MenuButton.js +0 -3
- package/dist/esm/react/web/ui/ConnectWallet/MenuButton.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/WalletSelector.js +2 -2
- package/dist/esm/react/web/ui/ConnectWallet/WalletSelector.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/WalletTypeRowButton.js +2 -5
- package/dist/esm/react/web/ui/ConnectWallet/WalletTypeRowButton.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/icons/EmailIcon.js +8 -0
- package/dist/esm/react/web/ui/ConnectWallet/icons/EmailIcon.js.map +1 -0
- package/dist/esm/react/web/ui/ConnectWallet/icons/FingerPrintIcon.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/icons/FingerPrintIcon.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/icons/GuestIcon.js +8 -0
- package/dist/esm/react/web/ui/ConnectWallet/icons/GuestIcon.js.map +1 -0
- package/dist/esm/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/icons/PhoneIcon.js +8 -0
- package/dist/esm/react/web/ui/ConnectWallet/icons/PhoneIcon.js.map +1 -0
- package/dist/esm/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js +5 -2
- package/dist/esm/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.js.map +1 -1
- package/dist/esm/react/web/ui/components/WalletImage.js +34 -9
- package/dist/esm/react/web/ui/components/WalletImage.js.map +1 -1
- package/dist/esm/react/web/wallets/in-app/WalletAuth.js +9 -2
- package/dist/esm/react/web/wallets/in-app/WalletAuth.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +12 -7
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/types/react/core/utils/walletIcon.d.ts +0 -3
- package/dist/types/react/core/utils/walletIcon.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/MenuButton.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/WalletTypeRowButton.d.ts +2 -1
- package/dist/types/react/web/ui/ConnectWallet/WalletTypeRowButton.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/icons/EmailIcon.d.ts +6 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/EmailIcon.d.ts.map +1 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/GuestIcon.d.ts +6 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/GuestIcon.d.ts.map +1 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/PhoneIcon.d.ts +6 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/PhoneIcon.d.ts.map +1 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/types.d.ts +1 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/types.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/WalletImage.d.ts.map +1 -1
- package/dist/types/react/web/wallets/in-app/WalletAuth.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/package.json +1 -1
- package/src/auth/core/generate-login-payload.test.ts +1 -1
- package/src/auth/core/generate-login-payload.ts +1 -1
- package/src/extensions/prebuilts/deploy-vote.test.ts +1 -46
- package/src/extensions/prebuilts/deploy-vote.ts +21 -20
- package/src/extensions/split/split.test.ts +76 -0
- package/src/extensions/vote/{read/proposalExists.test.ts → vote.test.ts} +21 -52
- package/src/react/core/utils/walletIcon.ts +3 -3
- package/src/react/web/ui/ConnectWallet/MenuButton.tsx +0 -3
- package/src/react/web/ui/ConnectWallet/WalletSelector.tsx +2 -2
- package/src/react/web/ui/ConnectWallet/WalletTypeRowButton.tsx +4 -17
- package/src/react/web/ui/ConnectWallet/icons/EmailIcon.tsx +30 -0
- package/src/react/web/ui/ConnectWallet/icons/FingerPrintIcon.tsx +9 -9
- package/src/react/web/ui/ConnectWallet/icons/GuestIcon.tsx +24 -0
- package/src/react/web/ui/ConnectWallet/icons/OutlineWalletIcon.tsx +2 -2
- package/src/react/web/ui/ConnectWallet/icons/PhoneIcon.tsx +32 -0
- package/src/react/web/ui/ConnectWallet/icons/types.ts +1 -1
- package/src/react/web/ui/ConnectWallet/screens/LinkedProfilesScreen.tsx +10 -1
- package/src/react/web/ui/components/WalletImage.tsx +48 -21
- package/src/react/web/wallets/in-app/WalletAuth.tsx +14 -2
- package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +12 -13
- package/src/version.ts +1 -1
- package/src/wallets/smart/smart-wallet-integration.test.ts +11 -8
- package/src/extensions/prebuilts/deploy-split.test.ts +0 -31
- package/src/extensions/split/read/getAllRecipientsAddresses.test.ts +0 -41
- package/src/extensions/split/read/getAllRecipientsPercentages.test.ts +0 -50
- package/src/extensions/split/read/getRecipientSplitPercentage.test.ts +0 -49
@@ -136,6 +136,27 @@ async function getInitializeTransaction(options: {
|
|
136
136
|
external_link,
|
137
137
|
social_urls,
|
138
138
|
} = params;
|
139
|
+
|
140
|
+
// Validate initialVoteQuorumFraction
|
141
|
+
const _num = Number(minVoteQuorumRequiredPercent);
|
142
|
+
if (Number.isNaN(_num)) {
|
143
|
+
throw new Error(
|
144
|
+
`${minVoteQuorumRequiredPercent} is not a valid minVoteQuorumRequiredPercent`,
|
145
|
+
);
|
146
|
+
}
|
147
|
+
if (_num < 0 || _num > 100) {
|
148
|
+
throw new Error("minVoteQuorumRequiredPercent must be >= 0 and <= 100");
|
149
|
+
}
|
150
|
+
|
151
|
+
// Make sure if user is passing a float, it should only have 2 digit after the decimal point
|
152
|
+
if (!Number.isInteger(_num)) {
|
153
|
+
throw new Error(
|
154
|
+
`${_num} is an invalid value. Only integer-like values accepted`,
|
155
|
+
);
|
156
|
+
}
|
157
|
+
|
158
|
+
const initialVoteQuorumFraction = BigInt(_num);
|
159
|
+
|
139
160
|
const tokenErc20Contract = getContract({
|
140
161
|
address: tokenAddress,
|
141
162
|
client,
|
@@ -177,26 +198,6 @@ async function getInitializeTransaction(options: {
|
|
177
198
|
})) ||
|
178
199
|
"";
|
179
200
|
|
180
|
-
// Validate initialVoteQuorumFraction
|
181
|
-
const _num = Number(minVoteQuorumRequiredPercent);
|
182
|
-
if (Number.isNaN(_num)) {
|
183
|
-
throw new Error(
|
184
|
-
`${minVoteQuorumRequiredPercent} is not a valid minVoteQuorumRequiredPercent`,
|
185
|
-
);
|
186
|
-
}
|
187
|
-
if (_num < 0 || _num > 100) {
|
188
|
-
throw new Error("minVoteQuorumRequiredPercent must be >= 0 and <= 100");
|
189
|
-
}
|
190
|
-
|
191
|
-
// Make sure if user is passing a float, it should only have 2 digit after the decimal point
|
192
|
-
if (!Number.isInteger(_num)) {
|
193
|
-
throw new Error(
|
194
|
-
`${_num} is an invalid value. Only integer-like values accepted`,
|
195
|
-
);
|
196
|
-
}
|
197
|
-
|
198
|
-
const initialVoteQuorumFraction = BigInt(_num);
|
199
|
-
|
200
201
|
return initialize({
|
201
202
|
contract: implementationContract,
|
202
203
|
name,
|
@@ -0,0 +1,76 @@
|
|
1
|
+
import { beforeAll, describe, expect, it } from "vitest";
|
2
|
+
import { ANVIL_CHAIN } from "~test/chains.js";
|
3
|
+
import { TEST_CLIENT } from "~test/test-clients.js";
|
4
|
+
import { TEST_ACCOUNT_D } from "~test/test-wallets.js";
|
5
|
+
import { type ThirdwebContract, getContract } from "../../contract/contract.js";
|
6
|
+
import { isAddress } from "../../utils/address.js";
|
7
|
+
import { deploySplitContract } from "../prebuilts/deploy-split.js";
|
8
|
+
import { getAllRecipientsAddresses } from "./read/getAllRecipientsAddresses.js";
|
9
|
+
import { getAllRecipientsPercentages } from "./read/getAllRecipientsPercentages.js";
|
10
|
+
import { getRecipientSplitPercentage } from "./read/getRecipientSplitPercentage.js";
|
11
|
+
|
12
|
+
let contract: ThirdwebContract;
|
13
|
+
const chain = ANVIL_CHAIN;
|
14
|
+
const client = TEST_CLIENT;
|
15
|
+
|
16
|
+
describe.runIf(process.env.TW_SECRET_KEY)("Split contract tests", () => {
|
17
|
+
beforeAll(async () => {
|
18
|
+
const address = await deploySplitContract({
|
19
|
+
account: TEST_ACCOUNT_D,
|
20
|
+
client,
|
21
|
+
chain,
|
22
|
+
params: {
|
23
|
+
name: "split-contract",
|
24
|
+
payees: [
|
25
|
+
"0x12345674b599ce99958242b3D3741e7b01841DF3",
|
26
|
+
"0xA6f11e47dE28B3dB934e945daeb6F538E9019694",
|
27
|
+
],
|
28
|
+
shares: [
|
29
|
+
5100n, // 51%
|
30
|
+
4900n, // 49%
|
31
|
+
],
|
32
|
+
},
|
33
|
+
});
|
34
|
+
expect(address).toBeDefined();
|
35
|
+
expect(isAddress(address)).toBe(true);
|
36
|
+
contract = getContract({
|
37
|
+
address,
|
38
|
+
client,
|
39
|
+
chain,
|
40
|
+
});
|
41
|
+
}, 60_000);
|
42
|
+
|
43
|
+
it("should return all recipient addresses", async () => {
|
44
|
+
const result = await getAllRecipientsAddresses({ contract });
|
45
|
+
expect(result).toStrictEqual([
|
46
|
+
"0x12345674b599ce99958242b3D3741e7b01841DF3",
|
47
|
+
"0xA6f11e47dE28B3dB934e945daeb6F538E9019694",
|
48
|
+
]);
|
49
|
+
});
|
50
|
+
|
51
|
+
it("should return all recipients and their share percentages", async () => {
|
52
|
+
const result = await getAllRecipientsPercentages({ contract });
|
53
|
+
expect(result).toStrictEqual([
|
54
|
+
{
|
55
|
+
address: "0x12345674b599ce99958242b3D3741e7b01841DF3",
|
56
|
+
splitPercentage: 51,
|
57
|
+
},
|
58
|
+
{
|
59
|
+
address: "0xA6f11e47dE28B3dB934e945daeb6F538E9019694",
|
60
|
+
splitPercentage: 49,
|
61
|
+
},
|
62
|
+
]);
|
63
|
+
});
|
64
|
+
|
65
|
+
it("should return split percentage for individual recipient", async () => {
|
66
|
+
const result = await getRecipientSplitPercentage({
|
67
|
+
contract,
|
68
|
+
recipientAddress: "0x12345674b599ce99958242b3D3741e7b01841DF3",
|
69
|
+
});
|
70
|
+
|
71
|
+
expect(result).toStrictEqual({
|
72
|
+
address: "0x12345674b599ce99958242b3D3741e7b01841DF3",
|
73
|
+
splitPercentage: 51,
|
74
|
+
});
|
75
|
+
});
|
76
|
+
});
|
@@ -3,22 +3,22 @@ import { ANVIL_CHAIN } from "~test/chains.js";
|
|
3
3
|
import { TEST_CONTRACT_URI } from "~test/ipfs-uris.js";
|
4
4
|
import { TEST_CLIENT } from "~test/test-clients.js";
|
5
5
|
import { TEST_ACCOUNT_C } from "~test/test-wallets.js";
|
6
|
-
import { getContract } from "
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
import {
|
10
|
-
import {
|
11
|
-
import {
|
12
|
-
import { propose } from "
|
13
|
-
import { getAll } from "./getAll.js";
|
14
|
-
import { proposalExists } from "./proposalExists.js";
|
6
|
+
import { getContract } from "../../contract/contract.js";
|
7
|
+
import { sendAndConfirmTransaction } from "../../transaction/actions/send-and-confirm-transaction.js";
|
8
|
+
import { delegate } from "../erc20/__generated__/IVotes/write/delegate.js";
|
9
|
+
import { mintTo } from "../erc20/write/mintTo.js";
|
10
|
+
import { deployERC20Contract } from "../prebuilts/deploy-erc20.js";
|
11
|
+
import { deployVoteContract } from "../prebuilts/deploy-vote.js";
|
12
|
+
import { propose } from "./__generated__/Vote/write/propose.js";
|
13
|
+
import { getAll } from "./read/getAll.js";
|
14
|
+
import { proposalExists } from "./read/proposalExists.js";
|
15
15
|
|
16
16
|
const account = TEST_ACCOUNT_C;
|
17
17
|
const client = TEST_CLIENT;
|
18
18
|
const chain = ANVIL_CHAIN;
|
19
19
|
|
20
20
|
describe.runIf(process.env.TW_SECRET_KEY)("proposal exists", () => {
|
21
|
-
it("
|
21
|
+
it("`proposalExists` and `propose` should work", async () => {
|
22
22
|
const tokenAddress = await deployERC20Contract({
|
23
23
|
client: TEST_CLIENT,
|
24
24
|
chain: ANVIL_CHAIN,
|
@@ -42,47 +42,16 @@ describe.runIf(process.env.TW_SECRET_KEY)("proposal exists", () => {
|
|
42
42
|
minVoteQuorumRequiredPercent: 51,
|
43
43
|
},
|
44
44
|
});
|
45
|
-
|
46
|
-
const contract = getContract({
|
45
|
+
const voteContract = getContract({
|
47
46
|
address,
|
48
47
|
chain,
|
49
48
|
client,
|
50
49
|
});
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
});
|
55
|
-
|
56
|
-
it("should return true if Vote has the proposal (id)", async () => {
|
57
|
-
const tokenAddress = await deployERC20Contract({
|
58
|
-
client: TEST_CLIENT,
|
59
|
-
chain: ANVIL_CHAIN,
|
60
|
-
account,
|
61
|
-
type: "TokenERC20",
|
62
|
-
params: {
|
63
|
-
name: "Token",
|
64
|
-
contractURI: TEST_CONTRACT_URI,
|
65
|
-
},
|
66
|
-
});
|
67
|
-
const address = await deployVoteContract({
|
68
|
-
account,
|
69
|
-
client: TEST_CLIENT,
|
70
|
-
chain: ANVIL_CHAIN,
|
71
|
-
params: {
|
72
|
-
name: "",
|
73
|
-
contractURI: TEST_CONTRACT_URI,
|
74
|
-
tokenAddress: tokenAddress,
|
75
|
-
initialProposalThreshold: "0.5",
|
76
|
-
initialVotingPeriod: 10,
|
77
|
-
minVoteQuorumRequiredPercent: 51,
|
78
|
-
},
|
79
|
-
});
|
80
|
-
|
81
|
-
const contract = getContract({
|
82
|
-
address,
|
83
|
-
chain,
|
84
|
-
client,
|
50
|
+
const result = await proposalExists({
|
51
|
+
contract: voteContract,
|
52
|
+
proposalId: 0n,
|
85
53
|
});
|
54
|
+
expect(result).toBe(false);
|
86
55
|
|
87
56
|
const tokenContract = getContract({
|
88
57
|
address: tokenAddress,
|
@@ -105,19 +74,19 @@ describe.runIf(process.env.TW_SECRET_KEY)("proposal exists", () => {
|
|
105
74
|
|
106
75
|
// step 3: create a proposal
|
107
76
|
const transaction = propose({
|
108
|
-
contract,
|
77
|
+
contract: voteContract,
|
109
78
|
description: "first proposal",
|
110
|
-
targets: [
|
79
|
+
targets: [voteContract.address],
|
111
80
|
values: [0n],
|
112
81
|
calldatas: ["0x"],
|
113
82
|
});
|
114
83
|
await sendAndConfirmTransaction({ transaction, account });
|
115
|
-
const allProposals = await getAll({ contract });
|
84
|
+
const allProposals = await getAll({ contract: voteContract });
|
116
85
|
expect(allProposals.length).toBe(1);
|
117
|
-
const
|
118
|
-
contract,
|
86
|
+
const exists = await proposalExists({
|
87
|
+
contract: voteContract,
|
119
88
|
proposalId: allProposals[0]?.proposalId || -1n,
|
120
89
|
});
|
121
|
-
expect(
|
90
|
+
expect(exists).toBe(true);
|
122
91
|
});
|
123
92
|
});
|
@@ -23,9 +23,9 @@ const githubIconUri =
|
|
23
23
|
"";
|
24
24
|
const xIcon =
|
25
25
|
"";
|
26
|
-
|
26
|
+
const emailIcon =
|
27
27
|
"";
|
28
|
-
|
28
|
+
const phoneIcon =
|
29
29
|
"";
|
30
30
|
export const genericTokenIcon =
|
31
31
|
"";
|
@@ -33,7 +33,7 @@ const guestIcon =
|
|
33
33
|
"";
|
34
34
|
export const genericWalletIcon =
|
35
35
|
"";
|
36
|
-
|
36
|
+
const passkeyIcon =
|
37
37
|
"";
|
38
38
|
|
39
39
|
export const socialIcons = {
|
@@ -16,7 +16,6 @@ import {
|
|
16
16
|
radius,
|
17
17
|
spacing,
|
18
18
|
} from "../../../core/design-system/index.js";
|
19
|
-
import { genericWalletIcon } from "../../../core/utils/walletIcon.js";
|
20
19
|
import { useSetSelectionData } from "../../providers/wallet-ui-states-provider.js";
|
21
20
|
import { sortWallets } from "../../utils/sortWallets.js";
|
22
21
|
import { LoadingScreen } from "../../wallets/shared/LoadingScreen.js";
|
@@ -42,6 +41,7 @@ import { PoweredByThirdweb } from "./PoweredByTW.js";
|
|
42
41
|
import { WalletButtonEl, WalletEntryButton } from "./WalletEntryButton.js";
|
43
42
|
import { WalletTypeRowButton } from "./WalletTypeRowButton.js";
|
44
43
|
import { compactModalMaxHeight } from "./constants.js";
|
44
|
+
import { OutlineWalletIcon } from "./icons/OutlineWalletIcon.js";
|
45
45
|
import type { ConnectLocale } from "./locale/types.js";
|
46
46
|
|
47
47
|
const InAppWalletSelectionUI = /* @__PURE__ */ lazy(
|
@@ -226,7 +226,7 @@ const WalletSelectorInner: React.FC<WalletSelectorProps> = (props) => {
|
|
226
226
|
const connectAWallet = (
|
227
227
|
<WalletTypeRowButton
|
228
228
|
client={props.client}
|
229
|
-
icon={
|
229
|
+
icon={OutlineWalletIcon}
|
230
230
|
onClick={() => {
|
231
231
|
setIsWalletGroupExpanded(true);
|
232
232
|
}}
|
@@ -1,19 +1,15 @@
|
|
1
1
|
import type { ThirdwebClient } from "../../../../client/client.js";
|
2
|
-
import {
|
3
|
-
iconSize,
|
4
|
-
radius,
|
5
|
-
spacing,
|
6
|
-
} from "../../../core/design-system/index.js";
|
2
|
+
import { iconSize, spacing } from "../../../core/design-system/index.js";
|
7
3
|
import { Text } from "../../ui/components/text.js";
|
8
|
-
import { Img } from "../components/Img.js";
|
9
4
|
import { Container } from "../components/basic.js";
|
10
5
|
import { Button } from "../components/buttons.js";
|
6
|
+
import type { IconFC } from "./icons/types.js";
|
11
7
|
|
12
8
|
type WalletTypeRowProps = {
|
13
9
|
client: ThirdwebClient;
|
14
10
|
onClick: () => void;
|
15
11
|
title: string;
|
16
|
-
icon:
|
12
|
+
icon: IconFC;
|
17
13
|
disabled?: boolean;
|
18
14
|
};
|
19
15
|
|
@@ -33,16 +29,7 @@ export function WalletTypeRowButton(props: WalletTypeRowProps) {
|
|
33
29
|
disabled={props.disabled}
|
34
30
|
>
|
35
31
|
<Container flex="row" gap="sm" center="y" color="accentText">
|
36
|
-
<
|
37
|
-
client={props.client}
|
38
|
-
src={props.icon}
|
39
|
-
width={iconSize.md}
|
40
|
-
height={iconSize.md}
|
41
|
-
loading="eager"
|
42
|
-
style={{
|
43
|
-
borderRadius: radius.md,
|
44
|
-
}}
|
45
|
-
/>
|
32
|
+
<props.icon size={iconSize.md} />
|
46
33
|
<Text color="primaryText">{props.title}</Text>
|
47
34
|
</Container>
|
48
35
|
</Button>
|
@@ -0,0 +1,30 @@
|
|
1
|
+
import type { IconFC } from "./types.js";
|
2
|
+
|
3
|
+
/**
|
4
|
+
* @internal
|
5
|
+
*/
|
6
|
+
export const EmailIcon: IconFC = (props) => {
|
7
|
+
return (
|
8
|
+
<svg
|
9
|
+
width={props.size}
|
10
|
+
height={props.size}
|
11
|
+
viewBox="0 0 16 16"
|
12
|
+
fill="none"
|
13
|
+
xmlns="http://www.w3.org/2000/svg"
|
14
|
+
role="presentation"
|
15
|
+
>
|
16
|
+
<path
|
17
|
+
d="M13.3335 2.6665H2.66683C1.93045 2.6665 1.3335 3.26346 1.3335 3.99984V11.9998C1.3335 12.7362 1.93045 13.3332 2.66683 13.3332H13.3335C14.0699 13.3332 14.6668 12.7362 14.6668 11.9998V3.99984C14.6668 3.26346 14.0699 2.6665 13.3335 2.6665Z"
|
18
|
+
stroke={props.color ?? "currentColor"}
|
19
|
+
strokeLinecap="round"
|
20
|
+
strokeLinejoin="round"
|
21
|
+
/>
|
22
|
+
<path
|
23
|
+
d="M14.6668 4.6665L8.68683 8.4665C8.48101 8.59545 8.24304 8.66384 8.00016 8.66384C7.75728 8.66384 7.51931 8.59545 7.3135 8.4665L1.3335 4.6665"
|
24
|
+
stroke={props.color ?? "currentColor"}
|
25
|
+
strokeLinecap="round"
|
26
|
+
strokeLinejoin="round"
|
27
|
+
/>
|
28
|
+
</svg>
|
29
|
+
);
|
30
|
+
};
|
@@ -11,63 +11,63 @@ export const FingerPrintIcon: IconFC = (props) => {
|
|
11
11
|
>
|
12
12
|
<path
|
13
13
|
d="M18.0001 15C17.2045 15 16.4414 15.3161 15.8788 15.8787C15.3162 16.4413 15.0001 17.2044 15.0001 18C15.0001 19.53 14.8501 21.765 14.6101 24"
|
14
|
-
stroke="currentColor"
|
14
|
+
stroke={props.color ?? "currentColor"}
|
15
15
|
strokeWidth="3"
|
16
16
|
strokeLinecap="round"
|
17
17
|
strokeLinejoin="round"
|
18
18
|
/>
|
19
19
|
<path
|
20
20
|
d="M21.0002 19.6801C21.0002 23.2501 21.0002 29.2501 19.5002 33.0001"
|
21
|
-
stroke="currentColor"
|
21
|
+
stroke={props.color ?? "currentColor"}
|
22
22
|
strokeWidth="3"
|
23
23
|
strokeLinecap="round"
|
24
24
|
strokeLinejoin="round"
|
25
25
|
/>
|
26
26
|
<path
|
27
27
|
d="M25.9348 31.53C26.1148 30.63 26.5798 28.08 26.6848 27"
|
28
|
-
stroke="currentColor"
|
28
|
+
stroke={props.color ?? "currentColor"}
|
29
29
|
strokeWidth="3"
|
30
30
|
strokeLinecap="round"
|
31
31
|
strokeLinejoin="round"
|
32
32
|
/>
|
33
33
|
<path
|
34
34
|
d="M2.99976 18C2.99976 14.8518 3.99032 11.7833 5.83112 9.22935C7.67193 6.67536 10.2697 4.76531 13.2563 3.76975C16.243 2.77419 19.4672 2.74359 22.4723 3.6823C25.4773 4.621 28.1108 6.48141 29.9998 9"
|
35
|
-
stroke="currentColor"
|
35
|
+
stroke={props.color ?? "currentColor"}
|
36
36
|
strokeWidth="3"
|
37
37
|
strokeLinecap="round"
|
38
38
|
strokeLinejoin="round"
|
39
39
|
/>
|
40
40
|
<path
|
41
41
|
d="M2.99976 24H3.01628"
|
42
|
-
stroke="currentColor"
|
42
|
+
stroke={props.color ?? "currentColor"}
|
43
43
|
strokeWidth="3"
|
44
44
|
strokeLinecap="round"
|
45
45
|
strokeLinejoin="round"
|
46
46
|
/>
|
47
47
|
<path
|
48
48
|
d="M32.7 24C33 21 32.8965 15.969 32.7 15"
|
49
|
-
stroke="currentColor"
|
49
|
+
stroke={props.color ?? "currentColor"}
|
50
50
|
strokeWidth="3"
|
51
51
|
strokeLinecap="round"
|
52
52
|
strokeLinejoin="round"
|
53
53
|
/>
|
54
54
|
<path
|
55
55
|
d="M7.49976 29.25C8.24976 27 8.99976 22.5 8.99976 18C8.99824 16.9783 9.17071 15.9638 9.50976 15"
|
56
|
-
stroke="currentColor"
|
56
|
+
stroke={props.color ?? "currentColor"}
|
57
57
|
strokeWidth="3"
|
58
58
|
strokeLinecap="round"
|
59
59
|
strokeLinejoin="round"
|
60
60
|
/>
|
61
61
|
<path
|
62
62
|
d="M12.9751 33C13.2901 32.01 13.6501 31.02 13.8301 30"
|
63
|
-
stroke="currentColor"
|
63
|
+
stroke={props.color ?? "currentColor"}
|
64
64
|
strokeWidth="3"
|
65
65
|
strokeLinecap="round"
|
66
66
|
strokeLinejoin="round"
|
67
67
|
/>
|
68
68
|
<path
|
69
69
|
d="M13.5 10.2C14.8686 9.40988 16.4211 8.99401 18.0014 8.99426C19.5818 8.99452 21.1342 9.41088 22.5025 10.2015C23.8708 10.9921 25.0069 12.129 25.7964 13.498C26.5859 14.867 27.001 16.4197 27 18V21"
|
70
|
-
stroke="currentColor"
|
70
|
+
stroke={props.color ?? "currentColor"}
|
71
71
|
strokeWidth="3"
|
72
72
|
strokeLinecap="round"
|
73
73
|
strokeLinejoin="round"
|
@@ -0,0 +1,24 @@
|
|
1
|
+
import type { IconFC } from "./types.js";
|
2
|
+
|
3
|
+
/**
|
4
|
+
* @internal
|
5
|
+
*/
|
6
|
+
export const GuestIcon: IconFC = (props) => {
|
7
|
+
return (
|
8
|
+
<svg
|
9
|
+
xmlns="http://www.w3.org/2000/svg"
|
10
|
+
width={props.size}
|
11
|
+
height={props.size}
|
12
|
+
viewBox="0 0 24 24"
|
13
|
+
fill="none"
|
14
|
+
stroke={props.color ?? "currentColor"}
|
15
|
+
strokeWidth="2"
|
16
|
+
strokeLinecap="round"
|
17
|
+
strokeLinejoin="round"
|
18
|
+
role="presentation"
|
19
|
+
>
|
20
|
+
<path d="M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2" />
|
21
|
+
<circle cx="12" cy="7" r="4" />
|
22
|
+
</svg>
|
23
|
+
);
|
24
|
+
};
|
@@ -15,14 +15,14 @@ export const OutlineWalletIcon: IconFC = (props) => {
|
|
15
15
|
>
|
16
16
|
<path
|
17
17
|
d="M19 7V4C19 3.73478 18.8946 3.48043 18.7071 3.29289C18.5196 3.10536 18.2652 3 18 3H5C4.46957 3 3.96086 3.21071 3.58579 3.58579C3.21071 3.96086 3 4.46957 3 5C3 5.53043 3.21071 6.03914 3.58579 6.41421C3.96086 6.78929 4.46957 7 5 7H20C20.2652 7 20.5196 7.10536 20.7071 7.29289C20.8946 7.48043 21 7.73478 21 8V12M21 12H18C17.4696 12 16.9609 12.2107 16.5858 12.5858C16.2107 12.9609 16 13.4696 16 14C16 14.5304 16.2107 15.0391 16.5858 15.4142C16.9609 15.7893 17.4696 16 18 16H21C21.2652 16 21.5196 15.8946 21.7071 15.7071C21.8946 15.5196 22 15.2652 22 15V13C22 12.7348 21.8946 12.4804 21.7071 12.2929C21.5196 12.1054 21.2652 12 21 12Z"
|
18
|
-
stroke="currentColor"
|
18
|
+
stroke={props.color ?? "currentColor"}
|
19
19
|
strokeWidth="1.5"
|
20
20
|
strokeLinecap="round"
|
21
21
|
strokeLinejoin="round"
|
22
22
|
/>
|
23
23
|
<path
|
24
24
|
d="M3 5V19C3 19.5304 3.21071 20.0391 3.58579 20.4142C3.96086 20.7893 4.46957 21 5 21H20C20.2652 21 20.5196 20.8946 20.7071 20.7071C20.8946 20.5196 21 20.2652 21 20V16"
|
25
|
-
stroke="currentColor"
|
25
|
+
stroke={props.color ?? "currentColor"}
|
26
26
|
strokeWidth="1.5"
|
27
27
|
strokeLinecap="round"
|
28
28
|
strokeLinejoin="round"
|
@@ -0,0 +1,32 @@
|
|
1
|
+
import type { IconFC } from "./types.js";
|
2
|
+
|
3
|
+
/**
|
4
|
+
* @internal
|
5
|
+
*/
|
6
|
+
export const PhoneIcon: IconFC = (props) => {
|
7
|
+
return (
|
8
|
+
<svg
|
9
|
+
width={props.size}
|
10
|
+
height={props.size}
|
11
|
+
viewBox="0 0 16 16"
|
12
|
+
fill="none"
|
13
|
+
xmlns="http://www.w3.org/2000/svg"
|
14
|
+
role="presentation"
|
15
|
+
>
|
16
|
+
<g clipPath="url(#clip0_5639_632)">
|
17
|
+
<path
|
18
|
+
d="M14.6669 11.2802V13.2802C14.6677 13.4659 14.6297 13.6497 14.5553 13.8198C14.4809 13.9899 14.3718 14.1426 14.235 14.2681C14.0982 14.3937 13.9367 14.4892 13.7608 14.5487C13.5849 14.6082 13.3985 14.6303 13.2136 14.6136C11.1622 14.3907 9.19161 13.6897 7.46028 12.5669C5.8495 11.5433 4.48384 10.1777 3.46028 8.56689C2.3336 6.8277 1.63244 4.84756 1.41361 2.78689C1.39695 2.60254 1.41886 2.41673 1.47795 2.24131C1.53703 2.06589 1.63199 1.90469 1.75679 1.76797C1.88159 1.63126 2.03348 1.52203 2.20281 1.44724C2.37213 1.37245 2.55517 1.33374 2.74028 1.33356H4.74028C5.06382 1.33038 5.37748 1.44495 5.62279 1.65592C5.8681 1.86689 6.02833 2.15986 6.07361 2.48023C6.15803 3.12027 6.31458 3.74871 6.54028 4.35356C6.62998 4.59218 6.64939 4.8515 6.59622 5.10081C6.54305 5.35012 6.41952 5.57897 6.24028 5.76023L5.39361 6.60689C6.34265 8.27592 7.72458 9.65786 9.39361 10.6069L10.2403 9.76023C10.4215 9.58099 10.6504 9.45746 10.8997 9.40429C11.149 9.35112 11.4083 9.37053 11.6469 9.46023C12.2518 9.68593 12.8802 9.84248 13.5203 9.92689C13.8441 9.97258 14.1399 10.1357 14.3513 10.3852C14.5627 10.6348 14.6751 10.9533 14.6669 11.2802Z"
|
19
|
+
stroke={props.color ?? "currentColor"}
|
20
|
+
strokeWidth="1.33333"
|
21
|
+
strokeLinecap="round"
|
22
|
+
strokeLinejoin="round"
|
23
|
+
/>
|
24
|
+
</g>
|
25
|
+
<defs>
|
26
|
+
<clipPath id="clip0_5639_632">
|
27
|
+
<rect width="16" height="16" fill="white" />
|
28
|
+
</clipPath>
|
29
|
+
</defs>
|
30
|
+
</svg>
|
31
|
+
);
|
32
|
+
};
|
@@ -1 +1 @@
|
|
1
|
-
export type IconFC = React.FC<{ size: string }>;
|
1
|
+
export type IconFC = React.FC<{ size: string; color?: string }>;
|
@@ -14,6 +14,9 @@ import { Text } from "../../components/text.js";
|
|
14
14
|
import { Blobbie } from "../Blobbie.js";
|
15
15
|
import { MenuButton } from "../MenuButton.js";
|
16
16
|
import { AddUserIcon } from "../icons/AddUserIcon.js";
|
17
|
+
import { EmailIcon } from "../icons/EmailIcon.js";
|
18
|
+
import { FingerPrintIcon } from "../icons/FingerPrintIcon.js";
|
19
|
+
import { PhoneIcon } from "../icons/PhoneIcon.js";
|
17
20
|
import type { ConnectLocale } from "../locale/types.js";
|
18
21
|
import type { WalletDetailsModalScreen } from "./types.js";
|
19
22
|
|
@@ -84,7 +87,7 @@ export function LinkedProfilesScreen(props: {
|
|
84
87
|
fontSize: fontSize.sm,
|
85
88
|
}}
|
86
89
|
>
|
87
|
-
<AddUserIcon size={iconSize.
|
90
|
+
<AddUserIcon size={iconSize.lg} />
|
88
91
|
<Text color="primaryText">
|
89
92
|
{props.locale.manageWallet.linkProfile}
|
90
93
|
</Text>
|
@@ -147,6 +150,12 @@ function LinkedProfile({
|
|
147
150
|
>
|
148
151
|
<Blobbie address={profile.details.address} size={32} />
|
149
152
|
</Container>
|
153
|
+
) : profile.type === "passkey" ? (
|
154
|
+
<FingerPrintIcon size={iconSize.lg} />
|
155
|
+
) : profile.type === "email" ? (
|
156
|
+
<EmailIcon size={iconSize.lg} />
|
157
|
+
) : profile.type === "phone" ? (
|
158
|
+
<PhoneIcon size={iconSize.lg} />
|
150
159
|
) : (
|
151
160
|
<Img
|
152
161
|
src={getSocialIcon(profile.type)}
|