@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.cjs CHANGED
@@ -1,31 +1,10 @@
1
1
  "use strict";
2
2
  var __create = Object.create;
3
3
  var __defProp = Object.defineProperty;
4
- var __defProps = Object.defineProperties;
5
4
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
7
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
8
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
9
6
  var __getProtoOf = Object.getPrototypeOf;
10
7
  var __hasOwnProp = Object.prototype.hasOwnProperty;
11
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
12
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
13
- var __spreadValues = (a, b) => {
14
- for (var prop in b || (b = {}))
15
- if (__hasOwnProp.call(b, prop))
16
- __defNormalProp(a, prop, b[prop]);
17
- if (__getOwnPropSymbols)
18
- for (var prop of __getOwnPropSymbols(b)) {
19
- if (__propIsEnum.call(b, prop))
20
- __defNormalProp(a, prop, b[prop]);
21
- }
22
- return a;
23
- };
24
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
25
- var __export = (target, all) => {
26
- for (var name in all)
27
- __defProp(target, name, { get: all[name], enumerable: true });
28
- };
29
8
  var __copyProps = (to, from, except, desc) => {
30
9
  if (from && typeof from === "object" || typeof from === "function") {
31
10
  for (let key of __getOwnPropNames(from))
@@ -46,1182 +25,20 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
46
25
 
47
26
  // src/app/index.ts
48
27
  var app_exports = {};
49
- __export(app_exports, {
50
- PaywithFractal: () => PaywithFractal
51
- });
52
28
  module.exports = __toCommonJS(app_exports);
53
- var import_bootstrap_min2 = require("bootstrap/dist/css/bootstrap.min.css");
54
29
 
55
- // src/app/components/Greet.tsx
30
+ // src/app/components/RequestPayment/RequestPayment.tsx
31
+ var import_react4 = require("react");
56
32
  var import_axios = __toESM(require("axios"), 1);
33
+
34
+ // src/app/components/Loader/Loader.tsx
57
35
  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
36
 
61
- // src/app/components/CustomStyle.tsx
37
+ // src/app/components/Loader/LoaderStyle.tsx
62
38
  var import_react = __toESM(require("react"), 1);
63
- var CustomStyle = (props) => {
64
- return /* @__PURE__ */ import_react.default.createElement("style", null, `
65
-
66
39
 
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;
551
- }
552
-
553
- .payment-success h2 {
554
- font-size: 24px;
555
- color: #35254D;
556
- line-height: 25px;
557
- }
558
-
559
- .payment-success p {
560
- font-size: 14px;
561
- color: #9A92A6;
562
- line-height: 15px;
563
- }
564
-
565
-
566
- .bg-light {
567
- background: #fff !important;
568
- }
569
-
570
- /* body {
571
- overflow: hidden !important;
572
- background: #fff !important;
573
- } */
574
-
575
- .app-pagination .page-item .page-link {
576
- color: #2e2f2f;
577
- }
578
-
579
- .app-pagination .page-item.active .page-link {
580
- background-color: #a9aeb3;
581
- border-color: #ddd;
582
- color: #2e2f2f;
583
- }
584
-
585
- .app-pagination .page-item.disabled .page-link {
586
- color: #2e2f2f;
587
- }
588
-
589
- .app-pagination .page-item .page-link:hover {
590
- text-decoration: none;
591
- color: #2e2f2f;
592
- }
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%;
601
- 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;
723
- }
724
- .requpay-in{
725
- width: 100%;
726
- background: 0 0 #ffffff;
727
- border-radius: 24px;
728
- border: 1px solid #e0dfe2;
729
- padding: 20px;
730
- }
731
-
732
- .requpay-in .mb-1{
733
- 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
- }
750
- `);
751
- };
40
+ // src/app/components/RequestPayment/RequestPayment.tsx
41
+ var import_react_bootstrap = require("react-bootstrap");
752
42
 
753
- // src/app/components/Greet.tsx
754
- function PaywithFractal({ name, amount, orderId, fractalPayClientKey }) {
755
- const baseUrl = "http://192.168.1.52:8082/";
756
- 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: ""
768
- });
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
781
- };
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);
841
- }
842
- }
843
- };
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;
851
- };
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"
865
- }));
866
- } else {
867
- setError({});
868
- }
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"
881
- }));
882
- }
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."
895
- }));
896
- }
897
- };
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."
909
- }));
910
- }
911
- };
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);
918
- }
919
- if (token === "exp_month") {
920
- handleMonthChange(value);
921
- }
922
- if (token === "exp_year") {
923
- handleYearChange(value);
924
- }
925
- if (token === "cvv") {
926
- handleCVVChange(value);
927
- }
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);
945
- }
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,
972
- {
973
- show,
974
- onHide: handleClose,
975
- backdrop: "static",
976
- keyboard: false,
977
- size: "lg"
978
- },
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",
1025
- {
1026
- src: "",
1027
- alt: "QRCode",
1028
- srcSet: ""
1029
- }
1030
- )), /* @__PURE__ */ import_react2.default.createElement(
1031
- "form",
1032
- {
1033
- id: "PaymentForm",
1034
- className: "payment-form",
1035
- onSubmit: handleSubmit
1036
- },
1037
- /* @__PURE__ */ import_react2.default.createElement(
1038
- "input",
1039
- {
1040
- type: "hidden",
1041
- id: "dctoken",
1042
- defaultValue: dcToken,
1043
- name: "dctoken"
1044
- }
1045
- ),
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",
1106
- {
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
1114
- }
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
- )),
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",
1144
- {
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
1153
- }
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
- ))))))))))))
1222
- ));
1223
- }
1224
- // Annotate the CommonJS export names for ESM import in node:
1225
- 0 && (module.exports = {
1226
- PaywithFractal
1227
- });
43
+ // src/app/components/RequestPayment/RequestPaymentstyles.tsx
44
+ var import_react3 = __toESM(require("react"), 1);