@react-email/render 1.2.3 → 1.3.1

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.
@@ -1,194 +1,142 @@
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/browser/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
- if (Array.isArray(doc)) {
49
- return doc.map((innerDoc) => recursivelyMapDoc(innerDoc, callback));
50
- }
51
- if (typeof doc === "object") {
52
- if (doc.type === "group") {
53
- return __spreadProps(__spreadValues({}, doc), {
54
- contents: recursivelyMapDoc(doc.contents, callback),
55
- expandedStates: recursivelyMapDoc(
56
- doc.expandedStates,
57
- callback
58
- )
59
- });
60
- }
61
- if ("contents" in doc) {
62
- return __spreadProps(__spreadValues({}, doc), {
63
- contents: recursivelyMapDoc(doc.contents, callback)
64
- });
65
- }
66
- if ("parts" in doc) {
67
- return __spreadProps(__spreadValues({}, doc), {
68
- parts: recursivelyMapDoc(doc.parts, callback)
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
- var modifiedHtml = __spreadValues({}, html);
32
+ const modifiedHtml = { ...html };
81
33
  if (modifiedHtml.printers) {
82
- const previousPrint = modifiedHtml.printers.html.print;
83
- modifiedHtml.printers.html.print = (path, options, print, args) => {
84
- const node = path.getNode();
85
- const rawPrintingResult = previousPrint(path, options, print, args);
86
- if (node.type === "ieConditionalComment") {
87
- const printingResult = recursivelyMapDoc(rawPrintingResult, (doc) => {
88
- if (typeof doc === "object" && doc.type === "line") {
89
- return doc.soft ? "" : " ";
90
- }
91
- return doc;
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
- var defaults = {
99
- endOfLine: "lf",
100
- tabWidth: 2,
101
- plugins: [modifiedHtml],
102
- bracketSameLine: true,
103
- parser: "html"
45
+ const defaults = {
46
+ endOfLine: "lf",
47
+ tabWidth: 2,
48
+ plugins: [modifiedHtml],
49
+ bracketSameLine: true,
50
+ parser: "html"
104
51
  };
105
- var pretty = (str, options = {}) => {
106
- return format(str.replaceAll("\0", ""), __spreadValues(__spreadValues({}, defaults), options));
52
+ const pretty = (str, options = {}) => {
53
+ return format(str.replaceAll("\0", ""), {
54
+ ...defaults,
55
+ ...options
56
+ });
107
57
  };
108
58
 
109
- // src/shared/utils/to-plain-text.ts
110
- import {
111
- convert
112
- } from "html-to-text";
113
- var plainTextSelectors = [
114
- { selector: "img", format: "skip" },
115
- { selector: "[data-skip-in-text=true]", format: "skip" },
116
- {
117
- selector: "a",
118
- options: { linkBrackets: false }
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(html2, options) {
122
- return convert(html2, __spreadValues({
123
- selectors: plainTextSelectors
124
- }, options));
78
+ function toPlainText(html$1, options) {
79
+ return convert(html$1, {
80
+ selectors: plainTextSelectors,
81
+ ...options
82
+ });
125
83
  }
126
84
 
127
- // src/shared/read-stream.browser.ts
128
- var decoder = new TextDecoder("utf-8");
129
- var readStream = (stream) => __async(void 0, null, function* () {
130
- const chunks = [];
131
- const writableStream = new WritableStream({
132
- write(chunk) {
133
- chunks.push(chunk);
134
- },
135
- abort(reason) {
136
- throw new Error("Stream aborted", {
137
- cause: {
138
- reason
139
- }
140
- });
141
- }
142
- });
143
- yield stream.pipeTo(writableStream);
144
- let length = 0;
145
- chunks.forEach((item) => {
146
- length += item.length;
147
- });
148
- const mergedChunks = new Uint8Array(length);
149
- let offset = 0;
150
- chunks.forEach((item) => {
151
- mergedChunks.set(item, offset);
152
- offset += item.length;
153
- });
154
- return decoder.decode(mergedChunks);
155
- });
156
-
157
- // src/browser/render.tsx
158
- import { jsx } from "react/jsx-runtime";
159
- var render = (node, options) => __async(void 0, null, function* () {
160
- const suspendedElement = /* @__PURE__ */ jsx(Suspense, { children: node });
161
- const reactDOMServer = yield import("react-dom/server.browser").then(
162
- // This is beacuse react-dom/server is CJS
163
- (m) => m.default
164
- );
165
- const html2 = yield new Promise((resolve, reject) => {
166
- reactDOMServer.renderToReadableStream(suspendedElement, {
167
- onError(error) {
168
- reject(error);
169
- },
170
- progressiveChunkSize: Number.POSITIVE_INFINITY
171
- }).then(readStream).then(resolve).catch(reject);
172
- });
173
- if (options == null ? void 0 : options.plainText) {
174
- return toPlainText(html2, options.htmlToTextOptions);
175
- }
176
- const doctype = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
177
- const document = `${doctype}${html2.replace(/<!DOCTYPE.*?>/, "")}`;
178
- if (options == null ? void 0 : options.pretty) {
179
- return pretty(document);
180
- }
181
- return document;
182
- });
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);
110
+ };
183
111
 
184
- // src/browser/index.ts
185
- var renderAsync = (element, options) => {
186
- return render(element, options);
112
+ //#endregion
113
+ //#region src/browser/render.tsx
114
+ const render = async (node, options) => {
115
+ const suspendedElement = /* @__PURE__ */ jsx(Suspense, { children: node });
116
+ const reactDOMServer = await import("react-dom/server.browser").then((m) => m.default);
117
+ const html$1 = await new Promise((resolve, reject) => {
118
+ reactDOMServer.renderToReadableStream(suspendedElement, {
119
+ onError(error) {
120
+ reject(error);
121
+ },
122
+ progressiveChunkSize: Number.POSITIVE_INFINITY
123
+ }).then(readStream).then(resolve).catch(reject);
124
+ });
125
+ if (options?.plainText) return toPlainText(html$1, options.htmlToTextOptions);
126
+ 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.*?>/, "")}`;
127
+ if (options?.pretty) return pretty(document);
128
+ return document;
187
129
  };
188
- export {
189
- plainTextSelectors,
190
- pretty,
191
- render,
192
- renderAsync,
193
- toPlainText
130
+
131
+ //#endregion
132
+ //#region src/browser/index.ts
133
+ /**
134
+ * @deprecated use {@link render}
135
+ */
136
+ const renderAsync = (element, options) => {
137
+ return render(element, options);
194
138
  };
139
+
140
+ //#endregion
141
+ export { plainTextSelectors, pretty, render, renderAsync, toPlainText };
142
+ //# 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/browser/render.tsx","../../src/browser/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 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","import { Suspense } from 'react';\nimport { pretty, toPlainText } from '../node';\nimport type { Options } from '../shared/options';\nimport { readStream } from '../shared/read-stream.browser';\n\nexport const render = async (node: React.ReactNode, options?: Options) => {\n const suspendedElement = <Suspense>{node}</Suspense>;\n const reactDOMServer = await import('react-dom/server.browser').then(\n // This is beacuse 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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"}
@@ -1,40 +1,46 @@
1
- import { HtmlToTextOptions, SelectorDefinition } from 'html-to-text';
2
- import { Options as Options$1 } from 'prettier';
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
- * @deprecated use {@link pretty} instead
7
- */
8
- pretty?: boolean;
6
+ /**
7
+ * @deprecated use {@link pretty} instead
8
+ */
9
+ pretty?: boolean;
9
10
  } & ({
10
- /**
11
- * @deprecated use {@link toPlainText} instead
12
- */
13
- plainText?: false;
11
+ /**
12
+ * @deprecated use {@link toPlainText} instead
13
+ */
14
+ plainText?: false;
14
15
  } | {
15
- /**
16
- * @deprecated use {@link toPlainText} instead
17
- */
18
- plainText?: true;
19
- /**
20
- * These are options you can pass down directly to the library we use for
21
- * converting the rendered email's HTML into plain text.
22
- *
23
- * @see https://github.com/html-to-text/node-html-to-text
24
- */
25
- htmlToTextOptions?: HtmlToTextOptions;
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/edge/render.d.ts
33
37
  declare const render: (element: React.ReactElement, options?: Options) => Promise<string>;
34
-
38
+ //#endregion
39
+ //#region src/edge/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 { type Options, plainTextSelectors, pretty, render, renderAsync, toPlainText };
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/edge/render.tsx","../../src/edge/index.ts"],"sourcesContent":[],"mappings":";;;;KAIY,OAAA;;;AAAZ;;;;AC0FA;;WAA6C,CAAA,EAAA,KAAA;;EAAY;;;;ECxF5C;AASb;;;;ACRA;EAqCC,iBAAA,CAAA,EHjByB,iBGiBzB;;;;cFkDY,gCAAgC,cAAY;;;cCxF5C,oBAAoB;iBASjB,WAAA,yBAAoC;;;cCRvC,kBACF,KAAA,CAAM,wBACL,YAAO;;;;;;AHLP,cIEC,WJqBa,EAAA,CAAA,OAAiB,EIrBN,KAAA,CAAM,YJqBA,EAAA,OAAA,CAAA,EIrBwB,OJqBxB,EAAA,GIrB+B,OJqB/B,CAAA,MAAA,CAAA"}
@@ -1,40 +1,46 @@
1
- import { HtmlToTextOptions, SelectorDefinition } from 'html-to-text';
2
- import { Options as Options$1 } from 'prettier';
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
- * @deprecated use {@link pretty} instead
7
- */
8
- pretty?: boolean;
6
+ /**
7
+ * @deprecated use {@link pretty} instead
8
+ */
9
+ pretty?: boolean;
9
10
  } & ({
10
- /**
11
- * @deprecated use {@link toPlainText} instead
12
- */
13
- plainText?: false;
11
+ /**
12
+ * @deprecated use {@link toPlainText} instead
13
+ */
14
+ plainText?: false;
14
15
  } | {
15
- /**
16
- * @deprecated use {@link toPlainText} instead
17
- */
18
- plainText?: true;
19
- /**
20
- * These are options you can pass down directly to the library we use for
21
- * converting the rendered email's HTML into plain text.
22
- *
23
- * @see https://github.com/html-to-text/node-html-to-text
24
- */
25
- htmlToTextOptions?: HtmlToTextOptions;
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/edge/render.d.ts
33
37
  declare const render: (element: React.ReactElement, options?: Options) => Promise<string>;
34
-
38
+ //#endregion
39
+ //#region src/edge/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 { type Options, plainTextSelectors, pretty, render, renderAsync, toPlainText };
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/edge/render.tsx","../../src/edge/index.ts"],"sourcesContent":[],"mappings":";;;;KAIY,OAAA;;;AAAZ;;;;AC0FA;;WAA6C,CAAA,EAAA,KAAA;;EAAY;;;;ECxF5C;AASb;;;;ACRA;EAqCC,iBAAA,CAAA,EHjByB,iBGiBzB;;;;cFkDY,gCAAgC,cAAY;;;cCxF5C,oBAAoB;iBASjB,WAAA,yBAAoC;;;cCRvC,kBACF,KAAA,CAAM,wBACL,YAAO;;;;;;AHLP,cIEC,WJqBa,EAAA,CAAA,OAAiB,EIrBN,KAAA,CAAM,YJqBA,EAAA,OAAA,CAAA,EIrBwB,OJqBxB,EAAA,GIrB+B,OJqB/B,CAAA,MAAA,CAAA"}