diff --git a/packages/demo/package.json b/packages/demo/package.json index 187853687..00f07869f 100644 --- a/packages/demo/package.json +++ b/packages/demo/package.json @@ -34,7 +34,7 @@ "@web3-onboard/keepkey": "^2.3.3", "@web3-onboard/keystone": "^2.3.3", "@web3-onboard/ledger": "^2.4.2", - "@web3-onboard/injected-wallets": "^2.6.1", + "@web3-onboard/injected-wallets": "^2.6.2-alpha.1", "@web3-onboard/magic": "^2.1.3", "@web3-onboard/phantom": "^2.0.0-alpha.1", "@web3-onboard/portis": "^2.1.3", diff --git a/packages/injected/package.json b/packages/injected/package.json index f1b583574..f22eeb132 100644 --- a/packages/injected/package.json +++ b/packages/injected/package.json @@ -1,6 +1,6 @@ { "name": "@web3-onboard/injected-wallets", - "version": "2.6.1", + "version": "2.6.2-alpha.1", "description": "Injected wallet module for connecting browser extension and mobile wallets to Web3-Onboard. Web3-Onboard makes it simple to connect Ethereum hardware and software wallets to your dapp. Features standardised spec compliant web3 providers for all supported wallets, framework agnostic modern javascript UI with code splitting, CSS customization, multi-chain and multi-account support, reactive wallet state subscriptions and real-time transaction state change notifications.", "keywords": [ "Ethereum", diff --git a/packages/injected/src/icons/safepal.ts b/packages/injected/src/icons/safepal.ts new file mode 100644 index 000000000..076e5888e --- /dev/null +++ b/packages/injected/src/icons/safepal.ts @@ -0,0 +1,102 @@ +export default ` +` diff --git a/packages/injected/src/types.ts b/packages/injected/src/types.ts index 8458f7d29..20e236c0c 100644 --- a/packages/injected/src/types.ts +++ b/packages/injected/src/types.ts @@ -51,10 +51,11 @@ export enum ProviderIdentityFlag { Opera = 'isOpera', Bitski = 'isBitski', Enkrypt = 'isEnkrypt', - Zeal = 'isZeal', Phantom = 'isPhantom', + Zeal = 'isZeal', Zerion = 'isZerion', - Rainbow = 'isRainbow' + Rainbow = 'isRainbow', + SafePal = 'isSafePal' } export enum ProviderLabel { @@ -99,7 +100,8 @@ export enum ProviderLabel { Zeal = 'Zeal', Phantom = 'Phantom', Zerion = 'Zerion', - Rainbow = 'Rainbow' + Rainbow = 'Rainbow', + SafePal = 'SafePal' } export interface MeetOneProvider extends ExternalProvider { diff --git a/packages/injected/src/wallets.ts b/packages/injected/src/wallets.ts index c0891e22d..8bcb70135 100644 --- a/packages/injected/src/wallets.ts +++ b/packages/injected/src/wallets.ts @@ -659,6 +659,18 @@ const phantom: InjectedWalletModule = { }), platforms: ['all'] } + +const safepal: InjectedWalletModule = { + label: ProviderLabel.SafePal, + injectedNamespace: InjectedNameSpace.Ethereum, + checkProviderIdentity: ({ provider }) => + !!provider && !!provider[ProviderIdentityFlag.SafePal], + getIcon: async () => (await import('./icons/safepal.js')).default, + getInterface: async () => ({ + provider: createEIP1193Provider(window.ethereum) + }), + platforms: ['all'] +} const rainbow: InjectedWalletModule = { label: ProviderLabel.Rainbow, @@ -710,7 +722,8 @@ const wallets = [ enkrypt, phantom, zerion, - rainbow + rainbow, + safepal ] export default wallets