rebill-web-components-sdk 1.8.5 → 1.8.6

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 (54) hide show
  1. package/dist/cjs/apm-checkout_16.cjs.entry.js +1 -1
  2. package/dist/cjs/{get-payment-method-display-name-oo6lOpoC.js → get-payment-method-display-name-C6mdzTEs.js} +86 -86
  3. package/dist/cjs/{get-payment-method-display-name-oo6lOpoC.js.map → get-payment-method-display-name-C6mdzTEs.js.map} +1 -1
  4. package/dist/cjs/{index-N1yCtvXq.js → index-DLv8bgA4.js} +3 -3
  5. package/dist/cjs/{index-N1yCtvXq.js.map → index-DLv8bgA4.js.map} +1 -1
  6. package/dist/cjs/{jspdf.es.min-BW0eLZgN.js → jspdf.es.min-CV0yEJ9o.js} +4 -4
  7. package/dist/cjs/{jspdf.es.min-BW0eLZgN.js.map → jspdf.es.min-CV0yEJ9o.js.map} +1 -1
  8. package/dist/cjs/otp-component_7.cjs.entry.js +1 -1
  9. package/dist/cjs/renewal-success-page_2.cjs.entry.js +1 -1
  10. package/dist/collection/utils/pdf-generator.js +1 -1
  11. package/dist/collection/utils/pdf-generator.js.map +1 -1
  12. package/dist/collection/utils/receipt-Cardtemplate.js +81 -81
  13. package/dist/collection/utils/receipt-Cardtemplate.js.map +1 -1
  14. package/dist/components/apm-checkout.js +1 -1
  15. package/dist/components/{p-LFMU1iYh.js → p-1tbGUoeo.js} +4 -4
  16. package/dist/components/{p-LFMU1iYh.js.map → p-1tbGUoeo.js.map} +1 -1
  17. package/dist/components/{p-CMnoxL8G.js → p-BnidisYn.js} +3 -3
  18. package/dist/components/{p-CMnoxL8G.js.map → p-BnidisYn.js.map} +1 -1
  19. package/dist/components/{p-fwl9Z4PT.js → p-C1THyrZh.js} +3 -3
  20. package/dist/components/{p-fwl9Z4PT.js.map → p-C1THyrZh.js.map} +1 -1
  21. package/dist/components/{p-BBEMTBwW.js → p-C69QonMT.js} +3 -3
  22. package/dist/components/{p-BBEMTBwW.js.map → p-C69QonMT.js.map} +1 -1
  23. package/dist/components/{p-ByJrcRsN.js → p-DZI13wtJ.js} +3 -3
  24. package/dist/components/{p-ByJrcRsN.js.map → p-DZI13wtJ.js.map} +1 -1
  25. package/dist/components/{p-tWMR1_gF.js → p-fStqPH4y.js} +86 -86
  26. package/dist/components/p-fStqPH4y.js.map +1 -0
  27. package/dist/components/rebill-checkout.js +2 -2
  28. package/dist/components/rebill-renewal.js +2 -2
  29. package/dist/components/renewal-success-page.js +1 -1
  30. package/dist/components/success-page.js +1 -1
  31. package/dist/esm/apm-checkout_16.entry.js +1 -1
  32. package/dist/esm/{get-payment-method-display-name-Dj7gQJ-R.js → get-payment-method-display-name-B59DbHr6.js} +86 -86
  33. package/dist/esm/{get-payment-method-display-name-Dj7gQJ-R.js.map → get-payment-method-display-name-B59DbHr6.js.map} +1 -1
  34. package/dist/esm/{index-wfvNOgYw.js → index-DtxAsmPA.js} +3 -3
  35. package/dist/esm/{index-wfvNOgYw.js.map → index-DtxAsmPA.js.map} +1 -1
  36. package/dist/esm/{jspdf.es.min-ssPVxe3c.js → jspdf.es.min-APwmCmmv.js} +4 -4
  37. package/dist/esm/{jspdf.es.min-ssPVxe3c.js.map → jspdf.es.min-APwmCmmv.js.map} +1 -1
  38. package/dist/esm/otp-component_7.entry.js +1 -1
  39. package/dist/esm/renewal-success-page_2.entry.js +1 -1
  40. package/dist/rebill-web-components-sdk/{p-6762520a.entry.js → p-07de4442.entry.js} +2 -2
  41. package/dist/rebill-web-components-sdk/{p-DeorBmj5.js → p-2D2ZgtY0.js} +2 -2
  42. package/dist/rebill-web-components-sdk/{p-DeorBmj5.js.map → p-2D2ZgtY0.js.map} +1 -1
  43. package/dist/rebill-web-components-sdk/{p-075927af.entry.js → p-4e35c3c8.entry.js} +2 -2
  44. package/dist/rebill-web-components-sdk/{p-BldcNI96.js → p-D5uLuMja.js} +9 -9
  45. package/dist/rebill-web-components-sdk/{p-BldcNI96.js.map → p-D5uLuMja.js.map} +1 -1
  46. package/dist/rebill-web-components-sdk/{p-6b756131.entry.js → p-ce0793c8.entry.js} +2 -2
  47. package/dist/rebill-web-components-sdk/{p-BWqURJ0r.js → p-ymT8AXMV.js} +5 -5
  48. package/dist/rebill-web-components-sdk/{p-BWqURJ0r.js.map → p-ymT8AXMV.js.map} +1 -1
  49. package/dist/rebill-web-components-sdk/rebill-web-components-sdk.esm.js +1 -1
  50. package/package.json +1 -1
  51. package/dist/components/p-tWMR1_gF.js.map +0 -1
  52. /package/dist/rebill-web-components-sdk/{p-6762520a.entry.js.map → p-07de4442.entry.js.map} +0 -0
  53. /package/dist/rebill-web-components-sdk/{p-075927af.entry.js.map → p-4e35c3c8.entry.js.map} +0 -0
  54. /package/dist/rebill-web-components-sdk/{p-6b756131.entry.js.map → p-ce0793c8.entry.js.map} +0 -0
@@ -8,7 +8,7 @@ var timer = require('./timer-YTImGFi7.js');
8
8
  var breakpoint = require('./breakpoint-CWd4pcNv.js');
9
9
  var installmentUtils = require('./installment-utils-rLbihvh5.js');
10
10
  var assets = require('./assets-Bp8hbwFO.js');
11
- var html2canvas = require('./get-payment-method-display-name-oo6lOpoC.js');
11
+ var html2canvas = require('./get-payment-method-display-name-C6mdzTEs.js');
12
12
  var dateFormatter = require('./date-formatter-L8HvuOay.js');
13
13
  require('./_commonjsHelpers-B83fTs8d.js');
14
14
  require('./config-ClgjQet_.js');
@@ -5,7 +5,7 @@ var i18n_service = require('./i18n.service-CBqStnfo.js');
5
5
  var renewal_store = require('./renewal.store-CuNyxFHU.js');
6
6
  var breakpoint = require('./breakpoint-CWd4pcNv.js');
7
7
  var colorClassMapper = require('./color-class-mapper-CtKnrxwI.js');
8
- var html2canvas = require('./get-payment-method-display-name-oo6lOpoC.js');
8
+ var html2canvas = require('./get-payment-method-display-name-C6mdzTEs.js');
9
9
  var dateFormatter = require('./date-formatter-L8HvuOay.js');
10
10
  require('./_commonjsHelpers-B83fTs8d.js');
11
11
  require('./assets-Bp8hbwFO.js');
@@ -80,7 +80,7 @@ export class PDFGenerator {
80
80
  // Add to DOM temporarily
81
81
  document.body.appendChild(tempContainer);
82
82
  // Generate canvas from HTML
83
- const canvas = await html2canvas(tempContainer.querySelector('.container'), {
83
+ const canvas = await html2canvas(tempContainer.querySelector('.rb-receipt-container'), {
84
84
  backgroundColor: '#ffffff',
85
85
  scale: 2,
86
86
  useCORS: true,
@@ -1 +1 @@
1
- {"version":3,"file":"pdf-generator.js","sourceRoot":"","sources":["../../src/utils/pdf-generator.ts"],"names":[],"mappings":"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","sourcesContent":["import html2canvas from 'html2canvas';\nimport { DownloadTemplate, DownloadTemplateData } from './download-template';\nimport { ReceiptTemplate, ReceiptTemplateData } from './receipt-Cardtemplate';\n\nexport class PDFGenerator {\n /**\n * Generates and downloads a PDF from the payment instructions\n */\n public static async generateAndDownloadPDF(data: DownloadTemplateData): Promise<void> {\n try {\n // Dynamically import jsPDF to avoid build issues\n const { jsPDF } = await import('jspdf');\n // Create a temporary container for the HTML content\n const tempContainer = document.createElement('div');\n tempContainer.style.position = 'absolute';\n tempContainer.style.left = '-9999px';\n tempContainer.style.top = '-9999px';\n tempContainer.style.width = '600px';\n tempContainer.innerHTML = await DownloadTemplate.generateHTML(data);\n\n // Add to DOM temporarily\n document.body.appendChild(tempContainer);\n\n // Generate canvas from HTML\n const canvas = await html2canvas(tempContainer.querySelector('.container') as HTMLElement, {\n backgroundColor: '#ffffff',\n scale: 2,\n useCORS: true,\n allowTaint: false,\n width: 600,\n windowWidth: 600,\n });\n\n // Remove temporary container\n document.body.removeChild(tempContainer);\n\n // Create PDF\n const pdf = new jsPDF({\n orientation: 'portrait',\n unit: 'mm',\n format: 'a4',\n });\n\n // Calculate dimensions\n const imgData = canvas.toDataURL('image/png');\n const imgWidth = 190; // A4 width minus margins\n const pageHeight = 290; // A4 height minus margins\n const imgHeight = (canvas.height * imgWidth) / canvas.width;\n\n let heightLeft = imgHeight;\n let position = 10; // Top margin\n\n // Add first page\n pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);\n heightLeft -= pageHeight;\n\n // Add additional pages if needed\n while (heightLeft >= 0) {\n position = heightLeft - imgHeight + 10;\n pdf.addPage();\n pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);\n heightLeft -= pageHeight;\n }\n\n // Download the PDF\n const paymentMethodType = data.paymentMethod.toLowerCase();\n const filename = `payment-instructions-${paymentMethodType}.pdf`;\n pdf.save(filename);\n } catch (error) {\n console.error('Error generating PDF:', error);\n // Fallback: open in new window if PDF generation fails\n await this.fallbackToNewWindow(data);\n }\n }\n\n /**\n * Generates and downloads a PDF receipt for successful payments\n */\n public static async generateAndDownloadReceipt(data: ReceiptTemplateData): Promise<void> {\n try {\n // Dynamically import jsPDF to avoid build issues\n const { jsPDF } = await import('jspdf');\n // Create a temporary container for the HTML content\n const tempContainer = document.createElement('div');\n tempContainer.style.position = 'absolute';\n tempContainer.style.left = '-9999px';\n tempContainer.style.top = '-9999px';\n tempContainer.style.width = '360px';\n tempContainer.innerHTML = await ReceiptTemplate.generateHTML(data);\n\n // Add to DOM temporarily\n document.body.appendChild(tempContainer);\n\n // Generate canvas from HTML\n const canvas = await html2canvas(tempContainer.querySelector('.container') as HTMLElement, {\n backgroundColor: '#ffffff',\n scale: 2,\n useCORS: true,\n allowTaint: false,\n width: 360,\n windowWidth: 360,\n });\n\n // Remove temporary container\n document.body.removeChild(tempContainer);\n\n // Create PDF with custom size (smaller than A4)\n const pdf = new jsPDF({\n orientation: 'portrait',\n unit: 'mm',\n format: [120, 200], // Custom size: 120mm width x 200mm height\n });\n\n // Calculate dimensions for the smaller page\n const imgData = canvas.toDataURL('image/png');\n const imgWidth = 100; // Page width minus margins\n const pageHeight = 180; // Page height minus margins\n const imgHeight = (canvas.height * imgWidth) / canvas.width;\n\n let heightLeft = imgHeight;\n let position = 10; // Top margin\n\n // Add first page\n pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);\n heightLeft -= pageHeight;\n\n // Add additional pages if needed\n while (heightLeft >= 0) {\n position = heightLeft - imgHeight + 10;\n pdf.addPage();\n pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);\n heightLeft -= pageHeight;\n }\n\n // Download the PDF\n const filename = `payment-receipt-${new Date().getTime()}.pdf`;\n pdf.save(filename);\n } catch (error) {\n console.error('Error generating receipt PDF:', error);\n // Fallback: open in new window if PDF generation fails\n await this.fallbackToNewWindowReceipt(data);\n }\n }\n\n /**\n * Fallback method to open payment instructions in a new window\n */\n private static async fallbackToNewWindow(data: DownloadTemplateData): Promise<void> {\n const newWindow = window.open('', '_blank');\n if (newWindow) {\n newWindow.document.write(await DownloadTemplate.generateHTML(data));\n newWindow.document.close();\n }\n }\n\n /**\n * Fallback method to open receipt in a new window\n */\n private static async fallbackToNewWindowReceipt(data: ReceiptTemplateData): Promise<void> {\n const newWindow = window.open('', '_blank');\n if (newWindow) {\n const html = await ReceiptTemplate.generateHTML(data);\n newWindow.document.write(html);\n newWindow.document.close();\n }\n }\n}\n"]}
1
+ {"version":3,"file":"pdf-generator.js","sourceRoot":"","sources":["../../src/utils/pdf-generator.ts"],"names":[],"mappings":"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","sourcesContent":["import html2canvas from 'html2canvas';\nimport { DownloadTemplate, DownloadTemplateData } from './download-template';\nimport { ReceiptTemplate, ReceiptTemplateData } from './receipt-Cardtemplate';\n\nexport class PDFGenerator {\n /**\n * Generates and downloads a PDF from the payment instructions\n */\n public static async generateAndDownloadPDF(data: DownloadTemplateData): Promise<void> {\n try {\n // Dynamically import jsPDF to avoid build issues\n const { jsPDF } = await import('jspdf');\n // Create a temporary container for the HTML content\n const tempContainer = document.createElement('div');\n tempContainer.style.position = 'absolute';\n tempContainer.style.left = '-9999px';\n tempContainer.style.top = '-9999px';\n tempContainer.style.width = '600px';\n tempContainer.innerHTML = await DownloadTemplate.generateHTML(data);\n\n // Add to DOM temporarily\n document.body.appendChild(tempContainer);\n\n // Generate canvas from HTML\n const canvas = await html2canvas(tempContainer.querySelector('.container') as HTMLElement, {\n backgroundColor: '#ffffff',\n scale: 2,\n useCORS: true,\n allowTaint: false,\n width: 600,\n windowWidth: 600,\n });\n\n // Remove temporary container\n document.body.removeChild(tempContainer);\n\n // Create PDF\n const pdf = new jsPDF({\n orientation: 'portrait',\n unit: 'mm',\n format: 'a4',\n });\n\n // Calculate dimensions\n const imgData = canvas.toDataURL('image/png');\n const imgWidth = 190; // A4 width minus margins\n const pageHeight = 290; // A4 height minus margins\n const imgHeight = (canvas.height * imgWidth) / canvas.width;\n\n let heightLeft = imgHeight;\n let position = 10; // Top margin\n\n // Add first page\n pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);\n heightLeft -= pageHeight;\n\n // Add additional pages if needed\n while (heightLeft >= 0) {\n position = heightLeft - imgHeight + 10;\n pdf.addPage();\n pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);\n heightLeft -= pageHeight;\n }\n\n // Download the PDF\n const paymentMethodType = data.paymentMethod.toLowerCase();\n const filename = `payment-instructions-${paymentMethodType}.pdf`;\n pdf.save(filename);\n } catch (error) {\n console.error('Error generating PDF:', error);\n // Fallback: open in new window if PDF generation fails\n await this.fallbackToNewWindow(data);\n }\n }\n\n /**\n * Generates and downloads a PDF receipt for successful payments\n */\n public static async generateAndDownloadReceipt(data: ReceiptTemplateData): Promise<void> {\n try {\n // Dynamically import jsPDF to avoid build issues\n const { jsPDF } = await import('jspdf');\n // Create a temporary container for the HTML content\n const tempContainer = document.createElement('div');\n tempContainer.style.position = 'absolute';\n tempContainer.style.left = '-9999px';\n tempContainer.style.top = '-9999px';\n tempContainer.style.width = '360px';\n tempContainer.innerHTML = await ReceiptTemplate.generateHTML(data);\n\n // Add to DOM temporarily\n document.body.appendChild(tempContainer);\n\n // Generate canvas from HTML\n const canvas = await html2canvas(\n tempContainer.querySelector('.rb-receipt-container') as HTMLElement,\n {\n backgroundColor: '#ffffff',\n scale: 2,\n useCORS: true,\n allowTaint: false,\n width: 360,\n windowWidth: 360,\n },\n );\n\n // Remove temporary container\n document.body.removeChild(tempContainer);\n\n // Create PDF with custom size (smaller than A4)\n const pdf = new jsPDF({\n orientation: 'portrait',\n unit: 'mm',\n format: [120, 200], // Custom size: 120mm width x 200mm height\n });\n\n // Calculate dimensions for the smaller page\n const imgData = canvas.toDataURL('image/png');\n const imgWidth = 100; // Page width minus margins\n const pageHeight = 180; // Page height minus margins\n const imgHeight = (canvas.height * imgWidth) / canvas.width;\n\n let heightLeft = imgHeight;\n let position = 10; // Top margin\n\n // Add first page\n pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);\n heightLeft -= pageHeight;\n\n // Add additional pages if needed\n while (heightLeft >= 0) {\n position = heightLeft - imgHeight + 10;\n pdf.addPage();\n pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);\n heightLeft -= pageHeight;\n }\n\n // Download the PDF\n const filename = `payment-receipt-${new Date().getTime()}.pdf`;\n pdf.save(filename);\n } catch (error) {\n console.error('Error generating receipt PDF:', error);\n // Fallback: open in new window if PDF generation fails\n await this.fallbackToNewWindowReceipt(data);\n }\n }\n\n /**\n * Fallback method to open payment instructions in a new window\n */\n private static async fallbackToNewWindow(data: DownloadTemplateData): Promise<void> {\n const newWindow = window.open('', '_blank');\n if (newWindow) {\n newWindow.document.write(await DownloadTemplate.generateHTML(data));\n newWindow.document.close();\n }\n }\n\n /**\n * Fallback method to open receipt in a new window\n */\n private static async fallbackToNewWindowReceipt(data: ReceiptTemplateData): Promise<void> {\n const newWindow = window.open('', '_blank');\n if (newWindow) {\n const html = await ReceiptTemplate.generateHTML(data);\n newWindow.document.write(html);\n newWindow.document.close();\n }\n }\n}\n"]}
@@ -57,7 +57,7 @@ export class ReceiptTemplate {
57
57
  justify-content: center;
58
58
  }
59
59
 
60
- .container {
60
+ .rb-receipt-container {
61
61
  max-width: 360px;
62
62
  width: 100%;
63
63
  background: white;
@@ -67,7 +67,7 @@ export class ReceiptTemplate {
67
67
  margin: 20px;
68
68
  }
69
69
 
70
- .header {
70
+ .rb-receipt-header {
71
71
  display: flex;
72
72
  justify-content: flex-start;
73
73
  align-items: center;
@@ -77,7 +77,7 @@ export class ReceiptTemplate {
77
77
  border-bottom: 1px solid #e5e7eb;
78
78
  }
79
79
 
80
- .logo {
80
+ .rb-receipt-logo {
81
81
  display: flex;
82
82
  align-items: center;
83
83
  gap: 6px;
@@ -86,12 +86,12 @@ export class ReceiptTemplate {
86
86
  height: 24px;
87
87
  }
88
88
 
89
- .logo img {
89
+ .rb-receipt-logo img {
90
90
  max-height: 24px;
91
91
  max-width: 72px;
92
92
  }
93
93
 
94
- .main-content {
94
+ .rb-receipt-main-content {
95
95
  display: flex;
96
96
  justify-content: center;
97
97
  align-items: center;
@@ -99,7 +99,7 @@ export class ReceiptTemplate {
99
99
  min-height: 180px;
100
100
  }
101
101
 
102
- .success-content {
102
+ .rb-receipt-success-content {
103
103
  display: flex;
104
104
  flex-direction: column;
105
105
  align-items: center;
@@ -108,7 +108,7 @@ export class ReceiptTemplate {
108
108
  width: 100%;
109
109
  }
110
110
 
111
- .success-title {
111
+ .rb-receipt-success-title {
112
112
  font-size: 12px;
113
113
  font-weight: 700;
114
114
  color: #1f2937;
@@ -117,18 +117,18 @@ export class ReceiptTemplate {
117
117
  text-align: center;
118
118
  }
119
119
 
120
- .success-icon {
120
+ .rb-receipt-success-icon {
121
121
  display: flex;
122
122
  justify-content: center;
123
123
  margin: 3px 0;
124
124
  }
125
125
 
126
- .success-icon svg {
126
+ .rb-receipt-success-icon svg {
127
127
  width: 48px;
128
128
  height: 48px;
129
129
  }
130
130
 
131
- .info-card {
131
+ .rb-receipt-info-card {
132
132
  padding: 10px;
133
133
  gap: 6px;
134
134
  width: 270px;
@@ -140,7 +140,7 @@ export class ReceiptTemplate {
140
140
  margin-bottom: 6px;
141
141
  }
142
142
 
143
- .card-row {
143
+ .rb-receipt-card-row {
144
144
  display: flex;
145
145
  justify-content: space-between;
146
146
  align-items: center;
@@ -148,29 +148,29 @@ export class ReceiptTemplate {
148
148
  padding: 1px 0;
149
149
  }
150
150
 
151
- .card-row:last-of-type {
151
+ .rb-receipt-card-row:last-of-type {
152
152
  margin-bottom: 0;
153
153
  }
154
154
 
155
- .card-value {
155
+ .rb-receipt-card-value {
156
156
  display: flex;
157
157
  align-items: center;
158
158
  gap: 4px;
159
159
  }
160
160
 
161
- .card-label {
161
+ .rb-receipt-card-label {
162
162
  font-size: 7px;
163
163
  color: #6b7280;
164
164
  font-weight: 500;
165
165
  }
166
166
 
167
- .card-text {
167
+ .rb-receipt-card-text {
168
168
  font-size: 7px;
169
169
  color: #6b7280;
170
170
  font-weight: 600;
171
171
  }
172
172
 
173
- .installments-text {
173
+ .rb-receipt-installments-text {
174
174
  font-size: 7px;
175
175
  color: #6b7280;
176
176
  font-weight: 600;
@@ -179,31 +179,31 @@ export class ReceiptTemplate {
179
179
  line-height: 1.2;
180
180
  }
181
181
 
182
- .card-divider {
182
+ .rb-receipt-card-divider {
183
183
  height: 1px;
184
184
  background: #e5e7eb;
185
185
  margin: 6px 0;
186
186
  }
187
187
 
188
- .contact-info {
188
+ .rb-receipt-contact-info {
189
189
  text-align: left;
190
190
  margin-top: 6px;
191
191
  }
192
192
 
193
- .contact-text {
193
+ .rb-receipt-contact-text {
194
194
  font-size: 6px;
195
195
  color: #6b7280;
196
196
  margin-bottom: 1px;
197
197
  }
198
198
 
199
- .contact-email {
199
+ .rb-receipt-contact-email {
200
200
  font-size: 6px;
201
201
  color: #35B093;
202
202
  text-decoration: none;
203
203
  font-weight: 600;
204
204
  }
205
205
 
206
- .trial-pill {
206
+ .rb-receipt-trial-pill {
207
207
  background-color: #d1fae5;
208
208
  border-radius: 3px;
209
209
  padding: 2px 4px;
@@ -213,13 +213,13 @@ export class ReceiptTemplate {
213
213
  margin-right: 4px;
214
214
  }
215
215
 
216
- .trial-pill-text {
216
+ .rb-receipt-trial-pill-text {
217
217
  font-size: 6px;
218
218
  color: #059669;
219
219
  font-weight: 600;
220
220
  }
221
221
 
222
- .total-amount-container {
222
+ .rb-receipt-total-amount-container {
223
223
  display: flex;
224
224
  align-items: center;
225
225
  justify-content: flex-end;
@@ -227,32 +227,32 @@ export class ReceiptTemplate {
227
227
  flex-direction: row;
228
228
  }
229
229
 
230
- .next-charge-section {
230
+ .rb-receipt-next-charge-section {
231
231
  margin-top: 6px;
232
232
  padding-top: 6px;
233
233
  }
234
234
 
235
- .next-charge-header {
235
+ .rb-receipt-next-charge-header {
236
236
  display: flex;
237
237
  justify-content: space-between;
238
238
  align-items: flex-start;
239
239
  margin-bottom: 4px;
240
240
  }
241
241
 
242
- .next-charge-title {
242
+ .rb-receipt-next-charge-title {
243
243
  font-size: 7px;
244
244
  font-weight: 600;
245
245
  color: #1f2937;
246
246
  }
247
247
 
248
- .next-charge-date {
248
+ .rb-receipt-next-charge-date {
249
249
  font-size: 7px;
250
250
  font-weight: 600;
251
251
  color: #1f2937;
252
252
  text-align: right;
253
253
  }
254
254
 
255
- .next-charge-row {
255
+ .rb-receipt-next-charge-row {
256
256
  display: flex;
257
257
  justify-content: space-between;
258
258
  align-items: center;
@@ -260,13 +260,13 @@ export class ReceiptTemplate {
260
260
  padding: 1px 0;
261
261
  }
262
262
 
263
- .next-charge-description {
263
+ .rb-receipt-next-charge-description {
264
264
  font-size: 6px;
265
265
  color: #6b7280;
266
266
  font-weight: 500;
267
267
  }
268
268
 
269
- .next-charge-amount {
269
+ .rb-receipt-next-charge-amount {
270
270
  font-size: 6px;
271
271
  color: #6b7280;
272
272
  font-weight: 600;
@@ -278,7 +278,7 @@ export class ReceiptTemplate {
278
278
  padding: 0;
279
279
  }
280
280
 
281
- .container {
281
+ .rb-receipt-container {
282
282
  box-shadow: none;
283
283
  border: 1px solid #ddd;
284
284
  }
@@ -286,12 +286,12 @@ export class ReceiptTemplate {
286
286
  </style>
287
287
  </head>
288
288
  <body>
289
- <div class="container">
290
- <div class="main-content">
291
- <div class="success-content">
292
- <div class="success-title">${I18nService.translate('processing.successTitle')}</div>
289
+ <div class="rb-receipt-container">
290
+ <div class="rb-receipt-main-content">
291
+ <div class="rb-receipt-success-content">
292
+ <div class="rb-receipt-success-title">${I18nService.translate('processing.successTitle')}</div>
293
293
 
294
- <div class="success-icon">
294
+ <div class="rb-receipt-success-icon">
295
295
  <svg viewBox="0 0 96 96" fill="none" xmlns="http://www.w3.org/2000/svg">
296
296
  <path
297
297
  fill-rule="evenodd"
@@ -302,103 +302,103 @@ export class ReceiptTemplate {
302
302
  </svg>
303
303
  </div>
304
304
 
305
- <div class="info-card">
306
- <div class="card-row">
307
- <div class="card-label">${I18nService.translate('processing.paymentMethod')}</div>
308
- <div class="card-value">
305
+ <div class="rb-receipt-info-card">
306
+ <div class="rb-receipt-card-row">
307
+ <div class="rb-receipt-card-label">${I18nService.translate('processing.paymentMethod')}</div>
308
+ <div class="rb-receipt-card-value">
309
309
  ${data.isBankTransfer ? '' : getCardIconSVG(data.cardBrand)}
310
- <span class="card-text">${data.isBankTransfer ? I18nService.translate('paymentMethods.bank_transfer') : data.cardBrand && data.cardLastFour ? `${data.cardBrand} - ${data.cardLastFour}` : data.cardBrand || ''}</span>
310
+ <span class="rb-receipt-card-text">${data.isBankTransfer ? I18nService.translate('paymentMethods.bank_transfer') : data.cardBrand && data.cardLastFour ? `${data.cardBrand} - ${data.cardLastFour}` : data.cardBrand || ''}</span>
311
311
  </div>
312
312
  </div>
313
313
 
314
314
  ${data.installments
315
315
  ? `
316
- <div class="card-row">
317
- <div class="card-label">${I18nService.translate('summary.installments')}</div>
318
- <div class="installments-text">${data.installments}</div>
316
+ <div class="rb-receipt-card-row">
317
+ <div class="rb-receipt-card-label">${I18nService.translate('summary.installments')}</div>
318
+ <div class="rb-receipt-installments-text">${data.installments}</div>
319
319
  </div>
320
320
  `
321
321
  : ''}
322
322
 
323
323
  ${data.discountAmount
324
324
  ? `
325
- <div class="card-row">
326
- <div class="card-label">${I18nService.translate('summary.discount')}</div>
327
- <div class="card-text">${data.discountAmount}</div>
325
+ <div class="rb-receipt-card-row">
326
+ <div class="rb-receipt-card-label">${I18nService.translate('summary.discount')}</div>
327
+ <div class="rb-receipt-card-text">${data.discountAmount}</div>
328
328
  </div>
329
329
  `
330
330
  : ''}
331
- <div class="card-row">
332
- <div class="card-label">${I18nService.translate('processing.paymentDate')}</div>
333
- <div class="card-text">${data.paymentDate}</div>
331
+ <div class="rb-receipt-card-row">
332
+ <div class="rb-receipt-card-label">${I18nService.translate('processing.paymentDate')}</div>
333
+ <div class="rb-receipt-card-text">${data.paymentDate}</div>
334
334
  </div>
335
335
 
336
- <div class="card-row">
337
- <div class="card-label">${I18nService.translate('processing.paymentEmail')}</div>
338
- <div class="card-text">${data.email}</div>
336
+ <div class="rb-receipt-card-row">
337
+ <div class="rb-receipt-card-label">${I18nService.translate('processing.paymentEmail')}</div>
338
+ <div class="rb-receipt-card-text">${data.email}</div>
339
339
  </div>
340
340
 
341
- <div class="card-row">
342
- <div class="card-label">${I18nService.translate('processing.paymentReference')}</div>
343
- <div class="card-text">${data.referenceNumber}</div>
341
+ <div class="rb-receipt-card-row">
342
+ <div class="rb-receipt-card-label">${I18nService.translate('processing.paymentReference')}</div>
343
+ <div class="rb-receipt-card-text">${data.referenceNumber}</div>
344
344
  </div>
345
345
  </div>
346
346
 
347
- <div class="info-card">
348
- <div class="card-label" style="font-size: 8px; font-weight: 600; color: #1f2937; margin-bottom: 6px;">
347
+ <div class="rb-receipt-info-card">
348
+ <div class="rb-receipt-card-label" style="font-size: 8px; font-weight: 600; color: #1f2937; margin-bottom: 6px;">
349
349
  ${I18nService.translate('processing.purchaseDetails')}
350
350
  </div>
351
351
 
352
- <div class="card-row">
353
- <div class="card-label">${I18nService.translate('processing.purchaseDetail')}</div>
354
- <div class="card-text">${data.productTitle}</div>
352
+ <div class="rb-receipt-card-row">
353
+ <div class="rb-receipt-card-label">${I18nService.translate('processing.purchaseDetail')}</div>
354
+ <div class="rb-receipt-card-text">${data.productTitle}</div>
355
355
  </div>
356
356
 
357
357
  ${!data.trialPeriodDays
358
358
  ? `
359
- <div class="card-row">
360
- <div class="card-label">${I18nService.translate('processing.purchaseSubtotal')}</div>
361
- <div class="card-text">${data.subtotal}</div>
359
+ <div class="rb-receipt-card-row">
360
+ <div class="rb-receipt-card-label">${I18nService.translate('processing.purchaseSubtotal')}</div>
361
+ <div class="rb-receipt-card-text">${data.subtotal}</div>
362
362
  </div>
363
363
  `
364
364
  : ''}
365
365
 
366
- <div class="card-row">
367
- <div class="card-label">${I18nService.translate('processing.purchaseTotal')}</div>
368
- <div class="total-amount-container">
366
+ <div class="rb-receipt-card-row">
367
+ <div class="rb-receipt-card-label">${I18nService.translate('processing.purchaseTotal')}</div>
368
+ <div class="rb-receipt-total-amount-container">
369
369
  ${data.trialPeriodDays && data.trialPeriodDays > 0
370
370
  ? `
371
- <div class="trial-pill">
372
- <span class="trial-pill-text">${I18nService.translate('processing.trialPill', {
371
+ <div class="rb-receipt-trial-pill">
372
+ <span class="rb-receipt-trial-pill-text">${I18nService.translate('processing.trialPill', {
373
373
  days: data.trialPeriodDays,
374
374
  count: data.trialPeriodDays,
375
375
  })}</span>
376
376
  </div>
377
377
  `
378
378
  : ''}
379
- <div class="card-text">${data.total}</div>
379
+ <div class="rb-receipt-card-text">${data.total}</div>
380
380
  </div>
381
381
  </div>
382
382
 
383
383
  ${(data.trialPeriodDays && data.trialPeriodDays > 0) ||
384
384
  (data.debitDay && data.debitDay > 0)
385
385
  ? `
386
- <div class="card-divider"></div>
386
+ <div class="rb-receipt-card-divider"></div>
387
387
 
388
- <div class="next-charge-section">
389
- <div class="next-charge-header">
390
- <div class="next-charge-title">${I18nService.translate('processing.nextCharge')}</div>
391
- <div class="next-charge-date">${I18nService.translate('processing.onDate', {
388
+ <div class="rb-receipt-next-charge-section">
389
+ <div class="rb-receipt-next-charge-header">
390
+ <div class="rb-receipt-next-charge-title">${I18nService.translate('processing.nextCharge')}</div>
391
+ <div class="rb-receipt-next-charge-date">${I18nService.translate('processing.onDate', {
392
392
  date: data.trialPeriodDays && data.trialPeriodDays > 0
393
393
  ? data.trialEndDate
394
394
  : data.debitDate,
395
395
  })}</div>
396
396
  </div>
397
- <div class="next-charge-row">
398
- <div class="next-charge-description">
397
+ <div class="rb-receipt-next-charge-row">
398
+ <div class="rb-receipt-next-charge-description">
399
399
  ${data.trialPeriodDays && data.trialPeriodDays > 0 ? I18nService.translate('processing.atEndOfTrial') : ''}
400
400
  </div>
401
- <div class="next-charge-amount">
401
+ <div class="rb-receipt-next-charge-amount">
402
402
  ${data.planAmount} ${I18nService.translate('processing.perMonth')}
403
403
  </div>
404
404
  </div>
@@ -406,10 +406,10 @@ export class ReceiptTemplate {
406
406
  `
407
407
  : ''}
408
408
 
409
- <div class="card-divider"></div>
409
+ <div class="rb-receipt-card-divider"></div>
410
410
 
411
- <div class="contact-info">
412
- <div class="contact-text">${I18nService.translate('processing.downloadDescription')}</div>
411
+ <div class="rb-receipt-contact-info">
412
+ <div class="rb-receipt-contact-text">${I18nService.translate('processing.downloadDescription')}</div>
413
413
  </div>
414
414
  </div>
415
415
  </div>
@@ -1 +1 @@
1
- {"version":3,"file":"receipt-Cardtemplate.js","sourceRoot":"","sources":["../../src/utils/receipt-Cardtemplate.ts"],"names":[],"mappings":"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","sourcesContent":["import { I18nService } from '../i18n/i18n.service';\n\nexport interface ReceiptTemplateData {\n paymentMethod: string;\n bank?: string;\n cardBrand?: string;\n cardLastFour?: string;\n paymentDate: string;\n email: string;\n referenceNumber: string;\n productTitle: string;\n subtotal: string;\n total: string;\n currency: string;\n discountAmount?: string;\n installments?: string;\n trialPeriodDays?: number;\n debitDay?: number;\n planAmount?: string;\n trialEndDate?: string;\n debitDate?: string;\n isBankTransfer?: boolean;\n}\n\nfunction getCardIconSVG(cardBrand?: string): string {\n if (!cardBrand) return '';\n\n const brandLower = cardBrand.toLowerCase();\n\n switch (brandLower) {\n case 'visa':\n return `<svg width=\"23\" height=\"16\" viewBox=\"0 0 23 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"0.5\" y=\"0.5\" width=\"22\" height=\"15\" rx=\"2\" fill=\"white\" stroke=\"#D9D9D9\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M7.02517 10.8392H5.63182L4.58697 6.79524C4.53738 6.60922 4.43208 6.44477 4.27718 6.36726C3.89063 6.17248 3.46468 6.01746 3 5.93928V5.78359H5.24458C5.55437 5.78359 5.78671 6.01746 5.82543 6.28908L6.36756 9.20609L7.76023 5.78359H9.11486L7.02517 10.8392ZM9.88932 10.8392H8.57341L9.65698 5.78359H10.9729L9.88932 10.8392ZM12.6754 7.18413C12.7141 6.91184 12.9464 6.75615 13.2175 6.75615C13.6434 6.71706 14.1074 6.79524 14.4947 6.98935L14.727 5.90087C14.3398 5.74517 13.9138 5.66699 13.5273 5.66699C12.2501 5.66699 11.3207 6.36726 11.3207 7.33915C11.3207 8.07851 11.979 8.46673 12.4437 8.7006C12.9464 8.9338 13.14 9.08949 13.1013 9.32269C13.1013 9.67249 12.7141 9.82818 12.3275 9.82818C11.8629 9.82818 11.3982 9.71158 10.9729 9.5168L10.7406 10.606C11.2052 10.8001 11.708 10.8783 12.1726 10.8783C13.6047 10.9167 14.4947 10.2171 14.4947 9.167C14.4947 7.84464 12.6754 7.76713 12.6754 7.18413ZM19.1 10.8392L18.0552 5.78359H16.9329C16.7005 5.78359 16.4682 5.93928 16.3907 6.17248L14.4559 10.8392H15.8106L16.081 10.1005H17.7454L17.9003 10.8392H19.1ZM17.1265 7.14505L17.513 9.05041H16.4294L17.1265 7.14505Z\" fill=\"#172B85\"/>\n </svg>`;\n\n case 'mastercard':\n return `<svg width=\"35\" height=\"25\" viewBox=\"0 0 35 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"0.5\" y=\"1.01758\" width=\"34\" height=\"23\" rx=\"3.5\" fill=\"white\" stroke=\"#D9D9D9\" />\n <path d=\"M22.1758 5.51758C25.9444 5.51758 29 8.60848 29 12.4209C28.9998 16.2332 25.9443 19.3232 22.1758 19.3232C20.4864 19.3231 18.9416 18.7007 17.75 17.6719C16.5584 18.7007 15.0137 19.3231 13.3242 19.3232C9.55566 19.3232 6.50018 16.2332 6.5 12.4209C6.5 8.60848 9.55555 5.51758 13.3242 5.51758C15.0134 5.51769 16.5584 6.13943 17.75 7.16797C18.9416 6.13943 20.4866 5.51769 22.1758 5.51758Z\" fill=\"#ED0006\"/>\n <path d=\"M22.1758 5.51758C25.9444 5.51758 29 8.60848 29 12.4209C28.9998 16.2332 25.9443 19.3232 22.1758 19.3232C20.4863 19.3231 18.9416 18.7007 17.75 17.6719C19.2164 16.4058 20.1474 14.524 20.1475 12.4209C20.1475 10.3174 19.2168 8.4341 17.75 7.16797C18.9416 6.13943 20.4866 5.51769 22.1758 5.51758Z\" fill=\"#F9A000\"/>\n <path d=\"M17.75 7.16895C19.2166 8.43507 20.1475 10.3176 20.1475 12.4209C20.1475 14.524 19.2163 16.4058 17.75 17.6719C16.2837 16.4058 15.3525 14.524 15.3525 12.4209C15.3525 10.3176 16.2834 8.43507 17.75 7.16895Z\" fill=\"#FF5E00\"/>\n </svg>`;\n\n case 'american-express':\n case 'amex':\n return `<svg width=\"23\" height=\"16\" viewBox=\"0 0 23 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"0.216981\" y=\"0.216981\" width=\"22.566\" height=\"15.566\" rx=\"0.867925\" fill=\"#1F72CD\" stroke=\"#D9D9D9\" stroke-width=\"0.433962\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4.1443 5.62012L2 10.5758H4.56703L4.88527 9.78562H5.61269L5.93093 10.5758H8.75651V9.9727L9.00828 10.5758H10.4699L10.7217 9.95995V10.5758H16.5981L17.3127 9.80614L17.9817 10.5758L21 10.5821L18.8489 8.11177L21 5.62012H18.0285L17.333 6.37551L16.685 5.62012H10.2922L9.74322 6.89921L9.18139 5.62012H6.61972V6.20265L6.33475 5.62012H4.1443ZM12.9196 6.32403H16.2941L17.3262 7.48832L18.3916 6.32403H19.4237L17.8555 8.11127L19.4237 9.87792H18.3448L17.3127 8.7001L16.2419 9.87792H12.9196V6.32403ZM13.7529 7.70949V7.06035V7.05973H15.8585L16.7772 8.09788L15.8178 9.1417H13.7529V8.43302H15.5938V7.70949H13.7529ZM4.64096 6.32403H5.89225L7.31456 9.68447V6.32403H8.68531L9.78388 8.73345L10.7963 6.32403H12.1602V9.88002H11.3303L11.3236 7.09356L10.1137 9.88002H9.37127L8.15459 7.09356V9.88002H6.4473L6.12363 9.08281H4.37497L4.05197 9.87932H3.13722L4.64096 6.32403ZM4.67357 8.34576L5.24969 6.9256L5.82513 8.34576H4.67357Z\" fill=\"white\"/>\n </svg>`;\n\n default:\n return `<svg width=\"14\" height=\"12\" viewBox=\"0 0 14 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M0.833984 4.50036V10.1644C0.833984 10.5326 1.13246 10.8311 1.50065 10.8311L12.498 10.8311C12.8662 10.8311 13.1647 10.5326 13.1647 10.1644V4.50036M0.833984 4.50036V1.83561C0.833984 1.46742 1.13246 1.16895 1.50065 1.16895H12.4974C12.8648 1.16895 13.163 1.46624 13.1636 1.83367C13.1651 2.72257 13.1647 3.61146 13.1647 4.50036M0.833984 4.50036H13.1647\" stroke=\"#788191\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>`;\n }\n}\n\nexport class ReceiptTemplate {\n public static async generateHTML(data: ReceiptTemplateData): Promise<string> {\n // const organizationName = sessionState.data.organization.name;\n\n return `\n <!DOCTYPE html>\n <html lang=\"${I18nService.getCurrentLanguage()}\">\n <head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>${I18nService.translate('processing.successTitle')}</title>\n <style>\n * {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n }\n\n body {\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;\n background-color: #f8fafc;\n padding: 0;\n line-height: 1.6;\n margin: 0;\n min-height: 100vh;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n .container {\n max-width: 360px;\n width: 100%;\n background: white;\n border-radius: 7px;\n box-shadow: 0 1px 12px rgba(0, 0, 0, 0.1);\n overflow: hidden;\n margin: 20px;\n }\n\n .header {\n display: flex;\n justify-content: flex-start;\n align-items: center;\n height: 43px;\n padding: 0 18px;\n background: white;\n border-bottom: 1px solid #e5e7eb;\n }\n\n .logo {\n display: flex;\n align-items: center;\n gap: 6px;\n font-weight: 600;\n width: 72px;\n height: 24px;\n }\n\n .logo img {\n max-height: 24px;\n max-width: 72px;\n }\n\n .main-content {\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 16px 8px;\n min-height: 180px;\n }\n\n .success-content {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 6px;\n max-width: 270px;\n width: 100%;\n }\n\n .success-title {\n font-size: 12px;\n font-weight: 700;\n color: #1f2937;\n margin: 0;\n padding: 0;\n text-align: center;\n }\n\n .success-icon {\n display: flex;\n justify-content: center;\n margin: 3px 0;\n }\n\n .success-icon svg {\n width: 48px;\n height: 48px;\n }\n\n .info-card {\n padding: 10px;\n gap: 6px;\n width: 270px;\n border: 1px solid #ebedef;\n border-radius: 5px;\n display: flex;\n flex-direction: column;\n background: white;\n margin-bottom: 6px;\n }\n\n .card-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n min-height: 10px;\n padding: 1px 0;\n }\n\n .card-row:last-of-type {\n margin-bottom: 0;\n }\n\n .card-value {\n display: flex;\n align-items: center;\n gap: 4px;\n }\n\n .card-label {\n font-size: 7px;\n color: #6b7280;\n font-weight: 500;\n }\n\n .card-text {\n font-size: 7px;\n color: #6b7280;\n font-weight: 600;\n }\n\n .installments-text {\n font-size: 7px;\n color: #6b7280;\n font-weight: 600;\n white-space: pre-line;\n text-align: right;\n line-height: 1.2;\n }\n\n .card-divider {\n height: 1px;\n background: #e5e7eb;\n margin: 6px 0;\n }\n\n .contact-info {\n text-align: left;\n margin-top: 6px;\n }\n\n .contact-text {\n font-size: 6px;\n color: #6b7280;\n margin-bottom: 1px;\n }\n\n .contact-email {\n font-size: 6px;\n color: #35B093;\n text-decoration: none;\n font-weight: 600;\n }\n\n .trial-pill {\n background-color: #d1fae5;\n border-radius: 3px;\n padding: 2px 4px;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n margin-right: 4px;\n }\n\n .trial-pill-text {\n font-size: 6px;\n color: #059669;\n font-weight: 600;\n }\n\n .total-amount-container {\n display: flex;\n align-items: center;\n justify-content: flex-end;\n gap: 4px;\n flex-direction: row;\n }\n\n .next-charge-section {\n margin-top: 6px;\n padding-top: 6px;\n }\n\n .next-charge-header {\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n margin-bottom: 4px;\n }\n\n .next-charge-title {\n font-size: 7px;\n font-weight: 600;\n color: #1f2937;\n }\n\n .next-charge-date {\n font-size: 7px;\n font-weight: 600;\n color: #1f2937;\n text-align: right;\n }\n\n .next-charge-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n min-height: 10px;\n padding: 1px 0;\n }\n\n .next-charge-description {\n font-size: 6px;\n color: #6b7280;\n font-weight: 500;\n }\n\n .next-charge-amount {\n font-size: 6px;\n color: #6b7280;\n font-weight: 600;\n }\n\n @media print {\n body {\n background: white;\n padding: 0;\n }\n\n .container {\n box-shadow: none;\n border: 1px solid #ddd;\n }\n }\n </style>\n </head>\n <body>\n <div class=\"container\">\n <div class=\"main-content\">\n <div class=\"success-content\">\n <div class=\"success-title\">${I18nService.translate('processing.successTitle')}</div>\n\n <div class=\"success-icon\">\n <svg viewBox=\"0 0 96 96\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M7.99219 47.998C7.99219 25.9067 25.9008 7.99805 47.9922 7.99805C70.0836 7.99805 87.9922 25.9067 87.9922 47.998C87.9922 70.0894 70.0836 87.998 47.9922 87.998C25.9008 87.998 7.99219 70.0894 7.99219 47.998ZM61.5401 39.2645C62.2396 38.4096 62.1136 37.1496 61.2587 36.4501C60.4038 35.7507 59.1437 35.8767 58.4443 36.7316L41.8437 57.0211L35.4064 50.5838C34.6254 49.8028 33.359 49.8028 32.578 50.5838C31.7969 51.3649 31.7969 52.6312 32.578 53.4123L40.578 61.4123C40.9775 61.8118 41.5275 62.0237 42.0918 61.9956C42.6562 61.9674 43.1823 61.7019 43.5401 61.2645L61.5401 39.2645Z\"\n fill=\"#35B093\"\n />\n </svg>\n </div>\n\n <div class=\"info-card\">\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('processing.paymentMethod')}</div>\n <div class=\"card-value\">\n ${data.isBankTransfer ? '' : getCardIconSVG(data.cardBrand)}\n <span class=\"card-text\">${data.isBankTransfer ? I18nService.translate('paymentMethods.bank_transfer') : data.cardBrand && data.cardLastFour ? `${data.cardBrand} - ${data.cardLastFour}` : data.cardBrand || ''}</span>\n </div>\n </div>\n\n ${\n data.installments\n ? `\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('summary.installments')}</div>\n <div class=\"installments-text\">${data.installments}</div>\n </div>\n `\n : ''\n }\n\n ${\n data.discountAmount\n ? `\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('summary.discount')}</div>\n <div class=\"card-text\">${data.discountAmount}</div>\n </div>\n `\n : ''\n }\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('processing.paymentDate')}</div>\n <div class=\"card-text\">${data.paymentDate}</div>\n </div>\n\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('processing.paymentEmail')}</div>\n <div class=\"card-text\">${data.email}</div>\n </div>\n\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('processing.paymentReference')}</div>\n <div class=\"card-text\">${data.referenceNumber}</div>\n </div>\n </div>\n\n <div class=\"info-card\">\n <div class=\"card-label\" style=\"font-size: 8px; font-weight: 600; color: #1f2937; margin-bottom: 6px;\">\n ${I18nService.translate('processing.purchaseDetails')}\n </div>\n\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('processing.purchaseDetail')}</div>\n <div class=\"card-text\">${data.productTitle}</div>\n </div>\n\n ${\n !data.trialPeriodDays\n ? `\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('processing.purchaseSubtotal')}</div>\n <div class=\"card-text\">${data.subtotal}</div>\n </div>\n `\n : ''\n }\n\n <div class=\"card-row\">\n <div class=\"card-label\">${I18nService.translate('processing.purchaseTotal')}</div>\n <div class=\"total-amount-container\">\n ${\n data.trialPeriodDays && data.trialPeriodDays > 0\n ? `\n <div class=\"trial-pill\">\n <span class=\"trial-pill-text\">${I18nService.translate(\n 'processing.trialPill',\n {\n days: data.trialPeriodDays,\n count: data.trialPeriodDays,\n },\n )}</span>\n </div>\n `\n : ''\n }\n <div class=\"card-text\">${data.total}</div>\n </div>\n </div>\n\n ${\n (data.trialPeriodDays && data.trialPeriodDays > 0) ||\n (data.debitDay && data.debitDay > 0)\n ? `\n <div class=\"card-divider\"></div>\n\n <div class=\"next-charge-section\">\n <div class=\"next-charge-header\">\n <div class=\"next-charge-title\">${I18nService.translate('processing.nextCharge')}</div>\n <div class=\"next-charge-date\">${I18nService.translate('processing.onDate', {\n date:\n data.trialPeriodDays && data.trialPeriodDays > 0\n ? data.trialEndDate\n : data.debitDate,\n })}</div>\n </div>\n <div class=\"next-charge-row\">\n <div class=\"next-charge-description\">\n ${data.trialPeriodDays && data.trialPeriodDays > 0 ? I18nService.translate('processing.atEndOfTrial') : ''}\n </div>\n <div class=\"next-charge-amount\">\n ${data.planAmount} ${I18nService.translate('processing.perMonth')}\n </div>\n </div>\n </div>\n `\n : ''\n }\n\n <div class=\"card-divider\"></div>\n\n <div class=\"contact-info\">\n <div class=\"contact-text\">${I18nService.translate('processing.downloadDescription')}</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </body>\n </html>\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"receipt-Cardtemplate.js","sourceRoot":"","sources":["../../src/utils/receipt-Cardtemplate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAwBnD,SAAS,cAAc,CAAC,SAAkB;IACxC,IAAI,CAAC,SAAS;QAAE,OAAO,EAAE,CAAC;IAE1B,MAAM,UAAU,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;IAE3C,QAAQ,UAAU,EAAE,CAAC;QACnB,KAAK,MAAM;YACT,OAAO;;;aAGA,CAAC;QAEV,KAAK,YAAY;YACf,OAAO;;;;;aAKA,CAAC;QAEV,KAAK,kBAAkB,CAAC;QACxB,KAAK,MAAM;YACT,OAAO;;;aAGA,CAAC;QAEV;YACE,OAAO;;aAEA,CAAC;IACZ,CAAC;AACH,CAAC;AAED,MAAM,OAAO,eAAe;IACnB,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,IAAyB;QACxD,gEAAgE;QAEhE,OAAO;;oBAES,WAAW,CAAC,kBAAkB,EAAE;;;;iBAInC,WAAW,CAAC,SAAS,CAAC,yBAAyB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sDA4PX,WAAW,CAAC,SAAS,CAAC,yBAAyB,CAAC;;;;;;;;;;;;;;;uDAe/C,WAAW,CAAC,SAAS,CAAC,0BAA0B,CAAC;;sBAElF,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC;yDACtB,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC,8BAA8B,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,EAAE;;;;kBAK5N,IAAI,CAAC,YAAY;YACf,CAAC,CAAC;;uDAEiC,WAAW,CAAC,SAAS,CAAC,sBAAsB,CAAC;8DACtC,IAAI,CAAC,YAAY;;iBAE9D;YACG,CAAC,CAAC,EACN;;kBAGE,IAAI,CAAC,cAAc;YACjB,CAAC,CAAC;;uDAEiC,WAAW,CAAC,SAAS,CAAC,kBAAkB,CAAC;sDAC1C,IAAI,CAAC,cAAc;;iBAExD;YACG,CAAC,CAAC,EACN;;uDAEuC,WAAW,CAAC,SAAS,CAAC,wBAAwB,CAAC;sDAChD,IAAI,CAAC,WAAW;;;;uDAIf,WAAW,CAAC,SAAS,CAAC,yBAAyB,CAAC;sDACjD,IAAI,CAAC,KAAK;;;;uDAIT,WAAW,CAAC,SAAS,CAAC,6BAA6B,CAAC;sDACrD,IAAI,CAAC,eAAe;;;;;;oBAMtD,WAAW,CAAC,SAAS,CAAC,4BAA4B,CAAC;;;;uDAIhB,WAAW,CAAC,SAAS,CAAC,2BAA2B,CAAC;sDACnD,IAAI,CAAC,YAAY;;;kBAIrD,CAAC,IAAI,CAAC,eAAe;YACnB,CAAC,CAAC;;uDAEiC,WAAW,CAAC,SAAS,CAAC,6BAA6B,CAAC;sDACrD,IAAI,CAAC,QAAQ;;iBAElD;YACG,CAAC,CAAC,EACN;;;uDAGuC,WAAW,CAAC,SAAS,CAAC,0BAA0B,CAAC;;sBAGlF,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,GAAG,CAAC;YAC9C,CAAC,CAAC;;iEAEuC,WAAW,CAAC,SAAS,CAC9D,sBAAsB,EACtB;gBACE,IAAI,EAAE,IAAI,CAAC,eAAe;gBAC1B,KAAK,EAAE,IAAI,CAAC,eAAe;aAC5B,CACF;;qBAEF;YACG,CAAC,CAAC,EACN;wDACoC,IAAI,CAAC,KAAK;;;;kBAKhD,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC;YAClD,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;YAClC,CAAC,CAAC;;;;;gEAK0C,WAAW,CAAC,SAAS,CAAC,uBAAuB,CAAC;+DAC/C,WAAW,CAAC,SAAS,CAC9D,mBAAmB,EACnB;gBACE,IAAI,EACF,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,GAAG,CAAC;oBAC9C,CAAC,CAAC,IAAI,CAAC,YAAY;oBACnB,CAAC,CAAC,IAAI,CAAC,SAAS;aACrB,CACF;;;;wBAIG,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,EAAE;;;wBAGxG,IAAI,CAAC,UAAU,IAAI,WAAW,CAAC,SAAS,CAAC,qBAAqB,CAAC;;;;iBAItE;YACG,CAAC,CAAC,EACN;;;;;yDAKyC,WAAW,CAAC,SAAS,CAAC,gCAAgC,CAAC;;;;;;;;KAQ3G,CAAC;IACJ,CAAC;CACF","sourcesContent":["import { I18nService } from '../i18n/i18n.service';\n\nexport interface ReceiptTemplateData {\n paymentMethod: string;\n bank?: string;\n cardBrand?: string;\n cardLastFour?: string;\n paymentDate: string;\n email: string;\n referenceNumber: string;\n productTitle: string;\n subtotal: string;\n total: string;\n currency: string;\n discountAmount?: string;\n installments?: string;\n trialPeriodDays?: number;\n debitDay?: number;\n planAmount?: string;\n trialEndDate?: string;\n debitDate?: string;\n isBankTransfer?: boolean;\n}\n\nfunction getCardIconSVG(cardBrand?: string): string {\n if (!cardBrand) return '';\n\n const brandLower = cardBrand.toLowerCase();\n\n switch (brandLower) {\n case 'visa':\n return `<svg width=\"23\" height=\"16\" viewBox=\"0 0 23 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"0.5\" y=\"0.5\" width=\"22\" height=\"15\" rx=\"2\" fill=\"white\" stroke=\"#D9D9D9\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M7.02517 10.8392H5.63182L4.58697 6.79524C4.53738 6.60922 4.43208 6.44477 4.27718 6.36726C3.89063 6.17248 3.46468 6.01746 3 5.93928V5.78359H5.24458C5.55437 5.78359 5.78671 6.01746 5.82543 6.28908L6.36756 9.20609L7.76023 5.78359H9.11486L7.02517 10.8392ZM9.88932 10.8392H8.57341L9.65698 5.78359H10.9729L9.88932 10.8392ZM12.6754 7.18413C12.7141 6.91184 12.9464 6.75615 13.2175 6.75615C13.6434 6.71706 14.1074 6.79524 14.4947 6.98935L14.727 5.90087C14.3398 5.74517 13.9138 5.66699 13.5273 5.66699C12.2501 5.66699 11.3207 6.36726 11.3207 7.33915C11.3207 8.07851 11.979 8.46673 12.4437 8.7006C12.9464 8.9338 13.14 9.08949 13.1013 9.32269C13.1013 9.67249 12.7141 9.82818 12.3275 9.82818C11.8629 9.82818 11.3982 9.71158 10.9729 9.5168L10.7406 10.606C11.2052 10.8001 11.708 10.8783 12.1726 10.8783C13.6047 10.9167 14.4947 10.2171 14.4947 9.167C14.4947 7.84464 12.6754 7.76713 12.6754 7.18413ZM19.1 10.8392L18.0552 5.78359H16.9329C16.7005 5.78359 16.4682 5.93928 16.3907 6.17248L14.4559 10.8392H15.8106L16.081 10.1005H17.7454L17.9003 10.8392H19.1ZM17.1265 7.14505L17.513 9.05041H16.4294L17.1265 7.14505Z\" fill=\"#172B85\"/>\n </svg>`;\n\n case 'mastercard':\n return `<svg width=\"35\" height=\"25\" viewBox=\"0 0 35 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"0.5\" y=\"1.01758\" width=\"34\" height=\"23\" rx=\"3.5\" fill=\"white\" stroke=\"#D9D9D9\" />\n <path d=\"M22.1758 5.51758C25.9444 5.51758 29 8.60848 29 12.4209C28.9998 16.2332 25.9443 19.3232 22.1758 19.3232C20.4864 19.3231 18.9416 18.7007 17.75 17.6719C16.5584 18.7007 15.0137 19.3231 13.3242 19.3232C9.55566 19.3232 6.50018 16.2332 6.5 12.4209C6.5 8.60848 9.55555 5.51758 13.3242 5.51758C15.0134 5.51769 16.5584 6.13943 17.75 7.16797C18.9416 6.13943 20.4866 5.51769 22.1758 5.51758Z\" fill=\"#ED0006\"/>\n <path d=\"M22.1758 5.51758C25.9444 5.51758 29 8.60848 29 12.4209C28.9998 16.2332 25.9443 19.3232 22.1758 19.3232C20.4863 19.3231 18.9416 18.7007 17.75 17.6719C19.2164 16.4058 20.1474 14.524 20.1475 12.4209C20.1475 10.3174 19.2168 8.4341 17.75 7.16797C18.9416 6.13943 20.4866 5.51769 22.1758 5.51758Z\" fill=\"#F9A000\"/>\n <path d=\"M17.75 7.16895C19.2166 8.43507 20.1475 10.3176 20.1475 12.4209C20.1475 14.524 19.2163 16.4058 17.75 17.6719C16.2837 16.4058 15.3525 14.524 15.3525 12.4209C15.3525 10.3176 16.2834 8.43507 17.75 7.16895Z\" fill=\"#FF5E00\"/>\n </svg>`;\n\n case 'american-express':\n case 'amex':\n return `<svg width=\"23\" height=\"16\" viewBox=\"0 0 23 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"0.216981\" y=\"0.216981\" width=\"22.566\" height=\"15.566\" rx=\"0.867925\" fill=\"#1F72CD\" stroke=\"#D9D9D9\" stroke-width=\"0.433962\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4.1443 5.62012L2 10.5758H4.56703L4.88527 9.78562H5.61269L5.93093 10.5758H8.75651V9.9727L9.00828 10.5758H10.4699L10.7217 9.95995V10.5758H16.5981L17.3127 9.80614L17.9817 10.5758L21 10.5821L18.8489 8.11177L21 5.62012H18.0285L17.333 6.37551L16.685 5.62012H10.2922L9.74322 6.89921L9.18139 5.62012H6.61972V6.20265L6.33475 5.62012H4.1443ZM12.9196 6.32403H16.2941L17.3262 7.48832L18.3916 6.32403H19.4237L17.8555 8.11127L19.4237 9.87792H18.3448L17.3127 8.7001L16.2419 9.87792H12.9196V6.32403ZM13.7529 7.70949V7.06035V7.05973H15.8585L16.7772 8.09788L15.8178 9.1417H13.7529V8.43302H15.5938V7.70949H13.7529ZM4.64096 6.32403H5.89225L7.31456 9.68447V6.32403H8.68531L9.78388 8.73345L10.7963 6.32403H12.1602V9.88002H11.3303L11.3236 7.09356L10.1137 9.88002H9.37127L8.15459 7.09356V9.88002H6.4473L6.12363 9.08281H4.37497L4.05197 9.87932H3.13722L4.64096 6.32403ZM4.67357 8.34576L5.24969 6.9256L5.82513 8.34576H4.67357Z\" fill=\"white\"/>\n </svg>`;\n\n default:\n return `<svg width=\"14\" height=\"12\" viewBox=\"0 0 14 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M0.833984 4.50036V10.1644C0.833984 10.5326 1.13246 10.8311 1.50065 10.8311L12.498 10.8311C12.8662 10.8311 13.1647 10.5326 13.1647 10.1644V4.50036M0.833984 4.50036V1.83561C0.833984 1.46742 1.13246 1.16895 1.50065 1.16895H12.4974C12.8648 1.16895 13.163 1.46624 13.1636 1.83367C13.1651 2.72257 13.1647 3.61146 13.1647 4.50036M0.833984 4.50036H13.1647\" stroke=\"#788191\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>`;\n }\n}\n\nexport class ReceiptTemplate {\n public static async generateHTML(data: ReceiptTemplateData): Promise<string> {\n // const organizationName = sessionState.data.organization.name;\n\n return `\n <!DOCTYPE html>\n <html lang=\"${I18nService.getCurrentLanguage()}\">\n <head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>${I18nService.translate('processing.successTitle')}</title>\n <style>\n * {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n }\n\n body {\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;\n background-color: #f8fafc;\n padding: 0;\n line-height: 1.6;\n margin: 0;\n min-height: 100vh;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n .rb-receipt-container {\n max-width: 360px;\n width: 100%;\n background: white;\n border-radius: 7px;\n box-shadow: 0 1px 12px rgba(0, 0, 0, 0.1);\n overflow: hidden;\n margin: 20px;\n }\n\n .rb-receipt-header {\n display: flex;\n justify-content: flex-start;\n align-items: center;\n height: 43px;\n padding: 0 18px;\n background: white;\n border-bottom: 1px solid #e5e7eb;\n }\n\n .rb-receipt-logo {\n display: flex;\n align-items: center;\n gap: 6px;\n font-weight: 600;\n width: 72px;\n height: 24px;\n }\n\n .rb-receipt-logo img {\n max-height: 24px;\n max-width: 72px;\n }\n\n .rb-receipt-main-content {\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 16px 8px;\n min-height: 180px;\n }\n\n .rb-receipt-success-content {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 6px;\n max-width: 270px;\n width: 100%;\n }\n\n .rb-receipt-success-title {\n font-size: 12px;\n font-weight: 700;\n color: #1f2937;\n margin: 0;\n padding: 0;\n text-align: center;\n }\n\n .rb-receipt-success-icon {\n display: flex;\n justify-content: center;\n margin: 3px 0;\n }\n\n .rb-receipt-success-icon svg {\n width: 48px;\n height: 48px;\n }\n\n .rb-receipt-info-card {\n padding: 10px;\n gap: 6px;\n width: 270px;\n border: 1px solid #ebedef;\n border-radius: 5px;\n display: flex;\n flex-direction: column;\n background: white;\n margin-bottom: 6px;\n }\n\n .rb-receipt-card-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n min-height: 10px;\n padding: 1px 0;\n }\n\n .rb-receipt-card-row:last-of-type {\n margin-bottom: 0;\n }\n\n .rb-receipt-card-value {\n display: flex;\n align-items: center;\n gap: 4px;\n }\n\n .rb-receipt-card-label {\n font-size: 7px;\n color: #6b7280;\n font-weight: 500;\n }\n\n .rb-receipt-card-text {\n font-size: 7px;\n color: #6b7280;\n font-weight: 600;\n }\n\n .rb-receipt-installments-text {\n font-size: 7px;\n color: #6b7280;\n font-weight: 600;\n white-space: pre-line;\n text-align: right;\n line-height: 1.2;\n }\n\n .rb-receipt-card-divider {\n height: 1px;\n background: #e5e7eb;\n margin: 6px 0;\n }\n\n .rb-receipt-contact-info {\n text-align: left;\n margin-top: 6px;\n }\n\n .rb-receipt-contact-text {\n font-size: 6px;\n color: #6b7280;\n margin-bottom: 1px;\n }\n\n .rb-receipt-contact-email {\n font-size: 6px;\n color: #35B093;\n text-decoration: none;\n font-weight: 600;\n }\n\n .rb-receipt-trial-pill {\n background-color: #d1fae5;\n border-radius: 3px;\n padding: 2px 4px;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n margin-right: 4px;\n }\n\n .rb-receipt-trial-pill-text {\n font-size: 6px;\n color: #059669;\n font-weight: 600;\n }\n\n .rb-receipt-total-amount-container {\n display: flex;\n align-items: center;\n justify-content: flex-end;\n gap: 4px;\n flex-direction: row;\n }\n\n .rb-receipt-next-charge-section {\n margin-top: 6px;\n padding-top: 6px;\n }\n\n .rb-receipt-next-charge-header {\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n margin-bottom: 4px;\n }\n\n .rb-receipt-next-charge-title {\n font-size: 7px;\n font-weight: 600;\n color: #1f2937;\n }\n\n .rb-receipt-next-charge-date {\n font-size: 7px;\n font-weight: 600;\n color: #1f2937;\n text-align: right;\n }\n\n .rb-receipt-next-charge-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n min-height: 10px;\n padding: 1px 0;\n }\n\n .rb-receipt-next-charge-description {\n font-size: 6px;\n color: #6b7280;\n font-weight: 500;\n }\n\n .rb-receipt-next-charge-amount {\n font-size: 6px;\n color: #6b7280;\n font-weight: 600;\n }\n\n @media print {\n body {\n background: white;\n padding: 0;\n }\n\n .rb-receipt-container {\n box-shadow: none;\n border: 1px solid #ddd;\n }\n }\n </style>\n </head>\n <body>\n <div class=\"rb-receipt-container\">\n <div class=\"rb-receipt-main-content\">\n <div class=\"rb-receipt-success-content\">\n <div class=\"rb-receipt-success-title\">${I18nService.translate('processing.successTitle')}</div>\n\n <div class=\"rb-receipt-success-icon\">\n <svg viewBox=\"0 0 96 96\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M7.99219 47.998C7.99219 25.9067 25.9008 7.99805 47.9922 7.99805C70.0836 7.99805 87.9922 25.9067 87.9922 47.998C87.9922 70.0894 70.0836 87.998 47.9922 87.998C25.9008 87.998 7.99219 70.0894 7.99219 47.998ZM61.5401 39.2645C62.2396 38.4096 62.1136 37.1496 61.2587 36.4501C60.4038 35.7507 59.1437 35.8767 58.4443 36.7316L41.8437 57.0211L35.4064 50.5838C34.6254 49.8028 33.359 49.8028 32.578 50.5838C31.7969 51.3649 31.7969 52.6312 32.578 53.4123L40.578 61.4123C40.9775 61.8118 41.5275 62.0237 42.0918 61.9956C42.6562 61.9674 43.1823 61.7019 43.5401 61.2645L61.5401 39.2645Z\"\n fill=\"#35B093\"\n />\n </svg>\n </div>\n\n <div class=\"rb-receipt-info-card\">\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('processing.paymentMethod')}</div>\n <div class=\"rb-receipt-card-value\">\n ${data.isBankTransfer ? '' : getCardIconSVG(data.cardBrand)}\n <span class=\"rb-receipt-card-text\">${data.isBankTransfer ? I18nService.translate('paymentMethods.bank_transfer') : data.cardBrand && data.cardLastFour ? `${data.cardBrand} - ${data.cardLastFour}` : data.cardBrand || ''}</span>\n </div>\n </div>\n\n ${\n data.installments\n ? `\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('summary.installments')}</div>\n <div class=\"rb-receipt-installments-text\">${data.installments}</div>\n </div>\n `\n : ''\n }\n\n ${\n data.discountAmount\n ? `\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('summary.discount')}</div>\n <div class=\"rb-receipt-card-text\">${data.discountAmount}</div>\n </div>\n `\n : ''\n }\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('processing.paymentDate')}</div>\n <div class=\"rb-receipt-card-text\">${data.paymentDate}</div>\n </div>\n\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('processing.paymentEmail')}</div>\n <div class=\"rb-receipt-card-text\">${data.email}</div>\n </div>\n\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('processing.paymentReference')}</div>\n <div class=\"rb-receipt-card-text\">${data.referenceNumber}</div>\n </div>\n </div>\n\n <div class=\"rb-receipt-info-card\">\n <div class=\"rb-receipt-card-label\" style=\"font-size: 8px; font-weight: 600; color: #1f2937; margin-bottom: 6px;\">\n ${I18nService.translate('processing.purchaseDetails')}\n </div>\n\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('processing.purchaseDetail')}</div>\n <div class=\"rb-receipt-card-text\">${data.productTitle}</div>\n </div>\n\n ${\n !data.trialPeriodDays\n ? `\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('processing.purchaseSubtotal')}</div>\n <div class=\"rb-receipt-card-text\">${data.subtotal}</div>\n </div>\n `\n : ''\n }\n\n <div class=\"rb-receipt-card-row\">\n <div class=\"rb-receipt-card-label\">${I18nService.translate('processing.purchaseTotal')}</div>\n <div class=\"rb-receipt-total-amount-container\">\n ${\n data.trialPeriodDays && data.trialPeriodDays > 0\n ? `\n <div class=\"rb-receipt-trial-pill\">\n <span class=\"rb-receipt-trial-pill-text\">${I18nService.translate(\n 'processing.trialPill',\n {\n days: data.trialPeriodDays,\n count: data.trialPeriodDays,\n },\n )}</span>\n </div>\n `\n : ''\n }\n <div class=\"rb-receipt-card-text\">${data.total}</div>\n </div>\n </div>\n\n ${\n (data.trialPeriodDays && data.trialPeriodDays > 0) ||\n (data.debitDay && data.debitDay > 0)\n ? `\n <div class=\"rb-receipt-card-divider\"></div>\n\n <div class=\"rb-receipt-next-charge-section\">\n <div class=\"rb-receipt-next-charge-header\">\n <div class=\"rb-receipt-next-charge-title\">${I18nService.translate('processing.nextCharge')}</div>\n <div class=\"rb-receipt-next-charge-date\">${I18nService.translate(\n 'processing.onDate',\n {\n date:\n data.trialPeriodDays && data.trialPeriodDays > 0\n ? data.trialEndDate\n : data.debitDate,\n },\n )}</div>\n </div>\n <div class=\"rb-receipt-next-charge-row\">\n <div class=\"rb-receipt-next-charge-description\">\n ${data.trialPeriodDays && data.trialPeriodDays > 0 ? I18nService.translate('processing.atEndOfTrial') : ''}\n </div>\n <div class=\"rb-receipt-next-charge-amount\">\n ${data.planAmount} ${I18nService.translate('processing.perMonth')}\n </div>\n </div>\n </div>\n `\n : ''\n }\n\n <div class=\"rb-receipt-card-divider\"></div>\n\n <div class=\"rb-receipt-contact-info\">\n <div class=\"rb-receipt-contact-text\">${I18nService.translate('processing.downloadDescription')}</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </body>\n </html>\n `;\n }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { A as APMCheckout, d as defineCustomElement$1 } from './p-BBEMTBwW.js';
1
+ import { A as APMCheckout, d as defineCustomElement$1 } from './p-C69QonMT.js';
2
2
 
3
3
  const ApmCheckout = APMCheckout;
4
4
  const defineCustomElement = defineCustomElement$1;