@coinflowlabs/react 4.1.0 → 4.1.2
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/README.md +1 -0
- package/build/cjs/CoinflowApplePayButton.d.ts +3 -5
- package/build/cjs/CoinflowApplePayButton.js +42 -38
- package/build/cjs/CoinflowApplePayButton.js.map +1 -1
- package/build/cjs/CoinflowCardForm.d.ts +2 -2
- package/build/cjs/CoinflowCardForm.js +35 -38
- package/build/cjs/CoinflowCardForm.js.map +1 -1
- package/build/cjs/CoinflowGooglePayButton.d.ts +1 -1
- package/build/cjs/CoinflowIFrame.d.ts +7 -2
- package/build/cjs/CoinflowIFrame.js +65 -6
- package/build/cjs/CoinflowIFrame.js.map +1 -1
- package/build/cjs/CoinflowPurchase.d.ts +2 -3
- package/build/cjs/CoinflowPurchase.js +11 -67
- package/build/cjs/CoinflowPurchase.js.map +1 -1
- package/build/cjs/CoinflowPurchaseHistory.d.ts +2 -2
- package/build/cjs/CoinflowPurchaseHistory.js +10 -42
- package/build/cjs/CoinflowPurchaseHistory.js.map +1 -1
- package/build/cjs/CoinflowPurchaseProtection.d.ts +1 -1
- package/build/cjs/CoinflowPurchaseProtection.js +2 -2
- package/build/cjs/CoinflowPurchaseProtection.js.map +1 -1
- package/build/cjs/CoinflowWithdraw.d.ts +3 -3
- package/build/cjs/CoinflowWithdraw.js +11 -45
- package/build/cjs/CoinflowWithdraw.js.map +1 -1
- package/build/cjs/CoinflowWithdrawHistory.d.ts +2 -2
- package/build/cjs/CoinflowWithdrawHistory.js +10 -43
- package/build/cjs/CoinflowWithdrawHistory.js.map +1 -1
- package/build/cjs/common/CoinflowLibMessageHandlers.d.ts +21 -0
- package/build/cjs/common/CoinflowLibMessageHandlers.js +186 -0
- package/build/cjs/common/CoinflowLibMessageHandlers.js.map +1 -0
- package/build/cjs/{CoinflowTypes.d.ts → common/CoinflowTypes.d.ts} +36 -41
- package/build/cjs/{CoinflowTypes.js → common/CoinflowTypes.js} +3 -2
- package/build/cjs/common/CoinflowTypes.js.map +1 -0
- package/build/cjs/common/CoinflowUtils.d.ts +21 -0
- package/build/cjs/{CoinflowUtils.js → common/CoinflowUtils.js} +65 -29
- package/build/cjs/common/CoinflowUtils.js.map +1 -0
- package/build/cjs/common/SolanaPeerDeps.d.ts +5 -0
- package/build/cjs/common/SolanaPeerDeps.js +22 -0
- package/build/cjs/common/SolanaPeerDeps.js.map +1 -0
- package/build/cjs/common/index.d.ts +3 -0
- package/build/cjs/common/index.js +7 -0
- package/build/cjs/common/index.js.map +1 -0
- package/build/cjs/index.d.ts +1 -3
- package/build/cjs/index.js +1 -3
- package/build/cjs/index.js.map +1 -1
- package/build/esm/CoinflowApplePayButton.d.ts +3 -5
- package/build/esm/CoinflowApplePayButton.js +42 -36
- package/build/esm/CoinflowApplePayButton.js.map +1 -1
- package/build/esm/CoinflowCardForm.d.ts +2 -2
- package/build/esm/CoinflowCardForm.js +37 -40
- package/build/esm/CoinflowCardForm.js.map +1 -1
- package/build/esm/CoinflowGooglePayButton.d.ts +1 -1
- package/build/esm/CoinflowIFrame.d.ts +7 -2
- package/build/esm/CoinflowIFrame.js +66 -5
- package/build/esm/CoinflowIFrame.js.map +1 -1
- package/build/esm/CoinflowPurchase.d.ts +2 -3
- package/build/esm/CoinflowPurchase.js +10 -65
- package/build/esm/CoinflowPurchase.js.map +1 -1
- package/build/esm/CoinflowPurchaseHistory.d.ts +2 -2
- package/build/esm/CoinflowPurchaseHistory.js +10 -42
- package/build/esm/CoinflowPurchaseHistory.js.map +1 -1
- package/build/esm/CoinflowPurchaseProtection.d.ts +1 -1
- package/build/esm/CoinflowPurchaseProtection.js +1 -1
- package/build/esm/CoinflowPurchaseProtection.js.map +1 -1
- package/build/esm/CoinflowWithdraw.d.ts +3 -3
- package/build/esm/CoinflowWithdraw.js +11 -45
- package/build/esm/CoinflowWithdraw.js.map +1 -1
- package/build/esm/CoinflowWithdrawHistory.d.ts +2 -2
- package/build/esm/CoinflowWithdrawHistory.js +10 -43
- package/build/esm/CoinflowWithdrawHistory.js.map +1 -1
- package/build/esm/common/CoinflowLibMessageHandlers.d.ts +21 -0
- package/build/esm/common/CoinflowLibMessageHandlers.js +180 -0
- package/build/esm/common/CoinflowLibMessageHandlers.js.map +1 -0
- package/build/esm/{CoinflowTypes.d.ts → common/CoinflowTypes.d.ts} +36 -41
- package/build/esm/{CoinflowTypes.js → common/CoinflowTypes.js} +2 -3
- package/build/esm/common/CoinflowTypes.js.map +1 -0
- package/build/esm/common/CoinflowUtils.d.ts +21 -0
- package/build/esm/{CoinflowUtils.js → common/CoinflowUtils.js} +65 -29
- package/build/esm/common/CoinflowUtils.js.map +1 -0
- package/build/esm/common/SolanaPeerDeps.d.ts +5 -0
- package/build/esm/common/SolanaPeerDeps.js +17 -0
- package/build/esm/common/SolanaPeerDeps.js.map +1 -0
- package/build/esm/common/index.d.ts +3 -0
- package/build/esm/common/index.js +4 -0
- package/build/esm/common/index.js.map +1 -0
- package/build/esm/index.d.ts +1 -3
- package/build/esm/index.js +1 -3
- package/build/esm/index.js.map +1 -1
- package/build/tsconfig.tsbuildinfo +1 -1
- package/package.json +16 -9
- package/build/cjs/CoinflowTypes.js.map +0 -1
- package/build/cjs/CoinflowUtils.d.ts +0 -22
- package/build/cjs/CoinflowUtils.js.map +0 -1
- package/build/cjs/useHandleHeightChange.d.ts +0 -2
- package/build/cjs/useHandleHeightChange.js +0 -24
- package/build/cjs/useHandleHeightChange.js.map +0 -1
- package/build/cjs/wallet/EthIFrameMessageHandlers.d.ts +0 -5
- package/build/cjs/wallet/EthIFrameMessageHandlers.js +0 -42
- package/build/cjs/wallet/EthIFrameMessageHandlers.js.map +0 -1
- package/build/cjs/wallet/NearIFrameMessageHandlers.d.ts +0 -5
- package/build/cjs/wallet/NearIFrameMessageHandlers.js +0 -31
- package/build/cjs/wallet/NearIFrameMessageHandlers.js.map +0 -1
- package/build/cjs/wallet/SocketService.d.ts +0 -5
- package/build/cjs/wallet/SocketService.js +0 -43
- package/build/cjs/wallet/SocketService.js.map +0 -1
- package/build/cjs/wallet/SolanaIFrameMessageHandlers.d.ts +0 -19
- package/build/cjs/wallet/SolanaIFrameMessageHandlers.js +0 -132
- package/build/cjs/wallet/SolanaIFrameMessageHandlers.js.map +0 -1
- package/build/cjs/wallet/useIframeWallet.d.ts +0 -15
- package/build/cjs/wallet/useIframeWallet.js +0 -137
- package/build/cjs/wallet/useIframeWallet.js.map +0 -1
- package/build/esm/CoinflowTypes.js.map +0 -1
- package/build/esm/CoinflowUtils.d.ts +0 -22
- package/build/esm/CoinflowUtils.js.map +0 -1
- package/build/esm/useHandleHeightChange.d.ts +0 -2
- package/build/esm/useHandleHeightChange.js +0 -19
- package/build/esm/useHandleHeightChange.js.map +0 -1
- package/build/esm/wallet/EthIFrameMessageHandlers.d.ts +0 -5
- package/build/esm/wallet/EthIFrameMessageHandlers.js +0 -38
- package/build/esm/wallet/EthIFrameMessageHandlers.js.map +0 -1
- package/build/esm/wallet/NearIFrameMessageHandlers.d.ts +0 -5
- package/build/esm/wallet/NearIFrameMessageHandlers.js +0 -27
- package/build/esm/wallet/NearIFrameMessageHandlers.js.map +0 -1
- package/build/esm/wallet/SocketService.d.ts +0 -5
- package/build/esm/wallet/SocketService.js +0 -35
- package/build/esm/wallet/SocketService.js.map +0 -1
- package/build/esm/wallet/SolanaIFrameMessageHandlers.d.ts +0 -19
- package/build/esm/wallet/SolanaIFrameMessageHandlers.js +0 -128
- package/build/esm/wallet/SolanaIFrameMessageHandlers.js.map +0 -1
- package/build/esm/wallet/useIframeWallet.d.ts +0 -15
- package/build/esm/wallet/useIframeWallet.js +0 -131
- package/build/esm/wallet/useIframeWallet.js.map +0 -1
|
@@ -2,7 +2,8 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.CoinflowUtils = void 0;
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
|
-
var
|
|
5
|
+
var SolanaPeerDeps_1 = require("./SolanaPeerDeps");
|
|
6
|
+
var lz_string_1 = tslib_1.__importDefault(require("lz-string"));
|
|
6
7
|
var CoinflowUtils = /** @class */ (function () {
|
|
7
8
|
function CoinflowUtils(env) {
|
|
8
9
|
this.env = env !== null && env !== void 0 ? env : 'prod';
|
|
@@ -64,7 +65,7 @@ var CoinflowUtils = /** @class */ (function () {
|
|
|
64
65
|
};
|
|
65
66
|
CoinflowUtils.getCoinflowUrl = function (_a) {
|
|
66
67
|
var _b;
|
|
67
|
-
var walletPubkey = _a.walletPubkey, route = _a.route, routePrefix = _a.routePrefix, env = _a.env, amount = _a.amount, transaction = _a.transaction, blockchain = _a.blockchain, supportsVersionedTransactions = _a.supportsVersionedTransactions, webhookInfo = _a.webhookInfo, email = _a.email, loaderBackground = _a.loaderBackground, handleHeightChange = _a.handleHeightChange,
|
|
68
|
+
var walletPubkey = _a.walletPubkey, route = _a.route, routePrefix = _a.routePrefix, env = _a.env, amount = _a.amount, transaction = _a.transaction, blockchain = _a.blockchain, supportsVersionedTransactions = _a.supportsVersionedTransactions, webhookInfo = _a.webhookInfo, email = _a.email, loaderBackground = _a.loaderBackground, handleHeightChange = _a.handleHeightChange, bankAccountLinkRedirect = _a.bankAccountLinkRedirect, additionalWallets = _a.additionalWallets, nearDeposit = _a.nearDeposit, chargebackProtectionData = _a.chargebackProtectionData, merchantCss = _a.merchantCss, color = _a.color, rent = _a.rent, lockDefaultToken = _a.lockDefaultToken, token = _a.token, tokens = _a.tokens, planCode = _a.planCode, disableApplePay = _a.disableApplePay, disableGooglePay = _a.disableGooglePay, customerInfo = _a.customerInfo, settlementType = _a.settlementType, lockAmount = _a.lockAmount, nativeSolToConvert = _a.nativeSolToConvert, theme = _a.theme, usePermit = _a.usePermit, transactionSigner = _a.transactionSigner, authOnly = _a.authOnly, deviceId = _a.deviceId, jwtToken = _a.jwtToken;
|
|
68
69
|
var prefix = routePrefix
|
|
69
70
|
? "/".concat(routePrefix, "/").concat(blockchain)
|
|
70
71
|
: "/".concat(blockchain);
|
|
@@ -80,13 +81,13 @@ var CoinflowUtils = /** @class */ (function () {
|
|
|
80
81
|
url.searchParams.append('supportsVersionedTransactions', 'true');
|
|
81
82
|
}
|
|
82
83
|
if (webhookInfo) {
|
|
83
|
-
url.searchParams.append('webhookInfo',
|
|
84
|
+
url.searchParams.append('webhookInfo', lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(webhookInfo)));
|
|
84
85
|
}
|
|
85
86
|
if (theme) {
|
|
86
|
-
url.searchParams.append('theme',
|
|
87
|
+
url.searchParams.append('theme', lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(theme)));
|
|
87
88
|
}
|
|
88
89
|
if (customerInfo) {
|
|
89
|
-
url.searchParams.append('customerInfo',
|
|
90
|
+
url.searchParams.append('customerInfo', lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(customerInfo)));
|
|
90
91
|
}
|
|
91
92
|
if (email) {
|
|
92
93
|
url.searchParams.append('email', email);
|
|
@@ -103,23 +104,26 @@ var CoinflowUtils = /** @class */ (function () {
|
|
|
103
104
|
if (handleHeightChange) {
|
|
104
105
|
url.searchParams.append('useHeightChange', 'true');
|
|
105
106
|
}
|
|
106
|
-
if (useSocket) {
|
|
107
|
-
url.searchParams.append('useSocket', 'true');
|
|
108
|
-
}
|
|
109
107
|
if (bankAccountLinkRedirect) {
|
|
110
108
|
url.searchParams.append('bankAccountLinkRedirect', bankAccountLinkRedirect);
|
|
111
109
|
}
|
|
112
110
|
if (additionalWallets)
|
|
113
|
-
url.searchParams.append('additionalWallets', JSON.stringify(additionalWallets));
|
|
111
|
+
url.searchParams.append('additionalWallets', lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(additionalWallets)));
|
|
114
112
|
if (nearDeposit)
|
|
115
113
|
url.searchParams.append('nearDeposit', nearDeposit);
|
|
116
114
|
if (chargebackProtectionData)
|
|
117
|
-
url.searchParams.append('chargebackProtectionData', JSON.stringify(chargebackProtectionData));
|
|
118
|
-
if (
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
115
|
+
url.searchParams.append('chargebackProtectionData', lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(chargebackProtectionData)));
|
|
116
|
+
if (deviceId) {
|
|
117
|
+
url.searchParams.append('deviceId', deviceId);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
if (typeof window !== 'undefined') {
|
|
121
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
122
|
+
// @ts-ignore
|
|
123
|
+
var deviceId_1 = (_b = window === null || window === void 0 ? void 0 : window.nSureSDK) === null || _b === void 0 ? void 0 : _b.getDeviceId();
|
|
124
|
+
if (deviceId_1)
|
|
125
|
+
url.searchParams.append('deviceId', deviceId_1);
|
|
126
|
+
}
|
|
123
127
|
}
|
|
124
128
|
if (merchantCss)
|
|
125
129
|
url.searchParams.append('merchantCss', merchantCss);
|
|
@@ -147,20 +151,54 @@ var CoinflowUtils = /** @class */ (function () {
|
|
|
147
151
|
url.searchParams.append('transactionSigner', transactionSigner);
|
|
148
152
|
if (authOnly === true)
|
|
149
153
|
url.searchParams.append('authOnly', 'true');
|
|
154
|
+
if (jwtToken)
|
|
155
|
+
url.searchParams.append('jwtToken', jwtToken);
|
|
150
156
|
return url.toString();
|
|
151
157
|
};
|
|
152
|
-
CoinflowUtils.
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
158
|
+
CoinflowUtils.getTransaction = function (props) {
|
|
159
|
+
return this.byBlockchain(props.blockchain, {
|
|
160
|
+
solana: function () {
|
|
161
|
+
if (!('transaction' in props))
|
|
162
|
+
return undefined;
|
|
163
|
+
var transaction = props.transaction;
|
|
164
|
+
if (!SolanaPeerDeps_1.web3)
|
|
165
|
+
throw new Error('@solana/web3.js dependency is required for Solana');
|
|
166
|
+
if (!SolanaPeerDeps_1.base58)
|
|
167
|
+
throw new Error('bs58 dependency is required for Solana');
|
|
168
|
+
if (transaction instanceof SolanaPeerDeps_1.web3.Transaction)
|
|
169
|
+
return SolanaPeerDeps_1.base58.encode(transaction.serialize({
|
|
170
|
+
requireAllSignatures: false,
|
|
171
|
+
verifySignatures: false,
|
|
172
|
+
}));
|
|
173
|
+
if (transaction instanceof SolanaPeerDeps_1.web3.VersionedTransaction)
|
|
174
|
+
return SolanaPeerDeps_1.base58.encode(transaction.serialize());
|
|
175
|
+
return undefined;
|
|
176
|
+
},
|
|
177
|
+
polygon: function () {
|
|
178
|
+
if (!('transaction' in props))
|
|
179
|
+
return undefined;
|
|
180
|
+
var transaction = props.transaction;
|
|
181
|
+
return lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(transaction));
|
|
182
|
+
},
|
|
183
|
+
eth: function () {
|
|
184
|
+
if (!('transaction' in props))
|
|
185
|
+
return undefined;
|
|
186
|
+
var transaction = props.transaction;
|
|
187
|
+
return lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(transaction));
|
|
188
|
+
},
|
|
189
|
+
base: function () {
|
|
190
|
+
if (!('transaction' in props))
|
|
191
|
+
return undefined;
|
|
192
|
+
var transaction = props.transaction;
|
|
193
|
+
return lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(transaction));
|
|
194
|
+
},
|
|
195
|
+
near: function () {
|
|
196
|
+
if (!('action' in props))
|
|
197
|
+
return undefined;
|
|
198
|
+
var action = props.action;
|
|
199
|
+
return lz_string_1.default.compressToEncodedURIComponent(JSON.stringify(action));
|
|
200
|
+
},
|
|
201
|
+
})();
|
|
164
202
|
};
|
|
165
203
|
CoinflowUtils.byBlockchain = function (blockchain, args) {
|
|
166
204
|
switch (blockchain) {
|
|
@@ -171,8 +209,6 @@ var CoinflowUtils = /** @class */ (function () {
|
|
|
171
209
|
case 'polygon':
|
|
172
210
|
return args.polygon;
|
|
173
211
|
case 'eth':
|
|
174
|
-
if (args.eth === undefined)
|
|
175
|
-
throw new Error('blockchain not supported for this operation!');
|
|
176
212
|
return args.eth;
|
|
177
213
|
case 'base':
|
|
178
214
|
return args.base;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CoinflowUtils.js","sourceRoot":"","sources":["../../../src/common/CoinflowUtils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// This works in angular, but not react
|
|
3
|
+
// let web3: typeof import('@solana/web3.js') | undefined;
|
|
4
|
+
// let base58: typeof import('bs58') | undefined;
|
|
5
|
+
//
|
|
6
|
+
// try {
|
|
7
|
+
// web3 = require('@solana/web3.js');
|
|
8
|
+
// base58 = require('bs58');
|
|
9
|
+
// } catch (e) {}
|
|
10
|
+
//
|
|
11
|
+
// export {web3, base58};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.base58 = exports.web3 = void 0;
|
|
14
|
+
var tslib_1 = require("tslib");
|
|
15
|
+
// This works in react, but not angular
|
|
16
|
+
var SolanaWeb3Js = tslib_1.__importStar(require("@solana/web3.js"));
|
|
17
|
+
var bs58_1 = tslib_1.__importDefault(require("bs58"));
|
|
18
|
+
var web3 = SolanaWeb3Js;
|
|
19
|
+
exports.web3 = web3;
|
|
20
|
+
var base58 = bs58_1.default;
|
|
21
|
+
exports.base58 = base58;
|
|
22
|
+
//# sourceMappingURL=SolanaPeerDeps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SolanaPeerDeps.js","sourceRoot":"","sources":["../../../src/common/SolanaPeerDeps.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,0DAA0D;AAC1D,iDAAiD;AACjD,EAAE;AACF,QAAQ;AACR,uCAAuC;AACvC,8BAA8B;AAC9B,iBAAiB;AACjB,EAAE;AACF,yBAAyB;;;;AAEzB,uCAAuC;AACvC,oEAAgD;AAChD,sDAAkC;AAElC,IAAM,IAAI,GAAoC,YAAY,CAAC;AAEnD,oBAAI;AADZ,IAAM,MAAM,GAAsC,cAAc,CAAC;AACnD,wBAAM"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var tslib_1 = require("tslib");
|
|
4
|
+
tslib_1.__exportStar(require("./CoinflowTypes"), exports);
|
|
5
|
+
tslib_1.__exportStar(require("./CoinflowUtils"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./CoinflowLibMessageHandlers"), exports);
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/index.ts"],"names":[],"mappings":";;;AAAA,0DAAgC;AAChC,0DAAgC;AAChC,uEAA6C"}
|
package/build/cjs/index.d.ts
CHANGED
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
export * from './CoinflowWithdraw';
|
|
2
2
|
export * from './CoinflowPurchase';
|
|
3
|
-
export * from './
|
|
4
|
-
export * from './wallet/useIframeWallet';
|
|
3
|
+
export * from './common';
|
|
5
4
|
export * from './CoinflowIFrame';
|
|
6
5
|
export * from './CoinflowPurchaseHistory';
|
|
7
6
|
export * from './CoinflowWithdrawHistory';
|
|
8
|
-
export * from './CoinflowTypes';
|
|
9
7
|
export * from './CoinflowPurchaseProtection';
|
|
10
8
|
export * from './CoinflowCardForm';
|
|
11
9
|
export * from './CoinflowApplePayButton';
|
package/build/cjs/index.js
CHANGED
|
@@ -3,12 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
var tslib_1 = require("tslib");
|
|
4
4
|
tslib_1.__exportStar(require("./CoinflowWithdraw"), exports);
|
|
5
5
|
tslib_1.__exportStar(require("./CoinflowPurchase"), exports);
|
|
6
|
-
tslib_1.__exportStar(require("./
|
|
7
|
-
tslib_1.__exportStar(require("./wallet/useIframeWallet"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./common"), exports);
|
|
8
7
|
tslib_1.__exportStar(require("./CoinflowIFrame"), exports);
|
|
9
8
|
tslib_1.__exportStar(require("./CoinflowPurchaseHistory"), exports);
|
|
10
9
|
tslib_1.__exportStar(require("./CoinflowWithdrawHistory"), exports);
|
|
11
|
-
tslib_1.__exportStar(require("./CoinflowTypes"), exports);
|
|
12
10
|
tslib_1.__exportStar(require("./CoinflowPurchaseProtection"), exports);
|
|
13
11
|
tslib_1.__exportStar(require("./CoinflowCardForm"), exports);
|
|
14
12
|
tslib_1.__exportStar(require("./CoinflowApplePayButton"), exports);
|
package/build/cjs/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;AAAA,6DAAmC;AACnC,6DAAmC;AACnC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;AAAA,6DAAmC;AACnC,6DAAmC;AACnC,mDAAyB;AACzB,2DAAiC;AACjC,oEAA0C;AAC1C,oEAA0C;AAC1C,uEAA6C;AAC7C,6DAAmC;AACnC,mEAAyC;AACzC,oEAA0C"}
|
|
@@ -1,12 +1,10 @@
|
|
|
1
|
-
import { CoinflowPurchaseProps } from './
|
|
2
|
-
import React from
|
|
1
|
+
import { CoinflowPurchaseProps } from './common';
|
|
2
|
+
import React from "react";
|
|
3
3
|
export declare function CoinflowApplePayButton(props: CoinflowPurchaseProps & MobileWalletButtonProps): React.JSX.Element;
|
|
4
4
|
export declare function MobileWalletButton({ props, route }: {
|
|
5
5
|
props: CoinflowPurchaseProps;
|
|
6
6
|
route: string;
|
|
7
|
-
}): React.JSX.Element
|
|
7
|
+
}): React.JSX.Element;
|
|
8
8
|
export interface MobileWalletButtonProps {
|
|
9
9
|
color: "white" | "black";
|
|
10
10
|
}
|
|
11
|
-
export declare function useStringWalletPubkey(props: CoinflowPurchaseProps): string | null | undefined;
|
|
12
|
-
export declare function useGetTokenHandler(props: CoinflowPurchaseProps): void;
|
|
@@ -1,48 +1,54 @@
|
|
|
1
1
|
import { __assign } from "tslib";
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
import { getMessageHandler } from './wallet/useIframeWallet';
|
|
6
|
-
import { CoinflowUtils } from './CoinflowUtils';
|
|
2
|
+
import { getWalletPubkey, getHandlers } from './common';
|
|
3
|
+
import { CoinflowIFrame } from "./CoinflowIFrame";
|
|
4
|
+
import React, { useEffect, useMemo, useRef } from "react";
|
|
7
5
|
export function CoinflowApplePayButton(props) {
|
|
8
6
|
return React.createElement(MobileWalletButton, { props: props, route: 'apple-pay' });
|
|
9
7
|
}
|
|
10
8
|
export function MobileWalletButton(_a) {
|
|
11
9
|
var props = _a.props, route = _a.route;
|
|
12
|
-
var
|
|
13
|
-
useHandleHeightChange(props.handleHeightChange);
|
|
14
|
-
useGetTokenHandler(props);
|
|
15
|
-
var walletPubkey = useStringWalletPubkey(props);
|
|
16
|
-
if (!walletPubkey)
|
|
17
|
-
return null;
|
|
18
|
-
var iframeProps = __assign(__assign({}, props), { walletPubkey: walletPubkey, IFrameRef: IFrameRef, transaction: undefined, routePrefix: 'form', route: "/".concat(route, "/").concat(props.merchantId) });
|
|
19
|
-
return React.createElement(CoinflowIFrame, __assign({}, iframeProps));
|
|
20
|
-
}
|
|
21
|
-
export function useStringWalletPubkey(props) {
|
|
22
|
-
return useMemo(function () {
|
|
23
|
-
var getWalletPubkey = CoinflowUtils.byBlockchain(props.blockchain, {
|
|
24
|
-
solana: function () { var _a, _b; return (_b = (_a = props === null || props === void 0 ? void 0 : props.wallet) === null || _a === void 0 ? void 0 : _a.publicKey) === null || _b === void 0 ? void 0 : _b.toString(); },
|
|
25
|
-
near: function () { return props.wallet.accountId; },
|
|
26
|
-
eth: function () { return props.wallet.address; },
|
|
27
|
-
polygon: function () { return props.wallet.address; },
|
|
28
|
-
base: function () { return props.wallet.address; },
|
|
29
|
-
});
|
|
30
|
-
return getWalletPubkey();
|
|
31
|
-
}, [props]);
|
|
32
|
-
}
|
|
33
|
-
export function useGetTokenHandler(props) {
|
|
10
|
+
var iframeRef = useRef(null);
|
|
34
11
|
var onSuccess = props.onSuccess;
|
|
35
12
|
useEffect(function () {
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
13
|
+
if (!onSuccess)
|
|
14
|
+
return;
|
|
15
|
+
if (!(iframeRef === null || iframeRef === void 0 ? void 0 : iframeRef.current))
|
|
16
|
+
return;
|
|
17
|
+
iframeRef.current.listenForMessage(function (data) {
|
|
18
|
+
try {
|
|
19
|
+
var res = JSON.parse(data);
|
|
20
|
+
return 'method' in res && res.method === 'getToken';
|
|
40
21
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
window.addEventListener('message', handler);
|
|
22
|
+
catch (e) {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
}).then(function (data) { return onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess(data); });
|
|
46
26
|
}, [onSuccess]);
|
|
27
|
+
var iframeProps = useMemo(function () {
|
|
28
|
+
var walletPubkey = getWalletPubkey(props);
|
|
29
|
+
return __assign(__assign({}, props), { walletPubkey: walletPubkey, transaction: undefined, routePrefix: 'form', route: "/".concat(route, "/").concat(props.merchantId) });
|
|
30
|
+
}, [props, route]);
|
|
31
|
+
var messageHandlers = useMemo(function () {
|
|
32
|
+
return __assign(__assign({}, getHandlers(props)), { handleHeightChange: props.handleHeightChange });
|
|
33
|
+
}, [props]);
|
|
34
|
+
return React.createElement(CoinflowIFrame, __assign({ ref: iframeRef }, iframeProps, messageHandlers));
|
|
47
35
|
}
|
|
36
|
+
// TODO
|
|
37
|
+
// export function useGetTokenHandler(props: CoinflowPurchaseProps) {
|
|
38
|
+
// const {onSuccess} = props;
|
|
39
|
+
//
|
|
40
|
+
// useEffect(() => {
|
|
41
|
+
// const handler = getMessageHandler('getToken', (data: string) => {
|
|
42
|
+
// if (data.startsWith('ERROR')) {
|
|
43
|
+
// console.error('Mobile Wallet Payment Error', data.replace('ERROR', ''));
|
|
44
|
+
// return;
|
|
45
|
+
// }
|
|
46
|
+
//
|
|
47
|
+
// onSuccess?.(data);
|
|
48
|
+
// });
|
|
49
|
+
//
|
|
50
|
+
// if (!window) throw new Error('Window not defined');
|
|
51
|
+
// window.addEventListener('message', handler);
|
|
52
|
+
// }, [onSuccess]);
|
|
53
|
+
// }
|
|
48
54
|
//# sourceMappingURL=CoinflowApplePayButton.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CoinflowApplePayButton.js","sourceRoot":"","sources":["../../src/CoinflowApplePayButton.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"CoinflowApplePayButton.js","sourceRoot":"","sources":["../../src/CoinflowApplePayButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAGL,eAAe,EACf,WAAW,EAEZ,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,cAAc,EAAkC,MAAM,kBAAkB,CAAC;AAClF,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAE1D,MAAM,UAAU,sBAAsB,CAAC,KAAsD;IAC3F,OAAO,oBAAC,kBAAkB,IAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,GAAI,CAAC;AAClE,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,EAA6D;QAA5D,KAAK,WAAA,EAAE,KAAK,WAAA;IAC9C,IAAM,SAAS,GAAG,MAAM,CAAiC,IAAI,CAAC,CAAC;IACxD,IAAA,SAAS,GAAI,KAAK,UAAT,CAAU;IAE1B,SAAS,CAAC;QACR,IAAI,CAAC,SAAS;YAAE,OAAO;QACvB,IAAI,CAAC,CAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,CAAA;YAAE,OAAO;QAChC,SAAS,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAC,IAAY;YAC9C,IAAI,CAAC;gBACH,IAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;gBAC7B,OAAO,QAAQ,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,KAAK,UAAU,CAAA;YACrD,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC,CAAC,CAAC,IAAI,CAAC,UAAA,IAAI,IAAI,OAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAG,IAAI,CAAC,EAAjB,CAAiB,CAAC,CAAC;IACrC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,IAAM,WAAW,GAAG,OAAO,CAAsB;QAC/C,IAAM,YAAY,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;QAC5C,6BACK,KAAK,KACR,YAAY,cAAA,EACZ,WAAW,EAAE,SAAS,EACtB,WAAW,EAAE,MAAM,EACnB,KAAK,EAAE,WAAI,KAAK,cAAI,KAAK,CAAC,UAAU,CAAE,IACvC;IACH,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;IACnB,IAAM,eAAe,GAAG,OAAO,CAAwB;QACrD,6BACK,WAAW,CAAC,KAAK,CAAC,KACrB,kBAAkB,EAAE,KAAK,CAAC,kBAAkB,IAC5C;IACJ,CAAC,EAAG,CAAC,KAAK,CAAC,CAAC,CAAC;IAEb,OAAO,oBAAC,cAAc,aAAC,GAAG,EAAE,SAAS,IAAM,WAAW,EAAO,eAAe,EAAI,CAAC;AACnF,CAAC;AAMD,OAAO;AACP,qEAAqE;AACrE,+BAA+B;AAC/B,EAAE;AACF,sBAAsB;AACtB,wEAAwE;AACxE,wCAAwC;AACxC,mFAAmF;AACnF,kBAAkB;AAClB,UAAU;AACV,EAAE;AACF,2BAA2B;AAC3B,UAAU;AACV,EAAE;AACF,0DAA0D;AAC1D,mDAAmD;AACnD,qBAAqB;AACrB,IAAI"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import React, { CSSProperties } from
|
|
2
|
-
import { CoinflowBlockchain, CoinflowEnvs } from './
|
|
1
|
+
import React, { CSSProperties } from "react";
|
|
2
|
+
import { CoinflowBlockchain, CoinflowEnvs } from './common';
|
|
3
3
|
export type CoinflowCardTokenResponse = {
|
|
4
4
|
last4: string;
|
|
5
5
|
type: 'VISA' | 'MSTR' | 'AMEX' | 'DISC';
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import { __assign, __awaiter, __generator } from "tslib";
|
|
2
|
-
import React, { forwardRef, useImperativeHandle, useMemo, useRef } from
|
|
3
|
-
import {
|
|
4
|
-
import { CoinflowIFrame } from './CoinflowIFrame';
|
|
5
|
-
import { useHandleHeightChange } from './useHandleHeightChange';
|
|
2
|
+
import React, { forwardRef, useImperativeHandle, useMemo, useRef } from "react";
|
|
3
|
+
import { CoinflowIFrame } from "./CoinflowIFrame";
|
|
6
4
|
/**
|
|
7
5
|
* Allows merchants to collect card information from their customers in a PCI-compliant way and receive a token for use with the `/api/checkout/token` endpoint.
|
|
8
6
|
*
|
|
@@ -23,56 +21,55 @@ import { useHandleHeightChange } from './useHandleHeightChange';
|
|
|
23
21
|
*
|
|
24
22
|
* ```
|
|
25
23
|
*/
|
|
26
|
-
export var CoinflowCardForm = forwardRef(function (
|
|
27
|
-
var
|
|
28
|
-
var IFrameRef = useRef(null);
|
|
29
|
-
useHandleHeightChange(handleHeightChange);
|
|
24
|
+
export var CoinflowCardForm = forwardRef(function (props, ref) {
|
|
25
|
+
var iframeRef = useRef();
|
|
30
26
|
useImperativeHandle(ref, function () { return ({
|
|
31
27
|
getToken: function () {
|
|
32
28
|
return __awaiter(this, void 0, void 0, function () {
|
|
33
|
-
var
|
|
34
|
-
return __generator(this, function (
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
29
|
+
var methodName, isValid, response;
|
|
30
|
+
return __generator(this, function (_a) {
|
|
31
|
+
switch (_a.label) {
|
|
32
|
+
case 0:
|
|
33
|
+
methodName = 'getToken';
|
|
34
|
+
if (!iframeRef.current)
|
|
35
|
+
throw new Error('Unable to get token');
|
|
36
|
+
isValid = function (data) {
|
|
37
|
+
try {
|
|
38
|
+
var res = JSON.parse(data);
|
|
39
|
+
return 'method' in res && res.method === methodName;
|
|
43
40
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
41
|
+
catch (e) {
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
return [4 /*yield*/, iframeRef.current.sendAndReceiveMessage(methodName, isValid)];
|
|
46
|
+
case 1:
|
|
47
|
+
response = _a.sent();
|
|
48
|
+
return [2 /*return*/, JSON.parse(response).data];
|
|
49
|
+
}
|
|
50
50
|
});
|
|
51
51
|
});
|
|
52
52
|
}
|
|
53
53
|
}); });
|
|
54
54
|
var merchantCss = useMemo(function () {
|
|
55
|
-
if (!customCss)
|
|
55
|
+
if (!props.customCss)
|
|
56
56
|
return undefined;
|
|
57
|
-
var cssStr = Object.entries(customCss).reduce(function (acc, _a) {
|
|
57
|
+
var cssStr = Object.entries(props.customCss).reduce(function (acc, _a) {
|
|
58
58
|
var key = _a[0], value = _a[1];
|
|
59
59
|
return acc + "".concat(key, " {").concat(CSSPropertiesToComponent(value), "}\n");
|
|
60
60
|
}, '');
|
|
61
61
|
return Buffer.from(cssStr).toString('base64');
|
|
62
|
-
}, [customCss]);
|
|
63
|
-
|
|
64
|
-
return
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
handleHeightChange: handleHeightChange,
|
|
74
|
-
};
|
|
75
|
-
return React.createElement(CoinflowIFrame, __assign({}, iFrameProps));
|
|
62
|
+
}, [props.customCss]);
|
|
63
|
+
var iframeProps = useMemo(function () {
|
|
64
|
+
return __assign(__assign({}, props), { walletPubkey: props.walletPubkey, route: "/checkout-form/".concat(props.merchantId), routePrefix: 'form', merchantCss: merchantCss, transaction: undefined });
|
|
65
|
+
}, [merchantCss, props]);
|
|
66
|
+
var messageHandlers = useMemo(function () {
|
|
67
|
+
return {
|
|
68
|
+
handleSendTransaction: function () { throw new Error('Not Supported'); },
|
|
69
|
+
handleHeightChange: props.handleHeightChange
|
|
70
|
+
};
|
|
71
|
+
}, [props]);
|
|
72
|
+
return React.createElement(CoinflowIFrame, __assign({ ref: iframeRef }, iframeProps, messageHandlers));
|
|
76
73
|
});
|
|
77
74
|
function CSSPropertiesToComponent(dict) {
|
|
78
75
|
var str = '';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CoinflowCardForm.js","sourceRoot":"","sources":["../../src/CoinflowCardForm.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"CoinflowCardForm.js","sourceRoot":"","sources":["../../src/CoinflowCardForm.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAiB,UAAU,EAAE,mBAAmB,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/F,OAAO,EAAE,cAAc,EAAkC,MAAM,kBAAkB,CAAC;AAmBlF;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,CAAC,IAAM,gBAAgB,GAAG,UAAU,CAAC,UAAC,KAA4B,EAAE,GAAG;IAC3E,IAAM,SAAS,GAAG,MAAM,EAAkC,CAAC;IAC3D,mBAAmB,CAAC,GAAG,EAAE,cAAM,OAAA,CAAC;QACxB,QAAQ;;;;;;4BACN,UAAU,GAAG,UAAU,CAAC;4BAC9B,IAAI,CAAC,SAAS,CAAC,OAAO;gCAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;4BACzD,OAAO,GAAG,UAAC,IAAY;gCAC3B,IAAI,CAAC;oCACH,IAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;oCAC7B,OAAO,QAAQ,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,KAAK,UAAU,CAAA;gCACrD,CAAC;gCAAC,OAAO,CAAC,EAAE,CAAC;oCACX,OAAO,KAAK,CAAC;gCACf,CAAC;4BACH,CAAC,CAAC;4BACe,qBAAM,SAAS,CAAC,OAAO,CAAC,qBAAqB,CAAC,UAAU,EAAE,OAAO,CAAC,EAAA;;4BAA7E,QAAQ,GAAG,SAAkE;4BACnF,sBAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,EAAC;;;;SAClC;KACF,CAAC,EAf6B,CAe7B,CAAC,CAAC;IAEJ,IAAM,WAAW,GAAG,OAAO,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,SAAS;YAAE,OAAO,SAAS,CAAC;QAEvC,IAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,UAAC,GAAG,EAAE,EAAY;gBAAX,GAAG,QAAA,EAAE,KAAK,QAAA;YACrE,OAAO,GAAG,GAAG,UAAG,GAAG,eAAK,wBAAwB,CAAC,KAAK,CAAC,QAAK,CAAC;QAC/D,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAChD,CAAC,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;IAEtB,IAAM,WAAW,GAAG,OAAO,CAAsB;QAC/C,6BACK,KAAK,KACR,YAAY,EAAE,KAAK,CAAC,YAAY,EAChC,KAAK,EAAE,yBAAkB,KAAK,CAAC,UAAU,CAAE,EAC3C,WAAW,EAAE,MAAM,EACnB,WAAW,aAAA,EACX,WAAW,EAAE,SAAS,IACtB;IACJ,CAAC,EAAE,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC;IAEzB,IAAM,eAAe,GAAG,OAAO,CAAwB;QACrD,OAAO;YACL,qBAAqB,EAAE,cAAO,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAA,CAAA,CAAC;YAC/D,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;SAC7C,CAAC;IACJ,CAAC,EAAG,CAAC,KAAK,CAAC,CAAC,CAAC;IAEb,OAAO,oBAAC,cAAc,aAAC,GAAG,EAAE,SAAS,IAAM,WAAW,EAAO,eAAe,EAAI,CAAC;AACnF,CAAC,CAAC,CAAC;AAEH,SAAS,wBAAwB,CAAC,IAAmB;IACnD,IAAI,GAAG,GAAG,EAAE,CAAC;4BACF,GAAG,EAAE,KAAK;QACnB,IAAI,GAAG,GAAG,EAAE,CAAC;QACb,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,UAAA,EAAE;YACtB,IAAI,EAAE,CAAC,WAAW,EAAE,KAAK,EAAE,EAAE,CAAC;gBAC5B,GAAG,IAAI,GAAG,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;YAChC,CAAC;iBAAK,CAAC;gBACL,GAAG,IAAI,EAAE,CAAC;YACZ,CAAC;QACH,CAAC,CAAC,CAAC;QACH,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,KAAK,GAAG,GAAG,CAAC;;IATjC,KAA0B,UAAoB,EAApB,KAAA,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAApB,cAAoB,EAApB,IAAoB;QAApC,IAAA,WAAY,EAAX,GAAG,QAAA,EAAE,KAAK,QAAA;gBAAV,GAAG,EAAE,KAAK;KAUpB;IACD,OAAO,GAAG,CAAC;AACb,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CoinflowPurchaseProps } from './
|
|
1
|
+
import { CoinflowPurchaseProps } from './common';
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { MobileWalletButtonProps } from './CoinflowApplePayButton';
|
|
4
4
|
export declare function CoinflowGooglePayButton(props: CoinflowPurchaseProps & MobileWalletButtonProps): React.JSX.Element;
|
|
@@ -1,3 +1,8 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { CoinflowIFrameProps } from './
|
|
3
|
-
export
|
|
2
|
+
import { CoinflowIFrameProps, IFrameMessageHandlers } from './common';
|
|
3
|
+
export type SendAndReceiveMessage = (message: string, isResponseValid: (response: string) => boolean) => Promise<string>;
|
|
4
|
+
export type CoinflowIFrameExposedFunctions = {
|
|
5
|
+
sendAndReceiveMessage: SendAndReceiveMessage;
|
|
6
|
+
listenForMessage: (isResponseValid: (response: string) => boolean) => Promise<string>;
|
|
7
|
+
};
|
|
8
|
+
export declare const CoinflowIFrame: React.ForwardRefExoticComponent<CoinflowIFrameProps & IFrameMessageHandlers & React.RefAttributes<unknown>>;
|
|
@@ -1,10 +1,71 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
|
|
1
|
+
import { __awaiter, __generator } from "tslib";
|
|
2
|
+
import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, } from 'react';
|
|
3
|
+
import { CoinflowUtils, handleIFrameMessage, } from './common';
|
|
4
|
+
export var CoinflowIFrame = forwardRef(function (props, ref) {
|
|
5
|
+
var IFrameRef = useRef(null);
|
|
4
6
|
var url = useMemo(function () {
|
|
5
7
|
return CoinflowUtils.getCoinflowUrl(props);
|
|
6
8
|
}, [props]);
|
|
7
|
-
var
|
|
9
|
+
var sendMessage = useCallback(function (message) {
|
|
10
|
+
var _a;
|
|
11
|
+
if (!((_a = IFrameRef === null || IFrameRef === void 0 ? void 0 : IFrameRef.current) === null || _a === void 0 ? void 0 : _a.contentWindow))
|
|
12
|
+
throw new Error('Iframe not defined');
|
|
13
|
+
IFrameRef.current.contentWindow.postMessage(message, '*');
|
|
14
|
+
}, []);
|
|
15
|
+
useImperativeHandle(ref, function () { return ({
|
|
16
|
+
listenForMessage: function (isResponseValid) {
|
|
17
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
18
|
+
var handler;
|
|
19
|
+
return __generator(this, function (_a) {
|
|
20
|
+
return [2 /*return*/, new Promise(function (resolve, reject) {
|
|
21
|
+
handler = function (_a) {
|
|
22
|
+
var data = _a.data, origin = _a.origin;
|
|
23
|
+
if (!origin.includes(CoinflowUtils.getCoinflowBaseUrl(props.env)))
|
|
24
|
+
return;
|
|
25
|
+
if (data.startsWith('ERROR')) {
|
|
26
|
+
reject(new Error(data.replace('ERROR', '')));
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
if (!isResponseValid(data))
|
|
30
|
+
return;
|
|
31
|
+
resolve(data);
|
|
32
|
+
};
|
|
33
|
+
if (!window)
|
|
34
|
+
throw new Error('Window not defined');
|
|
35
|
+
window.addEventListener('message', handler);
|
|
36
|
+
}).finally(function () {
|
|
37
|
+
window.removeEventListener('message', handler);
|
|
38
|
+
})];
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
},
|
|
42
|
+
sendAndReceiveMessage: function (message, isResponseValid) {
|
|
43
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
44
|
+
return __generator(this, function (_a) {
|
|
45
|
+
sendMessage(message);
|
|
46
|
+
return [2 /*return*/, this.listenForMessage(isResponseValid)];
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
},
|
|
50
|
+
}); });
|
|
51
|
+
var handleIframeMessages = useCallback(function (_a) {
|
|
52
|
+
var data = _a.data, origin = _a.origin;
|
|
53
|
+
if (!origin.includes(CoinflowUtils.getCoinflowBaseUrl(props.env)))
|
|
54
|
+
return;
|
|
55
|
+
var promise = handleIFrameMessage(data, props);
|
|
56
|
+
if (!promise)
|
|
57
|
+
return;
|
|
58
|
+
promise.then(sendMessage).catch(function (e) { return sendMessage('ERROR ' + e.message); });
|
|
59
|
+
}, [props, sendMessage]);
|
|
60
|
+
useEffect(function () {
|
|
61
|
+
if (!window)
|
|
62
|
+
throw new Error('Window not defined');
|
|
63
|
+
window.addEventListener('message', handleIframeMessages);
|
|
64
|
+
return function () {
|
|
65
|
+
window.removeEventListener('message', handleIframeMessages);
|
|
66
|
+
};
|
|
67
|
+
}, [handleIframeMessages]);
|
|
68
|
+
var handleHeightChange = props.handleHeightChange;
|
|
8
69
|
return useMemo(function () { return (React.createElement("iframe", { scrolling: handleHeightChange ? 'no' : 'yes', onLoad: function () {
|
|
9
70
|
if (IFrameRef.current)
|
|
10
71
|
IFrameRef.current.style.opacity = '1';
|
|
@@ -14,5 +75,5 @@ export function CoinflowIFrame(props) {
|
|
|
14
75
|
opacity: 0,
|
|
15
76
|
transition: 'opacity 300ms linear',
|
|
16
77
|
}, title: "withdraw", frameBorder: "0", src: url })); }, [IFrameRef, handleHeightChange, url]);
|
|
17
|
-
}
|
|
78
|
+
});
|
|
18
79
|
//# sourceMappingURL=CoinflowIFrame.js.map
|