react-email 4.0.16 → 4.1.0-canary.10

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 (470) hide show
  1. package/CHANGELOG.md +65 -0
  2. package/dev/index.js +40 -0
  3. package/dev/package.json +13 -0
  4. package/dist/index.js +1 -1
  5. package/package.json +13 -46
  6. package/readme.md +16 -0
  7. package/src/commands/build.ts +306 -0
  8. package/src/commands/dev.ts +27 -0
  9. package/src/commands/export.ts +204 -0
  10. package/src/commands/start.ts +38 -0
  11. package/src/index.ts +55 -0
  12. package/src/utils/__snapshots__/tree.spec.ts.snap +27 -0
  13. package/src/utils/esbuild/renderring-utilities-exporter.ts +1 -1
  14. package/src/utils/get-emails-directory-metadata.spec.ts +1 -1
  15. package/src/utils/get-preview-server-location.ts +51 -0
  16. package/src/utils/index.ts +2 -6
  17. package/src/utils/packageJson.ts +4 -0
  18. package/src/utils/preview/get-env-variables-for-preview-app.ts +14 -0
  19. package/src/utils/preview/hot-reloading/create-dependency-graph.spec.ts +284 -0
  20. package/src/utils/preview/hot-reloading/create-dependency-graph.ts +321 -0
  21. package/src/utils/preview/hot-reloading/get-imported-modules.spec.ts +151 -0
  22. package/src/utils/preview/hot-reloading/get-imported-modules.ts +49 -0
  23. package/src/utils/preview/hot-reloading/resolve-path-aliases.spec.ts +11 -0
  24. package/src/utils/preview/hot-reloading/resolve-path-aliases.ts +32 -0
  25. package/src/utils/preview/hot-reloading/setup-hot-reloading.ts +121 -0
  26. package/src/utils/preview/hot-reloading/test/tsconfig.json +8 -0
  27. package/src/utils/preview/index.ts +2 -0
  28. package/src/utils/preview/serve-static-file.ts +51 -0
  29. package/src/utils/preview/start-dev-server.ts +234 -0
  30. package/src/utils/tree.spec.ts +5 -0
  31. package/src/utils/tree.ts +76 -0
  32. package/src/utils/types/hot-reload-change.ts +1 -1
  33. package/src/utils/types/hot-reload-event.ts +1 -1
  34. package/tsconfig.json +4 -10
  35. package/dist/cli/index.d.mts +0 -1
  36. package/dist/cli/index.d.ts +0 -1
  37. package/dist/cli/index.js +0 -2785
  38. package/dist/cli/index.mjs +0 -1361
  39. package/dist/index.d.mts +0 -20
  40. package/dist/index.d.ts +0 -20
  41. package/dist/index.mjs +0 -21
  42. package/dist/package/index.d.mts +0 -33
  43. package/dist/package/index.d.ts +0 -33
  44. package/dist/package/index.js +0 -62
  45. package/dist/package/index.mjs +0 -7
  46. package/dist/preview/.next/BUILD_ID +0 -1
  47. package/dist/preview/.next/app-build-manifest.json +0 -44
  48. package/dist/preview/.next/app-path-routes-manifest.json +0 -6
  49. package/dist/preview/.next/build-manifest.json +0 -33
  50. package/dist/preview/.next/diagnostics/build-diagnostics.json +0 -6
  51. package/dist/preview/.next/diagnostics/framework.json +0 -1
  52. package/dist/preview/.next/export-marker.json +0 -6
  53. package/dist/preview/.next/images-manifest.json +0 -57
  54. package/dist/preview/.next/next-minimal-server.js.nft.json +0 -1
  55. package/dist/preview/.next/next-server.js.nft.json +0 -1
  56. package/dist/preview/.next/package.json +0 -1
  57. package/dist/preview/.next/prerender-manifest.json +0 -41
  58. package/dist/preview/.next/react-loadable-manifest.json +0 -1
  59. package/dist/preview/.next/required-server-files.json +0 -311
  60. package/dist/preview/.next/routes-manifest.json +0 -64
  61. package/dist/preview/.next/server/app/_not-found/page.js +0 -1
  62. package/dist/preview/.next/server/app/_not-found/page.js.nft.json +0 -1
  63. package/dist/preview/.next/server/app/_not-found/page_client-reference-manifest.js +0 -1
  64. package/dist/preview/.next/server/app/favicon.ico/route.js +0 -1
  65. package/dist/preview/.next/server/app/favicon.ico/route.js.nft.json +0 -1
  66. package/dist/preview/.next/server/app/favicon.ico.body +0 -0
  67. package/dist/preview/.next/server/app/favicon.ico.meta +0 -1
  68. package/dist/preview/.next/server/app/page.js +0 -1
  69. package/dist/preview/.next/server/app/page.js.nft.json +0 -1
  70. package/dist/preview/.next/server/app/page_client-reference-manifest.js +0 -1
  71. package/dist/preview/.next/server/app/preview/[...slug]/page.js +0 -321
  72. package/dist/preview/.next/server/app/preview/[...slug]/page.js.nft.json +0 -1
  73. package/dist/preview/.next/server/app/preview/[...slug]/page_client-reference-manifest.js +0 -1
  74. package/dist/preview/.next/server/app-paths-manifest.json +0 -6
  75. package/dist/preview/.next/server/chunks/134.js +0 -6
  76. package/dist/preview/.next/server/chunks/235.js +0 -15
  77. package/dist/preview/.next/server/chunks/275.js +0 -1
  78. package/dist/preview/.next/server/chunks/343.js +0 -20
  79. package/dist/preview/.next/server/chunks/428.js +0 -14
  80. package/dist/preview/.next/server/chunks/963.js +0 -1
  81. package/dist/preview/.next/server/functions-config-manifest.json +0 -4
  82. package/dist/preview/.next/server/interception-route-rewrite-manifest.js +0 -1
  83. package/dist/preview/.next/server/middleware-build-manifest.js +0 -1
  84. package/dist/preview/.next/server/middleware-manifest.json +0 -6
  85. package/dist/preview/.next/server/middleware-react-loadable-manifest.js +0 -1
  86. package/dist/preview/.next/server/next-font-manifest.js +0 -1
  87. package/dist/preview/.next/server/next-font-manifest.json +0 -1
  88. package/dist/preview/.next/server/pages/500.html +0 -1
  89. package/dist/preview/.next/server/pages/_app.js +0 -1
  90. package/dist/preview/.next/server/pages/_app.js.nft.json +0 -1
  91. package/dist/preview/.next/server/pages/_document.js +0 -1
  92. package/dist/preview/.next/server/pages/_document.js.nft.json +0 -1
  93. package/dist/preview/.next/server/pages/_error.js +0 -1
  94. package/dist/preview/.next/server/pages/_error.js.nft.json +0 -1
  95. package/dist/preview/.next/server/pages-manifest.json +0 -5
  96. package/dist/preview/.next/server/server-reference-manifest.js +0 -1
  97. package/dist/preview/.next/server/server-reference-manifest.json +0 -1
  98. package/dist/preview/.next/server/webpack-runtime.js +0 -1
  99. package/dist/preview/.next/static/chunks/107-3043079e7cb8bcae.js +0 -1
  100. package/dist/preview/.next/static/chunks/293-297b1eb2241f9a70.js +0 -1
  101. package/dist/preview/.next/static/chunks/3bd82e28-cda2c00a924937c5.js +0 -1
  102. package/dist/preview/.next/static/chunks/45-1021fac82f766268.js +0 -1
  103. package/dist/preview/.next/static/chunks/484-e38a627386aae911.js +0 -1
  104. package/dist/preview/.next/static/chunks/589-817d8691661d370e.js +0 -1
  105. package/dist/preview/.next/static/chunks/902-c34acb56733e0ce1.js +0 -1
  106. package/dist/preview/.next/static/chunks/app/_not-found/page-4cbc7dce3ad33336.js +0 -1
  107. package/dist/preview/.next/static/chunks/app/layout-269b5cbd8f4cd2e3.js +0 -1
  108. package/dist/preview/.next/static/chunks/app/page-2dbfb5b2dc4b1191.js +0 -1
  109. package/dist/preview/.next/static/chunks/app/preview/[...slug]/page-79e0c9b528a62f8b.js +0 -1
  110. package/dist/preview/.next/static/chunks/f33a14d2-ec7c5f0b91818561.js +0 -6
  111. package/dist/preview/.next/static/chunks/framework-b887e9fc751a9906.js +0 -1
  112. package/dist/preview/.next/static/chunks/main-9a03e7ba8acb1900.js +0 -1
  113. package/dist/preview/.next/static/chunks/main-app-976577a424e11c75.js +0 -1
  114. package/dist/preview/.next/static/chunks/pages/_app-542a93a5a214e1c0.js +0 -1
  115. package/dist/preview/.next/static/chunks/pages/_error-d5fe1b1612642f76.js +0 -1
  116. package/dist/preview/.next/static/chunks/polyfills-42372ed130431b0a.js +0 -1
  117. package/dist/preview/.next/static/chunks/webpack-31c45daa2bd82a7b.js +0 -1
  118. package/dist/preview/.next/static/css/ac3decd5d6736fbe.css +0 -3
  119. package/dist/preview/.next/static/media/05613964ce6c782e-s.p.otf +0 -0
  120. package/dist/preview/.next/static/media/11c6126b9369e85e-s.p.otf +0 -0
  121. package/dist/preview/.next/static/media/26a46d62cd723877-s.woff2 +0 -0
  122. package/dist/preview/.next/static/media/26cb97734d8cb717-s.p.otf +0 -0
  123. package/dist/preview/.next/static/media/55c55f0601d81cf3-s.woff2 +0 -0
  124. package/dist/preview/.next/static/media/581909926a08bbc8-s.woff2 +0 -0
  125. package/dist/preview/.next/static/media/8e9860b6e62d6359-s.woff2 +0 -0
  126. package/dist/preview/.next/static/media/97e0cb1ae144a2a9-s.woff2 +0 -0
  127. package/dist/preview/.next/static/media/bb6462617151f6b7-s.p.otf +0 -0
  128. package/dist/preview/.next/static/media/cf6daef822ab0142-s.p.otf +0 -0
  129. package/dist/preview/.next/static/media/df0a9ae256c0569c-s.woff2 +0 -0
  130. package/dist/preview/.next/static/media/e4051546b3043204-s.p.otf +0 -0
  131. package/dist/preview/.next/static/media/e4af272ccee01ff0-s.p.woff2 +0 -0
  132. package/dist/preview/.next/static/media/logo.2ce2a759.png +0 -0
  133. package/dist/preview/.next/static/yxjkw7Y7HRLmRWkl3S43z/_buildManifest.js +0 -1
  134. package/dist/preview/.next/static/yxjkw7Y7HRLmRWkl3S43z/_ssgManifest.js +0 -1
  135. package/dist/preview/.next/trace +0 -27
  136. package/dist/preview/.next/types/app/layout.ts +0 -84
  137. package/dist/preview/.next/types/app/page.ts +0 -84
  138. package/dist/preview/.next/types/app/preview/[...slug]/page.ts +0 -84
  139. package/dist/preview/.next/types/cache-life.d.ts +0 -141
  140. package/dist/preview/.next/types/package.json +0 -1
  141. package/module-punycode.d.ts +0 -3
  142. package/next-env.d.ts +0 -5
  143. package/next.config.js +0 -22
  144. package/postcss.config.js +0 -8
  145. package/scripts/build-preview-server.mjs +0 -33
  146. package/scripts/fill-caniemail-data.mjs +0 -36
  147. package/src/actions/email-validation/caniemail-data.ts +0 -85993
  148. package/src/actions/email-validation/check-compatibility.ts +0 -333
  149. package/src/actions/email-validation/check-images.spec.tsx +0 -100
  150. package/src/actions/email-validation/check-images.ts +0 -160
  151. package/src/actions/email-validation/check-links.spec.tsx +0 -113
  152. package/src/actions/email-validation/check-links.ts +0 -113
  153. package/src/actions/email-validation/get-code-location-from-ast-element.ts +0 -18
  154. package/src/actions/email-validation/quick-fetch.ts +0 -14
  155. package/src/actions/get-email-path-from-slug.ts +0 -32
  156. package/src/actions/get-emails-directory-metadata-action.ts +0 -19
  157. package/src/actions/render-email-by-path.tsx +0 -121
  158. package/src/animated-icons-data/help.json +0 -1082
  159. package/src/animated-icons-data/link.json +0 -1309
  160. package/src/animated-icons-data/load.json +0 -443
  161. package/src/animated-icons-data/mail.json +0 -1320
  162. package/src/app/env.ts +0 -15
  163. package/src/app/favicon.ico +0 -0
  164. package/src/app/fonts/SFMono/SFMonoBold.otf +0 -0
  165. package/src/app/fonts/SFMono/SFMonoBoldItalic.otf +0 -0
  166. package/src/app/fonts/SFMono/SFMonoHeavy.otf +0 -0
  167. package/src/app/fonts/SFMono/SFMonoHeavyItalic.otf +0 -0
  168. package/src/app/fonts/SFMono/SFMonoLight.otf +0 -0
  169. package/src/app/fonts/SFMono/SFMonoLightItalic.otf +0 -0
  170. package/src/app/fonts/SFMono/SFMonoMedium.otf +0 -0
  171. package/src/app/fonts/SFMono/SFMonoMediumItalic.otf +0 -0
  172. package/src/app/fonts/SFMono/SFMonoRegular.otf +0 -0
  173. package/src/app/fonts/SFMono/SFMonoRegularItalic.otf +0 -0
  174. package/src/app/fonts/SFMono/SFMonoSemibold.otf +0 -0
  175. package/src/app/fonts/SFMono/SFMonoSemiboldItalic.otf +0 -0
  176. package/src/app/fonts.ts +0 -39
  177. package/src/app/globals.css +0 -15
  178. package/src/app/layout.tsx +0 -43
  179. package/src/app/logo.png +0 -0
  180. package/src/app/page.tsx +0 -46
  181. package/src/app/preview/[...slug]/page.tsx +0 -157
  182. package/src/app/preview/[...slug]/preview.tsx +0 -216
  183. package/src/app/preview/[...slug]/rendering-error.tsx +0 -40
  184. package/src/commands/testing/out/magic-links/aws-verify-email.html +0 -165
  185. package/src/commands/testing/out/magic-links/linear-login-code.html +0 -90
  186. package/src/commands/testing/out/magic-links/notion-magic-link.html +0 -76
  187. package/src/commands/testing/out/magic-links/plaid-verify-identity.html +0 -78
  188. package/src/commands/testing/out/magic-links/raycast-magic-link.html +0 -91
  189. package/src/commands/testing/out/magic-links/slack-confirm.html +0 -240
  190. package/src/commands/testing/out/newsletters/codepen-challengers.html +0 -548
  191. package/src/commands/testing/out/newsletters/google-play-policy-update.html +0 -339
  192. package/src/commands/testing/out/newsletters/stack-overflow-tips.html +0 -231
  193. package/src/commands/testing/out/notifications/github-access-token.html +0 -104
  194. package/src/commands/testing/out/notifications/papermark-year-in-review.html +0 -317
  195. package/src/commands/testing/out/notifications/vercel-invite-user.html +0 -171
  196. package/src/commands/testing/out/notifications/yelp-recent-login.html +0 -195
  197. package/src/commands/testing/out/receipts/apple-receipt.html +0 -677
  198. package/src/commands/testing/out/receipts/nike-receipt.html +0 -724
  199. package/src/commands/testing/out/reset-password/dropbox-reset-password.html +0 -98
  200. package/src/commands/testing/out/reset-password/twitch-reset-password.html +0 -220
  201. package/src/commands/testing/out/reviews/airbnb-review.html +0 -206
  202. package/src/commands/testing/out/reviews/amazon-review.html +0 -356
  203. package/src/commands/testing/out/static/airbnb-logo.png +0 -0
  204. package/src/commands/testing/out/static/airbnb-review-user.jpg +0 -0
  205. package/src/commands/testing/out/static/amazon-book.jpg +0 -0
  206. package/src/commands/testing/out/static/amazon-facebook.jpg +0 -0
  207. package/src/commands/testing/out/static/amazon-instagram.jpg +0 -0
  208. package/src/commands/testing/out/static/amazon-logo.png +0 -0
  209. package/src/commands/testing/out/static/amazon-prime-logo.png +0 -0
  210. package/src/commands/testing/out/static/amazon-rating.gif +0 -0
  211. package/src/commands/testing/out/static/amazon-twitter.jpg +0 -0
  212. package/src/commands/testing/out/static/apple-card-icon.png +0 -0
  213. package/src/commands/testing/out/static/apple-hbo-max-icon.jpeg +0 -0
  214. package/src/commands/testing/out/static/apple-logo.png +0 -0
  215. package/src/commands/testing/out/static/apple-wallet.png +0 -0
  216. package/src/commands/testing/out/static/aws-logo.png +0 -0
  217. package/src/commands/testing/out/static/codepen-challengers.png +0 -0
  218. package/src/commands/testing/out/static/codepen-cube.png +0 -0
  219. package/src/commands/testing/out/static/codepen-pro.png +0 -0
  220. package/src/commands/testing/out/static/dropbox-logo.png +0 -0
  221. package/src/commands/testing/out/static/github.png +0 -0
  222. package/src/commands/testing/out/static/google-play-academy.png +0 -0
  223. package/src/commands/testing/out/static/google-play-chat.png +0 -0
  224. package/src/commands/testing/out/static/google-play-footer.png +0 -0
  225. package/src/commands/testing/out/static/google-play-header.png +0 -0
  226. package/src/commands/testing/out/static/google-play-icon.png +0 -0
  227. package/src/commands/testing/out/static/google-play-logo.png +0 -0
  228. package/src/commands/testing/out/static/google-play-pl.png +0 -0
  229. package/src/commands/testing/out/static/google-play.png +0 -0
  230. package/src/commands/testing/out/static/koala-logo.png +0 -0
  231. package/src/commands/testing/out/static/linear-logo.png +0 -0
  232. package/src/commands/testing/out/static/netlify-logo.png +0 -0
  233. package/src/commands/testing/out/static/nike-logo.png +0 -0
  234. package/src/commands/testing/out/static/nike-phone.png +0 -0
  235. package/src/commands/testing/out/static/nike-product.png +0 -0
  236. package/src/commands/testing/out/static/nike-recomendation-1.png +0 -0
  237. package/src/commands/testing/out/static/nike-recomendation-2.png +0 -0
  238. package/src/commands/testing/out/static/nike-recomendation-3.png +0 -0
  239. package/src/commands/testing/out/static/nike-recomendation-4.png +0 -0
  240. package/src/commands/testing/out/static/notion-logo.png +0 -0
  241. package/src/commands/testing/out/static/plaid-logo.png +0 -0
  242. package/src/commands/testing/out/static/raycast-bg.png +0 -0
  243. package/src/commands/testing/out/static/raycast-logo.png +0 -0
  244. package/src/commands/testing/out/static/slack-facebook.png +0 -0
  245. package/src/commands/testing/out/static/slack-linkedin.png +0 -0
  246. package/src/commands/testing/out/static/slack-logo.png +0 -0
  247. package/src/commands/testing/out/static/slack-twitter.png +0 -0
  248. package/src/commands/testing/out/static/stack-overflow-header.png +0 -0
  249. package/src/commands/testing/out/static/stack-overflow-logo-sm.png +0 -0
  250. package/src/commands/testing/out/static/stack-overflow-logo.png +0 -0
  251. package/src/commands/testing/out/static/stripe-logo.png +0 -0
  252. package/src/commands/testing/out/static/twitch-icon-facebook.png +0 -0
  253. package/src/commands/testing/out/static/twitch-icon-twitter.png +0 -0
  254. package/src/commands/testing/out/static/twitch-logo.png +0 -0
  255. package/src/commands/testing/out/static/vercel-arrow.png +0 -0
  256. package/src/commands/testing/out/static/vercel-logo.png +0 -0
  257. package/src/commands/testing/out/static/vercel-team.png +0 -0
  258. package/src/commands/testing/out/static/vercel-user.png +0 -0
  259. package/src/commands/testing/out/static/yelp-footer.png +0 -0
  260. package/src/commands/testing/out/static/yelp-header.png +0 -0
  261. package/src/commands/testing/out/static/yelp-logo.png +0 -0
  262. package/src/commands/testing/out/welcome/koala-welcome.html +0 -90
  263. package/src/commands/testing/out/welcome/netlify-welcome.html +0 -199
  264. package/src/commands/testing/out/welcome/stripe-welcome.html +0 -153
  265. package/src/components/button.tsx +0 -101
  266. package/src/components/code-container.tsx +0 -164
  267. package/src/components/code-snippet.tsx +0 -9
  268. package/src/components/code.tsx +0 -184
  269. package/src/components/heading.tsx +0 -113
  270. package/src/components/icons/icon-arrow-down.tsx +0 -16
  271. package/src/components/icons/icon-base.tsx +0 -26
  272. package/src/components/icons/icon-bug.tsx +0 -19
  273. package/src/components/icons/icon-button.tsx +0 -23
  274. package/src/components/icons/icon-check.tsx +0 -19
  275. package/src/components/icons/icon-clipboard.tsx +0 -40
  276. package/src/components/icons/icon-download.tsx +0 -19
  277. package/src/components/icons/icon-email.tsx +0 -18
  278. package/src/components/icons/icon-file.tsx +0 -19
  279. package/src/components/icons/icon-folder-open.tsx +0 -19
  280. package/src/components/icons/icon-folder.tsx +0 -18
  281. package/src/components/icons/icon-hide-sidebar.tsx +0 -23
  282. package/src/components/icons/icon-image.tsx +0 -19
  283. package/src/components/icons/icon-info.tsx +0 -18
  284. package/src/components/icons/icon-link.tsx +0 -14
  285. package/src/components/icons/icon-monitor.tsx +0 -19
  286. package/src/components/icons/icon-phone.tsx +0 -26
  287. package/src/components/icons/icon-reload.tsx +0 -18
  288. package/src/components/icons/icon-source.tsx +0 -19
  289. package/src/components/icons/icon-stamp.tsx +0 -14
  290. package/src/components/icons/icon-warning.tsx +0 -31
  291. package/src/components/index.ts +0 -7
  292. package/src/components/logo.tsx +0 -63
  293. package/src/components/resizable-wrapper.tsx +0 -173
  294. package/src/components/send.tsx +0 -134
  295. package/src/components/shell.tsx +0 -95
  296. package/src/components/sidebar/file-tree-directory-children.tsx +0 -134
  297. package/src/components/sidebar/file-tree-directory.tsx +0 -92
  298. package/src/components/sidebar/file-tree.tsx +0 -31
  299. package/src/components/sidebar/index.ts +0 -1
  300. package/src/components/sidebar/sidebar.tsx +0 -43
  301. package/src/components/text.tsx +0 -99
  302. package/src/components/toolbar/checking-results.tsx +0 -150
  303. package/src/components/toolbar/code-preview-line-link.tsx +0 -40
  304. package/src/components/toolbar/compatibility.tsx +0 -113
  305. package/src/components/toolbar/linter.tsx +0 -278
  306. package/src/components/toolbar/results.tsx +0 -51
  307. package/src/components/toolbar/spam-assassin.tsx +0 -155
  308. package/src/components/toolbar/toolbar-button.tsx +0 -52
  309. package/src/components/toolbar/use-cached-state.ts +0 -33
  310. package/src/components/toolbar.tsx +0 -349
  311. package/src/components/tooltip-content.tsx +0 -31
  312. package/src/components/tooltip.tsx +0 -19
  313. package/src/components/topbar/active-view-toggle-group.tsx +0 -86
  314. package/src/components/topbar/view-size-controls.tsx +0 -247
  315. package/src/components/topbar.tsx +0 -59
  316. package/src/contexts/emails.tsx +0 -59
  317. package/src/contexts/fragment-identifier.tsx +0 -48
  318. package/src/contexts/preview.tsx +0 -79
  319. package/src/hooks/use-clamped-state.ts +0 -24
  320. package/src/hooks/use-email-rendering-result.ts +0 -58
  321. package/src/hooks/use-fragment-identifier.ts +0 -14
  322. package/src/hooks/use-hot-reload.ts +0 -31
  323. package/src/hooks/use-icon-animation.ts +0 -41
  324. package/src/hooks/use-rendering-metadata.ts +0 -36
  325. package/src/package/body/dist/index.d.mts +0 -6
  326. package/src/package/body/dist/index.d.ts +0 -6
  327. package/src/package/body/dist/index.js +0 -79
  328. package/src/package/body/dist/index.mjs +0 -45
  329. package/src/package/button/dist/index.d.mts +0 -6
  330. package/src/package/button/dist/index.d.ts +0 -6
  331. package/src/package/button/dist/index.js +0 -252
  332. package/src/package/button/dist/index.mjs +0 -218
  333. package/src/package/code-block/dist/index.d.mts +0 -4906
  334. package/src/package/code-block/dist/index.d.ts +0 -4906
  335. package/src/package/code-block/dist/index.js +0 -18205
  336. package/src/package/code-block/dist/index.mjs +0 -18133
  337. package/src/package/code-inline/dist/index.d.mts +0 -11
  338. package/src/package/code-inline/dist/index.d.ts +0 -11
  339. package/src/package/code-inline/dist/index.js +0 -106
  340. package/src/package/code-inline/dist/index.mjs +0 -72
  341. package/src/package/column/dist/index.d.mts +0 -6
  342. package/src/package/column/dist/index.d.ts +0 -6
  343. package/src/package/column/dist/index.js +0 -79
  344. package/src/package/column/dist/index.mjs +0 -45
  345. package/src/package/components/dist/index.d.mts +0 -20
  346. package/src/package/components/dist/index.d.ts +0 -20
  347. package/src/package/components/dist/index.js +0 -62
  348. package/src/package/components/dist/index.mjs +0 -21
  349. package/src/package/container/dist/index.d.mts +0 -6
  350. package/src/package/container/dist/index.d.ts +0 -6
  351. package/src/package/container/dist/index.js +0 -93
  352. package/src/package/container/dist/index.mjs +0 -59
  353. package/src/package/font/dist/index.d.mts +0 -25
  354. package/src/package/font/dist/index.d.ts +0 -25
  355. package/src/package/font/dist/index.js +0 -55
  356. package/src/package/font/dist/index.mjs +0 -28
  357. package/src/package/head/dist/index.d.mts +0 -6
  358. package/src/package/head/dist/index.d.ts +0 -6
  359. package/src/package/head/dist/index.js +0 -83
  360. package/src/package/head/dist/index.mjs +0 -49
  361. package/src/package/heading/dist/index.d.mts +0 -43
  362. package/src/package/heading/dist/index.d.ts +0 -43
  363. package/src/package/heading/dist/index.js +0 -113
  364. package/src/package/heading/dist/index.mjs +0 -79
  365. package/src/package/hr/dist/index.d.mts +0 -6
  366. package/src/package/hr/dist/index.d.ts +0 -6
  367. package/src/package/hr/dist/index.js +0 -89
  368. package/src/package/hr/dist/index.mjs +0 -55
  369. package/src/package/html/dist/index.d.mts +0 -6
  370. package/src/package/html/dist/index.d.ts +0 -6
  371. package/src/package/html/dist/index.js +0 -79
  372. package/src/package/html/dist/index.mjs +0 -45
  373. package/src/package/img/dist/index.d.mts +0 -6
  374. package/src/package/img/dist/index.d.ts +0 -6
  375. package/src/package/img/dist/index.js +0 -94
  376. package/src/package/img/dist/index.mjs +0 -60
  377. package/src/package/link/dist/index.d.mts +0 -6
  378. package/src/package/link/dist/index.d.ts +0 -6
  379. package/src/package/link/dist/index.js +0 -90
  380. package/src/package/link/dist/index.mjs +0 -56
  381. package/src/package/markdown/dist/index.d.mts +0 -15
  382. package/src/package/markdown/dist/index.d.ts +0 -15
  383. package/src/package/markdown/dist/index.js +0 -92
  384. package/src/package/markdown/dist/index.mjs +0 -58
  385. package/src/package/preview/dist/index.d.mts +0 -12
  386. package/src/package/preview/dist/index.d.ts +0 -12
  387. package/src/package/preview/dist/index.js +0 -108
  388. package/src/package/preview/dist/index.mjs +0 -73
  389. package/src/package/render/dist/browser/index.d.mts +0 -24
  390. package/src/package/render/dist/browser/index.d.ts +0 -24
  391. package/src/package/render/dist/browser/index.js +0 -250
  392. package/src/package/render/dist/browser/index.mjs +0 -214
  393. package/src/package/render/dist/index.d.mts +0 -23
  394. package/src/package/render/dist/index.d.ts +0 -23
  395. package/src/package/render/dist/index.js +0 -768
  396. package/src/package/render/dist/index.mjs +0 -733
  397. package/src/package/render/dist/node/index.d.mts +0 -27
  398. package/src/package/render/dist/node/index.d.ts +0 -27
  399. package/src/package/render/dist/node/index.js +0 -212
  400. package/src/package/render/dist/node/index.mjs +0 -176
  401. package/src/package/row/dist/index.d.mts +0 -10
  402. package/src/package/row/dist/index.d.ts +0 -10
  403. package/src/package/row/dist/index.js +0 -93
  404. package/src/package/row/dist/index.mjs +0 -59
  405. package/src/package/section/dist/index.d.mts +0 -6
  406. package/src/package/section/dist/index.d.ts +0 -6
  407. package/src/package/section/dist/index.js +0 -93
  408. package/src/package/section/dist/index.mjs +0 -59
  409. package/src/package/tailwind/dist/index.d.ts +0 -19
  410. package/src/package/tailwind/dist/index.js +0 -48
  411. package/src/package/tailwind/dist/index.mjs +0 -17167
  412. package/src/package/tailwind/dist/tailwindcss/config.d.ts +0 -376
  413. package/src/package/tailwind/dist/tailwindcss/generated/.gitkeep +0 -0
  414. package/src/package/tailwind/dist/tailwindcss/generated/colors.d.ts +0 -298
  415. package/src/package/tailwind/dist/tailwindcss/generated/corePluginList.d.ts +0 -1
  416. package/src/package/tailwind/dist/tailwindcss/generated/default-theme.d.ts +0 -397
  417. package/src/package/tailwind/dist/tailwindcss/index.d.ts +0 -11
  418. package/src/package/text/dist/index.d.mts +0 -6
  419. package/src/package/text/dist/index.d.ts +0 -6
  420. package/src/package/text/dist/index.js +0 -89
  421. package/src/package/text/dist/index.mjs +0 -55
  422. package/src/utils/__snapshots__/get-email-component.spec.ts.snap +0 -3
  423. package/src/utils/caniemail/all-css-properties.ts +0 -358
  424. package/src/utils/caniemail/ast/__snapshots__/get-object-variables.spec.ts.snap +0 -74
  425. package/src/utils/caniemail/ast/__snapshots__/get-used-style-properties.spec.ts.snap +0 -24
  426. package/src/utils/caniemail/ast/get-object-variables.spec.ts +0 -19
  427. package/src/utils/caniemail/ast/get-object-variables.ts +0 -61
  428. package/src/utils/caniemail/ast/get-used-style-properties.spec.ts +0 -23
  429. package/src/utils/caniemail/ast/get-used-style-properties.ts +0 -91
  430. package/src/utils/caniemail/get-compatibility-stats-for-entry.ts +0 -118
  431. package/src/utils/caniemail/get-css-functions.ts +0 -25
  432. package/src/utils/caniemail/get-css-property-names.ts +0 -32
  433. package/src/utils/caniemail/get-css-property-with-value.ts +0 -14
  434. package/src/utils/caniemail/get-css-unit.ts +0 -3
  435. package/src/utils/caniemail/get-element-attributes.ts +0 -7
  436. package/src/utils/caniemail/get-element-names.ts +0 -20
  437. package/src/utils/caniemail/tailwind/generate-tailwind-rules.ts +0 -30
  438. package/src/utils/caniemail/tailwind/get-tailwind-config.ts +0 -187
  439. package/src/utils/caniemail/tailwind/get-tailwind-metadata.spec.ts +0 -25
  440. package/src/utils/caniemail/tailwind/get-tailwind-metadata.ts +0 -45
  441. package/src/utils/caniemail/tailwind/setup-tailwind-context.ts +0 -15
  442. package/src/utils/cn.ts +0 -6
  443. package/src/utils/constants.ts +0 -6
  444. package/src/utils/contains-email-template.spec.ts +0 -124
  445. package/src/utils/contains-email-template.ts +0 -33
  446. package/src/utils/copy-text-to-clipboard.ts +0 -7
  447. package/src/utils/get-email-component.spec.ts +0 -41
  448. package/src/utils/get-email-component.ts +0 -134
  449. package/src/utils/get-line-and-column-from-offset.spec.ts +0 -11
  450. package/src/utils/get-line-and-column-from-offset.ts +0 -11
  451. package/src/utils/improve-error-with-sourcemap.ts +0 -86
  452. package/src/utils/js-email-detection.spec.ts +0 -24
  453. package/src/utils/language-map.ts +0 -7
  454. package/src/utils/linting.ts +0 -60
  455. package/src/utils/load-stream.ts +0 -15
  456. package/src/utils/result.ts +0 -49
  457. package/src/utils/run-bundled-code.ts +0 -64
  458. package/src/utils/sanitize.ts +0 -6
  459. package/src/utils/static-node-modules-for-vm.ts +0 -93
  460. package/src/utils/testing/js-email-export-default.js +0 -17
  461. package/src/utils/testing/js-email-test.js +0 -18
  462. package/src/utils/testing/mdx-email-test.js +0 -128
  463. package/src/utils/testing/request-response-email.tsx +0 -9
  464. package/src/utils/types/as.ts +0 -26
  465. package/src/utils/types/email-template.ts +0 -8
  466. package/src/utils/types/error-object.ts +0 -11
  467. package/src/utils/unreachable.ts +0 -8
  468. package/tailwind-internals.d.ts +0 -133
  469. package/tailwind.config.ts +0 -99
  470. /package/src/{components/toolbar/results-table.tsx → utils/preview/hot-reloading/test/some-file.ts} +0 -0
@@ -1,118 +0,0 @@
1
- /* eslint-disable @typescript-eslint/no-non-null-assertion */
2
- import type {
3
- EmailClient,
4
- Platform,
5
- SupportEntry,
6
- } from '../../actions/email-validation/check-compatibility';
7
-
8
- export type SupportStatus = DetailedSupportStatus['status'];
9
-
10
- export type DetailedSupportStatus =
11
- | {
12
- status: 'success';
13
- }
14
- | {
15
- status: 'error';
16
- }
17
- | {
18
- status: 'warning';
19
- notes: string;
20
- };
21
-
22
- type EmailClientStats = {
23
- status: SupportStatus;
24
- perPlatform: Partial<Record<Platform, DetailedSupportStatus>>;
25
- };
26
-
27
- export type CompatibilityStats = {
28
- status: SupportStatus;
29
- perEmailClient: Partial<Record<EmailClient, EmailClientStats>>;
30
- };
31
-
32
- const noteNumbersRegex = /#(?<noteNumber>\d+)/g;
33
-
34
- export const getCompatibilityStatsForEntry = (
35
- entry: SupportEntry,
36
- emailClients: EmailClient[],
37
- ) => {
38
- const stats: CompatibilityStats = {
39
- status: 'success',
40
- perEmailClient: {},
41
- };
42
- for (const emailClient of emailClients) {
43
- const rawStats = entry.stats[emailClient];
44
- if (rawStats) {
45
- const emailClientStats: EmailClientStats = {
46
- status: 'success',
47
- perPlatform: {},
48
- };
49
-
50
- for (const [platform, statusPerVersion] of Object.entries(rawStats)) {
51
- const latestStatus = statusPerVersion[statusPerVersion.length - 1];
52
- if (latestStatus === undefined)
53
- throw new Error(
54
- 'Cannot load in status because there are none recorded for this platform/email client',
55
- {
56
- cause: {
57
- latestStatus,
58
- statusPerVersion,
59
- platform,
60
- emailClient,
61
- supportEntry: entry,
62
- },
63
- },
64
- );
65
- const statusString = latestStatus[Object.keys(latestStatus)[0]!]!;
66
- if (statusString.startsWith('u')) continue;
67
- if (statusString.startsWith('a')) {
68
- const notes: string[] = [];
69
- noteNumbersRegex.lastIndex = 0;
70
- for (const match of statusString.matchAll(noteNumbersRegex)) {
71
- if (match.groups?.noteNumber) {
72
- const { noteNumber } = match.groups;
73
- const note = entry.notes_by_num?.[Number.parseInt(noteNumber)];
74
- if (note) {
75
- notes.push(note);
76
- }
77
- // else if (isInternalDev) {
78
- // console.warn(
79
- // 'Could not get note by the number for a support entry',
80
- // {
81
- // platform,
82
- // statusString,
83
- // note,
84
- // },
85
- // );
86
- // }
87
- }
88
- }
89
- if (emailClientStats.status === 'success')
90
- emailClientStats.status = 'warning';
91
- if (stats.status === 'success') stats.status = 'warning';
92
- emailClientStats.perPlatform[platform as Platform] = {
93
- status: 'warning',
94
- notes:
95
- notes.length === 1
96
- ? notes[0]!
97
- : notes.map((note) => `- ${note}`).join('\n'),
98
- };
99
- } else if (statusString.startsWith('y')) {
100
- emailClientStats.perPlatform[platform as Platform] = {
101
- status: 'success',
102
- };
103
- } else if (statusString.startsWith('n')) {
104
- if (emailClientStats.status !== 'error')
105
- emailClientStats.status = 'error';
106
- if (stats.status !== 'error') stats.status = 'error';
107
- emailClientStats.perPlatform[platform as Platform] = {
108
- status: 'error',
109
- };
110
- }
111
- }
112
-
113
- stats.perEmailClient[emailClient] = emailClientStats;
114
- }
115
- }
116
-
117
- return stats;
118
- };
@@ -1,25 +0,0 @@
1
- export function getCssFunctions(title: string) {
2
- if (/^[a-zA-Z]\(\)$/.test(title.trim())) {
3
- return [title.replace('()', '')];
4
- }
5
-
6
- // ex: lch(), oklch(), lab(), oklab()
7
- // this regex avoids matching entries that are for CSS properties listed
8
- // separated by commas as well
9
- if (/^(?:[^(),]+?\(\),?)*$/.test(title.trim())) {
10
- return title
11
- .split(/\s*,\s*/)
12
- .map((functionCallWithoutParameters) =>
13
- functionCallWithoutParameters.replace('()', ''),
14
- );
15
- }
16
-
17
- // ex: CSS calc() function
18
- if (/^CSS [a-z]+\(\) function$/.test(title.trim())) {
19
- return [
20
- title.replace('CSS ', '').replace(' function', '').replace('()', ''),
21
- ];
22
- }
23
-
24
- return [];
25
- }
@@ -1,32 +0,0 @@
1
- import { allCssProperties } from './all-css-properties';
2
-
3
- export const getCssPropertyNames = (title: string, keywords: string | null) => {
4
- if (allCssProperties.includes(title.replace(' property', '')))
5
- return [title.replace(' property', '')];
6
-
7
- if (title.split('&').length > 1) {
8
- return title
9
- .split(/\s*&\s*/)
10
- .map((piece) => piece.trim())
11
- .filter((possiblePropertyName) =>
12
- allCssProperties.includes(possiblePropertyName),
13
- );
14
- }
15
-
16
- if (title.split(',').length > 1) {
17
- return title
18
- .split(/\s*,\s*/)
19
- .map((piece) => piece.trim())
20
- .filter((possiblePropertyName) =>
21
- allCssProperties.includes(possiblePropertyName),
22
- );
23
- }
24
-
25
- if (keywords) {
26
- return keywords
27
- .split(/\s*,\s*/)
28
- .filter((keyword) => allCssProperties.includes(keyword));
29
- }
30
-
31
- return [];
32
- };
@@ -1,14 +0,0 @@
1
- const propertyRegex =
2
- /(?<propertyName>[a-z-]+)\s*:\s*(?<propertyValue>[a-zA-Z\-0-9()+*/_ ]+)/;
3
-
4
- export const getCssPropertyWithValue = (title: string) => {
5
- const match = propertyRegex.exec(title.trim());
6
- if (match) {
7
- const [_full, propertyName, propertyValue] = match;
8
- return {
9
- name: propertyName!,
10
- value: propertyValue!,
11
- };
12
- }
13
- return undefined;
14
- };
@@ -1,3 +0,0 @@
1
- export const getCssUnit = (title: string) => {
2
- return title.endsWith(' unit') ? title.replace(' unit', '') : undefined;
3
- };
@@ -1,7 +0,0 @@
1
- export function getElementAttributes(title: string) {
2
- if (title.endsWith(' attribute')) {
3
- return [title.replace(' attribute', '')];
4
- }
5
-
6
- return [];
7
- }
@@ -1,20 +0,0 @@
1
- export const getElementNames = (title: string, keywords: string | null) => {
2
- const match = /<(?<elementName>[^>]*)> element/.exec(title);
3
- if (match) {
4
- const [_full, elementName] = match;
5
-
6
- if (elementName) {
7
- return [elementName];
8
- }
9
- }
10
-
11
- if (keywords !== null && keywords.length > 0) {
12
- return keywords.split(/\s*,\s*/).map((piece) => piece.trim());
13
- }
14
-
15
- if (title.split(',').length > 1) {
16
- return title.split(/\s*,\s*/).map((piece) => piece.trim());
17
- }
18
-
19
- return [];
20
- };
@@ -1,30 +0,0 @@
1
- import postcss from 'postcss';
2
- import type { Root, Rule } from 'postcss';
3
- import evaluateTailwindFunctions from 'tailwindcss/lib/lib/evaluateTailwindFunctions';
4
- import { generateRules as rawGenerateRules } from 'tailwindcss/lib/lib/generateRules';
5
- import type { JitContext } from 'tailwindcss/lib/lib/setupContextUtils';
6
-
7
- export const generateTailwindCssRules = (
8
- classNames: string[],
9
- tailwindContext: JitContext,
10
- ): { root: Root; rules: Rule[] } => {
11
- const bigIntRuleTuples: [bigint, Rule][] = rawGenerateRules(
12
- new Set(classNames),
13
- tailwindContext,
14
- );
15
-
16
- const root = postcss.root({
17
- nodes: bigIntRuleTuples.map(([, rule]) => rule),
18
- });
19
- evaluateTailwindFunctions(tailwindContext)(root);
20
-
21
- const actualRules: Rule[] = [];
22
- root.walkRules((rule) => {
23
- actualRules.push(rule);
24
- });
25
-
26
- return {
27
- root,
28
- rules: actualRules,
29
- };
30
- };
@@ -1,187 +0,0 @@
1
- import fs from 'node:fs';
2
- import path from 'node:path';
3
- import traverse from '@babel/traverse';
4
- import type { Node } from '@babel/traverse';
5
- import * as esbuild from 'esbuild';
6
- import type { Config as TailwindOriginalConfig } from 'tailwindcss';
7
- import type { AST } from '../../../actions/email-validation/check-compatibility';
8
- import { isErr } from '../../result';
9
- import { runBundledCode } from '../../run-bundled-code';
10
-
11
- export type TailwindConfig = Pick<
12
- TailwindOriginalConfig,
13
- | 'important'
14
- | 'prefix'
15
- | 'separator'
16
- | 'safelist'
17
- | 'blocklist'
18
- | 'presets'
19
- | 'future'
20
- | 'experimental'
21
- | 'darkMode'
22
- | 'theme'
23
- | 'corePlugins'
24
- | 'plugins'
25
- >;
26
-
27
- const getFirstExistingFilepath = (filePaths: string[]) => {
28
- for (const filePath of filePaths) {
29
- if (fs.existsSync(filePath)) {
30
- return filePath;
31
- }
32
- }
33
- };
34
-
35
- type ImportDeclaration = Node & { type: 'ImportDeclaration' };
36
-
37
- export const getTailwindConfig = async (
38
- sourceCode: string,
39
- ast: AST,
40
- sourcePath: string,
41
- ): Promise<TailwindConfig> => {
42
- const configAttribute = getTailwindConfigNode(ast);
43
-
44
- if (configAttribute) {
45
- const configIdentifierName =
46
- configAttribute.value?.type === 'JSXExpressionContainer' &&
47
- configAttribute.value.expression.type === 'Identifier'
48
- ? configAttribute.value.expression.name
49
- : undefined;
50
- if (configIdentifierName) {
51
- const tailwindConfigImport = getImportWithGivenDefaultSpecifier(
52
- ast,
53
- configIdentifierName,
54
- );
55
- if (tailwindConfigImport) {
56
- return getConfigFromImport(tailwindConfigImport, sourcePath);
57
- }
58
- }
59
-
60
- const configObjectExpression =
61
- configAttribute.value?.type === 'JSXExpressionContainer' &&
62
- configAttribute.value.expression.type === 'ObjectExpression'
63
- ? configAttribute.value.expression
64
- : undefined;
65
- if (configObjectExpression?.start && configObjectExpression.end) {
66
- const configObjectSourceCode = sourceCode.slice(
67
- configObjectExpression.start,
68
- configObjectExpression.end,
69
- );
70
-
71
- try {
72
- const getConfig = new Function(`return ${configObjectSourceCode}`);
73
- return getConfig() as TailwindConfig;
74
- } catch (exception) {
75
- console.warn(exception);
76
- console.warn(
77
- `Tried reading the config defined directly in the Tailwind component but was unable to, probably because it can't run by itself.`,
78
- );
79
- }
80
- }
81
- }
82
-
83
- return {};
84
- };
85
-
86
- const getConfigFromImport = async (
87
- tailwindConfigImport: ImportDeclaration,
88
- sourcePath: string,
89
- ): Promise<TailwindConfig> => {
90
- const configRelativePath = tailwindConfigImport.source.value;
91
- const sourceDirpath = path.dirname(sourcePath);
92
- const configFilepath = path.join(sourceDirpath, configRelativePath);
93
-
94
- const configBuildResult = await esbuild.build({
95
- bundle: true,
96
- stdin: {
97
- contents: `import tailwindConfig from "${configRelativePath}";
98
- export { tailwindConfig };`,
99
- loader: 'tsx',
100
- resolveDir: path.dirname(sourcePath),
101
- },
102
- platform: 'node',
103
- write: false,
104
- format: 'cjs',
105
- logLevel: 'silent',
106
- });
107
- const configFile = configBuildResult.outputFiles[0];
108
- if (configFile === undefined) {
109
- throw new Error(
110
- 'Could not build config file as it was found as undefined, this is most likely a bug, please open an issue.',
111
- );
112
- }
113
- const configModule = runBundledCode(configFile.text, configFilepath);
114
- if (isErr(configModule)) {
115
- throw new Error(
116
- `Error when trying to run the config file: ${configModule.error}`,
117
- );
118
- }
119
-
120
- if (
121
- typeof configModule.value === 'object' &&
122
- configModule.value !== null &&
123
- 'tailwindConfig' in configModule.value
124
- ) {
125
- return configModule.value.tailwindConfig as TailwindConfig;
126
- }
127
-
128
- throw new Error(
129
- `Could not read Tailwind config at ${configFilepath} because it doesn't have a default export in it.`,
130
- {
131
- cause: {
132
- configModule,
133
- configFilepath,
134
- },
135
- },
136
- );
137
- };
138
-
139
- const getImportWithGivenDefaultSpecifier = (
140
- ast: AST,
141
- specifierName: string,
142
- ) => {
143
- let importNode: ImportDeclaration | undefined;
144
- traverse(ast, {
145
- ImportDeclaration(nodePath) {
146
- if (
147
- nodePath.node.specifiers.some(
148
- (specifier) =>
149
- specifier.type === 'ImportDefaultSpecifier' &&
150
- specifier.local.name === specifierName,
151
- )
152
- ) {
153
- importNode = nodePath.node;
154
- }
155
- },
156
- });
157
- return importNode;
158
- };
159
-
160
- type JSXAttribute = Node & { type: 'JSXAttribute' };
161
-
162
- const getTailwindConfigNode = (ast: AST) => {
163
- let tailwindConfigNode: JSXAttribute | undefined;
164
- traverse(ast, {
165
- JSXOpeningElement(nodePath) {
166
- if (
167
- nodePath.node.name.type === 'JSXIdentifier' &&
168
- nodePath.node.name.name === 'Tailwind'
169
- ) {
170
- const configAttribute = nodePath.node.attributes.find(
171
- (
172
- attribute,
173
- ): attribute is Node & {
174
- type: 'JSXAttribute';
175
- } =>
176
- attribute.type === 'JSXAttribute' &&
177
- attribute.name.type === 'JSXIdentifier' &&
178
- attribute.name.name === 'config',
179
- );
180
- if (configAttribute) {
181
- tailwindConfigNode = configAttribute;
182
- }
183
- }
184
- },
185
- });
186
- return tailwindConfigNode;
187
- };
@@ -1,25 +0,0 @@
1
- import fs from 'node:fs/promises';
2
- import path from 'node:path';
3
- import { parse } from '@babel/parser';
4
- import { getTailwindMetadata } from './get-tailwind-metadata';
5
-
6
- describe('getTailwindMetadata()', () => {
7
- test('with the netlify-welcome demo email', async () => {
8
- const emailPath = path.resolve(
9
- __dirname,
10
- '../../../../../../apps/demo/emails/welcome/netlify-welcome.tsx',
11
- );
12
- const reactCode = await fs.readFile(emailPath, 'utf8');
13
- const ast = parse(reactCode, {
14
- strictMode: false,
15
- errorRecovery: true,
16
- sourceType: 'unambiguous',
17
- plugins: ['jsx', 'typescript', 'decorators'],
18
- });
19
-
20
- const tailwindMetadata = getTailwindMetadata(ast, reactCode, emailPath);
21
-
22
- expect(tailwindMetadata).toBeDefined();
23
- // console.log(tailwindMetadata);
24
- });
25
- });
@@ -1,45 +0,0 @@
1
- import traverse from '@babel/traverse';
2
- import type { JitContext } from 'tailwindcss/lib/lib/setupContextUtils';
3
- import type { AST } from '../../../actions/email-validation/check-compatibility';
4
- import { getTailwindConfig, type TailwindConfig } from './get-tailwind-config';
5
- import { setupTailwindContext } from './setup-tailwind-context';
6
-
7
- export const getTailwindMetadata = async (
8
- ast: AST,
9
- sourceCode: string,
10
- sourcePath: string,
11
- ): Promise<
12
- | {
13
- hasTailwind: false;
14
- }
15
- | {
16
- hasTailwind: true;
17
- config: TailwindConfig;
18
- context: JitContext;
19
- }
20
- > => {
21
- let hasTailwind = false as boolean;
22
- traverse(ast, {
23
- JSXOpeningElement(path) {
24
- if (
25
- path.node.name.type === 'JSXIdentifier' &&
26
- path.node.name.name === 'Tailwind'
27
- ) {
28
- hasTailwind = true;
29
- }
30
- },
31
- });
32
-
33
- if (!hasTailwind) {
34
- return { hasTailwind: false };
35
- }
36
-
37
- const config = await getTailwindConfig(sourceCode, ast, sourcePath);
38
- const context = setupTailwindContext(config);
39
-
40
- return {
41
- hasTailwind: true,
42
- config,
43
- context,
44
- };
45
- };
@@ -1,15 +0,0 @@
1
- import { createContext } from 'tailwindcss/lib/lib/setupContextUtils';
2
- import resolveConfig from 'tailwindcss/resolveConfig';
3
- import type { TailwindConfig } from './get-tailwind-config';
4
-
5
- export const setupTailwindContext = (config: TailwindConfig) => {
6
- return createContext(
7
- resolveConfig({
8
- ...config,
9
- content: [],
10
- corePlugins: {
11
- preflight: false,
12
- },
13
- }),
14
- );
15
- };
package/src/utils/cn.ts DELETED
@@ -1,6 +0,0 @@
1
- import { type ClassValue, clsx } from 'clsx';
2
- import { twMerge } from 'tailwind-merge';
3
-
4
- export const cn = (...inputs: ClassValue[]) => {
5
- return twMerge(clsx(inputs));
6
- };
@@ -1,6 +0,0 @@
1
- export const tabTransition = {
2
- type: 'spring',
3
- stiffness: 2000,
4
- damping: 80,
5
- mass: 1,
6
- };
@@ -1,124 +0,0 @@
1
- import {
2
- containsEmailTemplate,
3
- removeFilenameExtension,
4
- } from './contains-email-template';
5
- import type { EmailsDirectory } from './get-emails-directory-metadata';
6
-
7
- describe('removeFilenameExtension()', () => {
8
- it('should work with a single .', () => {
9
- expect(removeFilenameExtension('email-template.tsx')).toBe(
10
- 'email-template',
11
- );
12
- });
13
-
14
- it('should work with an example test file', () => {
15
- expect(removeFilenameExtension('email-template.spec.tsx')).toBe(
16
- 'email-template.spec',
17
- );
18
- });
19
-
20
- it('should do nothing when there is no extension', () => {
21
- expect(removeFilenameExtension('email-template')).toBe('email-template');
22
- });
23
- });
24
-
25
- describe('containsEmailTemplate()', () => {
26
- const directory: EmailsDirectory = {
27
- absolutePath: '/fake/path/emails',
28
- directoryName: 'emails',
29
- relativePath: '',
30
- emailFilenames: [],
31
- subDirectories: [
32
- {
33
- absolutePath: '/fake/path/emails/magic-links',
34
- directoryName: 'magic-links',
35
- relativePath: 'magic-links',
36
- emailFilenames: [
37
- 'aws-verify-email',
38
- 'linear-login-code',
39
- 'notion-magic-link',
40
- 'plaid-verify-identity',
41
- 'raycast-magic-link',
42
- 'slack-confirm',
43
- ],
44
- subDirectories: [
45
- {
46
- absolutePath: '/fake/path/emails/magic-links/resend',
47
- directoryName: 'resend',
48
- emailFilenames: ['verify-email'],
49
- relativePath: 'magic-links/resend',
50
- subDirectories: [],
51
- },
52
- ],
53
- },
54
- {
55
- absolutePath: '/fake/path/emails/newsletters',
56
- directoryName: 'newsletters',
57
- relativePath: 'newsletters',
58
- emailFilenames: [
59
- 'codepen-challengers',
60
- 'google-play-policy-update',
61
- 'stack-overflow-tips',
62
- ],
63
- subDirectories: [],
64
- },
65
- {
66
- absolutePath: '/fake/path/emails/notifications',
67
- directoryName: 'notifications',
68
- relativePath: 'notifications',
69
- emailFilenames: [
70
- 'github-access-token',
71
- 'papermark-year-in-review',
72
- 'vercel-invite-user',
73
- 'yelp-recent-login',
74
- ],
75
- subDirectories: [],
76
- },
77
- {
78
- absolutePath: '/fake/path/emails/receipts',
79
- directoryName: 'receipts',
80
- relativePath: 'receipts',
81
- emailFilenames: ['apple-receipt', 'nike-receipt'],
82
- subDirectories: [],
83
- },
84
- {
85
- absolutePath: '/fake/path/emails/reset-password',
86
- directoryName: 'reset-password',
87
- relativePath: 'reset-password',
88
- emailFilenames: ['dropbox-reset-password', 'twitch-reset-password'],
89
- subDirectories: [],
90
- },
91
- {
92
- absolutePath: '/fake/path/emails/reviews',
93
- directoryName: 'reviews',
94
- relativePath: 'reviews',
95
- emailFilenames: ['airbnb-review', 'amazon-review'],
96
- subDirectories: [],
97
- },
98
- {
99
- absolutePath: '/fake/path/emails/welcome',
100
- directoryName: 'welcome',
101
- relativePath: 'welcome',
102
- emailFilenames: ['koala-welcome', 'netlify-welcome', 'stripe-welcome'],
103
- subDirectories: [],
104
- },
105
- ],
106
- };
107
- it('should work with email inside a single sub directory', () => {
108
- expect(containsEmailTemplate('welcome/koala-welcome', directory)).toBe(
109
- true,
110
- );
111
- expect(containsEmailTemplate('welcome/missing-template', directory)).toBe(
112
- false,
113
- );
114
- });
115
-
116
- it('should work with email inside a second sub directory', () => {
117
- expect(
118
- containsEmailTemplate('magic-links/resend/verify-email', directory),
119
- ).toBe(true);
120
- expect(
121
- containsEmailTemplate('magic-links/resend/missing-template', directory),
122
- ).toBe(false);
123
- });
124
- });