@react-email/render 1.2.2 → 1.3.0
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/dist/browser/index.d.mts +33 -27
- package/dist/browser/index.d.mts.map +1 -0
- package/dist/browser/index.d.ts +33 -27
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +150 -207
- package/dist/browser/index.mjs +126 -178
- package/dist/browser/index.mjs.map +1 -0
- package/dist/edge/index.d.mts +33 -27
- package/dist/edge/index.d.mts.map +1 -0
- package/dist/edge/index.d.ts +33 -27
- package/dist/edge/index.d.ts.map +1 -0
- package/dist/edge/index.js +154 -216
- package/dist/edge/index.mjs +130 -187
- package/dist/edge/index.mjs.map +1 -0
- package/dist/node/index.d.mts +33 -27
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +33 -27
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +157 -222
- package/dist/node/index.mjs +132 -193
- package/dist/node/index.mjs.map +1 -0
- package/package.json +13 -4
- package/readme.md +3 -4
package/dist/edge/index.mjs
CHANGED
|
@@ -1,205 +1,148 @@
|
|
|
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 __async = (__this, __arguments, generator) => {
|
|
21
|
-
return new Promise((resolve, reject) => {
|
|
22
|
-
var fulfilled = (value) => {
|
|
23
|
-
try {
|
|
24
|
-
step(generator.next(value));
|
|
25
|
-
} catch (e) {
|
|
26
|
-
reject(e);
|
|
27
|
-
}
|
|
28
|
-
};
|
|
29
|
-
var rejected = (value) => {
|
|
30
|
-
try {
|
|
31
|
-
step(generator.throw(value));
|
|
32
|
-
} catch (e) {
|
|
33
|
-
reject(e);
|
|
34
|
-
}
|
|
35
|
-
};
|
|
36
|
-
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
37
|
-
step((generator = generator.apply(__this, __arguments)).next());
|
|
38
|
-
});
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
// src/edge/render.tsx
|
|
42
1
|
import { Suspense } from "react";
|
|
43
|
-
|
|
44
|
-
// src/shared/utils/pretty.ts
|
|
45
2
|
import * as html from "prettier/plugins/html";
|
|
46
3
|
import { format } from "prettier/standalone";
|
|
4
|
+
import { convert } from "html-to-text";
|
|
5
|
+
import { jsx } from "react/jsx-runtime";
|
|
6
|
+
|
|
7
|
+
//#region src/shared/utils/pretty.ts
|
|
47
8
|
function recursivelyMapDoc(doc, callback) {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
}
|
|
71
|
-
if (doc.type === "if-break") {
|
|
72
|
-
return __spreadProps(__spreadValues({}, doc), {
|
|
73
|
-
breakContents: recursivelyMapDoc(doc.breakContents, callback),
|
|
74
|
-
flatContents: recursivelyMapDoc(doc.flatContents, callback)
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
return callback(doc);
|
|
9
|
+
if (Array.isArray(doc)) return doc.map((innerDoc) => recursivelyMapDoc(innerDoc, callback));
|
|
10
|
+
if (typeof doc === "object") {
|
|
11
|
+
if (doc.type === "group") return {
|
|
12
|
+
...doc,
|
|
13
|
+
contents: recursivelyMapDoc(doc.contents, callback),
|
|
14
|
+
expandedStates: recursivelyMapDoc(doc.expandedStates, callback)
|
|
15
|
+
};
|
|
16
|
+
if ("contents" in doc) return {
|
|
17
|
+
...doc,
|
|
18
|
+
contents: recursivelyMapDoc(doc.contents, callback)
|
|
19
|
+
};
|
|
20
|
+
if ("parts" in doc) return {
|
|
21
|
+
...doc,
|
|
22
|
+
parts: recursivelyMapDoc(doc.parts, callback)
|
|
23
|
+
};
|
|
24
|
+
if (doc.type === "if-break") return {
|
|
25
|
+
...doc,
|
|
26
|
+
breakContents: recursivelyMapDoc(doc.breakContents, callback),
|
|
27
|
+
flatContents: recursivelyMapDoc(doc.flatContents, callback)
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
return callback(doc);
|
|
79
31
|
}
|
|
80
|
-
|
|
32
|
+
const modifiedHtml = { ...html };
|
|
81
33
|
if (modifiedHtml.printers) {
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
});
|
|
93
|
-
return printingResult;
|
|
94
|
-
}
|
|
95
|
-
return rawPrintingResult;
|
|
96
|
-
};
|
|
34
|
+
const previousPrint = modifiedHtml.printers.html.print;
|
|
35
|
+
modifiedHtml.printers.html.print = (path, options, print, args) => {
|
|
36
|
+
const node = path.getNode();
|
|
37
|
+
const rawPrintingResult = previousPrint(path, options, print, args);
|
|
38
|
+
if (node.type === "ieConditionalComment") return recursivelyMapDoc(rawPrintingResult, (doc) => {
|
|
39
|
+
if (typeof doc === "object" && doc.type === "line") return doc.soft ? "" : " ";
|
|
40
|
+
return doc;
|
|
41
|
+
});
|
|
42
|
+
return rawPrintingResult;
|
|
43
|
+
};
|
|
97
44
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
45
|
+
const defaults = {
|
|
46
|
+
endOfLine: "lf",
|
|
47
|
+
tabWidth: 2,
|
|
48
|
+
plugins: [modifiedHtml],
|
|
49
|
+
bracketSameLine: true,
|
|
50
|
+
parser: "html"
|
|
104
51
|
};
|
|
105
|
-
|
|
106
|
-
|
|
52
|
+
const pretty = (str, options = {}) => {
|
|
53
|
+
return format(str.replaceAll("\0", ""), {
|
|
54
|
+
...defaults,
|
|
55
|
+
...options
|
|
56
|
+
});
|
|
107
57
|
};
|
|
108
58
|
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
59
|
+
//#endregion
|
|
60
|
+
//#region src/shared/utils/to-plain-text.ts
|
|
61
|
+
const plainTextSelectors = [
|
|
62
|
+
{
|
|
63
|
+
selector: "img",
|
|
64
|
+
format: "skip"
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
selector: "[data-skip-in-text=true]",
|
|
68
|
+
format: "skip"
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
selector: "a",
|
|
72
|
+
options: {
|
|
73
|
+
linkBrackets: false,
|
|
74
|
+
hideLinkHrefIfSameAsText: true
|
|
75
|
+
}
|
|
76
|
+
}
|
|
120
77
|
];
|
|
121
|
-
function toPlainText(
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
78
|
+
function toPlainText(html$1, options) {
|
|
79
|
+
return convert(html$1, {
|
|
80
|
+
selectors: plainTextSelectors,
|
|
81
|
+
...options
|
|
82
|
+
});
|
|
125
83
|
}
|
|
126
84
|
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
offset += item.length;
|
|
153
|
-
});
|
|
154
|
-
return decoder.decode(mergedChunks);
|
|
155
|
-
});
|
|
156
|
-
|
|
157
|
-
// src/edge/import-react-dom.tsx
|
|
158
|
-
var importReactDom = () => {
|
|
159
|
-
return import("react-dom/server.edge").catch(
|
|
160
|
-
() => (
|
|
161
|
-
// This ensures that we still have compatibility with React 18,
|
|
162
|
-
// which doesn't have the `.edge` export.
|
|
163
|
-
import("react-dom/server")
|
|
164
|
-
)
|
|
165
|
-
);
|
|
85
|
+
//#endregion
|
|
86
|
+
//#region src/shared/read-stream.browser.ts
|
|
87
|
+
const decoder = new TextDecoder("utf-8");
|
|
88
|
+
const readStream = async (stream) => {
|
|
89
|
+
const chunks = [];
|
|
90
|
+
const writableStream = new WritableStream({
|
|
91
|
+
write(chunk) {
|
|
92
|
+
chunks.push(chunk);
|
|
93
|
+
},
|
|
94
|
+
abort(reason) {
|
|
95
|
+
throw new Error("Stream aborted", { cause: { reason } });
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
await stream.pipeTo(writableStream);
|
|
99
|
+
let length = 0;
|
|
100
|
+
chunks.forEach((item) => {
|
|
101
|
+
length += item.length;
|
|
102
|
+
});
|
|
103
|
+
const mergedChunks = new Uint8Array(length);
|
|
104
|
+
let offset = 0;
|
|
105
|
+
chunks.forEach((item) => {
|
|
106
|
+
mergedChunks.set(item, offset);
|
|
107
|
+
offset += item.length;
|
|
108
|
+
});
|
|
109
|
+
return decoder.decode(mergedChunks);
|
|
166
110
|
};
|
|
167
111
|
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
// This is because react-dom/server is CJS
|
|
174
|
-
(m) => m.default
|
|
175
|
-
);
|
|
176
|
-
const html2 = yield new Promise((resolve, reject) => {
|
|
177
|
-
reactDOMServer.renderToReadableStream(suspendedElement, {
|
|
178
|
-
onError(error) {
|
|
179
|
-
reject(error);
|
|
180
|
-
},
|
|
181
|
-
progressiveChunkSize: Number.POSITIVE_INFINITY
|
|
182
|
-
}).then(readStream).then(resolve).catch(reject);
|
|
183
|
-
});
|
|
184
|
-
if (options == null ? void 0 : options.plainText) {
|
|
185
|
-
return toPlainText(html2, options.htmlToTextOptions);
|
|
186
|
-
}
|
|
187
|
-
const doctype = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
|
|
188
|
-
const document = `${doctype}${html2.replace(/<!DOCTYPE.*?>/, "")}`;
|
|
189
|
-
if (options == null ? void 0 : options.pretty) {
|
|
190
|
-
return pretty(document);
|
|
191
|
-
}
|
|
192
|
-
return document;
|
|
193
|
-
});
|
|
112
|
+
//#endregion
|
|
113
|
+
//#region src/edge/import-react-dom.tsx
|
|
114
|
+
const importReactDom = () => {
|
|
115
|
+
return import("react-dom/server.edge").catch(() => import("react-dom/server"));
|
|
116
|
+
};
|
|
194
117
|
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
118
|
+
//#endregion
|
|
119
|
+
//#region src/edge/render.tsx
|
|
120
|
+
const render = async (element, options) => {
|
|
121
|
+
const suspendedElement = /* @__PURE__ */ jsx(Suspense, { children: element });
|
|
122
|
+
const reactDOMServer = await importReactDom().then((m) => m.default);
|
|
123
|
+
const html$1 = await new Promise((resolve, reject) => {
|
|
124
|
+
reactDOMServer.renderToReadableStream(suspendedElement, {
|
|
125
|
+
onError(error) {
|
|
126
|
+
reject(error);
|
|
127
|
+
},
|
|
128
|
+
progressiveChunkSize: Number.POSITIVE_INFINITY
|
|
129
|
+
}).then(readStream).then(resolve).catch(reject);
|
|
130
|
+
});
|
|
131
|
+
if (options?.plainText) return toPlainText(html$1, options.htmlToTextOptions);
|
|
132
|
+
const document = `<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">${html$1.replace(/<!DOCTYPE.*?>/, "")}`;
|
|
133
|
+
if (options?.pretty) return pretty(document);
|
|
134
|
+
return document;
|
|
198
135
|
};
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
136
|
+
|
|
137
|
+
//#endregion
|
|
138
|
+
//#region src/edge/index.ts
|
|
139
|
+
/**
|
|
140
|
+
* @deprecated use {@link render}
|
|
141
|
+
*/
|
|
142
|
+
const renderAsync = (element, options) => {
|
|
143
|
+
return render(element, options);
|
|
205
144
|
};
|
|
145
|
+
|
|
146
|
+
//#endregion
|
|
147
|
+
export { plainTextSelectors, pretty, render, renderAsync, toPlainText };
|
|
148
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","names":["defaults: Options","plainTextSelectors: SelectorDefinition[]","html","chunks: Uint8Array[]","html"],"sources":["../../src/shared/utils/pretty.ts","../../src/shared/utils/to-plain-text.ts","../../src/shared/read-stream.browser.ts","../../src/edge/import-react-dom.tsx","../../src/edge/render.tsx","../../src/edge/index.ts"],"sourcesContent":["import type { Options, Plugin } from 'prettier';\nimport type { builders } from 'prettier/doc';\nimport * as html from 'prettier/plugins/html';\nimport { format } from 'prettier/standalone';\n\ninterface HtmlNode {\n type: 'element' | 'text' | 'ieConditionalComment';\n name?: string;\n sourceSpan: {\n start: { file: unknown[]; offset: number; line: number; col: number };\n end: { file: unknown[]; offset: number; line: number; col: number };\n details: null;\n };\n parent?: HtmlNode;\n}\n\nfunction recursivelyMapDoc(\n doc: builders.Doc,\n callback: (innerDoc: string | builders.DocCommand) => builders.Doc,\n): builders.Doc {\n if (Array.isArray(doc)) {\n return doc.map((innerDoc) => recursivelyMapDoc(innerDoc, callback));\n }\n\n if (typeof doc === 'object') {\n if (doc.type === 'group') {\n return {\n ...doc,\n contents: recursivelyMapDoc(doc.contents, callback),\n expandedStates: recursivelyMapDoc(\n doc.expandedStates,\n callback,\n ) as builders.Doc[],\n };\n }\n\n if ('contents' in doc) {\n return {\n ...doc,\n contents: recursivelyMapDoc(doc.contents, callback),\n };\n }\n\n if ('parts' in doc) {\n return {\n ...doc,\n parts: recursivelyMapDoc(doc.parts, callback) as builders.Doc[],\n };\n }\n\n if (doc.type === 'if-break') {\n return {\n ...doc,\n breakContents: recursivelyMapDoc(doc.breakContents, callback),\n flatContents: recursivelyMapDoc(doc.flatContents, callback),\n };\n }\n }\n\n return callback(doc);\n}\n\nconst modifiedHtml = { ...html } as Plugin;\nif (modifiedHtml.printers) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n const previousPrint = modifiedHtml.printers.html.print;\n modifiedHtml.printers.html.print = (path, options, print, args) => {\n const node = path.getNode() as HtmlNode;\n\n const rawPrintingResult = previousPrint(path, options, print, args);\n\n if (node.type === 'ieConditionalComment') {\n const printingResult = recursivelyMapDoc(rawPrintingResult, (doc) => {\n if (typeof doc === 'object' && doc.type === 'line') {\n return doc.soft ? '' : ' ';\n }\n\n return doc;\n });\n\n return printingResult;\n }\n\n return rawPrintingResult;\n };\n}\n\nconst defaults: Options = {\n endOfLine: 'lf',\n tabWidth: 2,\n plugins: [modifiedHtml],\n bracketSameLine: true,\n parser: 'html',\n};\n\nexport const pretty = (str: string, options: Options = {}) => {\n return format(str.replaceAll('\\0', ''), {\n ...defaults,\n ...options,\n });\n};\n","import {\n convert,\n type HtmlToTextOptions,\n type SelectorDefinition,\n} from 'html-to-text';\n\nexport const plainTextSelectors: SelectorDefinition[] = [\n { selector: 'img', format: 'skip' },\n { selector: '[data-skip-in-text=true]', format: 'skip' },\n {\n selector: 'a',\n options: { linkBrackets: false, hideLinkHrefIfSameAsText: true },\n },\n];\n\nexport function toPlainText(html: string, options?: HtmlToTextOptions) {\n return convert(html, {\n selectors: plainTextSelectors,\n ...options,\n });\n}\n","import type { ReactDOMServerReadableStream } from 'react-dom/server.browser';\n\nconst decoder = new TextDecoder('utf-8');\n\nexport const readStream = async (stream: ReactDOMServerReadableStream) => {\n const chunks: Uint8Array[] = [];\n\n const writableStream = new WritableStream({\n write(chunk: Uint8Array) {\n chunks.push(chunk);\n },\n abort(reason) {\n throw new Error('Stream aborted', {\n cause: {\n reason,\n },\n });\n },\n });\n await stream.pipeTo(writableStream);\n\n let length = 0;\n chunks.forEach((item) => {\n length += item.length;\n });\n const mergedChunks = new Uint8Array(length);\n let offset = 0;\n chunks.forEach((item) => {\n mergedChunks.set(item, offset);\n offset += item.length;\n });\n\n return decoder.decode(mergedChunks);\n};\n","export const importReactDom = () => {\n // We don't use async here because tsup converts it to a generator syntax\n // that esbuild doesn't understand as dealing with the import failing during\n // bundling: https://github.com/evanw/esbuild/issues/3216#issuecomment-1628913722\n return import('react-dom/server.edge').catch(\n () =>\n // This ensures that we still have compatibility with React 18,\n // which doesn't have the `.edge` export.\n import('react-dom/server'),\n );\n};\n","import { Suspense } from 'react';\nimport { pretty } from '../node';\nimport type { Options } from '../shared/options';\nimport { readStream } from '../shared/read-stream.browser';\nimport { toPlainText } from '../shared/utils/to-plain-text';\nimport { importReactDom } from './import-react-dom';\n\nexport const render = async (\n element: React.ReactElement,\n options?: Options,\n) => {\n const suspendedElement = <Suspense>{element}</Suspense>;\n const reactDOMServer = await importReactDom().then(\n // This is because react-dom/server is CJS\n (m) => m.default,\n );\n\n const html = await new Promise<string>((resolve, reject) => {\n reactDOMServer\n .renderToReadableStream(suspendedElement, {\n onError(error: unknown) {\n reject(error);\n },\n progressiveChunkSize: Number.POSITIVE_INFINITY,\n })\n .then(readStream)\n .then(resolve)\n .catch(reject);\n });\n\n if (options?.plainText) {\n return toPlainText(html, options.htmlToTextOptions);\n }\n\n const doctype =\n '<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">';\n\n const document = `${doctype}${html.replace(/<!DOCTYPE.*?>/, '')}`;\n\n if (options?.pretty) {\n return pretty(document);\n }\n\n return document;\n};\n","import type { Options } from '../shared/options';\nimport { render } from './render';\n\n/**\n * @deprecated use {@link render}\n */\nexport const renderAsync = (element: React.ReactElement, options?: Options) => {\n return render(element, options);\n};\n\nexport * from '../shared/options';\nexport * from '../shared/utils/pretty';\nexport * from '../shared/utils/to-plain-text';\nexport * from './render';\n"],"mappings":"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"}
|
package/dist/node/index.d.mts
CHANGED
|
@@ -1,40 +1,46 @@
|
|
|
1
|
-
import { HtmlToTextOptions, SelectorDefinition } from
|
|
2
|
-
import { Options as Options$1 } from
|
|
1
|
+
import { HtmlToTextOptions, SelectorDefinition } from "html-to-text";
|
|
2
|
+
import { Options as Options$1 } from "prettier";
|
|
3
3
|
|
|
4
|
+
//#region src/shared/options.d.ts
|
|
4
5
|
type Options = {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
/**
|
|
7
|
+
* @deprecated use {@link pretty} instead
|
|
8
|
+
*/
|
|
9
|
+
pretty?: boolean;
|
|
9
10
|
} & ({
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
11
|
+
/**
|
|
12
|
+
* @deprecated use {@link toPlainText} instead
|
|
13
|
+
*/
|
|
14
|
+
plainText?: false;
|
|
14
15
|
} | {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
16
|
+
/**
|
|
17
|
+
* @deprecated use {@link toPlainText} instead
|
|
18
|
+
*/
|
|
19
|
+
plainText?: true;
|
|
20
|
+
/**
|
|
21
|
+
* These are options you can pass down directly to the library we use for
|
|
22
|
+
* converting the rendered email's HTML into plain text.
|
|
23
|
+
*
|
|
24
|
+
* @see https://github.com/html-to-text/node-html-to-text
|
|
25
|
+
*/
|
|
26
|
+
htmlToTextOptions?: HtmlToTextOptions;
|
|
26
27
|
});
|
|
27
|
-
|
|
28
|
+
//#endregion
|
|
29
|
+
//#region src/shared/utils/pretty.d.ts
|
|
28
30
|
declare const pretty: (str: string, options?: Options$1) => Promise<string>;
|
|
29
|
-
|
|
31
|
+
//#endregion
|
|
32
|
+
//#region src/shared/utils/to-plain-text.d.ts
|
|
30
33
|
declare const plainTextSelectors: SelectorDefinition[];
|
|
31
34
|
declare function toPlainText(html: string, options?: HtmlToTextOptions): string;
|
|
32
|
-
|
|
35
|
+
//#endregion
|
|
36
|
+
//#region src/node/render.d.ts
|
|
33
37
|
declare const render: (node: React.ReactNode, options?: Options) => Promise<string>;
|
|
34
|
-
|
|
38
|
+
//#endregion
|
|
39
|
+
//#region src/node/index.d.ts
|
|
35
40
|
/**
|
|
36
41
|
* @deprecated use {@link render}
|
|
37
42
|
*/
|
|
38
43
|
declare const renderAsync: (element: React.ReactElement, options?: Options) => Promise<string>;
|
|
39
|
-
|
|
40
|
-
export {
|
|
44
|
+
//#endregion
|
|
45
|
+
export { Options, plainTextSelectors, pretty, render, renderAsync, toPlainText };
|
|
46
|
+
//# sourceMappingURL=index.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.mts","names":[],"sources":["../../src/shared/options.ts","../../src/shared/utils/pretty.ts","../../src/shared/utils/to-plain-text.ts","../../src/node/render.tsx","../../src/node/index.ts"],"sourcesContent":[],"mappings":";;;;KAIY,OAAA;;;AAAZ;;;;AC2FA;;WAA6C,CAAA,EAAA,KAAA;;EAAY;;;;ECzF5C;AASb;;;;ACTA;EA2CC,iBAAA,CAAA,EHtByB,iBGsBzB;;;;cF8CY,gCAAgC,cAAY;;;cCzF5C,oBAAoB;iBASjB,WAAA,yBAAoC;;;cCTvC,eAAsB,KAAA,CAAM,qBAAqB,YAAO;;;;;;AHFzD,cIEC,WJqBa,EAAA,CAAA,OAAiB,EIrBN,KAAA,CAAM,YJqBA,EAAA,OAAA,CAAA,EIrBwB,OJqBxB,EAAA,GIrB+B,OJqB/B,CAAA,MAAA,CAAA"}
|
package/dist/node/index.d.ts
CHANGED
|
@@ -1,40 +1,46 @@
|
|
|
1
|
-
import { HtmlToTextOptions, SelectorDefinition } from
|
|
2
|
-
import { Options as Options$1 } from
|
|
1
|
+
import { HtmlToTextOptions, SelectorDefinition } from "html-to-text";
|
|
2
|
+
import { Options as Options$1 } from "prettier";
|
|
3
3
|
|
|
4
|
+
//#region src/shared/options.d.ts
|
|
4
5
|
type Options = {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
/**
|
|
7
|
+
* @deprecated use {@link pretty} instead
|
|
8
|
+
*/
|
|
9
|
+
pretty?: boolean;
|
|
9
10
|
} & ({
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
11
|
+
/**
|
|
12
|
+
* @deprecated use {@link toPlainText} instead
|
|
13
|
+
*/
|
|
14
|
+
plainText?: false;
|
|
14
15
|
} | {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
16
|
+
/**
|
|
17
|
+
* @deprecated use {@link toPlainText} instead
|
|
18
|
+
*/
|
|
19
|
+
plainText?: true;
|
|
20
|
+
/**
|
|
21
|
+
* These are options you can pass down directly to the library we use for
|
|
22
|
+
* converting the rendered email's HTML into plain text.
|
|
23
|
+
*
|
|
24
|
+
* @see https://github.com/html-to-text/node-html-to-text
|
|
25
|
+
*/
|
|
26
|
+
htmlToTextOptions?: HtmlToTextOptions;
|
|
26
27
|
});
|
|
27
|
-
|
|
28
|
+
//#endregion
|
|
29
|
+
//#region src/shared/utils/pretty.d.ts
|
|
28
30
|
declare const pretty: (str: string, options?: Options$1) => Promise<string>;
|
|
29
|
-
|
|
31
|
+
//#endregion
|
|
32
|
+
//#region src/shared/utils/to-plain-text.d.ts
|
|
30
33
|
declare const plainTextSelectors: SelectorDefinition[];
|
|
31
34
|
declare function toPlainText(html: string, options?: HtmlToTextOptions): string;
|
|
32
|
-
|
|
35
|
+
//#endregion
|
|
36
|
+
//#region src/node/render.d.ts
|
|
33
37
|
declare const render: (node: React.ReactNode, options?: Options) => Promise<string>;
|
|
34
|
-
|
|
38
|
+
//#endregion
|
|
39
|
+
//#region src/node/index.d.ts
|
|
35
40
|
/**
|
|
36
41
|
* @deprecated use {@link render}
|
|
37
42
|
*/
|
|
38
43
|
declare const renderAsync: (element: React.ReactElement, options?: Options) => Promise<string>;
|
|
39
|
-
|
|
40
|
-
export {
|
|
44
|
+
//#endregion
|
|
45
|
+
export { Options, plainTextSelectors, pretty, render, renderAsync, toPlainText };
|
|
46
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","names":[],"sources":["../../src/shared/options.ts","../../src/shared/utils/pretty.ts","../../src/shared/utils/to-plain-text.ts","../../src/node/render.tsx","../../src/node/index.ts"],"sourcesContent":[],"mappings":";;;;KAIY,OAAA;;;AAAZ;;;;AC2FA;;WAA6C,CAAA,EAAA,KAAA;;EAAY;;;;ECzF5C;AASb;;;;ACTA;EA2CC,iBAAA,CAAA,EHtByB,iBGsBzB;;;;cF8CY,gCAAgC,cAAY;;;cCzF5C,oBAAoB;iBASjB,WAAA,yBAAoC;;;cCTvC,eAAsB,KAAA,CAAM,qBAAqB,YAAO;;;;;;AHFzD,cIEC,WJqBa,EAAA,CAAA,OAAiB,EIrBN,KAAA,CAAM,YJqBA,EAAA,OAAA,CAAA,EIrBwB,OJqBxB,EAAA,GIrB+B,OJqB/B,CAAA,MAAA,CAAA"}
|