@subwallet/extension-inject 1.1.35-0 → 1.1.37-0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/bundle.d.ts CHANGED
@@ -1,6 +1,7 @@
1
1
  import type { Injected, InjectOptions } from './types';
2
- import { EvmProvider } from './types';
2
+ import { EIP6963ProviderInfo, EvmProvider } from './types';
3
3
  export { packageInfo } from './packageInfo';
4
4
  export declare function injectExtension(enable: (origin: string) => Promise<Injected>, { name, version }: InjectOptions): void;
5
5
  export declare function injectEvmExtension(evmProvider: EvmProvider): void;
6
+ export declare const eip6963ProviderInfo: EIP6963ProviderInfo;
6
7
  export declare const inject6963EIP: (provider: EvmProvider) => void;
package/bundle.js CHANGED
@@ -44,31 +44,29 @@ export function injectEvmExtension(evmProvider) {
44
44
  windowInject.ethereum = evmProvider;
45
45
  windowInject.dispatchEvent(new Event('ethereum#initialized'));
46
46
  }
47
- inject6963EIP(evmProvider);
48
47
  });
49
48
 
50
- // Todo: Need more discuss to make SubWallet as global before window load because it can be conflict with MetaMask
51
- // windowInject.ethereum = evmProvider;
52
- // windowInject.dispatchEvent(new Event('ethereum#initialized'));
49
+ // inject6963EIP(evmProvider);
53
50
  }
54
51
 
52
+ export const eip6963ProviderInfo = {
53
+ uuid: '10c67337-9211-48d9-aab0-cecdc4224acc',
54
+ name: 'SubWallet',
55
+ icon: '',
56
+ rdns: 'app.subwallet'
57
+ };
55
58
  export const inject6963EIP = provider => {
56
- // TODO: Need to confirm that infomation
57
- const info = {
58
- uuid: '10c67337-9211-48d9-aab0-cecdc4224acc',
59
- name: 'SubWallet',
60
- icon: '',
61
- rdns: 'app.subwallet.wallet'
62
- };
63
59
  const _provider = new Proxy(provider, {
64
- // TODO: Please review the security of this
65
60
  get(target, key) {
66
61
  if (key === 'then') {
67
62
  return Promise.resolve(target);
68
63
  }
69
-
70
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-return
71
- return Reflect.get(target, key).bind(target);
64
+ const proxyTarget = Reflect.get(target, key);
65
+ if (typeof (proxyTarget === null || proxyTarget === void 0 ? void 0 : proxyTarget.bind) === 'function') {
66
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-return
67
+ return proxyTarget.bind(target);
68
+ }
69
+ return proxyTarget;
72
70
  },
73
71
  deleteProperty() {
74
72
  return true;
@@ -76,7 +74,7 @@ export const inject6963EIP = provider => {
76
74
  });
77
75
  const announceProvider = () => {
78
76
  const detail = Object.freeze({
79
- info: info,
77
+ info: eip6963ProviderInfo,
80
78
  provider: _provider
81
79
  });
82
80
  const event = new CustomEvent('eip6963:announceProvider', {
package/cjs/bundle.js CHANGED
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.inject6963EIP = void 0;
6
+ exports.inject6963EIP = exports.eip6963ProviderInfo = void 0;
7
7
  exports.injectEvmExtension = injectEvmExtension;
8
8
  exports.injectExtension = injectExtension;
9
9
  Object.defineProperty(exports, "packageInfo", {
@@ -58,31 +58,30 @@ function injectEvmExtension(evmProvider) {
58
58
  windowInject.ethereum = evmProvider;
59
59
  windowInject.dispatchEvent(new Event('ethereum#initialized'));
60
60
  }
61
- inject6963EIP(evmProvider);
62
61
  });
63
62
 
64
- // Todo: Need more discuss to make SubWallet as global before window load because it can be conflict with MetaMask
65
- // windowInject.ethereum = evmProvider;
66
- // windowInject.dispatchEvent(new Event('ethereum#initialized'));
63
+ // inject6963EIP(evmProvider);
67
64
  }
68
65
 
66
+ const eip6963ProviderInfo = {
67
+ uuid: '10c67337-9211-48d9-aab0-cecdc4224acc',
68
+ name: 'SubWallet',
69
+ icon: '',
70
+ rdns: 'app.subwallet'
71
+ };
72
+ exports.eip6963ProviderInfo = eip6963ProviderInfo;
69
73
  const inject6963EIP = provider => {
70
- // TODO: Need to confirm that infomation
71
- const info = {
72
- uuid: '10c67337-9211-48d9-aab0-cecdc4224acc',
73
- name: 'SubWallet',
74
- icon: '',
75
- rdns: 'app.subwallet.wallet'
76
- };
77
74
  const _provider = new Proxy(provider, {
78
- // TODO: Please review the security of this
79
75
  get(target, key) {
80
76
  if (key === 'then') {
81
77
  return Promise.resolve(target);
82
78
  }
83
-
84
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-return
85
- return Reflect.get(target, key).bind(target);
79
+ const proxyTarget = Reflect.get(target, key);
80
+ if (typeof (proxyTarget === null || proxyTarget === void 0 ? void 0 : proxyTarget.bind) === 'function') {
81
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-return
82
+ return proxyTarget.bind(target);
83
+ }
84
+ return proxyTarget;
86
85
  },
87
86
  deleteProperty() {
88
87
  return true;
@@ -90,7 +89,7 @@ const inject6963EIP = provider => {
90
89
  });
91
90
  const announceProvider = () => {
92
91
  const detail = Object.freeze({
93
- info: info,
92
+ info: eip6963ProviderInfo,
94
93
  provider: _provider
95
94
  });
96
95
  const event = new CustomEvent('eip6963:announceProvider', {
@@ -13,6 +13,6 @@ const packageInfo = {
13
13
  name: '@subwallet/extension-inject',
14
14
  path: typeof __dirname === 'string' ? __dirname : 'auto',
15
15
  type: 'cjs',
16
- version: '1.1.35-0'
16
+ version: '1.1.37-0'
17
17
  };
18
18
  exports.packageInfo = packageInfo;
package/package.json CHANGED
@@ -14,7 +14,7 @@
14
14
  },
15
15
  "sideEffects": true,
16
16
  "type": "module",
17
- "version": "1.1.35-0",
17
+ "version": "1.1.37-0",
18
18
  "main": "./cjs/index.js",
19
19
  "module": "./index.js",
20
20
  "types": "./index.d.ts",
package/packageInfo.js CHANGED
@@ -7,5 +7,5 @@ export const packageInfo = {
7
7
  name: '@subwallet/extension-inject',
8
8
  path: (import.meta && import.meta.url) ? new URL(import.meta.url).pathname.substring(0, new URL(import.meta.url).pathname.lastIndexOf('/') + 1) : 'auto',
9
9
  type: 'esm',
10
- version: '1.1.35-0'
10
+ version: '1.1.37-0'
11
11
  };