react-email 4.0.15 → 4.0.16

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.
Files changed (163) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/cli/index.d.mts +1 -0
  3. package/dist/cli/index.d.ts +1 -0
  4. package/dist/cli/index.js +2785 -0
  5. package/dist/cli/index.mjs +1 -1
  6. package/dist/index.d.mts +20 -0
  7. package/dist/index.d.ts +20 -0
  8. package/dist/index.js +1407 -0
  9. package/dist/index.mjs +21 -0
  10. package/dist/package/index.d.mts +33 -0
  11. package/dist/package/index.d.ts +33 -0
  12. package/dist/package/index.js +62 -0
  13. package/dist/package/index.mjs +7 -0
  14. package/dist/preview/.next/BUILD_ID +1 -1
  15. package/dist/preview/.next/app-build-manifest.json +10 -10
  16. package/dist/preview/.next/app-path-routes-manifest.json +1 -1
  17. package/dist/preview/.next/build-manifest.json +3 -3
  18. package/dist/preview/.next/next-minimal-server.js.nft.json +1 -1
  19. package/dist/preview/.next/next-server.js.nft.json +1 -1
  20. package/dist/preview/.next/prerender-manifest.json +3 -3
  21. package/dist/preview/.next/required-server-files.json +4 -4
  22. package/dist/preview/.next/server/app/_not-found/page.js +1 -1
  23. package/dist/preview/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  24. package/dist/preview/.next/server/app/favicon.ico/route.js +1 -1
  25. package/dist/preview/.next/server/app/page.js +1 -1
  26. package/dist/preview/.next/server/app/page.js.nft.json +1 -1
  27. package/dist/preview/.next/server/app/page_client-reference-manifest.js +1 -1
  28. package/dist/preview/.next/server/app/preview/[...slug]/page.js +15 -15
  29. package/dist/preview/.next/server/app/preview/[...slug]/page.js.nft.json +1 -1
  30. package/dist/preview/.next/server/app/preview/[...slug]/page_client-reference-manifest.js +1 -1
  31. package/dist/preview/.next/server/app-paths-manifest.json +1 -1
  32. package/dist/preview/.next/server/chunks/235.js +4 -4
  33. package/dist/preview/.next/server/chunks/275.js +1 -0
  34. package/dist/preview/.next/server/middleware-build-manifest.js +1 -1
  35. package/dist/preview/.next/server/next-font-manifest.js +1 -1
  36. package/dist/preview/.next/server/next-font-manifest.json +1 -1
  37. package/dist/preview/.next/server/pages/500.html +1 -1
  38. package/dist/preview/.next/server/server-reference-manifest.js +1 -1
  39. package/dist/preview/.next/server/server-reference-manifest.json +1 -1
  40. package/dist/preview/.next/static/chunks/484-e38a627386aae911.js +1 -0
  41. package/dist/preview/.next/static/chunks/app/layout-269b5cbd8f4cd2e3.js +1 -0
  42. package/dist/preview/.next/static/chunks/app/page-2dbfb5b2dc4b1191.js +1 -0
  43. package/dist/preview/.next/static/chunks/app/preview/[...slug]/page-79e0c9b528a62f8b.js +1 -0
  44. package/dist/preview/.next/static/chunks/main-app-976577a424e11c75.js +1 -0
  45. package/dist/preview/.next/static/css/{35e8811589f0962b.css → ac3decd5d6736fbe.css} +1 -1
  46. package/dist/preview/.next/static/media/8e9860b6e62d6359-s.woff2 +0 -0
  47. package/dist/preview/.next/static/media/e4af272ccee01ff0-s.p.woff2 +0 -0
  48. package/dist/preview/.next/trace +27 -27
  49. package/dist/preview/.next/types/app/layout.ts +1 -1
  50. package/dist/preview/.next/types/app/page.ts +1 -1
  51. package/dist/preview/.next/types/app/preview/[...slug]/page.ts +1 -1
  52. package/package.json +1 -1
  53. package/src/app/layout.tsx +2 -2
  54. package/src/commands/testing/out/notifications/yelp-recent-login.html +1 -1
  55. package/src/commands/testing/out/reset-password/twitch-reset-password.html +1 -1
  56. package/src/components/shell.tsx +4 -1
  57. package/src/package/body/dist/index.d.mts +6 -0
  58. package/src/package/body/dist/index.d.ts +6 -0
  59. package/src/package/body/dist/index.js +79 -0
  60. package/src/package/body/dist/index.mjs +45 -0
  61. package/src/package/button/dist/index.d.mts +6 -0
  62. package/src/package/button/dist/index.d.ts +6 -0
  63. package/src/package/button/dist/index.js +252 -0
  64. package/src/package/button/dist/index.mjs +218 -0
  65. package/src/package/code-block/dist/index.d.mts +4906 -0
  66. package/src/package/code-block/dist/index.d.ts +4906 -0
  67. package/src/package/code-block/dist/index.js +18205 -0
  68. package/src/package/code-block/dist/index.mjs +18133 -0
  69. package/src/package/code-inline/dist/index.d.mts +11 -0
  70. package/src/package/code-inline/dist/index.d.ts +11 -0
  71. package/src/package/code-inline/dist/index.js +106 -0
  72. package/src/package/code-inline/dist/index.mjs +72 -0
  73. package/src/package/column/dist/index.d.mts +6 -0
  74. package/src/package/column/dist/index.d.ts +6 -0
  75. package/src/package/column/dist/index.js +79 -0
  76. package/src/package/column/dist/index.mjs +45 -0
  77. package/src/package/components/dist/index.d.mts +20 -0
  78. package/src/package/components/dist/index.d.ts +20 -0
  79. package/src/package/components/dist/index.js +62 -0
  80. package/src/package/components/dist/index.mjs +21 -0
  81. package/src/package/container/dist/index.d.mts +6 -0
  82. package/src/package/container/dist/index.d.ts +6 -0
  83. package/src/package/container/dist/index.js +93 -0
  84. package/src/package/container/dist/index.mjs +59 -0
  85. package/src/package/font/dist/index.d.mts +25 -0
  86. package/src/package/font/dist/index.d.ts +25 -0
  87. package/src/package/font/dist/index.js +55 -0
  88. package/src/package/font/dist/index.mjs +28 -0
  89. package/src/package/head/dist/index.d.mts +6 -0
  90. package/src/package/head/dist/index.d.ts +6 -0
  91. package/src/package/head/dist/index.js +83 -0
  92. package/src/package/head/dist/index.mjs +49 -0
  93. package/src/package/heading/dist/index.d.mts +43 -0
  94. package/src/package/heading/dist/index.d.ts +43 -0
  95. package/src/package/heading/dist/index.js +113 -0
  96. package/src/package/heading/dist/index.mjs +79 -0
  97. package/src/package/hr/dist/index.d.mts +6 -0
  98. package/src/package/hr/dist/index.d.ts +6 -0
  99. package/src/package/hr/dist/index.js +89 -0
  100. package/src/package/hr/dist/index.mjs +55 -0
  101. package/src/package/html/dist/index.d.mts +6 -0
  102. package/src/package/html/dist/index.d.ts +6 -0
  103. package/src/package/html/dist/index.js +79 -0
  104. package/src/package/html/dist/index.mjs +45 -0
  105. package/src/package/img/dist/index.d.mts +6 -0
  106. package/src/package/img/dist/index.d.ts +6 -0
  107. package/src/package/img/dist/index.js +94 -0
  108. package/src/package/img/dist/index.mjs +60 -0
  109. package/src/package/link/dist/index.d.mts +6 -0
  110. package/src/package/link/dist/index.d.ts +6 -0
  111. package/src/package/link/dist/index.js +90 -0
  112. package/src/package/link/dist/index.mjs +56 -0
  113. package/src/package/markdown/dist/index.d.mts +15 -0
  114. package/src/package/markdown/dist/index.d.ts +15 -0
  115. package/src/package/markdown/dist/index.js +92 -0
  116. package/src/package/markdown/dist/index.mjs +58 -0
  117. package/src/package/preview/dist/index.d.mts +12 -0
  118. package/src/package/preview/dist/index.d.ts +12 -0
  119. package/src/package/preview/dist/index.js +108 -0
  120. package/src/package/preview/dist/index.mjs +73 -0
  121. package/src/package/render/dist/browser/index.d.mts +24 -0
  122. package/src/package/render/dist/browser/index.d.ts +24 -0
  123. package/src/package/render/dist/browser/index.js +250 -0
  124. package/src/package/render/dist/browser/index.mjs +214 -0
  125. package/src/package/render/dist/index.d.mts +23 -0
  126. package/src/package/render/dist/index.d.ts +23 -0
  127. package/src/package/render/dist/index.js +768 -0
  128. package/src/package/render/dist/index.mjs +733 -0
  129. package/src/package/render/dist/node/index.d.mts +27 -0
  130. package/src/package/render/dist/node/index.d.ts +27 -0
  131. package/src/package/render/dist/node/index.js +212 -0
  132. package/src/package/render/dist/node/index.mjs +176 -0
  133. package/src/package/row/dist/index.d.mts +10 -0
  134. package/src/package/row/dist/index.d.ts +10 -0
  135. package/src/package/row/dist/index.js +93 -0
  136. package/src/package/row/dist/index.mjs +59 -0
  137. package/src/package/section/dist/index.d.mts +6 -0
  138. package/src/package/section/dist/index.d.ts +6 -0
  139. package/src/package/section/dist/index.js +93 -0
  140. package/src/package/section/dist/index.mjs +59 -0
  141. package/src/package/tailwind/dist/index.d.ts +19 -0
  142. package/src/package/tailwind/dist/index.js +48 -0
  143. package/src/package/tailwind/dist/index.mjs +17167 -0
  144. package/src/package/tailwind/dist/tailwindcss/config.d.ts +376 -0
  145. package/src/package/tailwind/dist/tailwindcss/generated/.gitkeep +0 -0
  146. package/src/package/tailwind/dist/tailwindcss/generated/colors.d.ts +298 -0
  147. package/src/package/tailwind/dist/tailwindcss/generated/corePluginList.d.ts +1 -0
  148. package/src/package/tailwind/dist/tailwindcss/generated/default-theme.d.ts +397 -0
  149. package/src/package/tailwind/dist/tailwindcss/index.d.ts +11 -0
  150. package/src/package/text/dist/index.d.mts +6 -0
  151. package/src/package/text/dist/index.d.ts +6 -0
  152. package/src/package/text/dist/index.js +89 -0
  153. package/src/package/text/dist/index.mjs +55 -0
  154. package/dist/preview/.next/server/chunks/488.js +0 -1
  155. package/dist/preview/.next/static/chunks/484-21e30f98c67e8d58.js +0 -1
  156. package/dist/preview/.next/static/chunks/app/layout-3044a159bf29302b.js +0 -1
  157. package/dist/preview/.next/static/chunks/app/page-ed77f0af99f8ff62.js +0 -1
  158. package/dist/preview/.next/static/chunks/app/preview/[...slug]/page-994a4d501e46f3f8.js +0 -1
  159. package/dist/preview/.next/static/chunks/main-app-5bc2d814f500db60.js +0 -1
  160. package/dist/preview/.next/static/media/6d93bde91c0c2823-s.woff2 +0 -0
  161. package/dist/preview/.next/static/media/a34f9d1faa5f3315-s.p.woff2 +0 -0
  162. /package/dist/preview/.next/static/{0LFN6rP55keVoTJYuP-4s → yxjkw7Y7HRLmRWkl3S43z}/_buildManifest.js +0 -0
  163. /package/dist/preview/.next/static/{0LFN6rP55keVoTJYuP-4s → yxjkw7Y7HRLmRWkl3S43z}/_ssgManifest.js +0 -0
@@ -0,0 +1,27 @@
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
+ /**
21
+ * @deprecated use `render`
22
+ */
23
+ declare const renderAsync: (element: React.ReactElement, options?: Options) => Promise<string>;
24
+
25
+ declare const plainTextSelectors: SelectorDefinition[];
26
+
27
+ export { Options, plainTextSelectors, render, renderAsync };
@@ -0,0 +1,27 @@
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
+ /**
21
+ * @deprecated use `render`
22
+ */
23
+ declare const renderAsync: (element: React.ReactElement, options?: Options) => Promise<string>;
24
+
25
+ declare const plainTextSelectors: SelectorDefinition[];
26
+
27
+ export { Options, plainTextSelectors, render, renderAsync };
@@ -0,0 +1,212 @@
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/node/index.ts
65
+ var node_exports = {};
66
+ __export(node_exports, {
67
+ plainTextSelectors: () => plainTextSelectors,
68
+ render: () => render,
69
+ renderAsync: () => renderAsync
70
+ });
71
+ module.exports = __toCommonJS(node_exports);
72
+
73
+ // src/node/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/node/read-stream.ts
101
+ var import_node_stream = require("stream");
102
+ var decoder = new TextDecoder("utf-8");
103
+ var readStream = (stream) => __async(void 0, null, function* () {
104
+ let result = "";
105
+ if ("pipeTo" in stream) {
106
+ const writableStream = new WritableStream({
107
+ write(chunk) {
108
+ result += decoder.decode(chunk);
109
+ }
110
+ });
111
+ yield stream.pipeTo(writableStream);
112
+ } else {
113
+ const writable = new import_node_stream.Writable({
114
+ write(chunk, _encoding, callback) {
115
+ result += decoder.decode(chunk);
116
+ callback();
117
+ }
118
+ });
119
+ stream.pipe(writable);
120
+ yield new Promise((resolve, reject) => {
121
+ writable.on("error", reject);
122
+ writable.on("close", () => {
123
+ resolve();
124
+ });
125
+ });
126
+ }
127
+ return result;
128
+ });
129
+
130
+ // src/node/render.tsx
131
+ var import_jsx_runtime = require("react/jsx-runtime");
132
+ var render = (element, options) => __async(void 0, null, function* () {
133
+ const suspendedElement = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react.Suspense, { children: element });
134
+ const reactDOMServer = yield import("react-dom/server");
135
+ let html2;
136
+ if (Object.hasOwn(reactDOMServer, "renderToReadableStream")) {
137
+ html2 = yield readStream(
138
+ yield reactDOMServer.renderToReadableStream(suspendedElement)
139
+ );
140
+ } else {
141
+ yield new Promise((resolve, reject) => {
142
+ const stream = reactDOMServer.renderToPipeableStream(suspendedElement, {
143
+ onAllReady() {
144
+ return __async(this, null, function* () {
145
+ html2 = yield readStream(stream);
146
+ resolve();
147
+ });
148
+ },
149
+ onError(error) {
150
+ reject(error);
151
+ }
152
+ });
153
+ });
154
+ }
155
+ if (options == null ? void 0 : options.plainText) {
156
+ return (0, import_html_to_text.convert)(html2, __spreadValues({
157
+ selectors: plainTextSelectors
158
+ }, options.htmlToTextOptions));
159
+ }
160
+ const doctype = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
161
+ const document = `${doctype}${html2.replace(/<!DOCTYPE.*?>/, "")}`;
162
+ if (options == null ? void 0 : options.pretty) {
163
+ return pretty(document);
164
+ }
165
+ return document;
166
+ });
167
+
168
+ // src/node/render-async.tsx
169
+ var import_html_to_text2 = require("html-to-text");
170
+ var import_react2 = require("react");
171
+ var import_jsx_runtime2 = require("react/jsx-runtime");
172
+ var renderAsync = (element, options) => __async(void 0, null, function* () {
173
+ const suspendedElement = /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_react2.Suspense, { children: element });
174
+ const reactDOMServer = yield import("react-dom/server");
175
+ let html2;
176
+ if (Object.hasOwn(reactDOMServer, "renderToReadableStream")) {
177
+ html2 = yield readStream(
178
+ yield reactDOMServer.renderToReadableStream(suspendedElement)
179
+ );
180
+ } else {
181
+ yield new Promise((resolve, reject) => {
182
+ const stream = reactDOMServer.renderToPipeableStream(suspendedElement, {
183
+ onAllReady() {
184
+ return __async(this, null, function* () {
185
+ html2 = yield readStream(stream);
186
+ resolve();
187
+ });
188
+ },
189
+ onError(error) {
190
+ reject(error);
191
+ }
192
+ });
193
+ });
194
+ }
195
+ if (options == null ? void 0 : options.plainText) {
196
+ return (0, import_html_to_text2.convert)(html2, __spreadValues({
197
+ selectors: plainTextSelectors
198
+ }, options.htmlToTextOptions));
199
+ }
200
+ const doctype = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
201
+ const document = `${doctype}${html2.replace(/<!DOCTYPE.*?>/, "")}`;
202
+ if (options == null ? void 0 : options.pretty) {
203
+ return pretty(document);
204
+ }
205
+ return document;
206
+ });
207
+ // Annotate the CommonJS export names for ESM import in node:
208
+ 0 && (module.exports = {
209
+ plainTextSelectors,
210
+ render,
211
+ renderAsync
212
+ });
@@ -0,0 +1,176 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
3
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
4
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
5
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
+ var __spreadValues = (a, b) => {
7
+ for (var prop in b || (b = {}))
8
+ if (__hasOwnProp.call(b, prop))
9
+ __defNormalProp(a, prop, b[prop]);
10
+ if (__getOwnPropSymbols)
11
+ for (var prop of __getOwnPropSymbols(b)) {
12
+ if (__propIsEnum.call(b, prop))
13
+ __defNormalProp(a, prop, b[prop]);
14
+ }
15
+ return a;
16
+ };
17
+ var __async = (__this, __arguments, generator) => {
18
+ return new Promise((resolve, reject) => {
19
+ var fulfilled = (value) => {
20
+ try {
21
+ step(generator.next(value));
22
+ } catch (e) {
23
+ reject(e);
24
+ }
25
+ };
26
+ var rejected = (value) => {
27
+ try {
28
+ step(generator.throw(value));
29
+ } catch (e) {
30
+ reject(e);
31
+ }
32
+ };
33
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
34
+ step((generator = generator.apply(__this, __arguments)).next());
35
+ });
36
+ };
37
+
38
+ // src/node/render.tsx
39
+ import { convert } from "html-to-text";
40
+ import { Suspense } from "react";
41
+
42
+ // src/shared/utils/pretty.ts
43
+ import { format } from "prettier/standalone";
44
+ import html from "prettier/plugins/html";
45
+ var defaults = {
46
+ endOfLine: "lf",
47
+ tabWidth: 2,
48
+ plugins: [html],
49
+ parser: "html"
50
+ };
51
+ var pretty = (str, options = {}) => {
52
+ return format(str, __spreadValues(__spreadValues({}, defaults), options));
53
+ };
54
+
55
+ // src/shared/plain-text-selectors.ts
56
+ var plainTextSelectors = [
57
+ { selector: "img", format: "skip" },
58
+ { selector: "#__react-email-preview", format: "skip" },
59
+ {
60
+ selector: "a",
61
+ options: { linkBrackets: false }
62
+ }
63
+ ];
64
+
65
+ // src/node/read-stream.ts
66
+ import { Writable } from "node:stream";
67
+ var decoder = new TextDecoder("utf-8");
68
+ var readStream = (stream) => __async(void 0, null, function* () {
69
+ let result = "";
70
+ if ("pipeTo" in stream) {
71
+ const writableStream = new WritableStream({
72
+ write(chunk) {
73
+ result += decoder.decode(chunk);
74
+ }
75
+ });
76
+ yield stream.pipeTo(writableStream);
77
+ } else {
78
+ const writable = new Writable({
79
+ write(chunk, _encoding, callback) {
80
+ result += decoder.decode(chunk);
81
+ callback();
82
+ }
83
+ });
84
+ stream.pipe(writable);
85
+ yield new Promise((resolve, reject) => {
86
+ writable.on("error", reject);
87
+ writable.on("close", () => {
88
+ resolve();
89
+ });
90
+ });
91
+ }
92
+ return result;
93
+ });
94
+
95
+ // src/node/render.tsx
96
+ import { jsx } from "react/jsx-runtime";
97
+ var render = (element, options) => __async(void 0, null, function* () {
98
+ const suspendedElement = /* @__PURE__ */ jsx(Suspense, { children: element });
99
+ const reactDOMServer = yield import("react-dom/server");
100
+ let html2;
101
+ if (Object.hasOwn(reactDOMServer, "renderToReadableStream")) {
102
+ html2 = yield readStream(
103
+ yield reactDOMServer.renderToReadableStream(suspendedElement)
104
+ );
105
+ } else {
106
+ yield new Promise((resolve, reject) => {
107
+ const stream = reactDOMServer.renderToPipeableStream(suspendedElement, {
108
+ onAllReady() {
109
+ return __async(this, null, function* () {
110
+ html2 = yield readStream(stream);
111
+ resolve();
112
+ });
113
+ },
114
+ onError(error) {
115
+ reject(error);
116
+ }
117
+ });
118
+ });
119
+ }
120
+ if (options == null ? void 0 : options.plainText) {
121
+ return convert(html2, __spreadValues({
122
+ selectors: plainTextSelectors
123
+ }, options.htmlToTextOptions));
124
+ }
125
+ const doctype = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
126
+ const document = `${doctype}${html2.replace(/<!DOCTYPE.*?>/, "")}`;
127
+ if (options == null ? void 0 : options.pretty) {
128
+ return pretty(document);
129
+ }
130
+ return document;
131
+ });
132
+
133
+ // src/node/render-async.tsx
134
+ import { convert as convert2 } from "html-to-text";
135
+ import { Suspense as Suspense2 } from "react";
136
+ import { jsx as jsx2 } from "react/jsx-runtime";
137
+ var renderAsync = (element, options) => __async(void 0, null, function* () {
138
+ const suspendedElement = /* @__PURE__ */ jsx2(Suspense2, { children: element });
139
+ const reactDOMServer = yield import("react-dom/server");
140
+ let html2;
141
+ if (Object.hasOwn(reactDOMServer, "renderToReadableStream")) {
142
+ html2 = yield readStream(
143
+ yield reactDOMServer.renderToReadableStream(suspendedElement)
144
+ );
145
+ } else {
146
+ yield new Promise((resolve, reject) => {
147
+ const stream = reactDOMServer.renderToPipeableStream(suspendedElement, {
148
+ onAllReady() {
149
+ return __async(this, null, function* () {
150
+ html2 = yield readStream(stream);
151
+ resolve();
152
+ });
153
+ },
154
+ onError(error) {
155
+ reject(error);
156
+ }
157
+ });
158
+ });
159
+ }
160
+ if (options == null ? void 0 : options.plainText) {
161
+ return convert2(html2, __spreadValues({
162
+ selectors: plainTextSelectors
163
+ }, options.htmlToTextOptions));
164
+ }
165
+ const doctype = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
166
+ const document = `${doctype}${html2.replace(/<!DOCTYPE.*?>/, "")}`;
167
+ if (options == null ? void 0 : options.pretty) {
168
+ return pretty(document);
169
+ }
170
+ return document;
171
+ });
172
+ export {
173
+ plainTextSelectors,
174
+ render,
175
+ renderAsync
176
+ };
@@ -0,0 +1,10 @@
1
+ import * as React from 'react';
2
+
3
+ type RowProps = Readonly<React.ComponentPropsWithoutRef<"table"> & {
4
+ children: React.ReactNode;
5
+ }>;
6
+ declare const Row: React.ForwardRefExoticComponent<Readonly<Omit<React.DetailedHTMLProps<React.TableHTMLAttributes<HTMLTableElement>, HTMLTableElement>, "ref"> & {
7
+ children: React.ReactNode;
8
+ }> & React.RefAttributes<HTMLTableElement>>;
9
+
10
+ export { Row, type RowProps };
@@ -0,0 +1,10 @@
1
+ import * as React from 'react';
2
+
3
+ type RowProps = Readonly<React.ComponentPropsWithoutRef<"table"> & {
4
+ children: React.ReactNode;
5
+ }>;
6
+ declare const Row: React.ForwardRefExoticComponent<Readonly<Omit<React.DetailedHTMLProps<React.TableHTMLAttributes<HTMLTableElement>, HTMLTableElement>, "ref"> & {
7
+ children: React.ReactNode;
8
+ }> & React.RefAttributes<HTMLTableElement>>;
9
+
10
+ export { Row, type RowProps };
@@ -0,0 +1,93 @@
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
+ Row: () => Row
63
+ });
64
+ module.exports = __toCommonJS(src_exports);
65
+
66
+ // src/row.tsx
67
+ var React = __toESM(require("react"));
68
+ var import_jsx_runtime = require("react/jsx-runtime");
69
+ var Row = React.forwardRef(
70
+ (_a, ref) => {
71
+ var _b = _a, { children, style } = _b, props = __objRest(_b, ["children", "style"]);
72
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
73
+ "table",
74
+ __spreadProps(__spreadValues({
75
+ align: "center",
76
+ width: "100%",
77
+ border: 0,
78
+ cellPadding: "0",
79
+ cellSpacing: "0",
80
+ role: "presentation"
81
+ }, props), {
82
+ ref,
83
+ style,
84
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("tbody", { style: { width: "100%" }, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("tr", { style: { width: "100%" }, children }) })
85
+ })
86
+ );
87
+ }
88
+ );
89
+ Row.displayName = "Row";
90
+ // Annotate the CommonJS export names for ESM import in node:
91
+ 0 && (module.exports = {
92
+ Row
93
+ });
@@ -0,0 +1,59 @@
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/row.tsx
34
+ import * as React from "react";
35
+ import { jsx } from "react/jsx-runtime";
36
+ var Row = React.forwardRef(
37
+ (_a, ref) => {
38
+ var _b = _a, { children, style } = _b, props = __objRest(_b, ["children", "style"]);
39
+ return /* @__PURE__ */ jsx(
40
+ "table",
41
+ __spreadProps(__spreadValues({
42
+ align: "center",
43
+ width: "100%",
44
+ border: 0,
45
+ cellPadding: "0",
46
+ cellSpacing: "0",
47
+ role: "presentation"
48
+ }, props), {
49
+ ref,
50
+ style,
51
+ children: /* @__PURE__ */ jsx("tbody", { style: { width: "100%" }, children: /* @__PURE__ */ jsx("tr", { style: { width: "100%" }, children }) })
52
+ })
53
+ );
54
+ }
55
+ );
56
+ Row.displayName = "Row";
57
+ export {
58
+ Row
59
+ };
@@ -0,0 +1,6 @@
1
+ import * as React from 'react';
2
+
3
+ type SectionProps = Readonly<React.ComponentPropsWithoutRef<"table">>;
4
+ declare const Section: React.ForwardRefExoticComponent<Readonly<Omit<React.DetailedHTMLProps<React.TableHTMLAttributes<HTMLTableElement>, HTMLTableElement>, "ref">> & React.RefAttributes<HTMLTableElement>>;
5
+
6
+ export { Section, type SectionProps };
@@ -0,0 +1,6 @@
1
+ import * as React from 'react';
2
+
3
+ type SectionProps = Readonly<React.ComponentPropsWithoutRef<"table">>;
4
+ declare const Section: React.ForwardRefExoticComponent<Readonly<Omit<React.DetailedHTMLProps<React.TableHTMLAttributes<HTMLTableElement>, HTMLTableElement>, "ref">> & React.RefAttributes<HTMLTableElement>>;
5
+
6
+ export { Section, type SectionProps };