@evervault/evervault-react-native 0.2.2 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +52 -12
- 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/evervault-react-native.podspec +1 -1
- package/lib/commonjs/components/Card/Card.js +115 -0
- package/lib/commonjs/components/Card/Card.js.map +1 -0
- package/lib/commonjs/components/Card/CardCVC.js +53 -0
- package/lib/commonjs/components/Card/CardCVC.js.map +1 -0
- package/lib/commonjs/components/Card/CardExpiry.js +40 -0
- package/lib/commonjs/components/Card/CardExpiry.js.map +1 -0
- package/lib/commonjs/components/Card/CardHolder.js +38 -0
- package/lib/commonjs/components/Card/CardHolder.js.map +1 -0
- package/lib/commonjs/components/Card/CardNumber.js +63 -0
- package/lib/commonjs/components/Card/CardNumber.js.map +1 -0
- package/lib/commonjs/components/Card/context.js +23 -0
- package/lib/commonjs/components/Card/context.js.map +1 -0
- package/lib/commonjs/components/Card/index.js +20 -0
- package/lib/commonjs/components/Card/index.js.map +1 -0
- package/lib/commonjs/components/Card/types.js +6 -0
- package/lib/commonjs/components/Card/types.js.map +1 -0
- package/lib/commonjs/components/Card/utilities.js +85 -0
- package/lib/commonjs/components/Card/utilities.js.map +1 -0
- package/lib/commonjs/components/Common/Error.js +2 -0
- package/lib/commonjs/components/Common/Error.js.map +1 -0
- package/lib/commonjs/components/index.js +3 -0
- package/lib/commonjs/components/index.js.map +1 -0
- package/lib/commonjs/index.js +18 -16
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/native.js +17 -0
- package/lib/commonjs/native.js.map +1 -0
- package/lib/commonjs/sdk.js +22 -0
- package/lib/commonjs/sdk.js.map +1 -0
- package/lib/module/components/Card/Card.js +110 -0
- package/lib/module/components/Card/Card.js.map +1 -0
- package/lib/module/components/Card/CardCVC.js +44 -0
- package/lib/module/components/Card/CardCVC.js.map +1 -0
- package/lib/module/components/Card/CardExpiry.js +34 -0
- package/lib/module/components/Card/CardExpiry.js.map +1 -0
- package/lib/module/components/Card/CardHolder.js +32 -0
- package/lib/module/components/Card/CardHolder.js.map +1 -0
- package/lib/module/components/Card/CardNumber.js +57 -0
- package/lib/module/components/Card/CardNumber.js.map +1 -0
- package/lib/module/components/Card/context.js +16 -0
- package/lib/module/components/Card/context.js.map +1 -0
- package/lib/module/components/Card/index.js +3 -0
- package/lib/module/components/Card/index.js.map +1 -0
- package/lib/module/components/Card/types.js +2 -0
- package/lib/module/components/Card/types.js.map +1 -0
- package/lib/module/components/Card/utilities.js +77 -0
- package/lib/module/components/Card/utilities.js.map +1 -0
- package/lib/module/components/Common/Error.js +2 -0
- package/lib/module/components/Common/Error.js.map +1 -0
- package/lib/module/components/index.js +2 -0
- package/lib/module/components/index.js.map +1 -0
- package/lib/module/index.js +2 -16
- package/lib/module/index.js.map +1 -1
- package/lib/module/native.js +11 -0
- package/lib/module/native.js.map +1 -0
- package/lib/module/sdk.js +15 -0
- package/lib/module/sdk.js.map +1 -0
- package/lib/typescript/src/components/Card/Card.d.ts +30 -0
- package/lib/typescript/src/components/Card/Card.d.ts.map +1 -0
- package/lib/typescript/src/components/Card/CardCVC.d.ts +6 -0
- package/lib/typescript/src/components/Card/CardCVC.d.ts.map +1 -0
- package/lib/typescript/src/components/Card/CardExpiry.d.ts +6 -0
- package/lib/typescript/src/components/Card/CardExpiry.d.ts.map +1 -0
- package/lib/typescript/src/components/Card/CardHolder.d.ts +7 -0
- package/lib/typescript/src/components/Card/CardHolder.d.ts.map +1 -0
- package/lib/typescript/src/components/Card/CardNumber.d.ts +8 -0
- package/lib/typescript/src/components/Card/CardNumber.d.ts.map +1 -0
- package/lib/typescript/src/components/Card/context.d.ts +13 -0
- package/lib/typescript/src/components/Card/context.d.ts.map +1 -0
- package/lib/typescript/src/components/Card/index.d.ts +3 -0
- package/lib/typescript/src/components/Card/index.d.ts.map +1 -0
- package/lib/typescript/src/components/Card/types.d.ts +13 -0
- package/lib/typescript/src/components/Card/types.d.ts.map +1 -0
- package/lib/typescript/src/components/Card/utilities.d.ts +8 -0
- package/lib/typescript/src/components/Card/utilities.d.ts.map +1 -0
- package/lib/typescript/src/components/Common/Error.d.ts +1 -0
- package/lib/typescript/src/components/Common/Error.d.ts.map +1 -0
- package/lib/typescript/src/components/index.d.ts +1 -0
- package/lib/typescript/src/components/index.d.ts.map +1 -0
- package/lib/typescript/src/index.d.ts +3 -2
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/native.d.ts +2 -0
- package/lib/typescript/src/native.d.ts.map +1 -0
- package/lib/typescript/src/sdk.d.ts +3 -0
- package/lib/typescript/src/sdk.d.ts.map +1 -0
- package/package.json +29 -23
- package/src/components/Card/Card.tsx +156 -0
- package/src/components/Card/CardCVC.tsx +47 -0
- package/src/components/Card/CardExpiry.tsx +39 -0
- package/src/components/Card/CardHolder.tsx +39 -0
- package/src/components/Card/CardNumber.tsx +64 -0
- package/src/components/Card/context.tsx +26 -0
- package/src/components/Card/index.ts +2 -0
- package/src/components/Card/types.ts +15 -0
- package/src/components/Card/utilities.ts +105 -0
- package/src/components/Common/Error.tsx +0 -0
- package/src/components/index.ts +1 -0
- package/src/index.tsx +3 -26
- package/src/native.ts +18 -0
- package/src/sdk.ts +17 -0
package/README.md
CHANGED
|
@@ -1,36 +1,76 @@
|
|
|
1
1
|
# react-native-evervault-sdk
|
|
2
2
|
|
|
3
|
-
Evervault react native sdk
|
|
4
3
|
|
|
5
4
|
## Installation
|
|
6
5
|
|
|
7
6
|
```sh
|
|
8
7
|
npm install @evervault/evervault-react-native
|
|
9
8
|
```
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
pod install
|
|
9
|
+
or
|
|
10
|
+
```sh
|
|
11
|
+
yarn add @evervault/evervault-react-native
|
|
14
12
|
```
|
|
15
13
|
|
|
16
14
|
## Usage
|
|
17
|
-
```
|
|
18
|
-
|
|
15
|
+
```typescript
|
|
16
|
+
// .tsx
|
|
17
|
+
import { init } from '@evervault/evervault-react-native';
|
|
18
|
+
|
|
19
19
|
|
|
20
20
|
export default function Component() {
|
|
21
|
-
const [
|
|
22
|
-
const testEncObject = { key: 'value', boolKey: true, number: 123};
|
|
21
|
+
const [cardData, setCardData] = useState<CardPayload | null>(null);
|
|
23
22
|
|
|
24
|
-
|
|
23
|
+
useEffect(() => {
|
|
25
24
|
async function initEvervault() {
|
|
26
25
|
try {
|
|
27
|
-
await init(
|
|
26
|
+
await init(
|
|
27
|
+
process.env.EV_TEAM_UUID as string,
|
|
28
|
+
process.env.EV_APP_UUID as string
|
|
29
|
+
);
|
|
28
30
|
} catch (error) {
|
|
29
31
|
console.error(error);
|
|
30
32
|
}
|
|
31
33
|
}
|
|
32
34
|
initEvervault();
|
|
33
|
-
encrypt(testEncObject).then(setEncObject);
|
|
34
35
|
}, []);
|
|
36
|
+
|
|
37
|
+
return (
|
|
38
|
+
<Card onChange={setCardData} onComplete={() => console.log("Form Complete!")} style={{ gap: 24 }}>
|
|
39
|
+
<Card.Number placeholder="4242 4242 4242 4242" style={{ padding: 24 }}/>
|
|
40
|
+
<Card.CVC placeholder="123" />
|
|
41
|
+
<Card.Holder placeholder="Mark Doyle" />
|
|
42
|
+
</Card>
|
|
43
|
+
);
|
|
35
44
|
}
|
|
36
45
|
```
|
|
46
|
+
|
|
47
|
+
## Reference
|
|
48
|
+
### `init(teamUuid, appUuid)`
|
|
49
|
+
|
|
50
|
+
Initialize the Evervault SDK, this must be called before `encrypt` to set your Apps keys on the device.
|
|
51
|
+
|
|
52
|
+
### Options
|
|
53
|
+
|
|
54
|
+
| Type | Type | Required |
|
|
55
|
+
| -------- | ------ | -------- |
|
|
56
|
+
| teamUuid | string | yes |
|
|
57
|
+
| appUuid | string | yes |
|
|
58
|
+
|
|
59
|
+
### Returns
|
|
60
|
+
|
|
61
|
+
`Promise<void>`
|
|
62
|
+
|
|
63
|
+
### `encrypt(data)`
|
|
64
|
+
Encrypts data using [Evervault Encryption](https://docs.evervault.com/security/evervault-encryption).
|
|
65
|
+
|
|
66
|
+
To encrypt strings using the React Native SDK, simply pass a String or an Object into the `encrypt()` function.
|
|
67
|
+
|
|
68
|
+
### Options
|
|
69
|
+
|
|
70
|
+
| Type | Type | Required |
|
|
71
|
+
| ---- | ----------------------------- | -------- |
|
|
72
|
+
| data | String, Number, Object, Array | yes |
|
|
73
|
+
|
|
74
|
+
### Returns
|
|
75
|
+
|
|
76
|
+
`Promise<string>`
|
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))
|
|
@@ -13,7 +13,7 @@ Pod::Spec.new do |s|
|
|
|
13
13
|
s.platforms = { :ios => "13.0" }
|
|
14
14
|
s.source = { :git => "https://github.com/evervault/evervault-react-native.git", :tag => "#{s.version}" }
|
|
15
15
|
|
|
16
|
-
s.source_files = "ios/**/*.{h,m,mm}"
|
|
16
|
+
s.source_files = "ios/**/*.{h,m,mm,swift}"
|
|
17
17
|
|
|
18
18
|
s.dependency "React-Core"
|
|
19
19
|
s.dependency "Evervault", '~> 0.3.2'
|
|
@@ -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 _shared = require("shared");
|
|
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, _shared.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","_shared","_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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"}
|
|
@@ -0,0 +1,53 @@
|
|
|
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 && Object.prototype.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
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
34
|
+
}, []);
|
|
35
|
+
return /*#__PURE__*/_react.default.createElement(_reactNativeMaskedText.TextInputMask, {
|
|
36
|
+
type: "custom",
|
|
37
|
+
options: {
|
|
38
|
+
mask
|
|
39
|
+
},
|
|
40
|
+
style: style,
|
|
41
|
+
value: context.values.cvc,
|
|
42
|
+
onChangeText: t => onChange(t),
|
|
43
|
+
id: "cvc",
|
|
44
|
+
editable: disabled,
|
|
45
|
+
selectTextOnFocus: disabled,
|
|
46
|
+
onBlur: onBlur,
|
|
47
|
+
placeholder: placeholder,
|
|
48
|
+
autoComplete: "cc-csc",
|
|
49
|
+
readOnly: readOnly
|
|
50
|
+
});
|
|
51
|
+
};
|
|
52
|
+
exports.CardCVC = CardCVC;
|
|
53
|
+
//# 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","prototype","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","createElement","TextInputMask","options","value","cvc","onChangeText","id","editable","selectTextOnFocus","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,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAjB,CAAA,EAAAc,CAAA,SAAAI,CAAA,GAAAR,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAI,CAAA,KAAAA,CAAA,CAAAX,GAAA,IAAAW,CAAA,CAAAC,GAAA,IAAAR,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAI,CAAA,IAAAV,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAgB,GAAA,CAAAnB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAKpC,MAAMY,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;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,oBACE9C,MAAA,CAAAU,OAAA,CAAAqC,aAAA,CAAC7C,sBAAA,CAAA8C,aAAa;IACZd,IAAI,EAAC,QAAQ;IACbe,OAAO,EAAE;MAAEjB;IAAK,CAAE;IAClBN,KAAK,EAAEA,KAAM;IACbwB,KAAK,EAAEpB,OAAO,CAACM,MAAM,CAACe,GAAI;IAC1BC,YAAY,EAAG5C,CAAC,IAAK+B,QAAQ,CAAC/B,CAAC,CAAE;IACjC6C,EAAE,EAAC,KAAK;IACRC,QAAQ,EAAE3B,QAAS;IACnB4B,iBAAiB,EAAE5B,QAAS;IAC5Ba,MAAM,EAAEA,MAAO;IACfZ,WAAW,EAAEA,WAAY;IACzB4B,YAAY,EAAC,QAAQ;IACrB3B,QAAQ,EAAEA;EAAS,CACpB,CAAC;AAEN,CAAC;AAAC4B,OAAA,CAAAhC,OAAA,GAAAA,OAAA"}
|
|
@@ -0,0 +1,40 @@
|
|
|
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
|
+
}) {
|
|
15
|
+
const context = (0, _context.useCardContext)();
|
|
16
|
+
const {
|
|
17
|
+
onBlur,
|
|
18
|
+
onChange
|
|
19
|
+
} = context.register('expiry');
|
|
20
|
+
(0, _react.useEffect)(() => {
|
|
21
|
+
context.setRegisteredFields(prev => new Set(prev).add('expiry'));
|
|
22
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
23
|
+
}, []);
|
|
24
|
+
return /*#__PURE__*/React.createElement(_reactNativeMaskedText.TextInputMask, {
|
|
25
|
+
type: "datetime",
|
|
26
|
+
value: context.values.expiry,
|
|
27
|
+
editable: disabled,
|
|
28
|
+
selectTextOnFocus: disabled,
|
|
29
|
+
onChangeText: onChange,
|
|
30
|
+
options: {
|
|
31
|
+
format: '99 / 99'
|
|
32
|
+
},
|
|
33
|
+
id: "expiry",
|
|
34
|
+
onBlur: onBlur,
|
|
35
|
+
placeholder: placeholder ?? 'MM / YY',
|
|
36
|
+
autoComplete: "cc-exp",
|
|
37
|
+
readOnly: readOnly
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=CardExpiry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_reactNativeMaskedText","require","_context","_react","CardExpiry","disabled","placeholder","readOnly","context","useCardContext","onBlur","onChange","register","useEffect","setRegisteredFields","prev","Set","add","React","createElement","TextInputMask","type","value","values","expiry","editable","selectTextOnFocus","onChangeText","options","format","id","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;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;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,oBACEC,KAAA,CAAAC,aAAA,CAACnB,sBAAA,CAAAoB,aAAa;IACZC,IAAI,EAAC,UAAU;IACfC,KAAK,EAAEd,OAAO,CAACe,MAAM,CAACC,MAAO;IAC7BC,QAAQ,EAAEpB,QAAS;IACnBqB,iBAAiB,EAAErB,QAAS;IAC5BsB,YAAY,EAAEhB,QAAS;IACvBiB,OAAO,EAAE;MACPC,MAAM,EAAE;IACV,CAAE;IACFC,EAAE,EAAC,QAAQ;IACXpB,MAAM,EAAEA,MAAO;IACfJ,WAAW,EAAEA,WAAW,IAAI,SAAU;IACtCyB,YAAY,EAAC,QAAQ;IACrBxB,QAAQ,EAAEA;EAAS,CACpB,CAAC;AAEN"}
|
|
@@ -0,0 +1,38 @@
|
|
|
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
|
+
}) {
|
|
16
|
+
const context = (0, _context.useCardContext)();
|
|
17
|
+
const {
|
|
18
|
+
onBlur,
|
|
19
|
+
onChange
|
|
20
|
+
} = context.register('name');
|
|
21
|
+
(0, _react.useEffect)(() => {
|
|
22
|
+
context.setRegisteredFields(prev => new Set(prev).add('name'));
|
|
23
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
24
|
+
}, []);
|
|
25
|
+
return /*#__PURE__*/React.createElement(_reactNative.TextInput, {
|
|
26
|
+
id: "name",
|
|
27
|
+
value: context.values.name,
|
|
28
|
+
readOnly: readOnly,
|
|
29
|
+
onBlur: onBlur,
|
|
30
|
+
autoFocus: autoFocus,
|
|
31
|
+
editable: disabled,
|
|
32
|
+
selectTextOnFocus: disabled,
|
|
33
|
+
placeholder: placeholder,
|
|
34
|
+
autoComplete: "cc-name",
|
|
35
|
+
onChangeText: v => onChange(v)
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=CardHolder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","require","_reactNative","_context","CardHolder","autoFocus","disabled","placeholder","readOnly","context","useCardContext","onBlur","onChange","register","useEffect","setRegisteredFields","prev","Set","add","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;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;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,oBACEC,KAAA,CAAAC,aAAA,CAAClB,YAAA,CAAAmB,SAAS;IACRC,EAAE,EAAC,MAAM;IACTC,KAAK,EAAEd,OAAO,CAACe,MAAM,CAACC,IAAK;IAC3BjB,QAAQ,EAAEA,QAAS;IACnBG,MAAM,EAAEA,MAAO;IACfN,SAAS,EAAEA,SAAU;IACrBqB,QAAQ,EAAEpB,QAAS;IACnBqB,iBAAiB,EAAErB,QAAS;IAC5BC,WAAW,EAAEA,WAAY;IACzBqB,YAAY,EAAC,SAAS;IACtBC,YAAY,EAAGC,CAAC,IAAKlB,QAAQ,CAACkB,CAAC;EAAE,CAClC,CAAC;AAEN"}
|
|
@@ -0,0 +1,63 @@
|
|
|
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
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
42
|
+
}, []);
|
|
43
|
+
return /*#__PURE__*/React.createElement(_reactNativeMaskedText.TextInputMask, {
|
|
44
|
+
style: style,
|
|
45
|
+
ref: ref,
|
|
46
|
+
type: "custom",
|
|
47
|
+
options: {
|
|
48
|
+
mask
|
|
49
|
+
},
|
|
50
|
+
id: "number",
|
|
51
|
+
value: innerValue,
|
|
52
|
+
onChangeText: onChange,
|
|
53
|
+
onBlur: onBlur,
|
|
54
|
+
readOnly: readOnly,
|
|
55
|
+
inputMode: "numeric",
|
|
56
|
+
autoFocus: autoFocus,
|
|
57
|
+
placeholder: placeholder,
|
|
58
|
+
editable: disabled,
|
|
59
|
+
selectTextOnFocus: disabled,
|
|
60
|
+
autoComplete: "cc-number"
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
//# 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","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;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,oBACEC,KAAA,CAAAC,aAAA,CAAC/B,sBAAA,CAAAgC,aAAa;IACZzB,KAAK,EAAEA,KAAM;IACbG,GAAG,EAAEA,GAAI;IACTuB,IAAI,EAAC,QAAQ;IACbC,OAAO,EAAE;MAAErB;IAAK,CAAE;IAClBsB,EAAE,EAAC,QAAQ;IACXpB,KAAK,EAAEH,UAAW;IAClBwB,YAAY,EAAEb,QAAS;IACvBD,MAAM,EAAEA,MAAO;IACfhB,QAAQ,EAAEA,QAAS;IACnB+B,SAAS,EAAC,SAAS;IACnBlC,SAAS,EAAEA,SAAU;IACrBE,WAAW,EAAEA,WAAY;IACzBiC,QAAQ,EAAElC,QAAS;IACnBmC,iBAAiB,EAAEnC,QAAS;IAC5BoC,YAAY,EAAC;EAAW,CACzB,CAAC;AAEN"}
|
|
@@ -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;AAUO,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,CAAE,CAAC;IACnBC,MAAM,EAAEA,CAAA,KAAM,CAAE;EAClB,CAAC,CAAC;EACFC,mBAAmB,EAAEA,CAAA,KAAM,CAAE;AAC/B,CAAC,CAAC;AAEK,MAAMC,cAAc,GAAGA,CAAA,KAAM,IAAAC,iBAAU,EAACb,WAAW,CAAC;AAACC,OAAA,CAAAW,cAAA,GAAAA,cAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
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
|
+
Object.defineProperty(exports, "CardPayload", {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
get: function () {
|
|
15
|
+
return _types.CardPayload;
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
var _Card = require("./Card");
|
|
19
|
+
var _types = require("types");
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_Card","require","_types"],"sourceRoot":"../../../../src","sources":["components/Card/index.ts"],"mappings":";;;;;;;;;;;;;;;;;AAAA,IAAAA,KAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../../src","sources":["components/Card/types.ts"],"mappings":""}
|