From ea6ee89809447e7232da54043dc1ea067e19edfe Mon Sep 17 00:00:00 2001 From: 0xFirekeeper <0xFirekeeper@gmail.com> Date: Sat, 1 Nov 2025 05:57:22 +0700 Subject: [PATCH 1/4] Add Epic Games as new auth provider Introduces Epic Games ('epic') as a supported authentication provider across dashboard, portal, playground, and analytics chart components. Adds the EpicIcon SVG, updates type definitions, test coverage, and icon mapping to support the new provider. --- apps/dashboard/src/@/api/team/ecosystems.ts | 3 ++- .../src/@/icons/brand-icons/EpicIcon.tsx | 18 ++++++++++++++++++ .../client/auth-options-form.client.tsx | 1 + .../InAppWalletUsersChartCard.stories.tsx | 1 + .../components/InAppWalletFormGroup.tsx | 1 + .../src/components/Document/AuthList.tsx | 1 + .../src/react/core/utils/walletIcon.test.ts | 4 ++++ .../src/react/core/utils/walletIcon.ts | 5 +++++ .../react/native/ui/components/WalletImage.tsx | 3 +++ .../react/native/ui/connect/InAppWalletUI.tsx | 2 ++ .../thirdweb/src/react/native/ui/icons/svgs.ts | 5 +++++ .../shared/ConnectWalletSocialOptions.tsx | 1 + .../react/web/wallets/shared/oauthSignIn.ts | 1 + .../src/stories/ConnectEmbed.stories.tsx | 1 + .../in-app/core/authentication/types.ts | 1 + .../wallets/in-app/native/native-connector.ts | 1 + .../wallets/in-app/web/lib/web-connector.ts | 2 ++ packages/thirdweb/src/wallets/types.ts | 1 + 18 files changed, 51 insertions(+), 1 deletion(-) create mode 100644 apps/dashboard/src/@/icons/brand-icons/EpicIcon.tsx diff --git a/apps/dashboard/src/@/api/team/ecosystems.ts b/apps/dashboard/src/@/api/team/ecosystems.ts index 5220e51d1a1..c0aed4fd47e 100644 --- a/apps/dashboard/src/@/api/team/ecosystems.ts +++ b/apps/dashboard/src/@/api/team/ecosystems.ts @@ -21,7 +21,8 @@ export type AuthOption = | "steam" | "apple" | "coinbase" - | "line"; + | "line" + | "epic"; export type Ecosystem = { name: string; diff --git a/apps/dashboard/src/@/icons/brand-icons/EpicIcon.tsx b/apps/dashboard/src/@/icons/brand-icons/EpicIcon.tsx new file mode 100644 index 00000000000..5d9a881dda1 --- /dev/null +++ b/apps/dashboard/src/@/icons/brand-icons/EpicIcon.tsx @@ -0,0 +1,18 @@ +import type { SVGProps } from "react"; + +export const EpicIcon = (props: SVGProps) => { + return ( + + Epic Games + + + ); +}; diff --git a/apps/dashboard/src/app/(app)/team/[team_slug]/(team)/~/ecosystem/[slug]/(active)/configuration/components/client/auth-options-form.client.tsx b/apps/dashboard/src/app/(app)/team/[team_slug]/(team)/~/ecosystem/[slug]/(active)/configuration/components/client/auth-options-form.client.tsx index 7907f9ce133..7ca148f25c8 100644 --- a/apps/dashboard/src/app/(app)/team/[team_slug]/(team)/~/ecosystem/[slug]/(active)/configuration/components/client/auth-options-form.client.tsx +++ b/apps/dashboard/src/app/(app)/team/[team_slug]/(team)/~/ecosystem/[slug]/(active)/configuration/components/client/auth-options-form.client.tsx @@ -58,6 +58,7 @@ const authOptions = [ "apple", "coinbase", "line", + "epic", ] as const satisfies AuthOption[]; type AuthOptionsFormData = { diff --git a/apps/dashboard/src/app/(app)/team/[team_slug]/[project_slug]/(sidebar)/wallets/analytics/chart/InAppWalletUsersChartCard.stories.tsx b/apps/dashboard/src/app/(app)/team/[team_slug]/[project_slug]/(sidebar)/wallets/analytics/chart/InAppWalletUsersChartCard.stories.tsx index a0ebb56d6e0..0da4d996b3d 100644 --- a/apps/dashboard/src/app/(app)/team/[team_slug]/[project_slug]/(sidebar)/wallets/analytics/chart/InAppWalletUsersChartCard.stories.tsx +++ b/apps/dashboard/src/app/(app)/team/[team_slug]/[project_slug]/(sidebar)/wallets/analytics/chart/InAppWalletUsersChartCard.stories.tsx @@ -87,6 +87,7 @@ const authMethodsToPickFrom: InAppWalletAuth[] = [ "line", "x", "tiktok", + "epic", "coinbase", "farcaster", "telegram", diff --git a/apps/playground-web/src/app/wallets/sign-in/components/InAppWalletFormGroup.tsx b/apps/playground-web/src/app/wallets/sign-in/components/InAppWalletFormGroup.tsx index c4bdc1834ed..0876dd2f19f 100644 --- a/apps/playground-web/src/app/wallets/sign-in/components/InAppWalletFormGroup.tsx +++ b/apps/playground-web/src/app/wallets/sign-in/components/InAppWalletFormGroup.tsx @@ -20,6 +20,7 @@ const allInAppWalletLoginMethods: InAppWalletAuth[] = [ "line", "x", "tiktok", + "epic", "facebook", "apple", "coinbase", diff --git a/apps/portal/src/components/Document/AuthList.tsx b/apps/portal/src/components/Document/AuthList.tsx index bed6db4802b..2809d7d37d5 100644 --- a/apps/portal/src/components/Document/AuthList.tsx +++ b/apps/portal/src/components/Document/AuthList.tsx @@ -15,6 +15,7 @@ const authOptions: InAppWalletAuth[] = [ "facebook", "x", "tiktok", + "epic", "discord", "telegram", "twitch", diff --git a/packages/thirdweb/src/react/core/utils/walletIcon.test.ts b/packages/thirdweb/src/react/core/utils/walletIcon.test.ts index 239470dec27..505ad32e044 100644 --- a/packages/thirdweb/src/react/core/utils/walletIcon.test.ts +++ b/packages/thirdweb/src/react/core/utils/walletIcon.test.ts @@ -55,6 +55,10 @@ describe("walletIcon", () => { expect(getSocialIcon("tiktok")).toBe(socialIcons.tiktok); }); + it("should return epic icon", () => { + expect(getSocialIcon("epic")).toBe(socialIcons.epic); + }); + it("should return farcaster icon", () => { expect(getSocialIcon("farcaster")).toBe(socialIcons.farcaster); }); diff --git a/packages/thirdweb/src/react/core/utils/walletIcon.ts b/packages/thirdweb/src/react/core/utils/walletIcon.ts index 9ee3e6ff5b3..9d22288c056 100644 --- a/packages/thirdweb/src/react/core/utils/walletIcon.ts +++ b/packages/thirdweb/src/react/core/utils/walletIcon.ts @@ -31,6 +31,8 @@ const xIcon = "data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzIwIiBoZWlnaHQ9IjMyMCIgdmlld0JveD0iMCAwIDMyMCAzMjAiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxyZWN0IHdpZHRoPSIzMjAiIGhlaWdodD0iMzIwIiByeD0iMjQiIGZpbGw9ImJsYWNrIi8+CjxwYXRoIGQ9Ik0xNzcuMzE1IDE0NS4zMzVMMjQ1LjA2OCA2N0gyMjkuMDEzTDE3MC4xODIgMTM1LjAxN0wxMjMuMTk1IDY3SDY5TDE0MC4wNTUgMTY5Ljg1NEw2OSAyNTJIODUuMDU2M0wxNDcuMTgzIDE4MC4xNzJMMTk2LjgwNSAyNTJIMjUxTDE3Ny4zMTEgMTQ1LjMzNUgxNzcuMzE1Wk0xNTUuMzIzIDE3MC43NkwxNDguMTI0IDE2MC41MThMOTAuODQxNyA3OS4wMjJIMTE1LjUwM0wxNjEuNzMxIDE0NC43OTJMMTY4LjkzIDE1NS4wMzRMMjI5LjAyIDI0MC41MjVIMjA0LjM1OUwxNTUuMzIzIDE3MC43NjRWMTcwLjc2WiIgZmlsbD0id2hpdGUiLz4KPC9zdmc+Cg=="; const tiktokIconUri = "data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 1200" xml:space="preserve">
  <path d="M636 1201c-23.02 0-46.042 0-69.697-.408-9.794-1.135-18.996-1.518-28.101-2.665-16.424-2.067-32.96-3.775-49.14-7.126-21.696-4.494-43.236-9.907-64.589-15.842-24.26-6.743-47.645-16.02-70.577-26.48-26.226-11.963-51.913-24.964-75.798-41.098-18.746-12.663-37.057-26.04-54.899-39.948-13.55-10.563-26.729-21.791-38.866-33.93-16.19-16.19-31.658-33.162-46.582-50.532-10.965-12.762-21.21-26.265-30.597-40.23-11.379-16.925-22.178-34.321-32.01-52.185-10.136-18.42-19.628-37.295-27.917-56.608-10.741-25.025-19.931-50.724-26.214-77.307-4.592-19.427-9.298-38.863-12.813-58.499-2.666-14.892-3.5-30.11-5.272-45.167C2.804 651.922 1.666 650.989 1 650c0-.444 0-.889.399-1.82.133-3.718-.133-6.95-.399-10.18 0-24.354 0-48.708.399-73.685.133-3.853-.133-7.084-.399-10.315 0-.444 0-.889.391-1.79.795-1.138 1.485-1.789 1.56-2.503.74-7.156 1.246-14.338 2.08-21.482 1.228-10.5 2.029-21.107 4.163-31.43 3.81-18.426 8.303-36.717 12.827-54.986 7.885-31.84 19.404-62.467 33.213-92.111 15.375-33.007 33.353-64.584 54.523-94.385 16.364-23.036 34.177-44.8 53.217-65.565 9.735-10.617 20.589-20.213 31.01-30.195 17.23-16.506 35.882-31.25 55.142-45.33 21.897-16.009 44.647-30.678 68.73-43.01 20.828-10.668 42.118-20.665 63.9-29.177 21.745-8.498 44.171-15.426 66.636-21.863 23.921-6.854 48.354-11.728 73.19-14.18 13.824-1.365 27.658-2.65 41.482-4.024 1-.1 1.958-.636 2.936-.969 23.02 0 46.042 0 69.697.408 9.797 1.135 19.003 1.513 28.111 2.666 16.264 2.06 32.634 3.789 48.657 7.113 21.86 4.536 43.576 9.936 65.1 15.883 24.28 6.71 47.641 16.069 70.607 26.474 25.976 11.77 51.082 25.118 75.15 40.36 32.09 20.324 61.967 43.626 89.55 69.698 13.695 12.945 26.62 26.796 39.004 41.012 12.49 14.339 24.027 29.523 35.715 44.544 16.174 20.787 29.734 43.324 42.177 66.442 19.589 36.397 35.554 74.418 47.076 114.153 4.741 16.352 8.538 33.01 12.039 49.68 2.925 13.93 5.164 28.033 7.024 42.15 1.815 13.768 2.75 27.652 4.124 41.48.1 1.001.636 1.96.969 2.937 0 23.02 0 46.042-.408 69.697-1.135 9.797-1.513 19.003-2.666 28.111-2.06 16.264-3.817 32.626-7.107 48.659-4.458 21.721-9.613 43.347-15.616 64.691-7.163 25.472-16.875 50.11-28 74.127-11.978 25.858-25.473 50.926-40.918 74.893a598.5 598.5 0 0 1-67.89 86.69c-12.933 13.705-26.792 26.624-41.008 39.007-14.34 12.491-29.523 24.028-44.545 35.716-20.786 16.174-43.323 29.734-66.442 42.177-36.397 19.589-74.418 35.554-114.153 47.076-16.352 4.741-33.01 8.538-49.68 12.039-13.93 2.925-28.034 5.164-42.15 7.025-13.768 1.814-27.652 2.748-41.48 4.123-1.001.1-1.96.636-2.937.969m179.934-855.948s-.024.087.04-.643c-1.288-1.67-2.63-3.3-3.858-5.014-9.688-13.519-17.965-27.82-24.114-43.317-6.333-15.96-10.648-32.397-12.004-49.556-.504-6.367-1-12.733-1.52-19.373-11.75 0-23.52 0-35.436-.185 0 0-.186-.146-.463-.886l-3.492-32.856H600v6.085c0 177.079-.017 354.157.029 531.236.004 15.602-3.893 30.314-10.476 44.184-11.668 24.58-29.91 42.805-54.753 54.333-23.586 10.945-47.958 13.654-73.132 7.113-8.04-2.089-15.788-5.306-24.265-8.253-.8-.695-1.6-1.39-2.422-2.79-26.17-40.707-28.596-83.111-2.248-123.477 30.059-46.051 74.249-61.208 127.89-47.878V515.307c-13.05-.393-25.742-.776-38.58-1.343 0 0-.187-.145-.058-1.05V481.49c-11.386-.504-22.53-1.623-33.636-1.333-14.45.376-29.038.845-43.264 3.147-17.186 2.781-33.887 7.878-50.142 14.54-27.694 11.35-52.639 26.837-74.434 47.277-7.485 7.02-14.475 14.604-21.309 22.272-11.064 12.415-20.237 26.187-28.242 40.764-11.36 20.685-19.97 42.481-24.678 65.555-2.765 13.548-3.827 27.469-5.173 41.269-.627 6.432-.44 12.997-.035 19.465.76 12.115 1.029 24.367 3.142 36.27 4.862 27.378 13.983 53.374 27.8 77.658 14.64 25.73 33.024 48.343 55.525 67.563 3.901 3.332 8.331 6.046 12.489 9.034 0 0-.013-.027.04.56.59.49 1.178.981 2.058 2.111 2.29 1.842 4.581 3.683 7.092 6.08.642.4 1.284.798 1.843 1.23 0 0 .012-.088.07.601 12.774 10.521 25.01 21.794 38.443 31.39 21.08 15.056 44.63 25.435 69.53 32.61 18.43 5.312 37.312 8.363 56.415 9.32 18.471.927 36.867-.568 55.145-3.795 27.01-4.77 52.449-13.707 76.404-27.059 26.103-14.548 48.825-33.126 68.297-55.807 12.829-14.944 24.21-30.913 32.525-48.702 6.58-14.08 12.012-28.762 17.03-43.491 6.907-20.265 9.805-41.48 9.903-62.731.417-90.143.177-180.288.177-270.433v-6.744c56.65 38.92 118.038 58.966 185.743 58.985v-134.52c-8.586-.876-16.904-1.676-25.209-2.595-4.524-.5-9.025-1.203-14.08-2.025-.206-.317-.413-.635-.226-1.719v-27.745c-7.818-.82-15.788-1.66-23.759-2.489-13.918-1.446-27.44-4.758-40.306-10.105-11.017-4.578-21.605-10.19-32.466-15.474 0 0-.234-.2-.664-.823a21 21 0 0 1-2.68-.732c-1.173-1.288-2.346-2.577-3.53-4.487-.659-.435-1.318-.87-1.889-1.33" style="--darkreader-inline-fill:var(--darkreader-background-000000, #000000);--darkreader-inline-stroke:none;visibility:visible;opacity:1" data-index="0"/>
  <path fill="#FFF" d="M1 554.454c.266 2.777.532 6.008.399 9.392C1 560.97 1 557.94 1 554.454" style="--darkreader-inline-fill:var(--darkreader-text-ffffff, #e8e6e3);--darkreader-inline-stroke:none;visibility:visible" data-index="5"/>
  <path fill="#FFF" d="M1 638.454c.266 2.777.532 6.008.399 9.392C1 644.97 1 641.94 1 638.454" style="--darkreader-inline-fill:var(--darkreader-text-ffffff, #e8e6e3);--darkreader-inline-stroke:none;visibility:visible" data-index="6"/>
  <path fill="#FFF" d="M824.463 352.222s.234.2.054.629c4.898 5.362 9.857 10.425 15.075 15.206 15.25 13.971 32.694 24.556 51.923 31.964 9.514 3.666 19.53 6.029 29.319 8.98.207.319.414.637.893 1.517.272 35.135.272 69.708.272 104.579-33.866-.056-66.203-5.087-97.775-15.124-31.516-10.02-60.722-24.745-88.224-43.972 0 1.546.003 2.365 0 3.184-.333 94.235-.576 188.47-1.131 282.703-.06 10.121-1.204 20.373-3.128 30.317-3.553 18.355-9.049 36.15-16.46 53.442-11.139 25.991-26.29 49.289-45.513 69.801-9.33 9.956-19.573 19.31-30.518 27.434-12.899 9.575-26.588 18.29-40.694 25.984a190.3 190.3 0 0 1-55.31 19.838c-15.868 3.041-32.048 4.68-48.164 6.118-7.837.698-15.899-.008-23.76-.926-13.934-1.627-27.967-3.102-41.644-6.085-22.69-4.948-44.071-13.642-64.112-25.53-4.659-2.763-9.653-4.96-14.493-7.418 0 0-.012.087.214-.267-.613-.712-1.45-1.071-2.29-1.43-2.29-1.842-4.58-3.683-6.965-6.21-.734-1.129-1.376-1.57-2.017-2.013 0 0 .013.027.203-.306-.955-1.939-1.982-3.644-3.262-5.132-14.851-17.275-26.576-36.468-35.944-57.22-11.765-26.066-19.075-53.395-20.68-81.788-1.05-18.594-.009-37.478 2.01-56.024 1.938-17.818 7.118-35.131 13.6-51.985 11.205-29.126 27.276-55.285 48.44-78.064 10.084-10.854 21.325-20.812 32.968-30.003 19.507-15.399 41.233-27.072 64.695-35.554 25.828-9.337 52.403-14.302 79.811-15.048 0 0 .186.145.179.69-.007 35.459-.007 70.374-.007 105.227-9.174-1.643-17.746-3.846-26.442-4.58-13.676-1.154-27.17.723-40.32 4.855-27.888 8.764-49.401 25.83-64.106 50.88-12.789 21.786-17.637 45.469-14.277 70.815 2.07 15.618 7.008 30.076 15.189 43.394 10.66 17.353 24.75 31.236 42.93 40.734.8.696 1.6 1.391 2.712 2.554 7.455 10.522 16.336 18.817 26.535 25.637 25.406 16.989 53.322 23.509 83.396 17.793 30.44-5.785 54.497-22.187 72.193-47.516 11.275-16.139 18.851-34.328 18.938-53.982.728-164.184.893-328.37 1.22-492.556.03-15.158.004-30.317.004-45.476V227c2.5 0 4.459.003 6.417 0l92.44-.182s.185.146.178.638c-.011.99-.118 1.515-.006 1.986 4.523 19.027 10.642 37.38 20.334 54.567 11.868 21.048 27.33 38.907 45.676 54.385 3.225 2.72 7.227 4.52 10.87 6.745 0 0 .025-.087-.228.236.549.758 1.351 1.193 2.153 1.628a213 213 0 0 0 4.05 4.357c1.215.615 1.897.739 2.579.862" style="--darkreader-inline-fill:var(--darkreader-background-ffffff, #181a1b);--darkreader-inline-stroke:none;opacity:1" data-index="7"/>
  <path fill="#FE2C55" d="M351.102 935.207c4.81 2.113 9.805 4.31 14.464 7.074 20.04 11.888 41.423 20.582 64.112 25.53 13.677 2.983 27.71 4.458 41.645 6.085 7.86.918 15.922 1.624 23.759.926 16.116-1.437 32.296-3.077 48.164-6.118a190.3 190.3 0 0 0 55.31-19.838c14.106-7.695 27.795-16.409 40.694-25.984 10.945-8.125 21.187-17.478 30.518-27.434 19.223-20.512 34.374-43.81 45.513-69.8 7.411-17.294 12.907-35.088 16.46-53.443 1.924-9.944 3.068-20.196 3.128-30.317.555-94.233.798-188.468 1.13-282.703.004-.82.001-1.638.001-3.184 27.502 19.227 56.708 33.953 88.224 43.972 31.572 10.037 63.91 15.068 97.775 15.124l-.001-104.474c4.51.154 9.012.857 13.536 1.357 8.305.919 16.623 1.719 25.209 2.596v134.519c-67.705-.02-129.093-20.066-185.743-58.985v6.744c0 90.145.24 180.29-.177 270.433-.098 21.251-2.996 42.466-9.902 62.73-5.02 14.73-10.45 29.412-17.031 43.492-8.314 17.789-19.696 33.758-32.525 48.702-19.472 22.68-42.194 41.259-68.297 55.807-23.955 13.352-49.395 22.29-76.404 27.059-18.278 3.227-36.674 4.722-55.145 3.796-19.103-.958-37.984-4.009-56.415-9.32-24.9-7.176-48.45-17.555-69.53-32.611-13.434-9.596-25.67-20.869-38.472-31.735" style="--darkreader-inline-fill:var(--darkreader-background-fe2c55, #b10123);--darkreader-inline-stroke:none;visibility:visible;opacity:1" data-index="8"/>
  <path fill="#25F4EE" d="M738.718 226.448c-30.675.431-61.488.492-92.301.551-1.958.004-3.916.001-6.417.001v5.288c0 15.159.026 30.318-.004 45.476-.327 164.186-.492 328.372-1.22 492.556-.087 19.654-7.663 37.843-18.938 53.982-17.696 25.329-41.753 41.73-72.193 47.516-30.074 5.716-57.99-.804-83.396-17.793-10.199-6.82-19.08-15.115-26.237-25.514 7.868 2.356 15.616 5.573 23.656 7.662 25.174 6.541 49.546 3.832 73.132-7.113 24.843-11.528 43.085-29.753 54.753-54.333 6.583-13.87 10.48-28.582 10.476-44.184-.046-177.079-.029-354.157-.029-531.236v-6.085h135.087c1.182 11.115 2.337 21.985 3.63 33.226" style="--darkreader-inline-fill:var(--darkreader-background-25f4ee, #09b3b0);--darkreader-inline-stroke:none;opacity:1" data-index="9"/>
  <path fill="#25F4EE" d="M521.92 513.367c-27.472 1.198-54.047 6.163-79.875 15.5-23.462 8.482-45.188 20.155-64.695 35.554-11.643 9.191-22.884 19.149-32.969 30.003-21.163 22.779-37.234 48.938-48.438 78.064-6.483 16.854-11.663 34.167-13.602 51.985-2.018 18.546-3.059 37.43-2.008 56.024 1.604 28.393 8.914 55.722 20.68 81.788 9.367 20.752 21.092 39.945 35.943 57.22 1.28 1.488 2.307 3.193 3.276 5.137-4.362-2.66-8.792-5.374-12.693-8.706-22.501-19.22-40.885-41.832-55.525-67.563-13.817-24.284-22.938-50.28-27.8-77.658-2.113-11.903-2.382-24.155-3.142-36.27-.406-6.468-.592-13.033.035-19.465 1.346-13.8 2.408-27.721 5.173-41.269 4.709-23.074 13.319-44.87 24.678-65.555 8.005-14.577 17.178-28.35 28.242-40.764 6.834-7.668 13.824-15.253 21.309-22.272 21.795-20.44 46.74-35.927 74.434-47.277 16.255-6.662 32.956-11.759 50.142-14.54 14.226-2.302 28.813-2.77 43.264-3.147 11.107-.29 22.25.829 33.636 1.333 0 11.145 0 21.285-.064 31.878" style="--darkreader-inline-fill:var(--darkreader-background-25f4ee, #09b3b0);--darkreader-inline-stroke:var(--darkreader-text-0d99ff, #23a3ff);opacity:1" data-index="10"/>
  <path fill="#FE2C55" d="M434.992 825.482c-18.17-9.146-32.26-23.029-42.92-40.382-8.18-13.318-13.12-27.776-15.19-43.394-3.359-25.346 1.49-49.029 14.278-70.815 14.705-25.05 36.218-42.116 64.106-50.88 13.15-4.132 26.644-6.009 40.32-4.855 8.696.734 17.268 2.937 26.442 4.58 0-34.853 0-69.768.08-105.135 12.773-.07 25.466.313 38.514.706v138.468c-53.64-13.33-97.83 1.827-127.89 47.878-26.347 40.366-23.921 82.77 2.26 123.829" style="--darkreader-inline-fill:var(--darkreader-background-fe2c55, #b10123);--darkreader-inline-stroke:none;opacity:1" data-index="11"/>
  <path fill="#FE2C55" d="M815.942 344.774c-3.676-1.86-7.678-3.66-10.903-6.38-18.345-15.478-33.808-33.337-45.676-54.385-9.692-17.187-15.811-35.54-20.334-54.567-.112-.471-.005-.995.08-1.894 11.849-.399 23.618-.399 35.369-.399.52 6.64 1.016 13.006 1.52 19.373 1.356 17.16 5.67 33.595 12.004 49.556 6.15 15.498 14.426 29.798 24.114 43.317 1.227 1.713 2.57 3.344 3.826 5.379" style="--darkreader-inline-fill:var(--darkreader-background-fe2c55, #b10123);--darkreader-inline-stroke:none" data-index="12"/>
  <path fill="#25F4EE" d="M921.03 408.619c-9.985-2.57-20-4.932-29.515-8.598-19.23-7.408-36.673-17.993-51.923-31.964-5.218-4.78-10.177-9.844-15.033-15.141 11 4.792 21.587 10.403 32.604 14.981 12.867 5.347 26.388 8.66 40.306 10.105 7.971.828 15.94 1.67 23.759 2.49 0 9.086 0 18.415-.197 28.127" style="--darkreader-inline-fill:var(--darkreader-text-25f4ee, #36f5ef);--darkreader-inline-stroke:var(--darkreader-text-0d99ff, #23a3ff);opacity:1" data-index="13"/>
  <path fill="#FE2C55" d="M817.829 346.692a3.5 3.5 0 0 1-2.192-1.305c.868.124 1.527.559 2.192 1.305" style="--darkreader-inline-fill:var(--darkreader-text-fe2c55, #fe395f);--darkreader-inline-stroke:none" data-index="14"/>
  <path fill="#25F4EE" d="M340.042 925.237c.614.148 1.256.59 1.845 1.399-.64-.125-1.23-.615-1.845-1.4" style="--darkreader-inline-fill:var(--darkreader-text-25f4ee, #36f5ef);--darkreader-inline-stroke:none;visibility:visible" data-index="15"/>
  <path fill="#FE2C55" d="M349.108 933.443a3.66 3.66 0 0 1 2.22 1.138c-.826-.062-1.468-.46-2.22-1.138" style="--darkreader-inline-fill:var(--darkreader-text-fe2c55, #fe395f);--darkreader-inline-stroke:none;visibility:visible" data-index="16"/>
  <path fill="#25F4EE" d="M824.248 351.911c-.467.188-1.15.064-2.04-.402.47-.198 1.147-.053 2.04.402" style="--darkreader-inline-fill:var(--darkreader-text-25f4ee, #36f5ef);--darkreader-inline-stroke:none" data-index="17"/>
</svg>
"; +const epicIconUri = + "data:image/svg+xml;base64,<?xml version="1.0" encoding="utf-8"?><!-- Uploaded to: SVG Repo, www.svgrepo.com, Generator: SVG Repo Mixer Tools -->
<svg width="800px" height="800px" viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
   <circle cx="512" cy="512" r="512" style="fill:#313131"/>
   <path d="M331.4 276c-29.3 0-40.1 10.8-40.1 40.1v353.4c0 3.3.1 6.4.4 9.2.7 6.4.8 12.7 6.8 19.7.6.8 6.6 5.2 6.6 5.2 3.2 1.6 5.5 2.7 9.2 4.3l177.8 74.5c9.2 4.2 13.1 5.9 19.8 5.7h.1c6.8.2 10.6-1.5 19.8-5.7l177.8-74.5c3.7-1.5 5.9-2.6 9.2-4.3 0 0 6.1-4.5 6.6-5.2 6-7 6-13.2 6.8-19.7.3-2.8.4-5.9.4-9.2V316c0-29.3-10.8-40-40.1-40H331.4zm285 66.3h14.5c24.2 0 36 11.8 36 36.2v40.1h-29.3v-38.5c0-7.8-3.6-11.5-11.2-11.5h-5c-7.8 0-11.5 3.6-11.5 11.5v124c0 7.8 3.6 11.4 11.5 11.4h5.5c7.5 0 11.1-3.6 11.1-11.4v-44.4h29.4v45.7c0 24.4-12 36.4-36.3 36.4h-14.8c-24.3 0-36.3-12.1-36.3-36.4V378.8c.1-24.4 12.1-36.5 36.4-36.5zm-260 1.6h66.4v27.2h-36.6v55.6h35.2v27.2h-35.2v59.2h37.1v27.2h-66.9V343.9zm81.4 0h46.9c24.3 0 36.3 12.1 36.3 36.5v52.2c0 24.4-12 36.5-36.3 36.5h-16.9v71.2h-29.9l-.1-196.4zm96.6 0h29.8v196.4h-29.8V343.9zm-66.8 26.5v72.3H480c7.5 0 11.1-3.6 11.1-11.5v-49.3c0-7.9-3.6-11.5-11.1-11.5h-12.4zM385.4 587h4.4l1 .1h1.6l.8.3h.8l.8.2.8.2.7.1.7.2.7.1.8.3.6.1.6.3.8.2.6.3.8.3.7.3.6.4.8.3.6.4.8.4.6.4.7.4.6.5.6.4.6.5.7.5.6.6.6.5-.5.6-.6.6-.5.6-.6.6-.5.6-.5.6-.6.6-.5.6-.5.6-.6.6-.5.6-.6.6-.5.6-.5.6-.6.6-.5.7-.6.6-.5.6-.6-.5-.6-.6-.6-.4-.7-.5-.6-.4-.7-.4-.6-.4-.7-.4-.6-.3-.6-.3-.6-.2-.7-.3-.8-.2-.6-.2-.8-.2-.8-.2-.8-.1h-.9l-1-.2h-1.6l-.8.1h-.8l-.8.2-.7.2-.7.2-.8.2-.6.3-.8.3-.6.4-.6.4-.6.4-.6.5-.6.5-.6.5-.5.6-.6.6-.4.6-.4.6-.5.6-.3.7-.4.6-.4.7-.2.7-.3.7-.2.8-.1.8-.2.7-.2.9v.8l-.1.8v1.9l.1.8.1.7.1.8.2.8.2.6.1.8.2.6.3.6.3.8.4.8.3.6.4.6.5.7.5.6.4.6.6.6.5.6.6.5.6.5.6.5.7.4.6.4.7.3.8.3.6.3.8.2.8.3.8.1.8.2.8.1 1 .1h2.6l1-.1h.8l.8-.3.8-.1.8-.3.7-.1.7-.3.6-.3.8-.3.5-.3.6-.4v-7.4h-11.8v-11.9h26.6v26.6l-.6.5-.6.5-.6.4-.6.5-.6.4-.6.5-.6.4-.7.4-.8.4-.7.4-.6.4-.8.3-.6.4-.8.3-.8.3-.8.3-.7.3-.7.2-.7.3-.8.2-.7.2-.8.3-.7.1-.8.2-.8.2-.8.1-.8.1-.8.1-.8.1-1 .1-.8.1-.9.1h-4.2l-.7.6h-.8l-.8-.1h-.8l-.8-.3-.8-.1-.8-.2-.8-.1-.6-.3-.8-.1-.8-.3-.7-.3-.7-.2-.8-.3-.7-.3-.8-.3-.6-.3-.8-.4-.6-.4-.8-.4-.6-.4-.6-.4-.6-.5-.6-.5-.7-.5-.5-.5-.6-.5-.6-.6-.6-.5-.6-.6-.7-.6-.6-.6-.5-.6-.5-.6-.4-.6-.5-.6-.4-.6-.4-.6-.4-.7-.4-.6-.3-.7-.3-.7-.3-.7-.3-.7-.2-.6-.3-.7-.2-.7-.2-.7-.2-.8-.2-.7-.2-.8-.1-.7-.2-.8-.1-.7-.1-.8-.1-.8-.1-.8v-4.4l.2-.8v-.9l.2-.8v-.8l.3-.8.3-.8.1-.8.2-.7.3-.8.2-.7.3-.8.3-.7.3-.7.3-.7.3-.7.4-.7.4-.6.4-.6.4-.6.4-.6.5-.7.5-.6.5-.6.6-.6.5-.6.5-.6.6-.6.5-.6.6-.5.6-.6.6-.5.6-.5.6-.4.6-.5.6-.4.7-.4.7-.4.8-.4.6-.4.8-.3.7-.3.8-.4.6-.2.8-.3.7-.3.7-.2.7-.2.8-.2.7-.2.8-.2h.8l.8-.2h.8l.8-.2h.8l1.3-1zm255.8.2h4.4l1 .2h1.6l.8.2h1l.8.3.7.1.8.2.8.1.7.2.8.2.8.3.6.1.8.3.8.3.6.3.8.3.8.3.7.4.6.3.8.4.7.4.6.4.7.5.6.4.6.5.6.5.6.5-.5.6-.4.7-.5.6-.5.6-.5.7-.4.6-.5.6-.5.7-.4.6-.5.6-.5.6-.5.7-.4.7-.5.6-.6.6-.4.6-.5.7-.6-.5-.7-.4-.6-.4-.6-.5-.7-.3-.6-.4-.8-.3-.6-.3-.8-.3-.6-.3-.6-.2-.7-.3-.8-.2-.8-.3-.8-.2-.9-.2-.8-.1-.8-.2-.8-.1-.8-.1-.7-.1h-1.8l-.9.1-.8.2-.8.1-.6.3-.6.3-.7.6-.5.7-.3.7v2l.4.9.3.5.6.6.8.4.6.4.8.3.8.3 1 .3.6.2.6.2.8.2.6.2.8.2.9.2.9.2.9.3.9.1.8.3.9.2.8.2.8.2.8.2.8.3.8.2.7.2.8.3.8.3.8.4.8.3.8.4.8.4.6.4.6.4.7.5.6.4.7.6.6.6.6.6.6.6.4.6.6.8.4.6.3.8.4.6.2.8.3.6.1.8.2.8.1.8.1.8.1.8v2l-.1.9-.1.8-.1.9-.2.8-.2.8-.2.8-.2.8-.3.7-.3.6-.3.7-.4.6-.5.6-.4.6-.4.7-.6.6-.5.6-.6.5-.6.6-.6.5-.6.5-.6.4-.7.5-.8.4-.6.3-.8.4-.8.3-.8.3-.8.3-.8.2-.6.2-.8.2-.8.2-.6.1-.8.2h-.3l-.8.1h-.8l-.8.2h-6l-.8-.1-.8-.1-.9-.1-.8-.2-.8-.1-.8-.1-.8-.2-.9-.2-.8-.2-.8-.2-.8-.2-.8-.2-.8-.3-.8-.3-.7-.2-.8-.2-.8-.3-.6-.3-.8-.3-.6-.4-.8-.3-.7-.4-.6-.4-.8-.4-.6-.4-.7-.4-.6-.5-.6-.5-.6-.5-.6-.5-.6-.5-.6-.6.5-.6.6-.6.5-.6.6-.6.5-.6.5-.6.6-.6.5-.6.6-.6.5-.6.6-.6.5-.6.5-.6.6-.6.5-.6.6-.6.6-.6.6.5.8.5.6.5.8.5.6.4.7.5.6.4.7.3.6.4.7.3.8.3.6.3.8.2.6.3.8.2.8.3.8.3.8.1.8.2.8.1h.9l.8.3h4.4l.8-.2.8-.2.6-.1.6-.2.6-.3.7-.5.4-.6.4-.6.2-.8v-1.9l-.3-.8-.5-.6-.5-.5-.7-.5-.6-.3-.8-.3-.8-.3-1-.4-.6-.1-.6-.2-.8-.2-.6-.2-.8-.3-.8-.1-.9-.3-.8-.1-.9-.3-.8-.1-.8-.3-.8-.1-.8-.3-.8-.2-.8-.2-.7-.3-.7-.2-.7-.3-.8-.3-.9-.3-.8-.3-.8-.3-.8-.4-.8-.4-.6-.4-.8-.4-.6-.5-.7-.4-.5-.5-.6-.6-.6-.6-.5-.6-.5-.6-.4-.6-.4-.6-.4-.7-.3-.6-.3-.6-.2-.7-.2-.6-.2-.8-.1-.7v-.8l-.2-.8v-3.5l.1-.8.1-.8.1-.6.2-.8.2-.6.2-.8.3-.6.3-.8.3-.6.4-.8.4-.6.6-.6.4-.6.6-.6.6-.6.5-.6.7-.6.5-.4.7-.5.6-.5.6-.4.8-.4.6-.3.8-.4.6-.3.8-.3.8-.3.8-.2.6-.2.8-.1.6-.2.8-.1.8-.2.8-.1.8-.1.8-.1.6-.1zm-197.1.6h15.1l.3.7.3.7.3.7.2.8.3.7.3.7.3.7.3.7.2.7.4.8.3.7.3.7.2.7.3.7.4.7.3.8.3.7.2.7.3.7.4.7.2.7.3.8.2.8.3.6.4.8.3.6.3.8.3.8.2.6.4.8.3.6.3.8.2.6.3.8.4.8.3.7.2.7.2.7.3.7.4.7.3.8.3.7.2.7.3.7.3.7.3.7.3.8.3.7.3.7.4.7.3.7.3.7.2.8.3.7.4.7.3.7.2.7.3.7.3.8.4.8.2.6.3.8.2.6.3.8.4.8.3.6.2.8.3.6.2.8.4.6.3.8.2.8.3.6.3.8.4.6.3.8.2.8.3.6.3.8.4.6H466l-.4-.7-.2-.7-.3-.7-.3-.8-.2-.7-.3-.7-.3-.7-.3-.7-.3-.7-.3-.7-.2-.7-.3-.8-.3-.7-.3-.7-.3-.7h-23.2l-.3.8-.2.6-.3.8-.4.8-.2.6-.3.8-.3.6-.2.8-.3.6-.3.8-.3.6-.3.8-.3.8-.3.6-.2.8h-16.5l.3-.8.3-.7.3-.7.3-.8.2-.7.4-.7.3-.7.3-.7.2-.7.3-.8.4-.7.3-.7.3-.7.2-.7.3-.7.4-.8.3-.7.3-.7.3-.7.3-.7.3-.7.3-.8.3-.8.3-.6.3-.8.4-.6.3-.8.2-.8.2-.6.3-.8.4-.6.3-.8.3-.6.2-.8.3-.8.4-.6.2-.8.3-.6.3-.8.3-.8.4-.6.3-.8.2-.6.3-.8.3-.6.4-.8.3-.8.3-.7.2-.7.3-.7.4-.7.3-.7.2-.8.3-.7.3-.7.4-.7.3-.7.2-.7.3-.8.3-.8.3-.6.3-.8.2-.6.3-.8.3-.8.4-.6.3-.8.3-.6.2-.8.3-.6.4-.8.3-.8.3-.6.3-.8.3-.6.4-.8.2-.8.2-.6.3-.8 2.8-.6zm46.8.4h16.5l.5.6.4.7.5.6.4.7.4.6.4.7.4.6.5.7.4.6.4.6.4.7.4.6.6.7.3.6.4.7.5.6.5.6.3.7.5.6.4.7.3.6.6.7.4.6.4.7.4.6.4.6.5.7.4.6.4.7.4.6.4.7.5.6.4.7.4.6.5-.6.3-.8.5-.6.5-.8.4-.6.3-.8.6-.6.4-.8.3-.6.5-.6.5-.8.4-.6.4-.8.4-.6.5-.8.4-.6.4-.8.4-.6.4-.6.5-.8.4-.6.4-.8.5-.6.4-.8.4-.6.5-.6.4-.8.5-.6.4-.8.4-.6.4-.8.5-.6.4-.8.4-.6H553v59.5h-15.7v-35l-.4.6-.5.8-.4.6-.5.6-.4.8-.5.6-.4.6-.5.8-.4.6-.4.6-.6.6-.4.8-.5.6-.4.6-.4.8-.5.6-.4.6-.5.8-.4.6-.5.6-.4.8-.4.6-.5.6-.4.8-.5.6-.5.6-.4.6-.4.8-.5.6-.5.6-.3.8-.6.6-.4.6-.5.8-.4.6h-.3l-.5-.7-.4-.6-.5-.7-.4-.6-.5-.7-.4-.6-.5-.7-.4-.6-.5-.7-.4-.6-.6-.7-.3-.6-.5-.7-.5-.6-.4-.7-.5-.6-.4-.8-.5-.6-.4-.7-.5-.6-.4-.7-.5-.6-.4-.7-.5-.6-.4-.7-.5-.6-.4-.7-.5-.6-.4-.7-.5-.6-.4-.7-.6-.6-.3-.7-.5-.6v35.1H491v-58.9l-.1-.2zm74 0h46.9v13.4h-31.4v9.5h28.2v12.7h-28.2V634h31.8v13.5H565v-58.9l-.1-.4zm-113.5 18.2-.3.8-.3.6-.3.8-.3.8-.2.7-.3.7-.3.8-.3.8-.2.6-.3.8-.3.6-.3.8-.3.8-.3.6-.2.8-.3.6-.3.8-.6 1.2-.2.6-.3.8-.3.8-.2.6-.3.8h13.7l-.3-.8-.3-.7-.3-.8-.3-.7-.2-.7-.3-.7-.3-.8-.3-.7-.3-.7-.3-.7-.2-.7-.3-.8-.3-.7-.3-.7-.3-.7-.2-.7-.3-.8-.3-.8-.3-.6-.3-.8-.3-.8-.2-.7-.8-1.1zm-24.5 111.4h171l-87.3 28.8-83.7-28.8z" style="fill:#fff"/>
</svg>"; const emailIcon = "data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHZpZXdCb3g9IjAgMCAxNiAxNiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEzLjMzMzUgMi42NjY1SDIuNjY2ODNDMS45MzA0NSAyLjY2NjUgMS4zMzM1IDMuMjYzNDYgMS4zMzM1IDMuOTk5ODRWMTEuOTk5OEMxLjMzMzUgMTIuNzM2MiAxLjkzMDQ1IDEzLjMzMzIgMi42NjY4MyAxMy4zMzMySDEzLjMzMzVDMTQuMDY5OSAxMy4zMzMyIDE0LjY2NjggMTIuNzM2MiAxNC42NjY4IDExLjk5OThWMy45OTk4NEMxNC42NjY4IDMuMjYzNDYgMTQuMDY5OSAyLjY2NjUgMTMuMzMzNSAyLjY2NjVaIiBzdHJva2U9IiMzMzg1RkYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMTQuNjY2OCA0LjY2NjVMOC42ODY4MyA4LjQ2NjVDOC40ODEwMSA4LjU5NTQ1IDguMjQzMDQgOC42NjM4NCA4LjAwMDE2IDguNjYzODRDNy43NTcyOCA4LjY2Mzg0IDcuNTE5MzEgOC41OTU0NSA3LjMxMzUgOC40NjY1TDEuMzMzNSA0LjY2NjUiIHN0cm9rZT0iIzMzODVGRiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+Cjwvc3ZnPgo="; const phoneIcon = @@ -61,6 +63,7 @@ export const socialIcons = { twitch: twitchIconUri, x: xIcon, tiktok: tiktokIconUri, + epic: epicIconUri, }; /** @@ -99,6 +102,8 @@ export function getSocialIcon(provider: AuthOption | ({} & string)): string { return xIcon; case "tiktok": return tiktokIconUri; + case "epic": + return epicIconUri; case "farcaster": return farcasterIconUri; case "telegram": diff --git a/packages/thirdweb/src/react/native/ui/components/WalletImage.tsx b/packages/thirdweb/src/react/native/ui/components/WalletImage.tsx index 51983797e59..435da415b00 100644 --- a/packages/thirdweb/src/react/native/ui/components/WalletImage.tsx +++ b/packages/thirdweb/src/react/native/ui/components/WalletImage.tsx @@ -11,6 +11,7 @@ import { APPLE_ICON, DISCORD_ICON, EMAIL_ICON, + EPIC_ICON, FACEBOOK_ICON, FARCASTER_ICON, GITHUB_ICON, @@ -106,6 +107,8 @@ export function getAuthProviderImage(authProvider: string | null): string { return X_ICON; case "tiktok": return TIKTOK_ICON; + case "epic": + return EPIC_ICON; case "farcaster": return FARCASTER_ICON; case "telegram": diff --git a/packages/thirdweb/src/react/native/ui/connect/InAppWalletUI.tsx b/packages/thirdweb/src/react/native/ui/connect/InAppWalletUI.tsx index 0c7d919c6c7..bb94340cdc3 100644 --- a/packages/thirdweb/src/react/native/ui/connect/InAppWalletUI.tsx +++ b/packages/thirdweb/src/react/native/ui/connect/InAppWalletUI.tsx @@ -32,6 +32,7 @@ import { APPLE_ICON, COINBASE_ICON, DISCORD_ICON, + EPIC_ICON, FACEBOOK_ICON, FARCASTER_ICON, GITHUB_ICON, @@ -69,6 +70,7 @@ const socialIcons = { twitch: TWITCH_ICON, x: X_ICON, tiktok: TIKTOK_ICON, + epic: EPIC_ICON, }; type InAppWalletFormUIProps = { diff --git a/packages/thirdweb/src/react/native/ui/icons/svgs.ts b/packages/thirdweb/src/react/native/ui/icons/svgs.ts index 9d846dbf379..4626f714d3f 100644 --- a/packages/thirdweb/src/react/native/ui/icons/svgs.ts +++ b/packages/thirdweb/src/react/native/ui/icons/svgs.ts @@ -155,6 +155,11 @@ export const TIKTOK_ICON = ` + + +`; + export const GUEST_ICON = ``; export const WALLET_ICON = ` diff --git a/packages/thirdweb/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx b/packages/thirdweb/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx index af3ed95e2d2..e959e82899a 100644 --- a/packages/thirdweb/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +++ b/packages/thirdweb/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx @@ -119,6 +119,7 @@ export const ConnectWalletSocialOptions = ( twitch: "Twitch", x: "X", tiktok: "TikTok", + epic: "Epic", }; const { data: ecosystemAuthOptions, isLoading } = useQuery({ diff --git a/packages/thirdweb/src/react/web/wallets/shared/oauthSignIn.ts b/packages/thirdweb/src/react/web/wallets/shared/oauthSignIn.ts index 57b5fb6448c..80fbc8cbc6b 100644 --- a/packages/thirdweb/src/react/web/wallets/shared/oauthSignIn.ts +++ b/packages/thirdweb/src/react/web/wallets/shared/oauthSignIn.ts @@ -44,6 +44,7 @@ function getOauthLoginPath( case "line": case "x": case "tiktok": + case "epic": case "guest": case "coinbase": case "discord": diff --git a/packages/thirdweb/src/stories/ConnectEmbed.stories.tsx b/packages/thirdweb/src/stories/ConnectEmbed.stories.tsx index 1abe85531a8..cab7b800bf7 100644 --- a/packages/thirdweb/src/stories/ConnectEmbed.stories.tsx +++ b/packages/thirdweb/src/stories/ConnectEmbed.stories.tsx @@ -89,6 +89,7 @@ export function AllInAppWalletAuthMethods() { "discord", "x", "tiktok", + "epic", "coinbase", "farcaster", "telegram", diff --git a/packages/thirdweb/src/wallets/in-app/core/authentication/types.ts b/packages/thirdweb/src/wallets/in-app/core/authentication/types.ts index 1311dc573ef..f82220e0bbe 100644 --- a/packages/thirdweb/src/wallets/in-app/core/authentication/types.ts +++ b/packages/thirdweb/src/wallets/in-app/core/authentication/types.ts @@ -103,6 +103,7 @@ export type AuthProvider = | "Coinbase" | "X" | "TikTok" + | "Epic" | "Line" | "Twitch" | "Steam" diff --git a/packages/thirdweb/src/wallets/in-app/native/native-connector.ts b/packages/thirdweb/src/wallets/in-app/native/native-connector.ts index 564d28965c7..5b6f6ad43c3 100644 --- a/packages/thirdweb/src/wallets/in-app/native/native-connector.ts +++ b/packages/thirdweb/src/wallets/in-app/native/native-connector.ts @@ -199,6 +199,7 @@ export class InAppNativeConnector implements InAppConnector { case "line": case "x": case "tiktok": + case "epic": case "apple": { const { socialAuth } = await import("./auth/native-auth.js"); const ExpoLinking = require("expo-linking"); diff --git a/packages/thirdweb/src/wallets/in-app/web/lib/web-connector.ts b/packages/thirdweb/src/wallets/in-app/web/lib/web-connector.ts index 908a24c23c3..6aee164ae11 100644 --- a/packages/thirdweb/src/wallets/in-app/web/lib/web-connector.ts +++ b/packages/thirdweb/src/wallets/in-app/web/lib/web-connector.ts @@ -338,6 +338,7 @@ export class InAppWebConnector implements InAppConnector { case "line": case "x": case "tiktok": + case "epic": case "steam": case "coinbase": case "discord": { @@ -411,6 +412,7 @@ export class InAppWebConnector implements InAppConnector { case "line": case "x": case "tiktok": + case "epic": case "guest": case "coinbase": case "twitch": diff --git a/packages/thirdweb/src/wallets/types.ts b/packages/thirdweb/src/wallets/types.ts index daf16784ef8..5d41ac52d2e 100644 --- a/packages/thirdweb/src/wallets/types.ts +++ b/packages/thirdweb/src/wallets/types.ts @@ -27,6 +27,7 @@ export const socialAuthOptions = [ "line", "x", "tiktok", + "epic", "coinbase", "farcaster", "telegram", From de77de10a84b6b46fad733c2524b3f860b83f542 Mon Sep 17 00:00:00 2001 From: 0xFirekeeper <0xFirekeeper@gmail.com> Date: Sat, 1 Nov 2025 06:02:34 +0700 Subject: [PATCH 2/4] Create beige-candles-happen.md --- .changeset/beige-candles-happen.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/beige-candles-happen.md diff --git a/.changeset/beige-candles-happen.md b/.changeset/beige-candles-happen.md new file mode 100644 index 00000000000..c39e04be48c --- /dev/null +++ b/.changeset/beige-candles-happen.md @@ -0,0 +1,5 @@ +--- +"thirdweb": patch +--- + +Added Epic Games Authentication From 60d924193123a2288aa097b73bf1b42b11abf42a Mon Sep 17 00:00:00 2001 From: 0xFirekeeper <0xFirekeeper@gmail.com> Date: Sat, 1 Nov 2025 06:13:20 +0700 Subject: [PATCH 3/4] Delete EpicIcon.tsx --- .../src/@/icons/brand-icons/EpicIcon.tsx | 18 ------------------ 1 file changed, 18 deletions(-) delete mode 100644 apps/dashboard/src/@/icons/brand-icons/EpicIcon.tsx diff --git a/apps/dashboard/src/@/icons/brand-icons/EpicIcon.tsx b/apps/dashboard/src/@/icons/brand-icons/EpicIcon.tsx deleted file mode 100644 index 5d9a881dda1..00000000000 --- a/apps/dashboard/src/@/icons/brand-icons/EpicIcon.tsx +++ /dev/null @@ -1,18 +0,0 @@ -import type { SVGProps } from "react"; - -export const EpicIcon = (props: SVGProps) => { - return ( - - Epic Games - - - ); -}; From 9d71fa545968489d90073201cae7d0742c02a610 Mon Sep 17 00:00:00 2001 From: 0xFirekeeper <0xFirekeeper@gmail.com> Date: Fri, 7 Nov 2025 06:02:08 +0700 Subject: [PATCH 4/4] Add Line, TikTok, and Epic Games OAuth support Extended the AuthMethodsTabs component to include Line, TikTok, and Epic Games as new OAuth authentication methods. Updated all relevant type definitions, UI labels, and provider mappings to support these new options. --- .../components/Document/AuthMethodsTabs.tsx | 28 +++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) diff --git a/apps/portal/src/components/Document/AuthMethodsTabs.tsx b/apps/portal/src/components/Document/AuthMethodsTabs.tsx index 07fc2d36bab..850e6f599d5 100644 --- a/apps/portal/src/components/Document/AuthMethodsTabs.tsx +++ b/apps/portal/src/components/Document/AuthMethodsTabs.tsx @@ -29,6 +29,9 @@ type AuthMethod = | "telegram" | "farcaster" | "github" + | "line" + | "tiktok" + | "epic" | "passkey" | "wallet" | "guest" @@ -55,6 +58,9 @@ const authMethods: { id: AuthMethod; label: string; description: string }[] = [ { id: "telegram", label: "Telegram", description: "Telegram OAuth" }, { id: "farcaster", label: "Farcaster", description: "Farcaster OAuth" }, { id: "github", label: "GitHub", description: "GitHub OAuth" }, + { id: "line", label: "Line", description: "Line OAuth" }, + { id: "tiktok", label: "TikTok", description: "TikTok OAuth" }, + { id: "epic", label: "Epic Games", description: "Epic Games OAuth" }, { id: "passkey", label: "Passkey", description: "WebAuthn passkey" }, { id: "wallet", @@ -244,6 +250,9 @@ const account = await wallet.connect({ case "telegram": case "farcaster": case "github": + case "line": + case "tiktok": + case "epic": return ( baseSetup + `// ${authMethod.charAt(0).toUpperCase() + authMethod.slice(1)} OAuth @@ -561,6 +570,9 @@ function PrebuiltUIExample() { case "telegram": case "farcaster": case "github": + case "line": + case "tiktok": + case "epic": return ( baseSetup + ` await wallet.connect({\n client,\n strategy: "${authMethod}",\n });\n` + @@ -639,7 +651,10 @@ var address = await wallet.LoginWithOtp("123456");` case "x": case "telegram": case "farcaster": - case "github": { + case "github": + case "line": + case "tiktok": + case "epic": { const providerMap: Record = { google: "Google", apple: "Apple", @@ -649,6 +664,9 @@ var address = await wallet.LoginWithOtp("123456");` telegram: "Telegram", farcaster: "Farcaster", github: "Github", + line: "Line", + tiktok: "TikTok", + epic: "Epic", }; return ( baseSetup + @@ -746,7 +764,10 @@ var wallet = await ThirdwebManager.Instance.ConnectWallet(options);` case "x": case "telegram": case "farcaster": - case "github": { + case "github": + case "line": + case "tiktok": + case "epic": { const providerMap: Record = { google: "Google", apple: "Apple", @@ -756,6 +777,9 @@ var wallet = await ThirdwebManager.Instance.ConnectWallet(options);` telegram: "Telegram", farcaster: "Farcaster", github: "Github", + line: "Line", + tiktok: "TikTok", + epic: "Epic", }; return ( baseSetup +