@dynamic-labs/utils 1.0.0-alpha.0 → 1.0.0-alpha.10
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/CHANGELOG.md +176 -0
- package/package.json +3 -3
- package/src/DeferredPromise/DeferredPromise.cjs +21 -0
- package/src/DeferredPromise/DeferredPromise.d.ts +13 -0
- package/src/DeferredPromise/DeferredPromise.js +17 -0
- package/src/DeferredPromise/index.d.ts +1 -0
- package/src/errors/InsufficientFundsError.cjs +24 -0
- package/src/errors/InsufficientFundsError.d.ts +9 -0
- package/src/errors/InsufficientFundsError.js +20 -0
- package/src/errors/PasskeyError.d.ts +8 -0
- package/src/errors/TransactionGasCannotBeSponsoredError.cjs +24 -0
- package/src/errors/TransactionGasCannotBeSponsoredError.d.ts +9 -0
- package/src/errors/TransactionGasCannotBeSponsoredError.js +20 -0
- package/src/errors/index.d.ts +3 -0
- package/src/index.cjs +8 -4
- package/src/index.d.ts +2 -2
- package/src/index.js +4 -2
- package/src/isMobile.cjs +12 -2
- package/src/isMobile.js +12 -2
- package/src/wrapMethodWithCallback/index.d.ts +1 -0
- package/src/wrapMethodWithCallback/wrapMethodWithCallback.cjs +46 -0
- package/src/wrapMethodWithCallback/wrapMethodWithCallback.d.ts +36 -0
- package/src/wrapMethodWithCallback/wrapMethodWithCallback.js +42 -0
- package/src/bigIntToHex/bigIntToHex.cjs +0 -15
- package/src/bigIntToHex/bigIntToHex.d.ts +0 -1
- package/src/bigIntToHex/bigIntToHex.js +0 -11
- package/src/bigIntToHex/index.d.ts +0 -1
- package/src/isBigInt/index.d.ts +0 -1
- package/src/isBigInt/isBigInt.cjs +0 -7
- package/src/isBigInt/isBigInt.d.ts +0 -1
- package/src/isBigInt/isBigInt.js +0 -3
package/CHANGELOG.md
CHANGED
|
@@ -1,4 +1,180 @@
|
|
|
1
1
|
|
|
2
|
+
## [1.0.0-alpha.10](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.9...v1.0.0-alpha.10) (2023-12-08)
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
### Bug Fixes
|
|
6
|
+
|
|
7
|
+
* allow transaction error to read from viem error ([#4101](https://github.com/dynamic-labs/DynamicAuth/issues/4101)) ([0f46cbe](https://github.com/dynamic-labs/DynamicAuth/commit/0f46cbea1eb260c2efdeee9b62f669fb3cf4ab93))
|
|
8
|
+
* trigger claim flow for unclaimed embedded smart contract wallet signer ([#4108](https://github.com/dynamic-labs/DynamicAuth/issues/4108)) ([37c9013](https://github.com/dynamic-labs/DynamicAuth/commit/37c9013109f2d6a37bde041da9072c5f5fa2df67))
|
|
9
|
+
* WalletConnect v2 connector with non active chains ([#4085](https://github.com/dynamic-labs/DynamicAuth/issues/4085)) ([f69cbe9](https://github.com/dynamic-labs/DynamicAuth/commit/f69cbe96012563f71e89939c96f2a46926e7b394))
|
|
10
|
+
|
|
11
|
+
## [1.0.0-alpha.9](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.8...v1.0.0-alpha.9) (2023-12-07)
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
### ⚠ BREAKING CHANGES
|
|
15
|
+
|
|
16
|
+
* how to migrate
|
|
17
|
+
Whenever you would use the property wallets from the object returned by useDynamicContext, you must now rename it to walletConnectorOptions.
|
|
18
|
+
|
|
19
|
+
### Features
|
|
20
|
+
|
|
21
|
+
* add support for eip6963 ([#4064](https://github.com/dynamic-labs/DynamicAuth/issues/4064)) ([3f8cf0e](https://github.com/dynamic-labs/DynamicAuth/commit/3f8cf0e4250945f3a331f701d491a308fab5f7b8))
|
|
22
|
+
* allow AA wallets to access owner features ([#4079](https://github.com/dynamic-labs/DynamicAuth/issues/4079)) ([9efc2be](https://github.com/dynamic-labs/DynamicAuth/commit/9efc2bee87ec9193c3682863d72024b3586de724))
|
|
23
|
+
* introduce UserWalletsContext ([#4083](https://github.com/dynamic-labs/DynamicAuth/issues/4083)) ([b9ca7f6](https://github.com/dynamic-labs/DynamicAuth/commit/b9ca7f6b0aff4b3992325b70cc9a903ece445c7f))
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
### Bug Fixes
|
|
27
|
+
|
|
28
|
+
* ensure zero dev provider will receive a signer ([#4084](https://github.com/dynamic-labs/DynamicAuth/issues/4084)) ([f02a540](https://github.com/dynamic-labs/DynamicAuth/commit/f02a54036d39bfc5fb0c262f292acf914e4bd653))
|
|
29
|
+
* render recovery section only when turnkey provider is enabled ([#4093](https://github.com/dynamic-labs/DynamicAuth/issues/4093)) ([5f29bd2](https://github.com/dynamic-labs/DynamicAuth/commit/5f29bd23ccca2e307822377be28396edc7ab1fda))
|
|
30
|
+
* reset selected social provider on logout ([#4078](https://github.com/dynamic-labs/DynamicAuth/issues/4078)) ([85dc611](https://github.com/dynamic-labs/DynamicAuth/commit/85dc611d9c0e733bdb9d316b008bdaa35bcc2a91))
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
* rename wallets > walletConnectorOptions ([#4086](https://github.com/dynamic-labs/DynamicAuth/issues/4086)) ([10a7795](https://github.com/dynamic-labs/DynamicAuth/commit/10a779567e751469a667095726da52d78facbd57))
|
|
34
|
+
|
|
35
|
+
## [1.0.0-alpha.8](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.7...v1.0.0-alpha.8) (2023-12-05)
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
### ⚠ BREAKING CHANGES
|
|
39
|
+
|
|
40
|
+
* rename EthereumSmartWalletConnectors to ZeroDevSmartWalletConnectors (#4067)
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
### Features
|
|
44
|
+
|
|
45
|
+
* add support for pregenerated wallets + securing them ([#3968](https://github.com/dynamic-labs/DynamicAuth/issues/3968)) ([8212b76](https://github.com/dynamic-labs/DynamicAuth/commit/8212b760ba199bd989e0ba2ad3caf97590db4861))
|
|
46
|
+
|
|
47
|
+
## [1.0.0-alpha.7](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.6...v1.0.0-alpha.7) (2023-12-05)
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
### Features
|
|
51
|
+
|
|
52
|
+
* add support for Turnkey HD wallets and backwards compatiblity for private key wallets ([#4011](https://github.com/dynamic-labs/DynamicAuth/issues/4011)) ([75c5258](https://github.com/dynamic-labs/DynamicAuth/commit/75c5258da494d5d4dfa8b96655303dd9645f2269))
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
### Bug Fixes
|
|
56
|
+
|
|
57
|
+
* add close button to wallets list ([#4036](https://github.com/dynamic-labs/DynamicAuth/issues/4036)) ([a2b988b](https://github.com/dynamic-labs/DynamicAuth/commit/a2b988bdfc662af6f85d37a79ed6666c483aa447))
|
|
58
|
+
* add support for embedded wallets in connect-only ([#4041](https://github.com/dynamic-labs/DynamicAuth/issues/4041)) ([ceea635](https://github.com/dynamic-labs/DynamicAuth/commit/ceea635b69e2a0c2636b47fbd30639d69dba7a1c))
|
|
59
|
+
* embedded wallet invalid stored chain breaking network picker ([#4050](https://github.com/dynamic-labs/DynamicAuth/issues/4050)) ([2e2384b](https://github.com/dynamic-labs/DynamicAuth/commit/2e2384ba37407d9164cce47e23f5d5f469f7e062))
|
|
60
|
+
* handle insufficient funds from AA provider ([#4027](https://github.com/dynamic-labs/DynamicAuth/issues/4027)) ([6b9cc88](https://github.com/dynamic-labs/DynamicAuth/commit/6b9cc886f4f2590094bd50aba195c07a5532dfa4))
|
|
61
|
+
* prevent double logout caused by wagmi sync ([#4048](https://github.com/dynamic-labs/DynamicAuth/issues/4048)) ([c66c81c](https://github.com/dynamic-labs/DynamicAuth/commit/c66c81c80839aa9ce1cfae76f4afce12e34f3513))
|
|
62
|
+
* properly detect network switch for secondary wallets ([#4038](https://github.com/dynamic-labs/DynamicAuth/issues/4038)) ([f87174d](https://github.com/dynamic-labs/DynamicAuth/commit/f87174de0892dd057401eaf3c0bc68d974add0fc))
|
|
63
|
+
* **use-wallets-connected-state:** update state on wallet id change ([#4045](https://github.com/dynamic-labs/DynamicAuth/issues/4045)) ([ca3a835](https://github.com/dynamic-labs/DynamicAuth/commit/ca3a8359eae386bffa758ed646ac14af8360a7f8))
|
|
64
|
+
* user should be able to see the full passkey name on management view ([#4043](https://github.com/dynamic-labs/DynamicAuth/issues/4043)) ([7bc1b70](https://github.com/dynamic-labs/DynamicAuth/commit/7bc1b7043cbc9f0e21df78a57efc3e6938a99db2))
|
|
65
|
+
* users should be able to easily find passkey recovery ([#4058](https://github.com/dynamic-labs/DynamicAuth/issues/4058)) ([0202ae9](https://github.com/dynamic-labs/DynamicAuth/commit/0202ae98c96544dec5ac357dc77000996e32ad33))
|
|
66
|
+
|
|
67
|
+
## [1.0.0-alpha.6](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.5...v1.0.0-alpha.6) (2023-11-29)
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
### Bug Fixes
|
|
71
|
+
|
|
72
|
+
* transaction layout show alert ([#4024](https://github.com/dynamic-labs/DynamicAuth/issues/4024)) ([52057f5](https://github.com/dynamic-labs/DynamicAuth/commit/52057f54ebc32464b2486a2328cb6310caf85208)), closes [#4020](https://github.com/dynamic-labs/DynamicAuth/issues/4020)
|
|
73
|
+
|
|
74
|
+
## [1.0.0-alpha.5](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.4...v1.0.0-alpha.5) (2023-11-29)
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
### Features
|
|
78
|
+
|
|
79
|
+
* gracefully handle uknown wallet ([#3997](https://github.com/dynamic-labs/DynamicAuth/issues/3997)) ([ce7ff6a](https://github.com/dynamic-labs/DynamicAuth/commit/ce7ff6a50a8e8947050734b61587c8cadd041dbe))
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
### Bug Fixes
|
|
83
|
+
|
|
84
|
+
* remove total on sponsored transactions ([#4019](https://github.com/dynamic-labs/DynamicAuth/issues/4019)) ([d976678](https://github.com/dynamic-labs/DynamicAuth/commit/d9766787b29665fbcd7983c5d61c31a4d97c8257))
|
|
85
|
+
* send balance align information ([#4020](https://github.com/dynamic-labs/DynamicAuth/issues/4020)) ([508dccf](https://github.com/dynamic-labs/DynamicAuth/commit/508dccfa2c6aeaed30616b6a41b30002cccb3b40))
|
|
86
|
+
|
|
87
|
+
## [1.0.0-alpha.4](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.3...v1.0.0-alpha.4) (2023-11-28)
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
### Bug Fixes
|
|
91
|
+
|
|
92
|
+
* update zerodev provider initialization ([#4015](https://github.com/dynamic-labs/DynamicAuth/issues/4015)) ([8faca00](https://github.com/dynamic-labs/DynamicAuth/commit/8faca00d414677adc5fecde451ca01da53fe9641))
|
|
93
|
+
|
|
94
|
+
## [1.0.0-alpha.3](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.2...v1.0.0-alpha.3) (2023-11-28)
|
|
95
|
+
|
|
96
|
+
|
|
97
|
+
### Bug Fixes
|
|
98
|
+
|
|
99
|
+
* fix solflare mobile wallet deep linking ([#3998](https://github.com/dynamic-labs/DynamicAuth/issues/3998)) ([10069ae](https://github.com/dynamic-labs/DynamicAuth/commit/10069ae9ed5d8e1978131f57c3e90680e85d2efb))
|
|
100
|
+
* passkey error message when reaching limit of accounts ([#4010](https://github.com/dynamic-labs/DynamicAuth/issues/4010)) ([dabce3b](https://github.com/dynamic-labs/DynamicAuth/commit/dabce3b6ada4bac75903b43d5cb125cfd5619d18))
|
|
101
|
+
|
|
102
|
+
## [1.0.0-alpha.2](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.1...v1.0.0-alpha.2) (2023-11-28)
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
### ⚠ BREAKING CHANGES
|
|
106
|
+
|
|
107
|
+
* rename walletsByChain to bridgeChains (#3954)
|
|
108
|
+
|
|
109
|
+
### Features
|
|
110
|
+
|
|
111
|
+
* passkey management and recovery ([#3911](https://github.com/dynamic-labs/DynamicAuth/issues/3911)) ([b692b3a](https://github.com/dynamic-labs/DynamicAuth/commit/b692b3a8697d0ffb441faae97e609b144965695d))
|
|
112
|
+
|
|
113
|
+
|
|
114
|
+
### Bug Fixes
|
|
115
|
+
|
|
116
|
+
* ensure all chain rpc providers are always assigned correctly ([#3981](https://github.com/dynamic-labs/DynamicAuth/issues/3981)) ([cd2e25c](https://github.com/dynamic-labs/DynamicAuth/commit/cd2e25c4eb39791866c1ea283d61fff388cce5df))
|
|
117
|
+
* initialize selected chain with first evm network if no value in ls ([#3999](https://github.com/dynamic-labs/DynamicAuth/issues/3999)) ([bc9e43b](https://github.com/dynamic-labs/DynamicAuth/commit/bc9e43be9d33c75bb1236756589f63f17b230ab1))
|
|
118
|
+
* nextjs issues to show transaction modals ([#3964](https://github.com/dynamic-labs/DynamicAuth/issues/3964)) ([9326ac4](https://github.com/dynamic-labs/DynamicAuth/commit/9326ac49394e067ce38b17faff08b4fabf91bb3f))
|
|
119
|
+
* onEmbeddedWalletCreated not being called ([#3975](https://github.com/dynamic-labs/DynamicAuth/issues/3975)) ([035cebe](https://github.com/dynamic-labs/DynamicAuth/commit/035cebe02891048e62c66a7277ed7f43c27e559d))
|
|
120
|
+
* return linked wallets even when there's no primary wallet ([#3965](https://github.com/dynamic-labs/DynamicAuth/issues/3965)) ([27705de](https://github.com/dynamic-labs/DynamicAuth/commit/27705de4ac7e1584efd1245bb9c6a818b1c20742))
|
|
121
|
+
* transaction modal not throwing viem compatible exception ([#3971](https://github.com/dynamic-labs/DynamicAuth/issues/3971)) ([bedab0c](https://github.com/dynamic-labs/DynamicAuth/commit/bedab0c4448bcca5c3e696ceb276867ce55bbd85))
|
|
122
|
+
* **zero-dev:** ensure the sign typed data is parsed for zero dev to handle ([#3974](https://github.com/dynamic-labs/DynamicAuth/issues/3974)) ([f517738](https://github.com/dynamic-labs/DynamicAuth/commit/f517738e1abc138f882525c128cd1ee5e88b9050))
|
|
123
|
+
* zerodev sign message with ethers ([#3972](https://github.com/dynamic-labs/DynamicAuth/issues/3972)) ([5de3873](https://github.com/dynamic-labs/DynamicAuth/commit/5de3873daa9cbfeef6dd9123b7a319d8e6b412d5))
|
|
124
|
+
* **zerodev:** ensure ECDSAProvider supports sendUserOperation ([#4003](https://github.com/dynamic-labs/DynamicAuth/issues/4003)) ([c8f5886](https://github.com/dynamic-labs/DynamicAuth/commit/c8f58868fcf6912fd11a92940369faf37e3fcdde))
|
|
125
|
+
* **zerodev:** ensure transaction is sponsored before submission ([#3932](https://github.com/dynamic-labs/DynamicAuth/issues/3932)) ([74becb7](https://github.com/dynamic-labs/DynamicAuth/commit/74becb7ec2fd55f8b905a9c9f0bbba44a9d22513))
|
|
126
|
+
|
|
127
|
+
|
|
128
|
+
* rename walletsByChain to bridgeChains ([#3954](https://github.com/dynamic-labs/DynamicAuth/issues/3954)) ([a91e8fe](https://github.com/dynamic-labs/DynamicAuth/commit/a91e8fe605694ccd8a00b71aa194c0c5191f156c))
|
|
129
|
+
|
|
130
|
+
## [1.0.0-alpha.1](https://github.com/dynamic-labs/DynamicAuth/compare/v1.0.0-alpha.0...v1.0.0-alpha.1) (2023-11-22)
|
|
131
|
+
|
|
132
|
+
|
|
133
|
+
### Features
|
|
134
|
+
|
|
135
|
+
* add basic zerodev connector ([#3782](https://github.com/dynamic-labs/DynamicAuth/issues/3782)) ([3f8debd](https://github.com/dynamic-labs/DynamicAuth/commit/3f8debddb1bff325389193e0348128ebb9ba59b9))
|
|
136
|
+
* add hcaptcha to dynamic signin methods ([#3853](https://github.com/dynamic-labs/DynamicAuth/issues/3853)) ([a4a9ad3](https://github.com/dynamic-labs/DynamicAuth/commit/a4a9ad3b048e33acc5b885cd797697ca4f41995e))
|
|
137
|
+
* add hcaptcha to magic login methods ([#3894](https://github.com/dynamic-labs/DynamicAuth/issues/3894)) ([c76b750](https://github.com/dynamic-labs/DynamicAuth/commit/c76b750351557ad9cf5bbcc39bd7fd0970b66312))
|
|
138
|
+
* add need help section to sign message modal ([#3847](https://github.com/dynamic-labs/DynamicAuth/issues/3847)) ([4f90617](https://github.com/dynamic-labs/DynamicAuth/commit/4f90617bcf400a7171062435c731d95c6bbf41c7))
|
|
139
|
+
* add perawallet to wallet book ([#3868](https://github.com/dynamic-labs/DynamicAuth/issues/3868)) ([5f4e79d](https://github.com/dynamic-labs/DynamicAuth/commit/5f4e79df202b02088b15c5dfab7feee5789e9ece))
|
|
140
|
+
* add serialization to allow sending events callbacks and wallet connectors used by customers ([0077eb0](https://github.com/dynamic-labs/DynamicAuth/commit/0077eb0af05feb765d0c61911a48d5e98554760a))
|
|
141
|
+
* add support for dynamic domains for starknet signatures ([#3927](https://github.com/dynamic-labs/DynamicAuth/issues/3927)) ([52797ce](https://github.com/dynamic-labs/DynamicAuth/commit/52797ce867c956049bfa5021cf5b1c562e771a2e))
|
|
142
|
+
* add support for Pera Wallet ([#3866](https://github.com/dynamic-labs/DynamicAuth/issues/3866)) ([cb99ae7](https://github.com/dynamic-labs/DynamicAuth/commit/cb99ae77605d913932a77bf2ea565b7e7baf781a))
|
|
143
|
+
* add support for private starknet rpc providers ([#3881](https://github.com/dynamic-labs/DynamicAuth/issues/3881)) ([8fd5ef9](https://github.com/dynamic-labs/DynamicAuth/commit/8fd5ef902d48ef828b1cb89d0e462ea5b54f4e42))
|
|
144
|
+
* add zerodev to wallet book and render generic wallet icon ([#3822](https://github.com/dynamic-labs/DynamicAuth/issues/3822)) ([9c5768d](https://github.com/dynamic-labs/DynamicAuth/commit/9c5768d0fc1169c62927926c0e436b6a448d5656))
|
|
145
|
+
* allow updating evmNetworks in real time ([#3877](https://github.com/dynamic-labs/DynamicAuth/issues/3877)) ([b4a2521](https://github.com/dynamic-labs/DynamicAuth/commit/b4a2521830b859a129d70bad2ae1213db075550d))
|
|
146
|
+
* editable copies as typed data ([#3784](https://github.com/dynamic-labs/DynamicAuth/issues/3784)) ([d6c6d74](https://github.com/dynamic-labs/DynamicAuth/commit/d6c6d74e60c9c9d459414c452fbd780d3f6bc2f9))
|
|
147
|
+
* email inputs now use email keyboard ([#3843](https://github.com/dynamic-labs/DynamicAuth/issues/3843)) ([76926e2](https://github.com/dynamic-labs/DynamicAuth/commit/76926e26b6a188d9d8e3bba2512340610e218e9f))
|
|
148
|
+
* hide unlink if disabled in dashboard ([#3825](https://github.com/dynamic-labs/DynamicAuth/issues/3825)) ([a0625e6](https://github.com/dynamic-labs/DynamicAuth/commit/a0625e6fd01aa5b57e6b8542efe04e280e0c6830))
|
|
149
|
+
* initialize smart wallet from verified credentials ([#3790](https://github.com/dynamic-labs/DynamicAuth/issues/3790)) ([1fc5890](https://github.com/dynamic-labs/DynamicAuth/commit/1fc5890f2e0ef458bfb59d38d536c41d183bc2a2))
|
|
150
|
+
* set smart wallet as primary when owner is an embedded wallet ([#3898](https://github.com/dynamic-labs/DynamicAuth/issues/3898)) ([ec40172](https://github.com/dynamic-labs/DynamicAuth/commit/ec401729f38d946d5431bbbb15c5c1cdc66acb73))
|
|
151
|
+
* support forced network validation via DynamicContext setting ([#3879](https://github.com/dynamic-labs/DynamicAuth/issues/3879)) ([a7993b9](https://github.com/dynamic-labs/DynamicAuth/commit/a7993b9b6bdd739bcb4e66e46d14e7f8623bed66))
|
|
152
|
+
* **transaction:** add sponsored gas transaction ([#3869](https://github.com/dynamic-labs/DynamicAuth/issues/3869)) ([ccceb24](https://github.com/dynamic-labs/DynamicAuth/commit/ccceb2421e029dc60e53912e404b574324d6772f))
|
|
153
|
+
|
|
154
|
+
|
|
155
|
+
### Bug Fixes
|
|
156
|
+
|
|
157
|
+
* **account-abstraction:** set verified credentials before setting EOA to wallet connector ([#3941](https://github.com/dynamic-labs/DynamicAuth/issues/3941)) ([7475c46](https://github.com/dynamic-labs/DynamicAuth/commit/7475c465f5ddf9e27d0b05d23e58d9b474fa8fd4))
|
|
158
|
+
* add brand to zerodev object ([#3828](https://github.com/dynamic-labs/DynamicAuth/issues/3828)) ([81cb237](https://github.com/dynamic-labs/DynamicAuth/commit/81cb237df4def8e1c53b4ae145afafccf3b04683))
|
|
159
|
+
* add spriteId to zerodev ([#3829](https://github.com/dynamic-labs/DynamicAuth/issues/3829)) ([6b87c5c](https://github.com/dynamic-labs/DynamicAuth/commit/6b87c5c3d5869f6cd15a7534fb0260932845fbb1))
|
|
160
|
+
* allow metadata to be updated in updateUser hook ([#3928](https://github.com/dynamic-labs/DynamicAuth/issues/3928)) ([4f39fbd](https://github.com/dynamic-labs/DynamicAuth/commit/4f39fbd757b4e816dd60651252575c1f7e4d80aa))
|
|
161
|
+
* blocto flow connect only infinite recursion ([#3883](https://github.com/dynamic-labs/DynamicAuth/issues/3883)) ([6c6f5ba](https://github.com/dynamic-labs/DynamicAuth/commit/6c6f5ba5dc0657cc7ffdc82a4ea7935f65686088))
|
|
162
|
+
* clear project settings on page refresh ([#3826](https://github.com/dynamic-labs/DynamicAuth/issues/3826)) ([da5b8f0](https://github.com/dynamic-labs/DynamicAuth/commit/da5b8f0a99bf913ea11314954e5f08c2b019f50f))
|
|
163
|
+
* don't call computeConnectedStateForWallets too often to avoid infinite loops ([#3946](https://github.com/dynamic-labs/DynamicAuth/issues/3946)) ([de4e61a](https://github.com/dynamic-labs/DynamicAuth/commit/de4e61a3fcdc9c25cbe030c3c25cbc2c04929a93))
|
|
164
|
+
* don't call disconnect multiple times ([#3940](https://github.com/dynamic-labs/DynamicAuth/issues/3940)) ([3ea8623](https://github.com/dynamic-labs/DynamicAuth/commit/3ea86233d8d07dfb3c751a5fec45d5df84e9e143))
|
|
165
|
+
* **embedded wallet:** stop overriding primary wallet selection ([#3796](https://github.com/dynamic-labs/DynamicAuth/issues/3796)) ([75b81e7](https://github.com/dynamic-labs/DynamicAuth/commit/75b81e74d472ce8cc493646b441d2b4fe3962373))
|
|
166
|
+
* exodusevm wallet connect and mobile deep linking ([#3855](https://github.com/dynamic-labs/DynamicAuth/issues/3855)) ([cf0b3f0](https://github.com/dynamic-labs/DynamicAuth/commit/cf0b3f077f935eab32ce45947f62e73342d6c169))
|
|
167
|
+
* handle errors properly when engaging captcha ([#3896](https://github.com/dynamic-labs/DynamicAuth/issues/3896)) ([2596315](https://github.com/dynamic-labs/DynamicAuth/commit/25963153d699b26c6e04ea38b267446d3a3af13b))
|
|
168
|
+
* null safe check to window object ([#3882](https://github.com/dynamic-labs/DynamicAuth/issues/3882)) ([8856b5a](https://github.com/dynamic-labs/DynamicAuth/commit/8856b5ae40d43285eac667401387971b9e3f077d))
|
|
169
|
+
* pass correct wallet connector onLinkSuccess ([#3904](https://github.com/dynamic-labs/DynamicAuth/issues/3904)) ([79cca69](https://github.com/dynamic-labs/DynamicAuth/commit/79cca69ed53a5ef2c4e4d712ce0934e1a4c11459))
|
|
170
|
+
* remove extra captcha context provider instantiation causing unecessary rerenderings ([#3914](https://github.com/dynamic-labs/DynamicAuth/issues/3914)) ([14120a6](https://github.com/dynamic-labs/DynamicAuth/commit/14120a6ac0415f9a59608b376e88de6c729d4e5d))
|
|
171
|
+
* remove the coming soon label ([#3860](https://github.com/dynamic-labs/DynamicAuth/issues/3860)) ([1effb7f](https://github.com/dynamic-labs/DynamicAuth/commit/1effb7f124bda66aae3e8991b5386a1cee28fd99))
|
|
172
|
+
* Revert "chore: fix vite build ([#3849](https://github.com/dynamic-labs/DynamicAuth/issues/3849))" ([#3870](https://github.com/dynamic-labs/DynamicAuth/issues/3870)) ([13bc424](https://github.com/dynamic-labs/DynamicAuth/commit/13bc42483bcb9338babd46eae00988acada83578))
|
|
173
|
+
* **single-wallet:** prompt user to select correct wallet ([#3742](https://github.com/dynamic-labs/DynamicAuth/issues/3742)) ([ccfdd3c](https://github.com/dynamic-labs/DynamicAuth/commit/ccfdd3cc6a4ac7f3b1ea13be92e58982ecfb1c59))
|
|
174
|
+
* update walletconnect.json and walletconnect source schema ([#3854](https://github.com/dynamic-labs/DynamicAuth/issues/3854)) ([88ee546](https://github.com/dynamic-labs/DynamicAuth/commit/88ee5468db0130b19c6637a5632e64e0bb5197ba))
|
|
175
|
+
* useEmailProvider not checking for enabled providers properly ([7c16edc](https://github.com/dynamic-labs/DynamicAuth/commit/7c16edc3785ba10d69762b174f054b0d10b8a072))
|
|
176
|
+
* **wagmi:** ensure chain is defined on wallet client ([#3888](https://github.com/dynamic-labs/DynamicAuth/issues/3888)) ([0e145f6](https://github.com/dynamic-labs/DynamicAuth/commit/0e145f6ac42f55df7a020716d4ddc023554d72f9))
|
|
177
|
+
|
|
2
178
|
## [1.0.0-alpha.0](https://github.com/dynamic-labs/DynamicAuth/compare/v0.19.0...v1.0.0-alpha.0) (2023-10-31)
|
|
3
179
|
|
|
4
180
|
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dynamic-labs/utils",
|
|
3
|
-
"version": "1.0.0-alpha.
|
|
3
|
+
"version": "1.0.0-alpha.10",
|
|
4
4
|
"repository": {
|
|
5
5
|
"type": "git",
|
|
6
6
|
"url": "https://github.com/dynamic-labs/DynamicAuth.git",
|
|
@@ -29,7 +29,7 @@
|
|
|
29
29
|
"viem": "^1.5.3"
|
|
30
30
|
},
|
|
31
31
|
"dependencies": {
|
|
32
|
-
"@dynamic-labs/logger": "1.0.0-alpha.
|
|
33
|
-
"@dynamic-labs/types": "1.0.0-alpha.
|
|
32
|
+
"@dynamic-labs/logger": "1.0.0-alpha.10",
|
|
33
|
+
"@dynamic-labs/types": "1.0.0-alpha.10"
|
|
34
34
|
}
|
|
35
35
|
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* A DeferredPromise provides methods to manually resolve or reject a Promise.
|
|
7
|
+
* This is useful in scenarios where you need to resolve or reject a Promise
|
|
8
|
+
* outside of the executor function.
|
|
9
|
+
*
|
|
10
|
+
* @template T The type of the value with which the promise will be resolved.
|
|
11
|
+
*/
|
|
12
|
+
class DeferredPromise {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.promise = new Promise((resolve, reject) => {
|
|
15
|
+
this.resolve = resolve;
|
|
16
|
+
this.reject = reject;
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
exports.DeferredPromise = DeferredPromise;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A DeferredPromise provides methods to manually resolve or reject a Promise.
|
|
3
|
+
* This is useful in scenarios where you need to resolve or reject a Promise
|
|
4
|
+
* outside of the executor function.
|
|
5
|
+
*
|
|
6
|
+
* @template T The type of the value with which the promise will be resolved.
|
|
7
|
+
*/
|
|
8
|
+
export declare class DeferredPromise<T> {
|
|
9
|
+
promise: Promise<T>;
|
|
10
|
+
resolve: (value: T | PromiseLike<T>) => void;
|
|
11
|
+
reject: (reason?: any) => void;
|
|
12
|
+
constructor();
|
|
13
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A DeferredPromise provides methods to manually resolve or reject a Promise.
|
|
3
|
+
* This is useful in scenarios where you need to resolve or reject a Promise
|
|
4
|
+
* outside of the executor function.
|
|
5
|
+
*
|
|
6
|
+
* @template T The type of the value with which the promise will be resolved.
|
|
7
|
+
*/
|
|
8
|
+
class DeferredPromise {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.promise = new Promise((resolve, reject) => {
|
|
11
|
+
this.resolve = resolve;
|
|
12
|
+
this.reject = reject;
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export { DeferredPromise };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { DeferredPromise } from './DeferredPromise';
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var DynamicError = require('./DynamicError.cjs');
|
|
6
|
+
|
|
7
|
+
class InsufficientFundsError extends DynamicError.DynamicError {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(InsufficientFundsError.message);
|
|
10
|
+
}
|
|
11
|
+
static isInstance(err) {
|
|
12
|
+
var _a;
|
|
13
|
+
const error = ((_a = err === null || err === void 0 ? void 0 : err.walk) === null || _a === void 0 ? void 0 : _a.call(err)) || err;
|
|
14
|
+
return error instanceof InsufficientFundsError;
|
|
15
|
+
}
|
|
16
|
+
static isErrorMessage(err) {
|
|
17
|
+
var _a;
|
|
18
|
+
const errorWithMessage = err;
|
|
19
|
+
return (((_a = errorWithMessage === null || errorWithMessage === void 0 ? void 0 : errorWithMessage.message) === null || _a === void 0 ? void 0 : _a.includes("AA21 didn't pay prefund")) || false);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
InsufficientFundsError.message = 'Insufficient funds.';
|
|
23
|
+
|
|
24
|
+
exports.InsufficientFundsError = InsufficientFundsError;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { DynamicError } from './DynamicError';
|
|
2
|
+
export declare class InsufficientFundsError extends DynamicError {
|
|
3
|
+
constructor();
|
|
4
|
+
static message: string;
|
|
5
|
+
static isInstance(err: {
|
|
6
|
+
walk?: () => unknown;
|
|
7
|
+
} | unknown): err is InsufficientFundsError;
|
|
8
|
+
static isErrorMessage(err: unknown): boolean;
|
|
9
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { DynamicError } from './DynamicError.js';
|
|
2
|
+
|
|
3
|
+
class InsufficientFundsError extends DynamicError {
|
|
4
|
+
constructor() {
|
|
5
|
+
super(InsufficientFundsError.message);
|
|
6
|
+
}
|
|
7
|
+
static isInstance(err) {
|
|
8
|
+
var _a;
|
|
9
|
+
const error = ((_a = err === null || err === void 0 ? void 0 : err.walk) === null || _a === void 0 ? void 0 : _a.call(err)) || err;
|
|
10
|
+
return error instanceof InsufficientFundsError;
|
|
11
|
+
}
|
|
12
|
+
static isErrorMessage(err) {
|
|
13
|
+
var _a;
|
|
14
|
+
const errorWithMessage = err;
|
|
15
|
+
return (((_a = errorWithMessage === null || errorWithMessage === void 0 ? void 0 : errorWithMessage.message) === null || _a === void 0 ? void 0 : _a.includes("AA21 didn't pay prefund")) || false);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
InsufficientFundsError.message = 'Insufficient funds.';
|
|
19
|
+
|
|
20
|
+
export { InsufficientFundsError };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var DynamicError = require('./DynamicError.cjs');
|
|
6
|
+
|
|
7
|
+
class TransactionGasCannotBeSponsoredError extends DynamicError.DynamicError {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(TransactionGasCannotBeSponsoredError.message);
|
|
10
|
+
}
|
|
11
|
+
static isInstance(err) {
|
|
12
|
+
var _a;
|
|
13
|
+
const error = ((_a = err === null || err === void 0 ? void 0 : err.walk) === null || _a === void 0 ? void 0 : _a.call(err)) || err;
|
|
14
|
+
return error instanceof TransactionGasCannotBeSponsoredError;
|
|
15
|
+
}
|
|
16
|
+
static isErrorMessage(err) {
|
|
17
|
+
var _a;
|
|
18
|
+
const errorWithMessage = err;
|
|
19
|
+
return (((_a = errorWithMessage === null || errorWithMessage === void 0 ? void 0 : errorWithMessage.message) === null || _a === void 0 ? void 0 : _a.includes('userOp did not match any gas sponsoring policies')) || false);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
TransactionGasCannotBeSponsoredError.message = 'Transaction gas cannot be sponsored.';
|
|
23
|
+
|
|
24
|
+
exports.TransactionGasCannotBeSponsoredError = TransactionGasCannotBeSponsoredError;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { DynamicError } from './DynamicError';
|
|
2
|
+
export declare class TransactionGasCannotBeSponsoredError extends DynamicError {
|
|
3
|
+
constructor();
|
|
4
|
+
static message: string;
|
|
5
|
+
static isInstance(err: {
|
|
6
|
+
walk?: () => unknown;
|
|
7
|
+
} | unknown): err is TransactionGasCannotBeSponsoredError;
|
|
8
|
+
static isErrorMessage(err: unknown): boolean;
|
|
9
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { DynamicError } from './DynamicError.js';
|
|
2
|
+
|
|
3
|
+
class TransactionGasCannotBeSponsoredError extends DynamicError {
|
|
4
|
+
constructor() {
|
|
5
|
+
super(TransactionGasCannotBeSponsoredError.message);
|
|
6
|
+
}
|
|
7
|
+
static isInstance(err) {
|
|
8
|
+
var _a;
|
|
9
|
+
const error = ((_a = err === null || err === void 0 ? void 0 : err.walk) === null || _a === void 0 ? void 0 : _a.call(err)) || err;
|
|
10
|
+
return error instanceof TransactionGasCannotBeSponsoredError;
|
|
11
|
+
}
|
|
12
|
+
static isErrorMessage(err) {
|
|
13
|
+
var _a;
|
|
14
|
+
const errorWithMessage = err;
|
|
15
|
+
return (((_a = errorWithMessage === null || errorWithMessage === void 0 ? void 0 : errorWithMessage.message) === null || _a === void 0 ? void 0 : _a.includes('userOp did not match any gas sponsoring policies')) || false);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
TransactionGasCannotBeSponsoredError.message = 'Transaction gas cannot be sponsored.';
|
|
19
|
+
|
|
20
|
+
export { TransactionGasCannotBeSponsoredError };
|
package/src/errors/index.d.ts
CHANGED
|
@@ -14,3 +14,6 @@ export * from './MissingEnvironmentIdError';
|
|
|
14
14
|
export * from './GateBlockedError';
|
|
15
15
|
export * from './UserHasAccountWithEmailError';
|
|
16
16
|
export * from './SocialAccountAlreadyExistsError';
|
|
17
|
+
export * from './TransactionGasCannotBeSponsoredError';
|
|
18
|
+
export * from './InsufficientFundsError';
|
|
19
|
+
export * from './PasskeyError';
|
package/src/index.cjs
CHANGED
|
@@ -20,6 +20,8 @@ var MissingEnvironmentIdError = require('./errors/MissingEnvironmentIdError.cjs'
|
|
|
20
20
|
var GateBlockedError = require('./errors/GateBlockedError.cjs');
|
|
21
21
|
var UserHasAccountWithEmailError = require('./errors/UserHasAccountWithEmailError.cjs');
|
|
22
22
|
var SocialAccountAlreadyExistsError = require('./errors/SocialAccountAlreadyExistsError.cjs');
|
|
23
|
+
var TransactionGasCannotBeSponsoredError = require('./errors/TransactionGasCannotBeSponsoredError.cjs');
|
|
24
|
+
var InsufficientFundsError = require('./errors/InsufficientFundsError.cjs');
|
|
23
25
|
var CancellablePromise = require('./CancellablePromise/CancellablePromise.cjs');
|
|
24
26
|
var isFunction = require('./isFunction/isFunction.cjs');
|
|
25
27
|
var isMobile = require('./isMobile.cjs');
|
|
@@ -29,9 +31,9 @@ var last = require('./last.cjs');
|
|
|
29
31
|
var getProvidersFromWindow = require('./getProvidersFromWindow.cjs');
|
|
30
32
|
var sleep = require('./sleep/sleep.cjs');
|
|
31
33
|
var getOrMapViemChain = require('./getOrMapViemChain.cjs');
|
|
32
|
-
var bigIntToHex = require('./bigIntToHex/bigIntToHex.cjs');
|
|
33
|
-
var isBigInt = require('./isBigInt/isBigInt.cjs');
|
|
34
34
|
var retryableFn = require('./retryableFn.cjs');
|
|
35
|
+
var wrapMethodWithCallback = require('./wrapMethodWithCallback/wrapMethodWithCallback.cjs');
|
|
36
|
+
var DeferredPromise = require('./DeferredPromise/DeferredPromise.cjs');
|
|
35
37
|
|
|
36
38
|
|
|
37
39
|
|
|
@@ -53,6 +55,8 @@ exports.MissingEnvironmentIdError = MissingEnvironmentIdError.MissingEnvironment
|
|
|
53
55
|
exports.GateBlockedError = GateBlockedError.GateBlockedError;
|
|
54
56
|
exports.UserHasAccountWithEmailError = UserHasAccountWithEmailError.UserHasAccountWithEmailError;
|
|
55
57
|
exports.SocialAccountAlreadyExistsError = SocialAccountAlreadyExistsError.SocialAccountAlreadyExistsError;
|
|
58
|
+
exports.TransactionGasCannotBeSponsoredError = TransactionGasCannotBeSponsoredError.TransactionGasCannotBeSponsoredError;
|
|
59
|
+
exports.InsufficientFundsError = InsufficientFundsError.InsufficientFundsError;
|
|
56
60
|
exports.CancellablePromise = CancellablePromise.CancellablePromise;
|
|
57
61
|
exports.isFunction = isFunction.isFunction;
|
|
58
62
|
exports.getAndroidVersion = isMobile.getAndroidVersion;
|
|
@@ -75,7 +79,7 @@ exports.sleep = sleep.sleep;
|
|
|
75
79
|
exports.getChain = getOrMapViemChain.getChain;
|
|
76
80
|
exports.getOrMapViemChain = getOrMapViemChain.getOrMapViemChain;
|
|
77
81
|
exports.mapChain = getOrMapViemChain.mapChain;
|
|
78
|
-
exports.bigIntToHex = bigIntToHex.bigIntToHex;
|
|
79
|
-
exports.isBigInt = isBigInt.isBigInt;
|
|
80
82
|
exports.FALLBACK_UNDEFINED = retryableFn.FALLBACK_UNDEFINED;
|
|
81
83
|
exports.retryableFn = retryableFn.retryableFn;
|
|
84
|
+
exports.wrapMethodWithCallback = wrapMethodWithCallback.wrapMethodWithCallback;
|
|
85
|
+
exports.DeferredPromise = DeferredPromise.DeferredPromise;
|
package/src/index.d.ts
CHANGED
|
@@ -10,6 +10,6 @@ export * from './last';
|
|
|
10
10
|
export * from './getProvidersFromWindow';
|
|
11
11
|
export * from './sleep';
|
|
12
12
|
export * from './getOrMapViemChain';
|
|
13
|
-
export * from './bigIntToHex';
|
|
14
|
-
export * from './isBigInt';
|
|
15
13
|
export * from './retryableFn';
|
|
14
|
+
export * from './wrapMethodWithCallback';
|
|
15
|
+
export * from './DeferredPromise';
|
package/src/index.js
CHANGED
|
@@ -16,6 +16,8 @@ export { MissingEnvironmentIdError } from './errors/MissingEnvironmentIdError.js
|
|
|
16
16
|
export { GateBlockedError } from './errors/GateBlockedError.js';
|
|
17
17
|
export { UserHasAccountWithEmailError } from './errors/UserHasAccountWithEmailError.js';
|
|
18
18
|
export { SocialAccountAlreadyExistsError } from './errors/SocialAccountAlreadyExistsError.js';
|
|
19
|
+
export { TransactionGasCannotBeSponsoredError } from './errors/TransactionGasCannotBeSponsoredError.js';
|
|
20
|
+
export { InsufficientFundsError } from './errors/InsufficientFundsError.js';
|
|
19
21
|
export { CancellablePromise } from './CancellablePromise/CancellablePromise.js';
|
|
20
22
|
export { isFunction } from './isFunction/isFunction.js';
|
|
21
23
|
export { getAndroidVersion, isAndroid, isIOS, isIPad, isIPhone, isIPhone8OrEarlier, isLegacySafari, isMobile, isSamsungBrowser, isWindows } from './isMobile.js';
|
|
@@ -25,6 +27,6 @@ export { last } from './last.js';
|
|
|
25
27
|
export { getProvidersFromWindow } from './getProvidersFromWindow.js';
|
|
26
28
|
export { sleep } from './sleep/sleep.js';
|
|
27
29
|
export { getChain, getOrMapViemChain, mapChain } from './getOrMapViemChain.js';
|
|
28
|
-
export { bigIntToHex } from './bigIntToHex/bigIntToHex.js';
|
|
29
|
-
export { isBigInt } from './isBigInt/isBigInt.js';
|
|
30
30
|
export { FALLBACK_UNDEFINED, retryableFn } from './retryableFn.js';
|
|
31
|
+
export { wrapMethodWithCallback } from './wrapMethodWithCallback/wrapMethodWithCallback.js';
|
|
32
|
+
export { DeferredPromise } from './DeferredPromise/DeferredPromise.js';
|
package/src/isMobile.cjs
CHANGED
|
@@ -47,7 +47,9 @@ const isAndroid = () => isMobile() && !isIOS();
|
|
|
47
47
|
const isLegacySafari = () => {
|
|
48
48
|
// We need to check if window.CSS exists and if it has supports function.
|
|
49
49
|
// We can use it only in browsers. This prevents customer tests from failing because of that.
|
|
50
|
-
if (
|
|
50
|
+
if (typeof window === 'undefined' ||
|
|
51
|
+
!window.CSS ||
|
|
52
|
+
typeof window.CSS.supports !== 'function') {
|
|
51
53
|
return false;
|
|
52
54
|
}
|
|
53
55
|
// Older versions of Safari <15 are not supporting aspect-ratio css property.
|
|
@@ -62,7 +64,12 @@ const isSamsungBrowser = () => {
|
|
|
62
64
|
}
|
|
63
65
|
return navigator.userAgent.includes('SamsungBrowser');
|
|
64
66
|
};
|
|
65
|
-
const isWindows = () =>
|
|
67
|
+
const isWindows = () => {
|
|
68
|
+
if (typeof window === 'undefined' || typeof navigator === 'undefined') {
|
|
69
|
+
return false;
|
|
70
|
+
}
|
|
71
|
+
return navigator.userAgent.indexOf('Windows') !== -1;
|
|
72
|
+
};
|
|
66
73
|
// regex from: https://github.com/matomo-org/device-detector/blob/master/regexes/device/mobiles.yml
|
|
67
74
|
const iPhoneLegacyRegex = [
|
|
68
75
|
{
|
|
@@ -115,6 +122,9 @@ const iPhoneLegacyRegex = [
|
|
|
115
122
|
},
|
|
116
123
|
];
|
|
117
124
|
const getAndroidVersion = () => {
|
|
125
|
+
if (typeof navigator === 'undefined') {
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
118
128
|
const androidVersionMatch = navigator.userAgent.match(/Android (\d+(\.\d+)?)/);
|
|
119
129
|
if (!androidVersionMatch) {
|
|
120
130
|
return;
|
package/src/isMobile.js
CHANGED
|
@@ -43,7 +43,9 @@ const isAndroid = () => isMobile() && !isIOS();
|
|
|
43
43
|
const isLegacySafari = () => {
|
|
44
44
|
// We need to check if window.CSS exists and if it has supports function.
|
|
45
45
|
// We can use it only in browsers. This prevents customer tests from failing because of that.
|
|
46
|
-
if (
|
|
46
|
+
if (typeof window === 'undefined' ||
|
|
47
|
+
!window.CSS ||
|
|
48
|
+
typeof window.CSS.supports !== 'function') {
|
|
47
49
|
return false;
|
|
48
50
|
}
|
|
49
51
|
// Older versions of Safari <15 are not supporting aspect-ratio css property.
|
|
@@ -58,7 +60,12 @@ const isSamsungBrowser = () => {
|
|
|
58
60
|
}
|
|
59
61
|
return navigator.userAgent.includes('SamsungBrowser');
|
|
60
62
|
};
|
|
61
|
-
const isWindows = () =>
|
|
63
|
+
const isWindows = () => {
|
|
64
|
+
if (typeof window === 'undefined' || typeof navigator === 'undefined') {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
return navigator.userAgent.indexOf('Windows') !== -1;
|
|
68
|
+
};
|
|
62
69
|
// regex from: https://github.com/matomo-org/device-detector/blob/master/regexes/device/mobiles.yml
|
|
63
70
|
const iPhoneLegacyRegex = [
|
|
64
71
|
{
|
|
@@ -111,6 +118,9 @@ const iPhoneLegacyRegex = [
|
|
|
111
118
|
},
|
|
112
119
|
];
|
|
113
120
|
const getAndroidVersion = () => {
|
|
121
|
+
if (typeof navigator === 'undefined') {
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
114
124
|
const androidVersionMatch = navigator.userAgent.match(/Android (\d+(\.\d+)?)/);
|
|
115
125
|
if (!androidVersionMatch) {
|
|
116
126
|
return;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { wrapMethodWithCallback } from './wrapMethodWithCallback';
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Wraps an existing method of an object with a callback function. This allows for additional
|
|
7
|
+
* processing or behavior to be executed around the original method. The original method is
|
|
8
|
+
* called within the callback, and its parameters and return value can be accessed and/or modified.
|
|
9
|
+
*
|
|
10
|
+
* @template T - The type of the object whose method is being wrapped.
|
|
11
|
+
* @template K - The key type of the method within the object.
|
|
12
|
+
* @template F - The type of the function, inferred from the method of the object.
|
|
13
|
+
*
|
|
14
|
+
* @param {T} obj - The object containing the method to be wrapped.
|
|
15
|
+
* @param {K} key - The key of the method in the object to be wrapped.
|
|
16
|
+
* @param {(original: F, ...args: Parameters<F>) => ReturnType<F>} callback - The callback
|
|
17
|
+
* function to wrap around the original method. It receive1`s the original method and its
|
|
18
|
+
* parameters as arguments.
|
|
19
|
+
*
|
|
20
|
+
* @returns {void} - The function does not return a value; it modifies the method of the object in place.
|
|
21
|
+
*
|
|
22
|
+
* @example
|
|
23
|
+
* // Example usage
|
|
24
|
+
* const myObject = {
|
|
25
|
+
* greet(name) {
|
|
26
|
+
* return `Hello, ${name}!`;
|
|
27
|
+
* }
|
|
28
|
+
* };
|
|
29
|
+
*
|
|
30
|
+
* wrapMethodWithCallback(myObject, 'greet', (original, ...args) => {
|
|
31
|
+
* console.log('Greet method called with args:', args);
|
|
32
|
+
* return original(...args).toUpperCase();
|
|
33
|
+
* });
|
|
34
|
+
*
|
|
35
|
+
* console.log(myObject.greet('Alice')); // Logs: 'Greet method called with args: ["Alice"]'
|
|
36
|
+
* // Returns: 'HELLO, ALICE!'
|
|
37
|
+
*/
|
|
38
|
+
const wrapMethodWithCallback = (obj, key, callback) => {
|
|
39
|
+
const original = obj[key];
|
|
40
|
+
const boundOriginal = original.bind(obj);
|
|
41
|
+
Object.assign(obj, {
|
|
42
|
+
[key]: (...args) => callback(boundOriginal, ...args),
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
exports.wrapMethodWithCallback = wrapMethodWithCallback;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
type Method = (...args: any[]) => any;
|
|
2
|
+
/**
|
|
3
|
+
* Wraps an existing method of an object with a callback function. This allows for additional
|
|
4
|
+
* processing or behavior to be executed around the original method. The original method is
|
|
5
|
+
* called within the callback, and its parameters and return value can be accessed and/or modified.
|
|
6
|
+
*
|
|
7
|
+
* @template T - The type of the object whose method is being wrapped.
|
|
8
|
+
* @template K - The key type of the method within the object.
|
|
9
|
+
* @template F - The type of the function, inferred from the method of the object.
|
|
10
|
+
*
|
|
11
|
+
* @param {T} obj - The object containing the method to be wrapped.
|
|
12
|
+
* @param {K} key - The key of the method in the object to be wrapped.
|
|
13
|
+
* @param {(original: F, ...args: Parameters<F>) => ReturnType<F>} callback - The callback
|
|
14
|
+
* function to wrap around the original method. It receive1`s the original method and its
|
|
15
|
+
* parameters as arguments.
|
|
16
|
+
*
|
|
17
|
+
* @returns {void} - The function does not return a value; it modifies the method of the object in place.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* // Example usage
|
|
21
|
+
* const myObject = {
|
|
22
|
+
* greet(name) {
|
|
23
|
+
* return `Hello, ${name}!`;
|
|
24
|
+
* }
|
|
25
|
+
* };
|
|
26
|
+
*
|
|
27
|
+
* wrapMethodWithCallback(myObject, 'greet', (original, ...args) => {
|
|
28
|
+
* console.log('Greet method called with args:', args);
|
|
29
|
+
* return original(...args).toUpperCase();
|
|
30
|
+
* });
|
|
31
|
+
*
|
|
32
|
+
* console.log(myObject.greet('Alice')); // Logs: 'Greet method called with args: ["Alice"]'
|
|
33
|
+
* // Returns: 'HELLO, ALICE!'
|
|
34
|
+
*/
|
|
35
|
+
export declare const wrapMethodWithCallback: <T extends object, K extends { [P in keyof T]: T[P] extends Method ? P : never; }[keyof T], F extends Method = T[K] extends Method ? T[K] : never>(obj: T, key: K, callback: (original: F, ...args: Parameters<F>) => ReturnType<F>) => void;
|
|
36
|
+
export {};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Wraps an existing method of an object with a callback function. This allows for additional
|
|
3
|
+
* processing or behavior to be executed around the original method. The original method is
|
|
4
|
+
* called within the callback, and its parameters and return value can be accessed and/or modified.
|
|
5
|
+
*
|
|
6
|
+
* @template T - The type of the object whose method is being wrapped.
|
|
7
|
+
* @template K - The key type of the method within the object.
|
|
8
|
+
* @template F - The type of the function, inferred from the method of the object.
|
|
9
|
+
*
|
|
10
|
+
* @param {T} obj - The object containing the method to be wrapped.
|
|
11
|
+
* @param {K} key - The key of the method in the object to be wrapped.
|
|
12
|
+
* @param {(original: F, ...args: Parameters<F>) => ReturnType<F>} callback - The callback
|
|
13
|
+
* function to wrap around the original method. It receive1`s the original method and its
|
|
14
|
+
* parameters as arguments.
|
|
15
|
+
*
|
|
16
|
+
* @returns {void} - The function does not return a value; it modifies the method of the object in place.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* // Example usage
|
|
20
|
+
* const myObject = {
|
|
21
|
+
* greet(name) {
|
|
22
|
+
* return `Hello, ${name}!`;
|
|
23
|
+
* }
|
|
24
|
+
* };
|
|
25
|
+
*
|
|
26
|
+
* wrapMethodWithCallback(myObject, 'greet', (original, ...args) => {
|
|
27
|
+
* console.log('Greet method called with args:', args);
|
|
28
|
+
* return original(...args).toUpperCase();
|
|
29
|
+
* });
|
|
30
|
+
*
|
|
31
|
+
* console.log(myObject.greet('Alice')); // Logs: 'Greet method called with args: ["Alice"]'
|
|
32
|
+
* // Returns: 'HELLO, ALICE!'
|
|
33
|
+
*/
|
|
34
|
+
const wrapMethodWithCallback = (obj, key, callback) => {
|
|
35
|
+
const original = obj[key];
|
|
36
|
+
const boundOriginal = original.bind(obj);
|
|
37
|
+
Object.assign(obj, {
|
|
38
|
+
[key]: (...args) => callback(boundOriginal, ...args),
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
export { wrapMethodWithCallback };
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
const bigIntToHex = (value) => {
|
|
6
|
-
if (typeof value !== 'bigint') {
|
|
7
|
-
throw new TypeError('Input must be of type BigInt');
|
|
8
|
-
}
|
|
9
|
-
if (value < 0) {
|
|
10
|
-
throw new RangeError('Negative BigInt values are not supported');
|
|
11
|
-
}
|
|
12
|
-
return `0x${value.toString(16)}`;
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
exports.bigIntToHex = bigIntToHex;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const bigIntToHex: (value: bigint) => `0x${string}`;
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
const bigIntToHex = (value) => {
|
|
2
|
-
if (typeof value !== 'bigint') {
|
|
3
|
-
throw new TypeError('Input must be of type BigInt');
|
|
4
|
-
}
|
|
5
|
-
if (value < 0) {
|
|
6
|
-
throw new RangeError('Negative BigInt values are not supported');
|
|
7
|
-
}
|
|
8
|
-
return `0x${value.toString(16)}`;
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
export { bigIntToHex };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { bigIntToHex } from './bigIntToHex';
|
package/src/isBigInt/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { isBigInt } from './isBigInt';
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const isBigInt: (value: bigint | unknown) => value is bigint;
|
package/src/isBigInt/isBigInt.js
DELETED