@pinerohit11/testwidget 0.1.34 → 0.1.35

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