@stackframe/stack-shared 2.8.22 → 2.8.27

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 (164) hide show
  1. package/CHANGELOG.md +30 -0
  2. package/dist/config/format.d.mts +20 -5
  3. package/dist/config/format.d.ts +20 -5
  4. package/dist/config/format.js +39 -14
  5. package/dist/config/format.js.map +1 -1
  6. package/dist/config/schema.d.mts +816 -294
  7. package/dist/config/schema.d.ts +816 -294
  8. package/dist/config/schema.js +471 -82
  9. package/dist/config/schema.js.map +1 -1
  10. package/dist/crud.d.mts +1 -0
  11. package/dist/crud.d.ts +1 -0
  12. package/dist/esm/config/format.js +37 -14
  13. package/dist/esm/config/format.js.map +1 -1
  14. package/dist/esm/config/schema.js +460 -78
  15. package/dist/esm/config/schema.js.map +1 -1
  16. package/dist/esm/helpers/emails.js +185 -0
  17. package/dist/esm/helpers/emails.js.map +1 -0
  18. package/dist/esm/interface/admin-interface.js +58 -36
  19. package/dist/esm/interface/admin-interface.js.map +1 -1
  20. package/dist/esm/interface/client-interface.js +41 -0
  21. package/dist/esm/interface/client-interface.js.map +1 -1
  22. package/dist/esm/interface/crud/{oauth.js → connected-accounts.js} +2 -2
  23. package/dist/esm/interface/crud/connected-accounts.js.map +1 -0
  24. package/dist/esm/interface/crud/oauth-providers.js +87 -0
  25. package/dist/esm/interface/crud/oauth-providers.js.map +1 -0
  26. package/dist/esm/interface/crud/projects.js +7 -5
  27. package/dist/esm/interface/crud/projects.js.map +1 -1
  28. package/dist/esm/interface/server-interface.js +51 -0
  29. package/dist/esm/interface/server-interface.js.map +1 -1
  30. package/dist/esm/known-errors.js +34 -1
  31. package/dist/esm/known-errors.js.map +1 -1
  32. package/dist/esm/schema-fields.js +112 -24
  33. package/dist/esm/schema-fields.js.map +1 -1
  34. package/dist/esm/utils/currencies.js +52 -0
  35. package/dist/esm/utils/currencies.js.map +1 -0
  36. package/dist/esm/utils/dates.js +55 -1
  37. package/dist/esm/utils/dates.js.map +1 -1
  38. package/dist/esm/utils/errors.js.map +1 -1
  39. package/dist/esm/utils/esbuild.js +14 -4
  40. package/dist/esm/utils/esbuild.js.map +1 -1
  41. package/dist/esm/utils/oauth.js +1 -1
  42. package/dist/esm/utils/oauth.js.map +1 -1
  43. package/dist/esm/utils/objects.js +2 -0
  44. package/dist/esm/utils/objects.js.map +1 -1
  45. package/dist/esm/utils/strings.js +4 -0
  46. package/dist/esm/utils/strings.js.map +1 -1
  47. package/dist/esm/utils/types.js +45 -0
  48. package/dist/esm/utils/types.js.map +1 -1
  49. package/dist/helpers/emails.d.mts +50 -0
  50. package/dist/helpers/emails.d.ts +50 -0
  51. package/dist/helpers/emails.js +216 -0
  52. package/dist/helpers/emails.js.map +1 -0
  53. package/dist/helpers/password.d.mts +1 -0
  54. package/dist/helpers/password.d.ts +1 -0
  55. package/dist/helpers/production-mode.d.mts +1 -0
  56. package/dist/helpers/production-mode.d.ts +1 -0
  57. package/dist/index.d.mts +3 -3
  58. package/dist/index.d.ts +3 -3
  59. package/dist/interface/admin-interface.d.mts +24 -15
  60. package/dist/interface/admin-interface.d.ts +24 -15
  61. package/dist/interface/admin-interface.js +58 -36
  62. package/dist/interface/admin-interface.js.map +1 -1
  63. package/dist/interface/client-interface.d.mts +25 -1
  64. package/dist/interface/client-interface.d.ts +25 -1
  65. package/dist/interface/client-interface.js +41 -0
  66. package/dist/interface/client-interface.js.map +1 -1
  67. package/dist/interface/crud/{oauth.d.mts → connected-accounts.d.mts} +1 -0
  68. package/dist/interface/crud/{oauth.d.ts → connected-accounts.d.ts} +1 -0
  69. package/dist/interface/crud/{oauth.js → connected-accounts.js} +5 -5
  70. package/dist/interface/crud/connected-accounts.js.map +1 -0
  71. package/dist/interface/crud/contact-channels.d.mts +1 -0
  72. package/dist/interface/crud/contact-channels.d.ts +1 -0
  73. package/dist/interface/crud/current-user.d.mts +1 -0
  74. package/dist/interface/crud/current-user.d.ts +1 -0
  75. package/dist/interface/crud/email-templates.d.mts +1 -0
  76. package/dist/interface/crud/email-templates.d.ts +1 -0
  77. package/dist/interface/crud/emails.d.mts +1 -0
  78. package/dist/interface/crud/emails.d.ts +1 -0
  79. package/dist/interface/crud/internal-api-keys.d.mts +1 -0
  80. package/dist/interface/crud/internal-api-keys.d.ts +1 -0
  81. package/dist/interface/crud/notification-preferences.d.mts +1 -0
  82. package/dist/interface/crud/notification-preferences.d.ts +1 -0
  83. package/dist/interface/crud/oauth-providers.d.mts +173 -0
  84. package/dist/interface/crud/oauth-providers.d.ts +173 -0
  85. package/dist/interface/crud/oauth-providers.js +107 -0
  86. package/dist/interface/crud/oauth-providers.js.map +1 -0
  87. package/dist/interface/crud/project-api-keys.d.mts +1 -0
  88. package/dist/interface/crud/project-api-keys.d.ts +1 -0
  89. package/dist/interface/crud/project-permissions.d.mts +1 -0
  90. package/dist/interface/crud/project-permissions.d.ts +1 -0
  91. package/dist/interface/crud/projects.d.mts +16 -12
  92. package/dist/interface/crud/projects.d.ts +16 -12
  93. package/dist/interface/crud/projects.js +5 -3
  94. package/dist/interface/crud/projects.js.map +1 -1
  95. package/dist/interface/crud/sessions.d.mts +1 -0
  96. package/dist/interface/crud/sessions.d.ts +1 -0
  97. package/dist/interface/crud/svix-token.d.mts +1 -0
  98. package/dist/interface/crud/svix-token.d.ts +1 -0
  99. package/dist/interface/crud/team-invitation-details.d.mts +1 -0
  100. package/dist/interface/crud/team-invitation-details.d.ts +1 -0
  101. package/dist/interface/crud/team-invitation.d.mts +1 -0
  102. package/dist/interface/crud/team-invitation.d.ts +1 -0
  103. package/dist/interface/crud/team-member-profiles.d.mts +1 -0
  104. package/dist/interface/crud/team-member-profiles.d.ts +1 -0
  105. package/dist/interface/crud/team-memberships.d.mts +1 -0
  106. package/dist/interface/crud/team-memberships.d.ts +1 -0
  107. package/dist/interface/crud/team-permissions.d.mts +1 -0
  108. package/dist/interface/crud/team-permissions.d.ts +1 -0
  109. package/dist/interface/crud/teams.d.mts +1 -0
  110. package/dist/interface/crud/teams.d.ts +1 -0
  111. package/dist/interface/crud/users.d.mts +1 -0
  112. package/dist/interface/crud/users.d.ts +1 -0
  113. package/dist/interface/server-interface.d.mts +46 -1
  114. package/dist/interface/server-interface.d.ts +46 -1
  115. package/dist/interface/server-interface.js +51 -0
  116. package/dist/interface/server-interface.js.map +1 -1
  117. package/dist/known-errors.d.mts +9 -0
  118. package/dist/known-errors.d.ts +9 -0
  119. package/dist/known-errors.js +34 -1
  120. package/dist/known-errors.js.map +1 -1
  121. package/dist/schema-fields.d.mts +51 -7
  122. package/dist/schema-fields.d.ts +51 -7
  123. package/dist/schema-fields.js +128 -24
  124. package/dist/schema-fields.js.map +1 -1
  125. package/dist/utils/currencies.d.mts +39 -0
  126. package/dist/utils/currencies.d.ts +39 -0
  127. package/dist/utils/currencies.js +78 -0
  128. package/dist/utils/currencies.js.map +1 -0
  129. package/dist/utils/dates.d.mts +5 -1
  130. package/dist/utils/dates.d.ts +5 -1
  131. package/dist/utils/dates.js +58 -2
  132. package/dist/utils/dates.js.map +1 -1
  133. package/dist/utils/errors.d.mts +9 -0
  134. package/dist/utils/errors.d.ts +9 -0
  135. package/dist/utils/errors.js.map +1 -1
  136. package/dist/utils/esbuild.d.mts +3 -0
  137. package/dist/utils/esbuild.d.ts +3 -0
  138. package/dist/utils/esbuild.js +14 -4
  139. package/dist/utils/esbuild.js.map +1 -1
  140. package/dist/utils/oauth.d.mts +2 -2
  141. package/dist/utils/oauth.d.ts +2 -2
  142. package/dist/utils/oauth.js +1 -1
  143. package/dist/utils/oauth.js.map +1 -1
  144. package/dist/utils/objects.d.mts +23 -8
  145. package/dist/utils/objects.d.ts +23 -8
  146. package/dist/utils/objects.js +2 -0
  147. package/dist/utils/objects.js.map +1 -1
  148. package/dist/utils/strings.d.mts +3 -1
  149. package/dist/utils/strings.d.ts +3 -1
  150. package/dist/utils/strings.js +5 -0
  151. package/dist/utils/strings.js.map +1 -1
  152. package/dist/utils/types.d.mts +73 -2
  153. package/dist/utils/types.d.ts +73 -2
  154. package/dist/utils/types.js +54 -0
  155. package/dist/utils/types.js.map +1 -1
  156. package/package.json +1 -1
  157. package/dist/esm/helpers/email-themes.js +0 -45
  158. package/dist/esm/helpers/email-themes.js.map +0 -1
  159. package/dist/esm/interface/crud/oauth.js.map +0 -1
  160. package/dist/helpers/email-themes.d.mts +0 -13
  161. package/dist/helpers/email-themes.d.ts +0 -13
  162. package/dist/helpers/email-themes.js +0 -71
  163. package/dist/helpers/email-themes.js.map +0 -1
  164. package/dist/interface/crud/oauth.js.map +0 -1
@@ -0,0 +1,50 @@
1
+ declare const previewTemplateSource: string;
2
+ declare const emptyEmailTheme: string;
3
+ declare const LightEmailTheme = "import { Html, Head, Tailwind, Body, Container } from '@react-email/components';\n\nexport function EmailTheme({ children }: { children: React.ReactNode }) {\n return (\n <Html>\n <Head />\n <Tailwind>\n <Body className=\"bg-[#fafbfb] font-sans text-base\">\n <Container className=\"bg-white p-[45px] rounded-lg\">\n {children}\n </Container>\n </Body>\n </Tailwind>\n </Html>\n );\n}";
4
+ declare const DEFAULT_EMAIL_THEME_ID = "1df07ae6-abf3-4a40-83a5-a1a2cbe336ac";
5
+ declare const DEFAULT_EMAIL_THEMES: {
6
+ "1df07ae6-abf3-4a40-83a5-a1a2cbe336ac": {
7
+ displayName: string;
8
+ tsxSource: string;
9
+ };
10
+ "a0172b5d-cff0-463b-83bb-85124697373a": {
11
+ displayName: string;
12
+ tsxSource: string;
13
+ };
14
+ };
15
+ declare const DEFAULT_EMAIL_TEMPLATES: {
16
+ "e7d009ce-8d47-4528-b245-5bf119f2ffa3": {
17
+ displayName: string;
18
+ tsxSource: string;
19
+ themeId: undefined;
20
+ };
21
+ "a70fb3a4-56c1-4e42-af25-49d25603abd0": {
22
+ displayName: string;
23
+ tsxSource: string;
24
+ themeId: undefined;
25
+ };
26
+ "822687fe-8d0a-4467-a0d1-416b6e639478": {
27
+ displayName: string;
28
+ tsxSource: string;
29
+ themeId: undefined;
30
+ };
31
+ "e84de395-2076-4831-9c19-8e9a96a868e4": {
32
+ displayName: string;
33
+ tsxSource: string;
34
+ themeId: undefined;
35
+ };
36
+ "066dd73c-36da-4fd0-b6d6-ebf87683f8bc": {
37
+ displayName: string;
38
+ tsxSource: string;
39
+ themeId: undefined;
40
+ };
41
+ };
42
+ declare const DEFAULT_TEMPLATE_IDS: {
43
+ readonly email_verification: "e7d009ce-8d47-4528-b245-5bf119f2ffa3";
44
+ readonly password_reset: "a70fb3a4-56c1-4e42-af25-49d25603abd0";
45
+ readonly magic_link: "822687fe-8d0a-4467-a0d1-416b6e639478";
46
+ readonly team_invitation: "e84de395-2076-4831-9c19-8e9a96a868e4";
47
+ readonly sign_in_invitation: "066dd73c-36da-4fd0-b6d6-ebf87683f8bc";
48
+ };
49
+
50
+ export { DEFAULT_EMAIL_TEMPLATES, DEFAULT_EMAIL_THEMES, DEFAULT_EMAIL_THEME_ID, DEFAULT_TEMPLATE_IDS, LightEmailTheme, emptyEmailTheme, previewTemplateSource };
@@ -0,0 +1,216 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/helpers/emails.ts
21
+ var emails_exports = {};
22
+ __export(emails_exports, {
23
+ DEFAULT_EMAIL_TEMPLATES: () => DEFAULT_EMAIL_TEMPLATES,
24
+ DEFAULT_EMAIL_THEMES: () => DEFAULT_EMAIL_THEMES,
25
+ DEFAULT_EMAIL_THEME_ID: () => DEFAULT_EMAIL_THEME_ID,
26
+ DEFAULT_TEMPLATE_IDS: () => DEFAULT_TEMPLATE_IDS,
27
+ LightEmailTheme: () => LightEmailTheme,
28
+ emptyEmailTheme: () => emptyEmailTheme,
29
+ previewTemplateSource: () => previewTemplateSource
30
+ });
31
+ module.exports = __toCommonJS(emails_exports);
32
+ var import_strings = require("../utils/strings.js");
33
+ var previewTemplateSource = import_strings.deindent`
34
+ import { Heading, Section, Button, Link, Column } from "@react-email/components";
35
+ export const variablesSchema = v => v;
36
+ export function EmailTemplate() {
37
+ return <>
38
+ <Heading as="h2" className="mb-4 text-2xl font-bold">
39
+ Header text
40
+ </Heading>
41
+ <Section className="mb-4">
42
+ Body text content with some additional information.
43
+ </Section>
44
+ <Row className="mb-4">
45
+ <Column>
46
+ <Button href="https://example.com">
47
+ A button
48
+ </Button>
49
+ </Column>
50
+ <Column>
51
+ <Link href="https://example.com">
52
+ A link
53
+ </Link>
54
+ </Column>
55
+ </Row>
56
+ </>;
57
+ }
58
+ `;
59
+ var emptyEmailTheme = import_strings.deindent`
60
+ import { Html, Tailwind, Body } from '@react-email/components';
61
+ export function EmailTheme({ children }: { children: React.ReactNode }) {
62
+ return (
63
+ <Html>
64
+ <Tailwind>
65
+ <Body>
66
+ {children}
67
+ </Body>
68
+ </Tailwind>
69
+ </Html>
70
+ );
71
+ }
72
+ `;
73
+ var LightEmailTheme = `import { Html, Head, Tailwind, Body, Container } from '@react-email/components';
74
+
75
+ export function EmailTheme({ children }: { children: React.ReactNode }) {
76
+ return (
77
+ <Html>
78
+ <Head />
79
+ <Tailwind>
80
+ <Body className="bg-[#fafbfb] font-sans text-base">
81
+ <Container className="bg-white p-[45px] rounded-lg">
82
+ {children}
83
+ </Container>
84
+ </Body>
85
+ </Tailwind>
86
+ </Html>
87
+ );
88
+ }`;
89
+ var DarkEmailTheme = `import { Html, Head, Tailwind, Body, Container } from '@react-email/components';
90
+
91
+ export function EmailTheme({ children }: { children: React.ReactNode }) {
92
+ return (
93
+ <Html>
94
+ <Head />
95
+ <Tailwind>
96
+ <Body className="bg-[#323232] font-sans text-white">
97
+ <Container className="bg-black p-[45px] rounded-lg">
98
+ {children}
99
+ </Container>
100
+ </Body>
101
+ </Tailwind>
102
+ </Html>
103
+ );
104
+ }`;
105
+ var DEFAULT_EMAIL_THEME_ID = "1df07ae6-abf3-4a40-83a5-a1a2cbe336ac";
106
+ var DEFAULT_EMAIL_THEMES = {
107
+ [DEFAULT_EMAIL_THEME_ID]: {
108
+ displayName: "Default Light",
109
+ tsxSource: LightEmailTheme
110
+ },
111
+ "a0172b5d-cff0-463b-83bb-85124697373a": {
112
+ displayName: "Default Dark",
113
+ tsxSource: DarkEmailTheme
114
+ }
115
+ };
116
+ var EMAIL_TEMPLATE_EMAIL_VERIFICATION_ID = "e7d009ce-8d47-4528-b245-5bf119f2ffa3";
117
+ var EMAIL_TEMPLATE_PASSWORD_RESET_ID = "a70fb3a4-56c1-4e42-af25-49d25603abd0";
118
+ var EMAIL_TEMPLATE_MAGIC_LINK_ID = "822687fe-8d0a-4467-a0d1-416b6e639478";
119
+ var EMAIL_TEMPLATE_TEAM_INVITATION_ID = "e84de395-2076-4831-9c19-8e9a96a868e4";
120
+ var EMAIL_TEMPLATE_SIGN_IN_INVITATION_ID = "066dd73c-36da-4fd0-b6d6-ebf87683f8bc";
121
+ var DEFAULT_EMAIL_TEMPLATES = {
122
+ [EMAIL_TEMPLATE_EMAIL_VERIFICATION_ID]: {
123
+ "displayName": "Email Verification",
124
+ "tsxSource": 'import { type } from "arktype"\nimport { Button, Section, Hr } from "@react-email/components";\nimport { Subject, NotificationCategory, Props } from "@stackframe/emails";\n\nexport const variablesSchema = type({\n emailVerificationLink: "string"\n})\n\nexport function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {\n return (\n <>\n <Subject value={`Verify your email at ${project.displayName}`} />\n <NotificationCategory value="Transactional" />\n <div className="bg-white text-[#242424] font-sans text-base font-normal tracking-[0.15008px] leading-[1.5] m-0 py-8 w-full min-h-full">\n <Section className="bg-white">\n <h3 className="text-black font-sans font-bold text-[20px] text-center py-4 px-6 m-0">\n Verify your email at {project.displayName}\n </h3>\n <p className="text-[#474849] font-sans font-normal text-[14px] text-center pt-2 px-6 pb-4 m-0">\n Hi{user.displayName ? (", " + user.displayName) : \'\'}! Please click on the following button to verify your email.\n </p>\n <div className="text-center py-3 px-6">\n <Button\n href={variables.emailVerificationLink}\n target="_blank"\n className="text-black font-sans font-bold text-[14px] inline-block bg-[#f0f0f0] rounded-[4px] py-3 px-5 no-underline border-0"\n >\n Verify my email\n </Button>\n </div>\n <div className="py-4 px-6">\n <Hr />\n </div>\n <p className="text-[#474849] font-sans font-normal text-[12px] text-center pt-1 px-6 pb-6 m-0">\n If you were not expecting this email, you can safely ignore it. \n </p>\n </Section>\n </div>\n </>\n )\n}\n\nEmailTemplate.PreviewVariables = {\n emailVerificationLink: "<email verification link>"\n} satisfies typeof variablesSchema.infer',
125
+ "themeId": void 0
126
+ },
127
+ [EMAIL_TEMPLATE_PASSWORD_RESET_ID]: {
128
+ "displayName": "Password Reset",
129
+ "tsxSource": 'import { type } from "arktype"\nimport { Button, Section, Hr } from "@react-email/components"\nimport { Subject, NotificationCategory, Props} from "@stackframe/emails"\n\nexport const variablesSchema = type({\n passwordResetLink: "string"\n})\n\nexport function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {\n return (\n <>\n <Subject value={"Reset your password at " + project.displayName} />\n <NotificationCategory value="Transactional" />\n <div className="bg-white text-[#242424] font-sans text-base font-normal tracking-tight leading-relaxed py-8 w-full min-h-full">\n <Section>\n <h3 className="text-black bg-transparent font-sans font-bold text-[20px] text-center py-4 px-6 m-0">\n Reset your password at {project.displayName}\n </h3>\n\n <p className="text-[#474849] bg-transparent text-sm font-sans font-normal text-center pt-2 pb-4 px-6 m-0">\n Hi{user.displayName ? (", " + user.displayName) : ""}! Please click on the following button to start the password reset process.\n </p>\n\n <div className="bg-transparent text-center px-6 py-3">\n <Button\n href={variables.passwordResetLink}\n className="text-black text-sm font-sans font-bold bg-[#f0f0f0] rounded-[4px] inline-block py-3 px-5 no-underline border-none"\n target="_blank"\n >\n Reset my password\n </Button>\n </div>\n\n <div className="px-6 py-4">\n <Hr />\n </div>\n\n <p className="text-[#474849] bg-transparent text-xs font-sans font-normal text-center pt-1 pb-6 px-6 m-0">\n If you were not expecting this email, you can safely ignore it.\n </p>\n </Section>\n </div>\n </>\n )\n}\n\nEmailTemplate.PreviewVariables = {\n passwordResetLink: "<password reset link>"\n} satisfies typeof variablesSchema.infer',
130
+ "themeId": void 0
131
+ },
132
+ [EMAIL_TEMPLATE_MAGIC_LINK_ID]: {
133
+ "displayName": "Magic Link/OTP",
134
+ "tsxSource": `import { type } from 'arktype';
135
+ import { Section, Hr } from '@react-email/components';
136
+ import { Subject, NotificationCategory, Props } from '@stackframe/emails';
137
+
138
+ export const variablesSchema = type({
139
+ magicLink: 'string',
140
+ otp: 'string',
141
+ });
142
+
143
+ export function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {
144
+ return (
145
+ <>
146
+ <Subject value={"Sign in to " + project.displayName + ": Your code is " + variables.otp} />
147
+ <NotificationCategory value="Transactional" />
148
+ <div className="bg-white text-[#242424] font-sans text-base font-normal tracking-[0.15008px] leading-6 m-0 py-8 w-full min-h-full">
149
+ <Section className="mx-auto bg-white">
150
+ <h3 className="text-black bg-transparent font-sans font-bold text-xl text-center px-6 py-4 m-0">
151
+ Sign in to {project.displayName}
152
+ </h3>
153
+ <p className="text-[#474849] bg-transparent text-sm font-sans font-normal text-center px-6 py-4 m-0">
154
+ Hi{user.displayName ? ", " + user.displayName : ""}! This is your one-time-password for signing in:
155
+ </p>
156
+ <p className="text-black bg-transparent text-2xl font-mono font-bold text-center px-6 py-4 m-0">
157
+ {variables.otp}
158
+ </p>
159
+ <p className="text-black bg-transparent text-sm font-sans font-normal text-center px-6 py-4 m-0">
160
+ Or you can click on{' '}
161
+ <a
162
+ key={20}
163
+ href={variables.magicLink}
164
+ target="_blank"
165
+ rel="noopener noreferrer"
166
+ className="text-blue-600 underline"
167
+ >
168
+ this link
169
+ </a>{' '}
170
+ to sign in
171
+ </p>
172
+ <Hr className="px-6 py-4 bg-transparent" />
173
+ <p className="text-[#474849] bg-transparent text-xs font-sans font-normal text-center px-6 pt-1 pb-6 m-0">
174
+ If you were not expecting this email, you can safely ignore it.
175
+ </p>
176
+ </Section>
177
+ </div>
178
+ </>
179
+ );
180
+ }
181
+
182
+ EmailTemplate.PreviewVariables = {
183
+ magicLink: "<magic link>",
184
+ otp: "3SLSWZ"
185
+ } satisfies typeof variablesSchema.infer`,
186
+ "themeId": void 0
187
+ },
188
+ [EMAIL_TEMPLATE_TEAM_INVITATION_ID]: {
189
+ "displayName": "Team Invitation",
190
+ "tsxSource": 'import { type } from "arktype";\nimport { Button, Section, Hr } from "@react-email/components";\nimport { Subject, NotificationCategory, Props } from "@stackframe/emails";\n\n\nexport const variablesSchema = type({\n teamDisplayName: "string",\n teamInvitationLink: "string"\n});\n\nexport function EmailTemplate({ user, variables }: Props<typeof variablesSchema.infer>) {\n return (\n <>\n <Subject value={"You have been invited to join " + variables.teamDisplayName} />\n <NotificationCategory value="Transactional" />\n <div className="bg-white text-[#242424] font-sans text-base font-normal tracking-[0.15008px] leading-[1.5] m-0 py-8 w-full min-h-full">\n <Section className="mx-auto max-w-lg bg-white">\n <h3 className="text-black bg-transparent font-sans font-bold text-xl text-center px-6 pt-8 m-0">\n You are invited to {variables.teamDisplayName}\n </h3>\n <p className="text-[#474849] bg-transparent text-sm font-sans font-normal text-center px-6 pt-2 pb-4 m-0">\n Hi{user.displayName ? ", " + user.displayName : ""}! Please click the button below to join the team {variables.teamDisplayName}\n </p>\n <div className="bg-transparent text-center px-6 py-3">\n <Button\n href={variables.teamInvitationLink}\n target="_blank"\n className="text-black text-sm font-sans font-bold bg-[#f0f0f0] rounded-md inline-block px-5 py-3 no-underline border-0"\n >\n Join team\n </Button>\n </div>\n <div className="px-6 py-4 bg-transparent">\n <Hr />\n </div>\n <p className="text-[#474849] bg-transparent text-xs font-sans font-normal text-center px-6 pb-6 pt-1 m-0">\n If you were not expecting this email, you can safely ignore it.\n </p>\n </Section>\n </div>\n </>\n );\n}\n\nEmailTemplate.PreviewVariables = {\n teamDisplayName: "My Team",\n teamInvitationLink: "<team invitation link>"\n} satisfies typeof variablesSchema.infer ',
191
+ "themeId": void 0
192
+ },
193
+ [EMAIL_TEMPLATE_SIGN_IN_INVITATION_ID]: {
194
+ "displayName": "Sign In Invitation",
195
+ "tsxSource": 'import { type } from "arktype"\nimport { Button, Section, Hr } from "@react-email/components";\nimport { Subject, NotificationCategory, Props } from "@stackframe/emails";\n\nexport const variablesSchema = type({\n signInInvitationLink: "string",\n teamDisplayName: "string"\n})\n\nexport function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {\n return (\n <>\n <Subject\n value={"You have been invited to sign in to " + project.displayName}\n />\n <NotificationCategory value="Transactional" />\n\n <div className="bg-white text-gray-900 font-sans text-base font-normal leading-normal w-full min-h-full m-0 py-8">\n <Section>\n <h3 className="text-black bg-transparent font-sans font-bold text-xl text-center pt-8 px-6 m-0">\n You are invited to sign in to {variables.teamDisplayName}\n </h3>\n\n <p className="text-gray-700 bg-transparent text-sm font-sans font-normal text-center pt-2 pb-4 px-6 m-0">\n Hi\n {user.displayName ? ", " + user.displayName : ""}! Please click on the following\n link to sign in to your account\n </p>\n\n <div className="bg-transparent text-center px-6 py-3">\n <Button\n href={variables.signInInvitationLink}\n className="text-black text-sm font-sans font-bold bg-gray-200 rounded-md inline-block py-3 px-5 no-underline border-none"\n target="_blank"\n >\n Sign in\n </Button>\n </div>\n\n <div className="px-6 py-4 bg-transparent">\n <Hr />\n </div>\n\n <p className="text-gray-700 bg-transparent text-xs font-sans font-normal text-center pt-1 pb-6 px-6 m-0">\n If you were not expecting this email, you can safely ignore it.\n </p>\n </Section>\n </div>\n </>\n )\n}\n\nEmailTemplate.PreviewVariables = {\n signInInvitationLink: "<sign in invitation link>",\n teamDisplayName: "My Team"\n} satisfies typeof variablesSchema.infer',
196
+ "themeId": void 0
197
+ }
198
+ };
199
+ var DEFAULT_TEMPLATE_IDS = {
200
+ email_verification: EMAIL_TEMPLATE_EMAIL_VERIFICATION_ID,
201
+ password_reset: EMAIL_TEMPLATE_PASSWORD_RESET_ID,
202
+ magic_link: EMAIL_TEMPLATE_MAGIC_LINK_ID,
203
+ team_invitation: EMAIL_TEMPLATE_TEAM_INVITATION_ID,
204
+ sign_in_invitation: EMAIL_TEMPLATE_SIGN_IN_INVITATION_ID
205
+ };
206
+ // Annotate the CommonJS export names for ESM import in node:
207
+ 0 && (module.exports = {
208
+ DEFAULT_EMAIL_TEMPLATES,
209
+ DEFAULT_EMAIL_THEMES,
210
+ DEFAULT_EMAIL_THEME_ID,
211
+ DEFAULT_TEMPLATE_IDS,
212
+ LightEmailTheme,
213
+ emptyEmailTheme,
214
+ previewTemplateSource
215
+ });
216
+ //# sourceMappingURL=emails.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/helpers/emails.ts"],"sourcesContent":["import { deindent } from \"../utils/strings\";\n\nexport const previewTemplateSource = deindent`\n import { Heading, Section, Button, Link, Column } from \"@react-email/components\";\n export const variablesSchema = v => v;\n export function EmailTemplate() {\n return <>\n <Heading as=\"h2\" className=\"mb-4 text-2xl font-bold\">\n Header text\n </Heading>\n <Section className=\"mb-4\">\n Body text content with some additional information.\n </Section>\n <Row className=\"mb-4\">\n <Column>\n <Button href=\"https://example.com\">\n A button\n </Button>\n </Column>\n <Column>\n <Link href=\"https://example.com\">\n A link\n </Link>\n </Column>\n </Row>\n </>;\n }\n`;\n\nexport const emptyEmailTheme = deindent`\n import { Html, Tailwind, Body } from '@react-email/components';\n export function EmailTheme({ children }: { children: React.ReactNode }) {\n return (\n <Html>\n <Tailwind>\n <Body>\n {children}\n </Body>\n </Tailwind>\n </Html>\n );\n }\n`;\n\nexport const LightEmailTheme = `import { Html, Head, Tailwind, Body, Container } from '@react-email/components';\n\nexport function EmailTheme({ children }: { children: React.ReactNode }) {\n return (\n <Html>\n <Head />\n <Tailwind>\n <Body className=\"bg-[#fafbfb] font-sans text-base\">\n <Container className=\"bg-white p-[45px] rounded-lg\">\n {children}\n </Container>\n </Body>\n </Tailwind>\n </Html>\n );\n}`;\n\n\nconst DarkEmailTheme = `import { Html, Head, Tailwind, Body, Container } from '@react-email/components';\n\nexport function EmailTheme({ children }: { children: React.ReactNode }) {\n return (\n <Html>\n <Head />\n <Tailwind>\n <Body className=\"bg-[#323232] font-sans text-white\">\n <Container className=\"bg-black p-[45px] rounded-lg\">\n {children}\n </Container>\n </Body>\n </Tailwind>\n </Html>\n );\n}`;\n\n\nexport const DEFAULT_EMAIL_THEME_ID = \"1df07ae6-abf3-4a40-83a5-a1a2cbe336ac\";\n\nexport const DEFAULT_EMAIL_THEMES = {\n [DEFAULT_EMAIL_THEME_ID]: {\n displayName: 'Default Light',\n tsxSource: LightEmailTheme,\n },\n \"a0172b5d-cff0-463b-83bb-85124697373a\": {\n displayName: 'Default Dark',\n tsxSource: DarkEmailTheme,\n },\n};\n\nconst EMAIL_TEMPLATE_EMAIL_VERIFICATION_ID = \"e7d009ce-8d47-4528-b245-5bf119f2ffa3\";\nconst EMAIL_TEMPLATE_PASSWORD_RESET_ID = \"a70fb3a4-56c1-4e42-af25-49d25603abd0\";\nconst EMAIL_TEMPLATE_MAGIC_LINK_ID = \"822687fe-8d0a-4467-a0d1-416b6e639478\";\nconst EMAIL_TEMPLATE_TEAM_INVITATION_ID = \"e84de395-2076-4831-9c19-8e9a96a868e4\";\nconst EMAIL_TEMPLATE_SIGN_IN_INVITATION_ID = \"066dd73c-36da-4fd0-b6d6-ebf87683f8bc\";\n\nexport const DEFAULT_EMAIL_TEMPLATES = {\n [EMAIL_TEMPLATE_EMAIL_VERIFICATION_ID]: {\n \"displayName\": \"Email Verification\",\n \"tsxSource\": \"import { type } from \\\"arktype\\\"\\nimport { Button, Section, Hr } from \\\"@react-email/components\\\";\\nimport { Subject, NotificationCategory, Props } from \\\"@stackframe/emails\\\";\\n\\nexport const variablesSchema = type({\\n emailVerificationLink: \\\"string\\\"\\n})\\n\\nexport function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {\\n return (\\n <>\\n <Subject value={`Verify your email at ${project.displayName}`} />\\n <NotificationCategory value=\\\"Transactional\\\" />\\n <div className=\\\"bg-white text-[#242424] font-sans text-base font-normal tracking-[0.15008px] leading-[1.5] m-0 py-8 w-full min-h-full\\\">\\n <Section className=\\\"bg-white\\\">\\n <h3 className=\\\"text-black font-sans font-bold text-[20px] text-center py-4 px-6 m-0\\\">\\n Verify your email at {project.displayName}\\n </h3>\\n <p className=\\\"text-[#474849] font-sans font-normal text-[14px] text-center pt-2 px-6 pb-4 m-0\\\">\\n Hi{user.displayName ? (\\\", \\\" + user.displayName) : ''}! Please click on the following button to verify your email.\\n </p>\\n <div className=\\\"text-center py-3 px-6\\\">\\n <Button\\n href={variables.emailVerificationLink}\\n target=\\\"_blank\\\"\\n className=\\\"text-black font-sans font-bold text-[14px] inline-block bg-[#f0f0f0] rounded-[4px] py-3 px-5 no-underline border-0\\\"\\n >\\n Verify my email\\n </Button>\\n </div>\\n <div className=\\\"py-4 px-6\\\">\\n <Hr />\\n </div>\\n <p className=\\\"text-[#474849] font-sans font-normal text-[12px] text-center pt-1 px-6 pb-6 m-0\\\">\\n If you were not expecting this email, you can safely ignore it. \\n </p>\\n </Section>\\n </div>\\n </>\\n )\\n}\\n\\nEmailTemplate.PreviewVariables = {\\n emailVerificationLink: \\\"<email verification link>\\\"\\n} satisfies typeof variablesSchema.infer\",\n \"themeId\": undefined,\n },\n [EMAIL_TEMPLATE_PASSWORD_RESET_ID]: {\n \"displayName\": \"Password Reset\",\n \"tsxSource\": \"import { type } from \\\"arktype\\\"\\nimport { Button, Section, Hr } from \\\"@react-email/components\\\"\\nimport { Subject, NotificationCategory, Props} from \\\"@stackframe/emails\\\"\\n\\nexport const variablesSchema = type({\\n passwordResetLink: \\\"string\\\"\\n})\\n\\nexport function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {\\n return (\\n <>\\n <Subject value={\\\"Reset your password at \\\" + project.displayName} />\\n <NotificationCategory value=\\\"Transactional\\\" />\\n <div className=\\\"bg-white text-[#242424] font-sans text-base font-normal tracking-tight leading-relaxed py-8 w-full min-h-full\\\">\\n <Section>\\n <h3 className=\\\"text-black bg-transparent font-sans font-bold text-[20px] text-center py-4 px-6 m-0\\\">\\n Reset your password at {project.displayName}\\n </h3>\\n\\n <p className=\\\"text-[#474849] bg-transparent text-sm font-sans font-normal text-center pt-2 pb-4 px-6 m-0\\\">\\n Hi{user.displayName ? (\\\", \\\" + user.displayName) : \\\"\\\"}! Please click on the following button to start the password reset process.\\n </p>\\n\\n <div className=\\\"bg-transparent text-center px-6 py-3\\\">\\n <Button\\n href={variables.passwordResetLink}\\n className=\\\"text-black text-sm font-sans font-bold bg-[#f0f0f0] rounded-[4px] inline-block py-3 px-5 no-underline border-none\\\"\\n target=\\\"_blank\\\"\\n >\\n Reset my password\\n </Button>\\n </div>\\n\\n <div className=\\\"px-6 py-4\\\">\\n <Hr />\\n </div>\\n\\n <p className=\\\"text-[#474849] bg-transparent text-xs font-sans font-normal text-center pt-1 pb-6 px-6 m-0\\\">\\n If you were not expecting this email, you can safely ignore it.\\n </p>\\n </Section>\\n </div>\\n </>\\n )\\n}\\n\\nEmailTemplate.PreviewVariables = {\\n passwordResetLink: \\\"<password reset link>\\\"\\n} satisfies typeof variablesSchema.infer\",\n \"themeId\": undefined,\n },\n [EMAIL_TEMPLATE_MAGIC_LINK_ID]: {\n \"displayName\": \"Magic Link/OTP\",\n \"tsxSource\": \"import { type } from 'arktype';\\nimport { Section, Hr } from '@react-email/components';\\nimport { Subject, NotificationCategory, Props } from '@stackframe/emails';\\n\\nexport const variablesSchema = type({\\n magicLink: 'string',\\n otp: 'string',\\n});\\n\\nexport function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {\\n return (\\n <>\\n <Subject value={\\\"Sign in to \\\" + project.displayName + \\\": Your code is \\\" + variables.otp} />\\n <NotificationCategory value=\\\"Transactional\\\" />\\n <div className=\\\"bg-white text-[#242424] font-sans text-base font-normal tracking-[0.15008px] leading-6 m-0 py-8 w-full min-h-full\\\">\\n <Section className=\\\"mx-auto bg-white\\\">\\n <h3 className=\\\"text-black bg-transparent font-sans font-bold text-xl text-center px-6 py-4 m-0\\\">\\n Sign in to {project.displayName}\\n </h3>\\n <p className=\\\"text-[#474849] bg-transparent text-sm font-sans font-normal text-center px-6 py-4 m-0\\\">\\n Hi{user.displayName ? \\\", \\\" + user.displayName : \\\"\\\"}! This is your one-time-password for signing in:\\n </p>\\n <p className=\\\"text-black bg-transparent text-2xl font-mono font-bold text-center px-6 py-4 m-0\\\">\\n {variables.otp}\\n </p>\\n <p className=\\\"text-black bg-transparent text-sm font-sans font-normal text-center px-6 py-4 m-0\\\">\\n Or you can click on{' '}\\n <a\\n key={20}\\n href={variables.magicLink}\\n target=\\\"_blank\\\"\\n rel=\\\"noopener noreferrer\\\"\\n className=\\\"text-blue-600 underline\\\"\\n >\\n this link\\n </a>{' '}\\n to sign in\\n </p>\\n <Hr className=\\\"px-6 py-4 bg-transparent\\\" />\\n <p className=\\\"text-[#474849] bg-transparent text-xs font-sans font-normal text-center px-6 pt-1 pb-6 m-0\\\">\\n If you were not expecting this email, you can safely ignore it.\\n </p>\\n </Section>\\n </div>\\n </>\\n );\\n}\\n\\nEmailTemplate.PreviewVariables = {\\n magicLink: \\\"<magic link>\\\",\\n otp: \\\"3SLSWZ\\\"\\n} satisfies typeof variablesSchema.infer\",\n \"themeId\": undefined,\n },\n [EMAIL_TEMPLATE_TEAM_INVITATION_ID]: {\n \"displayName\": \"Team Invitation\",\n \"tsxSource\": \"import { type } from \\\"arktype\\\";\\nimport { Button, Section, Hr } from \\\"@react-email/components\\\";\\nimport { Subject, NotificationCategory, Props } from \\\"@stackframe/emails\\\";\\n\\n\\nexport const variablesSchema = type({\\n teamDisplayName: \\\"string\\\",\\n teamInvitationLink: \\\"string\\\"\\n});\\n\\nexport function EmailTemplate({ user, variables }: Props<typeof variablesSchema.infer>) {\\n return (\\n <>\\n <Subject value={\\\"You have been invited to join \\\" + variables.teamDisplayName} />\\n <NotificationCategory value=\\\"Transactional\\\" />\\n <div className=\\\"bg-white text-[#242424] font-sans text-base font-normal tracking-[0.15008px] leading-[1.5] m-0 py-8 w-full min-h-full\\\">\\n <Section className=\\\"mx-auto max-w-lg bg-white\\\">\\n <h3 className=\\\"text-black bg-transparent font-sans font-bold text-xl text-center px-6 pt-8 m-0\\\">\\n You are invited to {variables.teamDisplayName}\\n </h3>\\n <p className=\\\"text-[#474849] bg-transparent text-sm font-sans font-normal text-center px-6 pt-2 pb-4 m-0\\\">\\n Hi{user.displayName ? \\\", \\\" + user.displayName : \\\"\\\"}! Please click the button below to join the team {variables.teamDisplayName}\\n </p>\\n <div className=\\\"bg-transparent text-center px-6 py-3\\\">\\n <Button\\n href={variables.teamInvitationLink}\\n target=\\\"_blank\\\"\\n className=\\\"text-black text-sm font-sans font-bold bg-[#f0f0f0] rounded-md inline-block px-5 py-3 no-underline border-0\\\"\\n >\\n Join team\\n </Button>\\n </div>\\n <div className=\\\"px-6 py-4 bg-transparent\\\">\\n <Hr />\\n </div>\\n <p className=\\\"text-[#474849] bg-transparent text-xs font-sans font-normal text-center px-6 pb-6 pt-1 m-0\\\">\\n If you were not expecting this email, you can safely ignore it.\\n </p>\\n </Section>\\n </div>\\n </>\\n );\\n}\\n\\nEmailTemplate.PreviewVariables = {\\n teamDisplayName: \\\"My Team\\\",\\n teamInvitationLink: \\\"<team invitation link>\\\"\\n} satisfies typeof variablesSchema.infer \",\n \"themeId\": undefined,\n },\n [EMAIL_TEMPLATE_SIGN_IN_INVITATION_ID]: {\n \"displayName\": \"Sign In Invitation\",\n \"tsxSource\": \"import { type } from \\\"arktype\\\"\\nimport { Button, Section, Hr } from \\\"@react-email/components\\\";\\nimport { Subject, NotificationCategory, Props } from \\\"@stackframe/emails\\\";\\n\\nexport const variablesSchema = type({\\n signInInvitationLink: \\\"string\\\",\\n teamDisplayName: \\\"string\\\"\\n})\\n\\nexport function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {\\n return (\\n <>\\n <Subject\\n value={\\\"You have been invited to sign in to \\\" + project.displayName}\\n />\\n <NotificationCategory value=\\\"Transactional\\\" />\\n\\n <div className=\\\"bg-white text-gray-900 font-sans text-base font-normal leading-normal w-full min-h-full m-0 py-8\\\">\\n <Section>\\n <h3 className=\\\"text-black bg-transparent font-sans font-bold text-xl text-center pt-8 px-6 m-0\\\">\\n You are invited to sign in to {variables.teamDisplayName}\\n </h3>\\n\\n <p className=\\\"text-gray-700 bg-transparent text-sm font-sans font-normal text-center pt-2 pb-4 px-6 m-0\\\">\\n Hi\\n {user.displayName ? \\\", \\\" + user.displayName : \\\"\\\"}! Please click on the following\\n link to sign in to your account\\n </p>\\n\\n <div className=\\\"bg-transparent text-center px-6 py-3\\\">\\n <Button\\n href={variables.signInInvitationLink}\\n className=\\\"text-black text-sm font-sans font-bold bg-gray-200 rounded-md inline-block py-3 px-5 no-underline border-none\\\"\\n target=\\\"_blank\\\"\\n >\\n Sign in\\n </Button>\\n </div>\\n\\n <div className=\\\"px-6 py-4 bg-transparent\\\">\\n <Hr />\\n </div>\\n\\n <p className=\\\"text-gray-700 bg-transparent text-xs font-sans font-normal text-center pt-1 pb-6 px-6 m-0\\\">\\n If you were not expecting this email, you can safely ignore it.\\n </p>\\n </Section>\\n </div>\\n </>\\n )\\n}\\n\\nEmailTemplate.PreviewVariables = {\\n signInInvitationLink: \\\"<sign in invitation link>\\\",\\n teamDisplayName: \\\"My Team\\\"\\n} satisfies typeof variablesSchema.infer\",\n \"themeId\": undefined,\n }\n};\n\nexport const DEFAULT_TEMPLATE_IDS = {\n email_verification: EMAIL_TEMPLATE_EMAIL_VERIFICATION_ID,\n password_reset: EMAIL_TEMPLATE_PASSWORD_RESET_ID,\n magic_link: EMAIL_TEMPLATE_MAGIC_LINK_ID,\n team_invitation: EMAIL_TEMPLATE_TEAM_INVITATION_ID,\n sign_in_invitation: EMAIL_TEMPLATE_SIGN_IN_INVITATION_ID,\n} as const;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qBAAyB;AAElB,IAAM,wBAAwB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA2B9B,IAAM,kBAAkB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAexB,IAAM,kBAAkB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAkB/B,IAAM,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAkBhB,IAAM,yBAAyB;AAE/B,IAAM,uBAAuB;AAAA,EAClC,CAAC,sBAAsB,GAAG;AAAA,IACxB,aAAa;AAAA,IACb,WAAW;AAAA,EACb;AAAA,EACA,wCAAwC;AAAA,IACtC,aAAa;AAAA,IACb,WAAW;AAAA,EACb;AACF;AAEA,IAAM,uCAAuC;AAC7C,IAAM,mCAAmC;AACzC,IAAM,+BAA+B;AACrC,IAAM,oCAAoC;AAC1C,IAAM,uCAAuC;AAEtC,IAAM,0BAA0B;AAAA,EACrC,CAAC,oCAAoC,GAAG;AAAA,IACtC,eAAe;AAAA,IACf,aAAa;AAAA,IACb,WAAW;AAAA,EACb;AAAA,EACA,CAAC,gCAAgC,GAAG;AAAA,IAClC,eAAe;AAAA,IACf,aAAa;AAAA,IACb,WAAW;AAAA,EACb;AAAA,EACA,CAAC,4BAA4B,GAAG;AAAA,IAC9B,eAAe;AAAA,IACf,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IACb,WAAW;AAAA,EACb;AAAA,EACA,CAAC,iCAAiC,GAAG;AAAA,IACnC,eAAe;AAAA,IACf,aAAa;AAAA,IACb,WAAW;AAAA,EACb;AAAA,EACA,CAAC,oCAAoC,GAAG;AAAA,IACtC,eAAe;AAAA,IACf,aAAa;AAAA,IACb,WAAW;AAAA,EACb;AACF;AAEO,IAAM,uBAAuB;AAAA,EAClC,oBAAoB;AAAA,EACpB,gBAAgB;AAAA,EAChB,YAAY;AAAA,EACZ,iBAAiB;AAAA,EACjB,oBAAoB;AACtB;","names":[]}
@@ -2,6 +2,7 @@ import '../crud.mjs';
2
2
  import { KnownErrors } from '../known-errors.mjs';
3
3
  import 'yup';
4
4
  import '../utils/types.mjs';
5
+ import '../utils/strings.mjs';
5
6
  import '../utils/errors.mjs';
6
7
  import '../utils/json.mjs';
7
8
  import '../utils/results.mjs';
@@ -2,6 +2,7 @@ import '../crud.js';
2
2
  import { KnownErrors } from '../known-errors.js';
3
3
  import 'yup';
4
4
  import '../utils/types.js';
5
+ import '../utils/strings.js';
5
6
  import '../utils/errors.js';
6
7
  import '../utils/json.js';
7
8
  import '../utils/results.js';
@@ -2,6 +2,7 @@ import { ProjectsCrud } from '../interface/crud/projects.mjs';
2
2
  import '../crud.mjs';
3
3
  import 'yup';
4
4
  import '../utils/types.mjs';
5
+ import '../utils/strings.mjs';
5
6
 
6
7
  type ProductionModeError = {
7
8
  message: string;
@@ -2,6 +2,7 @@ import { ProjectsCrud } from '../interface/crud/projects.js';
2
2
  import '../crud.js';
3
3
  import 'yup';
4
4
  import '../utils/types.js';
5
+ import '../utils/strings.js';
5
6
 
6
7
  type ProductionModeError = {
7
8
  message: string;
package/dist/index.d.mts CHANGED
@@ -4,21 +4,21 @@ export { StackServerInterface } from './interface/server-interface.mjs';
4
4
  export { KnownError, KnownErrors } from './known-errors.mjs';
5
5
  import './sessions.mjs';
6
6
  import 'jose';
7
- import './interface/crud/email-templates.mjs';
7
+ import './interface/crud/emails.mjs';
8
8
  import './crud.mjs';
9
9
  import 'yup';
10
10
  import './utils/types.mjs';
11
- import './interface/crud/emails.mjs';
11
+ import './utils/strings.mjs';
12
12
  import './interface/crud/internal-api-keys.mjs';
13
13
  import './interface/crud/project-permissions.mjs';
14
14
  import './interface/crud/projects.mjs';
15
15
  import './interface/crud/svix-token.mjs';
16
16
  import './interface/crud/team-permissions.mjs';
17
17
  import './utils/results.mjs';
18
+ import './interface/crud/connected-accounts.mjs';
18
19
  import './interface/crud/contact-channels.mjs';
19
20
  import './interface/crud/current-user.mjs';
20
21
  import './interface/crud/notification-preferences.mjs';
21
- import './interface/crud/oauth.mjs';
22
22
  import './interface/crud/sessions.mjs';
23
23
  import './interface/crud/team-invitation.mjs';
24
24
  import './interface/crud/team-member-profiles.mjs';
package/dist/index.d.ts CHANGED
@@ -4,21 +4,21 @@ export { StackServerInterface } from './interface/server-interface.js';
4
4
  export { KnownError, KnownErrors } from './known-errors.js';
5
5
  import './sessions.js';
6
6
  import 'jose';
7
- import './interface/crud/email-templates.js';
7
+ import './interface/crud/emails.js';
8
8
  import './crud.js';
9
9
  import 'yup';
10
10
  import './utils/types.js';
11
- import './interface/crud/emails.js';
11
+ import './utils/strings.js';
12
12
  import './interface/crud/internal-api-keys.js';
13
13
  import './interface/crud/project-permissions.js';
14
14
  import './interface/crud/projects.js';
15
15
  import './interface/crud/svix-token.js';
16
16
  import './interface/crud/team-permissions.js';
17
17
  import './utils/results.js';
18
+ import './interface/crud/connected-accounts.js';
18
19
  import './interface/crud/contact-channels.js';
19
20
  import './interface/crud/current-user.js';
20
21
  import './interface/crud/notification-preferences.js';
21
- import './interface/crud/oauth.js';
22
22
  import './interface/crud/sessions.js';
23
23
  import './interface/crud/team-invitation.js';
24
24
  import './interface/crud/team-member-profiles.js';
@@ -1,5 +1,4 @@
1
1
  import { InternalSession, AccessToken, RefreshToken } from '../sessions.mjs';
2
- import { EmailTemplateCrud, EmailTemplateType } from './crud/email-templates.mjs';
3
2
  import { InternalEmailsCrud } from './crud/emails.mjs';
4
3
  import { InternalApiKeysCrud } from './crud/internal-api-keys.mjs';
5
4
  import { ProjectPermissionDefinitionsCrud } from './crud/project-permissions.mjs';
@@ -13,11 +12,12 @@ import 'jose';
13
12
  import '../crud.mjs';
14
13
  import 'yup';
15
14
  import '../utils/types.mjs';
15
+ import '../utils/strings.mjs';
16
16
  import '../utils/results.mjs';
17
+ import './crud/connected-accounts.mjs';
17
18
  import './crud/contact-channels.mjs';
18
19
  import './crud/current-user.mjs';
19
20
  import './crud/notification-preferences.mjs';
20
- import './crud/oauth.mjs';
21
21
  import './crud/sessions.mjs';
22
22
  import './crud/team-invitation.mjs';
23
23
  import './crud/team-member-profiles.mjs';
@@ -72,13 +72,16 @@ declare class StackAdminInterface extends StackServerInterface {
72
72
  listInternalApiKeys(): Promise<InternalApiKeysCrud["Admin"]["Read"][]>;
73
73
  revokeInternalApiKeyById(id: string): Promise<void>;
74
74
  getInternalApiKey(id: string, session: InternalSession): Promise<InternalApiKeysCrud["Admin"]["Read"]>;
75
- listEmailTemplates(): Promise<EmailTemplateCrud['Admin']['Read'][]>;
75
+ listInternalEmailTemplates(): Promise<{
76
+ id: string;
77
+ display_name: string;
78
+ theme_id?: string;
79
+ tsx_source: string;
80
+ }[]>;
76
81
  listEmailThemes(): Promise<{
77
82
  id: string;
78
83
  display_name: string;
79
84
  }[]>;
80
- updateEmailTemplate(type: EmailTemplateType, data: EmailTemplateCrud['Admin']['Update']): Promise<EmailTemplateCrud['Admin']['Read']>;
81
- resetEmailTemplate(type: EmailTemplateType): Promise<void>;
82
85
  listTeamPermissionDefinitions(): Promise<TeamPermissionDefinitionsCrud['Admin']['Read'][]>;
83
86
  createTeamPermissionDefinition(data: TeamPermissionDefinitionsCrud['Admin']['Create']): Promise<TeamPermissionDefinitionsCrud['Admin']['Read']>;
84
87
  updateTeamPermissionDefinition(permissionId: string, data: TeamPermissionDefinitionsCrud['Admin']['Update']): Promise<TeamPermissionDefinitionsCrud['Admin']['Read']>;
@@ -112,19 +115,22 @@ declare class StackAdminInterface extends StackServerInterface {
112
115
  notification_category_name: string;
113
116
  }): Promise<void>;
114
117
  sendSignInInvitationEmail(email: string, callbackUrl: string): Promise<void>;
115
- sendEmailThemeChatMessage(themeId: string, currentEmailTheme: string, messages: Array<{
118
+ sendChatMessage(threadId: string, contextType: "email-theme" | "email-template", messages: Array<{
116
119
  role: string;
117
- content: string;
120
+ content: any;
118
121
  }>, abortSignal?: AbortSignal): Promise<{
119
122
  content: ChatContent;
120
123
  }>;
121
- listEmailThemeChatMessages(themeId: string): Promise<{
122
- messages: Array<{
123
- role: string;
124
- content: ChatContent;
125
- }>;
124
+ saveChatMessage(threadId: string, message: any): Promise<void>;
125
+ listChatMessages(threadId: string): Promise<{
126
+ messages: Array<any>;
126
127
  }>;
127
- renderEmailThemePreview(themeId: string, content: string): Promise<{
128
+ renderEmailPreview(options: {
129
+ themeId?: string | null | false;
130
+ themeTsxSource?: string;
131
+ templateId?: string;
132
+ templateTsxSource?: string;
133
+ }): Promise<{
128
134
  html: string;
129
135
  }>;
130
136
  createEmailTheme(displayName: string): Promise<{
@@ -134,10 +140,13 @@ declare class StackAdminInterface extends StackServerInterface {
134
140
  display_name: string;
135
141
  tsx_source: string;
136
142
  }>;
137
- updateEmailTheme(id: string, tsxSource: string, previewHtml: string): Promise<{
138
- display_name: string;
143
+ updateEmailTheme(id: string, tsxSource: string): Promise<void>;
144
+ updateEmailTemplate(id: string, tsxSource: string, themeId: string | null | false): Promise<{
139
145
  rendered_html: string;
140
146
  }>;
147
+ createEmailTemplate(displayName: string): Promise<{
148
+ id: string;
149
+ }>;
141
150
  }
142
151
 
143
152
  export { type AdminAuthApplicationOptions, type ChatContent, type InternalApiKeyCreateCrudRequest, type InternalApiKeyCreateCrudResponse, StackAdminInterface };
@@ -1,5 +1,4 @@
1
1
  import { InternalSession, AccessToken, RefreshToken } from '../sessions.js';
2
- import { EmailTemplateCrud, EmailTemplateType } from './crud/email-templates.js';
3
2
  import { InternalEmailsCrud } from './crud/emails.js';
4
3
  import { InternalApiKeysCrud } from './crud/internal-api-keys.js';
5
4
  import { ProjectPermissionDefinitionsCrud } from './crud/project-permissions.js';
@@ -13,11 +12,12 @@ import 'jose';
13
12
  import '../crud.js';
14
13
  import 'yup';
15
14
  import '../utils/types.js';
15
+ import '../utils/strings.js';
16
16
  import '../utils/results.js';
17
+ import './crud/connected-accounts.js';
17
18
  import './crud/contact-channels.js';
18
19
  import './crud/current-user.js';
19
20
  import './crud/notification-preferences.js';
20
- import './crud/oauth.js';
21
21
  import './crud/sessions.js';
22
22
  import './crud/team-invitation.js';
23
23
  import './crud/team-member-profiles.js';
@@ -72,13 +72,16 @@ declare class StackAdminInterface extends StackServerInterface {
72
72
  listInternalApiKeys(): Promise<InternalApiKeysCrud["Admin"]["Read"][]>;
73
73
  revokeInternalApiKeyById(id: string): Promise<void>;
74
74
  getInternalApiKey(id: string, session: InternalSession): Promise<InternalApiKeysCrud["Admin"]["Read"]>;
75
- listEmailTemplates(): Promise<EmailTemplateCrud['Admin']['Read'][]>;
75
+ listInternalEmailTemplates(): Promise<{
76
+ id: string;
77
+ display_name: string;
78
+ theme_id?: string;
79
+ tsx_source: string;
80
+ }[]>;
76
81
  listEmailThemes(): Promise<{
77
82
  id: string;
78
83
  display_name: string;
79
84
  }[]>;
80
- updateEmailTemplate(type: EmailTemplateType, data: EmailTemplateCrud['Admin']['Update']): Promise<EmailTemplateCrud['Admin']['Read']>;
81
- resetEmailTemplate(type: EmailTemplateType): Promise<void>;
82
85
  listTeamPermissionDefinitions(): Promise<TeamPermissionDefinitionsCrud['Admin']['Read'][]>;
83
86
  createTeamPermissionDefinition(data: TeamPermissionDefinitionsCrud['Admin']['Create']): Promise<TeamPermissionDefinitionsCrud['Admin']['Read']>;
84
87
  updateTeamPermissionDefinition(permissionId: string, data: TeamPermissionDefinitionsCrud['Admin']['Update']): Promise<TeamPermissionDefinitionsCrud['Admin']['Read']>;
@@ -112,19 +115,22 @@ declare class StackAdminInterface extends StackServerInterface {
112
115
  notification_category_name: string;
113
116
  }): Promise<void>;
114
117
  sendSignInInvitationEmail(email: string, callbackUrl: string): Promise<void>;
115
- sendEmailThemeChatMessage(themeId: string, currentEmailTheme: string, messages: Array<{
118
+ sendChatMessage(threadId: string, contextType: "email-theme" | "email-template", messages: Array<{
116
119
  role: string;
117
- content: string;
120
+ content: any;
118
121
  }>, abortSignal?: AbortSignal): Promise<{
119
122
  content: ChatContent;
120
123
  }>;
121
- listEmailThemeChatMessages(themeId: string): Promise<{
122
- messages: Array<{
123
- role: string;
124
- content: ChatContent;
125
- }>;
124
+ saveChatMessage(threadId: string, message: any): Promise<void>;
125
+ listChatMessages(threadId: string): Promise<{
126
+ messages: Array<any>;
126
127
  }>;
127
- renderEmailThemePreview(themeId: string, content: string): Promise<{
128
+ renderEmailPreview(options: {
129
+ themeId?: string | null | false;
130
+ themeTsxSource?: string;
131
+ templateId?: string;
132
+ templateTsxSource?: string;
133
+ }): Promise<{
128
134
  html: string;
129
135
  }>;
130
136
  createEmailTheme(displayName: string): Promise<{
@@ -134,10 +140,13 @@ declare class StackAdminInterface extends StackServerInterface {
134
140
  display_name: string;
135
141
  tsx_source: string;
136
142
  }>;
137
- updateEmailTheme(id: string, tsxSource: string, previewHtml: string): Promise<{
138
- display_name: string;
143
+ updateEmailTheme(id: string, tsxSource: string): Promise<void>;
144
+ updateEmailTemplate(id: string, tsxSource: string, themeId: string | null | false): Promise<{
139
145
  rendered_html: string;
140
146
  }>;
147
+ createEmailTemplate(displayName: string): Promise<{
148
+ id: string;
149
+ }>;
141
150
  }
142
151
 
143
152
  export { type AdminAuthApplicationOptions, type ChatContent, type InternalApiKeyCreateCrudRequest, type InternalApiKeyCreateCrudResponse, StackAdminInterface };