diff --git a/.github/workflows/dependency-review.yml b/.github/workflows/dependency-review.yml
new file mode 100644
index 000000000..078574c42
--- /dev/null
+++ b/.github/workflows/dependency-review.yml
@@ -0,0 +1,19 @@
+name: 'Dependency Review'
+on: [pull_request]
+
+permissions:
+ contents: read
+ pull-requests: write
+
+jobs:
+ dependency-review:
+ runs-on: ubuntu-latest
+ steps:
+ - name: 'Checkout Repository'
+ uses: actions/checkout@v5
+ - name: 'Dependency Review'
+ uses: actions/dependency-review-action@v4
+ with:
+ comment-summary-in-pr: on-failure
+ fail-on-severity: moderate
+ license-check: false
diff --git a/.github/workflows/quality.yml b/.github/workflows/quality.yml
index f944a0ec8..e88d0b605 100644
--- a/.github/workflows/quality.yml
+++ b/.github/workflows/quality.yml
@@ -16,7 +16,7 @@ jobs:
node-version: 16
- name: Use node_modules cache
- uses: actions/cache@v2
+ uses: actions/cache@v3
with:
path: '**/node_modules'
key: ${{ runner.os }}-modules-${{ hashFiles('**/pnpm-lock.yaml') }}
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 47c0fe2a3..c8a4592a9 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,31 @@
+# 1.9.1
+
+This update includes updates to the peer dependencies and improvements to the Family Accounts features.
+
+## Updated
+
+- `family` package updated to latest.
+
+## Improved
+
+- Improved support for `family` features.
+
+# 1.9.0
+
+We're thrilled to announce a major upgrade to ConnectKit—designed to make onboarding and navigating Ethereum simpler and safer than ever.
+
+Introducing [Family Accounts](https://app.family.co), simplified onboarding for new users.
+
+Learn more by reading the announcement [here](https://family.co/blog/family-accounts).
+
+## New
+
+- Support for [Family Accounts](https://app.family.co).
+
+## Improved
+
+- Updates chain logos for `zora`, `base`, `optimism` and `lens`.
+
# 1.8.2
This update includes improvements to the `CoinbaseWalletSDK` connect popup and `MockConnector`.
diff --git a/examples/testbench/src/components/Web3Provider.tsx b/examples/testbench/src/components/Web3Provider.tsx
index 82622c1e6..18d42e94c 100644
--- a/examples/testbench/src/components/Web3Provider.tsx
+++ b/examples/testbench/src/components/Web3Provider.tsx
@@ -41,6 +41,7 @@ export const ckConfig = getDefaultConfig({
appName: 'ConnectKit testbench',
appIcon: '/app.png',
walletConnectProjectId: process.env.NEXT_PUBLIC_WALLETCONNECT_PROJECT_ID!,
+ //enableFamily: false,
});
const customConfig = {
...ckConfig,
diff --git a/packages/connectkit/package.json b/packages/connectkit/package.json
index 1ca012997..9374bd108 100644
--- a/packages/connectkit/package.json
+++ b/packages/connectkit/package.json
@@ -1,6 +1,6 @@
{
"name": "connectkit",
- "version": "1.8.2",
+ "version": "1.9.1",
"author": "Family",
"homepage": "https://docs.family.co/connectkit",
"license": "BSD-2-Clause license",
@@ -41,6 +41,7 @@
"dependencies": {
"buffer": "^6.0.3",
"detect-browser": "^5.3.0",
+ "family": "^0.1.2",
"framer-motion": "^6.3.11",
"qrcode": "^1.5.0",
"react-transition-state": "^1.1.4",
diff --git a/packages/connectkit/src/assets/chains.tsx b/packages/connectkit/src/assets/chains.tsx
index 9821efdc8..19b0d77ec 100644
--- a/packages/connectkit/src/assets/chains.tsx
+++ b/packages/connectkit/src/assets/chains.tsx
@@ -108,6 +108,27 @@ export const Ethereum = ({ testnet, ...props }: Logo) => {
);
};
+export const LensChain = ({ testnet, ...props }: { testnet?: boolean }) => (
+
+);
+
export const Polygon = ({ testnet, ...props }: Logo) => (
);
@@ -850,6 +880,7 @@ const Zora = ({ testnet, ...props }: { testnet?: boolean }) => (
export default {
UnknownChain,
Base,
+ LensChain,
Ethereum,
Polygon,
Optimism,
diff --git a/packages/connectkit/src/assets/logos.tsx b/packages/connectkit/src/assets/logos.tsx
index d556a5b31..e1c77a1d0 100644
--- a/packages/connectkit/src/assets/logos.tsx
+++ b/packages/connectkit/src/assets/logos.tsx
@@ -1,4 +1,4 @@
-import { isFamily, isRainbow, isZerion } from '../utils/wallets';
+import { isArgent, isPhantom, isSafe } from '../utils/wallets';
export const Mock = ({ ...props }) => (
);
@@ -384,6 +163,23 @@ export const Coinbase = ({ background = false, ...props }) => (
);
+export const FamilyAccount = () => (
+
+);
+
export const Family = ({ ...props }) => {
const img =
'';
@@ -1262,12 +1058,12 @@ export const OtherWallets = ({ ...props }) => {
position: 'relative',
display: 'flex',
flexDirection: 'column',
- gap: 2,
+ gap: 3,
};
const row: React.CSSProperties = {
position: 'relative',
display: 'flex',
- gap: 2,
+ gap: 3,
};
const cell: React.CSSProperties = {
width: '50%',
@@ -1280,11 +1076,13 @@ export const OtherWallets = ({ ...props }) => {
-
+
-
{!isFamily() ? : }
-
{!isRainbow() ? : }
+
+
{!isSafe() ? : }
);
@@ -1329,6 +1127,7 @@ export default {
MetaMask,
Coinbase,
Family,
+ FamilyAccount,
Trust,
Argent,
ImToken,
diff --git a/packages/connectkit/src/components/Common/Button/index.tsx b/packages/connectkit/src/components/Common/Button/index.tsx
index 1e1ecc994..0d722b47c 100644
--- a/packages/connectkit/src/components/Common/Button/index.tsx
+++ b/packages/connectkit/src/components/Common/Button/index.tsx
@@ -42,7 +42,7 @@ const Button: React.FC = ({
: flattenChildren(children).join(''); // Need to generate a string for the key so we can automatically animate between content
const hrefUrl =
- typeof href === 'string' ? href : flattenChildren(href).join(''); // Need to have a flat string for the href
+ href && (typeof href === 'string' ? href : flattenChildren(href).join('')); // Need to have a flat string for the href
return (
{
const context = useContext();
@@ -29,17 +35,28 @@ const ConnectorList = () => {
const wallets = useWallets();
const { lastConnectorId } = useLastConnector();
+ const familyConnector = useFamilyConnector();
+ const familyAccountsConnector = useFamilyAccountsConnector();
+
+ let filteredWallets = wallets.filter(
+ (wallet) => wallet.id !== familyAccountsConnector?.id
+ );
+ if (familyConnector && isFamily()) {
+ filteredWallets = filteredWallets.filter(
+ (wallet) => wallet.id !== familyConnector?.id
+ );
+ }
const walletsToDisplay =
context.options?.hideRecentBadge || lastConnectorId === 'walletConnect' // do not hoist walletconnect to top of list
- ? wallets
+ ? filteredWallets
: [
// move last used wallet to top of list
// using .filter and spread to avoid mutating original array order with .sort
- ...wallets.filter(
+ ...filteredWallets.filter(
(wallet) => lastConnectorId === wallet.connector.id
),
- ...wallets.filter(
+ ...filteredWallets.filter(
(wallet) => lastConnectorId !== wallet.connector.id
),
];
@@ -105,7 +122,7 @@ const ConnectorItem = ({
// Safari requires opening popup on user gesture, so we connect immediately here
const shouldConnectImmediately =
(detectBrowser() === 'safari' || detectBrowser() === 'ios') &&
- isCoinbaseWalletConnector(wallet.connector.id);
+ (isCoinbaseWalletConnector(wallet.connector.id) || isPortoConnector(wallet.connector.id));
if (redirectToMoreWallets || shouldConnectImmediately) deeplink = undefined; // mobile redirects to more wallets page
@@ -134,6 +151,7 @@ const ConnectorItem = ({
{wallet.iconConnector ?? wallet.icon}
diff --git a/packages/connectkit/src/components/Common/ConnectorList/styles.ts b/packages/connectkit/src/components/Common/ConnectorList/styles.ts
index 0557aedff..0c4fbdbd3 100644
--- a/packages/connectkit/src/components/Common/ConnectorList/styles.ts
+++ b/packages/connectkit/src/components/Common/ConnectorList/styles.ts
@@ -212,6 +212,12 @@ const styles = {
&[data-shape='square'] {
border-radius: 0;
}
+
+ &[data-background='true'] {
+ border-radius: 22.5%;
+ background: var(--ck-body-background-tertiary);
+ padding: 8%;
+ }
`,
},
};
diff --git a/packages/connectkit/src/components/Common/FamilyAccountsButton/index.tsx b/packages/connectkit/src/components/Common/FamilyAccountsButton/index.tsx
new file mode 100644
index 000000000..7dbde54ed
--- /dev/null
+++ b/packages/connectkit/src/components/Common/FamilyAccountsButton/index.tsx
@@ -0,0 +1,41 @@
+import {
+ ButtonContainer,
+ InnerContainer,
+ IconContainer,
+ ButtonContainerInner,
+} from './styles';
+import FitText from '../FitText';
+import useLocales from '../../../hooks/useLocales';
+
+const FamilyLogo = () => (
+
+);
+
+export const FamilyAccountsButton = ({ onClick }: { onClick: () => void }) => {
+ const locales = useLocales();
+ return (
+
+
+
+
+
+
+ {locales.continueWithFamily}
+
+
+
+ );
+};
diff --git a/packages/connectkit/src/components/Common/FamilyAccountsButton/styles.ts b/packages/connectkit/src/components/Common/FamilyAccountsButton/styles.ts
new file mode 100644
index 000000000..85016e55f
--- /dev/null
+++ b/packages/connectkit/src/components/Common/FamilyAccountsButton/styles.ts
@@ -0,0 +1,79 @@
+import { motion } from 'framer-motion';
+import styled from './../../../styles/styled';
+
+export const ButtonContainerInner = styled(motion.div)`
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ inset: 0;
+ height: 100%;
+`;
+export const ButtonContainer = styled.button`
+ --color: #ffffff;
+ --background: var(--ck-family-accounts-brand);
+ --box-shadow: var(--ck-primary-button-box-shadow);
+ --border-radius: var(--ck-primary-button-border-radius);
+ --font-weight: var(--ck-primary-button-font-weight, 500);
+
+ --hover-color: var(--ck-button-primary-hover-color, var(--color));
+ --hover-background: var(
+ --ck-primary-button-hover-background,
+ var(--background)
+ );
+ --hover-box-shadow: var(
+ --ck-primary-button-hover-box-shadow,
+ var(--box-shadow)
+ );
+ --hover-border-radius: var(
+ --ck-primary-button-hover-border-radius,
+ var(--border-radius)
+ );
+ --hover-font-weight: var(--ck-primary-button-font-weight, var(--font-weight));
+
+ appearance: none;
+ cursor: pointer;
+ user-select: none;
+ min-width: fit-content;
+ width: 100%;
+ display: block;
+ text-align: center;
+ height: 48px;
+ margin: 18px 0 2px;
+ line-height: 48px;
+ padding: 0 4px;
+ font-size: 16px;
+ font-weight: var(--font-weight, 500);
+ text-decoration: none;
+ white-space: nowrap;
+ transition: 100ms ease;
+ transition-property: box-shadow, background-color;
+ color: var(--color);
+ background: var(--background);
+ border-radius: var(--border-radius);
+ box-shadow: var(--box-shadow);
+ will-change: transform, box-shadow, background-color, color;
+`;
+
+export const InnerContainer = styled.div`
+ transform: translateZ(0); // Shifting fix
+ position: relative;
+ display: inline-block;
+ vertical-align: middle;
+ max-width: calc(100% - 42px);
+ transition: opacity 300ms ease;
+`;
+
+export const IconContainer = styled.div`
+ position: relative;
+ display: inline-block;
+ vertical-align: middle;
+ max-width: 20px;
+ max-height: 20px;
+ margin: 0 12px 0 0;
+ svg {
+ display: block;
+ position: relative;
+ max-width: 100%;
+ height: auto;
+ }
+`;
diff --git a/packages/connectkit/src/components/Common/Modal/index.tsx b/packages/connectkit/src/components/Common/Modal/index.tsx
index 29e90aecc..c80c429d3 100644
--- a/packages/connectkit/src/components/Common/Modal/index.tsx
+++ b/packages/connectkit/src/components/Common/Modal/index.tsx
@@ -697,10 +697,16 @@ const Page: React.FC = ({
);
};
-export const OrDivider = ({ children }: { children?: React.ReactNode }) => {
+export const OrDivider = ({
+ children,
+ hideHr,
+}: {
+ children?: React.ReactNode;
+ hideHr?: boolean;
+}) => {
const locales = useLocales();
return (
-
+
{children ?? locales.or}
);
diff --git a/packages/connectkit/src/components/Common/Modal/styles.ts b/packages/connectkit/src/components/Common/Modal/styles.ts
index 4d90071ec..0c9dbd69b 100644
--- a/packages/connectkit/src/components/Common/Modal/styles.ts
+++ b/packages/connectkit/src/components/Common/Modal/styles.ts
@@ -71,7 +71,9 @@ export const PageContent = styled(motion.div)`
padding-top: 48px;
`;
-export const TextWithHr = styled(motion.div)`
+export const TextWithHr = styled(motion.div)<{
+ $disableHr?: boolean;
+}>`
user-select: none;
position: relative;
display: block;
@@ -90,6 +92,9 @@ export const TextWithHr = styled(motion.div)`
background: var(--ck-body-background);
transition: background-color 200ms ease;
}
+ ${(props) =>
+ !props.$disableHr &&
+ `
&:before {
z-index: 2;
content: '';
@@ -102,6 +107,7 @@ export const TextWithHr = styled(motion.div)`
background: var(--ck-body-divider);
box-shadow: var(--ck-body-divider-box-shadow);
}
+ `}
`;
export const ModalHeading = styled(motion.div)`
z-index: 3;
diff --git a/packages/connectkit/src/components/ConnectModal/ConnectUsing.tsx b/packages/connectkit/src/components/ConnectModal/ConnectUsing.tsx
index 877e945c5..f41a416d1 100644
--- a/packages/connectkit/src/components/ConnectModal/ConnectUsing.tsx
+++ b/packages/connectkit/src/components/ConnectModal/ConnectUsing.tsx
@@ -54,6 +54,7 @@ const ConnectUsing = () => {
switchConnectMethod={(id?: string) => {
//if (id) setId(id);
setStatus(states.INJECTOR);
+ setTimeout(context.triggerResize, 10); // delay required here for modal to resize
}}
/>
@@ -70,6 +71,7 @@ const ConnectUsing = () => {
switchConnectMethod={(id?: string) => {
//if (id) setId(id);
setStatus(states.QRCODE);
+ setTimeout(context.triggerResize, 10); // delay required here for modal to resize
}}
/>
diff --git a/packages/connectkit/src/components/ConnectModal/ConnectWithInjector/index.tsx b/packages/connectkit/src/components/ConnectModal/ConnectWithInjector/index.tsx
index abacab0ee..e8b934772 100644
--- a/packages/connectkit/src/components/ConnectModal/ConnectWithInjector/index.tsx
+++ b/packages/connectkit/src/components/ConnectModal/ConnectWithInjector/index.tsx
@@ -27,7 +27,11 @@ import SquircleSpinner from './SquircleSpinner';
import { RetryIconCircle, Scan } from '../../../assets/icons';
import BrowserIcon from '../../Common/BrowserIcon';
import { AlertIcon, TickIcon } from '../../../assets/icons';
-import { detectBrowser, isWalletConnectConnector } from '../../../utils';
+import {
+ detectBrowser,
+ isFamilyAccountsConnector,
+ isWalletConnectConnector,
+} from '../../../utils';
import useLocales from '../../../hooks/useLocales';
import { useConnect } from '../../../hooks/useConnect';
import { useContext } from '../../ConnectKit';
@@ -340,6 +344,16 @@ const ConnectWithInjector: React.FC<{
{locales.injectionScreen_failed_p}
+
+ {isFamilyAccountsConnector(wallet.id) && (
+ <>
+
+
+ >
+ )}
+
{/* Reason: Coinbase Wallet does not expose a QRURI when extension is installed */}
{/*
{wallet?.getWalletConnectDeeplink &&
@@ -365,11 +379,28 @@ const ConnectWithInjector: React.FC<{
exit={'exit'}
variants={contentVariants}
>
-
+
{locales.injectionScreen_rejected_h1}
{locales.injectionScreen_rejected_p}
+ {isFamilyAccountsConnector(wallet.id) && (
+ <>
+
+
+ >
+ )}
+
{/* Reason: Coinbase Wallet does not expose a QRURI when extension is installed */}
{/*
{wallet?.getWalletConnectDeeplink &&
@@ -395,7 +426,11 @@ const ConnectWithInjector: React.FC<{
exit={'exit'}
variants={contentVariants}
>
-
+
{wallet.connector.id === 'injected'
? locales.injectionScreen_connecting_injected_h1
diff --git a/packages/connectkit/src/components/ConnectModal/ConnectWithQRCode.tsx b/packages/connectkit/src/components/ConnectModal/ConnectWithQRCode.tsx
index 7bb7cae9d..cfa6b9ba7 100644
--- a/packages/connectkit/src/components/ConnectModal/ConnectWithQRCode.tsx
+++ b/packages/connectkit/src/components/ConnectModal/ConnectWithQRCode.tsx
@@ -5,7 +5,7 @@ import { useWalletConnectModal } from '../../hooks/useWalletConnectModal';
import {
detectBrowser,
- isCoinbaseWalletConnector,
+ isFamilyAccountsConnector,
isWalletConnectConnector,
} from '../../utils';
@@ -130,6 +130,14 @@ const ConnectWithQRCode: React.FC<{
)}
+ {isFamilyAccountsConnector(wallet.id) && (
+ <>
+
+
+ >
+ )}
{/*
{hasExtensionInstalled && ( // Run the extension
+
+ {isFamilyConnector && (
+ <>
+ {
+ try {
+ await connectorClient?.request<{
+ Method: 'family_switchAccounts';
+ Parameters: [];
+ ReturnType: { message: string; success: boolean };
+ }>({
+ method: 'family_switchAccounts',
+ params: [],
+ });
+ } catch (error) {
+ context.log(
+ 'rpc method family_switchAccounts is not implemented in this connector',
+ error
+ );
+ }
+ }}
+ >
+ {locales.switchWallets}
+
+ >
+ )}
{!isSafeConnector(connector?.id) && (
setShouldDisconnect(true)}
- icon={}
+ icon={isFamilyConnector ? undefined : }
>
{locales.disconnect}
diff --git a/packages/connectkit/src/constants/chainConfigs.tsx b/packages/connectkit/src/constants/chainConfigs.tsx
index 94254b634..f62d87f3e 100644
--- a/packages/connectkit/src/constants/chainConfigs.tsx
+++ b/packages/connectkit/src/constants/chainConfigs.tsx
@@ -37,6 +37,16 @@ export const chainConfigs: Chain[] = [
},
},
},
+ {
+ id: 232,
+ name: 'Lens Chain',
+ logo: ,
+ },
+ {
+ id: 37111,
+ name: 'Lens Chain Testnet',
+ logo: ,
+ },
{
id: 3,
name: 'Rinkeby',
diff --git a/packages/connectkit/src/defaultConfig.ts b/packages/connectkit/src/defaultConfig.ts
index 719a59ccd..de6850699 100644
--- a/packages/connectkit/src/defaultConfig.ts
+++ b/packages/connectkit/src/defaultConfig.ts
@@ -2,6 +2,7 @@ import { http } from 'wagmi';
import { type CreateConfigParameters } from '@wagmi/core';
import { mainnet, polygon, optimism, arbitrum } from 'wagmi/chains';
import { CoinbaseWalletParameters } from 'wagmi/connectors';
+import { EthereumProviderOptions as FamilyOptions } from 'family';
import defaultConnectors from './defaultConnectors';
@@ -21,6 +22,9 @@ type DefaultConfigProps = {
walletConnectProjectId: string;
// Coinbase Wallet preference
coinbaseWalletPreference?: CoinbaseWalletParameters<'4'>['preference'];
+ // Family options (https://app.family.co)
+ enableFamily?: boolean;
+ familyOptions?: FamilyOptions;
} & Partial;
const defaultConfig = ({
@@ -32,6 +36,8 @@ const defaultConfig = ({
coinbaseWalletPreference,
chains = [mainnet, polygon, optimism, arbitrum],
client,
+ enableFamily = true,
+ familyOptions,
...props
}: DefaultConfigProps): CreateConfigParameters => {
globalAppName = appName;
@@ -53,6 +59,8 @@ const defaultConfig = ({
},
walletConnectProjectId,
coinbaseWalletPreference,
+ enableFamily,
+ familyOptions,
});
const config: CreateConfigParameters = {
diff --git a/packages/connectkit/src/defaultConnectors.ts b/packages/connectkit/src/defaultConnectors.ts
index 514b2283d..fd049103b 100644
--- a/packages/connectkit/src/defaultConnectors.ts
+++ b/packages/connectkit/src/defaultConnectors.ts
@@ -7,6 +7,11 @@ import {
safe,
} from '@wagmi/connectors';
+import {
+ EthereumProviderOptions as FamilyOptions,
+ familyAccountsConnector,
+} from 'family';
+
type DefaultConnectorsProps = {
app: {
name: string;
@@ -16,18 +21,24 @@ type DefaultConnectorsProps = {
};
walletConnectProjectId?: string;
coinbaseWalletPreference?: CoinbaseWalletParameters<'4'>['preference'];
+ enableFamily?: boolean;
+ familyOptions?: FamilyOptions;
};
const defaultConnectors = ({
app,
walletConnectProjectId,
coinbaseWalletPreference,
+ enableFamily,
+ familyOptions,
}: DefaultConnectorsProps): CreateConnectorFn[] => {
const hasAllAppData = app.name && app.icon && app.description && app.url;
const shouldUseSafeConnector =
!(typeof window === 'undefined') && window?.parent !== window;
- const connectors: CreateConnectorFn[] = [];
+ const connectors: CreateConnectorFn[] = enableFamily
+ ? [familyAccountsConnector(familyOptions)]
+ : [];
// If we're in an iframe, include the SafeConnector
if (shouldUseSafeConnector) {
diff --git a/packages/connectkit/src/hooks/connectors/useWalletConnectUri.ts b/packages/connectkit/src/hooks/connectors/useWalletConnectUri.ts
index b5b785637..b43db83ae 100644
--- a/packages/connectkit/src/hooks/connectors/useWalletConnectUri.ts
+++ b/packages/connectkit/src/hooks/connectors/useWalletConnectUri.ts
@@ -18,7 +18,7 @@ export function useWalletConnectUri(
const [uri, setUri] = useState(undefined);
- const connector: Connector = useWalletConnectConnector();
+ const connector = useWalletConnectConnector();
const { isConnected } = useAccount();
const { connectAsync } = useConnect();
diff --git a/packages/connectkit/src/hooks/useConnectors.ts b/packages/connectkit/src/hooks/useConnectors.ts
index 8f9a17660..2ab20dc8c 100644
--- a/packages/connectkit/src/hooks/useConnectors.ts
+++ b/packages/connectkit/src/hooks/useConnectors.ts
@@ -14,7 +14,14 @@ export function useConnector(id: string, uuid?: string) {
(c) => c.id === id && c.name.includes('Injected')
) as Connector;
}
- return connectors.find((c) => c.id === id) as Connector;
+ return connectors.find((c) => c.id === id);
+}
+
+export function useFamilyAccountsConnector() {
+ return useConnector('familyAccountsProvider');
+}
+export function useFamilyConnector() {
+ return useConnector('co.family.wallet');
}
export function useInjectedConnector(uuid?: string) {
diff --git a/packages/connectkit/src/hooks/useLocales.tsx b/packages/connectkit/src/hooks/useLocales.tsx
index 266f488a5..452da38ec 100644
--- a/packages/connectkit/src/hooks/useLocales.tsx
+++ b/packages/connectkit/src/hooks/useLocales.tsx
@@ -4,8 +4,9 @@ import Logos from '../assets/logos';
import { useContext } from '../components/ConnectKit';
import { getLocale } from './../localizations';
+import { LocaleProps } from '../localizations/locales';
-export default function useLocales(replacements?: any) {
+export default function useLocales(replacements?: any): LocaleProps {
const context = useContext();
const language = context.options?.language ?? 'en-US';
@@ -15,16 +16,16 @@ export default function useLocales(replacements?: any) {
if (!translations) {
console.error(`Missing translations for: ${language}`);
- return `Missing translations for: ${language}`;
+ throw new Error(`Missing translations for: ${language}`);
}
- const translated: any = {};
+ const translated = {};
Object.keys(translations).map((key) => {
const string = translations[key];
return (translated[key] = localize(string, replacements));
});
- return translated;
+ return translated as LocaleProps;
}
const localize = (text: string, replacements?: any[string]) => {
diff --git a/packages/connectkit/src/index.ts b/packages/connectkit/src/index.ts
index a9a16a772..023b3f059 100644
--- a/packages/connectkit/src/index.ts
+++ b/packages/connectkit/src/index.ts
@@ -1,4 +1,4 @@
-export const CONNECTKIT_VERSION = '1.8.2';
+export const CONNECTKIT_VERSION = '1.9.1';
export * as Types from './types';
export { default as getDefaultConfig } from './defaultConfig';
diff --git a/packages/connectkit/src/localizations/locales/ar-AE.ts b/packages/connectkit/src/localizations/locales/ar-AE.ts
index 1bc9667e4..8d7b9588d 100644
--- a/packages/connectkit/src/localizations/locales/ar-AE.ts
+++ b/packages/connectkit/src/localizations/locales/ar-AE.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const arAE: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'الاتصال بالمحفظة',
disconnect: 'قطع الاتصال',
connected: 'متصل',
@@ -16,7 +18,7 @@ const arAE: LocaleProps = {
more: 'المزيد',
tryAgain: 'حاول مجددًا',
tryAgainQuestion: 'هل نحاول مرة أخرى؟',
- dontHaveTheApp: "ليس لديك التطبيق؟",
+ dontHaveTheApp: 'ليس لديك التطبيق؟',
scanTheQRCode: 'مسح رمز الاستجابة السريعة',
useWalletConnectModal: 'استخدم نموذج ولِيتكنيكت',
useModal: 'استخدم النموذج',
@@ -46,7 +48,7 @@ const arAE: LocaleProps = {
onboardingScreen_ctaUrl: `https://ethereum.org/ar/wallets/find-wallet/`,
aboutScreen_heading: `حول المحافظ`,
- aboutScreen_a_h1: `حافظ على أصولك الرقمية`,
+ aboutScreen_a_h1: `حافظ على أصولك الرقمية`,
aboutScreen_a_p: `تمكنك المحافظ من إرسال واستقبال وتخزين والتفاعل مع الأصول الرقمية مثل NFTs ورموز إيثريوم الأخرى.`,
aboutScreen_b_h1: `وسيلة أفضل لتسجيل الدخول`,
aboutScreen_b_p: `في تطبيقات العصر الحديث، يمكن استخدام محفظتك كوسيلة سهلة لتسجيل الدخول بدلاً من الحاجة إلى تذكر كلمة مرور.`,
@@ -102,17 +104,17 @@ const arAE: LocaleProps = {
switchNetworkScreen_heading: 'تبديل الشبكات',
signInWithEthereumScreen_tooltip:
-'أنت غير مسجل الدخول حاليًا إلى هذا التطبيق.\n**سجل الدخول باستخدام إثيريوم** للمتابعة.',
+ 'أنت غير مسجل الدخول حاليًا إلى هذا التطبيق.\n**سجل الدخول باستخدام إثيريوم** للمتابعة.',
signInWithEthereumScreen_signedOut_heading: 'سجل الدخول باستخدام إثيريوم',
signInWithEthereumScreen_signedOut_h1:
-'يود هذا التطبيق التحقق منك \n كصاحب لهذه المحفظة.',
+ 'يود هذا التطبيق التحقق منك \n كصاحب لهذه المحفظة.',
signInWithEthereumScreen_signedOut_p: `يرجى تأكيد طلب الرسالة في محفظتك للمتابعة.`,
signInWithEthereumScreen_signedOut_button: 'سجل الدخول',
signInWithEthereumScreen_signedIn_heading: 'تم تسجيل الدخول باستخدام إثيريوم',
signInWithEthereumScreen_signedIn_h1:
-'لقد قمت بتأكيد نفسك كصاحب لهذه المحفظة بنجاح.',
+ 'لقد قمت بتأكيد نفسك كصاحب لهذه المحفظة بنجاح.',
signInWithEthereumScreen_signedIn_p: `سيتطلب تسجيل الخروج منك إعادة المصادقة مرة أخرى في المستقبل.`,
signInWithEthereumScreen_signedIn_button: 'تسجيل الخروج',
};
diff --git a/packages/connectkit/src/localizations/locales/ca-AD.ts b/packages/connectkit/src/localizations/locales/ca-AD.ts
index 490e639b8..46b5c1d00 100644
--- a/packages/connectkit/src/localizations/locales/ca-AD.ts
+++ b/packages/connectkit/src/localizations/locales/ca-AD.ts
@@ -1,116 +1,121 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const caAD: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'Connecta la cartera',
- disconnect: 'Desconnectar',
- connected: 'Connectat',
- wrongNetwork: 'Xarxa incorrecta',
- switchNetworks: 'Canvi de xarxa',
- chainNetwork: 'Xarxa {{ CHAIN }}',
- copyToClipboard: 'Copia al portapapers',
- copyCode: 'Copia codi',
- moreInformation: 'Més informació',
- back: 'Enrere',
- close: 'Tanca',
- or: 'o',
- more: 'Més',
- tryAgain: 'Torna-ho a intentar',
- tryAgainQuestion: 'Tornar a intentar-ho?',
- dontHaveTheApp: "No tens l'aplicació?",
- scanTheQRCode: 'Escaneja el codi QR',
- useWalletConnectModal: 'Utilitza WalletConnect Modal',
- useModal: 'Utilitza Modal',
- installTheExtension: "Instal·la l'extensió",
- getWalletName: 'Obté {{ CONNECTORNAME }}',
- otherWallets: 'Altres carteres',
- learnMore: 'Més informació',
- getWallet: 'Obté una cartera',
- approveInWallet: 'Aprova a la cartera',
- confirmInWallet: 'Confirma a la cartera',
- awaitingConfirmation: 'Esperant confirmació',
- signIn: 'Inicia sessió',
- signOut: 'Tanca sessió',
- signedIn: 'Sessió iniciada',
- signedOut: 'Sessió tancada',
- walletNotConnected: 'Cartera no connectada',
-
- warnings_walletSwitchingUnsupported: `La teva cartera no permet canviar de xarxa des d'aquesta aplicació.`,
- warnings_walletSwitchingUnsupportedResolve: `Prova a canviar de xarxa des de la teva cartera.`,
- warnings_chainUnsupported: `Aquesta aplicació no és compatible amb la xarxa connectada actualment.`,
- warnings_chainUnsupportedResolve: `Canvia o desconnecta per continuar.`,
-
- onboardingScreen_heading: `Obté una cartera`,
- onboardingScreen_h1: `Comença a explorar la Web3`,
- onboardingScreen_p: `La teva cartera és el portal d'accés a tot el relacionat amb Ethereum, la tecnologia màgica que permet explorar la Web3.`,
- onboardingScreen_ctaText: `Tria la teva primera cartera`,
- onboardingScreen_ctaUrl: `https://ethereum.org/es/wallets/find-wallet/`,
-
- aboutScreen_heading: `Sobre les carteres`,
- aboutScreen_a_h1: `Per als teus actius digitals`,
- aboutScreen_a_p: `Les carteres et permeten enviar, rebre, emmagatzemar i interactuar amb actius digitals com els NFT i altres tokens d'Ethereum.`,
- aboutScreen_b_h1: `Una manera millor d'iniciar sessió`,
- aboutScreen_b_p: `Amb les aplicacions modernes, pots utilitzar la teva cartera per iniciar sessió fàcilment, en lloc de haver de recordar una contrasenya.`,
- aboutScreen_c_h1: `Explora el món de la Web3`,
- aboutScreen_c_p: `La teva cartera és una eina essencial que et permet explorar i participar en el món en ràpida evolució de la Web3.`,
- aboutScreen_ctaText: `Més informació`,
- aboutScreen_ctaUrl: `https://ethereum.org/es/wallets/`,
-
- connectorsScreen_heading: `Connecta una cartera`,
- connectorsScreen_newcomer: `No tinc una cartera`,
- connectorsScreen_h1: `Què és una cartera?`,
- connectorsScreen_p: `Les carteres s'utilitzen per enviar, rebre i emmagatzemar actius digitals. Si connectes una cartera, podràs interactuar amb les aplicacions.`,
-
- mobileConnectorsScreen_heading: `Tria una cartera`,
-
- scanScreen_heading: `Escaneja amb el telèfon`,
- scanScreen_heading_withConnector: `Escaneja amb {{ CONNECTORNAME }}`,
- scanScreen_tooltip_walletConnect: `Obre una cartera compatible amb WalletConnect [WALLETCONNECTLOGO] per escanejar`,
- scanScreen_tooltip_default: `Obre {{ CONNECTORNAME }} en el teu telèfon mòbil per escanejar`,
-
- downloadAppScreen_heading: `Obté {{ CONNECTORNAME }}`,
- downloadAppScreen_iosAndroid: `Escaneja amb la càmera del teu telèfon per descarregar-la en iOS o Android.`,
- downloadAppScreen_ios: `Escaneja amb la càmera del teu telèfon per descarregar-la en iOS.`,
- downloadAppScreen_android: `Escaneja amb la càmera del teu telèfon per descarregar-la en Android.`,
-
- injectionScreen_unavailable_h1: `Navegador no compatible`,
- injectionScreen_unavailable_p: `Per connectar la teva cartera de {{ CONNECTORSHORTNAME }}, instal·la l'extensió en {{ SUGGESTEDEXTENSIONBROWSER }}.`,
-
- injectionScreen_install_h1: `Instal·la {{ CONNECTORNAME }}`,
- injectionScreen_install_p: `Per connectar la teva cartera de {{ CONNECTORSHORTNAME }}, instal·la l'extensió del navegador.`,
-
- injectionScreen_connecting_h1: `Sol·licitud de connexió`,
- injectionScreen_connecting_p: `Obre l'extensió del navegador de {{ CONNECTORSHORTNAME }} per connectar la teva cartera.`,
-
- injectionScreen_connecting_injected_h1: `Sol·licitud de connexió`,
- injectionScreen_connecting_injected_p: `Accepta la sol·licitud a través de la teva cartera per connectar-te a aquesta aplicació.`,
-
- injectionScreen_connected_h1: `Ja connectada`,
- injectionScreen_connected_p: `Ja pots tancar aquesta finestra emergent`,
-
- injectionScreen_rejected_h1: `Sol·licitud cancel·lada`,
- injectionScreen_rejected_p: `Has cancel·lat la sol·licitud. Fes clic a dalt per tornar-ho a intentar.`,
-
- injectionScreen_failed_h1: `Error de connexió`,
- injectionScreen_failed_p: `Ho sentim, hi ha hagut un problema. Intenta connectar-te de nou.`,
-
- injectionScreen_notconnected_h1: `Inicia sessió en {{ CONNECTORNAME }}`,
- injectionScreen_notconnected_p: `Per continuar, inicia sessió en la teva extensió de {{ CONNECTORNAME }}.`,
-
- profileScreen_heading: 'Connectat',
-
- switchNetworkScreen_heading: 'Canvi de xarxa',
-
- signInWithEthereumScreen_tooltip: 'No has iniciat sessió en aquesta aplicació.\n**Inicia sessió amb Ethereum** per continuar.',
-
- signInWithEthereumScreen_signedOut_heading: 'Inicia sessió amb Ethereum',
- signInWithEthereumScreen_signedOut_h1: "Aquesta aplicació vol verificar que ets el propietari d'aquesta cartera.",
- signInWithEthereumScreen_signedOut_p: `Signa la sol·licitud de missatge en la teva cartera per continuar.`,
- signInWithEthereumScreen_signedOut_button: 'Inicia sessió',
-
- signInWithEthereumScreen_signedIn_heading: 'Sessió iniciada amb Ethereum',
- signInWithEthereumScreen_signedIn_h1: "T'has verificat correctament com a propietari d'aquesta cartera.",
- signInWithEthereumScreen_signedIn_p: `Si tanques la sessió, hauràs de tornar a autenticar-te més endavant.`,
- signInWithEthereumScreen_signedIn_button: 'Tanca sessió',
+ disconnect: 'Desconnectar',
+ connected: 'Connectat',
+ wrongNetwork: 'Xarxa incorrecta',
+ switchNetworks: 'Canvi de xarxa',
+ chainNetwork: 'Xarxa {{ CHAIN }}',
+ copyToClipboard: 'Copia al portapapers',
+ copyCode: 'Copia codi',
+ moreInformation: 'Més informació',
+ back: 'Enrere',
+ close: 'Tanca',
+ or: 'o',
+ more: 'Més',
+ tryAgain: 'Torna-ho a intentar',
+ tryAgainQuestion: 'Tornar a intentar-ho?',
+ dontHaveTheApp: "No tens l'aplicació?",
+ scanTheQRCode: 'Escaneja el codi QR',
+ useWalletConnectModal: 'Utilitza WalletConnect Modal',
+ useModal: 'Utilitza Modal',
+ installTheExtension: "Instal·la l'extensió",
+ getWalletName: 'Obté {{ CONNECTORNAME }}',
+ otherWallets: 'Altres carteres',
+ learnMore: 'Més informació',
+ getWallet: 'Obté una cartera',
+ approveInWallet: 'Aprova a la cartera',
+ confirmInWallet: 'Confirma a la cartera',
+ awaitingConfirmation: 'Esperant confirmació',
+ signIn: 'Inicia sessió',
+ signOut: 'Tanca sessió',
+ signedIn: 'Sessió iniciada',
+ signedOut: 'Sessió tancada',
+ walletNotConnected: 'Cartera no connectada',
+
+ warnings_walletSwitchingUnsupported: `La teva cartera no permet canviar de xarxa des d'aquesta aplicació.`,
+ warnings_walletSwitchingUnsupportedResolve: `Prova a canviar de xarxa des de la teva cartera.`,
+ warnings_chainUnsupported: `Aquesta aplicació no és compatible amb la xarxa connectada actualment.`,
+ warnings_chainUnsupportedResolve: `Canvia o desconnecta per continuar.`,
+
+ onboardingScreen_heading: `Obté una cartera`,
+ onboardingScreen_h1: `Comença a explorar la Web3`,
+ onboardingScreen_p: `La teva cartera és el portal d'accés a tot el relacionat amb Ethereum, la tecnologia màgica que permet explorar la Web3.`,
+ onboardingScreen_ctaText: `Tria la teva primera cartera`,
+ onboardingScreen_ctaUrl: `https://ethereum.org/es/wallets/find-wallet/`,
+
+ aboutScreen_heading: `Sobre les carteres`,
+ aboutScreen_a_h1: `Per als teus actius digitals`,
+ aboutScreen_a_p: `Les carteres et permeten enviar, rebre, emmagatzemar i interactuar amb actius digitals com els NFT i altres tokens d'Ethereum.`,
+ aboutScreen_b_h1: `Una manera millor d'iniciar sessió`,
+ aboutScreen_b_p: `Amb les aplicacions modernes, pots utilitzar la teva cartera per iniciar sessió fàcilment, en lloc de haver de recordar una contrasenya.`,
+ aboutScreen_c_h1: `Explora el món de la Web3`,
+ aboutScreen_c_p: `La teva cartera és una eina essencial que et permet explorar i participar en el món en ràpida evolució de la Web3.`,
+ aboutScreen_ctaText: `Més informació`,
+ aboutScreen_ctaUrl: `https://ethereum.org/es/wallets/`,
+
+ connectorsScreen_heading: `Connecta una cartera`,
+ connectorsScreen_newcomer: `No tinc una cartera`,
+ connectorsScreen_h1: `Què és una cartera?`,
+ connectorsScreen_p: `Les carteres s'utilitzen per enviar, rebre i emmagatzemar actius digitals. Si connectes una cartera, podràs interactuar amb les aplicacions.`,
+
+ mobileConnectorsScreen_heading: `Tria una cartera`,
+
+ scanScreen_heading: `Escaneja amb el telèfon`,
+ scanScreen_heading_withConnector: `Escaneja amb {{ CONNECTORNAME }}`,
+ scanScreen_tooltip_walletConnect: `Obre una cartera compatible amb WalletConnect [WALLETCONNECTLOGO] per escanejar`,
+ scanScreen_tooltip_default: `Obre {{ CONNECTORNAME }} en el teu telèfon mòbil per escanejar`,
+
+ downloadAppScreen_heading: `Obté {{ CONNECTORNAME }}`,
+ downloadAppScreen_iosAndroid: `Escaneja amb la càmera del teu telèfon per descarregar-la en iOS o Android.`,
+ downloadAppScreen_ios: `Escaneja amb la càmera del teu telèfon per descarregar-la en iOS.`,
+ downloadAppScreen_android: `Escaneja amb la càmera del teu telèfon per descarregar-la en Android.`,
+
+ injectionScreen_unavailable_h1: `Navegador no compatible`,
+ injectionScreen_unavailable_p: `Per connectar la teva cartera de {{ CONNECTORSHORTNAME }}, instal·la l'extensió en {{ SUGGESTEDEXTENSIONBROWSER }}.`,
+
+ injectionScreen_install_h1: `Instal·la {{ CONNECTORNAME }}`,
+ injectionScreen_install_p: `Per connectar la teva cartera de {{ CONNECTORSHORTNAME }}, instal·la l'extensió del navegador.`,
+
+ injectionScreen_connecting_h1: `Sol·licitud de connexió`,
+ injectionScreen_connecting_p: `Obre l'extensió del navegador de {{ CONNECTORSHORTNAME }} per connectar la teva cartera.`,
+
+ injectionScreen_connecting_injected_h1: `Sol·licitud de connexió`,
+ injectionScreen_connecting_injected_p: `Accepta la sol·licitud a través de la teva cartera per connectar-te a aquesta aplicació.`,
+
+ injectionScreen_connected_h1: `Ja connectada`,
+ injectionScreen_connected_p: `Ja pots tancar aquesta finestra emergent`,
+
+ injectionScreen_rejected_h1: `Sol·licitud cancel·lada`,
+ injectionScreen_rejected_p: `Has cancel·lat la sol·licitud. Fes clic a dalt per tornar-ho a intentar.`,
+
+ injectionScreen_failed_h1: `Error de connexió`,
+ injectionScreen_failed_p: `Ho sentim, hi ha hagut un problema. Intenta connectar-te de nou.`,
+
+ injectionScreen_notconnected_h1: `Inicia sessió en {{ CONNECTORNAME }}`,
+ injectionScreen_notconnected_p: `Per continuar, inicia sessió en la teva extensió de {{ CONNECTORNAME }}.`,
+
+ profileScreen_heading: 'Connectat',
+
+ switchNetworkScreen_heading: 'Canvi de xarxa',
+
+ signInWithEthereumScreen_tooltip:
+ 'No has iniciat sessió en aquesta aplicació.\n**Inicia sessió amb Ethereum** per continuar.',
+
+ signInWithEthereumScreen_signedOut_heading: 'Inicia sessió amb Ethereum',
+ signInWithEthereumScreen_signedOut_h1:
+ "Aquesta aplicació vol verificar que ets el propietari d'aquesta cartera.",
+ signInWithEthereumScreen_signedOut_p: `Signa la sol·licitud de missatge en la teva cartera per continuar.`,
+ signInWithEthereumScreen_signedOut_button: 'Inicia sessió',
+
+ signInWithEthereumScreen_signedIn_heading: 'Sessió iniciada amb Ethereum',
+ signInWithEthereumScreen_signedIn_h1:
+ "T'has verificat correctament com a propietari d'aquesta cartera.",
+ signInWithEthereumScreen_signedIn_p: `Si tanques la sessió, hauràs de tornar a autenticar-te més endavant.`,
+ signInWithEthereumScreen_signedIn_button: 'Tanca sessió',
};
export default caAD;
diff --git a/packages/connectkit/src/localizations/locales/ee-EE.ts b/packages/connectkit/src/localizations/locales/ee-EE.ts
index ce408882f..b0607d043 100644
--- a/packages/connectkit/src/localizations/locales/ee-EE.ts
+++ b/packages/connectkit/src/localizations/locales/ee-EE.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const eeEE: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'Ühenda rahakott',
disconnect: 'Katkesta ühendus',
connected: 'Ühendatud',
diff --git a/packages/connectkit/src/localizations/locales/en-US.ts b/packages/connectkit/src/localizations/locales/en-US.ts
index 0fcbac9d6..c914bf0c2 100644
--- a/packages/connectkit/src/localizations/locales/en-US.ts
+++ b/packages/connectkit/src/localizations/locales/en-US.ts
@@ -1,9 +1,16 @@
const enUS = {
+ // Family Account
+ continueWithFamily: 'Continue with Family',
+ orSelectWallet: 'or select a wallet from the list below',
+ loginWithEmailOrPhone: 'Login with Email or Phone',
+ connectWithFamilyIOS: 'Connect with Family iOS',
+ // ConnectKit
connectWallet: 'Connect Wallet',
disconnect: 'Disconnect',
connected: 'Connected',
wrongNetwork: 'Wrong Network',
switchNetworks: 'Switch Networks',
+ switchWallets: 'Switch Wallets',
chainNetwork: '{{ CHAIN }} Network',
copyToClipboard: 'Copy to Clipboard',
copyCode: 'Copy Code',
@@ -68,7 +75,7 @@ const enUS = {
downloadAppScreen_heading: `Get {{ CONNECTORNAME }}`,
downloadAppScreen_iosAndroid: `Scan with your phone camera to download on iOS or Android.`,
downloadAppScreen_ios: `Scan with your phone camera to download on iOS.`,
- downloadAppScreen_android: `Scan with your phone camera to download Android.`,
+ downloadAppScreen_android: `Scan with your phone camera to download on Android.`,
injectionScreen_unavailable_h1: `Unsupported Browser`,
injectionScreen_unavailable_p: `To connect your {{ CONNECTORSHORTNAME }} wallet,\ninstall the extension on {{ SUGGESTEDEXTENSIONBROWSER }}.`,
diff --git a/packages/connectkit/src/localizations/locales/es-ES.ts b/packages/connectkit/src/localizations/locales/es-ES.ts
index 56a44a8b8..c183e9ece 100644
--- a/packages/connectkit/src/localizations/locales/es-ES.ts
+++ b/packages/connectkit/src/localizations/locales/es-ES.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const esES: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'Conecta una cartera',
disconnect: 'Desconectar',
connected: 'Conectado',
diff --git a/packages/connectkit/src/localizations/locales/fa-IR.ts b/packages/connectkit/src/localizations/locales/fa-IR.ts
index 0da6ab35e..861f092fb 100644
--- a/packages/connectkit/src/localizations/locales/fa-IR.ts
+++ b/packages/connectkit/src/localizations/locales/fa-IR.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const faIR: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'اتصال به کیف پول',
disconnect: 'قطع ارتباط',
connected: 'متصل شد',
diff --git a/packages/connectkit/src/localizations/locales/fr-FR.ts b/packages/connectkit/src/localizations/locales/fr-FR.ts
index 4cf37cb9f..e8d152301 100644
--- a/packages/connectkit/src/localizations/locales/fr-FR.ts
+++ b/packages/connectkit/src/localizations/locales/fr-FR.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const frFR: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'Connecter le portefeuille',
disconnect: 'Déconnecter',
connected: 'Connecté',
diff --git a/packages/connectkit/src/localizations/locales/ja-JP.ts b/packages/connectkit/src/localizations/locales/ja-JP.ts
index 3d6ef9c34..ab7291bd2 100644
--- a/packages/connectkit/src/localizations/locales/ja-JP.ts
+++ b/packages/connectkit/src/localizations/locales/ja-JP.ts
@@ -1,4 +1,8 @@
-export default {
+import { LocaleProps } from './';
+import enUS from './en-US';
+
+const jaJP: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'ウォレットの接続',
disconnect: '切断',
connected: '接続されました',
@@ -111,3 +115,5 @@ export default {
signInWithEthereumScreen_signedIn_p: `サインアウトすると、今後 再度認証する必要があります。`,
signInWithEthereumScreen_signedIn_button: 'サインアウト',
};
+
+export default jaJP;
diff --git a/packages/connectkit/src/localizations/locales/pt-BR.ts b/packages/connectkit/src/localizations/locales/pt-BR.ts
index d623fa537..0f649ca19 100644
--- a/packages/connectkit/src/localizations/locales/pt-BR.ts
+++ b/packages/connectkit/src/localizations/locales/pt-BR.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const ptBR: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'Conectar carteira',
disconnect: 'Desconectar',
connected: 'Conectado',
@@ -101,16 +103,19 @@ const ptBR: LocaleProps = {
switchNetworkScreen_heading: 'Alternar rede',
- signInWithEthereumScreen_tooltip: 'Você não está conectado a este aplicativo.\n**Entre com Ethereum** para continuar.',
+ signInWithEthereumScreen_tooltip:
+ 'Você não está conectado a este aplicativo.\n**Entre com Ethereum** para continuar.',
signInWithEthereumScreen_signedOut_heading: 'Entrar com Ethereum',
- signInWithEthereumScreen_signedOut_h1: 'Este aplicativo gostaria de verificar você \n como o proprietário desta carteira.',
+ signInWithEthereumScreen_signedOut_h1:
+ 'Este aplicativo gostaria de verificar você \n como o proprietário desta carteira.',
signInWithEthereumScreen_signedOut_p: `Por favor, assine o pedido de mensagem \n em sua carteira para continuar.`,
signInWithEthereumScreen_signedOut_button: 'Entrar',
signInWithEthereumScreen_signedIn_heading: 'Conectado com Ethereum',
- signInWithEthereumScreen_signedIn_h1: 'Você se verificou com sucesso \n como o proprietário desta carteira',
+ signInWithEthereumScreen_signedIn_h1:
+ 'Você se verificou com sucesso \n como o proprietário desta carteira',
signInWithEthereumScreen_signedIn_p: `Se sair, será necessário que você \n autentique novamente no futuro.`,
- signInWithEthereumScreen_signedIn_button: 'Sair'
+ signInWithEthereumScreen_signedIn_button: 'Sair',
};
export default ptBR;
diff --git a/packages/connectkit/src/localizations/locales/ru-RU.ts b/packages/connectkit/src/localizations/locales/ru-RU.ts
index 87accce08..1ff69778f 100644
--- a/packages/connectkit/src/localizations/locales/ru-RU.ts
+++ b/packages/connectkit/src/localizations/locales/ru-RU.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const ruRU: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'Подключить кошелек',
disconnect: 'Отключить',
connected: 'Подключена',
@@ -46,7 +48,7 @@ const ruRU: LocaleProps = {
onboardingScreen_ctaUrl: `https://ethereum.org/en/wallets/find-wallet/`,
aboutScreen_heading: `О кошельках`,
- aboutScreen_a_h1: `Для ваших цифровых активов`,
+ aboutScreen_a_h1: `Для ваших цифровых активов`,
aboutScreen_a_p: `Кошельки позволяют вам отправлять, получать, хранить и взаимодействовать с цифровыми активами, такими как NFT и другие токены Ethereum.`,
aboutScreen_b_h1: `Лучший способ входа`,
aboutScreen_b_p: `В современных приложениях ваш кошелек можно использовать как удобный способ входа без необходимости помнить пароль.`,
@@ -115,4 +117,4 @@ const ruRU: LocaleProps = {
signInWithEthereumScreen_signedIn_button: 'Выйти',
};
-export default ruRU;
\ No newline at end of file
+export default ruRU;
diff --git a/packages/connectkit/src/localizations/locales/tr-TR.ts b/packages/connectkit/src/localizations/locales/tr-TR.ts
index ccc64fa5e..d2bc30d05 100644
--- a/packages/connectkit/src/localizations/locales/tr-TR.ts
+++ b/packages/connectkit/src/localizations/locales/tr-TR.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const trTR: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'Cüzdan Bağla',
disconnect: 'Bağlantıyı Kes',
connected: 'Bağlandı',
@@ -16,7 +18,7 @@ const trTR: LocaleProps = {
more: 'Daha Fazla',
tryAgain: 'Tekrar Dene',
tryAgainQuestion: 'Tekrar Dene?',
- dontHaveTheApp: "Uygulaman yok mu?",
+ dontHaveTheApp: 'Uygulaman yok mu?',
scanTheQRCode: 'Karekodu tarat',
useWalletConnectModal: 'WalletConnect Modalini Kullan ',
useModal: 'Modal Kullan',
@@ -74,7 +76,6 @@ const trTR: LocaleProps = {
injectionScreen_unavailable_h1: `Desteklenmeyen Tarayıcı`,
injectionScreen_unavailable_p: `{{ CONNECTORSHORTNAME }} cüzdanına bağlanmak için\n{{ SUGGESTEDEXTENSIONBROWSER }} üzerinde indirmen gerekiyor.`,
-
injectionScreen_install_h1: `{{ CONNECTORNAME }} İndir`,
injectionScreen_install_p: `{{ CONNECTORSHORTNAME }} cüzdanına bağlanmak için,\ntarayıcı eklentisini indir.`,
diff --git a/packages/connectkit/src/localizations/locales/vi-VN.ts b/packages/connectkit/src/localizations/locales/vi-VN.ts
index f53debd48..cf834c809 100644
--- a/packages/connectkit/src/localizations/locales/vi-VN.ts
+++ b/packages/connectkit/src/localizations/locales/vi-VN.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const viVN: LocaleProps = {
+ ...enUS, // fallback
connectWallet: 'Kết nối ví',
disconnect: 'Ngắt kết nối',
connected: 'Đã kết nối',
diff --git a/packages/connectkit/src/localizations/locales/zh-CN.ts b/packages/connectkit/src/localizations/locales/zh-CN.ts
index f390c1bd0..b16680ce6 100644
--- a/packages/connectkit/src/localizations/locales/zh-CN.ts
+++ b/packages/connectkit/src/localizations/locales/zh-CN.ts
@@ -1,6 +1,8 @@
import { LocaleProps } from './';
+import enUS from './en-US';
const zhCN: LocaleProps = {
+ ...enUS, // fallback
connectWallet: '绑定钱包',
disconnect: '解除绑定',
connected: '已绑定',
diff --git a/packages/connectkit/src/styles/index.ts b/packages/connectkit/src/styles/index.ts
index af0b94613..2b89d1c9a 100644
--- a/packages/connectkit/src/styles/index.ts
+++ b/packages/connectkit/src/styles/index.ts
@@ -31,7 +31,7 @@ const themeGlobals = {
'--ck-graphic-scaniconwithlogos-04': '#F6F7F9',
'--ck-chain-ethereum-01': '#25292E',
- '--ck-chain-ethereum-02': '#fff',
+ '--ck-chain-ethereum-02': '#ffffff',
'--ck-chain-ethereum-03': '#DFE0E0',
},
dark: {
@@ -90,22 +90,18 @@ const themeGlobals = {
},
},
brand: {
+ '--ck-family-accounts-brand': '#0090ff',
'--ck-family-brand': '#1A88F8',
'--ck-brand-walletConnect': '#3B99FC',
'--ck-brand-coinbaseWallet': '#0052FF',
- '--ck-brand-metamask': '#f6851b',
- '--ck-brand-metamask-01': '#F6851B',
- '--ck-brand-metamask-02': '#E2761B',
- '--ck-brand-metamask-03': '#CD6116',
- '--ck-brand-metamask-04': '#161616',
- '--ck-brand-metamask-05': '#763D16',
- '--ck-brand-metamask-06': '#D7C1B3',
- '--ck-brand-metamask-07': '#C0AD9E',
- '--ck-brand-metamask-08': '#E4761B',
- '--ck-brand-metamask-09': '#233447',
- '--ck-brand-metamask-10': '#E4751F',
- '--ck-brand-metamask-11': '#FEF5E7',
- '--ck-brand-metamask-12': '#E3C8AB',
+ '--ck-brand-metamask': '#FF5C16',
+ '--ck-brand-metamask-bg': '#FFF2EB',
+ '--ck-brand-metamask-01': '#FF5C16',
+ '--ck-brand-metamask-02': '#E34807',
+ '--ck-brand-metamask-03': '#FF8D5D',
+ '--ck-brand-metamask-04': '#661800',
+ '--ck-brand-metamask-05': '#C0C4CD',
+ '--ck-brand-metamask-06': '#E7EBF6',
'--ck-brand-trust-01': '#3375BB',
'--ck-brand-trust-02': '#ffffff',
'--ck-brand-trust-01b': '#ffffff', // dark Theme
@@ -170,11 +166,11 @@ const themes = {
nouns: createCssColors(themeColors.nouns),
};
const globals = {
- brand: createCssVars(themeGlobals.brand),
- ensLight: createCssVars(themeGlobals.ens.light),
- ensDark: createCssVars(themeGlobals.ens.dark),
- graphicsLight: createCssVars(themeGlobals.graphics.light),
- graphicsDark: createCssVars(themeGlobals.graphics.dark),
+ brand: createCssColors(themeGlobals.brand),
+ ensLight: createCssColors(themeGlobals.ens.light),
+ ensDark: createCssColors(themeGlobals.ens.dark),
+ graphicsLight: createCssColors(themeGlobals.graphics.light),
+ graphicsDark: createCssColors(themeGlobals.graphics.dark),
};
const globalsLight = css`
@@ -262,7 +258,6 @@ export const ResetContainer = styled(motion.div)<{
}
}}
-
${(props) => {
if (
props.$customTheme &&
diff --git a/packages/connectkit/src/utils/index.ts b/packages/connectkit/src/utils/index.ts
index 66f22e8ac..58980508f 100644
--- a/packages/connectkit/src/utils/index.ts
+++ b/packages/connectkit/src/utils/index.ts
@@ -24,7 +24,7 @@ const nFormatter = (num: number, digits: number = 2) => {
{ value: 1, symbol: '' },
{ value: 1e3, symbol: 'k' },
{ value: 1e6, symbol: 'm' },
- { value: 1e9, symbol: 'g' },
+ { value: 1e9, symbol: 'b' },
{ value: 1e12, symbol: 't' },
{ value: 1e15, symbol: 'p' },
{ value: 1e18, symbol: 'e' },
@@ -80,6 +80,12 @@ function flattenChildren(children: React.ReactNode): ReactChildArray {
export const isWalletConnectConnector = (connectorId?: string) =>
connectorId === 'walletConnect';
+export const isFamilyAccountsConnector = (connectorId?: string) =>
+ connectorId === 'familyAccountsProvider';
+
+export const isFamilyConnector = (connectorId?: string) =>
+ connectorId === 'co.family.wallet';
+
export const isMetaMaskConnector = (connectorId?: string) =>
connectorId === 'metaMaskSDK';
@@ -89,6 +95,9 @@ export const isCoinbaseWalletConnector = (connectorId?: string) =>
export const isLedgerConnector = (connectorId?: string) =>
connectorId === 'ledger';
+export const isPortoConnector = (connectorId?: string) =>
+ connectorId === 'xyz.ithaca.porto';
+
export const isSafeConnector = (connectorId?: string) => connectorId === 'safe';
export const isInjectedConnector = (connectorId?: string) =>
diff --git a/packages/connectkit/src/utils/wallets.ts b/packages/connectkit/src/utils/wallets.ts
index 539139224..13c8383a4 100644
--- a/packages/connectkit/src/utils/wallets.ts
+++ b/packages/connectkit/src/utils/wallets.ts
@@ -25,6 +25,7 @@ export const isFrame = () => isWalletInstalled('Frame');
export const isPhantom = () => isWalletInstalled('Phantom');
export const isInfinityWallet = () => isWalletInstalled('InfinityWallet');
export const isRabby = () => isWalletInstalled('Rabby');
+export const isArgent = () => isWalletInstalled('Argent');
export const isFrontier = () => isWalletInstalled('Frontier');
export const isTrust = () => {
if (typeof window === 'undefined') return false;
@@ -39,3 +40,4 @@ export const isTalisman = () => isWalletInstalled('Talisman');
export const isFordefi = () => isWalletInstalled('Fordefi');
export const isRainbow = () => isWalletInstalled('Rainbow');
export const isZerion = () => isWalletInstalled('Zerion');
+export const isSafe = () => isWalletInstalled('Safe');
diff --git a/packages/connectkit/src/wallets/walletConfigs.tsx b/packages/connectkit/src/wallets/walletConfigs.tsx
index 557fb0266..dadf9057b 100644
--- a/packages/connectkit/src/wallets/walletConfigs.tsx
+++ b/packages/connectkit/src/wallets/walletConfigs.tsx
@@ -129,6 +129,13 @@ export const walletConfigs: {
: `familywallet://wc?uri=${encodeURIComponent(uri)}`;
},
},
+ familyAccountsProvider: {
+ name: 'Family',
+ shortName: 'Family',
+ icon: ,
+ iconConnector: ,
+ iconShape: 'squircle',
+ },
frame: {
name: 'Frame',
icon: ,
diff --git a/yarn.lock b/yarn.lock
index d73eb2652..fe62dc4d0 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -7218,6 +7218,7 @@ __metadata:
"@types/styled-components": ^5.1.25
buffer: ^6.0.3
detect-browser: ^5.3.0
+ family: ^0.1.2
framer-motion: ^6.3.11
qrcode: ^1.5.0
react-transition-state: ^1.1.4
@@ -9691,6 +9692,27 @@ __metadata:
languageName: unknown
linkType: soft
+"family@npm:^0.1.2":
+ version: 0.1.2
+ resolution: "family@npm:0.1.2"
+ peerDependencies:
+ react: 17.x || 18.x || 19.x
+ react-dom: 17.x || 18.x || 19.x
+ viem: 2.x
+ wagmi: 2.x
+ peerDependenciesMeta:
+ react:
+ optional: true
+ react-dom:
+ optional: true
+ viem:
+ optional: true
+ wagmi:
+ optional: true
+ checksum: 2e2d43b773f7c8719fcb93331416ef7710151f961e6645ae3ff87a23584335b1fe36b29099b28d6d860bacc3722888cf5de0373ea976d620b43a8daf21422274
+ languageName: node
+ linkType: hard
+
"fast-deep-equal@npm:^3.1.1, fast-deep-equal@npm:^3.1.3":
version: 3.1.3
resolution: "fast-deep-equal@npm:3.1.3"