react-email 2.1.1 → 2.1.2

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.
@@ -0,0 +1,2363 @@
1
+ #!/usr/bin/env node
2
+ function _array_like_to_array(arr, len) {
3
+ if (len == null || len > arr.length) len = arr.length;
4
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
5
+ return arr2;
6
+ }
7
+ function _array_with_holes(arr) {
8
+ if (Array.isArray(arr)) return arr;
9
+ }
10
+ function _array_without_holes(arr) {
11
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
12
+ }
13
+ function _async_iterator(iterable) {
14
+ var method, async, sync, retry = 2;
15
+ for("undefined" != typeof Symbol && (async = Symbol.asyncIterator, sync = Symbol.iterator); retry--;){
16
+ if (async && null != (method = iterable[async])) return method.call(iterable);
17
+ if (sync && null != (method = iterable[sync])) return new AsyncFromSyncIterator(method.call(iterable));
18
+ async = "@@asyncIterator", sync = "@@iterator";
19
+ }
20
+ throw new TypeError("Object is not async iterable");
21
+ }
22
+ function AsyncFromSyncIterator(s) {
23
+ function AsyncFromSyncIteratorContinuation(r) {
24
+ if (Object(r) !== r) return Promise.reject(new TypeError(r + " is not an object."));
25
+ var done = r.done;
26
+ return Promise.resolve(r.value).then(function(value) {
27
+ return {
28
+ value: value,
29
+ done: done
30
+ };
31
+ });
32
+ }
33
+ return AsyncFromSyncIterator = function(s) {
34
+ this.s = s, this.n = s.next;
35
+ }, AsyncFromSyncIterator.prototype = {
36
+ s: null,
37
+ n: null,
38
+ next: function() {
39
+ return AsyncFromSyncIteratorContinuation(this.n.apply(this.s, arguments));
40
+ },
41
+ return: function(value) {
42
+ var ret = this.s.return;
43
+ return void 0 === ret ? Promise.resolve({
44
+ value: value,
45
+ done: !0
46
+ }) : AsyncFromSyncIteratorContinuation(ret.apply(this.s, arguments));
47
+ },
48
+ throw: function(value) {
49
+ var thr = this.s.return;
50
+ return void 0 === thr ? Promise.reject(value) : AsyncFromSyncIteratorContinuation(thr.apply(this.s, arguments));
51
+ }
52
+ }, new AsyncFromSyncIterator(s);
53
+ }
54
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
55
+ try {
56
+ var info = gen[key](arg);
57
+ var value = info.value;
58
+ } catch (error) {
59
+ reject(error);
60
+ return;
61
+ }
62
+ if (info.done) {
63
+ resolve(value);
64
+ } else {
65
+ Promise.resolve(value).then(_next, _throw);
66
+ }
67
+ }
68
+ function _async_to_generator(fn) {
69
+ return function() {
70
+ var self = this, args = arguments;
71
+ return new Promise(function(resolve, reject) {
72
+ var gen = fn.apply(self, args);
73
+ function _next(value) {
74
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
75
+ }
76
+ function _throw(err) {
77
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
78
+ }
79
+ _next(undefined);
80
+ });
81
+ };
82
+ }
83
+ function _define_property(obj, key, value) {
84
+ if (key in obj) {
85
+ Object.defineProperty(obj, key, {
86
+ value: value,
87
+ enumerable: true,
88
+ configurable: true,
89
+ writable: true
90
+ });
91
+ } else {
92
+ obj[key] = value;
93
+ }
94
+ return obj;
95
+ }
96
+ function _iterable_to_array(iter) {
97
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
98
+ }
99
+ function _iterable_to_array_limit(arr, i) {
100
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
101
+ if (_i == null) return;
102
+ var _arr = [];
103
+ var _n = true;
104
+ var _d = false;
105
+ var _s, _e;
106
+ try {
107
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
108
+ _arr.push(_s.value);
109
+ if (i && _arr.length === i) break;
110
+ }
111
+ } catch (err) {
112
+ _d = true;
113
+ _e = err;
114
+ } finally{
115
+ try {
116
+ if (!_n && _i["return"] != null) _i["return"]();
117
+ } finally{
118
+ if (_d) throw _e;
119
+ }
120
+ }
121
+ return _arr;
122
+ }
123
+ function _non_iterable_rest() {
124
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
125
+ }
126
+ function _non_iterable_spread() {
127
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
128
+ }
129
+ function _object_spread(target) {
130
+ for(var i = 1; i < arguments.length; i++){
131
+ var source = arguments[i] != null ? arguments[i] : {};
132
+ var ownKeys = Object.keys(source);
133
+ if (typeof Object.getOwnPropertySymbols === "function") {
134
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
135
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
136
+ }));
137
+ }
138
+ ownKeys.forEach(function(key) {
139
+ _define_property(target, key, source[key]);
140
+ });
141
+ }
142
+ return target;
143
+ }
144
+ function ownKeys(object, enumerableOnly) {
145
+ var keys = Object.keys(object);
146
+ if (Object.getOwnPropertySymbols) {
147
+ var symbols = Object.getOwnPropertySymbols(object);
148
+ if (enumerableOnly) {
149
+ symbols = symbols.filter(function(sym) {
150
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
151
+ });
152
+ }
153
+ keys.push.apply(keys, symbols);
154
+ }
155
+ return keys;
156
+ }
157
+ function _object_spread_props(target, source) {
158
+ source = source != null ? source : {};
159
+ if (Object.getOwnPropertyDescriptors) {
160
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
161
+ } else {
162
+ ownKeys(Object(source)).forEach(function(key) {
163
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
164
+ });
165
+ }
166
+ return target;
167
+ }
168
+ function _sliced_to_array(arr, i) {
169
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
170
+ }
171
+ function _to_consumable_array(arr) {
172
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
173
+ }
174
+ function _unsupported_iterable_to_array(o, minLen) {
175
+ if (!o) return;
176
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
177
+ var n = Object.prototype.toString.call(o).slice(8, -1);
178
+ if (n === "Object" && o.constructor) n = o.constructor.name;
179
+ if (n === "Map" || n === "Set") return Array.from(n);
180
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
181
+ }
182
+ function _ts_generator(thisArg, body) {
183
+ var f, y, t, g, _ = {
184
+ label: 0,
185
+ sent: function() {
186
+ if (t[0] & 1) throw t[1];
187
+ return t[1];
188
+ },
189
+ trys: [],
190
+ ops: []
191
+ };
192
+ return g = {
193
+ next: verb(0),
194
+ "throw": verb(1),
195
+ "return": verb(2)
196
+ }, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
197
+ return this;
198
+ }), g;
199
+ function verb(n) {
200
+ return function(v) {
201
+ return step([
202
+ n,
203
+ v
204
+ ]);
205
+ };
206
+ }
207
+ function step(op) {
208
+ if (f) throw new TypeError("Generator is already executing.");
209
+ while(_)try {
210
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
211
+ if (y = 0, t) op = [
212
+ op[0] & 2,
213
+ t.value
214
+ ];
215
+ switch(op[0]){
216
+ case 0:
217
+ case 1:
218
+ t = op;
219
+ break;
220
+ case 4:
221
+ _.label++;
222
+ return {
223
+ value: op[1],
224
+ done: false
225
+ };
226
+ case 5:
227
+ _.label++;
228
+ y = op[1];
229
+ op = [
230
+ 0
231
+ ];
232
+ continue;
233
+ case 7:
234
+ op = _.ops.pop();
235
+ _.trys.pop();
236
+ continue;
237
+ default:
238
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
239
+ _ = 0;
240
+ continue;
241
+ }
242
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
243
+ _.label = op[1];
244
+ break;
245
+ }
246
+ if (op[0] === 6 && _.label < t[1]) {
247
+ _.label = t[1];
248
+ t = op;
249
+ break;
250
+ }
251
+ if (t && _.label < t[2]) {
252
+ _.label = t[2];
253
+ _.ops.push(op);
254
+ break;
255
+ }
256
+ if (t[2]) _.ops.pop();
257
+ _.trys.pop();
258
+ continue;
259
+ }
260
+ op = body.call(thisArg, _);
261
+ } catch (e) {
262
+ op = [
263
+ 6,
264
+ e
265
+ ];
266
+ y = 0;
267
+ } finally{
268
+ f = t = 0;
269
+ }
270
+ if (op[0] & 5) throw op[1];
271
+ return {
272
+ value: op[0] ? op[1] : void 0,
273
+ done: true
274
+ };
275
+ }
276
+ }
277
+ function _ts_values(o) {
278
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
279
+ if (m) return m.call(o);
280
+ if (o && typeof o.length === "number") return {
281
+ next: function() {
282
+ if (o && i >= o.length) o = void 0;
283
+ return {
284
+ value: o && o[i++],
285
+ done: !o
286
+ };
287
+ }
288
+ };
289
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
290
+ }
291
+ var __create = Object.create;
292
+ var __defProp = Object.defineProperty;
293
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
294
+ var __getOwnPropNames = Object.getOwnPropertyNames;
295
+ var __getProtoOf = Object.getPrototypeOf;
296
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
297
+ var __copyProps = function(to, from, except, desc) {
298
+ if (from && typeof from === "object" || typeof from === "function") {
299
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
300
+ try {
301
+ var _loop = function() {
302
+ var key = _step.value;
303
+ if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
304
+ get: function() {
305
+ return from[key];
306
+ },
307
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
308
+ });
309
+ };
310
+ for(var _iterator = __getOwnPropNames(from)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true)_loop();
311
+ } catch (err) {
312
+ _didIteratorError = true;
313
+ _iteratorError = err;
314
+ } finally{
315
+ try {
316
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
317
+ _iterator.return();
318
+ }
319
+ } finally{
320
+ if (_didIteratorError) {
321
+ throw _iteratorError;
322
+ }
323
+ }
324
+ }
325
+ }
326
+ return to;
327
+ };
328
+ var __toESM = function(mod, isNodeMode, target) {
329
+ return target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(// If the importer is in node compatibility mode or this is not an ESM
330
+ // file that has been converted to a CommonJS file using a Babel-
331
+ // compatible transform (i.e. "__esModule" has not been set), then set
332
+ // "default" to the CommonJS "module.exports" for node compatibility.
333
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
334
+ value: mod,
335
+ enumerable: true
336
+ }) : target, mod);
337
+ };
338
+ // src/cli/index.ts
339
+ var import_commander = require("commander");
340
+ // package.json
341
+ var package_default = {
342
+ name: "react-email",
343
+ version: "2.1.2-canary.0",
344
+ description: "A live preview of your emails right in your browser.",
345
+ bin: {
346
+ email: "./dist/cli/index.js"
347
+ },
348
+ scripts: {
349
+ build: "tsup-node && node build-preview-server.mjs",
350
+ dev: "tsup-node --watch",
351
+ test: "vitest run",
352
+ "test:watch": "vitest",
353
+ clean: "rm -rf dist",
354
+ lint: "eslint . && tsc"
355
+ },
356
+ license: "MIT",
357
+ repository: {
358
+ type: "git",
359
+ url: "https://github.com/resend/react-email.git",
360
+ directory: "packages/react-email"
361
+ },
362
+ keywords: [
363
+ "react",
364
+ "email"
365
+ ],
366
+ engines: {
367
+ node: ">=18.0.0"
368
+ },
369
+ dependencies: {
370
+ "@babel/core": "7.23.9",
371
+ "@babel/parser": "7.24.1",
372
+ "@react-email/render": "0.0.12",
373
+ chalk: "4.1.2",
374
+ chokidar: "3.5.3",
375
+ commander: "11.1.0",
376
+ debounce: "2.0.0",
377
+ esbuild: "0.19.11",
378
+ glob: "10.3.4",
379
+ "log-symbols": "4.1.0",
380
+ "mime-types": "2.1.35",
381
+ "normalize-path": "3.0.0",
382
+ ora: "5.4.1",
383
+ react: "^18.2.0",
384
+ "react-dom": "^18.2.0",
385
+ shelljs: "0.8.5",
386
+ "socket.io": "4.7.3",
387
+ "source-map-js": "1.0.2",
388
+ "stacktrace-parser": "0.1.10"
389
+ },
390
+ devDependencies: {
391
+ "@radix-ui/colors": "1.0.1",
392
+ "@radix-ui/react-collapsible": "1.0.3",
393
+ "@radix-ui/react-popover": "1.0.7",
394
+ "@radix-ui/react-slot": "1.0.2",
395
+ "@radix-ui/react-toggle-group": "1.0.4",
396
+ "@radix-ui/react-tooltip": "1.0.6",
397
+ "@swc/core": "1.4.15",
398
+ "@types/babel__core": "7.20.5",
399
+ "@types/fs-extra": "11.0.1",
400
+ "@types/mime-types": "2.1.4",
401
+ "@types/node": "18.0.0",
402
+ "@types/normalize-path": "3.0.2",
403
+ "@types/react": "^18.2.0",
404
+ "@types/react-dom": "^18.2.0",
405
+ "@types/shelljs": "0.8.15",
406
+ "@types/webpack": "5.28.5",
407
+ "@vercel/style-guide": "5.1.0",
408
+ autoprefixer: "10.4.14",
409
+ clsx: "2.1.0",
410
+ eslint: "8.50.0",
411
+ "eslint-config-prettier": "9.0.0",
412
+ "eslint-config-turbo": "1.10.12",
413
+ "framer-motion": "10.17.4",
414
+ next: "14.2.1",
415
+ postcss: "8.4.38",
416
+ "prism-react-renderer": "2.1.0",
417
+ sharp: "0.33.3",
418
+ "socket.io-client": "4.7.3",
419
+ sonner: "1.3.1",
420
+ "tailwind-merge": "2.2.0",
421
+ tailwindcss: "3.4.0",
422
+ tsup: "7.2.0",
423
+ tsx: "4.7.1",
424
+ typescript: "5.1.6",
425
+ vitest: "1.1.3",
426
+ watch: "1.0.2"
427
+ }
428
+ };
429
+ // src/cli/commands/dev.ts
430
+ var import_node_fs4 = __toESM(require("fs"));
431
+ // src/cli/utils/tree.ts
432
+ var import_node_fs = require("fs");
433
+ var import_node_os = __toESM(require("os"));
434
+ var import_node_path = __toESM(require("path"));
435
+ var SYMBOLS = {
436
+ BRANCH: "├── ",
437
+ EMPTY: "",
438
+ INDENT: " ",
439
+ LAST_BRANCH: "└── ",
440
+ VERTICAL: "│ "
441
+ };
442
+ var getTreeLines = function() {
443
+ var _ref = _async_to_generator(function(dirPath, depth) {
444
+ var currentDepth, base, dirFullpath, dirname, lines, dirStat, _loop, childDirents, i;
445
+ var _arguments = arguments;
446
+ return _ts_generator(this, function(_state) {
447
+ switch(_state.label){
448
+ case 0:
449
+ currentDepth = _arguments.length > 2 && _arguments[2] !== void 0 ? _arguments[2] : 0;
450
+ base = process.cwd();
451
+ dirFullpath = import_node_path.default.resolve(base, dirPath);
452
+ dirname = import_node_path.default.basename(dirFullpath);
453
+ lines = [
454
+ dirname
455
+ ];
456
+ return [
457
+ 4,
458
+ import_node_fs.promises.stat(dirFullpath)
459
+ ];
460
+ case 1:
461
+ dirStat = _state.sent();
462
+ if (!(dirStat.isDirectory() && currentDepth < depth)) return [
463
+ 3,
464
+ 6
465
+ ];
466
+ _loop = function(i) {
467
+ var dirent, isLast, branchingSymbol, verticalSymbol, pathToDirectory, treeLinesForSubDirectory;
468
+ return _ts_generator(this, function(_state) {
469
+ switch(_state.label){
470
+ case 0:
471
+ dirent = childDirents[i];
472
+ isLast = i === childDirents.length - 1;
473
+ branchingSymbol = isLast ? SYMBOLS.LAST_BRANCH : SYMBOLS.BRANCH;
474
+ verticalSymbol = isLast ? SYMBOLS.INDENT : SYMBOLS.VERTICAL;
475
+ if (!dirent.isFile()) return [
476
+ 3,
477
+ 1
478
+ ];
479
+ lines.push("".concat(branchingSymbol).concat(dirent.name));
480
+ return [
481
+ 3,
482
+ 3
483
+ ];
484
+ case 1:
485
+ pathToDirectory = import_node_path.default.join(dirFullpath, dirent.name);
486
+ return [
487
+ 4,
488
+ getTreeLines(pathToDirectory, depth, currentDepth + 1)
489
+ ];
490
+ case 2:
491
+ treeLinesForSubDirectory = _state.sent();
492
+ lines = lines.concat(treeLinesForSubDirectory.map(function(line, index) {
493
+ return index === 0 ? "".concat(branchingSymbol).concat(line) : "".concat(verticalSymbol).concat(line);
494
+ }));
495
+ _state.label = 3;
496
+ case 3:
497
+ return [
498
+ 2
499
+ ];
500
+ }
501
+ });
502
+ };
503
+ return [
504
+ 4,
505
+ import_node_fs.promises.readdir(dirFullpath, {
506
+ withFileTypes: true
507
+ })
508
+ ];
509
+ case 2:
510
+ childDirents = _state.sent();
511
+ childDirents.sort(function(a, b) {
512
+ if (a.isDirectory() && b.isFile()) {
513
+ return -1;
514
+ } else if (a.isFile() && b.isDirectory()) {
515
+ return 1;
516
+ }
517
+ return b.name > a.name ? -1 : 1;
518
+ });
519
+ i = 0;
520
+ _state.label = 3;
521
+ case 3:
522
+ if (!(i < childDirents.length)) return [
523
+ 3,
524
+ 6
525
+ ];
526
+ return [
527
+ 5,
528
+ _ts_values(_loop(i))
529
+ ];
530
+ case 4:
531
+ _state.sent();
532
+ _state.label = 5;
533
+ case 5:
534
+ i++;
535
+ return [
536
+ 3,
537
+ 3
538
+ ];
539
+ case 6:
540
+ return [
541
+ 2,
542
+ lines
543
+ ];
544
+ }
545
+ });
546
+ });
547
+ return function getTreeLines(dirPath, depth) {
548
+ return _ref.apply(this, arguments);
549
+ };
550
+ }();
551
+ var tree = function() {
552
+ var _ref = _async_to_generator(function(dirPath, depth) {
553
+ var lines;
554
+ return _ts_generator(this, function(_state) {
555
+ switch(_state.label){
556
+ case 0:
557
+ return [
558
+ 4,
559
+ getTreeLines(dirPath, depth)
560
+ ];
561
+ case 1:
562
+ lines = _state.sent();
563
+ return [
564
+ 2,
565
+ lines.join(import_node_os.default.EOL)
566
+ ];
567
+ }
568
+ });
569
+ });
570
+ return function tree(dirPath, depth) {
571
+ return _ref.apply(this, arguments);
572
+ };
573
+ }();
574
+ // src/cli/utils/preview/hot-reloading/setup-hot-reloading.ts
575
+ var import_node_path3 = __toESM(require("path"));
576
+ var import_socket = require("socket.io");
577
+ var import_chokidar = require("chokidar");
578
+ var import_debounce = __toESM(require("debounce"));
579
+ // src/cli/utils/preview/hot-reloading/create-dependency-graph.ts
580
+ var import_node_path2 = __toESM(require("path"));
581
+ var import_node_fs2 = require("fs");
582
+ // src/cli/utils/preview/hot-reloading/get-imported-modules.ts
583
+ var import_core = require("@babel/core");
584
+ var import_parser = require("@babel/parser");
585
+ var getImportedModules = function(contents) {
586
+ var importedPaths = [];
587
+ var parsedContents = (0, import_parser.parse)(contents, {
588
+ sourceType: "unambiguous",
589
+ strictMode: false,
590
+ errorRecovery: true,
591
+ plugins: [
592
+ "jsx",
593
+ "typescript"
594
+ ]
595
+ });
596
+ (0, import_core.traverse)(parsedContents, {
597
+ ImportDeclaration: function ImportDeclaration(path11) {
598
+ importedPaths.push(path11.node.source.value);
599
+ },
600
+ CallExpression: function CallExpression(path11) {
601
+ if ("name" in path11.node.callee && path11.node.callee.name === "require") {
602
+ if (path11.node.arguments.length === 1) {
603
+ var importPathNode = path11.node.arguments[0];
604
+ if (importPathNode.type === "StringLiteral") {
605
+ importedPaths.push(importPathNode.value);
606
+ }
607
+ }
608
+ }
609
+ }
610
+ });
611
+ return importedPaths;
612
+ };
613
+ // src/cli/utils/preview/hot-reloading/create-dependency-graph.ts
614
+ var readAllFilesInsideDirectory = function() {
615
+ var _ref = _async_to_generator(function(directory) {
616
+ var allFilePaths, topLevelDirents, _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, _value, dirent, pathToDirent, _, err;
617
+ return _ts_generator(this, function(_state) {
618
+ switch(_state.label){
619
+ case 0:
620
+ allFilePaths = [];
621
+ return [
622
+ 4,
623
+ import_node_fs2.promises.readdir(directory, {
624
+ withFileTypes: true
625
+ })
626
+ ];
627
+ case 1:
628
+ topLevelDirents = _state.sent();
629
+ _iteratorAbruptCompletion = false, _didIteratorError = false;
630
+ _state.label = 2;
631
+ case 2:
632
+ _state.trys.push([
633
+ 2,
634
+ 9,
635
+ 10,
636
+ 15
637
+ ]);
638
+ _iterator = _async_iterator(topLevelDirents);
639
+ _state.label = 3;
640
+ case 3:
641
+ return [
642
+ 4,
643
+ _iterator.next()
644
+ ];
645
+ case 4:
646
+ if (!(_iteratorAbruptCompletion = !(_step = _state.sent()).done)) return [
647
+ 3,
648
+ 8
649
+ ];
650
+ _value = _step.value;
651
+ dirent = _value;
652
+ pathToDirent = import_node_path2.default.join(directory, dirent.name);
653
+ if (!dirent.isDirectory()) return [
654
+ 3,
655
+ 6
656
+ ];
657
+ _ = allFilePaths.concat;
658
+ return [
659
+ 4,
660
+ readAllFilesInsideDirectory(pathToDirent)
661
+ ];
662
+ case 5:
663
+ allFilePaths = _.apply(allFilePaths, [
664
+ _state.sent()
665
+ ]);
666
+ return [
667
+ 3,
668
+ 7
669
+ ];
670
+ case 6:
671
+ allFilePaths.push(pathToDirent);
672
+ _state.label = 7;
673
+ case 7:
674
+ _iteratorAbruptCompletion = false;
675
+ return [
676
+ 3,
677
+ 3
678
+ ];
679
+ case 8:
680
+ return [
681
+ 3,
682
+ 15
683
+ ];
684
+ case 9:
685
+ err = _state.sent();
686
+ _didIteratorError = true;
687
+ _iteratorError = err;
688
+ return [
689
+ 3,
690
+ 15
691
+ ];
692
+ case 10:
693
+ _state.trys.push([
694
+ 10,
695
+ ,
696
+ 13,
697
+ 14
698
+ ]);
699
+ if (!(_iteratorAbruptCompletion && _iterator.return != null)) return [
700
+ 3,
701
+ 12
702
+ ];
703
+ return [
704
+ 4,
705
+ _iterator.return()
706
+ ];
707
+ case 11:
708
+ _state.sent();
709
+ _state.label = 12;
710
+ case 12:
711
+ return [
712
+ 3,
713
+ 14
714
+ ];
715
+ case 13:
716
+ if (_didIteratorError) {
717
+ throw _iteratorError;
718
+ }
719
+ return [
720
+ 7
721
+ ];
722
+ case 14:
723
+ return [
724
+ 7
725
+ ];
726
+ case 15:
727
+ return [
728
+ 2,
729
+ allFilePaths
730
+ ];
731
+ }
732
+ });
733
+ });
734
+ return function readAllFilesInsideDirectory(directory) {
735
+ return _ref.apply(this, arguments);
736
+ };
737
+ }();
738
+ var isJavascriptModule = function(filePath) {
739
+ var extensionName = import_node_path2.default.extname(filePath);
740
+ return [
741
+ ".js",
742
+ ".ts",
743
+ ".jsx",
744
+ ".tsx",
745
+ ".mjs",
746
+ ".cjs"
747
+ ].includes(extensionName);
748
+ };
749
+ var createDependencyGraph = function() {
750
+ var _ref = _async_to_generator(function(directory) {
751
+ var filePaths, modulePaths, graph, getDependencyPaths, updateModuleDependenciesInGraph, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, filePath, err, removeModuleFromGraph;
752
+ return _ts_generator(this, function(_state) {
753
+ switch(_state.label){
754
+ case 0:
755
+ return [
756
+ 4,
757
+ readAllFilesInsideDirectory(directory)
758
+ ];
759
+ case 1:
760
+ filePaths = _state.sent();
761
+ modulePaths = filePaths.filter(isJavascriptModule);
762
+ graph = Object.fromEntries(modulePaths.map(function(path11) {
763
+ return [
764
+ path11,
765
+ {
766
+ path: path11,
767
+ dependencyPaths: [],
768
+ dependentPaths: [],
769
+ moduleDependencies: []
770
+ }
771
+ ];
772
+ }));
773
+ getDependencyPaths = function() {
774
+ var _ref = _async_to_generator(function(filePath) {
775
+ var contents, importedPaths, importedPathsRelativeToDirectory, moduleDependencies, nonNodeModuleImportPathsRelativeToDirectory;
776
+ return _ts_generator(this, function(_state) {
777
+ switch(_state.label){
778
+ case 0:
779
+ return [
780
+ 4,
781
+ import_node_fs2.promises.readFile(filePath, "utf8")
782
+ ];
783
+ case 1:
784
+ contents = _state.sent();
785
+ importedPaths = getImportedModules(contents);
786
+ importedPathsRelativeToDirectory = importedPaths.map(function(dependencyPath) {
787
+ var isModulePath = !dependencyPath.startsWith(".");
788
+ if (!isModulePath && !import_node_path2.default.isAbsolute(dependencyPath)) {
789
+ var pathToDependencyFromDirectory = import_node_path2.default.resolve(/*
790
+ path.resolve resolves paths differently from what imports on javascript do.
791
+
792
+ So if we wouldn't do this, for an email at "/path/to/email.tsx" with a dependecy path of "./other-email"
793
+ would end up going into /path/to/email.tsx/other-email instead of /path/to/other-email which is the
794
+ one the import is meant to go to
795
+ */ import_node_path2.default.dirname(filePath), dependencyPath);
796
+ if (!isJavascriptModule(pathToDependencyFromDirectory)) {
797
+ pathToDependencyFromDirectory = "".concat(pathToDependencyFromDirectory).concat(import_node_path2.default.extname(filePath));
798
+ }
799
+ return pathToDependencyFromDirectory;
800
+ } else {
801
+ return dependencyPath;
802
+ }
803
+ });
804
+ moduleDependencies = importedPathsRelativeToDirectory.filter(function(dependencyPath) {
805
+ return !dependencyPath.startsWith(".") && !import_node_path2.default.isAbsolute(dependencyPath);
806
+ });
807
+ nonNodeModuleImportPathsRelativeToDirectory = importedPathsRelativeToDirectory.filter(function(dependencyPath) {
808
+ return dependencyPath.startsWith(".") || import_node_path2.default.isAbsolute(dependencyPath);
809
+ });
810
+ return [
811
+ 2,
812
+ {
813
+ dependencyPaths: nonNodeModuleImportPathsRelativeToDirectory,
814
+ moduleDependencies: moduleDependencies
815
+ }
816
+ ];
817
+ }
818
+ });
819
+ });
820
+ return function getDependencyPaths(filePath) {
821
+ return _ref.apply(this, arguments);
822
+ };
823
+ }();
824
+ updateModuleDependenciesInGraph = function() {
825
+ var _ref = _async_to_generator(function(moduleFilePath) {
826
+ var _graph_moduleFilePath, module2, _ref, moduleDependencies, newDependencyPaths, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, dependencyPath, dependencyModule, _iteratorNormalCompletion1, _didIteratorError1, _iteratorError1, _iterator1, _step1, dependencyPath1, dependencyModule1;
827
+ return _ts_generator(this, function(_state) {
828
+ switch(_state.label){
829
+ case 0:
830
+ module2 = (_graph_moduleFilePath = graph[moduleFilePath]) !== null && _graph_moduleFilePath !== void 0 ? _graph_moduleFilePath : {
831
+ path: moduleFilePath,
832
+ dependencyPaths: [],
833
+ dependentPaths: [],
834
+ moduleDependencies: []
835
+ };
836
+ return [
837
+ 4,
838
+ getDependencyPaths(moduleFilePath)
839
+ ];
840
+ case 1:
841
+ _ref = _state.sent(), moduleDependencies = _ref.moduleDependencies, newDependencyPaths = _ref.dependencyPaths;
842
+ module2.moduleDependencies = moduleDependencies;
843
+ _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
844
+ try {
845
+ for(_iterator = module2.dependencyPaths[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
846
+ dependencyPath = _step.value;
847
+ if (newDependencyPaths.includes(dependencyPath)) continue;
848
+ dependencyModule = graph[dependencyPath];
849
+ if (dependencyModule !== void 0) {
850
+ dependencyModule.dependentPaths = dependencyModule.dependentPaths.filter(function(dependentPath) {
851
+ return dependentPath !== moduleFilePath;
852
+ });
853
+ }
854
+ }
855
+ } catch (err) {
856
+ _didIteratorError = true;
857
+ _iteratorError = err;
858
+ } finally{
859
+ try {
860
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
861
+ _iterator.return();
862
+ }
863
+ } finally{
864
+ if (_didIteratorError) {
865
+ throw _iteratorError;
866
+ }
867
+ }
868
+ }
869
+ module2.dependencyPaths = newDependencyPaths;
870
+ _iteratorNormalCompletion1 = true, _didIteratorError1 = false, _iteratorError1 = undefined;
871
+ try {
872
+ for(_iterator1 = newDependencyPaths[Symbol.iterator](); !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = true){
873
+ dependencyPath1 = _step1.value;
874
+ dependencyModule1 = graph[dependencyPath1];
875
+ if (dependencyModule1 !== void 0 && !dependencyModule1.dependentPaths.includes(moduleFilePath)) {
876
+ dependencyModule1.dependentPaths.push(moduleFilePath);
877
+ } else {
878
+ graph[dependencyPath1] = {
879
+ path: dependencyPath1,
880
+ moduleDependencies: [],
881
+ dependencyPaths: [],
882
+ dependentPaths: [
883
+ moduleFilePath
884
+ ]
885
+ };
886
+ }
887
+ }
888
+ } catch (err) {
889
+ _didIteratorError1 = true;
890
+ _iteratorError1 = err;
891
+ } finally{
892
+ try {
893
+ if (!_iteratorNormalCompletion1 && _iterator1.return != null) {
894
+ _iterator1.return();
895
+ }
896
+ } finally{
897
+ if (_didIteratorError1) {
898
+ throw _iteratorError1;
899
+ }
900
+ }
901
+ }
902
+ graph[moduleFilePath] = module2;
903
+ return [
904
+ 2
905
+ ];
906
+ }
907
+ });
908
+ });
909
+ return function updateModuleDependenciesInGraph(moduleFilePath) {
910
+ return _ref.apply(this, arguments);
911
+ };
912
+ }();
913
+ _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
914
+ _state.label = 2;
915
+ case 2:
916
+ _state.trys.push([
917
+ 2,
918
+ 7,
919
+ 8,
920
+ 9
921
+ ]);
922
+ _iterator = modulePaths[Symbol.iterator]();
923
+ _state.label = 3;
924
+ case 3:
925
+ if (!!(_iteratorNormalCompletion = (_step = _iterator.next()).done)) return [
926
+ 3,
927
+ 6
928
+ ];
929
+ filePath = _step.value;
930
+ return [
931
+ 4,
932
+ updateModuleDependenciesInGraph(filePath)
933
+ ];
934
+ case 4:
935
+ _state.sent();
936
+ _state.label = 5;
937
+ case 5:
938
+ _iteratorNormalCompletion = true;
939
+ return [
940
+ 3,
941
+ 3
942
+ ];
943
+ case 6:
944
+ return [
945
+ 3,
946
+ 9
947
+ ];
948
+ case 7:
949
+ err = _state.sent();
950
+ _didIteratorError = true;
951
+ _iteratorError = err;
952
+ return [
953
+ 3,
954
+ 9
955
+ ];
956
+ case 8:
957
+ try {
958
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
959
+ _iterator.return();
960
+ }
961
+ } finally{
962
+ if (_didIteratorError) {
963
+ throw _iteratorError;
964
+ }
965
+ }
966
+ return [
967
+ 7
968
+ ];
969
+ case 9:
970
+ removeModuleFromGraph = function(filePath) {
971
+ var module2 = graph[filePath];
972
+ if (module2) {
973
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
974
+ try {
975
+ for(var _iterator = module2.dependencyPaths[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
976
+ var dependencyPath = _step.value;
977
+ if (graph[dependencyPath]) {
978
+ graph[dependencyPath].dependentPaths = graph[dependencyPath].dependentPaths.filter(function(dependentPath) {
979
+ return dependentPath !== filePath;
980
+ });
981
+ }
982
+ }
983
+ } catch (err) {
984
+ _didIteratorError = true;
985
+ _iteratorError = err;
986
+ } finally{
987
+ try {
988
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
989
+ _iterator.return();
990
+ }
991
+ } finally{
992
+ if (_didIteratorError) {
993
+ throw _iteratorError;
994
+ }
995
+ }
996
+ }
997
+ delete graph[filePath];
998
+ }
999
+ };
1000
+ return [
1001
+ 2,
1002
+ [
1003
+ graph,
1004
+ function() {
1005
+ var _ref = /**
1006
+ * @param pathToModified - A path relative to the previosuly provided {@link directory}.
1007
+ */ _async_to_generator(function(event, pathToModified) {
1008
+ var filesInsideAddedDirectory, modulesInsideAddedDirectory, _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, _value, filePath, err, filesInsideDeletedDirectory, modulesInsideDeletedDirectory, _iteratorAbruptCompletion1, _didIteratorError1, _iteratorError1, _iterator1, _step1, _value1, filePath1, err1;
1009
+ return _ts_generator(this, function(_state) {
1010
+ switch(_state.label){
1011
+ case 0:
1012
+ switch(event){
1013
+ case "change":
1014
+ return [
1015
+ 3,
1016
+ 1
1017
+ ];
1018
+ case "add":
1019
+ return [
1020
+ 3,
1021
+ 4
1022
+ ];
1023
+ case "addDir":
1024
+ return [
1025
+ 3,
1026
+ 7
1027
+ ];
1028
+ case "unlink":
1029
+ return [
1030
+ 3,
1031
+ 22
1032
+ ];
1033
+ case "unlinkDir":
1034
+ return [
1035
+ 3,
1036
+ 23
1037
+ ];
1038
+ }
1039
+ return [
1040
+ 3,
1041
+ 37
1042
+ ];
1043
+ case 1:
1044
+ if (!isJavascriptModule(pathToModified)) return [
1045
+ 3,
1046
+ 3
1047
+ ];
1048
+ return [
1049
+ 4,
1050
+ updateModuleDependenciesInGraph(pathToModified)
1051
+ ];
1052
+ case 2:
1053
+ _state.sent();
1054
+ _state.label = 3;
1055
+ case 3:
1056
+ return [
1057
+ 3,
1058
+ 37
1059
+ ];
1060
+ case 4:
1061
+ if (!isJavascriptModule(pathToModified)) return [
1062
+ 3,
1063
+ 6
1064
+ ];
1065
+ return [
1066
+ 4,
1067
+ updateModuleDependenciesInGraph(pathToModified)
1068
+ ];
1069
+ case 5:
1070
+ _state.sent();
1071
+ _state.label = 6;
1072
+ case 6:
1073
+ return [
1074
+ 3,
1075
+ 37
1076
+ ];
1077
+ case 7:
1078
+ return [
1079
+ 4,
1080
+ readAllFilesInsideDirectory(pathToModified)
1081
+ ];
1082
+ case 8:
1083
+ filesInsideAddedDirectory = _state.sent();
1084
+ modulesInsideAddedDirectory = filesInsideAddedDirectory.filter(isJavascriptModule);
1085
+ _iteratorAbruptCompletion = false, _didIteratorError = false;
1086
+ _state.label = 9;
1087
+ case 9:
1088
+ _state.trys.push([
1089
+ 9,
1090
+ 15,
1091
+ 16,
1092
+ 21
1093
+ ]);
1094
+ _iterator = _async_iterator(modulesInsideAddedDirectory);
1095
+ _state.label = 10;
1096
+ case 10:
1097
+ return [
1098
+ 4,
1099
+ _iterator.next()
1100
+ ];
1101
+ case 11:
1102
+ if (!(_iteratorAbruptCompletion = !(_step = _state.sent()).done)) return [
1103
+ 3,
1104
+ 14
1105
+ ];
1106
+ _value = _step.value;
1107
+ filePath = _value;
1108
+ return [
1109
+ 4,
1110
+ updateModuleDependenciesInGraph(filePath)
1111
+ ];
1112
+ case 12:
1113
+ _state.sent();
1114
+ _state.label = 13;
1115
+ case 13:
1116
+ _iteratorAbruptCompletion = false;
1117
+ return [
1118
+ 3,
1119
+ 10
1120
+ ];
1121
+ case 14:
1122
+ return [
1123
+ 3,
1124
+ 21
1125
+ ];
1126
+ case 15:
1127
+ err = _state.sent();
1128
+ _didIteratorError = true;
1129
+ _iteratorError = err;
1130
+ return [
1131
+ 3,
1132
+ 21
1133
+ ];
1134
+ case 16:
1135
+ _state.trys.push([
1136
+ 16,
1137
+ ,
1138
+ 19,
1139
+ 20
1140
+ ]);
1141
+ if (!(_iteratorAbruptCompletion && _iterator.return != null)) return [
1142
+ 3,
1143
+ 18
1144
+ ];
1145
+ return [
1146
+ 4,
1147
+ _iterator.return()
1148
+ ];
1149
+ case 17:
1150
+ _state.sent();
1151
+ _state.label = 18;
1152
+ case 18:
1153
+ return [
1154
+ 3,
1155
+ 20
1156
+ ];
1157
+ case 19:
1158
+ if (_didIteratorError) {
1159
+ throw _iteratorError;
1160
+ }
1161
+ return [
1162
+ 7
1163
+ ];
1164
+ case 20:
1165
+ return [
1166
+ 7
1167
+ ];
1168
+ case 21:
1169
+ return [
1170
+ 3,
1171
+ 37
1172
+ ];
1173
+ case 22:
1174
+ if (isJavascriptModule(pathToModified)) {
1175
+ removeModuleFromGraph(pathToModified);
1176
+ }
1177
+ return [
1178
+ 3,
1179
+ 37
1180
+ ];
1181
+ case 23:
1182
+ return [
1183
+ 4,
1184
+ readAllFilesInsideDirectory(pathToModified)
1185
+ ];
1186
+ case 24:
1187
+ filesInsideDeletedDirectory = _state.sent();
1188
+ modulesInsideDeletedDirectory = filesInsideDeletedDirectory.filter(isJavascriptModule);
1189
+ _iteratorAbruptCompletion1 = false, _didIteratorError1 = false;
1190
+ _state.label = 25;
1191
+ case 25:
1192
+ _state.trys.push([
1193
+ 25,
1194
+ 30,
1195
+ 31,
1196
+ 36
1197
+ ]);
1198
+ _iterator1 = _async_iterator(modulesInsideDeletedDirectory);
1199
+ _state.label = 26;
1200
+ case 26:
1201
+ return [
1202
+ 4,
1203
+ _iterator1.next()
1204
+ ];
1205
+ case 27:
1206
+ if (!(_iteratorAbruptCompletion1 = !(_step1 = _state.sent()).done)) return [
1207
+ 3,
1208
+ 29
1209
+ ];
1210
+ _value1 = _step1.value;
1211
+ filePath1 = _value1;
1212
+ removeModuleFromGraph(filePath1);
1213
+ _state.label = 28;
1214
+ case 28:
1215
+ _iteratorAbruptCompletion1 = false;
1216
+ return [
1217
+ 3,
1218
+ 26
1219
+ ];
1220
+ case 29:
1221
+ return [
1222
+ 3,
1223
+ 36
1224
+ ];
1225
+ case 30:
1226
+ err1 = _state.sent();
1227
+ _didIteratorError1 = true;
1228
+ _iteratorError1 = err1;
1229
+ return [
1230
+ 3,
1231
+ 36
1232
+ ];
1233
+ case 31:
1234
+ _state.trys.push([
1235
+ 31,
1236
+ ,
1237
+ 34,
1238
+ 35
1239
+ ]);
1240
+ if (!(_iteratorAbruptCompletion1 && _iterator1.return != null)) return [
1241
+ 3,
1242
+ 33
1243
+ ];
1244
+ return [
1245
+ 4,
1246
+ _iterator1.return()
1247
+ ];
1248
+ case 32:
1249
+ _state.sent();
1250
+ _state.label = 33;
1251
+ case 33:
1252
+ return [
1253
+ 3,
1254
+ 35
1255
+ ];
1256
+ case 34:
1257
+ if (_didIteratorError1) {
1258
+ throw _iteratorError1;
1259
+ }
1260
+ return [
1261
+ 7
1262
+ ];
1263
+ case 35:
1264
+ return [
1265
+ 7
1266
+ ];
1267
+ case 36:
1268
+ return [
1269
+ 3,
1270
+ 37
1271
+ ];
1272
+ case 37:
1273
+ return [
1274
+ 2
1275
+ ];
1276
+ }
1277
+ });
1278
+ });
1279
+ return function(event, pathToModified) {
1280
+ return _ref.apply(this, arguments);
1281
+ };
1282
+ }()
1283
+ ]
1284
+ ];
1285
+ }
1286
+ });
1287
+ });
1288
+ return function createDependencyGraph(directory) {
1289
+ return _ref.apply(this, arguments);
1290
+ };
1291
+ }();
1292
+ // src/cli/utils/preview/hot-reloading/setup-hot-reloading.ts
1293
+ var setupHotreloading = function() {
1294
+ var _ref = _async_to_generator(function(devServer2, emailDirRelativePath) {
1295
+ var clients, io, absolutePathToEmailsDirectory, watcher, exit, changes, reload, _ref, dependencyGraph, updateDependencyGraph;
1296
+ return _ts_generator(this, function(_state) {
1297
+ switch(_state.label){
1298
+ case 0:
1299
+ clients = [];
1300
+ io = new import_socket.Server(devServer2);
1301
+ io.on("connection", function(client) {
1302
+ clients.push(client);
1303
+ client.on("disconnect", function() {
1304
+ clients = clients.filter(function(item) {
1305
+ return item !== client;
1306
+ });
1307
+ });
1308
+ });
1309
+ absolutePathToEmailsDirectory = import_node_path3.default.resolve(process.cwd(), emailDirRelativePath);
1310
+ watcher = (0, import_chokidar.watch)("", {
1311
+ ignoreInitial: true,
1312
+ cwd: absolutePathToEmailsDirectory
1313
+ });
1314
+ exit = function() {
1315
+ void watcher.close();
1316
+ };
1317
+ process.on("SIGINT", exit);
1318
+ process.on("uncaughtException", exit);
1319
+ changes = [];
1320
+ reload = (0, import_debounce.default)(function() {
1321
+ clients.forEach(function(client) {
1322
+ client.emit("reload", changes);
1323
+ });
1324
+ changes = [];
1325
+ }, 150);
1326
+ return [
1327
+ 4,
1328
+ createDependencyGraph(absolutePathToEmailsDirectory)
1329
+ ];
1330
+ case 1:
1331
+ _ref = _sliced_to_array.apply(void 0, [
1332
+ _state.sent(),
1333
+ 2
1334
+ ]), dependencyGraph = _ref[0], updateDependencyGraph = _ref[1];
1335
+ watcher.on("all", function() {
1336
+ var _ref = _async_to_generator(function(event, relativePathToChangeTarget) {
1337
+ var _changes, _dependencyGraph_pathToChangeTarget, file, pathToChangeTarget, _dependencyGraph_pathToChangeTarget_dependentPaths;
1338
+ return _ts_generator(this, function(_state) {
1339
+ switch(_state.label){
1340
+ case 0:
1341
+ file = relativePathToChangeTarget.split(import_node_path3.default.sep);
1342
+ if (file.length === 0) {
1343
+ return [
1344
+ 2
1345
+ ];
1346
+ }
1347
+ return [
1348
+ 4,
1349
+ updateDependencyGraph(event, relativePathToChangeTarget)
1350
+ ];
1351
+ case 1:
1352
+ _state.sent();
1353
+ changes.push({
1354
+ event: event,
1355
+ filename: relativePathToChangeTarget
1356
+ });
1357
+ pathToChangeTarget = import_node_path3.default.resolve(absolutePathToEmailsDirectory, relativePathToChangeTarget);
1358
+ (_changes = changes).push.apply(_changes, _to_consumable_array(((_dependencyGraph_pathToChangeTarget_dependentPaths = (_dependencyGraph_pathToChangeTarget = dependencyGraph[pathToChangeTarget]) === null || _dependencyGraph_pathToChangeTarget === void 0 ? void 0 : _dependencyGraph_pathToChangeTarget.dependentPaths) !== null && _dependencyGraph_pathToChangeTarget_dependentPaths !== void 0 ? _dependencyGraph_pathToChangeTarget_dependentPaths : []).map(function(dependentPath) {
1359
+ return {
1360
+ event: "change",
1361
+ filename: import_node_path3.default.relative(absolutePathToEmailsDirectory, dependentPath)
1362
+ };
1363
+ })));
1364
+ reload();
1365
+ return [
1366
+ 2
1367
+ ];
1368
+ }
1369
+ });
1370
+ });
1371
+ return function(event, relativePathToChangeTarget) {
1372
+ return _ref.apply(this, arguments);
1373
+ };
1374
+ }());
1375
+ return [
1376
+ 2,
1377
+ watcher
1378
+ ];
1379
+ }
1380
+ });
1381
+ });
1382
+ return function setupHotreloading(devServer2, emailDirRelativePath) {
1383
+ return _ref.apply(this, arguments);
1384
+ };
1385
+ }();
1386
+ // src/cli/utils/preview/start-dev-server.ts
1387
+ var import_node_path5 = __toESM(require("path"));
1388
+ var import_node_http = __toESM(require("http"));
1389
+ var import_node_url = __toESM(require("url"));
1390
+ var import_next = __toESM(require("next"));
1391
+ var import_ora = __toESM(require("ora"));
1392
+ var import_log_symbols = __toESM(require("log-symbols"));
1393
+ var import_chalk = __toESM(require("chalk"));
1394
+ // src/cli/utils/close-ora-on-sigint.ts
1395
+ var spinners = /* @__PURE__ */ new Set();
1396
+ process.on("SIGINT", function() {
1397
+ spinners.forEach(function(spinner) {
1398
+ if (spinner.isSpinning) {
1399
+ spinner.stop();
1400
+ }
1401
+ });
1402
+ });
1403
+ var closeOraOnSIGNIT = function(spinner) {
1404
+ spinners.add(spinner);
1405
+ };
1406
+ // src/cli/utils/preview/serve-static-file.ts
1407
+ var import_node_path4 = __toESM(require("path"));
1408
+ var import_node_fs3 = require("fs");
1409
+ var import_mime_types = require("mime-types");
1410
+ var serveStaticFile = function() {
1411
+ var _ref = _async_to_generator(function(res, parsedUrl, staticDirRelativePath) {
1412
+ var staticBaseDir, pathname, ext, fileAbsolutePath, doesFileExist, fileStat, fileData;
1413
+ return _ts_generator(this, function(_state) {
1414
+ switch(_state.label){
1415
+ case 0:
1416
+ staticBaseDir = import_node_path4.default.join(process.cwd(), staticDirRelativePath);
1417
+ pathname = parsedUrl.pathname;
1418
+ ext = import_node_path4.default.parse(pathname).ext;
1419
+ fileAbsolutePath = import_node_path4.default.join(staticBaseDir, pathname);
1420
+ doesFileExist = (0, import_node_fs3.existsSync)(fileAbsolutePath);
1421
+ if (!!doesFileExist) return [
1422
+ 3,
1423
+ 1
1424
+ ];
1425
+ res.statusCode = 404;
1426
+ res.end("File ".concat(pathname, " not found!"));
1427
+ return [
1428
+ 3,
1429
+ 4
1430
+ ];
1431
+ case 1:
1432
+ return [
1433
+ 4,
1434
+ import_node_fs3.promises.stat(fileAbsolutePath)
1435
+ ];
1436
+ case 2:
1437
+ fileStat = _state.sent();
1438
+ if (fileStat.isDirectory()) {
1439
+ fileAbsolutePath += "/index".concat(ext);
1440
+ }
1441
+ return [
1442
+ 4,
1443
+ import_node_fs3.promises.readFile(fileAbsolutePath)
1444
+ ];
1445
+ case 3:
1446
+ fileData = _state.sent();
1447
+ res.setHeader("Content-type", (0, import_mime_types.lookup)(ext) || "text/plain");
1448
+ res.end(fileData);
1449
+ _state.label = 4;
1450
+ case 4:
1451
+ return [
1452
+ 2
1453
+ ];
1454
+ }
1455
+ });
1456
+ });
1457
+ return function serveStaticFile(res, parsedUrl, staticDirRelativePath) {
1458
+ return _ref.apply(this, arguments);
1459
+ };
1460
+ }();
1461
+ // src/cli/utils/preview/get-env-variables-for-preview-app.ts
1462
+ var import_path = __toESM(require("path"));
1463
+ var getEnvVariablesForPreviewApp = function(relativePathToEmailsDirectory, cwd) {
1464
+ return {
1465
+ EMAILS_DIR_RELATIVE_PATH: relativePathToEmailsDirectory,
1466
+ EMAILS_DIR_ABSOLUTE_PATH: import_path.default.resolve(cwd, relativePathToEmailsDirectory),
1467
+ USER_PROJECT_LOCATION: cwd
1468
+ };
1469
+ };
1470
+ // src/cli/utils/preview/start-dev-server.ts
1471
+ var devServer;
1472
+ var safeAsyncServerListen = function(server, port) {
1473
+ return new Promise(function(resolve) {
1474
+ server.listen(port, function() {
1475
+ resolve({
1476
+ portAlreadyInUse: false
1477
+ });
1478
+ });
1479
+ server.on("error", function(e) {
1480
+ if (e.code === "EADDRINUSE") {
1481
+ resolve({
1482
+ portAlreadyInUse: true
1483
+ });
1484
+ }
1485
+ });
1486
+ });
1487
+ };
1488
+ var isDev = !__filename.endsWith(import_node_path5.default.join("cli", "index.js"));
1489
+ var cliPacakgeLocation = isDev ? import_node_path5.default.resolve(__dirname, "../../../..") : import_node_path5.default.resolve(__dirname, "../..");
1490
+ var previewServerLocation = isDev ? import_node_path5.default.resolve(__dirname, "../../../..") : import_node_path5.default.resolve(__dirname, "../preview");
1491
+ var startDevServer = function() {
1492
+ var _ref = _async_to_generator(function(emailsDirRelativePath, staticBaseDirRelativePath, port) {
1493
+ var portAlreadyInUse, nextPortToTry, spinner, timeBeforeNextReady, app, isNextReady, nextReadyPromise, nextHandleRequest, secondsToNextReady;
1494
+ return _ts_generator(this, function(_state) {
1495
+ switch(_state.label){
1496
+ case 0:
1497
+ devServer = import_node_http.default.createServer(function(req, res) {
1498
+ if (!req.url) {
1499
+ res.end(404);
1500
+ return;
1501
+ }
1502
+ var parsedUrl = import_node_url.default.parse(req.url, true);
1503
+ res.setHeader("Cache-Control", "no-cache, max-age=0, must-revalidate, no-store");
1504
+ res.setHeader("Pragma", "no-cache");
1505
+ res.setHeader("Expires", "-1");
1506
+ try {
1507
+ if (parsedUrl.path && parsedUrl.path.includes("static/") && !parsedUrl.path.includes("_next/static/")) {
1508
+ void serveStaticFile(res, parsedUrl, staticBaseDirRelativePath);
1509
+ } else if (!isNextReady) {
1510
+ void nextReadyPromise.then(function() {
1511
+ return nextHandleRequest === null || nextHandleRequest === void 0 ? void 0 : nextHandleRequest(req, res, parsedUrl);
1512
+ });
1513
+ } else {
1514
+ void (nextHandleRequest === null || nextHandleRequest === void 0 ? void 0 : nextHandleRequest(req, res, parsedUrl));
1515
+ }
1516
+ } catch (e) {
1517
+ console.error("caught error", e);
1518
+ res.writeHead(500);
1519
+ res.end();
1520
+ }
1521
+ });
1522
+ return [
1523
+ 4,
1524
+ safeAsyncServerListen(devServer, port)
1525
+ ];
1526
+ case 1:
1527
+ portAlreadyInUse = _state.sent().portAlreadyInUse;
1528
+ if (!portAlreadyInUse) {
1529
+ console.log(import_chalk.default.greenBright(" React Email ".concat(package_default.version)));
1530
+ console.log(" Running preview at: http://localhost:".concat(port, "\n"));
1531
+ } else {
1532
+ nextPortToTry = port + 1;
1533
+ console.warn(" ".concat(import_log_symbols.default.warning, " Port ").concat(port, " is already in use, trying ").concat(nextPortToTry));
1534
+ return [
1535
+ 2,
1536
+ startDevServer(emailsDirRelativePath, staticBaseDirRelativePath, nextPortToTry)
1537
+ ];
1538
+ }
1539
+ devServer.on("close", /*#__PURE__*/ _async_to_generator(function() {
1540
+ return _ts_generator(this, function(_state) {
1541
+ switch(_state.label){
1542
+ case 0:
1543
+ return [
1544
+ 4,
1545
+ app.close()
1546
+ ];
1547
+ case 1:
1548
+ _state.sent();
1549
+ return [
1550
+ 2
1551
+ ];
1552
+ }
1553
+ });
1554
+ }));
1555
+ devServer.on("error", function(e) {
1556
+ console.error(" ".concat(import_log_symbols.default.error, " preview server error: "), JSON.stringify(e));
1557
+ process.exit(1);
1558
+ });
1559
+ spinner = (0, import_ora.default)({
1560
+ text: "Getting react-email preview server ready...\n",
1561
+ prefixText: " "
1562
+ }).start();
1563
+ closeOraOnSIGNIT(spinner);
1564
+ timeBeforeNextReady = performance.now();
1565
+ process.env = _object_spread({}, process.env, getEnvVariablesForPreviewApp(// If we don't do normalization here, stuff like https://github.com/resend/react-email/issues/1354 happens.
1566
+ import_node_path5.default.normalize(emailsDirRelativePath), process.cwd()));
1567
+ app = (0, import_next.default)({
1568
+ // passing in env here does not get the environment variables there
1569
+ dev: isDev,
1570
+ hostname: "localhost",
1571
+ port: port,
1572
+ dir: previewServerLocation
1573
+ });
1574
+ isNextReady = false;
1575
+ nextReadyPromise = app.prepare();
1576
+ return [
1577
+ 4,
1578
+ nextReadyPromise
1579
+ ];
1580
+ case 2:
1581
+ _state.sent();
1582
+ isNextReady = true;
1583
+ nextHandleRequest = app.getRequestHandler();
1584
+ secondsToNextReady = ((performance.now() - timeBeforeNextReady) / 1e3).toFixed(1);
1585
+ spinner.stopAndPersist({
1586
+ text: "Ready in ".concat(secondsToNextReady, "s\n"),
1587
+ symbol: import_log_symbols.default.success
1588
+ });
1589
+ return [
1590
+ 2,
1591
+ devServer
1592
+ ];
1593
+ }
1594
+ });
1595
+ });
1596
+ return function startDevServer(emailsDirRelativePath, staticBaseDirRelativePath, port) {
1597
+ return _ref.apply(this, arguments);
1598
+ };
1599
+ }();
1600
+ var makeExitHandler = function(options) {
1601
+ return function(_codeOrSignal) {
1602
+ if (typeof devServer !== "undefined") {
1603
+ console.log("\nshutting down dev server");
1604
+ devServer.close();
1605
+ devServer = void 0;
1606
+ }
1607
+ if (options === null || options === void 0 ? void 0 : options.shouldKillProcess) {
1608
+ process.exit(options.killWithErrorCode ? 1 : 0);
1609
+ }
1610
+ };
1611
+ };
1612
+ process.on("exit", makeExitHandler());
1613
+ process.on("SIGINT", makeExitHandler({
1614
+ shouldKillProcess: true,
1615
+ killWithErrorCode: false
1616
+ }));
1617
+ process.on("SIGUSR1", makeExitHandler({
1618
+ shouldKillProcess: true,
1619
+ killWithErrorCode: false
1620
+ }));
1621
+ process.on("SIGUSR2", makeExitHandler({
1622
+ shouldKillProcess: true,
1623
+ killWithErrorCode: false
1624
+ }));
1625
+ process.on("uncaughtException", makeExitHandler({
1626
+ shouldKillProcess: true,
1627
+ killWithErrorCode: true
1628
+ }));
1629
+ // src/cli/commands/dev.ts
1630
+ var dev = function() {
1631
+ var _ref = _async_to_generator(function(param) {
1632
+ var emailsDirRelativePath, port, devServer2, error;
1633
+ return _ts_generator(this, function(_state) {
1634
+ switch(_state.label){
1635
+ case 0:
1636
+ emailsDirRelativePath = param.dir, port = param.port;
1637
+ _state.label = 1;
1638
+ case 1:
1639
+ _state.trys.push([
1640
+ 1,
1641
+ 4,
1642
+ ,
1643
+ 5
1644
+ ]);
1645
+ if (!import_node_fs4.default.existsSync(emailsDirRelativePath)) {
1646
+ throw new Error("Missing ".concat(emailsDirRelativePath, " folder"));
1647
+ }
1648
+ return [
1649
+ 4,
1650
+ startDevServer(emailsDirRelativePath, emailsDirRelativePath, // defaults to ./emails/static for the static files that are served to the preview
1651
+ parseInt(port))
1652
+ ];
1653
+ case 2:
1654
+ devServer2 = _state.sent();
1655
+ return [
1656
+ 4,
1657
+ setupHotreloading(devServer2, emailsDirRelativePath)
1658
+ ];
1659
+ case 3:
1660
+ _state.sent();
1661
+ return [
1662
+ 3,
1663
+ 5
1664
+ ];
1665
+ case 4:
1666
+ error = _state.sent();
1667
+ console.log(error);
1668
+ process.exit(1);
1669
+ return [
1670
+ 3,
1671
+ 5
1672
+ ];
1673
+ case 5:
1674
+ return [
1675
+ 2
1676
+ ];
1677
+ }
1678
+ });
1679
+ });
1680
+ return function dev(_) {
1681
+ return _ref.apply(this, arguments);
1682
+ };
1683
+ }();
1684
+ // src/cli/commands/export.ts
1685
+ var import_node_fs6 = __toESM(require("fs"));
1686
+ var import_node_path7 = __toESM(require("path"));
1687
+ var import_glob = require("glob");
1688
+ var import_esbuild = require("esbuild");
1689
+ var import_ora2 = __toESM(require("ora"));
1690
+ var import_log_symbols2 = __toESM(require("log-symbols"));
1691
+ var import_render = require("@react-email/render");
1692
+ var import_normalize_path = __toESM(require("normalize-path"));
1693
+ var import_shelljs = require("shelljs");
1694
+ // src/actions/get-emails-directory-metadata.ts
1695
+ var import_node_fs5 = __toESM(require("fs"));
1696
+ var import_node_path6 = __toESM(require("path"));
1697
+ var isFileAnEmail = function(fullPath) {
1698
+ var stat = import_node_fs5.default.statSync(fullPath);
1699
+ if (stat.isDirectory()) return false;
1700
+ var ext = import_node_path6.default.parse(fullPath).ext;
1701
+ if (![
1702
+ ".js",
1703
+ ".tsx",
1704
+ ".jsx"
1705
+ ].includes(ext)) return false;
1706
+ var fileContents = import_node_fs5.default.readFileSync(fullPath, "utf8");
1707
+ return /\bexport\s+default\b/gm.test(fileContents);
1708
+ };
1709
+ var mergeDirectoriesWithSubDirectories = function(emailsDirectoryMetadata) {
1710
+ var currentResultingMergedDirectory = emailsDirectoryMetadata;
1711
+ while(currentResultingMergedDirectory.emailFilenames.length === 0 && currentResultingMergedDirectory.subDirectories.length === 1){
1712
+ var onlySubDirectory = currentResultingMergedDirectory.subDirectories[0];
1713
+ currentResultingMergedDirectory = _object_spread_props(_object_spread({}, onlySubDirectory), {
1714
+ directoryName: import_node_path6.default.join(currentResultingMergedDirectory.directoryName, onlySubDirectory.directoryName)
1715
+ });
1716
+ }
1717
+ return currentResultingMergedDirectory;
1718
+ };
1719
+ var getEmailsDirectoryMetadata = function() {
1720
+ var _ref = _async_to_generator(function(absolutePathToEmailsDirectory) {
1721
+ var baseDirectoryPath, dirents, emailFilenames, subDirectories;
1722
+ var _arguments = arguments;
1723
+ return _ts_generator(this, function(_state) {
1724
+ switch(_state.label){
1725
+ case 0:
1726
+ baseDirectoryPath = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : absolutePathToEmailsDirectory;
1727
+ if (!import_node_fs5.default.existsSync(absolutePathToEmailsDirectory)) return [
1728
+ 2
1729
+ ];
1730
+ return [
1731
+ 4,
1732
+ import_node_fs5.default.promises.readdir(absolutePathToEmailsDirectory, {
1733
+ withFileTypes: true
1734
+ })
1735
+ ];
1736
+ case 1:
1737
+ dirents = _state.sent();
1738
+ emailFilenames = dirents.filter(function(dirent) {
1739
+ return isFileAnEmail(import_node_path6.default.join(absolutePathToEmailsDirectory, dirent.name));
1740
+ }).map(function(dirent) {
1741
+ return dirent.name.replace(import_node_path6.default.extname(dirent.name), "");
1742
+ });
1743
+ return [
1744
+ 4,
1745
+ Promise.all(dirents.filter(function(dirent) {
1746
+ return dirent.isDirectory() && !dirent.name.startsWith("_") && dirent.name !== "static";
1747
+ }).map(function(dirent) {
1748
+ var direntAbsolutePath = import_node_path6.default.join(absolutePathToEmailsDirectory, dirent.name);
1749
+ return getEmailsDirectoryMetadata(direntAbsolutePath, baseDirectoryPath);
1750
+ }))
1751
+ ];
1752
+ case 2:
1753
+ subDirectories = _state.sent();
1754
+ return [
1755
+ 2,
1756
+ mergeDirectoriesWithSubDirectories({
1757
+ absolutePath: absolutePathToEmailsDirectory,
1758
+ relativePath: import_node_path6.default.relative(baseDirectoryPath, absolutePathToEmailsDirectory),
1759
+ directoryName: absolutePathToEmailsDirectory.split(import_node_path6.default.sep).pop(),
1760
+ emailFilenames: emailFilenames,
1761
+ subDirectories: subDirectories
1762
+ })
1763
+ ];
1764
+ }
1765
+ });
1766
+ });
1767
+ return function getEmailsDirectoryMetadata(absolutePathToEmailsDirectory) {
1768
+ return _ref.apply(this, arguments);
1769
+ };
1770
+ }();
1771
+ // src/cli/commands/export.ts
1772
+ var getEmailTemplatesFromDirectory = function(emailDirectory) {
1773
+ var templatePaths = [];
1774
+ emailDirectory.emailFilenames.forEach(function(filename) {
1775
+ return templatePaths.push(import_node_path7.default.join(emailDirectory.absolutePath, filename));
1776
+ });
1777
+ emailDirectory.subDirectories.forEach(function(directory) {
1778
+ var _templatePaths;
1779
+ (_templatePaths = templatePaths).push.apply(_templatePaths, _to_consumable_array(getEmailTemplatesFromDirectory(directory)));
1780
+ });
1781
+ return templatePaths;
1782
+ };
1783
+ var exportTemplates = function() {
1784
+ var _ref = _async_to_generator(function(pathToWhereEmailMarkupShouldBeDumped, emailsDirectoryPath, options) {
1785
+ var spinner, emailsDirectoryMetadata, allTemplates, buildResult, allBuiltTemplates, _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, _value, template, component, rendered, htmlPath, exception, err, staticDirectoryPath, pathToDumpStaticFilesInto, result, fileTree;
1786
+ return _ts_generator(this, function(_state) {
1787
+ switch(_state.label){
1788
+ case 0:
1789
+ if (import_node_fs6.default.existsSync(pathToWhereEmailMarkupShouldBeDumped)) {
1790
+ import_node_fs6.default.rmSync(pathToWhereEmailMarkupShouldBeDumped, {
1791
+ recursive: true
1792
+ });
1793
+ }
1794
+ spinner = (0, import_ora2.default)("Preparing files...\n").start();
1795
+ closeOraOnSIGNIT(spinner);
1796
+ return [
1797
+ 4,
1798
+ getEmailsDirectoryMetadata(import_node_path7.default.join(process.cwd(), emailsDirectoryPath))
1799
+ ];
1800
+ case 1:
1801
+ emailsDirectoryMetadata = _state.sent();
1802
+ if (typeof emailsDirectoryMetadata === "undefined") {
1803
+ spinner.stopAndPersist({
1804
+ symbol: import_log_symbols2.default.error,
1805
+ text: "Could not find the directory at ".concat(emailsDirectoryPath)
1806
+ });
1807
+ return [
1808
+ 2
1809
+ ];
1810
+ }
1811
+ allTemplates = getEmailTemplatesFromDirectory(emailsDirectoryMetadata);
1812
+ buildResult = (0, import_esbuild.buildSync)({
1813
+ bundle: true,
1814
+ entryPoints: allTemplates,
1815
+ platform: "node",
1816
+ format: "cjs",
1817
+ loader: {
1818
+ ".js": "jsx"
1819
+ },
1820
+ outExtension: {
1821
+ ".js": ".cjs"
1822
+ },
1823
+ jsx: "transform",
1824
+ write: true,
1825
+ outdir: pathToWhereEmailMarkupShouldBeDumped
1826
+ });
1827
+ if (buildResult.warnings.length > 0) {
1828
+ console.warn(buildResult.warnings);
1829
+ }
1830
+ if (buildResult.errors.length > 0) {
1831
+ spinner.stopAndPersist({
1832
+ symbol: import_log_symbols2.default.error,
1833
+ text: "Failed to build emails"
1834
+ });
1835
+ console.error(buildResult.errors);
1836
+ throw new Error("esbuild bundling process for email templates:\n".concat(allTemplates.map(function(p) {
1837
+ return "- ".concat(p);
1838
+ }).join("\n")));
1839
+ }
1840
+ spinner.succeed();
1841
+ allBuiltTemplates = import_glob.glob.sync((0, import_normalize_path.default)("".concat(pathToWhereEmailMarkupShouldBeDumped, "/**/*.cjs")), {
1842
+ absolute: true
1843
+ });
1844
+ _iteratorAbruptCompletion = false, _didIteratorError = false;
1845
+ _state.label = 2;
1846
+ case 2:
1847
+ _state.trys.push([
1848
+ 2,
1849
+ 10,
1850
+ 11,
1851
+ 16
1852
+ ]);
1853
+ _iterator = _async_iterator(allBuiltTemplates);
1854
+ _state.label = 3;
1855
+ case 3:
1856
+ return [
1857
+ 4,
1858
+ _iterator.next()
1859
+ ];
1860
+ case 4:
1861
+ if (!(_iteratorAbruptCompletion = !(_step = _state.sent()).done)) return [
1862
+ 3,
1863
+ 9
1864
+ ];
1865
+ _value = _step.value;
1866
+ template = _value;
1867
+ _state.label = 5;
1868
+ case 5:
1869
+ _state.trys.push([
1870
+ 5,
1871
+ 7,
1872
+ ,
1873
+ 8
1874
+ ]);
1875
+ spinner.text = "rendering ".concat(template.split("/").pop());
1876
+ spinner.render();
1877
+ delete require.cache[template];
1878
+ component = require(template);
1879
+ return [
1880
+ 4,
1881
+ (0, import_render.renderAsync)(component.default({}), options)
1882
+ ];
1883
+ case 6:
1884
+ rendered = _state.sent();
1885
+ htmlPath = template.replace(".cjs", options.plainText ? ".txt" : ".html");
1886
+ (0, import_node_fs6.writeFileSync)(htmlPath, rendered);
1887
+ (0, import_node_fs6.unlinkSync)(template);
1888
+ return [
1889
+ 3,
1890
+ 8
1891
+ ];
1892
+ case 7:
1893
+ exception = _state.sent();
1894
+ spinner.stopAndPersist({
1895
+ symbol: import_log_symbols2.default.error,
1896
+ text: "failed when rendering ".concat(template.split("/").pop())
1897
+ });
1898
+ console.error(exception);
1899
+ throw exception;
1900
+ case 8:
1901
+ _iteratorAbruptCompletion = false;
1902
+ return [
1903
+ 3,
1904
+ 3
1905
+ ];
1906
+ case 9:
1907
+ return [
1908
+ 3,
1909
+ 16
1910
+ ];
1911
+ case 10:
1912
+ err = _state.sent();
1913
+ _didIteratorError = true;
1914
+ _iteratorError = err;
1915
+ return [
1916
+ 3,
1917
+ 16
1918
+ ];
1919
+ case 11:
1920
+ _state.trys.push([
1921
+ 11,
1922
+ ,
1923
+ 14,
1924
+ 15
1925
+ ]);
1926
+ if (!(_iteratorAbruptCompletion && _iterator.return != null)) return [
1927
+ 3,
1928
+ 13
1929
+ ];
1930
+ return [
1931
+ 4,
1932
+ _iterator.return()
1933
+ ];
1934
+ case 12:
1935
+ _state.sent();
1936
+ _state.label = 13;
1937
+ case 13:
1938
+ return [
1939
+ 3,
1940
+ 15
1941
+ ];
1942
+ case 14:
1943
+ if (_didIteratorError) {
1944
+ throw _iteratorError;
1945
+ }
1946
+ return [
1947
+ 7
1948
+ ];
1949
+ case 15:
1950
+ return [
1951
+ 7
1952
+ ];
1953
+ case 16:
1954
+ spinner.succeed("Rendered all files");
1955
+ spinner.text = "Copying static files";
1956
+ spinner.render();
1957
+ staticDirectoryPath = import_node_path7.default.join(emailsDirectoryPath, "static");
1958
+ if (!import_node_fs6.default.existsSync(staticDirectoryPath)) return [
1959
+ 3,
1960
+ 19
1961
+ ];
1962
+ pathToDumpStaticFilesInto = import_node_path7.default.join(pathToWhereEmailMarkupShouldBeDumped, "static");
1963
+ if (!import_node_fs6.default.existsSync(pathToDumpStaticFilesInto)) return [
1964
+ 3,
1965
+ 18
1966
+ ];
1967
+ return [
1968
+ 4,
1969
+ import_node_fs6.default.promises.rm(pathToDumpStaticFilesInto, {
1970
+ recursive: true
1971
+ })
1972
+ ];
1973
+ case 17:
1974
+ _state.sent();
1975
+ _state.label = 18;
1976
+ case 18:
1977
+ result = (0, import_shelljs.cp)("-r", staticDirectoryPath, import_node_path7.default.join(pathToWhereEmailMarkupShouldBeDumped, "static"));
1978
+ if (result.code > 0) {
1979
+ spinner.stopAndPersist({
1980
+ symbol: import_log_symbols2.default.error,
1981
+ text: "Failed to copy static files"
1982
+ });
1983
+ throw new Error("Something went wrong while copying the file to ".concat(pathToWhereEmailMarkupShouldBeDumped, "/static, ").concat(result.stderr));
1984
+ }
1985
+ _state.label = 19;
1986
+ case 19:
1987
+ spinner.succeed();
1988
+ return [
1989
+ 4,
1990
+ tree(pathToWhereEmailMarkupShouldBeDumped, 4)
1991
+ ];
1992
+ case 20:
1993
+ fileTree = _state.sent();
1994
+ console.log(fileTree);
1995
+ spinner.stopAndPersist({
1996
+ symbol: import_log_symbols2.default.success,
1997
+ text: "Successfully exported emails"
1998
+ });
1999
+ process.exit();
2000
+ return [
2001
+ 2
2002
+ ];
2003
+ }
2004
+ });
2005
+ });
2006
+ return function exportTemplates(pathToWhereEmailMarkupShouldBeDumped, emailsDirectoryPath, options) {
2007
+ return _ref.apply(this, arguments);
2008
+ };
2009
+ }();
2010
+ // src/cli/commands/build.ts
2011
+ var import_node_fs7 = __toESM(require("fs"));
2012
+ var import_node_path8 = __toESM(require("path"));
2013
+ var import_ora3 = __toESM(require("ora"));
2014
+ var import_shelljs2 = __toESM(require("shelljs"));
2015
+ var import_node_child_process = require("child_process");
2016
+ var import_log_symbols3 = __toESM(require("log-symbols"));
2017
+ var buildPreviewApp = function(absoluteDirectory) {
2018
+ return new Promise(function(resolve, reject) {
2019
+ var nextBuild = (0, import_node_child_process.spawn)("npm", [
2020
+ "run",
2021
+ "build"
2022
+ ], {
2023
+ cwd: absoluteDirectory
2024
+ });
2025
+ nextBuild.stdout.on("data", function(msg) {
2026
+ process.stdout.write(msg);
2027
+ });
2028
+ nextBuild.stderr.on("data", function(msg) {
2029
+ process.stderr.write(msg);
2030
+ });
2031
+ nextBuild.on("close", function(code) {
2032
+ if (code === 0) {
2033
+ resolve();
2034
+ } else {
2035
+ reject(new Error("Unable to build the Next app and it exited with code: ".concat(code)));
2036
+ }
2037
+ });
2038
+ });
2039
+ };
2040
+ var setNextEnvironmentVariablesForBuild = function() {
2041
+ var _ref = _async_to_generator(function(emailsDirRelativePath, builtPreviewAppPath) {
2042
+ var nextConfigContents;
2043
+ return _ts_generator(this, function(_state) {
2044
+ switch(_state.label){
2045
+ case 0:
2046
+ nextConfigContents = "\nconst path = require('path');\nconst emailsDirRelativePath = path.normalize('".concat(emailsDirRelativePath, "');\nconst userProjectLocation = path.resolve(process.cwd(), '../');\n/** @type {import('next').NextConfig} */\nmodule.exports = {\n env: {\n NEXT_PUBLIC_IS_BUILDING: 'true',\n EMAILS_DIR_RELATIVE_PATH: emailsDirRelativePath,\n EMAILS_DIR_ABSOLUTE_PATH: path.resolve(userProjectLocation, emailsDirRelativePath),\n USER_PROJECT_LOCATION: userProjectLocation\n },\n // this is needed so that the code for building emails works properly\n webpack: (\n /** @type {import('webpack').Configuration & { externals: string[] }} */\n config,\n { isServer }\n ) => {\n if (isServer) {\n config.externals.push('esbuild');\n }\n\n return config;\n },\n typescript: {\n ignoreBuildErrors: true\n },\n eslint: {\n ignoreDuringBuilds: true\n },\n experimental: {\n webpackBuildWorker: true,\n serverComponentsExternalPackages: [\n '@react-email/components',\n '@react-email/render',\n '@react-email/tailwind',\n ],\n },\n}");
2047
+ return [
2048
+ 4,
2049
+ import_node_fs7.default.promises.writeFile(import_node_path8.default.resolve(builtPreviewAppPath, "./next.config.js"), nextConfigContents, "utf8")
2050
+ ];
2051
+ case 1:
2052
+ _state.sent();
2053
+ return [
2054
+ 2
2055
+ ];
2056
+ }
2057
+ });
2058
+ });
2059
+ return function setNextEnvironmentVariablesForBuild(emailsDirRelativePath, builtPreviewAppPath) {
2060
+ return _ref.apply(this, arguments);
2061
+ };
2062
+ }();
2063
+ var getEmailSlugsFromEmailDirectory = function(emailDirectory, emailsDirectoryAbsolutePath) {
2064
+ var directoryPathRelativeToEmailsDirectory = emailDirectory.absolutePath.replace(emailsDirectoryAbsolutePath, "").trim();
2065
+ var slugs = [];
2066
+ emailDirectory.emailFilenames.forEach(function(filename) {
2067
+ return slugs.push(import_node_path8.default.join(directoryPathRelativeToEmailsDirectory, filename).split(import_node_path8.default.sep).filter(function(segment) {
2068
+ return segment.length > 0;
2069
+ }));
2070
+ });
2071
+ emailDirectory.subDirectories.forEach(function(directory) {
2072
+ var _slugs;
2073
+ (_slugs = slugs).push.apply(_slugs, _to_consumable_array(getEmailSlugsFromEmailDirectory(directory, emailsDirectoryAbsolutePath)));
2074
+ });
2075
+ return slugs;
2076
+ };
2077
+ var forceSSGForEmailPreviews = function() {
2078
+ var _ref = _async_to_generator(function(emailsDirPath, builtPreviewAppPath) {
2079
+ var emailDirectoryMetadata, parameters, layoutContents;
2080
+ return _ts_generator(this, function(_state) {
2081
+ switch(_state.label){
2082
+ case 0:
2083
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
2084
+ return [
2085
+ 4,
2086
+ getEmailsDirectoryMetadata(emailsDirPath)
2087
+ ];
2088
+ case 1:
2089
+ emailDirectoryMetadata = _state.sent();
2090
+ parameters = getEmailSlugsFromEmailDirectory(emailDirectoryMetadata, emailsDirPath).map(function(slug) {
2091
+ return {
2092
+ slug: slug
2093
+ };
2094
+ });
2095
+ return [
2096
+ 4,
2097
+ import_node_fs7.default.promises.readFile(import_node_path8.default.resolve(builtPreviewAppPath, "./src/app/layout.tsx"), "utf8")
2098
+ ];
2099
+ case 2:
2100
+ layoutContents = _state.sent();
2101
+ return [
2102
+ 4,
2103
+ import_node_fs7.default.promises.writeFile(import_node_path8.default.resolve(builtPreviewAppPath, "./src/app/layout.tsx"), layoutContents.replace("export const dynamic = 'force-dynamic';", ""), "utf8")
2104
+ ];
2105
+ case 3:
2106
+ _state.sent();
2107
+ return [
2108
+ 4,
2109
+ import_node_fs7.default.promises.appendFile(import_node_path8.default.resolve(builtPreviewAppPath, "./src/app/preview/[...slug]/page.tsx"), "\n\nexport async function generateStaticParams() { \n return ".concat(JSON.stringify(parameters), ";\n}"), "utf8")
2110
+ ];
2111
+ case 4:
2112
+ _state.sent();
2113
+ return [
2114
+ 2
2115
+ ];
2116
+ }
2117
+ });
2118
+ });
2119
+ return function forceSSGForEmailPreviews(emailsDirPath, builtPreviewAppPath) {
2120
+ return _ref.apply(this, arguments);
2121
+ };
2122
+ }();
2123
+ var updatePackageJson = function() {
2124
+ var _ref = _async_to_generator(function(builtPreviewAppPath) {
2125
+ var packageJsonPath, packageJson, _;
2126
+ return _ts_generator(this, function(_state) {
2127
+ switch(_state.label){
2128
+ case 0:
2129
+ packageJsonPath = import_node_path8.default.resolve(builtPreviewAppPath, "./package.json");
2130
+ _ = JSON.parse;
2131
+ return [
2132
+ 4,
2133
+ import_node_fs7.default.promises.readFile(packageJsonPath, "utf8")
2134
+ ];
2135
+ case 1:
2136
+ packageJson = _.apply(JSON, [
2137
+ _state.sent()
2138
+ ]);
2139
+ packageJson.scripts.build = "next build";
2140
+ packageJson.scripts.start = "next start";
2141
+ return [
2142
+ 4,
2143
+ import_node_fs7.default.promises.writeFile(packageJsonPath, JSON.stringify(packageJson), "utf8")
2144
+ ];
2145
+ case 2:
2146
+ _state.sent();
2147
+ return [
2148
+ 2
2149
+ ];
2150
+ }
2151
+ });
2152
+ });
2153
+ return function updatePackageJson(builtPreviewAppPath) {
2154
+ return _ref.apply(this, arguments);
2155
+ };
2156
+ }();
2157
+ var npmInstall = function() {
2158
+ var _ref = _async_to_generator(function(builtPreviewAppPath, packageManager) {
2159
+ return _ts_generator(this, function(_state) {
2160
+ return [
2161
+ 2,
2162
+ new Promise(function(resolve, reject) {
2163
+ import_shelljs2.default.exec("".concat(packageManager, " install --silent"), {
2164
+ cwd: builtPreviewAppPath
2165
+ }, function(code) {
2166
+ if (code === 0) {
2167
+ resolve();
2168
+ } else {
2169
+ reject(new Error("Unable to install the dependencies and it exited with code: ".concat(code)));
2170
+ }
2171
+ });
2172
+ })
2173
+ ];
2174
+ });
2175
+ });
2176
+ return function npmInstall(builtPreviewAppPath, packageManager) {
2177
+ return _ref.apply(this, arguments);
2178
+ };
2179
+ }();
2180
+ var build = function() {
2181
+ var _ref = _async_to_generator(function(param) {
2182
+ var emailsDirRelativePath, packageManager, spinner, emailsDirPath, staticPath, builtPreviewAppPath, builtStaticDirectory, error;
2183
+ return _ts_generator(this, function(_state) {
2184
+ switch(_state.label){
2185
+ case 0:
2186
+ emailsDirRelativePath = param.dir, packageManager = param.packageManager;
2187
+ _state.label = 1;
2188
+ case 1:
2189
+ _state.trys.push([
2190
+ 1,
2191
+ 12,
2192
+ ,
2193
+ 13
2194
+ ]);
2195
+ spinner = (0, import_ora3.default)({
2196
+ text: "Starting build process...",
2197
+ prefixText: " "
2198
+ }).start();
2199
+ closeOraOnSIGNIT(spinner);
2200
+ spinner.text = "Checking if emails folder exists";
2201
+ if (!import_node_fs7.default.existsSync(emailsDirRelativePath)) {
2202
+ throw new Error("Missing ".concat(emailsDirRelativePath, " folder"));
2203
+ }
2204
+ emailsDirPath = import_node_path8.default.join(process.cwd(), emailsDirRelativePath);
2205
+ staticPath = import_node_path8.default.join(emailsDirPath, "static");
2206
+ builtPreviewAppPath = import_node_path8.default.join(process.cwd(), ".react-email");
2207
+ if (!import_node_fs7.default.existsSync(builtPreviewAppPath)) return [
2208
+ 3,
2209
+ 3
2210
+ ];
2211
+ spinner.text = "Deleting pre-existing `.react-email` folder";
2212
+ return [
2213
+ 4,
2214
+ import_node_fs7.default.promises.rm(builtPreviewAppPath, {
2215
+ recursive: true
2216
+ })
2217
+ ];
2218
+ case 2:
2219
+ _state.sent();
2220
+ _state.label = 3;
2221
+ case 3:
2222
+ spinner.text = "Copying preview app from CLI to `.react-email`";
2223
+ return [
2224
+ 4,
2225
+ import_node_fs7.default.promises.cp(cliPacakgeLocation, builtPreviewAppPath, {
2226
+ recursive: true,
2227
+ filter: function(source) {
2228
+ return !source.includes("/cli/") && !source.includes("/.next/") && !/\/node_modules\/?$/.test(source);
2229
+ }
2230
+ })
2231
+ ];
2232
+ case 4:
2233
+ _state.sent();
2234
+ if (!import_node_fs7.default.existsSync(staticPath)) return [
2235
+ 3,
2236
+ 6
2237
+ ];
2238
+ spinner.text = "Copying `static` folder into `.react-email/public/static`";
2239
+ builtStaticDirectory = import_node_path8.default.resolve(builtPreviewAppPath, "./public/static");
2240
+ return [
2241
+ 4,
2242
+ import_node_fs7.default.promises.cp(staticPath, builtStaticDirectory, {
2243
+ recursive: true
2244
+ })
2245
+ ];
2246
+ case 5:
2247
+ _state.sent();
2248
+ _state.label = 6;
2249
+ case 6:
2250
+ spinner.text = "Setting Next environment variables for preview app to work properly";
2251
+ return [
2252
+ 4,
2253
+ setNextEnvironmentVariablesForBuild(emailsDirRelativePath, builtPreviewAppPath)
2254
+ ];
2255
+ case 7:
2256
+ _state.sent();
2257
+ spinner.text = "Setting server side generation for the email preview pages";
2258
+ return [
2259
+ 4,
2260
+ forceSSGForEmailPreviews(emailsDirPath, builtPreviewAppPath)
2261
+ ];
2262
+ case 8:
2263
+ _state.sent();
2264
+ spinner.text = "Updating package.json's build and start scripts";
2265
+ return [
2266
+ 4,
2267
+ updatePackageJson(builtPreviewAppPath)
2268
+ ];
2269
+ case 9:
2270
+ _state.sent();
2271
+ spinner.text = "Installing dependencies on `.react-email`";
2272
+ return [
2273
+ 4,
2274
+ npmInstall(builtPreviewAppPath, packageManager)
2275
+ ];
2276
+ case 10:
2277
+ _state.sent();
2278
+ spinner.stopAndPersist({
2279
+ text: "Successfully prepared `.react-email` for `next build`",
2280
+ symbol: import_log_symbols3.default.success
2281
+ });
2282
+ return [
2283
+ 4,
2284
+ buildPreviewApp(builtPreviewAppPath)
2285
+ ];
2286
+ case 11:
2287
+ _state.sent();
2288
+ return [
2289
+ 3,
2290
+ 13
2291
+ ];
2292
+ case 12:
2293
+ error = _state.sent();
2294
+ console.log(error);
2295
+ process.exit(1);
2296
+ return [
2297
+ 3,
2298
+ 13
2299
+ ];
2300
+ case 13:
2301
+ return [
2302
+ 2
2303
+ ];
2304
+ }
2305
+ });
2306
+ });
2307
+ return function build(_) {
2308
+ return _ref.apply(this, arguments);
2309
+ };
2310
+ }();
2311
+ // src/cli/commands/start.ts
2312
+ var import_node_fs8 = __toESM(require("fs"));
2313
+ var import_node_path9 = __toESM(require("path"));
2314
+ var import_node_child_process2 = require("child_process");
2315
+ var start = function() {
2316
+ var _ref = _async_to_generator(function() {
2317
+ var usersProjectLocation, builtPreviewPath, nextStart;
2318
+ return _ts_generator(this, function(_state) {
2319
+ try {
2320
+ usersProjectLocation = process.cwd();
2321
+ builtPreviewPath = import_node_path9.default.resolve(usersProjectLocation, "./.react-email");
2322
+ if (!import_node_fs8.default.existsSync(builtPreviewPath)) {
2323
+ throw new Error("Could not find `.react-email`, maybe you haven't ran `email build`?");
2324
+ }
2325
+ nextStart = (0, import_node_child_process2.spawn)("npm", [
2326
+ "start"
2327
+ ], {
2328
+ cwd: builtPreviewPath,
2329
+ stdio: "inherit"
2330
+ });
2331
+ process.on("SIGINT", function() {
2332
+ nextStart.kill("SIGINT");
2333
+ });
2334
+ nextStart.on("exit", function(code) {
2335
+ process.exit(code !== null && code !== void 0 ? code : 0);
2336
+ });
2337
+ } catch (error) {
2338
+ console.log(error);
2339
+ process.exit(1);
2340
+ }
2341
+ return [
2342
+ 2
2343
+ ];
2344
+ });
2345
+ });
2346
+ return function start() {
2347
+ return _ref.apply(this, arguments);
2348
+ };
2349
+ }();
2350
+ // src/cli/index.ts
2351
+ var PACKAGE_NAME = "react-email";
2352
+ import_commander.program.name(PACKAGE_NAME).description("A live preview of your emails right in your browser").version(package_default.version);
2353
+ import_commander.program.command("dev").description("Starts the preview email development app").option("-d, --dir <path>", "Directory with your email templates", "./emails").option("-p --port <port>", "Port to run dev server on", "3000").action(dev);
2354
+ import_commander.program.command("build").description("Copies the preview app for onto .react-email and builds it").option("-d, --dir <path>", "Directory with your email templates", "./emails").option("-p --packageManager <name>", "Package name to use on installation on `.react-email`", "npm").action(build);
2355
+ import_commander.program.command("start").description('Runs the built preview app that is inside of ".react-email"').action(start);
2356
+ import_commander.program.command("export").description("Build the templates to the `out` directory").option("--outDir <path>", "Output directory", "out").option("-p, --pretty", "Pretty print the output", false).option("-t, --plainText", "Set output format as plain text", false).option("-d, --dir <path>", "Directory with your email templates", "./emails").action(function(param) {
2357
+ var outDir = param.outDir, pretty = param.pretty, plainText = param.plainText, srcDir = param.dir;
2358
+ return exportTemplates(outDir, srcDir, {
2359
+ pretty: pretty,
2360
+ plainText: plainText
2361
+ });
2362
+ });
2363
+ import_commander.program.parse();