react-email 4.0.15 → 4.0.17
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.
- package/CHANGELOG.md +18 -0
- package/dist/cli/index.d.mts +1 -0
- package/dist/cli/index.d.ts +1 -0
- package/dist/cli/index.js +2785 -0
- package/dist/cli/index.mjs +77 -47
- package/dist/index.d.mts +20 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.js +1410 -0
- package/dist/index.mjs +21 -0
- package/dist/package/index.d.mts +33 -0
- package/dist/package/index.d.ts +33 -0
- package/dist/package/index.js +62 -0
- package/dist/package/index.mjs +7 -0
- package/dist/preview/.next/BUILD_ID +1 -1
- package/dist/preview/.next/app-build-manifest.json +10 -10
- package/dist/preview/.next/app-path-routes-manifest.json +1 -1
- package/dist/preview/.next/build-manifest.json +3 -3
- package/dist/preview/.next/next-minimal-server.js.nft.json +1 -1
- package/dist/preview/.next/next-server.js.nft.json +1 -1
- package/dist/preview/.next/prerender-manifest.json +3 -3
- package/dist/preview/.next/required-server-files.json +4 -4
- package/dist/preview/.next/server/app/_not-found/page.js +1 -1
- package/dist/preview/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/dist/preview/.next/server/app/favicon.ico/route.js +1 -1
- package/dist/preview/.next/server/app/page.js +1 -1
- package/dist/preview/.next/server/app/page.js.nft.json +1 -1
- package/dist/preview/.next/server/app/page_client-reference-manifest.js +1 -1
- package/dist/preview/.next/server/app/preview/[...slug]/page.js +17 -17
- package/dist/preview/.next/server/app/preview/[...slug]/page.js.nft.json +1 -1
- package/dist/preview/.next/server/app/preview/[...slug]/page_client-reference-manifest.js +1 -1
- package/dist/preview/.next/server/app-paths-manifest.json +1 -1
- package/dist/preview/.next/server/chunks/147.js +1 -0
- package/dist/preview/.next/server/chunks/235.js +4 -4
- package/dist/preview/.next/server/middleware-build-manifest.js +1 -1
- package/dist/preview/.next/server/next-font-manifest.js +1 -1
- package/dist/preview/.next/server/next-font-manifest.json +1 -1
- package/dist/preview/.next/server/pages/500.html +1 -1
- package/dist/preview/.next/server/pages-manifest.json +1 -1
- package/dist/preview/.next/server/server-reference-manifest.js +1 -1
- package/dist/preview/.next/server/server-reference-manifest.json +1 -1
- package/dist/preview/.next/static/chunks/484-3d4d9735a701a476.js +1 -0
- package/dist/preview/.next/static/chunks/app/layout-95b74654735388bd.js +1 -0
- package/dist/preview/.next/static/chunks/app/page-2dbfb5b2dc4b1191.js +1 -0
- package/dist/preview/.next/static/chunks/app/preview/[...slug]/page-42afb14d97d633e3.js +1 -0
- package/dist/preview/.next/static/chunks/main-app-976577a424e11c75.js +1 -0
- package/dist/preview/.next/static/css/{35e8811589f0962b.css → 78c81281aa95270f.css} +1 -1
- package/dist/preview/.next/static/media/8e9860b6e62d6359-s.woff2 +0 -0
- package/dist/preview/.next/static/media/e4af272ccee01ff0-s.p.woff2 +0 -0
- package/dist/preview/.next/trace +27 -27
- package/dist/preview/.next/types/app/layout.ts +1 -1
- package/dist/preview/.next/types/app/page.ts +1 -1
- package/dist/preview/.next/types/app/preview/[...slug]/page.ts +1 -1
- package/package.json +4 -3
- package/src/app/layout.tsx +2 -2
- package/src/app/preview/[...slug]/preview.tsx +1 -1
- package/src/commands/testing/out/notifications/yelp-recent-login.html +1 -1
- package/src/commands/testing/out/reset-password/twitch-reset-password.html +1 -1
- package/src/components/shell.tsx +4 -1
- package/src/components/sidebar/file-tree-directory-children.tsx +7 -2
- package/src/package/body/dist/index.d.mts +6 -0
- package/src/package/body/dist/index.d.ts +6 -0
- package/src/package/body/dist/index.js +79 -0
- package/src/package/body/dist/index.mjs +45 -0
- package/src/package/button/dist/index.d.mts +6 -0
- package/src/package/button/dist/index.d.ts +6 -0
- package/src/package/button/dist/index.js +252 -0
- package/src/package/button/dist/index.mjs +218 -0
- package/src/package/code-block/dist/index.d.mts +4906 -0
- package/src/package/code-block/dist/index.d.ts +4906 -0
- package/src/package/code-block/dist/index.js +18205 -0
- package/src/package/code-block/dist/index.mjs +18133 -0
- package/src/package/code-inline/dist/index.d.mts +11 -0
- package/src/package/code-inline/dist/index.d.ts +11 -0
- package/src/package/code-inline/dist/index.js +106 -0
- package/src/package/code-inline/dist/index.mjs +72 -0
- package/src/package/column/dist/index.d.mts +6 -0
- package/src/package/column/dist/index.d.ts +6 -0
- package/src/package/column/dist/index.js +79 -0
- package/src/package/column/dist/index.mjs +45 -0
- package/src/package/components/dist/index.d.mts +20 -0
- package/src/package/components/dist/index.d.ts +20 -0
- package/src/package/components/dist/index.js +62 -0
- package/src/package/components/dist/index.mjs +21 -0
- package/src/package/container/dist/index.d.mts +6 -0
- package/src/package/container/dist/index.d.ts +6 -0
- package/src/package/container/dist/index.js +93 -0
- package/src/package/container/dist/index.mjs +59 -0
- package/src/package/font/dist/index.d.mts +25 -0
- package/src/package/font/dist/index.d.ts +25 -0
- package/src/package/font/dist/index.js +55 -0
- package/src/package/font/dist/index.mjs +28 -0
- package/src/package/head/dist/index.d.mts +6 -0
- package/src/package/head/dist/index.d.ts +6 -0
- package/src/package/head/dist/index.js +83 -0
- package/src/package/head/dist/index.mjs +49 -0
- package/src/package/heading/dist/index.d.mts +43 -0
- package/src/package/heading/dist/index.d.ts +43 -0
- package/src/package/heading/dist/index.js +113 -0
- package/src/package/heading/dist/index.mjs +79 -0
- package/src/package/hr/dist/index.d.mts +6 -0
- package/src/package/hr/dist/index.d.ts +6 -0
- package/src/package/hr/dist/index.js +89 -0
- package/src/package/hr/dist/index.mjs +55 -0
- package/src/package/html/dist/index.d.mts +6 -0
- package/src/package/html/dist/index.d.ts +6 -0
- package/src/package/html/dist/index.js +79 -0
- package/src/package/html/dist/index.mjs +45 -0
- package/src/package/img/dist/index.d.mts +6 -0
- package/src/package/img/dist/index.d.ts +6 -0
- package/src/package/img/dist/index.js +94 -0
- package/src/package/img/dist/index.mjs +60 -0
- package/src/package/link/dist/index.d.mts +6 -0
- package/src/package/link/dist/index.d.ts +6 -0
- package/src/package/link/dist/index.js +90 -0
- package/src/package/link/dist/index.mjs +56 -0
- package/src/package/markdown/dist/index.d.mts +15 -0
- package/src/package/markdown/dist/index.d.ts +15 -0
- package/src/package/markdown/dist/index.js +92 -0
- package/src/package/markdown/dist/index.mjs +58 -0
- package/src/package/preview/dist/index.d.mts +12 -0
- package/src/package/preview/dist/index.d.ts +12 -0
- package/src/package/preview/dist/index.js +108 -0
- package/src/package/preview/dist/index.mjs +73 -0
- package/src/package/render/dist/browser/index.d.mts +24 -0
- package/src/package/render/dist/browser/index.d.ts +24 -0
- package/src/package/render/dist/browser/index.js +250 -0
- package/src/package/render/dist/browser/index.mjs +214 -0
- package/src/package/render/dist/index.d.mts +23 -0
- package/src/package/render/dist/index.d.ts +23 -0
- package/src/package/render/dist/index.js +768 -0
- package/src/package/render/dist/index.mjs +733 -0
- package/src/package/render/dist/node/index.d.mts +27 -0
- package/src/package/render/dist/node/index.d.ts +27 -0
- package/src/package/render/dist/node/index.js +212 -0
- package/src/package/render/dist/node/index.mjs +176 -0
- package/src/package/row/dist/index.d.mts +10 -0
- package/src/package/row/dist/index.d.ts +10 -0
- package/src/package/row/dist/index.js +93 -0
- package/src/package/row/dist/index.mjs +59 -0
- package/src/package/section/dist/index.d.mts +6 -0
- package/src/package/section/dist/index.d.ts +6 -0
- package/src/package/section/dist/index.js +93 -0
- package/src/package/section/dist/index.mjs +59 -0
- package/src/package/tailwind/dist/index.d.ts +19 -0
- package/src/package/tailwind/dist/index.js +48 -0
- package/src/package/tailwind/dist/index.mjs +17167 -0
- package/src/package/tailwind/dist/tailwindcss/config.d.ts +376 -0
- package/src/package/tailwind/dist/tailwindcss/generated/.gitkeep +0 -0
- package/src/package/tailwind/dist/tailwindcss/generated/colors.d.ts +298 -0
- package/src/package/tailwind/dist/tailwindcss/generated/corePluginList.d.ts +1 -0
- package/src/package/tailwind/dist/tailwindcss/generated/default-theme.d.ts +397 -0
- package/src/package/tailwind/dist/tailwindcss/index.d.ts +11 -0
- package/src/package/text/dist/index.d.mts +6 -0
- package/src/package/text/dist/index.d.ts +6 -0
- package/src/package/text/dist/index.js +89 -0
- package/src/package/text/dist/index.mjs +55 -0
- package/src/utils/__snapshots__/get-email-component.spec.ts.snap +1 -1
- package/src/utils/caniemail/get-element-names.ts +9 -3
- package/src/utils/contains-email-template.spec.ts +12 -0
- package/src/utils/contains-email-template.ts +26 -9
- package/src/utils/improve-error-with-sourcemap.ts +0 -1
- package/src/utils/types/error-object.ts +1 -1
- package/dist/preview/.next/server/chunks/488.js +0 -1
- package/dist/preview/.next/static/chunks/484-21e30f98c67e8d58.js +0 -1
- package/dist/preview/.next/static/chunks/app/layout-3044a159bf29302b.js +0 -1
- package/dist/preview/.next/static/chunks/app/page-ed77f0af99f8ff62.js +0 -1
- package/dist/preview/.next/static/chunks/app/preview/[...slug]/page-994a4d501e46f3f8.js +0 -1
- package/dist/preview/.next/static/chunks/main-app-5bc2d814f500db60.js +0 -1
- package/dist/preview/.next/static/media/6d93bde91c0c2823-s.woff2 +0 -0
- package/dist/preview/.next/static/media/a34f9d1faa5f3315-s.p.woff2 +0 -0
- /package/dist/preview/.next/static/{0LFN6rP55keVoTJYuP-4s → 9A_Lez8sdD6nDBcSehk5k}/_buildManifest.js +0 -0
- /package/dist/preview/.next/static/{0LFN6rP55keVoTJYuP-4s → 9A_Lez8sdD6nDBcSehk5k}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __objRest = (source, exclude) => {
|
|
21
|
+
var target = {};
|
|
22
|
+
for (var prop in source)
|
|
23
|
+
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
+
target[prop] = source[prop];
|
|
25
|
+
if (source != null && __getOwnPropSymbols)
|
|
26
|
+
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
+
target[prop] = source[prop];
|
|
29
|
+
}
|
|
30
|
+
return target;
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
// src/markdown.tsx
|
|
34
|
+
import { parseMarkdownToJSX } from "md-to-react-email";
|
|
35
|
+
import * as React from "react";
|
|
36
|
+
import { jsx } from "react/jsx-runtime";
|
|
37
|
+
var Markdown = React.forwardRef(
|
|
38
|
+
(_a, ref) => {
|
|
39
|
+
var _b = _a, { children, markdownContainerStyles, markdownCustomStyles } = _b, props = __objRest(_b, ["children", "markdownContainerStyles", "markdownCustomStyles"]);
|
|
40
|
+
const parsedMarkdown = parseMarkdownToJSX({
|
|
41
|
+
markdown: children,
|
|
42
|
+
customStyles: markdownCustomStyles
|
|
43
|
+
});
|
|
44
|
+
return /* @__PURE__ */ jsx(
|
|
45
|
+
"div",
|
|
46
|
+
__spreadProps(__spreadValues({}, props), {
|
|
47
|
+
dangerouslySetInnerHTML: { __html: parsedMarkdown },
|
|
48
|
+
"data-id": "react-email-markdown",
|
|
49
|
+
ref,
|
|
50
|
+
style: markdownContainerStyles
|
|
51
|
+
})
|
|
52
|
+
);
|
|
53
|
+
}
|
|
54
|
+
);
|
|
55
|
+
Markdown.displayName = "Markdown";
|
|
56
|
+
export {
|
|
57
|
+
Markdown
|
|
58
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
|
|
4
|
+
type PreviewProps = Readonly<React.ComponentPropsWithoutRef<"div"> & {
|
|
5
|
+
children: string | string[];
|
|
6
|
+
}>;
|
|
7
|
+
declare const Preview: React.ForwardRefExoticComponent<Readonly<Omit<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
|
|
8
|
+
children: string | string[];
|
|
9
|
+
}> & React.RefAttributes<HTMLDivElement>>;
|
|
10
|
+
declare const renderWhiteSpace: (text: string) => react_jsx_runtime.JSX.Element | null;
|
|
11
|
+
|
|
12
|
+
export { Preview, type PreviewProps, renderWhiteSpace };
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
|
|
4
|
+
type PreviewProps = Readonly<React.ComponentPropsWithoutRef<"div"> & {
|
|
5
|
+
children: string | string[];
|
|
6
|
+
}>;
|
|
7
|
+
declare const Preview: React.ForwardRefExoticComponent<Readonly<Omit<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
|
|
8
|
+
children: string | string[];
|
|
9
|
+
}> & React.RefAttributes<HTMLDivElement>>;
|
|
10
|
+
declare const renderWhiteSpace: (text: string) => react_jsx_runtime.JSX.Element | null;
|
|
11
|
+
|
|
12
|
+
export { Preview, type PreviewProps, renderWhiteSpace };
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __defProps = Object.defineProperties;
|
|
5
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
6
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
7
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
8
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
9
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
10
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
11
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
12
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
13
|
+
var __spreadValues = (a, b) => {
|
|
14
|
+
for (var prop in b || (b = {}))
|
|
15
|
+
if (__hasOwnProp.call(b, prop))
|
|
16
|
+
__defNormalProp(a, prop, b[prop]);
|
|
17
|
+
if (__getOwnPropSymbols)
|
|
18
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
19
|
+
if (__propIsEnum.call(b, prop))
|
|
20
|
+
__defNormalProp(a, prop, b[prop]);
|
|
21
|
+
}
|
|
22
|
+
return a;
|
|
23
|
+
};
|
|
24
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
25
|
+
var __objRest = (source, exclude) => {
|
|
26
|
+
var target = {};
|
|
27
|
+
for (var prop in source)
|
|
28
|
+
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
29
|
+
target[prop] = source[prop];
|
|
30
|
+
if (source != null && __getOwnPropSymbols)
|
|
31
|
+
for (var prop of __getOwnPropSymbols(source)) {
|
|
32
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
33
|
+
target[prop] = source[prop];
|
|
34
|
+
}
|
|
35
|
+
return target;
|
|
36
|
+
};
|
|
37
|
+
var __export = (target, all) => {
|
|
38
|
+
for (var name in all)
|
|
39
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
40
|
+
};
|
|
41
|
+
var __copyProps = (to, from, except, desc) => {
|
|
42
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
43
|
+
for (let key of __getOwnPropNames(from))
|
|
44
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
45
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
46
|
+
}
|
|
47
|
+
return to;
|
|
48
|
+
};
|
|
49
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
50
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
51
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
52
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
53
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
54
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
55
|
+
mod
|
|
56
|
+
));
|
|
57
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
58
|
+
|
|
59
|
+
// src/index.ts
|
|
60
|
+
var src_exports = {};
|
|
61
|
+
__export(src_exports, {
|
|
62
|
+
Preview: () => Preview,
|
|
63
|
+
renderWhiteSpace: () => renderWhiteSpace
|
|
64
|
+
});
|
|
65
|
+
module.exports = __toCommonJS(src_exports);
|
|
66
|
+
|
|
67
|
+
// src/preview.tsx
|
|
68
|
+
var React = __toESM(require("react"));
|
|
69
|
+
var import_jsx_runtime = require("react/jsx-runtime");
|
|
70
|
+
var PREVIEW_MAX_LENGTH = 150;
|
|
71
|
+
var Preview = React.forwardRef(
|
|
72
|
+
(_a, ref) => {
|
|
73
|
+
var _b = _a, { children = "" } = _b, props = __objRest(_b, ["children"]);
|
|
74
|
+
const text = (Array.isArray(children) ? children.join("") : children).substring(0, PREVIEW_MAX_LENGTH);
|
|
75
|
+
return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
|
|
76
|
+
"div",
|
|
77
|
+
__spreadProps(__spreadValues({
|
|
78
|
+
style: {
|
|
79
|
+
display: "none",
|
|
80
|
+
overflow: "hidden",
|
|
81
|
+
lineHeight: "1px",
|
|
82
|
+
opacity: 0,
|
|
83
|
+
maxHeight: 0,
|
|
84
|
+
maxWidth: 0
|
|
85
|
+
}
|
|
86
|
+
}, props), {
|
|
87
|
+
ref,
|
|
88
|
+
children: [
|
|
89
|
+
text,
|
|
90
|
+
renderWhiteSpace(text)
|
|
91
|
+
]
|
|
92
|
+
})
|
|
93
|
+
);
|
|
94
|
+
}
|
|
95
|
+
);
|
|
96
|
+
Preview.displayName = "Preview";
|
|
97
|
+
var whiteSpaceCodes = "\xA0\u200C\u200B\u200D\u200E\u200F\uFEFF";
|
|
98
|
+
var renderWhiteSpace = (text) => {
|
|
99
|
+
if (text.length >= PREVIEW_MAX_LENGTH) {
|
|
100
|
+
return null;
|
|
101
|
+
}
|
|
102
|
+
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { children: whiteSpaceCodes.repeat(PREVIEW_MAX_LENGTH - text.length) });
|
|
103
|
+
};
|
|
104
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
105
|
+
0 && (module.exports = {
|
|
106
|
+
Preview,
|
|
107
|
+
renderWhiteSpace
|
|
108
|
+
});
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __objRest = (source, exclude) => {
|
|
21
|
+
var target = {};
|
|
22
|
+
for (var prop in source)
|
|
23
|
+
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
+
target[prop] = source[prop];
|
|
25
|
+
if (source != null && __getOwnPropSymbols)
|
|
26
|
+
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
+
target[prop] = source[prop];
|
|
29
|
+
}
|
|
30
|
+
return target;
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
// src/preview.tsx
|
|
34
|
+
import * as React from "react";
|
|
35
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
36
|
+
var PREVIEW_MAX_LENGTH = 150;
|
|
37
|
+
var Preview = React.forwardRef(
|
|
38
|
+
(_a, ref) => {
|
|
39
|
+
var _b = _a, { children = "" } = _b, props = __objRest(_b, ["children"]);
|
|
40
|
+
const text = (Array.isArray(children) ? children.join("") : children).substring(0, PREVIEW_MAX_LENGTH);
|
|
41
|
+
return /* @__PURE__ */ jsxs(
|
|
42
|
+
"div",
|
|
43
|
+
__spreadProps(__spreadValues({
|
|
44
|
+
style: {
|
|
45
|
+
display: "none",
|
|
46
|
+
overflow: "hidden",
|
|
47
|
+
lineHeight: "1px",
|
|
48
|
+
opacity: 0,
|
|
49
|
+
maxHeight: 0,
|
|
50
|
+
maxWidth: 0
|
|
51
|
+
}
|
|
52
|
+
}, props), {
|
|
53
|
+
ref,
|
|
54
|
+
children: [
|
|
55
|
+
text,
|
|
56
|
+
renderWhiteSpace(text)
|
|
57
|
+
]
|
|
58
|
+
})
|
|
59
|
+
);
|
|
60
|
+
}
|
|
61
|
+
);
|
|
62
|
+
Preview.displayName = "Preview";
|
|
63
|
+
var whiteSpaceCodes = "\xA0\u200C\u200B\u200D\u200E\u200F\uFEFF";
|
|
64
|
+
var renderWhiteSpace = (text) => {
|
|
65
|
+
if (text.length >= PREVIEW_MAX_LENGTH) {
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
return /* @__PURE__ */ jsx("div", { children: whiteSpaceCodes.repeat(PREVIEW_MAX_LENGTH - text.length) });
|
|
69
|
+
};
|
|
70
|
+
export {
|
|
71
|
+
Preview,
|
|
72
|
+
renderWhiteSpace
|
|
73
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { HtmlToTextOptions, SelectorDefinition } from 'html-to-text';
|
|
2
|
+
|
|
3
|
+
type Options = {
|
|
4
|
+
pretty?: boolean;
|
|
5
|
+
} & ({
|
|
6
|
+
plainText?: false;
|
|
7
|
+
} | {
|
|
8
|
+
plainText?: true;
|
|
9
|
+
/**
|
|
10
|
+
* These are options you can pass down directly to the library we use for
|
|
11
|
+
* converting the rendered email's HTML into plain text.
|
|
12
|
+
*
|
|
13
|
+
* @see https://github.com/html-to-text/node-html-to-text
|
|
14
|
+
*/
|
|
15
|
+
htmlToTextOptions?: HtmlToTextOptions;
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
declare const render: (element: React.ReactElement, options?: Options) => Promise<string>;
|
|
19
|
+
|
|
20
|
+
declare const renderAsync: (element: React.ReactElement, options?: Options) => Promise<string>;
|
|
21
|
+
|
|
22
|
+
declare const plainTextSelectors: SelectorDefinition[];
|
|
23
|
+
|
|
24
|
+
export { Options, plainTextSelectors, render, renderAsync };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { HtmlToTextOptions, SelectorDefinition } from 'html-to-text';
|
|
2
|
+
|
|
3
|
+
type Options = {
|
|
4
|
+
pretty?: boolean;
|
|
5
|
+
} & ({
|
|
6
|
+
plainText?: false;
|
|
7
|
+
} | {
|
|
8
|
+
plainText?: true;
|
|
9
|
+
/**
|
|
10
|
+
* These are options you can pass down directly to the library we use for
|
|
11
|
+
* converting the rendered email's HTML into plain text.
|
|
12
|
+
*
|
|
13
|
+
* @see https://github.com/html-to-text/node-html-to-text
|
|
14
|
+
*/
|
|
15
|
+
htmlToTextOptions?: HtmlToTextOptions;
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
declare const render: (element: React.ReactElement, options?: Options) => Promise<string>;
|
|
19
|
+
|
|
20
|
+
declare const renderAsync: (element: React.ReactElement, options?: Options) => Promise<string>;
|
|
21
|
+
|
|
22
|
+
declare const plainTextSelectors: SelectorDefinition[];
|
|
23
|
+
|
|
24
|
+
export { Options, plainTextSelectors, render, renderAsync };
|
|
@@ -0,0 +1,250 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
7
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
8
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
9
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
10
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
11
|
+
var __spreadValues = (a, b) => {
|
|
12
|
+
for (var prop in b || (b = {}))
|
|
13
|
+
if (__hasOwnProp.call(b, prop))
|
|
14
|
+
__defNormalProp(a, prop, b[prop]);
|
|
15
|
+
if (__getOwnPropSymbols)
|
|
16
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
17
|
+
if (__propIsEnum.call(b, prop))
|
|
18
|
+
__defNormalProp(a, prop, b[prop]);
|
|
19
|
+
}
|
|
20
|
+
return a;
|
|
21
|
+
};
|
|
22
|
+
var __export = (target, all) => {
|
|
23
|
+
for (var name in all)
|
|
24
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
25
|
+
};
|
|
26
|
+
var __copyProps = (to, from, except, desc) => {
|
|
27
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
28
|
+
for (let key of __getOwnPropNames(from))
|
|
29
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
30
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
31
|
+
}
|
|
32
|
+
return to;
|
|
33
|
+
};
|
|
34
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
35
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
36
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
37
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
38
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
39
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
40
|
+
mod
|
|
41
|
+
));
|
|
42
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
43
|
+
var __async = (__this, __arguments, generator) => {
|
|
44
|
+
return new Promise((resolve, reject) => {
|
|
45
|
+
var fulfilled = (value) => {
|
|
46
|
+
try {
|
|
47
|
+
step(generator.next(value));
|
|
48
|
+
} catch (e) {
|
|
49
|
+
reject(e);
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
var rejected = (value) => {
|
|
53
|
+
try {
|
|
54
|
+
step(generator.throw(value));
|
|
55
|
+
} catch (e) {
|
|
56
|
+
reject(e);
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
60
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
61
|
+
});
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
// src/browser/index.ts
|
|
65
|
+
var browser_exports = {};
|
|
66
|
+
__export(browser_exports, {
|
|
67
|
+
plainTextSelectors: () => plainTextSelectors,
|
|
68
|
+
render: () => render,
|
|
69
|
+
renderAsync: () => renderAsync
|
|
70
|
+
});
|
|
71
|
+
module.exports = __toCommonJS(browser_exports);
|
|
72
|
+
|
|
73
|
+
// src/browser/render.tsx
|
|
74
|
+
var import_html_to_text = require("html-to-text");
|
|
75
|
+
var import_react = require("react");
|
|
76
|
+
|
|
77
|
+
// src/shared/utils/pretty.ts
|
|
78
|
+
var import_standalone = require("prettier/standalone");
|
|
79
|
+
var import_html = __toESM(require("prettier/plugins/html"));
|
|
80
|
+
var defaults = {
|
|
81
|
+
endOfLine: "lf",
|
|
82
|
+
tabWidth: 2,
|
|
83
|
+
plugins: [import_html.default],
|
|
84
|
+
parser: "html"
|
|
85
|
+
};
|
|
86
|
+
var pretty = (str, options = {}) => {
|
|
87
|
+
return (0, import_standalone.format)(str, __spreadValues(__spreadValues({}, defaults), options));
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
// src/shared/plain-text-selectors.ts
|
|
91
|
+
var plainTextSelectors = [
|
|
92
|
+
{ selector: "img", format: "skip" },
|
|
93
|
+
{ selector: "#__react-email-preview", format: "skip" },
|
|
94
|
+
{
|
|
95
|
+
selector: "a",
|
|
96
|
+
options: { linkBrackets: false }
|
|
97
|
+
}
|
|
98
|
+
];
|
|
99
|
+
|
|
100
|
+
// src/browser/render.tsx
|
|
101
|
+
var import_jsx_runtime = require("react/jsx-runtime");
|
|
102
|
+
var decoder = new TextDecoder("utf-8");
|
|
103
|
+
var readStream = (stream) => __async(void 0, null, function* () {
|
|
104
|
+
const chunks = [];
|
|
105
|
+
if ("pipeTo" in stream) {
|
|
106
|
+
const writableStream = new WritableStream({
|
|
107
|
+
write(chunk) {
|
|
108
|
+
chunks.push(chunk);
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
yield stream.pipeTo(writableStream);
|
|
112
|
+
} else {
|
|
113
|
+
throw new Error(
|
|
114
|
+
"For some reason, the Node version of `react-dom/server` has been imported instead of the browser one.",
|
|
115
|
+
{
|
|
116
|
+
cause: {
|
|
117
|
+
stream
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
);
|
|
121
|
+
}
|
|
122
|
+
let length = 0;
|
|
123
|
+
chunks.forEach((item) => {
|
|
124
|
+
length += item.length;
|
|
125
|
+
});
|
|
126
|
+
const mergedChunks = new Uint8Array(length);
|
|
127
|
+
let offset = 0;
|
|
128
|
+
chunks.forEach((item) => {
|
|
129
|
+
mergedChunks.set(item, offset);
|
|
130
|
+
offset += item.length;
|
|
131
|
+
});
|
|
132
|
+
return decoder.decode(mergedChunks);
|
|
133
|
+
});
|
|
134
|
+
var render = (element, options) => __async(void 0, null, function* () {
|
|
135
|
+
const suspendedElement = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react.Suspense, { children: element });
|
|
136
|
+
const reactDOMServer = yield import("react-dom/server");
|
|
137
|
+
let html2;
|
|
138
|
+
if (Object.hasOwn(reactDOMServer, "renderToReadableStream")) {
|
|
139
|
+
html2 = yield readStream(
|
|
140
|
+
yield reactDOMServer.renderToReadableStream(suspendedElement)
|
|
141
|
+
);
|
|
142
|
+
} else {
|
|
143
|
+
yield new Promise((resolve, reject) => {
|
|
144
|
+
const stream = reactDOMServer.renderToPipeableStream(suspendedElement, {
|
|
145
|
+
onAllReady() {
|
|
146
|
+
return __async(this, null, function* () {
|
|
147
|
+
html2 = yield readStream(stream);
|
|
148
|
+
resolve();
|
|
149
|
+
});
|
|
150
|
+
},
|
|
151
|
+
onError(error) {
|
|
152
|
+
reject(error);
|
|
153
|
+
}
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
if (options == null ? void 0 : options.plainText) {
|
|
158
|
+
return (0, import_html_to_text.convert)(html2, __spreadValues({
|
|
159
|
+
selectors: plainTextSelectors
|
|
160
|
+
}, options.htmlToTextOptions));
|
|
161
|
+
}
|
|
162
|
+
const doctype = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
|
|
163
|
+
const document = `${doctype}${html2.replace(/<!DOCTYPE.*?>/, "")}`;
|
|
164
|
+
if (options == null ? void 0 : options.pretty) {
|
|
165
|
+
return pretty(document);
|
|
166
|
+
}
|
|
167
|
+
return document;
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
// src/browser/render-async.tsx
|
|
171
|
+
var import_html_to_text2 = require("html-to-text");
|
|
172
|
+
var import_react2 = require("react");
|
|
173
|
+
|
|
174
|
+
// src/browser/read-stream.ts
|
|
175
|
+
var decoder2 = new TextDecoder("utf-8");
|
|
176
|
+
var readStream2 = (stream) => __async(void 0, null, function* () {
|
|
177
|
+
const chunks = [];
|
|
178
|
+
if ("pipeTo" in stream) {
|
|
179
|
+
const writableStream = new WritableStream({
|
|
180
|
+
write(chunk) {
|
|
181
|
+
chunks.push(chunk);
|
|
182
|
+
}
|
|
183
|
+
});
|
|
184
|
+
yield stream.pipeTo(writableStream);
|
|
185
|
+
} else {
|
|
186
|
+
throw new Error(
|
|
187
|
+
"For some reason, the Node version of `react-dom/server` has been imported instead of the browser one.",
|
|
188
|
+
{
|
|
189
|
+
cause: {
|
|
190
|
+
stream
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
);
|
|
194
|
+
}
|
|
195
|
+
let length = 0;
|
|
196
|
+
chunks.forEach((item) => {
|
|
197
|
+
length += item.length;
|
|
198
|
+
});
|
|
199
|
+
const mergedChunks = new Uint8Array(length);
|
|
200
|
+
let offset = 0;
|
|
201
|
+
chunks.forEach((item) => {
|
|
202
|
+
mergedChunks.set(item, offset);
|
|
203
|
+
offset += item.length;
|
|
204
|
+
});
|
|
205
|
+
return decoder2.decode(mergedChunks);
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
// src/browser/render-async.tsx
|
|
209
|
+
var import_jsx_runtime2 = require("react/jsx-runtime");
|
|
210
|
+
var renderAsync = (element, options) => __async(void 0, null, function* () {
|
|
211
|
+
const suspendedElement = /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_react2.Suspense, { children: element });
|
|
212
|
+
const reactDOMServer = yield import("react-dom/server");
|
|
213
|
+
let html2;
|
|
214
|
+
if (Object.hasOwn(reactDOMServer, "renderToReadableStream")) {
|
|
215
|
+
html2 = yield readStream2(
|
|
216
|
+
yield reactDOMServer.renderToReadableStream(suspendedElement)
|
|
217
|
+
);
|
|
218
|
+
} else {
|
|
219
|
+
yield new Promise((resolve, reject) => {
|
|
220
|
+
const stream = reactDOMServer.renderToPipeableStream(suspendedElement, {
|
|
221
|
+
onAllReady() {
|
|
222
|
+
return __async(this, null, function* () {
|
|
223
|
+
html2 = yield readStream2(stream);
|
|
224
|
+
resolve();
|
|
225
|
+
});
|
|
226
|
+
},
|
|
227
|
+
onError(error) {
|
|
228
|
+
reject(error);
|
|
229
|
+
}
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
if (options == null ? void 0 : options.plainText) {
|
|
234
|
+
return (0, import_html_to_text2.convert)(html2, __spreadValues({
|
|
235
|
+
selectors: plainTextSelectors
|
|
236
|
+
}, options.htmlToTextOptions));
|
|
237
|
+
}
|
|
238
|
+
const doctype = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
|
|
239
|
+
const document = `${doctype}${html2.replace(/<!DOCTYPE.*?>/, "")}`;
|
|
240
|
+
if (options == null ? void 0 : options.pretty) {
|
|
241
|
+
return pretty(document);
|
|
242
|
+
}
|
|
243
|
+
return document;
|
|
244
|
+
});
|
|
245
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
246
|
+
0 && (module.exports = {
|
|
247
|
+
plainTextSelectors,
|
|
248
|
+
render,
|
|
249
|
+
renderAsync
|
|
250
|
+
});
|