tonder-web-sdk 1.15.2 → 1.16.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/.husky/pre-commit +4 -0
  2. package/.prettierignore +8 -0
  3. package/.prettierrc +10 -0
  4. package/README.md +189 -35
  5. package/eslint.config.mjs +15 -0
  6. package/package.json +21 -4
  7. package/src/classes/3dsHandler.js +58 -62
  8. package/src/classes/BaseInlineCheckout.js +21 -36
  9. package/src/classes/LiteInlineCheckout.js +8 -8
  10. package/src/classes/checkout.js +75 -71
  11. package/src/classes/globalLoader.js +9 -7
  12. package/src/classes/inlineCheckout.js +528 -250
  13. package/src/data/apmApi.js +8 -14
  14. package/src/data/businessApi.js +5 -8
  15. package/src/data/cardApi.js +5 -14
  16. package/src/data/checkoutApi.js +54 -54
  17. package/src/data/customerApi.js +1 -6
  18. package/src/data/index.js +15 -15
  19. package/src/data/openPayApi.js +7 -7
  20. package/src/data/skyflowApi.js +14 -16
  21. package/src/helpers/skyflow.js +210 -119
  22. package/src/helpers/styles.js +56 -27
  23. package/src/helpers/template-skeleton.js +1 -1
  24. package/src/helpers/template.js +984 -541
  25. package/src/helpers/utils.js +152 -58
  26. package/src/helpers/validations.js +34 -35
  27. package/src/index-dev.js +38 -11
  28. package/src/index.html +20 -12
  29. package/src/index.js +19 -13
  30. package/src/shared/catalog/commonLogosCatalog.js +7 -0
  31. package/src/shared/catalog/paymentMethodsCatalog.js +242 -243
  32. package/src/shared/constants/colors.js +15 -0
  33. package/src/shared/constants/displayMode.js +4 -0
  34. package/src/shared/constants/fieldPathNames.js +4 -0
  35. package/src/shared/constants/htmlTonderIds.js +18 -0
  36. package/src/shared/constants/messages.js +10 -9
  37. package/types/card.d.ts +17 -17
  38. package/types/checkout.d.ts +85 -87
  39. package/types/common.d.ts +4 -1
  40. package/types/customer.d.ts +10 -10
  41. package/types/index.d.ts +9 -11
  42. package/types/inlineCheckout.d.ts +81 -61
  43. package/types/liteInlineCheckout.d.ts +78 -83
  44. package/types/paymentMethod.d.ts +17 -17
  45. package/types/transaction.d.ts +94 -94
  46. package/v1/bundle.min.js +3 -3
@@ -1,426 +1,77 @@
1
- import { getCardType } from "./utils";
2
- import {getPaymentMethodDetails} from "../shared/catalog/paymentMethodsCatalog";
1
+ import "accordion-js/dist/accordion.min.css";
2
+ import { getCardFormLabels, getCardType } from "./utils";
3
+ import { getPaymentMethodDetails } from "../shared/catalog/paymentMethodsCatalog";
4
+ import { getDefaultStyles } from "./styles";
5
+ import { COMMON_LOGOS } from "../shared/catalog/commonLogosCatalog";
6
+ import get from "lodash.get";
7
+ import { FIELD_PATH_NAMES } from "../shared/constants/fieldPathNames";
8
+ import { HTML_IDS } from "../shared/constants/htmlTonderIds";
9
+ import { DISPLAY_MODE } from "../shared/constants/displayMode";
10
+ import { COLORS } from "../shared/constants/colors";
3
11
 
4
- export const cardTemplate = (data) => `
5
- <div class="container-tonder">
6
- ${ data.customization?.saveCards?.showSaved ?
7
- `<div id="cardsListContainer" class="cards-list-container"></div>`
8
- :``
9
- }
10
- <div class="pay-new-card">
11
- <input checked id="new" class="card_selected" name="card_selected" type="radio"/>
12
- <label class="card-item-label-new" for="new">
13
- <img class="card-image" src="${getCardType("XXXX")}" />
14
- <div class="card-number">Pagar con tarjeta</div>
15
- </label>
16
- </div>
17
- <div id="global-loader" class="global-loader"></div>
18
- <div class="container-form">
19
- <div id="collectCardholderName" class="empty-div"></div>
20
- <div id="collectCardNumber" class="empty-div"></div>
21
- <div class="collect-row">
22
- <div id="collectExpirationMonth" class="empty-div"></div>
23
- <div id="collectExpirationYear" class="expiration-year"></div>
24
- <div id="collectCvv" class="empty-div"></div>
25
- </div>
26
- ${!!data.customization?.saveCards?.showSaveCardOption
27
- ? `
28
- <div class="checkbox" id="save-card-container">
29
- <input id="save-checkout-card" type="checkbox">
30
- <label for="save-checkout-card">
31
- Guardar tarjeta para futuros pagos
32
- </label>
12
+ export const containerCheckoutTemplate = data => {
13
+ const displayMode = data.customization?.displayMode || DISPLAY_MODE.light;
14
+ const renderPaymentButton = get(data, FIELD_PATH_NAMES.paymentButton, false);
15
+ document.documentElement.setAttribute("data-theme", displayMode);
16
+ return `
17
+ <div class="container-tonder" id="${HTML_IDS.tonderContainer}">
18
+ <div id="${HTML_IDS.globalLoader}" class="global-loader"></div>
33
19
  </div>
34
- `
35
- :``}
36
-
37
- <div id="msgError"></div>
38
- <div id="msgNotification"></div>
39
- </div>
40
- <div id="apmsListContainer" class="apms-list-container"></div>
41
- <div class="container-pay-button">
42
- <button id="tonderPayButton" class="pay-button">Pagar</button>
43
- </div>
44
- </div>
45
-
46
- <style>
47
-
48
- .container-tonder {
49
- background-color: #F9F9F9;
50
- margin: 0 auto !important;
51
- padding: 0px;
52
- overflow: hidden;
53
- transition: max-height 0.5s ease-out;
54
- max-width: 600px;
55
- border: solid 1px #e3e3e3;
56
- position: relative;
57
- font-family: ${getFontFamily(data)};
58
- }
59
- .container-pay-button{
60
- padding: ${!!data['renderPaymentButton'] ? '30px 25px':''};
61
- }
62
-
63
- .container-form {
64
- padding: 25px 25px 0px 25px;
65
- }
66
-
67
- .collect-row {
68
- display: flex !important;
69
- justify-content: space-between !important;
70
- width: 100% !important;
71
- }
72
-
73
- .collect-row > :first-child {
74
- min-width: 120px; !important
75
- }
76
-
77
- .expiration-year {
78
- position: relative !important;
79
- padding-top: 25px !important;
80
- }
81
-
82
- .empty-div {
83
- position: relative;
84
- height: 80px !important;
85
- margin-top: 2px;
86
- margin-bottom: 4px;
87
- margin-left: 10px !important;
88
- margin-right: 10px !important;
89
- }
90
-
91
- .error-container {
92
- color: red !important;
93
- background-color: #FFDBDB !important;
94
- margin-bottom: 13px !important;
95
- font-size: 80% !important;
96
- padding: 8px 10px !important;
97
- border-radius: 10px !important;
98
- text-align: left !important;
99
- }
100
-
101
- .message-container{
102
- color: #3bc635 !important;
103
- background-color: #DAFCE4 !important;
104
- margin-bottom: 13px !important;
105
- font-size: 80% !important;
106
- padding: 8px 10px !important;
107
- border-radius: 10px !important;
108
- text-align: left !important;
109
- }
110
-
111
- .pay-button {
112
- font-size: 16px;
113
- font-weight: bold;
114
- min-height: 2.3rem;
115
- border-radius: 0.5rem;
116
- cursor: pointer;
117
- width: 100%;
118
- padding: 1rem;
119
- text-align: center;
120
- border: none;
121
- background-color: #000;
122
- color: #fff;
123
- margin-bottom: 0px;
124
- display: none;
125
- }
126
-
127
- .lds-dual-ring {
128
- display: inline-block;
129
- width: 14px;
130
- height: 14px;
131
- }
132
-
133
- .lds-dual-ring:after {
134
- content: " ";
135
- display: block;
136
- width: 14px;
137
- height: 14px;
138
- border-radius: 50%;
139
- border: 6px solid #fff;
140
- border-color: #fff transparent #fff transparent;
141
- animation: lds-dual-ring 1.2s linear infinite;
142
- }
143
- @keyframes lds-dual-ring {
144
- 0% {
145
- transform: rotate(0deg);
146
- }
147
- 100% {
148
- transform: rotate(360deg);
149
- }
150
- }
151
-
152
- .global-loader {
153
- position: absolute;
154
- top: 0;
155
- left: 0;
156
- width: 100%;
157
- height: 100%;
158
- z-index: 1;
159
- }
160
-
161
- @media screen and (max-width: 600px) {
162
- .payment_method_zplit {
163
- font-size: 16px !important;
164
- width: 100% !important;
165
- }
166
-
167
- .payment_method_zplit label img {
168
- display: none !important;
169
- }
170
- }
171
-
172
- .checkbox label {
173
- margin-left: 10px;
174
- font-size: 12px;
175
- font-weight: 500;
176
- color: #1D1D1D;
177
- }
178
-
179
- .checkbox {
180
- margin-top: 10px;
181
- margin-bottom: 20px;
182
- text-align: left;
183
- padding: 0 8px;
184
- }
185
-
186
- .cards-list-container {
187
- display: flex;
188
- flex-direction: column;
189
- padding: 0px;
190
- gap: 33% 20px;
191
- }
192
-
193
- .apms-list-container {
194
- display: flex;
195
- flex-direction: column;
196
- gap: 33% 20px;
197
- max-height: 300px;
198
- overflow-y: auto;
199
- }
200
- .pay-new-card {
201
- display: flex;
202
- justify-content: start;
203
- align-items: center;
204
- color: #1D1D1D;
205
- gap: 33% 15px;
206
- margin-top: 10px;
207
- margin-bottom: 10px;
208
- padding: 0px 30px;
209
- width: 100%;
210
- position: relative;
211
- }
212
-
213
- .pay-new-card .card-number {
214
- font-size: 16px;
215
- }
216
- .card-image {
217
- width: 39px;
218
- height: 24px;
219
- text-align: left;
220
- }
221
-
222
- .card-item-label-new {
223
- display: flex;
224
- justify-content: start;
225
- align-items: center;
226
- color: #1D1D1D;
227
- gap: 33% 20px;
228
- margin-top: 10px;
229
- margin-bottom: 10px;
230
- width: 100%;
231
- }
232
-
233
- .card_selected {
234
- position: relative;
235
- width: 16px;
236
- height: 16px;
237
- min-width: 16px;
238
- appearance: none;
239
- cursor: pointer;
240
- border-radius: 100%;
241
- border: 1px #bababa solid;
242
- color: #3bc635;
243
- transition-property: all;
244
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
245
- transition-duration: 150ms;
246
- }
247
-
248
- .card_selected:before {
249
- width: 8px;
250
- height: 8px;
251
- content: "";
252
- position: absolute;
253
- top: 50%;
254
- left: 50%;
255
- display: block;
256
- transform: translate(-50%, -50%);
257
- border-radius: 100%;
258
- background-color: #3bc635;
259
- opacity: 0;
260
- transition-property: opacity;
261
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
262
- transition-duration: 150ms;
263
- }
264
-
265
- .card_selected:checked {
266
- border: 1px #3bc635 solid;
267
- position: relative;
268
- width: 16px;
269
- height: 16px;
270
- min-width: 16px;
271
- appearance: none;
272
- cursor: pointer;
273
- border-radius: 100%;
274
- color: #3bc635;
275
- transition-property: all;
276
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
277
- transition-duration: 150ms;
278
- }
279
-
280
- .card_selected:checked:before {
281
- content: "";
282
- border: 1px #3bc635 solid;
283
- width: 8px;
284
- height: 8px;
285
- position: absolute;
286
- top: 50%;
287
- left: 50%;
288
- display: block;
289
- transform: translate(-50%, -50%);
290
- border-radius: 100%;
291
- background-color: #3bc635;
292
- opacity: 50;
293
- transition-property: opacity;
294
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
295
- transition-duration: 150ms;
296
- }
297
-
298
- .card_selected:hover:before {
299
- width: 8px;
300
- height: 8px;
301
- content: "";
302
- position: absolute;
303
- top: 50%;
304
- left: 50%;
305
- display: block;
306
- transform: translate(-50%, -50%);
307
- border-radius: 100%;
308
- background-color: #3bc635;
309
- transition-property: opacity;
310
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
311
- transition-duration: 150ms;
312
- opacity: 10;
313
- }
314
-
315
-
316
- .error-custom-inputs-tonder {
317
- background-color: white;
318
- position: absolute;
319
- left: 0px;
320
- bottom: -4px;
321
- width: 100%;
322
- font-size: 12px;
323
- color: red;
324
- }
325
-
326
- .expiration-year .error-custom-inputs-tonder {
327
- background-color: white;
328
- position: absolute;
329
- left: 0px;
330
- bottom: 3px;
331
- width: 100%;
332
- font-size: 12px;
333
- color: red;
334
- }
335
- </style>
336
- `
337
-
338
- export const cardItemsTemplate = (cards) => {
339
-
340
- const cardItemsHTML = cards.reduce((total, card) => {
341
- return `${total}
342
- <div class="card-item" id="card_container-${card.skyflow_id}">
343
- <input id="${card.skyflow_id}" class="card_selected" name="card_selected" type="radio"/>
344
- <label class="card-item-label" for="${card.skyflow_id}">
345
- <img class="card-image" src="${getCardType(card.card_scheme)}" />
346
- <div class="card-number">${card.card_number}</div>
347
- <div class="card-expiration">Exp. ${card.expiration_month}/${card.expiration_year}</div>
348
- <div class="card-delete-icon">
349
- <button id="delete_button_${card.skyflow_id}" class="card-delete-button">
350
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px">
351
- <path fill="currentColor" d="M292.309-140.001q-30.308 0-51.308-21t-21-51.308V-720h-40v-59.999H360v-35.384h240v35.384h179.999V-720h-40v507.691q0 30.308-21 51.308t-51.308 21H292.309ZM376.155-280h59.999v-360h-59.999v360Zm147.691 0h59.999v-360h-59.999v360Z"/>
352
- </svg>
353
- </button>
354
- </div>
355
- </label>
356
- </div>`
357
- }, ``);
358
-
359
- const cardItemStyle = `
360
20
  <style>
361
- .card-item-label {
362
- display: flex;
363
- justify-content: space-between;
364
- align-items: center;
365
- color: #1D1D1D;
366
- gap: 33% 20px;
367
- margin-top: 15px;
368
- margin-bottom: 15px;
369
- width: 100%;
21
+ @import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap");
22
+ :root {
23
+ --tndr-gray-dark: ${COLORS.grayDark};
24
+ --tndr-gray-medium: ${COLORS.grayMedium};
25
+ --tndr-white: ${COLORS.white};
26
+ --tndr-black: ${COLORS.black};
27
+ --tndr-purple: ${COLORS.purple};
28
+ --tndr-border-light: ${COLORS.borderLight};
29
+ --tndr-border-dark: ${COLORS.borderDark};
30
+ --tndr-red-extra-light: ${COLORS.redExtraLight};
31
+ --tndr-red: ${COLORS.red};
32
+ --tndr-green-extra-light: ${COLORS.greenExtraLight};
33
+ --tndr-green: ${COLORS.green};
34
+ --tndr-border-medium: ${COLORS.borderMedium};
35
+ --tndr-gray-extra-light: ${COLORS.grayExtraLight};
370
36
  }
371
-
372
- .card-item {
37
+ .container-tonder {
38
+ background-color: var(--tndr-white);
39
+ margin: 0 auto !important;
40
+ padding: 0;
41
+ overflow: hidden;
42
+ transition: max-height 0.5s ease-out;
43
+ max-width: 600px;
44
+ border: solid 1px var(--tndr-border-light);
373
45
  position: relative;
374
- display: flex;
375
- justify-content: start;
376
- align-items: center;
377
- gap: 33% 15px;
378
- border-bottom: 1px solid #e2e8f0;
379
- padding: 0px 30px;
380
- }
381
-
382
- .card-item .card-number {
383
- font-size: 16px;
384
- }
385
-
386
- .card-item .card-expiration {
387
- font-size: 16px;
46
+ font-family: ${getFontFamily(data)};
47
+ border-radius: 11px;
388
48
  }
389
-
390
- .card-image {
391
- width: 39px;
392
- height: 24px;
393
- text-align: left;
394
- }
395
-
396
- .card-delete-button {
397
- background-color: transparent !important;
398
- color: #000000 !important;
399
- border: none;
400
- }
401
-
402
- .card-delete-button:hover {
403
- background-color: transparent !important;
404
- color: #D91C1C !important;
49
+ .tndr-hide-text {
50
+ color: transparent;
51
+ font-size: 1px;
405
52
  }
406
53
  .card_selected {
54
+ background-color: #F5F5F5;
407
55
  position: relative;
408
- width: 16px;
409
- min-width: 16px;
410
- height: 16px;
56
+ width: 25px;
57
+ height: 25px;
58
+ min-width: 25px;
411
59
  appearance: none;
412
60
  cursor: pointer;
413
61
  border-radius: 100%;
414
- border: 1px #bababa solid;
415
- color: #3bc635;
62
+ border: 1px var(--tndr-black) solid;
63
+ color: var(--tndr-white);
416
64
  transition-property: all;
417
65
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
418
66
  transition-duration: 150ms;
67
+ margin: 0 3px 0 0;
68
+ }
69
+ .card_selected:focus {
70
+ outline: none;
419
71
  }
420
-
421
72
  .card_selected:before {
422
- width: 8px;
423
- height: 8px;
73
+ width: 10px;
74
+ height: 10px;
424
75
  content: "";
425
76
  position: absolute;
426
77
  top: 50%;
@@ -428,7 +79,7 @@ export const cardItemsTemplate = (cards) => {
428
79
  display: block;
429
80
  transform: translate(-50%, -50%);
430
81
  border-radius: 100%;
431
- background-color: #3bc635;
82
+ background-color: var(--tndr-white);
432
83
  opacity: 0;
433
84
  transition-property: opacity;
434
85
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
@@ -436,15 +87,16 @@ export const cardItemsTemplate = (cards) => {
436
87
  }
437
88
 
438
89
  .card_selected:checked {
439
- border: 1px #3bc635 solid;
90
+ border: 1px var(--tndr-black) solid;
440
91
  position: relative;
441
- width: 16px;
442
- height: 16px;
443
- min-width: 16px;
92
+ width: 25px;
93
+ height: 25px;
94
+ min-width: 25px;
444
95
  appearance: none;
445
96
  cursor: pointer;
446
97
  border-radius: 100%;
447
- color: #3bc635;
98
+ color: var(--tndr-white);
99
+ background-color: var(--tndr-black);
448
100
  transition-property: all;
449
101
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
450
102
  transition-duration: 150ms;
@@ -452,16 +104,16 @@ export const cardItemsTemplate = (cards) => {
452
104
 
453
105
  .card_selected:checked:before {
454
106
  content: "";
455
- border: 1px #3bc635 solid;
456
- width: 8px;
457
- height: 8px;
107
+ border: 0;
108
+ width: 9px;
109
+ height: 9px;
458
110
  position: absolute;
459
111
  top: 50%;
460
112
  left: 50%;
461
113
  display: block;
462
114
  transform: translate(-50%, -50%);
463
115
  border-radius: 100%;
464
- background-color: #3bc635;
116
+ background-color: var(--tndr-white);
465
117
  opacity: 50;
466
118
  transition-property: opacity;
467
119
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
@@ -469,8 +121,8 @@ export const cardItemsTemplate = (cards) => {
469
121
  }
470
122
 
471
123
  .card_selected:hover:before {
472
- width: 8px;
473
- height: 8px;
124
+ width: 9px;
125
+ height: 9px;
474
126
  content: "";
475
127
  position: absolute;
476
128
  top: 50%;
@@ -478,69 +130,900 @@ export const cardItemsTemplate = (cards) => {
478
130
  display: block;
479
131
  transform: translate(-50%, -50%);
480
132
  border-radius: 100%;
481
- background-color: #3bc635;
133
+ background-color: var(--tndr-white);
482
134
  transition-property: opacity;
483
135
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
484
136
  transition-duration: 150ms;
485
137
  opacity: 10;
486
138
  }
139
+ .card-item-label,
140
+ .apm-item-label {
141
+ display: flex;
142
+ align-items: center;
143
+ color: var(--tndr-gray-medium);
144
+ gap: 12px;
145
+ margin-top: 10px;
146
+ margin-bottom: 10px;
147
+ width: 100%;
148
+ }
149
+ .ac {
150
+ background-color: transparent !important;
151
+ margin-bottom: 0 !important;
152
+ }
153
+ .ac-option-panel-container{
154
+ padding: ${renderPaymentButton ? "20px 30px 35px 30px" : "0px 30px 35px 30px"};
155
+ }
156
+ .pm-pay-button,
157
+ .card-pay-button{
158
+ display: block;
159
+ opacity: 0;
160
+ transform: translateY(10px);
161
+ transition: opacity 0.3s ease, transform 0.3s ease;
162
+ }
163
+ .error-container {
164
+ display: none;
165
+ color: var(--tndr-red) !important;
166
+ background-color: var(--tndr-red-extra-light) !important;
167
+ margin-bottom: 13px !important;
168
+ font-size: 14px !important;
169
+ padding: 10px 10px !important;
170
+ border-radius: 5px !important;
171
+ text-align: left !important;
172
+ align-items: center;
173
+ gap: 8px;
174
+ margin-top: 15px;
175
+ }
176
+
177
+ .message-container {
178
+ display: none;
179
+ color: var(--tndr-green) !important;
180
+ background-color: var(--tndr-green-extra-light) !important;
181
+ margin-bottom: 13px !important;
182
+ font-size: 14px !important;
183
+ padding: 10px 10px !important;
184
+ border-radius: 5px !important;
185
+ text-align: left !important;
186
+ align-items: center;
187
+ gap: 8px;
188
+ margin-top: ${renderPaymentButton ? "0px" : "15px"};
189
+ }
190
+ .error-container p,
191
+ .message-container p {
192
+ margin: 0;
193
+ }
194
+ .tndr-button {
195
+ font-size: 16px;
196
+ font-weight: 400;
197
+ min-height: 2.3rem;
198
+ border-radius: 5px;
199
+ cursor: pointer;
200
+ width: 100%;
201
+ padding: .5em 1em;
202
+ text-align: center;
203
+ border: none;
204
+ color: var(--tndr-white);
205
+ margin-bottom: 0;
206
+ font-family: "Inter", sans-serif;
207
+ }
208
+ .pay-button {
209
+ background-color: var(--tndr-black);
210
+ }
211
+ .cancel-button {
212
+ background-color: #e9e9e9;
213
+ color: var(--tndr-black);
214
+ }
215
+ .pay-button-text,
216
+ .cancel-button-text{
217
+ margin: .4em 0;
218
+ }
219
+ [data-theme="dark"] .container-tonder {
220
+ background-color: var(--tndr-gray-dark);
221
+ }
222
+ [data-theme="dark"] .card-item-label {
223
+ color: var(--tndr-white);
224
+ }
225
+ [data-theme="dark"] .apm-item-label {
226
+ color: var(--tndr-white);
227
+ }
228
+ [data-theme="dark"] .card-item-label-new {
229
+ color: var(--tndr-white);
230
+ }
231
+ [data-theme="dark"] .checkbox label {
232
+ color: var(--tndr-white);
233
+ }
234
+ [data-theme="dark"] .card_selected:checked {
235
+ background-color: var(--tndr-purple);
236
+ border: none;
237
+ }
238
+ [data-theme="dark"] .card_selected:checked:before {
239
+ background-color: var(--tndr-gray-dark);
240
+ }
241
+ [data-theme="dark"] .card_selected:hover:before {
242
+ background-color: var(--tndr-gray-dark);
243
+ }
244
+ [data-theme="dark"] .card_selected:before {
245
+ background-color: var(--tndr-gray-dark);
246
+ }
247
+ [data-theme="dark"] .card_selected {
248
+ background-color: #5C5C5C;
249
+ border: 1px var(--tndr-border-dark) solid;
250
+ }
251
+ [data-theme="dark"] .card-delete-button svg path {
252
+ fill: var(--tndr-white);
253
+ }
254
+ [data-theme="dark"] .pay-button {
255
+ background-color: var(--tndr-purple);
256
+ }
257
+ [data-theme="dark"] .cancel-button {
258
+ background-color: var(--tndr-gray-dark);
259
+ color: var(--tndr-white);
260
+ }
261
+ [data-theme="dark"] .tndr-footer-logos {
262
+ border: 1px solid var(--tndr-border-medium);
263
+ }
264
+ [data-theme="dark"] .tndr-footer .tndr-footer-secure p {
265
+ color: var(--tndr-gray-extra-light);
266
+ }
267
+ </style>
268
+ `;
269
+ };
270
+
271
+ export const cardTemplate = data => {
272
+ const displayMode = data.customization?.displayMode || DISPLAY_MODE.light;
273
+ const isDarkMode = displayMode === DISPLAY_MODE.dark;
274
+ const defaultStylesData = getDefaultStyles(isDarkMode);
275
+ const showPaymentButton = get(data, FIELD_PATH_NAMES.paymentButton, false);
276
+ const showCancelButton = get(data, FIELD_PATH_NAMES.cancelButton, false);
277
+
278
+ const existCardsOrPaymentMethods =
279
+ data.cardsData.length > 0 || data.paymentMethodsData.length > 0;
280
+ const paddingTopContainerForm = existCardsOrPaymentMethods ? "5px" : "30px";
281
+ const { cardLabel, cvvLabel, expiryDateLabel, nameLabel } = getCardFormLabels(
282
+ data.customStyles,
283
+ ).labels;
284
+
285
+ return `
286
+ ${data?.customization?.saveCards?.showSaved ? `<div id="${data.collectorIds.cardsListContainer}" class="cards-list-container"></div>` : ``}
287
+ ${
288
+ existCardsOrPaymentMethods && data?.customization?.cardForm?.show
289
+ ? `
290
+ <div class="pay-new-card">
291
+ <input checked id="new" class="card_selected" name="card_selected" type="radio"/>
292
+ <label class="card-item-label-new" for="new">
293
+ <img class="card-image" src="${getCardType("XXXX", displayMode === DISPLAY_MODE.dark)}" alt="" />
294
+ <div class="card-number">Tarjeta</div>
295
+ </label>
296
+ </div>
297
+ `
298
+ : ``
299
+ }
300
+ ${
301
+ data?.customization?.cardForm?.show
302
+ ? `
303
+ <div class="container-form">
304
+ <div id="${data.collectorIds.holderName}" class="empty-div tndr-card-holder"></div>
305
+ <div id="${data.collectorIds.cardNumber}" class="empty-div tndr-card-number"></div>
306
+ <div class="collect-row">
307
+ <div class="containerExpirationDate">
308
+ <label class="tndr-form-label">${expiryDateLabel}</label>
309
+ <div class="containerExpirationDateInput">
310
+ <div id="${data.collectorIds.expirationMonth}" class="empty-div empty-div-date"></div>
311
+ <div id="${data.collectorIds.expirationYear}" class="empty-div empty-div-date"></div>
312
+ </div>
313
+ </div>
314
+ <div class="cvvContainerCard" id="cvvContainerCard">
315
+ <label class="tndr-form-label">${cvvLabel}</label>
316
+ <div id="${data.collectorIds.cvv}" class="empty-div card-collect-cvv empty-div-date">
317
+ <div class="tndr-simulate-input-cvv-container">
318
+ <div class="tndr-simulate-input-cvv">
319
+ ${
320
+ isDarkMode
321
+ ? `
322
+ <svg class="cvvIconCard" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="40" height="24" viewBox="0 0 78 52">
323
+ <image id="BBVA_136_2x" data-name="BBVA – 136@2x" width="78" height="52" xlink:href=""/>
324
+ </svg>
325
+ `
326
+ : `
327
+ <svg class="cvvIconCard" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="40" height="24" viewBox="0 0 270 178">
328
+ <defs>
329
+ <linearGradient id="linear-gradient" x1="0.5" x2="0.5" y2="1" gradientUnits="objectBoundingBox">
330
+ <stop offset="0" stop-color="#386bbf"/>
331
+ <stop offset="1" stop-color="#032ea3"/>
332
+ </linearGradient>
333
+ <linearGradient id="linear-gradient-2" x1="0.5" y1="0.115" x2="0.5" y2="1" gradientUnits="objectBoundingBox">
334
+ <stop offset="0" stop-color="#1c1c1c"/>
335
+ <stop offset="1" stop-color="#151515"/>
336
+ </linearGradient>
337
+ </defs>
338
+ <g id="Grupo_3" data-name="Grupo 3" transform="translate(-69 -312)">
339
+ <g id="Grupo_2" data-name="Grupo 2">
340
+ <rect id="Rectángulo_58" data-name="Rectángulo 58" width="253" height="165" rx="25" transform="translate(69 312)" fill="url(#linear-gradient)"/>
341
+ <rect id="Rectángulo_61" data-name="Rectángulo 61" width="68" height="8" rx="4" transform="translate(86 437)" fill="#fff" opacity="0.877"/>
342
+ <rect id="Rectángulo_66" data-name="Rectángulo 66" width="253" height="24" transform="translate(69 347)" fill="url(#linear-gradient-2)"/>
343
+ <g id="Elipse_4" data-name="Elipse 4" transform="translate(221 374)" fill="#fff" stroke="#191919" stroke-width="1">
344
+ <ellipse cx="59" cy="58" rx="59" ry="58" stroke="none"/>
345
+ <ellipse cx="59" cy="58" rx="58.5" ry="57.5" fill="none"/>
346
+ </g>
347
+ </g>
348
+ <text id="_123" data-name="123" transform="translate(240 448)" font-size="45" font-family="Menlo-Regular, Menlo"><tspan x="0" y="0">123</tspan></text>
349
+ </g>
350
+ </svg>
351
+ `
352
+ }
353
+ <input tabindex="-1"/>
354
+ </div>
355
+ </div>
356
+ </div>
357
+ </div>
358
+ </div>
359
+ ${
360
+ !!data.customization?.saveCards?.showSaveCardOption
361
+ ? `
362
+ <div class="checkbox" id="save-card-container">
363
+ <input id="save-checkout-card" type="checkbox">
364
+ <label for="save-checkout-card">
365
+ Guardar tarjeta para futuros pagos
366
+ </label>
367
+ </div>
368
+ `
369
+ : ``
370
+ }
371
+ ${buttonAndMessagesTemplate({
372
+ ...data,
373
+ showPaymentButton,
374
+ showCancelButton,
375
+ classContainerButton: "container-pay-button",
376
+ classPayButton: "tndr-button pay-button hidden",
377
+ classCancelButton: "tndr-button cancel-button hidden",
378
+ tonderPayButtonId: data.collectorIds.tonderPayButton,
379
+ tonderCancelButtonId: data.collectorIds.tonderCancelButton,
380
+ msgErrorId: data.collectorIds.msgError,
381
+ msgErrorTextId: data.collectorIds.msgErrorText,
382
+ msgNotificationId: data.collectorIds.msgNotification,
383
+ msgNotificationTextId: data.collectorIds.msgNotificationText,
384
+ })}
385
+ </div>
386
+ `
387
+ : ``
388
+ }
389
+ ${
390
+ data?.customization?.paymentMethods?.show
391
+ ? `
392
+ <div id="${data.collectorIds.apmsListContainer}" class="apms-list-container"></div>
393
+ `
394
+ : ``
395
+ }
396
+ <div class="tndr-footer">
397
+ <div class="tndr-footer-secure">
398
+ <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 33 33">
399
+ <image id="Material_Icon_Lock_1_" data-name="Material Icon Lock (1)" width="33" height="33" xlink:href=""/>
400
+ </svg>
401
+ <p>Pagos seguros con Tonder</p>
402
+ </div>
403
+ <div class="tndr-footer-logos">
404
+ <img class="tndr-pci-logo" src="${COMMON_LOGOS.pci}" alt="pci"/>
405
+ <div class="tndr-footer-logos-divider"></div>
406
+ ${
407
+ isDarkMode
408
+ ? `
409
+ <img class="tndr-tonder-logo" src="${COMMON_LOGOS.tonderWhite}" alt="tonder"/>
410
+ `
411
+ : `
412
+ <img class="tndr-tonder-logo" src="${COMMON_LOGOS.tonderBlue}" alt="tonder"/>
413
+ `
414
+ }
415
+ </div>
416
+ </div>
417
+ <style>
418
+ .container-pay-button{
419
+ padding-top: ${!!showPaymentButton ? "25px" : ""};
420
+ }
421
+ .container-cancel-button{
422
+ padding-top: ${showCancelButton ? "10px" : "0"};
423
+ padding-bottom: 0;
424
+ }
425
+ .container-form {
426
+ padding: ${!!showPaymentButton ? `${paddingTopContainerForm} 30px 35px 30px` : `${paddingTopContainerForm} 30px 35px 30px`};
427
+ }
428
+
429
+ .collect-row {
430
+ display: flex;
431
+ flex-wrap: wrap;
432
+ justify-content: space-between;
433
+ width: 100% !important;
434
+ gap: 16px;
435
+ }
436
+
437
+ .collect-row > * {
438
+ flex: 1 1 calc(50% - 8px);
439
+ box-sizing: border-box;
440
+ }
441
+ .containerExpirationDate{
442
+ display: flex;
443
+ flex-direction: column;
444
+ align-items: flex-start;
445
+ justify-content: flex-end;
446
+ }
447
+ .tndr-form-label{
448
+ line-height: ${data?.customStyles?.labelStyles?.base?.lineHeight ? data?.customStyles?.labelStyles?.base?.lineHeight : "22px"};
449
+ color: ${data?.customStyles?.labelStyles?.base?.color ? data?.customStyles?.labelStyles?.base?.color : defaultStylesData.labelStyles.base.color};
450
+ font-size: ${data?.customStyles?.labelStyles?.base?.fontSize ? data?.customStyles?.labelStyles?.base?.fontSize : defaultStylesData.labelStyles.base.fontSize};
451
+ font-family: ${data?.customStyles?.labelStyles?.base?.fontFamily ? data?.customStyles?.labelStyles?.base?.fontFamily : defaultStylesData.labelStyles.base.fontFamily};
452
+ font-weight: ${data?.customStyles?.labelStyles?.base?.fontWeight ? data?.customStyles?.labelStyles?.base?.fontWeight : defaultStylesData.labelStyles.base.fontWeight};
453
+ text-align: ${data?.customStyles?.labelStyles?.base?.textAlign ? data?.customStyles?.labelStyles?.base?.textAlign : defaultStylesData.labelStyles.base.textAlign};
454
+ }
455
+
456
+ .containerExpirationDateInput{
457
+ display: flex;
458
+ align-items: center;
459
+ }
460
+ .expiration-year {
461
+ position: relative !important;
462
+ /*padding-top: 12px !important;*/
463
+ }
464
+ .empty-div {
465
+ position: relative;
466
+ margin-top: 2px;
467
+ margin-bottom: 4px;
468
+ }
469
+ .tndr-card-holder {
470
+ height: ${nameLabel === "" ? "60px" : "80px"};
471
+ }
472
+ .tndr-card-number {
473
+ height: ${cardLabel === "" ? "60px" : "80px"};
474
+ }
475
+ .empty-div-date {
476
+ height: 60px !important;
477
+ }
478
+ .card-collect-cvv{
479
+ width: 100%;
480
+ }
481
+
482
+ .hidden{
483
+ display: none;
484
+ }
485
+ .cvvContainerCard{
486
+ position: relative;
487
+ padding: 0;
488
+ display: flex;
489
+ flex-direction: column;
490
+ align-items: flex-start;
491
+ justify-content: flex-end;
492
+ }
493
+ .cvvIconCard {
494
+ position: absolute;
495
+ right: -12px;
496
+ top: 50%;
497
+ transform: translate(-50%, -50%);
498
+ }
499
+ .spinner-tndr {
500
+ width: 30px;
501
+ height: 30px;
502
+ border: 2px solid var(--tndr-white);
503
+ border-bottom-color: transparent;
504
+ border-radius: 50%;
505
+ display: inline-block;
506
+ box-sizing: border-box;
507
+ animation: spin-tndr 1s linear infinite;
508
+ }
509
+ .tndr-footer{
510
+ padding: 70px 20px 40px 20px;
511
+ display: flex;
512
+ flex-wrap: wrap;
513
+ align-items: center;
514
+ justify-content: center;
515
+ gap: 20px;
516
+ border-top: solid 1px var(--tndr-border-light);
517
+ }
518
+ .tndr-footer .tndr-footer-secure {
519
+ display: flex;
520
+ align-items: center;
521
+ gap: 5px;
522
+ text-align: start;
523
+ }
524
+ .tndr-footer .tndr-footer-secure p {
525
+ margin: 0;
526
+ color: #999999;
527
+ font-size: 14px;
528
+ }
529
+ .tndr-footer .tndr-footer-logos {
530
+ display: flex;
531
+ align-items: center;
532
+ border: 1px solid var(--tndr-border-medium);
533
+ border-radius: 30px;
534
+ font-weight: 400;
535
+ gap: 12px;
536
+ padding: 8px 12px;
537
+ }
538
+ .tndr-footer .tndr-footer-logos img {
539
+ width: 100%;
540
+ height: auto;
541
+ object-fit: contain;
542
+ }
543
+ .tndr-pci-logo {
544
+ max-width: 30px;
545
+ }
546
+ .tndr-tonder-logo {
547
+ max-width: 80px;
548
+ }
549
+ .tndr-footer-logos-divider{
550
+ width: .1px;
551
+ height: 24px;
552
+ background-color: #CCCCCC;
553
+ }
554
+ .tndr-simulate-input-cvv-container{
555
+ height: 100%;
556
+ width: 100%;
557
+ position: absolute;
558
+ pointer-events: none;
559
+
560
+ }
561
+ .tndr-simulate-input-cvv {
562
+ width: 100%;
563
+ pointer-events: none;
564
+ position: relative;
565
+ }
566
+ .tndr-simulate-input-cvv-container label{
567
+ line-height: ${data?.customStyles?.labelStyles?.base?.lineHeight ? data?.customStyles?.labelStyles?.base?.lineHeight : ""};
568
+ color: transparent;
569
+ font-size: ${data?.customStyles?.labelStyles?.base?.fontSize ? data?.customStyles?.labelStyles?.base?.fontSize : defaultStylesData.labelStyles.base.fontSize};
570
+ font-family: ${data?.customStyles?.labelStyles?.base?.fontFamily ? data?.customStyles?.labelStyles?.base?.fontFamily : defaultStylesData.labelStyles.base.fontFamily};
571
+ font-weight: ${data?.customStyles?.labelStyles?.base?.fontWeight ? data?.customStyles?.labelStyles?.base?.fontWeight : defaultStylesData.labelStyles.base.fontWeight};
572
+ text-align: ${data?.customStyles?.labelStyles?.base?.textAlign ? data?.customStyles?.labelStyles?.base?.textAlign : defaultStylesData.labelStyles.base.textAlign};
573
+ pointer-events: none;
574
+ }
575
+ .tndr-simulate-input-cvv input {
576
+ width: 100%;
577
+ margin: 0;
578
+ padding: 0;
579
+ border: 0;
580
+ min-height: 44px;
581
+ background-color: transparent;
582
+ pointer-events: none;
583
+ }
584
+
585
+
586
+ @keyframes spin-tndr {
587
+ 0% {
588
+ transform: rotate(0deg);
589
+ }
590
+ 100% {
591
+ transform: rotate(360deg);
592
+ }
593
+ }
594
+
595
+ .global-loader {
596
+ position: absolute;
597
+ top: 0;
598
+ left: 0;
599
+ width: 100%;
600
+ height: 100%;
601
+ z-index: 1;
602
+ }
603
+
604
+ @media screen and (max-width: 600px) {
605
+ .payment_method_zplit {
606
+ font-size: 16px !important;
607
+ width: 100% !important;
608
+ }
609
+
610
+ .payment_method_zplit label img {
611
+ display: none !important;
612
+ }
613
+ }
614
+
615
+ .checkbox label {
616
+ margin-left: 8px;
617
+ font-size: 14px;
618
+ font-weight: 600;
619
+ color: var(--tndr-gray-medium);
620
+ }
621
+
622
+ .checkbox {
623
+ margin-top: 10px;
624
+ margin-bottom: 10px;
625
+ text-align: left;
626
+ padding: 0;
627
+ display: flex;
628
+ align-items: center;
629
+ }
630
+
631
+ .checkbox input{
632
+ appearance: none;
633
+ margin: 0;
634
+ min-width: 20px;
635
+ border-radius: 3px;
636
+ width: 20px;
637
+ height: 20px;
638
+ border: 1px solid var(--tndr-border-light);
639
+ position: relative;
640
+ }
641
+
642
+ .checkbox input:checked {
643
+ background-color: var(--tndr-black);
644
+ }
645
+
646
+ .checkbox input:checked::after {
647
+ content: '';
648
+ position: absolute;
649
+ top: 2px;
650
+ left: 6px;
651
+ width: 4px;
652
+ height: 10px;
653
+ border: solid white;
654
+ border-width: 0 2px 2px 0;
655
+ transform: rotate(45deg);
656
+ }
657
+
658
+ .cards-list-container {
659
+ display: flex;
660
+ flex-direction: column;
661
+ padding: 0;
662
+ gap: 33% 20px;
663
+ }
664
+
665
+ .apms-list-container {
666
+ display: flex;
667
+ flex-direction: column;
668
+ gap: 33% 20px;
669
+ max-height: 300px;
670
+ overflow-y: auto;
671
+ }
672
+ .pay-new-card {
673
+ display: flex;
674
+ justify-content: start;
675
+ align-items: center;
676
+ color: var(--tndr-gray-medium);
677
+ gap: 12px;
678
+ margin-top: 5px;
679
+ padding: 5px 30px;
680
+ position: relative;
681
+ }
682
+
683
+ .pay-new-card .card-number {
684
+ font-size: 14px;
685
+ font-weight: 600;
686
+ }
687
+ .card-image {
688
+ width: 39px;
689
+ height: 24px;
690
+ text-align: left;
691
+ }
692
+
693
+ .card-item-label-new {
694
+ display: flex;
695
+ justify-content: start;
696
+ align-items: center;
697
+ color: var(--tndr-gray-medium);
698
+ gap: 12px;
699
+ margin-top: 10px;
700
+ margin-bottom: 10px;
701
+ width: 100%;
702
+ }
703
+
704
+ .error-custom-inputs-tonder {
705
+ background-color: white;
706
+ position: absolute;
707
+ left: 0;
708
+ bottom: -4px;
709
+ width: 100%;
710
+ font-size: 12px;
711
+ color: red;
712
+ }
713
+
714
+ .expiration-year .error-custom-inputs-tonder {
715
+ background-color: white;
716
+ position: absolute;
717
+ left: 0;
718
+ bottom: 3px;
719
+ width: 100%;
720
+ font-size: 12px;
721
+ color: red;
722
+ }
723
+ @media screen and (max-width: 450px) and (min-width: 364px) {
724
+ .tndr-footer-logos-divider{
725
+ width: 1px;
726
+ }
727
+ }
728
+
729
+ @media screen and (max-width: 363px) {
730
+ .tndr-footer-logos-divider{
731
+ width: 2px;
732
+ }
733
+ }
734
+ @media screen and (max-width: 768px) {
735
+ .tndr-pci-logo {
736
+ max-width: 25px;
737
+ }
738
+ .tndr-tonder-logo {
739
+ max-width: 60px;
740
+ }
741
+ .tndr-footer {
742
+ padding: 70px 0 40px 0;
743
+ }
744
+ }
745
+ @media screen and (max-width: 420px) {
746
+ .collect-row > * {
747
+ flex: 1 1 100%;
748
+ }
749
+ .collect-row {
750
+ gap: 0;
751
+ flex-direction: column;
752
+ }
753
+ }
754
+ </style>
755
+ `;
756
+ };
757
+
758
+ export const cardItemsTemplate = data => {
759
+ const displayMode = data.customization?.displayMode || DISPLAY_MODE.light;
760
+ const isDarkMode = displayMode === DISPLAY_MODE.dark;
761
+ const showPaymentButton = get(data, FIELD_PATH_NAMES.paymentButton, false);
762
+ const showCancelButton = get(data, FIELD_PATH_NAMES.cancelButton, false);
763
+ const { cvvLabel } = getCardFormLabels(data.customStyles).labels;
764
+ console.log("cvvLabel", cvvLabel);
765
+ const cardItemsHTML = data.cards.reduce((total, card) => {
766
+ return `${total}
767
+ <div class="ac ac-cards" id="option_container-${card.skyflow_id}">
768
+ <div class="card-item" >
769
+ <input id="${card.skyflow_id}" class="cards card_selected" name="card_selected" type="radio"/>
770
+ <label class="card-item-label" for="${card.skyflow_id}">
771
+ <div class="card-item-data">
772
+ <img class="card-image" src="${getCardType(card.card_scheme, displayMode === DISPLAY_MODE.dark)}" alt="" />
773
+ <div class="card-number">${card.card_number}</div>
774
+ <div class="card-expiration">Exp. ${card.expiration_month}/${card.expiration_year}</div>
775
+ </div>
776
+ <div class="card-delete-icon">
777
+ <button id="delete_button_${card.skyflow_id}" class="card-delete-button">
778
+ <svg xmlns="http://www.w3.org/2000/svg" width="14" height="18" viewBox="0 0 26.972 30.898">
779
+ <path id="Delete_Icon" data-name="Delete Icon" d="M165.057-809.1a3.218,3.218,0,0,1-2.381-1.008,3.336,3.336,0,0,1-.99-2.425V-834.85H160v-3.433h8.429V-840h10.114v1.717h8.429v3.433h-1.686v22.315a3.336,3.336,0,0,1-.99,2.425,3.218,3.218,0,0,1-2.381,1.008Zm3.371-6.866H171.8v-15.449h-3.371Zm6.743,0h3.371v-15.449h-3.371Z" transform="translate(-160 840)"/>
780
+ </svg>
781
+ </button>
782
+ </div>
783
+ </label>
784
+ </div>
785
+ <div class="ac-panel">
786
+ <div class="ac-option-panel-container" id="acContainer${card.skyflow_id}">
787
+ <div class="cvvContainer" id="cvvContainer${card.skyflow_id}">
788
+ <label class="tndr-form-label label-cvv-cards">${cvvLabel}</label>
789
+ <div id="${data.collectorIds.cvv}${card.skyflow_id}" class="empty-div">
790
+ <div class="tndr-simulate-input-cvv-container">
791
+ <div class="tndr-simulate-input-cvv">
792
+ ${
793
+ isDarkMode
794
+ ? `
795
+ <svg class="cvvIcon" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="40" height="24" viewBox="0 0 78 52">
796
+ <image id="BBVA_136_2x" data-name="BBVA – 136@2x" width="78" height="52" xlink:href=""/>
797
+ </svg>
798
+ `
799
+ : `
800
+ <svg class="cvvIcon" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="40" height="24" viewBox="0 0 270 178">
801
+ <defs>
802
+ <linearGradient id="linear-gradient" x1="0.5" x2="0.5" y2="1" gradientUnits="objectBoundingBox">
803
+ <stop offset="0" stop-color="#386bbf"/>
804
+ <stop offset="1" stop-color="#032ea3"/>
805
+ </linearGradient>
806
+ <linearGradient id="linear-gradient-2" x1="0.5" y1="0.115" x2="0.5" y2="1" gradientUnits="objectBoundingBox">
807
+ <stop offset="0" stop-color="#1c1c1c"/>
808
+ <stop offset="1" stop-color="#151515"/>
809
+ </linearGradient>
810
+ </defs>
811
+ <g id="Grupo_3" data-name="Grupo 3" transform="translate(-69 -312)">
812
+ <g id="Grupo_2" data-name="Grupo 2">
813
+ <rect id="Rectángulo_58" data-name="Rectángulo 58" width="253" height="165" rx="25" transform="translate(69 312)" fill="url(#linear-gradient)"/>
814
+ <rect id="Rectángulo_61" data-name="Rectángulo 61" width="68" height="8" rx="4" transform="translate(86 437)" fill="#fff" opacity="0.877"/>
815
+ <rect id="Rectángulo_66" data-name="Rectángulo 66" width="253" height="24" transform="translate(69 347)" fill="url(#linear-gradient-2)"/>
816
+ <g id="Elipse_4" data-name="Elipse 4" transform="translate(221 374)" fill="#fff" stroke="#191919" stroke-width="1">
817
+ <ellipse cx="59" cy="58" rx="59" ry="58" stroke="none"/>
818
+ <ellipse cx="59" cy="58" rx="58.5" ry="57.5" fill="none"/>
819
+ </g>
820
+ </g>
821
+ <text id="_123" data-name="123" transform="translate(240 448)" font-size="45" font-family="Menlo-Regular, Menlo"><tspan x="0" y="0">123</tspan></text>
822
+ </g>
823
+ </svg>
824
+ `
825
+ }
826
+ <input tabindex="-1"/>
827
+ </div>
828
+ </div>
829
+ </div>
830
+
831
+ </div>
832
+ ${buttonAndMessagesTemplate({
833
+ ...data,
834
+ showPaymentButton,
835
+ showCancelButton,
836
+ classContainerButton: "container-pay-button",
837
+ classPayButton: "card-pay-button tndr-button pay-button",
838
+ classCancelButton: "card-pay-button tndr-button cancel-button",
839
+ tonderPayButtonId: `${data.collectorIds.tonderPayButton}${card.skyflow_id}`,
840
+ tonderCancelButtonId: `${data.collectorIds.tonderCancelButton}${card.skyflow_id}`,
841
+ msgErrorId: `${data.collectorIds.msgError}${card.skyflow_id}`,
842
+ msgErrorTextId: `${data.collectorIds.msgErrorText}${card.skyflow_id}`,
843
+ msgNotificationId: `${data.collectorIds.msgNotification}${card.skyflow_id}`,
844
+ msgNotificationTextId: `${data.collectorIds.msgNotificationText}${card.skyflow_id}`,
845
+ })}
846
+
847
+ </div>
848
+ </div>
849
+ </div>`;
850
+ }, "");
851
+ const cardItemStyle = `
852
+ <style>
853
+ .ac-cards{
854
+ border: none;
855
+ border-bottom: 1px solid var(--tndr-border-light);
856
+ }
857
+ .cvvContainer{
858
+ max-width: 50%;
859
+ position: relative;
860
+ padding: 0 0 0 40px;
861
+ }
862
+ .label-cvv-cards {
863
+ opacity: 0;
864
+ }
865
+ .cvvIcon {
866
+ position: absolute;
867
+ right: -12px;
868
+ top: 21px;
869
+ opacity: 0;
870
+ transform: translate(-50%, 10px);
871
+ transition: opacity 0.3s ease, transform 0.3s ease;
872
+ }
873
+ .cvvContainer.show .label-cvv-cards{
874
+ opacity: 1;
875
+ transition-delay: 0.3s;
876
+ }
877
+ .cvvContainer.show .cvvIcon {
878
+ opacity: 1;
879
+ transform: translate(-50%,-50%);
880
+ transition-delay: 0.3s;
881
+ }
882
+ .ac-option-panel-container.show .card-pay-button {
883
+ opacity: 1;
884
+ transform: translateY(0);
885
+ transition-delay: 0.3s;
886
+ }
887
+ .card-item-label {
888
+ justify-content: space-between;
889
+ }
890
+ .card-item-data{
891
+ display: flex;
892
+ justify-content: space-between;
893
+ align-items: center;
894
+ gap: 12px;
895
+ }
896
+ .card-item {
897
+ position: relative;
898
+ display: flex;
899
+ justify-content: start;
900
+ align-items: center;
901
+ gap: 12px;
902
+ padding: 5px 30px;
903
+ }
904
+
905
+ .card-item .card-number,
906
+ .card-item .card-expiration {
907
+ font-size: 14px;
908
+ font-weight: 600;
909
+ }
910
+ .card-item .card-expiration {
911
+ margin-left: 2.5em;
912
+ }
913
+ .card-image {
914
+ width: 39px;
915
+ height: 24px;
916
+ text-align: left;
917
+ }
487
918
 
919
+ .card-delete-button {
920
+ background-color: transparent !important;
921
+ color: var(--tndr-black);
922
+ border: none;
923
+ padding: 0;
924
+ display: flex;
925
+ align-items: center;
926
+ }
927
+
928
+ .card-delete-button:hover {
929
+ background-color: transparent !important;
930
+ color: #D91C1C !important;
931
+ }
932
+
933
+ @media screen and (max-width: 768px) {
934
+ .cvvContainer {
935
+ max-width: 60%;
936
+ }
937
+ }
938
+
939
+ @media screen and (max-width: 480px) {
940
+ .cvvContainer {
941
+ max-width: 100%;
942
+ }
943
+ }
488
944
  </style>
489
- `
490
- const cardItem = `
491
- ${cardItemsHTML}
945
+ `;
946
+ return `
947
+ <div class="accordion-container">
948
+ ${cardItemsHTML}
949
+ </div>
492
950
  ${cardItemStyle}
493
- `
494
- return cardItem;
495
- }
951
+ `;
952
+ };
496
953
 
497
- export const apmItemsTemplate = (apms) => {
954
+ export const apmItemsTemplate = data => {
955
+ const showPaymentButton = get(data, FIELD_PATH_NAMES.paymentButton, false);
956
+ const showCancelButton = get(data, FIELD_PATH_NAMES.cancelButton, false);
498
957
 
499
- const apmItemsHTML = apms.reduce((total, apm) => {
958
+ const apmItemsHTML = data.paymentMethods.reduce((total, apm) => {
500
959
  const apm_data = getPaymentMethodDetails(apm.payment_method);
501
960
  return `${total}
502
- <div class="apm-item" id="card_container-${apm.pk}">
503
- <input id="${apm.pk}" class="card_selected" name="card_selected" type="radio"/>
504
- <label class="apm-item-label" for="${apm.pk}">
505
-
506
- <div class="apm-image">
507
- <div class="apm-image-border"></div>
508
- <img src="${apm_data.icon}" />
509
- </div>
510
- <div class="apm-name">${apm_data.label}</div>
511
- </label>
512
- </div>`
961
+ <div class="ac ac-paymentMethods" id="option_container-${apm.pk}">
962
+ <div class="apm-item">
963
+ <input id="${apm.pk}" class="paymentMethods card_selected" name="card_selected" type="radio"/>
964
+ <label class="apm-item-label" for="${apm.pk}">
965
+
966
+ <div class="apm-image">
967
+ <div class="apm-image-border"></div>
968
+ <img src="${apm_data.icon}" alt="${apm_data.label}" />
969
+ </div>
970
+ <div class="apm-name">${apm_data.label}</div>
971
+ </label>
972
+ </div>
973
+ <div class="ac-panel">
974
+ <div class="ac-option-panel-container tndr-pm-item-container" id="acContainer${apm.pk}">
975
+ <div class="tndr-hide-text">accordion</div>
976
+ ${buttonAndMessagesTemplate({
977
+ ...data,
978
+ showPaymentButton,
979
+ showCancelButton,
980
+ classContainerButton: "container-pay-button",
981
+ classPayButton: "pm-pay-button tndr-button pay-button",
982
+ classCancelButton: "pm-pay-button tndr-button cancel-button",
983
+ tonderPayButtonId: `${data.collectorIds.tonderPayButton}${apm.pk}`,
984
+ tonderCancelButtonId: `${data.collectorIds.tonderCancelButton}${apm.pk}`,
985
+ msgErrorId: `${data.collectorIds.msgError}${apm.pk}`,
986
+ msgErrorTextId: `${data.collectorIds.msgErrorText}${apm.pk}`,
987
+ msgNotificationId: `${data.collectorIds.msgNotification}${apm.pk}`,
988
+ msgNotificationTextId: `${data.collectorIds.msgNotificationText}${apm.pk}`,
989
+ })}
990
+
991
+ </div>
992
+ </div>
993
+ </div>`;
513
994
  }, ``);
514
995
 
515
996
  const apmItemStyle = `
516
997
  <style>
998
+ .ac-option-panel-container{
999
+ padding-top: 10px;
1000
+ }
1001
+ .ac-paymentMethods{
1002
+ border: none;
1003
+ border-top: 1px solid var(--tndr-border-light);
1004
+ }
517
1005
  .apm-item-label {
518
- display: flex;
519
1006
  justify-content: flex-start;
520
- align-items: center;
521
- color: #1D1D1D;
522
- gap: 33% 10px;
523
- margin-top: 15px;
524
- margin-bottom: 15px;
525
- width: 100%;
526
1007
  }
527
-
528
1008
  .apm-item {
529
1009
  position: relative;
530
1010
  display: flex;
531
1011
  justify-content: start;
532
1012
  align-items: center;
533
- gap: 33% 15px;
534
- border-bottom: 1px solid #e2e8f0;
535
- padding: 0px 30px;
1013
+ gap: 22px;
1014
+ padding: 5px 30px;
536
1015
  }
537
-
538
- .apm-item:first-child {
539
- border-top: 1px solid #e2e8f0;
1016
+ .ac-option-panel-container.show .pm-pay-button {
1017
+ opacity: 1;
1018
+ transform: translateY(0);
1019
+ }
1020
+ .ac-option-panel-container.tndr-pm-item-container{
1021
+ padding-top: 0;
540
1022
  }
541
1023
 
542
1024
  .apm-item .apm-name {
543
- font-size: 16px;
1025
+ font-size: 14px;
1026
+ font-weight: 600;
544
1027
  }
545
1028
  .apm-image {
546
1029
  width: 30px;
@@ -563,99 +1046,59 @@ export const apmItemsTemplate = (apms) => {
563
1046
  width: 100%;
564
1047
  height: 97%;
565
1048
  }
1049
+ </style>
1050
+ `;
1051
+ return `
1052
+ <div class="accordion-container-apm">
1053
+ ${apmItemsHTML}
1054
+ </div>
1055
+ ${apmItemStyle}
1056
+ `;
1057
+ };
566
1058
 
567
- .card_selected {
568
- position: relative;
569
- width: 16px;
570
- min-width: 16px;
571
- height: 16px;
572
- appearance: none;
573
- cursor: pointer;
574
- border-radius: 100%;
575
- border: 1px #bababa solid;
576
- color: #3bc635;
577
- transition-property: all;
578
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
579
- transition-duration: 150ms;
1059
+ const buttonAndMessagesTemplate = data => {
1060
+ return `
1061
+ ${
1062
+ data.showPaymentButton
1063
+ ? `
1064
+ <div class="${data.classContainerButton}">
1065
+ <button id="${data.tonderPayButtonId}" class="${data.classPayButton}">${data.customization?.paymentButton?.text}</button>
1066
+ </div>
1067
+ `
1068
+ : ``
580
1069
  }
581
-
582
- .card_selected:before {
583
- width: 8px;
584
- height: 8px;
585
- content: "";
586
- position: absolute;
587
- top: 50%;
588
- left: 50%;
589
- display: block;
590
- transform: translate(-50%, -50%);
591
- border-radius: 100%;
592
- background-color: #3bc635;
593
- opacity: 0;
594
- transition-property: opacity;
595
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
596
- transition-duration: 150ms;
1070
+ ${
1071
+ data.showCancelButton
1072
+ ? `
1073
+ <div class="container-cancel-button">
1074
+ <button type="button" id="${data.tonderCancelButtonId}" class="${data.classCancelButton}">${data.customization?.cancelButton?.text}</button>
1075
+ </div>
1076
+ `
1077
+ : ``
597
1078
  }
598
-
599
- .card_selected:checked {
600
- border: 1px #3bc635 solid;
601
- position: relative;
602
- width: 16px;
603
- height: 16px;
604
- min-width: 16px;
605
- appearance: none;
606
- cursor: pointer;
607
- border-radius: 100%;
608
- color: #3bc635;
609
- transition-property: all;
610
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
611
- transition-duration: 150ms;
612
- }
613
-
614
- .card_selected:checked:before {
615
- content: "";
616
- border: 1px #3bc635 solid;
617
- width: 8px;
618
- height: 8px;
619
- position: absolute;
620
- top: 50%;
621
- left: 50%;
622
- display: block;
623
- transform: translate(-50%, -50%);
624
- border-radius: 100%;
625
- background-color: #3bc635;
626
- opacity: 50;
627
- transition-property: opacity;
628
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
629
- transition-duration: 150ms;
1079
+ ${
1080
+ data?.customization?.showMessages
1081
+ ? `
1082
+ <div id="${data.msgErrorId}" class="error-container">
1083
+ <svg xmlns="http://www.w3.org/2000/svg" width="18" height="17" viewBox="0 0 28.25 27.828">
1084
+ <path id="Cancel_Icon" data-name="Cancel Icon" d="M89.04-859.129l5.085-5.009,5.085,5.009,1.978-1.948L96.1-866.086l5.085-5.009-1.978-1.948-5.085,5.009-5.085-5.009L87.063-871.1l5.085,5.009-5.085,5.009Zm5.085,6.957a13.935,13.935,0,0,1-5.509-1.1,14.276,14.276,0,0,1-4.485-2.974,14.04,14.04,0,0,1-3.019-4.418A13.375,13.375,0,0,1,80-866.086a13.374,13.374,0,0,1,1.112-5.426,14.041,14.041,0,0,1,3.019-4.418,14.277,14.277,0,0,1,4.485-2.974,13.932,13.932,0,0,1,5.509-1.1,13.933,13.933,0,0,1,5.509,1.1,14.278,14.278,0,0,1,4.485,2.974,14.041,14.041,0,0,1,3.019,4.418,13.374,13.374,0,0,1,1.112,5.426,13.375,13.375,0,0,1-1.112,5.426,14.04,14.04,0,0,1-3.019,4.418,14.276,14.276,0,0,1-4.485,2.974A13.935,13.935,0,0,1,94.125-852.172Z" transform="translate(-80 880)" fill="#832828"/>
1085
+ </svg>
1086
+ <p id="${data.msgErrorTextId}"></p>
1087
+ </div>
1088
+ <div id="${data.msgNotificationId}" class="message-container">
1089
+ <svg xmlns="http://www.w3.org/2000/svg" width="18" height="17" viewBox="0 0 28.25 27.828">
1090
+ <path id="Check_Circle_Icon" data-name="Check Circle Icon" d="M92.147-859.686l9.958-9.809-1.977-1.948-7.981,7.861-4.026-3.965L86.144-865.6Zm1.978,7.513a13.935,13.935,0,0,1-5.509-1.1,14.278,14.278,0,0,1-4.485-2.974,14.041,14.041,0,0,1-3.019-4.418A13.374,13.374,0,0,1,80-866.086a13.374,13.374,0,0,1,1.112-5.426,14.041,14.041,0,0,1,3.019-4.418,14.278,14.278,0,0,1,4.485-2.974,13.935,13.935,0,0,1,5.509-1.1,13.935,13.935,0,0,1,5.509,1.1,14.278,14.278,0,0,1,4.485,2.974,14.041,14.041,0,0,1,3.019,4.418,13.374,13.374,0,0,1,1.112,5.426,13.374,13.374,0,0,1-1.112,5.426,14.041,14.041,0,0,1-3.019,4.418,14.278,14.278,0,0,1-4.485,2.974A13.935,13.935,0,0,1,94.125-852.172Z" transform="translate(-80 880)" fill="#28832c"/>
1091
+ </svg>
1092
+ <p id="${data.msgNotificationTextId}"></p>
1093
+ </div>
1094
+ `
1095
+ : ``
630
1096
  }
631
1097
 
632
- .card_selected:hover:before {
633
- width: 8px;
634
- height: 8px;
635
- content: "";
636
- position: absolute;
637
- top: 50%;
638
- left: 50%;
639
- display: block;
640
- transform: translate(-50%, -50%);
641
- border-radius: 100%;
642
- background-color: #3bc635;
643
- transition-property: opacity;
644
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
645
- transition-duration: 150ms;
646
- opacity: 10;
647
- }
648
-
649
- </style>
650
- `
651
- const apmItem = `
652
- ${apmItemsHTML}
653
- ${apmItemStyle}
654
- `
655
- return apmItem;
656
- }
1098
+ `;
1099
+ };
657
1100
 
658
- const getFontFamily = (data) => {
1101
+ const getFontFamily = data => {
659
1102
  const base = data?.customStyles?.labelStyles?.base;
660
1103
  return base?.fontFamily || '"Inter", sans-serif';
661
- };
1104
+ };