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