diff --git a/src/components/Content/Content.tsx b/src/components/Content/Content.tsx index 093d783dd7db279b60f86060c5f71a9d839f872f..0e6c6cb7b1187f8d4a16e1b68486dee66d2d0a43 100644 --- a/src/components/Content/Content.tsx +++ b/src/components/Content/Content.tsx @@ -2,13 +2,17 @@ import React, { useCallback, useEffect } from 'react' import { useClient } from 'cozy-client' import { useRecoilState } from 'recoil' import { history } from 'components/App' - +import MailService from 'services/mail.service' import { ScreenType } from 'enum/screen.enum' import { ModalState, UserProfile } from 'models' import { userProfileState } from 'atoms/userProfile.state' import { screenTypeState } from 'atoms/screenType.state' import { modalState } from 'atoms/modal.state' import UserProfileService from 'services/userProfile.service' +import userInstanceSettings from 'components/Hooks/userInstanceSettings' +import CozyClient from 'cozy-client' +import schema from 'doctypes' +import get from 'lodash/get' import WelcomeModal from 'components/Welcome/WelcomeModal' import FeedbackModal from 'components/Feedback/FeedbackModal' @@ -37,6 +41,31 @@ const Content: React.FC<ContentProps> = ({ const [modal, setModalState] = useRecoilState<ModalState>(modalState) const setWelcomeModalViewed = useCallback(async () => { + let username = '' + const mailService = new MailService() + // Retrieve public name from the stack + const settings = await client + .getStackClient() + .fetchJSON('GET', '/settings/instance') + const publicName = get(settings, 'data.attributes.public_name') + if (publicName) { + username = publicName + } + const bodyBienvenu = mailService.CreateBodyWelcome( + username, + window.location.href + ) + const mailData = { + mode: 'noreply', + subject: '[Ecolyo] - Bienvenu', + parts: [ + { + type: 'text/html', + body: bodyBienvenu, + }, + ], + } + mailService.SendMail(client, mailData) const userProfileService = new UserProfileService(client) await userProfileService .updateUserProfile({ haveSeenWelcomeModal: true }) diff --git a/src/models/index.ts b/src/models/index.ts index 88c73990f4f8351e79fc372dbd9774464e174413..d86d4ffa93254bc9f43e6a3a304daf860760a895 100644 --- a/src/models/index.ts +++ b/src/models/index.ts @@ -7,6 +7,7 @@ export * from './ecogesture.model' export * from './fluid.model' export * from './indicator.model' export * from './konnector.model' +export * from './mail.model' export * from './modal.model' export * from './timePeriod.model' export * from './trigger.model' diff --git a/src/models/mail.model.ts b/src/models/mail.model.ts new file mode 100644 index 0000000000000000000000000000000000000000..208f77ad5a7bda4283cbcf9df4ed41b62384ba29 --- /dev/null +++ b/src/models/mail.model.ts @@ -0,0 +1,10 @@ +export interface MailInfo { + mode: string + subject: string + parts: MailPart +} + +export interface MailPart { + type: string + body: string +} diff --git a/src/services/mail.service.ts b/src/services/mail.service.ts new file mode 100644 index 0000000000000000000000000000000000000000..837f71052fd6e2b6f21b9dd98a3b1523b1ccdd80 --- /dev/null +++ b/src/services/mail.service.ts @@ -0,0 +1,294 @@ +import { Client } from 'cozy-client' +import { MailInfo } from 'models' + +export default class MailService { + public async SendMail( + client: Client, + mailInfo: Record<string, any> + ): Promise<string> { + try { + const jobCollection = client.collection('io.cozy.jobs') + await jobCollection.create('sendmail', mailInfo) + log('Info', 'Welcome Mail Sent') + } catch (e) { + // eslint-disable-next-line no-console + console.error(e) + } + return 'ok' + } + + public CreateBodyWelcome(username: string, clientUrl: string) { + return ` +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional //EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> + <html xmlns="http://www.w3.org/1999/xhtml"> + <head> + <title>Votre bilan hebdomadaire</title> + <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> + <meta name="viewport" content="width=device-width, initial-scale=1.0" /> + <style type="text/css"> + @font-face { + font-family: 'Lato'; + font-style: normal; + font-weight: 400; + src: local('Lato Regular'), local('Lato-Regular'), url(https://fonts.gstatic.com/s/lato/v11/qIIYRU-oROkIk8vfvxw6QvesZW2xOQ-xsNqO47m55DA.woff) format('woff'); + } + /* Fonts and Content */ + body, + td { + font-family: "Lato", sans-serif; + font-size: 14px; + } + body { + background-color: #FFFFFF; + margin: 0; + padding: 0; + -webkit-text-size-adjust: none; + -ms-text-size-adjust: none; + } + h2 { + padding-top: 12px; /* ne fonctionnera pas sous Outlook 2007+ */ + color: #ffffff; + font-size: 22px; + } + </style> + </head> + <body style="margin:0px; padding:0px; -webkit-text-size-adjust:none;"> + <table + width="100%" + cellpadding="0" + cellspacing="0" + border="0" + style="background-color:#000000" + > + <tbody> + <tr> + <td align="center" bgcolor="#FFFFFF"> + <table cellpadding="0" cellspacing="0" border="0"> + <tbody> + <tr> + <td class="w640" width="640" height="40"></td> + </tr> + <!-- entete --> + <tr class="pagetoplogo"> + <td class="w640" width="640"> + <table + class="w640" + width="640" + cellpadding="0" + cellspacing="0" + border="0" + bgcolor="#000000" + > + <tbody> + <tr> + <td class="w30" width="30"></td> + <td + class="w580" + width="580" + valign="middle" + align="center" + > + <div class="pagetoplogo-content" style="color:#FFFFFF; font-size: 30px; font-weight: bold; margin-top: 15px; margin-bottom: 15px;"> + <img + class="w580" + style="text-decoration: none; display: block; margin-bottom: 10px;" + src="" + alt="Ecolyo" + width="96" + height="96" + /> + <span>Ecolyo</span> + </div> + </td> + </tr> + </tbody> + </table> + </td> + </tr> + <!-- separateur horizontal --> + <tr> + <td + class="w640" + width="640" + height="2" + bgcolor="#e3b82a" + ></td> + </tr> + <!-- contenu --> + <tr class="content"> + <td class="w640" width="640" bgcolor="#000000"> + <table + class="w640" + width="640" + cellpadding="0" + cellspacing="0" + border="0" + > + <tbody> + <tr> + <td class="w30" width="30"></td> + <td class="w580" width="580"> + <!-- content area --> + <table + class="w580" + width="580" + cellpadding="0" + cellspacing="0" + border="0" + > + <tbody> + <tr> + <td class="w580" width="580" align="center"> + <h2 + style="color:#FFFFFF; font-size:22px; padding-top:12px;" + > + Bienvenue chez Ecolyo + </h2> + <div + class="article-content" + style="color:#FFFFFF; font-size:16px; padding-top:12px;" + > + + </div> + </td> + </tr> + <tr> + <td class="w30" width="580" height="20"></td> + </tr> + <tr> + <td + class="w580" + width="580" + height="1" + bgcolor="#FFFFFF" + ></td> + </tr> + </tbody> + </table> + <!-- content area --> + <table + class="w580" + width="580" + cellspacing="0" + cellpadding="0" + border="0" + > + <tbody> + <tr> + <td class="w580" width="580" align="left"> + <h2 + style="color:#FFFFFF; font-size:22px; padding-top:12px;" + > + Bonjour ${username}, + </h2 + </td> + </tr> + <tr> + </table> + <!-- content area --> + <table + class="w580" + width="580" + cellspacing="0" + cellpadding="0" + border="0" + > + <tbody> + <tr> + <td class="w580" width="580" align="left"> + <div + class="article-content" + style="color:#FFFFFF; font-size:16px; padding-top:12px;" + > + <p> + Retrouvez l'analyse complète de vos + consommations dans votre application + Ecolyo à l'adresse : + </p> + <a href="${clientUrl}"> + ${clientUrl} + </a> + </div> + </td> + </tr> + <tr> + <td class="w30" width="580" height="20"></td> + </tr> + </tbody> + </table> + </tr> + </tbody> + </table> + </td> + </tr> + <!-- separateur horizontal --> + <tr> + <td + class="w640" + width="640" + height="2" + bgcolor="#e3b82a" + ></td> + </tr> + <!-- pied de page --> + <tr class="pagebottom"> + <td class="w640" width="640"> + <table + class="w640" + width="640" + cellpadding="0" + cellspacing="0" + border="0" + bgcolor="#000000" + > + <tbody> + <tr> + <td colspan="5" height="10"></td> + </tr> + <tr> + <td class="w30" width="30"></td> + <td class="w580" width="580" valign="top"> + <p + align="right" + class="pagebottom-content-left" + style="color:#FFFFFF; font-size:16px; padding-top:12px;" + > + Créé par votre application Ecolyo + </p> + </td> + <td class="w30" width="30"></td> + </tr> + <tr> + <td + colspan="5" + height="10" + style="color:#FFFFFF; font-size:11px; padding-top:12px;" + align="center" + > + </td> + </tr> + <tr> + <td colspan="5" height="10"></td> + </tr> + </tbody> + </table> + </td> + </tr> + <tr> + <td class="w640" width="640" height="60"></td> + </tr> + </tbody> + </table> + </td> + </tr> + </tbody> + </table> + </td> + </tr> + </tbody> + </table> + </body> + </html> + ` + } +} diff --git a/yarn.lock b/yarn.lock index 545ed92b970e09d4bd23ff7f735f165880493c84..cdf1e09371455206900abea31a709a53f42b7cc4 100644 --- a/yarn.lock +++ b/yarn.lock @@ -9472,13 +9472,6 @@ minilog@3.1.0, "minilog@https://github.com/cozy/minilog.git#master": dependencies: microee "0.0.6" -"minilog@git+https://github.com/cozy/minilog.git#master": - version "3.1.0" - uid f01f7d9dfe20981177dd34b9662c2f077d818f82 - resolved "git+https://github.com/cozy/minilog.git#f01f7d9dfe20981177dd34b9662c2f077d818f82" - dependencies: - microee "0.0.6" - minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7"