Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Saifadin/postonents

React meets Emails | ⚛️ x 📧= 🔥
https://github.com/Saifadin/postonents

components emails hacktoberfest pdf react react-dom ssr typescript ui

Last synced: 3 months ago
JSON representation

React meets Emails | ⚛️ x 📧= 🔥

Awesome Lists containing this project

README

        

![Postonent](https://user-images.githubusercontent.com/1507057/50406874-db91d080-07cc-11e9-9c39-8f7cb3b84170.png)

A simple UI library for light-weight, highly customizable Email components. Remove the pain of writing emails, by writing the templates in React, then SSR them and pass the generated HTML to the Backend to send it out.

[![npm version](https://badge.fury.io/js/postonents.svg)](https://badge.fury.io/js/postonents) [![contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=flat)](https://github.com/Saifadin/postonents/issues) [![blazing](https://img.shields.io/badge/Status-Blazing%20%F0%9F%94%A5-brightgreen.svg)](https://github.com/Saifadin/postonents)

## Installation

To start with `postonents` install:

```
yarn add postonents
// or
npm install --save postonents
```

## Simple nodeJS setup

To add postonents to a nodeJS application also add install `react` and `react-dom`.

```
yarn add react react-dom
// or
npm install --save react react-dom
```

This will allow you to write something like this to generate an html string that can be provided to services like sendinblue or mandrill.

```jsx
import React from 'react';
import { renderHtml, Email, PostonentsProvider, Header } from 'postonents';

const Email = ({ email }) => (





);

const getHtml = async () => {
const html = await renderHtml(Email, { email: '[email protected]' });

return html;
};

// Now you can send the email with any email client library/service
```

## Components included

Included in this package are the following components:

- **`Template`**: The Wrapper component, that generates the ``, `` and `` tags with many customization possibilities like adding scripts and global styles.
- **`Container`**: Component to generally wrap `Row`s. By default a max of 600px wide. (for the reason why see [here](http://templates.mailchimp.com/development/html/))
- **`Row`**: Each row has 12 possible `Column`s, that wrap, if they are too big.
- **`Column`**: A Column for content separation, can be customized for `small` (<600px) and `large` (>=600px).
- **`Text`**: Component to display and style text content.
- **`Link`**: Component to display and style links (`a` tag). Can have the look of a link, a primary button and a hollow button.
- **`Image`**: Component for images. Needs a src and either height or width definition.
- **`Header`**, **`Footer`**: Two Layout Components for Layouting
- **`FullWidth`**: Basically a `Container` and a `Row`. For layouting on the top level, if different backgroundColors are wanted.
- **`PostonentsProvider`**, **`PostonentsConsumer`** and **`PostonentContext`**: Multiple possible ways to access or change the internal Context for styling components.
- **`renderHtml`**: A function that server-side renders your template and returns it as a string.

## Component API

All components generally have a `children`, a `className` and a `style` prop and this will be applied to the element that has the styling for easy overrides and customization

### **`Template`**

| Prop | type | required | description |
| --------------- | ---------------------------------- | -------- | ---------------------------------------------------------------------------------------------------------------- |
| `lang` | string | yes | Will be added to the `html` tag |
| `title` | string | yes | The `title` of the email |
| `headAdditions` | array<{ type, children?, props? }> | no | Needs to be an array, with a type (eg. `link`), props and maybe children, internally we do `React.createElement` |
| `headStyles` | string | no | Styles in the `head` tag, will automatically be wrapped in `