@pinerohit11/testwidget 0.1.34 → 0.1.36

Sign up to get free protection for your applications and to get access to all the features.
package/dist/index.cjs CHANGED
@@ -47,1181 +47,1195 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
47
47
  // src/app/index.ts
48
48
  var app_exports = {};
49
49
  __export(app_exports, {
50
- PaywithFractal: () => PaywithFractal
50
+ RequestPayment: () => RequestPayment
51
51
  });
52
52
  module.exports = __toCommonJS(app_exports);
53
- var import_bootstrap_min2 = require("bootstrap/dist/css/bootstrap.min.css");
54
53
 
55
- // src/app/components/Greet.tsx
54
+ // src/app/components/RequestPayment/RequestPayment.tsx
55
+ var import_react4 = require("react");
56
56
  var import_axios = __toESM(require("axios"), 1);
57
+
58
+ // src/app/components/Loader/Loader.tsx
57
59
  var import_react2 = __toESM(require("react"), 1);
58
- var import_react_bootstrap = require("react-bootstrap");
59
- var import_bootstrap_min = require("bootstrap/dist/css/bootstrap.min.css");
60
60
 
61
- // src/app/components/CustomStyle.tsx
61
+ // src/app/components/Loader/LoaderStyle.tsx
62
62
  var import_react = __toESM(require("react"), 1);
63
- var CustomStyle = (props) => {
63
+ var LoaderStyle = (props) => {
64
64
  return /* @__PURE__ */ import_react.default.createElement("style", null, `
65
-
65
+ .loader {
66
+ position: fixed;
67
+ /* Fixed position to cover the viewport */
68
+ top: 0;
69
+ left: 0;
70
+ width: 100%;
71
+ height: 100%;
72
+ display: flex;
73
+ justify-content: center;
74
+ align-items: center;
75
+ /* background: rgba(255, 255, 0, 0.01); Adjust the blur effect */
76
+ background-color: rgba(255, 255, 255, 0.521);
77
+ /* Semi-transparent black background */
66
78
 
67
- body {
68
- background: #d5d5d5;
69
- font-family: 'Poppins', sans-serif;
70
- }
71
-
72
- input::placeholder {
73
- font-weight: 500;
74
- opacity: 0.5;
75
- color: #35254D !important;
76
- }
77
-
78
- .bg-light {
79
- background: #d5d5d5 !important;
80
- height: 100vh;
81
- }
82
-
83
- .payment-popup {
84
- /* padding: 35px 40px; */
85
- padding: 0px;
86
- background: #fff;
87
- border-radius: 20px;
88
- position: relative;
89
- /* width: 400px; */
90
- margin: 0 auto;
91
- }
92
-
93
- @media(max-width:460px) {
94
- .payment-popup {
95
- padding: 35px 25px;
96
- width: 98%;
97
- }
98
- }
99
-
100
- .close-pop {
101
- position: absolute;
102
- right: 8px;
103
- top: 8px;
104
- border: 0;
105
- padding: 0;
106
- background: none !important;
107
- }
108
-
109
- .amex {
110
- /* background-image: url("./amex.svg"); */
111
- }
112
-
113
- .visa {
114
- /* background-image: url("./visa.svg"); */
115
- }
116
-
117
- .mastercard {
118
- /* background-image: url("./mastercard.svg"); */
119
- }
120
-
121
- .discover {
122
- /* background-image: url("./discover.svg"); */
123
- }
124
-
125
- .expiry-date-group {
126
- float: left;
127
- width: 30%
128
- }
129
-
130
- .expiry-date-group input {
131
- width: calc(100% + 1px);
132
- border-top-right-radius: 0;
133
- border-bottom-right-radius: 0;
134
- }
135
-
136
- .expiry-date-group input:focus {
137
- position: relative;
138
- z-index: 10;
139
- }
140
-
141
- .security-code-group {
142
- float: right;
143
- width: 40%;
144
- position: relative;
145
- }
146
-
147
- .security-code-group input {
148
- border-top-left-radius: 0;
149
- border-bottom-left-radius: 0;
150
- }
151
-
152
- .zip-code-group {
153
- clear: both;
154
- }
155
-
156
-
157
- #submitButton {
158
- outline: 0 !important;
159
- height: 46px;
160
- font-size: 16px;
161
- background-color: #161616 !important;
162
- border: none;
163
- display: block;
164
- width: 100%;
165
- border-radius: 180px;
166
- }
167
-
168
- #PayButton {
169
- outline: 0 !important;
170
- height: 46px;
171
- font-size: 16px;
172
- background-color: #161616 !important;
173
- border: none;
174
- display: block;
175
- width: 100%;
176
- border-radius: 180px;
177
- }
178
-
179
- #PayButton:hover {
180
- background-color: #61C699 !important;
181
- }
182
-
183
- #PayButton:active {
184
- background-color: #61C699 !important;
185
- }
186
-
187
- #PayButton:disabled {
188
- background: rgb(172, 44, 170) !important;
189
- color: #FFF !important;
190
- }
191
-
192
- .form-control {
193
- color: #35254D;
194
- }
195
-
196
- .container {
197
- margin-top: 10px;
198
- }
199
-
200
- #Checkout {
201
- z-index: 100001;
202
- width: 100%;
203
- height: 100%;
204
- min-height: 100%;
205
- background: 0 0 #ffffff;
206
- border-radius: 24px;
207
- border: 1px solid #E0DFE2;
208
- margin-left: auto;
209
- margin-right: auto;
210
- display: block;
211
- }
212
-
213
- #Checkout .header {
214
- display: flex;
215
- /* Enables Flexbox */
216
- justify-content: center;
217
- /* Centers content horizontally */
218
- align-items: center;
219
- /* Centers content vertically */
220
- text-align: center;
221
- padding: 8px;
222
- border-bottom: 1px solid #DEDEDE;
223
- margin: 0 10px 20px 10px;
224
- }
225
-
226
- #Checkout .header button {
227
- border: 0;
228
- background: none;
229
- padding: 0;
230
- }
231
-
232
- #Checkout h1 {
233
- margin: 0;
234
- flex: 1;
235
- padding: 10px;
236
- /* Allows the title to grow and fill the space for centering */
237
- font-size: 23px;
238
- font-weight: 500;
239
- color: #35254D;
240
- /* align-items: start; */
241
- display: flex;
242
- }
243
-
244
- #Checkout>form {
245
- margin: 0 25px 10px 25px;
246
- }
247
-
248
- label {
249
- color: rgba(53, 37, 77, 0.6);
250
- margin-bottom: 2px;
251
- text-transform: uppercase;
252
- font-family: "IBM Plex Mono", monospace;
253
- font-weight: 500;
254
- font-size: 12px;
255
- }
256
-
257
- .input-container {
258
- position: relative;
259
- }
260
-
261
- .input-container input {
262
- padding-right: 25px;
263
- }
264
-
265
- #zipcode {
266
- text-transform: capitalize !important;
267
- }
268
-
269
- #zipcode {
270
- width: 18px;
271
- position: absolute;
272
- right: 8px;
273
- top: 9px;
274
- }
275
-
276
- #zipcode .zip-tip {
277
- display: none;
278
- background-color: rgb(0, 0, 0, 0.4);
279
- padding: 5px 8px;
280
- border-radius: 6px;
281
- position: absolute;
282
- right: 26px;
283
- top: -9px;
284
- font-size: 12.5px;
285
- text-transform: capitalize !important;
286
- color: #fff;
287
- width: 240px;
288
- line-height: 16px;
289
- }
290
-
291
- #zipcode .zip-tip:before {
292
- width: 0;
293
- height: 0;
294
- border-top: 7px solid transparent;
295
- border-bottom: 7px solid transparent;
296
- border-left: 7px solid #000;
297
- opacity: 0.4;
298
- position: absolute;
299
- right: -7px;
300
- top: 50%;
301
- transform: translateY(-50%);
302
- content: '';
303
- }
304
-
305
-
306
-
307
- #zipcode:hover .zip-tip {
308
- display: block;
309
- }
310
-
311
-
312
- .input-container>i,
313
- a[role="button"] {
314
- color: #d3d3d3;
315
- width: 25px;
316
- height: 30px;
317
- line-height: 30px;
318
- font-size: 16px;
319
- position: absolute;
320
- top: 5px;
321
- right: 6px;
322
- cursor: pointer;
323
- text-align: center;
324
- }
325
-
326
- .input-container>i:hover,
327
- a[role="button"]:hover {
328
- color: #777;
329
- }
330
-
331
- .amount-placeholder {
332
- white-space: nowrap;
333
- font-size: 44px;
334
- /* height: 35px; */
335
- font-weight: 600;
336
- line-height: 40px;
337
- }
338
-
339
- .amount-placeholder>button {
340
- float: right;
341
- width: 60px;
342
- }
343
-
344
- .amount-placeholder>span {
345
- line-height: 34px;
346
- }
347
-
348
- .top-amnt {
349
- display: flex;
350
- margin-bottom: 10px;
351
- align-items: center;
352
- justify-content: space-between;
353
- }
354
-
355
- .amtleft {
356
- text-align: center;
357
- }
358
-
359
- .amtleft span {
360
- color: #35254D;
361
- margin: 0 -5px;
362
- }
363
-
364
- .card-row {
365
- text-align: right;
366
- margin: 8px 0 0 0;
367
- max-width: 85px;
368
- line-height: 20px;
369
- }
370
-
371
- .yer {
372
- border-radius: 0;
373
- }
374
-
375
- .card-row span {
376
- width: 33px;
377
- height: 21px;
378
- margin: 0 2px;
379
- background-repeat: no-repeat;
380
- display: inline-block;
381
- background-size: contain;
382
- }
383
-
384
- .card-image {
385
- background-repeat: no-repeat;
386
- padding-right: 50px;
387
- background-position: right 2px center;
388
- background-size: auto 90%
389
- }
390
-
391
- /* .cvc-preview-container {
392
- overflow: hidden;
393
- } */
394
-
395
- .cvc-preview-container {
396
- /* overflow: hidden; */
397
- position: absolute;
398
- z-index: 9999;
399
- right: -71px;
400
- top: -54px;
401
- width: 165px;
402
- border-radius: 5px;
403
- padding: 5px;
404
- background-color: rgb(0, 0, 0, 0.3);
405
- display: none;
406
- }
407
-
408
- .cvc-preview-container:before {
409
- position: absolute;
410
- left: 50%;
411
- transform: translate(-50%);
412
- bottom: -5px;
413
- width: 0;
414
- height: 0;
415
- border-left: 5px solid transparent;
416
- border-right: 5px solid transparent;
417
- border-top: 5px solid #000;
418
- opacity: 0.3;
419
- content: '';
420
- }
421
-
422
- .security-code-group #cvc:hover .cvc-preview-container {
423
- display: block;
424
- }
425
-
426
- .cvc-preview-container.two-card div {
427
- width: 50%;
428
- height: 45px;
429
- }
430
-
431
- .cvc-preview-container.two-card div.amex-cvc-preview {
432
- float: right;
433
- }
434
-
435
- .cvc-preview-container.two-card div.visa-mc-dis-cvc-preview {
436
- float: left;
437
- }
438
-
439
- /* .cvc-preview-container div {
440
- height: 160px;
441
- } */
442
-
443
- .amex-cvc-preview {
444
- background: url("") center center/contain no-repeat;
445
- }
446
-
447
- .visa-mc-dis-cvc-preview {
448
- background: url("") center center/contain no-repeat;
449
- }
450
-
451
- .submit-button-lock {
452
- height: 15px;
453
- margin-top: -2px;
454
- margin-right: 7px;
455
- vertical-align: middle;
456
- background: url("") center center/contain no-repeat;
457
- width: 14px;
458
- display: inline-block;
459
- }
460
-
461
- .align-middle {
462
- vertical-align: middle;
463
- }
464
-
465
- input {
466
- box-shadow: none !important;
467
- }
468
-
469
- .powerd-by-part {
470
- display: flex;
471
- font-size: 12px;
472
- text-align: center;
473
- align-items: center;
474
- justify-content: center;
475
- margin: 8px 0 20px 0;
476
- }
477
-
478
- .powered-logo {
479
- width: 18px;
480
- height: 18px;
481
- float: right;
482
- padding: 2px;
483
- background: #000000;
484
- border-radius: 4px;
485
- margin-left: 5px;
486
- }
487
-
488
- .comp-name {
489
- display: block;
490
- margin-bottom: 8px;
491
- }
492
-
493
- .client-logo {
494
- max-width: 140px;
495
- display: block;
496
- margin: auto;
497
- padding: 5px;
498
- }
499
-
500
- #qrCode {
501
- text-align: center;
502
- }
503
-
504
- #qrIcon {
505
- cursor: pointer;
506
- border: 1px solid rgb(252, 252, 252);
507
- padding: 10px;
508
- border-radius: 5px;
509
- background: #ffffff;
510
- }
511
-
512
- #target {
513
- display: none;
514
- text-align: center;
515
- transition: all 5s;
516
- padding: 5px;
517
- transition: max-height 0.5s, overflow 0.5s 0.5s;
518
- }
519
-
520
- /* input:focus {
521
- border-color: #acc6db !important;
522
- background-color: #acc6db !important;
523
- } */
524
-
525
-
526
-
527
-
528
-
529
-
530
-
531
- .payment-success {
532
- border-radius: 24px;
533
- padding: 160px 24px;
534
- text-align: center;
535
- background: linear-gradient(white, white) padding-box,
536
- linear-gradient(to bottom, #B0E2CC, #DBFCEE) border-box;
537
- border-radius: 24px;
538
- border: 1px solid transparent;
539
-
540
- }
541
-
542
- .payment-icon {
543
- width: 60px;
544
- height: 60px;
545
- border-radius: 180px;
546
- border: #61C699 1px solid;
547
- margin: 0 auto 15px auto;
548
- display: flex;
549
- align-items: center;
550
- justify-content: center;
79
+ backdrop-filter: blur(.5px);
80
+ /* Blur effect */
81
+ z-index: 9999;
82
+ /* Ensure it's on top of other elements */
83
+ }
84
+
85
+ .lds-ellipsis {
86
+ display: inline-block;
87
+ position: relative;
88
+ width: 80px;
89
+ height: 80px;
90
+ }
91
+
92
+ .lds-ellipsis div {
93
+ position: absolute;
94
+ top: 33px;
95
+ width: 13px;
96
+ height: 13px;
97
+ border-radius: 50%;
98
+ background: #000;
99
+ animation-timing-function: cubic-bezier(0, 1, 1, 0);
100
+ }
101
+
102
+ .lds-ellipsis div:nth-child(1) {
103
+ left: 8px;
104
+ animation: lds-ellipsis1 0.6s infinite;
105
+ }
106
+
107
+ .lds-ellipsis div:nth-child(2) {
108
+ left: 8px;
109
+ animation: lds-ellipsis2 0.6s infinite;
110
+ }
111
+
112
+ .lds-ellipsis div:nth-child(3) {
113
+ left: 32px;
114
+ animation: lds-ellipsis2 0.6s infinite;
115
+ }
116
+
117
+ .lds-ellipsis div:nth-child(4) {
118
+ left: 56px;
119
+ animation: lds-ellipsis3 0.6s infinite;
120
+ }
121
+
122
+ @keyframes lds-ellipsis1 {
123
+ 0% {
124
+ transform: scale(0);
551
125
  }
552
-
553
- .payment-success h2 {
554
- font-size: 24px;
555
- color: #35254D;
556
- line-height: 25px;
126
+
127
+ 100% {
128
+ transform: scale(1);
557
129
  }
558
-
559
- .payment-success p {
560
- font-size: 14px;
561
- color: #9A92A6;
562
- line-height: 15px;
130
+ }
131
+
132
+ @keyframes lds-ellipsis2 {
133
+ 0% {
134
+ transform: translate(0, 0);
563
135
  }
564
-
565
-
566
- .bg-light {
567
- background: #fff !important;
136
+
137
+ 100% {
138
+ transform: translate(24px, 0);
568
139
  }
569
-
570
- /* body {
571
- overflow: hidden !important;
572
- background: #fff !important;
573
- } */
574
-
575
- .app-pagination .page-item .page-link {
576
- color: #2e2f2f;
140
+ }
141
+
142
+ @keyframes lds-ellipsis3 {
143
+ 0% {
144
+ transform: scale(1);
577
145
  }
578
-
579
- .app-pagination .page-item.active .page-link {
580
- background-color: #a9aeb3;
581
- border-color: #ddd;
582
- color: #2e2f2f;
146
+
147
+ 100% {
148
+ transform: scale(0);
583
149
  }
584
-
585
- .app-pagination .page-item.disabled .page-link {
586
- color: #2e2f2f;
150
+ }
151
+ `);
152
+ };
153
+ var LoaderStyle_default = LoaderStyle;
154
+
155
+ // src/app/components/Loader/Loader.tsx
156
+ var Loader = (props) => {
157
+ return /* @__PURE__ */ import_react2.default.createElement(import_react2.default.Fragment, null, /* @__PURE__ */ import_react2.default.createElement(LoaderStyle_default, null), (props == null ? void 0 : props.loading) && /* @__PURE__ */ import_react2.default.createElement("div", { className: "loader" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "lds-ellipsis" }, /* @__PURE__ */ import_react2.default.createElement("div", null), /* @__PURE__ */ import_react2.default.createElement("div", null), /* @__PURE__ */ import_react2.default.createElement("div", null), /* @__PURE__ */ import_react2.default.createElement("div", null))));
158
+ };
159
+ var Loader_default = Loader;
160
+
161
+ // src/app/components/RequestPayment/RequestPayment.tsx
162
+ var import_react_bootstrap = require("react-bootstrap");
163
+
164
+ // src/app/components/RequestPayment/RequestPaymentstyles.tsx
165
+ var import_react3 = __toESM(require("react"), 1);
166
+ var RequestPaymentstyles = (props) => {
167
+ return /* @__PURE__ */ import_react3.default.createElement("style", null, `
168
+ .paymentBtn {
169
+ background-color: black;
170
+ border: none;
171
+ color: white;
172
+ padding: 15px 32px;
173
+ text-align: center;
174
+ text-decoration: none;
175
+ display: inline-block;
176
+ font-size: 16px;
177
+ margin: 4px 2px;
178
+ cursor: pointer;
179
+ border-radius: 180px;
180
+ /* width: auto; */
181
+ }
182
+ .modal-backdrop {
183
+ display: none !important;
184
+ }
185
+ /* CSS for modal */
186
+ .modal {
187
+ /* display: none; */
188
+ position: fixed;
189
+ z-index: 5555;
190
+ left: 0;
191
+ top: 0;
192
+ width: 100%;
193
+ height: 100%;
194
+ overflow: auto;
195
+ background-color: rgba(0, 0, 0, 0.4);
196
+ }
197
+
198
+ .input-container {
199
+ position: relative;
200
+ }
201
+ .error {
202
+ border: 1px solid red;
203
+ background-color: #ffe6e6; /* light red background color */
204
+ }
205
+ .form-group {
206
+ margin-bottom: 15px;
207
+ }
208
+ .input-container input {
209
+ padding-right: 25px;
210
+ }
211
+
212
+ .modal-header {
213
+ border-bottom: 0 !important;
214
+ padding-top: 0 !important;
215
+ }
216
+
217
+ /* CSS for modal content */
218
+ .modal-content {
219
+ /* height: 90vh !important; */
220
+ height: auto;
221
+ padding: 20px 5px;
222
+ /* background: #fff; */
223
+ border-radius: 20px !important;
224
+ position: relative;
225
+ width: 430px;
226
+ margin: 30px auto;
227
+ overflow: inherit !important;
228
+ }
229
+ .input-container {
230
+ display: flex;
231
+ align-items: baseline;
232
+ }
233
+
234
+ .input-error-container {
235
+ flex: 1;
236
+ }
237
+
238
+ .paymentBtn {
239
+ margin-left: 10px;
240
+ }
241
+
242
+ .PayButton {
243
+ outline: 0 !important;
244
+ height: 46px;
245
+ font-size: 16px;
246
+ background-color: #161616 !important;
247
+ border: none;
248
+ display: block;
249
+ width: 100%;
250
+ border-radius: 180px;
251
+ margin: 10px 0;
252
+ }
253
+
254
+ #PayButton:hover {
255
+ background-color: #61c699 !important;
256
+ }
257
+
258
+ #PayButton:active {
259
+ background-color: #61c699 !important;
260
+ }
261
+
262
+ #PayButton:disabled {
263
+ background: rgb(172, 44, 170) !important;
264
+ color: #fff !important;
265
+ }
266
+
267
+ label {
268
+ color: rgba(53, 37, 77, 0.6);
269
+ margin-bottom: 2px;
270
+ text-transform: uppercase;
271
+ font-family: "IBM Plex Mono", monospace;
272
+ font-weight: 500;
273
+ font-size: 12px;
274
+ }
275
+
276
+ .input-container {
277
+ position: relative;
278
+ }
279
+
280
+ .input-container input {
281
+ padding-right: 25px;
282
+ }
283
+
284
+ #Checkout {
285
+ /* z-index: 100001; */
286
+ width: 100%;
287
+ /* height: 100%; */
288
+ /* background: 0 0 #ffffff; */
289
+ border-radius: 24px;
290
+ border: 1px solid #e0dfe2;
291
+ display: block;
292
+ }
293
+
294
+ .container {
295
+ margin-top: 10px;
296
+ }
297
+
298
+ .powered-logo {
299
+ width: 18px;
300
+ height: 18px;
301
+ /* float: right; */
302
+ padding: 2px;
303
+ background: #000000;
304
+ border-radius: 4px;
305
+ /* margin-left: 5px; */
306
+ }
307
+
308
+ .modal-content .container {
309
+ width: 100%;
310
+ }
311
+
312
+ .powerd-by-part {
313
+ display: flex;
314
+ justify-content: center;
315
+ align-items: center;
316
+ gap: 5px;
317
+ }
318
+
319
+ .errorText {
320
+ color: red;
321
+ }
322
+
323
+ .input-group {
324
+ position: relative;
325
+ }
326
+
327
+ .paynowbtn {
328
+ outline: 0 !important;
329
+ padding: 7px 25px !important;
330
+ font-size: 13px;
331
+ background-color: #161616 !important;
332
+ border: #161616 1px solid !important;
333
+ color: #fff !important;
334
+ display: inline-block !important;
335
+ border-radius: 180px !important;
336
+ }
337
+
338
+ .paynowbtn:hover {
339
+ background-color: #fff !important;
340
+ border: #161616 1px solid !important;
341
+ color: #161616 !important;
342
+ }
343
+
344
+ .ButtonGroup__root.btn-group {
345
+ margin: 10px 0 20px 0;
346
+ }
347
+
348
+ .ButtonGroup__root.btn-group button {
349
+ background: #000;
350
+ border: 0;
351
+ margin: 0 5px;
352
+ border-radius: 4px !important;
353
+ }
354
+
355
+ .ButtonGroup__root.btn-group button:hover,
356
+ .ButtonGroup__root.btn-group button:focus {
357
+ background: #333 !important;
358
+ }
359
+
360
+ .input-group button {
361
+ background: #000;
362
+ border: 0;
363
+ margin: 0 5px;
364
+ border-radius: 0 4px 4px 0 !important;
365
+ }
366
+
367
+ .input-group button:hover,
368
+ .input-group button:focus {
369
+ background: #333 !important;
370
+ }
371
+
372
+ .payment-suc {
373
+ text-align: center;
374
+ }
375
+
376
+ .payment-suc .modal-dialog {
377
+ min-width: 600px;
378
+ padding: 50px 0;
379
+ }
380
+
381
+ .payment-suc h2 {
382
+ font-size: 24px;
383
+ color: #35254d;
384
+ font-weight: 500;
385
+ padding: 15px 0;
386
+ }
387
+
388
+ .payment-suc p {
389
+ font-size: 14px;
390
+ color: #9a92a6;
391
+ font-weight: 500;
392
+ }
393
+
394
+ .payment-suc .btn-close {
395
+ position: absolute;
396
+ right: 20px;
397
+ }
398
+
399
+ .Checkout.container iframe {
400
+ width: 100%;
401
+ overflow: hidden !important;
402
+ }
403
+
404
+ .responsive-tbl {
405
+ overflow-x: auto;
406
+ }
407
+ body {
408
+ position: relative !important;
409
+ }
410
+ thead,
411
+ tbody,
412
+ tfoot,
413
+ tr,
414
+ td,
415
+ th {
416
+ white-space: nowrap;
417
+ }
418
+
419
+ .button-group {
420
+ display: flex;
421
+ gap: 10px;
422
+ }
423
+ .rqstonClickbtn {
424
+ color: #fff;
425
+ background-color: #337ab7;
426
+ border-color: #2e6da4;
427
+ }
428
+ .loading-animation {
429
+ position: absolute;
430
+ top: 50%;
431
+ left: 50%;
432
+ transform: translate(-50%, -50%);
433
+ }
434
+
435
+ .spinner {
436
+ width: 40px;
437
+ height: 40px;
438
+ border-radius: 50%;
439
+ border: 4px solid #f3f3f3;
440
+ border-top: 4px solid black;
441
+ animation: spin 1s linear infinite;
442
+ }
443
+
444
+ @keyframes spin {
445
+ 0% {
446
+ transform: rotate(0deg);
587
447
  }
588
-
589
- .app-pagination .page-item .page-link:hover {
590
- text-decoration: none;
591
- color: #2e2f2f;
448
+ 100% {
449
+ transform: rotate(360deg);
592
450
  }
593
-
594
- .loader {
595
- position: fixed;
596
- /* Fixed position to cover the viewport */
597
- top: 0;
598
- left: 0;
599
- width: 100%;
600
- height: 100%;
451
+ }
452
+ /* .border-container {
601
453
  display: flex;
602
- justify-content: center;
603
- align-items: center;
604
- /* background: rgba(255, 255, 0, 0.01); Adjust the blur effect */
605
- background-color: rgba(255, 255, 255, 0.521);
606
- /* Semi-transparent black background */
607
-
608
- backdrop-filter: blur(.5px);
609
- /* Blur effect */
610
- z-index: 9999;
611
- /* Ensure it's on top of other elements */
612
- }
613
-
614
- .lds-ellipsis {
615
- display: inline-block;
616
- position: relative;
617
- width: 80px;
618
- height: 80px;
619
- }
620
-
621
- .lds-ellipsis div {
622
- position: absolute;
623
- top: 33px;
624
- width: 13px;
625
- height: 13px;
626
- border-radius: 50%;
627
- background: #000;
628
- animation-timing-function: cubic-bezier(0, 1, 1, 0);
629
- }
630
-
631
- .lds-ellipsis div:nth-child(1) {
632
- left: 8px;
633
- animation: lds-ellipsis1 0.6s infinite;
634
- }
635
-
636
- .lds-ellipsis div:nth-child(2) {
637
- left: 8px;
638
- animation: lds-ellipsis2 0.6s infinite;
639
- }
640
-
641
- .lds-ellipsis div:nth-child(3) {
642
- left: 32px;
643
- animation: lds-ellipsis2 0.6s infinite;
644
- }
645
-
646
- .lds-ellipsis div:nth-child(4) {
647
- left: 56px;
648
- animation: lds-ellipsis3 0.6s infinite;
649
- }
650
-
651
- @keyframes lds-ellipsis1 {
652
- 0% {
653
- transform: scale(0);
654
- }
655
-
656
- 100% {
657
- transform: scale(1);
658
- }
659
- }
660
-
661
- @keyframes lds-ellipsis2 {
662
- 0% {
663
- transform: translate(0, 0);
664
- }
665
-
666
- 100% {
667
- transform: translate(24px, 0);
668
- }
669
- }
670
-
671
- @keyframes lds-ellipsis3 {
672
- 0% {
673
- transform: scale(1);
674
- }
675
-
676
- 100% {
677
- transform: scale(0);
678
- }
679
- }
680
-
681
- .requestPayment {
682
- max-width: 420px;
683
- }
684
-
685
- .paymentBtn {
686
- background-color: black;
687
- border: none;
688
- color: white;
689
- padding: 15px 32px;
690
- text-align: center;
691
- text-decoration: none;
692
- display: inline-block;
693
- font-size: 16px;
694
- margin: 4px 2px;
695
- border-radius: 180px;
696
- }
697
-
698
- .PayButton {
699
- outline: 0 !important;
700
- height: 46px;
701
- background-color: #161616 !important;
702
- width: 100%;
703
- color: #fff;
704
- margin: 10px 0;
705
- }
706
-
707
-
708
-
709
-
710
-
711
- .requpay-main{
712
- max-width: 400px;
713
- width: 100%;
714
- height: auto;
715
- padding: 20px;
716
- border-radius: 20px !important;
717
- position: relative;
718
- margin: 30px auto;
719
- }
720
- .requpay-main h3{
721
- font-size: 20px;
722
- padding-left: 10px;
454
+ flex-direction: column;
455
+ border: 0px solid #ccc;
456
+ padding: 20px;
457
+ border-radius: 10px;
458
+ box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
459
+ align-items: baseline;
723
460
  }
724
- .requpay-in{
725
- width: 100%;
726
- background: 0 0 #ffffff;
727
- border-radius: 24px;
728
- border: 1px solid #e0dfe2;
461
+ .payment-container {
462
+ border: 0px solid #ccc;
729
463
  padding: 20px;
464
+ border-radius: 10px;
465
+ box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
466
+ } */
467
+
468
+ .payment-row {
469
+ display: flex;
470
+ align-items: center;
471
+ margin-bottom: 20px;
472
+ }
473
+
474
+ .payment-row label {
475
+ width: 150px;
476
+ font-weight: bold;
477
+ margin-right: 10px;
478
+ }
479
+
480
+ .payment-row input {
481
+ flex-grow: 1;
482
+ margin-right: 10px;
483
+ }
484
+
485
+ .payment-row button {
486
+ flex-grow: 1;
487
+ }
488
+ .payment-row {
489
+ display: flex;
490
+ flex-direction: column;
491
+ border-radius: 10px;
492
+ margin-top: 10px;
493
+ }
494
+
495
+ .input-wrapper {
496
+ flex: 1;
497
+ }
498
+
499
+ .button-wrapper {
500
+ margin-left: 10px;
501
+ }
502
+ .input-container {
503
+ display: flex;
504
+ flex-direction: column;
505
+ }
506
+
507
+ .export-btn1 {
508
+ background: black;
509
+ color: white;
510
+ height: 35px;
511
+ width: 68px;
512
+ border-radius: 5px;
513
+ margin-top: 20px;
514
+ }
515
+
516
+ .export-btn {
517
+ background: black;
518
+ color: white;
519
+ height: 35px;
520
+ width: 68px;
521
+ border-radius: 5px;
522
+ margin-left: 14px;
523
+ }
524
+
525
+ .payment-popup {
526
+ padding: 12px 20px;
527
+ background: #fff;
528
+ border-radius: 20px;
529
+ position: relative;
530
+ width: 100%;
531
+ margin: 0 auto;
532
+ }
533
+
534
+ .modal-content {
535
+ max-width: 420px;
536
+ margin-top: 5%;
537
+ }
538
+ @media (max-width: 460px) {
539
+ .payment-popup {
540
+ padding: 35px 25px;
541
+ width: 98%;
730
542
  }
731
-
732
- .requpay-in .mb-1{
543
+ }
544
+
545
+ .close-pop {
546
+ position: absolute;
547
+ right: 8px;
548
+ top: 8px;
549
+ border: 0;
550
+ padding: 0;
551
+ background: none !important;
552
+ }
553
+
554
+ .amex {
555
+ background-image: url("../amex.svg");
556
+ }
557
+
558
+ .visa {
559
+ background-image: url("../visa.svg");
560
+ }
561
+
562
+ .mastercard {
563
+ background-image: url("../mastercard.svg");
564
+ }
565
+
566
+ .discover {
567
+ background-image: url("../discover.svg");
568
+ }
569
+
570
+ .expiry-date-group {
571
+ float: left;
572
+ width: 30%;
573
+ }
574
+
575
+ .expiry-date-group input {
576
+ width: calc(100% + 1px);
577
+ border-top-right-radius: 0;
578
+ border-bottom-right-radius: 0;
579
+ }
580
+
581
+ .expiry-date-group input:focus {
582
+ position: relative;
583
+ z-index: 10;
584
+ }
585
+
586
+ .security-code-group {
587
+ float: right;
588
+ width: 40%;
589
+ position: relative;
590
+ }
591
+
592
+ .security-code-group input {
593
+ border-top-left-radius: 0;
594
+ border-bottom-left-radius: 0;
595
+ }
596
+
597
+ .zip-code-group {
598
+ clear: both;
599
+ }
600
+
601
+ #submitButton {
602
+ outline: 0 !important;
603
+ height: 46px;
604
+ font-size: 16px;
605
+ background-color: #161616 !important;
606
+ border: none;
607
+ display: block;
608
+ width: 100%;
609
+ border-radius: 180px;
610
+ }
611
+ #submitRequestButton {
612
+ outline: 0 !important;
613
+ height: 46px;
614
+ font-size: 16px;
615
+ background-color: #161616 !important;
616
+ border: none;
617
+ display: block;
618
+ width: 100%;
619
+ border-radius: 180px;
620
+ }
621
+ #PayButton {
622
+ outline: 0 !important;
623
+ height: 46px;
624
+ font-size: 16px;
625
+ background-color: #161616 !important;
626
+ border: none;
627
+ display: block;
628
+ width: 100%;
629
+ border-radius: 180px;
630
+ }
631
+
632
+ #PayButton:hover {
633
+ background-color: #61c699 !important;
634
+ }
635
+
636
+ #PayButton:active {
637
+ background-color: #61c699 !important;
638
+ }
639
+
640
+ #PayButton:disabled {
641
+ background: rgb(172, 44, 170) !important;
642
+ color: #fff !important;
643
+ }
644
+
645
+ .form-control {
646
+ color: #35254d;
647
+ }
648
+
649
+ .container {
650
+ margin-top: 10px;
651
+ }
652
+
653
+ #Checkout {
654
+ z-index: 100001;
655
+ width: 100%;
656
+ height: 100%;
657
+ min-height: 100%;
658
+ background: 0 0 #ffffff;
659
+ border-radius: 24px;
660
+ border: 1px solid #e0dfe2;
661
+ margin-left: auto;
662
+ margin-right: auto;
663
+ display: block;
664
+ }
665
+
666
+ #Checkout .header {
667
+ display: flex;
668
+ /* Enables Flexbox */
669
+ justify-content: center;
670
+ /* Centers content horizontally */
671
+ align-items: center;
672
+ /* Centers content vertically */
673
+ text-align: center;
674
+ padding: 8px;
675
+ border-bottom: 1px solid #dedede;
676
+ margin: 0 10px 20px 10px;
677
+ }
678
+
679
+ #Checkout .header button {
680
+ border: 0;
681
+ background: none;
682
+ padding: 0;
683
+ }
684
+
685
+ #Checkout h1 {
686
+ margin: 0;
687
+ flex: 1;
688
+ padding: 10px;
689
+ /* Allows the title to grow and fill the space for centering */
690
+ font-size: 23px;
691
+ font-weight: 500;
692
+ color: #35254d;
693
+ align-items: start;
694
+ display: flex;
695
+ }
696
+
697
+ #Checkout > form {
698
+ margin: 0 25px 10px 25px;
699
+ }
700
+
701
+ label {
702
+ color: rgba(53, 37, 77, 0.6);
703
+ margin-bottom: 2px;
704
+ text-transform: uppercase;
705
+ font-family: "IBM Plex Mono", monospace;
706
+ font-weight: 500;
707
+ font-size: 12px;
708
+ }
709
+
710
+ .input-container {
711
+ position: relative;
712
+ }
713
+
714
+ .input-container input {
715
+ padding-right: 25px;
716
+ }
717
+
718
+ #zipcode {
719
+ text-transform: capitalize !important;
720
+ }
721
+
722
+ #zipcode {
723
+ width: 18px;
724
+ position: absolute;
725
+ right: 8px;
726
+ top: 9px;
727
+ }
728
+
729
+ #zipcode .zip-tip {
730
+ display: none;
731
+ background-color: rgb(0, 0, 0, 0.4);
732
+ padding: 5px 8px;
733
+ border-radius: 6px;
734
+ position: absolute;
735
+ right: 26px;
736
+ top: -9px;
737
+ font-size: 12.5px;
738
+ text-transform: capitalize !important;
739
+ color: #fff;
740
+ width: 240px;
741
+ line-height: 16px;
742
+ }
743
+
744
+ #zipcode .zip-tip:before {
745
+ width: 0;
746
+ height: 0;
747
+ border-top: 7px solid transparent;
748
+ border-bottom: 7px solid transparent;
749
+ border-left: 7px solid #000;
750
+ opacity: 0.4;
751
+ position: absolute;
752
+ right: -7px;
753
+ top: 50%;
754
+ transform: translateY(-50%);
755
+ content: "";
756
+ }
757
+
758
+ #zipcode:hover .zip-tip {
759
+ display: block;
760
+ }
761
+
762
+ .input-container > i,
763
+ a[role="button"] {
764
+ color: #d3d3d3;
765
+ width: 25px;
766
+ height: 30px;
767
+ line-height: 30px;
768
+ font-size: 16px;
769
+ position: absolute;
770
+ top: 5px;
771
+ right: 6px;
772
+ cursor: pointer;
773
+ text-align: center;
774
+ }
775
+
776
+ .input-container > i:hover,
777
+ a[role="button"]:hover {
778
+ color: #777;
779
+ }
780
+
781
+ .amount-placeholder {
782
+ white-space: nowrap;
783
+ font-size: 44px;
784
+ /* height: 35px; */
785
+ font-weight: 600;
786
+ line-height: 40px;
787
+ }
788
+
789
+ .amount-placeholder > button {
790
+ float: right;
791
+ width: 60px;
792
+ }
793
+
794
+ .amount-placeholder > span {
795
+ line-height: 34px;
796
+ }
797
+
798
+ .top-amnt {
799
+ display: flex;
733
800
  margin-bottom: 10px;
734
- }
735
-
736
- .requpay-in .pay-amount {
737
- position: relative;
738
- }
739
- .requpay-in .pay-amount input{padding-left: 20px;}
740
- .requpay-in .pay-amount .dlr-sign {
741
- position: absolute;
742
- left: 10px;
743
- top: 7px;
744
- }
745
- .requpay-in .PayButton {
746
- border-radius: 4px;
747
- border:0;
748
- height: 43px;
749
- }
801
+ align-items: center;
802
+ justify-content: space-between;
803
+ }
804
+
805
+ .amtleft {
806
+ text-align: center;
807
+ }
808
+
809
+ .amtleft span {
810
+ color: #35254d;
811
+ margin: 0 -5px;
812
+ }
813
+
814
+ .card-row {
815
+ text-align: right;
816
+ margin: 22px 0 0 0;
817
+ max-width: 85px;
818
+ line-height: 20px;
819
+ }
820
+
821
+ .yer {
822
+ border-radius: 0;
823
+ }
824
+
825
+ .card-row span {
826
+ width: 33px;
827
+ height: 21px;
828
+ margin: 0 2px;
829
+ background-repeat: no-repeat;
830
+ display: inline-block;
831
+ background-size: contain;
832
+ }
833
+
834
+ .card-image {
835
+ background-repeat: no-repeat;
836
+ padding-right: 50px;
837
+ background-position: right 2px center;
838
+ background-size: auto 90%;
839
+ }
840
+
841
+ /* .cvc-preview-container {
842
+ overflow: hidden;
843
+ } */
844
+
845
+ .cvc-preview-container {
846
+ /* overflow: hidden; */
847
+ position: absolute;
848
+ z-index: 9999;
849
+ right: -71px;
850
+ top: -54px;
851
+ width: 165px;
852
+ border-radius: 5px;
853
+ padding: 5px;
854
+ background-color: rgb(0, 0, 0, 0.3);
855
+ display: none;
856
+ }
857
+
858
+ .cvc-preview-container:before {
859
+ position: absolute;
860
+ left: 50%;
861
+ transform: translate(-50%);
862
+ bottom: -5px;
863
+ width: 0;
864
+ height: 0;
865
+ border-left: 5px solid transparent;
866
+ border-right: 5px solid transparent;
867
+ border-top: 5px solid #000;
868
+ opacity: 0.3;
869
+ content: "";
870
+ }
871
+
872
+ .security-code-group #cvc:hover .cvc-preview-container {
873
+ display: block;
874
+ }
875
+
876
+ .cvc-preview-container.two-card div {
877
+ width: 50%;
878
+ height: 45px;
879
+ }
880
+
881
+ .cvc-preview-container.two-card div.amex-cvc-preview {
882
+ float: right;
883
+ }
884
+
885
+ .cvc-preview-container.two-card div.visa-mc-dis-cvc-preview {
886
+ float: left;
887
+ }
888
+
889
+ /* .cvc-preview-container div {
890
+ height: 160px;
891
+ } */
892
+
893
+ .amex-cvc-preview {
894
+ background: url("")
895
+ center center/contain no-repeat;
896
+ }
897
+
898
+ .visa-mc-dis-cvc-preview {
899
+ background: url("")
900
+ center center/contain no-repeat;
901
+ }
902
+
903
+ .submit-button-lock {
904
+ height: 15px;
905
+ margin-top: -2px;
906
+ margin-right: 7px;
907
+ vertical-align: middle;
908
+ background: url("")
909
+ center center/contain no-repeat;
910
+ width: 14px;
911
+ display: inline-block;
912
+ }
913
+
914
+ .align-middle {
915
+ vertical-align: middle;
916
+ }
917
+
918
+ input {
919
+ box-shadow: none !important;
920
+ }
921
+
922
+ .powerd-by-part {
923
+ display: flex;
924
+ font-size: 12px;
925
+ text-align: center;
926
+ align-items: center;
927
+ justify-content: center;
928
+ margin: 5px 0 20px 0;
929
+ }
930
+
931
+ .powered-logo {
932
+ width: 18px;
933
+ height: auto;
934
+ float: right;
935
+ padding: 2px;
936
+ background: #000000;
937
+ border-radius: 4px;
938
+ margin-left: 5px;
939
+ }
940
+
941
+ .comp-name {
942
+ display: block;
943
+ margin-bottom: 8px;
944
+ }
945
+
946
+ .client-logo {
947
+ max-width: 140px;
948
+ display: block;
949
+ margin: auto;
950
+ padding: 5px;
951
+ }
952
+
953
+ #qrCode {
954
+ text-align: center;
955
+ }
956
+
957
+ #qrIcon {
958
+ cursor: pointer;
959
+ border: 1px solid rgb(252, 252, 252);
960
+ padding: 10px;
961
+ border-radius: 5px;
962
+ background: #ffffff;
963
+ }
964
+
965
+ #target {
966
+ display: none;
967
+ text-align: center;
968
+ transition: all 5s;
969
+ padding: 5px;
970
+ transition: max-height 0.5s, overflow 0.5s 0.5s;
971
+ }
972
+
973
+ /* input:focus {
974
+ border-color: #acc6db !important;
975
+ background-color: #acc6db !important;
976
+ } */
977
+
750
978
  `);
751
979
  };
980
+ var RequestPaymentstyles_default = RequestPaymentstyles;
752
981
 
753
- // src/app/components/Greet.tsx
754
- function PaywithFractal({ name, amount, orderId, fractalPayClientKey }) {
755
- const baseUrl = "http://192.168.1.52:8082/";
982
+ // src/app/components/RequestPayment/RequestPayment.tsx
983
+ var RequestPayment = (props) => {
984
+ const fractalpayClientKey = props.fractalpayClientKey;
985
+ const baseUrl = "http://192.168.1.64:8082/";
756
986
  const masterBaseUrl = "http://192.168.1.52:8081/";
757
- console.log(name, "name", window == null ? void 0 : window.DatacapWebToken);
758
- const [dcToken, setDcToken] = (0, import_react2.useState)("");
759
- const [error, setError] = (0, import_react2.useState)({});
760
- const [toggleQr, setToggleQr] = (0, import_react2.useState)(false);
761
- const [formData, setFormData] = (0, import_react2.useState)({
762
- name: "John Doe",
763
- card_number: "4761 7310 0000 0043",
764
- exp_month: "12",
765
- exp_year: "2024",
766
- cvv: "201",
767
- zip: ""
987
+ const [show, setShow] = (0, import_react4.useState)(false);
988
+ const [loading, setLoading] = (0, import_react4.useState)(false);
989
+ const [errors, setErrors] = (0, import_react4.useState)({});
990
+ const [requestDetails, setRequestDetails] = (0, import_react4.useState)({
991
+ email: "",
992
+ amount: "",
993
+ phone_number: "",
994
+ order_id: "",
995
+ name: "",
996
+ fractalpayPublicKey: fractalpayClientKey
768
997
  });
769
- const [loading, setLoading] = (0, import_react2.useState)(false);
770
- const [show, setShow] = (0, import_react2.useState)(false);
771
- const handleSubmit = async (e) => {
772
- var _a, _b, _c, _d, _e, _f, _g;
773
- e.preventDefault();
774
- const data = {
775
- description: "widget payment",
776
- amount: amount || "1.00",
777
- phone_number: "1234567908",
778
- zip: formData.zip,
779
- orderId: orderId || "",
780
- fractalpayPublicKey: fractalPayClientKey
998
+ const [showConfirmationModal, setShowConfirmationModal] = (0, import_react4.useState)(false);
999
+ const phoneNumberRegex = (value) => /^\(?\d{3}\)?[-.\s]?\d{3}[-.\s]?\d{4}$/.test(value);
1000
+ const amountRegex = /[+-]?([0-9]*[.])?[0-9]+/;
1001
+ const isValidEmail = (value) => /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(value);
1002
+ const isAlpha = (value) => /^[A-Za-z\s]*$/.test(value);
1003
+ const handleClose = () => {
1004
+ setShow(false);
1005
+ emptyFields();
1006
+ setErrors({});
1007
+ };
1008
+ const handleShow = () => setShow(true);
1009
+ const handleCloseConfirmationModal = () => setShowConfirmationModal(false);
1010
+ const emptyFields = () => {
1011
+ setRequestDetails({
1012
+ email: "",
1013
+ amount: "",
1014
+ phone_number: "",
1015
+ order_id: "",
1016
+ name: "",
1017
+ fractalpayPublicKey: fractalpayClientKey
1018
+ });
1019
+ };
1020
+ const handleSubmit = (event) => {
1021
+ const message = {
1022
+ type: "preview.compiledcheck",
1023
+ other: __spreadProps(__spreadValues({}, event), { status: true })
781
1024
  };
782
- if (Object.keys(error).length < 1) {
783
- try {
784
- setLoading(true);
785
- const res = await import_axios.default.post(`${baseUrl}create-widget-order`, data, {
786
- headers: {
787
- "Content-Type": "application/json"
788
- }
789
- });
790
- if (res.data && ((_a = res.data) == null ? void 0 : _a.result)) {
791
- console.log("token", (_b = res.data) == null ? void 0 : _b.data);
792
- setDcToken((_d = (_c = res.data) == null ? void 0 : _c.data) == null ? void 0 : _d.dctoken);
793
- const tokenCallback = async (response) => {
794
- var _a2, _b2, _c2;
795
- console.log("response for token call back", response);
796
- if (response.Error) {
797
- alert("if");
798
- console.log("Error: ", response);
799
- setLoading(false);
800
- } else {
801
- const headers = {
802
- "Content-Type": "application/x-www-form-urlencoded"
803
- };
804
- const quickData = __spreadValues({
805
- name: formData.name,
806
- postal_code: formData.zip
807
- }, response);
808
- try {
809
- const resp = await import_axios.default.post(`${masterBaseUrl}quick-pay/${(_b2 = (_a2 = res.data) == null ? void 0 : _a2.data) == null ? void 0 : _b2.posSalesIdEncode}`, quickData, {
810
- headers
811
- });
812
- setLoading(false);
813
- console.log("quick response", resp);
814
- if (((_c2 = resp == null ? void 0 : resp.data) == null ? void 0 : _c2.result) && (resp == null ? void 0 : resp.status) === 200) {
815
- console.log("Payment success!", resp == null ? void 0 : resp.data);
816
- setFormData({
817
- name: "John Doe",
818
- card_number: "4761 7310 0000 0043",
819
- exp_month: "12",
820
- exp_year: "2024",
821
- cvv: "201",
822
- zip: ""
823
- });
824
- } else {
825
- console.log("Payment failed!", resp == null ? void 0 : resp.data);
826
- }
827
- } catch (error2) {
828
- console.log("Error: ", error2);
829
- setLoading(false);
830
- }
831
- }
832
- };
833
- window == null ? void 0 : window.DatacapWebToken.requestToken((_f = (_e = res.data) == null ? void 0 : _e.data) == null ? void 0 : _f.dctoken, "PaymentForm", tokenCallback);
834
- } else {
835
- setLoading(false);
836
- console.log("res", (_g = res.data) == null ? void 0 : _g.data);
837
- }
838
- } catch (error2) {
839
- setLoading(false);
840
- console.log(error2);
1025
+ console.log("message: ", message);
1026
+ window.parent.postMessage(message, "*");
1027
+ };
1028
+ const sendRequestPayment = async () => {
1029
+ setErrors({});
1030
+ if (!(requestDetails == null ? void 0 : requestDetails.email) && requestDetails.phone_number && !phoneNumberRegex(requestDetails.phone_number)) {
1031
+ setErrors((prevErrors) => __spreadProps(__spreadValues({}, prevErrors), {
1032
+ phone_number: "Phone number should be 10 digits"
1033
+ }));
1034
+ return;
1035
+ }
1036
+ if (!validateForm()) {
1037
+ return;
1038
+ }
1039
+ try {
1040
+ setLoading(true);
1041
+ const formData = {
1042
+ fractalpayPublicKey: fractalpayClientKey,
1043
+ amount: requestDetails.amount,
1044
+ phone_number: requestDetails.phone_number,
1045
+ order_id: requestDetails.order_id,
1046
+ action: "request",
1047
+ name: requestDetails.name,
1048
+ email: requestDetails.email
1049
+ };
1050
+ let response = await import_axios.default.post(`${baseUrl}create-widget-order`, formData);
1051
+ if ((response == null ? void 0 : response.status) === 200) {
1052
+ setShowConfirmationModal(true);
1053
+ setShow(false);
1054
+ emptyFields();
1055
+ handleSubmit(response == null ? void 0 : response.data);
841
1056
  }
1057
+ console.log(response == null ? void 0 : response.data);
1058
+ setLoading(false);
1059
+ } catch (error) {
1060
+ console.log(error);
1061
+ setLoading(false);
842
1062
  }
843
1063
  };
844
- const handleCardFormat = (numericValue) => {
845
- const cleaned = ("" + numericValue).replace(/\D/g, "");
846
- const match = cleaned.match(/^(\d{4})(\d{4})(\d{4})(\d{4})$/);
847
- if (match) {
848
- return `${match[1]} ${match[2]} ${match[3]} ${match[4]}`;
849
- }
850
- return numericValue;
1064
+ const validateAmount = (amount) => {
1065
+ return amountRegex.test(amount);
851
1066
  };
852
- const handleCardNumberChange = (value) => {
853
- setError((prev) => __spreadProps(__spreadValues({}, prev), { card_number: "" }));
854
- if (value && value.match(/[a-zA-Z]/)) {
855
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
856
- card_number: "Invalid input. Please enter only numbers."
857
- }));
858
- } else if (value.length > 12 && !(window == null ? void 0 : window.DatacapWebToken.validateCardNumber(value == null ? void 0 : value.replaceAll(" ", "")))) {
859
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
860
- card_number: "Invalid Card Number"
861
- }));
862
- } else if (!value.length) {
863
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
864
- card_number: "Card Number required"
1067
+ const handleChange = (e) => {
1068
+ const { value } = e.target;
1069
+ const token = e.target.dataset.token;
1070
+ setRequestDetails(__spreadProps(__spreadValues({}, requestDetails), { [token]: value }));
1071
+ if (token === "name" && !isAlpha(value)) {
1072
+ setErrors((prevErrors) => __spreadProps(__spreadValues({}, prevErrors), {
1073
+ [token]: "Only letters are allowed"
865
1074
  }));
866
- } else {
867
- setError({});
1075
+ return;
868
1076
  }
869
- };
870
- const handleMonthChange = (value) => {
871
- setError((prev) => __spreadProps(__spreadValues({}, prev), { exp_month: "" }));
872
- if (/^\d{0,2}$/.test(value) && (value === "" || parseInt(value, 10) >= 1 && parseInt(value, 10) <= 12)) {
873
- setError({});
874
- } else if (!value.length) {
875
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
876
- exp_month: "Month is required"
877
- }));
878
- } else {
879
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
880
- exp_month: "Value should be between 1 and 12"
1077
+ if (token === "phone_number" && !phoneNumberRegex(value)) {
1078
+ setErrors((prevErrors) => __spreadProps(__spreadValues({}, prevErrors), {
1079
+ [token]: "Phone number should be 10 digits"
881
1080
  }));
1081
+ return;
882
1082
  }
883
- };
884
- const handleYearChange = (value) => {
885
- setError((prev) => __spreadProps(__spreadValues({}, prev), { exp_year: "" }));
886
- if (window == null ? void 0 : window.DatacapWebToken.validateExpirationDate(formData.exp_month, value)) {
887
- setError({});
888
- } else if (!value.length) {
889
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
890
- exp_year: "Year is required"
891
- }));
892
- } else {
893
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
894
- exp_year: "Invalid Expiration Date."
1083
+ if (token === "email" && !isValidEmail(value)) {
1084
+ setErrors((prevErrors) => __spreadProps(__spreadValues({}, prevErrors), {
1085
+ email: "Invalid email format"
895
1086
  }));
1087
+ return;
1088
+ }
1089
+ if (value) {
1090
+ setErrors(__spreadProps(__spreadValues({}, errors), { [token]: "" }));
896
1091
  }
897
1092
  };
898
- const handleCVVChange = (value) => {
899
- setError((prev) => __spreadProps(__spreadValues({}, prev), { cvv: "" }));
900
- if (window == null ? void 0 : window.DatacapWebToken.validateCVV(value)) {
901
- setError({});
902
- } else if (!value.length) {
903
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
904
- cvv: "CVV is required"
905
- }));
906
- } else {
907
- setError((prev) => __spreadProps(__spreadValues({}, prev), {
908
- cvv: "Invalid CVV."
1093
+ const handleAmountBlur = () => {
1094
+ const value = requestDetails.amount;
1095
+ if (value && !value.includes(".")) {
1096
+ setRequestDetails((prev) => __spreadProps(__spreadValues({}, prev), {
1097
+ amount: `${value}.00`
909
1098
  }));
910
1099
  }
911
1100
  };
912
- const handleChange = (e) => {
913
- const token = e.target.getAttribute("data-token") || "";
914
- const value = e.target.value;
915
- setFormData((prev) => __spreadProps(__spreadValues({}, prev), { [token]: value }));
916
- if (token === "card_number") {
917
- handleCardNumberChange(value);
1101
+ const validateForm = () => {
1102
+ let newErrors = {};
1103
+ if (!requestDetails.name) newErrors.name = "Full Name is required";
1104
+ if (!requestDetails.amount) newErrors.amount = "Amount is required";
1105
+ if (!requestDetails.phone_number && !(requestDetails == null ? void 0 : requestDetails.email)) newErrors.phone_number = "Phone or Email is required";
1106
+ if (!requestDetails.email && !requestDetails.phone_number) newErrors.email = "Phone or Email is required";
1107
+ if (!requestDetails.phone_number && requestDetails.email && !isValidEmail(requestDetails == null ? void 0 : requestDetails.email)) newErrors.email = "Invalid email";
1108
+ setErrors(newErrors);
1109
+ return Object.keys(newErrors).length === 0;
1110
+ };
1111
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(RequestPaymentstyles_default, null), /* @__PURE__ */ React.createElement(Loader_default, { loading }), /* @__PURE__ */ React.createElement("button", { className: "paymentBtn", onClick: handleShow }, "Request Payment"), /* @__PURE__ */ React.createElement(import_react_bootstrap.Modal, { show, onHide: handleClose }, /* @__PURE__ */ React.createElement(import_react_bootstrap.Modal.Header, { closeButton: true }, /* @__PURE__ */ React.createElement(import_react_bootstrap.Modal.Title, null, "Request Payment")), /* @__PURE__ */ React.createElement(import_react_bootstrap.Modal.Body, { id: "Checkout" }, /* @__PURE__ */ React.createElement(import_react_bootstrap.Form, null, /* @__PURE__ */ React.createElement("div", { className: "mb-3" }, /* @__PURE__ */ React.createElement("label", { htmlFor: "exampleFormControlInput2", className: "form-label" }, "FULL NAME *"), /* @__PURE__ */ React.createElement(
1112
+ "input",
1113
+ {
1114
+ className: "form-control",
1115
+ type: "text",
1116
+ placeholder: "Full Name",
1117
+ "data-token": "name",
1118
+ onChange: handleChange
918
1119
  }
919
- if (token === "exp_month") {
920
- handleMonthChange(value);
1120
+ ), errors.name && /* @__PURE__ */ React.createElement("small", { className: "text-danger" }, errors.name)), /* @__PURE__ */ React.createElement("div", { className: "mb-3" }, /* @__PURE__ */ React.createElement("label", { htmlFor: "requestPhoneNumber", className: "form-label" }, "Phone Number"), /* @__PURE__ */ React.createElement(
1121
+ "input",
1122
+ {
1123
+ maxLength: 10,
1124
+ className: "form-control",
1125
+ onChange: (e) => {
1126
+ handleChange(e);
1127
+ },
1128
+ placeholder: "Phone Number",
1129
+ type: "text",
1130
+ "data-token": "phone_number"
921
1131
  }
922
- if (token === "exp_year") {
923
- handleYearChange(value);
1132
+ ), errors.phone_number && /* @__PURE__ */ React.createElement("small", { className: "text-danger" }, errors.phone_number)), /* @__PURE__ */ React.createElement("div", { className: "mb-3" }, /* @__PURE__ */ React.createElement("label", { htmlFor: "exampleFormControlInput2", className: "form-label" }, "EMAIL"), /* @__PURE__ */ React.createElement(
1133
+ "input",
1134
+ {
1135
+ className: "form-control",
1136
+ type: "text",
1137
+ placeholder: "Email",
1138
+ onChange: handleChange,
1139
+ "data-token": "email"
924
1140
  }
925
- if (token === "cvv") {
926
- handleCVVChange(value);
1141
+ ), errors.email && /* @__PURE__ */ React.createElement("small", { className: "text-danger" }, errors.email)), /* @__PURE__ */ React.createElement("div", { className: "mb-3" }, /* @__PURE__ */ React.createElement("label", { htmlFor: "exampleFormControlInput2", className: "form-label" }, "AMOUNT *"), /* @__PURE__ */ React.createElement("div", { className: "input-group" }, /* @__PURE__ */ React.createElement("span", { className: "input-group-text" }, "$"), /* @__PURE__ */ React.createElement(
1142
+ "input",
1143
+ {
1144
+ "data-token": "amount",
1145
+ type: "number",
1146
+ className: "form-control",
1147
+ value: requestDetails.amount,
1148
+ onChange: handleChange,
1149
+ onBlur: handleAmountBlur
927
1150
  }
928
- };
929
- (0, import_react2.useEffect)(() => {
930
- const scriptId = "my-script";
931
- const existingScript = document.getElementById(scriptId);
932
- if (!existingScript) {
933
- const script = document.createElement("script");
934
- script.src = "https://token-cert.dcap.com/v1/client";
935
- script.id = scriptId;
936
- script.async = true;
937
- script.onload = () => {
938
- if (typeof window !== "undefined" && window.DatacapWebToken) {
939
- console.log("DatacapWebToken", window.DatacapWebToken);
940
- } else {
941
- console.log("DatacapWebToken is not loaded yet.");
942
- }
943
- };
944
- document.head.appendChild(script);
1151
+ )), errors.amount && /* @__PURE__ */ React.createElement("small", { className: "text-danger" }, errors.amount)), /* @__PURE__ */ React.createElement("div", { className: "mb-3" }, /* @__PURE__ */ React.createElement("label", { htmlFor: "exampleFormControlInput2", className: "form-label" }, "ORDER ID"), /* @__PURE__ */ React.createElement(
1152
+ "input",
1153
+ {
1154
+ className: "form-control",
1155
+ type: "text",
1156
+ placeholder: "Order Id",
1157
+ onChange: handleChange,
1158
+ "data-token": "order_id"
945
1159
  }
946
- return () => {
947
- const script = document.getElementById(scriptId);
948
- if (script) {
949
- document.head.removeChild(script);
950
- }
951
- };
952
- }, []);
953
- (0, import_react2.useEffect)(() => {
954
- const link = document.createElement("link");
955
- link.rel = "stylesheet";
956
- link.href = "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.13.0/css/all.min.css";
957
- document.head.appendChild(link);
958
- return () => {
959
- document.head.removeChild(link);
960
- };
961
- }, []);
962
- const handleClose = () => {
963
- setShow(false);
964
- };
965
- const handleOpen = () => {
966
- console.log("open");
967
- setShow(true);
968
- };
969
- console.log(show, "open");
970
- return /* @__PURE__ */ import_react2.default.createElement(import_react2.default.Fragment, null, /* @__PURE__ */ import_react2.default.createElement(CustomStyle, null), /* @__PURE__ */ import_react2.default.createElement("div", { className: "w-100 text-center" }, /* @__PURE__ */ import_react2.default.createElement(import_react_bootstrap.Button, { onClick: handleOpen }, "Show")), /* @__PURE__ */ import_react2.default.createElement(
971
- import_react_bootstrap.Modal,
1160
+ ), errors.order_id && /* @__PURE__ */ React.createElement("small", { className: "text-danger" }, errors.order_id)), /* @__PURE__ */ React.createElement(
1161
+ import_react_bootstrap.Button,
972
1162
  {
973
- show,
974
- onHide: handleClose,
975
- backdrop: "static",
976
- keyboard: false,
977
- size: "lg"
1163
+ type: "button",
1164
+ className: "PayButton",
1165
+ onClick: sendRequestPayment,
1166
+ disabled: loading
978
1167
  },
979
- /* @__PURE__ */ import_react2.default.createElement(import_react_bootstrap.Modal.Body, null, /* @__PURE__ */ import_react2.default.createElement("div", { className: "bg-black" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "container bg-black" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "row bg-light no-gutters" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "col-sm-12" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "bd-example bd-example-tabs right-tabs mttabs m-3 " }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "payment-popup" }, /* @__PURE__ */ import_react2.default.createElement(
980
- "button",
981
- {
982
- className: "close-pop",
983
- onClick: () => {
984
- setShow(false);
985
- }
986
- },
987
- /* @__PURE__ */ import_react2.default.createElement(
988
- "svg",
989
- {
990
- xmlns: "http://www.w3.org/2000/svg",
991
- width: 37,
992
- height: 37,
993
- viewBox: "0 0 21 21"
994
- },
995
- /* @__PURE__ */ import_react2.default.createElement(
996
- "path",
997
- {
998
- fill: "none",
999
- stroke: "currentColor",
1000
- strokeLinecap: "round",
1001
- strokeLinejoin: "round",
1002
- d: "m7.5 7.5l6 6m0-6l-6 6"
1003
- }
1004
- )
1005
- )
1006
- ), /* @__PURE__ */ import_react2.default.createElement("div", { className: "row" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "comp-name" }, /* @__PURE__ */ import_react2.default.createElement(
1007
- "img",
1008
- {
1009
- src: "https://invoicestaging.skysystemz.com/assets/products/65c49a2740ff1.png",
1010
- alt: "",
1011
- className: "client-logo"
1012
- }
1013
- )), /* @__PURE__ */ import_react2.default.createElement("div", { className: "" }, /* @__PURE__ */ import_react2.default.createElement("div", { id: "Checkout", className: "inline" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "header" }, /* @__PURE__ */ import_react2.default.createElement("h1", null, "Pay"), /* @__PURE__ */ import_react2.default.createElement(
1014
- "i",
1015
- {
1016
- className: "fa fa-qrcode fa-2x",
1017
- id: "qrIcon",
1018
- title: "Show QR Code",
1019
- onClick: () => setToggleQr(!toggleQr)
1020
- }
1021
- )), /* @__PURE__ */ import_react2.default.createElement("div", { id: "qrCode", style: {
1022
- display: toggleQr ? "block" : "none"
1023
- } }, /* @__PURE__ */ import_react2.default.createElement(
1024
- "img",
1168
+ loading ? "Loading..." : "Send Request"
1169
+ )), /* @__PURE__ */ React.createElement("div", { className: "powerd-by-part" }, /* @__PURE__ */ React.createElement(
1170
+ "svg",
1171
+ {
1172
+ xmlns: "http://www.w3.org/2000/svg",
1173
+ width: "20",
1174
+ height: "20",
1175
+ viewBox: "0 0 26 26"
1176
+ },
1177
+ /* @__PURE__ */ React.createElement(
1178
+ "path",
1025
1179
  {
1026
- src: "",
1027
- alt: "QRCode",
1028
- srcSet: ""
1180
+ fill: "currentColor",
1181
+ d: "M23.633 5.028a1.074 1.074 0 0 0-.777-.366c-2.295-.06-5.199-2.514-7.119-3.477C14.551.592 13.768.201 13.18.098a1.225 1.225 0 0 0-.36.001c-.588.103-1.371.494-2.556 1.087c-1.92.962-4.824 3.416-7.119 3.476a1.08 1.08 0 0 0-.778.366a1.167 1.167 0 0 0-.291.834c.493 10.023 4.088 16.226 10.396 19.831c.164.093.346.141.527.141s.363-.048.528-.141c6.308-3.605 9.902-9.808 10.396-19.831a1.161 1.161 0 0 0-.29-.834zM18.617 8.97l-5.323 7.855c-.191.282-.491.469-.788.469c-.298 0-.629-.163-.838-.372l-3.752-3.753a.656.656 0 0 1 0-.926l.927-.929a.658.658 0 0 1 .926 0l2.44 2.44l4.239-6.257a.657.657 0 0 1 .91-.173l1.085.736a.657.657 0 0 1 .174.91z"
1029
1182
  }
1030
- )), /* @__PURE__ */ import_react2.default.createElement(
1031
- "form",
1183
+ )
1184
+ ), "Secure payments powered by Fractal", /* @__PURE__ */ React.createElement(
1185
+ "img",
1186
+ {
1187
+ src: "https://ui.fractalpay.com/favicon.ico",
1188
+ alt: "Fractal logo",
1189
+ className: "powered-logo"
1190
+ }
1191
+ )))), /* @__PURE__ */ React.createElement(
1192
+ import_react_bootstrap.Modal,
1193
+ {
1194
+ className: "payment-suc",
1195
+ show: showConfirmationModal,
1196
+ onHide: handleCloseConfirmationModal
1197
+ },
1198
+ /* @__PURE__ */ React.createElement(import_react_bootstrap.Modal.Header, { closeButton: true }),
1199
+ /* @__PURE__ */ React.createElement(import_react_bootstrap.Modal.Body, null, /* @__PURE__ */ React.createElement(
1200
+ "svg",
1032
1201
  {
1033
- id: "PaymentForm",
1034
- className: "payment-form",
1035
- onSubmit: handleSubmit
1202
+ width: "60",
1203
+ height: "60",
1204
+ viewBox: "0 0 60 60",
1205
+ fill: "none",
1206
+ xmlns: "http://www.w3.org/2000/svg"
1036
1207
  },
1037
- /* @__PURE__ */ import_react2.default.createElement(
1038
- "input",
1208
+ /* @__PURE__ */ React.createElement(
1209
+ "rect",
1039
1210
  {
1040
- type: "hidden",
1041
- id: "dctoken",
1042
- defaultValue: dcToken,
1043
- name: "dctoken"
1211
+ x: "0.5",
1212
+ y: "0.5",
1213
+ width: "59",
1214
+ height: "59",
1215
+ rx: "29.5",
1216
+ stroke: "#31B379"
1044
1217
  }
1045
1218
  ),
1046
- /* @__PURE__ */ import_react2.default.createElement("div", { className: "form-group top-amnt" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "amtleft" }, /* @__PURE__ */ import_react2.default.createElement("label", { htmlFor: "Amount" }, "Payment amount"), /* @__PURE__ */ import_react2.default.createElement("div", { className: "amount-placeholder" }, /* @__PURE__ */ import_react2.default.createElement("span", null, "$"), /* @__PURE__ */ import_react2.default.createElement("span", null, " ", amount || 1, " "))), /* @__PURE__ */ import_react2.default.createElement("div", { className: "card-row" }, /* @__PURE__ */ import_react2.default.createElement("span", { className: "visa" }), /* @__PURE__ */ import_react2.default.createElement("span", { className: "mastercard" }), /* @__PURE__ */ import_react2.default.createElement("span", { className: "amex" }), /* @__PURE__ */ import_react2.default.createElement("span", { className: "discover" }))),
1047
- /* @__PURE__ */ import_react2.default.createElement("div", { className: "form-group" }, /* @__PURE__ */ import_react2.default.createElement("label", { htmlFor: "NameOnCard" }, "Name on card"), /* @__PURE__ */ import_react2.default.createElement(
1048
- "input",
1049
- {
1050
- "data-token": "name",
1051
- id: "NameOnCard",
1052
- className: "form-control required",
1053
- type: "text",
1054
- maxLength: 100,
1055
- placeholder: "name",
1056
- value: formData == null ? void 0 : formData.name,
1057
- onChange: handleChange
1058
- }
1059
- ), /* @__PURE__ */ import_react2.default.createElement(
1060
- "span",
1061
- {
1062
- id: "NameOnCard-error",
1063
- style: { color: "red" }
1064
- }
1065
- )),
1066
- /* @__PURE__ */ import_react2.default.createElement("div", { className: "form-group" }, /* @__PURE__ */ import_react2.default.createElement(
1067
- "input",
1068
- {
1069
- "data-token": "card_number",
1070
- className: "null card-image form-control required",
1071
- type: "text",
1072
- maxLength: 19,
1073
- placeholder: "0000 0000 0000 0000",
1074
- value: handleCardFormat(formData == null ? void 0 : formData.card_number),
1075
- onChange: handleChange
1076
- }
1077
- ), error.card_number && /* @__PURE__ */ import_react2.default.createElement(
1078
- "span",
1079
- {
1080
- id: "card_number-error",
1081
- style: { color: "red" }
1082
- },
1083
- error.card_number
1084
- )),
1085
- /* @__PURE__ */ import_react2.default.createElement("div", { className: "expiry-date-group form-group" }, /* @__PURE__ */ import_react2.default.createElement(
1086
- "input",
1087
- {
1088
- "data-token": "exp_month",
1089
- className: "form-control required",
1090
- type: "text",
1091
- placeholder: "MM",
1092
- maxLength: 2,
1093
- value: formData == null ? void 0 : formData.exp_month,
1094
- onChange: handleChange
1095
- }
1096
- ), error.exp_month && /* @__PURE__ */ import_react2.default.createElement(
1097
- "span",
1098
- {
1099
- id: "exp_month-error",
1100
- style: { color: "red" }
1101
- },
1102
- error.exp_month
1103
- )),
1104
- /* @__PURE__ */ import_react2.default.createElement("div", { className: "expiry-date-group form-group" }, /* @__PURE__ */ import_react2.default.createElement(
1105
- "input",
1219
+ /* @__PURE__ */ React.createElement("g", { clipPath: "url(#clip0_2659_5018)" }, /* @__PURE__ */ React.createElement(
1220
+ "path",
1106
1221
  {
1107
- "data-token": "exp_year",
1108
- className: "form-control required",
1109
- type: "text",
1110
- placeholder: "YYYY",
1111
- maxLength: 4,
1112
- value: formData == null ? void 0 : formData.exp_year,
1113
- onChange: handleChange
1222
+ d: "M41.1778 22.248C40.7483 21.8184 40.0518 21.8184 39.6222 22.248L26.4435 35.4268L21.3778 30.3611C20.9483 29.9315 20.2518 29.9316 19.8222 30.3611C19.3926 30.7907 19.3926 31.4871 19.8222 31.9167L25.6657 37.7601C26.0951 38.1897 26.7921 38.1894 27.2213 37.7601L41.1778 23.8036C41.6074 23.3741 41.6074 22.6776 41.1778 22.248Z",
1223
+ fill: "#31B379"
1114
1224
  }
1115
- ), error.exp_year && /* @__PURE__ */ import_react2.default.createElement(
1116
- "span",
1117
- {
1118
- id: "exp_year-error",
1119
- style: { color: "red" }
1120
- },
1121
- error.exp_year
1122
1225
  )),
1123
- /* @__PURE__ */ import_react2.default.createElement("div", { className: "security-code-group form-group" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "input-container" }, /* @__PURE__ */ import_react2.default.createElement(
1124
- "input",
1125
- {
1126
- "data-token": "cvv",
1127
- className: "form-control required",
1128
- type: "text",
1129
- maxLength: 4,
1130
- placeholder: "CVC",
1131
- value: formData == null ? void 0 : formData.cvv,
1132
- onChange: handleChange
1133
- }
1134
- ), /* @__PURE__ */ import_react2.default.createElement("i", { id: "cvc", className: "fa fa-question-circle" })), error.cvv && /* @__PURE__ */ import_react2.default.createElement(
1135
- "span",
1136
- {
1137
- id: "cvv-error",
1138
- style: { color: "red" }
1139
- },
1140
- error.cvv
1141
- ), /* @__PURE__ */ import_react2.default.createElement("div", { className: "cvc-preview-container two-card hide" }, /* @__PURE__ */ import_react2.default.createElement("div", { className: "amex-cvc-preview" }), /* @__PURE__ */ import_react2.default.createElement("div", { className: "visa-mc-dis-cvc-preview" }))),
1142
- /* @__PURE__ */ import_react2.default.createElement("div", { className: "zip-code-group form-group" }, /* @__PURE__ */ import_react2.default.createElement("label", { htmlFor: "ZIPCode" }, "Postal code"), /* @__PURE__ */ import_react2.default.createElement("div", { className: "input-container" }, /* @__PURE__ */ import_react2.default.createElement(
1143
- "input",
1226
+ /* @__PURE__ */ React.createElement("defs", null, /* @__PURE__ */ React.createElement("clipPath", { id: "clip0_2659_5018" }, /* @__PURE__ */ React.createElement(
1227
+ "rect",
1144
1228
  {
1145
- id: "ZIPCode",
1146
- "data-token": "zip",
1147
- className: "form-control required",
1148
- type: "text",
1149
- maxLength: 7,
1150
- placeholder: "000000",
1151
- value: formData == null ? void 0 : formData.zip,
1152
- onChange: handleChange
1229
+ width: "22",
1230
+ height: "22",
1231
+ fill: "white",
1232
+ transform: "translate(19.5 19.0039)"
1153
1233
  }
1154
- ), /* @__PURE__ */ import_react2.default.createElement(
1155
- "a",
1156
- {
1157
- tabIndex: 0,
1158
- role: "button",
1159
- "data-toggle": "popover",
1160
- "data-trigger": "focus",
1161
- "data-placement": "left",
1162
- "data-content": "Enter the ZIP/Postal code for your credit card billing address."
1163
- },
1164
- /* @__PURE__ */ import_react2.default.createElement("i", { className: "fa fa-question-circle" })
1165
- ), /* @__PURE__ */ import_react2.default.createElement(
1166
- "span",
1167
- {
1168
- id: "ZIPCode-error",
1169
- style: { color: "red", display: "none" }
1170
- },
1171
- "This field is required"
1172
- ))),
1173
- /* @__PURE__ */ import_react2.default.createElement(
1174
- "button",
1175
- {
1176
- id: "PayButton",
1177
- className: "btn btn-block btn-success submit-button",
1178
- type: "submit"
1179
- },
1180
- /* @__PURE__ */ import_react2.default.createElement("span", { className: "submit-button-lock" }),
1181
- /* @__PURE__ */ import_react2.default.createElement("span", { className: "align-middle" }, "Pay $", amount || 1)
1182
- )
1183
- ), /* @__PURE__ */ import_react2.default.createElement("div", { className: "powerd-by-part", style: {
1184
- display: "flex",
1185
- fontSize: "12px",
1186
- textAlign: "center",
1187
- alignItems: "center",
1188
- justifyContent: "center",
1189
- margin: "8px 0 20px 0"
1190
- } }, /* @__PURE__ */ import_react2.default.createElement(
1191
- "svg",
1192
- {
1193
- xmlns: "http://www.w3.org/2000/svg",
1194
- width: 20,
1195
- height: 20,
1196
- viewBox: "0 0 26 26"
1197
- },
1198
- /* @__PURE__ */ import_react2.default.createElement(
1199
- "path",
1200
- {
1201
- fill: "currentColor",
1202
- d: "M23.633 5.028a1.074 1.074 0 0 0-.777-.366c-2.295-.06-5.199-2.514-7.119-3.477C14.551.592 13.768.201 13.18.098a1.225 1.225 0 0 0-.36.001c-.588.103-1.371.494-2.556 1.087c-1.92.962-4.824 3.416-7.119 3.476a1.08 1.08 0 0 0-.778.366a1.167 1.167 0 0 0-.291.834c.493 10.023 4.088 16.226 10.396 19.831c.164.093.346.141.527.141s.363-.048.528-.141c6.308-3.605 9.902-9.808 10.396-19.831a1.161 1.161 0 0 0-.29-.834zM18.617 8.97l-5.323 7.855c-.191.282-.491.469-.788.469c-.298 0-.629-.163-.838-.372l-3.752-3.753a.656.656 0 0 1 0-.926l.927-.929a.658.658 0 0 1 .926 0l2.44 2.44l4.239-6.257a.657.657 0 0 1 .91-.173l1.085.736a.657.657 0 0 1 .174.91z"
1203
- }
1204
- )
1205
- ), "Secure payments powered by Fractal", /* @__PURE__ */ import_react2.default.createElement(
1206
- "img",
1207
- {
1208
- src: "https://ui.fractalpay.com/favicon.ico",
1209
- alt: "Fractal logo",
1210
- className: "powered-logo",
1211
- style: {
1212
- width: "18px",
1213
- height: "18px",
1214
- float: "right",
1215
- padding: "2px",
1216
- background: "#000",
1217
- borderRadius: "4px",
1218
- marginLeft: "5px"
1219
- }
1220
- }
1221
- ))))))))))))
1234
+ )))
1235
+ ), /* @__PURE__ */ React.createElement("h2", null, "Payment link has been ", /* @__PURE__ */ React.createElement("br", null), " sent successfully"))
1222
1236
  ));
1223
- }
1237
+ };
1224
1238
  // Annotate the CommonJS export names for ESM import in node:
1225
1239
  0 && (module.exports = {
1226
- PaywithFractal
1240
+ RequestPayment
1227
1241
  });