tonder-web-sdk 1.16.3 → 1.16.6-beta.DEV-1433.2

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 (106) hide show
  1. package/README.md +22 -25
  2. package/package.json +10 -3
  3. package/types/common.d.ts +4 -0
  4. package/v1/bundle.min.js +1 -18
  5. package/.env-example +0 -1
  6. package/.husky/pre-commit +0 -4
  7. package/.prettierignore +0 -8
  8. package/.prettierrc +0 -10
  9. package/cypress/e2e/1-getting-started/todo.cy.js +0 -143
  10. package/cypress/e2e/2-advanced-examples/actions.cy.js +0 -299
  11. package/cypress/e2e/2-advanced-examples/aliasing.cy.js +0 -39
  12. package/cypress/e2e/2-advanced-examples/assertions.cy.js +0 -176
  13. package/cypress/e2e/2-advanced-examples/connectors.cy.js +0 -98
  14. package/cypress/e2e/2-advanced-examples/cookies.cy.js +0 -118
  15. package/cypress/e2e/2-advanced-examples/cypress_api.cy.js +0 -185
  16. package/cypress/e2e/2-advanced-examples/files.cy.js +0 -85
  17. package/cypress/e2e/2-advanced-examples/location.cy.js +0 -32
  18. package/cypress/e2e/2-advanced-examples/misc.cy.js +0 -104
  19. package/cypress/e2e/2-advanced-examples/navigation.cy.js +0 -56
  20. package/cypress/e2e/2-advanced-examples/network_requests.cy.js +0 -163
  21. package/cypress/e2e/2-advanced-examples/querying.cy.js +0 -114
  22. package/cypress/e2e/2-advanced-examples/spies_stubs_clocks.cy.js +0 -201
  23. package/cypress/e2e/2-advanced-examples/storage.cy.js +0 -110
  24. package/cypress/e2e/2-advanced-examples/traversal.cy.js +0 -121
  25. package/cypress/e2e/2-advanced-examples/utilities.cy.js +0 -108
  26. package/cypress/e2e/2-advanced-examples/viewport.cy.js +0 -58
  27. package/cypress/e2e/2-advanced-examples/waiting.cy.js +0 -30
  28. package/cypress/e2e/2-advanced-examples/window.cy.js +0 -22
  29. package/cypress/fixtures/example.json +0 -5
  30. package/cypress/support/commands.js +0 -25
  31. package/cypress/support/e2e.js +0 -20
  32. package/cypress.config.js +0 -9
  33. package/eslint.config.mjs +0 -15
  34. package/index.js.example +0 -50
  35. package/samples/react/README.md +0 -70
  36. package/samples/react/build/asset-manifest.json +0 -16
  37. package/samples/react/build/favicon.ico +0 -0
  38. package/samples/react/build/index.html +0 -1
  39. package/samples/react/build/logo192.png +0 -0
  40. package/samples/react/build/logo512.png +0 -0
  41. package/samples/react/build/manifest.json +0 -25
  42. package/samples/react/build/robots.txt +0 -3
  43. package/samples/react/build/static/css/main.073c9b0a.css +0 -2
  44. package/samples/react/build/static/css/main.073c9b0a.css.map +0 -1
  45. package/samples/react/build/static/js/787.b83ed06f.chunk.js +0 -2
  46. package/samples/react/build/static/js/787.b83ed06f.chunk.js.map +0 -1
  47. package/samples/react/build/static/js/main.0a848807.js +0 -3
  48. package/samples/react/build/static/js/main.0a848807.js.LICENSE.txt +0 -39
  49. package/samples/react/build/static/js/main.0a848807.js.map +0 -1
  50. package/samples/react/build/static/media/sdk-icons.b491623214b2af4cccdb.png +0 -0
  51. package/samples/react/package-lock.json +0 -28973
  52. package/samples/react/package.json +0 -44
  53. package/samples/react/public/favicon.ico +0 -0
  54. package/samples/react/public/index.html +0 -43
  55. package/samples/react/public/logo192.png +0 -0
  56. package/samples/react/public/logo512.png +0 -0
  57. package/samples/react/public/manifest.json +0 -25
  58. package/samples/react/public/robots.txt +0 -3
  59. package/samples/react/src/App.css +0 -38
  60. package/samples/react/src/App.js +0 -22
  61. package/samples/react/src/App.test.js +0 -8
  62. package/samples/react/src/assets/img/sdk-icons.png +0 -0
  63. package/samples/react/src/components/Cart.js +0 -29
  64. package/samples/react/src/components/ProductCard.js +0 -27
  65. package/samples/react/src/context/CartContext.js +0 -116
  66. package/samples/react/src/index.css +0 -13
  67. package/samples/react/src/index.js +0 -17
  68. package/samples/react/src/logo.svg +0 -1
  69. package/samples/react/src/reportWebVitals.js +0 -13
  70. package/samples/react/src/screens/Checkout.js +0 -82
  71. package/samples/react/src/screens/Store.js +0 -21
  72. package/samples/react/src/setupTests.js +0 -5
  73. package/samples/react/src/storeProducts.js +0 -30
  74. package/src/classes/3dsHandler.js +0 -199
  75. package/src/classes/BaseInlineCheckout.js +0 -303
  76. package/src/classes/LiteInlineCheckout.js +0 -217
  77. package/src/classes/checkout.js +0 -129
  78. package/src/classes/globalLoader.js +0 -31
  79. package/src/classes/inlineCheckout.js +0 -713
  80. package/src/data/apmApi.js +0 -38
  81. package/src/data/businessApi.js +0 -16
  82. package/src/data/cardApi.js +0 -134
  83. package/src/data/checkoutApi.js +0 -92
  84. package/src/data/customerApi.js +0 -32
  85. package/src/data/index.js +0 -17
  86. package/src/data/openPayApi.js +0 -16
  87. package/src/data/skyflowApi.js +0 -16
  88. package/src/helpers/skyflow.js +0 -370
  89. package/src/helpers/styles.js +0 -90
  90. package/src/helpers/template-skeleton.js +0 -59
  91. package/src/helpers/template.js +0 -1104
  92. package/src/helpers/utils.js +0 -257
  93. package/src/helpers/validations.js +0 -53
  94. package/src/index-dev.js +0 -329
  95. package/src/index.html +0 -180
  96. package/src/index.js +0 -21
  97. package/src/shared/catalog/commonLogosCatalog.js +0 -7
  98. package/src/shared/catalog/paymentMethodsCatalog.js +0 -246
  99. package/src/shared/constants/colors.js +0 -15
  100. package/src/shared/constants/displayMode.js +0 -4
  101. package/src/shared/constants/fieldPathNames.js +0 -4
  102. package/src/shared/constants/htmlTonderIds.js +0 -18
  103. package/src/shared/constants/messages.js +0 -11
  104. package/src/shared/constants/paymentMethodAPM.js +0 -63
  105. package/src/shared/constants/tonderUrl.js +0 -8
  106. package/webpack.config.js +0 -77
@@ -1,1104 +0,0 @@
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";
11
-
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>
19
- </div>
20
- <style>
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};
36
- }
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);
45
- position: relative;
46
- font-family: ${getFontFamily(data)};
47
- border-radius: 11px;
48
- }
49
- .tndr-hide-text {
50
- color: transparent;
51
- font-size: 1px;
52
- }
53
- .card_selected {
54
- background-color: #F5F5F5;
55
- position: relative;
56
- width: 25px;
57
- height: 25px;
58
- min-width: 25px;
59
- appearance: none;
60
- cursor: pointer;
61
- border-radius: 100%;
62
- border: 1px var(--tndr-black) solid;
63
- color: var(--tndr-white);
64
- transition-property: all;
65
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
66
- transition-duration: 150ms;
67
- margin: 0 3px 0 0;
68
- }
69
- .card_selected:focus {
70
- outline: none;
71
- }
72
- .card_selected:before {
73
- width: 10px;
74
- height: 10px;
75
- content: "";
76
- position: absolute;
77
- top: 50%;
78
- left: 50%;
79
- display: block;
80
- transform: translate(-50%, -50%);
81
- border-radius: 100%;
82
- background-color: var(--tndr-white);
83
- opacity: 0;
84
- transition-property: opacity;
85
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
86
- transition-duration: 150ms;
87
- }
88
-
89
- .card_selected:checked {
90
- border: 1px var(--tndr-black) solid;
91
- position: relative;
92
- width: 25px;
93
- height: 25px;
94
- min-width: 25px;
95
- appearance: none;
96
- cursor: pointer;
97
- border-radius: 100%;
98
- color: var(--tndr-white);
99
- background-color: var(--tndr-black);
100
- transition-property: all;
101
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
102
- transition-duration: 150ms;
103
- }
104
-
105
- .card_selected:checked:before {
106
- content: "";
107
- border: 0;
108
- width: 9px;
109
- height: 9px;
110
- position: absolute;
111
- top: 50%;
112
- left: 50%;
113
- display: block;
114
- transform: translate(-50%, -50%);
115
- border-radius: 100%;
116
- background-color: var(--tndr-white);
117
- opacity: 50;
118
- transition-property: opacity;
119
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
120
- transition-duration: 150ms;
121
- }
122
-
123
- .card_selected:hover:before {
124
- width: 9px;
125
- height: 9px;
126
- content: "";
127
- position: absolute;
128
- top: 50%;
129
- left: 50%;
130
- display: block;
131
- transform: translate(-50%, -50%);
132
- border-radius: 100%;
133
- background-color: var(--tndr-white);
134
- transition-property: opacity;
135
- transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
136
- transition-duration: 150ms;
137
- opacity: 10;
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
- }
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
- }
944
- </style>
945
- `;
946
- return `
947
- <div class="accordion-container">
948
- ${cardItemsHTML}
949
- </div>
950
- ${cardItemStyle}
951
- `;
952
- };
953
-
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);
957
-
958
- const apmItemsHTML = data.paymentMethods.reduce((total, apm) => {
959
- const apm_data = getPaymentMethodDetails(apm.payment_method);
960
- return `${total}
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>`;
994
- }, ``);
995
-
996
- const apmItemStyle = `
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
- }
1005
- .apm-item-label {
1006
- justify-content: flex-start;
1007
- }
1008
- .apm-item {
1009
- position: relative;
1010
- display: flex;
1011
- justify-content: start;
1012
- align-items: center;
1013
- gap: 22px;
1014
- padding: 5px 30px;
1015
- }
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;
1022
- }
1023
-
1024
- .apm-item .apm-name {
1025
- font-size: 14px;
1026
- font-weight: 600;
1027
- }
1028
- .apm-image {
1029
- width: 30px;
1030
- height: 30px;
1031
- position: relative;
1032
- display: flex;
1033
- justify-content: center;
1034
- align-items: center;
1035
- }
1036
- .apm-image img {
1037
- width: auto;
1038
- height: 30px;
1039
- }
1040
- .apm-image-border{
1041
- position: absolute;
1042
- border: 1px solid #bababa36;
1043
- border-radius: 4px;
1044
- pointer-events: none;
1045
- box-sizing: border-box;
1046
- width: 100%;
1047
- height: 97%;
1048
- }
1049
- </style>
1050
- `;
1051
- return `
1052
- <div class="accordion-container-apm">
1053
- ${apmItemsHTML}
1054
- </div>
1055
- ${apmItemStyle}
1056
- `;
1057
- };
1058
-
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
- : ``
1069
- }
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
- : ``
1078
- }
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
- : ``
1096
- }
1097
-
1098
- `;
1099
- };
1100
-
1101
- const getFontFamily = data => {
1102
- const base = data?.customStyles?.labelStyles?.base;
1103
- return base?.fontFamily || '"Inter", sans-serif';
1104
- };