feat: user handlebars as template engine for mailing & remove ejs

This commit is contained in:
abdou6666 2025-03-13 16:33:13 +01:00 committed by Mohamed Marrouchi
parent 6f02cf1443
commit ba4305a5c2
7 changed files with 77 additions and 54 deletions

9
api/package-lock.json generated
View File

@ -33,7 +33,6 @@
"connect-mongo": "^5.1.0",
"cookie-parser": "^1.4.6",
"dotenv": "^16.3.1",
"ejs": "^3.1.9",
"express-session": "^1.17.3",
"handlebars": "^4.7.8",
"module-alias": "^2.2.3",
@ -7408,7 +7407,8 @@
"node_modules/async": {
"version": "3.2.5",
"resolved": "https://registry.npmjs.org/async/-/async-3.2.5.tgz",
"integrity": "sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg=="
"integrity": "sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg==",
"optional": true
},
"node_modules/async-mutex": {
"version": "0.4.1",
@ -9629,6 +9629,7 @@
"version": "3.1.10",
"resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.10.tgz",
"integrity": "sha512-UeJmFfOrAQS8OJWPZ4qtgHyWExa088/MtK5UEyoJGFH67cDEXkZSviOiKRCZ4Xij0zxI3JECgYs3oKx+AizQBA==",
"optional": true,
"dependencies": {
"jake": "^10.8.5"
},
@ -10805,6 +10806,7 @@
"version": "1.0.4",
"resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.4.tgz",
"integrity": "sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q==",
"optional": true,
"dependencies": {
"minimatch": "^5.0.1"
}
@ -10813,6 +10815,7 @@
"version": "2.0.1",
"resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz",
"integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==",
"optional": true,
"dependencies": {
"balanced-match": "^1.0.0"
}
@ -10821,6 +10824,7 @@
"version": "5.1.6",
"resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz",
"integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==",
"optional": true,
"dependencies": {
"brace-expansion": "^2.0.1"
},
@ -12526,6 +12530,7 @@
"version": "10.8.7",
"resolved": "https://registry.npmjs.org/jake/-/jake-10.8.7.tgz",
"integrity": "sha512-ZDi3aP+fG/LchyBzUM804VjddnwfSfsdeYkwt8NcbKRvo4rFkjhs456iLFn3k2ZUWvNe4i48WACDbza8fhq2+w==",
"optional": true,
"dependencies": {
"async": "^3.2.3",
"chalk": "^4.0.2",

View File

@ -68,7 +68,6 @@
"connect-mongo": "^5.1.0",
"cookie-parser": "^1.4.6",
"dotenv": "^16.3.1",
"ejs": "^3.1.9",
"express-session": "^1.17.3",
"handlebars": "^4.7.8",
"module-alias": "^2.2.3",

View File

@ -71,7 +71,15 @@ const i18nOptions: I18nOptions = {
debug: false,
}),
template: {
adapter: new MjmlAdapter('ejs', { inlineCssEnabled: false }),
adapter: new MjmlAdapter(
'handlebars',
{
inlineCssEnabled: false,
},
{
handlebar: {},
},
),
dir: path.join(process.cwd(), 'dist', 'templates'),
options: {
context: {

View File

@ -2,34 +2,38 @@
<mj-body>
<mj-section>
<mj-column>
<mj-image width="186px" src="https://hexabot.ai/assets/images/logo.png"></mj-image>
<mj-image
width="186px"
src="https://hexabot.ai/assets/images/logo.png"
></mj-image>
<mj-divider border-color="#000"></mj-divider>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('hi') %> <%= first_name %>,</mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('account_successfully_created_confirm_password') %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'hi'}} {{first_name}},
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'account_successfully_created_confirm_password'}}
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('confirm_account') %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'confirm_account'}}
</mj-text>
<mj-button
href="<%= this.appUrl %>/login/<%= token %>"
href="{{appUrl}}/login/{{token}}"
font-size="16px"
background-color="#000"
><%= t('confirm') %></mj-button
>
{{t 'confirm'}}
</mj-button>
</mj-column>
</mj-section>
<mj-section>
<mj-column>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('best_regards') %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= this.appName %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'best_regards'}}
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{appName}}
</mj-text>
</mj-column>
</mj-section>
</mj-body>

View File

@ -2,36 +2,39 @@
<mj-body>
<mj-section>
<mj-column>
<mj-image width="186px" src="https://hexabot.ai/assets/images/logo.png"></mj-image>
<mj-image
width="186px"
src="https://hexabot.ai/assets/images/logo.png"
></mj-image>
<mj-divider border-color="#000"></mj-divider>
<mj-text font-size="16px" color="#000" font-family="helvetica">
<%= t('welcome') %>,
{{t 'welcome'}}
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'invitation_for_account_creation'}} {{appName}} {{t 'account'}}.
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= `${t('invitation_for_account_creation')} ${this.appName}
${t('account')}.` %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('create_account') %></mj-text
>{{ t 'create_account'}}</mj-text
>
<mj-button
href="<%= this.appUrl %>/register/<%= token %>"
href="{{appUrl}}/register/{{token}}"
font-size="16px"
background-color="#000"
><%= t('join') %></mj-button
>
{{t 'join'}}</mj-button
>
</mj-column>
</mj-section>
<mj-section>
<mj-column>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('best_regards') %></mj-text
>
>{{t 'best_regards'}}
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= this.appName %></mj-text
>{{this.appName }}</mj-text
>
</mj-column>
</mj-section>

View File

@ -2,33 +2,37 @@
<mj-body>
<mj-section>
<mj-column>
<mj-image width="186px" src="https://hexabot.ai/assets/images/logo.png"></mj-image>
<mj-image
width="186px"
src="https://hexabot.ai/assets/images/logo.png"
></mj-image>
<mj-divider border-color="#000"></mj-divider>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('hi') %> <%= first_name %>,</mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('password_reset_request') %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('click_to_reset_password') %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'hi'}} {{first_name}},
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'password_reset_request'}}
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'click_to_reset_password'}}
</mj-text>
<mj-button
href="<%= this.appUrl %>/reset/<%= token %>"
href="{{appUrl}}/reset/{{token}}"
font-size="16px"
background-color="#000"
><%= t('reset') %></mj-button
>
{{t 'reset'}}
</mj-button>
</mj-column>
</mj-section>
<mj-section>
<mj-column>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= t('best_regards') %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica"
><%= this.appName %></mj-text
>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{t 'best_regards'}}
</mj-text>
<mj-text font-size="16px" color="#000" font-family="helvetica">
{{appName}}
</mj-text>
</mj-column>
</mj-section>
</mj-body>

View File

@ -1,5 +1,5 @@
/*
* Copyright © 2024 Hexastack. All rights reserved.
* Copyright © 2025 Hexastack. All rights reserved.
*
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.