1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-23 20:22:45 +01:00
immich/web
Nicolò 9bce3417e9
feat(server): email notifications ()
* feat(server): add `react-mail` as mail template engine and `nodemailer`

* feat(server): add `smtp` related configs to `SystemConfig`

* feat(web): add page for SMTP settings

* feat(server): add `react-email.adapter`

This adapter render the React-Email into HTML and plain/text email.
The output is set as the body of the email.

* feat(server): add `MailRepository` and `MailService`

Allow to use the NestJS-modules-mailer module to send SMTP emails.
This is the base transport for the `NotificationRepository`

* feat(server): register the job dispatcher and Job for async email

This allows to queue email sending jobs for the `EmailService`.

* feat(server): add `NotificationRepository` and `NotificationService`

This act as a middleware to properly route the notification to the right transport.
As POC I've only implemented a simple SMTP transport.

* feat(server): add `welcome` email template

* feat(server): add the first notification on `createUser` in `UserService`

This trigger an event for the `NotificationRepository` that once processes
by using the global config and per-user config will carry the payload to the right notification transport.

* chore: clean up

* chore: clean up web

* fix: type errors"

* fix package lock

* fix mail sending, option to ignore certs

* chore: open api

* chore: clean up

* remove unused import

* feat: email feature flag

* chore: remove unused interface

* small styling

---------

Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Daniel Dietzler <mail@ddietzler.dev>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2024-05-02 15:43:18 +01:00
..
bin chore: web shutdown signal () 2024-02-14 08:57:02 -06:00
src feat(server): email notifications () 2024-05-02 15:43:18 +01:00
static chore(web): favicon without white bg () 2024-03-24 16:44:59 -05:00
.dockerignore feat(web)!: SPA () 2023-11-17 22:13:36 -06:00
.eslintignore chore(deps): update web () 2024-03-20 14:08:01 -05:00
.eslintrc.cjs chore(deps): update dependency eslint-plugin-unicorn to v52 () 2024-04-08 12:45:46 -04:00
.gitignore Add ablum feature to web () 2022-07-15 23:18:17 -05:00
.npmrc Add web interface with admin functionality () 2022-05-21 02:23:55 -05:00
.nvmrc chore: fvm and node dependency updates and pinning () 2024-05-01 14:05:18 +01:00
.prettierignore refactor: open api () 2024-01-12 07:36:27 -05:00
.prettierrc chore(web): auto sort imports () 2024-02-14 10:54:32 -05:00
Dockerfile chore(deps): update node.js to 142644a () 2024-04-29 22:15:22 -04:00
package-lock.json fix(deps): update typescript-projects () 2024-05-02 01:33:17 +01:00
package.json chore: fvm and node dependency updates and pinning () 2024-05-01 14:05:18 +01:00
postcss.config.cjs chore(web): prettier () 2023-06-30 23:50:47 -05:00
README.md docs: add some details for getting started as a developer () 2024-04-02 11:56:33 -05:00
svelte.config.js perf: precompress and cache assets () 2024-03-08 21:15:38 -05:00
tailwind.config.cjs fix(web): asset-grid padding/margin left fix () 2024-03-21 00:18:38 -05:00
tsconfig.json fix(web): validation when editing asset date & time () 2024-02-17 09:28:34 -05:00
vite.config.js feat(web): separate command to build with rollup plugin visualizer () 2024-04-26 15:36:30 -04:00

Immich web project

This project uses the SvelteKit web framework. Please refer to the SvelteKit docs for information on getting started as a contributor to this project. In particular, it will help you navigate the project's code if you understand the basics of SvelteKit routing.

When developing locally, you will run a SvelteKit Node.js server. When this project is deployed to production, it is built as a SPA and deployed as part of [../server](the server project).