@stackframe/stack 2.5.2 → 2.5.4

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 (144) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/components/credential-sign-in-form.js +4 -14
  3. package/dist/components/credential-sign-in-form.js.map +1 -1
  4. package/dist/components/credential-sign-up-form.js +18 -20
  5. package/dist/components/credential-sign-up-form.js.map +1 -1
  6. package/dist/components/elements/maybe-full-page.js.map +1 -1
  7. package/dist/components/elements/ssr-layout-effect.d.mts +1 -0
  8. package/dist/components/elements/ssr-layout-effect.d.ts +1 -0
  9. package/dist/components/elements/ssr-layout-effect.js +8 -1
  10. package/dist/components/elements/ssr-layout-effect.js.map +1 -1
  11. package/dist/components/elements/user-avatar.d.mts +5 -3
  12. package/dist/components/elements/user-avatar.d.ts +5 -3
  13. package/dist/components/elements/user-avatar.js.map +1 -1
  14. package/dist/components/forgot-password-form.js +3 -13
  15. package/dist/components/forgot-password-form.js.map +1 -1
  16. package/dist/components/magic-link-sign-in-form.js +3 -13
  17. package/dist/components/magic-link-sign-in-form.js.map +1 -1
  18. package/dist/components/message-cards/known-error-message-card.js.map +1 -1
  19. package/dist/components/message-cards/message-card.js.map +1 -1
  20. package/dist/components/message-cards/predefined-message-card.js.map +1 -1
  21. package/dist/components/oauth-button-group.d.mts +7 -2
  22. package/dist/components/oauth-button-group.d.ts +7 -2
  23. package/dist/components/oauth-button-group.js +1 -1
  24. package/dist/components/oauth-button-group.js.map +1 -1
  25. package/dist/components/oauth-button.js +28 -26
  26. package/dist/components/oauth-button.js.map +1 -1
  27. package/dist/components/password-reset-form.js +4 -3
  28. package/dist/components/password-reset-form.js.map +1 -1
  29. package/dist/components/selected-team-switcher.d.mts +5 -3
  30. package/dist/components/selected-team-switcher.d.ts +5 -3
  31. package/dist/components/selected-team-switcher.js +12 -1
  32. package/dist/components/selected-team-switcher.js.map +1 -1
  33. package/dist/components/user-button.js.map +1 -1
  34. package/dist/components-page/account-settings.js +42 -7
  35. package/dist/components-page/account-settings.js.map +1 -1
  36. package/dist/components-page/auth-page.d.mts +9 -2
  37. package/dist/components-page/auth-page.d.ts +9 -2
  38. package/dist/components-page/auth-page.js +3 -3
  39. package/dist/components-page/auth-page.js.map +1 -1
  40. package/dist/components-page/email-verification.js +12 -2
  41. package/dist/components-page/email-verification.js.map +1 -1
  42. package/dist/components-page/error-page.js.map +1 -1
  43. package/dist/components-page/magic-link-callback.js +13 -3
  44. package/dist/components-page/magic-link-callback.js.map +1 -1
  45. package/dist/components-page/password-reset.js +2 -2
  46. package/dist/components-page/password-reset.js.map +1 -1
  47. package/dist/components-page/sign-out.js +12 -2
  48. package/dist/components-page/sign-out.js.map +1 -1
  49. package/dist/components-page/stack-handler.d.mts +5 -3
  50. package/dist/components-page/stack-handler.d.ts +5 -3
  51. package/dist/components-page/stack-handler.js +27 -10
  52. package/dist/components-page/stack-handler.js.map +1 -1
  53. package/dist/esm/components/credential-sign-in-form.js +4 -4
  54. package/dist/esm/components/credential-sign-in-form.js.map +1 -1
  55. package/dist/esm/components/credential-sign-up-form.js +18 -20
  56. package/dist/esm/components/credential-sign-up-form.js.map +1 -1
  57. package/dist/esm/components/elements/maybe-full-page.js.map +1 -1
  58. package/dist/esm/components/elements/ssr-layout-effect.js +8 -1
  59. package/dist/esm/components/elements/ssr-layout-effect.js.map +1 -1
  60. package/dist/esm/components/elements/user-avatar.js.map +1 -1
  61. package/dist/esm/components/forgot-password-form.js +3 -3
  62. package/dist/esm/components/forgot-password-form.js.map +1 -1
  63. package/dist/esm/components/magic-link-sign-in-form.js +3 -3
  64. package/dist/esm/components/magic-link-sign-in-form.js.map +1 -1
  65. package/dist/esm/components/message-cards/known-error-message-card.js.map +1 -1
  66. package/dist/esm/components/message-cards/message-card.js.map +1 -1
  67. package/dist/esm/components/message-cards/predefined-message-card.js.map +1 -1
  68. package/dist/esm/components/oauth-button-group.js +1 -1
  69. package/dist/esm/components/oauth-button-group.js.map +1 -1
  70. package/dist/esm/components/oauth-button.js +29 -27
  71. package/dist/esm/components/oauth-button.js.map +1 -1
  72. package/dist/esm/components/password-reset-form.js +4 -3
  73. package/dist/esm/components/password-reset-form.js.map +1 -1
  74. package/dist/esm/components/selected-team-switcher.js +2 -1
  75. package/dist/esm/components/selected-team-switcher.js.map +1 -1
  76. package/dist/esm/components/user-button.js.map +1 -1
  77. package/dist/esm/components-page/account-settings.js +42 -7
  78. package/dist/esm/components-page/account-settings.js.map +1 -1
  79. package/dist/esm/components-page/auth-page.js +3 -3
  80. package/dist/esm/components-page/auth-page.js.map +1 -1
  81. package/dist/esm/components-page/email-verification.js +2 -2
  82. package/dist/esm/components-page/email-verification.js.map +1 -1
  83. package/dist/esm/components-page/error-page.js.map +1 -1
  84. package/dist/esm/components-page/magic-link-callback.js +3 -3
  85. package/dist/esm/components-page/magic-link-callback.js.map +1 -1
  86. package/dist/esm/components-page/password-reset.js +2 -2
  87. package/dist/esm/components-page/password-reset.js.map +1 -1
  88. package/dist/esm/components-page/sign-out.js +2 -2
  89. package/dist/esm/components-page/sign-out.js.map +1 -1
  90. package/dist/esm/components-page/stack-handler.js +27 -10
  91. package/dist/esm/components-page/stack-handler.js.map +1 -1
  92. package/dist/esm/index.js +1 -4
  93. package/dist/esm/index.js.map +1 -1
  94. package/dist/esm/lib/auth.js.map +1 -1
  95. package/dist/esm/lib/cookie.js +6 -1
  96. package/dist/esm/lib/cookie.js.map +1 -1
  97. package/dist/esm/lib/hooks.js.map +1 -1
  98. package/dist/esm/lib/stack-app.js +581 -456
  99. package/dist/esm/lib/stack-app.js.map +1 -1
  100. package/dist/esm/providers/stack-provider-client.js +3 -4
  101. package/dist/esm/providers/stack-provider-client.js.map +1 -1
  102. package/dist/esm/providers/theme-provider.js +16 -7
  103. package/dist/esm/providers/theme-provider.js.map +1 -1
  104. package/dist/esm/utils/browser-script.js +2 -2
  105. package/dist/esm/utils/browser-script.js.map +1 -1
  106. package/dist/esm/utils/email.js +2 -2
  107. package/dist/esm/utils/email.js.map +1 -1
  108. package/dist/index.d.mts +6 -4
  109. package/dist/index.d.ts +6 -4
  110. package/dist/index.js +4 -8
  111. package/dist/index.js.map +1 -1
  112. package/dist/lib/auth.js.map +1 -1
  113. package/dist/lib/cookie.js +6 -1
  114. package/dist/lib/cookie.js.map +1 -1
  115. package/dist/lib/hooks.d.mts +5 -3
  116. package/dist/lib/hooks.d.ts +5 -3
  117. package/dist/lib/hooks.js.map +1 -1
  118. package/dist/lib/stack-app.d.mts +219 -114
  119. package/dist/lib/stack-app.d.ts +219 -114
  120. package/dist/lib/stack-app.js +603 -476
  121. package/dist/lib/stack-app.js.map +1 -1
  122. package/dist/providers/stack-provider-client.d.mts +8 -6
  123. package/dist/providers/stack-provider-client.d.ts +8 -6
  124. package/dist/providers/stack-provider-client.js +4 -5
  125. package/dist/providers/stack-provider-client.js.map +1 -1
  126. package/dist/providers/stack-provider.d.mts +5 -3
  127. package/dist/providers/stack-provider.d.ts +5 -3
  128. package/dist/providers/theme-provider.d.mts +2 -1
  129. package/dist/providers/theme-provider.d.ts +2 -1
  130. package/dist/providers/theme-provider.js +15 -6
  131. package/dist/providers/theme-provider.js.map +1 -1
  132. package/dist/utils/browser-script.d.mts +3 -1
  133. package/dist/utils/browser-script.d.ts +3 -1
  134. package/dist/utils/browser-script.js +2 -2
  135. package/dist/utils/browser-script.js.map +1 -1
  136. package/dist/utils/email.js +2 -12
  137. package/dist/utils/email.js.map +1 -1
  138. package/package.json +4 -5
  139. package/dist/esm/providers/styled-components-registry.js +0 -25
  140. package/dist/esm/providers/styled-components-registry.js.map +0 -1
  141. package/dist/providers/styled-components-registry.d.mts +0 -8
  142. package/dist/providers/styled-components-registry.d.ts +0 -8
  143. package/dist/providers/styled-components-registry.js +0 -45
  144. package/dist/providers/styled-components-registry.js.map +0 -1
@@ -1,13 +1,15 @@
1
1
  import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import { StackClientApp, StackClientAppJson } from '../lib/stack-app.mjs';
2
+ import { CurrentUserCrud } from '@stackframe/stack-shared/dist/interface/crud/current-user';
3
3
  import React from 'react';
4
- import { UserJson } from '@stackframe/stack-shared';
4
+ import { StackClientApp, StackClientAppJson } from '../lib/stack-app.mjs';
5
+ import '@stackframe/stack-shared';
6
+ import '@stackframe/stack-shared/dist/helpers/production-mode';
5
7
  import '@stackframe/stack-shared/dist/interface/clientInterface';
6
- import '@stackframe/stack-shared/dist/utils/json';
7
- import '@stackframe/stack-shared/dist/interface/adminInterface';
8
- import '@stackframe/stack-shared/dist/interface/serverInterface';
8
+ import '@stackframe/stack-shared/dist/interface/crud/api-keys';
9
9
  import '@stackframe/stack-shared/dist/interface/crud/email-templates';
10
+ import '@stackframe/stack-shared/dist/interface/crud/team-permissions';
10
11
  import '@stackframe/stack-shared/dist/sessions';
12
+ import '@stackframe/stack-shared/dist/utils/json';
11
13
 
12
14
  declare const StackContext: React.Context<{
13
15
  app: StackClientApp<true>;
@@ -17,7 +19,7 @@ declare function StackProviderClient(props: {
17
19
  children?: React.ReactNode;
18
20
  }): react_jsx_runtime.JSX.Element;
19
21
  declare function UserSetter(props: {
20
- userJsonPromise: Promise<UserJson | null>;
22
+ userJsonPromise: Promise<CurrentUserCrud['Client']['Read'] | null>;
21
23
  }): null;
22
24
 
23
25
  export { StackContext, StackProviderClient, UserSetter };
@@ -1,13 +1,15 @@
1
1
  import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import { StackClientApp, StackClientAppJson } from '../lib/stack-app.js';
2
+ import { CurrentUserCrud } from '@stackframe/stack-shared/dist/interface/crud/current-user';
3
3
  import React from 'react';
4
- import { UserJson } from '@stackframe/stack-shared';
4
+ import { StackClientApp, StackClientAppJson } from '../lib/stack-app.js';
5
+ import '@stackframe/stack-shared';
6
+ import '@stackframe/stack-shared/dist/helpers/production-mode';
5
7
  import '@stackframe/stack-shared/dist/interface/clientInterface';
6
- import '@stackframe/stack-shared/dist/utils/json';
7
- import '@stackframe/stack-shared/dist/interface/adminInterface';
8
- import '@stackframe/stack-shared/dist/interface/serverInterface';
8
+ import '@stackframe/stack-shared/dist/interface/crud/api-keys';
9
9
  import '@stackframe/stack-shared/dist/interface/crud/email-templates';
10
+ import '@stackframe/stack-shared/dist/interface/crud/team-permissions';
10
11
  import '@stackframe/stack-shared/dist/sessions';
12
+ import '@stackframe/stack-shared/dist/utils/json';
11
13
 
12
14
  declare const StackContext: React.Context<{
13
15
  app: StackClientApp<true>;
@@ -17,7 +19,7 @@ declare function StackProviderClient(props: {
17
19
  children?: React.ReactNode;
18
20
  }): react_jsx_runtime.JSX.Element;
19
21
  declare function UserSetter(props: {
20
- userJsonPromise: Promise<UserJson | null>;
22
+ userJsonPromise: Promise<CurrentUserCrud['Client']['Read'] | null>;
21
23
  }): null;
22
24
 
23
25
  export { StackContext, StackProviderClient, UserSetter };
@@ -37,13 +37,12 @@ __export(stack_provider_client_exports, {
37
37
  UserSetter: () => UserSetter
38
38
  });
39
39
  module.exports = __toCommonJS(stack_provider_client_exports);
40
- var import_react = require("react");
41
- var import_stack_app = require("../lib/stack-app");
42
- var import_react2 = __toESM(require("react"));
43
- var import__ = require("..");
44
40
  var import_globals = require("@stackframe/stack-shared/dist/utils/globals");
41
+ var import_react = __toESM(require("react"));
42
+ var import__ = require("..");
43
+ var import_stack_app = require("../lib/stack-app");
45
44
  var import_jsx_runtime = require("react/jsx-runtime");
46
- var StackContext = import_react2.default.createContext(null);
45
+ var StackContext = import_react.default.createContext(null);
47
46
  function StackProviderClient(props) {
48
47
  const appJson = props.appJson;
49
48
  const app = import_stack_app.StackClientApp[import_stack_app.stackAppInternalsSymbol].fromClientJson(appJson);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/providers/stack-provider-client.tsx"],"sourcesContent":["\"use client\";\n\nimport { useEffect } from \"react\";\nimport { StackClientApp, StackClientAppJson, stackAppInternalsSymbol } from \"../lib/stack-app\";\nimport React from \"react\";\nimport { UserJson } from \"@stackframe/stack-shared\";\nimport { useStackApp } from \"..\";\nimport { globalVar } from \"@stackframe/stack-shared/dist/utils/globals\";\n\nexport const StackContext = React.createContext<null | {\n app: StackClientApp<true>,\n}>(null);\n\nexport function StackProviderClient(props: {\n appJson: StackClientAppJson<true, string>,\n children?: React.ReactNode,\n}) {\n const appJson = props.appJson;\n const app = StackClientApp[stackAppInternalsSymbol].fromClientJson(appJson);\n\n if (process.env.NODE_ENV === \"development\") {\n globalVar.stackApp = app;\n }\n \n return (\n <StackContext.Provider value={{ app }}>\n {props.children}\n </StackContext.Provider>\n );\n}\n\nexport function UserSetter(props: { userJsonPromise: Promise<UserJson | null> }) {\n const app = useStackApp();\n useEffect(() => {\n const promise = (async () => await props.userJsonPromise)(); // there is a Next.js bug where Promises passed by server components return `undefined` as their `then` value, so wrap it in a normal promise\n app[stackAppInternalsSymbol].setCurrentUser(promise);\n }, []);\n return null;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,mBAA0B;AAC1B,uBAA4E;AAC5E,IAAAA,gBAAkB;AAElB,eAA4B;AAC5B,qBAA0B;AAkBtB;AAhBG,IAAM,eAAe,cAAAC,QAAM,cAE/B,IAAI;AAEA,SAAS,oBAAoB,OAGjC;AACD,QAAM,UAAU,MAAM;AACtB,QAAM,MAAM,gCAAe,wCAAuB,EAAE,eAAe,OAAO;AAE1E,MAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,6BAAU,WAAW;AAAA,EACvB;AAEA,SACE,4CAAC,aAAa,UAAb,EAAsB,OAAO,EAAE,IAAI,GACjC,gBAAM,UACT;AAEJ;AAEO,SAAS,WAAW,OAAsD;AAC/E,QAAM,UAAM,sBAAY;AACxB,8BAAU,MAAM;AACd,UAAM,WAAW,YAAY,MAAM,MAAM,iBAAiB;AAC1D,QAAI,wCAAuB,EAAE,eAAe,OAAO;AAAA,EACrD,GAAG,CAAC,CAAC;AACL,SAAO;AACT;","names":["import_react","React"]}
1
+ {"version":3,"sources":["../../src/providers/stack-provider-client.tsx"],"sourcesContent":["\"use client\";\n\nimport { CurrentUserCrud } from \"@stackframe/stack-shared/dist/interface/crud/current-user\";\nimport { globalVar } from \"@stackframe/stack-shared/dist/utils/globals\";\nimport React, { useEffect } from \"react\";\nimport { useStackApp } from \"..\";\nimport { StackClientApp, StackClientAppJson, stackAppInternalsSymbol } from \"../lib/stack-app\";\n\nexport const StackContext = React.createContext<null | {\n app: StackClientApp<true>,\n}>(null);\n\nexport function StackProviderClient(props: {\n appJson: StackClientAppJson<true, string>,\n children?: React.ReactNode,\n}) {\n const appJson = props.appJson;\n const app = StackClientApp[stackAppInternalsSymbol].fromClientJson(appJson);\n\n if (process.env.NODE_ENV === \"development\") {\n globalVar.stackApp = app;\n }\n\n return (\n <StackContext.Provider value={{ app }}>\n {props.children}\n </StackContext.Provider>\n );\n}\n\nexport function UserSetter(props: { userJsonPromise: Promise<CurrentUserCrud['Client']['Read'] | null> }) {\n const app = useStackApp();\n useEffect(() => {\n const promise = (async () => await props.userJsonPromise)(); // there is a Next.js bug where Promises passed by server components return `undefined` as their `then` value, so wrap it in a normal promise\n app[stackAppInternalsSymbol].setCurrentUser(promise);\n }, []);\n return null;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAGA,qBAA0B;AAC1B,mBAAiC;AACjC,eAA4B;AAC5B,uBAA4E;AAkBxE;AAhBG,IAAM,eAAe,aAAAA,QAAM,cAE/B,IAAI;AAEA,SAAS,oBAAoB,OAGjC;AACD,QAAM,UAAU,MAAM;AACtB,QAAM,MAAM,gCAAe,wCAAuB,EAAE,eAAe,OAAO;AAE1E,MAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,6BAAU,WAAW;AAAA,EACvB;AAEA,SACE,4CAAC,aAAa,UAAb,EAAsB,OAAO,EAAE,IAAI,GACjC,gBAAM,UACT;AAEJ;AAEO,SAAS,WAAW,OAA+E;AACxG,QAAM,UAAM,sBAAY;AACxB,8BAAU,MAAM;AACd,UAAM,WAAW,YAAY,MAAM,MAAM,iBAAiB;AAC1D,QAAI,wCAAuB,EAAE,eAAe,OAAO;AAAA,EACrD,GAAG,CAAC,CAAC;AACL,SAAO;AACT;","names":["React"]}
@@ -2,12 +2,14 @@ import * as react_jsx_runtime from 'react/jsx-runtime';
2
2
  import React from 'react';
3
3
  import { StackClientApp } from '../lib/stack-app.mjs';
4
4
  import '@stackframe/stack-shared';
5
+ import '@stackframe/stack-shared/dist/helpers/production-mode';
5
6
  import '@stackframe/stack-shared/dist/interface/clientInterface';
6
- import '@stackframe/stack-shared/dist/utils/json';
7
- import '@stackframe/stack-shared/dist/interface/adminInterface';
8
- import '@stackframe/stack-shared/dist/interface/serverInterface';
7
+ import '@stackframe/stack-shared/dist/interface/crud/api-keys';
8
+ import '@stackframe/stack-shared/dist/interface/crud/current-user';
9
9
  import '@stackframe/stack-shared/dist/interface/crud/email-templates';
10
+ import '@stackframe/stack-shared/dist/interface/crud/team-permissions';
10
11
  import '@stackframe/stack-shared/dist/sessions';
12
+ import '@stackframe/stack-shared/dist/utils/json';
11
13
 
12
14
  declare function StackProvider({ children, app, }: {
13
15
  children: React.ReactNode;
@@ -2,12 +2,14 @@ import * as react_jsx_runtime from 'react/jsx-runtime';
2
2
  import React from 'react';
3
3
  import { StackClientApp } from '../lib/stack-app.js';
4
4
  import '@stackframe/stack-shared';
5
+ import '@stackframe/stack-shared/dist/helpers/production-mode';
5
6
  import '@stackframe/stack-shared/dist/interface/clientInterface';
6
- import '@stackframe/stack-shared/dist/utils/json';
7
- import '@stackframe/stack-shared/dist/interface/adminInterface';
8
- import '@stackframe/stack-shared/dist/interface/serverInterface';
7
+ import '@stackframe/stack-shared/dist/interface/crud/api-keys';
8
+ import '@stackframe/stack-shared/dist/interface/crud/current-user';
9
9
  import '@stackframe/stack-shared/dist/interface/crud/email-templates';
10
+ import '@stackframe/stack-shared/dist/interface/crud/team-permissions';
10
11
  import '@stackframe/stack-shared/dist/sessions';
12
+ import '@stackframe/stack-shared/dist/utils/json';
11
13
 
12
14
  declare function StackProvider({ children, app, }: {
13
15
  children: React.ReactNode;
@@ -31,9 +31,10 @@ type ThemeConfig = {
31
31
  light?: Partial<Colors>;
32
32
  dark?: Partial<Colors>;
33
33
  } & Partial<Omit<Theme, 'light' | 'dark'>>;
34
- declare function StackTheme({ theme, children, }: {
34
+ declare function StackTheme({ theme, children, nonce, }: {
35
35
  theme?: ThemeConfig;
36
36
  children?: React.ReactNode;
37
+ nonce?: string;
37
38
  }): react_jsx_runtime.JSX.Element;
38
39
 
39
40
  export { StackTheme, type Theme };
@@ -31,9 +31,10 @@ type ThemeConfig = {
31
31
  light?: Partial<Colors>;
32
32
  dark?: Partial<Colors>;
33
33
  } & Partial<Omit<Theme, 'light' | 'dark'>>;
34
- declare function StackTheme({ theme, children, }: {
34
+ declare function StackTheme({ theme, children, nonce, }: {
35
35
  theme?: ThemeConfig;
36
36
  children?: React.ReactNode;
37
+ nonce?: string;
37
38
  }): react_jsx_runtime.JSX.Element;
38
39
 
39
40
  export { StackTheme, type Theme };
@@ -35,7 +35,6 @@ __export(theme_provider_exports, {
35
35
  StackTheme: () => StackTheme
36
36
  });
37
37
  module.exports = __toCommonJS(theme_provider_exports);
38
- var import_styled_components_registry = __toESM(require("./styled-components-registry"));
39
38
  var import_global_css = require("../generated/global-css");
40
39
  var import_browser_script = require("../utils/browser-script");
41
40
  var import_constants = require("../utils/constants");
@@ -48,7 +47,7 @@ function convertColorToCSSVars(obj) {
48
47
  return [
49
48
  // Convert camelCase key to dash-case
50
49
  key.replace(/[A-Z]/g, (m) => `-${m.toLowerCase()}`),
51
- // Convert color to CSS HSL string
50
+ // Convert color to CSS HSL string
52
51
  `${color[0]} ${color[1]}% ${color[2]}%`
53
52
  ];
54
53
  }));
@@ -75,7 +74,8 @@ function convertColorsToCSS(theme) {
75
74
  }
76
75
  function StackTheme({
77
76
  theme,
78
- children
77
+ children,
78
+ nonce
79
79
  }) {
80
80
  const themeValue = {
81
81
  ...import_constants.DEFAULT_THEME,
@@ -83,9 +83,18 @@ function StackTheme({
83
83
  dark: { ...import_constants.DEFAULT_THEME.dark, ...theme?.dark },
84
84
  light: { ...import_constants.DEFAULT_THEME.light, ...theme?.light }
85
85
  };
86
- return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_styled_components_registry.default, { children: [
87
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_browser_script.BrowserScript, {}),
88
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("style", { dangerouslySetInnerHTML: { __html: import_global_css.globalCSS + "\n" + convertColorsToCSS(themeValue) } }),
86
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_jsx_runtime.Fragment, { children: [
87
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_browser_script.BrowserScript, { nonce }),
88
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
89
+ "style",
90
+ {
91
+ suppressHydrationWarning: true,
92
+ nonce,
93
+ dangerouslySetInnerHTML: {
94
+ __html: import_global_css.globalCSS + "\n" + convertColorsToCSS(themeValue)
95
+ }
96
+ }
97
+ ),
89
98
  children
90
99
  ] });
91
100
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/providers/theme-provider.tsx"],"sourcesContent":["'use client';\n\nimport React from \"react\";\nimport StyledComponentsRegistry from \"./styled-components-registry\";\nimport { globalCSS } from \"../generated/global-css\";\nimport { BrowserScript } from \"../utils/browser-script\";\nimport { DEFAULT_THEME } from \"../utils/constants\";\nimport Color from \"color\";\nimport { deindent } from \"@stackframe/stack-shared/dist/utils/strings\";\n\ntype Colors = {\n background: string,\n foreground: string,\n card: string,\n cardForeground: string,\n popover: string,\n popoverForeground: string,\n primary: string,\n primaryForeground: string,\n secondary: string,\n secondaryForeground: string,\n muted: string,\n mutedForeground: string,\n accent: string,\n accentForeground: string,\n destructive: string,\n destructiveForeground: string,\n border: string,\n input: string,\n ring: string,\n}\n\nexport type Theme = {\n light: Colors,\n dark: Colors,\n radius: string,\n};\n\ntype ThemeConfig = {\n light?: Partial<Colors>,\n dark?: Partial<Colors>,\n} & Partial<Omit<Theme, 'light' | 'dark'>>;\n\nfunction convertColorToCSSVars(obj: Record<string, string>) {\n return Object.fromEntries(Object.entries(obj).map(([key, value]) => {\n const color = Color(value).hsl().array();\n return [\n // Convert camelCase key to dash-case\n key.replace(/[A-Z]/g, m => `-${m.toLowerCase()}`),\n // Convert color to CSS HSL string \n `${color[0]} ${color[1]}% ${color[2]}%`\n ];\n }));\n}\n\nfunction convertColorsToCSS(theme: Theme) {\n const { dark, light, ...rest } = theme;\n const colors = {\n light: { ...convertColorToCSSVars(light), ...rest },\n dark: convertColorToCSSVars(dark),\n };\n\n function colorsToCSSVars(colors: Record<string, string>) {\n return Object.entries(colors).map((params) => { \n return `--${params[0]}: ${params[1]};\\n`;\n }).join('');\n }\n \n return deindent`\n .stack-scope {\n ${colorsToCSSVars(colors.light)}\n }\n [data-stack-theme=\"dark\"] .stack-scope {\n ${colorsToCSSVars(colors.dark)}\n }`;\n}\n \n\nexport function StackTheme({\n theme,\n children,\n} : {\n theme?: ThemeConfig,\n children?: React.ReactNode,\n}) {\n const themeValue: Theme = { \n ...DEFAULT_THEME,\n ...theme,\n dark: { ...DEFAULT_THEME.dark, ...theme?.dark }, \n light: { ...DEFAULT_THEME.light, ...theme?.light },\n };\n\n return (\n <StyledComponentsRegistry>\n <BrowserScript />\n <style dangerouslySetInnerHTML={{ __html: globalCSS + '\\n' + convertColorsToCSS(themeValue) }} />\n {children}\n </StyledComponentsRegistry>\n );\n}"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAGA,wCAAqC;AACrC,wBAA0B;AAC1B,4BAA8B;AAC9B,uBAA8B;AAC9B,mBAAkB;AAClB,qBAAyB;AAqFrB;AAlDJ,SAAS,sBAAsB,KAA6B;AAC1D,SAAO,OAAO,YAAY,OAAO,QAAQ,GAAG,EAAE,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM;AAClE,UAAM,YAAQ,aAAAA,SAAM,KAAK,EAAE,IAAI,EAAE,MAAM;AACvC,WAAO;AAAA;AAAA,MAEL,IAAI,QAAQ,UAAU,OAAK,IAAI,EAAE,YAAY,CAAC,EAAE;AAAA;AAAA,MAEhD,GAAG,MAAM,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC;AAAA,IACtC;AAAA,EACF,CAAC,CAAC;AACJ;AAEA,SAAS,mBAAmB,OAAc;AACxC,QAAM,EAAE,MAAM,OAAO,GAAG,KAAK,IAAI;AACjC,QAAM,SAAS;AAAA,IACb,OAAO,EAAE,GAAG,sBAAsB,KAAK,GAAG,GAAG,KAAK;AAAA,IAClD,MAAM,sBAAsB,IAAI;AAAA,EAClC;AAEA,WAAS,gBAAgBC,SAAgC;AACvD,WAAO,OAAO,QAAQA,OAAM,EAAE,IAAI,CAAC,WAAW;AAC5C,aAAO,KAAK,OAAO,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC;AAAA;AAAA,IACrC,CAAC,EAAE,KAAK,EAAE;AAAA,EACZ;AAEA,SAAO;AAAA;AAAA,IAEL,gBAAgB,OAAO,KAAK,CAAC;AAAA;AAAA;AAAA,IAG7B,gBAAgB,OAAO,IAAI,CAAC;AAAA;AAEhC;AAGO,SAAS,WAAW;AAAA,EACzB;AAAA,EACA;AACF,GAGG;AACD,QAAM,aAAoB;AAAA,IACxB,GAAG;AAAA,IACH,GAAG;AAAA,IACH,MAAM,EAAE,GAAG,+BAAc,MAAM,GAAG,OAAO,KAAK;AAAA,IAC9C,OAAO,EAAE,GAAG,+BAAc,OAAO,GAAG,OAAO,MAAM;AAAA,EACnD;AAEA,SACE,6CAAC,kCAAAC,SAAA,EACC;AAAA,gDAAC,uCAAc;AAAA,IACf,4CAAC,WAAM,yBAAyB,EAAE,QAAQ,8BAAY,OAAO,mBAAmB,UAAU,EAAE,GAAG;AAAA,IAC9F;AAAA,KACH;AAEJ;","names":["Color","colors","StyledComponentsRegistry"]}
1
+ {"version":3,"sources":["../../src/providers/theme-provider.tsx"],"sourcesContent":["'use client';\n\nimport React from \"react\";\nimport { globalCSS } from \"../generated/global-css\";\nimport { BrowserScript } from \"../utils/browser-script\";\nimport { DEFAULT_THEME } from \"../utils/constants\";\nimport Color from \"color\";\nimport { deindent } from \"@stackframe/stack-shared/dist/utils/strings\";\n\ntype Colors = {\n background: string,\n foreground: string,\n card: string,\n cardForeground: string,\n popover: string,\n popoverForeground: string,\n primary: string,\n primaryForeground: string,\n secondary: string,\n secondaryForeground: string,\n muted: string,\n mutedForeground: string,\n accent: string,\n accentForeground: string,\n destructive: string,\n destructiveForeground: string,\n border: string,\n input: string,\n ring: string,\n}\n\nexport type Theme = {\n light: Colors,\n dark: Colors,\n radius: string,\n};\n\ntype ThemeConfig = {\n light?: Partial<Colors>,\n dark?: Partial<Colors>,\n} & Partial<Omit<Theme, 'light' | 'dark'>>;\n\nfunction convertColorToCSSVars(obj: Record<string, string>) {\n return Object.fromEntries(Object.entries(obj).map(([key, value]) => {\n const color = Color(value).hsl().array();\n return [\n // Convert camelCase key to dash-case\n key.replace(/[A-Z]/g, m => `-${m.toLowerCase()}`),\n // Convert color to CSS HSL string\n `${color[0]} ${color[1]}% ${color[2]}%`\n ];\n }));\n}\n\nfunction convertColorsToCSS(theme: Theme) {\n const { dark, light, ...rest } = theme;\n const colors = {\n light: { ...convertColorToCSSVars(light), ...rest },\n dark: convertColorToCSSVars(dark),\n };\n\n function colorsToCSSVars(colors: Record<string, string>) {\n return Object.entries(colors).map((params) => {\n return `--${params[0]}: ${params[1]};\\n`;\n }).join('');\n }\n\n return deindent`\n .stack-scope {\n ${colorsToCSSVars(colors.light)}\n }\n [data-stack-theme=\"dark\"] .stack-scope {\n ${colorsToCSSVars(colors.dark)}\n }`;\n}\n\n\nexport function StackTheme({\n theme,\n children,\n nonce,\n} : {\n theme?: ThemeConfig,\n children?: React.ReactNode,\n nonce?: string,\n}) {\n const themeValue: Theme = {\n ...DEFAULT_THEME,\n ...theme,\n dark: { ...DEFAULT_THEME.dark, ...theme?.dark },\n light: { ...DEFAULT_THEME.light, ...theme?.light },\n };\n\n return (\n <>\n <BrowserScript nonce={nonce} />\n <style\n suppressHydrationWarning\n nonce={nonce}\n dangerouslySetInnerHTML={{\n __html: globalCSS + \"\\n\" + convertColorsToCSS(themeValue),\n }}\n />\n {children}\n </>\n );\n}"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAGA,wBAA0B;AAC1B,4BAA8B;AAC9B,uBAA8B;AAC9B,mBAAkB;AAClB,qBAAyB;AAuFrB;AApDJ,SAAS,sBAAsB,KAA6B;AAC1D,SAAO,OAAO,YAAY,OAAO,QAAQ,GAAG,EAAE,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM;AAClE,UAAM,YAAQ,aAAAA,SAAM,KAAK,EAAE,IAAI,EAAE,MAAM;AACvC,WAAO;AAAA;AAAA,MAEL,IAAI,QAAQ,UAAU,OAAK,IAAI,EAAE,YAAY,CAAC,EAAE;AAAA;AAAA,MAEhD,GAAG,MAAM,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC;AAAA,IACtC;AAAA,EACF,CAAC,CAAC;AACJ;AAEA,SAAS,mBAAmB,OAAc;AACxC,QAAM,EAAE,MAAM,OAAO,GAAG,KAAK,IAAI;AACjC,QAAM,SAAS;AAAA,IACb,OAAO,EAAE,GAAG,sBAAsB,KAAK,GAAG,GAAG,KAAK;AAAA,IAClD,MAAM,sBAAsB,IAAI;AAAA,EAClC;AAEA,WAAS,gBAAgBC,SAAgC;AACvD,WAAO,OAAO,QAAQA,OAAM,EAAE,IAAI,CAAC,WAAW;AAC5C,aAAO,KAAK,OAAO,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC;AAAA;AAAA,IACrC,CAAC,EAAE,KAAK,EAAE;AAAA,EACZ;AAEA,SAAO;AAAA;AAAA,IAEL,gBAAgB,OAAO,KAAK,CAAC;AAAA;AAAA;AAAA,IAG7B,gBAAgB,OAAO,IAAI,CAAC;AAAA;AAEhC;AAGO,SAAS,WAAW;AAAA,EACzB;AAAA,EACA;AAAA,EACA;AACF,GAIG;AACD,QAAM,aAAoB;AAAA,IACxB,GAAG;AAAA,IACH,GAAG;AAAA,IACH,MAAM,EAAE,GAAG,+BAAc,MAAM,GAAG,OAAO,KAAK;AAAA,IAC9C,OAAO,EAAE,GAAG,+BAAc,OAAO,GAAG,OAAO,MAAM;AAAA,EACnD;AAEA,SACE,4EACE;AAAA,gDAAC,uCAAc,OAAc;AAAA,IAC7B;AAAA,MAAC;AAAA;AAAA,QACC,0BAAwB;AAAA,QACxB;AAAA,QACA,yBAAyB;AAAA,UACvB,QAAQ,8BAAY,OAAO,mBAAmB,UAAU;AAAA,QAC1D;AAAA;AAAA,IACF;AAAA,IACC;AAAA,KACH;AAEJ;","names":["Color","colors"]}
@@ -1,5 +1,7 @@
1
1
  import * as react_jsx_runtime from 'react/jsx-runtime';
2
2
 
3
- declare function BrowserScript(): react_jsx_runtime.JSX.Element;
3
+ declare function BrowserScript(props: {
4
+ nonce?: string;
5
+ }): react_jsx_runtime.JSX.Element;
4
6
 
5
7
  export { BrowserScript };
@@ -1,5 +1,7 @@
1
1
  import * as react_jsx_runtime from 'react/jsx-runtime';
2
2
 
3
- declare function BrowserScript(): react_jsx_runtime.JSX.Element;
3
+ declare function BrowserScript(props: {
4
+ nonce?: string;
5
+ }): react_jsx_runtime.JSX.Element;
4
6
 
5
7
  export { BrowserScript };
@@ -50,8 +50,8 @@ var script = () => {
50
50
  attributeFilter: attributes
51
51
  });
52
52
  };
53
- function BrowserScript() {
54
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_ssr_layout_effect.SsrScript, { script: `(${script.toString()})()` });
53
+ function BrowserScript(props) {
54
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_ssr_layout_effect.SsrScript, { nonce: props.nonce, script: `(${script.toString()})()` });
55
55
  }
56
56
  // Annotate the CommonJS export names for ESM import in node:
57
57
  0 && (module.exports = {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utils/browser-script.tsx"],"sourcesContent":["// Note that this script can not import anything from outside as it will be converted to a string and executed in the browser.\n\nimport { SsrScript } from \"../components/elements/ssr-layout-effect\";\n\n// Also please note that there might be hydration issues with this script, always check the browser console for errors after changing this script.\nconst script = () => {\n const attributes = ['data-joy-color-scheme', 'data-mui-color-scheme', 'data-theme', 'data-color-scheme', 'class'];\n\n const observer = new MutationObserver((mutations) => {\n mutations.forEach((mutation) => {\n for (const attributeName of attributes) {\n if (mutation.attributeName === attributeName) {\n const colorTheme = document.documentElement.getAttribute(attributeName);\n if (!colorTheme) {\n continue;\n }\n const darkMode = colorTheme.includes('dark');\n const lightMode = colorTheme.includes('light');\n if (!darkMode && !lightMode) {\n continue;\n }\n document.documentElement.setAttribute('data-stack-theme', darkMode ? 'dark' : 'light');\n }\n }\n });\n });\n\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: attributes,\n });\n};\n\nexport function BrowserScript() {\n return <SsrScript script={`(${script.toString()})()`}/>;\n}"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,+BAA0B;AAgCjB;AA7BT,IAAM,SAAS,MAAM;AACnB,QAAM,aAAa,CAAC,yBAAyB,yBAAyB,cAAc,qBAAqB,OAAO;AAEhH,QAAM,WAAW,IAAI,iBAAiB,CAAC,cAAc;AACnD,cAAU,QAAQ,CAAC,aAAa;AAC9B,iBAAW,iBAAiB,YAAY;AACtC,YAAI,SAAS,kBAAkB,eAAe;AAC5C,gBAAM,aAAa,SAAS,gBAAgB,aAAa,aAAa;AACtE,cAAI,CAAC,YAAY;AACf;AAAA,UACF;AACA,gBAAM,WAAW,WAAW,SAAS,MAAM;AAC3C,gBAAM,YAAY,WAAW,SAAS,OAAO;AAC7C,cAAI,CAAC,YAAY,CAAC,WAAW;AAC3B;AAAA,UACF;AACA,mBAAS,gBAAgB,aAAa,oBAAoB,WAAW,SAAS,OAAO;AAAA,QACvF;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH,CAAC;AAED,WAAS,QAAQ,SAAS,iBAAiB;AAAA,IACzC,YAAY;AAAA,IACZ,iBAAiB;AAAA,EACnB,CAAC;AACH;AAEO,SAAS,gBAAgB;AAC9B,SAAO,4CAAC,sCAAU,QAAQ,IAAI,OAAO,SAAS,CAAC,OAAM;AACvD;","names":[]}
1
+ {"version":3,"sources":["../../src/utils/browser-script.tsx"],"sourcesContent":["// Note that this script can not import anything from outside as it will be converted to a string and executed in the browser.\n\nimport { SsrScript } from \"../components/elements/ssr-layout-effect\";\n\n// Also please note that there might be hydration issues with this script, always check the browser console for errors after changing this script.\nconst script = () => {\n const attributes = ['data-joy-color-scheme', 'data-mui-color-scheme', 'data-theme', 'data-color-scheme', 'class'];\n\n const observer = new MutationObserver((mutations) => {\n mutations.forEach((mutation) => {\n for (const attributeName of attributes) {\n if (mutation.attributeName === attributeName) {\n const colorTheme = document.documentElement.getAttribute(attributeName);\n if (!colorTheme) {\n continue;\n }\n const darkMode = colorTheme.includes('dark');\n const lightMode = colorTheme.includes('light');\n if (!darkMode && !lightMode) {\n continue;\n }\n document.documentElement.setAttribute('data-stack-theme', darkMode ? 'dark' : 'light');\n }\n }\n });\n });\n\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: attributes,\n });\n};\n\nexport function BrowserScript(props : { nonce?: string }) {\n return <SsrScript nonce={props.nonce} script={`(${script.toString()})()`}/>;\n}"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,+BAA0B;AAgCjB;AA7BT,IAAM,SAAS,MAAM;AACnB,QAAM,aAAa,CAAC,yBAAyB,yBAAyB,cAAc,qBAAqB,OAAO;AAEhH,QAAM,WAAW,IAAI,iBAAiB,CAAC,cAAc;AACnD,cAAU,QAAQ,CAAC,aAAa;AAC9B,iBAAW,iBAAiB,YAAY;AACtC,YAAI,SAAS,kBAAkB,eAAe;AAC5C,gBAAM,aAAa,SAAS,gBAAgB,aAAa,aAAa;AACtE,cAAI,CAAC,YAAY;AACf;AAAA,UACF;AACA,gBAAM,WAAW,WAAW,SAAS,MAAM;AAC3C,gBAAM,YAAY,WAAW,SAAS,OAAO;AAC7C,cAAI,CAAC,YAAY,CAAC,WAAW;AAC3B;AAAA,UACF;AACA,mBAAS,gBAAgB,aAAa,oBAAoB,WAAW,SAAS,OAAO;AAAA,QACvF;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH,CAAC;AAED,WAAS,QAAQ,SAAS,iBAAiB;AAAA,IACzC,YAAY;AAAA,IACZ,iBAAiB;AAAA,EACnB,CAAC;AACH;AAEO,SAAS,cAAc,OAA4B;AACxD,SAAO,4CAAC,sCAAU,OAAO,MAAM,OAAO,QAAQ,IAAI,OAAO,SAAS,CAAC,OAAM;AAC3E;","names":[]}
@@ -1,9 +1,7 @@
1
1
  "use strict";
2
- var __create = Object.create;
3
2
  var __defProp = Object.defineProperty;
4
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
6
  var __export = (target, all) => {
9
7
  for (var name in all)
@@ -17,14 +15,6 @@ var __copyProps = (to, from, except, desc) => {
17
15
  }
18
16
  return to;
19
17
  };
20
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
- mod
27
- ));
28
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
19
 
30
20
  // src/utils/email.tsx
@@ -33,10 +23,10 @@ __export(email_exports, {
33
23
  validateEmail: () => validateEmail
34
24
  });
35
25
  module.exports = __toCommonJS(email_exports);
36
- var yup = __toESM(require("yup"));
26
+ var import_schema_fields = require("@stackframe/stack-shared/dist/schema-fields");
37
27
  function validateEmail(email) {
38
28
  if (typeof email !== "string") throw new Error("Email must be a string");
39
- return yup.string().email().isValidSync(email);
29
+ return (0, import_schema_fields.yupString)().email().isValidSync(email);
40
30
  }
41
31
  // Annotate the CommonJS export names for ESM import in node:
42
32
  0 && (module.exports = {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utils/email.tsx"],"sourcesContent":["import * as yup from \"yup\";\n\nexport function validateEmail(email: string): boolean {\n if (typeof email !== \"string\") throw new Error(\"Email must be a string\");\n return yup.string().email().isValidSync(email);\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAAqB;AAEd,SAAS,cAAc,OAAwB;AACpD,MAAI,OAAO,UAAU,SAAU,OAAM,IAAI,MAAM,wBAAwB;AACvE,SAAW,WAAO,EAAE,MAAM,EAAE,YAAY,KAAK;AAC/C;","names":[]}
1
+ {"version":3,"sources":["../../src/utils/email.tsx"],"sourcesContent":["import { yupString } from \"@stackframe/stack-shared/dist/schema-fields\";\nimport * as yup from \"yup\";\n\nexport function validateEmail(email: string): boolean {\n if (typeof email !== \"string\") throw new Error(\"Email must be a string\");\n return yupString().email().isValidSync(email);\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2BAA0B;AAGnB,SAAS,cAAc,OAAwB;AACpD,MAAI,OAAO,UAAU,SAAU,OAAM,IAAI,MAAM,wBAAwB;AACvE,aAAO,gCAAU,EAAE,MAAM,EAAE,YAAY,KAAK;AAC9C;","names":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stackframe/stack",
3
- "version": "2.5.2",
3
+ "version": "2.5.4",
4
4
  "sideEffects": false,
5
5
  "exports": {
6
6
  ".": {
@@ -32,14 +32,13 @@
32
32
  "react-hook-form": "^7.51.4",
33
33
  "rimraf": "^5.0.5",
34
34
  "server-only": "^0.0.1",
35
- "styled-components": "^6.1.8",
36
35
  "tailwind-merge": "^2.3.0",
37
36
  "tailwindcss-animate": "^1.0.7",
38
37
  "tsx": "^4.7.2",
39
38
  "yup": "^1.4.0",
40
- "@stackframe/stack-sc": "2.5.2",
41
- "@stackframe/stack-ui": "2.5.2",
42
- "@stackframe/stack-shared": "2.5.2"
39
+ "@stackframe/stack-sc": "2.5.4",
40
+ "@stackframe/stack-shared": "2.5.4",
41
+ "@stackframe/stack-ui": "2.5.4"
43
42
  },
44
43
  "peerDependencies": {
45
44
  "next": ">=14.1",
@@ -1,25 +0,0 @@
1
- "use client";
2
- "use client";
3
-
4
- // src/providers/styled-components-registry.tsx
5
- import { useState } from "react";
6
- import { useServerInsertedHTML } from "next/navigation";
7
- import { ServerStyleSheet, StyleSheetManager } from "styled-components";
8
- import { isBrowserLike } from "@stackframe/stack-shared/dist/utils/env";
9
- import { Fragment, jsx } from "react/jsx-runtime";
10
- function StyledComponentsRegistry({
11
- children
12
- }) {
13
- const [styledComponentsStyleSheet] = useState(() => new ServerStyleSheet());
14
- useServerInsertedHTML(() => {
15
- const styles = styledComponentsStyleSheet.getStyleElement();
16
- styledComponentsStyleSheet.instance.clearTag();
17
- return /* @__PURE__ */ jsx(Fragment, { children: styles });
18
- });
19
- if (isBrowserLike()) return /* @__PURE__ */ jsx(Fragment, { children });
20
- return /* @__PURE__ */ jsx(StyleSheetManager, { sheet: styledComponentsStyleSheet.instance, children });
21
- }
22
- export {
23
- StyledComponentsRegistry as default
24
- };
25
- //# sourceMappingURL=styled-components-registry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/providers/styled-components-registry.tsx"],"sourcesContent":["'use client';\n \nimport React, { useState } from 'react';\nimport { useServerInsertedHTML } from 'next/navigation';\nimport { ServerStyleSheet, StyleSheetManager } from 'styled-components';\nimport { isBrowserLike } from '@stackframe/stack-shared/dist/utils/env';\n \nexport default function StyledComponentsRegistry({\n children,\n}: {\n children: React.ReactNode,\n}) {\n // Only create stylesheet once with lazy initial state\n // x-ref: https://reactjs.org/docs/hooks-reference.html#lazy-initial-state\n const [styledComponentsStyleSheet] = useState(() => new ServerStyleSheet());\n \n useServerInsertedHTML(() => {\n const styles = styledComponentsStyleSheet.getStyleElement();\n styledComponentsStyleSheet.instance.clearTag();\n return <>{styles}</>;\n });\n \n if (isBrowserLike()) return <>{children}</>;\n \n return (\n <StyleSheetManager sheet={styledComponentsStyleSheet.instance}>\n {children}\n </StyleSheetManager>\n );\n}\n"],"mappings":";;;AAEA,SAAgB,gBAAgB;AAChC,SAAS,6BAA6B;AACtC,SAAS,kBAAkB,yBAAyB;AACpD,SAAS,qBAAqB;AAcnB;AAZI,SAAR,yBAA0C;AAAA,EAC/C;AACF,GAEG;AAGD,QAAM,CAAC,0BAA0B,IAAI,SAAS,MAAM,IAAI,iBAAiB,CAAC;AAE1E,wBAAsB,MAAM;AAC1B,UAAM,SAAS,2BAA2B,gBAAgB;AAC1D,+BAA2B,SAAS,SAAS;AAC7C,WAAO,gCAAG,kBAAO;AAAA,EACnB,CAAC;AAED,MAAI,cAAc,EAAG,QAAO,gCAAG,UAAS;AAExC,SACE,oBAAC,qBAAkB,OAAO,2BAA2B,UAClD,UACH;AAEJ;","names":[]}
@@ -1,8 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import React from 'react';
3
-
4
- declare function StyledComponentsRegistry({ children, }: {
5
- children: React.ReactNode;
6
- }): react_jsx_runtime.JSX.Element;
7
-
8
- export { StyledComponentsRegistry as default };
@@ -1,8 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import React from 'react';
3
-
4
- declare function StyledComponentsRegistry({ children, }: {
5
- children: React.ReactNode;
6
- }): react_jsx_runtime.JSX.Element;
7
-
8
- export { StyledComponentsRegistry as default };
@@ -1,45 +0,0 @@
1
- "use client";
2
- "use strict";
3
- "use client";
4
- var __defProp = Object.defineProperty;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
-
22
- // src/providers/styled-components-registry.tsx
23
- var styled_components_registry_exports = {};
24
- __export(styled_components_registry_exports, {
25
- default: () => StyledComponentsRegistry
26
- });
27
- module.exports = __toCommonJS(styled_components_registry_exports);
28
- var import_react = require("react");
29
- var import_navigation = require("next/navigation");
30
- var import_styled_components = require("styled-components");
31
- var import_env = require("@stackframe/stack-shared/dist/utils/env");
32
- var import_jsx_runtime = require("react/jsx-runtime");
33
- function StyledComponentsRegistry({
34
- children
35
- }) {
36
- const [styledComponentsStyleSheet] = (0, import_react.useState)(() => new import_styled_components.ServerStyleSheet());
37
- (0, import_navigation.useServerInsertedHTML)(() => {
38
- const styles = styledComponentsStyleSheet.getStyleElement();
39
- styledComponentsStyleSheet.instance.clearTag();
40
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_jsx_runtime.Fragment, { children: styles });
41
- });
42
- if ((0, import_env.isBrowserLike)()) return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_jsx_runtime.Fragment, { children });
43
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_styled_components.StyleSheetManager, { sheet: styledComponentsStyleSheet.instance, children });
44
- }
45
- //# sourceMappingURL=styled-components-registry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/providers/styled-components-registry.tsx"],"sourcesContent":["'use client';\n \nimport React, { useState } from 'react';\nimport { useServerInsertedHTML } from 'next/navigation';\nimport { ServerStyleSheet, StyleSheetManager } from 'styled-components';\nimport { isBrowserLike } from '@stackframe/stack-shared/dist/utils/env';\n \nexport default function StyledComponentsRegistry({\n children,\n}: {\n children: React.ReactNode,\n}) {\n // Only create stylesheet once with lazy initial state\n // x-ref: https://reactjs.org/docs/hooks-reference.html#lazy-initial-state\n const [styledComponentsStyleSheet] = useState(() => new ServerStyleSheet());\n \n useServerInsertedHTML(() => {\n const styles = styledComponentsStyleSheet.getStyleElement();\n styledComponentsStyleSheet.instance.clearTag();\n return <>{styles}</>;\n });\n \n if (isBrowserLike()) return <>{children}</>;\n \n return (\n <StyleSheetManager sheet={styledComponentsStyleSheet.instance}>\n {children}\n </StyleSheetManager>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,mBAAgC;AAChC,wBAAsC;AACtC,+BAAoD;AACpD,iBAA8B;AAcnB;AAZI,SAAR,yBAA0C;AAAA,EAC/C;AACF,GAEG;AAGD,QAAM,CAAC,0BAA0B,QAAI,uBAAS,MAAM,IAAI,0CAAiB,CAAC;AAE1E,+CAAsB,MAAM;AAC1B,UAAM,SAAS,2BAA2B,gBAAgB;AAC1D,+BAA2B,SAAS,SAAS;AAC7C,WAAO,2EAAG,kBAAO;AAAA,EACnB,CAAC;AAED,UAAI,0BAAc,EAAG,QAAO,2EAAG,UAAS;AAExC,SACE,4CAAC,8CAAkB,OAAO,2BAA2B,UAClD,UACH;AAEJ;","names":[]}