@sanity/sdk-react 0.0.0-alpha.18 → 0.0.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (113) hide show
  1. package/README.md +54 -111
  2. package/dist/_chunks-es/useLogOut.js +24 -53
  3. package/dist/_chunks-es/useLogOut.js.map +1 -1
  4. package/dist/assets/bundle-CcAyERuZ.css +11 -0
  5. package/dist/components.d.ts +172 -69
  6. package/dist/components.js +277 -197
  7. package/dist/components.js.map +1 -1
  8. package/dist/hooks.d.ts +49 -4307
  9. package/dist/hooks.js +67 -646
  10. package/dist/hooks.js.map +1 -1
  11. package/dist/index.d.ts +3 -3
  12. package/dist/index.js +2 -10
  13. package/dist/index.js.map +1 -1
  14. package/package.json +42 -36
  15. package/src/_exports/components.ts +13 -3
  16. package/src/_exports/hooks.ts +2 -45
  17. package/src/_exports/index.ts +10 -1
  18. package/src/components/DocumentGridLayout/DocumentGridLayout.stories.tsx +113 -0
  19. package/src/components/DocumentGridLayout/DocumentGridLayout.test.tsx +42 -0
  20. package/src/components/DocumentGridLayout/DocumentGridLayout.tsx +21 -0
  21. package/src/components/DocumentListLayout/DocumentListLayout.stories.tsx +105 -0
  22. package/src/components/DocumentListLayout/DocumentListLayout.test.tsx +42 -0
  23. package/src/components/DocumentListLayout/DocumentListLayout.tsx +12 -0
  24. package/src/components/DocumentPreviewLayout/DocumentPreviewLayout.md +49 -0
  25. package/src/components/DocumentPreviewLayout/DocumentPreviewLayout.stories.tsx +39 -0
  26. package/src/components/DocumentPreviewLayout/DocumentPreviewLayout.test.tsx +30 -0
  27. package/src/components/DocumentPreviewLayout/DocumentPreviewLayout.tsx +171 -0
  28. package/src/components/Login/LoginLinks.test.tsx +12 -3
  29. package/src/components/Login/LoginLinks.tsx +29 -14
  30. package/src/components/auth/AuthBoundary.test.tsx +17 -4
  31. package/src/components/auth/AuthBoundary.tsx +4 -20
  32. package/src/components/auth/Login.test.tsx +16 -2
  33. package/src/components/auth/Login.tsx +30 -11
  34. package/src/components/auth/LoginCallback.test.tsx +17 -2
  35. package/src/components/auth/LoginCallback.tsx +10 -5
  36. package/src/components/auth/LoginError.test.tsx +17 -2
  37. package/src/components/auth/LoginError.tsx +16 -11
  38. package/src/components/auth/LoginFooter.test.tsx +16 -2
  39. package/src/components/auth/LoginFooter.tsx +24 -8
  40. package/src/components/auth/LoginLayout.test.tsx +16 -2
  41. package/src/components/auth/LoginLayout.tsx +38 -8
  42. package/src/{context → components/context}/SanityProvider.test.tsx +2 -2
  43. package/src/components/context/SanityProvider.tsx +42 -0
  44. package/src/css/css.config.js +220 -0
  45. package/src/css/paramour.css +2347 -0
  46. package/src/css/styles.css +11 -0
  47. package/src/hooks/auth/useAuthState.tsx +5 -4
  48. package/src/hooks/auth/useAuthToken.tsx +1 -1
  49. package/src/hooks/auth/useCurrentUser.tsx +4 -27
  50. package/src/hooks/auth/useHandleCallback.tsx +0 -1
  51. package/src/hooks/auth/useLogOut.tsx +1 -1
  52. package/src/hooks/auth/useLoginUrls.tsx +0 -1
  53. package/src/hooks/client/useClient.test.tsx +130 -0
  54. package/src/hooks/client/useClient.ts +30 -8
  55. package/src/hooks/context/useSanityInstance.test.tsx +2 -2
  56. package/src/hooks/context/useSanityInstance.ts +8 -24
  57. package/src/hooks/documentCollection/useDocuments.test.ts +130 -0
  58. package/src/hooks/documentCollection/useDocuments.ts +87 -0
  59. package/src/hooks/helpers/createCallbackHook.tsx +2 -3
  60. package/src/hooks/helpers/createStateSourceHook.test.tsx +0 -66
  61. package/src/hooks/helpers/createStateSourceHook.tsx +10 -29
  62. package/src/hooks/preview/usePreview.test.tsx +10 -19
  63. package/src/hooks/preview/usePreview.tsx +13 -67
  64. package/dist/_chunks-es/SanityInstanceContext.js +0 -6
  65. package/dist/_chunks-es/SanityInstanceContext.js.map +0 -1
  66. package/dist/context.d.ts +0 -47
  67. package/dist/context.js +0 -15
  68. package/dist/context.js.map +0 -1
  69. package/src/_exports/context.ts +0 -2
  70. package/src/components/SDKProvider.test.tsx +0 -79
  71. package/src/components/SDKProvider.tsx +0 -42
  72. package/src/components/SanityApp.test.tsx +0 -156
  73. package/src/components/SanityApp.tsx +0 -90
  74. package/src/components/auth/authTestHelpers.tsx +0 -11
  75. package/src/components/utils.ts +0 -22
  76. package/src/context/SanityInstanceContext.ts +0 -4
  77. package/src/context/SanityProvider.tsx +0 -50
  78. package/src/hooks/_synchronous-groq-js.mjs +0 -4
  79. package/src/hooks/comlink/useFrameConnection.test.tsx +0 -157
  80. package/src/hooks/comlink/useFrameConnection.ts +0 -130
  81. package/src/hooks/comlink/useManageFavorite.test.ts +0 -106
  82. package/src/hooks/comlink/useManageFavorite.ts +0 -98
  83. package/src/hooks/comlink/useRecordDocumentHistoryEvent.test.ts +0 -77
  84. package/src/hooks/comlink/useRecordDocumentHistoryEvent.ts +0 -75
  85. package/src/hooks/comlink/useWindowConnection.test.ts +0 -125
  86. package/src/hooks/comlink/useWindowConnection.ts +0 -94
  87. package/src/hooks/datasets/useDatasets.ts +0 -37
  88. package/src/hooks/document/useApplyActions.test.ts +0 -25
  89. package/src/hooks/document/useApplyActions.ts +0 -74
  90. package/src/hooks/document/useDocument.test.ts +0 -81
  91. package/src/hooks/document/useDocument.ts +0 -107
  92. package/src/hooks/document/useDocumentEvent.test.ts +0 -63
  93. package/src/hooks/document/useDocumentEvent.ts +0 -54
  94. package/src/hooks/document/useDocumentSyncStatus.test.ts +0 -16
  95. package/src/hooks/document/useDocumentSyncStatus.ts +0 -30
  96. package/src/hooks/document/useEditDocument.test.ts +0 -179
  97. package/src/hooks/document/useEditDocument.ts +0 -195
  98. package/src/hooks/document/usePermissions.ts +0 -82
  99. package/src/hooks/infiniteList/useInfiniteList.test.tsx +0 -152
  100. package/src/hooks/infiniteList/useInfiniteList.ts +0 -174
  101. package/src/hooks/paginatedList/usePaginatedList.test.tsx +0 -259
  102. package/src/hooks/paginatedList/usePaginatedList.ts +0 -290
  103. package/src/hooks/projection/useProjection.test.tsx +0 -218
  104. package/src/hooks/projection/useProjection.ts +0 -135
  105. package/src/hooks/projects/useProject.ts +0 -45
  106. package/src/hooks/projects/useProjects.ts +0 -41
  107. package/src/hooks/query/useQuery.test.tsx +0 -188
  108. package/src/hooks/query/useQuery.ts +0 -103
  109. package/src/hooks/users/useUsers.test.ts +0 -163
  110. package/src/hooks/users/useUsers.ts +0 -107
  111. package/src/utils/getEnv.ts +0 -21
  112. package/src/version.ts +0 -8
  113. package/src/vite-env.d.ts +0 -10
@@ -1 +1 @@
1
- {"version":3,"file":"components.js","sources":["../src/components/utils.ts","../src/components/auth/AuthError.ts","../src/components/auth/LoginFooter.tsx","../src/components/auth/LoginLayout.tsx","../src/components/auth/Login.tsx","../src/components/auth/LoginCallback.tsx","../src/components/auth/LoginError.tsx","../src/components/auth/AuthBoundary.tsx","../src/components/SDKProvider.tsx","../src/components/SanityApp.tsx"],"sourcesContent":["export function isInIframe(): boolean {\n return typeof window !== 'undefined' && window.self !== window.top\n}\n\n/**\n * @internal\n *\n * Checks if the current URL is a local URL.\n *\n * @param window - The window object\n * @returns True if the current URL is a local URL, false otherwise\n */\nexport function isLocalUrl(window: Window): boolean {\n const url = typeof window !== 'undefined' ? window.location.href : ''\n\n return (\n url.startsWith('http://localhost') ||\n url.startsWith('https://localhost') ||\n url.startsWith('http://127.0.0.1') ||\n url.startsWith('https://127.0.0.1')\n )\n}\n","/**\n * Error class for authentication-related errors. Wraps errors thrown during the\n * authentication flow.\n *\n * @remarks\n * This class provides a consistent error type for authentication failures while\n * preserving the original error as the cause. If the original error has a\n * message property, it will be used as the error message.\n *\n * @alpha\n */\nexport class AuthError extends Error {\n constructor(error: unknown) {\n if (\n typeof error === 'object' &&\n !!error &&\n 'message' in error &&\n typeof error.message === 'string'\n ) {\n super(error.message)\n } else {\n super()\n }\n\n this.cause = error\n }\n}\n","import {SanityLogo} from '@sanity/logos'\nimport {Fragment} from 'react'\n\nconst LINKS = [\n {\n url: 'https://slack.sanity.io/',\n i18nKey: 'workspaces.community-title',\n title: 'Community',\n },\n {\n url: 'https://www.sanity.io/docs',\n i18nKey: 'workspaces.docs-title',\n title: 'Docs',\n },\n {\n url: 'https://www.sanity.io/legal/privacy',\n i18nKey: 'workspaces.privacy-title',\n title: 'Privacy',\n },\n {\n url: 'https://www.sanity.io',\n i18nKey: 'workspaces.sanity-io-title',\n title: 'sanity.io',\n },\n]\n\n/**\n * Default footer component for login screens showing Sanity branding and legal\n * links.\n *\n * @alpha\n */\nexport function LoginFooter(): React.ReactNode {\n return (\n <div className=\"sc-login-footer\">\n <SanityLogo className=\"sc-login-footer__logo\" />\n\n <ul className=\"sc-login-footer__links\">\n {LINKS.map((link) => (\n <Fragment key={link.title}>\n <li className=\"sc-login-footer__link\">\n <a href={link.url} target=\"_blank\" rel=\"noopener noreferrer\">\n {link.title}\n </a>\n </li>\n </Fragment>\n ))}\n </ul>\n </div>\n )\n}\n","import {LoginFooter} from './LoginFooter'\n\n/**\n * @alpha\n */\nexport interface LoginLayoutProps {\n /** Optional header content rendered at top of card */\n header?: React.ReactNode\n\n /** Optional footer content rendered below card. Defaults to an internal login footer */\n footer?: React.ReactNode\n\n /** Main content rendered in card body */\n children?: React.ReactNode\n}\n\n/**\n * Layout component for login-related screens providing consistent styling and structure.\n * Renders content in a centered card with optional header and footer sections.\n *\n * Can be used to build custom login screens for the AuthBoundary component, including:\n * - Login provider selection (LoginComponent)\n * - OAuth callback handling (CallbackComponent)\n * - Error states (LoginErrorComponent)\n *\n * @example\n * ```tsx\n * // Custom login screen using the layout\n * function CustomLogin({header, footer}: LoginLayoutProps) {\n * return (\n * <LoginLayout\n * header={header}\n * footer={footer}\n * >\n * <CustomLoginContent />\n * </LoginLayout>\n * )\n * }\n *\n * // Use with AuthBoundary\n * <AuthBoundary\n * LoginComponent={CustomLogin}\n * header={<Logo />}\n * >\n * <ProtectedContent />\n * </AuthBoundary>\n * ```\n *\n * @alpha\n */\nexport function LoginLayout({\n children,\n footer = <LoginFooter />,\n header,\n}: LoginLayoutProps): React.ReactNode {\n return (\n <div className=\"sc-login-layout\">\n <div className=\"sc-login-layout__container\">\n <div className=\"sc-login-layout__card\">\n {header && <div className=\"sc-login-layout__card-header\">{header}</div>}\n\n {children && <div className=\"sc-login-layout__card-body\">{children}</div>}\n </div>\n\n {footer}\n </div>\n </div>\n )\n}\n","import {type JSX, Suspense} from 'react'\n\nimport {useLoginUrls} from '../../hooks/auth/useLoginUrls'\nimport {LoginLayout, type LoginLayoutProps} from './LoginLayout'\n\n/**\n * Login component that displays available authentication providers.\n * Renders a list of login options with a loading fallback while providers load.\n *\n * @alpha\n * @internal\n */\nexport function Login({header, footer}: LoginLayoutProps): JSX.Element {\n return (\n <LoginLayout header={header} footer={footer}>\n <div className=\"sc-login\">\n <h1 className=\"sc-login__title\">Choose login provider</h1>\n\n <Suspense fallback={<div className=\"sc-login__loading\">Loading…</div>}>\n <Providers />\n </Suspense>\n </div>\n </LoginLayout>\n )\n}\n\nfunction Providers() {\n const loginUrls = useLoginUrls()\n\n return (\n <div className=\"sc-login-providers\">\n {loginUrls.map(({title, url}) => (\n <a key={url} href={url}>\n {title}\n </a>\n ))}\n </div>\n )\n}\n","import {useEffect} from 'react'\n\nimport {useHandleCallback} from '../../hooks/auth/useHandleCallback'\nimport {LoginLayout, type LoginLayoutProps} from './LoginLayout'\n\n/**\n/**\n * Component shown during auth callback processing that handles login completion.\n * Automatically processes the auth callback when mounted and updates the URL\n * to remove callback parameters without triggering a page reload.\n *\n * @alpha\n */\nexport function LoginCallback({header, footer}: LoginLayoutProps): React.ReactNode {\n const handleCallback = useHandleCallback()\n\n useEffect(() => {\n const url = new URL(location.href)\n handleCallback(url.toString()).then((replacementLocation) => {\n if (replacementLocation) {\n // history API with `replaceState` is used to prevent a reload but still\n // remove the short-lived token from the URL\n history.replaceState(null, '', replacementLocation)\n }\n })\n }, [handleCallback])\n\n return (\n <LoginLayout header={header} footer={footer}>\n <div className=\"sc-login-callback\">\n <h1 className=\"sc-login-callback__title\">Logging you in…</h1>\n <div className=\"sc-login-callback__loading\">Loading…</div>\n </div>\n </LoginLayout>\n )\n}\n","import {useCallback} from 'react'\nimport {type FallbackProps} from 'react-error-boundary'\n\nimport {useLogOut} from '../../hooks/auth/useLogOut'\nimport {AuthError} from './AuthError'\nimport {LoginLayout, type LoginLayoutProps} from './LoginLayout'\n\n/**\n * @alpha\n */\nexport type LoginErrorProps = FallbackProps & LoginLayoutProps\n\n/**\n * Displays authentication error details and provides retry functionality.\n * Only handles {@link AuthError} instances - rethrows other error types.\n *\n * @alpha\n */\nexport function LoginError({\n error,\n resetErrorBoundary,\n header,\n footer,\n}: LoginErrorProps): React.ReactNode {\n if (!(error instanceof AuthError)) throw error\n const logout = useLogOut()\n\n const handleRetry = useCallback(async () => {\n await logout()\n resetErrorBoundary()\n }, [logout, resetErrorBoundary])\n\n return (\n <LoginLayout header={header} footer={footer}>\n <div className=\"sc-login-error\">\n <div className=\"sc-login-error__content\">\n <h2 className=\"sc-login-error__title\">Authentication Error</h2>\n <p className=\"sc-login-error__description\">\n Please try again or contact support if the problem persists.\n </p>\n </div>\n\n <button className=\"sc-login-error__button\" onClick={handleRetry}>\n Retry\n </button>\n </div>\n </LoginLayout>\n )\n}\n","import {AuthStateType} from '@sanity/sdk'\nimport {useMemo} from 'react'\nimport {ErrorBoundary, type FallbackProps} from 'react-error-boundary'\n\nimport {useAuthState} from '../../hooks/auth/useAuthState'\nimport {isInIframe} from '../utils'\nimport {AuthError} from './AuthError'\nimport {Login} from './Login'\nimport {LoginCallback} from './LoginCallback'\nimport {LoginError, type LoginErrorProps} from './LoginError'\nimport {type LoginLayoutProps} from './LoginLayout'\n\n// Only import bridge if we're in an iframe. This assumes that the app is\n// running within SanityOS if it is in an iframe.\nif (isInIframe()) {\n const parsedUrl = new URL(window.location.href)\n const mode = new URLSearchParams(parsedUrl.hash.slice(1)).get('mode')\n const script = document.createElement('script')\n script.src =\n mode === 'core-ui--staging'\n ? 'https://core.sanity-cdn.work/bridge.js'\n : 'https://core.sanity-cdn.com/bridge.js'\n script.type = 'module'\n script.async = true\n document.head.appendChild(script)\n}\n\n/**\n * @internal\n */\ninterface AuthBoundaryProps extends LoginLayoutProps {\n /**\n * Custom component to render the login screen.\n * Receives all login layout props. Defaults to {@link Login}.\n */\n LoginComponent?: React.ComponentType<LoginLayoutProps>\n\n /**\n * Custom component to render during OAuth callback processing.\n * Receives all login layout props. Defaults to {@link LoginCallback}.\n */\n CallbackComponent?: React.ComponentType<LoginLayoutProps>\n\n /**\n * Custom component to render when authentication errors occur.\n * Receives login layout props and error boundary props. Defaults to\n * {@link LoginError}\n */\n LoginErrorComponent?: React.ComponentType<LoginErrorProps>\n}\n\n/**\n * A component that handles authentication flow and error boundaries for a\n * protected section of the application.\n *\n * @remarks\n * This component manages different authentication states and renders the\n * appropriate components based on that state.\n *\n * @example\n * ```tsx\n * function App() {\n * return (\n * <AuthBoundary header={<MyLogo />}>\n * <ProtectedContent />\n * </AuthBoundary>\n * )\n * }\n * ```\n *\n * @internal\n */\nexport function AuthBoundary({\n LoginErrorComponent = LoginError,\n ...props\n}: AuthBoundaryProps): React.ReactNode {\n const {header, footer} = props\n const FallbackComponent = useMemo(() => {\n return function LoginComponentWithLayoutProps(fallbackProps: FallbackProps) {\n return <LoginErrorComponent {...fallbackProps} header={header} footer={footer} />\n }\n }, [header, footer, LoginErrorComponent])\n\n return (\n <ErrorBoundary FallbackComponent={FallbackComponent}>\n <AuthSwitch {...props} />\n </ErrorBoundary>\n )\n}\n\ninterface AuthSwitchProps extends LoginLayoutProps {\n LoginComponent?: React.ComponentType<LoginLayoutProps>\n CallbackComponent?: React.ComponentType<LoginLayoutProps>\n}\n\nfunction AuthSwitch({\n LoginComponent = Login,\n CallbackComponent = LoginCallback,\n children,\n ...props\n}: AuthSwitchProps) {\n const authState = useAuthState()\n\n switch (authState.type) {\n case AuthStateType.ERROR: {\n throw new AuthError(authState.error)\n }\n case AuthStateType.LOGGING_IN: {\n return <CallbackComponent {...props} />\n }\n case AuthStateType.LOGGED_IN: {\n return children\n }\n default: {\n return <LoginComponent {...props} />\n }\n }\n}\n","import {createSanityInstance, type SanityConfig} from '@sanity/sdk'\nimport {type ReactElement, type ReactNode, Suspense, useMemo} from 'react'\n\nimport {SanityProvider} from '../context/SanityProvider'\nimport {AuthBoundary} from './auth/AuthBoundary'\n\nconst DEFAULT_FALLBACK = (\n <>\n Warning: No fallback provided. Please supply a fallback prop to ensure proper Suspense handling.\n </>\n)\n\n/**\n * @internal\n */\nexport interface SDKProviderProps {\n children: ReactNode\n sanityConfigs: SanityConfig[]\n fallback: ReactNode\n}\n\n/**\n * @internal\n *\n * Top-level context provider that provides access to the Sanity SDK.\n */\nexport function SDKProvider({children, sanityConfigs, fallback}: SDKProviderProps): ReactElement {\n const sanityInstances = useMemo(() => {\n return sanityConfigs.map((sanityConfig: SanityConfig) => createSanityInstance(sanityConfig))\n }, [sanityConfigs])\n\n return (\n <SanityProvider sanityInstances={sanityInstances}>\n {/* This Suspense boundary is necessary because some hooks may suspend.\n It ensures that the Sanity instance state created above remains stable\n before rendering the AuthBoundary and its children. */}\n <Suspense fallback={fallback ?? DEFAULT_FALLBACK}>\n <AuthBoundary>{children}</AuthBoundary>\n </Suspense>\n </SanityProvider>\n )\n}\n","import {type SanityConfig} from '@sanity/sdk'\nimport {type ReactElement, useEffect} from 'react'\n\nimport {SDKProvider} from './SDKProvider'\nimport {isInIframe, isLocalUrl} from './utils'\n\n/**\n * @public\n */\nexport interface SanityAppProps {\n sanityConfigs: SanityConfig[]\n children: React.ReactNode\n fallback: React.ReactNode\n}\n\nconst CORE_URL = 'https://core.sanity.io'\n\n/**\n * @public\n *\n * The SanityApp component provides your Sanity application with access to your Sanity configuration,\n * as well as application context and state which is used by the Sanity React hooks. Your application\n * must be wrapped with the SanityApp component to function properly.\n *\n * @param props - Your Sanity configuration and the React children to render\n * @returns Your Sanity application, integrated with your Sanity configuration and application context\n *\n * @example\n * ```tsx\n * import { SanityApp } from '@sanity/sdk-react'\n *\n * import MyAppRoot from './Root'\n *\n * // Single project configuration\n * const mySanityConfigs = [\n * {\n * projectId: 'my-project-id',\n * dataset: 'production',\n * },\n * ]\n *\n * // Or multiple project configurations\n * const multipleConfigs = [\n * // Configuration for your main project. This will be used as the default project for all hooks if no resource ID override is provided.\n * {\n * projectId: 'marketing-website-project',\n * dataset: 'production',\n * },\n * // Configuration for a separate blog project\n * {\n * projectId: 'blog-project',\n * dataset: 'production',\n * },\n * // Configuration for a separate ecommerce project\n * {\n * projectId: 'ecommerce-project',\n * dataset: 'production',\n * }\n * ]\n *\n * export default function MyApp() {\n * return (\n * <SanityApp sanityConfigs={mySanityConfigs}>\n * <MyAppRoot />\n * </SanityApp>\n * )\n * }\n * ```\n */\nexport function SanityApp({sanityConfigs, children, fallback}: SanityAppProps): ReactElement {\n useEffect(() => {\n let timeout: NodeJS.Timeout | undefined\n\n if (!isInIframe() && !isLocalUrl(window)) {\n // If the app is not running in an iframe and is not a local url, redirect to core.\n timeout = setTimeout(() => {\n // eslint-disable-next-line no-console\n console.warn('Redirecting to core', CORE_URL)\n window.location.replace(CORE_URL)\n }, 1000)\n }\n return () => clearTimeout(timeout)\n }, [sanityConfigs])\n\n return (\n <SDKProvider sanityConfigs={sanityConfigs} fallback={fallback}>\n {children}\n </SDKProvider>\n )\n}\n"],"names":["isInIframe","window","self","top","isLocalUrl","url","location","href","startsWith","AuthError","Error","constructor","error","message","cause","LINKS","i18nKey","title","LoginFooter","$","_c","t0","Symbol","for","t1","map","_temp","link","LoginLayout","children","footer","header","Login","t2","t3","Providers","loginUrls","useLoginUrls","LoginCallback","handleCallback","useHandleCallback","URL","toString","then","useEffect","t4","replacementLocation","history","replaceState","LoginError","resetErrorBoundary","logout","useLogOut","handleRetry","parsedUrl","mode","URLSearchParams","hash","slice","get","script","document","createElement","src","type","async","head","appendChild","AuthBoundary","props","LoginErrorComponent","undefined","fallbackProps","FallbackComponent","t5","AuthSwitch","LoginComponent","CallbackComponent","authState","useAuthState","AuthStateType","ERROR","LOGGING_IN","LOGGED_IN","DEFAULT_FALLBACK","SDKProvider","sanityConfigs","fallback","sanityInstances","t6","sanityConfig","createSanityInstance","CORE_URL","SanityApp","_temp2","timeout","clearTimeout","console","warn","replace"],"mappings":"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"}
1
+ {"version":3,"file":"components.js","sources":["../src/components/auth/AuthError.ts","../src/components/auth/LoginFooter.tsx","../src/components/auth/LoginLayout.tsx","../src/components/auth/Login.tsx","../src/components/auth/LoginCallback.tsx","../src/components/auth/LoginError.tsx","../src/components/auth/AuthBoundary.tsx","../src/components/DocumentGridLayout/DocumentGridLayout.tsx","../src/components/DocumentListLayout/DocumentListLayout.tsx","../src/components/DocumentPreviewLayout/DocumentPreviewLayout.tsx","../src/components/Login/LoginLinks.tsx"],"sourcesContent":["/**\n * Error class for authentication-related errors. Wraps errors thrown during the\n * authentication flow.\n *\n * @remarks\n * This class provides a consistent error type for authentication failures while\n * preserving the original error as the cause. If the original error has a\n * message property, it will be used as the error message.\n *\n * @alpha\n */\nexport class AuthError extends Error {\n constructor(error: unknown) {\n if (\n typeof error === 'object' &&\n !!error &&\n 'message' in error &&\n typeof error.message === 'string'\n ) {\n super(error.message)\n } else {\n super()\n }\n\n this.cause = error\n }\n}\n","import {SanityLogo} from '@sanity/logos'\nimport {Flex, Text} from '@sanity/ui'\nimport {Fragment} from 'react'\nimport styled from 'styled-components'\n\nconst LINKS = [\n {\n url: 'https://slack.sanity.io/',\n i18nKey: 'workspaces.community-title',\n title: 'Community',\n },\n {\n url: 'https://www.sanity.io/docs',\n i18nKey: 'workspaces.docs-title',\n title: 'Docs',\n },\n {\n url: 'https://www.sanity.io/legal/privacy',\n i18nKey: 'workspaces.privacy-title',\n title: 'Privacy',\n },\n {\n url: 'https://www.sanity.io',\n i18nKey: 'workspaces.sanity-io-title',\n title: 'sanity.io',\n },\n]\n\nconst StyledText = styled(Text)`\n a {\n color: inherit;\n }\n`\n\n/**\n * Default footer component for login screens showing Sanity branding and legal\n * links.\n *\n * @alpha\n */\nexport function LoginFooter(): React.ReactNode {\n return (\n <Flex direction=\"column\" gap={4} justify=\"center\" align=\"center\" paddingTop={2}>\n <Text size={3}>\n <SanityLogo />\n </Text>\n\n <Flex align=\"center\" gap={2}>\n {LINKS.map((link, index) => (\n <Fragment key={link.title}>\n <StyledText muted size={1}>\n <a href={link.url} target=\"_blank\" rel=\"noopener noreferrer\">\n {link.title}\n </a>\n </StyledText>\n\n {index < LINKS.length - 1 && (\n <Text size={1} muted>\n •\n </Text>\n )}\n </Fragment>\n ))}\n </Flex>\n </Flex>\n )\n}\n","import {Card, Flex} from '@sanity/ui'\nimport styled from 'styled-components'\n\nimport {LoginFooter} from './LoginFooter'\n\n/**\n * @alpha\n */\nexport interface LoginLayoutProps {\n /** Optional header content rendered at top of card */\n header?: React.ReactNode\n\n /** Optional footer content rendered below card. Defaults to an internal login footer */\n footer?: React.ReactNode\n\n /** Main content rendered in card body */\n children?: React.ReactNode\n}\n\nconst Root = styled.div`\n width: 100%;\n display: flex;\n`\n\nconst Container = styled(Flex)`\n width: 320px;\n margin: auto;\n display: flex;\n`\n\nconst StyledCard = styled(Card)``\n\nconst ChildrenFlex = styled(Flex)`\n min-height: 154px;\n`\n\n/**\n * Layout component for login-related screens providing consistent styling and structure.\n * Renders content in a centered card with optional header and footer sections.\n *\n * Can be used to build custom login screens for the AuthBoundary component, including:\n * - Login provider selection (LoginComponent)\n * - OAuth callback handling (CallbackComponent)\n * - Error states (LoginErrorComponent)\n *\n * @example\n * ```tsx\n * // Custom login screen using the layout\n * function CustomLogin({header, footer}: LoginLayoutProps) {\n * return (\n * <LoginLayout\n * header={header}\n * footer={footer}\n * >\n * <CustomLoginContent />\n * </LoginLayout>\n * )\n * }\n *\n * // Use with AuthBoundary\n * <AuthBoundary\n * LoginComponent={CustomLogin}\n * header={<Logo />}\n * >\n * <ProtectedContent />\n * </AuthBoundary>\n * ```\n *\n * @alpha\n */\nexport function LoginLayout({\n children,\n footer = <LoginFooter />,\n header,\n}: LoginLayoutProps): React.ReactNode {\n return (\n <Root>\n <Container direction=\"column\" gap={4}>\n <StyledCard border radius={2} paddingY={4}>\n <Flex direction=\"column\" gap={4}>\n {header && (\n <Card borderBottom paddingX={4} paddingBottom={3}>\n {header}\n </Card>\n )}\n\n {children && (\n <ChildrenFlex paddingX={4} direction=\"column\">\n {children}\n </ChildrenFlex>\n )}\n </Flex>\n </StyledCard>\n\n {footer}\n </Container>\n </Root>\n )\n}\n","import {Button, Flex, Heading, Spinner} from '@sanity/ui'\nimport {Suspense} from 'react'\nimport styled from 'styled-components'\n\nimport {useLoginUrls} from '../../hooks/auth/useLoginUrls'\nimport {LoginLayout, type LoginLayoutProps} from './LoginLayout'\n\n/**\n * @alpha\n */\nexport interface LoginProps {\n header?: React.ReactNode\n footer?: React.ReactNode\n}\n\nconst FallbackRoot = styled(Flex)`\n height: 123px;\n`\n\n/**\n * Login component that displays available authentication providers.\n * Renders a list of login options with a loading fallback while providers load.\n *\n * @alpha\n */\nexport function Login({header, footer}: LoginLayoutProps): JSX.Element {\n return (\n <LoginLayout header={header} footer={footer}>\n <Flex direction=\"column\" gap={4}>\n <Heading as=\"h1\" size={1} align=\"center\">\n Choose login provider\n </Heading>\n\n <Suspense\n fallback={\n <FallbackRoot align=\"center\" justify=\"center\">\n <Spinner />\n </FallbackRoot>\n }\n >\n <Providers />\n </Suspense>\n </Flex>\n </LoginLayout>\n )\n}\n\nfunction Providers() {\n const loginUrls = useLoginUrls()\n\n return (\n <Flex direction=\"column\" gap={3}>\n {loginUrls.map(({title, url}) => (\n <Button key={url} text={title} as=\"a\" href={url} mode=\"ghost\" />\n ))}\n </Flex>\n )\n}\n","import {Flex, Spinner, Text} from '@sanity/ui'\nimport {useEffect} from 'react'\nimport styled from 'styled-components'\n\nimport {useHandleCallback} from '../../hooks/auth/useHandleCallback'\nimport {LoginLayout, type LoginLayoutProps} from './LoginLayout'\n\nconst StyledFlex = styled(Flex)`\n margin: auto;\n`\n\n/**\n * Component shown during auth callback processing that handles login completion.\n * Automatically processes the auth callback when mounted and updates the URL\n * to remove callback parameters without triggering a page reload.\n *\n * @alpha\n */\nexport function LoginCallback({header, footer}: LoginLayoutProps): React.ReactNode {\n const handleCallback = useHandleCallback()\n\n useEffect(() => {\n const url = new URL(location.href)\n handleCallback(url.toString()).then((replacementLocation) => {\n if (replacementLocation) {\n // history API with `replaceState` is used to prevent a reload but still\n // remove the short-lived token from the URL\n history.replaceState(null, '', replacementLocation)\n }\n })\n }, [handleCallback])\n\n return (\n <LoginLayout header={header} footer={footer}>\n <StyledFlex direction=\"column\" justify=\"center\" align=\"center\" gap={4}>\n <Text size={1}>Logging you in…</Text>\n <Spinner size={4} />\n </StyledFlex>\n </LoginLayout>\n )\n}\n","import {Button, Flex, Text} from '@sanity/ui'\nimport {useCallback} from 'react'\nimport {type FallbackProps} from 'react-error-boundary'\nimport styled from 'styled-components'\n\nimport {useLogOut} from '../../hooks/auth/useLogOut'\nimport {AuthError} from './AuthError'\nimport {LoginLayout, type LoginLayoutProps} from './LoginLayout'\n\n/**\n * @alpha\n */\nexport type LoginErrorProps = FallbackProps & LoginLayoutProps\n\nconst StyledFlex = styled(Flex)`\n margin: auto;\n`\n\n/**\n * Displays authentication error details and provides retry functionality.\n * Only handles {@link AuthError} instances - rethrows other error types.\n *\n * @alpha\n */\nexport function LoginError({\n error,\n resetErrorBoundary,\n header,\n footer,\n}: LoginErrorProps): React.ReactNode {\n if (!(error instanceof AuthError)) throw error\n const logout = useLogOut()\n\n const handleRetry = useCallback(async () => {\n await logout()\n resetErrorBoundary()\n }, [logout, resetErrorBoundary])\n\n return (\n <LoginLayout header={header} footer={footer}>\n <StyledFlex direction=\"column\" gap={4}>\n <Flex direction=\"column\" gap={3}>\n <Text as=\"h2\" align=\"center\" weight=\"bold\" size={3}>\n Authentication Error\n </Text>\n <Text size={1} align=\"center\">\n Please try again or contact support if the problem persists.\n </Text>\n </Flex>\n <Button text=\"Retry\" tone=\"primary\" onClick={handleRetry} />\n </StyledFlex>\n </LoginLayout>\n )\n}\n","import {AuthStateType} from '@sanity/sdk'\nimport {useMemo} from 'react'\nimport {ErrorBoundary, type FallbackProps} from 'react-error-boundary'\n\nimport {useAuthState} from '../../hooks/auth/useAuthState'\nimport {AuthError} from './AuthError'\nimport {Login} from './Login'\nimport {LoginCallback} from './LoginCallback'\nimport {LoginError, type LoginErrorProps} from './LoginError'\nimport type {LoginLayoutProps} from './LoginLayout'\n\n/**\n * @alpha\n */\nexport interface AuthBoundaryProps extends LoginLayoutProps {\n /**\n * Custom component to render the login screen.\n * Receives all login layout props. Defaults to {@link Login}.\n */\n LoginComponent?: React.ComponentType<LoginLayoutProps>\n\n /**\n * Custom component to render during OAuth callback processing.\n * Receives all login layout props. Defaults to {@link LoginCallback}.\n */\n CallbackComponent?: React.ComponentType<LoginLayoutProps>\n\n /**\n * Custom component to render when authentication errors occur.\n * Receives login layout props and error boundary props. Defaults to\n * {@link LoginError}\n */\n LoginErrorComponent?: React.ComponentType<LoginErrorProps>\n}\n\n/**\n * A component that handles authentication flow and error boundaries for a\n * protected section of the application.\n *\n * @remarks\n * This component manages different authentication states and renders the\n * appropriate components based on that state.\n *\n * @example\n * ```tsx\n * function App() {\n * return (\n * <AuthBoundary header={<MyLogo />}>\n * <ProtectedContent />\n * </AuthBoundary>\n * )\n * }\n * ```\n *\n * @alpha\n */\nexport function AuthBoundary({\n LoginErrorComponent = LoginError,\n ...props\n}: AuthBoundaryProps): React.ReactNode {\n const {header, footer} = props\n const FallbackComponent = useMemo(() => {\n return function LoginComponentWithLayoutProps(fallbackProps: FallbackProps) {\n return <LoginErrorComponent {...fallbackProps} header={header} footer={footer} />\n }\n }, [header, footer, LoginErrorComponent])\n\n return (\n <ErrorBoundary FallbackComponent={FallbackComponent}>\n <AuthSwitch {...props} />\n </ErrorBoundary>\n )\n}\n\ninterface AuthSwitchProps extends LoginLayoutProps {\n LoginComponent?: React.ComponentType<LoginLayoutProps>\n CallbackComponent?: React.ComponentType<LoginLayoutProps>\n}\n\nfunction AuthSwitch({\n LoginComponent = Login,\n CallbackComponent = LoginCallback,\n children,\n ...props\n}: AuthSwitchProps) {\n const authState = useAuthState()\n\n switch (authState.type) {\n case AuthStateType.ERROR: {\n throw new AuthError(authState.error)\n }\n case AuthStateType.LOGGING_IN: {\n return <CallbackComponent {...props} />\n }\n case AuthStateType.LOGGED_IN: {\n return children\n }\n default: {\n return <LoginComponent {...props} />\n }\n }\n}\n","import '../../css/styles.css'\n\nimport type {PropsWithChildren, ReactElement} from 'react'\n\n/**\n * @public\n */\nexport const DocumentGridLayout = (props: PropsWithChildren): ReactElement => {\n return (\n <>\n <style>{`\n .DocumentGridLayout {\n grid-template-columns: repeat(auto-fit, minmax(38ch, 1fr));\n }\n `}</style>\n <ol className=\"DocumentGridLayout list-none grid\">{props.children}</ol>\n </>\n )\n}\n\nDocumentGridLayout.displayName = 'DocumentGridLayout'\n","import '../../css/styles.css'\n\nimport type {PropsWithChildren, ReactElement} from 'react'\n\n/**\n * @public\n */\nexport const DocumentListLayout = (props: PropsWithChildren): ReactElement => {\n return <ol className=\"DocumentListLayout list-none\">{props.children}</ol>\n}\n\nDocumentListLayout.displayName = 'DocumentListLayout'\n","import 'inter-ui/inter.css'\nimport '../../css/styles.css'\n\nimport {DocumentIcon} from '@sanity/icons'\nimport {forwardRef} from 'react'\n\n/**\n * @public\n */\nexport interface DocumentPreviewLayoutProps {\n docType?: string\n media?: {type: string; url: string} | null | undefined\n onClick?: () => void\n selected?: boolean\n status?: string\n subtitle?: string\n title: string\n}\n\n/**\n * This is a component that renders a document preview.\n *\n * @public\n *\n * @param props - The props for the DocumentPreviewLayout component.\n * @returns - The DocumentPreviewLayout component.\n */\nexport const DocumentPreviewLayout = forwardRef(\n (\n {\n docType,\n media,\n onClick,\n selected = false,\n status = '',\n subtitle = '',\n title,\n }: DocumentPreviewLayoutProps,\n ref: React.Ref<HTMLElement>,\n ): JSX.Element => {\n // @TODO: empty state\n if (!title) {\n return <></>\n }\n\n let PreviewMedia\n\n if (media?.url) {\n const baseUrl = new URL(media.url)\n baseUrl.searchParams.set('h', '66')\n baseUrl.searchParams.set('w', '66')\n baseUrl.searchParams.set('fit', 'crop')\n const mediaUrl = baseUrl.toString()\n // media url string params for sanity img\n PreviewMedia = <img src={mediaUrl} alt=\"\" />\n } else {\n PreviewMedia = <DocumentIcon />\n }\n\n return (\n <>\n <style>{`\n .DocumentPreviewLayout {\n --_hoverFocusBg: light-dark(var(--shade-11), var(--tint-1));\n --_selectedBg: light-dark(var(--blue-10), var(--blue-2));\n --_selectedFg: light-dark(var(--gray-1), var(--gray-10));\n --_titleFg: light-dark(var(--gray-1), var(--gray-10));\n --_subtitleFg: light-dark(var(--gray-4), var(--gray-7));\n --_docTypeFg: light-dark(var(--gray-1), var(--gray-10));\n --_docTypeBg: light-dark(var(--shade-10), var(--tint-1));\n --_publishedFg: light-dark(var(--gray-1), var(--gray-10));\n --_publishedBg: light-dark(var(--green-10), var(--green-2));\n --_draftFg: light-dark(var(--gray-1), var(--gray-10));\n --_draftBg: light-dark(var(--yellow-6), var(--yellow-2));\n\n appearance: none;\n\n &:has(:hover, focus) {\n background-color: var(--hoverFocusBg, var(--_hoverFocusBg));\n }\n\n &.selected {\n background-color: var(--selectedBg, var(--_selectedBg));\n color: var(--selectedFg, var(--_selectedFg));\n }\n\n .Title {\n color: var(--titleFg, var(--_titleFg));\n }\n\n &:not(.selected) .Subtitle {\n color: var(--subtitleFg, var(--_subtitleFg));\n }\n\n .Media {\n aspect-ratio: 1;\n inline-size: 33px;\n border-color: var(--gray-8);\n }\n\n .DocType {\n color: var(--docTypeFg, var(--_docTypeFg));\n background-color: var(--docTypeBg, var(--_docTypeBg));\n }\n\n .Published {\n color: var(--publishedFg, var(--_publishedFg));\n background-color: var(--publishedBg, var(--_publishedBg));\n }\n\n .Draft {\n color: var(--draftFg, var(--_draftFg));\n background-color: var(--draftBg, var(--_draftBg));\n }\n\n :is(.Published, .Draft) figcaption {\n @container (width < 52ch) {\n clip: rect(0 0 0 0);\n clip-path: inset(50%);\n height: 1px;\n overflow: hidden;\n position: absolute;\n white-space: nowrap;\n width: 1px;\n }\n }\n\n }\n `}</style>\n <button\n onClick={onClick}\n ref={ref as React.Ref<HTMLButtonElement>}\n className={`DocumentPreviewLayout block si-100 text-start p-1 radius1 ${selected ? 'selected' : ''}`}\n >\n <div className=\"container-inline flex align-items-center gap-2 font-sans\">\n <figure className=\"Media border0 border-solid flex-none flex align-items-center justify-content-center object-cover\">\n {PreviewMedia}\n </figure>\n\n <div className=\"leading2 flex-grow overflow-hidden\">\n <p className=\"Title text-1 font-medium truncate\">{title}</p>\n {subtitle && <p className=\"Subtitle text-1 truncate\">{subtitle}</p>}\n </div>\n\n {docType && (\n <figure className=\"DocType inline-block pb-5 pi-3 radius-pill text-2\">\n <figcaption className=\"inline\">{docType}</figcaption>\n </figure>\n )}\n\n {/* @TODO: finalize UI for this */}\n {status === 'published' && (\n <figure className=\"Published inline-block pb-5 pi-3 radius-pill text-2\">\n ✔︎ <figcaption className=\"inline\">published</figcaption>\n </figure>\n )}\n\n {/* @TODO: finalize UI for this */}\n {status === 'draft' && (\n <figure className=\"Draft inline-block pb-5 pi-3 radius-pill text-2\">\n ⛑︎ <figcaption className=\"inline\">draft</figcaption>\n </figure>\n )}\n </div>\n </button>\n </>\n )\n },\n)\n\nDocumentPreviewLayout.displayName = 'DocumentPreviewLayout'\n","import {Button, Card, Container, Flex, Heading, Stack} from '@sanity/ui'\nimport {type ReactElement} from 'react'\n\nimport {useAuthState} from '../../hooks/auth/useAuthState'\nimport {useHandleCallback} from '../../hooks/auth/useHandleCallback'\nimport {useLoginUrls} from '../../hooks/auth/useLoginUrls'\n\n/**\n * Component that handles Sanity authentication flow and renders login provider options\n *\n * @public\n *\n * @returns Rendered component\n *\n * @remarks\n * The component handles three states:\n * 1. Loading state during token exchange\n * 2. Success state after successful authentication\n * 3. Provider selection UI when not authenticated\n *\n * @example\n * ```tsx\n * const config = { projectId: 'your-project-id', dataset: 'production' }\n * return <LoginLinks sanityInstance={config} />\n * ```\n */\nexport const LoginLinks = (): ReactElement => {\n const loginUrls = useLoginUrls()\n const authState = useAuthState()\n useHandleCallback()\n\n if (authState.type === 'logging-in') {\n return <div>Logging in...</div>\n }\n\n // Show success state after authentication\n if (authState.type === 'logged-in') {\n return <div>You are logged in</div>\n }\n\n /**\n * Render provider selection UI\n * Uses Sanity UI components for consistent styling\n */\n return (\n <Card height=\"fill\" overflow=\"auto\" paddingX={4}>\n <Flex height=\"fill\" direction=\"column\" align=\"center\" justify=\"center\" paddingTop={4}>\n <Container width={0}>\n <Stack space={4}>\n <Heading align=\"center\" size={1}>\n Choose login provider\n </Heading>\n\n <Stack space={2}>\n {loginUrls.map((provider, index) => (\n <Button\n key={`${provider.url}_${index}`}\n as=\"a\"\n href={provider.url}\n mode=\"ghost\"\n tone=\"default\"\n space={3}\n padding={3}\n text={provider.title}\n />\n ))}\n </Stack>\n </Stack>\n </Container>\n </Flex>\n </Card>\n )\n}\n"],"names":["StyledFlex","Fragment","Container"],"mappings":"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"}