@evervault/evervault-react-native 0.2.3 → 0.4.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 +46 -17
- package/android/build.gradle +5 -3
- package/android/gradle.properties +1 -1
- package/android/src/main/java/com/evervaultsdk/EvervaultSdkModule.kt +34 -5
- package/android/src/main/java/com/evervaultsdk/EvervaultSdkPackage.kt +1 -1
- package/dist/commonjs/components/Card/Card.js +115 -0
- package/dist/commonjs/components/Card/Card.js.map +1 -0
- package/dist/commonjs/components/Card/CardCVC.js +59 -0
- package/dist/commonjs/components/Card/CardCVC.js.map +1 -0
- package/dist/commonjs/components/Card/CardExpiry.js +50 -0
- package/dist/commonjs/components/Card/CardExpiry.js.map +1 -0
- package/dist/commonjs/components/Card/CardHolder.js +45 -0
- package/dist/commonjs/components/Card/CardHolder.js.map +1 -0
- package/dist/commonjs/components/Card/CardNumber.js +68 -0
- package/dist/commonjs/components/Card/CardNumber.js.map +1 -0
- package/dist/commonjs/components/Card/context.js +23 -0
- package/dist/commonjs/components/Card/context.js.map +1 -0
- package/dist/commonjs/components/Card/index.js +13 -0
- package/dist/commonjs/components/Card/index.js.map +1 -0
- package/dist/commonjs/components/Card/types.js +2 -0
- package/dist/commonjs/components/Card/types.js.map +1 -0
- package/dist/commonjs/components/Card/utilities.js +85 -0
- package/dist/commonjs/components/Card/utilities.js.map +1 -0
- package/dist/commonjs/components/useForm.js +116 -0
- package/dist/commonjs/components/useForm.js.map +1 -0
- package/dist/commonjs/index.js +26 -0
- package/dist/commonjs/index.js.map +1 -0
- package/{lib/commonjs/index.js → dist/commonjs/native.js} +3 -10
- package/dist/commonjs/native.js.map +1 -0
- package/dist/commonjs/sdk.js +28 -0
- package/dist/commonjs/sdk.js.map +1 -0
- package/dist/module/components/Card/Card.js +110 -0
- package/dist/module/components/Card/Card.js.map +1 -0
- package/dist/module/components/Card/CardCVC.js +50 -0
- package/dist/module/components/Card/CardCVC.js.map +1 -0
- package/dist/module/components/Card/CardExpiry.js +44 -0
- package/dist/module/components/Card/CardExpiry.js.map +1 -0
- package/dist/module/components/Card/CardHolder.js +39 -0
- package/dist/module/components/Card/CardHolder.js.map +1 -0
- package/dist/module/components/Card/CardNumber.js +62 -0
- package/dist/module/components/Card/CardNumber.js.map +1 -0
- package/dist/module/components/Card/context.js +16 -0
- package/dist/module/components/Card/context.js.map +1 -0
- package/dist/module/components/Card/index.js +2 -0
- package/dist/module/components/Card/index.js.map +1 -0
- package/dist/module/components/Card/types.js +2 -0
- package/dist/module/components/Card/types.js.map +1 -0
- package/dist/module/components/Card/utilities.js +77 -0
- package/dist/module/components/Card/utilities.js.map +1 -0
- package/dist/module/components/useForm.js +110 -0
- package/dist/module/components/useForm.js.map +1 -0
- package/dist/module/index.js +3 -0
- package/dist/module/index.js.map +1 -0
- package/{lib/module/index.js → dist/module/native.js} +2 -8
- package/dist/module/native.js.map +1 -0
- package/dist/module/sdk.js +21 -0
- package/dist/module/sdk.js.map +1 -0
- package/dist/typescript/src/components/Card/Card.d.ts +29 -0
- package/dist/typescript/src/components/Card/Card.d.ts.map +1 -0
- package/dist/typescript/src/components/Card/CardCVC.d.ts +6 -0
- package/dist/typescript/src/components/Card/CardCVC.d.ts.map +1 -0
- package/dist/typescript/src/components/Card/CardExpiry.d.ts +6 -0
- package/dist/typescript/src/components/Card/CardExpiry.d.ts.map +1 -0
- package/dist/typescript/src/components/Card/CardHolder.d.ts +7 -0
- package/dist/typescript/src/components/Card/CardHolder.d.ts.map +1 -0
- package/dist/typescript/src/components/Card/CardNumber.d.ts +8 -0
- package/dist/typescript/src/components/Card/CardNumber.d.ts.map +1 -0
- package/dist/typescript/src/components/Card/context.d.ts +12 -0
- package/dist/typescript/src/components/Card/context.d.ts.map +1 -0
- package/dist/typescript/src/components/Card/index.d.ts +2 -0
- package/dist/typescript/src/components/Card/index.d.ts.map +1 -0
- package/dist/typescript/src/components/Card/types.d.ts +35 -0
- package/dist/typescript/src/components/Card/types.d.ts.map +1 -0
- package/dist/typescript/src/components/Card/utilities.d.ts +7 -0
- package/dist/typescript/src/components/Card/utilities.d.ts.map +1 -0
- package/dist/typescript/src/components/useForm.d.ts +22 -0
- package/dist/typescript/src/components/useForm.d.ts.map +1 -0
- package/dist/typescript/src/index.d.ts +4 -0
- package/dist/typescript/src/index.d.ts.map +1 -0
- package/dist/typescript/src/native.d.ts +2 -0
- package/dist/typescript/src/native.d.ts.map +1 -0
- package/{lib/typescript/src/index.d.ts → dist/typescript/src/sdk.d.ts} +1 -1
- package/dist/typescript/src/sdk.d.ts.map +1 -0
- package/package.json +33 -33
- package/src/components/Card/Card.tsx +155 -0
- package/src/components/Card/CardCVC.tsx +53 -0
- package/src/components/Card/CardExpiry.tsx +48 -0
- package/src/components/Card/CardHolder.tsx +46 -0
- package/src/components/Card/CardNumber.tsx +69 -0
- package/src/components/Card/context.tsx +25 -0
- package/src/components/Card/index.ts +1 -0
- package/src/components/Card/types.ts +52 -0
- package/src/components/Card/utilities.ts +103 -0
- package/src/components/useForm.tsx +172 -0
- package/src/index.tsx +10 -26
- package/src/native.ts +18 -0
- package/src/sdk.ts +25 -0
- package/lib/commonjs/index.js.map +0 -1
- package/lib/module/index.js.map +0 -1
- package/lib/typescript/src/index.d.ts.map +0 -1
package/README.md
CHANGED
|
@@ -1,36 +1,65 @@
|
|
|
1
1
|
# react-native-evervault-sdk
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
## [Documentation](https://docs.evervault.com/sdks/react-native)
|
|
4
|
+
Please see our documentation site for a full guide and reference.
|
|
4
5
|
|
|
5
6
|
## Installation
|
|
6
7
|
|
|
7
8
|
```sh
|
|
8
9
|
npm install @evervault/evervault-react-native
|
|
9
10
|
```
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
pod install
|
|
11
|
+
or
|
|
12
|
+
```sh
|
|
13
|
+
yarn add @evervault/evervault-react-native
|
|
14
14
|
```
|
|
15
15
|
|
|
16
16
|
## Usage
|
|
17
|
-
```
|
|
18
|
-
import { init,
|
|
17
|
+
```tsx
|
|
18
|
+
import { init, Card, type CardPayload } from "@evervault/evervault-react-native"
|
|
19
19
|
|
|
20
|
-
export default function
|
|
21
|
-
const [
|
|
22
|
-
const testEncObject = { key: 'value', boolKey: true, number: 123};
|
|
20
|
+
export default function App() {
|
|
21
|
+
const [cardData, setCardData] = useState<CardPayload | undefined>(undefined);
|
|
23
22
|
|
|
24
|
-
|
|
25
|
-
async function
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
async function setupEvervault() {
|
|
26
25
|
try {
|
|
27
|
-
await init(
|
|
28
|
-
} catch (
|
|
29
|
-
|
|
26
|
+
await init(process.env.EXPO_PUBLIC_EV_TEAM_UUID, process.env.EXPO_PUBLIC_EV_APP_UUID);
|
|
27
|
+
} catch (err) {
|
|
28
|
+
throw new Error("Failed to initialize Evervault", err);
|
|
30
29
|
}
|
|
31
30
|
}
|
|
32
|
-
|
|
33
|
-
encrypt(testEncObject).then(setEncObject);
|
|
31
|
+
setupEvervault();
|
|
34
32
|
}, []);
|
|
33
|
+
|
|
34
|
+
return (
|
|
35
|
+
<ScrollView contentContainerStyle={styles.container}>
|
|
36
|
+
<Text style={styles.title}>evervault react native</Text>
|
|
37
|
+
<Card
|
|
38
|
+
onChange={setCardData}
|
|
39
|
+
onComplete={(payload) => console.log("Card Complete!", payload)}
|
|
40
|
+
style={styles.card}
|
|
41
|
+
>
|
|
42
|
+
<Text>Card Number</Text>
|
|
43
|
+
<Card.Number
|
|
44
|
+
placeholder="4242 4242 4242 4242"
|
|
45
|
+
style={styles.input}
|
|
46
|
+
/>
|
|
47
|
+
<Card.Expiry
|
|
48
|
+
placeholder="MM / YY"
|
|
49
|
+
style={styles.input}
|
|
50
|
+
/>
|
|
51
|
+
<Card.Holder
|
|
52
|
+
placeholder="John Doe"
|
|
53
|
+
style={styles.input}
|
|
54
|
+
/>
|
|
55
|
+
<Card.CVC
|
|
56
|
+
placeholder="523"
|
|
57
|
+
style={styles.input}
|
|
58
|
+
/>
|
|
59
|
+
</Card>
|
|
60
|
+
<Text style={styles.details}>{JSON.stringify(cardData, null, 2)}</Text>
|
|
61
|
+
<StatusBar style="auto" />
|
|
62
|
+
</ScrollView>
|
|
63
|
+
);
|
|
35
64
|
}
|
|
36
65
|
```
|
package/android/build.gradle
CHANGED
|
@@ -8,7 +8,7 @@ buildscript {
|
|
|
8
8
|
}
|
|
9
9
|
|
|
10
10
|
dependencies {
|
|
11
|
-
classpath "com.android.tools.build:gradle:
|
|
11
|
+
classpath "com.android.tools.build:gradle:8.4.0"
|
|
12
12
|
// noinspection DifferentKotlinGradleVersion
|
|
13
13
|
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
|
14
14
|
}
|
|
@@ -43,6 +43,7 @@ def supportsNamespace() {
|
|
|
43
43
|
}
|
|
44
44
|
|
|
45
45
|
android {
|
|
46
|
+
ndkVersion "27.0.11718014"
|
|
46
47
|
if (supportsNamespace()) {
|
|
47
48
|
namespace "com.evervaultsdk"
|
|
48
49
|
|
|
@@ -88,7 +89,8 @@ dependencies {
|
|
|
88
89
|
// For < 0.71, this will be from the local maven repo
|
|
89
90
|
// For > 0.71, this will be replaced by `com.facebook.react:react-android:$version` by react gradle plugin
|
|
90
91
|
//noinspection GradleDynamicVersion
|
|
91
|
-
implementation
|
|
92
|
-
implementation
|
|
92
|
+
implementation("com.evervault.sdk:evervault-core:1.1")
|
|
93
|
+
implementation("com.facebook.react:react-android:0.74.1")
|
|
94
|
+
implementation("org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version")
|
|
93
95
|
}
|
|
94
96
|
|
|
@@ -1,22 +1,51 @@
|
|
|
1
1
|
package com.evervaultsdk
|
|
2
2
|
|
|
3
|
+
import com.evervault.sdk.Evervault
|
|
4
|
+
import com.facebook.react.bridge.Arguments
|
|
5
|
+
import com.facebook.react.bridge.Promise
|
|
3
6
|
import com.facebook.react.bridge.ReactApplicationContext
|
|
4
7
|
import com.facebook.react.bridge.ReactContextBaseJavaModule
|
|
5
8
|
import com.facebook.react.bridge.ReactMethod
|
|
6
|
-
import com.facebook.react.bridge.
|
|
9
|
+
import com.facebook.react.bridge.ReadableMap
|
|
10
|
+
import com.facebook.react.bridge.WritableMap
|
|
11
|
+
import kotlinx.coroutines.CoroutineScope
|
|
12
|
+
import kotlinx.coroutines.Dispatchers
|
|
13
|
+
import kotlinx.coroutines.SupervisorJob
|
|
14
|
+
import kotlinx.coroutines.launch
|
|
15
|
+
import kotlinx.coroutines.withContext
|
|
16
|
+
|
|
7
17
|
|
|
8
18
|
class EvervaultSdkModule(reactContext: ReactApplicationContext) :
|
|
9
19
|
ReactContextBaseJavaModule(reactContext) {
|
|
20
|
+
private val evervaultScope = CoroutineScope(SupervisorJob() + Dispatchers.Main.immediate)
|
|
10
21
|
|
|
11
22
|
override fun getName(): String {
|
|
12
23
|
return NAME
|
|
13
24
|
}
|
|
14
25
|
|
|
15
|
-
// Example method
|
|
16
|
-
// See https://reactnative.dev/docs/native-modules-android
|
|
17
26
|
@ReactMethod
|
|
18
|
-
fun
|
|
19
|
-
|
|
27
|
+
fun initialize(teamUuid: String, appUuid: String, promise: Promise) {
|
|
28
|
+
try {
|
|
29
|
+
Evervault.shared.configure(teamUuid, appUuid)
|
|
30
|
+
promise.resolve(null)
|
|
31
|
+
} catch (e: Exception) {
|
|
32
|
+
promise.reject("InitializationError", "Failed to initialize Evervault SDK", e)
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
@ReactMethod
|
|
37
|
+
fun encrypt(value: String, promise: Promise) {
|
|
38
|
+
evervaultScope.launch {
|
|
39
|
+
try {
|
|
40
|
+
val encrypted = withContext(context = Dispatchers.IO) {
|
|
41
|
+
Evervault.shared.encrypt(value)
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
promise.resolve(encrypted)
|
|
45
|
+
} catch (e: Exception) {
|
|
46
|
+
promise.reject("EncryptionError", "Failed to encrypt with the Evervault SDK $e")
|
|
47
|
+
}
|
|
48
|
+
}
|
|
20
49
|
}
|
|
21
50
|
|
|
22
51
|
companion object {
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
package com.evervaultsdk
|
|
2
2
|
|
|
3
3
|
import com.facebook.react.ReactPackage
|
|
4
|
+
import com.facebook.react.bridge.JavaScriptModule
|
|
4
5
|
import com.facebook.react.bridge.NativeModule
|
|
5
6
|
import com.facebook.react.bridge.ReactApplicationContext
|
|
6
7
|
import com.facebook.react.uimanager.ViewManager
|
|
7
8
|
|
|
8
|
-
|
|
9
9
|
class EvervaultSdkPackage : ReactPackage {
|
|
10
10
|
override fun createNativeModules(reactContext: ReactApplicationContext): List<NativeModule> {
|
|
11
11
|
return listOf(EvervaultSdkModule(reactContext))
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Card = void 0;
|
|
7
|
+
var _cardValidator = require("@evervault/card-validator");
|
|
8
|
+
var _react = require("react");
|
|
9
|
+
var _useForm = require("../useForm");
|
|
10
|
+
var _utilities = require("./utilities");
|
|
11
|
+
var _CardNumber = require("./CardNumber");
|
|
12
|
+
var _context = require("./context");
|
|
13
|
+
var _sdk = require("../../sdk");
|
|
14
|
+
var _CardCVC = require("./CardCVC");
|
|
15
|
+
var _CardHolder = require("./CardHolder");
|
|
16
|
+
var _CardExpiry = require("./CardExpiry");
|
|
17
|
+
var _reactNative = require("react-native");
|
|
18
|
+
function Card({
|
|
19
|
+
initialValue,
|
|
20
|
+
config,
|
|
21
|
+
children,
|
|
22
|
+
onChange,
|
|
23
|
+
onComplete,
|
|
24
|
+
style
|
|
25
|
+
}) {
|
|
26
|
+
const [registeredFields, setRegisteredFields] = (0, _react.useState)(new Set());
|
|
27
|
+
const form = (0, _useForm.useForm)({
|
|
28
|
+
initialValues: initialValue ?? {
|
|
29
|
+
cvc: '',
|
|
30
|
+
expiry: '',
|
|
31
|
+
number: '',
|
|
32
|
+
name: ''
|
|
33
|
+
},
|
|
34
|
+
validate: {
|
|
35
|
+
name: values => {
|
|
36
|
+
if (!registeredFields.has('name')) {
|
|
37
|
+
return undefined;
|
|
38
|
+
}
|
|
39
|
+
if (values.name.length === 0) {
|
|
40
|
+
return 'invalid';
|
|
41
|
+
}
|
|
42
|
+
return undefined;
|
|
43
|
+
},
|
|
44
|
+
number: values => {
|
|
45
|
+
if (!registeredFields.has('number')) {
|
|
46
|
+
return undefined;
|
|
47
|
+
}
|
|
48
|
+
const cardValidation = (0, _cardValidator.validateNumber)(values.number);
|
|
49
|
+
if (!cardValidation.isValid) {
|
|
50
|
+
return 'invalid';
|
|
51
|
+
}
|
|
52
|
+
if (!(0, _utilities.isAcceptedBrand)(config?.acceptedBrands, cardValidation)) {
|
|
53
|
+
return 'unsupportedBrand';
|
|
54
|
+
}
|
|
55
|
+
return undefined;
|
|
56
|
+
},
|
|
57
|
+
expiry: values => {
|
|
58
|
+
if (!registeredFields.has('expiry')) {
|
|
59
|
+
return undefined;
|
|
60
|
+
}
|
|
61
|
+
const expiryValidation = (0, _cardValidator.validateExpiry)(values.expiry);
|
|
62
|
+
if (!expiryValidation.isValid) {
|
|
63
|
+
return 'invalid';
|
|
64
|
+
}
|
|
65
|
+
return undefined;
|
|
66
|
+
},
|
|
67
|
+
cvc: values => {
|
|
68
|
+
if (!registeredFields.has('cvc')) {
|
|
69
|
+
return undefined;
|
|
70
|
+
}
|
|
71
|
+
const cvcValidation = (0, _cardValidator.validateCVC)(values.cvc, values.number);
|
|
72
|
+
if (!cvcValidation.isValid) {
|
|
73
|
+
return 'invalid';
|
|
74
|
+
}
|
|
75
|
+
return undefined;
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
onChange: formState => {
|
|
79
|
+
const triggerChange = async () => {
|
|
80
|
+
const cardData = await (0, _utilities.changePayload)(_sdk.encrypt, formState, Array.from(registeredFields));
|
|
81
|
+
if (onChange) {
|
|
82
|
+
onChange(cardData);
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
triggerChange();
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
(0, _react.useEffect)(() => {
|
|
89
|
+
const getCardData = async () => {
|
|
90
|
+
const cardData = await (0, _utilities.changePayload)(_sdk.encrypt, form, Array.from(registeredFields));
|
|
91
|
+
if (onComplete) {
|
|
92
|
+
onComplete(cardData);
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
if ((0, _utilities.isComplete)(form, Array.from(registeredFields))) {
|
|
96
|
+
getCardData();
|
|
97
|
+
}
|
|
98
|
+
}, [form, onComplete, registeredFields]);
|
|
99
|
+
return /*#__PURE__*/React.createElement(_context.CardContext.Provider, {
|
|
100
|
+
value: {
|
|
101
|
+
values: form.values,
|
|
102
|
+
register: form.register,
|
|
103
|
+
setRegisteredFields
|
|
104
|
+
}
|
|
105
|
+
}, /*#__PURE__*/React.createElement(_reactNative.View, {
|
|
106
|
+
style: style
|
|
107
|
+
}, children));
|
|
108
|
+
}
|
|
109
|
+
const CardNamespace = exports.Card = Object.assign(Card, {
|
|
110
|
+
Number: _CardNumber.CardNumber,
|
|
111
|
+
CVC: _CardCVC.CardCVC,
|
|
112
|
+
Holder: _CardHolder.CardHolder,
|
|
113
|
+
Expiry: _CardExpiry.CardExpiry
|
|
114
|
+
});
|
|
115
|
+
//# sourceMappingURL=Card.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_cardValidator","require","_react","_useForm","_utilities","_CardNumber","_context","_sdk","_CardCVC","_CardHolder","_CardExpiry","_reactNative","Card","initialValue","config","children","onChange","onComplete","style","registeredFields","setRegisteredFields","useState","Set","form","useForm","initialValues","cvc","expiry","number","name","validate","values","has","undefined","length","cardValidation","validateNumber","isValid","isAcceptedBrand","acceptedBrands","expiryValidation","validateExpiry","cvcValidation","validateCVC","formState","triggerChange","cardData","changePayload","encrypt","Array","from","useEffect","getCardData","isComplete","React","createElement","CardContext","Provider","value","register","View","CardNamespace","exports","Object","assign","Number","CardNumber","CVC","CardCVC","Holder","CardHolder","Expiry","CardExpiry"],"sourceRoot":"../../../../src","sources":["components/Card/Card.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.CardCVC = void 0;
|
|
7
|
+
var _cardValidator = require("@evervault/card-validator");
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _reactNativeMaskedText = require("react-native-masked-text");
|
|
10
|
+
var _context = require("./context");
|
|
11
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
12
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
13
|
+
const CardCVC = ({
|
|
14
|
+
style,
|
|
15
|
+
disabled,
|
|
16
|
+
placeholder,
|
|
17
|
+
readOnly
|
|
18
|
+
}) => {
|
|
19
|
+
const context = (0, _context.useCardContext)();
|
|
20
|
+
const mask = (0, _react.useMemo)(() => {
|
|
21
|
+
const type = (0, _cardValidator.validateNumber)(context.values.number).brand;
|
|
22
|
+
if (type === 'american-express') {
|
|
23
|
+
return '9999';
|
|
24
|
+
}
|
|
25
|
+
return '999';
|
|
26
|
+
}, [context.values.number]);
|
|
27
|
+
const {
|
|
28
|
+
onChange,
|
|
29
|
+
onBlur
|
|
30
|
+
} = context.register('cvc');
|
|
31
|
+
(0, _react.useEffect)(() => {
|
|
32
|
+
context.setRegisteredFields(prev => new Set(prev).add('cvc'));
|
|
33
|
+
return () => context.setRegisteredFields(prev => {
|
|
34
|
+
const next = new Set(prev);
|
|
35
|
+
next.delete('cvc');
|
|
36
|
+
return next;
|
|
37
|
+
});
|
|
38
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
39
|
+
}, []);
|
|
40
|
+
return /*#__PURE__*/_react.default.createElement(_reactNativeMaskedText.TextInputMask, {
|
|
41
|
+
type: "custom",
|
|
42
|
+
options: {
|
|
43
|
+
mask
|
|
44
|
+
},
|
|
45
|
+
style: style,
|
|
46
|
+
value: context.values.cvc,
|
|
47
|
+
onChangeText: t => onChange(t),
|
|
48
|
+
id: "cvc",
|
|
49
|
+
editable: disabled,
|
|
50
|
+
selectTextOnFocus: disabled,
|
|
51
|
+
onBlur: onBlur,
|
|
52
|
+
placeholder: placeholder,
|
|
53
|
+
inputMode: "numeric",
|
|
54
|
+
autoComplete: "cc-csc",
|
|
55
|
+
readOnly: readOnly
|
|
56
|
+
});
|
|
57
|
+
};
|
|
58
|
+
exports.CardCVC = CardCVC;
|
|
59
|
+
//# sourceMappingURL=CardCVC.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_cardValidator","require","_react","_interopRequireWildcard","_reactNativeMaskedText","_context","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","CardCVC","style","disabled","placeholder","readOnly","context","useCardContext","mask","useMemo","type","validateNumber","values","number","brand","onChange","onBlur","register","useEffect","setRegisteredFields","prev","Set","add","next","delete","createElement","TextInputMask","options","value","cvc","onChangeText","id","editable","selectTextOnFocus","inputMode","autoComplete","exports"],"sourceRoot":"../../../../src","sources":["components/Card/CardCVC.tsx"],"mappings":";;;;;;AAAA,IAAAA,cAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,sBAAA,GAAAH,OAAA;AACA,IAAAI,QAAA,GAAAJ,OAAA;AAA2C,SAAAK,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAJ,wBAAAI,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAKpC,MAAMW,OAAO,GAAGA,CAAC;EACtBC,KAAK;EACLC,QAAQ;EACRC,WAAW;EACXC;AACQ,CAAC,KAAK;EACd,MAAMC,OAAO,GAAG,IAAAC,uBAAc,EAAC,CAAC;EAChC,MAAMC,IAAI,GAAG,IAAAC,cAAO,EAAC,MAAM;IACzB,MAAMC,IAAI,GAAG,IAAAC,6BAAc,EAACL,OAAO,CAACM,MAAM,CAACC,MAAM,CAAC,CAACC,KAAK;IACxD,IAAIJ,IAAI,KAAK,kBAAkB,EAAE;MAC/B,OAAO,MAAM;IACf;IACA,OAAO,KAAK;EACd,CAAC,EAAE,CAACJ,OAAO,CAACM,MAAM,CAACC,MAAM,CAAC,CAAC;EAE3B,MAAM;IAAEE,QAAQ;IAAEC;EAAO,CAAC,GAAGV,OAAO,CAACW,QAAQ,CAAC,KAAK,CAAC;EAEpD,IAAAC,gBAAS,EAAC,MAAM;IACdZ,OAAO,CAACa,mBAAmB,CAAEC,IAAI,IAAK,IAAIC,GAAG,CAACD,IAAI,CAAC,CAACE,GAAG,CAAC,KAAK,CAAC,CAAC;IAC/D,OAAO,MAAMhB,OAAO,CAACa,mBAAmB,CAAEC,IAAI,IAAK;MACjD,MAAMG,IAAI,GAAG,IAAIF,GAAG,CAACD,IAAI,CAAC;MAC1BG,IAAI,CAACC,MAAM,CAAC,KAAK,CAAC;MAClB,OAAOD,IAAI;IACb,CAAC,CAAC;IACF;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,oBACE9C,MAAA,CAAAU,OAAA,CAAAsC,aAAA,CAAC9C,sBAAA,CAAA+C,aAAa;IACZhB,IAAI,EAAC,QAAQ;IACbiB,OAAO,EAAE;MAAEnB;IAAK,CAAE;IAClBN,KAAK,EAAEA,KAAM;IACb0B,KAAK,EAAEtB,OAAO,CAACM,MAAM,CAACiB,GAAI;IAC1BC,YAAY,EAAG7C,CAAC,IAAK8B,QAAQ,CAAC9B,CAAC,CAAE;IACjC8C,EAAE,EAAC,KAAK;IACRC,QAAQ,EAAE7B,QAAS;IACnB8B,iBAAiB,EAAE9B,QAAS;IAC5Ba,MAAM,EAAEA,MAAO;IACfZ,WAAW,EAAEA,WAAY;IACzB8B,SAAS,EAAC,SAAS;IACnBC,YAAY,EAAC,QAAQ;IACrB9B,QAAQ,EAAEA;EAAS,CACpB,CAAC;AAEN,CAAC;AAAC+B,OAAA,CAAAnC,OAAA,GAAAA,OAAA","ignoreList":[]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.CardExpiry = CardExpiry;
|
|
7
|
+
var _reactNativeMaskedText = require("react-native-masked-text");
|
|
8
|
+
var _context = require("./context");
|
|
9
|
+
var _react = require("react");
|
|
10
|
+
function CardExpiry({
|
|
11
|
+
disabled,
|
|
12
|
+
placeholder,
|
|
13
|
+
readOnly,
|
|
14
|
+
style
|
|
15
|
+
}) {
|
|
16
|
+
const context = (0, _context.useCardContext)();
|
|
17
|
+
const {
|
|
18
|
+
onBlur,
|
|
19
|
+
onChange
|
|
20
|
+
} = context.register('expiry');
|
|
21
|
+
(0, _react.useEffect)(() => {
|
|
22
|
+
context.setRegisteredFields(prev => new Set(prev).add('expiry'));
|
|
23
|
+
return () => context.setRegisteredFields(prev => {
|
|
24
|
+
const next = new Set(prev);
|
|
25
|
+
next.delete('expiry');
|
|
26
|
+
return next;
|
|
27
|
+
});
|
|
28
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
29
|
+
}, []);
|
|
30
|
+
return /*#__PURE__*/React.createElement(_reactNativeMaskedText.TextInputMask, {
|
|
31
|
+
style: style,
|
|
32
|
+
type: "datetime",
|
|
33
|
+
value: context.values.expiry,
|
|
34
|
+
editable: disabled,
|
|
35
|
+
selectTextOnFocus: disabled
|
|
36
|
+
// store the expiry as MMYY not MM / YY
|
|
37
|
+
,
|
|
38
|
+
onChangeText: rawExpiry => onChange(rawExpiry.replace(' / ', '')),
|
|
39
|
+
options: {
|
|
40
|
+
format: '99 / 99'
|
|
41
|
+
},
|
|
42
|
+
id: "expiry",
|
|
43
|
+
onBlur: onBlur,
|
|
44
|
+
placeholder: placeholder ?? 'MM / YY',
|
|
45
|
+
inputMode: "numeric",
|
|
46
|
+
autoComplete: "cc-exp",
|
|
47
|
+
readOnly: readOnly
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=CardExpiry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_reactNativeMaskedText","require","_context","_react","CardExpiry","disabled","placeholder","readOnly","style","context","useCardContext","onBlur","onChange","register","useEffect","setRegisteredFields","prev","Set","add","next","delete","React","createElement","TextInputMask","type","value","values","expiry","editable","selectTextOnFocus","onChangeText","rawExpiry","replace","options","format","id","inputMode","autoComplete"],"sourceRoot":"../../../../src","sources":["components/Card/CardExpiry.tsx"],"mappings":";;;;;;AAAA,IAAAA,sBAAA,GAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AACA,IAAAE,MAAA,GAAAF,OAAA;AAKO,SAASG,UAAUA,CAAC;EACzBC,QAAQ;EACRC,WAAW;EACXC,QAAQ;EACRC;AACe,CAAC,EAAE;EAClB,MAAMC,OAAO,GAAG,IAAAC,uBAAc,EAAC,CAAC;EAEhC,MAAM;IAAEC,MAAM;IAAEC;EAAS,CAAC,GAAGH,OAAO,CAACI,QAAQ,CAAC,QAAQ,CAAC;EAEvD,IAAAC,gBAAS,EAAC,MAAM;IACdL,OAAO,CAACM,mBAAmB,CAAEC,IAAI,IAAK,IAAIC,GAAG,CAACD,IAAI,CAAC,CAACE,GAAG,CAAC,QAAQ,CAAC,CAAC;IAClE,OAAO,MAAMT,OAAO,CAACM,mBAAmB,CAAEC,IAAI,IAAK;MACjD,MAAMG,IAAI,GAAG,IAAIF,GAAG,CAACD,IAAI,CAAC;MAC1BG,IAAI,CAACC,MAAM,CAAC,QAAQ,CAAC;MACrB,OAAOD,IAAI;IACb,CAAC,CAAC;IACF;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,oBACEE,KAAA,CAAAC,aAAA,CAACtB,sBAAA,CAAAuB,aAAa;IACZf,KAAK,EAAEA,KAAM;IACbgB,IAAI,EAAC,UAAU;IACfC,KAAK,EAAEhB,OAAO,CAACiB,MAAM,CAACC,MAAO;IAC7BC,QAAQ,EAAEvB,QAAS;IACnBwB,iBAAiB,EAAExB;IACnB;IAAA;IACAyB,YAAY,EAAGC,SAAS,IAAKnB,QAAQ,CAACmB,SAAS,CAACC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAE;IACpEC,OAAO,EAAE;MACPC,MAAM,EAAE;IACV,CAAE;IACFC,EAAE,EAAC,QAAQ;IACXxB,MAAM,EAAEA,MAAO;IACfL,WAAW,EAAEA,WAAW,IAAI,SAAU;IACtC8B,SAAS,EAAC,SAAS;IACnBC,YAAY,EAAC,QAAQ;IACrB9B,QAAQ,EAAEA;EAAS,CACpB,CAAC;AAEN","ignoreList":[]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.CardHolder = CardHolder;
|
|
7
|
+
var _react = require("react");
|
|
8
|
+
var _reactNative = require("react-native");
|
|
9
|
+
var _context = require("./context");
|
|
10
|
+
function CardHolder({
|
|
11
|
+
autoFocus,
|
|
12
|
+
disabled,
|
|
13
|
+
placeholder,
|
|
14
|
+
readOnly,
|
|
15
|
+
style
|
|
16
|
+
}) {
|
|
17
|
+
const context = (0, _context.useCardContext)();
|
|
18
|
+
const {
|
|
19
|
+
onBlur,
|
|
20
|
+
onChange
|
|
21
|
+
} = context.register('name');
|
|
22
|
+
(0, _react.useEffect)(() => {
|
|
23
|
+
context.setRegisteredFields(prev => new Set(prev).add('name'));
|
|
24
|
+
return () => context.setRegisteredFields(prev => {
|
|
25
|
+
const next = new Set(prev);
|
|
26
|
+
next.delete('name');
|
|
27
|
+
return next;
|
|
28
|
+
});
|
|
29
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
30
|
+
}, []);
|
|
31
|
+
return /*#__PURE__*/React.createElement(_reactNative.TextInput, {
|
|
32
|
+
id: "name",
|
|
33
|
+
style: style,
|
|
34
|
+
value: context.values.name,
|
|
35
|
+
readOnly: readOnly,
|
|
36
|
+
onBlur: onBlur,
|
|
37
|
+
autoFocus: autoFocus,
|
|
38
|
+
editable: disabled,
|
|
39
|
+
selectTextOnFocus: disabled,
|
|
40
|
+
placeholder: placeholder,
|
|
41
|
+
autoComplete: "cc-name",
|
|
42
|
+
onChangeText: v => onChange(v)
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=CardHolder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","require","_reactNative","_context","CardHolder","autoFocus","disabled","placeholder","readOnly","style","context","useCardContext","onBlur","onChange","register","useEffect","setRegisteredFields","prev","Set","add","next","delete","React","createElement","TextInput","id","value","values","name","editable","selectTextOnFocus","autoComplete","onChangeText","v"],"sourceRoot":"../../../../src","sources":["components/Card/CardHolder.tsx"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,YAAA,GAAAD,OAAA;AACA,IAAAE,QAAA,GAAAF,OAAA;AAOO,SAASG,UAAUA,CAAC;EACzBC,SAAS;EACTC,QAAQ;EACRC,WAAW;EACXC,QAAQ;EACRC;AACe,CAAC,EAAE;EAClB,MAAMC,OAAO,GAAG,IAAAC,uBAAc,EAAC,CAAC;EAEhC,MAAM;IAAEC,MAAM;IAAEC;EAAS,CAAC,GAAGH,OAAO,CAACI,QAAQ,CAAC,MAAM,CAAC;EAErD,IAAAC,gBAAS,EAAC,MAAM;IACdL,OAAO,CAACM,mBAAmB,CAAEC,IAAI,IAAK,IAAIC,GAAG,CAACD,IAAI,CAAC,CAACE,GAAG,CAAC,MAAM,CAAC,CAAC;IAChE,OAAO,MAAMT,OAAO,CAACM,mBAAmB,CAAEC,IAAI,IAAK;MACjD,MAAMG,IAAI,GAAG,IAAIF,GAAG,CAACD,IAAI,CAAC;MAC1BG,IAAI,CAACC,MAAM,CAAC,MAAM,CAAC;MACnB,OAAOD,IAAI;IACb,CAAC,CAAC;IACF;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,oBACEE,KAAA,CAAAC,aAAA,CAACrB,YAAA,CAAAsB,SAAS;IACRC,EAAE,EAAC,MAAM;IACThB,KAAK,EAAEA,KAAM;IACbiB,KAAK,EAAEhB,OAAO,CAACiB,MAAM,CAACC,IAAK;IAC3BpB,QAAQ,EAAEA,QAAS;IACnBI,MAAM,EAAEA,MAAO;IACfP,SAAS,EAAEA,SAAU;IACrBwB,QAAQ,EAAEvB,QAAS;IACnBwB,iBAAiB,EAAExB,QAAS;IAC5BC,WAAW,EAAEA,WAAY;IACzBwB,YAAY,EAAC,SAAS;IACtBC,YAAY,EAAGC,CAAC,IAAKpB,QAAQ,CAACoB,CAAC;EAAE,CAClC,CAAC;AAEN","ignoreList":[]}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.CardNumber = CardNumber;
|
|
7
|
+
var _cardValidator = require("@evervault/card-validator");
|
|
8
|
+
var _react = require("react");
|
|
9
|
+
var _reactNativeMaskedText = require("react-native-masked-text");
|
|
10
|
+
var _context = require("./context");
|
|
11
|
+
function CardNumber({
|
|
12
|
+
autoFocus,
|
|
13
|
+
disabled,
|
|
14
|
+
placeholder,
|
|
15
|
+
readOnly,
|
|
16
|
+
style
|
|
17
|
+
}) {
|
|
18
|
+
const context = (0, _context.useCardContext)();
|
|
19
|
+
const ref = (0, _react.useRef)(null);
|
|
20
|
+
const [innerValue, mask] = (0, _react.useMemo)(() => {
|
|
21
|
+
const value = context.values.number;
|
|
22
|
+
const {
|
|
23
|
+
brand
|
|
24
|
+
} = (0, _cardValidator.validateNumber)(value);
|
|
25
|
+
const masks = {
|
|
26
|
+
'default': '9999 9999 9999 9999',
|
|
27
|
+
'unionpay': '9999 9999 9999 9999 999',
|
|
28
|
+
'american-express': '9999 999999 99999'
|
|
29
|
+
};
|
|
30
|
+
if (brand && !!masks[brand]) {
|
|
31
|
+
return [value, masks[brand]];
|
|
32
|
+
}
|
|
33
|
+
return [value, masks.default];
|
|
34
|
+
}, [context.values.number]);
|
|
35
|
+
const {
|
|
36
|
+
onBlur,
|
|
37
|
+
onChange
|
|
38
|
+
} = context.register('number');
|
|
39
|
+
(0, _react.useEffect)(() => {
|
|
40
|
+
context.setRegisteredFields(prev => new Set(prev).add('number'));
|
|
41
|
+
return () => context.setRegisteredFields(prev => {
|
|
42
|
+
const next = new Set(prev);
|
|
43
|
+
next.delete('name');
|
|
44
|
+
return next;
|
|
45
|
+
});
|
|
46
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
47
|
+
}, []);
|
|
48
|
+
return /*#__PURE__*/React.createElement(_reactNativeMaskedText.TextInputMask, {
|
|
49
|
+
style: style,
|
|
50
|
+
ref: ref,
|
|
51
|
+
type: "custom",
|
|
52
|
+
options: {
|
|
53
|
+
mask
|
|
54
|
+
},
|
|
55
|
+
id: "number",
|
|
56
|
+
value: innerValue,
|
|
57
|
+
onChangeText: onChange,
|
|
58
|
+
onBlur: onBlur,
|
|
59
|
+
readOnly: readOnly,
|
|
60
|
+
inputMode: "numeric",
|
|
61
|
+
autoFocus: autoFocus,
|
|
62
|
+
placeholder: placeholder,
|
|
63
|
+
editable: disabled,
|
|
64
|
+
selectTextOnFocus: disabled,
|
|
65
|
+
autoComplete: "cc-number"
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=CardNumber.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_cardValidator","require","_react","_reactNativeMaskedText","_context","CardNumber","autoFocus","disabled","placeholder","readOnly","style","context","useCardContext","ref","useRef","innerValue","mask","useMemo","value","values","number","brand","validateNumber","masks","default","onBlur","onChange","register","useEffect","setRegisteredFields","prev","Set","add","next","delete","React","createElement","TextInputMask","type","options","id","onChangeText","inputMode","editable","selectTextOnFocus","autoComplete"],"sourceRoot":"../../../../src","sources":["components/Card/CardNumber.tsx"],"mappings":";;;;;;AAAA,IAAAA,cAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,sBAAA,GAAAF,OAAA;AACA,IAAAG,QAAA,GAAAH,OAAA;AAOO,SAASI,UAAUA,CAAC;EACzBC,SAAS;EACTC,QAAQ;EACRC,WAAW;EACXC,QAAQ;EACRC;AACe,CAAC,EAAE;EAClB,MAAMC,OAAO,GAAG,IAAAC,uBAAc,EAAC,CAAC;EAChC,MAAMC,GAAG,GAAG,IAAAC,aAAM,EAAgB,IAAI,CAAC;EAEvC,MAAM,CAACC,UAAU,EAAEC,IAAI,CAAC,GAAG,IAAAC,cAAO,EAAC,MAAM;IACvC,MAAMC,KAAK,GAAGP,OAAO,CAACQ,MAAM,CAACC,MAAM;IAEnC,MAAM;MAAEC;IAAM,CAAC,GAAG,IAAAC,6BAAc,EAACJ,KAAK,CAAC;IAEvC,MAAMK,KAAK,GAAG;MACZ,SAAS,EAAE,qBAAqB;MAChC,UAAU,EAAE,yBAAyB;MACrC,kBAAkB,EAAE;IACtB,CAA2B;IAE3B,IAAIF,KAAK,IAAI,CAAC,CAACE,KAAK,CAACF,KAAK,CAAC,EAAE;MAC3B,OAAO,CAACH,KAAK,EAAEK,KAAK,CAACF,KAAK,CAAC,CAAC;IAC9B;IACA,OAAO,CAACH,KAAK,EAAEK,KAAK,CAACC,OAAO,CAAC;EAC/B,CAAC,EAAE,CAACb,OAAO,CAACQ,MAAM,CAACC,MAAM,CAAC,CAAC;EAE3B,MAAM;IAAEK,MAAM;IAAEC;EAAS,CAAC,GAAGf,OAAO,CAACgB,QAAQ,CAAC,QAAQ,CAAC;EAEvD,IAAAC,gBAAS,EAAC,MAAM;IACdjB,OAAO,CAACkB,mBAAmB,CAAEC,IAAI,IAAK,IAAIC,GAAG,CAACD,IAAI,CAAC,CAACE,GAAG,CAAC,QAAQ,CAAC,CAAC;IAClE,OAAO,MAAMrB,OAAO,CAACkB,mBAAmB,CAAEC,IAAI,IAAK;MACjD,MAAMG,IAAI,GAAG,IAAIF,GAAG,CAACD,IAAI,CAAC;MAC1BG,IAAI,CAACC,MAAM,CAAC,MAAM,CAAC;MACnB,OAAOD,IAAI;IACb,CAAC,CAAC;IACF;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,oBACEE,KAAA,CAAAC,aAAA,CAACjC,sBAAA,CAAAkC,aAAa;IACZ3B,KAAK,EAAEA,KAAM;IACbG,GAAG,EAAEA,GAAI;IACTyB,IAAI,EAAC,QAAQ;IACbC,OAAO,EAAE;MAAEvB;IAAK,CAAE;IAClBwB,EAAE,EAAC,QAAQ;IACXtB,KAAK,EAAEH,UAAW;IAClB0B,YAAY,EAAEf,QAAS;IACvBD,MAAM,EAAEA,MAAO;IACfhB,QAAQ,EAAEA,QAAS;IACnBiC,SAAS,EAAC,SAAS;IACnBpC,SAAS,EAAEA,SAAU;IACrBE,WAAW,EAAEA,WAAY;IACzBmC,QAAQ,EAAEpC,QAAS;IACnBqC,iBAAiB,EAAErC,QAAS;IAC5BsC,YAAY,EAAC;EAAW,CACzB,CAAC;AAEN","ignoreList":[]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.useCardContext = exports.CardContext = void 0;
|
|
7
|
+
var _react = require("react");
|
|
8
|
+
const CardContext = exports.CardContext = /*#__PURE__*/(0, _react.createContext)({
|
|
9
|
+
values: {
|
|
10
|
+
name: '',
|
|
11
|
+
number: '',
|
|
12
|
+
cvc: '',
|
|
13
|
+
expiry: ''
|
|
14
|
+
},
|
|
15
|
+
register: () => ({
|
|
16
|
+
onChange: () => {},
|
|
17
|
+
onBlur: () => {}
|
|
18
|
+
}),
|
|
19
|
+
setRegisteredFields: () => {}
|
|
20
|
+
});
|
|
21
|
+
const useCardContext = () => (0, _react.useContext)(CardContext);
|
|
22
|
+
exports.useCardContext = useCardContext;
|
|
23
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","require","CardContext","exports","createContext","values","name","number","cvc","expiry","register","onChange","onBlur","setRegisteredFields","useCardContext","useContext"],"sourceRoot":"../../../../src","sources":["components/Card/context.tsx"],"mappings":";;;;;;AACA,IAAAA,MAAA,GAAAC,OAAA;AASO,MAAMC,WAAW,GAAAC,OAAA,CAAAD,WAAA,gBAAG,IAAAE,oBAAa,EAAoB;EAC1DC,MAAM,EAAE;IACNC,IAAI,EAAE,EAAE;IACRC,MAAM,EAAE,EAAE;IACVC,GAAG,EAAE,EAAE;IACPC,MAAM,EAAE;EACV,CAAC;EACDC,QAAQ,EAAEA,CAAA,MAAO;IACfC,QAAQ,EAAEA,CAAA,KAAM,CAAC,CAAC;IAChBC,MAAM,EAAEA,CAAA,KAAM,CAAC;EACf,CAAC,CAAC;EACNC,mBAAmB,EAAEA,CAAA,KAAM,CAAC;AAC5B,CAAC,CAAC;AAEG,MAAMC,cAAc,GAAGA,CAAA,KAAM,IAAAC,iBAAU,EAACb,WAAW,CAAC;AAACC,OAAA,CAAAW,cAAA,GAAAA,cAAA","ignoreList":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
Object.defineProperty(exports, "Card", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function () {
|
|
9
|
+
return _Card.Card;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
var _Card = require("./Card");
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_Card","require"],"sourceRoot":"../../../../src","sources":["components/Card/index.ts"],"mappings":";;;;;;;;;;;AAAA,IAAAA,KAAA,GAAAC,OAAA","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../../src","sources":["components/Card/types.ts"],"mappings":"","ignoreList":[]}
|